:root{color-scheme:light;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f5f7fb;color:#18202f}*{box-sizing:border-box}body{margin:0}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.65}.app{display:grid;grid-template-columns:240px minmax(0,1fr);min-height:100vh}.sidebar{background:#111827;color:#f9fafb;padding:20px;display:flex;flex-direction:column;gap:10px}.brand{display:flex;align-items:center;gap:12px;margin-bottom:20px}.brand strong{display:block;font-size:17px}.brand span{color:#9ca3af;font-size:13px}.nav{display:flex;align-items:center;gap:10px;border:0;border-radius:8px;padding:11px 12px;color:#d1d5db;background:transparent;text-align:left}.nav.active,.nav:hover{background:#263244;color:#fff}.nav.danger{margin-top:auto;color:#fecaca}main{padding:24px;min-width:0}.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}h1,h2,p{margin:0}h1{font-size:26px;letter-spacing:0}h2{font-size:16px;margin-bottom:14px}.topbar p{color:#64748b;margin-top:4px}.grid{display:grid;gap:18px}.grid.two{grid-template-columns:minmax(300px,420px) minmax(0,1fr)}.grid.three{grid-template-columns:repeat(3,minmax(240px,1fr))}.spanAll{grid-column:1 / -1}.panel,.loginPanel{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:18px;box-shadow:0 1px 2px #0f172a0d}.loginShell{min-height:100vh;display:grid;place-items:center;padding:24px;background:#f5f7fb}.loginPanel{width:min(420px,100%);display:grid;gap:12px}.loginBrand{color:#111827}input,select,textarea{width:100%;border:1px solid #cbd5e1;border-radius:8px;padding:10px 12px;background:#fff;color:#18202f}textarea{min-height:240px;resize:vertical;font-family:SFMono-Regular,Consolas,monospace;font-size:12px}label{color:#475569;font-size:13px}.toggle{display:flex;align-items:center;gap:8px}.toggle input{width:auto}.primary,.secondary,.iconButton{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:8px;padding:10px 12px;text-decoration:none}.primary{color:#fff;background:#0f766e}.secondary{color:#0f172a;background:#e2e8f0;margin-left:8px}.buttonRow{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.buttonRow .secondary{margin-left:0}.dangerAction{color:#991b1b;background:#fee2e2;margin-left:0}.iconButton{width:38px;height:38px;padding:0;color:#0f172a;background:#e2e8f0}.danger{color:#991b1b}.list{display:grid;gap:10px}.list.compact{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.row{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:12px;border:1px solid #e2e8f0;border-radius:8px;min-height:66px}.peerRow{cursor:pointer}.peerRow:hover,.peerRow:focus-visible{border-color:#0f766e;outline:0;background:#f8fafc}.inlineMeta{display:inline-flex;align-items:center;gap:5px;margin-top:4px}.peerDetail{display:grid;gap:18px}.detailHeader{display:flex;align-items:center;justify-content:space-between}.detailBack{margin-left:0}.peerTitle{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}.routeEditor{align-items:flex-start}.routeEditorGrid{flex:1;display:grid;grid-template-columns:minmax(160px,1.1fr) minmax(190px,1.2fr) minmax(140px,1fr) minmax(110px,.7fr) auto;gap:8px}.row strong{display:block;overflow-wrap:anywhere}.routeLink{display:block;color:#0f766e;font-weight:700;text-align:left;overflow-wrap:anywhere}.buttonLike{border:0;padding:0;background:transparent}.row span{color:#64748b;font-size:13px;overflow-wrap:anywhere}.rowActions{display:flex;align-items:center;gap:8px;flex-shrink:0}.pill{border-radius:999px;padding:4px 9px;font-size:12px;color:#0f172a;background:#e2e8f0}.pill.online,.pill.active{color:#065f46;background:#d1fae5}.pill.offline,.pill.fermee{color:#92400e;background:#fef3c7}.pill.revoque{color:#991b1b;background:#fee2e2}.countdown{flex-shrink:0;border-radius:999px;padding:4px 9px;font-size:12px;color:#075985;background:#e0f2fe}.notice{margin-bottom:16px;border:1px solid #fde68a;background:#fffbeb;color:#92400e;border-radius:8px;padding:10px 12px}.muted{color:#64748b;font-size:13px;margin-bottom:14px;overflow-wrap:anywhere}.securityStatus{display:flex;align-items:center;gap:10px;margin-bottom:6px;color:#0f766e;font-weight:700}.twoFactorForm{display:grid;gap:12px}.totpSetup{display:grid;gap:10px}.totpSetup img{width:170px;height:170px;border:1px solid #e2e8f0;border-radius:8px}.totpSetup code{display:block;max-width:100%;padding:10px 12px;border-radius:8px;background:#f1f5f9;color:#334155;font-family:SFMono-Regular,Consolas,monospace;font-size:12px;overflow-wrap:anywhere}.configBox{display:grid;gap:12px;margin-top:14px}.configBox img{width:180px;height:180px;border:1px solid #e2e8f0;border-radius:8px}.segments{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.segments button{border:1px solid #cbd5e1;background:#fff;border-radius:8px;padding:9px}.segments button.active{border-color:#0f766e;color:#0f766e;background:#ecfdf5}.statLine,.traffic{display:flex;align-items:center;gap:10px;margin-bottom:12px}.traffic{justify-content:space-between}.bars{display:grid;gap:10px}.barRow{display:grid;grid-template-columns:140px 1fr;gap:10px;align-items:center;font-size:13px}.barRow div{height:10px;background:#e2e8f0;border-radius:999px;overflow:hidden}.barRow i{display:block;height:100%;background:#0f766e}.chartSummary{margin-bottom:8px}.chartControls{display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;margin-bottom:12px}.toggleGroup{display:inline-grid;grid-auto-flow:column;grid-auto-columns:minmax(54px,auto);gap:4px;padding:4px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px}.toggleGroup button{border:0;background:transparent;border-radius:6px;color:#475569;cursor:pointer;font-size:12px;font-weight:800;min-height:28px;padding:6px 9px;white-space:nowrap}.toggleGroup button.active{background:#fff;color:#0f172a;box-shadow:0 1px 4px #0f172a24}.toggleGroup.dataScale{grid-auto-columns:minmax(48px,auto)}.trafficChart{position:relative;width:100%;min-height:250px}.trafficChart.empty{display:grid;place-items:center;border:1px dashed #cbd5e1;border-radius:8px}.trafficChart svg{display:block;width:100%;height:auto}.chartGrid{stroke:#e2e8f0;stroke-width:1}.chartGrid.vertical{stroke-dasharray:3 5}.statusBand.connected{fill:#16a34a17}.statusBand.disconnected{fill:#dc262614}.chartLine{fill:none;stroke-width:3;stroke-linecap:round;stroke-linejoin:round;vector-effect:non-scaling-stroke}.chartLine.down{stroke:#0f766e}.chartLine.up{stroke:#2563eb}.chartDot.down{stroke:#0f766e;fill:#0f766e}.chartDot.up{stroke:#2563eb;fill:#2563eb}.chartScale,.chartTick{fill:#64748b;font-size:12px}.chartScale{text-anchor:end}.chartTick{text-anchor:middle}.chartTick.end{text-anchor:end}.chartHitArea{fill:transparent;pointer-events:all}.hoverLine{stroke:#0f172a;stroke-dasharray:4 4;stroke-width:1}.chartDot.hover{stroke:#fff;stroke-width:2}.chartTooltip{position:absolute;z-index:1;display:grid;min-width:174px;gap:3px;padding:9px 10px;background:#0f172aeb;border-radius:8px;color:#fff;font-size:12px;pointer-events:none;transform:translate(-50%,-100%);box-shadow:0 14px 28px #0f172a2e}.chartTooltip strong{font-size:12px}.chartTooltip em{font-style:normal;font-weight:800}.chartTooltip em.connected{color:#86efac}.chartTooltip em.disconnected{color:#fca5a5}.chartEmpty{position:absolute;inset:58px 0 34px 70px;display:grid;place-items:center;pointer-events:none}.chartMeta{display:flex;flex-wrap:wrap;gap:12px;margin-top:10px;font-size:13px;font-weight:700}.legendItem{display:inline-flex;align-items:center;gap:6px}.legendItem:before{content:"";width:18px;height:3px;border-radius:999px}.legendItem.down:before{background:#0f766e}.legendItem.up:before{background:#2563eb}.legendItem.connected:before{background:#16a34a52}.legendItem.disconnected:before{background:#dc262647}.tableWrap{overflow-x:auto}.connectionTable{width:100%;min-width:640px;border-collapse:separate;border-spacing:0 8px;font-size:13px}.connectionTable th{color:#64748b;font-size:12px;font-weight:700;text-align:left;text-transform:uppercase}.connectionTable th,.connectionTable td{padding:10px 12px}.connectionTable tbody tr.connected{background:#ecfdf5;box-shadow:inset 4px 0 #16a34a}.connectionTable tbody tr.disconnected{background:#fef2f2;box-shadow:inset 4px 0 #dc2626}.connectionTable tbody td:first-child{border-radius:8px 0 0 8px}.connectionTable tbody td:last-child{border-radius:0 8px 8px 0}.eventBadge{display:inline-flex;align-items:center;min-width:112px;font-weight:800}.eventBadge.connected{color:#166534}.eventBadge.disconnected{color:#991b1b}@media(max-width:980px){.app{grid-template-columns:1fr}.sidebar{position:sticky;top:0;z-index:2;flex-direction:row;overflow-x:auto}.brand{margin-bottom:0;min-width:170px}.nav.danger{margin-top:0}.grid.two,.grid.three,.routeEditorGrid{grid-template-columns:1fr}.traffic{align-items:flex-start}.chartControls{justify-content:flex-start}.toggleGroup{grid-auto-flow:row;grid-template-columns:repeat(3,minmax(52px,1fr));width:100%}.toggleGroup.dataScale{grid-template-columns:repeat(4,minmax(48px,1fr))}.connectionTable{min-width:560px}}
