: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__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__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: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)}.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)}.att3d{display:flex;flex-direction:column;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:1 / 1;box-shadow:var(--card-shadow),var(--card-inset-highlight)}.att3d__canvas{width:100%;flex:1;min-height:0;background:radial-gradient(circle,transparent 18%,transparent 18.5%,color-mix(in srgb,var(--border) 20%,transparent) 19%,transparent 19.5%),radial-gradient(circle,transparent 38%,transparent 38.5%,color-mix(in srgb,var(--border) 15%,transparent) 39%,transparent 39.5%),radial-gradient(circle,transparent 58%,transparent 58.5%,color-mix(in srgb,var(--border) 10%,transparent) 59%,transparent 59.5%),var(--att3d-canvas-bg, linear-gradient(180deg, #1a1a2e 0%, #0d0d1a 100%));cursor:grab}.att3d__canvas:active{cursor:grabbing}.att3d__data{display:flex;justify-content:space-around;padding:var(--space-3) var(--space-4);border-top:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0;gap:var(--space-2)}.att3d__item{display:flex;flex-direction:column;align-items:center;gap:2px;background:color-mix(in srgb,var(--bg-tertiary) 60%,transparent);padding:var(--space-1) var(--space-3);border-radius:var(--radius-md);border:1px solid color-mix(in srgb,var(--border) 30%,transparent)}.att3d__label{font-size:var(--text-xs);color:var(--text-tertiary);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.att3d__value{font-family:var(--font-mono);font-size:var(--text-base);font-weight:600;color:var(--text-primary)}.hud{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:1 / 1;box-shadow:var(--card-shadow),var(--card-inset-highlight)}.hud__canvas{display:block;width:100%;height:100%;background:#0a0a14}.sensor-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;min-height:0;box-shadow:var(--card-shadow),var(--card-inset-highlight)}.sensor-card__header{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);background:var(--bg-secondary)}.sensor-card__title{font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.sensor-card__grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3);padding:var(--space-3);background:transparent;flex:1;overflow-y:auto;min-height:0}.sensor-tile{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:var(--space-2) var(--space-2);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 4px 12px #0000000d,inset 0 1px #ffffff0d;transition:all var(--transition-base);cursor:default;overflow:hidden}.sensor-tile--clickable{cursor:pointer}.sensor-tile:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#ffffff0d,#fff0);pointer-events:none}.sensor-tile:hover{transform:translateY(-3px);box-shadow:0 12px 24px #0000001f,inset 0 1px #ffffff1a;background:var(--bg-hover)}.sensor-tile__icon{transition:color var(--transition-base)}.sensor-tile__label{font-size:var(--text-xs);font-weight:600;color:var(--text-primary);text-align:center}.sensor-tile--absent .sensor-tile__icon,.sensor-tile--absent .sensor-tile__label{color:var(--text-disabled)}.sensor-tile--healthy .sensor-tile__icon{color:var(--success)}.sensor-tile--unhealthy .sensor-tile__icon,.sensor-tile--unhealthy .sensor-tile__label{color:var(--danger)}.channels-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:row;min-height:80px;box-shadow:var(--card-shadow),var(--card-inset-highlight);transition:all var(--transition-base)}.channels-card .card__header{padding:var(--space-3) var(--space-2);border-bottom:none;border-right:1px solid var(--border);background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;writing-mode:vertical-rl;text-orientation:mixed}.channels-card .card__title{font-size:var(--text-xs);font-weight:600;color:var(--text-secondary);white-space:nowrap;letter-spacing:1px}.channels-card .card__body{padding:0 var(--space-3);flex:1;display:flex;flex-direction:column;justify-content:center}.channels__offline{display:flex;align-items:center;justify-content:center;padding:var(--space-4) 0;color:var(--text-disabled);font-size:var(--text-sm);font-style:italic}.channels__list{display:flex;justify-content:space-between;align-items:flex-end;padding:var(--space-2) 0}.channels__item{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);flex:1}.channels__value{font-size:11px;font-weight:600;color:var(--text-primary);font-family:var(--font-mono);height:14px}.channels__bar-container{width:25px;height:80px;background:var(--bg-tertiary);border-radius:var(--radius-sm);overflow:hidden;position:relative;display:flex;align-items:flex-end}.channels__bar-container:after{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:var(--border-hover);z-index:1}.channels-card--motor .channels__bar-container:after{display:none}.channels__bar-fill{width:100%;background:var(--success);border-radius:var(--radius-sm);transition:height .1s linear}.channels__label{font-size:12px;font-weight:700;color:var(--text-secondary);font-family:var(--font-mono)}.channels__list-wrapper{position:relative}.channels__overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center;gap:var(--space-2);background:#0000008c;border-radius:var(--radius-md);z-index:2;pointer-events:none;padding:6px 14px;color:#ffffffd9}.channels__overlay-text{font-size:var(--text-sm);font-weight:600;color:#ffffffd9;text-shadow:0 1px 4px rgba(0,0,0,.5);letter-spacing:.5px}.channels__overlay--failsafe{background:#ef4444b3;animation:channels-failsafe-pulse 2s ease-in-out infinite}@keyframes channels-failsafe-pulse{0%,to{opacity:.85}50%{opacity:1}}:root{--qd-cyan: #22d3ee;--qd-green: #4ade80;--qd-teal: #2dd4bf;--qd-blue: #60a5fa;--qd-purple: #a78bfa;--qd-orange: #fb923c;--qd-pink: #f472b6;--qd-rose: #fb7185;--qd-violet: #c084fc;--qd-yellow: #facc15;--qd-amber: #fbbf24;--qd-lime: #a3e635;--qd-sky: #38bdf8;--qd-indigo: #818cf8;--qd-fuchsia: #e879f9;--qd-red: #f87171;--qd-emerald: #34d399}.qd-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:row;box-shadow:var(--card-shadow),var(--card-inset-highlight);transition:all var(--transition-base);max-height:100%}.qd-card .card__header{padding:var(--space-3) var(--space-2);border-bottom:none;border-right:1px solid var(--border);background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;writing-mode:vertical-rl;text-orientation:mixed}.qd-card .card__title{font-size:var(--text-xs);font-weight:600;color:var(--text-secondary);white-space:nowrap;letter-spacing:1px}.qd-card .card__body{padding:var(--space-3);flex:1;display:flex;flex-direction:column;justify-content:center;min-height:0;overflow-y:auto}.qd__offline{display:flex;align-items:center;justify-content:center;padding:var(--space-4) 0;color:var(--text-disabled);font-size:var(--text-sm);font-style:italic}.qd__grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:1fr 1fr;gap:var(--space-3);height:100%}.qd__item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 4px;background:color-mix(in srgb,var(--bg-secondary) 50%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:var(--radius-md);border:1px solid color-mix(in srgb,var(--border) 40%,transparent);transition:all var(--transition-fast)}.qd__item:hover{background:var(--bg-hover);transform:translateY(-1px)}.qd__value{font-family:var(--font-mono);font-size:28px;font-weight:700;line-height:1.2;letter-spacing:-.02em;text-align:center;word-break:break-all;width:100%;padding:0 4px}.qd__unit{font-size:10px;font-weight:400;opacity:.7;margin-left:1px}.qd__label{font-size:10px;font-weight:500;color:var(--text-disabled);margin-top:2px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.qd__item--clickable{cursor:pointer}.qd__header--clickable{cursor:pointer;transition:background var(--transition-fast)}.qd__header--clickable:hover{background:var(--bg-hover)}.qd-picker__overlay{position:fixed;inset:0;background:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center;animation:qd-fade-in .15s ease-out}@keyframes qd-fade-in{0%{opacity:0}to{opacity:1}}.qd-picker{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);width:420px;max-height:70vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0006;animation:qd-slide-up .15s ease-out}@keyframes qd-slide-up{0%{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}.qd-picker__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border)}.qd-picker__title{font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.qd-picker__close{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)}.qd-picker__close:hover{background:var(--bg-hover);color:var(--text-primary)}.qd-picker__search{margin:var(--space-3) var(--space-4);padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);font-size:var(--text-sm)}.qd-picker__search:focus{border-color:var(--accent);outline:none}.qd-picker__list{overflow-y:auto;padding:0 var(--space-3) var(--space-3);flex:1;min-height:0}.qd-picker__group{margin-bottom:var(--space-2)}.qd-picker__group-name{font-size:11px;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;padding:var(--space-2) var(--space-2);position:sticky;top:0;background:var(--bg-secondary);z-index:1}.qd-picker__item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:4px var(--space-2);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast);text-align:left}.qd-picker__item:hover{background:var(--bg-hover)}.qd-picker__item--active{background:var(--accent-dim)}.qd-picker__item--active .qd-picker__item-name{color:var(--accent)}.qd-picker__item-name{font-family:var(--font-mono);font-size:12px;font-weight:500;color:var(--text-primary)}.qd-picker__item-value{font-family:var(--font-mono);font-size:12px;color:var(--text-secondary)}.qd-picker__item-unit{font-size:10px;color:var(--text-disabled);margin-left:2px}.qd-picker__empty{text-align:center;color:var(--text-disabled);font-size:var(--text-sm);padding:var(--space-6) 0}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;-moz-box-sizing:border-box;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;-webkit-transition:opacity .2s linear;-moz-transition:opacity .2s linear;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{-webkit-transform-origin:0 0;-ms-transform-origin:0 0;transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{-webkit-transition:none;-moz-transition:none;transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;-moz-box-sizing:border-box;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.map-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:row;box-shadow:var(--card-shadow),var(--card-inset-highlight);transition:all var(--transition-base)}.map-card .card__header{padding:var(--space-3) var(--space-2);border-bottom:none;border-right:1px solid var(--border);background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;writing-mode:vertical-rl;text-orientation:mixed}.map-card .card__title{font-size:var(--text-xs);font-weight:600;color:var(--text-secondary);white-space:nowrap;letter-spacing:1px}.map-card__body{flex:1;padding:0!important;min-height:200px;position:relative}.map-card__container{width:100%;height:100%;min-height:200px}.map-card__coords{position:absolute;bottom:6px;left:6px;font-family:var(--font-mono);font-size:12px;color:var(--text-secondary);background:color-mix(in srgb,var(--bg-primary) 85%,transparent);padding:2px 6px;border-radius:var(--radius-sm);z-index:1000;pointer-events:none}.map-drone-icon{background:none!important;border:none!important}.map-drone-arrow{width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:20px solid #3b82f6;filter:drop-shadow(0 1px 3px rgba(0,0,0,.4));transform-origin:center center;margin:2px auto 0}.map-card .leaflet-container{background:var(--bg-tertiary)}.dashboard{padding:var(--space-5);animation:fadeIn .25s ease-out;height:100%;overflow-y:auto}.dashboard__header{margin-bottom:var(--space-4)}.dashboard__title{font-size:var(--text-2xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-1)}.dashboard__subtitle{font-size:var(--text-sm);color:var(--text-secondary)}.dashboard__layout{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--space-4);align-items:stretch;max-width:1280px}.dashboard__layout-bottom{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);align-items:stretch;max-width:1280px;margin-top:var(--space-4)}.dashboard__layout-bottom:last-child{grid-template-rows:250px}.dashboard__layout-full{max-width:1280px;margin-top:var(--space-4)}@media(max-width:900px){.dashboard__layout,.dashboard__layout-2col,.dashboard__layout-bottom{grid-template-columns:1fr}}.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)}.fcfiles{display:flex;flex-direction:column;height:100%;overflow:hidden}.fcfiles--empty{align-items:center;justify-content:center;color:var(--text-tertiary);font-size:var(--text-sm)}.fcfiles__toolbar{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) 0;flex-shrink:0;border-bottom:1px solid var(--border);margin-bottom:var(--space-3)}.fcfiles__tool-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);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.fcfiles__tool-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-hover)}.fcfiles__tool-btn:disabled{opacity:.4;cursor:not-allowed}.fcfiles__tool-btn--accent{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 30%,transparent)}.fcfiles__tool-btn--accent:hover:not(:disabled){background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent);border-color:var(--accent)}.fcfiles__toolbar-center{display:flex;align-items:center;gap:var(--space-2);padding:0 var(--space-3);border-left:1px solid var(--border);border-right:1px solid var(--border);margin:0 var(--space-1)}.fcfiles__log-btn{display:flex;align-items:center;gap:var(--space-1);padding:4px 10px;border-radius:var(--radius-sm);border:1px solid color-mix(in srgb,var(--accent) 30%,transparent);background:color-mix(in srgb,var(--accent) 8%,transparent);color:var(--accent);font-size:var(--text-xs);font-weight:500;cursor:pointer;white-space:nowrap;transition:all var(--transition-fast)}.fcfiles__log-btn:hover:not(:disabled){background:color-mix(in srgb,var(--accent) 15%,transparent);border-color:var(--accent)}.fcfiles__log-btn:disabled{opacity:.4;cursor:not-allowed}.fcfiles__toggle-group{display:flex;align-items:center;gap:var(--space-2);padding-left:var(--space-2);border-left:1px solid var(--border)}.fcfiles__toggle-label{font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap}.fcfiles__toggle{position:relative;width:36px;height:20px;border-radius:10px;background:var(--bg-tertiary);border:1px solid var(--border);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0;padding:0}.fcfiles__toggle--on{background:var(--accent);border-color:var(--accent)}.fcfiles__toggle-knob{position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;transition:transform var(--transition-fast);box-shadow:0 1px 3px #0003}.fcfiles__toggle--on .fcfiles__toggle-knob{transform:translate(16px)}.fcfiles__tip{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:color-mix(in srgb,var(--accent) 10%,transparent);border:1px solid color-mix(in srgb,var(--accent) 30%,transparent);border-radius:var(--radius-sm);color:var(--accent);font-size:var(--text-sm);margin-bottom:var(--space-2);flex-shrink:0}.fcfiles__tip button{margin-left:auto;background:none;border:none;color:inherit;cursor:pointer;font-size:var(--text-base)}.fcfiles__breadcrumb{display:flex;align-items:center;gap:2px;flex:1;min-width:0;overflow-x:auto;font-size:var(--text-sm);font-family:var(--font-mono);padding:0 var(--space-2)}.fcfiles__crumb{background:none;border:none;color:var(--accent);cursor:pointer;padding:2px 4px;border-radius:var(--radius-xs, 2px);font-size:var(--text-sm);font-family:var(--font-mono);white-space:nowrap}.fcfiles__crumb:hover{background:color-mix(in srgb,var(--accent) 10%,transparent)}.fcfiles__crumb-sep{color:var(--text-tertiary)}.fcfiles__toolbar-right{display:flex;align-items:center;gap:var(--space-2);margin-left:auto}.fcfiles__view-toggle{display:flex;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.fcfiles__view-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:var(--bg-tertiary);color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast)}.fcfiles__view-btn:first-child{border-right:1px solid var(--border)}.fcfiles__view-btn--active{background:var(--accent);color:#fff}.fcfiles__view-btn:hover:not(.fcfiles__view-btn--active){color:var(--text-primary)}.fcfiles__newfolder{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) 0;flex-shrink:0}.fcfiles__newfolder-input{flex:1;max-width:300px;padding:var(--space-1) var(--space-3);font-size:var(--text-sm);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-primary);outline:none}.fcfiles__newfolder-input:focus{border-color:var(--accent)}.fcfiles__newfolder-ok,.fcfiles__newfolder-cancel{padding:var(--space-1) var(--space-3);font-size:var(--text-sm);border-radius:var(--radius-sm);border:1px solid var(--border);cursor:pointer;transition:all var(--transition-fast)}.fcfiles__newfolder-ok{background:var(--accent);color:#fff;border-color:var(--accent)}.fcfiles__newfolder-ok:hover{opacity:.9}.fcfiles__newfolder-cancel{background:var(--bg-tertiary);color:var(--text-secondary)}.fcfiles__error{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-3);background:#e53e3e1a;border:1px solid rgba(229,62,62,.3);border-radius:var(--radius-sm);color:#e53e3e;font-size:var(--text-sm);margin-bottom:var(--space-2);flex-shrink:0}.fcfiles__error button{background:none;border:none;color:inherit;cursor:pointer;font-size:var(--text-base)}.fcfiles__progress{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) 0;flex-shrink:0}.fcfiles__progress-label{font-size:var(--text-sm);color:var(--text-primary);font-family:var(--font-mono);white-space:nowrap;max-width:200px;overflow:hidden;text-overflow:ellipsis}.fcfiles__progress-bar{flex:1;height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden}.fcfiles__progress-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .2s}.fcfiles__progress-text{font-size:var(--text-xs);color:var(--text-secondary);font-family:var(--font-mono);white-space:nowrap}.fcfiles__loading,.fcfiles__empty{display:flex;align-items:center;justify-content:center;gap:var(--space-2);flex:1;color:var(--text-tertiary);font-size:var(--text-sm)}.fcfiles__spinner{animation:fcfiles-spin 1s linear infinite}@keyframes fcfiles-spin{to{transform:rotate(360deg)}}.fcfiles__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:var(--space-2);overflow-y:auto;flex:1;padding:var(--space-1);align-content:start}.fcfiles__grid-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--space-2) var(--space-1);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast);position:relative}.fcfiles__grid-item:hover{background:var(--bg-hover)}.fcfiles__grid-item:hover .fcfiles__grid-actions{opacity:1}.fcfiles__icon{width:64px;height:64px;flex-shrink:0}.fcfiles__icon--dir{color:#f6ad55}.fcfiles__icon--file{color:var(--text-tertiary)}.fcfiles__icon--log{color:var(--accent)}.fcfiles__icon--param{color:#38a169}.fcfiles__grid-name{font-size:var(--text-xs);color:var(--text-primary);text-align:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;word-break:break-all}.fcfiles__grid-size{font-size:10px;color:var(--text-tertiary);font-family:var(--font-mono)}.fcfiles__grid-actions{position:absolute;top:4px;right:4px;display:flex;gap:2px;opacity:0;transition:opacity var(--transition-fast)}.fcfiles__list{overflow-y:auto;flex:1;border:1px solid var(--border);border-radius:var(--radius-md)}.fcfiles__list-header{display:grid;grid-template-columns:1fr 100px 80px;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--text-xs);font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;background:var(--bg-secondary);border-bottom:1px solid var(--border);position:sticky;top:0}.fcfiles__list-row{display:grid;grid-template-columns:1fr 100px 80px;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);border-bottom:1px solid var(--border-subtle, rgba(128, 128, 128, .08));cursor:pointer;transition:background var(--transition-fast);align-items:center}.fcfiles__list-row:hover{background:var(--bg-hover)}.fcfiles__list-row:last-child{border-bottom:none}.fcfiles__list-col{display:flex;align-items:center;min-width:0}.fcfiles__list-col--name{gap:var(--space-2);overflow:hidden}.fcfiles__list-col--name .fcfiles__icon{width:20px;height:20px;flex-shrink:0}.fcfiles__list-col--name span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fcfiles__list-col--size{color:var(--text-secondary);font-family:var(--font-mono);font-size:var(--text-xs);justify-content:flex-end}.fcfiles__list-col--actions{display:flex;gap:4px;justify-content:flex-end}.fcfiles__action-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border:none;background:var(--bg-secondary, rgba(128, 128, 128, .12));color:var(--text-tertiary);cursor:pointer;border-radius:6px;transition:all var(--transition-fast);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 1px 3px #00000014}.fcfiles__action-btn:hover{color:var(--accent);background:color-mix(in srgb,var(--accent) 18%,var(--bg-secondary, #fff));box-shadow:0 1px 4px #0000001f}.fcfiles__action-btn--delete:hover{color:#e53e3e;background:#e53e3e26}.uplot,.uplot *,.uplot *:before,.uplot *:after{box-sizing:border-box}.uplot{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";line-height:1.5;width:min-content}.u-title{text-align:center;font-size:18px;font-weight:700}.u-wrap{position:relative;-webkit-user-select:none;user-select:none}.u-over,.u-under{position:absolute}.u-under{overflow:hidden}.uplot canvas{display:block;position:relative;width:100%;height:100%}.u-axis{position:absolute}.u-legend{font-size:14px;margin:auto;text-align:center}.u-inline{display:block}.u-inline *{display:inline-block}.u-inline tr{margin-right:16px}.u-legend th{font-weight:600}.u-legend th>*{vertical-align:middle;display:inline-block}.u-legend .u-marker{width:1em;height:1em;margin-right:4px;background-clip:padding-box!important}.u-inline.u-live th:after{content:":";vertical-align:middle}.u-inline:not(.u-live) .u-value{display:none}.u-series>*{padding:4px}.u-series th{cursor:pointer}.u-legend .u-off>*{opacity:.3}.u-select{background:#00000012;position:absolute;pointer-events:none}.u-cursor-x,.u-cursor-y{position:absolute;left:0;top:0;pointer-events:none;will-change:transform}.u-hz .u-cursor-x,.u-vt .u-cursor-y{height:100%;border-right:1px dashed #607D8B}.u-hz .u-cursor-y,.u-vt .u-cursor-x{width:100%;border-bottom:1px dashed #607D8B}.u-cursor-pt{position:absolute;top:0;left:0;border-radius:50%;border:0 solid;pointer-events:none;will-change:transform;background-clip:padding-box!important}.u-axis.u-off,.u-select.u-off,.u-cursor-x.u-off,.u-cursor-y.u-off,.u-cursor-pt.u-off{display:none}.log-analysis{display:flex;flex-direction:column;height:100%;overflow:hidden}.log-analysis--loaded{overflow-y:auto}.log-analysis__dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;margin:80px auto;padding:48px 64px;border:2px dashed var(--border-color, rgba(128, 128, 128, .3));border-radius:16px;cursor:pointer;transition:all .2s ease;color:var(--text-secondary, #888);max-width:480px}.log-analysis__dropzone:hover,.log-analysis__dropzone--active{border-color:var(--accent, #339af0);background:#339af00d;color:var(--text-primary, #ccc)}.log-analysis__dropzone svg{opacity:.5}.log-analysis__dropzone-title{font-size:15px;font-weight:500;margin:0}.log-analysis__dropzone-hint{font-size:12px;opacity:.6;margin:0}.log-analysis__error{color:#ff6b6b;text-align:center;font-size:13px;margin-top:12px}.log-analysis__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;margin:80px auto;color:var(--text-secondary, #888)}.log-analysis__spinner{width:32px;height:32px;border:3px solid rgba(128,128,128,.2);border-top-color:var(--accent, #339af0);border-radius:50%;animation:log-spin .8s linear infinite}@keyframes log-spin{to{transform:rotate(360deg)}}.log-analysis__progress-bar{width:200px;height:4px;background:#80808026;border-radius:2px;overflow:hidden}.log-analysis__progress-fill{height:100%;background:var(--accent, #339af0);border-radius:2px;transition:width .15s ease}.log-analysis__summary{display:flex;align-items:center;gap:20px;padding:10px 16px;background:#8080800f;border-radius:10px;margin:0 0 8px;flex-shrink:0}.log-analysis__summary-item{display:flex;align-items:center;gap:6px;font-size:12px}.log-analysis__summary-label{color:var(--text-secondary, #888)}.log-analysis__summary-value{color:var(--text-primary, #ccc);font-weight:500;font-family:SF Mono,Fira Code,monospace;font-size:11.5px}.log-analysis__reset-btn{margin-left:auto;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:#8080801a;border-radius:6px;color:var(--text-secondary, #888);cursor:pointer;transition:all .15s ease}.log-analysis__reset-btn:hover{background:#ff6b6b26;color:#ff6b6b}.mode-timeline{position:relative;height:22px;border-radius:6px;overflow:hidden;background:#80808014;margin-bottom:8px;flex-shrink:0}.mode-timeline__segment{position:absolute;top:0;height:100%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3);overflow:hidden;white-space:nowrap;transition:opacity .15s ease}.mode-timeline__segment:hover{opacity:.85}.log-analysis__preset-bar{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px;flex-shrink:0}.log-analysis__preset-btn{padding:4px 12px;font-size:11.5px;font-weight:500;border:1px solid rgba(128,128,128,.2);border-radius:6px;background:transparent;color:var(--text-secondary, #888);cursor:pointer;transition:all .15s ease}.log-analysis__preset-btn:hover:not(:disabled){border-color:var(--accent, #339af0);color:var(--text-primary, #ccc)}.log-analysis__preset-btn--active{background:#339af01f;border-color:var(--accent, #339af0);color:var(--accent, #339af0)}.log-analysis__preset-btn--disabled{opacity:.35;cursor:not-allowed}.log-analysis__charts{display:flex;flex-direction:column;gap:8px;padding-bottom:16px}.ts-chart{border:1px solid rgba(128,128,128,.12);border-radius:10px;background:#80808008;overflow:hidden}.ts-chart__header{display:flex;align-items:center;gap:8px;padding:8px 14px 2px}.ts-chart__title{font-size:12px;font-weight:600;color:var(--text-primary, #ccc)}.ts-chart__unit{font-size:10px;color:var(--text-secondary, #888);opacity:.7}.ts-chart__container{width:100%}.ts-chart .u-legend{font-size:10px!important;padding:2px 14px!important}.ts-chart .u-legend .u-series th{padding:1px 4px!important}.ts-chart .u-legend .u-label{font-size:10px!important}.logs{padding:var(--space-6);height:100%;display:flex;flex-direction:column;overflow:hidden}.logs__header{flex-shrink:0;margin-bottom:var(--space-5)}.logs__title{font-size:var(--text-2xl);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-1)}.logs__subtitle{font-size:var(--text-sm);color:var(--text-secondary)}.logs__tabs{display:flex;gap:var(--space-1);flex-shrink:0;overflow-x:auto;background:var(--bg-tertiary);border-radius:var(--radius-lg);padding:3px;margin-bottom:var(--space-1)}.logs__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}.logs__tab:hover{color:var(--text-primary);background:color-mix(in srgb,var(--accent) 8%,transparent)}.logs__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}.logs__content{flex:1;overflow-y:auto;padding-top:var(--space-5)}.logs__placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);color:var(--text-tertiary);font-size:var(--text-sm);height:300px}.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)}.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-secondary);flex-shrink:0;font-weight:500}.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}.frame-tab{display:flex;flex-direction:column;gap:var(--space-6)}.frame-tab__section{display:flex;flex-direction:column;gap:var(--space-3)}.frame-tab__section-title{font-size:var(--text-lg);font-weight:600;color:var(--text-primary)}.frame-tab__section-desc{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-2)}.frame-tab__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:var(--space-3);max-width:880px}.frame-tab__card{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-4);background:var(--bg-secondary);border:2px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.frame-tab__card:hover:not(:disabled){border-color:var(--border-hover);background:var(--bg-hover);transform:translateY(-2px)}.frame-tab__card--selected{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,var(--bg-secondary));box-shadow:0 0 0 1px var(--accent)}.frame-tab__card--selected:hover:not(:disabled){border-color:var(--accent)}.frame-tab__card:disabled{opacity:.4;cursor:not-allowed}.frame-icon{width:72px;height:72px;color:var(--text-primary)}.frame-tab__card--selected .frame-icon{color:var(--accent)}.frame-tab__card-label{font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.frame-tab__card--selected .frame-tab__card-label{color:var(--accent)}.frame-tab__types{display:flex;gap:var(--space-3);flex-wrap:wrap;max-width:720px}.frame-tab__type{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);background:var(--bg-secondary);border:2px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);min-width:130px}.frame-tab__type:hover:not(:disabled){border-color:var(--border-hover);background:var(--bg-hover)}.frame-tab__type--selected{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,var(--bg-secondary));box-shadow:0 0 0 1px var(--accent)}.frame-tab__type--selected:hover:not(:disabled){border-color:var(--accent)}.frame-tab__type:disabled{opacity:.4;cursor:not-allowed}.frame-tab__type-symbol{font-size:24px;font-weight:800;font-family:var(--font-mono);color:var(--text-tertiary);width:32px;text-align:center}.frame-tab__type--selected .frame-tab__type-symbol{color:var(--accent)}.frame-tab__type-label{font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.frame-tab__hint{font-size:var(--text-sm);color:var(--text-tertiary);font-style:italic}.motor-tab{display:flex;flex-direction:column;gap:var(--space-8);width:920px;max-width:100%}.motor-tab__section{display:flex;flex-direction:column;gap:var(--space-3)}.motor-tab__section-title{font-size:var(--text-lg);font-weight:600;color:var(--text-primary)}.motor-tab__section-desc{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-2)}.motor-tab__timeout-msg{font-size:var(--text-sm);color:#f59e0b;background:#f59e0b14;border:1px solid rgba(245,158,11,.2);border-radius:var(--radius-md);padding:6px 12px;margin-bottom:var(--space-2);animation:motor-fade-in .3s ease}@keyframes motor-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.motor-tab__esc-row{display:flex;align-items:center;gap:var(--space-3)}.motor-tab__esc-select{height:32px;padding:0 var(--space-3);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-primary);cursor:pointer;min-width:100px}.motor-tab__esc-select:disabled{opacity:.4;cursor:not-allowed}.motor-tab__esc-tip{font-size:var(--text-sm);color:var(--text-tertiary);line-height:1.3;text-align:center;white-space:pre-line}.motor-tab__top-row{display:flex;gap:var(--space-4);align-items:stretch;flex-wrap:nowrap}.motor-tab__compact-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);white-space:nowrap}.motor-tab__compact-label{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);white-space:pre-line;text-align:center;line-height:1.3}.motor-tab__passthrough-toggle{padding:var(--space-1) var(--space-3);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-xs);font-weight:600;cursor:pointer;transition:all var(--transition-fast);background:var(--bg-tertiary);color:var(--text-secondary)}.motor-tab__passthrough-toggle:hover{border-color:var(--accent)}.motor-tab__passthrough-toggle--on{background:var(--accent);color:#fff;border-color:var(--accent)}.motor-tab__slide-toggle{position:relative;width:36px;height:20px;border-radius:10px;border:none;background:var(--bg-tertiary);cursor:pointer;transition:background .2s;padding:0;flex-shrink:0}.motor-tab__slide-toggle--on{background:var(--accent)}.motor-tab__slide-toggle-knob{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:transform .2s}.motor-tab__slide-toggle--on .motor-tab__slide-toggle-knob{transform:translate(16px)}.motor-tab__tool-select{height:28px;padding:0 var(--space-2);background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-xs);color:var(--text-secondary);cursor:pointer;max-width:120px;text-overflow:ellipsis}.motor-tab__help-btn{width:22px;height:22px;border-radius:50%;border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-tertiary);font-size:12px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);flex-shrink:0}.motor-tab__help-btn:hover{border-color:var(--accent);color:var(--accent)}.motor-tab__help-wrapper{position:relative;display:flex;align-items:center}.motor-tab__help-tooltip{position:absolute;top:calc(100% + 8px);right:0;min-width:260px;padding:var(--space-3);background:var(--bg-secondary);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 8px 24px #0000001f;z-index:100;font-size:var(--text-xs);color:var(--text-secondary);line-height:1.5}.motor-tab__help-tooltip p{margin:0}.motor-tab__help-tooltip p+p{margin-top:var(--space-1);color:var(--text-tertiary)}.motor-tab__help-tooltip--warning{border-color:#f59e0b;color:var(--text-primary)}.motor-tab__help-warn{color:#ef4444!important}.motor-tab__main-row{display:flex;gap:var(--space-10);align-items:stretch}.motor-tab__servo-section{flex:1;min-width:400px}.motor-tab__servo-table{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;flex:1}.motor-tab__servo-header{display:grid;grid-template-columns:40px 1fr 140px;padding:var(--space-1) var(--space-3);background:var(--bg-tertiary);font-size:var(--text-xs);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;gap:var(--space-2)}.motor-tab__servo-row{display:grid;grid-template-columns:40px 1fr 140px;align-items:center;padding:3px var(--space-3);border-top:1px solid var(--border);gap:var(--space-2)}.motor-tab__servo-row:nth-child(2n){background:color-mix(in srgb,var(--bg-tertiary) 40%,transparent)}.motor-tab__servo-row:hover{background:var(--bg-hover)}.motor-tab__servo-row--disabled{opacity:.45}.motor-tab__servo-row--disabled:hover{opacity:.7}.motor-tab__servo-ch{font-size:var(--text-xs);font-weight:700;color:var(--text-secondary);text-align:center;font-family:var(--font-mono);background:var(--bg-tertiary);width:24px;height:24px;line-height:24px;border-radius:50%;display:inline-block}.motor-tab__servo-bar-wrap{position:relative;height:20px;background:var(--bg-tertiary);border-radius:var(--radius-sm);overflow:hidden}.motor-tab__servo-bar{position:absolute;left:0;top:0;bottom:0;border-radius:var(--radius-sm);transition:width .15s ease,background .3s ease;min-width:0}.motor-tab__servo-pwm{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-size:11px;font-weight:600;font-family:var(--font-mono);color:var(--text-primary);text-shadow:0 0 3px var(--bg-primary)}.motor-tab__servo-select{height:24px;padding:0 var(--space-2);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--text-xs);color:var(--text-primary);cursor:pointer;font-family:var(--font-mono)}.motor-tab__servo-select:disabled{opacity:.4;cursor:not-allowed}.motor-tab__test-section{min-width:200px;display:flex;flex-direction:column}.motor-tab__layout-diagram{display:flex;justify-content:center;padding:var(--space-2);border-radius:var(--radius-md)}.motor-tab__layout-diagram img{width:100%;max-width:220px;height:auto;filter:invert(.88) hue-rotate(180deg)}[data-theme=light] .motor-tab__layout-diagram img{filter:none}.motor-tab__test-card{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-4);background:color-mix(in srgb,var(--bg-secondary) 60%,transparent);border:1px solid var(--border);border-radius:var(--radius-lg);flex:1;transition:border-color .3s ease,box-shadow .3s ease}.motor-tab__test-card--active{border-color:var(--accent);box-shadow:0 0 12px color-mix(in srgb,var(--accent) 15%,transparent)}.motor-tab__test-toggle{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md)}.motor-tab__test-checkbox{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:600;color:var(--text-primary);cursor:pointer}.motor-tab__test-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.motor-tab__test-checkbox input[type=checkbox]:disabled{cursor:not-allowed}.motor-tab__test-toggle--on{border-color:var(--warning);background:color-mix(in srgb,var(--warning) 5%,var(--bg-secondary))}.motor-tab__test-warning{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--warning)}.motor-tab__test-sliders{display:flex;gap:var(--space-2);justify-content:center;padding:var(--space-3);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);transition:opacity var(--transition-fast)}.motor-tab__test-sliders--disabled{opacity:.35;pointer-events:none}.motor-tab__test-slider-col{display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.motor-tab__test-rpm{font-size:10px;font-family:var(--font-mono);color:#22c55e;text-align:center;min-width:32px;line-height:1}.motor-tab__test-val{font-size:11px;font-weight:600;font-family:var(--font-mono);color:var(--accent);min-width:32px;text-align:center}.motor-tab__test-motor-label{font-size:var(--text-xs);font-weight:700;color:var(--text-secondary)}.motor-tab__test-slider-col--all .motor-tab__test-val,.motor-tab__test-slider-col--all .motor-tab__test-motor-label{color:var(--warning)}.motor-tab__vslider--all::-webkit-slider-thumb{background:var(--warning)!important}.motor-tab__test-sliders-divider{width:1px;background:var(--border);align-self:stretch;margin:0 var(--space-1)}.motor-tab__vslider{-webkit-appearance:none;appearance:none;writing-mode:vertical-lr;direction:rtl;width:24px;height:140px;border-radius:12px;outline:none}.motor-tab__vslider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid var(--bg-primary);box-shadow:0 1px 4px #0003}.motor-tab__vslider:disabled::-webkit-slider-thumb{background:var(--text-tertiary);cursor:not-allowed}.motor-tab__wizard-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent) 80%,#000));color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast);align-self:flex-start;animation:wizard-pulse 2.5s ease-in-out infinite}@keyframes wizard-pulse{0%,to{box-shadow:0 0 color-mix(in srgb,var(--accent) 40%,transparent)}50%{box-shadow:0 0 0 6px color-mix(in srgb,var(--accent) 0%,transparent)}}.motor-tab__wizard-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px color-mix(in srgb,var(--accent) 30%,transparent);animation:none}.motor-tab__wizard-panel{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-4);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg)}.motor-tab__wizard-warning{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);text-align:center;padding:var(--space-3)}.motor-tab__wizard-warning h4{font-size:var(--text-base);font-weight:700;color:var(--warning)}.motor-tab__wizard-warning p{font-size:var(--text-sm);color:var(--text-secondary);max-width:360px}.motor-tab__wizard-actions{display:flex;gap:var(--space-3);justify-content:flex-end;flex-wrap:wrap}.motor-tab__btn{padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600;border:none;cursor:pointer;transition:all var(--transition-fast)}.motor-tab__btn--secondary{background:var(--bg-tertiary);color:var(--text-secondary)}.motor-tab__btn--secondary:hover{background:var(--bg-hover);color:var(--text-primary)}.motor-tab__btn--primary{background:var(--accent);color:#fff}.motor-tab__btn--primary:hover{filter:brightness(1.1)}.motor-tab__btn--danger{background:#ef4444;color:#fff}.motor-tab__btn--danger:hover{filter:brightness(1.1)}.motor-tab__wizard-step-info{display:flex;flex-direction:column;gap:var(--space-2)}.motor-tab__wizard-step-info p{font-size:var(--text-sm);color:var(--text-primary)}.motor-tab__wizard-step-badge{display:inline-flex;align-items:center;justify-content:center;padding:2px var(--space-3);background:var(--accent);color:#fff;border-radius:20px;font-size:var(--text-xs);font-weight:700;align-self:flex-start}.motor-tab__spin-btn{padding:var(--space-3) var(--space-5);background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:700;cursor:pointer;transition:all var(--transition-fast)}.motor-tab__spin-btn:hover:not(:disabled){transform:scale(1.02);box-shadow:0 4px 16px #10b9814d}.motor-tab__spin-btn--active{background:linear-gradient(135deg,#f59e0b,#d97706);animation:pulse-glow 1s ease-in-out infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 #f59e0b66}50%{box-shadow:0 0 0 12px #f59e0b00}}.motor-tab__spin-btn:disabled{opacity:.5;cursor:not-allowed}.motor-tab__motor-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:var(--space-2)}.motor-tab__motor-btn{padding:var(--space-2);background:var(--bg-tertiary);border:2px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600;color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast)}.motor-tab__motor-btn:hover:not(:disabled){border-color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,var(--bg-tertiary))}.motor-tab__motor-btn--used{opacity:.3;cursor:not-allowed;text-decoration:line-through}.motor-tab__wizard-result-title{font-size:var(--text-base);font-weight:600;color:var(--text-primary)}.motor-tab__result-table{display:flex;flex-direction:column;gap:var(--space-1)}.motor-tab__result-row{display:grid;grid-template-columns:1fr auto 1fr;gap:var(--space-3);align-items:center;padding:var(--space-1) var(--space-3);background:var(--bg-tertiary);border-radius:var(--radius-sm);font-size:var(--text-sm);font-family:var(--font-mono)}.motor-tab__result-row span:nth-child(2){color:var(--accent);font-weight:700}.motor-tab__hint{font-size:var(--text-sm);color:var(--text-tertiary);font-style:italic}.motor-tab__wizard-panel--safety .motor-tab__wizard-actions{justify-content:center}.motor-tab__wizard-spin-row{display:flex;gap:var(--space-3);align-items:center}.motor-tab__wizard-diagram-hint{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}.motor-tab__wizard-throttle-select{height:32px;padding:0 var(--space-2);background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-primary);cursor:pointer;font-family:var(--font-mono)}.motor-tab__frame-diagram{position:relative;display:flex;justify-content:center;align-items:center;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-3);min-height:200px}.motor-tab__frame-diagram img{width:100%;max-width:300px;height:auto;filter:invert(.88) hue-rotate(180deg);pointer-events:none}.motor-tab__frame-diagram--disabled .motor-tab__frame-hotspot{opacity:.25;animation:none;cursor:not-allowed}[data-theme=light] .motor-tab__frame-diagram img{filter:none}.motor-tab__frame-hotspot{position:absolute;width:48px;height:48px;border-radius:50%;border:3px solid var(--accent);background:color-mix(in srgb,var(--accent) 15%,transparent);cursor:pointer;transform:translate(-50%,-50%);transition:all .2s ease;display:flex;align-items:center;justify-content:center;z-index:2;animation:hotspot-breathe 2s ease-in-out infinite}@keyframes hotspot-breathe{0%,to{box-shadow:0 0 color-mix(in srgb,var(--accent) 30%,transparent)}50%{box-shadow:0 0 0 8px color-mix(in srgb,var(--accent) 0%,transparent)}}.motor-tab__frame-hotspot:hover:not(:disabled){border-color:#fff;background:color-mix(in srgb,var(--accent) 50%,transparent);transform:translate(-50%,-50%) scale(1.15);animation:none;box-shadow:0 0 16px color-mix(in srgb,var(--accent) 40%,transparent)}.motor-tab__frame-hotspot:active:not(:disabled){transform:translate(-50%,-50%) scale(.95)}.motor-tab__frame-hotspot--used{border-color:var(--text-tertiary);background:color-mix(in srgb,var(--text-tertiary) 15%,transparent);opacity:.35;cursor:not-allowed;animation:none}.motor-tab__frame-hotspot-label{font-size:13px;font-weight:700;color:var(--text-primary);pointer-events:none}.motor-tab__esc-direction-grid{display:flex;gap:var(--space-3);flex-wrap:wrap}.motor-tab__esc-direction-item{display:flex;align-items:center;gap:var(--space-2)}.motor-tab__esc-direction-label{font-size:var(--text-sm);font-weight:500;color:var(--text-primary);min-width:60px}.motor-tab__esc-direction-toggle{padding:var(--space-1) var(--space-3);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast);background:var(--bg-tertiary);color:var(--accent)}.motor-tab__esc-direction-toggle:hover{border-color:var(--accent)}.motor-tab__esc-direction-toggle--reversed{background:#ef4444;color:#fff;border-color:#ef4444}.rc-tab{display:flex;flex-direction:column;max-width:1100px;gap:var(--space-6)}.rc-tab__section{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5) var(--space-6);box-shadow:var(--card-shadow),var(--card-inset-highlight)}.rc-tab__section-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);flex-wrap:wrap}.rc-tab__section-title{font-size:var(--text-base);font-weight:600;color:var(--text-primary);margin:0}.rc-tab__rssi{font-size:var(--text-xs);font-family:var(--font-mono);color:var(--text-tertiary);margin-left:auto}.rc-tab__cal-btn{padding:6px 16px;font-size:13px;font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;background:var(--accent);color:#fff}.rc-tab__cal-btn:hover{filter:brightness(1.1)}.rc-tab__cal-btn--finish{background:#22c55e}.rc-tab__cal-btn--cancel{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border)}.rc-tab__cal-btn--cancel:hover{border-color:var(--danger, #ef4444);color:var(--danger, #ef4444)}.rc-tab__cal-hint{font-size:var(--text-sm);color:#f59e0b;background:#f59e0b14;border:1px solid rgba(245,158,11,.2);border-radius:var(--radius-md);padding:8px 12px;margin-bottom:var(--space-3)}.rc-tab__cal-success{font-size:var(--text-sm);color:#22c55e;background:#22c55e14;border:1px solid rgba(34,197,94,.25);border-radius:var(--radius-md);padding:8px 12px;margin-bottom:var(--space-3);animation:rc-fade-in .3s ease}@keyframes rc-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.rc-tab__pitch-reverse{display:flex;align-items:center;gap:var(--space-2);margin-left:auto}.rc-tab__pitch-label{font-size:12px;color:var(--text-secondary);white-space:nowrap}.rc-tab__pitch-toggle{position:relative;width:36px;height:20px;border-radius:10px;border:none;background:var(--bg-tertiary);cursor:pointer;transition:background .2s;padding:0}.rc-tab__pitch-toggle--on{background:var(--accent)}.rc-tab__pitch-toggle-knob{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:transform .2s}.rc-tab__pitch-toggle--on .rc-tab__pitch-toggle-knob{transform:translate(16px)}.rc-tab__help-wrapper{position:relative}.rc-tab__help-btn{width:18px;height:18px;border-radius:50%;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-tertiary);font-size:11px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;padding:0}.rc-tab__help-btn:hover{border-color:var(--accent);color:var(--accent)}.rc-tab__help-tooltip{position:absolute;top:calc(100% + 8px);right:0;width:340px;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px;box-shadow:0 8px 24px #0000001f;z-index:100;animation:rc-fade-in .15s ease}.rc-tab__help-tooltip p{font-size:12px;color:var(--text-secondary);margin:0 0 8px;line-height:1.6}.rc-tab__help-tooltip p:last-child{margin-bottom:0}.rc-tab__rssi-group{display:flex;align-items:center;gap:var(--space-2);margin-left:var(--space-4)}.rc-tab__rssi-value{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent);padding:2px 10px;border-radius:100px;white-space:nowrap}.rc-tab__rssi-select{padding:3px 8px;font-size:12px;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer}.rc-tab__channels-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:repeat(8,auto);grid-auto-flow:column;gap:var(--space-2) var(--space-5)}@media(max-width:700px){.rc-tab__channels-grid{grid-template-columns:1fr}}.rc-tab__channel{display:flex;align-items:center;padding:2px 0;gap:var(--space-2)}.rc-tab__channel-label{font-size:12px;font-weight:600;color:var(--text-tertiary);min-width:36px;font-family:var(--font-mono)}.rc-tab__channel-bar-bg{flex:1;height:16px;background:var(--bg-secondary);border-radius:7px;overflow:visible;border:1px solid var(--border);position:relative}.rc-tab__channel-bar-fill{height:100%;background:linear-gradient(90deg,#22c55e,#4ade80);border-radius:7px;transition:width .08s linear}.rc-tab__channel-bar-fill--cal{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.rc-tab__channel-marker{position:absolute;top:0;bottom:0;width:2px;background:#ef4444;border-radius:1px;z-index:1;transform:translate(-1px)}.rc-tab__channel-value{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--text-primary);min-width:38px;text-align:right}.rc-tab__current-mode-chip{font-size:12px;font-weight:600;color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent);padding:2px 10px;border-radius:100px;font-family:var(--font-mono);letter-spacing:.3px}.rc-tab__fltmode-ch{display:flex;align-items:center;gap:var(--space-2);margin-left:auto}.rc-tab__fltmode-ch-label{font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap}.rc-tab__fltmode-pwm{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--accent);font-weight:600}.rc-tab__select{padding:5px 10px;font-size:13px;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer}.rc-tab__modes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}@media(max-width:800px){.rc-tab__modes-grid{grid-template-columns:repeat(2,1fr)}}.rc-tab__mode-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);transition:all .15s ease}.rc-tab__mode-card--active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 2px 8px #3b82f626}.rc-tab__mode-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2)}.rc-tab__mode-number{font-size:13px;font-weight:600;color:var(--text-primary);padding-left:11px}.rc-tab__mode-range{font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary);padding-right:11px}.rc-tab__mode-select{width:100%}.rc-tab__options-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3)}@media(max-width:700px){.rc-tab__options-grid{grid-template-columns:1fr}}.rc-tab__option-row{display:flex;align-items:center;min-height:40px;gap:var(--space-3);padding:8px 14px;background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border)}.rc-tab__option-label{font-size:13px;font-weight:600;color:var(--text-primary);min-width:40px;font-family:var(--font-mono)}.rc-tab__option-select{flex:1}.port-tab{display:flex;flex-direction:column;max-width:1100px;gap:var(--space-4)}.port-tab__empty{text-align:center;padding:var(--space-8);color:var(--text-tertiary)}.port-tab__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}@media(max-width:850px){.port-tab__grid{grid-template-columns:1fr}}.port-tab__card{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);box-shadow:var(--card-shadow),var(--card-inset-highlight)}.port-tab__card-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-3)}.port-tab__port-name{font-size:14px;font-weight:700;font-family:var(--font-mono);color:var(--text-primary)}.port-tab__port-alias{font-size:12px;color:var(--text-tertiary)}.port-tab__uart-chip{font-size:12px;font-weight:600;color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent);padding:2px 10px;border-radius:100px;font-family:var(--font-mono);letter-spacing:.3px}.port-tab__board-info{display:flex;align-items:center}.port-tab__board-chip{font-size:12px;font-weight:600;color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent);padding:2px 10px;border-radius:100px;font-family:var(--font-mono);letter-spacing:.3px}.port-tab__reboot-hint{font-size:11px;color:#f59e0b;margin-left:auto;white-space:nowrap}.port-tab__card-body{display:flex;gap:var(--space-3);margin-bottom:var(--space-2)}.port-tab__field{flex:1;display:flex;align-items:center;gap:var(--space-2)}.port-tab__field-label{font-size:12px;font-weight:600;color:var(--text-tertiary);white-space:nowrap}.port-tab__select{padding:6px 10px;font-size:13px;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;width:100%}.port-tab__options-section{border-top:1px solid var(--border);margin-top:var(--space-2);padding-top:var(--space-2)}.port-tab__options-toggle{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:4px 0;background:none;border:none;cursor:pointer;font-size:12px;font-weight:600;color:var(--text-secondary)}.port-tab__options-toggle:hover{color:var(--text-primary)}.port-tab__options-value{font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary);background:var(--bg-secondary);padding:1px 6px;border-radius:var(--radius-sm)}.port-tab__chevron{margin-left:auto;font-size:11px;transition:transform .15s ease}.port-tab__chevron--open{transform:rotate(90deg)}.port-tab__bitmask-grid{display:flex;flex-direction:column;gap:2px;margin-top:var(--space-2);padding:var(--space-2) 0}.port-tab__bitmask-item{display:flex;align-items:center;gap:var(--space-2);padding:3px 0;cursor:pointer}.port-tab__bitmask-item input[type=checkbox]{accent-color:var(--accent);width:14px;height:14px;margin:0}.port-tab__bitmask-label{font-size:12px;color:var(--text-secondary);line-height:1.3}.pid-tab{display:flex;flex-direction:column;gap:var(--space-6);padding-bottom:var(--space-8)}.pid-tab__section{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5)}.pid-tab__section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.pid-tab__section-title{font-size:16px;font-weight:700;color:var(--text-primary);margin:0 0 var(--space-4) 0}.pid-tab__section-header .pid-tab__section-title{margin-bottom:0}.pid-tab__reboot-hint{padding:8px 12px;margin-bottom:var(--space-4);background:color-mix(in srgb,var(--warning) 12%,transparent);border:1px solid color-mix(in srgb,var(--warning) 30%,transparent);border-radius:var(--radius-md);color:var(--warning);font-size:12px;font-weight:600;animation:pid-fade-in .2s ease-out}.pid-tab__init-inputs{display:flex;align-items:flex-end;gap:var(--space-4);flex-wrap:wrap;margin-bottom:var(--space-4)}.pid-tab__init-field{display:flex;flex-direction:column;gap:4px}.pid-tab__init-field label{font-size:12px;font-weight:600;color:var(--text-secondary)}.pid-tab__init-field select{height:34px;padding:0 var(--space-3);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);font-size:13px;min-width:140px}.pid-tab__calc-btn{height:34px;padding:0 var(--space-5);background:var(--accent);color:#fff;border:none;border-radius:var(--radius-md);font-size:13px;font-weight:600;cursor:pointer;transition:opacity .15s ease}.pid-tab__calc-btn:hover:not(:disabled){opacity:.85}.pid-tab__calc-btn:disabled{opacity:.4;cursor:not-allowed}.pid-tab__preview{animation:pid-fade-in .2s ease-out}@keyframes pid-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.pid-tab__preview-table{width:100%;border-collapse:collapse;font-size:13px}.pid-tab__preview-table th{text-align:left;font-size:11px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;padding:6px 12px;border-bottom:1px solid var(--border)}.pid-tab__preview-table td{padding:6px 12px;border-bottom:1px solid color-mix(in srgb,var(--border) 50%,transparent)}.pid-tab__param-name{font-family:var(--font-mono);font-weight:600;color:var(--text-primary)}.pid-tab__new-value{font-family:var(--font-mono);font-weight:700;color:var(--accent)}.pid-tab__preview-row--missing{opacity:.35}.pid-tab__preview-actions{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-4)}.pid-tab__write-btn{height:34px;padding:0 var(--space-6);background:var(--success);color:#fff;border:none;border-radius:var(--radius-md);font-size:13px;font-weight:600;cursor:pointer;transition:opacity .15s ease}.pid-tab__write-btn:hover:not(:disabled){opacity:.85}.pid-tab__write-btn:disabled{opacity:.5;cursor:not-allowed}.pid-tab__cancel-btn{height:34px;padding:0 var(--space-5);background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-md);font-size:13px;font-weight:600;cursor:pointer;transition:background .15s ease}.pid-tab__cancel-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.pid-tab__write-msg{font-size:12px;font-weight:600;color:var(--success)}.pid-tab__lock-label{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.pid-tab__lock-label input[type=checkbox]{accent-color:var(--accent)}.pid-tab__advanced-toggle{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:8px 0;margin:var(--space-4) 0;background:none;border:1px dashed var(--border);border-radius:var(--radius-md);color:var(--text-tertiary);font-size:12px;font-weight:600;cursor:pointer;transition:color .15s ease,border-color .15s ease}.pid-tab__advanced-toggle svg{transition:transform .2s ease}.pid-tab__advanced-toggle--open svg{transform:rotate(180deg)}.pid-tab__advanced-toggle:hover{color:var(--accent);border-color:var(--accent)}.pid-tab__groups-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-4)}.pid-tab__group-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);box-shadow:var(--card-shadow),var(--card-inset-highlight)}.pid-tab__group-title{font-size:12px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin:0 0 var(--space-2) 0;padding-bottom:var(--space-2);border-bottom:1px solid var(--border)}.pid-tab__expand-btn{width:100%;padding:2px 0;margin-top:2px;background:none;border:none;border-top:1px dashed var(--border);color:var(--text-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .15s ease}.pid-tab__expand-btn svg{transition:transform .2s ease}.pid-tab__expand-btn--open svg{transform:rotate(180deg)}.pid-tab__expand-btn:hover{color:var(--accent)}.pid-tab__param-row{display:flex;align-items:center;justify-content:space-between;padding:4px 0;gap:var(--space-2)}.pid-tab__param-label{font-size:12px;font-weight:600;color:var(--text-primary);min-width:50px;cursor:help}.pid-tab__param-control{display:flex;align-items:center;gap:0;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.pid-tab__step-btn{width:26px;height:26px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:none;color:var(--text-secondary);font-size:14px;font-weight:700;cursor:pointer;transition:background .1s ease;flex-shrink:0}.pid-tab__step-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.pid-tab__param-input{width:72px;height:26px;text-align:center;border:none;border-left:1px solid var(--border);border-right:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-mono);font-size:12px;font-weight:600;outline:none}.pid-tab__param-input::-webkit-inner-spin-button,.pid-tab__param-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.pid-tab__param-select{height:26px;padding:0 var(--space-2);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);font-size:12px;min-width:120px}.osd{display:flex;gap:var(--space-4);height:100%;overflow:hidden}.osd__empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-tertiary);font-size:var(--text-sm);padding:var(--space-6);text-align:center}.osd__sidebar{width:260px;flex-shrink:0;display:flex;flex-direction:column;gap:var(--space-3);overflow-y:auto;border-right:1px solid var(--border);padding-right:var(--space-4)}.osd__global{display:flex;flex-direction:column;gap:var(--space-2);padding-bottom:var(--space-3);border-bottom:1px solid var(--border)}.osd__global-title{font-size:var(--text-xs);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-1)}.osd__global-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.osd__global-label{font-size:11px;font-family:var(--font-mono);color:var(--text-tertiary);flex-shrink:0}.osd__global-select{padding:2px 6px;font-size:11px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-primary);width:130px;flex-shrink:0}.osd__global-input{width:60px;padding:2px 6px;font-size:11px;font-family:var(--font-mono);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-primary);text-align:center}.osd__global-label--help{display:flex;align-items:center;gap:4px}.osd__global-row--vertical{align-items:flex-start;flex-direction:column}.osd__bitmask-btn{width:130px;height:18px;padding:0 6px;font-size:11px;font-family:var(--font-mono);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-primary);display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:background var(--transition-fast);flex-shrink:0}.osd__bitmask-btn:hover:not(:disabled){background:var(--bg-hover)}.osd__bitmask-btn:disabled{opacity:.5;cursor:not-allowed}.params__bitmask-arrow{font-size:8px;color:var(--text-tertiary)}.osd__bitmask-panel{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--space-2);margin-top:-2px}.params__bitmask-panel{display:flex;flex-direction:column;gap:4px}.params__bitmask-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-secondary);cursor:pointer}.params__bitmask-checkbox{accent-color:var(--accent);cursor:pointer;margin:0}.params__bitmask-bit{font-family:var(--font-mono);color:var(--text-tertiary);font-size:10px;width:32px}.params__bitmask-label{flex:1}.osd__screen-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}.osd__screen-tab{padding:3px 10px;font-size:11px;font-weight:500;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast)}.osd__screen-tab:hover{background:var(--bg-hover)}.osd__screen-tab--active{background:var(--accent);color:#fff;border-color:var(--accent)}.osd__item-panel{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.osd__cat-group{border-radius:var(--radius-sm)}.osd__cat-header{display:flex;align-items:center;width:100%;gap:var(--space-1);padding:4px 6px;font-size:11px;font-weight:600;color:var(--text-secondary);background:color-mix(in srgb,var(--bg-tertiary) 50%,transparent);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.osd__cat-header:hover{background:var(--bg-tertiary)}.osd__cat-arrow{font-size:8px;width:12px;color:var(--text-disabled)}.osd__cat-name{flex:1;text-align:left}.osd__cat-count{font-size:10px;color:var(--text-disabled);font-family:var(--font-mono)}.osd__cat-items{display:flex;flex-direction:column;padding-left:var(--space-1)}.osd__item-row{display:flex;align-items:center;gap:var(--space-1);padding:2px 6px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.osd__item-row:hover{background:color-mix(in srgb,var(--bg-hover) 60%,transparent)}.osd__item-row--selected{background:color-mix(in srgb,var(--accent) 12%,transparent)}.osd__item-checkbox{width:13px;height:13px;flex-shrink:0;accent-color:var(--accent)}.osd__item-label{font-size:11px;color:var(--text-secondary);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:pointer}.osd__item-pos{font-size:9px;font-family:var(--font-mono);color:var(--text-disabled);flex-shrink:0}.osd__main{flex:1;display:flex;flex-direction:column;min-width:0;overflow-y:auto}.osd__grid-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:var(--space-2);gap:var(--space-3);flex-shrink:0}.osd__grid-title{font-size:var(--text-xs);font-weight:500;color:var(--text-tertiary)}.osd__selected-info{display:flex;align-items:center;gap:var(--space-3)}.osd__selected-name{font-size:11px;font-weight:600;color:var(--accent)}.osd__pos-label{display:flex;align-items:center;gap:4px;font-size:11px;font-family:var(--font-mono);color:var(--text-tertiary)}.osd__pos-input{width:45px;padding:1px 4px;font-size:11px;font-family:var(--font-mono);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-primary);text-align:center}.osd__grid{width:100%;position:relative;background-image:url(/configurator/img/osd.jpg);background-color:#111118;background-size:100% 100%;background-position:center;background-repeat:no-repeat;border-radius:var(--radius-md);border:1px solid var(--border);overflow:hidden;-webkit-user-select:none;user-select:none;touch-action:none;aspect-ratio:4 / 3;cursor:crosshair}.osd__grid-canvas{display:block;width:100%;height:100%;image-rendering:pixelated;image-rendering:crisp-edges}.other-tab{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));max-width:900px;gap:var(--space-4)}.other-tab__card{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);box-shadow:var(--card-shadow),var(--card-inset-highlight)}.other-tab__card-title{font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--border)}.other-tab__param-list{display:flex;flex-direction:column;gap:var(--space-3)}.other-tab__param-row{display:flex;align-items:center;gap:var(--space-3)}.other-tab__param-label{flex:1;font-size:var(--text-xs);font-weight:500;color:var(--text-primary);cursor:help;min-width:0;line-height:1.4}.other-tab__param-control{flex-shrink:0;width:200px}.other-tab__select{width:100%;padding:6px 10px;font-size:12px;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:border-color .15s ease}.other-tab__select:hover:not(:disabled){border-color:var(--border-hover)}.other-tab__select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 15%,transparent)}.other-tab__select:disabled{opacity:.4;cursor:not-allowed}.other-tab__input{width:100%;padding:6px 10px;font-size:12px;font-family:var(--font-mono);background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-md);text-align:right;box-sizing:border-box;transition:border-color .15s ease}.other-tab__input:hover:not(:disabled){border-color:var(--border-hover)}.other-tab__input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 15%,transparent)}.other-tab__input:disabled{opacity:.4;cursor:not-allowed}.other-tab__input-wrap{display:flex;align-items:center;gap:4px}.other-tab__input-wrap .other-tab__input{flex:1}.other-tab__input-unit{font-size:10px;font-weight:600;color:var(--text-tertiary);white-space:nowrap;min-width:24px}.other-tab__bitmask-section{padding-top:var(--space-2);border-top:1px dashed var(--border)}.other-tab__bitmask-title{font-size:var(--text-xs);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-2);cursor:help}.other-tab__bitmask-grid{display:flex;flex-direction:column;gap:6px}.other-tab__bitmask-item{display:flex;align-items:flex-start;gap:6px;cursor:pointer}.other-tab__bitmask-item input[type=checkbox]{margin-top:2px;accent-color:var(--accent);cursor:pointer}.other-tab__bitmask-item input[type=checkbox]:disabled{cursor:not-allowed}.other-tab__bitmask-label{font-size:11px;color:var(--text-secondary);line-height:1.4}.other-tab__reboot-hint{font-size:11px;color:#f59e0b;text-align:center;padding:8px 0 2px;animation:other-hint-in .2s ease-out}@keyframes other-hint-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.settings{padding:var(--space-6);height:100%;display:flex;flex-direction:column;overflow:hidden}.settings__header{flex-shrink:0;margin-bottom:var(--space-5)}.settings__title{font-size:var(--text-2xl);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-1)}.settings__subtitle{font-size:var(--text-sm);color:var(--text-secondary)}.settings__tabs{display:flex;gap:var(--space-1);flex-shrink:0;overflow-x:auto;background:var(--bg-tertiary);border-radius:var(--radius-lg);padding:3px;margin-bottom:var(--space-1)}.settings__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}.settings__tab:hover{color:var(--text-primary);background:color-mix(in srgb,var(--accent) 8%,transparent)}.settings__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}.settings__content{flex:1;overflow-y:auto;padding-top:var(--space-5)}.settings__placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);color:var(--text-tertiary);font-size:var(--text-sm);height:300px}.accel-cal-inline{margin-top:var(--space-3);padding:var(--space-3);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);animation:accelCalFadeIn .2s ease-out}@keyframes accelCalFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.accel-cal-inline__header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);font-size:var(--text-sm)}.accel-cal-inline__progress{font-family:var(--font-mono);color:var(--text-tertiary);flex-shrink:0}.accel-cal-inline__progress-done{color:var(--accent);font-weight:700}.accel-cal-inline__status{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.accel-cal-inline__status--running{color:#eab308}.accel-cal-inline__status--success{color:#22c55e}.accel-cal-inline__status--failed{color:#ef4444}.accel-cal-inline__close{flex-shrink:0;padding:4px 12px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-secondary);font-size:var(--text-xs);cursor:pointer;transition:all var(--transition-fast)}.accel-cal-inline__close:hover{background:var(--bg-primary);color:var(--text-primary)}.accel-cal-inline__grid{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--space-2);overflow:hidden}@media(max-width:640px){.accel-cal-inline__grid{grid-template-columns:repeat(3,1fr)}}.accel-cal-inline__face{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:var(--space-2);border-radius:var(--radius-md);border:1.5px solid var(--border);background:var(--bg-primary);aspect-ratio:1;min-width:0;overflow:hidden;transition:all .3s ease}.accel-cal-inline__face--waiting{opacity:.45}.accel-cal-inline__face--active{border-color:#eab308;background:color-mix(in srgb,#eab308 8%,var(--bg-primary));opacity:1;box-shadow:0 0 12px color-mix(in srgb,#eab308 12%,transparent);animation:accelCalGlow 2s ease-in-out infinite}@keyframes accelCalGlow{0%,to{box-shadow:0 0 8px color-mix(in srgb,#eab308 8%,transparent)}50%{box-shadow:0 0 18px color-mix(in srgb,#eab308 20%,transparent)}}.accel-cal-inline__face--done{border-color:#22c55e;background:color-mix(in srgb,#22c55e 6%,var(--bg-primary));opacity:1}.accel-cal-inline__face-name{font-size:10px;font-weight:600;color:var(--text-tertiary);text-align:center}.accel-cal-inline__face--active .accel-cal-inline__face-name{color:#eab308}.accel-cal-inline__face--done .accel-cal-inline__face-name{color:#22c55e}.accel-cal-inline__check{position:absolute;top:2px;right:4px;color:#22c55e;font-weight:700;font-size:11px}.accel-cal-inline__pulse{position:absolute;top:3px;right:5px;color:#eab308;font-size:10px;animation:accelCalPulse 1s ease-in-out infinite}@keyframes accelCalPulse{0%,to{opacity:1}50%{opacity:.3}}.accel-cal-inline__confirm{margin-top:var(--space-3);display:flex;justify-content:center}.accel-cal-inline__confirm-btn{padding:8px 32px;border-radius:var(--radius-md);border:none;background:#eab308;color:#000;font-weight:700;font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);animation:accelCalPulse 2s ease-in-out infinite}.accel-cal-inline__confirm-btn:hover{background:#facc15;transform:scale(1.05);animation:none}.accel-cal-inline__confirm-btn:active{transform:scale(.98)}.imu-tab{display:flex;flex-direction:column;gap:var(--space-4)}.imu-subtabs{display:flex;gap:var(--space-1);align-items:center;justify-content:space-between;gap:var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--border)}.imu-subtabs__tabs{display:flex;gap:var(--space-2)}.imu-subtab{padding:6px 16px;font-size:13px;color:var(--text-secondary);background:transparent;border:none;border-radius:var(--radius-full);cursor:pointer;transition:all .15s ease}.imu-subtab:hover{color:var(--text-primary)}.imu-subtab--active{color:var(--accent);background:var(--bg-secondary);box-shadow:0 1px 3px #00000014;font-weight:600}.imu-subtabs__orient{display:flex;align-items:center;gap:var(--space-2);margin-left:auto}.imu-subtabs__orient-label{font-size:12px;color:var(--text-secondary);white-space:nowrap}.imu-subtabs__orient-select{padding:3px 8px;font-size:11px;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer}.imu-subtabs__orient-select:disabled{opacity:.5;cursor:not-allowed}.imu-panel{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}@media(max-width:900px){.imu-panel{grid-template-columns:1fr}}.imu-section{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--card-shadow),var(--card-inset-highlight)}.imu-section__header{display:flex;align-items:baseline;gap:var(--space-2);margin-bottom:var(--space-3)}.imu-section__title{font-size:var(--text-base);font-weight:600;color:var(--text-primary)}.imu-section__unit{font-size:var(--text-xs);color:var(--text-tertiary);font-family:var(--font-mono);margin-left:auto}.imu-section__chip{font-size:11px;font-weight:600;color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent);padding:1px 8px;border-radius:100px;font-family:var(--font-mono);letter-spacing:.3px}.imu-data-row{display:flex;gap:var(--space-3);margin-bottom:var(--space-3)}.imu-data-item{flex:1;padding:var(--space-2) var(--space-3);background:var(--bg-secondary);border-radius:var(--radius-md);border-left:3px solid transparent;display:flex;align-items:center;gap:var(--space-2)}.imu-data-item__label{font-size:var(--text-xs);font-weight:600;color:var(--text-tertiary);min-width:14px}.imu-data-item__value{font-family:var(--font-mono);font-size:var(--text-base);font-weight:600;color:var(--text-primary)}.imu-waveform{width:100%;border-radius:var(--radius-md);background:var(--bg-secondary);border:1px solid var(--border)}.imu-calibration{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--card-shadow),var(--card-inset-highlight)}.imu-calibration__header{margin-bottom:var(--space-3);display:flex;align-items:center;gap:var(--space-3)}.imu-calibration__title{font-size:var(--text-base);font-weight:600;color:var(--text-primary);margin:0}.imu-calibration__warn{font-size:var(--text-xs);font-weight:600;padding:2px 10px;border-radius:100px;animation:calMsgFade .3s ease-out}.imu-calibration__warn--red{color:#ef4444;background:color-mix(in srgb,#ef4444 12%,var(--bg-secondary))}.imu-calibration__warn--yellow{color:#eab308;background:color-mix(in srgb,#eab308 12%,var(--bg-secondary))}.imu-calibration__actions{display:flex;gap:var(--space-3)}.imu-cal-btn{padding:8px 20px;font-size:13px;font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.imu-cal-btn:disabled{opacity:.4;cursor:not-allowed}.imu-cal-btn--accel{background:var(--accent);color:#fff}.imu-cal-btn--accel:not(:disabled):hover{filter:brightness(1.1)}.imu-cal-btn--level{background:var(--accent);color:#fff}.imu-cal-btn--level:not(:disabled):hover{filter:brightness(1.1)}.imu-cal-btn--reboot{background:var(--warning-dim, rgba(245, 158, 11, .1));color:var(--warning, #f59e0b);border:1px solid var(--warning, #f59e0b)}.imu-cal-btn--reboot:not(:disabled):hover{background:var(--warning, #f59e0b);color:#fff}.imu-calibration__msg{margin-top:var(--space-2);padding:6px 12px;font-size:var(--text-sm);border-radius:var(--radius-md);animation:calMsgFade .2s ease-out}@keyframes calMsgFade{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.imu-calibration__msg--running{color:#eab308;background:color-mix(in srgb,#eab308 8%,var(--bg-secondary))}.imu-calibration__msg--success{color:#22c55e;background:color-mix(in srgb,#22c55e 8%,var(--bg-secondary))}.imu-calibration__msg--failed{color:#ef4444;background:color-mix(in srgb,#ef4444 8%,var(--bg-secondary))}.compass-tab{display:flex;flex-direction:column;gap:var(--space-4)}.compass-tab__no-sensor{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:color-mix(in srgb,var(--warning) 8%,transparent);border:1px solid color-mix(in srgb,var(--warning) 30%,transparent);border-radius:var(--radius-lg);color:var(--warning)}.compass-tab__no-sensor svg{flex-shrink:0;opacity:.6}.compass-tab__no-sensor-text{display:flex;flex-direction:column;gap:2px}.compass-tab__no-sensor-text strong{font-size:14px;color:var(--warning)}.compass-tab__no-sensor-text span{font-size:12px;color:var(--text-secondary)}.compass-subtabs{display:flex;gap:var(--space-2);padding-bottom:var(--space-2);border-bottom:1px solid var(--border)}.compass-subtab{padding:6px 16px;font-size:13px;color:var(--text-secondary);background:transparent;border:none;border-radius:var(--radius-full);cursor:pointer;transition:all .15s ease}.compass-subtab:hover{color:var(--text-primary)}.compass-subtab--active{color:var(--accent);background:var(--bg-secondary);box-shadow:0 1px 3px #00000014;font-weight:600}.compass-panel--disabled .compass-data-row,.compass-panel--disabled .compass-waveform{opacity:.4}.compass-section{background:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--space-4);border:1px solid var(--border);box-shadow:var(--card-shadow),var(--card-inset-highlight)}.compass-section__header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3)}.compass-section__title{font-size:14px;font-weight:700;color:var(--text-primary)}.compass-section__chip{font-size:11px;font-weight:600;color:var(--accent);background:var(--accent-dim);padding:2px 8px;border-radius:var(--radius-full)}.compass-section__chip--internal{color:#6366f1;background:#6366f11f}.compass-section__chip--external{color:#22c55e;background:#22c55e1f}.compass-section__unit{font-size:11px;color:var(--text-tertiary);margin-left:auto}.compass-section__orient-select{padding:3px 8px;font-size:11px;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer}.compass-section__orient-select:disabled{opacity:.5;cursor:not-allowed}.compass-section__use-label{font-size:12px;color:var(--text-secondary);margin-left:4px}.compass-data-row{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2);margin-bottom:var(--space-3)}.compass-data-item{display:flex;align-items:center;gap:var(--space-2);padding:6px 10px;background:var(--bg-secondary);border-radius:var(--radius-md);border-left:3px solid}.compass-data-item__label{font-size:11px;font-weight:600;color:var(--text-tertiary)}.compass-data-item__value{font-family:var(--font-mono);font-size:14px;font-weight:600;color:var(--text-primary)}.compass-waveform{width:100%;border-radius:var(--radius-md);background:var(--bg-secondary)}.compass-toggle{position:relative;display:inline-flex;width:36px;height:20px;cursor:pointer;flex-shrink:0}.compass-toggle input{opacity:0;width:0;height:0}.compass-toggle__slider{position:absolute;inset:0;background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;transition:all .2s ease}.compass-toggle__slider:before{content:"";position:absolute;width:14px;height:14px;left:2px;top:2px;background:var(--text-secondary);border-radius:50%;transition:all .2s ease}.compass-toggle input:checked+.compass-toggle__slider{background:var(--accent);border-color:var(--accent)}.compass-toggle input:checked+.compass-toggle__slider:before{transform:translate(16px);background:#fff}.compass-toggle input:disabled+.compass-toggle__slider{opacity:.5;cursor:not-allowed}.compass-controls{background:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--space-4);border:1px solid var(--border);box-shadow:var(--card-shadow),var(--card-inset-highlight)}.compass-controls__title{font-size:14px;font-weight:700;color:var(--text-primary);margin:0 0 var(--space-3) 0}.compass-controls__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--space-3)}.compass-controls__card{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:12px 16px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md)}.compass-controls__card-label{font-size:13px;color:var(--text-primary);font-weight:500}.compass-calibration{background:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--space-4);border:1px solid var(--border);box-shadow:var(--card-shadow),var(--card-inset-highlight)}.compass-calibration__header{margin-bottom:var(--space-3);display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-3)}.compass-calibration__title{font-size:var(--text-base);font-weight:600;color:var(--text-primary);margin:0}.compass-calibration__magfield-group{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2) var(--space-4);margin-bottom:var(--space-3)}.compass-calibration__magfield{display:flex;align-items:center;gap:var(--space-2)}.compass-calibration__magfield-label{font-size:13px;color:var(--text-secondary);font-weight:500}.compass-calibration__magfield-value{font-family:var(--font-mono);font-size:14px;font-weight:700}.compass-calibration__magfield-value--green{color:#22c55e}.compass-calibration__magfield-value--yellow{color:#eab308}.compass-calibration__magfield-value--red{color:#ef4444}.compass-calibration__magfield-warn{font-size:12px;color:#eab308;font-weight:500}.compass-calibration__toolbar{display:flex;align-items:center;gap:var(--space-4);flex-wrap:wrap}.compass-calibration__fitness{display:flex;align-items:center;gap:var(--space-2)}.compass-calibration__fitness-label{font-size:13px;color:var(--text-secondary);white-space:nowrap}.compass-calibration__fitness-select{padding:6px 10px;font-size:13px;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer}.compass-calibration__btns{display:flex;gap:var(--space-2);margin-left:auto}.compass-cal-btn{padding:8px 20px;font-size:13px;font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.compass-cal-btn:disabled{opacity:.4;cursor:not-allowed}.compass-cal-btn--start{background:var(--accent);color:#fff}.compass-cal-btn--start:hover:not(:disabled){filter:brightness(1.1)}.compass-cal-btn--cancel{background:var(--danger-dim);color:var(--danger);border:1px solid var(--danger)}.compass-cal-btn--cancel:hover:not(:disabled){background:var(--danger);color:#fff}.compass-cal-progress{margin-top:var(--space-4);animation:compass-fade-in .3s ease}@keyframes compass-fade-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.compass-cal-progress__hint{font-size:13px;color:var(--accent);margin:0 0 var(--space-3) 0;font-weight:500}.compass-cal-progress__bars{display:flex;flex-direction:column;gap:var(--space-2)}.compass-cal-progress__item{display:flex;align-items:center;gap:var(--space-3)}.compass-cal-progress__label{font-size:12px;font-weight:600;color:var(--text-secondary);min-width:80px}.compass-cal-progress__track{flex:1;height:8px;background:var(--bg-secondary);border-radius:4px;overflow:hidden}.compass-cal-progress__fill{height:100%;background:linear-gradient(90deg,var(--accent),#22c55e);border-radius:4px;transition:width .3s ease}.compass-cal-progress__pct{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--text-primary);min-width:36px;text-align:right}.compass-cal-progress__warn{margin-top:var(--space-3);padding:10px 14px;background:#f59e0b14;border:1px solid rgba(245,158,11,.3);border-radius:var(--radius-md)}.compass-cal-progress__warn-title{font-size:13px;font-weight:600;color:#f59e0b;margin:0 0 6px}.compass-cal-progress__warn-list{margin:0;padding-left:20px;font-size:12px;color:var(--text-secondary);line-height:1.6}.compass-cal-progress__warn-extra{margin:6px 0 0;font-size:12px;color:var(--text-tertiary)}.compass-cal-result{margin-top:var(--space-4);padding:var(--space-3);border-radius:var(--radius-md);animation:compass-fade-in .3s ease}.compass-cal-result--success{background:var(--success-dim);border:1px solid var(--success)}.compass-cal-result--failed{background:var(--danger-dim);border:1px solid var(--danger)}.compass-cal-result__title{font-size:14px;font-weight:700;margin:0 0 var(--space-2) 0}.compass-cal-result--success .compass-cal-result__title{color:var(--success)}.compass-cal-result--failed .compass-cal-result__title{color:var(--danger)}.compass-cal-result__item{display:flex;align-items:center;gap:var(--space-3);font-size:13px;color:var(--text-primary);padding:4px 0}.compass-cal-result__status--ok{color:var(--success);font-weight:700}.compass-cal-result__status--fail{color:var(--danger);font-weight:700}.compass-cal-result__detail{padding:8px 0;border-bottom:1px solid rgba(128,128,128,.15)}.compass-cal-result__detail:last-of-type{border-bottom:none}.compass-cal-result__data{display:flex;flex-wrap:wrap;gap:var(--space-2) var(--space-4);margin-top:4px;font-family:var(--font-mono);font-size:12px;color:var(--text-secondary)}.compass-cal-result__reboot{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid rgba(128,128,128,.2)}.compass-cal-result__reboot-hint{font-size:13px;color:var(--warning, #f59e0b);font-weight:500}.compass-cal-btn--reboot{background:var(--warning-dim, rgba(245, 158, 11, .1));color:var(--warning, #f59e0b);border:1px solid var(--warning, #f59e0b)}.compass-cal-btn--reboot:hover:not(:disabled){background:var(--warning, #f59e0b);color:#fff}.gps-tab{display:flex;flex-direction:column;gap:var(--space-4)}.gps-status-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.gps-status-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);box-shadow:var(--card-shadow),var(--card-inset-highlight);display:flex;flex-direction:column;gap:2px}.gps-status-card__label{font-size:var(--text-xs);color:var(--text-secondary);font-weight:500}.gps-status-card__value{font-family:var(--font-mono);font-size:var(--text-lg);font-weight:700;color:var(--text-primary);line-height:1.2}.gps-fix-badge{display:inline-flex;align-items:center;gap:6px;padding:2px 10px;border-radius:100px;font-size:13px;font-weight:700;font-family:var(--font-mono)}.gps-fix-badge--nofix{color:#ef4444;background:color-mix(in srgb,#ef4444 12%,var(--bg-secondary))}.gps-fix-badge--2d{color:#f59e0b;background:color-mix(in srgb,#f59e0b 12%,var(--bg-secondary))}.gps-fix-badge--3d{color:#22c55e;background:color-mix(in srgb,#22c55e 12%,var(--bg-secondary))}.gps-fix-badge--rtk{color:#3b82f6;background:color-mix(in srgb,#3b82f6 12%,var(--bg-secondary))}.gps-fix-badge__dot{width:8px;height:8px;border-radius:50%;background:currentColor}.gps-main-row{display:grid;grid-template-columns:240px 1fr 1fr;gap:var(--space-4);align-items:stretch}@media(max-width:960px){.gps-main-row{grid-template-columns:1fr}}.gps-left-col{display:flex;flex-direction:column;gap:var(--space-4)}.gps-visual-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--card-shadow),var(--card-inset-highlight)}.gps-visual-card__title{font-size:var(--text-base);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-3)}.gps-dop-row{display:flex;gap:var(--space-4)}.gps-dop-gauge{flex:1;display:flex;flex-direction:column;gap:var(--space-1)}.gps-dop-gauge__header{display:flex;justify-content:space-between;align-items:baseline}.gps-dop-gauge__label{font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.gps-dop-gauge__quality{font-size:var(--text-xs);font-weight:600}.gps-dop-gauge__bar-bg{height:8px;border-radius:100px;background:var(--bg-secondary);overflow:hidden}.gps-dop-gauge__bar-fill{height:100%;border-radius:100px;transition:width .3s ease,background .3s ease}.gps-dop-gauge__value{font-family:var(--font-mono);font-size:var(--text-xl);font-weight:700;text-align:center;margin-top:var(--space-1)}.gps-trend-canvas{width:100%;height:120px;display:block}.gps-left-card{display:flex;flex-direction:column}.gps-left-card .gps-trend-canvas{height:120px}.gps-scatter-card{display:flex;flex-direction:column;padding:var(--space-3) var(--space-4) var(--space-4)}.gps-scatter-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-2)}.gps-scatter-header .gps-visual-card__title{margin-bottom:0}.gps-scatter-controls{display:flex;align-items:center;gap:var(--space-2)}.gps-scatter-control{display:flex;align-items:center;gap:4px;font-size:var(--text-xs);color:var(--text-secondary);cursor:pointer}.gps-scatter-control input[type=range]{width:60px;height:4px;accent-color:#22c55e}.gps-scatter-select{font-size:var(--text-xs);padding:2px 4px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);font-family:var(--font-mono);cursor:pointer}.gps-scatter-control__val{font-family:var(--font-mono);font-size:10px;min-width:28px}.gps-scatter-btn{width:28px;height:28px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-secondary);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.gps-scatter-btn:hover{background:var(--bg-tertiary, var(--bg-secondary));color:var(--text-primary)}.gps-scatter-btn--active{background:color-mix(in srgb,#3b82f6 20%,var(--bg-secondary));color:#3b82f6;border-color:#3b82f6}.gps-scatter-btn--danger:hover{background:color-mix(in srgb,#ef4444 15%,var(--bg-secondary));color:#ef4444;border-color:#ef4444}.gps-scatter-info{font-size:var(--text-xs);color:var(--text-secondary);padding:var(--space-1) 0;font-family:var(--font-mono)}.gps-scatter-wrap{position:relative;flex:1;min-height:270px;overflow:hidden;border-radius:var(--radius-md)}.gps-scatter-wrap canvas{position:absolute;inset:0;display:block;-webkit-user-select:none;user-select:none}.gps-position-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-3)}.gps-position-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--bg-secondary);border-radius:var(--radius-md)}.gps-position-item__label{font-size:var(--text-xs);color:var(--text-secondary);min-width:56px;font-weight:500}.gps-position-item__value{font-family:var(--font-mono);font-size:var(--text-base);font-weight:600;color:var(--text-primary)}.gps-param-panel{display:flex;flex-direction:column;padding-bottom:0}.gps-param-row{display:flex;align-items:center;padding:7px var(--space-3);border-bottom:1px solid color-mix(in srgb,var(--border-color) 40%,transparent);transition:background .15s}.gps-param-row:hover{background:color-mix(in srgb,var(--bg-secondary) 60%,transparent)}.gps-param-row:last-child{border-bottom:none}.gps-param-row__label{flex:1;font-size:var(--text-xs);font-weight:500;color:var(--text-primary);cursor:help;min-width:0;line-height:1.4}.gps-param-row__control{display:flex;align-items:center;gap:4px;flex-shrink:0;width:96px;justify-content:flex-end}.gps-param-row__select,.gps-param-row__input{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--text-xs);padding:5px 8px;width:100%;box-sizing:border-box;transition:border-color .15s}.gps-param-row__select:focus,.gps-param-row__input:focus{outline:none;border-color:var(--color-primary, #3b82f6)}.gps-param-row__input{font-family:var(--font-mono);text-align:right}.gps-param-row__input:disabled,.gps-param-row__select:disabled{opacity:.4;cursor:not-allowed}.gps-param-row__control--has-unit .gps-param-row__input{width:calc(100% - 22px)}.gps-param-reboot-hint{font-size:11px;color:#f59e0b;text-align:center;padding:6px var(--space-3);animation:gps-hint-in .2s ease-out}@keyframes gps-hint-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.gps-param-row__unit{font-size:10px;color:var(--text-tertiary);width:18px;flex-shrink:0;text-align:left}.gps-param-toggle{position:relative;display:inline-block;width:36px;height:20px;flex-shrink:0}.gps-param-toggle input{opacity:0;width:0;height:0}.gps-param-toggle__slider{position:absolute;cursor:pointer;inset:0;background:var(--bg-tertiary);border-radius:20px;transition:background .2s}.gps-param-toggle__slider:before{content:"";position:absolute;width:14px;height:14px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:transform .2s}.gps-param-toggle input:checked+.gps-param-toggle__slider{background:var(--color-primary, #3b82f6)}.gps-param-toggle input:checked+.gps-param-toggle__slider:before{transform:translate(16px)}.gps-param-toggle input:disabled+.gps-param-toggle__slider{opacity:.4;cursor:not-allowed}.gps-param-tabs{display:flex;gap:0;margin:var(--space-2) var(--space-3);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-color)}.gps-param-tab{flex:1;padding:5px 0;font-size:var(--text-xs);font-weight:600;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s}.gps-param-tab--active{background:var(--color-primary, #3b82f6);color:#fff}.gps-param-tab:not(.gps-param-tab--active):hover{background:var(--bg-secondary)}.gps-param-list{display:flex;flex-direction:column}.hwid-tab{display:flex;flex-direction:column;gap:var(--space-4);max-width:900px}.hwid-tab__header{margin-bottom:var(--space-1)}.hwid-tab__title{font-size:16px;font-weight:700;color:var(--text-primary);margin:0}.hwid-tab__subtitle{font-size:12px;color:var(--text-tertiary);margin:4px 0 0}.hwid-tab__empty{text-align:center;padding:var(--space-8);color:var(--text-tertiary);font-size:13px}.hwid-tab__grid{display:flex;flex-direction:column;gap:var(--space-4)}.hwid-tab__category{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--card-shadow),var(--card-inset-highlight)}.hwid-tab__category-header{display:flex;align-items:center;gap:var(--space-2);padding:10px var(--space-4);background:var(--bg-secondary);border-bottom:1px solid var(--border)}.hwid-tab__category-label{font-size:13px;font-weight:700;color:var(--text-primary);letter-spacing:.02em}.hwid-tab__category-count{font-size:10px;font-weight:700;color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent);padding:2px 8px;border-radius:var(--radius-full);line-height:1;margin-left:auto}.hwid-tab__sensor-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1px;background:var(--border)}.hwid-tab__sensor-card{padding:var(--space-3) var(--space-4);background:var(--bg-primary);transition:background .15s ease}.hwid-tab__sensor-card:hover{background:var(--bg-secondary)}.hwid-tab__sensor-name{font-size:11px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.hwid-tab__sensor-model{display:inline-block;font-size:13px;font-weight:700;color:var(--accent);font-family:var(--font-mono);background:color-mix(in srgb,var(--accent) 10%,transparent);padding:2px 10px;border-radius:var(--radius-full);margin-bottom:8px}.hwid-tab__sensor-details{display:flex;flex-direction:column;gap:4px}.hwid-tab__detail{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.hwid-tab__detail-label{font-size:11px;color:var(--text-tertiary);font-weight:500}.hwid-tab__detail-value{font-size:11px;font-weight:600;color:var(--text-secondary)}.hwid-tab__detail-value--mono{font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary)}.optflow-tab{display:flex;flex-direction:column;gap:var(--space-4)}.optflow-main-row{display:flex;gap:var(--space-4);align-items:stretch}.optflow-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--card-shadow),var(--card-inset-highlight)}.optflow-card__title{font-size:var(--text-base);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-3);display:flex;align-items:center;gap:var(--space-3)}.optflow-quality-badge{font-size:11px;font-weight:600;color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent);padding:1px 8px;border-radius:100px;font-family:var(--font-mono)}.optflow-quality-badge strong{color:var(--accent);font-weight:600}.optflow-param-panel{width:280px;min-width:280px;flex-shrink:0}.optflow-param-list{display:flex;flex-direction:column;gap:var(--space-3)}.optflow-param-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.optflow-param-row__label{font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap}.optflow-param-row__select{width:140px;padding:3px 8px;font-size:11px;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-md);outline:none;cursor:pointer}.optflow-param-row__input{width:140px;padding:3px 8px;font-size:11px;font-family:var(--font-mono);background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-md);outline:none;box-sizing:border-box}.optflow-param-row__control{display:flex;align-items:center;gap:4px}.optflow-param-row__unit{font-size:10px;color:var(--text-tertiary)}.optflow-reboot-hint{margin-top:var(--space-3);padding:6px 12px;font-size:var(--text-xs);color:#eab308;background:color-mix(in srgb,#eab308 8%,var(--bg-secondary));border-radius:var(--radius-md);text-align:center}.optflow-wave-card{flex:1;min-width:0;display:flex;flex-direction:column}.optflow-wave-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-2)}.optflow-wave-legend{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.optflow-legend-item{display:flex;align-items:center;gap:4px;cursor:pointer;font-size:11px;color:var(--text-secondary);-webkit-user-select:none;user-select:none}.optflow-legend-item input[type=checkbox]{width:12px;height:12px;margin:0;accent-color:var(--accent)}.optflow-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.optflow-legend-label{font-family:var(--font-mono);font-size:10px}.optflow-wave-canvas{width:100%;flex:1;min-height:200px;display:block;border-radius:var(--radius-md);background:var(--bg-secondary);border:1px solid var(--border)}.rngfnd-tab{display:flex;flex-direction:column;gap:var(--space-4)}.rngfnd-sub-tabs{display:flex;gap:2px;background:var(--bg-tertiary);border-radius:var(--radius-md);padding:3px;width:fit-content}.rngfnd-sub-tab{padding:4px 10px;font-size:11px;font-weight:500;color:var(--text-tertiary);background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-mono)}.rngfnd-sub-tab:hover{color:var(--text-primary);background:var(--bg-hover)}.rngfnd-sub-tab--active{color:var(--accent);background:var(--bg-secondary);box-shadow:0 1px 3px #00000014;font-weight:600}.rngfnd-main-row{display:flex;gap:var(--space-4);align-items:stretch}.rngfnd-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--card-shadow),var(--card-inset-highlight)}.rngfnd-card__title{font-size:var(--text-base);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-3);display:flex;align-items:center;gap:var(--space-3)}.rngfnd-badge{font-size:11px;font-weight:600;color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent);padding:1px 8px;border-radius:100px;font-family:var(--font-mono)}.rngfnd-badge strong{color:var(--accent);font-weight:600}.rngfnd-param-panel{width:280px;min-width:280px;flex-shrink:0}.rngfnd-param-list{display:flex;flex-direction:column;gap:var(--space-3)}.rngfnd-param-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.rngfnd-param-row__label{font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap}.rngfnd-param-row__select{width:100%;padding:3px 8px;font-size:11px;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-md);outline:none;cursor:pointer}.rngfnd-param-row__input{width:100%;padding:3px 8px;font-size:11px;font-family:var(--font-mono);background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-md);outline:none;box-sizing:border-box}.rngfnd-param-row__control{display:flex;align-items:center;gap:4px;width:140px;flex-shrink:0}.rngfnd-param-row__unit{font-size:10px;color:var(--text-tertiary)}.rngfnd-reboot-hint{margin-top:var(--space-3);padding:6px 12px;font-size:var(--text-xs);color:#eab308;background:color-mix(in srgb,#eab308 8%,var(--bg-secondary));border-radius:var(--radius-md);text-align:center}.rngfnd-wave-card{flex:1;min-width:0;display:flex;flex-direction:column}.rngfnd-wave-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-2)}.rngfnd-wave-canvas{width:100%;flex:1;min-height:200px;display:block;border-radius:var(--radius-md);background:var(--bg-secondary);border:1px solid var(--border)}.sensors{padding:var(--space-6);height:100%;display:flex;flex-direction:column;overflow:hidden}.sensors__header{flex-shrink:0;margin-bottom:var(--space-5)}.sensors__title{font-size:var(--text-2xl);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-1)}.sensors__subtitle{font-size:var(--text-sm);color:var(--text-secondary)}.sensors__tabs{display:flex;gap:var(--space-1);flex-shrink:0;overflow-x:auto;background:var(--bg-tertiary);border-radius:var(--radius-lg);padding:3px;margin-bottom:var(--space-1)}.sensors__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}.sensors__tab:hover{color:var(--text-primary);background:color-mix(in srgb,var(--accent) 8%,transparent)}.sensors__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}.sensors__content{flex:1;overflow-y:auto;padding-top:var(--space-5)}.sensors__placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);color:var(--text-tertiary);font-size:var(--text-sm);height:300px}.charts{display:flex;flex-direction:column;height:100%;padding:var(--space-5);animation:fadeIn .25s ease-out;overflow:hidden}.charts__header{margin-bottom:var(--space-4);flex-shrink:0}.charts__title{font-size:var(--text-2xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-1)}.charts__subtitle{font-size:var(--text-sm);color:var(--text-secondary)}.charts__body{display:flex;gap:var(--space-4);flex:1;min-height:0}.charts__panel{width:200px;flex-shrink:0;background:color-mix(in srgb,var(--bg-secondary) 60%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius-lg);display:flex;flex-direction:column;overflow:hidden}.charts__panel-header{padding:var(--space-3);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.charts__panel-title{font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.charts__panel-body{flex:1;overflow-y:auto;padding:var(--space-2)}.charts__group{margin-bottom:var(--space-2)}.charts__group-title{font-size:10px;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;padding:var(--space-1) var(--space-2);cursor:pointer;display:flex;align-items:center;gap:var(--space-1);-webkit-user-select:none;user-select:none}.charts__group-title:hover{color:var(--text-secondary)}.charts__group-arrow{font-size:8px;transition:transform .15s ease}.charts__group-arrow--open{transform:rotate(90deg)}.charts__group-items{display:flex;flex-direction:column;gap:1px;padding-left:var(--space-2)}.charts__source-item{display:flex;align-items:center;gap:var(--space-2);padding:3px var(--space-2);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-xs);color:var(--text-secondary);transition:background .1s}.charts__source-item:hover{background:var(--bg-hover)}.charts__source-cb{width:12px;height:12px;border-radius:3px;border:1.5px solid var(--border-hover);flex-shrink:0;transition:all .15s}.charts__source-cb--active{border-color:transparent}.charts__source-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.charts__source-val{font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary);min-width:35px;text-align:right}.charts__main{flex:1;display:flex;flex-direction:column;min-width:0;gap:var(--space-3)}.charts__toolbar{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.charts__toolbar-group{display:flex;align-items:center;gap:var(--space-1);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:2px}.charts__toolbar-btn{padding:var(--space-1) var(--space-2);border:none;background:transparent;color:var(--text-secondary);font-size:var(--text-xs);font-weight:500;border-radius:var(--radius-sm);cursor:pointer;transition:all .1s}.charts__toolbar-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.charts__toolbar-btn--active{background:var(--accent);color:#fff}.charts__toolbar-btn--icon{display:flex;align-items:center;justify-content:center;padding:var(--space-1);width:28px;height:28px}.charts__toolbar-hint{font-size:10px;color:var(--text-disabled);margin-left:var(--space-1);white-space:nowrap}.charts__toolbar-spacer{flex:1}.charts__toolbar-status{font-size:var(--text-xs);color:var(--text-tertiary);font-family:var(--font-mono)}.charts__canvas-wrap{flex:1;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;position:relative;min-height:200px}.charts__canvas{width:100%;height:100%;display:block}.charts__empty{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);color:var(--text-disabled);font-size:var(--text-sm)}.charts__empty svg{opacity:.3}.charts__legend{display:flex;flex-wrap:wrap;gap:var(--space-2) var(--space-4);flex-shrink:0;padding:var(--space-1) 0}.charts__legend-item{display:flex;align-items:center;gap:var(--space-1);font-size:var(--text-xs);color:var(--text-secondary)}.charts__legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.charts__legend-val{font-family:var(--font-mono);font-weight:600;min-width:40px}.firmware-page{padding:var(--space-6);height:100%;display:flex;flex-direction:column;overflow-y:auto;animation:fadeIn .25s ease-out}.firmware-page__header{flex-shrink:0;margin-bottom:var(--space-5)}.firmware-page__title{font-size:var(--text-2xl);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-1)}.firmware-page__subtitle{font-size:var(--text-sm);color:var(--text-secondary)}.firmware-page__tabs{display:flex;gap:var(--space-1);flex-shrink:0;background:var(--bg-tertiary);border-radius:var(--radius-lg);padding:3px;margin-bottom:var(--space-1)}.firmware-page__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}.firmware-page__tab:hover{color:var(--text-primary);background:color-mix(in srgb,var(--accent) 8%,transparent)}.firmware-page__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}.firmware-page__content{flex:1;overflow-y:auto;padding-top:var(--space-5)}.online-tab{display:grid;grid-template-columns:2fr 1fr;gap:var(--space-5);max-width:1000px}.online-tab__vehicles{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3)}.online-tab__vehicle-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:var(--space-4) var(--space-3);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.online-tab__vehicle-btn:hover:not(:disabled){border-color:var(--border-hover);background:color-mix(in srgb,var(--accent) 5%,var(--bg-secondary))}.online-tab__vehicle-btn--active{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,var(--bg-secondary));box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 20%,transparent)}.online-tab__vehicle-btn:disabled{opacity:.4;cursor:not-allowed}.online-tab__select{padding:4px 8px;font-size:12px;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:border-color .15s ease}.online-tab__select:hover:not(:disabled){border-color:var(--border-hover)}.online-tab__select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 15%,transparent)}.online-tab__select:disabled{opacity:.4;cursor:not-allowed}.fw-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);box-shadow:var(--card-shadow),var(--card-inset-highlight)}.fw-card__title{font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:var(--space-2)}.online-tab__vehicle-label{font-size:14px;font-weight:600;color:var(--text-primary)}.online-tab__vehicle-img{width:96px;height:96px;object-fit:contain}.fw-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-8) var(--space-6);border:2px dashed var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);color:var(--text-tertiary);background:var(--bg-secondary);grid-column:1 / -1}.fw-dropzone:hover,.fw-dropzone--active{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 5%,var(--bg-secondary));color:var(--text-primary)}.fw-dropzone:hover svg,.fw-dropzone--active svg{color:var(--accent)}.fw-dropzone svg{opacity:.4;transition:all var(--transition-fast)}.fw-dropzone__title{font-size:var(--text-base);font-weight:600;margin:0}.fw-dropzone__hint{font-size:var(--text-xs);opacity:.6;margin:0}.fw-info__list{display:flex;flex-direction:column;gap:var(--space-3)}.fw-info__row{display:flex;align-items:center;gap:var(--space-3)}.fw-info__label{flex:1;font-size:var(--text-xs);font-weight:500;color:var(--text-secondary);min-width:0}.fw-info__value{font-size:var(--text-xs);font-weight:600;color:var(--text-primary)}.fw-info__value--ok{color:#51cf66}.fw-info__value--warn{color:#fcc419}.fw-actions{display:flex;gap:var(--space-3);padding-top:var(--space-3);border-top:1px dashed var(--border);margin-top:var(--space-1)}.fw-btn{padding:var(--space-2) var(--space-5);font-size:var(--text-sm);font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;gap:var(--space-2)}.fw-btn--primary{background:var(--accent);color:#fff;box-shadow:0 2px 8px color-mix(in srgb,var(--accent) 30%,transparent)}.fw-btn--primary:hover:not(:disabled){opacity:.9;transform:translateY(-1px);box-shadow:0 4px 12px color-mix(in srgb,var(--accent) 40%,transparent)}.fw-btn--primary:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}.fw-btn--secondary{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border)}.fw-btn--secondary:hover{border-color:var(--border-hover);color:var(--text-primary)}.fw-progress__phase{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-2)}.fw-progress__bar{height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden;margin-bottom:var(--space-1)}.fw-progress__fill{height:100%;border-radius:3px;transition:width .2s ease;background:var(--accent)}.fw-progress__fill--error{background:var(--danger, #ff6b6b)}.fw-progress__fill--done{background:#51cf66}.fw-log{max-height:220px;overflow-y:auto;padding:var(--space-3) var(--space-4);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:10.5px;line-height:1.7;color:var(--text-secondary);grid-column:1 / -1}.fw-log__line{margin:0;white-space:pre-wrap;word-break:break-all}.fw-log__line--error{color:var(--danger, #ff6b6b)}.fw-log__line--success{color:#51cf66}.fw-status-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;font-size:10px;font-weight:600;border-radius:var(--radius-full, 999px);letter-spacing:.3px}.fw-status-badge--flashing{background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent)}.fw-status-badge--done{background:color-mix(in srgb,#51cf66 12%,transparent);color:#51cf66}.fw-status-badge--error{background:color-mix(in srgb,#ff6b6b 12%,transparent);color:#ff6b6b}.fw-pulse{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--accent);animation:fw-pulse 1.2s ease-in-out infinite}@keyframes fw-pulse{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}.hardware{display:flex;flex-direction:column;height:100%;overflow:hidden}.hardware__header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border);flex-shrink:0}.hardware__title{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin:0 0 2px}.hardware__subtitle{font-size:var(--text-xs);color:var(--text-tertiary);margin:0}.hardware__content{flex:1;overflow-y:auto;padding:var(--space-4) var(--space-5);display:flex;flex-direction:column;gap:var(--space-5)}.hardware__section-title{font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin:0 0 var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--border)}.hardware__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--space-4)}.hardware__product{display:flex;flex-direction:column;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:all .2s ease;text-decoration:none;box-shadow:var(--card-shadow),var(--card-inset-highlight)}.hardware__product:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 6px 20px #0000001a,0 0 0 1px color-mix(in srgb,var(--accent) 30%,transparent)}.hardware__product-img-wrap{aspect-ratio:4 / 3;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);overflow:hidden}.hardware__product-img{width:100%;height:100%;object-fit:contain;padding:var(--space-3);transition:transform .3s ease}.hardware__product:hover .hardware__product-img{transform:scale(1.05)}.hardware__product-placeholder{color:var(--text-disabled);opacity:.4}.hardware__product-info{padding:var(--space-3) var(--space-3);display:flex;flex-direction:column;gap:2px;border-top:1px solid var(--border)}.hardware__product-name{font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.hardware__product-link{font-size:11px;color:var(--accent);font-weight:500;opacity:.7;transition:opacity .15s ease}.hardware__product:hover .hardware__product-link{opacity:1}.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}
