/* =========================================================
   Yarna · early.yarna.app — validation landing
   Single goal: read → trust → pay €19.
   Brand: saffron #E8B339 · warm charcoal #1C1714 · cream #FAF7F2
   ========================================================= */

:root{
  --saffron:    #E8B339;
  --saffron-2:  #C99224;
  --saffron-3:  #F0CC6F;
  --saffron-9:  #6B4E14;

  --char-1: #1C1714;
  --char-2: #241E19;
  --char-3: #332B23;
  --char-4: #4A3F33;
  --char-9: #0F0B08;

  --cream-1: #FAF7F2;
  --cream-2: #F6F1E8;
  --cream-3: #EDE6D8;
  --sand:    #D9D0BD;
  --stone:   #8A8276;
  --stone-2: #5A5246;
  --ink:     #231D17;

  --ok:   #5C8A66;
  --err:  #C45642;

  --serif: "Fraunces", "Cormorant Garamond", Georgia, serif;
  --sans:  "Inter", system-ui, "Helvetica Neue", Arial, sans-serif;
  --mono:  "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --maxw: 1080px;
  --narrow: 720px;
  --pad: 20px;

  --shadow-sm: 0 1px 2px rgba(15,11,8,.06), 0 2px 8px rgba(15,11,8,.05);
  --shadow-md: 0 10px 30px -10px rgba(15,11,8,.16);
  --shadow-lg: 0 34px 80px -30px rgba(15,11,8,.4);
  --shadow-phone: 0 50px 90px -30px rgba(15,11,8,.52), 0 0 0 1.5px rgba(255,255,255,.04) inset;
}

*{box-sizing:border-box; margin:0; padding:0}
html{scroll-behavior:smooth; -webkit-text-size-adjust:100%}
body{
  font-family:var(--sans); background:var(--cream-1); color:var(--ink);
  font-size:17px; line-height:1.6; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{display:block; max-width:100%}
a{color:inherit; text-decoration:none}
button{font-family:inherit; cursor:pointer; border:none; background:none}
::selection{background:var(--saffron-3); color:var(--ink)}

.container{max-width:var(--maxw); margin:0 auto; padding:0 var(--pad); width:100%}
.narrow{max-width:var(--narrow); margin-left:auto; margin-right:auto}
.section{padding:64px 0}
@media(min-width:760px){ .section{padding:88px 0} }

/* ---------- type ---------- */
h1,h2,h3{font-family:var(--serif); font-weight:400; line-height:1.08; letter-spacing:-.02em; color:var(--ink)}
.eyebrow{
  font-family:var(--mono); font-size:11px; font-weight:500; letter-spacing:.16em;
  text-transform:uppercase; color:var(--saffron-2); display:inline-flex; align-items:center; gap:10px;
}
.eyebrow::before{content:""; width:22px; height:1.5px; background:var(--saffron)}
.eyebrow.solo::before{display:none}
.h1{font-size:clamp(33px, 6.4vw, 54px); font-weight:400; line-height:1.05; letter-spacing:-.025em}
.h1 em{font-style:italic; color:var(--saffron-2)}
.h2{font-size:clamp(27px, 4.8vw, 40px); line-height:1.08; letter-spacing:-.02em}
.h2 em{font-style:italic; color:var(--saffron-2)}
.lede{font-size:clamp(18px, 2.4vw, 21px); line-height:1.55; color:var(--stone-2)}
.muted{color:var(--stone)}
.serif{font-family:var(--serif)}

.dark{background:var(--char-1); color:var(--cream-2)}
.dark h1,.dark h2,.dark h3{color:var(--cream-1)}
.dark .lede{color:rgba(246,241,232,.72)}
.dark .muted{color:rgba(246,241,232,.5)}
.dark .h1 em,.dark .h2 em{color:var(--saffron)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--sans); font-weight:600; font-size:17px; line-height:1;
  padding:18px 30px; border-radius:999px; transition:transform .14s ease, background .14s, box-shadow .14s;
  white-space:nowrap; text-align:center;
}
.btn-primary{background:var(--saffron); color:var(--char-1); box-shadow:0 6px 22px -6px rgba(232,179,57,.6)}
.btn-primary:hover{background:var(--saffron-3); transform:translateY(-2px); box-shadow:0 12px 30px -8px rgba(232,179,57,.7)}
.btn-primary:active{transform:translateY(0)}
.btn-lg{font-size:18px; padding:20px 36px}
.btn .arrow{transition:transform .16s}
.btn:hover .arrow{transform:translateX(3px)}
.btn-block{display:flex; width:100%}

.cta-group{display:flex; flex-direction:column; align-items:flex-start; gap:12px}
.cta-group.center{align-items:center; text-align:center}
.cta-sub{font-size:14px; color:var(--stone); line-height:1.5; max-width:420px}
.dark .cta-sub{color:rgba(246,241,232,.55)}
.cta-sub strong{color:inherit; font-weight:600}

/* ---------- header ---------- */
.site-header{position:sticky; top:0; z-index:100; background:rgba(250,247,242,.85); backdrop-filter:blur(14px) saturate(1.1); border-bottom:1px solid transparent; transition:border-color .2s}
.site-header.scrolled{border-bottom-color:var(--cream-3)}
.header-inner{display:flex; align-items:center; height:62px; gap:14px}
.logo{display:flex; align-items:center; gap:9px; font-family:var(--serif); font-size:23px; letter-spacing:-.02em; color:var(--ink)}
.logo svg{width:23px; height:23px; color:var(--saffron-2); flex-shrink:0}
.logo-text{display:flex; flex-direction:column; line-height:1}
.logo-tagline{font-family:var(--sans); font-size:10.5px; font-weight:500; letter-spacing:.01em; color:var(--stone); margin-top:2px; white-space:nowrap}
@media(max-width:430px){ .logo-tagline{display:none} }
.header-spacer{flex:1}
.header-cta{display:none}
@media(min-width:560px){ .header-cta{display:inline-flex; padding:11px 20px; font-size:15px} }

/* language switch — simple 2-way pill */
.lang-toggle{display:inline-flex; background:var(--cream-2); border-radius:999px; padding:3px; box-shadow:inset 0 0 0 1px var(--cream-3)}
.lang-toggle button{
  font-family:var(--mono); font-size:12px; font-weight:500; letter-spacing:.04em; text-transform:uppercase;
  padding:7px 12px; border-radius:999px; color:var(--stone); transition:color .14s, background .14s;
}
.lang-toggle button.active{background:var(--char-1); color:var(--cream-1)}

/* ---------- hero ---------- */
.hero{position:relative; overflow:hidden; padding-top:36px; padding-bottom:56px}
.hero-thread{position:absolute; inset:0; pointer-events:none; opacity:.55; z-index:0}
.hero-inner{position:relative; z-index:1; display:grid; grid-template-columns:1fr; gap:40px; align-items:center}
@media(min-width:900px){
  .hero{padding-top:56px; padding-bottom:80px}
  .hero-inner{grid-template-columns:1.08fr .92fr; gap:52px}
}
.hero-badge{
  display:inline-flex; align-items:center; gap:9px; padding:7px 14px 7px 10px; margin-bottom:22px;
  background:rgba(232,179,57,.12); border:1px solid rgba(232,179,57,.3); border-radius:999px;
  font-size:13px; font-weight:500; color:var(--saffron-9);
}
.hero-badge .dot{width:7px; height:7px; border-radius:50%; background:var(--saffron); box-shadow:0 0 0 0 rgba(232,179,57,.5); animation:livepulse 2.4s ease-out infinite}
@keyframes livepulse{0%{box-shadow:0 0 0 0 rgba(232,179,57,.5)}70%{box-shadow:0 0 0 8px rgba(232,179,57,0)}100%{box-shadow:0 0 0 0 rgba(232,179,57,0)}}
.hero h1{margin-bottom:20px}
.hero .lede{max-width:520px; margin-bottom:30px}
.hero .cta-group{margin-bottom:0}

.hero-reassure{margin-top:26px; display:flex; flex-direction:column; gap:9px}
.hero-reassure .item{display:flex; align-items:flex-start; gap:10px; font-size:14.5px; color:var(--stone-2)}
.hero-reassure svg{width:18px; height:18px; color:var(--ok); flex-shrink:0; margin-top:1px}

/* ---------- phone mockup (shared with video stand-in) ---------- */
.phone-stage{display:flex; justify-content:center; position:relative}
.phone-glow{position:absolute; width:80%; height:72%; top:12%; left:10%; background:radial-gradient(ellipse at center, rgba(232,179,57,.24), transparent 68%); filter:blur(36px); z-index:0}
.phone{
  position:relative; z-index:1; width:286px; height:588px; border-radius:46px; padding:13px;
  background:linear-gradient(165deg,#2c2419,#171210); box-shadow:var(--shadow-phone); flex-shrink:0;
}
.phone-screen{position:relative; width:100%; height:100%; border-radius:34px; overflow:hidden; background:var(--char-1)}
.phone-notch{position:absolute; top:12px; left:50%; transform:translateX(-50%); width:104px; height:28px; background:#0a0807; border-radius:16px; z-index:30}
.phone-status{position:absolute; top:16px; left:0; right:0; display:flex; justify-content:space-between; padding:0 26px; z-index:25; color:#fff; font-size:12px; font-weight:600}
.phone-status .s-r{font-size:10px; letter-spacing:.02em}

.app-top{display:flex; align-items:center; justify-content:space-between; margin-bottom:16px}
.app-top .a-title{font-family:var(--serif); font-size:19px; color:var(--cream-1)}
.app-top .a-av{width:30px; height:30px; border-radius:50%; background:var(--char-3); display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:600; color:var(--saffron-3); font-family:var(--mono)}

.scene{position:absolute; left:18px; right:18px; top:54px; bottom:18px; opacity:0; transition:opacity .5s ease; pointer-events:none}
.scene.active{opacity:1}

/* scene 1: record */
.rec-wrap{height:100%; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:24px; padding-top:30px}
.rec-hint{font-size:13px; color:rgba(246,241,232,.6); text-align:center; max-width:200px; line-height:1.45}
.rec-btn{width:100px; height:100px; border-radius:50%; background:var(--saffron); display:flex; align-items:center; justify-content:center; position:relative}
.rec-btn svg{width:40px; height:40px; color:var(--char-1)}
.scene.active .rec-btn{animation:recpulse 2s ease-out infinite}
@keyframes recpulse{0%{box-shadow:0 0 0 0 rgba(232,179,57,.4)}70%{box-shadow:0 0 0 24px rgba(232,179,57,0)}100%{box-shadow:0 0 0 0 rgba(232,179,57,0)}}

/* scene 2: transcribe */
.wave-wrap{height:100%; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:26px; padding-top:30px}
.wave{display:flex; align-items:center; gap:4px; height:62px}
.wave span{width:4px; border-radius:3px; background:var(--saffron); height:16px}
.scene.active .wave span{animation:wavebar 1s ease-in-out infinite}
@keyframes wavebar{0%,100%{height:11px; opacity:.5}50%{height:50px; opacity:1}}
.quote-snip{font-family:var(--serif); font-style:italic; font-size:15px; line-height:1.45; color:rgba(246,241,232,.85); text-align:center; max-width:215px}

/* scene 3: card */
.cardview{height:100%; display:flex; flex-direction:column; gap:10px}
.cv-head{display:flex; align-items:center; gap:11px; padding-bottom:3px}
.cv-av{width:42px; height:42px; border-radius:50%; background:linear-gradient(150deg,var(--saffron),var(--saffron-2)); display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-size:18px; color:var(--char-1); flex-shrink:0}
.cv-name{font-family:var(--serif); font-size:17px; color:var(--cream-1); line-height:1.1}
.cv-sub{font-size:10.5px; color:rgba(246,241,232,.5); font-family:var(--mono); letter-spacing:.02em; margin-top:2px}
.cv-row{background:var(--char-2); border:1px solid var(--char-3); border-radius:12px; padding:10px 13px; opacity:0; transform:translateY(8px)}
.scene.active .cv-row{animation:cvin .5s ease forwards}
.scene.active .cv-row:nth-child(2){animation-delay:.12s}
.scene.active .cv-row:nth-child(3){animation-delay:.34s}
.scene.active .cv-row:nth-child(4){animation-delay:.56s}
.scene.active .cv-row:nth-child(5){animation-delay:.78s}
@keyframes cvin{to{opacity:1; transform:translateY(0)}}
.cv-row .cv-label{font-family:var(--mono); font-size:9px; letter-spacing:.1em; text-transform:uppercase; color:var(--saffron-3); display:block; margin-bottom:3px}
.cv-row .cv-val{font-size:13px; color:var(--cream-2); line-height:1.35}
.cv-row.reminder{border-color:rgba(232,179,57,.32); background:rgba(232,179,57,.08)}
.cv-row.reminder .cv-val{display:flex; align-items:center; gap:7px}
.cv-row.reminder svg{width:14px; height:14px; color:var(--saffron); flex-shrink:0}

/* scene 4: list */
.listview{height:100%; display:flex; flex-direction:column; gap:9px; padding-top:2px}
.lv-title{font-family:var(--serif); font-size:15px; color:var(--cream-1); margin-bottom:4px}
.lv-row{display:flex; align-items:center; gap:11px; background:var(--char-2); border:1px solid var(--char-3); border-radius:12px; padding:10px 12px; opacity:0; transform:translateX(10px)}
.scene.active .lv-row{animation:lvin .45s ease forwards}
.scene.active .lv-row:nth-child(3){animation-delay:.1s}
.scene.active .lv-row:nth-child(4){animation-delay:.2s}
.scene.active .lv-row:nth-child(5){animation-delay:.3s}
@keyframes lvin{to{opacity:1; transform:translateX(0)}}
.lv-av{width:34px; height:34px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-size:15px; color:var(--char-1); flex-shrink:0}
.lv-meta{flex:1; min-width:0}
.lv-n{font-size:13px; color:var(--cream-1); font-weight:500}
.lv-d{font-size:11px; color:rgba(246,241,232,.5); font-family:var(--mono); margin-top:1px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}

.scene-dots{position:absolute; bottom:14px; left:50%; transform:translateX(-50%); display:flex; gap:6px; z-index:20}
.scene-dots i{width:6px; height:6px; border-radius:50%; background:rgba(246,241,232,.25); transition:background .3s, width .3s}
.scene-dots i.on{background:var(--saffron); width:18px; border-radius:3px}

/* ---------- video section ---------- */
.video-wrap{max-width:320px; margin:36px auto 0; position:relative}
.video-frame{
  position:relative; border-radius:24px; overflow:hidden; background:var(--char-1);
  box-shadow:var(--shadow-lg); aspect-ratio: 9/19.5; display:flex; align-items:center; justify-content:center;
}
.video-container {
    display: flex;
    justify-content: center;
    gap: 30px;
    flex-wrap: wrap;
    margin-top: 40px;
}
.video-frame video{width:100%; height:100%; object-fit:cover; display:block}
/* stand-in (no video yet): centered phone + soft thread bg */
.video-standin{position:absolute; inset:0; display:flex; align-items:center; justify-content:center; overflow:hidden; background:radial-gradient(ellipse at 50% 40%, #2a2218, var(--char-1) 70%)}
.video-standin .vs-thread{position:absolute; inset:0; opacity:.5}
.video-standin .phone{width:212px; height:436px; border-radius:36px; padding:10px}
.video-standin .phone-screen{border-radius:26px}
.video-standin .scene{top:42px; left:14px; right:14px; bottom:14px}
.video-standin .app-top{margin-bottom:12px}
.video-standin .rec-btn{width:78px; height:78px}
.video-standin .rec-btn svg{width:32px; height:32px}
.video-standin .cv-av{width:36px; height:36px; font-size:16px}
.video-standin .phone-notch{width:80px; height:22px; top:9px}
.video-standin .phone-status{display:none}
.video-badge{
  position:absolute; top:16px; left:16px; z-index:5; display:inline-flex; align-items:center; gap:8px;
  padding:8px 14px; background:rgba(15,11,8,.5); backdrop-filter:blur(8px); border-radius:999px;
  font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--cream-1);
}
.video-badge .rec-dot{width:8px; height:8px; border-radius:50%; background:var(--err); animation:livepulse 1.8s ease-out infinite}
.video-caption{text-align:center; margin-top:18px; font-size:14px; color:var(--stone)}

/* ---------- pain ---------- */
.pain-grid{display:grid; grid-template-columns:1fr; gap:18px; margin-top:42px}
@media(min-width:760px){ .pain-grid{grid-template-columns:repeat(3,1fr)} }
.pain-card{background:#fff; border:1px solid var(--cream-3); border-radius:20px; padding:28px 26px; box-shadow:var(--shadow-sm)}
.pain-ic{width:50px; height:50px; border-radius:14px; background:var(--cream-2); display:flex; align-items:center; justify-content:center; margin-bottom:18px}
.pain-ic svg{width:26px; height:26px; color:var(--saffron-2)}
.pain-card h3{font-size:20px; font-weight:500; margin-bottom:9px; letter-spacing:-.01em}
.pain-card p{font-size:15.5px; color:var(--stone-2); line-height:1.55}

/* ---------- how it works ---------- */
.steps{display:flex; flex-direction:column; gap:20px; margin-top:44px}
@media(min-width:820px){ .steps{display:grid; grid-template-columns:repeat(3,1fr); gap:22px} }
.step{position:relative; background:var(--char-2); border:1px solid var(--char-3); border-radius:22px; padding:28px 26px 30px; overflow:hidden}
.step-num{font-family:var(--serif); font-size:46px; font-weight:400; color:var(--saffron); line-height:1; margin-bottom:18px; display:block}
.step h3{color:var(--cream-1); font-size:21px; font-weight:500; margin-bottom:9px; letter-spacing:-.01em}
.step p{color:rgba(246,241,232,.68); font-size:15px; line-height:1.55}
.step .step-thread{position:absolute; right:-30px; top:-30px; width:120px; height:120px; opacity:.15; color:var(--saffron)}

/* ---------- offer ---------- */
.offer-card{
  max-width:600px; margin:44px auto 0; background:var(--cream-1); border-radius:28px; overflow:hidden;
  box-shadow:var(--shadow-lg); border:1px solid var(--cream-3);
}
.offer-head{background:linear-gradient(160deg,#241e19,#1c1714); color:var(--cream-1); padding:34px 34px 30px; position:relative; overflow:hidden}
.offer-head .oh-thread{position:absolute; inset:0; opacity:.4; pointer-events:none}
.offer-spots{display:inline-flex; align-items:center; gap:8px; font-family:var(--mono); font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--saffron); margin-bottom:18px; position:relative}
.offer-math{display:flex; align-items:baseline; gap:14px; flex-wrap:wrap; position:relative}
.offer-price{font-family:var(--serif); font-size:60px; font-weight:400; letter-spacing:-.03em; line-height:1; color:var(--cream-1)}
.offer-price .cur{font-size:38px}
.offer-eq{font-size:15px; color:rgba(246,241,232,.7); line-height:1.4}
.offer-eq strong{color:var(--saffron-3); font-weight:600}
.offer-body{padding:30px 34px 34px}
.offer-list{list-style:none; display:flex; flex-direction:column; gap:16px; margin-bottom:26px}
.offer-list li{display:flex; gap:13px; align-items:flex-start}
.offer-list .oi-ic{width:26px; height:26px; border-radius:8px; background:rgba(232,179,57,.14); display:flex; align-items:center; justify-content:center; flex-shrink:0; margin-top:1px}
.offer-list .oi-ic svg{width:15px; height:15px; color:var(--saffron-2)}
.offer-list .oi-t{font-size:16px; line-height:1.45}
.offer-list .oi-t strong{font-weight:600; color:var(--ink)}
.offer-list .oi-t span{color:var(--stone-2)}
.offer-how{background:var(--cream-2); border-radius:16px; padding:18px 20px; margin-bottom:24px; font-size:15px; line-height:1.55; color:var(--stone-2)}
.offer-how strong{color:var(--ink); font-weight:600}
.offer-cta-note{margin-top:14px; display:flex; align-items:center; justify-content:center; gap:8px; font-size:13.5px; color:var(--stone)}
.offer-cta-note svg{width:15px; height:15px; color:var(--stone)}

.guarantee{display:flex; gap:14px; align-items:flex-start; max-width:560px; margin:28px auto 0; padding:20px 22px; background:rgba(92,138,102,.08); border:1px solid rgba(92,138,102,.28); border-radius:16px}
.guarantee .g-ic{width:40px; height:40px; border-radius:11px; background:rgba(92,138,102,.16); display:flex; align-items:center; justify-content:center; flex-shrink:0}
.guarantee .g-ic svg{width:22px; height:22px; color:var(--ok)}
.guarantee h3{font-size:17px; font-weight:600; font-family:var(--sans); margin-bottom:4px; color:var(--ink)}
.guarantee p{font-size:14.5px; color:var(--stone-2); line-height:1.5}

/* ---------- about ---------- */
.about{position:relative; overflow:hidden}
.about-inner{display:grid; grid-template-columns:1fr; gap:34px; align-items:center}
@media(min-width:820px){ .about-inner{grid-template-columns:.62fr 1.38fr; gap:48px} }
.about-portrait{position:relative; max-width:196px; margin:0 auto}
.about-portrait .frame{aspect-ratio:4/5; border-radius:24px; overflow:hidden; background:linear-gradient(160deg,var(--cream-2),var(--sand)); position:relative; box-shadow:var(--shadow-md); display:flex; align-items:flex-end; justify-content:center}
.about-portrait .frame img{width:100%; height:100%; object-fit:cover; display:block}
.about-portrait .initial{font-family:var(--serif); font-size:150px; color:var(--saffron-2); opacity:.32; line-height:.8; margin-bottom:-10px}
.about-portrait .badge{position:absolute; bottom:-14px; left:50%; transform:translateX(-50%); white-space:nowrap; background:var(--char-1); color:var(--cream-1); padding:7px 15px; border-radius:999px; font-size:12px; font-weight:500; box-shadow:var(--shadow-md)}
.about-portrait .badge .accent{color:var(--saffron)}
.about-photo-slot{position:absolute; inset:0}
.about-text p{font-size:17.5px; line-height:1.65; color:var(--stone-2); margin-bottom:18px}
.about-text p strong{color:var(--ink); font-weight:600}
.about-text .sig{font-family:var(--serif); font-style:italic; font-size:22px; color:var(--saffron-2); margin-top:6px}

/* ---------- faq ---------- */
.faq{max-width:var(--narrow); margin:38px auto 0}
.faq-item{border-bottom:1px solid var(--cream-3)}
.faq-q{width:100%; display:flex; align-items:center; justify-content:space-between; gap:16px; padding:22px 4px; text-align:left; font-family:var(--serif); font-size:19px; font-weight:500; color:var(--ink); letter-spacing:-.01em}
.faq-q .faq-icon{flex-shrink:0; width:22px; height:22px; position:relative}
.faq-q .faq-icon::before,.faq-q .faq-icon::after{content:""; position:absolute; background:var(--saffron-2); border-radius:2px; top:50%; left:50%; transform:translate(-50%,-50%)}
.faq-q .faq-icon::before{width:14px; height:2px}
.faq-q .faq-icon::after{width:2px; height:14px; transition:transform .25s}
.faq-item.open .faq-icon::after{transform:translate(-50%,-50%) scaleY(0)}
.faq-a{max-height:0; overflow:hidden; transition:max-height .3s ease}
.faq-a-inner{padding:0 4px 22px; font-size:16px; color:var(--stone-2); line-height:1.6}

/* ---------- final cta ---------- */
.final{text-align:center; position:relative; overflow:hidden}
.final .container{position:relative; z-index:1}
.final-thread{position:absolute; inset:0; opacity:.4; pointer-events:none}
.final .h2{max-width:600px; margin:16px auto 0}
.final .cta-group{margin-top:30px}

/* ---------- footer ---------- */
.site-footer{background:var(--char-9); color:rgba(246,241,232,.55); padding:44px 0 32px}
.footer-inner{display:flex; flex-direction:column; gap:20px; align-items:center; text-align:center}
.footer-inner .logo{color:var(--cream-1)}
.footer-links{display:flex; gap:20px; flex-wrap:wrap; justify-content:center; font-size:14px}
.footer-links a{color:rgba(246,241,232,.65)}
.footer-links a:hover{color:var(--saffron)}
.footer-copy{font-size:13px; color:rgba(246,241,232,.4)}

/* ---------- sticky mobile CTA ---------- */
.sticky-cta{
  position:fixed; left:0; right:0; bottom:0; z-index:90; padding:12px var(--pad) calc(12px + env(safe-area-inset-bottom));
  background:rgba(250,247,242,.92); backdrop-filter:blur(14px); border-top:1px solid var(--cream-3);
  transform:translateY(120%); transition:transform .3s cubic-bezier(.3,.7,.3,1);
}
.sticky-cta.show{transform:translateY(0)}
.sticky-cta .btn{width:100%}
@media(min-width:760px){ .sticky-cta{display:none} }

/* ---------- helpers ---------- */
.reveal{opacity:0; transform:translateY(22px); transition:opacity .6s ease, transform .6s ease}
.reveal.in{opacity:1; transform:translateY(0)}
@media (prefers-reduced-motion: reduce){
  *{animation:none !important; transition:none !important}
  .reveal{opacity:1; transform:none}
  .scene{transition:none}
  .lp-field,.cv-row,.lv-row,.lp-item,.wave span,.lp-wave span{opacity:1 !important; transform:none !important}
}
[hidden]{display:none !important}

/* =========================================================
   HERO PHONE — LIGHT THEME (matches real app screenshots)
   Scoped to #hero-phone so the video block stays untouched.
   ========================================================= */
#hero-phone .phone{background:linear-gradient(165deg,#3a3128,#211a14)}
#hero-phone .phone-screen{background:var(--cream-1)}
#hero-phone .phone-status{color:var(--ink)}
#hero-phone .phone-status .s-r{color:var(--ink)}
#hero-phone .app-top .a-title{color:var(--ink)}
#hero-phone .app-top .a-av{background:var(--cream-3); color:var(--saffron-2)}
#hero-phone .scene{top:52px}

/* scene 1 · idle record */
.lp-rec{height:100%; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:22px; padding-bottom:8px}
.lp-mic-ring{padding:9px; border-radius:50%; border:2px solid rgba(232,179,57,.45)}
.lp-mic{width:92px; height:92px; border-radius:50%; background:var(--saffron); display:flex; align-items:center; justify-content:center}
.lp-mic svg{width:38px; height:38px; color:var(--char-1)}
.scene.active .lp-mic{animation:recpulse 2s ease-out infinite}
.lp-rec-txt{text-align:center}
.lp-rec-txt .t{font-size:16px; font-weight:600; color:var(--ink)}
.lp-rec-txt .s{font-size:12.5px; color:var(--stone); margin-top:4px; max-width:170px; line-height:1.4}
.lp-paste{margin-top:6px; padding:11px 26px; border-radius:999px; border:1.5px solid var(--saffron-2); color:var(--saffron-2); font-size:13.5px; font-weight:600}

/* scene 2 · recording */
.lp-recording{height:100%; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:14px}
.lp-rec-name{display:inline-flex; align-items:center; gap:6px; color:var(--saffron-2); font-weight:600; font-size:14px}
.lp-rec-name svg{width:14px; height:14px}
.lp-timer{font-family:var(--serif); font-size:52px; font-weight:400; letter-spacing:-.02em; color:var(--ink); line-height:1}
.lp-wave{display:flex; align-items:center; gap:3.5px; height:56px; margin:4px 0}
.lp-wave span{width:4px; border-radius:3px; background:var(--saffron); height:14px}
.scene.active .lp-wave span{animation:wavebar 1s ease-in-out infinite}
.lp-stop{margin-top:6px; width:58px; height:58px; border-radius:50%; background:var(--char-1); display:flex; align-items:center; justify-content:center}
.lp-stop i{width:18px; height:18px; border-radius:5px; background:var(--err); display:block}
.lp-stop-txt{font-size:12.5px; color:var(--stone)}

/* scene 3 · card confirmation */
.lp-card{height:100%; display:flex; flex-direction:column; gap:9px; overflow:hidden}
.lp-card-h{font-family:var(--serif); font-size:17px; font-weight:500; color:var(--ink); margin-bottom:2px}
.lp-field{opacity:0; transform:translateY(8px)}
.scene.active .lp-field{animation:cvin .5s ease forwards}
.scene.active .lp-field:nth-child(3){animation-delay:.14s}
.scene.active .lp-field:nth-child(4){animation-delay:.32s}
.scene.active .lp-field:nth-child(5){animation-delay:.5s}
.scene.active .lp-field:nth-child(6){animation-delay:.68s}
.lp-label{font-family:var(--mono); font-size:8.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--stone); display:block; margin-bottom:4px}
.lp-box{background:#fff; border:1px solid var(--cream-3); border-radius:10px; padding:9px 11px; font-size:13px; color:var(--ink); line-height:1.35}
.lp-inline{display:flex; gap:18px}
.lp-inline .lp-field{flex:1}
.lp-val{font-size:13.5px; color:var(--ink)}
.lp-field.reminder .lp-box{border-color:rgba(232,179,57,.4); background:rgba(232,179,57,.1); display:flex; align-items:center; gap:7px; color:var(--saffron-9); font-weight:500}
.lp-field.reminder svg{width:14px; height:14px; color:var(--saffron-2); flex-shrink:0}

/* scene 4 · contacts */
.lp-list{height:100%; display:flex; flex-direction:column; gap:8px}
.lp-list-h{font-family:var(--serif); font-size:18px; font-weight:500; color:var(--ink); margin-bottom:2px}
.lp-item{display:flex; align-items:center; gap:11px; padding:9px 4px; border-bottom:1px solid var(--cream-3); opacity:0; transform:translateX(10px)}
.scene.active .lp-item{animation:lvin .45s ease forwards}
.scene.active .lp-item:nth-child(3){animation-delay:.1s}
.scene.active .lp-item:nth-child(4){animation-delay:.2s}
.scene.active .lp-item:nth-child(5){animation-delay:.3s}
.lp-iav{width:38px; height:38px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-size:16px; color:#fff; flex-shrink:0}
.lp-imeta{flex:1; min-width:0}
.lp-in{font-size:14px; color:var(--ink); font-weight:600}
.lp-ir{font-size:12px; color:var(--stone); margin-top:1px}
.lp-badge{font-size:10.5px; font-weight:600; padding:4px 10px; border-radius:999px; white-space:nowrap}
.lp-badge.work{background:rgba(232,179,57,.18); color:var(--saffron-9)}
.lp-badge.new{background:rgba(91,122,154,.16); color:#42627f}

/* =========================================================
   WEB-VERSION PLAQUE (after the 3 steps)
   ========================================================= */
.web-plaque{
  margin-top:22px; display:flex; align-items:flex-start; gap:14px;
  background:var(--cream-2); border:1px solid var(--cream-3); border-radius:18px;
  padding:20px 22px;
}
.dark .web-plaque{background:rgba(246,241,232,.06); border-color:var(--char-3)}
.web-plaque .wp-ic{width:42px; height:42px; border-radius:11px; background:rgba(232,179,57,.14); display:flex; align-items:center; justify-content:center; flex-shrink:0}
.web-plaque .wp-ic svg{width:22px; height:22px; color:var(--saffron-2)}
.web-plaque .wp-text{font-size:15.5px; line-height:1.5; color:var(--stone-2)}
.dark .web-plaque .wp-text{color:rgba(246,241,232,.7)}
.web-plaque .wp-accent{display:inline-flex; align-items:center; gap:7px; margin-top:7px; font-weight:600; color:var(--ink)}
.dark .web-plaque .wp-accent{color:var(--cream-1)}
.web-plaque .wp-accent::before{content:""; width:7px; height:7px; border-radius:50%; background:var(--saffron); flex-shrink:0}

/* =========================================================
   PLATFORM CHOICE MODAL (iPhone / Android before checkout)
   ========================================================= */
.platform-backdrop{position:fixed; inset:0; background:rgba(15,11,8,.55); backdrop-filter:blur(3px); opacity:0; visibility:hidden; transition:opacity .22s, visibility .22s; z-index:200}
.platform-backdrop.open{opacity:1; visibility:visible}
.platform-modal{
  position:fixed; left:50%; bottom:0; transform:translate(-50%, 110%); pointer-events:none;
  width:100%; max-width:440px; z-index:210;
  background:var(--cream-1); border-radius:24px 24px 0 0; padding:30px 26px calc(30px + env(safe-area-inset-bottom));
  box-shadow:var(--shadow-lg); transition:transform .3s cubic-bezier(.3,.7,.3,1);
}
.platform-modal.open{transform:translate(-50%, 0); pointer-events:auto;}
@media(min-width:560px){
  .platform-modal{bottom:auto; top:50%; border-radius:24px; transform:translate(-50%,-46%) scale(.97); opacity:0; transition:opacity .2s, transform .2s}
  .platform-modal.open{transform:translate(-50%,-50%) scale(1); opacity:1}
}
.platform-modal .pm-close{position:absolute; top:16px; right:16px; width:36px; height:36px; border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--stone); background:var(--cream-2)}
.platform-modal .pm-close svg{width:18px; height:18px}
.platform-modal h3{font-family:var(--serif); font-size:25px; font-weight:500; letter-spacing:-.01em; color:var(--ink); margin-bottom:6px; padding-right:30px}
.platform-modal .pm-sub{font-size:14px; color:var(--stone); margin-bottom:22px}
.pm-choice{display:flex; flex-direction:column; gap:12px}
.pm-opt{display:flex; align-items:center; gap:14px; width:100%; text-align:left; padding:16px 18px; border-radius:16px; transition:transform .14s, box-shadow .14s, background .14s}
.pm-opt .pm-ic{width:30px; height:30px; flex-shrink:0; display:flex; align-items:center; justify-content:center}
.pm-opt .pm-ic svg{width:26px; height:26px}
.pm-opt.ios{background:var(--saffron); color:var(--char-1)}
.pm-opt.ios:hover{transform:translateY(-2px); box-shadow:0 10px 26px -8px rgba(232,179,57,.6)}
.pm-opt.ios .pm-t{font-weight:600; font-size:16px}
.pm-opt.android{background:var(--cream-2); color:var(--ink); box-shadow:inset 0 0 0 1.5px var(--cream-3); align-items:flex-start}
.pm-opt.android:hover{box-shadow:inset 0 0 0 1.5px var(--sand)}
.pm-opt.android .pm-ic{color:var(--stone-2); margin-top:2px}
.pm-opt.android .pm-t{font-weight:600; font-size:16px; margin-bottom:3px}
.pm-opt.android .pm-note{font-size:12.5px; color:var(--stone); line-height:1.45; font-weight:400}
