@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@300;400;500;600;700&family=Outfit:wght@300;400;500;600;700;800;900&display=swap');

*{margin:0;padding:0;box-sizing:border-box}

:root{
  --bg-0:#06080c;--bg-1:#0b0f18;--bg-2:#111827;--bg-3:#1a2235;--bg-4:#243049;
  --cyan:#00f0ff;--cyan-dim:#00889944;--cyan-glow:#00f0ff33;
  --red:#ff3358;--red-dim:#ff335822;
  --green:#00ff88;--green-dim:#00ff8822;
  --amber:#ffaa00;--amber-dim:#ffaa0022;
  --purple:#b44dff;--purple-dim:#b44dff22;
  --text:#e4e8f0;--text-dim:#8892a8;--text-muted:#4a5568;
  --border:#1e293b;--border-bright:#2d3f5f;
  --mono:'JetBrains Mono',monospace;
  --sans:'Outfit',sans-serif;
}

html{font-size:14px;background:var(--bg-0);color:var(--text)}
body{font-family:var(--sans);min-height:100vh;overflow-x:hidden}

/* ── Scrollbar ── */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--bg-1)}
::-webkit-scrollbar-thumb{background:var(--border-bright);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--cyan)}

/* ── Scanlines ── */
body::after{
  content:'';position:fixed;top:0;left:0;width:100%;height:100%;
  pointer-events:none;z-index:9999;
  background:repeating-linear-gradient(0deg,transparent,transparent 2px,#00f0ff02 2px,#00f0ff02 4px);
}

/* ── Header ── */
.header{
  position:sticky;top:0;z-index:100;
  background:linear-gradient(180deg,var(--bg-0) 0%,rgba(11,15,24,.95) 100%);
  border-bottom:1px solid var(--border);padding:0 2rem;
  backdrop-filter:blur(16px);
}
.header-inner{
  max-width:1600px;margin:0 auto;display:flex;align-items:center;
  justify-content:space-between;height:64px;
}
.logo{display:flex;align-items:center;gap:12px}
.logo-dot{
  width:8px;height:8px;border-radius:50%;background:var(--green);
  box-shadow:0 0 8px var(--green);animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.logo-mark{font-family:var(--mono);font-weight:700;font-size:1.5rem;letter-spacing:4px;color:var(--cyan);text-shadow:0 0 20px var(--cyan-glow)}
.logo-sub{font-size:.7rem;color:var(--text-dim);letter-spacing:2px;text-transform:uppercase}

/* ── Global Search ── */
.global-search{position:relative;width:340px}
.global-search input{
  width:100%;padding:.55rem 1rem .55rem 2.2rem;
  background:var(--bg-2);border:1px solid var(--border);border-radius:8px;
  color:var(--text);font-size:.85rem;font-family:var(--sans);transition:border-color .2s;
}
.global-search input:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 12px var(--cyan-glow)}
.global-search .gs-icon{position:absolute;left:.7rem;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:.9rem;pointer-events:none}
.global-search .gs-results{
  position:absolute;top:calc(100% + 6px);left:0;right:0;
  background:var(--bg-1);border:1px solid var(--border-bright);border-radius:10px;
  max-height:420px;overflow-y:auto;display:none;z-index:200;
  box-shadow:0 12px 40px #00000088;
}
.global-search .gs-results.open{display:block}
.gs-section{padding:.5rem .75rem}
.gs-section-title{font-size:.65rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);margin-bottom:.4rem;font-weight:600}
.gs-item{
  padding:.45rem .75rem;border-radius:6px;cursor:pointer;
  display:flex;align-items:center;gap:.5rem;font-size:.82rem;transition:background .15s;
}
.gs-item:hover{background:var(--bg-3)}
.gs-item .gs-type{font-size:.6rem;padding:2px 6px;border-radius:3px;font-family:var(--mono);flex-shrink:0}
.gs-item .gs-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gs-empty{padding:1.5rem;text-align:center;color:var(--text-muted);font-size:.85rem}

/* ── Tabs ── */
.tabs{display:flex;gap:2px}
.tab{
  padding:8px 18px;font-size:.82rem;font-weight:500;color:var(--text-dim);
  cursor:pointer;background:transparent;border:none;
  border-bottom:2px solid transparent;transition:all .2s;
  letter-spacing:.5px;font-family:var(--sans);
}
.tab:hover{color:var(--text)}
.tab.active{color:var(--cyan);border-bottom-color:var(--cyan);text-shadow:0 0 10px var(--cyan-dim)}

/* ── Main ── */
.main{max-width:1600px;margin:0 auto;padding:1.5rem 2rem 4rem}
.panel{display:none}.panel.active{display:block}

/* ── Grid ── */
.grid{display:grid;gap:1rem}
.g4{grid-template-columns:repeat(4,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g2{grid-template-columns:repeat(2,1fr)}
.mb{margin-bottom:1.25rem}

/* ── Stat Cards ── */
.stat-card{
  background:var(--bg-2);border:1px solid var(--border);border-radius:12px;
  padding:1.2rem 1.4rem;position:relative;overflow:hidden;
  transition:border-color .3s,transform .2s;
}
.stat-card:hover{border-color:var(--border-bright);transform:translateY(-2px)}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--cyan),transparent);opacity:.4}
.stat-label{font-size:.7rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:.4rem}
.stat-value{font-family:var(--mono);font-size:1.8rem;font-weight:700}
.v-cyan{color:var(--cyan)}.v-red{color:var(--red)}.v-green{color:var(--green)}.v-amber{color:var(--amber)}.v-purple{color:var(--purple)}

/* ── Chart Card ── */
.chart-card{background:var(--bg-2);border:1px solid var(--border);border-radius:12px;padding:1.5rem}
.chart-card h3{font-size:.8rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:1rem;font-weight:500}
.chart-wrap{position:relative;height:280px}
.chart-wrap.tall{height:360px}

/* ── Table ── */
.tbl-wrap{overflow-x:auto;border-radius:12px;border:1px solid var(--border);background:var(--bg-2)}
table{width:100%;border-collapse:collapse;font-size:.82rem}
thead{background:var(--bg-3)}
th{
  padding:.7rem 1rem;text-align:left;font-weight:600;color:var(--text-dim);
  text-transform:uppercase;letter-spacing:1px;font-size:.68rem;
  border-bottom:1px solid var(--border);white-space:nowrap;cursor:pointer;
  transition:color .2s;user-select:none;
}
th:hover{color:var(--cyan)}
th .sort-arrow{margin-left:4px;font-size:.6rem;opacity:.5}
th.sorted .sort-arrow{opacity:1;color:var(--cyan)}
td{padding:.55rem 1rem;border-bottom:1px solid var(--border);vertical-align:top}
tr:hover td{background:var(--bg-3)}
tr.clickable{cursor:pointer}

/* ── Tags ── */
.tag{
  display:inline-block;padding:2px 7px;border-radius:4px;font-size:.68rem;
  font-family:var(--mono);margin:1px;white-space:nowrap;
}
.t-cyan{background:var(--cyan-dim);color:var(--cyan);border:1px solid #00f0ff33}
.t-red{background:var(--red-dim);color:var(--red);border:1px solid #ff335833}
.t-green{background:var(--green-dim);color:var(--green);border:1px solid #00ff8833}
.t-amber{background:var(--amber-dim);color:var(--amber);border:1px solid #ffaa0033}
.t-purple{background:var(--purple-dim);color:var(--purple);border:1px solid #b44dff33}
.t-muted{background:#ffffff08;color:var(--text-dim);border:1px solid var(--border)}

/* ── Badges ── */
.os-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:6px;font-size:.72rem;font-weight:500}
.os-linux{background:#16a34a15;color:#4ade80;border:1px solid #16a34a33}
.os-windows{background:#2563eb15;color:#60a5fa;border:1px solid #2563eb33}
.os-freebsd{background:#dc262615;color:#f87171;border:1px solid #dc262633}
.os-unknown{background:#ffffff08;color:var(--text-dim);border:1px solid var(--border)}

.diff-badge{padding:3px 9px;border-radius:6px;font-size:.72rem;font-weight:600;display:inline-block}
.diff-easy{background:#16a34a18;color:#4ade80}
.diff-medium{background:#f59e0b18;color:#fbbf24}
.diff-hard{background:#ef444418;color:#f87171}
.diff-insane{background:#a855f718;color:#c084fc}

/* ── Search / Filters ── */
.search-bar{display:flex;gap:.75rem;margin-bottom:1rem;align-items:center;flex-wrap:wrap}
.search-group{position:relative;flex:1;min-width:240px}
.search-group .s-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}
.s-input{
  width:100%;padding:.6rem 1rem .6rem 2.4rem;
  background:var(--bg-2);border:1px solid var(--border);border-radius:8px;
  color:var(--text);font-size:.85rem;font-family:var(--sans);transition:border-color .2s;
}
.s-input:focus{outline:none;border-color:var(--cyan)}
.f-select{
  padding:.6rem .75rem;background:var(--bg-2);border:1px solid var(--border);
  border-radius:8px;color:var(--text);font-family:var(--sans);font-size:.82rem;cursor:pointer;
}
.f-select:focus{outline:none;border-color:var(--cyan)}
.result-count{font-size:.78rem;color:var(--text-dim);margin-bottom:.6rem}

/* ── Pagination ── */
.pagination{display:flex;justify-content:center;gap:.4rem;margin-top:1.25rem}
.pg-btn{
  padding:.35rem .7rem;background:var(--bg-2);border:1px solid var(--border);
  border-radius:6px;color:var(--text-dim);cursor:pointer;font-size:.78rem;
  font-family:var(--sans);transition:all .2s;
}
.pg-btn:hover{border-color:var(--cyan);color:var(--cyan)}
.pg-btn.active{background:var(--cyan);color:var(--bg-0);border-color:var(--cyan);font-weight:600}
.pg-btn:disabled{opacity:.3;cursor:default}

/* ── Modal ── */
.modal-overlay{
  display:none;position:fixed;top:0;left:0;width:100%;height:100%;
  background:#000000cc;z-index:200;backdrop-filter:blur(6px);
  justify-content:center;align-items:flex-start;padding:2.5rem 1rem;overflow-y:auto;
}
.modal-overlay.show{display:flex}
.modal{
  background:var(--bg-1);border:1px solid var(--border-bright);border-radius:16px;
  max-width:960px;width:100%;padding:2rem;position:relative;
  box-shadow:0 20px 60px #00000088;animation:modalIn .2s ease-out;
}
@keyframes modalIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.modal-close{
  position:absolute;top:1rem;right:1rem;background:none;border:none;
  color:var(--text-dim);font-size:1.4rem;cursor:pointer;padding:.25rem .5rem;
  border-radius:6px;transition:all .2s;
}
.modal-close:hover{color:var(--red);background:var(--red-dim)}
.modal h2{font-size:1.35rem;color:var(--cyan);font-weight:700;margin-bottom:.3rem}
.modal .meta{color:var(--text-dim);font-size:.82rem;margin-bottom:1.25rem;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.modal .section{margin-bottom:1.2rem}
.modal .sec-title{font-size:.7rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);margin-bottom:.4rem;font-weight:600}
.modal .synopsis{line-height:1.65;color:var(--text);font-size:.88rem}

/* ── Code Block ── */
.code-block{
  background:var(--bg-0);border:1px solid var(--border);border-radius:8px;
  padding:.75rem 1rem;font-family:var(--mono);font-size:.75rem;
  line-height:1.6;overflow-x:auto;color:#a5b4c8;white-space:pre-wrap;word-break:break-all;
  max-height:300px;overflow-y:auto;
}

/* ── Attack Chain ── */
.chain{display:flex;flex-direction:column;gap:0}
.chain-step{
  display:flex;gap:1rem;padding:.75rem 0;position:relative;
}
.chain-step::before{
  content:'';position:absolute;left:11px;top:28px;bottom:0;width:2px;
  background:var(--border);
}
.chain-step:last-child::before{display:none}
.chain-dot{
  width:24px;height:24px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:.6rem;font-weight:700;font-family:var(--mono);
  border:2px solid var(--cyan);color:var(--cyan);background:var(--bg-1);
  z-index:1;
}
.chain-body{flex:1}
.chain-phase{font-size:.75rem;text-transform:uppercase;letter-spacing:1px;color:var(--cyan);font-weight:600;margin-bottom:.3rem}
.chain-desc{font-size:.82rem;line-height:1.55;color:var(--text-dim)}

/* ── Archetype Card ── */
.arch-card{
  background:var(--bg-2);border:1px solid var(--border);border-radius:12px;
  padding:1.2rem;transition:border-color .3s;
}
.arch-card:hover{border-color:var(--cyan)}
.arch-name{font-family:var(--mono);font-size:.85rem;color:var(--cyan);margin-bottom:.4rem}
.arch-meta{font-size:.72rem;color:var(--text-dim);margin-bottom:.6rem;display:flex;gap:8px;align-items:center}
.arch-bar{height:4px;border-radius:2px;background:var(--bg-3);overflow:hidden;margin-bottom:.5rem}
.arch-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--cyan),var(--green));transition:width .6s}

.money{color:var(--green);font-family:var(--mono)}
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:340px;display:inline-block;vertical-align:bottom}
.link{color:var(--cyan);text-decoration:none;cursor:pointer}
.link:hover{text-decoration:underline}

/* ── Footer ── */
.footer{
  text-align:center;padding:2rem;color:var(--text-muted);font-size:.72rem;
  letter-spacing:1px;border-top:1px solid var(--border);margin-top:2rem;
}

/* ── Loading ── */
.loading{text-align:center;padding:3rem;color:var(--text-muted)}
.loading .spinner{
  display:inline-block;width:24px;height:24px;border:2px solid var(--border);
  border-top-color:var(--cyan);border-radius:50%;animation:spin .6s linear infinite;
  margin-bottom:.5rem;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Responsive ── */
@media(max-width:1100px){.g4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){
  .g4,.g3,.g2{grid-template-columns:1fr}
  .header-inner{flex-direction:column;height:auto;padding:1rem 0;gap:.75rem}
  .tabs{overflow-x:auto;width:100%;padding-bottom:.5rem}
  .global-search{width:100%}
  .main{padding:1rem}
}
