@font-face {
  font-family: 'UbuntuSansMono';
  src: url('../fonts/UbuntuSansMono-Regular.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'UbuntuSansMono';
  src: url('../fonts/UbuntuSansMono-Bold.ttf') format('truetype');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'UbuntuSansMono';
  src: url('../fonts/UbuntuSansMono-Italic.ttf') format('truetype');
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'UbuntuSansMono';
  src: url('../fonts/UbuntuSansMono-BoldItalic.ttf') format('truetype');
  font-weight: 700;
  font-style: italic;
  font-display: swap;
}

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

:root {
  --gb-bg0h:#1d2021; --gb-bg0:#282828; --gb-bg0s:#32302f;
  --gb-bg1:#3c3836;  --gb-bg2:#504945; --gb-bg3:#665c54; --gb-bg4:#7c6f64;
  --gb-fg0:#fbf1c7;  --gb-fg1:#ebdbb2; --gb-fg2:#d5c4a1; --gb-fg3:#bdae93; --gb-fg4:#a89984;
  --gb-red:#fb4934;  --gb-green:#b8bb26; --gb-yellow:#fabd2f; --gb-blue:#83a598;
  --gb-purple:#d3869b; --gb-aqua:#8ec07c; --gb-orange:#fe8019;
  --gb-red-d:#cc241d; --gb-green-d:#98971a; --gb-yellow-d:#d79921; --gb-blue-d:#458588;
  --gb-purple-d:#b16286; --gb-aqua-d:#689d6a; --gb-orange-d:#d65d0e;
  --mono:'UbuntuSansMono','Cascadia Code','Fira Code','JetBrains Mono',ui-monospace,'Courier New',monospace;
}

[data-theme="light"] {
  --gb-bg0h:#f9f5d7; --gb-bg0:#fbf1c7; --gb-bg0s:#f2e5bc;
  --gb-bg1:#ebdbb2;  --gb-bg2:#d5c4a1; --gb-bg3:#bdae93; --gb-bg4:#a89984;
  --gb-fg0:#282828;  --gb-fg1:#3c3836; --gb-fg2:#504945; --gb-fg3:#665c54; --gb-fg4:#7c6f64;
  --gb-red:#cc241d;  --gb-green:#98971a; --gb-yellow:#d79921; --gb-blue:#458588;
  --gb-purple:#b16286; --gb-aqua:#689d6a; --gb-orange:#d65d0e;
  --gb-red-d:#9d0006; --gb-green-d:#79740e; --gb-yellow-d:#b57614; --gb-blue-d:#076678;
  --gb-purple-d:#8f3f71; --gb-aqua-d:#427b58; --gb-orange-d:#af3a03;
}

html, body {
  min-height: 100vh;
  background: var(--gb-bg0h);
  color: var(--gb-fg1);
  font-family: var(--mono);
  font-size: 13px;
  line-height: 1.5;
}
body { padding: 20px; }

/* Header */
.hdr { display:flex; align-items:flex-end; justify-content:space-between; flex-wrap:wrap; gap:12px; margin-bottom:18px; padding-bottom:16px; border-bottom:1px solid var(--gb-bg2); }
.hdr h1 { font-size:17px; font-weight:700; color:var(--gb-yellow); letter-spacing:0.02em; line-height:1.2; }
.hdr .sub { font-size:10px; color:var(--gb-bg4); margin-top:3px; letter-spacing:0.08em; text-transform:uppercase; }

/* Mode tabs */
.mode-tabs { display:flex; gap:2px; background:var(--gb-bg1); padding:3px; border-radius:6px; border:1px solid var(--gb-bg2); }
.mode-tab { padding:6px 14px; border-radius:4px; border:none; background:transparent; color:var(--gb-fg4); font-family:var(--mono); font-size:11px; font-weight:600; cursor:pointer; transition:all 0.15s; text-transform:uppercase; letter-spacing:0.04em; white-space:nowrap; }
.mode-tab:hover { background:var(--gb-bg2); color:var(--gb-fg2); }
.mode-tab.active[data-mode="animal"] { background:var(--gb-orange-d); color:var(--gb-fg0); }
.mode-tab.active[data-mode="nam"]    { background:var(--gb-blue-d);   color:var(--gb-fg0); }
.mode-tab.active[data-mode="ratio"]  { background:var(--gb-purple-d); color:var(--gb-fg0); }

/* Stats row */
.stats { display:grid; grid-template-columns:repeat(auto-fit,minmax(140px,1fr)); gap:10px; margin-bottom:18px; }
.stat { background:var(--gb-bg0s); border:1px solid var(--gb-bg2); border-radius:8px; padding:12px 16px; }
.stat-lbl { font-size:10px; color:var(--gb-bg4); text-transform:uppercase; letter-spacing:0.08em; margin-bottom:4px; }
.stat-val { font-size:22px; font-weight:700; letter-spacing:-0.02em; line-height:1.1; }
.stat-val.a { color:var(--gb-orange); }
.stat-val.n { color:var(--gb-blue); }
.stat-val.r { color:var(--gb-purple); }
.stat-val.c { color:var(--gb-yellow); }
.stat-sub { font-size:10px; color:var(--gb-bg3); margin-top:2px; }

/* Card */
.card { background:var(--gb-bg0s); border:1px solid var(--gb-bg2); border-radius:8px; overflow:hidden; margin-bottom:18px; }
.card-hdr { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:8px; padding:10px 16px; border-bottom:1px solid var(--gb-bg2); background:var(--gb-bg1); }
.card-ttl { font-size:10px; text-transform:uppercase; letter-spacing:0.1em; color:var(--gb-bg4); font-weight:600; }

/* Map */
#map-svg { display:block; width:100%; height:430px; background:var(--gb-bg0s); cursor:default; }
.cpth { stroke:var(--gb-bg2); stroke-width:0.4px; cursor:pointer; transition:opacity 0.1s; }
.cpth:hover { opacity:0.7; stroke:var(--gb-fg4); stroke-width:1px; }
.cpth.sel { stroke:var(--gb-yellow) !important; stroke-width:2px !important; opacity:1 !important; }
.cpth.nd  { fill:var(--gb-bg0h) !important; cursor:default; }
.cpth.nd:hover { opacity:1; stroke:var(--gb-bg1) !important; stroke-width:0.4px !important; }

/* Map footer */
.map-foot { display:flex; align-items:center; gap:12px; padding:10px 16px; border-top:1px solid var(--gb-bg2); background:var(--gb-bg1); flex-wrap:wrap; }
.leg-lbl { font-size:10px; color:var(--gb-bg4); text-transform:uppercase; letter-spacing:0.06em; white-space:nowrap; }
#leg-ramp { display:flex; gap:2px; align-items:center; }
.leg-sw { width:20px; height:9px; border-radius:2px; display:inline-block; }
.sel-info { margin-left:auto; font-size:11px; color:var(--gb-fg4); }
.sel-info span { color:var(--gb-yellow); font-weight:700; }

/* Tooltip */
#tt { position:fixed; background:var(--gb-bg0h); border:1px solid var(--gb-bg3); border-radius:6px; padding:10px 14px; pointer-events:none; opacity:0; transition:opacity 0.1s; z-index:999; min-width:170px; box-shadow:0 6px 24px rgba(0,0,0,0.6); }
#tt.vis { opacity:1; }
#tt .tn  { font-size:13px; font-weight:700; color:var(--gb-yellow); margin-bottom:6px; border-bottom:1px solid var(--gb-bg2); padding-bottom:5px; }
#tt .tr  { display:flex; justify-content:space-between; gap:16px; font-size:11px; margin-top:3px; }
#tt .tk  { color:var(--gb-bg4); }
#tt .tv  { font-weight:700; }
#tt .ta  { color:var(--gb-orange); }
#tt .tn2 { color:var(--gb-blue); }
#tt .tr2 { color:var(--gb-purple); }
#tt .th  { font-size:10px; color:var(--gb-bg3); margin-top:7px; text-align:center; }

/* Chips */
.chips { display:flex; gap:6px; flex-wrap:wrap; align-items:center; padding:10px 16px; border-bottom:1px solid var(--gb-bg2); }
.chip { display:inline-flex; align-items:center; gap:5px; padding:3px 8px; border-radius:4px; font-size:10px; font-weight:600; letter-spacing:0.04em; background:var(--gb-bg2); color:var(--gb-fg2); text-transform:uppercase; border:1px solid var(--gb-bg3); }
.chipdot { width:7px; height:7px; border-radius:50%; flex-shrink:0; }
.chipx { cursor:pointer; color:var(--gb-bg4); margin-left:3px; font-size:13px; line-height:1; }
.chipx:hover { color:var(--gb-red); }
.chips-hint { font-size:10px; color:var(--gb-bg3); text-transform:uppercase; letter-spacing:0.06em; }

/* Chart view tabs */
.cv-tabs { display:flex; gap:2px; background:var(--gb-bg0s); padding:3px; border-radius:5px; border:1px solid var(--gb-bg2); }
.cv-tab  { padding:4px 10px; border-radius:3px; border:none; background:transparent; color:var(--gb-bg4); font-family:var(--mono); font-size:10px; font-weight:600; cursor:pointer; transition:all 0.12s; text-transform:uppercase; letter-spacing:0.04em; }
.cv-tab:hover  { background:var(--gb-bg2); color:var(--gb-fg3); }
.cv-tab.active { background:var(--gb-bg3); color:var(--gb-fg1); }

/* Chart area */
.chart-body { padding:16px; }
.no-sel { text-align:center; padding:56px 20px; color:var(--gb-bg3); font-size:11px; letter-spacing:0.05em; text-transform:uppercase; }
.no-sel span { display:block; font-size:30px; margin-bottom:10px; color:var(--gb-bg2); }
.chart-wrap { position:relative; width:100%; height:320px; }

/* Search */
#search-dropdown div { transition: background 0.1s; }

/* Scrollbar */
::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:var(--gb-bg1); }
::-webkit-scrollbar-thumb { background:var(--gb-bg3); border-radius:3px; }

/* Demo notice overlay */
#demo-notice {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  background: rgba(29, 32, 33, 0.75);
}
[data-theme="light"] #demo-notice {
  background: rgba(249, 245, 215, 0.75);
}
.notice-box {
  background: var(--gb-bg0s);
  border: 1px solid var(--gb-yellow);
  border-radius: 10px;
  padding: 32px 40px;
  max-width: 480px;
  width: 90%;
  text-align: center;
  box-shadow: 0 12px 48px rgba(0,0,0,0.7);
}
.notice-box .notice-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--gb-yellow);
  letter-spacing: 0.04em;
  margin-bottom: 14px;
}
.notice-box .notice-body {
  font-size: 12px;
  color: var(--gb-fg3);
  line-height: 1.7;
  margin-bottom: 24px;
}
.notice-box .notice-body strong {
  color: var(--gb-orange);
}
.notice-dismiss {
  background: var(--gb-bg2);
  border: 1px solid var(--gb-bg3);
  border-radius: 5px;
  color: var(--gb-fg2);
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 600;
  padding: 8px 24px;
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  transition: all 0.15s;
}
.notice-dismiss:hover {
  background: var(--gb-bg3);
  color: var(--gb-fg0);
  border-color: var(--gb-yellow);
}
