/* styles.css — extracted from index.html for external + immutable cache.
   Edit here directly. CF Pages serves with Cache-Control: 30d immutable. */
/* ─── A11Y: Reduced motion. REMOVE animation, don't just speed it up. ───
     We kill CSS animations (duration 0.01ms + 1 iteration = effectively instant).
     JS-driven animations (typeBubble, confetti, OCR scanSweep) also check
     window.matchMedia('(prefers-reduced-motion: reduce)').matches and
     short-circuit — see the reduceMotion() helper in the inline script below. */
  @media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
      animation-duration: 0.01ms !important;
      animation-iteration-count: 1 !important;
      animation-delay: 0ms !important;
      transition-duration: 0.01ms !important;
      transition-delay: 0ms !important;
      scroll-behavior: auto !important;
    }
    html { scroll-behavior: auto !important; }
    .confetti, .confetti i { display: none !important; }
  }

  /* ─── A11Y: Skip-to-content link.
     First focusable element in <body>. Hidden by transform off-screen,
     slides in on :focus. Targets #main (the hero landmark). */
  .skip-link {
    position: fixed;
    top: 8px;
    left: 8px;
    z-index: 10000;
    padding: 10px 16px;
    background: #ff2d95;
    color: #0a0a0f;
    font-weight: 700;
    font-size: 0.92rem;
    border-radius: 10px;
    text-decoration: none;
    box-shadow: 0 8px 24px rgba(255, 45, 149, 0.5), 0 0 0 2px rgba(255, 255, 255, 0.15) inset;
    transform: translateY(-200%);
    transition: transform 0.18s cubic-bezier(.22,.61,.36,1);
    outline: none;
  }
  .skip-link:focus,
  .skip-link:focus-visible {
    transform: translateY(0);
    outline: 2px solid #ffffff;
    outline-offset: 3px;
  }
  @media (prefers-reduced-motion: reduce) {
    .skip-link { transition: none; }
  }

  *,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{
    --bg:       #0a0a0f;
    --bg-soft:  #121216;
    --bg-card:  #18181d;
    --line:     #26262c;
    --ink:      #f4f4f6;
    --ink-mute: #9aa0a8;
    --silver:   #b8bcc3;
    --accent:   #ff2d95;  /* price / savings green */
    --accent-dk:#cc1166;
    --amber:    #ff2d95;  /* CTA */
    --amber-dk: #cc1166;
    --rose:     #ef4444;  /* urgency */
    --radius:   14px;
    --radius-lg:24px;
    --shadow:   0 10px 40px rgba(0,0,0,.45);
    --shadow-lg:0 30px 80px rgba(0,0,0,.6);
    --ease:     cubic-bezier(.22,.61,.36,1);
  }
  html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
  body{
    font-family:-apple-system,BlinkMacSystemFont,"SF Pro Display","SF Pro Text","Helvetica Neue",Inter,system-ui,sans-serif;
    background:var(--bg);
    color:var(--ink);
    line-height:1.55;
    letter-spacing:-.01em;
    overflow-x:hidden;
  }
  a{color:inherit;text-decoration:none}
  img{max-width:100%;display:block}
  button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
  :focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:6px}

  /* NAV */
  nav{
    position:sticky;top:0;z-index:80;
    background:rgba(10,10,12,.82);
    backdrop-filter:blur(20px) saturate(1.2);
    -webkit-backdrop-filter:blur(20px) saturate(1.2);
    border-bottom:1px solid var(--line);
    display:flex;align-items:center;justify-content:space-between;
    padding:0 clamp(20px,5vw,60px);
    height:64px;
  }
  .logo{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:-.03em;font-size:1.08rem}
  .logo-mark{
    width:32px;height:32px;border-radius:9px;
    background:linear-gradient(135deg,#1f1f26,#0a0a0f);
    border:1px solid var(--line);
    display:grid;place-items:center;
    color:var(--accent);font-weight:700;font-size:.78rem;letter-spacing:0;
  }
  .logo .muted{color:var(--ink-mute);font-weight:500}
  .brand-luxury{color:#ff2d95;font-weight:700;letter-spacing:-0.01em}
  nav ul{display:flex;gap:28px;list-style:none}
  nav ul a{color:var(--silver);font-size:.88rem;font-weight:500;transition:color .18s}
  nav ul a:hover{color:var(--ink)}
  .nav-cta{
    display:inline-flex;align-items:center;gap:8px;
    background:var(--amber);color:#2a001a;font-weight:700;font-size:.88rem;
    padding:9px 18px;border-radius:100px;transition:transform .15s var(--ease), background .2s;
  }
  .nav-cta:hover{background:var(--amber-dk);transform:translateY(-1px)}
  @media(max-width:780px){nav ul{display:none}}

  /* HERO */
  .hero{
    position:relative;overflow:hidden;
    padding:clamp(70px,12vw,140px) clamp(20px,5vw,60px) clamp(80px,14vw,150px);
    text-align:center;
  }
  .hero::before{
    content:'';position:absolute;inset:-20% -20% auto -20%;height:120%;
    background:radial-gradient(ellipse 55% 50% at 50% 20%, rgba(255,45,149,.12), transparent 60%);
    pointer-events:none;
  }
  .hero::after{
    content:'';position:absolute;inset:0;
    background:radial-gradient(circle at 10% 110%, rgba(255,45,149,.08), transparent 50%);
    pointer-events:none;
  }
  .hero-badge{
    display:inline-flex;align-items:center;gap:8px;
    padding:7px 16px;border:1px solid rgba(255,45,149,.35);
    background:rgba(255,45,149,.08);color:var(--accent);
    border-radius:100px;font-size:.78rem;font-weight:600;
    letter-spacing:.5px;text-transform:uppercase;
    margin-bottom:26px;position:relative;z-index:2;
  }
  .hero-badge .dot{width:7px;height:7px;background:var(--accent);border-radius:50%;box-shadow:0 0 10px var(--accent)}
  .hero h1{
    font-size:clamp(2.4rem,6vw,4.5rem);
    font-weight:800;letter-spacing:-.035em;line-height:1.04;
    max-width:980px;margin:0 auto;position:relative;z-index:2;
  }
  .hero h1 em{font-style:normal;background:linear-gradient(135deg,var(--accent),#ff79c6);-webkit-background-clip:text;background-clip:text;color:transparent}
  .hero .kicker{
    font-size:clamp(1rem,1.5vw,1.2rem);
    color:var(--ink-mute);margin:26px auto 0;max-width:640px;position:relative;z-index:2;
  }
  .hero-cta{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:42px;position:relative;z-index:2}
  .btn-primary{
    background:var(--amber);color:#2a001a;font-weight:700;
    padding:15px 30px;border-radius:100px;font-size:.98rem;
    transition:transform .15s var(--ease), background .2s, box-shadow .2s;
    box-shadow:0 10px 30px rgba(255,45,149,.25);
  }
  .btn-primary:hover{background:var(--amber-dk);transform:translateY(-2px);box-shadow:0 14px 40px rgba(255,45,149,.35)}
  .btn-ghost{
    background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.14);
    color:var(--ink);font-weight:600;padding:14px 28px;border-radius:100px;font-size:.95rem;
    transition:background .2s, border-color .2s;
  }
  .btn-ghost:hover{background:rgba(255,255,255,.09);border-color:rgba(255,255,255,.24)}

  /* hero hardware render — pure CSS MacBook silhouette */
  .hero-hardware{
    max-width:780px;margin:70px auto 0;position:relative;z-index:2;
    filter:drop-shadow(0 60px 60px rgba(0,0,0,.6));
    perspective:1800px;
  }
  .mb{
    aspect-ratio:16/10;background:linear-gradient(160deg,#2a2a33,#0f0f14 55%);
    border-radius:14px 14px 4px 4px;border:1px solid var(--line);
    transform:rotateX(14deg);transform-origin:50% 100%;
    position:relative;box-shadow:inset 0 0 0 1px rgba(255,255,255,.03);
  }
  .mb::before{
    content:'';position:absolute;inset:10px;border-radius:8px 8px 2px 2px;
    background:
      radial-gradient(ellipse 50% 30% at 50% 0%, rgba(255,255,255,.05), transparent 70%),
      linear-gradient(180deg,#0a0a0f,#14141a);
    border:1px solid #000;
  }
  .mb::after{
    content:'';position:absolute;top:10px;left:50%;transform:translateX(-50%);
    width:70px;height:8px;background:#000;border-radius:0 0 10px 10px;
    border-left:1px solid #25252b;border-right:1px solid #25252b;
  }
  .mb-base{
    height:14px;margin-top:-2px;
    background:linear-gradient(180deg,#2a2a33 0%,#1a1a20 40%,#0a0a0f 100%);
    border-radius:0 0 20px 20px;box-shadow:0 20px 50px rgba(0,0,0,.7);
    position:relative;
  }
  .mb-base::before{
    content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
    width:22%;height:4px;background:#050508;border-radius:0 0 6px 6px;
  }
  .hero-reel{
    position:absolute;inset:10px;width:calc(100% - 20px);height:calc(100% - 20px);
    border-radius:8px 8px 2px 2px;object-fit:cover;display:block;z-index:1;
    background:#000;border:1px solid #000;pointer-events:none;
  }

  .trust-bar{
    display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(16px,3vw,40px);
    margin:60px auto 0;padding-top:40px;
    border-top:1px solid var(--line);max-width:900px;
    position:relative;z-index:2;
  }
  .trust-item{display:flex;align-items:center;gap:8px;color:var(--silver);font-size:.85rem}
  .trust-item .ti-ic{font-size:1rem;color:var(--accent)}

  /* SECTIONS */
  section{padding:clamp(70px,9vw,110px) clamp(20px,5vw,60px);position:relative}
  .wrap{max-width:1240px;margin:0 auto}
  .section-head{max-width:760px;margin:0 auto clamp(40px,6vw,64px);text-align:center}
  .eyebrow{
    display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.18em;
    text-transform:uppercase;color:var(--accent);margin-bottom:14px;
  }
  .section-head h2{
    font-size:clamp(1.85rem,3.5vw,2.8rem);font-weight:800;
    letter-spacing:-.03em;line-height:1.1;margin-bottom:16px;
  }
  .section-head p{color:var(--ink-mute);font-size:1.05rem;max-width:640px;margin:0 auto}

  /* PILLARS */
  .pillars-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:22px}
  .pillar{
    background:linear-gradient(180deg,var(--bg-card),var(--bg-soft));
    border:1px solid var(--line);border-radius:var(--radius-lg);
    padding:36px 32px;transition:transform .3s var(--ease),border-color .3s;
    position:relative;overflow:hidden;
  }
  .pillar:hover{transform:translateY(-4px);border-color:rgba(255,45,149,.4)}
  .pillar::before{
    content:'';position:absolute;inset:auto -40% -40% auto;width:220px;height:220px;
    background:radial-gradient(circle,rgba(255,45,149,.1),transparent 60%);
    opacity:0;transition:opacity .3s;
  }
  .pillar:hover::before{opacity:1}
  .pillar-num{
    font-family:"SF Mono",ui-monospace,monospace;
    font-size:.78rem;color:var(--silver);letter-spacing:.15em;margin-bottom:18px;
  }
  .pillar h3{font-size:1.45rem;font-weight:700;letter-spacing:-.02em;margin-bottom:12px}
  .pillar p{color:var(--ink-mute);font-size:.98rem;line-height:1.6}
  .pillar .proof{
    margin-top:20px;padding-top:18px;border-top:1px solid var(--line);
    font-size:.83rem;color:var(--silver);
  }
  .pillar .proof b{color:var(--accent);font-weight:600}

  /* INVENTORY */
  #shop{background:var(--bg-soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
  .price-toggle{
    display:inline-flex;background:var(--bg);border:1px solid var(--line);
    border-radius:100px;padding:4px;margin:0 auto 36px;
  }
  .price-toggle button{
    padding:9px 20px;border-radius:100px;font-size:.85rem;font-weight:600;
    color:var(--ink-mute);transition:all .2s var(--ease);
  }
  .price-toggle button.active{background:var(--accent);color:#2a001a;box-shadow:0 4px 12px rgba(255,45,149,.3)}
  .price-toggle .lbl{display:block;text-align:center;margin-bottom:10px;color:var(--ink-mute);font-size:.8rem}

  .inv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:22px}
  .card{
    background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius-lg);
    overflow:hidden;transition:transform .3s var(--ease),border-color .3s,box-shadow .3s;
    position:relative;display:flex;flex-direction:column;
  }
  .card:hover{transform:translateY(-4px);border-color:rgba(255,45,149,.4);box-shadow:var(--shadow)}
  .card-img{
    aspect-ratio:4/3;background:linear-gradient(145deg,#1e1e25,#0a0a0f);
    display:grid;place-items:center;overflow:hidden;border-bottom:1px solid var(--line);
    position:relative;
  }
  .card-img img{max-width:80%;max-height:80%;object-fit:contain;filter:drop-shadow(0 10px 30px rgba(0,0,0,.5))}
  .card-img .cond{
    position:absolute;top:12px;left:12px;
    background:rgba(10,10,12,.8);backdrop-filter:blur(10px);
    padding:5px 11px;border-radius:100px;font-size:.68rem;
    font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--silver);
    border:1px solid var(--line);
  }
  .card-body{padding:22px 22px 24px;display:flex;flex-direction:column;gap:6px;flex:1}
  .card-tag{font-size:.72rem;color:var(--accent);font-weight:600;letter-spacing:.1em;text-transform:uppercase}
  .card h3{font-size:1.15rem;font-weight:700;letter-spacing:-.02em;margin-top:2px}
  .card .tagline{color:var(--ink-mute);font-size:.88rem;margin-bottom:10px;min-height:1.55em}
  .card-price-row{display:flex;align-items:baseline;justify-content:space-between;margin-top:auto;padding-top:12px}
  .card-price{font-size:1.75rem;font-weight:800;letter-spacing:-.035em;color:var(--ink)}
  .card-price .cur{font-size:1.1rem;font-weight:600;color:var(--silver);margin-right:2px;vertical-align:.25em}
  .card-strike{color:var(--ink-mute);font-size:.82rem;text-decoration:line-through}
  .card-save{color:var(--accent);font-size:.82rem;font-weight:600}
  .card-btn{
    margin-top:14px;width:100%;padding:12px;
    background:var(--amber);color:#2a001a;font-weight:700;font-size:.92rem;
    border-radius:10px;transition:background .2s,transform .15s var(--ease);
  }
  .card-btn:hover{background:var(--amber-dk);transform:translateY(-1px)}

  .skeleton{background:linear-gradient(90deg,var(--bg-card) 0%, var(--bg-soft) 50%, var(--bg-card) 100%);background-size:200% 100%;animation:sk 1.4s ease-in-out infinite}
  @keyframes sk{0%{background-position:200% 0}100%{background-position:-200% 0}}

  /* WARRANTY DIAGRAM */
  #warranty{padding-top:clamp(90px,11vw,130px)}
  .warranty-wrap{
    display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(30px,5vw,70px);
    align-items:center;max-width:1240px;margin:0 auto;
  }
  @media(max-width:900px){.warranty-wrap{grid-template-columns:1fr}}
  .warranty-diagram{
    position:relative;background:linear-gradient(160deg,var(--bg-card),var(--bg));
    border:1px solid var(--line);border-radius:var(--radius-lg);
    padding:36px;overflow:hidden;
  }
  .warranty-svg{width:100%;height:auto;max-height:520px}
  .warranty-photo{position:relative;width:100%}
  .warranty-photo img{width:100%;height:auto;display:block;filter:drop-shadow(0 20px 40px rgba(255,45,149,.15))}
  .warranty-dots{position:absolute;inset:0;pointer-events:none}
  .warranty-dots .wd{
    position:absolute;width:14px;height:14px;border-radius:50%;
    background:var(--accent);box-shadow:0 0 0 4px rgba(255,45,149,.25), 0 0 14px rgba(255,45,149,.6);
    transform:translate(-50%,-50%);pointer-events:auto;cursor:pointer;
    animation:dotPulse 2.4s ease-in-out infinite;
  }
  @keyframes dotPulse{0%,100%{box-shadow:0 0 0 4px rgba(255,45,149,.25), 0 0 14px rgba(255,45,149,.6)}50%{box-shadow:0 0 0 8px rgba(255,45,149,.15), 0 0 24px rgba(255,45,149,.8)}}
  .warranty-dots .wd:hover{background:var(--ink);transform:translate(-50%,-50%) scale(1.3)}
  .warranty-copy h3{font-size:clamp(1.5rem,2.6vw,2.1rem);font-weight:800;letter-spacing:-.025em;line-height:1.15;margin-bottom:18px}
  .warranty-copy p{color:var(--ink-mute);font-size:1rem;margin-bottom:14px}
  .parts-list{display:flex;flex-direction:column;gap:10px;margin-top:24px}
  .part-row{
    display:flex;justify-content:space-between;align-items:center;
    padding:12px 16px;background:var(--bg-card);
    border:1px solid var(--line);border-radius:10px;
    transition:border-color .2s;
  }
  .part-row:hover{border-color:rgba(255,45,149,.4)}
  .part-name{display:flex;align-items:center;gap:10px;font-weight:500;font-size:.95rem}
  .part-dot{width:9px;height:9px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px rgba(255,45,149,.5)}
  .part-price{font-family:"SF Mono",ui-monospace,monospace;font-size:.88rem;color:var(--ink-mute)}
  .part-price b{color:var(--accent);font-weight:600}
  .warranty-total{
    margin-top:20px;padding:20px 22px;
    background:linear-gradient(135deg,rgba(255,45,149,.12),rgba(255,45,149,.04));
    border:1px solid rgba(255,45,149,.3);border-radius:var(--radius);
    display:flex;justify-content:space-between;align-items:center;
  }
  .warranty-total .lbl{font-size:.85rem;color:var(--silver);text-transform:uppercase;letter-spacing:.1em}
  .warranty-total .val{font-size:1.6rem;font-weight:800;color:var(--accent);letter-spacing:-.02em}

  .part-row.active{border-color:var(--accent);background:rgba(255,45,149,.06)}

  /* CORE EXPLAINER */
  #core{background:var(--bg-soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
  .core-split{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:36px}
  @media(max-width:720px){.core-split{grid-template-columns:1fr}}
  .core-card{
    position:relative;padding:36px 32px;border-radius:var(--radius-lg);
    background:var(--bg-card);border:1px solid var(--line);
  }
  .core-card.featured{
    background:linear-gradient(160deg,rgba(255,45,149,.08),var(--bg-card));
    border-color:rgba(255,45,149,.35);
  }
  .core-card.featured::before{
    content:'This is the sticker price';
    position:absolute;top:-12px;left:32px;
    padding:4px 12px;background:var(--accent);color:#2a001a;
    border-radius:100px;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  }
  .core-card h4{font-size:1.2rem;font-weight:700;margin-bottom:8px}
  .core-card .subtitle{color:var(--ink-mute);font-size:.95rem;margin-bottom:20px}
  .core-example{
    font-family:"SF Mono",ui-monospace,monospace;font-size:.82rem;
    padding:16px 18px;background:var(--bg);border-radius:10px;border:1px solid var(--line);
    line-height:1.8;
  }
  .core-example .k{color:var(--silver)}
  .core-example .v{color:var(--ink);font-weight:600}
  .core-example .p{color:var(--accent);font-weight:700}
  .core-example .m{color:var(--ink-mute);text-decoration:line-through}

  /* HOW */
  .steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;counter-reset:step}
  .step{
    position:relative;padding:32px 28px;background:var(--bg-card);
    border:1px solid var(--line);border-radius:var(--radius-lg);
  }
  .step::before{
    counter-increment:step;content:counter(step,decimal-leading-zero);
    font-family:"SF Mono",ui-monospace,monospace;font-size:.78rem;color:var(--accent);
    display:block;margin-bottom:16px;letter-spacing:.2em;
  }
  .step h4{font-size:1.1rem;font-weight:700;margin-bottom:8px;letter-spacing:-.015em}
  .step p{color:var(--ink-mute);font-size:.93rem}

  /* FAQ */
  .faq{max-width:840px;margin:0 auto}
  .faq-item{
    border-bottom:1px solid var(--line);padding:22px 0;
    transition:border-color .2s;
  }
  .faq-item summary{
    list-style:none;cursor:pointer;
    display:flex;align-items:center;justify-content:space-between;
    font-size:1.05rem;font-weight:600;letter-spacing:-.01em;
  }
  .faq-item summary::-webkit-details-marker{display:none}
  .faq-item summary::after{
    content:'+';font-size:1.4rem;color:var(--silver);
    transition:transform .25s var(--ease), color .2s;line-height:1;
  }
  .faq-item[open] summary::after{transform:rotate(45deg);color:var(--accent)}
  .faq-item p{color:var(--ink-mute);margin-top:14px;font-size:.96rem;line-height:1.7}

  /* TESTIMONIALS */
  #testimonials{padding:clamp(70px,10vw,110px) clamp(20px,5vw,60px)}
  .tm-grid{
    display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
    gap:20px;max-width:1200px;margin:36px auto 0;
  }
  .tm-card{
    background:var(--bg-card);border:1px solid var(--line);
    border-radius:var(--radius);padding:26px 24px;
    display:flex;flex-direction:column;gap:14px;
    transition:transform .2s var(--ease), border-color .2s;
    position:relative;
  }
  .tm-card:hover{transform:translateY(-3px);border-color:rgba(255,45,149,.4)}
  .tm-stars{color:var(--accent);font-size:1rem;letter-spacing:2px;line-height:1}
  .tm-quote{
    color:var(--ink);font-size:.96rem;line-height:1.6;letter-spacing:-.005em;
    font-style:normal;margin:0;
  }
  .tm-quote::before{content:'"';color:rgba(255,45,149,.4);font-size:2rem;line-height:0;vertical-align:-.4em;margin-right:3px}
  .tm-quote::after{content:'"';color:rgba(255,45,149,.4);font-size:2rem;line-height:0;vertical-align:-.4em;margin-left:2px}
  .tm-meta{
    display:flex;align-items:center;gap:12px;
    padding-top:14px;border-top:1px solid var(--line);margin-top:auto;
  }
  .tm-ava{
    width:38px;height:38px;border-radius:50%;
    background:linear-gradient(135deg,rgba(255,45,149,.3),rgba(255,45,149,.08));
    border:1px solid rgba(255,45,149,.4);
    display:grid;place-items:center;
    font-weight:700;color:var(--accent);font-size:.88rem;flex-shrink:0;
  }
  .tm-who{display:flex;flex-direction:column;min-width:0}
  .tm-who .nm{color:var(--ink);font-weight:600;font-size:.93rem;letter-spacing:-.01em}
  .tm-who .ct{color:var(--ink-mute);font-size:.78rem;margin-top:2px}
  .tm-machine{
    display:inline-block;font-size:.72rem;color:var(--silver);
    background:var(--bg-soft);border:1px solid var(--line);
    padding:3px 10px;border-radius:100px;letter-spacing:.02em;
    margin-left:auto;flex-shrink:0;
  }
  @media(max-width:500px){
    .tm-machine{margin-left:0;margin-top:4px}
    .tm-meta{flex-wrap:wrap}
  }

  /* CTA */
  .cta{
    background:linear-gradient(135deg,rgba(255,45,149,.12),rgba(255,45,149,.06));
    border:1px solid rgba(255,45,149,.3);border-radius:var(--radius-lg);
    padding:clamp(40px,6vw,68px);text-align:center;max-width:1000px;margin:0 auto;
    position:relative;overflow:hidden;
  }
  .cta::before{
    content:'';position:absolute;inset:0;
    background:radial-gradient(circle at 50% 0%, rgba(255,45,149,.1), transparent 60%);
    pointer-events:none;
  }
  .cta h3{font-size:clamp(1.6rem,3vw,2.3rem);font-weight:800;letter-spacing:-.025em;margin-bottom:14px;position:relative}
  .cta p{color:var(--ink-mute);margin-bottom:28px;max-width:560px;margin-left:auto;margin-right:auto;position:relative}
  .cta .btn-primary{position:relative}

  /* CONTACT form */
  #contact{padding-bottom:clamp(80px,11vw,120px)}
  .lead-form{
    max-width:640px;margin:36px auto 0;
    background:var(--bg-card);border:1px solid var(--line);
    border-radius:var(--radius-lg);padding:36px;
  }
  .lead-form label{display:block;font-size:.82rem;font-weight:600;color:var(--silver);margin-bottom:6px;letter-spacing:.04em;text-transform:uppercase}
  .lead-form input, .lead-form textarea, .lead-form select{
    width:100%;padding:13px 16px;margin-bottom:16px;
    background:var(--bg);color:var(--ink);
    border:1px solid var(--line);border-radius:10px;
    font:inherit;transition:border-color .2s;
  }
  .lead-form input:focus, .lead-form textarea:focus, .lead-form select:focus{
    outline:none;border-color:var(--accent);
  }
  .lead-form textarea{min-height:110px;resize:vertical}
  .lead-form button{
    width:100%;padding:15px;background:var(--amber);color:#2a001a;font-weight:700;
    border-radius:10px;font-size:1rem;transition:background .2s,transform .15s var(--ease);
  }
  .lead-form button:hover{background:var(--amber-dk);transform:translateY(-1px)}
  .form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
  @media(max-width:520px){.form-row{grid-template-columns:1fr}}
  .form-status{padding:14px 16px;border-radius:10px;margin-top:14px;font-size:.9rem;display:none}
  .form-status.ok{background:rgba(255,45,149,.1);color:var(--accent);border:1px solid rgba(255,45,149,.3);display:block}
  .form-status.err{background:rgba(239,68,68,.1);color:var(--rose);border:1px solid rgba(239,68,68,.3);display:block}

  /* FOOTER */
  footer{border-top:1px solid var(--line);padding:40px clamp(20px,5vw,60px);text-align:center;color:var(--ink-mute);font-size:.85rem}
  footer a{color:var(--silver);margin:0 10px}

  /* CHAT WIDGET */
  .chat-fab{
    position:fixed;bottom:24px;right:24px;z-index:100;
    display:flex;align-items:center;gap:10px;
    padding:14px 22px;
    background:linear-gradient(135deg,var(--accent),var(--accent-dk));
    color:#2a001a;font-weight:700;border-radius:100px;
    box-shadow:0 15px 40px rgba(255,45,149,.4), 0 0 0 0 rgba(255,45,149,.7);
    cursor:pointer;transition:transform .2s var(--ease);
    animation:pulse 2.4s infinite;
  }
  .chat-fab:hover{transform:translateY(-2px)}
  .chat-fab.hidden{display:none}
  .chat-fab .av{
    width:30px;height:30px;border-radius:50%;background:#2a001a;color:var(--accent);
    display:grid;place-items:center;font-weight:800;font-size:.82rem;
  }
  @keyframes pulse{
    0%{box-shadow:0 15px 40px rgba(255,45,149,.4), 0 0 0 0 rgba(255,45,149,.5)}
    70%{box-shadow:0 15px 40px rgba(255,45,149,.4), 0 0 0 18px rgba(255,45,149,0)}
    100%{box-shadow:0 15px 40px rgba(255,45,149,.4), 0 0 0 0 rgba(255,45,149,0)}
  }

  .chat-panel{
    position:fixed;bottom:24px;right:24px;z-index:100;
    width:min(460px, calc(100vw - 48px));
    height:min(680px, calc(100vh - 100px));
    background:var(--bg-card);border:1px solid var(--line);
    border-radius:20px;box-shadow:var(--shadow-lg);
    display:none;flex-direction:column;overflow:hidden;
  }
  .chat-panel.open{display:flex;animation:slideUp .3s var(--ease)}
  @keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
  .chat-header{
    padding:16px 20px;background:linear-gradient(135deg,var(--accent),var(--accent-dk));
    color:#2a001a;display:flex;align-items:center;justify-content:space-between;
  }
  .chat-header .who{display:flex;align-items:center;gap:10px}
  .chat-header .ava{width:36px;height:36px;border-radius:50%;background:#2a001a;color:var(--accent);display:grid;place-items:center;font-weight:800}
  .chat-header .name{font-weight:700;line-height:1.1}
  .chat-header .sub{font-size:.72rem;opacity:.75}
  .chat-close{background:rgba(0,0,0,.15);color:#2a001a;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-size:1.2rem;line-height:1}
  .chat-close:hover{background:rgba(0,0,0,.25)}
  .chat-body{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:10px}
  .msg{max-width:85%;padding:10px 14px;border-radius:16px;font-size:.93rem;line-height:1.5;word-wrap:break-word;flex:0 0 auto}
  .msg.user{align-self:flex-end;background:var(--accent);color:#2a001a;border-bottom-right-radius:4px}
  .msg.rick{align-self:flex-start;background:var(--bg-soft);color:var(--ink);border:1px solid var(--line);border-bottom-left-radius:4px}
  .msg.typing{color:var(--ink-mute);font-style:italic}
  .msg.typing::after{content:'...';display:inline-block;animation:dots 1.4s infinite}
  @keyframes dots{0%,20%{content:'.'}40%{content:'..'}60%,100%{content:'...'}}
  .chat-input{
    padding:14px 16px;background:var(--bg);border-top:1px solid var(--line);
    display:flex;gap:10px;align-items:flex-end;
  }
  .chat-input textarea{
    flex:1;padding:10px 14px;background:var(--bg-card);color:var(--ink);
    border:1px solid var(--line);border-radius:20px;resize:none;
    font:inherit;font-size:.93rem;max-height:120px;min-height:40px;
  }
  .chat-input textarea:focus{outline:none;border-color:var(--accent)}
  .chat-send{
    width:40px;height:40px;border-radius:50%;
    background:var(--accent);color:#2a001a;display:grid;place-items:center;
    transition:background .2s;flex-shrink:0;
  }
  .chat-send:hover{background:var(--accent-dk)}
  .chat-send:disabled{opacity:.5;cursor:not-allowed}
  /* Static quick-prompts row hidden — the welcome cards above + dynamic predict
     pills below now cover the same intent. Keep the markup for backwards-compat
     in case any handler still references it. */
  .quick-prompts{display:none !important}
  .quick-prompt{
    padding:6px 12px;background:var(--bg-soft);border:1px solid var(--line);
    color:var(--silver);font-size:.78rem;border-radius:100px;transition:all .2s;
  }
  .quick-prompt:hover{border-color:var(--accent);color:var(--accent)}

  /* ─── MOBILE: Rick-as-narrator — chat lives at bottom, page visible above ─── */
  @media(max-width:780px){
    nav{padding:0 16px;height:56px}
    nav .logo{font-size:.98rem}
    nav ul{display:none}
    .nav-cta{padding:7px 14px;font-size:.82rem}

    .hero{padding:46px 18px 50px}
    .hero h1{font-size:clamp(1.9rem,8.5vw,2.6rem)}
    .hero .kicker{font-size:.95rem}
    .hero-hardware{margin-top:36px;max-width:100%}
    .trust-bar{margin:36px auto 0;padding-top:24px;gap:14px;font-size:.78rem}

    section{padding:54px 18px}

    .pillars-grid{gap:14px}
    .pillar{padding:24px 22px}
    .pillar h3{font-size:1.25rem}

    #shop .section-head{margin-bottom:24px}
    .inv-grid{grid-template-columns:repeat(2,1fr);gap:12px}
    .card-body{padding:14px 14px 18px}
    .card h3{font-size:.95rem}
    .card-tag{font-size:.64rem}
    .card .tagline{font-size:.78rem;min-height:2.2em}
    .card-price{font-size:1.3rem}
    .card-btn{padding:10px;font-size:.82rem}
    .card-img{aspect-ratio:16/11}

    .picks-grid{grid-template-columns:1fr;gap:16px}
    .pick-body{padding:20px}

    .price-toggle{padding:3px}
    .price-toggle button{padding:7px 12px;font-size:.78rem}
    .family-toggle{overflow-x:auto;flex-wrap:nowrap;justify-content:flex-start;max-width:100%;padding:3px 4px}
    .family-toggle button{white-space:nowrap;padding:7px 14px;font-size:.76rem}

    .warranty-wrap{grid-template-columns:1fr;gap:26px}
    .warranty-copy h3{font-size:1.5rem}

    .core-split{grid-template-columns:1fr;gap:14px}
    .core-card{padding:24px 20px}

    .faq{max-width:100%}
    .faq-item summary{font-size:.95rem}

    .cta{padding:36px 22px}
    .cta h3{font-size:1.5rem}

    #contact .lead-form{padding:24px;margin:20px 12px 0}
    .form-row{grid-template-columns:1fr}

    footer{padding:28px 18px;font-size:.78rem}
  }

  /* ═══════════════════════════════════════════════════════════════════════
     CHAT-TAKEOVER MODE — premium mobile chat = the entire site
     Design goals: iOS Messages quality, 16px body text, safe-area aware,
     proper breathing room, premium header with whispers, predictive next button.
     ═══════════════════════════════════════════════════════════════════════ */
  /* FOCUSED HAND-OFF — set when customer lands from a "Lock it in" button.
     Hides every shortcut / pick-3 card / welcome widget so they can't
     drift off the lock-in close. Only the seed bubble + Rick's reply
     stream remain visible. */
  body.focused-handoff #quick,
  body.focused-handoff .rick-inline-widget,
  body.focused-handoff .welcome-card-btn,
  body.focused-handoff .pred-pill,
  body.focused-handoff .whisper{display:none !important}

  body.chat-takeover{
    overflow:hidden;
    height:100dvh; height:-webkit-fill-available;
  }
  body.chat-takeover > nav,
  body.chat-takeover > .personal-banner,
  body.chat-takeover > header.hero,
  body.chat-takeover > section,
  body.chat-takeover > footer,
  body.chat-takeover > .chat-fab{display:none !important}

  body.chat-takeover .chat-panel{
    position:fixed !important;inset:0 !important;
    width:100vw !important;height:100dvh !important;max-width:100vw !important;
    max-height:none !important;border-radius:0 !important;border:none !important;
    display:flex !important;flex-direction:column;
    background:var(--bg);
    padding-top:env(safe-area-inset-top);
    padding-bottom:env(safe-area-inset-bottom);
  }
  body.chat-takeover .chat-panel .drag-handle{display:none}
  body.chat-takeover .personal-note{display:none !important}
  body.chat-takeover .trade-total-pill{
    /* In takeover mode the pill sits in the flex column between chat-body and
       predict-bar — no fixed positioning needed. Keep a slightly tighter pad. */
    margin:6px 14px 0;padding:9px 16px;font-size:.84rem;
  }

  /* ─── Premium chat header (takeover) ─── */
  body.chat-takeover .chat-header{
    position:relative;flex-shrink:0;
    background:linear-gradient(180deg, rgba(255,45,149,.96), rgba(204,17,102,.96));
    padding:14px 18px 12px;
    display:flex;align-items:center;gap:12px;
    box-shadow:0 4px 20px rgba(255,45,149,.25), 0 1px 0 rgba(0,0,0,.35);
    z-index:3;
  }
  body.chat-takeover .chat-header .who{flex:1;min-width:0;gap:12px}
  body.chat-takeover .chat-header .ava{
    width:42px;height:42px;flex-shrink:0;
    background:#fff;color:var(--accent);font-size:1.05rem;font-weight:800;
    box-shadow:0 6px 20px rgba(0,0,0,.4), 0 0 0 3px rgba(255,255,255,.18);
    position:relative;
  }
  body.chat-takeover .chat-header .ava::after{
    content:'';position:absolute;right:-1px;bottom:-1px;
    width:12px;height:12px;border-radius:50%;
    background:#22c55e;border:2.5px solid #cc1166;
  }
  body.chat-takeover .chat-header .name{font-size:1.05rem;letter-spacing:-.015em;color:#fff}
  body.chat-takeover .chat-header .sub{font-size:.76rem;opacity:.92;color:#fff;margin-top:1px;font-weight:500}
  body.chat-takeover .chat-close{
    background:rgba(255,255,255,.18);color:#fff;width:36px;height:36px;
    font-size:1.3rem;border-radius:50%;
  }
  body.chat-takeover .chat-close:hover{background:rgba(255,255,255,.28)}

  /* ─── Whisper bar (ear-whispers under header) ─── */
  .rick-whisper{
    flex-shrink:0;position:relative;
    background:rgba(255,45,149,.06);
    border-bottom:1px solid rgba(255,45,149,.18);
    padding:9px 18px;min-height:34px;
    display:flex;align-items:center;gap:9px;
    font-size:.82rem;color:var(--ink);
    overflow:hidden;
  }
  .rick-whisper:empty{display:none}
  .rick-whisper .wisp-ico{
    flex-shrink:0;width:18px;height:18px;border-radius:50%;
    background:linear-gradient(135deg,var(--accent),var(--accent-dk));color:#fff;
    display:grid;place-items:center;font-size:.7rem;font-weight:800;
    box-shadow:0 0 10px rgba(255,45,149,.6);
  }
  .rick-whisper .wisp-text{
    flex:1 1 0;min-width:0;
    overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
    animation:wispIn .35s var(--ease);
    font-style:italic;letter-spacing:.005em;
  }
  @keyframes wispIn{from{transform:translateY(-6px);opacity:0}to{transform:translateY(0);opacity:1}}
  .rick-whisper.changing .wisp-text{animation:wispOut .25s ease forwards}
  @keyframes wispOut{to{transform:translateY(-6px);opacity:0}}

  /* ─── Chat body (scroll area) with premium spacing ─── */
  body.chat-takeover .chat-body{
    flex:1 1 auto;overflow-y:auto;overscroll-behavior:contain;
    padding:18px 16px 12px;gap:14px;
    -webkit-overflow-scrolling:touch;
    scroll-behavior:smooth;
  }
  body.chat-takeover .chat-body .msg{
    font-size:15.5px;line-height:1.5;padding:12px 16px;border-radius:20px;
    max-width:86%;letter-spacing:-.005em;
  }
  body.chat-takeover .chat-body .msg.rick{
    background:var(--bg-card);border:1px solid var(--line);
    border-bottom-left-radius:6px;color:var(--ink);
  }
  body.chat-takeover .chat-body .msg.user{
    background:linear-gradient(135deg,var(--accent),var(--accent-dk));
    color:#fff;border-bottom-right-radius:6px;font-weight:500;
    box-shadow:0 4px 14px rgba(255,45,149,.3);
  }

  /* Rich chat widgets get more polish on takeover */
  body.chat-takeover .rick-inline-widget{border-radius:18px}
  body.chat-takeover .riw-header{padding:16px 20px}
  body.chat-takeover .riw-body{padding:18px 20px}
  body.chat-takeover .riw-eyebrow{font-size:.7rem}
  body.chat-takeover .riw-title{font-size:1.12rem;line-height:1.3}

  body.chat-takeover .rick-card{border-radius:18px}
  body.chat-takeover .rick-card .rc-body{padding:18px 20px}
  body.chat-takeover .rick-card .rc-title{font-size:1.08rem}

  body.chat-takeover .tour-chapter{max-width:94%;padding:18px 20px}
  body.chat-takeover .tour-chapter .title{font-size:1.12rem}

  /* ─── Predictive next-action pill (above input) ─── */
  .predict-bar{
    flex-shrink:0;position:relative;
    padding:8px 14px 2px;background:transparent;
    display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;
    -webkit-overflow-scrolling:touch;
  }
  .predict-bar::-webkit-scrollbar{display:none}
  .predict-bar:empty{display:none}
  .predict-bar .predict-pill{
    flex-shrink:0;display:inline-flex;align-items:center;gap:7px;
    padding:10px 16px;border-radius:100px;
    background:rgba(255,45,149,.12);border:1px solid rgba(255,45,149,.45);
    color:var(--accent);font-size:.86rem;font-weight:600;letter-spacing:-.005em;
    cursor:pointer;white-space:nowrap;
    transition:all .18s var(--ease);
    animation:predictIn .3s var(--ease);
  }
  @keyframes predictIn{from{transform:translateY(6px);opacity:0}to{transform:translateY(0);opacity:1}}
  .predict-bar .predict-pill:hover{background:rgba(255,45,149,.22);transform:translateY(-1px)}
  .predict-bar .predict-pill::before{content:'→';opacity:.75;font-weight:800}
  .predict-bar .predict-pill.primary{
    background:linear-gradient(135deg,var(--accent),var(--accent-dk));color:#fff;
    border-color:transparent;box-shadow:0 6px 18px rgba(255,45,149,.45);
  }
  .predict-bar .predict-pill.primary::before{content:'✦';color:rgba(255,255,255,.9)}

  /* Soft-no / graceful-exit pill — V10: customer needs permission to say no
     so they don't bounce. Visually subdued (no pink), still tappable. */
  .predict-bar .predict-pill.exit{
    background:rgba(255,255,255,.04);
    border-color:rgba(255,255,255,.18);
    color:var(--ink-mute);
    margin-left:6px;
  }
  .predict-bar .predict-pill.exit:hover{
    background:rgba(255,255,255,.08);
    color:var(--ink);
  }
  .predict-bar .predict-pill.exit::before{content:'×';opacity:.55;font-weight:700}

  /* Smooth horizontal scroll snapping for the 10-pill row */
  .predict-bar{scroll-snap-type:x proximity;scroll-padding-left:14px}
  .predict-bar .predict-pill{scroll-snap-align:start}

  /* ─── Premium input bar (takeover) ─── */
  body.chat-takeover .chat-input{
    flex-shrink:0;padding:10px 14px calc(14px + env(safe-area-inset-bottom));
    gap:10px;align-items:center;
    background:var(--bg);border-top:1px solid var(--line);
  }
  body.chat-takeover .chat-input textarea{
    min-height:44px;max-height:130px;
    padding:12px 18px;font-size:16px;border-radius:22px;
    background:var(--bg-card);border:1px solid var(--line);
    transition:border-color .2s;
  }
  body.chat-takeover .chat-input textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(255,45,149,.18)}
  body.chat-takeover .chat-send{
    width:44px;height:44px;font-size:1.2rem;
    background:linear-gradient(135deg,var(--accent),var(--accent-dk));color:#fff;
    box-shadow:0 6px 18px rgba(255,45,149,.4);
    transition:transform .15s;
  }
  body.chat-takeover .chat-send:hover{transform:scale(1.06)}

  /* Quick prompts — hide in takeover, we use welcome widget instead */
  body.chat-takeover .quick-prompts{display:none}

  /* ─── Menu button in chat header ─── */
  .chat-menu-btn{
    background:rgba(255,255,255,.18);color:#fff;width:36px;height:36px;
    border-radius:50%;display:grid;place-items:center;
    font-size:1.15rem;line-height:1;cursor:pointer;border:none;flex-shrink:0;
    transition:background .18s;
  }
  .chat-menu-btn:hover{background:rgba(255,255,255,.3)}

  /* ─── Family tabs fade-edge indicator (right side gradient) ─── */
  body.chat-takeover .riw-family-tabs{position:relative}
  body.chat-takeover .riw-family-tabs::after{
    content:'';position:absolute;top:0;right:-1px;bottom:8px;width:32px;
    background:linear-gradient(90deg, transparent, var(--bg-card));
    pointer-events:none;
  }

  /* ─── Enhanced typing indicator (iMessage-style bouncing dots) ─── */
  .msg.typing{
    padding:14px 18px !important;display:inline-flex;align-items:center;gap:4px;
    background:var(--bg-card) !important;border:1px solid var(--line) !important;
  }
  .msg.typing::after{content:none !important}
  .msg.typing .td{
    width:8px;height:8px;border-radius:50%;background:var(--accent);
    animation:tdots 1.1s ease-in-out infinite;
  }
  .msg.typing .td:nth-child(2){animation-delay:.15s}
  .msg.typing .td:nth-child(3){animation-delay:.3s}
  @keyframes tdots{0%,60%,100%{transform:translateY(0);opacity:.5}30%{transform:translateY(-6px);opacity:1}}

  /* ─── Sparkle confetti (replace the rotated rectangles) ─── */
  .confetti i{
    width:auto !important;height:auto !important;font-size:20px;
    background:transparent !important;
    color:var(--accent);
    filter:drop-shadow(0 0 8px rgba(255,45,149,.6));
  }

  /* ─── Locked trade-in card: undo link ─── */
  .locked-stamp .undo{
    background:none;border:none;color:var(--accent);
    font-size:.78rem;text-decoration:underline;cursor:pointer;
    margin-top:6px;padding:0;
  }
  .locked-stamp .undo:hover{color:var(--accent-dk)}

  /* ─── Pick3 inline variant (for chat takeover) ─── */
  .inline-pick3{
    align-self:stretch;display:flex;flex-direction:column;gap:12px;
    flex:0 0 auto;
  }
  .inline-pick3-header{text-align:center;padding:4px 0 8px}
  .inline-pick3-header .eyebrow{font-size:.7rem;color:var(--accent);font-weight:700;letter-spacing:.15em;text-transform:uppercase;margin-bottom:4px}
  .inline-pick3-header h3{font-size:1.25rem;font-weight:800;color:var(--ink);letter-spacing:-.02em}
  .inline-pick3-header p{font-size:.88rem;color:var(--ink-mute);margin-top:4px}
  .inline-pick{
    background:linear-gradient(165deg,var(--bg-card),var(--bg-soft));
    border:1px solid var(--line);border-radius:18px;
    padding:16px;position:relative;overflow:hidden;
    animation:dropIn .4s var(--ease);
  }
  .inline-pick.best{
    border-color:rgba(255,45,149,.55);
    background:linear-gradient(165deg,rgba(255,45,149,.08),var(--bg-card));
    box-shadow:0 12px 36px rgba(255,45,149,.2);
  }
  .inline-pick .tier-badge{
    display:inline-block;padding:4px 11px;border-radius:100px;font-size:.66rem;
    font-weight:700;letter-spacing:.1em;text-transform:uppercase;
    background:rgba(255,255,255,.06);color:var(--silver);border:1px solid var(--line);
    margin-bottom:10px;
  }
  .inline-pick.best .tier-badge{
    background:linear-gradient(135deg,var(--accent),var(--accent-dk));color:#fff;border-color:transparent;
  }
  .inline-pick-img{
    width:100%;aspect-ratio:16/10;background:linear-gradient(145deg,#1e1e25,#0a0a0f);
    border-radius:12px;display:grid;place-items:center;margin-bottom:12px;
    border:1px solid var(--line);overflow:hidden;
  }
  .inline-pick-img img{max-width:78%;max-height:82%;filter:drop-shadow(0 12px 28px rgba(0,0,0,.6))}
  .inline-pick h5{font-size:1.1rem;font-weight:700;letter-spacing:-.015em;margin-bottom:3px}
  .inline-pick .sub{font-size:.82rem;color:var(--ink-mute);margin-bottom:10px}
  .inline-pick .reason{
    background:rgba(255,45,149,.06);border-left:3px solid var(--accent);
    padding:10px 12px;border-radius:0 8px 8px 0;margin-bottom:12px;
    font-size:.88rem;line-height:1.5;color:var(--ink);font-style:italic;
  }
  .inline-pick .reason::before{content:'— Rick: ';color:var(--accent);font-weight:700;font-style:normal;font-size:.82em}
  .inline-pick.best .reason::before{content:'— Rick\'s pick: ';color:var(--accent)}
  .inline-pick-price{
    display:flex;align-items:baseline;justify-content:space-between;
    padding:10px 0;border-top:1px solid var(--line);margin-bottom:12px;
  }
  .inline-pick-price .big{font-size:1.7rem;font-weight:800;color:var(--ink);letter-spacing:-.03em}
  .inline-pick-price .big .cur{font-size:.6em;color:var(--silver);vertical-align:.3em;margin-right:2px}
  .inline-pick-price .sm{font-size:.78rem;color:var(--ink-mute)}
  .inline-pick-price .sm b{color:var(--accent)}
  .inline-pick-btn{
    width:100%;padding:14px;border:none;border-radius:12px;cursor:pointer;
    background:var(--accent);color:#fff;font-weight:700;font-size:.95rem;
    transition:all .18s var(--ease);
  }
  .inline-pick.best .inline-pick-btn{
    background:linear-gradient(135deg,var(--accent),var(--accent-dk));
    box-shadow:0 10px 26px rgba(255,45,149,.4), inset 0 1px 0 rgba(255,255,255,.25);
  }
  .inline-pick-btn:hover{transform:translateY(-1px)}

  /* ─── ADD-ON SUGGESTIONS WIDGET ─── */
  .addon-widget{
    align-self:stretch;display:flex;flex-direction:column;gap:12px;
    padding:16px 14px;
    background:linear-gradient(165deg,var(--bg-card),var(--bg-soft));
    border:1px solid rgba(255,45,149,.35);border-radius:18px;
    animation:dropIn .4s var(--ease);
    position:relative;
    flex:0 0 auto;
  }
  .addon-widget .aw-eyebrow{font-size:.68rem;color:var(--accent);font-weight:700;letter-spacing:.15em;text-transform:uppercase;text-align:center}
  .addon-widget .aw-title{font-size:1.1rem;font-weight:800;color:var(--ink);letter-spacing:-.015em;text-align:center;line-height:1.3}
  .addon-widget .aw-sub{font-size:.82rem;color:var(--ink-mute);text-align:center;margin-top:-4px;line-height:1.45}
  .addon-row{
    display:flex;gap:11px;padding:12px;
    background:var(--bg);border:1px solid var(--line);border-radius:14px;
    align-items:center;transition:border-color .18s, background .18s;
  }
  .addon-row.selected{
    border-color:var(--accent);background:rgba(255,45,149,.06);
    box-shadow:0 8px 24px rgba(255,45,149,.18);
  }
  .addon-row img{width:56px;height:56px;object-fit:contain;flex-shrink:0;background:var(--bg-soft);border-radius:10px;padding:3px}
  .addon-row .info{flex:1;min-width:0}
  .addon-row .atag{font-size:.62rem;color:var(--accent);font-weight:700;letter-spacing:.08em;text-transform:uppercase}
  .addon-row .ttl{font-size:.9rem;font-weight:700;color:var(--ink);letter-spacing:-.005em;line-height:1.3}
  .addon-row .tempt{font-size:.76rem;color:var(--ink-mute);margin-top:3px;line-height:1.4}
  .addon-row .tempt b{color:var(--accent);font-weight:700}
  .addon-row .add-btn{
    flex-shrink:0;padding:10px 14px;border:none;border-radius:100px;cursor:pointer;
    background:rgba(255,45,149,.15);border:1px solid rgba(255,45,149,.4);
    color:var(--accent);font-weight:700;font-size:.82rem;
    transition:all .18s;
  }
  .addon-row.selected .add-btn{
    background:var(--accent);color:#fff;border-color:transparent;
  }
  .addon-row .add-btn::before{content:'+';margin-right:4px;font-weight:800}
  .addon-row.selected .add-btn::before{content:'✓';margin-right:4px}
  .addon-summary{
    margin-top:6px;padding:12px 14px;
    background:linear-gradient(135deg,rgba(255,45,149,.1),rgba(255,45,149,.04));
    border:1px solid rgba(255,45,149,.3);border-radius:12px;
    display:flex;justify-content:space-between;align-items:center;gap:10px;
  }
  .addon-summary .lbl{font-size:.78rem;color:var(--silver);text-transform:uppercase;letter-spacing:.06em}
  .addon-summary .amt{font-size:1.25rem;font-weight:800;color:var(--accent);letter-spacing:-.02em}
  .addon-commit{
    width:100%;padding:14px;border:none;border-radius:12px;cursor:pointer;
    background:linear-gradient(135deg,var(--accent),var(--accent-dk));color:#fff;
    font-weight:800;font-size:.95rem;letter-spacing:-.005em;
    box-shadow:0 10px 26px rgba(255,45,149,.35), inset 0 1px 0 rgba(255,255,255,.25);
    transition:transform .15s var(--ease);
  }
  .addon-commit:hover{transform:translateY(-1px)}
  .addon-commit:disabled{opacity:.55;cursor:default;transform:none}

  /* A11y focus outlines — ensure visible on keyboard nav */
  button:focus-visible, a:focus-visible, input:focus-visible, textarea:focus-visible, select:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
    border-radius: 6px;
  }

  /* ═════════════════════════════════════════════════════════════════════
     PHOTO-TRADE THEATER — upload → fake OCR → Jessica approval drama
     ═════════════════════════════════════════════════════════════════════ */
  .photo-trade{
    align-self:stretch;border-radius:18px;overflow:hidden;
    background:linear-gradient(165deg,var(--bg-card),var(--bg-soft));
    border:1px solid rgba(255,45,149,.4);
    animation:dropIn .4s var(--ease);
    flex:0 0 auto;
  }
  .pt-header{
    padding:16px 18px;
    background:linear-gradient(135deg,rgba(255,45,149,.14),rgba(255,45,149,.04));
    border-bottom:1px solid rgba(255,45,149,.2);
  }
  .pt-header .eye{font-size:.68rem;color:var(--accent);font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin-bottom:3px}
  .pt-header .ttl{font-size:1.05rem;font-weight:800;color:var(--ink);letter-spacing:-.015em;line-height:1.3}
  .pt-body{padding:16px 18px;display:flex;flex-direction:column;gap:14px}
  .pt-pitch{font-size:.88rem;color:var(--ink);line-height:1.5}
  .pt-pitch b{color:var(--accent)}

  .pt-slots{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
  .pt-slot{
    aspect-ratio:1;position:relative;border-radius:14px;cursor:pointer;
    background:var(--bg);border:2px dashed rgba(255,45,149,.35);
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
    color:var(--silver);font-size:.78rem;text-align:center;padding:8px;
    transition:all .2s var(--ease);overflow:hidden;
  }
  .pt-slot:hover{border-color:var(--accent);background:rgba(255,45,149,.05)}
  .pt-slot .slot-ico{font-size:1.6rem;opacity:.7}
  .pt-slot .slot-label{font-weight:600;color:var(--ink-mute);line-height:1.3}
  .pt-slot input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}
  .pt-slot.filled{border-style:solid;border-color:var(--accent);padding:0;background:var(--bg)}
  .pt-slot.filled img{width:100%;height:100%;object-fit:cover;border-radius:12px}
  .pt-slot.filled .slot-ico,.pt-slot.filled .slot-label{display:none}
  .pt-slot .check-badge{
    position:absolute;top:6px;right:6px;z-index:2;
    width:22px;height:22px;border-radius:50%;
    background:var(--accent);color:#fff;display:none;place-items:center;
    font-size:.82rem;font-weight:800;box-shadow:0 4px 10px rgba(255,45,149,.45);
  }
  .pt-slot.filled .check-badge{display:grid}

  .pt-progress{display:flex;align-items:center;gap:10px;font-size:.82rem;color:var(--ink-mute)}
  .pt-progress .bar{flex:1;height:4px;background:var(--bg);border-radius:2px;overflow:hidden}
  .pt-progress .bar::before{
    content:'';display:block;height:100%;width:var(--p,0%);
    background:linear-gradient(90deg,var(--accent),var(--accent-dk));
    transition:width .35s var(--ease);
  }

  .pt-cta{
    width:100%;padding:14px;border:none;border-radius:12px;cursor:pointer;
    background:linear-gradient(135deg,var(--accent),var(--accent-dk));color:#fff;
    font-weight:800;font-size:.96rem;letter-spacing:-.005em;
    box-shadow:0 10px 26px rgba(255,45,149,.35), inset 0 1px 0 rgba(255,255,255,.25);
    transition:all .18s var(--ease);
  }
  .pt-cta:hover{transform:translateY(-1px)}
  .pt-cta:disabled{opacity:.4;cursor:default;transform:none;box-shadow:none}

  /* OCR scan line animation over the model-number photo */
  .pt-slot.scanning::after{
    content:'';position:absolute;left:0;right:0;top:0;height:3px;
    background:linear-gradient(90deg,transparent,var(--accent),transparent);
    box-shadow:0 0 12px var(--accent);
    animation:scanSweep 1.8s ease-in-out infinite;
  }
  @keyframes scanSweep{0%{top:0;opacity:1}50%{top:calc(100% - 3px);opacity:1}100%{top:0;opacity:1}}
  .pt-slot.scanning{border-color:var(--accent);box-shadow:0 0 0 2px rgba(255,45,149,.25), 0 0 30px rgba(255,45,149,.4)}

  .pt-detected{
    font-family:"SF Mono",ui-monospace,monospace;font-size:.84rem;
    padding:10px 12px;background:rgba(34,197,94,.08);border:1px solid rgba(34,197,94,.35);
    border-radius:10px;color:#8fe3b0;display:flex;align-items:center;gap:8px;
    animation:dropIn .4s var(--ease);
  }
  .pt-detected::before{content:'✓';color:#22c55e;font-weight:800;font-size:1rem}

  /* Jessica approval chat bubbles */
  .pt-chat{display:flex;flex-direction:column;gap:8px;padding:14px 0 4px}
  .pt-bubble{
    max-width:86%;padding:10px 13px;border-radius:16px;font-size:.88rem;line-height:1.45;
    animation:bubbleIn .35s var(--ease);
  }
  @keyframes bubbleIn{from{transform:translateY(8px) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}
  .pt-bubble.rick{
    align-self:flex-start;background:rgba(255,45,149,.12);border:1px solid rgba(255,45,149,.3);
    color:var(--ink);border-bottom-left-radius:5px;
  }
  .pt-bubble.jess{
    align-self:flex-end;background:var(--bg);border:1px solid var(--line);
    color:var(--ink);border-bottom-right-radius:5px;
  }
  .pt-bubble .who{font-size:.65rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;margin-bottom:3px;opacity:.7}
  .pt-bubble.rick .who{color:var(--accent)}
  .pt-bubble.jess .who{color:var(--amber)}
  .pt-bubble.typing{
    display:inline-flex;align-items:center;gap:4px;padding:12px 16px;
  }
  .pt-bubble.typing .td{
    width:7px;height:7px;border-radius:50%;background:var(--ink-mute);
    animation:tdots 1.1s ease-in-out infinite;
  }
  .pt-bubble.typing .td:nth-child(2){animation-delay:.15s}
  .pt-bubble.typing .td:nth-child(3){animation-delay:.3s}

  /* "Let's DO this!" urgency button */
  .pt-urge-btn{
    position:sticky;bottom:8px;align-self:center;
    padding:12px 22px;margin:6px 0;
    background:linear-gradient(135deg,#f5b042,var(--accent));color:#fff;
    border:none;border-radius:100px;cursor:pointer;
    font-weight:800;font-size:.92rem;letter-spacing:-.005em;
    box-shadow:0 10px 26px rgba(245,176,66,.45), 0 0 0 0 rgba(255,45,149,.6);
    animation:urgePulse 1.4s ease-in-out infinite, dropIn .35s var(--ease);
    transition:transform .15s var(--ease);
  }
  @keyframes urgePulse{
    0%,100%{box-shadow:0 10px 26px rgba(245,176,66,.45), 0 0 0 0 rgba(255,45,149,.6)}
    50%{box-shadow:0 12px 32px rgba(245,176,66,.65), 0 0 0 14px rgba(255,45,149,0)}
  }
  .pt-urge-btn:hover{transform:translateY(-2px) scale(1.03)}
  .pt-urge-btn::before{content:'⚡ ';margin-right:2px}

  .pt-fingers{
    display:inline-block;animation:fingerWiggle 1.2s ease-in-out infinite;font-size:1.3em;
  }
  @keyframes fingerWiggle{0%,100%{transform:rotate(-8deg)}50%{transform:rotate(8deg)}}

  /* typing cursor effect on bubbles */
  .pt-bubble.typing-char::after{
    content:'▊';display:inline-block;color:var(--accent);
    animation:blink 0.8s steps(2) infinite;margin-left:2px;opacity:.7;
  }
  @keyframes blink{to{opacity:0}}

  /* APPROVED pill — dramatic reveal */
  .pt-approved{
    margin-top:6px;padding:16px 18px;
    background:linear-gradient(135deg,rgba(34,197,94,.15),rgba(255,45,149,.08));
    border:1.5px solid #22c55e;border-radius:14px;
    text-align:center;position:relative;overflow:hidden;
    animation:approveIn .55s cubic-bezier(.2,1.4,.4,1);
  }
  @keyframes approveIn{
    0%{transform:scale(.7) rotate(-3deg);opacity:0}
    60%{transform:scale(1.08) rotate(1deg);opacity:1}
    100%{transform:scale(1) rotate(0);opacity:1}
  }
  .pt-approved .stamp{
    display:inline-block;padding:4px 12px;border-radius:100px;
    background:#22c55e;color:#fff;font-size:.72rem;font-weight:800;letter-spacing:.15em;
    margin-bottom:8px;box-shadow:0 6px 18px rgba(34,197,94,.5);
  }
  .pt-approved .new-credit{
    font-size:2rem;font-weight:800;color:var(--accent);letter-spacing:-.03em;line-height:1;margin-bottom:5px;
  }
  .pt-approved .delta{font-size:.85rem;color:var(--ink-mute)}
  .pt-approved .delta b{color:#22c55e;font-weight:700}
  .pt-approved .lock-btn{
    margin-top:14px;width:100%;padding:12px;
    background:linear-gradient(135deg,var(--accent),var(--accent-dk));color:#fff;
    font-weight:800;font-size:.94rem;border:none;border-radius:10px;cursor:pointer;
    box-shadow:0 8px 22px rgba(255,45,149,.4);
    transition:transform .15s var(--ease);
  }
  .pt-approved .lock-btn:hover{transform:translateY(-1px)}

  /* ─── Pick3 loading shimmer (before Rick's response streams) ─── */
  .pick3-loading{
    align-self:stretch;padding:20px 18px;
    background:linear-gradient(165deg,var(--bg-card),var(--bg-soft));
    border:1px solid rgba(255,45,149,.3);border-radius:16px;
    display:flex;align-items:center;gap:14px;
    animation:dropIn .35s var(--ease);
    flex:0 0 auto;
  }
  .pick3-loading .spinner{
    width:28px;height:28px;border-radius:50%;
    border:3px solid rgba(255,45,149,.2);border-top-color:var(--accent);
    animation:spin .9s linear infinite;flex-shrink:0;
  }
  @keyframes spin{to{transform:rotate(360deg)}}
  .pick3-loading .txt{font-size:.88rem;color:var(--ink);line-height:1.4}
  .pick3-loading .txt b{color:var(--accent);font-weight:700}

  /* ─── Tour back button ─── */
  .tour-chapter .tour-back-btn{
    margin-top:10px;margin-right:8px;padding:8px 16px;
    background:transparent;color:var(--ink-mute);border:1px solid var(--line);
    border-radius:100px;cursor:pointer;font-size:.8rem;font-weight:500;
    transition:all .2s;
  }
  .tour-chapter .tour-back-btn:hover{border-color:var(--silver);color:var(--ink)}
  .tour-chapter .tour-back-btn:disabled{opacity:.35;cursor:default}

  /* Respect prefers-reduced-motion */
  @media(prefers-reduced-motion:reduce){
    *,*::before,*::after{
      animation-duration:.01ms !important;animation-iteration-count:1 !important;
      transition-duration:.01ms !important;
    }
    .chat-fab,.trade-yes-btn,.rick-cta,.deal-claim{animation:none !important}
  }

  /* Welcome widget premium card buttons */
  .welcome-card-btn{
    width:100%;padding:16px 18px;
    background:linear-gradient(165deg,var(--bg-card),var(--bg-soft));
    border:1px solid var(--line);border-radius:14px;
    display:flex;align-items:center;gap:14px;
    cursor:pointer;transition:all .18s var(--ease);
    text-align:left;
  }
  .welcome-card-btn:hover{
    border-color:rgba(255,45,149,.5);
    transform:translateY(-1px);
    box-shadow:0 8px 24px rgba(255,45,149,.15);
  }
  .welcome-card-btn .wcb-ico{
    font-size:1.55rem;flex-shrink:0;width:42px;height:42px;border-radius:12px;
    background:rgba(255,45,149,.1);display:grid;place-items:center;
    border:1px solid rgba(255,45,149,.28);
  }
  .welcome-card-btn .wcb-txt{flex:1;min-width:0}
  .welcome-card-btn .wcb-ttl{
    font-size:.98rem;font-weight:700;color:var(--ink);letter-spacing:-.01em;
  }
  .welcome-card-btn .wcb-sub{
    font-size:.8rem;color:var(--ink-mute);margin-top:2px;line-height:1.4;
  }
  .welcome-card-btn .wcb-arrow{
    font-size:1.1rem;color:var(--ink-mute);flex-shrink:0;transition:transform .18s,color .2s;
  }
  .welcome-card-btn:hover .wcb-arrow{color:var(--accent);transform:translateX(3px)}
  .welcome-card-btn.primary{
    background:linear-gradient(135deg,var(--accent),var(--accent-dk));
    border-color:transparent;
    box-shadow:0 10px 28px rgba(255,45,149,.35);
  }
  .welcome-card-btn.primary .wcb-ico{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.3)}
  .welcome-card-btn.primary .wcb-ttl,
  .welcome-card-btn.primary .wcb-sub,
  .welcome-card-btn.primary .wcb-arrow{color:#fff}
  .welcome-card-btn.primary .wcb-sub{opacity:.85}

  @media(max-width:780px){
    /* Fallback mobile layout (when NOT in takeover — e.g., user dismissed) */
    .chat-panel{bottom:0;right:0;left:0;width:100%;height:48vh;border-radius:22px 22px 0 0;border-bottom:none}
    .chat-panel.expanded{height:88vh}
    .chat-panel .drag-handle{
      position:absolute;top:0;left:0;right:0;height:22px;
      display:flex;align-items:flex-start;justify-content:center;padding-top:7px;
      cursor:grab;touch-action:none;z-index:5;
    }
    .chat-panel .drag-handle::before{content:'';width:40px;height:4px;background:rgba(255,255,255,.35);border-radius:4px}
    .chat-fab{bottom:18px;right:18px;padding:11px 18px;font-size:.9rem}
    .chat-fab .av{width:26px;height:26px;font-size:.72rem}
    .personal-note{display:none !important}
    .warranty-diagram{padding:20px}
    .inv-grid{grid-template-columns:1fr}
    body.narrator-mode{padding-bottom:48vh;transition:padding .4s var(--ease)}
    body.narrator-mode.chat-expanded{padding-bottom:88vh}
  }

  /* Inline widgets for chat-takeover mode — work on any width */
  .rick-inline-widget{
    align-self:stretch;
    background:linear-gradient(165deg,#18181f,#0e0e13);
    border:1px solid var(--line);border-radius:16px;
    overflow:hidden;flex:0 0 auto;
    animation:dropIn .35s var(--ease);
  }
  .rick-inline-widget .riw-header{
    padding:14px 18px;background:linear-gradient(135deg,rgba(255,45,149,.15),rgba(255,45,149,.05));
    border-bottom:1px solid var(--line);
  }
  .rick-inline-widget .riw-eyebrow{font-size:.68rem;color:var(--accent);font-weight:700;letter-spacing:.15em;text-transform:uppercase;margin-bottom:3px}
  .rick-inline-widget .riw-title{font-size:1.05rem;font-weight:700;color:var(--ink);letter-spacing:-.015em}
  .rick-inline-widget .riw-body{padding:16px 18px}

  .riw-warranty-photo{
    position:relative;width:100%;aspect-ratio:16/10;
    background:linear-gradient(145deg,#1e1e25,#0a0a0f);
    display:flex;align-items:center;justify-content:center;
    border-bottom:1px solid var(--line);
  }
  .riw-warranty-photo img{max-width:88%;max-height:88%;filter:drop-shadow(0 10px 30px rgba(255,45,149,.2))}
  .riw-warranty-photo .dot{
    position:absolute;width:12px;height:12px;border-radius:50%;
    background:var(--accent);box-shadow:0 0 0 4px rgba(255,45,149,.25), 0 0 12px rgba(255,45,149,.6);
    transform:translate(-50%,-50%);animation:dotPulse 2.4s ease-in-out infinite;
  }

  .riw-parts{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}
  .riw-parts li{
    display:flex;justify-content:space-between;align-items:center;
    padding:10px 14px;background:rgba(255,255,255,.02);border:1px solid var(--line);
    border-radius:9px;font-size:.85rem;
  }
  .riw-parts .p-name{display:flex;align-items:center;gap:8px;color:var(--ink);font-weight:500}
  .riw-parts .p-name::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 6px rgba(255,45,149,.5)}
  .riw-parts .p-cost{font-family:"SF Mono",ui-monospace,monospace;font-size:.8rem;color:var(--ink-mute)}
  .riw-parts .p-cost b{color:var(--accent);font-weight:600}
  .riw-total{
    margin-top:12px;padding:12px 16px;
    background:linear-gradient(135deg,rgba(255,45,149,.12),rgba(255,45,149,.04));
    border:1px solid rgba(255,45,149,.3);border-radius:10px;
    display:flex;justify-content:space-between;align-items:center;
  }
  .riw-total .lbl{font-size:.75rem;color:var(--silver);text-transform:uppercase;letter-spacing:.08em}
  .riw-total .val{font-size:1.3rem;font-weight:800;color:var(--accent);letter-spacing:-.02em}

  .riw-family-tabs{
    display:flex;gap:6px;overflow-x:auto;padding-bottom:8px;
    scrollbar-width:none;-webkit-overflow-scrolling:touch;
  }
  .riw-family-tabs::-webkit-scrollbar{display:none}
  .riw-family-tabs button{
    white-space:nowrap;padding:8px 14px;border-radius:100px;
    background:var(--bg-card);border:1px solid var(--line);color:var(--silver);
    font-size:.82rem;font-weight:600;cursor:pointer;transition:all .2s;
  }
  .riw-family-tabs button.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 4px 12px rgba(255,45,149,.35)}
  .riw-family-list{display:flex;flex-direction:column;gap:10px;margin-top:12px}
  .riw-family-list .rfl-card{
    display:flex;gap:12px;padding:10px;background:var(--bg-card);
    border:1px solid var(--line);border-radius:12px;transition:border-color .2s;
  }
  .riw-family-list .rfl-card:hover{border-color:rgba(255,45,149,.5)}
  .riw-family-list img{width:68px;height:68px;object-fit:contain;flex-shrink:0;background:var(--bg);border-radius:8px;padding:4px}
  .riw-family-list .rfl-info{flex:1;display:flex;flex-direction:column;gap:3px;min-width:0}
  .riw-family-list .rfl-tag{font-size:.6rem;color:var(--accent);font-weight:700;letter-spacing:.1em;text-transform:uppercase}
  .riw-family-list .rfl-name{font-size:.92rem;font-weight:700;color:var(--ink);letter-spacing:-.01em}
  .riw-family-list .rfl-price{font-size:1.1rem;font-weight:800;color:var(--accent);margin-top:2px}
  .riw-family-list .rfl-price .co{font-size:.7rem;color:var(--ink-mute);font-weight:500;text-decoration:none;margin-left:6px}
  .riw-family-list .rfl-buy{
    align-self:center;flex-shrink:0;padding:8px 14px;border-radius:100px;
    background:var(--accent);color:#fff;font-weight:700;font-size:.8rem;
    border:none;cursor:pointer;transition:background .2s,transform .15s;
  }
  .riw-family-list .rfl-buy:hover{background:var(--accent-dk);transform:translateY(-1px)}

  .riw-how-steps{display:flex;flex-direction:column;gap:10px;counter-reset:rstep}
  .riw-how-steps .rs{display:flex;gap:12px;padding:12px;background:var(--bg-card);border:1px solid var(--line);border-radius:10px}
  .riw-how-steps .rs::before{
    counter-increment:rstep;content:counter(rstep);
    flex-shrink:0;width:30px;height:30px;border-radius:50%;
    background:rgba(255,45,149,.15);border:1px solid rgba(255,45,149,.35);
    color:var(--accent);font-weight:800;font-size:.85rem;
    display:grid;place-items:center;
  }
  .riw-how-steps .rs h5{font-size:.92rem;font-weight:700;margin-bottom:3px}
  .riw-how-steps .rs p{font-size:.82rem;color:var(--ink-mute);line-height:1.5}

  .riw-core-split{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}
  .riw-core-split .cc{padding:14px;background:var(--bg-card);border:1px solid var(--line);border-radius:12px;text-align:center}
  .riw-core-split .cc.featured{border-color:rgba(255,45,149,.5);background:linear-gradient(160deg,rgba(255,45,149,.1),var(--bg-card))}
  .riw-core-split .cc .cct{font-size:.7rem;color:var(--accent);font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:4px}
  .riw-core-split .cc .ccv{font-size:1.5rem;font-weight:800;color:var(--ink);letter-spacing:-.02em}
  .riw-core-split .cc .ccs{font-size:.7rem;color:var(--ink-mute);margin-top:3px}

  /* ─── SPOTLIGHT — when Rick focuses a section ─── */
  .spotlight-target{
    position:relative;z-index:2;
    animation:spotPulse 2.8s ease-out;
  }
  @keyframes spotPulse{
    0%{box-shadow:0 0 0 0 rgba(255,45,149,0), 0 0 0 0 rgba(0,0,0,0) inset}
    15%{box-shadow:0 0 0 3px rgba(255,45,149,.6), 0 0 80px 20px rgba(255,45,149,.35), 0 0 0 999px rgba(0,0,0,.65) inset}
    60%{box-shadow:0 0 0 2px rgba(255,45,149,.35), 0 0 40px 10px rgba(255,45,149,.2), 0 0 0 999px rgba(0,0,0,.25) inset}
    100%{box-shadow:0 0 0 0 rgba(255,45,149,0), 0 0 0 0 rgba(0,0,0,0) inset}
  }

  /* Tour chapter card — cinema-style title insert */
  .tour-chapter{
    align-self:center;max-width:85%;
    background:linear-gradient(135deg,rgba(255,45,149,.15),rgba(204,17,102,.08));
    border:1px solid rgba(255,45,149,.4);border-radius:14px;
    padding:14px 18px;text-align:center;
    animation:chapterIn .4s var(--ease);
    flex:0 0 auto;
  }
  @keyframes chapterIn{from{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}
  .tour-chapter .num{font-size:.7rem;color:var(--accent);font-weight:700;letter-spacing:.15em;text-transform:uppercase;margin-bottom:4px}
  .tour-chapter .title{font-size:1.05rem;font-weight:700;color:var(--ink);letter-spacing:-.01em}
  .tour-chapter .body{font-size:.85rem;color:var(--ink-mute);margin-top:6px}
  .tour-chapter .tour-next-btn{
    margin-top:14px;padding:10px 22px;
    background:var(--accent);color:#fff;font-weight:700;font-size:.88rem;
    border-radius:100px;border:none;cursor:pointer;
    transition:transform .15s var(--ease), background .2s;
    box-shadow:0 6px 18px rgba(255,45,149,.35);
  }
  .tour-chapter .tour-next-btn:hover{background:var(--accent-dk);transform:translateY(-1px)}
  .tour-chapter .tour-next-btn:disabled{opacity:.55;cursor:default;transform:none}
  .tour-chapter .tour-skip{
    display:block;margin-top:8px;background:none;border:none;color:var(--ink-mute);
    font-size:.76rem;cursor:pointer;text-decoration:underline;
  }
  .tour-chapter .tour-skip:hover{color:var(--ink)}
  .tour-chapter .progress-dots{
    display:flex;justify-content:center;gap:4px;margin-top:10px;
  }
  .tour-chapter .pd{
    width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.15);
    transition:all .3s var(--ease);
  }
  .tour-chapter .pd.active{background:var(--accent);width:18px;border-radius:4px}
  .tour-chapter .pd.done{background:rgba(255,45,149,.45)}

  /* ─── RICK DIRECTIVE UI — in-chat product cards, buy buttons, compare cards ─── */
  .rick-card{
    align-self:flex-start;max-width:90%;width:100%;
    background:linear-gradient(160deg,#1c1c22,#121218);
    border:1px solid rgba(255,45,149,.35);border-radius:16px;
    overflow:hidden;box-shadow:0 8px 30px rgba(0,0,0,.5);
    animation:dropIn .35s var(--ease);
    flex:0 0 auto;
  }
  @keyframes dropIn{from{transform:translateY(10px) scale(.96);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}
  .rick-card .rc-img{
    aspect-ratio:16/10;background:linear-gradient(145deg,#1e1e25,#0a0a0f);
    display:grid;place-items:center;overflow:hidden;border-bottom:1px solid var(--line);
  }
  .rick-card .rc-img img{max-width:75%;max-height:75%;filter:drop-shadow(0 6px 20px rgba(0,0,0,.5))}
  .rick-card .rc-body{padding:16px 18px}
  .rick-card .rc-tag{font-size:.68rem;color:var(--accent);font-weight:700;letter-spacing:.1em;text-transform:uppercase}
  .rick-card .rc-title{font-size:1.05rem;font-weight:700;margin:4px 0 2px;letter-spacing:-.015em}
  .rick-card .rc-sub{font-size:.82rem;color:var(--ink-mute);margin-bottom:10px}
  .rick-card .rc-prices{display:flex;gap:14px;align-items:baseline;margin:10px 0 14px}
  .rick-card .rc-price{font-size:1.6rem;font-weight:800;letter-spacing:-.03em}
  .rick-card .rc-price .cur{font-size:.85em;color:var(--silver);vertical-align:.18em;margin-right:1px}
  .rick-card .rc-strike{color:var(--ink-mute);font-size:.82rem;text-decoration:line-through}
  .rick-card .rc-save{color:var(--accent);font-size:.82rem;font-weight:600}
  .rick-card .rc-btn{
    width:100%;padding:12px;background:var(--amber);color:#2a001a;
    font-weight:700;border-radius:10px;font-size:.92rem;
    transition:background .2s,transform .15s var(--ease);
  }
  .rick-card .rc-btn:hover{background:var(--amber-dk);transform:translateY(-1px)}

  /* Giant "ask for the sale" button in chat */
  .rick-cta{
    align-self:stretch;
    display:block;width:100%;padding:18px 22px;
    background:linear-gradient(135deg,var(--amber),#ff9fd1);color:#2a001a;
    font-weight:800;font-size:1.05rem;letter-spacing:-.01em;border-radius:16px;
    text-align:center;border:none;cursor:pointer;
    box-shadow:0 10px 30px rgba(255,45,149,.3), inset 0 1px 0 rgba(255,255,255,.4);
    transition:transform .15s var(--ease), box-shadow .2s;
    animation:pulseCta 2.2s ease-in-out infinite;
    position:relative;overflow:hidden;
    flex:0 0 auto;
  }
  .rick-cta::after{
    content:'';position:absolute;inset:0;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent);
    transform:translateX(-100%);animation:shimmer 2.8s ease-in-out infinite;
  }
  @keyframes shimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}
  @keyframes pulseCta{0%,100%{box-shadow:0 10px 30px rgba(255,45,149,.3), inset 0 1px 0 rgba(255,255,255,.4)}50%{box-shadow:0 14px 40px rgba(255,45,149,.55), inset 0 1px 0 rgba(255,255,255,.4)}}
  .rick-cta:hover{transform:translateY(-2px)}
  .rick-cta .rc-arrow{margin-left:8px;transition:transform .2s}
  .rick-cta:hover .rc-arrow{transform:translateX(4px)}
  .rick-cta .rc-line2{display:block;font-size:.78rem;font-weight:600;opacity:.7;margin-top:4px}

  /* Compare card */
  .rick-compare{
    align-self:stretch;display:grid;grid-template-columns:1fr 1fr;gap:8px;
    background:#111117;border:1px solid var(--line);border-radius:14px;padding:10px;
    flex:0 0 auto;
  }
  .rick-compare .rco{padding:14px;background:var(--bg-soft);border-radius:10px;border:1px solid var(--line)}
  .rick-compare .rco img{width:100%;aspect-ratio:4/3;object-fit:contain;margin-bottom:8px}
  .rick-compare .rco h5{font-size:.88rem;font-weight:700;letter-spacing:-.01em}
  .rick-compare .rco .p{font-size:1.1rem;font-weight:800;color:var(--accent);margin-top:4px}
  .rick-compare-note{grid-column:1/-1;font-size:.82rem;color:var(--ink-mute);text-align:center;padding:6px 0}

  /* ─── PAGE HIGHLIGHT (Rick scrolls + pulses a section) ─── */
  .rick-highlight-target{
    position:relative;
    animation:rickHalo 2.6s ease-out;
  }
  @keyframes rickHalo{
    0%{box-shadow:0 0 0 0 rgba(255,45,149,.0), 0 0 0 0 rgba(255,45,149,0)}
    15%{box-shadow:0 0 0 8px rgba(255,45,149,.35), 0 0 60px 20px rgba(255,45,149,.25)}
    60%{box-shadow:0 0 0 4px rgba(255,45,149,.2), 0 0 40px 10px rgba(255,45,149,.15)}
    100%{box-shadow:0 0 0 0 rgba(255,45,149,0), 0 0 0 0 rgba(255,45,149,0)}
  }
  .rick-highlight-note{
    position:fixed;left:50%;transform:translateX(-50%);
    bottom:100px;z-index:110;
    background:linear-gradient(135deg,var(--accent),var(--accent-dk));
    color:#2a001a;font-weight:700;padding:12px 22px;border-radius:100px;
    box-shadow:0 20px 50px rgba(255,45,149,.4);
    font-size:.95rem;letter-spacing:-.01em;
    animation:slideNote .3s var(--ease), fadeOutNote .5s ease 3.5s forwards;
    display:flex;align-items:center;gap:10px;
  }
  .rick-highlight-note::before{content:'R';width:24px;height:24px;border-radius:50%;background:#2a001a;color:var(--accent);display:grid;place-items:center;font-size:.8rem;font-weight:800}
  @keyframes slideNote{from{transform:translate(-50%,20px);opacity:0}to{transform:translate(-50%,0);opacity:1}}
  @keyframes fadeOutNote{to{opacity:0;transform:translate(-50%,-10px)}}

  /* ─── RICK TOAST (hover nudges + LLM-emitted toasts) ─── */
  .rick-toast-stack{
    position:fixed;top:80px;right:20px;z-index:120;
    display:flex;flex-direction:column;gap:10px;
    max-width:340px;pointer-events:none;
  }
  .rick-toast{
    background:linear-gradient(160deg,#18181f,#0e0e13);
    border:1px solid rgba(255,45,149,.4);
    border-left:3px solid var(--accent);
    border-radius:14px;padding:14px 16px 14px 16px;
    box-shadow:0 20px 50px rgba(0,0,0,.6);
    animation:toastIn .35s var(--ease), toastOut .35s ease 7s forwards;
    pointer-events:auto;font-size:.9rem;line-height:1.45;
    position:relative;
  }
  .rick-toast .rt-head{display:flex;align-items:center;gap:8px;margin-bottom:6px}
  .rick-toast .rt-ava{width:22px;height:22px;border-radius:50%;background:var(--accent);color:#2a001a;display:grid;place-items:center;font-weight:800;font-size:.72rem}
  .rick-toast .rt-name{font-weight:700;font-size:.78rem;color:var(--accent)}
  .rick-toast .rt-time{font-size:.68rem;color:var(--ink-mute);margin-left:auto}
  .rick-toast .rt-body{color:var(--ink);font-size:.88rem}
  .rick-toast .rt-cta{
    margin-top:10px;display:inline-block;padding:7px 14px;
    background:var(--accent);color:#2a001a;font-weight:700;border-radius:100px;
    font-size:.78rem;cursor:pointer;border:none;
  }
  .rick-toast .rt-cta:hover{background:var(--accent-dk)}
  .rick-toast .rt-close{
    position:absolute;top:8px;right:10px;color:var(--ink-mute);
    background:none;border:none;cursor:pointer;font-size:1.1rem;line-height:1;padding:2px 6px;
  }
  .rick-toast .rt-close:hover{color:var(--ink)}
  @keyframes toastIn{from{transform:translateX(360px);opacity:0}to{transform:translateX(0);opacity:1}}
  @keyframes toastOut{to{transform:translateX(360px);opacity:0}}
  @media(max-width:500px){.rick-toast-stack{left:12px;right:12px;max-width:none}}

  /* ─── IMMERSIVE DEAL MODAL ─── */
  .deal-scrim{
    position:fixed;inset:0;z-index:200;
    background:radial-gradient(ellipse at center,rgba(40,0,25,.92) 0%,rgba(0,0,0,.95) 70%);
    backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
    display:none;align-items:center;justify-content:center;
    padding:clamp(16px,4vw,40px);overflow-y:auto;
  }
  .deal-scrim.open{display:flex;animation:scrimIn .4s var(--ease)}
  @keyframes scrimIn{from{opacity:0}to{opacity:1}}
  .deal-box{
    max-width:760px;width:100%;
    background:linear-gradient(165deg,#16161c 0%,#0a0a0f 100%);
    border:1px solid rgba(255,45,149,.4);border-radius:28px;
    padding:clamp(28px,5vw,56px);position:relative;
    box-shadow:0 40px 120px rgba(255,45,149,.25), 0 20px 60px rgba(0,0,0,.8);
    animation:dealIn .5s var(--ease);
  }
  @keyframes dealIn{from{transform:translateY(40px) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}
  .deal-box::before{
    content:'';position:absolute;inset:-1px;border-radius:28px;
    background:linear-gradient(135deg,rgba(255,45,149,.5),transparent 50%,rgba(255,45,149,.3));
    -webkit-mask:linear-gradient(#000,#000) content-box,linear-gradient(#000,#000);mask:linear-gradient(#000,#000) content-box,linear-gradient(#000,#000);
    -webkit-mask-composite:xor;mask-composite:exclude;padding:1px;
    pointer-events:none;
  }
  .deal-close{
    position:absolute;top:18px;right:18px;
    width:36px;height:36px;border-radius:50%;
    background:rgba(255,255,255,.06);border:1px solid var(--line);
    color:var(--silver);font-size:1.2rem;line-height:1;
    cursor:pointer;display:grid;place-items:center;
    transition:background .2s,color .2s;
  }
  .deal-close:hover{background:rgba(255,255,255,.12);color:var(--ink)}
  .deal-badge{
    display:inline-flex;align-items:center;gap:10px;
    background:rgba(255,45,149,.15);border:1px solid rgba(255,45,149,.4);
    padding:8px 16px;border-radius:100px;
    font-size:.78rem;font-weight:700;color:var(--accent);
    letter-spacing:.08em;text-transform:uppercase;margin-bottom:18px;
  }
  .deal-badge .db-rick{width:22px;height:22px;border-radius:50%;background:var(--accent);color:#2a001a;display:grid;place-items:center;font-size:.72rem;font-weight:800}
  .deal-title{font-size:clamp(1.8rem,4vw,2.7rem);font-weight:800;letter-spacing:-.035em;line-height:1.08;margin-bottom:10px}
  .deal-model{font-size:1.05rem;color:var(--silver);margin-bottom:24px}
  .deal-image{
    aspect-ratio:16/10;background:linear-gradient(145deg,#1e1e25,#0a0a0f);
    border-radius:18px;display:grid;place-items:center;margin-bottom:28px;
    border:1px solid var(--line);overflow:hidden;
  }
  .deal-image img{max-width:72%;max-height:72%;filter:drop-shadow(0 30px 50px rgba(0,0,0,.7))}
  .deal-reason{
    background:rgba(255,45,149,.08);border-left:3px solid var(--accent);
    padding:16px 20px;border-radius:10px;margin-bottom:26px;
    font-size:1rem;line-height:1.55;color:var(--ink);
    font-style:italic;
  }
  .deal-reason::before{content:'— Rick: ';color:var(--accent);font-weight:700;font-style:normal}
  .deal-pricing{
    display:grid;grid-template-columns:auto 1fr;gap:8px 22px;
    align-items:baseline;margin-bottom:24px;
  }
  .deal-price{font-size:clamp(2.8rem,7vw,4.2rem);font-weight:800;letter-spacing:-.04em;color:var(--accent);line-height:1}
  .deal-price .cur{font-size:.4em;font-weight:700;color:var(--silver);vertical-align:.4em;margin-right:2px}
  .deal-pricing-side{display:flex;flex-direction:column;gap:2px;padding-top:8px}
  .deal-was{color:var(--ink-mute);font-size:1rem;text-decoration:line-through}
  .deal-save{color:var(--accent);font-size:1rem;font-weight:700}
  .deal-countdown{
    display:flex;align-items:center;gap:12px;margin-bottom:24px;
    padding:12px 18px;background:rgba(255,45,149,.08);border:1px solid rgba(255,45,149,.25);
    border-radius:12px;
  }
  .deal-countdown .dc-label{color:var(--amber);font-size:.82rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}
  .deal-countdown .dc-value{font-family:"SF Mono",ui-monospace,monospace;font-weight:800;font-size:1.15rem;color:var(--ink);margin-left:auto}
  .deal-claim{
    width:100%;padding:22px;
    background:linear-gradient(135deg,var(--amber) 0%,#ff9fd1 50%,var(--amber) 100%);background-size:200% 100%;
    color:#2a001a;font-weight:800;font-size:1.2rem;letter-spacing:-.01em;
    border-radius:16px;text-align:center;border:none;cursor:pointer;
    box-shadow:0 20px 60px rgba(255,45,149,.45), inset 0 1px 0 rgba(255,255,255,.4);
    transition:transform .15s var(--ease), box-shadow .2s, background-position .4s;
    position:relative;overflow:hidden;
  }
  .deal-claim:hover{transform:translateY(-2px);background-position:100% 0;box-shadow:0 24px 70px rgba(255,45,149,.6), inset 0 1px 0 rgba(255,255,255,.5)}
  .deal-claim .dc-sub{display:block;font-size:.82rem;opacity:.7;font-weight:600;margin-top:4px}
  .deal-foot{text-align:center;margin-top:16px;font-size:.85rem;color:var(--ink-mute)}
  .deal-foot .d-cancel{color:var(--silver);text-decoration:underline;cursor:pointer;background:none;border:none;font:inherit}

  /* confetti on celebrate */
  .confetti{position:fixed;inset:0;pointer-events:none;z-index:300;overflow:hidden}
  .confetti i{position:absolute;width:8px;height:14px;opacity:.9;animation:fall linear forwards}
  @keyframes fall{0%{transform:translateY(-20px) rotate(0)}100%{transform:translateY(110vh) rotate(720deg);opacity:.3}}

  /* ─── Enhanced trade-in card — storyboard + pain points + soft-yes ─── */
  .trade-storyboard{
    display:flex;align-items:center;gap:14px;
    padding:18px;margin:12px 0 16px;
    background:var(--bg);border:1px solid var(--line);border-radius:14px;
    position:relative;overflow:hidden;
  }
  .trade-storyboard .icon{
    width:54px;height:54px;flex-shrink:0;
    background:linear-gradient(145deg,#1c1c22,#0a0a0f);
    border:1px solid var(--line);border-radius:12px;
    display:grid;place-items:center;font-size:1.7rem;
    position:relative;z-index:2;
  }
  .trade-storyboard .icon.end{
    background:linear-gradient(145deg,rgba(255,45,149,.15),rgba(255,45,149,.05));
    border-color:rgba(255,45,149,.5);color:var(--accent);
    box-shadow:0 0 20px rgba(255,45,149,.3);
    animation:iconPulse 2s ease-in-out infinite;
  }
  @keyframes iconPulse{0%,100%{box-shadow:0 0 20px rgba(255,45,149,.3)}50%{box-shadow:0 0 32px rgba(255,45,149,.55)}}
  .trade-storyboard .flow{
    flex:1;position:relative;height:54px;display:flex;align-items:center;justify-content:center;
  }
  .trade-storyboard .flow svg{width:100%;height:100%;overflow:visible}
  .trade-storyboard .flow-label{
    position:absolute;top:-8px;left:50%;transform:translateX(-50%);
    font-size:.7rem;color:var(--accent);font-weight:700;letter-spacing:.1em;text-transform:uppercase;
    background:var(--bg);padding:0 8px;
  }
  .trade-storyboard .amount{
    font-size:1.4rem;font-weight:800;color:var(--accent);letter-spacing:-.02em;
    position:absolute;bottom:-4px;left:50%;transform:translateX(-50%);
    white-space:nowrap;
  }

  .trade-pain-list{list-style:none;margin:0 0 18px 0;padding:0;display:flex;flex-direction:column;gap:7px}
  .trade-pain-list li{
    display:flex;align-items:flex-start;gap:9px;
    font-size:.88rem;color:var(--ink);line-height:1.45;
  }
  .trade-pain-list .chk{
    flex-shrink:0;width:18px;height:18px;border-radius:50%;
    background:rgba(255,45,149,.15);border:1.5px solid var(--accent);
    display:grid;place-items:center;font-size:.72rem;color:var(--accent);font-weight:800;
    margin-top:1px;
  }

  .trade-yes-btn{
    width:100%;padding:14px 18px;
    background:linear-gradient(135deg,var(--accent),var(--accent-dk));
    color:#fff;font-weight:800;font-size:1rem;letter-spacing:-.01em;
    border-radius:12px;border:none;cursor:pointer;text-align:center;
    box-shadow:0 10px 26px rgba(255,45,149,.35), inset 0 1px 0 rgba(255,255,255,.25);
    transition:transform .15s var(--ease), box-shadow .2s;
    position:relative;overflow:hidden;
    animation:yesPulse 2.4s ease-in-out infinite;
  }
  .trade-yes-btn::after{
    content:'';position:absolute;inset:0;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,.28),transparent);
    transform:translateX(-100%);animation:yesShimmer 2.8s ease-in-out infinite;
  }
  @keyframes yesShimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}
  @keyframes yesPulse{0%,100%{box-shadow:0 10px 26px rgba(255,45,149,.35), inset 0 1px 0 rgba(255,255,255,.25)}50%{box-shadow:0 14px 36px rgba(255,45,149,.55), inset 0 1px 0 rgba(255,255,255,.25)}}
  .trade-yes-btn:hover{transform:translateY(-2px)}
  .trade-yes-btn .chk-emoji{margin-right:8px}
  .trade-yes-btn .sub{display:block;font-size:.78rem;opacity:.85;font-weight:600;margin-top:3px;letter-spacing:0}

  /* Locked-in state */
  .rick-trade-card.locked{
    border-color:rgba(255,45,149,.7);
    background:linear-gradient(160deg,rgba(255,45,149,.08),#0a0a0f);
  }
  .locked-stamp{
    display:flex;align-items:center;gap:12px;padding:14px 16px;
    background:rgba(255,45,149,.08);border:1px solid rgba(255,45,149,.35);
    border-radius:12px;font-size:.9rem;color:var(--ink);
    animation:lockIn .4s var(--ease);
    margin-top:10px;
  }
  @keyframes lockIn{from{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}
  .locked-stamp .stamp-ico{
    flex-shrink:0;
    width:34px;height:34px;border-radius:50%;background:var(--accent);color:#fff;
    display:grid;place-items:center;font-weight:800;font-size:1.1rem;
  }
  .locked-stamp .stamp-text{flex:1 1 0;min-width:0;line-height:1.45}
  .locked-stamp .stamp-amount{font-size:.94rem}
  .locked-stamp .stamp-amount b{color:var(--accent);font-weight:800}
  .locked-stamp .stamp-sub{
    color:var(--ink-mute);font-size:.8rem;margin-top:4px;line-height:1.5;
  }

  /* Email-save row — now a SEPARATE row below the locked stamp, not jammed inside it. */
  .locked-email-row{
    display:flex;gap:8px;margin-top:10px;align-items:stretch;
    padding:10px 12px;background:var(--bg);
    border:1px solid var(--line);border-radius:10px;
  }
  .locked-email-input{
    flex:1 1 0;min-width:0;
    padding:9px 12px;border:1px solid var(--line);border-radius:8px;
    background:var(--bg-soft);color:var(--ink);font-size:.86rem;
    transition:border-color .15s var(--ease);
  }
  .locked-email-input:focus{outline:none;border-color:var(--accent)}
  .locked-email-input::placeholder{color:var(--ink-mute)}
  .locked-email-btn{
    flex-shrink:0;
    padding:9px 18px;border-radius:8px;background:var(--accent);
    color:#fff;border:none;font-weight:700;font-size:.86rem;cursor:pointer;
    transition:transform .12s var(--ease), box-shadow .12s var(--ease);
  }
  .locked-email-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(255,45,149,.4)}
  .locked-email-confirm{font-size:.86rem;color:var(--accent);padding:8px 4px;font-weight:600}
  .locked-email-error{font-size:.84rem;color:var(--rose);padding:8px 4px}

  /* Action row — single horizontal track holding the trade-in total pill on the LEFT
     (sticky so it stays visible while predict pills scroll horizontally) and the
     predict pills row on the RIGHT (overflow-x scroll). User: "with the pills, not on top". */
  .action-row{
    flex-shrink:0;display:flex;align-items:center;gap:8px;
    padding:8px 14px 2px;min-height:0;
  }
  .action-row .predict-bar{
    flex:1 1 0;min-width:0;padding:0;margin:0;
  }

  /* Trade-in total pill — same SHAPE as predict pills, but solid pink to call out.
     Only renders when an actual evaluated credit > 0 is present. */
  .trade-total-pill{
    flex-shrink:0;display:none;align-items:center;gap:6px;
    padding:10px 14px;border-radius:100px;
    background:linear-gradient(135deg,rgba(255,45,149,.95),rgba(204,17,102,.95));
    color:#fff;font-weight:700;font-size:.86rem;letter-spacing:-.005em;
    box-shadow:0 4px 12px rgba(255,45,149,.35);
    animation:pillIn .4s var(--ease);
    cursor:default;white-space:nowrap;
  }
  .trade-total-pill.visible{display:inline-flex}
  @keyframes pillIn{from{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}
  .trade-total-pill .ico{
    width:20px;height:20px;border-radius:50%;background:rgba(255,255,255,.22);
    display:grid;place-items:center;font-size:.72rem;font-weight:800;
  }
  .trade-total-pill .count{font-size:.7rem;opacity:.82;margin-left:2px;font-weight:600}
  .trade-total-pill .amount{font-size:.98rem;font-weight:800;letter-spacing:-.02em}
  .trade-total-pill .bump{animation:pillBump .5s var(--ease)}
  @keyframes pillBump{0%{transform:scale(1)}40%{transform:scale(1.12)}100%{transform:scale(1)}}

  /* ─── PERSONALIZATION BANNER (shown when Rick has rebuilt the page) ─── */
  .personal-banner{
    background:linear-gradient(90deg,rgba(255,45,149,.12),rgba(255,45,149,.08));
    border-bottom:1px solid rgba(255,45,149,.3);
    padding:12px clamp(20px,5vw,60px);
    display:flex;align-items:center;justify-content:space-between;gap:16px;
    font-size:.88rem;position:sticky;top:64px;z-index:70;
    backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  }
  .personal-banner.hidden{display:none}
  .pb-left{display:flex;align-items:center;gap:10px;color:var(--ink)}
  .pb-ava{width:24px;height:24px;border-radius:50%;background:var(--accent);color:#2a001a;display:grid;place-items:center;font-weight:800;font-size:.72rem;flex-shrink:0}
  .pb-reset{background:none;border:none;color:var(--silver);font-size:.8rem;cursor:pointer;text-decoration:underline}
  .pb-reset:hover{color:var(--ink)}

  /* ─── RICK'S 3 PICKS — the rabbit hole section ─── */
  .picks-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-top:30px}
  .pick{
    position:relative;background:linear-gradient(165deg,var(--bg-card),var(--bg-soft));
    border:1px solid var(--line);border-radius:var(--radius-lg);
    overflow:hidden;display:flex;flex-direction:column;
    transition:transform .3s var(--ease), border-color .3s, box-shadow .3s;
  }
  .pick:hover{transform:translateY(-6px);border-color:rgba(255,45,149,.5);box-shadow:0 30px 70px rgba(0,0,0,.5)}
  .pick.best{
    border-color:rgba(255,45,149,.5);
    box-shadow:0 20px 60px rgba(255,45,149,.15);
  }
  .pick.best::before{
    content:'';position:absolute;inset:-1px;border-radius:calc(var(--radius-lg) + 1px);
    background:linear-gradient(135deg,rgba(255,45,149,.6),transparent 50%,rgba(255,45,149,.4));
    -webkit-mask:linear-gradient(#000,#000) content-box,linear-gradient(#000,#000);mask:linear-gradient(#000,#000) content-box,linear-gradient(#000,#000);
    -webkit-mask-composite:xor;mask-composite:exclude;padding:1px;pointer-events:none;
  }
  .pick-tier{
    position:absolute;top:16px;right:16px;z-index:2;
    padding:5px 13px;border-radius:100px;font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
    background:rgba(10,10,12,.8);backdrop-filter:blur(10px);border:1px solid var(--line);color:var(--silver);
  }
  .pick.good .pick-tier{color:var(--silver);border-color:var(--line)}
  .pick.better .pick-tier{color:var(--accent);border-color:rgba(255,45,149,.4)}
  .pick.best .pick-tier{color:var(--amber);border-color:rgba(255,45,149,.5);background:rgba(255,45,149,.1)}
  .pick-img{aspect-ratio:16/11;background:linear-gradient(145deg,#1e1e25,#0a0a0f);display:grid;place-items:center;border-bottom:1px solid var(--line);overflow:hidden;padding:24px}
  .pick-img img{max-width:88%;max-height:88%;filter:drop-shadow(0 18px 40px rgba(0,0,0,.6))}
  .pick-body{padding:24px 24px 26px;display:flex;flex-direction:column;gap:10px;flex:1}
  .pick-title{font-size:1.25rem;font-weight:700;letter-spacing:-.02em;line-height:1.2}
  .pick-sub{color:var(--ink-mute);font-size:.85rem}
  .pick-reason{
    background:rgba(255,45,149,.06);border-left:3px solid var(--accent);
    padding:14px 16px;border-radius:0 10px 10px 0;margin:10px 0;
    font-size:.92rem;line-height:1.55;color:var(--ink);font-style:italic;
  }
  .pick-reason::before{content:'— Rick: ';color:var(--accent);font-style:normal;font-weight:700;font-size:.85em}
  .pick.best .pick-reason{background:rgba(255,45,149,.06);border-left-color:var(--amber)}
  .pick.best .pick-reason::before{content:'— Rick\'s pick: ';color:var(--amber)}
  .pick-price-row{display:flex;align-items:baseline;justify-content:space-between;margin-top:auto;padding-top:14px}
  .pick-price{font-size:1.85rem;font-weight:800;letter-spacing:-.035em}
  .pick-price .cur{font-size:.55em;font-weight:700;color:var(--silver);vertical-align:.35em;margin-right:2px}
  .pick-price .lbl{font-size:.7rem;color:var(--ink-mute);text-transform:uppercase;letter-spacing:.08em;display:block;margin-top:2px;font-weight:600}
  .pick-without{color:var(--ink-mute);font-size:.82rem;text-decoration:line-through;margin-top:2px}
  .pick-btn{
    margin-top:16px;width:100%;padding:14px;font-weight:700;font-size:.95rem;
    background:var(--amber);color:#2a001a;border-radius:10px;
    transition:background .2s, transform .15s var(--ease);
  }
  .pick-btn:hover{background:var(--amber-dk);transform:translateY(-1px)}
  .pick.best .pick-btn{
    background:linear-gradient(135deg,var(--amber),#ff9fd1);
    box-shadow:0 10px 24px rgba(255,45,149,.35);
  }

  .picks-header{text-align:center;max-width:680px;margin:0 auto}
  .picks-header .eyebrow{color:var(--amber)}
  .picks-header h2 span.you{background:linear-gradient(135deg,var(--accent),#ff79c6);-webkit-background-clip:text;background-clip:text;color:transparent}

  /* ─── RICK'S PERSONAL NOTE (sticky right-rail pillar) ─── */
  .personal-note{
    position:fixed;bottom:100px;left:20px;z-index:90;
    max-width:280px;padding:16px 18px;
    background:linear-gradient(160deg,#1c1c22,#0e0e13);
    border:1px solid rgba(255,45,149,.35);border-radius:14px;
    box-shadow:0 20px 50px rgba(0,0,0,.6);
    animation:noteIn .4s var(--ease);
  }
  .personal-note.hidden{display:none}
  .pn-head{display:flex;align-items:center;gap:8px;margin-bottom:8px}
  .pn-ava{width:22px;height:22px;border-radius:50%;background:var(--accent);color:#2a001a;display:grid;place-items:center;font-weight:800;font-size:.72rem}
  .pn-lbl{font-size:.72rem;color:var(--accent);font-weight:700;letter-spacing:.08em;text-transform:uppercase}
  .pn-body{font-size:.88rem;line-height:1.5;color:var(--ink)}
  .pn-close{position:absolute;top:8px;right:10px;background:none;border:none;color:var(--ink-mute);font-size:1.1rem;cursor:pointer;line-height:1}
  @keyframes noteIn{from{transform:translateX(-20px) scale(.95);opacity:0}to{transform:translateX(0) scale(1);opacity:1}}
  @media(max-width:700px){.personal-note{left:12px;right:12px;max-width:none;bottom:90px}}

  /* ─── Cookie consent banner (privacy-first, dark-glass, pink border) ─── */
  .lc-cookie{
    position:fixed;left:16px;bottom:16px;z-index:9500;
    max-width:340px;
    background:rgba(18,18,22,.92);
    backdrop-filter:blur(20px) saturate(1.3);
    -webkit-backdrop-filter:blur(20px) saturate(1.3);
    border:1px solid rgba(255,45,149,.4);
    border-radius:14px;
    box-shadow:0 12px 36px rgba(0,0,0,.55), 0 0 0 1px rgba(255,45,149,.12);
    padding:12px 14px;
    color:var(--ink);
    font-size:.84rem;line-height:1.45;
    animation:lcCookieIn .32s var(--ease);
  }
  .lc-cookie[hidden]{display:none}
  @keyframes lcCookieIn{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
  .lc-cookie-title{font-weight:700;font-size:.86rem;margin-bottom:4px;color:var(--ink);letter-spacing:-.01em}
  .lc-cookie-body{color:var(--silver);margin-bottom:10px;font-size:.78rem;line-height:1.45}
  .lc-cookie-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
  .lc-cookie-btn{
    padding:7px 13px;border-radius:100px;font-size:.78rem;font-weight:700;
    transition:transform .14s var(--ease), background .18s, border-color .18s;
    border:1px solid transparent;cursor:pointer;
  }
  .lc-cookie-btn.primary{background:var(--accent);color:#2a001a}
  .lc-cookie-btn.primary:hover{background:var(--accent-dk);transform:translateY(-1px)}
  .lc-cookie-btn.ghost{background:transparent;color:var(--ink);border-color:var(--line)}
  .lc-cookie-btn.ghost:hover{border-color:var(--accent);color:var(--accent)}
  .lc-cookie-sub{
    margin-top:12px;padding-top:12px;border-top:1px solid var(--line);
    display:none;
  }
  .lc-cookie.expanded .lc-cookie-sub{display:block;animation:lcCookieSubIn .22s var(--ease)}
  @keyframes lcCookieSubIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
  .lc-cookie-opt{display:flex;align-items:flex-start;gap:10px;padding:8px 0;cursor:pointer}
  .lc-cookie-opt input{margin-top:3px;accent-color:var(--accent)}
  .lc-cookie-opt .lbl{font-weight:600;color:var(--ink);font-size:.86rem}
  .lc-cookie-opt .hint{color:var(--ink-mute);font-size:.78rem;display:block;margin-top:2px}
  @media(max-width:500px){
    .lc-cookie{left:8px;right:8px;bottom:8px;padding:14px}
    .lc-cookie-actions{flex-direction:column;align-items:stretch}
    .lc-cookie-btn{width:100%;text-align:center}
  }

  /* ─── Google Map embed wrapper (themed) ─── */
  .lc-map-section{padding:clamp(40px,6vw,70px) clamp(20px,5vw,60px) 10px}
  .lc-map-card{
    max-width:900px;margin:0 auto;
    border:1px solid rgba(255,45,149,.4);
    border-radius:var(--radius-lg);
    overflow:hidden;
    background:var(--bg-card);
    box-shadow:0 20px 60px rgba(0,0,0,.5), 0 0 0 1px rgba(255,45,149,.12);
  }
  .lc-map-head{padding:16px 22px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px;flex-wrap:wrap}
  .lc-map-head .lc-map-pin{
    width:34px;height:34px;border-radius:10px;
    background:linear-gradient(135deg,var(--accent),var(--accent-dk));
    color:#2a001a;display:grid;place-items:center;font-size:1rem;font-weight:800;flex-shrink:0;
    box-shadow:0 6px 16px rgba(255,45,149,.35);
  }
  .lc-map-head .lc-map-txt{flex:1;min-width:200px}
  .lc-map-head h3{font-size:1.05rem;margin:0;color:var(--ink);letter-spacing:-.015em}
  .lc-map-head p{font-size:.84rem;color:var(--ink-mute);margin:2px 0 0}
  .lc-map-head .lc-map-cta{
    display:inline-flex;align-items:center;gap:6px;
    padding:8px 14px;border-radius:100px;
    background:var(--accent);color:#2a001a;font-weight:700;font-size:.84rem;
    transition:background .2s, transform .15s var(--ease);
  }
  .lc-map-head .lc-map-cta:hover{background:var(--accent-dk);transform:translateY(-1px)}
  .lc-map-frame{position:relative;width:100%;aspect-ratio:16/9;background:#0a0a0f}
  .lc-map-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:grayscale(.15) contrast(1.05)}
  @media(max-width:600px){
    .lc-map-frame{aspect-ratio:4/3}
  }

  /* ─── Chat input: dynamic viewport height so iOS keyboard doesn't cover it.
     100dvh naturally tracks the visual viewport on modern iOS/Android; we
     already use it for the takeover container. The JS also sets a CSS var
     --lc-vvh from visualViewport.height as a fallback for older iOS. */
  body.chat-takeover .chat-panel{
    height:100dvh;
    height:var(--lc-vvh, 100dvh);
  }
  body.chat-takeover .chat-input{
    padding-bottom:max(14px, env(safe-area-inset-bottom));
  }
  /* FIX (wave-2): cookie banner blocks chat input on mobile takeover.
     Push it visually out of the way (and below the chat) when chat owns the screen. */
  body.chat-takeover .lc-cookie{display:none !important}

