@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root,:root[data-theme=light]{color-scheme:light;--color-primary-700: #1d4ed8;--color-primary-600: #2563eb;--color-primary-500: #3b82f6;--color-primary-400: #60a5fa;--color-primary-100: #dbeafe;--color-primary-50: #eff6ff;--color-neutral-900: #0f172a;--color-neutral-800: #1e293b;--color-neutral-700: #334155;--color-neutral-600: #475569;--color-neutral-500: #64748b;--color-neutral-400: #94a3b8;--color-neutral-300: #cbd5e1;--color-neutral-200: #e2e8f0;--color-neutral-100: #f1f5f9;--color-neutral-50: #f8fafc;--color-bg-app: #f5f9ff;--color-surface: #ffffff;--color-surface-soft: #f8fbff;--color-sidebar: #0b1730;--color-sidebar-soft: #111c33;--color-sidebar-active: #2563eb;--color-text-primary: #0f172a;--color-text-secondary: #475569;--color-text-muted: #64748b;--color-border: #e2e8f0;--color-border-soft: #e6edf5;--color-border-card: #e6edf5;--color-text-weak: #64748b;--color-surface-hover: #f8fbff;--shadow-card: var(--shadow-md);--color-success: #16a34a;--color-success-bg: #dcfce7;--color-warning: #f59e0b;--color-warning-bg: #fef3c7;--color-error: #dc2626;--color-error-bg: #fee2e2;--color-info: #0ea5e9;--color-info-bg: #e0f2fe;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-2xl: 24px;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .04);--shadow-md: 0 4px 16px rgba(15, 23, 42, .06);--shadow-lg: 0 8px 24px rgba(15, 23, 42, .08);--shadow-xl: 0 16px 40px rgba(15, 23, 42, .1);--chart-series-1: #006591;--chart-series-2: #38bdf8;--chart-series-3: #0891b2;--chart-series-4: #64748b;--chart-track: #f1f5f9;--chart-label: #475569;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--surface: var(--color-bg-app);--surface-dim: var(--color-neutral-200);--surface-bright: var(--color-surface);--surface-container-lowest: var(--color-surface);--surface-container-low: var(--color-neutral-100);--surface-container: var(--color-neutral-200);--surface-container-high: var(--color-neutral-300);--surface-container-highest: var(--color-neutral-400);--on-surface: var(--color-text-primary);--on-surface-variant: var(--color-text-secondary);--border-subtle: var(--color-border);--primary: var(--color-primary-600);--on-primary: #ffffff;--secondary: var(--color-primary-600);--on-secondary: #ffffff;--secondary-container: var(--color-primary-400);--on-secondary-container: var(--color-primary-700);--status-success: var(--color-success);--status-warning: var(--color-warning);--status-error: var(--color-error);--status-info: var(--color-info);--status-pro: #8b5cf6;--status-success-bg: var(--color-success-bg);--status-warning-bg: var(--color-warning-bg);--status-error-bg: var(--color-error-bg);--status-info-bg: var(--color-info-bg);--status-pro-bg: rgba(139, 92, 246, .12);--shadow-hover: var(--shadow-md);--shadow-modal: var(--shadow-xl);--accent-muted: rgba(37, 99, 235, .12);--accent-hover: var(--color-primary-700);--text-dim: var(--color-text-weak)}:root[data-theme=dark]{color-scheme:dark;--color-primary-700: #60a5fa;--color-primary-600: #3b82f6;--color-primary-500: #2563eb;--color-primary-400: #93c5fd;--color-primary-100: rgba(59, 130, 246, .16);--color-primary-50: rgba(59, 130, 246, .1);--color-neutral-900: #f8fafc;--color-neutral-800: #f1f5f9;--color-neutral-700: #e2e8f0;--color-neutral-600: #cbd5e1;--color-neutral-500: #94a3b8;--color-neutral-400: #64748b;--color-neutral-300: #475569;--color-neutral-200: #334155;--color-neutral-100: #1e293b;--color-neutral-50: #0f172a;--color-bg-app: #061224;--color-surface: #0d1b31;--color-surface-soft: #12233f;--color-surface-hover: #12233f;--color-sidebar: #08162b;--color-sidebar-soft: #0d1b31;--color-sidebar-active: #2563eb;--color-text-primary: #f8fafc;--color-text-secondary: #cbd5e1;--color-text-muted: #94a3b8;--color-text-weak: #64748b;--color-border: rgba(148, 163, 184, .2);--color-border-soft: rgba(148, 163, 184, .14);--color-border-card: rgba(148, 163, 184, .14);--color-success: #22c55e;--color-success-bg: rgba(34, 197, 94, .14);--color-warning: #fbbf24;--color-warning-bg: rgba(251, 191, 36, .14);--color-error: #f87171;--color-error-bg: rgba(248, 113, 113, .14);--color-info: #38bdf8;--color-info-bg: rgba(56, 189, 248, .14);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .35);--shadow-md: 0 8px 24px rgba(0, 0, 0, .22);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .28);--shadow-xl: 0 16px 40px rgba(0, 0, 0, .35);--shadow-card: 0 8px 24px rgba(0, 0, 0, .22);--chart-series-1: #38bdf8;--chart-series-2: #60a5fa;--chart-series-3: #22d3ee;--chart-series-4: #94a3b8;--chart-track: #1e293b;--chart-label: #94a3b8;--surface: var(--color-bg-app);--surface-dim: #020617;--surface-bright: var(--color-surface-soft);--surface-container-lowest: var(--color-surface);--surface-container-low: var(--color-surface-soft);--surface-container: #0f172a;--surface-container-high: var(--color-neutral-200);--surface-container-highest: var(--color-neutral-300);--on-surface: var(--color-text-primary);--on-surface-variant: var(--color-text-secondary);--border-subtle: var(--color-border);--primary: var(--color-primary-600);--on-primary: #ffffff;--secondary: var(--color-primary-500);--secondary-container: var(--color-primary-400);--on-secondary-container: var(--color-primary-100);--accent-muted: rgba(59, 130, 246, .2);--accent-hover: var(--color-primary-400);--text-dim: var(--color-text-weak)}@media (prefers-color-scheme: dark){:root:not([data-theme=light]):not([data-theme=dark]){color-scheme:dark;--color-primary-700: #60a5fa;--color-primary-600: #3b82f6;--color-primary-500: #2563eb;--color-primary-400: #93c5fd;--color-primary-100: rgba(59, 130, 246, .16);--color-primary-50: rgba(59, 130, 246, .1);--color-bg-app: #061224;--color-surface: #0d1b31;--color-surface-soft: #12233f;--color-surface-hover: #12233f;--color-sidebar: #08162b;--color-text-primary: #f8fafc;--color-text-secondary: #cbd5e1;--color-text-muted: #94a3b8;--color-text-weak: #64748b;--color-border: rgba(148, 163, 184, .2);--color-border-soft: rgba(148, 163, 184, .14);--color-border-card: rgba(148, 163, 184, .14);--color-success: #22c55e;--color-success-bg: rgba(34, 197, 94, .14);--color-warning: #fbbf24;--color-warning-bg: rgba(251, 191, 36, .14);--color-error: #f87171;--color-error-bg: rgba(248, 113, 113, .14);--color-info: #38bdf8;--color-info-bg: rgba(56, 189, 248, .14);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .35);--shadow-md: 0 8px 24px rgba(0, 0, 0, .22);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .28);--shadow-xl: 0 16px 40px rgba(0, 0, 0, .35);--shadow-card: 0 8px 24px rgba(0, 0, 0, .22);--surface: var(--color-bg-app);--surface-dim: #020617;--surface-bright: var(--color-surface-soft);--surface-container-lowest: var(--color-surface);--surface-container-low: var(--color-surface-soft);--surface-container: #0f172a;--surface-container-high: #334155;--surface-container-highest: #475569;--on-surface: var(--color-text-primary);--on-surface-variant: var(--color-text-secondary);--border-subtle: var(--color-border);--primary: var(--color-primary-600);--secondary: var(--color-primary-500);--accent-muted: rgba(59, 130, 246, .2);--accent-hover: var(--color-primary-400);--text-dim: var(--color-text-weak);--status-success-bg: var(--color-success-bg);--status-warning-bg: var(--color-warning-bg);--status-error-bg: var(--color-error-bg);--status-info-bg: var(--color-info-bg)}}:root{--font-sans: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace;--radius-full: 9999px;--sidebar-w: 260px;--gutter: 1.5rem;--container-padding: 2rem;--stack-sm: .5rem;--stack-md: 1rem;--stack-lg: 2rem;--text-headline-lg: 1.875rem;--text-headline-lg-mobile: 1.5rem;--text-headline-md: 1.25rem;--text-title-sm: 1.125rem;--text-title-md: 1.25rem;--text-body-lg: 1rem;--text-body-md: .875rem;--text-label-sm: .75rem;--text-mono: .8125rem;--leading-headline-lg: 2.375rem;--leading-headline-md: 1.75rem;--leading-body-lg: 1.5rem;--leading-body-md: 1.375rem;--leading-label-sm: 1rem;--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: var(--color-text-muted);--accent: var(--secondary);--accent-hover: var(--color-primary-700);--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}.theme-dark{color-scheme:dark}*,*: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(--color-text-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 .875rem;margin:var(--stack-sm) 0 var(--stack-md);background:var(--color-surface);min-height:44px;font-size:var(--text-body-md);border-radius:var(--radius-md);border-color:var(--color-border)}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:44px;padding:.55rem 1.15rem;margin:0;background:var(--color-primary-600);color:var(--on-primary);border:none;font-weight:600;font-size:var(--text-body-md);border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;transition:transform .15s ease,background .15s ease,box-shadow .15s ease}button:hover:not(:disabled){background:var(--color-primary-700)}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:not(.sidebar--ethereal) 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:not(.sidebar--ethereal) a:hover,.side a:hover{background:var(--surface-container-low);color:var(--on-surface);text-decoration:none}.sidebar:not(.sidebar--ethereal) 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,.layout.layout--shell .main .page{max-width:none;width:100%;margin:0}.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(--color-surface);border:1px solid var(--color-border-soft);border-radius:var(--radius-lg);padding:var(--space-6);margin-bottom:var(--stack-lg);min-width:0;box-shadow:var(--shadow-sm);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(--color-warning-bg);color:var(--color-text-primary);border:1px solid color-mix(in srgb,var(--color-warning) 35%,transparent)}.banner.err{background:var(--color-error-bg);color:var(--color-text-primary);border:1px solid color-mix(in srgb,var(--color-error) 35%,transparent)}.banner.ok{background:var(--color-success-bg);color:var(--color-text-primary);border:1px solid color-mix(in srgb,var(--color-success) 35%,transparent)}.hint{font-size:var(--text-label-sm);color:var(--color-text-muted);margin:var(--stack-sm) 0;line-height:1.45}.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(--color-success-bg);color:var(--color-success)}.badge.warn,.badge.pending{background:var(--color-warning-bg);color:var(--color-warning)}.badge.off,.badge.error,.badge.err{background:var(--color-error-bg);color:var(--color-error)}.badge.info,.badge.processing{background:var(--color-info-bg);color:var(--color-info)}.badge.pro{background:var(--status-pro-bg);color:#6d28d9}.status-dot.online:not(.status-dot--online){color:var(--status-success);font-size:var(--text-label-sm);font-weight:600}.status-dot.offline:not(.status-dot--offline):not(.status-dot--err){color:var(--status-error);font-size:var(--text-label-sm);font-weight:600}.status-dot.pending:not(.status-dot--warn){color:var(--status-warning);font-size:var(--text-label-sm);font-weight:600}.status-dot.online:not(.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)}.list-form-panel{margin-top:var(--stack-lg)}.list-form-panel-head{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:1rem}.list-form-panel-title{margin:0;font-size:1.05rem;font-weight:600}@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}}html,body,#root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.layout--shell .page-title-row,.layout--shell .page-header h1,.layout--shell h1{font-size:1.875rem;line-height:1.27;font-weight:700;letter-spacing:-.02em}.layout--shell h2,.dash-panel-title{font-size:1.5rem;line-height:1.33;font-weight:700}.layout--shell h3,.ds-card-title{font-size:1.25rem;line-height:1.4;font-weight:600}.layout--shell h4{font-size:1.125rem;line-height:1.44;font-weight:600}body,.layout--shell{font-size:.875rem;line-height:1.57}.ds-caption,.caption{font-size:.75rem;line-height:1.5;font-weight:400}.ui-input-label,label.field>span:first-child{font-size:.75rem;line-height:1.33;font-weight:600}.ds-text-secondary{color:var(--color-text-secondary);font-size:.875rem;line-height:1.5}.ds-text-muted{color:var(--color-text-muted);font-size:.8125rem;line-height:1.45}.ds-card-title{margin:0 0 1rem;font-size:1.125rem;font-weight:600;color:var(--color-text-primary)}.ds-alert{display:flex;gap:.75rem;padding:.85rem 1rem;border-radius:var(--radius-md);margin-bottom:var(--space-4, 16px);font-size:.875rem;line-height:1.5}.ds-alert__icon{flex-shrink:0;width:1.25rem;height:1.25rem;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;border-radius:50%}.ds-alert__title{display:block;margin-bottom:.25rem;font-size:.875rem}.ds-alert__content p{margin:.25rem 0 0}.ds-alert__content p:first-child{margin-top:0}.ds-alert--info{background:var(--color-info-bg);border:1px solid color-mix(in srgb,var(--color-info) 35%,transparent);color:var(--color-text-primary)}.ds-alert--info .ds-alert__icon{background:color-mix(in srgb,var(--color-info) 20%,transparent);color:var(--color-info)}.ds-alert--warning{background:var(--color-warning-bg);border:1px solid color-mix(in srgb,var(--color-warning) 35%,transparent);color:var(--color-text-primary)}.ds-alert--warning .ds-alert__icon{background:color-mix(in srgb,var(--color-warning) 22%,transparent);color:var(--color-warning)}.ds-alert--error{background:var(--color-error-bg);border:1px solid color-mix(in srgb,var(--color-error) 35%,transparent);color:var(--color-text-primary)}.ds-alert--error .ds-alert__icon{background:color-mix(in srgb,var(--color-error) 18%,transparent);color:var(--color-error)}.ds-alert--success{background:var(--color-success-bg);border:1px solid color-mix(in srgb,var(--color-success) 35%,transparent);color:var(--color-text-primary)}.ds-alert--success .ds-alert__icon{background:color-mix(in srgb,var(--color-success) 18%,transparent);color:var(--color-success)}.ds-empty{text-align:center;padding:2rem 1.5rem;color:var(--color-text-muted)}.ds-empty__title{margin:0 0 .35rem;font-weight:600;color:var(--color-text-secondary)}.ds-empty__desc{margin:0;font-size:.875rem}.ds-empty__action{margin-top:1rem}.ds-danger-zone{background:var(--color-surface);border:1px solid color-mix(in srgb,var(--color-error) 40%,transparent);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;box-shadow:var(--shadow-sm)}.ds-danger-zone__head{display:flex;align-items:center;gap:.65rem;margin-bottom:1rem}.ds-danger-zone__badge{width:1.75rem;height:1.75rem;border-radius:var(--radius-md);background:var(--color-error-bg);color:var(--color-error);font-weight:700;display:flex;align-items:center;justify-content:center;font-size:.875rem}.ds-danger-zone__title{margin:0;font-size:1.125rem;font-weight:600;color:var(--color-error)}.ds-danger-zone .hint,.ds-danger-zone .ds-text-muted{color:var(--color-text-muted)}.ds-badge--neutral{background:var(--color-neutral-100);color:var(--color-text-secondary)}:root[data-theme=dark] .ds-badge--neutral{background:var(--color-neutral-200);color:var(--color-text-secondary)}.theme-toggle{position:relative}.theme-toggle__btn{cursor:pointer}.theme-toggle__btn:not(:disabled){opacity:1;cursor:pointer}.theme-toggle__menu{position:absolute;top:calc(100% + 6px);right:0;min-width:168px;margin:0;padding:.35rem;list-style:none;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:50}.theme-toggle__option{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .65rem;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-primary);font:inherit;font-size:.875rem;cursor:pointer;text-align:left}.theme-toggle__option:hover{background:var(--color-surface-soft)}.theme-toggle__option.is-active{background:var(--color-primary-50);color:var(--color-primary-700)}:root[data-theme=dark] .theme-toggle__option.is-active{background:var(--color-primary-100);color:var(--color-primary-400)}.theme-toggle__check{margin-left:auto;font-size:.75rem;font-weight:700}.theme-toggle__option-icon{display:flex;opacity:.85}.ds-theme-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem;margin-top:1.25rem}.ds-theme-card{display:flex;flex-direction:column;align-items:flex-start;gap:.35rem;padding:1rem 1.1rem;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);cursor:pointer;text-align:left;font-family:inherit;transition:border-color .15s,box-shadow .15s}.ds-theme-card:hover{border-color:var(--color-primary-400)}.ds-theme-card.is-active{border-color:var(--color-primary-600);box-shadow:0 0 0 3px var(--accent-muted, rgba(37, 99, 235, .12))}.ds-theme-card__label{font-weight:600;color:var(--color-text-primary)}.ds-theme-card__hint{font-size:.75rem;color:var(--color-text-muted)}.ds-preview-row{display:flex;flex-wrap:wrap;gap:.5rem}.ds-preview-card{padding:1.25rem 1.5rem}.infra-meta-line{margin:.5rem 0 0;font-size:.875rem;color:var(--color-text-secondary)}.infra-limitante{display:inline-flex;align-items:center;gap:.35rem;margin-top:.5rem;padding:.35rem .65rem;border-radius:var(--radius-sm);background:var(--color-warning-bg);color:var(--color-warning);font-size:.8125rem;font-weight:600}.infra-kpi-row .hint{color:var(--color-text-muted)}.infra-kpi-row b{color:var(--color-text-primary)}.theme-selector{display:flex;flex-direction:column;gap:.35rem;width:100%}.theme-selector--compact .theme-selector__label{display:none}.theme-selector__label{font-size:.625rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#94a3b8f2}.theme-selector__select{width:100%;min-height:2.25rem;margin:0;padding:.35rem .5rem;font-size:.8125rem;font-weight:500;border-radius:var(--radius-md);border:1px solid rgba(148,163,184,.35);background:#0f172a59;color:#f1f5f9;cursor:pointer}.theme-selector__select:focus{outline:none;border-color:var(--color-primary-400);box-shadow:0 0 0 3px #3b82f640}.sidebar-footer .theme-selector{padding:0 .65rem .5rem;border-bottom:1px solid rgba(148,163,184,.15);margin-bottom:.35rem}.layout--shell .main{background:var(--color-bg-app)}.layout--shell .page-header{border-bottom-color:var(--color-border-soft)}.layout--shell .page-header h1{background:linear-gradient(90deg,var(--color-text-primary) 0%,var(--color-primary-600) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}:root[data-theme=dark] .layout--shell .page-header h1{background:linear-gradient(90deg,var(--color-text-primary) 0%,var(--color-primary-400) 100%);-webkit-background-clip:text;background-clip:text}.layout--shell .card{background:var(--color-surface);border:1px solid var(--color-border-card, var(--color-border-soft));border-radius:var(--radius-lg);box-shadow:var(--shadow-card, var(--shadow-md));padding:var(--space-6, 24px)}.layout--shell .card>h3:first-child,.layout--shell .card>h2.dash-panel-title:first-child{margin-top:0}.layout--shell thead th{background:var(--color-surface-soft);color:var(--color-text-muted);border-bottom-color:var(--color-border)}.layout--shell tbody tr:hover td{background:var(--color-surface-soft)}.layout--shell tbody td{border-bottom-color:var(--color-border-soft)}.dash-panel-title,.dash-faixa-etaria-title{color:var(--color-text-primary)}.dash-faixa-legend{color:var(--color-text-secondary)}.dash-faixa-center-value{fill:var(--color-text-primary)}.dash-faixa-center-label{fill:var(--chart-label, var(--color-text-muted))}.dash-mikrotik-ip{color:var(--chart-label, var(--color-text-muted))}input:focus,select:focus,textarea:focus,button:focus-visible{box-shadow:0 0 0 4px var(--accent-muted)}button:hover:not(:disabled):not(.secondary){background:var(--color-primary-700)}:root[data-theme=dark] button:hover:not(:disabled):not(.secondary){background:var(--color-primary-500);filter:brightness(1.05)}h1,h2,h3{color:var(--color-text-primary)}h4{color:var(--color-text-secondary)}.preview-viewport__stage{background:var(--color-surface-soft);border-color:var(--color-border)}.preview-toolbar{background:var(--color-surface);border-color:var(--color-border)}.preview-toolbar__zoom-btn,.preview-toolbar__zoom-select{background:var(--color-surface-soft);border-color:var(--color-border);color:var(--color-text-primary)}.preview-toolbar__fit-btn{background:var(--color-primary-600);color:#fff}.preview-toolbar__scale-hint{color:var(--color-text-muted)}.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-inline .status-dot{display:inline-block;width:10px;height:10px;min-width:10px;min-height:10px;border-radius:50%;background-color:#94a3b8;flex-shrink:0;font-size:0;line-height:0;color:transparent;border:none;box-shadow:none}.status-inline .status-dot:before{display:none!important;content:none!important;animation:none!important}.status-inline .status-dot.status-dot--online{background-color:#16a34a;box-shadow:0 0 0 2px #16a34a73}.status-inline .status-dot.status-dot--offline,.status-inline .status-dot.status-dot--err{background-color:#dc2626;box-shadow:0 0 0 2px #dc262673}.status-inline .status-dot.status-dot--warn{background-color:#ca8a04;box-shadow:0 0 0 2px #ca8a0473}.login-shell{min-height:100vh;display:grid;grid-template-columns:minmax(280px,1fr) minmax(320px,480px);background:var(--color-bg-app, #f5f9ff)}.login-hero{position:relative;display:flex;align-items:stretch;padding:clamp(2rem,5vw,3.5rem);background:linear-gradient(145deg,var(--color-neutral-900, #0f172a) 0%,var(--color-primary-700, #1d4ed8) 42%,var(--color-primary-600, #2563eb) 100%);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(96,165,250,.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:var(--color-primary-400, #60a5fa);flex-shrink:0}.login-panel{display:flex;align-items:center;justify-content:center;padding:clamp(1.5rem,4vw,2.5rem);background:var(--color-bg-app, #f5f9ff)}.login-card{width:100%;max-width:400px;background:var(--color-surface, #fff);border:1px solid var(--color-border-soft, #e6edf5);border-radius:var(--radius-2xl, 24px);padding:2rem;box-shadow:var(--shadow-lg)}.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, 16px);background:linear-gradient(135deg,var(--color-neutral-900, #0f172a),var(--color-primary-600, #2563eb));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;color:var(--color-text-primary)}.login-card-sub{margin:.2rem 0 0;font-size:.875rem;color:var(--color-text-muted)}.login-form{display:flex;flex-direction:column;gap:1rem}.login-form .field{margin:0}.login-form .ui-input-wrap .ui-input,.login-form .field input{margin-top:.35rem}.login-submit.ui-btn,.login-submit{margin-top:.5rem;padding:.75rem 1rem;border-radius:var(--radius-lg, 16px);font-weight:600;background:linear-gradient(180deg,var(--color-primary-500, #3b82f6) 0%,var(--color-primary-600, #2563eb) 100%);border:none;color:#fff;cursor:pointer;transition:opacity .15s ease,transform .1s ease}.login-submit:hover:not(:disabled){opacity:.95;transform:translateY(-1px);filter:brightness(1.03)}.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:var(--color-text-muted);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}}.ui-btn{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;font-family:inherit;font-weight:600;border-radius:var(--radius-md);cursor:pointer;transition:background .15s,border-color .15s,opacity .15s}.ui-btn--primary{padding:.6rem 1.1rem;border:none;background:var(--color-primary-600);color:#fff}.ui-btn--primary:hover:not(:disabled){background:var(--color-primary-700)}.ui-btn--secondary{padding:.55rem 1rem;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-primary)}.ui-btn--outline{padding:.55rem 1rem;border:1px solid var(--color-border);background:transparent;color:var(--color-text-primary)}.ui-btn--ghost{padding:.55rem 1rem;border:none;background:transparent;color:var(--color-text-secondary)}.ui-btn--ghost:hover:not(:disabled){background:var(--color-surface-soft)}.ui-btn--destructive{padding:.6rem 1.1rem;border:none;background:var(--color-error);color:#fff}.ui-btn--destructive:hover:not(:disabled){background:#b91c1c;filter:none}.ui-btn--link{padding:0;border:none;background:none;color:var(--color-primary-600);font-weight:500;min-height:auto}.ui-btn--block{width:100%}.ui-btn:disabled{opacity:.6;cursor:not-allowed}.ui-input-wrap{display:flex;flex-direction:column;gap:.35rem;margin:0}.ui-input-label{font-size:.875rem;font-weight:500;color:var(--color-text-primary)}.ui-input{width:100%;box-sizing:border-box;padding:.65rem .85rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-primary);font:inherit}.ui-input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px var(--accent-muted)}.ui-card{background:var(--color-surface);border:1px solid var(--color-border-card, var(--color-border-soft));border-radius:var(--radius-lg);box-shadow:var(--shadow-card, var(--shadow-sm))}.ui-card--padded{padding:var(--space-5, 20px)}.app-topbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4, 16px);flex-wrap:wrap;padding:var(--space-3, 12px) var(--space-5, 20px);margin:calc(-1 * var(--space-4, 16px)) calc(-1 * var(--space-5, 20px)) var(--space-4, 16px);background:var(--color-surface);border-bottom:1px solid var(--color-border-soft);border-radius:var(--radius-lg) var(--radius-lg) 0 0;box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:20}.app-topbar--hotspot{flex-wrap:nowrap;min-height:72px;max-height:80px;padding:0 clamp(1rem,2vw,1.5rem);margin:calc(-1*clamp(1rem,2.5vw,2rem)) calc(-1*clamp(1rem,2.5vw,2rem)) .75rem;border-radius:0;box-shadow:none;background:var(--color-surface);border-bottom:1px solid var(--color-border-soft)}.app-topbar--hotspot .app-topbar-product{font-size:.6875rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-muted);flex-shrink:0}.app-topbar--hotspot .app-topbar-end{margin-left:auto;flex-shrink:0;display:flex;align-items:center;gap:.75rem}.app-topbar-datetime{font-size:.8125rem;font-weight:500;color:var(--color-text-muted);white-space:nowrap;line-height:1.2}.app-topbar-datetime-short{display:none}.layout--shell .main>.app-topbar{margin-top:0;border-radius:0;position:sticky;top:0}.layout--shell .main>.app-topbar--hotspot+.page .page-header,.layout--shell .main>.app-topbar--hotspot+*>.page-header{margin-top:0;padding-top:.25rem;margin-bottom:var(--space-4, 16px)}.theme-segmented{display:inline-flex;align-items:center;padding:3px;gap:2px;border-radius:10px;background:var(--color-neutral-100, #f1f5f9);border:1px solid var(--color-border-soft);height:36px;box-sizing:border-box}:root[data-theme=dark] .theme-segmented{background:var(--color-neutral-100, #1e293b);border-color:var(--color-border)}.theme-segmented__btn{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;min-width:2.5rem;height:100%;padding:0 .65rem;border:none;border-radius:8px;background:transparent;color:var(--color-text-muted);font-size:.75rem;font-weight:500;font-family:inherit;cursor:pointer;transition:background .2s ease,color .2s ease,box-shadow .2s ease}.theme-segmented__btn:hover:not(.is-active){color:var(--color-text-secondary);background:#ffffff80}:root[data-theme=dark] .theme-segmented__btn:hover:not(.is-active){background:#ffffff0f}.theme-segmented__btn.is-active{background:var(--color-primary-600);color:#fff;box-shadow:var(--shadow-sm)}.theme-segmented__btn.is-active svg{stroke:#fff}.theme-segmented__label{line-height:1}@media (max-width: 900px){.theme-segmented__label{display:none}.theme-segmented__btn{padding:0 .5rem}}@media (max-width: 640px){.app-topbar-datetime-full{display:none}.app-topbar-datetime-short{display:inline;font-size:.8125rem;font-weight:500;color:var(--color-text-muted)}.app-topbar--hotspot{min-height:64px;padding:0 1rem}}.app-topbar-start{display:flex;flex-direction:column;gap:.15rem;min-width:0}.app-topbar-product{font-size:.6875rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted)}.app-topbar-date{font-size:.875rem;font-weight:500;color:var(--color-text-primary);text-transform:capitalize;line-height:1.35}.app-topbar-time{margin-left:.5rem;font-weight:400;color:var(--color-text-muted);text-transform:none}.app-topbar-end{display:flex;align-items:center;gap:var(--space-3, 12px)}.app-topbar-icon-btn{display:flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-soft);color:var(--color-text-secondary);cursor:pointer;transition:background .15s,border-color .15s}.app-topbar-icon-btn:hover:not(:disabled){background:var(--color-surface);border-color:var(--color-primary-400);color:var(--color-primary-600)}.app-topbar-icon-btn:disabled{cursor:not-allowed;opacity:.55}.app-topbar-user{display:flex;align-items:center;gap:.65rem;padding:.35rem .65rem .35rem .35rem;border-radius:var(--radius-lg);border:1px solid var(--color-border-soft);background:var(--color-surface-soft);max-width:min(280px,50vw)}.app-topbar-avatar{width:2rem;height:2rem;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--color-primary-700),var(--color-primary-500));color:#fff;font-size:.875rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.app-topbar-user-text{display:flex;flex-direction:column;min-width:0;line-height:1.25}.app-topbar-user-name{font-size:.8125rem;font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-topbar-user-role{font-size:.6875rem;color:var(--color-text-muted);text-transform:capitalize}@media (max-width: 640px){.app-topbar-date{font-size:.8125rem}.app-topbar-user-text{display:none}}.profile-menu{position:relative}.profile-menu__trigger{display:inline-flex;align-items:center;gap:.5rem;padding:.35rem .5rem .35rem .35rem;border:1px solid var(--color-border-soft);border-radius:var(--radius-lg);background:var(--color-surface-soft);color:var(--color-text-primary);font-family:inherit;cursor:pointer;transition:background .15s,border-color .15s,box-shadow .15s;max-width:min(220px,42vw)}.profile-menu__trigger:hover{background:var(--color-surface-hover, var(--color-surface));border-color:var(--color-border)}.profile-menu__trigger[aria-expanded=true]{border-color:var(--color-primary-500);box-shadow:0 0 0 3px var(--accent-muted)}.profile-menu__avatar{width:2rem;height:2rem;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--color-primary-700),var(--color-primary-500));color:#fff;font-size:.875rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.profile-menu__trigger-text{display:flex;flex-direction:column;align-items:flex-start;min-width:0;line-height:1.2;text-align:left}.profile-menu__name{font-size:.8125rem;font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.profile-menu__chevron{display:flex;flex-shrink:0;opacity:.55;transition:transform .2s ease}.profile-menu__trigger[aria-expanded=true] .profile-menu__chevron{transform:rotate(180deg)}.profile-menu__panel{position:absolute;top:calc(100% + 8px);right:0;width:min(320px,calc(100vw - 1.5rem));min-width:280px;max-width:340px;background:var(--color-surface);border:1px solid var(--color-border-card, var(--color-border-soft));border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:60;overflow:hidden}.profile-menu__section{padding:.85rem 1rem;border-bottom:1px solid var(--color-border-soft)}.profile-menu__section:last-child{border-bottom:none}.profile-menu__section-title{margin:0 0 .5rem;font-size:.625rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted)}.profile-menu__user-name{margin:0;font-size:.9375rem;font-weight:600;color:var(--color-text-primary)}.profile-menu__user-role{margin:.15rem 0 0;font-size:.8125rem;color:var(--color-text-secondary)}.profile-menu__user-email{margin:.2rem 0 0;font-size:.75rem;color:var(--color-text-muted);word-break:break-all}.profile-menu__empresa-name{margin:0 0 .5rem;font-size:.875rem;font-weight:600;color:var(--color-text-primary);line-height:1.3}.profile-menu__meta{margin:0;display:flex;flex-direction:column;gap:.35rem}.profile-menu__meta-row{display:flex;justify-content:space-between;gap:.75rem;font-size:.8125rem}.profile-menu__meta-row dt{margin:0;color:var(--color-text-muted);font-weight:500}.profile-menu__meta-row dd{margin:0;font-weight:500;color:var(--color-text-secondary);text-align:right}.profile-menu__meta-row dd.is-warn{color:var(--color-warning)}.profile-menu__meta-row dd.is-err{color:var(--color-error)}.profile-menu__theme-list{display:flex;flex-direction:column;gap:.35rem}.profile-menu__theme-btn{display:flex;align-items:center;gap:.5rem;width:100%;padding:.45rem .65rem;border:1px solid var(--color-border-soft);border-radius:var(--radius-md);background:var(--color-surface-soft);color:var(--color-text-secondary);font-size:.8125rem;font-weight:500;font-family:inherit;cursor:pointer;text-align:left;transition:background .15s,border-color .15s,color .15s}.profile-menu__theme-btn:hover{border-color:var(--color-primary-400)}.profile-menu__theme-btn.is-active{background:var(--color-primary-50);border-color:var(--color-primary-500);color:var(--color-primary-700);font-weight:600}:root[data-theme=dark] .profile-menu__theme-btn.is-active{background:var(--color-primary-100);border-color:var(--color-primary-500);color:var(--color-primary-400)}.profile-menu__actions{padding:.35rem}.profile-menu__action{display:flex;align-items:center;gap:.5rem;width:100%;padding:.55rem .75rem;border:none;border-radius:var(--radius-md);background:transparent;color:var(--color-text-primary);font-size:.875rem;font-weight:500;font-family:inherit;text-decoration:none;cursor:pointer;text-align:left;transition:background .15s}.profile-menu__action:hover{background:var(--color-surface-soft);text-decoration:none}.profile-menu__action--danger{color:var(--color-error)}.profile-menu__action--danger:hover{background:var(--color-error-bg)}@media (max-width: 640px){.profile-menu__trigger-text{display:none}.profile-menu__trigger{padding:.35rem}}[data-portal-theme=light] .visual-preview-screen--portal,[data-portal-theme=light] .portal-preview-screen{color-scheme:light}[data-portal-theme=dark] .visual-preview-screen--portal{background:#0f172a;color-scheme:dark}[data-portal-theme=dark] .portal-preview-screen .portal-canvas-card-ethereal,[data-portal-theme=dark] .portal-status-connected-card{--portal-card-bg: #1e293b;--portal-card-border: #334155;--portal-card-text: #e2e8f0;--portal-card-muted: #94a3b8}[data-portal-theme=dark] .portal-preview-screen .portal-canvas-card-ethereal{background:var(--portal-card-bg, #1e293b);border-color:var(--portal-card-border, #334155);color:var(--portal-card-text, #e2e8f0)}[data-portal-theme=dark] .portal-preview-screen .portal-canvas-card-ethereal .hint,[data-portal-theme=dark] .portal-preview-screen .portal-canvas-card-ethereal label{color:var(--portal-card-muted, #94a3b8)}[data-portal-theme=dark] .portal-preview-screen input,[data-portal-theme=dark] .portal-preview-screen select,[data-portal-theme=dark] .portal-preview-screen textarea{background:#0f172a;border-color:#475569;color:#f1f5f9}[data-portal-theme=dark] .portal-status-screen--connected{background:linear-gradient(165deg,#1e293b,#0f172a)}[data-portal-theme=dark] .portal-status-connected-card{background:#1e293b;border-color:#334155;color:#e2e8f0}[data-portal-theme=dark] .portal-status-connected-lead,[data-portal-theme=dark] .portal-status-connected-hint{color:#94a3b8}[data-portal-theme=dark] .portal-status-connected-row{border-color:#334155;color:#94a3b8}[data-portal-theme=dark] .portal-status-connected-row strong{color:#f1f5f9}html[data-portal-tema=auto]{color-scheme:light dark}@media (prefers-color-scheme: dark){html[data-portal-tema=auto]{color-scheme:dark}}.portal-theme-mode-field{margin-bottom:1rem}.portal-theme-mode-options{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.portal-theme-mode-btn{padding:.45rem .85rem;border-radius:var(--radius-md, 8px);border:1px solid var(--color-border, #e2e8f0);background:var(--color-surface, #fff);color:var(--color-text-secondary, #475569);font-size:.8125rem;font-weight:500;cursor:pointer;transition:border-color .15s,background .15s,color .15s}.portal-theme-mode-btn:hover{border-color:var(--color-primary-400, #60a5fa)}.portal-theme-mode-btn.is-active{border-color:var(--color-primary-600, #2563eb);background:var(--color-primary-50, #eff6ff);color:var(--color-primary-700, #1d4ed8)}:root[data-theme=dark] .portal-theme-mode-btn.is-active{background:var(--color-primary-100, rgba(59, 130, 246, .16));color:var(--color-primary-400, #93c5fd)}.portal-theme-mode-hint{margin:.5rem 0 0;font-size:.75rem;color:var(--color-text-muted, #64748b);line-height:1.45}.sidebar--ethereal{--sidebar-bg: var(--color-sidebar, #0b1730);--sidebar-border: rgba(255, 255, 255, .08);--sidebar-text: #cbd5e1;--sidebar-text-strong: #ffffff;--sidebar-hover: rgba(255, 255, 255, .08);--sidebar-active-bg: var(--color-primary-600, #2563eb);--sidebar-submenu-bg: var(--color-sidebar-soft, #111c33);--sidebar-submenu-border: rgba(255, 255, 255, .08);--sidebar-width: 248px;--sidebar-nav-font: var(--text-body-md, 1rem);--sidebar-nav-sub-font: var(--text-label-sm, .875rem);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 #00000040;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-md);background:linear-gradient(135deg,#1e3a8a 0%,var(--color-primary-600, #2563eb) 100%);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-tenant-card{margin:.5rem .65rem 0;padding:.75rem .85rem;border-radius:12px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1)}.sidebar-tenant-card__name{margin:0 0 .65rem;font-size:.875rem;font-weight:600;color:#fff;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-tenant-card__meta{margin:0;display:flex;flex-direction:column;gap:.5rem}.sidebar-tenant-card__row{display:grid;grid-template-columns:auto 1fr;gap:.35rem .65rem;align-items:baseline}.sidebar-tenant-card__row dt{margin:0;font-size:.625rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#94a3b8f2}.sidebar-tenant-card__row dd{margin:0;font-size:.8125rem;font-weight:500;color:#e2e8f0;text-align:right}.sidebar-tenant-card__row dd.is-soon{color:#fbbf24}.sidebar-tenant-card__row dd.is-expired{color:#f87171}.sidebar-tenant-card__days{font-weight:400;font-size:.75rem;opacity:.85}.sidebar-user-card{display:flex;align-items:center;gap:.65rem;margin:.5rem .65rem .65rem;padding:.7rem .85rem;border-radius:12px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08)}.sidebar-user-avatar{width:2.25rem;height:2.25rem;border-radius:10px;background:linear-gradient(135deg,var(--color-primary-700, #1d4ed8),var(--color-primary-500, #3b82f6));color:#fff;font-size:.9375rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-user-text{min-width:0;flex:1}.sidebar-user-name{margin:0;font-size:.8125rem;font-weight:600;color:#f8fafc;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{margin:.1rem 0 0;font-size:.6875rem;font-weight:500;color:#94a3b8;text-transform:capitalize;line-height:1.2}.sidebar-tenant-info{padding:.5rem 1rem .65rem;border-bottom:1px solid var(--sidebar-border);font-size:.6875rem;line-height:1.35;color:var(--sidebar-text)}.sidebar-tenant-name{margin:0 0 .35rem;font-size:.75rem;font-weight:600;color:var(--sidebar-text-strong);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-tenant-dl{margin:0;display:grid;grid-template-columns:auto 1fr;gap:.15rem .5rem;align-items:baseline}.sidebar-tenant-dl dt{margin:0;font-weight:500;color:#94a3b8;font-size:.625rem;text-transform:uppercase;letter-spacing:.03em}.sidebar-tenant-dl dd{margin:0;font-size:.6875rem;color:var(--sidebar-text-strong);font-weight:500}.sidebar-tenant-days{font-weight:400;color:#94a3b8}.sidebar-tenant-warn{color:#fbbf24}.sidebar-tenant-warn.err{color:#f87171}.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:1rem .65rem;display:flex;flex-direction:column;gap:2px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) transparent}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-thumb{background:#ffffff2e;border-radius:6px}.sidebar-nav-caption{margin:.85rem .5rem .35rem;font-size:.6875rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#94a3b8d9}.sidebar-nav-caption:first-child{margin-top:.15rem}.sidebar-link,.sidebar-nav-group-toggle,.sidebar-logout{display:flex;align-items:center;gap:.65rem;width:calc(100% - .5rem);margin-left:.25rem;margin-right:.25rem;min-height:2.5rem;padding:.5rem .75rem;border:none;border-radius:var(--radius-lg);background:transparent;color:var(--sidebar-text);font-size:var(--sidebar-nav-font);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:#fff!important;font-weight:600;box-shadow:none}.sidebar-link.active .sidebar-link-icon{opacity:1;color:#fff}.sidebar-link.active .sidebar-link-label{color:#fff}.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:2px;padding:.35rem;border-radius:14px;background:var(--sidebar-submenu-bg);border:1px solid var(--sidebar-submenu-border);box-shadow:none}.sidebar-nav-group.is-active-section.is-open .sidebar-nav-group-items-inner{border-color:#ffffff1f}.sidebar-nav-group-items .sidebar-link{min-height:2.125rem;font-size:var(--sidebar-nav-sub-font);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:#ffffff59;transform:translateY(-50%)}.sidebar-nav-group-items .sidebar-link.active:before{background:#fff}.sidebar--ethereal .sidebar-footer{margin-top:0;padding:.75rem .65rem 1rem;border-top:1px solid var(--sidebar-border);background:var(--sidebar-bg)}.sidebar-logout{color:var(--sidebar-text);border:1px solid var(--sidebar-border);background:#ffffff0a}.sidebar-logout:hover{background:#f871711f;border-color:#f8717159;color:#fecaca}.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;font-size:var(--sidebar-nav-font)}.sidebar--ethereal .sidebar-nav-group-items a.sidebar-link{font-size:var(--sidebar-nav-sub-font)}.sidebar--ethereal .sidebar-nav-group-toggle,.sidebar--ethereal .sidebar-logout{font-size:var(--sidebar-nav-font)}.sidebar--ethereal a.sidebar-link.active{background:var(--sidebar-active-bg);color:#fff!important}.sidebar--ethereal a.sidebar-link.active .sidebar-link-label,.sidebar--ethereal a.sidebar-link.active .sidebar-link-icon{color:#fff}@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:var(--color-bg-app);padding:clamp(1rem,2.5vw,2rem);padding-top:0;min-width:0;display:flex;flex-direction:column;overflow-x:hidden}.layout--shell .main>.app-topbar{margin:0 calc(-1*clamp(1rem,2.5vw,2rem)) var(--space-4, 16px);flex-shrink:0}.layout--shell .main>.app-topbar--hotspot{width:calc(100% + 2*clamp(1rem,2.5vw,2rem));margin-left:calc(-1*clamp(1rem,2.5vw,2rem));margin-right:calc(-1*clamp(1rem,2.5vw,2rem))}.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 var(--color-border-soft)}.layout--shell .page-header-text{min-width:0}.layout--shell .card>h3{margin:0 0 1rem}.layout--shell .card>.section-heading-row{margin:0 0 1rem}.form-panel-policy{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--stack-md) var(--stack-lg);align-items:start;width:100%}.form-panel-policy .field--full{grid-column:1 / -1}.form-panel-policy .form-panel-actions{grid-column:1 / -1;display:flex;flex-wrap:wrap;align-items:center;gap:var(--stack-md);margin-top:.15rem}.form-panel-policy label.field input,.form-panel-policy label.field select,.form-panel-policy label.field textarea{width:100%;box-sizing:border-box}.form-panel-policy label.field input,.form-panel-policy label.field select{min-height:2.75rem}@media (max-width: 640px){.form-panel-policy{grid-template-columns:1fr}}.layout--shell .card .table-scroll{margin-top:0}.layout--shell table{border-radius:var(--radius-lg)}.layout--shell tr.table-empty-row td{background:var(--color-surface);color:var(--color-text-muted)}.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(2,minmax(0,1fr));gap:var(--stack-md);margin:0 0 var(--stack-lg);width:100%;align-items:stretch}@media (min-width: 720px){.dash-stats{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width: 1100px){.dash-stats:not(.dash-stats--hero):not(.dash-stats--4){grid-template-columns:repeat(5,minmax(0,1fr))}}.dash-stats--hero,.dash-stats--4{grid-template-columns:repeat(4,minmax(0,1fr));width:100%}@media (max-width: 900px){.dash-stats--hero,.dash-stats--4{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 520px){.dash-stats--hero,.dash-stats--4{grid-template-columns:1fr}}.dash-stat{display:flex;align-items:center;gap:.9rem;padding:1rem 1.1rem;min-height:5.5rem;height:100%;box-sizing:border-box;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:var(--shadow-lg);border-color:var(--color-primary-400, #60a5fa)}.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;justify-content:center;gap:.35rem;flex:1;min-width:0;min-height:3.25rem}.dash-stat-label{font-size:.6875rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--color-text-muted);line-height:1.35;min-height:2.7em;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.dash-stat-value{font-size:1.5rem;font-weight:700;letter-spacing:-.02em;color:var(--color-text-primary);line-height:1.15;flex-shrink:0}.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:var(--color-text-muted)}.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:var(--color-text-muted);font-weight:500}.dash-license-row dd{margin:0;font-weight:600;color:var(--color-text-primary)}.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:var(--color-surface-soft);font-size:.875rem}.dash-list li strong{font-weight:600;color:var(--color-text-primary)}.dash-list li span{color:var(--color-text-weak, var(--color-text-muted));font-size:.8125rem}.dash-empty{margin:0;color:var(--color-text-weak, var(--color-text-muted));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:var(--color-text-weak, var(--color-text-muted));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 var(--color-border-card, var(--color-border-soft));border-radius:var(--radius-lg);padding:1rem 1.1rem;background:var(--color-surface);box-shadow:var(--shadow-card, var(--shadow-sm))}.dash-mikrotik-card header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.dash-mikrotik-card header strong{font-size:.9375rem;color:var(--color-text-primary)}.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:var(--color-text-weak, var(--color-text-muted));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}.layout--shell .page-header h1,.layout--shell .page-title-row{color:var(--color-text-primary)}.layout--shell .page-header .page-subtitle{color:var(--color-text-secondary)}.dash-stat-label{color:var(--color-text-muted)}.dash-stat-value{color:var(--color-text-primary);font-weight:700}.dash-panel-title,.dash-faixa-etaria-title,.dash-stats-block-title{color:var(--color-text-muted)}.dash-panel-hint,.dash-empty,.dash-panel-footer a{color:var(--color-text-weak, var(--color-text-muted))}.dash-license-row dt{color:var(--color-text-muted)}.dash-license-row dd,.dash-list li strong,.dash-mikrotik-card header strong{color:var(--color-text-primary);font-weight:600}.dash-list li span,.dash-mikrotik-ip,.dash-faixa-footnote,.dash-pie-empty{color:var(--color-text-weak, var(--color-text-muted))}.layout--shell .card,.layout--shell .ui-card,.dash-stat.card,.dash-stat{background:var(--color-surface);border:1px solid var(--color-border-card, var(--color-border-soft));box-shadow:var(--shadow-card, var(--shadow-md));transition:background .2s ease,border-color .2s ease,box-shadow .2s ease,transform .15s ease}a.dash-stat:hover,.layout--shell .card:hover{background:var(--color-surface-hover, var(--color-surface-soft))}:root[data-theme=dark] .layout--shell .main{background:var(--color-bg-app)}:root[data-theme=dark] .layout--shell .page-header h1,:root[data-theme=dark] .layout--shell .page-title-row{background:none;-webkit-text-fill-color:var(--color-text-primary);color:var(--color-text-primary)}:root[data-theme=dark] .layout--shell .page-header .page-subtitle{color:var(--color-text-secondary)}:root[data-theme=dark] .layout--shell .card,:root[data-theme=dark] .layout--shell .ui-card,:root[data-theme=dark] .dash-stat,:root[data-theme=dark] .dash-panel.card,:root[data-theme=dark] .dash-mikrotik-card{background:var(--color-surface);border:1px solid rgba(148,163,184,.14);box-shadow:0 8px 24px #00000038}:root[data-theme=dark] a.dash-stat:hover,:root[data-theme=dark] .layout--shell .card:hover{background:var(--color-surface-hover);border-color:#60a5fa47;box-shadow:0 10px 28px #00000047}:root[data-theme=dark] .dash-stat-label,:root[data-theme=dark] .dash-panel-title,:root[data-theme=dark] .dash-faixa-etaria-title{color:var(--color-text-muted)}:root[data-theme=dark] .dash-stat-value{color:var(--color-text-primary);font-weight:700}:root[data-theme=dark] .dash-panel-hint,:root[data-theme=dark] .dash-empty,:root[data-theme=dark] .dash-faixa-footnote{color:var(--color-text-weak)}:root[data-theme=dark] .dash-list li{background:var(--color-surface-soft);border:1px solid rgba(148,163,184,.08)}:root[data-theme=dark] .dash-list li strong{color:var(--color-text-primary)}:root[data-theme=dark] .dash-list li span{color:var(--color-text-weak)}:root[data-theme=dark] .dash-quick-link{background:var(--color-surface);border-color:#94a3b824;color:var(--color-text-secondary)}:root[data-theme=dark] .dash-quick-link:hover{background:var(--color-surface-hover);border-color:#60a5fa47;color:var(--color-primary-400)}:root[data-theme=dark] .dash-panel-footer{border-top-color:#94a3b81f}:root[data-theme=dark] .dash-panel-footer a{color:var(--color-primary-400)}:root[data-theme=dark] .dash-nas-bar-wrap{background:#0f1b31cc}:root[data-theme=dark] .dash-faixa-legend{color:var(--color-text-secondary)}:root[data-theme=dark] .dash-faixa-center-value{fill:var(--color-text-primary)}:root[data-theme=dark] .dash-faixa-center-label{fill:var(--color-text-weak)}:root[data-theme=dark] .dash-stat-icon--slate{background:#94a3b81f;color:#94a3b8}:root[data-theme=dark] .dash-stat-icon--blue{background:#3b82f62e;color:#60a5fa}:root[data-theme=dark] .dash-stat-icon--emerald{background:#22c55e24;color:#4ade80}:root[data-theme=dark] .dash-stat-icon--amber{background:#fbbf2424;color:#fbbf24}:root[data-theme=dark] .dash-stat-icon--violet{background:#8b5cf624;color:#a78bfa}:root[data-theme=dark] .dash-stat-icon--rose{background:#f43f5e1f;color:#fb7185}:root[data-theme=dark] .app-topbar--hotspot{background:var(--color-surface);border-bottom-color:#94a3b81f}.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{min-width:200px;max-width:min(360px,calc(100vw - 24px));padding:.65rem .85rem;font-size:12px;line-height:1.5;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, .18));text-align:left;white-space:normal;word-wrap:break-word;pointer-events:none}.hint-icon-popover--portal{position:fixed;z-index:10050;margin:0;transform:none}.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-instance-card-head{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.75rem}.wa-instance-card-head .section-heading-row{margin:0}.wa-instance-hero{display:flex;align-items:center;gap:1rem;padding:1.1rem 1.25rem;margin-bottom:1rem;border-radius:var(--radius-lg);border:1px solid var(--border-subtle);background:var(--surface-container-low)}.wa-instance-hero-dot{width:1rem;height:1rem;border-radius:50%;flex-shrink:0;background:var(--surface-container-highest);box-shadow:0 0 0 4px #94a3b840}.wa-instance-hero--open{background:var(--status-success-bg);border-color:#10b98159}.wa-instance-hero--open .wa-instance-hero-dot{background:var(--status-success);box-shadow:0 0 0 4px #10b98140}.wa-instance-hero--open .wa-instance-hero-value{color:#047857}.wa-instance-hero--close .wa-instance-hero-dot,.wa-instance-hero--err .wa-instance-hero-dot{background:var(--status-error);box-shadow:0 0 0 4px #ef444433}.wa-instance-hero--close,.wa-instance-hero--err{background:var(--status-error-bg);border-color:#ef44444d}.wa-instance-hero--close .wa-instance-hero-value,.wa-instance-hero--err .wa-instance-hero-value{color:#b91c1c}.wa-instance-hero--connecting,.wa-instance-hero--warn{background:var(--status-warning-bg);border-color:#f59e0b59}.wa-instance-hero--connecting .wa-instance-hero-dot,.wa-instance-hero--warn .wa-instance-hero-dot{background:var(--status-warning);box-shadow:0 0 0 4px #f59e0b40;animation:wa-hero-pulse 1.2s ease-in-out infinite}.wa-instance-hero--connecting .wa-instance-hero-value,.wa-instance-hero--warn .wa-instance-hero-value{color:#b45309}.wa-instance-hero--not_created,.wa-instance-hero--offline{background:var(--surface-container-low)}@keyframes wa-hero-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.65;transform:scale(.92)}}.wa-instance-hero-text{display:flex;flex-direction:column;gap:.2rem;min-width:0}.wa-instance-hero-label{font-size:.6875rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--on-surface-variant)}.wa-instance-hero-value{font-size:1.5rem;font-weight:700;letter-spacing:-.02em;line-height:1.15;color:var(--on-surface)}.wa-instance-hero-meta{font-size:.8125rem;color:var(--on-surface-variant);margin-top:.15rem}.wa-webhook-hint{margin:0 0 1rem;padding:.55rem .75rem;border:1px dashed var(--border-subtle);border-radius:var(--radius-md);font-size:.8125rem;line-height:1.45;color:var(--on-surface-variant)}.wa-webhook-hint code{font-size:.75rem;word-break:break-all}.status-inline{display:inline-flex;align-items:center;gap:.35rem;font-size:var(--text-label-sm, .875rem)}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;background:var(--surface-container-highest)}.status-dot--online{background:var(--status-success)}.status-dot--offline{background:var(--surface-container-highest)}.status-dot--warn{background:var(--status-warning)}.status-dot--err{background:var(--status-error)}.wa-status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem;margin-bottom:1rem}.wa-status-grid--details{grid-template-columns:repeat(3,minmax(0,1fr))}@media (max-width: 720px){.wa-status-grid--details{grid-template-columns:1fr}.wa-instance-hero-value{font-size:1.35rem}}.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}.async-ui-loading{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;display:flex;align-items:center;justify-content:center;background:#0f172a73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);pointer-events:all}.async-ui-loading-card{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:1.75rem 2rem;background:var(--surface-container-highest, #fff);border-radius:16px;box-shadow:0 20px 50px #0003;max-width:320px;text-align:center}.async-ui-spinner{width:40px;height:40px;border:3px solid var(--outline-variant, #e2e8f0);border-top-color:var(--primary, #0f172a);border-radius:50%;animation:async-ui-spin .75s linear infinite}@keyframes async-ui-spin{to{transform:rotate(360deg)}}.async-ui-loading-text{margin:0;font-size:15px;font-weight:500;color:var(--on-surface, #1e293b)}.async-ui-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10001;display:flex;align-items:center;justify-content:center;padding:1rem;background:#0f172a8c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.async-ui-modal{width:100%;max-width:420px;background:var(--surface-container-highest, #fff);border-radius:16px;box-shadow:0 24px 60px #00000040;overflow:hidden}.async-ui-modal-header{display:flex;align-items:center;gap:.75rem;padding:1.25rem 1.5rem .5rem}.async-ui-modal-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}.async-ui-modal-icon--error{background:#fef2f2;color:#dc2626}.async-ui-modal-icon--success{background:#f0fdf4;color:#16a34a}.async-ui-modal-title{margin:0;font-size:1.1rem;font-weight:600}.async-ui-modal-body{margin:0;padding:.5rem 1.5rem 1.25rem;font-size:14px;line-height:1.5;color:var(--on-surface-variant, #475569);white-space:pre-wrap;word-break:break-word}.async-ui-modal-footer{padding:0 1.5rem 1.25rem;display:flex;justify-content:flex-end;gap:.5rem}.async-ui-modal-btn{padding:.5rem 1.25rem;border-radius:8px;border:none;font-size:14px;font-weight:600;cursor:pointer;background:var(--primary, #0f172a);color:var(--on-primary, #fff)}.async-ui-modal-btn:hover{opacity:.9}.async-ui-toast-stack{position:fixed;top:1rem;right:1rem;z-index:10002;display:flex;flex-direction:column;gap:.5rem;max-width:min(360px,calc(100vw - 2rem));pointer-events:none}.async-ui-toast{pointer-events:auto;padding:.75rem 1rem;border-radius:10px;font-size:14px;line-height:1.4;box-shadow:0 8px 24px #00000026;animation:async-ui-toast-in .25s ease}@keyframes async-ui-toast-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.async-ui-toast--success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.async-ui-toast--info{background:#eff6ff;color:#1e40af;border:1px solid #bfdbfe}.async-ui-toast--warn{background:#fffbeb;color:#92400e;border:1px solid #fde68a}.preview-viewport{display:flex;flex-direction:column;gap:.5rem;width:100%;min-width:0;min-height:0;flex:1}.preview-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem .75rem;flex-shrink:0}.preview-toolbar__zoom{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .35rem;background:var(--surface-container-lowest, #fff);border:1px solid var(--border-subtle, #cbd5e1);border-radius:var(--radius-full, 999px)}.preview-toolbar__zoom-btn{width:2rem;height:2rem;border:none;border-radius:var(--radius-full, 999px);background:var(--surface-container-low, #f1f5f9);color:var(--on-surface, #0f172a);font-size:1.1rem;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.preview-toolbar__zoom-btn:hover{background:var(--surface-container, #e2e8f0)}.preview-toolbar__zoom-select{border:none;background:transparent;font-size:.8rem;font-weight:600;color:var(--on-surface, #0f172a);padding:.25rem .35rem;cursor:pointer;min-width:3.5rem;text-align:center}.preview-toolbar__fit-btn{border:none;border-radius:var(--radius-full, 999px);padding:.35rem .75rem;font-size:.75rem;font-weight:600;background:var(--primary, #0f172a);color:var(--on-primary, #fff);cursor:pointer;margin-left:.15rem}.preview-toolbar__fit-btn:hover{opacity:.9}.preview-toolbar__scale-hint{font-size:.7rem;color:var(--on-surface-variant, #64748b);padding:0 .35rem;white-space:nowrap}.preview-viewport__stage{flex:1;min-height:320px;max-height:min(82vh,920px);min-width:0;overflow:hidden;padding:.5rem;background:radial-gradient(ellipse at 50% 0%,rgba(148,163,184,.14),transparent 72%),var(--surface-container-low, #f1f5f9);border-radius:var(--radius-lg, 12px);border:1px solid var(--border-subtle, #e2e8f0)}.preview-viewport__stage-center{width:100%;height:100%;min-height:0;display:flex;align-items:center;justify-content:center;overflow:hidden}.preview-viewport__scaled-holder{position:relative;flex-shrink:0;overflow:hidden}.preview-viewport__device-root{transform-origin:top left;position:absolute;top:0;left:0;will-change:transform}.preview-viewport__hint{margin:0;text-align:center;font-size:.68rem;color:var(--on-surface-variant, #64748b);line-height:1.4;flex-shrink:0}.preview-device-toolbar{display:inline-flex;flex-wrap:wrap;gap:.35rem;padding:.25rem;background:var(--surface-container, #e2e8f0);border-radius:var(--radius-full, 999px);border:1px solid var(--border-subtle, #cbd5e1)}.preview-device-toolbar__btn{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .75rem;border:none;border-radius:var(--radius-full, 999px);background:transparent;color:var(--on-surface-variant, #475569);font-size:.8rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.preview-device-toolbar__btn:hover{background:#fff9;color:var(--on-surface, #0f172a)}.preview-device-toolbar__btn--active{background:var(--surface-container-lowest, #fff);color:var(--on-surface, #0f172a);box-shadow:0 1px 4px #0f172a1f}.preview-device-toolbar__dims{font-size:.65rem;opacity:.75;font-weight:400}@media (max-width: 520px){.preview-device-toolbar__dims{display:none}}.visual-preview-device--logical{width:100%;height:100%;min-height:0}.visual-preview-device{position:relative;box-sizing:border-box;display:flex;flex-direction:column;background:#1e293b;border-radius:1.35rem;box-shadow:0 0 0 1px #0f172a40,0 16px 40px #0f172a38;overflow:hidden}.visual-preview-device--tablet{border-radius:1.15rem}.visual-preview-device--desktop{border-radius:.55rem;background:#334155}.visual-preview-chrome--mobile .visual-preview-notch{position:absolute;top:0;left:50%;transform:translate(-50%);width:38%;max-width:120px;height:22px;background:#1e293b;border-radius:0 0 14px 14px;z-index:5;pointer-events:none}.visual-preview-chrome--tablet .visual-preview-tablet-cam{position:absolute;top:10px;left:50%;transform:translate(-50%);width:10px;height:10px;border-radius:50%;background:#0f172a;border:2px solid #475569;z-index:5}.visual-preview-browser-bar{display:flex;align-items:center;gap:.4rem;padding:.45rem .65rem;background:#1e293b;border-bottom:1px solid #475569;flex-shrink:0}.visual-preview-browser-dot{width:9px;height:9px;border-radius:50%;background:#64748b}.visual-preview-browser-dot:nth-child(1){background:#f87171}.visual-preview-browser-dot:nth-child(2){background:#fbbf24}.visual-preview-browser-dot:nth-child(3){background:#4ade80}.visual-preview-browser-url{flex:1;margin-left:.35rem;padding:.2rem .6rem;font-size:.65rem;color:#94a3b8;background:#0f172a;border-radius:4px;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.visual-preview-home-indicator{position:absolute;bottom:6px;left:50%;transform:translate(-50%);width:32%;max-width:120px;height:4px;background:#ffffff59;border-radius:4px;z-index:5;pointer-events:none}.visual-preview-screen{position:relative;flex:1;min-height:0;width:100%;overflow:hidden;background:#0f172a}.visual-preview-screen--portal{background:var(--surface, #f8fafc);overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;scrollbar-gutter:stable}.visual-preview-screen--portal .portal-editor-colorbar{top:auto;bottom:.65rem;right:.5rem;left:auto}.visual-preview-screen--campaign{background:#000;overflow:hidden}.visual-preview-device--desktop .visual-preview-screen{border-radius:0 0 .5rem .5rem}.visual-preview-meta{margin:.5rem 0 0;text-align:center;font-size:var(--text-label-sm, .75rem);color:var(--on-surface-variant, #64748b)}.visual-preview-screen .campaign-screen{position:absolute;top:0;right:0;bottom:0;left:0;min-height:0;height:100%;width:100%;overflow:hidden}.campanha-preview-empty{display:flex;align-items:center;justify-content:center;min-height:100%;padding:2rem 1.5rem;text-align:center;color:#94a3b8;font-size:.9rem;line-height:1.5}.visual-preview-screen--portal .portal-preview-screen{position:relative;width:100%;min-height:100%;box-sizing:border-box}.portal-preview-screen .portal-canvas{width:100%;min-height:100%;min-width:0;display:flex;align-items:center;justify-content:center;padding:max(.75rem,12px);padding-top:max(1.25rem,20px);padding-bottom:max(1.5rem,24px);box-sizing:border-box}.portal-preview-screen .portal-canvas-inner{width:100%;max-width:420px;margin:0 auto;flex-shrink:0}.visual-preview-screen--portal[data-device=mobile] .portal-canvas-inner{max-width:100%}.visual-preview-screen--portal[data-device=mobile] .portal-canvas{align-items:flex-start;padding-top:max(2rem,28px)}.visual-preview-screen--portal[data-device=tablet] .portal-canvas-inner,.visual-preview-screen--portal[data-device=desktop] .portal-canvas-inner{max-width:420px}.portal-preview-screen .portal-canvas-card-ethereal{width:100%;box-sizing:border-box}.visual-preview-device:not([data-device]){max-width:390px}.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}.url-access-pill{display:inline-block;font-size:12px;font-weight:600;padding:4px 10px;border-radius:var(--radius-lg, .5rem)}.url-access-status{line-height:1.4}.ficha-section .guia-list li{font-size:14px}.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-block{margin-bottom:var(--stack-lg)}.dash-stats-block-title{margin:0 0 .65rem;font-size:.7rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--on-surface-variant)}.dash-stats--hero{grid-template-columns:repeat(4,minmax(0,1fr))}.dash-stats--hero .dash-stat{min-height:5.5rem;align-items:center}@media (max-width: 1100px){.dash-stats--hero{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 520px){.dash-stats--hero{grid-template-columns:1fr}}.dash-stat-compact{display:flex;align-items:flex-start;gap:.75rem;min-height:5.25rem;padding:.9rem 1rem;text-decoration:none;color:inherit;transition:border-color .15s ease,box-shadow .15s ease}a.dash-stat-compact:hover{text-decoration:none;border-color:#cbd5e1;box-shadow:0 8px 24px -14px #0f172a1f}.dash-stat-compact-icon{width:2.25rem;height:2.25rem;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.dash-stat-compact-icon svg{width:1.15rem;height:1.15rem}.dash-stat-compact-icon--blue{background:#0065911f;color:#006591}.dash-stat-compact-icon--slate{background:#f1f5f9;color:#64748b}.dash-stat-compact-icon--violet{background:#8b5cf61a;color:#7c3aed}.dash-stat-compact-icon--emerald{background:#10b9811a;color:#059669}.dash-stat-compact-icon--amber{background:#f59e0b1a;color:#d97706}.dash-stat-compact-icon--rose{background:#f43f5e1a;color:#e11d48}.dash-stat-compact-body{display:flex;flex-direction:column;justify-content:space-between;flex:1;min-width:0;min-height:3.25rem;gap:.4rem}.dash-stat-compact-label{font-size:.68rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--on-surface-variant);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-stat-compact-row{display:flex;align-items:baseline;flex-wrap:nowrap;gap:.4rem}.dash-stat-compact-row b{font-size:1.4rem;font-weight:700;line-height:1;color:var(--on-surface);flex-shrink:0}.dash-stat-compact-hint{font-size:.78rem;color:var(--on-surface-variant);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-stats--compact{gap:.65rem}.dash-stats--compact-4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr))}@media (max-width: 960px){.dash-stats--compact-4{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 480px){.dash-stats--compact-4{grid-template-columns:1fr}}.alertas-legend{display:flex;flex-wrap:wrap;align-items:center;gap:1rem}.alertas-legend-item{font-size:.8rem;font-weight:600;padding:.2rem .55rem .2rem .65rem;border-radius:var(--radius-sm);border-left:3px solid transparent}.alertas-legend-item--critico{color:#9f1239;background:#ef44440f;border-left-color:#ef444473}.alertas-legend-item--warn{color:#92400e;background:#f59e0b12;border-left-color:#f59e0b80}.alertas-legend-item--ok{color:#047857;background:#10b9810f;border-left-color:#10b98173}.alertas-table tbody tr.alert-row--critico{background:#ef444409}.alertas-table tbody tr.alert-row--critico td:first-child{box-shadow:inset 3px 0 #ef444466}.alertas-table tbody tr.alert-row--warn{background:#f59e0b0a}.alertas-table tbody tr.alert-row--warn td:first-child{box-shadow:inset 3px 0 #f59e0b73}.alertas-table tbody tr.alert-row--ok{background:#10b98108}.alertas-table tbody tr.alert-row--ok td:first-child{box-shadow:inset 3px 0 #10b98161}.alert-tipo-pill{display:inline-block;font-size:.78rem;font-weight:600;padding:.15rem .45rem;border-radius:var(--radius-sm)}.alert-tipo-pill--critico{color:#9f1239;background:#ef444414}.alert-tipo-pill--warn{color:#92400e;background:#f59e0b1a}.alert-tipo-pill--ok{color:#047857;background:#10b98114}.alert-status{font-size:.85rem;font-weight:600}.alert-status--critico{color:#b91c1c}.alert-status--warn{color:#b45309}.alert-status--ok{color:#059669}.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}.infra-avisos p{font-size:var(--text-label-sm)}.infra-recomendacao p{margin:0 0 .75rem;line-height:1.5}.infra-list{margin:.5rem 0 1rem;padding-left:1.25rem;color:var(--on-surface-variant)}.infra-kpi-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem}.infra-kpi-row b{display:block;font-size:1.35rem;margin-top:.2rem}.infra-filters{display:flex;flex-wrap:wrap;align-items:flex-end;gap:1rem;margin-bottom:1rem}.infra-filters .field{margin:0;min-width:160px}
