/* =========================================================
   FRACTAL STUDIOS — Stylesheet (v3: full-bleed / glass / cinematic)
   Palette: #000 / #1C1C1C / #595959 / #C90000 / #FFF
   Type: Realtime (drop into assets/fonts) → Space Mono fallback
   ========================================================= */

@font-face{font-family:'Realtime';src:url('../assets/fonts/Realtime-Regular.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'Realtime';src:url('../assets/fonts/Realtime-Medium.woff2') format('woff2');font-weight:500;font-display:swap}
@font-face{font-family:'Realtime';src:url('../assets/fonts/Realtime-Bold.woff2') format('woff2');font-weight:700;font-display:swap}

:root{
  --black:#000;--eerie:#1c1c1c;--eerie-2:#121212;--dim:#595959;
  --red:#c90000;--red-bright:#ff1f1f;--white:#fff;
  --fg:#fff;--muted:#8c8c8c;--faint:#565656;
  --line:rgba(255,255,255,.10);--line-2:rgba(255,255,255,.05);

  --ff:'Realtime','Space Mono',ui-monospace,monospace;
  --ff-body:'Inter',-apple-system,sans-serif;

  --gutter:clamp(18px,3.4vw,56px);
  --ease:cubic-bezier(.16,1,.3,1);
  --ease-2:cubic-bezier(.62,0,.16,1);
  --nav-h:70px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scroll-padding-top:var(--nav-h)}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{font-family:var(--ff);background:var(--black);color:var(--fg);
  font-size:13px;line-height:1.5;overflow-x:hidden;cursor:none;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
@media (hover:none),(pointer:coarse){body{cursor:auto}}

a{color:inherit;text-decoration:none}
button{font:inherit;border:none;background:none;color:inherit}
ul,ol{list-style:none}
img,svg,video{display:block;max-width:100%}
::selection{background:var(--red);color:#fff}
.svg-defs{position:absolute;width:0;height:0;overflow:hidden}

/* full-bleed wrapper used by section heads/content */
.pad{padding-inline:var(--gutter)}

.label{display:inline-block;font:400 11px/1 var(--ff);letter-spacing:.16em;color:var(--red);text-transform:uppercase}

/* =========================================================
   LIQUID GLASS
   ========================================================= */
.lg{position:relative;isolation:isolate;
  background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.12);
  backdrop-filter:blur(16px) saturate(160%);-webkit-backdrop-filter:blur(16px) saturate(160%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.2),inset 0 -1px 0 rgba(255,255,255,.04),0 20px 50px -18px rgba(0,0,0,.65);
  overflow:hidden}
.lg::before{content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;background:linear-gradient(180deg,rgba(255,255,255,.16),transparent 40%)}
.lg::after{content:"";position:absolute;top:-60%;left:-30%;width:50%;height:220%;pointer-events:none;
  background:linear-gradient(115deg,transparent,rgba(255,255,255,.18),transparent);
  transform:rotate(8deg) translateX(-60%);transition:transform 1s var(--ease)}
.lg:hover::after{transform:rotate(8deg) translateX(420%)}

/* =========================================================
   GRAIN / VIGNETTE / CURSOR
   ========================================================= */
.grain{position:fixed;inset:-50%;z-index:9000;pointer-events:none;opacity:.045;
  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='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 6s steps(6) infinite}
@keyframes grain{0%,100%{transform:translate(0,0)}20%{transform:translate(-6%,4%)}40%{transform:translate(4%,-6%)}60%{transform:translate(-4%,2%)}80%{transform:translate(6%,-2%)}}
.vignette{position:fixed;inset:0;z-index:8999;pointer-events:none;background:radial-gradient(120% 90% at 50% 40%,transparent 55%,rgba(0,0,0,.5) 100%)}

.cursor{position:fixed;inset:0 auto auto 0;z-index:10000;pointer-events:none}
/* red core dot — exact follow */
.cursor__dot{position:fixed;width:6px;height:6px;border-radius:50%;background:var(--red-bright);
  box-shadow:0 0 8px 1px rgba(201,0,0,.8),0 0 2px #fff;transform:translate(-50%,-50%);
  transition:width .25s var(--ease),height .25s var(--ease),opacity .25s,background .25s}
/* camera focus reticle — trailing follow */
.cursor__reticle{position:fixed;width:34px;height:34px;transform:translate(-50%,-50%) rotate(0deg);
  transition:width .35s var(--ease),height .35s var(--ease),opacity .3s,transform .5s var(--ease),background .35s,border-radius .35s;
  border-radius:3px}
.cursor__reticle i{position:absolute;width:9px;height:9px;border:1.5px solid rgba(255,255,255,.7);transition:border-color .3s,opacity .3s}
.cursor__reticle i:nth-child(1){top:0;left:0;border-right:0;border-bottom:0}
.cursor__reticle i:nth-child(2){top:0;right:0;border-left:0;border-bottom:0}
.cursor__reticle i:nth-child(3){bottom:0;left:0;border-right:0;border-top:0}
.cursor__reticle i:nth-child(4){bottom:0;right:0;border-left:0;border-top:0}
.cursor__label{position:fixed;transform:translate(-50%,-50%);font:400 9px/1 var(--ff);letter-spacing:.14em;color:#fff;opacity:0;transition:opacity .25s;text-transform:uppercase}
/* hover — focus lock: brackets tighten + go red, dot spreads to a ring */
body.cursor-hover .cursor__reticle{width:26px;height:26px;transform:translate(-50%,-50%) rotate(45deg)}
body.cursor-hover .cursor__reticle i{border-color:var(--red-bright)}
body.cursor-hover .cursor__dot{width:3px;height:3px}
/* view / play — open into a liquid-glass disc with a label */
body.cursor-view .cursor__reticle,body.cursor-play .cursor__reticle{width:84px;height:84px;border-radius:50%;
  background:rgba(201,0,0,.16);backdrop-filter:blur(3px) saturate(140%);-webkit-backdrop-filter:blur(3px) saturate(140%)}
body.cursor-view .cursor__reticle i,body.cursor-play .cursor__reticle i{opacity:0}
body.cursor-view .cursor__dot,body.cursor-play .cursor__dot{opacity:0}
body.cursor-view .cursor__label,body.cursor-play .cursor__label{opacity:1}
/* logo — square framing */
body.cursor-logo .cursor__reticle{width:44px;height:44px}
body.cursor-logo .cursor__reticle i{border-color:#fff}
@media (hover:none),(pointer:coarse){.cursor{display:none}}

/* =========================================================
   PRELOADER
   ========================================================= */
.preloader{position:fixed;inset:0;z-index:9999;background:var(--black);display:grid;place-items:center;transition:opacity .6s var(--ease),visibility .6s}
.preloader.is-done{opacity:0;visibility:hidden}
.preloader__inner{display:flex;flex-direction:column;align-items:center;gap:16px;width:min(70vw,240px)}
.preloader__mark{color:#fff;width:74px;animation:markPulse 1.5s var(--ease) infinite}
@keyframes markPulse{0%,100%{opacity:.35}50%{opacity:1}}
.preloader__bar{width:100%;height:1px;background:rgba(255,255,255,.12);overflow:hidden}
.preloader__bar span{display:block;height:100%;width:0;background:var(--red);transition:width .2s linear}
.preloader__count{font:400 11px var(--ff);letter-spacing:.2em;color:var(--muted)}
.preloader__count::after{content:'%';color:var(--red)}

/* =========================================================
   NAV
   ========================================================= */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;padding-inline:var(--gutter);transition:height .4s var(--ease)}
.nav.is-scrolled{height:58px}
.nav__brand{display:flex;align-items:center;gap:10px}
.brand-mark{width:32px;height:auto;color:#fff;transition:color .3s}
.nav__brand:hover .brand-mark{color:var(--red)}
.brand-word{font:700 12px var(--ff);letter-spacing:.34em;padding-left:.2em}
.nav__links{display:flex;align-items:center;gap:2px;padding:5px;border-radius:100px}
.nav.is-scrolled .nav__links{box-shadow:inset 0 1px 0 rgba(255,255,255,.18),0 14px 40px -18px rgba(0,0,0,.7)}
.nav__link{position:relative;padding:8px 15px;font:400 11px var(--ff);letter-spacing:.06em;color:var(--muted);text-transform:uppercase;border-radius:100px;transition:color .3s,background .3s}
.nav__link:hover,.nav__link.is-active{color:#fff;background:rgba(255,255,255,.06)}
.nav__link.is-active{color:var(--red-bright)}
.nav__toggle{display:none;width:42px;height:42px;flex-direction:column;gap:6px;align-items:center;justify-content:center}
.nav__toggle span{width:24px;height:1.5px;background:#fff;transition:transform .4s var(--ease)}
.nav__toggle[aria-expanded="true"] span:first-child{transform:translateY(3.75px) rotate(45deg)}
.nav__toggle[aria-expanded="true"] span:last-child{transform:translateY(-3.75px) rotate(-45deg)}

.menu{position:fixed;inset:0;z-index:999;background:rgba(8,8,8,.9);backdrop-filter:blur(26px);-webkit-backdrop-filter:blur(26px);
  display:flex;flex-direction:column;justify-content:center;padding:0 8vw;clip-path:circle(0% at calc(100% - 42px) 36px);transition:clip-path .7s var(--ease);visibility:hidden}
.menu.is-open{clip-path:circle(150% at calc(100% - 42px) 36px);visibility:visible}
.menu__inner{display:flex;flex-direction:column;gap:4px}
.menu__link{font:400 clamp(1.8rem,8vw,3rem) var(--ff);text-transform:uppercase;display:flex;align-items:baseline;gap:16px;color:#fff;opacity:0;transform:translateY(24px);transition:opacity .5s var(--ease),transform .5s var(--ease),color .3s}
.menu.is-open .menu__link{opacity:1;transform:none}
.menu.is-open .menu__link:nth-child(1){transition-delay:.12s}.menu.is-open .menu__link:nth-child(2){transition-delay:.18s}.menu.is-open .menu__link:nth-child(3){transition-delay:.24s}.menu.is-open .menu__link:nth-child(4){transition-delay:.3s}
.menu__link:hover{color:var(--red)}
.menu__link i{font-size:.8rem;color:var(--red)}
.menu__foot{margin-top:40px;display:flex;flex-direction:column;gap:6px;font:400 12px var(--ff);color:var(--muted)}

/* =========================================================
   MAIN (sits above the reveal footer)
   ========================================================= */
main{position:relative;z-index:2;background:var(--black)}

/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;min-height:100svh;overflow:hidden;display:flex}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__vid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 1.2s var(--ease)}
.hero__vid.is-ready{opacity:1}
.hero__scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.55),rgba(0,0,0,.25) 38%,rgba(0,0,0,.78))}
.hero__glow{position:absolute;border-radius:50%;filter:blur(90px)}
.hero__glow--1{width:55vw;height:55vw;top:-12%;right:-8%;background:radial-gradient(circle,rgba(201,0,0,.45),transparent 65%);animation:float1 16s var(--ease) infinite alternate}
.hero__glow--2{width:45vw;height:45vw;bottom:-18%;left:-6%;background:radial-gradient(circle,rgba(201,0,0,.22),transparent 70%);animation:float2 20s var(--ease) infinite alternate}
@keyframes float1{to{transform:translate(-8%,8%) scale(1.12)}}
@keyframes float2{to{transform:translate(8%,-6%) scale(1.1)}}
.hero__streak{position:absolute;top:50%;left:-20%;width:140%;height:32vh;background:linear-gradient(100deg,transparent,rgba(255,40,40,.4),rgba(255,255,255,.5),rgba(255,40,40,.3),transparent);filter:blur(46px);transform:translateY(-50%) rotate(-8deg);opacity:.45;animation:streak 14s var(--ease-2) infinite}
@keyframes streak{0%,100%{transform:translateY(-50%) rotate(-8deg) translateX(-6%)}50%{transform:translateY(-42%) rotate(-6deg) translateX(6%)}}
.hero__grid{position:absolute;inset:0;opacity:.35;background-image:linear-gradient(var(--line-2) 1px,transparent 1px),linear-gradient(90deg,var(--line-2) 1px,transparent 1px);background-size:72px 72px;-webkit-mask-image:radial-gradient(120% 80% at 50% 55%,#000 28%,transparent 78%);mask-image:radial-gradient(120% 80% at 50% 55%,#000 28%,transparent 78%)}

.hero__mark{position:absolute;top:50%;left:50%;transform:translate(-50%,-58%);width:min(56vw,640px);z-index:1;color:#fff;opacity:.05;pointer-events:none}
.hero__mark svg{width:100%;height:auto}

/* white play + liquid glass */
.reel{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:16px;cursor:none;animation:reelFloat 6s var(--ease) infinite}
@keyframes reelFloat{0%,100%{transform:translate(-50%,-50%)}50%{transform:translate(-50%,calc(-50% - 8px))}}
.reel__ring{position:absolute;top:0;left:50%;transform:translateX(-50%);width:92px;height:92px;border-radius:50%}
.reel__play{position:relative;width:92px;height:92px;display:grid;place-items:center;color:#fff;transition:transform .4s var(--ease)}
.reel__play svg{width:26px;height:26px;margin-left:3px}
.reel:hover .reel__play{transform:scale(1.1)}
.reel__txt{margin-top:104px;font:400 11px var(--ff);letter-spacing:.16em;text-transform:uppercase;color:#fff}
.reel__txt i{color:var(--muted);font-style:normal;margin-left:6px}

.hero__foot{position:absolute;left:0;right:0;bottom:clamp(26px,5vh,52px);z-index:3;padding-inline:var(--gutter);display:flex;align-items:flex-end;justify-content:space-between;gap:24px}
.hero__intro{font:400 12px var(--ff);letter-spacing:.12em;text-transform:uppercase;color:#c4c4c4}
.hero__meta{display:flex;flex-direction:column;gap:6px;text-align:right;font:400 11px var(--ff);letter-spacing:.1em;color:var(--muted);text-transform:uppercase}
.hero__scroll{position:absolute;left:50%;bottom:14px;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:8px;font:400 10px var(--ff);letter-spacing:.24em;text-transform:uppercase;color:var(--muted)}
.hero__scroll i{width:1px;height:38px;background:linear-gradient(var(--red),transparent);position:relative;overflow:hidden}
.hero__scroll i::after{content:"";position:absolute;inset:0 0 auto 0;height:40%;background:#fff;animation:scrollLine 1.8s var(--ease) infinite}
@keyframes scrollLine{0%{transform:translateY(-100%)}100%{transform:translateY(250%)}}

/* =========================================================
   BUTTON
   ========================================================= */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:15px 22px;border-radius:100px;background:#fff;color:#000;cursor:none;
  font:400 11px var(--ff);letter-spacing:.12em;text-transform:uppercase;position:relative;overflow:hidden;transition:color .4s var(--ease)}
.btn svg{width:15px;height:15px;position:relative;z-index:1;transition:transform .4s var(--ease)}
.btn span{position:relative;z-index:1}
.btn::before{content:"";position:absolute;inset:0;background:var(--red);transform:translateY(101%);transition:transform .45s var(--ease)}
.btn:hover{color:#fff}.btn:hover::before{transform:translateY(0)}.btn:hover svg{transform:translateX(4px)}

/* =========================================================
   WORK (full-bleed)
   ========================================================= */
.work{padding:clamp(70px,10vw,140px) 0}
.work__head{display:flex;align-items:center;justify-content:space-between;gap:24px;padding-inline:var(--gutter);margin-bottom:clamp(32px,4vw,56px)}
.work__filters{display:flex;gap:6px}
.filter{padding:8px 15px;border:1px solid var(--line);border-radius:100px;cursor:none;font:400 10px var(--ff);letter-spacing:.08em;text-transform:uppercase;color:var(--muted);transition:all .3s var(--ease)}
.filter:hover{color:#fff;border-color:rgba(255,255,255,.3)}
.filter.is-active{background:#fff;border-color:#fff;color:#000}

.work__grid{padding-inline:var(--gutter);display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(16px,2vw,32px)}
.card{position:relative;border-radius:10px;overflow:hidden;aspect-ratio:16/9;cursor:none;background:var(--eerie);
  opacity:0;transform:translateY(40px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.card.in{opacity:1;transform:none}
.card.is-hidden{display:none}
.card__media{position:absolute;inset:0;transform:scale(1.08);will-change:transform;transition:filter .6s}
.card__media[data-vis="1"]{background:radial-gradient(60% 80% at 30% 30%,rgba(255,30,30,.7),transparent 60%),radial-gradient(80% 90% at 80% 70%,rgba(120,0,0,.9),transparent 70%),linear-gradient(135deg,#2a0000,#000)}
.card__media[data-vis="2"]{background:radial-gradient(70% 70% at 70% 40%,rgba(201,0,0,.5),transparent 60%),conic-gradient(from 200deg at 60% 60%,#1c1c1c,#000,#2a0505,#000)}
.card__media[data-vis="3"]{background:radial-gradient(50% 60% at 50% 50%,rgba(255,40,40,.45),transparent 60%),repeating-linear-gradient(90deg,#0a0a0a 0 8px,#161616 8px 16px),linear-gradient(#120000,#000)}
.card__media[data-vis="4"]{background:linear-gradient(80deg,transparent 30%,rgba(255,80,80,.55) 48%,rgba(255,255,255,.65) 52%,rgba(255,40,40,.45) 56%,transparent 75%),linear-gradient(135deg,#300,#000)}
.card__media[data-vis="5"]{background:radial-gradient(circle at 40% 40%,rgba(255,30,30,.55),transparent 50%),radial-gradient(circle at 70% 70%,rgba(120,0,80,.45),transparent 55%),linear-gradient(160deg,#1a0010,#000)}
.card__media[data-vis="6"]{background:conic-gradient(from 90deg at 50% 50%,#000,#2a0000,#000,#c90000 90%,#000),linear-gradient(#0a0a0a,#000)}
.card__vid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .9s var(--ease)}
.card__vid.is-ready{opacity:1}
.card__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(0,0,0,.8))}
.card::before{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;background:linear-gradient(115deg,transparent 38%,rgba(255,255,255,.16) 50%,transparent 62%);transform:translateX(-120%);transition:transform .9s var(--ease)}
.card:hover::before{transform:translateX(120%)}
.card__bar{position:absolute;left:18px;right:18px;bottom:16px;z-index:3;display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.card__title{font:400 clamp(.9rem,1.4vw,1.1rem) var(--ff);letter-spacing:.02em;text-transform:uppercase}
.card__cat{font:400 10px var(--ff);letter-spacing:.04em;color:var(--red-bright);text-transform:uppercase;margin-right:auto}
.card__year{font:400 10px var(--ff);color:var(--muted)}

/* =========================================================
   CLIENTS
   ========================================================= */
.clients{padding:clamp(60px,9vw,120px) 0;border-top:1px solid var(--line-2);overflow:hidden}
.clients__head{padding-inline:var(--gutter);display:flex;flex-direction:column;gap:10px;margin-bottom:clamp(36px,5vw,64px)}
.clients__sub{font:400 13px var(--ff);color:var(--muted);letter-spacing:.02em}
.clients__rows{display:flex;flex-direction:column;gap:clamp(8px,1.4vw,18px)}
.cl-row{overflow:hidden;border-block:1px solid var(--line-2);padding:6px 0}
.cl-track{display:flex;align-items:center;gap:clamp(40px,6vw,90px);width:max-content;animation:clScroll 34s linear infinite}
.cl-row--rev .cl-track{animation-direction:reverse}
.cl-track span{font:400 clamp(1.6rem,5vw,3.4rem) var(--ff);text-transform:uppercase;letter-spacing:.01em;color:#2c2c2c;transition:color .35s var(--ease);-webkit-text-stroke:1px rgba(255,255,255,.14)}
.cl-track span:hover{color:#fff;-webkit-text-stroke:1px transparent}
@keyframes clScroll{to{transform:translateX(-50%)}}

/* =========================================================
   SERVICES
   ========================================================= */
.services{padding:clamp(60px,9vw,120px) 0;padding-inline:var(--gutter)}
.services .label{margin-bottom:clamp(26px,4vw,44px)}
.services__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(12px,1.4vw,18px)}
.svc{border-radius:14px;padding:clamp(22px,2.4vw,34px);min-height:170px;display:flex;flex-direction:column;align-items:flex-start;text-align:left;width:100%;cursor:none;transition:transform .5s var(--ease),border-color .5s}
.svc:hover{transform:translateY(-6px);border-color:rgba(255,31,31,.4)}
.svc__no{font:400 11px var(--ff);letter-spacing:.1em;color:var(--faint)}
.svc h3{font:400 clamp(1.1rem,1.8vw,1.5rem) var(--ff);text-transform:uppercase;letter-spacing:.02em;margin-top:28px}
.svc__go{margin-top:auto;padding-top:18px;font:400 10px var(--ff);letter-spacing:.12em;text-transform:uppercase;color:var(--red-bright);opacity:0;transform:translateY(6px);transition:opacity .4s var(--ease),transform .4s var(--ease)}
.svc:hover .svc__go{opacity:1;transform:none}

/* =========================================================
   CONTACT
   ========================================================= */
.contact{padding:clamp(80px,12vw,150px) 0;padding-inline:var(--gutter);position:relative;overflow:hidden}
.contact__glow{position:absolute;top:8%;left:50%;transform:translateX(-50%);width:60vw;height:60vw;max-width:800px;max-height:800px;background:radial-gradient(circle,rgba(201,0,0,.2),transparent 65%);filter:blur(70px);z-index:0;pointer-events:none}
.contact__inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,80px);align-items:start}
.contact__title{font:400 clamp(1.7rem,4vw,3rem)/1.1 var(--ff);text-transform:uppercase;letter-spacing:-.01em;margin-top:14px}
.contact__title em{font-style:normal;color:var(--red)}
.contact__meta{margin-top:40px;display:flex;flex-direction:column;gap:18px}
.contact__meta li{display:flex;flex-direction:column;gap:5px;border-top:1px solid var(--line-2);padding-top:14px}
.contact__meta span{font:400 10px var(--ff);letter-spacing:.14em;color:var(--faint);text-transform:uppercase}
.contact__meta a{font:400 14px var(--ff);transition:color .3s;width:fit-content}
.contact__meta a:hover{color:var(--red)}
.contact__socials{display:flex;gap:16px;flex-wrap:wrap}
.contact__form{border-radius:16px;padding:clamp(22px,3vw,36px);display:flex;flex-direction:column;gap:15px}
.field{display:flex;flex-direction:column;gap:7px}
.field label{font:400 10px var(--ff);letter-spacing:.12em;color:var(--muted);text-transform:uppercase}
.field input,.field textarea,.field select{width:100%;padding:13px 15px;border-radius:9px;background:rgba(0,0,0,.35);border:1px solid var(--line);color:#fff;font:400 14px var(--ff-body);transition:border-color .3s,background .3s;resize:vertical}
.field input::placeholder,.field textarea::placeholder{color:#5a5a5a}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--red);background:rgba(0,0,0,.55)}
.field .invalid,.field input.invalid,.field textarea.invalid,.field select.invalid{border-color:var(--red-bright)}
.select-wrap{position:relative}
.select-wrap select{appearance:none;-webkit-appearance:none;cursor:none}
.select-wrap svg{position:absolute;right:13px;top:50%;transform:translateY(-50%);width:17px;height:17px;color:var(--muted);pointer-events:none}
.select-wrap option{background:#111;color:#fff}
.form-note{font:400 11px var(--ff);letter-spacing:.04em;min-height:16px}
.form-note.ok{color:#3ddc6d}.form-note.err{color:var(--red-bright)}

/* =========================================================
   FOOTER (reveal curtain)
   ========================================================= */
.footer{position:fixed;left:0;right:0;bottom:0;z-index:1;background:var(--eerie-2);
  padding:clamp(36px,4vw,60px) var(--gutter) 28px;display:flex;flex-direction:column;justify-content:space-between;min-height:60vh}
.footer__top-row{display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;align-items:center}
.footer__links{display:flex;gap:22px;flex-wrap:wrap}
.footer__links a{font:400 11px var(--ff);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);transition:color .3s}
.footer__links a:hover{color:#fff}
.footer__email{font:400 13px var(--ff);color:#fff;transition:color .3s}
.footer__email:hover{color:var(--red)}
.footer__big{font:700 clamp(4rem,23vw,21rem) var(--ff);line-height:.82;letter-spacing:-.02em;text-align:center;
  background:linear-gradient(180deg,#fff 30%,#3a3a3a);-webkit-background-clip:text;background-clip:text;color:transparent;
  margin:clamp(24px,4vw,48px) 0}
.footer__bar{display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center;font:400 10px var(--ff);letter-spacing:.08em;color:var(--faint);text-transform:uppercase}
.footer__top{cursor:none;color:var(--muted);transition:color .3s;font:inherit}
.footer__top:hover{color:var(--red)}

/* =========================================================
   LIGHTBOX (liquid glass video overlay)
   ========================================================= */
.lightbox{position:fixed;inset:0;z-index:9500;display:grid;place-items:center;padding:var(--gutter);
  opacity:0;visibility:hidden;transition:opacity .5s var(--ease),visibility .5s}
.lightbox.is-open{opacity:1;visibility:visible}
.lightbox__scrim{position:absolute;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(22px) saturate(140%);-webkit-backdrop-filter:blur(22px) saturate(140%)}
.lightbox__close{position:absolute;top:calc(var(--gutter));right:var(--gutter);z-index:2;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;color:#fff;cursor:none;
  background:rgba(255,255,255,.06);border:1px solid var(--line);backdrop-filter:blur(10px);transition:background .3s,transform .3s var(--ease)}
.lightbox__close:hover{background:var(--red);transform:rotate(90deg)}
.lightbox__close svg{width:20px;height:20px}
.lightbox__panel{position:relative;z-index:1;width:min(92vw,1100px);border-radius:16px;padding:14px;
  transform:scale(.94) translateY(16px);transition:transform .6s var(--ease)}
.lightbox.is-open .lightbox__panel{transform:none}
.lightbox__stage{position:relative;aspect-ratio:16/9;border-radius:10px;overflow:hidden;background:#000;display:grid;place-items:center}
.lightbox__stage video,.lightbox__stage iframe{width:100%;height:100%;object-fit:cover;border:0}
.lightbox__ph{position:absolute;inset:0}
.lightbox__ph-note{position:relative;z-index:1;font:400 11px var(--ff);letter-spacing:.14em;text-transform:uppercase;color:#fff;background:rgba(0,0,0,.4);padding:10px 16px;border-radius:100px;border:1px solid var(--line)}
.lightbox__info{display:flex;align-items:baseline;justify-content:space-between;gap:12px;padding:14px 6px 4px}
.lightbox__info h3{font:400 14px var(--ff);text-transform:uppercase;letter-spacing:.04em}
.lightbox__info span{font:400 11px var(--ff);color:var(--muted);text-transform:uppercase;letter-spacing:.06em}

/* =========================================================
   CATEGORY VIEW (curtain)
   ========================================================= */
.catview{position:fixed;inset:0;z-index:9400;opacity:0;visibility:hidden;transition:opacity .5s var(--ease),visibility .5s}
.catview.is-open{opacity:1;visibility:visible}
.catview__scrim{position:absolute;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(20px) saturate(140%);-webkit-backdrop-filter:blur(20px) saturate(140%)}
.catview__panel{position:absolute;inset:clamp(10px,1.6vw,26px);border-radius:18px;padding:clamp(24px,4vw,64px);overflow-y:auto;overflow-x:hidden;
  transform:translateY(102%);transition:transform .85s var(--ease-2)}
.catview.is-open .catview__panel{transform:translateY(0)}
.catview__close{position:absolute;top:clamp(16px,2vw,28px);right:clamp(16px,2vw,28px);z-index:5;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;color:#fff;cursor:none;
  background:rgba(255,255,255,.06);border:1px solid var(--line);backdrop-filter:blur(10px);transition:background .3s,transform .3s var(--ease)}
.catview__close:hover{background:var(--red);transform:rotate(90deg)}
.catview__close svg{width:20px;height:20px}
.catview__bg{position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);z-index:0;pointer-events:none;text-align:center;white-space:nowrap;
  font:700 clamp(3.5rem,20vw,17rem) var(--ff);line-height:.78;text-transform:uppercase;letter-spacing:-.02em;
  background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.01));-webkit-background-clip:text;background-clip:text;color:transparent}
.catview__head{position:relative;z-index:2;display:flex;align-items:baseline;gap:14px;margin-bottom:clamp(22px,3vw,40px)}
.catview__count{font:400 11px var(--ff);color:var(--muted);letter-spacing:.1em}
.catview__grid{position:relative;z-index:2;display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(16px,2vw,28px)}
.catview__empty{position:relative;z-index:2;font:400 12px var(--ff);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding:48px 0;text-align:center}
@media (max-width:768px){.catview__grid{grid-template-columns:1fr}}

/* =========================================================
   REVEAL
   ========================================================= */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:980px){.services__grid{grid-template-columns:repeat(2,1fr)}.contact__inner{grid-template-columns:1fr;gap:44px}}
@media (max-width:768px){
  .nav__links{display:none}.nav__toggle{display:flex}
  .work__grid{grid-template-columns:1fr}
  .card{aspect-ratio:16/10}
  .services__grid{grid-template-columns:1fr}
  .hero__foot{flex-direction:column;align-items:flex-start;gap:12px}
  .hero__meta{text-align:left}.hero__mark{width:80vw}
  .footer{min-height:auto}
}

/* =========================================================
   REDUCED MOTION
   ========================================================= */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .reveal,.card{opacity:1;transform:none}
  .grain{display:none}
}
