*{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,-apple-system,sans-serif;background:#f1f5f9;color:#1e293b;font-size:14px}a{color:inherit;text-decoration:none}#app{flex-direction:column;height:100vh;overflow:hidden}#app,header{display:flex}header{background:#0f172a;color:#fff;padding:0 20px;height:48px;align-items:center;justify-content:space-between;flex-shrink:0}header .logo{font-size:15px}.app-version,header .logo{font-weight:600;letter-spacing:.3px}.app-version{margin-left:8px;font-size:11px;color:#64748b;background:#e2e8f0;border-radius:4px;padding:1px 6px}body.dark .app-version{color:#9aa4b2;background:#2a323f}header .meta{font-size:12px;color:#94a3b8;display:flex;align-items:center;gap:12px}header .meta button{background:#1e3a5f;color:#93c5fd;border:none;padding:4px 10px;border-radius:4px;cursor:pointer;font-size:12px}header .meta button:hover{background:#2563eb}.body{flex:1 1}.body,.sidebar{display:flex;overflow:hidden}.sidebar{width:200px;background:#fff;border-right:1px solid #e2e8f0;flex-direction:column;flex-shrink:0}.sidebar-hd{padding:12px 14px;font-size:11px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.6px;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;justify-content:space-between;gap:8px}.group-select{font:inherit;font-size:11px;font-weight:600;color:#475569;background:#fff;border:1px solid #cbd5e1;border-radius:5px;padding:2px 4px;cursor:pointer;text-transform:none;letter-spacing:0}.city-group-hd{padding:8px 14px 4px;font-size:10px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;position:-webkit-sticky;position:sticky;top:0;background:#fff}.city-list{overflow-y:auto;flex:1 1}.city-item{padding:10px 14px;cursor:pointer;border-left:3px solid transparent;display:flex;align-items:center;gap:8px}.city-item:hover{background:#f8fafc}.city-item.active{border-left-color:#3b82f6;background:#eff6ff;color:#1d4ed8;font-weight:500}.city-dot{width:8px;height:8px;border-radius:50%;background:#cbd5e1;flex-shrink:0}.city-item.active .city-dot{background:#3b82f6}.city-name{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.city-new-badge{font-size:9px;font-weight:600;color:#fff;background:#10b981;padding:1px 5px;letter-spacing:.5px;text-transform:uppercase}.city-new-badge,.poly-link{flex-shrink:0;border-radius:3px}.poly-link{font-size:10px;color:#94a3b8;padding:1px 4px;border:1px solid #e2e8f0;text-decoration:none;opacity:0;transition:opacity .15s}.city-item:hover .poly-link{opacity:1}.city-item.active .poly-link{opacity:1;color:#3b82f6;border-color:#bfdbfe}.main{flex:1 1;display:flex;flex-direction:column;overflow:hidden}.rec-strip{background:#fffbeb;border-bottom:1px solid #fde68a;padding:8px 20px;display:flex;align-items:center;gap:12px;flex-shrink:0}.rec-strip-label{font-size:11px;font-weight:700;color:#b45309;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;flex-shrink:0}.rec-cards{display:flex;gap:8px;overflow-x:auto;padding-bottom:2px}.rec-card{flex-shrink:0;display:flex;flex-direction:column;align-items:flex-start;gap:1px;background:#fff;border:1px solid #fcd34d;border-radius:8px;padding:6px 12px;cursor:pointer;font:inherit;text-align:left;transition:border-color .12s,box-shadow .12s}.rec-card:hover{border-color:#f59e0b;box-shadow:0 1px 4px rgba(245,158,11,.25)}.rec-card.active{border-color:#f59e0b;background:#fef3c7}.rec-card-name{font-size:13px;font-weight:600;color:#1e293b}.rec-card-temps{display:flex;gap:10px}.rec-card-stat{font-size:11px;font-weight:600;color:#92400e;white-space:nowrap}.rec-card-stat-k{font-weight:500;color:#b45309;opacity:.8}.status-bar{background:#fff;border-bottom:1px solid #e2e8f0;padding:10px 20px;display:flex;gap:16px;flex-wrap:wrap;flex-shrink:0}.source-pill{display:flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;background:#f8fafc;border:1px solid #e2e8f0;font-size:12px}.source-pill .dot{width:7px;height:7px;border-radius:50%}.dot-ok{background:#22c55e}.dot-err{background:#ef4444}.dot-stale{background:#f59e0b}.dot-unknown{background:#94a3b8}.source-pill .label{font-weight:500;text-transform:capitalize}.source-pill .age{color:#64748b;margin-left:2px}.source-pill .fails{color:#ef4444;font-size:11px;margin-left:2px}.date-nav{background:#fff;border-bottom:1px solid #e2e8f0;padding:8px 20px;display:flex;align-items:center;gap:10px;flex-shrink:0}.date-nav button{background:#f1f5f9;border:1px solid #e2e8f0;padding:4px 10px;border-radius:4px;cursor:pointer;color:#475569;font-size:13px}.date-nav button:hover:not(:disabled){background:#e2e8f0}.date-nav button:disabled{opacity:.4;cursor:not-allowed}#date-picker{border:1px solid #e2e8f0;border-radius:4px;padding:4px 8px;font-size:13px;color:#1e293b;background:#fff}.date-nav .date-label{font-weight:500;font-size:13px;color:#475569}.tabs{background:#fff;border-bottom:1px solid #e2e8f0;padding:0 20px;display:flex;gap:2px;flex-shrink:0}.tab{padding:10px 14px;cursor:pointer;font-size:13px;color:#64748b;background:none;border:none;border-bottom:2px solid transparent;font-family:inherit}.tab:hover{color:#334155}.tab.active{border-bottom-color:#3b82f6;color:#2563eb;font-weight:500}.content{flex:1 1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px}.tab-pane{display:none}.tab-pane.active{display:flex;flex-direction:column;gap:16px}.card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.card-hd{padding:12px 16px;border-bottom:1px solid #f1f5f9;font-weight:500;font-size:13px;color:#374151;display:flex;align-items:center;justify-content:space-between}.card-hd .count{font-size:12px;color:#94a3b8;font-weight:400}.card-body{padding:16px}.chart-wrap{padding:12px 16px 16px;height:260px;position:relative}.feedback-body{padding:14px 16px;display:flex;flex-direction:column;gap:14px}.feedback-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));grid-gap:10px;gap:10px}.feedback-card-option{position:relative;min-height:86px;padding:10px 12px;border:1px solid #e2e8f0;background:#fff;border-radius:8px;cursor:pointer;text-align:left;overflow:hidden;color:#1e293b;display:block}.feedback-card-option:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.feedback-card-option:hover{border-color:#93c5fd;background:#f8fafc}.feedback-card-option:has(input:checked){border-color:#3b82f6;background:#eff6ff}.feedback-card-option:has(input:checked):after{content:"✓";position:absolute;top:8px;right:10px;width:20px;height:20px;border-radius:50%;background:#2563eb;color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700}.feedback-card-option:has(input:disabled){cursor:default}.feedback-card-option input{position:absolute;opacity:0;pointer-events:none}.feedback-option-title{font-weight:600;font-size:13px;line-height:1.3}.feedback-option-desc{font-size:12px;color:#64748b;line-height:1.45;margin-top:3px}.feedback-custom{display:flex;gap:10px;align-items:flex-start}.feedback-custom textarea{flex:1 1;min-height:42px;max-height:120px;resize:vertical;border:1px solid #e2e8f0;border-radius:8px;padding:9px 10px;font:inherit;font-size:13px;color:#1e293b;background:#fff}.feedback-custom button{border:none;border-radius:6px;background:#2563eb;color:#fff;padding:9px 14px;font-size:13px;cursor:pointer;white-space:nowrap}.feedback-custom button:hover{background:#1d4ed8}.feedback-custom button:disabled{opacity:.55;cursor:not-allowed}.feedback-message{min-height:18px;font-size:12px;color:#64748b}.tbl{width:100%;border-collapse:collapse;font-size:13px}.tbl th{text-align:left;font-size:11px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.4px;background:#f8fafc;border-bottom:1px solid #e2e8f0}.tbl td,.tbl th{padding:8px 12px}.tbl td{border-bottom:1px solid #f1f5f9;vertical-align:top}.tbl tr:last-child td{border-bottom:none}.tbl tr:hover td{background:#fafbfc}.badge{display:inline-block;padding:2px 7px;border-radius:10px;font-size:11px;font-weight:500}.badge-ok{background:#dcfce7;color:#15803d}.badge-err{background:#fee2e2;color:#b91c1c}.badge-revised{background:#fef3c7;color:#b45309}.fc-row-revised td:first-child{box-shadow:inset 3px 0 0 #f59e0b}.mono{font-family:ui-monospace,monospace;font-size:12px}.trunc{max-width:340px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-muted{color:#94a3b8}.temp{font-weight:600;color:#1e293b}.empty{padding:32px;text-align:center;color:#94a3b8;font-size:13px}.nav-toggle{display:none;background:#1e3a5f;color:#93c5fd;border:none;width:32px;height:32px;border-radius:4px;cursor:pointer;font-size:16px;align-items:center;justify-content:center;margin-right:8px}.nav-toggle:hover{background:#2563eb}.nav-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:40}@media (max-width:768px){header{padding:0 12px;height:44px}header .logo{font-size:14px}header .meta{font-size:11px;gap:8px}header .meta button{padding:3px 8px;font-size:11px}.nav-toggle{display:flex}.sidebar{position:fixed;top:0;left:0;bottom:0;width:220px;z-index:50;transform:translateX(-100%);transition:transform .2s ease;box-shadow:2px 0 12px rgba(0,0,0,.25)}.body.nav-open .sidebar{transform:translateX(0)}.body.nav-open .nav-backdrop{display:block}.status-bar{padding:8px 12px;gap:8px}.source-pill{padding:3px 8px;font-size:11px}.date-nav{padding:6px 12px;gap:6px;flex-wrap:wrap}.date-nav button{padding:4px 8px;font-size:12px}#date-picker{padding:3px 6px;font-size:12px}.tabs{padding:0 8px;overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap}.tab{padding:8px 10px;font-size:12px;flex-shrink:0}.content{padding:10px;gap:10px}.card-hd{font-size:12px}.card-body,.card-hd{padding:10px 12px}.chart-wrap{padding:8px 8px 12px;height:220px}.feedback-body{padding:12px}.feedback-options{grid-template-columns:1fr}.feedback-custom{flex-direction:column}.feedback-custom button{width:100%}.tbl{font-size:12px;display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap}.tbl td,.tbl th{padding:6px 8px}.trunc{max-width:180px}}@media (max-width:420px){header .meta #last-refresh{display:none}.chart-wrap{height:200px}.tab{padding:8px;font-size:11px}}.fc-row-clickable{cursor:pointer}.fc-row-clickable:hover{background:#f1f5f9}body.dark{background:#161a22;color:#cbd2dc}body.dark header{background:#0c1018;color:#e6ebf2}body.dark header .meta{color:#7d8694}body.dark header .meta button{background:#1c2433;color:#9ec1ff}body.dark header .meta button:hover{background:#2563eb;color:#fff}body.dark .sidebar{background:#1b212c;border-right-color:#262d3a}body.dark .sidebar-hd{color:#7d8694;border-bottom-color:#262d3a}body.dark .group-select{color:#c2c9d4;background:#1a2029;border-color:#39414f}body.dark .city-group-hd{color:#5e6675;background:#1b212c}body.dark .city-item:hover{background:#222a37}body.dark .city-item.active{background:#1d2a44;color:#9ec1ff;border-left-color:#3b82f6}body.dark .city-dot{background:#3a4456}body.dark .city-item.active .city-dot{background:#3b82f6}body.dark .poly-link{color:#7d8694;border-color:#2c3445}body.dark .city-item.active .poly-link{color:#9ec1ff;border-color:#2c4a78}body.dark .status-bar{background:#1b212c;border-bottom-color:#262d3a}body.dark .rec-strip{background:#2a2410;border-bottom-color:#4a3d12}body.dark .rec-strip-label{color:#fbbf24}body.dark .rec-card{background:#221d0e;border-color:#5a4a14}body.dark .rec-card:hover{border-color:#d97706}body.dark .rec-card.active{border-color:#d97706;background:#3a300f}body.dark .rec-card-name{color:#e6ebf2}body.dark .rec-card-stat{color:#fcd34d}body.dark .rec-card-stat-k{color:#d4a017}body.dark .source-pill{background:#222a37;border-color:#2c3445}body.dark .source-pill .age{color:#7d8694}body.dark .date-nav{background:#1b212c;border-bottom-color:#262d3a}body.dark .date-nav button{background:#222a37;border-color:#2c3445;color:#b8c0cc}body.dark .date-nav button:hover:not(:disabled){background:#2a3344}body.dark #date-picker{background:#222a37;border-color:#2c3445;color:#cbd2dc;color-scheme:dark}body.dark .date-nav .date-label{color:#b8c0cc}body.dark .tabs{background:#1b212c;border-bottom-color:#262d3a}body.dark .tab{color:#7d8694}body.dark .tab:hover{color:#b8c0cc}body.dark .tab.active{color:#9ec1ff;border-bottom-color:#3b82f6}body.dark .card{background:#1b212c;border-color:#262d3a}body.dark .card-hd{color:#cbd2dc;border-bottom-color:#222a37}body.dark .card-hd .count{color:#7d8694}body.dark .feedback-card-option{background:#1b212c;border-color:#2c3445;color:#cbd2dc}body.dark .feedback-card-option:hover{background:#222a37;border-color:#3b82f6}body.dark .feedback-card-option:has(input:checked){background:#1d2a44;border-color:#3b82f6}body.dark .feedback-message,body.dark .feedback-option-desc{color:#7d8694}body.dark .feedback-custom textarea{background:#222a37;border-color:#2c3445;color:#cbd2dc;color-scheme:dark}body.dark .tbl th{background:#222a37;color:#7d8694;border-bottom-color:#2c3445}body.dark .tbl td{border-bottom-color:#222a37}body.dark .tbl tr:hover td{background:#222a37}body.dark .badge-ok{background:#0f3a24;color:#5cc88a}body.dark .badge-err{background:#3d1717;color:#f88}body.dark .badge-revised{background:#3a2a0d;color:#f5b041}body.dark .fc-row-revised td:first-child{box-shadow:inset 3px 0 0 #f59e0b}body.dark .text-muted{color:#7d8694}body.dark .temp{color:#e6ebf2}body.dark .empty{color:#7d8694}body.dark .nav-toggle{background:#1c2433;color:#9ec1ff}body.dark .nav-toggle:hover{background:#2563eb;color:#fff}body.dark .fc-row-clickable:hover{background:#222a37}body.dark .modal-box{background:#1b212c;color:#cbd2dc;box-shadow:0 10px 30px rgba(0,0,0,.5)}body.dark .modal-hd{border-bottom-color:#262d3a}body.dark .modal-hd .close-btn{color:#7d8694}body.dark [style*="border-top:1px solid #f1f5f9"]{border-top-color:#222a37!important}body.dark [style*="border-bottom:1px solid #f1f5f9"]{border-bottom-color:#222a37!important}body.dark [style*="background:#f8fafc"]{background:#222a37!important}body.dark [style*="border:1px solid #e2e8f0"]{border-color:#2c3445!important}.modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.5);display:none;align-items:center;justify-content:center;z-index:1000}.modal-backdrop.show,.modal-box{display:flex}.modal-box{background:#fff;border-radius:8px;max-width:560px;width:92%;max-height:80vh;flex-direction:column;box-shadow:0 10px 30px rgba(0,0,0,.2)}.modal-hd{padding:12px 16px;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center;font-weight:600}.modal-hd .close-btn{cursor:pointer;background:none;border:none;font-size:20px;color:#64748b;padding:0 4px}.modal-bd{padding:12px 16px;overflow:auto}body,html{height:100%}