:root{--bg-primary: #0A0A0F;--bg-secondary: #13131A;--bg-tertiary: #1C1C26;--bg-hover: #24243A;--border: rgba(255, 255, 255, .06);--border-hover: rgba(255, 255, 255, .12);--text-primary: #F0F0F5;--text-secondary: #8888A0;--text-disabled: #555566;--accent: #3B82F6;--accent-hover: #5B9BF7;--accent-dim: rgba(59, 130, 246, .15);--success: #22C55E;--success-dim: rgba(34, 197, 94, .15);--warning: #F59E0B;--warning-dim: rgba(245, 158, 11, .15);--danger: #EF4444;--danger-dim: rgba(239, 68, 68, .15);--info: #6366F1;--chart-1: #3B82F6;--chart-2: #22C55E;--chart-3: #EF4444;--chart-4: #F59E0B;--chart-5: #A855F7;--chart-6: #06B6D4;--chart-7: #EC4899;--chart-8: #84CC16;--font-ui: "Inter", "Noto Sans SC", -apple-system, system-ui, sans-serif;--font-mono: "JetBrains Mono", "SF Mono", "Fira Code", monospace;--text-xs: 12px;--text-sm: 13px;--text-base: 14px;--text-lg: 17px;--text-xl: 20px;--text-2xl: 24px;--text-data-sm: 20px;--text-data: 28px;--text-data-lg: 36px;--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;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .5);--glow-accent: 0 0 20px rgba(59, 130, 246, .15);--glow-success: 0 0 20px rgba(34, 197, 94, .15);--glow-danger: 0 0 20px rgba(239, 68, 68, .15);--card-shadow: 0 2px 8px rgba(0, 0, 0, .25);--card-shadow-hover: 0 8px 24px rgba(0, 0, 0, .35), 0 2px 6px rgba(0, 0, 0, .2);--card-inset-highlight: inset 0 1px 0 rgba(255, 255, 255, .06);--card-inset-highlight-hover: inset 0 1px 0 rgba(255, 255, 255, .09);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease-out;--topbar-height: 56px;--sidebar-width: 72px;--statusbar-height: 32px;--att3d-canvas-bg: linear-gradient(180deg, #1a1a2e 0%, #0d0d1a 100%)}[data-theme=light]{--bg-primary: #F5F5F7;--bg-secondary: #FFFFFF;--bg-tertiary: #F0F0F2;--bg-hover: #E8E8ED;--border: rgba(0, 0, 0, .08);--border-hover: rgba(0, 0, 0, .15);--text-primary: #1D1D1F;--text-secondary: #6E6E73;--text-disabled: #AEAEB2;--accent: #2563EB;--accent-hover: #3B82F6;--accent-dim: rgba(37, 99, 235, .1);--success: #16A34A;--success-dim: rgba(22, 163, 74, .1);--warning: #D97706;--warning-dim: rgba(217, 119, 6, .1);--danger: #DC2626;--danger-dim: rgba(220, 38, 38, .1);--info: #4F46E5;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--glow-accent: 0 0 20px rgba(37, 99, 235, .1);--glow-success: 0 0 20px rgba(22, 163, 74, .1);--glow-danger: 0 0 20px rgba(220, 38, 38, .1);--card-shadow: 0 1px 4px rgba(0, 0, 0, .06), 0 2px 8px rgba(0, 0, 0, .04);--card-shadow-hover: 0 6px 20px rgba(0, 0, 0, .1), 0 2px 6px rgba(0, 0, 0, .06);--card-inset-highlight: inset 0 1px 0 rgba(255, 255, 255, .5);--card-inset-highlight-hover: inset 0 1px 0 rgba(255, 255, 255, .7);--att3d-canvas-bg: linear-gradient(180deg, #e8ecf1 0%, #d5dce6 100%)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:var(--font-ui);font-size:var(--text-base);line-height:1.5;color:var(--text-primary);background-color:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}@supports (-moz-appearance: none) or (-ms-overflow-style: none){body{-webkit-font-smoothing:auto}}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}button{font-family:inherit;cursor:pointer;border:none;outline:none;background:none;color:inherit}input,select,textarea{font-family:inherit;font-size:inherit;color:inherit;background:none;border:none;outline:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#fff3}[data-theme=light] ::-webkit-scrollbar-thumb{background:#0000001f}[data-theme=light] ::-webkit-scrollbar-thumb:hover{background:#0003}::selection{background:var(--accent-dim);color:var(--text-primary)}#pwa-update-bar{position:fixed;bottom:0;left:0;right:0;z-index:99999;display:flex;align-items:center;justify-content:center;gap:12px;padding:10px 20px;background:var(--bg-tertiary, #1a1a2e);border-top:1px solid var(--accent, #6366f1);font-size:var(--text-sm, 13px);color:var(--text-primary);animation:pwa-slide-up .3s ease-out}#pwa-update-bar span{flex:1;text-align:center}#pwa-update-btn{padding:4px 16px;border-radius:6px;background:var(--accent, #6366f1);color:#fff;font-size:var(--text-sm, 13px);font-weight:500;cursor:pointer;border:none;transition:opacity .2s}#pwa-update-btn:hover{opacity:.85}#pwa-dismiss-btn{padding:4px 8px;background:none;border:none;color:var(--text-secondary, #888);cursor:pointer;font-size:14px}@keyframes pwa-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-fade-in{animation:fadeIn .25s ease-out forwards}.animate-slide-up{animation:slideUp .25s ease-out forwards}.animate-scale-in{animation:scaleIn .3s cubic-bezier(.16,1,.3,1) forwards}.topbar{height:var(--topbar-height);background:var(--bg-secondary);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-5);-webkit-user-select:none;user-select:none;flex-shrink:0}.topbar__left{display:flex;align-items:center;gap:var(--space-3)}.topbar__logo{display:flex;align-items:center;gap:var(--space-2)}.topbar__logo img{background:#fff;border-radius:4px;padding:2px}[data-theme=light] .topbar__logo img{background:none;padding:0}.topbar__logo-text{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.topbar__center{display:flex;align-items:center}.topbar__subtitle{font-size:var(--text-sm);color:var(--text-tertiary);font-style:italic;letter-spacing:.01em}.topbar__vehicle-info{display:flex;align-items:center;gap:var(--space-3)}.topbar__board{font-size:var(--text-sm);font-weight:500;color:var(--accent);font-family:var(--font-mono);background:var(--accent-dim);padding:2px 10px;border-radius:var(--radius-full)}.topbar__autopilot{font-size:var(--text-sm);font-weight:500;color:var(--text-primary);background:var(--bg-tertiary);padding:2px 10px;border-radius:var(--radius-full)}.topbar__px4-badge{font-size:var(--text-sm);font-weight:700;color:#f97316;background:#f973161f;padding:2px 10px;border-radius:var(--radius-full);border:1px solid rgba(249,115,22,.4);letter-spacing:.04em}.topbar__px4-warn{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:#f97316;background:#f973161a;border:1px solid rgba(249,115,22,.3);padding:4px 12px;border-radius:var(--radius-full);white-space:nowrap;animation:topbar-px4-warn-in .3s ease-out}@keyframes topbar-px4-warn-in{0%{opacity:0;transform:translate(8px)}to{opacity:1;transform:translate(0)}}.topbar__firmware{font-size:var(--text-sm);color:var(--text-secondary);font-family:var(--font-mono)}.topbar__right{display:flex;align-items:center;gap:var(--space-3)}.topbar__connect-btn{display:flex;align-items:center;gap:var(--space-2);padding:6px 16px;border-radius:var(--radius-sm);background:var(--bg-tertiary);border:1px solid var(--border);font-size:var(--text-sm);font-weight:500;color:var(--text-primary);transition:all var(--transition-base);cursor:pointer}.topbar__connect-btn:hover{background:var(--bg-hover);border-color:var(--border-hover)}.topbar__connect-btn--disconnected{animation:connect-pulse 2.5s ease-in-out infinite}@keyframes connect-pulse{0%,to{border-color:var(--border);box-shadow:none}50%{border-color:var(--accent);box-shadow:0 0 8px var(--accent-dim)}}.topbar__icon-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--transition-base);cursor:pointer;background:none;border:none;text-decoration:none}.topbar__icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.topbar__lang-label{font-size:var(--text-sm);font-weight:600;line-height:1}.topbar__lang-wrapper{position:relative}.topbar__lang-menu{position:absolute;top:calc(100% + 6px);right:0;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:0 4px 16px #0000001f;padding:4px;z-index:1000;min-width:100px;animation:lang-menu-in .15s ease-out}@keyframes lang-menu-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.topbar__lang-option{display:block;width:100%;padding:6px 12px;border:none;background:none;border-radius:var(--radius-xs, 4px);font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;text-align:left;transition:all var(--transition-base);white-space:nowrap}.topbar__lang-option:hover{background:var(--bg-hover);color:var(--text-primary)}.topbar__lang-option--active{color:var(--accent);font-weight:600}.topbar__status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.topbar__status-dot--disconnected{background:var(--text-disabled)}.topbar__status-dot--connecting{background:var(--warning);animation:pulse 1.5s ease-in-out infinite;box-shadow:var(--glow-accent)}.topbar__status-dot--connected{background:var(--success);box-shadow:var(--glow-success);animation:pulse 2s ease-in-out infinite}.topbar__status-dot--error{background:var(--danger);box-shadow:var(--glow-danger)}.prearm{position:relative;display:flex;align-items:center;flex-shrink:0}.prearm__badge{display:flex;align-items:center;gap:7px;padding:7px 16px;border-radius:var(--radius-full);border:1px solid transparent;font-size:12px;font-weight:700;letter-spacing:.04em;line-height:1;cursor:default;transition:all var(--transition-fast);background:none;white-space:nowrap;font-family:inherit}.prearm__badge--ready{background:var(--success-dim);color:var(--success);border-color:var(--success);cursor:pointer}.prearm__badge--not-ready{background:var(--warning-dim);color:var(--warning);border-color:var(--warning);cursor:pointer}.prearm__badge--not-ready:hover{background:#f59e0b40}.prearm__badge--offline{background:var(--bg-tertiary);color:var(--text-disabled);border-color:var(--border)}.prearm__badge--flash{background:var(--danger-dim)!important;color:var(--danger)!important;border-color:var(--danger)!important;animation:prearm-flash .4s ease-in-out 5}@keyframes prearm-flash{0%,to{transform:scale(1);box-shadow:0 0 4px #ef44444d}50%{transform:scale(1.12);box-shadow:0 0 12px #ef444499,0 0 24px #ef44444d}}.prearm__text{font-size:11px;font-weight:700}.prearm__count{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 4px;border-radius:var(--radius-full);background:var(--warning);color:#fff;font-size:10px;font-weight:800;line-height:1}.prearm__chevron{transition:transform var(--transition-fast);flex-shrink:0}.prearm__chevron--open{transform:rotate(180deg)}.prearm-panel{width:340px;max-height:380px;background:var(--bg-secondary);border:1px solid var(--border-hover);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:10000;overflow:hidden;display:flex;flex-direction:column}.prearm-panel__header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}.prearm-panel__arming-btn{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:600;color:#fff;letter-spacing:.02em;background:var(--accent);border:none;border-radius:var(--radius-sm);padding:5px 14px;cursor:pointer;transition:all var(--transition-fast);font-family:inherit}.prearm-panel__arming-btn:hover{filter:brightness(1.15)}.prearm-panel__close{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:none;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.prearm-panel__close:hover{background:var(--bg-hover);color:var(--text-primary)}.prearm-panel__list{overflow-y:auto;padding:8px;flex:1}.prearm-panel__list::-webkit-scrollbar{width:4px}.prearm-panel__list::-webkit-scrollbar-thumb{background:var(--border-hover);border-radius:2px}.prearm-panel__item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);margin-bottom:2px;transition:background var(--transition-fast)}.prearm-panel__item:hover{background:var(--bg-hover)}.prearm-panel__icon{display:flex;align-items:center;flex-shrink:0;margin-top:1px}.prearm-panel__text{font-size:12px;font-weight:500;color:var(--text-primary);line-height:1.4;word-break:break-word}.prearm-panel__item--error .prearm-panel__icon{color:var(--danger)}.prearm-panel__item--warning .prearm-panel__icon{color:var(--warning)}.prearm-panel__item--info .prearm-panel__icon{color:var(--accent)}.prearm-panel__footer{padding:10px 16px;border-top:1px solid var(--border)}.prearm-panel__hint{font-size:11px;color:var(--text-secondary);line-height:1.4}.prearm-panel__arming-editor{padding:8px 12px;border-bottom:1px solid var(--border);background:var(--bg-tertiary)}.prearm-panel__arming-param-name{font-size:11px;font-weight:700;color:var(--text-secondary);margin-bottom:6px;font-family:monospace}.prearm-panel__arming-bitmask{display:flex;flex-direction:column;gap:3px;max-height:200px;overflow-y:auto}.prearm-panel__arming-bitmask::-webkit-scrollbar{width:4px}.prearm-panel__arming-bitmask::-webkit-scrollbar-thumb{background:var(--border-hover);border-radius:2px}.prearm-panel__arming-item{display:flex;align-items:center;gap:8px;padding:3px 4px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.prearm-panel__arming-item:hover{background:var(--bg-hover)}.prearm-panel__arming-checkbox{flex-shrink:0;accent-color:var(--primary)}.prearm-panel__arming-bit{font-size:10px;font-weight:600;color:var(--text-disabled);min-width:36px;font-family:monospace}.prearm-panel__arming-label{font-size:11px;font-weight:500;color:var(--text-primary)}.setup-guide{position:relative;display:flex;align-items:center;margin-left:auto;margin-right:var(--space-2);flex-shrink:0}.setup-guide__badge{display:flex;align-items:center;gap:7px;padding:7px 16px;border-radius:var(--radius-full);border:1px solid transparent;font-size:12px;font-weight:700;letter-spacing:.04em;line-height:1;cursor:default;transition:all var(--transition-fast);background:none;white-space:nowrap;font-family:inherit}.setup-guide__badge--done{background:var(--success-dim);color:var(--success);border-color:var(--success)}.setup-guide__badge--pending{background:var(--accent-dim);color:var(--accent);border-color:var(--accent);cursor:pointer}.setup-guide__badge--pending:hover{background:color-mix(in srgb,var(--accent) 25%,transparent)}.setup-guide__badge--offline{background:var(--bg-tertiary);color:var(--text-disabled);border-color:var(--border)}.setup-guide__text{font-size:11px;font-weight:700}.setup-guide__count{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 4px;border-radius:var(--radius-full);background:var(--accent);color:#fff;font-size:10px;font-weight:800;line-height:1}.setup-guide__chevron{transition:transform var(--transition-fast);flex-shrink:0}.setup-guide__chevron--open{transform:rotate(180deg)}.setup-panel{width:340px;max-height:440px;background:var(--bg-secondary);border:1px solid var(--border-hover);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:10000;overflow:hidden;display:flex;flex-direction:column}.setup-panel__header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}.setup-panel__title{font-size:13px;font-weight:700;color:var(--text-primary);letter-spacing:.02em}.setup-panel__close{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:none;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.setup-panel__close:hover{background:var(--bg-hover);color:var(--text-primary)}.setup-panel__progress{padding:12px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border)}.setup-panel__progress-bar{flex:1;height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden}.setup-panel__progress-fill{height:100%;background:var(--success);border-radius:3px;transition:width .3s ease}.setup-panel__progress-text{font-size:11px;font-weight:600;color:var(--text-secondary);white-space:nowrap}.setup-panel__list{overflow-y:auto;padding:8px;flex:1}.setup-panel__list::-webkit-scrollbar{width:4px}.setup-panel__list::-webkit-scrollbar-thumb{background:var(--border-hover);border-radius:2px}.setup-panel__item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);margin-bottom:2px;transition:background var(--transition-fast)}.setup-panel__item--passed .setup-panel__icon{color:var(--success)}.setup-panel__item--passed .setup-panel__text{color:var(--text-secondary);text-decoration:line-through;text-decoration-color:var(--text-disabled)}.setup-panel__item--pending{cursor:pointer}.setup-panel__item--pending:hover{background:var(--bg-hover)}.setup-panel__item--pending .setup-panel__icon{color:var(--warning)}.setup-panel__text{font-size:12px;font-weight:500;color:var(--text-primary);line-height:1.4;flex:1}.setup-panel__icon{display:flex;align-items:center;flex-shrink:0}.setup-panel__go{display:flex;align-items:center;color:var(--text-tertiary);opacity:0;transition:opacity var(--transition-fast)}.setup-panel__item--pending:hover .setup-panel__go{opacity:1}.setup-panel__footer{padding:10px 16px;border-top:1px solid var(--border)}.setup-panel__hint{font-size:11px;color:var(--text-secondary);line-height:1.4}.telemetry-bar{height:44px;background:var(--bg-secondary);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 var(--space-4);gap:0;flex-shrink:0;-webkit-user-select:none;user-select:none;position:relative;z-index:100}.tbar__group{display:flex;align-items:center;gap:8px;padding:0 14px;height:100%;white-space:nowrap;position:relative}.tbar__group:not(:last-child):after{content:"";position:absolute;right:0;top:25%;height:50%;width:1px;background:var(--border)}.tbar__group:first-child{padding-left:2px}.tbar__icon{display:flex;align-items:center;justify-content:center;width:18px;height:18px;flex-shrink:0;color:var(--text-secondary)}.tbar__icon svg{width:18px;height:18px}.tbar__value{font-family:var(--font-mono);font-size:14px;font-weight:600;color:var(--text-primary);line-height:1}.tbar__unit{font-family:var(--font-mono);font-size:10px;color:var(--text-secondary);margin-left:2px;font-weight:400}.tbar__arm-badge{font-size:11px;font-weight:700;letter-spacing:.06em;padding:4px 10px;border-radius:var(--radius-full);line-height:1;transition:all .3s ease}.tbar__arm-badge--armed{background:var(--danger-dim);color:var(--danger);border:1px solid var(--danger);animation:tbar-armed-glow 1.5s ease-in-out infinite,tbar-armed-pop .35s ease-out}@keyframes tbar-armed-glow{0%,to{box-shadow:0 0 4px #ef44444d,0 0 12px #ef444426}50%{box-shadow:0 0 8px #ef444499,0 0 24px #ef44444d}}@keyframes tbar-armed-pop{0%{transform:scale(.8);opacity:0}50%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}.tbar__arm-badge--disarmed{background:var(--success-dim);color:var(--success);border:1px solid var(--success);animation:tbar-disarmed-pop .3s ease-out}@keyframes tbar-disarmed-pop{0%{transform:scale(.85);opacity:0}60%{transform:scale(1.08)}to{transform:scale(1);opacity:1}}.tbar__mode-pill{font-size:12px;font-weight:700;letter-spacing:.05em;padding:4px 12px;border-radius:var(--radius-full);line-height:1;border:1px solid transparent;animation:tbar-mode-pop .25s ease-out}@keyframes tbar-mode-pop{0%{opacity:0;transform:scale(.85)}60%{transform:scale(1.05)}to{opacity:1;transform:scale(1)}}.tbar__mode-pill--stable{background:var(--success-dim);color:var(--success);border-color:var(--success)}.tbar__mode-pill--auto{background:var(--accent-dim);color:var(--accent);border-color:var(--accent)}.tbar__mode-pill--manual{background:var(--warning-dim);color:var(--warning);border-color:var(--warning)}.tbar__stack{display:flex;flex-direction:column;justify-content:center;gap:2px;line-height:1}.tbar__stack-row{display:flex;align-items:center;justify-content:center;gap:4px}.tbar__stack-label{font-size:10px;color:var(--text-secondary);font-weight:400}.tbar__stack-value{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--text-primary);line-height:1;min-width:36px;text-align:right;font-variant-numeric:tabular-nums}.tbar__stack-unit{font-family:var(--font-mono);font-size:9px;color:var(--text-secondary);font-weight:400}.tbar__gps-fix{font-size:10px;font-weight:700;padding:2px 6px;border-radius:var(--radius-full);line-height:1;letter-spacing:.04em}.tbar__gps-fix--nofix{background:var(--danger-dim);color:var(--danger)}.tbar__gps-fix--2d{background:var(--warning-dim);color:var(--warning)}.tbar__gps-fix--3d{background:var(--success-dim);color:var(--success)}.tbar__gps-fix--rtk{background:var(--accent-dim);color:var(--accent)}.tbar__batt-icon{display:flex;align-items:center;flex-shrink:0;position:relative;margin-right:4px}.tbar__batt-icon:after{content:"";position:absolute;right:-3px;top:50%;transform:translateY(-50%);width:3px;height:8px;background:var(--border-hover);border-radius:0 2px 2px 0}.tbar__batt-bar{width:28px;height:16px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden;border:1px solid var(--border)}.tbar__batt-fill{height:100%;border-radius:2px;transition:width .5s ease}.tbar__batt-fill--good{background:var(--success)}.tbar__batt-fill--warn{background:var(--warning)}.tbar__batt-fill--crit{background:var(--danger)}.tbar__batt-fill--dim{background:var(--text-disabled);width:0%!important}.tbar__value--good{color:var(--success)}.tbar__value--warn{color:var(--warning)}.tbar__value--crit{color:var(--danger)}.telemetry-bar--offline{opacity:.5}.telemetry-bar--offline .tbar__arm-badge{background:var(--bg-tertiary);color:var(--text-disabled);border-color:var(--border);animation:none}.telemetry-bar--offline .tbar__gps-fix{background:var(--bg-tertiary);color:var(--text-disabled)}.tbar__group--clickable{cursor:pointer;border-radius:var(--radius-md);transition:background .15s ease}.tbar__group--clickable:hover{background:var(--bg-tertiary)}.tbar__group--tip{position:relative}.tbar__group--tip:before{content:attr(data-tooltip);position:absolute;top:calc(100% + 4px);left:50%;transform:translate(-50%) translateY(-4px);font-size:10px;font-weight:600;color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border);box-shadow:0 2px 8px #0000001f;padding:3px 8px;border-radius:var(--radius-sm);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .15s ease,transform .15s ease;z-index:200}.tbar__group--tip:hover:before{opacity:1;transform:translate(-50%) translateY(0)}.tbar__gps-popover{position:fixed;transform:translate(-50%);width:max-content;min-width:300px;background:color-mix(in srgb,var(--bg-secondary) 80%,transparent);backdrop-filter:blur(16px) saturate(1.4);-webkit-backdrop-filter:blur(16px) saturate(1.4);border:1px solid color-mix(in srgb,var(--border) 60%,transparent);border-radius:var(--radius-lg);box-shadow:0 8px 32px #00000040;padding:12px;z-index:9999;animation:tbar-popover-in .15s ease-out}@keyframes tbar-popover-in{0%{opacity:0;transform:translate(-50%) translateY(-4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.tbar__gps-popover-arrow{position:absolute;top:-6px;left:50%;transform:translate(-50%) rotate(45deg);width:10px;height:10px;background:color-mix(in srgb,var(--bg-secondary) 80%,transparent);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-left:1px solid color-mix(in srgb,var(--border) 60%,transparent);border-top:1px solid color-mix(in srgb,var(--border) 60%,transparent)}.tbar__gps-popover-title{font-size:12px;font-weight:700;color:var(--text-secondary);text-align:center;margin-bottom:10px;letter-spacing:.04em;text-transform:uppercase}.tbar__gps-popover-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 12px}.tbar__gps-popover-item{display:flex;justify-content:space-between;align-items:center;padding:4px 8px;background:color-mix(in srgb,var(--bg-tertiary) 60%,transparent);border-radius:var(--radius-sm)}.tbar__gps-popover-item--full{grid-column:1 / -1}.tbar__gps-popover-label{font-size:11px;color:var(--text-tertiary);font-weight:500}.tbar__gps-popover-value{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--text-primary);white-space:nowrap}.tbar__ekf-wrap{position:relative}.tbar__ekf-btn{display:flex;align-items:center;gap:4px;padding:2px 6px;background:none;border:none;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:background .15s ease}.tbar__ekf-btn:hover{background:var(--bg-hover)}.tbar__ekf-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.tbar__ekf-dot--good{background:#22c55e}.tbar__ekf-dot--warn{background:#eab308}.tbar__ekf-dot--bad{background:#ef4444}.tbar__ekf-dropdown{position:absolute;top:calc(100% + 10px);left:50%;transform:translate(-50%);background:color-mix(in srgb,var(--bg-secondary) 80%,transparent);backdrop-filter:blur(16px) saturate(1.4);-webkit-backdrop-filter:blur(16px) saturate(1.4);border:1px solid color-mix(in srgb,var(--border) 60%,transparent);border-radius:var(--radius-lg);box-shadow:0 8px 32px #00000040;padding:12px 14px;z-index:9999;min-width:160px;animation:tbar-popover-in .15s ease-out}.tbar__ekf-dropdown:before{content:"";position:absolute;top:-6px;left:50%;transform:translate(-50%) rotate(45deg);width:10px;height:10px;background:color-mix(in srgb,var(--bg-secondary) 80%,transparent);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-left:1px solid color-mix(in srgb,var(--border) 60%,transparent);border-top:1px solid color-mix(in srgb,var(--border) 60%,transparent)}.tbar__ekf-title{font-size:12px;font-weight:700;color:var(--text-secondary);text-align:center;margin-bottom:10px;letter-spacing:.04em;text-transform:uppercase}.tbar__ekf-bars{display:flex;gap:8px;justify-content:center;align-items:flex-end}.tbar__ekf-bar-col{display:flex;flex-direction:column;align-items:center;gap:4px}.tbar__ekf-bar-track{width:16px;height:60px;background:var(--bg-tertiary);border-radius:3px;position:relative;overflow:hidden;display:flex;align-items:flex-end}.tbar__ekf-bar-fill{width:100%;border-radius:3px;transition:height .3s ease;min-height:2px}.tbar__ekf-bar-fill--good{background:#22c55e}.tbar__ekf-bar-fill--warn{background:#eab308}.tbar__ekf-bar-fill--bad{background:#ef4444}.tbar__ekf-bar-label{font-size:9px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;-webkit-user-select:none;user-select:none}.sidebar__nav{display:flex;flex-direction:column;padding:var(--space-2) 0;gap:var(--space-1)}.sidebar__item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:var(--space-2) 0;margin:0 var(--space-2);border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--transition-base);position:relative;cursor:pointer}.sidebar__item:hover{color:var(--text-primary);background:var(--bg-hover)}.sidebar__item--active{color:var(--accent);background:var(--accent-dim)}.sidebar__item--active:before{content:"";position:absolute;left:-8px;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--accent);border-radius:0 2px 2px 0}.sidebar__icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px}.sidebar__label{font-size:10px;font-weight:500;line-height:1}.statusbar{height:var(--statusbar-height);background:var(--bg-secondary);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-4);flex-shrink:0;-webkit-user-select:none;user-select:none;position:relative}.statusbar__left,.statusbar__right{display:flex;align-items:center;gap:var(--space-4)}.statusbar__center{position:absolute;left:50%;transform:translate(-50%);font-size:var(--text-xs)}.statusbar__item{display:flex;align-items:center;gap:var(--space-1);font-size:var(--text-xs)}.statusbar__label{color:var(--text-disabled)}.statusbar__value{color:var(--text-secondary)}.statusbar__value--mono{font-family:var(--font-mono)}.statusbar__value--connected{color:var(--success)}.statusbar__value--connecting{color:var(--warning)}.statusbar__value--disconnected{color:var(--text-disabled)}.statusbar__value--error{color:var(--danger)}.stb{background:var(--bg-secondary);border-top:1px solid var(--border);font-size:var(--text-xs);flex-shrink:0;position:relative}.stb__header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:4px var(--space-4);cursor:pointer;transition:background var(--transition-base);gap:var(--space-3)}.stb__header:hover{background:var(--bg-hover)}.stb__preview{display:flex;align-items:center;gap:var(--space-2);overflow:hidden;min-width:0}.stb__badge{flex-shrink:0;padding:1px 6px;border-radius:var(--radius-sm);font-size:10px;font-weight:600;font-family:var(--font-mono);letter-spacing:.03em;line-height:1.4}.stb__severity--error .stb__badge,.stb__badge.stb__severity--error{background:color-mix(in srgb,var(--danger) 15%,transparent);color:var(--danger)}.stb__severity--warning .stb__badge,.stb__badge.stb__severity--warning{background:color-mix(in srgb,var(--warning) 15%,transparent);color:var(--warning)}.stb__severity--info .stb__badge,.stb__badge.stb__severity--info{background:color-mix(in srgb,var(--accent) 15%,transparent);color:var(--accent)}.stb__severity--debug .stb__badge,.stb__badge.stb__severity--debug{background:var(--bg-tertiary);color:var(--text-tertiary)}.stb__text{color:var(--text-secondary);font-family:var(--font-mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stb__toggle{display:flex;align-items:center;gap:var(--space-1);color:var(--text-tertiary);font-size:10px;flex-shrink:0}.stb__count{background:var(--bg-tertiary);padding:0 5px;border-radius:var(--radius-full);font-size:10px;font-weight:600;color:var(--text-secondary)}.stb__list{position:absolute;bottom:100%;left:0;right:0;max-height:240px;overflow-y:auto;background:var(--bg-secondary);border-top:1px solid var(--border);border-bottom:1px solid var(--border);box-shadow:0 -4px 16px #00000014;z-index:1000}.stb__line{display:flex;align-items:center;gap:var(--space-2);padding:3px var(--space-4);font-family:var(--font-mono)}.stb__line:nth-child(2n){background:color-mix(in srgb,var(--bg-primary) 50%,transparent)}.stb__time{flex-shrink:0;color:var(--text-disabled);font-size:10px}.stb__severity--error .stb__text{color:var(--danger)}.stb__severity--warning .stb__text{color:var(--warning)}.pwa-banner{display:flex;align-items:center;justify-content:space-between;padding:8px var(--space-5);background:var(--accent-dim);border-bottom:1px solid var(--accent);font-size:var(--text-sm);color:var(--text-primary);gap:var(--space-3);flex-shrink:0}.pwa-banner__content{display:flex;align-items:center;gap:var(--space-2)}.pwa-banner__icon{color:var(--accent);flex-shrink:0}.pwa-banner__actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.pwa-banner__install{padding:4px 14px;border-radius:var(--radius-sm);background:var(--accent);color:#fff;font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:background var(--transition-fast)}.pwa-banner__install:hover{background:var(--accent-hover)}.pwa-banner__dismiss{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:14px;cursor:pointer;transition:all var(--transition-fast)}.pwa-banner__dismiss:hover{background:var(--bg-hover);color:var(--text-primary)}.dialog-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease-out}.connect-dialog{background:var(--bg-tertiary);border:1px solid var(--border-hover);border-radius:var(--radius-lg);width:400px;max-width:90vw;box-shadow:var(--shadow-lg)}.connect-dialog__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5);border-bottom:1px solid var(--border)}.connect-dialog__title{font-size:var(--text-lg);font-weight:600;color:var(--text-primary)}.connect-dialog__close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--transition-fast)}.connect-dialog__close:hover{background:var(--bg-hover);color:var(--text-primary)}.connect-dialog__body{padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-4)}.connect-dialog__field{display:flex;flex-direction:column;gap:var(--space-2)}.connect-dialog__label{font-size:var(--text-sm);font-weight:500;color:var(--text-secondary)}.connect-dialog__select{width:100%;height:36px;padding:0 var(--space-3);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--text-base);font-family:var(--font-mono);cursor:pointer;transition:border-color var(--transition-fast);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%238888A0' viewBox='0 0 24 24'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.connect-dialog__select:focus{border-color:var(--accent);box-shadow:var(--glow-accent)}.connect-dialog__select option{background:var(--bg-secondary);color:var(--text-primary)}.connect-dialog__hint{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.6}.connect-dialog__footer{padding:var(--space-4) var(--space-5);border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:var(--space-3)}.connect-dialog__btn{height:36px;padding:0 var(--space-5);border-radius:var(--radius-sm);font-size:var(--text-base);font-weight:500;cursor:pointer;transition:all var(--transition-base)}.connect-dialog__btn--primary{background:var(--accent);color:#fff}.connect-dialog__btn--primary:hover{background:var(--accent-hover);box-shadow:var(--glow-accent)}.connect-dialog__btn--primary:disabled{opacity:.5;cursor:not-allowed}.connect-dialog__btn--danger{background:var(--danger);color:#fff}.connect-dialog__btn--danger:hover{background:#dc2626;box-shadow:var(--glow-danger)}.connect-dialog__error{font-size:var(--text-sm);color:var(--danger);line-height:1.6;padding:var(--space-3);background:var(--danger-dim);border-radius:var(--radius-sm)}.rate-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);display:flex;flex-direction:column;height:fit-content;position:sticky;top:0}.rate-card__header{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border)}.rate-card__title{font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.rate-card__body{padding:var(--space-3) var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.rate-card__row{display:flex;align-items:center;gap:var(--space-3)}.rate-card__label{flex:1;font-size:var(--text-sm);color:var(--text-primary);font-weight:500;white-space:nowrap}.rate-card__select-group{display:flex;align-items:center;gap:4px}.rate-card__select{height:28px;padding:0 var(--space-2);background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--text-sm);font-family:var(--font-mono);outline:none;cursor:pointer;transition:border-color var(--transition-fast);-webkit-appearance:none;appearance:none;min-width:56px;text-align:center;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23888'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 6px center;padding-right:20px}.rate-card__select:focus{border-color:var(--accent)}.rate-card__select:disabled{opacity:.4;cursor:not-allowed}.rate-card__unit{font-size:var(--text-xs);color:var(--text-tertiary);font-family:var(--font-mono);width:20px}.rate-card__footer{padding:var(--space-3) var(--space-4);border-top:1px solid var(--border);text-align:center}.rate-card__reset-btn{font-size:var(--text-xs);color:var(--text-tertiary);background:none;border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px 12px;cursor:pointer;transition:all var(--transition-fast)}.rate-card__reset-btn:hover{color:var(--text-primary);border-color:var(--text-tertiary)}.status-tab{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.status-tab__toolbar{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);flex-shrink:0}.status-tab__search{flex:1;height:36px;padding:0 var(--space-3);font-size:var(--text-sm);font-family:var(--font-mono);background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.status-tab__search:focus{border-color:var(--accent);box-shadow:var(--glow-accent)}.status-tab__search::placeholder{color:var(--text-disabled)}.status-tab__count{font-size:var(--text-xs);font-family:var(--font-mono);color:var(--text-secondary);white-space:nowrap;flex-shrink:0}.status-tab__empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);color:var(--text-disabled);font-size:var(--text-sm)}.status-tab__table-wrap{flex:1;overflow-y:auto;min-height:0;padding-bottom:var(--space-2)}.status-tab__group{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-secondary);margin-bottom:var(--space-2)}.status-tab__group:last-child{margin-bottom:0}.status-tab__group-header{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);font-size:var(--text-xs);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;background:var(--bg-tertiary);border:none;border-radius:var(--radius-md) var(--radius-md) 0 0;cursor:pointer;transition:background var(--transition-fast);text-align:left}.status-tab__group--collapsed .status-tab__group-header{border-radius:var(--radius-md)}.status-tab__group-header:hover{background:var(--bg-hover)}.status-tab__group-arrow{color:var(--text-disabled);transition:transform var(--transition-fast);flex-shrink:0}.status-tab__group-arrow--open{transform:rotate(90deg)}.status-tab__group-name{flex:1}.status-tab__group-count{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:500;color:var(--text-disabled);background:var(--bg-secondary);padding:0 var(--space-2);border-radius:var(--radius-full);line-height:1.6}.status-tab__grid{columns:3;column-gap:0;font-family:var(--font-mono);font-size:var(--text-xs);border-top:1px solid var(--border)}.status-tab__item{display:flex;align-items:baseline;gap:var(--space-2);padding:3px var(--space-3);border-bottom:1px solid var(--border);border-right:1px solid var(--border);transition:background-color .3s ease;overflow:hidden;break-inside:avoid}.status-tab__item:hover{background:var(--bg-hover)}.status-tab__item--changed{background:var(--accent-dim)}.status-tab__item-name{color:var(--text-primary);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:0;min-width:0}.status-tab__item-value{color:var(--accent);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:right;flex:1;min-width:0}.status-tab__item-unit{color:var(--text-disabled);font-weight:400;font-size:.85em;margin-left:2px}.console{padding:var(--space-6);height:100%;display:flex;flex-direction:column;overflow:hidden}.console__body{flex:1;display:grid;grid-template-columns:1fr 280px;gap:var(--space-4);overflow:hidden;min-height:0}.console__main{display:flex;flex-direction:column;overflow:hidden;min-height:0}.console__sidebar{overflow-y:auto}.console__header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-3);flex-shrink:0}.console__tabs{display:flex;gap:var(--space-1);margin-bottom:var(--space-4);flex-shrink:0;overflow-x:auto;background:var(--bg-tertiary);border-radius:var(--radius-lg);padding:3px}.console__tab{padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);background:none;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.console__tab:hover{color:var(--text-primary);background:color-mix(in srgb,var(--accent) 8%,transparent)}.console__tab--active{color:var(--accent);background:var(--bg-secondary);box-shadow:0 1px 3px #00000014,0 0 0 1px color-mix(in srgb,var(--accent) 15%,transparent);font-weight:600}.console__title{font-size:var(--text-2xl);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-1)}.console__subtitle{font-size:var(--text-sm);color:var(--text-secondary)}.console__actions{display:flex;align-items:center;gap:var(--space-3)}.console__stats{font-size:var(--text-xs);color:var(--text-tertiary);font-family:var(--font-mono)}.console__btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-sm);color:var(--text-secondary);background:var(--bg-tertiary);border:1px solid var(--border);transition:all var(--transition-fast);cursor:pointer}.console__btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-hover)}.console__btn--active{color:var(--accent);border-color:var(--accent);background:#007aff1a}.console__empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);color:var(--text-tertiary);font-size:var(--text-sm)}.console__list{flex:1;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-secondary)}.console-row--header{display:flex;align-items:center;padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--border);font-size:var(--text-xs);color:var(--text-tertiary);font-weight:600;text-transform:uppercase;letter-spacing:.05em;position:sticky;top:0;background:var(--bg-secondary);z-index:1}.console-row__header{display:flex;align-items:center;width:100%;padding:var(--space-2) var(--space-3);border:none;background:none;color:var(--text-primary);font-size:var(--text-sm);font-family:var(--font-mono);cursor:pointer;transition:background var(--transition-fast);text-align:left}.console-row__header:hover{background:var(--bg-hover)}.console-row{border-bottom:1px solid var(--border)}.console-row:last-child{border-bottom:none}.console-row__expand{width:24px;flex-shrink:0;text-align:center;color:var(--text-tertiary);font-weight:600;font-size:var(--text-base)}.console-row__id{width:60px;flex-shrink:0;color:var(--text-tertiary);font-size:var(--text-xs)}.console-row__name{flex:1;font-weight:500;color:var(--accent)}.console-row--header .console-row__name{color:var(--text-tertiary)}.console-row__count{width:80px;flex-shrink:0;text-align:right;color:var(--text-secondary);font-size:var(--text-xs)}.console-row__hz{width:70px;flex-shrink:0;text-align:right;color:var(--success);font-weight:600;font-size:var(--text-xs)}.console-row__body{padding:var(--space-2) var(--space-3) var(--space-3);padding-left:calc(24px + var(--space-3));background:var(--bg-primary);border-top:1px solid var(--border);max-height:300px;overflow-y:auto}.console-row__table{width:100%;border-collapse:collapse;font-family:var(--font-mono);font-size:var(--text-xs)}.console-row__table td{padding:var(--space-1) var(--space-2)}.console-row__key{color:var(--text-secondary);width:180px;white-space:nowrap}.console-row__value{color:var(--text-primary);font-weight:500}.link-stats{flex-shrink:0;margin-top:var(--space-4);padding:var(--space-4);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md)}.link-stats__title{font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-3);text-transform:uppercase;letter-spacing:.05em}.link-stats__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:var(--space-3)}.link-stats__item{display:flex;flex-direction:column;gap:2px}.link-stats__label{font-size:var(--text-xs);color:var(--text-tertiary)}.link-stats__value{font-size:var(--text-sm);font-family:var(--font-mono);font-weight:600;color:var(--text-primary)}.link-stats__value--warn{color:var(--danger)}.params{display:flex;flex-direction:column;height:100%;overflow:hidden}.params--empty{align-items:center;justify-content:center;gap:var(--space-4)}.params__empty-icon{color:var(--text-disabled);opacity:.5}.params__empty-text{color:var(--text-tertiary);font-size:var(--text-sm)}.params__header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border);flex-shrink:0}.params__title-row{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:var(--space-3)}.params__title{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin:0}.params__stats{font-size:var(--text-xs);color:var(--text-tertiary);font-family:var(--font-mono);margin-left:var(--space-3)}.params__actions{display:flex;gap:var(--space-2);margin-left:auto}.params__action-btn{padding:4px 12px;font-size:var(--text-xs);font-weight:500;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent);border:1px solid color-mix(in srgb,var(--accent) 30%,transparent)}.params__action-btn:hover{background:color-mix(in srgb,var(--accent) 20%,transparent)}.params__action-btn--danger{color:var(--danger);background:color-mix(in srgb,var(--danger) 10%,transparent);border:1px solid color-mix(in srgb,var(--danger) 30%,transparent)}.params__action-btn--danger:hover{background:color-mix(in srgb,var(--danger) 20%,transparent)}.params__action-btn--warning{color:var(--warning);background:color-mix(in srgb,var(--warning) 10%,transparent);border:1px solid color-mix(in srgb,var(--warning) 30%,transparent)}.params__action-btn--warning:hover{background:color-mix(in srgb,var(--warning) 20%,transparent)}.params__action-btn--active{color:#fff;background:var(--accent);border-color:var(--accent)}.params__action-btn--active:hover{background:color-mix(in srgb,var(--accent) 85%,#000)}.params__flat-row{padding:0 var(--space-5)}.params__progress{height:3px;background:var(--bg-tertiary);border-radius:var(--radius-full);margin-bottom:var(--space-3);overflow:hidden}.params__progress-bar{height:100%;background:var(--accent);border-radius:var(--radius-full);transition:width .3s ease}.params__search{position:relative;display:flex;align-items:center}.params__search-icon{position:absolute;left:10px;color:var(--text-disabled);pointer-events:none}.params__search-input{width:100%;padding:7px 32px 7px 34px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--text-sm);font-family:var(--font-mono);outline:none;transition:border-color var(--transition-base)}.params__search-input:focus{border-color:var(--accent)}.params__search-input::placeholder{color:var(--text-disabled)}.params__search-clear{position:absolute;right:8px;color:var(--text-tertiary);font-size:12px;cursor:pointer;padding:2px 4px;border-radius:var(--radius-sm)}.params__search-clear:hover{color:var(--text-primary);background:var(--bg-hover)}.params__tree{flex:1;overflow-y:auto;padding:var(--space-2) 0}.params__no-results{text-align:center;padding:var(--space-8);color:var(--text-tertiary);font-size:var(--text-sm)}.params__group{border-bottom:1px solid color-mix(in srgb,var(--border) 50%,transparent)}.params__group-header{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:8px var(--space-5);cursor:pointer;transition:background var(--transition-base);text-align:left}.params__group-header:hover{background:var(--bg-hover)}.params__group-arrow{font-size:10px;color:var(--text-tertiary);width:14px;text-align:center;flex-shrink:0}.params__group-name{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);font-family:var(--font-mono)}.params__group-count{font-size:var(--text-xs);color:var(--text-disabled);margin-left:auto;font-family:var(--font-mono)}.params__group-body{padding:0 0 var(--space-1) 0}.params__subgroup{border-top:1px solid color-mix(in srgb,var(--border) 30%,transparent)}.params__subgroup-header{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:5px var(--space-5) 5px calc(var(--space-5) + 14px + var(--space-2));cursor:pointer;transition:background var(--transition-base);text-align:left}.params__subgroup-header:hover{background:var(--bg-hover)}.params__subgroup-name{font-size:var(--text-xs);font-weight:500;color:var(--text-secondary);font-family:var(--font-mono)}.params__subgroup-body{padding:0 var(--space-5) var(--space-2) calc(var(--space-5) + 28px + var(--space-4))}.params__leaf{border-top:1px solid color-mix(in srgb,var(--border) 20%,transparent)}.params__leaf-header{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:3px 0;cursor:pointer;transition:background var(--transition-base);text-align:left}.params__leaf-header:hover{background:color-mix(in srgb,var(--bg-hover) 50%,transparent)}.params__leaf-name{font-size:11px;font-weight:400;color:var(--text-disabled);font-family:var(--font-mono)}.params__leaf-body{padding-left:calc(14px + var(--space-2))}.params__leaf-child{border-top:1px solid color-mix(in srgb,var(--border) 15%,transparent)}.params__leaf-child-header{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:3px 0;cursor:pointer;transition:background var(--transition-base);text-align:left}.params__leaf-child-header:hover{background:color-mix(in srgb,var(--bg-hover) 40%,transparent)}.params__row-wrap{border-bottom:1px solid color-mix(in srgb,var(--border) 25%,transparent)}.params__row{display:flex;align-items:center;padding:6px 0;gap:var(--space-3);max-width:800px}.params__row:hover{background:color-mix(in srgb,var(--bg-hover) 50%,transparent)}.params__name-col{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.params__name-line{display:flex;align-items:baseline;gap:var(--space-1);min-width:0}.params__name{font-size:var(--text-xs);font-family:var(--font-mono);color:var(--text-primary);flex-shrink:0;font-weight:600}.params__unit{font-size:9px;color:var(--text-disabled);font-family:var(--font-mono);flex-shrink:0}.params__reboot{font-size:11px;color:var(--warning);cursor:help;flex-shrink:0}.params__human-name{font-size:10px;color:var(--text-tertiary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.params__desc-line{font-size:10px;color:var(--text-disabled);line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.params__right-col{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.params__value-cell{min-width:80px;text-align:right;flex-shrink:0}.params__default{font-size:10px;font-family:var(--font-mono);color:var(--warning, #e8a838);background:color-mix(in srgb,var(--warning, #e8a838) 8%,transparent);padding:1px 6px;border-radius:var(--radius-sm);white-space:nowrap;flex-shrink:0}.params__value{font-size:var(--text-xs);font-family:var(--font-mono);color:var(--accent);cursor:pointer;padding:2px 8px;border-radius:var(--radius-sm);transition:all var(--transition-base);text-align:right;background:transparent;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.params__value--modified{color:var(--warning, #e8a838)}.params__value:hover{background:color-mix(in srgb,var(--accent) 12%,transparent)}.params__select{padding:2px 6px;font-size:var(--text-xs);font-family:var(--font-mono);color:var(--text-primary);background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);outline:none;max-width:220px;cursor:pointer}.params__select:focus{border-color:var(--accent)}.params__input{width:100px;padding:2px 8px;font-size:var(--text-xs);font-family:var(--font-mono);color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--accent);border-radius:var(--radius-sm);text-align:right;outline:none}.params__value--bitmask{display:inline-flex;align-items:center;gap:4px}.params__bitmask-arrow{font-size:8px;color:var(--text-disabled)}.params__bitmask-panel{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:2px 12px;padding:6px 0 8px;border-top:1px solid color-mix(in srgb,var(--border) 40%,transparent)}.params__bitmask-item{display:flex;align-items:center;gap:var(--space-2);padding:2px 4px;border-radius:var(--radius-sm);cursor:pointer;font-size:11px;transition:background var(--transition-base)}.params__bitmask-item:hover{background:var(--bg-hover)}.params__bitmask-checkbox{width:13px;height:13px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.params__bitmask-bit{font-size:9px;font-family:var(--font-mono);color:var(--text-disabled);min-width:32px}.params__bitmask-label{color:var(--text-secondary);font-size:11px}.params__confirm-overlay{position:fixed;inset:0;z-index:1000;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center}.params__confirm-dialog{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-6);max-width:400px;width:90%;box-shadow:0 8px 32px #0000004d}.params__confirm-text{font-size:var(--text-sm);color:var(--text-primary);margin:0 0 var(--space-5) 0;line-height:1.5}.params__confirm-actions{display:flex;gap:var(--space-3);justify-content:flex-end}.params__confirm-btn{padding:6px 18px;font-size:var(--text-sm);font-weight:500;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.params__confirm-btn--cancel{color:var(--text-secondary);background:var(--bg-tertiary);border:1px solid var(--border)}.params__confirm-btn--cancel:hover{background:var(--bg-hover)}.params__confirm-btn--danger{color:#fff;background:#e53e3e;border:1px solid #e53e3e}.params__confirm-btn--danger:hover{background:#c53030}.params__confirm-btn--warning{color:#fff;background:#dd6b20;border:1px solid #dd6b20}.params__confirm-btn--warning:hover{background:#c05621}.params__import-dialog{max-width:440px}.params__import-warn-title{font-size:var(--text-base);font-weight:600;color:#dd6b20;margin:0 0 var(--space-3) 0}.params__import-warn-text{color:#e53e3e;font-weight:500}.params__import-stats{display:flex;flex-direction:column;gap:var(--space-1);font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-5);padding:var(--space-3);background:var(--bg-secondary);border-radius:var(--radius-md)}.params__import-progress{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-3)}.params__import-progress-bar{flex:1;height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden}.params__import-progress-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .15s ease}.params__import-progress-text{font-size:var(--text-sm);color:var(--text-secondary);white-space:nowrap}.params__import-diff-list{max-height:300px;overflow-y:auto;margin-bottom:var(--space-4);border:1px solid var(--border);border-radius:var(--radius-md);font-size:12px}.params__import-diff-header,.params__import-diff-row{display:grid;grid-template-columns:1fr .5fr .5fr;gap:var(--space-2);padding:4px 8px}.params__import-diff-header{font-weight:600;color:var(--text-secondary);background:var(--bg-tertiary);position:sticky;top:0;border-bottom:1px solid var(--border)}.params__import-diff-row{border-bottom:1px solid var(--border-subtle, rgba(128, 128, 128, .1))}.params__import-diff-row:last-child{border-bottom:none}.params__import-diff-name{color:var(--text-primary);font-family:var(--font-mono, monospace)}.params__import-diff-old{color:#e53e3e;text-align:right}.params__import-diff-new{color:#38a169;text-align:right}.params__import-diff-header--single,.params__import-diff-row--single{grid-template-columns:1fr}.app{display:flex;flex-direction:column;height:100vh;width:100vw;overflow:hidden;background:var(--bg-primary)}.app__body{display:flex;flex:1;overflow:hidden}.app__main{flex:1;overflow:hidden;background:var(--bg-primary)}.param-load-bar{background:var(--bg-secondary);border-bottom:1px solid var(--border);padding:4px var(--space-4);flex-shrink:0}.param-load-bar__info{display:flex;align-items:center;justify-content:space-between;margin-bottom:3px}.param-load-bar__label{font-size:11px;color:var(--text-secondary);font-weight:500}.param-load-bar__count{font-size:11px;color:var(--text-tertiary);font-family:var(--font-mono)}.param-load-bar__track{height:3px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.param-load-bar__fill{height:100%;background:var(--success);border-radius:var(--radius-full);transition:width .3s ease}
