/* ============================================================
   EASTCAMP — main.css
   Edit the tokens below to re-skin the whole site.
   ============================================================ */
:root{
  --bg:        #0A0A0B;
  --bg-2:      #121214;
  --surface:   #1A1A1E;
  --text:      #F3F0E9;
  --muted:     #8A8A90;
  --line:      rgba(243,240,233,0.12);
  --accent:    #F2B441;

  --font-display:'Archivo Black', sans-serif;
  --font-body:   'Archivo', sans-serif;
  --font-mono:   'JetBrains Mono', monospace;

  --maxw: 1320px;
  --gutter: clamp(20px, 5vw, 64px);
  --ease: cubic-bezier(.16,1,.3,1);
}

/* ---------- reset ---------- */
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--accent);color:#000}

body::after{content:"";position:fixed;inset:0;z-index:60;pointer-events:none;opacity:.04;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='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ---------- viewfinder chrome ---------- */
.viewfinder{position:fixed;inset:18px;z-index:50;pointer-events:none}
.vf-corner{position:absolute;width:26px;height:26px;border:2px solid var(--text);opacity:0;transform:scale(.4);transition:transform .9s var(--ease) .2s, opacity .9s var(--ease) .2s}
.vf-corner.tl{top:0;left:0;border-right:none;border-bottom:none}
.vf-corner.tr{top:0;right:0;border-left:none;border-bottom:none}
.vf-corner.bl{bottom:0;left:0;border-right:none;border-top:none}
.vf-corner.br{bottom:0;right:0;border-left:none;border-top:none}
.loaded .vf-corner{transform:scale(1);opacity:.55}

/* ---------- custom cursor ---------- */
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;z-index:100;pointer-events:none;border-radius:50%;transform:translate(-50%,-50%);will-change:transform}
.cursor-dot{width:5px;height:5px;background:var(--accent)}
.cursor-ring{width:34px;height:34px;border:1px solid rgba(243,240,233,.6);transition:width .3s var(--ease),height .3s var(--ease),border-color .3s var(--ease),background .3s var(--ease)}
.cursor-ring .label{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:10px;letter-spacing:.05em;color:#000;opacity:0;text-transform:uppercase}
body.focusing .cursor-ring{width:74px;height:74px;border-color:var(--accent);background:var(--accent)}
body.focusing .cursor-ring .label{opacity:1}
body.focusing .cursor-dot{opacity:0}
@media (hover:none),(pointer:coarse){.cursor-dot,.cursor-ring{display:none}}

/* ---------- top bar ---------- */
.topbar{position:fixed;top:0;left:0;right:0;z-index:40;display:flex;align-items:center;justify-content:space-between;padding:26px var(--gutter);mix-blend-mode:difference}
.tc{font-family:var(--font-mono);font-size:12px;letter-spacing:.08em;display:flex;align-items:center;gap:9px}
.rec-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:blink 1.4s steps(1) infinite}
@keyframes blink{50%{opacity:.15}}
.brand{font-family:var(--font-display);font-size:19px;letter-spacing:.12em}
.nav-links{display:flex;gap:30px;font-size:13px;letter-spacing:.04em;text-transform:uppercase}
.nav-links a{position:relative;padding:2px 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;height:1px;width:0;background:var(--accent);transition:width .35s var(--ease)}
.nav-links a:hover::after{width:100%}
.menu-btn{display:none;font-family:var(--font-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase}
@media(max-width:860px){.nav-links{display:none}.menu-btn{display:block}.topbar{padding:20px var(--gutter)}}

/* ---------- layout helpers ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}
.section{padding:clamp(90px,14vh,170px) 0;position:relative}
.eyebrow{font-family:var(--font-mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:12px;margin-bottom:28px}
.eyebrow::before{content:"";width:34px;height:1px;background:var(--accent)}
.divider{display:flex;align-items:center;gap:18px;color:var(--muted);font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase}
.divider .rule{flex:1;height:1px;background:var(--line)}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
.line{display:block;overflow:hidden}
.line span{display:block;transform:translateY(105%);transition:transform 1s var(--ease)}
.line.in span{transform:none}
.line:nth-child(2) span{transition-delay:.1s}
.line:nth-child(3) span{transition-delay:.2s}

/* ---------- hero ---------- */
.hero{height:100svh;min-height:640px;position:relative;display:flex;align-items:flex-end;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg::before{content:"";position:absolute;inset:-20%;
  background:radial-gradient(60% 70% at 70% 30%, rgba(242,180,65,.18), transparent 60%),radial-gradient(50% 60% at 20% 80%, rgba(30,58,64,.55), transparent 60%),linear-gradient(180deg,#0d0d10,#070708);
  filter:saturate(1.05);animation:drift 22s ease-in-out infinite alternate}
@keyframes drift{from{transform:translate3d(0,0,0) scale(1.05)}to{transform:translate3d(-3%,2%,0) scale(1.12)}}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,11,.2) 0%,rgba(10,10,11,.1) 50%,rgba(10,10,11,.92) 100%)}
.hero-inner{position:relative;z-index:2;width:100%;padding-bottom:clamp(60px,10vh,120px)}
.hero h1{font-family:var(--font-display);font-weight:400;line-height:.96;font-size:clamp(2.7rem,8vw,7.2rem);letter-spacing:-.01em;text-transform:uppercase}
.hero h1 em{font-style:normal;color:var(--accent)}
.hero-foot{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;margin-top:46px;flex-wrap:wrap}
.showreel{display:inline-flex;align-items:center;gap:14px;font-family:var(--font-mono);font-size:13px;letter-spacing:.1em;text-transform:uppercase}
.showreel .tri{width:42px;height:42px;border:1px solid var(--text);border-radius:50%;display:grid;place-items:center;transition:background .3s var(--ease),color .3s var(--ease)}
.showreel:hover .tri{background:var(--accent);border-color:var(--accent);color:#000}
.scroll-cue{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;color:var(--muted);text-transform:uppercase;writing-mode:vertical-rl;display:flex;align-items:center;gap:10px}
.scroll-cue::after{content:"";width:1px;height:46px;background:linear-gradient(var(--accent),transparent);animation:cue 1.8s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}40%{transform:scaleY(1);transform-origin:top}60%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---------- clients marquee ---------- */
.clients{padding:46px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden}
.marquee{display:flex;gap:80px;width:max-content;animation:scroll-x 38s linear infinite}
.marquee img{height:30px;width:auto;opacity:.6;filter:grayscale(1) brightness(1.6);transition:opacity .3s}
.marquee img:hover{opacity:1}
@keyframes scroll-x{to{transform:translateX(-50%)}}

/* ---------- selected work ---------- */
.work-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:54px;flex-wrap:wrap}
.work-head h2{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.6rem);line-height:1;text-transform:uppercase;letter-spacing:-.01em}
.work-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:22px}
.tile{position:relative;overflow:hidden;background:var(--surface);border-radius:2px;display:block}
.tile.lg{grid-column:span 8;aspect-ratio:16/9}
.tile.sm{grid-column:span 4;aspect-ratio:4/5}
.tile.full{grid-column:span 12;aspect-ratio:21/9}
.tile img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease),filter .6s;filter:saturate(.85) brightness(.78)}
.tile:hover img{transform:scale(1.05);filter:saturate(1) brightness(.92)}
.tile-empty{width:100%;height:100%;display:grid;place-items:center;color:var(--muted);font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;background:repeating-linear-gradient(45deg,#141417,#141417 12px,#171719 12px,#171719 24px)}
.tile-meta{position:absolute;left:0;bottom:0;padding:26px;z-index:2;width:100%;background:linear-gradient(transparent,rgba(7,7,8,.85))}
.tile-meta .cat{font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}
.tile-meta h3{font-family:var(--font-display);font-size:clamp(1.2rem,2.4vw,2rem);text-transform:uppercase;margin-top:8px;line-height:1}
@media(max-width:860px){.tile.lg,.tile.sm,.tile.full{grid-column:span 12}.tile.lg{aspect-ratio:16/10}}

/* ---------- stats ---------- */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;text-align:center}
.stat .num{font-family:var(--font-display);font-size:clamp(2.6rem,7vw,5.4rem);line-height:1;letter-spacing:-.02em}
.stat .num em{font-style:normal;color:var(--accent)}
.stat .lab{font-family:var(--font-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:10px}
@media(max-width:680px){.stats{grid-template-columns:1fr;gap:46px}}

/* ---------- services ---------- */
.services{border-top:1px solid var(--line)}
.svc{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:clamp(22px,3.4vw,40px) 0;border-bottom:1px solid var(--line);position:relative;transition:padding-left .45s var(--ease)}
.svc .idx{font-family:var(--font-mono);font-size:12px;color:var(--muted);width:46px}
.svc h3{font-family:var(--font-display);font-size:clamp(1.7rem,5.5vw,4rem);text-transform:uppercase;line-height:.95;letter-spacing:-.01em;transition:color .35s var(--ease);flex:1}
.svc .arrow{font-family:var(--font-mono);opacity:0;transform:translateX(-12px);transition:opacity .35s,transform .35s var(--ease);color:var(--accent)}
.svc:hover{padding-left:22px}
.svc:hover h3{color:var(--accent)}
.svc:hover .arrow{opacity:1;transform:none}

/* ---------- team ---------- */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.member{position:relative;aspect-ratio:3/4;overflow:hidden;background:var(--surface);border-radius:2px}
.member img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) brightness(.85);transition:filter .5s,transform 1s var(--ease)}
.member:hover img{filter:grayscale(0) brightness(1);transform:scale(1.04)}
.member .info{position:absolute;left:0;bottom:0;padding:18px;width:100%;background:linear-gradient(transparent,rgba(7,7,8,.9))}
.member .info .nm{font-family:var(--font-display);font-size:1.05rem;text-transform:uppercase;line-height:1}
.member .info .role{font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;color:var(--muted);margin-top:5px}
@media(max-width:860px){.team-grid{grid-template-columns:repeat(2,1fr)}}

/* ---------- testimonials ---------- */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.quote{border-left:1px solid var(--line);padding-left:24px}
.quote p{font-size:1.05rem;line-height:1.55;color:#dcdad3}
.quote .by{font-family:var(--font-mono);font-size:12px;letter-spacing:.06em;color:var(--accent);margin-top:18px;text-transform:uppercase}
@media(max-width:860px){.quotes{grid-template-columns:1fr;gap:40px}}

/* ---------- contact / footer ---------- */
.contact{padding:clamp(100px,16vh,200px) 0 70px}
.contact .big{font-family:var(--font-display);font-size:clamp(2.6rem,10vw,8rem);line-height:.92;text-transform:uppercase;letter-spacing:-.02em}
.contact .big a{display:inline-block;transition:color .35s var(--ease)}
.contact .big a:hover{color:var(--accent)}
.foot{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;margin-top:90px;padding-top:34px;border-top:1px solid var(--line);font-family:var(--font-mono);font-size:13px;color:var(--muted)}
.foot a:hover{color:var(--text)}
.foot .col{display:flex;flex-direction:column;gap:6px}
.foot .socials{display:flex;gap:20px;text-transform:uppercase;letter-spacing:.06em}

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