﻿:root{--bg: #f5f7fb;--panel: #ffffff;--text: #1f2937;--muted: #6b7280;--accent: #1d4ed8;--border: #e5e7eb}.demo-disabled{color:var(--color-muted, #888);font-style:italic;cursor:not-allowed;font-size:.85em;user-select:none}body{margin:0;padding:0;font-family:Arial,sans-serif;background:var(--bg);color:var(--text)}.container{max-width:1100px;margin:0 auto;padding:24px}.header{display:flex;align-items:center;gap:12px;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:16px 20px;margin-bottom:20px}.logo{width:44px;height:44px;border-radius:10px;background:#fff;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;overflow:hidden}.logo img{width:34px;height:34px;object-fit:contain}h1{margin:0;font-size:24px}h2{margin:0 0 12px 0;font-size:20px}.section{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:16px}button{border:1px solid var(--accent);color:var(--accent);background:#fff;border-radius:8px;padding:6px 10px;cursor:pointer}pre{margin-top:10px;padding:10px;background:#0f172a;color:#e2e8f0;border-radius:8px;overflow-x:auto;display:none;white-space:pre-wrap}.ports-list{list-style:none;padding-left:0}.back-link{display:inline-flex;align-items:center;gap:6px;color:var(--accent);text-decoration:none;font-size:14px;margin-bottom:16px}.back-link:hover{text-decoration:underline}.anchor-target{scroll-margin-top:20px}details.section summary{cursor:pointer;user-select:none;display:flex;align-items:center;justify-content:space-between;list-style:none}details.section summary::-webkit-details-marker{display:none}details.section summary h2{display:inline;margin:0}details.section summary::after{content:"";font-family:"Font Awesome 6 Free";font-weight:900;font-size:.75rem;color:var(--text-muted, #888);transition:transform .2s ease;flex-shrink:0}details.section[open]>summary::after{transform:rotate(180deg)}details.section .section-body{margin-top:12px}.section--update-available{background:#fff7ed;border-color:#ea580c;border-left:4px solid #ea580c}.btn-download{display:inline-flex;align-items:center;gap:8px;background:#ea580c;color:#fff;border:none;border-radius:8px;padding:8px 16px;font-size:14px;font-weight:600;text-decoration:none;cursor:pointer;margin-bottom:12px}.btn-download:hover{background:#c2410c;color:#fff}.meta{margin:6px 0 0 0;color:var(--muted);font-size:14px}.params{margin:10px 0;padding-left:18px}.app-layout{display:flex;min-height:100vh}.sidebar{width:180px;min-width:180px;background:#1e293b;color:#cbd5e1;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto;flex-shrink:0}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:18px 16px 14px;flex-shrink:0;text-decoration:none}.sidebar-brand img{width:30px;height:30px;border-radius:6px;padding:2px;object-fit:contain}.sidebar-brand span{font-size:15px;font-weight:700;color:#f1f5f9;letter-spacing:.02em}.appfooter-esfom-logo{display:block;height:14px;width:auto;filter:brightness(0);opacity:.4;flex-shrink:0}.sidebar-nav{padding:8px 0;flex:1}.nav-group{margin-bottom:4px}.nav-group-label{display:flex;align-items:center;justify-content:space-between;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#475569;padding:10px 16px 4px;cursor:pointer;user-select:none}.nav-group-label:hover{color:#94a3b8}.nav-group-chevron{font-size:9px;transition:transform .2s ease;opacity:.6}.nav-group--collapsed .nav-group-chevron{transform:rotate(-90deg)}.nav-group--collapsed .nav-list{display:none}.nav-list{list-style:none;margin:0;padding:0}.nav-link{display:flex;align-items:center;gap:8px;padding:7px 16px;font-size:13px;color:#94a3b8;text-decoration:none;transition:background .12s,color .12s}.nav-link:hover{background:hsla(0,0%,100%,.07);color:#f1f5f9}.nav-link.active{background:rgba(29,78,216,.25);color:#93c5fd}.nav-link.nav-link-error{color:#fca5a5 !important}.nav-link.nav-link-error i{color:#ef4444 !important}.nav-link i{width:14px;text-align:center;font-size:12px;flex-shrink:0}.main-wrapper{flex:1;display:flex;flex-direction:column;min-width:0;min-height:100vh}.demo-banner{background:#ea580c;color:#fff;text-align:center;padding:7px 16px;font-size:13px;font-weight:600;flex-shrink:0;letter-spacing:.01em}.demo-banner i{margin-right:6px}.topbar{background:var(--panel);border-bottom:1px solid var(--border);padding:12px 24px;flex-shrink:0;display:flex;align-items:center;gap:16px}.topbar .topbar-titles{flex:1}.topbar h1{margin:0;font-size:20px}.topbar .meta{margin:3px 0 0;font-size:13px}.topbar-auth{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--muted);white-space:nowrap}.topbar-auth .topbar-username{font-weight:600;color:var(--text)}.topbar-auth .topbar-logout-btn{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border:1px solid var(--border);border-radius:6px;background:rgba(0,0,0,0);color:var(--muted);font-size:12px;cursor:pointer;transition:all .12s}.topbar-auth .topbar-logout-btn:hover{border-color:#ef4444;color:#ef4444}.lang-switcher{display:flex;align-items:center;gap:2px;border:1px solid var(--border);border-radius:6px;padding:2px;flex-shrink:0}.lang-btn{padding:2px 7px;border:none;border-radius:4px;background:rgba(0,0,0,0);color:var(--muted);font-size:11px;font-weight:600;letter-spacing:.5px;cursor:pointer;transition:background .12s,color .12s}.lang-btn:hover{color:var(--text)}.lang-btn.lang-btn--active{background:var(--accent, #3b82f6);color:#fff}.main-content{flex:1;padding:20px 24px}.app-footer{background:var(--panel);border-top:1px solid var(--border);padding:8px 24px;font-size:12px;color:var(--muted);flex-shrink:0;display:flex;align-items:center;gap:8px}table{width:100%;border-collapse:collapse}.topology-links{margin:0;padding-left:16px}.topology-links a{color:var(--accent);text-decoration:none}.topology-links a:hover{text-decoration:underline}th,td{border-bottom:1px solid var(--border);text-align:left;padding:10px;vertical-align:top}th{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em}th.sortable{cursor:pointer;user-select:none;white-space:nowrap}th.sortable:hover{color:var(--text)}th.sort-active{color:var(--accent)}.sort-icon{font-style:normal;font-size:10px}.cfg-input{width:100%;box-sizing:border-box;padding:7px 10px;border:1px solid var(--border);border-radius:6px;font-size:14px;font-family:inherit;background:#fff;color:var(--text);transition:border-color .12s,box-shadow .12s}.cfg-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px rgba(29,78,216,.08)}.cfg-field{margin-bottom:10px}.cfg-field label{display:block;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}.cfg-field-check{display:flex;flex-direction:column;justify-content:flex-end}.cfg-field-check input[type=checkbox]{width:18px;height:18px;margin:6px 0 0;cursor:pointer;accent-color:var(--accent)}.cfg-row2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.cfg-section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:12px;padding-bottom:6px;border-bottom:1px solid var(--border)}.sidebar-tier-badge{display:block;margin:0 12px 10px;padding:3px 8px;border-radius:4px;font-size:10px;font-weight:700;letter-spacing:.06em;text-align:center;text-decoration:none;background:hsla(0,0%,100%,.08);color:#94a3b8;border:1px solid hsla(0,0%,100%,.12);transition:background .12s,color .12s}.sidebar-tier-badge:hover{background:hsla(0,0%,100%,.14);color:#f1f5f9}.sidebar-tier-badge-free{background:rgba(99,102,241,.15);color:#a5b4fc;border-color:rgba(99,102,241,.3)}.sidebar-tier-badge-pro{background:rgba(22,163,74,.15);color:#4ade80;border-color:rgba(22,163,74,.3)}.sidebar-tier-badge-enterprise{background:rgba(147,51,234,.15);color:#c084fc;border-color:rgba(147,51,234,.3)}.sidebar-tier-badge-error{background:rgba(220,38,38,.2) !important;color:#fca5a5 !important;border-color:rgba(220,38,38,.4) !important}.nav-pro-plus-badge{margin-left:auto;font-size:9px;font-weight:700;letter-spacing:.06em;padding:1px 5px;border-radius:3px;background:rgba(234,179,8,.18);color:#fbbf24;border:1px solid rgba(234,179,8,.3);flex-shrink:0}.nav-pro-badge{margin-left:auto;font-size:9px;font-weight:700;letter-spacing:.06em;padding:1px 5px;border-radius:3px;background:rgba(22,163,74,.18);color:#4ade80;border:1px solid rgba(22,163,74,.3);flex-shrink:0}.endpoint-list{display:flex;flex-direction:column;gap:4px;min-width:0}.endpoint-row{display:flex;align-items:center;gap:8px;min-width:0}.endpoint-param{flex-shrink:0;font-size:11px;font-weight:700;font-family:monospace;color:var(--accent);background:#eff6ff;border:1px solid #bfdbfe;border-radius:4px;padding:2px 7px;white-space:nowrap}.endpoint-param-multi{color:#16a34a;background:#f0fdf4;border-color:#86efac}.endpoint-param-cmd{color:#4f46e5;background:#eef2ff;border-color:#c7d2fe}.endpoint-url{flex:1;font-size:12px;font-family:monospace;color:var(--muted);text-decoration:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.endpoint-url:hover{color:var(--accent);text-decoration:underline}.endpoint-copy-btn{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:1px solid var(--border);border-radius:5px;background:rgba(0,0,0,0);color:var(--muted);cursor:pointer;font-size:11px;transition:background .12s,color .12s}.endpoint-copy-btn:hover{background:var(--bg);color:var(--text)}.cfg-load-label{font-size:14px;font-weight:600}.cfg-driver-select{width:auto;min-width:240px}.cfg-btn-muted{border-color:var(--muted);color:var(--muted)}.cfg-btn-muted:hover{background:#f9fafb}.cfg-json-preview{max-height:75vh;overflow-y:auto;margin:0;font-size:12px;line-height:1.5}.cfg-row3-end{align-items:end}.cfg-load-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.cfg-layout{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}.cfg-preview-panel{position:sticky;top:20px}.cfg-row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.cmd-block{border:1px solid var(--border);border-radius:8px;padding:14px;margin-bottom:12px;background:#f9fafb}.cmd-block-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.cmd-block-label{font-size:13px;font-weight:700;color:var(--text)}.cmd-remove-btn{border-color:#ef4444;color:#ef4444;font-size:12px;padding:4px 8px}.cmd-remove-btn:hover{background:#fef2f2}.cmd-subsection{border-top:1px solid var(--border);margin-top:12px;padding-top:10px}.cmd-subsection-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:10px}.cfg-default-hint{font-size:10px;font-weight:400;color:var(--muted);text-transform:none;letter-spacing:0;font-family:monospace}.cfg-preview-actions{display:flex;gap:6px;margin-bottom:10px;flex-wrap:wrap;align-items:center}.vas-btn{border-color:#16a34a;color:#16a34a}.vas-toast{display:none;margin-bottom:8px;padding:6px 10px;border-radius:5px;font-size:12px}.vas-toast.visible{display:block}#json-preview{display:block}.vas-toast-ok{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0}.vas-toast-error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.license-text-meta{margin-bottom:16px}.license-section-heading{margin-top:20px;margin-bottom:8px;font-size:15px}.license-text-list{padding-left:20px;line-height:1.8}.license-limit-alert{display:flex;align-items:center;gap:10px;margin-top:10px;padding:10px 14px;background:#fffbeb;border:1px solid #fde68a;border-radius:8px;font-size:13px;color:#92400e}.license-limit-alert i{flex-shrink:0;font-size:14px;color:#d97706}.license-limit-alert span{flex:1}.license-limit-alert a{flex-shrink:0;font-weight:700;color:#92400e;text-decoration:underline;white-space:nowrap}.license-limit-alert a:hover{color:#78350f}.hwui-box{display:flex;align-items:center;gap:10px;background:#f1f5f9;border:1px solid var(--border);border-radius:8px;padding:12px 16px;width:fit-content}.hwui-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);white-space:nowrap}.hwui-value{font-family:monospace;font-size:15px;font-weight:600;letter-spacing:.08em;color:var(--accent);user-select:all}.hwui-copy-btn{background:none;border:1px solid var(--border);border-radius:6px;padding:4px 8px;cursor:pointer;color:var(--muted);font-size:13px;line-height:1}.hwui-copy-btn:hover{background:var(--border);color:var(--text)}.license-upgrade-btn{display:inline-flex;align-items:center;gap:7px;margin-top:14px;padding:8px 16px;background:#2563eb;color:#fff;border-radius:8px;font-size:13px;font-weight:600;text-decoration:none;transition:background .15s}.license-upgrade-btn i{font-size:12px}.license-upgrade-btn:hover{background:#1d4ed8;color:#fff;text-decoration:none}.license-hwui-meta{max-width:560px}.license-section-cols{display:grid;grid-template-columns:1fr auto;gap:20px;align-items:start}.license-section-main{min-width:0}.license-activate-wrap{margin-top:16px}.license-tier-panel{width:350px;flex-shrink:0;border-radius:10px;padding:16px;text-align:center;border:1px solid var(--border)}.license-tier-panel-free{background:rgba(99,102,241,.06);border-color:rgba(99,102,241,.2)}.license-tier-panel-paid{background:rgba(22,163,74,.07);border-color:rgba(22,163,74,.3)}.license-tier-panel-error{background:rgba(220,38,38,.08) !important;border-color:rgba(220,38,38,.4) !important}.license-mismatch-alert{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:12px;padding:8px 12px;background:#fee2e2;border:1px solid #fecaca;border-radius:6px;font-size:13px;font-weight:700;color:#991b1b;text-align:center}.license-mismatch-alert i{flex-shrink:0;font-size:15px}.license-tier-badge{font-size:18px;font-weight:800;letter-spacing:.08em;color:var(--text);margin-bottom:8px}.license-tier-details{font-size:12px;color:var(--muted);line-height:1.6}.license-tier-detail-row{display:flex;justify-content:space-between;gap:8px;padding:3px 0;border-bottom:1px solid rgba(0,0,0,.05)}.license-tier-detail-row span{font-weight:600;color:var(--muted);white-space:nowrap}.license-subsection-title{font-size:14px;font-weight:700;margin:0 0 10px;color:var(--text)}.license-token-input-wrap{position:relative;flex:1}.license-token-input{padding-right:36px}.license-eye-btn{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:none;border:none;padding:4px 6px;cursor:pointer;color:var(--muted);font-size:13px;line-height:1}.license-eye-btn:hover{color:var(--text)}.license-activate-row{display:flex;gap:8px;align-items:center;max-width:600px}.license-result{margin-top:12px;padding:10px 14px;border-radius:8px;font-size:13px;max-width:600px}.license-result-free{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.license-result-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.mirror-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.mirror-section-header h2{margin:0}.mirror-form-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.mirror-form-header h2{margin:0}.mirror-form-header-btns{display:flex;gap:10px}.mirror-id-row{display:grid;grid-template-columns:1fr 1fr 64px;gap:16px;margin-top:16px;align-items:end}.mirror-id-row .cfg-field{margin:0}.cfg-field-mt{margin-top:16px}.mirror-favicon-box{height:38px;display:flex;align-items:center;justify-content:center;background:var(--bg);border:1px solid var(--border);border-radius:8px;overflow:hidden}.mirror-commands-field{flex:1;display:flex;flex-direction:column}.mirror-commands-hint{margin-bottom:10px;line-height:1.6}.mirror-load-error{color:#f87171}.mirror-url-input-row{display:flex;gap:8px}.label-sub{font-weight:400;text-transform:none}.mirror-grid{display:flex;flex-direction:column;gap:12px}.mirror-card{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:14px 16px;display:flex;flex-direction:column;transition:border-color .15s,box-shadow .15s}.mirror-card:hover{border-color:var(--muted);box-shadow:0 2px 8px rgba(0,0,0,.04)}.mirror-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.mirror-card-title{display:flex;flex-direction:column;gap:2px}.mirror-card-id{font-weight:700;font-size:14px;color:var(--text);font-family:monospace;background:var(--bg);padding:4px 8px;border-radius:6px;width:fit-content;display:inline-flex;align-items:center;gap:8px}.mirror-favicon{width:18px;height:18px;border-radius:4px;object-fit:contain}.mirror-favicon-placeholder{width:18px;height:18px;border-radius:4px;background:var(--border);color:var(--muted);display:flex;align-items:center;justify-content:center;font-size:10px}.mirror-card-name{font-size:15px;font-weight:600;color:var(--text);margin-top:4px}.mirror-card-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.mirror-card-meta{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;font-size:12px}.mirror-url-label{color:var(--muted);word-break:break-all;flex:1 1 100%;margin-bottom:4px}.mirror-url-label code{background:var(--bg);padding:1px 4px;border-radius:3px;color:var(--text);font-weight:600}.mirror-card-desc{font-size:13px;color:var(--muted);margin:0 0 12px;line-height:1.5}.mirror-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:6px;font-size:11px;font-weight:600}.mirror-badge-auth{background:#fef3c7;color:#92400e;border:1px solid #fde68a}.mirror-badge-open{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.mirror-badge-poll{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.mirror-status{font-size:10px;font-weight:800;padding:2px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:.05em}.mirror-status-on{background:#dcfce7;color:#166534}.mirror-status-off{background:#fee2e2;color:#991b1b}.mirror-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:1px solid var(--border);border-radius:8px;background:var(--panel);color:var(--muted);cursor:pointer;font-size:14px;transition:all .12s}.mirror-icon-btn:hover{background:var(--bg);color:var(--text);border-color:var(--muted)}.mirror-icon-btn-danger:hover{background:#fee2e2;color:#dc2626;border-color:#fca5a5}.mirror-btn-small{padding:0 12px;height:38px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);cursor:pointer;transition:all .15s}.mirror-btn-small:hover:not(:disabled){background:var(--border);border-color:var(--muted)}.mirror-btn-small:disabled{opacity:.5;cursor:not-allowed}.mirror-textarea{resize:vertical;font-family:inherit}.mirror-textarea-code{font-family:monospace;font-size:12px}.mirror-form-error{margin-top:10px;padding:12px 16px;background:#fee2e2;color:#991b1b;border:1px solid #fca5a5;border-radius:8px;font-size:14px;font-weight:500}.mirror-btn-cancel{background:rgba(0,0,0,0);border:1px solid var(--border);color:var(--muted)}.mirror-btn-cancel:hover{background:var(--bg);color:var(--text);border-color:var(--muted)}.mirror-form-cols{display:grid;grid-template-columns:2fr 1fr;gap:32px;align-items:start}@media(max-width: 1100px){.mirror-form-cols{grid-template-columns:1fr}.mirror-form-aside{position:static}}.mirror-form-aside{display:flex;flex-direction:column;position:sticky;top:16px}.mirror-commands-ta{flex:1;min-height:500px;resize:vertical}.mirror-form-aside .endpoint-list{border-top:1px solid var(--border);margin-top:auto;padding-top:12px;gap:6px}.endpoint-row{display:flex;align-items:center;gap:10px;font-size:12px}.endpoint-copy-btn{background:rgba(0,0,0,0);border:none;padding:4px;color:var(--muted);cursor:pointer;font-size:13px;line-height:1}.endpoint-copy-btn:hover{color:var(--text)}.endpoint-param{font-family:monospace;font-weight:700;color:var(--text);min-width:80px}.endpoint-url{color:var(--muted);text-decoration:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.endpoint-url:hover{color:var(--text);text-decoration:underline}.endpoint-row-multi{margin-top:4px;padding-top:4px;border-top:1px dashed var(--border)}.endpoint-row-multi .endpoint-param-multi{color:#6366f1;font-style:italic}.monitor-statusbar{display:flex;align-items:center;gap:20px;font-size:13px;color:var(--muted);margin-bottom:18px;flex-wrap:wrap}.mon-badge{padding:2px 10px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.mon-badge-live{background:#dcfce7;color:#16a34a}.mon-badge-connecting{background:#fef9c3;color:#92400e}.monitor-grid{display:grid;grid-template-columns:repeat(4, 1fr);gap:16px;margin-bottom:24px}@media(max-width: 900px){.monitor-grid{grid-template-columns:repeat(2, 1fr)}}.mon-card{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:18px 20px;display:flex;flex-direction:column;gap:4px}.mon-card-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:2px}.mon-card-sub{font-size:12px;color:var(--muted)}.mon-big-metric{font-size:38px;font-weight:800;color:var(--text);line-height:1.1;transition:color .4s ease}.mon-bar-chart{width:100%;height:44px;margin:4px 0 2px}.mon-chart-container{width:100%}.mon-charts-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.mon-chart-section{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:16px 20px}.mon-chart-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:6px}.term-raw-label-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.term-raw-mode-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin:0}.term-raw-port-select{flex:1}.cfg-row2-mt8{margin-top:8px}.cfg-row2-mt4{margin-top:4px}.cfg-field-0{margin:0}.term-btn-connect{flex:1}.term-btn-disconnect{flex:1;border-color:#ef4444;color:#ef4444}.term-btn-disconnect:hover{background:#fef2f2}.term-line-ending-select{font-family:monospace;font-size:13px}.term-repeat-row-inline{margin-bottom:0;flex-shrink:0}.term-cmd-bufsize-field{width:80px;margin:0;flex-shrink:0}.term-cmd-sendmode-field{margin:0;flex:1;min-width:0}.term-checkbox-md{width:15px;height:15px;accent-color:var(--accent)}.term-checkbox-sm{width:13px;height:13px;accent-color:var(--accent)}.term-capture-icon{color:#ef4444}.term-checkbox-mt{margin-top:10px}.term-layout{display:grid;grid-template-columns:2fr 1fr;gap:16px;align-items:stretch;min-height:320px}.term-panel{display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--border);border-radius:12px;overflow:hidden}.term-panel-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-bottom:1px solid var(--border);flex-shrink:0}.term-panel-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.term-output{font-family:"Courier New",Courier,monospace;font-size:13px;line-height:1.65;background:#0f172a;color:#e2e8f0;flex:1;overflow-y:auto;padding:12px 16px}.term-sidebar{display:flex;flex-direction:column;gap:16px;min-width:0;overflow-y:auto}.term-sidebar-section{margin-bottom:0}.term-command-section{flex:1;display:flex;flex-direction:column}.term-device-label-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.term-device-label-row label{margin:0}.term-proto-info{font-size:12px;color:var(--muted);font-family:monospace;margin:4px 0 10px}.term-checkbox-row{display:flex;align-items:center;gap:6px;font-size:14px;cursor:pointer;user-select:none;margin-bottom:10px}.term-conn-btns{display:flex;gap:8px}.term-cmd-options{display:flex;align-items:flex-end;gap:12px;margin-bottom:12px}.term-btn-send{width:100%;padding:.6em 1em;font-size:15px;font-weight:700;line-height:1.6;background:var(--accent);color:#fff;border-color:var(--accent);margin-top:auto;justify-content:center}.term-btn-send:hover{background:#1e40af;border-color:#1e40af}.term-mode-tabs{display:flex;border:1px solid var(--border);border-radius:6px;overflow:hidden;margin-bottom:12px}.term-tab{flex:1;border:none;border-radius:0;padding:5px 0;font-size:12px;font-weight:600;color:var(--muted);background:#fff;cursor:pointer;transition:background .1s,color .1s}.term-tab+.term-tab{border-left:1px solid var(--border)}.term-tab:hover{background:#f1f5f9;color:var(--text)}.term-tab-active{background:#eff6ff;color:var(--accent)}.term-raw-port-row{display:flex;align-items:center;gap:6px}.term-conn-info-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:5px 16px;font-size:12px;background:#0f172a;border-bottom:1px solid #1e293b;flex-shrink:0;flex-wrap:wrap}.term-conn-info-bar .term-pin-label{color:#475569}.term-conn-info-bar .term-pin{font-size:9px;padding:1px 5px}.term-conn-info-bar .term-pin-on{background:#14532d;color:#4ade80}.term-conn-info-bar .term-pin-off{background:#1e293b;color:#475569}.term-cib-left{display:flex;align-items:center;gap:8px}.term-cib-port{font-family:monospace;font-weight:700;font-size:13px;color:#93c5fd}.term-cib-params{font-family:monospace;color:#64748b;font-size:12px}.term-cib-pins{display:flex;align-items:center;gap:4px}.term-cib-div{width:1px;height:12px;background:#334155;margin:0 4px}.term-line{white-space:pre-wrap;word-break:break-all}.term-status{color:#64748b}.term-error{color:#f87171}.term-tx{color:#60a5fa}.term-rx{color:#4ade80}.term-badge{display:inline-block;font-size:12px;font-weight:700;padding:3px 10px;border-radius:20px;font-family:monospace;white-space:nowrap}.term-badge-on{background:#dcfce7;color:#16a34a}.term-badge-off{background:#f1f5f9;color:#94a3b8}.term-header-btns{display:flex;align-items:center;gap:6px}.term-hdr-btn{border:1px solid var(--border);border-radius:6px;padding:4px 8px;font-size:12px;color:var(--muted);background:#fff;cursor:pointer;line-height:1;flex-shrink:0}.term-hdr-btn:hover{background:#f1f5f9;color:var(--text)}.term-hdr-btn-active{background:#eff6ff;color:var(--accent);border-color:#bfdbfe}.term-hdr-btn-recording{background:#fee2e2;color:#dc2626;border-color:#fecaca}.term-search-input{width:120px;padding:4px 8px;border:1px solid var(--border);border-radius:6px;font-size:12px;font-family:inherit;background:#fff;color:var(--text)}.term-search-input:focus{outline:none;border-color:var(--accent)}.term-stats-bar{display:flex;align-items:center;gap:14px;padding:5px 16px;font-size:12px;color:var(--muted);background:#f8fafc;border-bottom:1px solid var(--border);flex-shrink:0}.term-stats-bar b{color:var(--text);font-weight:600}.term-stat-capture{display:flex;align-items:center;gap:4px;font-weight:600;color:#dc2626}.term-pins-row{display:flex;gap:10px;align-items:center;margin:6px 0 12px;flex-wrap:wrap}.term-pins-group{display:flex;align-items:center;gap:4px}.term-pin-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-right:2px}.term-pin{font-size:10px;font-weight:700;font-family:monospace;padding:2px 6px;border-radius:4px;cursor:default;letter-spacing:.03em}.term-pin-on{background:#dcfce7;color:#15803d}.term-pin-off{background:#f1f5f9;color:#94a3b8}.term-btn-group{display:flex;border:1px solid var(--border);border-radius:6px;overflow:hidden}.term-btn-group-item{flex:1;border:none;border-radius:0;padding:5px 0;font-size:12px;font-weight:600;color:var(--muted);background:#fff;cursor:pointer;transition:background .1s,color .1s}.term-btn-group-item+.term-btn-group-item{border-left:1px solid var(--border)}.term-btn-group-item:hover{background:#f1f5f9;color:var(--text)}.term-btn-group-active{background:#eff6ff;color:var(--accent)}.term-repeat-row{display:flex;align-items:center;gap:6px;margin-bottom:10px}.term-repeat-input{width:60px !important;padding:5px 6px !important;font-size:12px !important;text-align:center}.term-repeat-sep{font-size:12px;color:var(--muted);flex-shrink:0}.term-btn-file{width:100%;padding:6px;font-size:13px;margin-bottom:8px;color:var(--muted);border-color:var(--border);background:#f9fafb;border-radius:8px;text-align:center}.term-btn-file:not([disabled]):hover{background:#f1f5f9;color:var(--text)}.term-search-match{background:rgba(251,191,36,.15);border-radius:2px}.term-frame-even{border-left:3px solid #3b82f6;padding-left:6px}.term-frame-odd{border-left:3px solid #8b5cf6;padding-left:6px}.term-frame-partial{border-left:3px solid #f59e0b;padding-left:6px}.topo-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.topo-section-header h2{margin:0}.topo-form-actions{display:flex;gap:8px;margin-top:10px}.topo-form-btn-save{background:var(--accent);color:#fff;border-color:var(--accent)}.topo-form-btn-cancel{border-color:var(--muted);color:var(--muted)}.topo-keep-alive-check{width:16px;height:16px;accent-color:var(--accent)}.endpoint-empty{color:var(--muted);font-size:12px}.topo-form-wrap{margin-bottom:12px}.topo-form-panel{background:#f9fafb;border:1px solid var(--border);border-radius:8px;padding:14px 16px}.topo-form-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:10px}.topo-form-grid{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:10px;align-items:end}.topo-actions{white-space:nowrap}.topo-toggle{display:inline-flex;align-items:center;cursor:pointer;user-select:none}.topo-toggle input{position:absolute;opacity:0;width:0;height:0}.topo-toggle-track{display:inline-block;width:34px;height:18px;background:#cbd5e1;border-radius:9px;position:relative;transition:background .2s}.topo-toggle input:checked~.topo-toggle-track{background:#22c55e}.topo-toggle-thumb{position:absolute;top:2px;left:2px;width:14px;height:14px;background:#fff;border-radius:50%;transition:left .2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}.topo-toggle input:checked~.topo-toggle-track .topo-toggle-thumb{left:18px}.topo-btn-edit,.topo-btn-remove{font-size:13px;padding:4px 7px;line-height:1}.topo-btn-edit{margin-right:3px}.topo-btn-remove{border-color:#ef4444;color:#ef4444}.topo-btn-remove:hover{background:#fef2f2}.topo-table-fixed{table-layout:fixed;width:100%}.topo-table-fixed td,.topo-table-fixed th{overflow:hidden;text-overflow:ellipsis}.topo-conn-section{margin-top:10px;border-top:1px solid var(--border);padding-top:8px}.topo-conn-section-header{display:flex;align-items:center;gap:12px;margin-bottom:6px}.topo-conn-override-label{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text);cursor:pointer;user-select:none}.topo-conn-override-label input[type=checkbox]{width:14px;height:14px;accent-color:var(--accent)}.topo-conn-driver-hint{font-size:11px;color:var(--muted);font-family:monospace}.topo-conn-fields{background:#f8fafc;border:1px solid var(--border);border-radius:6px;padding:10px 12px}.topo-conn-grid{display:grid;grid-template-columns:repeat(4, 1fr);gap:8px;margin-bottom:8px}.topo-conn-grid:last-child{margin-bottom:0}.port-icon-virtual{color:#7c3aed}.port-icon-active{color:#28a745}.port-icon-idle{color:#ccc}.port-real{color:#16a34a;font-weight:600}.port-virtual{color:#7c3aed;font-weight:600}.port-mock{color:#1d4ed8;font-weight:600}.port-tcp{color:#0891b2;font-weight:600}.port-missing{color:#dc2626;font-weight:600}.conn-legend{display:block;margin-top:3px;font-size:10px;font-family:monospace;padding:1px 6px;border-radius:4px;background:var(--bg);border:1px solid var(--border);white-space:nowrap}.conn-legend-serial{color:var(--muted)}.conn-legend-tcp{color:#0891b2;border-color:#bae6fd;background:#f0f9ff}.conn-sep{margin:0 0px;opacity:.5}.topo-ka-cell{display:flex;flex-direction:column;align-items:center;gap:4px}.conn-badge{display:inline-block;padding:1px 7px;border-radius:20px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.conn-badge-CONNECTED{background:#dcfce7;color:#16a34a}.conn-badge-RECONNECTING{background:#fef9c3;color:#92400e}.conn-badge-FAILED{background:#fee2e2;color:#dc2626}.topology-accordion{margin-top:24px;border:1px solid var(--border);border-radius:8px;overflow:hidden}.topology-accordion-header{background:#f1f5f9;padding:10px 16px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;user-select:none;transition:background .1s}.topology-accordion-header:hover{background:#e2e8f0}.topology-accordion-header h3{margin:0;font-size:14px;font-weight:700;color:#475569;display:flex;align-items:center;gap:8px}.topology-accordion-toggle-icon{font-size:12px;color:var(--muted);transition:transform .2s}.topology-accordion.collapsed .topology-accordion-toggle-icon{transform:rotate(-90deg)}.topology-accordion.collapsed .topology-accordion-content{display:none}.topology-accordion-content{padding:0;background:#fff}.topology-accordion-content table{margin:0;border:none;border-radius:0;border-top:1px solid var(--border)}.device-card{border:1px solid var(--border);border-radius:10px;padding:12px;margin-bottom:12px}.device-card[hidden]{display:none}.device-card-body{display:flex;justify-content:space-between;gap:16px}.device-card-main{flex:1}.device-image-wrap{width:180px;min-width:90px;height:180px;border:1px solid var(--border);border-radius:10px;background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden}.device-image{width:100%;height:100%;object-fit:cover}.devices-filter-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:16px;padding:10px 14px;background:var(--section-bg);border:1px solid var(--border);border-radius:8px}.devices-filter-bar label{font-size:12px;font-weight:600;color:var(--muted);white-space:nowrap}.devices-filter-select,.devices-filter-search{font-size:13px;padding:4px 8px;border:1px solid var(--border);border-radius:5px;background:var(--bg);color:var(--text);min-width:150px}.devices-filter-search{min-width:180px}.btn-muted{font-size:12px;padding:4px 10px;border-color:var(--muted);color:var(--muted)}.devices-count{margin-left:auto;font-size:12px;color:var(--muted);white-space:nowrap}.devices-loading{padding:32px;text-align:center;color:var(--muted);font-size:14px}.devices-error{padding:16px;background:rgba(220,53,69,.1);border:1px solid rgba(220,53,69,.3);border-radius:8px;color:var(--danger, #dc3545);font-size:13px;margin-bottom:12px}.device-card-actions{display:flex;align-items:center;gap:8px;margin-top:10px;flex-wrap:wrap}.btn-view-json,.btn-view-installed{font-size:12px;padding:4px 10px}.btn-view-installed{border-color:var(--success, #198754);color:var(--success, #198754)}.btn-install{font-size:12px;padding:4px 10px;background:var(--accent, #0d6efd);color:#fff;border-color:var(--accent, #0d6efd)}.btn-install:disabled{opacity:.65;cursor:not-allowed}.btn-installed{background:var(--success, #198754);border-color:var(--success, #198754);cursor:default}.devices-locked-badge{font-size:12px;color:var(--muted);display:inline-flex;align-items:center;gap:5px}.devices-installed-badge{font-size:12px;color:var(--success, #198754);display:inline-flex;align-items:center;gap:5px}.btn-upgrade{background:var(--warning, #f59e0b);border-color:var(--warning, #f59e0b);color:#000}.badge-valign-middle{vertical-align:middle}.badge{display:inline-block;font-size:11px;font-weight:700;padding:2px 7px;border-radius:4px;letter-spacing:.03em;white-space:nowrap}.badge-req{background:#fee2e2;color:#b91c1c}.badge-opt{background:#f3f4f6;color:#6b7280}.badge-type{background:#eff6ff;color:#1d4ed8;font-weight:400;font-family:monospace;font-size:12px;padding:2px 6px}.ref-table{width:100%;border-collapse:collapse;margin:0 0 8px 0;font-size:14px}.ref-table th{background:#f9fafb;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.04em;padding:8px 10px;border-bottom:2px solid var(--border)}.ref-table td{padding:9px 10px;border-bottom:1px solid var(--border);vertical-align:top}.ref-table tr:last-child td{border-bottom:none}.ref-table .ref-table-group-header{background:#f1f5f9;color:var(--muted);font-size:11px;font-family:inherit;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:6px 10px;border-top:1px solid var(--border)}.ref-table td:first-child{font-family:monospace;font-size:13px;color:#0f172a;font-weight:600}.field-desc{color:var(--text);margin:0}.field-note{color:var(--muted);font-size:12px;margin:3px 0 0 0}.val-list{margin:0;padding:0;list-style:none}.val-list li{margin-bottom:3px}.val-list code{background:#f1f5f9;border-radius:3px;padding:1px 5px;font-size:12px}pre.example{display:block;background:#0f172a;color:#e2e8f0;border-radius:10px;padding:16px 18px;font-size:13px;line-height:1.6;overflow-x:auto;margin:0;white-space:pre}.hl-key{color:#93c5fd}.hl-str{color:#86efac}.hl-num{color:#fde68a}.hl-bool{color:#f9a8d4}.hl-cmt{color:#64748b;font-style:italic}.protocol-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(220px, 1fr));gap:12px;margin-top:4px}.protocol-card{border:1px solid var(--border);border-radius:10px;padding:12px 14px}.protocol-card h4{margin:0 0 6px 0;font-size:14px;font-family:monospace;color:var(--accent)}.protocol-card p{margin:0;font-size:13px;color:var(--muted)}.parser-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(240px, 1fr));gap:12px;margin-top:4px}.parser-card{border:1px solid var(--border);border-radius:10px;padding:12px 14px}.parser-card h4{margin:0 0 4px 0;font-size:13px;font-family:monospace;color:#0f172a}.parser-card p{margin:0;font-size:13px;color:var(--muted)}.parser-card .mini-ex{font-size:12px;font-family:monospace;background:#f1f5f9;border-radius:4px;padding:2px 6px;margin-top:5px;display:inline-block;color:#334155}.ref-section-meta{margin-bottom:12px}.val-list-mt{margin-top:5px}.ref-example-heading{margin-top:20px}.about-info-table{margin-top:16px}.about-info-table td:first-child{width:160px;font-family:monospace;font-weight:600}.legend{display:flex;gap:12px;margin-bottom:14px;font-size:13px;align-items:center}.toc{list-style:none;padding:0;margin:0}.toc li{padding:4px 0}.toc a{color:var(--accent);text-decoration:none;font-size:14px}.toc a:hover{text-decoration:underline}.topo-canvas{position:relative;display:grid;grid-template-columns:1fr 1fr 180px 1fr 1fr 1fr 1fr;align-items:stretch;min-height:520px;padding:40px 8px}.topo-svg{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:visible;z-index:0}.topo-col{display:flex;flex-direction:column;justify-content:center;gap:10px;padding:0 10px;z-index:1}.topo-col-left{align-items:flex-end}.topo-col-right{align-items:flex-start}.topo-col-inactive{opacity:1}.topo-col-center{display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1}.topo-col-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:4px;line-height:1.5}.topo-col-label span{display:block;font-weight:400;text-transform:none;letter-spacing:0;font-size:9px;opacity:.75}.topo-col-left .topo-col-label{text-align:right}.topo-col-right .topo-col-label{text-align:left}.topo-node{background:var(--panel);border:1.5px solid var(--border);border-radius:10px;padding:10px 12px;width:175px;box-sizing:border-box}.topo-node-header{display:flex;align-items:center;gap:7px;margin-bottom:4px}.topo-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.topo-node-id{font-family:monospace;font-size:12px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topo-node-sub{font-size:11px;color:var(--muted);margin-bottom:5px;padding-left:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topo-params{list-style:none;padding:0 0 0 15px;margin:0}.topo-params li{font-size:11px;color:var(--muted);line-height:1.65}.topo-params li code{font-size:11px;color:var(--text);background:none}.topo-hub{background:var(--panel);border:2px solid var(--accent);border-radius:16px;padding:20px 16px;text-align:center}.topo-hub img{width:44px;height:44px;display:block;margin:0 auto 10px}.topo-hub-name{font-size:13px;font-weight:700;color:var(--accent);letter-spacing:.03em}.topo-hub-sub{font-size:10px;color:var(--muted);margin-top:3px}.topo-header{display:flex;justify-content:flex-end;margin-bottom:10px}.topo-updated{font-size:11px;color:var(--muted)}.topo-legend{display:flex;flex-wrap:wrap;gap:16px;margin-top:12px;padding:10px 16px;background:var(--panel);border:1px solid var(--border);border-radius:8px}.legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted)}.legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.topo-client-desc{color:var(--text);font-style:italic}.legend-dot-real{background:#22c55e}.legend-dot-virtual{background:#7c3aed}.legend-dot-error{background:#ef4444}.topo-node-locked{opacity:.55;border-style:dashed;pointer-events:none}.legend-dot-paused{background:#6b7280}.topo-markers{display:flex;gap:3px;margin-bottom:4px;padding-left:15px}.topo-marker{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:3px;font-family:monospace;font-size:10px;font-weight:700;line-height:1;cursor:default}.topo-marker-active{background:#22c55e;color:#fff}.topo-marker-idle{background:#eab308;color:#fff}.topo-marker-paused{background:#6b7280;color:#fff}.topo-empty{font-size:11px;color:var(--muted);padding:6px 0;font-style:italic}.settings-loading{color:var(--muted);font-size:14px;padding:8px 0}.settings-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(320px, 1fr));gap:16px}.settings-card{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:16px 18px}.settings-card-header{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:6px}.settings-card-label{font-size:14px;font-weight:700;color:var(--text)}.settings-card-key{font-family:monospace;font-size:11px;color:var(--muted);background:#f1f5f9;border-radius:4px;padding:2px 6px;white-space:nowrap}.settings-card-desc{font-size:12px;color:var(--muted);margin:0 0 12px;line-height:1.5}.settings-card-control{display:flex;gap:8px;align-items:center}.settings-input{flex:1;min-width:0;padding:6px 10px;border:1px solid var(--border);border-radius:8px;font-size:14px;color:var(--text);background:var(--bg)}.settings-input:focus{outline:none;border-color:var(--accent)}.settings-save-btn{background:var(--accent);color:#fff;border-color:var(--accent);white-space:nowrap;font-size:13px}.settings-save-btn:hover{background:#1e40af;border-color:#1e40af}.settings-card-status{margin-top:8px;font-size:12px;min-height:18px}.text-error{color:#dc2626}.text-success{color:#16a34a}.text-muted{color:var(--muted)}.settings-rows{display:flex;flex-direction:column;gap:10px}.settings-row{display:grid;grid-template-columns:1fr auto auto auto;align-items:center;gap:14px;padding:12px 14px;border:1px solid var(--border);border-radius:10px;background:var(--panel)}.settings-row-main{min-width:0}.settings-row-control{display:flex;align-items:center;justify-content:center;min-width:150px}.settings-row-save{width:auto}.settings-row-save .settings-save-btn{width:100%}.settings-row .settings-card-desc{margin:2px 0 0 0}.settings-row .settings-card-status{min-width:100px;text-align:right;margin-top:0}.settings-counter{display:flex;align-items:center;justify-content:center;gap:6px;width:100%}.settings-counter-btn{width:30px;height:30px;padding:0;border:1px solid var(--border);border-radius:8px;background:#fff;color:var(--text);font-size:18px;line-height:1}.settings-counter-input{width:130px;text-align:center}.settings-switch{position:relative;display:inline-block;width:44px;height:24px}.settings-switch input{opacity:0;width:0;height:0}.settings-slider{position:absolute;cursor:pointer;inset:0;background:#cbd5e1;transition:.2s;border-radius:999px}.settings-slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;top:3px;background:#fff;transition:.2s;border-radius:50%}.settings-switch input:checked+.settings-slider{background:var(--accent)}.settings-switch input:checked+.settings-slider:before{transform:translateX(20px)}@media(max-width: 980px){.settings-row{grid-template-columns:1fr;gap:10px}.settings-row-control{justify-self:start;min-width:0;width:100%;justify-content:flex-start}.settings-row-save{width:100%}.settings-row-save .settings-save-btn{width:auto}.settings-row .settings-card-status{text-align:left;min-width:0}}.settings-filter-bar{display:flex;gap:12px;margin-bottom:20px;background:var(--panel);padding:14px 18px;border:1px solid var(--border);border-radius:12px;align-items:center}.settings-filter-bar .filter-search-wrap{flex:1;min-width:0;position:relative}.settings-filter-bar .filter-search-wrap i{position:absolute;left:12px;top:11px;color:var(--muted)}.settings-filter-bar .filter-search-wrap input{padding-left:36px;width:100%;height:38px;box-sizing:border-box;margin:0;flex:none}.settings-filter-bar .filter-category-wrap{flex:0 0 200px}.settings-filter-bar .filter-category-wrap select{width:100%;height:38px;padding:0 10px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;box-sizing:border-box}.settings-filter-bar .filter-category-wrap select:focus{outline:none;border-color:var(--accent)}@media(max-width: 600px){.settings-filter-bar{flex-direction:column;align-items:stretch}.settings-filter-bar .filter-category-wrap{flex:0 0 auto;width:100%}}.settings-select{appearance:auto;padding:6px 10px;border:1px solid var(--border);border-radius:6px;background:var(--panel);color:var(--text);font-size:14px;cursor:pointer}.settings-category-badge{display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:2px 8px;border-radius:6px;background:#e2e8f0;color:#475569;margin-right:8px;vertical-align:middle}.history-btn-group{display:flex;gap:8px}.history-csv-btn{background:#f8fafc;color:#475569;border-color:#cbd5e1}.history-csv-btn:hover{background:#f1f5f9}.history-filters-section{margin-bottom:16px}.history-filters{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}.history-select,.history-dt{min-width:180px}.history-load-wrap{flex-shrink:0}.history-load-btn{background:var(--accent);color:#fff;border-color:var(--accent);padding:7px 16px;font-size:14px;white-space:nowrap}.history-load-btn:hover{background:#1e40af;border-color:#1e40af}.history-status{margin-top:10px;font-size:13px;min-height:20px}.history-status.history-status-error{color:#dc2626}.history-status.history-status-warn{color:#d97706}.history-status.history-status-loading{color:var(--muted)}.history-chart-section{margin-bottom:16px}.history-chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.history-chart-title{font-size:14px;font-weight:700;color:var(--text)}.history-chart-count{font-size:12px;color:var(--muted)}.history-chart-wrap{position:relative;height:240px}.history-stats-section{margin-bottom:16px}.history-stats-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:10px}.history-stats-group{margin-bottom:14px}.history-stats-group:last-child{margin-bottom:0}.history-stats-param-label{font-size:12px;font-weight:700;color:var(--text);margin-bottom:6px;display:flex;align-items:center;gap:6px}.history-stats-grid{display:flex;flex-wrap:wrap;gap:8px}.history-stat-card{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:8px 14px;min-width:90px;text-align:center}.history-stat-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:3px}.history-stat-value{font-size:15px;font-weight:700;font-family:monospace;color:var(--text)}.history-stat-unit{font-size:10px;color:var(--muted);margin-top:1px}.history-table-wrap{overflow-x:auto}.hist-ts{font-size:12px;white-space:nowrap;color:var(--muted)}.hist-val{font-weight:600;font-family:monospace}.hist-source{font-size:12px;color:var(--muted)}.hist-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:700;letter-spacing:.03em}.badge-ok{background:#dcfce7;color:#15803d}.badge-error{background:#fee2e2;color:#b91c1c}.badge-warn{background:#fef9c3;color:#92400e}.badge-muted{background:#f1f5f9;color:var(--muted)}.client-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px;flex-shrink:0}.client-status{display:flex;align-items:center;font-size:12px;font-weight:600}.client-status.allowed{color:#16a34a}.client-status.blocked{color:#dc2626}.client-btn-allow{font-size:12px;padding:4px 10px;color:#16a34a;border-color:#16a34a}.client-btn-allow:hover{background:#f0fdf4}.client-btn-block{font-size:12px;padding:4px 10px;border-color:#ef4444;color:#ef4444}.client-btn-block:hover{background:#fef2f2}.clients-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.clients-header-left{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.clients-header-left h2{margin:0}.clients-counters{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.clients-counter{font-size:12px;font-weight:600;color:var(--muted);display:flex;align-items:center;gap:4px}.clients-counter--allowed{color:#16a34a}.clients-counter--blocked{color:#dc2626}.clients-updated{font-size:11px;color:var(--muted)}.client-uid{font-family:monospace;font-size:12px}.client-empty{font-size:13px;color:var(--muted);font-style:italic;padding:12px 0}.clients-filters{display:flex;align-items:center;gap:8px;margin-bottom:14px;flex-wrap:wrap}.clients-filter-input{flex:1;min-width:180px;max-width:280px;height:32px;padding:0 10px;border:1px solid var(--border);border-radius:6px;background:var(--surface, #fff);color:var(--text);font-size:13px;font-family:inherit}.clients-filter-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px rgba(59,130,246,.1)}.clients-filter-input::placeholder{color:var(--muted)}.clients-filter-select{height:32px;padding:0 8px;border:1px solid var(--border);border-radius:6px;background:var(--surface, #fff);color:var(--text);font-size:13px;font-family:inherit;cursor:pointer}.clients-filter-select:focus{outline:none;border-color:var(--accent)}.clients-filter-clear{height:32px;padding:0 12px;border:1px solid var(--border);border-radius:6px;background:rgba(0,0,0,0);color:var(--muted);font-size:12px;font-family:inherit;cursor:pointer;display:flex;align-items:center;gap:5px;white-space:nowrap}.clients-filter-clear:hover{border-color:var(--text);color:var(--text)}.clients-th-sort{cursor:pointer;user-select:none;white-space:nowrap}.clients-th-sort:hover{color:var(--accent)}.sort-arrow{font-size:11px;margin-left:2px}.sort-arrow--inactive{color:var(--muted);opacity:.4}.sort-arrow--active{color:var(--accent)}.client-desc-input{width:100%;min-width:140px;box-sizing:border-box;border:1px solid rgba(0,0,0,0);border-radius:4px;padding:3px 6px;font-size:13px;font-family:inherit;color:var(--text);background:rgba(0,0,0,0);transition:border-color .12s,background .12s}.client-desc-input:hover{border-color:var(--border);background:#f9fafb}.client-desc-input:focus{outline:none;border-color:var(--accent);background:#fff;box-shadow:0 0 0 2px rgba(29,78,216,.08)}.client-desc-input::placeholder{color:var(--muted);font-style:italic}.refresh-indicator{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted)}.status-dot{width:8px;height:8px;border-radius:50%;background:#6b7280;flex-shrink:0}.status-dot.live{background:#22c55e;box-shadow:0 0 0 3px rgba(34,197,94,.25);animation:dash-pulse 2s ease-in-out infinite}.status-dot.connecting{background:#f59e0b;animation:dash-pulse .8s ease-in-out infinite}.status-dot.offline{background:#ef4444}@keyframes dash-pulse{0%,100%{opacity:1}50%{opacity:.35}}.strategy-tag{display:inline-flex;align-items:center;padding:3px 10px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap}.strategy-tag.strategy-always{background:#dcfce7;color:#15803d}.strategy-tag.strategy-active{background:#dbeafe;color:#1d4ed8}.strategy-tag.strategy-manual{background:#fef3c7;color:#b45309}.strategy-tag.strategy-disabled{background:#f1f5f9;color:#64748b}.strategy-select{padding:4px 8px;border:1px solid var(--border);border-radius:6px;background:var(--panel);color:var(--text);font-size:13px;cursor:pointer}.dashboard-page{padding:20px}.dashboard-page .dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.dashboard-page .dashboard-header h2{margin:0;font-size:24px;font-weight:700}.dashboard-page .dashboard-header .dashboard-controls{display:flex;gap:10px;align-items:center}.dashboard-page .device-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(340px, 1fr));gap:20px}.dashboard-page .device-card{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:16px 0 0;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column;position:relative;overflow:hidden}.dashboard-page .device-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.08)}.dashboard-page .device-card.status-error{border-left:4px solid #ef4444}.dashboard-page .device-card.status-error .status-badge{background:#fee2e2;color:#b91c1c}.dashboard-page .device-card.status-ok{border-left:4px solid #10b981}.dashboard-page .device-card.status-ok .status-badge{background:#d1fae5;color:#047857}.dashboard-page .device-card.poll-disabled{opacity:.7}.dashboard-page .device-card .card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;padding:0 16px 12px;border-bottom:1px solid var(--border)}.dashboard-page .device-card .card-header .device-info h3{margin:0;font-size:17px;font-weight:600}.dashboard-page .device-card .card-header .device-info .device-id{font-size:11px;color:var(--muted);font-family:monospace}.dashboard-page .device-card .card-header .card-header-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.dashboard-page .device-card .card-header .status-badge{padding:4px 10px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase}.dashboard-page .device-card .card-poll-toggle{display:inline-flex;align-items:center;cursor:pointer;user-select:none}.dashboard-page .device-card .card-poll-toggle input{position:absolute;opacity:0;width:0;height:0}.dashboard-page .device-card .card-toggle-track{display:inline-block;width:34px;height:18px;background:#cbd5e1;border-radius:9px;position:relative;transition:background .2s}.card-poll-toggle input:checked~.dashboard-page .device-card .card-toggle-track{background:#22c55e}.dashboard-page .device-card .card-toggle-thumb{position:absolute;top:2px;left:2px;width:14px;height:14px;background:#fff;border-radius:50%;transition:left .2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}.card-poll-toggle input:checked~.card-toggle-track .dashboard-page .device-card .card-toggle-thumb{left:18px}.dashboard-page .device-card .card-params{display:flex;flex-direction:column;gap:6px;padding:12px 14px;flex:1}.dashboard-page .device-card .param-block{display:flex;flex-direction:column;gap:4px;padding:8px 10px;background:var(--bg);border:1px solid var(--border);border-radius:8px}.dashboard-page .device-card .param-block.param-empty{font-size:12px;color:var(--muted);text-align:center;padding:14px}.dashboard-page .device-card .param-header{display:flex;justify-content:space-between;align-items:baseline;gap:8px}.dashboard-page .device-card .param-name{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}.dashboard-page .device-card .param-reading{display:flex;align-items:baseline;gap:4px}.dashboard-page .device-card .param-value{font-size:22px;font-weight:700;color:var(--text);line-height:1}.dashboard-page .device-card .param-unit{font-size:12px;color:var(--muted)}.dashboard-page .device-card .param-stats{display:flex;gap:10px}.dashboard-page .device-card .stat-item{display:inline-flex;align-items:center;gap:3px;font-size:11px;color:var(--muted)}.dashboard-page .device-card .stat-item i{font-size:9px}.dashboard-page .device-card .stat-item.stat-min i{color:#3b82f6}.dashboard-page .device-card .stat-item.stat-max i{color:#ef4444}.dashboard-page .device-card .stat-item.stat-avg i{color:#8b5cf6}.dashboard-page .device-card .card-footer{display:flex;justify-content:space-between;align-items:center;padding:8px 14px;border-top:1px solid var(--border);font-size:11px;color:var(--muted)}.dashboard-page .device-card .card-footer .last-update{display:flex;align-items:center;gap:5px}.dashboard-page .device-card .card-footer .card-footer-right{display:flex;align-items:center;gap:8px}.dashboard-page .device-card .card-footer .device-driver{font-size:11px;color:var(--muted)}.dashboard-page .device-card .card-footer .device-interval-select{padding:2px 6px;border:1px solid var(--border);border-radius:5px;background:var(--panel);color:var(--text);font-size:11px;cursor:pointer}.dashboard-page .device-card .poll-disabled-overlay{position:absolute;inset:0;background:rgba(0,0,0,.45);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;gap:6px;pointer-events:none;z-index:1}body.kiosk-mode .sidebar,body.kiosk-mode header:not(.dashboard-header){display:none !important}body.kiosk-mode .main-content{margin-left:0 !important;padding:0 !important}body.kiosk-mode .app-footer{display:none !important}body.kiosk-mode .dashboard-page{height:100vh;background:#000;color:#fff}body.kiosk-mode .dashboard-page .device-card{background:#111;border-color:#333;color:#fff}body.kiosk-mode .dashboard-page .device-card .card-header{border-bottom-color:#222}body.kiosk-mode .dashboard-page .device-card .param-block{background:#1a1a1a;border-color:#2a2a2a}body.kiosk-mode .dashboard-page .device-card .param-value{color:#fff}body.kiosk-mode .dashboard-page .device-card .param-name,body.kiosk-mode .dashboard-page .device-card .param-unit,body.kiosk-mode .dashboard-page .device-card .stat-item,body.kiosk-mode .dashboard-page .device-card .device-id,body.kiosk-mode .dashboard-page .device-card .card-footer,body.kiosk-mode .dashboard-page .device-card .device-driver{color:#888}body.kiosk-mode .dashboard-page .device-card .card-footer{border-top-color:#222}body.kiosk-mode .dashboard-page .device-card .device-interval-select{background:#1a1a1a;border-color:#333;color:#888}@media(max-width: 768px){.dashboard-page .device-grid{grid-template-columns:1fr}}.rm-section-label{margin:16px 0 6px;font-size:.85rem;text-transform:uppercase;color:var(--text-muted, #6b7280);letter-spacing:.05em}.rm-section-note{margin-top:12px}.wh-token-row{display:flex;gap:6px}.wh-token-row .cfg-input{flex:1;min-width:0}.mirror-icon-btn.wh-btn-copied{color:#16a34a;border-color:#86efac}.mirror-icon-btn.wh-btn-visible{color:var(--accent);border-color:var(--accent)}.wh-form-error{margin-top:10px;padding:10px 14px;background:#fee2e2;color:#991b1b;border:1px solid #fca5a5;border-radius:8px;font-size:13px;font-weight:500}.alerts-info{display:inline-flex;align-items:center;gap:6px;position:relative}.alerts-info .alerts-info-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--border);color:var(--muted);font-size:10px;font-style:normal;font-weight:700;cursor:default;flex-shrink:0;transition:background .15s,color .15s}.alerts-info .alerts-info-icon:hover{background:var(--accent);color:#fff}.alerts-info .alerts-tooltip{display:none;position:absolute;left:26px;top:50%;transform:translateY(-50%);z-index:100;background:#1f2937;color:#f9fafb;font-size:12px;font-weight:400;line-height:1.55;padding:10px 14px;border-radius:8px;width:320px;box-shadow:0 4px 16px rgba(0,0,0,.25);pointer-events:none}.alerts-info .alerts-tooltip::before{content:"";position:absolute;right:100%;top:50%;transform:translateY(-50%);border:6px solid rgba(0,0,0,0);border-right-color:#1f2937}.alerts-info .alerts-tooltip code{background:hsla(0,0%,100%,.15);border-radius:4px;padding:1px 5px;font-size:11px}.alerts-info:hover .alerts-tooltip{display:block}.alerts-locked{padding:40px 24px;text-align:center;color:var(--text-muted)}.alerts-locked i{font-size:2rem;margin-bottom:12px;display:block}.alerts-locked a{color:var(--accent);text-decoration:underline}.alerts-condition-row{display:flex;gap:8px;align-items:center;margin-bottom:8px}.alerts-condition-row select,.alerts-condition-row input{flex:1;min-width:0}.alerts-condition-row .mirror-icon-btn{flex-shrink:0}.alerts-test-row{display:flex;gap:8px;align-items:flex-end;margin-top:8px}.alerts-test-row .cfg-input{flex:1;min-width:0}.alerts-test-result{font-size:12px;padding:4px 10px;border-radius:6px;white-space:nowrap}.alerts-test-result.ok{background:#dcfce7;color:#15803d}.alerts-test-result.err{background:#fee2e2;color:#991b1b}.alerts-form-error{margin-top:10px;padding:10px 14px;background:#fee2e2;color:#991b1b;border:1px solid #fca5a5;border-radius:8px;font-size:13px;font-weight:500}.alerts-placeholder-hint{margin-top:6px;font-size:11px;color:var(--text-muted);line-height:1.6}.log-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-bottom:12px}.log-toolbar-left,.log-toolbar-right{display:flex;align-items:center;gap:8px}.log-toolbar-sep{display:inline-block;width:1px;height:20px;background:var(--border);margin:0 12px;flex-shrink:0}.log-level-label{font-size:12px;color:var(--muted);white-space:nowrap}.log-level-select{width:auto;min-width:120px;padding:4px 8px;font-size:12px}.log-autoscroll-label{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--muted);cursor:pointer;user-select:none}.log-status{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--muted)}.log-table-wrap{overflow-y:auto;max-height:65vh;border:1px solid var(--border);border-radius:8px;background:var(--panel)}.log-table{width:100%;border-collapse:collapse;font-size:12px}.log-table thead th{position:sticky;top:0;background:var(--panel);border-bottom:1px solid var(--border);padding:6px 10px;text-align:left;font-size:11px;font-weight:600;color:var(--muted);white-space:nowrap;z-index:1}.log-table tbody tr{border-bottom:1px solid var(--border);transition:background .1s}.log-table tbody tr:last-child{border-bottom:none}.log-table tbody tr:hover{background:var(--hover)}.log-table td{padding:4px 10px;vertical-align:top}.log-col-ts{white-space:nowrap;color:var(--muted);width:72px}.log-col-level{white-space:nowrap;width:90px}.log-col-logger{white-space:nowrap;max-width:200px;overflow:hidden;text-overflow:ellipsis;color:var(--muted);font-size:11px}.log-col-msg{word-break:break-all;font-family:monospace}.log-badge{display:inline-block;font-size:10px;font-weight:700;padding:1px 6px;border-radius:3px;letter-spacing:.04em;text-transform:uppercase}.log-lvl-debug{background:rgba(99,102,241,.15);color:#818cf8}.log-lvl-info{background:rgba(34,197,94,.13);color:#22c55e}.log-lvl-warn{background:rgba(234,179,8,.15);color:#eab308}.log-lvl-error{background:rgba(239,68,68,.15);color:#ef4444}.log-demo-sentinel{text-align:center;font-size:11px;color:var(--muted);padding:8px 10px;font-style:italic}.users-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px}.users-table-wrap{background:var(--panel);border:1px solid var(--border);border-radius:12px;overflow:hidden}.users-table{width:100%;border-collapse:collapse}.users-table th,.users-table td{padding:10px 14px;text-align:left;border-bottom:1px solid var(--border);vertical-align:middle;font-size:13px}.users-table tr:last-child td{border-bottom:none}.users-table th{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);background:var(--bg)}.users-table .users-col-pw{min-width:220px}.users-table .users-col-pw form{display:flex;gap:6px;align-items:center}.users-table .users-col-pw input{flex:1;min-width:0}.users-table .users-col-session{white-space:nowrap;font-size:12px;color:var(--muted)}.users-table .users-col-actions{white-space:nowrap;text-align:right}.users-role-badge{display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:2px 7px;border-radius:4px;background:rgba(29,78,216,.12);color:#93c5fd;border:1px solid rgba(29,78,216,.25)}.users-builtin-badge{display:inline-block;font-size:10px;font-weight:600;letter-spacing:.04em;padding:2px 7px;border-radius:4px;background:rgba(100,116,139,.12);color:var(--muted);border:1px solid rgba(100,116,139,.2);margin-left:6px}.btn{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:7px;font-size:13px;font-family:inherit;cursor:pointer;transition:background .12s,border-color .12s,color .12s;border:1px solid rgba(0,0,0,0);white-space:nowrap;text-decoration:none}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:#1e40af;border-color:#1e40af}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.btn-secondary{background:rgba(0,0,0,0);color:var(--text);border-color:var(--border);background:var(--panel)}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.btn-secondary:disabled{opacity:.55;cursor:not-allowed}.btn-danger{background:rgba(0,0,0,0);color:#dc2626;border-color:#dc2626}.btn-danger:hover{background:#dc2626;color:#fff}.btn-danger:disabled{opacity:.55;cursor:not-allowed}.btn-warning{background:rgba(0,0,0,0);color:#d97706;border-color:#d97706}.btn-warning:hover{background:#d97706;color:#fff}.btn-warning:disabled{opacity:.55;cursor:not-allowed}.btn-sm{padding:4px 8px;font-size:12px;border-radius:6px}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-card{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:24px;width:100%;max-width:360px;display:flex;flex-direction:column;gap:14px}.modal-title{font-size:16px;font-weight:700;color:var(--text);margin:0}.modal-footer{display:flex;gap:8px;justify-content:flex-end}.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg);margin:0}.login-card{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:2.5rem 2rem;width:100%;max-width:360px}.login-logo{display:flex;align-items:center;gap:.75rem;margin-bottom:2rem}.login-logo img{width:36px;height:36px}.login-logo span{font-size:1.25rem;font-weight:700;color:var(--text)}.login-title{font-size:1rem;color:var(--muted);margin-bottom:1.5rem}.login-field{margin-bottom:1rem}.login-field label{display:block;font-size:.8rem;color:var(--muted);margin-bottom:.4rem}.login-field input{width:100%;box-sizing:border-box}.login-btn{width:100%;margin-top:.5rem;padding:.65rem 1rem;font-size:.95rem;cursor:pointer}.login-error{color:#f87171;font-size:.85rem;margin-top:.75rem;min-height:1.2em}.login-default-hint{font-size:.75rem;color:var(--muted);margin-top:1rem;text-align:center}.cmp-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:10px 16px;margin-bottom:16px;flex-wrap:wrap}.cmp-bar-state{display:flex;align-items:center;gap:10px}.cmp-bar-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.cmp-state-badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap}.cmp-state-badge.cmp-state--idle{background:#f1f5f9;color:#64748b}.cmp-state-badge.cmp-state--stabilizing{background:#fef3c7;color:#b45309}.cmp-state-badge.cmp-state--measuring{background:#dbeafe;color:#1d4ed8}.cmp-state-badge.cmp-state--paused{background:#fde8d8;color:#c2410c}.cmp-state-badge.cmp-state--completed{background:#dcfce7;color:#15803d}.cmp-live-dot{width:8px;height:8px;border-radius:50%;background:#6b7280;flex-shrink:0;transition:background .2s}.cmp-live-dot.active{background:#22c55e;box-shadow:0 0 0 3px rgba(34,197,94,.25);animation:cmp-pulse 2s ease-in-out infinite}@keyframes cmp-pulse{0%,100%{opacity:1}50%{opacity:.35}}.cmp-bar-actions{display:flex;gap:8px}.cmp-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;border-radius:8px;font-size:13px;font-weight:600;border:none;cursor:pointer;transition:filter .12s,opacity .12s}.cmp-btn:disabled{opacity:.4;cursor:not-allowed;filter:none}.cmp-btn.cmp-btn--start{background:#16a34a;color:#fff}.cmp-btn.cmp-btn--start:not(:disabled):hover{filter:brightness(1.1)}.cmp-btn.cmp-btn--stop{background:#dc2626;color:#fff}.cmp-btn.cmp-btn--stop:not(:disabled):hover{filter:brightness(1.1)}.cmp-btn.cmp-btn--register{background:var(--accent);color:#fff}.cmp-btn.cmp-btn--register:not(:disabled):hover{filter:brightness(1.1)}.cmp-btn.cmp-btn--new{background:rgba(0,0,0,0);border:1px solid var(--border);color:var(--muted);margin-left:auto}.cmp-btn.cmp-btn--new:not(:disabled):hover{border-color:var(--accent);color:var(--accent)}.cmp-btn-small{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border:1px solid var(--border);border-radius:6px;background:var(--panel);color:var(--text);font-size:12px;cursor:pointer;transition:border-color .12s,color .12s;white-space:nowrap}.cmp-btn-small:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.cmp-btn-small:disabled{opacity:.4;cursor:not-allowed}.cmp-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;padding:0;border:1px solid var(--border);border-radius:6px;background:rgba(0,0,0,0);color:var(--muted);font-size:12px;cursor:pointer;flex-shrink:0;transition:border-color .12s,color .12s}.cmp-icon-btn:hover{border-color:#ef4444;color:#ef4444}.cmp-icon-btn:disabled{opacity:.4;cursor:not-allowed}.cmp-profiles-bar{display:flex;align-items:center;gap:8px;background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:10px 16px;margin-bottom:16px;flex-wrap:wrap}.cmp-profiles-divider{width:1px;height:24px;background:var(--border);flex-shrink:0;margin:0 4px}.cmp-profile-select{min-width:180px;max-width:240px}.cmp-profile-name{min-width:160px;max-width:200px}.cmp-btn-small--danger:hover:not(:disabled){border-color:#ef4444;color:#ef4444}.cmp-section-title{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:700;margin:0 0 16px;color:var(--text)}.cmp-collapsible{margin-bottom:12px}.cmp-collapsible-hdr{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--panel);border:1px solid var(--border);border-radius:10px;cursor:pointer;font-size:14px;font-weight:700;color:var(--text);user-select:none;transition:background .12s}.cmp-collapsible-hdr:hover{background:var(--bg)}.cmp-collapsible-hdr i{color:var(--muted);font-size:12px}.cmp-collapsible-body{margin-top:4px;overflow:hidden;transition:opacity .2s}.cmp-collapsible-body.cmp-collapsed{display:none}.cfg-row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}@media(max-width: 700px){.cfg-row3{grid-template-columns:1fr}}.cfg-row4{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:12px}@media(max-width: 900px){.cfg-row4{grid-template-columns:1fr 1fr}}@media(max-width: 500px){.cfg-row4{grid-template-columns:1fr}}.cmp-hint{font-size:12px;color:var(--muted);margin:0 0 8px;line-height:1.5}.cmp-corrections-list{display:flex;flex-direction:column;gap:6px;margin-bottom:4px}.cmp-corr-row{display:grid;grid-template-columns:1fr 1fr 28px;align-items:end;gap:8px}.cmp-corr-row .cfg-field{margin:0}.cmp-tab-bar{display:flex;gap:4px;margin-bottom:12px}.cmp-tab{padding:5px 14px;border:1px solid var(--border);border-radius:6px;background:rgba(0,0,0,0);color:var(--muted);font-size:12px;font-weight:600;cursor:pointer;transition:background .12s,border-color .12s,color .12s}.cmp-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}.cmp-tab:not(.active):not(:disabled):hover{border-color:var(--accent);color:var(--accent)}.cmp-tab:disabled{opacity:.4;cursor:not-allowed}.cmp-tol-panel.hidden{display:none}.cmp-formula-hint{font-size:13px;font-style:italic;color:var(--muted);margin:0 0 10px}.cmp-range-entries{display:flex;flex-direction:column;gap:6px}.cmp-range-row{display:grid;grid-template-columns:1fr auto 1fr auto 1fr 28px;align-items:center;gap:6px}.cmp-range-sep{font-size:13px;color:var(--muted);text-align:center;flex-shrink:0}.cmp-meas-hdr{display:flex;flex-direction:column;gap:10px;padding:12px 16px;background:var(--bg);border:1px solid var(--border);border-radius:8px;margin-bottom:12px}.cmp-cal-add{display:flex;align-items:center;gap:6px}.cmp-cal-input{width:90px}.cmp-live-row{display:flex;align-items:center;gap:20px;flex-wrap:wrap}.cmp-live-device{display:flex;align-items:center;gap:8px}.cmp-live-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);flex-shrink:0}.cmp-live-param{font-size:12px;color:var(--muted);font-style:italic}.cmp-live-value{font-size:18px;font-weight:700;font-family:monospace;color:var(--text);min-width:80px}.cmp-stab-wrap{display:flex;flex-direction:column;gap:4px}.cmp-stab-info{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--muted)}.cmp-stab-pct{font-weight:700;color:#b45309}.cmp-progress-track{height:6px;background:var(--border);border-radius:3px;overflow:hidden}.cmp-progress-fill{height:100%;background:linear-gradient(90deg, #f59e0b, #d97706);border-radius:3px;transition:width .3s ease}.cmp-table-wrap{overflow-x:auto}.cmp-table{width:100%;border-collapse:collapse;font-size:13px}.cmp-table th{text-align:left;padding:8px 10px;background:var(--bg);border-bottom:1px solid var(--border);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);white-space:nowrap}.cmp-table td{padding:7px 10px;border-bottom:1px solid var(--border);color:var(--text);white-space:nowrap}.cmp-table tr:last-child td{border-bottom:none}.cmp-table .cmp-row-fail td{background:#fef2f2}.cmp-table .cmp-row-pending td{background:var(--bg);color:var(--muted);font-style:italic}.cmp-empty-row td{text-align:center;color:var(--muted);padding:24px}.cmp-ts{font-size:12px;color:var(--muted);font-family:monospace}.cmp-delta{font-family:monospace}.cmp-pass{background:#dcfce7;color:#15803d}.cmp-fail{background:#fee2e2;color:#dc2626}.cmp-status-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px}.cmp-reg-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}.cmp-reg-badge.cmp-reg--auto{background:#f0fdf4;color:#15803d}.cmp-reg-badge.cmp-reg--manual{background:#eff6ff;color:#1d4ed8}.cmp-pending-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600;background:#f8fafc;color:#94a3b8;border:1px dashed #cbd5e1}.cmp-summary-wrap{display:flex;gap:32px;align-items:flex-start;flex-wrap:wrap}.cmp-verdict-block{display:flex;flex-direction:column;align-items:center;gap:6px;min-width:100px}.cmp-verdict{font-size:36px;font-weight:800;letter-spacing:-0.02em;color:var(--muted)}.cmp-verdict.cmp-verdict--pass{color:#16a34a}.cmp-verdict.cmp-verdict--fail{color:#dc2626}.cmp-verdict-counts{font-size:13px;color:var(--muted);text-align:center}.cmp-breakdown{flex:1;display:flex;flex-direction:column;gap:6px;min-width:200px}.cmp-breakdown-row{display:flex;align-items:center;justify-content:space-between;padding:5px 10px;background:var(--bg);border-radius:6px;font-size:13px}.cmp-breakdown-nom{color:var(--text)}.cmp-breakdown-stat{font-weight:700;font-size:13px;padding:2px 8px;border-radius:8px}.cmp-export-wrap{position:relative;display:inline-flex}.cmp-btn--export{background:#2563eb;color:#fff}.cmp-btn--export:not(:disabled):hover{filter:brightness(1.1)}.cmp-export-wrap>.cmp-btn--export:first-child{border-radius:8px 0 0 8px;border-right:1px solid hsla(0,0%,100%,.25)}.cmp-export-caret{border-radius:0 8px 8px 0;padding:7px 10px}.cmp-export-menu{display:none;position:absolute;top:calc(100% + 4px);right:0;background:var(--panel);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,.15);z-index:200;min-width:110px;overflow:hidden}.cmp-export-menu.open{display:block}.cmp-export-item{display:flex;align-items:center;gap:8px;width:100%;padding:9px 16px;background:none;border:none;cursor:pointer;font-size:13px;color:var(--text);text-align:left}.cmp-export-item:hover{background:var(--bg)}.cmp-info-box{display:flex;align-items:flex-start;gap:12px;background:rgba(37,99,235,.05);border:1px solid rgba(37,99,235,.15);border-radius:10px;padding:12px 16px;margin-bottom:16px;font-size:13px;line-height:1.5;color:var(--text)}.cmp-info-box i{color:#2563eb;font-size:16px;margin-top:2px}.cmp-info-box p{margin:0}.cmp-info-box p+p{margin-top:4px}.cmp-info-box .cmp-info-close{margin-left:auto;flex-shrink:0;background:none;border:none;cursor:pointer;color:#2563eb;opacity:.5;padding:0 2px;font-size:14px;line-height:1;align-self:flex-start}.cmp-info-box .cmp-info-close:hover{opacity:1}
