@import"https://fonts.googleapis.com/css2?family=Crimson+Pro:ital,wght@0,400;0,500;0,600;0,700&family=IBM+Plex+Mono:wght@400;500;600&family=Sora:wght@400;500;600;700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-base: #f5f5f0;--bg-surface: #ffffff;--bg-elevated: #fafaf8;--bg-hover: #f0f0ec;--text-primary: #1c1917;--text-secondary: #57534e;--text-tertiary: #a8a29e;--text-muted: #d6d3d1;--border: #e7e5e4;--border-light: #f0eeec;--border-strong: #d6d3d1;--accent: #c25e00;--accent-soft: rgba(194, 94, 0, .06);--accent-hover: #a85000;--accent-text: #9a4a00;--success: #15803d;--success-soft: rgba(21, 128, 61, .06);--warning: #b45309;--danger: #b91c1c;--font-serif: "Crimson Pro", Georgia, serif;--font-sans: "Sora", system-ui, sans-serif;--font-mono: "IBM Plex Mono", "SF Mono", monospace;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--shadow-sm: 0 1px 2px rgba(28, 25, 23, .04);--shadow-md: 0 4px 12px rgba(28, 25, 23, .06);--shadow-lg: 0 12px 32px rgba(28, 25, 23, .08);--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1)}html,body,#root{height:100%}body{font-family:var(--font-sans);font-size:14px;line-height:1.5;color:var(--text-primary);background:var(--bg-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::selection{background:var(--accent-soft);color:var(--accent-text)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.app-layout{min-height:100vh;display:flex;flex-direction:column}.topbar{position:sticky;top:0;z-index:50;background:#f5f5f0eb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:0 var(--space-8)}.topbar-inner{max-width:1440px;margin:0 auto;height:64px;display:flex;align-items:center;justify-content:space-between;gap:var(--space-6)}.topbar-brand{display:flex;align-items:center;gap:var(--space-3);text-decoration:none;flex-shrink:0}.brand-mark{width:32px;height:32px;border-radius:var(--radius-sm);background:var(--text-primary);color:var(--bg-surface);display:flex;align-items:center;justify-content:center;font-family:var(--font-serif);font-size:14px;font-weight:700;letter-spacing:-.02em}.brand-name{font-family:var(--font-serif);font-size:20px;font-weight:600;color:var(--text-primary);letter-spacing:-.02em}.topbar-center{display:flex;align-items:center;gap:var(--space-4);flex:1;justify-content:center}.topbar-right{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.main-area{flex:1;padding:var(--space-8)}.content-wrapper{max-width:1440px;margin:0 auto}.select-control{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-8) var(--space-2) var(--space-4);font-family:var(--font-sans);font-size:13px;font-weight:500;color:var(--text-primary);cursor:pointer;transition:all .2s var(--ease-out);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2357534e' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;min-width:160px}.select-control:hover{border-color:var(--border-strong)}.select-control:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.date-preset-group{display:inline-flex;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:3px;gap:2px}.date-preset-btn{border:none;background:transparent;padding:6px 14px;border-radius:var(--radius-sm);font-family:var(--font-sans);font-size:12px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s var(--ease-out);white-space:nowrap}.date-preset-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.date-preset-btn.active{background:var(--text-primary);color:var(--bg-surface)}.icon-btn{width:36px;height:36px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s var(--ease-out);flex-shrink:0}.icon-btn:hover{border-color:var(--border-strong);color:var(--text-primary);background:var(--bg-hover)}.icon-btn:disabled{opacity:.4;cursor:not-allowed}.icon-btn.is-loading svg{animation:spin 1s linear infinite}.tab-bar{display:flex;gap:var(--space-1);border-bottom:1px solid var(--border);margin-bottom:var(--space-8)}.tab-btn{border:none;background:transparent;padding:var(--space-3) var(--space-4);font-family:var(--font-sans);font-size:13px;font-weight:500;color:var(--text-tertiary);cursor:pointer;position:relative;transition:all .2s var(--ease-out);margin-bottom:-1px}.tab-btn:hover{color:var(--text-secondary)}.tab-btn.active{color:var(--text-primary);font-weight:600}.tab-btn.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--text-primary);border-radius:1px 1px 0 0}.section-header{margin-bottom:var(--space-6)}.section-label{font-family:var(--font-serif);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--text-tertiary);margin-bottom:var(--space-2)}.section-title{font-family:var(--font-serif);font-size:32px;font-weight:600;color:var(--text-primary);letter-spacing:-.02em;line-height:1.2}.section-subtitle{font-size:14px;color:var(--text-tertiary);margin-top:var(--space-1)}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin-bottom:var(--space-8)}.stat-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-6);transition:all .3s var(--ease-out);position:relative;overflow:hidden}.stat-card:after{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent);opacity:0;transition:opacity .3s ease}.stat-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card:hover:after{opacity:1}.stat-card-label{font-size:12px;font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--space-3);display:flex;align-items:center;gap:var(--space-2)}.stat-card-value{font-family:var(--font-mono);font-size:36px;font-weight:600;color:var(--text-primary);letter-spacing:-.03em;line-height:1}.stat-card-pending{color:var(--text-muted)}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:all .3s var(--ease-out)}.card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md)}.card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-light)}.card-title{font-family:var(--font-serif);font-size:16px;font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.card-meta{font-size:12px;font-weight:500;color:var(--text-tertiary);font-family:var(--font-mono);font-size:11px}.card-body{padding:var(--space-5) var(--space-6)}.chart-container{height:320px}.metric-toggle-group{display:flex;gap:var(--space-2)}.metric-toggle{display:flex;align-items:center;gap:var(--space-2);padding:4px 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-surface);font-family:var(--font-sans);font-size:11px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s var(--ease-out)}.metric-toggle:hover{border-color:var(--border-strong)}.metric-toggle.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-text)}.metric-toggle-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-tertiary);padding:var(--space-3) 0;border-bottom:1px solid var(--border)}.data-table td{font-size:13px;color:var(--text-primary);padding:var(--space-3) 0;border-bottom:1px solid var(--border-light);transition:all .15s ease;vertical-align:middle}.data-table tr:hover td{background:var(--bg-hover)}.data-table tr:hover td:first-child{border-radius:var(--radius-sm) 0 0 var(--radius-sm);padding-left:var(--space-3)}.data-table tr:hover td:last-child{border-radius:0 var(--radius-sm) var(--radius-sm) 0;padding-right:var(--space-3)}.data-table tr:last-child td{border-bottom:none}.data-table .col-url{color:var(--text-secondary);font-size:12px;max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:var(--font-mono)}.data-table .col-num{text-align:right;font-family:var(--font-mono);font-weight:500;font-size:13px;color:var(--text-primary)}.data-table .col-bar{width:80px;padding-left:var(--space-4)}.bar-bg{width:100%;height:4px;background:var(--border-light);border-radius:2px;overflow:hidden}.bar-fill{height:100%;border-radius:2px;background:var(--text-primary);transition:width .8s var(--ease-out)}.vitals-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}.vital-item{text-align:center;padding:var(--space-6) var(--space-4);background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border-light);transition:all .3s var(--ease-out)}.vital-item:hover{border-color:var(--border);background:var(--bg-hover)}.vital-name{font-size:10px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.12em;margin-bottom:var(--space-3);font-family:var(--font-sans)}.vital-value{font-family:var(--font-mono);font-size:28px;font-weight:600;color:var(--text-primary);letter-spacing:-.02em;line-height:1}.vital-value.good{color:var(--success)}.vital-value.needs-improvement{color:var(--warning)}.vital-value.poor{color:var(--danger)}.vital-badge{display:inline-block;margin-top:var(--space-3);border-radius:var(--radius-sm);padding:3px 8px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;font-family:var(--font-sans)}.vital-badge.good{background:var(--success-soft);color:var(--success)}.vital-badge.needs-improvement{background:#b453090f;color:var(--warning)}.vital-badge.poor{background:#b91c1c0f;color:var(--danger)}.device-list{display:flex;flex-direction:column;gap:var(--space-5)}.device-row{display:flex;flex-direction:column;gap:var(--space-2)}.device-row-header{display:flex;align-items:center;justify-content:space-between}.device-name{font-size:13px;font-weight:600;color:var(--text-primary);font-family:var(--font-sans)}.device-stats{display:flex;align-items:center;gap:var(--space-2)}.device-pct{font-size:14px;font-weight:600;font-family:var(--font-mono)}.device-count{font-size:12px;color:var(--text-tertiary);font-family:var(--font-mono)}.state-center{min-height:120px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);color:var(--text-tertiary);font-size:13px}.spinner{width:20px;height:20px;border-radius:50%;border:2px solid var(--border);border-top-color:var(--accent);animation:spin .8s linear infinite}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:var(--space-4);color:var(--text-tertiary);padding:var(--space-16) var(--space-8);text-align:center}.empty-state-icon{width:48px;height:48px;border-radius:var(--radius-lg);background:var(--bg-elevated);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:14px;font-weight:600;color:var(--text-tertiary)}.empty-state-title{font-family:var(--font-serif);font-size:18px;font-weight:600;color:var(--text-primary)}.empty-state-subtitle{font-size:13px;color:var(--text-tertiary);max-width:320px;line-height:1.6}.dashboard-grid{display:grid;grid-template-columns:2fr 1fr;gap:var(--space-6)}.dashboard-grid .card:first-child{grid-column:1 / -1}.dashboard-sidebar{display:flex;flex-direction:column;gap:var(--space-6)}.recharts-cartesian-grid line{stroke:var(--border-light)!important}.recharts-xAxis .recharts-cartesian-axis-tick-value,.recharts-yAxis .recharts-cartesian-axis-tick-value{fill:var(--text-tertiary)!important;font-size:11px!important;font-family:var(--font-mono)!important}.recharts-tooltip-wrapper .recharts-default-tooltip{border-radius:var(--radius-md)!important;border:1px solid var(--border)!important;background:var(--bg-surface)!important;box-shadow:var(--shadow-lg)!important;font-family:var(--font-sans)!important}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.animate-in{opacity:0;animation:fadeSlideUp .5s var(--ease-out) forwards}.animate-in-delay-1{animation-delay:.05s}.animate-in-delay-2{animation-delay:.1s}.animate-in-delay-3{animation-delay:.15s}.animate-in-delay-4{animation-delay:.2s}.animate-in-delay-5{animation-delay:.25s}@media (max-width: 1100px){.stats-grid{grid-template-columns:repeat(2,1fr)}.dashboard-grid{grid-template-columns:1fr}.dashboard-grid .card:first-child{grid-column:1}.vitals-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.topbar{padding:0 var(--space-4)}.topbar-center{display:none}.main-area{padding:var(--space-4)}.stats-grid,.vitals-grid{grid-template-columns:1fr}.section-title{font-size:24px}}
