/* REALM RUNNER — covert ops streaming hub */
:root{
  --void: #060606;
  --ink: #0b0b0c;
  --shell: #111114;
  --panel: #16161a;
  --line: rgba(255,255,255,0.08);
  --line-2: rgba(255,255,255,0.14);
  --fg: #ededee;
  --fg-2: #b6b6bb;
  --fg-3: #6b6b72;
  --fg-4: #3d3d44;
  --signal: #ff2a2a;          /* live red */
  --signal-deep: #b30c0c;
  --cyan: #4cf3ff;            /* recon cyan */
  --amber: #ffb547;
  --grid: rgba(255,255,255,0.04);
}

*{box-sizing:border-box}
html,body{margin:0;background:var(--void);color:var(--fg);
  font-family: "Inter Tight", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-feature-settings: "ss01","cv11";
  -webkit-font-smoothing: antialiased;
}
body{
  background:
    radial-gradient(1200px 600px at 70% -10%, rgba(255,42,42,0.10), transparent 60%),
    radial-gradient(900px 600px at -10% 110%, rgba(76,243,255,0.05), transparent 60%),
    var(--void);
  min-height:100vh;
}

.mono{ font-family: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace; letter-spacing: 0.02em;}
.display{ font-family: "Anton", "Bebas Neue", "Inter Tight", sans-serif; letter-spacing: -0.01em;}

/* === scanline + grain overlays === */
.scan::before{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:60;
  background: repeating-linear-gradient(180deg, rgba(255,255,255,0.018) 0 1px, transparent 1px 3px);
  mix-blend-mode: overlay;
}
.grain::after{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:61; opacity:.25;
  background-image:
    radial-gradient(rgba(255,255,255,0.06) 1px, transparent 1px),
    radial-gradient(rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size: 3px 3px, 7px 7px;
  background-position: 0 0, 1px 2px;
  mix-blend-mode: overlay;
}

/* === top chrome === */
.chrome{
  position:sticky; top:0; z-index:1000;
  display:flex; align-items:center; gap:24px;
  padding:14px 28px;
  background:linear-gradient(180deg, rgba(6,6,6,0.92), rgba(6,6,6,0.6) 70%, transparent);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--line);
}
.brand{ display:flex; align-items:center; gap:10px; cursor:pointer;}
.brand .mark{
  width:34px; height:34px; border:1.5px solid #fff; border-radius:50%;
  display:grid; place-items:center; position:relative;
  font-family:"Anton", sans-serif; font-size:18px;
}
.brand .mark::before{
  content:""; position:absolute; inset:-4px; border:1px dashed rgba(255,255,255,0.25); border-radius:50%;
  animation: spin 24s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.brand .word{ display:flex; flex-direction:column; line-height:1;}
.brand .word b{ font-family:"Anton", sans-serif; font-size:18px; letter-spacing:0.03em;}
.brand .word small{ font-family: "JetBrains Mono", monospace; color:var(--fg-3); font-size:9.5px; letter-spacing:0.18em; margin-top:3px;}

.nav{ display:flex; gap:4px; }
.nav button{
  appearance:none; background:transparent; border:0; color:var(--fg-2);
  font: 500 12px/1 "JetBrains Mono", monospace; letter-spacing:0.16em; text-transform:uppercase;
  padding:10px 14px; border-radius:6px; cursor:pointer;
}
.nav button:hover{ color:var(--fg); background: rgba(255,255,255,0.04);}
.nav button.active{ color:var(--fg); background: rgba(255,255,255,0.06);}
.nav button.active::before{ content:"› "; color:var(--signal);}

.chrome .right{ margin-left:auto; display:flex; align-items:center; gap:10px;}

.live-pill{
  display:inline-flex; align-items:center; gap:8px; padding:6px 10px 6px 8px;
  border:1px solid var(--line-2); border-radius:999px;
  font: 600 10.5px/1 "JetBrains Mono", monospace; letter-spacing:0.16em; text-transform:uppercase;
  color:var(--fg);
}
.live-pill .dot{
  width:8px; height:8px; border-radius:50%; background:var(--signal);
  box-shadow: 0 0 0 0 rgba(255,42,42,0.6);
  animation: pulse 1.6s infinite;
}
.live-pill.adult .dot{ background:#ff2a2a;}
.live-pill.offline .dot{ background:#666; animation:none;}
@keyframes pulse{
  0%{ box-shadow: 0 0 0 0 rgba(255,42,42,0.6);}
  70%{ box-shadow: 0 0 0 10px rgba(255,42,42,0);}
  100%{ box-shadow: 0 0 0 0 rgba(255,42,42,0);}
}

.btn{
  appearance:none; cursor:pointer; border:1px solid var(--line-2); background:transparent; color:var(--fg);
  padding:9px 14px; border-radius:0;
  font: 600 11px/1 "JetBrains Mono", monospace; letter-spacing: 0.16em; text-transform:uppercase;
}
.btn:hover{ background:rgba(255,255,255,0.05); border-color:rgba(255,255,255,0.3);}
.btn.primary{ background:var(--signal); border-color:var(--signal); color:#fff;}
.btn.primary:hover{ background:#ff4040; border-color:#ff4040;}
.btn.ghost{ border-color:transparent; color:var(--fg-2);}
.btn.ghost:hover{ color:var(--fg); background: rgba(255,255,255,0.04);}

/* Square JOIN CTA — matches cinematic hero style */
.btn.join-cta{
  background: transparent;
  color: #fff;
  border: 1.5px solid #fff;
  border-radius: 0;
  padding: 10px 16px;
  font: 600 11px/1 "JetBrains Mono", monospace;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}
.btn.join-cta:hover{ background:#fff; color: var(--signal); }

.btn.login-cta{
  background: var(--signal);
  color: #fff;
  border: 1.5px solid var(--signal);
  border-radius: 0;
  padding: 10px 16px;
  font: 600 11px/1 "JetBrains Mono", monospace;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}
.btn.login-cta:hover{ background: #fff; color: var(--signal); border-color: #fff; }

/* Language dropdown */
.lang-dd{ position: relative; }
.lang-trigger{
  appearance:none; background:transparent; border:0; color:#fff;
  display:flex; align-items:center; gap:6px;
  padding: 9px 10px; cursor: pointer;
  font: 600 11px/1 "JetBrains Mono", monospace; letter-spacing: 0.2em; text-transform: uppercase;
  border-radius: 4px;
}
.lang-trigger:hover{ background: rgba(255,255,255,0.06); }
.lang-trigger svg{ opacity: 0.7; }
.lang-menu{
  position: absolute; top: calc(100% + 6px); right: 0; z-index: 60;
  min-width: 90px;
  background: #0d0d10;
  border: 1px solid var(--line-2);
  border-radius: 6px;
  padding: 4px;
  box-shadow: 0 18px 40px rgba(0,0,0,0.55);
}
.lang-menu button{
  appearance:none; background:transparent; border:0; color: var(--fg-2);
  display: block; width: 100%; text-align: left;
  padding: 8px 12px; cursor: pointer; border-radius: 4px;
  font: 600 11px/1 "JetBrains Mono", monospace; letter-spacing: 0.2em; text-transform: uppercase;
}
.lang-menu button:hover{ background: rgba(255,255,255,0.06); color:#fff; }
.lang-menu button.active{ color: #fff; background: rgba(255,42,42,0.12); }

/* === HUB layout === */
.hub{
  display:grid;
  grid-template-columns: 1fr 420px;
  gap:18px;
  padding:18px 28px;
}
@media (max-width: 1100px){ .hub{ grid-template-columns: 1fr; } }

.stage{
  position:relative;
  border:1px solid var(--line);
  border-radius:10px;
  overflow:hidden;
  background:#000;
  min-height: 540px;
  aspect-ratio: 16/9;
}
.stage .frame{ position:absolute; inset:0; }

/* placeholder cinematic background */
.cinematic{
  position:absolute; inset:0;
  background:
    radial-gradient(80% 60% at 60% 40%, rgba(255,42,42,0.55) 0%, rgba(120,10,10,0.35) 30%, rgba(0,0,0,1) 75%),
    linear-gradient(180deg, #1a0303 0%, #060606 100%);
}
.cinematic::before{
  content:""; position:absolute; inset:0;
  background-image:
    repeating-linear-gradient(180deg, rgba(0,0,0,0.4) 0 2px, transparent 2px 5px),
    radial-gradient(40% 28% at 50% 64%, rgba(0,0,0,0.55) 0%, transparent 70%);
}
.cinematic .silhouette{
  position:absolute; left:50%; bottom:18%; width:42px; height:120px; transform:translateX(-50%);
  background:linear-gradient(180deg, #1a0202 0%, #0a0101 60%, transparent 100%);
  clip-path: polygon(40% 0, 60% 0, 70% 30%, 80% 60%, 78% 100%, 22% 100%, 20% 60%, 30% 30%);
  opacity:.85;
}

.stage-overlay{
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,0.55) 0%, rgba(0,0,0,0) 30%, rgba(0,0,0,0) 55%, rgba(0,0,0,0.85) 100%);
  pointer-events:none;
}

.stage-top{
  position:absolute; top:18px; left:18px; right:18px;
  display:flex; align-items:flex-start; justify-content:space-between; gap:16px;
}
.stage-top .telemetry{
  font: 500 10px/1.5 "JetBrains Mono", monospace; letter-spacing:0.18em;
  color:rgba(255,255,255,0.7); text-transform:uppercase;
}
.stage-top .telemetry .row{ display:flex; gap:14px; }
.stage-top .telemetry b{ color:var(--fg);}

.stage-title{
  position:absolute; left:28px; right:28px; bottom:84px;
}
.stage-title .eyebrow{
  font: 600 10px/1 "JetBrains Mono", monospace; letter-spacing:0.24em; text-transform:uppercase;
  color:var(--signal); margin-bottom:14px; display:flex; align-items:center; gap:10px;
}
.stage-title .eyebrow::before{
  content:""; width:24px; height:1px; background:var(--signal);
}
.stage-title h1{
  margin:0;
  font-family: "Anton", "Bebas Neue", sans-serif;
  font-size: clamp(40px, 6vw, 84px);
  line-height: 0.92;
  letter-spacing: -0.01em;
  color:#fff;
  text-shadow: 0 4px 30px rgba(0,0,0,0.6);
}
.stage-title .meta{
  margin-top:14px;
  font: 500 11.5px/1.4 "JetBrains Mono", monospace; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--fg-2);
  display:flex; gap:20px; flex-wrap:wrap;
}
.stage-title .meta span{ display:flex; align-items:center; gap:8px;}

.player-bar{
  position:absolute; left:0; right:0; bottom:0;
  padding:14px 22px 16px;
  display:flex; align-items:center; gap:14px;
  background: linear-gradient(180deg, transparent, rgba(0,0,0,0.7));
}
.player-bar .play{
  width:44px; height:44px; border-radius:50%;
  display:grid; place-items:center;
  background: rgba(255,255,255,0.92); color:#000; cursor:pointer; border:none;
}
.player-bar .play:hover{ background:#fff;}
.timeline{ flex:1; height:3px; background: rgba(255,255,255,0.18); position:relative; cursor:pointer; border-radius:2px;}
.timeline .buf{ position:absolute; left:0; top:0; bottom:0; width:62%; background:rgba(255,255,255,0.32);}
.timeline .pos{ position:absolute; left:0; top:0; bottom:0; width:38%; background:var(--signal);}
.timeline .knob{ position:absolute; left:38%; top:50%; transform:translate(-50%,-50%); width:12px; height:12px; border-radius:50%; background:var(--signal); box-shadow: 0 0 0 4px rgba(255,42,42,0.18);}
.tcode{ font: 500 11px/1 "JetBrains Mono", monospace; color:var(--fg-2); letter-spacing:0.08em; min-width:96px;}
.iconbtn{ background:transparent; border:0; color:var(--fg-2); cursor:pointer; padding:6px;}
.iconbtn:hover{ color:var(--fg);}

/* === RIGHT RAIL: live tracker map === */
.rail{
  display:flex; flex-direction:column; gap:18px;
  min-width: 0;
}
.card{
  border:1px solid var(--line);
  border-radius:10px;
  background: linear-gradient(180deg, var(--shell), #0c0c0e);
  overflow:hidden;
}
.card-hd{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 16px;
  border-bottom:1px solid var(--line);
}
.card-hd h3{
  margin:0; font: 600 11px/1 "JetBrains Mono", monospace; letter-spacing:0.2em; text-transform:uppercase; color:var(--fg);
}
.card-hd .sub{ font: 500 10px/1 "JetBrains Mono", monospace; color:var(--fg-3); letter-spacing:0.14em; text-transform:uppercase;}

.map{
  position:relative;
  height: 360px;
  background:
    radial-gradient(60% 40% at 30% 30%, rgba(76,243,255,0.05), transparent 60%),
    linear-gradient(180deg, #0a0a0c, #050507);
  border-bottom:1px solid var(--line);
  overflow:hidden;
}
.map .grid{
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.045) 1px, transparent 1px);
  background-size: 28px 28px;
  mask-image: radial-gradient(circle at 50% 50%, black 50%, transparent 100%);
}
.map .continents{
  position:absolute; inset:0;
  background:
    /* fake continent blobs as soft fills */
    radial-gradient(120px 70px at 18% 38%, rgba(255,255,255,0.06), transparent 70%),
    radial-gradient(180px 90px at 32% 32%, rgba(255,255,255,0.05), transparent 70%),
    radial-gradient(160px 80px at 55% 30%, rgba(255,255,255,0.05), transparent 70%),
    radial-gradient(220px 120px at 70% 60%, rgba(255,255,255,0.045), transparent 70%),
    radial-gradient(110px 70px at 78% 38%, rgba(255,255,255,0.04), transparent 70%),
    radial-gradient(100px 50px at 25% 70%, rgba(255,255,255,0.04), transparent 70%);
  filter: blur(0.5px);
}
.map .crosshair{
  position:absolute; left:0; right:0; top:50%; height:1px;
  background: linear-gradient(90deg, transparent, rgba(76,243,255,0.18) 30% 70%, transparent);
}
.map .crosshair.v{ top:0; bottom:0; left:50%; width:1px; height:auto;
  background: linear-gradient(180deg, transparent, rgba(76,243,255,0.18) 30% 70%, transparent);}
.map .corner{ position:absolute; width:14px; height:14px; border:1px solid rgba(76,243,255,0.5);}
.map .corner.tl{ top:10px; left:10px; border-right:0; border-bottom:0;}
.map .corner.tr{ top:10px; right:10px; border-left:0; border-bottom:0;}
.map .corner.bl{ bottom:10px; left:10px; border-right:0; border-top:0;}
.map .corner.br{ bottom:10px; right:10px; border-left:0; border-top:0;}

.pin{
  position:absolute; transform: translate(-50%, -100%);
  display:flex; flex-direction:column; align-items:center; gap:4px;
  cursor:pointer;
}
.pin .head{
  width:14px; height:14px; border-radius:50%;
  background:#fff; border:2px solid #000;
  box-shadow: 0 0 0 3px rgba(255,255,255,0.08);
  position:relative;
}
.pin.live .head{ background:var(--signal); border-color:#1a0202;
  box-shadow: 0 0 0 3px rgba(255,42,42,0.18), 0 0 14px rgba(255,42,42,0.7);}
.pin.live .head::before{
  content:""; position:absolute; inset:-6px; border:1px solid var(--signal); border-radius:50%; animation: ring 1.8s infinite;
}
.pin.archive .head{ background:transparent; border-color:#fff;}
@keyframes ring{
  0%{ transform:scale(0.6); opacity:.9;}
  100%{ transform:scale(2.2); opacity:0;}
}
.pin .label{
  font: 500 9px/1 "JetBrains Mono", monospace; letter-spacing:0.16em; text-transform:uppercase;
  color:rgba(255,255,255,0.7); white-space:nowrap; padding:3px 6px;
  background: rgba(0,0,0,0.7); border:1px solid var(--line); border-radius:3px;
  transform: translateY(-30px);
}
.pin:hover .label{ color:#fff; border-color: var(--line-2); background:#000;}
.pin.selected .head{ box-shadow: 0 0 0 4px rgba(76,243,255,0.4);}
.pin.selected .label{ color:var(--cyan); border-color: rgba(76,243,255,0.5);}

.region-list{
  max-height: 280px; overflow:auto;
}
.region-list::-webkit-scrollbar{ width:6px;}
.region-list::-webkit-scrollbar-thumb{ background: rgba(255,255,255,0.12); border-radius:4px;}

.region-item{
  display:grid; grid-template-columns: auto 1fr auto; align-items:center; gap:12px;
  padding:12px 16px; border-bottom:1px solid var(--line);
  cursor:pointer; transition: background 0.15s;
}
.region-item:hover{ background: rgba(255,255,255,0.02);}
.region-item.selected{ background: rgba(76,243,255,0.05); border-left:2px solid var(--cyan);}
.region-item .idx{
  font: 500 10px/1 "JetBrains Mono", monospace; color:var(--fg-3); letter-spacing:0.1em;
}
.region-item .name{
  font: 600 13px/1.2 "Inter Tight", sans-serif; letter-spacing:-0.01em;
}
.region-item .name small{
  display:block; margin-top:4px;
  font: 500 9.5px/1 "JetBrains Mono", monospace; color:var(--fg-3); letter-spacing:0.16em; text-transform:uppercase;
}
.region-item .count{
  font: 500 10px/1 "JetBrains Mono", monospace; color:var(--fg-2); letter-spacing:0.1em;
}
.region-item.live .count{ color:var(--signal);}

/* === Continue Watching strip === */
.section{ padding: 36px 28px 12px;}
.section-hd{
  display:flex; align-items:flex-end; justify-content:space-between;
  margin-bottom:18px;
}
.section-hd h2{
  margin:0;
  font-family:"Anton", sans-serif;
  font-size: 36px;
  letter-spacing:-0.01em;
  font-weight: 400;
}
.section-hd .crumb{
  font: 500 10px/1 "JetBrains Mono", monospace; color:var(--fg-3); letter-spacing:0.22em; text-transform:uppercase;
  margin-bottom:8px;
}
.section-hd .right{ display:flex; gap:10px;}

.strip{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
  gap: 18px;
  padding-bottom: 16px;
}

.tile{
  position:relative; aspect-ratio: 16/10; border-radius:8px; overflow:hidden;
  border:1px solid var(--line); background: var(--ink); cursor:pointer;
  scroll-snap-align: start;
  transition: transform 0.18s ease, border-color 0.18s ease;
}
.tile:hover{ transform: translateY(-2px); border-color: var(--line-2);}
.tile .art{
  position:absolute; inset:0;
  background-size:cover; background-position:center;
}
.tile .art.fallback{
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.025) 0 8px, rgba(255,255,255,0) 8px 18px),
    linear-gradient(135deg, var(--shell), #1c1c20);
}
.tile .badge{
  position:absolute; top:12px; left:12px;
  font: 600 10.5px/1 "JetBrains Mono", monospace; letter-spacing:0.18em; text-transform:uppercase;
  padding:6px 9px; border-radius:0; background: rgba(0,0,0,0.7); border:1px solid var(--line-2);
}
.tile .badge.live{ background: rgba(255,42,42,0.92); border-color: rgba(255,255,255,0.2); color:#fff; display:flex; align-items:center; gap:6px;}
.tile .badge.live::before{ content:""; width:6px; height:6px; border-radius:50%; background:#fff; animation:pulse 1.6s infinite;}
.tile .badge.locked{ background: rgba(0,0,0,0.7);}
.tile .progress{
  position:absolute; left:0; right:0; bottom:0; height:3px; background: rgba(255,255,255,0.1);
}
.tile .progress > div{ height:100%; background: var(--signal);}
.tile .info{
  position:absolute; left:0; right:0; bottom:3px;
  padding:18px 18px 16px;
  background: linear-gradient(180deg, transparent, rgba(0,0,0,0.92));
}
.tile .info h4{
  margin:0; font: 600 17px/1.25 "Inter Tight", sans-serif; letter-spacing:-0.01em;
}
.tile .info .row{
  margin-top:6px; display:flex; gap:10px; align-items:center;
  font: 500 10px/1 "JetBrains Mono", monospace; color:var(--fg-2); letter-spacing:0.12em; text-transform:uppercase;
}
.tile .info .row span{ display:inline-flex; align-items:center; gap:5px;}

/* fallback art variants */
.art.v1{ background-image: linear-gradient(135deg, #2a0606, #060606 60%); }
.art.v2{ background-image: linear-gradient(135deg, #061b22, #050505 60%); }
.art.v3{ background-image: linear-gradient(135deg, #1a0e02, #060606 60%); }
.art.v4{ background-image: linear-gradient(135deg, #1a1a1a, #060606 60%); }
.art.v5{ background-image: linear-gradient(135deg, #0e0218, #060606 60%); }
.art.v6{ background-image: linear-gradient(135deg, #021a14, #060606 60%); }
.art.v7{ background-image: linear-gradient(135deg, #1f0202, #050505 60%); }
.art.v8{ background-image: linear-gradient(135deg, #02101a, #050505 60%); }

/* === ARCHIVE timeline === */
.archive-shell{ padding: 22px 28px 60px;}
.archive-grid{
  display:grid; grid-template-columns: 240px 1fr; gap:24px;
}
@media (max-width: 980px){ .archive-grid{ grid-template-columns: 1fr; } }
.facets{
  border:1px solid var(--line); border-radius:8px; padding:18px; background: var(--shell);
  align-self:start; position:sticky; top: 86px;
}
.facets h4{
  margin:0 0 10px; font: 600 10px/1 "JetBrains Mono", monospace; letter-spacing:0.2em; text-transform:uppercase; color:var(--fg-3);
}
.facets .group{ margin-bottom: 18px;}
.facet-btn{
  appearance:none; background:transparent; border:0; color:var(--fg-2);
  display:block; width:100%; text-align:left; padding:6px 8px; border-radius:4px;
  font: 500 12px/1.2 "Inter Tight", sans-serif; cursor:pointer;
}
.facet-btn:hover{ background: rgba(255,255,255,0.04); color:var(--fg);}
.facet-btn.active{ background: rgba(255,42,42,0.08); color:var(--signal);}
.facet-btn .count{ float:right; font: 500 10px "JetBrains Mono", monospace; color:var(--fg-3);}

.year-row{
  display:grid; grid-template-columns: 100px 1fr; gap:18px;
  padding: 26px 0; border-bottom: 1px solid var(--line);
  align-items: start;
}
.year-row .year{
  font-family: "Anton", sans-serif; font-size: 56px; line-height: 0.9; color: var(--fg);
  letter-spacing: -0.01em;
}
.year-row .year small{ display:block; font: 500 10px/1 "JetBrains Mono", monospace; letter-spacing:0.18em; color:var(--fg-3); text-transform:uppercase; margin-top:8px;}
.year-grid{
  display:grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap:18px;
}

/* === Archive video cards (16:9 horizontal) === */
.vid-card{
  display:flex; flex-direction: column; gap: 10px;
  cursor:pointer; background: transparent;
}
.vid-card .thumb{
  position:relative; aspect-ratio: 16/9; overflow:hidden;
  border: 1px solid var(--line); background: var(--ink);
  transition: border-color 0.18s ease, transform 0.18s ease;
}
.vid-card:hover .thumb{ border-color: rgba(255,255,255,0.4); transform: translateY(-2px); }
.vid-card .thumb .art{ position:absolute; inset:0; }
.vid-card .thumb .art.fallback{
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.025) 0 8px, rgba(255,255,255,0) 8px 18px),
    linear-gradient(135deg, var(--shell), #1c1c20);
}
.vid-card .thumb::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background: linear-gradient(180deg, rgba(0,0,0,0.0) 55%, rgba(0,0,0,0.65));
}
.vid-ep{
  position:absolute; top: 10px; left: 10px;
  font: 600 10px/1 "JetBrains Mono", monospace; letter-spacing: 0.2em; text-transform: uppercase;
  padding: 5px 8px; background: rgba(0,0,0,0.7); border: 1px solid rgba(255,255,255,0.15); color: #fff;
  z-index: 2;
}
.vid-dur{
  position:absolute; bottom: 10px; right: 10px;
  font: 600 11px/1 "JetBrains Mono", monospace; letter-spacing: 0.08em;
  padding: 4px 7px; background: rgba(0,0,0,0.85); color: #fff;
  z-index: 2;
}
.vid-play{
  position:absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
  width: 44px; height: 44px; border-radius: 50%;
  background: rgba(255,255,255,0.94); display:flex; align-items:center; justify-content:center;
  opacity: 0; transition: opacity 0.18s ease; z-index: 3; padding-left: 3px;
}
.vid-card:hover .vid-play{ opacity: 1; }
.vid-meta{ padding: 0 2px; }
.vid-meta h4{
  margin: 0; font: 600 15.5px/1.3 "Inter Tight", sans-serif; letter-spacing: -0.005em; color: var(--fg);
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.vid-row{
  margin-top: 6px; display: flex; gap: 6px; flex-wrap: wrap;
  font: 600 10.5px/1 "JetBrains Mono", monospace; letter-spacing: 0.16em; color: var(--fg-2); text-transform: uppercase;
}

/* === Doors (PPV courses) === */
.doors-shell{ padding: 22px 28px 60px;}
.doors-grid{
  display:grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap:18px;
  margin-top: 22px;
}
.door{
  position:relative; aspect-ratio: 3/4;
  border:1px solid var(--line);
  border-radius: 8px;
  background:
    repeating-linear-gradient(180deg, rgba(255,255,255,0.025) 0 1px, transparent 1px 4px),
    linear-gradient(180deg, #1a1a1d, #0a0a0c);
  overflow:hidden; cursor:pointer; transition: transform 0.2s, border-color 0.2s;
}
.door:hover{ border-color: var(--line-2); }
.door .frame{
  position:absolute; inset: 18px; border:1px solid rgba(255,255,255,0.16);
  border-radius:4px;
  display:flex; flex-direction:column;
  background:
    radial-gradient(80% 50% at 50% 0%, rgba(255,42,42,0.08), transparent 70%),
    linear-gradient(180deg, #161618, #0a0a0c);
}
.door .panel{
  flex:1; position:relative; border-bottom:1px solid rgba(255,255,255,0.08);
  display:grid; place-items:center;
}
.door .lock{
  width:62px; height:62px; border-radius:50%;
  border:1.5px solid rgba(255,255,255,0.6); display:grid; place-items:center;
  color: rgba(255,255,255,0.85);
  background: radial-gradient(circle, rgba(255,42,42,0.18), transparent 70%);
}
.door .keypad{
  position:absolute; right:18px; top:50%; transform:translateY(-50%);
  display:grid; grid-template-columns: repeat(3, 8px); gap:4px;
}
.door .keypad i{ width:8px; height:8px; border-radius:50%; background: rgba(255,255,255,0.18); display:block;}
.door .keypad i.lit{ background: var(--signal); box-shadow: 0 0 6px var(--signal);}
.door .meta{
  padding: 14px 16px; border-top:1px solid rgba(255,255,255,0.06);
}
.door .meta .ep{
  font: 500 9.5px/1 "JetBrains Mono", monospace; letter-spacing:0.2em; color: var(--fg-3); text-transform:uppercase;
}
.door .meta h4{
  margin:6px 0 0; font: 600 16px/1.2 "Inter Tight", sans-serif; letter-spacing:-0.01em;
}
.door .meta .price{
  margin-top:10px; display:flex; justify-content:space-between; align-items:center;
  font: 600 11px/1 "JetBrains Mono", monospace; letter-spacing:0.14em; text-transform:uppercase; color:var(--fg-2);
}
.door .meta .price b{ color: var(--signal);}
.door.unlocked .frame{
  border-color: rgba(76,243,255,0.4);
  background:
    radial-gradient(80% 50% at 50% 0%, rgba(76,243,255,0.12), transparent 70%),
    linear-gradient(180deg, #0a1a1f, #060a0c);
}
.door.unlocked .lock{ border-color: var(--cyan); color: var(--cyan); transform: rotate(-30deg) translateX(2px);}
.door.unlocked .keypad i{ background: var(--cyan); box-shadow: 0 0 4px var(--cyan);}
.door.opening .frame{ animation: openFlash 0.6s ease;}
@keyframes openFlash{
  0%{ filter: brightness(1);}
  50%{ filter: brightness(2.2);}
  100%{ filter: brightness(1);}
}

/* === Forum === */
.forum-shell{ padding: 22px 28px 60px; max-width: 1400px;}
.forum-grid{ display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 28px; align-items: start; }
@media (max-width: 1100px){ .forum-grid{ grid-template-columns: 1fr; } }
.forum-main{ min-width: 0; }
.forum-rail{ display:flex; flex-direction: column; gap: 14px; position: sticky; top: 86px; }

.forum-card{ border: 1px solid var(--line); background: var(--surface); }
.forum-card-hd{
  display:flex; justify-content: space-between; align-items: center;
  padding: 12px 14px; border-bottom: 1px solid var(--line);
}
.forum-card-hd h4{
  margin: 0; font: 600 10.5px/1 "JetBrains Mono", monospace; letter-spacing: 0.22em; color: #fff; text-transform: uppercase;
}
.forum-card-hd .muted{ font: 600 10px/1 "JetBrains Mono", monospace; letter-spacing: 0.16em; color: var(--fg-3); }
.online-dot{ display:inline-block; width: 6px; height: 6px; border-radius: 50%; background: #6ad17a; margin-right: 5px; }

.forum-cats{ display:flex; flex-direction: column; }
.forum-cat{
  appearance:none; cursor:pointer; background: transparent; border: 0; border-bottom: 1px solid var(--line);
  display: grid; grid-template-columns: 22px 1fr auto; gap: 10px; align-items: center;
  padding: 11px 14px; color: var(--fg-2); text-align: left;
}
.forum-cat:last-child{ border-bottom: 0; }
.forum-cat:hover{ background: rgba(255,255,255,0.03); color: #fff; }
.forum-cat.active{ background: rgba(255,255,255,0.05); color: #fff; border-left: 3px solid var(--signal); padding-left: 11px; }
.forum-cat.running.active{ border-left-color: var(--signal); }
.forum-cat.retreat.active{ border-left-color: #6ad17a; }
.forum-cat.event.active{ border-left-color: #f4c14d; }
.forum-cat .ic{ font-size: 14px; color: var(--fg-3); }
.forum-cat.active .ic{ color: #fff; }
.forum-cat .lbl{ font: 600 12.5px/1.2 "Inter Tight", sans-serif; letter-spacing: -0.005em; }
.forum-cat .num{ font: 600 10px/1 "JetBrains Mono", monospace; color: var(--fg-3); letter-spacing: 0.12em; }

.forum-stats{ display: grid; grid-template-columns: 1fr 1fr; gap: 0; }
.forum-stats > div{ padding: 14px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.forum-stats > div:nth-child(2n){ border-right: 0; }
.forum-stats > div:nth-last-child(-n+2){ border-bottom: 0; }
.forum-stats b{ display:block; font-family: "Anton", sans-serif; font-size: 26px; line-height: 1; letter-spacing: -0.005em; color: #fff; }
.forum-stats span{ display:block; margin-top: 5px; font: 600 10px/1 "JetBrains Mono", monospace; letter-spacing: 0.18em; color: var(--fg-3); text-transform: uppercase; }
.online-num{ display:flex !important; align-items: center; gap: 6px; }
.online-num .dot{ width: 7px; height: 7px; border-radius: 50%; background: #6ad17a; animation: pulse 1.6s infinite; }

.forum-users{ display:flex; flex-direction: column; }
.forum-user{
  display: grid; grid-template-columns: 22px 30px 1fr auto; gap: 10px; align-items: center;
  padding: 10px 14px; border-bottom: 1px solid var(--line);
}
.forum-user:last-child{ border-bottom: 0; }
.forum-user .rk{ font: 600 10px/1 "JetBrains Mono", monospace; color: var(--fg-3); letter-spacing: 0.14em; }
.forum-user .av{
  width: 28px; height: 28px; border-radius: 50%; background: rgba(255,255,255,0.06); border: 1px solid var(--line-2);
  display:grid; place-items:center; font: 600 10px/1 "JetBrains Mono", monospace; letter-spacing: 0.06em; color: #fff;
}
.forum-user .info{ min-width: 0; }
.forum-user .u-name{ font: 600 12.5px/1.2 "Inter Tight", sans-serif; color: #fff; }
.forum-user .u-sub{ font: 500 10px/1.2 "JetBrains Mono", monospace; letter-spacing: 0.14em; color: var(--fg-3); text-transform: uppercase; margin-top: 3px; }
.u-badge{
  font: 600 9.5px/1 "JetBrains Mono", monospace; letter-spacing: 0.16em; padding: 4px 6px;
  border: 1px solid var(--line-2); color: var(--fg-2);
}
.u-badge.mod{ color: var(--signal); border-color: var(--signal); }
.u-badge.t3{ color: #f4c14d; border-color: #f4c14d; }

.forum-online{ padding: 12px 14px; display:flex; flex-wrap: wrap; gap: 5px; }
.forum-online .ou{
  font: 600 10.5px/1 "JetBrains Mono", monospace; letter-spacing: 0.08em; color: #fff;
  padding: 5px 7px; background: rgba(255,255,255,0.04); border: 1px solid var(--line-2);
}
.forum-online .ou::before{ content: "● "; color: #6ad17a; }
.forum-online .ou-more{ font: 600 10px/1 "JetBrains Mono", monospace; letter-spacing: 0.14em; color: var(--fg-3); padding: 5px 4px; }

.forum-recent{ display:flex; flex-direction: column; }
.forum-rec{ padding: 11px 14px; border-bottom: 1px solid var(--line); }
.forum-rec:last-child{ border-bottom: 0; }
.rec-line{ font: 400 12px/1.45 "Inter Tight", sans-serif; color: var(--fg-2); }
.rec-line b{ color: #fff; font-weight: 600; }
.rec-line em{ font-style: normal; color: var(--fg-3); }
.rec-thread{ color: #fff; }
.rec-time{ margin-top: 4px; font: 600 9.5px/1 "JetBrains Mono", monospace; letter-spacing: 0.18em; color: var(--fg-3); text-transform: uppercase; }

.forum-rules{ margin: 0; padding: 12px 14px 12px 32px; }
.forum-rules li{ font: 400 12px/1.5 "Inter Tight", sans-serif; color: var(--fg-2); margin-bottom: 6px; }
.forum-rules li:last-child{ margin-bottom: 0; }
.thread{
  padding: 22px 0; border-bottom:1px solid var(--line);
  display:grid; grid-template-columns: 64px 1fr auto; gap:18px; align-items:start;
  cursor:pointer;
}
.thread:hover{ background: rgba(255,255,255,0.015);}
.avatar{
  width:48px; height:48px; border-radius:50%;
  background: linear-gradient(135deg, #2a0606, #060606);
  border:1px solid var(--line-2);
  display:grid; place-items:center;
  font-family:"Anton", sans-serif; font-size:18px; color: var(--fg-2);
}
.thread .body h3{
  margin:0; font: 600 18px/1.25 "Inter Tight", sans-serif; letter-spacing:-0.01em;
}
.thread .body .by{
  margin-top:6px; font: 500 10px/1 "JetBrains Mono", monospace; color: var(--fg-3); letter-spacing:0.16em; text-transform:uppercase;
}
.thread .body p{
  margin:10px 0 0; color: var(--fg-2); font-size: 13.5px; line-height:1.55; max-width: 70ch;
}
.thread .body .tags{ margin-top:10px; display:flex; gap:6px;}
.tag{
  font: 500 9.5px/1 "JetBrains Mono", monospace; padding:5px 7px; border:1px solid var(--line);
  border-radius:3px; color:var(--fg-2); letter-spacing:0.14em; text-transform:uppercase;
}
.thread .stats{
  text-align:right;
  font: 500 10px/1.5 "JetBrains Mono", monospace; color: var(--fg-3); letter-spacing:0.14em; text-transform:uppercase;
}
.thread .stats b{ display:block; font: 600 22px/1 "Anton", sans-serif; color:var(--fg); letter-spacing:0;}

/* === Membership === */
.tiers{
  display:grid; grid-template-columns: repeat(4, 1fr); gap:14px;
  padding: 22px 28px 60px;
}
@media (max-width: 1100px){ .tiers{ grid-template-columns: repeat(2, 1fr);} }
@media (max-width: 600px){ .tiers{ grid-template-columns: 1fr;} }
.tier{
  border:1px solid var(--line); border-radius:8px; padding: 22px;
  background: linear-gradient(180deg, var(--shell), #0c0c0e);
  position:relative; overflow:hidden;
}
.tier .lvl{
  font: 600 10px/1 "JetBrains Mono", monospace; letter-spacing:0.22em; text-transform:uppercase; color:var(--fg-3);
}
.tier h3{
  margin:8px 0 0; font-family:"Anton", sans-serif; font-size: 32px; letter-spacing:-0.01em;
}
.tier .price{
  margin-top:6px; font: 500 13px/1 "JetBrains Mono", monospace; color: var(--fg-2); letter-spacing:0.1em;
}
.tier ul{ list-style:none; padding:0; margin: 18px 0 22px; }
.tier li{
  font-size: 12.5px; line-height: 1.6; color: var(--fg-2);
  padding-left: 18px; position: relative;
}
.tier li::before{
  content:""; position:absolute; left:0; top:0.6em; width:8px; height:1px; background:var(--fg-3);
}
.tier.featured{
  border-color: rgba(255,42,42,0.4);
  box-shadow: 0 0 0 1px rgba(255,42,42,0.2) inset;
}
.tier.featured::before{
  content:"PREMIUM"; position:absolute; top:14px; right:14px;
  font: 600 9.5px/1 "JetBrains Mono", monospace; letter-spacing:0.2em; color: var(--signal);
}
.tier.adult{
  border-color: rgba(255,255,255,0.04);
  background:
    repeating-linear-gradient(45deg, rgba(255,42,42,0.04) 0 6px, transparent 6px 12px),
    linear-gradient(180deg, var(--shell), #0c0c0e);
}
.tier.adult .lvl{ color: var(--signal);}

/* footer */
.footer{
  border-top:1px solid var(--line);
  padding: 0;
  background: #08080a;
  color: var(--fg-2);
  font-family: "Inter Tight", sans-serif;
  margin-top: 60px;
}
.footer-top{
  display:grid; grid-template-columns: 1.4fr 2fr; gap: 60px;
  padding: 50px 28px 36px; border-bottom: 1px solid var(--line);
}
@media (max-width: 980px){
  .footer-top{ grid-template-columns: 1fr; gap: 36px; }
}
.footer-brand .brand{ margin-bottom: 14px; }
.footer-blurb{
  font: 400 13.5px/1.6 "Inter Tight", sans-serif; color: var(--fg-2); margin: 0 0 20px; max-width: 42ch;
}
.footer-stats{
  display: flex; gap: 18px; flex-wrap: wrap;
  font: 600 10.5px/1 "JetBrains Mono", monospace; letter-spacing: 0.18em; color: var(--fg-3); text-transform: uppercase;
}
.footer .pulse{ display:flex; align-items:center; gap:8px; color: #fff;}
.footer .pulse .dot{ width:6px; height:6px; background: var(--signal); border-radius:50%; animation: pulse 1.6s infinite;}

.footer-cols{
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px;
}
@media (max-width: 720px){ .footer-cols{ grid-template-columns: repeat(2, 1fr); } }
.footer-col{ display:flex; flex-direction: column; gap: 10px; }
.footer-col h5{
  margin: 0 0 4px;
  font: 600 10.5px/1 "JetBrains Mono", monospace; letter-spacing: 0.22em; text-transform: uppercase; color: #fff;
}
.footer-col a{
  cursor: pointer; color: var(--fg-2); text-decoration: none;
  font: 400 13px/1.4 "Inter Tight", sans-serif;
  transition: color 0.15s ease;
}
.footer-col a:hover{ color: #fff; }

.footer-social{ display:flex; gap: 8px; margin-top: 4px; }
.footer-social a{
  width: 34px; height: 34px; display: grid; place-items: center;
  border: 1px solid var(--line-2); color: var(--fg-2);
  transition: color 0.15s ease, border-color 0.15s ease, background 0.15s ease;
}
.footer-social a:hover{ color: #fff; border-color: #fff; background: rgba(255,255,255,0.04); }

.footer-newsletter{
  display:flex; gap: 6px; margin-top: 16px;
}
.footer-newsletter input{
  flex: 1; min-width: 0; background: #0d0d10; border: 1px solid var(--line-2); color: #fff;
  padding: 9px 10px; font: 12px/1 "JetBrains Mono", monospace; letter-spacing: 0.04em; border-radius: 0;
}
.footer-newsletter input:focus{ outline: 1px solid var(--signal); border-color: var(--signal); }
.footer-newsletter .btn.primary{ padding: 9px 14px; }

.footer-disclaimer{
  padding: 22px 28px;
  border-bottom: 1px solid var(--line);
  font: 400 11.5px/1.65 "Inter Tight", sans-serif;
  color: var(--fg-3); max-width: 1100px;
}

.footer-bottom{
  display:flex; justify-content: space-between; align-items: center; gap: 18px; flex-wrap: wrap;
  padding: 18px 28px 22px;
  font: 600 10.5px/1.4 "JetBrains Mono", monospace; letter-spacing: 0.18em; color: var(--fg-3); text-transform: uppercase;
}
.footer-legal{ display:flex; gap: 10px; align-items:center; flex-wrap: wrap; }
.footer-legal a{
  cursor:pointer; color: var(--fg-2); text-decoration: none;
}
.footer-legal a:hover{ color: #fff; }
.footer-legal span{ color: var(--fg-3); }
.footer-copy{ color: var(--fg-3); }

/* modal */
.modal{
  position:fixed; inset:0; z-index:200; background: rgba(0,0,0,0.78);
  display:grid; place-items:center; padding:22px;
  backdrop-filter: blur(6px);
}
.modal .sheet{
  width: min(560px, 100%);
  border:1px solid var(--line-2);
  background: linear-gradient(180deg, #121214, #0a0a0c);
  border-radius:10px; padding: 26px;
  position:relative;
}
.modal .sheet::before{
  content:""; position:absolute; inset:0; pointer-events:none; border-radius:10px;
  background: radial-gradient(70% 40% at 50% 0%, rgba(255,42,42,0.08), transparent 70%);
}
.modal .close{
  position:absolute; top:14px; right:14px;
  background:transparent; border:0; color: var(--fg-3); cursor:pointer; font-size: 18px;
}
.modal h2{
  margin:0; font-family:"Anton", sans-serif; font-size: 36px; letter-spacing:-0.01em;
}
.modal .lead{
  margin: 8px 0 18px; font: 500 11px/1 "JetBrains Mono", monospace; letter-spacing:0.18em; color: var(--signal); text-transform:uppercase;
}

/* video page */
.video-shell{ padding: 22px 28px 60px;}
.video-grid{ display:grid; grid-template-columns: 1fr 360px; gap: 22px;}
@media (max-width: 1100px){ .video-grid{ grid-template-columns: 1fr;} }
.player-large{
  position:relative; aspect-ratio: 16/9; border:1px solid var(--line); border-radius: 8px; overflow:hidden; background:#000;
}
.video-meta h1{
  margin: 18px 0 0; font-family:"Anton", sans-serif; font-size: 44px; letter-spacing:-0.01em; line-height: 0.95;
}
.video-meta .row{
  margin-top: 12px; display:flex; gap:18px; flex-wrap:wrap;
  font: 500 11px/1 "JetBrains Mono", monospace; color: var(--fg-2); letter-spacing:0.14em; text-transform:uppercase;
}
.video-meta p{ margin-top: 14px; max-width: 70ch; color: var(--fg-2); font-size: 14px; line-height: 1.6;}

.episodes h4{
  margin:0 0 12px; font: 600 11px/1 "JetBrains Mono", monospace; letter-spacing:0.2em; text-transform:uppercase; color:var(--fg-3);
}
.ep-row{
  display:grid; grid-template-columns: 130px 1fr auto; gap: 12px; align-items:center;
  padding: 10px 0; border-bottom:1px solid var(--line); cursor:pointer;
}
.ep-row .thumb{
  aspect-ratio: 16/10; border-radius: 4px; border:1px solid var(--line); position:relative; overflow:hidden;
}
.ep-row .thumb .progress{ position:absolute; left:0; right:0; bottom:0; height:2px; background: rgba(255,255,255,0.1);}
.ep-row .thumb .progress > div{ height:100%; background: var(--signal);}
.ep-row .t{
  font: 600 13px/1.3 "Inter Tight", sans-serif; letter-spacing:-0.01em;
}
.ep-row .t small{
  display:block; margin-top:4px; font: 500 10px/1 "JetBrains Mono", monospace; color: var(--fg-3); letter-spacing:0.14em; text-transform:uppercase;
}
.ep-row .dur{ font: 500 10px/1 "JetBrains Mono", monospace; color: var(--fg-3); letter-spacing:0.14em;}
.ep-row:hover{ background: rgba(255,255,255,0.015);}
.ep-row.playing{ background: rgba(255,42,42,0.05);}
.ep-row.playing .t{ color: var(--signal);}

/* comments */
.comments{ margin-top: 28px;}
.comments h4{
  margin:0 0 14px; font: 600 11px/1 "JetBrains Mono", monospace; letter-spacing:0.2em; text-transform:uppercase; color:var(--fg-3);
}
.comment{
  display:grid; grid-template-columns: 36px 1fr; gap: 12px; padding: 14px 0; border-bottom:1px solid var(--line);
}
.comment .av{
  width:36px; height:36px; border-radius:50%; background: linear-gradient(135deg, #2a0606, #060606); border:1px solid var(--line-2);
  display:grid; place-items:center; font-family:"Anton", sans-serif; font-size: 14px; color: var(--fg-2);
}
.comment .u{ font: 600 12px/1 "Inter Tight"; letter-spacing:-0.01em;}
.comment .u small{ font: 500 10px/1 "JetBrains Mono", monospace; color: var(--fg-3); letter-spacing:0.14em; margin-left:8px;}
.comment p{ margin:6px 0 0; font-size: 13px; line-height: 1.55; color: var(--fg-2);}
.comment-box{
  margin-top: 14px; display:flex; gap:10px;
}
.comment-box textarea{
  flex:1; background: var(--shell); border:1px solid var(--line); border-radius: 6px; color: var(--fg);
  padding: 10px 12px; font: 13px/1.5 "Inter Tight", sans-serif; resize: none; min-height: 60px;
  outline:none;
}
.comment-box textarea:focus{ border-color: var(--line-2);}

/* ============================================================
   CINEMATIC HERO (red full-bleed)
   ============================================================ */
.cine-hero{
  position:relative;
  min-height: 760px;
  display:grid;
  grid-template-columns: 1fr;
  grid-template-rows: auto 1fr auto auto;
  background:
    radial-gradient(120% 80% at 50% 100%, rgba(0,0,0,0.55) 0%, transparent 60%),
    radial-gradient(60% 50% at 50% 70%, rgba(255,255,255,0.04) 0%, transparent 70%),
    linear-gradient(180deg, #c50808 0%, #9a0303 55%, #4a0202 100%);
  overflow:hidden;
  border-bottom: 1px solid rgba(0,0,0,0.6);
}

/* Global persistent left rail — fixed, always present on every page */
.global-rail{
  position: fixed;
  left: 0; top: 0; bottom: 0;
  width: 54px;
  display: flex; flex-direction: column; align-items: center; justify-content: space-between;
  padding: 22px 0;
  z-index: 80;
  background: rgba(8,8,10,0.92);
  border-right: 1px solid rgba(255,255,255,0.08);
  backdrop-filter: blur(8px);
  opacity: 0;
  transform: translateX(-12px);
  transition: opacity .35s ease, transform .35s ease;
  pointer-events: none;
}
.global-rail.visible{
  opacity: 1;
  transform: translateX(0);
  pointer-events: auto;
}
.global-rail .mono-mark{
  width: 30px; height: 30px; border: 1.5px solid #fff; border-radius: 50%;
  display: grid; place-items: center;
  font-family: "Anton", sans-serif; color: #fff; font-size: 14px;
}
.global-rail .vbrand{
  writing-mode: vertical-rl; transform: rotate(180deg);
  font: 600 9.5px/1 "JetBrains Mono", monospace; letter-spacing: 0.32em; text-transform: uppercase;
  color: rgba(255,255,255,0.85);
}
.global-rail .socials{ display: flex; flex-direction: column; gap: 8px; }
.global-rail .socials i{
  width: 26px; height: 26px; border-radius: 50%; border: 1px solid rgba(255,255,255,0.25);
  display: grid; place-items: center;
  font: 600 9px/1 "JetBrains Mono", monospace; color: #fff;
  background: rgba(255,255,255,0.03);
  cursor: pointer;
}
.global-rail .socials i:hover{ border-color: #fff; background: rgba(255,255,255,0.08); }

/* Push content right when rail is visible */
.has-rail{ padding-left: 54px; }
.has-rail .chrome{ padding-left: 28px; }
.cine-hero::before{
  content:""; position:absolute; inset:0;
  background-image: repeating-linear-gradient(180deg, rgba(0,0,0,0.18) 0 1px, transparent 1px 4px);
  pointer-events:none;
}
.cine-hero::after{
  content:""; position:absolute; left:0; right:0; bottom:0; height:42%;
  background:
    linear-gradient(180deg, transparent 0%, rgba(0,0,0,0.45) 70%, rgba(0,0,0,0.85) 100%),
    radial-gradient(80% 100% at 50% 100%, rgba(40,2,2,0.8), transparent 70%);
  pointer-events:none;
}
.cine-figure{
  position:absolute; left:50%; bottom:30%; transform:translateX(-50%);
  width:42px; height:140px;
  background: linear-gradient(180deg, rgba(20,2,2,0.95) 0%, rgba(40,4,4,0.7) 70%, transparent 100%);
  clip-path: polygon(38% 0, 62% 0, 70% 22%, 78% 50%, 80% 80%, 76% 100%, 24% 100%, 20% 80%, 22% 50%, 30% 22%);
  filter: blur(0.4px);
  z-index: 2;
  pointer-events:none;
}
.cine-figure::after{
  content:""; position:absolute; left:50%; bottom:-30px; transform:translateX(-50%);
  width:120px; height:24px; border-radius:50%;
  background: radial-gradient(closest-side, rgba(0,0,0,0.55), transparent 70%);
}
.cine-horizon{
  position:absolute; left:0; right:0; bottom: 26%; height:1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.18) 30% 70%, transparent);
  pointer-events:none;
}

.cine-rail{
  grid-column: 1; grid-row: 1 / -1;
  border-right:1px solid rgba(0,0,0,0.35);
  display:none;
  padding: 22px 0;
  z-index:5;
  background: rgba(0,0,0,0.08);
}
.cine-rail .mono-mark{
  width:30px; height:30px; border:1.5px solid #fff; border-radius:50%;
  display:grid; place-items:center;
  font-family:"Anton",sans-serif; color:#fff; font-size:14px;
}
.cine-rail .vbrand{
  writing-mode: vertical-rl; transform: rotate(180deg);
  font: 600 9.5px/1 "JetBrains Mono", monospace; letter-spacing:0.32em; text-transform:uppercase;
  color: rgba(255,255,255,0.85);
}
.cine-rail .socials{ display:flex; flex-direction:column; gap:8px; }
.cine-rail .socials i{
  width:26px; height:26px; border-radius:50%; border:1px solid rgba(0,0,0,0.55);
  display:grid; place-items:center;
  font: 600 9px/1 "JetBrains Mono", monospace; letter-spacing:0.04em; color:#fff;
  background: rgba(0,0,0,0.25);
}

.cine-nav{
  grid-column: 1; grid-row: 1;
  display:flex; align-items:center; gap:22px;
  padding: 22px 36px 22px 80px;
  z-index:5;
}
.cine-nav .grp{ display:flex; gap:22px;}
.cine-nav button{
  appearance:none; background:transparent; border:0; color:#fff;
  font: 600 11px/1 "JetBrains Mono", monospace; letter-spacing:0.22em; text-transform:uppercase; cursor:pointer;
  opacity:.85;
}
.cine-nav button:hover{ opacity:1; }
.cine-nav button.active{ opacity:1; }
.cine-nav .gap{ flex:1; }
.cine-nav .lang{
  font: 600 11px/1 "JetBrains Mono", monospace; letter-spacing:0.2em; color:#fff; opacity:.85;
}
.cine-nav .lang b{ opacity:1; }
.cine-nav .lang span{ opacity:0.45; margin: 0 4px;}
.cine-nav .cta{
  appearance:none; background:transparent; color:#fff;
  border:1.5px solid #fff; padding: 10px 16px; border-radius: 0;
  font: 600 11px/1 "JetBrains Mono", monospace; letter-spacing:0.22em; text-transform:uppercase; cursor:pointer;
}
.cine-nav .cta:hover{ background:#fff; color:#9a0303;}

.cine-headline{
  grid-column: 1; grid-row: 1 / 3;
  padding: 30px 36px 0 80px;
  z-index: 4;
  align-self: start;
}
.cine-headline .eyebrow{
  font: 500 11px/1 "JetBrains Mono", monospace; letter-spacing:0.22em; text-transform:uppercase;
  color: rgba(255,255,255,0.85); margin-bottom: 18px; display:flex; align-items:center; gap:14px;
}
.cine-headline .eyebrow::before{
  content:""; width:36px; height:1px; background: rgba(255,255,255,0.7);
}
.cine-headline h1{
  margin:0;
  font-family:"Anton","Bebas Neue",sans-serif;
  font-size: clamp(56px, 9vw, 140px);
  line-height: 0.86;
  letter-spacing: -0.015em;
  color:#fff;
  text-transform: uppercase;
  text-shadow: 0 6px 40px rgba(0,0,0,0.35);
  max-width: 70%;
}
.cine-headline h1 .outline{
  -webkit-text-stroke: 2px #fff;
  color: transparent;
  display: inline-block;
}
.cine-headline .meta{
  margin-top:18px;
  font: 500 12px/1 "JetBrains Mono", monospace; letter-spacing:0.2em; text-transform:uppercase;
  color: rgba(255,255,255,0.85);
  display:flex; gap:18px; flex-wrap:wrap;
}
.cine-headline .meta b{ color:#fff;}

.cine-hp{
  position:absolute; top: 90px; right: 36px; z-index:4;
  width:48px; height:48px; border-radius:50%; border:1.5px solid #fff;
  display:grid; place-items:center; color:#fff;
  background: rgba(0,0,0,0.15);
}
.cine-hp::before{
  content:""; position:absolute; inset:-6px; border:1px dashed rgba(255,255,255,0.35); border-radius:50%;
  animation: spin 24s linear infinite;
}

.cine-tagline{
  grid-column: 1; grid-row: 3;
  padding: 0 36px 18px;
  text-align: right;
  z-index:4;
}
.cine-tagline h2{
  margin:0;
  font-family:"Anton",sans-serif;
  font-size: clamp(22px, 2.6vw, 40px);
  line-height: 0.95;
  letter-spacing: -0.005em;
  color:#fff;
  text-transform: uppercase;
}

.cine-bottom{
  grid-column: 2; grid-row: 4;
  display:grid; grid-template-columns: auto auto auto 1fr auto auto;
  gap: 32px; align-items: end;
  padding: 18px 36px 22px;
  z-index:5;
  border-top: 1px solid rgba(255,255,255,0.18);
}
.cine-bottom .col{
  font: 500 11px/1.5 "JetBrains Mono", monospace; letter-spacing:0.16em; text-transform:uppercase;
  color: rgba(255,255,255,0.65);
}
.cine-bottom .col b{ color:#fff; display:block; margin-top:6px; font-weight:600;}
.cine-bottom .progress{
  position:relative; height:1px; background: rgba(255,255,255,0.25); align-self:center; min-width: 280px;
}
.cine-bottom .progress > div{
  position:absolute; left:0; top:0; bottom:0; background:#fff;
}
.cine-bottom .pageno{
  font-family:"Anton",sans-serif; font-size: 36px; line-height:1; color:#fff;
}
.cine-bottom .pageno span{ font-size: 13px; color: rgba(255,255,255,0.6); margin-left: 4px; vertical-align: 6px; font-family:"JetBrains Mono",monospace; letter-spacing:0.14em;}
.cine-bottom .arrows{ display:flex; gap:10px; }
.cine-bottom .arrows button{
  appearance:none; background:transparent; border:1px solid rgba(255,255,255,0.4);
  color:#fff; width: 38px; height: 38px; border-radius:50%; cursor:pointer;
  display:grid; place-items:center;
}
.cine-bottom .arrows button:hover{ background: rgba(255,255,255,0.1); border-color:#fff;}

/* Stat row removed from absolute positioning; now lives inside headline */
.cine-stats{
  display:flex; gap: 40px; flex-wrap: wrap;
  margin-top: 24px;
  font: 500 11px/1.5 "JetBrains Mono", monospace; letter-spacing:0.18em; text-transform:uppercase;
  color: rgba(255,255,255,0.7);
}
.cine-stats b{ color:#fff; display:block; margin-top:4px; font-weight:600;}

@media (max-width: 1100px){
  .cine-hero{ min-height: 720px; }
  .cine-headline h1{ font-size: clamp(48px, 8vw, 96px); max-width: 100%; }
  .cine-bottom{ grid-template-columns: 1fr 1fr 1fr auto; gap: 18px; }
  .cine-bottom .progress{ display:none; }
}
@media (max-width: 720px){
  .cine-headline{ padding: 22px 22px 0 28px; }
  .cine-tagline{ padding: 0 22px 16px; text-align: left; }
  .cine-bottom{ grid-template-columns: 1fr 1fr; padding: 16px 22px 20px; }
  .cine-nav{ padding: 18px 22px; gap: 12px; flex-wrap: wrap; }
  .cine-nav .grp{ gap: 12px; }
}

/* utility */
.hidden{ display:none !important;}

/* === CALENDAR === */
.cal-shell{ padding: 22px 28px 60px; }
.cal-toolbar{
  display:flex; justify-content:space-between; align-items:center; gap: 18px;
  padding: 14px 0 18px; border-bottom: 1px solid var(--line); margin-bottom: 18px;
}
.cal-nav{ display:flex; gap: 14px; align-items:center; }
.cal-month{
  font-family: "Anton", sans-serif; font-size: 36px; line-height: 1;
  letter-spacing: -0.005em; text-transform: uppercase;
}
.cal-month span{ color: var(--fg-2); margin-left: 8px; font-size: 26px; }
.cal-arrow{
  appearance:none; cursor:pointer; background: transparent; border: 1px solid var(--line-2);
  width: 34px; height: 34px; display:flex; align-items:center; justify-content:center; color: #fff;
}
.cal-arrow:hover{ border-color: #fff; }
.cal-filters{ display:flex; gap: 6px; flex-wrap: wrap; }
.cal-filter{
  appearance:none; cursor:pointer; background: transparent; border: 1px solid var(--line-2); color: var(--fg-2);
  padding: 8px 12px; font: 600 10.5px/1 "JetBrains Mono", monospace; letter-spacing: 0.16em; text-transform: uppercase;
}
.cal-filter.active{ border-color: #fff; color: #fff; background: rgba(255,255,255,0.04); }
.cal-filter.running{ }
.cal-filter.running.active{ border-color: var(--signal); color: var(--signal); }
.cal-filter.retreat.active{ border-color: #6ad17a; color: #6ad17a; }
.cal-filter.event.active{ border-color: #f4c14d; color: #f4c14d; }

.cal-grid-wrap{ display:grid; grid-template-columns: minmax(0, 1fr) 340px; gap: 18px; align-items: start; }
.cal-grid{ border: 1px solid var(--line); background: var(--surface); min-width: 0; }
.cal-body{ display: grid; grid-template-columns: repeat(7, minmax(0, 1fr)); }
.cal-head{
  display:grid; grid-template-columns: repeat(7, minmax(0, 1fr));
  border-bottom: 1px solid var(--line); background: #0a0a0c;
}
@media (max-width: 1100px){ .cal-grid-wrap{ grid-template-columns: 1fr; } }
.cal-head > div{
  padding: 10px 12px; font: 600 10px/1 "JetBrains Mono", monospace; letter-spacing: 0.22em; color: var(--fg-2);
  border-right: 1px solid var(--line);
}
.cal-head > div:last-child{ border-right: 0; }
.cal-body{ display: grid; grid-template-columns: repeat(7, minmax(0, 1fr)); }
.cal-cell{
  min-height: 110px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line);
  padding: 8px; display:flex; flex-direction: column; gap: 6px;
  background: var(--surface);
  min-width: 0;
}
.cal-cell:nth-child(7n){ border-right: 0; }
.cal-cell.blank{ background: #08080a; }
.cal-cell.today{ background: rgba(255,42,42,0.06); outline: 1px solid var(--signal); outline-offset: -1px; }
.cal-num{
  font: 600 11px/1 "JetBrains Mono", monospace; letter-spacing: 0.14em; color: var(--fg-2);
  display:flex; justify-content:space-between; align-items:center;
}
.todaytag{
  font: 600 9px/1 "JetBrains Mono", monospace; letter-spacing: 0.2em;
  color: var(--signal); padding: 3px 5px; border: 1px solid var(--signal);
}
.cal-evs{ display:flex; flex-direction: column; gap: 4px; }
.cal-ev{
  appearance:none; cursor:pointer; background: rgba(255,255,255,0.04);
  border: 1px solid var(--line-2); border-left: 3px solid var(--signal);
  padding: 5px 7px; display:flex; gap: 6px; align-items:center; text-align:left;
  font: 600 11px/1.25 "Inter Tight", sans-serif; color: #fff; min-width: 0;
}
.cal-ev:hover{ background: rgba(255,255,255,0.08); }
.cal-ev .dot{ display:none; }
.cal-ev .t{ overflow:hidden; text-overflow:ellipsis; white-space: nowrap; }
.cal-ev.running{ border-left-color: var(--signal); }
.cal-ev.retreat{ border-left-color: #6ad17a; }
.cal-ev.event{ border-left-color: #f4c14d; }
.cal-more{ font: 600 9.5px/1 "JetBrains Mono", monospace; letter-spacing: 0.16em; color: var(--fg-2); padding-left: 4px; }

/* rail */
.cal-rail{ display:flex; flex-direction: column; gap: 10px; }
.cal-rail-hd{ padding: 4px 2px 6px; }
.cal-rail-hd .crumb{ font: 600 10px/1 "JetBrains Mono", monospace; letter-spacing: 0.22em; color: var(--fg-2); margin-bottom: 8px; }
.cal-rail-hd h3{ margin: 0; font-family: "Anton", sans-serif; font-size: 22px; letter-spacing: -0.005em; }
.cal-list{ display:flex; flex-direction: column; gap: 6px; }
.cal-item{
  appearance:none; cursor:pointer; text-align:left;
  display:grid; grid-template-columns: 60px 1fr; gap: 12px;
  border: 1px solid var(--line); border-left: 3px solid var(--signal);
  background: var(--surface); padding: 12px; color: #fff;
}
.cal-item:hover{ border-color: var(--line-2); }
.cal-item.selected{ background: rgba(255,255,255,0.04); border-color: #fff; }
.cal-item.running{ border-left-color: var(--signal); }
.cal-item.retreat{ border-left-color: #6ad17a; }
.cal-item.event{ border-left-color: #f4c14d; }
.cal-date{ display:flex; flex-direction: column; align-items: flex-start; gap: 4px; }
.cal-date b{ font-family: "Anton", sans-serif; font-size: 30px; line-height: 1; letter-spacing: -0.01em; }
.cal-date span{ font: 600 10px/1 "JetBrains Mono", monospace; letter-spacing: 0.18em; color: var(--fg-2); }
.cal-it-body{ display:flex; flex-direction: column; gap: 4px; min-width: 0; }
.cal-it-type{ font: 600 9.5px/1 "JetBrains Mono", monospace; letter-spacing: 0.2em; color: var(--fg-2); }
.cal-it-title{ font: 600 13.5px/1.3 "Inter Tight", sans-serif; letter-spacing: -0.005em; }
.cal-it-loc{ font: 600 10.5px/1.3 "JetBrains Mono", monospace; letter-spacing: 0.14em; color: var(--fg-2); text-transform: uppercase; }

/* detail modal */
.cal-detail{
  position: fixed; inset: 0; background: rgba(0,0,0,0.7); z-index: 90;
  display:flex; align-items:center; justify-content:center; padding: 20px;
}
.cal-detail-card{
  position: relative; max-width: 520px; width: 100%; background: #0d0d10;
  border: 1px solid var(--line-2); border-top: 4px solid var(--signal);
  padding: 28px;
}
.cal-detail-card.running{ border-top-color: var(--signal); }
.cal-detail-card.retreat{ border-top-color: #6ad17a; }
.cal-detail-card.event{ border-top-color: #f4c14d; }
.cal-close{
  position:absolute; top: 12px; right: 12px; appearance:none; background:transparent; border:0;
  color: var(--fg-2); font-size: 22px; cursor:pointer; line-height: 1; padding: 4px 8px;
}
.cal-close:hover{ color: #fff; }
.cal-detail-type{
  font: 600 10.5px/1 "JetBrains Mono", monospace; letter-spacing: 0.22em; color: var(--fg-2); margin-bottom: 10px;
}
.cal-detail-card h3{
  margin: 0 0 8px; font-family: "Anton", sans-serif; font-size: 32px; line-height: 1.05;
  letter-spacing: -0.01em; text-transform: uppercase;
}
.cal-detail-card p{ color: var(--fg-2); margin: 0 0 18px; line-height: 1.55; font-size: 13.5px; }
.cal-detail-meta{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 14px; padding: 14px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); margin-bottom: 18px; }
.cal-detail-meta b{ display:block; font: 600 9.5px/1 "JetBrains Mono", monospace; letter-spacing: 0.22em; color: var(--fg-2); margin-bottom: 6px; }
.cal-detail-meta span{ font: 600 11.5px/1.3 "JetBrains Mono", monospace; letter-spacing: 0.08em; color: #fff; }
.cal-detail-actions{ display:flex; gap: 8px; }
.cal-detail-actions .btn{ flex: 1; }

/* nav LIVE indicator dot */
.chrome .nav button.has-live-dot{ position: relative; }
.nav-live-dot{
  position: absolute; top: 3px; right: 1px;
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--signal);
  box-shadow: 0 0 0 0 rgba(255, 42, 42, 0.6);
  animation: navPulse 1.4s infinite;
  pointer-events: none;
}
.nav-live-dot.adult{ background: #ff3aa6; box-shadow: 0 0 0 0 rgba(255,58,166,0.55); animation-name: navPulseAdult; }
@keyframes navPulse{
  0%   { box-shadow: 0 0 0 0   rgba(255,42,42,0.6); }
  70%  { box-shadow: 0 0 0 8px rgba(255,42,42,0); }
  100% { box-shadow: 0 0 0 0   rgba(255,42,42,0); }
}
@keyframes navPulseAdult{
  0%   { box-shadow: 0 0 0 0   rgba(255,58,166,0.55); }
  70%  { box-shadow: 0 0 0 8px rgba(255,58,166,0); }
  100% { box-shadow: 0 0 0 0   rgba(255,58,166,0); }
}

/* === LIVE BROADCAST PAGE === */
.live-view{ padding: 22px 28px 60px; }
.live-hd{
  display:flex; justify-content:space-between; align-items:flex-end; gap:22px;
  margin-bottom: 18px; padding-bottom: 16px; border-bottom: 1px solid var(--line);
}
.live-hd .crumb{ font: 600 10.5px/1 "JetBrains Mono", monospace; letter-spacing: 0.22em; color: var(--fg-2); margin-bottom: 10px;}
.live-title{
  font-family: "Anton", "Bebas Neue", sans-serif; font-size: 56px; line-height: 0.95;
  letter-spacing: -0.012em; margin: 0; text-transform: uppercase;
}
.live-meta{ display:flex; gap:14px; align-items:center; flex-wrap:wrap; margin-top: 12px;
  font: 600 10.5px/1 "JetBrains Mono", monospace; letter-spacing: 0.16em; color: var(--fg-2); text-transform: uppercase;
}
.live-meta .live-pill{ font-size: 10.5px; }
.live-hd .right{ display:flex; gap:8px; align-items:center; }

.live-grid{ display: grid; grid-template-columns: 1fr 360px; gap: 18px; }
.live-stage{ display:flex; flex-direction: column; gap: 14px; }
.live-stage .frame{
  position: relative; aspect-ratio: 16/9; background:#000;
  border: 1px solid var(--line); overflow: hidden;
}
.live-watermark{
  position:absolute; top: 14px; right: 14px; padding: 5px 9px;
  background: rgba(0,0,0,0.45); border: 1px solid rgba(255,255,255,0.18);
  font: 600 9.5px/1 "JetBrains Mono", monospace; letter-spacing: 0.22em; color:#fff;
}
.live-tele-overlay{
  position:absolute; top: 14px; left: 14px;
  background: rgba(0,0,0,0.55); border: 1px solid rgba(255,255,255,0.14);
  padding: 10px 12px; min-width: 230px;
}
.live-tele{ display: grid; grid-template-columns: auto 1fr; gap: 5px 14px; align-items: baseline; }
.lt-row{ display: contents; font: 600 10px/1.4 "JetBrains Mono", monospace; letter-spacing: 0.16em; }
.lt-row b{ color: rgba(255,255,255,0.55); font-weight: 600; font: 600 10px/1.4 "JetBrains Mono", monospace; letter-spacing: 0.16em; }
.lt-row span{ color: #fff; text-align: right; font: 600 10px/1.4 "JetBrains Mono", monospace; letter-spacing: 0.16em; }

/* route trace */
.live-route{
  border: 1px solid var(--line); background: var(--surface);
  padding: 14px 16px;
}
.lr-hd{
  display:flex; justify-content:space-between; align-items:center; margin-bottom: 8px;
  font: 600 10.5px/1 "JetBrains Mono", monospace; letter-spacing: 0.18em; text-transform: uppercase;
}
.lr-hd .muted{ color: var(--fg-2); }
.live-route svg{ width: 100%; height: 110px; display: block; }
.lr-stats{ display:grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-top: 10px; padding-top: 12px; border-top: 1px solid var(--line); }
.lr-stats div{ display:flex; flex-direction: column; gap: 4px; }
.lr-stats b{ font-family: "Anton", sans-serif; font-size: 26px; letter-spacing: -0.01em; }
.lr-stats span{ font: 600 9.5px/1 "JetBrains Mono", monospace; letter-spacing: 0.18em; color: var(--fg-2); text-transform: uppercase; }

/* live chat */
.live-side{ display:flex; flex-direction: column; }
.live-chat{
  display:flex; flex-direction: column; height: 100%;
  border: 1px solid var(--line); background: var(--surface);
}
.lc-hd{
  display:flex; justify-content: space-between; align-items: center;
  padding: 12px 14px; border-bottom: 1px solid var(--line);
  font: 600 10.5px/1 "JetBrains Mono", monospace; letter-spacing: 0.18em; text-transform: uppercase;
}
.lc-hd .muted{ color: var(--fg-2); }
.live-dot{ display:inline-block; width: 7px; height: 7px; border-radius: 50%; background: var(--signal); animation: pulse 1.2s infinite; margin-right: 6px;}
.lc-body{
  flex: 1; min-height: 380px; max-height: 520px; overflow-y: auto;
  padding: 12px 14px; display: flex; flex-direction: column; gap: 8px;
  font: 12.5px/1.5 "JetBrains Mono", monospace;
}
.lc-msg{ display: grid; grid-template-columns: auto 1fr; gap: 8px; align-items: baseline; }
.lc-msg .u{ color: rgba(255,255,255,0.55); font-weight: 600; }
.lc-msg .t{ color: #fff; min-width: 0; word-break: break-word; }
.lc-msg.mod .u{ color: var(--signal); }
.lc-msg.self .u{ color: #6ad17a; }
.lc-input{
  display:flex; gap: 6px; padding: 10px; border-top: 1px solid var(--line);
}
.lc-input input{
  flex: 1; background: #0a0a0c; border: 1px solid var(--line-2); color: #fff;
  padding: 9px 10px; font: 12px/1 "JetBrains Mono", monospace; letter-spacing: 0.04em;
  border-radius: 0;
}
.lc-input input:focus{ outline: 1px solid var(--signal); border-color: var(--signal); }
.lc-input .btn.primary{ padding: 9px 14px; }

@media (max-width: 1100px){
  .live-grid{ grid-template-columns: 1fr; }
  .live-title{ font-size: 42px; }
}

/* Leaflet host & dark theme tweaks */
.leaflet-host{ width:100%; background:#0a0a0c; position: relative; z-index: 1; }
.leaflet-container{ background:#0a0a0c !important; font-family: "JetBrains Mono", monospace; z-index: 1 !important; }
.leaflet-control-zoom a{ background:#0d0d10 !important; color:#fff !important; border-color: rgba(255,255,255,0.15) !important; }
.leaflet-control-zoom a:hover{ background:#1a1a1e !important; }
.leaflet-control-attribution{ background: rgba(0,0,0,0.6) !important; color: rgba(255,255,255,0.5) !important; font-size: 9px !important;}
.leaflet-control-attribution a{ color: rgba(255,255,255,0.7) !important; }
.leaflet-tooltip{
  background: #0d0d10 !important; color: #fff !important; border: 1px solid rgba(255,255,255,0.15) !important;
  font: 600 9.5px/1 "JetBrains Mono", monospace !important; letter-spacing: 0.16em; text-transform: uppercase;
  padding: 5px 8px !important; box-shadow: none !important;
}
.leaflet-tooltip-top:before{ border-top-color: #0d0d10 !important; }
.rr-marker-wrap{ background:transparent !important; border:none !important; }
.rr-marker{
  width:14px; height:14px; border-radius:50%;
  background:#fff; border:2px solid #000;
  box-shadow: 0 0 0 3px rgba(255,255,255,0.08);
  position:relative;
}
.rr-marker.live{
  background: var(--signal); border-color:#1a0202;
  box-shadow: 0 0 0 3px rgba(255,42,42,0.18), 0 0 14px rgba(255,42,42,0.7);
}
.rr-marker.live::before{
  content:""; position:absolute; inset:-6px; border:1px solid var(--signal); border-radius:50%; animation: ring 1.8s infinite;
}
.spacer{ flex:1;}
.kbd{
  display:inline-block; font: 500 10px/1 "JetBrains Mono", monospace; padding:3px 5px; border:1px solid var(--line-2); border-radius:3px; color: var(--fg-2);
}

/* ============================================================
   MOBILE — comprehensive responsive pass
   ============================================================ */

/* ── Tablet-and-down (≤900px) ───────────────────────── */
@media (max-width: 900px){
  /* shrink generic shells */
  .archive-shell, .doors-shell, .forum-shell, .cal-shell, .live-shell,
  .video-shell, .map-shell, .tiers-shell{ padding: 16px 18px 48px !important; }

  /* hub padding (cinematic hero handles its own) */
  .hub{ padding: 14px 18px 32px; }

  /* tiles a touch smaller min */
  .tile-grid, .continue-grid{ grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)) !important; }
  .archive-grid{ grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)) !important; }
  .doors-grid{ grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)) !important; }

  /* live grid (chat to bottom) */
  .live-grid{ grid-template-columns: 1fr !important; }
  .lc-shell{ max-height: 340px; }
}

/* ── Phone (≤720px) ─────────────────────────────────── */
@media (max-width: 720px){
  /* TOP CHROME: collapse to 2 rows — brand + (right cluster) on row 1, nav scroll on row 2 */
  .chrome{
    flex-wrap: wrap;
    gap: 10px;
    padding: 10px 14px;
  }
  .brand .word small{ display:none; }
  .brand .word b{ font-size: 16px; }
  .brand .mark{ width: 30px; height: 30px; font-size: 16px; }

  /* right cluster: tighter, hide live-pill (the indicator inside LIVE button is enough) */
  .chrome .right{ gap: 6px; flex-wrap: nowrap; }
  .live-pill{ display:none; }
  .lang-trigger{ padding: 8px 8px; font-size: 10px; letter-spacing: 0.16em; }
  .btn.join-cta, .btn.login-cta{
    padding: 8px 10px; font-size: 10px; letter-spacing: 0.14em;
  }

  /* nav becomes a horizontally-scrolling strip on its own row */
  .nav{
    order: 99;
    flex: 0 0 100%;
    margin: 0 -14px;
    padding: 4px 14px;
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    border-top: 1px solid var(--line);
  }
  .nav::-webkit-scrollbar{ display:none; }
  .nav button{
    flex: 0 0 auto;
    padding: 8px 10px;
    font-size: 11px;
    letter-spacing: 0.12em;
  }

  /* Tiles further reduced for narrow phones */
  .tile-grid, .continue-grid{ grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)) !important; }
  .archive-grid{ grid-template-columns: 1fr !important; }
  .doors-grid{ grid-template-columns: 1fr !important; }
  .tiers{ grid-template-columns: 1fr !important; }

  /* page-section pretitle: smaller */
  .section-title, .archive-title, .doors-title{
    font-size: clamp(28px, 7vw, 44px) !important;
  }

  /* CALENDAR cells: less padding, smaller fonts */
  .cal-grid-wrap{ grid-template-columns: 1fr !important; }
  .cal-toolbar{ flex-direction: column; align-items: stretch; gap: 12px; }
  .cal-toolbar .cal-nav{ justify-content: space-between; }
  .cal-month{ font-size: 28px; }
  .cal-month span{ font-size: 18px; }
  .cal-cell{ min-height: 78px; padding: 4px 4px 6px; font-size: 11px; }
  .cal-it{ padding: 3px 4px; font-size: 10px; }
  .cal-it-body strong{ font-size: 10.5px; }
  .cal-it-body em{ display:none; }
  .cal-head{ font-size: 9.5px; }

  /* FORUM right rail collapses (already <=1100) but tighten widget paddings */
  .forum-side > *{ padding: 14px 14px !important; }

  /* FOOTER: 1 column on phones */
  .footer-cols{ grid-template-columns: 1fr !important; gap: 22px; }
  .footer-top{ flex-direction: column; gap: 22px; }
  .footer-brand{ max-width: 100%; }
  .footer-bottom{
    flex-direction: column; align-items: flex-start !important; gap: 14px;
  }
  .footer-bottom .footer-policies{ flex-wrap: wrap; gap: 10px 18px; }

  /* CINEMATIC HERO: tighten further (existing rules at @720 already touch some) */
  .cine-hero{ min-height: 560px; }
  .cine-headline h1{ font-size: clamp(40px, 11vw, 72px) !important; line-height: 0.92; }
  .cine-stats{ flex-wrap: wrap; gap: 14px 22px; }
  .cine-stat .num{ font-size: 22px; }
  .cine-side-rail{ display: none; }
  .cine-bottom{ grid-template-columns: 1fr !important; row-gap: 10px; }

  /* LIVE page: chat panel takes full width (already 1col @900) */
  .lc-shell{ max-height: 320px; }
  .live-stage .frame{ aspect-ratio: 16/9; }

  /* VIDEO detail */
  .video-grid{ grid-template-columns: 1fr !important; }
  .video-meta h2{ font-size: 28px !important; }

  /* DOORS — locked vault doors */
  .door{ padding: 14px !important; }
  .door h3{ font-size: 18px !important; }

  /* MAP page: keep full bleed but pull map height to viewport */
  .map-shell{ padding: 12px 12px 40px !important; }
  .leaflet-host{ height: calc(100vh - 220px); min-height: 360px; }

  /* Buttons baseline: comfortable touch targets */
  .btn{ padding: 11px 14px; min-height: 40px; }
  input, textarea, select{ font-size: 16px; }   /* prevent iOS zoom on focus */

  /* Modal full-screen on phone */
  .modal{ inset: 0 !important; max-width: 100% !important; max-height: 100% !important; border-radius: 0 !important; }
}

/* ── Small phone (≤480px) ──────────────────────────── */
@media (max-width: 480px){
  .chrome{ padding: 8px 10px; }
  .brand .word b{ font-size: 14px; }
  .lang-trigger{ display: none; }                /* hide lang dd entirely; available in footer */
  .btn.join-cta, .btn.login-cta{
    padding: 7px 8px; font-size: 9.5px; letter-spacing: 0.1em;
  }

  .archive-shell, .doors-shell, .forum-shell, .cal-shell,
  .live-shell, .video-shell, .map-shell, .tiers-shell,
  .hub{ padding: 12px 10px 36px !important; }

  .cine-headline{ padding: 18px 14px 0 14px !important; }
  .cine-tagline{ padding: 0 14px 12px !important; }
  .cine-bottom{ padding: 12px 14px 16px !important; }
  .cine-headline h1{ font-size: clamp(34px, 12vw, 60px) !important; }

  .footer-stats{ flex-wrap: wrap; gap: 10px 14px; }

  .tiers .tier{ padding: 18px !important; }
  .tier .price{ font-size: 30px !important; }

  .cal-cell{ min-height: 64px; padding: 3px; }
  .cal-it{ padding: 2px 3px; font-size: 9.5px; }
}

/* Slight UX boost: prefer no horizontal scrolling anywhere */
html, body{ overflow-x: hidden; }
