.login-container{position:relative;display:flex;justify-content:center;align-items:center;min-height:100vh;background:url('https://images.unsplash.com/photo-1504917595217-d4dc5ebb6"; fallback') center/cover no-repeat;background-image:url(https://images.unsplash.com/photo-1565793298595-6a879b1d9492?w=1920&q=80);background-size:cover;background-position:center}.login-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0a0f1e8c;z-index:0}.login-box{position:relative;z-index:1;background:#0f172ab8;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.08);padding:2.75rem 2.5rem 2rem;border-radius:16px;width:100%;max-width:440px;box-shadow:0 24px 80px #00000073;animation:slideUp .5s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.login-logo{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:1.75rem}.login-logo-icon{width:52px;height:52px;filter:drop-shadow(0 0 6px rgba(74,158,255,.4))}.login-logo-text{display:flex;flex-direction:column;line-height:1.15}.login-logo-title{font-size:1.65rem;font-weight:800;color:#fff;letter-spacing:2px}.login-logo-subtitle{font-size:.7rem;font-weight:600;color:#a0bee6cc;letter-spacing:4.5px;margin-top:1px}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:1.75rem;color:#fff;margin-bottom:.4rem;font-weight:700}.login-header p{color:#b4c8e6b3;font-size:.9rem}.login-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column}.input-wrapper{position:relative;display:flex;align-items:center;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:8px;transition:border-color .25s ease,box-shadow .25s ease}.input-wrapper:focus-within{border-color:#4a9eff80;box-shadow:0 0 0 3px #4a9eff14}.input-icon{display:flex;align-items:center;justify-content:center;padding:0 0 0 1rem;color:#a0bee68c;flex-shrink:0}.input-icon svg{width:18px;height:18px}.form-group input{flex:1;padding:.9rem 1rem;background:transparent;border:none;outline:none;color:#e0e8f0;font-size:.95rem;letter-spacing:.2px}.form-group input::placeholder{color:#a0bee673}.form-group input:disabled{opacity:.5;cursor:not-allowed}.forgot-link{padding-right:1rem;font-size:.75rem;color:#8cafdca6;white-space:nowrap;cursor:pointer;transition:color .2s ease}.forgot-link:hover{color:#4a9effe6}.error-message{padding:.7rem 1rem;background:#ef44441f;border:1px solid rgba(239,68,68,.25);border-radius:8px;color:#fca5a5;font-size:.85rem;text-align:center}.login-button{padding:.9rem;background:linear-gradient(180deg,#3b8bef,#1d6dd8,#1a5fb8);color:#fff;border:none;border-radius:8px;font-size:1.05rem;font-weight:700;letter-spacing:.5px;cursor:pointer;transition:all .25s ease;margin-top:.5rem;box-shadow:0 4px 16px #1d6dd84d}.login-button:hover:not(:disabled){background:linear-gradient(180deg,#4a96f5,#2578e4,#1d6dd8);box-shadow:0 6px 24px #1d6dd873;transform:translateY(-1px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.55;cursor:not-allowed}.login-footer{text-align:center;margin-top:1.75rem;font-size:.8rem;color:#a0bee673}.support-link{color:#4a9effb3;cursor:pointer;transition:color .2s ease}.support-link:hover{color:#4a9eff}@media (max-width: 500px){.login-box{margin:1rem;padding:2rem 1.5rem 1.5rem}.login-logo-title{font-size:1.35rem}.login-header h1{font-size:1.5rem}}.metric-selector{width:280px;background:var(--bg-primary);border-right:1px solid var(--border-primary);display:flex;flex-direction:column;overflow-y:auto}.metric-selector-header{padding:16px;border-bottom:1px solid var(--border-primary)}.header-row{display:flex;align-items:center;gap:8px;margin-bottom:12px}.header-icon{font-size:18px}.header-title{font-weight:600;font-size:16px;flex:1;color:var(--text-primary)}.deselect-all{background:none;border:none;color:var(--accent-primary);font-size:12px;cursor:pointer;padding:4px 8px;border-radius:4px}.deselect-all:hover{background:var(--accent-subtle)}.metric-filter{width:100%;padding:8px 12px;border:1px solid var(--border-primary);border-radius:6px;font-size:14px;background:var(--input-bg);color:var(--text-primary)}.metric-filter:focus{outline:none;border-color:var(--accent-primary)}.sort-section{padding:12px 16px;border-bottom:1px solid var(--border-primary)}.sort-label{font-size:11px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.sort-select{width:100%;padding:6px 8px;border:1px solid var(--border-primary);border-radius:4px;font-size:13px;background:var(--input-bg);color:var(--text-primary);cursor:pointer}.metric-section{border-bottom:1px solid var(--border-primary)}.section-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--bg-secondary)}.section-title{font-size:11px;font-weight:600;color:var(--text-secondary);letter-spacing:.5px}.collapse-btn{background:none;border:none;font-size:16px;cursor:pointer;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.metric-list{padding:8px 0}.metric-item{display:flex;align-items:center;gap:10px;padding:8px 16px;cursor:pointer;transition:background .2s}.metric-item:hover{background:var(--bg-secondary)}.metric-item.selected{background:var(--bg-primary)}.metric-item.available{padding-left:12px}.metric-color{width:12px;height:12px;border-radius:2px;flex-shrink:0}.metric-checkbox{width:16px;height:16px;flex-shrink:0}.metric-checkbox input[type=checkbox]{cursor:pointer}.metric-name{flex:1;font-size:13px;color:var(--text-primary)}.metric-actions{display:flex;gap:4px;opacity:0;transition:opacity .2s}.metric-item:hover .metric-actions{opacity:1}.metric-action-btn{background:none;border:none;font-size:14px;cursor:pointer;padding:2px 6px;border-radius:3px;color:var(--text-secondary)}.metric-action-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.metric-item.right-label{border-left:3px solid #9C27B0}.metric-item-wrapper{border-bottom:1px solid var(--border-secondary)}.metric-item-wrapper:last-child{border-bottom:none}.metric-range-row{display:flex;gap:8px;padding:4px 16px 8px 38px}.metric-range-label{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text-secondary)}.metric-range-input{width:60px;padding:3px 6px;border:1px solid var(--border-primary);border-radius:4px;font-size:11px;background:var(--bg-secondary);color:var(--text-primary)}.metric-range-input:focus{outline:none;border-color:var(--accent-primary);background:var(--bg-primary)}.metric-range-input::-webkit-inner-spin-button,.metric-range-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.metric-range-input{-moz-appearance:textfield}.date-range-selector{display:flex;align-items:center;gap:8px;position:relative}.date-display{display:flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid var(--border-primary);border-radius:6px;cursor:pointer;background:var(--bg-primary);transition:background .2s}.date-display:hover{background:var(--bg-secondary)}.date-icon{font-size:14px}.date-text{font-size:13px;color:var(--text-primary);white-space:nowrap}.date-separator{font-size:12px;color:var(--text-secondary)}.date-picker-dropdown{position:absolute;top:100%;right:0;margin-top:8px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;box-shadow:var(--shadow-lg);padding:16px;z-index:1000;min-width:320px}.quick-select{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border-primary)}.quick-select-title{font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.quick-select button{display:block;width:100%;padding:8px 12px;margin-bottom:4px;border:1px solid var(--border-primary);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);text-align:left;cursor:pointer;font-size:13px;transition:background .2s}.quick-select button:hover{background:var(--bg-secondary)}.custom-range{margin-bottom:16px}.input-group{margin-bottom:12px}.input-group label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:4px}.input-group input{width:100%;padding:8px 12px;border:1px solid var(--border-primary);border-radius:4px;font-size:13px;background:var(--input-bg);color:var(--text-primary)}.input-group input:focus{outline:none;border-color:var(--accent-primary)}.apply-btn{width:100%;padding:10px;background:var(--accent-primary);color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:background .2s}.apply-btn:hover{background:var(--accent-hover)}.state-edit-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:9999}.state-edit-modal{background:var(--bg-primary);border-radius:12px;width:400px;max-width:90vw;box-shadow:var(--shadow-lg);overflow:hidden;border:1px solid var(--border-primary)}.state-edit-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-primary)}.state-edit-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.state-edit-close{background:none;border:none;font-size:22px;color:var(--text-muted);cursor:pointer;padding:0 4px;line-height:1}.state-edit-close:hover{color:var(--text-primary)}.state-edit-info{padding:12px 20px;display:flex;align-items:center;gap:12px;background:var(--bg-secondary);border-bottom:1px solid var(--border-primary)}.state-edit-badge{padding:4px 10px;border-radius:4px;font-size:11px;font-weight:600;color:#fff;text-transform:uppercase}.state-edit-badge[data-state=uptime]{background:#4caf50}.state-edit-badge[data-state=downtime]{background:#f44336}.state-edit-badge[data-state=maintenance]{background:#2196f3}.state-edit-badge[data-state=idle]{background:#9e9e9e}.state-edit-time{font-size:12px;color:var(--text-secondary)}.state-edit-loading{padding:40px 20px;text-align:center;color:var(--text-muted)}.state-edit-form{padding:20px;display:flex;flex-direction:column;gap:16px}.state-edit-field{display:flex;flex-direction:column;gap:6px}.state-edit-field label{font-size:13px;font-weight:500;color:var(--text-secondary)}.state-edit-field select,.state-edit-field textarea{padding:8px 12px;border:1px solid var(--border-primary);border-radius:6px;font-size:13px;color:var(--text-primary);background:var(--input-bg);transition:border-color .2s}.state-edit-field select:focus,.state-edit-field textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #2196f31a}.state-edit-field textarea{resize:vertical;min-height:60px}.state-edit-actions{display:flex;justify-content:flex-end;gap:10px;padding:16px 20px;border-top:1px solid var(--border-primary)}.state-edit-btn{padding:8px 20px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;border:none;transition:background .2s}.state-edit-btn.cancel{background:var(--bg-tertiary);color:var(--text-secondary)}.state-edit-btn.cancel:hover{background:var(--border-primary)}.state-edit-btn.save{background:var(--accent-primary);color:#fff}.state-edit-btn.save:hover{background:var(--accent-hover)}.state-edit-btn:disabled{opacity:.6;cursor:not-allowed}.state-edit-error{margin:0 20px 12px;padding:10px 12px;border-radius:6px;background:#f443361f;border:1px solid rgba(244,67,54,.4);color:#f44336;font-size:13px}.timeseries-chart-container{display:flex;flex-direction:column;gap:16px;width:100%}.chart-controls{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--bg-secondary);border-radius:8px;flex-wrap:wrap}.control-btn{padding:6px 12px;border:1px solid var(--border-primary);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);font-size:12px;cursor:pointer;display:flex;align-items:center;gap:4px;transition:all .2s}.control-btn:hover{background:var(--accent-subtle);border-color:var(--accent-primary);color:var(--accent-primary)}.control-btn.active{background:var(--accent-primary);border-color:var(--accent-hover);color:#fff;font-weight:600;box-shadow:0 2px 4px #2196f34d}.control-btn.active:hover{background:var(--accent-hover);color:#fff}.layers-indicator{margin-left:auto;padding:6px 12px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:4px;font-size:12px;font-weight:500;color:var(--text-secondary)}.state-visualization{width:100%;height:40px;position:relative;margin-bottom:8px}.state-bar{width:100%;height:100%;position:relative;border-radius:4px;overflow:hidden;display:flex}.state-segment{position:absolute;height:100%;display:flex;align-items:center;justify-content:center;flex-direction:column;transition:all .2s;cursor:pointer;border-right:1px solid rgba(255,255,255,.3)}.state-segment:hover{opacity:.85;transform:scaleY(1.05);z-index:10;box-shadow:0 2px 8px #00000026}.state-label{color:#fff;font-size:10px;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.3);letter-spacing:.5px;text-align:center;line-height:1.2}.chart-canvas{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;padding:16px}.statistics-table{width:100%;overflow-x:auto;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;padding:16px}.statistics-table table{width:100%;border-collapse:collapse;font-size:13px}.statistics-table th,.statistics-table td{padding:10px 16px;text-align:left;border-bottom:1px solid var(--border-primary);color:var(--text-primary)}.statistics-table th{font-weight:600;color:var(--text-primary);background:var(--bg-secondary)}.statistics-table tbody tr:last-child td{border-bottom:none}.stat-label{font-weight:600;color:var(--text-secondary);font-size:11px;text-transform:uppercase;letter-spacing:.5px}.baseline-btn{padding:4px 8px;border:1px solid var(--border-primary);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);font-size:11px;cursor:pointer;display:flex;align-items:center;gap:4px;transition:all .2s}.baseline-btn:hover{background:var(--accent-subtle);border-color:var(--accent-primary);color:var(--accent-primary)}.event-filter-container{position:relative}.event-filter-dropdown{position:absolute;top:100%;left:0;margin-top:4px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:100;min-width:220px;padding:8px 0}.event-filter-header{display:flex;justify-content:space-between;align-items:center;padding:6px 12px 8px;border-bottom:1px solid var(--border-primary);font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.density-notice{font-size:10px;color:#ff9800;font-weight:500;text-transform:none;letter-spacing:0}.density-badge{margin-left:4px;font-size:11px}.event-filter-option{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:background .15s;font-size:13px;color:var(--text-primary)}.event-filter-option:hover{background:var(--bg-secondary)}.event-filter-option input[type=checkbox]{width:14px;height:14px;cursor:pointer;accent-color:var(--accent-primary)}.event-filter-color{width:12px;height:12px;border-radius:3px;flex-shrink:0}.event-filter-label{flex:1;font-weight:500}.event-filter-count{font-size:11px;color:var(--text-secondary);background:var(--bg-secondary);padding:2px 6px;border-radius:10px;min-width:20px;text-align:center}.event-filter-actions{display:flex;gap:6px;padding:8px 12px 4px;border-top:1px solid var(--border-primary);margin-top:4px}.event-filter-action-btn{flex:1;padding:4px 8px;border:1px solid var(--border-primary);border-radius:4px;background:var(--bg-secondary);color:var(--text-primary);font-size:11px;cursor:pointer;transition:all .15s;text-align:center}.event-filter-action-btn:hover{background:var(--accent-subtle);border-color:var(--accent-primary);color:var(--accent-primary)}.explore-container{display:flex;flex-direction:column;height:100vh;background:var(--bg-secondary)}.explore-header{display:flex;justify-content:space-between;align-items:center;background:var(--bg-primary);border-bottom:1px solid var(--border-primary);padding:0 20px;height:60px}.explore-tabs{display:flex;gap:8px}.tab{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--accent-subtle);border-radius:6px 6px 0 0;font-weight:500;cursor:pointer;color:var(--text-primary)}.tab.active{background:var(--accent-primary);color:#fff}.tab-badge{background:#ffffff4d;padding:2px 8px;border-radius:4px;font-size:12px}.tab-close{background:none;border:none;color:inherit;font-size:18px;cursor:pointer;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center}.explore-controls{display:flex;align-items:center;gap:12px}.plant-selector{display:flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid var(--border-primary);border-radius:6px;cursor:pointer;background:var(--bg-primary);color:var(--text-primary)}.plant-selector:hover{background:var(--bg-secondary)}.icon{font-size:14px}.share-wrapper{position:relative;display:flex;flex-direction:column;align-items:center}.btn-share{padding:8px 16px;border:1px solid var(--accent-primary);border-radius:6px;background:var(--bg-primary);color:var(--accent-primary);cursor:pointer;font-weight:500;display:flex;align-items:center;gap:6px}.btn-share:hover{background:var(--accent-subtle)}.share-copied-message{position:absolute;top:100%;margin-top:4px;font-size:11px;color:var(--accent-primary);white-space:nowrap;z-index:9999;animation:fadeIn .2s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.explore-content{display:flex;flex:1;overflow:hidden}.explore-main{flex:1;display:flex;flex-direction:column;overflow:auto;padding:20px;background:var(--bg-primary)}.loading-state{display:flex;align-items:center;justify-content:center;height:100%;font-size:18px;color:var(--text-secondary)}:root{--vd-navy: #1a2744;--vd-navy-light: #243656;--vd-navy-dark: #0f1a2e;--vd-blue-accent: #4a90d9;--vd-blue-bright: #5ca0ec;--vd-white: #ffffff;--vd-white-text: #ffffff;--vd-gray-100: #f8f9fb;--vd-gray-200: #eef1f5;--vd-gray-300: #dce1e8;--vd-gray-400: #b4bdc9;--vd-gray-500: #8892a0;--vd-gray-600: #5f6c7d;--vd-text-primary: #1f2937;--vd-text-secondary: #6b7280;--vd-text-muted: #9ca3af;--vd-border: #e5e7eb;--vd-border-light: #f3f4f6;--vd-shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--vd-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--vd-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--vd-transition: .15s ease}[data-theme=dark]{--vd-navy: #0f1520;--vd-navy-light: #1a2235;--vd-navy-dark: #080d14;--vd-blue-accent: #60a5fa;--vd-blue-bright: #93c5fd;--vd-white: #1a1a2e;--vd-white-text: #f0f0f5;--vd-gray-100: #16213e;--vd-gray-200: #1e1e3a;--vd-gray-300: #2e2e4a;--vd-gray-400: #71717a;--vd-gray-500: #a1a1aa;--vd-gray-600: #d4d4d8;--vd-text-primary: #e4e4e7;--vd-text-secondary: #a1a1aa;--vd-text-muted: #71717a;--vd-border: #2e2e4a;--vd-border-light: #252540;--vd-shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--vd-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -1px rgba(0, 0, 0, .3);--vd-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5), 0 4px 6px -2px rgba(0, 0, 0, .4)}.view-data-container{display:flex;flex-direction:column;height:100vh;background-color:var(--vd-gray-100);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.view-data-header{display:flex;align-items:center;padding:0;background:var(--vd-white);border-bottom:1px solid var(--vd-border);min-height:44px}.search-name-section{display:flex;align-items:center;height:44px;padding:0 16px;gap:8px;border-right:1px solid var(--vd-border)}.search-icon{font-size:14px;color:var(--vd-gray-500)}.search-name{color:var(--vd-blue-accent);font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px;transition:color var(--vd-transition)}.search-name:hover{color:var(--vd-blue-bright)}.search-name-input{font-size:13px;padding:4px 8px;border:1px solid var(--vd-blue-accent);border-radius:4px;outline:none;width:140px;color:var(--vd-text-primary);background:var(--vd-white)}.edit-icon{font-size:11px;color:var(--vd-blue-accent);opacity:.7}.add-tab-btn{background:none;border:none;font-size:16px;color:var(--vd-blue-accent);cursor:pointer;padding:6px 10px;border-radius:4px;transition:background var(--vd-transition)}.add-tab-btn:hover{background:var(--vd-gray-100)}.view-data-content{display:flex;flex:1;overflow:hidden}.filter-sidebar{width:360px;min-width:360px;background:linear-gradient(180deg,var(--vd-navy) 0%,var(--vd-navy-dark) 100%);overflow-y:auto;padding:20px 16px;display:flex;flex-direction:column;gap:20px;scrollbar-width:thin;scrollbar-color:var(--vd-navy-light) transparent}.filter-sidebar::-webkit-scrollbar{width:6px}.filter-sidebar::-webkit-scrollbar-track{background:transparent}.filter-sidebar::-webkit-scrollbar-thumb{background:var(--vd-navy-light);border-radius:3px}.filter-section{display:flex;flex-direction:column;gap:10px}.filter-section-label{font-size:10px;font-weight:700;color:var(--vd-gray-400);text-transform:uppercase;letter-spacing:1px;margin:0;padding-left:2px}.filter-dropdown{position:relative;width:100%}.filter-dropdown-trigger{width:100%;display:flex;align-items:center;padding:11px 14px;background:var(--vd-navy-light);border:1px solid rgba(255,255,255,.1);border-radius:6px;cursor:pointer;font-size:13px;color:var(--vd-white-text);text-align:left;transition:all var(--vd-transition);gap:8px}.filter-dropdown-trigger:hover{background:#ffffff1a;border-color:#fff3}.filter-dropdown-trigger:focus{outline:none;border-color:var(--vd-blue-accent);box-shadow:0 0 0 2px #4a90d933}.filter-dropdown-trigger span:first-child{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.calendar-icon,.clock-icon{font-size:13px;opacity:.7;flex-shrink:0}.dropdown-chevron{font-size:9px;color:var(--vd-gray-400);flex-shrink:0;transition:transform var(--vd-transition)}.dropdown-chevron.open{transform:rotate(180deg)}.filter-dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--vd-white);border:1px solid var(--vd-border);border-radius:8px;box-shadow:var(--vd-shadow-lg);z-index:1000;max-height:320px;overflow-y:auto;animation:dropdownSlide .15s ease-out}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.filter-dropdown-menu.time-dropdown{min-width:240px}.dropdown-search{padding:10px 12px;border-bottom:1px solid var(--vd-border);position:sticky;top:0;background:var(--vd-white);z-index:1}.dropdown-search-input{width:100%;padding:8px 10px 8px 32px;border:1px solid var(--vd-border);border-radius:6px;font-size:13px;color:var(--vd-text-primary);outline:none;background:var(--vd-gray-100) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%239ca3af'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M21 21l-6-6m2-5a7 7 0 11-14 0 7 7 0 0114 0z'/%3E%3C/svg%3E") 8px center / 16px no-repeat;transition:all var(--vd-transition)}.dropdown-search-input:focus{border-color:var(--vd-blue-accent);background-color:var(--vd-white)}.dropdown-search-input::placeholder{color:var(--vd-text-muted)}.filter-dropdown-item{display:block;width:100%;padding:10px 14px;background:none;border:none;text-align:left;cursor:pointer;font-size:13px;color:var(--vd-text-primary);transition:background-color var(--vd-transition)}.filter-dropdown-item:hover{background-color:var(--vd-gray-100)}.filter-dropdown-item.selected{background-color:#4a90d914;color:var(--vd-blue-accent);font-weight:500}.filter-checkbox-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;font-size:13px;color:var(--vd-text-primary);transition:background-color var(--vd-transition);-webkit-user-select:none;user-select:none}.filter-checkbox-item:hover{background-color:var(--vd-gray-100)}.filter-checkbox-item input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--vd-blue-accent);border-radius:3px}.select-all-item{font-weight:500;color:var(--vd-text-secondary)}.filter-dropdown-divider{height:1px;background:var(--vd-border);margin:4px 0}.filter-dropdown-group{margin-bottom:4px}.filter-group-header{display:flex;align-items:center;gap:10px;padding:8px 14px;cursor:pointer;font-size:13px;font-weight:600;color:var(--vd-text-primary);background-color:var(--vd-gray-100);-webkit-user-select:none;user-select:none;border-top:1px solid var(--vd-border)}.filter-group-header:hover{background-color:var(--vd-gray-200, #e5e7eb)}.filter-group-header input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--vd-blue-accent);border-radius:3px}.filter-group-title{font-weight:600;text-transform:uppercase;letter-spacing:.02em;font-size:12px}.filter-grouped-item{padding-left:32px}.custom-date-range{padding:14px;border-top:1px solid var(--vd-border);display:flex;flex-direction:column;gap:12px}.date-input-group{display:flex;flex-direction:column;gap:6px}.date-input-group label{font-size:11px;font-weight:600;color:var(--vd-text-secondary);text-transform:uppercase;letter-spacing:.5px}.date-input-group input{padding:9px 12px;border:1px solid var(--vd-border);border-radius:6px;font-size:13px;color:var(--vd-text-primary);background:var(--vd-white);transition:all var(--vd-transition)}.date-input-group input:focus{outline:none;border-color:var(--vd-blue-accent);box-shadow:0 0 0 2px #4a90d91a}.apply-custom-btn{padding:10px 18px;background:var(--vd-blue-accent);color:var(--vd-white-text);border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;margin-top:4px;transition:background-color var(--vd-transition)}.apply-custom-btn:hover{background:var(--vd-blue-bright)}.show-more-btn{background:none;border:none;color:var(--vd-blue-accent);font-size:12px;font-weight:500;cursor:pointer;padding:8px 0;text-align:center;transition:color var(--vd-transition)}.show-more-btn:hover{color:var(--vd-blue-bright)}.measures-search{display:flex;align-items:center;gap:8px;padding:11px 14px;background:var(--vd-navy-light);border:1px solid rgba(255,255,255,.1);border-radius:6px;transition:all var(--vd-transition)}.measures-search:focus-within{border-color:var(--vd-blue-accent)}.search-icon-small{font-size:13px;color:var(--vd-gray-400)}.measures-input{flex:1;border:none;outline:none;font-size:13px;color:var(--vd-white-text);background:transparent}.measures-input::placeholder{color:var(--vd-gray-500)}.group-by-item{display:flex;align-items:center;gap:8px}.group-by-select{flex:1;padding:11px 36px 11px 14px;border:1px solid rgba(255,255,255,.1);border-radius:6px;font-size:13px;color:var(--vd-white-text);background:var(--vd-navy-light);cursor:pointer;transition:all var(--vd-transition);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%23b4bdc9'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:14px}.group-by-select:hover{background-color:#ffffff1a}.group-by-select:focus{outline:none;border-color:var(--vd-blue-accent)}.group-by-select option{background:var(--vd-navy);color:var(--vd-white-text)}.remove-group-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--vd-gray-400);cursor:pointer;font-size:16px;transition:all var(--vd-transition)}.remove-group-btn:hover{border-color:#ef4444;color:#ef4444;background:#ef44441a}.add-group-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#4a90d926;border:1px solid rgba(74,144,217,.3);border-radius:6px;color:var(--vd-blue-accent);cursor:pointer;font-size:18px;font-weight:300;transition:all var(--vd-transition)}.add-group-btn:hover{background:#4a90d940;border-color:var(--vd-blue-accent)}.plus-icon{line-height:1}.filter-actions{display:flex;flex-direction:column;gap:10px;margin-top:auto;padding-top:20px}.search-btn{width:100%;padding:13px;background:linear-gradient(135deg,var(--vd-blue-accent) 0%,var(--vd-blue-bright) 100%);color:var(--vd-white-text);border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all var(--vd-transition);box-shadow:0 2px 8px #4a90d94d}.search-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #4a90d966}.search-btn:active{transform:translateY(0)}.clear-btn{width:100%;padding:11px;background:none;color:var(--vd-gray-400);border:none;font-size:13px;cursor:pointer;transition:color var(--vd-transition)}.clear-btn:hover{color:var(--vd-white-text)}.data-table-container{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--vd-white);position:relative}.table-controls{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--vd-border);background:var(--vd-white)}.table-controls-left{display:flex;align-items:center;gap:10px}.nav-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--vd-white);border:1px solid var(--vd-border);border-radius:6px;color:var(--vd-text-secondary);cursor:pointer;font-size:12px;font-weight:600;transition:all var(--vd-transition)}.nav-btn:hover{border-color:var(--vd-blue-accent);color:var(--vd-blue-accent)}.saved-searches-link,.save-as-link{color:var(--vd-text-secondary);font-size:13px;cursor:pointer;transition:color var(--vd-transition);padding:0 8px}.saved-searches-link:hover,.save-as-link:hover{color:var(--vd-blue-accent)}.table-controls-right{display:flex;align-items:center;gap:10px}.share-btn,.export-btn{padding:9px 18px;background:var(--vd-white);border:1px solid var(--vd-border);border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;color:var(--vd-text-primary);transition:all var(--vd-transition)}.share-btn:hover{border-color:var(--vd-blue-accent);color:var(--vd-blue-accent)}.export-btn{background:var(--vd-blue-accent);color:var(--vd-white-text);border-color:var(--vd-blue-accent)}.export-btn:hover{background:var(--vd-blue-bright);border-color:var(--vd-blue-bright)}.results-summary{padding:12px 20px;font-size:13px;color:var(--vd-text-secondary);border-bottom:1px solid var(--vd-border);background:var(--vd-gray-100)}.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#fffffff2;display:flex;align-items:center;justify-content:center;z-index:100}[data-theme=dark] .loading-overlay{background:#1a1a2ef2}.loading-spinner{display:flex;align-items:center;gap:12px;padding:20px 32px;background:var(--vd-white);border-radius:10px;box-shadow:var(--vd-shadow-lg);font-size:14px;color:var(--vd-text-secondary)}.loading-spinner:before{content:"";width:20px;height:20px;border:2px solid var(--vd-gray-300);border-top-color:var(--vd-blue-accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.data-table-wrapper{flex:1;overflow:auto}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table thead{position:sticky;top:0;z-index:10}.data-table th{padding:14px 16px;text-align:left;font-weight:600;font-size:12px;color:var(--vd-text-secondary);background:var(--vd-gray-100);border-bottom:1px solid var(--vd-border);white-space:nowrap;text-transform:uppercase;letter-spacing:.3px}.data-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color var(--vd-transition)}.data-table th.sortable:hover{color:var(--vd-blue-accent)}.data-table th.numeric{text-align:right}.sort-indicator{display:inline-block;margin-left:4px;font-size:10px;color:var(--vd-blue-accent)}.data-table td{padding:14px 16px;border-bottom:1px solid var(--vd-border-light);color:var(--vd-text-primary);vertical-align:middle}.data-table td.numeric{text-align:right;font-variant-numeric:tabular-nums}.data-table tbody tr{transition:background-color var(--vd-transition)}.data-table tbody tr:hover{background-color:var(--vd-gray-100)}.view-link{color:var(--vd-blue-accent);text-decoration:none;font-weight:500;transition:color var(--vd-transition)}.view-link:hover{color:var(--vd-blue-bright);text-decoration:underline}.clickable-cell{cursor:pointer;transition:color var(--vd-transition)}.clickable-cell:hover{color:var(--vd-blue-accent)}.aggregated-count{display:inline-flex;align-items:center;justify-content:center;min-width:28px;padding:3px 8px;background:#4a90d91a;color:var(--vd-blue-accent);border-radius:4px;font-size:12px;font-weight:600;cursor:pointer;transition:all var(--vd-transition)}.aggregated-count:hover{background:#4a90d933;transform:scale(1.05)}.single-value{color:var(--vd-text-primary)}.empty-value{color:var(--vd-text-muted)}.state-downtime{color:#f59e0b;font-weight:500}.state-uptime{color:#10b981;font-weight:500}.when-cell{font-size:12px;color:var(--vd-text-secondary);line-height:1.5}.when-row{display:flex;gap:8px;align-items:center}.when-date{color:var(--vd-text-primary);font-weight:500}.when-time{color:var(--vd-text-secondary)}.when-separator{color:var(--vd-text-muted)}.duration-cell{color:var(--vd-text-secondary);font-weight:500}.cell-drilldown-popup{position:fixed;background:var(--vd-white);border:1px solid var(--vd-border);border-radius:10px;box-shadow:var(--vd-shadow-lg);min-width:180px;max-width:280px;max-height:320px;overflow-y:auto;z-index:1000;animation:popupFade .15s ease-out}@keyframes popupFade{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.drilldown-header{display:flex;align-items:center;gap:8px;padding:12px 16px;font-size:12px;font-weight:600;color:var(--vd-text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--vd-border);background:var(--vd-gray-100);border-radius:10px 10px 0 0;position:sticky;top:0}.drilldown-header .plus-icon{color:var(--vd-blue-accent)}.drilldown-values{padding:6px 0}.drilldown-value{padding:10px 16px;font-size:13px;color:var(--vd-text-primary);cursor:pointer;transition:background-color var(--vd-transition);display:flex;align-items:center;gap:10px}.drilldown-value:hover{background-color:var(--vd-gray-100)}.drilldown-value:before{content:"";width:6px;height:6px;background:var(--vd-blue-accent);border-radius:50%;flex-shrink:0}.text-filter-group{display:flex;flex-direction:column;gap:4px}.text-filter-label{font-size:11px;color:var(--vd-gray-400);padding-left:2px;font-weight:500}.text-filter-input{width:100%;padding:11px 14px;background:var(--vd-navy-light);border:1px solid rgba(255,255,255,.1);border-radius:6px;font-size:13px;color:var(--vd-white-text);outline:none;transition:all var(--vd-transition);box-sizing:border-box}.text-filter-input:focus{border-color:var(--vd-blue-accent);box-shadow:0 0 0 2px #4a90d933}.text-filter-input::placeholder{color:var(--vd-gray-500)}.hour-range-group{display:flex;flex-direction:column;gap:6px}.hour-range-label{font-size:11px;color:var(--vd-gray-400);padding-left:2px;font-weight:500}.hour-range-inputs{display:flex;align-items:center;gap:8px}.hour-input{flex:1;padding:10px 12px;background:var(--vd-navy-light);border:1px solid rgba(255,255,255,.1);border-radius:6px;font-size:13px;color:var(--vd-white-text);outline:none;transition:all var(--vd-transition);text-align:center;-webkit-appearance:textfield;appearance:textfield;-moz-appearance:textfield}.hour-input::-webkit-outer-spin-button,.hour-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.hour-input:focus{border-color:var(--vd-blue-accent);box-shadow:0 0 0 2px #4a90d933}.hour-input::placeholder{color:var(--vd-gray-500)}.hour-range-separator{color:var(--vd-gray-400);font-size:14px;flex-shrink:0}.th-grouped{color:var(--vd-blue-accent);font-weight:700}.th-aggregated{color:var(--vd-text-secondary);font-weight:600;font-style:italic}.event-count-cell{font-weight:600;font-variant-numeric:tabular-nums;color:var(--vd-text-primary)}.error-banner{display:flex;align-items:center;gap:10px;padding:12px 20px;background:#fef2f2;border-bottom:1px solid #fecaca;color:#b91c1c;font-size:13px}.error-icon{font-size:16px;flex-shrink:0}.error-retry-btn{margin-left:auto;padding:6px 14px;background:var(--vd-white);border:1px solid #fecaca;border-radius:6px;color:#b91c1c;font-size:12px;font-weight:600;cursor:pointer;transition:all var(--vd-transition)}.error-retry-btn:hover{background:#fef2f2;border-color:#b91c1c}.empty-state-cell{text-align:center;padding:48px 20px!important;color:var(--vd-text-muted);font-size:14px}.pagination-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-top:1px solid var(--vd-border);background:var(--vd-gray-100);flex-shrink:0}.pagination-info{font-size:13px;color:var(--vd-text-secondary)}.pagination-controls{display:flex;align-items:center;gap:20px}.page-size-label{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--vd-text-secondary)}.page-size-select{padding:6px 10px;border:1px solid var(--vd-border);border-radius:6px;font-size:13px;color:var(--vd-text-primary);background:var(--vd-white);cursor:pointer;outline:none;transition:border-color var(--vd-transition)}.page-size-select:focus{border-color:var(--vd-blue-accent)}.page-nav{display:flex;align-items:center;gap:6px}.page-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--vd-white);border:1px solid var(--vd-border);border-radius:6px;color:var(--vd-text-secondary);cursor:pointer;font-size:14px;font-weight:600;transition:all var(--vd-transition)}.page-btn:hover:not(:disabled){border-color:var(--vd-blue-accent);color:var(--vd-blue-accent)}.page-btn:disabled{opacity:.35;cursor:not-allowed}.page-indicator{font-size:13px;color:var(--vd-text-secondary);padding:0 8px;white-space:nowrap}@media (max-width: 1200px){.filter-sidebar{width:320px;min-width:320px}}@media (max-width: 992px){.filter-sidebar{width:280px;min-width:280px;padding:16px 12px}.pagination-bar{flex-direction:column;gap:10px;align-items:flex-start}}@media (max-width: 768px){.view-data-content{flex-direction:column}.filter-sidebar{width:100%;min-width:100%;max-height:50vh;border-bottom:1px solid var(--vd-border)}.pagination-controls{flex-direction:column;align-items:flex-start;gap:10px}}.actions-cell{text-align:center;white-space:nowrap}.view-explore-btn{padding:6px 14px;background:#4a90d91a;color:var(--vd-blue-accent);border:1px solid rgba(74,144,217,.3);border-radius:5px;font-size:12px;font-weight:600;cursor:pointer;transition:all var(--vd-transition)}.view-explore-btn:hover{background:var(--vd-blue-accent);color:var(--vd-white-text);border-color:var(--vd-blue-accent)}.sidebar{position:fixed;left:0;top:0;width:260px;height:100vh;background:linear-gradient(180deg,#667eea,#764ba2);color:#fff;display:flex;flex-direction:column;box-shadow:4px 0 20px #0000001a;z-index:1000;transition:transform .3s ease}.sidebar-hidden{transform:translate(-100%)}.sidebar-toggle{position:fixed;left:260px;top:12px;z-index:1001;width:28px;height:48px;border:none;background:linear-gradient(180deg,#667eea,#764ba2);color:#fff;font-size:1.1rem;font-weight:700;cursor:pointer;border-radius:0 6px 6px 0;display:flex;align-items:center;justify-content:center;box-shadow:4px 2px 10px #00000026;transition:left .3s ease,background .2s ease;padding:0;line-height:1}.sidebar-toggle.collapsed{left:0}.sidebar-toggle:hover{background:linear-gradient(180deg,#5a6fd6,#6a3f94)}.sidebar-header{padding:1.5rem 1.5rem 1rem;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo{font-size:1.5rem;font-weight:700;letter-spacing:-.5px}.sidebar-nav{flex:1;padding:1rem;display:flex;flex-direction:column;gap:.375rem;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:.875rem;padding:.875rem 1rem;background:transparent;border:none;border-radius:8px;color:#fffc;cursor:pointer;transition:all .2s ease;font-size:.95rem;text-align:left;width:100%}.nav-item:hover{background:#ffffff1a;color:#fff}.nav-item.active{background:#fff3;color:#fff;font-weight:600}.nav-icon{font-size:1.15rem;display:flex;align-items:center;justify-content:center;width:24px;flex-shrink:0}.nav-label{font-weight:500}.sidebar-footer{padding:1rem;border-top:1px solid rgba(255,255,255,.1)}.user-info{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#ffffff1a;border-radius:8px;margin-bottom:.75rem}.user-avatar{width:36px;height:36px;background:#fff3;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}.user-details{flex:1;min-width:0}.user-name{font-weight:600;font-size:.875rem;margin-bottom:.125rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.7rem;opacity:.75;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logout-button{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:8px;color:#fff;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.logout-button:hover{background:#fff3}.logout-icon{font-size:1rem}.theme-toggle-wrapper{padding:0 0 .75rem}.theme-toggle-btn{width:100%;display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:8px;color:#fff;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.theme-toggle-btn:hover{background:#fff3}.theme-toggle-icon{font-size:1.1rem;display:flex;align-items:center}.theme-toggle-label{flex:1;text-align:left}.theme-toggle-switch{position:relative;width:36px;height:20px;background:#fff3;border-radius:10px;transition:background .2s ease;flex-shrink:0}.theme-toggle-switch.active{background:#fff6}.theme-toggle-knob{position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform .2s ease}.theme-toggle-switch.active .theme-toggle-knob{transform:translate(16px)}.app-layout{display:flex;min-height:100vh}.app-content{flex:1;margin-left:260px;transition:margin-left .3s ease;min-width:0}.app-content.sidebar-collapsed{margin-left:0}.data-status-indicator{display:inline-flex;align-items:center;gap:6px}.data-status-dot{width:10px;height:10px;border-radius:50%;display:inline-block;flex-shrink:0}.data-status-dot--green{background-color:#4caf50}.data-status-dot--yellow{background-color:#ffc107}.data-status-dot--red{background-color:#f44336}.data-status-label{font-size:.85rem;color:var(--text-secondary);white-space:nowrap}.time-range-selector{display:inline-flex;align-items:center;gap:8px}.time-range-date{font-size:.85rem;color:var(--text-secondary);white-space:nowrap}.time-range-dropdown{padding:6px 10px;border:1px solid var(--border-primary);border-radius:6px;background:var(--input-bg);color:var(--text-primary);font-size:.85rem;cursor:pointer;outline:none;transition:border-color .2s,background .2s;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.time-range-dropdown:hover{border-color:var(--accent-primary)}.time-range-dropdown:focus{border-color:var(--accent-primary)}.time-range-dropdown option{background:var(--bg-elevated);color:var(--text-primary)}.monitoring-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background-color:var(--bg-elevated);border-bottom:1px solid var(--border-primary);gap:16px;flex-wrap:wrap}.monitoring-header__left{display:flex;align-items:center;gap:12px;min-width:0}.monitoring-header__title{margin:0;font-size:16px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.monitoring-header__right{display:flex;align-items:center;gap:12px;flex-shrink:0}.monitoring-header__metric-badge{display:inline-flex;align-items:center;padding:4px 10px;font-size:13px;font-weight:500;color:var(--accent-primary);background-color:var(--accent-subtle);border-radius:12px;white-space:nowrap}.monitoring-header__view-toggle{display:inline-flex;border:1px solid var(--border-primary);border-radius:6px;overflow:hidden}.monitoring-header__view-btn{padding:6px 14px;font-size:13px;font-weight:500;color:var(--text-secondary);background:transparent;border:none;cursor:pointer;transition:background-color .15s,color .15s}.monitoring-header__view-btn:hover{background-color:var(--accent-subtle)}.monitoring-header__view-btn--active{color:#fff;background-color:var(--accent-primary)}.monitoring-header__view-btn--active:hover{background-color:var(--accent-hover)}.monitoring-metric-sidebar{width:280px;background:var(--bg-primary);border-right:1px solid var(--border-primary);display:flex;flex-direction:column;overflow-y:auto}.monitoring-metric-sidebar-header{padding:16px;border-bottom:1px solid var(--border-primary)}.monitoring-metric-sidebar-header .header-row{display:flex;align-items:center;gap:8px;margin-bottom:12px}.monitoring-metric-sidebar-header .header-icon{font-size:18px}.monitoring-metric-sidebar-header .header-title{font-weight:600;font-size:16px;flex:1;color:var(--text-primary)}.monitoring-metric-sidebar-header .deselect-all-btn{background:none;border:none;color:var(--accent-primary);font-size:12px;cursor:pointer;padding:4px 8px;border-radius:4px}.monitoring-metric-sidebar-header .deselect-all-btn:hover{background:var(--accent-subtle)}.monitoring-metric-sidebar-header .metric-search-input{width:100%;padding:8px 12px;border:1px solid var(--border-primary);border-radius:6px;font-size:14px;box-sizing:border-box;background:var(--input-bg);color:var(--text-primary)}.monitoring-metric-sidebar-header .metric-search-input:focus{outline:none;border-color:var(--accent-primary)}.monitoring-metric-sidebar .sort-section{padding:12px 16px;border-bottom:1px solid var(--border-primary)}.monitoring-metric-sidebar .sort-label{font-size:11px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.monitoring-metric-sidebar .sort-select{width:100%;padding:6px 8px;border:1px solid var(--border-primary);border-radius:4px;font-size:13px;background:var(--input-bg);color:var(--text-primary);cursor:pointer}.monitoring-metric-sidebar .metric-section{border-bottom:1px solid var(--border-primary)}.monitoring-metric-sidebar .section-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--bg-secondary)}.monitoring-metric-sidebar .section-title{font-size:11px;font-weight:600;color:var(--text-secondary);letter-spacing:.5px}.monitoring-metric-sidebar .metric-list{padding:8px 0}.monitoring-metric-sidebar .metric-item{display:flex;align-items:center;gap:10px;padding:8px 16px;cursor:pointer;transition:background .2s}.monitoring-metric-sidebar .metric-item:hover{background:var(--bg-secondary)}.monitoring-metric-sidebar .metric-item.selected{background:var(--bg-primary)}.monitoring-metric-sidebar .metric-item.available{padding-left:12px}.monitoring-metric-sidebar .metric-color-dot{width:12px;height:12px;border-radius:2px;flex-shrink:0}.monitoring-metric-sidebar .metric-checkbox{width:16px;height:16px;flex-shrink:0}.monitoring-metric-sidebar .metric-checkbox input[type=checkbox]{cursor:pointer}.monitoring-metric-sidebar .metric-name{flex:1;font-size:13px;color:var(--text-primary)}.monitoring-metric-sidebar .metric-remove-btn{background:none;border:none;font-size:14px;cursor:pointer;padding:2px 6px;border-radius:3px;color:var(--text-secondary);opacity:0;transition:opacity .2s}.monitoring-metric-sidebar .metric-item:hover .metric-remove-btn{opacity:1}.monitoring-metric-sidebar .metric-remove-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.monitoring-metric-sidebar .sidebar-loading{display:flex;align-items:center;justify-content:center;padding:32px 16px;color:var(--text-secondary);font-size:14px}.monitoring-metric-sidebar .sidebar-error{padding:16px;text-align:center}.monitoring-metric-sidebar .sidebar-error .error-message{color:var(--status-error-text);font-size:13px;margin-bottom:12px}.monitoring-metric-sidebar .sidebar-error .retry-btn{background:var(--accent-primary);color:#fff;border:none;padding:6px 16px;border-radius:4px;font-size:13px;cursor:pointer}.monitoring-metric-sidebar .sidebar-error .retry-btn:hover{background:var(--accent-hover)}.metric-limit-message{padding:8px 16px;font-size:12px;color:var(--text-warning, #e6a817);background:var(--bg-warning, rgba(230, 168, 23, .1));border-bottom:1px solid var(--border-primary)}.metric-item.available.disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.snapshot-card{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background-color:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:8px;min-width:140px;flex-shrink:0}.snapshot-card-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.snapshot-card-content{display:flex;flex-direction:column;gap:2px;overflow:hidden}.snapshot-card-parameter{font-size:.75rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.snapshot-card-value{font-size:1rem;font-weight:600;color:var(--text-primary);white-space:nowrap}.snapshot-bar{display:flex;gap:10px;overflow-x:auto;padding:8px 0;scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-track)}.snapshot-bar::-webkit-scrollbar{height:6px}.snapshot-bar::-webkit-scrollbar-track{background:transparent}.snapshot-bar::-webkit-scrollbar-thumb{background-color:var(--scrollbar-thumb);border-radius:3px}.snapshot-card-placeholder{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background-color:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:8px;min-width:140px;flex-shrink:0}.placeholder-dot{width:10px;height:10px;border-radius:50%;background-color:var(--border-primary);animation:pulse 1.4s ease-in-out infinite}.placeholder-content{display:flex;flex-direction:column;gap:6px}.placeholder-line{height:10px;border-radius:4px;background-color:var(--border-primary);animation:pulse 1.4s ease-in-out infinite}.placeholder-line-short{width:60px}.placeholder-line-long{width:40px}@keyframes pulse{0%,to{opacity:.4}50%{opacity:.8}}.monitoring-chart-container{display:flex;flex-direction:column;width:100%;position:relative}.monitoring-chart-canvas{width:100%;height:400px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px}.monitoring-chart-resolution{font-size:12px;color:var(--text-muted);padding:6px 0 0 4px}.monitoring-chart-loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:var(--bg-overlay);border-radius:8px;z-index:10}.monitoring-chart-loading-overlay .spinner{width:32px;height:32px;border:3px solid var(--border-primary);border-top-color:var(--accent-primary);border-radius:50%;animation:monitoring-chart-spin .8s linear infinite}@keyframes monitoring-chart-spin{to{transform:rotate(360deg)}}.monitoring-chart-error{display:flex;align-items:center;justify-content:center;width:100%;height:400px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;color:var(--status-error-text);font-size:14px}.monitoring-chart-empty{display:flex;align-items:center;justify-content:center;width:100%;height:400px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;color:var(--text-muted);font-size:14px}.tile-view-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;padding:16px 0}.tile-view-card{display:flex;flex-direction:column;background-color:var(--bg-primary);border-radius:10px;padding:14px 16px 8px;box-shadow:var(--shadow-sm);border:1px solid var(--border-secondary);min-height:180px;overflow:hidden}.tile-card-header{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.tile-card-title{display:flex;align-items:flex-start;gap:8px}.tile-view-color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:3px}.tile-card-label{display:flex;flex-direction:column;gap:2px}.tile-card-name{font-size:.82rem;font-weight:600;color:var(--text-primary);word-break:break-word}.tile-card-source{font-size:.7rem;color:var(--text-muted)}.tile-card-stats{display:flex;flex-wrap:wrap;gap:8px 16px;padding-left:18px}.tile-stat{display:flex;align-items:baseline;gap:6px;min-width:0}.tile-stat-label{font-size:.68rem;color:var(--text-muted);flex-shrink:0}.tile-stat-value{font-size:.9rem;font-weight:700;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tile-card-chart-area{flex:1;min-height:60px;position:relative;overflow:hidden}.tile-mini-chart{width:100%;height:100%;min-height:60px}.tile-chart-empty{display:flex;align-items:center;justify-content:center;height:100%;font-size:.75rem;color:var(--text-muted)}.production-run-bar{display:flex;align-items:center;gap:20px;padding:10px 16px;background-color:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:8px;font-size:.85rem;color:var(--text-secondary);flex-wrap:wrap}.production-run-bar__item{display:flex;align-items:center;gap:6px;white-space:nowrap}.production-run-bar__label{color:var(--text-muted)}.production-run-bar__value{color:var(--text-primary);font-weight:500}.production-run-bar__state--uptime{color:#4caf50;font-weight:600}.production-run-bar__state--downtime{color:#f44336;font-weight:600}.production-run-bar__empty{color:var(--text-muted);font-style:italic}.production-run-bar--loading{display:flex;align-items:center;gap:20px;padding:10px 16px;background-color:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:8px}.production-run-bar__skeleton{height:12px;border-radius:4px;background-color:var(--border-primary);animation:production-run-pulse 1.4s ease-in-out infinite}.production-run-bar__skeleton--short{width:80px}.production-run-bar__skeleton--medium{width:120px}.production-run-bar__skeleton--long{width:100px}@keyframes production-run-pulse{0%,to{opacity:.4}50%{opacity:.8}}.monitoring-dashboard{display:flex;flex-direction:column;height:100vh;background:var(--bg-secondary)}.monitoring-selectors{display:flex;align-items:flex-start;gap:16px;padding:12px 20px;background:var(--bg-primary);border-bottom:1px solid var(--border-primary)}.monitoring-selector-group{display:flex;flex-direction:column;gap:4px;min-width:200px}.monitoring-selector-label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.monitoring-selector-wrapper{position:relative;display:flex;align-items:center}.monitoring-select{width:100%;padding:8px 12px;border:1px solid var(--border-primary);border-radius:6px;background:var(--input-bg);font-size:14px;color:var(--text-primary);cursor:pointer;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.monitoring-select:disabled{background:var(--bg-secondary);color:var(--text-muted);cursor:not-allowed}.monitoring-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #2196f326}.monitoring-selector-spinner{position:absolute;right:32px;width:14px;height:14px;border:2px solid var(--border-primary);border-top-color:var(--accent-primary);border-radius:50%;animation:monitoring-spin .6s linear infinite}@keyframes monitoring-spin{to{transform:rotate(360deg)}}.monitoring-selector-error{display:flex;align-items:center;gap:8px;font-size:13px;color:#e53935}.monitoring-retry-btn{padding:2px 10px;border:1px solid #e53935;border-radius:4px;background:var(--bg-primary);color:#e53935;font-size:12px;cursor:pointer}.monitoring-retry-btn:hover{background:var(--status-error-bg)}.monitoring-prompt{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--text-secondary)}.monitoring-prompt-icon{font-size:48px;margin-bottom:8px}.monitoring-prompt-title{margin:0;font-size:20px;font-weight:600;color:var(--text-primary)}.monitoring-prompt-text{margin:0;font-size:14px;color:var(--text-muted)}.monitoring-body{display:flex;flex:1;overflow:hidden}.monitoring-main{flex:1;display:flex;flex-direction:column;overflow:auto;padding:16px 20px;background:var(--bg-primary);gap:12px}.monitoring-visualization{flex:1;min-height:0}.dashboard-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background-color:var(--bg-elevated);border-bottom:1px solid var(--border-primary);gap:16px;flex-wrap:wrap}.dashboard-header__left{display:flex;align-items:center;gap:12px;min-width:0}.dashboard-header__title{margin:0;font-size:16px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-header__right{display:flex;align-items:center;gap:12px;flex-shrink:0}.dashboard-header__select-wrapper{position:relative;display:inline-flex;align-items:center}.dashboard-header__select{padding:6px 12px;font-size:13px;font-weight:500;color:var(--text-primary);background-color:var(--input-bg);border:1px solid var(--border-primary);border-radius:6px;cursor:pointer;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto;min-width:160px}.dashboard-header__select:focus{outline:2px solid var(--accent-primary);outline-offset:1px}.dashboard-header__select:disabled{opacity:.6;cursor:not-allowed}.dashboard-header__select option{background-color:var(--bg-elevated);color:var(--text-primary)}.dashboard-header__loading-indicator{position:absolute;right:8px;width:14px;height:14px;border:2px solid var(--border-primary);border-top-color:var(--accent-primary);border-radius:50%;animation:dashboard-header-spin .6s linear infinite;pointer-events:none}@keyframes dashboard-header-spin{to{transform:rotate(360deg)}}.dashboard-header__site-error{display:flex;align-items:center;gap:8px}.dashboard-header__error-text{font-size:13px;color:var(--status-error-text)}.dashboard-header__retry-btn{padding:4px 10px;font-size:12px;font-weight:500;color:var(--text-primary);background-color:transparent;border:1px solid var(--border-primary);border-radius:4px;cursor:pointer;transition:background-color .15s}.dashboard-header__retry-btn:hover{background-color:var(--accent-subtle)}.dashboard-header__retry-btn:focus{outline:2px solid var(--accent-primary);outline-offset:1px}.dashboard-header__metric-dropdown{position:relative}.dashboard-header__metric-dropdown-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:500;color:var(--text-primary);background-color:var(--input-bg);border:1px solid var(--border-primary);border-radius:6px;cursor:pointer;transition:background-color .15s;white-space:nowrap}.dashboard-header__metric-dropdown-btn:hover{background-color:var(--accent-subtle)}.dashboard-header__metric-dropdown-btn:focus{outline:2px solid var(--accent-primary);outline-offset:1px}.dashboard-header__dropdown-arrow{font-size:10px;color:var(--text-secondary)}.dashboard-header__metric-dropdown-menu{position:absolute;top:calc(100% + 4px);right:0;min-width:160px;background-color:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:6px;padding:6px 0;z-index:100;box-shadow:var(--shadow-lg)}.dashboard-header__metric-option{display:flex;align-items:center;gap:8px;padding:6px 12px;font-size:13px;color:var(--text-primary);cursor:pointer;transition:background-color .15s}.dashboard-header__metric-option:hover{background-color:var(--accent-subtle)}.dashboard-header__metric-option input[type=checkbox]{accent-color:var(--accent-primary);cursor:pointer}.dashboard-header__metric-label{-webkit-user-select:none;user-select:none}.dashboard-header__line-dropdown-menu{min-width:220px;max-height:320px;overflow-y:auto}.dashboard-header__line-actions{display:flex;gap:8px;padding:4px 12px 8px;border-bottom:1px solid var(--border-primary);margin-bottom:4px}.dashboard-header__line-action-btn{flex:1;background:none;border:1px solid var(--border-primary);border-radius:4px;padding:4px 8px;font-size:12px;color:var(--text-secondary);cursor:pointer;transition:background-color .15s,color .15s}.dashboard-header__line-action-btn:hover{background-color:var(--accent-subtle);color:var(--text-primary)}.dashboard-header__line-empty{padding:8px 12px;font-size:13px;color:var(--text-secondary)}.dashboard-header__view-toggle{display:inline-flex;border:1px solid var(--border-primary);border-radius:6px;overflow:hidden}.dashboard-header__view-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:500;color:var(--text-secondary);background-color:var(--input-bg);border:none;cursor:pointer;transition:background-color .15s,color .15s;white-space:nowrap}.dashboard-header__view-btn+.dashboard-header__view-btn{border-left:1px solid var(--border-primary)}.dashboard-header__view-btn:hover{background-color:var(--accent-subtle);color:var(--text-primary)}.dashboard-header__view-btn--active,.dashboard-header__view-btn--active:hover{background-color:var(--accent-primary);color:#fff}.state-history-bar{display:flex;flex-direction:row;width:100%;height:24px;border-radius:4px;overflow:hidden;background-color:var(--border-primary)}.state-history-bar--empty{background-color:var(--border-primary)}.state-history-bar__segment{height:100%;min-width:1px}.state-history-bar__segment--uptime{background-color:#4caf50}.state-history-bar__segment--downtime{background-color:#f44336}.line-row{background-color:var(--bg-elevated);border-bottom:1px solid var(--border-primary);transition:background-color .15s}.line-row:hover{background-color:var(--table-row-hover)}.line-row__name-cell{padding:10px 12px;min-width:160px}.line-row__name-wrapper{display:flex;flex-direction:column;gap:2px}.line-row__name{font-size:14px;font-weight:600;color:var(--text-primary)}.line-row__name--link{text-decoration:none;color:var(--text-primary);transition:color .15s}.line-row__name--link:hover{color:var(--accent-primary);text-decoration:underline}.line-row__name--link:focus{outline:2px solid var(--accent-primary);outline-offset:1px;border-radius:2px}.line-row__explore-link{font-size:12px;color:var(--accent-primary);text-decoration:none;transition:color .15s}.line-row__explore-link:hover{color:var(--accent-hover);text-decoration:underline}.line-row__explore-link:focus{outline:2px solid var(--accent-primary);outline-offset:1px;border-radius:2px}.line-row__state-cell{padding:10px 12px;min-width:200px;width:30%}.line-row__metric-cell{padding:10px 12px;text-align:right;font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;min-width:80px}.line-row__run-cell{padding:10px 12px;min-width:180px}.line-row__run-info{display:flex;flex-direction:column;gap:1px}.line-row__run-pwo{font-size:13px;font-weight:600;color:var(--text-primary)}.line-row__run-product{font-size:12px;color:var(--text-secondary)}.line-row__run-duration{font-size:12px;color:var(--status-success)}.line-row__no-run{font-size:13px;color:var(--text-muted);font-style:italic}.line-row__warning-cell{padding:10px 12px;text-align:center;min-width:48px}.line-row__warning-wrapper{position:relative;display:inline-block}.line-row__warning-btn{background:none;border:none;cursor:pointer;font-size:16px;padding:2px 4px;border-radius:4px;transition:background-color .15s}.line-row__warning-btn:hover{background-color:#ffc10726}.line-row__warning-btn:focus{outline:2px solid #ffc107;outline-offset:1px}.line-row__warning-popover{position:absolute;right:0;top:calc(100% + 6px);min-width:220px;max-width:320px;background-color:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:6px;padding:8px 0;z-index:200;box-shadow:var(--shadow-lg)}.line-row__warning-list{list-style:none;margin:0;padding:0}.line-row__warning-item{padding:6px 12px;font-size:12px;color:var(--status-warning);line-height:1.4;border-bottom:1px solid var(--border-primary)}.line-row__warning-item:last-child{border-bottom:none}.line-row--loading td{padding:10px 12px}.line-row__loading-indicator{display:flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:13px}.line-row__spinner{width:14px;height:14px;border:2px solid var(--border-primary);border-top-color:var(--accent-primary);border-radius:50%;animation:line-row-spin .6s linear infinite}@keyframes line-row-spin{to{transform:rotate(360deg)}}.line-row--error td{padding:10px 12px}.line-row__error{display:flex;align-items:center;gap:8px}.line-row__error-icon{font-size:14px}.line-row__error-name{font-size:14px;font-weight:600;color:var(--text-primary)}.line-row__error-text{font-size:13px;color:var(--status-error-text)}.line-table{width:100%;border-collapse:collapse;background-color:var(--bg-elevated);border-radius:8px;overflow:hidden}.line-table__header-row{background-color:var(--table-header-bg);border-bottom:2px solid var(--border-primary)}.line-table__header-cell{padding:10px 12px;font-size:12px;font-weight:600;color:var(--text-secondary);text-align:left;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.line-table__header-cell--metric{text-align:right;min-width:80px}.line-table__header-cell--warnings{text-align:center;min-width:48px}.line-table__skeleton-row{border-bottom:1px solid var(--border-primary)}.line-table__skeleton-row td{padding:14px 12px}.line-table__skeleton-bar{height:16px;background:linear-gradient(90deg,var(--border-primary) 25%,var(--border-secondary) 50%,var(--border-primary) 75%);background-size:200% 100%;border-radius:4px;animation:line-table-shimmer 1.5s ease-in-out infinite}@keyframes line-table-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.line-table__empty-container{display:flex;align-items:center;justify-content:center;padding:48px 16px;background-color:var(--bg-elevated);border-radius:8px;border:1px solid var(--border-primary)}.line-table__empty-message{margin:0;font-size:14px;color:var(--text-muted);font-style:italic}.line-table__error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px 16px;background-color:var(--bg-elevated);border-radius:8px;border:1px solid var(--border-primary)}.line-table__error-icon{font-size:24px}.line-table__error-message{margin:0;font-size:14px;color:var(--status-error-text);text-align:center}.line-table__retry-btn{padding:6px 16px;font-size:13px;font-weight:500;color:var(--text-primary);background-color:transparent;border:1px solid var(--border-primary);border-radius:6px;cursor:pointer;transition:background-color .15s}.line-table__retry-btn:hover{background-color:var(--accent-subtle)}.line-table__retry-btn:focus{outline:2px solid var(--accent-primary);outline-offset:1px}.line-card{display:flex;flex-direction:column;gap:12px;padding:14px 16px;background-color:var(--bg-elevated);border:1px solid var(--border-primary);border-top:3px solid var(--border-primary);border-radius:8px;min-height:150px;box-shadow:var(--shadow-sm, 0 1px 2px rgba(0, 0, 0, .08))}.line-card__header{display:flex;align-items:center;justify-content:space-between;gap:8px}.line-card__name{font-size:14px;font-weight:700;color:var(--text-primary);text-decoration:none;text-transform:uppercase;letter-spacing:.02em}.line-card__name:hover{color:var(--accent-primary);text-decoration:underline}.line-card__warning{font-size:13px;cursor:help}.line-card__metrics{display:flex;flex-direction:column;gap:4px}.line-card__metric{display:flex;align-items:center;justify-content:space-between;font-size:12px}.line-card__metric-label{color:var(--text-secondary)}.line-card__metric-value{font-weight:600;color:var(--text-primary)}.line-card__status-row{display:flex;align-items:center;gap:8px;margin-top:auto}.line-card__status-label{font-size:10px;font-weight:600;letter-spacing:.06em;color:var(--text-muted)}.line-card__status-badge{padding:3px 10px;font-size:11px;font-weight:700;color:#fff;border-radius:12px;text-transform:uppercase;letter-spacing:.03em}.line-card__status-badge--none{background-color:var(--border-primary);color:var(--text-secondary)}.line-card__status-duration{margin-left:auto;font-size:12px;font-weight:600;color:var(--text-secondary)}.line-card__run{display:flex;flex-direction:column;gap:2px;border-top:1px solid var(--border-primary);padding-top:8px}.line-card__run-product{font-size:12px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.line-card__run-meta{font-size:11px;color:var(--text-secondary)}.line-card__no-run{font-size:12px;color:var(--text-muted);font-style:italic}.line-card--loading,.line-card--error{align-items:center;justify-content:center;text-align:center;gap:8px;font-size:13px;color:var(--text-secondary)}.line-card__error-icon{font-size:18px}.line-card__error-text{font-size:12px;color:var(--status-error-text)}.line-card__spinner{width:18px;height:18px;border:2px solid var(--border-primary);border-top-color:var(--accent-primary);border-radius:50%;animation:line-card-spin .6s linear infinite}@keyframes line-card-spin{to{transform:rotate(360deg)}}.line-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;padding:16px}.line-grid__skeleton-card{min-height:150px;border-radius:8px;background:linear-gradient(90deg,var(--border-primary) 25%,var(--bg-elevated) 50%,var(--border-primary) 75%);background-size:200% 100%;animation:line-grid-shimmer 1.2s ease-in-out infinite}@keyframes line-grid-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.line-grid__empty-container,.line-grid__error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px 16px;text-align:center}.line-grid__empty-message{margin:0;font-size:14px;color:var(--text-muted);font-style:italic}.line-grid__error-icon{font-size:24px}.line-grid__error-message{margin:0;font-size:14px;color:var(--status-error-text)}.line-grid__retry-btn{padding:6px 14px;font-size:13px;font-weight:500;color:var(--text-primary);background-color:transparent;border:1px solid var(--border-primary);border-radius:6px;cursor:pointer;transition:background-color .15s}.line-grid__retry-btn:hover{background-color:var(--accent-subtle)}.summary-bar{display:flex;align-items:center;background-color:var(--table-header-bg);border-top:2px solid var(--border-primary);border-radius:0 0 8px 8px;padding:12px;gap:12px}.summary-bar__label{font-size:14px;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;min-width:160px}.summary-bar__spacer{flex:1}.summary-bar__metric{display:flex;flex-direction:column;align-items:flex-end;min-width:80px;padding:0 12px}.summary-bar__metric-label{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px;margin-bottom:2px}.summary-bar__metric-value{font-size:15px;font-weight:700;color:var(--text-primary)}.dashboard{display:flex;flex-direction:column;min-height:100vh;background-color:var(--bg-secondary);color:var(--text-primary)}.dashboard__prompt{display:flex;align-items:center;justify-content:center;flex:1;padding:64px 16px}.dashboard__prompt-text{margin:0;font-size:15px;color:var(--text-muted);font-style:italic;text-align:center}.dashboard__load-more-sentinel{min-height:1px;padding:0 16px}.dashboard__loading-more{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px;font-size:13px;color:var(--text-secondary)}.dashboard__loading-more-spinner{width:16px;height:16px;border:2px solid var(--border-primary);border-top-color:var(--accent-primary);border-radius:50%;animation:dashboard-load-more-spin .6s linear infinite}@keyframes dashboard-load-more-spin{to{transform:rotate(360deg)}}.dashboard__loading-preferences{display:flex;align-items:center;justify-content:center;gap:8px;padding:64px 16px;font-size:14px;color:var(--text-secondary)}.admin-portal{display:flex;flex-direction:column;height:100vh;background:var(--bg-secondary)}.admin-header{display:flex;align-items:center;gap:16px;padding:16px 24px;background:var(--bg-primary);border-bottom:1px solid var(--border-primary)}.admin-header__title{margin:0;font-size:22px;font-weight:700;color:var(--text-primary)}.admin-tabs{display:flex;gap:0;padding:0 24px;background:var(--bg-primary);border-bottom:1px solid var(--border-primary)}.admin-tab{padding:12px 20px;border:none;background:transparent;font-size:14px;font-weight:500;color:var(--text-secondary);cursor:pointer;border-bottom:2px solid transparent;transition:all .2s ease}.admin-tab:hover{color:var(--text-primary);background:var(--bg-secondary)}.admin-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary);font-weight:600}.admin-selectors{display:flex;align-items:flex-start;gap:16px;padding:12px 24px;background:var(--bg-primary);border-bottom:1px solid var(--border-primary)}.admin-selector-group{display:flex;flex-direction:column;gap:4px;min-width:200px}.admin-selector-label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.admin-selector-wrapper{position:relative;display:flex;align-items:center}.admin-select{width:100%;padding:8px 12px;border:1px solid var(--border-primary);border-radius:6px;background:var(--input-bg);font-size:14px;color:var(--text-primary);cursor:pointer;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.admin-select:disabled{background:var(--bg-secondary);color:var(--text-muted);cursor:not-allowed}.admin-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #2196f326}.admin-selector-spinner{position:absolute;right:32px;width:14px;height:14px;border:2px solid var(--border-primary);border-top-color:var(--accent-primary);border-radius:50%;animation:admin-spin .6s linear infinite}@keyframes admin-spin{to{transform:rotate(360deg)}}.admin-selector-error{display:flex;align-items:center;gap:8px;font-size:13px;color:#e53935}.admin-retry-btn{padding:2px 10px;border:1px solid #e53935;border-radius:4px;background:var(--bg-primary);color:#e53935;font-size:12px;cursor:pointer}.admin-retry-btn:hover{background:var(--status-error-bg)}.admin-content{flex:1;overflow:auto;padding:24px}.admin-prompt{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--text-secondary);padding:60px 20px}.admin-prompt-icon{font-size:48px;margin-bottom:8px}.admin-prompt-title{margin:0;font-size:20px;font-weight:600;color:var(--text-primary)}.admin-prompt-text{margin:0;font-size:14px;color:var(--text-secondary)}.metric-order-container{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:10px;overflow:hidden}.metric-order-toolbar{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border-primary)}.metric-order-toolbar__left{display:flex;align-items:center;gap:12px}.metric-order-toolbar__title{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.metric-order-toolbar__count{font-size:13px;color:var(--text-secondary);background:var(--bg-secondary);padding:2px 8px;border-radius:12px}.metric-order-save-btn{padding:8px 20px;border:none;border-radius:6px;background:var(--accent-primary);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s ease,opacity .2s ease}.metric-order-save-btn:hover{background:var(--accent-hover)}.metric-order-save-btn:disabled{opacity:.5;cursor:not-allowed}.metric-order-save-btn.saving{opacity:.7}.metric-order-table{width:100%;border-collapse:collapse}.metric-order-table thead{background:var(--bg-secondary)}.metric-order-table th{padding:10px 16px;font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;text-align:left;border-bottom:1px solid var(--border-primary)}.metric-order-table th:first-child{width:50px;text-align:center}.metric-order-table th:nth-child(2){width:60px;text-align:center}.metric-order-table tbody tr{border-bottom:1px solid var(--border-primary);transition:background .15s ease}.metric-order-table tbody tr:last-child{border-bottom:none}.metric-order-table tbody tr:hover{background:var(--bg-secondary)}.metric-order-table tbody tr.dragging{opacity:.5;background:var(--bg-tertiary)}.metric-order-table tbody tr.drag-over{border-top:2px solid var(--accent-primary)}.metric-order-table td{padding:12px 16px;font-size:14px;color:var(--text-primary);vertical-align:middle}.metric-order-table td:first-child{text-align:center;cursor:grab;color:var(--text-muted);font-size:18px}.metric-order-table td:first-child:active{cursor:grabbing}.metric-order-table td:nth-child(2){text-align:center;font-weight:500;color:var(--text-secondary);font-size:13px}.metric-name-cell{font-weight:500;font-family:SF Mono,Fira Code,monospace;font-size:13px}.metric-alias-input{width:100%;max-width:250px;padding:6px 10px;border:1px solid var(--border-primary);border-radius:4px;background:var(--input-bg);font-size:13px;color:var(--text-primary);transition:border-color .2s ease}.metric-alias-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #2196f31a}.metric-alias-input::placeholder{color:var(--text-muted)}.metric-precision-input{width:80px;padding:6px 10px;border:1px solid var(--border-primary);border-radius:4px;background:var(--input-bg);font-size:13px;color:var(--text-primary);transition:border-color .2s ease}.metric-precision-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #2196f31a}.metric-precision-input::placeholder{color:var(--text-muted)}.metric-order-loading{display:flex;align-items:center;justify-content:center;gap:12px;padding:60px 20px;color:var(--text-secondary);font-size:14px}.metric-order-loading .admin-selector-spinner{position:static}.metric-order-empty{padding:40px 20px;text-align:center;color:var(--text-secondary);font-size:14px}.metric-order-success{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--status-active-bg, rgba(76, 175, 80, .1));border:1px solid rgba(76,175,80,.3);border-radius:6px;color:#4caf50;font-size:13px;font-weight:500;margin-bottom:16px;animation:admin-fade-in .3s ease}@keyframes admin-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.metric-order-error{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--status-error-bg, rgba(229, 57, 53, .1));border:1px solid rgba(229,57,53,.3);border-radius:6px;color:#e53935;font-size:13px;font-weight:500;margin-bottom:16px}.drag-handle{display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none}.app{min-height:100vh}:root,[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f5f7fa;--bg-tertiary: #eef1f5;--bg-elevated: #ffffff;--bg-overlay: rgba(255, 255, 255, .95);--text-primary: #1f2937;--text-secondary: #6b7280;--text-muted: #9ca3af;--text-inverse: #ffffff;--border-primary: #e5e7eb;--border-secondary: #f3f4f6;--border-focus: #2196f3;--accent-primary: #2196f3;--accent-hover: #1976d2;--accent-subtle: rgba(33, 150, 243, .08);--accent-muted: rgba(33, 150, 243, .15);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--input-bg: #ffffff;--input-border: #e5e7eb;--table-header-bg: #f8f9fb;--table-row-hover: #f5f7fa;--scrollbar-thumb: #c1c1c1;--scrollbar-track: transparent;--status-error-bg: #fef2f2;--status-error-border: #fecaca;--status-error-text: #b91c1c;--status-success: #10b981;--status-warning: #f59e0b}[data-theme=dark]{--bg-primary: #1a1a2e;--bg-secondary: #16213e;--bg-tertiary: #0f3460;--bg-elevated: #1e1e3a;--bg-overlay: rgba(26, 26, 46, .95);--text-primary: #e4e4e7;--text-secondary: #a1a1aa;--text-muted: #71717a;--text-inverse: #1a1a2e;--border-primary: #2e2e4a;--border-secondary: #252540;--border-focus: #60a5fa;--accent-primary: #60a5fa;--accent-hover: #93c5fd;--accent-subtle: rgba(96, 165, 250, .1);--accent-muted: rgba(96, 165, 250, .2);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -1px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5), 0 4px 6px -2px rgba(0, 0, 0, .4);--input-bg: #1e1e3a;--input-border: #2e2e4a;--table-header-bg: #1e1e3a;--table-row-hover: #252540;--scrollbar-thumb: #3f3f5a;--scrollbar-track: transparent;--status-error-bg: #2d1b1b;--status-error-border: #5c2020;--status-error-text: #fca5a5;--status-success: #34d399;--status-warning: #fbbf24}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-secondary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}#root{min-height:100vh}
