/* ═══════════════════════════════════════
   BLOK v6 — Creative Redesign
   Refs: ssscript, walbi, fitonist, flashquad
   ═══════════════════════════════════════ */

/* ── Fonts ── */
@font-face{font-family:'DM';src:url('assets/fonts/dot_matrix.ttf') format('truetype');font-display:swap}
@font-face{font-family:'SM';src:url('assets/fonts/space_mono_regular.ttf') format('truetype');font-weight:400;font-display:swap}
@font-face{font-family:'SM';src:url('assets/fonts/space_mono_bold.ttf') format('truetype');font-weight:700;font-display:swap}

/* ── Vars ── */
:root{
  --bg:#050505;
  --bg2:#0a0a0a;
  --surface:#111;
  --card:#0d0d0d;
  --border:#484848;
  --ac:#F5FF00;
  --ac-dim:rgba(245,255,0,.12);
  --green:#4ADE80;
  --blue:#60A5FA;
  --orange:#FB923C;
  --purple:#A78BFA;
  --txt:#e8e8e8;
  --txt2:#c2c2c2;
  --txt3:#959595;
  --dm:'DM',monospace;
  --sm:'SM','Courier New',monospace;
  --ease:cubic-bezier(.22,1,.36,1);
  --nav-h:60px;
}

/* ── Reset ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--sm);background:var(--bg);color:var(--txt);overflow-x:hidden;cursor:none}
a{color:inherit;text-decoration:none}
button{background:none;border:none;color:inherit;font:inherit;cursor:none}
img{max-width:100%;display:block}
::selection{background:var(--ac);color:#000}

/* ── Cursor hide on mobile ── */
@media(pointer:coarse){body,button{cursor:auto}}

/* ── Canvas ── */
#trail{position:fixed;inset:0;z-index:9999;pointer-events:none}

/* ── Loader ── */
#loader{position:fixed;inset:0;z-index:10000;background:var(--bg);display:flex;align-items:center;justify-content:center;transition:opacity .6s var(--ease),visibility .6s}
#loader.done{opacity:0;visibility:hidden;pointer-events:none}
.ld-eye{width:clamp(110px,16vw,180px);animation:pulse 1.2s ease infinite}
@keyframes pulse{0%,100%{opacity:.35;transform:scale(.97)}50%{opacity:1;transform:scale(1)}}

/* ── Layout ── */
.wrap{max-width:1200px;margin:0 auto;padding:0 28px}
.wrap-sm{max-width:800px}
.sec{padding:140px 0}
.sec-dark{background:var(--bg2)}

/* ── Nav ── */
#nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 32px;height:var(--nav-h);background:rgba(5,5,5,.65);backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4);border-bottom:1px solid rgba(255,255,255,.2);transition:transform .4s var(--ease)}
#nav.hide{transform:translateY(-100%)}
.n-logo img{height:22px;opacity:.9}
.n-links{display:flex;gap:32px}
.n-links a{font-size:13px;letter-spacing:.04em;color:var(--txt2);transition:color .25s;position:relative}
.n-links a::after{content:'';position:absolute;left:0;bottom:-4px;width:100%;height:1px;background:var(--ac);transform:scaleX(0);transform-origin:right;transition:transform .35s var(--ease)}
.n-links a:hover{color:var(--txt)}
.n-links a:hover::after{transform:scaleX(1);transform-origin:left}
.n-cta{font-size:12px;letter-spacing:.08em;text-transform:uppercase;padding:8px 20px;border:1px solid var(--ac);color:var(--ac);border-radius:100px;transition:all .3s var(--ease)}
.n-cta:hover{background:var(--ac);color:#000}

/* Burger */
.n-burger{display:none;width:28px;height:20px;position:relative;flex-direction:column;justify-content:space-between}
.n-burger span{display:block;width:100%;height:2px;background:var(--txt);border-radius:2px;transition:all .3s}
.n-burger.active span:first-child{transform:rotate(45deg) translate(6px,6px)}
.n-burger.active span:last-child{transform:rotate(-45deg) translate(6px,-6px)}

/* Mobile menu */
.mmenu{position:fixed;inset:0;z-index:99;background:rgba(5,5,5,.97);backdrop-filter:blur(30px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:36px;opacity:0;visibility:hidden;transition:all .35s var(--ease)}
.mmenu.open{opacity:1;visibility:visible}
.mmenu a{font-size:20px;letter-spacing:.04em;color:var(--txt2);transition:color .2s}
.mmenu a:hover{color:var(--txt)}
.mm-cta{padding:12px 32px;border:1px solid var(--ac);color:var(--ac)!important;border-radius:100px}

/* ══════════════════════════════════════
   HERO — editorial, product-first.
   Copy leads; the 3D mark is an identity
   accent on the right with real depth.
   ══════════════════════════════════════ */
#hero{height:100vh;min-height:680px;position:relative;overflow:hidden;background:radial-gradient(ellipse 80% 70% at 68% 45%,#0b0b0b 0%,#050505 60%,#020202 100%)}
#hero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.012) 1px,transparent 1px);background-size:26px 26px;pointer-events:none}
#hero::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 95% 85% at 50% 50%,transparent 55%,rgba(0,0,0,.6) 100%);pointer-events:none;z-index:4}

.h-meta{position:absolute;top:calc(var(--nav-h) + 34px);font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:var(--txt3);z-index:5}
.hm-l{left:40px}
.hm-r{right:40px}

/* faint wordmark anchoring the visual side */
.h-big{position:absolute;top:50%;right:-4%;transform:translateY(-50%);font-family:var(--dm);font-size:clamp(90px,17vw,250px);letter-spacing:.06em;color:#121212;user-select:none;z-index:1;line-height:1}

/* layout */
.h-grid{position:relative;z-index:3;height:100%;max-width:1280px;margin:0 auto;padding:0 48px;display:grid;grid-template-columns:minmax(0,7fr) minmax(0,5fr);align-items:center;gap:24px}
.h-copy{padding-top:var(--nav-h)}

.h-title{font-family:var(--dm);font-weight:400;font-size:clamp(40px,6.2vw,84px);line-height:1.08;letter-spacing:.04em;text-transform:uppercase;margin-bottom:26px}
.h-line{display:block;overflow:hidden}
.h-line i{display:block;font-style:normal;transform:translateY(110%);animation:hRise .9s var(--ease) forwards}
.h-line:nth-child(2) i{animation-delay:.12s}
@keyframes hRise{to{transform:translateY(0)}}
.ac{color:var(--ac)}

.hero-p{font-size:15px;line-height:1.75;color:var(--txt2);max-width:440px;margin-bottom:30px;opacity:0;animation:hFade .8s var(--ease) .35s forwards}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;opacity:0;animation:hFade .8s var(--ease) .5s forwards}
.h-trust{display:block;margin-top:18px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--txt3);opacity:0;animation:hFade .8s var(--ease) .65s forwards}
@keyframes hFade{to{opacity:1}}

/* three.js column */
.h-visual{position:relative;height:min(72vh,640px);z-index:2}
#hero3d{position:absolute;inset:0}
#hero3d canvas{display:block;width:100%!important;height:100%!important}

/* ── Marquee divider ── */
.marquee{overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg);padding:18px 0}
.mq-track{display:flex;align-items:center;gap:36px;width:max-content;animation:mq 26s linear infinite}
.mq-track span{font-family:var(--dm);font-size:14px;letter-spacing:.18em;text-transform:uppercase;color:var(--txt3);white-space:nowrap}
.mq-track i{width:6px;height:6px;background:var(--ac);border-radius:50%;flex-shrink:0;opacity:.7}
@keyframes mq{to{transform:translateX(-50%)}}

/* Buttons */
.btn-p{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;background:var(--ac);color:#000;font-size:14px;font-weight:700;letter-spacing:.02em;border-radius:100px;transition:all .3s var(--ease)}
.btn-p:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(245,255,0,.2)}
.btn-p svg{transition:transform .3s}.btn-p:hover svg{transform:translate(2px,-2px)}
.btn-g{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;font-size:14px;color:var(--txt2);border:1px solid var(--border);border-radius:100px;transition:all .3s var(--ease)}
.btn-g:hover{border-color:var(--txt3);color:var(--txt)}
.btn-lg{padding:18px 36px;font-size:15px}

/* ── App showcase section: phone + value props ── */
.app-sec{background:var(--bg2);border-bottom:1px solid var(--border)}
.app-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:64px;align-items:center}
.app-show{display:flex;justify-content:center;padding:20px 0 40px}

.app-points{display:flex;flex-direction:column}
.app-point{display:flex;gap:24px;padding:30px 0;border-top:1px solid var(--border)}
.app-point:last-child{border-bottom:1px solid var(--border)}
.ap-n{font-family:var(--dm);font-size:13px;color:var(--ac);letter-spacing:.2em;padding-top:4px}
.app-point h3{font-size:19px;font-weight:700;letter-spacing:-.01em;margin-bottom:8px}
.app-point p{font-size:14px;color:var(--txt2);line-height:1.7}

/* ── Device scene: phone + badges ── */
.device-scene{position:relative;width:300px}

.phone{width:300px;border-radius:46px;padding:3px;background:linear-gradient(155deg,#3a3a3a 0%,#1a1a1a 30%,#0e0e0e 65%,#262626 100%);box-shadow:0 60px 100px rgba(0,0,0,.7),0 20px 40px rgba(0,0,0,.5),0 0 90px rgba(245,255,0,.04);position:relative}
.phone::before{content:'';position:absolute;left:-2px;top:120px;width:2px;height:54px;border-radius:2px;background:linear-gradient(90deg,#333,#111)}
.phone::after{content:'';position:absolute;right:-2px;top:150px;width:2px;height:70px;border-radius:2px;background:linear-gradient(90deg,#111,#333)}

.p-screen{background:linear-gradient(180deg,#0b0b0b 0%,#060606 100%);border-radius:43px;padding:14px 18px 12px;min-height:560px;display:flex;flex-direction:column;align-items:center;position:relative;overflow:hidden;border:6px solid #000}

/* status bar */
.p-status{width:100%;display:flex;justify-content:space-between;align-items:center;font-size:11px;font-weight:700;color:#ddd;padding:2px 8px 0}
.p-sig{display:inline-flex;align-items:flex-end;gap:2px}
.p-sig i{width:3px;background:#ddd;border-radius:1px;display:block}
.p-sig i:nth-child(1){height:4px}.p-sig i:nth-child(2){height:6px}.p-sig i:nth-child(3){height:8px}
.p-sig b{width:16px;height:8px;border:1px solid #888;border-radius:2px;display:block;position:relative;margin-left:3px}
.p-sig b::after{content:'';position:absolute;inset:1px;right:4px;background:#ddd;border-radius:1px}

/* app header — logo left, like the real app */
.p-apphead{width:100%;display:flex;align-items:center;margin-top:18px;padding:0 4px}
.p-logoimg{height:15px;opacity:.95}

/* circle hero toggle — like CircleHero in the app */
.p-toggle{position:relative;width:120px;height:120px;margin:22px 0 0;display:flex;align-items:center;justify-content:center}
.p-btn{width:86px;height:86px;border-radius:50%;background:rgba(255,255,255,.05);border:1px solid rgba(245,255,0,.5);display:flex;align-items:center;justify-content:center;box-shadow:0 0 40px rgba(245,255,0,.18),inset 0 1px 0 rgba(255,255,255,.05);position:relative;z-index:1}
.p-ring{position:absolute;inset:0;border-radius:50%;border:1px solid rgba(245,255,0,.18)}
.p-ring.r1{animation:pring 3s ease-out infinite}
.p-ring.r2{animation:pring 3s ease-out 1.5s infinite}
@keyframes pring{0%{transform:scale(.78);opacity:0}30%{opacity:1}100%{transform:scale(1.12);opacity:0}}

/* solid yellow space chip — exactly like the app */
.p-spacechip{display:inline-flex;align-items:center;gap:6px;margin-top:18px;background:var(--ac);color:#000;font-size:10px;font-weight:700;letter-spacing:.12em;padding:7px 16px;border-radius:100px}

/* stats row — TIME / ATTEMPTS glass cards */
.p-stats{width:100%;display:flex;gap:8px;margin-top:18px}
.p-stat{flex:1;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:11px 13px;display:flex;flex-direction:column;gap:5px;text-align:left}
.p-stat-l{font-size:7.5px;letter-spacing:.2em;color:var(--txt3);font-weight:700}
.p-stat-v{font-size:16px;font-weight:700;color:#eee;letter-spacing:.04em}

/* blocked apps card with dot chips */
.p-blocked{width:100%;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:13px;margin-top:8px;text-align:left}
.p-blocked-t{font-size:11px;font-weight:700;color:#ddd}
.p-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.p-appchip{display:inline-flex;align-items:center;gap:5px;font-size:9.5px;color:rgba(255,255,255,.8);background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:100px;padding:5px 10px}
.p-appchip i{width:5px;height:5px;border-radius:50%;background:var(--c);display:block}
.p-add{color:var(--txt3);background:none}

/* emergency unlock — red, like the app */
.p-emergency{font-size:8px;letter-spacing:.14em;color:rgba(255,107,91,.55);font-weight:700;margin-top:14px}

.p-gesture{width:110px;height:4px;border-radius:3px;background:rgba(255,255,255,.25);margin-top:auto}
.p-glare{position:absolute;inset:0;background:linear-gradient(115deg,rgba(255,255,255,.055) 0%,rgba(255,255,255,.015) 28%,transparent 45%);pointer-events:none;border-radius:37px}

/* Floating badges */
.float-badge{position:absolute;display:inline-flex;align-items:center;gap:6px;padding:9px 16px;background:rgba(14,14,14,.72);border:1px solid rgba(255,255,255,.1);border-radius:100px;font-size:12px;color:var(--txt);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);white-space:nowrap;z-index:4;box-shadow:0 10px 30px rgba(0,0,0,.45)}
.fb-1{top:-14px;right:-36px;animation:fb1 4s ease-in-out infinite}
.fb-3{bottom:300px;right:-70px;animation:fb3 4.5s ease-in-out infinite}
@keyframes fb1{0%,100%{transform:translate(0,0)}50%{transform:translate(4px,-6px)}}
@keyframes fb3{0%,100%{transform:translate(0,0)}50%{transform:translate(5px,4px)}}

/* Scroll cue */
.scroll-cue{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);text-align:center}
.scroll-cue span{font-size:10px;letter-spacing:.3em;color:var(--txt3);animation:scrollBounce 2s ease infinite}
@keyframes scrollBounce{0%,100%{transform:translateY(0);opacity:.4}50%{transform:translateY(5px);opacity:.8}}

.scroll-cue{z-index:3}

/* ══════════════════════════════════════
   SECTIONS COMMON
   ══════════════════════════════════════ */
.label{font-size:12px;letter-spacing:.15em;color:var(--txt3);text-transform:uppercase;margin-bottom:16px}
.sec-title{font-family:var(--dm);font-size:clamp(28px,4vw,50px);font-weight:400;line-height:1.2;letter-spacing:.04em;text-transform:uppercase;margin-bottom:64px}
.dim{color:var(--txt3)}

/* ══════════════════════════════════════
   HOW IT WORKS — timeline
   ══════════════════════════════════════ */
.steps{display:flex;flex-direction:column;gap:0;position:relative}
.step{display:flex;gap:32px;padding:40px 0;position:relative}
.step-line{position:absolute;left:11px;top:0;bottom:0;width:1px;background:var(--border)}
.step:last-child .step-line{display:none}
.step-dot{width:23px;height:23px;border-radius:50%;border:2px solid var(--border);background:var(--bg);flex-shrink:0;position:relative;z-index:1;transition:all .5s var(--ease)}
.step.v .step-dot{border-color:var(--ac);background:var(--ac);box-shadow:0 0 20px rgba(245,255,0,.2)}
.step-content{flex:1}
.step-n{font-family:var(--dm);font-size:13px;color:var(--ac);letter-spacing:.2em;display:block;margin-bottom:10px}
.step h3{font-size:22px;font-weight:700;margin-bottom:8px;letter-spacing:-.01em}
.step p{font-size:15px;color:var(--txt2);line-height:1.6;max-width:480px}

/* ══════════════════════════════════════
   STATS
   ══════════════════════════════════════ */
.stats-sec{padding:100px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg)}
.stats-row{display:flex;align-items:center;justify-content:center;gap:48px;flex-wrap:wrap}
.stat{text-align:center}
.stat-val{font-family:var(--dm);font-size:clamp(52px,8vw,96px);color:var(--ac);line-height:1;letter-spacing:.02em}
.stat-val span{font-size:.5em;color:var(--ac);opacity:.7}
.stat-label{font-size:14px;color:var(--txt2);margin-top:8px;letter-spacing:.04em}
.stat-div{width:1px;height:60px;background:var(--border);flex-shrink:0}

/* ══════════════════════════════════════
   BENTO FEATURES
   ══════════════════════════════════════ */
.bento{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}

.b-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:28px;position:relative;overflow:hidden;transition:all .4s var(--ease)}
.b-card:hover{border-color:rgba(255,255,255,.08);transform:translateY(-3px)}
.b-card::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 0%,rgba(245,255,0,.03),transparent 60%);pointer-events:none;opacity:0;transition:opacity .4s}
.b-card:hover::after{opacity:1}

.b-card h3{font-size:18px;font-weight:700;margin-bottom:6px;letter-spacing:-.01em}
.b-card p{font-size:13px;color:var(--txt2);line-height:1.6}

.b-tag{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ac);display:inline-block;margin-bottom:16px;padding:3px 10px;background:var(--ac-dim);border-radius:4px}
.tag-green{color:var(--green);background:rgba(74,222,128,.1)}
.tag-blue{color:var(--blue);background:rgba(96,165,250,.1)}
.tag-orange{color:var(--orange);background:rgba(251,146,60,.1)}
.tag-purple{color:var(--purple);background:rgba(167,139,250,.1)}

/* Tall card */
.b-tall{grid-row:span 2;display:flex;flex-direction:column}
.b-visual{flex:1;display:flex;align-items:center;justify-content:center;margin:20px 0;opacity:.8}

/* Wide card */
.b-wide{grid-column:span 2;position:relative}

/* Bars deco */
.b-bars{display:flex;align-items:flex-end;gap:4px;height:80px;margin-bottom:16px}
.bar{width:100%;background:rgba(255,255,255,.06);border-radius:3px 3px 0 0;transition:height .6s var(--ease)}
.bar-ac{background:rgba(74,222,128,.3)}

/* Chips deco */
.b-deco{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}
.deco-chip{font-size:11px;letter-spacing:.06em;padding:6px 14px;border:1px solid var(--border);border-radius:100px;color:var(--txt3)}
.chip-active{border-color:var(--ac);color:var(--ac);background:var(--ac-dim)}

/* Dot grid deco */
.b-dots{position:absolute;bottom:16px;right:16px;width:140px;height:80px;overflow:hidden;opacity:.15}
.dot-grid{width:100%;height:100%;background-image:radial-gradient(circle,#fff 1px,transparent 1px);background-size:14px 14px}

/* ══════════════════════════════════════
   STATEMENT
   ══════════════════════════════════════ */
.statement-sec{padding:120px 0}
.statement{font-size:clamp(22px,3vw,38px);font-weight:700;line-height:1.4;text-align:center;letter-spacing:-.02em;color:var(--txt3)}
.statement em{font-style:normal;color:var(--txt)}

/* principles — open source / any NFC */
.principles{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:90px}
.principle{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:42px 36px;transition:border-color .4s var(--ease)}
.principle:hover{border-color:rgba(245,255,0,.25)}
.pr-tag{display:block;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--txt3);margin-bottom:18px}
.principle h3{font-family:var(--dm);font-size:clamp(22px,2.6vw,32px);font-weight:400;letter-spacing:.04em;text-transform:uppercase;margin-bottom:14px}
.principle p{font-size:14px;color:var(--txt2);line-height:1.75}
.pr-link{display:inline-block;margin-top:18px;font-size:13px;color:var(--ac);letter-spacing:.02em;border-bottom:1px solid transparent;transition:border-color .3s var(--ease)}
.pr-link:hover{border-color:var(--ac)}
@media(max-width:760px){.principles{grid-template-columns:1fr;margin-top:64px}.principle{padding:32px 26px}}

/* ══════════════════════════════════════
   FAQ
   ══════════════════════════════════════ */
.faqs{display:flex;flex-direction:column;gap:0}
.fq{border-bottom:1px solid var(--border)}
.fq:first-child{border-top:1px solid var(--border)}
.fq-q{width:100%;display:flex;justify-content:space-between;align-items:center;padding:22px 0;font-size:16px;font-weight:700;text-align:left;letter-spacing:-.01em;cursor:none}
.fq-i{width:20px;height:20px;position:relative;flex-shrink:0}
.fq-i::before,.fq-i::after{content:'';position:absolute;background:var(--txt2);transition:transform .3s var(--ease)}
.fq-i::before{width:20px;height:2px;top:9px;left:0}
.fq-i::after{width:2px;height:20px;left:9px;top:0}
.fq.open .fq-i::after{transform:rotate(90deg)}
.fq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.fq.open .fq-a{max-height:300px}
.fq-a p{padding:0 0 22px;font-size:14px;color:var(--txt2);line-height:1.7}

/* ══════════════════════════════════════
   CTA
   ══════════════════════════════════════ */
.cta-sec{padding:120px 0}
.cta-box{text-align:center;max-width:640px;margin:0 auto;padding:80px 40px;border:1px solid var(--border);border-radius:24px;background:var(--card);position:relative;overflow:hidden}
.cta-box::before{content:'';position:absolute;top:-50%;left:50%;transform:translateX(-50%);width:400px;height:400px;background:radial-gradient(circle,rgba(245,255,0,.04),transparent 60%);pointer-events:none}
.cta-box h2{font-family:var(--dm);font-size:clamp(24px,3.5vw,40px);font-weight:400;line-height:1.25;letter-spacing:.04em;text-transform:uppercase;margin-bottom:16px}
.cta-box p{font-size:15px;color:var(--txt2);margin-bottom:32px;line-height:1.6}
.cta-note{display:block;margin-top:16px;font-size:12px;color:var(--txt3);letter-spacing:.04em}

/* ══════════════════════════════════════
   FOOTER
   ══════════════════════════════════════ */
footer{border-top:1px solid var(--border);padding:40px 0}
.ft-row{display:flex;align-items:center;justify-content:space-between}
.ft-l{display:flex;align-items:center;gap:16px}
.ft-logo{height:18px;opacity:.5}
.ft-l p{font-size:12px;color:var(--txt3)}
.ft-r{display:flex;gap:24px}
.ft-r a{font-size:12px;color:var(--txt3);transition:color .2s}
.ft-r a:hover{color:var(--txt)}

/* ══════════════════════════════════════
   REVEAL ANIMATION
   ══════════════════════════════════════ */
.rv{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.rv.v{opacity:1;transform:translateY(0)}

/* ══════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════ */
@media(max-width:960px){
  .h-meta{top:calc(var(--nav-h) + 22px)}
  .hm-l{left:24px}
  .hm-r{right:24px}
  .h-grid{grid-template-columns:1fr;padding:0 28px;align-content:center;gap:0}
  .h-copy{padding-top:calc(var(--nav-h) + 30px);text-align:center}
  .hero-p{margin-left:auto;margin-right:auto}
  .hero-btns{justify-content:center}
  .h-visual{height:30vh;min-height:200px;order:-1;margin-top:var(--nav-h)}
  .h-big{right:50%;transform:translate(50%,-50%);top:32%}
  .scroll-cue{display:none}
  .app-grid{grid-template-columns:1fr;gap:24px}
  .device-scene{width:280px}
  .phone{width:280px}
  .bento{grid-template-columns:repeat(2,1fr)}
  .b-tall{grid-row:span 1}
  .b-wide{grid-column:span 2}
  .stats-row{gap:32px}
  .stat-div{display:none}
}

@media(max-width:640px){
  .n-links{display:none}
  .n-cta{display:none}
  .n-burger{display:flex}
  .sec{padding:100px 0}
  .bento{grid-template-columns:1fr}
  .b-wide{grid-column:span 1}
  .stats-row{flex-direction:column;gap:40px}
  .hero-btns{flex-direction:column;align-items:stretch}
  .hero-btns .btn-p,.hero-btns .btn-g{text-align:center;justify-content:center}
  .device-scene{width:250px}
  .phone{width:250px}
  .p-screen{min-height:480px}
  .float-badge{font-size:11px;padding:6px 12px}
  .fb-1{right:-12px}
  .fb-3{right:-12px;bottom:-10px}
  .h-title{font-size:clamp(34px,11vw,48px)}
  .hm-r{display:none}
  .cta-box{padding:60px 24px}
  .ft-row{flex-direction:column;gap:16px;text-align:center}
  .step{gap:20px}
}
