:root{--bg:#f0ead8;--surface:#faf7ee;--surface2:#eee8d0;--border:#c8c084;--accent:#6b7a2e;--accent2:#8b6914;--accent3:#5a6e22;--text:#2a2a10;--muted:#5c5c30;--text-on-accent:#fff;--font-mono:"Courier New", monospace;--danger:#b54a3f;--danger-bg:#b54a3f1f;--grad-header:linear-gradient(135deg, #d8d4a0 0%, #c8c47a 50%, #b8b460 100%);--grad-card:linear-gradient(145deg, #fdfbf0 0%, #f5f0d8 100%);--grad-accent:linear-gradient(135deg, #7d8f32 0%, #5a6e22 100%);--grad-surface2:linear-gradient(135deg, #e8e4c0 0%, #d8d49a 100%);--grad-bg:linear-gradient(160deg, #f5ead8 0%, #ede6cc 40%, #e5dfc0 100%);--shadow-card:0 2px 12px #5a50141a, 0 1px 3px #5a501412;--shadow-hover:0 6px 24px #5a501429, 0 2px 6px #5a50141a}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{min-height:100vh}body{background:var(--grad-bg);color:var(--text);background-attachment:fixed;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6}button{font-family:inherit}:focus-visible{outline:2px solid var(--accent3);outline-offset:2px}@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}.app-header{border-bottom:1px solid var(--border);background:var(--grad-header);z-index:100;flex-wrap:wrap;align-items:center;gap:1rem;padding:1.1rem 2rem;display:flex;position:sticky;top:0;box-shadow:0 2px 16px #5a50142e}.logo{background:var(--grad-accent);border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:16px;display:flex;box-shadow:0 2px 6px #0000002e,inset 0 1px 1px #ffffff4d}.app-header h1{letter-spacing:-.01em;color:#1e1e08;text-shadow:0 1px 2px #fff6;font-size:1rem;font-weight:700}.nav-tabs{gap:.25rem;margin-left:auto;display:flex}.nav-tab{color:#2a2a10;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff40;border:1px solid #b4aa5066;border-radius:6px;padding:.35rem .9rem;font-size:.82rem;font-weight:500;transition:all .15s}.nav-tab:hover{color:#1a1a08;border-color:var(--border);background:#ffffff73;box-shadow:0 1px 4px #5a501426}.nav-tab.active{border-color:var(--accent);color:#fff;background:var(--grad-accent);box-shadow:0 2px 8px #5a6e2259,inset 0 1px 1px #fff3}.container{max-width:1200px;margin:0 auto;padding:2rem}.section-label{text-transform:uppercase;letter-spacing:.09em;color:var(--muted);margin-bottom:1rem;font-size:.75rem;font-weight:600}.card{background:var(--grad-card);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:14px;padding:1.5rem}.card-title{margin-bottom:.5rem;font-size:.95rem;font-weight:700}.card-desc{color:var(--muted);margin-bottom:1rem;font-size:.85rem}.city-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.city-card{background:var(--grad-card);border:1.5px solid var(--border);cursor:pointer;box-shadow:var(--shadow-card);text-align:left;border-radius:12px;padding:1.1rem;transition:border-color .15s,box-shadow .15s,transform .1s}.city-card:hover{border-color:var(--accent);box-shadow:var(--shadow-hover);transform:translateY(-1px)}.city-card.selected{border-color:var(--accent3);background:var(--grad-accent);color:#fff}.city-card .city-name{font-size:.95rem;font-weight:700}.city-card .city-meta{opacity:.8;margin-top:.25rem;font-size:.75rem}.weight-controls{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin:1.5rem 0;display:grid}.weight-control label{justify-content:space-between;margin-bottom:.4rem;font-size:.85rem;font-weight:600;display:flex}.weight-control .weight-value{font-family:var(--font-mono);color:var(--accent3)}.weight-control input[type=range]{width:100%;accent-color:var(--accent)}.weight-control .weight-hint{color:var(--muted);margin-top:.3rem;font-size:.72rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.stat-card{background:var(--grad-card);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:12px;padding:1rem 1.1rem}.stat-label{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-size:.7rem;font-weight:600}.stat-value{font-size:1.6rem;font-weight:800;font-family:var(--font-mono);margin:.2rem 0}.stat-value.warn{color:var(--accent2)}.stat-value.danger{color:var(--danger)}.stat-sub{color:var(--accent3);font-size:.75rem;font-weight:600}.stat-hint{color:var(--muted);margin-top:.35rem;font-size:.72rem}.model-card{background:var(--grad-card);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:14px;margin-bottom:1.5rem;padding:1.5rem}.model-title{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:.6rem;font-size:.9rem;font-weight:700}.equation{font-family:var(--font-mono);background:var(--surface2);border-radius:8px;margin-bottom:.8rem;padding:.7rem 1rem;font-size:.95rem;overflow-x:auto}.model-explain{margin-bottom:.8rem;font-size:.85rem}.corr-row{flex-wrap:wrap;gap:1.5rem;font-size:.82rem;display:flex}.charts-grid{grid-template-columns:1fr 1fr;gap:1.2rem;margin-bottom:1.5rem;display:grid}.chart-card{background:var(--grad-card);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:14px;padding:1.2rem}.chart-card.wide{grid-column:1/-1}.chart-title{margin-bottom:.3rem;font-size:.88rem;font-weight:700}.chart-desc{color:var(--muted);margin-bottom:.8rem;font-size:.78rem}.chart-wrap{height:260px;position:relative}@media (width<=800px){.charts-grid{grid-template-columns:1fr}}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.82rem}th,td{text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;padding:.5rem .7rem}th{background:var(--surface2);text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-size:.72rem;font-weight:700}tr.anomaly td{background:var(--danger-bg);color:var(--danger);font-weight:600}.status-banner{border-radius:10px;align-items:center;gap:.6rem;margin-bottom:1.2rem;padding:.8rem 1.1rem;font-size:.85rem;display:flex}.status-banner.loading{background:var(--surface2);color:var(--muted)}.status-banner.error{background:var(--danger-bg);color:var(--danger)}.status-banner.info{color:var(--accent3);background:#78793f26}.spinner{border:2px solid #00000026;border-top-color:var(--accent3);border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.badge{border-radius:5px;margin-left:.4rem;padding:.15rem .5rem;font-size:.68rem;font-weight:700;display:inline-block}.badge-good{color:var(--accent);background:#78793f33}.badge-warn{color:var(--accent3);background:#bdb77c4d}.badge-bad{color:var(--danger);background:#b54a3f2e}.btn-primary{background:var(--grad-accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.65rem 1.3rem;font-size:.85rem;font-weight:700;transition:opacity .2s,transform .1s}.btn-primary:hover{opacity:.9}.btn-primary:active{transform:scale(.98)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.gloss-section{margin-bottom:2rem}.gloss-section-title{color:var(--accent3);margin-bottom:1rem;font-size:1rem;font-weight:700}.gloss-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;display:grid}.gloss-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:1rem 1.1rem}.gloss-term{margin-bottom:.4rem;font-size:.88rem;font-weight:700}.gloss-formula{font-family:var(--font-mono);color:var(--accent3);margin-bottom:.4rem;font-size:.78rem}.gloss-def{color:var(--text);font-size:.82rem}.gloss-eg{color:var(--muted);margin-top:.4rem;font-size:.78rem;font-style:italic}
