:root{--color-text: #1c1c1e;--color-heading: #111827;--color-muted: #64748b;--color-subtle: #94a3b8;--color-page: #f2f2f7;--color-surface: #ffffff;--color-surface-muted: #f8fafc;--color-surface-soft: #f1f5f9;--color-border: #e2e8f0;--color-border-strong: #cbd5e1;--color-brand: #fcca59;--color-brand-strong: #b68b31;--color-success: #22c55e;--color-success-strong: #10b981;--color-video-bg: #020617;--color-video-panel: #111827;--color-video-text: #d1fae5;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 22px;--radius-pill: 999px;--shadow-soft: 0 1px 8px rgb(15 23 42 / 5%);--shadow-control: 0 8px 24px rgb(15 23 42 / 10%);--shadow-panel: 0 18px 40px rgb(15 23 42 / 32%);--shadow-panel-strong: 0 22px 48px rgb(15 23 42 / 38%);--z-nav: 20;--z-viewer-hud: 36;--z-pip: 100;--z-status: 140}*{box-sizing:border-box}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--color-text);background:var(--color-page)}button,input,select{font:inherit}button{border:0;cursor:pointer}button:disabled,.disabled{cursor:not-allowed;opacity:.52}.appShell{min-height:100vh}.navBar{position:sticky;top:0;z-index:var(--z-nav);display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:var(--space-5);padding:var(--space-3) var(--space-5);border-bottom:1px solid var(--color-border);background:#ffffffdb;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:var(--shadow-soft)}.brand,.accountButton,.tabs,.tabButton,.titleCluster,.pageActions,.missionItem,.deviceTop{display:flex;align-items:center}.brand{gap:10px;font-weight:800;color:var(--color-heading)}.brandMark,.avatar{display:grid;place-items:center;width:36px;height:36px;border-radius:var(--radius-md);background:linear-gradient(135deg,#fcca59,#fb923c);color:var(--color-surface);box-shadow:0 2px 8px #0000001f}.tabs{gap:4px;padding:4px;border-radius:var(--radius-lg);background:var(--color-surface-soft);box-shadow:inset 0 1px 2px #0f172a0d}.tabButton{gap:8px;padding:10px 22px;border-radius:var(--radius-md);background:transparent;color:var(--color-muted);font-weight:650;transition:.18s ease}.tabButton.active{background:var(--color-surface);color:var(--color-heading);box-shadow:0 1px 6px #0f172a14}.tabButton.active svg{color:var(--color-brand-strong)}.accountButton{justify-self:end;gap:10px;padding:4px 14px 4px 4px;border:1px solid transparent;border-radius:var(--radius-pill);background:var(--color-surface);color:var(--color-heading)}.accountButton strong,.accountButton small{display:block;text-align:left}.accountButton small{display:flex;gap:4px;align-items:center;color:var(--color-muted)}.page{min-height:calc(100vh - 74px)}.homeGrid{--workspace-status-height: 44px;--workspace-status-gap: 12px;--workspace-outer-pad: 16px;--viewer-hud-pad-x: 24px;--viewer-hud-pad-y: 16px;position:relative;display:grid;grid-template-columns:minmax(0,1fr);grid-template-rows:minmax(0,1fr);gap:0;height:calc(100vh - 74px);overflow:hidden;padding:var(--workspace-outer-pad);box-sizing:border-box}.mainVision,.card,.deviceCard,.mapCard,.placeholderCard,.missionItem{border:1px solid #e2e8f0;background:#fff;box-shadow:0 1px 4px #0f172a0a}.mainVision{position:relative;overflow:hidden;border-radius:18px}.homeWorkspace{overflow:hidden;background:#f8fafc}.operationWorkspaceStage{min-height:0}.workspaceMainLayer{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;min-width:0;min-height:0}.card{display:grid;gap:16px;padding:22px;border-radius:28px}.cardHeader{display:flex;justify-content:space-between;gap:12px}.titleCluster{min-width:0;gap:10px}.titleCluster h2,.deviceCard h2,.mapCard h2,.missionItem h2,.placeholderCard h2{margin:0;color:#0f172a;font-size:18px}.titleCluster p,.deviceCard p,.mapCard p,.missionItem p,.placeholderCard p{margin:3px 0 0;color:#64748b;font-size:13px}.statusPill{align-self:flex-start;padding:5px 11px;border-radius:999px;background:#f1f5f9;color:#64748b;font-size:12px;font-weight:800}.statusPill.online{background:#dcfce7;color:#15803d}.metricGrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.metric{display:grid;grid-template-columns:auto 1fr;gap:2px 8px;align-items:center;padding:12px;border-radius:18px;background:#f8fafc}.metric svg{grid-row:span 2}.metric span{color:#64748b;font-size:11px;font-weight:800;text-transform:uppercase}.metric strong{font-size:14px}.metric.compact{display:block}.green{color:#22c55e}.yellowText{color:#b68b31}.editorToolbar select,.editorToolbar input{min-height:38px;border:1px solid #e2e8f0;border-radius:13px;background:#fff;color:#334155;padding:0 12px}.primaryButton,.ghostButton,.roundPlay{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;border-radius:13px;font-weight:750}.primaryButton{background:#fcca59;color:#1f2937}.ghostButton{background:#f8fafc;color:#64748b;padding:0 16px}.sectionTitle{margin:0;color:#64748b;font-size:13px;font-weight:800;letter-spacing:.05em;text-transform:uppercase}.mapLayerSwitch,.mapToolSwitch{display:flex;gap:4px;padding:0}.mapControlGroup{display:flex;gap:4px;justify-items:start;align-items:flex-start;padding:4px;border:1px solid rgb(226 232 240 / 80%);border-radius:14px;background:#ffffffe0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 22px #0f172a1a}.controlGroupHeader{display:inline-flex;flex:0 0 auto;gap:6px;align-items:center;justify-content:center;height:32px;min-height:32px;padding:0 10px;border:0;border-radius:10px;background:transparent;color:#475569;font-size:12px;font-weight:850;line-height:1;white-space:nowrap}.controlGroupHeader svg,.mapLayerSwitch button svg,.mapToolSwitch button svg,.viewerTtsQuick button svg{flex:0 0 auto;width:15px;height:15px;vertical-align:middle}.controlGroupHeader span,.mapLayerSwitch button span,.mapToolSwitch button span,.viewerTtsQuick button span,.viewerActionDock button span{display:inline-flex;align-items:center;min-height:1em;line-height:1}.controlGroupHeader[aria-expanded=true] svg:last-child{transform:rotate(180deg)}.mapLayerSwitch button,.mapToolSwitch button{display:inline-flex;flex:0 0 auto;gap:6px;align-items:center;justify-content:center;min-width:48px;height:32px;min-height:32px;padding:0 10px;border-radius:10px;background:transparent;color:#64748b;font-size:12px;font-weight:850;line-height:1;white-space:nowrap}.mapLayerSwitch button.active,.mapLayerSwitch button.recording,.mapToolSwitch button.active{background:#111827;color:#fff}.mapLayerSwitch button.recording{background:#dc2626}.mapToolSwitch button:disabled{opacity:.45;text-decoration:none}.broadcastList{display:grid;gap:0;min-width:0;max-width:100%}.broadcastListHeader{position:sticky;top:0;z-index:8;display:flex;align-items:center;justify-content:space-between;gap:8px;margin:0;padding:10px 14px 9px;border-bottom:1px solid #e2e8f0;background:#fffffff5;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.broadcastListTitle{margin:0;color:#0f172a;font-size:14px;font-weight:700}.broadcastInstant{position:sticky;top:42px;z-index:7;display:grid;grid-template-columns:minmax(0,1fr) 34px;gap:8px;align-items:stretch;padding:9px 10px 10px;border-bottom:1px solid #e2e8f0;background:#fffffff0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.broadcastInstantInput{width:100%;min-width:0;min-height:34px;max-height:92px;box-sizing:border-box;resize:vertical;padding:8px 10px;border:1px solid #e2e8f0;border-radius:10px;background:#f8fafc;color:#0f172a;font:inherit;font-size:13px;line-height:1.35;outline:none}.broadcastInstantInput:focus{border-color:#94a3b8;background:#fff}.broadcastListStack{display:grid;gap:8px;padding:10px}.broadcastCard{display:grid;gap:8px;min-width:0;max-width:100%;padding:10px;border:1px solid #e2e8f0;border-radius:16px;background:#fff;overflow:hidden;box-sizing:border-box}.broadcastCard.dragging{opacity:.72;box-shadow:0 10px 24px #0f172a1a}.broadcastCardHeader{display:flex;flex-wrap:wrap;align-items:center;gap:6px 8px;min-width:0}.broadcastCardGrip{display:grid;width:24px;height:24px;place-items:center;border:none;border-radius:8px;background:#f8fafc;color:#94a3b8;cursor:grab;touch-action:none}.broadcastCardGrip:active{cursor:grabbing}.broadcastCardTitle{margin:0;flex:1 1 8rem;min-width:0;color:#0f172a;font-size:14px;font-weight:700;overflow-wrap:anywhere;word-break:break-word}.broadcastCardActions{display:flex;flex:0 1 auto;flex-wrap:wrap;justify-content:flex-end;gap:6px;margin-left:auto;max-width:100%}.broadcastCardAction{display:inline-flex;align-items:center;justify-content:center;gap:4px;padding:4px 10px;border:1px solid #e2e8f0;border-radius:999px;background:#fff;color:#475569;font-size:12px;cursor:pointer}.broadcastCardAction.primary{border-color:#0f172a;background:#0f172a;color:#fff}.broadcastCardAction.primary:disabled{border-color:#cbd5e1;background:#e2e8f0;color:#94a3b8;cursor:not-allowed}.broadcastCardAction.danger{border-color:#fecaca;color:#b91c1c}.broadcastCardAction:disabled{opacity:.45;cursor:not-allowed}.broadcastIconAction{display:inline-grid;flex:0 0 30px;width:30px;height:30px;place-items:center;padding:0;border:1px solid #e2e8f0;border-radius:10px;background:#fff;color:#475569;cursor:pointer}.broadcastIconAction.primary{border-color:#0f172a;background:#0f172a;color:#fff}.broadcastIconAction.danger{border-color:#fecaca;color:#b91c1c}.broadcastIconAction:not(:disabled):hover{background:#f8fafc;color:#0f172a}.broadcastIconAction.primary:not(:disabled):hover{border-color:#1e293b;background:#1e293b;color:#fff}.broadcastIconAction.danger:not(:disabled):hover{background:#fef2f2;color:#991b1b}.broadcastIconAction:disabled{opacity:.45;cursor:not-allowed}.broadcastCardBody{display:grid;gap:6px;min-width:0}.broadcastCardContent{width:100%;min-width:0;max-width:100%;box-sizing:border-box;padding:9px 12px;border:1px solid #e2e8f0;border-radius:10px;background:#f8fafc;color:#334155;font-size:14px;line-height:1.5;overflow-wrap:anywhere;word-break:break-word}.broadcastCardText{display:inline;white-space:pre-wrap;overflow-wrap:anywhere;word-break:break-word}.broadcastCardSlot{display:inline-block;vertical-align:baseline;min-width:3.5rem;max-width:min(100%,64ch);width:auto;margin:1px 4px 1px 0;box-sizing:border-box;padding:4px 9px;border-radius:8px;background:#fff;color:#0f172a;font-size:13px;outline:none}.broadcastCardSlot.filled{border:1px solid #cbd5e1}.broadcastCardSlot.empty{border:1px dashed #cbd5e1;color:#94a3b8}.broadcastAddInline{display:grid;gap:8px;min-width:0;padding:0 10px 2px}.broadcastAddInline.open{padding:10px;border:1px dashed #cbd5e1;border-radius:16px;background:#ffffffe5}.broadcastAddBar{display:flex;width:100%;min-height:40px;align-items:center;justify-content:center;gap:8px;border:1px dashed #cbd5e1;border-radius:12px;background:#f8fafcdb;color:#475569;font-size:14px;font-weight:850}.broadcastAddBar:hover{border-color:#94a3b8;background:#f1f5f9;color:#0f172a}.broadcastAddName{width:100%;min-width:0;min-height:36px;box-sizing:border-box;padding:0 10px;border:1px solid #e2e8f0;border-radius:12px;background:#f8fafc;color:#0f172a;font:inherit;font-size:14px;font-weight:800}.broadcastAddActions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.broadcastInlinePreview{display:grid;gap:4px;min-width:0;padding:8px 10px;border:1px solid #e2e8f0;border-radius:12px;background:#f8fafc}.broadcastInlinePreview span{color:#64748b;font-size:12px;font-weight:800}.broadcastInlinePreviewContent{margin:0;color:#0f172a;font-size:14px;line-height:1.45;overflow-wrap:anywhere;word-break:break-word}.broadcastPreviewSlot{display:inline-flex;vertical-align:baseline;align-items:center;max-width:min(100%,64ch);margin:1px 4px 1px 0;padding:3px 9px;border:1px dashed #cbd5e1;border-radius:8px;background:#fff;color:#64748b;font-size:13px;font-weight:700;line-height:1.25;overflow-wrap:anywhere}.broadcastInlinePreviewEmpty{color:#94a3b8;font-size:13px}.speechTemplateComposerWrap{display:grid;gap:8px;min-width:0}.speechTemplateComposer{min-height:120px;max-width:100%;padding:12px 14px;border:1px solid #cbd5e1;border-radius:12px;background:#fff;color:#0f172a;font-size:14px;line-height:1.65;overflow-wrap:anywhere;word-break:break-word;outline:none}.speechTemplateComposer:empty:before,.speechTemplateComposer[data-show-placeholder=true]:before{content:attr(data-placeholder);color:#94a3b8;pointer-events:none}.speechTemplateComposer:focus{border-color:#64748b;box-shadow:0 0 0 2px #64748b1f}.speechTemplateComposerHint{margin:0;color:#94a3b8;font-size:11px}.speechTemplateSlotRow{display:flex;justify-content:flex-end}.speechTemplateSlotAddBtn{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border:1px solid #e2e8f0;border-radius:999px;background:#fff;color:#334155;font-size:12px;cursor:pointer}.speechTemplateSlotAddBtn:disabled{opacity:.5;cursor:not-allowed}.speechTemplateSlotChip{display:inline-flex;align-items:center;gap:2px;max-width:min(100%,70ch);margin:0 4px 2px 0;padding:2px 6px 2px 2px;border:1px dashed #94a3b8;border-radius:8px;background:#f8fafc;vertical-align:baseline;-webkit-user-select:none;user-select:none}.speechTemplateSlotChip.selected{border-color:#0f172a;background:#e2e8f0}.speechTemplateSlotChip.drop-target{outline:2px solid #fbbf24}.speechTemplateSlotChip.dragging{opacity:.45;pointer-events:none}.speechTemplateSlotChipGrip{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:4px;background:transparent;color:#94a3b8;font-size:10px;line-height:1;cursor:grab;touch-action:none}.speechTemplateSlotChipGrip:active{cursor:grabbing;background:#e2e8f0}.speechTemplateSlotChipLabel{color:#475569;font-size:12px;white-space:nowrap}.speechTemplateSlotChipInput{min-width:4ch;max-width:min(64ch,100%);padding:2px 4px;border:0;border-radius:6px;background:transparent;color:#475569;font:inherit;font-size:12px;font-weight:800;outline:none}.speechTemplateSlotChipInput::placeholder{color:#94a3b8;font-weight:800}.speechTemplateSlotChipInput:focus{background:#fff;box-shadow:inset 0 0 0 1px #cbd5e1}.videoSim{position:relative;display:grid;width:100%;height:100%;min-height:180px;place-items:center;overflow:hidden;background:radial-gradient(circle at 45% 45%,rgb(16 185 129 / 18%),transparent 24%),linear-gradient(135deg,var(--color-video-panel),var(--color-video-bg));color:var(--color-video-text);font-family:JetBrains Mono,ui-monospace,monospace}.videoPlayer{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;width:100%;height:100%;place-items:center}.videoPlayer>div,.videoPlayer video{width:100%!important;height:100%!important}.videoPlayer video{object-fit:contain!important;background:var(--color-video-bg)}.videoSim.main{min-height:100%}.scanLines{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.22;background-image:repeating-linear-gradient(transparent,transparent 2px,black 2px,black 4px);pointer-events:none}.videoHud{position:absolute;top:16px;left:16px;display:flex;gap:10px;font-size:12px}.videoSim.main .videoHud{top:48px}.videoHud span{display:inline-flex;gap:5px;align-items:center;padding:5px 8px;border-radius:var(--radius-sm);background:#0000006b}.videoPreviewGate{position:absolute;top:0;right:0;bottom:0;left:0;z-index:4;display:grid;place-items:center;align-content:center;gap:10px;padding:20px;background:#020617bd;color:var(--color-surface);text-align:center}.videoPreviewGate p{margin:0;color:var(--color-video-text);font-size:13px;font-weight:800}.videoPreviewGate button{min-height:34px;padding:0 14px;border-radius:var(--radius-pill);background:#34d399;color:#052e16;font-size:12px;font-weight:900;box-shadow:0 10px 26px #10b98147}.crosshair{width:52px;height:52px;border:1px solid rgb(52 211 153 / 60%);border-radius:var(--radius-pill);box-shadow:inset 0 0 0 24px transparent}.viewerHud{position:absolute;top:0;right:0;bottom:0;left:0;z-index:var(--z-viewer-hud);pointer-events:none}.viewerHud button{pointer-events:auto}.viewerInfoHud,.viewerOperationHud{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.viewerOperationHud .mapControlGroup,.viewerActionDock,.viewerTtsDock,.viewerCommandBusy{border:1px solid rgb(226 232 240 / 72%);background:#ffffffd6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-control);pointer-events:auto}.viewerStatusLayer{position:absolute;top:var(--workspace-outer-pad, 16px);right:calc(var(--workspace-outer-pad, 16px) + var(--viewer-hud-pad-x, 24px));left:calc(var(--workspace-outer-pad, 16px) + var(--viewer-hud-pad-x, 24px));z-index:var(--z-status);min-height:var(--workspace-status-height, 40px);pointer-events:none}.viewerStatusBar{position:relative;display:flex;width:100%;max-width:100%;gap:22px;align-items:center;justify-content:space-between;overflow:visible;min-height:var(--workspace-status-height, 40px);padding:0;border:0;border-radius:0;background:transparent;color:var(--viewer-status-fg, var(--color-heading));-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:none;pointer-events:auto}.viewerStatusLeft,.viewerStatusCenter,.viewerStatusRight{display:flex;gap:12px;align-items:center;min-width:0}.viewerStatusLeft{flex:1 1 0;justify-content:flex-start;overflow:visible}.viewerStatusCenter{flex:0 1 auto;justify-content:center;max-width:min(520px,42vw);overflow:hidden}.viewerStatusRight{flex:1 1 0;justify-content:flex-end}.viewerStatusItem{display:inline-flex;flex:0 0 auto;gap:7px;align-items:center;min-height:32px;padding:0;border-radius:0;background:transparent;color:var(--viewer-status-fg, var(--color-heading));font-size:14px;font-weight:850;text-shadow:var(--viewer-status-shadow, none);white-space:nowrap}.viewerStatusMenu{position:relative;flex:0 1 auto;min-width:0}.viewerStatusMenuButton{display:inline-flex;flex:0 1 auto;gap:7px;align-items:center;justify-content:center;min-width:0;min-height:32px;padding:0;border-radius:0;background:transparent;color:var(--viewer-status-fg, var(--color-heading));font-size:14px;font-weight:850;line-height:1;text-shadow:var(--viewer-status-shadow, none);white-space:nowrap}.viewerStatusMenuButton svg{flex:0 0 auto}.viewerStatusMenuButton span{overflow:hidden;text-overflow:ellipsis}.viewerStatusMenuButton[aria-expanded=true] svg:last-child{transform:rotate(180deg)}.viewerStatusMenuPanel{position:absolute;top:calc(100% + 8px);left:0;z-index:70;display:grid;min-width:max(140px,100%);max-width:min(260px,calc(100vw - 48px));max-height:min(320px,calc(100vh - 160px));overflow:auto;padding:6px;border:1px solid rgb(226 232 240 / 72%);border-radius:14px;background:#ffffffeb;box-shadow:0 18px 42px #0f172a3d;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.viewerStatusMenuPanel button{display:inline-flex;gap:10px;align-items:center;justify-content:space-between;min-width:0;min-height:34px;padding:0 10px;border:0;border-radius:10px;background:transparent;color:#334155;font-size:12px;font-weight:800;text-align:left;white-space:nowrap}.viewerStatusMenuPanel button span{overflow:hidden;text-overflow:ellipsis}.viewerStatusMenuPanel button:hover,.viewerStatusMenuPanel button.selected{background:#f1f5f9;color:#0f172a}.viewerStatusMenu.strong,.viewerStatusItem.strong{background:transparent;color:var(--viewer-status-strong-fg, #0f172a)}.viewerStatusItem.active{color:var(--viewer-status-active-fg, #15803d)}.viewerVideoStatusItem{overflow:hidden;text-overflow:ellipsis}.statusThemeLight{--viewer-status-fg: #475569;--viewer-status-strong-fg: #0f172a;--viewer-status-active-fg: #15803d;--viewer-status-shadow: 0 1px 1px rgb(255 255 255 / 85%)}.statusThemeDark{--viewer-status-fg: rgb(226 232 240 / 94%);--viewer-status-strong-fg: white;--viewer-status-active-fg: rgb(220 252 231 / 96%);--viewer-status-shadow: 0 1px 2px rgb(0 0 0 / 70%)}.viewerSidePanel{position:absolute;top:calc(var(--viewer-hud-pad-y, 16px) + var(--workspace-status-height, 40px) + var(--workspace-status-gap, 12px));left:var(--viewer-hud-pad-x, 24px);z-index:34;display:flex;flex-direction:column;gap:8px;width:min(360px,calc(100% - (var(--viewer-hud-pad-x, 24px) * 2)));min-height:0;max-height:calc(100% - 230px);padding:10px 12px;border:1px solid rgb(226 232 240 / 62%);border-radius:16px;background:#ffffff94;color:#0f172a;box-shadow:0 16px 36px #0f172a1f;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);pointer-events:auto}.viewerSidePanel:has(.viewerMapInfoPanel.collapsed):has(.viewerLogPanel.collapsed){width:max-content;max-width:min(180px,calc(100% - (var(--viewer-hud-pad-x, 24px) * 2)));padding:8px 10px;gap:2px}.viewerMapInfoPanel,.viewerLogPanel{overflow:hidden;padding:0;border:0;border-radius:0;background:transparent;color:#0f172a;box-shadow:none;pointer-events:auto}.viewerMapInfoPanel{flex:0 0 auto}.viewerLogPanel{flex:1 1 auto;min-height:0}.viewerMapInfoPanel.collapsed,.viewerLogPanel.collapsed{flex:0 0 auto;min-height:0}.viewerMapInfoHeader,.viewerLogHeader{display:flex;width:100%;align-items:center;justify-content:flex-start;gap:5px;height:24px;padding:0;border-radius:10px;background:transparent;color:#334155;font-size:12px;font-weight:900}.viewerMapInfoPanel dl{display:grid;gap:8px;margin:10px 0 0}.viewerMapInfoPanel div{display:grid;grid-template-columns:minmax(76px,.85fr) minmax(0,1.15fr);gap:10px}.viewerMapInfoPanel dt,.viewerMapInfoPanel dd{min-width:0;margin:0;overflow:hidden;color:#64748b;font-size:12px;font-weight:850;line-height:1.35;text-overflow:ellipsis;white-space:nowrap}.viewerMapInfoPanel dd{color:#0f172a;font-weight:900}.viewerLogList{display:grid;gap:7px;max-height:min(300px,calc(100vh - 360px));margin-top:8px;overflow:auto;padding-right:2px;scrollbar-width:thin}.viewerLogItem,.viewerLogEmpty{overflow:hidden;padding:8px 10px;border:1px solid rgb(226 232 240 / 52%);border-radius:10px;background:#ffffff7a;color:#1e293b;font-size:12px;font-weight:750;line-height:1.35;text-overflow:ellipsis}.viewerLogEmpty{color:#64748b}.statusThemeDark .viewerSidePanel{border-color:#94a3b83d;background:#0f172a6b;color:#fff;box-shadow:0 16px 38px #0000003d}.statusThemeDark .viewerMapInfoHeader,.statusThemeDark .viewerLogHeader{color:#e2e8f0eb}.statusThemeDark .viewerMapInfoPanel dt{color:#cbd5e1c2}.statusThemeDark .viewerMapInfoPanel dd{color:#f8fafcf0}.statusThemeDark .viewerLogItem,.statusThemeDark .viewerLogEmpty{border-color:#94a3b82e;background:#0f172a57;color:#f1f5f9eb}.viewerOperationHud .mapControlGroup{gap:8px;padding:4px;border-radius:18px}.viewerOperationHud .controlGroupHeader,.viewerHudGroupHeader{height:42px;min-height:42px;padding:0 14px;border-radius:13px;background:#111827;color:#fff;font-size:14px;font-weight:850;box-shadow:0 8px 18px #0f172a2e;pointer-events:auto}.viewerOperationHud .mapLayerSwitch,.viewerOperationHud .mapToolSwitch{gap:6px}.viewerOperationHud .mapLayerSwitch button,.viewerOperationHud .mapToolSwitch button,.viewerActionDock button,.viewerTtsQuick button{min-width:54px;height:42px;min-height:42px;padding:0 14px;border-radius:13px;font-size:14px;font-weight:850}.viewerOperationHud .mapControlGroup.open .controlGroupHeader,.viewerTtsDock.open .viewerHudGroupHeader,.viewerActionDock.open .viewerHudGroupHeader{border-top-left-radius:6px;border-bottom-left-radius:6px;box-shadow:inset 1px 0 #ffffff29,-1px 0 #e2e8f0e0,0 8px 18px #0f172a2e}.viewerOperationHud .controlGroupHeader svg,.viewerOperationHud .mapLayerSwitch button svg,.viewerOperationHud .mapToolSwitch button svg,.viewerTtsQuick button svg{width:17px;height:17px}.viewerTopDock{position:absolute;top:calc(var(--viewer-hud-pad-y, 16px) + var(--workspace-status-height, 40px) + var(--workspace-status-gap, 12px));right:var(--viewer-hud-pad-x, 24px);display:flex;flex-direction:column;max-width:calc(100% - (var(--viewer-hud-pad-x, 24px) * 2));gap:12px;align-items:flex-end;justify-content:flex-end;pointer-events:none}.viewerBottomDock{position:absolute;right:var(--viewer-hud-pad-x, 24px);bottom:54px;display:flex;flex-direction:column-reverse;max-width:calc(100% - (var(--viewer-hud-pad-x, 24px) * 2));gap:12px;align-items:flex-end;justify-content:flex-end;pointer-events:none}.viewerControlHint{position:absolute;right:var(--viewer-hud-pad-x, 24px);bottom:20px;z-index:44;display:flex;flex-wrap:wrap;max-width:min(410px,calc(100% - (var(--viewer-hud-pad-x, 24px) * 2)));gap:10px;justify-content:flex-end;padding:0 2px;color:#94a3b8;pointer-events:none}.viewerControlHint span{display:inline-flex;align-items:center;gap:5px;min-height:22px;padding:0;color:#94a3b8;font-size:11px;font-weight:700;white-space:nowrap}.viewerControlHint svg{flex:0 0 auto;color:#cbd5e1}.viewerActionDock button{display:inline-flex;gap:8px;align-items:center;justify-content:center;background:transparent;color:#475569;line-height:1;white-space:nowrap}.viewerActionPanel button,.viewerTtsQuick button,.viewerOperationHud .mapLayerSwitch button,.viewerOperationHud .mapToolSwitch button{background:#f8fafcb8}.viewerOperationHud .mapLayerSwitch button.active,.viewerOperationHud .mapToolSwitch button.active{background:#2563eb;color:#fff;box-shadow:0 8px 18px #2563eb47}.viewerOperationHud .mapLayerSwitch button.active:hover,.viewerOperationHud .mapToolSwitch button.active:hover{background:#1d4ed8}.viewerActionDock .viewerHudGroupHeader{display:inline-flex;width:auto;background:#111827;color:#fff}.viewerActionDock{position:relative;z-index:1;display:flex;flex:0 0 auto;gap:8px;align-items:center;padding:4px;border-radius:18px}.viewerActionDock:not(.open) .viewerHudGroupHeader,.viewerTtsDock.collapsed .viewerHudGroupHeader,.viewerOperationHud .mapControlGroup.collapsed .controlGroupHeader{width:auto;min-width:max-content;padding:0 14px;border-radius:14px;background:#111827;color:#fff}.viewerActionPanel{display:flex;flex:0 1 auto;gap:6px;min-width:0;overflow-x:auto;scrollbar-width:none}.viewerActionPanel::-webkit-scrollbar,.viewerTtsQuick::-webkit-scrollbar{display:none}.viewerOperationHud .mapLayerSwitch button:not(:disabled):hover,.viewerOperationHud .mapToolSwitch button:not(:disabled):hover,.viewerActionDock button:not(:disabled):hover,.viewerTtsQuick button:not(:disabled):hover{background:#f8fafc}.viewerActionDock button:disabled,.viewerTtsQuick button:disabled{cursor:not-allowed;opacity:.58}.viewerTtsDock{position:relative;display:flex;gap:8px;align-items:center;min-width:0;padding:4px;border-radius:16px;pointer-events:none}.viewerTtsDock:has(.viewerTtsPanel){z-index:95}.viewerTtsQuick{display:flex;max-width:min(520px,50vw);gap:6px;overflow-x:auto;padding:0;scrollbar-width:none}.viewerTtsQuick button{display:inline-flex;flex:0 0 auto;gap:8px;align-items:center;justify-content:center;max-width:170px;background:transparent;color:#334155;line-height:1}.viewerTtsQuick button span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.viewerTtsQuick .viewerTtsMore{background:#f59e0b;color:#111827;box-shadow:0 8px 18px #f59e0b3d}.viewerTtsQuick .viewerTtsMore:hover:not(:disabled){background:#d97706;color:#fff}.viewerTtsPanel{position:absolute;right:0;bottom:calc(100% + 12px);z-index:90;width:min(520px,calc(100vw - 64px));max-height:min(560px,calc(100vh - 260px));overflow:auto;padding:0;border:1px solid rgb(226 232 240 / 82%);border-radius:18px;background:#fffffff0;box-shadow:0 22px 60px #0f172a38;pointer-events:auto;scrollbar-gutter:stable;scrollbar-width:thin;scrollbar-color:rgb(100 116 139 / 56%) transparent}.viewerTtsPanel::-webkit-scrollbar{width:8px}.viewerTtsPanel::-webkit-scrollbar-track{margin:12px 0;background:transparent}.viewerTtsPanel::-webkit-scrollbar-thumb{border:2px solid transparent;border-radius:999px;background:#64748b6b;background-clip:content-box}.viewerTtsPanel::-webkit-scrollbar-thumb:hover{background:#33415594;background-clip:content-box}.viewerCommandBusy{position:absolute;right:var(--viewer-hud-pad-x, 24px);bottom:72px;display:inline-flex;gap:6px;align-items:center;min-height:32px;padding:0 10px;border-radius:999px;color:#334155;font-size:12px;font-weight:800}.mainVision .mapInfoOverlay{top:calc(var(--viewer-hud-pad-y, 16px) + var(--workspace-status-height, 40px) + var(--workspace-status-gap, 12px));left:var(--viewer-hud-pad-x, 24px);width:min(360px,calc(100% - (var(--viewer-hud-pad-x, 24px) * 2)));max-width:min(360px,calc(100% - (var(--viewer-hud-pad-x, 24px) * 2)));border-radius:16px}.mainVision .mapInfoOverlay.collapsed{width:auto;min-width:0}.pip{position:absolute;top:0;left:0;z-index:var(--z-pip);width:320px;height:190px;overflow:hidden;padding:0;border:4px solid var(--color-surface);border-radius:var(--radius-xl);background:var(--color-video-bg);box-shadow:var(--shadow-panel);cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;will-change:transform}.pip.dragging{cursor:grabbing;box-shadow:var(--shadow-panel-strong)}.pipOverlay{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#0000002e;color:var(--color-surface);opacity:0;transition:opacity .16s ease}.pip:hover .pipOverlay{opacity:1}.pip:has(.pointCloudOverlay) .pipOverlay{opacity:0}.pip .alignedViewer,.pip .alignedCanvas{height:100%;min-height:0}.pip .pointCloudOverlay{padding:16px;font-size:14px}.mapView{position:relative;display:grid;width:100%;height:100%;min-height:420px;place-items:center;overflow:auto;background:#f8fafc}.mapView.compact{min-height:100%}.mapCanvasWrap{position:relative;display:inline-block}.mapCanvas{display:block;border:1px solid #cbd5e1;border-radius:12px;background:#fff;image-rendering:pixelated;touch-action:none}.mapCanvas.interactive{cursor:crosshair}.mapCanvas.panReady{cursor:grab}.mapCanvas.panning{cursor:grabbing}.mapHint{position:absolute;top:16px;left:16px;display:flex;flex-direction:column;gap:8px;max-width:min(320px,calc(100% - 32px));padding:7px 11px;border:1px solid #e2e8f0;border-radius:12px;background:#ffffffdb;color:#475569;font-size:13px;pointer-events:none}.mapHintText{line-height:1.4}.mapPoseReadout{display:grid;gap:2px;padding-top:6px;border-top:1px solid #e2e8f0;font-size:12px;font-variant-numeric:tabular-nums}.mapPoseReadoutTitle{color:#10b981;font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.mapPoseReadoutRow{display:flex;flex-wrap:wrap;gap:6px;align-items:baseline;color:#334155}.mapPoseReadoutRow strong{color:#0f172a;font-weight:700}.mapPoseReadoutNote{color:#b45309;font-size:11px;font-style:normal;font-weight:600}.mapPoseTools{position:absolute;top:16px;right:16px;display:flex;gap:6px;padding:5px;border:1px solid #e2e8f0;border-radius:14px;background:#ffffffeb;box-shadow:0 8px 24px #0f172a1f}.mapPoseTools button{display:inline-flex;align-items:center;gap:6px;min-height:36px;padding:0 11px;border-radius:10px;background:transparent;color:#475569;font-size:12px;font-weight:800}.mapPoseTools button.active{background:#111827;color:#fff}.mapPoseTools button.pulse{background:#fcca59;color:#1f2937;box-shadow:0 0 0 4px #fcca5947}.mapZoomControls{position:absolute;right:16px;bottom:16px;display:flex;align-items:center;overflow:hidden;border:1px solid #e2e8f0;border-radius:13px;background:#ffffffe5;box-shadow:0 8px 24px #0f172a1f}.mapZoomControls button,.mapZoomControls span{display:grid;min-width:40px;height:38px;place-items:center;color:#475569;font-size:12px;font-weight:800}.mapZoomControls button{background:transparent}.mapZoomControls button:disabled{cursor:not-allowed;opacity:.38}.alignedViewer{min-height:0}.alignedViewer,.alignedCanvas{position:relative;width:100%;height:100%;min-width:0;min-height:0;overflow:hidden}.alignedCanvas canvas{display:block;width:100%;height:100%}.alignedCanvas.inspectMode,.alignedCanvas.inspectMode canvas{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32'%3E%3Cpath fill='%23111827' stroke='white' stroke-width='2' d='M11 3h6v11h2V6h5v13l-5 7H9L5 18V8h5v8h1z'/%3E%3C/svg%3E") 12 12,grab}.alignedCanvas.inspectMode:active,.alignedCanvas.inspectMode:active canvas{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32'%3E%3Cpath fill='%230f172a' stroke='white' stroke-width='2' d='M10 5h5v9h2V7h5v12l-5 7H9L5 18v-6h5z'/%3E%3C/svg%3E") 12 12,grabbing}.mapViewer{position:relative;width:100%;height:100%;min-width:0;min-height:0}.mapViewerTools{position:absolute;top:14px;right:14px;z-index:8;display:flex;flex-wrap:wrap;gap:10px;align-items:start;justify-content:flex-end}.threeDControlHint{position:absolute;right:16px;bottom:76px;z-index:6;display:flex;flex-wrap:wrap;max-width:min(430px,calc(100% - 32px));gap:10px;justify-content:flex-end;padding:0 2px;color:#94a3b8;pointer-events:none}.threeDControlHint span{display:inline-flex;align-items:center;gap:5px;min-height:22px;padding:0;color:#94a3b8;font-size:11px;font-weight:700;white-space:nowrap}.threeDControlHint svg{color:#cbd5e1}.mapInfoOverlay{position:absolute;top:14px;left:14px;z-index:5;min-width:190px;max-width:min(320px,calc(100% - 28px));border:1px solid rgb(226 232 240 / 78%);border-radius:10px;background:#ffffffdb;color:#0f172a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 22px #0f172a1a}.mapInfoOverlay.collapsed{min-width:0}.mapInfoToggle{display:flex;width:100%;align-items:center;gap:5px;min-height:30px;padding:6px 9px;border-radius:10px;background:transparent;color:#0f172a;font-size:12px;font-weight:850}.mapInfoOverlay dl{display:grid;gap:6px;margin:0;padding:0 10px 10px}.mapInfoOverlay div{display:grid;grid-template-columns:82px minmax(0,1fr);gap:8px;align-items:baseline}.mapInfoOverlay dt{color:#64748b;font-size:11px;font-weight:800}.mapInfoOverlay dd{min-width:0;margin:0;color:#0f172a;font-size:12px;font-weight:800;overflow-wrap:anywhere}.mapInfoPoseValue{font-variant-numeric:tabular-nums;line-height:1.35}.pointCloudOverlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:12;display:grid;place-items:center;padding:24px;background:#f1f5f9e0;color:#334155;font-size:15px;font-weight:800;line-height:1.4;text-align:center;pointer-events:none;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.pointCloudOverlay.error{background:#f1f5f9eb;color:#991b1b}.contentPage{width:min(1040px,100%);margin:0 auto;padding:32px}.pageActions{justify-content:flex-end;margin-bottom:28px}.cardGrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:22px}.deviceCard,.mapCard,.placeholderCard{display:grid;gap:12px;padding:24px;border-radius:28px}.deviceCard.selected{border-color:#fcca59;box-shadow:0 0 0 4px #fcca5933}.deviceTop{justify-content:space-between;margin-bottom:8px}.iconBox{display:grid;width:52px;height:52px;place-items:center;border-radius:18px;background:#f1f5f9;color:#334155}.iconBox.route{background:#fef0cd;color:#8a651d}.mapThumb{position:relative;display:grid;height:140px;place-items:center;overflow:hidden;border:1px solid #f1f5f9;border-radius:20px;background:radial-gradient(circle,#cbd5e1 1px,transparent 1px);background-size:20px 20px}.mapThumb img{max-width:100%;max-height:100%}.mapCard small,.missionItem small{display:inline-flex;gap:5px;align-items:center;color:#94a3b8}.mapCardButton{width:100%;color:inherit;text-align:left;transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease}.mapCardButton:hover{border-color:#cbd5e1;box-shadow:0 10px 24px #0f172a17;transform:translateY(-1px)}.mapPreviewPage{display:grid;grid-template-rows:auto minmax(0,1fr);height:calc(100vh - 65px);padding:16px}.mapPreviewHeader{display:grid;grid-template-columns:auto minmax(0,1fr);gap:16px;align-items:center;padding:0 0 14px}.mapPreviewHeader h1{margin:0;color:#0f172a;font-size:20px;line-height:1.2}.mapPreviewHeader p{margin:3px 0 0;color:#64748b;font-size:13px}.mapPreviewHeader .secondaryButton{display:inline-flex;align-items:center;gap:7px;min-height:38px;padding:0 13px;border:1px solid #e2e8f0;border-radius:12px;background:#fff;color:#475569;font-size:13px;font-weight:800}.mapPreviewStage{position:relative;min-height:0;overflow:hidden;border:1px solid #e2e8f0;border-radius:24px;background:#fff;box-shadow:0 1px 4px #0f172a0a}.missionList{display:grid;gap:14px}.missionItem{display:grid;grid-template-columns:auto 1fr auto auto;gap:18px;align-items:center;padding:22px;border-radius:28px}.roundPlay{width:48px;height:48px;border-radius:18px;background:#111827;color:#fff}.roundPlay:disabled{opacity:.45;cursor:not-allowed}.roundStop{width:48px;height:48px;border-radius:18px;border:0;background:#dc2626;color:#fff;cursor:pointer}.roundStop:hover{background:#b91c1c}.statusPill.pulse{background:#fef3c7;color:#b45309;animation:statusPillPulse 1.4s ease-in-out infinite}.statusPill.active{background:#dbeafe;color:#1d4ed8}@keyframes statusPillPulse{0%,to{opacity:1}50%{opacity:.65}}.editorPage{display:grid;grid-template-rows:auto 1fr;height:calc(100vh - 65px);padding:16px}.editorToolbar{display:grid;grid-template-columns:minmax(220px,1fr) 180px 200px auto auto;gap:14px;align-items:center;padding:16px;border:1px solid #e2e8f0;border-bottom:0;border-radius:28px 28px 0 0;background:#fff}.editorCanvas{position:relative;overflow:hidden;border:1px solid #e2e8f0;border-radius:0 0 28px 28px;background:#f8fafc}.pointPanel{position:absolute;top:24px;right:24px;display:grid;gap:12px;width:288px;max-height:calc(100% - 48px);overflow:auto;padding:18px;border:1px solid #e2e8f0;border-radius:22px;background:#ffffffe5;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 12px 30px #0f172a1f}.pointPanelList{display:grid;gap:10px}.pointPanel h3{display:flex;gap:8px;align-items:center;margin:0;font-size:14px}.pointRow{display:flex;gap:12px;align-items:flex-start;padding:12px 10px;border:1px solid #e2e8f0;border-radius:14px;background:#fff;box-shadow:0 2px 8px #0f172a0f}.pointRowIndex{display:grid;flex-shrink:0;width:26px;height:26px;margin-top:2px;place-items:center;border-radius:999px;background:#f59e0b;color:#111827;font-size:12px;font-weight:900}.pointRowActive .pointRowIndex{background:#06b6d4;color:#fff}.pointRowDragging{z-index:1;opacity:.92;box-shadow:0 8px 20px #0f172a24}.pointRowActive{border-color:#06b6d4;background:#ecfeff;box-shadow:0 4px 14px #06b6d42e;cursor:pointer}.editorActivePointHint{margin:4px 0 0;color:#0891b2;font-size:13px;font-weight:600}.pointRowHandle,.pointRowDelete{display:grid;flex-shrink:0;width:28px;height:28px;place-items:center;padding:0;border:0;border-radius:8px;background:transparent;color:#64748b;cursor:pointer}.pointRowHandle{touch-action:none;cursor:grab}.pointRowHandle:active{cursor:grabbing}.pointRowDelete:hover{background:#fee2e2;color:#b91c1c}.pointRowBody{display:grid;flex:1;gap:6px;min-width:0;padding-top:2px}.pointRowCoords{color:#0f172a;font-size:13px;font-weight:600;line-height:1.35}.pointRowYaw{color:#64748b;font-size:12px;font-variant-numeric:tabular-nums;line-height:1.35}.routeEditorCanvas{display:block}.routeEditorSaveBar{position:absolute;left:24px;bottom:24px;z-index:2;display:flex;gap:12px;align-items:center;padding:10px 12px;border:1px solid #e2e8f0;border-radius:16px;background:#ffffffeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 12px 30px #0f172a1f}.routeEditorNameInput{width:200px;padding:8px 12px;border:1px solid #e2e8f0;border-radius:10px;font-size:14px}.toastError{position:fixed;right:18px;bottom:18px;padding:12px 16px;border-radius:14px;background:#fee2e2;color:#991b1b;box-shadow:0 12px 30px #0f172a1f}.emptyMap{color:#94a3b8}@media (max-width: 1100px){.navBar{grid-template-columns:minmax(0,1fr) auto;gap:8px 12px;padding:8px 14px}.tabs{grid-column:1 / -1;grid-row:2;max-width:100%;overflow-x:auto;overscroll-behavior-x:contain;padding:3px;border-radius:14px;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tabButton{flex:0 0 auto;gap:6px;padding:8px 12px;border-radius:11px;white-space:nowrap}.accountButton{grid-column:2;grid-row:1;justify-self:end;padding:3px 10px 3px 3px}.homeGrid{grid-template-columns:1fr}.homeGrid,.editorPage{height:auto}.mainVision{min-height:520px}.editorToolbar{grid-template-columns:1fr}.alignedCanvas{min-height:520px}.mapViewerTools{right:12px;left:auto;display:flex;flex-wrap:wrap;gap:8px;align-items:start;justify-content:flex-end}.mapControlGroup,.mapLayerSwitch,.mapToolSwitch{min-width:0}.mapLayerSwitch{max-width:100%;overflow-x:auto;overscroll-behavior-x:contain;scrollbar-width:none}.mapLayerSwitch::-webkit-scrollbar{display:none}.mapViewControlGroup{justify-self:start}.mapNavControlGroup{justify-self:end;max-width:100%}.mapToolSwitch{max-width:100%;overflow-x:auto;overscroll-behavior-x:contain;scrollbar-width:none}.mapToolSwitch::-webkit-scrollbar{display:none}.mapInfoOverlay{top:62px;left:12px;max-width:min(320px,calc(100% - 24px))}.viewerStatusBar{max-width:100%;overflow:visible;scrollbar-width:none}.viewerStatusBar::-webkit-scrollbar{display:none}.viewerStatusLeft,.viewerStatusCenter,.viewerStatusRight{overflow-x:auto;scrollbar-width:none}.viewerStatusLeft::-webkit-scrollbar,.viewerStatusCenter::-webkit-scrollbar,.viewerStatusRight::-webkit-scrollbar{display:none}.viewerBottomDock{right:min(430px,calc(100% - 24px));max-width:calc(100% - 454px)}.viewerSidePanel{left:12px;width:min(320px,calc(100% - 24px))}.viewerSidePanel:has(.viewerMapInfoPanel.collapsed):has(.viewerLogPanel.collapsed){width:max-content;max-width:min(180px,calc(100% - 24px))}.viewerTtsQuick{max-width:min(520px,48vw)}.mainVision .mapViewerTools{top:12px}.mainVision .mapInfoOverlay{top:calc(12px + var(--workspace-status-height, 40px) + var(--workspace-status-gap, 12px));left:12px;width:min(320px,calc(100% - 24px));max-width:min(320px,calc(100% - 24px))}}@media (max-width: 640px){.navBar{gap:6px 10px;padding:7px 10px}.brand{grid-column:1;grid-row:1;gap:8px;min-width:0;font-size:15px}.brand span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.brandMark,.avatar{width:30px;height:30px;border-radius:10px}.accountButton{gap:6px;padding:2px 8px 2px 2px}.accountButton>span:not(.avatar){display:none}.tabButton{gap:4px;padding:6px 8px;font-size:13px}.tabButton svg{width:16px;height:16px}.mapViewerTools{top:10px;right:10px;left:10px;gap:6px}.mapControlGroup{max-width:100%}.controlGroupHeader{height:30px;min-height:30px;padding:0 8px;border-radius:10px;font-size:11px}.mapNavControlGroup{justify-self:stretch}.mapLayerSwitch,.mapToolSwitch{padding:0;border-radius:12px}.mapLayerSwitch button,.mapToolSwitch button{min-width:42px;height:30px;min-height:30px;padding:0 8px;border-radius:9px;font-size:11px}.mapToolSwitch button{gap:5px}.mapToolSwitch button svg{width:14px;height:14px}.mapInfoOverlay{top:92px;left:10px;max-width:min(300px,calc(100% - 20px))}.mainVision .mapInfoOverlay{width:auto;min-width:0}.mainVision .mapInfoOverlay:not(.collapsed){width:min(260px,calc(100% - 20px));max-width:min(260px,calc(100% - 20px))}.mainVision .mapInfoOverlay dl{display:none}.viewerStatusBar{max-width:100%;min-height:36px;padding:0 8px;border-radius:0}.viewerStatusItem{min-height:26px;padding:0;font-size:11px}.viewerStatusCenter{max-width:min(340px,36vw)}.viewerStatusMenuButton{min-height:26px;font-size:11px}.viewerStatusMenuButton span{max-width:112px}.viewerStatusMenuPanel{min-width:max(128px,100%)}.videoSim.main .videoHud{top:42px}.viewerActionDock button{min-width:34px;height:30px;padding:0 8px;border-radius:9px}.viewerActionDock .viewerHudGroupHeader,.viewerHudGroupHeader{width:auto;height:30px;min-height:30px;padding:0 8px;border-radius:12px}.viewerBottomDock{right:10px;bottom:42px;flex-wrap:wrap;gap:6px;max-width:calc(100% - 20px)}.viewerControlHint{right:10px;bottom:10px;max-width:calc(100% - 20px);gap:8px}.viewerControlHint span{font-size:10px}.viewerActionDock{max-width:100%;padding:3px;border-radius:12px}.viewerActionPanel{display:flex;max-width:calc(100vw - 72px);overflow-x:auto;scrollbar-width:none}.viewerActionPanel::-webkit-scrollbar{display:none}.viewerTtsDock{max-width:100%}.viewerTtsQuick{max-width:min(100%,calc(100vw - 20px));padding:0;border-radius:12px}.viewerTtsQuick button{height:30px;min-height:30px;max-width:112px;padding:0 8px;border-radius:9px;font-size:11px}.viewerTtsPanel{order:-1;width:calc(100vw - 40px);max-height:min(270px,calc(100vh - 360px));padding:10px;border-radius:16px}.viewerCommandBusy{right:10px;bottom:84px}.viewerSidePanel{top:calc(10px + var(--workspace-status-height, 40px) + var(--workspace-status-gap, 12px));bottom:auto;left:10px;width:min(260px,calc(100% - 20px));max-height:320px;gap:8px;padding:10px;border-radius:14px}.viewerSidePanel:has(.viewerMapInfoPanel.collapsed):has(.viewerLogPanel.collapsed){width:max-content;max-width:min(180px,calc(100% - 20px));padding:8px 10px}.viewerMapInfoPanel,.viewerLogPanel{padding:0}.viewerLogPanel{max-height:180px;min-height:0}.viewerMapInfoPanel div{grid-template-columns:minmax(68px,.78fr) minmax(0,1.22fr);gap:8px}.viewerMapInfoPanel dt,.viewerMapInfoPanel dd{font-size:11px}.viewerLogList{gap:6px}.viewerLogItem,.viewerLogEmpty{padding:7px 8px;font-size:11px}.mainVision .mapViewerTools{top:10px}.mainVision .mapInfoOverlay{top:calc(10px + var(--workspace-status-height, 40px) + var(--workspace-status-gap, 12px))}.pip{width:220px;height:132px;border-width:3px;border-radius:18px}.pip .pointCloudOverlay{padding:12px;font-size:12px}}@media (max-width: 430px){.controlGroupHeader>span{display:none}}
