/* ============================================================
   Andy Akotia - Portfolio
   Outer-space, premium, built to make people stop
   ============================================================ */

:root{
  --bg:#04050d;
  --ink:#eef1ff;
  --muted:#9aa3c7;
  --faint:#5b6486;
  --line:rgba(140,160,255,.14);
  --glass:rgba(16,20,42,.5);
  --gold:#c9a227;
  --mint:#00e6b0;
  --blue:#5b8cff;
  --violet:#9b6cff;
  --pink:#ff6b9d;
  --grad:linear-gradient(120deg,#5b8cff 0%,#9b6cff 45%,#00e6b0 100%);
  --grad-soft:linear-gradient(120deg,rgba(91,140,255,.16),rgba(155,108,255,.16));
  --maxw:1240px;
  --r:20px;
  --ease:cubic-bezier(.16,1,.3,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  font-family:'Sora',system-ui,sans-serif;
  background:var(--bg);color:var(--ink);line-height:1.6;
  overflow-x:hidden;position:relative;-webkit-font-smoothing:antialiased;
}
body.lock{overflow:hidden;height:100vh}

a{color:inherit}

/* ---------- Intro loader ---------- */
.loader{
  position:fixed;inset:0;z-index:10000;background:#04050d;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  transition:transform 1s var(--ease);
}
.loader.done{transform:translateY(-100%)}
.loader-inner{text-align:center}
.loader-name{
  font-family:'Space Grotesk',sans-serif;font-weight:700;
  font-size:clamp(1.6rem,6vw,3.2rem);letter-spacing:.22em;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  background-size:200% 200%;animation:flow 5s ease infinite;
}
.loader-role{margin-top:12px;color:var(--faint);letter-spacing:.34em;text-transform:uppercase;font-size:.74rem}
.loader-count{position:absolute;bottom:7vh;right:7vw;display:flex;align-items:flex-end;font-family:'Space Grotesk',sans-serif;font-weight:700}
.loader-count span{font-size:clamp(3rem,12vw,7rem);line-height:.85;color:var(--ink)}
.loader-count i{font-style:normal;color:var(--mint);font-size:1.4rem;margin-left:6px;margin-bottom:.3em}
.loader-bar{position:absolute;bottom:0;left:0;width:100%;height:3px;background:rgba(140,160,255,.08)}
.loader-bar span{display:block;height:100%;width:0;background:var(--grad)}

/* ---------- Cosmic backdrop ---------- */
#webgl{position:fixed;inset:0;width:100%;height:100%;z-index:-3;display:block}
.nebula{position:fixed;border-radius:50%;filter:blur(100px);opacity:.4;z-index:-2;pointer-events:none;mix-blend-mode:screen;will-change:transform}
.nebula-1{width:55vw;height:55vw;left:-12vw;top:-8vw;background:radial-gradient(circle at 30% 30%,rgba(91,140,255,.5),transparent 60%)}
.nebula-2{width:55vw;height:55vw;right:-16vw;top:38vh;background:radial-gradient(circle at 60% 40%,rgba(155,108,255,.45),rgba(0,230,176,.16) 50%,transparent 70%)}
.grain{
  position:fixed;inset:0;z-index:70;pointer-events:none;opacity:.045;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- Custom cursor ---------- */
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;z-index:9998;pointer-events:none;border-radius:50%;transform:translate(-50%,-50%);opacity:0;transition:opacity .3s}
.cursor-dot{width:7px;height:7px;background:var(--mint);mix-blend-mode:difference}
.cursor-ring{width:42px;height:42px;border:1px solid rgba(160,180,255,.5);transition:width .3s var(--ease),height .3s var(--ease),background .3s,border-color .3s,opacity .3s;display:grid;place-items:center}
.cursor-ring span{font-family:'Space Grotesk',sans-serif;font-size:.6rem;letter-spacing:.12em;color:var(--ink);opacity:0;transition:opacity .25s}
.cursor-ring.hover{width:64px;height:64px;border-color:rgba(160,180,255,.9);background:rgba(91,140,255,.08)}
.cursor-ring.view{width:92px;height:92px;background:rgba(91,140,255,.14);border-color:transparent}
.cursor-ring.view span{opacity:1}
body.cursor-on,body.cursor-on a,body.cursor-on button,body.cursor-on [data-cursor]{cursor:none}

/* ---------- Layout helpers ---------- */
section{position:relative;padding:130px clamp(20px,6vw,80px);max-width:var(--maxw);margin:0 auto}
.section-head{margin-bottom:60px;max-width:840px}
.kicker{font-family:'Space Grotesk',sans-serif;font-size:.8rem;letter-spacing:.22em;text-transform:uppercase;color:var(--mint);display:inline-block;margin-bottom:18px}
.section-head h2{font-size:clamp(2rem,5vw,3.6rem);font-weight:700;line-height:1.06;letter-spacing:-.025em;text-shadow:0 2px 26px rgba(4,5,13,.6)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:.98rem;padding:16px 32px;border-radius:100px;text-decoration:none;cursor:pointer;border:0;transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .35s;will-change:transform}
.btn-primary{background:var(--grad);color:#06081a;background-size:160% 160%}
.btn-primary:hover{box-shadow:0 14px 44px rgba(91,140,255,.45)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn-ghost:hover{border-color:rgba(140,160,255,.5);background:rgba(140,160,255,.06)}
.btn-block{width:100%}

/* ---------- Nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:22px clamp(20px,6vw,80px);transition:background .4s,backdrop-filter .4s,padding .4s,border-color .4s;border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(4,5,13,.72);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding-top:14px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.nav-brand{display:flex;align-items:center;gap:11px;text-decoration:none}
.brand-mark{width:38px;height:38px;border-radius:11px;display:block;flex:0 0 auto}
.brand-name{font-family:'Space Grotesk',sans-serif;font-weight:600}
.nav-links{display:flex;align-items:center;gap:34px}
.nav-links a{color:var(--muted);text-decoration:none;font-size:.96rem;transition:color .25s;position:relative}
.nav-links a:not(.nav-cta):hover{color:var(--ink)}
.nav-links a:not(.nav-cta)::after{content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--grad);transition:width .3s var(--ease)}
.nav-links a:not(.nav-cta):hover::after{width:100%}
.nav-cta{padding:11px 22px;border-radius:100px;border:1px solid var(--line);color:var(--ink)!important}
.nav-cta:hover{background:rgba(140,160,255,.1);border-color:rgba(140,160,255,.4)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;z-index:60}
.nav-toggle span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.3s var(--ease)}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{position:fixed;inset:0;z-index:45;background:rgba(4,5,13,.97);backdrop-filter:blur(20px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:30px;opacity:0;visibility:hidden;transition:opacity .4s,visibility .4s}
.mobile-menu.open{opacity:1;visibility:visible}
.mobile-menu a{color:var(--ink);text-decoration:none;font-size:1.8rem;font-weight:600;font-family:'Space Grotesk',sans-serif}

/* ---------- Kinetic line reveal ---------- */
.line-reveal{overflow:hidden;display:block}
.line-reveal>span{display:block;transform:translateY(110%);transition:transform 1s var(--ease)}
.hero-cta.line-reveal{overflow:visible}
body.ready .line-reveal>span{transform:none}
body.ready .hero-cta.line-reveal{opacity:1}
.hero-cta.line-reveal{opacity:0;transition:opacity .8s ease .6s}
/* stagger */
body.ready .eyebrow.line-reveal>span{transition-delay:.05s}
body.ready .hero-title .line-reveal:nth-child(1)>span{transition-delay:.12s}
body.ready .hero-title .line-reveal:nth-child(2)>span{transition-delay:.2s}
body.ready .hero-title .line-reveal:nth-child(3)>span{transition-delay:.28s}
body.ready .hero-sub.line-reveal>span{transition-delay:.4s}
body.ready .hero-stats .line-reveal:nth-child(1)>span{transition-delay:.7s}
body.ready .hero-stats .line-reveal:nth-child(2)>span{transition-delay:.78s}
body.ready .hero-stats .line-reveal:nth-child(3)>span{transition-delay:.86s}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding-top:130px;padding-bottom:60px;max-width:var(--maxw);margin:0 auto}
.hero::before{
  content:"";position:absolute;inset:-10vh -8vw;z-index:-1;pointer-events:none;
  background:
    linear-gradient(100deg,rgba(4,5,13,.92) 0%,rgba(4,5,13,.62) 34%,rgba(4,5,13,.12) 62%,rgba(4,5,13,0) 80%),
    linear-gradient(0deg,rgba(4,5,13,.92) 0%,rgba(4,5,13,.35) 32%,rgba(4,5,13,0) 58%);
}
.hero-inner{position:relative;max-width:940px}
.eyebrow{font-family:'Space Grotesk',sans-serif;letter-spacing:.32em;text-transform:uppercase;font-size:.82rem;color:var(--mint);margin-bottom:26px;text-shadow:0 2px 16px rgba(4,5,13,.7)}
.hero-title{font-size:clamp(2.7rem,9vw,6.8rem);font-weight:800;line-height:1;letter-spacing:-.035em;margin-bottom:32px;text-shadow:0 4px 40px rgba(4,5,13,.5)}
.hero-title .accent{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;background-size:200% 200%;animation:flow 8s ease infinite}
@keyframes flow{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.hero-sub{position:relative;font-size:clamp(1.05rem,2vw,1.32rem);color:#c2cbe8;max-width:640px;font-weight:300;margin-bottom:44px;text-shadow:0 2px 18px rgba(4,5,13,.85)}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}
.hero-stats{display:flex;gap:0;flex-wrap:wrap;margin-top:72px;border-top:1px solid var(--line);padding-top:30px}
.hero-stats>div{flex:1 1 200px;padding-right:24px}
.hero-stats span{display:flex;flex-direction:column;color:var(--faint);font-size:.92rem}
.hero-stats b{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.15rem;color:var(--ink);margin-bottom:4px}
.scroll-hint{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);color:var(--faint);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:10px}
.scroll-hint span{width:1px;height:44px;background:linear-gradient(var(--mint),transparent);animation:drop 2s ease infinite}
@keyframes drop{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.1%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---------- Marquee ---------- */
.marquee{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:24px 0;background:rgba(8,10,24,.35)}
.marquee-track{display:flex;white-space:nowrap;animation:scrollx 30s linear infinite;width:max-content}
.marquee-track span{font-family:'Space Grotesk',sans-serif;font-size:clamp(1.3rem,3vw,2.1rem);font-weight:600;color:var(--ink);padding:0 30px;opacity:.85}
.marquee-track i{color:var(--mint);font-style:normal;display:flex;align-items:center;font-size:.8em;opacity:.7}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ---------- About ---------- */
.about-lead{font-size:clamp(1.25rem,2.6vw,1.9rem);font-weight:200;line-height:1.45;color:var(--ink);margin-bottom:64px;max-width:980px;text-shadow:0 2px 22px rgba(4,5,13,.7)}
.about-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.about-cols .ac-num{font-family:'Space Grotesk',sans-serif;font-size:.85rem;color:var(--mint);display:block;margin-bottom:14px;letter-spacing:.1em}
.about-cols h3{font-family:'Space Grotesk',sans-serif;font-size:1.2rem;margin-bottom:12px}
.about-cols p{color:var(--muted);font-size:1rem}

/* ---------- Sectors strip ---------- */
.sectors{margin-top:56px;padding-top:28px;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;align-items:baseline;gap:10px 26px}
.sectors-label{font-family:'Space Grotesk',sans-serif;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--faint)}
.sectors-list{font-family:'Space Grotesk',sans-serif;font-size:clamp(1rem,2vw,1.3rem);color:var(--ink);letter-spacing:.01em}

/* ---------- Process ---------- */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line)}
.step{padding:34px 26px 34px 0;border-right:1px solid var(--line);position:relative}
.step:last-child{border-right:0}
.step-num{font-family:'Space Grotesk',sans-serif;font-size:.85rem;color:var(--mint);letter-spacing:.1em;display:block;margin-bottom:18px}
.step h3{font-family:'Space Grotesk',sans-serif;font-size:1.3rem;margin-bottom:12px}
.step p{color:var(--muted);font-size:.95rem;text-shadow:0 2px 14px rgba(4,5,13,.6)}

/* ---------- Work (editorial rows) ---------- */
.cases{display:flex;flex-direction:column;gap:0}
.case-row{position:relative;display:grid;grid-template-columns:auto 1fr 1.05fr;gap:40px;align-items:center;padding:56px 0;border-top:1px solid var(--line)}
.case-row:last-of-type{border-bottom:1px solid var(--line)}
.case-row.alt{grid-template-columns:auto 1.05fr 1fr}
.case-row.alt .case-media{order:3}
.case-row.alt .case-info{order:2}
.case-hit{position:absolute;inset:0;z-index:4}
.case-index{font-family:'Space Grotesk',sans-serif;font-size:clamp(2rem,4vw,3.4rem);font-weight:700;color:transparent;-webkit-text-stroke:1px rgba(140,160,255,.35);align-self:flex-start;line-height:1}
.case-media{position:relative;display:grid;place-items:center;min-height:280px;transition:transform .6s var(--ease)}
.case-row:hover .case-media{transform:translateY(-8px)}
.case-info h3{font-size:clamp(1.7rem,3.6vw,2.7rem);font-weight:700;letter-spacing:-.02em;line-height:1.04}
.case-tag{font-family:'Space Grotesk',sans-serif;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--mint);margin-bottom:14px}
.case-role{color:var(--blue);font-family:'Space Grotesk',sans-serif;font-size:.98rem;margin:8px 0 18px}
.case-desc{color:#aab3d6;font-size:1.02rem;margin-bottom:20px;max-width:520px;text-shadow:0 2px 16px rgba(4,5,13,.8)}
.case-meta{list-style:none;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.case-meta li{font-size:.78rem;font-family:'Space Grotesk',sans-serif;color:var(--muted);padding:6px 12px;border:1px solid var(--line);border-radius:100px;background:rgba(140,160,255,.04)}
.case-go{font-family:'Space Grotesk',sans-serif;font-size:.92rem;color:var(--ink);position:relative;z-index:5}
.case-row:hover .case-go{color:var(--mint)}
.work-more{text-align:center;color:var(--faint);margin-top:48px;font-family:'Space Grotesk',sans-serif;letter-spacing:.04em}

/* ---------- Scroll progress ---------- */
.scroll-progress{position:fixed;top:0;left:0;height:4px;width:0;z-index:9999;background:var(--grad);background-size:200% 100%;box-shadow:0 0 16px rgba(91,140,255,.7);transition:width .1s linear}

/* ---------- Real screenshot slots (auto-show when the file exists) ---------- */
.case-shot{display:none;width:100%;max-width:460px;border-radius:14px;border:1px solid var(--line);box-shadow:0 36px 90px rgba(0,0,0,.55)}
.case-shot.shot-phone{max-width:210px;border-radius:28px;padding:0}
/* transparent device lineups: shadow is baked into the PNG */
.case-shot.shot-trio{max-width:560px;width:100%;border:0;box-shadow:none;border-radius:0;background:none;transition:transform .3s var(--ease);will-change:transform}
.case-shot.shot-grid{max-width:540px;border-radius:14px}
.case-media.has-shot .case-shot{display:block}
.case-media.has-shot .fallback{display:none}

/* layered screenshot stack (Royal Athletes) */
.shot-stack{display:none;position:relative;width:100%;max-width:540px;transform-style:preserve-3d;transition:transform .25s var(--ease)}
.case-media.has-shot .shot-stack{display:block}
.shot-stack .shot-main{max-width:100%;width:100%;border-radius:14px}
.shot-stack .shot-float{position:absolute;width:56%;right:-7%;bottom:-13%;max-width:none;border-radius:11px;border:1px solid var(--line);box-shadow:0 26px 60px rgba(0,0,0,.6);transform:translateZ(45px) translateY(0);animation:floatZ 6s ease-in-out infinite}
@keyframes floatZ{0%,100%{transform:translateZ(45px) translateY(0)}50%{transform:translateZ(45px) translateY(-11px)}}

/* tactile 3D tilt target */
[data-tilt]{transition:transform .3s var(--ease);will-change:transform}

/* ---------- Case visuals (CSS art fallback) ---------- */
.browser{width:100%;max-width:440px;background:#0a0e22;border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:0 36px 90px rgba(0,0,0,.55)}
.browser-bar{display:flex;align-items:center;gap:7px;padding:12px 15px;background:#0e1330;border-bottom:1px solid var(--line)}
.browser-bar i{width:11px;height:11px;border-radius:50%;background:#2a3260}
.browser-bar i:first-child{background:#ff6b6b}.browser-bar i:nth-child(2){background:#ffd166}.browser-bar i:nth-child(3){background:#06d6a0}
.browser-bar span{margin-left:12px;font-size:.78rem;color:var(--faint);font-family:'Space Grotesk',sans-serif}
.ra-body{padding:40px 30px;background:radial-gradient(circle at 50% 0%,#1b2a6b33,#0a0e22 70%);text-align:center;min-height:260px}
.ra-crown{font-size:2.6rem;color:var(--gold);text-shadow:0 0 26px rgba(201,162,39,.6)}
.ra-hero-text{font-family:'Space Grotesk',sans-serif;font-weight:700;letter-spacing:.3em;color:#fff;margin:14px 0 26px;font-size:1.15rem}
.ra-row{display:flex;gap:11px;justify-content:center;margin-bottom:28px}
.ra-row span{width:52px;height:34px;border-radius:7px;background:linear-gradient(135deg,#1b2a6b,#2f3a73)}
.ra-swatches{display:flex;gap:9px;justify-content:center}
.ra-swatches i{width:22px;height:22px;border-radius:50%;background:var(--c);border:1px solid rgba(255,255,255,.15)}

.phone{width:172px;height:348px;background:#0a0e22;border:2px solid rgba(140,160,255,.25);border-radius:30px;padding:11px;box-shadow:0 30px 70px rgba(0,0,0,.6)}
.phone-screen{width:100%;height:100%;border-radius:21px;overflow:hidden;position:relative;padding:18px 14px}
.os-screen{background:linear-gradient(160deg,#0c1024,#0a0e22)}
.os-top{font-family:'Space Grotesk',sans-serif;color:var(--gold);font-size:.85rem;font-weight:700;letter-spacing:.1em;margin-bottom:16px}
.os-cards{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}
.os-cards span{height:36px;border-radius:8px;background:linear-gradient(135deg,#1b2a6b,#141a3a)}
.os-bars{display:flex;flex-direction:column;gap:8px}
.os-bars i{height:9px;border-radius:5px;background:rgba(201,162,39,.5)}
.os-bars i:nth-child(2){width:80%}.os-bars i:nth-child(3){width:60%}
.os-tab{position:absolute;bottom:14px;left:14px;right:14px;display:flex;justify-content:space-between;padding:9px 14px;background:#0e1330;border-radius:12px}
.os-tab b{width:18px;height:18px;border-radius:6px;background:#2a3260}
.os-tab b:first-child{background:var(--gold)}
.fit-screen{background:linear-gradient(160deg,#070a16,#05060f)}
.fit-top{font-family:'Space Grotesk',sans-serif;color:var(--mint);font-size:.85rem;font-weight:700;letter-spacing:.08em;margin-bottom:14px}
.fit-paths{display:flex;gap:7px;margin-bottom:22px}
.fit-paths span{font-size:.66rem;padding:6px 9px;border-radius:9px;background:rgba(91,140,255,.14);border:1px solid var(--line);color:var(--ink)}
.fit-paths span:first-child{background:var(--grad);color:#06081a;font-weight:700;border:0}
.fit-ring{width:104px;height:104px;border-radius:50%;margin:6px auto;border:7px solid rgba(91,140,255,.18);border-top-color:var(--mint);border-right-color:var(--violet);box-shadow:0 0 34px rgba(0,230,176,.25);animation:spin 7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.fit-tab{position:absolute;bottom:14px;left:14px;right:14px;display:flex;justify-content:space-between;padding:9px 12px;background:#0a0e1f;border-radius:12px}
.fit-tab b{width:15px;height:15px;border-radius:5px;background:#1b2350}
.fit-tab b:nth-child(3){background:var(--mint)}
.brand-stack{display:flex;gap:16px}
.bchip{width:64px;height:64px;border-radius:17px;display:grid;place-items:center;font-size:1.7rem;font-weight:700;color:#06081a;background:var(--c);box-shadow:0 14px 34px rgba(0,0,0,.45);animation:float 5s ease-in-out infinite}
.bchip:nth-child(2){animation-delay:.6s}.bchip:nth-child(3){animation-delay:1.2s}.bchip:nth-child(4){animation-delay:1.8s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* ---------- Offer ---------- */
.offer-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.offer-card{background:var(--glass);border:1px solid var(--line);border-radius:var(--r);padding:38px 32px;backdrop-filter:blur(8px);transition:transform .5s var(--ease),border-color .5s;position:relative;overflow:hidden}
.offer-card::before{content:"";position:absolute;inset:0;background:var(--grad-soft);opacity:0;transition:opacity .5s}
.offer-card:hover{transform:translateY(-8px);border-color:rgba(140,160,255,.4)}
.offer-card:hover::before{opacity:1}
.offer-card>*{position:relative}
.offer-num{font-family:'Space Grotesk',sans-serif;font-size:.85rem;color:var(--mint);letter-spacing:.1em;margin-bottom:20px}
.offer-card h3{font-family:'Space Grotesk',sans-serif;font-size:1.3rem;margin-bottom:12px;line-height:1.2}
.offer-card p{color:var(--muted);font-size:.96rem}

/* ---------- Contact ---------- */
.contact{padding-bottom:150px}
.contact-inner{background:var(--glass);border:1px solid var(--line);border-radius:30px;padding:clamp(32px,5vw,68px);backdrop-filter:blur(10px);position:relative;overflow:hidden}
.contact-inner::before{content:"";position:absolute;width:55%;height:60%;top:-20%;right:-10%;background:radial-gradient(circle,rgba(155,108,255,.28),transparent 70%);filter:blur(40px)}
.contact-inner>*{position:relative}
.contact-lead{color:var(--muted);font-size:1.05rem;margin-top:18px;max-width:560px}
.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;margin-top:48px;align-items:start}
.contact-direct{display:flex;flex-direction:column;gap:16px}
.contact-line{display:flex;flex-direction:column;gap:4px;text-decoration:none;padding:24px 26px;border:1px solid var(--line);border-radius:16px;background:rgba(140,160,255,.04);transition:transform .35s var(--ease),border-color .35s,background .35s}
.contact-line:hover{border-color:rgba(140,160,255,.4);background:rgba(140,160,255,.1)}
.contact-line.static{cursor:default}
.contact-line.static:hover{transform:none;border-color:var(--line);background:rgba(140,160,255,.04)}
.cl-label{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--faint)}
.cl-value{font-family:'Space Grotesk',sans-serif;font-size:1.2rem;color:var(--ink);display:flex;align-items:center;gap:10px}
.dot{width:9px;height:9px;border-radius:50%;background:var(--mint);box-shadow:0 0 0 0 rgba(0,230,176,.6);animation:pulse 2.4s ease-out infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(0,230,176,.55)}70%{box-shadow:0 0 0 10px rgba(0,230,176,0)}100%{box-shadow:0 0 0 0 rgba(0,230,176,0)}}
.contact-form{display:flex;flex-direction:column;gap:18px}
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-size:.82rem;letter-spacing:.05em;color:var(--muted);font-family:'Space Grotesk',sans-serif}
.field input,.field textarea{background:rgba(4,5,13,.6);border:1px solid var(--line);border-radius:12px;padding:15px 16px;color:var(--ink);font-family:'Sora',sans-serif;font-size:1rem;resize:vertical;transition:border-color .3s,background .3s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--blue);background:rgba(4,5,13,.85)}
.field input::placeholder,.field textarea::placeholder{color:var(--faint)}
.hidden-field{display:none}

/* ---------- Footer ---------- */
.footer{padding:80px clamp(20px,6vw,80px) 50px;border-top:1px solid var(--line);color:var(--muted);max-width:var(--maxw);margin:0 auto}
.footer-cta{text-align:center;padding-bottom:64px;border-bottom:1px solid var(--line)}
.footer-kicker{display:inline-flex;align-items:center;gap:10px;font-family:'Space Grotesk',sans-serif;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);margin-bottom:22px}
.footer-bigmail{display:inline-block;font-family:'Space Grotesk',sans-serif;font-weight:700;letter-spacing:-.02em;font-size:clamp(1.6rem,6vw,4rem);color:var(--ink);text-decoration:none;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;background-size:200% 200%;transition:opacity .3s;will-change:transform}
.footer-bigmail:hover{opacity:.85}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;padding-top:32px}
.footer-brand{display:inline-flex;align-items:center;gap:10px;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:1.05rem;color:var(--ink)}
.footer-time{font-family:'Space Grotesk',sans-serif;font-size:.84rem;color:var(--faint);letter-spacing:.04em}
.footer-time span{color:var(--mint)}
.footer-copy{color:var(--faint);font-size:.84rem;margin:0}

/* ---------- Scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}

@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .line-reveal>span{transform:none!important}
  .hero-cta.line-reveal{opacity:1!important}
  .marquee-track,.bchip,.fit-ring,.hero-title .accent,.loader-name,.scroll-hint span,.nebula,.shot-stack .shot-float,.dot{animation:none}
  .shot-stack .shot-float{transform:translateZ(45px)}
}

/* ---------- Responsive ---------- */
@media (max-width:920px){
  .nav-links{display:none}
  .nav-toggle{display:flex}
  .about-cols{grid-template-columns:1fr;gap:28px}
  .process-grid{grid-template-columns:1fr 1fr}
  .step{padding:28px 22px;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
  .step:nth-child(2n){border-right:0}
  .offer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:12px}
  .contact-grid{grid-template-columns:1fr;gap:32px}
  .case-row,.case-row.alt{grid-template-columns:1fr;gap:24px;padding:48px 0}
  .case-row.alt .case-media,.case-row.alt .case-info{order:initial}
  .case-index{font-size:2.4rem}
  .case-media{min-height:0;order:-1}
  section{padding:96px clamp(20px,6vw,80px)}
}
@media (max-width:560px){
  body{cursor:auto!important}
  .cursor-dot,.cursor-ring{display:none}
  .hero{padding-top:120px}
  .hero-cta{flex-direction:column;align-items:stretch}
  .hero-cta .btn{width:100%}
  .hero-stats{gap:18px}
  .hero-stats>div{flex:1 1 100%;padding-right:0}
  section{padding:76px 20px}
  .brand-name{display:none}
  .loader-count{right:5vw;bottom:5vh}
  .process-grid{grid-template-columns:1fr}
  .step{border-right:0}
  .step:nth-child(2n){border-right:0}
}
