/* ===================================================================
   TROUBLEMOVIES — Cinematic Design System v2
=================================================================== */
:root{
  --bg:#07040d; --bg-soft:#0e0819; --bg-card:#130c22;
  --line:rgba(255,255,255,.08); --line-2:rgba(255,255,255,.14);
  --ink:#f6f3fb; --muted:#9a8fb4; --muted-dim:#6c6285;
  --violet:#b98cff; --violet-hi:#cda9ff; --magenta:#ff5c8a; --amber:#ffb37a;
  --grad:linear-gradient(105deg,#b98cff 0%,#ff5c8a 100%);
  --glow:rgba(185,140,255,.45);
  --display:"Bricolage Grotesque",system-ui,sans-serif;
  --body:"Inter",system-ui,sans-serif; --mono:"Space Grotesk",monospace;
  --ease:cubic-bezier(.22,1,.36,1); --max:1280px;
}
*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{ background:var(--bg); color:var(--ink); font-family:var(--body); font-size:clamp(15px,1.1vw,17px); line-height:1.6; overflow-x:hidden; -webkit-font-smoothing:antialiased; }
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--violet); color:#0a0710; }
::-webkit-scrollbar{ width:10px; } ::-webkit-scrollbar-track{ background:var(--bg); }
::-webkit-scrollbar-thumb{ background:#2a2140; border-radius:10px; }
@media (hover:hover){ body{ cursor:none; } a,button,input,select,textarea,label{ cursor:none; } }

/* scroll progress */
.progress{ position:fixed; top:0; left:0; height:3px; width:0; background:var(--grad); z-index:9999; box-shadow:0 0 12px var(--glow); }

/* ---------- helpers ---------- */
.eyebrow{ font-family:var(--mono); font-size:.72rem; letter-spacing:.28em; text-transform:uppercase; color:var(--violet); display:inline-flex; align-items:center; gap:.6em; margin-bottom:1.1rem; }
.eyebrow::before{ content:""; width:26px; height:1px; background:var(--violet); opacity:.6; }
.section__head{ max-width:820px; margin:0 auto clamp(2.5rem,5vw,4.5rem); text-align:center; }
.section__head .eyebrow{ justify-content:center; }
.section__title{ font-family:var(--display); font-weight:700; font-size:clamp(2.1rem,5.4vw,3.8rem); line-height:1.02; letter-spacing:-.025em; }
.section__lead{ color:var(--muted); margin-top:1.1rem; font-size:1.06rem; }

/* split-word reveal */
[data-split] .word{ display:inline-block; overflow:hidden; vertical-align:top; }
[data-split] .word i{ display:inline-block; transform:translateY(110%); transition:transform .85s var(--ease); font-style:inherit; }
[data-split].in .word i{ transform:none; }
[data-split].in .word:nth-child(2) i{ transition-delay:.05s }
[data-split].in .word:nth-child(3) i{ transition-delay:.1s }
[data-split].in .word:nth-child(4) i{ transition-delay:.15s }
[data-split].in .word:nth-child(5) i{ transition-delay:.2s }
[data-split].in .word:nth-child(6) i{ transition-delay:.25s }
[data-split].in .word:nth-child(n+7) i{ transition-delay:.3s }

/* ---------- buttons ---------- */
.btn{ --pad:.95rem 1.7rem; font-family:var(--mono); font-size:.92rem; font-weight:500; display:inline-flex; align-items:center; gap:.6em; padding:var(--pad); border-radius:100px; border:1px solid transparent; background:var(--grad); color:#0a0710; transition:transform .4s var(--ease),box-shadow .4s var(--ease),filter .3s; white-space:nowrap; }
.btn:hover{ box-shadow:0 14px 44px -8px var(--glow); filter:brightness(1.08); }
.btn--sm{ --pad:.6rem 1.15rem; font-size:.82rem; }
.btn--ghost{ background:transparent; color:var(--ink); border-color:var(--line-2); }
.btn--ghost:hover{ border-color:var(--violet); box-shadow:none; background:rgba(185,140,255,.06); }
.btn--full{ width:100%; justify-content:center; padding:1.1rem; }

/* ===================================================================
   LOADER
=================================================================== */
.loader{ position:fixed; inset:0; z-index:10000; background:var(--bg); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:1.5rem; transition:opacity .8s var(--ease),visibility .8s; }
.loader.hide{ opacity:0; visibility:hidden; }
.loader__eyes{ display:flex; gap:30px; }
.loader__eyes span{ width:13px; height:13px; border-radius:50%; background:#fff; box-shadow:0 0 26px 7px var(--glow); animation:blink 1.5s var(--ease) infinite; }
.loader__eyes span:nth-child(2){ animation-delay:.05s; }
@keyframes blink{ 0%,90%,100%{ transform:scaleY(1); } 95%{ transform:scaleY(.08); } }
.loader__logo{ height:clamp(44px,9vw,70px); width:auto; animation:logoIn 1s var(--ease) both .2s; }
@keyframes logoIn{ from{ opacity:0; transform:translateY(12px); } }
.loader__bar{ width:150px; height:2px; background:rgba(255,255,255,.12); border-radius:2px; overflow:hidden; }
.loader__bar i{ display:block; height:100%; width:0; background:var(--grad); animation:fill 1.7s var(--ease) forwards; }
@keyframes fill{ to{ width:100%; } }

/* ===================================================================
   CURSOR
=================================================================== */
.cursor,.cursor-dot{ position:fixed; top:0; left:0; pointer-events:none; z-index:9000; border-radius:50%; }
.cursor{ width:36px; height:36px; border:1px solid var(--violet); transform:translate(-50%,-50%); transition:width .28s var(--ease),height .28s var(--ease),background .28s,border-color .28s; display:flex; align-items:center; justify-content:center; mix-blend-mode:screen; }
.cursor-dot{ width:5px; height:5px; background:var(--violet); transform:translate(-50%,-50%); transition:opacity .2s; }
.cursor__label{ font-family:var(--mono); font-size:.6rem; letter-spacing:.12em; color:#0a0710; opacity:0; transition:opacity .2s; text-transform:uppercase; }
.cursor.grow{ width:60px; height:60px; background:rgba(185,140,255,.16); border-color:transparent; mix-blend-mode:normal; }
.cursor.play{ width:84px; height:84px; background:var(--grad); border-color:transparent; mix-blend-mode:normal; }
.cursor.play .cursor__label{ opacity:1; }
.cursor.play ~ .cursor-dot{ opacity:0; }
@media (hover:none){ .cursor,.cursor-dot{ display:none; } }

/* ===================================================================
   NAV
=================================================================== */
.nav{ position:fixed; inset:0 0 auto 0; z-index:500; display:flex; align-items:center; justify-content:space-between; padding:1.05rem clamp(1.1rem,4vw,2.6rem); transition:background .4s var(--ease),padding .4s var(--ease),border-color .4s; border-bottom:1px solid transparent; }
.nav.scrolled{ background:rgba(7,4,13,.72); backdrop-filter:blur(14px); border-color:var(--line); padding-top:.7rem; padding-bottom:.7rem; }
.brand{ display:flex; align-items:center; }
.brand__mark{ height:30px; width:auto; flex:none; }
.nav__links{ display:flex; gap:2rem; }
.nav__links a{ font-family:var(--mono); font-size:.86rem; color:var(--muted); position:relative; padding:.2rem 0; transition:color .3s; }
.nav__links a::after{ content:""; position:absolute; left:0; bottom:-2px; width:0; height:1px; background:var(--grad); transition:width .35s var(--ease); }
.nav__links a:hover{ color:var(--ink); } .nav__links a:hover::after,.nav__links a.active::after{ width:100%; } .nav__links a.active{ color:var(--ink); }
.nav__right{ display:flex; align-items:center; gap:1rem; }
.lang{ background:none; border:1px solid var(--line-2); color:var(--muted); font-family:var(--mono); font-size:.78rem; padding:.32rem .55rem; border-radius:100px; display:flex; gap:.3em; transition:border-color .3s,color .3s; }
.lang:hover{ border-color:var(--violet); color:var(--ink); }
.lang .lang__off{ opacity:.4; } .lang.en .lang__on{ opacity:.4; } .lang.en .lang__off{ opacity:1; color:var(--violet); } .lang:not(.en) .lang__on{ color:var(--violet); }
.nav__ig{ color:var(--muted); display:flex; transition:color .3s; } .nav__ig:hover{ color:var(--violet); }
.burger{ display:none; background:none; border:none; flex-direction:column; gap:6px; padding:6px; }
.burger span{ width:24px; height:2px; background:var(--ink); border-radius:2px; transition:.35s var(--ease); }
.burger[aria-expanded="true"] span:first-child{ transform:translateY(4px) rotate(45deg); }
.burger[aria-expanded="true"] span:last-child{ transform:translateY(-4px) rotate(-45deg); }

/* ===================================================================
   HERO — flashlight reveal
=================================================================== */
.hero{ position:relative; min-height:100svh; display:flex; align-items:center; overflow:hidden; background:#050309; }
.hero__stage{ position:absolute; inset:0; z-index:0; will-change:transform,opacity; }
.hero__layer{ position:absolute; inset:0; }
.hero__deer{ position:absolute; top:50%; left:50%; width:min(1080px,128vw); max-width:none; transform:translate(-50%,-46%); }
.hero__layer--ambient{ opacity:.18; filter:brightness(.85) saturate(.9); }
.hero__layer--torch{
  animation:breathe 5s ease-in-out infinite;
  -webkit-mask-image:radial-gradient(circle var(--torch,23vmax) at var(--mx,50%) var(--my,42%),#000 0%,#000 24%,transparent 62%);
          mask-image:radial-gradient(circle var(--torch,23vmax) at var(--mx,50%) var(--my,42%),#000 0%,#000 24%,transparent 62%);
}
@keyframes breathe{ 0%,100%{ filter:brightness(.95) } 50%{ filter:brightness(1.14) } }
.hero__embers{ position:absolute; inset:0; pointer-events:none; }
.hero__vignette{ position:absolute; inset:0; background:radial-gradient(78% 70% at 50% 40%,transparent 32%,var(--bg) 90%); }
.hero__grain{ position:absolute; inset:0; opacity:.05; pointer-events:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%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"); }

.hero__inner{ position:relative; z-index:2; width:100%; max-width:var(--max); margin:0 auto; padding:0 clamp(1.2rem,5vw,2.6rem); text-align:center; }
.hero__eyebrow{ justify-content:center; opacity:0; animation:up .8s var(--ease) both .9s; }
.hero__title{ font-family:var(--display); font-weight:800; font-size:clamp(2.9rem,9.4vw,7.4rem); line-height:.92; letter-spacing:-.035em; margin:.3rem 0 1.4rem; }
.hero__title .l{ display:block; overflow:hidden; }
.hero__title .l > *{ display:inline-block; transform:translateY(110%); animation:rise 1s var(--ease) forwards; }
.hero__title em{ font-style:normal; background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.hero__title .l:nth-child(1) > *{ animation-delay:.4s; }
.hero__title .l:nth-child(2) > *{ animation-delay:.55s; }
@keyframes rise{ to{ transform:none; } }
.hero__sub{ max-width:600px; margin:0 auto 2rem; color:var(--muted); font-size:clamp(1rem,1.4vw,1.18rem); opacity:0; animation:up .8s var(--ease) both 1.05s; }
.hero__cta{ display:flex; gap:1.4rem; justify-content:center; align-items:center; flex-wrap:wrap; opacity:0; animation:up .8s var(--ease) both 1.2s; }
@keyframes up{ from{ opacity:0; transform:translateY(20px); } to{ opacity:1; transform:none; } }

/* reel chip */
.hero__reel{ display:inline-flex; align-items:center; gap:.85rem; background:none; border:none; color:var(--ink); text-align:left; }
.hero__reel-ring{ width:48px; height:48px; border-radius:50%; border:1px solid var(--line-2); display:flex; align-items:center; justify-content:center; position:relative; transition:.4s var(--ease); flex:none; }
.hero__reel-ring::before{ content:""; position:absolute; inset:-1px; border-radius:50%; border:1px solid var(--violet); opacity:.5; animation:ripple 2.4s ease-out infinite; }
@keyframes ripple{ 0%{ transform:scale(1); opacity:.6 } 100%{ transform:scale(1.7); opacity:0 } }
.hero__reel-tri{ width:0; height:0; border-left:11px solid var(--ink); border-top:7px solid transparent; border-bottom:7px solid transparent; margin-left:3px; transition:border-left-color .3s; }
.hero__reel:hover .hero__reel-ring{ background:var(--grad); border-color:transparent; }
.hero__reel:hover .hero__reel-tri{ border-left-color:#0a0710; }
.hero__reel-txt{ display:flex; flex-direction:column; line-height:1.25; }
.hero__reel-txt b{ font-family:var(--mono); font-size:.78rem; color:var(--violet); font-weight:500; }
.hero__reel-txt i{ font-style:normal; font-size:.86rem; color:var(--muted); }

.hero__hint{ position:absolute; left:50%; bottom:6.5rem; transform:translateX(-50%); z-index:2; font-family:var(--mono); font-size:.68rem; letter-spacing:.22em; text-transform:uppercase; color:var(--muted-dim); opacity:0; animation:up .8s var(--ease) both 1.6s, pulse 2.4s ease-in-out infinite 2s; pointer-events:none; }
@keyframes pulse{ 0%,100%{ opacity:.55 } 50%{ opacity:.18 } }
.hero__scroll{ position:absolute; bottom:1.8rem; left:50%; transform:translateX(-50%); z-index:2; font-family:var(--mono); font-size:.68rem; letter-spacing:.25em; text-transform:uppercase; color:var(--muted); display:flex; flex-direction:column; align-items:center; gap:.5rem; }
.hero__scroll i{ width:1px; height:32px; background:linear-gradient(var(--violet),transparent); animation:scrolldn 1.8s ease-in-out infinite; }
@keyframes scrolldn{ 0%{ transform:scaleY(0); transform-origin:top } 50%{ transform:scaleY(1); transform-origin:top } 50.1%{ transform-origin:bottom } 100%{ transform:scaleY(0); transform-origin:bottom } }

/* ===================================================================
   MARQUEE
=================================================================== */
.marquee{ border-block:1px solid var(--line); padding:1.05rem 0; overflow:hidden; background:var(--bg-soft); }
.marquee__track{ display:flex; align-items:center; gap:2rem; width:max-content; animation:scroll-x 30s linear infinite; }
.marquee__track span{ font-family:var(--display); font-weight:700; font-size:clamp(1.4rem,3vw,2.3rem); white-space:nowrap; }
.marquee__track b{ color:var(--violet); font-size:1.1rem; }
@keyframes scroll-x{ to{ transform:translateX(-50%); } }
.marquee:hover .marquee__track{ animation-play-state:paused; }

/* ===================================================================
   WORK — editorial grid
=================================================================== */
.work{ max-width:var(--max); margin:0 auto; padding:clamp(4.5rem,9vw,7.5rem) clamp(1.2rem,5vw,2.6rem); }
.work__grid{ display:grid; grid-template-columns:repeat(6,1fr); gap:clamp(.9rem,1.6vw,1.5rem); }
.work__card{ position:relative; border-radius:16px; overflow:hidden; aspect-ratio:16/10; border:1px solid var(--line); background:var(--bg-card); opacity:0; transform:translateY(40px) scale(.98); transition:opacity .8s var(--ease),transform .8s var(--ease),border-color .4s; }
.work__card.in{ opacity:1; transform:none; }
.work__card--lg{ grid-column:span 4; } .work__card--sm{ grid-column:span 2; }
.work__media{ position:absolute; inset:0; }
.work__media img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease),filter .6s; filter:saturate(.82) brightness(.72); }
.work__card:hover{ border-color:var(--line-2); }
.work__card:hover .work__media img{ transform:scale(1.08); filter:saturate(1.05) brightness(.92); }
.work__overlay{ position:absolute; inset:0; background:linear-gradient(transparent 30%,rgba(7,4,13,.5) 60%,rgba(7,4,13,.95)); display:flex; flex-direction:column; justify-content:flex-end; padding:clamp(1.1rem,2.5vw,1.9rem); z-index:2; }
.work__cat{ font-family:var(--mono); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--violet); margin-bottom:.45rem; display:flex; gap:.7em; align-items:center; }
.work__cat span{ color:var(--muted-dim); }
.work__name{ font-family:var(--display); font-weight:700; font-size:clamp(1.3rem,2.6vw,2.1rem); letter-spacing:-.015em; transform:translateY(6px); transition:transform .5s var(--ease); }
.work__card:hover .work__name{ transform:none; }
.work__tag{ position:absolute; top:1.1rem; left:1.1rem; z-index:3; font-family:var(--mono); font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink); background:rgba(7,4,13,.55); backdrop-filter:blur(6px); border:1px solid var(--line-2); padding:.3rem .7rem; border-radius:100px; }
.work__play{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%) scale(.6); width:66px; height:66px; border-radius:50%; background:rgba(255,255,255,.1); backdrop-filter:blur(6px); border:1px solid rgba(255,255,255,.35); display:flex; align-items:center; justify-content:center; color:#fff; opacity:0; transition:.45s var(--ease); z-index:3; }
.work__play::after{ content:""; width:0; height:0; border-left:14px solid #fff; border-top:9px solid transparent; border-bottom:9px solid transparent; margin-left:4px; }
.work__card:hover .work__play{ opacity:1; transform:translate(-50%,-50%) scale(1); }
@media (hover:none){ .work__play{ opacity:.85; transform:translate(-50%,-50%) scale(.85); } }

/* ===================================================================
   SERVICES
=================================================================== */
.services{ max-width:var(--max); margin:0 auto; padding:clamp(4rem,9vw,7rem) clamp(1.2rem,5vw,2.6rem); }
.svc{ border-top:1px solid var(--line); }
.svc__item{ display:flex; align-items:center; gap:clamp(1rem,4vw,3rem); padding:clamp(1.6rem,3.5vw,2.4rem) .5rem; border-bottom:1px solid var(--line); position:relative; transition:padding-left .45s var(--ease); }
.svc__item::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:0; background:var(--grad); transition:width .45s var(--ease); opacity:.07; }
.svc__item:hover{ padding-left:1.6rem; } .svc__item:hover::before{ width:100%; }
.svc__num{ font-family:var(--mono); font-size:.9rem; color:var(--violet); flex:none; width:2.4em; }
.svc__body h3{ font-family:var(--display); font-weight:700; font-size:clamp(1.35rem,3vw,2.1rem); letter-spacing:-.015em; }
.svc__body p{ color:var(--muted); margin-top:.5rem; max-width:62ch; font-size:1rem; }
.svc__arrow{ margin-left:auto; font-size:1.6rem; color:var(--muted-dim); transition:transform .45s var(--ease),color .45s; flex:none; }
.svc__item:hover .svc__arrow{ transform:translate(6px,-6px); color:var(--violet); }

/* ===================================================================
   ABOUT
=================================================================== */
.about{ max-width:var(--max); margin:0 auto; padding:clamp(5rem,11vw,9rem) clamp(1.2rem,5vw,2.6rem); }
.about__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2.5rem,6vw,5rem); align-items:start; }
.about__title{ font-family:var(--display); font-weight:700; font-size:clamp(1.9rem,4.2vw,3.2rem); line-height:1.05; letter-spacing:-.02em; margin-bottom:2rem; }
.about__media{ position:relative; border-radius:16px; overflow:hidden; border:1px solid var(--line); }
.about__media::after{ content:""; position:absolute; inset:0; background:linear-gradient(transparent 50%,var(--bg)); }
.about__media img{ width:100%; height:360px; object-fit:cover; object-position:center 28%; transition:transform 1.2s var(--ease); }
.about__media:hover img{ transform:scale(1.05); }
.about__media-cap{ position:absolute; left:1rem; bottom:1rem; z-index:2; font-family:var(--mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); }
.about__right p{ color:var(--muted); font-size:1.12rem; margin-bottom:1.3rem; } .about__right p b{ color:var(--ink); }
.stats{ display:grid; grid-template-columns:repeat(2,1fr); gap:2rem 1rem; margin-top:2.5rem; border-top:1px solid var(--line); padding-top:2.5rem; }
.stat__num,.stat__plus{ font-family:var(--display); font-weight:800; font-size:clamp(2.4rem,5vw,3.6rem); line-height:1; background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.stat p{ font-family:var(--mono); font-size:.76rem; letter-spacing:.06em; color:var(--muted); margin-top:.6rem; text-transform:uppercase; }

/* ===================================================================
   PROCESS
=================================================================== */
.process{ max-width:var(--max); margin:0 auto; padding:clamp(4rem,9vw,7rem) clamp(1.2rem,5vw,2.6rem); }
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem; }
.step{ padding:1.9rem; border:1px solid var(--line); border-radius:16px; background:linear-gradient(160deg,var(--bg-card),transparent); transition:transform .5s var(--ease),border-color .5s; }
.step:hover{ transform:translateY(-6px); border-color:rgba(185,140,255,.4); }
.step__n{ font-family:var(--mono); font-size:.85rem; color:var(--violet); }
.step h3{ font-family:var(--display); font-weight:700; font-size:1.35rem; margin:.9rem 0 .5rem; }
.step p{ color:var(--muted); font-size:.95rem; }

/* ===================================================================
   CLIENTS + QUOTE
=================================================================== */
.clients{ max-width:var(--max); margin:0 auto; padding:clamp(3rem,7vw,5rem) clamp(1.2rem,5vw,2.6rem); text-align:center; border-top:1px solid var(--line); }
.clients__label{ font-family:var(--mono); font-size:.78rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin-bottom:2rem; }
.clients__row{ display:flex; align-items:center; justify-content:center; gap:clamp(2rem,6vw,4.5rem); flex-wrap:wrap; }
.clients__row img{ height:42px; width:auto; object-fit:contain; filter:grayscale(1) brightness(0) invert(1); opacity:.5; transition:opacity .4s,filter .4s; }
.clients__row img:hover{ opacity:1; filter:none; }
.clients__more{ font-family:var(--mono); color:var(--muted-dim); font-size:.9rem; }
.quote{ max-width:780px; margin:clamp(3rem,7vw,5rem) auto 0; }
.quote blockquote{ font-family:var(--display); font-weight:600; font-size:clamp(1.4rem,3.2vw,2.2rem); line-height:1.25; letter-spacing:-.01em; }
.quote figcaption{ margin-top:1.4rem; font-family:var(--mono); font-size:.85rem; color:var(--muted); }
.quote figcaption b{ color:var(--violet); }

/* ===================================================================
   CONTACT
=================================================================== */
.contact{ position:relative; margin-top:clamp(3rem,7vw,5rem); padding:clamp(4rem,9vw,7rem) clamp(1.2rem,5vw,2.6rem); overflow:hidden; }
.contact__bg{ position:absolute; inset:0; z-index:0; }
.contact__glow{ position:absolute; top:0; left:50%; transform:translate(-50%,-40%); width:900px; height:600px; max-width:120vw; background:radial-gradient(circle,rgba(185,140,255,.18),transparent 60%); }
.contact__inner{ position:relative; z-index:1; max-width:var(--max); margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,6vw,5rem); align-items:start; }
.contact__title{ font-family:var(--display); font-weight:800; font-size:clamp(2rem,5vw,3.4rem); line-height:1.02; letter-spacing:-.025em; }
.contact__lead{ color:var(--muted); margin-top:1.1rem; font-size:1.1rem; max-width:42ch; }
.contact__direct{ margin-top:2rem; display:flex; flex-direction:column; gap:.6rem; font-family:var(--mono); font-size:.95rem; }
.contact__direct a{ color:var(--muted); transition:color .3s; width:fit-content; } .contact__direct a:hover{ color:var(--violet); }
.contact__mail{ font-size:1.05rem; color:var(--ink) !important; border-bottom:1px solid var(--line); padding-bottom:.4rem; }
.form{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.field{ position:relative; } .field--full{ grid-column:1/-1; }
.field input,.field select,.field textarea{ width:100%; background:var(--bg-card); border:1px solid var(--line); border-radius:12px; color:var(--ink); font-family:var(--body); font-size:.98rem; padding:1.2rem 1rem .55rem; transition:border-color .3s,box-shadow .3s; resize:none; }
.field textarea{ padding-top:1.3rem; }
.field select{ padding:1.05rem 1rem; color:var(--muted); appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath fill='%239a8fb4' d='M1 1l5 5 5-5'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 1rem center; }
.field select:valid{ color:var(--ink); }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--violet); box-shadow:0 0 0 3px rgba(185,140,255,.12); }
.field label{ position:absolute; left:1rem; top:1rem; color:var(--muted); font-size:.98rem; pointer-events:none; transition:.25s var(--ease); }
.field input:focus + label,.field input:not(:placeholder-shown) + label,.field textarea:focus + label,.field textarea:not(:placeholder-shown) + label{ top:.4rem; font-size:.66rem; color:var(--violet); letter-spacing:.04em; }
.field option{ background:var(--bg-soft); color:var(--ink); }
.form__note{ grid-column:1/-1; font-family:var(--mono); font-size:.85rem; color:var(--violet); min-height:1.2em; text-align:center; }
.form .btn--full{ grid-column:1/-1; }

/* ===================================================================
   FOOTER
=================================================================== */
.footer{ border-top:1px solid var(--line); padding:0 clamp(1.2rem,5vw,2.6rem) 2rem; max-width:var(--max); margin:0 auto; }
.footer__cta{ padding:clamp(3rem,8vw,6rem) 0; border-bottom:1px solid var(--line); text-align:center; }
.footer__big{ font-family:var(--display); font-weight:700; font-size:clamp(1.8rem,6vw,4rem); letter-spacing:-.03em; line-height:1.05; background:linear-gradient(90deg,var(--ink),var(--ink)); -webkit-background-clip:text; background-clip:text; transition:.4s var(--ease); display:inline-block; }
.footer__big:hover{ background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; transform:translateY(-2px); }
.footer__top{ display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:1rem; padding-top:2.4rem; }
.brand--lg .brand__mark{ height:44px; }
.footer__tag{ font-family:var(--display); font-size:clamp(1.1rem,2.5vw,1.6rem); color:var(--muted); font-weight:600; }
.footer__links{ display:flex; gap:2rem; flex-wrap:wrap; margin:2.4rem 0; padding-block:1.6rem; border-block:1px solid var(--line); }
.footer__links a{ font-family:var(--mono); font-size:.86rem; color:var(--muted); transition:color .3s; } .footer__links a:hover{ color:var(--violet); }
.footer__bottom{ display:flex; align-items:center; justify-content:space-between; font-family:var(--mono); font-size:.8rem; color:var(--muted-dim); }
.footer__deer{ color:var(--violet); }

/* ===================================================================
   LIGHTBOX
=================================================================== */
.lightbox{ position:fixed; inset:0; z-index:8000; background:rgba(4,2,8,.94); backdrop-filter:blur(10px); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:1.2rem; padding:1.5rem; opacity:0; visibility:hidden; transition:opacity .4s var(--ease),visibility .4s; }
.lightbox.open{ opacity:1; visibility:visible; }
.lightbox__frame{ width:min(1040px,100%); aspect-ratio:16/9; border-radius:14px; overflow:hidden; box-shadow:0 30px 90px -20px var(--glow); transform:scale(.95); transition:transform .5s var(--ease); }
.lightbox.open .lightbox__frame{ transform:scale(1); }
.lightbox__frame #lightboxPlayer{ width:100%; height:100%; }
.lightbox__frame iframe{ display:block; width:100%; height:100%; border:0; }
.lightbox__title{ font-family:var(--mono); font-size:.85rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }
.lightbox__close{ position:absolute; top:1.4rem; right:1.6rem; background:none; border:1px solid var(--line-2); color:var(--ink); width:46px; height:46px; border-radius:50%; font-size:1.1rem; transition:.3s; }
.lightbox__close:hover{ border-color:var(--violet); transform:rotate(90deg); }

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

/* ===================================================================
   RESPONSIVE
=================================================================== */
@media (max-width:900px){
  .about__grid,.contact__inner{ grid-template-columns:1fr; }
  .steps{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:760px){
  .nav__links{ position:fixed; inset:0 0 0 auto; width:min(82vw,330px); background:var(--bg-soft); flex-direction:column; justify-content:center; gap:1.8rem; padding:2rem; transform:translateX(100%); transition:transform .5s var(--ease); border-left:1px solid var(--line); }
  .nav__links.open{ transform:none; box-shadow:-30px 0 80px rgba(0,0,0,.6); }
  .nav__links a{ font-size:1.3rem; }
  .burger{ display:flex; } .nav__ig,.nav .btn--sm{ display:none; }
  .work__grid{ grid-template-columns:1fr; }
  .work__card--lg,.work__card--sm{ grid-column:auto; aspect-ratio:16/11; }
  .form{ grid-template-columns:1fr; }
  .footer__top{ flex-direction:column; align-items:flex-start; }
  .hero__layer--ambient{ opacity:.28; }
  .hero__layer--torch{ -webkit-mask-image:radial-gradient(circle var(--torch,42vmax) at var(--mx,50%) var(--my,40%),#000 0%,#000 32%,transparent 72%); mask-image:radial-gradient(circle var(--torch,42vmax) at var(--mx,50%) var(--my,40%),#000 0%,#000 32%,transparent 72%); }
  .hero__cta{ flex-direction:column; gap:1.6rem; }
  .hero__hint{ bottom:5.5rem; }
}
@media (max-width:420px){
  .stats{ grid-template-columns:1fr 1fr; }
}

@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.01ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; scroll-behavior:auto !important; }
  .reveal,[data-split] .word i,.work__card{ opacity:1 !important; transform:none !important; }
  .hero__layer--torch{ -webkit-mask-image:none; mask-image:none; opacity:.5; }
}
