/* ====================================================================
   THE OPERATOR — Portfolio of Akash Rathore
   Editorial newspaper × stadium broadcast
   --------------------------------------------------------------------
   00  Reset & base
   01  Tokens (themes: paper / floodlights)
   02  Curtain · Ticker · Scroll progress · Skip
   03  Wrap · Masthead
   04  Cover / Hero
   05  Section primitives
   06  Manifesto
   07  Stats
   08  Project grid
   09  Career deck (tape)
   10  Toolkit
   11  Contact · Accreditation pass
   12  Colophon
   13  Project environment modal
   14  Tweaks panel
   15  Reveals · Motion
   16  Responsive
   ==================================================================== */

/* ============= 00 RESET ============= */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Space Grotesk',system-ui,sans-serif;
  font-size:16px;line-height:1.5;
  color:var(--ink);background:var(--bg);
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
  font-feature-settings:"ss01","ss02","cv01","cv02";
}
img,svg{display:block;max-width:100%}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
a{color:inherit;text-decoration:none}
ul{margin:0;padding:0;list-style:none}
h1,h2,h3,h4,h5,h6{margin:0;font-weight:400;letter-spacing:-0.01em}
em{font-style:italic}
sup{font-size:.55em;vertical-align:super}
sub{font-size:.55em;vertical-align:sub}
.mono{font-family:'JetBrains Mono',ui-monospace,monospace}
::selection{background:var(--flood);color:var(--paper)}

/* ============= 01 TOKENS ============= */
:root{
  /* PAPER (default) */
  --bg:#f1ebda;
  --bg-deep:#e8e0c8;
  --paper:#faf4e3;
  --paper-2:#f6efd9;
  --ink:#14110a;
  --ink-2:#2a241a;
  --mute:#867c66;
  --mute-2:#a39a82;
  --rule:#d3c8a8;
  --rule-soft:#e3dac0;
  --flood:#d63919;        /* vermilion · floodlight */
  --flood-deep:#a82e15;
  --gold:#b08842;
  --hl:#f6d564;
  --shadow:0 1px 0 rgba(20,17,10,.04), 0 20px 40px -20px rgba(20,17,10,.12);
  --shadow-2:0 1px 0 rgba(20,17,10,.05), 0 30px 60px -25px rgba(20,17,10,.22);

  --maxw:1480px;
  --pad:64px;
  --gut:32px;

  --r-sm:6px;--r-md:14px;--r-lg:22px;--r-xl:34px;

  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}
[data-theme="floodlights"]{
  --bg:#0b0905;
  --bg-deep:#050402;
  --paper:#100e08;
  --paper-2:#15120a;
  --ink:#f1e8d0;
  --ink-2:#d6cba8;
  --mute:#7a7058;
  --mute-2:#5a5240;
  --rule:#1f1a10;
  --rule-soft:#161208;
  --flood:#ffb547;        /* warm stadium light */
  --flood-deep:#e89a2c;
  --gold:#d4a85a;
  --hl:#ffd76b;
  --shadow:0 0 0 1px rgba(255,181,71,.05), 0 30px 60px -30px rgba(0,0,0,.8);
  --shadow-2:0 0 0 1px rgba(255,181,71,.07), 0 50px 90px -30px rgba(0,0,0,.9);
}

/* Subtle newsprint grain */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.5 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.55'/></svg>");
  mix-blend-mode:multiply;opacity:.18;
}
[data-theme="floodlights"] body::before,
body[data-theme="floodlights"]::before{mix-blend-mode:screen;opacity:.06}

.skip-link{
  position:fixed;left:50%;top:-100px;transform:translateX(-50%);
  background:var(--ink);color:var(--paper);padding:10px 18px;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;z-index:9999;border-radius:0 0 8px 8px;
  transition:top .2s var(--ease);
}
.skip-link:focus{top:0}

/* ============= 02 CURTAIN / TICKER / PROGRESS ============= */
.curtain{
  position:fixed;inset:0;z-index:200;background:var(--ink);
  display:grid;place-items:center;color:var(--paper);
  transition:opacity .9s var(--ease) .15s, visibility .9s;
}
.curtain.gone{opacity:0;visibility:hidden;pointer-events:none}
.curtain .floodlights{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(60% 60% at 20% 10%, rgba(255,181,71,.35), transparent 60%),
    radial-gradient(40% 60% at 80% 15%, rgba(255,181,71,.22), transparent 60%),
    radial-gradient(80% 50% at 50% 100%, rgba(214,57,25,.18), transparent 65%);
  filter:blur(2px);
}
.curtain .stack{position:relative;text-align:center;padding:0 24px}
.curtain .meta{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.32em;
  text-transform:uppercase;color:rgba(241,232,208,.55);margin-bottom:24px;
  opacity:0;transform:translateY(8px);
  animation:cIn .8s var(--ease-out) .15s forwards;
}
.curtain .mark{
  font-family:'Instrument Serif',serif;font-size:clamp(80px,16vw,220px);
  line-height:.86;letter-spacing:-0.04em;
  opacity:0;transform:translateY(40px);
  animation:cIn 1.05s var(--ease-out) .25s forwards;
}
.curtain .mark em{color:var(--flood);font-style:italic}
.curtain .strap{
  font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.28em;
  text-transform:uppercase;color:rgba(241,232,208,.7);margin-top:28px;
  opacity:0;animation:cIn .8s var(--ease-out) .55s forwards;
}
.curtain .bar{
  height:2px;width:0;background:var(--flood);margin:36px auto 0;
  animation:cBar 1.2s var(--ease-out) .7s forwards;
}
@keyframes cIn{to{opacity:1;transform:translateY(0)}}
@keyframes cBar{to{width:280px}}

.ticker{
  position:relative;z-index:5;
  display:flex;align-items:center;gap:0;
  border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);
  background:var(--paper);
  font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.14em;
  text-transform:uppercase;
  overflow:hidden;
}
.ticker .label{
  flex-shrink:0;padding:11px 18px;background:var(--ink);color:var(--paper);
  display:flex;align-items:center;gap:8px;
  border-right:1px solid var(--rule);
  font-weight:600;
}
.ticker .label .pulse{
  width:7px;height:7px;border-radius:50%;background:var(--flood);
  box-shadow:0 0 0 0 var(--flood);
  animation:pulse 1.6s infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(214,57,25,.6)}
  100%{box-shadow:0 0 0 14px rgba(214,57,25,0)}
}
.ticker .track{
  display:flex;gap:48px;padding:11px 24px;
  white-space:nowrap;
  animation:tk 60s linear infinite;
  color:var(--ink-2);
}
.ticker .track span{display:inline-flex;align-items:center;gap:10px;flex-shrink:0}
.ticker .track .dot{color:var(--flood);font-size:8px}
@keyframes tk{to{transform:translateX(-50%)}}

.scroll-prog{
  position:fixed;left:0;top:0;height:2px;width:0;
  background:var(--flood);z-index:150;
  transition:width .1s linear;
}

/* ============= 03 WRAP / MASTHEAD ============= */
.wrap{
  max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);
  position:relative;z-index:2;
}

.masthead{
  display:flex;align-items:center;justify-content:space-between;
  padding:28px 0 22px;border-bottom:1px solid var(--rule);
  margin-bottom:0;gap:24px;flex-wrap:wrap;
}
.masthead .left{display:flex;align-items:center;gap:18px}
.mast-mark{
  width:46px;height:46px;border:1px solid var(--ink);
  display:grid;place-items:center;
  font-family:'Instrument Serif',serif;font-size:34px;line-height:1;
  background:var(--ink);color:var(--paper);
  letter-spacing:-0.02em;
  position:relative;
}
.mast-mark::after{
  content:"";position:absolute;inset:-4px;border:1px solid var(--ink);
}
.mast-title{
  font-family:'Instrument Serif',serif;font-size:26px;line-height:1;
}
.mast-meta{
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--mute);
  display:flex;gap:14px;margin-top:6px;flex-wrap:wrap;
}
.mast-meta b{color:var(--ink);font-weight:500}
.mast-right{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

.btn-ghost{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;
  padding:11px 16px;
  border:1px solid var(--ink);color:var(--ink);
  background:transparent;
  border-radius:999px;
  transition:background .25s var(--ease), color .25s var(--ease), transform .15s var(--ease);
  position:relative;will-change:transform;
}
.btn-ghost svg{width:11px;height:11px}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.btn-ghost.solid{background:var(--ink);color:var(--paper)}
.btn-ghost.solid:hover{background:var(--flood);border-color:var(--flood)}
#themeBtn{padding-left:36px;position:relative}
#themeBtn::before{
  content:"";position:absolute;left:14px;top:50%;transform:translateY(-50%);
  width:10px;height:10px;border-radius:50%;
  background:var(--flood);
  box-shadow:0 0 10px var(--flood);
}
[data-theme="floodlights"] #themeBtn::before{background:var(--flood);box-shadow:0 0 16px var(--flood)}

/* ============= 04 COVER / HERO ============= */
.cover{
  position:relative;padding:72px 0 90px;
  border-bottom:1px solid var(--rule);
}
.cover::before,.cover::after{
  content:"";position:absolute;left:0;right:0;height:1px;background:var(--rule-soft);
}
.cover::before{top:14px}
.cover::after{top:24px}

.cover-grid{
  display:grid;grid-template-columns:1.45fr .55fr;gap:64px;align-items:end;
  position:relative;z-index:2;
}
.issue{
  display:flex;gap:14px;align-items:center;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--mute);margin-bottom:34px;flex-wrap:wrap;
}
.issue .pill{
  background:var(--ink);color:var(--paper);padding:6px 12px;border-radius:999px;
  letter-spacing:.2em;white-space:nowrap;
}
.issue span{white-space:nowrap}
.cover h1{
  font-family:'Instrument Serif',serif;font-weight:400;
  font-size:clamp(96px,15vw,232px);line-height:.84;letter-spacing:-0.045em;
  color:var(--ink);
  margin:0;
}
.cover h1 .amp{color:var(--flood)}
.sub-row{
  display:flex;justify-content:space-between;align-items:flex-end;gap:36px;
  margin-top:36px;flex-wrap:wrap;
}
.roles{display:flex;gap:8px;flex-wrap:wrap}
.role-chip{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;
  padding:9px 14px;border:1px solid var(--rule);border-radius:999px;
  color:var(--ink-2);white-space:nowrap;
}
.role-chip.solid{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.location{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--mute);
  text-align:right;line-height:1.7;
}
.location b{color:var(--ink);display:block;font-weight:500;letter-spacing:.18em}

.scrollcue{
  display:flex;align-items:center;gap:14px;
  margin-top:64px;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--mute);
}
.scrollcue .line{
  width:64px;height:1px;background:var(--ink);position:relative;
  animation:cue 1.8s ease-in-out infinite;
  transform-origin:left;
}
@keyframes cue{
  0%,100%{transform:scaleX(.4)}
  50%{transform:scaleX(1)}
}

/* Hero feature card */
.feature{
  background:var(--paper);
  border:1px solid var(--rule);
  border-radius:var(--r-md);
  padding:28px 28px 22px;position:relative;
  box-shadow:var(--shadow);
}
.feature .stamp{
  position:absolute;top:-12px;left:24px;
  background:var(--flood);color:#fff;
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;
  padding:5px 10px;text-transform:uppercase;border-radius:3px;
  transform:rotate(-2deg);
}
.feature h3{
  font-family:'Instrument Serif',serif;font-size:34px;line-height:1.05;
  letter-spacing:-0.015em;margin:8px 0 12px;
}
.feature h3 em{color:var(--flood)}
.feature p{font-size:14px;line-height:1.5;color:var(--ink-2);margin:0 0 18px}
.feature ul{display:grid;gap:0;border-top:1px solid var(--rule-soft)}
.feature li{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:10px 0;border-bottom:1px solid var(--rule-soft);
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.1em;
  text-transform:uppercase;
}
.feature li span{color:var(--mute)}
.feature li b{font-weight:500;color:var(--ink)}

/* Floating tickets (replaces polaroids) */
.tickets{
  position:absolute;inset:0;pointer-events:none;z-index:1;
}
.ticket{
  position:absolute;display:flex;background:var(--paper);
  border:1px solid var(--ink);
  border-radius:8px;
  box-shadow:0 24px 60px -20px rgba(20,17,10,.35), 0 0 0 1px rgba(20,17,10,.04);
  pointer-events:auto;
  font-family:'JetBrains Mono',monospace;
  --tk-rot:0deg;--tk-ty:60px;--tk-op:0;
  opacity:var(--tk-op);
  transform:translateY(var(--tk-ty)) rotate(var(--tk-rot)) scale(.95);
  transition:transform .9s var(--ease-out), opacity .7s var(--ease-out);
  will-change:transform,opacity;
  cursor:pointer;
}
.ticket.in{--tk-op:1;--tk-ty:0px;}
.ticket.in{transform:translateY(0) rotate(var(--tk-rot)) scale(1)}
.ticket:hover{transform:translateY(-6px) rotate(0deg) scale(1.02);z-index:5}

.ticket .tk-perf{
  width:18px;align-self:stretch;
  background:
    radial-gradient(circle at 50% 0,transparent 0 5px,var(--ink) 5px 6px,transparent 6px 12px),
    repeating-linear-gradient(0deg,var(--paper) 0 8px,transparent 8px 16px);
  background-size:18px 16px;
  border-right:1px dashed var(--ink);
  position:relative;
}
.ticket .tk-body{
  flex:1;padding:14px 14px 12px;display:flex;flex-direction:column;gap:6px;
  min-width:170px;
}
.tk-head{
  display:flex;justify-content:space-between;align-items:center;
  border-bottom:1px solid var(--rule);padding-bottom:7px;margin-bottom:4px;
}
.tk-event{
  font-family:'Instrument Serif',serif;font-size:18px;letter-spacing:-0.01em;
  color:var(--ink);font-style:normal;
}
.tk-stamp{
  font-size:8px;letter-spacing:.24em;text-transform:uppercase;
  border:1.5px solid var(--flood);color:var(--flood);
  padding:3px 7px;border-radius:3px;font-weight:600;
  transform:rotate(-4deg);
}
.tk-art{
  height:54px;border-radius:4px;margin:2px 0 4px;position:relative;overflow:hidden;
}
.tk-art-ipl{
  background:
    radial-gradient(60% 100% at 50% 0,rgba(255,181,71,.85),transparent 70%),
    linear-gradient(180deg,#3a1606 0%,#0a0408);
}
.tk-art-ipl::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(to bottom,transparent 65%,rgba(255,181,71,.18) 65%,rgba(255,181,71,.18) 66%,transparent 66%),
    repeating-linear-gradient(90deg,transparent 0 14px,rgba(255,255,255,.06) 14px 15px);
}
.tk-art-arch{
  background:
    repeating-radial-gradient(circle at 50% 50%,
      #fff8e1 0 6px,#f4d56e 6px 12px,#14110a 12px 18px,#d63919 18px 24px,#14110a 24px 30px);
}
.tk-art-som{
  background:
    radial-gradient(50% 90% at 50% 100%,rgba(255,181,71,.55),transparent 65%),
    linear-gradient(180deg,#3a1a08,#0a0502);
}
.tk-art-som::after{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 50% 75%,rgba(255,236,170,.35) 0 3px,transparent 3px),
    radial-gradient(circle at 30% 80%,rgba(255,236,170,.3) 0 2px,transparent 2px),
    radial-gradient(circle at 70% 80%,rgba(255,236,170,.3) 0 2px,transparent 2px),
    radial-gradient(circle at 15% 85%,rgba(255,236,170,.25) 0 2px,transparent 2px),
    radial-gradient(circle at 85% 85%,rgba(255,236,170,.25) 0 2px,transparent 2px);
}
.tk-row{
  display:flex;justify-content:space-between;align-items:baseline;
  font-size:9px;letter-spacing:.16em;text-transform:uppercase;line-height:1.3;
}
.tk-row span{color:var(--mute)}
.tk-row b{color:var(--ink);font-weight:500}
.tk-barcode{
  margin-top:6px;height:18px;
  background:repeating-linear-gradient(90deg,
    var(--ink) 0 1px, transparent 1px 3px,
    var(--ink) 3px 5px, transparent 5px 6px,
    var(--ink) 6px 7px, transparent 7px 11px);
}
.ticket .tk-stub{
  width:46px;background:var(--ink);color:var(--paper);
  border-radius:0 7px 7px 0;
  display:flex;flex-direction:column;align-items:center;justify-content:space-between;
  padding:12px 0;
  position:relative;
}
.tk-stub-no{
  font-family:'Instrument Serif',serif;font-size:26px;line-height:1;
  writing-mode:vertical-rl;transform:rotate(180deg);
}
.tk-stub-l{
  font-size:8px;letter-spacing:.24em;text-transform:uppercase;
  writing-mode:vertical-rl;transform:rotate(180deg);color:var(--flood);
}

.tk-1{top:14%;right:-30px;--tk-rot:7deg;width:230px}
.tk-2{top:48%;right:6%;--tk-rot:-8deg;width:215px}
.tk-3{top:78%;right:34%;--tk-rot:4deg;width:200px}

/* ============= 05 SECTION PRIMITIVES ============= */
.section{
  padding:88px 0;border-bottom:1px solid var(--rule);
  position:relative;
}
.section-tag{
  display:inline-flex;align-items:center;gap:12px;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--mute);
  padding-bottom:14px;margin-bottom:28px;
  border-bottom:1px solid var(--rule-soft);
  width:100%;
}
.section-tag .num{
  background:var(--ink);color:var(--paper);padding:5px 9px;letter-spacing:.18em;
  white-space:nowrap;
}
.section-h{
  font-family:'Instrument Serif',serif;font-weight:400;
  font-size:clamp(56px,8.2vw,124px);line-height:1.0;letter-spacing:-0.035em;
  margin:0 0 36px;color:var(--ink);
  padding-bottom:6px;
}
.section-h em{color:var(--flood);font-style:italic}
.section-lede{
  font-size:18px;line-height:1.5;color:var(--ink-2);max-width:62ch;
  margin:0;
}

/* ============= 06 MANIFESTO ============= */
.manifesto{
  display:grid;grid-template-columns:1.5fr .8fr;gap:64px;margin-top:48px;
  align-items:start;
}
.manifesto .body p{
  font-family:'Instrument Serif',serif;font-size:26px;line-height:1.38;
  letter-spacing:-0.005em;color:var(--ink);margin:0 0 22px;
}
.manifesto .hl{
  background:linear-gradient(transparent 60%, rgba(246,213,100,.55) 60%);
  padding:0 2px;
}
[data-theme="floodlights"] .manifesto .hl{
  background:linear-gradient(transparent 60%, rgba(255,181,71,.28) 60%);
}
.pullquote{
  border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);
  padding:24px 0 24px 36px;margin:30px 0;
  font-family:'Instrument Serif',serif;font-style:italic;
  font-size:32px;line-height:1.22;color:var(--ink);
  position:relative;
}
.pullquote::before{
  content:"\201C";position:absolute;left:-12px;top:6px;
  font-size:80px;line-height:1;color:var(--flood);
  font-family:'Instrument Serif',serif;
}
.pullquote cite{
  display:block;margin-top:14px;
  font-family:'JetBrains Mono',monospace;font-style:normal;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--mute);
}

.side{display:grid;gap:18px}

/* DOSSIER FOLDERS — tap to open */
.dossier{position:relative}
.doss-meta{
  display:flex;justify-content:space-between;align-items:baseline;
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--mute);
  padding-bottom:10px;border-bottom:1px solid var(--rule);margin-bottom:14px;
  gap:12px;flex-wrap:wrap;
}
.doss-meta .doss-instr{color:var(--flood)}
.folder{
  display:block;width:100%;
  background:var(--paper);
  border:1px solid var(--ink);
  border-radius:10px 10px 4px 4px;
  text-align:left;padding:0;overflow:hidden;
  box-shadow:0 8px 22px -16px rgba(20,17,10,.4);
  transition:transform .35s var(--ease-out), box-shadow .35s var(--ease);
  position:relative;
}
.folder:hover{transform:translateY(-2px);box-shadow:0 18px 36px -20px rgba(20,17,10,.4)}
.folder + .folder{margin-top:-8px}
.folder::before{
  content:"";position:absolute;top:0;left:14px;width:46px;height:8px;
  background:var(--ink);border-radius:6px 6px 0 0;transform:translateY(-8px);
}
.folder-tab{
  display:grid;grid-template-columns:auto 1fr auto auto;
  align-items:center;gap:12px;
  padding:14px 16px;
  background:linear-gradient(180deg,var(--paper) 0%, var(--paper-2) 100%);
  border-bottom:1px dashed var(--rule);
  transition:background .25s var(--ease);
}
.folder[aria-expanded="true"] .folder-tab{background:var(--ink);color:var(--paper);border-bottom-color:rgba(255,255,255,.18)}
.folder[aria-expanded="true"] .folder-tab .f-num,
.folder[aria-expanded="true"] .folder-tab .f-title{color:var(--paper)}
.f-num{
  font-family:'Instrument Serif',serif;font-size:28px;line-height:1;letter-spacing:-0.02em;
  color:var(--ink);min-width:34px;
}
.f-title{
  font-family:'Instrument Serif',serif;font-size:24px;letter-spacing:-0.015em;
  color:var(--ink);
}
.f-stamp{
  font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.22em;
  text-transform:uppercase;
  padding:4px 8px;border-radius:3px;
  background:var(--flood);color:#fff;
  transform:rotate(-3deg);
}
.f-stamp.doc{background:var(--ink);color:var(--paper)}
.f-stamp.ops{background:var(--gold);color:#1a1208}
.folder[aria-expanded="true"] .f-stamp{transform:rotate(0deg) scale(1.04)}
.f-chev{
  width:14px;height:14px;color:var(--mute);
  transition:transform .35s var(--ease-out);
}
.folder[aria-expanded="true"] .f-chev{transform:rotate(180deg);color:var(--paper)}

.folder-body{
  max-height:0;overflow:hidden;
  transition:max-height .55s var(--ease-out);
  background:
    repeating-linear-gradient(0deg, transparent 0 31px, var(--rule-soft) 31px 32px),
    var(--paper);
  position:relative;
}
.folder[aria-expanded="true"] .folder-body{max-height:300px}
.folder-body .row{
  display:flex;justify-content:space-between;align-items:baseline;gap:12px;
  padding:8px 16px;
  font-size:13px;
  border-bottom:1px dashed transparent;
}
.folder-body .row span:first-child{color:var(--ink);font-weight:500}
.folder-body .row span:last-child{
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--mute);text-align:right;
}
.folder-seal{
  position:absolute;top:10px;right:14px;
  font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.28em;
  text-transform:uppercase;color:var(--flood);
  border:1.5px solid var(--flood);padding:4px 8px;border-radius:3px;
  transform:rotate(-6deg);
  opacity:0;transition:opacity .35s var(--ease) .15s;
}
.folder[aria-expanded="true"] .folder-seal{opacity:1}
.folder-foot{
  display:flex;justify-content:space-between;align-items:center;
  padding:10px 16px;border-top:1px solid var(--rule);
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--mute);
}
.side-block{
  background:var(--paper);border:1px solid var(--rule);border-radius:var(--r-md);
  padding:18px 20px;box-shadow:var(--shadow);
}
.side-block h5{
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.26em;
  text-transform:uppercase;color:var(--mute);
  padding-bottom:10px;border-bottom:1px solid var(--rule-soft);margin-bottom:8px;
}
.side-block .row{
  display:flex;justify-content:space-between;align-items:baseline;gap:12px;
  padding:8px 0;border-bottom:1px dashed var(--rule-soft);
  font-size:13px;
}
.side-block .row:last-child{border-bottom:0}
.side-block .row span:first-child{color:var(--ink);font-weight:500}
.side-block .row span:last-child{
  font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:.1em;text-transform:uppercase;color:var(--mute);
  text-align:right;
}

/* ============= 07 STATS ============= */
.stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);
  margin-top:14px;
}
.stat{
  padding:38px 24px 32px;border-right:1px solid var(--rule);
  position:relative;
}
.stat:last-child{border-right:0}
.stat .num{
  font-family:'Instrument Serif',serif;font-size:clamp(80px,9.5vw,140px);
  line-height:.9;letter-spacing:-0.04em;color:var(--ink);
  font-variant-numeric:tabular-nums;
  display:flex;align-items:baseline;gap:4px;
}
.stat .num sup{font-size:.35em;color:var(--flood);font-style:italic}
.stat .label{
  margin-top:14px;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ink);font-weight:500;
}
.stat .sub{
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--mute);margin-top:4px;
}

/* ============= 08 PROJECT GRID — ENVIRONMENT DOSSIERS ============= */
.project-bar{
  display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:24px;
}
.project-grid{
  display:grid;grid-template-columns:repeat(12,1fr);gap:18px;margin-top:8px;
  perspective:1400px;
}

.proj{
  --bp:#0d2030;
  --bp-hi:#ffb547;
  position:relative;cursor:pointer;
  background:var(--paper);
  border:1px solid var(--ink);
  border-radius:14px;overflow:hidden;
  display:flex;flex-direction:column;
  min-height:420px;
  transition:transform .5s var(--ease-out), box-shadow .5s var(--ease-out);
  transform-style:preserve-3d;
  will-change:transform;
  box-shadow:0 8px 30px -20px rgba(20,17,10,.25);
}
.proj:hover{
  box-shadow:0 40px 80px -30px rgba(20,17,10,.4), 0 0 0 1px var(--ink);
}

/* Top strip (boarding-pass header) */
.proj-top{
  display:flex;justify-content:space-between;align-items:center;
  padding:11px 16px;background:var(--ink);color:var(--paper);
  border-bottom:1px dashed var(--mute-2);
  position:relative;z-index:3;
}
.proj-top::before,.proj-top::after{
  content:"";position:absolute;width:14px;height:14px;border-radius:50%;
  background:var(--bg);bottom:-7px;
  border:1px solid var(--ink);
}
.proj-top::before{left:-8px}
.proj-top::after{right:-8px}
.proj-gate{
  display:flex;align-items:center;gap:8px;
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.26em;
  text-transform:uppercase;font-weight:500;
}
.proj-gate i{
  width:7px;height:7px;border-radius:50%;background:var(--flood);
  box-shadow:0 0 0 0 var(--flood);animation:pulse 1.6s infinite;flex-shrink:0;
}
.proj-stamp{
  font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.28em;
  text-transform:uppercase;font-weight:600;
  padding:4px 9px;border-radius:3px;
  border:1.5px solid var(--flood);color:var(--flood);background:transparent;
  transform:rotate(-3deg);
}
.proj-stamp.st-live{border-color:var(--flood);color:#fff;background:var(--flood)}
.proj-stamp.st-marquee{border-color:#ffb547;color:#ffb547}
.proj-stamp.st-policy{border-color:#5dc7d7;color:#5dc7d7}
.proj-stamp.st-ship{border-color:#7ed99c;color:#7ed99c}
.proj-stamp.st-q{border-color:var(--paper-2);color:var(--paper-2)}
.proj-stamp.st-pm{border-color:#ffd76b;color:#ffd76b;background:rgba(255,215,107,.08)}

/* Blueprint art window */
.proj-blueprint{
  position:relative;flex:1;
  background:
    radial-gradient(70% 100% at 50% 0%, color-mix(in oklch, var(--bp) 85%, #fff 12%), var(--bp) 60%) ,
    var(--bp);
  color:rgba(255,255,255,.78);
  overflow:hidden;
  border-bottom:1px solid var(--ink);
  min-height:200px;
  transform:translateZ(0);
}
.proj[data-bp="gms"]    .proj-blueprint{--bp:#1a1410}
.proj[data-bp="sajha"]  .proj-blueprint{--bp:#0e3525}
.proj[data-bp="ipl"]    .proj-blueprint{--bp:#1a2a3a}
.proj[data-bp="ng"]     .proj-blueprint{--bp:#0a283d}
.proj[data-bp="archery"].proj-blueprint{--bp:#191510}
.proj[data-bp="somnath"].proj-blueprint{--bp:#2a1408}

.bp-svg{
  position:absolute;inset:0;width:100%;height:100%;
  color:rgba(255,236,200,.85);
  transition:transform .6s var(--ease-out);
}
.proj:hover .bp-svg{transform:scale(1.04)}
.bp-svg text{
  font-family:'JetBrains Mono',monospace;font-size:8px;letter-spacing:.18em;
  fill:rgba(255,236,200,.55);text-transform:uppercase;
}
.bp-lab{fill:rgba(255,236,200,.55)}

/* Blueprint nodes - GMS */
.bp-node{fill:rgba(255,255,255,.06);stroke:currentColor;stroke-width:1}
.bp-node.hub{fill:var(--flood);stroke:var(--flood)}
.bp-node.hub + .bp-text{fill:#fff;font-family:'Instrument Serif',serif;font-size:14px;letter-spacing:-0.01em}
.proj[data-bp="gms"]:hover .bp-node:not(.hub){
  animation:nodePulse 1.4s ease-in-out infinite;
}
.bp-node.n-a{animation-delay:0s}
.bp-node.n-b{animation-delay:.2s}
.bp-node.n-c{animation-delay:.4s}
.bp-node.n-d{animation-delay:.6s}
.bp-node.n-e{animation-delay:.8s}
.bp-node.n-f{animation-delay:1s}
@keyframes nodePulse{
  0%,100%{fill:rgba(255,255,255,.06)}
  50%{fill:rgba(214,57,25,.4)}
}

/* SAJHA */
.bp-cap{fill:var(--flood)}
.bp-cap-ring{fill:none;stroke:var(--flood);stroke-width:1}
.proj[data-bp="sajha"]:hover .bp-cap-ring{animation:capPulse 1.6s ease-out infinite}
@keyframes capPulse{
  0%{r:9;opacity:1}
  100%{r:30;opacity:0}
}
.bp-dot{fill:rgba(255,236,200,.5)}
.proj[data-bp="sajha"]:hover .bp-state{stroke:var(--flood);fill:rgba(214,57,25,.12)}

/* IPL */
.bp-oval,.bp-30y{stroke:rgba(255,236,200,.7)}
.proj[data-bp="ipl"]:hover .bp-oval{stroke:#7ed99c;fill:rgba(126,217,156,.08)}
.bp-fielders circle{fill:rgba(255,255,255,.9)}
.proj[data-bp="ipl"]:hover .bp-fielders circle{
  animation:fldGlow 1.4s ease-in-out infinite;
}
.bp-fielders circle:nth-child(1){animation-delay:0s}
.bp-fielders circle:nth-child(2){animation-delay:.1s}
.bp-fielders circle:nth-child(3){animation-delay:.2s}
.bp-fielders circle:nth-child(4){animation-delay:.3s}
.bp-fielders circle:nth-child(5){animation-delay:.4s}
.bp-fielders circle:nth-child(6){animation-delay:.5s}
.bp-fielders circle:nth-child(7){animation-delay:.6s}
.bp-fielders circle:nth-child(8){animation-delay:.7s}
.bp-fielders circle:nth-child(9){animation-delay:.8s}
.bp-fielders circle:nth-child(10){animation-delay:.9s}
.bp-fielders circle:nth-child(11){animation-delay:1s}
@keyframes fldGlow{
  0%,100%{filter:drop-shadow(0 0 0 var(--flood))}
  50%{filter:drop-shadow(0 0 4px #ffb547)}
}
.bp-pyl{fill:var(--flood)}

/* NG */
.bp-arena{fill:rgba(214,57,25,.08);stroke:rgba(255,236,200,.7)}
.proj[data-bp="ng"]:hover .bp-arena{animation:arenaLit 2.4s ease-in-out infinite}
.bp-arena.n-1{animation-delay:0s}
.bp-arena.n-2{animation-delay:.3s}
.bp-arena.n-3{animation-delay:.6s}
.bp-arena.n-4{animation-delay:.9s}
.bp-arena.n-5{animation-delay:1.2s}
.bp-arena.n-6{animation-delay:1.5s}
@keyframes arenaLit{
  0%,100%{fill:rgba(214,57,25,.08);stroke:rgba(255,236,200,.7)}
  50%{fill:rgba(255,181,71,.35);stroke:#ffb547;filter:drop-shadow(0 0 6px rgba(255,181,71,.6))}
}

/* Archery */
.bp-target{transform-origin:center;transform-box:fill-box}
.proj[data-bp="archery"]:hover .bp-target:nth-child(2){animation:tgtHit 1.6s ease-out infinite}
@keyframes tgtHit{
  0%,80%,100%{transform:scale(1)}
  85%{transform:scale(1.18)}
}
.proj[data-bp="archery"]:hover .bp-arrow{
  animation:arrowFly 1.6s ease-out infinite;
}
@keyframes arrowFly{
  0%{stroke-dashoffset:200;d:path("M48 90 L180 90")}
  60%{stroke-dashoffset:0}
  100%{stroke-dashoffset:0;opacity:0}
}

/* Somnath */
.bp-ring{transform-origin:200px 120px;transform-box:view-box}
.proj[data-bp="somnath"]:hover .r-outer{animation:ringSpin 12s linear infinite}
.proj[data-bp="somnath"]:hover .r-mid{animation:ringSpin 8s linear infinite reverse}
@keyframes ringSpin{to{transform:rotate(360deg)}}
.diya{fill:rgba(255,200,120,.4)}
.proj[data-bp="somnath"]:hover .diya{
  animation:diyaFlame 1.8s ease-in-out infinite;
  fill:#ffd76b;
  filter:drop-shadow(0 0 4px #ffb547);
}
.bp-diyas circle:nth-child(1){animation-delay:0s}
.bp-diyas circle:nth-child(2){animation-delay:.3s}
.bp-diyas circle:nth-child(3){animation-delay:.5s}
.bp-diyas circle:nth-child(4){animation-delay:.8s}
.bp-diyas circle:nth-child(5){animation-delay:1.1s}
.bp-diyas circle:nth-child(6){animation-delay:1.4s}
@keyframes diyaFlame{
  0%,100%{opacity:.4}
  50%{opacity:1;filter:drop-shadow(0 0 6px #ffb547)}
}

/* Floodlight sweep on hover */
.bp-sweep{
  position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(120deg, transparent 0%, transparent 30%, rgba(255,181,71,.18) 45%, rgba(255,181,71,.3) 50%, rgba(255,181,71,.18) 55%, transparent 70%, transparent 100%);
  background-size:300% 100%;background-position:200% 0;
  mix-blend-mode:screen;
  transition:background-position 1.4s var(--ease-out);
}
.proj:hover .bp-sweep{background-position:-50% 0}

.bp-meta{
  position:absolute;left:14px;bottom:10px;
  font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.22em;
  text-transform:uppercase;color:rgba(255,236,200,.45);
  z-index:2;
}
.proj-blueprint::after{
  /* corner registration marks */
  content:"";position:absolute;inset:8px;pointer-events:none;
  background:
    linear-gradient(to right,rgba(255,236,200,.4) 0 10px,transparent 10px) 0 0/100% 1px no-repeat,
    linear-gradient(to bottom,rgba(255,236,200,.4) 0 10px,transparent 10px) 0 0/1px 100% no-repeat,
    linear-gradient(to left,rgba(255,236,200,.4) 0 10px,transparent 10px) 100% 0/100% 1px no-repeat,
    linear-gradient(to bottom,rgba(255,236,200,.4) 0 10px,transparent 10px) 100% 0/1px 100% no-repeat,
    linear-gradient(to right,rgba(255,236,200,.4) 0 10px,transparent 10px) 0 100%/100% 1px no-repeat,
    linear-gradient(to top,rgba(255,236,200,.4) 0 10px,transparent 10px) 0 100%/1px 100% no-repeat,
    linear-gradient(to left,rgba(255,236,200,.4) 0 10px,transparent 10px) 100% 100%/100% 1px no-repeat,
    linear-gradient(to top,rgba(255,236,200,.4) 0 10px,transparent 10px) 100% 100%/1px 100% no-repeat;
}

/* Signage panel (bottom) */
.proj-sign{
  padding:18px 22px 22px;background:var(--paper);
  display:flex;flex-direction:column;gap:12px;
  position:relative;z-index:2;
}
.prs-row{
  display:flex;justify-content:space-between;align-items:baseline;gap:10px;
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--mute);
  padding-bottom:8px;border-bottom:1px solid var(--rule-soft);
}
.prs-client{color:var(--ink);font-weight:500}
.prs-title{
  font-family:'Instrument Serif',serif;font-weight:400;
  font-size:42px;line-height:.96;letter-spacing:-0.025em;
  color:var(--ink);margin:2px 0 0;
}
.prs-title em{color:var(--flood);font-style:italic}
.prs-title sup{font-size:.55em;color:var(--flood);font-style:italic}

/* LCD-style KPI readouts */
.prs-kpi{
  display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:6px;
}
.prs-kpi > div{
  background:var(--ink);color:var(--paper);padding:9px 10px;border-radius:5px;
  display:flex;flex-direction:column;gap:2px;
  position:relative;overflow:hidden;
  border:1px solid var(--ink);
}
.prs-kpi > div::before{
  content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(0deg,transparent 0 2px,rgba(255,255,255,.03) 2px 3px);
  pointer-events:none;
}
.prs-kpi b{
  font-family:'Instrument Serif',serif;font-size:22px;line-height:1;
  letter-spacing:-0.01em;color:var(--flood);font-weight:400;
}
.prs-kpi b sup{font-size:.55em;color:var(--flood)}
.prs-kpi span{
  font-family:'JetBrains Mono',monospace;font-size:8px;letter-spacing:.22em;
  text-transform:uppercase;color:rgba(241,232,208,.6);
}

.prs-foot{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:12px;border-top:1px dashed var(--rule-soft);
}
.prs-status{
  display:inline-flex;align-items:center;gap:7px;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ink);
}
.prs-status i{
  width:8px;height:8px;border-radius:50%;background:var(--mute-2);
}
.prs-status.on i{background:var(--flood);box-shadow:0 0 0 0 var(--flood);animation:pulse 1.6s infinite}
.prs-status.soon i{background:#ffb547;box-shadow:0 0 0 2px rgba(255,181,71,.22)}
.prs-status.archive i{background:var(--mute-2)}
.prs-cta{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;font-weight:600;color:var(--flood);
  transition:gap .25s var(--ease);
}
.prs-cta svg{width:12px;height:12px;transition:transform .25s var(--ease)}
.proj:hover .prs-cta{gap:14px}
.proj:hover .prs-cta svg{transform:translateX(2px)}

/* Active broadcast indicator on Live project */
.proj[data-key="gms"]::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,transparent,var(--flood),transparent);
  background-size:50% 100%;
  animation:liveSlide 3s linear infinite;
  z-index:4;
}
@keyframes liveSlide{
  0%{background-position:-50% 0}
  100%{background-position:150% 0}
}

/* Theme: floodlights */
[data-theme="floodlights"] .proj{background:var(--paper);border-color:var(--flood)}
[data-theme="floodlights"] .proj-top::before,
[data-theme="floodlights"] .proj-top::after{background:var(--bg)}
[data-theme="floodlights"] .prs-kpi > div{background:#1d180e}

/* Responsive */
@media (max-width:1100px){
  .project-grid{grid-template-columns:repeat(6,1fr)}
  .proj[style*="span 7"],.proj[style*="span 5"]{grid-column:span 6 !important}
  .proj{min-height:380px}
}
@media (max-width:680px){
  .project-grid{grid-template-columns:1fr}
  .prs-title{font-size:32px}
  .prs-kpi{grid-template-columns:repeat(2,1fr)}
}

/* ============= 09 CAREER DECK ============= */
.deck-wrap{margin-top:28px}

/* --- Broadcast strip (top) --- */
.tape-bcast{
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:18px;
  background:var(--ink);color:var(--paper);
  padding:11px 18px;border-radius:10px 10px 0 0;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;
  position:relative;overflow:hidden;
}
.tape-bcast::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(60% 100% at 0% 50%,rgba(214,57,25,.18),transparent 60%);
}
.tb-left{display:flex;align-items:center;gap:10px;position:relative}
.tb-rec{
  width:9px;height:9px;border-radius:50%;background:var(--flood);
  box-shadow:0 0 0 0 var(--flood);animation:pulse 1.6s infinite;
}
.tb-tag{color:var(--flood);font-weight:600;letter-spacing:.32em}
.tb-now{color:rgba(241,232,208,.7)}
.tb-now .deck-now-emp{color:var(--paper);font-weight:600}
.tb-vu{
  display:flex;align-items:flex-end;justify-content:center;gap:3px;height:24px;
  position:relative;
}
.tb-vu i{
  display:block;width:4px;height:6px;background:var(--paper);opacity:.25;
  border-radius:1px;animation:vu 1.1s ease-in-out infinite;
}
.tb-vu i:nth-child(1){animation-delay:-0.0s;height:6px}
.tb-vu i:nth-child(2){animation-delay:-0.15s;height:10px}
.tb-vu i:nth-child(3){animation-delay:-0.3s;height:14px}
.tb-vu i:nth-child(4){animation-delay:-0.45s;height:18px}
.tb-vu i:nth-child(5){animation-delay:-0.6s;height:22px;background:var(--flood);opacity:.8}
.tb-vu i:nth-child(6){animation-delay:-0.75s;height:24px;background:var(--flood);opacity:.9}
.tb-vu i:nth-child(7){animation-delay:-0.9s;height:24px;background:var(--flood);opacity:.9}
.tb-vu i:nth-child(8){animation-delay:-1.05s;height:22px;background:var(--flood);opacity:.8}
.tb-vu i:nth-child(9){animation-delay:-1.2s;height:18px}
.tb-vu i:nth-child(10){animation-delay:-1.35s;height:14px}
.tb-vu i:nth-child(11){animation-delay:-1.5s;height:10px}
.tb-vu i:nth-child(12){animation-delay:-1.65s;height:6px}
@keyframes vu{0%,100%{transform:scaleY(.3);opacity:.3}50%{transform:scaleY(1);opacity:1}}
.tb-right{display:flex;align-items:center;gap:14px;color:rgba(241,232,208,.65)}
.tb-side{padding:4px 9px;background:rgba(255,255,255,.06);border-radius:3px;color:var(--paper)}
.tb-tc{color:var(--flood);font-variant-numeric:tabular-nums;letter-spacing:.16em}

/* --- Year scrubber --- */
.tape-scrub{
  background:var(--paper);border:1px solid var(--rule);border-top:0;
  border-radius:0 0 10px 10px;
  padding:14px 22px 12px;margin-bottom:22px;
  box-shadow:var(--shadow);
}
.ts-track{
  position:relative;height:14px;display:flex;align-items:center;
}
.ts-track::before{
  content:"";position:absolute;left:0;right:0;top:50%;height:2px;
  background:var(--rule);transform:translateY(-1px);
}
.ts-fill{
  position:absolute;left:0;top:50%;height:2px;
  background:var(--flood);width:0;transform:translateY(-1px);
  transition:width .5s var(--ease-out);
}
.ts-dots{
  position:relative;width:100%;display:flex;justify-content:space-between;
}
.ts-dots button{
  width:14px;height:14px;border-radius:50%;background:var(--paper);
  border:2px solid var(--rule);
  transition:all .3s var(--ease);
  position:relative;
  z-index:2;
}
.ts-dots button.done{border-color:var(--flood);background:var(--flood)}
.ts-dots button.on{
  background:var(--flood);border-color:var(--flood);
  transform:scale(1.4);
  box-shadow:0 0 0 4px rgba(214,57,25,.18);
}
.ts-years{
  display:flex;justify-content:space-between;margin-top:8px;
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;
  color:var(--mute);
}

/* --- Main layout: stage + bside --- */
.tape-main{
  display:grid;grid-template-columns:1.35fr 1fr;gap:26px;align-items:start;
}
.tape-left{position:relative}

.deck-stage{
  position:relative;height:540px;perspective:1600px;
  margin:0;
  overflow:visible;
}

.deck-dots{display:flex;gap:6px;justify-content:center;margin-top:18px}
.deck-dots button{
  width:24px;height:3px;background:var(--rule);transition:all .3s var(--ease);
  border-radius:0;
}
.deck-dots button.on{background:var(--ink);width:48px}

/* --- B-side panel --- */
.tape-bside{
  display:grid;gap:14px;
}
.bs-card{
  background:var(--paper);border:1px solid var(--rule);border-radius:12px;
  padding:14px 16px 12px;box-shadow:var(--shadow);
}
.bs-h{
  display:flex;justify-content:space-between;align-items:baseline;gap:10px;
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ink);
  padding-bottom:10px;margin-bottom:12px;border-bottom:1px solid var(--rule-soft);
}
.bs-h .bs-meta{color:var(--mute);font-weight:400}
.bs-foot{
  display:flex;justify-content:space-between;align-items:center;
  margin-top:10px;padding-top:10px;border-top:1px dashed var(--rule-soft);
  font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--mute);
}

/* Reels */
.bs-reels .reel-rig{
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:6px;
  padding:4px 0 8px;
}
.reel{position:relative;color:var(--ink)}
.reel svg{width:100%;height:auto;max-width:100px;margin:auto;display:block}
.reel-spokes{transform-origin:50% 50%;animation:reelSpin 4s linear infinite}
.bs-reels.paused .reel-spokes{animation-play-state:paused}
.reel.right .reel-spokes{animation-duration:5s}
@keyframes reelSpin{to{transform:rotate(360deg)}}
.reel-tape{
  flex:1;height:8px;background:
    linear-gradient(180deg,transparent 0 2px,var(--ink) 2px 6px,transparent 6px 8px);
  position:relative;border-radius:2px;
}
[data-theme="floodlights"] .reel-tape{
  background:linear-gradient(180deg,transparent 0 2px,var(--flood) 2px 6px,transparent 6px 8px);
}
.bs-tape-id{color:var(--ink);font-weight:500;letter-spacing:.24em}

/* India map */
.bs-map .map-wrap{
  position:relative;display:flex;justify-content:center;padding:4px 0;
}
.india-map{width:130px;height:auto;color:var(--ink)}
.map-dots{position:absolute;inset:0}
.md{
  position:absolute;display:flex;align-items:center;gap:4px;
  font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--mute-2);
  transform:translate(-50%,-50%);
  transition:all .35s var(--ease-out);
  opacity:.45;
}
.md i{
  width:6px;height:6px;border-radius:50%;background:var(--mute-2);
  flex-shrink:0;transition:all .3s var(--ease);
}
.md b{display:none;font-weight:500;color:var(--ink)}
.md.on{opacity:1;color:var(--ink);z-index:3}
.md.on i{
  background:var(--flood);transform:scale(1.6);
  box-shadow:0 0 0 4px rgba(214,57,25,.2), 0 0 0 8px rgba(214,57,25,.08);
  animation:pulseDot 1.6s infinite;
}
.md.on b{display:inline-block;background:var(--ink);color:var(--paper);padding:2px 6px;border-radius:3px;font-size:8px}
@keyframes pulseDot{
  0%,100%{box-shadow:0 0 0 4px rgba(214,57,25,.2),0 0 0 8px rgba(214,57,25,.08)}
  50%{box-shadow:0 0 0 6px rgba(214,57,25,.28),0 0 0 12px rgba(214,57,25,.04)}
}
.bs-coord{color:var(--mute);letter-spacing:.16em}
.bs-loc-name{color:var(--ink);font-weight:500;letter-spacing:.18em}

/* Trajectory */
.bs-traj .traj{
  width:100%;height:90px;display:block;
}
.bs-traj .traj-pts circle{fill:var(--flood)}
.bs-traj .traj-pts circle.cur{
  fill:var(--flood);stroke:var(--paper);stroke-width:2;
  filter:drop-shadow(0 0 4px var(--flood));
}
.traj-axis{
  display:flex;justify-content:space-between;margin-top:6px;
  font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.18em;
  color:var(--mute);
}

/* Metadata */
.bs-status-pill{
  background:var(--flood);color:#fff;padding:3px 8px;border-radius:3px;
  letter-spacing:.22em;font-weight:600;
}
.bs-status-pill.off{background:var(--mute-2);color:var(--paper)}
.meta-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
}
.meta-grid > div{
  border:1px solid var(--rule-soft);border-radius:6px;padding:8px 10px;
  background:var(--paper-2);
}
.meta-grid .mk{
  display:block;
  font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--mute);margin-bottom:2px;
}
.meta-grid .mv{
  font-family:'Instrument Serif',serif;font-size:18px;line-height:1;
  letter-spacing:-0.01em;color:var(--ink);
}

/* --- Filmstrip --- */
.tape-film{
  margin:24px 0 0;
  background:var(--ink);
  border-radius:6px;
  padding:6px 0;position:relative;
}
.film-perf{
  height:14px;background:
    radial-gradient(circle at 14px 50%,transparent 0 4px,var(--ink) 4px 5px,transparent 5px 14px) 0 0/28px 14px,
    var(--ink);
}
.film-perf::before{
  content:"";display:block;height:14px;
  background:repeating-linear-gradient(90deg,var(--paper) 0 8px,transparent 8px 28px);
}
.film-perf{
  background:repeating-linear-gradient(90deg,transparent 0 8px,var(--paper) 8px 18px,transparent 18px 28px) center/auto 7px no-repeat,
             var(--ink);
}
.film-frames{
  display:grid;grid-template-columns:repeat(6,1fr);gap:2px;
  background:var(--ink);padding:4px 6px;
}
.film-frames .frame{
  position:relative;height:84px;cursor:pointer;overflow:hidden;
  background:var(--paper-2);
  border:1px solid transparent;
  transition:all .3s var(--ease-out);
}
.film-frames .frame::before{
  content:"";position:absolute;inset:0;background-size:cover;background-position:center;
  transition:transform .5s var(--ease-out);
}
.film-frames .frame:hover::before{transform:scale(1.08)}
.film-frames .frame.on{border-color:var(--flood)}
.film-frames .frame.on::after{
  content:"";position:absolute;inset:0;border:2px solid var(--flood);
  box-shadow:inset 0 0 0 2px var(--ink);pointer-events:none;
}
.film-frames .frame .fm-no{
  position:absolute;top:6px;left:7px;
  font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.18em;
  color:#fff;background:rgba(0,0,0,.55);padding:2px 5px;border-radius:2px;
  z-index:2;
}
.film-frames .frame .fm-t{
  position:absolute;bottom:6px;left:7px;right:7px;
  font-family:'Instrument Serif',serif;font-size:13px;line-height:1.05;
  color:#fff;z-index:2;letter-spacing:-0.01em;
  text-shadow:0 1px 4px rgba(0,0,0,.5);
}

/* --- Transport controls --- */
.tape-ctrls{
  display:flex;align-items:center;gap:14px;
  margin-top:22px;padding:14px 18px;
  background:var(--paper);border:1px solid var(--rule);border-radius:10px;
  box-shadow:var(--shadow);flex-wrap:wrap;
}
.deck-btn{
  width:42px;height:42px;border:1px solid var(--ink);border-radius:50%;
  display:grid;place-items:center;transition:all .25s var(--ease);
  flex-shrink:0;
}
.deck-btn svg{width:13px;height:13px}
.deck-btn:hover{background:var(--ink);color:var(--paper)}
.deck-play{background:var(--flood);color:#fff;border-color:var(--flood)}
.deck-play:hover{background:var(--flood-deep);border-color:var(--flood-deep)}
.deck-counter{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;
}
.deck-counter b{font-size:18px;font-weight:600;letter-spacing:.1em}
.deck-counter sub{font-size:11px;color:var(--mute);margin-left:2px}
.deck-hint{
  margin-left:auto;
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--mute);
}
.deck-hint kbd{
  display:inline-block;padding:2px 6px;margin:0 2px;
  border:1px solid var(--rule);border-radius:3px;font-size:10px;
  background:var(--paper-2);
}

/* shrink card a touch to fit left column */
.deck-card{
  position:absolute;left:50%;top:50%;
  width:min(560px,86%);height:480px;
  margin-left:calc(min(560px,86%) / -2);margin-top:-240px;
  background:var(--paper);
  border:1px solid var(--rule);
  border-radius:var(--r-lg);
  padding:0;
  box-shadow:var(--shadow-2);
  transition:transform .6s var(--ease-out), opacity .5s var(--ease), filter .5s var(--ease);
  cursor:grab;user-select:none;
  display:flex;flex-direction:column;
  will-change:transform;
  overflow:hidden;
}
.deck-card.drag{cursor:grabbing;transition:none}
.dc-pts{display:none}  /* legacy hidden */

@media (max-width:1100px){
  .tape-main{grid-template-columns:1fr;gap:18px}
  .tape-bside{grid-template-columns:1fr 1fr;display:grid}
  .bs-reels,.bs-meta-card{grid-column:span 2}
}
@media (max-width:680px){
  .tape-bside{grid-template-columns:1fr}
  .bs-reels,.bs-meta-card,.bs-map,.bs-traj{grid-column:span 1}
  .tape-bcast{grid-template-columns:1fr;gap:10px}
  .tb-vu{justify-content:flex-start}
  .deck-stage{height:580px}
  .film-frames{grid-template-columns:repeat(3,1fr)}
  .deck-hint{display:none}
}

/* ============= 10 TOOLKIT ============= */
.toolkit{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--rule);border:1px solid var(--rule);
  margin-top:32px;
}
.tk-group{background:var(--paper);padding:28px 26px}
.tk-group h5{
  display:flex;align-items:center;gap:12px;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ink);
  padding-bottom:16px;margin-bottom:18px;
  border-bottom:1px solid var(--rule-soft);
}
.tk-group .ic{
  width:28px;height:28px;display:grid;place-items:center;
  border:1px solid var(--ink);
  color:var(--ink);
}
.tk-group .ic svg{width:14px;height:14px}
.tk-list{display:flex;flex-wrap:wrap;gap:8px}
.tk-list span{
  font-size:13px;padding:7px 12px;border-radius:999px;
  background:var(--bg);color:var(--ink-2);
  border:1px solid var(--rule-soft);
  white-space:nowrap;
}
.tk-list span.star{
  background:var(--ink);color:var(--paper);border-color:var(--ink);
  font-weight:500;
}
.tk-list span.star::before{content:"★ ";color:var(--flood)}
[data-theme="floodlights"] .tk-list span{background:var(--bg-deep)}
[data-theme="floodlights"] .tk-list span.star{background:var(--flood);color:var(--bg);border-color:var(--flood)}
[data-theme="floodlights"] .tk-list span.star::before{content:"★ ";color:var(--bg)}

/* ============= 11 CONTACT + PASS ============= */
.contact{
  display:grid;grid-template-columns:1.1fr .9fr;gap:64px;
  padding:96px 0;border-bottom:1px solid var(--rule);
  align-items:center;
}
.contact h2{
  font-family:'Instrument Serif',serif;font-weight:400;
  font-size:clamp(56px,7.5vw,108px);line-height:.92;letter-spacing:-0.035em;
  margin:14px 0 18px;
}
.contact h2 em{color:var(--flood);font-style:italic}
.contact .lede{font-size:18px;line-height:1.5;color:var(--ink-2);max-width:48ch;margin:0 0 28px}
.contact-links{display:grid;gap:0;border-top:1px solid var(--rule)}
.c-link{
  display:flex;justify-content:space-between;align-items:center;
  padding:18px 0;border-bottom:1px solid var(--rule);
  position:relative;transition:padding-left .35s var(--ease);
}
.c-link::before{
  content:"";position:absolute;left:0;top:50%;width:0;height:1px;
  background:var(--flood);transition:width .35s var(--ease);
}
.c-link:hover{padding-left:24px}
.c-link:hover::before{width:14px}
.c-link span{
  font-family:'Instrument Serif',serif;font-size:24px;letter-spacing:-0.01em;
}
.c-link small{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--mute);transition:color .25s var(--ease);
}
.c-link:hover small{color:var(--flood)}

/* The accreditation pass */
.pass-stage{
  perspective:1800px;display:grid;place-items:center;
  position:relative;padding:32px 0;
}
.pass-stage::before{
  content:"";position:absolute;top:-6px;left:50%;width:2px;height:60px;
  background:var(--ink);
}
.pass-stage::after{
  content:"";position:absolute;top:54px;left:50%;width:12px;height:12px;
  background:var(--paper);border:1px solid var(--ink);border-radius:50%;
  transform:translateX(-50%);
}
.pass{
  width:360px;height:540px;position:relative;
  transform-style:preserve-3d;
  transition:transform 1s var(--ease-out);
  margin-top:90px;
  cursor:pointer;
  transform:rotateY(0) rotate(-3deg);
}
.pass.flipped{transform:rotateY(180deg) rotate(3deg)}
.pass:hover{transform:rotateY(0) rotate(-1deg) translateY(-4px)}
.pass.flipped:hover{transform:rotateY(180deg) rotate(1deg) translateY(-4px)}

.pass-face{
  position:absolute;inset:0;
  background:var(--paper);
  border:1px solid var(--ink);
  border-radius:var(--r-md);
  padding:24px 24px;
  box-shadow:0 30px 60px -20px rgba(0,0,0,.35), 0 0 0 1px rgba(0,0,0,.05);
  backface-visibility:hidden;-webkit-backface-visibility:hidden;
  display:flex;flex-direction:column;
}
.pass-back{transform:rotateY(180deg)}
.pass .punch{
  position:absolute;top:18px;left:50%;transform:translateX(-50%);
  width:42px;height:14px;
  background:var(--ink);border-radius:8px;
  box-shadow:inset 0 0 0 3px var(--paper);
}
.pf-head{
  margin-top:28px;text-align:center;
  padding-bottom:18px;border-bottom:1px dashed var(--ink);
}
.pf-head .ev{
  font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.3em;
  text-transform:uppercase;color:var(--mute);display:block;
}
.pf-head .title{
  font-family:'Instrument Serif',serif;font-size:36px;line-height:1;
  letter-spacing:-0.02em;display:block;margin:8px 0 4px;
}
.pf-head .title em{color:var(--flood)}
.pf-head .lvl{
  display:inline-block;margin-top:8px;
  background:var(--flood);color:#fff;padding:4px 12px;border-radius:3px;
  font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.28em;
  text-transform:uppercase;
}
.pass .photo{
  margin:18px auto 14px;width:120px;height:140px;
  background:
    radial-gradient(50% 40% at 50% 32%,#f0c89a,#9c6a40 70%,#3e2615),
    linear-gradient(180deg,#3e2615,#1a0e08);
  border:1px solid var(--ink);
  position:relative;
}
.pass .photo::after{
  content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(0deg,transparent 0 3px,rgba(0,0,0,.04) 3px 4px);
}
.pass .name{
  text-align:center;
  font-family:'Instrument Serif',serif;font-size:28px;line-height:1;
  letter-spacing:-0.015em;
}
.pass .name em{color:var(--flood)}
.pass .role{
  text-align:center;
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.24em;
  text-transform:uppercase;color:var(--mute);margin-top:8px;
}
.pass .zones{
  display:grid;grid-template-columns:repeat(5,1fr);gap:5px;margin-top:18px;
}
.pass .zones span{
  text-align:center;padding:6px 0;
  font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.2em;
  text-transform:uppercase;
  background:var(--ink);color:var(--paper);border-radius:3px;
}
.pass .zones .no{
  background:transparent;color:var(--mute);border:1px solid var(--rule);
  text-decoration:line-through;
}
.pass .footstrip{
  margin-top:auto;
  padding-top:14px;border-top:1px solid var(--ink);
  display:flex;justify-content:space-between;
  font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--mute);
}

/* Back of pass */
.bk-h{
  margin-top:28px;
  text-align:center;
  font-family:'Instrument Serif',serif;font-size:24px;
  padding-bottom:12px;border-bottom:1px dashed var(--ink);
}
.bk-list{
  font-family:'JetBrains Mono',monospace;font-size:10px;line-height:1.6;
  letter-spacing:.04em;color:var(--ink-2);
  padding:16px 0;display:grid;gap:8px;
}
.bk-list b{
  display:block;color:var(--flood);
  letter-spacing:.18em;text-transform:uppercase;font-size:9px;
  margin-top:4px;
}
.bk-code{
  text-align:center;font-family:'JetBrains Mono',monospace;
  font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--ink);
  padding:8px 0;border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);
}
.barcode{
  margin:14px 0;height:38px;
  background:repeating-linear-gradient(90deg,
    var(--ink) 0 2px, transparent 2px 4px,
    var(--ink) 4px 5px, transparent 5px 9px,
    var(--ink) 9px 12px, transparent 12px 13px,
    var(--ink) 13px 14px, transparent 14px 19px);
}
.signature{
  margin-top:auto;text-align:right;
  font-family:'Instrument Serif',serif;font-style:italic;font-size:22px;
  border-top:1px solid var(--ink);padding-top:10px;
}
.signature small{
  display:block;font-family:'JetBrains Mono',monospace;font-style:normal;
  font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--mute);
  margin-top:2px;
}
.pass-hint{
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--mute);
}

/* ============= 12 COLOPHON ============= */
.colophon{
  padding:90px 0 60px;text-align:center;
}
.colophon .big{
  font-family:'Instrument Serif',serif;font-size:clamp(120px,18vw,260px);
  line-height:.8;letter-spacing:-0.04em;color:var(--ink);
}
.colophon .big em{color:var(--flood)}
.colophon .meta{
  margin-top:32px;
  font-family:'JetBrains Mono',monospace;font-size:11px;line-height:1.8;
  letter-spacing:.18em;text-transform:uppercase;color:var(--mute);
}
.colophon .meta b{color:var(--ink);display:block;margin-bottom:8px}

/* ============= 13 PROJECT ENVIRONMENT MODAL ============= */
.env{
  position:fixed;inset:0;z-index:300;
  background:rgba(10,8,5,.5);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  opacity:0;visibility:hidden;
  transition:opacity .5s var(--ease), visibility .5s;
  display:grid;place-items:start center;padding:24px;overflow-y:auto;
}
.env.open{opacity:1;visibility:visible}
.env-panel{
  width:100%;max-width:1240px;background:var(--bg);
  border-radius:var(--r-xl);border:1px solid var(--rule);
  margin:24px 0;
  overflow:hidden;
  transform:translateY(40px) scale(.98);
  transition:transform .55s var(--ease-out);
  box-shadow:0 50px 100px -30px rgba(0,0,0,.5);
}
.env.open .env-panel{transform:translateY(0) scale(1)}
.env-head{
  display:flex;justify-content:space-between;align-items:center;
  padding:18px 28px;border-bottom:1px solid var(--rule);
  background:var(--paper);
}
.crumbs{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--mute);
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
}
.crumbs .name{color:var(--ink)}
.crumbs .dot{color:var(--flood)}
.env-close{
  width:42px;height:42px;border-radius:50%;border:1px solid var(--ink);
  display:grid;place-items:center;transition:all .25s var(--ease);
}
.env-close:hover{background:var(--flood);color:#fff;border-color:var(--flood);transform:rotate(90deg)}
.env-body{padding:0}

.env-hero{
  position:relative;height:380px;overflow:hidden;
  border-bottom:1px solid var(--rule);
  display:flex;align-items:flex-end;
}
.heroimg{
  position:absolute;inset:0;z-index:0;
}
.env-hero::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(to top,rgba(0,0,0,.78),rgba(0,0,0,.1));
}
.heroinfo{
  position:relative;z-index:2;padding:32px 36px;color:#fff;width:100%;
}
.kicker{
  display:flex;gap:10px;align-items:center;flex-wrap:wrap;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:rgba(255,255,255,.78);margin-bottom:12px;
}
.kicker .pill{
  background:var(--flood);color:#fff;padding:5px 10px;border-radius:3px;
}
.heroinfo h2{
  font-family:'Instrument Serif',serif;font-size:clamp(48px,5.5vw,82px);
  line-height:.95;letter-spacing:-0.03em;margin:0 0 10px;color:#fff;
}
.heroinfo h2 em{color:var(--flood);font-style:italic}
[data-theme="floodlights"] .heroinfo h2 em{color:#ffa654}
.heroinfo .strap{
  font-size:17px;color:rgba(255,255,255,.88);max-width:62ch;margin:0;
}

.env-tabs{
  display:flex;gap:0;padding:0 36px;
  border-bottom:1px solid var(--rule);background:var(--paper);
  overflow-x:auto;
}
.env-tab{
  display:flex;align-items:center;gap:12px;
  padding:18px 24px 16px;
  border-bottom:2px solid transparent;
  color:var(--mute);transition:all .25s var(--ease);
  flex-shrink:0;
}
.env-tab.active{color:var(--ink);border-bottom-color:var(--flood)}
.env-tab:hover{color:var(--ink)}
.env-tab .ic{
  width:28px;height:28px;border:1px solid currentColor;
  display:grid;place-items:center;
}
.env-tab .ic svg{width:14px;height:14px}
.env-tab .lbl{display:flex;flex-direction:column;align-items:flex-start;line-height:1}
.env-tab .n{
  font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.22em;
  text-transform:uppercase;opacity:.7;margin-bottom:4px;
}
.env-tab .t{
  font-family:'Instrument Serif',serif;font-size:20px;letter-spacing:-0.01em;
}

.tab-pane{display:none;padding:48px 36px 56px}
.tab-pane.active{display:block;animation:fadeUp .5s var(--ease-out)}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

.ov-grid{
  display:grid;grid-template-columns:1.4fr .7fr;gap:64px;
}
.ov-grid h3{
  font-family:'Instrument Serif',serif;font-size:42px;letter-spacing:-0.02em;
  margin:0 0 18px;
}
.ov-grid h3 em{color:var(--flood);font-style:italic}
.ov-body p{
  font-family:'Instrument Serif',serif;font-size:22px;line-height:1.4;
  letter-spacing:-0.005em;color:var(--ink);margin:0 0 16px;
}
.why-q{
  border-top:1px solid var(--rule);padding-top:18px;
  font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--mute);
}
.ov-side{
  background:var(--paper);border:1px solid var(--rule);border-radius:var(--r-md);
  padding:24px;position:relative;
}
.ov-side .stamp{
  position:absolute;top:-12px;left:18px;background:var(--ink);color:var(--paper);
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;
  text-transform:uppercase;padding:5px 10px;
}
.kvs{display:grid;gap:0}
.kvs .kv{
  display:flex;justify-content:space-between;gap:10px;align-items:baseline;
  padding:11px 0;border-bottom:1px dashed var(--rule-soft);
}
.kvs .kv:last-child{border-bottom:0}
.kvs .kv .k{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--mute);
}
.kvs .kv .v{font-weight:500;color:var(--ink);text-align:right;font-size:14px}

.gallery{
  display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:140px;gap:8px;
}
.g-img{
  border-radius:8px;overflow:hidden;position:relative;
  transition:transform .5s var(--ease-out);
  cursor:zoom-in;
}
.g-img:hover{transform:scale(1.02);z-index:2}
.g-img::after{
  content:attr(data-cap);position:absolute;left:12px;bottom:10px;
  font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.2em;
  text-transform:uppercase;color:rgba(255,255,255,.9);
  background:rgba(0,0,0,.4);padding:4px 8px;border-radius:3px;
  opacity:0;transition:opacity .25s var(--ease);
}
.g-img:hover::after{opacity:1}

.specs-wrap{display:grid;grid-template-columns:1.2fr 1fr;gap:48px}
.spec-list{display:grid;gap:0}
.spec-list li{
  display:grid;grid-template-columns:140px 1fr;gap:18px;
  padding:14px 0;border-bottom:1px solid var(--rule-soft);
  align-items:baseline;
}
.spec-list li .k{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--flood);
}
.spec-list li .v{font-size:15px;color:var(--ink)}
.chips-wrap{display:flex;flex-wrap:wrap;gap:8px}
.chips-wrap span{
  padding:8px 14px;border:1px solid var(--rule);border-radius:999px;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-2);
}

.outcomes{display:grid;grid-template-columns:1fr 1fr;gap:48px}
.bullet-list{display:grid;gap:14px}
.bullet-list li{
  padding-left:28px;position:relative;font-size:15px;line-height:1.5;
}
.bullet-list li::before{
  content:"";position:absolute;left:0;top:9px;
  width:14px;height:1px;background:var(--flood);
}
.bullet-list li b{color:var(--flood);font-weight:600}

.bars{display:grid;gap:14px}
.bar-row{display:grid;gap:6px}
.bar-row .bh{
  display:flex;justify-content:space-between;align-items:baseline;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;
}
.bar-row .bh .l{color:var(--ink)}
.bar-row .bh .r{color:var(--flood)}
.bar{
  height:6px;background:var(--rule-soft);border-radius:99px;overflow:hidden;
  position:relative;
}
.bar > i{
  display:block;height:100%;width:0;background:var(--flood);
  border-radius:99px;transition:width 1.2s var(--ease-out);
}

/* =====================================================================
   APPEND: deck-card v2 · modal HUD · zone matrix · phases · ov-seal
   ===================================================================== */

/* ----- Deck card v2 ----- */
.deck-card{
  height:480px;padding:0;overflow:hidden;
}
.dc-bcast{
  display:grid;grid-template-columns:auto 1fr auto auto;
  align-items:center;gap:10px;
  background:var(--ink);color:var(--paper);
  padding:9px 16px;
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;
  text-transform:uppercase;
  border-radius:var(--r-lg) var(--r-lg) 0 0;
}
.dc-bcast .dot{
  width:8px;height:8px;border-radius:50%;background:var(--flood);
  box-shadow:0 0 0 0 var(--flood);animation:pulse 1.6s infinite;
}
.dc-bcast .venue{color:var(--paper);font-weight:500}
.dc-bcast .clock{color:var(--flood);font-variant-numeric:tabular-nums}
.dc-bcast .ix{color:var(--mute-2)}

.dc-pad{padding:22px 28px 18px;display:flex;flex-direction:column;height:calc(100% - 38px);position:relative}
.dc-head{
  display:flex;justify-content:space-between;align-items:flex-start;gap:14px;
  padding-bottom:14px;border-bottom:1px solid var(--rule);
}
.dc-when{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--mute);
}
.dc-type{
  display:inline-flex;align-items:center;gap:7px;
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--flood);
  padding:5px 10px;border:1px solid var(--flood);border-radius:3px;
  white-space:nowrap;
}
.dc-type svg{width:11px;height:11px}
.dc-role{
  font-family:'Instrument Serif',serif;font-size:42px;line-height:1.02;
  letter-spacing:-0.02em;margin:14px 0 6px;color:var(--ink);
}
.dc-role em{color:var(--flood)}
.dc-org{
  font-size:14px;color:var(--ink-2);margin-bottom:14px;
  display:flex;align-items:center;gap:10px;
}
.dc-org::before{content:"";width:18px;height:1px;background:var(--ink-2)}

/* mini stats row */
.dc-mini{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border:1px solid var(--rule);border-radius:8px;
  margin-bottom:14px;background:var(--paper-2);
}
.dc-mini > div{
  padding:9px 12px;border-right:1px solid var(--rule);
}
.dc-mini > div:last-child{border-right:0}
.dc-mini .v{
  font-family:'Instrument Serif',serif;font-size:22px;line-height:1;
  color:var(--ink);letter-spacing:-0.01em;
}
.dc-mini .v em{color:var(--flood);font-style:italic}
.dc-mini .k{
  font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--mute);margin-top:3px;
}

/* quote */
.dc-quote{
  font-family:'Instrument Serif',serif;font-style:italic;
  font-size:15px;line-height:1.4;color:var(--ink-2);
  padding:10px 14px;border-left:2px solid var(--flood);
  margin-bottom:12px;background:linear-gradient(90deg,rgba(214,57,25,.04),transparent);
}
[data-theme="floodlights"] .dc-quote{background:linear-gradient(90deg,rgba(255,181,71,.06),transparent)}

/* skill chips inside deck card */
.dc-skills{
  display:flex;flex-wrap:wrap;gap:5px;margin-bottom:12px;
}
.dc-skills span{
  font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-2);
  padding:4px 8px;border:1px solid var(--rule);border-radius:99px;
  white-space:nowrap;
}

.dc-foot{
  margin-top:auto;padding-top:12px;border-top:1px solid var(--rule);
  display:flex;justify-content:space-between;align-items:center;gap:10px;
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--mute);
}
.dc-foot .seal{
  display:inline-flex;align-items:center;gap:6px;color:var(--ink);font-weight:500;
}
.dc-foot .seal::before{
  content:"";width:6px;height:6px;background:var(--flood);border-radius:50%;
}
.dc-foot .cta{
  display:inline-flex;align-items:center;gap:7px;
  color:var(--flood);font-weight:600;letter-spacing:.18em;
}
.dc-foot .cta svg{width:11px;height:11px;transition:transform .25s var(--ease)}
.dc-foot .cta:hover svg{transform:translate(2px,-2px)}

/* mini timeline showing position */
.dc-rail{
  position:absolute;left:28px;right:28px;bottom:0;height:3px;
  background:var(--rule-soft);
}
.dc-rail::after{
  content:"";position:absolute;left:0;top:0;height:100%;background:var(--flood);
  width:var(--rail,16%);
  transition:width .6s var(--ease-out);
}
.dc-no{
  font-family:'Instrument Serif',serif;font-size:140px;
  position:absolute;right:18px;top:10px;line-height:.8;
  color:rgba(20,17,10,.06);pointer-events:none;font-style:italic;
  z-index:0;
}
.dc-pad > *{position:relative;z-index:1}
.dc-pad > .dc-no{z-index:0}
[data-theme="floodlights"] .dc-no{color:rgba(241,232,208,.05)}

/* widen the deck slightly to fit content */
.deck-card{width:min(620px,86vw);margin-left:calc(min(620px,86vw) / -2)}

/* ----- Modal: live broadcast HUD ----- */
.hud{
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:18px;
  padding:14px 22px;margin-bottom:28px;
  background:var(--ink);color:var(--paper);
  border-radius:14px;
  font-family:'JetBrains Mono',monospace;
  position:relative;overflow:hidden;
}
.hud::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(60% 100% at 0% 50%,rgba(214,57,25,.18),transparent 60%),
    repeating-linear-gradient(90deg,transparent 0 40px,rgba(255,255,255,.02) 40px 41px);
  pointer-events:none;
}
.hud-tag{
  display:flex;align-items:center;gap:8px;
  font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--paper);position:relative;z-index:2;
}
.hud-live{
  width:8px;height:8px;border-radius:50%;background:var(--flood);
  box-shadow:0 0 0 0 var(--flood);animation:pulse 1.6s infinite;
}
.hud-stats{
  display:flex;gap:10px;flex-wrap:wrap;position:relative;z-index:2;
}
.hud-stat{
  display:flex;align-items:baseline;gap:8px;
  padding:6px 12px;border:1px solid rgba(255,255,255,.12);
  border-radius:6px;background:rgba(255,255,255,.04);
  min-width:84px;
}
.hud-stat .v{
  font-family:'Instrument Serif',serif;font-size:24px;line-height:1;
  color:var(--paper);letter-spacing:-0.01em;
}
.hud-stat .v em{color:var(--flood);font-style:italic}
.hud-stat .v sup{font-size:.55em;color:var(--flood);vertical-align:super}
.hud-stat .k{
  font-size:9px;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(241,232,208,.6);
}
.hud-side{
  display:flex;align-items:center;gap:14px;
  font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(241,232,208,.7);
  position:relative;z-index:2;
}
.hud-clock{
  color:var(--flood);font-variant-numeric:tabular-nums;letter-spacing:.16em;
}
.hud-loc{
  border:1px solid rgba(255,181,71,.5);color:var(--flood);
  padding:4px 9px;border-radius:3px;
}

/* ----- Modal: Zone Matrix ----- */
.zonemat{
  margin-top:38px;
  background:var(--paper);border:1px solid var(--rule);border-radius:12px;
  padding:18px 18px 16px;
}
.zm-h{
  display:flex;justify-content:space-between;align-items:baseline;gap:12px;
  padding-bottom:10px;border-bottom:1px solid var(--rule-soft);margin-bottom:14px;
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;
  text-transform:uppercase;
}
.zm-l{color:var(--ink);font-weight:600}
.zm-r{color:var(--mute)}
.zm-grid{
  display:grid;grid-template-columns:90px repeat(5,1fr);gap:4px;
}
.zm-cell{
  text-align:center;padding:9px 4px;
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.16em;
  text-transform:uppercase;
  border-radius:4px;background:var(--bg);color:var(--ink-2);
  transition:all .2s var(--ease);cursor:default;
  border:1px solid var(--rule-soft);
}
.zm-cell.h{background:transparent;color:var(--mute);border-color:transparent;font-weight:600}
.zm-cell.role{text-align:left;color:var(--ink);font-weight:600;background:transparent;border-color:transparent;padding-left:0}
.zm-cell.on{background:var(--flood);color:#fff;border-color:var(--flood)}
.zm-cell.esc{background:var(--gold);color:#1a1208;border-color:var(--gold)}
.zm-cell.off{background:var(--paper-2);color:var(--mute-2);text-decoration:line-through}
.zm-cell.on:hover,.zm-cell.esc:hover{transform:scale(1.08);z-index:2}
.zm-legend{
  margin-top:14px;
  display:flex;gap:18px;flex-wrap:wrap;
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--mute);
}
.zm-key{font-size:14px;line-height:1;margin-right:5px}
.zm-key.on{color:var(--flood)}
.zm-key.esc{color:var(--gold)}
.zm-key.off{color:var(--mute-2)}

/* ----- Modal: ov-seal ----- */
.ov-seal{
  margin-top:22px;
  position:relative;width:140px;height:140px;margin-left:auto;margin-right:auto;
}
.ov-seal-ring{
  position:absolute;inset:0;border-radius:50%;
  border:1px solid var(--flood);
  display:grid;place-items:center;
  animation:spin 22s linear infinite;
}
.ov-seal-ring span{
  position:absolute;inset:0;display:grid;place-items:center;
  font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.32em;
  text-transform:uppercase;color:var(--flood);
  transform-origin:50% 50%;
}
.ov-seal-ring span:nth-child(1){transform:rotate(0deg) translateY(-58px)}
.ov-seal-ring span:nth-child(2){transform:rotate(120deg) translateY(-58px)}
.ov-seal-ring span:nth-child(3){transform:rotate(240deg) translateY(-58px)}
@keyframes spin{to{transform:rotate(360deg)}}
.ov-seal-core{
  position:absolute;inset:24px;
  border:1px solid var(--ink);border-radius:50%;
  background:var(--paper-2);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:4px;
}
.ov-seal-core .seal-no{
  font-family:'Instrument Serif',serif;font-size:32px;line-height:.9;
  letter-spacing:-0.02em;color:var(--ink);
}
.ov-seal-core .seal-l{
  font-family:'JetBrains Mono',monospace;font-size:8px;letter-spacing:.24em;
  text-transform:uppercase;color:var(--mute);
}

/* ----- Modal: Phase timeline ----- */
.phases{margin-bottom:38px;background:var(--paper);border:1px solid var(--rule);border-radius:12px;padding:18px 22px}
.ph-h{
  display:flex;justify-content:space-between;align-items:baseline;
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;
  text-transform:uppercase;
  padding-bottom:14px;margin-bottom:14px;border-bottom:1px solid var(--rule-soft);
}
.ph-h .ph-meta{color:var(--mute)}
.ph-track{
  display:grid;grid-template-columns:repeat(6,1fr);gap:0;position:relative;
  counter-reset:phs;
}
.ph-track::before{
  content:"";position:absolute;top:18px;left:8%;right:8%;height:2px;
  background:var(--rule);z-index:0;
}
.ph-step{
  position:relative;z-index:1;
  display:flex;flex-direction:column;align-items:center;gap:6px;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--mute);
}
.ph-dot{
  width:14px;height:14px;border-radius:50%;
  background:var(--paper);border:2px solid var(--rule);
  position:relative;
  transition:all .35s var(--ease);
}
.ph-step.done .ph-dot{
  background:var(--flood);border-color:var(--flood);
  box-shadow:0 0 0 4px rgba(214,57,25,.12);
}
.ph-step.done .ph-dot::after{
  content:"\2713";position:absolute;inset:0;display:grid;place-items:center;
  color:#fff;font-size:9px;font-weight:700;line-height:1;
}
.ph-step.active .ph-dot{
  background:var(--flood);border-color:var(--flood);
  animation:pulse 1.6s infinite;
}
.ph-step .ph-n{font-size:9px;color:var(--mute);letter-spacing:.22em;margin-top:6px}
.ph-step .ph-t{font-size:12px;color:var(--ink);letter-spacing:.14em;font-weight:500}
.ph-step.done .ph-t{color:var(--ink)}

@media (max-width:680px){
  .hud{grid-template-columns:1fr;gap:10px}
  .hud-stats{flex-wrap:wrap}
  .zm-grid{grid-template-columns:80px repeat(5,1fr)}
  .ph-track{grid-template-columns:repeat(3,1fr);gap:14px}
  .ph-track::before{display:none}
  .ov-seal{margin-top:14px}
}

/* ============= 14 TWEAKS PANEL =============
.tweaks{
  position:fixed;bottom:24px;right:24px;z-index:400;
  width:320px;background:var(--paper);
  border:1px solid var(--ink);border-radius:var(--r-md);
  box-shadow:0 30px 60px -20px rgba(0,0,0,.35);
  padding:18px 18px 16px;
  transform:translateY(20px);opacity:0;visibility:hidden;
  transition:all .35s var(--ease-out);
  font-family:'Space Grotesk',sans-serif;
}
.tweaks.show{transform:translateY(0);opacity:1;visibility:visible}
.tw-h{
  display:flex;justify-content:space-between;align-items:center;
  padding-bottom:12px;border-bottom:1px solid var(--rule);margin-bottom:14px;
}
.tw-h .ttl{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ink);
}
.tw-h button{
  width:28px;height:28px;border:1px solid var(--rule);border-radius:50%;
  display:grid;place-items:center;font-size:14px;color:var(--mute);
}
.tw-h button:hover{background:var(--ink);color:var(--paper)}
.tw-row{
  padding:10px 0;border-bottom:1px dashed var(--rule-soft);
}
.tw-row:last-child{border-bottom:0}
.tw-row label{
  display:block;
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--mute);margin-bottom:8px;
}
.tw-swatches{display:flex;gap:6px}
.tw-sw{
  width:30px;height:30px;border-radius:50%;border:1px solid var(--rule);
  cursor:pointer;transition:transform .2s var(--ease);
}
.tw-sw:hover{transform:scale(1.08)}
.tw-sw.on{box-shadow:0 0 0 2px var(--paper),0 0 0 3px var(--ink);transform:scale(1.08)}
.tw-toggles{display:flex;gap:6px}
.tw-toggles button{
  flex:1;padding:8px 10px;
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.14em;
  text-transform:uppercase;
  border:1px solid var(--rule);color:var(--ink-2);border-radius:6px;
  transition:all .2s var(--ease);
}
.tw-toggles button.on{background:var(--ink);color:var(--paper);border-color:var(--ink)}

/* ============= 15 REVEALS ============= */
[data-reveal]{
  opacity:0;transform:translateY(24px);
  transition:opacity .9s var(--ease-out), transform .9s var(--ease-out);
}
[data-reveal].in{opacity:1;transform:translateY(0)}

/* ============= 16 RESPONSIVE ============= */
@media (max-width:1100px){
  :root{--pad:32px}
  .cover-grid{grid-template-columns:1fr;gap:40px}
  .feature{margin-top:-24px}
  .manifesto{grid-template-columns:1fr;gap:32px}
  .stats{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:0}
  .stat:nth-child(-n+2){border-bottom:1px solid var(--rule)}
  .project-grid{grid-template-columns:repeat(2,1fr)}
  .toolkit{grid-template-columns:repeat(2,1fr)}
  .contact{grid-template-columns:1fr;gap:40px}
  .ov-grid,.specs-wrap,.outcomes{grid-template-columns:1fr;gap:32px}
  .gallery{grid-template-columns:repeat(3,1fr)}
  .tickets{display:none}
  .polaroids{display:none}
}
@media (max-width:680px){
  :root{--pad:20px}
  .masthead{flex-direction:column;align-items:flex-start}
  .mast-right{width:100%}
  .stats{grid-template-columns:1fr}
  .stat{border-right:0;border-bottom:1px solid var(--rule)}
  .stat:last-child{border-bottom:0}
  .project-grid{grid-template-columns:1fr}
  .toolkit{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .tweaks{left:12px;right:12px;width:auto;bottom:12px}
  .deck-stage{height:560px}
  .pass{transform:scale(.85) rotate(-3deg);margin-top:60px}
}

/* prefers reduced motion */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;transition-duration:.01ms!important}
}
