/* ============================================================
   PLEYRA - light, serif-led, premium consumer (Novu language)
   PHOTOS: every <img class="bg"> / <img class="photo"> is a swap slot.
           Replace src="data:..." with src="your-photo.jpg". Done.
   ============================================================ */
:root{
  --bg:#ffffff; --bg-2:#f6f5f2;
  --ink:#16161b; --ink-soft:#56565e; --ink-mute:#8c8c94;
  --line:rgba(20,20,25,.09); --line-2:rgba(20,20,25,.16);
  --obpro:#0fb1a3; --gynstat:#c34d72; --mensy:#9f4a93; --stellaxe:#3fd9f5; --star:#f7821f;
  --blue-1:#23527e; --blue-2:#3f78a8; --blue-3:#5f9bcb;
  --r:28px; --maxw:1140px; --ease:cubic-bezier(.22,1,.36,1);
  --sans:"Poppins",-apple-system,system-ui,sans-serif;
  --serif:"Poppins",-apple-system,system-ui,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:rgba(63,120,168,.22)}
.serif{font-family:var(--serif);font-weight:600;line-height:1.06;letter-spacing:-.02em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}
.eyebrow{font-size:.74rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-mute);display:inline-flex;align-items:center;gap:.6em}
.eyebrow::before{display:none}

.apple{display:inline-flex;align-items:center;gap:9px;border-radius:100px;font-weight:600;transition:transform .3s var(--ease),box-shadow .3s,background .3s}
.apple svg{width:17px;height:17px;flex:none}
.apple--light{background:#fff;color:#111;padding:13px 26px;box-shadow:0 10px 30px -10px rgba(0,0,0,.4)}
.apple--light:hover{transform:translateY(-2px);box-shadow:0 16px 36px -12px rgba(0,0,0,.5)}
.apple--dark{background:#111;color:#fff;padding:11px 22px}
.apple--dark:hover{transform:translateY(-2px)}
.apple .two{display:flex;flex-direction:column;align-items:flex-start;line-height:1.05}
.apple .two small{font-size:.62rem;opacity:.7;font-weight:500}
.apple .two b{font-size:.92rem;font-weight:700}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:110;padding:20px 0}
.nav-in{max-width:1280px;margin:0 auto;padding:0 26px;display:flex;align-items:center;justify-content:space-between}
.logo{font-family:var(--serif);font-weight:600;font-size:1.55rem;letter-spacing:-.02em;color:#fff;transition:color .35s var(--ease)}
.logo .d{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--stellaxe);margin-left:3px;vertical-align:.12em;box-shadow:0 0 12px var(--stellaxe)}
nav.scrolled .logo{color:var(--ink)}
.logo .logoimg{height:36px;width:auto;display:block}
nav.scrolled .logoimg{filter:invert(1)}
.pill{display:flex;align-items:center;gap:6px;padding:6px 6px 6px 8px;border-radius:100px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);transition:background .35s,border-color .35s,box-shadow .35s}
nav.scrolled .pill{background:rgba(255,255,255,.82);border-color:rgba(20,20,25,.07);box-shadow:0 8px 30px -12px rgba(0,0,0,.18)}
.pill a.lnk{font-size:.92rem;font-weight:500;color:#fff;padding:8px 16px;border-radius:100px;transition:color .35s,background .25s}
.pill a.lnk:hover{background:rgba(255,255,255,.12)}
nav.scrolled .pill a.lnk{color:var(--ink-soft)}
nav.scrolled .pill a.lnk:hover{color:var(--ink);background:rgba(20,20,25,.05)}
.spacer{width:108px}
.navtoggle{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:46px;height:46px;background:rgba(12,22,38,.30);border:1px solid rgba(255,255,255,.18);border-radius:14px;-webkit-backdrop-filter:blur(14px) saturate(140%);backdrop-filter:blur(14px) saturate(140%);cursor:pointer;padding:0;transition:background .35s,border-color .35s,box-shadow .35s}
nav.scrolled .navtoggle{background:rgba(255,255,255,.85);border-color:rgba(20,20,25,.08);box-shadow:0 8px 30px -12px rgba(0,0,0,.18)}
body.nav-open .navtoggle{background:rgba(20,20,25,.06);border-color:rgba(20,20,25,.1)}
.navtoggle span{display:block;height:2px;width:22px;background:#fff;border-radius:2px;transition:transform .3s var(--ease),opacity .2s,background .3s}
nav.scrolled .navtoggle span{background:var(--ink)}
body.nav-open .navtoggle span{background:var(--ink)}
body.nav-open .navtoggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.nav-open .navtoggle span:nth-child(2){opacity:0}
body.nav-open .navtoggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
/* MOBILE NAV - refined overlay, atmospheric bloom + staggered reveal */
.mnav{position:fixed;inset:0;z-index:105;background:var(--bg);display:flex;flex-direction:column;padding:calc(env(safe-area-inset-top,0px) + 90px) clamp(26px,7vw,40px) calc(env(safe-area-inset-bottom,0px) + 32px);opacity:0;visibility:hidden;overflow:hidden;transition:opacity .42s var(--ease),visibility .42s var(--ease)}
.mnav::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background:radial-gradient(130% 90% at 100% -8%,rgba(15,177,163,.12),transparent 58%),radial-gradient(95% 75% at -10% 110%,rgba(35,82,126,.08),transparent 60%);opacity:0;transform:scale(1.08);transition:opacity .7s var(--ease),transform .9s var(--ease)}
.mnav::after{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.04;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='nm'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23nm)'/%3E%3C/svg%3E")}
body.nav-open .mnav{opacity:1;visibility:visible}
body.nav-open .mnav::before{opacity:1;transform:none}
.mnav-inner{position:relative;z-index:1;display:flex;flex-direction:column;height:100%}
.mnav-eyebrow{font-size:.72rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-mute);opacity:0;transform:translateY(12px);transition:opacity .5s var(--ease),transform .5s var(--ease)}
body.nav-open .mnav-eyebrow{opacity:1;transform:none;transition-delay:.1s}
.mnav-links{flex:1;display:flex;flex-direction:column;justify-content:center;gap:2px;margin:8px 0}
.mlnk{display:flex;align-items:baseline;gap:clamp(14px,4vw,20px);font-family:var(--serif);font-weight:600;font-size:clamp(2rem,10vw,2.9rem);letter-spacing:-.025em;line-height:1.16;color:var(--ink);padding:9px 0;opacity:0;transform:translateY(26px);transition:opacity .55s var(--ease),transform .55s var(--ease),color .25s}
.mlnk .mnum{font-family:ui-monospace,"SFMono-Regular",Menlo,monospace;font-size:.74rem;font-weight:600;letter-spacing:.05em;color:var(--ink-mute);flex:none;width:1.7em;transition:color .25s,transform .35s var(--ease)}
.mlnk:active{color:var(--obpro)}
@media(hover:hover){.mlnk:hover{color:var(--obpro)}.mlnk:hover .mnum{color:var(--obpro);transform:translateX(3px)}}
body.nav-open .mlnk{opacity:1;transform:none}
body.nav-open .mlnk:nth-child(1){transition-delay:.16s}
body.nav-open .mlnk:nth-child(2){transition-delay:.22s}
body.nav-open .mlnk:nth-child(3){transition-delay:.28s}
body.nav-open .mlnk:nth-child(4){transition-delay:.34s}
.mnav-foot{display:flex;flex-direction:column;gap:18px;opacity:0;transform:translateY(16px);transition:opacity .55s var(--ease),transform .55s var(--ease)}
body.nav-open .mnav-foot{opacity:1;transform:none;transition-delay:.42s}
.mnav-foot .divider{height:1px;width:100%;background:linear-gradient(90deg,var(--line),transparent)}
.mnav .mcta{align-self:flex-start;font-size:1.02rem;padding:14px 26px}
.mnav-meta{display:flex;align-items:center;justify-content:space-between;font-size:.78rem;color:var(--ink-mute)}
.mnav-meta .dot{display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--obpro);box-shadow:0 0 10px var(--obpro);margin-right:8px;vertical-align:1px}
body.nav-open{overflow:hidden}
body.nav-open .logoimg{filter:invert(1)}

/* HERO (photo-ready: swap .photo src) */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;padding:120px 0 90px;border-bottom-left-radius:clamp(34px,5vw,66px);border-bottom-right-radius:clamp(34px,5vw,66px)}
.hero .photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero .scrim{position:absolute;inset:0;z-index:1;background:radial-gradient(75% 65% at 50% 52%,rgba(6,20,38,.5),transparent 78%),linear-gradient(180deg,rgba(8,28,48,.5),rgba(12,38,60,.22) 45%,rgba(10,30,52,.55))}
.hero .grain{position:absolute;inset:0;z-index:1;opacity:.05;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.hero-c{position:relative;z-index:2;max-width:980px;padding:0 26px;color:#fff}
.hero h1{font-size:clamp(2.7rem,7.4vw,5.6rem);font-weight:700;letter-spacing:-.03em;line-height:1.04}
.hero h1 .em{font-style:italic;font-weight:500}
.hero p{font-size:clamp(1.05rem,1.8vw,1.32rem);color:rgba(255,255,255,.9);max-width:46ch;margin:26px auto 0;line-height:1.5}
.hero .cta{margin-top:40px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.scrolldown{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:2;color:rgba(255,255,255,.6);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:10px}
.scrolldown .bar{width:1px;height:42px;background:linear-gradient(rgba(255,255,255,.6),transparent);animation:drop 2.2s var(--ease) infinite}
@keyframes drop{0%{transform:scaleY(0);transform-origin:top}40%{transform:scaleY(1);transform-origin:top}60%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

.rl{opacity:0;transform:translateY(24px);animation:rise .9s var(--ease) forwards}
@keyframes rise{to{opacity:1;transform:none}}
.d1{animation-delay:.1s}.d2{animation-delay:.24s}.d3{animation-delay:.4s}

section{position:relative}
.reveal{opacity:0;transform:translateY(32px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* APPS / carousel - matches the 3 card archetypes from the reference */
.apps{padding:118px 0 110px}
.apps-head{max-width:var(--maxw);margin:0 auto 44px;padding:0 26px;display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap}
.apps-head h2{font-size:clamp(2.1rem,5vw,3.7rem)}
.apps-head p{color:var(--ink-soft);max-width:36ch}
.scroller{overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:8px 0 14px}
.scroller::-webkit-scrollbar{display:none}
.track{display:flex;gap:22px;padding:0 max(26px,calc((100vw - var(--maxw))/2 + 26px));width:max-content}

.card{scroll-snap-align:start;width:478px;max-width:90vw;border-radius:var(--r);overflow:hidden;position:relative;height:680px;display:flex;flex-direction:column;box-shadow:0 14px 44px -28px rgba(0,0,0,.2);transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.card:hover{transform:translateY(-6px);box-shadow:0 34px 64px -28px rgba(0,0,0,.3)}
.card .pad{padding:32px 30px 0;display:flex;flex-direction:column;gap:13px;position:relative;z-index:3}
.card .ptag{font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase}
.card h3{font-family:var(--serif);font-optical-sizing:auto;font-size:clamp(1.6rem,2.6vw,2.05rem);font-weight:600;letter-spacing:-.02em;line-height:1.03}
.card .pp{font-size:.98rem;line-height:1.5}
.card .acts{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;padding:18px 30px 26px;position:relative;z-index:3;background:#fff}
.support{font-size:.9rem;font-weight:600;color:var(--ink-soft);transition:color .25s;display:inline-flex;align-items:center;gap:.3em}
.support:hover{color:var(--ink)}

/* (B) white card with app mockup - like "Structure in seconds" */
.card--light{background:#fff}
.card--light .ptag{color:var(--c)}
.card--light .pp{color:var(--ink-soft)}
.card--light .acts .apple--dark{background:var(--c)}
.card--light .support:hover{color:var(--c)}

/* (A/C) photo card with overlaid text - swap .bg src */
.card--photo{color:#fff}
.card--photo .bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.card--photo::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(8,18,32,.5),rgba(8,18,32,.12) 38%,rgba(8,18,32,.05) 60%,rgba(8,18,32,.45))}
.card--photo .ptag{color:rgba(255,255,255,.92)}
.card--photo h3{color:#fff}
.card--photo .pp{color:rgba(255,255,255,.92)}
.card--photo .support{color:rgba(255,255,255,.85)}
.card--photo .support:hover{color:#fff}
.card--photo .apple--dark{background:#fff;color:#111}

/* floating chips (like "The power of three") */
.chips-float{position:absolute;right:18px;top:46%;z-index:3;display:flex;flex-direction:column;gap:11px;align-items:flex-end}
.chips-float span{background:rgba(255,255,255,.92);color:#1a1a1f;font-size:.86rem;font-weight:600;padding:11px 16px;border-radius:13px;box-shadow:0 10px 24px -12px rgba(0,0,0,.4);display:flex;align-items:center;gap:9px}
.chips-float span::before{content:"";width:15px;height:15px;border-radius:5px;border:1.5px solid color-mix(in srgb,var(--c) 60%,#bbb)}

/* voice/mini glass pill (like the waveform pill) */
.glasspill{position:absolute;left:50%;bottom:108px;transform:translateX(-50%);z-index:3;background:rgba(255,255,255,.22);border:1px solid rgba(255,255,255,.35);backdrop-filter:blur(8px);border-radius:100px;padding:11px 22px;display:flex;align-items:flex-end;gap:3px;height:42px}
.glasspill i{width:3px;border-radius:3px;background:#fff;animation:eq 1s ease-in-out infinite}
.glasspill i:nth-child(1){height:10px;animation-delay:0s}.glasspill i:nth-child(2){height:20px;animation-delay:.1s}.glasspill i:nth-child(3){height:14px;animation-delay:.2s}.glasspill i:nth-child(4){height:24px;animation-delay:.3s}.glasspill i:nth-child(5){height:11px;animation-delay:.15s}.glasspill i:nth-child(6){height:18px;animation-delay:.25s}.glasspill i:nth-child(7){height:9px;animation-delay:.05s}
@keyframes eq{0%,100%{transform:scaleY(.5)}50%{transform:scaleY(1)}}

/* (D) dark cinematic card - STELLAXE */
.card--dark{background:radial-gradient(120% 80% at 50% 0%,#0d2733,#070b10 70%);color:#fff;border-color:rgba(63,217,245,.18)}
.card--dark .ptag{color:var(--stellaxe)}
.card--dark h3{color:#fff}
.card--dark .pp{color:rgba(255,255,255,.78)}
.card--dark .support{color:rgba(255,255,255,.78)}
.card--dark .support:hover{color:var(--stellaxe)}
.card--dark .apple--dark{background:var(--stellaxe);color:#06222b}

/* app mockup (phone) inside white card - my own UI, not a copied screenshot */
.mock{margin:20px 30px 0;flex:1;display:flex;justify-content:center;align-items:flex-end}
.stage{flex:1;position:relative;display:flex;justify-content:center;align-items:flex-end;overflow:hidden;padding:20px 26px 34px}
.stage::before{content:"";position:absolute;inset:0;z-index:0;background:radial-gradient(120% 66% at 50% 12%,color-mix(in srgb,var(--c) 11%,transparent),transparent 62%)}
.stage .glow{position:absolute;bottom:3%;left:50%;transform:translateX(-50%);width:62%;height:44%;border-radius:50%;background:var(--c);filter:blur(74px);opacity:.15;z-index:0}
/* realistic iPhone */
.phone{position:relative;z-index:2;height:99%;aspect-ratio:71/152;box-sizing:border-box;padding:2.5px;border-radius:17% / 8.2%;background:linear-gradient(143deg,#7d7e83 0%,#3a3b3f 13%,#1c1d21 34%,#1c1d21 66%,#3a3b3f 87%,#7d7e83 100%);box-shadow:0 36px 56px -22px rgba(10,14,22,.5),0 14px 24px -12px rgba(10,14,22,.42),inset 0 0 0 .5px rgba(255,255,255,.28),inset 0 0 2px rgba(255,255,255,.18)}
.phone::after{content:"";position:absolute;left:50%;bottom:-11px;transform:translateX(-50%);width:70%;height:18px;background:radial-gradient(50% 100% at 50% 0,rgba(8,11,18,.34),transparent 72%);filter:blur(8px);z-index:-1}
.phone .sbtn{position:absolute;width:2.5px;border-radius:2px 0 0 2px;background:linear-gradient(90deg,#4a4b50,#202125);z-index:1}
.phone .sbtn-act{left:-2px;top:20%;height:4.6%;border-radius:2px 0 0 2px}
.phone .sbtn-vol{left:-2px;top:29%;height:13%;border-radius:2px 0 0 2px}
.phone .sbtn-pwr{right:-2px;top:25.5%;height:11%;background:linear-gradient(270deg,#4a4b50,#202125);border-radius:0 2px 2px 0}
.iscreen{position:relative;width:100%;height:100%;border-radius:15.2% / 7.4%;background:#040406;padding:4px;box-sizing:border-box;overflow:hidden;box-shadow:inset 0 0 0 1px #000,inset 0 0 6px rgba(0,0,0,.9)}
.shot{width:100%;height:100%;object-fit:cover;display:block;border-radius:13% / 6.4%}
.dynisland{position:absolute;top:2.7%;left:50%;transform:translateX(-50%);width:30%;aspect-ratio:3.6;background:#000;border-radius:100px;z-index:5;box-shadow:0 0 0 .5px rgba(30,33,40,.7),0 1px 2px rgba(0,0,0,.5)}
.dynisland::after{content:"";position:absolute;right:8%;top:50%;transform:translateY(-50%);width:19%;aspect-ratio:1;border-radius:50%;background:radial-gradient(circle at 60% 38%,#26344a 0%,#0a0f17 60%,#05070b 100%);box-shadow:inset 0 0 1.5px rgba(90,135,180,.65)}
.screen{background:#fbfbfa;border-radius:29px;overflow:hidden;padding:14px 13px 0;height:340px;position:relative;display:flex;flex-direction:column;gap:9px}
.island{position:absolute;top:9px;left:50%;transform:translateX(-50%);width:74px;height:19px;background:#0c0c0e;border-radius:100px;z-index:4}
.sb{display:flex;justify-content:space-between;align-items:center;font-size:.6rem;font-weight:700;color:#111;padding:2px 8px 4px}
.todaycard{background:var(--c);border-radius:15px;padding:13px 14px;color:#fff;display:flex;justify-content:space-between;align-items:center}
.todaycard b{font-size:.92rem;font-weight:700}.todaycard small{font-size:.62rem;opacity:.92;display:block;margin-top:2px}
.todaycard .go{width:22px;height:22px;border-radius:50%;background:rgba(255,255,255,.28);display:grid;place-items:center;font-size:.7rem}
.trow{display:flex;align-items:center;gap:10px;padding:8px 4px;border-bottom:1px solid rgba(20,20,25,.06)}
.trow .ck{width:16px;height:16px;border-radius:5px;border:1.5px solid #cfcfcf;flex:none}
.trow .ck.on{background:var(--c);border-color:var(--c)}
.trow .tt{flex:1;font-size:.74rem;font-weight:600;color:#222}
.trow .tt span{display:block;font-size:.6rem;font-weight:500;color:#999}
.trow .ct{font-size:.56rem;font-weight:700;padding:3px 7px;border-radius:100px;background:color-mix(in srgb,var(--c) 15%,#fff);color:color-mix(in srgb,var(--c) 78%,#000)}
.tabbar{margin-top:auto;display:flex;justify-content:space-around;align-items:center;padding:10px 0 12px;border-top:1px solid rgba(20,20,25,.06)}
.tabbar i{width:30px;height:30px;border-radius:50%;background:#eee}
.tabbar i.mid{background:var(--c)}

/* HUD mock - STELLAXE */
.hud{margin:20px 30px 0;flex:1;border-radius:22px;position:relative;overflow:hidden;background:radial-gradient(120% 90% at 50% 35%,rgba(63,217,245,.14),#060a10 72%);display:grid;place-items:center;min-height:300px}
.hud .ring{position:absolute;border:1px solid rgba(63,217,245,.4);border-radius:50%}
.hud .r1{width:150px;height:150px}.hud .r2{width:220px;height:220px;border-style:dashed;opacity:.5;animation:spin 20s linear infinite}.hud .r3{width:88px;height:88px;border-color:rgba(63,217,245,.7)}
@keyframes spin{to{transform:rotate(360deg)}}
.hud .core{width:56px;height:56px;border-radius:50%;background:radial-gradient(circle,#d6f8ff,var(--stellaxe));box-shadow:0 0 42px var(--stellaxe)}
.hud .scan{position:absolute;inset:0;background:repeating-linear-gradient(transparent 0 3px,rgba(63,217,245,.05) 3px 4px)}
.hud .co{position:absolute;font-size:.6rem;letter-spacing:.14em;color:rgba(63,217,245,.85)}
.hud .co.a{bottom:16px;left:16px}.hud .co.b{top:16px;right:14px;text-align:right}

.arrows{max-width:var(--maxw);margin:30px auto 0;padding:0 26px;display:flex;gap:12px;justify-content:center}
.arrows button{width:46px;height:46px;border-radius:50%;border:1px solid var(--line-2);background:#fff;color:var(--ink);cursor:pointer;font-size:1.1rem;transition:transform .3s var(--ease),background .25s,border-color .25s}
.arrows button:hover{transform:translateY(-2px);border-color:var(--ink);background:var(--ink);color:#fff}

/* statement */
.stmt{padding:100px 0;text-align:center}
.stmt .wrap{max-width:768px}
.stmt .eyebrow{margin-bottom:20px}
.stmt .eyebrow::before{display:none}
.stmt h2{font-size:clamp(2rem,4.8vw,3.5rem);max-width:18ch;margin:0 auto}
.stmt h2 .em,.reviews h2 .em,.faq h2 .em,.foot-cta h2 .em{font-style:italic;font-weight:500}
.stmt-r{color:var(--ink-soft);font-size:clamp(1.08rem,1.6vw,1.28rem);line-height:1.55;max-width:54ch;margin:22px auto 0}

/* privacy panel */
.privacy{padding:30px clamp(16px,3vw,38px) 110px}
.panel{max-width:none;margin:0;border-radius:34px;overflow:hidden;position:relative;background:radial-gradient(90% 160% at 0% 0%,#1c2417,#0b0d09 55%);color:#fff;padding:96px clamp(40px,6vw,96px);min-height:400px;display:flex;align-items:center}
.panel .lock{position:absolute;right:6%;top:50%;transform:translateY(-50%);width:230px;height:230px;color:rgba(255,255,255,.05)}
.panel .pc{position:relative;z-index:2;max-width:540px}
.panel .eyebrow{color:rgba(255,255,255,.55)}.panel .eyebrow::before{background:rgba(255,255,255,.3)}
.panel h2{font-size:clamp(1.9rem,4vw,3rem);margin-top:18px}
.panel p{color:rgba(255,255,255,.72);margin-top:20px;max-width:44ch;font-size:1.05rem}
.panel .mini-grid{display:flex;gap:30px;margin-top:30px;flex-wrap:wrap}
.panel .mini-grid div{font-size:.92rem;color:rgba(255,255,255,.8)}
.panel .mini-grid b{display:block;font-family:var(--serif);font-size:1.5rem;font-weight:600;color:#fff}

/* reviews */
.reviews{padding:96px 0 110px;text-align:center}
.reviews h2{font-size:clamp(2.1rem,5vw,3.6rem)}
.reviews .sub{color:var(--ink-soft);margin:18px auto 50px;max-width:48ch}
.rev-marquee{overflow:hidden;padding:6px 0 12px;text-align:left;-webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.rev-track{display:flex;gap:22px;width:max-content;animation:revscroll 55s linear infinite}
.reviews:hover .rev-track{animation-play-state:paused}
@keyframes revscroll{to{transform:translateX(-50%)}}

.rcard{scroll-snap-align:start;width:408px;max-width:86vw;flex:none;background:#fff;border-radius:24px;padding:38px 38px 32px;box-shadow:0 24px 56px -32px rgba(0,0,0,.22);display:flex;flex-direction:column;min-height:336px}
.stars{color:var(--star);font-size:1.05rem;letter-spacing:3px;margin-bottom:22px}
.rcard q{font-size:1.22rem;line-height:1.5;quotes:none;color:var(--ink)}
.rcard .by{margin-top:auto;padding-top:28px;display:flex;align-items:center;gap:9px;font-size:.9rem;color:var(--ink-mute)}
.rcard .by svg{width:13px;height:13px}

/* FAQ */
.faq{padding:90px 0 120px;text-align:center}
.faq h2{font-size:clamp(2.2rem,5.4vw,3.8rem)}
.faq-list{max-width:760px;margin:40px auto 0;text-align:left}
.faq-item{border-bottom:0}
.faq-q{width:100%;background:none;border:0;cursor:pointer;font-family:var(--sans);color:var(--ink);font-size:clamp(1.02rem,1.7vw,1.2rem);font-weight:600;padding:25px 4px;display:flex;justify-content:space-between;align-items:center;gap:20px}
.faq-q .pm{flex:none;width:22px;height:22px;position:relative}
.faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;background:var(--ink-soft);border-radius:2px}
.faq-q .pm::before{width:100%;height:1.5px;top:50%;left:0;transform:translateY(-50%)}
.faq-q .pm::after{height:100%;width:1.5px;left:50%;top:0;transform:translateX(-50%);transition:transform .4s var(--ease)}
.faq-item.open .pm::after{transform:translateX(-50%) scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .5s var(--ease)}
.faq-a p{color:var(--ink-soft);padding:0 4px 26px;max-width:64ch}

/* footer CTA (photo-ready: swap .photo src) */
.foot{position:relative;overflow:hidden;color:#fff;padding:120px 0 40px;border-top-left-radius:clamp(34px,5vw,66px);border-top-right-radius:clamp(34px,5vw,66px)}
.foot .photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.foot .scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(10,30,52,.4),rgba(12,38,60,.55))}
.foot-in{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:0 26px}
.foot-cta{text-align:center;padding-bottom:90px}
.foot-cta h2{font-size:clamp(2.4rem,6vw,4.6rem);font-weight:500}
.foot-cta p{color:rgba(255,255,255,.9);font-size:1.1rem;margin:22px auto 34px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr auto;gap:36px;align-items:start;padding-top:54px}
.fbrand .logo{color:#fff;font-size:1.7rem}
.fbrand .logoimg{height:30px}
.fbrand p{color:rgba(255,255,255,.72);max-width:26ch;margin-top:14px;font-size:.94rem}
.fcol h5{font-family:var(--serif);font-weight:600;font-size:1.12rem;margin-bottom:16px}
.fcol a{display:block;color:rgba(255,255,255,.8);font-size:.95rem;padding:5px 0;transition:color .25s}
.fcol a:hover{color:#fff}
.qr{width:128px;text-align:center}.qr .code{width:128px;height:128px;background:#fff;border-radius:14px;padding:11px}
.qr small{display:block;margin-top:10px;font-size:.78rem;color:rgba(255,255,255,.8)}
.legal{display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;margin-top:42px;padding-top:8px}
.legal span,.legal a{font-size:.84rem;color:rgba(255,255,255,.7)}
.legal .lk{display:flex;gap:22px}.legal .lk a:hover{color:#fff}

.navcta{flex:none}
#studio .wrap{max-width:900px}
.studio-hl{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:52px;text-align:left}
.studio-hl .hl{background:var(--bg-2);border-radius:22px;padding:32px 28px 30px;display:flex;flex-direction:column;transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.studio-hl .hl:hover{transform:translateY(-4px);box-shadow:0 26px 54px -32px rgba(0,0,0,.22)}
.studio-hl .hl .ic{width:50px;height:50px;border-radius:15px;display:grid;place-items:center;color:var(--c);background:color-mix(in srgb,var(--c) 14%,#fff);margin-bottom:20px}
.studio-hl .hl .ic svg{width:24px;height:24px}
.studio-hl .hl h4{font-weight:700;font-size:1.18rem;letter-spacing:-.01em;margin-bottom:9px}
.studio-hl .hl p{color:var(--ink-soft);font-size:.97rem;line-height:1.55;margin:0}
.support-sec{padding:110px 0;text-align:center}
.support-sec .eyebrow{margin-bottom:20px}
.support-sec .eyebrow::before{display:none}
.support-sec h2{font-size:clamp(2rem,4.8vw,3.5rem);max-width:18ch;margin:0 auto}
.support-intro{color:var(--ink-soft);font-size:clamp(1.05rem,1.6vw,1.2rem);max-width:62ch;margin:22px auto 0;line-height:1.55}
.support-intro a{color:var(--obpro);font-weight:600}
.support-panel{max-width:880px;margin:44px auto 0;background:var(--bg-2);border-radius:28px;padding:clamp(30px,4.5vw,54px);text-align:left;box-shadow:0 30px 72px -42px rgba(0,0,0,.22)}
.support-form{display:flex;flex-direction:column;gap:20px}
.support-form .row2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.support-form label{display:flex;flex-direction:column;gap:8px;font-size:.74rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute)}
.support-form input,.support-form select,.support-form textarea{font-family:var(--sans);font-size:1.02rem;font-weight:400;text-transform:none;letter-spacing:0;color:var(--ink);background:#fff;border:0;border-radius:14px;padding:16px 18px;transition:box-shadow .25s;width:100%;box-shadow:0 1px 2px rgba(0,0,0,.05)}
.support-form input::placeholder,.support-form textarea::placeholder{color:var(--ink-mute)}
.support-form input:focus,.support-form select:focus,.support-form textarea:focus{outline:none;box-shadow:0 0 0 3px rgba(63,120,168,.3)}
.support-form textarea{resize:vertical;min-height:144px}
.form-row{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:4px}
.support-send{cursor:pointer;border:0;font-size:.98rem}
.form-note{font-size:.95rem;color:var(--obpro);font-weight:600;text-transform:none;letter-spacing:0;min-height:1.2em;margin:0}
@media(max-width:680px){.studio-hl{grid-template-columns:1fr;gap:18px}.support-form .row2{grid-template-columns:1fr}}
@media(max-width:820px){
  .pill{display:none}.navcta{display:none}.navtoggle{display:flex}
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px}.fbrand{grid-column:1/-1}.qr{grid-column:1/-1;margin-top:8px}
  .panel{padding:60px 30px}.panel .lock{opacity:.5;width:150px;height:150px;right:-20px}
}
@media(max-width:560px){.wrap,.hero-c,.apps-head{padding-left:20px;padding-right:20px}.apps,.stmt,.reviews,.faq,.privacy{padding-top:74px;padding-bottom:74px}.card{height:min(680px,82svh)}.acts{flex-wrap:wrap}.track{gap:16px}}
.screen.game{background:radial-gradient(120% 90% at 50% 42%,rgba(63,217,245,.18),#05080d 72%);color:#fff;padding:14px 14px 0}
.screen.game .gtop{font-size:.58rem;letter-spacing:.16em;color:rgba(63,217,245,.85);text-align:center;margin-top:10px}
.screen.game .grings{position:relative;flex:1;display:grid;place-items:center}
.screen.game .grings span{position:absolute;border-radius:50%}
.screen.game .r1{width:118px;height:118px;border:1px solid rgba(63,217,245,.45)}
.screen.game .r2{width:168px;height:168px;border:1px dashed rgba(63,217,245,.4);animation:spin 18s linear infinite}
.screen.game .core{width:46px;height:46px;background:radial-gradient(circle,#d6f8ff,var(--stellaxe));box-shadow:0 0 36px var(--stellaxe)}
.screen.game .gscan{position:absolute;inset:0;background:repeating-linear-gradient(transparent 0 3px,rgba(63,217,245,.05) 3px 4px);pointer-events:none}
.screen.game .gcoord{font-size:.56rem;letter-spacing:.12em;color:rgba(63,217,245,.8);text-align:center;padding:5px 0}
.screen.game .gplay{margin:4px 0 14px;height:40px;border-radius:12px;background:var(--stellaxe);color:#06222b;font-weight:700;font-size:.78rem;display:grid;place-items:center}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal,.rl{opacity:1!important;transform:none!important}}

/* per-app legal links (Privacy / Terms) under the App Store button */
.appdocs{flex-basis:100%;display:flex;gap:10px;align-items:center;font-size:.78rem;color:var(--ink-mute);margin-top:2px}
.appdocs a{color:var(--ink-mute);transition:color .2s}
.appdocs a:hover{color:var(--c)}
/* app icon inline with the app name (logo lockup) */
.namelock{display:flex;align-items:center;gap:13px}
.namelock h3{min-width:0}
.appicon{flex:none;width:46px;height:46px;border-radius:23%;object-fit:cover;display:block;background:#fff;box-shadow:0 6px 16px -7px rgba(10,14,22,.3),0 0 0 1px rgba(0,0,0,.05)}
/* contact form honeypot (hidden from humans) */
.hp{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;opacity:0!important;pointer-events:none}
