:root{
  --bg:#0b0f17;
  --panel:#0f1624;
  --card:#101a2b;
  --line:rgba(120,160,255,0.20);
  --text:#dbe7ff;
  --muted:rgba(219,231,255,0.70);
  --bg-deep:#05070a;
  --accent-blue:#3b82f6;
  --glass:rgba(15,22,36,0.72);
  --border-light:rgba(255,255,255,0.10);
  --ok:#22c55e;
  --warn:#f59e0b;
  --bad:#ef4444;
}

*{ box-sizing:border-box; }
html,body{ height:100%; }

body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  background:var(--bg);
  color:var(--text);
  overflow:hidden;
}

input,
select,
button{
  font:inherit;
}

input[type="range"]{
  width:100%;
}

.layout{
  height:100vh;
  display:grid;
  grid-template-columns:1.7fr 1fr;
  gap:12px;
  padding:12px;
}

.workstation-container{
  grid-template-columns:1fr;
  gap:0;
  padding:0;
  background:
    radial-gradient(circle at 50% -10%, rgba(59,130,246,0.14), transparent 32%),
    linear-gradient(180deg, #07111f 0%, #05070a 52%, #03050a 100%);
  overflow:hidden;
  position:relative;
}

.workstation-container .panel{
  display:none;
}

.workstation-container .view{
  grid-column:1;
  grid-row:1;
  border-radius:0;
  border:0;
  background:#05070a;
}

.legacy-panel{
  display:none !important;
}

.top-nav{
  position:fixed;
  top:16px;
  left:50%;
  transform:translateX(-50%);
  width:min(98vw, 1760px);
  min-height:60px;
  border-radius:999px;
  border:1px solid var(--border-light);
  background:var(--glass);
  backdrop-filter:blur(20px);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:0 14px 0 18px;
  z-index:120;
  box-shadow:0 24px 60px rgba(0,0,0,0.42);
}

.nav-workflow-item{
  position:relative;
}

.nav-brand-btn{
  border:1px solid rgba(96,165,250,0.22);
  background:
    radial-gradient(circle at 20% 20%, rgba(125,211,252,0.18), transparent 42%),
    linear-gradient(135deg, rgba(17,24,39,0.92), rgba(8,12,20,0.96));
  color:#fff;
  border-radius:18px;
  padding:12px 18px;
  font-size:1.45rem;
  font-weight:800;
  letter-spacing:-0.6px;
  cursor:pointer;
  box-shadow:0 16px 36px rgba(0,0,0,0.32);
  transition:transform 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}

.nav-brand-btn:hover{
  transform:translateY(-1px);
  border-color:rgba(125,211,252,0.42);
  box-shadow:0 18px 40px rgba(0,0,0,0.4);
}

.nav-links{
  display:none;
}

.nav-item{
  position:relative;
}

.nav-trigger{
  border:none;
  background:transparent;
  color:#9fb2d1;
  padding:8px 8px;
  border-radius:10px;
  font-size:12px;
  cursor:pointer;
  transition:background 0.15s ease, color 0.15s ease;
  white-space:nowrap;
}

.nav-trigger:hover{
  color:#fff;
  background:rgba(255,255,255,0.06);
}

.nav-trigger-primary{
  color:#fff;
  font-weight:700;
  padding:10px 12px;
  background:linear-gradient(135deg, rgba(59,130,246,0.18), rgba(15,22,36,0.26));
  border:1px solid rgba(96,165,250,0.18);
}

.nav-trigger-primary:hover{
  background:linear-gradient(135deg, rgba(59,130,246,0.28), rgba(15,22,36,0.36));
}

.tension-control{
  display:flex;
  align-items:center;
  gap:8px;
  background:rgba(255,255,255,0.04);
  border-radius:999px;
  padding:6px 8px;
  cursor:default;
}

.tension-control:hover{
  background:rgba(255,255,255,0.04);
}

.tension-label{
  font-size:10px;
  font-weight:800;
  letter-spacing:0.8px;
  color:#64748b;
}

#tensionSlider{
  width:108px;
  accent-color:var(--accent-blue);
  cursor:ew-resize;
}

#penetrationSlider{
  width:108px;
  accent-color:var(--warn);
  cursor:ew-resize;
}

.tension-track{
  position:relative;
  width:108px;
  height:16px;
  display:flex;
  align-items:center;
}

.tension-target{
  position:absolute;
  left:25%;
  top:3px;
  width:2px;
  height:10px;
  border-radius:2px;
  background:var(--ok);
  pointer-events:none;
  box-shadow:0 0 8px rgba(34,197,94,0.55);
}

.tension-value{
  width:56px;
  text-align:right;
  font-size:10px;
  color:#fff;
  font-family: ui-monospace, "SFMono-Regular", Menlo, Monaco, Consolas, "Liberation Mono", monospace;
}

.assessment-trigger{
  color:var(--accent-blue);
  font-weight:700;
}

.megamenu{
  position:absolute;
  top:46px;
  left:0;
  min-width:240px;
  border-radius:16px;
  border:1px solid var(--border-light);
  background:var(--glass);
  backdrop-filter:blur(25px);
  box-shadow:0 20px 40px rgba(0,0,0,0.48);
  padding:10px;
  display:none;
  z-index:150;
}

.megamenu.open{
  display:block;
}

.workflow-megamenu{
  min-width:420px;
  padding:14px;
}

.workflow-master-menu{
  min-width:min(720px, calc(100vw - 32px));
  padding:16px;
}

.workflow-stack-section{
  border:1px solid rgba(255,255,255,0.08);
  border-radius:16px;
  background:rgba(255,255,255,0.03);
  overflow:hidden;
}

.workflow-stack-section + .workflow-stack-section{
  margin-top:12px;
}

.workflow-stack-trigger{
  list-style:none;
  cursor:pointer;
  padding:14px 16px;
  font-size:14px;
  font-weight:800;
  color:#fff;
}

.workflow-stack-trigger::-webkit-details-marker{
  display:none;
}

.workflow-stack-body{
  padding:0 16px 16px;
}

.workflow-subhead-row{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:10px;
  margin-bottom:8px;
}

.workflow-subhead{
  font-size:10px;
  font-weight:800;
  letter-spacing:1px;
  text-transform:uppercase;
  color:#8ab4ff;
}

.workflow-mega-header{
  font-size:11px;
  font-weight:800;
  letter-spacing:1px;
  text-transform:uppercase;
  color:#9fb2d1;
  margin-bottom:10px;
}

.workflow-option-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:10px;
}

.workflow-option-card{
  display:grid;
  gap:8px;
  width:100%;
  border:1px solid rgba(96,165,250,0.16);
  background:linear-gradient(180deg, rgba(10,16,28,0.88), rgba(13,20,33,0.92));
  color:#dbe7ff;
  border-radius:16px;
  padding:14px;
  text-align:left;
  cursor:pointer;
  transition:transform 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}

.workflow-option-card:hover{
  transform:translateY(-2px);
  border-color:rgba(96,165,250,0.36);
  box-shadow:0 12px 26px rgba(59,130,246,0.16);
}

.workflow-option-eyebrow{
  font-size:10px;
  font-weight:800;
  letter-spacing:0.9px;
  text-transform:uppercase;
  color:#8ab4ff;
}

.workflow-option-title{
  font-size:15px;
  font-weight:800;
  color:#fff;
}

.workflow-option-copy{
  font-size:12px;
  line-height:1.45;
  color:#9fb2d1;
}

.workflow-field{
  display:grid;
  gap:8px;
  margin-bottom:10px;
}

.workflow-field span{
  font-size:11px;
  font-weight:700;
  letter-spacing:0.5px;
  text-transform:uppercase;
  color:#9fb2d1;
}

.workflow-chip-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:8px;
  margin-bottom:12px;
}

.workflow-type-chip{
  border:1px solid rgba(96,165,250,0.16);
  background:rgba(12,18,30,0.74);
  color:#cbd5e1;
  border-radius:12px;
  padding:10px 12px;
  text-align:center;
  cursor:pointer;
  transition:background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.workflow-type-chip:hover{
  color:#fff;
  background:rgba(25,36,58,0.9);
}

.workflow-type-chip.active{
  color:#fff;
  border-color:rgba(96,165,250,0.5);
  background:linear-gradient(135deg, rgba(59,130,246,0.28), rgba(15,22,36,0.92));
}

.workflow-hidden-select{
  position:absolute;
  width:1px;
  height:1px;
  overflow:hidden;
  clip:rect(0 0 0 0);
  white-space:nowrap;
  clip-path:inset(50%);
}

.workflow-action-btn{
  width:100%;
  border:none;
  border-radius:12px;
  background:linear-gradient(135deg, #2563eb, #1d4ed8);
  color:#fff;
  font-size:13px;
  font-weight:700;
  padding:12px 14px;
  cursor:pointer;
  transition:transform 0.15s ease, box-shadow 0.15s ease;
}

.workflow-action-btn:hover{
  transform:translateY(-1px);
  box-shadow:0 14px 28px rgba(37,99,235,0.28);
}

.workflow-menu-status{
  margin-top:10px;
  padding:10px 12px;
  border-radius:12px;
  background:rgba(8,12,20,0.56);
  border:1px solid rgba(255,255,255,0.07);
  color:#cbd5e1;
  font-size:12px;
  line-height:1.4;
}

.menu-grid{
  display:grid;
  gap:6px;
}

.menu-btn{
  display:block;
  width:100%;
  text-align:left;
  border:none;
  background:transparent;
  color:#cbd5e1;
  border-radius:10px;
  padding:10px 12px;
  font-size:12px;
  cursor:pointer;
  transition:background 0.15s ease, color 0.15s ease, transform 0.15s ease;
}

.menu-btn:hover{
  background:rgba(255,255,255,0.06);
  color:#fff;
  transform:translateY(-1px);
}

.menu-caption{
  margin-top:4px;
  font-size:9px;
  letter-spacing:0.7px;
  text-transform:uppercase;
  color:#64748b;
  padding:2px 4px 0;
}

.menu-select{
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;
  border:1px solid var(--border-light);
  background:rgba(255,255,255,0.08);
  color:#dbe7ff;
}

.menu-btn.active{
  background:rgba(59,130,246,0.16);
  color:#fff;
}

.assessment-menu{
  min-width:320px;
  padding:14px;
}

.assessment-head{
  display:flex;
  align-items:flex-end;
  gap:10px;
  margin-bottom:10px;
}

.assessment-score{
  font-size:2rem;
  font-weight:800;
  color:#fff;
  line-height:1;
}

.assessment-status{
  font-size:12px;
  font-weight:700;
  color:#9fb2d1;
}

.assessment-kpis{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:8px;
}

.assessment-kpi{
  border-radius:8px;
  background:rgba(255,255,255,0.05);
  padding:8px;
}

.assessment-label{
  font-size:9px;
  letter-spacing:0.6px;
  color:#94a3b8;
}

.assessment-value{
  margin-top:4px;
  font-size:12px;
  color:#dbe7ff;
}

.assessment-metrics{
  margin-top:10px;
  font-size:11px;
  color:#9fb2d1;
}

.assessment-rec{
  margin-top:10px;
  padding-top:10px;
  border-top:1px solid var(--border-light);
  font-size:11px;
  color:#cbd5e1;
}

.assessment-clinical{
  margin-top:8px;
  font-size:11px;
  color:#9fb2d1;
}

.signoff-btn{
  margin-top:12px;
  text-align:center;
  border:1px solid var(--ok);
  color:var(--ok);
  display:none;
}

.menu-row{
  display:grid;
  grid-template-columns:repeat(6, minmax(34px, 1fr));
  gap:6px;
  margin-bottom:6px;
}

.menu-row:last-child{
  margin-bottom:0;
}

.menu-row .menu-btn{
  text-align:center;
  padding:8px 4px;
}

.nav-actions{
  display:flex;
  align-items:center;
  gap:6px;
  margin-left:auto;
  white-space:nowrap;
  flex:0 0 auto;
}

.nav-assessment-item .megamenu{
  left:auto;
  right:0;
}

.pill-btn{
  border:1px solid var(--border-light);
  background:rgba(13,20,33,0.82);
  color:#dbe7ff;
  border-radius:999px;
  padding:8px 12px;
  font-size:12px;
  cursor:pointer;
  transition:transform 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
  white-space:nowrap;
}

.pill-btn:hover{
  transform:translateY(-1px);
}

.pill-btn.primary{
  background:var(--accent-blue);
  color:#fff;
  border-color:transparent;
  font-weight:700;
  box-shadow:0 10px 22px rgba(59,130,246,0.35);
}

.workstation-container .topline{
  padding-top:74px;
}

.workstation-container .bottomline{
  padding-bottom:70px;
}

.view{
  position:relative;
  background:linear-gradient(180deg, rgba(22,32,56,0.55), rgba(11,15,23,0.95));
  border:1px solid var(--line);
  border-radius:18px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
}

.viewport{
  flex:1;
  min-height:380px;
  position:relative;
}

.viewport canvas{
  width:100%;
  height:100%;
  display:block;
}

.topline{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  padding:10px 10px 8px;
  position:relative;
  z-index:4;
}

.minimal-topline{
  justify-content:flex-end;
  padding:88px 18px 0;
}

.pill-row{
  display:flex;
  gap:8px;
}

.workflow-headline{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.workflow-title-block{
  display:flex;
  flex-direction:column;
  gap:4px;
}

.workflow-kicker{
  font-size:10px;
  font-weight:800;
  letter-spacing:1px;
  text-transform:uppercase;
  color:#7dd3fc;
}

.workflow-title{
  font-size:18px;
  font-weight:800;
  letter-spacing:-0.3px;
  color:#fff;
}

.workflow-pill-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.workflow-pill{
  display:flex;
  flex-direction:column;
  gap:4px;
  min-width:150px;
  padding:10px 12px;
  border-radius:14px;
  background:rgba(8,12,20,0.58);
  border:1px solid rgba(96,165,250,0.12);
  backdrop-filter:blur(10px);
}

.workflow-pill span{
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:0.8px;
  color:#9fb2d1;
}

.workflow-pill strong{
  font-size:13px;
  color:#fff;
}

.bottomline{
  padding:10px;
  border-top:1px solid var(--line);
  background:rgba(10,14,22,0.65);
  position:relative;
  z-index:4;
}

.status{
  color:var(--text);
  font-size:13px;
}

.brand{
  font-size:1.08rem;
  font-weight:800;
  letter-spacing:-0.4px;
  margin:2px 6px 14px;
  color:#fff;
}

.brand span{
  color:var(--accent-blue);
  font-style:italic;
}

.floating-dock{
  position:absolute;
  left:50%;
  bottom:18px;
  transform:translateX(-50%);
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 18px;
  border-radius:22px;
  border:1px solid var(--border-light);
  background:
    linear-gradient(135deg, rgba(8,12,20,0.96), rgba(14,22,38,0.88));
  backdrop-filter:blur(18px);
  z-index:30;
  box-shadow:0 24px 54px rgba(0,0,0,0.42);
}

.bottom-dock{
  left:50%;
}

.dock-divider{
  width:1px;
  height:22px;
  background:rgba(255,255,255,0.18);
}

.dock-action{
  border:none;
  background:transparent;
  color:#dbe7ff;
  font-size:12px;
  padding:8px 10px;
  border-radius:12px;
  cursor:pointer;
  transition:background 0.15s ease, color 0.15s ease;
}

.dock-action:hover{
  background:rgba(255,255,255,0.08);
}

.dock-equipment-btn{
  border:1px solid rgba(96,165,250,0.14);
  background:rgba(255,255,255,0.03);
}

.dock-equipment-btn.active{
  color:#fff;
  border-color:rgba(96,165,250,0.42);
  background:linear-gradient(135deg, rgba(59,130,246,0.22), rgba(15,22,36,0.92));
}

.dock-action.highlight{
  color:var(--accent-blue);
  font-weight:700;
}

.viewport-shortcut-bar {
  position: absolute;
  top: 20px;
  left: 50%;
  transform: translateX(-50%) translateY(-30px);
  background: rgba(15, 23, 42, 0.85);
  backdrop-filter: blur(8px);
  color: #60a5fa;
  padding: 10px 24px;
  border-radius: 30px;
  font-family: monospace;
  font-size: 14px;
  font-weight: bold;
  letter-spacing: 0.5px;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3);
  border: 1px solid rgba(96, 165, 250, 0.3);
  z-index: 1000;
  pointer-events: none; 
  opacity: 0; 
  transition: opacity 0.4s ease, transform 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275); 
}

.viewport-shortcut-bar.show-hud {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

.object-mode-toolbar{
  position:absolute;
  top:86px;
  left:14px;
  z-index:95;
  display:none;
  align-items:flex-start;
  gap:12px;
  pointer-events:auto;
}

.object-mode-toolbar.show-toolbar{
  display:flex;
}

.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0, 0, 0, 0);
  white-space:nowrap;
  border:0;
}

.viewport-nav-tools{
  position:absolute;
  top:264px;
  right:18px;
  z-index:96;
  display:none;
  flex-direction:column;
  gap:10px;
  pointer-events:auto;
}

.viewport-nav-tools.show-tools{
  display:flex;
}

.viewport-nav-btn{
  width:34px;
  height:34px;
  display:grid;
  place-items:center;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.12);
  background:linear-gradient(180deg, rgba(61,64,69,0.95), rgba(42,45,49,0.95));
  color:#eef2f8;
  box-shadow:0 10px 18px rgba(0,0,0,0.22);
  cursor:pointer;
  transition:transform 0.16s ease, border-color 0.16s ease, background 0.16s ease, box-shadow 0.16s ease, color 0.16s ease, opacity 0.16s ease;
}

.viewport-nav-btn:hover:not(:disabled){
  transform:translateY(-1px);
  border-color:rgba(148,190,255,0.42);
  background:linear-gradient(180deg, rgba(74,78,83,0.98), rgba(52,56,60,0.98));
  box-shadow:0 14px 26px rgba(0,0,0,0.26);
}

.viewport-nav-btn:disabled{
  cursor:default;
  opacity:0.42;
  box-shadow:none;
}

.viewport-nav-btn svg{
  width:18px;
  height:18px;
  stroke:currentColor;
  fill:none;
  stroke-width:1.75;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.viewport-nav-btn.is-active{
  border-color:rgba(120,172,255,0.62);
  background:linear-gradient(180deg, rgba(72,109,186,0.98), rgba(52,82,146,0.98));
  color:#ffffff;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,0.1), 0 14px 28px rgba(59,130,246,0.28);
}

.view-axis-navigator{
  position:absolute;
  top:144px;
  right:20px;
  z-index:96;
  width:112px;
  height:112px;
  display:none;
  pointer-events:none;
}

.view-axis-navigator.show-navigator{
  display:block;
}

.view-axis-disc,
.view-axis-arm,
.view-axis-btn{
  position:absolute;
}

.view-axis-disc{
  left:50%;
  top:50%;
  width:78px;
  height:78px;
  transform:translate(-50%, -50%);
  border-radius:999px;
  background:transparent;
  border:none;
  box-shadow:none;
}

.view-axis-arm{
  left:50%;
  top:50%;
  width:2px;
  height:24px;
  transform-origin:50% 100%;
  background:linear-gradient(180deg, rgba(255,255,255,0.26), rgba(255,255,255,0.06));
  box-shadow:0 0 0 1px rgba(0,0,0,0.02);
}

.axis-arm-north{
  transform:translate(-50%, -100%);
}

.axis-arm-east{
  width:24px;
  height:2px;
  transform:translate(0, -50%);
}

.axis-arm-south{
  transform:translate(-50%, 0);
}

.axis-arm-west{
  width:24px;
  height:2px;
  transform:translate(-100%, -50%);
}

.view-axis-btn{
  pointer-events:auto;
  width:28px;
  height:28px;
  border-radius:999px;
  display:grid;
  place-items:center;
  border:1px solid rgba(255,255,255,0.12);
  background:linear-gradient(180deg, rgba(66,69,74,0.96), rgba(43,46,51,0.96));
  color:#f8fafc;
  font-size:11px;
  font-weight:800;
  letter-spacing:0.02em;
  cursor:pointer;
  box-shadow:0 8px 18px rgba(0,0,0,0.22);
  --slot-transform:none;
  transform:var(--slot-transform);
  transition:transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease, background 0.15s ease, color 0.15s ease;
}

.view-axis-btn:hover{
  transform:var(--slot-transform) scale(1.06);
  border-color:rgba(255,255,255,0.34);
  box-shadow:0 12px 22px rgba(0,0,0,0.3);
}

.view-axis-btn.is-active{
  border-color:rgba(255,255,255,0.58);
  color:#ffffff;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,0.1), 0 14px 24px rgba(0,0,0,0.3);
}

.view-axis-btn.is-back{
  width:22px;
  height:22px;
  font-size:0;
  color:transparent;
  border-color:rgba(255,255,255,0.16);
  box-shadow:0 6px 14px rgba(0,0,0,0.16);
  opacity:0.96;
}

.view-axis-btn.is-back:hover{
  transform:var(--slot-transform) scale(1.03);
}

.view-axis-btn.axis-x{
  background:linear-gradient(180deg, rgba(182,64,64,0.98), rgba(130,38,38,0.98));
}

.view-axis-btn.axis-y{
  background:linear-gradient(180deg, rgba(107,183,72,0.98), rgba(62,123,40,0.98));
}

.view-axis-btn.axis-z{
  background:linear-gradient(180deg, rgba(70,122,214,0.98), rgba(42,78,148,0.98));
}

.view-axis-center{
  left:50%;
  top:50%;
  width:30px;
  height:30px;
  --slot-transform:translate(-50%, -50%);
  z-index:2;
}

.view-axis-north{
  left:50%;
  top:10px;
  --slot-transform:translateX(-50%);
}

.view-axis-east{
  right:10px;
  top:50%;
  --slot-transform:translateY(-50%);
}

.view-axis-south{
  left:50%;
  bottom:10px;
  --slot-transform:translateX(-50%);
}

.view-axis-west{
  left:10px;
  top:50%;
  --slot-transform:translateY(-50%);
}

.object-mode-rail{
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:10px 8px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,0.08);
  background:linear-gradient(180deg, rgba(62,64,67,0.96), rgba(41,43,45,0.96));
  box-shadow:0 18px 40px rgba(0,0,0,0.34);
  backdrop-filter:blur(14px);
}

.object-mode-tool{
  position:relative;
  width:40px;
  height:40px;
  display:grid;
  place-items:center;
  border-radius:10px;
  border:1px solid rgba(255,255,255,0.08);
  background:linear-gradient(180deg, rgba(73,75,78,0.95), rgba(52,54,57,0.95));
  color:#e8edf7;
  cursor:pointer;
  transition:background 0.16s ease, border-color 0.16s ease, transform 0.16s ease, box-shadow 0.16s ease, color 0.16s ease;
}

.object-mode-tool:hover{
  transform:translateY(-1px);
  border-color:rgba(96,165,250,0.44);
  background:linear-gradient(180deg, rgba(84,87,91,0.96), rgba(60,62,66,0.96));
  box-shadow:0 12px 24px rgba(0,0,0,0.26);
}

.object-mode-tool.is-active{
  color:#ffffff;
  border-color:rgba(140,181,255,0.76);
  background:linear-gradient(180deg, rgba(92,131,212,0.96), rgba(66,102,175,0.96));
  box-shadow:inset 0 0 0 1px rgba(255,255,255,0.12), 0 10px 22px rgba(59,130,246,0.26);
}

.object-mode-tool svg{
  width:22px;
  height:22px;
  stroke:currentColor;
  fill:none;
  stroke-width:1.75;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.object-mode-tool-divider{
  width:100%;
  height:1px;
  margin:2px 0;
  background:linear-gradient(90deg, rgba(255,255,255,0), rgba(255,255,255,0.18), rgba(255,255,255,0));
}

.object-mode-tool::after{
  content:attr(data-tool-label);
  position:absolute;
  left:calc(100% + 12px);
  top:50%;
  transform:translateY(-50%) translateX(-6px);
  padding:8px 10px;
  border-radius:10px;
  background:rgba(14,16,19,0.96);
  border:1px solid rgba(255,255,255,0.08);
  box-shadow:0 12px 26px rgba(0,0,0,0.3);
  color:#eef2f7;
  font-size:11px;
  font-weight:700;
  letter-spacing:0.02em;
  white-space:nowrap;
  opacity:0;
  pointer-events:none;
  transition:opacity 0.14s ease, transform 0.14s ease;
}

.object-mode-tool:hover::after{
  opacity:1;
  transform:translateY(-50%) translateX(0);
}

.object-mode-panel{
  min-width:260px;
  max-width:292px;
  padding:14px 15px 13px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,0.08);
  background:linear-gradient(180deg, rgba(58,60,62,0.95), rgba(42,44,46,0.95));
  box-shadow:0 20px 44px rgba(0,0,0,0.32);
  backdrop-filter:blur(14px);
}

.object-mode-panel-header{
  display:flex;
  align-items:center;
  gap:8px;
}

.object-mode-mode-pill{
  padding:6px 10px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,0.08);
  background:rgba(28,30,33,0.96);
  color:#e8edf3;
  font-size:12px;
  font-weight:700;
}

.object-mode-kicker{
  margin-top:10px;
  font-size:11px;
  line-height:1.45;
  color:rgba(226,232,240,0.76);
}

.object-mode-title{
  font-size:14px;
  font-weight:800;
  color:#f8fafc;
}

.object-mode-transform{
  margin-top:14px;
  padding-top:12px;
  border-top:1px solid rgba(255,255,255,0.08);
}

.object-mode-transform-title{
  margin-bottom:8px;
  font-size:11px;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:rgba(248,250,252,0.72);
}

.object-mode-transform-row + .object-mode-transform-row{
  margin-top:8px;
}

.object-mode-transform-label{
  display:block;
  margin-bottom:2px;
  font-size:11px;
  font-weight:700;
  color:rgba(226,232,240,0.62);
}

.object-mode-transform-value{
  display:block;
  font-family:ui-monospace, "SFMono-Regular", Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  font-size:11px;
  color:#f8fbff;
  white-space:pre-wrap;
}

.object-mode-panel-foot{
  margin-top:12px;
  padding-top:10px;
  border-top:1px solid rgba(255,255,255,0.06);
  color:rgba(226,232,240,0.58);
  font-size:10px;
  line-height:1.45;
}

@media (max-width: 900px){
  .object-mode-toolbar{
    top:82px;
    left:10px;
    gap:10px;
  }

  .camera-view-toggle{
    top:82px;
    right:10px;
    padding:9px 12px;
  }

  .object-mode-panel{
    min-width:220px;
    max-width:240px;
  }
}

.workflow-modal{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  z-index:220;
}

.workflow-modal.open{
  display:flex;
}

.workflow-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(2,6,23,0.74);
  backdrop-filter:blur(8px);
}

.workflow-modal-shell{
  position:relative;
  z-index:1;
  width:min(1380px, calc(100vw - 40px));
  height:min(860px, calc(100vh - 48px));
  border-radius:24px;
  border:1px solid rgba(96,165,250,0.16);
  background:linear-gradient(180deg, rgba(3,7,18,0.98), rgba(5,11,23,0.98));
  box-shadow:0 40px 80px rgba(0,0,0,0.46);
  display:grid;
  grid-template-rows:auto auto 1fr;
  overflow:hidden;
}

.workflow-modal-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:20px 22px 12px;
  border-bottom:1px solid rgba(255,255,255,0.08);
}

.workflow-modal-title{
  font-size:24px;
  font-weight:800;
  color:#fff;
}

.workflow-modal-close{
  border:none;
  background:rgba(255,255,255,0.08);
  color:#dbe7ff;
  border-radius:999px;
  width:40px;
  height:40px;
  font-size:16px;
  cursor:pointer;
}

.workflow-modal-copy{
  padding:14px 22px 16px;
  color:#9fb2d1;
  font-size:13px;
  line-height:1.5;
}

.workflow-modal-frame{
  grid-row:3;
  width:100%;
  height:100%;
  min-height:0;
  border:none;
  background:#1e1e22;
  display:block;
}

.neural-audit-hud{
  position:absolute;
  right:16px;
  bottom:76px;
  width:220px;
  background:rgba(10,16,28,0.76);
  border:1px solid rgba(245,158,11,0.35);
  border-right:4px solid var(--warn);
  border-radius:12px;
  padding:10px 12px;
  backdrop-filter:blur(10px);
  z-index:25;
  pointer-events:none;
}

.dock-item{
  position:relative;
}

.dock-menu{
  top:auto;
  bottom:52px;
  left:50%;
  transform:translateX(-50%);
}

.manual-dock-menu{
  width:min(420px, calc(100vw - 32px));
}

.sculpt-dock-menu{
  width:min(300px, calc(100vw - 32px));
}

.menu-section{
  border:1px solid rgba(255,255,255,0.08);
  border-radius:12px;
  background:rgba(255,255,255,0.03);
  overflow:hidden;
}

.menu-section + .menu-section{
  margin-top:8px;
}

.menu-section-trigger{
  list-style:none;
  cursor:pointer;
  padding:10px 12px;
  color:#dbe7ff;
  font-size:12px;
  font-weight:700;
  user-select:none;
}

.menu-section-trigger::-webkit-details-marker{
  display:none;
}

.menu-section-trigger::after{
  content:"▾";
  float:right;
  color:#94a3b8;
}

.menu-section:not([open]) .menu-section-trigger::after{
  content:"▸";
}

.menu-section-body{
  padding:0 10px 10px;
}

.sculpt-start-btn{
  text-align:center;
  background:rgba(59,130,246,0.18);
  color:#fff;
  font-weight:700;
}

.sculpt-menu-controls{
  margin-top:10px;
  padding:10px;
  border-radius:12px;
  background:rgba(8,12,20,0.6);
  border:1px solid rgba(255,255,255,0.08);
}

.sculpt-radio-group{
  display:grid;
  gap:8px;
  margin-bottom:10px;
  font-size:12px;
  color:#dbe7ff;
}

.sculpt-slider-label{
  display:grid;
  gap:6px;
  margin-top:8px;
  font-size:11px;
  color:#9fb2d1;
}

.production-seal{
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%, -50%) rotate(-14deg);
  border:3px solid var(--ok);
  color:var(--ok);
  background:rgba(34,197,94,0.06);
  border-radius:8px;
  padding:8px 18px;
  font-size:1.6rem;
  font-weight:900;
  letter-spacing:1px;
  opacity:0.85;
  display:none;
  pointer-events:none;
  z-index:40;
}

.hud-header{
  font-size:10px;
  letter-spacing:1px;
  text-transform:uppercase;
  color:#9db4d4;
}

.audit-row{
  display:flex;
  justify-content:space-between;
  margin-top:8px;
  font-size:12px;
  color:#dbe7ff;
}

#auditStatusHUD.audit-ok{ color:var(--ok); }
#auditStatusHUD.audit-bad{ color:var(--bad); }
#auditStatusHUD.audit-pending{ color:var(--warn); }

.pulse-container{
  width:100%;
  height:4px;
  background:rgba(255,255,255,0.12);
  margin-top:10px;
  border-radius:8px;
  overflow:hidden;
  display:none;
}

.pulse-fill{
  width:100%;
  height:100%;
  background:var(--accent-blue);
  box-shadow:0 0 14px var(--accent-blue);
  animation:scan-pulse 1.4s linear infinite;
}

.pulse-container.pulse-error .pulse-fill{
  background:var(--bad);
  box-shadow:0 0 14px var(--bad);
}

@keyframes scan-pulse{
  0%{ transform:translateX(-100%); }
  100%{ transform:translateX(100%); }
}

@keyframes clinical-alert-pulse{
  0%{ text-shadow:0 0 0 var(--bad); transform:scale(1); }
  50%{ text-shadow:0 0 12px var(--bad); transform:scale(1.04); }
  100%{ text-shadow:0 0 0 var(--bad); transform:scale(1); }
}

.clinical-alert-active{
  animation:clinical-alert-pulse 1s ease-in-out infinite;
  color:var(--bad) !important;
}

.panel{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:18px;
  padding:10px;
  overflow:auto;
}

.card{
  background:linear-gradient(180deg, rgba(20,30,55,0.55), rgba(15,22,36,0.85));
  border:1px solid rgba(120,160,255,0.18);
  border-radius:16px;
  padding:12px;
  margin-bottom:10px;
}

.card h3{
  margin:0 0 10px;
  font-size:14px;
  letter-spacing:0.3px;
  color:rgba(219,231,255,0.92);
}

.row{
  display:flex;
  gap:8px;
  align-items:center;
  margin-bottom:8px;
  flex-wrap:wrap;
}

.grow{ flex:1; }
.wide{ flex:1; min-width:180px; }

.pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid rgba(120,160,255,0.18);
  background:rgba(8,12,20,0.55);
  font-size:12px;
  color:rgba(219,231,255,0.85);
}

.chip{
  border:1px solid rgba(120,160,255,0.25);
  background:rgba(12,18,30,0.75);
  color:rgba(219,231,255,0.92);
  border-radius:12px;
  padding:9px 10px;
  font-size:12px;
  cursor:pointer;
  transition:transform 0.06s ease, background 0.12s ease;
  user-select:none;
}

.chip:hover{
  transform:translateY(-1px);
  background:rgba(18,26,44,0.85);
}

.chip:active{
  transform:translateY(0);
}

.chip.active{
  outline:2px solid rgba(60,255,160,0.35);
}

.file,
.select{
  display:flex;
  flex-direction:column;
  gap:6px;
  padding:8px;
  border-radius:12px;
  border:1px dashed rgba(120,160,255,0.25);
  background:rgba(8,12,20,0.35);
  flex:1;
  min-width:160px;
}

.file span,
.select span{
  font-size:11px;
  color:var(--muted);
}

.file input,
.select select{
  width:100%;
  color:var(--text);
}

.grid2{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  margin-top:6px;
}

.kpi{
  border:1px solid rgba(120,160,255,0.18);
  border-radius:12px;
  padding:8px;
  background:rgba(8,12,20,0.35);
}

.kpi .k{
  font-size:11px;
  color:var(--muted);
  margin-bottom:4px;
}

.kpi .v{
  font-size:12px;
  color:rgba(219,231,255,0.92);
}

.note{
  margin:8px 0 0;
  padding:10px;
  border-radius:12px;
  border:1px solid rgba(120,160,255,0.18);
  background:rgba(8,12,20,0.35);
  color:rgba(219,231,255,0.88);
  white-space:pre-wrap;
  max-height:170px;
  overflow:auto;
  font-size:12px;
  line-height:1.35;
}

.chat{
  border:1px solid rgba(120,160,255,0.18);
  border-radius:12px;
  background:rgba(8,12,20,0.35);
  padding:8px;
  height:140px;
  overflow:auto;
}

.aiMsg{
  padding:8px 10px;
  border-radius:12px;
  margin-bottom:6px;
  font-size:12px;
  line-height:1.35;
  border:1px solid rgba(120,160,255,0.12);
}

.aiUser{ background:rgba(34,52,88,0.45); }
.aiBot{ background:rgba(16,26,43,0.65); }

.aiBar{
  display:flex;
  gap:8px;
  margin-top:8px;
}

.aiBar input{
  flex:1;
  min-width:140px;
  padding:10px;
  border-radius:12px;
  border:1px solid rgba(120,160,255,0.18);
  background:rgba(8,12,20,0.35);
  color:var(--text);
  outline:none;
}

.agentLog{
  margin-top:10px;
  padding:10px;
  border-radius:12px;
  background:rgba(20,30,55,0.55);
  border:1px solid rgba(120,160,255,0.25);
  color:#dbe7ff;
  font-size:12px;
  line-height:1.35;
  max-height:160px;
  overflow:auto;
  white-space:pre-wrap;
}

#voiceToggle.active{
  outline:2px solid rgba(60,255,160,0.45);
}

.alert-neutral,
.alert-good,
.alert-warn,
.alert-bad{
  border-radius:14px;
  padding:10px;
  border:1px solid rgba(120,160,255,0.18);
  background:rgba(8,12,20,0.35);
}

.alert-good{ outline:2px solid rgba(60,255,160,0.22); }
.alert-warn{ outline:2px solid rgba(255,200,60,0.22); }
.alert-bad{ outline:2px solid rgba(255,60,90,0.22); }

.alert-title{
  font-size:12px;
  color:rgba(219,231,255,0.90);
  margin-bottom:3px;
}

.alert-status{
  font-size:12px;
  color:rgba(219,231,255,0.80);
}

.status-pill-large{
  padding:9px 10px;
  border-radius:999px;
  border:1px solid rgba(120,160,255,0.18);
  background:rgba(8,12,20,0.55);
  color:rgba(219,231,255,0.90);
  font-size:12px;
}

.status-pill-large.ready{
  outline:2px solid rgba(60,255,160,0.22);
}

.status-pill-large.warn{
  outline:2px solid rgba(255,200,60,0.22);
}

.status-pill-large.error{
  outline:2px solid rgba(255,60,90,0.22);
}

.hint{
  margin-top:6px;
  font-size:11px;
  color:rgba(219,231,255,0.65);
}

.landmarkTable{
  margin-top:8px;
  border:1px solid rgba(120,160,255,0.18);
  border-radius:12px;
  background:rgba(8,12,20,0.35);
  overflow:hidden;
}

.landmarkTable .pill{
  margin:8px;
}

.landmarkTableScroll{
  max-height:160px;
  overflow:auto;
}

.landmarkGrid{
  width:100%;
  border-collapse:collapse;
  font-size:11px;
}

.landmarkGrid th,
.landmarkGrid td{
  padding:6px 8px;
  border-top:1px solid rgba(120,160,255,0.14);
  text-align:left;
  color:rgba(219,231,255,0.9);
}

.landmarkGrid th{
  font-size:10px;
  letter-spacing:0.3px;
  color:rgba(219,231,255,0.7);
  background:rgba(12,18,30,0.5);
  position:sticky;
  top:0;
}

.landmarkGrid td.status-ok{ color:#76ffa7; }
.landmarkGrid td.status-tight{ color:#ff8b8b; }
.landmarkGrid td.status-loose{ color:#60a5fa; }
.landmarkGrid td.status-warn{ color:#f59e0b; }
.landmarkGrid td.status-na{ color:rgba(219,231,255,0.6); }

.clinical-ok{ color:var(--ok) !important; }
.clinical-warn{ color:var(--warn) !important; }
.clinical-bad{ color:var(--bad) !important; }

#clinicalDashboard{
  position:absolute;
  top:14px;
  right:14px;
  width:min(320px, calc(100% - 28px));
  background:rgba(11,15,23,0.82);
  border-left:4px solid var(--accent-blue);
  border-radius:10px;
  padding:12px;
  color:#e2e8f0;
  pointer-events:none;
  backdrop-filter:blur(8px);
  z-index:20;
  box-shadow:0 8px 22px rgba(0,0,0,0.25);
}

#clinicalDashboard .dash-header{
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:1px;
  color:#94a3b8;
}

#clinicalDashboard .dash-status{
  font-size:15px;
  font-weight:700;
  margin:6px 0 5px;
}

#clinicalDashboard .dash-summary{
  font-size:12px;
  line-height:1.4;
  color:#cbd5e1;
}

#clinicalDashboard .dash-metrics{
  margin-top:8px;
  font-size:11px;
  color:#9fb2d1;
}

#clinicalDashboard.status-ready{ border-left-color:var(--ok); }
#clinicalDashboard.status-ready .dash-status{ color:var(--ok); }
#clinicalDashboard.status-warn{ border-left-color:var(--warn); }
#clinicalDashboard.status-warn .dash-status{ color:var(--warn); }
#clinicalDashboard.status-error{ border-left-color:var(--bad); }
#clinicalDashboard.status-error .dash-status{ color:var(--bad); }

@media (max-width: 1100px){
  .layout{ grid-template-columns:1fr; }
  .panel{ height:auto; }
  .workstation-container{
    padding:0;
    gap:0;
  }
  .top-nav{
    top:10px;
    width:calc(100% - 16px);
    border-radius:16px;
    min-height:56px;
    padding:8px 10px;
    gap:8px;
    flex-wrap:wrap;
    justify-content:center;
  }
  .nav-links{
    display:none;
  }
  .workflow-option-grid{
    grid-template-columns:1fr;
  }
  .nav-trigger{
    padding:6px 8px;
    font-size:12px;
  }
  .workstation-container .topline{
    padding-top:96px;
  }
  .floating-dock{
    left:10px;
    right:10px;
    transform:none;
    justify-content:center;
    flex-wrap:wrap;
    border-radius:14px;
  }
  .neural-audit-hud{
    right:10px;
    bottom:120px;
    width:min(220px, calc(100% - 20px));
  }
  .dock-menu{
    left:0;
    right:0;
    transform:none;
    width:auto;
  }
  .workflow-modal-shell{
    width:calc(100vw - 20px);
    height:calc(100vh - 20px);
  }
}

@media (max-width: 720px){
  .top-nav{
    align-items:stretch;
  }
  .nav-brand-btn{
    width:100%;
    text-align:center;
  }
  .nav-actions{
    width:100%;
    justify-content:center;
  }
  .tension-control{
    max-width:100%;
  }
  .tension-track,
  #tensionSlider,
  #penetrationSlider{
    width:96px;
  }
  .assessment-menu{
    min-width:min(320px, calc(100vw - 24px));
    left:auto;
    right:0;
  }
  .megamenu{
    min-width:min(280px, calc(100vw - 24px));
  }
  .topline,
  .bottomline{
    padding-left:8px;
    padding-right:8px;
  }
  .pill-row{
    flex-wrap:wrap;
    justify-content:flex-end;
  }
  .floating-dock{
    gap:6px;
    padding:8px 10px;
  }
  .dock-action{
    font-size:11px;
    padding:6px 7px;
  }
  .menu-row{
    grid-template-columns:repeat(3, minmax(34px, 1fr));
  }
  .workflow-modal-head,
  .workflow-modal-copy{
    padding-left:16px;
    padding-right:16px;
  }
}
