:root{
  /* dark theme defaults */
  --bg:#0b1020; /* deep navy */
  --panel:#121a2e;
  --text:#e8eefc;
  --muted:#93a2c6;
  --accent:#60a5fa;
  --border:#1f2b4a;
  --code-bg:#0f1a31;
}
[data-theme="light"]{
  --bg:#f6f7fb;
  --panel:#ffffff;
  --text:#1a2238;
  --muted:#55627a;
  --accent:#1d4ed8;
  --border:#d6d9e2;
  --code-bg:#f1f3f9;
}
*{box-sizing:border-box}
html,body{height:100%;margin:0;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,"Noto Sans TC",sans-serif}
.container{width:min(1100px,96%);margin:0 auto}
.topbar{background:var(--panel);border-bottom:1px solid var(--border)}
.topbar h1{margin:0;padding:14px 0;font-weight:700}
.topbar .meta{display:flex;gap:16px;flex-wrap:wrap;padding-bottom:12px;color:var(--muted)}
.topbar .meta a{color:#fff;text-decoration:none}
.topbar .meta a:hover{text-decoration:underline}
code{background:var(--code-bg);color:var(--text);padding:0 6px;border-radius:4px}
main{padding:16px 0}
#map{height:72vh;border:1px solid var(--border);border-radius:8px;box-shadow:0 0 0 1px rgba(255,255,255,.02) inset}
.help{margin-top:12px;color:var(--muted)}
.help summary{cursor:pointer;color:var(--accent)}

/* browse list */
.list{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;margin-top:16px}
.card{display:block;padding:14px 16px;background:var(--panel);border:1px solid var(--border);border-radius:10px;color:var(--text);text-decoration:none}
.card:hover{border-color:var(--accent)}
.card .title{font-weight:700;margin-bottom:6px}
.card .sub{color:var(--muted);font-size:12px;margin-bottom:8px}
.card .stats{display:flex;gap:12px;color:var(--muted);font-size:12px}

/* select */
select{background:var(--panel);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:4px 8px}

/* theme toggle */
.theme-toggle{background:transparent;color:var(--text);border:1px solid var(--border);border-radius:6px;padding:4px 10px;cursor:pointer}
.theme-toggle:hover{border-color:var(--accent)}

/* footer */
.footer{margin-top:16px;border-top:1px solid var(--border);background:transparent}
.footer .container{padding:12px 0;color:var(--muted)}
.footer a{color:var(--accent);text-decoration:none}
.footer a:hover{text-decoration:underline}
