@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";.wa-connection-hero{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem 1.25rem;margin-bottom:var(--stack-lg);padding:1.25rem 1.5rem;border-radius:var(--radius-lg);border:2px solid var(--border-subtle);background:var(--surface-container-low)}.wa-connection-hero--open{border-color:color-mix(in srgb,var(--status-success) 55%,transparent);background:color-mix(in srgb,var(--status-success) 12%,var(--surface-container-low))}.wa-connection-hero--close,.wa-connection-hero--err{border-color:color-mix(in srgb,var(--status-error) 45%,transparent);background:color-mix(in srgb,var(--status-error) 10%,var(--surface-container-low))}.wa-connection-hero--warn,.wa-connection-hero--connecting{border-color:color-mix(in srgb,var(--status-warning, #f59e0b) 50%,transparent);background:color-mix(in srgb,var(--status-warning, #f59e0b) 10%,var(--surface-container-low))}.wa-connection-hero--offline{opacity:.92}.wa-connection-hero__main{flex:1 1 12rem;min-width:0}.wa-connection-hero__label{font-size:var(--text-label-sm);font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--on-surface-variant);margin:0 0 .35rem}.wa-connection-hero__state{display:flex;align-items:center;gap:.65rem;margin:0;font-size:1.75rem;font-weight:700;line-height:1.2;color:var(--on-surface)}.wa-connection-hero__state .status-dot{width:14px;height:14px;flex-shrink:0}.wa-connection-hero__meta{margin:.5rem 0 0;font-size:var(--text-sm);color:var(--on-surface-variant)}.wa-connection-hero__meta code{font-size:.9em}.wa-connection-hero__aside{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}.wa-steps{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.wa-qr-box{min-height:280px;display:flex;align-items:center;justify-content:center;border:2px dashed var(--border-subtle);border-radius:var(--radius-lg);background:var(--surface-container-low);margin:1rem 0;padding:1rem}.wa-qr-box img{max-width:280px;width:100%;height:auto;background:#fff;padding:8px;border-radius:var(--radius-md)}.wa-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin:1rem 0}.wa-metric{text-align:center;padding:.75rem;background:var(--surface-container-low);border-radius:var(--radius-md)}.wa-metric b{display:block;font-size:1.5rem}.wa-metric--msg b{color:var(--status-info)}.wa-metric--ct b{color:var(--status-success)}.wa-metric--chat b{color:var(--status-pro)}.wa-status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem;margin-bottom:1rem}.wa-status-cell{padding:.65rem .75rem;background:var(--surface-container-low);border-radius:var(--radius-md);font-size:var(--text-sm)}.wa-status-cell dt{font-size:var(--text-label-sm);color:var(--on-surface-variant);margin-bottom:.2rem}.wa-status-cell dd{margin:0;font-weight:600}.wa-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}: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,.form-panel-policy .policy-checkbox-group,.form-panel-policy .field--checkbox{grid-column:1 / -1}.form-panel-policy .policy-checkbox-group{display:flex;flex-direction:column;gap:.65rem;padding:.15rem 0}.form-panel-policy .field--checkbox,.form-panel-policy .policy-checkbox-group .portal-editor-check{display:flex;flex-direction:row;align-items:flex-start;gap:.65rem;width:100%;text-transform:none;letter-spacing:normal;font-weight:500;font-size:var(--text-body-md);line-height:1.45;color:var(--on-surface);cursor:pointer}.form-panel-policy .field--checkbox input[type=checkbox],.form-panel-policy .policy-checkbox-group .portal-editor-check input[type=checkbox]{width:1rem;min-width:1rem;min-height:1rem;margin:.15rem 0 0;flex-shrink:0}.form-panel-policy .field--checkbox span,.form-panel-policy .policy-checkbox-group .portal-editor-check span{flex:1;min-width:0}.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[type=checkbox],.form-panel-policy label.field input[type=radio]{width:auto;min-height:auto}.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}.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}.dash-grid--auto{grid-template-columns:repeat(auto-fit,minmax(min(100%,17.5rem),1fr));align-items:stretch;width:100%}.dash-grid--auto>.card,.dash-grid--auto>section{min-width:0}.dash-grid--analytics{grid-template-columns:1fr 1fr minmax(220px,1fr);align-items:stretch;width:100%}@media (max-width: 1100px){.dash-grid--analytics{grid-template-columns:1fr 1fr}.dash-panel--nas-compact{grid-column:1 / -1}}@media (max-width: 700px){.dash-grid--analytics{grid-template-columns:1fr}}.dash-panel--faixas{padding-top:1rem}.dash-faixa-etaria{display:flex;flex-direction:column;align-items:center;gap:.75rem;width:100%}.dash-faixa-etaria-title{align-self:flex-start;margin:0;font-size:.8125rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted)}.dash-faixa-legend{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem 1.25rem;max-width:320px;font-size:.8125rem;color:var(--on-surface-variant)}.dash-faixa-legend li{display:inline-flex;align-items:center;gap:.4rem}.dash-faixa-legend-swatch{width:14px;height:10px;border-radius:2px;flex-shrink:0}.dash-faixa-chart{display:flex;justify-content:center;width:100%}.dash-faixa-svg{display:block}.dash-faixa-center-value{font-size:1.75rem;font-weight:700;fill:var(--color-text-primary);font-family:var(--font-sans)}.dash-faixa-center-label{font-size:.625rem;font-weight:500;fill:var(--color-text-weak, var(--color-text-muted));font-family:var(--font-sans)}.dash-faixa-footnote{margin:0;font-size:.75rem;color:var(--on-surface-variant);text-align:center}.dash-pie-empty{color:var(--on-surface-variant);font-size:.875rem;margin:.5rem 0 0}.dash-nas-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.75rem}.dash-nas-list li{display:flex;flex-direction:column;gap:.35rem}.dash-nas-list li>div{display:flex;justify-content:space-between;align-items:baseline;gap:.5rem}.dash-nas-bar-wrap{display:flex;align-items:center;gap:.5rem;background:var(--chart-track, #f1f5f9);border-radius:6px;height:8px;position:relative;overflow:hidden}.dash-nas-bar{display:block;height:100%;background:linear-gradient(90deg,var(--chart-series-1, #006591),var(--chart-series-2, #38bdf8));border-radius:6px;min-width:4px}.dash-nas-bar-wrap em{position:absolute;right:6px;top:-18px;font-style:normal;font-size:.75rem;font-weight:600;color:var(--chart-label, #475569)}.dash-panel--nas-compact{padding:.85rem 1rem 1rem}.dash-nas-compact{display:flex;flex-direction:column;gap:.5rem;height:100%}.dash-nas-compact .dash-faixa-etaria-title{margin-bottom:.15rem}.dash-nas-list--compact{gap:.5rem}.dash-nas-list--compact li{gap:.2rem}.dash-nas-compact__head{display:flex;align-items:center;justify-content:space-between;gap:.35rem;min-width:0}.dash-nas-compact__name{font-size:.8125rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-nas-compact__count{font-size:.75rem;font-weight:700;color:var(--color-primary-600);flex-shrink:0}.dash-nas-compact__ip{font-size:.6875rem;color:var(--color-text-muted);font-family:var(--font-mono)}.dash-nas-bar-wrap--compact{height:5px}.dash-nas-bar-wrap--compact .dash-nas-bar{min-width:2px}.license-dl{display:grid;gap:.65rem;margin:0}.license-dl>div{display:grid;grid-template-columns:11rem 1fr;gap:var(--stack-md);align-items:baseline}.license-dl dt{margin:0;font-size:var(--text-label-sm);font-weight:600;color:var(--on-surface-variant);text-transform:uppercase;letter-spacing:.03em}.license-dl dd{margin:0}.juridico-top-grid .license-dl--fluid>div{grid-template-columns:minmax(5.5rem,8.5rem) minmax(0,1fr)}@media (max-width: 420px){.juridico-top-grid .license-dl--fluid>div{grid-template-columns:1fr;gap:.15rem}}.juridico-wan-scroll{max-height:min(22rem,50vh);overflow-y:auto;padding-right:.15rem}.dash-list--wrap li{flex-wrap:wrap;align-items:flex-start;gap:.35rem .75rem}.dash-list--wrap li strong{flex:0 1 auto;min-width:6.5rem;word-break:break-all}.dash-list--wrap li span{flex:1 1 10rem;min-width:0;text-align:right;word-break:break-word;line-height:1.35}@media (max-width: 520px){.dash-list--wrap li{flex-direction:column;align-items:stretch}.dash-list--wrap li span{text-align:left}}.juridico-tables-grid{grid-template-columns:repeat(auto-fit,minmax(min(100%,22rem),1fr))}.portais-page-header{margin-bottom:1.25rem}.portais-page-header h1{margin:0 0 .35rem;font-size:var(--text-headline-lg)}.portais-page-sub{margin:0;max-width:52rem}.portais-flow-hint{display:flex;align-items:flex-start;gap:.75rem;padding:1rem 1.25rem;background:var(--status-info-bg);border:1px solid rgba(59,130,246,.25);border-radius:var(--radius-xl);margin-bottom:1.25rem;font-size:var(--text-body-md);color:var(--on-surface-variant)}.portais-flow-hint--warn{background:var(--status-warning-bg);border-color:#f59e0b59}.portais-flow-hint code{font-family:var(--font-mono);font-size:.875em;background:var(--surface-container-low);padding:.1rem .35rem;border-radius:var(--radius-sm)}.portais-flow-arrow{color:var(--secondary);font-weight:700}.portais-duo{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.25rem;align-items:start;width:100%}@media (max-width: 768px){.portais-duo{grid-template-columns:1fr}}.portais-duo-col{display:flex;flex-direction:column;gap:.5rem;min-width:0}.portais-duo-label{margin:0;font-size:var(--text-label-sm);font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--on-surface-variant)}.portais-duo--legados{margin-top:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.portais-legados{margin-top:1.5rem;padding:.75rem 1rem;background:var(--surface-container-low);border-radius:var(--radius-lg);border:1px solid var(--border-subtle)}.portais-legados summary{cursor:pointer;font-weight:500;color:var(--on-surface-variant)}.portais-status-section{margin-top:1.5rem;padding:1.25rem 1.35rem}.portais-status-section-title{margin:0 0 .35rem;font-size:var(--text-title-md);font-weight:600}.portais-status-section-lead{margin:0 0 1.1rem;font-size:var(--text-body-md);color:var(--on-surface-variant);line-height:1.45;max-width:52rem}.portais-status-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;align-items:stretch}.portais-status-card{display:flex;flex-direction:column;min-width:0;border:1px solid var(--border-subtle);border-radius:var(--radius-xl);background:var(--surface-container-lowest);overflow:hidden}.portais-status-card-head{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:.5rem;padding:.85rem 1rem;border-bottom:1px solid var(--border-subtle);background:var(--surface-container-low)}.portais-status-card-title{margin:0;font-size:var(--text-title-sm);font-weight:600}.portais-status-card-sub{margin:.2rem 0 0;font-size:var(--text-label-sm);color:var(--on-surface-variant)}.portais-status-card-actions{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center}.portais-status-card-preview{flex:1;min-height:300px;max-height:380px;overflow:hidden;position:relative}.portais-status-screen{height:100%;min-height:300px;padding:.75rem;display:flex;align-items:flex-start;justify-content:center;overflow-y:auto;box-sizing:border-box}.portais-status-screen-card{width:100%;max-width:320px;background:#ffffffeb;border-radius:var(--radius-xl);box-shadow:0 8px 28px #0f172a1f;padding:.85rem .9rem 1rem;text-align:center}.portal-status-screen-logo{max-height:40px;max-width:140px;margin:0 auto .5rem;object-fit:contain}.portal-status-screen-logo-ph{width:40px;height:40px;margin:0 auto .5rem;border-radius:var(--radius-md);background:var(--surface-container-low);display:flex;align-items:center;justify-content:center;font-size:1.1rem}.portal-status-screen-body{text-align:left}.portal-status-success h3{margin:0 0 .35rem;font-size:1rem;font-weight:700;color:var(--on-surface);text-align:center}.portal-status-success-lead{margin:0 0 .65rem;font-size:.8rem;color:var(--on-surface-variant);text-align:center;line-height:1.4}.portal-status-resumo{background:var(--surface-container-low);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:.5rem .65rem;margin:.5rem 0}.portal-status-resumo-row{display:flex;justify-content:space-between;gap:.5rem;padding:.35rem 0;border-bottom:1px solid var(--border-subtle);font-size:.72rem}.portal-status-resumo-row:last-child{border-bottom:none}.portal-status-resumo-row span{color:var(--on-surface-variant);text-transform:uppercase;font-size:.62rem;letter-spacing:.03em}.portal-status-resumo-row strong{color:var(--on-surface);text-align:right}.portal-status-success-hint{margin:.5rem 0 0;font-size:.68rem;color:var(--on-surface-variant);line-height:1.35;text-align:center}.portal-status-success-btn{display:block;width:100%;margin-top:.5rem;padding:.55rem .75rem;border-radius:var(--radius-md);border:1px solid transparent;color:#fff;font-size:.8rem;font-weight:600;text-align:center}.portal-status-screen--connected{background:linear-gradient(165deg,#1e293b,#0f172a);align-items:center}.portal-status-connected-card{width:100%;max-width:300px;background:#1e293b;border:1px solid #334155;border-radius:14px;padding:1.1rem 1rem;text-align:center;color:#e2e8f0;box-shadow:0 12px 32px #00000059}.portal-status-connected-icon{width:44px;height:44px;margin:0 auto .65rem;border-radius:50%;background:#38bdf826;display:flex;align-items:center;justify-content:center;font-size:1.35rem;font-weight:700}.portal-status-connected-title{margin:0 0 .25rem;font-size:1.05rem;font-weight:700}.portal-status-connected-lead{margin:0 0 .75rem;font-size:.78rem;color:#94a3b8;line-height:1.4}.portal-status-connected-empresa{margin:0 0 .65rem;font-size:.7rem;color:#64748b}.portal-status-connected-row{display:flex;justify-content:space-between;gap:.5rem;padding:.45rem 0;border-bottom:1px solid #334155;font-size:.75rem;text-align:left}.portal-status-connected-row strong{color:#f1f5f9}.portal-status-connected-btn{display:block;width:100%;margin-top:.85rem;padding:.65rem;border-radius:8px;font-size:.82rem;font-weight:700;text-align:center}.portal-status-connected-hint{margin:.65rem 0 0;font-size:.65rem;color:#64748b;line-height:1.35}.portal-card{display:flex;flex-direction:column;min-height:280px;background:var(--surface-container-lowest);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-hover)}.portal-card--empty{align-items:center;justify-content:center;padding:2rem;text-align:center;gap:1rem}.portal-card-accent{height:5px;flex-shrink:0}.portal-card-content{display:flex;flex-direction:column;flex:1;padding:1.25rem;gap:.75rem}.portal-card-head{display:flex;align-items:flex-start;gap:.75rem}.portal-card-icon-wrap{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);background:var(--surface-container-low)}.portal-card-titles{flex:1;min-width:0}.portal-card-titles h3{margin:0;font-size:var(--text-body-lg);font-weight:600;line-height:1.3}.portal-card-slug{margin:.15rem 0 0;font-size:var(--text-label-sm);font-family:var(--font-mono);color:var(--on-surface-variant)}.portal-card-desc{margin:0;font-size:var(--text-body-md);color:var(--on-surface-variant);line-height:1.45}.portal-card-stats{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.5rem 1rem;font-size:var(--text-label-sm);color:var(--on-surface-variant)}.portal-card-stats strong{color:var(--on-surface)}.portal-card-actions{margin-top:auto;display:flex;flex-direction:column;gap:.5rem;padding-top:.75rem;border-top:1px solid var(--border-subtle)}.portal-card-btn-primary{width:100%;padding:.65rem 1rem;border:none;border-radius:var(--radius-lg);background:var(--primary);color:var(--on-primary);font-weight:600;font-size:var(--text-body-md);cursor:pointer}.portal-card-btn-primary:hover{filter:brightness(1.08)}.portal-card-btn-link{text-align:center;font-size:var(--text-label-sm);color:var(--secondary);text-decoration:none;font-weight:500}.portal-card-btn-link:hover{text-decoration:underline}.portal-tipo-badge{flex-shrink:0;white-space:nowrap;padding:.25rem .55rem;font-size:.6875rem;font-weight:600;border-radius:var(--radius-md);border:1px solid;line-height:1.2}.portal-tipo-badge--lgpd,.portal-tipo-badge--cadastro{background:#06b6d41f;color:#0e7490;border-color:#06b6d459}.portal-card--cadastro .portal-card-icon-wrap{background:#06b6d414}.portal-card--login .portal-card-icon-wrap{background:#3b82f614}.portal-tipo-badge--login{background:#3b82f61f;color:#1d4ed8;border-color:#3b82f659}.portais-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;padding:1rem}.portais-modal{background:var(--surface-container-lowest);border-radius:var(--radius-xl);padding:1.5rem;max-width:520px;width:100%;box-shadow:var(--shadow-modal)}.portais-tipo-pick{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin:1rem 0}.portais-tipo-option{padding:1rem;border:2px solid var(--border-subtle);border-radius:var(--radius-lg);cursor:pointer;text-align:center;background:var(--surface-container-lowest)}.portais-tipo-option.selected{border-color:var(--secondary);background:var(--status-info-bg)}.portais-tipo-option-icon{display:block;margin:0 auto .5rem}.portais-tipo-option-desc{display:block;font-size:var(--text-label-sm);color:var(--on-surface-variant);margin-top:.25rem}.portais-hero{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.25rem;padding:1.25rem 1.5rem}.portais-hero-title{margin:0 0 .35rem;font-size:var(--text-headline-lg)}.portais-hero-sub{margin:0;max-width:42rem;color:var(--on-surface-variant);line-height:1.5}.portais-flow-steps{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem 1rem;margin-bottom:1.25rem;padding:1rem 1.25rem}.portais-flow-step{display:flex;align-items:center;gap:.65rem;font-size:var(--text-body-md)}.portais-flow-step-num{width:28px;height:28px;border-radius:50%;background:var(--secondary);color:var(--on-secondary, #fff);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8125rem;flex-shrink:0}.portais-flow-step--done .portais-flow-step-num{background:var(--status-success, #16a34a)}.portais-flow-step-arrow{color:var(--on-surface-variant);font-weight:700;font-size:1.25rem}.portais-flow-code{display:block;margin-top:.15rem;font-family:var(--font-mono);font-size:.75rem;color:var(--on-surface-variant)}.portais-duo-step{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--surface-container-high);font-size:.75rem;font-weight:700;margin-right:.35rem}.portais-duo-head{display:flex;align-items:center;margin-bottom:.25rem}.portais-empty-all{text-align:center;padding:2rem;margin-top:1rem}.portais-empty-all h3{margin-top:0}.portal-temas-rapidos{display:flex;flex-direction:column;gap:.5rem}.portal-temas-rapidos-label{font-size:var(--text-label-sm);font-weight:600;color:var(--on-surface-variant)}.portal-temas-rapidos-row{display:flex;flex-wrap:wrap;gap:.5rem}.portal-tema-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .65rem;border:1px solid var(--border-subtle);border-radius:var(--radius-full);background:var(--surface-container-lowest);color:var(--on-surface);font-size:var(--text-label-sm);font-weight:500;min-height:auto;cursor:pointer}.portal-tema-chip:hover{color:var(--on-surface);border-color:var(--secondary);background:var(--status-info-bg)}.portal-tema-chip-swatch{width:18px;height:18px;border-radius:50%;border:1px solid rgba(0,0,0,.1);flex-shrink:0}.portal-editor-root{width:100%;max-width:none;box-sizing:border-box;flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.main.layout-fluid.editor-fill>.portal-editor-root,.main.layout-fluid.editor-fill>.campanha-editor-root,.main.layout-fluid>.page.page-fluid{width:100%;max-width:none}.portal-editor-root .portal-editor-topbar{flex-shrink:0}.portal-editor-root .portal-editor-body{flex:1;min-height:0;overflow:hidden}@media (min-width: 900px){.portal-editor-root .portal-editor-body{min-height:0;max-height:none}.portal-editor-root .portal-editor-canvas-area,.portal-editor-root .portal-editor-sidebar{max-height:100%}}.portal-editor-topbar{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--border-subtle)}.portal-editor-topbar-left{display:flex;align-items:flex-start;gap:.75rem;flex:1;min-width:200px}.portal-editor-topbar-right{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.portal-editor-title-row{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem}.portal-editor-title-row h1{margin:0;font-size:var(--text-headline-md)}.portal-editor-sub{margin:.25rem 0 0;font-size:var(--text-label-sm)}.portal-editor-sub code{font-family:var(--font-mono)}.portal-editor-body{display:grid;grid-template-columns:minmax(0,1fr);gap:1rem;width:100%;align-items:stretch}@media (min-width: 900px){.portal-editor-body{grid-template-columns:60% 40%;gap:1rem;min-height:0;height:100%}}.portal-editor-canvas-area{grid-column:1;width:100%;min-width:0;display:flex;flex-direction:column;min-height:0}@media (min-width: 900px){.portal-editor-canvas-area:not(.portal-editor-canvas-area--preview){grid-column:1;max-height:calc(100vh - 8.5rem)}.portal-editor-root .portal-editor-canvas-area--preview{grid-column:1;flex:1;min-height:0;max-height:calc(100vh - 8.5rem);overflow:hidden}}.portal-editor-preview-label{margin:0 0 .5rem;font-size:var(--text-label-sm);font-weight:600;color:var(--on-surface-variant);flex-shrink:0}.portal-editor-canvas-scroll{flex:1;min-height:0;overflow-x:hidden;overflow-y:auto;border-radius:var(--radius-xl);border:1px solid var(--border-subtle);background:var(--surface-container-low);box-shadow:var(--shadow-sm)}.portal-editor-root .portal-editor-canvas-scroll--preview{flex:1;min-height:0;max-height:100%;overflow:hidden;border:none;background:transparent;box-shadow:none}.portal-editor-root .portal-editor-canvas-area--preview{flex:1;min-height:0;display:flex;flex-direction:column}.portal-editor-root .portal-editor-canvas-area--preview .preview-viewport{flex:1;min-height:0;width:100%;display:flex;flex-direction:column}.portal-editor-preview-colors{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem;padding:.35rem .5rem;background:var(--surface-container-lowest, #fff);border-radius:var(--radius-md, 8px);border:1px solid var(--border-subtle, #e2e8f0)}.portal-editor-preview-colors .portal-editor-colorbar{position:static;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;padding:0;border-radius:0}.portal-editor-canvas-wrap{position:relative;width:100%;min-height:min-content;overflow:visible;padding-top:.25rem}.portal-editor-colorbar{position:absolute;top:10px;right:10px;left:auto;z-index:20;display:flex;flex-wrap:wrap;gap:.5rem;padding:.5rem .75rem;background:#0000008c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-full);pointer-events:auto}.portal-editor-canvas-wrap .portal-canvas{padding-top:3.25rem}.portal-editor-sidebar{grid-column:1;width:100%;min-width:0;display:flex;flex-direction:column;background:var(--surface-container-lowest);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);overflow:hidden;min-height:420px}@media (min-width: 900px){.portal-editor-sidebar{grid-column:2;grid-row:1;min-height:0;max-height:calc(100vh - 8.5rem)}.main.layout-fluid.editor-fill .portal-editor-sidebar{max-height:100%;height:100%}}.portal-editor-tabs{display:flex;flex-direction:column;gap:.4rem;padding:.65rem .75rem;border-bottom:1px solid var(--border-subtle);background:var(--surface-container-low);flex-shrink:0}.portal-editor-tabs-row{display:flex;flex-wrap:wrap;gap:.35rem;align-items:flex-start}.portal-editor-tab{flex:0 0 auto;display:inline-flex;flex-direction:column;align-items:flex-start;gap:.05rem;padding:.4rem .6rem;border:1px solid transparent;border-radius:var(--radius-md);background:transparent;color:var(--on-surface-variant);font-size:var(--text-label-sm);cursor:pointer;text-align:left;transition:background .15s,border-color .15s,color .15s;min-width:4.5rem}.portal-editor-tab:hover{background:var(--surface-container-lowest);color:var(--on-surface)}.portal-editor-tab--active{background:var(--surface-container-lowest);border-color:var(--primary);color:var(--primary);font-weight:600;box-shadow:var(--shadow-sm)}.portal-editor-tab-label{font-weight:inherit;line-height:1.2}.portal-editor-tab-short{font-size:.65rem;opacity:.75;font-weight:400;line-height:1.2;white-space:nowrap}.portal-editor-tab-badge{font-size:.6rem;padding:.1rem .35rem;border-radius:var(--radius-sm);background:var(--status-warn-container, #fef3c7);color:var(--status-warn, #b45309);font-weight:600;margin-top:.15rem}.portal-editor-tab-content{flex:1;min-width:0;min-height:280px;overflow-y:auto;padding:1.1rem 1.25rem 1.5rem}.portal-editor-hint-box--warn{border-color:var(--status-warn, #f59e0b);background:color-mix(in srgb,var(--status-warn, #f59e0b) 8%,var(--surface-container-low))}.portal-editor-section{display:flex;flex-direction:column;gap:.85rem}.portal-editor-section-title{margin:0;font-size:var(--text-title-sm);font-weight:600;color:var(--on-surface)}.portal-editor-section-lead{margin:-.35rem 0 0;font-size:var(--text-body-md);color:var(--on-surface-variant);line-height:1.45}.portal-editor-section-head{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}.portal-editor-hint-box{padding:.65rem .75rem;background:var(--surface-container-low);border-radius:var(--radius-md);border:1px solid var(--border-subtle);margin:0}.portal-editor-color-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.portal-editor-color-grid .color-dot-btn{flex-direction:column;align-items:center;gap:.35rem;width:100%;padding:.5rem;background:var(--surface-container-low);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--on-surface);font-size:.7rem}.portal-editor-color-grid .color-picker-pop{right:auto;left:0}.portal-editor-sidebar .portal-editor-color-grid{grid-template-columns:repeat(2,1fr)}.portal-editor-fields-list{display:flex;flex-direction:column;gap:.65rem}.portal-editor-field-card{padding:0;background:var(--surface-container-lowest);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);display:flex;flex-direction:column;overflow:hidden}.portal-editor-field-card-head{display:flex;align-items:center;gap:.5rem;padding:.5rem .65rem;background:var(--surface-container-low);border-bottom:1px solid var(--border-subtle)}.portal-editor-field-card-order{display:flex;flex-direction:column;gap:.15rem;flex-shrink:0}.portal-editor-field-card-order button{width:1.65rem;height:1.35rem;padding:0;line-height:1;font-size:.7rem}.portal-editor-field-card-index{flex-shrink:0;min-width:1.5rem;height:1.5rem;display:inline-flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:var(--on-surface-variant);background:var(--surface-container-lowest);border:1px solid var(--border-subtle);border-radius:var(--radius-sm)}.portal-editor-field-card-title{flex:1;min-width:0;font-size:var(--text-label-sm);font-weight:600;color:var(--on-surface);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.portal-editor-field-card-type{flex-shrink:0;font-size:.65rem;font-weight:600;padding:.15rem .45rem;border-radius:var(--radius-full);background:var(--surface-container-high, #e8edf4);color:var(--on-surface-variant)}.portal-editor-field-card-body{padding:.65rem;display:flex;flex-direction:column;gap:.55rem}.portal-editor-field-card-row{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.portal-editor-field-card-actions{display:flex;align-items:center;justify-content:space-between;gap:.5rem;flex-wrap:wrap;padding:.5rem .65rem;border-top:1px solid var(--border-subtle);background:var(--surface-container-low)}.portal-editor-field-remove{color:var(--status-error)}.portal-editor-fields-empty{padding:1.25rem;text-align:center;font-size:var(--text-body-md);color:var(--on-surface-variant);border:1px dashed var(--border-subtle);border-radius:var(--radius-lg);background:var(--surface-container-low)}.portal-editor-check{display:flex;align-items:center;gap:.5rem;font-size:var(--text-body-md);cursor:pointer}.portal-editor-disabled-block{opacity:.45;pointer-events:none}.portal-editor-mono{font-family:var(--font-mono);font-size:.85rem}.portal-editor-preview{margin:0;padding:.75rem;background:var(--surface-container-low);border:1px solid var(--border-subtle);border-radius:var(--radius-md);font-size:.8rem;white-space:pre-wrap;max-height:200px;overflow-y:auto}.portal-editor-panel{background:var(--surface-container-lowest);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden}.portal-editor-panel summary{padding:.75rem 1rem;font-weight:600;cursor:pointer;list-style:none;background:var(--surface-container-low)}.portal-editor-panel summary::-webkit-details-marker{display:none}.portal-editor-panel-body{padding:1rem;display:flex;flex-direction:column;gap:.75rem}.portal-editor-canvas-wrap .portal-canvas{width:100%!important;min-width:0;min-height:auto;max-height:none;display:flex!important;align-items:flex-start;justify-content:center;padding:.5rem .75rem 1.25rem;box-sizing:border-box}.portal-editor-canvas-wrap .portal-canvas-inner{width:100%;max-width:100%;margin:0 auto}.portal-canvas-card-ethereal{width:100%;background:var(--surface-container-lowest);color:var(--on-surface);border-radius:var(--radius-xl);padding:1.5rem;box-shadow:var(--shadow-modal);border:1px solid var(--border-subtle)}.portal-canvas-header{text-align:center;margin-bottom:1.25rem}.portal-canvas-logo{max-height:56px;margin:0 auto 1rem;display:block}.portal-canvas-logo-placeholder{width:56px;height:56px;margin:0 auto 1rem;border-radius:50%;background:var(--surface-container-low);border:1px dashed var(--border-subtle);display:flex;align-items:center;justify-content:center;font-size:1.5rem;cursor:pointer}.portal-canvas-title{font-size:var(--text-headline-md);font-weight:600;color:var(--primary);margin:0 0 .35rem}.portal-canvas-subtitle{font-size:var(--text-body-md);margin:0;color:var(--on-surface-variant)}.portal-canvas-field label{display:block;font-size:var(--text-label-sm);font-weight:600;text-transform:uppercase;margin-bottom:.25rem;color:var(--on-surface-variant)}.portal-canvas-field .fake-input{display:flex;align-items:center;gap:.5rem;padding:.75rem;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);background:var(--surface-container-low);color:var(--on-surface-variant);margin-bottom:.75rem}.portal-canvas-lgpd-check{display:flex;gap:.5rem;align-items:flex-start;font-size:var(--text-body-md);color:var(--on-surface-variant);margin:.75rem 0;padding:.75rem;background:var(--surface-container-low);border-radius:var(--radius-lg);border:1px solid var(--border-subtle)}.portal-canvas-check-box{width:16px;height:16px;border:2px solid var(--surface-container-highest);border-radius:var(--radius-sm);flex-shrink:0;margin-top:2px}.portal-canvas-btn{width:100%;padding:.875rem;border:none;border-radius:.75rem;color:#fff;font-weight:600;font-size:1rem;cursor:pointer;margin-top:.5rem}.portal-canvas-footer{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-subtle);font-size:var(--text-body-md);color:var(--on-surface-variant);text-align:center;line-height:1.5}.portal-canvas-link-box{margin-top:1rem;padding:.75rem;background:var(--surface-container-low);border-radius:var(--radius-lg);text-align:center;font-size:var(--text-body-md);color:var(--on-surface-variant)}.editable-hit{cursor:pointer;border-radius:4px;position:relative}.editable-hit:hover{outline:2px dashed #3b82f6;outline-offset:3px}.editable-hit .edit-hint{position:absolute;top:-1.25rem;left:0;font-size:.625rem;background:#3b82f6;color:#fff;padding:2px 6px;border-radius:4px;opacity:0;pointer-events:none;white-space:nowrap}.editable-hit:hover .edit-hint{opacity:1}.editable-inline-input{width:100%;background:#fff3;border:2px solid #3b82f6;border-radius:4px;color:inherit;font:inherit;padding:.25rem .5rem;outline:none}.color-dot-btn{display:flex;align-items:center;gap:.35rem;background:transparent;border:none;color:#ffffffe6;font-size:.625rem;cursor:pointer;padding:0}.color-dot-swatch{width:22px;height:22px;border-radius:50%;border:2px solid rgba(255,255,255,.5)}.color-picker-pop{position:absolute;top:100%;right:0;margin-top:.5rem;padding:.75rem;background:var(--surface-container-lowest);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-modal);z-index:30}.campo-row-editor{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;padding:.5rem;background:var(--surface-container-low);border-radius:var(--radius-md);font-size:var(--text-label-sm)}.campaign-screen{position:relative;display:flex;flex-direction:column;width:100%;height:100%;min-height:100%;background:#000;color:#fff;--campaign-bar: #0f172a;--campaign-btn: #006591;overflow:hidden;box-sizing:border-box}.campaign-media-wrap{flex:1 1 0;min-height:0;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;background:#000}.campaign-media{width:100%;height:100%;max-width:100%;max-height:100%;display:block}.campaign-dots{position:absolute;bottom:.65rem;left:0;right:0;display:flex;justify-content:center;gap:.35rem;z-index:2;pointer-events:none}.campaign-dots--clickable .campaign-dot{border:none;padding:0;cursor:pointer;pointer-events:auto}.campaign-dot{width:7px;height:7px;border-radius:50%;background:#fff6}.campaign-dot.active{background:#fff;transform:scale(1.2)}.campaign-wait-overlay{position:absolute;top:max(.75rem,env(safe-area-inset-top,0px));right:max(.75rem,env(safe-area-inset-right,0px));z-index:12;display:flex;flex-direction:column;align-items:flex-end;gap:.3rem;min-width:6.5rem;padding:.4rem .6rem;background:#0000006b;border:1px solid rgba(255,255,255,.18);border-radius:var(--radius-md, .375rem);font-size:.72rem;line-height:1.3;color:#ffffffeb;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);box-sizing:border-box;pointer-events:auto;transition:opacity .2s ease,visibility .2s ease}.campaign-wait-overlay--hidden{visibility:hidden;opacity:0;pointer-events:none}.campaign-wait-overlay-text{font-weight:500;letter-spacing:.01em;white-space:nowrap}.campaign-wait-overlay-skip{margin:0;padding:0;border:none;background:none;color:#ffffffd9;font:inherit;font-size:.68rem;text-decoration:underline;cursor:pointer;-webkit-tap-highlight-color:transparent}.campaign-wait-overlay-skip:hover{color:#fff}.campaign-skip--static{position:absolute;top:max(.75rem,env(safe-area-inset-top,0px));right:max(.75rem,env(safe-area-inset-right,0px));z-index:12;padding:.4rem .6rem;background:#0000006b;border:1px solid rgba(255,255,255,.18);border-radius:var(--radius-md, .375rem);font-size:.72rem;color:#ffffffbf;pointer-events:none}.campaign-footer-bar{flex:0 0 auto;position:relative;z-index:10;width:100%;min-height:5.75rem;padding:2.1rem 1rem calc(.75rem + env(safe-area-inset-bottom,0px));padding-left:max(1rem,env(safe-area-inset-left,0px));padding-right:max(1rem,env(safe-area-inset-right,0px));background:var(--campaign-bar);box-sizing:border-box;flex-shrink:0}.campaign-btn-float{position:absolute;left:1rem;right:1rem;top:0;transform:translateY(-50%);z-index:11;max-width:28rem;margin:0 auto}.campaign-footer-inner{display:flex;flex-direction:column;align-items:stretch;gap:.35rem;padding-top:.35rem;max-width:28rem;margin:0 auto;width:100%}.campaign-btn{width:100%;border:none;border-radius:var(--radius-md, .375rem);cursor:pointer;line-height:1.25;font-family:inherit;-webkit-tap-highlight-color:transparent}.campaign-btn:disabled{opacity:.55;cursor:not-allowed}.campaign-btn--primary{padding:.85rem 1rem;font-size:1rem;font-weight:700;background:var(--campaign-btn);color:#fff;box-shadow:0 6px 20px #0006;min-height:2.75rem}.campaign-btn--secondary{background:transparent;color:#fffffff2;font-weight:500;font-size:.85rem;padding:.5rem .25rem;text-decoration:underline;min-height:2.25rem}.campaign-wait-hint{margin:0;text-align:center;font-size:.72rem;color:#ffffffbf}@media (max-width: 380px){.campaign-footer-bar{padding-left:.75rem;padding-right:.75rem}.campaign-btn-float{left:.75rem;right:.75rem}.campaign-btn--primary{font-size:.95rem;padding:.75rem .85rem}}.layout--shell .main.layout-fluid.editor-fill{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;padding-bottom:0}.campanha-editor-root{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;width:100%;box-sizing:border-box}.campanha-editor-topbar.portal-editor-topbar{flex-shrink:0;align-items:center}.campanha-editor-topbar .portal-editor-topbar-left{align-items:center}.campanha-editor-topbar .portal-editor-topbar-right{align-items:center;flex-shrink:0}.portal-editor-campanha-title{margin:0;font-size:var(--text-headline-md);font-weight:600;line-height:1.2}.portal-editor-topbar-msg{max-width:14rem;text-align:right}.campanha-editor-root .portal-editor-body{flex:1 1 auto;min-height:0;overflow:hidden;height:calc(100vh - 8.25rem);max-height:calc(100vh - 8.25rem)}@media (min-width: 900px){.campanha-editor-root .portal-editor-body{grid-template-columns:minmax(0,58%) minmax(0,42%);gap:1rem;align-items:stretch}}.campanha-editor-root .portal-editor-sidebar.campanha-editor-sidebar{min-height:0!important;height:100%!important;max-height:100%!important;display:flex;flex-direction:column;overflow:hidden;align-self:stretch}.campanha-editor-panel-scroll{flex:1 1 auto;min-height:0;height:100%;max-height:100%;overflow-x:hidden;overflow-y:scroll;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;touch-action:pan-y;padding:1rem 1.15rem 2.5rem;box-sizing:border-box}.campanha-editor-form-inner{display:block;min-height:min-content}.campanha-editor-form-inner h4{margin:1rem 0 .5rem;font-size:.95rem}.campanha-editor-root .portal-editor-canvas-area--preview{min-height:0;height:100%;max-height:100%;overflow:hidden}.campanha-editor-root .portal-editor-canvas-scroll--preview{flex:1;min-height:0;height:100%;max-height:100%;overflow:hidden;border:none;background:transparent;box-shadow:none}.campanha-editor-root .portal-editor-canvas-area--preview .preview-viewport{flex:1;min-height:0}.campanha-preview-empty{display:flex;align-items:center;justify-content:center;width:100%;height:100%;min-height:280px;padding:2rem;text-align:center;color:#ffffffb3;font-size:var(--text-body-md);box-sizing:border-box}.campanha-preview-toolbar--inline{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin:0;padding:0}.campanha-preview-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.5rem;padding:0 .25rem}.campanha-preview-toolbar label.check-row{font-size:var(--text-label-sm);margin:0}.campanha-slide-focal{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-top:.5rem}.campanha-slide-focal label{font-size:var(--text-label-sm)}.campanha-slide-focal input[type=range]{width:100%}.campanha-slide-card{padding:.85rem 0;margin-bottom:.75rem;border-bottom:1px solid var(--border-subtle)}.campanha-slide-card:last-of-type{border-bottom:none;margin-bottom:0}@media (max-width: 899px){.campanha-editor-root .portal-editor-body{height:auto;max-height:none;overflow:visible;grid-template-columns:1fr}.campanha-editor-root .portal-editor-sidebar.campanha-editor-sidebar{height:auto!important;max-height:min(70vh,560px)!important}.campanha-editor-panel-scroll{max-height:min(70vh,560px)}}.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}
