/* ===========================================================================
   RoyalCare Booking — front-end styles
   Scoped under .rcb-app so it never collides with the Elementor theme.
   Design notes:
     • All corners are SQUARE (border-radius:0).
     • Progress bar scrolls with the page (NOT sticky).
     • Summary rail becomes sticky only once scrolled to (JS-toggled).
     • Content max-width 1240px, 24px left/right gutters to match the header.
   ========================================================================= */

.rcb-app{
  --blue:#4A9FE0;--blue-dk:#1A5C8A;--blue-dkr:#0D2B45;--blue-lt:#A8D8F5;--blue-pl:#EBF5FD;
  --gold:#F5A623;--gold-dk:#C47D08;--gold-lt:#FFD06A;--gold-pl:#FFF8ED;
  --ink:#0F1E2E;--body:#3A4A5C;--muted:#7A8EA0;--line:rgba(74,159,224,0.14);
  --cream:#F9FBFD;--warm:#F2F6FA;--ease:cubic-bezier(.16,1,.3,1);
  font-family:'Plus Jakarta Sans',sans-serif;color:var(--ink);line-height:1.65;
}
.rcb-app *,.rcb-app *::before,.rcb-app *::after{box-sizing:border-box}
.rcb-app a{text-decoration:none;color:inherit}
.rcb-app img{max-width:100%;display:block}

/* ── HERO ──────────────────────────────────────────────────────────────── */
.rcb-hero{background:linear-gradient(155deg,var(--blue-dkr) 0%,var(--blue-dk) 55%,#163A5C 100%);padding:120px 0 120px;position:relative}
.rcb-hero .rcb-wrap{position:relative;z-index:2}
.rcb-wrap{max-width:1240px;margin:0 auto;padding:0 24px}
.rcb-hero .bc{font-size:.75rem;color:rgba(255,255,255,.46);margin-bottom:20px;display:flex;align-items:center;gap:7px}
.rcb-hero .bc a{color:rgba(255,255,255,.6)}.rcb-hero .bc a:hover{color:#fff}
.rcb-hero h1{font-family:'Playfair Display',serif;font-size:clamp(2.3rem,4.6vw,4rem);font-weight:600;line-height:1.07;color:#fff;margin:0 0 18px}
.rcb-hero h1 em{font-style:italic;color:var(--gold-lt)}
.rcb-hero .hero-lead{font-size:1.02rem;color:rgba(255,255,255,.74);max-width:640px;line-height:1.85;margin:0}

/* ── SHELL / LAYOUT ────────────────────────────────────────────────────── */
.rcb-section{background:var(--warm);padding:70px 0 80px;position:relative}
.rcb-tool-shell{max-width:1240px;margin:0 auto;padding:0 24px;position:relative;z-index:3}
/* Form steps on the LEFT (lead), summary rail on the RIGHT */
.rcb-book-layout{display:grid;grid-template-columns:1fr 330px;gap:32px;align-items:start}
/* After a successful booking the rail is gone — center the confirmation full-width */
.rcb-book-layout.rcb-confirmed{grid-template-columns:1fr}
.rcb-book-layout.rcb-confirmed > div{max-width:860px;margin:0 auto;width:100%}

/* ── PROGRESS (scrolls with the page — NOT sticky) ─────────────────────── */
.rcb-prog-bar{padding:0 0 16px;margin-bottom:4px}
.rcb-app .prog-wrap{background:#fff;border:1.5px solid var(--line);border-radius:0;padding:16px 20px;box-shadow:0 6px 24px rgba(74,159,224,.10)}
.rcb-app .prog-label{display:flex;justify-content:space-between;font-size:.74rem;font-weight:600;color:var(--muted);margin-bottom:8px}
.rcb-app .prog-track{height:6px;background:var(--line);border-radius:0;overflow:hidden}
.rcb-app .prog-fill{height:100%;background:linear-gradient(90deg,var(--blue),var(--gold));border-radius:0;transition:width .5s var(--ease)}

/* ── DRAFT BANNER ──────────────────────────────────────────────────────── */
.rcb-app .draft-banner{background:linear-gradient(135deg,var(--gold-pl),#fff);border:1.5px solid rgba(245,166,35,.4);border-radius:0;padding:16px 20px;margin-bottom:18px;display:none;align-items:center;gap:16px;flex-wrap:wrap}
.rcb-app .draft-banner.show{display:flex}
.rcb-app .draft-banner .db-txt{flex:1;min-width:200px}
.rcb-app .draft-banner .db-txt strong{display:block;font-size:.92rem;color:var(--ink);font-weight:700;margin-bottom:2px}
.rcb-app .draft-banner .db-txt span{font-size:.8rem;color:var(--body)}
.rcb-app .draft-banner .db-btns{display:flex;gap:8px}
.rcb-app .db-resume{background:var(--gold);color:#fff;border:none;padding:9px 18px;border-radius:0;font-weight:700;font-size:.8rem;cursor:pointer;font-family:inherit;transition:all .2s}
.rcb-app .db-resume:hover{background:var(--gold-lt);color:var(--ink)}
.rcb-app .db-discard{background:transparent;color:var(--muted);border:1.5px solid var(--line);padding:9px 18px;border-radius:0;font-weight:600;font-size:.8rem;cursor:pointer;font-family:inherit}
.rcb-app .db-discard:hover{background:var(--warm);color:var(--body)}

/* ── STEP BLOCKS ───────────────────────────────────────────────────────── */
.rcb-app .step-block{background:#fff;border:1.5px solid var(--line);border-radius:0;margin-bottom:18px;overflow:hidden;transition:opacity .4s var(--ease),box-shadow .3s,border-color .3s;scroll-margin-top:120px}
.rcb-app .step-block.locked{opacity:.5;pointer-events:none;filter:grayscale(.3)}
.rcb-app .step-block.locked .sb-body{display:none}
.rcb-app .step-block.active{border-color:rgba(74,159,224,.45);box-shadow:0 12px 40px rgba(74,159,224,.13)}
.rcb-app .step-block.done .sb-body{display:none}
.rcb-app .step-block.done.editing .sb-body{display:block}
.rcb-app .sb-head{display:flex;align-items:center;gap:14px;padding:20px 24px;cursor:default}
.rcb-app .step-block.done .sb-head{cursor:pointer}
.rcb-app .sb-num{min-width:34px;height:34px;border-radius:0;background:var(--warm);border:2px solid var(--line);color:var(--muted);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;flex-shrink:0;transition:all .3s}
.rcb-app .step-block.active .sb-num{background:var(--gold);border-color:var(--gold);color:#fff}
.rcb-app .step-block.done .sb-num{background:var(--blue-dk);border-color:var(--blue-dk);color:#fff}
.rcb-app .sb-head-text{flex:1;min-width:0}
.rcb-app .sb-title{font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:600;color:var(--ink);line-height:1.25}
.rcb-app .sb-title em{font-style:italic;color:var(--blue-dk)}
.rcb-app .step-block.locked .sb-title{color:var(--muted)}
.rcb-app .sb-summary{font-size:.8rem;color:var(--blue-dk);font-weight:600;margin-top:3px;display:none}
.rcb-app .step-block.done .sb-summary{display:block}
.rcb-app .sb-edit{background:var(--blue-pl);border:1px solid rgba(74,159,224,.3);color:var(--blue-dk);font-size:.72rem;font-weight:700;padding:7px 15px;border-radius:0;cursor:pointer;flex-shrink:0;display:none;transition:all .2s;font-family:inherit}
.rcb-app .sb-edit:hover{background:var(--blue-dk);color:#fff}
.rcb-app .step-block.done .sb-edit{display:inline-block}
.rcb-app .step-block.done.editing .sb-edit{display:none}
.rcb-app .sb-body{padding:4px 24px 24px}
.rcb-app .step-sub{font-size:.9rem;color:var(--muted);margin:0 0 22px;line-height:1.6}
.rcb-app .sb-actions{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:22px;padding-top:18px;border-top:1px solid var(--line)}
.rcb-app .sb-actions.end{justify-content:flex-end}
.rcb-app .btn-continue{background:var(--blue-dk);color:#fff;border:none;padding:13px 28px;border-radius:0;font-family:inherit;font-size:.88rem;font-weight:700;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px}
.rcb-app .btn-continue:hover:not(:disabled){background:var(--blue);transform:translateY(-1px)}
.rcb-app .btn-continue:disabled{opacity:.4;cursor:not-allowed;transform:none}
.rcb-app .btn-prev{background:var(--warm);color:var(--body);border:1.5px solid var(--line);padding:11px 22px;border-radius:0;font-family:inherit;font-size:.84rem;font-weight:600;cursor:pointer;transition:all .2s}
.rcb-app .btn-prev:hover{background:#e8eef4}

/* ── CARDS GRID ────────────────────────────────────────────────────────── */
.rcb-app .c-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.rcb-app .c-card{background:#fff;border:2px solid var(--line);border-radius:0;padding:18px 16px;cursor:pointer;transition:all .22s;position:relative;display:flex;align-items:flex-start;gap:13px}
.rcb-app .c-card:hover{border-color:rgba(74,159,224,.4);box-shadow:0 6px 24px rgba(74,159,224,.1);transform:translateY(-2px)}
.rcb-app .c-card.sel{border-color:var(--blue-dk);background:var(--blue-pl)}
.rcb-app .c-card.sel::after{content:"";position:absolute;top:10px;right:12px;width:22px;height:22px;background:var(--blue-dk);border-radius:50%;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 8'%3E%3Cpath d='M1 4L3.5 6.5L9 1' stroke='white' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:11px}
.rcb-app .c-ico{font-size:1.8rem;flex-shrink:0;margin-top:1px}
.rcb-app .c-title{font-size:.9rem;font-weight:700;color:var(--ink);margin-bottom:3px}
.rcb-app .c-sub{font-size:.76rem;color:var(--muted);line-height:1.5}
.rcb-app .c-card.sel .c-title{color:var(--blue-dk)}

/* ── URGENCY ───────────────────────────────────────────────────────────── */
.rcb-app .u-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.rcb-app .u-card{background:#fff;border:2px solid var(--line);border-radius:0;padding:22px 16px;cursor:pointer;text-align:center;transition:all .22s}
.rcb-app .u-card:hover{border-color:rgba(74,159,224,.4);transform:translateY(-2px)}
.rcb-app .u-card.sel{border-color:var(--gold);background:var(--gold-pl)}
.rcb-app .u-ico{font-size:2rem;margin-bottom:10px}
.rcb-app .u-title{font-size:.9rem;font-weight:700;color:var(--ink);margin-bottom:4px}
.rcb-app .u-sub{font-size:.76rem;color:var(--muted)}

/* ── INPUTS ────────────────────────────────────────────────────────────── */
.rcb-app .t-input{width:100%;padding:14px 18px;border:2px solid var(--line);border-radius:0;font-family:inherit;font-size:.95rem;color:var(--ink);outline:none;background:#fff;transition:all .2s}
.rcb-app .t-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(74,159,224,.12)}
.rcb-app .t-area{width:100%;min-height:110px;padding:14px 16px;border:2px solid var(--line);border-radius:0;font-family:inherit;font-size:.9rem;color:var(--ink);outline:none;resize:vertical;line-height:1.6;transition:border-color .2s}
.rcb-app .t-area:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(74,159,224,.12)}
.rcb-app .fg label{display:block;font-size:.68rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}

/* ── CITY DROPDOWN ─────────────────────────────────────────────────────── */
.rcb-app .c-drop{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1.5px solid var(--line);border-radius:0;box-shadow:0 12px 40px rgba(74,159,224,.14);z-index:100;max-height:220px;overflow-y:auto;display:none}
.rcb-app .c-drop.open{display:block}
.rcb-app .c-opt{padding:12px 16px;font-size:.88rem;cursor:pointer;transition:background .15s;display:flex;justify-content:space-between;align-items:center}
.rcb-app .c-opt:hover{background:var(--blue-pl);color:var(--blue-dk)}
.rcb-app .c-opt-region{font-size:.72rem;color:var(--muted)}
.rcb-app .city-ok{background:var(--blue-pl);border:1.5px solid rgba(74,159,224,.3);border-radius:0;padding:13px 16px;font-size:.88rem;font-weight:600;color:var(--blue-dk);margin-top:10px;display:flex;align-items:center;gap:10px}

/* ── QTY CONTROLS ──────────────────────────────────────────────────────── */
.rcb-app .svc-qty{display:flex;align-items:center;gap:10px;margin-top:14px;background:var(--warm);border:1px solid var(--line);border-radius:0;padding:12px 16px}
.rcb-app .svc-qty label{font-size:.8rem;font-weight:700;color:var(--ink);flex:1}
.rcb-app .qty-ctrl{display:flex;align-items:center;gap:0;border:1.5px solid var(--line);border-radius:0;overflow:hidden;background:#fff}
.rcb-app .qty-ctrl button{width:38px;height:38px;border:none;background:#fff;font-size:1.3rem;font-weight:700;color:var(--blue-dk);cursor:pointer;transition:background .15s;line-height:1}
.rcb-app .qty-ctrl button:hover{background:var(--blue-pl)}
.rcb-app .qty-ctrl input{width:50px;height:38px;border:none;border-left:1px solid var(--line);border-right:1px solid var(--line);text-align:center;font-family:inherit;font-size:13px;font-weight:700;color:var(--ink);outline:none}
.rcb-app .qty-unit{font-size:.74rem;color:var(--muted);min-width:74px}

/* ── PAYMENT ───────────────────────────────────────────────────────────── */
.rcb-app .charge-box{background:var(--gold-pl);border:1.5px solid rgba(245,166,35,.35);border-radius:0;padding:16px 18px;margin:18px 0;text-align:center}
.rcb-app .charge-box .cb-lbl{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-dk);margin-bottom:4px}
.rcb-app .charge-box .cb-amt{font-family:'Playfair Display',serif;font-size:1.7rem;font-weight:600;color:var(--ink)}
.rcb-app .charge-box .cb-note{font-size:.74rem;color:var(--body);margin-top:5px;line-height:1.5}
.rcb-app .pay-card{background:#fff;border:2px solid var(--line);border-radius:0;padding:26px 24px;margin-top:8px}
.rcb-app .pay-card .pc-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.rcb-app .pay-card .pc-head .lock{display:flex;align-items:center;gap:7px;font-size:.74rem;font-weight:700;color:#1F9D55}
.rcb-app .pay-card .pc-head .cards{display:flex;gap:6px}
.rcb-app .card-badge{font-size:.62rem;font-weight:800;letter-spacing:.04em;padding:4px 8px;border-radius:0;background:var(--warm);color:var(--body);border:1px solid var(--line)}
.rcb-app .pf{margin-bottom:14px}
.rcb-app .pf label{display:block;font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
/* Stripe Element mount points styled like inputs */
.rcb-app .pf .StripeElement,.rcb-app .pf input{width:100%;padding:13px 15px;border:1.5px solid #D0DFec;border-radius:0;font-family:inherit;font-size:.95rem;color:var(--ink);background:#fff;outline:none;transition:border-color .2s,box-shadow .2s;letter-spacing:.02em}
.rcb-app .pf .StripeElement--focus,.rcb-app .pf input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(74,159,224,.12)}
.rcb-app .pf .StripeElement--invalid{border-color:#E5484D}
.rcb-app .pf-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.rcb-app .pf-err{font-size:.72rem;color:#E5484D;margin-top:5px;display:none}
.rcb-app .pf-err.show{display:block}
.rcb-app .pay-error{background:#FEF1F1;border:1px solid #F3C7C7;color:#B42318;border-radius:0;padding:12px 14px;font-size:.82rem;margin-top:12px;display:none}
.rcb-app .pay-error.show{display:block}
.rcb-app .trust-row{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:18px}
.rcb-app .trust-pill{display:flex;align-items:center;gap:7px;font-size:.74rem;color:var(--body);font-weight:600}
.rcb-app .trust-pill span{font-size:1rem}

/* ── PROCESSING ────────────────────────────────────────────────────────── */
.rcb-app .ai-load{display:none;text-align:center;padding:60px 20px;background:#fff;border:1.5px solid var(--line);border-radius:0}
.rcb-app .ai-load.active{display:block}
.rcb-app .ai-spin{width:54px;height:54px;border:4px solid var(--line);border-top-color:var(--blue);border-radius:50%;animation:rcbspin 1s linear infinite;margin:0 auto 22px}
@keyframes rcbspin{to{transform:rotate(360deg)}}
.rcb-app .ai-load-title{font-family:'Playfair Display',serif;font-size:1.5rem;color:var(--ink);margin-bottom:8px}
.rcb-app .ai-steps{display:flex;flex-direction:column;gap:6px;max-width:380px;margin:18px auto 0}
.rcb-app .ai-step-item{font-size:.82rem;color:var(--muted);padding:7px 13px;border-radius:0;transition:all .4s;text-align:left}
.rcb-app .ai-step-item.doing{background:var(--blue-pl);color:var(--blue-dk);font-weight:600}
.rcb-app .ai-step-item.done{color:var(--body)}

/* ── SUMMARY RAIL ──────────────────────────────────────────────────────── */
.rcb-app .summary-rail{position:relative;top:0;background:#fff;border:1px solid var(--line);border-radius:0;padding:24px 22px;box-shadow:0 8px 30px rgba(74,159,224,.08);align-self:start}
.rcb-app .summary-rail.is-sticky{position:sticky;top:var(--rcb-sticky-top,110px)}
.rcb-app .summary-rail h4{font-family:'Playfair Display',serif;font-size:1.15rem;color:var(--ink);margin:0 0 4px}
.rcb-app .summary-rail .sr-sub{font-size:.74rem;color:var(--muted);margin-bottom:18px}
.rcb-app .sr-line{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:9px 0;border-bottom:1px dashed var(--line);font-size:.82rem}
.rcb-app .sr-line .k{color:var(--muted);font-weight:600}
.rcb-app .sr-line .v{color:var(--ink);font-weight:700;text-align:right;max-width:170px}
.rcb-app .sr-empty{font-size:.8rem;color:var(--muted);font-style:italic;padding:14px 0}
.rcb-app .sr-total{margin-top:16px;padding:16px;border-radius:0;background:var(--blue-pl);text-align:center}
.rcb-app .sr-total .lbl{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--blue-dk);margin-bottom:4px}
.rcb-app .sr-total .amt{font-family:'Playfair Display',serif;font-size:1.9rem;font-weight:600;color:var(--blue-dk);line-height:1}
.rcb-app .sr-total .per{font-size:.72rem;color:var(--muted);margin-top:4px}
.rcb-app .sr-note{font-size:.68rem;color:var(--muted);text-align:center;margin-top:12px;line-height:1.5}

/* ── CONFIRMATION ──────────────────────────────────────────────────────── */
.rcb-app .confirm-wrap{display:none}
.rcb-app .confirm-wrap.show{display:block;animation:rcbIn .5s var(--ease)}
@keyframes rcbIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.rcb-app .confirm-hero{background:linear-gradient(145deg,var(--blue-dk),var(--blue-dkr));border-radius:0;padding:48px 40px;color:#fff;text-align:center;position:relative;overflow:hidden;margin-bottom:22px}
.rcb-app .confirm-hero::before{content:'';position:absolute;top:-60px;right:-60px;width:280px;height:280px;border-radius:50%;background:rgba(74,159,224,.12)}
.rcb-app .confirm-check{width:72px;height:72px;border-radius:50%;background:rgba(31,157,85,.2);border:2px solid #4ADE80;display:flex;align-items:center;justify-content:center;font-size:2.2rem;margin:0 auto 18px;position:relative;z-index:1}
.rcb-app .confirm-hero h2{font-family:'Playfair Display',serif;font-size:2rem;font-weight:600;margin-bottom:10px;position:relative;z-index:1}
.rcb-app .confirm-hero p{font-size:.94rem;color:rgba(255,255,255,.8);max-width:480px;margin:0 auto;line-height:1.7;position:relative;z-index:1}
.rcb-app .confirm-ref{display:inline-block;margin-top:18px;background:rgba(245,166,35,.18);border:1px solid rgba(245,166,35,.4);border-radius:0;padding:8px 22px;font-size:.84rem;font-weight:700;color:var(--gold-lt);position:relative;z-index:1}
.rcb-app .confirm-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:22px}
.rcb-app .confirm-box{background:#fff;border:1px solid var(--line);border-radius:0;padding:24px 22px}
.rcb-app .confirm-box h4{font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin:0 0 14px}
.rcb-app .confirm-box .cb-line{display:flex;justify-content:space-between;gap:12px;padding:7px 0;font-size:.85rem;border-bottom:1px solid var(--line)}
.rcb-app .confirm-box .cb-line:last-child{border-bottom:none}
.rcb-app .confirm-box .cb-line .k{color:var(--muted);font-weight:600}
.rcb-app .confirm-box .cb-line .v{color:var(--ink);font-weight:700;text-align:right}
.rcb-app .next-steps{background:#fff;border:1px solid var(--line);border-radius:0;padding:26px 24px;margin-bottom:22px}
.rcb-app .next-steps h4{font-family:'Playfair Display',serif;font-size:1.25rem;color:var(--ink);margin:0 0 16px}
.rcb-app .next-steps ol{list-style:none;counter-reset:ns;display:flex;flex-direction:column;gap:14px;margin:0;padding:0}
.rcb-app .next-steps li{counter-increment:ns;display:flex;gap:14px;align-items:flex-start;font-size:.88rem;color:var(--body);line-height:1.6}
.rcb-app .next-steps li::before{content:counter(ns);min-width:30px;height:30px;background:var(--blue-dk);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;flex-shrink:0}
.rcb-app .confirm-cta{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}
.rcb-app .btn-gold{display:inline-flex;align-items:center;gap:8px;background:var(--gold);color:#fff;border:none;padding:13px 26px;border-radius:0;font-weight:700;font-size:.86rem;cursor:pointer;text-decoration:none}
.rcb-app .btn-gold:hover{background:var(--gold-lt);color:var(--ink)}
.rcb-app .btn-outline{display:inline-flex;align-items:center;gap:8px;background:#fff;color:var(--blue-dk);border:1.5px solid var(--blue);padding:13px 26px;border-radius:0;font-weight:700;font-size:.86rem;cursor:pointer;text-decoration:none}
.rcb-app .btn-outline:hover{background:var(--blue-pl)}

/* ── NOT CONFIGURED NOTICE ─────────────────────────────────────────────── */
.rcb-app .rcb-notice{background:#FEF8ED;border:1.5px solid var(--gold-lt);border-radius:0;padding:14px 18px;font-size:.85rem;color:var(--gold-dk);margin-bottom:18px}

/* ── RESPONSIVE ────────────────────────────────────────────────────────── */
@media(max-width:880px){
  .rcb-book-layout{grid-template-columns:1fr}
  /* On mobile the summary sits BELOW the steps and is never sticky */
  .rcb-app .summary-rail,.rcb-app .summary-rail.is-sticky{position:static;order:2;top:auto}
  .rcb-app .confirm-grid{grid-template-columns:1fr}
  .rcb-app .step-block{scroll-margin-top:90px}
}
@media(max-width:768px){
  .rcb-hero{padding:88px 0 88px}
  .rcb-section{padding:48px 0 64px}
  .rcb-wrap,.rcb-tool-shell{padding:0 24px}
  .rcb-hero h1{font-size:clamp(2rem,8vw,2.6rem)}
  .rcb-hero .hero-lead{font-size:.96rem}
  .rcb-app .c-grid,.rcb-app .u-grid,.rcb-app .pf-row{grid-template-columns:1fr}
  .rcb-app .sb-head{padding:16px 18px}
  .rcb-app .sb-body{padding:4px 18px 20px}
  .rcb-app .draft-banner .db-btns{width:100%}
  .rcb-app .db-resume,.rcb-app .db-discard{flex:1}
  .rcb-app .confirm-hero{padding:36px 24px}
}
@media(max-width:480px){
  .rcb-hero{padding:72px 0 72px}
}

/* ── Tax / fee breakdown, wallet button, callouts (v1.2) ───────────── */
.rcb-app .charge-box .cb-breakdown{margin-top:14px;text-align:left;background:#fff;border:1px solid var(--line);padding:12px 14px}
.rcb-app .cbk-row{display:flex;justify-content:space-between;align-items:center;font-size:.82rem;color:var(--body);padding:4px 0}
.rcb-app .cbk-row.cbk-total{border-top:1px solid var(--line);margin-top:4px;padding-top:8px;font-weight:700;color:var(--ink)}
.rcb-app .cbk-row.cbk-balance{color:var(--blue-dk);font-weight:700}
.rcb-app .charge-box .cb-explain{font-size:.82rem;line-height:1.55;color:var(--gold-dk);margin-top:12px;font-weight:600}
.rcb-app .wallet-wrap{margin:18px 0 4px}
.rcb-app #rcbPaymentRequestButton{margin-bottom:14px}
.rcb-app .wallet-or{display:flex;align-items:center;text-align:center;color:var(--muted);font-size:.74rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin:6px 0 2px}
.rcb-app .wallet-or::before,.rcb-app .wallet-or::after{content:"";flex:1;height:1px;background:var(--line)}
.rcb-app .wallet-or span{padding:0 12px}
.rcb-app .sr-break{margin-top:12px;border-top:1px solid var(--line);padding-top:10px}
.rcb-app .srb-row{display:flex;justify-content:space-between;font-size:.78rem;color:var(--body);padding:3px 0}
.rcb-app .srb-row.srb-total{font-weight:700;color:var(--ink);border-top:1px solid var(--line);margin-top:3px;padding-top:7px}
.rcb-app .srb-row.srb-today{color:var(--blue-dk);font-weight:700}
.rcb-app .confirm-callout{background:var(--blue-pl);border:1.5px solid rgba(74,159,224,.3);border-left-width:4px;padding:14px 18px;margin:18px 0;font-size:.9rem;line-height:1.6;color:var(--blue-dk);font-weight:600}

/* ── Terms & Privacy agreement checkbox (v1.2.1) ───────────────────── */
.rcb-app .rcb-agree{display:flex;align-items:flex-start;gap:10px;margin:18px 0 4px;font-size:.82rem;line-height:1.5;color:var(--body);cursor:pointer;justify-content:center}
.rcb-app .rcb-agree input[type=checkbox]{width:18px;height:18px;min-width:18px;margin-top:1px;accent-color:var(--blue-dk);cursor:pointer}
.rcb-app .rcb-agree a{color:var(--blue-dk);font-weight:600;text-decoration:underline}
.rcb-app .rcb-agree a:hover{color:var(--blue)}
.rcb-app .rcb-req{color:#E5484D;font-weight:700}
