:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#f3f4f6;background-color:#111827;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%}*{box-sizing:border-box}.app{min-height:100vh;background:#111827;color:#f3f4f6}.app-header{background:#1f2937;padding:1rem 2rem;border-bottom:1px solid #374151;display:flex;justify-content:space-between;align-items:center}.app-header h1{margin:0;font-size:1.5rem;font-weight:600}.table-toggle-btn{padding:.5rem 1rem;background:#374151;color:#f3f4f6;border:1px solid #4b5563;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s}.table-toggle-btn:hover{background:#4b5563;border-color:#6b7280}.controls{padding:1rem 2rem;background:#1f2937;border-bottom:1px solid #374151;display:flex;flex-direction:column;gap:1rem}.controls-row{display:flex;flex-wrap:wrap;gap:2rem;align-items:center}.user-id-input{display:flex;align-items:center;gap:.75rem}.user-id-input label{font-weight:500;color:#9ca3af}.user-id-input input{padding:.5rem .75rem;border:1px solid #374151;border-radius:6px;background:#111827;color:#f3f4f6;font-size:.875rem;width:340px;font-family:monospace}.user-id-input input:focus{outline:none;border-color:#3b82f6}.user-id-input button{padding:.5rem 1rem;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:background .2s}.user-id-input button:hover:not(:disabled){background:#2563eb}.user-id-input button:disabled{opacity:.5;cursor:not-allowed}.time-range-selector,.data-source-toggle{display:flex;align-items:center;gap:.75rem}.time-range-selector .label,.data-source-toggle .label{font-weight:500;color:#9ca3af}.button-group{display:flex;gap:.25rem}.range-btn{padding:.375rem .75rem;background:#374151;color:#9ca3af;border:none;border-radius:4px;font-size:.875rem;cursor:pointer;transition:all .2s}.range-btn:hover{background:#4b5563}.range-btn.active{background:#3b82f6;color:#fff}.checkbox-group{display:flex;gap:1rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;color:#d1d5db}.checkbox-label input{cursor:pointer}.source-indicator{width:12px;height:12px;border-radius:2px}.main-content{padding:1.5rem 2rem}.dashboard{width:100%}.dashboard.loading,.dashboard.empty,.dashboard.error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:#9ca3af}.dashboard.error .error-message{color:#ef4444}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.dashboard-header h2{margin:0;font-size:1.25rem}.data-points{color:#6b7280;font-size:.875rem}.charts-grid{display:grid;gap:1.5rem}.metric-chart{background:#1f2937;border-radius:8px;padding:1rem 1.5rem;border:1px solid #374151}.metric-chart h3{margin:0 0 1rem;font-size:1rem;font-weight:500}.metric-chart h3 .unit{color:#6b7280;font-weight:400}.metric-chart.empty{display:flex;flex-direction:column;min-height:200px}.metric-chart .no-data{flex:1;display:flex;align-items:center;justify-content:center;color:#6b7280}.chart-tooltip{background:#1f2937;border:1px solid #374151;border-radius:6px;padding:.75rem;font-size:.875rem}.chart-tooltip .tooltip-time{margin:0 0 .5rem;color:#9ca3af;font-size:.75rem}.chart-tooltip p{margin:.25rem 0}.spinner{width:40px;height:40px;border:3px solid #374151;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.sidebar-overlay{position:fixed;inset:0;background:#00000080;z-index:100}.data-sidebar{position:fixed;top:0;right:0;width:500px;max-width:90vw;height:100vh;background:#1f2937;border-left:1px solid #374151;z-index:101;display:flex;flex-direction:column;animation:slideIn .2s ease-out}.data-sidebar.wide{width:900px;max-width:95vw}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #374151;flex-shrink:0}.sidebar-header h2{margin:0;font-size:1.25rem}.sidebar-header-info{display:flex;align-items:center;gap:1rem}.row-count{color:#6b7280;font-size:.875rem}.close-btn{background:none;border:none;color:#9ca3af;font-size:1.75rem;cursor:pointer;line-height:1;padding:.25rem}.close-btn:hover{color:#f3f4f6}.table-controls{display:flex;gap:2rem;padding:.75rem 1.5rem;background:#111827;border-bottom:1px solid #374151;flex-shrink:0}.control-group{display:flex;align-items:center;gap:.75rem}.control-label{font-size:.8125rem;font-weight:500;color:#9ca3af}.checkbox-control{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;color:#d1d5db;cursor:pointer}.checkbox-control input{cursor:pointer}.wide-table tbody tr.highlight-raw{background:#3b82f626}.wide-table tbody tr.highlight-raw:hover{background:#3b82f640}.wide-table tbody tr.highlight-live{background:#22c55e26}.wide-table tbody tr.highlight-live:hover{background:#22c55e40}.wide-table tbody tr.dim-row{opacity:.35}.wide-table tbody tr.dim-row:hover{opacity:.5}.sidebar-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.no-data-message{color:#6b7280;text-align:center;padding:2rem}.wide-table-wrapper{flex:1;overflow:auto}.wide-table{width:100%;border-collapse:collapse;font-size:.8125rem}.wide-table th,.wide-table td{padding:.5rem;text-align:left;border-bottom:1px solid #374151;white-space:nowrap}.wide-table thead{position:sticky;top:0;z-index:10}.wide-table th{color:#9ca3af;font-weight:600;background:#111827;border-bottom:2px solid #374151}.wide-table td{color:#d1d5db}.wide-table tbody tr:hover{background:#ffffff0d}.time-cell{font-family:monospace;font-size:.75rem;color:#9ca3af}.value-cell{font-family:monospace;font-weight:500;text-align:right}.q-badge{display:inline-block;width:20px;height:20px;line-height:20px;text-align:center;border-radius:4px;font-size:.7rem;font-weight:600}.q-badge.q-good{background:#22c55e33;color:#4ade80}.q-badge.q-medium{background:#eab30833;color:#facc15}.q-badge.q-poor{background:#ef444433;color:#f87171}.q-badge.q-na{background:#6b728033;color:#6b7280}.source-badge{display:inline-block;padding:.125rem .5rem;border-radius:4px;font-size:.7rem;font-weight:500}.source-badge.raw_metrics{background:#3b82f633;color:#60a5fa}.source-badge.live_pings{background:#22c55e33;color:#4ade80}@media(max-width:768px){.app-header{flex-direction:column;gap:1rem;align-items:flex-start}.controls{padding:1rem}.controls-row{flex-direction:column;align-items:flex-start;gap:1rem}.user-id-input{flex-wrap:wrap}.user-id-input input{width:100%}.main-content{padding:1rem}.data-sidebar,.data-sidebar.wide{width:100%;max-width:100%}}
