:root{
  --ink:#0c0d11;
  --panel:#14161d;
  --panel-2:#1b1e27;
  --line:#262a36;
  --text:#e8eaf0;
  --muted:#8b91a3;
  --orange:#ff6b2c;
  --teal:#2dd6c1;
  --display:'Anton',sans-serif;
  --body:'Space Grotesk',sans-serif;
  --mono:'IBM Plex Mono',monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--ink);
  color:var(--text);
  font-family:var(--body);
  overflow-x:hidden;
  padding-bottom:64px;
}
/* film grain — z-index:-1 keeps it on the page background only, never over content */
body::after{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:-1;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
::selection{background:var(--orange);color:var(--ink)}

/* ---------- NAV ---------- */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 28px;
  background:linear-gradient(to bottom, rgba(12,13,17,.92), rgba(12,13,17,0));
  backdrop-filter:blur(2px);
}
.logo{font-family:var(--mono);font-size:13px;letter-spacing:.12em;color:var(--text);text-decoration:none}
.logo b{color:var(--orange)}
.nav-links{display:flex;gap:26px}
.nav-links a{
  font-family:var(--mono);font-size:12px;letter-spacing:.08em;
  color:var(--muted);text-decoration:none;transition:color .25s;
}
.nav-links a:hover,.nav-links a:focus-visible{color:var(--teal)}
a:focus-visible,button:focus-visible{outline:2px solid var(--teal);outline-offset:3px;border-radius:2px}

/* ---------- MOBILE MENU ---------- */
.nav-toggle{
  display:none;width:42px;height:42px;
  flex-direction:column;align-items:center;justify-content:center;gap:5px;
  background:rgba(20,22,29,.6);border:1px solid var(--line);border-radius:4px;
  cursor:pointer;transition:border-color .25s;
}
.nav-toggle:hover{border-color:var(--teal)}
.nav-toggle span{
  display:block;width:18px;height:2px;background:var(--text);border-radius:1px;
  transition:transform .3s ease,opacity .3s ease;
}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{
  position:fixed;inset:0;z-index:99;display:none;
  flex-direction:column;justify-content:center;gap:0;
  background:rgba(12,13,17,.96);backdrop-filter:blur(12px);
  padding:90px 28px 110px;
  opacity:0;visibility:hidden;
  transition:opacity .35s ease,visibility .35s;
}
.mobile-menu.open{opacity:1;visibility:visible}
.mobile-menu a{
  font-family:var(--mono);font-size:19px;letter-spacing:.14em;
  color:var(--text);text-decoration:none;
  display:flex;align-items:baseline;gap:16px;
  padding:16px 4px;border-bottom:1px solid var(--line);
  opacity:0;transform:translateY(14px);
  transition:opacity .4s ease,transform .4s ease,color .25s;
}
.mobile-menu a:first-child{border-top:1px solid var(--line)}
.mobile-menu a:hover,.mobile-menu a:focus-visible{color:var(--teal)}
.mobile-menu .m-tc{font-size:11px;color:var(--orange);letter-spacing:.1em;min-width:42px}
.mobile-menu.open a{opacity:1;transform:none}
.mobile-menu.open a:nth-child(1){transition-delay:.06s}
.mobile-menu.open a:nth-child(2){transition-delay:.11s}
.mobile-menu.open a:nth-child(3){transition-delay:.16s}
.mobile-menu.open a:nth-child(4){transition-delay:.21s}
.mobile-menu.open a:nth-child(5){transition-delay:.26s}
.mobile-menu.open a:nth-child(6){transition-delay:.31s}

/* ---------- HERO ---------- */
.hero{
  min-height:100vh;display:flex;flex-direction:column;justify-content:center;
  padding:110px 28px 84px;position:relative;perspective:1200px; /* bottom padding clears the fixed scrubber */
  max-width:1240px;margin:0 auto; /* keep text + photo composed together on wide screens */
}
.hero-eyebrow{
  font-family:var(--mono);font-size:12px;letter-spacing:.18em;color:var(--teal);
  display:flex;align-items:center;gap:10px;margin-bottom:18px;
}
.rec-dot{width:9px;height:9px;border-radius:50%;background:#ff3b30;animation:blink 1.4s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.15}}
h1{
  font-family:var(--display);
  /* sized by width AND height so the full hero (headline+copy+CTAs) fits the first screen */
  font-size:clamp(64px,min(13vw,17.4vh),176px);
  line-height:.92;text-transform:uppercase;font-weight:400;
  letter-spacing:.01em;
}
h1 .stroke{
  color:transparent;
  -webkit-text-stroke:2px var(--text);
}
h1 .grade{
  background:linear-gradient(95deg,var(--orange) 20%,var(--teal) 80%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero-sub{
  margin-top:26px;max-width:520px;color:var(--muted);font-size:17px;line-height:1.65;
}
.hero-cta{margin-top:34px;display:flex;gap:14px;flex-wrap:wrap}
.btn{
  font-family:var(--mono);font-size:13px;letter-spacing:.06em;
  padding:14px 26px;border-radius:4px;text-decoration:none;cursor:pointer;border:0;
  transition:transform .2s,box-shadow .2s;
  display:inline-block;
}
.btn-primary{background:var(--orange);color:var(--ink);font-weight:500}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(255,107,44,.35)}
.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal)}

/* floating 3D frames behind hero */
.float-frame{
  position:absolute;border:1px solid var(--line);border-radius:8px;
  background:linear-gradient(135deg,rgba(255,107,44,.07),rgba(45,214,193,.07));
  background-size:cover;background-position:center;
  pointer-events:none;will-change:transform;
}
/* frame positions are % of .hero-visual (the photo box) so they hug the
   photo at every resolution; ff3/ffr behind it, ff1/ff2 in front */
.ff1{width:200px;height:120px;bottom:4%;left:58%;transform:rotate(6deg)}
.ff2{width:160px;height:95px;top:44%;right:70%;transform:rotate(-8deg)}
.ff3{width:290px;height:175px;top:-6%;right:50%;transform:rotate(3deg)}
.ffr{width:124px;height:220px;top:16%;left:68%;transform:rotate(7deg)} /* 9:16 reels frame, peeks from behind the photo */
.float-frame::before{
  content:attr(data-tc);position:absolute;bottom:8px;left:10px;
  font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:.08em;
  background:rgba(12,13,17,.6);padding:2px 6px;border-radius:3px;
}

/* ---------- HERO VISUAL (photo + frames as one anchored unit) ---------- */
.hero-visual{
  position:absolute;right:12%;top:50%;transform:translateY(-50%);
  height:min(72vh,640px);aspect-ratio:653/1300; /* matches me.png */
  pointer-events:none;
}
/* ---------- HERO PHOTO (static cutout, graded like a film still) ---------- */
.hero-photo{
  position:absolute;inset:0;z-index:2;
  pointer-events:none;isolation:isolate;
  filter:drop-shadow(0 24px 48px rgba(0,0,0,.55));
}
.hero-photo img{
  height:100%;width:100%;display:block;position:relative;z-index:0;
  filter:brightness(.94) saturate(.92) contrast(1.04);
}
/* split-tone grade clipped to the cutout's alpha:
   deep teal lifts the shadows (lighten), warm orange caps the highlights (darken) */
.hero-photo::before,.hero-photo::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  /* --hero-cutout is set from js/config.js so the mask follows SITE.heroImage */
  -webkit-mask:var(--hero-cutout,url('../assets/me.png')) center / 100% 100% no-repeat;
  mask:var(--hero-cutout,url('../assets/me.png')) center / 100% 100% no-repeat;
}
.hero-photo::before{
  z-index:1;mix-blend-mode:lighten;
  background:linear-gradient(165deg,rgba(8,34,32,.85),rgba(12,46,42,.85));
}
.hero-photo::after{
  z-index:2;mix-blend-mode:darken;
  background:linear-gradient(165deg,rgba(255,226,198,.9),rgba(250,206,170,.9));
}
/* depth: far frames (ff3, ffr) sit behind the photo, nearer frames float in front */
.ff1{z-index:3}
.ff2{z-index:3}
.ff3{z-index:1}
.ffr{z-index:1}

/* ---------- SECTION SHARED ---------- */
section{padding:110px 28px;max-width:1240px;margin:0 auto}
.sec-head{display:flex;align-items:baseline;gap:18px;margin-bottom:48px;flex-wrap:wrap}
.sec-tc{font-family:var(--mono);font-size:12px;color:var(--orange);letter-spacing:.1em}
h2{
  font-family:var(--display);font-size:clamp(36px,6vw,68px);
  text-transform:uppercase;font-weight:400;letter-spacing:.01em;
}
.sec-note{font-family:var(--mono);font-size:12px;color:var(--muted);margin-left:auto}

/* ---------- SHOWREEL ---------- */
.reel-stage{perspective:1400px}
.reel{
  position:relative;border-radius:14px;overflow:hidden;
  aspect-ratio:16/9;cursor:pointer;
  background:
    radial-gradient(ellipse at 25% 30%,rgba(255,107,44,.5),transparent 55%),
    radial-gradient(ellipse at 78% 75%,rgba(45,214,193,.45),transparent 55%),
    var(--panel-2);
  border:1px solid var(--line);
  transform-style:preserve-3d;
  transition:transform .15s ease-out,box-shadow .3s;
  will-change:transform;
  box-shadow:0 30px 80px rgba(0,0,0,.5);
}
.reel .demo-tag{
  position:absolute;top:16px;left:16px;font-family:var(--mono);font-size:11px;
  letter-spacing:.14em;color:var(--ink);background:var(--teal);
  padding:5px 10px;border-radius:3px;font-weight:500;
}
.reel .reel-tc{
  position:absolute;top:16px;right:16px;font-family:var(--mono);font-size:12px;
  color:var(--text);background:rgba(12,13,17,.6);padding:5px 10px;border-radius:3px;
}
.play-btn{
  position:absolute;inset:0;margin:auto;width:92px;height:92px;border-radius:50%;
  background:rgba(12,13,17,.55);border:1px solid rgba(232,234,240,.3);
  backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;
  transition:transform .3s,background .3s;transform:translateZ(60px);
}
.reel:hover .play-btn{transform:translateZ(60px) scale(1.08);background:rgba(255,107,44,.85)}
.play-btn svg{margin-left:6px}
.reel-bar{
  position:absolute;bottom:0;left:0;right:0;height:46px;
  background:rgba(12,13,17,.7);backdrop-filter:blur(6px);
  display:flex;align-items:center;gap:14px;padding:0 16px;
  font-family:var(--mono);font-size:11px;color:var(--muted);
}
.reel-track{flex:1;height:4px;background:var(--line);border-radius:2px;overflow:hidden}
.reel-fill{width:34%;height:100%;background:linear-gradient(90deg,var(--orange),var(--teal))}

/* ---------- WORK GRID ---------- */
.work-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:26px;
  perspective:1200px;
}
.card{
  position:relative;border-radius:12px;border:1px solid var(--line);
  background:var(--panel);overflow:hidden;cursor:pointer;
  transform-style:preserve-3d;transition:transform .15s ease-out,border-color .3s;
  will-change:transform;
}
.card:hover{border-color:rgba(255,107,44,.5)}
.card-thumb{
  aspect-ratio:16/9;position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.card-thumb .demo-label{
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:rgba(232,234,240,.8);
  border:1px dashed rgba(232,234,240,.35);padding:8px 14px;border-radius:4px;
  transform:translateZ(40px);
}
.t1{background:linear-gradient(130deg,#ff6b2c 0%,#b3286e 100%)}
.t2{background:linear-gradient(130deg,#2dd6c1 0%,#1f5bd8 100%)}
.t3{background:linear-gradient(130deg,#f7c948 0%,#ff6b2c 100%)}
.t4{background:linear-gradient(130deg,#7b5cff 0%,#2dd6c1 100%)}
.t5{background:linear-gradient(130deg,#ff4d6d 0%,#7b5cff 100%)}
.t6{background:linear-gradient(130deg,#1f5bd8 0%,#0e9f8a 100%)}
.card-thumb::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to top,rgba(12,13,17,.55),transparent 50%);
}
.card-body{padding:18px;display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.card-title{font-size:17px;font-weight:600;letter-spacing:.01em}
.card-cat{font-family:var(--mono);font-size:11px;color:var(--muted);margin-top:5px;letter-spacing:.08em}
.card-dur{font-family:var(--mono);font-size:11px;color:var(--teal);white-space:nowrap;padding-top:3px}

/* ---------- VERTICAL WORK ---------- */
.work-grid-v{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:22px;
  perspective:1200px;max-width:980px;
}
.card-thumb-v{aspect-ratio:9/16}
.format-tag{
  font-family:var(--mono);font-size:10px;letter-spacing:.14em;
  padding:4px 9px;border-radius:3px;margin-left:12px;
  border:1px solid var(--line);color:var(--muted);vertical-align:middle;
}

/* ---------- BEFORE / AFTER GRADE SLIDER ---------- */
.ba-wrap{
  position:relative;border-radius:14px;overflow:hidden;border:1px solid var(--line);
  aspect-ratio:16/9;max-width:900px;margin:0 auto;cursor:ew-resize;user-select:none;
  touch-action:none;
}
.ba-layer{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.ba-before{
  background:url('../assets/grade-before.jpg') center/cover no-repeat;
}
.ba-after{
  background:url('../assets/grade-after.jpg') center/cover no-repeat;
  clip-path:inset(0 0 0 50%);
}
.ba-label{
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;
  background:rgba(12,13,17,.65);padding:6px 12px;border-radius:3px;
  position:absolute;top:16px;
}
.ba-before .ba-label{left:16px;color:var(--muted)}
.ba-after .ba-label{right:16px;color:var(--teal)}
.ba-handle{
  position:absolute;top:0;bottom:0;left:50%;width:2px;background:#fff;
  box-shadow:0 0 14px rgba(255,255,255,.7);pointer-events:none;
}
.ba-handle::before{
  content:'◂ ▸';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  background:#fff;color:var(--ink);font-size:11px;letter-spacing:1px;
  padding:8px 10px;border-radius:30px;white-space:nowrap;font-family:var(--mono);
}
.ba-hint{
  text-align:center;font-family:var(--mono);font-size:11px;color:var(--muted);
  letter-spacing:.12em;margin-top:16px;
}

/* ---------- PROCESS ---------- */
.proc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:0;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.proc{
  padding:30px 26px;background:var(--panel);border-right:1px solid var(--line);
  transition:background .3s;position:relative;
}
.proc:last-child{border-right:0}
.proc:hover{background:var(--panel-2)}
.proc-step{font-family:var(--mono);font-size:11px;color:var(--orange);letter-spacing:.14em;margin-bottom:14px}
.proc h3{font-size:17px;font-weight:600;margin-bottom:10px}
.proc p{color:var(--muted);font-size:14px;line-height:1.65}

/* ---------- TESTIMONIALS (scrolling marquee) ---------- */
.testi-marquee{
  overflow:hidden;
  mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
}
.testi-track{display:flex}
.testi-set{display:flex;flex-wrap:wrap;gap:22px;padding-right:22px}
.testi-track.scrolling{width:max-content;animation:testi-scroll 45s linear infinite}
.testi-track.scrolling .testi-set{flex-wrap:nowrap}
.testi-track.scrolling:hover,
.testi-track.scrolling:focus-within{animation-play-state:paused}
@keyframes testi-scroll{to{transform:translateX(-50%)}}
.testi{
  border:1px solid var(--line);border-radius:12px;padding:28px 26px;background:var(--panel);
  display:flex;flex-direction:column;gap:18px;
  width:min(360px,78vw);flex-shrink:0;
}
.testi-quote{font-size:15.5px;line-height:1.7;color:var(--text)}
.testi-quote::before{content:'“';color:var(--orange);font-family:var(--display);font-size:30px;line-height:0;margin-right:4px}
.testi-who{display:flex;align-items:center;gap:12px;margin-top:auto}
.testi-av{
  width:40px;height:40px;border-radius:50%;flex-shrink:0;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-size:16px;color:var(--ink);
}
.testi-av img{width:100%;height:100%;object-fit:cover;display:block}
.av1{background:linear-gradient(135deg,var(--orange),#f7c948)}
.av2{background:linear-gradient(135deg,var(--teal),#1f5bd8)}
.av3{background:linear-gradient(135deg,#ff4d6d,#7b5cff)}
.testi-name{font-size:14px;font-weight:600}
.testi-role{font-family:var(--mono);font-size:11px;color:var(--muted);margin-top:3px}
.stars{color:var(--orange);font-size:13px;letter-spacing:3px}

/* ---------- SERVICES ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:22px}
.svc{
  border:1px solid var(--line);border-radius:12px;padding:28px 24px;background:var(--panel);
  transition:transform .3s,border-color .3s;
}
.svc:hover{transform:translateY(-6px);border-color:var(--teal)}
.svc-icon{
  width:46px;height:46px;border-radius:9px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,rgba(255,107,44,.18),rgba(45,214,193,.18));
  margin-bottom:18px;font-size:20px;
}
.svc h3{font-size:18px;font-weight:600;margin-bottom:10px}
.svc p{color:var(--muted);font-size:14.5px;line-height:1.65}

/* ---------- ABOUT ---------- */
.about-wrap{display:grid;grid-template-columns:1.2fr .8fr;gap:50px;align-items:start}
.about-wrap p{color:var(--muted);font-size:17px;line-height:1.75;margin-bottom:18px}
.about-wrap p b{color:var(--text);font-weight:600}
.stats{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.stat{
  border:1px solid var(--line);border-radius:10px;padding:22px;background:var(--panel);
}
.stat-num{font-family:var(--display);font-size:38px;color:var(--orange)}
.stat-label{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.1em;margin-top:6px}
.tools{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.tool{
  font-family:var(--mono);font-size:12px;color:var(--text);
  border:1px solid var(--line);border-radius:30px;padding:8px 16px;background:var(--panel-2);
}

/* ---------- CONTACT ---------- */
.contact{text-align:center;padding-bottom:140px}
.contact h2{margin-bottom:18px}
.contact p{color:var(--muted);max-width:460px;margin:0 auto 32px;line-height:1.7}
.contact .email{
  font-family:var(--mono);font-size:clamp(16px,3vw,24px);color:var(--teal);text-decoration:none;
  border-bottom:1px solid var(--teal);padding-bottom:4px;transition:color .25s,border-color .25s;
}
.contact .email:hover{color:var(--orange);border-color:var(--orange)}
.socials{margin-top:36px;display:flex;justify-content:center;gap:22px}
.socials a{font-family:var(--mono);font-size:12px;color:var(--muted);text-decoration:none;letter-spacing:.1em}
.socials a:hover{color:var(--text)}

/* ---------- TIMELINE SCRUBBER (signature) ---------- */
.scrubber{
  position:fixed;bottom:0;left:0;right:0;height:64px;z-index:200;
  background:rgba(16,17,23,.92);backdrop-filter:blur(10px);
  border-top:1px solid var(--line);
  display:flex;align-items:center;gap:16px;padding:0 20px;
}
.scrub-tc{
  font-family:var(--mono);font-size:13px;color:var(--orange);min-width:96px;font-weight:500;
}
.scrub-track{
  flex:1;height:30px;position:relative;border-radius:4px;overflow:hidden;
  background:repeating-linear-gradient(90deg,var(--panel-2) 0 2px,transparent 2px 40px),var(--panel);
}
.scrub-clips{position:absolute;inset:5px 0;display:flex;gap:3px}
.clip{border-radius:3px;opacity:.85}
.clip:nth-child(1){flex:2.2;background:linear-gradient(90deg,#ff6b2c,#d8542a)}
.clip:nth-child(2){flex:3;background:linear-gradient(90deg,#2dd6c1,#1fa898)}
.clip:nth-child(3){flex:1.6;background:linear-gradient(90deg,#7b5cff,#5b40cc)}
.clip:nth-child(4){flex:2.4;background:linear-gradient(90deg,#f7c948,#e0a824)}
.clip:nth-child(5){flex:1.8;background:linear-gradient(90deg,#ff4d6d,#d23a57)}
.playhead{
  position:absolute;top:0;bottom:0;width:2px;background:#fff;left:0;
  box-shadow:0 0 10px rgba(255,255,255,.8);
}
.playhead::before{
  content:'';position:absolute;top:-1px;left:-5px;border:6px solid transparent;border-top-color:#fff;
}
.scrub-label{
  font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:.14em;
  min-width:70px;text-align:right;
}

/* ---------- LIGHTBOX PLAYER ---------- */
.lightbox{
  position:fixed;inset:0;z-index:300;
  display:flex;align-items:center;justify-content:center;padding:24px;
  opacity:0;visibility:hidden;
  transition:opacity .3s ease,visibility .3s;
}
.lightbox.open{opacity:1;visibility:visible}
.lb-backdrop{
  position:absolute;inset:0;cursor:pointer;
  background:rgba(12,13,17,.88);backdrop-filter:blur(8px);
}
.lb-stage{
  position:relative;width:min(92vw,960px,124vh); /* 124vh caps the 16:9 player at ~70vh tall */
  transform:translateY(18px) scale(.97);transition:transform .3s ease;
}
.lightbox.open .lb-stage{transform:none}
.lightbox.vertical .lb-stage{width:min(80vw,400px,42dvh)} /* 42dvh caps the Shorts player at ~75vh tall */
.lb-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;gap:14px}
.lb-tc{font-family:var(--mono);font-size:12px;color:var(--orange);letter-spacing:.14em;text-transform:uppercase}
.lb-close{
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;
  color:var(--muted);background:rgba(20,22,29,.6);
  border:1px solid var(--line);border-radius:4px;padding:8px 14px;cursor:pointer;
  transition:color .25s,border-color .25s;white-space:nowrap;
}
.lb-close:hover{color:var(--teal);border-color:var(--teal)}
.lb-frame{
  aspect-ratio:16/9;border:1px solid var(--line);border-radius:14px;
  overflow:hidden;background:var(--panel);
  box-shadow:0 30px 80px rgba(0,0,0,.6);
}
.lightbox.vertical .lb-frame{aspect-ratio:9/16}
.lb-frame iframe{width:100%;height:100%;border:0;display:block}
.lb-placeholder{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(ellipse at 25% 30%,rgba(255,107,44,.35),transparent 55%),
    radial-gradient(ellipse at 78% 75%,rgba(45,214,193,.3),transparent 55%),
    var(--panel-2);
}
.lb-placeholder span{
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:rgba(232,234,240,.8);
  border:1px dashed rgba(232,234,240,.35);padding:8px 14px;border-radius:4px;
}

/* ---------- REVEAL ON SCROLL ---------- */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

footer{
  text-align:center;font-family:var(--mono);font-size:11px;color:var(--muted);
  padding:30px 20px 40px;letter-spacing:.1em;
}

@media(max-width:820px){
  .nav-links{display:none}
  .nav-toggle{display:flex}
  .mobile-menu{display:flex}
  .hero-visual{display:none}
  .about-wrap{grid-template-columns:1fr}
  .float-frame{display:none}
  section{padding:80px 20px}
  .scrub-label{display:none}
  .scrub-tc{min-width:84px;font-size:12px}
}
/* ---------- RESPONSIVE TIERS ---------- */

/* tablets / small laptops (821–1180px): shrink the hero photo so it
   never collides with the headline; drop the mid-left front frame */
@media(min-width:821px) and (max-width:1180px){
  .hero-visual{height:min(54vh,460px);right:9%}
  .ff3{width:220px;height:133px}
  .ff1{width:160px;height:96px}
  .ffr{width:104px;height:185px}
  .ff2{width:130px;height:78px}
}

/* short landscape screens (rotated phones, tiny laptops):
   let the hero grow instead of cramming into 100vh */
@media(max-height:560px){
  .hero{min-height:auto;padding:120px 28px 80px}
}

/* very narrow screens (flip phones, folds, small androids) */
@media(max-width:380px){
  nav{padding:14px 16px}
  section{padding:64px 14px}
  h1{font-size:clamp(44px,18vw,60px)}
  .hero{padding:96px 16px 48px}
  .hero-sub{font-size:15px}
  .btn{padding:12px 18px;font-size:12px}
  .mobile-menu{padding:80px 18px 96px}
  .mobile-menu a{font-size:16px}
  .sec-note{display:none}
  .format-tag{display:none}
  .stats{grid-template-columns:1fr}
  .testi{width:86vw}
  .scrubber{padding:0 10px;gap:8px}
  .scrub-tc{min-width:72px;font-size:11px}
}

/* large screens: scale the ENTIRE design uniformly with CSS zoom.
   Every px-based size (cards, text, nav, scrubber) multiplies by the zoom
   factor, while vw/vh-based sizes (headline, hero photo, section padding)
   resolve against the real viewport — so a 4K screen renders exactly like
   the tuned 1920x1080 layout, pixel-doubled. Steps keep the effective CSS
   viewport in the ~1500-2000px range where the base design is verified. */
@media(min-width:1800px){
  body{--z:1.15;--zs:1.1;zoom:var(--z)}
  /* sections scale GENTLER than the hero: nested zoom multiplies, so
     zs/z counter-scales them down to the --zs factor */
  section,footer{zoom:calc(var(--zs)/var(--z))}
  /* vw/vh inside a zoomed body get scaled AGAIN by the engine,
     so every viewport-unit length here is divided by --z to stay true.
     Only the HERO goes full-bleed; sections keep their centered 1240px
     container (their zoom scales it proportionally). */
  .hero{max-width:none;margin:0;min-height:calc(100vh/var(--z));
        padding-left:calc(4vw/var(--z));padding-right:calc(4vw/var(--z))}
  nav{padding:18px calc(4vw/var(--z))}
  h1{font-size:clamp(64px,min(calc(13vw/var(--z)),calc(17.4vh/var(--z))),176px)}
  .hero-visual{height:calc(78vh/var(--z));right:8%}
  /* take the lightbox OUT of the zoom system entirely and size it purely
     by viewport proportions — immune to zoom/viewport-unit quirks */
  .lightbox{zoom:calc(1/var(--z))}
  .lb-stage{width:min(92vw,124vh)}                  /* 16:9 player ≈ 70vh tall */
  .lightbox.vertical .lb-stage{width:min(80vw,40dvh)} /* Shorts ≈ 71vh tall */
}
@media(min-width:2200px){body{--z:1.4;--zs:1.15}}
@media(min-width:2700px){body{--z:1.7;--zs:1.25}}
@media(min-width:3300px){body{--z:2;--zs:1.35}}

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