/* =============================================
   . (Period) — Black · Purple · Gold
   ============================================= */

@import url('https://api.fontshare.com/v2/css?f[]=switzer@300,400,500,600,700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400&display=swap');

/* ---- Tokens ---- */
:root {
  --bg: #F8F7FA;
  --surface: #FFFFFF;
  --surface-2: #F2EFF8;
  --surface-offset: #EAE5F5;
  --border: #DDD7EE;
  --divider: #E8E3F2;

  --text: #0D0A14;
  --text-muted: #6B6080;
  --text-faint: #B0A8C8;
  --text-inverse: #FAF9FB;

  --accent: #6B2FA0;
  --accent-hover: #5A2487;
  --accent-active: #481B6E;
  --accent-subtle: #F0EAFA;
  --accent-subtle-hover: #E5DCFA;

  --gold: #C9941A;
  --gold-hover: #B07D10;
  --gold-light: #F5D060;
  --gold-subtle: #FBF4E3;

  --success: #2D7A4A;
  --error: #A03030;

  --font-display: 'Cormorant Garamond', 'Georgia', serif;
  --font-body: 'Switzer', 'Helvetica Neue', sans-serif;

  --text-xs:   clamp(0.75rem,  0.7rem  + 0.25vw, 0.875rem);
  --text-sm:   clamp(0.875rem, 0.8rem  + 0.35vw, 1rem);
  --text-base: clamp(1rem,     0.95rem + 0.25vw, 1.125rem);
  --text-lg:   clamp(1.125rem, 1rem    + 0.75vw, 1.5rem);
  --text-xl:   clamp(1.5rem,   1.2rem  + 1.25vw, 2.25rem);
  --text-2xl:  clamp(2rem,     1.4rem  + 2vw,    3rem);
  --text-hero: clamp(3rem,     1.5rem  + 6vw,    6rem);

  --sp-1: .25rem; --sp-2: .5rem;  --sp-3: .75rem;
  --sp-4: 1rem;   --sp-5: 1.25rem;--sp-6: 1.5rem;
  --sp-8: 2rem;   --sp-10: 2.5rem;--sp-12: 3rem;  --sp-16: 4rem;

  --r-sm: .375rem; --r-md: .625rem; --r-lg: 1rem;
  --r-xl: 1.5rem;  --r-2xl: 2rem;   --r-full: 9999px;

  --shadow-sm: 0 1px 3px rgba(13,10,20,.07);
  --shadow-md: 0 4px 20px rgba(107,47,160,.12);
  --shadow-lg: 0 12px 48px rgba(107,47,160,.18);
  --shadow-gold: 0 6px 24px rgba(201,148,26,.35);

  --trans: 180ms cubic-bezier(.16,1,.3,1);
  --trans-slow: 320ms cubic-bezier(.16,1,.3,1);
  --header-h: 64px;
  --trending-h: 36px;
  --top-offset: calc(var(--header-h) + var(--trending-h));
}

[data-theme='dark'] {
  --bg: #080610;
  --surface: #100D1A;
  --surface-2: #181225;
  --surface-offset: #1E1630;
  --border: #2E2448;
  --divider: #231C3A;
  --text: #EDE8FA;
  --text-muted: #9B90BB;
  --text-faint: #4A3F6A;
  --text-inverse: #080610;
  --accent: #A855F7;
  --accent-hover: #C084FC;
  --accent-active: #D8B4FE;
  --accent-subtle: #1E1035;
  --accent-subtle-hover: #2A163D;
  --gold: #F0B429;
  --gold-hover: #FBBF24;
  --gold-light: #FDE68A;
  --gold-subtle: #1C1405;
  --shadow-sm: 0 1px 3px rgba(0,0,0,.4);
  --shadow-md: 0 4px 20px rgba(0,0,0,.5);
  --shadow-lg: 0 12px 48px rgba(168,85,247,.2);
  --shadow-gold: 0 6px 24px rgba(240,180,41,.3);
}

@media (prefers-color-scheme: dark) {
  :root:not([data-theme]) {
    --bg: #080610; --surface: #100D1A; --surface-2: #181225;
    --surface-offset: #1E1630; --border: #2E2448; --divider: #231C3A;
    --text: #EDE8FA; --text-muted: #9B90BB; --text-faint: #4A3F6A;
    --text-inverse: #080610;
    --accent: #A855F7; --accent-hover: #C084FC; --accent-active: #D8B4FE;
    --accent-subtle: #1E1035; --accent-subtle-hover: #2A163D;
    --gold: #F0B429; --gold-hover: #FBBF24; --gold-light: #FDE68A; --gold-subtle: #1C1405;
    --shadow-sm: 0 1px 3px rgba(0,0,0,.4);
    --shadow-md: 0 4px 20px rgba(0,0,0,.5);
    --shadow-lg: 0 12px 48px rgba(168,85,247,.2);
    --shadow-gold: 0 6px 24px rgba(240,180,41,.3);
  }
}

/* =============================================
   WHY PERIOD MODAL
   ============================================= */
.why-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.72);
  backdrop-filter: blur(6px);
  z-index: 500;
  opacity: 0;
  transition: opacity 300ms ease;
}
.why-overlay.open { opacity: 1; }

.why-modal {
  position: fixed; inset: 0;
  z-index: 501;
  display: none;
  flex-direction: column;
  overflow-y: auto;
  background: linear-gradient(170deg, #0D0A18 0%, #160E2E 60%, #0A0612 100%);
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 300ms ease, transform 380ms cubic-bezier(.16,1,.3,1);
}
.why-modal.open { opacity: 1; transform: translateY(0); }

.why-modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--sp-4) var(--sp-4);
  position: sticky; top: 0;
  background: rgba(13,10,24,.94);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(168,85,247,.1);
  z-index: 2;
}
.why-modal-logo { display: flex; align-items: center; gap: 8px; }
.why-modal-dot {
  font-family: var(--font-display);
  font-size: 2rem; font-weight: 700;
  color: #0A0812; line-height: 1;
  text-shadow: 0 0 16px rgba(240,180,41,.8), 0 0 32px rgba(168,85,247,.4);
}
.why-close-btn {
  width: 36px; height: 36px;
  border-radius: var(--r-full);
  background: rgba(255,255,255,.07);
  color: rgba(237,232,250,.55);
  display: flex; align-items: center; justify-content: center;
  transition: background var(--trans), color var(--trans);
}
.why-close-btn:hover { background: rgba(255,255,255,.14); color: #EDE8FA; }

.why-modal-body {
  padding: var(--sp-6) var(--sp-4) var(--sp-16);
  max-width: 580px; margin: 0 auto; width: 100%;
}

.why-headline {
  font-family: var(--font-display);
  font-size: clamp(1.7rem, 5.5vw, 2.8rem);
  font-weight: 600; color: #EDE8FA; line-height: 1.15;
  margin-bottom: var(--sp-2);
}
.why-tagline2 {
  font-size: var(--text-sm); color: rgba(237,232,250,.55);
  margin-bottom: var(--sp-6); line-height: 1.7;
}

.why-cards { display: flex; flex-direction: column; gap: var(--sp-3); margin-bottom: var(--sp-8); }

.why-card {
  background: rgba(255,255,255,.035);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: var(--r-xl);
  padding: var(--sp-5);
  animation: whyCardIn 420ms cubic-bezier(.16,1,.3,1) both;
}
@keyframes whyCardIn {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}
[data-version="teen"]      .why-card { border-color: rgba(207,106,255,.18); }
[data-version="adult"]     .why-card { border-color: rgba(168,85,247,.18); }
[data-version="emergency"] .why-card { border-color: rgba(239,68,68,.18); }
[data-version="gifter"]    .why-card { border-color: rgba(236,72,153,.18); }
[data-version="holistic"]  .why-card { border-color: rgba(52,211,153,.18); }

.why-card-top {
  display: flex; align-items: center; gap: var(--sp-2); margin-bottom: var(--sp-2);
}
.why-card-icon { font-size: 1.25rem; }
.why-card-label {
  font-size: .7rem; font-weight: 700; letter-spacing: .09em;
  text-transform: uppercase; color: var(--accent);
}
[data-version="teen"]      .why-card-label { color: #CF6AFF; }
[data-version="adult"]     .why-card-label { color: #A855F7; }
[data-version="emergency"] .why-card-label { color: #EF4444; }
[data-version="gifter"]    .why-card-label { color: #EC4899; }
[data-version="holistic"]  .why-card-label { color: #34D399; }

.why-card-title {
  font-family: var(--font-display);
  font-size: var(--text-lg); font-weight: 600;
  color: #EDE8FA; margin-bottom: var(--sp-2); line-height: 1.3;
}
.why-card-body {
  font-size: var(--text-sm); color: rgba(237,232,250,.68); line-height: 1.75;
}

.why-cta-block {
  text-align: center; padding-top: var(--sp-6);
  border-top: 1px solid rgba(255,255,255,.06);
}
.why-shop-btn {
  display: inline-flex; align-items: center; justify-content: center;
  height: 52px; padding: 0 var(--sp-10);
  background: var(--gold); color: #0D0A14;
  border-radius: var(--r-full); font-size: var(--text-base); font-weight: 700;
  box-shadow: var(--shadow-gold); margin-bottom: var(--sp-3);
  transition: background var(--trans), transform var(--trans);
}
.why-shop-btn:hover { background: var(--gold-hover); transform: translateY(-1px); }
.why-footer-sub {
  font-size: var(--text-xs); color: rgba(237,232,250,.35); line-height: 1.6;
}

/* Hero "Why Period." pill */
.hero-why-btn {
  background: linear-gradient(135deg, rgba(212,175,55,.12), rgba(168,85,247,.12)) !important;
  border-color: rgba(212,175,55,.35) !important;
  color: #F5D060 !important;
}
.hero-why-btn:hover {
  background: linear-gradient(135deg, rgba(212,175,55,.22), rgba(168,85,247,.22)) !important;
  border-color: rgba(212,175,55,.6) !important;
}

/* ── AUDIT FIXES ───────────────────────────────────────────────────── */

/* Emergency mode: hide Care Package card and CTA on home screen */
[data-version="emergency"] #cardCarePackage,
[data-version="emergency"] #heroCarePackage { display: none !important; }

/* =============================================
   BASE RESET
   ============================================= */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:none;text-size-adjust:none;-webkit-font-smoothing:antialiased;scroll-behavior:smooth}
body{font-family:var(--font-body);font-size:var(--text-base);color:var(--text);background:var(--bg);min-height:100dvh;line-height:1.6;overflow-x:hidden}
img,svg{display:block;max-width:100%}
button{cursor:pointer;background:none;border:none;font:inherit;color:inherit}
input,select,textarea{font:inherit;color:inherit}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.15;text-wrap:balance}
::selection{background:var(--accent-subtle);color:var(--text)}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:var(--r-sm)}
a,button,[role='button'],input{transition:color var(--trans),background var(--trans),border-color var(--trans),box-shadow var(--trans),opacity var(--trans)}

/* =============================================
   HEADER
   ============================================= */
.header {
  position: fixed;
  top:0;left:0;right:0;
  height: var(--header-h);
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  z-index: 100;
  display: flex;
  align-items: center;
  padding: 0 var(--sp-4);
  gap: var(--sp-3);
}

/* ---- Crown + Dot Brand Mark ---- */
.brand-mark {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
  cursor: pointer;
  flex: 1;
}

.crown-svg {
  display: block;
  width: 32px;
  position: relative;
  z-index: 2;
  margin-bottom: -10px;
}

.brand-dot {
  font-family: var(--font-display);
  font-size: 2.4rem;
  font-weight: 700;
  color: #D4AF37;
  line-height: 0.7;
  letter-spacing: 0;
  display: block;
  text-shadow: 0 0 8px rgba(212,175,55,0.6), 0 0 20px rgba(212,175,55,0.3);
  position: relative;
  z-index: 1;
}



.header-actions {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  flex-shrink: 0;
}

.icon-btn {
  width: 40px;height: 40px;
  border-radius: var(--r-full);
  display: flex;align-items: center;justify-content: center;
  color: var(--text-muted);
}
.icon-btn:hover{background:var(--surface-offset);color:var(--text)}

/* ── Version Badge Pill ─────────────────────────────── */
.version-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 13px 6px 10px;
  border-radius: var(--r-full);
  border: none;
  cursor: pointer;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.03em;
  white-space: nowrap;
  background: var(--vbadge-bg, #A855F7);
  color: #fff;
  box-shadow: 0 0 0 2px rgba(168,85,247,0.35), 0 2px 8px rgba(0,0,0,0.3);
  transition: transform 0.15s, box-shadow 0.15s, background 0.3s;
  animation: badgePulse 2.4s ease-in-out 1.2s 2;
  flex-shrink: 0;
}
.version-badge:hover {
  transform: translateY(-1px) scale(1.04);
  box-shadow: 0 0 0 3px rgba(168,85,247,0.5), 0 4px 14px rgba(0,0,0,0.35);
}
.version-badge:active { transform: scale(0.97); }
.version-badge svg { opacity: 0.85; flex-shrink: 0; }

/* Per-version accent */
[data-version="teen"]      .version-badge { --vbadge-bg: #CF6AFF; box-shadow: 0 0 0 2px rgba(207,106,255,0.35), 0 2px 8px rgba(0,0,0,0.3); }
[data-version="adult"]     .version-badge { --vbadge-bg: #A855F7; box-shadow: 0 0 0 2px rgba(168,85,247,0.35), 0 2px 8px rgba(0,0,0,0.3); }
[data-version="emergency"] .version-badge { --vbadge-bg: #EF4444; box-shadow: 0 0 0 2px rgba(239,68,68,0.4),  0 2px 8px rgba(0,0,0,0.3); }
[data-version="gifter"]    .version-badge { --vbadge-bg: #EC4899; box-shadow: 0 0 0 2px rgba(236,72,153,0.4), 0 2px 8px rgba(0,0,0,0.3); }
[data-version="holistic"]  .version-badge { --vbadge-bg: #34D399; box-shadow: 0 0 0 2px rgba(52,211,153,0.4),  0 2px 8px rgba(0,0,0,0.3); }

/* No-version state — use gold to invite first pick */
:not([data-version]) .version-badge,
[data-version=""] .version-badge {
  --vbadge-bg: #D4AF37;
  box-shadow: 0 0 0 2px rgba(212,175,55,0.4), 0 2px 8px rgba(0,0,0,0.3);
  color: #0D0A14;
}

@keyframes badgePulse {
  0%   { box-shadow: 0 0 0 2px rgba(168,85,247,0.35), 0 2px 8px rgba(0,0,0,0.3); }
  50%  { box-shadow: 0 0 0 6px rgba(168,85,247,0.0),  0 4px 18px rgba(168,85,247,0.4); transform: scale(1.06); }
  100% { box-shadow: 0 0 0 2px rgba(168,85,247,0.35), 0 2px 8px rgba(0,0,0,0.3); }
}

.cart-btn{position:relative}
.cart-badge {
  position: absolute;
  top: 4px;right: 4px;
  width: 18px;height: 18px;
  background: var(--gold);
  color: #0D0A14;
  font-size: .62rem;font-weight: 700;
  border-radius: var(--r-full);
  display: none;
  align-items: center;justify-content: center;
}
.cart-badge.visible{display:flex}

/* =============================================
   VIEW SYSTEM
   ============================================= */
.view { display: none; }
.view.active { display: block; }

/* =============================================
   HOME VIEW
   ============================================= */
#homeView {
  padding-top: var(--top-offset);
}

/* Hero */
.home-hero {
  min-height: 60dvh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--sp-12) var(--sp-6) var(--sp-8);
  background: linear-gradient(170deg, #0D0A18 0%, #1A0E36 55%, #09060F 100%);
  position: relative;
  overflow: hidden;
}

/* Ambient glow orbs */
.home-hero::before {
  content: '';
  position: absolute;
  top: 20%; left: 20%;
  width: 300px; height: 300px;
  background: radial-gradient(circle, rgba(107,47,160,.3) 0%, transparent 70%);
  pointer-events: none;
}
.home-hero::after {
  content: '';
  position: absolute;
  bottom: 10%; right: 15%;
  width: 250px; height: 250px;
  background: radial-gradient(circle, rgba(201,148,26,.15) 0%, transparent 70%);
  pointer-events: none;
}

.hero-brand-mark {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: var(--sp-6);
  position: relative;
  z-index: 1;
}

.hero-crown-svg {
  width: 56px;
  display: block;
  position: relative;
  z-index: 2;
  margin-bottom: -14px;
}

.hero-dot {
  font-family: var(--font-display);
  font-size: clamp(5rem, 15vw, 9rem);
  font-weight: 700;
  color: #D4AF37;
  line-height: 0.65;
  text-shadow: 0 0 40px rgba(212,175,55,0.9), 0 0 80px rgba(212,175,55,0.5), 0 0 120px rgba(168,85,247,.3);
  display: block;
  position: relative;
  z-index: 1;
}

.hero-tagline {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 400;
  color: #EDE8FA;
  margin-bottom: var(--sp-3);
  position: relative;
  z-index: 1;
  font-style: italic;
}

.hero-sub {
  font-size: var(--text-sm);
  color: rgba(237,232,250,.6);
  max-width: 320px;
  margin: 0 auto var(--sp-8);
  line-height: 1.7;
  position: relative;
  z-index: 1;
}

/* Hero CTA pair */
.hero-cta-pair {
  display: flex;
  gap: var(--sp-3);
  flex-wrap: wrap;
  justify-content: center;
  position: relative;
  z-index: 1;
}

.cta-primary {
  height: 52px;
  padding: 0 var(--sp-8);
  background: var(--gold);
  color: #0D0A14;
  border-radius: var(--r-full);
  font-size: var(--text-base);
  font-weight: 700;
  display: inline-flex;align-items: center;gap: var(--sp-2);
  box-shadow: var(--shadow-gold);
}
.cta-primary:hover{background:var(--gold-hover);transform:translateY(-1px)}

.cta-secondary {
  height: 52px;
  padding: 0 var(--sp-8);
  background: transparent;
  color: #EDE8FA;
  border-radius: var(--r-full);
  font-size: var(--text-base);
  font-weight: 600;
  display: inline-flex;align-items: center;gap: var(--sp-2);
  border: 1.5px solid rgba(237,232,250,.35);
}
.cta-secondary:hover{background:rgba(237,232,250,.08);border-color:rgba(237,232,250,.6)}

/* Mode cards */
.mode-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-4);
  padding: var(--sp-12) var(--sp-4) var(--sp-4);
}
@media (max-width: 420px) {
  .mode-cards { grid-template-columns: 1fr; }
}

.mode-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: var(--sp-6) var(--sp-5);
  cursor: pointer;
  transition: transform var(--trans), box-shadow var(--trans), border-color var(--trans);
  position: relative;
  overflow: hidden;
  text-align: left;
}
.mode-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--accent)}

.mode-card--gold { border-color: var(--gold); }
.mode-card--gold:hover { border-color: var(--gold-hover); box-shadow: var(--shadow-gold); }
.mode-card--gold::before {
  content: '';
  position: absolute;
  top: 0;left: 0;right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--gold), var(--gold-light));
}
.mode-card--purple::before {
  content: '';
  position: absolute;
  top: 0;left: 0;right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--accent), #C084FC);
}

.mode-card-icon {
  font-size: 2.2rem;
  margin-bottom: var(--sp-3);
  line-height: 1;
}
.mode-card-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 600;
  margin-bottom: var(--sp-2);
  color: var(--text);
}
.mode-card-desc {
  font-size: var(--text-sm);
  color: var(--text-muted);
  line-height: 1.6;
  margin-bottom: var(--sp-4);
}
.mode-card-link {
  font-size: var(--text-sm);
  font-weight: 700;
  display: inline-flex;align-items: center;gap: var(--sp-2);
}
.mode-card--gold   .mode-card-link { color: var(--gold); }
.mode-card--purple .mode-card-link { color: var(--accent); }

/* How it works */
.how-section {
  padding: var(--sp-12) var(--sp-4) var(--sp-6);
}
.how-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 600;
  margin-bottom: var(--sp-5);
  text-align: center;
}
.how-steps {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.how-step {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-4);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-4) var(--sp-5);
}
.how-step-num {
  width: 32px;height: 32px;
  border-radius: var(--r-full);
  display: flex;align-items: center;justify-content: center;
  font-weight: 700;font-size: var(--text-sm);
  flex-shrink: 0;
  background: var(--accent-subtle);
  color: var(--accent);
}
.how-step--gold .how-step-num { background: var(--gold-subtle); color: var(--gold); }
.how-step-text {}
.how-step-name { font-weight: 600; font-size: var(--text-sm); margin-bottom: 2px; }
.how-step-desc { font-size: var(--text-xs); color: var(--text-muted); line-height: 1.6; }

/* Home footer strip */
.home-footer {
  padding: var(--sp-8) var(--sp-4) var(--sp-12);
}
.trust-strip {
  display: flex;gap: var(--sp-3);
  overflow-x: auto;scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  padding-bottom: var(--sp-2);
}
.trust-strip::-webkit-scrollbar{display:none}
.trust-badge {
  display: flex;align-items: center;gap: var(--sp-2);
  font-size: var(--text-xs);font-weight: 500;
  color: var(--text-muted);white-space: nowrap;flex-shrink: 0;
  padding: var(--sp-2) var(--sp-3);
  background: var(--surface);border: 1px solid var(--border);
  border-radius: var(--r-full);
}

/* =============================================
   SHOP VIEW (On-Demand)
   ============================================= */
#shopView {
  padding-top: var(--top-offset);
}

/* Delivery ETA banner */
.delivery-banner {
  background: linear-gradient(135deg, #1A0E36, #0D0A18);
  padding: var(--sp-4) var(--sp-4);
  display: flex;align-items: center;justify-content: space-between;
  gap: var(--sp-3);
  border-bottom: 1px solid var(--border);
}
.delivery-info { display: flex;align-items: center;gap: var(--sp-3); }
.delivery-icon {
  width: 40px;height: 40px;
  background: rgba(201,148,26,.15);
  border: 1px solid rgba(201,148,26,.3);
  border-radius: var(--r-full);
  display: flex;align-items: center;justify-content: center;
  font-size: 1.1rem;flex-shrink: 0;
}
.delivery-label {
  font-size: var(--text-xs);font-weight: 600;
  text-transform: uppercase;letter-spacing: .08em;
  color: var(--gold);
  margin-bottom: 2px;
}
.delivery-time {
  font-size: var(--text-sm);font-weight: 600;
  color: #EDE8FA;
}
.delivery-fee {
  font-size: var(--text-xs);
  color: rgba(237,232,250,.5);
}

.address-pill {
  display: flex;align-items: center;gap: var(--sp-2);
  background: rgba(237,232,250,.08);
  border: 1px solid rgba(237,232,250,.15);
  border-radius: var(--r-full);
  padding: var(--sp-2) var(--sp-3);
  font-size: var(--text-xs);color: rgba(237,232,250,.7);
  cursor: pointer;white-space: nowrap;flex-shrink: 0;
}
.address-pill:hover{background:rgba(237,232,250,.14)}

/* Search bar */
.search-bar {
  padding: var(--sp-3) var(--sp-4);
  background: var(--bg);
  border-bottom: 1px solid var(--border);
}
.search-input-wrap { position: relative;max-width: 600px;margin: 0 auto; }
.search-input-wrap svg {
  position: absolute;left: var(--sp-3);
  top: 50%;transform: translateY(-50%);
  color: var(--text-muted);pointer-events: none;
}
.search-input {
  width: 100%;height: 42px;
  padding: 0 var(--sp-4) 0 40px;
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--r-full);
  font-size: var(--text-sm);
  outline: none;
}
.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}
.search-input::placeholder{color:var(--text-faint)}

/* Filter pills */
.filter-bar {
  background: var(--bg);
  border-bottom: 1px solid var(--border);
  padding: var(--sp-3) var(--sp-4);
  overflow-x: auto;scrollbar-width: none;-webkit-overflow-scrolling: touch;
}
.filter-bar::-webkit-scrollbar{display:none}
.filter-pills{display:flex;gap:var(--sp-2);min-width:max-content}
.pill {
  height: 34px;padding: 0 var(--sp-4);
  border-radius: var(--r-full);font-size: var(--text-sm);font-weight: 500;
  white-space: nowrap;border: 1.5px solid var(--border);
  background: var(--surface);color: var(--text-muted);
  display: flex;align-items: center;gap: var(--sp-2);
}
.pill:hover{border-color:var(--accent);color:var(--accent)}
.pill.active{background:var(--accent);border-color:var(--accent);color:white}

/* Product section */
.section-header {
  padding: var(--sp-5) var(--sp-4) var(--sp-3);
  display: flex;align-items: baseline;justify-content: space-between;
}
.section-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:600}
.section-count{font-size:var(--text-xs);color:var(--text-muted);font-weight:500}

.product-grid {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: var(--sp-3);
  padding: 0 var(--sp-4) var(--sp-16);
}
@media(min-width:480px){.product-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:768px){.product-grid{grid-template-columns:repeat(4,1fr);gap:var(--sp-4);padding:0 var(--sp-8) var(--sp-16)}}

/* Product card */
.product-card {
  background: var(--surface);border: 1px solid var(--border);
  border-radius: var(--r-lg);overflow: hidden;cursor: pointer;
  transition: transform var(--trans),box-shadow var(--trans),border-color var(--trans);
}
.product-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--accent)}
.product-card:active{transform:translateY(0)}

.product-img {
  width:100%;aspect-ratio:1;
  display:flex;align-items:center;justify-content:center;
  font-size:2.4rem;position:relative;overflow:hidden;
}
.product-img[data-cat="period"]  {background:linear-gradient(135deg,#1A0D2E,#3D1A6E)}
.product-img[data-cat="intimate"]{background:linear-gradient(135deg,#0D1020,#1F1050)}
.product-img[data-cat="wellness"]{background:linear-gradient(135deg,#0D150A,#1A3020)}
.product-img[data-cat="skincare"]{background:linear-gradient(135deg,#1A1205,#3D2A08)}
.product-img[data-cat="hygiene"] {background:linear-gradient(135deg,#0A1020,#102040)}

.product-card:hover .product-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(201,148,26,.12),transparent);
  pointer-events:none;
}

.product-img-badge {
  position:absolute;top:var(--sp-2);left:var(--sp-2);
  background:var(--gold);color:#0D0A14;
  font-size:.58rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.07em;
  padding:2px var(--sp-2);border-radius:var(--r-full);
}

.product-eta {
  position:absolute;bottom:var(--sp-2);right:var(--sp-2);
  background:rgba(8,6,16,.75);backdrop-filter:blur(4px);
  color:rgba(237,232,250,.9);
  font-size:.6rem;font-weight:600;
  padding:2px var(--sp-2);border-radius:var(--r-full);
  display:flex;align-items:center;gap:3px;
}

.product-body{padding:var(--sp-3)}
.product-name{
  font-size:var(--text-sm);font-weight:600;color:var(--text);
  line-height:1.3;margin-bottom:var(--sp-1);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.product-sub{font-size:var(--text-xs);color:var(--text-muted);margin-bottom:var(--sp-2)}
.product-footer{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-2)}
.product-price{font-size:var(--text-sm);font-weight:700}

.add-btn {
  width:30px;height:30px;border-radius:var(--r-full);
  background:var(--accent);color:white;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:background var(--trans),transform var(--trans);
}
.add-btn:hover{background:var(--accent-hover);transform:scale(1.08)}
.add-btn.in-cart{background:var(--gold);color:#0D0A14}

/* Empty state */
.empty-state{text-align:center;padding:var(--sp-12) var(--sp-8);grid-column:1/-1}
.empty-icon{font-size:3rem;margin-bottom:var(--sp-4)}
.empty-title{font-family:var(--font-display);font-size:var(--text-lg);margin-bottom:var(--sp-2)}
.empty-sub{font-size:var(--text-sm);color:var(--text-muted)}

/* =============================================
   SUBSCRIBE VIEW
   ============================================= */
#subscribeView {
  padding-top: var(--top-offset);
}

.subscribe-hero {
  background: linear-gradient(170deg,#0D0A18,#1A0E36,#09060F);
  padding: var(--sp-10) var(--sp-5) var(--sp-8);
  text-align: center;
  border-bottom: 1px solid var(--border);
  position: relative;
  overflow: hidden;
}
.subscribe-hero::before{
  content:'';position:absolute;top:-30%;left:50%;transform:translateX(-50%);
  width:400px;height:400px;
  background:radial-gradient(circle,rgba(107,47,160,.25),transparent 70%);
  pointer-events:none;
}

.subscribe-eyebrow{
  font-size:var(--text-xs);font-weight:700;text-transform:uppercase;
  letter-spacing:.12em;color:var(--gold);margin-bottom:var(--sp-2);
  position:relative;z-index:1;
}
.subscribe-title{
  font-family:var(--font-display);font-size:var(--text-2xl);
  font-weight:600;color:#EDE8FA;margin-bottom:var(--sp-3);
  line-height:1.2;position:relative;z-index:1;
}
.subscribe-title span{color:var(--gold);font-style:italic}
.subscribe-sub{
  font-size:var(--text-sm);color:rgba(237,232,250,.6);
  max-width:340px;margin:0 auto;line-height:1.7;
  position:relative;z-index:1;
}

/* Plan cards */
.plans-section{padding:var(--sp-6) var(--sp-4) var(--sp-4)}
.plans-label{
  font-size:var(--text-xs);font-weight:700;text-transform:uppercase;
  letter-spacing:.1em;color:var(--text-muted);
  margin-bottom:var(--sp-4);text-align:center;
}
.plan-cards{display:flex;flex-direction:column;gap:var(--sp-3)}

.plan-card {
  background:var(--surface);border:2px solid var(--border);
  border-radius:var(--r-xl);padding:var(--sp-5);cursor:pointer;
  transition:border-color var(--trans),box-shadow var(--trans);
  position:relative;
}
.plan-card:hover{border-color:var(--accent)}
.plan-card.selected{border-color:var(--accent);box-shadow:var(--shadow-md)}
.plan-card.selected.gold-plan{border-color:var(--gold);box-shadow:var(--shadow-gold)}

.plan-popular {
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--gold);color:#0D0A14;
  font-size:.62rem;font-weight:800;
  text-transform:uppercase;letter-spacing:.08em;
  padding:3px var(--sp-3);border-radius:var(--r-full);
  white-space:nowrap;
}

.plan-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-3)}
.plan-name{font-family:var(--font-display);font-size:var(--text-lg);font-weight:600}
.plan-price-wrap{text-align:right}
.plan-price{font-family:var(--font-display);font-size:var(--text-xl);font-weight:600;color:var(--text)}
.plan-per{font-size:var(--text-xs);color:var(--text-muted)}

.plan-slot-info{
  font-size:var(--text-sm);font-weight:600;
  color:var(--accent);margin-bottom:var(--sp-3);
  display:flex;align-items:center;gap:var(--sp-2);
}
.plan-card.selected .plan-slot-info{color:var(--accent)}
.plan-card.selected.gold-plan .plan-slot-info{color:var(--gold)}

.plan-features{display:flex;flex-direction:column;gap:var(--sp-2)}
.plan-feature{
  display:flex;align-items:center;gap:var(--sp-2);
  font-size:var(--text-xs);color:var(--text-muted);
}
.plan-feature-check{
  width:16px;height:16px;border-radius:var(--r-full);
  background:var(--accent-subtle);color:var(--accent);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;font-size:.6rem;
}
.plan-card.selected.gold-plan .plan-feature-check{background:var(--gold-subtle);color:var(--gold)}

/* Plan radio indicator */
.plan-radio {
  width:20px;height:20px;
  border:2px solid var(--border);border-radius:var(--r-full);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:border-color var(--trans);
}
.plan-card.selected   .plan-radio{border-color:var(--accent);background:var(--accent)}
.plan-card.selected.gold-plan .plan-radio{border-color:var(--gold);background:var(--gold)}
.plan-radio-dot{width:8px;height:8px;border-radius:var(--r-full);background:white;display:none}
.plan-card.selected .plan-radio-dot{display:block}

/* Item picker */
.picker-section{padding:var(--sp-4) var(--sp-4) var(--sp-4)}
.picker-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:var(--sp-4);flex-wrap:wrap;gap:var(--sp-3);
}
.picker-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:600}
.picker-slots{
  font-size:var(--text-xs);font-weight:700;
  padding:var(--sp-2) var(--sp-3);
  background:var(--accent-subtle);color:var(--accent);
  border-radius:var(--r-full);border:1px solid var(--border);
  white-space:nowrap;
}
.picker-slots.full{background:var(--gold-subtle);color:var(--gold)}

.picker-hint{
  font-size:var(--text-xs);color:var(--text-muted);
  margin-bottom:var(--sp-4);display:flex;align-items:center;gap:var(--sp-2);
}

.picker-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-3);
  margin-bottom:var(--sp-8);
}
@media(min-width:480px){.picker-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:768px){.picker-grid{grid-template-columns:repeat(4,1fr);gap:var(--sp-4)}}

.picker-card {
  background:var(--surface);border:1.5px solid var(--border);
  border-radius:var(--r-lg);overflow:hidden;cursor:pointer;
  transition:border-color var(--trans),transform var(--trans);
  position:relative;
}
.picker-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.picker-card.selected{border-color:var(--gold)}
.picker-card.disabled{opacity:.4;pointer-events:none}

.picker-check {
  position:absolute;top:var(--sp-2);right:var(--sp-2);
  width:22px;height:22px;border-radius:var(--r-full);
  background:var(--gold);color:#0D0A14;
  display:none;align-items:center;justify-content:center;
  z-index:2;font-size:.65rem;
}
.picker-card.selected .picker-check{display:flex}

.picker-img{
  width:100%;aspect-ratio:1;
  display:flex;align-items:center;justify-content:center;
  font-size:2rem;
}
.picker-body{padding:var(--sp-2) var(--sp-3) var(--sp-3)}
.picker-name{
  font-size:var(--text-xs);font-weight:600;color:var(--text);
  line-height:1.3;margin-bottom:2px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.picker-price{font-size:var(--text-xs);color:var(--text-muted)}

/* Subscribe CTA */
.subscribe-cta-bar {
  position:sticky;bottom:0;
  background:var(--surface);border-top:1px solid var(--border);
  padding:var(--sp-4) var(--sp-4) var(--sp-6);
  z-index:50;
}
.subscribe-summary{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:var(--sp-3);
}
.subscribe-summary-text{font-size:var(--text-xs);color:var(--text-muted)}
.subscribe-summary-price{font-family:var(--font-display);font-size:var(--text-lg);font-weight:600;color:var(--gold)}

.subscribe-btn {
  width:100%;height:52px;
  background:linear-gradient(135deg,var(--accent),#9B27C8);
  color:white;border-radius:var(--r-full);
  font-size:var(--text-base);font-weight:700;
  display:flex;align-items:center;justify-content:center;gap:var(--sp-2);
  box-shadow:0 6px 24px rgba(107,47,160,.4);
  transition:all var(--trans);
}
.subscribe-btn:hover{box-shadow:0 8px 32px rgba(107,47,160,.55);transform:translateY(-1px)}
.subscribe-btn:disabled{opacity:.5;pointer-events:none}

/* =============================================
   BACK BUTTON
   ============================================= */
.back-bar {
  display:flex;align-items:center;gap:var(--sp-2);
  padding:var(--sp-3) var(--sp-4);
  background:var(--bg);
  border-bottom:1px solid var(--border);
}
.back-btn {
  display:flex;align-items:center;gap:var(--sp-2);
  font-size:var(--text-sm);font-weight:600;color:var(--text-muted);
}
.back-btn:hover{color:var(--accent)}
.back-bar-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:600;flex:1;text-align:center}
.back-bar-spacer{width:80px}/* balance back button */

/* =============================================
   PRODUCT MODAL
   ============================================= */
.overlay {
  position:fixed;inset:0;
  background:rgba(8,6,16,.72);backdrop-filter:blur(6px);
  z-index:200;opacity:0;pointer-events:none;
  transition:opacity var(--trans);
}
.overlay.open{opacity:1;pointer-events:all}

.modal {
  position:fixed;bottom:0;left:0;right:0;
  background:var(--surface);
  border-radius:var(--r-xl) var(--r-xl) 0 0;
  border-top:1px solid var(--border);
  z-index:210;max-height:92dvh;overflow-y:auto;
  transform:translateY(100%);
  transition:transform var(--trans-slow);
}
.modal.open{transform:translateY(0)}

@media(min-width:600px){
  .modal{
    bottom:auto;top:50%;left:50%;
    transform:translate(-50%,-42%);
    width:90%;max-width:480px;
    border-radius:var(--r-xl);border:1px solid var(--border);
    max-height:86dvh;opacity:0;
    transition:transform 260ms cubic-bezier(.16,1,.3,1),opacity 260ms ease;
  }
  .modal.open{transform:translate(-50%,-50%);opacity:1}
}

.modal-drag-handle{width:36px;height:4px;background:var(--border);border-radius:var(--r-full);margin:var(--sp-3) auto var(--sp-1)}
@media(min-width:600px){.modal-drag-handle{display:none}}

.modal-hero{
  width:100%;aspect-ratio:4/3;
  display:flex;align-items:center;justify-content:center;
  font-size:5rem;position:relative;
}
.modal-hero::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.modal-close{
  position:absolute;top:var(--sp-3);right:var(--sp-3);
  width:36px;height:36px;
  background:rgba(13,10,20,.6);backdrop-filter:blur(4px);
  border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;
  color:white;border:1px solid rgba(255,255,255,.15);
}
.modal-close:hover{background:rgba(13,10,20,.85)}

.modal-body{padding:var(--sp-5) var(--sp-5) var(--sp-8)}
.modal-cat-tag{
  display:inline-flex;align-items:center;gap:var(--sp-1);
  font-size:var(--text-xs);font-weight:600;
  text-transform:uppercase;letter-spacing:.1em;color:var(--gold);margin-bottom:var(--sp-2);
}
.modal-cat-tag::before{content:'';display:inline-block;width:16px;height:1.5px;background:var(--gold);border-radius:2px}
.modal-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:600;margin-bottom:var(--sp-1)}
.modal-sub{font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--sp-4)}
.modal-desc{
  font-size:var(--text-sm);color:var(--text-muted);line-height:1.75;
  margin-bottom:var(--sp-5);border-top:1px solid var(--divider);padding-top:var(--sp-4);
}
.modal-features{display:flex;flex-wrap:wrap;gap:var(--sp-2);margin-bottom:var(--sp-5)}
.feature-tag{
  font-size:var(--text-xs);font-weight:600;color:var(--accent);
  background:var(--accent-subtle);border-radius:var(--r-full);
  padding:var(--sp-1) var(--sp-3);border:1px solid var(--border);
}
.modal-footer{
  display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);
  border-top:1px solid var(--divider);padding-top:var(--sp-5);
}
.modal-price{font-family:var(--font-display);font-size:var(--text-xl);font-weight:600}
.modal-price-sub{font-size:var(--text-xs);color:var(--text-muted);font-family:var(--font-body);margin-top:1px}
.modal-add-btn{
  height:48px;padding:0 var(--sp-6);
  background:var(--accent);color:white;border-radius:var(--r-full);
  font-size:var(--text-sm);font-weight:600;white-space:nowrap;
  display:flex;align-items:center;gap:var(--sp-2);
  box-shadow:0 4px 20px rgba(107,47,160,.35);
}
.modal-add-btn:hover{background:var(--accent-hover);box-shadow:0 4px 24px rgba(107,47,160,.5)}
.modal-add-btn.in-cart{background:var(--gold);color:#0D0A14;box-shadow:var(--shadow-gold)}

/* =============================================
   CART SIDEBAR
   ============================================= */
.cart-sidebar {
  position:fixed;top:0;right:0;bottom:0;
  width:min(380px,100vw);
  background:var(--surface);border-left:1px solid var(--border);
  z-index:300;transform:translateX(100%);
  transition:transform var(--trans-slow);
  display:flex;flex-direction:column;
}
.cart-sidebar.open{transform:translateX(0)}
.cart-overlay{
  position:fixed;inset:0;background:rgba(8,6,16,.55);
  backdrop-filter:blur(3px);z-index:290;opacity:0;pointer-events:none;
  transition:opacity var(--trans);
}
.cart-overlay.open{opacity:1;pointer-events:all}

.cart-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:var(--sp-5) var(--sp-5) var(--sp-4);
  border-bottom:1px solid var(--border);position:relative;
}
.cart-header::after{
  content:'';position:absolute;bottom:-1px;left:var(--sp-5);right:var(--sp-5);
  height:2px;background:linear-gradient(90deg,var(--accent),var(--gold));
  border-radius:var(--r-full);
}
.cart-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:600}
.cart-body{flex:1;overflow-y:auto;padding:var(--sp-4)}
.cart-empty{text-align:center;padding:var(--sp-10) var(--sp-4);color:var(--text-muted)}
.cart-empty-icon{font-size:3rem;margin-bottom:var(--sp-3)}
.cart-empty-text{font-size:var(--text-sm);line-height:1.7}

.cart-item{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) 0;border-bottom:1px solid var(--divider)}
.cart-item-img{
  width:56px;height:56px;border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;flex-shrink:0;border:1px solid var(--border);
}
.cart-item-info{flex:1;min-width:0}
.cart-item-name{font-size:var(--text-sm);font-weight:600;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cart-item-price{font-size:var(--text-xs);color:var(--gold);font-weight:600}
.cart-qty{display:flex;align-items:center;gap:var(--sp-2);flex-shrink:0}
.qty-btn{
  width:26px;height:26px;border-radius:var(--r-full);
  border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;
  font-size:.9rem;color:var(--text-muted);
}
.qty-btn:hover{border-color:var(--accent);color:var(--accent)}
.qty-num{font-size:var(--text-sm);font-weight:600;min-width:20px;text-align:center}

.cart-footer{padding:var(--sp-4) var(--sp-5) var(--sp-6);border-top:1px solid var(--border)}
.cart-delivery-row{
  display:flex;align-items:center;gap:var(--sp-2);
  font-size:var(--text-xs);color:var(--text-muted);
  margin-bottom:var(--sp-3);
  padding:var(--sp-3);background:var(--surface-2);border-radius:var(--r-md);
  border:1px solid var(--border);
}
.cart-delivery-row strong{color:var(--gold)}
.cart-subtotal{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:var(--sp-1)}
.cart-subtotal-label{font-size:var(--text-sm);color:var(--text-muted)}
.cart-subtotal-amt{font-family:var(--font-display);font-size:var(--text-xl);font-weight:600;color:var(--gold)}
.cart-note{font-size:var(--text-xs);color:var(--text-faint);margin-bottom:var(--sp-4)}
.checkout-btn{
  width:100%;height:52px;
  background:linear-gradient(135deg,var(--accent),#9B27C8);color:white;
  border-radius:var(--r-full);font-size:var(--text-base);font-weight:700;
  display:flex;align-items:center;justify-content:center;gap:var(--sp-2);
  box-shadow:0 6px 24px rgba(107,47,160,.4);position:relative;overflow:hidden;
}
.checkout-btn::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(201,148,26,.25),transparent);
  opacity:0;transition:opacity var(--trans);
}
.checkout-btn:hover::after{opacity:1}
.checkout-btn:hover{box-shadow:0 8px 32px rgba(107,47,160,.55)}

/* =============================================
   SUCCESS MODALS
   ============================================= */
.success-modal {
  position:fixed;inset:0;
  background:rgba(8,6,16,.8);backdrop-filter:blur(8px);
  z-index:400;display:flex;align-items:center;justify-content:center;
  padding:var(--sp-6);opacity:0;pointer-events:none;
  transition:opacity var(--trans);
}
.success-modal.open{opacity:1;pointer-events:all}
.success-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-2xl);padding:var(--sp-10) var(--sp-8);
  text-align:center;max-width:360px;width:100%;
  position:relative;overflow:hidden;
}
.success-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--accent),var(--gold));
}
.success-icon{font-size:3.5rem;margin-bottom:var(--sp-4)}
.success-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:600;margin-bottom:var(--sp-2)}
.success-sub{font-size:var(--text-sm);color:var(--text-muted);line-height:1.7;margin-bottom:var(--sp-6)}
.success-btn{
  width:100%;height:48px;background:var(--accent);color:white;
  border-radius:var(--r-full);font-size:var(--text-sm);font-weight:700;
  display:flex;align-items:center;justify-content:center;gap:var(--sp-2);
}
.success-btn:hover{background:var(--accent-hover)}
.success-eta{
  font-size:var(--text-xs);font-weight:700;color:var(--gold);
  background:var(--gold-subtle);border:1px solid rgba(201,148,26,.25);
  border-radius:var(--r-full);padding:var(--sp-2) var(--sp-4);
  margin-bottom:var(--sp-5);display:inline-block;
}

/* =============================================
   TOAST
   ============================================= */
.toast{
  position:fixed;bottom:var(--sp-6);left:50%;
  transform:translateX(-50%) translateY(calc(100% + var(--sp-6) + 60px));
  background:var(--surface-2);color:var(--text);
  padding:var(--sp-3) var(--sp-5);border-radius:var(--r-full);
  font-size:var(--text-sm);font-weight:500;white-space:nowrap;
  z-index:500;transition:transform 300ms cubic-bezier(.16,1,.3,1);
  box-shadow:var(--shadow-lg);border:1px solid var(--border);
  opacity:0;
  pointer-events:none;
}
.toast.show{
  transform:translateX(-50%) translateY(0);
  opacity:1;
  pointer-events:auto;
}

/* =============================================
   SCROLLBAR
   ============================================= */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--r-full)}

/* Gold shimmer animation */
@keyframes goldShimmer{0%{background-position:-200% center}100%{background-position:200% center}}
.gold-shimmer{
  background:linear-gradient(90deg,var(--gold) 0%,var(--gold-light) 40%,var(--gold) 80%);
  background-size:200% auto;-webkit-background-clip:text;
  -webkit-text-fill-color:transparent;background-clip:text;
  animation:goldShimmer 3s linear infinite;
}

/* =============================================
   VERSION PICKER (First Launch)
   ============================================= */
.version-picker {
  position: fixed; inset: 0;
  background: #050310;
  z-index: 1000;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: var(--sp-5) var(--sp-4) var(--sp-10);
  overflow-y: auto;
  transition: opacity 450ms ease;
}

/* Hide immediately when version is already chosen — set before render by head script */
[data-version] .version-picker { display: none; }

.vp-inner {
  max-width: 500px; width: 100%;
  text-align: center;
  display: flex; flex-direction: column; align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-4) 0 var(--sp-8);
}

.vp-brand {
  display: flex; flex-direction: column; align-items: center;
  margin-bottom: var(--sp-1);
}
.vp-crown { width: 44px; display: block; }
.vp-dot {
  font-family: var(--font-display); font-size: clamp(5rem, 14vw, 8rem);
  font-weight: 900; color: #F0B429; line-height: 0.5;
  -webkit-text-stroke: 1px rgba(255,220,100,.6);
  text-shadow:
    0 0 6px rgba(240,180,41,1),
    0 0 24px rgba(240,180,41,.9),
    0 0 60px rgba(240,180,41,.55),
    0 0 100px rgba(168,85,247,.4);
  position: relative;
  top: -28px;
}

.vp-headline {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 6vw, 2.25rem);
  font-weight: 600; color: #EDE8FA;
  letter-spacing: -.01em; line-height: 1.1;
}
.vp-sub {
  font-size: var(--text-sm); color: rgba(237,232,250,.4);
  margin-top: calc(-1 * var(--sp-2));
}

.vp-cards {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: var(--sp-2); width: 100%;
}

.vp-card {
  position: relative; border-radius: var(--r-xl);
  padding: var(--sp-3) var(--sp-3);
  text-align: left; overflow: hidden; cursor: pointer;
  transition: transform var(--trans), box-shadow var(--trans), border-color var(--trans);
  border: 1.5px solid transparent;
  display: flex; flex-direction: column; gap: var(--sp-1);
  min-height: 0;
}
.vp-card:hover { transform: translateY(-5px); }
.vp-card:active { transform: translateY(-1px); }
.vp-card:focus-visible { outline: 2px solid rgba(237,232,250,.4); outline-offset: 3px; }

.vp-card--teen {
  background: linear-gradient(150deg, #1E0740, #380B62, #1C0538);
  border-color: rgba(207,106,255,.3);
}
.vp-card--teen:hover {
  box-shadow: 0 16px 48px rgba(207,106,255,.3);
  border-color: rgba(207,106,255,.6);
}
.vp-card--adult {
  background: linear-gradient(150deg, #0C0A1A, #1C1135, #100E22);
  border-color: rgba(240,180,41,.22);
}
.vp-card--adult:hover {
  box-shadow: 0 16px 48px rgba(240,180,41,.2);
  border-color: rgba(240,180,41,.5);
}
.vp-card--emergency {
  background: linear-gradient(150deg, #1E0606, #3A0D0D, #1A0404);
  border-color: rgba(239,68,68,.32);
}
.vp-card--emergency:hover {
  box-shadow: 0 16px 48px rgba(239,68,68,.32);
  border-color: rgba(239,68,68,.7);
}
.vp-card--gifter {
  background: linear-gradient(150deg, #1E0816, #3A0F2A, #1A0612);
  border-color: rgba(244,114,182,.28);
}
.vp-card--gifter:hover {
  box-shadow: 0 16px 48px rgba(244,114,182,.26);
  border-color: rgba(244,114,182,.65);
}

.vp-card-glow {
  position: absolute; top: -20px; right: -20px;
  width: 110px; height: 110px; border-radius: 50%;
  pointer-events: none;
}
.vp-card-glow--teen      { background: radial-gradient(circle, rgba(207,106,255,.4)  0%, transparent 70%); }
.vp-card-glow--adult     { background: radial-gradient(circle, rgba(240,180,41,.28)  0%, transparent 70%); }
.vp-card-glow--emergency { background: radial-gradient(circle, rgba(239,68,68,.42)   0%, transparent 70%); }
.vp-card-glow--gifter    { background: radial-gradient(circle, rgba(244,114,182,.38) 0%, transparent 70%); }

.vp-card-tag {
  font-size: .62rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .12em;
}
.vp-card--teen .vp-card-tag      { color: #CF6AFF; }
.vp-card--adult .vp-card-tag     { color: #F0B429; }
.vp-card--emergency .vp-card-tag { color: #FF6B6B; }
.vp-card--gifter .vp-card-tag    { color: #F472B6; }

.vp-card-emoji { font-size: 1.45rem; line-height: 1; margin: var(--sp-1) 0; }

.vp-card-title {
  font-family: var(--font-display);
  font-size: var(--text-base); font-weight: 600;
  color: #EDE8FA; line-height: 1.25;
}
.vp-card-desc {
  font-size: var(--text-xs); color: rgba(237,232,250,.48);
  line-height: 1.65; flex: 1;
}
.vp-card-cta {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  font-size: var(--text-sm); font-weight: 700;
  margin-top: var(--sp-1);
}
.vp-card--teen .vp-card-cta      { color: #CF6AFF; }
.vp-card--adult .vp-card-cta     { color: #F0B429; }
.vp-card--emergency .vp-card-cta { color: #FF6B6B; }
.vp-card--gifter .vp-card-cta    { color: #F472B6; }

.vp-note {
  font-size: var(--text-xs); color: rgba(237,232,250,.2);
  letter-spacing: .02em;
}

/* =============================================
   TEEN THEME OVERRIDES
   ============================================= */

/* Teen dark — brighter, more vibrant purple */
[data-version='teen'][data-theme='dark'],
[data-version='teen']:not([data-theme='light']) {
  --accent:              #CF6AFF;
  --accent-hover:        #DB80FF;
  --accent-active:       #E590FF;
  --accent-subtle:       #220A3A;
  --accent-subtle-hover: #2E1048;
  --shadow-lg:           0 12px 48px rgba(207,106,255,.28);
  --shadow-md:           0 4px 20px rgba(207,106,255,.18);
}

/* Teen light — richer purple */
[data-version='teen'][data-theme='light'] {
  --accent:        #9B20D0;
  --accent-hover:  #8019B5;
  --accent-subtle: #F5E8FF;
}

/* Rounder corners across the board in teen mode */
[data-version='teen'] {
  --r-lg:  1.25rem;
  --r-xl:  2rem;
  --r-2xl: 2.5rem;
}

/* Teen hero — deeper, more vivid purple gradient */
[data-version='teen'] .home-hero {
  background: linear-gradient(170deg, #0D0520 0%, #2C0A55 55%, #0D0520 100%);
}
[data-version='teen'] .home-hero::before {
  background: radial-gradient(circle, rgba(180,30,220,.48) 0%, transparent 70%);
}
[data-version='teen'] .home-hero::after {
  background: radial-gradient(circle, rgba(207,106,255,.12) 0%, transparent 70%);
}

/* Teen subscribe hero */
[data-version='teen'] .subscribe-hero {
  background: linear-gradient(170deg, #0D0520, #2C0A55, #0D0520);
}
[data-version='teen'] .subscribe-hero::before {
  background: radial-gradient(circle, rgba(180,30,220,.3), transparent 70%);
}

/* Teen subscribe title span color */
[data-version='teen'] .subscribe-title span { color: #CF6AFF; }

/* =============================================
   EMERGENCY THEME OVERRIDES
   ============================================= */

[data-version='emergency'][data-theme='dark'],
[data-version='emergency']:not([data-theme='light']) {
  --accent:              #EF4444;
  --accent-hover:        #F87171;
  --accent-active:       #FCA5A5;
  --accent-subtle:       #3A0808;
  --accent-fg:           #ffffff;
  --hero-accent-glow:    rgba(239,68,68,.35);
}

[data-version='emergency'][data-theme='light'] {
  --accent:              #DC2626;
  --accent-hover:        #EF4444;
  --accent-fg:           #ffffff;
}

/* =============================================
   GIFTER THEME OVERRIDES
   ============================================= */

[data-version='gifter'][data-theme='dark'],
[data-version='gifter']:not([data-theme='light']) {
  --accent:              #EC4899;
  --accent-hover:        #F472B6;
  --accent-active:       #F9A8D4;
  --accent-subtle:       #3D0820;
  --accent-fg:           #ffffff;
  --hero-accent-glow:    rgba(236,72,153,.35);
}

[data-version='gifter'][data-theme='light'] {
  --accent:              #DB2777;
  --accent-hover:        #EC4899;
  --accent-fg:           #ffffff;
}

/* ==============================================
   TRENDING STRIP
   ============================================== */
.trending-strip {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: 0 var(--sp-5);
  height: var(--trending-h);
  background: var(--surface-2);
  border-bottom: 1px solid var(--border);
  overflow: hidden;
  /* Fixed below the main header — always visible on all views */
  position: fixed;
  top: var(--header-h);
  left: 0;
  right: 0;
  z-index: 99;
  box-shadow: 0 2px 8px rgba(0,0,0,.22);
}

.trending-label {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--gold);
  white-space: nowrap;
  letter-spacing: .04em;
  text-transform: uppercase;
  flex-shrink: 0;
}

.trending-pills {
  display: flex;
  gap: var(--sp-2);
  overflow-x: auto;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  flex: 1;
}
.trending-pills::-webkit-scrollbar { display: none; }

.trending-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-1);
  padding: var(--sp-1) var(--sp-3);
  background: var(--surface-offset);
  border: 1.5px solid var(--border);
  border-radius: var(--r-full);
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--text-muted);
  white-space: nowrap;
  flex-shrink: 0;
  cursor: pointer;
  transition: border-color var(--trans), color var(--trans), background var(--trans);
}
.trending-pill:hover {
  border-color: var(--accent);
  color: var(--text);
  background: var(--accent-subtle);
}
.trending-pill .fire { color: var(--gold); }

/* weekly focus pill */
.trending-pill--focus {
  border-color: var(--gold);
  color: var(--gold);
  background: var(--gold-subtle);
}
.trending-pill--focus:hover {
  background: var(--gold-subtle);
  border-color: var(--gold-hover);
}

/* ==============================================
   NEWSLETTER HOME CTA SECTION
   ============================================== */
.nl-home-cta {
  margin: var(--sp-6) var(--sp-5);
  background: linear-gradient(135deg, var(--surface-2) 0%, var(--surface-offset) 100%);
  border: 1.5px solid var(--accent-subtle);
  border-radius: var(--r-xl);
  padding: var(--sp-5) var(--sp-5);
  position: relative;
  overflow: hidden;
}
.nl-home-cta::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 80% 20%, rgba(168,85,247,.08) 0%, transparent 60%);
  pointer-events: none;
}

.nl-home-inner { position: relative; z-index: 1; }

.nl-home-eyebrow {
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: var(--sp-3);
}

.nl-home-h3 {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 600;
  color: var(--text);
  margin-bottom: var(--sp-3);
  line-height: 1.2;
}

.nl-home-sub {
  font-size: var(--text-sm);
  color: var(--text-muted);
  line-height: 1.6;
  margin-bottom: var(--sp-5);
}

.nl-home-perks {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  margin-bottom: var(--sp-6);
}
.nl-home-perks li {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  font-size: var(--text-sm);
  color: var(--text-muted);
}
.nl-home-perks li span:first-child { font-size: 1rem; flex-shrink: 0; }

.nl-home-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-6);
  background: var(--accent);
  color: #fff;
  border-radius: var(--r-full);
  font-size: var(--text-sm);
  font-weight: 700;
  letter-spacing: .02em;
  transition: background var(--trans), transform 80ms ease, box-shadow var(--trans);
  box-shadow: 0 4px 16px rgba(168,85,247,.28);
}
.nl-home-btn:hover  { background: var(--accent-hover); box-shadow: 0 6px 20px rgba(168,85,247,.38); }
.nl-home-btn:active { transform: scale(.97); }

/* ==============================================
   TRACKER ACCESS BUTTON (home footer)
   ============================================== */
.tracker-access-btn {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-4);
  background: var(--surface-2);
  border: 1.5px solid var(--border);
  border-radius: var(--r-full);
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--text-muted);
  margin: var(--sp-3) auto var(--sp-2);
  width: fit-content;
  transition: border-color var(--trans), color var(--trans), background var(--trans);
}
.tracker-access-btn:hover {
  border-color: var(--accent);
  color: var(--text);
  background: var(--accent-subtle);
}
.tracker-access-btn .tlock { font-size: .85em; opacity: .7; }
.tracker-access-btn.unlocked .tlock { display: none; }
.tracker-access-btn.unlocked { border-color: var(--gold); color: var(--gold); }
.tracker-access-btn.unlocked:hover { background: var(--gold-subtle); border-color: var(--gold-hover); }

/* ==============================================
   NEWSLETTER MODAL
   ============================================== */
.nl-modal {
  position: fixed;
  inset: 0;
  z-index: 9000;
  background: rgba(8,6,16,.75);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 0;
  animation: nlFadeIn 220ms ease forwards;
}
@keyframes nlFadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@media (min-width: 560px) {
  .nl-modal { align-items: center; padding: var(--sp-5); }
}

.nl-modal-inner {
  position: relative;
  width: 100%;
  max-width: 520px;
  max-height: 92dvh;
  overflow-y: auto;
  background: var(--surface);
  border-radius: var(--r-2xl) var(--r-2xl) 0 0;
  padding: var(--sp-8) var(--sp-6) var(--sp-10);
  scrollbar-width: none;
  animation: nlSlideUp 300ms cubic-bezier(.16,1,.3,1) forwards;
}
.nl-modal-inner::-webkit-scrollbar { display: none; }

@media (min-width: 560px) {
  .nl-modal-inner {
    border-radius: var(--r-2xl);
    padding: var(--sp-10) var(--sp-8);
    animation: nlScaleIn 280ms cubic-bezier(.16,1,.3,1) forwards;
  }
}

@keyframes nlSlideUp {
  from { transform: translateY(40px); opacity: 0; }
  to   { transform: translateY(0);    opacity: 1; }
}
@keyframes nlScaleIn {
  from { transform: scale(.95) translateY(8px); opacity: 0; }
  to   { transform: scale(1)   translateY(0);   opacity: 1; }
}

.nl-close-btn {
  position: absolute;
  top: var(--sp-5);
  right: var(--sp-5);
  width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  background: var(--surface-2);
  border: 1.5px solid var(--border);
  border-radius: var(--r-full);
  color: var(--text-muted);
  transition: background var(--trans), color var(--trans), border-color var(--trans);
  flex-shrink: 0;
}
.nl-close-btn:hover { background: var(--surface-offset); color: var(--text); border-color: var(--accent); }

.nl-brand-mark {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-1);
  margin-bottom: var(--sp-5);
}
.nl-crown { width: 56px; height: auto; }
.nl-dot {
  font-family: var(--font-display);
  font-size: 3.5rem;
  font-weight: 600;
  color: #D4AF37;
  line-height: 1;
  text-shadow: 0 0 18px rgba(240,180,41,.45);
}
[data-theme='light'] .nl-dot { text-shadow: none; }

.nl-title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 600;
  color: var(--text);
  text-align: center;
  line-height: 1.2;
  margin-bottom: var(--sp-2);
}

.nl-eyebrow {
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--accent);
  text-align: center;
  margin-bottom: var(--sp-5);
}

/* Rotating fact teaser card */
.nl-fact-card {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  background: var(--surface-2);
  border: 1.5px solid var(--border);
  border-left: 3px solid var(--accent);
  border-radius: var(--r-lg);
  padding: var(--sp-4) var(--sp-5);
  margin-bottom: var(--sp-5);
}
.nl-fact-icon { font-size: 1.4rem; flex-shrink: 0; margin-top: 1px; }
.nl-fact-text {
  font-size: var(--text-sm);
  color: var(--text-muted);
  line-height: 1.6;
}

/* Perks list */
.nl-perks {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  margin-bottom: var(--sp-6);
}
.nl-perks li {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  font-size: var(--text-sm);
  color: var(--text-muted);
  line-height: 1.5;
}
.nl-perks li > span:first-child { font-size: 1.1rem; flex-shrink: 0; padding-top: 1px; }
.nl-perks li strong { color: var(--text); display: block; }

/* Life stage selector */
.nl-stage-label {
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--text-faint);
  margin-bottom: var(--sp-3);
}
.nl-stage-row {
  display: flex;
  gap: var(--sp-2);
  flex-wrap: wrap;
  margin-bottom: var(--sp-5);
}
.nl-stage-btn {
  flex: 1;
  min-width: 80px;
  padding: var(--sp-2) var(--sp-3);
  background: var(--surface-2);
  border: 1.5px solid var(--border);
  border-radius: var(--r-full);
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--text-muted);
  text-align: center;
  transition: border-color var(--trans), color var(--trans), background var(--trans);
}
.nl-stage-btn:hover { border-color: var(--accent); color: var(--text); }
.nl-stage-btn.active {
  border-color: var(--accent);
  background: var(--accent);
  color: #fff;
}

/* Email input row */
.nl-input-row {
  display: flex;
  gap: var(--sp-2);
  margin-bottom: var(--sp-3);
}
#nlEmailInput {
  flex: 1;
  height: 48px;
  padding: 0 var(--sp-4);
  background: var(--surface-2);
  border: 1.5px solid var(--border);
  border-radius: var(--r-full);
  font-size: var(--text-sm);
  color: var(--text);
  outline: none;
  transition: border-color var(--trans), box-shadow var(--trans);
}
#nlEmailInput:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(168,85,247,.18); }
#nlEmailInput::placeholder { color: var(--text-faint); }

.nl-submit-btn {
  width: 48px; height: 48px;
  border-radius: var(--r-full);
  background: var(--accent);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: background var(--trans), transform 80ms ease;
  box-shadow: 0 4px 14px rgba(168,85,247,.32);
}
.nl-submit-btn:hover  { background: var(--accent-hover); }
.nl-submit-btn:active { transform: scale(.93); }

.nl-privacy {
  font-size: var(--text-xs);
  color: var(--text-faint);
  text-align: center;
  line-height: 1.5;
}

/* Success state */
.nl-success {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: var(--sp-6) 0;
}
.nl-success-icon { font-size: 3.5rem; margin-bottom: var(--sp-4); }
.nl-success-h3 {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--text);
  margin-bottom: var(--sp-3);
}
.nl-success-p {
  font-size: var(--text-sm);
  color: var(--text-muted);
  line-height: 1.6;
  margin-bottom: var(--sp-6);
  max-width: 300px;
}
.nl-open-tracker {
  padding: var(--sp-3) var(--sp-8);
  background: var(--accent);
  color: #fff;
  border-radius: var(--r-full);
  font-size: var(--text-sm);
  font-weight: 700;
  box-shadow: 0 4px 16px rgba(168,85,247,.28);
  transition: background var(--trans), transform 80ms ease;
}
.nl-open-tracker:hover  { background: var(--accent-hover); }
.nl-open-tracker:active { transform: scale(.96); }

/* ==============================================
   TRACKER VIEW
   ============================================== */

/* Phase Card */
.tracker-phase-card {
  margin: var(--sp-5) var(--sp-5) 0;
  background: linear-gradient(135deg, var(--surface-2), var(--surface-offset));
  border: 1.5px solid var(--accent-subtle);
  border-radius: var(--r-xl);
  padding: var(--sp-5) var(--sp-6);
  position: relative;
  overflow: hidden;
}
.tracker-phase-card::before {
  content: '';
  position: absolute;
  top: -30px; right: -30px;
  width: 120px; height: 120px;
  background: radial-gradient(circle, rgba(168,85,247,.15) 0%, transparent 70%);
  pointer-events: none;
}

.tpc-row {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  margin-bottom: var(--sp-3);
}
.tpc-emoji { font-size: 2.5rem; flex-shrink: 0; }
.tpc-phase {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--text);
  line-height: 1.2;
}
.tpc-day {
  font-size: var(--text-sm);
  color: var(--text-muted);
  margin-top: var(--sp-1);
}
.tpc-next {
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--accent);
  background: var(--accent-subtle);
  display: inline-block;
  padding: var(--sp-1) var(--sp-3);
  border-radius: var(--r-full);
  margin-bottom: var(--sp-3);
}
.tpc-next:empty { display: none; }
.tpc-tip {
  font-size: var(--text-xs);
  color: var(--text-muted);
  line-height: 1.5;
  border-top: 1px solid var(--border);
  padding-top: var(--sp-3);
  margin-top: var(--sp-1);
}
.tpc-tip:empty { display: none; }

/* Calendar Navigation */
.tracker-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-5) var(--sp-5) var(--sp-3);
}
.tracker-nav-btn {
  width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  background: var(--surface-2);
  border: 1.5px solid var(--border);
  border-radius: var(--r-full);
  color: var(--text-muted);
  transition: background var(--trans), border-color var(--trans), color var(--trans);
}
.tracker-nav-btn:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-subtle); }

.tracker-month-label {
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--text);
  letter-spacing: .02em;
}

/* Day-of-week header */
.tracker-dow-row {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  padding: 0 var(--sp-5);
  margin-bottom: var(--sp-2);
}
.tracker-dow-row span {
  text-align: center;
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--text-faint);
  letter-spacing: .06em;
  padding: var(--sp-2) 0;
}

/* Calendar Grid */
.tracker-cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  padding: 0 var(--sp-5);
  gap: var(--sp-1);
  margin-bottom: var(--sp-4);
}

.tcal-day {
  position: relative;
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--r-full);
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--text-muted);
  cursor: pointer;
  transition: background var(--trans), color var(--trans);
  user-select: none;
}
.tcal-day:hover { background: var(--surface-2); color: var(--text); }
.tcal-day.empty { cursor: default; pointer-events: none; }

/* Today */
.tcal-day.today {
  font-weight: 700;
  color: var(--gold);
  box-shadow: 0 0 0 2px var(--gold);
}

/* Logged period day */
.tcal-day.period-logged {
  background: var(--accent);
  color: #fff;
  font-weight: 700;
}
.tcal-day.period-logged:hover { background: var(--accent-hover); }

/* Predicted period */
.tcal-day.period-predicted {
  border: 2px dashed var(--accent);
  color: var(--accent);
  background: var(--accent-subtle);
}

/* Ovulation window */
.tcal-day.ovulation {
  background: rgba(20, 184, 166, .18);
  color: #14b8a6;
  border: 1.5px solid rgba(20, 184, 166, .35);
}

/* Today + logged */
.tcal-day.today.period-logged {
  background: var(--accent);
  box-shadow: 0 0 0 2.5px var(--gold);
  color: #fff;
}

/* Calendar Legend */
.tracker-legend {
  display: flex;
  gap: var(--sp-5);
  flex-wrap: wrap;
  padding: 0 var(--sp-5) var(--sp-4);
}
.tleg-item {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--text-xs);
  color: var(--text-muted);
}
.tleg-dot {
  width: 10px; height: 10px;
  border-radius: var(--r-full);
  flex-shrink: 0;
}
.tleg-logged    { background: var(--accent); }
.tleg-predicted { border: 2px dashed var(--accent); background: transparent; }
.tleg-ovulation { background: #14b8a6; }
.tleg-today     { background: transparent; box-shadow: 0 0 0 2px var(--gold); }

/* Log Buttons */
.tracker-log-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-3);
  padding: 0 var(--sp-5) var(--sp-5);
}
.tracker-log-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  height: 44px;
  border-radius: var(--r-lg);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: .03em;
  border: 2px solid transparent;
  transition: background var(--trans), border-color var(--trans), color var(--trans), transform 80ms ease;
}
.tracker-log-btn:active { transform: scale(.96); }

.tracker-log-start {
  background: var(--accent);
  color: #fff;
  box-shadow: 0 4px 14px rgba(168,85,247,.28);
}
.tracker-log-start:hover { background: var(--accent-hover); }

.tracker-log-end {
  background: var(--surface-2);
  border-color: var(--border);
  color: var(--text-muted);
}
.tracker-log-end:hover { border-color: var(--accent); color: var(--text); background: var(--accent-subtle); }
.tracker-log-end.active {
  background: var(--accent-subtle);
  border-color: var(--accent);
  color: var(--accent);
}

/* Stats Row */
.tracker-stats-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-3);
  padding: 0 var(--sp-5) var(--sp-5);
}
.tstat {
  background: var(--surface-2);
  border: 1.5px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-4) var(--sp-3);
  text-align: center;
}
.tstat-val {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--accent);
  line-height: 1.1;
  margin-bottom: var(--sp-1);
}
.tstat-label {
  font-size: var(--text-xs);
  color: var(--text-faint);
  line-height: 1.4;
}

/* Educational Fact Card */
.tracker-edu-card {
  margin: 0 var(--sp-5) var(--sp-10);
  background: var(--surface-2);
  border: 1.5px solid var(--border);
  border-left: 3px solid var(--gold);
  border-radius: var(--r-lg);
  padding: var(--sp-5) var(--sp-5);
}
.tec-eyebrow {
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: var(--sp-3);
}
.tec-text {
  font-size: var(--text-sm);
  color: var(--text-muted);
  line-height: 1.65;
  margin-bottom: var(--sp-3);
}
.tec-link {
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
  transition: color var(--trans);
}
.tec-link:hover { color: var(--accent-hover); text-decoration: underline; }

/* Version-specific tracker phase accents */
[data-version='teen'] .tpc-next    { color: #CF6AFF; background: rgba(207,106,255,.12); }
[data-version='teen'] .tstat-val   { color: #CF6AFF; }
[data-version='emergency'] .tpc-next  { color: #EF4444; background: rgba(239,68,68,.12); }
[data-version='emergency'] .tstat-val { color: #EF4444; }
[data-version='gifter'] .tpc-next     { color: #EC4899; background: rgba(236,72,153,.12); }
[data-version='gifter'] .tstat-val    { color: #EC4899; }

/* ==============================================
   HOLISTIC THEME OVERRIDES
   ============================================== */

[data-version='holistic'][data-theme='dark'],
[data-version='holistic']:not([data-theme='light']) {
  --accent:              #34D399;
  --accent-hover:        #6EE7B7;
  --accent-active:       #A7F3D0;
  --accent-subtle:       #022C22;
  --accent-subtle-hover: #064E3B;
  --accent-fg:           #022C22;
  --shadow-lg:           0 12px 48px rgba(52,211,153,.22);
  --shadow-md:           0 4px 20px rgba(52,211,153,.14);
}

[data-version='holistic'][data-theme='light'] {
  --accent:        #059669;
  --accent-hover:  #047857;
  --accent-subtle: #ECFDF5;
  --accent-fg:     #ffffff;
}

/* Holistic hero gradient */
[data-version='holistic'] .home-hero {
  background: linear-gradient(170deg, #061A10 0%, #0D2E1A 55%, #061A10 100%);
}
[data-version='holistic'] .home-hero::before {
  background: radial-gradient(circle, rgba(52,211,153,.28) 0%, transparent 70%);
}
[data-version='holistic'] .home-hero::after {
  background: radial-gradient(circle, rgba(52,211,153,.08) 0%, transparent 70%);
}
[data-version='holistic'] .subscribe-hero {
  background: linear-gradient(170deg, #061A10, #0D2E1A, #061A10);
}
[data-version='holistic'] .subscribe-title span { color: #34D399; }

/* ==============================================
   VERSION PICKER — HOLISTIC CARD
   ============================================== */

.vp-card--holistic {
  background: linear-gradient(160deg, #071A0E 0%, #0D2E18 60%, #071A0E 100%);
  border-color: rgba(52,211,153,.25);
}
.vp-card--holistic:hover { border-color: rgba(52,211,153,.55); }
.vp-card-glow--holistic {
  background: radial-gradient(circle at 50% 0%, rgba(52,211,153,.35) 0%, transparent 65%);
}
.vp-card--holistic .vp-card-tag  { color: #34D399; background: rgba(52,211,153,.12); border-color: rgba(52,211,153,.25); }
.vp-card--holistic .vp-card-cta  { color: #34D399; }
.vp-card--holistic .vp-card-cta svg { stroke: #34D399; }

/* Holistic card spans full width at the bottom (5th card) */
.vp-cards { grid-template-columns: 1fr 1fr; }
.vp-card--holistic {
  grid-column: 1 / -1;
  flex-direction: row;
  align-items: center;
  gap: var(--sp-4);
  text-align: left;
}
.vp-card--holistic .vp-card-emoji { font-size: 2.2rem; flex-shrink: 0; }
.vp-card--holistic .vp-card-title { font-size: var(--text-base); }

/* ==============================================
   HOME MODE CARD — HOLISTIC
   ============================================== */

.mode-card--holistic {
  border-color: rgba(52,211,153,.25);
  background: linear-gradient(160deg, #071A0E 0%, #0D2E18 100%);
}
.mode-card--holistic:hover {
  border-color: rgba(52,211,153,.5);
  box-shadow: 0 8px 28px rgba(52,211,153,.18);
}
.mode-card--holistic .mode-card-icon { background: rgba(52,211,153,.1); }
.mode-card--holistic .mode-card-title { color: #34D399; }
.mode-card--holistic .mode-card-link  { color: #34D399; }
.mode-card--holistic .mode-card-link svg { stroke: #34D399; }

/* ==============================================
   REMINDER SECTION (in Tracker View)
   ============================================== */

.reminder-section {
  margin: 0 var(--sp-5) var(--sp-5);
  background: var(--surface-2);
  border: 1.5px solid var(--border);
  border-radius: var(--r-xl);
  overflow: hidden;
}

.rem-header {
  padding: var(--sp-5) var(--sp-5) var(--sp-4);
  border-bottom: 1px solid var(--border);
}
.rem-title {
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--text);
  margin-bottom: var(--sp-1);
}
.rem-sub {
  font-size: var(--text-xs);
  color: var(--text-muted);
  line-height: 1.5;
}

/* Tabs */
.rem-tabs {
  display: flex;
  border-bottom: 1px solid var(--border);
}
.rem-tab {
  flex: 1;
  padding: var(--sp-3) var(--sp-4);
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--text-muted);
  text-align: center;
  border-bottom: 2px solid transparent;
  transition: color var(--trans), border-color var(--trans);
  background: none;
}
.rem-tab:hover { color: var(--text); }
.rem-tab.active {
  color: var(--accent);
  border-bottom-color: var(--accent);
}

/* Panel content */
.rem-panel { padding: var(--sp-5); }

.rem-panel-desc {
  font-size: var(--text-xs);
  color: var(--text-muted);
  line-height: 1.6;
  margin-bottom: var(--sp-4);
}

.rem-days-label {
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: var(--text-faint);
  margin-bottom: var(--sp-2);
}

.rem-days-row {
  display: flex;
  gap: var(--sp-2);
  flex-wrap: wrap;
  margin-bottom: var(--sp-4);
}

.rem-days-btn {
  flex: 1;
  min-width: 60px;
  padding: var(--sp-2) var(--sp-2);
  background: var(--surface-offset);
  border: 1.5px solid var(--border);
  border-radius: var(--r-full);
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--text-muted);
  text-align: center;
  transition: border-color var(--trans), color var(--trans), background var(--trans);
}
.rem-days-btn:hover  { border-color: var(--accent); color: var(--text); }
.rem-days-btn.active { border-color: var(--accent); background: var(--accent); color: #fff; }

/* Enable / Save button */
.rem-enable-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  width: 100%;
  height: 44px;
  background: var(--accent);
  color: #fff;
  border-radius: var(--r-lg);
  font-size: var(--text-sm);
  font-weight: 700;
  box-shadow: 0 4px 14px rgba(168,85,247,.24);
  transition: background var(--trans), transform 80ms ease;
  margin-bottom: var(--sp-3);
}
.rem-enable-btn:hover  { background: var(--accent-hover); }
.rem-enable-btn:active { transform: scale(.97); }

/* SMS input row */
.rem-input-row {
  display: flex;
  gap: var(--sp-2);
  margin-bottom: var(--sp-3);
}
#remSmsInput {
  flex: 1;
  height: 44px;
  padding: 0 var(--sp-4);
  background: var(--surface-offset);
  border: 1.5px solid var(--border);
  border-radius: var(--r-lg);
  font-size: var(--text-sm);
  color: var(--text);
  outline: none;
  transition: border-color var(--trans), box-shadow var(--trans);
}
#remSmsInput:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(168,85,247,.15); }
#remSmsInput::placeholder { color: var(--text-faint); }

.rem-save-btn {
  height: 44px;
  padding: 0 var(--sp-5);
  background: var(--accent);
  color: #fff;
  border-radius: var(--r-lg);
  font-size: var(--text-xs);
  font-weight: 700;
  display: flex; align-items: center; gap: var(--sp-2);
  flex-shrink: 0;
  transition: background var(--trans);
  box-shadow: 0 4px 12px rgba(168,85,247,.22);
}
.rem-save-btn:hover  { background: var(--accent-hover); }

.rem-sms-note {
  font-size: var(--text-xs);
  color: var(--text-faint);
  line-height: 1.5;
  margin-bottom: var(--sp-2);
}

.rem-status {
  font-size: var(--text-xs);
  color: var(--success);
  font-weight: 600;
  padding: var(--sp-2) var(--sp-3);
  background: rgba(45,122,74,.1);
  border: 1px solid rgba(45,122,74,.2);
  border-radius: var(--r-md);
  line-height: 1.5;
}

/* Holistic reminder accent */
[data-version='holistic'] .rem-enable-btn { box-shadow: 0 4px 14px rgba(52,211,153,.24); }
[data-version='holistic'] .rem-save-btn   { box-shadow: 0 4px 12px rgba(52,211,153,.22); }

/* ===== PICKER CATEGORY FILTER BAR ===== */
.picker-filter-bar {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding: 0 var(--sp-4) var(--sp-3);
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  flex-wrap: nowrap;
}
.picker-filter-bar::-webkit-scrollbar { display: none; }

.picker-filter-tab {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 7px 14px;
  border-radius: 999px;
  border: 1.5px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.05);
  color: rgba(255,255,255,0.6);
  font-size: var(--text-xs);
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: all 0.18s ease;
}
.picker-filter-tab:hover {
  border-color: rgba(255,255,255,0.28);
  color: #fff;
  background: rgba(255,255,255,0.1);
}
.picker-filter-tab.active {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
  box-shadow: 0 0 12px rgba(168,85,247,0.4);
}

/* Category label on picker cards */
.picker-cat {
  font-size: 10px;
  color: rgba(255,255,255,0.4);
  font-weight: 500;
  margin-top: 2px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* Empty state */
.picker-empty {
  grid-column: 1/-1;
  text-align: center;
  color: rgba(255,255,255,0.35);
  font-size: var(--text-sm);
  padding: var(--sp-8) 0;
}

/* =============================================
   LEGAL MODAL
   ============================================= */
.legal-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.6);
  z-index: 1100;
  backdrop-filter: blur(4px);
}
.legal-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 1101;
  align-items: flex-end;
  justify-content: center;
}
@media (min-width: 640px) {
  .legal-modal { align-items: center; }
}
.legal-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.25rem 1.5rem 1rem;
  border-bottom: 1px solid rgba(255,255,255,.08);
  position: sticky;
  top: 0;
  background: #1a1026;
  z-index: 1;
}
.legal-modal-title {
  font-size: 1.05rem;
  font-weight: 700;
  color: #fff;
  margin: 0;
  letter-spacing: .01em;
}
.legal-modal-close {
  background: rgba(255,255,255,.08);
  border: none;
  border-radius: 50%;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: rgba(255,255,255,.7);
  flex-shrink: 0;
  transition: background .15s;
}
.legal-modal-close:hover { background: rgba(255,255,255,.15); }
.legal-modal-body {
  padding: 1.25rem 1.5rem 2rem;
  overflow-y: auto;
  flex: 1;
  /* scroll within the modal itself */
  max-height: calc(80vh - 64px);
}
/* The actual modal card */
.legal-modal[role="dialog"] {
  /* override the flex container display trick */
}
/* Inner card wrapper */
.legal-modal > * {
  /* nothing extra — the modal IS the card */
}

/* Re-style: make the modal itself the scrollable card */
div#legalModal {
  display: none; /* JS controls via style.display='flex' */
  position: fixed;
  inset: 0;
  z-index: 1101;
  align-items: flex-end;
  justify-content: center;
  padding: 0;
}
@media (min-width: 640px) {
  div#legalModal { align-items: center; padding: 1.5rem; }
}
div#legalModal > .legal-modal-header,
div#legalModal > .legal-modal-body {
  /* children live inside the card below */
}
/* Actual card — wrap header + body in a visual container using a pseudo approach.
   Since we can't wrap them without changing HTML, we style legalModal itself as the card. */
div#legalModal {
  background: transparent;
}
/* Card visual: apply background to the direct children collectively via a wrapper trick.
   Since legalModalHeader + legalModalBody are siblings, target legalModal's layout. */
.legal-modal-header { border-radius: 20px 20px 0 0; }
@media (min-width: 640px) {
  .legal-modal-header { border-radius: 16px 16px 0 0; }
}

/* Build a real card container */
div#legalModal::before {
  content: '';
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0;
  width: min(100%, 640px);
  height: min(82vh, 640px);
  background: #1a1026;
  border-radius: 20px 20px 0 0;
  z-index: -1;
  box-shadow: 0 -8px 48px rgba(0,0,0,.5);
}
@media (min-width: 640px) {
  div#legalModal::before {
    bottom: auto;
    top: 50%;
    transform: translate(-50%,-50%);
    border-radius: 16px;
    height: auto;
  }
}

/* Direct children of legalModal need to be in the visible card */
.legal-modal-header,
.legal-modal-body {
  width: min(100%, 640px);
  background: #1a1026;
}
.legal-modal-header {
  border-radius: 20px 20px 0 0;
  box-shadow: 0 -4px 32px rgba(0,0,0,.4);
}
.legal-modal-body {
  border-radius: 0 0 0 0;
}
@media (min-width: 640px) {
  .legal-modal-header { border-radius: 16px 16px 0 0; }
}

/* Legal content typography */
.legal-modal-body h2 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--accent, #A855F7);
  margin: 1.4rem 0 .4rem;
}
.legal-modal-body h3 {
  font-size: .92rem;
  font-weight: 600;
  color: rgba(255,255,255,.9);
  margin: 1rem 0 .3rem;
}
.legal-modal-body p,
.legal-modal-body li {
  font-size: .85rem;
  line-height: 1.65;
  color: rgba(255,255,255,.65);
  margin-bottom: .5rem;
}
.legal-modal-body ul {
  padding-left: 1.25rem;
  margin-bottom: .75rem;
}
.legal-modal-body a {
  color: var(--accent, #A855F7);
  text-decoration: none;
}
.legal-modal-body a:hover { text-decoration: underline; }
.legal-updated {
  font-size: .75rem;
  color: rgba(255,255,255,.35);
  margin-bottom: 1rem;
}

/* Legal footer */
.legal-footer-links {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: .35rem .5rem;
  padding: .6rem 1rem .5rem;
  margin-top: .5rem;
}
.legal-link {
  background: none;
  border: none;
  cursor: pointer;
  font-size: .72rem;
  color: rgba(255,255,255,.4);
  padding: 0;
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color .15s;
}
.legal-link:hover { color: rgba(255,255,255,.75); }
.legal-dot {
  font-size: .72rem;
  color: rgba(255,255,255,.25);
}
.legal-copy {
  font-size: .72rem;
  color: rgba(255,255,255,.3);
}

/* =============================================
   EXPRESS CHECKOUT — APPLE PAY & GOOGLE PAY
   ============================================= */
.express-checkout {
  display: flex;
  gap: .6rem;
  margin-top: .75rem;
}
.pay-btn {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .45rem;
  height: 46px;
  border: none;
  border-radius: 12px;
  font-size: .82rem;
  font-weight: 700;
  cursor: pointer;
  transition: opacity .15s, transform .1s;
  letter-spacing: .01em;
}
.pay-btn:active { transform: scale(.97); opacity: .85; }
.pay-btn svg { flex-shrink: 0; }

/* Apple Pay — black pill, white text */
.apple-pay-btn {
  background: #000;
  color: #fff;
  border: 1px solid rgba(255,255,255,.12);
}
.apple-pay-btn svg {
  width: 36px;
  height: 15px;
  fill: #fff;
}
.apple-pay-btn:hover { background: #111; }

/* Google Pay — white pill, dark text */
.google-pay-btn {
  background: #fff;
  color: #3c4043;
  border: 1px solid rgba(0,0,0,.08);
}
.google-pay-btn svg {
  width: 40px;
  height: 16px;
}
.google-pay-btn:hover { background: #f8f8f8; }

/* "or" divider between express and standard checkout */
.pay-divider {
  display: flex;
  align-items: center;
  gap: .5rem;
  margin: .8rem 0 .1rem;
  color: rgba(255,255,255,.25);
  font-size: .72rem;
}
.pay-divider::before,
.pay-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: rgba(255,255,255,.1);
}

/* Stripe trust badge in cart footer */
.stripe-badge {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .3rem;
  margin-top: .6rem;
  font-size: .68rem;
  color: rgba(255,255,255,.28);
}
.stripe-badge svg { opacity: .4; }

/* =============================================
   CATEGORY GRID — shop browse view
   ============================================= */
.category-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-4) var(--sp-8);
}
@media (min-width: 480px) {
  .category-grid { grid-template-columns: repeat(3, 1fr); }
}

.cat-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  padding: var(--sp-4) var(--sp-3);
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: 16px;
  cursor: pointer;
  transition: border-color var(--trans), background var(--trans), transform var(--trans), box-shadow var(--trans);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.cat-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--accent-subtle) 0%, transparent 70%);
  opacity: 0;
  transition: opacity var(--trans);
}
.cat-card:hover::before { opacity: 1; }
.cat-card:hover {
  border-color: var(--accent);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(168,85,247,.18);
}
.cat-card:active { transform: translateY(0); }

/* Favorites card special treatment */
.cat-card[data-cat="favorites"] {
  border-color: rgba(239,68,68,.35);
  background: linear-gradient(135deg, rgba(239,68,68,.06) 0%, var(--surface) 100%);
}
.cat-card[data-cat="favorites"]:hover {
  border-color: #ef4444;
  box-shadow: 0 6px 20px rgba(239,68,68,.2);
}

.cat-card-icon {
  font-size: 1.8rem;
  line-height: 1;
  position: relative;
}
.cat-card-name {
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--text);
  letter-spacing: .01em;
  position: relative;
}
.cat-card-count {
  font-size: .68rem;
  color: var(--text-muted);
  position: relative;
}

/* =============================================
   SHOP BREADCRUMB
   ============================================= */
.shop-breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--border);
}
.shop-back-cat-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-1);
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--accent);
  background: var(--accent-subtle);
  border: 1px solid rgba(168,85,247,.25);
  border-radius: var(--r-full);
  padding: .3rem .75rem;
  cursor: pointer;
  transition: background var(--trans), border-color var(--trans);
  white-space: nowrap;
}
.shop-back-cat-btn:hover {
  background: rgba(168,85,247,.2);
  border-color: var(--accent);
}
.shop-bc-title {
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* =============================================
   FAVORITES — heart button on product cards
   ============================================= */
.product-img { position: relative; }  /* ensure positioning context */

.fav-btn {
  position: absolute;
  top: var(--sp-2);
  right: var(--sp-2);
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: rgba(0,0,0,.45);
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: rgba(255,255,255,.55);
  transition: color var(--trans), background var(--trans), transform .1s;
  z-index: 2;
  backdrop-filter: blur(4px);
}
.fav-btn:hover { color: #ef4444; background: rgba(0,0,0,.6); }
.fav-btn:active { transform: scale(.88); }
.fav-btn.active {
  color: #ef4444;
  background: rgba(239,68,68,.2);
  border: 1px solid rgba(239,68,68,.4);
}
.fav-btn svg { pointer-events: none; }

/* =============================================
   MONTHLY UPSELL (post-order)
   ============================================= */
.monthly-upsell {
  margin-top: var(--sp-4);
  text-align: center;
}
.upsell-divider {
  width: 40px;
  height: 2px;
  background: var(--border);
  margin: 0 auto var(--sp-4);
  border-radius: 2px;
}
.upsell-question {
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--text);
  margin-bottom: var(--sp-1);
}
.upsell-sub {
  font-size: .78rem;
  color: var(--text-muted);
  line-height: 1.5;
  margin-bottom: var(--sp-3);
  padding: 0 var(--sp-2);
}
.upsell-btns {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}
.upsell-yes {
  background: linear-gradient(135deg, var(--accent), var(--accent-dark, #7c3aed));
  color: #fff;
  border: none;
  border-radius: var(--r-lg);
  padding: .65rem 1.2rem;
  font-size: var(--text-sm);
  font-weight: 700;
  cursor: pointer;
  transition: opacity var(--trans), transform .1s;
}
.upsell-yes:hover { opacity: .9; }
.upsell-yes:active { transform: scale(.97); }
.upsell-no {
  background: none;
  border: none;
  color: var(--text-muted);
  font-size: .78rem;
  cursor: pointer;
  padding: var(--sp-1);
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color var(--trans);
}
.upsell-no:hover { color: var(--text); }

/* =============================================
   EMERGENCY SHOP — stripped-down urgent UX
   ============================================= */

/* Hide trending strip + search bar in emergency mode — reduce visual noise */
[data-version="emergency"] .trending-strip { display: none !important; }
[data-version="emergency"] #shopView { padding-top: var(--header-h); }
[data-version="emergency"] .search-bar { display: none; }

/* Calm reassurance banner */
.emg-calm {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-5) var(--sp-5) var(--sp-4);
  background: linear-gradient(135deg, rgba(239,68,68,.08) 0%, rgba(13,10,20,.0) 60%);
  border-bottom: 1px solid rgba(239,68,68,.12);
}
.emg-calm-icon {
  font-size: 2.2rem;
  flex-shrink: 0;
  line-height: 1;
}
.emg-calm-title {
  font-size: var(--text-base);
  font-weight: 800;
  color: var(--text);
  letter-spacing: -.01em;
  margin-bottom: 2px;
}
.emg-calm-sub {
  font-size: var(--text-xs);
  color: var(--text-muted);
}

/* One-tap kit hero button */
.emg-kit-btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  margin: var(--sp-4) var(--sp-4) 0;
  padding: var(--sp-4) var(--sp-4);
  background: linear-gradient(135deg, #7f1d1d, #991b1b, #b91c1c);
  border: none;
  border-radius: 18px;
  cursor: pointer;
  transition: opacity .15s, transform .1s, box-shadow .15s;
  box-shadow: 0 6px 28px rgba(239,68,68,.35);
  width: calc(100% - var(--sp-8));
  text-align: left;
}
.emg-kit-btn:hover { opacity: .93; box-shadow: 0 8px 36px rgba(239,68,68,.45); }
.emg-kit-btn:active { transform: scale(.98); }

.emg-kit-left {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  flex: 1;
  min-width: 0;
}
.emg-kit-emoji {
  font-size: 2rem;
  flex-shrink: 0;
  line-height: 1;
}
.emg-kit-text { min-width: 0; }
.emg-kit-title {
  font-size: var(--text-sm);
  font-weight: 800;
  color: #fff;
  letter-spacing: -.01em;
  margin-bottom: 3px;
}
.emg-kit-sub {
  font-size: .72rem;
  color: rgba(255,255,255,.75);
  line-height: 1.4;
  white-space: normal;
}
.emg-kit-right {
  flex-shrink: 0;
  text-align: right;
}
.emg-kit-price {
  font-size: var(--text-sm);
  font-weight: 800;
  color: #fff;
  margin-bottom: 2px;
}
.emg-kit-cta {
  font-size: .72rem;
  color: rgba(255,255,255,.8);
  font-weight: 600;
  white-space: nowrap;
}

/* "Need anything else?" secondary items */
.emg-also-label {
  font-size: .72rem;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: .06em;
  padding: var(--sp-5) var(--sp-5) var(--sp-2);
}

.emg-items {
  display: flex;
  flex-direction: column;
  gap: 1px;
  background: var(--border);
  border-radius: 16px;
  overflow: hidden;
  margin: 0 var(--sp-4) var(--sp-6);
}

.emg-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  background: var(--surface);
  transition: background var(--trans);
}
.emg-item:first-child { border-radius: 16px 16px 0 0; }
.emg-item:last-child  { border-radius: 0 0 16px 16px; }
.emg-item:only-child  { border-radius: 16px; }

.emg-item-info {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  flex: 1;
  min-width: 0;
}
.emg-item-emoji {
  font-size: 1.4rem;
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--surface-2);
  border-radius: 10px;
}
.emg-item-name {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.emg-item-meta {
  font-size: .7rem;
  color: var(--text-muted);
  margin-top: 1px;
}

.emg-add-btn {
  flex-shrink: 0;
  height: 34px;
  padding: 0 var(--sp-3);
  border-radius: var(--r-full);
  border: 1.5px solid rgba(239,68,68,.4);
  background: rgba(239,68,68,.08);
  color: #ef4444;
  font-size: var(--text-xs);
  font-weight: 700;
  cursor: pointer;
  transition: background var(--trans), border-color var(--trans), color var(--trans);
  white-space: nowrap;
}
.emg-add-btn:hover {
  background: rgba(239,68,68,.18);
  border-color: #ef4444;
}
.emg-add-btn.in-cart {
  background: rgba(239,68,68,.15);
  border-color: #ef4444;
  color: #ef4444;
}

/* ==========================================================
   ONBOARDING QUIZ
   ========================================================== */
.quiz-overlay {
  position: fixed;
  inset: 0;
  background: rgba(13,10,20,0.92);
  backdrop-filter: blur(8px);
  z-index: 9000;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 0;
}
@media (min-width: 600px) {
  .quiz-overlay { align-items: center; padding: var(--sp-4); }
}
.quiz-card {
  background: var(--surface-1);
  border-radius: var(--r-2xl) var(--r-2xl) 0 0;
  width: 100%;
  max-width: 480px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border: 1.5px solid var(--border);
  animation: slideUpQuiz 0.36s var(--ease-spring) forwards;
}
@media (min-width: 600px) {
  .quiz-card { border-radius: var(--r-2xl); }
}
@keyframes slideUpQuiz {
  from { transform: translateY(60px); opacity: 0; }
  to   { transform: translateY(0);    opacity: 1; }
}
.quiz-top-bar {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-5) var(--sp-3);
}
.quiz-progress-track {
  flex: 1;
  height: 4px;
  background: var(--border);
  border-radius: 99px;
  overflow: hidden;
}
.quiz-progress-fill {
  height: 100%;
  background: var(--accent);
  border-radius: 99px;
  transition: width 0.4s var(--ease-out);
  width: 20%;
}
.quiz-skip-btn {
  font-size: var(--text-sm);
  color: var(--text-muted);
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--sp-1) var(--sp-2);
  border-radius: var(--r-md);
  transition: color 0.2s;
}
.quiz-skip-btn:hover { color: var(--text-base); }

.quiz-body {
  flex: 1;
  overflow-y: auto;
  padding: var(--sp-5) var(--sp-5) var(--sp-3);
}
.quiz-q-eyebrow {
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--accent);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: var(--sp-2);
}
.quiz-q-text {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--text-base);
  line-height: 1.25;
  margin-bottom: var(--sp-1);
}
.quiz-q-sub {
  font-size: var(--text-sm);
  color: var(--text-muted);
  margin-bottom: var(--sp-5);
}
.quiz-choices {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-3);
}
.quiz-choice {
  background: var(--surface-2);
  border: 2px solid var(--border);
  border-radius: var(--r-xl);
  padding: var(--sp-4);
  cursor: pointer;
  text-align: left;
  transition: border-color 0.18s, background 0.18s, transform 0.15s;
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
}
.quiz-choice:hover { border-color: var(--accent); transform: translateY(-2px); }
.quiz-choice.selected {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 12%, var(--surface-2));
}
.quiz-choice-icon { font-size: 28px; line-height: 1; margin-bottom: var(--sp-1); }
.quiz-choice-label { font-size: var(--text-sm); font-weight: 700; color: var(--text-base); }
.quiz-choice-desc  { font-size: var(--text-xs); color: var(--text-muted); }

/* Done slide */
.quiz-done-slide {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--sp-3);
  padding: var(--sp-6) 0;
}
.quiz-done-icon { font-size: 56px; }
.quiz-done-title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 700;
  color: var(--text-base);
}
.quiz-done-sub { font-size: var(--text-sm); color: var(--text-muted); max-width: 280px; }
.quiz-prefs-chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  justify-content: center;
  margin-top: var(--sp-1);
}
.quiz-pref-chip {
  background: color-mix(in srgb, var(--accent) 15%, var(--surface-2));
  border: 1px solid var(--accent);
  color: var(--accent);
  font-size: var(--text-xs);
  font-weight: 600;
  border-radius: 99px;
  padding: 4px 12px;
}

.quiz-footer {
  padding: var(--sp-4) var(--sp-5) var(--sp-5);
  border-top: 1px solid var(--border);
}
.quiz-next-btn {
  width: 100%;
  height: 52px;
  background: var(--accent);
  color: white;
  border: none;
  border-radius: var(--r-full);
  font-size: var(--text-base);
  font-weight: 700;
  cursor: pointer;
  transition: opacity 0.2s, transform 0.15s;
}
.quiz-next-btn:disabled { opacity: 0.38; cursor: not-allowed; }
.quiz-next-btn:not(:disabled):hover { transform: translateY(-1px); }
.quiz-next-btn.done-btn { background: var(--gold, #D4AF37); }

/* ==========================================================
   GIVE-BACK / ROUND-UP in Cart
   ========================================================== */
.give-back-section {
  margin: var(--sp-3) 0;
  background: color-mix(in srgb, var(--accent) 8%, var(--surface-2));
  border: 1.5px solid color-mix(in srgb, var(--accent) 30%, var(--border));
  border-radius: var(--r-xl);
  padding: var(--sp-3) var(--sp-4);
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}
.give-back-header {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}
.give-back-title {
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--accent);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.give-back-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  cursor: pointer;
  padding: var(--sp-2) 0;
  border-top: 1px solid color-mix(in srgb, var(--accent) 15%, var(--border));
}
.give-back-row:first-of-type { border-top: none; margin-top: var(--sp-1); }
.give-back-row-info { display: flex; flex-direction: column; gap: 2px; flex: 1; }
.give-back-row-label { font-size: var(--text-sm); color: var(--text-base); font-weight: 500; }
.give-back-row-sub   { font-size: var(--text-xs); color: var(--accent); font-weight: 600; }

/* Toggle pill */
.give-back-toggle-wrap { position: relative; width: 40px; height: 22px; flex-shrink: 0; }
.give-back-chk { position: absolute; opacity: 0; width: 0; height: 0; }
.give-back-pill {
  position: absolute;
  inset: 0;
  background: var(--border);
  border-radius: 99px;
  cursor: pointer;
  transition: background 0.25s;
}
.give-back-pill::after {
  content: '';
  position: absolute;
  top: 3px; left: 3px;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: white;
  transition: transform 0.25s;
}
.give-back-chk:checked + .give-back-pill { background: var(--accent); }
.give-back-chk:checked + .give-back-pill::after { transform: translateX(18px); }

/* ==========================================================
   COMMUNITY IMPACT COUNTER
   ========================================================== */
.impact-section {
  margin: var(--sp-10) var(--sp-4) var(--sp-5);
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--accent) 14%, var(--surface-1)) 0%,
    color-mix(in srgb, #D4AF37 8%, var(--surface-1)) 100%
  );
  border: 1.5px solid color-mix(in srgb, var(--accent) 25%, var(--border));
  border-radius: 24px;
  overflow: hidden;
}
.impact-inner {
  padding: var(--sp-6) var(--sp-5);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--sp-4);
}
.impact-eyebrow {
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--accent);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}
.impact-heading {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 800;
  color: var(--text-base);
  line-height: 1.2;
}
.impact-counters {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-4);
  width: 100%;
}
.impact-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-1);
  flex: 1;
}
.impact-num {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 7vw, 2.4rem);
  font-weight: 800;
  color: var(--accent);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.impact-lbl {
  font-size: var(--text-xs);
  color: var(--text-muted);
  line-height: 1.4;
}
.impact-vline {
  width: 1px;
  height: 48px;
  background: color-mix(in srgb, var(--accent) 25%, var(--border));
  flex-shrink: 0;
}
.impact-sub {
  font-size: var(--text-xs);
  color: var(--text-muted);
  line-height: 1.6;
}
.impact-link {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.impact-cta-btn {
  background: var(--accent);
  color: white;
  border: none;
  border-radius: var(--r-full);
  padding: var(--sp-3) var(--sp-6);
  font-size: var(--text-sm);
  font-weight: 700;
  cursor: pointer;
  transition: transform 0.15s, opacity 0.2s;
}
.impact-cta-btn:hover { transform: translateY(-2px); opacity: 0.9; }

/* ==========================================================
   HOW IT WORKS JUMP BUTTON (all versions except emergency)
   ========================================================== */
/* ── Community Hero Bar ───────────────────────────────── */
.comm-hero-bar {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  max-width: 360px;
  width: 100%;
  margin: 0 auto var(--sp-3);
  padding: var(--sp-2) var(--sp-4);
  background: linear-gradient(90deg, rgba(168,85,247,.10) 0%, rgba(201,148,26,.07) 100%);
  border: 1px solid rgba(168,85,247,.22);
  border-radius: var(--r-full);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--accent);
  letter-spacing: .02em;
  cursor: pointer;
  transition: background 0.18s, border-color 0.18s, transform 0.15s;
}
.comm-hero-bar:hover {
  background: rgba(168,85,247,.18);
  border-color: rgba(168,85,247,.4);
  transform: translateY(-1px);
}
.comm-hero-bar .comm-hero-icon {
  font-size: 1em;
  flex-shrink: 0;
}
.comm-hero-bar .comm-hero-text {
  flex: 1;
  text-align: center;
}
.comm-hero-bar svg {
  flex-shrink: 0;
  opacity: 0.6;
}

/* ── Hero Quick-Links Row ─────────────────────────────── */
.hero-quick-links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  justify-content: center;
  margin-bottom: var(--sp-3);
}

.hero-how-btn {
  display: flex;   /* visible in all versions */
  align-items: center;
  gap: var(--sp-2);
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  border: 1.5px solid color-mix(in srgb, var(--accent) 35%, transparent);
  color: var(--accent);
  border-radius: var(--r-full);
  padding: var(--sp-2) var(--sp-4);
  font-size: var(--text-sm);
  font-weight: 600;
  cursor: pointer;
  margin-bottom: 0;   /* row handles spacing now */
  transition: background 0.2s, transform 0.15s;
  width: fit-content;
  align-self: center;
  white-space: nowrap;
}
.hero-how-btn:hover {
  background: color-mix(in srgb, var(--accent) 22%, transparent);
  transform: translateY(2px);
}
/* Tracker pill — slightly purple-tinted */
.hero-how-btn--tracker {
  background: color-mix(in srgb, #A855F7 10%, transparent);
  border-color: color-mix(in srgb, #A855F7 30%, transparent);
  color: #A855F7;
}
.hero-how-btn--tracker:hover {
  background: color-mix(in srgb, #A855F7 20%, transparent);
}
/* Newsletter pill — gold-tinted */
.hero-how-btn--nl {
  background: color-mix(in srgb, #D4AF37 10%, transparent);
  border-color: color-mix(in srgb, #D4AF37 35%, transparent);
  color: #D4AF37;
}
.hero-how-btn--nl:hover {
  background: color-mix(in srgb, #D4AF37 20%, transparent);
}

/* Hide in emergency — that UI is intentionally stripped down */
[data-version="emergency"] .hero-quick-links {
  display: none !important;
}
[data-version="emergency"] .hero-how-btn {
  display: none !important;
}

/* ── Feature Spotlight Cards ──────────────────────────── */
.feature-spotlight {
  padding: var(--sp-10) var(--sp-4) var(--sp-2);
}
[data-version="emergency"] .feature-spotlight {
  display: none !important;
}

.feature-spotlight-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-3);
}
@media (max-width: 500px) {
  .feature-spotlight-grid { grid-template-columns: 1fr; }
}

.feature-spot-card {
  background: var(--surface-offset);
  border-radius: 18px;
  padding: var(--sp-4);
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  border: 1px solid rgba(255,255,255,0.07);
  position: relative;
  overflow: hidden;
  transition: transform 0.18s, box-shadow 0.18s;
}
.feature-spot-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 24px rgba(0,0,0,0.25);
}
/* Accent top bar */
.feature-spot-card--tracker::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--accent);
  border-radius: 18px 18px 0 0;
}
.feature-spot-card--newsletter::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: #D4AF37;
  border-radius: 18px 18px 0 0;
}

.fsc-top {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}
.fsc-icon {
  font-size: 24px;
  line-height: 1;
  flex-shrink: 0;
}
.fsc-eyebrow {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--accent);
}
.fsc-eyebrow--gold { color: #D4AF37; }

.fsc-title {
  font-size: 16px;
  font-weight: 800;
  color: var(--text);
  margin: 0;
  line-height: 1.2;
}
.fsc-desc {
  font-size: 13px;
  color: var(--text-muted);
  line-height: 1.55;
  margin: 0;
  flex: 1;
}
.fsc-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 9px 16px;
  border-radius: var(--r-full);
  border: none;
  cursor: pointer;
  font-size: 13px;
  font-weight: 700;
  background: var(--accent);
  color: #fff;
  transition: opacity 0.2s, transform 0.15s;
  align-self: flex-start;
  margin-top: var(--sp-1);
  white-space: nowrap;
}
.fsc-btn:hover { opacity: 0.85; transform: translateY(-1px); }
.fsc-btn--nl {
  background: #D4AF37;
  color: #0D0A14;
}

/* ==========================================================
   TRACKER TUTORIAL OVERLAY
   ========================================================== */
.tracker-tutorial {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.90);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 900;
  padding: 24px;
  animation: tutFadeIn 0.4s ease;
}
.tracker-tutorial.hidden {
  display: none !important;
}
@keyframes tutFadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

.tut-card {
  background: var(--surface);
  border-radius: 24px;
  padding: 0 0 24px;
  max-width: 340px;
  width: 100%;
  text-align: center;
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.1);
  cursor: pointer;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
}
.tut-card-inner {
  padding: 0 28px;
}
/* Progress bar across the very top */
.tut-progress-bar {
  width: 100%;
  height: 4px;
  background: rgba(255, 255, 255, 0.08);
  margin-bottom: 28px;
  border-radius: 0;
}
.tut-progress-fill {
  height: 100%;
  background: var(--accent);
  width: 0%;
  transition: width 0.05s linear;
  border-radius: 0 2px 2px 0;
}

.tut-step-emoji {
  display: block;
  font-size: 56px;
  line-height: 1;
  margin: 0 auto 18px;
  animation: tutEmojiPop 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
}
@keyframes tutEmojiPop {
  from { transform: scale(0.5); opacity: 0; }
  to   { transform: scale(1);   opacity: 1; }
}
.tut-title {
  font-size: 22px;
  font-weight: 800;
  color: var(--text);
  margin: 0 0 10px;
  padding: 0 24px;
  animation: tutSlideUp 0.3s ease;
}
.tut-desc {
  font-size: 15px;
  color: var(--text-muted);
  line-height: 1.6;
  margin: 0 0 22px;
  padding: 0 24px;
  animation: tutSlideUp 0.35s ease;
}
@keyframes tutSlideUp {
  from { transform: translateY(10px); opacity: 0; }
  to   { transform: none;             opacity: 1; }
}
.tut-dots {
  display: flex;
  gap: 8px;
  justify-content: center;
  margin-bottom: 16px;
}
.tut-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.18);
  transition: background 0.25s, transform 0.25s;
}
.tut-dot.active {
  background: var(--accent);
  transform: scale(1.35);
}
.tut-tap-hint {
  font-size: 12px;
  color: rgba(255,255,255,0.3);
  margin: 0 0 14px;
  letter-spacing: 0.04em;
}
.tut-skip-btn {
  background: none;
  border: none;
  color: var(--text-muted);
  font-size: 13px;
  cursor: pointer;
  padding: 4px 12px;
  border-radius: 8px;
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: color 0.2s;
}
.tut-skip-btn:hover { color: var(--text); }

/* ==========================================================
   HOLISTIC & NATURAL CARD — hidden on ALL home screens
   (holistic experience lives in the version picker, not as a home card)
   ========================================================== */
#cardHolistic {
  display: none !important;
}

/* ==========================================================
   EMOJI REVIEW PROMPT
   ========================================================== */
.review-prompt {
  width: 100%;
  margin-top: var(--sp-2);
}
.review-prompt-divider {
  height: 1px;
  background: var(--border);
  margin: var(--sp-4) 0 var(--sp-3);
}
.review-prompt-q {
  font-size: var(--text-sm);
  color: var(--text-muted);
  text-align: center;
  margin-bottom: var(--sp-3);
}
.review-emoji-row {
  display: flex;
  justify-content: center;
  gap: var(--sp-3);
}
.review-emoji-btn {
  background: var(--surface-2);
  border: 2px solid var(--border);
  border-radius: var(--r-xl);
  width: 52px;
  height: 52px;
  font-size: 26px;
  cursor: pointer;
  transition: transform 0.18s, border-color 0.18s, background 0.18s;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}
.review-emoji-btn:hover {
  transform: scale(1.18);
  border-color: var(--accent);
}
.review-emoji-btn.selected {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 15%, var(--surface-2));
  transform: scale(1.22);
}
.review-thanks {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  padding: var(--sp-3) 0;
  animation: fadeInUp 0.3s ease forwards;
}
.review-thanks-emoji  { font-size: 28px; }
.review-thanks-text   { font-size: var(--text-sm); color: var(--text-muted); font-weight: 500; }

/* ==========================================================
   IMPACT STRIP (compact teaser below hero, above mode cards)
   ========================================================== */
.impact-strip {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-3);
  flex-wrap: wrap;
  width: calc(100% - var(--sp-8));
  margin: 0 var(--sp-4) var(--sp-4);
  padding: var(--sp-3) var(--sp-4);
  background: color-mix(in srgb, var(--accent) 10%, var(--surface-1));
  border: 1.5px solid color-mix(in srgb, var(--accent) 28%, var(--border));
  border-radius: var(--r-full);
  cursor: pointer;
  transition: background 0.2s, transform 0.15s;
  text-align: center;
}
.impact-strip:hover {
  background: color-mix(in srgb, var(--accent) 16%, var(--surface-1));
  transform: translateY(-1px);
}
.impact-strip-item {
  display: flex;
  align-items: center;
  gap: 5px;
  white-space: nowrap;
}
.impact-strip-num {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: 800;
  color: var(--accent);
  font-variant-numeric: tabular-nums;
}
.impact-strip-lbl {
  font-size: var(--text-xs);
  color: var(--text-muted);
}
.impact-strip-divider {
  width: 1px;
  height: 14px;
  background: color-mix(in srgb, var(--accent) 30%, var(--border));
  flex-shrink: 0;
}
.impact-strip-cta {
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--accent);
  gap: var(--sp-1);
}

/* Hide in emergency mode */
[data-version="emergency"] .impact-strip {
  display: none;
}


/* ==========================================================
   COMMUNITY VIEW
   ========================================================== */

/* ─── Greeting bar ─────────────────────────────────────── */
.comm-greeting {
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 15%, var(--surface-1)), var(--surface-1));
  border-bottom: 1px solid color-mix(in srgb, var(--accent) 20%, var(--border));
  padding: var(--sp-4) var(--sp-4) var(--sp-3);
}
.comm-greeting-inner { max-width: 600px; margin: 0 auto; }
.comm-greeting-text {
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--text);
  margin: 0;
  line-height: 1.4;
}

/* ─── Community header ──────────────────────────────────── */
.comm-header {
  padding: var(--sp-4) var(--sp-4) var(--sp-2);
  max-width: 600px;
  margin: 0 auto;
}
.comm-title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 800;
  color: var(--text);
  margin: 0 0 var(--sp-1);
}
.comm-subtitle {
  font-size: var(--text-sm);
  color: var(--text-muted);
  margin: 0 0 var(--sp-2);
}
.comm-phase-note {
  font-size: 11px;
  color: var(--text-muted);
  margin: 0;
  opacity: 0.7;
  font-style: italic;
}

/* ─── Topic grid ────────────────────────────────────────── */
.comm-topics { padding: 0 var(--sp-4) var(--sp-4); max-width: 600px; margin: 0 auto; }
.comm-topic-grid { display: flex; flex-direction: column; gap: var(--sp-3); }

.comm-topic-card {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  background: var(--surface-1);
  border: 1.5px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-3) var(--sp-4);
  cursor: pointer;
  text-align: left;
  transition: border-color 0.2s, background 0.2s, transform 0.15s;
  width: 100%;
}
.comm-topic-card:hover {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 6%, var(--surface-1));
  transform: translateY(-1px);
}
.comm-topic-emoji { font-size: 1.8rem; flex-shrink: 0; line-height: 1; }
.comm-topic-info { flex: 1; min-width: 0; }
.comm-topic-title {
  font-weight: 700;
  font-size: var(--text-sm);
  color: var(--text);
  margin-bottom: 2px;
}
.comm-topic-desc {
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.4;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.comm-topic-count {
  font-size: 12px;
  font-weight: 700;
  color: var(--accent);
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  border-radius: var(--r-full);
  padding: 3px 10px;
  flex-shrink: 0;
}

/* ─── Thread view ───────────────────────────────────────── */
.comm-thread {
  display: flex;
  flex-direction: column;
  height: calc(100dvh - 120px);
  max-width: 600px;
  margin: 0 auto;
}
.comm-thread-topbar {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.comm-back-btn {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  background: none;
  border: none;
  color: var(--accent);
  font-size: var(--text-sm);
  font-weight: 600;
  cursor: pointer;
  padding: 4px 0;
  transition: opacity 0.2s;
}
.comm-back-btn:hover { opacity: 0.7; }
.comm-thread-header {
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--text);
  flex: 1;
  text-align: right;
}

/* ─── Posts list ────────────────────────────────────────── */
.comm-posts {
  flex: 1;
  overflow-y: auto;
  padding: var(--sp-3) var(--sp-4);
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  -webkit-overflow-scrolling: touch;
}

.comm-post {
  background: var(--surface-1);
  border: 1.5px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-3) var(--sp-4);
  animation: fadeInUp 0.25s ease forwards;
}
.comm-post--own {
  border-color: color-mix(in srgb, var(--accent) 40%, var(--border));
  background: color-mix(in srgb, var(--accent) 6%, var(--surface-1));
}
.comm-post-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-2);
}
.comm-post-author {
  font-size: 12px;
  font-weight: 700;
  color: var(--accent);
}
.comm-post-time {
  font-size: 11px;
  color: var(--text-muted);
}
.comm-post-text {
  font-size: var(--text-sm);
  color: var(--text);
  line-height: 1.55;
  margin-bottom: var(--sp-2);
}
.comm-post-footer { display: flex; gap: var(--sp-3); align-items: center; }
.comm-like-btn {
  display: flex;
  align-items: center;
  gap: 5px;
  background: none;
  border: none;
  color: var(--text-muted);
  font-size: 12px;
  cursor: pointer;
  padding: 2px 0;
  transition: color 0.2s;
}
.comm-like-btn:hover, .comm-like-btn.liked { color: #ef4444; }
.comm-empty {
  text-align: center;
  color: var(--text-muted);
  font-size: var(--text-sm);
  padding: var(--sp-8) 0;
}

/* ─── Compose box ───────────────────────────────────────── */
.comm-compose {
  display: flex;
  align-items: flex-end;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-4);
  border-top: 1px solid var(--border);
  flex-shrink: 0;
  background: var(--surface-1);
}
.comm-input {
  flex: 1;
  background: var(--surface-2);
  border: 1.5px solid var(--border);
  border-radius: var(--r-lg);
  color: var(--text);
  font-size: var(--text-sm);
  line-height: 1.5;
  padding: var(--sp-2) var(--sp-3);
  resize: none;
  font-family: var(--font-body);
  transition: border-color 0.2s;
}
.comm-input:focus {
  outline: none;
  border-color: var(--accent);
}
.comm-post-btn {
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: var(--r-full);
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: filter 0.2s, transform 0.15s;
  flex-shrink: 0;
}
.comm-post-btn:hover { filter: brightness(1.1); transform: scale(1.05); }

/* ─── Community feature card on home ───────────────────── */
.feature-spot-card--community {
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 12%, var(--surface-1)), var(--surface-1));
  border-color: color-mix(in srgb, var(--accent) 35%, var(--border));
}
.fsc-btn--community {
  background: var(--accent);
  color: #fff;
  border: none;
}
.fsc-btn--community:hover { filter: brightness(1.1); }

/* ==========================================================
   NICKNAME SETUP MODAL
   ========================================================== */
.nickname-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.75);
  z-index: 1200;
  opacity: 0;
  transition: opacity 0.3s ease;
  backdrop-filter: blur(6px);
}
.nickname-overlay.open { opacity: 1; }

.nickname-modal {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 1201;
  background: var(--surface-1);
  border-radius: var(--r-xl) var(--r-xl) 0 0;
  padding: var(--sp-6) var(--sp-5) var(--sp-8);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  transform: translateY(100%);
  transition: transform 0.35s cubic-bezier(0.32,0.72,0,1);
}
.nickname-modal.open { transform: translateY(0); }

@media (min-width: 600px) {
  .nickname-modal {
    top: 50%;
    left: 50%;
    right: auto;
    bottom: auto;
    transform: translate(-50%, -40%) scale(0.96);
    border-radius: var(--r-xl);
    width: 90%;
    max-width: 440px;
    opacity: 0;
    transition: transform 0.3s cubic-bezier(0.32,0.72,0,1), opacity 0.3s ease;
  }
  .nickname-modal.open {
    transform: translate(-50%, -50%) scale(1);
    opacity: 1;
  }
}

.nickname-crown { font-size: 2.5rem; margin-bottom: var(--sp-3); line-height: 1; }
.nickname-title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 800;
  color: var(--text);
  margin: 0 0 var(--sp-2);
}
.nickname-sub {
  font-size: var(--text-sm);
  color: var(--text-muted);
  margin: 0 0 var(--sp-5);
  line-height: 1.5;
}
.nickname-input {
  width: 100%;
  max-width: 320px;
  background: var(--surface-2);
  border: 2px solid var(--border);
  border-radius: var(--r-lg);
  color: var(--text);
  font-size: var(--text-base);
  padding: var(--sp-3) var(--sp-4);
  text-align: center;
  font-family: var(--font-body);
  margin-bottom: var(--sp-4);
  transition: border-color 0.2s;
}
.nickname-input:focus {
  outline: none;
  border-color: var(--accent);
}
.nickname-confirm-btn {
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: var(--r-full);
  padding: var(--sp-3) var(--sp-7);
  font-size: var(--text-base);
  font-weight: 700;
  cursor: pointer;
  width: 100%;
  max-width: 320px;
  margin-bottom: var(--sp-3);
  transition: filter 0.2s, transform 0.15s;
}
.nickname-confirm-btn:hover { filter: brightness(1.1); transform: translateY(-1px); }
.nickname-privacy {
  font-size: 11px;
  color: var(--text-muted);
  margin: 0;
  opacity: 0.7;
}

/* ─── Community feature card span full width ─────────────── */
@media (min-width: 340px) {
  .feature-spotlight-grid .feature-spot-card--community {
    grid-column: 1 / -1;
  }
}

/* =====================================================
   AGE GATE
   ===================================================== */
#ageGateWrap {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: #0D0A14;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
}
.age-gate-screen {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  max-width: 360px;
  width: 100%;
  gap: 1.25rem;
  animation: ageFadeIn .35s ease;
}
@keyframes ageFadeIn {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}
.age-gate-logo {
  font-size: 4rem;
  font-weight: 900;
  color: #D4AF37;
  line-height: 1;
  letter-spacing: -2px;
}
.age-gate-heading {
  font-size: 1.5rem;
  font-weight: 700;
  color: #fff;
  margin: 0;
}
.age-gate-body {
  font-size: 1rem;
  color: #bbb;
  margin: 0;
  line-height: 1.6;
}
.age-gate-link {
  color: #A855F7;
  text-decoration: none;
}
.age-gate-btns {
  display: flex;
  flex-direction: column;
  gap: .75rem;
  width: 100%;
  margin-top: .5rem;
}
.age-gate-yes {
  width: 100%;
  padding: .9rem 1.5rem;
  background: linear-gradient(135deg, #A855F7, #7C3AED);
  color: #fff;
  border: none;
  border-radius: 14px;
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  transition: opacity .2s;
}
.age-gate-yes:hover { opacity: .88; }
.age-gate-no {
  width: 100%;
  padding: .75rem 1.5rem;
  background: transparent;
  color: #888;
  border: 1px solid #333;
  border-radius: 14px;
  font-size: .9rem;
  cursor: pointer;
  transition: color .2s, border-color .2s;
}
.age-gate-no:hover { color: #aaa; border-color: #555; }

/* =====================================================
   BACKUP CONTACT LINE (footer)
   ===================================================== */
.backup-contact-line {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: .35rem .45rem;
  font-size: .78rem;
  color: #9CA3AF;
  margin: .75rem .5rem 1rem;
  padding: .75rem 1rem;
  background: rgba(168, 85, 247, 0.06);
  border: 1px solid rgba(168, 85, 247, 0.18);
  border-radius: 12px;
  text-align: center;
  line-height: 1.55;
}
.backup-contact-line svg { color: #D4AF37; flex-shrink: 0; }
.backup-tel {
  color: #D4AF37;
  text-decoration: none;
  font-weight: 700;
  letter-spacing: .02em;
  font-size: .82rem;
}
.backup-tel:hover { text-decoration: underline; }

/* =====================================================
   MANAGE / CANCEL SUBSCRIPTION (subscribe success modal)
   ===================================================== */
.manage-sub-row {
  margin-top: 1.25rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(255,255,255,.08);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .35rem;
}
.manage-sub-hint {
  font-size: .75rem;
  color: #888;
}
.manage-sub-link {
  background: none;
  border: none;
  color: #A855F7;
  font-size: .85rem;
  font-weight: 500;
  cursor: pointer;
  padding: .25rem .5rem;
  border-radius: 6px;
  transition: background .2s;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.manage-sub-link:hover { background: rgba(168,85,247,.1); }

/* ── Smart Suggestions (subscription builder) ─────────────────── */
#smartSuggestions {
  margin: 0 0 1rem 0;
}
.smart-suggest-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--gold, #D4AF37);
  margin-bottom: 0.55rem;
}
.smart-suggest-label svg {
  stroke: var(--gold, #D4AF37);
  fill: none;
  flex-shrink: 0;
}
.smart-suggest-row {
  display: flex;
  gap: 0.6rem;
  overflow-x: auto;
  padding-bottom: 4px;
  scrollbar-width: none;
}
.smart-suggest-row::-webkit-scrollbar { display: none; }
.smart-chip {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0.45rem 0.75rem;
  border-radius: 50px;
  border: 1.5px solid var(--purple, #A855F7);
  background: transparent;
  color: var(--text, #fff);
  font-size: 0.8rem;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.18s, color 0.18s;
  font-family: inherit;
  flex-shrink: 0;
}
.smart-chip.selected {
  background: var(--purple, #A855F7);
  color: #fff;
  border-color: var(--purple, #A855F7);
}
.smart-chip:hover:not(.selected) {
  background: rgba(168,85,247,0.12);
}
.smart-chip .chip-emoji { font-size: 1rem; line-height: 1; }
.smart-chip .chip-name  { max-width: 120px; overflow: hidden; text-overflow: ellipsis; }

/* ── Text Review Box (adult & holistic only) ──────────────────── */
.review-text-box {
  margin-top: 0.85rem;
  animation: fadeSlideUp 0.22s ease;
}
@keyframes fadeSlideUp {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
.review-text-label {
  display: block;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--text-muted, #9CA3AF);
  margin-bottom: 0.4rem;
  letter-spacing: 0.03em;
}
.review-optional {
  font-weight: 400;
  opacity: 0.7;
}
.review-textarea {
  width: 100%;
  background: rgba(255,255,255,0.06);
  border: 1.5px solid rgba(168,85,247,0.35);
  border-radius: 10px;
  color: var(--text, #F9FAFB);
  font-family: inherit;
  font-size: 0.9rem;
  line-height: 1.5;
  padding: 0.6rem 0.75rem;
  resize: none;
  outline: none;
  transition: border-color 0.18s;
  box-sizing: border-box;
}
.review-textarea:focus {
  border-color: var(--purple, #A855F7);
}
.review-textarea::placeholder {
  color: rgba(255,255,255,0.3);
  font-style: italic;
}
.review-text-actions {
  display: flex;
  gap: 0.6rem;
  margin-top: 0.55rem;
  justify-content: flex-end;
}
.review-submit-btn {
  background: var(--purple, #A855F7);
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 0.42rem 1.1rem;
  font-size: 0.85rem;
  font-weight: 700;
  font-family: inherit;
  cursor: pointer;
  transition: opacity 0.15s;
}
.review-submit-btn:hover { opacity: 0.85; }
.review-skip-btn {
  background: transparent;
  color: var(--text-muted, #9CA3AF);
  border: 1.5px solid rgba(255,255,255,0.15);
  border-radius: 8px;
  padding: 0.42rem 0.9rem;
  font-size: 0.85rem;
  font-family: inherit;
  cursor: pointer;
  transition: border-color 0.15s;
}
.review-skip-btn:hover { border-color: rgba(255,255,255,0.35); }

/* ── Adult-only: hidden in teen mode ─────────────────────────── */
[data-version="teen"] .adult-only {
  display: none !important;
}

/* ── Cycle Phase Education ────────────────────────────────────── */
.cycle-edu-section {
  padding: 2rem 1.2rem 1.2rem;
}
.cycle-edu-eyebrow {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gold, #D4AF37);
  margin-bottom: 0.35rem;
}
.cycle-edu-title {
  font-size: 1.35rem;
  font-weight: 700;
  color: #fff;
  margin: 0 0 0.4rem;
  line-height: 1.25;
}
.cycle-edu-sub {
  font-size: 0.88rem;
  color: rgba(255,255,255,0.6);
  margin: 0 0 1.2rem;
  line-height: 1.5;
  max-width: 36ch;
}
.cycle-phase-row {
  display: flex;
  gap: 0.85rem;
  overflow-x: auto;
  padding-bottom: 6px;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}
.cycle-phase-row::-webkit-scrollbar { display: none; }
.cycle-phase-card {
  flex: 0 0 200px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(168,85,247,0.2);
  border-radius: 16px;
  padding: 1rem 1rem 0.85rem;
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  transition: border-color 0.2s, background 0.2s;
}
.cycle-phase-card:hover {
  border-color: rgba(168,85,247,0.45);
  background: rgba(168,85,247,0.07);
}
.cycle-phase-card--peak {
  border-color: rgba(212,175,55,0.35);
  background: rgba(212,175,55,0.04);
}
.cycle-phase-card--peak:hover {
  border-color: rgba(212,175,55,0.6);
  background: rgba(212,175,55,0.08);
}
.phase-pill {
  display: inline-block;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  padding: 3px 9px;
  border-radius: 50px;
  width: fit-content;
  margin-bottom: 0.1rem;
}
.phase-pill--menstrual  { background: rgba(239,68,68,0.15);  color: #F87171; }
.phase-pill--follicular { background: rgba(168,85,247,0.18); color: #C084FC; }
.phase-pill--ovulation  { background: rgba(212,175,55,0.2);  color: #F0C040; }
.phase-pill--luteal     { background: rgba(99,102,241,0.18); color: #A5B4FC; }
.phase-name {
  font-size: 1rem;
  font-weight: 700;
  color: #fff;
  line-height: 1.2;
}
.phase-keyword {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.38);
  margin-bottom: 0.2rem;
}
.phase-desc {
  font-size: 0.8rem;
  color: rgba(255,255,255,0.65);
  line-height: 1.55;
  margin: 0;
  flex: 1;
}
.phase-products {
  font-size: 0.68rem;
  color: rgba(168,85,247,0.85);
  font-weight: 600;
  margin-top: 0.5rem;
  padding-top: 0.5rem;
  border-top: 1px solid rgba(168,85,247,0.15);
}
.cycle-edu-note {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.73rem;
  color: rgba(255,255,255,0.35);
  margin: 1rem 0 0;
  line-height: 1.4;
}
.cycle-edu-note svg { flex-shrink: 0; stroke: rgba(255,255,255,0.3); }

/* ── Voices We Love ───────────────────────────────────────────── */
.voices-section {
  padding: 1.5rem 1.2rem;
  border-top: 1px solid rgba(255,255,255,0.06);
}
.voices-eyebrow {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--purple, #A855F7);
  margin-bottom: 0.35rem;
}
.voices-title {
  font-size: 1.25rem;
  font-weight: 700;
  color: #fff;
  margin: 0 0 0.35rem;
}
.voices-sub {
  font-size: 0.85rem;
  color: rgba(255,255,255,0.55);
  line-height: 1.5;
  margin: 0 0 1.1rem;
  max-width: 38ch;
}
.voices-row {
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
}
.voice-card {
  display: flex;
  align-items: flex-start;
  gap: 0.9rem;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(168,85,247,0.15);
  border-radius: 14px;
  padding: 0.9rem 1rem;
  position: relative;
}
.voice-avatar {
  font-size: 1.6rem;
  line-height: 1;
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  background: rgba(168,85,247,0.12);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.voice-info { flex: 1; min-width: 0; }
.voice-name {
  font-size: 0.88rem;
  font-weight: 700;
  color: #fff;
  line-height: 1.2;
}
.voice-handle {
  font-size: 0.73rem;
  color: var(--purple, #A855F7);
  margin-bottom: 0.3rem;
}
.voice-bio {
  font-size: 0.78rem;
  color: rgba(255,255,255,0.55);
  line-height: 1.45;
  margin: 0;
}
.voice-tag {
  position: absolute;
  top: 0.7rem;
  right: 0.75rem;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  color: var(--gold, #D4AF37);
  background: rgba(212,175,55,0.1);
  border: 1px solid rgba(212,175,55,0.25);
  border-radius: 50px;
  padding: 2px 8px;
  text-transform: uppercase;
}
.voices-suggest {
  margin-top: 1rem;
  font-size: 0.8rem;
  color: rgba(255,255,255,0.4);
  text-align: center;
}
.voices-suggest-link {
  color: var(--purple, #A855F7);
  text-decoration: underline;
  font-weight: 600;
}

/* ── The Change, Sis ─────────────────────────────────────────── */
.change-sis-section {
  padding: 2rem 1.2rem 1.8rem;
  border-top: 1px solid rgba(168,85,247,0.12);
}
.change-sis-eyebrow {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gold, #D4AF37);
  margin-bottom: 0.35rem;
}
.change-sis-title {
  font-size: 1.4rem;
  font-weight: 800;
  color: #fff;
  margin: 0 0 0.4rem;
  line-height: 1.2;
}
.change-sis-sub {
  font-size: 0.88rem;
  color: rgba(255,255,255,0.6);
  line-height: 1.55;
  margin: 0 0 1.3rem;
  max-width: 38ch;
}

/* scrolling card row */
.change-sis-row {
  display: flex;
  gap: 0.9rem;
  overflow-x: auto;
  padding-bottom: 8px;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  margin: 0 -1.2rem;
  padding-left: 1.2rem;
  padding-right: 1.2rem;
}
.change-sis-row::-webkit-scrollbar { display: none; }

/* individual card */
.change-card {
  flex: 0 0 220px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(168,85,247,0.18);
  border-radius: 18px;
  padding: 1.1rem 1rem 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  transition: border-color 0.2s, background 0.2s;
}
.change-card:hover {
  border-color: rgba(168,85,247,0.4);
  background: rgba(168,85,247,0.06);
}
.change-card-icon {
  font-size: 1.8rem;
  line-height: 1;
  margin-bottom: 0.15rem;
}

/* pills */
.change-pill {
  display: inline-block;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  padding: 3px 9px;
  border-radius: 50px;
  width: fit-content;
  margin-bottom: 0.1rem;
}
.change-pill--mind   { background: rgba(168,85,247,0.18); color: #C084FC; }
.change-pill--body   { background: rgba(239,68,68,0.15);  color: #F87171; }
.change-pill--stages { background: rgba(212,175,55,0.18); color: #E8C84A; }

.change-card-title {
  font-size: 0.95rem;
  font-weight: 700;
  color: #fff;
  line-height: 1.25;
}
.change-card-body {
  font-size: 0.8rem;
  color: rgba(255,255,255,0.6);
  line-height: 1.5;
  margin: 0 0 0.2rem;
  flex: 1;
}
.change-card-list {
  list-style: none;
  padding: 0;
  margin: 0.2rem 0 0;
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}
.change-card-list li {
  font-size: 0.77rem;
  color: rgba(255,255,255,0.65);
  padding-left: 1rem;
  position: relative;
  line-height: 1.4;
}
.change-card-list li::before {
  content: '•';
  position: absolute;
  left: 0;
  color: var(--purple, #A855F7);
  font-size: 0.85rem;
}

/* stage breakdown */
.change-stage {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 0.55rem 0;
  border-bottom: 1px solid rgba(255,255,255,0.07);
}
.change-stage:last-child { border-bottom: none; }
.change-stage-label {
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--gold, #D4AF37);
}
.change-stage-desc {
  font-size: 0.75rem;
  color: rgba(255,255,255,0.55);
  line-height: 1.4;
}

/* you're not alone callout */
.change-sis-note {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  background: rgba(168,85,247,0.07);
  border: 1px solid rgba(168,85,247,0.2);
  border-radius: 14px;
  padding: 1rem 1.1rem;
  margin-top: 1.4rem;
}
.change-sis-note-icon {
  font-size: 1.2rem;
  flex-shrink: 0;
  margin-top: 1px;
}
.change-sis-note-text {
  font-size: 0.83rem;
  color: rgba(255,255,255,0.7);
  line-height: 1.55;
  margin: 0;
}
.change-sis-note-text strong {
  color: #fff;
  font-weight: 700;
}

/* shop button */
.change-sis-shop-btn {
  display: block;
  width: 100%;
  margin-top: 1.2rem;
  padding: 0.85rem 1rem;
  background: linear-gradient(135deg, rgba(168,85,247,0.25) 0%, rgba(212,175,55,0.15) 100%);
  border: 1px solid rgba(168,85,247,0.4);
  border-radius: 14px;
  color: #fff;
  font-size: 0.95rem;
  font-weight: 700;
  cursor: pointer;
  text-align: center;
  transition: background 0.2s, border-color 0.2s, transform 0.15s;
  letter-spacing: 0.01em;
}
.change-sis-shop-btn:hover {
  background: linear-gradient(135deg, rgba(168,85,247,0.38) 0%, rgba(212,175,55,0.25) 100%);
  border-color: var(--gold, #D4AF37);
  transform: translateY(-1px);
}
.change-sis-shop-btn:active { transform: translateY(0); }

/* ── Teen-only: hidden outside teen mode ───────────────── */
.teen-only { display: none !important; }
[data-version="teen"] .teen-only { display: block !important; }

/* ── Shared teen section header ──────────────────────────────── */
.teen-eyebrow {
  font-size: 0.7rem; font-weight: 700; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--teen-accent, #CF6AFF);
  margin-bottom: 0.3rem;
}
.teen-sec-title {
  font-size: 1.3rem; font-weight: 800; color: #fff;
  margin: 0 0 0.35rem; line-height: 1.2;
}
.teen-sec-sub {
  font-size: 0.85rem; color: rgba(255,255,255,0.6);
  line-height: 1.5; margin: 0 0 1.1rem; max-width: 36ch;
}
.teen-sec-header { padding: 0 0 0.2rem; }
.teen-body-section, .teen-facts-section, .teen-freak-section {
  padding: 2rem 1.2rem 1.2rem;
}
.teen-facts-section { border-top: 1px solid rgba(207,106,255,0.12); }
.teen-freak-section  { border-top: 1px solid rgba(207,106,255,0.12); }
.teen-edu-note {
  display: flex; align-items: flex-start; gap: 6px;
  font-size: 0.72rem; color: rgba(255,255,255,0.3);
  margin: 1rem 0 0; line-height: 1.45;
}
.teen-edu-note svg { flex-shrink: 0; stroke: rgba(255,255,255,0.25); margin-top:1px; }

/* ── Your Body No Cap — phase cards ──────────────────────────── */
.teen-phase-row {
  display: flex; gap: 0.8rem; overflow-x: auto;
  padding-bottom: 6px; scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}
.teen-phase-row::-webkit-scrollbar { display: none; }
.teen-phase-card {
  flex: 0 0 185px; border-radius: 18px; padding: 1rem;
  border: 1.5px solid rgba(207,106,255,0.2);
  background: rgba(207,106,255,0.05);
  display: flex; flex-direction: column; gap: 0.25rem;
  transition: border-color 0.2s, background 0.2s;
}
.teen-phase-card:hover {
  border-color: rgba(207,106,255,0.5);
  background: rgba(207,106,255,0.1);
}
.tpc-vibe    { font-size: 1.5rem; line-height: 1; margin-bottom: 0.15rem; }
.tpc-pill    {
  display: inline-block; font-size: 0.62rem; font-weight: 700;
  letter-spacing: 0.05em; padding: 2px 8px; border-radius: 50px;
  width: fit-content; background: rgba(207,106,255,0.18); color: #CF6AFF;
}
.tpc--menstrual  .tpc-pill { background: rgba(248,113,113,0.15); color: #FCA5A5; }
.tpc--ovulation  .tpc-pill { background: rgba(212,175,55,0.18);  color: #F0C040; }
.tpc--follicular .tpc-pill { background: rgba(207,106,255,0.18); color: #CF6AFF; }
.tpc--luteal     .tpc-pill { background: rgba(99,102,241,0.18);  color: #A5B4FC; }
.tpc-name  { font-size: 1rem; font-weight: 800; color: #fff; line-height: 1.15; }
.tpc-desc  {
  font-size: 0.79rem; color: rgba(255,255,255,0.65);
  line-height: 1.55; margin: 0.1rem 0 0; flex: 1;
}
.tpc-want  {
  font-size: 0.66rem; color: rgba(207,106,255,0.85);
  font-weight: 600; margin-top: 0.5rem; padding-top: 0.5rem;
  border-top: 1px solid rgba(207,106,255,0.15);
}

/* ── Did You Know — rotating fact card ───────────────────────── */
.teen-fact-card {
  background: linear-gradient(135deg, rgba(207,106,255,0.12) 0%, rgba(168,85,247,0.06) 100%);
  border: 1.5px solid rgba(207,106,255,0.25);
  border-radius: 20px; padding: 1.4rem 1.2rem; min-height: 130px;
  display: flex; align-items: center;
}
.tfc-inner {
  display: flex; flex-direction: column; gap: 0.5rem; width: 100%;
  transition: opacity 0.28s ease, transform 0.28s ease;
}
.tfc-emoji { font-size: 1.8rem; line-height: 1; }
.tfc-text  {
  font-size: 0.9rem; color: #fff; line-height: 1.6; margin: 0;
  font-weight: 500;
}
.tfc-dots  {
  display: flex; gap: 5px; justify-content: center; margin-top: 0.6rem;
}
.tfc-dot   {
  width: 6px; height: 6px; border-radius: 50%;
  background: rgba(207,106,255,0.25); transition: background 0.3s;
}
.tfc-dot.active { background: var(--teen-accent, #CF6AFF); }
.teen-facts-cta { font-size: 0.78rem; color: rgba(255,255,255,0.4); margin: 0.8rem 0 0; }
.teen-scoop-link {
  background: none; border: none; color: var(--teen-accent, #CF6AFF);
  font-size: inherit; font-family: inherit; font-weight: 700;
  cursor: pointer; padding: 0; text-decoration: underline;
}

/* ── Freak Out Guide ─────────────────────────────────────────── */
.freak-steps {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 0.7rem;
}
.freak-step {
  display: flex; gap: 1rem; align-items: flex-start;
  background: rgba(255,255,255,0.04); border-radius: 14px;
  padding: 0.9rem 1rem; border: 1px solid rgba(207,106,255,0.12);
}
.freak-step--cta {
  border-color: rgba(207,106,255,0.3);
  background: rgba(207,106,255,0.07);
}
.freak-num {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--teen-accent, #CF6AFF); color: #fff;
  font-size: 0.8rem; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; margin-top: 1px;
}
.freak-title { font-size: 0.9rem; font-weight: 700; color: #fff; margin-bottom: 0.25rem; }
.freak-desc  { font-size: 0.8rem; color: rgba(255,255,255,0.65); line-height: 1.5; margin: 0; }
.freak-order-btn {
  display: inline-block; margin-top: 0.7rem; padding: 0.5rem 1.1rem;
  background: var(--teen-accent, #CF6AFF); color: #fff; border: none;
  border-radius: 10px; font-size: 0.85rem; font-weight: 700;
  font-family: inherit; cursor: pointer; transition: opacity 0.15s;
}
.freak-order-btn:hover { opacity: 0.85; }
.freak-disclaimer { margin-top: 1.2rem; }

/* ── Hero Scoop button ───────────────────────────────────────── */
.hero-scoop-btn { border-color: rgba(207,106,255,0.35) !important; }
[data-version="teen"] .hero-scoop-btn { border-color: rgba(207,106,255,0.5) !important; }

/* ── The Cycle Scoop view ────────────────────────────────────── */
.scoop-header {
  display: flex; align-items: flex-start; gap: 0.75rem;
  padding: 1rem 1.2rem 0.2rem;
}
.scoop-title-wrap { flex: 1; }
.scoop-title {
  font-size: 1.4rem; font-weight: 800; color: #fff;
  margin: 0 0 0.2rem; line-height: 1.2;
}
.scoop-sub { font-size: 0.82rem; color: rgba(255,255,255,0.5); margin: 0; }
.scoop-tabs {
  display: flex; gap: 0; padding: 0.8rem 1.2rem 0;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.scoop-tab {
  flex: 1; background: none; border: none; border-bottom: 2.5px solid transparent;
  color: rgba(255,255,255,0.4); font-size: 0.88rem; font-weight: 700;
  font-family: inherit; padding: 0.5rem 0 0.65rem; cursor: pointer;
  transition: color 0.18s, border-color 0.18s; text-align: center;
}
.scoop-tab.active {
  color: var(--purple, #A855F7);
  border-bottom-color: var(--purple, #A855F7);
}
.scoop-panel { padding: 1rem 1.2rem 2rem; }
.scoop-panel-note {
  font-size: 0.75rem; color: rgba(255,255,255,0.35); margin: 0 0 1rem;
}
.scoop-facts-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 0.7rem;
}
@media(max-width:380px) { .scoop-facts-grid { grid-template-columns: 1fr; } }
.scoop-fact-card {
  background: rgba(255,255,255,0.04); border: 1.5px solid rgba(168,85,247,0.18);
  border-radius: 14px; padding: 0.85rem 0.8rem;
  cursor: pointer; transition: border-color 0.18s, background 0.18s;
  position: relative; overflow: hidden;
}
.scoop-fact-card:hover { border-color: rgba(168,85,247,0.4); background: rgba(168,85,247,0.07); }
.scoop-fact-card.saved {
  border-color: var(--gold, #D4AF37);
  background: rgba(212,175,55,0.08);
}
.scoop-fact-card.saved::after {
  content: '★'; position: absolute; top: 6px; right: 8px;
  font-size: 0.7rem; color: var(--gold, #D4AF37);
}
.sfc-tag {
  font-size: 0.6rem; font-weight: 700; letter-spacing: 0.07em;
  text-transform: uppercase; color: rgba(168,85,247,0.7); margin-bottom: 0.3rem;
}
.sfc-emoji { font-size: 1.3rem; line-height: 1; margin-bottom: 0.3rem; }
.sfc-text  { font-size: 0.78rem; color: rgba(255,255,255,0.72); line-height: 1.5; margin: 0; }

/* ── FAQ accordion ───────────────────────────────────────────── */
.faq-list { display: flex; flex-direction: column; gap: 0.5rem; }
.faq-item {
  background: rgba(255,255,255,0.04); border: 1px solid rgba(168,85,247,0.15);
  border-radius: 12px; overflow: hidden; transition: border-color 0.18s;
}
.faq-item.open { border-color: rgba(168,85,247,0.4); }
.faq-q {
  width: 100%; background: none; border: none; color: #fff;
  font-size: 0.88rem; font-weight: 600; font-family: inherit;
  padding: 0.85rem 1rem; text-align: left; cursor: pointer;
  display: flex; align-items: center; justify-content: space-between; gap: 0.5rem;
}
.faq-q span { flex: 1; line-height: 1.4; }
.faq-chevron { flex-shrink: 0; transition: transform 0.22s ease; }
.faq-item.open .faq-chevron { transform: rotate(180deg); }
.faq-a { padding: 0 1rem 0.9rem; }
.faq-a p {
  font-size: 0.82rem; color: rgba(255,255,255,0.62);
  line-height: 1.6; margin: 0;
}

/* Legal modal footer */
.legal-modal-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 20px;
  border-top: 1px solid rgba(168,85,247,0.15);
  background: rgba(168,85,247,0.04);
  flex-shrink: 0;
}
.legal-download-btn {
  display: inline-flex;
  align-items: center;
  font-size: 12px;
  font-weight: 600;
  color: #A855F7;
  text-decoration: none;
  padding: 6px 12px;
  border: 1px solid rgba(168,85,247,0.3);
  border-radius: 20px;
  transition: background 0.2s;
}
.legal-download-btn:hover { background: rgba(168,85,247,0.1); }
.legal-copy-small {
  font-size: 10px;
  color: #9CA3AF;
}


/* =============================================
   PROMO CODE + PRICE BREAKDOWN (cart footer)
   ============================================= */
.promo-row { margin-bottom: 12px; }

.promo-input-wrap {
  display: flex;
  gap: 8px;
  align-items: center;
}
.promo-input {
  flex: 1;
  background: rgba(168,85,247,0.07);
  border: 1.5px solid rgba(168,85,247,0.22);
  border-radius: 10px;
  color: var(--text, #F3F0FF);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 9px 12px;
  outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.promo-input::placeholder {
  text-transform: none;
  letter-spacing: normal;
  font-weight: 400;
  color: var(--text-faint, #6B617A);
}
.promo-input:focus {
  border-color: var(--purple, #A855F7);
  box-shadow: 0 0 0 3px rgba(168,85,247,0.15);
}
.promo-apply-btn {
  background: var(--purple, #A855F7);
  color: #fff;
  border: none;
  border-radius: 10px;
  font-size: 12px;
  font-weight: 800;
  padding: 9px 15px;
  cursor: pointer;
  white-space: nowrap;
  letter-spacing: 0.04em;
  transition: opacity 0.15s, transform 0.1s;
}
.promo-apply-btn:hover  { opacity: 0.85; }
.promo-apply-btn:active { transform: scale(0.96); }

.promo-applied-row {
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgba(109,170,69,0.1);
  border: 1.5px solid rgba(109,170,69,0.28);
  border-radius: 10px;
  padding: 8px 12px;
  animation: promoSlideIn 0.2s ease;
}
@keyframes promoSlideIn { from { opacity:0; transform:translateY(-4px); } to { opacity:1; transform:translateY(0); } }
.promo-tag-icon { font-size: 14px; flex-shrink: 0; }
.promo-applied-label { flex: 1; font-size: 12px; font-weight: 700; color: #6DAA45; }
.promo-remove-btn {
  background: none; border: none; cursor: pointer;
  color: var(--text-muted, #9CA3AF);
  font-size: 13px; padding: 0 4px; line-height: 1;
  transition: color 0.15s;
}
.promo-remove-btn:hover { color: #F87171; }

.price-breakdown {
  padding: 10px 0 12px;
  border-top: 1px solid rgba(255,255,255,0.06);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  margin-bottom: 14px;
}
.price-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 3px 0;
}
.price-row-label {
  font-size: 12px;
  color: var(--text-muted, #9CA3AF);
}
.price-row-val {
  font-size: 13px;
  font-weight: 600;
  color: var(--text, #F3F0FF);
}
.price-row--discount .price-row-label,
.price-row-val--discount { color: #6DAA45; }

.price-row--total {
  margin-top: 8px;
  padding-top: 9px;
  border-top: 1px solid rgba(255,255,255,0.07);
}
.price-row--total .price-row-label {
  font-size: 13px;
  font-weight: 700;
  color: var(--text, #F3F0FF);
}
.price-row-val--total {
  font-family: var(--font-display, serif);
  font-size: 20px;
  font-weight: 700;
  color: var(--gold, #D4AF37);
}

/* =============================================
   STRIPE CHECKOUT MODAL
   ============================================= */
.co-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.72);
  z-index: 1100;
  opacity: 0; pointer-events: none;
  transition: opacity 0.3s;
}
.co-overlay.open { opacity: 1; pointer-events: all; }

.co-modal {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  max-width: 520px;
  margin: 0 auto;
  background: #130D1E;
  border-radius: 24px 24px 0 0;
  border-top: 1px solid rgba(168,85,247,0.2);
  z-index: 1101;
  max-height: 92vh;
  overflow-y: auto;
  transform: translateY(100%);
  transition: transform 0.35s cubic-bezier(0.32,0,0.15,1);
  display: flex;
  flex-direction: column;
}
.co-modal.open { transform: translateY(0); }

.co-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 20px 16px;
  border-bottom: 1px solid rgba(168,85,247,0.12);
  flex-shrink: 0;
  position: sticky; top: 0;
  background: #130D1E;
  z-index: 1;
}
.co-back-btn {
  background: rgba(168,85,247,0.1);
  border-radius: 10px;
  width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  border: none; cursor: pointer; color: #A855F7;
  transition: background 0.15s;
}
.co-back-btn:hover { background: rgba(168,85,247,0.2); }

.co-title {
  font-family: var(--font-display, serif);
  font-size: 17px; font-weight: 700;
  color: var(--text, #F3F0FF);
}

.co-body { padding: 20px; flex: 1; }

/* Summary */
.co-summary { margin-bottom: 20px; }
.co-sum-items { margin-bottom: 8px; }
.co-sum-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-size: 13px;
  color: var(--text-muted, #9CA3AF);
  padding: 4px 0;
  gap: 10px;
}
.co-sum-row span:first-child { flex: 1; }
.co-sum-row span:last-child { font-weight: 600; color: var(--text, #F3F0FF); flex-shrink: 0; }
.co-sum-divider { height: 1px; background: rgba(168,85,247,0.1); margin: 8px 0; }
.co-sum-discount span:last-child,
.co-sum-free    span:last-child { color: #6DAA45; }
.co-sum-total {
  font-size: 15px; font-weight: 700;
  padding-top: 8px;
  border-top: 1px solid rgba(168,85,247,0.12);
}
.co-sum-total span:first-child { color: var(--text, #F3F0FF); }
.co-sum-total span:last-child {
  font-family: var(--font-display, serif);
  font-size: 19px;
  color: var(--gold, #D4AF37);
}

/* Card form */
.co-section-label {
  font-size: 11px; font-weight: 800;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--text-muted, #9CA3AF);
  margin-bottom: 14px;
}
.co-field-wrap { margin-bottom: 14px; }
.co-label {
  display: block;
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.05em; text-transform: uppercase;
  color: var(--text-muted, #9CA3AF);
  margin-bottom: 6px;
}
.co-input {
  width: 100%;
  background: rgba(168,85,247,0.06);
  border: 1.5px solid rgba(168,85,247,0.18);
  border-radius: 12px;
  color: var(--text, #F3F0FF);
  font-size: 15px;
  padding: 13px 14px;
  outline: none; box-sizing: border-box;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.co-input::placeholder { color: var(--text-faint, #6B617A); }
.co-input:focus {
  border-color: var(--purple, #A855F7);
  box-shadow: 0 0 0 3px rgba(168,85,247,0.15);
}
.co-stripe-element {
  background: rgba(168,85,247,0.06);
  border: 1.5px solid rgba(168,85,247,0.18);
  border-radius: 12px;
  padding: 14px;
  transition: border-color 0.2s;
}
.co-stripe-element.StripeElement--focus {
  border-color: var(--purple, #A855F7);
  box-shadow: 0 0 0 3px rgba(168,85,247,0.15);
}
.co-stripe-error {
  font-size: 12px; color: #F87171;
  margin-top: 6px; min-height: 16px;
}
.co-pay-btn {
  width: 100%;
  background: linear-gradient(135deg, #A855F7 0%, #7C3AED 100%);
  color: #fff; border: none;
  border-radius: 14px;
  font-size: 16px; font-weight: 800;
  padding: 15px 20px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  margin-top: 20px;
  box-shadow: 0 4px 24px rgba(168,85,247,0.4);
  letter-spacing: 0.02em;
  transition: opacity 0.15s, box-shadow 0.15s, transform 0.1s;
}
.co-pay-btn:hover  { opacity: 0.9; box-shadow: 0 6px 30px rgba(168,85,247,0.55); }
.co-pay-btn:active { transform: scale(0.98); }
.co-pay-btn:disabled { opacity: 0.55; cursor: not-allowed; }

.co-footer-trust {
  display: flex; align-items: center; justify-content: center; gap: 6px;
  padding: 13px 20px;
  font-size: 11px; color: var(--text-faint, #6B617A);
  border-top: 1px solid rgba(168,85,247,0.08);
  flex-shrink: 0;
}

/* ── PWA INSTALL BANNER ── */
#pwaInstallBanner {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  background: #1A1025;
  border-top: 2px solid #A855F7;
  padding: 14px 18px 20px;
  z-index: 9999;
  display: none;
  animation: slideUpBanner 0.35s ease;
}
@keyframes slideUpBanner {
  from { transform: translateY(100%); }
  to   { transform: translateY(0); }
}
.pwa-banner-inner {
  max-width: 480px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.pwa-banner-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.pwa-banner-text { flex: 1; }
.pwa-banner-title {
  font-size: 14px;
  font-weight: 700;
  color: #D4AF37;
  margin-bottom: 3px;
  letter-spacing: 0.3px;
}
.pwa-banner-sub {
  font-size: 12.5px;
  color: #C4B5FD;
  line-height: 1.45;
}
.pwa-banner-close {
  background: none;
  border: none;
  color: #6B7280;
  font-size: 20px;
  cursor: pointer;
  padding: 0;
  line-height: 1;
  flex-shrink: 0;
  margin-top: -2px;
}
.pwa-banner-steps {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.pwa-step {
  background: #2D1B4E;
  border: 1px solid #A855F7;
  border-radius: 20px;
  padding: 5px 12px;
  font-size: 11.5px;
  color: #E9D5FF;
  white-space: nowrap;
}
.pwa-step-arrow { color: #A855F7; font-size: 13px; }
.pwa-banner-btn {
  background: linear-gradient(135deg, #A855F7, #7C3AED);
  border: none;
  border-radius: 10px;
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  padding: 10px;
  cursor: pointer;
  width: 100%;
  letter-spacing: 0.3px;
}

/* ── iOS SAFE AREA (iPhone home indicator) ── */
.home-footer {
  padding-bottom: calc(var(--sp-12, 3rem) + env(safe-area-inset-bottom, 0px));
}
#pwaInstallBanner {
  padding-bottom: calc(14px + env(safe-area-inset-bottom, 0px));
}
.cart-sheet {
  padding-bottom: env(safe-area-inset-bottom, 0px);
}
.cart-footer {
  padding-bottom: calc(var(--sp-4, 1rem) + env(safe-area-inset-bottom, 0px));
}
