/* OCHP lighting page — stage plot, fixture inventory, DMX map, cue book. Pairs with base.css. */

/* STATS (shared shape with audio) */
.stats{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem;
  margin-top:3.5rem;
}
.stat{
  padding:1.25rem 1.4rem;background:var(--bg-1);border:1px solid var(--border-1);
  border-radius:var(--radius-lg);transition:all .25s cubic-bezier(.4,0,.2,1);
  position:relative;overflow:hidden;
}
.stat:hover{border-color:var(--border-2);transform:translateY(-3px);box-shadow:var(--shadow-md)}
.stat::before{
  content:'';position:absolute;inset:0;border-radius:var(--radius-lg);
  background:linear-gradient(135deg,transparent 60%,var(--accent,var(--purple)) 200%);
  opacity:.06;pointer-events:none;
}
.stat-num{font-size:2.25rem;font-weight:700;letter-spacing:-.03em;line-height:1;color:var(--accent,var(--text-1))}
.stat-label{font-size:12px;color:var(--text-3);margin-top:8px;font-weight:500;letter-spacing:.02em}

/* NAV */
nav{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.82);
  backdrop-filter:saturate(160%) blur(14px);-webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid var(--border-1);
}
.nav-inner{max-width:1100px;margin:0 auto;display:flex;gap:1.75rem;padding:0 1.5rem;overflow-x:auto;-ms-overflow-style:none;scrollbar-width:none}
.nav-inner::-webkit-scrollbar{display:none}
nav a{
  color:var(--text-2);text-decoration:none;padding:1.1rem 0;
  font-size:14px;font-weight:500;letter-spacing:-.005em;
  border-bottom:2px solid transparent;white-space:nowrap;
  transition:color .15s,border-color .15s;
}
nav a:hover{color:var(--text-1)}
nav a.active{color:var(--text-1);border-bottom-color:var(--purple)}

/* SECTIONS */
main{max-width:1100px;margin:0 auto;padding:5rem 1.5rem 2rem}
section{margin-bottom:7rem;scroll-margin-top:80px}
.section-head{margin-bottom:2.75rem;max-width:720px}
.section-eyebrow{
  display:flex;align-items:center;gap:14px;
  font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  color:var(--text-3);margin-bottom:1.25rem;
}
.section-eyebrow::before{content:'';width:32px;height:1px;background:var(--gradient)}
h2{font-size:clamp(1.85rem,3.2vw,2.6rem);font-weight:700;letter-spacing:-.025em;line-height:1.15;margin-bottom:.85rem}
.section-sub{font-size:16px;color:var(--text-2);line-height:1.6}

/* ---------- STAGE PLOT ---------- */
.plot-wrap{
  background:
    radial-gradient(ellipse 60% 50% at 50% 30%, rgba(124,58,237,.06), transparent 65%),
    linear-gradient(180deg,#0f172a 0%,#0b1226 100%);
  color:#e2e8f0;
  border:1px solid rgba(124,58,237,.22);border-radius:var(--radius-xl);
  padding:1.25rem;margin-bottom:1.25rem;position:relative;overflow:hidden;
}
.plot-wrap::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent 0%,#a78bfa 25%,#60a5fa 50%,#22d3ee 75%,transparent 100%);
  opacity:.6;
}
.plot-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem;gap:1rem;flex-wrap:wrap;padding:0 .25rem}
.plot-title{font-size:13px;font-weight:600;color:#f1f5f9;letter-spacing:-.005em}
.plot-sub{font-size:12px;color:#94a3b8;margin-top:2px}
.plot-clear{
  font-size:11px;color:#94a3b8;background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);border-radius:100px;padding:5px 12px;
  cursor:pointer;font-family:inherit;letter-spacing:.04em;transition:all .15s;
  text-transform:uppercase;font-weight:600;
}
.plot-clear:hover{color:#f1f5f9;border-color:rgba(255,255,255,.22)}
.plot-clear[data-active="true"]{color:#c4b5fd;border-color:rgba(167,139,250,.45);background:rgba(167,139,250,.10)}

.plot-svg{width:100%;height:auto;display:block;font-family:'Inter',sans-serif}

/* Sanctuary outline — traced from the OCHP floor plan.
   Green to match the annotated screenshot. */
.sanctuary{
  fill:rgba(16,185,129,.04);
  stroke:rgba(74,222,128,.55);
  stroke-width:2;
  stroke-linejoin:round;
  filter:drop-shadow(0 0 18px rgba(34,197,94,.18));
}
.venue-label{
  font-size:11px;font-weight:700;letter-spacing:.32em;text-transform:uppercase;
  fill:rgba(241,245,249,.55);pointer-events:none;
}
.venue-label-sm{
  font-size:9px;font-weight:500;letter-spacing:.14em;
  fill:rgba(148,163,184,.55);pointer-events:none;
}
.edge-label{
  font-size:9px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  fill:rgba(148,163,184,.40);pointer-events:none;
}

/* Fixture dots */
.fixture{
  cursor:pointer;
  transition:r .2s ease, opacity .25s ease, stroke .2s ease;
  stroke:rgba(15,23,42,.85);stroke-width:1.5;
  filter:drop-shadow(0 0 5px color-mix(in srgb, var(--zc) 65%, transparent));
}
.fixture:hover{
  r:8;
  stroke:#f1f5f9;
}
.fixture.dim{opacity:.18;filter:none}
.fixture.hot{
  stroke:#f8fafc;stroke-width:2;
  filter:drop-shadow(0 0 12px color-mix(in srgb, var(--zc) 85%, transparent))
         drop-shadow(0 0 4px color-mix(in srgb, var(--zc) 100%, transparent));
}

.plot-tooltip{
  position:absolute;pointer-events:none;
  background:rgba(15,23,42,.94);color:#f1f5f9;
  padding:10px 12px;border-radius:8px;
  font-size:12px;font-weight:500;
  border:1px solid var(--zc, rgba(255,255,255,.18));box-shadow:var(--shadow-lg);
  opacity:0;transition:opacity .15s;
  z-index:20;white-space:nowrap;line-height:1.45;
}
.plot-tooltip.visible{opacity:1}
.plot-tooltip .tt-name{font-weight:700;letter-spacing:-.005em;color:var(--zc,#f1f5f9)}
.plot-tooltip .tt-meta{font-size:11px;color:#94a3b8;margin-top:3px;font-family:'JetBrains Mono',ui-monospace,monospace}

.plot-legend{
  display:flex;gap:.65rem .9rem;flex-wrap:wrap;align-items:center;
  margin-top:1.25rem;padding:.85rem 1.1rem;
  background:rgba(15,23,42,.025);border:1px solid var(--border-1);
  border-radius:var(--radius-md);font-size:12px;color:var(--text-2);
}
.plot-legend .pl-item{
  display:inline-flex;align-items:center;gap:7px;cursor:pointer;
  padding:4px 10px 4px 8px;border-radius:100px;
  background:var(--bg-1);border:1px solid var(--border-1);
  transition:background .15s, color .15s, border-color .15s, transform .15s;
}
.plot-legend .pl-item:hover{
  border-color:color-mix(in srgb,var(--zc) 35%,var(--border-2));
  transform:translateY(-1px);
}
.plot-legend .pl-item.is-active{
  background:color-mix(in srgb,var(--zc) 10%,var(--bg-1));
  border-color:color-mix(in srgb,var(--zc) 50%,transparent);
}
.plot-legend .pl-dot{width:9px;height:9px;border-radius:50%;background:var(--zc);box-shadow:0 0 8px var(--zc)}
.plot-legend .pl-name{font-weight:500;color:var(--text-1)}
.plot-legend .pl-count{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:11px;color:var(--text-3);font-weight:500}

/* ---------- FIXTURE GROUPS ---------- */
.group-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.85rem;
}
.group-card{
  background:linear-gradient(180deg,var(--bg-1),#fafbfd);
  border:1px solid var(--border-1);border-radius:var(--radius-lg);
  padding:1.2rem 1.25rem 1.1rem;position:relative;overflow:hidden;
  transition:transform .25s,border-color .25s,box-shadow .25s;
  cursor:default;
}
.group-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--zc,var(--purple));
}
.group-card::after{
  content:'';position:absolute;top:-50px;right:-50px;width:140px;height:140px;
  background:radial-gradient(circle,var(--zc,var(--purple)),transparent 70%);
  opacity:.10;pointer-events:none;
}
.group-card:hover{transform:translateY(-3px);border-color:var(--border-2);box-shadow:var(--shadow-md)}

.group-role{
  display:inline-block;font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10.5px;
  color:var(--text-3);font-weight:600;letter-spacing:.05em;margin-bottom:8px;text-transform:uppercase;
}
.group-name{font-size:16px;font-weight:600;letter-spacing:-.015em;margin-bottom:14px;color:var(--text-1);display:flex;align-items:center;justify-content:space-between;gap:8px}
.group-count{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:11px;font-weight:700;color:var(--zc,var(--purple));
  background:color-mix(in srgb,var(--zc,var(--purple)) 10%,transparent);
  padding:3px 9px;border-radius:100px;
  border:1px solid color-mix(in srgb,var(--zc,var(--purple)) 25%,transparent);
}
.group-dots{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:10px;min-height:22px}
.group-dots .gd{width:14px;height:14px;border-radius:4px;background:var(--zc);opacity:.85;box-shadow:0 0 6px color-mix(in srgb,var(--zc) 50%,transparent)}
.group-models{display:flex;flex-direction:column;gap:3px;margin-bottom:10px}
.group-models .gm-model{
  font-size:11.5px;color:var(--text-1);font-weight:500;letter-spacing:-.005em;
  line-height:1.3;
}
.group-meta{font-size:11px;color:var(--text-3);line-height:1.5;display:flex;gap:6px;flex-wrap:wrap}
.group-meta .gm-tag{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  background:var(--bg-2);border:1px solid var(--border-1);
  padding:2px 8px;border-radius:5px;color:var(--text-2);font-size:10px;letter-spacing:.01em;
}
.group-card.is-active{
  border-color:color-mix(in srgb,var(--zc) 45%,var(--border-2));
  box-shadow:0 0 0 1px color-mix(in srgb,var(--zc) 30%,transparent), var(--shadow-md);
}

/* ---------- DMX NETWORK ---------- */
.net-wrap{
  background:linear-gradient(180deg,var(--bg-1) 0%,#fafbfd 100%);
  border:1px solid var(--border-1);border-radius:var(--radius-xl);
  padding:1.5rem;position:relative;overflow:hidden;
}
.net-wrap::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent 0%,var(--cyan) 25%,var(--blue) 50%,var(--purple) 75%,transparent 100%);
  opacity:.5;
}
.net-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.25rem;gap:1rem;flex-wrap:wrap}
.net-title{font-size:13px;font-weight:600;color:var(--text-1);letter-spacing:-.005em}
.net-sub{font-size:12px;color:var(--text-3);margin-top:2px}
.net-legend{display:flex;gap:1rem;font-size:11.5px;color:var(--text-2)}
.net-key{display:inline-flex;align-items:center;gap:7px}
.net-dot{width:9px;height:9px;border-radius:3px}
.net-dot.active{background:linear-gradient(135deg,var(--purple),var(--blue));box-shadow:0 0 8px rgba(124,58,237,.5)}
.net-dot.avail{background:var(--bg-3);border:1px solid var(--border-2)}

.net-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.85rem}

.ctrl{
  background:var(--bg-1);
  border:1px solid var(--border-1);border-radius:var(--radius-lg);
  padding:1.1rem 1.2rem 1rem;transition:border-color .2s,transform .2s,box-shadow .2s;
  position:relative;
}
.ctrl:hover{border-color:var(--border-2);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.ctrl.primary{border-color:rgba(124,58,237,.35);background:linear-gradient(180deg,var(--bg-1),rgba(124,58,237,.04))}
.ctrl.primary::before{
  content:'';position:absolute;top:0;left:14px;right:14px;height:2px;
  background:linear-gradient(90deg,var(--purple),var(--blue));border-radius:0 0 4px 4px;
}
.ctrl-head{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.75rem}
.ctrl-name{font-size:14px;font-weight:600;color:var(--text-1);letter-spacing:-.005em;display:flex;align-items:center;gap:6px}
.ctrl-tag{
  font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10px;
  padding:3px 8px;border-radius:5px;background:var(--bg-2);border:1px solid var(--border-1);
  color:var(--text-2);white-space:nowrap;font-weight:600;letter-spacing:.04em;
}
.ctrl.primary .ctrl-tag{background:rgba(124,58,237,.10);color:var(--purple);border-color:rgba(124,58,237,.25)}
.ctrl-addr{
  font-family:'JetBrains Mono',ui-monospace,monospace;font-size:11.5px;
  color:var(--text-2);margin-bottom:.85rem;letter-spacing:.01em;
  display:flex;align-items:center;gap:6px;
}
.ctrl-addr .lead{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:.12em;font-weight:600}
.universes{display:grid;grid-template-columns:repeat(4,1fr);gap:5px;margin-bottom:.75rem}
.uni{
  position:relative;min-height:46px;
  background:var(--bg-2);border:1px solid var(--border-1);border-radius:6px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;
  font-family:'JetBrains Mono',ui-monospace,monospace;font-size:9px;color:var(--text-3);
  overflow:hidden;padding:4px;
}
.uni .uni-num{font-weight:700;color:var(--text-2);font-size:11px;line-height:1}
.uni .uni-lbl{font-size:9px;letter-spacing:.04em;text-transform:uppercase;line-height:1.2}
.uni .uni-sub{font-size:8.5px;color:var(--text-3);letter-spacing:.02em;margin-top:1px}
.ctrl-loc{
  font-size:10.5px;color:var(--text-3);font-style:italic;
  border-top:1px solid var(--border-1);padding-top:.55rem;letter-spacing:.01em;
}
.uni.active{
  background:linear-gradient(135deg,rgba(124,58,237,.16),rgba(37,99,235,.08));
  border-color:rgba(124,58,237,.32);
}
.uni.active .uni-num{color:var(--purple)}
.uni.active .uni-lbl{color:var(--blue)}
.uni.active .uni-sub{color:var(--purple);font-weight:600}
.uni.active::after{
  content:'';position:absolute;inset:auto 0 0 0;height:3px;
  background:linear-gradient(90deg,var(--purple) 0%,var(--blue) 28%,transparent 28%);
}

/* ---------- PATCH SHEET ---------- */
.patch-wrap{
  background:linear-gradient(180deg,var(--bg-1) 0%,#fafbfd 100%);
  border:1px solid var(--border-1);border-radius:var(--radius-xl);
  padding:1.5rem;margin-bottom:1.5rem;position:relative;overflow:hidden;
}
.patch-wrap::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent 0%,var(--purple) 25%,var(--blue) 50%,var(--cyan) 75%,transparent 100%);
  opacity:.5;
}
.patch-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.25rem;gap:1rem;flex-wrap:wrap}
.patch-title{font-size:13px;font-weight:600;color:var(--text-1);letter-spacing:-.005em}
.patch-sub{font-size:12px;color:var(--text-3);margin-top:2px;font-family:'JetBrains Mono',ui-monospace,monospace}
.patch-legend{display:flex;gap:1rem;font-size:11.5px;color:var(--text-2)}
.patch-key{display:inline-flex;align-items:center;gap:7px}
.patch-dot{width:9px;height:9px;border-radius:3px}
.patch-dot.used{background:linear-gradient(135deg,var(--purple),var(--blue));box-shadow:0 0 8px rgba(124,58,237,.5)}
.patch-dot.free{background:var(--bg-3);border:1px solid var(--border-2)}

.patch-strip{
  position:relative;height:34px;
  background:repeating-linear-gradient(
    90deg,
    var(--bg-2) 0,
    var(--bg-2) calc(100%/16 - 1px),
    var(--border-1) calc(100%/16 - 1px),
    var(--border-1) calc(100%/16)
  );
  border:1px solid var(--border-1);border-radius:6px;overflow:hidden;
}
.patch-seg{
  position:absolute;top:3px;bottom:3px;
  border-radius:3px;cursor:pointer;
  box-shadow:0 0 6px color-mix(in srgb,var(--zc) 45%,transparent);
  transition:opacity .2s, transform .15s, box-shadow .2s;
}
.patch-seg:hover{
  transform:scaleY(1.15);z-index:2;
  box-shadow:0 0 0 1px var(--zc), 0 0 14px color-mix(in srgb,var(--zc) 70%,transparent);
}
.patch-seg.dim{opacity:.22;box-shadow:none}

.patch-ruler{
  position:relative;height:22px;margin-top:6px;
  font-family:'JetBrains Mono',ui-monospace,monospace;font-size:9.5px;
  color:var(--text-3);
}
.patch-tick{
  position:absolute;top:0;width:1px;height:5px;background:var(--border-2);
  transform:translateX(-50%);
}
.patch-tick.major{height:8px;background:var(--border-3)}
.patch-tick-lbl{
  position:absolute;top:7px;left:50%;transform:translateX(-50%);
  white-space:nowrap;color:var(--text-3);font-weight:500;
}

/* Per-fixture table */
.patch-table{
  background:var(--bg-1);border:1px solid var(--border-1);
  border-radius:var(--radius-lg);overflow:hidden;
}
.pt-head, .pt-row{
  display:grid;grid-template-columns:160px 70px 1fr 1.2fr 90px;
  gap:14px;padding:11px 18px;align-items:center;font-size:13px;
  border-bottom:1px solid var(--border-1);
}
.pt-row:last-child{border-bottom:none}
.pt-head{
  font-size:10.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--text-3);background:rgba(15,23,42,.025);
}
.pt-row{cursor:pointer;transition:background .15s, opacity .25s}
.pt-row:hover{background:rgba(124,58,237,.04)}
.pt-row.dim{opacity:.32}
.pt-c-addr{
  display:flex;align-items:center;gap:8px;
  font-family:'JetBrains Mono',ui-monospace,monospace;font-size:12px;
  font-weight:600;color:var(--text-1);
}
.pt-c-addr .pt-pip{
  width:8px;height:8px;border-radius:2px;background:var(--zc);
  box-shadow:0 0 6px color-mix(in srgb,var(--zc) 60%,transparent);
}
.pt-c-addr .pt-end{color:var(--text-3);font-weight:500;font-size:11px}
.pt-c-ch{
  font-family:'JetBrains Mono',ui-monospace,monospace;font-size:11px;
  color:var(--text-2);font-weight:500;
  padding:3px 9px;border-radius:5px;background:var(--bg-2);
  border:1px solid var(--border-1);display:inline-block;width:fit-content;
}
.pt-c-model{color:var(--text-1);font-weight:500;letter-spacing:-.005em}
.pt-c-group{color:var(--text-2)}
.pt-c-uid{
  font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10.5px;
  color:var(--text-3);letter-spacing:.02em;
}

@media (max-width:760px){
  .pt-head, .pt-row{
    grid-template-columns:130px 1fr;
    gap:8px;padding:10px 12px;
  }
  .pt-c-ch, .pt-c-uid, .pt-head .pt-c-ch, .pt-head .pt-c-uid{display:none}
  .pt-c-group{display:none}
}

/* ---------- SCENE BOOK ---------- */
.bank-rail{
  display:flex;gap:6px;flex-wrap:wrap;margin-bottom:1.25rem;
  padding-bottom:1.1rem;border-bottom:1px solid var(--border-1);
}
.bank-pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 14px 7px 10px;border-radius:100px;
  background:var(--bg-1);border:1px solid var(--border-1);
  font-size:13px;font-weight:500;color:var(--text-2);
  cursor:pointer;transition:all .15s;font-family:inherit;
}
.bank-pill:hover{border-color:var(--border-2);color:var(--text-1)}
.bank-pill .bp-letter{
  display:inline-flex;align-items:center;justify-content:center;
  width:20px;height:20px;border-radius:6px;
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:11px;font-weight:700;background:var(--bg-2);color:var(--text-3);
}
.bank-pill .bp-count{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:11px;color:var(--text-3)}
.bank-pill[data-active="true"]{
  background:linear-gradient(135deg,rgba(124,58,237,.10),rgba(37,99,235,.04));
  border-color:rgba(124,58,237,.35);color:var(--text-1);
}
.bank-pill[data-active="true"] .bp-letter{background:rgba(124,58,237,.18);color:var(--purple)}

.flow-strip{
  display:flex;gap:0;margin-bottom:2rem;
  border-radius:var(--radius-md);overflow:hidden;
  border:1px solid var(--border-1);height:36px;
}
.flow-strip .fs-seg{
  flex:1;display:flex;align-items:center;justify-content:center;
  gap:6px;font-size:11px;font-weight:600;color:var(--text-2);
  background:var(--bg-1);border-right:1px solid var(--border-1);
  letter-spacing:.04em;cursor:pointer;transition:all .15s;
  position:relative;text-transform:uppercase;
}
.flow-strip .fs-seg:last-child{border-right:none}
.flow-strip .fs-seg:hover{background:var(--bg-2)}
.flow-strip .fs-seg[data-active="true"]{
  background:linear-gradient(180deg,rgba(124,58,237,.12),rgba(37,99,235,.04));
  color:var(--purple);
}
.flow-strip .fs-seg .fs-letter{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  background:var(--bg-2);border-radius:4px;padding:1px 5px;
  font-size:10px;font-weight:700;color:var(--text-3);
}
.flow-strip .fs-seg[data-active="true"] .fs-letter{background:rgba(124,58,237,.18);color:var(--purple)}
@media (max-width:680px){.flow-strip{display:none}}

.scene-banks{display:flex;flex-direction:column;gap:2rem}
.scene-bank{
  background:var(--bg-1);border:1px solid var(--border-1);border-radius:var(--radius-lg);
  padding:1.25rem 1.35rem 1.1rem;
}
.scene-empty{
  padding:2rem;text-align:center;color:var(--text-3);font-size:13px;
  border:1px dashed var(--border-2);border-radius:var(--radius-lg);
  background:var(--bg-1);
}
.scene-bank-head{
  display:flex;align-items:center;gap:12px;margin-bottom:1rem;
  padding-bottom:.85rem;border-bottom:1px solid var(--border-1);
}
.scene-bank-letter{
  display:inline-flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:8px;
  background:linear-gradient(135deg,rgba(124,58,237,.14),rgba(37,99,235,.06));
  border:1px solid rgba(124,58,237,.22);
  color:var(--purple);font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:14px;font-weight:700;
}
.scene-bank-title{font-size:16px;font-weight:600;color:var(--text-1);letter-spacing:-.01em}
.scene-bank-meta{margin-left:auto;font-size:11px;color:var(--text-3);font-family:'JetBrains Mono',ui-monospace,monospace}

.scene-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.6rem;
}
.scene{
  position:relative;
  background:var(--bg-2);border:1px solid var(--border-1);border-radius:8px;
  padding:.65rem .8rem .55rem;
  display:flex;flex-direction:column;gap:6px;
  transition:all .15s;cursor:default;overflow:hidden;
}
.scene::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--zc,var(--purple));opacity:.85;
}
.scene:hover{
  transform:translateY(-2px);border-color:var(--border-3);
  background:var(--bg-1);box-shadow:var(--shadow-md);
}
.scene-name{
  font-size:13px;font-weight:600;color:var(--text-1);letter-spacing:-.005em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.scene-bar{
  position:relative;height:5px;background:var(--bg-3);
  border-radius:99px;overflow:hidden;
}
.scene-bar::before{
  content:'';position:absolute;inset:0 auto 0 0;width:var(--dim,0%);
  background:linear-gradient(90deg,var(--zc,var(--purple)),color-mix(in srgb,var(--zc,var(--purple)) 60%,white));
  border-radius:99px;transition:width .3s;
}
.scene-row{
  display:flex;align-items:center;justify-content:space-between;
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:10.5px;color:var(--text-3);
}
.scene-row .sr-dim{color:var(--text-2);font-weight:600}
.scene-row .sr-fade{display:inline-flex;align-items:center;gap:4px}
.scene-row .sr-fade .ar{color:var(--text-3)}

.scene.special{background:linear-gradient(135deg,rgba(225,29,72,.06),rgba(219,39,119,.03));border-color:rgba(225,29,72,.22)}
.scene.special::before{background:var(--rose)}
.scene.special .scene-name{color:var(--rose)}

/* FOOTER */
footer{
  max-width:1100px;margin:0 auto;padding:2.5rem 1.5rem 4rem;
  border-top:1px solid var(--border-1);color:var(--text-3);font-size:13px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;align-items:center;
}
footer a{color:var(--text-2);text-decoration:none;border-bottom:1px solid var(--border-2);transition:color .15s,border-color .15s}
footer a:hover{color:var(--text-1);border-bottom-color:var(--purple)}

@media (max-width:760px){
  .plot-wrap{padding:1rem}
  .group-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}
  .scene-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
}

/* PRINT */
@media print{
  body{background:white;color:black}
  .hero::before,.hero::after,nav,footer{display:none}
  .plot-wrap{background:white;color:black;border-color:#ddd}
  .plot-wrap *{fill:#0f172a !important;color:#0f172a !important}
  .scene-bank,.ctrl,.group-card{break-inside:avoid;border-color:#ddd}
  section{margin-bottom:2rem;page-break-inside:avoid}
}
