*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-main: #0d1117;--bg-card: #161b22;--bg-sidebar: #0d1117;--bg-elevated: #1c2128;--bg-hover: #21262d;--border: #30363d;--border-subtle: #21262d;--text-primary: #e6edf3;--text-secondary: #8b949e;--text-muted: #484f58;--accent-blue: #58a6ff;--accent-cyan: #79c0ff;--accent-green: #3fb950;--accent-red: #f85149;--accent-amber: #d29922;--accent-purple: #bc8cff;--accent-orange: #ffa657;--status-healthy: #3fb950;--status-degraded: #d29922;--status-down: #f85149;--sidebar-width: 220px;--header-height: 64px;--transition: all .2s ease}html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,system-ui,sans-serif;font-size:14px;background-color:var(--bg-main);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased}#root{display:flex;height:100vh;overflow:hidden}.app-layout{display:flex;width:100%;height:100vh;overflow:hidden}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;margin-left:var(--sidebar-width)}.page-content{flex:1;overflow-y:auto;padding:24px 32px;background:var(--bg-main)}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--bg-sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;height:100vh;position:fixed;left:0;top:0;z-index:100}.sidebar-logo{padding:20px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}.sidebar-logo-icon{width:32px;height:32px;background:linear-gradient(135deg,#58a6ff,#79c0ff);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:#0d1117;flex-shrink:0}.sidebar-logo-text{font-size:13px;font-weight:600;color:var(--text-primary);line-height:1.3}.sidebar-logo-sub{font-size:10px;color:var(--text-secondary);font-weight:400}.sidebar-nav{flex:1;padding:12px 0;overflow-y:auto}.nav-section-label{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:8px 16px 4px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 16px;color:var(--text-secondary);text-decoration:none;font-size:13.5px;font-weight:500;border-radius:0;transition:var(--transition);cursor:pointer;border:none;background:none;width:100%;text-align:left;border-left:3px solid transparent}.nav-item:hover{color:var(--text-primary);background:var(--bg-hover)}.nav-item.active{color:var(--accent-blue);background:#58a6ff14;border-left-color:var(--accent-blue)}.nav-item-icon{font-size:16px;width:20px;text-align:center;flex-shrink:0}.sidebar-footer{padding:16px;border-top:1px solid var(--border)}.sidebar-status{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-secondary)}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--status-healthy);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:20px}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-title{font-size:14px;font-weight:600;color:var(--text-primary)}.card-subtitle{font-size:12px;color:var(--text-secondary);margin-top:2px}.stats-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;margin-bottom:24px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:18px 20px;display:flex;flex-direction:column;gap:6px;transition:var(--transition)}.stat-card:hover{border-color:var(--accent-blue);background:var(--bg-elevated)}.stat-label{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.stat-value{font-size:26px;font-weight:700;color:var(--text-primary);line-height:1.1}.stat-unit{font-size:13px;font-weight:400;color:var(--text-secondary)}.stat-trend{font-size:11px;color:var(--text-secondary);display:flex;align-items:center;gap:4px}.stat-trend.up{color:var(--accent-green)}.stat-trend.down{color:var(--accent-red)}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.badge-healthy,.badge-green{background:#3fb95026;color:var(--accent-green);border:1px solid rgba(63,185,80,.3)}.badge-degraded,.badge-amber{background:#d2992226;color:var(--accent-amber);border:1px solid rgba(210,153,34,.3)}.badge-down,.badge-red{background:#f8514926;color:var(--accent-red);border:1px solid rgba(248,81,73,.3)}.badge-info,.badge-blue{background:#58a6ff1f;color:var(--accent-blue);border:1px solid rgba(88,166,255,.25)}.badge-connected{background:#3fb95026;color:var(--accent-green);border:1px solid rgba(63,185,80,.3);padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600}.badge-active-count{background:#f8514926;color:var(--accent-red);border:1px solid rgba(248,81,73,.3);padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600}.status-indicator{display:inline-flex;align-items:center;gap:6px;font-size:12px}.status-dot-sm{width:7px;height:7px;border-radius:50%;flex-shrink:0}.status-dot-sm.healthy{background:var(--status-healthy)}.status-dot-sm.degraded{background:var(--status-degraded)}.status-dot-sm.down{background:var(--status-down)}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:var(--transition);border:none;text-decoration:none}.btn-primary{background:var(--accent-blue);color:#0d1117;font-weight:600}.btn-primary:hover{background:#79c0ff}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--accent-blue)}.btn-danger{background:#f8514926;color:var(--accent-red);border:1px solid rgba(248,81,73,.3)}.btn-danger:hover{background:#f8514940}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-sm{padding:4px 10px;font-size:12px}.btn-reset{background:linear-gradient(135deg,#21262d,#30363d);color:var(--text-primary);border:1px solid var(--border);padding:7px 16px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:var(--transition)}.btn-reset:hover{background:linear-gradient(135deg,#30363d,#3d444d);border-color:var(--accent-amber);color:var(--accent-amber)}.table-container{overflow-x:auto;border-radius:10px;border:1px solid var(--border)}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th{background:var(--bg-elevated);color:var(--text-secondary);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;padding:10px 14px;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap}.data-table td{padding:11px 14px;color:var(--text-primary);border-bottom:1px solid var(--border-subtle);vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr{transition:background .15s}.data-table tbody tr:hover{background:var(--bg-hover);cursor:pointer}.data-table tbody tr.selected{background:#58a6ff0f}.form-control{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-primary);padding:7px 12px;border-radius:6px;font-size:13px;font-family:inherit;transition:var(--transition);outline:none}.form-control:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px #58a6ff1f}.form-control::placeholder{color:var(--text-muted)}select.form-control{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238b949e' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px}.input-group{display:flex;align-items:center;gap:8px}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-input-wrapper .search-icon{position:absolute;left:10px;color:var(--text-muted);font-size:13px;pointer-events:none}.search-input-wrapper input{padding-left:32px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}.page-header-left{display:flex;flex-direction:column;gap:2px}.page-title{font-size:22px;font-weight:700;color:var(--text-primary);line-height:1.2}.page-subtitle{font-size:13px;color:var(--text-secondary)}.page-header-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.dashboard-header{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:16px 24px;display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.dashboard-header-left{display:flex;align-items:center;gap:16px}.sdwan-logo{display:flex;align-items:center;gap:12px}.sdwan-logo-icon{width:40px;height:40px;background:linear-gradient(135deg,#58a6ff,#79c0ff);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:800;color:#0d1117}.sdwan-logo-text{font-size:15px;font-weight:700;color:var(--text-primary)}.sdwan-logo-sub{font-size:11px;color:var(--text-secondary)}.site-info{display:flex;flex-direction:column;gap:2px;padding-left:16px;border-left:1px solid var(--border)}.site-name{font-size:13px;font-weight:600;color:var(--text-primary)}.site-label{font-size:11px;color:var(--text-secondary)}.dashboard-header-right{display:flex;align-items:center;gap:14px}.avatar{width:34px;height:34px;background:linear-gradient(135deg,#3fb950,#79c0ff);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#0d1117;cursor:pointer}.link-cards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.link-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:18px 20px;transition:var(--transition);cursor:default}.link-card:hover{border-color:var(--accent-blue);background:var(--bg-elevated)}.link-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px}.link-card-name{font-size:13px;font-weight:600;color:var(--text-primary)}.link-card-type{font-size:11px;color:var(--text-secondary);margin-top:2px}.link-card-metrics{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}.link-metric{display:flex;flex-direction:column;gap:2px}.link-metric-label{font-size:10px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.link-metric-value{font-size:15px;font-weight:600;color:var(--text-primary)}.util-bar-container{margin-top:2px}.util-bar-label{display:flex;justify-content:space-between;font-size:11px;color:var(--text-secondary);margin-bottom:5px}.util-bar{height:5px;background:var(--border);border-radius:3px;overflow:hidden}.util-bar-fill{height:100%;border-radius:3px;transition:width .5s ease}.util-bar-fill.low{background:var(--accent-green)}.util-bar-fill.medium{background:var(--accent-blue)}.util-bar-fill.high{background:var(--accent-amber)}.util-bar-fill.critical{background:var(--accent-red)}.alerts-list{display:flex;flex-direction:column;gap:1px}.alert-item{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border-subtle);cursor:pointer}.alert-item:last-child{border-bottom:none}.alert-item:hover{opacity:.85}.alert-severity-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.alert-severity-dot.critical{background:var(--accent-red)}.alert-severity-dot.warning{background:var(--accent-amber)}.alert-severity-dot.info{background:var(--accent-blue)}.alert-text{flex:1;font-size:13px;color:var(--text-primary)}.alert-time{font-size:11px;color:var(--text-secondary);white-space:nowrap}.chart-section{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:20px;margin-bottom:24px}.chart-title{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:16px}.chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.topology-canvas{background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;overflow:hidden;position:relative}.topology-legend{display:flex;gap:16px;padding:12px 16px;background:var(--bg-elevated);border-top:1px solid var(--border);flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary)}.legend-dot{width:10px;height:10px;border-radius:50%}.detail-panel{background:var(--bg-card);border:1px solid var(--accent-blue);border-radius:10px;padding:20px;margin-top:20px;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.detail-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.detail-panel-title{font-size:15px;font-weight:600;color:var(--text-primary)}.detail-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:14px;margin-bottom:16px}.detail-stat{display:flex;flex-direction:column;gap:3px}.detail-stat-label{font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.detail-stat-value{font-size:18px;font-weight:600;color:var(--text-primary)}.filter-tabs{display:flex;gap:4px;background:var(--bg-elevated);padding:4px;border-radius:8px;width:fit-content;margin-bottom:20px}.filter-tab{padding:6px 14px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:var(--transition);border:none;color:var(--text-secondary);background:transparent}.filter-tab:hover{color:var(--text-primary);background:var(--bg-hover)}.filter-tab.active{background:var(--bg-card);color:var(--text-primary);box-shadow:0 1px 3px #0000004d}.settings-section{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:24px;margin-bottom:20px}.settings-section-title{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border-subtle);gap:16px}.settings-row:last-child{border-bottom:none;padding-bottom:0}.settings-row-label{display:flex;flex-direction:column;gap:2px;min-width:200px}.settings-row-label span{font-size:13px;color:var(--text-primary);font-weight:500}.settings-row-label small{font-size:11px;color:var(--text-secondary)}.settings-control{min-width:200px}.checkbox-row{display:flex;align-items:center;gap:10px;padding:10px 0}.checkbox-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent-blue);cursor:pointer}.checkbox-row label{font-size:13px;color:var(--text-primary);cursor:pointer}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;z-index:500;display:flex;align-items:center;justify-content:center;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:24px;width:520px;max-width:calc(100vw - 40px);animation:scaleIn .15s ease;max-height:85vh;overflow-y:auto}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border)}.modal-title{font-size:16px;font-weight:600;color:var(--text-primary)}.modal-close{background:none;border:none;color:var(--text-secondary);font-size:18px;cursor:pointer;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:var(--transition)}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-footer{display:flex;gap:10px;justify-content:flex-end;margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:var(--border)!important}.recharts-text{fill:var(--text-secondary)!important;font-size:11px!important}.recharts-legend-item-text{color:var(--text-secondary)!important;font-size:12px!important}.recharts-tooltip-wrapper .recharts-default-tooltip{background:var(--bg-elevated)!important;border:1px solid var(--border)!important;border-radius:6px!important;font-size:12px!important}.priority-high{color:var(--accent-red)}.priority-medium{color:var(--accent-amber)}.priority-low{color:var(--text-secondary)}.severity-critical{background:#f8514926;color:var(--accent-red);border:1px solid rgba(248,81,73,.3)}.severity-warning{background:#d2992226;color:var(--accent-amber);border:1px solid rgba(210,153,34,.3)}.severity-info{background:#58a6ff1f;color:var(--accent-blue);border:1px solid rgba(88,166,255,.25)}.divider{height:1px;background:var(--border);margin:16px 0}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-green{color:var(--accent-green)}.text-red{color:var(--accent-red)}.text-amber{color:var(--accent-amber)}.text-blue{color:var(--accent-blue)}.mb-4{margin-bottom:4px}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.flex{display:flex}.flex-1{flex:1}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.view-all-link{color:var(--accent-blue);text-decoration:none;font-size:13px;font-weight:500;transition:var(--transition);cursor:pointer}.view-all-link:hover{color:var(--accent-cyan)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media (min-width: 1600px){.stats-grid{grid-template-columns:repeat(6,1fr)}.link-cards-grid{grid-template-columns:repeat(4,1fr)}.page-content{padding:28px 40px}}.topology-svg{width:100%;display:block}.topology-node{cursor:pointer}.topology-node circle{transition:r .15s ease,filter .15s ease}.topology-node:hover circle{filter:brightness(1.2)}.topology-node text{pointer-events:none;-webkit-user-select:none;user-select:none}.topology-link{cursor:pointer;stroke-width:2}.topology-link:hover{stroke-width:3;opacity:.8}.bandwidth-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.two-col-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.toast{position:fixed;bottom:24px;right:24px;background:var(--bg-elevated);border:1px solid var(--accent-green);border-radius:8px;padding:12px 18px;font-size:13px;color:var(--text-primary);display:flex;align-items:center;gap:10px;animation:slideUp .25s ease;z-index:1000;box-shadow:0 8px 24px #0006}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.toast-icon{color:var(--accent-green)}
