/* CD mobile pass: P1.1 hero input → bordered input-prefix affordance on mobile; P1.2 header z-index bumped + isolation so content never bleeds through; P1.3 chart annotations hidden on mobile, replaced with caption list; P1.4 .helper mono override scoped to desktop only (mobile uses body sans); P1.5 Scope cell no-wrap on middle-dot separators; P2.1 .hero-ask mobile one step down; P2.2 pension helper paragraph split into 3 blocks; P2.3 TL;DR merge skipped (would remove facts or create strain). */
:root{--header-h:71px;--bg:#FFFFFF;--surface:#FFFFFF;--surface-alt:#F2F4F7;--border:rgba(91,97,110,0.20);--border-soft:rgba(91,97,110,0.12);--border-focus:#0052FF;--text:#0A0B0D;--text-muted:#5B616E;--text-light:#7D8492;--accent:#0A0B0D;--accent-light:#EEF0F3;--accent-dark:#0A0B0D;--brand:#0052FF;--brand-hover:#578BFA;--brand-soft:rgba(0,82,255,0.10);--coral:#0052FF;--green:#067647;--green-bg:#ECFDF3;--green-border:#ABEFC6;--amber:#B54708;--amber-bg:#FFFAEB;--amber-border:#FEDF89;--red:#B42318;--red-bg:#FEF3F2;--red-border:#FECDCA;--radius:10px;--radius-lg:16px;--ring-warm:rgba(91,97,110,0.18);--ring-deep:rgba(91,97,110,0.32);--shadow-sm:0 0 0 1px var(--border-soft);--shadow:0 4px 24px rgba(10,11,13,.05),0 0 0 1px var(--border-soft);--shadow-lg:0 12px 40px rgba(10,11,13,.06),0 0 0 1px var(--border-soft);--font-body:'Manrope',-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;--font-display:'Manrope',ui-sans-serif,system-ui,sans-serif;--font-mono:'DM Mono',ui-monospace,Menlo,monospace;--transition:0.2s ease;--space-xs:12px;--space-sm:16px;--space-md:24px;--rec-space-lg:18px;--rec-space-md:10px;--rec-space-sm:6px;--rec-divider:rgba(10,11,13,.10);--rec-border:rgba(91,97,110,0.20);--val-warn-bg:#FFFAEB;--val-stop-bg:#FEF3F2;--val-warn-bg-mobile:#FEF0C7;--val-stop-bg-mobile:#FEE4E2}
[data-theme="dark"]{--bg:#0A0B0D;--surface:#13151A;--surface-alt:#1C1F24;--border:rgba(255,255,255,0.10);--border-soft:rgba(255,255,255,0.06);--border-focus:#578BFA;--text:#FFFFFF;--text-muted:#A4ABB8;--text-light:#7D8492;--accent:#FFFFFF;--accent-light:rgba(0,82,255,0.12);--accent-dark:#FFFFFF;--brand:#578BFA;--brand-hover:#7BA6FC;--brand-soft:rgba(87,139,250,0.14);--coral:#578BFA;--green:#3CCB7F;--green-bg:rgba(60,203,127,0.10);--green-border:rgba(60,203,127,0.25);--amber:#F59E0B;--amber-bg:rgba(245,158,11,0.10);--amber-border:rgba(245,158,11,0.25);--red:#F87171;--red-bg:rgba(248,113,113,0.10);--red-border:rgba(248,113,113,0.25);--ring-warm:rgba(255,255,255,0.10);--ring-deep:rgba(255,255,255,0.18);--shadow-sm:0 0 0 1px var(--border);--shadow:0 4px 24px rgba(0,0,0,.4),0 0 0 1px var(--border);--shadow-lg:0 12px 40px rgba(0,0,0,.5),0 0 0 1px var(--border);--rec-divider:rgba(164,171,184,.18);--rec-border:rgba(164,171,184,.22);--val-warn-bg:rgba(245,158,11,0.10);--val-stop-bg:rgba(248,113,113,0.10)}
[data-theme="dark"] .site-header{background:rgba(10,11,13,.85);border-bottom-color:var(--border)}
[data-theme="dark"] .recommendation{background:var(--surface-alt);border-color:var(--border)}
[data-theme="dark"] .recommendation p,
[data-theme="dark"] .recommendation .action-subheadline,
[data-theme="dark"] .supporting-savings,
[data-theme="dark"] .recommendation .inline-note{color:var(--text-muted)}
[data-theme="dark"] .recommendation h4{color:var(--brand)}
[data-theme="dark"] .recommendation .action-subsection-heading{color:var(--text-muted)}
[data-theme="dark"] .action-headline,
[data-theme="dark"] .recommendation .action-headline strong{color:var(--text)}
[data-theme="dark"] .pension-warning{background:var(--amber-bg);border-color:var(--amber-border);color:var(--amber)}
[data-theme="dark"] .alt-route-banner{background:var(--amber-bg);border-color:var(--amber-border);color:var(--amber)}
[data-theme="dark"] input[type="text"],
[data-theme="dark"] input[type="number"],
[data-theme="dark"] select,
[data-theme="dark"] input[type="date"]{background:var(--surface-alt);border-color:var(--border);color:var(--text)}
[data-theme="dark"] .toggle-group label{border-color:var(--border);color:var(--text-muted);background:var(--surface)}
[data-theme="dark"] .toggle-group label:hover{border-color:var(--ring-deep);background:var(--surface-alt);color:var(--text)}
[data-theme="dark"] .toggle-group input:checked+label{border-color:rgba(255,255,255,0.3);background:rgba(255,255,255,0.09);color:var(--text)}
[data-theme="dark"] .route-tab{color:var(--text-muted)}
[data-theme="dark"] .route-tab.active{background:var(--surface);color:var(--text);box-shadow:0 1px 2px rgba(0,0,0,.3),0 0 0 1px var(--border)}
[data-theme="dark"] .route-switcher{background:var(--surface-alt)}
[data-theme="dark"] .compact-details{border-color:var(--border);background:var(--surface-alt)}
[data-theme="dark"] .compact-details summary{color:var(--text)}
[data-theme="dark"] .breakdown-details{border-color:var(--border);background:var(--surface-alt)}
[data-theme="dark"] .breakdown-details summary{color:var(--text)}
[data-theme="dark"] .breakdown-inner{border-top-color:var(--border)}
[data-theme="dark"] .conditional-inner{background:var(--surface-alt);border-color:var(--border)}
[data-theme="dark"] .scenario-verdict{background:var(--surface-alt);color:var(--text);border:1px solid var(--border)}
[data-theme="dark"] input:focus,
[data-theme="dark"] select:focus{box-shadow:0 0 0 3px rgba(87,139,250,.22)}
[data-theme="dark"] .disclaimer{border-top-color:var(--border);color:var(--text-light)}
[data-theme="dark"] .hero{background:transparent;border-bottom-color:var(--border)}
[data-theme="dark"] .hero-salary{border-bottom-color:var(--border)}
[data-theme="dark"] .hero-salary:focus-within{border-bottom-color:var(--text)}
.header-right{display:flex;align-items:center;gap:12px}
.theme-toggle{
  display:inline-flex;align-items:center;justify-content:center;
  width:36px;height:36px;border-radius:50%;
  background:transparent;border:1px solid var(--border);
  color:var(--text);cursor:pointer;padding:0;
  transition:background var(--transition),border-color var(--transition);
  flex-shrink:0;
}
.theme-toggle:hover{border-color:var(--ring-deep);background:var(--surface-alt)}
.theme-toggle svg{width:16px;height:16px;display:block}
.theme-toggle .moon{display:block}
.theme-toggle .sun{display:none}
[data-theme="dark"] .theme-toggle .moon{display:none}
[data-theme="dark"] .theme-toggle .sun{display:block}
*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;min-height:100vh;transition:background-color .3s ease,color .3s ease}
.site-header{border-bottom:1px solid var(--border-soft);padding:18px 0;position:sticky;top:0;z-index:100;backdrop-filter:saturate(1.5) blur(12px);-webkit-backdrop-filter:saturate(1.5) blur(12px);background:rgba(255,255,255,.85)}
.header-inner{max-width:1120px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.header-brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.header-dot{width:10px;height:10px;border-radius:50%;background:var(--brand);flex-shrink:0;box-shadow:0 0 0 3px rgba(0,82,255,0.08)}
[data-theme="dark"] .header-dot{background:var(--brand);box-shadow:0 0 0 3px rgba(87,139,250,0.14)}
.header-wordmark{font-family:var(--font-display);font-size:17px;font-weight:600;color:var(--text);letter-spacing:-.015em;line-height:1;white-space:nowrap}
.header-divider{width:1px;height:18px;background:var(--border);margin:0 4px;flex-shrink:0}
.header-eyebrow{font-family:var(--font-mono);font-size:11.5px;font-weight:500;color:var(--text-muted);letter-spacing:.14em;text-transform:uppercase;line-height:1;white-space:nowrap}
.header-eyebrow .sep{margin:0 6px;color:var(--text-light);opacity:.7}
/* Legacy classes kept as no-ops in case cached markup leaks in */
.header-icon,.header-title,.header-badge{display:none}
.layout{max-width:1120px;margin:0 auto;padding:40px 24px 80px;display:grid;grid-template-columns:1fr 420px;gap:32px}
.hero{grid-column:1/-1;background:transparent;padding:clamp(28px,4vw,48px) 0 clamp(24px,4vw,40px);color:var(--text);text-align:left;border-bottom:1px solid var(--border-soft);margin-bottom:40px}
.hero-input-wrap{max-width:680px;margin:0 auto;padding:0 8px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;padding:5px 13px;background:var(--surface-alt);border:1px solid var(--border-soft);border-radius:999px;font-size:12px;font-weight:500;letter-spacing:.04em;color:var(--text-muted);margin-bottom:28px;text-transform:uppercase}
.hero-eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--amber)}
.hero-ask{font-family:var(--font-display);font-size:clamp(40px,4.4vw,56px);font-weight:600;letter-spacing:-.025em;color:var(--text);margin:0 0 28px;line-height:1.08;max-width:16ch}
.hero-salary{display:flex;align-items:baseline;justify-content:flex-start;gap:10px;border-bottom:2px solid var(--border);padding:0 0 14px;margin-bottom:0;transition:border-color .2s ease;flex-wrap:wrap}
.hero-salary:focus-within{border-bottom-color:var(--text)}
.hero-salary-prefix{font-family:var(--font-display);font-size:clamp(50px,5vw,56px);font-weight:500;color:var(--text-light);line-height:1;letter-spacing:-.03em;flex-shrink:0}
.hero-salary input[type="text"]{flex:0 0 auto;min-width:0;width:auto;max-width:100%;font-family:var(--font-display);font-size:clamp(50px,5vw,56px);font-weight:500;color:var(--text);line-height:1;letter-spacing:-.03em;border:none!important;outline:none;background:transparent!important;padding:0;font-variant-numeric:tabular-nums;border-radius:0;box-shadow:none!important;height:auto}
.hero-salary input[type="text"]::placeholder{color:var(--text-light);opacity:.35}
.hero-salary input[type="text"]:focus,.hero-salary input[type="text"]:hover{box-shadow:none!important;border:none!important;background:transparent!important}
.hero-salary-suffix{font-family:var(--font-body);font-size:15px;font-weight:400;color:var(--text-muted);white-space:nowrap;flex-shrink:0;align-self:baseline;padding-bottom:6px}
.hero-salary-presets{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:18px 0 0}
.hero-salary-presets button{min-height:34px;padding:7px 14px;border:1px solid var(--border);border-radius:16px;background:var(--surface);color:var(--text);font-family:var(--font-mono);font-size:12px;font-weight:500;letter-spacing:.04em;cursor:pointer;transition:background var(--transition),border-color var(--transition),color var(--transition)}
.hero-salary-presets button:hover{border-color:var(--text)}
.hero-salary-presets button:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
.hero-salary-presets button.is-active{background:var(--text);border-color:var(--text);color:var(--bg)}
[data-theme="dark"] .hero-salary-presets button{background:var(--surface);border-color:var(--border);color:var(--text-muted)}
[data-theme="dark"] .hero-salary-presets button:hover{border-color:var(--ring-deep);color:var(--text)}
[data-theme="dark"] .hero-salary-presets button.is-active{background:var(--text);border-color:var(--text);color:var(--bg)}
.hero-chart{margin:40px 0 0;display:block}
.hero-chart-caption{font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.08em;color:var(--text-light);margin-bottom:12px;text-transform:uppercase}
.hero-chart-bar{display:flex;width:100%;height:18px;border-radius:5px;overflow:hidden;background:var(--surface-alt);box-shadow:0 0 0 1px var(--border-soft) inset}
.hero-chart-seg{height:100%;transition:flex-basis .18s cubic-bezier(.4,0,.2,1);min-width:0;position:relative}
.hero-chart-seg+.hero-chart-seg{border-left:1px solid rgba(255,255,255,.6)}
.hero-chart-seg--tax{background:#E8833A;flex:0 0 30%}
.hero-chart-seg--ni{background:#9CA3AF;flex:0 0 8%}
.hero-chart-seg--takehome{background:#0A0B0D;flex:0 0 62%}
[data-theme="dark"] .hero-chart-bar{background:var(--surface-alt);box-shadow:0 0 0 1px var(--border) inset}
[data-theme="dark"] .hero-chart-seg--tax{background:#F59E0B}
[data-theme="dark"] .hero-chart-seg--ni{background:#6B7280}
[data-theme="dark"] .hero-chart-seg--takehome{background:#FFFFFF}
[data-theme="dark"] .hero-chart-seg+.hero-chart-seg{border-left-color:rgba(10,11,13,.45)}
.hero-chart-legend{list-style:none;padding:0;margin:18px 0 0;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}
.hero-chart-item{display:flex;flex-direction:column;gap:4px;min-width:0;padding-left:14px;position:relative}
.hero-chart-item .swatch{position:absolute;left:0;top:8px;width:8px;height:8px;border-radius:2px}
.hero-chart-item[data-item="tax"] .swatch{background:#E8833A}
.hero-chart-item[data-item="ni"] .swatch{background:#9CA3AF}
.hero-chart-item[data-item="takehome"] .swatch{background:#0A0B0D}
[data-theme="dark"] .hero-chart-item[data-item="tax"] .swatch{background:#F59E0B}
[data-theme="dark"] .hero-chart-item[data-item="ni"] .swatch{background:#6B7280}
[data-theme="dark"] .hero-chart-item[data-item="takehome"] .swatch{background:#FFFFFF}
.hero-chart-item .amount-val{font-family:var(--font-display);font-size:22px;font-weight:500;color:var(--text);letter-spacing:-.01em;font-variant-numeric:tabular-nums;line-height:1.1;transition:opacity .15s ease}
.hero-chart-item .meta{font-size:12.5px;color:var(--text-muted);font-weight:400;line-height:1.3}
.hero-chart-item .pct{color:var(--text-light);font-variant-numeric:tabular-nums}
.hero-chart.is-placeholder .amount-val,.hero-chart.is-placeholder .meta .pct{opacity:.85}
/* Ghost preview — shown before user types. Desaturated, mono caption signals "example data". */
.hero-chart.is-ghost .hero-chart-bar{filter:saturate(.25);opacity:.55}
.hero-chart.is-ghost .hero-chart-item{opacity:.5}
.hero-chart.is-ghost .hero-chart-item .swatch{filter:saturate(.25)}
.hero-chart.is-ghost #heroChartCaption{color:var(--text-light)}
.hero-chart-bar,.hero-chart-item,.hero-chart-item .swatch{transition:opacity .35s cubic-bezier(.4,0,.2,1),filter .35s cubic-bezier(.4,0,.2,1)}
/* Legacy reveal classes retained in case cached hero markup still references them. */
.hero-reveal{opacity:1;transform:translateY(0);transition:opacity .35s cubic-bezier(.4,0,.2,1),transform .35s cubic-bezier(.4,0,.2,1)}
.hero--empty .hero-reveal{opacity:0;transform:translateY(8px);pointer-events:none;visibility:hidden;height:0;margin:0;overflow:hidden}
.hero-spiel{font-size:15.5px;color:var(--text-muted);margin:0 0 28px;line-height:1.6;max-width:62ch}
.hero-cta-row{display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:36px}
.hero-cta{display:inline-flex;align-items:center;gap:6px;padding:11px 22px;background:var(--text);color:var(--bg);border-radius:999px;font-family:var(--font-body);font-size:14.5px;font-weight:500;text-decoration:none;border:1px solid var(--text);transition:background .15s ease,color .15s ease,transform .15s ease}
.hero-cta:hover{background:var(--surface);color:var(--text);transform:translateY(-1px)}
.hero-cta:focus-visible{outline:2px solid var(--brand);outline-offset:3px}
.hero-cta-secondary{display:inline-flex;align-items:center;gap:6px;padding:11px 20px;background:transparent;color:var(--text-muted);border-radius:999px;font-family:var(--font-body);font-size:14.5px;font-weight:500;text-decoration:none;border:1px solid var(--border);transition:color .15s ease,border-color .15s ease,background .15s ease,transform .15s ease}
.hero-cta-secondary:hover{color:var(--text);border-color:var(--ring-deep);background:var(--surface-alt);transform:translateY(-1px)}
.hero-cta-secondary:focus-visible{outline:2px solid var(--brand);outline-offset:3px}
[data-theme="dark"] .hero-cta{background:var(--text);color:var(--bg);border-color:var(--text)}
[data-theme="dark"] .hero-cta:hover{background:var(--surface-alt);color:var(--text)}
[data-theme="dark"] .hero-cta-secondary{color:var(--text-muted);border-color:var(--border)}
[data-theme="dark"] .hero-cta-secondary:hover{color:var(--text);background:var(--surface-alt);border-color:var(--ring-deep)}

.input-col{display:flex;flex-direction:column}
.input-col .card:last-child{flex:1;margin-bottom:0}
.card{background:var(--surface);border:1px solid var(--border-soft);border-radius:16px;padding:30px;margin-bottom:var(--space-md);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition),border-color var(--transition)}
.card:hover{box-shadow:var(--shadow);border-color:var(--border)}
.card--secondary{background:#f7f7f8}
[data-theme="dark"] .card--secondary{background:#0f1117}
.card-header{display:flex;align-items:center;gap:var(--space-xs);margin-bottom:var(--space-sm);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border)}
.card-title{font-family:var(--font-display);font-size:21px;font-weight:500;letter-spacing:-.012em;color:var(--text)}
.card-subtitle{font-size:13.5px;color:var(--text-muted);margin-top:4px;line-height:1.5}
.field{margin-bottom:var(--space-md)}.field>*:last-child{margin-bottom:0!important}.field:last-child{margin-bottom:0}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-xs);margin-bottom:var(--space-md)}.field-row>.field{margin-bottom:0}.field-row:last-child{margin-bottom:0}
label{display:block;font-size:14px;font-weight:500;margin-bottom:var(--space-xs);color:var(--text)}
.helper{font-size:12.5px;color:var(--text-muted);margin-top:var(--space-xs);margin-bottom:0;line-height:1.5}
.helper-inline{font-size:12.5px;color:var(--text-light);font-weight:400;margin-left:4px}
.bonus-type-radios,
.pension-type-radios{display:none;}
.unit-input{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:6px;width:100%;padding:4px;border:1px solid var(--border);border-radius:12px;background:#fff;transition:border-color var(--transition),box-shadow var(--transition);}
.unit-input:focus-within{border-color:var(--border-focus);box-shadow:0 0 0 3px rgba(0,82,255,.18);}
.unit-input-fields{min-width:0;}
.unit-input .input-prefix,
.unit-input .input-suffix{width:100%;}
.unit-input .input-prefix::before,
.unit-input .input-suffix::after{display:none;}
.unit-input input[type="text"],
.unit-input input[type="number"]{min-height:38px;padding:8px 10px;border:0;border-radius:8px;background:transparent;box-shadow:none;}
.unit-input input[type="text"]:hover,
.unit-input input[type="number"]:hover,
.unit-input input[type="text"]:focus,
.unit-input input[type="number"]:focus{border-color:transparent;box-shadow:none;}
.unit-toggle{display:grid;grid-template-columns:repeat(2,34px);gap:2px;padding:2px;border:1px solid var(--border-soft);border-radius:9px;background:var(--surface-alt);}
.unit-toggle-btn{height:34px;padding:0;border:0;border-radius:7px;background:transparent;color:var(--text-muted);font-family:var(--font-body);font-size:13px;font-weight:600;line-height:1;cursor:pointer;transition:background var(--transition),color var(--transition);}
.unit-toggle-btn:hover{color:var(--text);}
.unit-toggle-btn.is-active{background:rgba(0,0,0,0.09);color:var(--text);}
[data-theme="dark"] .unit-input{background:var(--surface-alt);border-color:var(--border);}
[data-theme="dark"] .unit-toggle{background:var(--surface);border-color:var(--border);}
[data-theme="dark"] .unit-toggle-btn.is-active{background:rgba(255,255,255,0.09);color:var(--text);}
input[type="text"],input[type="number"],select{width:100%;padding:12px 14px;font-size:15px;font-family:var(--font-body);border:1px solid var(--border);border-radius:12px;background:#FFFFFF;color:var(--text);transition:border-color var(--transition),box-shadow var(--transition);font-variant-numeric:tabular-nums}
input[type="text"]:hover,input[type="number"]:hover,select:hover{border-color:var(--ring-deep)}
select{padding-right:36px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%237D8492' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;cursor:pointer}
input[type="number"]::-webkit-inner-spin-button,input[type="number"]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
input:focus,select:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px rgba(0,82,255,.18)}
.input-prefix{position:relative}.input-prefix::before{content:'\00A3';position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:15px;pointer-events:none;z-index:1}.input-prefix input{padding-left:28px}
.input-suffix{position:relative}.input-suffix::after{content:attr(data-suffix);position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:14px;pointer-events:none}.input-suffix input{padding-right:36px}
.field-group{margin-top:0;padding-top:var(--space-md);border-top:1px solid var(--border)}
.benefit-list{display:flex;flex-direction:column;gap:var(--space-xs)}.benefit-row .input-prefix{position:relative}
.remove-benefit-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);width:22px;height:22px;padding:0;border:none;background:transparent;color:var(--text-muted);font-size:16px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background var(--transition),color var(--transition)}
.remove-benefit-btn:hover{background:var(--red-bg);color:var(--red)}
.add-link-btn{margin-top:var(--space-xs);background:transparent;border:none;color:var(--accent-dark);font-size:13px;font-weight:600;cursor:pointer;padding:0}.add-link-btn:hover{text-decoration:underline}
.toggle-group{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:0}
.toggle-group label{display:flex;align-items:center;gap:6px;padding:9px 14px;border:1px solid var(--border);border-radius:12px;cursor:pointer;font-size:14px;font-weight:500;color:var(--text-muted);background:#FFFFFF;transition:all var(--transition);user-select:none;margin-bottom:0}
.toggle-group label:hover{border-color:var(--ring-deep);color:var(--text);background:#FFFFFF}
.toggle-group input:checked+label{border-color:rgba(0,0,0,0.3);background:rgba(0,0,0,0.09);color:var(--text);font-weight:500}
.toggle-group input{display:none}
.field--car-status>label .helper-inline{display:block;margin:3px 0 0;line-height:1.35;}
.field--car-status .toggle-group--car-status{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:3px;flex-wrap:nowrap;width:100%;padding:3px;border:1px solid var(--border);border-radius:12px;background:var(--surface-alt);}
.field--car-status .toggle-group--car-status label{min-width:0;min-height:38px;justify-content:center;margin:0;padding:8px 10px;border:0;border-radius:9px;background:transparent;color:var(--text-muted);font-size:13.5px;line-height:1.2;text-align:center;white-space:nowrap;}
.field--car-status .toggle-group--car-status label:hover{background:transparent;color:var(--text);}
.field--car-status .toggle-group--car-status input:checked+label{background:rgba(0,0,0,0.09);color:var(--text);border-color:transparent;box-shadow:none;}
[data-theme="dark"] .field--car-status .toggle-group--car-status{background:var(--surface-alt);border-color:var(--border);}
[data-theme="dark"] .field--car-status .toggle-group--car-status label{background:transparent;}
[data-theme="dark"] .field--car-status .toggle-group--car-status input:checked+label{background:rgba(255,255,255,0.09);color:var(--text);}
.field .helper-inline{white-space:normal}
.field+.field,.field-row+.field,.field-group+.field,.field-group+.field-group,.conditional+.field{margin-top:0}
.field>label+.toggle-group,.field>label+.input-prefix,.field>label+.input-suffix,.field>label+select,.field>label+input{margin-top:0}
.field>.toggle-group+.helper,.field>.input-prefix+.helper,.field>.input-suffix+.helper,.field>select+.helper,.field>input+.helper{margin-top:var(--space-xs)}
.field>.helper+.field,.field>.helper+.conditional,.field>.helper+.input-prefix,.field>.helper+.input-suffix,.field>.helper+.toggle-group{margin-top:0}
#bonusPctFields,#bonusAmountFields,#pensionPctFields,#pensionAmountFields{margin-bottom:0}
#pensionBaseToggle{margin-top:var(--space-sm)}
.pension-advanced-toggle{
  display:flex;
  width:100%;
  justify-content:flex-start;
  margin:14px 0 6px;
  padding:0;
  border:0;
  background:transparent;
  font-family:var(--font-body);
}
.pension-advanced-toggle::after{content:"+";margin-left:auto;color:var(--text-light);font-weight:600}
.pension-advanced-toggle[aria-expanded="true"]::after{content:"-"}
#pensionBaseFields{margin-top:0}
.field--pension-mode > #pensionBaseFields + .helper{margin-top:0}
#pensionBaseFields .field--pension-basis,
#pensionBaseFields .field--bonus-sacrifice{
  display:grid;
  grid-template-columns:minmax(0,190px) minmax(180px,1fr);
  gap:12px;
  align-items:center;
  margin:0 0 14px;
}
#pensionBaseFields .field--pension-basis label,
#pensionBaseFields .field--bonus-sacrifice label{margin:0}
#pensionBaseFields .mobile-pension-basis-select,
#pensionBaseFields .mobile-bonus-sac-select{
  display:block;
  width:100%;
  max-width:360px;
}
#pensionBaseFields .field--pension-basis .toggle-group,
#pensionBaseFields .field--bonus-sacrifice .toggle-group{display:none}
.conditional{overflow:hidden;max-height:0;opacity:0;transition:max-height .35s ease,opacity .25s ease,margin .25s ease;margin-top:0}
.conditional.open{max-height:2000px;opacity:1;margin-top:var(--space-sm)}
.conditional-inner{background:var(--surface-alt);border:1px solid var(--border-soft);border-radius:14px;padding:var(--space-sm)}
.results-col{position:sticky;top:90px;max-height:calc(100vh - 110px);display:flex;flex-direction:column;align-self:start}
.results-card{background:var(--surface);border:1px solid var(--border-soft);border-radius:16px;box-shadow:0 4px 24px rgba(10,11,13,.05),0 0 0 1px var(--border-soft);overflow:hidden;display:flex;flex-direction:column;max-height:calc(100vh - 110px)}
.results-header{padding:26px 28px 22px;border-bottom:1px solid var(--border)}
.results-header h2{font-family:var(--font-display);font-size:24px;font-weight:500;letter-spacing:-.014em;line-height:1.15}
.results-subtitle{font-size:13.5px;color:var(--text-muted);margin-top:6px;line-height:1.5}
.results-header-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.results-body{padding:24px 28px 28px;overflow-y:auto;flex:1 1 auto}
.status-banner{padding:26px 24px 24px;border-radius:16px;margin-bottom:0;font-size:14px;line-height:1.6}
.status-banner .status-title{font-weight:500;font-size:14.5px;margin-top:20px;margin-bottom:8px;padding-top:18px;border-top:1px solid rgba(10,11,13,.08);line-height:1.5}
.status-banner .status-childcare{margin-top:14px;padding-top:12px;border-top:1px solid rgba(10,11,13,.08);font-size:13px;line-height:1.55;opacity:.88}
.status-banner .status-childcare strong{font-weight:600}
.status-under{background:var(--green-bg);border:1px solid var(--green-border);color:var(--green)}
.status-close{background:var(--amber-bg);border:1px solid var(--amber-border);color:var(--amber)}
.status-over{background:var(--red-bg);border:1px solid var(--red-border);color:var(--red)}
.status-desktop-copy{display:block}
.mobile-status-card{display:none}
.status-ani{font-family:var(--font-display);font-size:46px;font-weight:500;line-height:1;margin-bottom:6px;font-variant-numeric:tabular-nums;letter-spacing:-.024em}
.status-ani-sub{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.09em;opacity:.72;margin-bottom:14px}
.status-delta{font-size:13.5px;font-weight:500;margin-bottom:12px;opacity:.85;font-variant-numeric:tabular-nums}
.result-section{margin-bottom:20px}
.result-section-title{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-light);font-weight:500;margin-bottom:12px}
.result-row{display:flex;justify-content:space-between;align-items:baseline;padding:7px 0;font-size:14px}
.result-row .label{color:var(--text-muted);font-weight:400}
.result-row .value{font-weight:500;font-variant-numeric:tabular-nums;text-align:right;flex-shrink:0;margin-left:16px;color:var(--text)}
.result-row.step{padding-left:0}
.result-row.highlight{padding:11px 14px;margin:4px -14px;background:var(--surface-alt);border-radius:10px;border:1px solid var(--border-soft)}
.result-row.highlight .label{color:var(--text);font-weight:500}
.result-row.highlight .value{font-size:16px;color:var(--text);font-family:var(--font-display);font-weight:500}
.result-divider{border:none;border-top:1px solid var(--border);margin:14px 0}
.breakdown-note{font-size:12.5px;color:var(--text-muted);margin-top:8px;line-height:1.5;font-style:italic}
.result-row.take-home-monthly{padding-top:4px;border-top:none}
.result-row.take-home-monthly .label,.result-row.take-home-monthly .value{font-size:13px;color:var(--text-muted);font-weight:500}
#childcareResult,#actionPanel{position:relative}
/* Family cost callout (HICBC + CB + childcare) — sits beneath statusBanner */
#familyCostCallout{margin:12px 0 4px}
.fcc{background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px}
.fcc-intro{display:flex;align-items:baseline;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.fcc-eyebrow{font-size:12.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted)}
.fcc-total{font-family:var(--font-mono);font-size:28px;font-weight:500;letter-spacing:-.02em;color:var(--amber);line-height:1}
.fcc-total.pos{color:var(--green)}
.fcc-peryr{font-family:var(--font-body);font-size:13px;font-weight:400;color:var(--text-muted);margin-left:6px;letter-spacing:0}
.fcc-rows{display:flex;flex-direction:column;gap:8px}
.fcc-row{display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:14px}
.fcc-label{color:var(--text-muted)}
.fcc-val{font-family:var(--font-mono);font-weight:500;font-size:14px;color:var(--text)}
.fcc-val.neg{color:var(--amber)}
.fcc-val.pos{color:var(--green)}
[data-theme="dark"] .fcc{background:var(--surface-alt);border-color:var(--border)}
/* Diagnostic section (ANI + childcare) sits above a clear separator */
.results-diagnostic{margin-bottom:0}
/* Separator between diagnostic and prescription */
.results-section-divider{border:none;border-top:1px solid var(--border);margin:24px 0 22px}
#actionPanel:not(:empty){margin-top:0;padding-top:0;border-top:none}
#actionPanel.validation-stop{margin-top:0;padding-top:0;border-top:none}
.breakdown-wrap{margin-top:24px;padding-top:20px;border-top:1px solid var(--border)}
.recommendation .recommendation-divider{border:0;border-top:1px solid var(--rec-divider);margin:var(--rec-space-lg) 0}
.rec-car-commitment-note{margin:14px 0 var(--rec-space-lg);padding-top:12px;border-top:1px solid var(--rec-divider);font-size:12.5px;color:var(--text-muted);line-height:1.5}
.breakdown-details{margin-top:0;border:1px solid var(--border-soft);border-radius:14px;background:var(--surface-alt);overflow:hidden}
.breakdown-details summary{list-style:none;cursor:pointer;padding:15px 18px;font-size:13px;font-weight:500;color:var(--text);display:flex;align-items:center;justify-content:space-between}
.breakdown-details summary::-webkit-details-marker{display:none}
.breakdown-details summary::after{content:'+';font-size:18px;line-height:1;color:var(--text-light);font-family:var(--font-body)}
.breakdown-details[open] summary::after{content:'\2212'}
.breakdown-inner{padding:14px 18px 18px;border-top:1px solid var(--border-soft)}
.recommendation{margin-top:0;padding:28px 26px 26px;background:var(--bg);border:1px solid var(--border);border-radius:16px;box-shadow:0 0 0 1px var(--border-soft);position:relative;font-variant-numeric:tabular-nums}
.recommendation::before{content:none}
.recommendation h4{font-family:var(--font-body);font-size:11px;font-weight:500;color:var(--brand);margin:0 0 14px;text-transform:uppercase;letter-spacing:.09em}
.recommendation p{font-size:14px;color:var(--text-muted);line-height:1.6;margin:0}
.recommendation p strong{color:var(--text);font-weight:500}
.recommendation p + p{margin-top:var(--rec-space-sm)}
.action-headline{font-family:var(--font-display);font-size:25px;font-weight:500;color:var(--text);line-height:1.18;letter-spacing:-0.018em;margin:0}
.action-headline strong{font-weight:500;color:var(--text)}
.action-subheadline{font-size:14.5px;font-weight:500;color:var(--text-muted);margin:0;line-height:1.5}
.action-subsection-heading{font-size:11px;font-weight:500;line-height:1.5;text-transform:uppercase;letter-spacing:0.09em;color:var(--text-light);margin:0 0 var(--rec-space-sm);}
.recommendation .action-block{display:flex;flex-direction:column;gap:var(--rec-space-md)}
.recommendation > .action-headline{margin:2px 0 12px}
.recommendation .action-block + .supporting-block{margin-top:var(--rec-space-md)}
.recommendation .supporting-block{display:flex;flex-direction:column;gap:var(--rec-space-sm)}
.recommendation .supporting-block p{margin:0}
.recommendation .supporting-block + .how-it-works-block{margin-top:var(--rec-space-lg)}
.recommendation .how-it-works-block + .impact-block{margin-top:var(--rec-space-lg)}
.recommendation .how-it-works-block .recommendation-divider,
.recommendation .impact-block .recommendation-divider{margin:0 0 var(--rec-space-md)}
.recommendation .impact-block p{margin:0}
.recommendation .impact-block .impact-list{margin:var(--rec-space-sm) 0 0 18px;padding:0;list-style:disc;font-size:13.5px;line-height:1.5;display:flex;flex-direction:column;gap:var(--rec-space-sm)}
.recommendation .impact-block .impact-list li{margin:0}
.recommendation .impact-block .impact-list + div{margin-top:var(--rec-space-md)}
.recommendation .inline-note,
.recommendation .alt-suppressed-note,
.recommendation .supporting-savings,
.recommendation .pension-warning,
.recommendation .soft-warning{margin-top:var(--rec-space-md)}
.supporting-savings{padding-top:var(--rec-space-md);border-top:1px solid var(--rec-divider);font-size:12.5px;color:var(--text-muted);line-height:1.45}
.pension-warning{padding:10px 14px;background:var(--amber-bg);border:1px solid var(--amber-border);border-radius:var(--radius);font-size:12.5px;color:var(--amber);line-height:1.5}
.pension-warning strong{font-weight:600}
.soft-warning{font-size:12.5px;color:var(--amber);line-height:1.5}
.action-section-title{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);font-weight:600;margin-bottom:14px}
.action-output{margin-top:16px}
.scenario-primary-block{text-align:left;padding:4px 0 0}
.scenario-primary-block .primary-label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);display:block}
.scenario-primary-block .primary-value{font-size:13.5px;font-weight:400;color:var(--text);font-variant-numeric:tabular-nums;letter-spacing:0;display:block;margin-top:7px;line-height:1.55}
.scenario-primary-block .primary-value strong{font-size:16px;font-weight:700;color:var(--text)}
.scenario-primary-block .primary-value.negative,.scenario-primary-block .primary-value.positive,.scenario-primary-block .primary-value.zero{color:var(--text)}
.scenario-impact-note{margin-top:6px;font-size:12px;line-height:1.5;color:var(--text-muted)}
.primary-insight{display:block;margin-top:6px;font-size:13px;color:var(--accent-dark);font-weight:500;line-height:1.45}
.scenario-upside{margin-top:var(--rec-space-lg);padding-top:var(--rec-space-md);border-top:1px solid var(--rec-divider)}
.upside-label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:12px}
.upside-items{display:flex;flex-direction:column;gap:10px}
.upside-item{display:flex;align-items:baseline;gap:8px;font-size:14px;color:var(--text);line-height:1.4}
.upside-icon{flex-shrink:0;font-size:14px}
.upside-text{font-size:14px;color:var(--text)}.upside-text strong{color:var(--green);font-variant-numeric:tabular-nums;font-size:.9em;font-weight:600}
.scenario-verdict{margin-top:20px;padding:14px 16px;background:var(--surface-alt);border:1px solid var(--border-soft);border-radius:12px;font-size:13.5px;line-height:1.5;color:var(--text);font-weight:500}
.scenario-verdict strong{font-weight:500;font-variant-numeric:tabular-nums}
.comparison-mobile{display:block}
.comparison-card{padding:14px 16px;border-bottom:1px solid var(--border-soft);background:var(--surface)}
.comparison-card:last-child{border-bottom:none}
.comparison-card.highlight-card{background:var(--surface-alt)}
.comparison-card-label{font-size:13px;color:var(--text-muted);font-weight:400;margin-bottom:7px}
.comparison-card.highlight-card .comparison-card-label{color:var(--text);font-weight:500;font-size:13.5px}
.comparison-card-values{display:flex;align-items:center;gap:10px;font-variant-numeric:tabular-nums}
.comparison-card-now{font-size:12.5px;color:var(--text-light)}
.comparison-card-arrow{font-size:13px;color:var(--text-light);opacity:.5}
.comparison-card-after{font-size:14.5px;font-weight:500;color:var(--text);font-family:var(--font-display)}
.comparison-card.highlight-card .comparison-card-after{color:var(--green)}
.comparison-card-change{margin-left:auto;font-size:11.5px;font-weight:500;font-variant-numeric:tabular-nums;padding:3px 9px;border-radius:999px;letter-spacing:.02em}
.comparison-card-change.pos{color:var(--green);background:var(--green-bg)}
.comparison-card-change.neg{color:var(--amber);background:var(--amber-bg)}
.comparison-card-change.neu{color:var(--text-muted);background:var(--surface-alt)}
[data-theme="dark"] .comparison-card.highlight-card{background:var(--surface-alt)}
[data-theme="dark"] .comparison-card.highlight-card .comparison-card-after{color:var(--green)}
[data-theme="dark"] .comparison-card-change.pos{color:var(--green);background:var(--green-bg)}
[data-theme="dark"] .comparison-card-change.neg{color:var(--amber);background:var(--amber-bg)}
[data-theme="dark"] .comparison-card-change.neu{color:var(--text-muted);background:var(--surface-alt)}
label:has(#childcareToggle){min-height:44px;}
.childcare-status{display:inline-flex;align-items:center;gap:6px;padding:6px 13px;border-radius:999px;font-size:12.5px;font-weight:500;margin-top:6px;letter-spacing:.01em}
.childcare-status::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}
.childcare-ok{background:var(--green-bg);color:var(--green);border:1px solid var(--green-border)}
.childcare-risk{background:var(--amber-bg);color:var(--amber);border:1px solid var(--amber-border)}
.childcare-lost{background:var(--red-bg);color:var(--red);border:1px solid var(--red-border)}
.disclaimer{max-width:1120px;margin:0 auto;text-align:center;padding:28px 24px;font-size:12.5px;color:var(--text-light);line-height:1.65;border-top:1px solid var(--border-soft);background:var(--bg)}
.disclaimer strong{color:var(--text-muted);font-weight:500}

.inline-note{font-size:12px;color:var(--text-light);line-height:1.45;margin-top:0}
.inline-note-meta{display:block;margin-top:4px;color:var(--text-light)}
.inline-info-wrap{position:relative;display:inline;vertical-align:baseline}
.inline-info-trigger{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border:none;background:none;color:var(--text-light);font-size:12px;line-height:1;cursor:pointer;padding:0;margin-left:4px;vertical-align:text-top;opacity:.8;font-family:var(--font-body);position:relative}
.inline-info-trigger:hover{opacity:1;color:var(--text-muted)}
.inline-info-trigger::before{content:'';position:absolute;inset:-14px;}
.inline-info-popover{display:none;position:absolute;left:0;top:calc(100% + 8px);width:min(260px,calc(100vw - 48px));padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text-muted);font-size:12px;line-height:1.5;box-shadow:var(--shadow);z-index:30}
.inline-info-popover::before{content:'';position:absolute;top:-7px;left:14px;width:12px;height:12px;background:var(--surface);border-left:1px solid var(--border);border-top:1px solid var(--border);transform:rotate(45deg)}
.inline-info-wrap.open .inline-info-popover,.inline-info-wrap:focus-within .inline-info-popover{display:block}
@media(hover:hover){.inline-info-wrap:hover .inline-info-popover{display:block}}
.compact-details{margin-top:14px;border:1px solid var(--border-soft);border-radius:12px;background:var(--surface-alt);overflow:hidden}
.compact-details summary{list-style:none;cursor:pointer;padding:13px 16px;font-size:12.5px;font-weight:500;color:var(--text);display:flex;align-items:center;justify-content:space-between}
.compact-details summary::-webkit-details-marker{display:none}
.compact-details summary::after{content:'+';font-size:17px;line-height:1;color:var(--text-light);font-family:var(--font-body)}
.compact-details[open] summary::after{content:'\2212'}
.compact-details .compact-inner{padding:0}

/* Route tabs — segmented control (wireframe lines 304-317 + 1285).
   Bare titles (no sub-label per wireframe fix #4); container is just bg+padding,
   no border. Active tab: white card with soft drop + 1px ring. */
.route-switcher{
  display:flex;
  gap:4px;
  margin-bottom:18px;
  padding:4px;
  border-radius:10px;
  background:var(--surface-alt);
}
.route-tab{
  flex:1;
  min-width:0;
  padding:9px 8px;
  font-size:12px;
  font-weight:600;
  color:var(--text-muted);
  text-align:center;
  cursor:pointer;
  border:0;
  background:transparent;
  border-radius:7px;
  font-family:inherit;
  transition:all .15s ease;
  line-height:1.2;
  /* In narrow sidebar (~360px), 13px wraps 'Salary sacrifice' to 2 lines. 12px keeps each label on a single line. */
  white-space:nowrap;
  letter-spacing:-0.1px;
}
.route-tab:hover:not(.active){
  color:var(--text);
}
.route-switcher:has(.route-tab:nth-child(3)) .route-tab{
  min-height:38px;
  padding-inline:6px;
  white-space:normal;
}
.route-tab:focus:not(:focus-visible){
  outline:none;
}
.route-tab:focus-visible{
  outline:2px solid var(--brand);
  outline-offset:2px;
}
.route-tab.active{
  background:var(--surface);
  color:var(--text);
  box-shadow:0 1px 2px rgba(10,11,13,.06),0 0 0 1px var(--border-soft);
}
.alt-route-banner{
  display:flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  margin-bottom:12px;
  background:var(--amber-bg);
  border:1px solid var(--amber-border);
  border-radius:var(--radius);
  font-size:12.5px;
  color:var(--amber);
  line-height:1.4;
}
.alt-route-banner strong{font-weight:600}
.alt-suppressed-note{
  font-size:12.5px;
  color:var(--text-muted);
  line-height:1.45;
  margin-top:0;
  margin-bottom:0;
  padding-bottom:var(--rec-space-md);
  border-bottom:1px solid var(--rec-divider);
  font-style:italic;
}
.planning-timing{
  margin-top:16px;
  padding-top:14px;
  border-top:1px solid var(--rec-divider);
}
.planning-timing-toggle{
  font-size:12.5px;
  color:var(--accent);
  cursor:pointer;
  font-weight:500;
  display:inline-flex;
  align-items:center;
  gap:4px;
  user-select:none;
  transition:color .15s;
}
.planning-timing-toggle:hover{
  color:var(--accent-dark);
}
@media(max-width:860px){
.layout{grid-template-columns:1fr;padding:0 20px;gap:0;background:var(--surface)}
.hero{margin:0;border-radius:0;padding:32px 0 20px;border-bottom:1px solid var(--border-soft)}
.hero-input-wrap{padding:0}
.hero-ask{font-size:28px;margin-bottom:18px}
/* P1.1 Hero salary input — mobile affordance: bordered field echoing .input-prefix pattern */
.hero-salary{padding:14px 16px;margin-bottom:18px;border:1px solid var(--border);border-bottom:1px solid var(--border);border-radius:12px;background:var(--surface);gap:6px;align-items:center}
.hero-salary:focus-within{border-color:var(--border-focus);border-bottom-color:var(--border-focus);box-shadow:0 0 0 3px rgba(0,82,255,.18)}
.hero-salary-prefix{font-size:30px;line-height:1.1;padding-bottom:0}
.hero-salary input[type="text"]{font-size:30px;line-height:1.1}
.hero-salary input[type="text"]::placeholder{color:var(--text-muted);opacity:.9}
.hero-salary-suffix{font-size:13px;padding-bottom:0;align-self:center;margin-left:auto}
[data-theme="dark"] .hero-salary{background:var(--surface-alt);border-color:var(--border)}
[data-theme="dark"] .hero-salary:focus-within{border-color:var(--border-focus);box-shadow:0 0 0 3px rgba(87,139,250,.22)}
/* P1.4 Helper text uses body sans on mobile, comfortably sized */
.helper{font-family:var(--font-body);font-size:13.5px;line-height:1.55;color:var(--text-muted)}
.hero-sub{font-size:14.5px;margin-bottom:28px}
.hero-spiel{display:none}
.hero-cta{font-size:14px;padding:10px 18px}
body{background:var(--surface)}
[data-theme="dark"] body{background:var(--bg)}
[data-theme="dark"] .layout{background:var(--bg)}
/* Header: balanced, easy tap target, intentional spacing */
/* P1.2 Sticky header — ensure content cannot bleed through on mobile */
.site-header{padding:12px 0;background:var(--surface);backdrop-filter:none;-webkit-backdrop-filter:none;z-index:200;isolation:isolate}
[data-theme="dark"] .site-header{background:var(--bg)}
.header-inner{padding:0 16px;gap:10px}
.header-icon{width:34px;height:34px;font-size:14px;border-radius:8px;flex-shrink:0}
.header-title{font-size:15px;line-height:1.3}
.header-badge{display:inline-block;font-size:11px;padding:3px 8px}
.badge-short{display:inline}
.badge-full{display:none}
.header-right{gap:10px}
.theme-toggle{width:36px;height:36px;flex-shrink:0}
.theme-toggle::before{content:'';position:absolute;inset:-9px 0;}
.input-col{margin-top:32px}
.input-col .card:last-child{flex:0 0 auto}
.card{padding:20px;margin-bottom:var(--space-md)}
.card-header{margin-bottom:var(--space-sm);padding-bottom:var(--space-sm)}
.card-title{font-size:16px}
.card-subtitle{font-size:12.5px}
.results-body{padding:16px}
.field-row{grid-template-columns:1fr;gap:var(--space-md)}
.field{margin-bottom:var(--space-md)}
/* Inputs: comfortable tap targets */
input[type="text"],input[type="number"],select{padding:12px 14px;font-size:16px}
.input-prefix input{padding-left:28px;padding-right:14px}
.input-suffix input{padding-right:36px}
.results-col{position:relative;top:0;max-height:none;min-width:0}
.results-card{max-height:none;min-width:0}
.results-body{overflow-y:visible}
.results-header{padding:18px 16px 14px}
.results-header h2{font-size:18px}
.results-header-top{flex-direction:column;align-items:flex-start;gap:4px}
/* Toggle buttons: comfortable touch targets */
.toggle-group{gap:6px;flex-wrap:wrap}
.toggle-group label{padding:9px 13px;font-size:13.5px;min-height:44px;display:flex;align-items:center}
/* Status banner — tweak 4: slightly more breathing room */
.status-banner{padding:20px 16px 20px;font-size:13.5px;line-height:1.6}
.status-ani{font-size:32px;line-height:1.05}
.status-delta{font-size:14px}
.status-banner .status-title{font-size:14px;margin-top:14px;margin-bottom:8px;padding-top:12px;line-height:1.5}
/* Action panel */
.recommendation{padding:16px}
.action-headline{font-size:16px;line-height:1.45}
.action-subheadline{font-size:14px}
:root{--rec-space-lg:16px;--rec-space-md:8px;--rec-space-sm:6px}
/* Upside items */
.upside-item{font-size:13.5px;gap:10px;line-height:1.5}
.upside-text{font-size:13.5px}
.scenario-verdict{padding:12px 14px;font-size:13px;line-height:1.55}
/* Breakdown */
.breakdown-details summary{padding:13px 14px;font-size:13px}
.breakdown-inner{padding:14px 14px 16px}
/* Field/field-group spacing inherits from desktop (24/16 via tokens) */
.result-row{font-size:13px;padding:6px 0}
.result-row .label{line-height:1.4}
.result-row .value{margin-left:12px;font-size:13px}
.result-row.highlight{padding:9px 12px;margin:4px -12px}
.result-row.highlight .value{font-size:15px}
.result-section-title{font-size:10.5px;letter-spacing:.07em}
/* Childcare pill: full-width on mobile */
.childcare-status{display:flex;font-size:13px;line-height:1.45;padding:8px 12px}
.status-banner .status-childcare{font-size:12.5px;margin-top:12px;padding-top:10px}
/* Route switcher overrides removed — primary rule above already matches wireframe at all viewports. */
/* Cards always shown */

/* Planning timing section */
.planning-timing{margin-top:18px;padding-top:16px}
.planning-timing-toggle{font-size:13px;min-height:36px;display:inline-flex;align-items:center}
/* Alt route banner */
.alt-route-banner{padding:10px 12px;font-size:13px;line-height:1.5}
.alt-suppressed-note{font-size:13px;line-height:1.5}
/* inline-note */
.inline-note{font-size:12.5px;line-height:1.5}
/* compact details */
.compact-details summary{padding:13px 14px;font-size:13px}

/* A: Results divider — removed */
/* B: Results col band — transparent on desktop */
.results-col{background:transparent}
}
@media(max-width:640px){
.header-brand{min-width:0;flex:1 1 auto}
.header-divider,.header-eyebrow{display:none}
.header-wordmark{min-width:0;overflow:hidden;text-overflow:ellipsis}
}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.card{animation:fadeIn .4s ease both}.card:nth-child(2){animation-delay:.05s}.card:nth-child(3){animation-delay:.1s}.card:nth-child(4){animation-delay:.15s}.card:nth-child(5){animation-delay:.2s}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

/* A+BC mobile results transition */
@media(max-width:860px){
/* B: Results band spacing */
.results-col{background:transparent;margin:32px -20px 0;padding:28px 20px 8px;border-top:1px solid var(--border-soft)}
.input-col .card:last-child{margin-bottom:0}
.why-matters{margin-top:0}
/* C: Stronger results header */
.results-header h2{font-size:20px;font-weight:600;color:var(--accent-dark)}
.results-subtitle{font-size:13px;margin-top:4px}
/* Remove card chrome — band is the container */
.results-card{background:transparent;border:none;box-shadow:none}
.results-body{padding:16px 0 0}
/* Status banner sits flush on mobile — remove top border to avoid stray coloured line */
}
@media(max-width:860px){
[data-theme="dark"] .results-card{background:transparent;border:none;box-shadow:none}
}
/* Date range error toast */
.date-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(0);background:var(--amber-bg);border:1px solid var(--amber-border);color:var(--amber);font-size:14.5px;font-weight:500;line-height:1.55;padding:14px 18px;border-radius:var(--radius);box-shadow:var(--shadow);display:flex;align-items:flex-start;gap:10px;max-width:360px;width:calc(100% - 48px);z-index:999;animation:toastIn .2s ease}
.date-toast-close{flex-shrink:0;margin-left:auto;padding-left:10px;background:none;border:none;color:var(--amber);font-size:18px;line-height:1;cursor:pointer;opacity:.7;font-family:var(--font-body)}
.date-toast-close:hover{opacity:1}
@media(max-width:860px){.date-toast{bottom:auto;top:50%;transform:translate(-50%,-50%)}
.date-toast.hiding{animation:toastOutMobile .3s ease forwards}}
@keyframes toastOutMobile{from{opacity:1;transform:translate(-50%,-50%)}to{opacity:0;transform:translate(-50%,-46%)}}
.date-toast.hiding{animation:toastOut .3s ease forwards}
.date-toast-icon{flex-shrink:0;font-size:15px}
@keyframes toastIn{from{opacity:0;transform:translateX(-50%) translateY(12px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
@keyframes toastOut{from{opacity:1;transform:translateX(-50%) translateY(0)}to{opacity:0;transform:translateX(-50%) translateY(12px)}}

/* Validation state bar */
.validation-stop-card{background:var(--amber-bg);border:1px solid var(--amber-border);border-radius:var(--radius);padding:20px 18px;border-left:3px solid var(--amber)}
.validation-state-bar{border-radius:var(--radius);padding:11px 14px;font-size:13px;line-height:1.5;margin-bottom:16px;border-left:3px solid transparent;transition:background 0.2s ease,border-color 0.2s ease}
.validation-state-bar.is-warn{background:var(--val-warn-bg);border-left-color:var(--amber);color:var(--text)}
.validation-state-bar.is-stop{background:var(--val-stop-bg);border-left-color:var(--amber);color:var(--text)}
/* Slightly stronger contrast on mobile */
@media(max-width:699px){
  .validation-state-bar.is-warn{background:var(--val-warn-bg-mobile);border-left-width:4px}
  .validation-state-bar.is-stop{background:var(--val-stop-bg-mobile);border-left-width:4px}
}

/* ─────────────────────────────────────────────────────────
   "Why this matters" — mobile-first scrollytelling redesign
   ───────────────────────────────────────────────────────── */

.why-matters{
  --why-pad: 20px;
  --why-column: 720px;
  --why-warn: #B4530A;
  --why-warn-soft: rgba(180,83,10,0.08);
  --why-drag: var(--amber);
  --why-drag-soft: var(--amber-bg);
  --why-good: var(--green);
  --why-good-soft: var(--green-bg);
  --why-dark: var(--text);
  --why-dark-soft: rgba(10,11,13,0.72);
  --why-shadow: 0 1px 0 rgba(10,11,13,0.04),0 8px 24px -16px rgba(10,11,13,0.18);
  margin-top: 40px;
  background: var(--bg);
  color: var(--text);
  border-top: 1px solid var(--border-soft);
}
[data-theme="dark"] .why-matters{
  --why-warn: #E8A65A;
  --why-warn-soft: rgba(232,166,90,0.12);
  --why-dark: #FFFFFF;
  --why-dark-soft: rgba(255,255,255,0.78);
  --why-shadow: 0 1px 0 rgba(255,255,255,0.04),0 12px 28px -18px rgba(0,0,0,0.6);
}
.why-matters .mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}
.why-muted{color:var(--text-light);font-weight:500}
.why-overline{
  display:inline-block;
  font-family:var(--font-mono);
  font-size:11px;
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:var(--text-light);
}
.why-hero,
.why-m1,
.why-m3-pad,
.why-end-pad,
.why-footer{
  max-width:var(--why-column);
  margin-left:auto;
  margin-right:auto;
  padding-left:var(--why-pad);
  padding-right:var(--why-pad);
}
.why-hero{
  padding-top:clamp(56px,8vw,82px);
  padding-bottom:48px;
  display:flex;
  flex-direction:column;
  gap:18px;
  border-bottom:1px solid var(--border-soft);
}
.why-hero-title{
  font-family:var(--font-display);
  font-size:clamp(34px,8vw,52px);
  line-height:1.04;
  letter-spacing:-.025em;
  font-weight:600;
  color:var(--text);
  max-width:13ch;
  text-wrap:balance;
}
.why-hero-title em{font-style:italic;color:var(--why-warn);font-weight:700}
.why-hero-dek{
  font-size:clamp(16.5px,2vw,18px);
  line-height:1.58;
  color:var(--text-muted);
  max-width:64ch;
  text-wrap:pretty;
}
.why-hero-dek strong{color:var(--text);font-weight:600}
.why-scroll-cue{
  margin-top:6px;
  display:inline-flex;
  align-items:center;
  gap:10px;
  align-self:flex-start;
  text-decoration:none;
  font-family:var(--font-mono);
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:var(--text);
  padding:11px 14px;
  border:1px solid var(--text);
  border-radius:56px;
  transition:background .15s ease,color .15s ease,transform .15s ease;
}
.why-scroll-cue:hover{background:var(--text);color:var(--bg);transform:translateY(-1px)}
.why-cue-arrow{display:inline-block;animation:whyCueBob 1.6s ease-in-out infinite}
@keyframes whyCueBob{0%,100%{transform:translateY(0)}50%{transform:translateY(3px)}}

.why-m1{position:relative;padding-top:48px;padding-bottom:48px}
.why-m1-rail{position:absolute;left:38px;top:0;bottom:84px;width:2px;pointer-events:none}
.why-m1-rail-track{position:absolute;inset:0;background:var(--border)}
.why-m1-rail-progress{position:absolute;left:0;right:0;top:0;height:0;background:linear-gradient(180deg,var(--text) 0%,var(--why-warn) 50%,var(--why-drag) 78%,var(--why-good) 100%);transition:height .15s linear}
.why-stations{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}
.why-station{position:relative;padding:28px 0 28px 48px;opacity:.36;transition:opacity .35s ease}
.why-station.is-in-view,.why-cliff.is-in-view{opacity:1}
.why-station-marker{position:absolute;left:8px;top:32px;display:flex;align-items:center;justify-content:center}
.why-station-y{position:absolute;right:calc(100% + 6px);top:50%;transform:translateY(-50%);font-size:11px;line-height:1;color:var(--text-light);white-space:nowrap;background:var(--bg);padding:2px 4px}
.why-station-dot{width:22px;height:22px;border-radius:50%;background:var(--bg);border:2px solid var(--text);position:relative;z-index:2;transition:transform .3s ease,background .3s ease}
.why-station.is-in-view .why-station-dot{transform:scale(1.15)}
.why-station-dot--warn{border-color:var(--why-warn);background:var(--why-warn)}
.why-station-dot--drag{border-color:var(--why-drag);background:var(--why-drag)}
.why-station-dot--break{border-color:var(--why-good);background:var(--why-good)}
.why-station-eyebrow{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--text-light);margin:0 0 6px}
.why-station h3{font-family:var(--font-display);font-size:clamp(21px,5.4vw,27px);font-weight:600;letter-spacing:-.015em;line-height:1.2;color:var(--text);text-wrap:balance;margin:0}
.why-station h3 em{color:var(--text);font-style:italic;font-weight:700}
.why-station-body{margin:8px 0 0;color:var(--text-muted);font-size:15.5px;line-height:1.58;text-wrap:pretty}
.why-station-card--warn h3 strong,.why-station--warn strong{color:var(--why-warn)}
.why-penny-meter{display:flex;margin-top:14px;height:36px;border-radius:8px;overflow:hidden;border:1px solid var(--border-soft);background:var(--surface-alt);font-family:var(--font-mono);font-size:12px}
.why-penny{display:flex;align-items:center;justify-content:center;min-width:0;font-weight:500}
.why-penny span{white-space:nowrap;padding:0 8px}
.why-penny--keep{background:var(--why-good-soft);color:var(--why-good)}
.why-penny--gone{background:var(--why-warn-soft);color:var(--why-warn)}
[data-theme="dark"] .why-penny-meter{border-color:var(--border);box-shadow:inset 0 0 0 1px rgba(255,255,255,.04)}
[data-theme="dark"] .why-penny--keep{background:var(--green-border);color:var(--green)}
[data-theme="dark"] .why-penny--gone{background:var(--amber-border);color:var(--amber)}

.why-cliff{position:relative;margin:12px 0;padding:32px 0 60px 48px;opacity:.72;background:linear-gradient(180deg,transparent 0%,var(--why-warn-soft) 18%,var(--why-warn-soft) 86%,transparent 100%);border-top:1px solid var(--why-warn);border-bottom:1px solid var(--why-warn);transition:opacity .35s ease}
.why-cliff-pillar{position:absolute;left:18px;top:0;bottom:0;width:0;border-left:2px dashed var(--why-warn);z-index:1}
.why-cliff-shadow{position:absolute;left:-10px;top:30%;width:22px;height:60%;background:radial-gradient(ellipse at center,rgba(10,11,13,.14) 0%,transparent 70%);border-radius:50%;filter:blur(2px)}
.why-cliff-card{position:relative;z-index:2;padding-right:16px}
.why-cliff-eyebrow{display:inline-block;background:var(--why-warn);color:#fff;padding:5px 9px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;border-radius:4px;margin:0 0 14px}
[data-theme="dark"] .why-cliff-eyebrow{color:#111}
.why-cliff-title{font-family:var(--font-display);font-size:clamp(30px,7.8vw,42px);line-height:1.05;font-weight:700;letter-spacing:-.025em;margin:0 0 18px;color:var(--text)}
.why-cliff-big{display:inline-block;color:var(--why-warn);font-size:1.28em;letter-spacing:-.04em}
.why-cliff-list{list-style:none;display:flex;flex-direction:column;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px;margin:0 0 14px;box-shadow:var(--shadow-sm)}
.why-cliff-list li{display:grid;grid-template-columns:minmax(76px,88px) minmax(0,1fr);gap:12px;align-items:baseline;font-size:14.5px;line-height:1.4;color:var(--text)}
.why-cliff-list .mono{color:var(--why-warn);font-weight:500;font-size:14px;text-align:right;white-space:nowrap}
.why-cliff-list em{font-style:normal;font-weight:700;color:var(--text);background:var(--why-warn-soft);padding:1px 5px;border-radius:4px}
.why-cliff-foot{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin:0;line-height:1.5}
.why-m1-foot{margin:12px 0 0 48px;font-size:12.5px;color:var(--text-muted);line-height:1.55;letter-spacing:.01em;padding:16px;border:1px dashed var(--border);border-radius:8px;background:var(--surface-alt)}

.why-m3{background:var(--bg);border-top:1px solid var(--border-soft);padding:48px 0}
.why-m3-title{font-family:var(--font-display);font-size:clamp(28px,6.8vw,38px);font-weight:600;line-height:1.08;letter-spacing:-.025em;margin:10px 0 16px;color:var(--text);text-wrap:balance}
.why-m3-title em{font-style:italic;color:var(--why-warn);font-weight:700}
.why-m3-body{font-size:16px;line-height:1.58;color:var(--text-muted);margin:0 0 12px;text-wrap:pretty}
.why-m3-body .num{color:var(--text);font-weight:500;white-space:nowrap}
.why-receipt-deck{margin:28px 0}
.why-receipt-progress{display:flex;gap:6px;max-width:var(--why-column);margin:0 auto;padding:0 var(--why-pad) 14px}
.why-receipt-progress-step{flex:1;display:flex;flex-direction:column;gap:4px;background:transparent;border:0;border-top:2px solid var(--border);text-align:left;padding:8px 10px 10px;color:var(--text-light);transition:color .15s ease,border-color .15s ease;cursor:pointer;min-width:0}
.why-receipt-progress-step.is-active{border-top-color:var(--text);color:var(--text)}
.why-receipt-deck[data-state="after"] .why-receipt-progress-step.is-active{border-top-color:var(--why-warn);color:var(--why-warn)}
.why-receipt-deck[data-state="fix"] .why-receipt-progress-step.is-active{border-top-color:var(--why-good);color:var(--why-good)}
.why-step-num{font-size:10px;letter-spacing:.1em}.why-step-label{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.why-receipt-track{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;gap:14px;padding:4px max(var(--why-pad),calc((100vw - var(--why-column)) / 2 + var(--why-pad))) 18px;scrollbar-width:none;overscroll-behavior-x:contain}
.why-receipt-track::-webkit-scrollbar{display:none}
.why-receipt{flex:0 0 min(420px,calc(100vw - 40px));scroll-snap-align:center;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px;display:flex;flex-direction:column;box-shadow:var(--why-shadow);position:relative;min-height:318px;opacity:.68;transition:opacity .15s ease,border-color .15s ease,box-shadow .15s ease,transform .15s ease}
.why-receipt.is-active{opacity:1;border-color:var(--text);box-shadow:0 0 0 1px var(--text),var(--why-shadow);transform:translateY(-2px)}
.why-receipt[data-card="after"]{background:linear-gradient(180deg,var(--why-warn-soft) 0%,var(--surface) 74%)}
.why-receipt[data-card="after"].is-active{border-color:var(--why-warn);box-shadow:0 0 0 1px var(--why-warn),var(--why-shadow)}
.why-receipt[data-card="fix"].is-active{border-color:var(--why-good);box-shadow:0 0 0 1px var(--why-good),var(--why-shadow)}
.why-receipt-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding-bottom:14px;border-bottom:1px dashed var(--border);margin-bottom:14px}
.why-receipt-overline{font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--text-light);margin:0 0 4px}
.why-receipt-status{font-family:var(--font-mono);font-size:12px;font-weight:500;margin:0}.why-receipt-status::before{content:'● ';font-size:10px}.why-receipt-status--ok{color:var(--why-good)}.why-receipt-status--bad{color:var(--why-warn)}
.why-receipt-salary{text-align:right;font-size:11px;color:var(--text-light);line-height:1.3;margin:0}.why-receipt-salary strong{display:block;font-size:14px;color:var(--text);margin-top:2px}
.why-receipt-rows{list-style:none;display:flex;flex-direction:column;gap:10px;margin:0 0 16px;padding:0}.why-receipt-rows li{display:flex;align-items:baseline;justify-content:space-between;gap:10px;font-size:14px;line-height:1.4;color:var(--text-muted)}.why-receipt-rows .mono{color:var(--text);font-size:14px;white-space:nowrap}.why-receipt-rows .is-credit .mono{color:var(--why-good)}.why-receipt-rows .is-strike{color:var(--text-light)}.why-receipt-rows .is-strike span:first-child{text-decoration:line-through;text-decoration-color:var(--why-warn)}.why-receipt-rows .is-strike em{font-style:normal;color:var(--why-warn);font-weight:700}.why-receipt-rows .is-strike .mono{color:var(--text-light)}.why-receipt-rows .is-bonus{color:var(--text);padding-top:8px;border-top:1px dotted var(--border)}.why-receipt-rows .is-bonus .mono{font-weight:500;color:var(--text)}
.why-receipt-foot{margin-top:auto;padding-top:12px;border-top:2px solid var(--text);display:flex;flex-direction:column;gap:4px}.why-receipt-due-label{font-size:10px;text-transform:uppercase;letter-spacing:.14em;color:var(--text-light);margin:0}.why-receipt-due{font-family:var(--font-mono);font-size:36px;font-weight:500;letter-spacing:-.02em;color:var(--text);line-height:1;margin:0}.why-receipt-foot--bad{border-top-color:var(--why-warn)}.why-receipt-foot--bad .why-receipt-due{color:var(--why-warn)}.why-receipt-delta{font-size:12px;color:var(--why-warn);margin:4px 0 0;font-weight:500;line-height:1.35}.why-receipt-delta--good{color:var(--why-good)}
.why-receipt-nav{display:flex;align-items:center;justify-content:space-between;gap:12px;max-width:var(--why-column);margin:0 auto;padding:0 var(--why-pad)}.why-receipt-nav-btn{width:44px;height:44px;border-radius:50%;background:var(--surface);border:1px solid var(--border);font-size:18px;color:var(--text);display:flex;align-items:center;justify-content:center;transition:background .15s ease,color .15s ease,transform .15s ease;cursor:pointer}.why-receipt-nav-btn:hover{background:var(--text);color:var(--bg)}.why-receipt-nav-btn:active{transform:scale(.94)}.why-receipt-nav-btn:disabled{opacity:.34;cursor:not-allowed;background:var(--surface);color:var(--text)}.why-receipt-hint{font-size:11px;color:var(--text-light);text-transform:uppercase;letter-spacing:.1em;margin:0}
.why-m3-verdict,.why-m3-remedy{font-size:16px;line-height:1.58;color:var(--text);margin:0 0 14px;text-wrap:pretty}.why-m3-verdict{padding-top:12px;border-top:1px solid var(--border)}.why-m3-verdict strong{color:var(--why-warn);font-weight:600}.why-m3-remedy{background:var(--why-good-soft);border-left:3px solid var(--why-good);padding:14px 16px;border-radius:0 8px 8px 0;color:var(--text-muted);font-size:15.5px}

.why-end{background:var(--text);color:var(--bg);padding:56px 0 0}.why-end-pad{padding-bottom:48px}.why-end .why-overline{color:rgba(255,255,255,.58)}.why-end-title{font-family:var(--font-display);font-size:clamp(34px,8vw,46px);font-weight:600;letter-spacing:-.03em;line-height:1.05;margin:10px 0 16px;color:var(--bg);text-wrap:balance}.why-end-body{font-size:16px;line-height:1.58;color:rgba(255,255,255,.76);margin:0 0 26px;text-wrap:pretty;max-width:62ch}.why-end-cta{display:inline-flex;align-items:center;justify-content:center;gap:12px;background:var(--bg);color:var(--text);text-decoration:none;font-size:17px;font-weight:700;padding:16px 22px;border-radius:12px;letter-spacing:-.01em;width:100%;transition:background .15s ease,color .15s ease,transform .15s ease}.why-end-cta:hover{background:var(--why-warn);color:#fff;transform:translateY(-1px)}.why-end-cta span{transition:transform .15s ease}.why-end-cta:hover span{transform:translateX(4px)}.why-end-actions{display:flex;flex-direction:column;gap:8px;margin-top:16px}.why-end-share-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;background:transparent;color:var(--bg);border:1px solid rgba(255,255,255,.22);border-radius:12px;padding:14px 18px;font-size:14px;font-weight:500;transition:background .15s ease,border-color .15s ease;cursor:pointer}.why-end-share-btn:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.38)}.why-end-share-btn--ghost{border-color:transparent;color:rgba(255,255,255,.66);font-family:var(--font-mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase}
.why-footer{background:rgba(0,0,0,.28);padding-top:32px;padding-bottom:48px;border-top:1px solid rgba(255,255,255,.14);display:flex;flex-direction:column;gap:18px}.why-footer-block{font-size:13px;color:rgba(255,255,255,.68);line-height:1.55;margin:0}.why-footer-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.why-footer-links a{color:var(--bg);text-decoration:none;font-size:14px;border-bottom:1px solid rgba(255,255,255,.26);padding-bottom:6px;transition:border-color .15s ease}.why-footer-links a:hover{border-color:var(--bg)}.why-footer-disclaimer{font-size:12px;color:rgba(255,255,255,.54);font-style:italic;line-height:1.5;margin:0}
[data-theme="dark"] .why-end{background:var(--surface-alt);color:var(--text);border-top:1px solid var(--border)}
[data-theme="dark"] .why-end .why-overline{color:var(--text-light)}
[data-theme="dark"] .why-end-title{color:var(--text)}
[data-theme="dark"] .why-end-body{color:var(--text-muted)}
[data-theme="dark"] .why-end-cta{background:var(--text);color:var(--bg)}
[data-theme="dark"] .why-end-cta:hover{background:var(--why-warn);color:#111}
[data-theme="dark"] .why-end-share-btn{color:var(--text);border-color:var(--border)}
[data-theme="dark"] .why-end-share-btn:hover{background:rgba(255,255,255,.08);border-color:var(--ring-deep)}
[data-theme="dark"] .why-end-share-btn--ghost{color:var(--text-muted)}
[data-theme="dark"] .why-footer{background:var(--bg);border-top-color:var(--ring-deep);box-shadow:0 0 0 100vmax var(--bg);clip-path:inset(0 -100vmax)}
[data-theme="dark"] .why-footer-block{color:var(--text-muted)}
[data-theme="dark"] .why-footer-links a{color:var(--text);border-bottom-color:var(--border)}
[data-theme="dark"] .why-footer-links a:hover{border-color:var(--text)}
[data-theme="dark"] .why-footer-disclaimer{color:var(--text-light)}
[data-theme="dark"] #statusBanner:not(:empty),
[data-theme="dark"] #actionPanel:not(:empty),
[data-theme="dark"] .why-matters,
[data-theme="dark"] .why-m3{border-top-color:var(--border)}
[data-theme="dark"] .why-hero{border-bottom-color:var(--border)}

@media (max-width:560px){
  .why-matters{--why-pad:20px;--why-column:100vw}
  .why-m1-rail{left:60px}
  .why-station{padding-left:60px}
  .why-station-marker{left:29px}
  .why-station-y{right:calc(100% + 4px)}
  .why-cliff{padding-left:60px}
  .why-cliff-pillar{left:40px}
  .why-m1-foot{margin-left:60px}
  .why-cliff-list{padding:12px}.why-cliff-list li{grid-template-columns:76px minmax(0,1fr);gap:10px;font-size:13.8px}.why-cliff-list .mono{font-size:13px}
  .why-receipt{min-height:340px}.why-receipt-head{flex-direction:column}.why-receipt-salary{text-align:left}.why-receipt-due{font-size:34px}
}
@media (max-width:430px){
  .why-cliff-list{gap:13px;padding:14px}
  .why-cliff-list li{display:block;font-size:14.2px}
  .why-cliff-list .mono{display:inline;text-align:left;font-size:14.5px}
  .why-cliff-list .mono::after{content:": "}
}
@media (prefers-reduced-motion:reduce){
  .why-matters *, .why-matters *::before, .why-matters *::after{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .why-station,.why-cliff{opacity:1}
}


/* ═══ VISUAL POLISH PASS — aligned to reference page ═══ */

/* Metadata labels: use mono font for all uppercase labels */
.result-section-title,
.status-ani-sub,
.action-subsection-heading,
.upside-label,
.hero-eyebrow,
.header-badge,
.card-subtitle,
.helper-inline,
.breakdown-note,
.inline-note,
.cliff-label-suffix,
.disclaimer strong {
  font-family: var(--font-mono);
}

/* Card polish: softer shadow, tighter radius */
.card {
  box-shadow: 0 1px 0 rgba(10,11,13,0.04), 0 4px 16px rgba(10,11,13,0.03);
  border-color: var(--border);
}
.card:hover {
  box-shadow: 0 1px 0 rgba(10,11,13,0.06), 0 8px 24px rgba(10,11,13,0.06);
}

/* Results card: premium elevation */
.results-card {
  box-shadow: 0 1px 0 rgba(10,11,13,0.06), 0 12px 36px rgba(10,11,13,0.06);
}

/* Status banner: slightly tighter */
.status-ani {
  font-size: 42px;
  letter-spacing: -0.03em;
}

/* Input fields: refined */
input[type="text"],
input[type="number"],
select {
  font-size: 14.5px;
  border-radius: 10px;
  padding: 11px 14px;
  letter-spacing: -0.005em;
}
.input-prefix input { padding-left: 28px; }

/* Toggle group: refined */
.toggle-group label {
  border-radius: 10px;
  font-size: 13.5px;
  padding: 8px 13px;
}

/* Recommendation block: cleaner card */
.recommendation {
  border-radius: 14px;
  padding: 26px 24px 24px;
}
.recommendation h4 {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.12em;
}

/* Action headline: tighter tracking */
.action-headline {
  font-size: 24px;
  letter-spacing: -0.02em;
  line-height: 1.15;
}
.action-headline strong {
  font-weight: 600;
}

/* Route switcher tabs — wireframe values are set in the primary block above; this used to override with tighter values but no longer needs to. */

/* Comparison cards: mono numerics */
.comparison-card-now,
.comparison-card-after,
.comparison-card-change {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
}

/* Result rows: mono values */
.result-row .value {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
}
.result-row.highlight .value {
  font-family: var(--font-display);
}

/* Breakdown details: refined */
.breakdown-details {
  border-radius: 12px;
}
.breakdown-details summary {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* Compact details: same treatment */
.compact-details summary {
  font-size: 12px;
}

/* Hero: refine eyebrow and rate bars */
.hero-eyebrow {
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.06em;
}
.hero-rate-row {
  font-family: var(--font-mono);
  font-size: 12.5px;
}
.hero-rate-row .pct {
  font-family: var(--font-display);
}

/* Header: align badge to mono */
.header-badge {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.04em;
}

/* Spacing: tighten card padding slightly */
.card {
  padding: 28px;
}

/* Disclaimer: mono for emphasis */
.disclaimer {
  font-size: 12px;
  line-height: 1.7;
}

/* Childcare status pills: mono */
.childcare-status {
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.04em;
}

/* Scenario primary value: display font for big numbers */
.scenario-primary-block .primary-value strong {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 600;
  letter-spacing: -0.01em;
}

/* Upside items: tighter */
.upside-text strong {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
}

/* Pension warning: refined radius */
.pension-warning {
  border-radius: 10px;
}

/* Status delta: mono */
.status-delta {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
}


/* ═══ RESULTS COLUMN POLISH ═══ */

/* Results header: align to Manrope display system */
.results-header {
  padding: 28px 28px 24px;
}
.results-header h2 {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 500;
  letter-spacing: -0.015em;
  line-height: 1.2;
}

@media (min-width:861px){
  .results-header{min-height:128px;}
}
.results-subtitle {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-muted);
  margin-top: 8px;
  letter-spacing: 0.04em;
}

/* Results body: consistent padding */
.results-body {
  padding: 26px 28px 28px;
}

/* Status banner: tighter, more premium */
.status-banner {
  padding: 24px 22px 22px;
  border-radius: 14px;
}
.status-ani {
  font-family: var(--font-display);
  font-size: 40px;
  font-weight: 600;
  letter-spacing: -0.03em;
  line-height: 1;
  margin-bottom: 4px;
}
.status-ani-sub {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.12em;
  margin-bottom: 12px;
}
.status-delta {
  font-family: var(--font-mono);
  font-size: 13px;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.01em;
}
.status-banner .status-title {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  line-height: 1.5;
}
.status-banner .status-childcare {
  font-family: var(--font-body);
  font-size: 12.5px;
  line-height: 1.55;
}

/* Result sections: uniform mono headers */
.result-section {
  margin-bottom: 22px;
}
.result-section-title {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.12em;
  color: var(--text-light);
  font-weight: 500;
  margin-bottom: 10px;
  text-transform: uppercase;
}

/* Result rows: aligned type */
.result-row {
  font-family: var(--font-body);
  font-size: 13.5px;
  padding: 6px 0;
}
.result-row .label {
  color: var(--text-muted);
  font-weight: 400;
  font-size: 13.5px;
}
.result-row .value {
  font-family: var(--font-mono);
  font-size: 13.5px;
  font-weight: 500;
  font-variant-numeric: tabular-nums;
  color: var(--text);
}
.result-row.highlight {
  padding: 10px 14px;
  margin: 6px -14px;
  border-radius: 10px;
}
.result-row.highlight .label {
  font-weight: 500;
  color: var(--text);
  font-size: 13.5px;
}
.result-row.highlight .value {
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 500;
  color: var(--text);
}

/* Dividers: cleaner */
.result-divider {
  margin: 12px 0;
}

/* Take-home monthly row */
.result-row.take-home-monthly .label,
.result-row.take-home-monthly .value {
  font-family: var(--font-mono);
  font-size: 12.5px;
  color: var(--text-muted);
  font-weight: 500;
}

/* Breakdown wrap: breathing room */
.breakdown-wrap {
  margin-top: 22px;
  padding-top: 18px;
}

/* Breakdown inner rows */
.breakdown-inner {
  padding: 14px 18px 16px;
}
.breakdown-inner .result-row {
  font-size: 13px;
  padding: 5px 0;
}
.breakdown-inner .result-row .label {
  font-size: 13px;
}
.breakdown-inner .result-row .value {
  font-family: var(--font-mono);
  font-size: 13px;
}
.breakdown-note {
  font-family: var(--font-mono);
  font-size: 11.5px;
  line-height: 1.5;
}

/* Recommendation block in results */
.recommendation {
  font-variant-numeric: tabular-nums;
}
.recommendation p {
  font-size: 13.5px;
  line-height: 1.6;
}
.recommendation p strong {
  color: var(--text);
  font-weight: 600;
}

/* Action headline in results */
.action-headline {
  font-family: var(--font-display);
  font-size: 23px;
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.18;
}

/* Scenario blocks */
.scenario-primary-block .primary-label {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.1em;
}
.scenario-primary-block .primary-value {
  font-family: var(--font-body);
  font-size: 13.5px;
  line-height: 1.55;
}
.scenario-primary-block .primary-value strong {
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 600;
  letter-spacing: -0.01em;
}

/* Scenario verdict */
.scenario-verdict {
  font-family: var(--font-body);
  font-size: 13px;
  border-radius: 10px;
}

/* Inline notes */
.inline-note {
  font-family: var(--font-mono);
  font-size: 11.5px;
  line-height: 1.5;
}

/* ═══ END RESULTS POLISH ═══ */

/* ═══ END POLISH PASS ═══ */

/* ═══ LANDING PAGE ADDITIONS (/100k-tax-trap) ═══ */
.hero-dek{font-family:var(--font-body);font-size:15.5px;font-weight:400;color:var(--text-muted);line-height:1.62;max-width:64ch;margin:0 0 36px;text-wrap:pretty}
@media(max-width:860px){.hero-dek{font-size:17px;line-height:1.65;margin-bottom:22px}}
.hero-dek strong{color:var(--text);font-weight:600}
.hero-entry-label{font-family:var(--font-mono);font-size:11.5px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--text-light);margin:0 0 14px}
/* Eyebrow override for landing: cool accent dot (matches brand) */
.hero--input .hero-eyebrow{letter-spacing:.08em;font-size:11px;white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis}
@media (max-width:640px){
  .hero--input .hero-eyebrow{font-size:10px;letter-spacing:.06em}
}
.hero--input .hero-eyebrow::before{background:var(--brand)}

/* Shared labels */
.landing-label{display:inline-block;font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--text-light);margin-bottom:14px}

/* TL;DR */
.landing-tldr{grid-column:1/-1;max-width:880px;margin:0 auto 32px;padding:26px 28px;background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--brand);border-radius:12px;box-shadow:var(--shadow-sm)}
.landing-tldr-body{font-family:var(--font-body);font-size:16px;line-height:1.65;color:var(--text);margin:0;max-width:70ch}
.landing-tldr-body strong{color:var(--text);font-weight:600}
[data-theme="dark"] .landing-tldr{background:var(--surface-alt);border-color:var(--border)}

/* Key facts strip */
.landing-facts{grid-column:1/-1;max-width:880px;margin:0 auto 32px;padding:4px 0 0}
.landing-facts-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0;margin:0;padding:0;border:1px solid var(--border-soft);border-radius:12px;overflow:hidden;background:var(--surface-alt)}
.landing-fact{padding:18px 20px;border-right:1px solid var(--border-soft);border-bottom:1px solid var(--border-soft);background:var(--surface)}
.landing-fact:nth-child(3n){border-right:none}
.landing-fact:nth-last-child(-n+3){border-bottom:none}
.landing-fact dt{font-family:var(--font-mono);font-size:10.5px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--text-light);margin-bottom:6px}
.landing-fact dd{font-family:var(--font-display);font-size:19px;font-weight:500;color:var(--text);letter-spacing:-.015em;font-variant-numeric:tabular-nums;margin:0;line-height:1.25}
.landing-fact-note{display:inline-block;font-family:var(--font-mono);font-size:11px;font-weight:400;color:var(--text-muted);letter-spacing:.04em;margin-left:4px;text-transform:none;vertical-align:middle}
.landing-facts-source{font-family:var(--font-mono);font-size:11.5px;color:var(--text-light);margin:12px 2px 0;letter-spacing:.04em}
.landing-facts-source a{color:var(--text-muted);text-decoration:underline;text-underline-offset:2px;text-decoration-color:var(--border)}
.landing-facts-source a:hover{color:var(--brand);text-decoration-color:var(--brand)}
[data-theme="dark"] .landing-fact{background:var(--surface-alt);border-color:var(--border-soft)}
[data-theme="dark"] .landing-facts-grid{background:var(--surface);border-color:var(--border)}

/* Worked examples */
.landing-examples{grid-column:1/-1;max-width:880px;margin:0 auto 40px;padding:4px 0 0}
.landing-examples-table{width:100%;border-collapse:separate;border-spacing:0;border:1px solid var(--border-soft);border-radius:12px;overflow:hidden;font-variant-numeric:tabular-nums;background:var(--surface)}
.landing-examples-table th,.landing-examples-table td{padding:14px 20px;text-align:left;font-size:15px;border-bottom:1px solid var(--border-soft)}
.landing-examples-table thead th{font-family:var(--font-mono);font-size:10.5px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--text-light);background:var(--surface-alt);border-bottom:1px solid var(--border)}
.landing-examples-table tbody td{color:var(--text-muted);font-family:var(--font-body);font-weight:500}
.landing-examples-table tbody td:first-child{color:var(--text);font-family:var(--font-display);font-weight:500;letter-spacing:-.01em}
.landing-examples-table tbody tr:last-child td{border-bottom:none}
.landing-examples-highlight td{background:rgba(245,158,11,.12);color:var(--text)!important}
[data-theme="dark"] .landing-examples-highlight td{background:rgba(245,158,11,.18)}
/* Combined hero numbers disclosure: quiet desktop footer to the hero. */
.hero-numbers{width:100%;margin:40px 0 0;padding-top:28px;border:0;border-top:1px solid var(--border-soft);border-radius:0;background:transparent;box-shadow:none;overflow:visible;}
.hero-numbers > summary{list-style:none;cursor:pointer;padding:6px 0;display:flex;align-items:center;gap:10px;user-select:none;}
.hero-numbers > summary::-webkit-details-marker{display:none;}
.hero-numbers > summary:focus-visible{outline:2px solid var(--brand);outline-offset:6px;border-radius:4px;}
.hero-numbers-title{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:500;color:var(--text);flex:1;min-width:0;line-height:1.35;}
.hero-numbers > summary:hover .hero-numbers-title{color:var(--text);}
.hero-numbers-dot{width:6px;height:6px;border-radius:50%;background:var(--brand);flex-shrink:0;}
.hero-numbers-meta{font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted);font-weight:500;flex-shrink:0;}
.hero-numbers-chev{color:var(--text-muted);font-size:11px;line-height:1;transition:transform .2s ease-out,color .15s ease;display:inline-block;flex-shrink:0;margin-left:2px;}
.hero-numbers > summary:hover .hero-numbers-chev{color:var(--text);}
.hero-numbers[open] .hero-numbers-chev{transform:rotate(180deg);}
.hero-numbers-body{padding:0;}
.hero-numbers-tabs-row{display:flex;align-items:center;justify-content:space-between;gap:16px;margin:32px 0 24px;}
.hero-numbers-tabs{display:inline-flex;align-items:center;gap:0;padding:3px;border:1px solid var(--border-soft);border-radius:22px;background:var(--surface-alt);}
.hero-numbers-tab{font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;padding:8px 16px;border:0;border-radius:18px;background:transparent;color:var(--text-muted);cursor:pointer;transition:background var(--transition),color var(--transition),box-shadow var(--transition);}
.hero-numbers-tab:hover{color:var(--text);}
.hero-numbers-tab:focus-visible{outline:2px solid var(--brand);outline-offset:2px;}
.hero-numbers-tab.is-active{background:var(--surface);color:var(--text);box-shadow:0 1px 2px rgba(10,11,13,.06);}
.hero-numbers-source{font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;color:var(--text-muted);text-decoration:none;white-space:nowrap;}
.hero-numbers-source:hover{color:var(--text);}
.hero-numbers-panel[hidden]{display:none;}
.hero-numbers-facts{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:32px 40px;margin:0;padding:0;}
.hero-numbers-fact{min-width:0;}
.hero-numbers-fact dt{font-family:var(--font-mono);font-size:10.5px;font-weight:500;letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted);margin-bottom:8px;}
.hero-numbers-fact dd{font-family:var(--font-display);font-size:18px;font-weight:600;letter-spacing:-.005em;color:var(--text);font-variant-numeric:tabular-nums;margin:0;line-height:1.28;}
.fact-note{font-family:var(--font-mono);font-size:11px;font-weight:400;color:var(--text-muted);letter-spacing:0;margin-left:4px;white-space:nowrap;}
.hero-numbers-examples{width:100%;border:0;border-collapse:separate;border-spacing:0;font-variant-numeric:tabular-nums;background:transparent;}
.hero-numbers-examples th{padding:6px 16px 14px;text-align:left;border-bottom:1px solid var(--border);font-family:var(--font-mono);font-size:10.5px;font-weight:500;letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted);}
.hero-numbers-examples td{padding:16px;text-align:left;border-bottom:1px solid var(--border-soft);font-size:14px;line-height:1.35;color:var(--text-muted);}
.hero-numbers-examples td:first-child{color:var(--text);font-weight:500;}
.hero-numbers-examples tbody tr:last-child td{border-bottom:0;}
.hero-numbers-example-row--highlight td{padding:18px 16px;border-bottom:0;background:var(--amber-bg);color:var(--text);font-weight:600;}
.hero-numbers-example-row--highlight td:first-child{border-radius:6px 0 0 6px;}
.hero-numbers-example-row--highlight td:last-child{border-radius:0 6px 6px 0;}
.hero-numbers-example-row--highlight strong{color:var(--text);font-weight:600;}
.landing-examples-gloss{font-size:13px;color:var(--text-muted);line-height:1.65;margin:24px 2px 0;max-width:70ch}
[data-theme="dark"] .hero-numbers{border-top-color:var(--border);}
[data-theme="dark"] .hero-numbers-tabs{background:var(--surface-alt);border-color:var(--border);}
[data-theme="dark"] .hero-numbers-tab.is-active{background:var(--surface);box-shadow:0 1px 2px rgba(0,0,0,.32);}

/* Small screens */
@media (max-width:720px){
  .landing-facts-grid{grid-template-columns:1fr 1fr}
  .landing-fact:nth-child(3n){border-right:1px solid var(--border-soft)}
  .landing-fact:nth-child(2n){border-right:none}
  .landing-fact:nth-last-child(-n+3){border-bottom:1px solid var(--border-soft)}
  .landing-fact:nth-last-child(-n+2){border-bottom:none}
  .landing-examples-table th,.landing-examples-table td{padding:12px 14px;font-size:13.5px}
  .landing-tldr{padding:22px 22px}
}
/* ═══ END LANDING PAGE ADDITIONS ═══ */

/* ═══════════════════════════════════════════════════════════════
   V3 ACTION PANEL — additive. New class names (.act-*, .when-*,
   .result-*, .v3-*, .partner-*) don't clash with existing rules.
   Desktop + mobile responsive via @media at the bottom.
   ═══════════════════════════════════════════════════════════════ */
.recommendation .mono{font-family:var(--font-mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace);font-feature-settings:"tnum" 1,"lnum" 1;}
.recommendation .brtxt{color:var(--brand);font-weight:500;}

.act-corner-tag{position:absolute;top:16px;right:18px;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.12em;color:var(--text-muted);}
.act-corner-tag.--brand{color:var(--brand);}
/* Wireframe fix (m0417): on desktop, the 01·ACT / 02·WHEN / 03·RESULT pill becomes a top-row label rather than corner-absolute, so titles wrapping to two lines no longer collide with it. Mobile keeps the corner placement (vertical compression). */
.act-corner-tag.--inline{position:static;display:block;margin-bottom:10px;}

.act-card{border:1px solid var(--border);border-radius:14px;background:var(--surface);margin-bottom:10px;overflow:hidden;position:relative;}
.act-card > summary{list-style:none;cursor:pointer;padding:18px 20px;position:relative;display:block;}
.act-card > summary::-webkit-details-marker{display:none;}
.act-card .act-eyebrow{font-size:11px;color:var(--text-muted);font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding-right:60px;}
.act-card .act-headline{font-family:var(--font-display);font-size:24px;font-weight:500;letter-spacing:-0.018em;line-height:1.25;margin-top:6px;padding-right:40px;color:var(--text);}
.act-card .act-headline strong{font-weight:500;color:var(--brand);}
.act-card .act-reveal{margin-top:14px;display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--brand);font-weight:600;}
/* Show/Hide label swap based on <details open> state — pure CSS, no JS state needed. */
.act-card .act-reveal-hide{display:none;}
.act-card[open] .act-reveal-show{display:none;}
.act-card[open] .act-reveal-hide{display:inline;}
.act-card .act-reveal-meta{margin-left:auto;font-size:11px;color:var(--text-light);font-weight:500;letter-spacing:.04em;}
.act-card .act-chev{color:var(--text-muted);transition:transform .15s;display:inline-block;}
.act-card[open] .act-chev{transform:rotate(180deg);}
.act-card .act-body{padding:16px 20px 20px;border-top:1px dashed var(--rec-divider);}
.act-card .act-body > p:first-child{margin-top:0;}
.act-card .act-body > p:last-child{margin-bottom:0;}
.act-card .act-body p{font-size:15px;line-height:1.6;color:var(--text-muted);margin:0 0 10px;}
.act-card .act-body p strong{color:var(--text);font-weight:600;}
/* Wireframe stages — WHEN-labelled lanes, no rail or numbered circles.
   The numbered nodes were duplicating the 01/02/03 pattern in 'Why this works'; here the rhythm is a schedule, not a logical sequence. Hairline between stages instead. */
.act-timeline{position:relative;}
.act-step{padding:20px 0;border-top:1px solid var(--border-soft);}
.act-step:first-child{padding-top:0;border-top:0;}
.act-step:last-child{padding-bottom:0;}
.act-step-when{display:inline-block;font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted);font-weight:600;line-height:1.2;margin-bottom:9px;background:transparent!important;box-shadow:none!important;padding:0;}
.act-step:first-child .act-step-when{color:var(--brand);}
.act-step-title{font-size:16px;font-weight:600;color:var(--text);line-height:1.4;margin-bottom:6px;}
.act-step-title strong{font-weight:600;color:var(--text);}
.act-step-body{font-size:14.5px;color:var(--text-muted);line-height:1.6;}
.act-step-body strong{color:var(--text);font-weight:600;}
[data-theme="dark"] .act-step-num{background:var(--surface-alt);border-color:var(--border);color:var(--text-muted);}
[data-theme="dark"] .act-step:first-child .act-step-num{background:var(--brand);color:#fff;}

.when-card{border:1px solid var(--border);border-radius:14px;padding:18px 22px;background:var(--surface);position:relative;margin-bottom:12px;}
.when-card .when-eyebrow{font-size:11px;color:var(--text-muted);font-weight:700;letter-spacing:.12em;text-transform:uppercase;}
.when-card .when-body{font-size:15px;font-weight:500;line-height:1.55;color:var(--text);display:flex;flex-direction:column;gap:3px;}
/* Inline-note's base style is small + text-light (used elsewhere in the calculator); inside the WHEN body it must inherit the card body styling. Wireframe uses 17px at the 460px artboard; in our narrower sidebar we drop to 15px for matching perceived density. */
.when-card .when-body .inline-note{margin:0;padding:0;border:0;background:none;display:block;font-size:15px;line-height:1.55;color:var(--text);font-family:var(--font-body);}
.when-card .when-body .alt-suppressed-note{margin:0;padding:0;border:0;background:none;display:block;font-size:15px;line-height:1.55;color:var(--text);font-family:var(--font-body);}

.result-card{background:var(--brand-soft);border:1px solid rgba(0,82,255,.25);border-radius:14px;padding:20px 22px;position:relative;margin-bottom:24px;}
.result-card .result-eyebrow{font-size:11px;color:var(--brand);font-weight:700;letter-spacing:.12em;text-transform:uppercase;}
.result-card .result-number{font-family:var(--font-mono);font-size:44px;font-weight:500;letter-spacing:-1.4px;line-height:1;color:var(--brand);}
.result-card .result-number-suffix{font-size:16px;color:var(--text-muted);}
.result-card .result-sub{font-size:13px;color:var(--text-muted);margin-top:6px;line-height:1.5;}
.result-card .result-sub .mono{color:var(--text);}
/* Take-home / cost row inside the RESULT card. Surfaces the trade-off so the user sees both sides in one glance. */
.result-takehome{margin-top:14px;padding-top:12px;border-top:1px solid rgba(0,82,255,.18);}
.result-takehome-eyebrow{font-size:11px;color:var(--text-muted);font-weight:600;letter-spacing:.06em;text-transform:uppercase;margin-bottom:10px;}
.result-takehome-row{display:flex;align-items:baseline;justify-content:space-between;gap:12px;}
.result-takehome-row + .result-takehome-row{margin-top:8px;padding-top:8px;border-top:1px dashed rgba(0,82,255,.18);}
.result-takehome-label{font-size:12px;color:var(--text-muted);font-weight:500;}
.result-takehome-label .result-takehome-sub{color:var(--text-light);}
.result-takehome-value{font-family:var(--font-mono);font-size:17px;font-weight:600;color:var(--text);letter-spacing:-0.3px;}
.result-takehome-value-suffix{font-size:12px;color:var(--text-muted);font-weight:500;}
/* PP-only two-line take-home: cash flow on row 1, net cost punch on row 2 (right-aligned, brand). */
.result-takehome-flow{font-size:13px;color:var(--text-muted);line-height:1.5;}
.result-takehome-flow .mono{color:var(--text);font-weight:600;}
.result-takehome-net{display:flex;align-items:baseline;justify-content:flex-end;gap:8px;margin-top:6px;}
.result-takehome-arrow{color:var(--text-light);font-size:14px;}
.result-takehome-net-label{font-size:13px;color:var(--text-muted);}
.result-takehome-net-value{font-family:var(--font-mono);font-size:18px;font-weight:600;color:var(--brand);letter-spacing:-0.3px;}

.v3-expandable{border:1px solid var(--border);border-radius:12px;margin-bottom:10px;background:var(--surface);overflow:hidden;}
.v3-expandable > summary{list-style:none;cursor:pointer;padding:13px 16px;display:flex;align-items:center;justify-content:space-between;font-size:15px;font-weight:600;color:var(--text);}
.v3-expandable > summary::-webkit-details-marker{display:none;}
.v3-expandable > summary .v3-chev{color:var(--text-muted);transition:transform .15s;display:inline-block;}
.v3-expandable[open] > summary .v3-chev{transform:rotate(180deg);}
.v3-expandable .v3-body{padding:4px 18px 16px;}
.v3-expandable .v3-body > .comparison-mobile{margin-top:4px;}

.why-row{display:flex;gap:14px;padding:14px 0;border-top:1px dashed var(--rec-divider);}
.why-row:first-child{border-top:0;padding-top:6px;}
.why-num{flex:0 0 24px;font-family:var(--font-mono);font-size:12px;color:var(--brand);font-weight:600;letter-spacing:.05em;padding-top:4px;}
.why-text{font-size:16px;color:var(--text);line-height:1.6;}
.why-text strong{font-weight:600;color:var(--text);}
.why-text .mono{font-family:var(--font-mono);font-feature-settings:"tnum" 1,"lnum" 1;}
/* PP See-the-maths trio — label-value rows with brand-coloured punch line. Same visual rhythm as .why-row (hairline-separated) but without the numbered prefix since this is a numerical summary, not a sequenced narrative. */
.ledger-row{display:flex;align-items:baseline;justify-content:space-between;gap:14px;padding:12px 0;border-top:1px dashed var(--rec-divider);}
.ledger-row:first-child{border-top:0;padding-top:6px;}
.ledger-label{font-size:14px;color:var(--text);font-weight:500;}
.ledger-value{font-family:var(--font-mono);font-size:15px;font-weight:600;color:var(--text);}
.ledger-value.--brand{color:var(--brand);font-size:17px;}
.ledger-row-summary{margin-top:2px;}
/* CalcShell — wireframe in-place breakdown of how the recommended figure was derived. POST-action figures. */
.v3-calc-shell{margin-top:10px;background:transparent;border:1px solid var(--border-soft);border-radius:12px;overflow:hidden;}
.v3-calc-shell-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 16px;background:var(--surface-alt,#F5F5F4);border:0;color:var(--text-muted);font-family:inherit;cursor:pointer;text-align:left;min-height:44px;font-size:13px;font-weight:500;}
.v3-calc-shell-label{flex:1;}
.v3-calc-shell-chev{color:var(--text-muted);font-size:12px;transition:transform .18s ease-out;display:inline-block;opacity:.7;}
.v3-calc-shell-chev.--open{transform:rotate(180deg);}
.v3-calc-shell-body{border-top:1px solid var(--border-soft);background:#FAFAFA;}
.calc-shell-section-head{padding:18px 16px 11px;border-top:1px solid var(--border-soft);}
.calc-shell-section-head:first-child{border-top:0;}
.calc-shell-section-label{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-light);font-weight:600;}
.calc-shell-row{display:flex;gap:14px;align-items:flex-start;padding:10px 16px 10px 30px;}
.calc-shell-row-content{flex:1;min-width:0;}
.calc-shell-row-label{font-size:13px;font-weight:500;color:var(--text);line-height:1.4;}
.calc-shell-row-note{font-size:11.5px;color:var(--text-muted);line-height:1.45;margin-top:2px;}
.calc-shell-row-value{font-family:var(--font-mono);font-size:13px;font-weight:500;white-space:nowrap;flex-shrink:0;padding-top:1px;color:var(--text);}
.calc-shell-row-value.--sub,.calc-shell-row-value.--allowance,.calc-shell-row-value.--add{color:var(--green,#067647);}
.calc-shell-row.--total{background:var(--brand-soft);padding:13px 16px;margin-top:12px;margin-bottom:12px;}
.calc-shell-row.--total .calc-shell-row-label{font-weight:600;font-size:13.5px;}
.calc-shell-row.--total .calc-shell-row-value{color:var(--brand);font-weight:600;font-size:15px;}
.calc-shell-row.--total .calc-shell-row-note{margin-top:4px;}
[data-theme="dark"] .v3-calc-shell{border-color:var(--border);}
[data-theme="dark"] .v3-calc-shell-toggle{background:var(--surface-alt);}
[data-theme="dark"] .v3-calc-shell-body{background:var(--surface-alt);}
[data-theme="dark"] .calc-shell-row.--total{background:rgba(87,139,250,.14);}

.partner-divider{margin:24px 0;height:1px;background:var(--rec-divider);border:0;}
.partner-eyebrow{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-light);font-weight:700;margin-bottom:12px;}
.partner-block{padding:20px;background:var(--surface-alt);border-radius:10px;border:1px solid var(--border-soft);}
.partner-row{padding-top:16px;padding-bottom:16px;border-top:1px dashed var(--rec-divider);}
.partner-row:first-child{padding-top:0;border-top:0;}
.partner-row:last-child{padding-bottom:0;}
.partner-row-text{font-size:16px;color:var(--text);line-height:1.45;font-weight:500;margin-bottom:12px;}
.partner-cta{width:100%;padding:12px 14px;border-radius:7px;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px;text-decoration:none;box-sizing:border-box;white-space:nowrap;}
.partner-cta.--primary{background:var(--text);color:var(--surface);border:0;}
.partner-cta.--secondary{background:var(--surface);color:var(--text);border:1px solid var(--border);}
.partner-foot{margin-top:14px;font-size:12px;color:var(--text-light);line-height:1.45;}
.partner-foot .mono{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;font-weight:600;color:var(--text-light);}

/* ─── Scenario Tool — grouped card with Plan from / Plan to expandable rows ──
   Replaces the prior chip-style target picker and the standalone planning-timing toggle.
   Same visual shape on mobile and desktop (single source of styles). */
.scen-tool{margin-top:28px;}
.scen-tool-header{display:flex;align-items:center;gap:10px;margin-bottom:18px;}
.scen-tool-hairline{flex:1;height:1px;background:var(--rec-divider);}
.scen-tool-eyebrow{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-light);font-weight:600;font-family:var(--font-mono);}
.scen-tool-card{background:var(--surface);border:1px solid var(--border-soft);border-radius:12px;overflow:hidden;}
.scen-row{width:100%;display:flex;align-items:center;gap:14px;background:transparent;border:0;padding:16px 18px;cursor:pointer;color:var(--text);font-size:14px;font-weight:500;font-family:inherit;text-align:left;min-height:48px;}
.scen-row-icon{flex-shrink:0;color:var(--text-muted);display:inline-flex;align-items:center;}
.scen-row-label{flex:1;}
.scen-row-value{font-size:14px;color:var(--text-light);font-weight:500;font-family:var(--font-mono);}
.scen-row-chev{color:#C7C7CC;font-size:16px;line-height:1;display:inline-block;width:10px;text-align:center;flex-shrink:0;transition:transform .18s ease-out;}
.scen-row-chev.--open{transform:rotate(90deg);}
.scen-row-divider{height:1px;background:var(--border-soft);}
.scen-panel{padding:0 18px 16px;border-top:1px solid var(--border-soft);background:var(--surface-alt);}
.scen-panel-intro{font-size:12.5px;color:var(--text-light);line-height:1.5;padding:14px 0 12px;}
.scen-control-row{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--surface);border:1px solid var(--border-soft);border-radius:10px;margin-bottom:12px;}
.scen-control-readout{font-size:14px;color:var(--text);font-weight:500;flex:1;font-family:var(--font-mono);}
.scen-control-action{font-size:12px;color:var(--brand);font-weight:500;}
.scen-control-label{flex:1;font-size:13.5px;color:var(--text-muted);}
.scen-control-prefix{font-size:14px;color:var(--text-light);font-weight:500;font-family:var(--font-mono);}
.scen-control-input{width:80px;border:0;outline:0;background:transparent;font-size:14px;font-weight:600;color:var(--text);font-family:var(--font-mono);padding:0;text-align:right;}
/* Visible date input, styled to look like a native control inside the grouped card. */
.scen-date-input{display:block;font-family:var(--font-mono);font-size:14px;color:var(--text);font-weight:500;background:var(--surface);border:1px solid var(--border-soft);border-radius:10px;padding:12px 14px;cursor:pointer;width:100%;box-sizing:border-box;margin-bottom:12px;-webkit-appearance:none;appearance:none;}
.scen-date-input::-webkit-calendar-picker-indicator{cursor:pointer;color:var(--brand);opacity:.7;}
.scen-date-input:hover::-webkit-calendar-picker-indicator{opacity:1;}
.scen-readouts{}
.scen-readout-row{display:flex;align-items:center;padding:12px 2px;border-top:1px solid var(--border-soft);min-height:42px;}
.scen-readout-key{flex:1;font-size:13.5px;color:var(--text-muted);}
.scen-readout-value{font-size:14px;font-weight:600;color:var(--text);font-family:var(--font-mono);}
.scen-readout-value.--brand{color:var(--brand);}
/* Reset-to-today link inside the Plan-from panel — small text-link, shown only when an override date is set. */
.scen-reset-row{display:flex;justify-content:flex-end;margin-top:14px;}
.scen-reset-link{background:transparent;border:0;font-size:11.5px;color:var(--text-muted);cursor:pointer;font-family:inherit;text-decoration:underline;text-underline-offset:3px;padding:0;}
.scen-reset-link:hover{color:var(--text);}
.scen-presets-eyebrow{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-light);font-weight:600;margin-bottom:8px;font-family:var(--font-mono);}
.scen-presets{display:flex;gap:8px;}
.scen-preset{flex:1;padding:10px 8px;background:var(--surface);color:var(--text);border:1px solid var(--border-soft);border-radius:10px;font-family:inherit;cursor:pointer;text-align:center;line-height:1.3;}
.scen-preset.--active{background:var(--brand);color:#fff;border-color:var(--brand);}
.scen-preset-amt{display:block;font-size:12.5px;font-weight:600;font-family:var(--font-mono);}
.scen-preset-lbl{display:block;font-size:10px;font-weight:500;margin-top:3px;opacity:.75;letter-spacing:.01em;}
/* ─── Mobile-native action + hero (≤640px) — wireframe ArtboardRecommendedV3 mobile branch ─── */
.mob-rec-route-status{margin-top:6px;margin-bottom:24px;font-size:10px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;font-family:var(--font-mono);display:flex;align-items:center;gap:6px;color:var(--text-light);}
.mob-rec-route-status.--rec{color:var(--brand);}
.mob-rec-route-status-dot{width:6px;height:6px;border-radius:999px;flex-shrink:0;border:1.5px solid var(--text-light);}
.mob-rec-route-status.--rec .mob-rec-route-status-dot{background:var(--brand);border:0;}
.mob-rec-action{padding-bottom:18px;}
.mob-rec-action-title{font-size:26px;font-weight:500;letter-spacing:-0.6px;line-height:1.2;color:var(--text);margin-bottom:8px;}
.mob-rec-action-title strong,.mob-rec-action-title .brtxt{color:var(--brand);font-weight:500;}
.mob-rec-action-sub{font-size:15.5px;line-height:1.5;color:var(--text-muted);margin-bottom:18px;}
.mob-rec-action-cta{width:100%;padding:14px 16px;background:var(--brand);color:#fff;border:0;border-radius:10px;font-size:15.5px;font-weight:600;font-family:inherit;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;}
.mob-rec-action-cta.--open{border-radius:10px 10px 0 0;}
.mob-rec-action-cta-chev{font-size:14px;display:inline-block;transition:transform .2s;}
.mob-rec-action-cta.--open .mob-rec-action-cta-chev{transform:rotate(180deg);}
.mob-rec-step-list{padding:18px 20px 20px;background:var(--surface);border:1px solid var(--border-soft);border-top:0;border-radius:0 0 10px 10px;}
.mob-rec-step{font-size:17px;line-height:1.6;color:var(--text);}
.mob-rec-step:not(:first-child){padding-top:16px;border-top:1px dashed var(--rec-divider);}
.mob-rec-step:not(:last-child){padding-bottom:16px;}
.mob-rec-step strong{color:var(--text);font-weight:600;}
.mob-rec-hero{padding:24px 22px 22px;background:var(--brand-soft);border:1px solid rgba(0,82,255,.2);border-radius:16px;margin-top:8px;margin-bottom:24px;}
.mob-rec-hero-eyebrow{font-size:13px;color:var(--brand);font-weight:600;letter-spacing:.04em;margin-bottom:8px;}
.mob-rec-hero-number{font-family:var(--font-mono);font-size:56px;font-weight:500;letter-spacing:-2.2px;line-height:.95;color:var(--brand);}
.mob-rec-hero-number-suffix{font-size:16px;color:var(--text-muted);font-weight:500;}
.mob-rec-hero-sub{font-size:15.5px;color:var(--text-muted);margin-top:14px;line-height:1.6;}
/* Reuse .result-takehome styles inside .mob-rec-hero for the take-home cost row. */
.mob-rec-hero .result-takehome{margin-top:18px;padding-top:16px;}
.mob-rec-hero .result-takehome-eyebrow{font-size:11.5px;}
.mob-rec-hero .result-takehome-value{font-size:19px;}
/* Mobile "See the maths" — header strip + comparison rows + marginal rate footer. */
.v3-summary-sub{color:var(--text-muted);font-weight:400;}
.mob-rec-maths-body{}
.mob-rec-maths-header{display:flex;justify-content:space-between;align-items:center;padding:10px 18px;background:var(--surface-alt);border-top:1px solid var(--border-soft);border-bottom:1px solid var(--border-soft);}
.mob-rec-maths-header-l{font-size:11px;font-weight:600;color:var(--text-light);text-transform:uppercase;letter-spacing:.08em;}
.mob-rec-maths-header-r{display:flex;gap:32px;font-size:11px;color:var(--text-light);font-weight:600;text-transform:uppercase;letter-spacing:.07em;padding-right:78px;}
.mob-rec-maths-rows{}
.mob-rec-marginal{padding:14px 18px;display:flex;align-items:center;gap:12px;border-top:1px solid var(--border-soft);}
.mob-rec-marginal-label{font-size:11px;color:var(--text-muted);font-weight:600;letter-spacing:.1em;text-transform:uppercase;}
.mob-rec-marginal-values{display:flex;align-items:baseline;gap:8px;margin-top:4px;}
.mob-rec-marginal-today{font-size:20px;font-weight:600;color:var(--amber,#b54708);text-decoration:line-through;text-decoration-color:rgba(181,71,8,.4);font-family:var(--font-mono);}
.mob-rec-marginal-arrow{font-size:14px;color:var(--text-light);}
.mob-rec-marginal-after{font-size:22px;font-weight:600;color:var(--text);font-family:var(--font-mono);}
.mob-rec-marginal-after.--good{color:var(--green,#067647);}
[data-theme="dark"] .mob-rec-step-list{background:var(--surface-alt);border-color:var(--border);}
[data-theme="dark"] .scen-tool-card{background:var(--surface-alt);border-color:var(--border);}
[data-theme="dark"] .scen-control-row,
[data-theme="dark"] .scen-preset{background:var(--surface);border-color:var(--border);}
[data-theme="dark"] .scen-preset.--active{background:var(--brand);border-color:var(--brand);}
[data-theme="dark"] .act-card,
[data-theme="dark"] .when-card,
[data-theme="dark"] .v3-expandable{background:var(--surface-alt);border-color:var(--border);}
[data-theme="dark"] .partner-block{background:var(--surface-alt);border-color:var(--border);}
[data-theme="dark"] .partner-cta.--secondary{background:var(--surface);}

@media (max-width:640px){
  .act-card > summary{padding:16px 16px;}
  .act-card .act-corner-tag{top:14px;right:14px;}
  .act-card .act-headline{font-size:22px;padding-right:60px;}
  .act-card .act-reveal{font-size:14px;margin-top:16px;}
  .act-card .act-reveal-meta{display:none;}
  .act-card .act-body{padding:16px 16px;}
  .act-timeline::before{left:13px;}
  .act-step{padding-left:38px;}
  .act-step-num{width:27px;height:27px;font-size:11px;}
  .act-step-when{font-size:10px;margin-bottom:7px;}
  .act-step-title{font-size:16px;}
  .act-step-body{font-size:14.5px;}
  .act-step-meta{grid-template-columns:1fr;}
  .when-card{padding:16px 18px;}
  .when-card .when-body{padding-right:60px;font-size:16px;}
  .result-card{padding:18px 20px;}
  .result-card .result-number{font-size:40px;}
  .result-card .result-sub{font-size:14px;margin-top:8px;}
  .v3-expandable > summary{padding:15px 18px;font-size:16px;}
  .v3-expandable .v3-body{padding:4px 18px 18px;}
  .why-row{padding:12px 0;}
  .why-text{font-size:15.5px;}
  .partner-divider{margin:28px 0;}
  .partner-row{padding:18px 0;}
  .partner-cta{padding:13px 14px;font-size:15px;border-radius:8px;}
  .partner-block{padding:20px 20px;border-radius:12px;}
}
/* ═══ END V3 ACTION PANEL ═══ */

/* Mobile-first calculator shell. Desktop stays on the existing grid; these controls only
   participate below the narrow breakpoint. */
.mobile-hero-eyebrow,
.mobile-hero-question,
.mobile-hero-subtext,
.mobile-details-toggle{display:none;}
.bonus-mode-hint,
.bonus-label-short,
.bonus-toggle-short,
.detail-label-short,
.detail-title-short,
.mobile-family-subtitle,
.mobile-pension-basis-select,
.mobile-bonus-sac-select,
.mobile-car-status-select,
.mobile-car-method-select,
.mobile-car-type-select,
.mobile-car-sac-type-select,
.mobile-childcare-support-select{display:none;}
.mobile-details-body{display:contents;}
.mobile-estimate-preview{display:none;}
.theme-toggle{aspect-ratio:1 / 1;position:relative;}

@media(max-width:860px){
  .layout{display:flex;flex-direction:column;padding:0 20px 24px;gap:0;background:var(--bg);}
  .hero{display:contents;}
  .hero-input-wrap{max-width:none;display:contents;padding:0;}
  .hero-ask,
  .hero-dek,
  .hero-entry-label{display:none;}
  .mobile-hero-eyebrow{order:1;display:flex;align-items:center;gap:7px;margin:24px 0 12px;font-family:var(--font-mono);font-size:10.5px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--text-light);}
  .mobile-hero-eyebrow span[aria-hidden="true"]{color:var(--accent);}
  .mobile-hero-question{order:1;display:block;margin:0 0 10px;font-size:38px;line-height:1.03;letter-spacing:-.035em;font-weight:600;color:var(--text);}
  .mobile-hero-subtext{order:1;display:block;margin:0 0 22px;max-width:min(100%,44ch);font-size:15px;line-height:1.5;color:var(--text-muted);text-wrap:pretty;}
  .hero-salary{order:1;align-items:baseline;padding:0 0 14px;margin:0;border:0;border-bottom:2px solid var(--text);border-radius:0;background:transparent;box-shadow:none;gap:7px;}
  .hero-salary:focus-within{border-color:var(--brand);box-shadow:none;}
  .hero-salary-prefix{font-size:54px;line-height:1;padding:0;color:var(--text-light);}
  .hero-salary input[type="text"]{flex:1 1 0;font-size:54px;line-height:1;letter-spacing:-.04em;min-width:0;}
  .hero-salary-suffix{font-size:12.5px;line-height:1.2;align-self:center;padding:0;margin-left:auto;color:var(--text-muted);}
  .hero-salary-presets{order:1;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:7px;margin:14px 0 18px;}
  .hero-salary-presets button{min-width:0;min-height:36px;padding:7px 5px;border:1px solid var(--border-soft);border-radius:999px;background:var(--surface);color:var(--text-muted);font-family:var(--font-body);font-size:12.5px;font-weight:600;cursor:pointer;}
  .hero-salary-presets button:hover{border-color:var(--ring-deep);color:var(--text);}
  .hero-salary-presets button:focus-visible{outline:2px solid var(--brand);outline-offset:2px;}
  .hero-salary-presets button.is-active{background:var(--brand-soft);border-color:rgba(0,82,255,.28);color:var(--brand);}
  .hero-chart{display:none;}
  .hero-cta-row{order:6;display:none;flex-direction:column;align-items:stretch;gap:8px;margin-top:0;}
  .hero-cta,
  .hero-cta-secondary{width:100%;justify-content:center;min-height:46px;}
  .hero-numbers{display:none;}

  .mobile-estimate-preview{order:2;display:block;margin:0 0 12px;padding:12px 13px;border:1px solid var(--border-soft);border-radius:14px;background:var(--surface);box-shadow:var(--shadow-sm);color:var(--text);}
  .mobile-estimate-preview:empty{display:none;}
  .mobile-estimate-row{display:flex;align-items:center;justify-content:space-between;gap:12px;}
  .mobile-estimate-main{min-width:0;display:grid;gap:2px;}
  .mobile-estimate-eyebrow{font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-light);}
  .mobile-estimate-main strong{font-size:23px;line-height:1.05;letter-spacing:-.02em;color:var(--text);}
  .mobile-estimate-main span:last-child{font-size:11.5px;color:var(--text-muted);}
  .mobile-estimate-pill{flex:0 0 auto;max-width:46%;padding:6px 8px;border-radius:999px;background:var(--bg-soft);color:var(--text-muted);font-size:11.5px;font-weight:700;text-align:right;line-height:1.25;}
  .mobile-estimate-note{margin-top:7px;font-size:12px;line-height:1.4;color:var(--text-muted);}
  .mobile-estimate-preview.is-over{border-color:rgba(185,28,28,.22);}
  .mobile-estimate-preview.is-over .mobile-estimate-pill{background:rgba(185,28,28,.08);color:var(--red);}
  .mobile-estimate-preview.is-close .mobile-estimate-pill{background:rgba(146,64,14,.08);color:var(--accent);}
  .mobile-estimate-preview.is-under .mobile-estimate-pill{background:var(--brand-soft);color:var(--brand);}

  .results-col{order:4;position:relative;top:auto;max-height:none;min-width:0;margin:48px 0 0;padding:0;background:transparent;border-top:0;}
  .hero--empty ~ .results-col:has(#actionPanel:empty){display:none;}
  .results-card{background:transparent;border:0;box-shadow:none;max-height:none;min-width:0;overflow:visible;}
  .results-header{display:none;}
  .results-body{padding:0;overflow:visible;}
  #statusBanner{margin:0 0 48px;}
  #statusBanner:not(:empty){margin:0 -20px 48px;padding:22px 20px 0;border-top:1px solid var(--border-soft);}
  #statusBanner:not(:empty)::before{content:none;display:none;}
  #childcareResult{margin:0 0 12px;}
  #familyCostCallout{margin:0 0 18px;}
  #resultsDivider{display:none!important;}
  #actionPanel{min-width:0;}
  #actionPanel:not(:empty){margin:0 -20px;padding:48px 20px 0;border-top:1px solid var(--border-soft);}
  #actionPanel:not(.validation-stop):not(:empty)::before{content:"Recommendation based on current inputs";display:block;font-family:var(--font-mono);font-size:10.5px;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:var(--text-light);margin:0 0 10px;}
  .status-banner{padding:0;border-radius:0;font-size:13px;line-height:1.5;box-shadow:none;overflow:visible;}
  .status-banner.status-under,
  .status-banner.status-close,
  .status-banner.status-over{background:transparent;border:0;color:var(--text);}
  .status-desktop-copy{display:none;}
  .mobile-status-card{display:block;color:var(--text);}
  .mobile-result-block{padding:26px 0 18px;}
  .mobile-result-label{font-family:var(--font-mono);font-size:10.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--text-light);margin-bottom:10px;}
  .mobile-result-amount{display:flex;align-items:baseline;gap:4px;font-family:var(--font-display);font-size:58px;font-weight:500;letter-spacing:-.045em;line-height:.96;color:var(--text);font-variant-numeric:tabular-nums;}
  .mobile-result-currency{color:var(--text-light);}
  .mobile-result-sub{display:flex;align-items:center;flex-wrap:wrap;gap:5px 10px;margin-top:12px;font-size:14px;line-height:1.4;color:var(--text-muted);}
  .mobile-result-sub strong{font-weight:600;color:var(--text);font-variant-numeric:tabular-nums;}
  .mobile-result-dot{width:3px;height:3px;border-radius:50%;background:var(--text-light);opacity:.75;}
  .mobile-result-bar{display:flex;height:7px;margin-top:20px;border-radius:999px;overflow:hidden;background:var(--surface-alt);}
  .mobile-result-seg{height:100%;min-width:2px;}
  .mobile-result-seg.takehome{background:var(--brand);}
  .mobile-result-seg.tax{background:#E8833A;}
  .mobile-result-seg.ni{background:#9CA3AF;}
  .mobile-result-legend{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:15px;}
  .mobile-result-legend-item{min-width:0;}
  .mobile-result-legend-label{display:block;font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:var(--text-light);white-space:nowrap;}
  .mobile-result-swatch{display:inline-block;width:7px;height:7px;margin-right:6px;border-radius:2px;vertical-align:middle;position:relative;top:-1px;}
  .mobile-result-swatch.takehome{background:var(--brand);}
  .mobile-result-swatch.tax{background:#E8833A;}
  .mobile-result-swatch.ni{background:#9CA3AF;}
  .mobile-result-legend-value{display:block;margin-top:6px;font-size:clamp(16px,4.6vw,18px);font-weight:500;line-height:1.1;color:var(--text);font-variant-numeric:tabular-nums;white-space:nowrap;}
  .mobile-result-legend-item:nth-child(1) .mobile-result-legend-value{color:var(--brand);}
  .mobile-result-legend-item:nth-child(2) .mobile-result-legend-value{color:#B4530A;}
  .mobile-result-legend-item:nth-child(3) .mobile-result-legend-value{color:var(--text-muted);}
  .mobile-result-legend-value em{font-style:normal;font-size:12px;color:var(--text-light);margin-left:2px;}
  .mobile-trap-card{margin:24px 0 0;padding:22px 20px 24px;background:transparent;border:1px solid var(--border-soft);border-radius:22px;box-shadow:var(--shadow-sm);}
  .mobile-trap-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:18px;}
  .mobile-trap-title{font-size:22px;font-weight:600;line-height:1.15;letter-spacing:-.025em;color:var(--text);}
  .mobile-trap-rate{display:flex;align-items:baseline;gap:2px;font-family:var(--font-display);font-size:44px;font-weight:500;line-height:1;letter-spacing:-.04em;color:var(--text);font-variant-numeric:tabular-nums;}
  .mobile-trap-rate span{font-size:22px;color:var(--text-light);letter-spacing:-.02em;}
  .mobile-trap-rate.is-trap{color:var(--red);}
  .mobile-trap-rail{position:relative;margin-top:4px;padding:34px 0 42px;}
  .mobile-trap-track{position:relative;height:10px;border-radius:999px;background:var(--surface-alt);overflow:hidden;box-shadow:inset 0 0 0 1px var(--border-soft);}
  .mobile-trap-zone{position:absolute;top:0;bottom:0;background:var(--text);background-image:repeating-linear-gradient(-45deg,transparent 0 4px,rgba(255,255,255,.18) 4px 5px);}
  .mobile-trap-marker{position:absolute;top:39px;width:20px;height:20px;border:4px solid var(--text);border-radius:50%;background:var(--surface);box-shadow:0 2px 8px rgba(10,11,13,.18);transform:translate(-50%,-50%);z-index:2;}
  .mobile-trap-marker.is-trap{border-color:var(--red);}
  .mobile-trap-marker-label{position:absolute;top:0;transform:translateX(-50%);padding:5px 10px;border-radius:999px;background:var(--text);color:var(--bg);font-size:12px;font-weight:700;line-height:1;white-space:nowrap;font-variant-numeric:tabular-nums;z-index:3;}
  .mobile-trap-marker-label::after{content:"";position:absolute;left:50%;top:100%;transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--text);}
  .mobile-trap-tick{position:absolute;top:22px;bottom:19px;width:1px;background:var(--border);}
  .mobile-trap-tick span{position:absolute;top:calc(100% + 7px);left:50%;transform:translateX(-50%);font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;color:var(--text-light);white-space:nowrap;}
  .mobile-trap-tick-start span{left:0;transform:none;}
  .mobile-trap-tick-end span{left:auto;right:0;transform:none;}
  .mobile-status-copy{margin:0;color:var(--text-muted);font-size:14px;line-height:1.45;text-wrap:pretty;}
  .mobile-status-copy strong{font-weight:600;color:var(--text);}
  .mobile-status-childcare{margin-top:12px;padding-top:11px;border-top:1px solid var(--border-soft);color:var(--text-muted);font-size:12.5px;line-height:1.5;}
  .fcc{border-radius:16px;padding:16px;background:var(--surface);}
  .fcc-intro{gap:8px;}
  .fcc-total{font-size:24px;}
  #actionPanel:not(:empty){margin-top:0;}
  .recommendation{padding:18px;background:var(--surface);border-radius:18px;box-shadow:var(--shadow-sm);}
  .action-headline{font-size:21px;line-height:1.22;}
  .action-subheadline{font-size:14px;}
  .route-switcher{overflow-x:auto;scrollbar-width:none;margin-bottom:14px;}
  .route-switcher::-webkit-scrollbar{display:none;}
  .route-tab{flex:1 0 auto;min-width:max-content;padding:10px 12px;font-size:12px;white-space:nowrap;}
  .validation-stop-card{border-radius:16px;padding:18px 16px;}

  .input-col{order:3;margin-top:8px;min-width:0;}
  .mobile-details-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:15px 16px;margin:0;border:1px solid var(--border);border-radius:16px;background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm);font-family:var(--font-body);cursor:pointer;text-align:left;}
  .mobile-details-toggle:focus:not(:focus-visible){outline:none;}
  .mobile-details-toggle:focus-visible{outline:2px solid var(--brand);outline-offset:3px;}
  .mobile-details-toggle-main{display:flex;align-items:center;gap:10px;font-size:15px;font-weight:600;min-width:0;}
  .mobile-details-plus{width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:var(--brand-soft);color:var(--brand);font-size:18px;line-height:1;transition:transform .15s ease;}
  .mobile-details-toggle-meta{font-size:11.5px;color:var(--text-muted);line-height:1.35;text-align:right;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .mobile-details-chev{display:inline-block;color:var(--text-light);transition:transform .15s ease;}
  .mobile-details-body{display:none;margin-top:14px;}
  .input-col.mobile-details-open .mobile-details-body{display:flex;flex-direction:column;}
  .input-col.mobile-details-open .mobile-details-plus{transform:rotate(45deg);}
  .input-col.mobile-details-open .mobile-details-chev{transform:rotate(90deg);}
  .mobile-details-body .card{padding:14px 16px 4px;border-radius:14px;margin-bottom:12px;background:var(--surface);border-color:var(--border-soft);box-shadow:var(--shadow-sm);}
  .mobile-details-body .card:hover{box-shadow:var(--shadow-sm);border-color:var(--border-soft);}
  .mobile-details-body .card-header{display:block;margin:0 0 8px;padding:0;border-bottom:0;}
  .mobile-details-body .card-title{font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--text-muted);line-height:1.35;}
  .mobile-details-body .detail-label-long,
  .mobile-details-body .detail-title-long{display:none;}
  .mobile-details-body .detail-label-short,
  .mobile-details-body .detail-title-short{display:inline;}
  .mobile-details-body .card-subtitle{display:none;}
  .mobile-details-body .field-row{display:block;margin:0;}
  .mobile-details-body .field{display:grid;grid-template-columns:minmax(0,1fr) minmax(84px,34%);align-items:center;gap:4px 12px;margin:0;padding:12px 0;border-top:1px solid var(--border-soft);min-width:0;}
  .mobile-details-body .card-header + .field,
  .mobile-details-body .card-header + .field-row .field:first-child{border-top:0;}
  .mobile-details-body .field-row .field{margin:0;}
  .mobile-details-body label{min-width:0;margin:0!important;font-size:14px;line-height:1.32;font-weight:500;color:var(--text);}
  .mobile-details-body .helper-inline{display:block;margin:2px 0 0;font-size:11.5px;line-height:1.35;color:var(--text-muted);font-weight:400;}
  .mobile-details-body .helper-inline--compact{white-space:normal;font-size:11px;line-height:1.35;}
  .mobile-details-body .helper{grid-column:1/2;margin:0;font-size:11px;line-height:1.42;color:var(--text-muted);}
  .mobile-details-body .mobile-detail-long-helper{display:none;}
  .mobile-details-body .mobile-family-subtitle{display:block;padding:15px 0 7px;border-top:1px solid var(--border-soft);font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--text-muted);}
  .mobile-details-body .field-group{padding-top:13px;}
  .mobile-details-body .field > .input-prefix,
  .mobile-details-body .field > .input-suffix,
  .mobile-details-body .field > input[type="text"],
  .mobile-details-body .field > input[type="number"],
  .mobile-details-body .field > select{grid-column:2;min-width:0;width:100%;}
  .mobile-details-body input[type="text"],
  .mobile-details-body input[type="number"]{min-height:31px;padding:3px 0 4px;border:0!important;border-bottom:1.5px solid var(--border)!important;border-radius:0!important;background:transparent!important;box-shadow:none!important;text-align:right;font-size:15px;font-weight:500;color:var(--text);font-variant-numeric:tabular-nums;}
  .mobile-details-body input[type="text"]:focus,
  .mobile-details-body input[type="number"]:focus{border-bottom-color:var(--brand)!important;box-shadow:none!important;}
  .mobile-details-body input::placeholder{color:var(--text-light);opacity:.7;}
  .mobile-details-body .input-prefix::before{left:0;font-size:15px;color:var(--text-muted);}
  .mobile-details-body .input-prefix input{padding-left:20px;padding-right:0;}
  .mobile-details-body .input-suffix::after{right:0;font-size:13px;color:var(--text-muted);}
  .mobile-details-body .input-suffix input{padding-right:22px;}
  .mobile-details-body select{min-height:35px;padding:7px 28px 7px 10px!important;border:1.5px solid var(--border)!important;border-radius:8px!important;background-color:transparent!important;color:var(--text)!important;box-shadow:none!important;font-size:15px;font-weight:500;}
  .mobile-details-body select:focus{border-color:var(--brand)!important;box-shadow:none!important;}
  .mobile-details-body .toggle-group{grid-column:1/-1;display:flex;gap:3px;margin:0;padding:2px;border:1px solid var(--border-soft);border-radius:12px;background:var(--surface-alt);}
  .mobile-details-body .toggle-group label{min-width:0;min-height:30px;display:flex;align-items:center;justify-content:center;flex:1 1 auto;margin:0;padding:5px 8px;border:0;border-radius:10px;background:transparent;color:var(--text-muted);font-size:11.5px;line-height:1.2;text-align:center;}
  .mobile-details-body .toggle-group label:hover{background:transparent;color:var(--text);}
  .mobile-details-body .toggle-group input:checked + label{background:rgba(0,0,0,0.09);color:var(--text);box-shadow:none;}
  .mobile-details-body .toggle-group--compact{grid-column:1;display:inline-flex;justify-self:start;width:auto;min-width:0;margin-top:6px;border-radius:999px;}
  .mobile-details-body .toggle-group--compact label{flex:0 0 auto;min-width:36px;min-height:27px;padding:4px 11px;border-radius:999px;font-size:12px;line-height:1;}
  .mobile-details-body .field--pension-mode{grid-template-columns:minmax(0,1fr) minmax(84px,34%);align-items:center;}
  .mobile-details-body .field--pension-mode .pension-mode-label{grid-column:1;grid-row:1;}
  .mobile-details-body .field--pension-mode .pension-entry{display:contents;}
  .mobile-details-body .field--pension-mode .unit-input-fields{grid-column:2;grid-row:1;min-width:0;width:100%;}
  .mobile-details-body .field--pension-mode .unit-toggle{grid-column:1;grid-row:2;justify-self:start;margin-top:7px;}
  .mobile-details-body .field--pension-mode .pension-value-fields{min-width:0;width:100%;}
  .mobile-details-body .field--pension-mode .pension-extra-field{grid-column:1/-1;grid-row:3;margin-top:10px!important;}
  .mobile-details-body .field--pension-mode .planning-timing-toggle{grid-column:1/-1;grid-row:4;margin-top:10px!important;}
  .mobile-details-body .field--pension-mode #pensionBaseFields{grid-column:1/-1;grid-row:5;}
  .mobile-details-body .field--pension-mode .pension-extra-field .helper{grid-column:1/-1;}
  .mobile-details-body .field--pension-mode .pension-advanced-toggle{margin:8px 0 4px!important;padding:4px 0 10px;}
  .mobile-details-body .field--pension-mode #pensionBaseFields{padding-top:0;}
  .mobile-details-body #pensionBaseFields .field--pension-basis,
  .mobile-details-body #pensionBaseFields .field--bonus-sacrifice{grid-template-columns:minmax(0,1fr) minmax(84px,34%);padding:12px 0;margin:0;}
  .mobile-details-body #pensionBaseFields .mobile-pension-basis-select,
  .mobile-details-body #pensionBaseFields .mobile-bonus-sac-select{display:block;grid-column:2;min-width:0;width:100%;}
  .mobile-details-body #pensionBaseFields .field--pension-basis .toggle-group,
  .mobile-details-body #pensionBaseFields .field--bonus-sacrifice .toggle-group{display:none;}
  .mobile-details-body .field--car-status,
  .mobile-details-body .field--car-method,
  .mobile-details-body .field--car-type,
  .mobile-details-body .field--car-sac-type{grid-template-columns:minmax(0,1fr) minmax(84px,34%);}
  .mobile-details-body .mobile-car-status-select,
  .mobile-details-body .mobile-car-method-select,
  .mobile-details-body .mobile-car-type-select,
  .mobile-details-body .mobile-car-sac-type-select{display:block;grid-column:2;min-width:0;width:100%;}
  .mobile-details-body .field--car-status .toggle-group,
  .mobile-details-body .field--car-method .toggle-group,
  .mobile-details-body .field--car-type .toggle-group,
  .mobile-details-body .field--car-sac-type .toggle-group{display:none;}
  .mobile-details-body .field--childcare-toggle{grid-template-columns:minmax(0,1fr) minmax(84px,34%);}
  .mobile-details-body .field--childcare-toggle label{display:block!important;cursor:default!important;}
  .mobile-details-body .field--childcare-toggle label input{display:none;}
  .mobile-details-body .mobile-childcare-support-select{display:block;grid-column:2;min-width:0;width:100%;}
  .mobile-details-body .field--bonus-mode{grid-template-columns:minmax(0,1fr) minmax(84px,34%);align-items:center;}
  .mobile-details-body .field--bonus-mode .bonus-mode-label{grid-column:1;grid-row:1;}
  .mobile-details-body .field--bonus-mode .bonus-mode-hint{display:block;margin-top:2px;}
  .mobile-details-body .field--bonus-mode .bonus-label-long{display:none;}
  .mobile-details-body .field--bonus-mode .bonus-label-short{display:inline;}
  .mobile-details-body .field--bonus-mode .bonus-entry{display:contents;}
  .mobile-details-body .field--bonus-mode .unit-input-fields{grid-column:2;grid-row:1;min-width:0;width:100%;}
  .mobile-details-body .field--bonus-mode .unit-toggle{grid-column:1;grid-row:2;justify-self:start;margin-top:7px;}
  .mobile-details-body .field--bonus-mode #bonusPctFields,
  .mobile-details-body .field--bonus-mode #bonusAmountFields{min-width:0;width:100%;margin:0;}
  .mobile-details-body .unit-input{display:contents;}
  .mobile-details-body .unit-input .input-prefix::before,
  .mobile-details-body .unit-input .input-suffix::after{display:block;}
  .mobile-details-body .unit-input input[type="text"],
  .mobile-details-body .unit-input input[type="number"]{min-height:31px;padding-top:3px!important;padding-bottom:4px!important;border:0!important;border-bottom:1.5px solid var(--border)!important;border-radius:0!important;text-align:right;}
  .mobile-details-body .unit-input input[type="text"]:focus,
  .mobile-details-body .unit-input input[type="number"]:focus{border-bottom-color:var(--brand)!important;}
  .mobile-details-body .unit-toggle{display:inline-grid;grid-template-columns:repeat(2,24px);gap:2px;width:auto;padding:2px;border:1px solid var(--border-soft);border-radius:999px;background:var(--surface-alt);}
  .mobile-details-body .unit-toggle-btn{height:24px;border-radius:999px;font-size:11.5px;}
  .mobile-details-body .field > .toggle-group + .helper ~ .helper{display:none;}
  .mobile-details-body .planning-timing-toggle{margin:0!important;padding:12px 0;border-top:1px solid var(--border-soft);font-size:13px;line-height:1.35;color:var(--text);font-weight:500;}
  .mobile-details-body .conditional.open{margin-top:0;}
  .mobile-details-body .conditional-inner{padding:0;border:0;border-radius:0;background:transparent;}
  .mobile-details-body .benefit-list{grid-column:2;gap:0;}
  .mobile-details-body .benefit-row{display:grid;grid-template-columns:minmax(0,1fr);padding:0;}
  .mobile-details-body .benefit-row .input-prefix:has(.remove-benefit-btn){display:grid;grid-template-columns:minmax(0,1fr);}
  .mobile-details-body .benefit-row .input-prefix:has(.remove-benefit-btn) input{grid-column:1;grid-row:1;padding-right:0!important;}
  .mobile-details-body .benefit-row .input-prefix:has(.remove-benefit-btn)::before{top:15px;transform:none;}
  .mobile-details-body .remove-benefit-btn{position:static;transform:none;grid-column:1;grid-row:2;justify-self:end;width:auto;height:24px;margin-top:4px;padding:0;background:transparent;color:var(--text-muted);font-size:0;line-height:1;border-radius:0;}
  .mobile-details-body .remove-benefit-btn::before{content:"Remove";font-size:11.5px;font-weight:600;}
  .mobile-details-body .remove-benefit-btn:hover{background:transparent;color:var(--red);}
  .mobile-details-body .add-link-btn{grid-column:1/-1;justify-self:start;margin-top:2px;min-height:30px;padding:0;font-size:12px;color:var(--brand);}
  .mobile-details-body .add-link-btn + .helper{grid-column:1/-1;}
  .mobile-details-body input[type="checkbox"]{accent-color:var(--brand);}

  .act-card,
  .when-card,
  .result-card,
  .v3-expandable,
  .partner-block,
  .scen-tool-card{border-radius:16px;}
  .act-card .act-headline{font-size:21px;line-height:1.28;padding-right:36px;}
  .act-card .act-body p{font-size:14.5px;}
  .when-card .when-body{padding-right:0;}
  .result-card{padding:18px;background:var(--brand-soft);}
  .result-card .result-number{font-size:40px;letter-spacing:-1.2px;}
  .result-takehome-row,
  .result-takehome-net{flex-wrap:wrap;}
  .v3-expandable > summary{min-height:48px;padding:15px 16px;font-size:15px;gap:12px;}
  .v3-expandable .v3-body{padding:4px 14px 16px;}
  .comparison-card{padding:14px;background:var(--surface);}
  .comparison-card-values{flex-wrap:wrap;gap:8px;}
  .comparison-card-change{margin-left:0;}
  .mob-rec-action-title{font-size:24px;}
  .mob-rec-action-sub{font-size:15px;}
  .mob-rec-hero{padding:20px 18px;border-radius:16px;}
  .mob-rec-hero-number{font-size:44px;letter-spacing:-1.6px;}
  .mob-rec-maths-header{align-items:flex-start;gap:8px;padding:10px 14px;}
  .mob-rec-maths-header-r{gap:14px;padding-right:0;white-space:nowrap;}
  .mob-rec-marginal{align-items:flex-start;flex-direction:column;gap:6px;padding:14px;}
  .ledger-row{flex-wrap:wrap;gap:6px;}
  .ledger-value{margin-left:auto;}
  .v3-calc-shell-toggle{padding:12px 14px;}
  .calc-shell-section-head{padding:16px 14px 9px;}
  .calc-shell-row{padding:10px 14px;gap:8px;flex-wrap:wrap;}
  .calc-shell-row-value{margin-left:auto;white-space:normal;text-align:right;}
  .partner-cta{white-space:normal;min-height:44px;}

  .scen-tool{margin-top:24px;}
  .scen-tool-header{margin-bottom:14px;}
  .scen-row{padding:15px 14px;gap:10px;min-height:50px;}
  .scen-row-label,
  .scen-row-value,
  .scen-control-label,
  .scen-control-readout{min-width:0;}
  .scen-row-value{max-width:46%;font-size:12.5px;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .scen-panel{padding:0 14px 14px;}
  .scen-control-row{flex-wrap:wrap;align-items:center;padding:12px;}
  .scen-control-input{width:96px;max-width:100%;font-size:16px;}
  .scen-presets{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;}
  .scen-preset{min-width:0;min-height:48px;}
  .scen-readout-row{gap:12px;}
  .scen-readout-value{text-align:right;}

  [data-theme="dark"] .hero-salary,
  [data-theme="dark"] .mobile-details-toggle,
  [data-theme="dark"] .fcc,
  [data-theme="dark"] .recommendation{background:var(--surface);border-color:var(--border);}
  [data-theme="dark"] .hero-salary{background:transparent;border-color:var(--text);}
  [data-theme="dark"] .hero-salary:focus-within{border-color:var(--brand);}
  [data-theme="dark"] .hero-salary-presets button{background:var(--surface-alt);border-color:var(--border);color:var(--text-muted);}
  [data-theme="dark"] .hero-salary-presets button.is-active{background:var(--brand-soft);border-color:rgba(87,139,250,.28);color:var(--brand);}
  [data-theme="dark"] .mobile-result-seg.tax,
  [data-theme="dark"] .mobile-result-swatch.tax{background:#F59E0B;}
  [data-theme="dark"] .mobile-result-seg.ni,
  [data-theme="dark"] .mobile-result-swatch.ni{background:#6B7280;}
  [data-theme="dark"] .mobile-result-legend-item:nth-child(2) .mobile-result-legend-value{color:#E8A65A;}
  [data-theme="dark"] .mobile-details-body .card{background:var(--surface);border-color:var(--border);}
  [data-theme="dark"] .mobile-details-body .toggle-group{background:var(--surface-alt);border-color:var(--border);}
  [data-theme="dark"] .mobile-details-body .toggle-group input:checked + label{background:rgba(255,255,255,0.09);color:var(--text);}
  [data-theme="dark"] .mobile-details-body input[type="text"],
  [data-theme="dark"] .mobile-details-body input[type="number"],
  [data-theme="dark"] .mobile-details-body select{background:transparent!important;border-color:var(--border)!important;color:var(--text)!important;}
}

@media(max-width:430px){
  .mobile-hero-question{font-size:36px;}
  .hero-salary-prefix,
  .hero-salary input[type="text"]{font-size:50px;}
  .mobile-details-toggle{align-items:center;}
  .mobile-details-toggle-meta{max-width:none;line-height:1.2;}
  .route-tab{font-size:11.5px;padding-inline:10px;}
  .scen-presets{grid-template-columns:1fr;}
}
