:root{
  --purple:#7F77DD;--purple-light:#EEEDFE;--purple-mid:#534AB7;--purple-deep:#26215C;--purple-border:#AFA9EC;--purple-tint:#F6F5FE;
  --green:#1D9E75;--green-light:#E1F5EE;--coral:#D85A30;--coral-light:#FAECE7;--amber:#BA7517;--amber-light:#FAEEDA;--olive:#639922;--olive-light:#EAF3DE;
  --text:#1a1825;--text-muted:#5F5E5A;--text-faint:#6f6e68;--border:#e8e6f0;--border-soft:#f0eef5;
  --bg:#ffffff;--bg-warm:#FBFAF7;--bg-tint:#F6F5FE;
  --serif:'Newsreader','Times New Roman',serif;--sans:'Inter',system-ui,sans-serif;--mono:'JetBrains Mono',ui-monospace,monospace;--hand:'Caveat','Segoe Script',cursive;
  --radius:12px;--radius-lg:18px;
  --shadow-soft:0 16px 32px -16px rgba(127,119,221,0.22);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;overflow-x:clip;}
body{font-family:var(--sans);background:var(--bg);color:var(--text);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;}
a{color:inherit;text-decoration:none;}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit;}
h1,h2,h3,h4{margin:0;line-height:1.15;letter-spacing:-0.02em;}
p{margin:0;}
img{max-width:100%;display:block;}
.shell{max-width:1180px;margin:0 auto;padding:0 32px;}

/* Skip link (keyboard a11y) */
.skip-link{position:absolute;left:-9999px;top:0;z-index:100;background:var(--purple);color:#fff;padding:10px 16px;border-radius:8px;font-size:14px;font-weight:600;}
.skip-link:focus{left:12px;top:12px;}

/* Reveal */
.reveal{opacity:0;transform:translateY(20px);transition:opacity 800ms cubic-bezier(.2,.8,.2,1),transform 800ms cubic-bezier(.2,.8,.2,1);transition-delay:var(--rd,0ms);}
.reveal.in{opacity:1;transform:translateY(0);}

/* Respect users who prefer reduced motion */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  *,*::before,*::after{animation-duration:0.001ms!important;animation-iteration-count:1!important;transition-duration:0.001ms!important;}
  .reveal{opacity:1!important;transform:none!important;}
}

/* Mono */
.mono{font-family:var(--mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--purple-mid);}

/* Nav */
.nav{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:16px 5%;background:rgba(255,255,255,0.85);backdrop-filter:blur(14px) saturate(1.2);-webkit-backdrop-filter:blur(14px) saturate(1.2);border-bottom:0.5px solid transparent;transition:border-color 200ms ease;}
.nav.scrolled{border-bottom-color:var(--border);}
.brand{display:flex;align-items:center;gap:10px;}
.brand-mark{width:34px;height:34px;display:grid;place-items:center;transition:transform 400ms cubic-bezier(.2,.8,.2,1);}
.brand-mark img{width:100%;height:100%;display:block;}
.brand:hover .brand-mark{transform:rotate(-6deg) scale(1.05);}
.brand-name{font-family:'Nunito','Inter',system-ui,sans-serif;font-size:22px;font-weight:900;letter-spacing:-0.3px;color:var(--purple-mid);}
.nav-right{display:flex;align-items:center;gap:14px;}
.nav-links{display:flex;gap:26px;}
.nav-links a{font-size:14px;color:var(--text-muted);position:relative;transition:color 200ms;}
.nav-links a:hover{color:var(--text);}
.nav-links a::after{content:'';position:absolute;left:0;bottom:-3px;width:100%;height:1px;background:var(--purple);transform:scaleX(0);transform-origin:right;transition:transform 280ms cubic-bezier(.2,.8,.2,1);}
.nav-links a:hover::after{transform:scaleX(1);transform-origin:left;}
.lang-toggle{display:flex;font-family:var(--mono);font-size:11px;border:0.5px solid var(--border);border-radius:999px;padding:3px;background:white;}
.lang-toggle a{padding:5px 11px;border-radius:999px;color:var(--text-faint);letter-spacing:0.08em;transition:all 200ms;}
.lang-toggle a.active{background:var(--text);color:white;}
.nav-signin{font-size:14px;color:var(--text-muted);font-weight:500;padding:9px 14px;border-radius:8px;transition:all 200ms;}
.nav-signin:hover{color:var(--text);background:var(--purple-light);}

.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 22px;border-radius:10px;font-size:14px;font-weight:500;transition:all 220ms cubic-bezier(.2,.8,.2,1);position:relative;overflow:hidden;}
.btn-primary{background:var(--purple);color:white;box-shadow:0 6px 16px -8px rgba(127,119,221,0.5);}
.btn-primary:hover{transform:translateY(-1px);background:var(--purple-mid);box-shadow:0 10px 24px -8px rgba(83,74,183,0.55);}
.btn-primary::after{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.25),transparent);transition:left 700ms ease;}
.btn-primary:hover::after{left:100%;}
.btn-secondary{background:white;color:var(--purple-mid);border:1.5px solid var(--purple-border);}
.btn-secondary:hover{background:var(--purple-light);}
.btn-arrow{display:inline-block;transition:transform 280ms cubic-bezier(.2,.8,.2,1);}
.btn:hover .btn-arrow{transform:translateX(4px);}

/* HERO */
.hero{position:relative;text-align:center;padding:80px 5% 40px;overflow:hidden;}
.hero-blobs{position:absolute;inset:0;pointer-events:none;z-index:0;}
.hero-blob{position:absolute;border-radius:50%;filter:blur(70px);opacity:0.5;}
.hero-blob-1{width:480px;height:480px;background:radial-gradient(circle,var(--purple-border),transparent 70%);top:-120px;left:-140px;animation:blob 22s ease-in-out infinite;}
.hero-blob-2{width:380px;height:380px;background:radial-gradient(circle,#9FE1CB,transparent 70%);top:80px;right:-120px;animation:blob 26s ease-in-out infinite -8s;}
.hero-blob-3{width:320px;height:320px;background:radial-gradient(circle,#F5C4B3,transparent 70%);bottom:-60px;left:35%;animation:blob 24s ease-in-out infinite -14s;opacity:0.4;}
@keyframes blob{0%,100%{transform:translate(0,0) scale(1);}33%{transform:translate(40px,-30px) scale(1.1);}66%{transform:translate(-30px,20px) scale(0.95);}}
.hero-inner{position:relative;z-index:2;}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--purple-light);color:var(--purple-mid);font-size:12px;font-weight:500;padding:6px 14px;border-radius:999px;border:0.5px solid var(--purple-border);margin-bottom:24px;}
.hero-badge .dot{width:6px;height:6px;border-radius:50%;background:var(--purple);box-shadow:0 0 0 3px rgba(127,119,221,0.25);animation:pulse 2.4s ease-in-out infinite;}
/* Founding-users launch banner. Warm honey accent so it pops against
   the purple hero badge without clashing. Sits ABOVE the hero badge
   to flag the promo first thing on landing. */
.founding-strip{display:inline-flex;align-items:center;gap:10px;background:#FFF4D6;color:#7A5A00;font-size:13px;font-weight:600;letter-spacing:0.2px;padding:8px 16px;border-radius:999px;border:0.5px solid #FFD86B;margin-bottom:14px;}
.founding-strip .gift{font-size:14px;line-height:1;}
@keyframes pulse{0%,100%{box-shadow:0 0 0 3px rgba(127,119,221,0.25);}50%{box-shadow:0 0 0 7px rgba(127,119,221,0);}}
.hero h1{font-size:clamp(36px,5.4vw,64px);font-weight:700;letter-spacing:-0.025em;line-height:1.05;max-width:880px;margin:0 auto 22px;}
.hero h1 .em{display:inline-block;font-family:var(--hand);font-style:normal;font-weight:700;font-size:1.12em;color:var(--purple);letter-spacing:0;position:relative;}
.hero h1 .em::after{content:'';position:absolute;left:0;right:0;bottom:-6px;height:8px;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 8' preserveAspectRatio='none'><path d='M2 5 Q 50 1 100 4 T 198 3' stroke='%237F77DD' stroke-width='2' fill='none' stroke-linecap='round'/></svg>") no-repeat center;background-size:100% 100%;opacity:0.7;}
.hero p.sub{font-size:18px;color:var(--text-muted);max-width:580px;margin:0 auto 32px;line-height:1.6;}
.hero-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}
.hero-note{font-size:13px;color:var(--text-faint);margin-top:16px;}
.hero-rotator-wrap{text-align:center;margin-top:20px;min-height:30px;}
.hero-rotator{font-family:var(--serif);font-style:italic;font-size:19px;color:var(--purple-mid);display:inline-block;transition:opacity 500ms ease,transform 500ms ease;}
.hero-rotator.fading{opacity:0;transform:translateY(4px);}
.hero-badge-wrap{text-align:center;margin-top:18px;}
.appstore-badge{display:inline-flex;align-items:center;gap:10px;background:#000;color:#fff;border-radius:11px;padding:8px 18px;text-decoration:none;transition:transform 220ms cubic-bezier(.2,.8,.2,1),box-shadow 220ms;box-shadow:0 6px 16px -8px rgba(0,0,0,0.5);}
.appstore-badge:hover{transform:translateY(-2px);box-shadow:0 12px 26px -10px rgba(0,0,0,0.55);}
.asb-apple{width:22px;height:22px;color:#fff;flex-shrink:0;}
.asb-txt{display:flex;flex-direction:column;line-height:1;text-align:left;}
.asb-txt small{font-size:9px;letter-spacing:0.02em;opacity:0.92;margin-bottom:2px;}
.asb-txt strong{font-size:17px;font-weight:600;letter-spacing:-0.01em;}
.hero-stats{max-width:820px;margin:48px auto 0;display:flex;justify-content:center;flex-wrap:wrap;gap:24px 56px;border-top:0.5px solid var(--border);padding-top:28px;}
.hero-stat{text-align:center;}
.hero-stat-num{font-size:28px;font-weight:700;letter-spacing:-0.5px;line-height:1;}
.hero-stat-label{font-size:12px;color:var(--text-muted);margin-top:6px;font-weight:500;}

/* Trust */
.trust-row{max-width:1000px;margin:0 auto;padding:32px 5%;display:flex;justify-content:center;flex-wrap:wrap;gap:10px 14px;}
.trust-badge{display:inline-flex;align-items:center;gap:6px;background:white;border:0.5px solid var(--border);padding:7px 14px;border-radius:18px;font-size:12px;color:var(--text-muted);font-weight:500;transition:all 200ms;}
.trust-badge:hover{border-color:var(--purple-border);transform:translateY(-1px);color:var(--text);}
.trust-badge svg{width:12px;height:12px;color:var(--purple);}

/* Phones */
.phones-wrap{position:relative;padding:16px 2% 36px;overflow-x:clip;}
.phones-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:640px;height:480px;background:radial-gradient(ellipse,rgba(175,169,236,0.35),transparent 70%);pointer-events:none;z-index:0;animation:glow 6s ease-in-out infinite;}
@keyframes glow{0%,100%{opacity:0.5;transform:translate(-50%,-50%) scale(1);}50%{opacity:0.85;transform:translate(-50%,-50%) scale(1.08);}}
.phones{position:relative;z-index:1;display:flex;gap:12px;justify-content:center;align-items:flex-start;}
.phone-wrap{display:flex;flex-direction:column;align-items:center;gap:10px;}
.phone-label{font-family:var(--mono);font-size:10px;letter-spacing:0.2em;color:var(--text-faint);text-transform:uppercase;}
.phone{width:220px;height:416px;background:#1a1825;border-radius:40px;padding:8px;border:6px solid #2c2a3a;box-shadow:0 36px 80px -28px rgba(38,33,92,0.45),0 0 0 1px rgba(175,169,236,0.18);position:relative;animation:float 7s ease-in-out infinite;transition:transform 600ms cubic-bezier(.2,.8,.2,1);}
.phone-wrap:nth-child(1) .phone{animation-delay:-2s;}
.phone-wrap:nth-child(3) .phone{animation-delay:-4.2s;}
.phone-wrap:hover .phone{transform:translateY(-14px) scale(1.02);animation-play-state:paused;}
@keyframes float{0%,100%{transform:translateY(0);}50%{transform:translateY(-12px);}}
.phone-screen{width:100%;height:100%;background:white;border-radius:32px;overflow:hidden;position:relative;}
.phone-shot{width:100%;height:100%;object-fit:cover;object-position:top center;display:block;}
.banner-shot{flex:1 1 0;min-width:0;max-width:420px;border-radius:24px;overflow:hidden;background:#f8f8ff;box-shadow:0 30px 70px -30px rgba(38,33,92,0.42),0 0 0 1px rgba(175,169,236,0.12);display:block;animation:float 7s ease-in-out infinite;transition:transform 600ms cubic-bezier(.2,.8,.2,1);}
.banner-shot img{display:block;width:100%;height:auto;}
.banner-shot:nth-child(1){animation-delay:-2s;}
.banner-shot:nth-child(3){animation-delay:-4.2s;}
.banner-shot:hover{transform:translateY(-12px) scale(1.02);animation-play-state:paused;}
@media(max-width:560px){.phones{flex-direction:column;align-items:center;}.banner-shot{flex:0 0 auto;width:clamp(240px,72%,300px);max-width:300px;}}
.ph-statusbar{position:absolute;top:0;left:0;right:0;padding:6px 16px 2px;display:flex;justify-content:space-between;align-items:center;font-size:9px;font-weight:600;z-index:3;}
.ph-statusbar.dark{color:white;}

/* phone1 — pregnancy */
.ph-preg{background:#f9f9f9;padding:30px 12px 12px;height:100%;display:flex;flex-direction:column;gap:10px;}
.ph-preg-header{display:flex;align-items:center;gap:9px;}
.ph-week-circle{width:42px;height:42px;background:var(--purple);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:white;flex-shrink:0;}
.ph-week-num{font-size:16px;font-weight:700;line-height:1;}
.ph-week-lbl{font-size:6px;opacity:0.85;text-transform:uppercase;letter-spacing:0.5px;margin-top:1px;}
.ph-preg-title{font-size:11px;font-weight:600;line-height:1.2;}
.ph-trimester{display:inline-block;margin-top:3px;padding:1px 7px;border-radius:5px;background:rgba(76,175,80,0.15);font-size:7px;font-weight:600;color:#2e7d32;}
.ph-fruit-card{background:white;border-radius:12px;padding:12px;display:flex;align-items:center;gap:12px;}
.ph-fruit-emoji{font-size:32px;line-height:1;}
.ph-fruit-text{font-size:11px;font-weight:500;}
.ph-fruit-size{font-size:8px;color:var(--text-faint);margin-top:2px;}
.ph-tip{background:var(--purple-light);border-radius:9px;padding:8px 10px;}
.ph-tip-label{font-size:7px;font-weight:700;color:var(--purple-mid);letter-spacing:0.5px;}
.ph-tip-text{font-size:8px;color:var(--purple-deep);margin-top:2px;line-height:1.45;}
.ph-preg-text{font-size:8px;color:var(--text-muted);line-height:1.5;}
.ph-preg-footer{margin-top:auto;padding-top:10px;border-top:0.5px solid var(--border);display:flex;justify-content:space-between;align-items:center;}
.ph-days-num{font-size:14px;font-weight:700;color:var(--purple);line-height:1;}
.ph-days-lbl{font-size:7px;color:var(--text-faint);margin-top:2px;}
.ph-due{text-align:right;}
.ph-due-lbl{font-size:7px;color:var(--text-faint);}
.ph-due-date{font-size:9px;font-weight:600;}

/* phone2 — dashboard */
.ph-dash{background:white;padding:30px 12px 12px;height:100%;display:flex;flex-direction:column;gap:10px;}
.ph-child-row{display:flex;align-items:center;gap:8px;}
.ph-child-ava{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,#F5C4B3,#e89480);display:grid;place-items:center;color:#7a2410;font-weight:700;font-size:11px;flex-shrink:0;}
.ph-child-name{font-size:11px;font-weight:700;}
.ph-child-stats{font-size:8px;color:var(--text-faint);margin-top:1px;}
.ph-switch{font-size:8px;color:var(--purple);font-weight:600;}
.ph-capsule-card{background:var(--purple-light);border:1px solid var(--purple-border);border-radius:14px;padding:12px;}
.ph-capsule-label{display:flex;align-items:center;gap:5px;font-size:8px;font-weight:700;color:var(--purple-mid);letter-spacing:0.4px;text-transform:uppercase;margin-bottom:5px;}
.ph-capsule-days{display:flex;align-items:baseline;gap:5px;}
.ph-capsule-num{font-size:28px;font-weight:700;color:var(--purple-mid);letter-spacing:-0.5px;line-height:1;font-family:var(--serif);}
.ph-capsule-unit{font-size:11px;color:var(--purple-mid);font-weight:600;}
.ph-capsule-bar{margin-top:8px;height:4px;background:rgba(127,119,221,0.2);border-radius:2px;overflow:hidden;}
.ph-capsule-bar-fill{width:28%;height:100%;background:var(--purple);border-radius:2px;}
.ph-capsule-meta{display:flex;justify-content:space-between;margin-top:5px;font-size:8px;color:var(--purple-mid);}
.ph-mem-section{display:flex;flex-direction:column;gap:6px;}
.ph-mem-head{display:flex;justify-content:space-between;align-items:center;}
.ph-mem-title{font-size:8px;font-weight:700;color:var(--text-faint);text-transform:uppercase;letter-spacing:0.4px;}
.ph-mem-link{font-size:8px;color:var(--purple);font-weight:600;}
.ph-mem-card{background:var(--bg-warm);border:0.5px solid var(--border);border-radius:11px;overflow:hidden;}
.ph-mem-img{height:70px;position:relative;}
.ph-mem-img.spring{background:linear-gradient(135deg,#F5C4B3 0%,#e89480 100%);}
.ph-mem-img.spring::after{content:'🌸';position:absolute;inset:0;display:grid;place-items:center;font-size:28px;opacity:0.85;}
.ph-mem-meta{padding:7px 10px;}
.ph-mem-date{font-size:7px;color:var(--text-faint);}
.ph-mem-text{font-size:9px;line-height:1.3;margin-top:2px;}
.ph-prompt{margin-top:auto;background:linear-gradient(135deg,var(--purple-light),#ddd8fb);border-radius:10px;padding:8px 10px;display:flex;align-items:center;gap:8px;}
.ph-prompt-icon{width:22px;height:22px;border-radius:50%;background:var(--purple);display:grid;place-items:center;color:white;flex-shrink:0;}
.ph-prompt-title{font-size:8px;color:var(--purple-mid);font-weight:600;}
.ph-prompt-cta{font-size:7px;color:var(--purple);margin-top:2px;}

/* phone3 — opening */
.ph-open{height:100%;display:flex;flex-direction:column;}
.ph-open-header{background:linear-gradient(160deg,var(--purple-deep) 0%,var(--purple-mid) 100%);padding:30px 14px 16px;color:white;}
.ph-open-eyebrow{font-size:8px;color:var(--purple-border);text-transform:uppercase;letter-spacing:0.6px;margin-bottom:4px;}
.ph-open-title{font-size:14px;font-weight:700;font-family:var(--serif);letter-spacing:-0.3px;margin-bottom:6px;}
.ph-open-stats{display:flex;gap:10px;font-size:8px;color:var(--purple-border);}
.ph-open-body{padding:12px;flex:1;}
.ph-letter{background:linear-gradient(135deg,var(--purple-light),#ddd8fb);border-radius:10px;padding:10px 11px;margin-bottom:10px;border-left:3px solid var(--purple);}
.ph-letter-label{display:flex;align-items:center;gap:4px;font-size:8px;font-weight:700;color:var(--purple-mid);margin-bottom:4px;}
.ph-letter-text{font-size:8px;color:var(--purple-deep);font-style:italic;font-family:var(--serif);line-height:1.5;}
.ph-photo-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px;}
.ph-photo{aspect-ratio:1;border-radius:7px;display:grid;place-items:center;font-size:22px;}
.ph-photo.p1{background:linear-gradient(135deg,#F5C4B3,#e89480);}
.ph-photo.p2{background:linear-gradient(135deg,#9FE1CB,#5fbf99);}
.ph-photo.p3{background:linear-gradient(135deg,#B5D4F4,#7faae3);}
.ph-photo.p4{background:linear-gradient(135deg,#FAC775,#e09c3a);}

/* Section frame */
.section{padding:90px 5%;position:relative;}
.section.warm{background:var(--bg-warm);}
.section.tint{background:var(--purple-tint);}
.section-label{font-size:11px;font-weight:600;color:var(--purple);letter-spacing:2.5px;text-transform:uppercase;text-align:center;margin-bottom:12px;}
.section-title{font-size:clamp(28px,4.2vw,44px);font-weight:700;letter-spacing:-0.025em;text-align:center;margin:0 auto 10px;max-width:720px;}
.section-title .em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--purple);}
.section-sub{font-size:16px;color:var(--text-muted);text-align:center;max-width:540px;margin:0 auto 56px;}

/* Loss aversion */
.loss{padding:100px 5%;text-align:center;background:var(--bg-warm);position:relative;}
.loss-quote{font-size:clamp(30px,4.8vw,52px);font-weight:400;font-family:var(--serif);line-height:1.2;letter-spacing:-0.025em;max-width:820px;margin:0 auto 24px;}
.loss-quote .em{font-style:italic;color:var(--purple);}
.loss-body{font-size:17px;color:var(--text-muted);line-height:1.7;max-width:580px;margin:0 auto;}

/* Features */
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;max-width:1080px;margin:0 auto;}
.feature-card{background:white;border:0.5px solid var(--border);border-radius:var(--radius-lg);padding:28px;transition:all 320ms cubic-bezier(.2,.8,.2,1);position:relative;overflow:hidden;}
.feature-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,transparent 0%,rgba(127,119,221,0.04) 100%);opacity:0;transition:opacity 320ms;}
.feature-card:hover{border-color:var(--purple-border);transform:translateY(-4px);box-shadow:var(--shadow-soft);}
.feature-card:hover::before{opacity:1;}
.feature-card>*{position:relative;z-index:1;}
.feature-icon{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;margin-bottom:16px;transition:transform 320ms cubic-bezier(.34,1.56,.64,1);}
.feature-card:hover .feature-icon{transform:scale(1.1) rotate(-6deg);}
.feature-icon.purple{background:var(--purple-light);color:var(--purple);}
.feature-icon.green{background:var(--green-light);color:var(--green);}
.feature-icon.coral{background:var(--coral-light);color:var(--coral);}
.feature-icon.olive{background:var(--olive-light);color:var(--olive);}
.feature-icon.amber{background:var(--amber-light);color:var(--amber);}
.feature-icon svg{width:22px;height:22px;}
.feature-title{font-size:17px;font-weight:600;margin-bottom:8px;}
.feature-desc{font-size:14px;color:var(--text-muted);line-height:1.6;}

/* How — letter timeline */

.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;max-width:1000px;margin:0 auto;position:relative;}
.steps::before{content:'';position:absolute;top:48px;left:9%;right:9%;height:2px;background:repeating-linear-gradient(90deg,var(--purple-border) 0 6px,transparent 6px 14px);z-index:0;}
.step{text-align:left;padding:24px;background:white;border-radius:var(--radius-lg);border:0.5px solid var(--border);transition:all 320ms;position:relative;z-index:1;}
.step:hover{border-color:var(--purple-border);transform:translateY(-3px);box-shadow:var(--shadow-soft);}
.step:hover .step-icon{transform:scale(1.08) rotate(-4deg);}
.step-icon{width:48px;height:48px;background:var(--purple-light);border-radius:13px;display:grid;place-items:center;font-size:24px;margin-bottom:12px;transition:transform 320ms cubic-bezier(.2,.8,.2,1);box-shadow:0 6px 18px -10px rgba(127,119,221,0.5);}
.step-kicker{font-family:var(--mono);font-size:10px;letter-spacing:0.15em;color:var(--purple-mid);font-weight:600;margin-bottom:6px;}
.step-title{font-size:15px;font-weight:600;margin-bottom:8px;}
.step-desc{font-size:13px;color:var(--text-muted);line-height:1.6;}

/* Pricing */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(8px,1.4vw,14px);max-width:1000px;margin:0 auto;}
@media(max-width:680px){.pricing-grid{grid-template-columns:1fr;max-width:460px;}}
.pricing-card{background:white;border:0.5px solid var(--border);border-radius:var(--radius-lg);padding:clamp(18px,2.4vw,28px) clamp(16px,2vw,24px);position:relative;display:flex;flex-direction:column;transition:all 320ms cubic-bezier(.2,.8,.2,1);}
.pricing-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft);border-color:var(--purple-border);}
.pricing-card.featured{border:2px solid var(--purple);background:linear-gradient(180deg,white,var(--purple-tint));}
.pricing-card .badge{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:var(--purple);color:white;font-family:var(--mono);font-size:10px;font-weight:600;padding:4px 12px;border-radius:999px;letter-spacing:0.1em;white-space:nowrap;}
.plan-name{font-family:var(--mono);font-size:11px;font-weight:600;color:var(--text-faint);letter-spacing:0.15em;margin-bottom:8px;}
.plan-price{display:flex;align-items:baseline;gap:2px;font-weight:700;color:var(--text);letter-spacing:-1px;line-height:1;min-height:44px;}
.plan-price .cur{font-size:22px;font-weight:600;}
.plan-price .num{font-size:40px;font-family:var(--serif);font-weight:500;}
.plan-price .free{font-size:36px;font-family:var(--serif);font-weight:500;}
.plan-price .per{font-size:13px;font-weight:400;color:var(--text-faint);margin-left:6px;letter-spacing:0;}
.plan-yearly{display:inline-flex;align-items:center;gap:6px;margin-top:6px;font-size:12px;color:var(--text-muted);}
.plan-yearly strong{color:var(--text);font-weight:600;}
.plan-yearly .save{background:var(--green-light);color:var(--green);font-size:10px;font-weight:700;padding:2px 7px;border-radius:6px;letter-spacing:0.05em;}
.plan-sub{font-size:12px;color:var(--text-faint);margin:6px 0 0;min-height:18px;}
.plan-divider{height:0.5px;background:var(--border);margin:18px 0;}
.plan-row{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-muted);margin-bottom:10px;}
.plan-row strong{color:var(--text);font-weight:500;}
.chk{width:18px;height:18px;border-radius:50%;background:var(--purple-light);color:var(--purple);display:grid;place-items:center;flex-shrink:0;}
.chk svg{width:10px;height:10px;}
.crs{width:18px;height:18px;border-radius:50%;background:#f3f1ec;color:#b4b2a9;display:grid;place-items:center;flex-shrink:0;}
.plan-row.disabled{color:#b4b2a9;}
.plan-btn{display:block;text-align:center;padding:12px;border-radius:10px;font-size:13px;font-weight:500;margin-top:auto;width:100%;cursor:pointer;transition:all 220ms;border:none;text-decoration:none;}
.plan-btn-spacer{margin-top:20px;}
.plan-disclosure{font-size:11px;line-height:1.5;color:var(--text-faint);margin-top:10px;text-align:center;}
.plan-btn.primary{background:var(--purple);color:white;}
.plan-btn.primary:hover{background:var(--purple-mid);transform:translateY(-1px);}
.plan-btn.soft{background:var(--purple-light);color:var(--purple-mid);}
.plan-btn.soft:hover{background:var(--purple-border);color:white;}
.plan-btn.outline{background:white;color:var(--purple-mid);border:1px solid var(--purple-border);}
.plan-btn.outline:hover{background:var(--purple-light);}

/* FAQ */
.faq-list{max-width:800px;margin:0 auto;}
.faq-item{background:white;border:0.5px solid var(--border);border-radius:14px;margin-bottom:10px;overflow:hidden;transition:all 220ms;cursor:pointer;}
.faq-item:hover{border-color:var(--purple-border);}
.faq-item.open{border-color:var(--purple);box-shadow:0 8px 20px -10px rgba(127,119,221,0.25);}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:24px;padding:20px 24px;font-size:16px;font-weight:500;}
.faq-q .plus{width:30px;height:30px;border-radius:50%;background:var(--purple-light);color:var(--purple);display:grid;place-items:center;font-size:18px;flex-shrink:0;transition:all 320ms cubic-bezier(.2,.8,.2,1);}
.faq-item.open .plus{background:var(--purple);color:white;transform:rotate(45deg);}
.faq-a{max-height:0;overflow:hidden;font-size:14px;color:var(--text-muted);line-height:1.7;transition:max-height 380ms ease,padding 380ms ease,opacity 280ms ease;opacity:0;padding:0 24px;}
.faq-item.open .faq-a{max-height:300px;padding:0 24px 22px;opacity:1;}

/* Final CTA */
.final-cta{padding:100px 5%;text-align:center;background:linear-gradient(170deg,var(--purple) 0%,var(--purple-mid) 100%);color:white;position:relative;overflow:hidden;}
.final-cta::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 600px 300px at 30% 0%,rgba(255,255,255,0.15),transparent 70%),radial-gradient(ellipse 500px 400px at 80% 100%,rgba(38,33,92,0.4),transparent 70%);pointer-events:none;}
.final-cta-inner{position:relative;z-index:2;}
.final-cta h2{font-size:clamp(36px,5vw,56px);font-family:var(--serif);font-weight:400;letter-spacing:-0.025em;margin-bottom:16px;line-height:1.1;max-width:760px;margin-left:auto;margin-right:auto;}
.final-cta p{font-size:17px;color:rgba(255,255,255,0.85);max-width:440px;margin:0 auto 32px;}
.final-cta .btn-primary{background:white;color:var(--purple-mid);padding:16px 32px;font-size:15px;font-weight:600;}
.final-cta .btn-primary:hover{background:var(--purple-deep);color:white;}
.final-cta .note{font-size:12px;color:rgba(255,255,255,0.6);margin-top:16px;}

/* Footer */
.footer{padding:40px 5%;border-top:0.5px solid var(--border);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;text-align:center;}
.footer-left{display:flex;align-items:center;gap:14px;}
.footer-tag{font-size:13px;color:var(--text-faint);}
.footer-links{display:flex;gap:22px;justify-content:center;flex-wrap:wrap;}
.footer-links a{font-size:13px;color:var(--text-faint);transition:color 200ms;}
.footer-links a:hover{color:var(--text);}
.footer-badges{display:flex;gap:14px;justify-content:center;align-items:center;flex-wrap:wrap;}
.footer-badges img{height:48px;width:auto;border-radius:6px;display:block;opacity:0.95;transition:opacity 200ms;}
.footer-badges a:hover img{opacity:1;}
.footer-copy{font-size:12px;color:var(--text-faint);}

/* Responsive */
@media (max-width:980px){
  .features-grid{grid-template-columns:repeat(2,1fr);}
  .steps{grid-template-columns:repeat(2,1fr);}
  .steps::before{display:none;}
  .nav-links{display:none;}
}
@media (max-width:640px){
  .features-grid{grid-template-columns:1fr;}
  .steps{grid-template-columns:1fr;}
  .phones{gap:24px;}
  .phone{width:200px;height:377px;}
  .section{padding:70px 5%;}
  .hero{padding:60px 5% 30px;}
  .hero-stats{gap:20px 32px;}
  .nav-signin{display:none;}
}

/* ===== Capsule scene — emotional showcase (letter + seal + memories) ===== */
.capsule-scene{position:relative;padding:96px 5% 104px;background:var(--bg-warm);overflow:hidden;}
.scene-head{text-align:center;max-width:580px;margin:0 auto 64px;}
.scene-head h2{font-size:clamp(28px,4vw,42px);}
.scene-head .em{font-family:var(--hand);font-style:normal;font-weight:700;color:var(--purple);font-size:1.1em;}
.scene-head p{color:var(--text-muted);margin-top:14px;font-size:17px;line-height:1.6;}
.scene-stage{position:relative;max-width:720px;margin:0 auto;display:flex;justify-content:center;}

/* Letter card */
.letter-card{position:relative;z-index:2;width:min(440px,86vw);background:linear-gradient(170deg,#FCFBF7,#F6F2E9);border-radius:7px;padding:44px 42px 34px;box-shadow:0 34px 80px -30px rgba(38,33,92,0.34),0 2px 0 rgba(0,0,0,0.03);transform:rotate(-1.4deg);border:1px solid rgba(0,0,0,0.045);}
.letter-card::before{content:'';position:absolute;inset:0;border-radius:7px;pointer-events:none;background-image:radial-gradient(rgba(70,60,30,0.05) 1px,transparent 1.4px);background-size:5px 5px;opacity:0.55;}
.letter-greeting{font-family:var(--hand);font-size:38px;font-weight:700;color:var(--purple-deep);line-height:1;}
.letter-for{font-family:var(--hand);font-size:19px;color:var(--text-muted);margin-top:2px;}
.letter-body{font-family:var(--serif);font-style:italic;font-size:15.5px;color:#4b4842;line-height:1.85;margin-top:22px;position:relative;}
.letter-sign{font-family:var(--hand);font-size:23px;color:var(--purple-mid);margin-top:18px;text-align:right;line-height:1;}
.letter-date{font-family:var(--mono);font-size:11px;color:var(--text-faint);text-align:right;margin-top:8px;letter-spacing:0.08em;}

/* Wax seal */
.wax-seal{position:absolute;right:-20px;bottom:-22px;z-index:3;width:82px;height:82px;border-radius:50%;background:radial-gradient(circle at 36% 30%,#9C92F0,#6A5FD0 55%,#473CAB);box-shadow:0 12px 24px -8px rgba(74,63,176,0.6),inset 0 2px 6px rgba(255,255,255,0.25),inset 0 -5px 9px rgba(0,0,0,0.28);display:grid;place-items:center;transform:rotate(9deg);}
.wax-seal span{font-family:var(--serif);font-weight:600;font-size:27px;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,0.3);}
.wax-seal::before{content:'';position:absolute;inset:7px;border-radius:50%;border:1.5px dashed rgba(255,255,255,0.5);}

/* Floating memory items */
.scene-item{position:absolute;z-index:4;background:#fff;box-shadow:0 20px 44px -20px rgba(38,33,92,0.4);}
.polaroid{padding:9px 9px 0;border-radius:3px;width:138px;}
.polaroid .ph{width:100%;height:120px;border-radius:2px;overflow:hidden;display:grid;place-items:center;font-size:34px;}
.polaroid .ph img{width:100%;height:100%;object-fit:cover;display:block;}
.polaroid .ph.a{background:linear-gradient(135deg,#FBE7D2,#F4C9A8);}
.polaroid .ph.b{background:linear-gradient(135deg,#D6E8F7,#AFCDEC);}
.polaroid .cap{font-family:var(--hand);font-size:17px;color:var(--text-muted);text-align:center;padding:7px 2px 11px;line-height:1;}
.scene-item.p1{top:-30px;left:-6px;transform:rotate(-7deg);}
.scene-item.p2{bottom:6px;left:-44px;transform:rotate(5deg);}

/* Voice note chip */
.voice-chip{display:flex;align-items:center;gap:11px;border-radius:15px;padding:12px 16px;top:46px;right:-34px;transform:rotate(4deg);}
.vplay{width:30px;height:30px;border-radius:50%;background:var(--purple);display:grid;place-items:center;color:#fff;font-size:11px;flex-shrink:0;}
.voice-wave{display:flex;align-items:flex-end;gap:3px;height:26px;}
.voice-wave i{width:3px;border-radius:2px;background:var(--purple-border);animation:vwave 1.3s ease-in-out infinite;}
@keyframes vwave{0%,100%{height:6px}50%{height:22px}}
.voice-time{font-family:var(--mono);font-size:11px;color:var(--text-faint);}

/* Sticky note */
.sticky-note{bottom:-20px;right:6px;background:#FFF1B8;padding:15px 17px;border-radius:2px;transform:rotate(-4deg);font-family:var(--hand);font-size:19px;color:#7A5A00;box-shadow:0 16px 32px -16px rgba(120,90,0,0.35);}

@media (max-width:760px){
  .scene-stage{flex-direction:column;align-items:center;}
  .scene-item{position:static;transform:rotate(-2deg);margin:16px auto 0;}
  .letter-card{transform:none;}
  .wax-seal{right:12px;bottom:-24px;}
}

/* Scene entrance choreography — only when JS adds .anim (so no-JS / reduced-motion
   users see everything in final state). Items fly in, then the seal stamps down. */
.scene-stage.anim .letter-card{opacity:0;transform:translateY(34px) rotate(-1.4deg);}
.scene-stage.anim .scene-item.p1{opacity:0;transform:translateX(-72px) rotate(-15deg);}
.scene-stage.anim .scene-item.p2{opacity:0;transform:translateX(-84px) rotate(-3deg);}
.scene-stage.anim .voice-chip{opacity:0;transform:translateX(72px) rotate(13deg);}
.scene-stage.anim .sticky-note{opacity:0;transform:translateX(60px) translateY(22px) rotate(7deg);}
.scene-stage.anim .wax-seal{opacity:0;transform:scale(2.3) rotate(40deg);}
.scene-stage.anim.played .letter-card,
.scene-stage.anim.played .scene-item.p1,
.scene-stage.anim.played .scene-item.p2,
.scene-stage.anim.played .voice-chip,
.scene-stage.anim.played .sticky-note{transition:opacity .55s ease,transform .7s cubic-bezier(.2,.8,.2,1);}
.scene-stage.anim.played .letter-card{opacity:1;transform:rotate(-1.4deg);transition-delay:.05s;}
.scene-stage.anim.played .scene-item.p1{opacity:1;transform:rotate(-7deg);transition-delay:.38s;}
.scene-stage.anim.played .scene-item.p2{opacity:1;transform:rotate(5deg);transition-delay:.52s;}
.scene-stage.anim.played .voice-chip{opacity:1;transform:rotate(4deg);transition-delay:.62s;}
.scene-stage.anim.played .sticky-note{opacity:1;transform:rotate(-4deg);transition-delay:.72s;}
.scene-stage.anim.sealed .wax-seal{opacity:1;transform:rotate(9deg);transition:opacity .3s ease,transform .55s cubic-bezier(.2,1.5,.45,1);}

/* Letter typewriter caret */
.letter-greeting.typing::after,.letter-for.typing::after,.letter-body.typing::after{content:'';display:inline-block;width:2px;height:0.9em;background:currentColor;margin-left:2px;vertical-align:-1px;animation:caret .7s steps(1) infinite;}
@keyframes caret{50%{opacity:0;}}

@media (prefers-reduced-motion: reduce){
  .scene-stage.anim .letter-card,.scene-stage.anim .scene-item,.scene-stage.anim .wax-seal{opacity:1!important;transform:none!important;}
}
