:root{
  --bg:#0a0e14; --panel:#0f1620; --line:rgba(61,168,201,.22);
  --cyan:#3da8c9; --cyan-b:#5fd0e8; --ink:#dfe7ee; --mut:#7d8a99;
  --ok:#6fd0a0; --pend:#5b6675; --gold:#d6b25a;
  --mono:'JetBrains Mono',ui-monospace,Menlo,monospace;
  --sans:'Noto Sans SC',-apple-system,sans-serif;
}

/* ===== Light theme (blueprint 浅色) ===== */
[data-theme="light"]{
  --bg:#eef1f5; --panel:#ffffff; --line:rgba(27,110,140,.20);
  --cyan:#1b6e8c; --cyan-b:#155a73; --ink:#16202a; --mut:#5b6b78;
  --ok:#1f8f63; --pend:#93a0ab; --gold:#9a7b2e;
}
[data-theme="light"] body{background:radial-gradient(1100px 520px at 50% -8%, rgba(27,110,140,.10), transparent 70%), var(--bg)}
[data-theme="light"] .topbar{background:rgba(255,255,255,.85)}

/* theme toggle button + icon swap */
.theme-btn{flex:none;width:34px;height:34px;display:grid;place-items:center;background:transparent;
  border:1px solid var(--line);border-radius:8px;color:var(--cyan);cursor:pointer;transition:border-color .15s,color .15s}
.theme-btn:hover{border-color:var(--cyan);color:var(--cyan-b)}
.theme-btn svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.6}
.tb-right{display:flex;align-items:center;gap:14px}
.ico-sun{display:none}
[data-theme="light"] .ico-moon{display:none}
[data-theme="light"] .ico-sun{display:block}
*{box-sizing:border-box;margin:0;padding:0}
body{
  background:radial-gradient(1100px 520px at 50% -8%, rgba(61,168,201,.07), transparent 70%), var(--bg);
  color:var(--ink);font-family:var(--sans);line-height:1.6;min-height:100vh;
}
.topbar{
  display:flex;align-items:center;justify-content:space-between;padding:16px 22px;
  border-bottom:1px solid var(--line);background:rgba(10,14,20,.82);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);position:sticky;top:0;z-index:10;
}
.brand{font-family:var(--mono);letter-spacing:.12em;font-size:15px}
.brand b{color:var(--cyan-b)} .brand .mk{color:var(--cyan)}
.sector{font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--mut)}
.banner{
  font-family:var(--mono);font-size:11px;letter-spacing:.05em;color:var(--mut);
  padding:8px 22px;border-bottom:1px solid var(--line);background:var(--panel);
}
.tree{max-width:1000px;margin:0 auto;padding:28px 18px 80px}

/* ---- collapsible pyramid tree ---- */
.node>.kids{display:none;margin-left:18px;border-left:1px solid rgba(61,168,201,.35);padding-left:16px;position:relative}
.node.open>.kids{display:block}
/* horizontal connector stub from vertical spine to each child row */
.kids>.node>.row{position:relative}
.kids>.node>.row::before{content:"";position:absolute;left:-16px;top:17px;width:12px;height:1px;background:rgba(61,168,201,.45)}
.row{display:flex;align-items:center;gap:10px;padding:7px 8px;border-radius:6px;cursor:default;font-family:var(--mono)}
.row.has-kids{cursor:pointer}
.row.has-kids:hover{background:var(--panel)}
.tw{color:var(--cyan);width:14px;font-size:12px;flex:none}
.tw.dot{color:var(--pend)}
.nm{color:var(--ink);font-size:14px}
.role{color:var(--mut);font-size:11px;font-family:var(--sans)}
.badge{font-size:9px;letter-spacing:.1em;color:var(--gold);border:1px solid rgba(214,178,90,.4);border-radius:3px;padding:1px 5px;flex:none}
.cos{margin:2px 0 6px 24px;display:flex;flex-direction:column;gap:3px}
.co{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:12px}
.cn{color:var(--ink)} .tk{color:var(--cyan-b);font-size:11px}
.px{font-size:11px;margin-left:auto;flex:none} .px.ok{color:var(--ok)} .px.pend,.px.priv{color:var(--pend)}
.as{color:var(--mut);font-size:10px;margin-left:6px;flex:none}
@media(max-width:560px){
  .role{display:none}
  .tree{padding:18px 12px 60px}
  .co{flex-wrap:wrap;gap:4px}
}

/* ---- homepage: sector navigation ---- */
.topbar a.brand{text-decoration:none;color:inherit}
.hero{max-width:1000px;margin:0 auto;padding:34px 22px 6px}
.hero h1{font-size:clamp(22px,3.4vw,34px);font-weight:700;letter-spacing:-.01em;color:var(--ink)}
.hero p{color:var(--mut);font-size:14px;margin-top:12px;max-width:760px}
.hero p b{color:var(--cyan-b)}
.hero .note{font-family:var(--mono);font-size:11px;color:var(--pend);margin-top:14px;letter-spacing:.04em}
.sectors{max-width:1000px;margin:0 auto;padding:18px 22px 80px}
.layer{margin-top:30px}
.layer-h{font-family:var(--mono);font-size:12px;letter-spacing:.18em;color:var(--mut);margin-bottom:14px;border-bottom:1px solid var(--line);padding-bottom:8px}
.layer-h .lk{color:var(--cyan);border:1px solid var(--line);border-radius:4px;padding:1px 7px;margin-right:8px}
.layer-h .le{color:var(--pend);font-size:10px;margin-left:8px}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
.sc{display:block;text-decoration:none;color:inherit;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:16px;transition:border-color .15s,transform .15s}
.sc.live{cursor:pointer}
.sc.live:hover{border-color:var(--cyan);transform:translateY(-2px)}
.sc:not(.live){opacity:.6}
.sc-head{display:flex;align-items:center;gap:10px}
.sc-head .ic{font-size:22px;flex:none}
.sc-name{font-size:16px;font-weight:600;color:var(--ink)}
.sc-en{font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--pend)}
.st{margin-left:auto;flex:none;font-family:var(--mono);font-size:10px;color:var(--pend);border:1px solid var(--line);border-radius:4px;padding:2px 7px}
.st.live{color:var(--ok);border-color:rgba(111,208,160,.4)}
.sc-flag{font-size:12px;color:var(--mut);margin:12px 0 10px;font-family:var(--mono)}
.sc-bs{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.sc-bs .bl{font-size:10px;color:var(--gold);font-family:var(--mono);letter-spacing:.1em}
.bs{font-size:11px;color:var(--cyan-b);background:rgba(61,168,201,.1);border:1px solid var(--line);border-radius:4px;padding:1px 7px}
.ic-dot{width:9px;height:9px;border-radius:50%;background:var(--pend);flex:none}
.ic-dot.on{background:var(--cyan);box-shadow:0 0 8px var(--cyan)}
.bs-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--cyan);box-shadow:0 0 6px var(--cyan);margin-right:7px;vertical-align:middle}
.back{display:inline-block;font-family:var(--mono);font-size:11px;color:var(--mut);padding:12px 22px 0;text-decoration:none}
.back:hover{color:var(--cyan-b)}
.back-fab{position:fixed;left:16px;bottom:18px;z-index:50;width:40px;height:40px;border-radius:50%;
  display:grid;place-items:center;background:var(--panel);border:1px solid var(--cyan);color:var(--cyan-b);
  text-decoration:none;font-size:18px;box-shadow:0 0 12px rgba(61,168,201,.25);transition:transform .15s}
.back-fab:hover{transform:translateY(-2px)}
.planned{color:var(--mut);font-family:var(--mono);font-size:13px;padding:40px 8px;line-height:2}
.planned span{color:var(--pend);font-size:11px}
.rank-link{display:inline-block;margin-top:18px;font-family:var(--mono);font-size:12px;color:var(--gold);
  border:1px solid var(--gold-line);border-radius:6px;padding:8px 14px;text-decoration:none;transition:background .15s}
.rank-link:hover{background:var(--gold-soft)}

/* ---- ranking / hidden winners ---- */
.rank{max-width:1000px;margin:0 auto;padding:10px 22px 80px;display:flex;flex-direction:column;gap:8px}
.rk{display:flex;align-items:center;gap:14px;background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:12px 14px}
.rk.winner{border-color:rgba(214,178,90,.5);box-shadow:0 0 0 1px rgba(214,178,90,.12) inset}
.rk-no{font-family:var(--mono);font-size:13px;color:var(--pend);width:26px;flex:none;text-align:right}
.rk.winner .rk-no{color:var(--gold)}
.rk-main{flex:1;min-width:0}
.rk-top{display:flex;align-items:center;gap:10px;font-family:var(--mono)}
.rk-top .cn{color:var(--ink);font-size:14px}
.rk-top .tk{color:var(--cyan-b);font-size:11px}
.rk-top .px{margin-left:auto;flex:none}
.rk-sec{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}
.rk-stat{flex:none;text-align:center;font-family:var(--mono);min-width:54px}
.rk-stat b{display:block;font-size:20px;color:var(--cyan)}
.rk.winner .rk-stat b{color:var(--gold)}
.rk-stat span{font-size:9px;color:var(--mut);letter-spacing:.1em}
.rk-stat i{display:block;font-size:10px;color:var(--pend);font-style:normal;margin-top:2px}
@media(max-width:560px){.rk-top .px{margin-left:0}.rk-top{flex-wrap:wrap;gap:6px}}
