/* Control-Center-specific styles layered over the shared studio.css design
   system (same tokens: --accent, --glass, --mono, vp-chip / seg / gbtn). */

/* CC grid: the telemetry band (camera strip + joint state) spans ONLY the
   center column — the network rail and status dock run full height beside it */
.studio.cc{ grid-template-rows:50px 1fr 6px var(--plots-h) 6px var(--tl-h);
  grid-template-areas:
    "top     top  top    top  top"
    "browser bs   center ds   dock"
    "browser bs   ps     ds   dock"
    "browser bs   plots  ds   dock"
    "tls     tls  tls    tls  tls"
    "timeline timeline timeline timeline timeline"; }

/* ── top bar: [brand] · [SAFETY center] · [session tools + status right] ── */
.safety-cluster{ display:flex; gap:10px; align-items:center; }
.gbtn.estop.big{ font-size:12px; padding:9px 22px; border-radius:999px;
  box-shadow:0 6px 18px -6px rgba(210,59,42,.55); }
.gbtn.estop.big.engaged{ box-shadow:0 6px 18px -6px rgba(63,181,107,.55); }
.tb-sep{ width:1px; height:18px; background:var(--hairline); margin:0 4px; }
.topright{ display:flex; align-items:center; gap:8px; }
.conn-label{ font-size:10px; color:var(--ash); letter-spacing:.08em; }
.conn.ok{ color:var(--live); }
/* E-STOP: red while the robot is live (click = stop); once ENGAGED the same
   button turns green "RE-ENGAGE" (click = release + re-energize) */
.gbtn.estop{ background:var(--danger); border-color:var(--danger);
  color:#fff; font-weight:600; letter-spacing:.08em; }
.gbtn.estop:hover{ filter:brightness(1.15); }
.gbtn.estop.engaged{ background:var(--live); border-color:var(--live); color:#fff;
  animation:estopPulse 1.2s infinite; }
@keyframes estopPulse{ 50%{ filter:brightness(1.3);} }
.gbtn.rec{ background:var(--danger); color:#fff; border-color:var(--danger); }
/* torque: amber "Disable Torque" while energized, gray "Enable Torque" when limp */
.gbtn.on{ color:var(--accent-soft); border-color:var(--accent-soft);
  background:rgba(194,91,42,.14); }
.rec-task{ font-family:var(--mono); font-size:10px; color:var(--ash);
  cursor:pointer; padding:4px 8px; border-radius:999px; border:1px dashed var(--glass-bd); }
.rec-task:hover{ color:var(--ink); }

/* ── viewport toolbar: row 1 = visualization chips, row 2 = teleop cluster ── */
.vp-teleop{ position:absolute; top:48px; left:50%; transform:translateX(-50%);
  display:flex; gap:8px; align-items:center; z-index:30; white-space:nowrap; }
.vp-manip{ position:absolute; top:86px; left:50%; transform:translateX(-50%);
  display:flex; gap:8px; z-index:30; }
.tp-start{ font-family:var(--mono); font-size:11px; letter-spacing:.1em;
  text-transform:uppercase; padding:8px 16px; border-radius:999px;
  background:var(--accent); color:#fff; border:1px solid var(--accent);
  cursor:pointer; box-shadow:var(--sh); }
.tp-start.on{ background:var(--danger); border-color:var(--danger); }
.tp-seg{ background:rgba(20,18,16,.65); backdrop-filter:blur(12px) saturate(1.5);
  border:1px solid var(--glass-bd); border-radius:999px; }
.tp-seg button{ font-size:10px; }

/* single-line chip rail across the top of the viewer (scrolls if narrow) */
.vp-toggles{ position:absolute; top:10px; left:10px; right:10px; display:flex;
  flex-wrap:nowrap; gap:6px; max-width:none; z-index:25; overflow-x:auto;
  padding-bottom:4px; scrollbar-width:none; }
.vp-toggles::-webkit-scrollbar{ display:none; }
.vp-toggles .vp-chip{ flex:none; }
.vp-chip.goal{ color:#4dff8a; border-color:rgba(77,255,138,.4); }
.vp-caret{ margin-left:6px; opacity:.65; padding:2px 3px; border-radius:4px; }
.vp-caret:hover{ opacity:1; background:rgba(242,238,230,.12); }
.vp-mslider{ display:flex; align-items:center; gap:7px; padding:7px 9px;
  font-family:var(--mono); font-size:10px; color:var(--ash);
  border-top:1px solid var(--hairline); }
.vp-mslider input{ flex:1; accent-color:var(--accent); min-width:70px; }
.vp-mslider b{ width:42px; text-align:right; color:var(--ink-soft); }
/* .vp-camctl: keep studio.css's top-right column (curation-studio layout);
   nudge it below the chip rail so the two never overlap */
.vp-camctl{ top:48px; }
.vp-camctl .cc-size{ width:84px; accent-color:var(--accent); }

/* ── bottom-center viewer navigation ── */
.vp-navctl{ position:absolute; bottom:10px; left:50%; transform:translateX(-50%);
  display:flex; gap:6px; z-index:26; }
.vp-navctl .vp-chip.goal{ color:#4dff8a; border-color:rgba(77,255,138,.4); }
.vp-navctl .vp-chip.goal.on{ color:#0d0c0b; background:#4dff8a; border-color:#4dff8a; }
.vp-navctl .vp-chip.go{ color:#0d0c0b; background:#4dff8a; border-color:#4dff8a;
  font-weight:600; animation:goPulse 1.4s infinite; }
@keyframes goPulse{ 50%{ filter:brightness(1.25);} }
/* SLAM matches the Nav chip family: quiet green outline when on, never the
   default peach fill */
.vp-navctl .vp-chip[data-nav="slam"].on{ color:#4dff8a; background:rgba(20,18,16,.6);
  border-color:rgba(77,255,138,.4); }
/* busy state: spinner ring so a relaunch never reads as frozen */
.vp-chip.loading{ pointer-events:none; opacity:.85; }
.vp-chip.loading::after{ content:''; display:inline-block; width:9px; height:9px;
  margin-left:7px; vertical-align:-1px; border-radius:50%;
  border:1.5px solid rgba(77,255,138,.35); border-top-color:#4dff8a;
  animation:chipSpin .7s linear infinite; }
@keyframes chipSpin{ to{ transform:rotate(360deg); } }

/* ── joint-space slider panel (left edge, manipulate → joint space) ── */
.vp-joints{ position:absolute; left:10px; top:86px; bottom:56px; width:238px;
  overflow-y:auto; z-index:27; padding:8px 10px; border-radius:var(--r-md);
  background:rgba(20,18,16,.72); border:1px solid var(--glass-bd);
  backdrop-filter:blur(14px) saturate(1.4); }
.jsp-group{ font-family:var(--mono); font-size:9px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ash); padding:8px 0 3px; }
.jsp-row{ display:flex; align-items:center; gap:6px; padding:2px 0; }
.jsp-name{ font-family:var(--mono); font-size:9px; color:var(--ink-soft);
  width:62px; flex:none; white-space:nowrap; overflow:hidden; }
.jsp-row input{ flex:1; accent-color:var(--accent); height:12px; }
.jsp-val{ width:38px; font-size:9.5px; color:var(--ash); text-align:right; }

/* ── first-person view ── */
.fpv{ position:absolute; inset:0; z-index:20; background:transparent; }
.fpv-img{ background:#000; }
/* cover (not contain): footage fills the frame with no bars, and the 3D view
   behind can match it EXACTLY during the crossfade (same center crop) */
.fpv-img{ width:100%; height:100%; object-fit:cover; }
.fpv-tag{ position:absolute; top:10px; right:12px; font-size:10px;
  letter-spacing:.14em; color:var(--accent-soft); text-transform:uppercase; }
/* PiP: shrink the live 3D canvas into the TOP-RIGHT corner above the fpv
   image, clear of the joysticks (bottom corners) and the nav bar (bottom
   center); the camera-control column hides while the PiP occupies its spot */
.viewport3d.pip-3d > canvas{ position:absolute; right:12px; top:48px;
  left:auto; bottom:auto; width:240px !important; height:170px !important;
  z-index:26; border:1px solid var(--glass-bd-2); border-radius:var(--r-md);
  background:rgba(13,12,11,.85); }
.viewport3d.pip-3d .vp-camctl{ display:none; }

/* ── virtual joysticks ── */
.stick{ position:absolute; bottom:26px; width:120px; height:120px; z-index:28;
  border-radius:50%; border:1px solid var(--glass-bd-2);
  background:radial-gradient(circle at 50% 40%, rgba(242,238,230,.08), rgba(20,18,16,.5));
  backdrop-filter:blur(10px); touch-action:none; }
.stick.left{ left:36px; } .stick.right{ right:36px; }
.stick-knob{ position:absolute; left:50%; top:50%; width:44px; height:44px;
  margin:-22px 0 0 -22px; border-radius:50%; background:var(--accent);
  opacity:.85; box-shadow:var(--sh); pointer-events:none; }
.stick-tag{ position:absolute; bottom:-18px; width:100%; text-align:center;
  font-family:var(--mono); font-size:8.5px; letter-spacing:.14em; color:var(--ash); }
/* per-arm height hold-buttons flanking the sticks (manipulate mode) */
.stick-ud{ position:absolute; bottom:36px; display:flex; flex-direction:column;
  gap:8px; z-index:28; }
.stick-ud.left{ left:8px; } .stick-ud.right{ right:8px; }
.stick-ud button{ width:34px; height:42px; border-radius:10px;
  background:rgba(20,18,16,.6); border:1px solid var(--glass-bd);
  color:var(--ink-soft); font-size:13px; backdrop-filter:blur(10px);
  cursor:pointer; touch-action:none; }
.stick-ud button:active{ background:var(--accent); color:#fff;
  border-color:var(--accent); }
.kbd-hint{ position:absolute; bottom:8px; left:50%; transform:translateX(-50%);
  font-size:9px; color:var(--ash-dim); z-index:24; letter-spacing:.08em; }

/* ── left networking rail ── */
.np-sec{ font-family:var(--mono); text-transform:uppercase; letter-spacing:.16em;
  font-size:9.5px; color:var(--ash); padding:12px 14px 5px; }
.np-row{ display:flex; align-items:center; gap:7px; padding:3px 14px;
  font-size:11.5px; color:var(--ink-soft); }
.np-row span{ flex:1; color:var(--ash); }
.np-row b{ font-weight:500; }
.np-dot{ width:7px; height:7px; border-radius:50%; background:var(--ash-dim); flex:none; }
.np-dot.up{ background:var(--live); box-shadow:0 0 6px rgba(63,181,107,.7); }
.np-dot.down{ background:var(--danger); }
.np-empty{ padding:4px 14px; font-size:11px; color:var(--ash-dim); font-style:italic; }
.np-client{ margin:5px 10px; padding:7px 9px; border-radius:var(--r-sm);
  background:var(--glass); border:1px solid var(--hairline); }
.np-client.driver{ border-color:rgba(194,91,42,.5); }
.np-cl-head{ display:flex; gap:6px; align-items:center; font-size:11.5px; }
.np-cl-sub{ font-size:10px; color:var(--ash); margin-top:2px; }
.np-ic{ font-size:12px; }
.np-badge{ font-family:var(--mono); font-size:8px; padding:1px 6px;
  border-radius:999px; background:var(--accent); color:#fff; letter-spacing:.1em; }
.np-chip{ font-family:var(--mono); font-size:8.5px; padding:1px 7px;
  border-radius:999px; border:1px solid var(--glass-bd); color:var(--ash);
  margin-left:auto; }
.np-chip.t-lan{ color:#3ecf8e; border-color:rgba(62,207,142,.4); }
.np-chip.t-ts{ color:#bf8af2; border-color:rgba(191,138,242,.4); }
.np-chip.t-relay{ color:var(--warn); border-color:rgba(233,166,121,.4); }
.np-chip.t-inet{ color:#e7c24b; border-color:rgba(231,194,75,.4); }

/* ── right status dock ── */
.st-row{ display:flex; justify-content:space-between; padding:4px 14px;
  font-size:11.5px; color:var(--ash); border-bottom:1px solid var(--hairline); }
.st-row b{ color:var(--ink-soft); font-weight:500; }
.st-row b.ok{ color:var(--live); }
.st-row b.warn{ color:var(--warn); }
.st-row b.bad{ color:var(--danger); }
.st-task .st-row{ border-bottom:none; }

/* ── joint band extras ── */
.temp-legend i{ display:inline-block; width:8px; height:8px; border-radius:2px;
  margin-right:4px; vertical-align:-1px; }
.temp-legend .t-ok{ background:#3ecf8e; } .temp-legend .t-warn{ background:#E7C24B; }
.temp-legend .t-hot{ background:#D9463A; }
#jointCanvas{ width:100%; height:calc(100% - 34px - 132px); display:block; }

/* telemetry band gets room for the permanent camera strip */
.studio.cc{ --plots-h:272px; }
.cam-strip{ display:flex; gap:8px; height:124px; padding:6px 10px 2px;
  justify-content:center; }
/* tiles keep the stream's true aspect: 16:9 boxes, letterboxed content */
.cam-strip .cam-tile.strip{ flex:0 1 auto; aspect-ratio:16/9; height:116px;
  cursor:default; background:#000; }
.cam-strip .cam-tile.strip img{ object-fit:contain; }
.cam-dchip{ position:absolute; top:5px; right:5px; font-family:var(--mono);
  font-size:9px; padding:2px 7px; border-radius:999px; background:rgba(20,18,16,.7);
  border:1px solid var(--glass-bd); color:var(--ash); cursor:pointer; }
.cam-dchip.on{ color:var(--bg); background:var(--accent-soft); border-color:var(--accent-soft); }
.cam-dchip:disabled{ opacity:.35; cursor:not-allowed; }

/* ── dexterity window ── */
.dex{ display:flex; flex-direction:column; height:100%; }
.dex-head{ display:flex; gap:8px; padding:8px; border-bottom:1px solid var(--hairline); }
.dex-body{ flex:1; overflow-y:auto; padding:8px 10px; }
.dex-row{ display:flex; gap:8px; align-items:center; padding:3px 0; position:relative; }
.dex-lab{ font-family:var(--mono); font-size:9.5px; color:var(--ash);
  width:78px; flex:none; text-transform:uppercase; letter-spacing:.06em; }
.dex-row input[type=range]{ flex:1; accent-color:var(--accent); height:14px; }
.dex-val{ width:36px; font-size:10px; color:var(--ink-soft); text-align:right; }
.dex-cur{ position:absolute; top:2px; width:2px; height:12px;
  background:var(--live); opacity:0; pointer-events:none; }
.dex-poses{ display:grid; grid-template-columns:repeat(3,1fr); gap:6px; margin:10px 0; }
.dex-poses .gbtn{ text-align:center; }
.dex-cam{ width:100%; margin-top:4px; }
.dex-video{ width:100%; border-radius:var(--r-sm); margin-top:8px;
  transform:scaleX(-1); }

/* ── setpoint timeline ── */
.sp-lane{ position:relative; height:44px; margin-top:4px;
  background:var(--glass); border-radius:var(--r-sm);
  border:1px solid var(--hairline); }
.sp-key{ position:absolute; top:10px; font-size:15px; color:var(--accent-soft);
  cursor:grab; user-select:none; line-height:1; }
.sp-key.sel{ color:#fff; text-shadow:0 0 8px var(--accent); }
#tlPlayBtn{ color:var(--live); }

/* ── add-window types ── */
.win-bar{ display:flex; gap:10px; align-items:center; padding:7px 9px;
  border-bottom:1px solid var(--hairline); flex-wrap:wrap; }
.win-bar .cc-lbl{ display:flex; align-items:center; gap:6px;
  font-family:var(--mono); font-size:9px; color:var(--ash);
  text-transform:uppercase; letter-spacing:.08em; }
.win-bar input[type=range]{ width:90px; accent-color:var(--accent); }
.win-cam{ height:calc(100% - 40px); background:#000; }
.win-cam img{ width:100%; height:100%; object-fit:contain; display:block; }
.win-tftree{ overflow-y:auto; font-size:11px; padding:6px 0; }
.tft-row{ display:flex; justify-content:space-between; gap:10px; padding:2px 10px 2px 0;
  color:var(--ash); border-left:1px solid transparent; }
.tft-row.joint{ color:var(--accent-soft); }
.tft-name{ white-space:nowrap; }
.tft-pos{ font-size:9.5px; color:var(--ash-dim); }
.win-grid2d{ position:relative; }
.win-grid2d canvas{ width:100%; height:100%; display:block; }
.win-jhist canvas{ display:block; }
.band-toggles{ margin-left:auto; display:flex; gap:6px; }
.vp-chip.warn{ color:var(--warn); border-color:rgba(233,166,121,.4); }

/* camera wall tiles (floating panel) */
.vw-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(190px,1fr));
  gap:8px; padding:8px; overflow-y:auto; height:100%; }
.cam-tile{ position:relative; aspect-ratio:16/9; border-radius:var(--r-sm);
  overflow:hidden; background:#0a0908; border:1px solid var(--hairline);
  cursor:pointer; }
.cam-tile img{ width:100%; height:100%; object-fit:cover; display:block; }
.cam-tile .cam-tag{ position:absolute; left:7px; bottom:5px; top:auto; right:auto;
  font-family:var(--mono); font-size:9px; letter-spacing:.1em;
  color:var(--accent-soft); text-transform:uppercase;
  /* pill hugs the text exactly — no stretched backdrop */
  display:inline-block; width:auto; max-width:max-content; white-space:nowrap;
  background:rgba(0,0,0,.55); padding:2px 6px; border-radius:5px; }
.cam-tile .cam-missing{ display:none; position:absolute; inset:0;
  align-items:center; justify-content:center; font-family:var(--mono);
  font-size:10px; color:var(--ash); background:rgba(13,12,11,.8); }
.cam-tile.dead .cam-missing{ display:flex; }
.cam-tile.off{ opacity:.35; }
.cam-tile.off img{ display:none; }

/* ── SIM control center additions: badge, sim cluster, scene picker, modal ── */
.sim-badge{ font-family:var(--mono); font-size:9px; letter-spacing:.18em;
  color:#7fd4a0; border:1px solid rgba(127,212,160,.45); border-radius:4px;
  padding:2px 6px; margin-left:8px; background:rgba(63,181,107,.12); }
.sim-cluster{ display:flex; align-items:center; gap:6px; }
.gbtn.loading{ opacity:.55; pointer-events:none; position:relative; }

.scene-wrap{ position:relative; }
.scene-wrap #sceneName{ font-weight:600; color:var(--accent-soft); }
.scene-menu{ position:absolute; top:calc(100% + 8px); left:50%;
  transform:translateX(-50%); z-index:70; width:340px; max-height:66vh;
  overflow-y:auto; padding:6px; border-radius:12px;
  background:rgba(20,19,18,.96); border:1px solid var(--line, rgba(255,255,255,.09));
  box-shadow:0 18px 48px -12px rgba(0,0,0,.7); backdrop-filter:blur(14px); }
.scene-menu.hidden{ display:none; }
.scene-note{ font-size:10px; color:var(--ink-soft); padding:8px 10px;
  border-bottom:1px solid rgba(255,255,255,.07); margin-bottom:4px; }
.scene-item{ display:flex; gap:10px; align-items:center; width:100%;
  padding:6px; border:0; border-radius:9px; background:transparent;
  color:var(--ink); cursor:pointer; text-align:left; }
.scene-item:hover{ background:rgba(255,255,255,.06); }
.scene-item.on{ outline:1px solid var(--accent-soft);
  background:rgba(63,181,107,.08); }
.scene-thumb{ flex:0 0 96px; height:60px; border-radius:6px; overflow:hidden;
  display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.05); color:var(--ink-soft); font-size:14px; }
.scene-thumb img{ width:100%; height:100%; object-fit:cover; display:block; }
.scene-meta{ display:flex; flex-direction:column; gap:2px; min-width:0; }
.scene-meta b{ font-size:12px; font-weight:600; }
.scene-meta small{ font-size:10px; color:var(--ink-soft); white-space:nowrap;
  overflow:hidden; text-overflow:ellipsis; }

/* save-episode confirm */
.ep-modal-back{ position:fixed; inset:0; z-index:90; display:flex;
  align-items:center; justify-content:center; background:rgba(0,0,0,.55);
  backdrop-filter:blur(4px); }
.ep-modal-back.hidden{ display:none; }
.ep-modal{ width:440px; max-width:92vw; max-height:86vh; overflow-y:auto;
  border-radius:14px; padding:16px 18px; background:rgba(22,21,20,.98);
  border:1px solid rgba(255,255,255,.1);
  box-shadow:0 24px 64px -16px rgba(0,0,0,.8); }
.ep-h{ font-size:15px; font-weight:650; margin-bottom:10px; }
.ep-info{ font-size:11px; color:var(--ink-soft); }
.ep-table{ width:100%; border-collapse:collapse; }
.ep-table td{ padding:3px 6px 3px 0; vertical-align:top; }
.ep-table td:first-child{ color:var(--ash, #8a857e); white-space:nowrap;
  width:86px; }
.ep-mods{ display:flex; flex-wrap:wrap; gap:5px; margin:10px 0 4px; }
.ep-mod{ font-family:var(--mono); font-size:9.5px; padding:3px 7px;
  border-radius:999px; border:1px solid rgba(255,255,255,.12);
  color:var(--ink-soft); }
.ep-mod small{ color:var(--accent-soft); margin-left:4px; }
.ep-field{ display:flex; flex-direction:column; gap:4px; font-size:10px;
  color:var(--ink-soft); margin-top:10px; text-transform:uppercase;
  letter-spacing:.08em; }
.ep-field input{ font-family:var(--mono); font-size:12px; color:var(--ink);
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12);
  border-radius:8px; padding:7px 10px; outline:none; }
.ep-field input:focus{ border-color:var(--accent-soft); }
.ep-path{ font-size:9.5px; color:var(--ash, #8a857e); margin-top:8px;
  word-break:break-all; }
.ep-actions{ display:flex; justify-content:flex-end; gap:8px; margin-top:14px; }
.ep-actions .ep-save{ background:var(--accent); border-color:var(--accent);
  color:#fff; }
.ep-actions .ep-save:hover{ filter:brightness(1.12); }

/* ── top bar: E-STOP dead-centered, no layout shift from live numbers ────── */
/* The safety cluster is pinned to the page center (out of flex flow), so the
   varying widths of the scene label / latency readout can never nudge it.
   The E-STOP button itself is the centering anchor. */
.topbar{ justify-content:space-between; }
.safety-cluster{ position:absolute; left:50%; transform:translateX(-50%); }
.sim-cluster{ margin-left:6px; }
/* latency/name readout: fixed box + tabular digits — updates in place */
.conn-label{ display:inline-block; min-width:220px; max-width:220px;
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
  text-align:right; font-variant-numeric:tabular-nums; }

/* browser MuJoCo viewer window */
.win-simview{ user-select:none; touch-action:none; }
.win-simview img{ width:100%; height:100%; object-fit:contain; display:block;
  background:#151413; }

/* ── DEXTERITY permanent dock: both ORCA hands, in-viewer (not a window) ── */
.vp-dexdock{ position:absolute; top:52px; right:12px; bottom:12px; width:600px;
  max-width:46vw; z-index:40; display:flex; flex-direction:column;
  border-radius:14px; background:rgba(20,19,18,.93);
  border:1px solid rgba(255,255,255,.09); backdrop-filter:blur(14px);
  box-shadow:0 18px 48px -18px rgba(0,0,0,.65); overflow:hidden; }
.vp-dexdock.hidden{ display:none; }
.dexdock-head{ display:flex; align-items:center; gap:8px; padding:8px 12px;
  border-bottom:1px solid rgba(255,255,255,.07); flex:0 0 auto; }
.dexdock-title{ font-size:9.5px; letter-spacing:.16em; color:var(--accent-soft); }
.dexdock-hide{ margin-left:auto; background:none; border:0; color:var(--ash);
  cursor:pointer; font-size:12px; padding:2px 6px; border-radius:6px; }
.dexdock-hide:hover{ color:var(--ink); background:rgba(255,255,255,.08); }
.dexdock-cols{ display:flex; flex:1; min-height:0; }
.dexdock-col{ flex:1; min-width:0; display:flex; flex-direction:column;
  overflow-y:auto; padding:8px; }
.dexdock-col + .dexdock-col{ border-left:1px solid rgba(255,255,255,.07); }
.dexdock-side{ font-size:9px; letter-spacing:.18em; color:var(--ash);
  padding:0 2px 6px; }
.dexdock-col .dex-head{ flex-wrap:wrap; }

/* dexterity dock: sections + the shared both-hands webcam */
.dex-sec{ font-size:8.5px; letter-spacing:.16em; color:var(--ash);
  margin:10px 2px 4px; }
.dexdock-cam{ flex:0 0 auto; border-top:1px solid rgba(255,255,255,.07);
  padding:8px; }
.dex-camrow{ display:flex; gap:8px; }
.dex-camrow .gbtn{ font-size:10px; }
.dex-camview{ position:relative; margin-top:8px; border-radius:10px;
  overflow:hidden; }
.dex-camview.hidden{ display:none; }
.dex-camview video, .dex-camview canvas{ width:100%; display:block;
  transform:scaleX(-1); }             /* selfie mirror, skeleton matches */
.dex-camview canvas{ position:absolute; inset:0; height:100%; }

/* ── dexterity as a REAL side panel: viewer reflows, compact content ──────── */
.center{ display:flex; min-width:0; }
.center .viewport3d{ flex:1 1 auto; min-width:0; }
.vp-dexdock{ position:static; inset:auto; width:440px; max-width:none;
  flex:0 0 440px; height:auto; border-radius:0; border:0;
  border-left:1px solid rgba(255,255,255,.09); background:rgba(18,17,16,.97);
  box-shadow:none; backdrop-filter:none; z-index:auto; }
@media (max-width: 1500px){ .vp-dexdock{ width:380px; flex-basis:380px; } }
/* compact content so both hands fit without overflow */
.vp-dexdock .dexdock-col{ padding:6px; }
.vp-dexdock .dex-head{ margin-bottom:4px; }
.vp-dexdock .dex-head .seg button{ font-size:8.5px; padding:3px 7px; }
.vp-dexdock .dex-row{ gap:5px; margin:2px 0; }
.vp-dexdock .dex-lab{ font-size:8.5px; width:64px; overflow:hidden;
  text-overflow:ellipsis; white-space:nowrap; }
.vp-dexdock .dex-row input[type=range]{ height:10px; }
.vp-dexdock .dex-val{ font-size:8px; width:44px; }
.vp-dexdock .dex-poses{ gap:3px; margin:2px 0; display:flex; flex-wrap:wrap; }
.vp-dexdock .dex-poses .gbtn{ font-size:8px; padding:3px 6px; letter-spacing:.02em; }
.vp-dexdock .dex-sec{ margin:8px 2px 3px; }
.vp-dexdock .dexdock-cam{ padding:6px; }
.vp-dexdock .dex-camview{ max-height:180px; }
.vp-dexdock .dex-camview video{ max-height:180px; object-fit:cover; }

/* ── webcam full-body teleop (bodyteleop.js) ───────────────────────────────
   The teleop cluster becomes a column: row 1 = the two start buttons + segs,
   row 2 = live region/tracking chips, row 3 = mirrored webcam preview. */
.vp-teleop{ flex-direction:column; max-width:calc(100% - 24px); }
.vp-teleop .tp-row{ display:flex; gap:8px; row-gap:6px; align-items:center;
  white-space:nowrap; flex-wrap:wrap; justify-content:center; }
.tp-start.kbd{ background:rgba(20,18,16,.65); border-color:var(--glass-bd);
  color:var(--ink); }
.tp-start.kbd.on{ background:var(--danger); border-color:var(--danger); color:#fff; }
.bt-status{ display:flex; gap:6px; margin-top:6px; justify-content:center; }
.bt-chip{ font-size:9.5px; letter-spacing:.06em; padding:3px 10px;
  border-radius:999px; background:rgba(20,18,16,.72);
  border:1px solid var(--glass-bd); color:var(--ash); white-space:nowrap; }
.bt-chip b{ color:var(--ink); font-weight:600; }
.bt-chip .ok{ color:#4dff8a; }
.bt-chip .no{ color:#ff6a5e; }
.bt-preview{ position:relative; margin-top:6px; width:210px; border-radius:10px;
  overflow:hidden; border:1px solid var(--glass-bd); box-shadow:var(--sh);
  background:#000; }
.bt-preview video, .bt-preview canvas{ display:block; width:100%;
  transform:scaleX(-1); }                    /* mirrored selfie view */
.bt-preview canvas{ position:absolute; inset:0; height:100%; }
.bt-preview .bt-tag{ position:absolute; left:8px; bottom:6px; font-size:8.5px;
  letter-spacing:.12em; color:rgba(255,255,255,.75); text-shadow:0 1px 2px #000; }
