/* =============================================================================
   TTHC LIVE QUOTE BUILDER — VEGAS BLUE BRAND SYSTEM
   Black-Navy base · Vegas Blue primary · Ice Blue accents · Chrome display
   Green reserved for savings/discounts only. (BRAND-KIT.md, LOCKED)
   ============================================================================= */

:root {
  /* --- Vegas Blue brand palette (BRAND-KIT.md) --- */
  --felt:        #040818;   /* Black Navy — page background / dark hero canvas */
  --felt-2:      #060c20;
  --panel:       #0a1330;   /* deep-navy-tinted panel */
  --panel-2:     #0d1838;
  --panel-3:     #122046;
  --line:        #1e2c55;
  --line-soft:   #16213f;

  /* primary brand blue (mapped onto legacy --gold* names so all usages shift) */
  --gold:        #3377F0;   /* Vegas Blue — primary CTA / emphasis / links */
  --gold-deep:   #0C2B8A;   /* Deep Navy — strong end of the brand gradient */
  --gold-glow:   rgba(51, 119, 240, 0.55);

  /* secondary accent (legacy --cyan* names) */
  --cyan:        #73E1FF;   /* Ice Blue — highlight / glow / secondary emphasis */
  --cyan-glow:   rgba(115, 225, 255, 0.5);

  /* tertiary accent — retired magenta, now Ice Blue family (on-brand) */
  --magenta:     #73E1FF;
  --magenta-glow:rgba(115, 225, 255, 0.45);

  --green:       #3ddc84;   /* "win" / savings / discounts ONLY */
  --green-glow:  rgba(61, 220, 132, 0.45);

  --ink:         #FFFFFF;   /* clean white */
  --ink-muted:   #aeb9d4;   /* cool muted slate-blue */
  --ink-faint:   #67739a;

  /* chrome metallic display gradient (white -> slate) */
  --chrome-top:  #FFFFFF;
  --chrome-bot:  #7E89A5;

  /* --- type (BRAND-KIT: Anton display / Archivo subhead / Inter body) --- */
  --font-display: 'Anton', 'Arial Narrow', sans-serif;
  --font-body:    'Inter', 'Helvetica Neue', sans-serif;
  --font-subhead: 'Archivo', 'Helvetica Neue', sans-serif;
  --font-mono:    'DM Mono', 'Courier New', monospace;

  /* --- spacing --- */
  --sp-1:4px; --sp-2:8px; --sp-3:12px; --sp-4:16px; --sp-5:20px;
  --sp-6:24px; --sp-8:32px; --sp-10:40px; --sp-12:48px; --sp-16:64px;

  --r-sm:8px; --r-md:14px; --r-lg:20px; --r-xl:28px; --r-full:999px;

  --ease: cubic-bezier(0.16, 1, 0.3, 1);
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale; text-rendering:optimizeLegibility; scroll-behavior:smooth; }

body {
  min-height:100dvh;
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.55;
  color:var(--ink);
  background:var(--felt);
  position:relative;
  overflow-x:hidden;
}

img,svg { display:block; max-width:100%; }
button { cursor:pointer; background:none; border:none; color:inherit; font:inherit; }
input { font:inherit; color:inherit; }

::selection { background:var(--gold-glow); color:#fff; }

:focus-visible { outline:2px solid var(--cyan); outline-offset:3px; border-radius:var(--r-sm); }

@media (prefers-reduced-motion: reduce) {
  *,*::before,*::after { animation-duration:.01ms !important; transition-duration:.01ms !important; }
}

/* ============ AMBIENT BACKDROP ============ */
.bg-felt {
  position:fixed; inset:0; z-index:-2;
  background:
    radial-gradient(circle at 18% 12%, #0a1640 0%, transparent 42%),
    radial-gradient(circle at 85% 88%, #0C2B8A 0%, transparent 45%),
    var(--felt);
}
.bg-felt::after {
  content:""; position:absolute; inset:0;
  background-image:
    repeating-linear-gradient(45deg, rgba(255,255,255,.012) 0 2px, transparent 2px 6px);
  opacity:.6;
}
.bg-glow {
  position:fixed; inset:0; z-index:-1; pointer-events:none;
  background:
    radial-gradient(ellipse 60% 40% at 50% -5%, var(--gold-glow), transparent 60%);
  opacity:.22;
  animation:glowPulse 7s var(--ease) infinite alternate;
}
@keyframes glowPulse { from{opacity:.14;} to{opacity:.30;} }

/* ============ HEADER / MARQUEE ============ */
.marquee {
  position:relative;
  padding:var(--sp-12) var(--sp-5) var(--sp-8);
  text-align:center;
  border-bottom:1px solid var(--line-soft);
  background:linear-gradient(180deg, rgba(10,14,12,0) 0%, rgba(6,9,8,.5) 100%);
}
.marquee-inner { max-width:900px; margin:0 auto; }

.brand {
  display:inline-flex; align-items:center; gap:var(--sp-4);
  flex-wrap:wrap; justify-content:center;
}
.brand-name {
  font-family:var(--font-display);
  font-size:clamp(2.1rem, 6vw, 4.4rem);
  letter-spacing:.04em;
  line-height:.95;
  background:linear-gradient(180deg, var(--chrome-top) 0%, #c8d0e2 55%, var(--chrome-bot) 100%);
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent;
  filter:drop-shadow(0 0 18px var(--gold-glow));
  text-transform:uppercase;
}
.brand-bulbs {
  width:clamp(40px,14vw,120px); height:14px;
  background-image:radial-gradient(circle, var(--gold) 0 3px, transparent 4px);
  background-size:16px 14px;
  filter:drop-shadow(0 0 6px var(--gold-glow));
  animation:bulbs 1.1s steps(2) infinite;
  border-radius:var(--r-full);
}
@keyframes bulbs { 50% { opacity:.35; } }

.brand-sub {
  margin-top:var(--sp-4);
  font-family:var(--font-subhead); font-weight:700;
  font-size:.78rem; letter-spacing:.28em; text-transform:uppercase;
  color:var(--cyan);
  text-shadow:0 0 10px var(--cyan-glow);
  font-weight:600;
}
.brand-tag {
  margin-top:var(--sp-3);
  color:var(--ink-muted);
  font-size:clamp(.95rem,2.5vw,1.1rem);
  max-width:560px; margin-inline:auto;
}

/* ============ LAYOUT ============ */
.layout {
  max-width:1240px; margin:0 auto;
  padding:var(--sp-10) var(--sp-5) var(--sp-16);
  display:grid;
  grid-template-columns:1fr 400px;
  gap:var(--sp-8);
  align-items:start;
}
@media (max-width:980px) {
  .layout { grid-template-columns:1fr; }
}

/* ============ STEP BANNERS ============ */
.step-banner {
  display:flex; align-items:center; gap:var(--sp-4);
  margin-bottom:var(--sp-6);
}
.perks-banner { margin-top:var(--sp-10); }
.step-num {
  font-family:var(--font-display);
  font-size:1.6rem;
  color:#fff;
  background:linear-gradient(180deg,var(--gold),var(--gold-deep));
  width:48px; height:48px; flex:none;
  display:grid; place-items:center;
  border-radius:50%;
  box-shadow:0 0 18px var(--gold-glow), inset 0 0 0 2px rgba(255,255,255,.25);
}
.step-banner h2 {
  font-family:var(--font-display);
  font-size:clamp(1.3rem,3.5vw,1.8rem);
  letter-spacing:.02em; text-transform:uppercase;
  color:var(--ink);
}
.step-banner p { color:var(--ink-muted); font-size:.92rem; margin-top:2px; }
.step-banner em { color:var(--gold); font-style:normal; font-weight:700; }

/* ============ SERVICE CARDS ============ */
.service-stack { display:flex; flex-direction:column; gap:var(--sp-4); }

.svc {
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  background:linear-gradient(180deg, var(--panel-2), var(--panel));
  overflow:hidden;
  transition:border-color .25s var(--ease), box-shadow .25s var(--ease);
}
.svc.is-active {
  border-color:var(--gold-deep);
  box-shadow:0 0 0 1px var(--gold-deep), 0 0 28px rgba(255,213,74,.12);
}

.svc-head {
  width:100%;
  display:flex; align-items:center; gap:var(--sp-4);
  padding:var(--sp-5) var(--sp-5);
  text-align:left;
}
.svc-icon {
  width:46px; height:46px; flex:none;
  display:grid; place-items:center;
  border-radius:var(--r-md);
  background:var(--panel-3);
  border:1px solid var(--line);
  color:var(--cyan);
  transition:.25s var(--ease);
}
.svc.is-active .svc-icon {
  color:#fff;
  background:linear-gradient(180deg,var(--gold),var(--gold-deep));
  border-color:var(--gold);
  box-shadow:0 0 16px var(--gold-glow);
}
.svc-icon svg { width:24px; height:24px; }
.svc-titles { flex:1; min-width:0; }
.svc-name {
  font-family:var(--font-display);
  font-size:1.18rem; letter-spacing:.02em; text-transform:uppercase;
  color:var(--ink);
}
.svc-blurb { color:var(--ink-muted); font-size:.82rem; line-height:1.4; }

.svc-right { display:flex; align-items:center; gap:var(--sp-3); flex:none; }
.svc-amount {
  font-family:var(--font-mono);
  font-size:.95rem; font-weight:500;
  color:var(--gold);
  text-shadow:0 0 10px var(--gold-glow);
  opacity:0; transform:translateX(6px);
  transition:.25s var(--ease);
  white-space:nowrap;
}
.svc-amount.show { opacity:1; transform:none; }
.svc-caret {
  width:26px; height:26px; color:var(--ink-faint);
  transition:transform .3s var(--ease), color .2s;
}
.svc.is-open .svc-caret { transform:rotate(180deg); color:var(--gold); }

/* body */
.svc-body {
  display:grid; grid-template-rows:0fr;
  transition:grid-template-rows .35s var(--ease);
}
.svc.is-open .svc-body { grid-template-rows:1fr; }
.svc-body-inner { overflow:hidden; }
.svc-body-pad {
  padding:0 var(--sp-5) var(--sp-5);
  border-top:1px solid var(--line-soft);
  margin-top:0;
}
.svc.is-open .svc-body-pad { padding-top:var(--sp-5); }

.field { margin-top:var(--sp-5); }
.field:first-child { margin-top:var(--sp-4); }
.field-label {
  font-family:var(--font-subhead); font-weight:600;
  font-size:.72rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--cyan); font-weight:700; margin-bottom:var(--sp-3);
  text-shadow:0 0 8px var(--cyan-glow);
}

/* ---- chip option grids ---- */
.chip-grid { display:flex; flex-wrap:wrap; gap:var(--sp-2); }
.chip {
  position:relative;
  border:1px solid var(--line);
  background:var(--panel-3);
  border-radius:var(--r-full);
  padding:10px 16px;
  font-size:.88rem; font-weight:600;
  color:var(--ink-muted);
  display:inline-flex; align-items:center; gap:8px;
  transition:.18s var(--ease);
}
.chip .chip-price { font-family:var(--font-mono); font-size:.8rem; color:var(--ink-faint); }
.chip:hover { border-color:var(--cyan); color:var(--ink); }
.chip.sel {
  border-color:var(--gold);
  background:linear-gradient(180deg,#26200d,#1c1808);
  color:var(--gold);
  box-shadow:0 0 0 1px var(--gold-deep), 0 0 14px rgba(255,213,74,.18);
}
.chip.sel .chip-price { color:var(--gold); }

/* plain-English helper line under a field label */
.field-help {
  font-size:.82rem; line-height:1.45; color:var(--ink-muted);
  margin:-2px 0 var(--sp-3); max-width:60ch;
}

/* prominent "read this" callout (e.g. SUV — no big items) */
.field-warn {
  font-size:.82rem; line-height:1.5; color:var(--ink);
  background:rgba(255,213,74,.07);
  border:1px solid var(--gold-deep);
  border-left:3px solid var(--gold);
  border-radius:var(--r-md, 12px);
  padding:11px 14px; margin:0 0 var(--sp-3); max-width:62ch;
}
.field-warn strong { color:var(--gold); font-weight:800; }

/* ---- size legend (junk "what fits" guide) ---- */
.size-legend {
  display:grid; grid-template-columns:repeat(5,1fr); gap:var(--sp-2);
  margin-bottom:var(--sp-3);
}
.size-legend-card {
  border:1px solid var(--line);
  background:var(--panel-3);
  border-radius:var(--r-md, 12px);
  padding:10px 10px 12px;
  transition:.18s var(--ease);
}
.size-legend-card .slc-name {
  font-family:var(--font-display);
  font-size:1rem; letter-spacing:.02em; color:var(--gold); line-height:1;
}
.size-legend-card .slc-sub {
  font-family:var(--font-mono); font-size:.68rem; color:var(--cyan);
  margin:4px 0 6px; letter-spacing:.02em;
}
.size-legend-card .slc-ex {
  font-size:.74rem; line-height:1.35; color:var(--ink-muted);
}
.size-legend-card.hot {
  border-color:var(--gold);
  background:linear-gradient(180deg,#26200d,#1c1808);
  box-shadow:0 0 0 1px var(--gold-deep), 0 0 16px rgba(255,213,74,.22);
  transform:translateY(-2px);
}
@media (max-width:760px){
  .size-legend { grid-template-columns:repeat(2,1fr); }
}

/* matrix (junk) */
.matrix-rows { display:flex; flex-direction:column; gap:var(--sp-3); }
.matrix-row { }
.matrix-row-label { margin-bottom:8px; display:flex; flex-direction:column; gap:2px; }
.matrix-row-label .mrl-main { font-size:.9rem; font-weight:800; color:var(--ink); }
.matrix-row-label .mrl-sub  { font-size:.76rem; font-weight:500; color:var(--ink-muted); }
.chip .chip-size { font-weight:800; }

/* ---- stacked chips: plain-English label on top, clarifier below ---- */
.chip.chip-stack {
  flex-direction:column;
  align-items:flex-start;
  text-align:left;
  gap:5px;
  border-radius:var(--r-md, 12px);
  padding:12px 15px;
  max-width:340px;
}
.chip.chip-stack .chip-main {
  display:flex; align-items:baseline; gap:8px; flex-wrap:wrap;
  font-weight:800; color:var(--ink); line-height:1.2;
  width:100%;
}
.chip.chip-stack:hover .chip-main { color:var(--ink); }
.chip.chip-stack.sel .chip-main { color:var(--gold); }
.chip.chip-stack .chip-main .chip-price { margin-left:auto; }
.chip.chip-stack .chip-sub {
  font-size:.76rem; font-weight:500; line-height:1.4;
  color:var(--ink-muted);
}
.chip.chip-stack.sel .chip-sub { color:var(--ink); }
@media (max-width:760px){
  .chip.chip-stack { max-width:100%; width:100%; }
}

/* qty stepper */
.qty {
  display:inline-flex; align-items:center; gap:0;
  border:1px solid var(--line); border-radius:var(--r-full);
  background:var(--panel-3); overflow:hidden;
}
.qty button {
  width:38px; height:38px; font-size:1.3rem; font-weight:700;
  color:var(--gold); display:grid; place-items:center;
  transition:background .15s;
}
.qty button:hover { background:var(--panel); }
.qty input {
  width:46px; text-align:center; border:none; background:none;
  font-family:var(--font-mono); font-size:1rem; color:var(--ink);
  -moz-appearance:textfield;
}
.qty input::-webkit-outer-spin-button,.qty input::-webkit-inner-spin-button{ -webkit-appearance:none; margin:0; }
.qty-row { display:flex; align-items:center; gap:var(--sp-4); margin-top:var(--sp-3); }
.qty-row .qty-label { font-size:.85rem; color:var(--ink-muted); }

/* freq toggle */
.freq-toggle { display:inline-flex; border:1px solid var(--line); border-radius:var(--r-full); overflow:hidden; background:var(--panel-3); }
.freq-toggle button { padding:8px 18px; font-size:.82rem; font-weight:700; color:var(--ink-muted); }
.freq-toggle button.on { background:linear-gradient(180deg,#26200d,#1c1808); color:var(--gold); box-shadow:inset 0 0 0 1px var(--gold-deep); }

/* rider checkboxes */
.riders { display:flex; flex-direction:column; gap:var(--sp-2); margin-top:var(--sp-2); }
.rider {
  display:flex; align-items:flex-start; gap:var(--sp-3);
  padding:11px 14px; border:1px solid var(--line-soft);
  border-radius:var(--r-md); background:var(--felt-2);
  transition:.15s var(--ease);
}
.rider:hover { border-color:var(--line); }
.rider.sel { border-color:var(--cyan); background:rgba(47,243,224,.05); }
.rider-box {
  width:20px; height:20px; flex:none; border-radius:6px; margin-top:1px;
  border:1.5px solid var(--line); display:grid; place-items:center;
  transition:.15s;
}
.rider-price { margin-top:1px; }
.rider.sel .rider-box { background:var(--cyan); border-color:var(--cyan); box-shadow:0 0 10px var(--cyan-glow); }
.rider-box svg { width:13px; height:13px; color:var(--felt); opacity:0; }
.rider.sel .rider-box svg { opacity:1; }
.rider-text { flex:1; display:flex; flex-direction:column; gap:2px; }
.rider-label { font-size:.86rem; color:var(--ink); font-weight:600; }
.rider-sub { font-size:.74rem; line-height:1.35; color:var(--ink-muted); }
.rider-price { font-family:var(--font-mono); font-size:.82rem; color:var(--ink-muted); white-space:nowrap; }
.rider.sel .rider-price { color:var(--cyan); }

.note-line {
  font-size:.76rem; color:var(--ink-faint);
  margin-top:var(--sp-3); padding-left:var(--sp-1);
  border-left:2px solid var(--line); padding-left:var(--sp-3);
}

/* ============ PERKS ============ */
.perks { display:grid; grid-template-columns:1fr 1fr; gap:var(--sp-4); }
@media (max-width:560px){ .perks { grid-template-columns:1fr; } }
.perk-chip { cursor:pointer; }
.perk-chip input { position:absolute; opacity:0; pointer-events:none; }
.perk-face {
  display:block; padding:var(--sp-4) var(--sp-5);
  border:1px solid var(--line); border-radius:var(--r-md);
  background:var(--panel-2); transition:.2s var(--ease);
}
.perk-chip:hover .perk-face { border-color:var(--magenta); }
.perk-chip input:checked + .perk-face {
  border-color:var(--magenta);
  background:linear-gradient(180deg, rgba(255,61,139,.10), rgba(255,61,139,.03));
  box-shadow:0 0 0 1px var(--magenta), 0 0 18px var(--magenta-glow);
}
.perk-title { display:block; font-weight:800; font-size:.95rem; color:var(--ink); }
.perk-chip input:checked + .perk-face .perk-title { color:var(--magenta); }
.perk-desc { display:block; font-size:.78rem; color:var(--ink-muted); margin-top:3px; }

/* ============ TICKET / JACKPOT ============ */
.ticket {
  position:sticky; top:var(--sp-5);
  border:1px solid var(--gold-deep);
  border-radius:var(--r-xl);
  background:
    radial-gradient(ellipse 100% 50% at 50% 0%, rgba(255,213,74,.06), transparent 60%),
    linear-gradient(180deg, var(--panel-2), var(--felt-2));
  box-shadow:0 0 0 1px rgba(255,213,74,.1), 0 24px 60px rgba(0,0,0,.55), 0 0 40px rgba(255,213,74,.06);
  overflow:hidden;
}
.ticket-head {
  display:flex; align-items:center; justify-content:space-between;
  padding:var(--sp-4) var(--sp-5);
  border-bottom:1px dashed var(--line);
}
.ticket-label { font-size:.7rem; letter-spacing:.26em; font-weight:800; color:var(--gold); text-shadow:0 0 10px var(--gold-glow); }
.ticket-pulse { width:10px; height:10px; border-radius:50%; background:var(--green); box-shadow:0 0 12px var(--green-glow); animation:pulse 1.6s infinite; }
@keyframes pulse { 50%{ opacity:.3; transform:scale(.8);} }

.jackpot {
  text-align:center; padding:var(--sp-8) var(--sp-5) var(--sp-2);
  display:flex; align-items:flex-start; justify-content:center; gap:4px;
}
.jackpot-cur { font-family:var(--font-display); font-size:2rem; color:var(--gold); margin-top:10px; opacity:.85; }
.jackpot-num {
  font-family:var(--font-display);
  font-size:clamp(3.2rem,8vw,4.6rem); line-height:.9;
  /* Casino-readout gold, NOT white. A white fill + glow bloomed inside the
     Anton "0" glyph and read as an oversized highlighted circle. Solid gold
     with a tight dark outline keeps every digit crisp and on-brand. */
  color:var(--gold);
  text-shadow:0 1px 0 rgba(0,0,0,.55), 0 0 16px var(--gold-glow);
  letter-spacing:.02em;
  transition:transform .18s var(--ease);
}
.jackpot-num.bump { animation:bump .35s var(--ease); }
@keyframes bump { 0%{transform:scale(1);} 40%{transform:scale(1.06);} 100%{transform:scale(1);} }
.jackpot-cents { font-size:.42em; color:var(--gold); opacity:.72; vertical-align:super; text-shadow:0 1px 0 rgba(0,0,0,.5); }
.jackpot-sub { text-align:center; color:var(--ink-muted); font-size:.85rem; padding:0 var(--sp-5) var(--sp-4); }

.savings-pill {
  margin:0 var(--sp-5) var(--sp-5);
  text-align:center; padding:10px;
  border-radius:var(--r-full);
  background:linear-gradient(180deg, rgba(61,220,132,.16), rgba(61,220,132,.05));
  border:1px solid var(--green);
  color:var(--green); font-weight:800; font-size:.9rem;
  text-shadow:0 0 10px var(--green-glow);
  animation:bump .4s var(--ease);
}

/* breakdown */
.breakdown { padding:0 var(--sp-5) var(--sp-4); }
.empty-ticket { text-align:center; padding:var(--sp-8) var(--sp-2); color:var(--ink-muted); }
.empty-chip { font-size:1.4rem; letter-spacing:.3em; color:var(--gold-deep); margin-bottom:var(--sp-3); opacity:.6; }
.empty-hint { font-size:.78rem; color:var(--ink-faint); margin-top:var(--sp-2); }

.bd-group { margin-bottom:var(--sp-4); }
.bd-line {
  display:flex; justify-content:space-between; align-items:baseline; gap:var(--sp-3);
  padding:7px 0; border-bottom:1px solid var(--line-soft);
  font-size:.87rem;
}
.bd-line:last-child { border-bottom:none; }
.bd-line .bd-name { color:var(--ink); flex:1; }
.bd-line .bd-name small { display:block; color:var(--ink-faint); font-size:.72rem; }
.bd-line .bd-val { font-family:var(--font-mono); color:var(--ink); white-space:nowrap; }
.bd-line.is-discount .bd-val { color:var(--green); }
.bd-line.is-strike .bd-orig { color:var(--ink-faint); text-decoration:line-through; font-size:.78rem; margin-right:6px; }

.bd-step {
  display:flex; justify-content:space-between; gap:var(--sp-3);
  padding:8px 12px; margin-top:var(--sp-2);
  border-radius:var(--r-sm); background:var(--felt-2);
  font-size:.82rem;
}
.bd-step .bd-step-name { color:var(--ink-muted); }
.bd-step.win .bd-step-name { color:var(--green); }
.bd-step .bd-step-val { font-family:var(--font-mono); color:var(--ink); white-space:nowrap; }
.bd-step.win .bd-step-val { color:var(--green); }
.bd-step-note { font-size:.74rem; color:var(--ink-faint); padding:2px 12px var(--sp-2); }

.bd-divider { height:1px; background:repeating-linear-gradient(90deg,var(--line) 0 6px, transparent 6px 12px); margin:var(--sp-4) 0; }

.bd-total {
  display:flex; justify-content:space-between; align-items:baseline;
  padding-top:var(--sp-3); margin-top:var(--sp-2);
  border-top:2px solid var(--gold-deep);
}
.bd-total .bd-total-label { font-family:var(--font-display); font-size:1.1rem; letter-spacing:.04em; color:var(--gold); text-transform:uppercase; }
.bd-total .bd-total-val { font-family:var(--font-mono); font-size:1.3rem; font-weight:500; color:#fff; }

/* foot */
.ticket-foot { padding:var(--sp-4) var(--sp-5) var(--sp-6); border-top:1px dashed var(--line); }
.foot-note { font-size:.8rem; color:var(--gold); margin-bottom:var(--sp-3); text-align:center; }
.cta {
  display:block; text-align:center; text-decoration:none;
  padding:14px; border-radius:var(--r-full);
  font-family:var(--font-display); font-size:1.1rem; letter-spacing:.05em; text-transform:uppercase;
  color:#fff;
  background:linear-gradient(180deg,var(--gold),var(--gold-deep));
  box-shadow:0 0 24px var(--gold-glow), inset 0 1px 0 rgba(255,255,255,.5);
  transition:transform .15s var(--ease), box-shadow .2s;
}
.cta:hover { transform:translateY(-2px); box-shadow:0 6px 30px var(--gold-glow); }
.fine { font-size:.7rem; color:var(--ink-faint); text-align:center; margin-top:var(--sp-3); line-height:1.5; }

/* ============ PAGE FOOT ============ */
.page-foot {
  text-align:center; padding:var(--sp-10) var(--sp-5) var(--sp-16);
  border-top:1px solid var(--line-soft);
  color:var(--ink-faint); font-size:.82rem;
  max-width:700px; margin:0 auto;
}

/* mobile sticky mini-total */
@media (max-width:980px) {
  .ticket { position:static; }
}

/* ============ UPSELL / MODAL ============ */
.upsell-overlay {
  position:fixed; inset:0; z-index:100;
  display:grid; place-items:center;
  padding:var(--sp-5);
  background:rgba(4,7,6,.78);
  backdrop-filter:blur(6px);
  opacity:0; transition:opacity .25s var(--ease);
}
.upsell-overlay.in { opacity:1; }
.upsell {
  width:min(440px,100%);
  border:1px solid var(--gold-deep);
  border-radius:var(--r-xl);
  background:
    radial-gradient(ellipse 100% 60% at 50% 0%, rgba(255,213,74,.10), transparent 60%),
    linear-gradient(180deg, var(--panel-2), var(--felt-2));
  box-shadow:0 0 0 1px rgba(255,213,74,.15), 0 30px 80px rgba(0,0,0,.6), 0 0 50px rgba(255,213,74,.1);
  padding:var(--sp-8) var(--sp-6) var(--sp-6);
  text-align:center;
  transform:translateY(16px) scale(.97);
  transition:transform .3s var(--ease);
}
.upsell-overlay.in .upsell { transform:none; }
.upsell-ribbon {
  display:inline-block; margin-bottom:var(--sp-4);
  padding:6px 16px; border-radius:var(--r-full);
  font-size:.66rem; letter-spacing:.2em; font-weight:800;
  color:#fff;
  background:linear-gradient(180deg,var(--gold),var(--gold-deep));
  box-shadow:0 0 18px var(--gold-glow);
}
.upsell-title {
  font-family:var(--font-display);
  font-size:1.5rem; letter-spacing:.02em; text-transform:uppercase;
  color:var(--ink); line-height:1.05; margin-bottom:var(--sp-3);
}
.upsell-pitch { color:var(--ink-muted); font-size:.92rem; line-height:1.55; margin-bottom:var(--sp-5); }
.upsell-pitch strong { color:var(--gold); }

.upsell-offer {
  border:1px solid var(--line); border-radius:var(--r-md);
  background:var(--felt-2); padding:var(--sp-4);
  margin-bottom:var(--sp-5); text-align:left;
}
.upsell-offer-row { display:flex; justify-content:space-between; align-items:center; gap:var(--sp-3); font-size:.9rem; padding-bottom:var(--sp-3); border-bottom:1px solid var(--line-soft); }
.upsell-prices { white-space:nowrap; }
.upsell-was { color:var(--ink-faint); text-decoration:line-through; font-size:.82rem; margin-right:8px; font-family:var(--font-mono); }
.upsell-now { color:var(--green); font-weight:800; font-family:var(--font-mono); text-shadow:0 0 10px var(--green-glow); }
.upsell-newtotal { display:flex; justify-content:space-between; align-items:center; gap:var(--sp-3); padding-top:var(--sp-3); font-size:.92rem; }
.upsell-newtotal-val { font-family:var(--font-display); font-size:1.35rem; color:#fff; text-shadow:0 0 16px var(--gold-glow); }

.upsell-actions { display:flex; flex-direction:column; gap:var(--sp-3); }
.upsell-yes {
  display:block; text-decoration:none; text-align:center;
  padding:14px; border-radius:var(--r-full);
  font-family:var(--font-display); font-size:1.05rem; letter-spacing:.04em; text-transform:uppercase;
  color:#fff;
  background:linear-gradient(180deg,var(--gold),var(--gold-deep));
  box-shadow:0 0 24px var(--gold-glow), inset 0 1px 0 rgba(255,255,255,.5);
  transition:transform .15s var(--ease);
}
.upsell-yes:hover { transform:translateY(-2px); }
.upsell-no {
  padding:12px; border-radius:var(--r-full);
  font-size:.88rem; font-weight:600; color:var(--ink-muted);
  border:1px solid var(--line); background:var(--panel-3);
  transition:.15s var(--ease);
}
.upsell-no:hover { color:var(--ink); border-color:var(--ink-faint); }

/* confirm */
.upsell.confirm { }
.confirm-check {
  width:64px; height:64px; margin:0 auto var(--sp-4);
  display:grid; place-items:center; border-radius:50%;
  color:var(--felt);
  background:linear-gradient(180deg,var(--green),#2bb56a);
  box-shadow:0 0 26px var(--green-glow);
}
.confirm-check svg { width:34px; height:34px; }
.confirm-extra { color:var(--green); font-weight:700; margin-bottom:var(--sp-3); }

/* ============================================================================
   JUNK DESTINATION GATE  (landfill vs Goodwill donation)  +  donation credit
   ============================================================================ */

/* green "save $35" tag inside the Goodwill gate chip */
.chip .chip-price.chip-save {
  color:var(--green);
  text-shadow:0 0 8px var(--green-glow);
  font-weight:800;
}

/* Goodwill reject-list panel — hidden until the donation option is picked */
.gw-note {
  display:none;
  font-size:.82rem; line-height:1.55; color:var(--ink);
  background:rgba(61,220,132,.06);
  border:1px solid rgba(61,220,132,.45);
  border-left:3px solid var(--green);
  border-radius:var(--r-md, 12px);
  padding:12px 15px; margin:var(--sp-3) 0 0; max-width:64ch;
}
.gw-note.show { display:block; }
.gw-note strong { color:var(--magenta); font-weight:800; }
.gw-note .gw-nolist {
  margin:8px 0 10px; padding-left:1.15em; list-style:none;
}
.gw-note .gw-nolist li {
  position:relative; padding:2px 0 2px 4px; color:var(--ink-muted);
}
.gw-note .gw-nolist li::before {
  content:"\00d7"; color:var(--magenta); font-weight:800;
  position:absolute; left:-0.95em; top:1px;
}
.gw-note .gw-yes {
  display:block; margin-top:8px; padding-top:8px;
  border-top:1px dashed rgba(61,220,132,.35);
  color:var(--green); font-weight:600;
}

/* donation credit line in the ticket breakdown */
.bd-line.is-credit .bd-name small {
  color:var(--green); font-weight:600;
}
.bd-val.bd-credit {
  color:var(--green); font-weight:800;
  text-shadow:0 0 8px var(--green-glow);
}

/* ============================================================================
   OPTIONS-QTY ROWS  (palm trimming: each height has its own quantity stepper)
   ============================================================================ */
.oq-rows { display:flex; flex-direction:column; gap:var(--sp-2); }
.oq-row {
  display:flex; align-items:center; gap:var(--sp-3);
  border:1px solid var(--line);
  background:var(--panel-3);
  border-radius:var(--r-md, 12px);
  padding:11px 14px;
  transition:.18s var(--ease);
}
.oq-row:hover { border-color:var(--gold-deep); }
.oq-info { display:flex; flex-direction:column; gap:3px; flex:1; min-width:0; }
.oq-label {
  display:flex; align-items:baseline; gap:8px;
  font-weight:700; color:var(--ink);
}
.oq-label .oq-price {
  margin-left:auto; font-family:var(--font-mono); font-size:.8rem;
  color:var(--gold); white-space:nowrap;
}
.oq-sub { font-size:.8rem; line-height:1.4; color:var(--ink-muted); }
.oq-row .qty { flex:none; }
@media (max-width:520px){
  .oq-label { flex-wrap:wrap; }
  .oq-label .oq-price { margin-left:0; }
}

/* =============================================================================
   LEAD CAPTURE — contact gate + verify panel
   ========================================================================== */
.gate-locked { overflow:hidden; }

.gate-overlay {
  position:fixed; inset:0; z-index:1000;
  display:flex; align-items:center; justify-content:center;
  padding:var(--sp-5);
  background:rgba(2,5,14,.82);
  backdrop-filter:blur(7px);
  opacity:0; transition:opacity .3s var(--ease);
}
.gate-overlay.in { opacity:1; }

.gate {
  position:relative;
  width:100%; max-width:430px;
  background:linear-gradient(180deg, var(--panel-2), var(--panel));
  border:1px solid var(--line);
  border-radius:var(--r-xl);
  padding:var(--sp-8) var(--sp-6) var(--sp-6);
  box-shadow:0 30px 80px rgba(0,0,0,.6), 0 0 0 1px rgba(115,225,255,.06) inset;
  transform:translateY(14px) scale(.98);
  transition:transform .35s var(--ease);
}
.gate-overlay.in .gate { transform:none; }

.gate-ribbon {
  display:inline-block;
  font-family:var(--font-subhead); font-weight:800; letter-spacing:.14em;
  font-size:.66rem; color:var(--cyan);
  text-transform:uppercase;
  padding:5px 12px; margin-bottom:var(--sp-4);
  border:1px solid var(--line); border-radius:var(--r-full);
  background:rgba(115,225,255,.05);
}
.gate-title {
  font-family:var(--font-display); font-size:1.9rem; line-height:1.05;
  color:#fff; margin:0 0 var(--sp-2);
  text-shadow:0 0 22px var(--gold-glow);
}
.gate-sub { color:var(--ink-muted); font-size:.9rem; line-height:1.5; margin:0 0 var(--sp-5); }

.gate-form { display:flex; flex-direction:column; gap:var(--sp-3); }
.gate-field { display:flex; flex-direction:column; gap:6px; }
.gate-field span {
  font-family:var(--font-subhead); font-weight:700; font-size:.74rem;
  letter-spacing:.06em; text-transform:uppercase; color:var(--ink-muted);
}
.gate-field input {
  width:100%; box-sizing:border-box;
  background:var(--felt-2); color:#fff;
  border:1px solid var(--line); border-radius:var(--r-md);
  padding:13px 14px; font-family:var(--font-body); font-size:1rem;
  transition:border-color .18s, box-shadow .18s;
}
.gate-field input::placeholder { color:var(--ink-faint); }
.gate-field input:focus {
  outline:none; border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(51,119,240,.22);
}
.gate-error {
  color:#ff7b8a; font-size:.84rem; font-weight:600;
  margin:2px 0 0; padding:8px 12px;
  background:rgba(255,90,110,.08); border:1px solid rgba(255,90,110,.25);
  border-radius:var(--r-sm);
}
.gate-go {
  margin-top:var(--sp-2);
  background:linear-gradient(180deg, var(--gold), var(--gold-deep));
  color:#fff; border:none; border-radius:var(--r-md);
  padding:15px; font-family:var(--font-subhead); font-weight:800;
  font-size:1rem; letter-spacing:.02em; cursor:pointer;
  box-shadow:0 8px 24px var(--gold-glow);
  transition:transform .18s var(--ease), box-shadow .18s;
}
.gate-go:hover:not(:disabled) { transform:translateY(-2px); box-shadow:0 12px 30px var(--gold-glow); }
.gate-go:disabled { opacity:.65; cursor:default; }
.gate-fine { color:var(--ink-faint); font-size:.74rem; text-align:center; margin:var(--sp-3) 0 0; line-height:1.45; }

/* ---- verify panel (reuses .upsell shell) ---- */
.upsell.verify .verify-quote {
  background:var(--felt-2); border:1px solid var(--line);
  border-radius:var(--r-md); padding:var(--sp-4);
  margin-bottom:var(--sp-4);
}
.verify-quote-total { display:flex; justify-content:space-between; align-items:baseline; }
.verify-quote-total span { color:var(--ink-muted); font-size:.82rem; font-family:var(--font-subhead); font-weight:700; letter-spacing:.06em; text-transform:uppercase; }
.verify-quote-total b { font-family:var(--font-display); font-size:1.7rem; color:#fff; text-shadow:0 0 16px var(--gold-glow); }
.verify-quote-svcs { color:var(--cyan); font-size:.86rem; margin-top:6px; font-weight:600; }
.verify-contact { display:flex; flex-direction:column; gap:7px; margin-bottom:var(--sp-4); }
.verify-row { display:flex; justify-content:space-between; align-items:center; font-size:.86rem; padding-bottom:6px; border-bottom:1px solid var(--line-soft); }
.verify-row span { color:var(--ink-faint); }
.verify-row b { color:#fff; font-weight:600; }
.verify-missing { color:var(--ink-muted); font-size:.84rem; font-style:italic; }
