/* ═══════════════════════════════════════════════════════════════
   LUNELLA — single-file marketing site (self-contained, offline)
   Palette: peach #FFB199 · pink #FF7EB3 · rose #E0457B
            lilac #B96FE0 · cream #FFF8EF · plum ink #2E1A2E
   Type:   serif display (system) + sans UI (system)
   ═══════════════════════════════════════════════════════════════ */
:root{
  --peach:#FFB199;
  --pink:#FF7EB3;
  --rose:#E0457B;
  --rose-deep:#C2305F;
  --lilac:#B96FE0;
  --lilac-deep:#9A4FC4;
  --cream:#FFF8EF;
  --cream-2:#FFF1E4;
  --cream-3:#FCE9DC;
  --ink:#2E1A2E;
  --ink-soft:#6E5468;
  --ink-faint:#9D8A97;
  --white:#FFFFFF;
  --line:rgba(46,26,46,0.09);
  --line-2:rgba(46,26,46,0.14);
  --grad-warm:linear-gradient(120deg,#FFB199 0%,#FF7EB3 48%,#B96FE0 100%);
  --grad-cta:linear-gradient(120deg,#FF8FB0 0%,#E0457B 55%,#B96FE0 120%);
  --shadow-xs:0 1px 3px rgba(46,26,46,0.05);
  --shadow-sm:0 4px 16px -6px rgba(46,26,46,0.10);
  --shadow-md:0 18px 44px -20px rgba(224,69,123,0.30);
  --shadow-lg:0 40px 90px -34px rgba(120,40,90,0.45);
  --shadow-phone:0 50px 100px -34px rgba(120,30,80,0.45),0 14px 40px -20px rgba(46,26,46,0.25);
  --radius:24px;
  --radius-lg:34px;
  --maxw:1180px;
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI","Inter",Roboto,Helvetica,Arial,sans-serif;
  --font-serif:"Iowan Old Style","Palatino Linotype","Palatino","Book Antiqua",Georgia,"Times New Roman",serif;
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:90px;-webkit-text-size-adjust:100%;}
body{
  margin:0;font-family:var(--font);color:var(--ink);background:var(--cream);
  line-height:1.62;font-size:17px;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
h1,h2,h3{margin:0;}
.display{font-family:var(--font-serif);font-weight:600;letter-spacing:-0.01em;line-height:1.04;}
h1{font-size:clamp(2.7rem,6.2vw,4.6rem);}
h2{font-size:clamp(2rem,4.2vw,3.1rem);}
h3{font-size:1.18rem;font-weight:750;letter-spacing:-0.01em;line-height:1.25;}
p{margin:0;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px;width:100%;}
.eyebrow{
  font-size:0.76rem;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--rose);display:inline-flex;align-items:center;gap:9px;
}
.eyebrow::before{content:"";width:22px;height:1.5px;background:linear-gradient(90deg,var(--peach),var(--rose));border-radius:2px;}
.eyebrow.center::before{display:none;}

.btn{display:inline-flex;align-items:center;gap:10px;border:none;cursor:pointer;font-family:inherit;
  font-weight:650;font-size:1rem;padding:14px 24px;border-radius:15px;
  transition:transform .2s ease,box-shadow .25s ease,background .25s ease,color .2s ease;text-decoration:none;}
.btn:active{transform:scale(0.985);}
.btn-ghost{background:transparent;color:var(--ink);padding:13px 18px;border-radius:13px;border:1px solid var(--line-2);}
.btn-ghost:hover{background:rgba(46,26,46,0.05);border-color:rgba(224,69,123,0.3);color:var(--rose-deep);}

/* ── Google Play badge (drawn) ── */
.play-badge{display:inline-flex;align-items:center;gap:13px;background:#1B1020;color:#fff;
  border-radius:15px;padding:11px 22px 11px 18px;box-shadow:0 14px 34px -14px rgba(27,16,32,0.6);
  transition:transform .2s ease,box-shadow .25s ease;border:1px solid rgba(255,255,255,0.08);}
.play-badge:hover{transform:translateY(-2px);box-shadow:0 20px 44px -16px rgba(27,16,32,0.65);}
.play-badge .tri{width:23px;height:25px;flex:none;}
.play-badge .pb-text{display:flex;flex-direction:column;line-height:1.05;text-align:left;}
.play-badge .pb-small{font-size:0.64rem;letter-spacing:0.05em;opacity:0.82;text-transform:uppercase;font-weight:600;}
.play-badge .pb-big{font-size:1.25rem;font-weight:700;letter-spacing:0.01em;margin-top:2px;}

/* ═══════════ HEADER ═══════════ */
header{position:sticky;top:0;z-index:80;backdrop-filter:saturate(150%) blur(16px);
  -webkit-backdrop-filter:saturate(150%) blur(16px);background:rgba(255,248,239,0.74);
  border-bottom:1px solid transparent;transition:border-color .3s ease,box-shadow .3s ease;}
header.scrolled{border-bottom-color:var(--line);box-shadow:0 10px 34px -26px rgba(46,26,46,0.6);}
.scroll-progress{position:absolute;top:0;left:0;height:2.5px;width:0;
  background:linear-gradient(90deg,var(--peach),var(--pink),var(--lilac));border-radius:0 2px 2px 0;transition:width .1s linear;}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px;}
.brand{display:flex;align-items:center;gap:11px;font-weight:800;font-size:1.34rem;letter-spacing:-0.02em;}
.brand .moon-glyph{width:32px;height:32px;flex:none;}
.nav-links{display:flex;align-items:center;gap:4px;}
.nav-links a:not(.play-badge){padding:9px 14px;border-radius:11px;font-weight:600;font-size:0.95rem;
  color:var(--ink-soft);transition:color .2s ease,background .2s ease;}
.nav-links a:not(.play-badge):hover{color:var(--ink);background:rgba(46,26,46,0.05);}
.nav-cta{margin-left:10px;padding:8px 16px 8px 13px;border-radius:13px;}
.nav-cta .pb-big{font-size:1.0rem;}
.nav-cta .pb-small{font-size:0.55rem;}
.nav-cta .tri{width:17px;height:19px;}
.menu-btn{display:none;background:none;border:none;cursor:pointer;padding:8px;border-radius:10px;color:var(--ink);}
.menu-btn:hover{background:rgba(46,26,46,0.06);}
.mobile-menu{display:none;flex-direction:column;gap:4px;padding:8px 26px 24px;
  background:rgba(255,248,239,0.98);border-bottom:1px solid var(--line);}
.mobile-menu.open{display:flex;}
.mobile-menu a:not(.play-badge){padding:13px 12px;border-radius:12px;font-weight:650;color:var(--ink);}
.mobile-menu a:not(.play-badge):hover{background:rgba(46,26,46,0.05);}
.mobile-menu .play-badge{margin-top:12px;align-self:flex-start;}

/* ═══════════ HERO ═══════════ */
.hero{position:relative;overflow:hidden;padding:clamp(48px,7vw,86px) 0 clamp(60px,8vw,104px);}
.hero-bg{position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(115% 80% at 82% 4%, rgba(185,111,224,0.32) 0%, rgba(185,111,224,0) 52%),
    radial-gradient(100% 70% at 6% 96%, rgba(255,177,153,0.46) 0%, rgba(255,177,153,0) 52%),
    radial-gradient(120% 100% at 96% 92%, rgba(255,126,179,0.30) 0%, rgba(255,126,179,0) 48%),
    linear-gradient(180deg,#FFEFE2 0%, #FFF8EF 62%, #FFF8EF 100%);}
.hero-bg::after{content:"";position:absolute;inset:0;
  background-image:
    radial-gradient(1.6px 1.6px at 22% 26%, rgba(255,255,255,0.95), transparent),
    radial-gradient(1.4px 1.4px at 64% 16%, rgba(255,255,255,0.75), transparent),
    radial-gradient(1.8px 1.8px at 88% 52%, rgba(255,255,255,0.85), transparent),
    radial-gradient(1.3px 1.3px at 44% 72%, rgba(255,255,255,0.65), transparent);}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.04fr 0.96fr;
  gap:clamp(24px,4vw,56px);align-items:center;}
.hero-copy{max-width:560px;}
.hero h1{margin:20px 0 0;}
.hero h1 .accent{background:linear-gradient(108deg,var(--rose),var(--lilac));
  -webkit-background-clip:text;background-clip:text;color:transparent;}
.hero .sub{font-size:clamp(1.06rem,1.5vw,1.22rem);color:var(--ink-soft);margin-top:24px;max-width:480px;}
.hero-actions{display:flex;flex-wrap:wrap;align-items:center;gap:15px;margin-top:34px;}
.hero-trust{display:flex;flex-wrap:wrap;gap:14px 22px;margin-top:32px;}
.trust-item{display:flex;align-items:center;gap:9px;font-size:0.9rem;font-weight:600;color:var(--ink-soft);}
.trust-item svg{width:18px;height:18px;color:var(--rose);flex:none;}

/* hero visual: phone + moon */
.hero-visual{position:relative;display:flex;align-items:center;justify-content:center;min-height:520px;}
.moon-stage{position:absolute;top:-2%;right:2%;width:min(230px,42%);aspect-ratio:1;z-index:1;}
.moon-halo{position:absolute;inset:-14%;border-radius:50%;
  background:radial-gradient(circle at 50% 46%, rgba(255,238,214,0.95) 0%, rgba(255,182,202,0.5) 30%, rgba(185,111,224,0.28) 54%, rgba(185,111,224,0) 72%);
  filter:blur(4px);animation:halo-pulse 7s ease-in-out infinite;}
.moon-svg{position:relative;z-index:2;width:100%;height:100%;animation:moon-float 9s ease-in-out infinite;}
.spark{position:absolute;z-index:3;color:#FFF6E9;filter:drop-shadow(0 0 6px rgba(255,210,170,0.9));animation:twinkle 4s ease-in-out infinite;}
.spark.s1{top:-8%;left:-6%;width:24px;}
.spark.s2{bottom:6%;left:-12%;width:16px;animation-delay:1.2s;}
.spark.s3{top:16%;right:-8%;width:18px;animation-delay:2.1s;}

@keyframes moon-float{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-14px) rotate(-2deg)}}
@keyframes halo-pulse{0%,100%{opacity:0.8;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}
@keyframes twinkle{0%,100%{opacity:0.35;transform:scale(0.85)}50%{opacity:1;transform:scale(1.12)}}

/* ═══════════ PHONE MOCKUP ═══════════ */
/* Real app screenshots (already include the device frame; transparent corners,
   so a drop-shadow follows the phone silhouette). */
.phone-shot{position:relative;z-index:5;display:block;width:300px;max-width:82vw;height:auto;
  filter:drop-shadow(0 26px 52px rgba(214,51,108,0.22)) drop-shadow(0 6px 16px rgba(46,26,46,0.12));}
.show-visual .phone-shot,.hero-visual .phone-shot{flex:none;}

/* "More screens" gallery */
.shots{margin-top:60px;display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,4vw,56px);align-items:start;}
.shots figure{margin:0;display:flex;flex-direction:column;align-items:center;text-align:center;}
.shots img{width:248px;max-width:100%;height:auto;
  filter:drop-shadow(0 20px 42px rgba(214,51,108,0.20)) drop-shadow(0 5px 14px rgba(46,26,46,0.10));}
.shots figcaption{margin-top:20px;color:var(--ink-soft);font-size:0.98rem;line-height:1.5;max-width:30ch;}
.shots figcaption strong{display:block;color:var(--ink);font-weight:700;margin-bottom:4px;font-size:1.02rem;}

.phone{position:relative;z-index:5;width:300px;flex:none;border-radius:46px;
  background:linear-gradient(150deg,#2A1828,#140A14);padding:11px;box-shadow:var(--shadow-phone);}
.phone::after{content:"";position:absolute;top:14px;left:50%;transform:translateX(-50%);
  width:120px;height:26px;background:#100810;border-radius:0 0 16px 16px;z-index:6;}
.phone-screen{position:relative;border-radius:36px;overflow:hidden;background:var(--cream);
  aspect-ratio:9/19.3;display:flex;flex-direction:column;}
.ps-status{display:flex;align-items:center;justify-content:space-between;padding:13px 22px 4px;
  font-size:0.7rem;font-weight:700;color:var(--ink);}
.ps-status .dots{display:flex;gap:4px;align-items:center;}
.ps-status .dots svg{width:15px;height:15px;}
.ps-body{flex:1;padding:6px 18px 0;overflow:hidden;}
.ps-appbar{display:flex;align-items:center;justify-content:space-between;padding:6px 0 4px;}
.ps-appbar .ab-brand{display:flex;align-items:center;gap:7px;font-weight:800;font-size:1.02rem;letter-spacing:-0.01em;}
.ps-appbar .ab-brand svg{width:18px;height:18px;}
.ps-appbar .ab-ava{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--peach),var(--lilac));}
.ps-greet{font-size:0.78rem;color:var(--ink-faint);margin:2px 0 0;font-weight:600;}

/* cycle ring */
.cyc-ring{position:relative;width:172px;height:172px;margin:14px auto 8px;border-radius:50%;
  background:conic-gradient(from 214deg,
    #FFC59E 0deg, #FF8FB0 90deg, #E0457B 150deg, #B96FE0 210deg,
    rgba(185,111,224,0.16) 210deg, rgba(185,111,224,0.12) 360deg);}
.cyc-ring::before{content:"";position:absolute;inset:15px;background:var(--white);border-radius:50%;
  box-shadow:inset 0 0 0 1px rgba(46,26,46,0.04);}
.cyc-marker{position:absolute;inset:0;transform:rotate(204deg);}
.cyc-marker::after{content:"";position:absolute;top:-3px;left:calc(50% - 9px);width:18px;height:18px;
  border-radius:50%;background:#fff;border:4px solid var(--rose);box-shadow:0 2px 8px rgba(224,69,123,0.5);}
.cyc-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:2;}
.cyc-center .cc-k{font-size:0.6rem;font-weight:700;letter-spacing:0.18em;color:var(--ink-faint);text-transform:uppercase;}
.cyc-center .cc-d{font-family:var(--font-serif);font-size:2.9rem;font-weight:600;line-height:0.9;color:var(--ink);margin:2px 0;}
.cyc-center .cc-tag{font-size:0.66rem;font-weight:700;color:var(--lilac-deep);background:rgba(185,111,224,0.14);
  padding:3px 10px;border-radius:999px;}
.ps-phasebar{display:flex;gap:6px;margin:10px 2px 0;}
.phase-chip{flex:1;text-align:center;font-size:0.58rem;font-weight:700;padding:6px 2px;border-radius:9px;
  color:var(--ink-soft);background:rgba(46,26,46,0.04);}
.phase-chip.active{background:linear-gradient(135deg,rgba(255,126,179,0.22),rgba(185,111,224,0.22));color:var(--rose-deep);}
.ps-logcard{margin:11px 2px 0;background:linear-gradient(135deg,#FFF,#FFF6EF);border:1px solid var(--line);
  border-radius:16px;padding:12px 14px;display:flex;align-items:center;gap:11px;}
.ps-logcard .lc-ic{width:34px;height:34px;border-radius:11px;flex:none;display:flex;align-items:center;justify-content:center;
  background:var(--grad-cta);color:#fff;}
.ps-logcard .lc-ic svg{width:18px;height:18px;}
.ps-logcard .lc-t{font-weight:750;font-size:0.82rem;}
.ps-logcard .lc-s{font-size:0.68rem;color:var(--ink-faint);}

/* bottom nav */
.ps-nav{margin-top:auto;display:flex;justify-content:space-around;align-items:center;padding:11px 14px;
  padding-bottom:18px;background:rgba(255,255,255,0.7);border-top:1px solid var(--line);}
.ps-nav .nb{display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--ink-faint);}
.ps-nav .nb svg{width:20px;height:20px;}
.ps-nav .nb.on{color:var(--rose);}
.ps-nav .nb .plus{width:36px;height:36px;border-radius:50%;background:var(--grad-cta);color:#fff;
  display:flex;align-items:center;justify-content:center;box-shadow:0 8px 18px -8px rgba(224,69,123,0.7);margin-top:-2px;}
.ps-nav .nb .plus svg{width:20px;height:20px;}

/* calendar screen */
.ps-cal-head{display:flex;align-items:center;justify-content:space-between;margin:8px 2px 10px;}
.ps-cal-head .cm{font-family:var(--font-serif);font-size:1.15rem;font-weight:600;}
.ps-cal-head .nav-a{display:flex;gap:8px;color:var(--ink-faint);}
.ps-cal-head .nav-a svg{width:16px;height:16px;}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px 2px;}
.cal-dow{font-size:0.56rem;font-weight:700;text-align:center;color:var(--ink-faint);text-transform:uppercase;letter-spacing:0.05em;padding-bottom:2px;}
.cal-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:0.72rem;font-weight:600;
  color:var(--ink-soft);border-radius:50%;position:relative;}
.cal-day.period{background:linear-gradient(135deg,var(--pink),var(--rose));color:#fff;font-weight:700;}
.cal-day.fertile{color:var(--lilac-deep);font-weight:700;}
.cal-day.fertile::after{content:"";position:absolute;bottom:3px;width:4px;height:4px;border-radius:50%;background:var(--lilac);}
.cal-day.today{box-shadow:inset 0 0 0 2px var(--rose);color:var(--rose-deep);font-weight:800;}
.cal-day.muted{color:var(--ink-faint);opacity:0.4;}
.cal-legend{display:flex;gap:13px;margin:14px 2px 0;flex-wrap:wrap;}
.cal-legend .lg{display:flex;align-items:center;gap:6px;font-size:0.62rem;font-weight:600;color:var(--ink-soft);}
.cal-legend .sw{width:11px;height:11px;border-radius:50%;}
.ps-predict{margin:14px 2px 0;background:linear-gradient(135deg,#FFF1F6,#F6EEFF);border:1px solid var(--line);
  border-radius:16px;padding:13px 15px;}
.ps-predict .pd-k{font-size:0.58rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--rose);}
.ps-predict .pd-t{font-family:var(--font-serif);font-size:1.05rem;font-weight:600;margin-top:3px;}

/* log screen */
.ps-log-h{font-family:var(--font-serif);font-size:1.3rem;font-weight:600;margin:10px 2px 2px;}
.ps-log-sub{font-size:0.72rem;color:var(--ink-faint);margin:0 2px 14px;font-weight:600;}
.ps-section-l{font-size:0.62rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-faint);margin:14px 2px 9px;}
.mood-row{display:flex;justify-content:space-between;gap:6px;margin:0 2px;}
.mood{flex:1;aspect-ratio:1;border-radius:50%;background:rgba(46,26,46,0.04);display:flex;align-items:center;justify-content:center;color:var(--ink-faint);}
.mood svg{width:22px;height:22px;}
.mood.sel{background:var(--grad-cta);color:#fff;box-shadow:0 8px 18px -8px rgba(224,69,123,0.6);}
.chip-row{display:flex;flex-wrap:wrap;gap:7px;margin:0 2px;}
.sym-chip{font-size:0.68rem;font-weight:650;padding:7px 12px;border-radius:999px;background:rgba(46,26,46,0.04);color:var(--ink-soft);}
.sym-chip.sel{background:linear-gradient(135deg,rgba(255,126,179,0.2),rgba(185,111,224,0.2));color:var(--rose-deep);box-shadow:inset 0 0 0 1px rgba(224,69,123,0.25);}

/* ═══════════ SECTION SHELL ═══════════ */
.section-pad{padding:clamp(64px,9vw,116px) 0;}
.section-head{max-width:640px;margin:0 auto;text-align:center;}
.section-head .eyebrow{justify-content:center;}
.section-head h2{margin-top:16px;}
.section-head p{color:var(--ink-soft);margin-top:18px;font-size:1.1rem;}

/* ═══════════ FEATURES (bento) ═══════════ */
.features{background:linear-gradient(180deg,var(--cream) 0%, #FFF1E4 100%);}
.bento{display:grid;grid-template-columns:repeat(6,1fr);gap:20px;margin-top:58px;}
.f-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:30px 28px;
  box-shadow:var(--shadow-xs);transition:transform .25s ease,box-shadow .3s ease,border-color .3s ease;
  display:flex;flex-direction:column;}
.f-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:rgba(224,69,123,0.2);}
.f-card.span-3{grid-column:span 3;}
.f-card.span-2{grid-column:span 2;}
.lang-line{text-align:center;margin-top:42px;color:var(--ink-soft);font-size:.98rem;letter-spacing:.2px;}
.f-card.feature-hero{grid-column:span 3;grid-row:span 2;position:relative;overflow:hidden;
  background:linear-gradient(155deg,#3A1F3C 0%,#5A2750 55%,#7A3168 100%);color:#FCEFF6;justify-content:flex-end;min-height:300px;}
.f-card.feature-hero::before{content:"";position:absolute;inset:0;
  background:radial-gradient(70% 60% at 78% 14%, rgba(255,126,179,0.4) 0%, transparent 60%),
            radial-gradient(60% 60% at 10% 96%, rgba(185,111,224,0.4) 0%, transparent 60%);}
.f-card.feature-hero .fh-moon{position:absolute;top:24px;right:26px;width:88px;height:88px;z-index:1;
  filter:drop-shadow(0 0 24px rgba(255,210,170,0.6));}
.f-card.feature-hero h3,.f-card.feature-hero p{position:relative;z-index:2;}
.f-card.feature-hero h3{font-family:var(--font-serif);font-weight:600;font-size:1.7rem;color:#fff;line-height:1.12;}
.f-card.feature-hero p{color:rgba(252,239,246,0.82);margin-top:12px;font-size:1rem;}
.f-card.feature-hero .fh-badge{position:relative;z-index:2;display:inline-flex;align-items:center;gap:8px;
  align-self:flex-start;margin-bottom:auto;background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.2);
  padding:7px 14px;border-radius:999px;font-size:0.74rem;font-weight:700;letter-spacing:0.05em;backdrop-filter:blur(6px);}
.f-icon{width:52px;height:52px;border-radius:15px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,rgba(255,177,153,0.96),rgba(255,126,179,0.92));color:#fff;
  margin-bottom:18px;box-shadow:0 10px 22px -10px rgba(224,69,123,0.55);}
.f-icon.alt{background:linear-gradient(135deg,rgba(255,126,179,0.96),rgba(185,111,224,0.94));}
.f-icon svg{width:26px;height:26px;}
.f-card h3{margin-bottom:9px;}
.f-card p{color:var(--ink-soft);font-size:0.98rem;}

/* ═══════════ SHOWCASE ═══════════ */
.showcase{background:var(--cream);}
.show-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,90px);align-items:center;}
.show-row + .show-row{margin-top:clamp(70px,9vw,120px);}
.show-row.flip .show-visual{order:2;}
.show-text{max-width:460px;}
.show-text h3{font-family:var(--font-serif);font-weight:600;font-size:clamp(1.7rem,3vw,2.3rem);line-height:1.1;margin-top:16px;}
.show-text p{color:var(--ink-soft);margin-top:16px;font-size:1.06rem;}
.show-list{list-style:none;padding:0;margin:24px 0 0;display:flex;flex-direction:column;gap:13px;}
.show-list li{display:flex;align-items:flex-start;gap:12px;font-size:0.98rem;color:var(--ink);font-weight:500;}
.show-list li svg{width:20px;height:20px;flex:none;color:var(--rose);margin-top:3px;}
.show-visual{position:relative;display:flex;justify-content:center;align-items:center;min-height:560px;}
.show-visual::before{content:"";position:absolute;width:78%;aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle, rgba(255,177,153,0.4) 0%, rgba(255,126,179,0.18) 45%, transparent 70%);
  filter:blur(10px);z-index:0;}

/* ═══════════ PRIVACY BAND ═══════════ */
.privacy-band{position:relative;overflow:hidden;color:#FCEFF6;
  background:linear-gradient(135deg,#34193A 0%, #4A2240 46%, #6B2B57 100%);}
.privacy-band::before{content:"";position:absolute;inset:0;
  background:radial-gradient(66% 88% at 88% 10%, rgba(255,126,179,0.32) 0%, transparent 58%),
            radial-gradient(58% 78% at 5% 92%, rgba(185,111,224,0.32) 0%, transparent 58%);}
.privacy-band::after{content:"";position:absolute;inset:0;opacity:0.5;
  background-image:
    radial-gradient(1.5px 1.5px at 15% 24%, rgba(255,255,255,0.7),transparent),
    radial-gradient(1.3px 1.3px at 76% 34%, rgba(255,255,255,0.6),transparent),
    radial-gradient(1.6px 1.6px at 60% 80%, rgba(255,255,255,0.7),transparent),
    radial-gradient(1.2px 1.2px at 34% 64%, rgba(255,255,255,0.5),transparent);}
.privacy-inner{position:relative;z-index:2;text-align:center;max-width:780px;margin:0 auto;}
.privacy-inner .eyebrow{color:#FFB7D2;justify-content:center;}
.privacy-inner .eyebrow::before{background:linear-gradient(90deg,var(--peach),#FFB7D2);}
.privacy-inner h2{color:#fff;margin-top:18px;font-size:clamp(2.1rem,4.6vw,3.3rem);}
.privacy-inner .promise{color:rgba(252,239,246,0.82);font-size:1.14rem;margin-top:22px;max-width:580px;margin-left:auto;margin-right:auto;}
.promise-chips{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin-top:36px;}
.chip{display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.16);padding:10px 18px;border-radius:999px;font-weight:600;font-size:0.94rem;backdrop-filter:blur(6px);}
.chip svg{width:16px;height:16px;color:#FFC4DB;flex:none;}

/* ═══════════ FAQ ═══════════ */
.faq-list{max-width:800px;margin:52px auto 0;display:flex;flex-direction:column;gap:14px;}
.faq-item{background:var(--white);border:1px solid var(--line);border-radius:18px;overflow:hidden;
  transition:box-shadow .25s ease,border-color .25s ease;}
.faq-item.open{box-shadow:var(--shadow-md);border-color:rgba(224,69,123,0.2);}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:18px;background:none;border:none;
  cursor:pointer;font-family:inherit;text-align:left;padding:22px 24px;font-size:1.08rem;font-weight:700;color:var(--ink);}
.faq-q .q-icon{width:28px;height:28px;flex:none;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--pink),var(--lilac));color:#fff;transition:transform .3s ease;}
.faq-item.open .q-icon{transform:rotate(45deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;}
.faq-a-inner{padding:0 24px 22px;color:var(--ink-soft);font-size:1rem;}
.faq-a-inner a{color:var(--rose);font-weight:600;text-decoration:underline;text-underline-offset:2px;}

/* ═══════════ PRIVACY POLICY ═══════════ */
.policy{background:linear-gradient(180deg,#FFF1E4 0%, var(--cream) 100%);}
.policy-shell{display:grid;grid-template-columns:240px 1fr;gap:48px;align-items:start;max-width:980px;margin:48px auto 0;}
.policy-toc{position:sticky;top:100px;}
.policy-toc .toc-k{font-size:0.7rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:14px;}
.policy-toc a{display:block;padding:7px 12px;border-radius:10px;font-size:0.92rem;font-weight:600;color:var(--ink-soft);
  border-left:2px solid transparent;transition:color .2s,background .2s,border-color .2s;}
.policy-toc a:hover{color:var(--rose-deep);background:rgba(224,69,123,0.06);border-left-color:var(--rose);}
.policy-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(28px,4vw,48px);box-shadow:var(--shadow-xs);}
.policy-card .meta{font-size:0.9rem;color:var(--ink-faint);margin:0 0 4px;}
.policy-card h3{scroll-margin-top:100px;margin-top:32px;font-size:1.08rem;color:var(--ink);
  display:flex;align-items:center;gap:10px;}
.policy-card h3 .hx{width:26px;height:26px;border-radius:8px;flex:none;display:flex;align-items:center;justify-content:center;
  background:rgba(224,69,123,0.1);color:var(--rose-deep);}
.policy-card h3 .hx svg{width:14px;height:14px;}
.policy-card p{color:var(--ink-soft);margin-top:10px;font-size:1rem;}
.policy-card .lead{font-size:1.1rem;color:var(--ink);margin-top:18px;line-height:1.6;}
.policy-card a{color:var(--rose);font-weight:600;}

/* ═══════════ FINAL CTA ═══════════ */
.final-cta{position:relative;overflow:hidden;background:linear-gradient(135deg,#FFB199 0%,#FF7EB3 50%,#B96FE0 100%);
  text-align:center;color:#fff;}
.final-cta::after{content:"";position:absolute;inset:0;
  background-image:radial-gradient(1.6px 1.6px at 20% 30%, rgba(255,255,255,0.9), transparent),
    radial-gradient(1.4px 1.4px at 78% 22%, rgba(255,255,255,0.7), transparent),
    radial-gradient(1.6px 1.6px at 62% 74%, rgba(255,255,255,0.8), transparent);}
.final-cta .fc-inner{position:relative;z-index:2;max-width:680px;margin:0 auto;}
.final-cta h2{color:#fff;font-size:clamp(2.1rem,4.6vw,3.2rem);text-shadow:0 2px 20px rgba(120,30,80,0.25);}
.final-cta p{color:rgba(255,255,255,0.9);font-size:1.14rem;margin-top:18px;}
.final-cta .fc-actions{display:flex;justify-content:center;flex-wrap:wrap;gap:14px;margin-top:34px;}
.final-cta .play-badge{background:#1B1020;}
.final-cta .note{margin-top:22px;font-size:0.9rem;color:rgba(255,255,255,0.82);font-weight:600;}

/* ═══════════ FOOTER ═══════════ */
footer{background:#241324;color:rgba(255,243,250,0.66);padding:66px 0 36px;}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px;}
.footer-brand{max-width:340px;}
.footer-brand .brand{color:#fff;margin-bottom:14px;}
.footer-brand p{color:rgba(255,243,250,0.6);font-size:0.96rem;}
.footer-col h4{color:#fff;font-size:0.8rem;letter-spacing:0.13em;text-transform:uppercase;font-weight:700;margin:0 0 16px;}
.footer-col a{display:block;padding:6px 0;color:rgba(255,243,250,0.64);font-size:0.96rem;transition:color .2s ease;}
.footer-col a:hover{color:#fff;}
.footer-langs{font-size:0.92rem;color:rgba(255,243,250,0.55);margin-top:6px;line-height:1.85;}
.footer-bottom{display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center;
  margin-top:50px;padding-top:28px;border-top:1px solid rgba(255,255,255,0.10);font-size:0.9rem;color:rgba(255,243,250,0.5);}
.footer-bottom a{color:rgba(255,243,250,0.66);}
.footer-bottom a:hover{color:#fff;}

/* ═══════════ REVEAL ANIM ═══════════ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1);}
.reveal.in{opacity:1;transform:none;}

/* ═══════════ RESPONSIVE ═══════════ */
@media (max-width:960px){
  .bento{grid-template-columns:repeat(4,1fr);}
  .f-card.feature-hero{grid-column:span 4;grid-row:auto;min-height:240px;}
  .f-card.span-3{grid-column:span 2;}
  .f-card.span-2{grid-column:span 2;}
}
@media (max-width:880px){
  .hero-grid{grid-template-columns:1fr;text-align:center;}
  .hero-copy{max-width:none;margin:0 auto;}
  .hero .sub{margin-left:auto;margin-right:auto;}
  .hero-actions,.hero-trust{justify-content:center;}
  .hero-visual{order:-1;min-height:0;margin-bottom:8px;}
  .moon-stage{width:150px;top:-10px;right:6%;}
  .nav-links{display:none;}
  .menu-btn{display:flex;}
  .show-row{grid-template-columns:1fr;gap:36px;text-align:center;}
  .show-row.flip .show-visual{order:0;}
  .show-text{max-width:none;margin:0 auto;}
  .show-list{display:inline-flex;text-align:left;}
  .show-visual{min-height:0;}
  .shots{grid-template-columns:1fr;gap:48px;}
  .policy-shell{grid-template-columns:1fr;gap:24px;}
  .policy-toc{position:static;display:none;}
  .footer-top{grid-template-columns:1fr 1fr;}
  .footer-brand{grid-column:1 / -1;}
}
@media (max-width:620px){
  body{font-size:16px;}
  .wrap{padding:0 18px;}
  .bento{grid-template-columns:1fr;}
  .f-card.feature-hero,.f-card.span-3,.f-card.span-2{grid-column:span 1;}
  .footer-top{grid-template-columns:1fr;}
  .hero-actions{flex-direction:column;align-items:stretch;}
  .hero-actions .play-badge,.hero-actions .btn{justify-content:center;}
  .final-cta .fc-actions{flex-direction:column;align-items:stretch;}
  .footer-bottom{flex-direction:column;align-items:flex-start;}
  .phone{width:270px;}
}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  .moon-svg,.moon-halo,.spark{animation:none !important;}
  .reveal{opacity:1 !important;transform:none !important;}
  *{transition-duration:0.01ms !important;}
}
