:root{--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace;--surface: #f8fafc;--surface-dim: #e2e8f0;--surface-bright: #ffffff;--surface-container-lowest: #ffffff;--surface-container-low: #f1f5f9;--surface-container: #e2e8f0;--surface-container-high: #cbd5e1;--surface-container-highest: #94a3b8;--on-surface: #0f172a;--on-surface-variant: #475569;--border-subtle: #e2e8f0;--primary: #000000;--on-primary: #ffffff;--secondary: #006591;--on-secondary: #ffffff;--secondary-container: #39b8fd;--on-secondary-container: #004666;--status-success: #10b981;--status-warning: #f59e0b;--status-error: #ef4444;--status-info: #3b82f6;--status-pro: #8b5cf6;--status-success-bg: rgba(16, 185, 129, .1);--status-warning-bg: rgba(245, 158, 11, .1);--status-error-bg: rgba(239, 68, 68, .1);--status-info-bg: rgba(59, 130, 246, .1);--status-pro-bg: rgba(139, 92, 246, .1);--radius-sm: .125rem;--radius-md: .25rem;--radius-lg: .5rem;--radius-xl: .75rem;--radius-xxl: 1rem;--radius-full: 9999px;--sidebar-w: 260px;--gutter: 1.5rem;--container-padding: 2rem;--stack-sm: .5rem;--stack-md: 1rem;--stack-lg: 2rem;--text-headline-lg: 2.25rem;--text-headline-lg-mobile: 1.75rem;--text-headline-md: 1.5rem;--text-body-lg: 1.125rem;--text-body-md: 1rem;--text-label-sm: .875rem;--text-mono: .9375rem;--leading-headline-lg: 2.75rem;--leading-headline-md: 2rem;--leading-body-lg: 1.625rem;--leading-body-md: 1.375rem;--leading-label-sm: 1.125rem;--shadow-hover: 0 4px 20px -2px rgba(0, 0, 0, .05);--shadow-modal: 0 20px 25px -5px rgba(0, 0, 0, .1);--z-modal: 300;--bg-base: var(--surface);--bg-elevated: var(--surface-container);--bg-surface: var(--surface-container-lowest);--bg-hover: var(--surface-container-low);--border: var(--border-subtle);--border-focus: var(--secondary);--text: var(--on-surface);--text-muted: var(--on-surface-variant);--text-dim: #6b7280;--accent: var(--secondary);--accent-hover: #004d6e;--accent-muted: rgba(0, 101, 145, .12);--success: var(--status-success);--success-bg: var(--status-success-bg);--warn: var(--status-warning);--warn-bg: var(--status-warning-bg);--danger: var(--status-error);--danger-bg: var(--status-error-bg);--radius-sm-legacy: var(--radius-md);--space-1: var(--stack-sm);--space-2: var(--stack-sm);--space-3: var(--stack-md);--space-4: var(--stack-md);--space-5: 1.25rem;--space-6: var(--gutter);--page-max: 1200px;--header-h: 56px;--text-xs: var(--text-label-sm);--text-sm: var(--text-body-md);--text-base: var(--text-body-md);--text-lg: var(--text-body-lg);--text-xl: var(--text-headline-lg);--transition-fast: .15s ease;--transition-normal: .2s ease-in-out}@media (prefers-color-scheme: dark){:root:not([data-theme=light]){color-scheme:dark;--surface: #090d16;--surface-dim: #020617;--surface-bright: #0f172a;--surface-container-lowest: #131b2e;--surface-container-low: #1e293b;--surface-container: #0f172a;--surface-container-high: #334155;--surface-container-highest: #475569;--on-surface: #f8fafc;--on-surface-variant: #94a3b8;--border-subtle: #1e293b;--shadow-hover: 0 4px 20px -2px rgba(0, 0, 0, .35);--shadow-modal: 0 20px 25px -5px rgba(0, 0, 0, .45)}}:root[data-theme=dark],.theme-dark{color-scheme:dark;--surface: #090d16;--surface-dim: #020617;--surface-bright: #0f172a;--surface-container-lowest: #131b2e;--surface-container-low: #1e293b;--surface-container: #0f172a;--surface-container-high: #334155;--surface-container-highest: #475569;--on-surface: #f8fafc;--on-surface-variant: #94a3b8;--border-subtle: #1e293b;--shadow-hover: 0 4px 20px -2px rgba(0, 0, 0, .35);--shadow-modal: 0 20px 25px -5px rgba(0, 0, 0, .45)}*,*:before,*:after{box-sizing:border-box}html{font-size:16px;-webkit-text-size-adjust:100%}body{margin:0;font-family:var(--font-sans);font-size:var(--text-body-md);line-height:var(--leading-body-md);background:var(--surface);color:var(--on-surface);overflow-x:hidden}a{color:var(--secondary);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4{margin:0 0 var(--stack-md);font-weight:600;line-height:1.25;color:var(--primary)}h1{font-size:var(--text-headline-lg);line-height:var(--leading-headline-lg);font-weight:700;letter-spacing:-.02em}h2,h3{font-size:var(--text-headline-md);line-height:var(--leading-headline-md);font-weight:600}h4{font-size:var(--text-body-lg);line-height:var(--leading-body-lg);color:var(--on-surface-variant);font-weight:500}.headline-lg{font-size:var(--text-headline-lg);line-height:var(--leading-headline-lg);font-weight:700;letter-spacing:-.02em}.headline-md{font-size:var(--text-headline-md);line-height:var(--leading-headline-md);font-weight:600}.body-lg{font-size:var(--text-body-lg);line-height:var(--leading-body-lg);font-weight:500}.body-md{font-size:var(--text-body-md);line-height:var(--leading-body-md);font-weight:400}.label-sm{font-size:var(--text-label-sm);line-height:var(--leading-label-sm);font-weight:600;letter-spacing:.05em;text-transform:uppercase}.mono-code{font-family:var(--font-mono);font-size:var(--text-mono);line-height:var(--leading-body-md)}p{margin:0 0 var(--stack-md)}code,.mono-break{font-family:var(--font-mono);font-size:var(--text-mono);background:var(--surface-container-low);padding:.1em .35em;border-radius:var(--radius-sm)}input,button,select,textarea{font:inherit;border-radius:var(--radius-md);border:1px solid var(--border-subtle);color:var(--on-surface)}input:not([type=checkbox]):not([type=radio]),select,textarea{width:100%;padding:.5rem .75rem;margin:var(--stack-sm) 0 var(--stack-md);background:var(--surface-container-low);min-height:44px;font-size:var(--text-body-md);border-radius:var(--radius-lg)}input[type=checkbox],input[type=radio]{width:1.125rem;height:1.125rem;min-width:1.125rem;min-height:1.125rem;max-width:1.125rem;padding:0;margin:0;flex-shrink:0;accent-color:var(--secondary);cursor:pointer;vertical-align:middle;background:var(--surface-bright)}input[type=checkbox]:focus,input[type=radio]:focus{outline:none;border-color:var(--secondary);box-shadow:0 0 0 2px var(--accent-muted)}.check-row,label.check-row,.portal-editor-check,label.field.field-check,label.field:has(>input[type=checkbox]),label.field:has(>input[type=radio]),label.field:has(>span>input[type=checkbox]),label.field:has(>span>input[type=radio]){display:flex;align-items:flex-start;gap:.5rem;width:auto;text-transform:none;font-weight:500;letter-spacing:normal;font-size:var(--text-body-md);color:var(--on-surface);cursor:pointer}.check-row input[type=checkbox],.check-row input[type=radio],.portal-editor-check input[type=checkbox],.portal-editor-check input[type=radio],label.field.field-check input[type=checkbox],label.field.field-check input[type=radio],label.field:has(>input[type=checkbox]) input[type=checkbox],label.field:has(>input[type=radio]) input[type=radio],label.field:has(>span>input[type=checkbox]) input[type=checkbox],label.field:has(>span>input[type=radio]) input[type=radio]{margin-top:.2rem}.data-table input[type=checkbox],.data-table input[type=radio]{margin:0;display:inline-block}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--secondary);box-shadow:0 0 0 2px var(--accent-muted)}textarea{resize:vertical;min-height:88px}button{display:inline-flex;align-items:center;justify-content:center;gap:var(--stack-sm);width:auto;min-height:40px;padding:.5rem 1rem;margin:0;background:var(--primary);color:var(--on-primary);border:none;font-weight:600;font-size:var(--text-body-md);cursor:pointer;white-space:nowrap;transition:transform .15s ease,background .15s ease,box-shadow .15s ease}button:hover{background:#1a1a1a}button:active{transform:scale(.98)}button:disabled{opacity:.5;cursor:not-allowed}button.secondary{background:var(--surface-container-lowest);color:var(--on-surface);border:1px solid var(--border-subtle)}button.secondary:hover{background:var(--surface-container-low)}button.danger{background:var(--status-error);color:#fff;border-color:var(--status-error)}button.danger:hover{filter:brightness(1.05)}button.btn-sm{min-height:32px;padding:.25rem .65rem;font-size:var(--text-label-sm)}button.btn-block{width:100%}label.field{display:block;font-size:var(--text-label-sm);font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--on-surface-variant);margin-bottom:var(--stack-sm)}label.field input,label.field select{margin-top:var(--stack-sm);margin-bottom:0;text-transform:none;font-weight:400;letter-spacing:normal}.layout{display:flex;min-height:100vh;max-height:100vh;overflow:hidden}.sidebar,.side{flex:0 0 var(--sidebar-w);width:var(--sidebar-w);background:var(--surface-container-lowest);border-right:1px solid var(--border-subtle);padding:var(--gutter);display:flex;flex-direction:column;gap:var(--stack-sm);overflow-y:auto}.sidebar-brand,.side-brand{font-size:var(--text-headline-md);font-weight:600;color:var(--primary);margin-bottom:var(--stack-lg);padding:var(--stack-sm) 0;letter-spacing:-.02em}.sidebar a,.side a{display:block;padding:.5rem .65rem;color:var(--on-surface-variant);text-decoration:none;border-radius:var(--radius-md);font-size:var(--text-body-md);transition:background .15s ease,color .15s ease}.sidebar a:hover,.side a:hover{background:var(--surface-container-low);color:var(--on-surface);text-decoration:none}.sidebar a.active,.side a.active{background:#39b8fd33;color:var(--on-secondary-container);font-weight:600}.sidebar-footer{margin-top:auto;padding-top:var(--gutter)}.main{flex:1;min-width:0;overflow-x:hidden;overflow-y:auto;padding:var(--container-padding);background:var(--surface)}.main.layout-fluid,.layout-fluid .page{max-width:none;width:100%}.page{max-width:var(--page-max);width:100%;margin:0 auto}.page.page-fluid{max-width:none}.page-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--stack-md);margin-bottom:var(--stack-lg)}.page-header h1{margin:0}.page-actions{display:flex;flex-wrap:wrap;gap:var(--stack-sm)}.page-header .page-subtitle{margin:.35rem 0 0;color:var(--on-surface-variant);font-size:var(--text-body-md);line-height:1.5}.page-lead{margin:0 0 var(--stack-lg);color:var(--on-surface-variant);font-size:var(--text-body-md);line-height:1.5}.card,.bento-card{background:var(--surface-container-lowest);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--gutter);margin-bottom:var(--stack-lg);min-width:0;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease}.card.interactive:hover,.bento-card:hover{border-color:var(--secondary);box-shadow:var(--shadow-hover);transform:translateY(-2px)}.card>h3,.card>h4{margin:0 0 var(--stack-md)}.card>h3+.hint,.card>h4+.hint{margin:0 0 var(--stack-md)}.card>.hint+.table-scroll{margin-top:0}.card>h3+.table-scroll,.card>h3+.table-wrap,.card>.table-scroll:first-child{margin-top:0}.stats,.bento-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--stack-md)}.stat{text-align:left;padding:var(--stack-md)!important}.stat span,.stat-label{display:block;font-size:var(--text-label-sm);font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--on-surface-variant);margin-bottom:var(--stack-sm)}.stat b,.stat-value{font-size:var(--text-headline-lg);color:var(--primary);font-weight:600;letter-spacing:-.02em;word-break:break-word}.table-scroll,.table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0}table.data-table,table{width:100%;border-collapse:separate;border-spacing:0;font-size:var(--text-body-md)}table.data-table thead,table thead{position:relative;z-index:1}table.data-table th,table th{padding:.75rem .85rem;text-align:left;border-bottom:1px solid var(--border-subtle);background:var(--surface-container-low);font-size:var(--text-label-sm);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--on-surface-variant);white-space:nowrap;vertical-align:middle}table.data-table td,table td{padding:.75rem .85rem;text-align:left;border-bottom:1px solid var(--border-subtle);vertical-align:middle;background:var(--surface-container-lowest)}table.data-table tbody tr:hover td,table tbody tr:hover td{background:var(--surface-container-low)}table.data-table tr.table-empty-row td,table tr.table-empty-row td{padding:1.35rem .85rem;text-align:center;color:var(--on-surface-variant);font-size:var(--text-body-md);font-weight:400;text-transform:none;letter-spacing:normal;background:var(--surface-container-lowest);border-bottom:none}table.data-table tr.table-empty-row:hover td{background:var(--surface-container-lowest)}.table-empty,.empty-state{margin:0;padding:1.25rem .85rem;text-align:center;color:var(--on-surface-variant);font-size:var(--text-body-md);line-height:1.5;border-top:1px solid var(--border-subtle)}table.data-table td.actions{max-width:none;white-space:nowrap}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--stack-md)}.form-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.modal-card{max-width:520px;width:100%;margin:1rem;max-height:90vh;overflow-y:auto}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#191c1e59;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--gutter)}.modal{background:var(--surface-container-lowest);border:1px solid var(--border-subtle);border-radius:var(--radius-xxl);padding:var(--container-padding);width:100%;max-width:480px;max-height:min(90vh,720px);overflow-y:auto;box-shadow:var(--shadow-modal)}.modal.wide{max-width:640px}.modal-footer{display:flex;flex-wrap:wrap;gap:var(--stack-sm);margin-top:var(--stack-lg);padding-top:var(--stack-md);border-top:1px solid var(--border-subtle)}.banner{padding:var(--stack-md);border-radius:var(--radius-lg);margin-bottom:var(--stack-lg);font-size:var(--text-body-md)}.banner.warn{background:var(--status-warning-bg);color:#b45309;border:1px solid rgba(245,158,11,.35)}.banner.err{background:var(--status-error-bg);color:#b91c1c;border:1px solid rgba(239,68,68,.35)}.banner.ok{background:var(--status-success-bg);color:#047857;border:1px solid rgba(16,185,129,.35)}.hint{font-size:var(--text-label-sm);color:var(--status-warning);margin:var(--stack-sm) 0}.field-help{font-size:var(--text-body-md);color:var(--on-surface-variant);margin:0 0 var(--stack-lg);line-height:1.5}.field-hint{display:block;font-size:var(--text-label-sm);color:var(--text-dim);margin-top:var(--stack-sm)}.badge{display:inline-flex;align-items:center;padding:.25rem .65rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.icon-interactive{cursor:pointer;transition:transform var(--transition-normal),color var(--transition-normal)}.icon-interactive:hover{transform:scale(1.15) rotate(3deg);color:var(--secondary)}.icon-container{display:inline-flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:var(--radius-xl);background:var(--surface-container-low);border:1px solid transparent;transition:background var(--transition-fast),border-color var(--transition-fast)}.icon-container:hover{background:color-mix(in srgb,var(--secondary) 10%,transparent);border-color:color-mix(in srgb,var(--secondary) 20%,transparent)}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:calc(var(--z-modal) - 1)}.drawer-panel{position:fixed;top:0;right:0;bottom:0;width:min(420px,100vw);background:var(--surface-container-lowest);border-left:1px solid var(--border-subtle);border-radius:var(--radius-xxl) 0 0 var(--radius-xxl);box-shadow:var(--shadow-modal);z-index:var(--z-modal);overflow-y:auto;padding:var(--container-padding)}.badge.ok,.badge.success{background:var(--status-success-bg);color:#047857}.badge.warn,.badge.pending{background:var(--status-warning-bg);color:#b45309}.badge.off,.badge.error{background:var(--status-error-bg);color:#b91c1c}.badge.info,.badge.processing{background:var(--status-info-bg);color:#1d4ed8}.badge.pro{background:var(--status-pro-bg);color:#6d28d9}.status-dot{font-size:var(--text-label-sm);font-weight:600}.status-dot.online{color:var(--status-success)}.status-dot.offline{color:var(--status-error)}.status-dot.pending{color:var(--status-warning)}.status-dot.online:before,.status-pulse:before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--status-success);margin-right:6px;vertical-align:middle;animation:ethereal-pulse 2s ease-in-out infinite}@keyframes ethereal-pulse{0%,to{box-shadow:0 0 #10b98180}50%{box-shadow:0 0 0 6px #10b98100}}.avatar{width:32px;height:32px;border-radius:var(--radius-full);background:var(--surface-container-highest);color:var(--on-surface-variant);font-size:var(--text-label-sm);font-weight:600;display:inline-flex;align-items:center;justify-content:center}.steps{background:var(--surface-container-low);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--stack-md) var(--gutter);margin-bottom:var(--stack-lg);font-size:var(--text-body-md);color:var(--on-surface-variant)}.code-block{background:var(--surface-container-low);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--stack-md);font-family:var(--font-mono);font-size:var(--text-mono);line-height:1.45;white-space:pre-wrap;word-break:break-word;max-height:min(40vh,280px);overflow:auto}.btn-row{display:flex;flex-wrap:wrap;gap:var(--stack-sm);align-items:center}.login-page,.login-wrap,.login.card{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--gutter);background:var(--surface)}.login-wrap,.login.card,.login.card>.card{width:100%;max-width:400px;margin:0;min-height:auto}.login-page h1,.login-wrap h1,.login.card h1{text-align:center;margin-bottom:var(--stack-lg)}.login-page button,.login-wrap button,.login.card button{width:100%}input.inline{width:auto;display:inline-block;margin-right:var(--stack-sm)}@media (max-width: 768px){.form-grid,.form-grid-3{grid-template-columns:1fr}.layout{flex-direction:column;max-height:none}.sidebar,.side{flex:none;width:100%;flex-direction:row;flex-wrap:wrap;padding:var(--stack-md)}.sidebar-brand,.side-brand{margin:0 var(--stack-md) 0 0}.sidebar-footer{margin-top:0;margin-left:auto}.main{padding:var(--stack-md)}h1,.headline-lg{font-size:var(--text-headline-lg-mobile);line-height:2.25rem}}.login-shell{min-height:100vh;display:grid;grid-template-columns:minmax(280px,1fr) minmax(320px,480px);background:#f8fafc}.login-hero{position:relative;display:flex;align-items:stretch;padding:clamp(2rem,5vw,3.5rem);background:linear-gradient(145deg,#0f172a,#0c4a6e 42%,#006591);color:#fff;overflow:hidden}.login-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 80% 60% at 20% 100%,rgba(57,184,253,.35),transparent),radial-gradient(ellipse 50% 40% at 90% 10%,rgba(255,255,255,.08),transparent);pointer-events:none}.login-hero-inner{position:relative;z-index:1;display:flex;flex-direction:column;justify-content:center;max-width:28rem}.login-hero-mark{width:3.25rem;height:3.25rem;border-radius:1rem;background:#ffffff1f;border:1px solid rgba(255,255,255,.2);font-size:1.5rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.login-hero h2{margin:0 0 .75rem;font-size:clamp(1.5rem,3vw,2rem);font-weight:700;letter-spacing:-.03em;line-height:1.2}.login-hero p{margin:0 0 1.75rem;font-size:1rem;line-height:1.6;color:#ffffffd1}.login-hero-features{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.65rem}.login-hero-features li{display:flex;align-items:center;gap:.6rem;font-size:.9375rem;color:#ffffffe6}.login-hero-features li:before{content:"";width:6px;height:6px;border-radius:50%;background:#39b8fd;flex-shrink:0}.login-panel{display:flex;align-items:center;justify-content:center;padding:clamp(1.5rem,4vw,2.5rem)}.login-card{width:100%;max-width:400px;background:#fff;border:1px solid #e8edf3;border-radius:var(--radius-xxl);padding:2rem;box-shadow:0 1px 2px #0f172a0a,0 12px 40px -16px #0f172a1f}.login-card-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.75rem}.login-card-mark{width:2.75rem;height:2.75rem;border-radius:var(--radius-lg);background:linear-gradient(135deg,#0f172a,#006591);color:#fff;font-weight:700;font-size:1.125rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.login-card-header h1{margin:0;font-size:1.375rem;font-weight:700;letter-spacing:-.02em;text-align:left}.login-card-sub{margin:.2rem 0 0;font-size:.875rem;color:var(--on-surface-variant)}.login-form{display:flex;flex-direction:column;gap:1rem}.login-form .field{margin:0}.login-form .field input{margin-top:.35rem;border-radius:var(--radius-lg);border:1px solid #e2e8f0;padding:.65rem .85rem;transition:border-color .15s ease,box-shadow .15s ease}.login-form .field input:focus{border-color:#006591;box-shadow:0 0 0 3px #00659126;outline:none}.login-submit{margin-top:.5rem;padding:.75rem 1rem;border-radius:var(--radius-lg);font-weight:600;background:linear-gradient(180deg,#0077a8,#006591);border:none;color:#fff;cursor:pointer;transition:opacity .15s ease,transform .1s ease}.login-submit:hover:not(:disabled){opacity:.95;transform:translateY(-1px)}.login-submit:disabled{opacity:.65;cursor:wait}.login-banner{margin-bottom:1rem}.login-footer-note{margin:1.5rem 0 0;text-align:center;font-size:.75rem;color:#94a3b8;letter-spacing:.02em}@media (max-width: 768px){.login-shell{grid-template-columns:1fr}.login-hero{min-height:auto;padding:2rem 1.5rem 1.5rem}.login-hero-features{flex-direction:row;flex-wrap:wrap;gap:.5rem 1.25rem}}.sidebar--ethereal{--sidebar-bg: #ffffff;--sidebar-border: #e8edf3;--sidebar-text: #475569;--sidebar-text-strong: #0f172a;--sidebar-hover: #f1f5f9;--sidebar-active-bg: linear-gradient(90deg, rgba(0, 101, 145, .12) 0%, rgba(57, 184, 253, .08) 100%);--sidebar-active-border: #006591;--sidebar-width: 248px;flex:0 0 var(--sidebar-width);width:var(--sidebar-width);background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);box-shadow:4px 0 24px -12px #0f172a14;padding:0;display:flex;flex-direction:column;gap:0;overflow:hidden}.sidebar--ethereal .sidebar-brand{display:flex;align-items:center;gap:.75rem;padding:1.25rem 1rem 1rem;margin:0;border-bottom:1px solid var(--sidebar-border)}.sidebar-brand-mark{width:2.5rem;height:2.5rem;border-radius:var(--radius-lg);background:linear-gradient(135deg,#0f172a,#006591);color:#fff;font-size:1.125rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 12px #00659140}.sidebar-brand-text{display:flex;flex-direction:column;gap:.1rem;min-width:0}.sidebar-brand-name{font-size:1.0625rem;font-weight:700;letter-spacing:-.03em;color:var(--sidebar-text-strong);line-height:1.2}.sidebar-brand-sub{font-size:.6875rem;font-weight:500;color:var(--sidebar-text);letter-spacing:.04em;text-transform:uppercase}.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:.75rem .65rem 1rem;display:flex;flex-direction:column;gap:2px}.sidebar-nav-caption{margin:.85rem .5rem .35rem;font-size:.6875rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#94a3b8}.sidebar-nav-caption:first-child{margin-top:.15rem}.sidebar-link,.sidebar-nav-group-toggle,.sidebar-logout{display:flex;align-items:center;gap:.65rem;width:100%;min-height:2.375rem;padding:.4rem .6rem;border:none;border-radius:var(--radius-lg);background:transparent;color:var(--sidebar-text);font-size:.875rem;font-weight:500;text-decoration:none;cursor:pointer;text-align:left;font-family:inherit;transition:background .18s ease,color .18s ease,box-shadow .18s ease;position:relative}.sidebar-link-icon{display:flex;align-items:center;justify-content:center;width:1.25rem;height:1.25rem;flex-shrink:0;opacity:.72}.sidebar-link-icon svg{width:1.125rem;height:1.125rem}.sidebar-link-label,.sidebar-nav-group-label{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-link:hover,.sidebar-nav-group-toggle:hover{background:var(--sidebar-hover);color:var(--sidebar-text-strong);text-decoration:none}.sidebar-link:hover .sidebar-link-icon,.sidebar-nav-group-toggle:hover .sidebar-link-icon{opacity:1}.sidebar-link.active{background:var(--sidebar-active-bg);color:var(--sidebar-active-border);font-weight:600;box-shadow:inset 3px 0 0 var(--sidebar-active-border)}.sidebar-link.active .sidebar-link-icon{opacity:1;color:var(--sidebar-active-border)}.sidebar-nav-group{margin:0}.sidebar-nav-group-toggle{font-weight:500;text-transform:none;letter-spacing:normal}.sidebar-nav-group.is-active-section>.sidebar-nav-group-toggle{color:var(--sidebar-text-strong)}.sidebar-nav-group.is-active-section>.sidebar-nav-group-toggle .sidebar-link-icon{opacity:1;color:var(--sidebar-active-border)}.sidebar-nav-chevron{display:flex;width:1rem;height:1rem;flex-shrink:0;opacity:.45;transition:transform .2s ease,opacity .2s ease}.sidebar-nav-chevron svg{width:1rem;height:1rem}.sidebar-nav-group.is-open .sidebar-nav-chevron{transform:rotate(180deg);opacity:.7}.sidebar-nav-group-items{padding-left:.35rem}.sidebar-nav-group-items[hidden]{display:none}.sidebar-nav-group.is-open .sidebar-nav-group-items{padding:0 .4rem .35rem}.sidebar-nav-group-items-inner{display:flex;flex-direction:column;gap:1px;padding:.35rem .25rem .4rem;border-radius:var(--radius-lg);background:var(--sidebar-submenu-bg, #f1f5f9);border:1px solid var(--sidebar-submenu-border, #e2e8f0);box-shadow:inset 0 1px #fff9}.sidebar-nav-group.is-active-section.is-open .sidebar-nav-group-items-inner{background:linear-gradient(180deg,#00659114,#f1f5f9);border-color:#00659126}.sidebar-nav-group-items .sidebar-link{min-height:2.125rem;font-size:.8125rem;padding-left:2.15rem;margin-top:1px}.sidebar-nav-group-items .sidebar-link:before{content:"";position:absolute;left:1.15rem;top:50%;width:4px;height:4px;border-radius:50%;background:#cbd5e1;transform:translateY(-50%)}.sidebar-nav-group-items .sidebar-link.active:before{background:var(--sidebar-active-border)}.sidebar--ethereal .sidebar-footer{margin-top:0;padding:.75rem .65rem 1rem;border-top:1px solid var(--sidebar-border);background:linear-gradient(180deg,transparent,#f8fafc 40%)}.sidebar-logout{color:var(--sidebar-text);border:1px solid var(--sidebar-border);background:#fff}.sidebar-logout:hover{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.sidebar-logout:hover .sidebar-link-icon{opacity:1;color:#b91c1c}.sidebar.sidebar--ethereal{padding:0;gap:0}.sidebar--ethereal a.sidebar-link,.sidebar--ethereal .sidebar-nav-group-items a{display:flex;padding:.4rem .6rem}.sidebar--ethereal a.sidebar-link.active{background:var(--sidebar-active-bg);color:var(--sidebar-active-border)}@media (max-width: 768px){.layout.layout--shell{flex-direction:column;max-height:none}.sidebar--ethereal{flex:none;width:100%;max-height:none;flex-direction:column;border-right:none;border-bottom:1px solid var(--sidebar-border)}.sidebar--ethereal .sidebar-nav{max-height:50vh}}.layout--shell .main{background:#f8fafc}.layout--shell .page-header{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:var(--stack-md);padding-bottom:var(--stack-md);margin-bottom:var(--stack-lg);border-bottom:1px solid #e8edf3}.layout--shell .page-header-text{min-width:0}.layout--shell .page-header h1{margin:0;font-size:var(--text-headline-md);letter-spacing:-.02em;background:linear-gradient(90deg,#0f172a,#006591);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.layout--shell .page-header .page-subtitle{margin:.35rem 0 0;color:#64748b;font-size:.9375rem}.layout--shell .page-actions button,.layout--shell .page-actions .btn{border-radius:var(--radius-lg);font-weight:600}.layout--shell .card{border-radius:var(--radius-xl);border:1px solid #e8edf3;box-shadow:0 1px 3px #0f172a0a}.layout--shell .card>h3{margin:0 0 1rem}.layout--shell .card .table-scroll{margin-top:0}.layout--shell table{border-radius:var(--radius-lg)}.layout--shell thead th{background:#f1f5f9;font-size:.75rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:#64748b;border-bottom:1px solid #e2e8f0;padding-top:.8rem;padding-bottom:.8rem}.layout--shell tbody tr:hover td{background:#f8fafc}.layout--shell tr.table-empty-row td{background:#fff;color:#64748b}.layout--shell button:not(.sidebar-logout):not(.sidebar-nav-group-toggle){border-radius:var(--radius-lg)}.layout--shell .banner{border-radius:var(--radius-lg)}.dash-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--stack-md);margin-bottom:var(--stack-lg)}.dash-stat{display:flex;align-items:center;gap:1rem;padding:1.15rem 1.25rem;text-decoration:none;color:inherit;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}a.dash-stat:hover{text-decoration:none;transform:translateY(-2px);box-shadow:0 12px 32px -12px #0f172a26;border-color:#cbd5e1}.dash-stat-icon{width:2.75rem;height:2.75rem;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.dash-stat-icon svg{width:1.35rem;height:1.35rem}.dash-stat-icon--blue{background:linear-gradient(135deg,#00659126,#39b8fd33);color:#006591}.dash-stat-icon--slate{background:#f1f5f9;color:#475569}.dash-stat-icon--violet{background:#8b5cf61f;color:#7c3aed}.dash-stat-icon--emerald{background:#10b9811f;color:#059669}.dash-stat-icon--amber{background:#f59e0b1f;color:#d97706}.dash-stat-icon--rose{background:#f43f5e1a;color:#e11d48}.dash-stat-body{display:flex;flex-direction:column;gap:.15rem;min-width:0}.dash-stat-label{font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:#64748b}.dash-stat-value{font-size:1.625rem;font-weight:700;letter-spacing:-.02em;color:#0f172a;line-height:1.1}.dash-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--stack-lg);align-items:start}@media (max-width: 960px){.dash-grid{grid-template-columns:1fr}}.dash-panel{padding:1.35rem 1.5rem}.dash-panel-title{margin:0 0 1rem;font-size:.8125rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#64748b}.dash-quick{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.65rem}.dash-quick-link{display:flex;align-items:center;gap:.6rem;padding:.65rem .85rem;border-radius:var(--radius-lg);border:1px solid #e8edf3;background:#fff;color:#334155;font-size:.875rem;font-weight:500;text-decoration:none;transition:background .15s ease,border-color .15s ease,color .15s ease}.dash-quick-link:hover{background:#f1f5f9;border-color:#cbd5e1;color:#006591;text-decoration:none}.dash-quick-link svg{width:1.125rem;height:1.125rem;flex-shrink:0;opacity:.75}.dash-license{display:flex;flex-direction:column;gap:.75rem}.dash-license-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;font-size:.875rem}.dash-license-row dt{margin:0;color:#64748b;font-weight:500}.dash-license-row dd{margin:0;font-weight:600;color:#0f172a}.dash-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.5rem}.dash-list li{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.55rem .75rem;border-radius:var(--radius-lg);background:#f8fafc;font-size:.875rem}.dash-list li strong{font-weight:600;color:#0f172a}.dash-list li span{color:#64748b;font-size:.8125rem}.dash-empty{margin:0;color:#94a3b8;font-size:.875rem}.dash-panel-footer{margin-top:1rem;padding-top:.85rem;border-top:1px solid #e8edf3}.dash-panel-footer a{font-size:.875rem;font-weight:600;color:#006591;text-decoration:none}.dash-panel-footer a:hover{text-decoration:underline}.status-pill{display:inline-block;padding:.15rem .55rem;border-radius:var(--radius-full);font-size:var(--text-label-sm);font-weight:600}.status-pill--ok{background:var(--status-success-bg);color:#047857}.status-pill--warn{background:var(--status-warning-bg);color:#b45309}.status-pill--err{background:var(--status-error-bg);color:#b91c1c}.dash-panel-hint{margin:-.5rem 0 1rem;font-size:.8125rem;color:#64748b;line-height:1.45}.dash-mikrotiks-panel{margin-bottom:var(--stack-lg)}.dash-mikrotiks-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--stack-md)}.dash-mikrotik-card{border:1px solid #e8edf3;border-radius:var(--radius-lg);padding:1rem 1.1rem;background:#fafbfc}.dash-mikrotik-card header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.dash-mikrotik-card header strong{font-size:.9375rem;color:#0f172a}.dash-mikrotik-count{font-size:1.5rem;font-weight:700;color:#006591;line-height:1}.dash-mikrotik-ip{margin:.35rem 0 .65rem;font-size:.75rem;color:#94a3b8;font-family:var(--font-mono)}.dash-device-chips{display:flex;flex-wrap:wrap;gap:.35rem}.dash-chip{display:inline-block;padding:.12rem .45rem;border-radius:var(--radius-full);font-size:.6875rem;font-weight:600;background:#f1f5f9;color:#475569}.dash-chip--android{background:#dcfce7;color:#166534}.dash-chip--ios{background:#e0e7ff;color:#3730a3}.dash-chip--mobile{background:#fef3c7;color:#92400e}.dash-chip--desktop{background:#e2e8f0;color:#334155}.dash-chip--outro{background:#f1f5f9;color:#64748b}.page-title-row,.section-heading-row,.field-label-row{display:inline-flex;align-items:center;gap:.35rem;flex-wrap:wrap}.section-heading-row{margin:0 0 .75rem}h3.section-heading-row{font-size:1rem;font-weight:600}.field-label-row{font-weight:inherit}.hint-icon-wrap{position:relative;display:inline-flex;vertical-align:middle;margin-left:2px}.hint-icon{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;padding:0;border:none;border-radius:var(--radius-full, 9999px);background:transparent;color:var(--on-surface-variant, #64748b);cursor:help;transition:color .15s,background .15s}.hint-icon:hover,.hint-icon:focus-visible{color:var(--secondary, #006591);background:var(--accent-muted, rgba(0, 101, 145, .1));outline:none}.hint-icon--warn{color:var(--status-warning, #d97706)}.hint-icon--warn:hover{background:var(--status-warning-bg, rgba(245, 158, 11, .12))}.hint-icon--err{color:var(--status-error, #dc2626)}.hint-icon--err:hover{background:var(--status-error-bg, rgba(239, 68, 68, .1))}.hint-icon-popover{position:absolute;z-index:400;left:50%;bottom:calc(100% + 6px);transform:translate(-50%);min-width:200px;max-width:320px;padding:.6rem .75rem;font-size:12px;line-height:1.45;font-weight:400;color:var(--on-surface, #0f172a);background:var(--surface-bright, #fff);border:1px solid var(--border-subtle, #e2e8f0);border-radius:var(--radius-md, .375rem);box-shadow:var(--shadow-modal, 0 8px 24px rgba(15, 23, 42, .12));text-align:left;white-space:normal;pointer-events:none}.hint-icon-popover:after{content:"";position:absolute;top:100%;left:50%;margin-left:-5px;border:5px solid transparent;border-top-color:var(--border-subtle, #e2e8f0)}.hint-icon-wrap--below .hint-icon-popover{bottom:auto;top:calc(100% + 6px)}.hint-icon-wrap--below .hint-icon-popover:after{top:auto;bottom:100%;border-top-color:transparent;border-bottom-color:var(--border-subtle, #e2e8f0)}.summary-with-hint{display:inline-flex;align-items:center;gap:.35rem;flex-wrap:wrap}summary .hint-icon{pointer-events:auto}.wa-steps{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.wa-qr-box{min-height:280px;display:flex;align-items:center;justify-content:center;border:2px dashed var(--border-subtle);border-radius:var(--radius-lg);background:var(--surface-container-low);margin:1rem 0;padding:1rem}.wa-qr-box img{max-width:280px;width:100%;height:auto;background:#fff;padding:8px;border-radius:var(--radius-md)}.wa-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin:1rem 0}.wa-metric{text-align:center;padding:.75rem;background:var(--surface-container-low);border-radius:var(--radius-md)}.wa-metric b{display:block;font-size:1.5rem}.wa-metric--msg b{color:var(--status-info)}.wa-metric--ct b{color:var(--status-success)}.wa-metric--chat b{color:var(--status-pro)}.wa-status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem;margin-bottom:1rem}.wa-status-cell{padding:.65rem .75rem;background:var(--surface-container-low);border-radius:var(--radius-md);font-size:var(--text-sm)}.wa-status-cell dt{font-size:var(--text-label-sm);color:var(--on-surface-variant);margin-bottom:.2rem}.wa-status-cell dd{margin:0;font-weight:600}.wa-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.module-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--stack-sm)}.module-picker-item{display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto;column-gap:.5rem;row-gap:.2rem;padding:.75rem 1rem;border:1px solid var(--border-subtle, #e8edf3);border-radius:var(--radius-lg, .5rem);background:var(--surface-container-low, #f8fafc);cursor:pointer;transition:border-color .15s,background .15s}.module-picker-item.is-on{border-color:var(--secondary, #006591);background:var(--accent-muted, rgba(0, 101, 145, .08))}.module-picker-item.is-locked{opacity:.85;cursor:default}.module-picker-item input[type=checkbox]{grid-column:1;grid-row:1 / 3;align-self:start;margin-top:.15rem}.module-picker-label{grid-column:2;grid-row:1;font-weight:600;font-size:var(--text-label-sm, .875rem)}.module-picker-desc{grid-column:2;grid-row:2;font-size:12px;color:var(--on-surface-variant, #64748b);line-height:1.35}.module-badges{display:inline-flex;flex-wrap:wrap;gap:4px}.status-inline{display:inline-flex;align-items:center;gap:.35rem;font-size:var(--text-label-sm, .875rem);color:var(--on-surface, #0f172a)}.status-inline--muted{color:var(--on-surface-variant, #64748b)}.status-inline-label{font-weight:500}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--surface-container-high, #cbd5e1);flex-shrink:0}.status-dot--online{background:var(--status-success, #10b981);box-shadow:0 0 0 2px #10b98133}.status-dot--offline{background:var(--surface-container-highest, #94a3b8)}.status-dot--warn{background:var(--status-warning, #f59e0b);box-shadow:0 0 0 2px #f59e0b33}.status-dot--err{background:var(--status-error, #ef4444);box-shadow:0 0 0 2px #ef444433}.text-err{color:var(--status-error, #ef4444)}.dash-panel-head{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:1rem}.dash-panel-actions{align-items:center}.dash-stats--compact .dash-stat{padding:.75rem 1rem}.dash-stats--compact .dash-stat b{display:block;font-size:1.25rem;margin-top:.15rem}.dash-tenant-detail{margin-top:1rem}.dash-tenant-detail-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.dash-tenant-detail-head h3{margin:0 0 .25rem;font-size:1.125rem}.data-table--compact td,.data-table--compact th{padding:.5rem .65rem;font-size:13px}.mono-code{font-family:var(--font-mono, monospace);font-size:11px}.wan-ip-vps{color:var(--status-warning, #f59e0b)}.wan-ip-mk{color:var(--status-success, #10b981)}.ficha-section h4{margin:0 0 .5rem;font-size:var(--text-label-sm);color:var(--on-surface-variant);text-transform:uppercase;letter-spacing:.04em}.license-dl{display:grid;grid-template-columns:minmax(120px,auto) 1fr;gap:.35rem 1rem;font-size:14px;margin:0}.license-dl dt{color:var(--on-surface-variant, #64748b);font-weight:500}.license-dl dd{margin:0}
