:root{
  --bg:#070b0f; --bg2:#0b1119; --panel:#0e1622; --panel2:#121c2a;
  --line:#1c2a3a; --text:#c6d4e2; --dim:#5f7286; --dimmer:#3c4a5a;
  --cyan:#22d3ee; --cyan-dim:#0e7490; --green:#4ade80; --mag:#f472b6;
  --amber:#fbbf24; --red:#f87171;
  --mono:ui-monospace,"JetBrains Mono","SF Mono",Menlo,Consolas,monospace;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:radial-gradient(1200px 600px at 70% -10%,#0d1a24 0,var(--bg) 55%) fixed,var(--bg);
  color:var(--text);font-family:var(--mono);font-size:14px;line-height:1.5;
  -webkit-font-smoothing:antialiased;min-height:100vh;
}
a{color:var(--cyan);text-decoration:none}
a:hover{text-shadow:0 0 8px var(--cyan)}
.accent{color:var(--cyan)}.dim{color:var(--dim)}
.scanlines{position:fixed;inset:0;pointer-events:none;z-index:99;
  background:repeating-linear-gradient(0deg,rgba(0,0,0,0),rgba(0,0,0,0) 2px,rgba(0,0,0,.14) 3px,rgba(0,0,0,0) 4px);
  mix-blend-mode:overlay;opacity:.5}

/* header */
.topbar{display:flex;align-items:baseline;gap:18px;flex-wrap:wrap;
  padding:20px 26px 14px;border-bottom:1px solid var(--line)}
.brand{font-size:22px;font-weight:700;letter-spacing:.5px;color:#eaf2fb;text-shadow:0 0 18px rgba(34,211,238,.25)}
.brand .prompt{color:var(--green);text-shadow:0 0 10px var(--green)}
.brand .ver{font-size:11px;color:var(--dim);border:1px solid var(--line);padding:1px 6px;border-radius:4px;margin-left:6px}
.tagline{color:var(--dim);font-size:12.5px}

/* stats */
.statstrip{display:flex;gap:26px;align-items:center;flex-wrap:wrap;
  padding:14px 26px;background:linear-gradient(180deg,rgba(34,211,238,.04),transparent);border-bottom:1px solid var(--line)}
.stat{display:flex;flex-direction:column;line-height:1.15}
.stat.grow{margin-left:auto;text-align:right}
.stat .num{font-size:20px;font-weight:700;color:var(--cyan);text-shadow:0 0 12px rgba(34,211,238,.3)}
.stat .lbl{font-size:10.5px;text-transform:uppercase;letter-spacing:1px;color:var(--dim)}

/* controls */
.controls{display:flex;gap:12px;align-items:center;flex-wrap:wrap;padding:16px 26px 8px}
.segs{display:flex;border:1px solid var(--line);border-radius:7px;overflow:hidden}
.segs button{background:transparent;color:var(--dim);border:0;padding:8px 14px;font-family:var(--mono);
  font-size:11.5px;letter-spacing:1px;cursor:pointer;transition:.15s}
.segs button:hover{color:var(--text);background:var(--panel)}
.segs button.on{background:var(--cyan);color:#04222b;font-weight:700}
#search{flex:1;min-width:220px;background:var(--panel);border:1px solid var(--line);border-radius:7px;
  color:var(--text);font-family:var(--mono);font-size:13px;padding:9px 13px}
#search:focus{outline:none;border-color:var(--cyan-dim);box-shadow:0 0 0 2px rgba(34,211,238,.12)}
.cats{display:flex;gap:7px;flex-wrap:wrap;width:100%;padding-top:6px}
.chip{background:var(--panel);border:1px solid var(--line);color:var(--dim);border-radius:20px;
  padding:5px 12px;font-size:11px;cursor:pointer;transition:.15s;white-space:nowrap}
.chip:hover{color:var(--text);border-color:var(--cyan-dim)}
.chip.on{background:rgba(34,211,238,.14);border-color:var(--cyan);color:var(--cyan)}
.chip .c{opacity:.6;margin-left:5px}

/* grid */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px;padding:18px 26px 60px}
.loading{color:var(--dim);padding:40px;grid-column:1/-1;text-align:center;animation:pulse 1.2s infinite}
@keyframes pulse{50%{opacity:.4}}
.card{background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);
  border-radius:11px;padding:15px 16px;cursor:pointer;position:relative;overflow:hidden;
  transition:transform .12s,border-color .12s,box-shadow .12s}
.card:hover{transform:translateY(-3px);border-color:var(--cyan-dim);box-shadow:0 10px 30px -12px rgba(34,211,238,.35)}
.card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--cat,#334)}
.card .row1{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:9px}
.badge{font-size:9.5px;letter-spacing:1px;text-transform:uppercase;font-weight:700;
  padding:3px 8px;border-radius:5px;color:#05141b;background:var(--cat,#445)}
.when{font-size:11px;color:var(--dim);white-space:nowrap}
.card h3{margin:0 0 7px;font-size:15px;line-height:1.3;color:#eaf2fb;font-weight:600}
.meta{display:flex;gap:12px;flex-wrap:wrap;font-size:11.5px;color:var(--dim);margin-bottom:10px}
.meta b{color:var(--text);font-weight:600}
.tags{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:10px}
.tag{font-size:10px;color:var(--cyan);background:rgba(34,211,238,.08);border:1px solid rgba(34,211,238,.2);
  padding:2px 7px;border-radius:12px}
.tag.interest{color:var(--mag);background:rgba(244,114,182,.1);border-color:rgba(244,114,182,.3)}
.confbar{display:flex;align-items:center;gap:8px;font-size:10px;color:var(--dim)}
.confbar .track{flex:1;height:4px;background:var(--line);border-radius:3px;overflow:hidden}
.confbar .fill{height:100%;background:linear-gradient(90deg,var(--amber),var(--green))}
.free{color:var(--green);font-weight:700}
.multi{color:var(--amber);font-size:9.5px;border:1px solid rgba(251,191,36,.35);
  padding:1px 6px;border-radius:10px;margin-left:4px;white-space:nowrap}
.dates{display:flex;flex-direction:column;gap:6px}
.drow{display:flex;justify-content:space-between;align-items:center;background:var(--panel);
  border:1px solid var(--line);border-radius:8px;padding:8px 12px;font-size:12.5px;color:var(--text)}
.drow .dacts{display:flex;gap:14px}
.drow .dacts a{font-size:15px}

/* detail sheet */
.overlay{position:fixed;inset:0;z-index:100;background:rgba(3,6,9,.78);backdrop-filter:blur(4px);
  display:flex;justify-content:center;align-items:flex-start;overflow-y:auto;padding:40px 16px}
.overlay[hidden]{display:none}  /* the [hidden] attr alone loses to the class rule */
.sheet{background:linear-gradient(180deg,var(--panel2),var(--bg2));border:1px solid var(--cyan-dim);
  border-radius:14px;max-width:720px;width:100%;box-shadow:0 30px 80px -20px rgba(34,211,238,.3);
  animation:rise .18s ease-out}
@keyframes rise{from{transform:translateY(14px);opacity:0}}
.sheet .hero{padding:22px 24px 0;position:relative}
.sheet .close{position:absolute;top:14px;right:16px;background:var(--panel);border:1px solid var(--line);
  color:var(--dim);width:30px;height:30px;border-radius:7px;cursor:pointer;font-size:15px}
.sheet .close:hover{color:var(--text);border-color:var(--cyan)}
.sheet h2{margin:6px 40px 4px 0;font-size:22px;color:#eaf2fb;line-height:1.25}
.sheet .sub{color:var(--dim);font-size:12.5px;margin-bottom:14px}
.heroimg{width:100%;height:180px;object-fit:cover;border-radius:10px;margin:12px 0;border:1px solid var(--line);display:none}
.heroimg.ok{display:block}  /* only show once actually loaded - no empty frame */
.deck{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;padding:4px 24px 4px}
.dcell{background:var(--panel);border:1px solid var(--line);border-radius:9px;padding:11px 13px}
.dcell .k{font-size:9.5px;text-transform:uppercase;letter-spacing:1px;color:var(--dim);margin-bottom:3px}
.dcell .v{font-size:14px;color:#eaf2fb;font-weight:600}
.section{padding:14px 24px 0}
.section h4{font-size:10.5px;letter-spacing:1.5px;text-transform:uppercase;color:var(--cyan);
  margin:0 0 8px;border-bottom:1px solid var(--line);padding-bottom:5px}
.section p{margin:0;color:var(--text);font-size:13px;white-space:pre-wrap}
.actions{display:flex;gap:9px;flex-wrap:wrap;padding:16px 24px 6px}
.btn{flex:1;min-width:130px;text-align:center;background:var(--cyan);color:#04222b;border:0;border-radius:8px;
  padding:11px;font-family:var(--mono);font-weight:700;font-size:12px;letter-spacing:.5px;cursor:pointer;transition:.14s}
.btn:hover{box-shadow:0 6px 20px -6px rgba(34,211,238,.6);transform:translateY(-1px)}
.btn.ghost{background:transparent;color:var(--cyan);border:1px solid var(--cyan-dim)}
.subaction{padding:8px 24px 0;text-align:center}
.linkbtn{background:none;border:0;color:var(--dim);font-family:var(--mono);font-size:11px;
  cursor:pointer;text-decoration:underline;text-underline-offset:3px;padding:4px}
.linkbtn:hover{color:var(--cyan)}
.prov{display:flex;gap:16px;flex-wrap:wrap;padding:12px 24px 22px;font-size:11px;color:var(--dim)}
.prov b{color:var(--text)}
.roadmap{display:flex;gap:7px;flex-wrap:wrap;padding:2px 24px 18px}
.rm{font-size:10px;color:var(--dimmer);border:1px dashed var(--line);padding:3px 9px;border-radius:12px}
.rm::before{content:"◔ ";color:var(--amber)}

@media(max-width:560px){.topbar{padding:16px}.statstrip,.controls,.grid{padding-left:16px;padding-right:16px}}
