/* Milliard — official brand typeface */
@font-face{font-family:'Milliard';src:url('../fonts/milliard-book.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Milliard';src:url('../fonts/milliard-book-italic.woff2') format('woff2');font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:'Milliard';src:url('../fonts/milliard-medium.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Milliard';src:url('../fonts/milliard-semibold.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:'Milliard';src:url('../fonts/milliard-extrabold.woff2') format('woff2');font-weight:800;font-style:normal;font-display:swap}
@font-face{font-family:'Milliard';src:url('../fonts/milliard-black.woff2') format('woff2');font-weight:900;font-style:normal;font-display:swap}

:root{
  /* VSE brand */
  --bg:#212b54; --bg2:#26305c; --panel:#2b3663;
  --ink:#f4f6f9; --ink-dim:#a9b1cc; --line:rgba(255,255,255,.10);
  --accent:#6a9799; --accent2:#9fc4c5; --arc:rgba(255,255,255,.14);
  --display:'Milliard',system-ui,sans-serif;
  --body:'Milliard',system-ui,sans-serif;
  --serif:'Instrument Serif',Georgia,serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:var(--body);line-height:1.6;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1280px;margin:0 auto;padding:0 6vw}
::selection{background:var(--accent);color:#1b2040}

/* ---------- scroll progress ---------- */
#progress{position:fixed;top:0;left:0;height:2px;width:0;background:linear-gradient(90deg,var(--accent),var(--accent2));z-index:120}

/* ---------- preloader ---------- */
#loader{position:fixed;inset:0;z-index:300;background:var(--bg);display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:30px;overflow:hidden;transition:opacity .7s ease,visibility .7s}
#loader.done{opacity:0;visibility:hidden}
#loader img{height:70px;opacity:.9;animation:breathe 2s ease-in-out infinite}
@keyframes breathe{0%,100%{opacity:.45}50%{opacity:1}}
#loader .pct{font-family:var(--display);font-weight:700;font-size:.95rem;letter-spacing:.3em;color:var(--ink-dim)}

/* ---------- nav ---------- */
nav{position:fixed;inset:0 0 auto;z-index:100;display:flex;align-items:center;justify-content:space-between;
  padding:20px 5vw;mix-blend-mode:normal;transition:background .4s,border-color .4s;border-bottom:1px solid transparent}
nav.scrolled{background:rgba(33,43,84,.78);backdrop-filter:blur(16px);border-bottom-color:var(--line)}
nav .logo img{height:40px;width:auto}
nav ul{display:flex;gap:36px;list-style:none;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim)}
nav ul a{position:relative;padding:4px 0}
nav ul a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--accent);transition:width .3s}
nav ul a:hover{color:var(--ink)} nav ul a:hover::after{width:100%}
.cta-btn{position:relative;font-weight:600;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;
  color:#1b2040;background:var(--accent);padding:13px 28px;border-radius:100px;display:inline-block;overflow:hidden;transition:transform .3s,box-shadow .3s}
.cta-btn::after{content:"";position:absolute;top:0;left:-80%;width:50%;height:100%;transform:skewX(-20deg);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.45),transparent);transition:left .6s ease}
.cta-btn:hover{transform:translateY(-2px) scale(1.03);box-shadow:0 12px 44px rgba(106,151,153,.45)}
.cta-btn:hover::after{left:130%}
.ghost-btn{position:relative;overflow:hidden;z-index:0}
.ghost-btn::before{content:"";position:absolute;inset:0;z-index:-1;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .35s cubic-bezier(.2,.7,.2,1);border-radius:inherit}
.ghost-btn:hover::before{transform:scaleX(1)}
.ghost-btn:hover{color:#1b2040!important;border-color:var(--accent)}
@media(max-width:900px){nav ul{display:none}}

/* ---------- hero ---------- */
.hero{min-height:100svh;display:flex;align-items:flex-end;padding-bottom:10vh;position:relative;isolation:isolate;overflow:hidden}
#lights{position:absolute;inset:0;z-index:-1}
.hero .haze{position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(900px 500px at 30% 110%,rgba(127,178,180,.10),transparent 60%),
             radial-gradient(700px 420px at 85% 20%,rgba(255,255,255,.05),transparent 60%)}
/* brand swirl — concentric arcs, slow rotation */
.swirl{position:absolute;z-index:-1;pointer-events:none;opacity:.85}
.hero .swirl{right:-22vmin;top:50%;width:120vmin;height:120vmin;transform:translateY(-50%)}
.swirl svg{width:100%;height:100%;animation:spin 90s linear infinite}
.swirl .ring2{animation:spin 60s linear infinite reverse;transform-origin:center}
@keyframes spin{to{transform:rotate(360deg)}}
.kicker{display:inline-flex;align-items:center;gap:12px;font-size:.76rem;letter-spacing:.26em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:30px}
.kicker .live-dot{width:8px;height:8px;border-radius:50%;background:#ff3b3b;animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.2}}
h1{font-family:var(--display);font-weight:800;font-size:clamp(2.5rem,6.6vw,5.6rem);line-height:1.0;letter-spacing:-.015em;max-width:15ch}
.em{font-family:var(--serif);font-style:italic;font-weight:400;letter-spacing:0;
  background:linear-gradient(92deg,var(--accent),var(--accent2));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.lede{max-width:54ch;color:var(--ink-dim);font-size:clamp(1rem,1.35vw,1.15rem);margin:30px 0 40px}
.hero-ctas{display:flex;gap:18px;flex-wrap:wrap;align-items:center}
.ghost-btn{font-weight:600;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;padding:13px 28px;border-radius:100px;border:1px solid var(--line);color:var(--ink);transition:border-color .3s,color .3s,transform .3s}
.ghost-btn:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}
.cursor-hint{margin-top:34px;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-dim);opacity:.7}
.scroll-cue{position:absolute;right:5vw;bottom:5vh;font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-dim);
  writing-mode:vertical-rl;display:flex;align-items:center;gap:12px}
.scroll-cue::after{content:"";width:1px;height:46px;background:linear-gradient(var(--accent),transparent);animation:drop 1.8s ease-in-out infinite}
@keyframes drop{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---------- masked line reveal ---------- */
.line-mask{overflow:hidden;display:block}
.line-mask>span{display:block;transform:translateY(110%);transition:transform 1s cubic-bezier(.2,.7,.1,1)}
.in .line-mask>span{transform:none}
.d1>span{transition-delay:.08s}.d2>span{transition-delay:.18s}.d3>span{transition-delay:.28s}
.reveal{opacity:0;transform:translateY(30px);transition:opacity .9s ease,transform .9s cubic-bezier(.2,.7,.1,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .line-mask>span,.reveal{transform:none!important;opacity:1!important;transition:none!important}
  .marquee-track{animation:none!important}
}

/* ---------- studio statement ---------- */
.statement{padding:150px 0 120px}
.eyebrow{font-size:.76rem;letter-spacing:.26em;text-transform:uppercase;color:var(--accent);margin-bottom:28px;display:block}
h2.big{font-family:var(--display);font-weight:700;font-size:clamp(1.7rem,3.8vw,3.1rem);line-height:1.12;letter-spacing:-.01em;max-width:26ch}
.statement p.body{max-width:62ch;color:var(--ink-dim);margin-top:34px;font-size:1.05rem}
.stat-row{display:flex;gap:0;margin-top:70px;border-top:1px solid var(--line)}
.stat{flex:1;padding:36px 30px 0;border-left:1px solid var(--line);position:relative;transition:transform .35s}
.stat::before{content:"";position:absolute;top:-1px;left:0;height:2px;width:0;background:var(--accent);transition:width .45s cubic-bezier(.2,.7,.2,1)}
.stat:hover{transform:translateY(-6px)}
.stat:hover::before{width:100%}
.stat:first-child{border-left:none;padding-left:0}
.stat b{font-family:var(--display);font-weight:700;font-size:clamp(1.7rem,3vw,2.6rem);display:block;transition:color .35s}
.stat:hover b{color:var(--accent2)}
.stat b small{font-size:.55em;color:var(--accent)}
.stat span{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-dim)}
@media(max-width:800px){.stat-row{flex-direction:column}.stat{border-left:none;padding:26px 0 0}}

/* ---------- work / studios cards ---------- */
.work{padding:60px 0 140px}
.card{display:grid;grid-template-columns:1.15fr .85fr;gap:60px;align-items:end;margin-top:110px}
.card:nth-child(even){grid-template-columns:.85fr 1.15fr}
.card:nth-child(even) .card-img{order:2}
.card-img{position:relative;border-radius:18px;overflow:hidden;aspect-ratio:16/10;border:1px solid var(--line);transition:border-color .4s,box-shadow .4s}
.card-img::after{content:"";position:absolute;inset:0;background:linear-gradient(20deg,rgba(33,43,84,.45),transparent 55%);opacity:1;transition:opacity .5s}
.card-img img{width:100%;height:118%;object-fit:cover;will-change:transform;filter:saturate(.95);
  transition:scale .8s cubic-bezier(.2,.7,.2,1),filter .5s}
.card:hover .card-img{border-color:rgba(106,151,153,.55);box-shadow:0 24px 70px rgba(0,0,0,.35)}
.card:hover .card-img::after{opacity:0}
.card:hover .card-img img{scale:1.06;filter:saturate(1.12)}
.card-tag{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);display:block;margin-bottom:16px;transition:letter-spacing .4s}
.card:hover .card-tag{letter-spacing:.34em}
.card h3{font-family:var(--display);font-weight:700;font-size:clamp(1.4rem,2.6vw,2.1rem);line-height:1.15;margin-bottom:16px;
  display:inline;background:linear-gradient(var(--accent2),var(--accent2)) no-repeat left 1.06em/0 2px;transition:background-size .5s cubic-bezier(.2,.7,.2,1)}
.card:hover h3{background-size:100% 2px}
.card p{color:var(--ink-dim);max-width:44ch;margin-top:16px}
@media(max-width:900px){.card,.card:nth-child(even){grid-template-columns:1fr;gap:26px;margin-top:70px}.card:nth-child(even) .card-img{order:0}}

/* ---------- marquee ---------- */
.marquee{border-block:1px solid var(--line);padding:26px 0;overflow:hidden;background:var(--bg2)}
.marquee-track{display:flex;gap:0;width:max-content;animation:scroll 26s linear infinite}
.marquee-track span{font-family:var(--display);font-weight:700;font-size:clamp(1.2rem,2.4vw,2rem);letter-spacing:.04em;
  text-transform:uppercase;padding:0 28px;white-space:nowrap;color:var(--ink);transition:color .3s,text-shadow .3s}
.marquee-track span:hover{color:var(--accent2);text-shadow:0 0 24px rgba(159,196,197,.5)}
.marquee-track i{font-style:normal;color:var(--accent);padding:0 6px}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- services (numbered list) ---------- */
.services-sec{padding:140px 0}
.svc-list{margin-top:70px;border-top:1px solid var(--line)}
.svc{display:grid;grid-template-columns:90px 1fr 2fr 60px;gap:30px;align-items:baseline;
  padding:40px 10px;border-bottom:1px solid var(--line);position:relative;transition:background .35s,padding-left .35s}
.svc::before{content:"";position:absolute;left:0;top:0;height:100%;width:0;background:linear-gradient(90deg,rgba(127,178,180,.12),transparent);transition:width .45s}
.svc:hover{padding-left:26px}
.svc:hover::before{width:100%}
.svc .num{font-family:var(--display);font-weight:700;font-size:.85rem;color:var(--ink-dim);transition:color .3s,transform .35s;display:inline-block}
.svc:hover .num{color:var(--accent);transform:scale(1.5)}
.svc h3{font-family:var(--display);font-weight:700;font-size:clamp(1.1rem,2vw,1.5rem);transition:transform .35s,color .35s}
.svc:hover h3{transform:translateX(6px);color:var(--accent2)}
.svc p{color:var(--ink-dim);font-size:.95rem;max-width:56ch;transition:color .35s}
.svc:hover p{color:var(--ink)}
.svc .arrow{font-size:1.4rem;color:var(--ink-dim);transition:transform .35s,color .35s;justify-self:end}
.svc:hover .arrow{transform:translateX(8px) rotate(-45deg);color:var(--accent)}
@media(max-width:900px){.svc{grid-template-columns:50px 1fr;gap:10px}.svc p{grid-column:2}.svc .arrow{display:none}}

/* ---------- clients ---------- */
.clients{padding:110px 0;border-top:1px solid var(--line);overflow:hidden}
.clients h2.big{text-align:center;margin:0 auto}
.clients .sub{text-align:center;color:var(--ink-dim);margin:16px auto 70px}
.logo-track{display:flex;gap:80px;width:max-content;animation:scroll 38s linear infinite}
.logo-track:hover{animation-play-state:paused}
.logo-track img{height:42px;width:auto;object-fit:contain;filter:grayscale(1) brightness(0) invert(1);opacity:.5;transition:opacity .3s,transform .3s}
.logo-track img:hover{opacity:1;transform:scale(1.08)}

/* ---------- contact ---------- */
.contact{padding:160px 0;text-align:center;position:relative;overflow:hidden;border-top:1px solid var(--line);
  background:radial-gradient(900px 420px at 50% 0%,rgba(127,178,180,.12),transparent 60%),var(--bg2)}
.contact h2{font-family:var(--display);font-weight:800;font-size:clamp(2rem,5.4vw,4.2rem);line-height:1.05;max-width:18ch;margin:0 auto 26px}
.contact p{color:var(--ink-dim);max-width:46ch;margin:0 auto 48px}
.contact-links{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

footer{padding:44px 5vw;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;align-items:center;border-top:1px solid var(--line);color:var(--ink-dim);font-size:.8rem}
footer img{height:32px;opacity:.85}

/* ---------- multi-page additions ---------- */
.page-hero{min-height:52vh;display:flex;align-items:flex-end;padding:160px 0 70px;position:relative;isolation:isolate;overflow:hidden}
.page-hero .swirl{right:-30vmin;top:40%;width:100vmin;height:100vmin;position:absolute;transform:translateY(-50%);z-index:-1;opacity:.6}
.page-hero h1{font-size:clamp(2.2rem,5.4vw,4.2rem)}
.page-hero p.lede{max-width:54ch;color:var(--ink-dim);margin-top:24px;font-size:1.08rem}
.content-sec{padding:90px 0}
.prose{max-width:68ch;color:var(--ink-dim);font-size:1.05rem}
.prose p{margin-bottom:1.4em}
.prose strong{color:var(--ink)}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
@media(max-width:900px){.two-col{grid-template-columns:1fr}}
.img-frame{border-radius:18px;overflow:hidden;border:1px solid var(--line)}
.img-frame img{transition:scale .8s cubic-bezier(.2,.7,.2,1),filter .5s;filter:saturate(.95)}
.img-frame:hover img{scale:1.05;filter:saturate(1.1)}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gallery .img-frame{aspect-ratio:4/3}
.gallery .img-frame img{width:100%;height:100%;object-fit:cover}
@media(max-width:860px){.gallery{grid-template-columns:1fr 1fr}}
.client-cloud{display:flex;flex-wrap:wrap;gap:12px 14px;margin-top:50px;justify-content:center;max-width:1000px;margin-inline:auto}
.client-cloud span{font-size:.86rem;letter-spacing:.08em;color:var(--ink-dim);border:1px solid var(--line);
  padding:9px 18px;border-radius:100px;transition:color .3s,border-color .3s,transform .3s,background .3s}
.client-cloud span:hover{color:#1b2040;background:var(--accent);border-color:var(--accent);transform:translateY(-3px)}
.detail-list{margin-top:60px;display:grid;gap:22px}
.detail{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:42px 38px;transition:transform .35s,border-color .35s,box-shadow .35s}
.detail:hover{transform:translateY(-5px);border-color:rgba(106,151,153,.5);box-shadow:0 20px 60px rgba(0,0,0,.3)}
.detail h3{font-family:var(--display);font-size:1.3rem;margin-bottom:12px}
.detail .num{font-family:var(--display);font-size:.78rem;letter-spacing:.2em;color:var(--accent);display:block;margin-bottom:16px}
.detail p{color:var(--ink-dim)}
.detail ul{margin:18px 0 0 1.2em;color:var(--ink-dim)}
.detail li{margin-bottom:6px}
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:22px;margin-top:60px}
.contact-card{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:40px 32px;text-align:center;transition:transform .35s,border-color .35s}
.contact-card:hover{transform:translateY(-6px);border-color:var(--accent)}
.contact-card h3{font-family:var(--display);font-size:1.05rem;margin-bottom:10px}
.contact-card a{color:var(--accent2)}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr}}
