@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--bg: #f3f6fc;--surface: #ffffff;--surface-muted: #f8f9fb;--text: #0f172a;--muted: #64748b;--border: #e2e8f0;--primary: #2563eb;--primary-dark: #1d4ed8;--danger: #dc2626;--warning: #f59e0b;--sidebar-start: #101935;--sidebar-end: #182542;--shadow: 0 18px 50px rgba(15, 23, 42, .08)}*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);min-height:100vh}button,input,select{font-family:inherit}button{border:none;cursor:pointer;background:transparent;transition:transform .15s ease,box-shadow .15s ease,background .15s ease}input,select{width:100%;padding:.75rem .9rem;border-radius:12px;border:1px solid var(--border);background:var(--surface);font-size:.95rem;color:var(--text)}input:focus,select:focus{outline:2px solid rgba(37,99,235,.4);border-color:transparent}input[type=checkbox]{width:auto;padding:0;border:none;accent-color:var(--primary);transform:scale(1.05)}.app{min-height:100vh;background:var(--bg)}.loading-state,.auth-main{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e0e7ff,#f8fafc)}.loading-panel{padding:2rem 2.5rem;border-radius:20px;background:var(--surface);box-shadow:var(--shadow);display:flex;align-items:center;gap:1rem}.loading-spinner{width:32px;height:32px;border-radius:50%;border:3px solid #dbeafe;border-top-color:var(--primary);animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dashboard-shell{min-height:100vh;height:100vh;display:flex;overflow:hidden}.sidebar{width:260px;background:linear-gradient(180deg,var(--sidebar-start) 0%,var(--sidebar-end) 100%);color:#e2e8f0;padding:2rem 1.75rem;display:flex;flex-direction:column;gap:2rem;flex-shrink:0;height:100vh;overflow-y:auto}.sidebar__brand{display:flex;align-items:center;gap:.85rem}.brand-mark{width:42px;height:42px;border-radius:16px;background:#ffffff1a;display:inline-flex;align-items:center;justify-content:center;font-weight:600}.sidebar__brand p{margin:0;font-weight:600}.sidebar__brand small{color:#e2e8f0b3}.sidebar__nav{display:flex;flex-direction:column;gap:.5rem}.nav-item{color:inherit;padding:.65rem .85rem;border-radius:12px;text-align:left;background:transparent;font-size:.95rem}.nav-item.active{background:#ffffff26;box-shadow:inset 0 0 0 1px #ffffff26}.nav-item.muted{opacity:.6;cursor:not-allowed}.sidebar__footer{margin-top:auto;background:#ffffff0d;border-radius:16px;padding:1rem}.sidebar__footer p{margin:0 0 .35rem;font-size:.85rem;color:#e2e8f0bf}.sidebar__footer strong{font-size:1.35rem}.sidebar__copyright{display:block;margin-top:.65rem;font-size:.75rem;color:#e2e8f0a6}.dashboard-surface{flex:1;background:var(--bg);display:flex;flex-direction:column;height:100vh;min-height:0}.topbar{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}.topbar__locale{font-size:.85rem;color:var(--muted);display:flex;flex-direction:column;gap:.35rem}.topbar__locale select{width:170px}.topbar__right{display:flex;align-items:center;gap:1rem}.user-chip{display:flex;align-items:center;gap:.85rem;padding:.4rem .75rem;border-radius:999px;background:var(--surface-muted)}.user-chip__meta{display:flex;flex-direction:column;font-size:.8rem;color:var(--muted)}.role{font-weight:600;color:var(--text)}.avatar{width:36px;height:36px;border-radius:50%;background:#1d4ed8;color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:600}.pill-button{padding:.6rem 1.5rem;border-radius:999px;background:var(--text);color:#fff;font-weight:600}.pill-button:hover{background:#111827}.page-content{flex:1;padding:2rem;overflow-y:auto;min-height:0}.login-view{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a,#1e3a8a 60%,#2563eb);color:#fff;padding:2rem}.login-panel{width:min(900px,100%);display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));background:#0f172abf;border-radius:28px;overflow:hidden;box-shadow:var(--shadow)}.login-copy{padding:3rem 2.5rem;background:#ffffff08}.login-copy h1{margin:.25rem 0 .75rem;font-size:2rem}.login-copy p{margin:0;color:#ffffffd9}.login-card{padding:3rem 2.5rem;background:var(--surface);color:var(--text);display:flex;flex-direction:column;gap:.75rem}.login-card__locale{align-self:flex-end;color:var(--muted)}.login-card h2{margin:0}.login-card .subtle{margin:0 0 .5rem}.login-card button{margin-top:.5rem;width:100%}.eyebrow{text-transform:uppercase;letter-spacing:.15em;font-size:.75rem;color:var(--muted);margin:0 0 .25rem}.lede{color:var(--muted);margin:.5rem 0 0}.primary-btn{width:auto;padding:.85rem 1rem;border-radius:14px;background:var(--primary);color:#fff;font-weight:600;box-shadow:0 12px 20px #2563eb26}.primary-btn:hover{background:var(--primary-dark)}.ghost-btn{width:auto;padding:.8rem 1rem;border-radius:14px;border:1px solid var(--border);background:var(--surface);font-weight:600;color:var(--text)}.ghost-btn:hover{background:var(--surface-muted)}.error,.error-banner{background:#fee4e2;color:#b42318;border:1px solid #fecdca;padding:.85rem 1rem;border-radius:12px;font-size:.9rem}.error-banner{margin-bottom:1rem}.clients-dashboard{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:1.5rem;align-items:stretch;padding-bottom:2.5rem}.page-header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:1.25rem 1.5rem;background:linear-gradient(135deg,#e0e7ff,#f8fafc);border-radius:22px;box-shadow:var(--shadow)}.page-header h1{margin:.25rem 0;font-size:2rem}.header-actions{display:flex;flex-wrap:wrap;align-items:center;gap:.85rem}.header-actions-group{display:flex;align-items:flex-end;gap:.75rem;padding:.6rem .9rem;border-radius:16px;background:var(--surface);box-shadow:0 10px 30px #0f172a14}.header-actions-group label{display:flex;flex-direction:column;gap:.3rem;font-size:.8rem;color:var(--muted)}.header-actions-group select{width:200px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.25rem}.stat-card{background:var(--surface);border-radius:22px;padding:1.5rem;box-shadow:var(--shadow);display:flex;gap:1rem;align-items:center}.stat-icon{width:52px;height:52px;border-radius:16px;background:linear-gradient(135deg,#2563eb26,#0ea5e926)}.stat-content h3{margin:.15rem 0;font-size:1.75rem}.stat-label,.stat-description{margin:0;color:var(--muted)}.insights-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem}.panel{background:var(--surface);border-radius:22px;padding:1.75rem;box-shadow:var(--shadow)}.panel header h2{margin:0}.panel header .subtle{margin-top:.25rem}.health-list{list-style:none;padding:1.5rem 0 0;margin:0;display:flex;flex-direction:column;gap:1rem}.health-list li{display:flex;justify-content:space-between;gap:1rem;align-items:center}.health-label{margin:0;font-weight:600}.health-description{margin:.25rem 0 0;color:var(--muted);font-size:.9rem}.status-pill{border-radius:999px;padding:.2rem .8rem;font-size:.8rem;font-weight:600;background:var(--surface-muted);color:var(--muted)}.status-pill.success{background:#ecfdf3;color:#039855}.status-pill.warning{background:#fff7ed;color:#c2410c}.status-pill.muted{background:#f8fafc;color:var(--muted)}.form-panel{max-width:720px;width:100%;align-self:flex-start}.peers-panel{width:100%}.client-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem 1.5rem}.client-form small{display:block;margin-top:.25rem;color:var(--muted)}.client-form .toggle-field{align-self:flex-start}.client-form .form-actions{display:flex;gap:.75rem;flex-wrap:wrap;grid-column:1 / -1}.toggle-field{display:flex;justify-content:space-between;align-items:center}.toggle-field small{margin-top:.2rem}.table-header{display:flex;justify-content:space-between;gap:1rem;align-items:center}.table-header-controls{display:flex;align-items:center;gap:.65rem;flex-wrap:wrap;justify-content:flex-end}.table-wrapper{margin-top:1.5rem;overflow-x:auto}.ghost-btn--compact{padding:.5rem .85rem;font-size:.85rem}.clients-table{width:100%;border-collapse:collapse;font-size:.9rem}.clients-table th{text-align:left;font-size:.85rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);border-bottom:1px solid var(--border);padding:0 0 .75rem}.clients-table td{border-bottom:1px solid var(--border);padding:.9rem 0;vertical-align:top}.clients-table tbody tr:last-of-type td{border-bottom-color:transparent}.clients-table tbody tr:hover{background:var(--surface-muted)}.status-cell{display:flex;flex-direction:column;align-items:flex-start;gap:.35rem}.link-btn{padding:0;border:none;background:none;color:var(--primary);font-weight:600;font-size:.85rem;text-decoration:underline}.link-btn:hover{color:var(--primary-dark)}.cell-title{margin:0;font-weight:600}.cell-subtitle{margin:.2rem 0 0;color:var(--muted);font-size:.75rem}.table-actions{display:flex;flex-wrap:wrap;gap:.35rem}.table-actions button{padding:.4rem .8rem;border-radius:999px;border:1px solid var(--border);font-size:.8rem;background:var(--surface-muted)}.table-actions button:hover{background:var(--surface)}.table-actions .danger{border-color:#dc262666;color:var(--danger);background:#dc26260d}.empty-state{margin-top:1.5rem;padding:2rem;border-radius:16px;background:var(--surface-muted);text-align:center;color:var(--muted)}.peer-graph-section{width:100%}.peer-graph-panel{display:flex;flex-direction:column;gap:.75rem}.peer-graph-header{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start;flex-wrap:wrap}.peer-graph-header h2{margin:.2rem 0}.peer-graph-actions{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.peer-graph-actions label{font-size:.85rem;color:var(--muted);display:flex;flex-direction:column;gap:.35rem}.peer-graph-description{margin:0;color:var(--muted)}.peer-graph-chart{background:var(--surface-muted);border-radius:20px;padding:1rem;border:1px solid var(--border)}.peer-graph-chart svg{width:100%;height:220px}.traffic-line{fill:none;stroke-width:3;stroke-linecap:round;stroke-linejoin:round}.traffic-line.rx{stroke:#22c55e}.traffic-line.tx{stroke:#0ea5e9}.traffic-legend{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:.5rem}.traffic-legend>div{display:flex;gap:.65rem;align-items:center;padding:.75rem;border-radius:14px;background:var(--surface-muted)}.traffic-legend strong{display:block}.traffic-legend p{margin:.15rem 0 0;color:var(--muted)}.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.legend-dot.rx{background:#22c55e}.legend-dot.tx{background:#0ea5e9}.legend-dot.neutral{background:var(--muted)}@media (max-width: 980px){.dashboard-shell{flex-direction:column;height:auto;overflow:visible}.sidebar{width:100%;height:auto;overflow:visible;border-bottom-left-radius:28px;border-bottom-right-radius:28px}.dashboard-surface{height:auto;min-height:auto}.topbar{flex-direction:column;align-items:flex-start;gap:1rem}.page-content{overflow:visible}.page-header{padding:1rem 1.1rem}.header-actions-group,.header-actions-group select{width:100%}}@media (max-height: 1080px) and (min-width: 981px){.sidebar{padding:1.5rem 1.25rem}.topbar{padding:1.25rem 1.5rem}.page-content{padding:1.5rem}}
