.ofi-cp-checkout{max-width:1140px;margin:32px auto;padding:0 16px;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:#0f172a}
.ofi-cp-checkout-shell{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(320px,.85fr);gap:28px;align-items:start}
.ofi-cp-checkout-main,.ofi-cp-order-box,.ofi-cp-thankyou{padding:28px;border:1px solid #e2e8f0;border-radius:24px;background:#fff;box-shadow:0 18px 48px rgba(15,23,42,.06)}
.ofi-cp-hero-card{padding:0 0 18px;margin-bottom:20px;border-bottom:1px solid #eff6ff}.ofi-cp-topline{display:inline-flex;align-items:center;padding:7px 12px;border-radius:999px;background:#eff6ff;color:#2563eb;font-size:12px;font-weight:700;letter-spacing:.02em;margin-bottom:14px}.ofi-cp-title{margin:0 0 12px;font-size:34px;line-height:1.08;letter-spacing:-.03em}.ofi-cp-price-stack{margin-bottom:14px}.ofi-cp-regular-price{font-size:18px;color:#64748b;text-decoration:line-through;margin-bottom:6px}.ofi-cp-price-row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.ofi-cp-price{font-size:42px;line-height:1;font-weight:700;color:#0f172a;letter-spacing:-.04em}.ofi-cp-offer-badge{display:inline-flex;align-items:center;min-height:32px;padding:6px 12px;border-radius:999px;background:#dbeafe;color:#1d4ed8;font-size:13px;font-weight:700}.ofi-cp-save-line{font-size:14px;color:#2563eb;font-weight:700;margin-top:8px}.ofi-cp-desc{font-size:15px;line-height:1.7;color:#334155}.ofi-cp-sandbox-note{padding:12px 14px;background:#fffaf5;color:#9a3412;border:1px solid #fed7aa;border-radius:12px;font-size:13px;margin-top:14px}
.ofi-cp-section-title{font-size:13px;text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:#475569;margin:14px 0 12px}.ofi-cp-grid-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 16px}.ofi-cp-field{margin:0}.ofi-cp-field-full{grid-column:1 / -1}.ofi-cp-field-half{grid-column:auto}.ofi-cp-form p{margin:0 0 14px}.ofi-cp-form label{display:block;font-weight:700;margin-bottom:7px;color:#0f172a;font-size:14px}.ofi-cp-form input[type=text],.ofi-cp-form input[type=email],.ofi-cp-form input[type=url],.ofi-cp-form input[type=number],.ofi-cp-form select,.ofi-cp-form textarea{width:100%;height:44px;padding:10px 14px;border:1px solid #cfd8e3;border-radius:10px;background:#fff;box-shadow:0 1px 2px rgba(15,23,42,.06), inset 0 1px 0 rgba(255,255,255,.9);transition:border-color .2s ease,box-shadow .2s ease,color .2s ease}.ofi-cp-form textarea{height:auto;min-height:96px}.ofi-cp-form input::placeholder,.ofi-cp-form textarea::placeholder{color:#9ca3af}.ofi-cp-form select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,#64748b 50%),linear-gradient(135deg,#64748b 50%,transparent 50%);background-position:calc(100% - 18px) calc(50% - 3px),calc(100% - 12px) calc(50% - 3px);background-size:6px 6px,6px 6px;background-repeat:no-repeat;padding-right:34px}.ofi-cp-form input:focus,.ofi-cp-form select:focus,.ofi-cp-form textarea:focus{outline:none;border-color:#93c5fd;box-shadow:0 0 0 3px rgba(37,99,235,.10),0 1px 2px rgba(15,23,42,.06)}.ofi-cp-help{display:block;font-size:12px;color:#64748b;margin-top:6px}
.ofi-cp-bump{padding:14px 16px;background:linear-gradient(180deg,#f8fbff 0%,#f1f5f9 100%);border:1px solid #dbeafe;border-radius:16px}.ofi-cp-bump label{display:flex;justify-content:space-between;gap:14px;align-items:center}.ofi-cp-bump strong{color:#1d4ed8}
.ofi-cp-gateways{display:flex;gap:12px;margin:0 0 18px;flex-wrap:wrap}.ofi-cp-gateways label{display:flex;align-items:center;gap:10px;padding:12px 16px;border:1px solid #cbd5e1;border-radius:999px;background:#f8fafc;font-weight:700;color:#0f172a}
.ofi-cp-panel{border:1px solid #dbeafe;border-radius:18px;padding:18px;background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);margin-bottom:18px}.ofi-cp-panel-title{font-weight:700;font-size:16px;margin-bottom:6px}.ofi-cp-panel-desc{font-size:14px;color:#475569;margin-bottom:12px}.ofi-cp-card-element{padding:16px;border:1px solid #cbd5e1;border-radius:14px;background:#fff}.ofi-cp-paypal-buttons{min-height:46px}
.ofi-cp-submit{background:#1677d3;color:#fff;border:0;padding:16px 20px;border-radius:16px;font-weight:700;font-size:16px;cursor:pointer;width:100%;box-shadow:0 10px 24px rgba(22,119,211,.24);transition:transform .15s ease,opacity .2s ease,box-shadow .2s ease}.ofi-cp-submit:hover{transform:translateY(-1px);box-shadow:0 14px 28px rgba(22,119,211,.28)}.ofi-cp-submit.is-loading{opacity:.7;cursor:wait}.ofi-cp-message{margin-top:14px;font-size:14px;min-height:20px}.ofi-cp-message.is-error{color:#b91c1c}.ofi-cp-message.is-success{color:#166534}.ofi-cp-message.is-info{color:#1d4ed8}
.ofi-cp-order-box{position:sticky;top:24px;background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%)}.ofi-cp-order-box h4{margin:0 0 18px;font-size:24px;letter-spacing:-.03em}.ofi-cp-order-line,.ofi-cp-order-total{display:flex;justify-content:space-between;gap:12px;padding:14px 0;border-bottom:1px solid #e5edf7}.ofi-cp-order-line.is-muted{color:#64748b;font-size:14px}.ofi-cp-order-total{font-size:22px;font-weight:700;border-bottom:0;padding-top:18px}.ofi-cp-checkout-points{margin:18px 0 0;padding-left:18px;color:#334155;line-height:1.8}
.ofi-cp-thankyou-wrap{max-width:1120px;margin:34px auto;padding:0 16px;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}.ofi-cp-thankyou-shell{max-width:920px;margin:0 auto;padding:34px;border:1px solid #e2e8f0;border-radius:28px;background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);box-shadow:0 22px 60px rgba(15,23,42,.08)}.ofi-cp-thankyou{max-width:none;margin:0}.ofi-cp-thankyou-header{text-align:center;margin-bottom:24px}.ofi-cp-thankyou-icon{width:76px;height:76px;margin:0 auto 14px;border-radius:999px;background:rgba(52,211,153,.14);color:#10b981;display:flex;align-items:center;justify-content:center;font-size:42px;font-weight:700}.ofi-cp-thankyou-icon.is-pending{background:rgba(59,130,246,.12);color:#2563eb}.ofi-cp-thankyou-title{margin:0 0 8px;font-size:42px;line-height:1.05;letter-spacing:-.04em;color:#0f172a}.ofi-cp-thankyou-subtitle{max-width:620px;margin:0 auto;color:#475569;font-size:16px;line-height:1.7}.ofi-cp-thankyou-total-card{max-width:380px;margin:0 auto 24px;padding:18px 22px;border-radius:22px;background:#fff;border:1px solid #dbeafe;box-shadow:0 12px 32px rgba(37,99,235,.08);text-align:center}.ofi-cp-thankyou-total-label{font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:#64748b;font-weight:700;margin-bottom:6px}.ofi-cp-thankyou-total-value{font-size:38px;font-weight:700;letter-spacing:-.04em;color:#0f172a}.ofi-cp-thankyou-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(300px,.8fr);gap:22px;margin-bottom:22px}.ofi-cp-thankyou-card{padding:24px;border:1px solid #e2e8f0;border-radius:22px;background:#fff;box-shadow:0 12px 32px rgba(15,23,42,.05)}.ofi-cp-thankyou-card-primary{border-color:#dbeafe}.ofi-cp-thankyou-card-details{background:linear-gradient(180deg,#fff 0%,#f8fbff 100%)}.ofi-cp-thankyou-card-title{font-size:22px;font-weight:700;letter-spacing:-.03em;color:#0f172a;margin-bottom:14px}.ofi-cp-thankyou-card-copy{margin:0 0 18px;color:#475569;line-height:1.7}.ofi-cp-thankyou-items{display:flex;flex-direction:column;gap:14px}.ofi-cp-thankyou-item{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;padding:16px 18px;border-radius:18px;background:#f8fbff;border:1px solid #dbeafe}.ofi-cp-thankyou-item-main{min-width:0}.ofi-cp-thankyou-item-name{font-weight:700;color:#0f172a;font-size:17px;line-height:1.4}.ofi-cp-thankyou-item-meta{margin-top:8px}.ofi-cp-thankyou-badge{display:inline-flex;align-items:center;min-height:28px;padding:5px 10px;border-radius:999px;background:#eff6ff;color:#1d4ed8;font-size:12px;font-weight:700}.ofi-cp-thankyou-item-price{font-weight:700;color:#0f172a;white-space:nowrap;font-size:18px}.ofi-cp-thankyou-actions{display:flex;flex-direction:column;gap:14px}.ofi-cp-download-btn{display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:14px 20px;border-radius:16px;background:#1677d3;color:#fff;text-decoration:none;font-weight:700;box-shadow:0 12px 28px rgba(22,119,211,.22)}.ofi-cp-download-btn:hover{transform:translateY(-1px)}.ofi-cp-license-box{padding:16px 18px;border-radius:18px;background:#f8fbff;border:1px solid #dbeafe}.ofi-cp-license-label{font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:#64748b;font-weight:700;margin-bottom:8px}.ofi-cp-license-code{display:block;padding:12px 14px;border-radius:14px;background:#0f172a;color:#fff;font-size:16px;overflow:auto}.ofi-cp-thankyou-inline-note,.ofi-cp-thankyou-note{color:#475569;font-size:14px;line-height:1.7}.ofi-cp-thankyou-detail-row{display:flex;justify-content:space-between;gap:16px;padding:14px 0;border-bottom:1px solid #e5edf7;color:#334155}.ofi-cp-thankyou-detail-row strong{color:#0f172a}.ofi-cp-thankyou-detail-row:last-of-type{border-bottom:0}.ofi-cp-thankyou-note{margin-top:12px}
@media (max-width:960px){.ofi-cp-checkout-shell{grid-template-columns:1fr}.ofi-cp-order-box{position:static;order:-1}.ofi-cp-title{font-size:28px}.ofi-cp-price{font-size:36px}.ofi-cp-thankyou-grid{grid-template-columns:1fr}.ofi-cp-thankyou-title{font-size:34px}}
@media (max-width:640px){.ofi-cp-grid-fields{grid-template-columns:1fr}.ofi-cp-field-full,.ofi-cp-field-half{grid-column:1 / -1}.ofi-cp-checkout-main,.ofi-cp-order-box,.ofi-cp-thankyou{padding:20px}.ofi-cp-price-row{align-items:flex-start}.ofi-cp-gateways label{width:100%;justify-content:flex-start}.ofi-cp-thankyou-shell{padding:22px}.ofi-cp-thankyou-title{font-size:30px}.ofi-cp-thankyou-item,.ofi-cp-thankyou-detail-row{flex-direction:column;align-items:flex-start}.ofi-cp-thankyou-total-value{font-size:32px}}


body.ofi-cp-thankyou-page { background:#eef3f8; margin:0; }
.ofi-cp-thankyou-wrap { min-height:100vh; background:#eef3f8; padding:48px 20px; }
.ofi-cp-thankyou-shell { max-width:980px; margin:0 auto; }
.ofi-cp-thankyou-header { text-align:center; background:#fff; border-radius:20px; padding:36px 32px 26px; box-shadow:0 20px 45px rgba(15,23,42,.08); border-top:6px solid #2f80ed; margin-bottom:22px; }
.ofi-cp-thankyou-icon { width:72px; height:72px; border-radius:999px; margin:0 auto 16px; background:rgba(52,211,153,.14); color:#10b981; display:flex; align-items:center; justify-content:center; font-size:42px; font-weight:700; }
.ofi-cp-thankyou-icon.is-pending { background:rgba(59,130,246,.12); color:#2563eb; }
.ofi-cp-thankyou-title { margin:0 0 10px; font-size:42px; line-height:1.1; color:#0f172a; }
.ofi-cp-thankyou-subtitle { margin:0; font-size:18px; color:#475569; }
.ofi-cp-thankyou-total-card { background:linear-gradient(135deg,#1d4ed8,#2563eb); color:#fff; border-radius:20px; padding:22px 28px; box-shadow:0 20px 45px rgba(37,99,235,.20); margin:0 auto 22px; max-width:420px; text-align:center; }
.ofi-cp-thankyou-total-label { font-size:14px; letter-spacing:.08em; text-transform:uppercase; opacity:.8; }
.ofi-cp-thankyou-total-value { font-size:42px; font-weight:700; margin-top:6px; }
.ofi-cp-thankyou-grid { display:grid; grid-template-columns:1.2fr .8fr; gap:22px; margin-bottom:22px; }
.ofi-cp-thankyou-card { background:#fff; border-radius:20px; padding:28px; box-shadow:0 20px 45px rgba(15,23,42,.08); }
.ofi-cp-thankyou-card-title { font-size:24px; font-weight:700; color:#0f172a; margin-bottom:18px; }
.ofi-cp-thankyou-card-copy { margin:0 0 14px; color:#475569; font-size:16px; }
.ofi-cp-thankyou-items { display:flex; flex-direction:column; gap:14px; }
.ofi-cp-thankyou-item { border:1px solid #dbe7f5; border-radius:16px; padding:18px; display:flex; justify-content:space-between; gap:16px; align-items:flex-start; background:#f8fbff; }
.ofi-cp-thankyou-item-name { font-size:20px; font-weight:700; color:#10223a; margin-bottom:8px; }
.ofi-cp-thankyou-item-price { font-size:20px; font-weight:700; color:#10223a; white-space:nowrap; }
.ofi-cp-thankyou-badge { display:inline-block; background:#e7f0ff; color:#2563eb; border-radius:999px; padding:6px 10px; font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.04em; }
.ofi-cp-thankyou-item-actions { margin-top:12px; display:flex; flex-direction:column; gap:10px; }
.ofi-cp-download-btn { display:inline-flex; align-items:center; justify-content:center; min-height:50px; padding:0 22px; border-radius:14px; background:#2563eb; color:#fff; text-decoration:none; font-weight:700; box-shadow:0 16px 32px rgba(37,99,235,.24); transition:transform .15s ease, box-shadow .15s ease; }
.ofi-cp-download-btn:hover { color:#fff; transform:translateY(-1px); box-shadow:0 18px 34px rgba(37,99,235,.28); }
.ofi-cp-download-btn.is-small { min-height:42px; padding:0 16px; font-size:14px; box-shadow:none; }
.ofi-cp-thankyou-inline-license { color:#334155; font-size:14px; }
.ofi-cp-thankyou-inline-license code, .ofi-cp-license-code { background:#f1f5f9; border:1px solid #d9e4ef; border-radius:10px; padding:6px 8px; font-family:ui-monospace,SFMono-Regular,Menlo,monospace; }
.ofi-cp-license-box { margin-top:14px; padding:16px; border-radius:16px; border:1px dashed #93c5fd; background:#f8fbff; }
.ofi-cp-license-label { font-weight:700; color:#0f172a; margin-bottom:8px; }
.ofi-cp-thankyou-inline-note, .ofi-cp-thankyou-note { color:#475569; font-size:15px; }
.ofi-cp-thankyou-detail-row { display:flex; justify-content:space-between; gap:16px; padding:12px 0; border-bottom:1px solid #e5edf6; color:#475569; }
.ofi-cp-thankyou-detail-row:last-of-type { border-bottom:none; }
.ofi-cp-thankyou-detail-row strong { color:#0f172a; }
.ofi-cp-thankyou-card-details { max-width:980px; margin:0 auto; }
@media (max-width: 900px) { .ofi-cp-thankyou-grid { grid-template-columns:1fr; } .ofi-cp-thankyou-title { font-size:34px; } .ofi-cp-thankyou-total-value { font-size:34px; } }
@media (max-width: 640px) { .ofi-cp-thankyou-wrap { padding:24px 14px; } .ofi-cp-thankyou-header, .ofi-cp-thankyou-card { padding:20px; border-radius:16px; } .ofi-cp-thankyou-item { flex-direction:column; } .ofi-cp-thankyou-item-price { white-space:normal; } }


/* v1.6.2 thank-you refinements */
body.ofi-cp-thankyou-page { background:#eef3f8; }
.ofi-cp-thankyou-wrap { max-width: 1000px; min-height:auto; padding:28px 16px 40px; }
.ofi-cp-thankyou-shell { max-width: 1000px; padding: 0; border: 0; border-radius: 0; background: transparent; box-shadow: none; }
.ofi-cp-thankyou-header { padding: 24px 24px 20px; border-radius: 18px; margin-bottom: 18px; }
.ofi-cp-thankyou-icon { width: 58px; height: 58px; margin-bottom: 12px; font-size: 34px; }
.ofi-cp-thankyou-title { font-size: 28px; margin-bottom: 8px; }
.ofi-cp-thankyou-subtitle { font-size: 15px; line-height: 1.6; }
.ofi-cp-thankyou-total-card { max-width: 320px; padding: 16px 20px; border-radius: 18px; margin-bottom: 18px; background: linear-gradient(135deg,#1d4ed8,#2563eb); color: #fff; }
.ofi-cp-thankyou-total-label { color: rgba(255,255,255,.82); opacity: 1; }
.ofi-cp-thankyou-total-value { font-size: 30px; line-height: 1.05; color: #fff; }
.ofi-cp-thankyou-grid { gap: 18px; margin-bottom: 18px; }
.ofi-cp-thankyou-card { padding: 22px; border-radius: 18px; }
.ofi-cp-thankyou-card-title { font-size: 18px; margin-bottom: 14px; }
.ofi-cp-thankyou-card-copy, .ofi-cp-thankyou-inline-note, .ofi-cp-thankyou-note, .ofi-cp-thankyou-detail-row { font-size: 14px; }
.ofi-cp-thankyou-item { padding: 16px 16px; border-radius: 14px; }
.ofi-cp-thankyou-item-name { font-size: 16px; line-height: 1.45; }
.ofi-cp-thankyou-item-price { font-size: 16px; }
.ofi-cp-thankyou-badge { font-size: 11px; padding: 5px 10px; }
.ofi-cp-download-btn { min-height: 46px; padding: 0 18px; border-radius: 12px; font-size: 14px; }
.ofi-cp-download-btn.is-small { min-height: 40px; font-size: 13px; }
.ofi-cp-thankyou-detail-row { padding: 11px 0; }
@media (max-width: 900px) {
  .ofi-cp-thankyou-wrap { padding-top: 20px; }
  .ofi-cp-thankyou-title { font-size: 24px; }
  .ofi-cp-thankyou-total-value { font-size: 26px; }
}
@media (max-width: 640px) {
  .ofi-cp-thankyou-header, .ofi-cp-thankyou-card { padding: 18px; }
  .ofi-cp-thankyou-title { font-size: 22px; }
  .ofi-cp-thankyou-subtitle { font-size: 14px; }
  .ofi-cp-thankyou-total-card { max-width: none; }
}

/* v1.6.3 hierarchy and compact thank-you improvements */
.ofi-cp-thankyou-wrap { max-width: 960px; padding: 22px 14px 36px; }
.ofi-cp-thankyou-header { padding: 20px 22px 18px; border-radius: 16px; margin-bottom: 16px; }
.ofi-cp-thankyou-icon { width: 54px; height: 54px; margin-bottom: 10px; font-size: 30px; }
.ofi-cp-thankyou-title { font-size: 26px; margin-bottom: 6px; }
.ofi-cp-thankyou-subtitle { font-size: 14px; line-height: 1.55; }
.ofi-cp-thankyou-grid { gap: 16px; margin-bottom: 16px; }
.ofi-cp-thankyou-grid-top { grid-template-columns: minmax(0,1.18fr) minmax(250px,.82fr); align-items: stretch; }
.ofi-cp-thankyou-card { padding: 20px; border-radius: 16px; }
.ofi-cp-thankyou-card-title { font-size: 17px; margin-bottom: 12px; }
.ofi-cp-thankyou-card-title.is-small { font-size: 15px; margin-bottom: 10px; }
.ofi-cp-thankyou-card-copy,
.ofi-cp-thankyou-inline-note,
.ofi-cp-thankyou-note,
.ofi-cp-thankyou-detail-row { font-size: 13.5px; }
.ofi-cp-thankyou-card-hero { border: 1px solid #dbeafe; background: linear-gradient(180deg,#ffffff 0%,#f8fbff 100%); }
.ofi-cp-thankyou-card-aside { display: flex; flex-direction: column; gap: 14px; justify-content: flex-start; }
.ofi-cp-thankyou-primary-product { display: flex; flex-direction: column; gap: 14px; }
.ofi-cp-thankyou-primary-name { font-size: 20px; line-height: 1.35; font-weight: 700; color: #0f172a; }
.ofi-cp-thankyou-primary-actions { display: flex; flex-direction: column; gap: 12px; }
.ofi-cp-thankyou-badge { min-height: 24px; padding: 4px 10px; font-size: 10.5px; letter-spacing: .04em; text-transform: uppercase; }
.ofi-cp-thankyou-badge.is-primary { background: #eff6ff; color: #1d4ed8; }
.ofi-cp-thankyou-mini-total { padding: 14px 16px; border-radius: 14px; background: #f8fbff; border: 1px solid #dbeafe; box-shadow: none; text-align: left; }
.ofi-cp-thankyou-mini-total .ofi-cp-thankyou-total-label { color: #64748b; font-size: 11px; letter-spacing: .08em; }
.ofi-cp-thankyou-mini-total .ofi-cp-thankyou-total-value { color: #0f172a; font-size: 24px; margin-top: 4px; }
.ofi-cp-thankyou-next-step { padding: 14px 16px; border-radius: 14px; background: #fff; border: 1px solid #e2e8f0; }
.ofi-cp-thankyou-step-list { margin: 0; padding-left: 18px; color: #475569; line-height: 1.7; }
.ofi-cp-thankyou-item { padding: 14px 15px; border-radius: 14px; }
.ofi-cp-thankyou-item-name { font-size: 15px; margin-bottom: 6px; }
.ofi-cp-thankyou-item-price { font-size: 15px; }
.ofi-cp-thankyou-item-actions { margin-top: 10px; gap: 8px; }
.ofi-cp-download-btn { gap: 8px; }
.ofi-cp-download-btn-icon { font-size: 15px; line-height: 1; }
.ofi-cp-download-btn-primary { width: 100%; min-height: 54px; padding: 0 22px; border-radius: 14px; font-size: 15px; box-shadow: 0 18px 34px rgba(37,99,235,.20); }
.ofi-cp-download-btn.is-small { min-height: 38px; padding: 0 14px; border-radius: 11px; font-size: 13px; }
.ofi-cp-license-box { margin-top: 0; padding: 14px; border-radius: 14px; }
.ofi-cp-license-label { font-size: 12px; margin-bottom: 6px; }
.ofi-cp-license-code { font-size: 14px; }
.ofi-cp-thankyou-detail-row { padding: 10px 0; }
@media (max-width: 900px) {
  .ofi-cp-thankyou-grid-top,
  .ofi-cp-thankyou-grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .ofi-cp-thankyou-wrap { padding: 18px 12px 28px; }
  .ofi-cp-thankyou-header,
  .ofi-cp-thankyou-card { padding: 16px; }
  .ofi-cp-thankyou-title { font-size: 22px; }
  .ofi-cp-thankyou-primary-name { font-size: 18px; }
  .ofi-cp-thankyou-mini-total .ofi-cp-thankyou-total-value { font-size: 22px; }
}


/* v1.6.4 thank-you hierarchy refinements */
.ofi-cp-thankyou-wrap { max-width: 930px; padding: 18px 12px 30px; }
.ofi-cp-thankyou-header { padding: 18px 20px 16px; margin-bottom: 14px; }
.ofi-cp-thankyou-icon { width: 50px; height: 50px; font-size: 28px; margin-bottom: 8px; }
.ofi-cp-thankyou-title { font-size: 24px; }
.ofi-cp-thankyou-subtitle { font-size: 13.5px; }
.ofi-cp-thankyou-grid { gap: 14px; margin-bottom: 14px; }
.ofi-cp-thankyou-card { padding: 18px; }
.ofi-cp-thankyou-card-title { font-size: 16px; margin-bottom: 10px; }
.ofi-cp-thankyou-primary-product, .ofi-cp-thankyou-primary-actions { gap: 12px; }
.ofi-cp-thankyou-primary-name { font-size: 18px; }
.ofi-cp-thankyou-mini-total { padding: 12px 14px; border-radius: 12px; }
.ofi-cp-thankyou-next-step { padding: 12px 14px; border-radius: 12px; }
.ofi-cp-thankyou-item { padding: 13px 14px; }
.ofi-cp-download-btn { border-radius: 8px; }
.ofi-cp-download-btn-primary { min-height: 50px; border-radius: 9px; }
.ofi-cp-download-btn.is-small { border-radius: 8px; }
.ofi-cp-thankyou-inline-action {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: #2563eb;
  text-decoration: none;
  font-weight: 700;
  font-size: 13px;
  padding: 0;
}
.ofi-cp-thankyou-inline-action:hover { color: #1d4ed8; text-decoration: underline; }
.ofi-cp-thankyou-inline-note.is-soft { color: #64748b; font-size: 12.5px; }
@media (max-width: 640px) {
  .ofi-cp-thankyou-wrap { padding: 16px 10px 24px; }
  .ofi-cp-thankyou-header, .ofi-cp-thankyou-card { padding: 15px; }
  .ofi-cp-download-btn-primary { min-height: 48px; }
}

/* v1.6.6 bump card upgrade */
.ofi-cp-bump-wrap { margin: 4px 0 18px; }
.ofi-cp-bump-checkbox {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.ofi-cp-bump-card {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  padding: 16px 18px;
  border: 1px solid #dbeafe;
  border-radius: 14px;
  background: linear-gradient(180deg,#f8fbff 0%,#f1f5f9 100%);
  cursor: pointer;
  transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease, background .18s ease;
}
.ofi-cp-bump-card:hover {
  border-color: #93c5fd;
  box-shadow: 0 10px 24px rgba(37,99,235,.08);
}
.ofi-cp-bump-checkbox:checked + .ofi-cp-bump-card {
  border-color: #60a5fa;
  background: linear-gradient(180deg,#eff6ff 0%,#f8fbff 100%);
  box-shadow: 0 14px 28px rgba(37,99,235,.10);
}
.ofi-cp-bump-card-main {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  min-width: 0;
  flex: 1;
}
.ofi-cp-bump-media {
  flex: 0 0 110px;
  width: 110px;
  overflow: hidden;
  border-radius: 10px;
  background: #fff;
  border: 1px solid #dbe7f5;
}
.ofi-cp-bump-media img {
  display: block;
  width: 100%;
  height: auto;
}
.ofi-cp-bump-copy {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.ofi-cp-bump-eyebrow {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  min-height: 24px;
  padding: 4px 10px;
  border-radius: 999px;
  background: #e7f0ff;
  color: #2563eb;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.ofi-cp-bump-title {
  font-size: 24px;
  line-height: 1.15;
  font-weight: 700;
  color: #0f172a;
}
.ofi-cp-bump-price-line {
  font-size: 16px;
  font-weight: 700;
  color: #1d4ed8;
}
.ofi-cp-bump-desc {
  color: #475569;
  font-size: 14px;
  line-height: 1.65;
}
.ofi-cp-bump-side {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: 4px;
}
.ofi-cp-bump-toggle {
  position: relative;
  display: inline-flex;
  width: 48px;
  height: 28px;
  border-radius: 999px;
  background: #cbd5e1;
  transition: background .18s ease;
}
.ofi-cp-bump-toggle-knob {
  position: absolute;
  top: 3px;
  left: 3px;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: #fff;
  box-shadow: 0 2px 8px rgba(15,23,42,.18);
  transition: transform .18s ease;
}
.ofi-cp-bump-checkbox:checked + .ofi-cp-bump-card .ofi-cp-bump-toggle {
  background: #2563eb;
}
.ofi-cp-bump-checkbox:checked + .ofi-cp-bump-card .ofi-cp-bump-toggle-knob {
  transform: translateX(20px);
}
@media (max-width: 640px) {
  .ofi-cp-bump-card { padding: 14px; gap: 12px; }
  .ofi-cp-bump-card-main { gap: 12px; }
  .ofi-cp-bump-media { flex-basis: 86px; width: 86px; }
  .ofi-cp-bump-title { font-size: 20px; }
  .ofi-cp-bump-price-line { font-size: 15px; }
  .ofi-cp-bump-desc { font-size: 13px; }
}


/* v1.6.7 checkout media and typography polish */
.ofi-cp-hero-layout {
  display: block;
}
.ofi-cp-hero-layout.has-media {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 240px;
  gap: 20px;
  align-items: start;
}
.ofi-cp-hero-copy {
  min-width: 0;
}
.ofi-cp-hero-media {
  width: 100%;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid #dbe7f5;
  background: linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);
  box-shadow: 0 10px 24px rgba(15,23,42,.06);
}
.ofi-cp-hero-media img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 3;
  object-fit: cover;
}
.ofi-cp-title {
  font-weight: 700;
}
.ofi-cp-bump-title {
  font-weight: 700;
  letter-spacing: -0.02em;
}
@media (max-width: 900px) {
  .ofi-cp-hero-layout.has-media {
    grid-template-columns: 1fr;
  }
  .ofi-cp-hero-media {
    max-width: 320px;
    order: -1;
  }
}
@media (max-width: 640px) {
  .ofi-cp-hero-media {
    max-width: 100%;
    border-radius: 12px;
  }
  .ofi-cp-title {
    font-size: 30px;
    line-height: 1.1;
  }
}


/* v1.6.8 summary image move + bump polish */
.ofi-cp-summary-media {
  margin: -2px 0 14px;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid #dbe7f5;
  background: linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);
  box-shadow: 0 8px 20px rgba(15,23,42,.05);
  padding: 10px;
}
.ofi-cp-summary-media img {
  display: block;
  width: 100%;
  height: 150px;
  object-fit: contain;
  object-position: center center;
}
.ofi-cp-hero-layout,
.ofi-cp-hero-layout.has-media {
  display: block;
}
.ofi-cp-title {
  font-weight: 600;
}
.ofi-cp-bump-card {
  align-items: stretch;
}
.ofi-cp-bump-card-main {
  align-items: flex-start;
}
.ofi-cp-bump-media {
  flex: 0 0 84px;
  width: 84px;
  height: 64px;
  border-radius: 8px;
  background: linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);
  border: 1px solid #dbe7f5;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.ofi-cp-bump-media img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center center;
  display: block;
}
.ofi-cp-bump-copy {
  gap: 5px;
}
.ofi-cp-bump-title {
  font-size: 20px;
  font-weight: 600;
  line-height: 1.18;
}
.ofi-cp-bump-price-line {
  font-size: 15px;
  font-weight: 700;
}
.ofi-cp-bump-desc {
  color: #475569;
  font-size: 13px;
  line-height: 1.55;
  max-width: 44ch;
}
.ofi-cp-bump-side {
  align-self: flex-end;
  padding-top: 0;
  padding-bottom: 2px;
}
@media (max-width: 900px) {
  .ofi-cp-summary-media img {
    height: 140px;
  }
}
@media (max-width: 640px) {
  .ofi-cp-summary-media {
    margin-bottom: 12px;
    border-radius: 10px;
    padding: 8px;
  }
  .ofi-cp-summary-media img {
    height: 128px;
  }
  .ofi-cp-bump-media {
    flex-basis: 72px;
    width: 72px;
    height: 56px;
  }
  .ofi-cp-bump-title {
    font-size: 18px;
  }
  .ofi-cp-bump-desc {
    font-size: 12.5px;
  }
}

.ofi-cp-coupon-field{margin-top:8px}
.ofi-cp-coupon-row{display:flex;gap:10px;align-items:center}
.ofi-cp-coupon-row input[name="coupon_code"]{flex:1}
.ofi-cp-apply-coupon{border:1px solid #2f6ce5;background:#fff;color:#2f6ce5;padding:12px 16px;border-radius:10px;font-weight:600;cursor:pointer;white-space:nowrap}
.ofi-cp-apply-coupon:disabled{opacity:.65;cursor:not-allowed}
@media (max-width: 640px){.ofi-cp-coupon-row{flex-direction:column;align-items:stretch}.ofi-cp-apply-coupon{width:100%}}


.ofi-cp-line-discount-row{transition:color .2s ease, background-color .2s ease, border-color .2s ease}
.ofi-cp-line-discount-row.is-applied{
  background:rgba(22,163,74,.08);
  border:1px solid rgba(22,163,74,.18);
  border-radius:12px;
  padding:12px 14px;
  margin-top:10px;
}
.ofi-cp-line-discount-row.is-applied span{
  color:#166534;
  font-weight:600;
}
.ofi-cp-line-discount-row.is-applied .ofi-cp-line-discount{
  color:#15803d;
  font-weight:600;
}

/* v1.7.2 thank you cleanup */
.ofi-cp-thankyou-side-stack{display:flex;flex-direction:column;gap:14px}.ofi-cp-thankyou-inline-license{color:#334155;font-size:14px}.ofi-cp-thankyou-inline-license code{display:inline-block;background:#f1f5f9!important;border:1px solid #d9e4ef;border-radius:10px;padding:6px 10px;color:#0f172a!important;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.ofi-cp-thankyou-item-actions .ofi-cp-download-btn{align-self:flex-start;background:#2563eb;color:#fff;box-shadow:0 14px 28px rgba(37,99,235,.22);border:1px solid #2563eb;font-weight:700}.ofi-cp-thankyou-item-actions .ofi-cp-download-btn:hover{background:#1d4ed8;color:#fff;box-shadow:0 16px 30px rgba(37,99,235,.26)}.ofi-cp-thankyou-item-actions .ofi-cp-download-btn .ofi-cp-download-btn-icon{color:inherit}.ofi-cp-thankyou-card-primary{border-color:#dbeafe}.ofi-cp-thankyou-card-primary .ofi-cp-thankyou-item{background:#f8fbff}@media (max-width:900px){.ofi-cp-thankyou-side-stack{gap:14px}}


/* v1.9.0 checkout CRO + payment element */
.ofi-cp-payment-element{padding:14px 0 4px;}
.ofi-cp-coupon-toggle{display:inline-flex;align-items:center;gap:8px;background:none;border:none;padding:0;color:#2563eb;font-weight:700;cursor:pointer;font-size:15px;}
.ofi-cp-coupon-toggle:hover{text-decoration:underline;}
.ofi-cp-coupon-body{margin-top:10px;}
.ofi-cp-trust-points{display:grid;gap:8px;margin-top:14px;color:#475569;font-size:13px;}
.ofi-cp-trust-points span{display:flex;align-items:center;gap:8px;}
.ofi-cp-trust-points span:before{content:'✓';display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:999px;background:#eff6ff;color:#2563eb;font-size:12px;font-weight:700;flex:0 0 18px;}
.ofi-cp-country-help{display:block;margin-top:6px;}
.ofi-cp-panel-desc{margin-bottom:6px;}
.ofi-cp-submit{margin-top:8px;}
@media (min-width: 768px){.ofi-cp-trust-points{grid-template-columns:repeat(3,minmax(0,1fr));}}

.ofi-cp-order-coupon{margin-top:18px;padding-top:2px}.ofi-cp-order-coupon .ofi-cp-coupon-toggle{padding-left:0}.ofi-cp-order-coupon .ofi-cp-coupon-body{padding-top:10px}.ofi-cp-trust-points span:first-child{font-weight:700}


/* v1.9.1.3 contact spacing polish */
.ofi-cp-grid-fields {
  row-gap: 10px;
}
.ofi-cp-grid-fields > .ofi-cp-field {
  margin: 0;
}

/* Bump spacing improvement */
.ofi-cp-bump, .ofi-cp-bump-card { margin-top: 18px; }

/* v1.10.5.1 coupon feedback hotfix */
.ofi-cp-coupon-feedback{display:none;margin-top:8px;font-size:13px;line-height:1.45;font-weight:700}
.ofi-cp-coupon-feedback.has-message{display:block}
.ofi-cp-coupon-feedback.is-error{color:#b91c1c}
.ofi-cp-coupon-feedback.is-success{color:#166534}
.ofi-cp-coupon-feedback.is-info{color:#1d4ed8}


/* v1.10.8 checkout UX polish */
.ofi-cp-message{
  padding:10px 12px;
  border-radius:10px;
  background:#f8fafc;
  border:1px solid #e2e8f0;
}
.ofi-cp-message:empty{
  padding:0;
  border:0;
  background:transparent;
}
.ofi-cp-message.is-error{
  background:#fef2f2;
  border-color:#fecaca;
}
.ofi-cp-message.is-success{
  background:#f0fdf4;
  border-color:#bbf7d0;
}
.ofi-cp-message.is-info{
  background:#eff6ff;
  border-color:#bfdbfe;
}
.ofi-cp-paypal-buttons{
  transition:opacity .18s ease;
}

/* =========================================================
   Phase 29B — Public Checkout Premium UI Redesign
   Uses OFI Premium UI v1.3.1 tokens/classes as the visual base.
   Checkout typography cap: max font-weight 700.
========================================================= */
.ofi-cp-checkout.ofi-ui {
  --ofi-primary: #2563eb;
  --ofi-primary-hover: #1d4ed8;
  --ofi-primary-dark: #1e3a8a;
  --ofi-primary-soft: #dbeafe;
  --ofi-primary-softer: #eff6ff;
  --ofi-success: #16a34a;
  --ofi-success-soft: #dcfce7;
  --ofi-bg: #f7f8fb;
  --ofi-surface: #ffffff;
  --ofi-surface-soft: #f8fafc;
  --ofi-text: #0f172a;
  --ofi-text-soft: #334155;
  --ofi-muted: #64748b;
  --ofi-border: #e2e8f0;
  --ofi-border-soft: #f1f5f9;
  --ofi-border-strong: #cbd5e1;
  --ofi-shadow-soft: 0 16px 42px rgba(15, 23, 42, 0.09);
  --ofi-shadow-medium: 0 22px 65px rgba(15, 23, 42, 0.13);
  --ofi-shadow-primary: 0 16px 34px rgba(37, 99, 235, 0.24);
  width: min(1180px, calc(100% - 32px));
  max-width: none;
  margin: 30px auto 48px;
  padding: 0;
  background: transparent;
  color: var(--ofi-text);
  font-family: var(--ofi-font, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
  font-size: 16px;
  line-height: 1.45;
}
.ofi-cp-checkout.ofi-ui,
.ofi-cp-checkout.ofi-ui * { box-sizing: border-box; }
.ofi-cp-checkout :is(h1,h2,h3,h4,h5,h6,strong,b,label,button,.ofi-cp-title,.ofi-cp-price,.ofi-cp-save-pill,.ofi-cp-topline,.ofi-cp-section-title,.ofi-cp-panel-title,.ofi-cp-order-total,.ofi-cp-bump-title,.ofi-cp-bump-price-line,.ofi-cp-bump-eyebrow,.ofi-cp-trust-card strong,.ofi-cp-order-line strong,.ofi-cp-summary-trust div,.ofi-cp-line-total) {
  font-weight: 700 !important;
}
.ofi-cp-checkout-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) 430px;
  gap: 28px;
  align-items: start;
}
.ofi-cp-checkout-main,
.ofi-cp-order-box {
  padding: 30px;
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(226,232,240,.92);
  border-radius: 24px;
  box-shadow: var(--ofi-shadow-soft);
  overflow: hidden;
}
.ofi-cp-order-box {
  padding: 24px;
  position: sticky;
  top: 24px;
  background: rgba(255,255,255,.98);
}
.ofi-cp-hero-card {
  padding: 0;
  margin: 0 0 24px;
  border: 0;
}
.ofi-cp-topline-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 22px;
}
.ofi-cp-topline {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 32px;
  padding: 7px 12px;
  border-radius: 999px;
  background: var(--ofi-primary-softer);
  border: 1px solid rgba(37,99,235,.14);
  color: var(--ofi-primary-dark);
  font-size: 13px;
  letter-spacing: .01em;
  margin: 0;
  white-space: nowrap;
}
.ofi-cp-topline.is-soft {
  background: #f8fafc;
  border-color: #e2e8f0;
  color: #334155;
}
.ofi-cp-title {
  margin: 0;
  max-width: 760px;
  font-size: clamp(34px, 4.1vw, 56px);
  line-height: 1.02;
  letter-spacing: -0.045em;
  color: var(--ofi-text);
}
.ofi-cp-hero-subtitle {
  margin: 16px 0 0;
  max-width: 720px;
  color: var(--ofi-text-soft);
  font-size: 18px;
  line-height: 1.55;
}
.ofi-cp-price-stack {
  margin: 26px 0 0;
}
.ofi-cp-price-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
}
.ofi-cp-regular-price {
  color: var(--ofi-muted);
  text-decoration: line-through;
  font-size: 18px;
  font-weight: 500 !important;
  margin: 0;
}
.ofi-cp-price {
  color: var(--ofi-text);
  font-size: clamp(42px, 5vw, 60px);
  line-height: 1;
  letter-spacing: -0.05em;
}
.ofi-cp-save-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 8px 13px;
  background: var(--ofi-primary-soft);
  color: var(--ofi-primary-dark);
  font-size: 14px;
}
.ofi-cp-payment-notes {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
  color: var(--ofi-text-soft);
  font-size: 15px;
  font-weight: 500;
  margin-top: 16px;
}
.ofi-cp-payment-notes span + span::before,
.ofi-cp-trust-points span + span::before {
  content: "";
  display: inline-block;
  width: 4px;
  height: 4px;
  margin: 0 12px 3px 0;
  border-radius: 999px;
  background: var(--ofi-border-strong);
}
.ofi-cp-benefit-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px 18px;
  margin: 28px 0 0;
  padding: 0;
  list-style: none;
}
.ofi-cp-benefit-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  color: var(--ofi-text-soft);
  font-weight: 500;
}
.ofi-cp-check-icon {
  display: inline-flex;
  width: 22px;
  height: 22px;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  border-radius: 50%;
  background: var(--ofi-success-soft);
  color: var(--ofi-success);
  font-weight: 700;
  font-size: 14px;
  margin-top: 1px;
}
.ofi-cp-trust-cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 30px;
}
.ofi-cp-trust-card {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 16px;
  border-radius: 18px;
  background: var(--ofi-surface-soft);
  border: 1px solid var(--ofi-border);
}
.ofi-cp-trust-card strong,
.ofi-cp-trust-card small {
  display: block;
}
.ofi-cp-trust-card small {
  color: var(--ofi-muted);
  margin-top: 4px;
  font-size: 14px;
  line-height: 1.45;
}
.ofi-cp-trust-icon {
  width: 38px;
  height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  border-radius: 14px;
  background: #fff;
  border: 1px solid var(--ofi-border);
}
.ofi-cp-form-card,
.ofi-cp-bump-card,
.ofi-cp-panel {
  border-radius: 20px;
  border: 1px solid var(--ofi-border);
  background: rgba(248,250,252,.78);
  box-shadow: none;
}
.ofi-cp-form-card {
  padding: 22px;
  margin-top: 20px;
}
.ofi-cp-section-title {
  margin: 0 0 14px;
  color: #334155;
  font-size: 13px;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.ofi-cp-grid-fields {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.ofi-cp-form label {
  margin-bottom: 8px;
  color: var(--ofi-text);
  font-size: 14px;
}
.ofi-cp-form input[type=text],
.ofi-cp-form input[type=email],
.ofi-cp-form input[type=url],
.ofi-cp-form input[type=number],
.ofi-cp-form select,
.ofi-cp-form textarea,
.ofi-cp-coupon-body input[type=text] {
  width: 100%;
  min-height: 46px;
  border: 1px solid var(--ofi-border);
  border-radius: 14px;
  background: #fff;
  color: var(--ofi-text);
  padding: 11px 14px;
  box-shadow: 0 1px 2px rgba(15,23,42,.04);
}
.ofi-cp-form input:focus,
.ofi-cp-form select:focus,
.ofi-cp-form textarea:focus,
.ofi-cp-coupon-body input:focus {
  outline: none;
  border-color: #93c5fd;
  box-shadow: 0 0 0 4px rgba(37,99,235,.10);
}
.ofi-cp-gateways {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin: 0 0 18px;
}
.ofi-cp-gateways label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 46px;
  padding: 11px 16px;
  border: 1px solid var(--ofi-border);
  border-radius: 999px;
  background: #fff;
  color: var(--ofi-text);
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(15,23,42,.04);
}
.ofi-cp-gateways label:has(input:checked) {
  border-color: #bfdbfe;
  background: var(--ofi-primary-softer);
  color: var(--ofi-primary-dark);
}
.ofi-cp-panel {
  padding: 18px;
  margin-bottom: 18px;
  background: #fff;
}
.ofi-cp-panel-title {
  font-size: 16px;
  margin-bottom: 6px;
  color: var(--ofi-text);
}
.ofi-cp-panel-desc {
  font-size: 14px;
  line-height: 1.55;
  color: var(--ofi-muted);
}
.ofi-cp-submit {
  min-height: 58px;
  border: 0;
  border-radius: 16px;
  background: var(--ofi-primary);
  color: #fff;
  width: 100%;
  cursor: pointer;
  box-shadow: var(--ofi-shadow-primary);
  font-size: 16px;
  transition: transform .16s ease, box-shadow .16s ease, background .16s ease;
}
.ofi-cp-submit:hover {
  background: var(--ofi-primary-hover);
  transform: translateY(-1px);
  box-shadow: 0 18px 38px rgba(37,99,235,.28);
}
.ofi-cp-trust-points {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0 12px;
  margin-top: 14px;
  color: var(--ofi-muted);
  font-size: 13px;
}
.ofi-cp-bump-wrap {
  margin: 20px 0 0;
}
.ofi-cp-bump-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 16px;
  background: linear-gradient(180deg, #f8fbff 0%, #f1f5f9 100%);
  cursor: pointer;
}
.ofi-cp-bump-checkbox:checked + .ofi-cp-bump-card {
  border-color: #93c5fd;
  background: var(--ofi-primary-softer);
  box-shadow: 0 14px 30px rgba(37,99,235,.09);
}
.ofi-cp-bump-media {
  width: 92px;
  flex-basis: 92px;
  border-radius: 12px;
  background: #fff;
  border: 1px solid var(--ofi-border);
  overflow: hidden;
}
.ofi-cp-bump-title {
  font-size: 18px;
  line-height: 1.25;
}
.ofi-cp-bump-price-line {
  color: var(--ofi-primary-dark);
  font-size: 14px;
}
.ofi-cp-bump-desc {
  color: var(--ofi-muted);
  font-size: 13.5px;
  line-height: 1.5;
}
.ofi-cp-bump-eyebrow {
  background: var(--ofi-primary-soft);
  color: var(--ofi-primary-dark);
  font-size: 11px;
  letter-spacing: .06em;
}
.ofi-cp-bump-toggle {
  width: 50px;
  height: 28px;
  border-radius: 999px;
  background: #cbd5e1;
  padding: 3px;
}
.ofi-cp-bump-toggle-knob {
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: #fff;
  display: block;
  transition: transform .18s ease;
}
.ofi-cp-bump-checkbox:checked + .ofi-cp-bump-card .ofi-cp-bump-toggle {
  background: var(--ofi-primary);
}
.ofi-cp-bump-checkbox:checked + .ofi-cp-bump-card .ofi-cp-bump-toggle-knob {
  transform: translateX(22px);
}
.ofi-cp-summary-media {
  display: grid;
  place-items: center;
  min-height: 158px;
  border-radius: 22px;
  background: linear-gradient(135deg, rgba(37,99,235,.12), rgba(20,184,166,.12));
  border: 1px solid var(--ofi-border);
  overflow: hidden;
  margin-bottom: 26px;
  padding: 12px;
}
.ofi-cp-summary-media img {
  display: block;
  width: 100%;
  max-height: 150px;
  object-fit: contain;
  border-radius: 14px;
}
.ofi-cp-order-box h4 {
  margin: 0 0 22px;
  font-size: 25px;
  line-height: 1.15;
  letter-spacing: -0.035em;
}
.ofi-cp-order-line,
.ofi-cp-order-total {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 15px 0;
  border-bottom: 1px solid var(--ofi-border-soft);
  color: var(--ofi-text);
}
.ofi-cp-order-line span,
.ofi-cp-order-line strong {
  font-size: 15px;
}
.ofi-cp-order-line.is-muted {
  color: var(--ofi-muted);
}
.ofi-cp-order-line.is-savings strong,
.ofi-cp-line-offer,
.ofi-cp-line-coupon {
  color: var(--ofi-success);
}
.ofi-cp-order-total {
  align-items: center;
  border-bottom: 0;
  padding-top: 24px;
  font-size: 24px;
}
.ofi-cp-order-total strong {
  font-size: 28px;
  letter-spacing: -0.035em;
}
.ofi-cp-order-coupon {
  margin-top: 12px;
}
.ofi-cp-coupon-toggle {
  appearance: none;
  border: 0;
  background: transparent;
  padding: 0;
  color: var(--ofi-primary);
  cursor: pointer;
  font-size: 14px;
}
.ofi-cp-coupon-body {
  margin-top: 12px;
  padding: 14px;
  border: 1px solid var(--ofi-border);
  border-radius: 16px;
  background: var(--ofi-surface-soft);
}
.ofi-cp-coupon-row {
  display: flex;
  gap: 10px;
  align-items: stretch;
}
.ofi-cp-coupon-row input {
  flex: 1;
}
.ofi-cp-apply-coupon {
  border: 1px solid var(--ofi-primary);
  border-radius: 14px;
  background: var(--ofi-primary);
  color: #fff;
  padding: 0 14px;
  cursor: pointer;
}
.ofi-cp-coupon-feedback.has-message {
  display: block;
  margin-top: 8px;
  color: var(--ofi-primary-dark);
}
.ofi-cp-coupon-feedback.is-error {
  color: #b91c1c;
}
.ofi-cp-summary-trust {
  margin-top: 24px;
  padding: 18px;
  border-radius: 18px;
  background: var(--ofi-surface-soft);
  border: 1px solid var(--ofi-border);
  color: var(--ofi-text-soft);
  display: grid;
  gap: 10px;
  font-size: 14px;
}
.ofi-cp-message {
  margin-top: 14px;
  min-height: 20px;
  font-size: 14px;
}
.ofi-cp-message.is-error { color: #b91c1c; }
.ofi-cp-message.is-success { color: #166534; }
.ofi-cp-message.is-info { color: #1d4ed8; }
@media (max-width: 1020px) {
  .ofi-cp-checkout-shell { grid-template-columns: 1fr; }
  .ofi-cp-order-box { position: static; order: -1; }
}
@media (max-width: 760px) {
  .ofi-cp-checkout.ofi-ui { width: min(100% - 22px, 1180px); margin-top: 18px; }
  .ofi-cp-checkout-main,
  .ofi-cp-order-box { padding: 20px; border-radius: 20px; }
  .ofi-cp-title { font-size: clamp(32px, 10vw, 44px); }
  .ofi-cp-hero-subtitle { font-size: 16px; }
  .ofi-cp-benefit-list,
  .ofi-cp-trust-cards,
  .ofi-cp-grid-fields { grid-template-columns: 1fr; }
  .ofi-cp-field-full,
  .ofi-cp-field-half { grid-column: 1 / -1; }
  .ofi-cp-coupon-row { flex-direction: column; }
  .ofi-cp-gateways label { width: 100%; }
}

/* =========================================================
   Phase 29B.2 — Checkout Visual Scale Polish
   Purpose: keep the approved premium look, but reduce hero/title/price scale
   so the checkout feels compact and purchase-focused instead of oversized.
   No payment, coupon, bump, order, fulfillment, download, or license logic changed.
========================================================= */
.ofi-cp-checkout.ofi-ui {
  width: min(1120px, calc(100% - 32px)) !important;
  margin-top: 24px !important;
  margin-bottom: 42px !important;
}
.ofi-cp-checkout.ofi-ui :is(h1,h2,h3,h4,h5,h6,strong,b,label,button,.ofi-cp-title,.ofi-cp-price,.ofi-cp-save-pill,.ofi-cp-topline,.ofi-cp-section-title,.ofi-cp-panel-title,.ofi-cp-order-total,.ofi-cp-bump-title,.ofi-cp-bump-price-line,.ofi-cp-bump-eyebrow,.ofi-cp-trust-card strong,.ofi-cp-order-line strong,.ofi-cp-summary-trust div,.ofi-cp-line-total) {
  font-weight: 700 !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-checkout-shell {
  grid-template-columns: minmax(0, 1fr) 395px !important;
  gap: 24px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-checkout-main,
.ofi-cp-checkout.ofi-ui .ofi-cp-order-box {
  border-radius: 22px !important;
  box-shadow: 0 14px 36px rgba(15, 23, 42, 0.075) !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-checkout-main {
  padding: 26px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-order-box {
  padding: 22px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-topline-row {
  gap: 9px !important;
  margin-bottom: 18px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-topline {
  min-height: 30px !important;
  padding: 6px 11px !important;
  font-size: 12.5px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-title {
  max-width: 660px !important;
  font-size: clamp(30px, 3.05vw, 44px) !important;
  line-height: 1.08 !important;
  letter-spacing: -0.036em !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-hero-subtitle {
  margin-top: 14px !important;
  max-width: 680px !important;
  font-size: 16.5px !important;
  line-height: 1.55 !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-price-stack {
  margin-top: 22px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-price-row {
  gap: 11px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-regular-price {
  font-size: 16.5px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-price {
  font-size: clamp(38px, 3.8vw, 50px) !important;
  letter-spacing: -0.045em !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-save-pill {
  padding: 7px 12px !important;
  font-size: 13.5px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-payment-notes {
  margin-top: 14px !important;
  gap: 10px !important;
  font-size: 14.5px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-benefit-list {
  margin-top: 24px !important;
  gap: 12px 16px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-benefit-list li {
  font-size: 15.5px !important;
  line-height: 1.45 !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-check-icon {
  width: 21px !important;
  height: 21px !important;
  font-size: 13px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-trust-cards {
  margin-top: 24px !important;
  gap: 12px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-trust-card {
  min-height: 0 !important;
  padding: 14px !important;
  border-radius: 16px !important;
  gap: 10px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-trust-icon {
  width: 34px !important;
  height: 34px !important;
  border-radius: 12px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-trust-card strong {
  font-size: 15px !important;
  line-height: 1.3 !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-trust-card small {
  font-size: 13px !important;
  line-height: 1.42 !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-form-card {
  padding: 20px !important;
  margin-top: 18px !important;
  border-radius: 18px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-bump-card {
  padding: 14px !important;
  border-radius: 18px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-bump-title {
  font-size: 16.5px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-submit {
  min-height: 54px !important;
  border-radius: 15px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-summary-media {
  min-height: 132px !important;
  margin-bottom: 22px !important;
  border-radius: 20px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-summary-media img {
  max-height: 126px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-order-box h4 {
  margin-bottom: 20px !important;
  font-size: 22px !important;
  line-height: 1.18 !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-order-line,
.ofi-cp-checkout.ofi-ui .ofi-cp-order-total {
  padding: 13px 0 !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-order-line span,
.ofi-cp-checkout.ofi-ui .ofi-cp-order-line strong {
  font-size: 14.5px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-order-total {
  padding-top: 20px !important;
  font-size: 21px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-order-total strong {
  font-size: 24px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-summary-trust {
  margin-top: 20px !important;
  padding: 16px !important;
  border-radius: 16px !important;
  font-size: 13.5px !important;
}
@media (max-width: 1020px) {
  .ofi-cp-checkout.ofi-ui .ofi-cp-checkout-shell {
    grid-template-columns: 1fr !important;
  }
}
@media (max-width: 760px) {
  .ofi-cp-checkout.ofi-ui { width: min(100% - 22px, 1120px) !important; }
  .ofi-cp-checkout.ofi-ui .ofi-cp-checkout-main,
  .ofi-cp-checkout.ofi-ui .ofi-cp-order-box { padding: 20px !important; border-radius: 20px !important; }
  .ofi-cp-checkout.ofi-ui .ofi-cp-title { font-size: clamp(28px, 8.4vw, 38px) !important; }
  .ofi-cp-checkout.ofi-ui .ofi-cp-price { font-size: clamp(36px, 11vw, 46px) !important; }
  .ofi-cp-checkout.ofi-ui .ofi-cp-hero-subtitle { font-size: 15.5px !important; }
  .ofi-cp-checkout.ofi-ui .ofi-cp-benefit-list,
  .ofi-cp-checkout.ofi-ui .ofi-cp-trust-cards,
  .ofi-cp-checkout.ofi-ui .ofi-cp-grid-fields { grid-template-columns: 1fr !important; }
}

/* =========================================================
   Phase 29B.3 — Left Column Content Simplification & Hierarchy Polish
   Purpose: reduce repeated trust text, compact hero typography, and make
   the left checkout column read as one clean purchase flow.
   No Stripe, PayPal, coupon, bump, order, fulfillment, download, or license logic changed.
========================================================= */
.ofi-cp-checkout.ofi-ui .ofi-cp-checkout-shell {
  grid-template-columns: minmax(0, 1fr) 390px !important;
  gap: 22px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-checkout-main {
  padding: 24px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-hero-card {
  margin-bottom: 18px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-topline-row {
  margin-bottom: 16px !important;
  gap: 8px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-topline {
  min-height: 28px !important;
  padding: 5px 10px !important;
  font-size: 12px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-title {
  max-width: 640px !important;
  font-size: clamp(28px, 2.55vw, 38px) !important;
  line-height: 1.10 !important;
  letter-spacing: -0.032em !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-hero-subtitle {
  margin-top: 13px !important;
  max-width: 680px !important;
  font-size: 15.5px !important;
  line-height: 1.56 !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-price-stack {
  margin-top: 20px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-price-row {
  gap: 10px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-regular-price {
  font-size: 15.5px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-price {
  font-size: clamp(34px, 3.1vw, 44px) !important;
  letter-spacing: -0.04em !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-save-pill {
  padding: 6px 11px !important;
  font-size: 13px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-payment-notes {
  display: inline-flex !important;
  width: auto !important;
  max-width: 100% !important;
  margin-top: 13px !important;
  padding: 8px 11px !important;
  gap: 8px !important;
  border: 1px solid var(--ofi-border) !important;
  border-radius: 999px !important;
  background: var(--ofi-surface-soft) !important;
  color: var(--ofi-text-soft) !important;
  font-size: 13.5px !important;
  line-height: 1.35 !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-payment-notes span + span::before {
  width: 4px !important;
  height: 4px !important;
  margin: 0 8px 3px 0 !important;
  background: #cbd5e1 !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-benefit-list {
  grid-template-columns: 1fr !important;
  max-width: 690px !important;
  margin-top: 20px !important;
  padding-top: 2px !important;
  gap: 10px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-benefit-list li {
  align-items: flex-start !important;
  gap: 9px !important;
  font-size: 14.8px !important;
  line-height: 1.42 !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-check-icon {
  width: 20px !important;
  height: 20px !important;
  font-size: 12px !important;
  margin-top: 1px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-trust-cards {
  display: none !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-form-card {
  margin-top: 16px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-section-title {
  margin-bottom: 12px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-summary-media {
  min-height: 128px !important;
  margin-bottom: 20px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-summary-media img {
  max-height: 120px !important;
}
@media (max-width: 1020px) {
  .ofi-cp-checkout.ofi-ui .ofi-cp-checkout-shell {
    grid-template-columns: 1fr !important;
  }
}
@media (max-width: 760px) {
  .ofi-cp-checkout.ofi-ui .ofi-cp-title {
    font-size: clamp(26px, 7.6vw, 34px) !important;
  }
  .ofi-cp-checkout.ofi-ui .ofi-cp-price {
    font-size: clamp(32px, 10vw, 40px) !important;
  }
  .ofi-cp-checkout.ofi-ui .ofi-cp-payment-notes {
    border-radius: 16px !important;
    width: 100% !important;
    justify-content: flex-start !important;
  }
}


/* =========================================================
   Phase 29B.4 — Chip Polish + Configurable Checkout Microcopy
   Purpose: make trust chips feel intentional/premium, add product-configurable
   microcopy, and turn technical payment status text into buyer-facing help.
   No Stripe, PayPal, coupon, bump, order, fulfillment, download, or license logic changed.
========================================================= */
.ofi-cp-checkout.ofi-ui .ofi-cp-topline-row {
  gap: 9px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-topline {
  min-height: 30px !important;
  padding: 6px 12px !important;
  border-color: rgba(37,99,235,.22) !important;
  background: linear-gradient(180deg, #eff6ff 0%, #eaf3ff 100%) !important;
  box-shadow: 0 8px 18px rgba(37,99,235,.07) !important;
  color: #0f3f9e !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-topline.is-soft {
  border-color: rgba(245,158,11,.22) !important;
  background: linear-gradient(180deg, #fff7ed 0%, #fffbeb 100%) !important;
  color: #9a3412 !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-microcopy {
  display: inline-flex !important;
  align-items: flex-start !important;
  gap: 8px !important;
  max-width: 680px !important;
  margin: 12px 0 0 !important;
  padding: 10px 12px !important;
  border: 1px solid #dbeafe !important;
  border-radius: 14px !important;
  background: linear-gradient(180deg, #f8fbff 0%, #eff6ff 100%) !important;
  color: #1e3a8a !important;
  font-size: 14px !important;
  line-height: 1.45 !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-microcopy span[aria-hidden="true"] {
  flex: 0 0 auto !important;
  line-height: 1.45 !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-payment-notes {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  margin-top: 13px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-payment-notes span {
  display: inline-flex !important;
  align-items: center !important;
  gap: 7px !important;
  min-height: 30px !important;
  padding: 7px 11px !important;
  border: 1px solid #dbeafe !important;
  border-radius: 999px !important;
  background: #f8fbff !important;
  color: #1e3a8a !important;
  font-size: 13.2px !important;
  line-height: 1.1 !important;
  font-weight: 600 !important;
  box-shadow: 0 7px 16px rgba(37,99,235,.055) !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-payment-notes span + span::before {
  content: none !important;
  display: none !important;
  width: 0 !important;
  height: 0 !important;
  margin: 0 !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-payment-notes span::before {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 18px !important;
  height: 18px !important;
  border-radius: 999px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  flex: 0 0 18px !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-payment-notes span:nth-child(1)::before {
  content: '✓' !important;
  background: #dcfce7 !important;
  color: #16a34a !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-payment-notes span:nth-child(2)::before {
  content: '↻' !important;
  background: #eef2ff !important;
  color: #4f46e5 !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-payment-notes span:nth-child(3)::before {
  content: '⚡' !important;
  background: #fff7ed !important;
  color: #ea580c !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-message {
  margin-top: 14px !important;
  min-height: 0 !important;
  padding: 11px 13px !important;
  border-radius: 14px !important;
  border: 1px solid #dbeafe !important;
  background: #f8fbff !important;
  color: #1e3a8a !important;
  font-size: 13.5px !important;
  line-height: 1.45 !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-message:empty {
  display: none !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-message.is-error {
  border-color: #fecaca !important;
  background: #fef2f2 !important;
  color: #991b1b !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-message.is-success {
  border-color: #bbf7d0 !important;
  background: #f0fdf4 !important;
  color: #166534 !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-message.is-info {
  border-color: #dbeafe !important;
  background: #f8fbff !important;
  color: #1e3a8a !important;
}
@media (max-width: 760px) {
  .ofi-cp-checkout.ofi-ui .ofi-cp-payment-notes span {
    width: 100% !important;
    justify-content: flex-start !important;
  }
  .ofi-cp-checkout.ofi-ui .ofi-cp-microcopy {
    display: flex !important;
    width: 100% !important;
  }
}

/* =========================================================
   Phase 30A — Checkout Visual Foundation
   Scope: typography, theme tokens, surfaces, spacing, hierarchy,
   form presentation and native OFI checkout controls only.
   Payment-provider internals and checkout business logic are unchanged.
   Typography rule: only 400, 500, 600 and 700 are used.
========================================================= */
.ofi-cp-checkout.ofi-ui {
  --ofi-cp-font: "Nunito Sans", "Avenir Next", "Segoe UI Rounded", "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  --ofi-primary: #0f9488;
  --ofi-primary-hover: #0b8178;
  --ofi-primary-dark: #075f5a;
  --ofi-primary-soft: #dff7f3;
  --ofi-primary-softer: #f0fbf9;
  --ofi-success: #0f9f6e;
  --ofi-success-soft: #e4f8ef;
  --ofi-bg: #f7fafb;
  --ofi-surface: #ffffff;
  --ofi-surface-soft: #f8fbfc;
  --ofi-text: #10213d;
  --ofi-text-soft: #40516a;
  --ofi-muted: #718096;
  --ofi-border: #dfe8ee;
  --ofi-border-soft: #edf2f5;
  --ofi-border-strong: #cddbe3;
  --ofi-shadow-soft: 0 18px 48px rgba(16, 33, 61, 0.075);
  --ofi-shadow-medium: 0 24px 70px rgba(16, 33, 61, 0.105);
  --ofi-shadow-primary: 0 15px 32px rgba(15, 148, 136, 0.24);
  width: min(1220px, calc(100% - 36px)) !important;
  margin: 24px auto 52px !important;
  color: var(--ofi-text) !important;
  font-family: var(--ofi-cp-font) !important;
  font-size: 16px !important;
  line-height: 1.5 !important;
  font-synthesis: none;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.ofi-cp-checkout.ofi-ui,
.ofi-cp-checkout.ofi-ui input,
.ofi-cp-checkout.ofi-ui select,
.ofi-cp-checkout.ofi-ui textarea,
.ofi-cp-checkout.ofi-ui button {
  font-family: var(--ofi-cp-font) !important;
}

/* Enforce the approved maximum font weight throughout the public checkout. */
.ofi-cp-checkout.ofi-ui :is(
  h1,h2,h3,h4,h5,h6,strong,b,label,button,
  .ofi-cp-title,.ofi-cp-price,.ofi-cp-save-pill,.ofi-cp-topline,
  .ofi-cp-section-title,.ofi-cp-panel-title,.ofi-cp-order-total,
  .ofi-cp-bump-title,.ofi-cp-bump-price-line,.ofi-cp-bump-eyebrow,
  .ofi-cp-order-line strong,.ofi-cp-summary-trust div,.ofi-cp-line-total,
  .ofi-cp-coupon-toggle,.ofi-cp-apply-coupon
) {
  font-weight: 700 !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-trust-points span::before,
.ofi-cp-checkout.ofi-ui .ofi-cp-payment-notes span::before,
.ofi-cp-checkout.ofi-ui .ofi-cp-check-icon {
  font-weight: 700 !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-checkout-shell {
  grid-template-columns: minmax(0, 1fr) 388px !important;
  gap: 24px !important;
  align-items: start !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-checkout-main,
.ofi-cp-checkout.ofi-ui .ofi-cp-order-box {
  border: 1px solid rgba(215, 226, 233, 0.94) !important;
  background: rgba(255, 255, 255, 0.985) !important;
  box-shadow: var(--ofi-shadow-soft) !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-checkout-main {
  padding: 30px !important;
  border-radius: 26px !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-order-box {
  top: 22px !important;
  padding: 22px !important;
  border-radius: 24px !important;
  background: linear-gradient(180deg, #ffffff 0%, #fbfdfd 100%) !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-hero-card {
  margin-bottom: 22px !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-topline-row {
  gap: 10px !important;
  margin-bottom: 20px !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-topline {
  min-height: 34px !important;
  padding: 7px 13px !important;
  border-color: rgba(15, 148, 136, 0.20) !important;
  background: linear-gradient(180deg, #f0fbf9 0%, #e7f8f5 100%) !important;
  color: #08766d !important;
  box-shadow: 0 8px 18px rgba(15, 148, 136, 0.07) !important;
  font-size: 13px !important;
  letter-spacing: 0 !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-topline.is-soft {
  border-color: rgba(16, 185, 129, 0.20) !important;
  background: linear-gradient(180deg, #f1fcf7 0%, #e9f9f1 100%) !important;
  color: #087a57 !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-title {
  max-width: 760px !important;
  font-size: clamp(34px, 3.35vw, 44px) !important;
  line-height: 1.08 !important;
  letter-spacing: -0.034em !important;
  color: #10213d !important;
  text-wrap: balance;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-hero-subtitle {
  max-width: 760px !important;
  margin-top: 14px !important;
  color: #465872 !important;
  font-size: 16.5px !important;
  line-height: 1.62 !important;
  font-weight: 400 !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-microcopy {
  display: flex !important;
  width: 100% !important;
  max-width: 760px !important;
  margin-top: 18px !important;
  padding: 14px 16px !important;
  gap: 10px !important;
  border: 1px solid #ccece7 !important;
  border-radius: 15px !important;
  background: linear-gradient(135deg, #f2fbfa 0%, #eaf8f6 100%) !important;
  color: #17665f !important;
  font-size: 14.5px !important;
  line-height: 1.5 !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.85) !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-price-stack {
  margin-top: 24px !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-price-row {
  gap: 11px !important;
  align-items: center !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-regular-price {
  color: #718096 !important;
  font-size: 16px !important;
  font-weight: 500 !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-price {
  color: #10213d !important;
  font-size: clamp(40px, 4vw, 50px) !important;
  line-height: 1 !important;
  letter-spacing: -0.045em !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-save-pill {
  min-height: 32px !important;
  padding: 7px 12px !important;
  border: 1px solid #c7ebe5 !important;
  border-radius: 999px !important;
  background: #dff7f3 !important;
  color: #08766d !important;
  font-size: 13px !important;
  box-shadow: none !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-payment-notes {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  width: 100% !important;
  max-width: 760px !important;
  gap: 12px !important;
  margin-top: 18px !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-payment-notes span {
  min-height: 56px !important;
  width: 100% !important;
  justify-content: flex-start !important;
  padding: 11px 13px !important;
  border: 1px solid #d7e7ea !important;
  border-radius: 13px !important;
  background: linear-gradient(180deg, #ffffff 0%, #f8fcfc 100%) !important;
  color: #234058 !important;
  font-size: 13.2px !important;
  line-height: 1.28 !important;
  font-weight: 600 !important;
  box-shadow: 0 7px 18px rgba(16, 33, 61, 0.045) !important;
  white-space: normal !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-payment-notes span::before {
  width: 21px !important;
  height: 21px !important;
  flex-basis: 21px !important;
  background: #e5f8f4 !important;
  color: #0f9488 !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-payment-notes span:nth-child(2)::before,
.ofi-cp-checkout.ofi-ui .ofi-cp-payment-notes span:nth-child(3)::before {
  background: #e5f8f4 !important;
  color: #0f9488 !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-benefit-list {
  max-width: 760px !important;
  margin-top: 22px !important;
  gap: 10px !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-benefit-list li {
  color: #263d57 !important;
  font-size: 14.8px !important;
  line-height: 1.45 !important;
  font-weight: 500 !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-check-icon {
  width: 21px !important;
  height: 21px !important;
  flex: 0 0 21px !important;
  border: 0 !important;
  background: #dff7f3 !important;
  color: #0d8b80 !important;
  box-shadow: none !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-bump-card {
  border-color: #d6e8e8 !important;
  background: linear-gradient(180deg, #fbfefe 0%, #f3faf9 100%) !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-bump-card:hover {
  border-color: #75c9c1 !important;
  box-shadow: 0 12px 26px rgba(15, 148, 136, 0.09) !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-bump-checkbox:checked + .ofi-cp-bump-card {
  border-color: #3bb3a8 !important;
  background: linear-gradient(180deg, #f0fbf9 0%, #f8fdfc 100%) !important;
  box-shadow: 0 14px 30px rgba(15, 148, 136, 0.12) !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-bump-eyebrow {
  background: #dff7f3 !important;
  color: #08766d !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-bump-price-line {
  color: #08766d !important;
}
.ofi-cp-checkout.ofi-ui .ofi-cp-bump-checkbox:checked + .ofi-cp-bump-card .ofi-cp-bump-toggle {
  background: #0f9488 !important;
}


.ofi-cp-checkout.ofi-ui .ofi-cp-form-card {
  margin-top: 18px !important;
  padding: 20px !important;
  border: 1px solid #dce7ed !important;
  border-radius: 18px !important;
  background: linear-gradient(180deg, #fbfdfd 0%, #f8fbfc 100%) !important;
  box-shadow: none !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-section-title {
  margin: 0 0 14px !important;
  color: #203650 !important;
  font-size: 13.5px !important;
  line-height: 1.35 !important;
  letter-spacing: 0.045em !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-grid-fields {
  gap: 15px 18px !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-form label {
  margin-bottom: 7px !important;
  color: #1d3049 !important;
  font-size: 13.5px !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-form :is(input[type=text], input[type=email], input[type=url], input[type=number], select, textarea) {
  min-height: 48px !important;
  padding: 11px 14px !important;
  border: 1px solid #cfdae2 !important;
  border-radius: 12px !important;
  background: #ffffff !important;
  color: #172b44 !important;
  font-size: 15px !important;
  font-weight: 400 !important;
  box-shadow: 0 2px 5px rgba(16, 33, 61, 0.04) !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-form :is(input, select, textarea):focus {
  outline: none !important;
  border-color: #5bc1b8 !important;
  box-shadow: 0 0 0 4px rgba(15, 148, 136, 0.11) !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-gateways {
  gap: 12px !important;
  margin-bottom: 16px !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-gateways label {
  min-height: 48px !important;
  min-width: 150px !important;
  padding: 12px 16px !important;
  border: 1px solid #d7e1e8 !important;
  border-radius: 12px !important;
  background: #ffffff !important;
  color: #233c55 !important;
  font-size: 13.5px !important;
  box-shadow: 0 5px 14px rgba(16, 33, 61, 0.045) !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-gateways label:has(input:checked) {
  border-color: #2eaea3 !important;
  background: #f0fbf9 !important;
  color: #08766d !important;
  box-shadow: 0 0 0 2px rgba(15, 148, 136, 0.08) !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-gateways input[type=radio] {
  accent-color: #0f9488 !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-panel {
  padding: 18px !important;
  border: 1px solid #d8e7e9 !important;
  border-radius: 16px !important;
  background: linear-gradient(180deg, #ffffff 0%, #f7fbfb 100%) !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-panel-title {
  color: #1c334b !important;
  font-size: 15.5px !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-panel-desc {
  color: #607086 !important;
  font-size: 13.5px !important;
  line-height: 1.5 !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-submit {
  min-height: 56px !important;
  margin-top: 9px !important;
  border: 0 !important;
  border-radius: 14px !important;
  background: linear-gradient(135deg, #0d9589 0%, #0c887f 100%) !important;
  color: #ffffff !important;
  font-size: 16px !important;
  letter-spacing: 0 !important;
  box-shadow: var(--ofi-shadow-primary) !important;
  transition: transform .16s ease, box-shadow .18s ease, filter .18s ease !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-submit:hover {
  transform: translateY(-1px) !important;
  filter: brightness(.985) !important;
  box-shadow: 0 18px 38px rgba(15, 148, 136, 0.29) !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-submit:focus-visible {
  outline: 3px solid rgba(15, 148, 136, 0.24) !important;
  outline-offset: 3px !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-trust-points {
  color: #627286 !important;
  font-size: 12.8px !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-trust-points span::before {
  background: #e5f8f4 !important;
  color: #0f9488 !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-message.is-info {
  border-color: #cdebe7 !important;
  background: #f2fbfa !important;
  color: #17665f !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-summary-media {
  min-height: 150px !important;
  margin-bottom: 20px !important;
  padding: 12px !important;
  border: 1px solid #d8e9eb !important;
  border-radius: 18px !important;
  background: linear-gradient(135deg, #eff8fb 0%, #e2f5f2 100%) !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-summary-media img {
  max-height: 138px !important;
  border-radius: 12px !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-order-box h4 {
  margin-bottom: 18px !important;
  color: #172b44 !important;
  font-size: 21px !important;
  letter-spacing: -0.02em !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-order-line,
.ofi-cp-checkout.ofi-ui .ofi-cp-order-total {
  border-color: #e4ecef !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-order-line span,
.ofi-cp-checkout.ofi-ui .ofi-cp-order-line strong {
  font-size: 14px !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-order-line.is-muted {
  color: #718096 !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-order-line.is-savings strong {
  color: #0d9a67 !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-order-total {
  color: #172b44 !important;
  font-size: 20px !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-order-total strong {
  color: #08766d !important;
  font-size: 23px !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-coupon-toggle {
  color: #087f75 !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-apply-coupon {
  border-color: #0f9488 !important;
  background: #0f9488 !important;
  color: #ffffff !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-summary-trust {
  border: 1px solid #dce9eb !important;
  border-radius: 16px !important;
  background: linear-gradient(180deg, #f8fcfc 0%, #f2f9f8 100%) !important;
  color: #2d4b5e !important;
}

@media (max-width: 980px) {
  .ofi-cp-checkout.ofi-ui .ofi-cp-checkout-shell {
    grid-template-columns: 1fr !important;
  }
  .ofi-cp-checkout.ofi-ui .ofi-cp-order-box {
    position: static !important;
  }
}

@media (max-width: 780px) {
  .ofi-cp-checkout.ofi-ui {
    width: min(100% - 20px, 1220px) !important;
    margin-top: 12px !important;
  }
  .ofi-cp-checkout.ofi-ui .ofi-cp-checkout-main,
  .ofi-cp-checkout.ofi-ui .ofi-cp-order-box {
    padding: 20px !important;
    border-radius: 20px !important;
  }
  .ofi-cp-checkout.ofi-ui .ofi-cp-title {
    font-size: clamp(29px, 8vw, 37px) !important;
  }
  .ofi-cp-checkout.ofi-ui .ofi-cp-price {
    font-size: clamp(36px, 11vw, 44px) !important;
  }
  .ofi-cp-checkout.ofi-ui .ofi-cp-payment-notes {
    grid-template-columns: 1fr !important;
  }
  .ofi-cp-checkout.ofi-ui .ofi-cp-payment-notes span {
    min-height: 46px !important;
  }
  .ofi-cp-checkout.ofi-ui .ofi-cp-grid-fields {
    grid-template-columns: 1fr !important;
  }
  .ofi-cp-checkout.ofi-ui .ofi-cp-field-full,
  .ofi-cp-checkout.ofi-ui .ofi-cp-field-half {
    grid-column: 1 / -1 !important;
  }
}

@media (max-width: 520px) {
  .ofi-cp-checkout.ofi-ui .ofi-cp-topline-row {
    gap: 8px !important;
  }
  .ofi-cp-checkout.ofi-ui .ofi-cp-topline {
    width: 100% !important;
    justify-content: flex-start !important;
  }
  .ofi-cp-checkout.ofi-ui .ofi-cp-price-row {
    align-items: flex-start !important;
  }
  .ofi-cp-checkout.ofi-ui .ofi-cp-gateways label {
    width: 100% !important;
  }
}

/* =========================================================
   Phase 30B — Premium Layout, Icons & Offer Badge
   Scope: public checkout markup presentation only.
   Payment-provider internals and business logic remain unchanged.
   Typography cap remains 700.
========================================================= */
.ofi-cp-checkout.ofi-ui .ofi-cp-svg-icon {
  display: inline-flex;
  width: 1em;
  height: 1em;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  color: currentColor;
  line-height: 1;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-svg-icon svg {
  display: block;
  width: 1em;
  height: 1em;
  overflow: visible;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-topline-icon {
  font-size: 15px;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-microcopy {
  align-items: center !important;
  gap: 13px !important;
  padding: 12px 15px !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-microcopy-icon {
  display: inline-flex;
  width: 38px;
  height: 38px;
  align-items: center;
  justify-content: center;
  flex: 0 0 38px;
  border: 1px solid rgba(15, 148, 136, .20);
  border-radius: 13px;
  background: rgba(255,255,255,.76);
  color: var(--ofi-primary);
  box-shadow: 0 5px 14px rgba(15, 148, 136, .08);
  font-size: 21px;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-microcopy-text {
  min-width: 0;
  color: #17665f;
  font-weight: 600;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-offer-badge {
  display: inline-flex !important;
  min-height: 32px !important;
  align-items: center !important;
  gap: 7px !important;
  padding: 7px 11px !important;
  border: 1px solid #f2d7a1 !important;
  border-radius: 999px !important;
  background: linear-gradient(180deg, #fffaf0 0%, #fff4dc 100%) !important;
  color: #8d5b08 !important;
  font-size: 12.8px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  box-shadow: 0 5px 14px rgba(141, 91, 8, .06) !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-offer-badge-icon {
  font-size: 14px;
}

/* Remove the legacy generated dots/checks now that the markup uses SVG icons. */
.ofi-cp-checkout.ofi-ui .ofi-cp-payment-notes span::before,
.ofi-cp-checkout.ofi-ui .ofi-cp-trust-points span::before {
  content: none !important;
  display: none !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-payment-note {
  display: flex !important;
  align-items: center !important;
  gap: 9px !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-payment-note > .ofi-cp-svg-icon {
  width: 22px;
  height: 22px;
  flex-basis: 22px;
  border-radius: 999px;
  background: #e5f8f4;
  color: var(--ofi-primary);
  font-size: 15px;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-payment-note > span:last-child {
  min-width: 0;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-check-icon .ofi-cp-svg-icon {
  font-size: 14px;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-section-title {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin-bottom: 16px !important;
  color: #183149 !important;
  font-size: 16px !important;
  line-height: 1.3 !important;
  letter-spacing: -0.01em !important;
  text-transform: none !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-section-icon {
  display: inline-flex;
  width: 31px;
  height: 31px;
  align-items: center;
  justify-content: center;
  flex: 0 0 31px;
  border: 1px solid #cce8e5;
  border-radius: 10px;
  background: #eaf8f6;
  color: var(--ofi-primary);
  font-size: 17px;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-form-card-contact,
.ofi-cp-checkout.ofi-ui .ofi-cp-form-card-payment {
  background: linear-gradient(180deg, #fbfefe 0%, #f6fafb 100%) !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-gateways {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  width: 100% !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-gateway-option {
  width: 100% !important;
  min-width: 0 !important;
  justify-content: flex-start !important;
  gap: 10px !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-gateway-option input[type=radio] {
  flex: 0 0 auto;
  margin: 0 !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-gateway-icon {
  display: inline-flex;
  width: 27px;
  height: 27px;
  align-items: center;
  justify-content: center;
  flex: 0 0 27px;
  border-radius: 9px;
  background: #f3f7f8;
  color: #3c5268;
  font-size: 16px;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-gateway-option:has(input:checked) .ofi-cp-gateway-icon {
  background: #dff7f3;
  color: var(--ofi-primary);
}

.ofi-cp-checkout.ofi-ui .ofi-cp-submit {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-submit-icon {
  font-size: 18px;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-submit.is-loading .ofi-cp-submit-icon {
  opacity: .72;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-trust-points {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 9px 16px !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-trust-points > span {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  min-width: 0;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-trust-points > span > .ofi-cp-svg-icon {
  color: var(--ofi-primary);
  font-size: 14px;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-trust-points > span > span:last-child {
  min-width: 0;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-order-title {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-order-title-icon {
  width: 32px;
  height: 32px;
  align-items: center;
  justify-content: center;
  border: 1px solid #cce8e5;
  border-radius: 10px;
  background: #eaf8f6;
  color: var(--ofi-primary);
  font-size: 17px;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-summary-trust {
  gap: 0 !important;
  padding: 17px !important;
  background: linear-gradient(180deg, #f9fdfc 0%, #f2f9f8 100%) !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-summary-trust-title {
  display: flex !important;
  align-items: center !important;
  gap: 9px !important;
  padding-bottom: 13px;
  border-bottom: 1px solid #dfeceb;
  color: #17665f !important;
  font-size: 14.5px;
  font-weight: 700 !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-summary-trust-title .ofi-cp-svg-icon {
  font-size: 18px;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-summary-trust-item {
  position: relative;
  display: grid !important;
  grid-template-columns: 32px minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  padding-top: 14px;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-summary-trust-icon {
  display: inline-flex;
  width: 28px;
  height: 28px;
  align-items: center;
  justify-content: center;
  border: 1px solid #cfe8e5;
  border-radius: 9px;
  background: #ffffff;
  color: var(--ofi-primary);
  font-size: 15px;
  box-shadow: 0 4px 10px rgba(16, 33, 61, .04);
}

.ofi-cp-checkout.ofi-ui .ofi-cp-summary-trust-copy {
  display: block;
  min-width: 0;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-summary-trust-copy strong,
.ofi-cp-checkout.ofi-ui .ofi-cp-summary-trust-copy small {
  display: block;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-summary-trust-copy strong {
  color: #17665f;
  font-size: 13.7px;
  line-height: 1.35;
  font-weight: 700 !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-summary-trust-copy small {
  margin-top: 3px;
  color: #68798a;
  font-size: 12.5px;
  line-height: 1.45;
  font-weight: 400 !important;
}

@media (max-width: 780px) {
  .ofi-cp-checkout.ofi-ui .ofi-cp-gateways {
    grid-template-columns: 1fr !important;
  }

  .ofi-cp-checkout.ofi-ui .ofi-cp-trust-points {
    align-items: flex-start !important;
    flex-direction: column !important;
  }

  .ofi-cp-checkout.ofi-ui .ofi-cp-trust-points > span {
    justify-content: flex-start !important;
  }
}

@media (max-width: 520px) {
  .ofi-cp-checkout.ofi-ui .ofi-cp-microcopy {
    align-items: flex-start !important;
  }

  .ofi-cp-checkout.ofi-ui .ofi-cp-microcopy-icon {
    width: 34px;
    height: 34px;
    flex-basis: 34px;
    font-size: 18px;
  }

  .ofi-cp-checkout.ofi-ui .ofi-cp-price-row {
    gap: 9px !important;
  }

  .ofi-cp-checkout.ofi-ui .ofi-cp-offer-badge {
    min-height: 30px !important;
    font-size: 12px !important;
  }
}

/* Phase 30B nested-span guard: Phase 30A intentionally styled every legacy
   payment-note span as a card. Reset only the new icon/text children. */
.ofi-cp-checkout.ofi-ui .ofi-cp-payment-note > .ofi-cp-svg-icon {
  display: inline-flex !important;
  width: 22px !important;
  height: 22px !important;
  min-height: 22px !important;
  flex: 0 0 22px !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: #e5f8f4 !important;
  color: var(--ofi-primary) !important;
  box-shadow: none !important;
  font-size: 15px !important;
  line-height: 1 !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-payment-note > span:last-child:not(.ofi-cp-svg-icon) {
  display: block !important;
  width: auto !important;
  min-width: 0 !important;
  min-height: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: inherit !important;
  box-shadow: none !important;
  font-size: inherit !important;
  line-height: inherit !important;
  font-weight: 600 !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-trust-points > span > span:last-child:not(.ofi-cp-svg-icon) {
  display: inline !important;
  width: auto !important;
  min-width: 0 !important;
}


/* =========================================================
   Phase 30C — Payment UI Polish & Interactive States
   Scope: provider-supported appearance, gateway switching,
   validation presentation, responsive payment polish.
   Business/payment logic remains unchanged.
========================================================= */
.ofi-cp-checkout.ofi-ui .ofi-cp-panel-stripe,
.ofi-cp-checkout.ofi-ui .ofi-cp-panel-paypal {
  transform-origin: top center;
  animation: ofiCpPanelIn .18s ease both;
}

@keyframes ofiCpPanelIn {
  from { opacity: 0; transform: translateY(4px); }
  to { opacity: 1; transform: translateY(0); }
}

.ofi-cp-checkout.ofi-ui .ofi-cp-stripe-element {
  position: relative;
  min-height: 250px;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-stripe-element.is-mounting::before {
  content: '';
  display: block;
  min-height: 230px;
  border-radius: 13px;
  background:
    linear-gradient(90deg, rgba(241,246,247,.7) 25%, rgba(255,255,255,.95) 42%, rgba(241,246,247,.7) 62%) 0 0 / 220% 100%,
    #f5f9fa;
  animation: ofiCpStripeLoading 1.15s linear infinite;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-stripe-element.is-mounting .ofi-cp-payment-element {
  position: absolute;
  inset: 0;
  opacity: 0;
  pointer-events: none;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-stripe-element.is-ready {
  min-height: 0;
}

@keyframes ofiCpStripeLoading {
  to { background-position: -220% 0, 0 0; }
}

.ofi-cp-checkout.ofi-ui .ofi-cp-paypal-buttons {
  width: 100%;
  max-width: none;
  min-height: 48px;
  overflow: hidden;
  border-radius: 12px;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-form[data-active-gateway="paypal"] .ofi-cp-panel-paypal {
  border-color: #d9e3ea !important;
  background: linear-gradient(180deg, #ffffff 0%, #f9fbfd 100%) !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-form[data-active-gateway="paypal"] .ofi-cp-trust-points {
  margin-top: 13px !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-submit {
  position: relative;
  isolation: isolate;
  overflow: hidden;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-submit.is-gateway-hidden {
  display: none !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-submit::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: -1;
  background: linear-gradient(110deg, transparent 18%, rgba(255,255,255,.18) 42%, transparent 66%);
  transform: translateX(-120%);
  transition: transform .45s ease;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-submit:hover::after {
  transform: translateX(120%);
}

.ofi-cp-checkout.ofi-ui .ofi-cp-submit:active {
  transform: translateY(0) scale(.997) !important;
  box-shadow: 0 10px 24px rgba(15, 148, 136, .20) !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-submit:disabled {
  cursor: wait !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-submit.is-loading .ofi-cp-submit-icon {
  display: none !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-submit.is-loading::before {
  content: '';
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
  border: 2px solid rgba(255,255,255,.45);
  border-top-color: #ffffff;
  border-radius: 999px;
  animation: ofiCpButtonSpin .75s linear infinite;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-submit.is-success {
  background: linear-gradient(135deg, #0e9b72 0%, #087f60 100%) !important;
  box-shadow: 0 15px 32px rgba(14, 155, 114, .24) !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-submit.is-error {
  background: linear-gradient(135deg, #b43b36 0%, #98302d 100%) !important;
  box-shadow: 0 12px 28px rgba(180, 59, 54, .20) !important;
}

@keyframes ofiCpButtonSpin {
  to { transform: rotate(360deg); }
}

.ofi-cp-checkout.ofi-ui .ofi-cp-field.has-error :is(input, select, textarea) {
  border-color: #d96a63 !important;
  background: #fffafa !important;
  box-shadow: 0 0 0 4px rgba(180, 35, 24, .08) !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-field.has-error label {
  color: #a61b1b !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-message {
  display: none;
  position: relative;
  align-items: flex-start;
  gap: 9px;
  min-height: 0 !important;
  margin-top: 14px !important;
  padding: 11px 13px 11px 40px !important;
  border: 1px solid transparent;
  border-radius: 12px;
  font-size: 13.2px !important;
  line-height: 1.45 !important;
  font-weight: 500 !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-message.has-message {
  display: block;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-message::before {
  content: '';
  position: absolute;
  left: 14px;
  top: 13px;
  width: 16px;
  height: 16px;
  border: 2px solid currentColor;
  border-radius: 999px;
  opacity: .72;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-message::after {
  content: '';
  position: absolute;
  left: 21px;
  top: 17px;
  width: 2px;
  height: 5px;
  border-radius: 2px;
  background: currentColor;
  box-shadow: 0 7px 0 -0.2px currentColor;
  opacity: .78;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-message.is-info {
  border-color: #cdebe7 !important;
  background: #f2fbfa !important;
  color: #17665f !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-message.is-success {
  border-color: #bfe8d3 !important;
  background: #f0fbf5 !important;
  color: #087a57 !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-message.is-error {
  border-color: #efc7c4 !important;
  background: #fff6f5 !important;
  color: #a61b1b !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-form.is-processing .ofi-cp-gateways,
.ofi-cp-checkout.ofi-ui .ofi-cp-form.is-processing .ofi-cp-grid-fields,
.ofi-cp-checkout.ofi-ui .ofi-cp-form.is-processing .ofi-cp-coupon-field {
  opacity: .76;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-gateway-option {
  transition: border-color .16s ease, background-color .16s ease, color .16s ease, box-shadow .16s ease, transform .16s ease !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-gateway-option:hover {
  transform: translateY(-1px);
  border-color: #a9d9d4 !important;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-gateway-option:focus-within {
  outline: 3px solid rgba(15, 148, 136, .13);
  outline-offset: 2px;
}

@media (max-width: 1100px) and (min-width: 981px) {
  .ofi-cp-checkout.ofi-ui .ofi-cp-checkout-shell {
    grid-template-columns: minmax(0, 1fr) 350px !important;
    gap: 20px !important;
  }
  .ofi-cp-checkout.ofi-ui .ofi-cp-checkout-main {
    padding: 25px !important;
  }
  .ofi-cp-checkout.ofi-ui .ofi-cp-order-box {
    padding: 19px !important;
  }
}

@media (max-width: 640px) {
  .ofi-cp-checkout.ofi-ui .ofi-cp-form-card {
    padding: 16px !important;
  }
  .ofi-cp-checkout.ofi-ui .ofi-cp-panel {
    padding: 15px !important;
  }
  .ofi-cp-checkout.ofi-ui .ofi-cp-submit {
    min-height: 54px !important;
    font-size: 15px !important;
  }
  .ofi-cp-checkout.ofi-ui .ofi-cp-message {
    padding-right: 11px !important;
  }
}

@media (hover: none) {
  .ofi-cp-checkout.ofi-ui .ofi-cp-submit:hover,
  .ofi-cp-checkout.ofi-ui .ofi-cp-gateway-option:hover {
    transform: none !important;
  }
  .ofi-cp-checkout.ofi-ui .ofi-cp-submit:hover::after {
    transform: translateX(-120%);
  }
}

@media (prefers-reduced-motion: reduce) {
  .ofi-cp-checkout.ofi-ui *,
  .ofi-cp-checkout.ofi-ui *::before,
  .ofi-cp-checkout.ofi-ui *::after {
    scroll-behavior: auto !important;
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
  }
}


/* =========================================================
   Phase 30D — Regression QA & Production Readiness
   ========================================================= */
.ofi-cp-checkout.ofi-ui,
.ofi-cp-checkout.ofi-ui .ofi-cp-checkout-shell,
.ofi-cp-checkout.ofi-ui .ofi-cp-checkout-main,
.ofi-cp-checkout.ofi-ui .ofi-cp-order-box,
.ofi-cp-checkout.ofi-ui .ofi-cp-form-card,
.ofi-cp-checkout.ofi-ui .ofi-cp-panel,
.ofi-cp-checkout.ofi-ui .ofi-cp-grid-fields,
.ofi-cp-checkout.ofi-ui .ofi-cp-field,
.ofi-cp-checkout.ofi-ui .ofi-cp-price-row,
.ofi-cp-checkout.ofi-ui .ofi-cp-payment-notes {
  min-width: 0;
}

.ofi-cp-checkout.ofi-ui :is(.ofi-cp-title,.ofi-cp-hero-subtitle,.ofi-cp-microcopy-text,.ofi-cp-benefit-list li span:last-child,.ofi-cp-panel-desc,.ofi-cp-summary-trust-copy,.ofi-cp-order-line span) {
  overflow-wrap: anywhere;
}

.ofi-cp-checkout.ofi-ui :is(.ofi-cp-order-line strong,.ofi-cp-order-total strong) {
  white-space: nowrap;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-offer-badge {
  max-width: 100%;
  white-space: normal;
  text-align: left;
}

.ofi-cp-checkout.ofi-ui.is-payment-locked :is(
  .ofi-cp-gateway-option,
  .ofi-cp-bump-card,
  .ofi-cp-coupon-toggle,
  .ofi-cp-coupon-row,
  .ofi-cp-stripe-element,
  .ofi-cp-paypal-buttons
) {
  pointer-events: none !important;
  cursor: progress !important;
}

.ofi-cp-checkout.ofi-ui.is-payment-locked :is(.ofi-cp-gateway-option,.ofi-cp-bump-card,.ofi-cp-coupon-field) {
  opacity: .68;
}

.ofi-cp-checkout.ofi-ui.is-payment-locked input[name="coupon_code"] {
  background: #f7fafb !important;
}

.ofi-cp-checkout.ofi-ui [aria-disabled="true"] {
  cursor: progress;
}

.ofi-cp-checkout.ofi-ui :is(input,select,textarea,button):focus-visible,
.ofi-cp-checkout.ofi-ui .ofi-cp-bump-checkbox:focus-visible + .ofi-cp-bump-card {
  outline: 3px solid rgba(15, 148, 136, .18) !important;
  outline-offset: 2px;
}

.ofi-cp-checkout.ofi-ui .ofi-cp-coupon-toggle:disabled,
.ofi-cp-checkout.ofi-ui .ofi-cp-apply-coupon:disabled {
  opacity: .65;
}

@media (max-width: 480px) {
  .ofi-cp-checkout.ofi-ui .ofi-cp-checkout-main,
  .ofi-cp-checkout.ofi-ui .ofi-cp-order-box {
    padding-left: 15px !important;
    padding-right: 15px !important;
  }

  .ofi-cp-checkout.ofi-ui .ofi-cp-price-row {
    gap: 9px !important;
  }

  .ofi-cp-checkout.ofi-ui .ofi-cp-price {
    font-size: clamp(36px, 12vw, 46px) !important;
  }

  .ofi-cp-checkout.ofi-ui .ofi-cp-regular-price,
  .ofi-cp-checkout.ofi-ui .ofi-cp-save-pill,
  .ofi-cp-checkout.ofi-ui .ofi-cp-offer-badge {
    flex: 0 1 auto;
  }

  .ofi-cp-checkout.ofi-ui .ofi-cp-coupon-row {
    flex-direction: column !important;
    align-items: stretch !important;
  }

  .ofi-cp-checkout.ofi-ui .ofi-cp-apply-coupon {
    width: 100%;
  }
}
