.ai-summary-card{background:linear-gradient(135deg,#3b82f61a,#22d3ee0d);border:1px solid rgba(59,130,246,.3)}.ai-summary-card .card-title{display:flex;align-items:center;gap:.5rem}.ai-icon{font-size:1.25rem}.ai-summary-content{white-space:pre-wrap;line-height:1.7;color:var(--text-primary);font-size:.9375rem}.health-summary{display:flex;gap:2rem;flex-wrap:wrap}.health-item{display:flex;align-items:center;gap:.5rem}.tcp-stats,.dns-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.tcp-stat,.dns-stat{display:flex;justify-content:space-between;padding:.75rem;background:var(--bg-tertiary);border-radius:.375rem}.anomaly-client{font-size:.875rem;color:var(--text-secondary);margin-top:.25rem}.connections-table-wrapper{overflow-x:auto}.connections-table{width:100%;border-collapse:collapse;font-size:.875rem}.connections-table th{text-align:left;padding:.75rem .5rem;background:var(--bg-tertiary);color:var(--text-secondary);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600;border-bottom:1px solid var(--border)}.connections-table td{padding:.625rem .5rem;border-bottom:1px solid var(--border);color:var(--text-primary)}.connections-table tr:hover{background:#3b82f60d}.ip-cell{font-family:SF Mono,Consolas,monospace;font-size:.8125rem;color:var(--accent)}.port-cell{font-family:SF Mono,Consolas,monospace;font-weight:600}.protocol-badge{display:inline-block;padding:.25rem .5rem;border-radius:.25rem;font-size:.6875rem;font-weight:600;text-transform:uppercase}.protocol-badge.https{background:#10b98133;color:var(--success)}.protocol-badge.http{background:#f59e0b33;color:var(--warning)}.protocol-badge.http\(s\){background:#3b82f633;color:var(--accent)}.protocol-badge.tcp{background:#94a3b833;color:var(--text-secondary)}.protocol-badge.udp{background:#a855f733;color:#a855f7}.protocol-badge.dns{background:#22d3ee33;color:#22d3ee}.protocol-badge.ssh{background:#ef444433;color:var(--danger)}.protocol-badge.ftp,.protocol-badge.telnet{background:#ef44444d;color:var(--danger)}.protocol-badge.smtp,.protocol-badge.pop3,.protocol-badge.imap{background:#fb923c33;color:#fb923c}.protocol-badge.rdp{background:#3b82f633;color:var(--accent)}.more-items{text-align:center;padding:.75rem;color:var(--text-secondary);font-size:.875rem;border-top:1px dashed var(--border)}.show-more-btn{width:100%;padding:.75rem 1rem;margin-top:.5rem;background:linear-gradient(135deg,#3b82f61a,#22d3ee1a);border:1px dashed var(--border);border-radius:.375rem;color:var(--accent);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.show-more-btn:hover{background:linear-gradient(135deg,#3b82f633,#22d3ee33);border-color:var(--accent)}.client-list-controls{margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center}.filter-group{display:flex;align-items:center}.table-container{overflow-x:auto}.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.sortable:hover{background:var(--bg-tertiary)}.timeline-view{height:100%;display:flex;flex-direction:column}.timeline-controls{margin-bottom:1rem;display:flex;gap:2rem;align-items:center}.timeline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.timeline-category{font-size:.75rem;text-transform:uppercase;font-weight:600;letter-spacing:.05em}.timeline-details{margin-top:.5rem;padding:.5rem;background:var(--bg-primary);border-radius:.25rem;font-family:monospace;font-size:.75rem;color:var(--text-secondary);white-space:pre-wrap;max-height:200px;overflow-y:auto}.roaming-view{display:flex;flex-direction:column;gap:1.5rem}.roaming-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.roaming-stat-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:.75rem;padding:1.25rem;text-align:center;transition:all .2s}.roaming-stat-card:hover{border-color:var(--accent);transform:translateY(-2px)}.roaming-stat-card.roam{background:linear-gradient(135deg,#10b9811a,#10b9810d);border-color:#10b9814d}.roaming-stat-card.stay{background:linear-gradient(135deg,#3b82f61a,#3b82f60d);border-color:#3b82f64d}.roaming-stat-icon{font-size:1.75rem;margin-bottom:.5rem}.roaming-stat-value{font-size:2rem;font-weight:700;color:var(--text-primary);line-height:1}.roaming-stat-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-top:.5rem}.roaming-filters{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;padding:1rem;background:var(--bg-secondary);border-radius:.5rem;border:1px solid var(--border)}.roaming-filters .filter-group{display:flex;align-items:center;gap:.5rem}.roaming-filters label{font-size:.875rem;color:var(--text-secondary)}.roaming-filters select{padding:.5rem .75rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:.375rem;color:var(--text-primary);font-size:.875rem;min-width:200px}.filter-toggles{display:flex;gap:.75rem;margin-left:auto}.filter-toggles .toggle{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:.375rem;cursor:pointer;transition:all .2s;font-size:.8125rem}.filter-toggles .toggle input{display:none}.filter-toggles .toggle.active{background:#f59e0b33;border-color:var(--warning);color:var(--warning)}.filter-toggles .toggle.active.roam{background:#10b98133;border-color:var(--success);color:var(--success)}.filter-toggles .toggle.active.stay{background:#3b82f633;border-color:var(--accent);color:var(--accent)}.client-roaming-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.client-roaming-card{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:.5rem;padding:1rem;cursor:pointer;transition:all .2s}.client-roaming-card:hover{border-color:var(--accent)}.client-roaming-card.selected{border-color:var(--accent);background:#3b82f61a}.client-mac{font-family:SF Mono,Consolas,monospace;font-size:.875rem;font-weight:600;color:var(--accent);margin-bottom:.375rem}.client-bssid{font-size:.75rem;color:var(--text-secondary);margin-bottom:.5rem}.client-roaming-stats{display:flex;gap:1rem}.client-roaming-stats .stat{font-size:.75rem;color:var(--text-secondary)}.client-roaming-stats .stat-num{font-weight:600;color:var(--text-primary)}.event-count{font-size:.875rem;font-weight:400;color:var(--text-secondary);margin-left:.5rem}.roaming-timeline{display:flex;flex-direction:column;gap:.75rem}.roaming-event{background:var(--bg-tertiary);border-left:4px solid;border-radius:.375rem;padding:1rem}.roaming-event.probe{border-left-color:var(--warning)}.roaming-event.roam{border-left-color:var(--success);background:linear-gradient(135deg,rgba(16,185,129,.05),transparent)}.roaming-event.stay{border-left-color:var(--accent)}.event-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.event-icon{font-size:1rem}.event-type{font-size:.6875rem;font-weight:700;padding:.125rem .5rem;border-radius:.25rem;background:#ffffff1a}.roaming-event.probe .event-type{background:#f59e0b33;color:var(--warning)}.roaming-event.roam .event-type{background:#10b98133;color:var(--success)}.roaming-event.stay .event-type{background:#3b82f633;color:var(--accent)}.event-time{font-size:.75rem;color:var(--text-secondary);margin-left:auto}.event-client{font-size:.8125rem;color:var(--text-secondary);font-family:SF Mono,Consolas,monospace;margin-bottom:.5rem}.event-details{font-size:.875rem;color:var(--text-primary);display:flex;flex-direction:column;gap:.25rem}.event-details .signal.weak{color:var(--warning)}.roam-transition{display:flex;align-items:center;gap:1rem;padding:.75rem;background:var(--bg-secondary);border-radius:.375rem;margin:.5rem 0}.from-ap,.to-ap{display:flex;flex-direction:column;gap:.125rem}.from-ap .label,.to-ap .label{font-size:.6875rem;color:var(--text-secondary);text-transform:uppercase}.from-ap .bssid,.to-ap .bssid{font-family:SF Mono,Consolas,monospace;font-size:.8125rem;color:var(--text-primary)}.from-ap .ssid,.to-ap .ssid{font-size:.75rem;color:var(--accent)}.arrow{font-size:1.5rem;color:var(--success);font-weight:700}.roam-metrics{display:flex;align-items:center;gap:1rem;font-size:.8125rem;color:var(--text-secondary);padding:.5rem 0}.roam-metrics strong{color:var(--text-primary)}.roam-metrics strong.weak{color:var(--danger)}.roam-metrics strong.good{color:var(--success)}.roam-metrics .signal-arrow{color:var(--success);font-weight:700;font-size:1rem}.roam-metrics .old-signal{padding:.25rem .5rem;background:#ef44441a;border-radius:.25rem}.roam-metrics .new-signal{padding:.25rem .5rem;background:#10b9811a;border-radius:.25rem}.roam-metrics .roam-time{margin-left:auto;padding:.25rem .5rem;background:var(--bg-secondary);border-radius:.25rem}.more-events{text-align:center;padding:1rem;color:var(--text-secondary);font-size:.875rem;border-top:1px dashed var(--border)}.graphs-tab{padding:20px;overflow-y:auto;height:100%}.graphs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(480px,1fr));gap:20px}.graph-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;padding:20px}.graph-card h3{margin:0 0 15px;color:var(--text-primary);font-size:16px;font-weight:600}.graph-card h4{margin:15px 0 10px;color:var(--text-primary);font-size:14px;font-weight:500}.client-selector{margin-bottom:15px}.client-selector>span,.client-selector>label{display:block;color:var(--text-secondary);font-size:12px;margin-bottom:8px}.client-selector select{padding:6px 10px;background:var(--bg-primary);border:1px solid var(--border);color:var(--text-primary);border-radius:4px;font-size:13px}.client-chips{display:flex;flex-wrap:wrap;gap:8px}.chip{padding:4px 12px;border-radius:16px;border:2px solid var(--border);background:var(--bg-primary);color:var(--text-primary);cursor:pointer;font-size:11px;transition:all .2s;font-family:JetBrains Mono,monospace}.chip:hover{border-color:var(--accent);background:var(--bg-tertiary)}.chip.selected{background:var(--accent);color:var(--bg-primary);border-color:var(--accent)}.signal-legend,.congestion-legend{display:flex;flex-wrap:wrap;gap:15px;margin-top:15px;font-size:11px;padding-top:10px;border-top:1px solid var(--border)}.legend-item{display:flex;align-items:center;gap:4px}.legend-item.excellent{color:#4ecdc4}.legend-item.good{color:#95e1d3}.legend-item.fair{color:#ffe66d}.legend-item.poor{color:#ff6b6b}.legend-item.low{color:#4ecdc4}.legend-item.medium{color:#ffe66d}.legend-item.high{color:#ff6b6b}.no-data{padding:40px 20px;text-align:center;color:var(--text-secondary);font-style:italic;font-size:13px}.no-data.small{padding:20px}.no-roaming-note{text-align:center;color:var(--text-secondary);font-size:12px;margin-top:15px;font-style:italic}.custom-tooltip{background:var(--bg-secondary);border:1px solid var(--border);padding:10px 14px;border-radius:6px;box-shadow:0 4px 12px #0000004d}.custom-tooltip p{margin:3px 0;color:var(--text-primary);font-size:12px}.custom-tooltip .label{font-weight:600;margin-bottom:6px}.band-section{margin-bottom:20px}.band-section:last-child{margin-bottom:0}.roaming-svg{display:block;margin:10px auto}.roaming-stats{margin-top:15px;padding-top:15px;border-top:1px solid var(--border)}.roaming-stats h4{margin:0 0 10px;font-size:13px}.roaming-table-wrapper{max-height:150px;overflow-y:auto}.roaming-stats table{width:100%;border-collapse:collapse;font-size:12px}.roaming-stats th{text-align:left;padding:6px 8px;background:var(--bg-primary);color:var(--text-secondary);font-weight:500;position:sticky;top:0}.roaming-stats td{padding:6px 8px;border-bottom:1px solid var(--border);font-family:JetBrains Mono,monospace}.roaming-stats .improved{color:#4ecdc4}.roaming-stats .degraded{color:#ff6b6b}.controls{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:15px}.unit-selector{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-secondary)}.unit-selector select{padding:4px 8px;background:var(--bg-primary);border:1px solid var(--border);color:var(--text-primary);border-radius:4px;font-size:12px}.stats-row{display:flex;gap:15px;flex-wrap:wrap}.stats-row .stat{color:var(--text-secondary);font-size:12px}.stats-row .stat strong{color:var(--accent)}.recommendation{margin-top:10px;padding:10px 12px;background:var(--bg-primary);border-radius:4px;font-size:12px;color:var(--text-secondary)}.recommendation strong{color:var(--text-primary)}.recommendation .warning{color:#ffe66d}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:var(--border)}.recharts-legend-item-text{color:var(--text-primary)!important;font-size:12px}.recharts-brush-slide{fill:var(--bg-secondary);fill-opacity:.8}.recharts-brush-traveller rect{fill:var(--accent)}@media(max-width:1200px){.graphs-grid{grid-template-columns:1fr}}.analysis-tab{padding:20px}.analysis-nav{display:flex;gap:10px;margin-bottom:20px;border-bottom:1px solid var(--border);padding-bottom:10px}.analysis-nav button{padding:10px 20px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);cursor:pointer;transition:all .2s}.analysis-nav button:hover{background:var(--bg-primary)}.analysis-nav button.active{background:var(--accent);border-color:var(--accent);color:var(--bg-primary)}.analysis-content{min-height:400px}.summary-cards{display:flex;gap:15px;margin-bottom:20px;flex-wrap:wrap}.summary-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;padding:15px 20px;min-width:120px;flex:1}.summary-card .card-value{font-size:24px;font-weight:700;color:var(--text-primary)}.summary-card .card-label{font-size:12px;color:var(--text-secondary);margin-top:5px}.root-causes,.alerts-section,.anomalies-section{margin-bottom:20px}.cause-card,.alert-card,.anomaly-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;padding:15px;margin-bottom:10px}.alert-card.critical{border-color:#ff6b6b;background:#ff6b6b1a}.alert-card.high{border-color:#ff9f43;background:#ff9f431a}.severity-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:700;margin-right:8px}.severity-badge.critical{background:#ff6b6b;color:#fff}.severity-badge.high{background:#ff9f43;color:#fff}.severity-badge.medium{background:#ffd93d;color:#000}.cause-recommendation,.alert-recommendation,.anomaly-recommendation{margin-top:10px;padding-top:10px;border-top:1px solid var(--border);font-size:13px;color:var(--text-secondary)}.analysis-table{width:100%;border-collapse:collapse;margin-top:10px}.analysis-table th,.analysis-table td{padding:10px;text-align:left;border-bottom:1px solid var(--border)}.analysis-table th{background:var(--bg-primary);font-weight:600}.attack-alert{display:flex;align-items:center;gap:15px;padding:15px 20px;border-radius:8px;margin-bottom:20px}.attack-alert.critical{background:#ff6b6b33;border:2px solid #ff6b6b}.attack-alert .alert-icon{font-size:32px}.deep-dive-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:15px}.stats-panel{background:var(--bg-primary);padding:15px;border-radius:8px}.stat-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border)}.client-cause{margin-top:15px;padding:10px;background:var(--bg-secondary);border-radius:6px}.tabs{display:flex;gap:5px;margin-bottom:15px}.tabs button{padding:8px 16px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:4px;color:var(--text-secondary);cursor:pointer}.tabs button.active{background:var(--accent);color:var(--bg-primary);border-color:var(--accent)}.legend{display:flex;gap:20px;margin-top:15px;font-size:12px}.failure-badge{display:inline-block;padding:2px 6px;margin:2px;border-radius:3px;font-size:11px;background:var(--bg-primary);border:1px solid var(--border)}.empty-state{text-align:center;padding:40px;color:var(--text-secondary)}.potential-issue{padding:1rem;height:100%;overflow:auto}.potential-issue-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.potential-issue-controls{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem;color:var(--text-secondary);font-size:.9rem}.potential-issue-controls label{display:flex;align-items:center}.potential-issue-title{font-size:1rem;font-weight:600}.potential-issue-empty{color:var(--text-secondary);padding:1rem;border:1px dashed var(--border);border-radius:.5rem}.potential-issue-meta{margin-bottom:.75rem;color:var(--text-secondary);font-size:.85rem}.potential-issue-output{white-space:pre-wrap;word-break:break-word;background:#ffffff0a;border:1px solid var(--border);border-radius:.5rem;padding:1rem;line-height:1.5;font-size:.95rem;overflow:auto}.form-help{font-size:.75rem;color:var(--text-secondary);margin-top:.25rem}.form-help a{color:var(--accent);text-decoration:none}.form-help a:hover{text-decoration:underline}.about-content{color:var(--text-secondary);line-height:1.6}.about-content p{margin-bottom:.5rem}.settings-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.settings-modal{background:var(--bg-secondary);border-radius:.5rem;width:90%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 25px -5px #0000004d}.settings-header{padding:1.5rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.settings-header h2{margin:0;font-size:1.25rem;color:var(--text-primary)}.close-btn{background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:all .2s}.close-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.settings-content{padding:1.5rem;overflow-y:auto;flex:1}.setting-group{margin-bottom:1.5rem}.setting-group label{display:block;margin-bottom:.5rem;color:var(--text-primary);font-weight:500}.setting-group .hint{display:block;margin-top:.25rem;font-size:.75rem;color:var(--text-secondary)}.test-result{padding:.75rem;border-radius:.375rem;margin-top:1rem;margin-bottom:1rem}.test-result.success{background:#10b9811a;border:1px solid var(--success);color:var(--success)}.test-result.error{background:#ef44441a;border:1px solid var(--danger);color:var(--danger)}.settings-footer{padding:1.5rem;border-top:1px solid var(--border);display:flex;gap:.75rem;justify-content:flex-end}.chat-panel{display:flex;flex-direction:column;height:100%;background:var(--bg-secondary);border-radius:.75rem;overflow:hidden;border:1px solid var(--border)}.chat-header{display:flex;align-items:center;gap:.75rem;padding:1rem;background:linear-gradient(135deg,#3b82f61a,#22d3ee1a);border-bottom:1px solid var(--border)}.chat-header-icon{font-size:1.5rem}.chat-header-text{flex:1}.chat-header-title{font-weight:600;color:var(--text-primary)}.chat-header-subtitle{font-size:.75rem;color:var(--text-secondary);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.clear-chat-btn{padding:.5rem;background:transparent;border:1px solid var(--border);border-radius:.5rem;cursor:pointer;font-size:.875rem;transition:all .2s;opacity:.6}.clear-chat-btn:hover{opacity:1;background:#ef444433;border-color:#ef4444}.chat-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.chat-welcome{text-align:center;color:var(--text-secondary);padding:1.5rem 1rem;display:flex;flex-direction:column;align-items:center}.welcome-icon{font-size:3rem;margin-bottom:1rem;animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.chat-welcome h3{color:var(--text-primary);margin:0 0 .5rem;font-size:1.25rem}.chat-welcome p{margin-bottom:1.5rem;font-size:.875rem;max-width:280px;line-height:1.5}.suggestions-label{font-size:.75rem;color:var(--text-secondary);margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.05em}.suggestions{display:flex;flex-direction:column;gap:.5rem;width:100%}.suggestion-btn{padding:.625rem .875rem;font-size:.8rem;background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-primary);border-radius:.5rem;cursor:pointer;text-align:left;transition:all .2s}.suggestion-btn:hover:not(:disabled){background:var(--accent);border-color:var(--accent);color:#fff;transform:translate(4px)}.suggestion-btn:disabled{opacity:.5;cursor:not-allowed}.chat-message{display:flex;gap:.5rem;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-message.user{flex-direction:row-reverse}.message-icon{width:28px;height:28px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:.875rem;flex-shrink:0}.chat-message.user .message-icon{background:var(--accent)}.message-content{max-width:85%;padding:.75rem 1rem;border-radius:1rem;font-size:.875rem;line-height:1.5;white-space:pre-wrap;word-break:break-word}.chat-message.user .message-content{background:var(--accent);color:#fff;border-bottom-right-radius:.25rem}.chat-message.assistant .message-content{background:var(--bg-tertiary);color:var(--text-primary);border-bottom-left-radius:.25rem}.chat-message.error .message-content{background:#ef444433;color:#fca5a5}.typing-indicator{display:flex;gap:4px;align-items:center;padding:4px 0}.typing-indicator span{width:6px;height:6px;border-radius:50%;background:var(--text-secondary);animation:bounce 1.4s infinite ease-in-out}.typing-indicator span:nth-child(1){animation-delay:-.32s}.typing-indicator span:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.chat-input-area{display:flex;gap:.5rem;padding:1rem;border-top:1px solid var(--border);background:var(--bg-primary)}.chat-input{flex:1;padding:.75rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:.5rem;color:var(--text-primary);font-size:.875rem}.chat-input::placeholder{color:var(--text-secondary)}.send-btn{padding:.75rem 1rem;background:linear-gradient(135deg,#3b82f6,#22d3ee);border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-size:1rem;transition:all .2s}.send-btn:hover:not(:disabled){transform:scale(1.05)}.send-btn:disabled{opacity:.5;cursor:not-allowed}.login-page{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(1000px 500px at 20% 0%,rgba(59,130,246,.25),transparent 60%),radial-gradient(1000px 500px at 80% 100%,rgba(16,185,129,.18),transparent 60%),var(--bg-primary);padding:1rem}.login-card{width:420px;max-width:95vw;background:#1e293be6;border:1px solid var(--border);border-radius:.75rem;padding:1.25rem;box-shadow:0 20px 80px #0006}.login-title{font-size:1.25rem;font-weight:700}.login-subtitle{margin-top:.25rem;color:var(--text-secondary);font-size:.95rem;margin-bottom:1rem}.login-label{display:block;margin-top:.5rem;margin-bottom:.25rem;color:var(--text-secondary);font-size:.85rem}.login-btn{width:100%;margin-top:1rem}.login-hint{margin-top:.75rem;font-size:.8rem;color:var(--text-secondary)}:root{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--text-primary: #f8fafc;--text-secondary: #94a3b8;--border: #475569;--accent: #3b82f6;--success: #10b981;--warning: #f59e0b;--danger: #ef4444}*{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:var(--bg-primary);color:var(--text-primary);overflow:hidden}#root{width:100vw;height:100vh}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-header{background:var(--bg-secondary);border-bottom:1px solid var(--border);padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between}.app-title{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.app-actions{display:flex;gap:.75rem}.btn{padding:.5rem 1rem;border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-primary);border-radius:.375rem;cursor:pointer;font-size:.875rem;transition:all .2s}.btn:hover{background:var(--bg-secondary);border-color:var(--accent)}.btn-primary{background:var(--accent);border-color:var(--accent)}.btn-primary:hover{background:#2563eb}.btn:disabled,.btn-primary:disabled{opacity:.5;cursor:not-allowed;background:var(--bg-tertiary);border-color:var(--border)}.btn-primary:disabled{background:var(--bg-tertiary);border-color:var(--border)}.btn-primary:disabled:hover{background:var(--bg-tertiary);border-color:var(--border)}.btn-danger{background:var(--danger);border-color:var(--danger)}.btn-danger:hover{background:#dc2626}.tabs{display:flex;background:var(--bg-secondary);border-bottom:1px solid var(--border);padding:0 1rem;gap:.5rem}.tab{padding:.75rem 1.25rem;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);cursor:pointer;font-size:.875rem;transition:all .2s}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.main-content{flex:1;display:flex;overflow:hidden}.content-area{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.content{flex:1;overflow:auto;padding:1.5rem}.chat-sidebar{width:400px;min-width:320px;max-width:450px;border-left:1px solid var(--border);padding:1rem;background:var(--bg-primary);overflow:hidden;display:flex;flex-direction:column}.tab.chat-toggle{margin-left:auto;background:var(--bg-tertiary);border-radius:.375rem .375rem 0 0;border:1px solid var(--border);border-bottom:none}.tab.chat-toggle.active{background:var(--accent);color:#fff;border-color:var(--accent)}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-secondary);gap:1.5rem;position:fixed;inset:0;background:var(--bg-primary);z-index:2000}.loading-spinner{width:48px;height:48px;border:4px solid var(--bg-secondary);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.progress-container{width:400px;max-width:90%;display:flex;flex-direction:column;gap:.5rem}.progress-bar-wrapper{width:100%;height:8px;background-color:var(--bg-secondary);border-radius:4px;overflow:hidden;position:relative}.progress-bar{height:100%;background:linear-gradient(90deg,var(--accent),#60a5fa);border-radius:4px;transition:width .3s ease;position:relative;overflow:hidden}.progress-bar:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 1.5s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.progress-text{font-size:.875rem;color:var(--text-secondary);text-align:center}.error{background:#ef44441a;border:1px solid var(--danger);color:var(--danger);padding:1rem;border-radius:.375rem;margin-bottom:1rem}.success{background:#10b9811a;border:1px solid var(--success);color:var(--success);padding:1rem;border-radius:.375rem;margin-bottom:1rem}.card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:.5rem;padding:1.5rem;margin-bottom:1rem}.card-title{font-size:1.125rem;font-weight:600;margin-bottom:1rem;color:var(--text-primary)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:.5rem;padding:1rem}.stat-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.stat-value{font-size:1.5rem;font-weight:600;color:var(--text-primary)}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--border)}.table th{background:var(--bg-tertiary);color:var(--text-secondary);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.table td{color:var(--text-primary)}.table tr:hover{background:var(--bg-tertiary)}.badge{display:inline-block;padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:600}.badge-success{background:#10b98133;color:var(--success)}.badge-warning{background:#f59e0b33;color:var(--warning)}.badge-danger{background:#ef444433;color:var(--danger)}.badge-info{background:#3b82f633;color:var(--accent)}.health-score{display:inline-flex;align-items:center;gap:.5rem}.health-bar{width:60px;height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden}.health-bar-fill{height:100%;transition:width .3s}.health-bar-fill.good{background:var(--success)}.health-bar-fill.warning{background:var(--warning)}.health-bar-fill.critical{background:var(--danger)}.anomaly-list{list-style:none}.anomaly-item{padding:1rem;border-left:3px solid;margin-bottom:.75rem;background:var(--bg-tertiary);border-radius:.375rem}.anomaly-item.info{border-color:var(--accent)}.anomaly-item.warning{border-color:var(--warning)}.anomaly-item.critical{border-color:var(--danger)}.anomaly-title{font-weight:600;margin-bottom:.25rem}.anomaly-description{color:var(--text-secondary);font-size:.875rem;margin-bottom:.5rem}.anomaly-suggestion{color:var(--text-secondary);font-size:.75rem;font-style:italic}.timeline{position:relative;padding-left:2rem}.timeline:before{content:"";position:absolute;left:.5rem;top:0;bottom:0;width:2px;background:var(--border)}.timeline-event{position:relative;padding:.75rem;margin-bottom:1rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:.375rem}.timeline-event:before{content:"";position:absolute;left:-1.75rem;top:1rem;width:.75rem;height:.75rem;border-radius:50%;background:var(--accent);border:2px solid var(--bg-primary)}.timeline-event.important:before{background:var(--warning)}.timeline-time{font-size:.75rem;color:var(--text-secondary);margin-bottom:.25rem}.timeline-type{font-weight:600;margin-bottom:.25rem}.timeline-client{font-size:.875rem;color:var(--text-secondary)}.chat-container{display:flex;flex-direction:column;height:100%}.chat-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:1rem}.chat-message{padding:1rem;border-radius:.5rem;max-width:80%}.chat-message.user{align-self:flex-end;background:var(--accent);color:#fff}.chat-message.assistant{align-self:flex-start;background:var(--bg-secondary);border:1px solid var(--border)}.chat-input-container{padding:1rem;border-top:1px solid var(--border);display:flex;gap:.75rem}.chat-input{flex:1;padding:.75rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:.375rem;color:var(--text-primary);font-size:.875rem}.chat-input:focus{outline:none;border-color:var(--accent)}.form-group{margin-bottom:1rem}.form-label{display:block;margin-bottom:.5rem;color:var(--text-secondary);font-size:.875rem}.form-input,.form-select{width:100%;padding:.75rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:.375rem;color:var(--text-primary);font-size:.875rem}.form-input:focus,.form-select:focus{outline:none;border-color:var(--accent)}.empty-state{text-align:center;padding:3rem;color:var(--text-secondary)}.empty-state-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border)}
