/* ============================================================
   2T5 FILM — MAIN STYLESHEET  v3
   ============================================================ */

/* Gotham — load from CDN fallback stack */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,300;1,400&display=swap');

/*
  Gotham stack: if Gotham is locally installed it wins,
  otherwise Montserrat is a near-identical geometric sans.
*/
:root {
  --ff-g: 'Gotham', 'Montserrat', 'Helvetica Neue', Arial, sans-serif;
  --ff-d: 'Gotham', 'Montserrat', 'Helvetica Neue', Arial, sans-serif;
  --ff-s: 'Gotham', 'Montserrat', 'Helvetica Neue', Arial, sans-serif;
  --ff-m: 'Gotham', 'Montserrat', 'Courier New', monospace;

  --black:   #0a0908;
  --white:   #f5f1ec;
  --paper:   #ece8e1;
  --red:     #b85450;
  --red-dim: #c97a77;
  --red-text:#9e443f;
  --gray:    #8a857e;
  --gray-text:#6b665f;
  --gray-lt: #cdc8c1;
  --border:  rgba(10,9,8,0.12);
  --ease-out: cubic-bezier(0.16,1,0.3,1);
  --ease-in:  cubic-bezier(0.7,0,0.84,0);

  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 16px;
}

/* ── RESET ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; overflow-x:hidden; }
body {
  background:var(--white); color:var(--black);
  font-family:var(--ff-s); font-size:16px; line-height:1.6;
  overflow-x:hidden;
}

/* ── NOISE ── */
body::before {
  content:''; position:fixed; inset:0; pointer-events:none; z-index:9000;
  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.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  opacity:.28;
}

/* ── TYPE ── */
h1,h2,h3,h4 { font-family:var(--ff-g); font-weight:300; line-height:1.05; }
.label {
  font-family:var(--ff-g); font-size:10px;
  letter-spacing:0.2em; text-transform:uppercase; color:var(--gray-text);
}
.label-red { color:var(--red-text); }

/* ── LAYOUT ── */
.container { max-width:1440px; margin:0 auto; padding:0 60px; }
@media(max-width:1024px){ .container{ padding:0 40px; } }
@media(max-width:768px) { .container{ padding:0 20px; } }

/* ── CURSOR ── */
.cursor {
  position:fixed; left:0; top:0;
  width:10px; height:10px;
  background:var(--red); border-radius:50%;
  pointer-events:none; z-index:9999;
  will-change:transform;
  transition:width .2s var(--ease-out), height .2s var(--ease-out), background .2s;
}
.cursor.hover { width:36px; height:36px; background:rgba(184,84,80,.55); }
.cursor-ring {
  position:fixed; left:0; top:0;
  width:34px; height:34px;
  border:1px solid rgba(184,84,80,.5); border-radius:50%;
  pointer-events:none; z-index:9998;
  will-change:transform;
}
/* White cursor on red game overlay */
body.gp-playing .cursor { background:#fff; }
body.gp-playing .cursor.hover { background:rgba(255,255,255,.55); }
body.gp-playing .cursor-ring { border-color:rgba(255,255,255,.5); }
@media(max-width:768px){ .cursor,.cursor-ring { display:none; } }

/* ── SCROLL REVEAL ── */
.reveal { opacity:1; transform:none; transition:opacity .85s var(--ease-out), transform .85s var(--ease-out); }
.reveal.js-hidden { opacity:0; transform:translateY(28px); }
.reveal.visible { opacity:1 !important; transform:none !important; }
.reveal-d1 { transition-delay:.1s; }
.reveal-d2 { transition-delay:.22s; }
.reveal-d3 { transition-delay:.36s; }

/* ── SCREEN-READER ONLY ── */
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0; }

/* ── SCROLLBAR ── */
::-webkit-scrollbar { width:2px; }
::-webkit-scrollbar-track { background:var(--white); }
::-webkit-scrollbar-thumb { background:var(--gray-lt); }

/* ============================================================
   PAGE TRANSITION — bold 4-strip sweep
   ============================================================ */
#page-transition {
  position:fixed; inset:0; z-index:8000; pointer-events:none;
  display:flex; flex-direction:column;
}
.pt-block {
  flex:1; background:var(--red);
  transform:scaleX(1); transform-origin:right; transition:none;
}
#page-transition.sweep-in  .pt-block { transform:scaleX(1); transform-origin:left; }
#page-transition.sweep-in  .pt-block:nth-child(1){ transition:transform .36s var(--ease-out) .00s; }
#page-transition.sweep-in  .pt-block:nth-child(2){ transition:transform .36s var(--ease-out) .05s; }
#page-transition.sweep-in  .pt-block:nth-child(3){ transition:transform .36s var(--ease-out) .10s; }
#page-transition.sweep-in  .pt-block:nth-child(4){ transition:transform .36s var(--ease-out) .15s; }
#page-transition.sweep-out .pt-block { transform:scaleX(0); transform-origin:right; }
#page-transition.sweep-out .pt-block:nth-child(1){ transition:transform .36s var(--ease-in) .15s; }
#page-transition.sweep-out .pt-block:nth-child(2){ transition:transform .36s var(--ease-in) .10s; }
#page-transition.sweep-out .pt-block:nth-child(3){ transition:transform .36s var(--ease-in) .05s; }
#page-transition.sweep-out .pt-block:nth-child(4){ transition:transform .36s var(--ease-in) .00s; }

/* ============================================================
   GAME POOL — mini-game page transitions
   Background matches the red sweep for seamless feel.
   ============================================================ */
#game-overlay {
  position:fixed; inset:0; z-index:7999;
  background:var(--red);
  display:none; flex-direction:column;
  overflow:hidden;
  touch-action:none;
}
#game-overlay.gp-active {
  display:flex;
  animation:gp-in .35s ease forwards;
}
@keyframes gp-in { from{opacity:0} to{opacity:1} }

.gp-grain {
  position:absolute; inset:0; pointer-events:none; z-index:1;
  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='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.06'/%3E%3C/svg%3E");
  opacity:.45; mix-blend-mode:overlay;
}
.gp-vignette {
  position:absolute; inset:0; pointer-events:none; z-index:2;
  background:radial-gradient(ellipse at center, transparent 35%, rgba(0,0,0,.35) 100%);
}
.gp-hdr {
  position:relative; z-index:5;
  display:flex; align-items:flex-start; justify-content:space-between;
  padding:36px 48px 0;
  transition:opacity .25s;
}
@media(max-width:768px){ .gp-hdr { padding:20px 20px 0; } }
.gp-rec {
  display:flex; align-items:center; gap:7px;
  font-family:var(--ff-g); font-size:10px; font-weight:600;
  letter-spacing:.18em; text-transform:uppercase;
  color:rgba(255,255,255,.7);
}
.gp-rec-dot {
  width:7px; height:7px; border-radius:50%;
  background:#fff;
  animation:gp-blink 1s ease-in-out infinite;
}
@keyframes gp-blink { 0%,100%{opacity:1} 50%{opacity:.15} }
.gp-title-wrap {
  position:absolute; left:0; right:0;
  text-align:center; pointer-events:none;
  display:flex; flex-direction:column; align-items:center; gap:12px;
}
.gp-title {
  font-family:var(--ff-g);
  font-size:clamp(24px, 5vw, 56px);
  font-weight:700; letter-spacing:.08em;
  text-transform:uppercase;
  color:#fff;
  line-height:1;
}
.gp-subtitle {
  font-family:var(--ff-g);
  font-size:clamp(13px, 1.8vw, 18px);
  font-weight:500; letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(255,255,255,.55);
  line-height:1.3;
  transition:opacity 1.5s ease 3s;
}
.gp-subtitle.gp-fade { opacity:0; }
.gp-timer {
  font-family:var(--ff-m); font-size:12px; font-weight:500;
  letter-spacing:.1em; color:rgba(255,255,255,.4);
}
.gp-arena {
  flex:1; position:relative; z-index:5;
  overflow:hidden;
  display:flex; align-items:center; justify-content:center;
  transition:opacity .25s;
}
.gp-bar-wrap {
  height:3px; background:rgba(0,0,0,.15);
  position:relative; z-index:5;
  margin:0 48px 28px;
  transition:opacity .25s;
}
@media(max-width:768px){ .gp-bar-wrap { margin:0 20px 16px; } }
.gp-bar { height:100%; background:#fff; width:100%; }
.gp-results {
  position:absolute; inset:0; z-index:20;
  display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:16px;
  opacity:0; pointer-events:none; transition:opacity .2s;
}
.gp-results.gp-show { opacity:1; pointer-events:auto; }
.gp-end-word {
  font-family:var(--ff-g);
  font-size:clamp(24px, 5vw, 64px);
  font-weight:800; letter-spacing:.06em;
  text-transform:uppercase; color:#fff; line-height:1.15;
  text-align:center; max-width:80%; padding:0 20px; word-break:keep-all;
  animation:gp-pop .4s ease-out;
  text-shadow:0 2px 20px rgba(0,0,0,.2);
}
@keyframes gp-pop {
  0%{transform:scale(1.5);opacity:0}
  60%{transform:scale(.96);opacity:1}
  100%{transform:scale(1)}
}
.gp-score {
  font-family:var(--ff-g); font-size:clamp(12px,1.4vw,15px); font-weight:500;
  letter-spacing:.2em; text-transform:uppercase;
  color:rgba(255,255,255,.5);
}
.gp-rating {
  font-family:var(--ff-s); font-size:clamp(15px,1.6vw,18px); font-style:italic;
  color:rgba(255,255,255,.75);
  max-width:440px; text-align:center; line-height:1.5;
}

/* ── Replay buttons (games page only) ── */
.gp-replay-wrap { display:flex; gap:12px; margin-top:24px; opacity:0; transition:opacity .5s; justify-content:center; }
.gp-replay-wrap.gp-replay-show { opacity:1; }
.gp-replay-btn { font-family:var(--ff-g); font-size:11px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; padding:12px 28px; border-radius:3px; border:none; cursor:pointer; transition:opacity .2s, transform .15s; }
.gp-replay-btn:hover { opacity:.85; transform:scale(1.03); }
.gp-replay-btn:active { transform:scale(.97); }
.gp-replay-btn { background:#fff; color:var(--black); }

/* ── Story card preview (end screen) ── */
.gp-story-preview { display:flex; justify-content:center; }
.gp-story-img {
  max-height:65vh; width:auto; border-radius:var(--radius-lg);
  box-shadow:0 8px 40px rgba(0,0,0,.4);
}
@media(max-width:768px){
  .gp-story-img { max-height:50vh; }
  .gp-replay-wrap { flex-wrap:wrap; }
}

/* ── Close button (games page end screen) ── */
.gp-close {
  position:absolute; top:12px; right:12px; z-index:25;
  background:none; border:none; color:rgba(255,255,255,.35);
  font-size:22px; cursor:pointer; padding:6px 8px; line-height:1;
  transition:color .2s, transform .15s;
  display:none;
}
.gp-close.gp-close-show { display:block; }
.gp-close:hover { color:#fff; transform:scale(1.15); }

/* ── Stat cards (games page end screen) ── */
.gp-stats {
  display:flex; gap:20px; margin:12px 0 8px;
  justify-content:center; flex-wrap:wrap;
}
.gp-stat-card {
  background:rgba(255,255,255,.07);
  backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.09); border-radius:12px;
  padding:14px 22px; text-align:center; min-width:80px;
  animation:gp-stat-in .5s ease-out both;
}
@keyframes gp-stat-in {
  0% { opacity:0; transform:translateY(16px) scale(.92); }
  100% { opacity:1; transform:translateY(0) scale(1); }
}
.gp-stat-value {
  font-family:var(--ff-g); font-size:clamp(18px,2.5vw,28px);
  font-weight:800; line-height:1.2;
}
.gp-stat-label {
  font-family:var(--ff-g); font-size:clamp(8px,1vw,11px);
  font-weight:500; letter-spacing:.15em; text-transform:uppercase;
  color:rgba(255,255,255,.4); margin-top:4px;
}
@media(max-width:768px){
  .gp-stats { gap:12px; }
  .gp-stat-card { padding:10px 16px; min-width:60px; }
}

/* ── Round hype splash ── */
.gp-hype { position:fixed; top:50%; left:50%; transform:translate(-50%,-50%) scale(.5); z-index:8100; pointer-events:none;
  font-family:var(--ff-g); font-size:clamp(48px,12vw,140px); font-weight:900; letter-spacing:.06em;
  color:#2ecc71; text-shadow:0 4px 32px rgba(46,204,113,.35); white-space:nowrap;
  animation:gp-hype .7s ease-out forwards; }
@keyframes gp-hype { 0%{opacity:0;transform:translate(-50%,-50%) scale(.5)} 20%{opacity:1;transform:translate(-50%,-50%) scale(1.1)} 40%{transform:translate(-50%,-50%) scale(1)} 70%{opacity:1} 100%{opacity:0;transform:translate(-50%,-50%) scale(1.2)} }

/* ── Game: Clapper Sync ── */
.gc-bar { width:80%; max-width:520px; height:64px; position:relative; border-radius:4px; background:rgba(0,0,0,.12); overflow:hidden; }
.gc-target { position:absolute; top:0; bottom:0; background:rgba(255,255,255,.15); border-left:2px solid rgba(255,255,255,.5); border-right:2px solid rgba(255,255,255,.5); }
.gc-line { position:absolute; top:0; bottom:0; width:3px; background:#fff; box-shadow:0 0 12px rgba(255,255,255,.5); }
.gc-round { margin-bottom:22px; font-family:var(--ff-g); font-size:clamp(12px,1.5vw,16px); letter-spacing:.22em; text-transform:uppercase; color:rgba(255,255,255,.55); }
.gc-flash { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-family:var(--ff-g); font-size:clamp(28px,5vw,48px); font-weight:700; color:#fff; opacity:0; transition:opacity .15s; pointer-events:none; text-shadow:0 2px 12px rgba(0,0,0,.2); }
.gc-flash.gp-show { opacity:1; }

/* ── Game: Cut Cut Cut ── */
.gx-counter { font-family:var(--ff-m); font-size:clamp(64px,16vw,160px); font-weight:700; color:#fff; letter-spacing:.04em; line-height:1; text-shadow:0 2px 20px rgba(0,0,0,.15); }
.gx-target { font-family:var(--ff-g); font-size:clamp(16px,2.4vw,24px); font-weight:700; letter-spacing:.25em; text-transform:uppercase; color:rgba(255,255,255,.8); margin-top:24px; }
.gx-round { font-family:var(--ff-g); font-size:clamp(12px,1.5vw,16px); letter-spacing:.22em; text-transform:uppercase; color:rgba(255,255,255,.45); margin-bottom:28px; }
.gx-flash { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-family:var(--ff-g); font-size:clamp(28px,5vw,48px); font-weight:700; color:#fff; opacity:0; transition:opacity .15s; pointer-events:none; text-shadow:0 2px 12px rgba(0,0,0,.2); }
.gx-flash.gp-show { opacity:1; }

/* ── Game: Focus Pull ── */
img.gf-circle { width:clamp(160px,28vw,280px); height:auto; object-fit:contain; border-radius:0; transition:filter .05s; display:block; }
.gf-ring { position:absolute; width:clamp(200px,32vw,340px); height:clamp(200px,32vw,340px); border:1px solid rgba(255,255,255,.2); border-radius:50%; pointer-events:none; display:flex; align-items:center; justify-content:center; }
.gf-slider { position:absolute; bottom:clamp(28px,6vw,80px); width:clamp(240px,44vw,440px); height:48px; display:flex; align-items:center; }
.gf-track { width:100%; height:3px; background:rgba(0,0,0,.15); position:relative; border-radius:2px; }
.gf-thumb { position:absolute; top:50%; width:26px; height:26px; border-radius:50%; background:#fff; transform:translate(-50%,-50%); touch-action:none; z-index:10; box-shadow:0 0 12px rgba(0,0,0,.2); }
.gf-label { position:absolute; bottom:calc(100% + 16px); left:50%; transform:translateX(-50%); font-family:var(--ff-g); font-size:clamp(11px,1.4vw,14px); letter-spacing:.2em; text-transform:uppercase; color:rgba(255,255,255,.45); white-space:nowrap; }
.gf-round { margin-bottom:22px; font-family:var(--ff-g); font-size:clamp(12px,1.5vw,16px); letter-spacing:.22em; text-transform:uppercase; color:rgba(255,255,255,.55); }
.gf-sharp { position:absolute; font-family:var(--ff-g); font-size:clamp(20px,3.5vw,36px); font-weight:700; color:#fff; opacity:0; transition:opacity .15s; pointer-events:none; letter-spacing:.1em; text-shadow:0 2px 12px rgba(0,0,0,.2); }
.gf-sharp.gp-show { opacity:1; }

/* ── Game: Quiet on Set ── */
.gq-d { position:absolute; display:flex; flex-direction:column; align-items:center; gap:4px; transform:translate(-50%,-50%) scale(0); transition:transform .25s var(--ease-out),opacity .25s; user-select:none; -webkit-user-select:none; pointer-events:all; z-index:2; }
.gq-d.gq-in { transform:translate(-50%,-50%) scale(1); }
.gq-d.gq-out { transform:translate(-50%,-50%) scale(0); opacity:0; pointer-events:none; }
.gq-d.gq-fade { opacity:0; pointer-events:none; transform:translate(-50%,-50%) scale(.6); }
.gq-emoji { font-size:clamp(38px,6.5vw,64px); display:block; line-height:1; filter:drop-shadow(0 2px 8px rgba(0,0,0,.3)); animation:gq-wob .6s ease-in-out infinite alternate; }
.gq-d.gq-out .gq-emoji { animation:none; }
.gq-snd { font-family:var(--ff-g); font-size:clamp(10px,1.2vw,13px); font-weight:600; letter-spacing:.16em; color:rgba(255,255,255,.6); white-space:nowrap; max-width:min(200px,45vw); overflow:hidden; text-overflow:ellipsis; }
@keyframes gq-wob { 0%{transform:rotate(-4deg) scale(1)} 100%{transform:rotate(4deg) scale(1.06)} }

/* ── Game: Frame the Shot ── */
.gd-stage { position:relative; width:clamp(300px,65vw,560px); height:clamp(300px,65vw,560px); border-radius:4px; background:rgba(0,0,0,.08); }
.gd-vf { border:2px solid rgba(255,255,255,.45); border-radius:3px; pointer-events:none; z-index:3; box-sizing:border-box; }
.gd-vf::before, .gd-vf::after { content:''; position:absolute; background:rgba(255,255,255,.1); }
.gd-vf::before { left:33.33%; top:0; bottom:0; width:1px; }
.gd-vf::after { top:33.33%; left:0; right:0; height:1px; }
.gd-crosshair { position:absolute; top:50%; left:50%; width:32px; height:32px; transform:translate(-50%,-50%); pointer-events:none; z-index:4; }
.gd-crosshair::before, .gd-crosshair::after { content:''; position:absolute; background:rgba(255,255,255,.6); }
.gd-crosshair::before { left:50%; top:0; bottom:0; width:1px; transform:translateX(-50%); }
.gd-crosshair::after { top:50%; left:0; right:0; height:1px; transform:translateY(-50%); }
.gd-actor { position:absolute; font-size:clamp(36px,6vw,56px); line-height:1; z-index:2; user-select:none; -webkit-user-select:none; filter:drop-shadow(0 2px 8px rgba(0,0,0,.4)); transform:translate(-50%,-50%); }
.gd-actor.gd-flee { transition:left .2s ease-in, top .2s ease-in; }
.gd-round { margin-bottom:16px; font-family:var(--ff-g); font-size:clamp(12px,1.5vw,16px); letter-spacing:.22em; text-transform:uppercase; color:rgba(255,255,255,.55); }
.gd-flash { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-family:var(--ff-g); font-size:clamp(28px,5vw,48px); font-weight:700; color:#fff; opacity:0; transition:opacity .15s; pointer-events:none; text-shadow:0 2px 12px rgba(0,0,0,.2); z-index:5; }
.gd-flash.gp-show { opacity:1; }
.gd-countdown { position:absolute; bottom:10px; right:14px; font-family:var(--ff-m); font-size:clamp(32px,6vw,56px); font-weight:700; color:rgba(255,255,255,.25); z-index:4; pointer-events:none; line-height:1; }
.gd-rec { position:absolute; top:8px; left:10px; font-family:var(--ff-g); font-size:10px; letter-spacing:.15em; color:rgba(255,255,255,.7); z-index:4; display:flex; align-items:center; gap:5px; }
.gd-rec::before { content:''; width:7px; height:7px; border-radius:50%; background:#fff; animation:gp-rec .9s ease-in-out infinite alternate; }

/* ── Game: Yapımcıyı Yakala ── */

/* Producer character card */
.gy-producer {
  position:absolute; z-index:5; user-select:none; -webkit-user-select:none;
  transform:translate(-50%,-50%);
  display:flex; flex-direction:column; align-items:center; gap:2px;
  transition:left .15s ease-out, top .15s ease-out;
}
.gy-avatar {
  display:flex; align-items:center; justify-content:center;
  width:clamp(64px,11vw,96px); height:clamp(64px,11vw,96px);
  font-size:clamp(40px,7vw,60px); line-height:1;
  background:#f5f1ec;
  border-radius:50%; border:2px solid rgba(255,255,255,.18);
  box-shadow:0 4px 24px rgba(0,0,0,.35), 0 0 0 1px rgba(255,255,255,.06);
  transition:transform .15s, border-color .15s, box-shadow .15s;
}
.gy-label {
  font-family:var(--ff-g); font-size:clamp(8px,1.1vw,11px); font-weight:700;
  letter-spacing:.2em; color:rgba(255,255,255,.5);
  background:rgba(0,0,0,.35); padding:2px 8px; border-radius:10px;
  backdrop-filter:blur(4px); white-space:nowrap;
}
.gy-producer.gy-dodge { transition:left .08s ease-in, top .08s ease-in; }
.gy-producer.gy-dodge .gy-avatar { border-color:rgba(255,200,50,.5); box-shadow:0 0 16px rgba(255,200,50,.2); }
.gy-producer.gy-flee { transition:left .1s ease-in, top .1s ease-in; }
.gy-producer.gy-caught .gy-avatar {
  transform:scale(1.25); border-color:rgba(74,222,128,.7);
  box-shadow:0 0 30px rgba(74,222,128,.35), 0 0 60px rgba(74,222,128,.1);
}

/* Catch flash ring */
.gy-flash {
  position:absolute; z-index:2; pointer-events:none;
  width:100px; height:100px; border-radius:50%;
  transform:translate(-50%,-50%) scale(0); opacity:0;
  border:3px solid rgba(74,222,128,.6);
  box-shadow:0 0 20px rgba(74,222,128,.3);
}
.gy-flash.gy-flash-go {
  animation:gy-ring .5s ease-out forwards;
}
@keyframes gy-ring {
  0%   { transform:translate(-50%,-50%) scale(0); opacity:1; }
  100% { transform:translate(-50%,-50%) scale(2.5); opacity:0; }
}

/* Bubble layer — holds floating speech bubbles */
.gy-bubble-layer {
  position:absolute; inset:0; z-index:4; pointer-events:none; overflow:hidden;
}

/* Individual speech bubble */
.gy-bubble {
  position:absolute;
  transform:translate(-50%,-50%);
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  font-size:clamp(12px,1.6vw,16px); font-weight:500;
  color:rgba(255,255,255,.92); line-height:1.35;
  background:rgba(0,0,0,.55); backdrop-filter:blur(10px);
  padding:8px 14px; border-radius:14px;
  border:1px solid rgba(255,255,255,.1);
  box-shadow:0 4px 20px rgba(0,0,0,.3);
  white-space:nowrap; max-width:clamp(180px,40vw,320px);
  overflow:hidden; text-overflow:ellipsis;
  animation:gy-bubble-in 2.2s ease forwards;
}
.gy-hl { color:#fbbf24; font-weight:700; }
@media(max-width:480px){
  .gy-bubble { white-space:normal; max-width:min(160px,42vw); font-size:11px; padding:6px 10px; border-radius:10px; }
}
@keyframes gy-bubble-in {
  0%   { opacity:0; transform:translate(-50%,-50%) translateY(8px) scale(.92); }
  10%  { opacity:1; transform:translate(-50%,-50%) translateY(0) scale(1); }
  75%  { opacity:1; transform:translate(-50%,-50%) translateY(0) scale(1); }
  100% { opacity:0; transform:translate(-50%,-50%) translateY(-10px) scale(.95); }
}

/* Center-bottom HUD */
.gy-hud {
  position:absolute; bottom:14px; left:50%; transform:translateX(-50%);
  z-index:5; pointer-events:none;
}
.gy-hud-inner {
  display:flex; align-items:center; gap:0;
  background:rgba(0,0,0,.6); backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.1);
  border-radius:16px; padding:10px 20px;
  box-shadow:0 8px 32px rgba(0,0,0,.4);
}
.gy-hud-sep {
  width:1px; height:28px; background:rgba(255,255,255,.1); margin:0 16px;
}
/* Money */
.gy-hud-money { display:flex; align-items:baseline; gap:2px; }
.gy-hud-lira {
  font-family:var(--ff-g); font-size:clamp(16px,2.2vw,22px); font-weight:700;
  color:rgba(255,255,255,.4); line-height:1;
}
.gy-hud-amount {
  font-family:var(--ff-g); font-size:clamp(20px,3vw,30px); font-weight:800;
  color:#fff; letter-spacing:-.01em; line-height:1;
}
/* Days */
.gy-hud-days { display:flex; flex-direction:column; align-items:center; gap:1px; }
.gy-hud-day-num {
  font-family:var(--ff-g); font-size:clamp(20px,3vw,30px); font-weight:800;
  color:#f87171; line-height:1; transition:color .2s;
}
.gy-hud-day-label {
  font-family:var(--ff-g); font-size:clamp(7px,.9vw,10px); font-weight:700;
  letter-spacing:.18em; color:rgba(255,255,255,.35); line-height:1;
}
/* Score (tahsilat) */
.gy-hud-score { display:flex; flex-direction:column; align-items:center; gap:1px; }
.gy-hud-score-num {
  font-family:var(--ff-g); font-size:clamp(20px,3vw,30px); font-weight:800;
  color:#4ade80; line-height:1;
}
.gy-hud-score-label {
  font-family:var(--ff-g); font-size:clamp(7px,.9vw,10px); font-weight:700;
  letter-spacing:.18em; color:rgba(255,255,255,.35); line-height:1;
}
/* HUD bump animation */
.gy-hud-bump { animation:gy-bump .3s ease; }
@keyframes gy-bump {
  0%   { transform:scale(1); }
  40%  { transform:scale(1.2); }
  100% { transform:scale(1); }
}
/* Legacy compat */
.gy-round { display:none; }

/* ── Game: Müşteri Revizyon (WhatsApp UI) ── */
/* ── Müşteri Revizyon: inline HUD bar ── */
.gm-hud-bar {
  flex-shrink:0;
  background:rgba(11,20,26,.95);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.gm-hud-inner {
  display:flex; align-items:center; justify-content:center; gap:0;
  padding:8px 16px;
}
.gm-hud-sep { width:1px; height:22px; background:rgba(255,255,255,.1); margin:0 14px; }
/* Sanity */
.gm-hud-sanity { display:flex; flex-direction:column; align-items:center; gap:4px; }
.gm-hud-sanity-label {
  font-family:var(--ff-g); font-size:9px; font-weight:700;
  letter-spacing:.18em; color:rgba(255,255,255,.35); line-height:1;
}
.gm-sanity-track { width:clamp(80px,18vw,120px); height:5px; background:rgba(255,255,255,.1); border-radius:3px; overflow:hidden; }
.gm-sanity-bar { height:100%; width:100%; background:#4ade80; border-radius:3px; transition:width .5s ease, background .5s; }
/* Revision */
.gm-hud-rev { display:flex; flex-direction:column; align-items:center; gap:1px; }
.gm-hud-rev-num {
  font-family:var(--ff-g); font-size:22px; font-weight:800;
  color:#fff; line-height:1;
}
.gm-hud-rev-label {
  font-family:var(--ff-g); font-size:9px; font-weight:700;
  letter-spacing:.18em; color:rgba(255,255,255,.35); line-height:1;
}
/* ── iPhone 16 Pro Frame (desktop only) ── */
/* Override red game overlay bg when iPhone frame is present */
#game-overlay:has(.gm-iphone) { background:var(--red); }

.gm-iphone {
  width:100%; height:100%;
  display:flex; align-items:center; justify-content:center;
}
@media(min-width:769px){
  .gm-iphone {
    padding:16px;
  }
  .gm-iphone-frame {
    position:relative;
    width:380px; height:min(820px, calc(100vh - 120px));
    border-radius:52px;
    border:5px solid #2c2c2e;
    box-shadow:none;
    overflow:hidden;
    display:flex; flex-direction:column;
    background:#000;
  }
  /* Status bar */
  .gm-status-bar {
    display:flex; align-items:center; justify-content:space-between;
    padding:14px 28px 8px;
    background:#0b141a;
    flex-shrink:0;
    position:relative; z-index:2;
  }
  .gm-sb-left { flex:1; }
  .gm-sb-time {
    font-family:-apple-system,BlinkMacSystemFont,'SF Pro Text',sans-serif;
    font-size:15px; font-weight:600; color:#fff;
    letter-spacing:-.2px;
  }
  .gm-sb-island {
    width:126px; height:36px;
    background:#000; border-radius:20px;
    flex-shrink:0;
    box-shadow:0 0 0 0.5px rgba(255,255,255,.06);
  }
  .gm-sb-right {
    flex:1; display:flex; align-items:center; justify-content:flex-end; gap:5px;
  }
  .gm-sb-icon { width:16px; height:12px; color:#fff; }
  .gm-sb-batt { display:flex; align-items:center; gap:1px; }
  .gm-sb-batt-body {
    width:22px; height:11px; border:1.5px solid rgba(255,255,255,.9);
    border-radius:3px; padding:1px; position:relative;
  }
  .gm-sb-batt-fill {
    width:65%; height:100%; background:#fff; border-radius:1px;
  }
  .gm-sb-batt-tip {
    width:2px; height:5px; background:rgba(255,255,255,.5);
    border-radius:0 1px 1px 0;
  }
  /* Home indicator */
  .gm-home-indicator {
    padding:6px 0 8px;
    display:flex; justify-content:center;
    background:#0b141a;
    flex-shrink:0;
  }
  .gm-home-bar {
    width:130px; height:5px; background:rgba(255,255,255,.25);
    border-radius:3px;
  }
  /* Side buttons — volume + power */
  .gm-iphone-frame::before {
    content:'';
    position:absolute; left:-6px; top:160px;
    width:3px; height:32px;
    background:#1a1a1a; border-radius:2px 0 0 2px;
    box-shadow:0 38px 0 #1a1a1a, 0 -44px 0 #1a1a1a;
  }
  .gm-iphone-frame::after {
    content:'';
    position:absolute; right:-6px; top:190px;
    width:3px; height:64px;
    background:#1a1a1a; border-radius:0 2px 2px 0;
  }
}
@media(max-width:768px){
  .gm-iphone { position:absolute; inset:0; }
  .gm-iphone-frame {
    position:absolute; inset:0;
    display:flex; flex-direction:column;
    border-radius:0;
  }
  .gm-status-bar { display:none; }
  .gm-home-indicator { display:none; }
  #game-overlay:has(.gm-iphone) { background:var(--red); }
}

/* ── Fullscreen WhatsApp frame ── */
.gm-wrap {
  position:relative; flex:1;
  display:flex; flex-direction:column;
  background:#0b141a; overflow:hidden;
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
}
.gm-wa-header { display:flex; align-items:center; gap:8px; padding:8px 12px; background:#1f2c33; border-bottom:1px solid rgba(255,255,255,.06); flex-shrink:0; }
.gm-wa-back { flex-shrink:0; display:flex; align-items:center; }
.gm-wa-back svg { width:22px; height:22px; }
.gm-wa-avatar { width:36px; height:36px; border-radius:50%; background:rgba(255,255,255,.08); display:flex; align-items:center; justify-content:center; font-size:17px; flex-shrink:0; }
.gm-wa-info { flex:1; min-width:0; }
.gm-wa-name { font-size:15px; font-weight:600; color:#e9edef; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.gm-wa-status { font-size:12px; color:#8696a0; }
.gm-wa-actions { display:flex; align-items:center; gap:16px; flex-shrink:0; }
.gm-wa-actions svg { width:20px; height:20px; }
.gm-chat { flex:1; overflow-y:auto; padding:14px 16px 60px; display:flex; flex-direction:column; gap:3px; background:#0b141a url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M30 5l5 8h-10zM10 25l5 8H5zM50 25l5 8H45zM30 45l5 8h-10z' fill='rgba(255,255,255,.012)'/%3E%3C/svg%3E"); scroll-behavior:smooth; }
.gm-chat::-webkit-scrollbar { width:3px; }
.gm-chat::-webkit-scrollbar-thumb { background:rgba(255,255,255,.08); border-radius:2px; }
.gm-bubble { max-width:82%; padding:6px 10px 6px 10px; border-radius:8px; font-size:14px; line-height:1.45; animation:gm-slide .25s ease-out; word-wrap:break-word; position:relative; }
.gm-bubble-client { align-self:flex-start; background:#1f2c33; color:#e9edef; border-top-left-radius:2px; }
.gm-bubble-you { align-self:flex-end; background:#005c4b; color:#e9edef; border-top-right-radius:2px; padding-right:42px; padding-bottom:4px; }
.gm-ticks { position:absolute; right:6px; bottom:4px; font-size:11px; color:rgba(255,255,255,.35); letter-spacing:-2px; }
.gm-delivered .gm-ticks { color:#53bdeb; }
.gm-bubble-system { align-self:center; background:rgba(255,255,255,.05); color:rgba(255,255,255,.35); font-size:11px; border-radius:6px; padding:3px 12px; }
.gm-reaction { position:absolute; bottom:-10px; left:-4px; font-size:16px; background:#1f2c33; border-radius:12px; padding:1px 4px; line-height:1; box-shadow:0 1px 4px rgba(0,0,0,.3); animation:gm-react-pop .3s ease; }
.gm-bubble:has(.gm-reaction) { margin-bottom:14px; }
@keyframes gm-react-pop { 0%{transform:scale(0);} 60%{transform:scale(1.2);} 100%{transform:scale(1);} }
.gm-typing { align-self:flex-start; display:flex; gap:3px; padding:12px 16px; background:#1f2c33; border-radius:8px; border-top-left-radius:2px; }
.gm-typing span { width:6px; height:6px; border-radius:50%; background:rgba(255,255,255,.25); animation:gm-dot 1.4s infinite; }
.gm-typing span:nth-child(2) { animation-delay:.2s; }
.gm-typing span:nth-child(3) { animation-delay:.4s; }
.gm-options { display:flex; gap:10px; padding:14px 16px; background:rgba(11,20,26,.95); flex-shrink:0; }
.gm-opt { flex:1; padding:14px 12px; border-radius:10px; border:1.5px solid rgba(255,255,255,.18); background:rgba(255,255,255,.05); color:#e9edef; font-size:15px; font-weight:600; cursor:pointer; transition:background .15s, border-color .15s, transform .1s; text-align:center; position:relative; overflow:hidden; line-height:1.3; }
.gm-opt:hover { background:rgba(255,255,255,.1); border-color:rgba(255,255,255,.35); transform:scale(1.02); }
.gm-opt:active { background:rgba(37,211,102,.2); border-color:#25D366; transform:scale(.97); }
.gm-opt-text { position:relative; z-index:1; }
.gm-opt-timer { position:absolute; bottom:0; left:0; height:3px; background:#25D366; width:100%; }
.gm-working { align-self:flex-end; display:flex; align-items:center; gap:8px; padding:6px 10px; background:#005c4b; color:rgba(233,237,239,.5); font-size:12px; border-radius:8px; border-top-right-radius:2px; animation:gm-slide .25s ease-out; }
.gm-working-bar { width:50px; height:3px; background:rgba(255,255,255,.12); border-radius:2px; overflow:hidden; }
.gm-working-fill { height:100%; background:#25D366; animation:gm-work .8s ease-in-out; }
/* mobile overrides removed — fullscreen is now default */
/* WhatsApp call bubble */
.gm-call { align-self:flex-start; display:flex; align-items:center; gap:10px; padding:8px 12px 8px 10px; background:#182229; border-radius:8px; border-top-left-radius:2px; border:1px solid rgba(255,255,255,.06); max-width:82%; animation:gm-slide .25s ease-out; }
.gm-call-icon { width:32px; height:32px; border-radius:50%; background:rgba(239,68,68,.1); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.gm-call-icon svg { width:16px; height:16px; }
.gm-call-info { flex:1; min-width:0; }
.gm-call-title { font-size:13px; font-weight:600; color:#e9edef; }
.gm-call-sub { font-size:10px; color:#8696a0; margin-top:1px; }
.gm-call-time { font-size:10px; color:#667781; align-self:flex-end; white-space:nowrap; }
/* Link preview inside bubble */
.gm-link-preview { background:rgba(255,255,255,.05); border-left:3px solid #25D366; border-radius:0 4px 4px 0; padding:6px 8px; margin-bottom:4px; }
.gm-bubble-client .gm-link-preview { border-left-color:rgba(255,255,255,.15); }
.gm-link-title { font-size:12px; font-weight:600; color:#e9edef; margin-bottom:1px; word-break:break-all; }
.gm-link-domain { font-size:10px; color:#8696a0; display:flex; align-items:center; gap:3px; }
/* Voice note */
.gm-voice { display:flex; align-items:center; gap:8px; min-width:130px; }
.gm-voice-play { width:28px; height:28px; border-radius:50%; background:rgba(255,255,255,.1); display:flex; align-items:center; justify-content:center; font-size:11px; color:#e9edef; flex-shrink:0; cursor:pointer; }
.gm-voice-bars { display:flex; align-items:center; gap:1.5px; height:24px; flex:1; }
.gm-voice-bars span { display:block; width:2px; background:rgba(255,255,255,.35); border-radius:1px; }
.gm-voice-dur { font-size:10px; color:#8696a0; white-space:nowrap; }
.gm-voice-bubble .gm-ticks { bottom:4px; }
/* Bubble timestamp */
.gm-time { font-size:10px; color:#667781; margin-left:6px; white-space:nowrap; float:right; margin-top:4px; }
.gm-bubble-you .gm-time { margin-right:28px; }
@keyframes gm-slide { from{opacity:0;transform:translateY(6px)} to{opacity:1;transform:translateY(0)} }
@keyframes gm-dot { 0%,60%,100%{opacity:.25;transform:translateY(0)} 30%{opacity:.8;transform:translateY(-3px)} }
@keyframes gm-work { from{width:0} to{width:100%} }
@keyframes gm-shake { 0%,100%{transform:translateX(0)} 20%{transform:translateX(-3px)} 40%{transform:translateX(3px)} 60%{transform:translateX(-2px)} 80%{transform:translateX(1px)} }

/* ============================================================
   LOADER
   ============================================================ */
#loader {
  position:fixed; inset:0; background:var(--black); z-index:9500;
  display:flex; flex-direction:column; align-items:center;
  justify-content:center; gap:20px;
  transition:opacity .55s var(--ease-in);
}
#loader.done { opacity:0; pointer-events:none; }
.loader-logo {
  height:44px; width:auto; display:block;
  filter:brightness(0) invert(1);
}
.loader-track { width:140px; height:1px; background:#1e1a16; overflow:hidden; }
.loader-bar   { height:100%; background:var(--red); width:0%; }
.loader-pct   { font-family:var(--ff-g); font-size:9px; letter-spacing:.16em; color:#3a3530; }

/* ============================================================
   NAV — centered sticky horizontal, no hamburger
   ============================================================ */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  height:68px;
  display:flex; align-items:center;
  padding:0 48px;
  background:rgba(8,7,6,.94);
  backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(255,255,255,.07);
}
@media(max-width:960px){ .nav{ padding:0 24px; height:60px; } }

.nav.scrolled {
  background:rgba(8,7,6,.98);
}

.nav-logo {
  font-family:var(--ff-g); font-size:14px; font-weight:800;
  letter-spacing:.16em; text-transform:uppercase;
  color:var(--white); text-decoration:none;  white-space:nowrap; position:relative; z-index:2;
}
.nav-logo span { color:var(--red); }

.nav-logo-img {
  height:39px; width:auto; display:block; object-fit:contain;
  filter:brightness(0) invert(1);
}

/* Center nav links — span full nav width and flex-center, so they sit at exact viewport center */
.nav-links {
  position:absolute; left:0; right:0;
  display:flex; align-items:center; justify-content:center;
  gap:0; list-style:none;
  pointer-events:none;
}
.nav-links li { pointer-events:all; }
.nav-links li a {
  font-family:var(--ff-g); font-size:11px; font-weight:500;
  letter-spacing:.18em; text-transform:uppercase;
  color:rgba(255,255,255,.5); text-decoration:none;  padding:8px 18px; position:relative;
  transition:color .3s;
}
.nav-links li a::after {
  content:''; position:absolute; bottom:2px; left:18px; right:18px;
  height:1px; background:var(--red);
  transform:scaleX(0); transform-origin:left;
  transition:transform .3s var(--ease-out);
}
.nav-links li a:hover { color:var(--white); }
.nav-links li a:hover::after { transform:scaleX(1); }
.nav-links li a.active { color:var(--white); }
.nav-links li a.active::after { transform:scaleX(1); }

/* SERVICES — center item, bigger */
.nav-links li.nav-featured a {
  font-size:13px; font-weight:700; letter-spacing:.22em;
  color:var(--white); padding:8px 26px;
}
.nav-links li.nav-featured a::after { left:26px; right:26px; background:var(--red); height:2px; }

/* Nav right group — Instagram icon + Games button */
.nav-right {
  position:relative; z-index:2; margin-left:auto;
  display:flex; align-items:center; gap:12px;
}
.nav-games-btn {
  font-family:var(--ff-g); font-size:9px; font-weight:700;
  letter-spacing:.16em; text-transform:uppercase;
  background:var(--red); color:#fff; padding:6px 14px;
  text-decoration:none; transition:opacity .25s;
  border-radius:0;
}
.nav-games-btn:hover { opacity:.85; }
.nav-ig {
  display:flex; align-items:center;  opacity:.5; transition:opacity .25s;
}
.nav-ig:hover { opacity:1; }
.nav-ig svg { width:18px; height:18px; fill:#fff; }

/* nav always dark — no color overrides on scroll */

/* Mobile nav */
@media(max-width:960px){
  .nav-links { display:none; }
  /* Mobile hamburger fallback */
  .nav-mobile-toggle {
    display:flex; flex-direction:column; gap:5px;
    background:none; border:none; padding:4px;
    margin-left:auto;
  }
  .nav-mobile-toggle span {
    display:block; width:24px; height:1px; background:var(--white);
    transition:transform .3s, opacity .3s, background .4s;
  }
  /* mobile toggle stays white on always-dark nav */
  .nav-mobile-toggle.open span:nth-child(1){ transform:rotate(45deg) translate(4px,4px); }
  .nav-mobile-toggle.open span:nth-child(2){ opacity:0; }
  .nav-mobile-toggle.open span:nth-child(3){ transform:rotate(-45deg) translate(4px,-4px); }
}
@media(min-width:961px){ .nav-mobile-toggle{ display:none; } }

/* Mobile drawer */
.nav-mobile-drawer {
  display:none; position:fixed; inset:0; top:60px;
  background:var(--black); z-index:999;
  flex-direction:column; justify-content:center; align-items:center; gap:8px;
  padding:40px 24px; overflow-y:auto;
}
.nav-mobile-drawer.open { display:flex; }
.nav-mobile-drawer a {
  font-family:var(--ff-g); font-size:clamp(28px,6vw,48px); font-weight:300;
  letter-spacing:.08em; text-transform:uppercase;
  color:var(--white); text-decoration:none;  padding:10px 0; border-bottom:1px solid rgba(255,255,255,.07); width:100%;
  text-align:center; transition:color .3s;
}
.nav-mobile-drawer a.featured { color:var(--red); font-weight:700; }
.nav-mobile-drawer a:hover { color:var(--red); }

/* ============================================================
   SECTION SHARED
   ============================================================ */
.section-eyebrow {
  font-family:var(--ff-g); font-size:10px; font-weight:600; letter-spacing:.22em;
  text-transform:uppercase; color:var(--red-text);
  display:none;
}
.section-eyebrow::before { content:none; }

.section-title {
  font-family:var(--ff-g);
  font-size:clamp(40px,5.2vw,84px); font-weight:300;
  letter-spacing:-.01em; line-height:1;
}
.section-title em { font-style:italic; color:var(--red); }
.section-title strong { font-weight:700; }

/* ============================================================
   SKILL TAGS
   ============================================================ */
.skill-tags { display:flex; flex-wrap:wrap; gap:6px; margin-top:18px; }
.skill-tag {
  font-family:var(--ff-g); font-size:9px; font-weight:500; letter-spacing:.14em;
  text-transform:uppercase; padding:5px 12px;
  border:1px solid var(--border); color:var(--gray);
  transition:border-color .25s, color .25s, background .25s;
}
.skill-tag:hover { border-color:var(--red); color:var(--red); }

/* ============================================================
   FULLSCREEN PLAYER
   ============================================================ */
#fs-player {
  position:fixed; inset:0; z-index:7000; background:#000;
  display:flex; flex-direction:column;
  opacity:0; pointer-events:none; transition:opacity .35s;
}
#fs-player.open { opacity:1; pointer-events:all; }
#fs-player-inner {
  flex:1; display:flex; align-items:center; justify-content:center;
  overflow:hidden; position:relative;
}
#fs-player-inner video, #fs-player-inner img {
  max-width:100%; max-height:100%; object-fit:contain;
  transform:scale(.97); transition:transform .45s var(--ease-out);
}
#fs-player.open #fs-player-inner video,
#fs-player.open #fs-player-inner img { transform:scale(1); }
#fs-player-inner iframe { width:100%; height:100%; border:none; }
#fs-bar {
  height:54px; background:rgba(0,0,0,.75); backdrop-filter:blur(12px);
  display:flex; align-items:center; justify-content:space-between;
  padding:0 28px; flex-shrink:0;
}
#fs-counter {
  font-family:var(--ff-g); font-size:10px; font-weight:500; letter-spacing:.16em;
  color:var(--gray); margin-right:auto; padding-left:20px;
}
#fs-prev, #fs-next {
  position:absolute; top:50%; transform:translateY(-50%);
  width:56px; height:56px; background:rgba(0,0,0,.55); border:1px solid rgba(255,255,255,.12);
  border-radius:50%;  font-size:20px; color:var(--white);
  display:flex; align-items:center; justify-content:center;
  transition:background .2s, border-color .2s; z-index:10;
}
#fs-prev { left:24px; }
#fs-next { right:24px; }
#fs-prev:hover, #fs-next:hover { background:rgba(184,84,80,.75); border-color:var(--red); }

/* Thumbnail strip — sits between video and bar in normal flex flow */
#fs-strip {
  flex-shrink:0;
  overflow-x:auto; overflow-y:hidden;
  background:rgba(0,0,0,.92);
  border-top:1px solid rgba(255,255,255,.06);
  padding:10px 24px;
  display:flex; justify-content:center;
  z-index:9;
  scrollbar-width:none;
}
#fs-strip::-webkit-scrollbar { display:none; }
#fs-thumbs { display:flex; gap:6px; }

.fs-thumb {
  flex-shrink:0; width:96px; height:54px;
  border:2px solid transparent; border-radius:2px;
  overflow:hidden; transition:border-color .2s, opacity .2s;
  opacity:.5; background:#111;
}
.fs-thumb img { width:100%; height:100%; object-fit:cover; display:block; }
.fs-thumb-empty { width:100%; height:100%; background:#1a1714; }
.fs-thumb:hover { opacity:.8; }
.fs-thumb.active { border-color:var(--red); opacity:1; }

#fs-bar { position:relative; z-index:11; }
#fs-title-text { font-family:var(--ff-g); font-size:14px; font-weight:400; color:var(--white); }
#fs-meta { font-family:var(--ff-g); font-size:9px; letter-spacing:.14em; text-transform:uppercase; color:var(--gray); }
#fs-close {
  font-family:var(--ff-g); font-size:10px; font-weight:500; letter-spacing:.16em; text-transform:uppercase;
  color:var(--gray-lt); background:none; border:none;  transition:color .25s;
}
#fs-close:hover { color:var(--red); }
#fs-capture {
  position:absolute; top:20px; right:20px; z-index:12;
  font-family:var(--ff-g); font-size:12px; font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  color:#fff; background:var(--red); border:none; border-radius:6px;
  padding:10px 18px; cursor:pointer; transition:opacity .2s;
  opacity:.85;
}
#fs-capture:hover { opacity:1; }
.fs-spinner {
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center; pointer-events:none;
}
.fs-spinner::after {
  content:''; width:36px; height:36px;
  border:2px solid rgba(255,255,255,.08); border-top-color:var(--red);
  border-radius:50%; animation:spin .75s linear infinite;
}
@keyframes spin { to{ transform:rotate(360deg); } }

/* ============================================================
   SERVICE GALLERY LIGHTBOX
   ============================================================ */
/* ============================================================
   SERVICE GALLERY LIGHTBOX — redesigned
   ============================================================ */
#svc-gallery {
  position:fixed; inset:0; z-index:7500;
  background:rgba(8,7,6,.72);
  backdrop-filter:blur(20px) saturate(.7);
  display:flex; flex-direction:column;
  opacity:0; pointer-events:none; transition:opacity .35s;
  overflow:hidden;
}
#svc-gallery.open { opacity:1; pointer-events:all; }

.sg-header {
  flex-shrink:0;
  display:flex; align-items:center; justify-content:space-between;
  padding:28px 48px 24px;
  border-bottom:1px solid rgba(255,255,255,.07);
  background:rgba(10,9,8,.6);
}
.sg-title {
  font-family:var(--ff-g); font-size:13px; font-weight:700;
  letter-spacing:.2em; text-transform:uppercase; color:var(--white);
}
.sg-count {
  font-family:var(--ff-g); font-size:9px; font-weight:400;
  letter-spacing:.14em; text-transform:uppercase; color:var(--gray);
  margin-left:16px;
}
.sg-header-left { display:flex; align-items:center; gap:0; }
.sg-close {
  display:flex; align-items:center; gap:10px;
  font-family:var(--ff-g); font-size:10px; font-weight:600; letter-spacing:.2em; text-transform:uppercase;
  color:var(--gray); background:none; border:1px solid rgba(255,255,255,.12);
  padding:10px 20px; transition:all .25s;
}
.sg-close:hover { color:var(--white); border-color:var(--red); background:var(--red); }

.sg-body {
  flex:1; overflow-y:auto; padding:40px 48px 48px;
  scrollbar-width:thin; scrollbar-color:rgba(184,84,80,.4) transparent;
  cursor:default;
}

.sg-grid {
  position: relative;
  width:100%; max-width:1400px; margin:0 auto;
  opacity:0; transition:opacity .25s;
}
.sg-grid.laid-out { opacity:1; }
.sg-grid .sg-item { position: absolute; }

.sg-item {
  background:#111010; overflow:hidden;  position:relative; border-radius:2px;
  border:1px solid rgba(255,255,255,.05);
  transition:border-color .3s;
}
.sg-item:hover { border-color:rgba(184,84,80,.5); }
.sg-item-media {
  width:100%; position:relative; overflow:hidden;
  background:#0a0909;
}
/* aspect ratios for gallery items */
.sg-item[data-ar="landscape"] .sg-item-media { aspect-ratio:16/9; }
.sg-item[data-ar="square"]    .sg-item-media { aspect-ratio:1/1; }
.sg-item[data-ar="portrait"]  .sg-item-media { aspect-ratio:9/16; }
.sg-item:not([data-ar])       .sg-item-media { aspect-ratio:16/9; }

.sg-item img {
  width:100%; height:100%; object-fit:cover; display:block;
  transition:transform .55s var(--ease-out), filter .4s;
  filter:saturate(.7);
}
.sg-item[data-ar="portrait"] img { object-position:top center; }
.sg-item:hover img { transform:scale(1.04); filter:saturate(1); }

/* Video thumb in gallery */
.sg-item-video {
  width:100%; height:100%; object-fit:cover; display:block;  background:#000;
}
.sg-item-play {
  position:absolute; top:50%; left:50%;
  transform:translate(-50%,-50%) scale(.85);
  width:56px; height:56px; border-radius:50%;
  background:rgba(184,84,80,.9); border:2px solid rgba(255,255,255,.15);
  display:flex; align-items:center; justify-content:center;
  opacity:0; transition:opacity .3s, transform .3s var(--ease-out);
  pointer-events:none;
}
.sg-item-play svg { width:18px; height:18px; fill:#fff; margin-left:3px; }
.sg-item:hover .sg-item-play { opacity:1; transform:translate(-50%,-50%) scale(1); }
.sg-item-type-badge {
  position:absolute; top:10px; left:10px;
  font-family:var(--ff-g); font-size:7px; font-weight:700; letter-spacing:.18em; text-transform:uppercase;
  padding:3px 8px; background:rgba(184,84,80,.9); color:#fff;
}

.sg-item-label {
  padding:14px 18px 16px;
  font-family:var(--ff-g); font-size:10px; font-weight:500;
  letter-spacing:.12em; text-transform:uppercase;
  color:var(--gray); border-top:1px solid rgba(255,255,255,.05);
  background:rgba(14,12,10,.8);
  display:flex; align-items:center; justify-content:space-between;
}
.sg-item-label .sg-label-text { color:rgba(220,215,207,.7); }
.sg-item-label .sg-open-icon { color:var(--red); font-size:12px; opacity:.7; }

.sg-placeholder {
  width:100%; height:100%; aspect-ratio:16/9;
  background:linear-gradient(135deg, #141210, #1e1b17);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px;
}
.sg-placeholder-icon { font-size:28px; opacity:.2; }
.sg-placeholder-txt {
  font-family:var(--ff-g); font-size:9px; letter-spacing:.18em; text-transform:uppercase;
  color:#3a3530;
}

/* Gallery zoom icon on image items */
.sg-item-zoom {
  position:absolute; top:10px; right:10px; z-index:6;
  font-size:16px; color:rgba(255,255,255,.6);
  opacity:0; transition:opacity .25s;
  pointer-events:none;
}
.sg-item:hover .sg-item-zoom { opacity:1; }

/* Before/after slider inside gallery popup */
.sg-ba-slider { border-radius:0; width:100%; height:100%; cursor:ew-resize; }
.sg-ba-fill { overflow:hidden; }
.sg-ba-fill img { width:100%; height:100%; object-fit:cover; display:block; }

/* ============================================================
   UNIFIED ITEM VIEWER — z:8500, above gallery (7500)
   ============================================================ */
#sg-viewer {
  position:fixed; inset:0; z-index:8500;
  background:rgba(8,7,6,.75);
  backdrop-filter:blur(24px) saturate(.65);
  display:flex; flex-direction:column;
  opacity:0; pointer-events:none; transition:opacity .28s;
}
#sg-viewer.open { opacity:1; pointer-events:all; }

/* Header bar */
#sg-viewer-header {
  flex-shrink:0;
  display:flex; align-items:center; gap:16px;
  padding:18px 32px 14px;
  border-bottom:1px solid rgba(255,255,255,.06);
  background:rgba(8,7,6,.85);
}
#sg-viewer-title {
  font-family:var(--ff-g); font-size:11px; font-weight:700;
  letter-spacing:.2em; text-transform:uppercase; color:var(--white);
  flex:1;
}
#sg-viewer-counter {
  font-family:var(--ff-g); font-size:9px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--gray);
}
#sg-viewer-close {
  font-family:var(--ff-g); font-size:9px; font-weight:700; letter-spacing:.2em; text-transform:uppercase;
  color:rgba(220,215,207,.45); background:none; border:1px solid rgba(220,215,207,.12);
  padding:8px 18px; transition:all .22s;
}
#sg-viewer-close:hover { color:var(--white); border-color:var(--red); background:var(--red); }
#sgv-capture {
  font-family:var(--ff-g); font-size:9px; font-weight:700; letter-spacing:.2em; text-transform:uppercase;
  color:#fff; background:var(--red); border:1px solid var(--red);
  padding:8px 18px; cursor:pointer; transition:opacity .2s;
}
#sgv-capture:hover { opacity:.8; }

/* Stage — media + side arrows */
#sg-viewer-stage {
  flex:1; display:flex; align-items:stretch; min-height:0; position:relative;
}
#sg-viewer-media {
  flex:1; min-height:0;
  overflow:hidden; position:relative; background:transparent;
}
/* All media content is absolutely positioned so dimensions are always definite.
   This prevents portrait images being clipped when max-height:100% fails to
   resolve in a flex context. */
#sg-viewer-media .sgv-img {
  position:absolute; inset:0;
  margin:24px;
  width:calc(100% - 48px); height:calc(100% - 48px);
  object-fit:contain; object-position:center !important;
  display:block; scale:none !important;
}
#sg-viewer-media .sgv-video {
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:contain; display:block; background:#000;
}
#sg-viewer-media .sgv-iframe {
  position:absolute; inset:0;
  width:100%; height:100%; border:none;
}
.sgv-fullq-btn {
  position:absolute; bottom:80px; right:24px; z-index:20;
  background:rgba(192,57,43,.88); color:#fff; border:none;
  padding:7px 16px;
  font-family:var(--ff-g); font-size:9px; font-weight:600;
  letter-spacing:.16em; text-transform:uppercase;
  cursor:pointer; border-radius:2px;
  transition:background .2s;
}
.sgv-fullq-btn:hover { background:rgba(192,57,43,1); }
#sg-viewer-label {
  position:absolute; bottom:16px; left:50%; transform:translateX(-50%);
  font-family:var(--ff-g); font-size:9px; letter-spacing:.18em; text-transform:uppercase;
  color:rgba(220,215,207,.3); white-space:nowrap; pointer-events:none;
}
.sgv-spinner {
  width:32px; height:32px;
  border:2px solid rgba(255,255,255,.06); border-top-color:var(--red);
  border-radius:50%; animation:spin .75s linear infinite;
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
}
.sgv-slider-wrap {
  position:absolute; inset:0;
}
.sgv-ba {
  width:100%; height:100%;
}
/* Viewer BA slider: show full image (contain) so portrait images are never cropped */
.sgv-ba .sg-ba-fill img {
  object-fit:contain; object-position:center;
}
/* Zoom/pan wrapper — content is placed inside this; transform applies zoom */
#sgv-zoom-wrap {
  position:absolute; inset:0;
  transform-origin:center center;
  will-change:transform;
}
.sgv-empty {
  font-family:var(--ff-g); font-size:10px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--gray); opacity:.4;
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
}

/* Prev / Next arrows */
#sg-viewer-prev,
#sg-viewer-next {
  flex-shrink:0; width:64px;
  display:flex; align-items:center; justify-content:center;
  font-size:22px; color:rgba(220,215,207,.25);
  background:none; border:none;  transition:color .2s, background .2s;
  z-index:2;
}
#sg-viewer-prev:hover,
#sg-viewer-next:hover {
  color:var(--white); background:rgba(184,84,80,.15);
}
@media(max-width:768px){
  #sg-viewer-prev, #sg-viewer-next { display:none; }
  #sg-viewer-header { padding:12px 16px 10px; gap:10px; }
  #sg-viewer-title {
    white-space:nowrap; overflow:hidden; min-width:0;
  }
  #sg-viewer-title.marquee > span {
    display:inline-block;
    animation:sgMarquee var(--marquee-dur, 8s) linear infinite;
    padding-right:3em;
  }
  #sg-viewer-counter { white-space:nowrap; flex-shrink:0; }
  #sg-viewer-close { flex-shrink:0; }
  .sg-header { padding:20px 20px 16px; }
  .sg-body { padding:24px 20px 32px; }
}
@keyframes sgMarquee {
  0%   { transform:translateX(0); }
  100% { transform:translateX(-100%); }
}

/* Thumbnail strip */
#sg-viewer-strip {
  flex-shrink:0; height:88px;
  background:rgba(8,7,6,.9); border-top:1px solid rgba(255,255,255,.06);
  overflow-x:auto; overflow-y:hidden;
  scrollbar-width:thin; scrollbar-color:rgba(184,84,80,.3) transparent;
  display:flex; align-items:center;
}
#sg-viewer-thumbs {
  display:flex; gap:4px; padding:8px 16px;
  min-width:max-content;
}
.sgv-thumb {
  /* width is driven by inline aspect-ratio + height:68px set per-item */
  height:68px; width:auto; flex-shrink:0; position:relative;
  overflow:hidden; background:#111010;
  border:2px solid transparent; transition:border-color .2s, opacity .2s;
  opacity:.45;
}
.sgv-thumb.active { border-color:var(--red); opacity:1; }
.sgv-thumb:hover { opacity:.85; }
.sgv-thumb img {
  width:100%; height:100%; object-fit:cover; display:block;
}
.sgv-thumb video, .sgv-thumb-vid {
  width:100%; height:100%; object-fit:cover; display:block;
}
.sgv-thumb-play {
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-size:14px; color:rgba(255,255,255,.7); pointer-events:none;
  background:rgba(0,0,0,.25);
}
.sgv-thumb.active .sgv-thumb-play { color:var(--white); }
.sgv-thumb-empty { width:100%; height:100%; background:#1a1714; }

/* Video thumbnail in gallery grid */
.sg-item-video-thumb {
  width:100%; height:100%; object-fit:cover; display:block;
  background:#0a0909;
}

/* ============================================================
   IMAGE FULLSCREEN LIGHTBOX (legacy — kept for safety)
   ============================================================ */
#img-fullscreen {
  position:fixed; inset:0; z-index:9500;
  background:rgba(5,4,3,.96);
  display:flex; align-items:center; justify-content:center;
  opacity:0; pointer-events:none; transition:opacity .3s;
}
#img-fullscreen.open { opacity:1; pointer-events:all; }
#img-fs-inner {
  position:relative; max-width:92vw; max-height:88vh;
  display:flex; align-items:center; justify-content:center;
}
#img-fs-inner img {
  max-width:92vw; max-height:88vh;
  object-fit:contain; display:block;
  border-radius:2px;
}
#img-fs-close {
  position:absolute; top:24px; right:32px;
  font-family:var(--ff-g); font-size:9px; font-weight:700; letter-spacing:.2em; text-transform:uppercase;
  color:rgba(220,215,207,.5); background:none; border:1px solid rgba(220,215,207,.15);
  padding:8px 18px; transition:all .25s;
}
#img-fs-close:hover { color:var(--white); border-color:var(--red); background:var(--red); }
#img-fs-caption {
  position:absolute; bottom:32px; left:50%; transform:translateX(-50%);
  font-family:var(--ff-g); font-size:9px; letter-spacing:.18em; text-transform:uppercase;
  color:rgba(220,215,207,.4); white-space:nowrap;
}
#img-fs-spinner {
  width:28px; height:28px; border:2px solid rgba(255,255,255,.1);
  border-top-color:var(--red); border-radius:50%;
  animation:spin .8s linear infinite; display:none;
}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer {
  background:var(--black); padding:18px 60px;
  display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:24px;
}
.footer-logo { height:32px; width:auto; display:block; filter:brightness(0) invert(1); }
.footer-copy { font-family:var(--ff-g); font-size:9px; font-weight:400; letter-spacing:.14em; text-transform:uppercase; color:#2e2a26; text-align:center; }
.footer-links { display:flex; gap:20px; justify-content:flex-end; }
.footer-links a {
  font-family:var(--ff-g); font-size:9px; font-weight:500; letter-spacing:.14em; text-transform:uppercase;
  text-decoration:none; transition:opacity .25s;
  background:var(--paper); color:var(--black); padding:6px 14px; border-radius:0;
}
.footer-links a:hover { opacity:.7; }
.footer-links a[data-page*="games"] {
  background:var(--red); color:#fff; font-weight:700; letter-spacing:.16em;
}
.footer-links a[data-page*="games"]:hover { opacity:.85; }
.footer-links a[href*="imdb"] {
  background:var(--paper); color:var(--black);
}
@media(max-width:768px){
  .site-footer{ grid-template-columns:1fr; text-align:center; padding:14px 16px; gap:8px; }
  .footer-logo { height:24px; margin:0 auto; }
  .footer-copy { font-size:7px; letter-spacing:.1em; }
  .footer-links { flex-wrap:wrap; justify-content:center; gap:6px; }
  .footer-links a { font-size:8px; padding:5px 10px; letter-spacing:.1em; border-radius:0; }
  .footer-links a[href*="imdb"] { display:none; }
}

/* ── CTA BAND ── */
.cta-band {
  background:var(--black); padding:80px 60px;
  display:flex; align-items:center; justify-content:space-between; gap:40px;
}
@media(max-width:768px){ .cta-band{ padding:56px 20px; flex-direction:column; align-items:flex-start; gap:28px; } }
.cta-headline {
  font-family:var(--ff-g); font-size:clamp(28px,3.8vw,56px);
  font-weight:300; color:var(--white); line-height:1.1;
}
.cta-headline span { color:var(--red); font-weight:700; }
.btn-primary {
  display:inline-flex; align-items:center; gap:14px;
  font-family:var(--ff-g); font-size:11px; font-weight:600; letter-spacing:.18em;
  text-transform:uppercase; padding:16px 32px;
  background:var(--red); color:var(--white);
  border:none; text-decoration:none; flex-shrink:0;
  transition:background .25s, gap .25s;
}
.btn-primary:hover { background:#a04845; gap:20px; }
.btn-primary::after { content:'→'; }

/* ============================================================
   SHARED "OUR WORKS" SECTION — homepage + inner pages
   ============================================================ */
.home-recent {
  background:var(--white); padding:80px 0;
}
.home-recent-header {
  display:flex; align-items:flex-end; justify-content:space-between;
  padding:0 60px; margin-bottom:36px;
}
@media(max-width:768px){ .home-recent-header{ padding:0 20px; flex-direction:column; align-items:flex-start; gap:14px; } }

.home-works-title {
  font-family:var(--ff-g); font-size:clamp(30px,4.1vw,66px);
  font-weight:800; text-transform:uppercase;
  color:var(--black); letter-spacing:-.01em; line-height:.92;
  text-decoration:none; display:inline-block;
  transition:color .3s;
}
.home-works-title em { color:var(--red); font-style:normal; transition:color .3s; }
.home-works-title:hover { color:var(--red); }
.home-works-title:hover em { color:var(--black); }

.hw-link {
  font-family:var(--ff-g); font-size:10px; font-weight:600; letter-spacing:.18em;
  text-transform:uppercase; color:var(--red); text-decoration:none;
  display:inline-flex; align-items:center; gap:10px;  transition:gap .25s;
}
.hw-link:hover { gap:16px; }
.hw-link::after { content:'→'; }

.hw-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:3px;
}
@media(max-width:900px){ .hw-grid{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:560px){ .hw-grid{ grid-template-columns:1fr; } }

.hw-item {
  position:relative; overflow:hidden;
  background:var(--black); aspect-ratio:16/9;
}
.hw-thumb {
  width:100%; height:100%; object-fit:cover; display:block;
  filter:saturate(.6); transition:transform .65s var(--ease-out), filter .45s;
}
.hw-placeholder {
  width:100%; height:100%;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--ff-g); font-size:9px; font-weight:500; letter-spacing:.18em;
  color:#2a2620; text-transform:uppercase;
  transition:transform .65s var(--ease-out);
}
.hw-item:hover .hw-thumb { transform:scale(1.04); filter:saturate(1); }
.hw-item:hover .hw-placeholder { transform:scale(1.03); }
.hw-overlay {
  position:absolute; left:0; right:0; bottom:0; z-index:2;
  background:rgba(10,9,8,.75);
  opacity:0; transition:opacity .35s;
  display:flex; align-items:flex-end; padding:12px 20px;
}
.hw-item:hover .hw-overlay { opacity:1; }

/* Hover scrub video preview (works on .port-inner and .hw-item) */
.hover-preview-video {
  position:absolute; inset:0; z-index:1;
  width:100%; height:100%; object-fit:cover;
}
/* Touch-hold preview visual feedback */
.touch-previewing { outline:2px solid var(--red); outline-offset:-2px; }

.hw-cat {
  font-family:var(--ff-g); font-size:9px; font-weight:500; letter-spacing:.14em;
  text-transform:uppercase; color:var(--red-text); margin-bottom:4px;
}
.hw-title {
  font-family:var(--ff-g); font-size:16px; font-weight:600;
  color:var(--white); line-height:1.2;
}

/* ════════════════════════════════════════════════════════════
   ADMIN MODE — activate with ?admin in the URL
   Requires: python3 admin-server.py (instead of http.server)
════════════════════════════════════════════════════════════ */
#admin-bar {
  position:fixed; bottom:0; left:0; right:0; z-index:99999;
  display:flex; flex-direction:column;
  background:rgba(6,5,4,.97); border-top:2px solid var(--red);
  font-family:var(--ff-g); font-size:9px; letter-spacing:.18em; text-transform:uppercase;
  color:rgba(255,255,255,.4);
}
#admin-bar-label { color:var(--red); font-weight:700; font-size:10px; flex-shrink:0; }
#admin-bar-hint  { opacity:.35; flex-shrink:0; }
#admin-bar-pos   { font-variant-numeric:tabular-nums; min-width:108px; color:rgba(255,255,255,.65); }
#admin-bar-count { margin-left:auto; flex-shrink:0; }
.admin-bar-btn {
  flex-shrink:0; padding:5px 14px; border-radius:2px;
  font-family:var(--ff-g); font-size:8px; font-weight:700;
  letter-spacing:.18em; text-transform:uppercase; cursor:pointer;
  transition:opacity .15s, background .15s, color .15s;
}
#admin-save-btn {
  background:var(--red); color:#fff; border:1px solid var(--red);
}
#admin-save-btn:disabled { opacity:.3; pointer-events:none; }
#admin-reset-btn {
  background:transparent; color:rgba(255,255,255,.45);
  border:1px solid rgba(255,255,255,.18);
}
#admin-reset-btn:hover { color:var(--white); border-color:rgba(255,255,255,.5); }

/* Adjustable elements: highlight on hover, crosshair cursor */
.admin-mode [data-apid] {
  outline:1px dashed rgba(192,57,43,.35); outline-offset:-1px;
  cursor:crosshair !important;
}
.admin-mode [data-apid]:hover {
  outline-color:rgba(192,57,43,.75);
}
.admin-mode [data-apid].ap-dragging {
  outline:2px solid var(--red); cursor:grabbing !important;
}

/* ── ACCESSIBILITY — reduced motion ── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; }
  .reveal.js-hidden { opacity: 1 !important; transform: none !important; }
}

/* ── ACCESSIBILITY — keyboard focus ── */
:focus-visible { outline: 2px solid var(--red); outline-offset: 2px; }
a:focus-visible, button:focus-visible { outline: 2px solid var(--red); outline-offset: 2px; }

/* ── ACCESSIBILITY — cursor: none only on hover-capable devices ── */
@media (hover: hover) {
  body { cursor: none; }
  a, button, .nav-logo, .nav-links li a, .nav-games-btn, .nav-ig,
  .nav-mobile-toggle, .nav-mobile-drawer a, .hero-dot, .hero-arrow,
  .svc-more-btn, .svc-teaser-card, .svc-card,
  #game-overlay, .gf-thumb, .gq-d, .gy-producer,
  .hw-item, .hw-close, .hw-view-all, .hw-more,
  .fs-prev-btn, .fs-next-btn, #fs-prev, #fs-next, #fs-close,
  .sg-viewer-btn, #sg-viewer-prev, #sg-viewer-next, #sg-viewer-close,
  .ft-link, .ft-ig, .ft-imdb,
  .port-item, .cat-tab, .tal-tab, .track-tab,
  .trad-item, .ai-card,
  .tal-item, .founder-imdb, .logo-item,
  .ct-office-email, .btn-submit,
  .game-card, .games-random { cursor: none; }
}

/* ── ACCESSIBILITY — 44px minimum touch targets on mobile ── */
@media (max-width: 768px) {
  .nav-mobile-toggle { min-width: 44px; min-height: 44px; display: flex; align-items: center; justify-content: center; }
  .nav-games-btn { min-height: 44px; display: inline-flex; align-items: center; }
  .nav-ig { min-width: 44px; min-height: 44px; justify-content: center; }
  .ft-link, .ft-ig, .ft-imdb { min-height: 44px; display: inline-flex; align-items: center; }
}
