/* ============================================================
   BLACK MAGIC ENTERTAINMENT — "Ink & Ember"
   Type: Forma DJR Display (display) · Aktiv Grotesk (body) · Logic Monospace (labels)
   ============================================================ */

:root{
  --ink:        #0a0a0c;
  --ink-2:      #0e0e12;
  --ash:        #15151a;
  --ash-2:      #1c1c22;
  --bone:       #ece7df;
  --smoke:      #9a958d;
  --smoke-dim:  #8a857d;
  --ember:      #e2531c;
  --ember-hot:  #ff7d32;
  --ember-deep: #a82408;
  --line:       rgba(236,231,223,.10);
  --line-2:     rgba(236,231,223,.16);

  --font-display:'forma-djr-display', 'Helvetica Neue', system-ui, sans-serif;
  --font-serif:'Cinzel', 'Trajan Pro', 'Times New Roman', Georgia, serif;
  --font-mono:'logic-monospace', ui-monospace, monospace;
  --font-body:'aktiv-grotesk', system-ui, sans-serif;

  --pad: clamp(1.25rem, 5vw, 6rem);
  --maxw: 1500px;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-font-smoothing:antialiased; }
html.cursor-on, html.cursor-on *{ cursor:none; }
body{
  background:var(--ink);
  color:var(--bone);
  font-family:var(--font-body);
  font-weight:400;
  line-height:1.55;
  overflow-x:hidden;
}

img,video{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ cursor:pointer; }
em{ font-style:italic; color:var(--bone); }

::selection{ background:var(--ember); color:#fff; }

:focus-visible{ outline:2px solid var(--ember); outline-offset:3px; border-radius:4px; }
.btn:focus-visible, .work-card__play:focus-visible, .lightbox__close:focus-visible, .nav__cta:focus-visible{ outline:2px solid var(--ember-hot); outline-offset:4px; }

/* skip link */
.skip-link{ position:absolute; left:-9999px; top:0; z-index:2000; }
.skip-link:focus{ left:1rem; top:1rem; background:var(--ember); color:#fff; padding:.7rem 1.1rem; border-radius:6px; font-family:var(--font-mono); font-size:.8rem; }

/* ---------- atmosphere ---------- */
.grain{
  position:fixed; inset:-10%; width:120%; height:120%; z-index:9000; pointer-events:none; opacity:.06;
  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='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:grainShift .6s steps(1) infinite;
}
@keyframes grainShift{
  0%{transform:translate(0,0)} 20%{transform:translate(-4%,-3%)} 40%{transform:translate(3%,-5%)}
  60%{transform:translate(-3%,4%)} 80%{transform:translate(5%,2%)} 100%{transform:translate(0,0)}
}
.vignette{
  position:fixed; inset:0; z-index:8000; pointer-events:none;
  background:radial-gradient(120% 90% at 50% 30%, transparent 55%, rgba(0,0,0,.55) 100%);
}
/* smoldering ember WebGL background (created by ember-bg.js) */
.ember-bg{ position:fixed; inset:0; width:100%; height:100%; z-index:-1; pointer-events:none; }
.gearworks{ position:fixed; inset:0; width:100%; height:100%; z-index:-2; pointer-events:none; }
.gear-veil{ position:fixed; inset:0; width:100%; height:100%; z-index:-1; pointer-events:none; }
.cinema-bg{ position:fixed; inset:0; width:100%; height:100%; z-index:-1; pointer-events:none; }

/* ---------- custom cursor ---------- */
.cursor{ position:fixed; top:0; left:0; z-index:9999; pointer-events:none; mix-blend-mode:difference; }
.cursor__dot{ position:absolute; width:6px; height:6px; border-radius:50%; background:var(--bone); transform:translate(-50%,-50%); }
.cursor__ring{ position:absolute; width:38px; height:38px; border:1px solid rgba(236,231,223,.6); border-radius:50%; transform:translate(-50%,-50%); transition:width .25s, height .25s, opacity .25s; }
.cursor.is-hover .cursor__ring{ width:62px; height:62px; border-color:var(--ember); }
@media (max-width:900px){ .cursor{ display:none; } }

/* ---------- ember text ---------- */
.ember-text{
  position:relative;
  /* padding gives the italic/bold glyph overhang room so background-clip:text doesn't cut letters */
  padding:.08em .14em; margin:0 -.07em;
  background:linear-gradient(95deg, var(--ember-deep), var(--ember) 40%, var(--ember-hot));
  -webkit-background-clip:text; background-clip:text; color:transparent;
  font-style:italic;
}
.muted{ color:var(--smoke); }
/* hero signature: the word "burn" glows like an ember */
.hero__title .ember-text{ animation:emberGlow 4.5s ease-in-out infinite; }
@keyframes emberGlow{
  0%,100%{ filter:drop-shadow(0 0 12px rgba(226,83,28,.30)); }
  45%{ filter:drop-shadow(0 0 28px rgba(255,125,50,.65)); }
  55%{ filter:drop-shadow(0 0 18px rgba(255,125,50,.45)); }
}

/* ============================================================ NAV */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:1000;
  display:flex; align-items:center; justify-content:space-between;
  padding:1.25rem var(--pad);
  transition:background .4s, padding .4s, border-color .4s, transform .45s cubic-bezier(.6,0,.2,1);
  border-bottom:1px solid transparent;
}
.nav.is-stuck{
  background:rgba(10,10,12,.72); backdrop-filter:blur(14px);
  padding-top:.85rem; padding-bottom:.85rem; border-color:var(--line);
}
.nav.nav--hidden{ transform:translateY(-100%); }
.brand{ display:flex; flex-direction:row; align-items:center; gap:.55rem; line-height:1; }
.brand__emblem{ width:38px; height:38px; image-rendering:pixelated; flex:0 0 auto; }
.brand__text{ display:flex; flex-direction:column; line-height:1; }
.brand__logo{ height:clamp(26px,3vw,34px); width:auto; display:block; }
.brand__mark{ font-family:var(--font-serif); font-weight:600; font-size:1rem; letter-spacing:.382em; }
.brand__sub{ font-family:var(--font-mono); font-size:.58rem; letter-spacing:.42em; color:var(--smoke); margin-top:.4rem; }
.nav__links{ display:flex; align-items:center; gap:2.2rem; font-family:var(--font-mono); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; }
.nav__links a{ color:var(--smoke); transition:color .25s; }
.nav__links a:hover{ color:var(--bone); }
.nav__cta{ color:var(--bone)!important; border:1px solid var(--line-2); padding:.6rem 1.1rem; border-radius:100px; transition:all .3s!important; }
.nav__cta:hover{ background:var(--ember); border-color:var(--ember); color:#fff!important; }
.nav__burger{ display:none; flex-direction:column; gap:6px; background:none; border:0; padding:4px; }
.nav__burger span{ width:26px; height:2px; background:var(--bone); transition:transform .3s, opacity .3s; transform-origin:center; }
.nav__burger.is-open span:nth-child(1){ transform:translateY(4px) rotate(45deg); }
.nav__burger.is-open span:nth-child(2){ transform:translateY(-4px) rotate(-45deg); }

/* ============================================================ HERO */
.hero{ position:relative; height:100svh; min-height:640px; overflow:hidden; display:flex; align-items:flex-end; }
.hero__media{ position:absolute; inset:0; z-index:0; background:radial-gradient(80% 60% at 18% 30%, rgba(226,83,28,.16), var(--ink) 62%); }
.hero__video{ width:100%; height:100%; object-fit:cover; background:var(--ash); filter:saturate(1.05) contrast(1.03); }
.hero__scrim{
  position:absolute; inset:0;
  background:
    linear-gradient(to top, var(--ink) 2%, rgba(10,10,12,.2) 38%, rgba(10,10,12,.55) 100%),
    radial-gradient(80% 60% at 15% 90%, rgba(226,83,28,.16), transparent 60%);
}
.hero__inner{ position:relative; z-index:2; padding:0 var(--pad) clamp(3rem,7vw,6rem); max-width:1100px; will-change:transform,opacity; }
.eyebrow{ font-family:var(--font-mono); font-size:.74rem; letter-spacing:.28em; text-transform:uppercase; color:var(--ember-hot); margin-bottom:1.6rem; }
.hero__title{
  font-family:var(--font-serif); font-weight:800;
  font-size:clamp(2.6rem, 8.4vw, 8.4rem); line-height:1.0; letter-spacing:.0618em; text-transform:uppercase;
}
.hero__title .line{ display:block; }
.hero__sub{ margin-top:1.8rem; max-width:48ch; font-size:clamp(1rem,1.5vw,1.25rem); color:var(--smoke); }
.hero__sub em{ color:var(--bone); }
.hero__actions{ display:flex; flex-wrap:wrap; gap:1rem; margin-top:2.4rem; }

.hero__meta{ position:absolute; z-index:2; font-family:var(--font-mono); font-size:.6rem; letter-spacing:.25em; color:var(--smoke); display:flex; flex-direction:column; gap:.35rem; }
.hero__meta--tl{ top:6.5rem; left:var(--pad); }
.hero__meta--tr{ top:6.5rem; right:var(--pad); text-align:right; }

.hero__scroll{ position:absolute; z-index:2; bottom:2rem; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:.6rem; font-family:var(--font-mono); font-size:.58rem; letter-spacing:.3em; color:var(--smoke); }
.hero__scroll-line{ width:1px; height:42px; background:linear-gradient(var(--ember),transparent); animation:scrollpulse 2s infinite; }
@keyframes scrollpulse{ 0%,100%{ opacity:.3; transform:scaleY(.7);} 50%{ opacity:1; transform:scaleY(1);} }

/* ---------- buttons ---------- */
.btn{ display:inline-flex; align-items:center; gap:.6rem; font-family:var(--font-mono); font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; padding:1rem 1.6rem; border-radius:100px; border:1px solid transparent; transition:transform .3s, background .3s, color .3s, border-color .3s; }
.btn--ember{ background:var(--ember); color:#fff; }
.btn--ember:hover{ background:var(--ember-hot); transform:translateY(-2px); box-shadow:0 14px 40px -10px rgba(226,83,28,.6); }
.btn--ghost{ border-color:var(--line-2); color:var(--bone); }
.btn--ghost:hover{ border-color:var(--bone); transform:translateY(-2px); }
.btn--lg{ padding:1.25rem 2.2rem; font-size:.85rem; }
.btn__icon{ display:inline-flex; }
.btn__icon svg{ display:block; }

/* ============================================================ MARQUEE */
.marquee{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:1.5rem 0; overflow:hidden; white-space:nowrap; background:var(--ink-2); }
.marquee__track{ display:inline-flex; align-items:center; gap:2.5rem; animation:scroll-x 55s linear infinite; }
.marquee__track span:not(.dot){ font-family:var(--font-display); font-weight:700; font-style:italic; font-size:clamp(1.5rem,3.2vw,2.6rem); text-transform:uppercase; letter-spacing:-.01em; color:var(--bone); }
.marquee__track .dot{ width:7px; height:7px; border-radius:50%; background:var(--ember); box-shadow:0 0 10px rgba(226,83,28,.7); }
@keyframes scroll-x{ to{ transform:translateX(-50%); } }

/* ============================================================ PROOF */
.proof{ max-width:var(--maxw); margin:0 auto; padding:2.6rem var(--pad); display:flex; flex-wrap:wrap; align-items:center; gap:1.2rem 2.4rem; border-bottom:1px solid var(--line); }
.proof__label{ font-family:var(--font-mono); font-size:.66rem; letter-spacing:.24em; text-transform:uppercase; color:var(--ember); }
.proof__list{ list-style:none; display:flex; flex-wrap:wrap; gap:1rem 2rem; }
.proof__list li{ font-family:var(--font-display); font-weight:400; font-size:clamp(1rem,1.6vw,1.3rem); color:var(--smoke); position:relative; }
.proof__list li:not(:last-child)::after{ content:"·"; position:absolute; right:-1.1rem; color:var(--smoke-dim); }

/* ============================================================ SECTION SHELL */
section{ position:relative; }
/* sections kept transparent so the ember background smolders through */
.work, .services, .studio{ border-top:1px solid var(--line); }
.section-index{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.22em; text-transform:uppercase; color:var(--ember); margin-bottom:1.4rem; }
.section-head{ padding:clamp(4.5rem,9vw,8rem) var(--pad) 0; max-width:var(--maxw); margin:0 auto; }
.section-title{ font-family:var(--font-display); font-weight:700; font-size:clamp(2.6rem,7vw,6rem); line-height:.98; letter-spacing:-.025em; text-transform:uppercase; }

/* ---------- manifesto ---------- */
.manifesto{ padding:clamp(6rem,12vw,11rem) var(--pad); max-width:1300px; margin:0 auto; }
.manifesto__head{ font-family:var(--font-display); font-weight:400; font-size:clamp(2rem,5.4vw,4.4rem); line-height:1.06; letter-spacing:-.02em; }
.manifesto__body{ margin-top:2.6rem; max-width:54ch; font-size:clamp(1rem,1.4vw,1.18rem); color:var(--smoke); }

/* ============================================================ WORK */
.work{ padding-bottom:clamp(3rem,6vw,5rem); }
.work__grid{ display:grid; grid-template-columns:1.35fr 1fr; gap:clamp(1rem,2.2vw,2rem); padding:clamp(2.5rem,5vw,4rem) var(--pad) 0; max-width:var(--maxw); margin:0 auto; }
.work-card--lg{ grid-column:1 / -1; }
.work-card{ position:relative; }
.work-card:nth-of-type(3){ margin-top:clamp(2rem,6vw,5rem); }   /* editorial offset */
.work-card__media{ position:relative; overflow:hidden; border-radius:6px; background:var(--ash); aspect-ratio:16/9; }
.work-card--lg .work-card__media{ aspect-ratio:21/9; }
.work-card__media img{ width:100%; height:100%; object-fit:cover; filter:grayscale(.25) contrast(1.02); transition:transform .9s cubic-bezier(.2,.8,.2,1), filter .6s; }
.work-card:hover .work-card__media img{ transform:scale(1.05); filter:grayscale(0) contrast(1.05); }
.work-card__media::after{ content:""; position:absolute; inset:0; background:linear-gradient(to top, rgba(10,10,12,.7), transparent 55%); opacity:.85; }
.work-card__play{ position:absolute; z-index:2; top:50%; left:50%; transform:translate(-50%,-50%); width:84px; height:84px; border-radius:50%; border:1px solid rgba(236,231,223,.5); background:rgba(10,10,12,.35); backdrop-filter:blur(6px); color:var(--bone); display:grid; place-items:center; transition:all .3s; }
.work-card__play svg{ margin-left:3px; }
.work-card__play:hover{ background:var(--ember); border-color:var(--ember); transform:translate(-50%,-50%) scale(1.08); }
.work-card__meta{ padding:1.2rem .2rem 0; }
.work-card__cat{ font-family:var(--font-mono); font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ember); }
.work-card__title{ font-family:var(--font-display); font-weight:700; font-size:clamp(1.5rem,2.6vw,2.4rem); margin:.5rem 0 .4rem; text-transform:uppercase; letter-spacing:-.01em; }
.work-card__desc{ color:var(--smoke); max-width:48ch; font-size:.98rem; }
/* full-width video showcase (range / product) */
.work-showcase{ max-width:var(--maxw); margin:clamp(2.5rem,5vw,4rem) auto 0; padding:0 var(--pad); }
.work-showcase__eyebrow{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.22em; text-transform:uppercase; color:var(--ember); margin-bottom:1.2rem; }
.work-showcase__media{ position:relative; overflow:hidden; border-radius:6px; background:var(--ash); }
.work-showcase__media video{ width:100%; height:auto; display:block; }
.work-showcase .work-card__meta{ padding-left:0; padding-right:0; }
/* Re-Vision process inset (PIP on the architecture film) */
.revision-inset{ position:absolute; left:clamp(.7rem,2.2%,1.5rem); bottom:clamp(.7rem,2.2%,1.5rem); width:clamp(150px,30%,340px); margin:0; border:1px solid rgba(255,255,255,.22); border-radius:5px; overflow:hidden; box-shadow:0 14px 36px rgba(0,0,0,.55); background:#000; z-index:2; }
.revision-inset__cap{ position:absolute; left:0; right:0; bottom:0; padding:.95rem .7rem .55rem; background:linear-gradient(0deg, rgba(8,8,10,.92), rgba(8,8,10,0)); display:flex; flex-direction:column; gap:.1rem; pointer-events:none; }
.revision-inset__t{ font-family:var(--font-display); font-style:italic; font-weight:700; font-size:clamp(.72rem,1.5vw,.95rem); color:var(--bone); line-height:1.05; }
.revision-inset__s{ font-family:var(--font-mono); font-size:clamp(.5rem,1vw,.6rem); letter-spacing:.14em; text-transform:uppercase; color:var(--ember); }

/* ============================================================ WORK — editorial gallery */
.gallery{ max-width:var(--maxw); margin:0 auto; padding:clamp(2.5rem,5vw,4rem) var(--pad) 0; display:flex; flex-direction:column; gap:clamp(1.1rem,2.4vw,2rem); }
.duo{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(1.1rem,2.4vw,2rem); align-items:start; }
.tile{ position:relative; border-radius:8px; overflow:hidden; background:var(--ash); border:1px solid var(--line); transition:border-color .4s; }
.tile:hover{ border-color:var(--line-2); }
.tile--feature{ aspect-ratio:16/9; }
.tile--wide{ aspect-ratio:1000/420; }
.duo .tile{ aspect-ratio:16/10; }
.tile__media{ position:absolute; inset:0; overflow:hidden; }
.tile__media video, .tile__media img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform 1.1s cubic-bezier(.2,.8,.2,1), filter .6s; }
.tile__media img{ filter:grayscale(.2) contrast(1.02); }
.tile:hover .tile__media video, .tile:hover .tile__media img{ transform:scale(1.05); filter:grayscale(0) contrast(1.04); }
.tile__media::after{ content:""; position:absolute; inset:0; background:linear-gradient(to top, rgba(8,8,11,.92) 2%, rgba(8,8,11,.34) 30%, transparent 60%); pointer-events:none; }
.tile__index{ position:absolute; z-index:3; top:clamp(.9rem,2vw,1.4rem); left:clamp(1.1rem,2.4vw,2rem); font-family:var(--font-mono); font-size:.72rem; letter-spacing:.18em; color:rgba(236,231,223,.55); }
.tile__overlay{ position:absolute; z-index:2; left:0; right:0; bottom:0; padding:clamp(1.1rem,2.6vw,2.1rem); display:flex; flex-direction:column; gap:.35rem; pointer-events:none; }
.tile__cat{ font-family:var(--font-mono); font-size:.64rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ember-hot); }
.tile__title{ font-family:var(--font-display); font-weight:700; text-transform:uppercase; letter-spacing:-.01em; line-height:.98; font-size:clamp(1.45rem,2.4vw,2.3rem); }
.tile--feature .tile__title{ font-size:clamp(2.1rem,4.2vw,3.6rem); }
.tile__desc{ color:var(--smoke); font-size:.92rem; line-height:1.5; max-width:48ch; max-height:0; opacity:0; overflow:hidden; transform:translateY(6px); transition:max-height .55s cubic-bezier(.2,.8,.2,1), opacity .4s, transform .5s, margin .4s; }
.tile--feature .tile__desc, .tile:hover .tile__desc{ max-height:7rem; opacity:1; transform:none; margin-top:.5rem; }
.tile__play{ position:absolute; z-index:4; top:50%; left:50%; transform:translate(-50%,-50%); width:84px; height:84px; border-radius:50%; border:1px solid rgba(236,231,223,.5); background:rgba(10,10,12,.35); backdrop-filter:blur(6px); color:var(--bone); display:grid; place-items:center; cursor:pointer; transition:all .3s; }
.tile__play svg{ margin-left:3px; }
.tile__play:hover{ background:var(--ember); border-color:var(--ember); transform:translate(-50%,-50%) scale(1.08); }
.tile--note{ aspect-ratio:16/10; display:flex; flex-direction:column; justify-content:center; gap:.9rem; padding:clamp(1.6rem,3.2vw,2.8rem); background:linear-gradient(155deg, var(--ink-2), var(--ash)); border:1px solid var(--line-2); }
.tile--note .tile__cat{ color:var(--ember); }
.tile--note h3{ font-family:var(--font-display); font-weight:700; text-transform:uppercase; line-height:.98; letter-spacing:-.01em; font-size:clamp(1.6rem,2.6vw,2.4rem); }
.tile--note p{ color:var(--smoke); font-size:.95rem; line-height:1.55; max-width:34ch; }
.tile--note .btn{ align-self:flex-start; margin-top:.3rem; }
@media (max-width:760px){
  .duo{ grid-template-columns:1fr; }
  .tile--wide{ aspect-ratio:16/9; }
  .tile--note{ aspect-ratio:auto; }
  .tile__desc{ max-height:7rem; opacity:1; transform:none; margin-top:.5rem; }
}

/* ============================================================ FEATURE (Inferno) */
.feature{ max-width:var(--maxw); margin:0 auto; padding:clamp(3.5rem,7vw,6.5rem) var(--pad); }
.feature__head{ margin-bottom:clamp(1.4rem,3vw,2.4rem); }
.feature__player{ position:relative; border-radius:8px; overflow:hidden; background:#000; border:1px solid var(--line); box-shadow:0 30px 90px rgba(0,0,0,.6); }
.feature__player video{ width:100%; height:auto; display:block; }
.feature__caption{ margin-top:1.2rem; color:var(--smoke); font-size:.98rem; max-width:72ch; line-height:1.6; }
.feature__credit{ display:block; margin-top:.5rem; font-family:var(--font-mono); font-size:.72rem; letter-spacing:.04em; color:var(--smoke-dim); }

/* ============================================================ SERVICES */
.services__list{ max-width:var(--maxw); margin:0 auto; padding:clamp(2.5rem,5vw,4rem) var(--pad) 0; }
.service{ position:relative; display:grid; grid-template-columns:auto 1fr auto; gap:clamp(1rem,4vw,3rem); align-items:baseline; padding:2.2rem 0; border-top:1px solid var(--line); transition:padding .4s; }
.service:last-of-type{ border-bottom:1px solid var(--line); }
.service::after{ content:""; position:absolute; left:0; bottom:-1px; height:1px; width:100%; background:var(--ember); transform:scaleX(0); transform-origin:left; transition:transform .5s cubic-bezier(.2,.8,.2,1); }
.service:hover{ padding-left:1.2rem; }
.service:hover::after{ transform:scaleX(1); }
.service__num{ font-family:var(--font-mono); font-size:.8rem; color:var(--smoke-dim); transition:color .3s; }
.service:hover .service__num{ color:var(--ember); }
.service__body h3{ font-family:var(--font-display); font-weight:700; font-size:clamp(1.5rem,3.4vw,2.6rem); text-transform:uppercase; letter-spacing:-.01em; transition:color .3s; }
.service:hover .service__body h3{ color:var(--ember); }
.service__body p{ color:var(--smoke); margin-top:.6rem; max-width:60ch; }
.service__price{ font-family:var(--font-mono); font-size:.85rem; color:var(--bone); white-space:nowrap; transition:color .3s; }
.service:hover .service__price{ color:var(--ember-hot); }
.services__note{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.06em; color:var(--smoke-dim); margin-top:2.2rem; }

/* ============================================================ STUDIO / EDGE */
.edge__grid{ max-width:var(--maxw); margin:0 auto; padding:clamp(2.5rem,5vw,4rem) var(--pad) clamp(5rem,9vw,8rem); display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(1.5rem,3vw,3rem); }
.edge{ padding:2.2rem; border:1px solid var(--line); border-radius:6px; background:linear-gradient(180deg, var(--ink-2), var(--ink)); position:relative; overflow:hidden; transition:border-color .4s, transform .4s; }
.edge::before{ content:""; position:absolute; top:0; left:0; width:40px; height:2px; background:var(--ember); transition:width .4s; }
.edge:hover{ border-color:var(--line-2); transform:translateY(-4px); }
.edge:hover::before{ width:72px; }
.edge h3{ font-family:var(--font-display); font-weight:700; font-size:clamp(1.3rem,2.2vw,1.8rem); margin-bottom:.8rem; text-transform:uppercase; letter-spacing:-.01em; }
.edge p{ color:var(--smoke); }

/* ---------- founder ---------- */
.founder{ max-width:var(--maxw); margin:0 auto; padding:clamp(.5rem,2vw,2rem) var(--pad) clamp(4rem,8vw,7rem); }
.founder__kicker{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.22em; text-transform:uppercase; color:var(--ember); margin-bottom:1rem; }
.founder__name{ font-family:var(--font-serif); font-weight:700; font-size:clamp(2rem,4.5vw,3.4rem); letter-spacing:.05em; text-transform:uppercase; line-height:1; }
.founder__role{ font-family:var(--font-mono); font-size:.8rem; letter-spacing:.14em; text-transform:uppercase; color:var(--smoke); margin-top:.7rem; }
.founder__bio{ margin-top:1.6rem; max-width:64ch; font-size:clamp(1rem,1.4vw,1.18rem); line-height:1.62; color:var(--smoke); }
.founder__bio strong{ color:var(--bone); font-weight:600; }
.founder__credits{ margin-top:2.2rem; display:flex; align-items:baseline; gap:1.4rem 1.6rem; flex-wrap:wrap; border-top:1px solid var(--line); padding-top:1.4rem; }
.founder__credits-label{ font-family:var(--font-mono); font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; color:var(--smoke-dim); }
.founder__credits ul{ display:flex; flex-wrap:wrap; gap:.5rem 1.5rem; }
.founder__credits li{ font-family:var(--font-serif); font-weight:600; font-size:clamp(.95rem,1.4vw,1.2rem); color:var(--bone); letter-spacing:.03em; position:relative; }
.founder__credits li:not(:last-child)::after{ content:"·"; position:absolute; right:-.9rem; color:var(--ember); }

/* ============================================================ CONTACT */
.contact{ position:relative; padding:clamp(6rem,13vw,12rem) var(--pad); text-align:center; overflow:hidden; border-top:1px solid var(--line); }
.contact::before{ content:""; position:absolute; inset:0; background:radial-gradient(60% 80% at 50% 120%, rgba(226,83,28,.22), transparent 60%); }
.contact__inner{ position:relative; z-index:2; max-width:900px; margin:0 auto; }
.contact__head{ font-family:var(--font-display); font-weight:700; font-size:clamp(2.6rem,9vw,7rem); line-height:.96; letter-spacing:-.03em; text-transform:uppercase; margin:1rem 0 1.6rem; }
.contact__sub{ color:var(--smoke); max-width:50ch; margin:0 auto 2.6rem; font-size:clamp(1rem,1.4vw,1.18rem); }
.contact__form{ max-width:560px; margin:2.6rem auto 0; text-align:left; display:flex; flex-direction:column; gap:1.2rem; }
.contact__form .field{ display:flex; flex-direction:column; gap:.5rem; }
.contact__form label{ font-family:var(--font-mono); font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:var(--smoke); }
.contact__form input, .contact__form select, .contact__form textarea{ width:100%; background:var(--ink-2); border:1px solid var(--line); border-radius:6px; color:var(--bone); font-family:var(--font-body); font-size:1rem; padding:.85rem 1rem; transition:border-color .25s, background .25s; }
.contact__form textarea{ resize:vertical; min-height:120px; line-height:1.5; }
.contact__form input:focus, .contact__form select:focus, .contact__form textarea:focus{ outline:none; border-color:var(--ember); background:var(--ash); }
.contact__form select{ appearance:none; -webkit-appearance:none; cursor:pointer; }
.contact__form button.btn{ margin-top:.4rem; align-self:flex-start; border:none; cursor:pointer; }
.contact__hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.contact__sign{ margin-top:1.6rem; font-family:var(--font-display); font-style:italic; font-weight:400; font-size:1.05rem; color:var(--bone); }
.contact__line{ margin-top:.8rem; font-family:var(--font-mono); font-size:.78rem; letter-spacing:.1em; color:var(--smoke); }
.contact__line a{ color:var(--ember); }

/* ============================================================ FOOTER */
.footer{ border-top:1px solid var(--line); padding:clamp(3rem,6vw,5rem) var(--pad) 2.5rem; max-width:var(--maxw); margin:0 auto; }
.footer__brand{ display:flex; flex-direction:column; gap:.4rem; margin-bottom:3rem; }
.footer__mark{ font-family:var(--font-serif); font-weight:700; font-size:clamp(1.6rem,4.4vw,3rem); letter-spacing:.16em; text-transform:uppercase; }
.footer__tag{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.3em; text-transform:uppercase; color:var(--ember); }
.footer__logo{ width:clamp(260px,32vw,440px); height:auto; display:block; margin-bottom:.6rem; }
.footer__cols{ display:flex; flex-wrap:wrap; gap:1.4rem 3rem; padding-bottom:2.5rem; border-bottom:1px solid var(--line); font-family:var(--font-mono); font-size:.78rem; letter-spacing:.06em; color:var(--smoke); }
.footer__cols a:hover{ color:var(--ember); }
.footer__bottom{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:1rem; margin-top:2rem; font-family:var(--font-mono); font-size:.68rem; letter-spacing:.1em; color:var(--smoke-dim); }
.footer__bottom a:hover{ color:var(--bone); }

/* ============================================================ LIGHTBOX */
.lightbox{ position:fixed; inset:0; z-index:5000; display:flex; align-items:center; justify-content:center; padding:var(--pad); background:rgba(5,5,6,.94); backdrop-filter:blur(8px); opacity:0; visibility:hidden; transition:opacity .4s, visibility .4s; }
.lightbox.is-open{ opacity:1; visibility:visible; }
.lightbox__frame{ width:100%; max-width:1200px; aspect-ratio:21/9; transform:scale(.96); transition:transform .5s cubic-bezier(.2,.8,.2,1); }
.lightbox.is-open .lightbox__frame{ transform:scale(1); }
.lightbox__video{ width:100%; height:100%; object-fit:contain; border-radius:6px; background:#000; }
.lightbox.is-loading .lightbox__frame::after{ content:"Loading reel…"; position:absolute; inset:0; display:grid; place-items:center; font-family:var(--font-mono); font-size:.8rem; letter-spacing:.2em; color:var(--smoke); pointer-events:none; }
.lightbox__close{ position:absolute; top:1.5rem; right:1.5rem; width:48px; height:48px; border-radius:50%; border:1px solid var(--line-2); background:transparent; color:var(--bone); font-size:1.1rem; transition:all .3s; }
.lightbox__close:hover{ background:var(--ember); border-color:var(--ember); }

/* ============================================================ REVEALS */
[data-reveal]{ opacity:0; transform:translateY(38px); }
[data-load]{ opacity:0; }

/* ============================================================ RESPONSIVE */
@media (max-width:900px){
  .nav__links{ position:fixed; inset:0; flex-direction:column; justify-content:center; gap:2.4rem; background:rgba(10,10,12,.97); backdrop-filter:blur(20px); font-size:1.1rem; transform:translateY(-100%); transition:transform .5s cubic-bezier(.6,0,.2,1); }
  .nav__links.is-open{ transform:translateY(0); }
  .nav__burger{ display:flex; z-index:1001; }
  .nav.nav--hidden{ transform:none; }
  .hero__meta{ display:none; }
  .work__grid{ grid-template-columns:1fr; }
  .work-card--lg .work-card__media{ aspect-ratio:16/9; }
  .work-card:nth-of-type(3){ margin-top:0; }
  .service{ grid-template-columns:auto 1fr; }
  .service__price{ grid-column:2; margin-top:.6rem; }
  .edge__grid{ grid-template-columns:1fr; }
  .lightbox__frame{ aspect-ratio:16/9; }
  .proof{ gap:.8rem 1.4rem; }
}
@media (prefers-reduced-motion:reduce){
  *{ animation:none!important; transition:none!important; }
  [data-reveal],[data-load]{ opacity:1!important; transform:none!important; }
  .grain{ animation:none!important; }
}
