/* Mothership Graphics, cosmic cinematic */
:root{
  --bg:#05060A;
  --bg-2:#0A0C14;
  --ink:#F2F4F8;
  --muted:#9AA3B2;
  --dim:#6E7689;
  --violet:#6E4BFF;
  --blue:#2E7BFF;
  --grad:linear-gradient(135deg,#6E4BFF,#2E7BFF);
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.14);
  --glow:0 0 40px rgba(110,75,255,.35);
  --maxw:1320px;
  --pad:clamp(20px,5vw,64px);
  --display:"Space Grotesk",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:"Inter",system-ui,sans-serif;font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3{font-family:var(--display);font-weight:600;line-height:1.05;text-wrap:balance;margin:0}
p{text-wrap:pretty}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:var(--violet);color:#fff}
code{font-family:var(--mono);font-size:.85em;color:var(--blue);background:rgba(46,123,255,.1);padding:.1em .4em;border-radius:5px}

/* Backdrop */
#starfield{display:none}
.bg-scrub{position:fixed;inset:0;width:100%;height:100%;object-fit:cover;z-index:-3;background:#05060A;pointer-events:none;filter:brightness(.5) saturate(1.05)}
.nebula{position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(60% 50% at 70% 12%,rgba(110,75,255,.20),transparent 70%),
    radial-gradient(50% 45% at 18% 30%,rgba(46,123,255,.16),transparent 70%),
    radial-gradient(80% 60% at 50% 110%,rgba(110,75,255,.12),transparent 70%);}

.container{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}

/* Nav */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:18px var(--pad);transition:background .3s,border-color .3s,padding .3s;border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(5,6,10,.72);backdrop-filter:blur(14px);border-bottom-color:var(--line);padding-top:12px;padding-bottom:12px}
.brand{display:flex;align-items:center;gap:11px}
.mark{width:34px;height:34px;filter:drop-shadow(0 0 10px rgba(110,75,255,.5))}
.brand-word{font-family:"Michroma",var(--display);font-weight:400;letter-spacing:.14em;font-size:13px}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{color:var(--muted);font-size:14.5px;font-weight:500;transition:color .2s}
.nav-links a:hover{color:var(--ink)}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:600;font-size:15px;padding:13px 26px;border-radius:100px;cursor:pointer;border:1px solid transparent;transition:transform .18s,box-shadow .25s,background .2s,border-color .2s;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--grad);color:#fff;box-shadow:var(--glow)}
.btn-primary:hover{box-shadow:0 0 56px rgba(110,75,255,.6);transform:translateY(-2px)}
.btn-ghost{background:rgba(255,255,255,.03);color:var(--ink);border-color:var(--line-2)}
.btn-ghost:hover{border-color:var(--blue);background:rgba(46,123,255,.08)}

/* Hero */
.hero{position:relative;text-align:center;overflow:hidden;padding:0 var(--pad)}
.hero-title-block{position:relative;z-index:2;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center}
.hero-detail{position:relative;z-index:2;max-width:820px;margin:0 auto;padding:8vh 0 100px;display:flex;flex-direction:column;align-items:center}
.ufo-hero-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;display:block;pointer-events:none}
.hero-tag{text-shadow:0 2px 14px rgba(0,0,0,.7)}
.hero-tag{display:inline-block;font-family:var(--mono);font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--blue);padding:8px 18px;border:1px solid rgba(46,123,255,.32);border-radius:999px;background:rgba(5,6,10,.5);margin-bottom:30px}
.wordmark{font-family:"Michroma",var(--display);font-weight:400;letter-spacing:.012em;font-size:clamp(22px,6.2vw,84px);line-height:1;display:flex;flex-direction:column;align-items:center;background:linear-gradient(180deg,#ffffff 0%,#e2e7fa 32%,#9aa6ea 58%,#6E4BFF 84%,#2E7BFF 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 0 46px rgba(110,75,255,.5))}
.wordmark-sub{font-family:"Michroma",var(--display);font-size:.34em;letter-spacing:.26em;font-weight:400;color:#dbe2fb;-webkit-text-fill-color:#dbe2fb;margin-top:.5em;padding-left:.26em;text-shadow:0 2px 14px rgba(0,0,0,.55),0 0 22px rgba(110,75,255,.28)}
.logo-lockup{display:flex;flex-direction:column;align-items:center}
.logo-mark{width:clamp(50px,6vw,78px);height:auto;margin-bottom:26px;filter:drop-shadow(0 0 20px rgba(110,75,255,.6))}
.light-streak{position:relative;width:min(560px,82vw);height:2px;margin:32px 0 26px;border-radius:2px;background:linear-gradient(90deg,transparent,rgba(110,75,255,.25) 18%,#2E7BFF 50%,rgba(110,75,255,.25) 82%,transparent)}
.light-streak::after{content:"";position:absolute;top:50%;left:0;width:72px;height:4px;transform:translate(-30px,-50%);background:linear-gradient(90deg,transparent,#fff,transparent);filter:blur(1px);box-shadow:0 0 22px 5px rgba(46,123,255,.85);animation:streak 3.4s ease-in-out infinite}
@keyframes streak{0%{left:-6%}50%{left:106%}100%{left:-6%}}
.tagline{font-family:"Michroma",var(--display);font-size:clamp(12px,1.7vw,19px);font-weight:400;margin:0;letter-spacing:.16em;text-transform:uppercase;color:#eef1fb;-webkit-text-fill-color:#eef1fb;text-shadow:0 2px 5px rgba(0,0,0,.92),0 0 22px rgba(0,0,0,.7)}
.tagline span{color:#fff;-webkit-text-fill-color:#fff;text-shadow:0 2px 5px rgba(0,0,0,.92),0 0 16px rgba(255,255,255,.45)}
.hero-copy{color:#cfd5e6;font-size:clamp(16px,1.4vw,19px);max-width:640px;margin:0 auto;text-shadow:0 2px 18px rgba(0,0,0,.9)}
.award-row{margin-top:30px;display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.award-pill{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);padding:9px 16px;background:rgba(110,75,255,.12);border:1px solid rgba(110,75,255,.32);border-radius:999px;backdrop-filter:blur(8px)}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:34px}
.services{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:56px auto 0;max-width:1000px}
.service{background:rgba(5,6,10,.7);border:1px solid var(--line);border-radius:14px;padding:20px 16px;text-align:center;backdrop-filter:blur(10px);font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.service strong{display:block;font-family:var(--display);font-weight:700;font-size:14px;color:var(--ink);letter-spacing:.04em;margin-bottom:6px;text-transform:none}
.scroll-hint{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);width:26px;height:42px;border:1.5px solid var(--line-2);border-radius:100px;display:flex;justify-content:center;padding-top:8px;z-index:2}
.scroll-hint span{width:4px;height:8px;border-radius:4px;background:var(--blue);animation:scroll 1.6s ease-in-out infinite}
@keyframes scroll{0%{opacity:0;transform:translateY(0)}40%{opacity:1}100%{opacity:0;transform:translateY(14px)}}

/* Conversion */
.hero-value{font-family:"Inter",sans-serif;color:#dfe4f7;font-size:clamp(15px,1.7vw,20px);max-width:560px;margin:26px auto 0;line-height:1.5;text-shadow:0 2px 18px rgba(0,0,0,.9)}
.hero-cta-top{margin-top:24px}
.hero-reassure{font-family:var(--mono);font-size:12px;letter-spacing:.05em;color:var(--muted);margin:16px 0 0;text-shadow:0 2px 14px rgba(0,0,0,.85)}
.trust{padding:44px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:rgba(5,6,10,.45);backdrop-filter:blur(6px)}
.trust .container{display:flex;flex-direction:column;align-items:center;gap:18px}
.trust-label{font-family:var(--mono);font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--blue);margin:0}
.trust-logos{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 32px}
.trust-logos span{font-family:var(--display);font-weight:600;font-size:clamp(14px,1.6vw,19px);letter-spacing:.03em;color:#aeb6cf;text-transform:uppercase;opacity:.82;transition:opacity .2s,color .2s}
.trust-logos span:hover{opacity:1;color:var(--ink)}
.cta-band{max-width:var(--maxw);margin:0 auto;padding:clamp(40px,7vw,90px) var(--pad)}
.cta-band-inner{border:1px solid var(--line-2);border-radius:24px;background:radial-gradient(130% 130% at 50% 0%,rgba(110,75,255,.16),rgba(10,12,20,.72) 70%);padding:clamp(34px,6vw,64px);text-align:center;backdrop-filter:blur(10px)}
.cta-band-inner h2{margin-bottom:14px}
.cta-band-inner p{color:var(--muted);font-size:18px;margin:0 auto 28px;max-width:560px}
.cta-band-inner .hero-cta{justify-content:center;margin-top:0}

/* CSS fallback saucer (shown until/unless WebGL hero mounts) */
.hero-ufo-css{position:absolute;top:30%;left:50%;transform:translate(-50%,-50%);z-index:1;width:320px;height:160px;pointer-events:none;animation:hover 6s ease-in-out infinite}
.hero-ufo-css .saucer{position:absolute;top:40px;left:50%;transform:translateX(-50%);width:300px;height:74px;border-radius:50%;background:radial-gradient(60% 120% at 50% 18%,#eaf0ff 0%,#9fb0e8 26%,#5b5f9c 52%,#1b1838 100%);box-shadow:0 0 60px rgba(110,75,255,.5),inset 0 -10px 30px rgba(0,0,0,.6)}
.hero-ufo-css .saucer::before{content:"";position:absolute;top:-26px;left:50%;transform:translateX(-50%);width:120px;height:80px;border-radius:50%;background:radial-gradient(50% 60% at 42% 32%,rgba(216,244,255,.95),rgba(46,123,255,.5) 55%,rgba(10,24,40,.7));box-shadow:0 0 30px rgba(46,123,255,.55)}
.hero-ufo-css .saucer::after{content:"";position:absolute;bottom:6px;left:50%;transform:translateX(-50%);width:240px;height:14px;border-radius:50%;background:radial-gradient(closest-side,rgba(110,75,255,.9),transparent);filter:blur(2px);animation:blink 1.6s ease-in-out infinite}
.hero-ufo-css .saucer-beam{position:absolute;top:104px;left:50%;transform:translateX(-50%);width:120px;height:150px;clip-path:polygon(34% 0,66% 0,100% 100%,0 100%);background:linear-gradient(180deg,rgba(110,75,255,.4),transparent);animation:blink 2.6s ease-in-out infinite}
@keyframes hover{0%,100%{transform:translate(-50%,-50%)}50%{transform:translate(-50%,calc(-50% - 16px))}}
@keyframes blink{0%,100%{opacity:.45}50%{opacity:.9}}
body.webgl-ok .hero-ufo-css{display:none}

/* Sections */
.section{position:relative;padding:clamp(80px,12vh,130px) 0}
.section .container{padding:0 var(--pad)}
.section-head{max-width:760px;margin-bottom:48px}
.kicker{font-family:var(--mono);color:var(--blue);font-weight:600;letter-spacing:.2em;text-transform:uppercase;font-size:12px;margin:0 0 16px}
.h-2{font-size:clamp(28px,4.4vw,50px);letter-spacing:.005em}
.section-head .sub{color:var(--muted);margin-top:16px;font-size:18px}

/* Portfolio categories */
.cat{padding:clamp(50px,7vh,80px) 0}
.category-header{max-width:820px;margin-bottom:36px}
.category-num{display:none}
.category-header h2{font-size:clamp(26px,3.6vw,44px)}
.category-header p{color:var(--muted);font-size:16px;line-height:1.6;margin-top:14px;max-width:700px}
.mgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media (max-width:1100px){.mgrid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.mgrid{grid-template-columns:1fr}}
.mtile{position:relative;display:block;aspect-ratio:16/9;border-radius:14px;overflow:hidden;background:#070a12;border:1px solid var(--line);cursor:pointer;transition:transform .3s,border-color .3s,box-shadow .3s}
.mtile:hover{transform:translateY(-4px);border-color:rgba(110,75,255,.55);box-shadow:0 20px 60px rgba(0,0,0,.5),0 0 32px rgba(110,75,255,.18)}
.mtile-thumb{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .5s}
.mtile:hover .mtile-thumb{transform:scale(1.05)}
.mtile-thumb::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 30%,rgba(0,0,0,.85) 100%)}
.mtile-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:54px;height:54px;border-radius:50%;border:1.5px solid rgba(255,255,255,.55);backdrop-filter:blur(4px);z-index:2;transition:transform .3s,background .3s}
.mtile-play::after{content:"";position:absolute;top:50%;left:54%;transform:translate(-50%,-50%);border-left:13px solid #fff;border-top:8px solid transparent;border-bottom:8px solid transparent}
.mtile:hover .mtile-play{transform:translate(-50%,-50%) scale(1.12);background:rgba(110,75,255,.32)}
.mtile-meta{position:absolute;bottom:14px;left:18px;right:18px;z-index:2}
.mtile-title{font-family:var(--display);font-weight:600;font-size:16px;color:var(--ink);text-shadow:0 2px 12px rgba(0,0,0,.85);margin-bottom:4px}
.mtile-platform{display:none}

/* Lightbox */
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(5,6,10,.94);backdrop-filter:blur(14px);display:none;align-items:center;justify-content:center;padding:40px}
.lightbox.is-open{display:flex}
.lightbox-frame{position:relative;width:100%;max-width:1280px;aspect-ratio:16/9;background:#000;border-radius:14px;overflow:hidden;box-shadow:0 30px 100px rgba(0,0,0,.7)}
.lightbox-frame #lightbox-slot,.lightbox-frame iframe{width:100%;height:100%;display:block;border:0}
.lightbox-close{position:absolute;top:-52px;right:0;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid var(--line-2);color:var(--ink);font-family:var(--display);font-size:22px;cursor:pointer;transition:all .2s}
.lightbox-close:hover{background:var(--violet);color:#fff;border-color:var(--violet)}
.lightbox-external{position:absolute;left:50%;transform:translateX(-50%);bottom:24px;font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);text-decoration:none;border:1px solid var(--line-2);border-radius:999px;padding:9px 18px;background:rgba(5,6,10,.6);transition:all .2s;z-index:201}
.lightbox-external[hidden]{display:none}
.lightbox-external:hover{color:#fff;border-color:var(--violet);background:rgba(110,75,255,.3)}

/* Capabilities */
.cap-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.cap{background:var(--bg-2);border:1px solid var(--line);border-radius:16px;padding:28px;transition:border-color .3s,transform .3s}
.cap:hover{border-color:var(--violet);transform:translateY(-4px)}
.cap h3{font-size:19px;margin-bottom:10px}
.cap p{color:var(--muted);font-size:15.5px;margin:0}
.speed-banner{margin-top:30px;border:1px solid var(--line);border-radius:20px;padding:clamp(34px,6vw,64px);text-align:center;background:radial-gradient(120% 140% at 50% 0%,rgba(110,75,255,.14),transparent 70%)}
.speed-banner p{margin:0;font-family:var(--display);color:var(--ink);font-weight:600;font-size:clamp(22px,3.4vw,36px);line-height:1.3}
.speed-banner .big{margin-top:6px}
.speed-banner .big span{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* Process */
.steps{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.step{background:var(--bg-2);border:1px solid var(--line);border-radius:16px;padding:28px}
.step .num{font-family:var(--display);font-size:13px;font-weight:600;color:var(--blue);letter-spacing:.1em}
.step h3{font-size:20px;margin:14px 0 10px}
.step p{color:var(--muted);font-size:15px;margin:0}

/* About */
.about-inner{max-width:760px}
.about-inner h2{margin-bottom:22px}
.about-inner p{color:var(--muted);font-size:18px;margin:0 0 18px}

/* Start */
.start-form{max-width:760px;background:var(--bg-2);border:1px solid var(--line);border-radius:20px;padding:clamp(24px,4vw,40px);display:flex;flex-direction:column;gap:18px}
.start-form .row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.start-form label{display:flex;flex-direction:column;gap:8px;font-size:14px;font-weight:500;color:var(--muted)}
.start-form input,.start-form select,.start-form textarea{font-family:inherit;font-size:15px;color:var(--ink);background:rgba(255,255,255,.03);border:1px solid var(--line-2);border-radius:10px;padding:13px 14px;transition:border-color .2s}
.start-form input:focus,.start-form select:focus,.start-form textarea:focus{outline:none;border-color:var(--violet);box-shadow:0 0 0 3px rgba(110,75,255,.18)}
.start-form textarea{resize:vertical}
.form-actions{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-top:6px}
.full-brief-link{display:inline-block;margin-top:18px;font-family:var(--mono);font-size:13px;letter-spacing:.08em;color:var(--blue);border-bottom:1px solid rgba(46,123,255,.4);padding-bottom:2px;transition:color .2s,border-color .2s}
.full-brief-link:hover{color:var(--ink);border-color:var(--ink)}
.start-cta{margin-top:6px}
.read-panel{background:rgba(8,10,18,.5);backdrop-filter:blur(9px);-webkit-backdrop-filter:blur(9px);border:1px solid var(--line);border-radius:22px;padding:clamp(28px,5vw,52px);box-shadow:0 24px 70px rgba(0,0,0,.35)}
.about .about-inner.read-panel{max-width:820px}
.start .start-panel{max-width:760px;margin:0 auto;text-align:center}
.start .start-cta{display:flex;justify-content:center}

/* Footer */
.footer{max-width:var(--maxw);margin:0 auto;padding:60px var(--pad) 50px;display:flex;flex-direction:column;align-items:center;gap:18px;text-align:center}
.footer-brand{display:flex;align-items:center;gap:11px}
.footer-mail{font-family:var(--display);font-size:clamp(20px,3vw,30px);font-weight:500;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.footer-social{display:flex;gap:24px}
.footer-social a{color:var(--muted);font-size:14px;transition:color .2s}
.footer-social a:hover{color:var(--ink)}
.copy{color:#5a6273;font-size:13px;margin:8px 0 0}

/* Reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--blue);outline-offset:3px}

/* Responsive */
@media (max-width:900px){
  .cap-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .services{grid-template-columns:repeat(2,1fr)}
  .nav-links{gap:16px}
  .nav-links a:not(.btn){display:none}
}
@media (max-width:560px){
  .cap-grid,.steps,.services{grid-template-columns:1fr}
  .start-form .row{grid-template-columns:1fr}
}

@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
  .scroll-hint span,.light-streak::after,.hero-ufo-css,.hero-ufo-css .saucer::after,.hero-ufo-css .saucer-beam{animation:none}
}
