/* ───────────────────────────  RESET / BASE  ─────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
:root{
  --bg:#000;
  --fg:#fff;
  --mute:#9a9a9a;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.16);
  --silver: linear-gradient(135deg,#ffffff 0%,#ededed 25%,#d4d4d4 50%,#ededed 75%,#ffffff 100%);
  --silver-soft: linear-gradient(180deg,#fafafa 0%,#dcdcdc 45%,#bdbdbd 55%,#f0f0f0 100%);
  --chrome-conic: conic-gradient(from 210deg at 50% 50%,
    #ffffff 0deg,#8a8a8a 60deg,#ffffff 120deg,#3d3d3d 180deg,
    #f0f0f0 240deg,#646464 300deg,#ffffff 360deg);
  --ease:cubic-bezier(.2,.7,.2,1);
}
html,body{background:var(--bg);color:var(--fg);font-family:'Inter',system-ui,-apple-system,'Segoe UI',sans-serif;font-feature-settings:'ss01','ss02','cv11';-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
body{cursor:none}
a{color:inherit;text-decoration:none}
img,svg,video{display:block;max-width:100%}
button{font:inherit;color:inherit;background:none;border:0;cursor:none}
em,.italic{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;letter-spacing:.005em}
::selection{background:#fff;color:#000}

/* ───────────────────────────  GLOBAL DECOR  ─────────────────────────── */
.grain{position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.06;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 .55 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>")}

.cursor,.cursor-dot{position:fixed;top:0;left:0;pointer-events:none;z-index:9999;border-radius:50%;transform:translate(-50%,-50%);transition:width .25s var(--ease),height .25s var(--ease),opacity .25s,background .25s}
.cursor{width:32px;height:32px;border:1px solid rgba(255,255,255,.55);backdrop-filter:invert(1) hue-rotate(180deg);mix-blend-mode:difference}
.cursor-dot{width:5px;height:5px;background:#fff}
.cursor.is-link{width:64px;height:64px;border-color:rgba(255,255,255,.9);background:rgba(255,255,255,.06)}
@media (hover:none){body{cursor:auto}.cursor,.cursor-dot{display:none}}

.scroll-bar{position:fixed;top:0;left:0;height:2px;width:0;z-index:9998;background:var(--silver);box-shadow:0 0 12px rgba(255,255,255,.3)}

/* ───────────────────────────  NAV  ─────────────────────────── */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:18px 28px;background:linear-gradient(to bottom,rgba(0,0,0,.6),rgba(0,0,0,0));backdrop-filter:blur(0px);transition:backdrop-filter .4s,background .4s,padding .4s var(--ease)}
.nav.scrolled{backdrop-filter:blur(14px) saturate(140%);background:rgba(0,0,0,.55);border-bottom:1px solid var(--line);padding:12px 28px}
.brand{display:flex;align-items:center;gap:10px}
.brand-logo{height:40px;width:auto;display:block;filter:drop-shadow(0 0 14px rgba(255,255,255,.18))}
.nav.scrolled .brand-logo{height:32px;transition:height .4s var(--ease)}
.brand-word{font-weight:800;letter-spacing:.32em;font-size:13px;background:var(--silver);background-size:200% 200%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:shimmer 18s linear infinite}
.foot-logo{height:48px;width:auto;display:block;filter:drop-shadow(0 0 24px rgba(255,255,255,.18))}
@keyframes shimmer{0%{background-position:0% 50%}100%{background-position:-200% 50%}}
.nav-links{display:flex;gap:28px;font-size:13px;color:var(--mute)}
.nav-links a{position:relative;padding:6px 0;transition:color .3s}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:#fff;transform:scaleX(0);transform-origin:right;transition:transform .4s var(--ease)}
.nav-links a:hover{color:#fff}
.nav-links a:hover::after{transform:scaleX(1);transform-origin:left}
.nav-cta{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;font-weight:500;padding:9px 16px;border:1px solid var(--line-2);border-radius:999px;background:rgba(255,255,255,.02);transition:background .3s,border-color .3s,transform .3s}
.nav-cta:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.4)}
@media (max-width:780px){.nav-links{display:none}.nav{padding:14px 18px}}

/* ───────────────────────────  HERO  ─────────────────────────── */
.hero{position:relative;height:100svh;min-height:640px;padding:120px 28px 80px;display:flex;flex-direction:column;justify-content:center;overflow:hidden}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:.95;filter:contrast(1.05) saturate(.9) brightness(.95)}
.hero-vignette{position:absolute;inset:0;z-index:1;pointer-events:none;background:
  radial-gradient(ellipse at 50% 50%,rgba(0,0,0,0) 0%,rgba(0,0,0,.18) 75%,rgba(0,0,0,.6) 100%),
  linear-gradient(to right,rgba(0,0,0,.55) 0%,rgba(0,0,0,.15) 35%,rgba(0,0,0,0) 60%),
  linear-gradient(to bottom,rgba(0,0,0,.35) 0%,rgba(0,0,0,0) 30%,rgba(0,0,0,0) 70%,rgba(0,0,0,.6) 100%)}
.hero-orb{position:absolute;top:50%;left:50%;width:min(120vmin,900px);aspect-ratio:1;transform:translate(-50%,-50%);background:var(--chrome-conic);border-radius:50%;filter:blur(80px) saturate(110%);opacity:.18;mix-blend-mode:screen;animation:spin 40s linear infinite;z-index:1}
.hero-orb::after{content:"";position:absolute;inset:8%;border-radius:50%;background:radial-gradient(circle at 30% 30%,#fff 0%,rgba(255,255,255,0) 55%);mix-blend-mode:screen;opacity:.4}
.hero-glow{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 90%,rgba(255,255,255,.18),rgba(0,0,0,0) 60%),radial-gradient(ellipse at 10% 20%,rgba(255,255,255,.06),rgba(0,0,0,0) 50%);z-index:1;pointer-events:none}
@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg)}}

.hero-meta{position:relative;z-index:2;display:inline-flex;align-items:center;gap:10px;font-size:11.5px;color:var(--mute);letter-spacing:.18em;text-transform:uppercase;margin-bottom:22px;text-shadow:0 1px 12px rgba(0,0,0,.6)}
.hero-meta .dot{width:7px;height:7px;border-radius:50%;background:#fff;box-shadow:0 0 10px #fff;animation:pulse 2s ease-in-out infinite}
@keyframes pulse{50%{opacity:.4;transform:scale(.8)}}

.hero-title{position:relative;z-index:2;font-size:clamp(40px,7.2vw,108px);line-height:.96;letter-spacing:-.03em;font-weight:700;margin-bottom:24px;filter:drop-shadow(0 4px 30px rgba(0,0,0,.55))}
.hero-title .line{display:block;overflow:hidden}
.hero-title .word{display:inline-block;background:var(--silver);background-size:200% 200%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:shimmer 24s linear infinite}
.hero-title .italic .word{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;letter-spacing:-.005em}

.hero-sub{position:relative;z-index:2;max-width:520px;font-size:clamp(14px,1.2vw,16.5px);line-height:1.55;color:rgba(255,255,255,.85);margin-bottom:28px;text-shadow:0 1px 16px rgba(0,0,0,.6)}

.hero-actions{position:relative;z-index:2;display:flex;gap:14px;flex-wrap:wrap}

.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 26px;border-radius:999px;font-size:14px;font-weight:500;letter-spacing:.01em;transition:transform .4s var(--ease),background .3s,color .3s,border-color .3s,box-shadow .4s;will-change:transform}
.btn.primary{background:var(--silver-soft);color:#0a0a0a;font-weight:700;letter-spacing:.04em;box-shadow:0 0 0 1px rgba(255,255,255,.25),0 10px 40px -10px rgba(255,255,255,.35),inset 0 1px 0 rgba(255,255,255,.95),inset 0 -1px 0 rgba(0,0,0,.15)}
.btn.primary:hover{box-shadow:0 0 0 1px rgba(255,255,255,.5),0 18px 60px -10px rgba(255,255,255,.55),inset 0 1px 0 rgba(255,255,255,.9)}
.btn.ghost{border:1px solid var(--line-2);color:#fff;background:rgba(255,255,255,.02)}
.btn.ghost:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.5)}

.hero-scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--mute);z-index:2;animation:float 3s ease-in-out infinite}
@keyframes float{50%{transform:translate(-50%,8px)}}

/* ───────────────────────────  MARQUEE STRIP  ─────────────────────────── */
.marquee-strip{position:relative;border-block:1px solid var(--line);padding:22px 0;overflow:hidden;background:radial-gradient(ellipse at 50% 0,rgba(255,255,255,.04),transparent 70%)}
.marquee-track{display:flex;gap:48px;width:max-content;animation:marq 40s linear infinite;font-size:14px;letter-spacing:.18em;text-transform:uppercase}
.marquee-track span{display:inline-flex;align-items:center;gap:48px;background:var(--silver);background-size:200% 200%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:shimmer 22s linear infinite}
@keyframes marq{to{transform:translateX(-50%)}}

/* ───────────────────────────  MANIFESTO  ─────────────────────────── */
.manifesto{padding:140px 28px;max-width:1280px;margin:0 auto;position:relative}
.eyebrow{font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--mute);margin-bottom:28px}
.eyebrow.center{text-align:center}
.manifesto-text{font-size:clamp(30px,4.8vw,72px);line-height:1.05;letter-spacing:-.02em;font-weight:600;max-width:1180px;text-wrap:balance}
.manifesto-text .reveal-line{display:block;overflow:hidden;white-space:nowrap}
@media (max-width:900px){.manifesto-text .reveal-line{white-space:normal}}
.manifesto-text .reveal-line span{display:inline-block}
.manifesto-text .italic{color:rgba(255,255,255,.55)}
.manifesto-meta{margin-top:90px;display:grid;grid-template-columns:repeat(4,1fr);gap:24px;border-top:1px solid var(--line);padding-top:40px}
.manifesto-meta>div{display:flex;flex-direction:column;gap:6px}
.manifesto-meta .num{font-size:clamp(40px,5vw,72px);line-height:1;letter-spacing:-.03em;font-weight:600;background:var(--silver);background-size:200% 200%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:shimmer 28s linear infinite}
.manifesto-meta .lbl{font-size:12px;color:var(--mute);letter-spacing:.14em;text-transform:uppercase}
@media (max-width:780px){.manifesto-meta{grid-template-columns:repeat(2,1fr)}}

/* ───────────────────────────  CAPABILITIES  ─────────────────────────── */
.caps{padding:140px 28px;max-width:1280px;margin:0 auto}
.caps-head{margin-bottom:64px}
.caps-head h2{font-size:clamp(40px,7vw,108px);line-height:.95;letter-spacing:-.03em;font-weight:600}
.caps-head h2 em{color:rgba(255,255,255,.55)}
.caps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.cap{padding:40px;background:#000;position:relative;transition:background .4s var(--ease)}
.cap::before{content:"";position:absolute;inset:0;background:radial-gradient(600px circle at var(--mx,50%) var(--my,50%),rgba(255,255,255,.06),transparent 40%);opacity:0;transition:opacity .4s;pointer-events:none}
.cap:hover::before{opacity:1}
.cap:hover{background:#0a0a0a}
.cap-num{display:inline-block;font-size:11px;letter-spacing:.32em;color:var(--mute);margin-bottom:24px}
.cap h3{font-size:22px;font-weight:500;margin-bottom:14px;letter-spacing:-.01em}
.cap p{font-size:14.5px;line-height:1.6;color:rgba(255,255,255,.62)}
@media (max-width:1000px){.caps-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.caps-grid{grid-template-columns:1fr}}


/* ───────────────────────────  LOGOS / CLIENTS  ─────────────────────────── */
.logos{padding:90px 0;border-block:1px solid var(--line);background:radial-gradient(ellipse at 50% 50%,rgba(255,255,255,.03),transparent 70%)}
.logos .eyebrow{margin-bottom:36px}
.logo-marquee{overflow:hidden}
.logo-track{display:flex;gap:80px;width:max-content;animation:marq 50s linear infinite}
.logo-track span{font-size:clamp(28px,4vw,52px);font-weight:600;letter-spacing:.06em;color:rgba(255,255,255,.45);transition:color .3s}
.logo-track span:hover{color:#fff}

/* ───────────────────────────  CONTACT  ─────────────────────────── */
.contact{position:relative;padding:160px 28px;max-width:880px;margin:0 auto;text-align:center;overflow:hidden}
.contact-orb{position:absolute;top:50%;left:50%;width:min(80vmin,700px);aspect-ratio:1;transform:translate(-50%,-50%);background:var(--chrome-conic);border-radius:50%;filter:blur(80px);opacity:.35;animation:spin 60s linear infinite reverse;z-index:0;pointer-events:none}
.contact>*{position:relative;z-index:1}
.contact-title{font-size:clamp(44px,8vw,128px);line-height:.96;letter-spacing:-.03em;font-weight:600;margin-bottom:18px}
.contact-title em{color:rgba(255,255,255,.6)}
.contact-sub{color:rgba(255,255,255,.7);font-size:16px;margin-bottom:48px;max-width:520px;margin-inline:auto}
.contact-form{display:grid;grid-template-columns:1fr 1fr;gap:14px;text-align:left}
.contact-form label{display:flex;flex-direction:column;gap:8px;position:relative}
.contact-form label.full{grid-column:span 2}
.contact-form label>span{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--mute)}
.contact-form input,.contact-form textarea{font:inherit;color:#fff;background:rgba(255,255,255,.02);border:1px solid var(--line-2);border-radius:10px;padding:14px 16px;font-size:15px;outline:none;transition:border-color .3s,background .3s,box-shadow .3s;cursor:none;font-family:inherit}
.contact-form input:focus,.contact-form textarea:focus{border-color:rgba(255,255,255,.6);background:rgba(255,255,255,.05);box-shadow:0 0 0 4px rgba(255,255,255,.05)}
.contact-form textarea{resize:vertical;min-height:120px}
.contact-form button{grid-column:span 2;justify-self:center;margin-top:14px}
.contact-form .lbl-sent{display:none}
.contact-form.sent .lbl-default{display:none}
.contact-form.sent .lbl-sent{display:inline}
.contact-form.sent input,.contact-form.sent textarea{opacity:.5;pointer-events:none}
@media (max-width:640px){.contact-form{grid-template-columns:1fr}.contact-form label.full,.contact-form button{grid-column:span 1}}

/* ───────────────────────────  FOOTER  ─────────────────────────── */
.footer{position:relative;border-top:1px solid var(--line);padding:80px 28px 40px;overflow:hidden}
.foot-top{display:grid;grid-template-columns:1.3fr 2fr;gap:40px;max-width:1280px;margin:0 auto;padding-bottom:60px}
.foot-brand p{color:var(--mute);max-width:320px;margin-top:16px}
.foot-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.foot-cols h4{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--mute);margin-bottom:16px;font-weight:500}
.foot-cols a{display:block;padding:5px 0;color:rgba(255,255,255,.78);font-size:14px;transition:color .3s,transform .3s}
.foot-cols a:hover{color:#fff;transform:translateX(4px)}
.foot-bot{display:flex;justify-content:space-between;align-items:center;max-width:1280px;margin:0 auto;padding:24px 0;border-top:1px solid var(--line);font-size:12px;color:var(--mute);letter-spacing:.06em}
.foot-mark{font-family:'Inter',sans-serif;font-weight:900;font-size:clamp(120px,28vw,520px);line-height:.78;letter-spacing:-.04em;text-align:center;background:var(--silver);background-size:200% 200%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:shimmer 18s linear infinite;margin-top:-30px;margin-bottom:-20px;user-select:none;pointer-events:none}
@media (max-width:780px){.foot-top{grid-template-columns:1fr}.foot-cols{grid-template-columns:repeat(2,1fr)}.foot-bot{flex-direction:column;gap:8px;text-align:center}}

/* ───────────────────────────  REVEAL  ─────────────────────────── */
.reveal,.reveal-word,.reveal-line span{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal-word,.reveal-line span{transform:translateY(110%)}
.is-in.reveal,.is-in .reveal-word,.is-in.reveal-line span{opacity:1;transform:translateY(0)}
/* stagger words */
.is-in .reveal-word:nth-child(1){transition-delay:.05s}
.is-in .reveal-word:nth-child(2){transition-delay:.15s}
.is-in .reveal-word:nth-child(3){transition-delay:.25s}
.is-in .reveal-word:nth-child(4){transition-delay:.35s}

/* respect reduced motion */
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal,.reveal-word,.reveal-line span{opacity:1;transform:none}
}
