:root{
  --bg:#08090b;
  --panel:#0e1013;
  --line:#ffffff14;
  --text:#f2f2ee;
  --muted:#9aa3a1;
  --accent:#45d6e8;
  --heading:"Space Grotesk",system-ui,sans-serif;
  --body:Manrope,system-ui,sans-serif;
  color-scheme:dark;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--text);font-family:var(--body);line-height:1.6}
img,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--heading);line-height:1.08;margin:0}

/* header */
.site-header{
  position:sticky;top:0;z-index:10;
  display:flex;align-items:center;gap:1.5rem;
  padding:.9rem clamp(1rem,4vw,3rem);
  background:rgba(8,9,11,.86);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.brand{font-family:var(--heading);font-weight:700;font-size:1.1rem}
.site-header nav{display:flex;gap:1.4rem;margin-left:auto}
.site-header nav a,.cta{font-size:.88rem;color:var(--muted)}
.site-header nav a:hover{color:var(--text)}
.cta{border:1px solid var(--accent);color:var(--text);padding:.45rem .9rem}
.cta:hover{background:var(--accent);color:#05171b}

/* hero */
.hero{position:relative;min-height:82vh;display:flex;align-items:flex-end;overflow:hidden}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,9,11,.25) 0%,rgba(8,9,11,.82) 78%,var(--bg) 100%)}
.hero-copy{position:relative;padding:clamp(2rem,6vw,4.5rem) clamp(1rem,4vw,3rem);max-width:56rem}
.kicker{color:var(--accent);font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;margin:0 0 1rem}
.hero h1{font-size:clamp(2.1rem,5vw,3.8rem);font-weight:700}
.lede{color:var(--muted);max-width:38rem;font-size:1.05rem;margin:1.2rem 0 0}
.hero-actions{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.8rem}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:2.9rem;padding:0 1.3rem;border:1px solid var(--line);font-weight:700;font-size:.92rem}
.btn:hover{border-color:var(--text)}
.btn.primary{border-color:var(--accent)}
.btn.primary:hover{background:var(--accent);color:#05171b}
.clients{color:var(--muted);font-size:.82rem;margin-top:2rem}

/* sections */
.section{padding:clamp(3.5rem,7vw,6rem) clamp(1rem,4vw,3rem);border-top:1px solid var(--line)}
.section-head{display:flex;flex-wrap:wrap;align-items:baseline;gap:1rem;margin-bottom:1.6rem}
.section-head h2,.about-copy h2,.contact h2{font-size:clamp(1.6rem,3vw,2.6rem)}
.section-head p{color:var(--muted);margin:0}

/* filters */
.filter-bar{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}
.filter-bar button{
  font:inherit;font-size:.84rem;cursor:pointer;
  background:none;color:var(--muted);
  border:1px solid var(--line);padding:.4rem .85rem;
}
.filter-bar button:hover{color:var(--text)}
.filter-bar button.active{color:var(--text);border-color:var(--accent)}

/* work grid */
.work-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(20rem,100%),1fr));gap:1.6rem 1.2rem}
.work-card.hidden{display:none}
.media{
  position:relative;display:block;width:100%;padding:0;cursor:pointer;
  border:1px solid var(--line);background:#000;
  aspect-ratio:16/9;overflow:hidden;
}
.media img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease,opacity .3s ease}
.work-card.vert .media img{object-fit:contain}
.media:hover img{transform:scale(1.03)}
.media::after{
  content:"";position:absolute;inset:0;margin:auto;width:3rem;height:3rem;
  background:rgba(8,9,11,.62) url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="white"><path d="M8 5v14l11-7z"/></svg>') center/1.4rem no-repeat;
  border-radius:50%;border:1px solid rgba(255,255,255,.35);
  transition:transform .2s ease;
}
.media:hover::after{transform:scale(1.08)}
.media.playing::after{display:none}
.media video{width:100%;height:100%;object-fit:contain;background:#000}
.badge{
  position:absolute;right:.55rem;bottom:.55rem;
  font-size:.72rem;font-variant-numeric:tabular-nums;
  background:rgba(8,9,11,.72);padding:.15rem .45rem;border:1px solid var(--line);
}
.work-card h3{font-size:1rem;margin:.8rem 0 .15rem}
.work-card p{color:var(--muted);font-size:.85rem;margin:0}

/* about */
.about-grid{display:grid;grid-template-columns:minmax(16rem,.9fr) minmax(18rem,1.1fr);gap:clamp(2rem,5vw,4.5rem)}
.about-copy p{color:var(--muted);max-width:34rem}
.about-copy .tools{font-size:.85rem;margin-top:1.4rem}
.timeline{border-top:1px solid var(--line)}
.t-row{display:grid;grid-template-columns:6.2rem 1fr;gap:1rem;padding:1.05rem 0;border-bottom:1px solid var(--line)}
.t-row time{color:var(--accent);font-size:.88rem;font-variant-numeric:tabular-nums}
.t-row strong{display:block;font-weight:700}
.t-row span{color:var(--muted);font-size:.88rem}

/* contact */
.contact{text-align:left}
.contact .lede{margin-top:.8rem}
.contact-links{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.8rem}
.contact-links a{border:1px solid var(--line);padding:.6rem 1rem;font-size:.9rem;color:var(--muted)}
.contact-links a:hover{color:var(--text);border-color:var(--accent)}

footer{padding:1.6rem clamp(1rem,4vw,3rem);border-top:1px solid var(--line)}
footer p{color:var(--muted);font-size:.8rem;margin:0}

@media (max-width:760px){
  .site-header nav{gap:.9rem}
  .hero{min-height:64vh}
  .about-grid{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .media img,.media::after{transition:none}
}
