:root,[data-theme=light]{color-scheme:light;--sn-bg: #f8fafc;--sn-bg-subtle: #f1f5f9;--sn-surface: #ffffff;--sn-surface-2: #f8fafc;--sn-surface-elevated: #ffffff;--sn-surface-inset: #f1f5f9;--sn-surface-hover: #f8fafc;--sn-sidebar: #ffffff;--sn-modal-overlay: rgba(15, 23, 42, .45);--sn-text: #0f172a;--sn-text-secondary: #334155;--sn-muted: #64748b;--sn-muted-light: #94a3b8;--sn-primary: #2563eb;--sn-accent: #2563eb;--sn-accent-hover: #1d4ed8;--sn-accent-soft: rgba(37, 99, 235, .08);--sn-accent-glow: rgba(37, 99, 235, .18);--sn-teal: #0d9488;--sn-teal-soft: rgba(13, 148, 136, .1);--sn-warm: #d97706;--sn-warm-soft: rgba(217, 119, 6, .1);--sn-gradient: linear-gradient(135deg, #2563eb 0%, #0d9488 100%);--sn-border: #e2e8f0;--sn-border-light: #f1f5f9;--sn-shadow-xs: 0 1px 2px rgba(15, 23, 42, .04);--sn-shadow-sm: 0 1px 3px rgba(15, 23, 42, .06);--sn-shadow-md: 0 4px 12px rgba(15, 23, 42, .08);--sn-shadow-lg: 0 8px 24px rgba(15, 23, 42, .1);--sn-shadow-card: 0 1px 3px rgba(15, 23, 42, .06);--sn-success: #059669;--sn-success-soft: rgba(5, 150, 105, .1);--sn-warn: #d97706;--sn-warn-soft: rgba(217, 119, 6, .1);--sn-danger: #dc2626;--sn-danger-soft: rgba(220, 38, 38, .1);--sn-code-bg: #f8fafc;--sn-code-header-bg: #f1f5f9;--sn-code-border: #e2e8f0;--sn-code-fg: #334155;--sn-code-fg-muted: #64748b;--sn-code-lineno: #94a3b8;--sn-code-path: #0f172a;--sn-code-stripe: rgba(15, 23, 42, .025);--sn-code-hover: rgba(37, 99, 235, .06);--sn-code-hover-accent: rgba(37, 99, 235, .4);--sn-code-error-msg: #b91c1c;--sn-log-highlight-bg: rgba(250, 204, 21, .55);--sn-log-highlight-fg: #0f172a;--sn-log-live-fg: #15803d;--sn-log-live-bg: rgba(34, 197, 94, .12);--sn-log-live-border: rgba(34, 197, 94, .35);--sn-log-time-fg: #64748b;--sn-log-time-bg: rgba(100, 116, 139, .12);--sn-log-ip-fg: #4338ca;--sn-log-ip-bg: rgba(67, 56, 202, .1);--sn-log-host-fg: #0e7490;--sn-log-host-bg: rgba(14, 116, 144, .1);--sn-log-muted-fg: #64748b;--sn-log-muted-bg: rgba(100, 116, 139, .12);--sn-log-method-get-fg: #15803d;--sn-log-method-get-bg: rgba(34, 197, 94, .15);--sn-log-method-post-fg: #1d4ed8;--sn-log-method-post-bg: rgba(59, 130, 246, .12);--sn-log-method-write-fg: #b45309;--sn-log-method-write-bg: rgba(245, 158, 11, .15);--sn-log-method-delete-fg: #b91c1c;--sn-log-method-delete-bg: rgba(239, 68, 68, .12);--sn-log-method-other-fg: #475569;--sn-log-method-other-bg: rgba(71, 85, 105, .1);--sn-log-status-2xx-fg: #15803d;--sn-log-status-2xx-bg: rgba(34, 197, 94, .15);--sn-log-status-3xx-fg: #0369a1;--sn-log-status-3xx-bg: rgba(14, 165, 233, .12);--sn-log-status-4xx-fg: #c2410c;--sn-log-status-4xx-bg: rgba(249, 115, 22, .15);--sn-log-status-5xx-fg: #b91c1c;--sn-log-status-5xx-bg: rgba(239, 68, 68, .15);--sn-log-status-other-fg: #475569;--sn-log-status-other-bg: rgba(71, 85, 105, .1);--sn-log-level-error-fg: #b91c1c;--sn-log-level-error-bg: rgba(239, 68, 68, .15);--sn-log-level-warn-fg: #b45309;--sn-log-level-warn-bg: rgba(245, 158, 11, .18);--sn-log-level-info-fg: #0369a1;--sn-log-level-info-bg: rgba(14, 165, 233, .12);--sn-diff-add-bg: rgba(34, 197, 94, .18);--sn-diff-add-fg: #15803d;--sn-diff-remove-bg: rgba(239, 68, 68, .18);--sn-diff-remove-fg: #b91c1c;--sn-diff-same-fg: #64748b;--sn-chart-grid: #e2e8f0;--sn-chart-axis: #64748b;--sn-chart-tooltip-bg: #ffffff;--sn-chart-tooltip-border: #e2e8f0;--sn-chart-tooltip-shadow: 0 4px 12px rgba(15, 23, 42, .08);--sn-radius-sm: 6px;--sn-radius: 8px;--sn-radius-lg: 12px;--sn-radius-xl: 16px;--sn-font: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;--sn-font-display: var(--sn-font);--sn-ease-out: cubic-bezier(.22, 1, .36, 1);--sn-transition: .15s ease;--sn-transition-spring: .2s ease}[data-theme=dark]{color-scheme:dark;--sn-bg: #0f1419;--sn-bg-subtle: #161b22;--sn-surface: #1c2128;--sn-surface-2: #161b22;--sn-surface-elevated: #252b33;--sn-surface-inset: #0f1419;--sn-surface-hover: #252b33;--sn-sidebar: #161b22;--sn-modal-overlay: rgba(0, 0, 0, .65);--sn-text: #e6edf3;--sn-text-secondary: #c9d1d9;--sn-muted: #8b949e;--sn-muted-light: #6e7681;--sn-primary: #58a6ff;--sn-accent: #58a6ff;--sn-accent-hover: #79b8ff;--sn-accent-soft: rgba(88, 166, 255, .12);--sn-accent-glow: rgba(88, 166, 255, .2);--sn-teal: #3fb950;--sn-teal-soft: rgba(63, 185, 80, .12);--sn-warm: #d29922;--sn-warm-soft: rgba(210, 153, 34, .12);--sn-gradient: linear-gradient(135deg, #58a6ff 0%, #3fb950 100%);--sn-border: #30363d;--sn-border-light: #21262d;--sn-shadow-xs: 0 1px 2px rgba(0, 0, 0, .2);--sn-shadow-sm: 0 1px 3px rgba(0, 0, 0, .25);--sn-shadow-md: 0 4px 12px rgba(0, 0, 0, .3);--sn-shadow-lg: 0 8px 24px rgba(0, 0, 0, .35);--sn-shadow-card: 0 1px 3px rgba(0, 0, 0, .25);--sn-success: #3fb950;--sn-success-soft: rgba(63, 185, 80, .15);--sn-warn: #d29922;--sn-warn-soft: rgba(210, 153, 34, .15);--sn-danger: #f85149;--sn-danger-soft: rgba(248, 81, 73, .15);--sn-code-bg: #0d1117;--sn-code-header-bg: #161b22;--sn-code-border: #30363d;--sn-code-fg: #c9d1d9;--sn-code-fg-muted: #6e7681;--sn-code-lineno: #484f58;--sn-code-path: #e6edf3;--sn-code-stripe: rgba(255, 255, 255, .02);--sn-code-hover: rgba(88, 166, 255, .08);--sn-code-hover-accent: rgba(88, 166, 255, .4);--sn-code-error-msg: #ffa198;--sn-log-highlight-bg: rgba(187, 128, 9, .35);--sn-log-highlight-fg: #e6edf3;--sn-log-live-fg: #3fb950;--sn-log-live-bg: rgba(63, 185, 80, .15);--sn-log-live-border: rgba(63, 185, 80, .35);--sn-log-time-fg: #8b949e;--sn-log-time-bg: rgba(139, 148, 158, .12);--sn-log-ip-fg: #a5b4fc;--sn-log-ip-bg: rgba(165, 180, 252, .12);--sn-log-host-fg: #67e8f9;--sn-log-host-bg: rgba(103, 232, 249, .1);--sn-log-muted-fg: #6e7681;--sn-log-muted-bg: rgba(110, 118, 129, .15);--sn-log-method-get-fg: #3fb950;--sn-log-method-get-bg: rgba(63, 185, 80, .12);--sn-log-method-post-fg: #79b8ff;--sn-log-method-post-bg: rgba(121, 184, 255, .12);--sn-log-method-write-fg: #e3b341;--sn-log-method-write-bg: rgba(227, 179, 65, .12);--sn-log-method-delete-fg: #ffa198;--sn-log-method-delete-bg: rgba(255, 161, 152, .12);--sn-log-method-other-fg: #c9d1d9;--sn-log-method-other-bg: rgba(201, 209, 217, .1);--sn-log-status-2xx-fg: #3fb950;--sn-log-status-2xx-bg: rgba(63, 185, 80, .15);--sn-log-status-3xx-fg: #79b8ff;--sn-log-status-3xx-bg: rgba(121, 184, 255, .12);--sn-log-status-4xx-fg: #ffa657;--sn-log-status-4xx-bg: rgba(255, 166, 87, .15);--sn-log-status-5xx-fg: #f85149;--sn-log-status-5xx-bg: rgba(248, 81, 73, .18);--sn-log-status-other-fg: #e6edf3;--sn-log-status-other-bg: rgba(230, 237, 243, .1);--sn-log-level-error-fg: #ffa198;--sn-log-level-error-bg: rgba(248, 81, 73, .25);--sn-log-level-warn-fg: #e3b341;--sn-log-level-warn-bg: rgba(227, 179, 65, .2);--sn-log-level-info-fg: #79b8ff;--sn-log-level-info-bg: rgba(121, 184, 255, .15);--sn-diff-add-bg: rgba(63, 185, 80, .2);--sn-diff-add-fg: #7ee787;--sn-diff-remove-bg: rgba(248, 81, 73, .2);--sn-diff-remove-fg: #ffa198;--sn-diff-same-fg: #c9d1d9;--sn-chart-grid: #30363d;--sn-chart-axis: #8b949e;--sn-chart-tooltip-bg: #1c2128;--sn-chart-tooltip-border: #30363d;--sn-chart-tooltip-shadow: 0 4px 12px rgba(0, 0, 0, .35)}*{box-sizing:border-box}body{margin:0;font-family:var(--sn-font);background:var(--sn-bg);color:var(--sn-text);min-height:100vh;-webkit-font-smoothing:antialiased;transition:background-color var(--sn-transition),color var(--sn-transition)}a{color:var(--sn-accent);text-decoration:none;transition:color var(--sn-transition)}a:hover{color:var(--sn-accent-hover)}.fade-in{animation:fadeIn .5s cubic-bezier(.22,1,.36,1)}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}.page-enter{animation:pageEnter .45s cubic-bezier(.22,1,.36,1)}@keyframes pageEnter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.sidebar{background:var(--sn-sidebar);border-right:1px solid var(--sn-border);display:flex;flex-direction:column;padding:1.35rem 1rem;box-shadow:var(--sn-shadow-xs);position:sticky;top:0;height:100vh;overflow-y:auto}.brand{display:flex;align-items:center;gap:.65rem;font-weight:800;font-size:1.08rem;margin-bottom:1.75rem;letter-spacing:-.02em;color:var(--sn-text)}.brand-icon{width:36px;height:36px;display:grid;place-items:center;background:var(--sn-gradient);border-radius:10px;font-size:1rem;box-shadow:0 3px 10px var(--sn-accent-glow);transition:transform var(--sn-transition-spring)}.brand:hover .brand-icon{transform:scale(1.06) rotate(-4deg)}.nav-section{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--sn-muted-light);padding:0 .75rem;margin:.5rem 0 .65rem}.nav-link{display:flex;align-items:center;gap:.6rem;padding:.6rem .85rem;border-radius:var(--sn-radius-sm);color:var(--sn-muted);margin-bottom:.2rem;font-weight:500;font-size:.92rem;transition:background var(--sn-transition),color var(--sn-transition),transform .2s,box-shadow var(--sn-transition);position:relative}.nav-link:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%) scaleY(0);width:3px;height:60%;border-radius:0 3px 3px 0;background:var(--sn-gradient);transition:transform .25s ease}.nav-link:hover{background:var(--sn-bg-subtle);color:var(--sn-text);text-decoration:none;transform:translate(2px)}.nav-link.active{background:var(--sn-accent-soft);color:var(--sn-accent-hover);font-weight:600;box-shadow:var(--sn-shadow-xs)}.nav-link.active:before{transform:translateY(-50%) scaleY(1)}.nav-icon{font-size:1.05rem;width:1.35rem;text-align:center;flex-shrink:0}.sidebar-footer{margin-top:auto;padding-top:1.25rem;border-top:1px solid var(--sn-border);display:flex;flex-direction:column;gap:.65rem}.user-badge{font-size:.85rem;color:var(--sn-muted);padding:.45rem .75rem;background:var(--sn-bg-subtle);border-radius:var(--sn-radius-sm);font-weight:500}.main-content{padding:2rem 2.25rem;overflow:auto;background:radial-gradient(ellipse 70% 40% at 100% 0%,rgba(14,165,233,.06),transparent 55%),var(--sn-bg)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;padding-bottom:.85rem;border-bottom:1px solid var(--sn-border-light);gap:.75rem 1rem;flex-wrap:wrap}.page-header h1{margin:0;font-size:1.85rem;font-weight:800;letter-spacing:-.03em}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:var(--sn-surface);border:1px solid var(--sn-border);border-radius:var(--sn-radius-lg);padding:1.35rem;display:flex;flex-direction:column;gap:.35rem;box-shadow:var(--sn-shadow-card);transition:transform var(--sn-transition-spring),box-shadow var(--sn-transition),border-color var(--sn-transition)}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--sn-shadow-md);border-color:#0ea5e940}.stat-card.warn{border-color:var(--sn-warn);background:linear-gradient(135deg,var(--sn-surface) 0%,var(--sn-warn-soft) 100%)}.stat-value{font-size:2.1rem;font-weight:800;letter-spacing:-.03em;color:var(--sn-text)}.stat-label{color:var(--sn-muted);font-size:.88rem;font-weight:500}.panel{background:var(--sn-surface);border:1px solid var(--sn-border);border-radius:var(--sn-radius-lg);padding:1.35rem 1.5rem;margin-bottom:1rem;box-shadow:var(--sn-shadow-card);transition:box-shadow var(--sn-transition)}.panel:hover{box-shadow:var(--sn-shadow-sm)}.panel.warn{border-color:var(--sn-warn);background:linear-gradient(135deg,var(--sn-surface) 0%,var(--sn-warn-soft) 100%)}.panel-header-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.panel-header-row h2{margin:0}.data-table tr.row-warn td{background:var(--sn-warn-soft)}.panel h2{margin:0 0 1rem;font-size:.95rem;font-weight:600;color:var(--sn-muted)}.data-table{width:100%;border-collapse:separate;border-spacing:0;background:var(--sn-surface);border-radius:var(--sn-radius-lg);overflow:hidden;border:1px solid var(--sn-border);box-shadow:var(--sn-shadow-card)}.data-table th,.data-table td{padding:.8rem 1.1rem;text-align:left;border-bottom:1px solid var(--sn-border-light)}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr{transition:background var(--sn-transition)}.data-table tbody tr:hover{background:var(--sn-bg-subtle)}.data-table tbody tr.row-clickable{cursor:pointer}.data-table tbody tr.row-clickable:active{background:var(--sn-accent-soft)}.table-hint{font-size:.85rem;margin:0 0 .75rem}.tiles-hint{font-size:.85rem;margin:0 0 1rem;color:var(--sn-muted)}.tile-grid{display:grid;gap:1rem;margin-bottom:.5rem}.tile-grid-auto{grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr))}.tile-grid-cols-1{grid-template-columns:1fr}.tile-grid-cols-2{grid-template-columns:repeat(2,1fr)}.tile-grid-cols-3{grid-template-columns:repeat(3,1fr)}.tile-grid-cols-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 900px){.tile-grid-cols-3,.tile-grid-cols-4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.tile-grid-cols-2,.tile-grid-cols-3,.tile-grid-cols-4{grid-template-columns:1fr}}.tile-grid-animate>.tile-card,.tile-grid-animate>.tile-list-item{animation:tileEnter .55s cubic-bezier(.22,1,.36,1) backwards}@keyframes tileEnter{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:none}}.tile-card{display:flex;flex-direction:column;gap:.85rem;padding:1.15rem 1.25rem;background:var(--sn-surface);border:1px solid var(--sn-border);border-radius:var(--sn-radius-lg);box-shadow:var(--sn-shadow-card);transition:transform var(--sn-transition),box-shadow var(--sn-transition),border-color var(--sn-transition),background var(--sn-transition);position:relative;overflow:hidden}.tile-card:before{content:"";position:absolute;inset:0 auto 0 0;width:3px;background:var(--sn-gradient);opacity:0;transition:opacity var(--sn-transition)}.tile-card-accent:before{opacity:1}.tile-card-warn{border-color:#f59e0b59;background:linear-gradient(135deg,var(--sn-surface) 0%,var(--sn-warn-soft) 100%)}.cert-expiry-warn{color:var(--sn-warn);font-weight:500}.cert-expiry-danger{color:var(--sn-danger);font-weight:500}.tile-card-clickable{cursor:pointer}.tile-card-clickable:hover{transform:translateY(-4px);box-shadow:var(--sn-shadow-md);border-color:#0ea5e940}.tile-card-clickable:hover:before{opacity:1}.tile-card-clickable:active{transform:translateY(-1px) scale(.995)}.tile-card-header{display:flex;align-items:flex-start;gap:.75rem}.tile-card-icon{flex-shrink:0;width:40px;height:40px;display:grid;place-items:center;border-radius:var(--sn-radius-sm);background:var(--sn-accent-soft);font-size:1.1rem}.tile-card-header-text{flex:1;min-width:0}.tile-card-title{margin:0;font-size:1rem;font-weight:700;letter-spacing:-.02em;color:var(--sn-text);word-break:break-word}.tile-card-subtitle{margin:.25rem 0 0;font-size:.82rem;color:var(--sn-muted);line-height:1.4;word-break:break-word}.tile-card-badges{display:flex;flex-wrap:wrap;gap:.35rem;justify-content:flex-end}.tile-meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.55rem 1rem;margin:0}.tile-meta-row{display:flex;flex-direction:column;gap:.15rem;min-width:0}.tile-meta-row-full{grid-column:1 / -1}.tile-meta-row dt{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--sn-muted-light)}.tile-meta-row dd{margin:0;font-size:.88rem;color:var(--sn-text-secondary);word-break:break-word}.tile-mono{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.82rem}.tile-actions{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:auto;padding-top:.35rem;border-top:1px solid var(--sn-border-light)}.tile-empty{grid-column:1 / -1;text-align:center;padding:2.5rem 1rem;color:var(--sn-muted);background:var(--sn-bg-subtle);border-radius:var(--sn-radius-lg);border:1px dashed var(--sn-border)}.tile-list{display:flex;flex-direction:column;gap:.65rem}.tile-list-item{display:grid;gap:.65rem;padding:.9rem 1.1rem;background:var(--sn-surface);border:1px solid var(--sn-border);border-radius:var(--sn-radius);box-shadow:var(--sn-shadow-xs);transition:transform var(--sn-transition),box-shadow var(--sn-transition),border-color var(--sn-transition)}.tile-list-item:hover{transform:translate(4px);box-shadow:var(--sn-shadow-sm);border-color:#0ea5e933}.tile-list-item-warn{border-color:#f59e0b59;background:linear-gradient(90deg,var(--sn-warn-soft) 0%,var(--sn-surface) 12%)}.tile-list-head{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem .75rem}.tile-list-head-main{flex:1;min-width:0;display:flex;flex-wrap:wrap;align-items:baseline;gap:.35rem .65rem}.tile-list-time{font-size:.78rem;color:var(--sn-muted);font-variant-numeric:tabular-nums}.tile-list-path{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.84rem;word-break:break-all}.tile-list-stats{display:flex;flex-wrap:wrap;gap:.75rem 1.25rem;font-size:.82rem;color:var(--sn-muted)}.tile-list-stat strong{color:var(--sn-text-secondary);font-weight:600}.tile-chip-row{display:flex;flex-wrap:wrap;gap:.35rem}.site-tiles-grid{align-items:stretch}.tile-card-site{gap:.75rem;min-height:168px;padding:1rem 1.1rem 1rem 1.15rem}.site-tile-top{display:flex;align-items:flex-start;gap:.75rem;min-width:0}.site-tile-avatar{flex-shrink:0;width:42px;height:42px;display:grid;place-items:center;border-radius:12px;background:var(--sn-gradient);color:#fff;font-size:1rem;font-weight:800;letter-spacing:-.03em;box-shadow:0 4px 12px var(--sn-accent-glow)}.site-tile-head{flex:1;min-width:0;display:flex;flex-direction:column;gap:.45rem}.site-tile-title{margin:0;font-size:.98rem;font-weight:700;letter-spacing:-.02em;color:var(--sn-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.25}.site-tile-badges{display:flex;flex-wrap:wrap;gap:.35rem}.site-tile-domains{display:flex;flex-wrap:nowrap;align-items:center;gap:.35rem;min-height:1.65rem;overflow:hidden}.site-tile-domains-empty{font-size:.8rem;color:var(--sn-muted-light)}.site-domain-chip{flex-shrink:1;min-width:0;max-width:100%;padding:.2rem .55rem;border-radius:999px;background:var(--sn-bg-subtle);border:1px solid var(--sn-border-light);font-size:.72rem;color:var(--sn-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.site-domain-chip-more{flex-shrink:0;background:var(--sn-accent-soft);border-color:#0ea5e933;color:var(--sn-accent-hover);font-weight:600}.site-tile-stats{display:flex;align-items:center;gap:.85rem;margin-top:auto;padding-top:.75rem;border-top:1px solid var(--sn-border-light)}.site-tile-stat{display:flex;flex-direction:column;gap:.1rem;min-width:0}.site-tile-stat-value{font-size:1.05rem;font-weight:700;color:var(--sn-text);line-height:1.2}.site-tile-stat-value.site-tile-stat-ok{color:#0d9488}.site-tile-stat-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--sn-muted-light)}.site-tile-stat-divider{width:1px;align-self:stretch;background:var(--sn-border-light);margin:.15rem 0}@media (max-width: 1100px){.site-tiles-grid.tile-grid-cols-3{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.site-tiles-grid.tile-grid-cols-3{grid-template-columns:1fr}}.data-table th{color:var(--sn-muted);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;background:var(--sn-bg-subtle)}.btn-primary,.btn-secondary,.btn-ghost{border:none;border-radius:var(--sn-radius-sm);padding:.6rem 1.1rem;font:inherit;font-weight:600;font-size:.9rem;cursor:pointer;transition:transform var(--sn-transition-spring),box-shadow var(--sn-transition),background var(--sn-transition),border-color var(--sn-transition)}.btn-primary{background:var(--sn-gradient);color:#fff;box-shadow:0 2px 8px var(--sn-accent-glow)}.btn-primary:hover{box-shadow:var(--sn-shadow-lg);transform:translateY(-2px)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.btn-secondary{background:var(--sn-surface);color:var(--sn-text-secondary);border:1px solid var(--sn-border);box-shadow:var(--sn-shadow-xs)}.btn-secondary:hover{border-color:var(--sn-accent);color:var(--sn-accent);transform:translateY(-1px);box-shadow:var(--sn-shadow-sm)}.btn-ghost{background:transparent;color:var(--sn-muted)}.btn-ghost:hover{background:var(--sn-bg-subtle);color:var(--sn-text)}.form-inline{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.form-stack label{display:flex;flex-direction:column;gap:.4rem;margin-bottom:.85rem;font-weight:500;font-size:.88rem;color:var(--sn-muted)}input,select,textarea{background:var(--sn-surface-inset);border:1px solid var(--sn-border);border-radius:var(--sn-radius-sm);color:var(--sn-text);padding:.6rem .85rem;font:inherit;transition:border-color var(--sn-transition),box-shadow var(--sn-transition),background var(--sn-transition)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--sn-accent);box-shadow:0 0 0 3px var(--sn-accent-soft)}.error{color:var(--sn-danger);font-weight:500}.success{color:var(--sn-success);font-weight:500}.muted{color:var(--sn-muted)}.kv{display:grid;grid-template-columns:150px 1fr;gap:.55rem 1rem}.kv dt{color:var(--sn-muted);font-weight:500;font-size:.9rem}.kv dd{margin:0;font-weight:500}.code-block{background:var(--sn-bg-subtle);border:1px solid var(--sn-border);border-radius:var(--sn-radius-sm);padding:1rem;overflow:auto;max-height:400px;font-size:.8rem;color:var(--sn-text-secondary)}.code-textarea{width:100%;min-height:320px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.82rem;line-height:1.45;padding:1rem;border:1px solid var(--sn-border);border-radius:var(--sn-radius-sm);background:var(--sn-bg-subtle);color:var(--sn-text-secondary);resize:vertical}.import-select-row{display:flex;align-items:center;gap:.65rem;margin-bottom:.5rem;cursor:pointer}.import-select-row .badge{margin-left:.5rem}.panel-footer-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--sn-border)}.checkbox-inline{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer}.field-block{display:block;margin-bottom:1rem}.field-block .field-label{display:block;font-weight:600;margin-bottom:.5rem}.badge{display:inline-block;padding:.2rem .55rem;border-radius:999px;font-size:.72rem;font-weight:600;margin-right:.35rem;background:var(--sn-bg-subtle);color:var(--sn-muted)}.badge.up{background:var(--sn-success-soft);color:var(--sn-success)}.badge.down{background:var(--sn-danger-soft);color:var(--sn-danger)}.badge.warn{background:var(--sn-warn-soft);color:var(--sn-warn)}.login-page{min-height:100vh;display:grid;place-items:center;background:radial-gradient(ellipse 70% 50% at 30% -10%,rgba(14,165,233,.14),transparent 55%),radial-gradient(ellipse 50% 40% at 90% 80%,rgba(20,184,166,.1),transparent 50%),var(--sn-bg);padding:1.5rem}.login-card{position:relative;width:min(420px,92vw);background:var(--sn-surface);border:1px solid var(--sn-border);border-radius:var(--sn-radius-xl);padding:2.5rem;overflow:hidden;box-shadow:var(--sn-shadow-md)}.login-glow{position:absolute;inset:-60% auto auto -20%;width:260px;height:260px;background:radial-gradient(circle,rgba(14,165,233,.15),transparent 70%);pointer-events:none;animation:loginGlow 5s ease-in-out infinite}@keyframes loginGlow{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.login-card h1{margin:0 0 .35rem;font-weight:800;letter-spacing:-.03em}.login-card form{display:flex;flex-direction:column;gap:1rem;margin-top:1.75rem}.login-card label{display:flex;flex-direction:column;gap:.4rem;font-size:.88rem;color:var(--sn-muted);font-weight:500}.wizard-steps{display:flex;gap:.65rem;margin-bottom:1.25rem;flex-wrap:wrap}.step{padding:.4rem .85rem;border-radius:999px;background:var(--sn-bg-subtle);color:var(--sn-muted);font-size:.82rem;font-weight:600;border:1px solid var(--sn-border-light);transition:background var(--sn-transition),color var(--sn-transition)}.step.active{background:var(--sn-accent-soft);color:var(--sn-accent-hover);border-color:#0ea5e940}.btn-row{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:1rem}.file-list{max-height:200px;overflow:auto;font-size:.85rem;color:var(--sn-muted)}.warn-text{color:var(--sn-warn);font-weight:500}.info-box h2{margin:0 0 .75rem;font-size:1rem;color:var(--sn-text)}.info-box p{margin:0 0 .65rem;line-height:1.55;color:var(--sn-text-secondary)}.info-box p:last-child{margin-bottom:0}.info-box code{font-size:.85em;background:var(--sn-surface-inset);border:1px solid var(--sn-border);padding:.1rem .35rem;border-radius:4px}.path-table{margin-top:1rem}.path-table .path-role{font-weight:600;white-space:nowrap}.path-table code{font-size:.82rem;word-break:break-all}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:grid;place-items:center;padding:1rem;background:var(--sn-modal-overlay);animation:modalFadeIn .2s ease}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.modal-dialog{width:min(1180px,98vw);height:min(94vh,960px);max-width:none;max-height:min(94vh,960px);display:flex;flex-direction:column;background:var(--sn-surface);border:1px solid var(--sn-border);border-radius:var(--sn-radius-lg);box-shadow:var(--sn-shadow-md);animation:modalSlideUp .25s cubic-bezier(.22,1,.36,1)}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:none}}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.1rem 1.25rem;border-bottom:1px solid var(--sn-border)}.modal-header h2{margin:0;font-size:1.1rem;font-weight:700;color:var(--sn-text)}.modal-header-text{min-width:0}.modal-subtitle{margin:.25rem 0 0;font-size:.85rem;color:var(--sn-muted);word-break:break-word}.modal-close{font-size:1.4rem;line-height:1;padding:.25rem .5rem}.modal-body{padding:1.25rem;overflow-y:auto;flex:1;min-height:0}.modal-footer{display:flex;justify-content:flex-end;gap:.65rem;padding:1rem 1.25rem;border-top:1px solid var(--sn-border)}.modal-dialog{font-size:.8125rem;line-height:1.4}.modal-dialog .modal-header{gap:.6rem;padding:.65rem .9rem}.modal-dialog .modal-header h2{font-size:.92rem;font-weight:700}.modal-dialog .modal-subtitle{margin-top:.15rem;font-size:.75rem}.modal-dialog .modal-close{font-size:1.15rem;padding:.15rem .4rem}.modal-dialog .modal-body{padding:.7rem .85rem}.modal-dialog .modal-footer{gap:.45rem;padding:.55rem .85rem}.modal-dialog .btn-primary,.modal-dialog .btn-secondary,.modal-dialog .btn-ghost{padding:.42rem .75rem;font-size:.78rem}.modal-dialog .btn-sm{font-size:.72rem;padding:.28rem .5rem}.modal-dialog .form-inline{gap:.45rem}.modal-dialog .form-stack label{gap:.28rem;margin-bottom:.55rem;font-size:.78rem}.modal-dialog input,.modal-dialog select,.modal-dialog textarea,.modal-dialog .input-soft,.modal-dialog .form-field-block input,.modal-dialog .form-field-block select,.modal-dialog .form-field-block textarea{padding:.4rem .55rem;font-size:.8125rem}.modal-dialog .form-field-block{gap:.22rem;margin-bottom:.5rem}.modal-dialog .form-field-label{font-size:.76rem}.modal-dialog .form-field-label-row{gap:.3rem}.modal-dialog .nginx-directive-tag{font-size:.64rem;padding:.05rem .3rem}.modal-dialog .section-intro{margin-bottom:.65rem;font-size:.76rem;line-height:1.4;padding:.45rem .6rem}.modal-dialog .field-hint,.modal-dialog .field-inline-hint{font-size:.7rem;margin-top:.2rem}.modal-dialog .field-example{font-size:.68rem}.modal-dialog .form-row-2{gap:.5rem}.modal-dialog .modal-subsection{margin-top:.35rem;padding-top:.5rem}.modal-dialog .modal-subsection h3{margin-bottom:.45rem;font-size:.78rem}.modal-dialog .modal-subsection-hint{margin-bottom:.5rem;font-size:.74rem}.modal-dialog .detail-card{padding:.5rem .6rem;margin-bottom:.4rem}.modal-dialog .detail-card-title{font-size:.74rem;margin-bottom:.25rem}.modal-dialog .detail-kv{font-size:.76rem;gap:.2rem .5rem}.modal-dialog .modal-loading{padding:1.25rem;font-size:.78rem}.modal-dialog .preset-chips{gap:.35rem;margin-bottom:.5rem}.modal-dialog .preset-chips button{font-size:.72rem}.modal-dialog .field-group-title{margin:.35rem 0 .45rem;font-size:.7rem}.modal-dialog .site-edit-summary{gap:.45rem .85rem;padding:.5rem .65rem;margin-bottom:.65rem}.modal-dialog .site-edit-summary-label{font-size:.64rem;margin-bottom:.1rem}.modal-dialog .site-edit-summary-value{font-size:.78rem}.modal-dialog .site-status-badge{font-size:.68rem;padding:.15rem .42rem}.modal-dialog .site-edit-tabs{grid-template-columns:repeat(auto-fit,minmax(92px,1fr));gap:.35rem;margin-bottom:.65rem}.modal-dialog .site-edit-tab{gap:.08rem;padding:.42rem .5rem}.modal-dialog .site-edit-tab.active:after{left:.5rem;right:.5rem}.modal-dialog .site-edit-tab-label{font-size:.76rem}.modal-dialog .site-edit-tab-desc{font-size:.64rem;line-height:1.25}.modal-dialog .site-tab-section h3{font-size:.82rem;margin-bottom:.35rem}.modal-dialog .site-toggle-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.45rem;margin-bottom:.65rem}.modal-dialog .site-toggle-card{gap:.45rem;padding:.5rem .6rem}.modal-dialog .site-toggle-card-title{font-size:.78rem;gap:.3rem}.modal-dialog .site-toggle-card-desc{font-size:.7rem;line-height:1.3}.modal-dialog .site-route-card{margin-bottom:.65rem}.modal-dialog .route-card-header{gap:.5rem;padding:.5rem .65rem}.modal-dialog .route-index-badge{width:1.35rem;height:1.35rem;font-size:.68rem}.modal-dialog .route-path-chip{font-size:.76rem;padding:.12rem .38rem}.modal-dialog .route-arrow{font-size:.78rem}.modal-dialog .route-target-chip{font-size:.72rem;padding:.1rem .42rem}.modal-dialog .route-card-section{padding:.5rem .65rem .15rem}.modal-dialog .route-card-section+.route-card-section{margin-top:.15rem;padding-top:.5rem}.modal-dialog .route-section-title{margin-bottom:.4rem;font-size:.64rem}.modal-dialog .route-fields-grid{gap:.45rem .65rem}.modal-dialog .route-fields-grid .form-field-block,.modal-dialog .site-route-card .form-field-block{margin-bottom:.4rem}.modal-dialog .switch-row{gap:.65rem;padding:.45rem .6rem;margin-bottom:.45rem}.modal-dialog .switch-row-title{font-size:.76rem}.modal-dialog .switch-row-desc{font-size:.68rem}.modal-dialog .switch{width:2.15rem;height:1.25rem}.modal-dialog .switch-slider:before{width:.95rem;height:.95rem}.modal-dialog .route-subheading{font-size:.74rem;margin:.45rem 0 .25rem}.modal-dialog .route-subhint{font-size:.72rem;margin-bottom:.45rem}.modal-dialog .route-advanced summary{padding:.45rem .65rem;font-size:.74rem}.modal-dialog .route-advanced-body{padding:.4rem .65rem .55rem}.modal-dialog .route-header-pair{gap:.35rem}.modal-dialog .route-upstream-preview{margin-top:.45rem;padding:.5rem .6rem}.modal-dialog .site-feature-save-row{margin-top:.65rem;padding-top:.5rem}.modal-dialog .cert-modal-busy{gap:.5rem;padding:.5rem .65rem}.modal-dialog .cert-modal-busy p,.modal-dialog .cert-modal-msg{font-size:.76rem}.modal-dialog .cert-modal-msg{padding:.45rem .6rem}.modal-dialog .nginx-config-editor{min-height:16rem;font-size:.72rem;line-height:1.4}.modal-dialog .config-preview,.modal-dialog .snippet-preview{font-size:.7rem;padding:.45rem}.modal-dialog .header-chip{font-size:.72rem;padding:.25rem .38rem}.modal-dialog .muted,.modal-dialog .warn-text,.modal-dialog .error{font-size:.76rem}.modal-dialog h4{font-size:.78rem;margin:.5rem 0 .35rem}.modal-dialog .panel-nested,.modal-dialog .upstream-settings-section,.modal-dialog .upstream-usage-section{padding:.5rem .6rem}.modal-dialog .upstream-summary-row{font-size:.76rem}.modal-dialog .upstream-live-health-label{font-size:.68rem}.modal-dialog .server-list{gap:.3rem}.modal-dialog .server-list li{font-size:.76rem}.modal-dialog .site-bot-rate-section h4,.modal-dialog .site-bot-exempt-note,.modal-dialog .tiles-hint{font-size:.72rem}[data-theme=dark] .modal-header{border-bottom-color:var(--sn-border)}[data-theme=dark] .site-edit-summary-label{color:var(--sn-muted-light)}[data-theme=dark] .site-toggle-card{background:var(--sn-surface-inset);border-color:var(--sn-border)}[data-theme=dark] .form-field-label{color:var(--sn-text-secondary)}[data-theme=dark] .nginx-directive-tag{background:var(--sn-bg);border-color:var(--sn-border);color:var(--sn-muted-light)}[data-theme=dark] .panel.info-box{background:var(--sn-surface-2);border-color:var(--sn-border)}[data-theme=dark] .upstream-settings-section,[data-theme=dark] .upstream-usage-section,[data-theme=dark] .panel-nested,[data-theme=dark] .backend-picker-item{background:var(--sn-surface-inset);border-color:var(--sn-border)}.checkbox-label{flex-direction:row!important;align-items:center;gap:.55rem!important}.checkbox-label input[type=checkbox]{width:auto;margin:0}.detail-card{background:var(--sn-bg);border:1px solid var(--sn-border-light);border-radius:var(--sn-radius);padding:.75rem .85rem;margin-bottom:.55rem}.detail-card-title{font-size:.82rem;font-weight:600;color:var(--sn-text);margin-bottom:.35rem}.detail-kv{display:grid;grid-template-columns:8rem 1fr;gap:.25rem .75rem;font-size:.85rem;margin:0}.detail-kv dt{color:var(--sn-muted);margin:0}.detail-kv dd{margin:0;word-break:break-word}.header-chip-list{display:flex;flex-direction:column;gap:.35rem;margin:0;padding:0;list-style:none}.header-chip{font-size:.82rem;padding:.35rem .5rem;background:var(--sn-surface);border:1px solid var(--sn-border-light);border-radius:6px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.snippet-preview{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.78rem;white-space:pre-wrap;background:var(--sn-bg);border:1px solid var(--sn-border-light);border-radius:var(--sn-radius);padding:.65rem;margin:0;max-height:8rem;overflow:auto}.modal-loading{padding:2rem;text-align:center;color:var(--sn-muted)}.cert-edit-modal-body{display:flex;flex-direction:column;gap:.75rem;min-height:0}.cert-modal-busy{display:flex;align-items:center;gap:.75rem;padding:.85rem 1rem;border-radius:var(--sn-radius);border:1px solid color-mix(in srgb,var(--sn-accent) 35%,var(--sn-border));background:var(--sn-accent-soft);color:var(--sn-text)}.cert-modal-busy p{margin:0;font-size:.88rem}.cert-modal-spinner{width:1.1rem;height:1.1rem;border:2px solid color-mix(in srgb,var(--sn-accent) 25%,transparent);border-top-color:var(--sn-accent);border-radius:50%;animation:certModalSpin .8s linear infinite;flex-shrink:0}@keyframes certModalSpin{to{transform:rotate(360deg)}}.cert-modal-msg{margin:0;padding:.65rem .85rem;border-radius:var(--sn-radius);font-size:.88rem}.cert-modal-msg.ok{background:var(--sn-success-soft);border:1px solid color-mix(in srgb,var(--sn-success) 35%,transparent);color:#047857}.cert-modal-msg.error{background:color-mix(in srgb,var(--sn-danger) 10%,var(--sn-surface));border:1px solid color-mix(in srgb,var(--sn-danger) 35%,transparent);color:#b91c1c}.config-preview{max-height:28rem;overflow:auto;font-size:.78rem}.nginx-config-editor{width:100%;min-height:22rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;font-size:.8rem;line-height:1.45;-moz-tab-size:4;tab-size:4;padding:.85rem 1rem;border-radius:var(--radius-md, 8px);border:1px solid var(--border-subtle, #2a3142);background:#0f1419;color:#c9d1d9;resize:vertical}.nginx-config-editor:focus{outline:2px solid var(--accent, #4f8cff);outline-offset:1px}.site-config-toolbar{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-bottom:.75rem}.site-config-dirty-badge{font-size:.78rem;color:var(--warn, #e6a23c)}.site-config-warnings{margin:0 0 .75rem;padding-left:1.1rem;font-size:.85rem;color:var(--warn, #e6a23c)}.btn-row{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.inline-form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.5rem;align-items:end}.btn-icon{padding:.25rem .5rem;min-width:auto}.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.modal-subsection{margin-top:.5rem;padding-top:.75rem;border-top:1px solid var(--sn-border-light)}.modal-subsection h3{margin:0 0 .65rem;font-size:.88rem;color:var(--sn-muted);font-weight:600}.server-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.45rem}.server-list li{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem}.chart-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:1rem;margin-bottom:1rem}.chart-panel{background:var(--sn-surface);border:1px solid var(--sn-border);border-radius:var(--sn-radius-lg);padding:1.25rem;box-shadow:var(--sn-shadow-card)}.chart-panel h2{margin:0 0 1rem;font-size:.92rem;color:var(--sn-muted);font-weight:600}.table-scroll{overflow-x:auto}.ua-cell,.path-cell{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.85rem}.field-example{margin:.25rem 0 0;font-size:.78rem;color:var(--sn-muted-light);font-family:ui-monospace,monospace}.field-hint{margin:.35rem 0 0;font-size:.82rem;line-height:1.45;color:var(--sn-muted)}.field-hint-details{margin:.35rem 0 0;font-size:.8rem}.field-hint-details summary{cursor:pointer;color:var(--sn-accent, #0ea5e9);font-weight:500;-webkit-user-select:none;user-select:none;list-style:none}.field-hint-details summary::-webkit-details-marker{display:none}.field-hint-details summary:before{content:"▸ ";display:inline-block;transition:transform .15s}.field-hint-details[open] summary:before{transform:rotate(90deg)}.field-hint-details p{margin:.4rem 0 0;padding:.55rem .65rem;line-height:1.45;color:var(--sn-muted);background:var(--sn-surface-inset);border:1px solid var(--sn-border);border-radius:var(--sn-radius-sm)}.field-inline-hint{margin:.35rem 0 0;font-size:.78rem;color:var(--sn-muted-light);line-height:1.35}.input-soft,.site-route-card .form-field-block input,.site-route-card .form-field-block select,.site-route-card .form-field-block textarea{background:var(--sn-surface-inset);border:1px solid var(--sn-border);border-radius:var(--sn-radius-sm);padding:.55rem .7rem;transition:border-color .15s,box-shadow .15s,background .15s}.input-soft:focus,.site-route-card .form-field-block input:focus,.site-route-card .form-field-block select:focus,.site-route-card .form-field-block textarea:focus{outline:none;border-color:var(--sn-accent);background:var(--sn-surface-inset);box-shadow:0 0 0 3px var(--sn-accent-soft)}.form-field-block{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.85rem}.form-field-block input,.form-field-block select,.form-field-block textarea{width:100%}.form-field-label{font-weight:600;font-size:.9rem;color:var(--sn-text)}.form-field-label-row{display:flex;flex-wrap:wrap;align-items:center;gap:.45rem}.nginx-directive-tag{font-size:.72rem;font-weight:500;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--sn-muted);background:var(--sn-bg);border:1px solid var(--sn-border-light);border-radius:4px;padding:.1rem .4rem}.section-intro{margin:0 0 1rem;font-size:.88rem;line-height:1.5;color:var(--sn-muted);padding:.65rem .85rem;background:var(--sn-surface-2);border-radius:var(--sn-radius-sm);border:1px solid var(--sn-border);border-left:3px solid var(--sn-primary)}.preset-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.preset-chips button{font-size:.8rem}.location-card-title{font-weight:600;margin:0 0 .75rem;font-size:.95rem;color:var(--sn-text)}.site-edit-summary{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:.75rem 1.25rem;padding:.85rem 1rem;margin-bottom:1rem;background:var(--sn-surface-2);border:1px solid var(--sn-border);border-radius:var(--sn-radius-lg)}.site-edit-summary-label{display:block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--sn-muted);margin-bottom:.2rem}.site-edit-summary-value{font-size:.92rem;font-weight:600;color:var(--sn-text);word-break:break-word}.site-edit-summary-badges{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center}.site-status-badge{font-size:.78rem;font-weight:600;padding:.25rem .55rem;border-radius:999px;background:var(--sn-bg);border:1px solid var(--sn-border-light);color:var(--sn-muted)}.field-hint-details{display:none}.site-status-badge-btn{cursor:pointer;font:inherit;line-height:inherit;transition:opacity .15s ease,border-color .15s ease,background .15s ease}.site-status-badge-btn:hover{opacity:.88;border-color:color-mix(in srgb,var(--sn-accent) 45%,transparent)}.site-status-badge.on{background:var(--sn-accent-soft);border-color:color-mix(in srgb,var(--sn-accent) 35%,transparent);color:var(--sn-primary)}.modal-dialog:has(.site-edit-modal-body) .modal-body{display:flex;flex-direction:column;overflow:hidden}.site-edit-modal-body{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.site-edit-modal-loading{display:flex;flex:1;align-items:center;justify-content:center;margin:0}.site-edit-modal-body .site-edit-summary,.site-edit-modal-body .site-edit-tabs{flex-shrink:0}.site-edit-modal-body .site-feature-modal-form{margin-top:0}.site-feature-save-row{margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--sn-border-light);flex-shrink:0}.site-edit-modal-body .site-edit-form{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.site-edit-tab-panel{flex:1;min-height:0;overflow-y:auto;padding-right:.15rem}.site-edit-tabs{display:grid;grid-template-columns:repeat(auto-fit,minmax(118px,1fr));gap:.5rem;margin-bottom:1.15rem}.site-edit-tab{display:flex;flex-direction:column;align-items:flex-start;gap:.15rem;padding:.65rem .75rem;border:1px solid var(--sn-border);border-radius:var(--sn-radius);background:var(--sn-surface-inset);cursor:pointer;text-align:left;transition:border-color .15s,box-shadow .15s,background .15s}.site-edit-tab:hover{border-color:color-mix(in srgb,var(--sn-border) 70%,var(--sn-accent) 30%);background:var(--sn-surface-2)}.site-edit-tab.active{border-color:var(--sn-accent);box-shadow:var(--sn-shadow-sm);background:var(--sn-surface);position:relative}.site-edit-tab.active:after{content:"";position:absolute;left:.75rem;right:.75rem;top:0;height:2px;border-radius:0 0 2px 2px;background:var(--sn-gradient, linear-gradient(135deg, #0ea5e9, #14b8a6))}.site-edit-tab-label{font-size:.88rem;font-weight:700;color:var(--sn-text)}.site-edit-tab-desc{font-size:.72rem;color:var(--sn-muted);line-height:1.3}.site-edit-form{margin-top:0}.site-tab-section{margin-top:0!important;padding-top:0!important;border-top:none!important}.site-tab-section h3{font-size:1rem;color:var(--sn-text);margin-bottom:.5rem}.field-group-title{margin:.5rem 0 .65rem;font-size:.82rem;font-weight:700;color:var(--sn-muted);text-transform:uppercase;letter-spacing:.03em}.site-toggle-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:.65rem;margin-bottom:1rem}.site-toggle-card{display:flex;gap:.65rem;align-items:flex-start;padding:.85rem 1rem;border:1px solid var(--sn-border-light);border-radius:var(--sn-radius-lg);background:var(--sn-surface);cursor:pointer;transition:border-color .15s,box-shadow .15s}.site-toggle-card:hover{border-color:var(--sn-border)}.site-toggle-card.active{border-color:var(--sn-primary);box-shadow:0 0 0 1px var(--sn-primary);background:var(--sn-accent-soft)}.site-toggle-card input[type=checkbox]{margin-top:.2rem;flex-shrink:0}.site-toggle-card-body{display:flex;flex-direction:column;gap:.25rem;min-width:0}.site-toggle-card-title{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem;font-size:.9rem;font-weight:600;color:var(--sn-text)}.site-toggle-card-desc{font-size:.82rem;line-height:1.4;color:var(--sn-muted)}.site-route-card{padding:0;margin-bottom:1rem;overflow:hidden;border:1px solid var(--sn-border);border-radius:var(--sn-radius-lg);background:var(--sn-surface);box-shadow:var(--sn-shadow-card)}.site-route-card:before{content:"";display:block;height:3px;background:var(--sn-gradient, linear-gradient(135deg, #0ea5e9, #14b8a6))}.route-card-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.85rem 1rem;background:var(--sn-surface-2);border-bottom:1px solid var(--sn-border)}.route-card-header-main{display:flex;align-items:center;gap:.65rem;min-width:0}.route-index-badge{flex-shrink:0;width:1.65rem;height:1.65rem;display:grid;place-items:center;font-size:.78rem;font-weight:700;color:#fff;background:var(--sn-gradient, linear-gradient(135deg, #0ea5e9, #14b8a6));border-radius:8px}.route-card-headline{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem;min-width:0}.route-path-chip{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.88rem;font-weight:600;color:var(--sn-text);background:var(--sn-surface);border:1px solid var(--sn-border);border-radius:6px;padding:.2rem .5rem}.route-arrow{color:var(--sn-muted-light);font-size:.9rem}.route-target-chip{font-size:.82rem;font-weight:600;color:var(--sn-accent-hover, #0284c7);background:var(--sn-accent-soft, rgba(14, 165, 233, .1));border-radius:999px;padding:.15rem .55rem;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.route-target-chip.muted{color:var(--sn-muted);background:var(--sn-bg-subtle);font-weight:500}.route-delete-btn{flex-shrink:0;font-size:.82rem;color:var(--sn-danger, #ef4444)}.route-delete-btn:hover{background:var(--sn-danger-soft, rgba(239, 68, 68, .12))}.route-card-section{padding:.85rem 1rem .25rem}.route-card-section+.route-card-section{border-top:1px dashed var(--sn-border-light);margin-top:.25rem;padding-top:.85rem}.route-section-title{margin:0 0 .65rem;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--sn-muted)}.route-fields-grid{display:grid;grid-template-columns:1fr 1fr;gap:.65rem 1rem}.route-fields-grid .form-field-block{margin-bottom:.5rem}.site-route-card .form-field-block{margin-bottom:.65rem}.switch-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.65rem .85rem;margin-bottom:.65rem;border:1px solid var(--sn-border);border-radius:var(--sn-radius);background:var(--sn-surface-inset);cursor:pointer;transition:border-color .15s,background .15s}.switch-row:hover{border-color:var(--sn-border)}.switch-row.active{border-color:color-mix(in srgb,var(--sn-accent) 35%,var(--sn-border));background:var(--sn-accent-soft)}.switch-row-text{display:flex;flex-direction:column;gap:.15rem;min-width:0}.switch-row-title{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem;font-size:.88rem;font-weight:600;color:var(--sn-text)}.switch-row-desc{font-size:.78rem;color:var(--sn-muted);line-height:1.35}.switch{position:relative;flex-shrink:0;width:2.5rem;height:1.45rem}.switch input{position:absolute;opacity:0;width:0;height:0}.switch-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--sn-border, #cbd5e1);border-radius:999px;transition:background .2s}.switch-slider:before{content:"";position:absolute;width:1.1rem;height:1.1rem;left:.18rem;top:50%;transform:translateY(-50%);background:var(--sn-surface);border-radius:50%;box-shadow:0 1px 3px #0f172a26;transition:transform .2s cubic-bezier(.34,1.56,.64,1)}.switch input:checked+.switch-slider{background:var(--sn-accent, #0ea5e9)}.switch input:checked+.switch-slider:before{transform:translate(1.05rem,-50%)}.switch input:focus-visible+.switch-slider{box-shadow:0 0 0 3px var(--sn-accent-soft)}.route-advanced{border-top:1px solid var(--sn-border-light);margin-top:.35rem}.route-advanced summary{padding:.75rem 1rem;font-size:.85rem;font-weight:600;color:var(--sn-muted);cursor:pointer;-webkit-user-select:none;user-select:none;list-style:none;transition:color .15s,background .15s}.route-advanced summary::-webkit-details-marker{display:none}.route-advanced summary:before{content:"▸ ";display:inline-block;transition:transform .15s}.route-advanced[open] summary:before{transform:rotate(90deg)}.route-advanced[open] summary{color:var(--sn-text);background:var(--sn-bg-subtle)}.route-advanced-body{padding:0 1rem 1rem}.route-header-pair{display:grid;grid-template-columns:1fr 1fr auto;gap:.5rem;align-items:start;margin-bottom:.35rem}.route-header-remove{margin-top:1.65rem}.route-add-btn{width:100%;margin-top:.25rem}.btn-sm{font-size:.82rem;padding:.35rem .65rem}.route-subheading{font-size:.85rem;font-weight:600;margin:.75rem 0 .35rem;color:var(--sn-text)}.route-subhint{font-size:.82rem;margin:0 0 .65rem}@media (max-width: 640px){.route-fields-grid,.route-header-pair{grid-template-columns:1fr}.route-header-remove{margin-top:0}}.route-card-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.site-create-panel{margin-bottom:1rem;padding:.9rem 1.1rem;background:linear-gradient(180deg,var(--sn-bg-subtle) 0%,var(--sn-surface) 100%);border:1px solid var(--sn-border);border-radius:var(--sn-radius-lg);box-shadow:var(--sn-shadow-xs)}.site-create-form{display:grid;grid-template-columns:minmax(160px,1fr) minmax(200px,1.35fr) auto;gap:.75rem 1rem;align-items:end}.site-create-field{display:flex;flex-direction:column;gap:.35rem;min-width:0;margin:0}.site-create-label{display:inline-flex;align-items:center;gap:.4rem;font-size:.68rem;font-weight:700;color:var(--sn-muted);text-transform:uppercase;letter-spacing:.06em}.site-create-input{width:100%;min-height:2.45rem;padding:.45rem .75rem;font-size:.88rem;font-weight:500;color:var(--sn-text);background:var(--sn-surface);border:1px solid var(--sn-border);border-radius:var(--sn-radius);box-shadow:inset 0 1px 2px #0f172a0a;transition:border-color .15s ease,box-shadow .15s ease}.site-create-input::placeholder{color:color-mix(in srgb,var(--sn-muted) 72%,transparent);font-weight:400}.site-create-input:focus{outline:none;border-color:var(--sn-accent);box-shadow:0 0 0 3px var(--sn-accent-soft)}.site-create-submit{min-height:2.45rem;padding-inline:1.35rem;white-space:nowrap}.page-subtitle{margin:.25rem 0 0;font-size:.9rem;color:var(--sn-muted)}.compare-summary-panel{margin-bottom:1rem}.compare-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.65rem;margin-bottom:1rem}.compare-summary-card{padding:.85rem 1rem;border-radius:var(--sn-radius);border:1px solid var(--sn-border-light);background:var(--sn-bg-subtle);display:flex;flex-direction:column;gap:.15rem}.compare-summary-card.same{background:var(--sn-success-soft);border-color:#10b98140}.compare-summary-card.changed{background:var(--sn-warn-soft);border-color:#f59e0b4d}.compare-summary-card.new{background:var(--sn-accent-soft);border-color:#0ea5e94d}.compare-summary-card.native-only{background:var(--sn-teal-soft);border-color:#14b8a640}.compare-summary-value{font-size:1.35rem;font-weight:800;color:var(--sn-text);line-height:1}.compare-summary-label{font-size:.78rem;color:var(--sn-muted)}.compare-meta{margin-bottom:.75rem}.compare-legend{display:flex;flex-wrap:wrap;gap:1rem;margin:0;font-size:.82rem}.legend-item{display:inline-flex;align-items:center;gap:.4rem}.legend-swatch{width:.75rem;height:.75rem;border-radius:3px;display:inline-block}.legend-swatch.remove{background:#fecaca;border:1px solid #f87171}.legend-swatch.add{background:#bbf7d0;border:1px solid #4ade80}.compare-toolbar{display:flex;flex-wrap:wrap;justify-content:space-between;gap:.75rem;margin-bottom:.85rem}.compare-filters,.compare-view-toggle{display:flex;flex-wrap:wrap;gap:.35rem}.compare-filter.active,.compare-view-toggle .active{background:var(--sn-accent-soft);border-color:var(--sn-accent);color:var(--sn-accent-hover)}.compare-list{display:flex;flex-direction:column;gap:.65rem}.compare-item{border:1px solid var(--sn-border);border-radius:var(--sn-radius-lg);background:var(--sn-surface);box-shadow:var(--sn-shadow-xs);overflow:hidden}.compare-item.open{box-shadow:var(--sn-shadow-card)}.compare-item-header{width:100%;display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.85rem 1rem;border:none;background:transparent;cursor:pointer;text-align:left}.compare-item-header:hover{background:var(--sn-bg-subtle)}.compare-item-main{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;min-width:0}.compare-domain{font-size:.95rem;color:var(--sn-text)}.compare-file-tag{font-size:.72rem;font-family:ui-monospace,monospace;color:var(--sn-muted);background:var(--sn-bg-subtle);padding:.15rem .45rem;border-radius:4px}.compare-item-stats{display:flex;align-items:center;gap:.45rem;flex-shrink:0}.compare-stat{font-size:.78rem;font-weight:700;padding:.15rem .4rem;border-radius:4px}.compare-stat.remove{background:#fecaca;color:#b91c1c}.compare-stat.add{background:#bbf7d0;color:#15803d}.compare-chevron{color:var(--sn-muted);font-size:.85rem}.compare-item-body{padding:0 1rem 1rem;border-top:1px solid var(--sn-border-light)}.compare-item-hint{margin:.75rem 0 .5rem;font-size:.85rem}.compare-item-meta{margin-bottom:.75rem}.compare-badge{font-size:.72rem;font-weight:700;padding:.2rem .5rem;border-radius:999px;white-space:nowrap}.compare-badge.same{background:var(--sn-success-soft);color:#047857}.compare-badge.changed{background:var(--sn-warn-soft);color:#b45309}.compare-badge.new{background:var(--sn-accent-soft);color:#0369a1}.compare-badge.native-only{background:var(--sn-teal-soft);color:#0f766e}.compare-badge.disabled{background:var(--sn-bg-subtle);color:var(--sn-muted)}.compare-badge.empty{background:var(--sn-bg-subtle);color:var(--sn-muted-light)}.compare-risk{font-size:.68rem;font-weight:700;padding:.15rem .45rem;border-radius:999px;white-space:nowrap}.compare-risk.low{background:#ecfdf5;color:#047857}.compare-risk.medium{background:var(--sn-warn-soft);color:#b45309}.compare-risk.high{background:#fef2f2;color:#b91c1c}.compare-issues{margin:0 0 .75rem;padding-left:1.1rem;font-size:.85rem;color:var(--sn-muted)}.compare-issues li{margin-bottom:.25rem}.compare-diff-pre{margin:0;padding:.75rem;border-radius:var(--sn-radius);border:1px solid var(--sn-code-border);background:var(--sn-code-bg);color:var(--sn-code-fg);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.76rem;line-height:1.45;overflow:auto;max-height:28rem}.compare-split{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.compare-split-title{margin:0 0 .35rem;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--sn-muted)}.diff-line{white-space:pre-wrap;word-break:break-word;padding:0 .25rem}.diff-line.add{background:var(--sn-diff-add-bg);color:var(--sn-diff-add-fg)}.diff-line.remove{background:var(--sn-diff-remove-bg);color:var(--sn-diff-remove-fg)}.diff-line.same{color:var(--sn-diff-same-fg)}.diff-prefix{display:inline-block;width:1rem;opacity:.75}.compare-empty-diff{font-size:.85rem;margin:.5rem 0}.upstream-filter-orphans{margin-left:auto;white-space:nowrap}.upstream-bindings-cell{display:flex;flex-direction:column;gap:.25rem;max-width:18rem}.upstream-binding-chip{display:inline-block;font-size:.78rem;padding:.15rem .45rem;border-radius:999px;background:var(--sn-accent-soft);color:#0369a1;width:fit-content}.upstream-binding-chip.docker{background:var(--sn-teal-soft);color:#0f766e}.upstream-server-chip{display:inline-block;font-size:.78rem;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;margin-right:.35rem}.upstream-servers-cell{font-size:.82rem;max-width:12rem}.upstream-settings-cell{font-size:.82rem;max-width:16rem;vertical-align:top}.upstream-settings-section{background:var(--sn-bg-subtle);border:1px solid var(--sn-border-light);border-radius:var(--sn-radius);padding:.85rem 1rem}.upstream-orphan-badge{margin-left:.4rem;vertical-align:middle}.upstream-usage-section{background:var(--sn-bg-subtle);border:1px solid var(--sn-border-light);border-radius:var(--sn-radius);padding:.85rem 1rem}.upstream-usage-list{margin:.35rem 0 0;padding-left:1.1rem}.upstream-usage-list li{margin-bottom:.25rem}.upstream-usage-link{color:var(--sn-accent);text-decoration:none;font-weight:600}.upstream-usage-link:hover{text-decoration:underline}.upstream-usage-hosts{font-size:.82rem}.upstream-card-list{display:flex;flex-direction:column;gap:1rem}.upstream-card{padding:1rem 1.15rem}.upstream-card-header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:.75rem;margin-bottom:.85rem}.upstream-card-title{margin:0;font-size:1.05rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.upstream-card-subtitle{margin:.25rem 0 0;font-size:.82rem}.upstream-card-actions{display:flex;flex-wrap:wrap;gap:.35rem}.upstream-summary{border-top:1px solid var(--sn-border-light);padding-top:.75rem}.upstream-summary-compact{border-top:none;padding-top:0}.upstream-summary-grid{margin:0;display:flex;flex-direction:column;gap:.55rem}.upstream-summary-row{display:grid;grid-template-columns:7.5rem 1fr;gap:.5rem 1rem;align-items:start}.upstream-summary-row dt{margin:0;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--sn-muted)}.upstream-summary-row dd{margin:0;font-size:.88rem}.upstream-summary-servers{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.3rem}.upstream-summary-servers li{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem}.upstream-server-count,.upstream-thresholds,.upstream-target-type{font-size:.8rem}.upstream-summary-edit-link{display:inline-block;margin-top:.65rem;font-size:.85rem;color:var(--sn-accent);text-decoration:none;font-weight:600}.upstream-summary-edit-link:hover{text-decoration:underline}.upstream-live-health{margin-top:.75rem;padding-top:.65rem;border-top:1px dashed var(--sn-border-light);display:flex;flex-wrap:wrap;gap:.35rem;align-items:center}.upstream-live-health-label{font-size:.78rem;font-weight:600;color:var(--sn-muted)}.upstream-server-row{align-items:end}.modal-subsection-hint{margin:-.25rem 0 .75rem;font-size:.85rem}.route-upstream-preview{margin-top:.65rem;padding:.75rem .85rem;border-radius:var(--sn-radius);background:var(--sn-bg-subtle);border:1px solid var(--sn-border-light)}.panel-nested{background:var(--sn-bg-subtle)}.docker-net-filter{font-size:.85rem;white-space:nowrap}@media (max-width: 900px){.upstream-summary-row{grid-template-columns:1fr;gap:.2rem}}@media (max-width: 900px){.compare-split{grid-template-columns:1fr}}@media (max-width: 900px){.site-edit-tabs{grid-template-columns:repeat(2,1fr)}.site-create-form{grid-template-columns:1fr}.site-create-submit{width:100%}}@media (max-width: 768px){.app-shell{grid-template-columns:1fr}.sidebar{position:relative;height:auto;max-height:none;flex-direction:column;align-items:stretch}.sidebar-nav{overflow:visible}.main-content{padding:1.25rem}}.site-topology{--topo-node-w: 248px;--topo-node-h: 158px;--topo-route-gap: 1.25rem}.site-topology-intro{margin:0 0 .75rem;font-size:.88rem;line-height:1.5}.site-topology-toolbar{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.65rem}.site-topology-pan-hint{font-size:.78rem}.site-topology-viewport{position:relative;min-height:22rem;max-height:min(52vh,520px);overflow:hidden;border:1px solid var(--sn-border);border-radius:var(--sn-radius-lg);background:radial-gradient(circle at 1px 1px,color-mix(in srgb,var(--sn-border) 55%,transparent) 1px,transparent 0) 0 0 / 18px 18px,var(--sn-bg-subtle);cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none}.site-topology-viewport:active{cursor:grabbing}.site-topology-canvas{display:inline-flex;flex-direction:column;align-items:center;min-width:max(100%,fit-content);padding:1.25rem 2rem 1.75rem;will-change:transform}.site-topology-trunk{display:flex;flex-direction:column;align-items:center;width:var(--topo-node-w)}.site-topology-aux-row{display:flex;flex-direction:row;align-items:flex-start;justify-content:center;gap:var(--topo-route-gap);width:max-content;padding:0 .5rem}.site-topology-aux-col{flex:0 0 var(--topo-node-w);width:var(--topo-node-w);display:flex;flex-direction:column;align-items:center}.site-topology-aux-tree{display:flex;flex-direction:column;align-items:center;width:100%}.site-topology-routes-tree{display:flex;flex-direction:column;align-items:center;width:max-content;min-width:100%;margin-top:.15rem}.site-topology-routes-row{display:flex;flex-direction:row;align-items:flex-start;justify-content:center;gap:var(--topo-route-gap);width:max-content;min-width:100%;padding:0 .5rem}.site-topology-route-col{flex:0 0 var(--topo-node-w);width:var(--topo-node-w);display:flex;flex-direction:column;align-items:center}.topo-routes-fork{--route-col: var(--topo-node-w);--route-gap: var(--topo-route-gap);--route-count: 1;display:flex;flex-direction:column;align-items:center;width:max(100%,calc(var(--route-count) * var(--route-col) + (var(--route-count) - 1) * var(--route-gap)))}.topo-routes-fork-stem{display:block;width:2px;height:1.1rem;background:linear-gradient(180deg,var(--sn-accent-soft),rgba(14,165,233,.35));border-radius:2px}.topo-routes-fork-bar{display:block;width:calc(100% - var(--route-col));max-width:calc(var(--route-count) * var(--route-col) + (var(--route-count) - 1) * var(--route-gap) - var(--route-col));min-width:0;height:2px;background:linear-gradient(90deg,rgba(14,165,233,.2),var(--sn-accent-soft),rgba(14,165,233,.2));border-radius:2px}.topo-routes-fork-drops{display:flex;flex-direction:row;align-items:flex-start;justify-content:center;gap:var(--route-gap);width:calc(var(--route-count) * var(--route-col) + (var(--route-count) - 1) * var(--route-gap))}.topo-routes-fork-drop{flex:0 0 var(--route-col);display:flex;justify-content:center}.topo-routes-fork-drop:before{content:"";display:block;width:2px;height:1.1rem;background:linear-gradient(180deg,rgba(14,165,233,.35),var(--sn-accent-soft));border-radius:2px}.site-topology-backends{display:flex;flex-direction:column;gap:.65rem;width:100%}.site-topology-backends .topo-node{width:100%;max-width:none;flex:0 0 auto}.topo-node{box-sizing:border-box;width:var(--topo-node-w);height:var(--topo-node-h);min-height:var(--topo-node-h);max-width:var(--topo-node-w);display:flex;flex-direction:column;text-align:left;padding:.7rem .8rem .65rem;border-radius:var(--sn-radius);border:1px solid color-mix(in srgb,var(--sn-border) 88%,transparent);background:linear-gradient(165deg,var(--sn-surface) 0%,color-mix(in srgb,var(--sn-bg-subtle) 40%,var(--sn-surface)) 100%);box-shadow:var(--sn-shadow-xs);animation:tileEnter .5s cubic-bezier(.22,1,.36,1) backwards;position:relative;overflow:hidden}.topo-node:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--topo-accent, var(--sn-accent));border-radius:var(--sn-radius) 0 0 var(--sn-radius);opacity:.85}.topo-node-client{--topo-accent: #64748b}.topo-node-waf{--topo-accent: #dc2626}.topo-node-site{--topo-accent: var(--sn-accent)}.topo-node-ssl{--topo-accent: #8b5cf6}.topo-node-logs{--topo-accent: #0d9488}.topo-node-route{--topo-accent: #d97706}.topo-node-upstream{--topo-accent: #3b82f6}.topo-node-backend{--topo-accent: #059669}.site-topology-trunk .topo-node,.site-topology-aux-col .topo-node,.site-topology-route-col>.topo-node{width:100%;max-width:none}.topo-node-clickable{cursor:pointer;font:inherit;color:inherit;text-decoration:none;transition:transform var(--sn-transition),box-shadow var(--sn-transition),border-color var(--sn-transition)}.topo-node-clickable:hover{transform:translateY(-2px);box-shadow:var(--sn-shadow-sm);border-color:color-mix(in srgb,var(--topo-accent, var(--sn-accent)) 35%,var(--sn-border))}.topo-connector{display:flex;flex-direction:column;align-items:center;height:2rem;color:var(--sn-muted-light)}.topo-connector-short{height:1.35rem}.topo-connector-line{flex:1;width:2px;background:linear-gradient(180deg,var(--sn-accent-soft),rgba(14,165,233,.35));border-radius:2px}.topo-connector-arrow{font-size:.65rem;line-height:1;color:var(--sn-accent)}.topo-node-kind{display:inline-block;flex-shrink:0;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:.12rem .4rem;border-radius:999px;margin-bottom:.35rem;align-self:flex-start}.topo-node-kind-client{background:#64748b24;color:#475569}.topo-node-kind-waf{background:#dc26261a;color:#b91c1c}.topo-node-kind-site{background:var(--sn-accent-soft);color:var(--sn-accent-hover)}.topo-node-kind-ssl{background:#8b5cf61f;color:#7c3aed}.topo-node-kind-logs{background:var(--sn-teal-soft);color:#0f766e}.topo-node-kind-route{background:var(--sn-warm-soft);color:#b45309}.topo-node-kind-upstream{background:#3b82f61f;color:#2563eb}.topo-node-kind-backend{background:var(--sn-success-soft);color:#047857}.topo-node-head{flex-shrink:0;margin-bottom:.25rem;min-height:2.35rem}.topo-node-title{margin:0;font-size:.88rem;font-weight:700;letter-spacing:-.02em;line-height:1.25;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.topo-node-sub{margin:.15rem 0 0;font-size:.72rem;color:var(--sn-muted);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.topo-node-badges{display:flex;flex-wrap:wrap;gap:.3rem;margin-bottom:.25rem;flex-shrink:0;min-height:1.35rem;align-items:center}.topo-node-body{flex:1;min-height:0;font-size:.78rem;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-start}.topo-node-placeholder{display:block;flex:1;min-height:.5rem}.topo-meta-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.2rem;overflow:hidden}.topo-meta-list li{display:flex;flex-wrap:nowrap;gap:.35rem;align-items:baseline;overflow:hidden}.topo-meta-list span:first-child{font-size:.7rem;font-weight:600;text-transform:uppercase;color:var(--sn-muted-light);min-width:3.5rem}.topo-meta-list code{font-size:.72rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex:1}.topo-path{font-size:.72rem!important}.topo-directive{display:block;padding:.3rem .45rem;background:var(--sn-bg-subtle);border-radius:var(--sn-radius-sm);font-size:.72rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topo-muted{margin:0;color:var(--sn-muted);font-size:.82rem}.topo-waf-stats{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:.35rem;height:100%}.topo-waf-stat{display:flex;flex-direction:column;justify-content:center;gap:.1rem;padding:.35rem .45rem;border-radius:var(--sn-radius-sm);border:1px solid var(--sn-border-light);background:var(--sn-bg-subtle)}.topo-waf-stat span{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--sn-muted-light)}.topo-waf-stat strong{font-size:.92rem;font-weight:700;letter-spacing:-.02em}.topo-waf-stat-pass strong{color:#047857}.topo-waf-stat-block strong{color:#b91c1c}.topo-waf-total{margin:.25rem 0 0;font-size:.68rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.site-topology-legend{display:flex;flex-wrap:wrap;gap:.65rem 1.25rem;justify-content:center;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--sn-border-light);font-size:.78rem;color:var(--sn-muted)}.topo-legend-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:.35rem;vertical-align:middle}.topo-legend-dot.client{background:#64748b}.topo-legend-dot.waf{background:#dc2626}.topo-legend-dot.site{background:var(--sn-accent)}.topo-legend-dot.ssl{background:#8b5cf6}.topo-legend-dot.logs{background:var(--sn-teal)}.topo-legend-dot.route{background:var(--sn-warm)}.topo-legend-dot.upstream{background:#3b82f6}.topo-legend-dot.backend{background:var(--sn-success)}.upstream-backend-chips{display:flex;flex-direction:column;gap:.4rem}.upstream-backend-chip{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem;padding:.35rem .55rem;border-radius:var(--sn-radius-sm);background:var(--sn-bg-subtle);border:1px solid var(--sn-border-light);font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.8rem}.backend-picker{display:flex;flex-direction:column;gap:.85rem}.backend-picker-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.45rem}.backend-picker-item{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:.5rem .75rem;padding:.65rem .75rem;border:1px solid var(--sn-border-light);border-radius:var(--sn-radius);background:var(--sn-bg)}.backend-picker-item-main{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem .6rem;min-width:0}.backend-picker-item .switch-row{margin:0;padding:.35rem .5rem;min-width:140px}.backend-picker-item .switch-row-desc{display:none}.backend-picker-remove{align-self:center}.backend-picker-target{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.88rem}.backend-picker-type{font-size:.78rem}.backend-picker-add{padding:.75rem}.page-toolbar{display:flex;flex-wrap:wrap;align-items:flex-end;gap:.75rem 1.25rem;margin-bottom:1rem;padding:.85rem 1rem}.page-toolbar .switch-row{flex:1 1 220px;max-width:320px}.page-toolbar-field{flex:1 1 200px;max-width:280px;margin:0}.backend-probe-section{margin-top:.5rem;padding:.75rem}@media (max-width: 640px){.site-topology{--topo-node-w: min(248px, 82vw)}.site-topology-aux-row{flex-direction:column;align-items:center;width:100%}}.chart-panel-wide{grid-column:1 / -1}.country-traffic-summary{display:flex;flex-wrap:wrap;align-items:center;gap:.65rem 1rem;margin-bottom:1rem;padding-bottom:.85rem;border-bottom:1px solid var(--sn-border)}.country-traffic-pill{display:inline-flex;align-items:center;padding:.2rem .65rem;border-radius:999px;font-size:.78rem;font-weight:600;background:color-mix(in srgb,var(--sn-accent) 12%,transparent);color:var(--sn-accent)}.country-traffic-flags{display:inline-flex;align-items:center;gap:.15rem}.country-traffic-flag-chip{font-size:1.35rem;line-height:1;filter:drop-shadow(0 1px 1px rgba(15,23,42,.12))}.country-traffic-total{margin-left:auto;font-size:.82rem}.country-traffic-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.65rem}.country-traffic-row{display:grid;grid-template-columns:1.4rem 2.1rem 1fr;gap:.55rem .75rem;align-items:start;padding:.55rem .65rem;border-radius:var(--sn-radius-md);background:color-mix(in srgb,var(--sn-surface-elevated, var(--sn-bg)) 70%,transparent);border:1px solid color-mix(in srgb,var(--sn-border) 80%,transparent);transition:border-color .15s ease,box-shadow .15s ease}.country-traffic-row:hover{border-color:color-mix(in srgb,var(--sn-accent) 35%,var(--sn-border));box-shadow:var(--sn-shadow-sm)}.country-traffic-rank{font-size:.75rem;font-weight:700;color:var(--sn-muted);padding-top:.35rem;text-align:right}.country-traffic-flag{font-size:1.65rem;line-height:1;padding-top:.1rem;filter:drop-shadow(0 1px 2px rgba(15,23,42,.15))}.country-traffic-body{min-width:0}.country-traffic-head{display:flex;flex-wrap:wrap;align-items:baseline;gap:.35rem .5rem;margin-bottom:.35rem}.country-traffic-name{font-weight:600;font-size:.92rem;color:var(--sn-text)}.country-traffic-code{font-size:.68rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:.1rem .35rem;border-radius:4px;background:var(--sn-bg);color:var(--sn-muted);border:1px solid var(--sn-border)}.country-traffic-stats{margin-left:auto;font-size:.88rem;font-weight:600;font-variant-numeric:tabular-nums;white-space:nowrap}.country-traffic-share{margin-left:.45rem;font-size:.78rem;font-weight:600;color:var(--sn-muted)}.country-traffic-bar-track{height:8px;border-radius:999px;background:color-mix(in srgb,var(--sn-border) 55%,transparent);overflow:hidden}.country-traffic-bar-fill{height:100%;border-radius:inherit;min-width:4px;transition:width .45s ease;box-shadow:inset 0 -1px #ffffff26}.country-traffic-meta{margin-top:.25rem;font-size:.74rem}.country-traffic--compact .country-traffic-summary,.ip-traffic--compact .ip-traffic-summary{margin-bottom:.5rem;padding-bottom:.45rem;gap:.4rem .65rem}.country-traffic--compact .country-traffic-pill,.ip-traffic--compact .country-traffic-pill{font-size:.72rem;padding:.12rem .5rem}.country-traffic--compact .country-traffic-flag-chip,.ip-traffic--compact .country-traffic-flag-chip{font-size:1.05rem}.country-traffic--compact .country-traffic-total,.ip-traffic--compact .country-traffic-total{font-size:.75rem}.country-traffic--compact .country-traffic-list,.ip-traffic--compact .ip-traffic-list{gap:.35rem}.country-traffic--compact .country-traffic-row,.ip-traffic--compact .ip-traffic-row{padding:.35rem .45rem;gap:.35rem .5rem;grid-template-columns:1.1rem 1.65rem 1fr}.country-traffic--compact .country-traffic-rank,.ip-traffic--compact .country-traffic-rank{font-size:.68rem;padding-top:.2rem}.country-traffic--compact .country-traffic-flag,.ip-traffic--compact .country-traffic-flag{font-size:1.25rem}.country-traffic--compact .country-traffic-name,.ip-traffic--compact .ip-traffic-addr{font-size:.82rem}.country-traffic--compact .country-traffic-stats,.ip-traffic--compact .ip-traffic-stats{font-size:.8rem}.country-traffic--compact .country-traffic-bar-track,.ip-traffic--compact .country-traffic-bar-track{height:5px}.country-traffic--compact .country-traffic-meta,.ip-traffic--compact .country-traffic-meta{font-size:.68rem;margin-top:.15rem}.ip-traffic--compact .ip-traffic-footer{margin-top:.45rem}.ip-traffic--compact .ip-traffic-toggle{font-size:.78rem;padding:.3rem .65rem}.country-cell{display:inline-flex;align-items:center;gap:.4rem;flex-wrap:wrap}.country-cell-flag{font-size:1.15rem;line-height:1}.ip-traffic-summary{display:flex;flex-wrap:wrap;align-items:center;gap:.65rem 1rem;margin-bottom:1rem;padding-bottom:.85rem;border-bottom:1px solid var(--sn-border)}.ip-traffic-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.65rem}.ip-traffic-row{display:grid;grid-template-columns:1.4rem 2.1rem 1fr;gap:.55rem .75rem;align-items:start;padding:.55rem .65rem;border-radius:var(--sn-radius-md);background:color-mix(in srgb,var(--sn-surface-elevated, var(--sn-bg)) 70%,transparent);border:1px solid color-mix(in srgb,var(--sn-border) 80%,transparent);transition:border-color .15s ease,box-shadow .15s ease}.ip-traffic-row:hover{border-color:color-mix(in srgb,var(--sn-accent) 35%,var(--sn-border));box-shadow:var(--sn-shadow-sm)}.ip-traffic-body{min-width:0}.ip-traffic-head{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem .5rem;margin-bottom:.35rem}.ip-traffic-addr{font-size:.88rem;font-weight:600;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;color:var(--sn-text);background:color-mix(in srgb,var(--sn-bg) 85%,transparent);padding:.12rem .4rem;border-radius:4px;border:1px solid var(--sn-border)}.ip-traffic-stats{margin-left:auto;font-size:.88rem;font-weight:600;font-variant-numeric:tabular-nums;white-space:nowrap}.ip-traffic-footer{display:flex;justify-content:center;margin-top:.85rem;padding-top:.5rem}.ip-traffic-toggle{min-width:12rem}@media (max-width: 640px){.ip-traffic-stats{width:100%;margin-left:0}.country-traffic-total{margin-left:0;width:100%}.country-traffic-stats{width:100%;margin-left:0}}.logs-toolbar{padding:0;overflow:hidden}.logs-toolbar-top{display:grid;grid-template-columns:minmax(220px,1.4fr) auto auto;gap:.85rem 1rem;align-items:end;padding:1rem 1.15rem;border-bottom:1px solid var(--sn-border);background:linear-gradient(180deg,var(--sn-bg-subtle) 0%,var(--sn-surface) 100%)}.logs-toolbar-label{display:block;margin-bottom:.35rem;font-size:.7rem;font-weight:700;color:var(--sn-muted);text-transform:uppercase;letter-spacing:.06em}.logs-toolbar-file{min-width:0}.logs-toolbar-select{width:100%;min-height:2.5rem;padding:.45rem 2.25rem .45rem .75rem;font-size:.9rem;font-weight:500;color:var(--sn-text);background-color:var(--sn-surface);border:1px solid var(--sn-border);border-radius:var(--sn-radius);box-shadow:inset 0 1px 2px #0f172a0a;cursor:pointer;transition:border-color var(--sn-transition),box-shadow var(--sn-transition)}.logs-toolbar-select:hover{border-color:var(--sn-border-strong, var(--sn-muted-light))}.logs-toolbar-select:focus{outline:none;border-color:var(--sn-accent, #4f8cff);box-shadow:0 0 0 3px #4f8cff2e}.logs-toolbar-toggles{display:flex;flex-wrap:wrap;gap:.45rem;align-items:center}.logs-toggle{display:inline-flex;align-items:center;gap:0;margin:0;padding:.42rem .8rem;font-size:.82rem;font-weight:600;color:var(--sn-text-secondary);background:var(--sn-surface);border:1px solid var(--sn-border);border-radius:999px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--sn-transition),border-color var(--sn-transition),color var(--sn-transition),box-shadow var(--sn-transition)}.logs-toggle input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.logs-toggle:hover{border-color:var(--sn-border-strong, var(--sn-muted-light));color:var(--sn-text)}.logs-toggle--on{background:var(--sn-accent-soft, rgba(79, 140, 255, .1));border-color:var(--sn-accent, #4f8cff);color:var(--sn-accent, #4f8cff);box-shadow:0 1px 2px #4f8cff1f}.logs-toggle--live .logs-toggle-text:before{content:"";display:inline-block;width:7px;height:7px;margin-right:.4rem;border-radius:50%;background:#22c55e;box-shadow:0 0 #22c55e80;animation:logsPulse 1.8s ease-out infinite;vertical-align:middle}@keyframes logsPulse{0%{box-shadow:0 0 #22c55e8c}70%{box-shadow:0 0 0 8px #22c55e00}to{box-shadow:0 0 #22c55e00}}.logs-toolbar-edit{align-self:end;min-height:2.5rem;padding:.45rem .95rem;font-size:.82rem;font-weight:600;color:var(--sn-text-secondary);background:var(--sn-surface);border:1px solid var(--sn-border);border-radius:var(--sn-radius);cursor:pointer;white-space:nowrap;transition:background var(--sn-transition),border-color var(--sn-transition),color var(--sn-transition)}.logs-toolbar-edit:hover{color:var(--sn-text);border-color:var(--sn-border-strong, var(--sn-muted-light));background:var(--sn-bg-subtle)}.logs-toolbar-edit--active{color:var(--sn-accent, #4f8cff);border-color:var(--sn-accent, #4f8cff);background:var(--sn-accent-soft, rgba(79, 140, 255, .1))}.logs-toolbar-search{display:flex;align-items:stretch;gap:0;padding:.85rem 1.15rem;border-bottom:1px solid var(--sn-border)}.logs-toolbar-search-input{flex:1;min-width:0;min-height:2.5rem;padding:.5rem .85rem;font-size:.9rem;color:var(--sn-text);background:var(--sn-surface);border:1px solid var(--sn-border);border-right:none;border-radius:var(--sn-radius) 0 0 var(--sn-radius);transition:border-color var(--sn-transition),box-shadow var(--sn-transition)}.logs-toolbar-search-input:focus{outline:none;border-color:var(--sn-accent, #4f8cff);box-shadow:0 0 0 3px #4f8cff26;z-index:1}.logs-toolbar-search-input::placeholder{color:var(--sn-muted-light)}.logs-toolbar-search-btn{min-width:5.5rem;min-height:2.5rem;padding:0 1.1rem;font-size:.85rem;font-weight:600;color:var(--sn-surface);background:var(--sn-accent, #4f8cff);border:1px solid var(--sn-accent, #4f8cff);border-radius:0 var(--sn-radius) var(--sn-radius) 0;cursor:pointer;transition:filter var(--sn-transition),opacity var(--sn-transition)}.logs-toolbar-search-btn:hover:not(:disabled){filter:brightness(1.06)}.logs-toolbar-search-btn:disabled{opacity:.45;cursor:not-allowed}.logs-toolbar-meta{display:flex;flex-direction:column;gap:.55rem;padding:.7rem 1.15rem .85rem;background:var(--sn-bg-subtle)}.logs-toolbar-chips{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem}.logs-meta-chip{display:inline-flex;align-items:center;padding:.2rem .6rem;font-size:.72rem;font-weight:600;border-radius:999px;background:var(--sn-surface);color:var(--sn-text-secondary);border:1px solid var(--sn-border)}.logs-meta-chip--domain{color:var(--sn-accent, #4f8cff);border-color:#4f8cff59;background:var(--sn-accent-soft, rgba(79, 140, 255, .08))}.logs-meta-chip--kind.logs-meta-chip--access{color:#0f766e;border-color:#0f766e47;background:#0f766e14}.logs-meta-chip--kind.logs-meta-chip--error{color:#b45309;border-color:#b4530947;background:#b4530914}.logs-meta-live{background:var(--sn-log-live-bg);color:var(--sn-log-live-fg);border-color:var(--sn-log-live-border);text-transform:uppercase;letter-spacing:.06em}.logs-toolbar-path{display:block;margin:0;padding:.45rem .65rem;font-size:.74rem;line-height:1.35;color:var(--sn-muted);background:var(--sn-surface);border:1px dashed var(--sn-border);border-radius:var(--sn-radius-sm, 6px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 860px){.logs-toolbar-top{grid-template-columns:1fr;align-items:stretch}.logs-toolbar-edit{align-self:stretch;width:100%}}.logs-fix-form{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.logs-viewer-panel{padding:0;overflow:hidden;border-color:var(--sn-code-border)}.logs-viewer-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.65rem 1rem;background:var(--sn-code-header-bg);border-bottom:1px solid var(--sn-code-border)}.logs-viewer-title{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.82rem;font-weight:600;color:var(--sn-code-path)}.logs-viewer-status{font-size:.72rem;color:var(--sn-code-fg-muted);text-transform:uppercase;letter-spacing:.05em}.logs-viewer{margin:0;max-height:min(70vh,720px);overflow:auto;padding:.35rem 0;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.78rem;line-height:1.55;background:var(--sn-code-bg);color:var(--sn-code-fg)}.logs-viewer-wrap .log-body,.logs-viewer-wrap .log-path,.logs-viewer-wrap .log-tail,.logs-viewer-wrap .log-error-msg{white-space:pre-wrap;word-break:break-word}.logs-viewer:not(.logs-viewer-wrap) .log-body{white-space:nowrap}.logs-empty{padding:2.5rem 1rem;text-align:center;color:var(--sn-code-fg-muted)}.logs-line{display:flex;gap:0;align-items:flex-start;padding:.12rem .75rem .12rem 0;border-left:3px solid transparent;transition:background .12s ease,border-color .12s ease}.logs-line-even{background:var(--sn-code-stripe)}.logs-line:hover{background:var(--sn-code-hover);border-left-color:var(--sn-code-hover-accent)}.logs-line-error{border-left-color:var(--sn-log-level-error-bg)}.logs-lineno{flex:0 0 3.25rem;padding-right:.75rem;text-align:right;color:var(--sn-code-lineno);-webkit-user-select:none;user-select:none;font-size:.72rem;line-height:1.65}.log-body{flex:1;min-width:0;display:flex;flex-wrap:wrap;align-items:baseline;gap:.35rem .5rem;padding:.05rem 0}.log-chip{display:inline-flex;align-items:center;padding:.05rem .45rem;border-radius:4px;font-size:.72rem;font-weight:600;line-height:1.4;white-space:nowrap}.log-chip-time{color:var(--sn-log-time-fg);background:var(--sn-log-time-bg)}.log-chip-ip{color:var(--sn-log-ip-fg);background:var(--sn-log-ip-bg)}.log-chip-host{color:var(--sn-log-host-fg);background:var(--sn-log-host-bg)}.log-chip-muted{color:var(--sn-log-muted-fg);background:var(--sn-log-muted-bg);font-weight:500}.log-path{color:var(--sn-code-path);font-weight:500}.log-tail{color:var(--sn-code-fg-muted);font-size:.72rem}.log-error-msg{color:var(--sn-code-error-msg)}.log-method-get{color:var(--sn-log-method-get-fg);background:var(--sn-log-method-get-bg)}.log-method-post{color:var(--sn-log-method-post-fg);background:var(--sn-log-method-post-bg)}.log-method-write{color:var(--sn-log-method-write-fg);background:var(--sn-log-method-write-bg)}.log-method-delete{color:var(--sn-log-method-delete-fg);background:var(--sn-log-method-delete-bg)}.log-method-other{color:var(--sn-log-method-other-fg);background:var(--sn-log-method-other-bg)}.log-status-2xx{color:var(--sn-log-status-2xx-fg);background:var(--sn-log-status-2xx-bg)}.log-status-3xx{color:var(--sn-log-status-3xx-fg);background:var(--sn-log-status-3xx-bg)}.log-status-4xx{color:var(--sn-log-status-4xx-fg);background:var(--sn-log-status-4xx-bg)}.log-status-5xx{color:var(--sn-log-status-5xx-fg);background:var(--sn-log-status-5xx-bg)}.log-status-other{color:var(--sn-log-status-other-fg);background:var(--sn-log-status-other-bg)}.log-level-error{color:var(--sn-log-level-error-fg);background:var(--sn-log-level-error-bg);text-transform:uppercase}.log-level-warn{color:var(--sn-log-level-warn-fg);background:var(--sn-log-level-warn-bg);text-transform:uppercase}.log-level-info{color:var(--sn-log-level-info-fg);background:var(--sn-log-level-info-bg);text-transform:uppercase}.log-highlight{background:var(--sn-log-highlight-bg);color:var(--sn-log-highlight-fg);border-radius:2px;padding:0 .1em}.log-body-raw{color:var(--sn-code-fg);word-break:break-word}.theme-toggle{display:inline-flex;flex-wrap:wrap;gap:.35rem;padding:.25rem;background:var(--sn-bg-subtle);border:1px solid var(--sn-border);border-radius:var(--sn-radius-sm)}.theme-toggle-compact{width:100%;justify-content:center;margin-bottom:.65rem}.theme-toggle-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .65rem;border:none;border-radius:6px;background:transparent;color:var(--sn-muted);font:inherit;font-size:.82rem;font-weight:600;cursor:pointer;transition:background var(--sn-transition),color var(--sn-transition),box-shadow var(--sn-transition)}.theme-toggle-compact .theme-toggle-btn{flex:1;justify-content:center;padding:.45rem .35rem;font-size:1rem}.theme-toggle-btn:hover{color:var(--sn-text);background:var(--sn-surface-hover)}.theme-toggle-btn.active{color:var(--sn-text);background:var(--sn-surface);box-shadow:var(--sn-shadow-xs)}.theme-toggle-icon{font-size:1rem;line-height:1}.login-theme{display:flex;justify-content:center;margin-bottom:1rem}.login-theme .theme-toggle-compact{width:auto;margin-bottom:0}.sidebar-footer .theme-toggle-compact{margin-bottom:.75rem}.backend-kind-tabs{display:flex;flex-wrap:wrap;gap:.35rem}.backend-kind-tab{padding:.45rem .75rem;border:1px solid var(--sn-border);border-radius:var(--sn-radius-sm);background:var(--sn-bg-subtle);color:var(--sn-muted);font:inherit;font-size:.85rem;font-weight:600;cursor:pointer;transition:background var(--sn-transition),border-color var(--sn-transition),color var(--sn-transition)}.backend-kind-tab:hover{color:var(--sn-text);border-color:var(--sn-accent-soft)}.backend-kind-tab.active{background:var(--sn-accent-soft);border-color:var(--sn-accent);color:var(--sn-text)}.backend-kind-hint{margin:.35rem 0 0;font-size:.85rem}.backend-host-port-row{align-items:flex-end;gap:.75rem}.backend-probe-row{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;margin-top:.5rem}.backend-probe-ok,.backend-probe-fail{font-size:.88rem;font-weight:600}.upstream-health-results .badge{font-size:.72rem}.waf-page-header{align-items:center;margin-bottom:.85rem}.waf-header-text{min-width:0}.waf-toolbar{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:.75rem 1rem;margin-bottom:1rem;padding:.9rem 1.1rem;background:linear-gradient(180deg,var(--sn-bg-subtle) 0%,var(--sn-surface) 100%);border:1px solid var(--sn-border);border-radius:var(--sn-radius-lg);box-shadow:var(--sn-shadow-xs)}.waf-toolbar-period{display:flex;flex-direction:column;min-width:0}.waf-toolbar-label{display:block;margin-bottom:.35rem;font-size:.68rem;font-weight:700;color:var(--sn-muted);text-transform:uppercase;letter-spacing:.06em}.waf-toolbar-refresh{min-height:2.45rem;white-space:nowrap}.waf-period-bar{display:flex;flex-wrap:wrap;gap:.35rem;padding:.25rem;background:var(--sn-surface-inset);border:1px solid var(--sn-border);border-radius:var(--sn-radius-lg)}.waf-period-btn{padding:.45rem .85rem;border:none;border-radius:var(--sn-radius);background:transparent;color:var(--sn-muted);font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s,color .15s,box-shadow .15s}.waf-period-btn:hover{color:var(--sn-text);background:var(--sn-surface-2)}.waf-period-btn.active{color:var(--sn-text);background:var(--sn-surface);box-shadow:var(--sn-shadow-sm)}.waf-summary-grid{grid-template-columns:repeat(4,1fr);gap:.55rem;margin-bottom:.85rem}.waf-page .waf-summary-grid .stat-card{padding:.7rem .8rem;gap:.15rem}.waf-page .waf-summary-grid .stat-card:hover{transform:translateY(-2px)}.waf-page .waf-summary-grid .stat-value{font-size:1.4rem}.waf-page .waf-summary-grid .stat-label{font-size:.76rem;line-height:1.25}.waf-top-country-value{display:flex;align-items:center;gap:.35rem;font-size:.95rem;line-height:1.2}.waf-chart-grid{grid-template-columns:repeat(2,1fr);gap:.6rem;margin-bottom:.5rem}.waf-chart-grid .chart-panel{padding:.7rem .8rem;margin-bottom:0}.waf-chart-grid .panel-header-row{margin-bottom:.45rem;gap:.45rem}.waf-chart-grid .chart-panel h2,.waf-chart-grid .panel-header-row h2{margin:0;font-size:.8rem}.waf-chart-empty{margin:0;font-size:.82rem}.waf-chart-grid .waf-event-chart .country-traffic-summary,.waf-chart-grid .waf-event-chart .ip-traffic-summary{margin-bottom:.45rem;padding-bottom:.4rem;gap:.35rem .6rem}.waf-chart-grid .country-traffic-list,.waf-chart-grid .ip-traffic-list{gap:.3rem}.waf-chart-grid .country-traffic-row,.waf-chart-grid .ip-traffic-row{padding:.32rem .42rem;gap:.3rem .45rem;grid-template-columns:1.1rem 1.75rem 1fr}.waf-chart-grid .country-traffic-rank{font-size:.68rem;padding-top:.2rem}.waf-chart-grid .country-traffic-flag{font-size:1.2rem;padding-top:0}.waf-chart-grid .country-traffic-flag-chip{font-size:1rem}.waf-chart-grid .country-traffic-head,.waf-chart-grid .ip-traffic-head{margin-bottom:.15rem;gap:.25rem .4rem}.waf-chart-grid .country-traffic-name{font-size:.82rem}.waf-chart-grid .ip-traffic-addr{font-size:.76rem;padding:.06rem .28rem}.waf-chart-grid .country-traffic-meta{margin-top:.08rem;font-size:.66rem}.waf-chart-grid .waf-stacked-bar-track{height:5px}.waf-chart-grid .waf-event-count{font-size:.76rem}.waf-chart-grid .waf-event-count-label{font-size:.65rem}.waf-chart-grid .waf-event-chart-totals{font-size:.74rem;gap:.35rem .65rem}.waf-chart-grid .country-traffic-pill{font-size:.72rem;padding:.12rem .5rem}.waf-chart-grid .ip-traffic-footer{margin-top:.4rem;padding-top:.25rem}.waf-chart-grid .ip-traffic-toggle{min-width:10rem;font-size:.82rem;padding:.35rem .65rem}.waf-chart-grid .chart-panel h2{margin:0}.waf-chart-legend{display:flex;gap:.5rem;font-size:.7rem;color:var(--sn-muted)}.waf-legend-item:before{content:"";display:inline-block;width:8px;height:8px;border-radius:2px;margin-right:.28rem;vertical-align:middle}.waf-legend-blocked:before{background:var(--sn-danger)}.waf-legend-detected:before{background:var(--sn-warn)}.waf-event-chart-totals{display:flex;flex-wrap:wrap;gap:.5rem 1rem;font-size:.82rem}.waf-event-chart-stats{margin-left:auto;display:flex;flex-wrap:wrap;align-items:baseline;gap:.35rem .65rem;font-variant-numeric:tabular-nums;white-space:nowrap}.waf-event-count{font-size:.88rem;font-weight:600}.waf-event-count-label{margin-left:.2rem;font-size:.72rem;font-weight:600;opacity:.85}.waf-event-count-blocked{color:var(--sn-danger)}.waf-event-count-detected{color:var(--sn-warn)}.waf-stacked-bar-track{height:8px;border-radius:999px;background:color-mix(in srgb,var(--sn-border) 55%,transparent);overflow:hidden}.waf-stacked-bar-inner{display:flex;height:100%;min-width:4px;border-radius:inherit;overflow:hidden;transition:width .45s ease}.waf-stacked-bar-segment{height:100%;min-width:0;box-shadow:inset 0 -1px #ffffff1f}.waf-stacked-bar-blocked{border-radius:999px 0 0 999px}.waf-stacked-bar-detected{border-radius:0 999px 999px 0}.waf-stacked-bar-inner .waf-stacked-bar-blocked:only-child,.waf-stacked-bar-inner .waf-stacked-bar-detected:only-child{border-radius:inherit}.waf-events-panel h2,.waf-rules-panel h2{margin:0}.waf-events-filters{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.waf-filter-input,.waf-filter-select{min-width:140px;padding:.45rem .65rem;border:1px solid var(--sn-border);border-radius:var(--sn-radius);background:var(--sn-surface-inset);color:var(--sn-text);font-size:.88rem}.waf-filter-input-country{min-width:5.5rem;max-width:6rem;text-transform:uppercase;letter-spacing:.04em}.waf-filter-input-rule{min-width:7rem;max-width:9rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.82rem}.waf-filter-country-chip{display:inline-flex;align-items:center;gap:.3rem;padding:.35rem .55rem;border-radius:var(--sn-radius);border:1px solid var(--sn-border);background:var(--sn-bg);font-size:.82rem;font-weight:600}.waf-filter-clear{padding:.45rem .75rem;font-size:.82rem}.waf-chart-row-clickable{cursor:pointer}.waf-chart-row-clickable:focus-visible{outline:2px solid color-mix(in srgb,var(--sn-accent) 65%,transparent);outline-offset:2px}.waf-events-table-wrap{margin-top:.75rem}.waf-events-table{font-size:.85rem}.waf-events-table th,.waf-events-table td{vertical-align:middle}.waf-col-time{white-space:nowrap;font-size:.8rem}.waf-col-rule code{font-size:.78rem}.waf-col-actions{width:1%;white-space:nowrap;text-align:right}.waf-method{color:var(--sn-muted);font-weight:600;font-size:.78rem}.waf-ip-code{font-size:.82rem}.waf-row-actions{display:flex;gap:.25rem;justify-content:flex-end}.waf-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:1px solid var(--sn-border);border-radius:var(--sn-radius);background:var(--sn-surface-inset);color:var(--sn-muted);cursor:pointer;transition:border-color .15s,background .15s,color .15s}.waf-icon-btn:hover:not(:disabled){border-color:color-mix(in srgb,var(--sn-border) 60%,var(--sn-accent) 40%);background:var(--sn-surface-2);color:var(--sn-text)}.waf-icon-btn:disabled{opacity:.45;cursor:not-allowed}.waf-icon-btn--danger:hover:not(:disabled){border-color:var(--sn-danger);color:var(--sn-danger);background:color-mix(in srgb,var(--sn-danger) 12%,transparent)}.waf-icon-btn--success:hover:not(:disabled){border-color:var(--sn-success);color:var(--sn-success);background:color-mix(in srgb,var(--sn-success) 12%,transparent)}.waf-add-form{display:flex;flex-wrap:wrap;gap:.75rem;align-items:flex-end;margin-bottom:1.25rem;padding-bottom:1.25rem;border-bottom:1px solid var(--sn-border)}.waf-add-form-fields{display:flex;flex-wrap:wrap;gap:.65rem;flex:1;min-width:0}.waf-field{display:flex;flex-direction:column;gap:.25rem;min-width:140px}.waf-field-grow{flex:1;min-width:180px}.waf-field-label{font-size:.72rem;font-weight:600;color:var(--sn-muted);text-transform:uppercase;letter-spacing:.03em}.waf-field input,.waf-field select{padding:.5rem .65rem;border:1px solid var(--sn-border);border-radius:var(--sn-radius);background:var(--sn-surface-inset);color:var(--sn-text);font-size:.88rem}.waf-add-submit{flex-shrink:0}.waf-rules-count-badge{font-size:.82rem;font-weight:600;color:var(--sn-muted);padding:.35rem .65rem;border:1px solid var(--sn-border);border-radius:var(--sn-radius-pill, 999px);background:var(--sn-surface-inset)}.waf-rules-tabs{display:flex;gap:.5rem;margin-bottom:1rem}.waf-rules-tab{display:inline-flex;align-items:center;gap:.45rem;padding:.5rem .85rem;border:1px solid var(--sn-border);border-radius:var(--sn-radius);background:var(--sn-surface-inset);color:var(--sn-muted);font-size:.88rem;font-weight:600;cursor:pointer;transition:border-color .15s,background .15s,color .15s}.waf-rules-tab:hover{color:var(--sn-text);border-color:color-mix(in srgb,var(--sn-border) 70%,var(--sn-accent) 30%)}.waf-rules-tab.active{color:var(--sn-text);border-color:var(--sn-accent);background:var(--sn-surface);box-shadow:var(--sn-shadow-sm)}.waf-rules-tab-count{font-size:.75rem;font-weight:700;padding:.1rem .45rem;border-radius:999px;background:var(--sn-surface-2);color:var(--sn-muted)}.waf-rules-tab.active .waf-rules-tab-count{background:color-mix(in srgb,var(--sn-accent) 15%,transparent);color:var(--sn-accent)}.waf-rules-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.waf-rules-item{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.65rem .75rem;border:1px solid var(--sn-border);border-radius:var(--sn-radius);background:var(--sn-surface-inset)}.waf-rules-item-main{display:flex;flex-direction:column;gap:.2rem;min-width:0}.waf-rules-note{font-size:.85rem;color:var(--sn-text)}.waf-rules-meta{font-size:.75rem}.waf-rules-item-side{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.waf-rule-status-btn{border:none;cursor:pointer;font:inherit;line-height:inherit;margin-right:0;transition:opacity .15s ease}.waf-rule-status-btn:hover:not(:disabled){opacity:.85}.waf-rule-status-btn:disabled{cursor:wait;opacity:.6}.waf-rule-enable-btn{padding:.25rem .65rem;font-size:.75rem;line-height:1.2}.waf-rules-empty{padding:1rem 0}.waf-rules-toolbar{margin-bottom:.85rem}.waf-rules-search{display:flex;flex-direction:column;gap:.25rem;max-width:28rem}.waf-rules-search input{width:100%}.waf-rules-table-meta{margin:0 0 .65rem;font-size:.82rem}.waf-rules-table-wrap{max-height:min(70vh,42rem)}.waf-rules-table .waf-rules-col-source{max-width:14rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.waf-rules-col-status{width:6.5rem;white-space:nowrap}.waf-rules-col-actions{width:2.5rem;text-align:right}.waf-rules-th-sort{display:inline-flex;align-items:center;gap:.25rem;padding:0;border:none;background:none;font:inherit;font-weight:600;color:inherit;cursor:pointer}.waf-rules-th-sort:hover,.waf-rules-th-sort.active{color:var(--sn-accent)}.waf-rules-th-arrow{font-size:.72rem;opacity:.65}.waf-rules-pagination{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:.85rem}.waf-ip-detail-meta{margin-bottom:.85rem}.waf-ip-detail-kv{display:grid;grid-template-columns:auto 1fr;gap:.35rem 1rem;margin:0;font-size:.88rem}.waf-ip-detail-kv dt{color:var(--sn-muted);font-weight:500}.waf-ip-detail-kv dd{margin:0}.waf-ip-detail-hits-hint{margin:0 0 .65rem;font-size:.82rem}.waf-bot-panel,.waf-policy-panel{display:flex;flex-direction:column;gap:1rem}.waf-policy-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(16rem,1fr));gap:.85rem}.waf-policy-card{border:1px solid var(--sn-border, rgba(255, 255, 255, .08));border-radius:.5rem;padding:.85rem 1rem;background:var(--sn-surface-2, rgba(255, 255, 255, .02))}.waf-policy-card-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.45rem}.waf-policy-card-head h3{margin:0;font-size:1rem}.waf-policy-toggle{display:flex;align-items:center;gap:.4rem;font-weight:600;white-space:nowrap}.waf-policy-mode{min-width:3.5rem;text-align:right}.waf-policy-desc{margin:0;font-size:.875rem;line-height:1.4}.waf-policy-tags{margin:.35rem 0 0;font-size:.75rem}.waf-policy-anomaly label{display:flex;flex-direction:column;gap:.35rem;max-width:20rem}.waf-policy-anomaly-value{font-weight:700;font-variant-numeric:tabular-nums}.waf-bot-section h2,.waf-bot-section h3{margin:0 0 .65rem}.waf-bot-lead{margin:0 0 .5rem;max-width:52rem}.waf-bot-global-head{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:.75rem 1rem;margin-bottom:.85rem}.waf-bot-global-head h2{margin:0 0 .35rem}.waf-bot-sites-link{text-decoration:none;white-space:nowrap}.waf-bot-scope-note{margin-bottom:1rem;padding:.75rem .9rem;font-size:.86rem;line-height:1.45}.waf-bot-sites-summary{margin-top:1.1rem;padding-top:1rem;border-top:1px solid var(--sn-border)}.waf-bot-sites-summary-stats{display:flex;flex-wrap:wrap;gap:.45rem;margin-bottom:.65rem}.waf-bot-summary-chip{display:inline-flex;align-items:center;padding:.2rem .65rem;font-size:.74rem;font-weight:600;border-radius:999px;border:1px solid var(--sn-border);background:var(--sn-surface)}.waf-bot-summary-chip--active{color:#0f766e;border-color:#0f766e4d;background:#0f766e14}.waf-bot-summary-chip--custom{color:var(--sn-accent, #4f8cff);border-color:#4f8cff59;background:#4f8cff14}.waf-bot-summary-chip--exempt{color:var(--sn-muted)}.waf-bot-exempt-details{font-size:.86rem}.waf-bot-exempt-details summary{cursor:pointer;font-weight:600;color:var(--sn-text-secondary)}.waf-bot-exempt-list{list-style:none;margin:.65rem 0 0;padding:0;display:flex;flex-direction:column;gap:.45rem}.waf-bot-exempt-item{display:grid;grid-template-columns:minmax(120px,1fr) auto 1fr;gap:.5rem .75rem;align-items:center;padding:.45rem .65rem;border:1px solid var(--sn-border);border-radius:var(--sn-radius);background:var(--sn-bg-subtle)}.waf-bot-exempt-name{font-weight:600}.waf-bot-exempt-badge{font-size:.72rem;font-weight:600;color:var(--sn-muted)}.waf-bot-exempt-reason{font-size:.78rem}.site-bot-rate-section{margin-top:.5rem;padding-top:.75rem;border-top:1px dashed var(--sn-border)}.site-bot-exempt-note{padding:.65rem .75rem;border-radius:var(--sn-radius);background:var(--sn-warn-soft, rgba(230, 162, 60, .12));border:1px solid var(--sn-warn, #e6a23c)}.waf-bot-form{display:flex;flex-direction:column;gap:.85rem;align-items:flex-start}.waf-bot-toggle{display:flex;align-items:center;gap:.5rem;font-weight:600}.waf-bot-limits{display:flex;flex-wrap:wrap;gap:1rem}.waf-bot-limits label{display:flex;flex-direction:column;gap:.35rem;min-width:10rem}.waf-bot-rules-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.45rem}.waf-bot-rule-btn{border:none;background:none;padding:0;color:var(--sn-accent);cursor:pointer;text-align:left;font:inherit}.waf-bot-rule-btn:hover{text-decoration:underline}.waf-bot-section-hint{margin:-.35rem 0 .75rem}.waf-bot-blocked-wrap,.waf-bot-recent-wrap{margin-top:.25rem}.waf-bot-blocked-table,.waf-bot-recent-table{font-size:.875rem}.waf-bot-blocked-table th,.waf-bot-blocked-table td,.waf-bot-recent-table th,.waf-bot-recent-table td{vertical-align:middle}.waf-col-bot-label{max-width:18rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.waf-col-num{text-align:right;font-variant-numeric:tabular-nums}.waf-bot-ip-btn{border:none;background:none;padding:0;cursor:pointer;font:inherit}.waf-bot-ip-btn:hover .waf-ip-code{color:var(--sn-accent)}.waf-ip-link-btn{border:none;background:none;padding:0;cursor:pointer;font:inherit}.waf-ip-link-btn:hover .waf-ip-code{color:var(--sn-accent)}.waf-ip-detail-modal .waf-ip-detail-section{margin-top:1rem}.waf-ip-detail-modal .waf-ip-detail-section h3{margin:0 0 .5rem;font-size:.92rem;font-weight:600}.waf-ip-detail-rule-status{display:flex;flex-wrap:wrap;align-items:center;gap:.45rem .65rem;margin-bottom:.75rem}.waf-ip-detail-rule-note{font-size:.82rem}.waf-ip-detail-hits-wrap{max-height:240px}.waf-ip-detail-hits-table{font-size:.82rem}.waf-ip-detail-hits-table th,.waf-ip-detail-hits-table td{padding:.35rem .5rem}.waf-ip-detail-host{max-width:9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.waf-ip-detail-ua-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.35rem;max-height:160px;overflow-y:auto}.waf-ip-detail-ua-item code{display:block;font-size:.78rem;line-height:1.35;word-break:break-all;color:var(--sn-muted)}.waf-ip-detail-footer{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.65rem;width:100%}.waf-ip-detail-actions{display:flex;flex-wrap:wrap;gap:.5rem}.waf-ip-detail-block-btn{color:var(--sn-danger);border-color:color-mix(in srgb,var(--sn-danger) 45%,var(--sn-border))}.waf-ip-detail-block-btn:hover{background:color-mix(in srgb,var(--sn-danger) 12%,transparent)}@media (max-width: 768px){.waf-summary-grid{grid-template-columns:repeat(2,1fr)}.waf-chart-grid{grid-template-columns:1fr}.waf-toolbar{flex-direction:column;align-items:stretch}.waf-toolbar-refresh{width:100%}.waf-period-bar{justify-content:stretch}.waf-period-btn{flex:1;text-align:center}.waf-add-form{flex-direction:column;align-items:stretch}.waf-add-form-fields{flex-direction:column}.waf-field,.waf-field-grow{min-width:0;width:100%}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.nav-top{margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--sn-border-light)}.sidebar-nav{flex:1;min-height:0;overflow-y:auto;margin:0 -.25rem;padding:0 .25rem}.nav-group{margin-bottom:.35rem}.nav-group-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;gap:.5rem;padding:.45rem .65rem;margin-bottom:.15rem;border:none;border-radius:var(--sn-radius-sm);background:transparent;color:var(--sn-muted);font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;cursor:pointer;transition:background var(--sn-transition),color var(--sn-transition)}.nav-group-toggle:hover{background:var(--sn-surface-hover);color:var(--sn-text-secondary)}.nav-group--active .nav-group-toggle{color:var(--sn-accent)}.nav-group-title{flex:1;text-align:left}.nav-group-chevron{flex-shrink:0;opacity:.55;transition:transform .2s ease}.nav-group--collapsed .nav-group-chevron{transform:rotate(-90deg)}.nav-group-items{overflow:hidden}.nav-group-items[hidden]{display:none}.nav-group-items nav{padding-bottom:.25rem}.nav-icon-wrap{width:28px;height:28px;display:grid;place-items:center;border-radius:var(--sn-radius-sm);background:var(--sn-surface-inset);border:1px solid var(--sn-border-light);flex-shrink:0}.nav-svg{width:16px;height:16px;opacity:.75}.nav-link.active .nav-icon-wrap{background:var(--sn-accent-soft);border-color:transparent;color:var(--sn-accent)}.nav-link.active .nav-svg{opacity:1}.nav-glow,.brand-mark{display:none}.brand-text{display:flex;flex-direction:column;gap:0;min-width:0}.brand-name{font-weight:600;font-size:.95rem;letter-spacing:-.01em}.brand-tag{font-size:.72rem;font-weight:500;color:var(--sn-muted);text-transform:none;letter-spacing:0}.brand-icon{display:grid}.sidebar .brand-icon-fallback{width:32px;height:32px;border-radius:var(--sn-radius-sm);background:var(--sn-accent);color:#fff;display:grid;place-items:center;font-size:.75rem;font-weight:700;flex-shrink:0}.page-header-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:.65rem}.page-header h1{margin:0;font-size:1.35rem;font-weight:600;letter-spacing:-.02em;color:var(--sn-text);background:none;-webkit-text-fill-color:unset;line-height:1.2}.shell-toolbar{display:inline-flex;align-items:center;gap:.15rem;flex-shrink:0;padding:.2rem;background:var(--sn-surface);border:1px solid var(--sn-border);border-radius:10px;box-shadow:var(--sn-shadow-xs)}.shell-toolbar-divider{width:1px;align-self:stretch;margin:.35rem .15rem;background:var(--sn-border);flex-shrink:0}.theme-toggle-toolbar{display:inline-flex;align-items:center;gap:.1rem;padding:0;margin:0;border:none;background:transparent}.theme-toggle-toolbar .theme-toggle-btn{display:grid;place-items:center;width:2rem;height:2rem;padding:0;flex:none;border:none;border-radius:7px;color:var(--sn-muted);background:transparent;cursor:pointer;transition:background .15s ease,color .15s ease}.theme-toggle-toolbar .theme-toggle-btn:hover{color:var(--sn-text);background:var(--sn-surface-hover)}.theme-toggle-toolbar .theme-toggle-btn.active{color:var(--sn-accent);background:var(--sn-accent-soft);box-shadow:none}.page-subtitle{margin:.25rem 0 0;color:var(--sn-muted);font-size:.9rem}.user-account-menu{position:relative}.user-account-trigger{display:flex;align-items:center;gap:.45rem;padding:.35rem .65rem .35rem .4rem;border:1px solid var(--sn-border);border-radius:var(--sn-radius-sm);background:var(--sn-surface);color:var(--sn-text-secondary);cursor:pointer;font:inherit;transition:background var(--sn-transition),border-color var(--sn-transition)}.user-account-trigger:hover{background:var(--sn-surface-hover);border-color:var(--sn-border-strong, var(--sn-border))}.user-account-trigger--toolbar{border:none;background:transparent;padding:.15rem .45rem .15rem .2rem;border-radius:7px;min-height:2rem}.user-account-trigger--toolbar:hover,.user-account-trigger--toolbar.user-account-trigger--open{background:var(--sn-surface-hover);border-color:transparent}.user-account-trigger--toolbar.user-account-trigger--open .user-account-chevron{transform:rotate(180deg);opacity:.85}.user-account-avatar{width:1.5rem;height:1.5rem;display:grid;place-items:center;border-radius:50%;background:var(--sn-accent);color:#fff;font-size:.68rem;font-weight:700;flex-shrink:0}.user-account-name{font-size:.8rem;font-weight:600;color:var(--sn-text);max-width:8rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-account-chevron{opacity:.45;flex-shrink:0;transition:transform .2s ease,opacity .2s ease}.user-account-panel{position:absolute;top:calc(100% + .4rem);right:0;z-index:40;width:min(320px,calc(100vw - 2rem));padding:1rem;background:var(--sn-surface);border:1px solid var(--sn-border);border-radius:var(--sn-radius-md);box-shadow:var(--sn-shadow-lg)}.user-account-panel-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.75rem}.user-account-panel-head h2{margin:0;font-size:.95rem;font-weight:600}.user-account-role{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--sn-muted);padding:.15rem .45rem;border-radius:999px;background:var(--sn-surface-inset)}.user-account-msg{margin:0 0 .65rem;font-size:.8rem}.user-account-form{display:flex;flex-direction:column;gap:.65rem}.user-account-form label{display:flex;flex-direction:column;gap:.3rem;font-size:.8rem;font-weight:500;color:var(--sn-text-secondary)}.user-account-form input{font-size:.85rem}.user-account-form--password{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--sn-border-light)}.user-account-form--password h3{margin:0;font-size:.85rem;font-weight:600;color:var(--sn-text)}.user-account-form .btn-sm{align-self:flex-start}.user-account-panel-footer{margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--sn-border-light)}.user-account-logout{width:100%;justify-content:center}.stat-value{font-weight:600;font-size:1.75rem;color:var(--sn-text);background:none;-webkit-text-fill-color:unset}.dashboard-page .page-header{margin-bottom:.85rem}.dashboard-header h1{font-size:1.25rem}@media (max-width: 640px){.user-account-trigger--toolbar .user-account-name{display:none}.shell-toolbar{padding:.15rem}.theme-toggle-toolbar .theme-toggle-btn{width:1.85rem;height:1.85rem}}.dashboard-error{margin:0 0 .65rem;font-size:.85rem}.dash-metrics{display:flex;flex-wrap:wrap;gap:.45rem;margin-bottom:.75rem}.dash-metric{display:flex;align-items:baseline;gap:.35rem;padding:.4rem .65rem;border:1px solid var(--sn-border);border-radius:var(--sn-radius-sm);background:var(--sn-surface);text-decoration:none;color:inherit;transition:background var(--sn-transition),border-color var(--sn-transition)}.dash-metric:hover{background:var(--sn-surface-hover);border-color:#0ea5e94d}.dash-metric--warn{border-color:var(--sn-warn);background:var(--sn-warn-soft)}.dash-metric-value{font-size:1rem;font-weight:700;letter-spacing:-.02em;color:var(--sn-text);line-height:1}.dash-metric-label{font-size:.72rem;font-weight:500;color:var(--sn-muted);white-space:nowrap}.dash-alerts{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.75rem}.dash-alert{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .55rem;border:1px solid var(--sn-border);border-radius:var(--sn-radius-sm);background:var(--sn-warn-soft);text-decoration:none;color:inherit;font-size:.78rem}.dash-alert:hover{border-color:var(--sn-warn)}.dash-alert-text{color:var(--sn-text-secondary)}.dash-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.65rem}.dash-grid-pair{grid-column:1 / -1;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem;align-items:stretch}.dash-grid-pair--compact{align-items:stretch}.dash-tile-compact.dash-panel--domains .dash-domains-list{overflow-y:auto;overscroll-behavior:contain}.dash-tile-compact.dash-live-tile{padding:.45rem .6rem}.dash-tile-compact .dash-live-head{margin-bottom:.3rem}.dash-tile-compact .dash-live-meta{max-width:52%;overflow:hidden;text-overflow:ellipsis}.dash-tile-compact .dash-live-body{gap:.3rem;overflow:hidden}.dash-tile-compact .dash-live-top{gap:.35rem}.dash-tile-compact .dash-live-rps-card{padding:.3rem .45rem}.dash-tile-compact .dash-live-rps{font-size:1.2rem}.dash-tile-compact .dash-live-metric{min-height:2rem;padding:.22rem .35rem}.dash-tile-compact .dash-live-metric-value{font-size:.75rem}.dash-tile-compact .dash-live-status-bar{height:6px;margin-bottom:0}.dash-tile-compact .dash-live-code-chips,.dash-tile-compact .dash-live-hosts-block,.dash-tile-compact .dash-live-foot{display:none}.dash-tile-compact .dash-live-section-title{margin-bottom:.2rem}.dash-tile-compact.dash-live-tile--loading .dash-live-skeleton{min-height:0;flex:1}.dash-tile-compact.dash-panel--domains{padding:.45rem .6rem}.dash-tile-compact .dash-domains-row{padding:.16rem 0;font-size:.72rem;line-height:1.25}.dash-tile-compact .dash-panel-head{margin-bottom:.2rem}.dash-tile-compact .dash-panel-title{margin-bottom:0}.dashboard-page{--dash-tile-height: 280px;--dash-tile-compact-height: 140px}.dash-tile-equal{display:flex;flex-direction:column;min-height:var(--dash-tile-height);height:100%;align-self:stretch}.dash-tile-compact{min-height:var(--dash-tile-compact-height);max-height:var(--dash-tile-compact-height);height:var(--dash-tile-compact-height);overflow:hidden}.dash-panel{padding:.65rem .75rem;background:var(--sn-surface);border:1px solid var(--sn-border);border-radius:var(--sn-radius-md);min-width:0}.dash-panel--wide{grid-column:span 2}.dash-panel-head{display:flex;align-items:center;gap:.4rem;margin-bottom:.35rem}.dash-panel-head .dash-panel-title{margin-bottom:0}.dash-panel-badge{font-size:.62rem;font-weight:700;padding:.1rem .4rem;border-radius:999px;background:var(--sn-surface-inset);color:var(--sn-muted)}.dash-panel--domains{display:flex;flex-direction:column;min-height:0}.dash-domains-list{list-style:none;margin:0;padding:0;overflow-y:auto;flex:1;min-height:0}.dash-domains-row{display:flex;align-items:baseline;justify-content:space-between;gap:.75rem;padding:.28rem 0;border-bottom:1px solid var(--sn-border-light);font-size:.78rem;line-height:1.35}.dash-domains-row:last-child{border-bottom:none}.dash-domains-name{flex:1;min-width:0;word-break:break-word;color:var(--sn-text-secondary)}.dash-domains-count{flex-shrink:0;font-weight:700;font-variant-numeric:tabular-nums;color:var(--sn-text)}.dash-panel-title{margin:0 0 .35rem;font-size:.72rem;font-weight:600;letter-spacing:.02em;text-transform:uppercase;color:var(--sn-muted)}.dash-panel--donut{display:flex;flex-direction:column}.dash-panel--donut.dash-tile-equal .dash-donut{flex:1;justify-content:center}.dash-donut{display:flex;flex-direction:column;gap:.35rem;flex:1;min-height:0}.dash-donut-chart{min-height:0}.dash-donut-legend{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.22rem}.dash-donut-legend-row{display:grid;grid-template-columns:.5rem minmax(0,1fr) auto auto;align-items:center;gap:.35rem .45rem;font-size:.72rem;line-height:1.3}.dash-donut-legend-dot{width:.5rem;height:.5rem;border-radius:50%;flex-shrink:0}.dash-donut-legend-name{color:var(--sn-text-secondary);font-weight:600}.dash-donut-legend-value{font-weight:700;font-variant-numeric:tabular-nums;color:var(--sn-text);text-align:right}.dash-donut-legend-pct{font-weight:600;font-variant-numeric:tabular-nums;color:var(--sn-muted);min-width:2rem;text-align:right}.dash-empty{margin:0;font-size:.8rem;padding:1.5rem 0;text-align:center}.dash-kv{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.35rem .5rem;margin:0}.dash-kv>div{display:flex;flex-direction:column;gap:.1rem}.dash-kv-wide{grid-column:1 / -1}.dash-kv dt{font-size:.68rem;font-weight:500;color:var(--sn-muted);text-transform:uppercase;letter-spacing:.03em}.dash-kv dd{margin:0;font-size:.82rem;font-weight:600;color:var(--sn-text)}.dash-bad{color:var(--sn-danger)}.dash-nginx-tile{padding:.5rem .6rem;background:linear-gradient(155deg,var(--sn-surface) 0%,var(--sn-surface-inset) 100%);border:1px solid var(--sn-border);border-radius:var(--sn-radius-md);min-width:0}.dash-nginx-tile--ok{border-color:#10b98147}.dash-nginx-tile--bad{border-color:#ef444459;background:linear-gradient(155deg,var(--sn-surface) 0%,var(--sn-danger-soft, rgba(239, 68, 68, .06)) 100%)}.dash-nginx-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.4rem}.dash-nginx-title-row{display:flex;align-items:center;gap:.35rem}.dash-nginx-dot{width:6px;height:6px;border-radius:50%}.dash-nginx-dot--ok{background:var(--sn-success);box-shadow:0 0 0 2px var(--sn-success-soft)}.dash-nginx-dot--bad{background:var(--sn-danger);box-shadow:0 0 0 2px var(--sn-danger-soft, rgba(239, 68, 68, .15));animation:dash-nginx-alert 2s ease-in-out infinite}.dash-nginx-dot--muted{background:var(--sn-muted);opacity:.6}@keyframes dash-nginx-alert{0%,to{opacity:1}50%{opacity:.45}}.dash-nginx-title{font-size:.68rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--sn-text-secondary)}.dash-nginx-mode{font-size:.6rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;padding:.12rem .4rem;border-radius:999px;border:1px solid var(--sn-border);background:var(--sn-surface-inset);color:var(--sn-muted)}.dash-nginx-mode--docker{color:#2563eb;border-color:#2563eb40;background:#2563eb14}.dash-nginx-mode--host{color:#7c3aed;border-color:#7c3aed40;background:#7c3aed14}.dash-nginx-hero{display:flex;align-items:center;gap:.5rem;padding:.45rem .5rem;margin-bottom:.4rem;border-radius:var(--sn-radius-sm);background:var(--sn-surface-inset);border:1px solid var(--sn-border-light)}.dash-nginx-hero--ok{border-color:#10b98133;background:var(--sn-success-soft)}.dash-nginx-hero--bad{border-color:#ef444440;background:var(--sn-danger-soft, rgba(239, 68, 68, .08))}.dash-nginx-hero-icon{width:1.75rem;height:1.75rem;display:grid;place-items:center;border-radius:50%;font-size:.9rem;font-weight:800;flex-shrink:0;background:var(--sn-surface);color:var(--sn-text)}.dash-nginx-hero--ok .dash-nginx-hero-icon{color:var(--sn-success)}.dash-nginx-hero--bad .dash-nginx-hero-icon{color:var(--sn-danger)}.dash-nginx-hero-text{display:flex;flex-direction:column;gap:.05rem;min-width:0}.dash-nginx-hero-label{font-size:.95rem;font-weight:800;letter-spacing:-.02em;color:var(--sn-text);line-height:1.1}.dash-nginx-hero-sub{font-size:.62rem;font-weight:500;color:var(--sn-muted);text-transform:uppercase;letter-spacing:.04em}.dash-nginx-stats{display:flex;flex-wrap:wrap;gap:.35rem .55rem;margin-bottom:.35rem}.dash-nginx-stat{display:flex;flex-direction:column;gap:.05rem;min-width:3.5rem}.dash-nginx-stat-label{font-size:.58rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--sn-muted)}.dash-nginx-stat-value{font-size:.75rem;font-weight:700;color:var(--sn-text);font-variant-numeric:tabular-nums}.dash-nginx-stat-value--ok{color:var(--sn-success)}.dash-nginx-stat-value--bad{color:var(--sn-danger)}.dash-nginx-link{margin-top:auto;font-size:.68rem;font-weight:600;color:var(--sn-accent);text-decoration:none}.dash-nginx-link:hover{text-decoration:underline}.dash-live-tile{display:flex;flex-direction:column;padding:.65rem .75rem;background:var(--sn-surface);border:1px solid var(--sn-border);border-radius:var(--sn-radius-md);min-width:0;transition:border-color .35s ease,box-shadow .35s ease}.dash-live-tile--pulse{border-color:#0ea5e973;box-shadow:0 0 0 1px #0ea5e91f}.dash-live-tile--loading .dash-live-skeleton{flex:1;min-height:12rem;margin-top:.35rem;border-radius:var(--sn-radius-sm);background:linear-gradient(90deg,var(--sn-surface-inset) 25%,var(--sn-surface-hover) 50%,var(--sn-surface-inset) 75%);background-size:200% 100%;animation:dash-live-shimmer 1.2s ease-in-out infinite}@keyframes dash-live-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.dash-live-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.5rem;flex-shrink:0}.dash-live-title-row{display:flex;align-items:center;gap:.35rem}.dash-live-dot{width:6px;height:6px;border-radius:50%;background:var(--sn-success);box-shadow:0 0 0 2px var(--sn-success-soft);animation:dash-live-dot 2.2s ease-in-out infinite}@keyframes dash-live-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.82)}}.dash-live-title{font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--sn-muted)}.dash-live-meta{font-size:.62rem;color:var(--sn-muted);white-space:nowrap}.dash-live-body{flex:1;min-height:0;display:flex;flex-direction:column;gap:.55rem}.dash-live-top{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);gap:.5rem;flex-shrink:0}.dash-live-rps-card{display:flex;flex-direction:column;justify-content:center;gap:.15rem;padding:.55rem .65rem;border-radius:var(--sn-radius-sm);background:linear-gradient(145deg,var(--sn-accent-soft) 0%,var(--sn-surface-inset) 100%);border:1px solid rgba(14,165,233,.18)}.dash-live-rps-label{font-size:.62rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--sn-muted)}.dash-live-rps-row{display:flex;align-items:baseline;gap:.3rem}.dash-live-rps{font-size:1.65rem;font-weight:800;letter-spacing:-.03em;color:var(--sn-text);font-variant-numeric:tabular-nums;line-height:1}.dash-live-rps-unit{font-size:.75rem;font-weight:600;color:var(--sn-muted)}.dash-live-rps-sub{font-size:.68rem;color:var(--sn-text-secondary)}.dash-live-metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.35rem}.dash-live-metric{display:flex;flex-direction:column;justify-content:center;gap:.1rem;padding:.35rem .45rem;border-radius:6px;background:var(--sn-surface-inset);border:1px solid var(--sn-border-light);min-height:2.5rem}.dash-live-metric-label{font-size:.58rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--sn-muted);line-height:1.2}.dash-live-metric-value{font-size:.82rem;font-weight:700;color:var(--sn-text)}.dash-live-section-title{display:block;margin-bottom:.3rem;font-size:.62rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--sn-muted)}.dash-live-codes{flex-shrink:0}.dash-live-value{display:inline-block;font-variant-numeric:tabular-nums;transition:color .2s ease,transform .2s ease}.dash-live-value--bump{animation:dash-live-bump .45s ease}@keyframes dash-live-bump{0%{color:var(--sn-accent);transform:translateY(-1px) scale(1.06)}to{color:inherit;transform:none}}.dash-live-status-bar{display:flex;height:8px;border-radius:999px;overflow:hidden;background:var(--sn-surface-inset);margin-bottom:.35rem}.dash-live-status-seg{min-width:2px;transition:width .5s ease}.dash-live-status-seg--ok{background:var(--sn-success)}.dash-live-status-seg--info{background:var(--sn-info, #3b82f6)}.dash-live-status-seg--warn{background:var(--sn-warn)}.dash-live-status-seg--bad{background:var(--sn-danger)}.dash-live-status-seg--muted{background:var(--sn-muted)}.dash-live-code-chips{display:flex;flex-wrap:wrap;gap:.3rem}.dash-live-code-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.18rem .45rem;border-radius:999px;font-size:.68rem;font-weight:700;font-variant-numeric:tabular-nums;background:var(--sn-surface-inset);border:1px solid var(--sn-border-light)}.dash-live-code-chip-code{opacity:.85}.dash-live-code-chip--ok{color:var(--sn-success);background:var(--sn-success-soft);border-color:transparent}.dash-live-code-chip--info{color:var(--sn-info, #3b82f6);background:#3b82f61a;border-color:transparent}.dash-live-code-chip--warn{color:var(--sn-warn);background:var(--sn-warn-soft);border-color:transparent}.dash-live-code-chip--bad{color:var(--sn-danger);background:var(--sn-danger-soft, rgba(239, 68, 68, .08));border-color:transparent}.dash-live-hosts-block{flex:1;min-height:0;display:flex;flex-direction:column}.dash-live-hosts{list-style:none;margin:0;padding:0;flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column}.dash-live-hosts li{display:grid;grid-template-columns:minmax(0,1fr) 3rem 2.5rem;align-items:center;gap:.4rem;padding:.32rem 0;border-bottom:1px solid var(--sn-border-light);font-size:.75rem}.dash-live-hosts li:last-child{border-bottom:none}.dash-live-host-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--sn-text-secondary)}.dash-live-host-track{height:5px;border-radius:999px;background:var(--sn-surface-inset);overflow:hidden}.dash-live-host-fill{display:block;height:100%;border-radius:inherit;background:var(--sn-accent);opacity:.7;transition:width .5s ease}.dash-live-host-count{text-align:right;font-size:.75rem;font-weight:700;color:var(--sn-text)}.dash-live-foot{flex-shrink:0;padding-top:.45rem;margin-top:.15rem;border-top:1px solid var(--sn-border-light)}.dash-live-link{font-size:.68rem;font-weight:600;color:var(--sn-accent);text-decoration:none}.dash-live-link:hover{text-decoration:underline}.dash-link{display:inline-block;margin-top:.45rem;font-size:.75rem;font-weight:500;color:var(--sn-accent);text-decoration:none}.dash-link:hover{text-decoration:underline}@media (max-width: 1100px){.dash-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.dash-panel--wide{grid-column:span 2}}@media (max-width: 640px){.dash-grid,.dash-grid-pair{grid-template-columns:1fr}.dash-tile-equal{min-height:0}.dash-tile-compact{min-height:var(--dash-tile-compact-height);max-height:none;height:auto}.dash-panel--wide{grid-column:span 1}.dash-metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}}.login-page{display:grid;place-items:center;min-height:100vh;padding:1.5rem;background:var(--sn-bg)}.login-card{width:min(400px,100%);padding:2rem;background:var(--sn-surface);border:1px solid var(--sn-border);border-radius:var(--sn-radius-lg);box-shadow:var(--sn-shadow-md)}.login-card-shine{display:none}.login-brand{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}.login-brand h1{margin:0;font-size:1.25rem;font-weight:600}.login-theme{display:flex;justify-content:center;margin-bottom:1.25rem}.shell-toolbar--solo{padding:.2rem .25rem}.field-label{display:flex;flex-direction:column;gap:.35rem;font-size:.85rem;font-weight:500;color:var(--sn-text-secondary);margin-bottom:1rem}.theme-toggle-compact{display:flex;gap:.2rem;padding:.2rem;background:var(--sn-surface-inset);border:1px solid var(--sn-border);border-radius:var(--sn-radius-sm)}.theme-toggle-btn{flex:1;padding:.35rem;border-radius:4px;font-size:.75rem;transition:background var(--sn-transition)}.theme-toggle-btn.active{background:var(--sn-surface);color:var(--sn-text);box-shadow:var(--sn-shadow-xs)}.charts-page .page-header{align-items:center;margin-bottom:.85rem}.charts-header-text{min-width:0}.charts-page .page-header-lead{margin:.2rem 0 0;font-size:.85rem}.charts-toolbar{display:grid;grid-template-columns:minmax(180px,1.6fr) minmax(140px,1fr) minmax(120px,.85fr) auto;gap:.75rem 1rem;align-items:end;margin-bottom:1rem;padding:.9rem 1.1rem;background:linear-gradient(180deg,var(--sn-bg-subtle) 0%,var(--sn-surface) 100%);border:1px solid var(--sn-border);border-radius:var(--sn-radius-lg);box-shadow:var(--sn-shadow-xs)}.charts-toolbar-label{display:block;margin-bottom:.35rem;font-size:.68rem;font-weight:700;color:var(--sn-muted);text-transform:uppercase;letter-spacing:.06em}.charts-toolbar-field{display:flex;flex-direction:column;min-width:0;margin:0}.charts-toolbar-input,.charts-toolbar-select{width:100%;min-height:2.45rem;padding:.45rem .75rem;font-size:.88rem;font-weight:500;color:var(--sn-text);background:var(--sn-surface);border:1px solid var(--sn-border);border-radius:var(--sn-radius);box-shadow:inset 0 1px 2px #0f172a0a;transition:border-color .15s ease,box-shadow .15s ease}.charts-toolbar-input:focus,.charts-toolbar-select:focus{outline:none;border-color:var(--sn-accent);box-shadow:0 0 0 3px #4f8cff26}.charts-toolbar-input::placeholder{color:var(--sn-muted-light)}.charts-toolbar-refresh{align-self:end;min-height:2.45rem;white-space:nowrap}@media (max-width: 900px){.charts-toolbar{grid-template-columns:1fr 1fr}.charts-toolbar-field--search{grid-column:1 / -1}.charts-toolbar-refresh{grid-column:1 / -1;width:100%}}@media (max-width: 520px){.charts-toolbar{grid-template-columns:1fr}}.charts-hint{margin:0 0 .75rem;font-size:.85rem}.charts-kpis{margin-bottom:1.25rem}.charts-primary-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;margin-bottom:1rem}.charts-card{display:flex;flex-direction:column;min-height:0;padding:1.1rem 1.2rem 1.15rem;background:var(--sn-surface);border:1px solid var(--sn-border);border-radius:var(--sn-radius-lg);box-shadow:var(--sn-shadow-card);transition:border-color .15s ease,box-shadow .15s ease}.charts-card:hover{border-color:color-mix(in srgb,var(--sn-accent) 22%,var(--sn-border));box-shadow:var(--sn-shadow-md, var(--sn-shadow-card))}.charts-card-head{margin:0 0 .85rem;padding-bottom:.75rem;border-bottom:1px solid color-mix(in srgb,var(--sn-border) 85%,transparent)}.charts-card-title{margin:0;font-size:1rem;font-weight:600;color:var(--sn-text);letter-spacing:-.01em}.charts-card-subtitle{margin:.3rem 0 0;font-size:.8rem;line-height:1.4;color:var(--sn-muted)}.charts-card-body{flex:1;min-height:0}.charts-empty{display:flex;align-items:center;justify-content:center;min-height:200px;text-align:center;margin:0}.charts-geo-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;margin-bottom:1rem}.charts-geo-card{padding:.85rem 1rem .95rem}.charts-geo-card .charts-card-head{margin-bottom:.55rem;padding-bottom:.5rem}.charts-geo-card .charts-card-title{font-size:.92rem}.charts-geo-card .charts-card-subtitle{font-size:.74rem;margin-top:.15rem}.charts-section-title{margin:0 0 .85rem;font-size:1rem;font-weight:600;color:var(--sn-text)}.charts-errors-summary{margin-bottom:1rem}@media (max-width: 1100px){.charts-primary-grid,.charts-geo-grid{grid-template-columns:1fr}}@media (max-width: 720px){.charts-page .page-header{flex-direction:column}.charts-filters{flex-wrap:wrap;width:100%}}.docs-page{max-width:none}.docs-page-header{margin-bottom:1rem}.docs-page .page-header-lead{margin:.35rem 0 0;font-size:.9rem;color:var(--sn-muted);line-height:1.5;max-width:52rem}.docs-shell{display:grid;grid-template-columns:minmax(240px,280px) minmax(0,1fr);gap:1.25rem;align-items:start}.docs-sidebar-sticky{position:sticky;top:.75rem;max-height:calc(100vh - 1.5rem);display:flex;flex-direction:column;gap:.75rem;overflow:hidden}.docs-search{display:flex;flex-direction:column;gap:.3rem;flex-shrink:0}.docs-search-label{font-size:.68rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--sn-muted)}.docs-search input{width:100%;padding:.5rem .65rem;border-radius:var(--sn-radius-sm);border:1px solid var(--sn-border);background:var(--sn-bg);color:var(--sn-text);font-size:.84rem}.docs-search input:focus{outline:none;border-color:var(--sn-accent);box-shadow:0 0 0 2px var(--sn-accent-soft)}.docs-toc{flex:1;min-height:0;overflow-y:auto;padding:.65rem .5rem;border-radius:var(--sn-radius);background:var(--sn-surface);border:1px solid var(--sn-border-light)}.docs-toc-group h2{font-size:.65rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--sn-muted);margin:.85rem 0 .4rem;padding:0 .35rem}.docs-toc-group:first-child h2{margin-top:.15rem}.docs-toc-chapter{margin-bottom:.35rem}.docs-toc-chapter-btn{display:block;width:100%;text-align:left;padding:.3rem .4rem;border:none;background:transparent;font-size:.8rem;font-weight:600;color:var(--sn-text);cursor:pointer;border-radius:var(--sn-radius-sm)}.docs-toc-chapter-btn:hover{background:var(--sn-surface-hover);color:var(--sn-accent)}.docs-toc-chapter ul{list-style:none;margin:0;padding:0 0 0 .55rem;border-left:1px solid var(--sn-border-light)}.docs-toc-section-btn{display:block;width:100%;text-align:left;padding:.22rem .4rem;border:none;background:transparent;font-size:.76rem;color:var(--sn-text-secondary);cursor:pointer;border-radius:4px;line-height:1.35}.docs-toc-section-btn:hover{color:var(--sn-text);background:var(--sn-surface-hover)}.docs-toc-section-btn.is-active{color:var(--sn-accent);background:var(--sn-accent-soft);font-weight:500}.docs-toc-empty{font-size:.8rem;color:var(--sn-muted);padding:.5rem}.docs-sidebar-panel-links{flex-shrink:0;max-height:140px;overflow-y:auto;padding:.5rem;border-radius:var(--sn-radius-sm);border:1px dashed var(--sn-border-light)}.docs-sidebar-panel-links-title{display:block;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--sn-muted);margin-bottom:.35rem}.docs-panel-link{display:block;font-size:.74rem;color:var(--sn-text-secondary);text-decoration:none;padding:.15rem 0}.docs-panel-link:hover{color:var(--sn-accent)}.docs-content-panel{min-width:0;padding:1.5rem 1.75rem 2rem;border-radius:var(--sn-radius-lg);background:var(--sn-surface);border:1px solid var(--sn-border-light);box-shadow:0 1px 3px #0000000a}.docs-chapter{padding-bottom:2rem;margin-bottom:2rem;border-bottom:1px solid var(--sn-border-light);scroll-margin-top:1rem}.docs-chapter:last-of-type{border-bottom:none;margin-bottom:0}.docs-chapter-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.25rem}.docs-chapter-group{display:inline-block;font-size:.68rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--sn-accent);margin-bottom:.35rem}.docs-chapter-head h2{margin:0 0 .4rem;font-size:1.5rem;font-weight:700;letter-spacing:-.02em;color:var(--sn-text)}.docs-chapter-intro{margin:0;font-size:.92rem;line-height:1.55;color:var(--sn-muted);max-width:46rem}.docs-open-panel{flex-shrink:0;white-space:nowrap}.docs-section{margin-bottom:1.5rem;scroll-margin-top:1.25rem}.docs-section h3{margin:0 0 .75rem;padding-bottom:.4rem;font-size:1.05rem;font-weight:600;color:var(--sn-text);border-bottom:1px solid var(--sn-border-light)}.docs-section-body>*:last-child{margin-bottom:0}.docs-section p{margin:0 0 .7rem;font-size:.88rem;line-height:1.6;color:var(--sn-text-secondary)}.docs-section ul,.docs-section ol{margin:0 0 .8rem;padding-left:1.35rem;font-size:.88rem;line-height:1.6;color:var(--sn-text-secondary)}.docs-section li{margin-bottom:.4rem}.docs-section li::marker{color:var(--sn-muted)}.docs-inline-code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.82em;padding:.1em .35em;border-radius:4px;background:var(--sn-bg-subtle);border:1px solid var(--sn-border-light);color:var(--sn-text)}.docs-table-wrap{overflow-x:auto;margin-bottom:.85rem;border-radius:var(--sn-radius-sm);border:1px solid var(--sn-border-light)}.docs-table{width:100%;border-collapse:collapse;font-size:.82rem}.docs-table th,.docs-table td{padding:.5rem .7rem;text-align:left;vertical-align:top;border-bottom:1px solid var(--sn-border-light)}.docs-table tr:last-child th,.docs-table tr:last-child td{border-bottom:none}.docs-table th{background:var(--sn-bg-subtle);font-weight:600;color:var(--sn-text);white-space:nowrap}.docs-table td{color:var(--sn-text-secondary)}.docs-table tbody tr:hover td{background:color-mix(in srgb,var(--sn-accent) 4%,transparent)}.docs-code-figure{margin:0 0 .85rem}.docs-code-figure figcaption{font-size:.75rem;font-weight:500;color:var(--sn-muted);margin-bottom:.35rem}.docs-code{margin:0;padding:.85rem 1rem;border-radius:var(--sn-radius-sm);background:var(--sn-bg-subtle);border:1px solid var(--sn-border-light);overflow-x:auto;font-size:.78rem;line-height:1.5}.docs-code code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;color:var(--sn-text);white-space:pre}.docs-callout{margin:0 0 .85rem;padding:.7rem .9rem;border-radius:var(--sn-radius-sm);font-size:.86rem;line-height:1.55}.docs-callout-label{display:block;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-bottom:.25rem}.docs-callout--tip{background:color-mix(in srgb,var(--sn-accent) 10%,var(--sn-surface));border:1px solid color-mix(in srgb,var(--sn-accent) 22%,transparent);color:var(--sn-text-secondary)}.docs-callout--tip .docs-callout-label{color:var(--sn-accent)}.docs-callout--warn{background:color-mix(in srgb,#f59e0b 10%,var(--sn-surface));border:1px solid color-mix(in srgb,#f59e0b 28%,transparent);color:var(--sn-text-secondary)}.docs-callout--warn .docs-callout-label{color:#d97706}.docs-link-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.55rem;margin-bottom:.85rem}.docs-link-card{display:block;padding:.65rem .75rem;border-radius:var(--sn-radius-sm);background:var(--sn-bg-subtle);border:1px solid var(--sn-border-light);text-decoration:none;transition:border-color var(--sn-transition),background var(--sn-transition)}.docs-link-card:hover{border-color:var(--sn-accent);background:var(--sn-accent-soft)}.docs-link-card strong{display:block;font-size:.82rem;color:var(--sn-text)}.docs-link-card span{font-size:.72rem;color:var(--sn-muted)}.docs-page-footer,.docs-empty{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--sn-border-light);font-size:.84rem;color:var(--sn-muted)}.docs-page-footer a{color:var(--sn-accent)}@media (max-width: 960px){.docs-shell{grid-template-columns:1fr}.docs-sidebar-sticky{position:static;max-height:none}.docs-toc{max-height:220px}.docs-chapter-head{flex-direction:column}.docs-content-panel{padding:1rem 1.1rem 1.5rem}}
