:root{--text: #6b6375;--text-h: #08060d;--bg: #fff;--border: #e5e4e7;--code-bg: #f4f3ec;--accent: #aa3bff;--accent-bg: rgba(170, 59, 255, .1);--accent-border: rgba(170, 59, 255, .5);--social-bg: rgba(244, 243, 236, .5);--shadow: rgba(0, 0, 0, .1) 0 10px 15px -3px, rgba(0, 0, 0, .05) 0 4px 6px -2px;--sans: system-ui, "Segoe UI", Roboto, sans-serif;--heading: system-ui, "Segoe UI", Roboto, sans-serif;--mono: ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (max-width: 1024px){:root{font-size:16px}}@media (prefers-color-scheme: dark){:root{--text: #9ca3af;--text-h: #f3f4f6;--bg: #16171d;--border: #2e303a;--code-bg: #1f2028;--accent: #c084fc;--accent-bg: rgba(192, 132, 252, .15);--accent-border: rgba(192, 132, 252, .5);--social-bg: rgba(47, 48, 58, .5);--shadow: rgba(0, 0, 0, .4) 0 10px 15px -3px, rgba(0, 0, 0, .25) 0 4px 6px -2px}#social .button-icon{filter:invert(1) brightness(2)}}body{margin:0}#root{width:100%;min-height:100svh;display:flex;flex-direction:column;box-sizing:border-box}h1,h2{font-family:var(--heading);font-weight:500;color:var(--text-h)}h1{font-size:56px;letter-spacing:-1.68px;margin:32px 0}@media (max-width: 1024px){h1{font-size:36px;margin:20px 0}}h2{font-size:24px;line-height:118%;letter-spacing:-.24px;margin:0 0 8px}@media (max-width: 1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);display:inline-flex;border-radius:4px;color:var(--text-h)}code{font-size:15px;line-height:135%;padding:4px 8px;background:var(--code-bg)}@keyframes spin{to{transform:rotate(360deg)}}.page{display:flex;flex-direction:column;height:100vh;width:100vw;background:#f5f4f0;font-family:DM Mono,IBM Plex Mono,Courier New,monospace;overflow:hidden}.header{display:flex;align-items:center;gap:20px;padding:10px 20px;background:#111;border-bottom:1px solid #333;flex-shrink:0;flex-wrap:wrap}.wordmark{display:flex;align-items:baseline;gap:6px}.w-primary{color:#fff;font-weight:700;font-size:18px;letter-spacing:.08em}.w-div{color:#555;font-size:18px}.w-secondary{color:#9ca3af;font-weight:400;font-size:14px}.search-wrap{flex:1;min-width:220px;max-width:520px;display:flex;align-items:center;background:#1f1f1f;border:1px solid #333;border-radius:6px;padding:0 4px 0 10px;gap:4px}.search-icon{width:16px;height:16px;flex-shrink:0}.search-input{flex:1;background:transparent;border:none;outline:none;color:#e5e7eb;font-family:inherit;font-size:13px;padding:8px 6px}.clear-btn{background:none;border:none;color:#6b7280;cursor:pointer;font-size:12px;padding:0 4px}.search-btn{background:#1d4ed8;color:#fff;border:none;border-radius:4px;font-family:inherit;font-size:12px;font-weight:600;padding:5px 12px;cursor:pointer;flex-shrink:0}.body{display:flex;flex:1;overflow:hidden}.map-area{flex:1;position:relative;background:#e8e6e0;display:flex;align-items:center;justify-content:center}.load-state{display:flex;flex-direction:column;align-items:center;justify-content:center}.spinner{width:32px;height:32px;border-radius:50%;border:3px solid #d1d5db;border-top-color:#111;animation:spin .7s linear infinite}.spinner-sm{width:12px;height:12px;border-radius:50%;border:2px solid #9ca3af;border-top-color:#1d4ed8;animation:spin .7s linear infinite;display:inline-block;margin-right:6px;flex-shrink:0}.fetching-overlay{position:absolute;bottom:20px;left:50%;transform:translate(-50%);background:rgba(255,255,255,.92);border-radius:6px;padding:8px 16px;font-size:12px;color:#374151;display:flex;align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);gap:6px}.error-banner{position:absolute;bottom:20px;left:50%;transform:translate(-50%);background:#fef2f2;border:1px solid #fca5a5;color:#dc2626;border-radius:6px;padding:8px 16px;font-size:12px;max-width:80%}.empty-prompt{position:absolute;bottom:20px;left:50%;transform:translate(-50%);background:rgba(255,255,255,.85);border-radius:6px;padding:8px 16px;font-size:12px;color:#6b7280;white-space:nowrap;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.sidebar{width:240px;flex-shrink:0;background:#fff;border-left:1px solid #e5e7eb;display:flex;flex-direction:column;overflow-y:auto}.side-section{padding:14px 16px;border-bottom:1px solid #f0f0f0;flex-shrink:0}.section-title{font-size:10px;color:#9ca3af;text-transform:uppercase;letter-spacing:.08em;display:block;margin-bottom:6px}.meta-label{font-size:10px;color:#9ca3af;text-transform:uppercase;letter-spacing:.08em}.meta-value{font-size:13px;color:#111;font-weight:600;margin-top:2px}.table-link{display:inline-block;margin-top:10px;font-size:11px;color:#1d4ed8;text-decoration:none;border-bottom:1px solid #bfdbfe;padding-bottom:1px}.filter-section{border-bottom:1px solid #f0f0f0;flex-shrink:0;display:flex;flex-direction:column}.filter-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px 4px;flex-shrink:0}.fetching-badge{font-size:10px;color:#9ca3af;font-style:italic}.filter-scroll{padding:4px 16px 12px;display:flex;flex-direction:column;gap:10px}.dim-filter{display:flex;flex-direction:column;gap:3px}.dim-label{font-size:10px;color:#6b7280;text-transform:uppercase;letter-spacing:.06em}.dim-select{background:#f9fafb;border:1px solid #e5e7eb;border-radius:4px;font-family:inherit;font-size:11px;color:#111;padding:4px 6px;cursor:pointer;width:100%;max-width:100%}.filter-action-btn{background:#111;color:#fff;border:none;border-radius:4px;font-family:inherit;font-size:11px;font-weight:600;padding:6px 12px;cursor:pointer;width:100%;text-align:center;margin-top:4px}.legend-labels{display:flex;justify-content:space-between;font-size:10px;color:#6b7280}.legend-na{display:flex;align-items:center;gap:6px;font-size:10px;color:#6b7280;margin-top:6px}.na-box{display:inline-block;width:12px;height:12px;background:#d4d4d4;border-radius:2px;flex-shrink:0}.detail-card{padding:14px 16px;border-bottom:1px solid #f0f0f0;position:relative;background:#fafafa;flex-shrink:0}.detail-name{font-size:12px;font-weight:700;color:#111;margin-bottom:4px}.detail-value{font-size:22px;font-weight:700;color:#1d4ed8;line-height:1.1}.detail-meta{font-size:10px;color:#9ca3af;margin-top:4px}.close-btn{position:absolute;top:10px;right:10px;background:none;border:none;color:#9ca3af;cursor:pointer;font-size:12px}.hint-card{padding:14px 16px;border-bottom:1px solid #f0f0f0;font-size:11px;color:#9ca3af;font-style:italic;flex-shrink:0}.rank-card{flex:1;padding:14px 16px;min-height:200px}.rank-row{display:flex;align-items:center;gap:8px;padding:5px 4px;border-radius:4px;transition:background .1s;cursor:pointer}.rank-num{font-size:10px;color:#d1d5db;width:16px;text-align:right;flex-shrink:0}.rank-name{font-size:11px;color:#374151;flex:1}.rank-val{font-size:11px;color:#111;font-weight:600}.tooltip{position:fixed;z-index:1000;pointer-events:none;background:#111;color:#fff;border-radius:6px;padding:8px 12px;box-shadow:0 4px 16px #00000040}.tt-name{font-size:11px;color:#9ca3af;margin-bottom:2px}.tt-val{font-size:14px;font-weight:700}.header-link-wrap{margin-left:auto}.header-link-wrap a{color:#60a5fa;font-size:12px;text-decoration:none;transition:color .15s ease}.header-link-wrap a:hover{color:#93c5fd;text-decoration:underline}frontend/src/App.css *{margin:0;padding:0;box-sizing:border-box}body{background:linear-gradient(135deg,#f5f7fa 0%,#c3cfe2 100%);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif}.App{min-height:100vh;padding:20px}@media (max-width: 768px){.App{padding:12px}}
