:root{
  --bg:#06090d;
  --bg2:#0a0e14;
  --panel:#101720;
  --panel2:#151f2b;
  --line:rgba(255,255,255,.08);
  --text:#eff5fb;
  --muted:#8fa0b4;
  --blue:#3e8cff;
  --blue2:#6dc0ff;
  --green:#4fd57f;
  --yellow:#ffcd4c;
  --orange:#ff9a3d;
  --red:#ff5151;
  --accent:#d12626;
  --shadow:0 18px 40px rgba(0,0,0,.28);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%;background:radial-gradient(circle at top left,#132031 0,#0a0d11 28%,#05070a 100%);font-family:Inter,Segoe UI,Arial,sans-serif;color:var(--text)}
body{overflow:hidden}
a{color:inherit;text-decoration:none}
button,input,select{font:inherit}
button{cursor:pointer}
.login-screen{position:fixed;inset:0;z-index:9999;display:grid;place-items:center;background:radial-gradient(circle at 30% 20%,rgba(209,38,38,.22),transparent 36%),linear-gradient(135deg,rgba(2,4,6,.88),rgba(5,8,12,.98));backdrop-filter:blur(14px)}
body:not(.locked) .login-screen{display:none}
.login-card{width:min(440px,calc(100vw - 32px));padding:34px;border:1px solid rgba(255,255,255,.12);border-radius:26px;background:linear-gradient(180deg,rgba(20,27,36,.92),rgba(7,10,14,.95));box-shadow:0 40px 120px rgba(0,0,0,.55);text-align:center}
.login-card img{width:86px;height:86px;object-fit:contain}
.login-card h1{margin:14px 0 6px;font-size:28px;letter-spacing:1px}
.login-card p{margin:0 0 26px;color:var(--muted);font-size:13px;line-height:1.5}
.login-card label{display:block;text-align:left;color:#cbd7e3;font-size:12px;font-weight:700;margin-bottom:8px;text-transform:uppercase;letter-spacing:.7px}
.password-row{display:grid;grid-template-columns:1fr auto;gap:8px;margin-bottom:12px}
.password-row input{height:48px;border-radius:13px;border:1px solid rgba(255,255,255,.12);background:#0c121a;color:#fff;padding:0 14px;outline:none}
.password-row input:focus{border-color:rgba(62,140,255,.7);box-shadow:0 0 0 4px rgba(62,140,255,.12)}
.password-row button,.primary-login{height:48px;border-radius:13px;border:1px solid rgba(255,255,255,.1);background:#172130;color:#fff;padding:0 16px}
.primary-login{width:100%;background:linear-gradient(135deg,var(--accent),#8b1212);font-weight:800;letter-spacing:.4px}
.login-error{min-height:22px;color:#ff7a7a;font-size:12px;margin:10px 0}
.login-card small{display:block;color:#748396;font-size:11px;line-height:1.45}
.app-shell{height:100%;display:flex;flex-direction:column}
.topbar{height:72px;padding:0 16px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,rgba(0,0,0,.92),rgba(10,11,15,.9));display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:18px}
.brand-wrap{display:flex;align-items:center;gap:12px;min-width:290px}
.brand-logo{width:46px;height:46px;object-fit:contain;border-radius:50%}
.brand-title{font-size:18px;font-weight:800;letter-spacing:2px}
.brand-subtitle{font-size:12px;color:var(--muted)}
.nav-tabs{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.nav-tabs a{font-size:13px;padding:10px 0;color:#d4dde7;position:relative;white-space:nowrap}
.nav-tabs a.active{color:#fff;font-weight:700}
.nav-tabs a.active::after{content:"";position:absolute;left:0;right:0;bottom:-12px;height:3px;background:var(--accent);border-radius:999px}
.topbar-actions{display:flex;align-items:center;gap:10px}
.search-box{display:grid;grid-template-columns:180px 36px;align-items:center;background:#111720;border:1px solid var(--line);border-radius:999px;overflow:hidden}
.search-box input{height:36px;border:0;background:transparent;color:#fff;padding:0 12px;outline:none;font-size:12px}
.search-box button{height:36px;border:0;background:#182335;color:#fff}
.topbar select{height:36px;background:#111720;border:1px solid var(--line);border-radius:999px;color:#eaf3fb;padding:0 12px;font-size:12px}
.icon-btn{background:#111720;border:1px solid var(--line);color:#ecf2f7;width:36px;height:36px;border-radius:50%}
.notif{position:relative}
.notif span{position:absolute;right:-2px;top:-2px;background:var(--accent);color:#fff;border-radius:999px;font-size:10px;min-width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-weight:800}
.user-chip{display:flex;align-items:center;gap:10px;background:#111720;border:1px solid var(--line);padding:8px 12px;border-radius:999px}
.user-chip strong{display:block;font-size:13px}
.user-chip small{display:block;color:var(--muted);font-size:10px}
.status-online{width:10px;height:10px;border-radius:50%;background:#3dda66;box-shadow:0 0 12px #3dda66}
.workspace{flex:1;min-height:0;display:grid;grid-template-columns:250px 1fr 270px;gap:10px;padding:10px}
.left-rail,.right-rail{display:flex;flex-direction:column;gap:10px;overflow:auto;padding-right:2px}
.center-stage{min-width:0;display:grid;grid-template-rows:auto minmax(410px,1fr) auto;gap:10px;overflow:hidden}
.panel-card,.kpi-card,.viewer-panel{background:linear-gradient(180deg,#101720,#0d131b);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow)}
.panel-card{padding:12px;overflow:hidden}
.panel-title{display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:700;letter-spacing:.2px;margin-bottom:10px}
.panel-title span{font-weight:500;color:var(--muted);font-size:11px}
.panel-title button{background:transparent;border:0;color:#b5c2d2;font-size:20px;line-height:1}
.kpi-row{display:grid;grid-template-columns:repeat(9,minmax(0,1fr));gap:10px}
.kpi-card{padding:10px 12px;min-height:88px;position:relative;overflow:hidden}
.kpi-card label{display:block;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:6px}
.kpi-card strong{font-size:30px;line-height:1.1;display:block}
.kpi-card small{display:block;color:#9ed3a3;font-size:11px;margin-top:6px}
.kpi-card.narrow strong{font-size:24px}
.kpi-card.alerts strong{display:flex;gap:12px}.kpi-card .crit{color:var(--red)}.kpi-card .warn{color:var(--yellow)}
.sparkline{position:absolute;left:0;right:0;bottom:0;height:34px;opacity:.85;background:linear-gradient(180deg,transparent,rgba(0,0,0,.12)),linear-gradient(90deg,transparent 0 5%,rgba(78,153,255,.15) 5% 10%,transparent 10% 14%,rgba(78,153,255,.32) 14% 18%,transparent 18% 24%,rgba(78,153,255,.18) 24% 29%,transparent 29% 36%,rgba(78,153,255,.45) 36% 40%,transparent 40% 45%,rgba(78,153,255,.22) 45% 52%,transparent 52% 56%,rgba(78,153,255,.3) 56% 63%,transparent 63% 70%,rgba(78,153,255,.5) 70% 78%,transparent 78% 84%,rgba(78,153,255,.22) 84% 92%,transparent 92% 100%)}
.viewer-panel{position:relative;min-height:0;overflow:hidden;background:linear-gradient(180deg,#ebecef,#f5f5f6)}
#viewer{position:absolute;inset:0}
.viewer-toolbar{position:absolute;z-index:3;display:flex;gap:8px;background:rgba(11,18,28,.9);padding:8px;border-radius:10px;border:1px solid rgba(255,255,255,.06);backdrop-filter:blur(10px)}
.viewer-toolbar.top-left{left:14px;top:14px}
.mode,.tool-btn{border:1px solid rgba(255,255,255,.08);background:#1a2430;color:#eaf4ff;border-radius:8px;height:34px;min-width:38px;padding:0 12px;font-size:12px}
.mode.active,.tool-btn.active{background:var(--accent);color:#fff}
.time-chip{position:absolute;right:14px;top:14px;z-index:3;padding:9px 12px;border-radius:10px;background:rgba(11,18,28,.92);border:1px solid rgba(255,255,255,.08);color:#ecf3fb;font-size:12px}
.selected-popup{position:absolute;right:14px;top:58px;z-index:5;width:315px;max-width:calc(100% - 28px);padding:12px;border-radius:14px;background:rgba(10,16,24,.94);border:1px solid rgba(255,255,255,.1);box-shadow:var(--shadow);backdrop-filter:blur(12px);transform:translateX(0)}
#selectedDetails{font-size:12px;line-height:1.5;color:#cbd8e7}
#selectedDetails .asset-name{font-size:17px;font-weight:800;color:#fff;margin-bottom:6px}
#selectedDetails .asset-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}
#selectedDetails .asset-grid div{padding:8px;border-radius:10px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.05)}
.floating-controls{position:absolute;left:50%;bottom:16px;transform:translateX(-50%);z-index:3;display:flex;gap:10px;padding:10px 14px;background:rgba(13,18,26,.92);border:1px solid rgba(255,255,255,.06);border-radius:16px;box-shadow:var(--shadow)}
.floating-controls button,.zoom-controls button{background:#111823;border:1px solid rgba(255,255,255,.07);color:#eaf2fb;border-radius:10px;min-width:40px;height:40px}
.floating-controls button:first-child{background:var(--accent)}
.zoom-controls{position:absolute;right:14px;bottom:16px;z-index:3;display:flex;flex-direction:column;gap:8px}
.sim-controls{position:absolute;left:14px;bottom:16px;width:230px;z-index:3;padding:10px 12px;background:rgba(13,18,26,.9);border:1px solid rgba(255,255,255,.08);border-radius:14px;color:#eef6ff}
.sim-controls label{display:flex;justify-content:space-between;font-size:11px;color:#c4d2e2;margin-bottom:8px}.sim-controls input{width:100%}
.bottom-grid{display:grid;grid-template-columns:1.15fr 1fr 1.05fr 1.2fr 1.25fr .85fr;gap:10px;min-height:230px}
.tall{min-height:220px}
.donut-row{display:grid;grid-template-columns:92px 1fr;gap:10px;align-items:center}
.donut{width:92px;height:92px;border-radius:50%;display:grid;place-items:center;position:relative}
.donut::before{content:"";position:absolute;inset:0;border-radius:50%;background:conic-gradient(var(--blue),#5eb4ff,#6bd0d8,#6ad95d,#ffcd4c,#ff7d3d,#ef4d78,var(--blue))}
.donut::after{content:"";position:absolute;inset:14px;border-radius:50%;background:linear-gradient(180deg,#101720,#0d131b)}
.donut span{position:relative;z-index:2;text-align:center}.donut b{display:block;font-size:24px}.donut small{color:var(--muted);font-size:10px}
.donut-fleet::before{background:conic-gradient(#2f8cff 0 35%,#ff9a3d 35% 60%,#8f67f5 60% 82%,#3e4b59 82% 100%)}
.donut-tool::before{background:conic-gradient(#2f8cff 0 8%,#8796a5 8% 100%)}
.legend{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.legend li{display:flex;align-items:center;gap:8px;color:#cbd7e3;font-size:12px}
.legend.small li{font-size:11px;color:var(--muted)}
.sw{width:10px;height:10px;border-radius:50%;display:inline-block}.sw.production{background:#3e8cff}.sw.tooling{background:#ff9a3d}.sw.inspect{background:#8f67f5}.sw.idle{background:#7b8795}
.compact li{font-size:11px}
.micro-chart{height:44px;border-radius:10px;border:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(0,0,0,.12)),linear-gradient(90deg,transparent 0 7%,rgba(55,150,255,.3) 7% 12%,transparent 12% 18%,rgba(55,150,255,.18) 18% 24%,transparent 24% 30%,rgba(55,150,255,.4) 30% 35%,transparent 35% 42%,rgba(55,150,255,.22) 42% 50%,transparent 50% 56%,rgba(55,150,255,.34) 56% 62%,transparent 62% 69%,rgba(55,150,255,.2) 69% 76%,transparent 76% 82%,rgba(55,150,255,.44) 82% 88%,transparent 88% 100%)}
.status-row{display:grid;grid-template-columns:34px 1fr 50px;gap:8px;align-items:center;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.05)}
.status-row:last-child{border-bottom:none}
.status-row .dot{width:10px;height:10px;border-radius:50%;display:inline-block;background:#36d063;box-shadow:0 0 10px rgba(54,208,99,.6);margin-left:8px}
.status-row .dot.setup{background:#f4c244;box-shadow:0 0 10px rgba(244,194,68,.5)}
.status-row .dot.idle{background:#718090;box-shadow:none}
.status-row .label strong{display:block;font-size:12px}.status-row .label small{display:block;color:var(--muted);font-size:10px}
.bar{height:7px;border-radius:99px;background:#1c2431;overflow:hidden;position:relative}.bar i{position:absolute;inset:0 auto 0 0;width:var(--w);background:linear-gradient(90deg,#39cf69,#95dd58)}
.personnel-list{display:flex;flex-direction:column;gap:7px}
.personnel-row{display:grid;grid-template-columns:32px 1fr auto;gap:8px;align-items:center;padding:7px;border-radius:10px;background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.05)}
.worker-avatar{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,#ffcd4c,#ff8d2b);color:#111;font-weight:900;font-size:12px}
.personnel-row strong{font-size:12px}.personnel-row small{display:block;color:var(--muted);font-size:10px}
.safety-strip{margin-top:10px;padding:9px;border-radius:10px;background:rgba(79,213,127,.12);border:1px solid rgba(79,213,127,.25);color:#7cea9e;font-size:12px;text-align:center;font-weight:700}
.safety-strip.warn{background:rgba(255,205,76,.14);border-color:rgba(255,205,76,.32);color:#ffdc75}
.data-table{width:100%;border-collapse:collapse;font-size:11px}.data-table th,.data-table td{padding:6px 4px;border-bottom:1px solid rgba(255,255,255,.05);text-align:left;vertical-align:top}.data-table th{color:var(--muted);font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:.35px}.data-table.tight td,.data-table.tight th{padding:6px 2px}
.pill{display:inline-block;padding:2px 8px;border-radius:999px;font-size:10px;font-weight:700}.pill.ok{background:rgba(79,213,127,.15);color:#73e296}.pill.warn{background:rgba(255,205,76,.15);color:#ffd66e}.pill.critical{background:rgba(255,81,81,.14);color:#ff6b6b}
.inspection-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.inspection-stat{padding:10px;border-radius:10px;border:1px solid rgba(255,255,255,.05);background:rgba(255,255,255,.02)}
.inspection-stat label{display:block;color:var(--muted);font-size:10px;text-transform:uppercase}.inspection-stat strong{display:block;font-size:18px;margin-top:6px}.inspection-stat .good{color:#62d581}.inspection-stat .bad{color:#ff6969}.inspection-stat small{font-size:10px;color:var(--muted)}
.part-preview{margin-top:12px;display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center}.part-visual{height:92px;border-radius:12px;background:linear-gradient(135deg,#0d1219,#151e2a);display:grid;place-items:center;border:1px solid var(--line)}
.part-shape{width:82px;height:82px;border-radius:18px;background:linear-gradient(135deg,#c8d2dd,#8894a5);box-shadow:inset -15px -15px 24px rgba(0,0,0,.14), inset 12px 12px 18px rgba(255,255,255,.35);position:relative}
.part-shape::before,.part-shape::after{content:"";position:absolute;border-radius:50%;background:#27323f;inset:20px}.part-shape::after{inset:32px;background:#9ba5b3}
.tolerance-banner{text-align:center;margin-top:10px;padding:8px 10px;border-radius:10px;background:rgba(79,213,127,.14);color:#75e391;font-size:12px;font-weight:800;letter-spacing:1px}
.event-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.event-list li{display:grid;grid-template-columns:46px 1fr;gap:10px;font-size:11px;align-items:start;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.05)}.event-list li:last-child{border-bottom:none}
.event-list time{color:var(--muted)}.event-list .sev-good{color:#6cdc81}.event-list .sev-bad{color:#ff6969}.event-list .sev-info{color:#5ba8ff}.event-list .sev-warn{color:#ffd75b}
.route-map{height:118px;border-radius:12px;border:1px solid var(--line);background:
linear-gradient(90deg,transparent 0 10%,rgba(65,122,201,.85) 10% 11%,transparent 11% 33%,rgba(65,122,201,.85) 33% 34%,transparent 34% 56%,rgba(65,122,201,.85) 56% 57%,transparent 57% 79%,rgba(65,122,201,.85) 79% 80%,transparent 80%),
linear-gradient(transparent 0 16%,rgba(65,122,201,.85) 16% 17%,transparent 17% 49%,rgba(65,122,201,.85) 49% 50%,transparent 50% 82%,rgba(65,122,201,.85) 82% 83%,transparent 83%),
linear-gradient(180deg,#0c1117,#121b26);position:relative;overflow:hidden}
.route-map::before{content:"";position:absolute;inset:0;background:
radial-gradient(circle at 15% 17%,rgba(255,255,255,.85) 0 2%,transparent 2.5%),
radial-gradient(circle at 38% 17%,rgba(255,255,255,.85) 0 2%,transparent 2.5%),
radial-gradient(circle at 61% 17%,rgba(255,255,255,.85) 0 2%,transparent 2.5%),
radial-gradient(circle at 84% 17%,rgba(255,255,255,.85) 0 2%,transparent 2.5%),
radial-gradient(circle at 15% 50%,rgba(255,255,255,.85) 0 2%,transparent 2.5%),
radial-gradient(circle at 38% 50%,rgba(255,255,255,.85) 0 2%,transparent 2.5%),
radial-gradient(circle at 61% 50%,rgba(255,255,255,.85) 0 2%,transparent 2.5%),
radial-gradient(circle at 84% 50%,rgba(255,255,255,.85) 0 2%,transparent 2.5%),
radial-gradient(circle at 15% 83%,rgba(255,255,255,.85) 0 2%,transparent 2.5%),
radial-gradient(circle at 38% 83%,rgba(255,255,255,.85) 0 2%,transparent 2.5%),
radial-gradient(circle at 61% 83%,rgba(255,255,255,.85) 0 2%,transparent 2.5%),
radial-gradient(circle at 84% 83%,rgba(255,255,255,.85) 0 2%,transparent 2.5%)}
.route-map::after{content:"";position:absolute;left:8%;right:8%;top:20%;bottom:20%;border:2px dashed rgba(60,220,130,.85);border-radius:16px;box-shadow:0 0 0 1px rgba(255,153,60,.4) inset}
.route-legend{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px;font-size:10px;color:var(--muted)}
.control-buttons{display:grid;grid-template-columns:1fr;gap:7px;margin-top:10px}.control-buttons button{height:32px;border:1px solid rgba(255,255,255,.08);background:#152131;color:#eaf2fb;border-radius:9px;font-size:11px}.control-buttons button:hover{border-color:rgba(62,140,255,.7)}
.process-flow{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;align-items:center}.process-flow div{position:relative;padding:10px 8px;border-radius:10px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);font-size:10.5px;text-align:center;min-height:72px;display:flex;align-items:center;justify-content:center}.process-flow div:not(:last-child)::after{content:"→";position:absolute;right:-10px;top:50%;transform:translateY(-50%);color:#6ea9f8;font-size:18px}
.process-kpis{margin-top:12px;display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.process-kpis div{padding:8px;border-radius:10px;background:rgba(255,255,255,.025);text-align:center;border:1px solid rgba(255,255,255,.05)}.process-kpis strong{display:block;font-size:16px}.process-kpis span{display:block;color:var(--muted);font-size:10px;margin-top:3px}
.switch-list{display:flex;flex-direction:column;gap:10px}.switch-list label{font-size:12px;color:#c9d5e3;display:flex;gap:8px;align-items:center}.switch-list input{accent-color:var(--accent)}
.tool-summary-head{display:grid;grid-template-columns:102px 1fr;gap:12px;align-items:center}
.bar-stack{display:flex;flex-direction:column;gap:10px}.bar-stack div{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;font-size:11px}.bar-stack span{color:#d5deea}.bar-stack b{color:var(--muted);font-weight:600}.bar-stack i{grid-column:1 / -1;height:7px;border-radius:999px;background:rgba(255,255,255,.06);position:relative;overflow:hidden}.bar-stack i::before{content:"";position:absolute;left:0;top:0;bottom:0;width:var(--w);background:var(--c)}
.good{color:#61d781}.bad{color:#ff6767}
.toast{position:fixed;left:50%;bottom:28px;transform:translate(-50%,18px);z-index:10000;background:rgba(11,18,28,.96);border:1px solid rgba(255,255,255,.12);box-shadow:var(--shadow);border-radius:999px;padding:12px 18px;color:#fff;font-size:13px;opacity:0;pointer-events:none;transition:.25s ease}
.toast.show{opacity:1;transform:translate(-50%,0)}
@media (max-width:1600px){
  .workspace{grid-template-columns:230px 1fr 250px}
  .kpi-row{grid-template-columns:repeat(5,minmax(0,1fr))}
  .bottom-grid{grid-template-columns:repeat(3,1fr)}
  .center-stage{grid-template-rows:auto minmax(390px,1fr) auto}
}
@media (max-width:1120px){
  body{overflow:auto}
  .workspace{grid-template-columns:1fr}
  .left-rail,.right-rail{display:none}
  .bottom-grid{grid-template-columns:1fr 1fr}
  .nav-tabs{display:none}
  .topbar{grid-template-columns:auto 1fr}.topbar-actions{justify-content:flex-end}
}

/* v3 log/database upgrades */
.log-scroller{max-height:168px;overflow:auto;padding-right:4px;border-radius:10px;scrollbar-width:thin;scrollbar-color:#3e8cff rgba(255,255,255,.04)}
.log-scroller.small-scroll{max-height:150px}
.log-scroller::-webkit-scrollbar{width:8px;height:8px}.log-scroller::-webkit-scrollbar-track{background:rgba(255,255,255,.04);border-radius:99px}.log-scroller::-webkit-scrollbar-thumb{background:rgba(62,140,255,.65);border-radius:99px}
.log-note,.db-note{margin-top:8px;color:#8fa0b4;font-size:10.5px;line-height:1.45}
.database-export{margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.07);display:grid;gap:8px}
.download-btn,.database-export button{height:34px;border:1px solid rgba(255,255,255,.08);background:#152131;color:#eaf2fb;border-radius:9px;font-size:11px;display:flex;align-items:center;justify-content:center;text-decoration:none}
.download-btn:hover,.database-export button:hover{border-color:rgba(62,140,255,.75);background:#1b2a40}
.database-export .download-btn:first-of-type{background:linear-gradient(135deg,#d12626,#8b1212);border-color:rgba(255,255,255,.12);font-weight:800}
.data-table tbody tr:hover{background:rgba(62,140,255,.08)}

.control-buttons.stack{gap:8px}
.database-status{display:grid;grid-template-columns:1fr;gap:8px}
.database-status div{padding:10px;border-radius:10px;background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.05)}
.database-status strong{display:block;font-size:16px;color:#fff}.database-status span{display:block;font-size:10px;color:var(--muted);margin-top:3px}
.mode-active{outline:2px solid rgba(62,140,255,.75);box-shadow:0 0 0 4px rgba(62,140,255,.12)}
.selected-popup.hidden{display:none}
.operation-badge{display:inline-block;margin-top:7px;padding:3px 7px;border-radius:999px;background:rgba(62,140,255,.14);color:#8fc5ff;font-size:10px;font-weight:700}

/* v5 adaptive responsive UI: iPhone / iPad / desktop / Mac / control-room */
.mobile-quick-nav,.mobile-bottom-nav{display:none}
#deviceModeSelect{min-width:138px}
body.device-iphone .testing-badge::after,body.device-mobile .testing-badge::after{content:" · iPhone"}
body.device-ipad .testing-badge::after,body.device-tablet .testing-badge::after{content:" · iPad"}
body.device-mac .testing-badge::after{content:" · Mac"}
body.device-controlroom .testing-badge::after{content:" · Control Room"}
body.device-desktop .testing-badge::after{content:" · Desktop"}
body.device-controlroom .workspace{grid-template-columns:300px 1fr 320px}
body.device-controlroom .viewer-panel{min-height:560px}
body.device-controlroom .kpi-row{grid-template-columns:repeat(9,minmax(0,1fr))}
body.device-controlroom .bottom-grid{grid-template-columns:repeat(6,minmax(0,1fr))}

@media (hover:none){
  button,.nav-tabs a,.mode,.tool-btn,.download-btn{min-height:42px}
  .data-table th,.data-table td{padding-top:8px;padding-bottom:8px}
  .log-scroller{scrollbar-width:auto}
}

@media (max-width:1180px){
  body{overflow:auto;-webkit-text-size-adjust:100%;padding-bottom:env(safe-area-inset-bottom)}
  .app-shell{height:auto;min-height:100svh}
  .topbar{position:sticky;top:0;z-index:50;height:auto;min-height:70px;grid-template-columns:1fr;gap:10px;padding:10px 12px calc(8px + env(safe-area-inset-top))}
  .brand-wrap{min-width:0;width:100%;justify-content:flex-start}.brand-logo{width:42px;height:42px}.brand-title{font-size:17px}.brand-subtitle{font-size:11px}.testing-badge{font-size:10px;color:#8fc5ff;margin-top:2px}
  .nav-tabs{display:flex;justify-content:flex-start;gap:8px;overflow-x:auto;white-space:nowrap;padding:0 0 4px;scrollbar-width:none}.nav-tabs::-webkit-scrollbar{display:none}.nav-tabs a{padding:9px 10px;border:1px solid var(--line);border-radius:999px;background:#111720}.nav-tabs a.active::after{display:none}.nav-tabs a.active{background:linear-gradient(135deg,var(--accent),#8b1212)}
  .topbar-actions{width:100%;display:grid;grid-template-columns:1fr 1fr auto auto;gap:8px}.search-box{grid-column:1 / -1;grid-template-columns:1fr 42px;width:100%;border-radius:14px}.search-box input{height:42px;font-size:13px}.search-box button{height:42px}.topbar select{height:42px;min-width:0;width:100%;border-radius:14px}.user-chip{display:none}.icon-btn{width:42px;height:42px}
  .mobile-quick-nav{display:flex;position:sticky;top:var(--adaptive-top,0);z-index:45;gap:8px;padding:8px 10px;background:rgba(6,9,13,.92);border-bottom:1px solid var(--line);backdrop-filter:blur(12px);overflow-x:auto;scrollbar-width:none}.mobile-quick-nav::-webkit-scrollbar{display:none}.mobile-quick-nav button{flex:0 0 auto;border:1px solid var(--line);background:#111720;color:#dce9f7;border-radius:999px;padding:9px 14px;font-weight:800;font-size:12px}.mobile-quick-nav button.active{background:linear-gradient(135deg,var(--accent),#8b1212);color:#fff}
  .workspace{display:flex;flex-direction:column;gap:10px;padding:10px;min-height:0;overflow:visible}.center-stage{order:1;display:flex;flex-direction:column;gap:10px;overflow:visible}.left-rail{order:2;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;overflow:visible;padding:0}.right-rail{order:3;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;overflow:visible;padding:0}.panel-card{min-width:0}.kpi-row{display:flex;overflow-x:auto;gap:10px;padding-bottom:2px;scroll-snap-type:x proximity}.kpi-card{flex:0 0 180px;scroll-snap-align:start;min-height:92px}.kpi-card strong{font-size:26px}.viewer-panel{height:62svh;min-height:460px;max-height:760px}.bottom-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;min-height:0}.tall{min-height:220px}.log-scroller{max-height:210px}.floating-controls{left:50%;bottom:12px;max-width:calc(100% - 24px);overflow-x:auto;gap:8px;padding:8px}.floating-controls button,.zoom-controls button{min-width:44px;height:44px}.viewer-toolbar.top-left{left:10px;right:10px;top:10px;overflow-x:auto}.viewer-toolbar{gap:6px}.time-chip{top:58px;right:10px;font-size:11px}.selected-popup{top:auto;left:10px;right:10px;bottom:74px;width:auto;max-height:38svh;overflow:auto}.sim-controls{left:10px;bottom:68px;width:205px}.zoom-controls{right:10px;bottom:74px}.process-flow{grid-template-columns:1fr 1fr}.process-flow div:not(:last-child)::after{display:none}.process-kpis{grid-template-columns:repeat(2,1fr)}
}

@media (max-width:720px){
  html,body{width:100%;overflow-x:hidden}.topbar{padding-left:10px;padding-right:10px}.brand-logo{width:38px;height:38px}.brand-title{font-size:16px}.brand-subtitle{max-width:calc(100vw - 72px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar-actions{grid-template-columns:1fr 1fr 44px 44px}.topbar select{font-size:11px;padding:0 8px}.nav-tabs{gap:6px}.nav-tabs a{font-size:12px;padding:8px 10px}.workspace{padding:8px 8px calc(84px + env(safe-area-inset-bottom));gap:8px}.mobile-bottom-nav{display:grid;position:fixed;left:0;right:0;bottom:0;z-index:80;grid-template-columns:repeat(5,1fr);gap:0;padding:7px 8px calc(7px + env(safe-area-inset-bottom));background:rgba(7,10,14,.96);border-top:1px solid var(--line);box-shadow:0 -18px 50px rgba(0,0,0,.45);backdrop-filter:blur(16px)}.mobile-bottom-nav button{border:0;background:transparent;color:#aebccd;border-radius:12px;min-height:50px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}.mobile-bottom-nav button b{font-size:12px}.mobile-bottom-nav button span{font-size:10px}.mobile-bottom-nav button.active{background:linear-gradient(135deg,rgba(209,38,38,.9),rgba(139,18,18,.9));color:#fff}.mobile-quick-nav{display:none}.kpi-row{margin:0 -8px;padding:0 8px 2px}.kpi-card{flex-basis:158px}.kpi-card strong{font-size:23px}.viewer-panel{height:58svh;min-height:390px;border-radius:12px}.viewer-toolbar.top-left{top:8px;left:8px;right:8px;padding:6px}.mode,.tool-btn{height:38px;min-width:42px;padding:0 10px;font-size:11px}.time-chip{display:none}.selected-popup{bottom:70px;max-height:45svh;font-size:12px}.floating-controls{bottom:8px;padding:6px 8px}.floating-controls button,.zoom-controls button{min-width:40px;height:40px}.sim-controls{left:8px;right:8px;bottom:56px;width:auto;padding:8px 10px}.zoom-controls{right:8px;bottom:112px}.bottom-grid,.left-rail,.right-rail{grid-template-columns:1fr}.inspection-grid,.metric-grid{grid-template-columns:1fr 1fr}.donut-row,.tool-summary-head{grid-template-columns:82px 1fr}.donut{width:82px;height:82px}.panel-card{border-radius:12px;padding:11px}.panel-title{font-size:12px}.log-scroller{max-height:230px;overflow:auto}.log-scroller .data-table{min-width:620px}.data-table{font-size:10.5px}.route-map{height:108px}.control-buttons button,.database-export button,.download-btn{height:40px}.process-flow{grid-template-columns:1fr}.process-flow div{min-height:44px}.part-preview{grid-template-columns:1fr}.legend.small{flex-direction:row;flex-wrap:wrap}.toast{bottom:calc(78px + env(safe-area-inset-bottom));width:calc(100% - 28px);text-align:center;border-radius:16px}
}

@media (max-width:430px){
  .topbar-actions{grid-template-columns:1fr 1fr 42px 42px}.search-box{grid-column:1 / -1}.kpi-card{flex-basis:148px}.kpi-card label{font-size:10px}.kpi-card strong{font-size:21px}.viewer-panel{height:56svh;min-height:360px}.sim-controls{display:none}.selected-popup{left:8px;right:8px}.brand-subtitle{display:none}.testing-badge{display:block}.panel-card{padding:10px}.inspection-stat strong{font-size:16px}.process-kpis{grid-template-columns:1fr 1fr}.floating-controls{max-width:calc(100% - 16px)}.floating-controls button:nth-child(n+6){display:none}.zoom-controls{display:none}.viewer-toolbar .tool-btn{padding:0 9px}.log-scroller{max-height:250px}
}

/* Forced device profiles from selector */
body.device-iphone{overflow:auto}body.device-iphone .workspace{display:flex;flex-direction:column;padding:8px 8px calc(84px + env(safe-area-inset-bottom))}body.device-iphone .center-stage{order:1;display:flex;flex-direction:column}body.device-iphone .left-rail,body.device-iphone .right-rail{display:grid;grid-template-columns:1fr;overflow:visible;padding:0}body.device-iphone .kpi-row{display:flex;overflow-x:auto}body.device-iphone .kpi-card{flex:0 0 155px}body.device-iphone .bottom-grid{grid-template-columns:1fr}body.device-iphone .viewer-panel{height:58svh;min-height:380px}body.device-iphone .mobile-bottom-nav{display:grid}body.device-iphone .mobile-quick-nav{display:none}
body.device-ipad .workspace,body.device-tablet .workspace{display:flex;flex-direction:column}body.device-ipad .left-rail,body.device-ipad .right-rail,body.device-tablet .left-rail,body.device-tablet .right-rail{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));overflow:visible;padding:0}body.device-ipad .bottom-grid,body.device-tablet .bottom-grid{grid-template-columns:repeat(2,minmax(0,1fr))}body.device-ipad .viewer-panel,body.device-tablet .viewer-panel{height:64svh;min-height:520px}body.device-ipad .kpi-row,body.device-tablet .kpi-row{grid-template-columns:repeat(3,minmax(0,1fr))}
body.device-desktop .mobile-bottom-nav,body.device-mac .mobile-bottom-nav,body.device-controlroom .mobile-bottom-nav{display:none!important}

/* v6 iPhone 3D visibility + navigation fix */
#viewer,
#viewer canvas{
  width:100% !important;
  height:100% !important;
  display:block !important;
  touch-action:none;
  -webkit-user-select:none;
  user-select:none;
}
.viewer-panel{
  isolation:isolate;
  overflow:hidden;
  position:relative;
}
.mobile-3d-hint{
  display:none;
  position:absolute;
  left:10px;
  right:10px;
  top:58px;
  z-index:4;
  padding:8px 10px;
  border-radius:12px;
  background:rgba(10,18,29,.82);
  border:1px solid rgba(255,255,255,.12);
  color:#eaf4ff;
  font-size:11px;
  line-height:1.35;
  pointer-events:none;
  backdrop-filter:blur(10px);
}
.mobile-full-btn{display:none}

@media (max-width:720px){
  .mobile-full-btn{display:inline-flex;align-items:center;justify-content:center}
  .mobile-3d-hint{display:block}
  #factoryPanel{display:flex;flex-direction:column}
  #viewerPanel{order:-20;height:68svh;min-height:500px;max-height:none;margin-bottom:8px;background:#eaf2fa}
  #kpiPanel{order:1}
  #logsPanel{order:2}
  .viewer-toolbar.top-left{right:8px;overflow-x:auto;scrollbar-width:none;padding-right:8px}
  .viewer-toolbar.top-left::-webkit-scrollbar{display:none}
  .floating-controls{bottom:10px;left:8px;right:8px;transform:none;justify-content:flex-start;overflow-x:auto;scrollbar-width:none}
  .floating-controls::-webkit-scrollbar{display:none}
  .sim-controls{display:none!important}
  .zoom-controls{display:flex;right:8px;bottom:66px}
  .selected-popup{display:none}
  body.mobile-selected-open .selected-popup{display:block}
}

@media (max-width:430px){
  #viewerPanel{height:70svh;min-height:510px}
  .mobile-3d-hint{top:54px;font-size:10.5px;padding:7px 9px}
  .viewer-toolbar .tool-btn{padding:0 8px}
  .viewer-toolbar .tool-btn:not(.mobile-full-btn){min-width:54px}
}

body.device-iphone #viewerPanel{
  order:-20;
  height:70svh;
  min-height:520px;
  max-height:none;
}
body.device-iphone #kpiPanel{order:1}
body.device-iphone #logsPanel{order:2}
body.device-iphone .mobile-3d-hint{display:block}
body.device-iphone #viewerPanel canvas{touch-action:none}

body.mobile-3d-focus{overflow:hidden!important}
body.mobile-3d-focus #viewerPanel{
  position:fixed!important;
  inset:calc(env(safe-area-inset-top) + 6px) 6px calc(8px + env(safe-area-inset-bottom)) 6px;
  z-index:120;
  height:auto!important;
  min-height:0!important;
  max-height:none!important;
  border-radius:18px;
  box-shadow:0 30px 90px rgba(0,0,0,.65);
}
body.mobile-3d-focus .mobile-bottom-nav{display:none!important}
body.mobile-3d-focus .viewer-toolbar.top-left{top:8px;left:8px;right:8px}
body.mobile-3d-focus .mobile-3d-hint{top:58px}
body.mobile-3d-focus .floating-controls{bottom:10px}
body.mobile-3d-focus .zoom-controls{display:flex;bottom:70px}
body.mobile-3d-focus .mobile-full-btn{background:#ff5151;color:#fff}

/* v7 iPhone-safe 3D layout fallback
   This is intentionally DOM/CSS based, so iPhone will still show the factory layout
   even when WebGL, import maps, or CDN modules fail. */
#viewer{background:#eaf2fa;position:absolute;inset:0;overflow:hidden}
#viewer canvas{position:absolute!important;inset:0!important;z-index:1!important;background:#eaf2fa!important}
.mobile-safe-3d{display:none;position:absolute;inset:0;z-index:20;background:linear-gradient(180deg,#edf6ff,#dfeaf6 58%,#d5e5f5);overflow:hidden;color:#142033;touch-action:none;-webkit-user-select:none;user-select:none}
.safe3d-header{position:absolute;left:10px;right:10px;top:54px;z-index:25;display:flex;justify-content:space-between;gap:8px;align-items:center;padding:8px 10px;border-radius:13px;background:rgba(255,255,255,.9);border:1px solid rgba(40,80,120,.16);box-shadow:0 10px 25px rgba(31,58,90,.12);font-size:11px;backdrop-filter:blur(10px)}
.safe3d-header strong{font-size:12px;color:#102136}.safe3d-header span{color:#49637c;text-align:right}
.safe3d-viewport{position:absolute;left:0;right:0;top:0;bottom:54px;overflow:hidden;touch-action:none;cursor:grab}
.safe3d-viewport:active{cursor:grabbing}
.safe3d-scene{position:absolute;left:0;top:0;width:1000px;height:620px;transform-origin:0 0;background:linear-gradient(90deg,rgba(41,124,224,.055) 1px,transparent 1px),linear-gradient(rgba(41,124,224,.055) 1px,transparent 1px),linear-gradient(180deg,#f8fbff,#eef5fb);background-size:50px 50px;border:1px solid rgba(50,100,150,.16);border-radius:18px;box-shadow:0 28px 70px rgba(31,58,90,.22)}
.safe3d-flows{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none}
.safe3d-flows .lane{fill:none;stroke:#b9cce0;stroke-width:14;stroke-linecap:round;opacity:.55}
.safe3d-flows .flow{fill:none;stroke-width:8;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:18 16;filter:drop-shadow(0 2px 5px rgba(0,0,0,.18));animation:safeFlow 2.5s linear infinite}
.safe3d-flows .flow-prod{stroke:#1e88ff}.safe3d-flows .flow-prod.alt{animation-duration:3.1s;opacity:.85}.safe3d-flows .flow-tool{stroke:#ff9a3d;animation-duration:2.15s}.safe3d-flows .flow-qc{stroke:#8d6bf2;animation-duration:2.85s}
@keyframes safeFlow{to{stroke-dashoffset:-68}}
.safe-station,.safe-toolbank,.safe-charger,.safe-machine,.safe-amr,.safe-worker{position:absolute;z-index:4;border:1px solid rgba(43,95,150,.18);box-shadow:0 14px 26px rgba(31,58,90,.16)}
.safe-station{left:36px;width:160px;height:86px;border-radius:16px;background:linear-gradient(135deg,#ffffff,#dcecff);display:flex;flex-direction:column;align-items:flex-start;justify-content:center;padding:12px;transform:skewY(-4deg)}
.safe-station b,.safe-toolbank b,.safe-charger b{font-size:14px;color:#102136}.safe-station span,.safe-toolbank span,.safe-charger span{font-size:10px;color:#49637c;line-height:1.3;margin-top:4px}.station-a{top:92px}.station-b{top:430px}
.safe-toolbank{right:28px;top:70px;width:180px;height:168px;border-radius:18px;background:linear-gradient(135deg,#ffffff,#e4f0ff);padding:12px;display:flex;flex-direction:column;justify-content:center;border-color:rgba(255,154,61,.45)}
.safe-toolbank:before{content:"";position:absolute;left:12px;right:12px;top:64px;height:54px;border-radius:10px;background:repeating-linear-gradient(90deg,#9aaabd 0 7px,#f6f9fd 7px 12px);box-shadow:inset 0 0 0 1px rgba(0,0,0,.08)}
.safe-toolbank i{margin-top:auto;font-style:normal;font-size:10px;color:#ff7b1e;font-weight:800}
.safe-charger{right:34px;bottom:28px;width:152px;height:70px;border-radius:15px;background:linear-gradient(135deg,#273849,#172232);color:#eef6ff;padding:12px}.safe-charger b{color:#fff}.safe-charger span{color:#b7c6d5}
.safe-machine{width:118px;height:88px;border-radius:14px;background:linear-gradient(180deg,#ffffff,#dfe9f4);transform:skewY(-3deg);padding:7px}
.safe-machine:after{content:"";position:absolute;left:5px;right:-7px;bottom:-8px;height:10px;border-radius:0 0 14px 14px;background:#aebccd;transform:skewX(-40deg);z-index:-1;opacity:.85}
.safe-machine-top{height:22px;display:flex;justify-content:space-between;align-items:center}.safe-machine-top b{font-size:15px;color:#0d1e33}.safe-machine-top span{font-size:9px;color:#5f7287;background:#eef4fb;border-radius:999px;padding:2px 5px}
.safe-cnc-body{position:absolute;left:9px;top:33px;width:68px;height:42px;border-radius:9px;background:linear-gradient(135deg,#53697d,#25384c);box-shadow:inset 0 0 0 1px rgba(255,255,255,.18)}
.safe-cnc-body i{position:absolute;left:8px;right:8px;top:8px;height:20px;border-radius:5px;background:linear-gradient(180deg,#7bc2ff,#2c7ace);opacity:.8}.safe-cnc-body em{position:absolute;left:23px;bottom:5px;width:18px;height:8px;border-radius:50%;background:#d6dde6}
.safe-ur{position:absolute;right:10px;top:35px;width:34px;height:22px;border-radius:10px;background:#fff;border:2px solid #d12626;color:#d12626;font-size:9px;font-weight:900;display:grid;place-items:center}.safe-ur:after{content:"";position:absolute;left:-13px;top:8px;width:18px;height:4px;background:#d12626;border-radius:999px;transform:rotate(-25deg)}
.safe-dock{position:absolute;right:6px;bottom:-24px;width:54px;height:22px;border-radius:8px;background:#7ab7ff;color:#0b2b4d;font-size:9px;font-weight:900;display:grid;place-items:center;border:1px solid rgba(20,80,140,.3)}
.safe-machine.run{border-left:5px solid #4fd57f}.safe-machine.setup{border-left:5px solid #ffcd4c}.safe-machine.idle{border-left:5px solid #8796a5}
.safe-amr{width:62px;height:42px;border-radius:16px;background:linear-gradient(135deg,#287bda,#1b528e);color:#fff;font-size:10px;font-weight:900;text-align:center;padding-top:6px;border-color:rgba(255,255,255,.22);animation:safeBob 2s ease-in-out infinite}.safe-amr small{font-size:9px;color:#d8eeff}.safe-amr:after{content:"";position:absolute;left:10px;right:10px;bottom:-5px;height:6px;border-radius:50%;background:rgba(0,0,0,.22);filter:blur(2px)}
.safe-amr.tool1,.safe-amr.tool2{background:linear-gradient(135deg,#ff9a3d,#b7500d)}.safe-amr.qc1,.safe-amr.qc2{background:linear-gradient(135deg,#8d6bf2,#5532aa)}
.amr1{left:210px;top:345px}.amr2{left:455px;top:175px;animation-delay:.4s}.amr3{left:665px;top:345px;animation-delay:.8s}.tool1{right:118px;top:250px;animation-delay:.2s}.tool2{right:118px;top:420px;animation-delay:1s}.qc1{left:510px;top:508px;animation-delay:.5s}.qc2{left:315px;top:508px;animation-delay:.9s}
@keyframes safeBob{50%{transform:translateY(-4px)}}
.safe-worker{width:62px;height:30px;border-radius:999px;background:#fff6d9;border-color:rgba(255,205,76,.6);font-size:11px;font-weight:900;color:#4c3820;display:grid;place-items:center}.safe-worker.w1{left:62px;top:210px}.safe-worker.w2{left:62px;top:395px}.safe-worker.w3{right:78px;top:260px}
.safe3d-footer{position:absolute;left:8px;right:8px;bottom:8px;z-index:26;display:flex;gap:6px;align-items:center;padding:7px;border-radius:14px;background:rgba(10,18,29,.92);border:1px solid rgba(255,255,255,.12);box-shadow:0 10px 24px rgba(31,58,90,.22);overflow-x:auto;backdrop-filter:blur(10px)}
.safe3d-footer button{height:36px;border:1px solid rgba(255,255,255,.12);border-radius:10px;background:#172236;color:#fff;font-size:11px;font-weight:800;padding:0 10px;white-space:nowrap}.safe3d-footer button:last-of-type{background:#d12626}.safe3d-footer span{font-size:10px;color:#d8e6f5;white-space:nowrap;margin-left:auto}.safe3d-footer i{display:inline-block;width:9px;height:9px;border-radius:50%;margin:0 3px 0 8px}.legend-blue{background:#1e88ff}.legend-orange{background:#ff9a3d}.legend-purple{background:#8d6bf2}

@media (max-width:760px){
  body:not(.show-webgl-mobile) .mobile-safe-3d{display:block}
  body:not(.show-webgl-mobile) .viewer-toolbar.top-left,
  body:not(.show-webgl-mobile) .mobile-3d-hint,
  body:not(.show-webgl-mobile) .floating-controls,
  body:not(.show-webgl-mobile) .zoom-controls,
  body:not(.show-webgl-mobile) .selected-popup{display:none!important}
  #viewerPanel{background:#eaf2fa!important}
}
@media (max-width:430px){
  .safe3d-header{top:8px;display:block}.safe3d-header span{display:block;text-align:left;margin-top:2px}.safe3d-viewport{top:0;bottom:54px}.safe3d-footer span{display:none}.safe3d-footer button{height:34px;font-size:10px;padding:0 8px}.safe3d-scene{width:1000px;height:620px}.mobile-safe-3d{font-size:12px}
}
body.iphone-safe-layout:not(.show-webgl-mobile) .mobile-safe-3d{display:block}
body.iphone-safe-layout:not(.show-webgl-mobile) .viewer-toolbar.top-left,
body.iphone-safe-layout:not(.show-webgl-mobile) .mobile-3d-hint,
body.iphone-safe-layout:not(.show-webgl-mobile) .floating-controls,
body.iphone-safe-layout:not(.show-webgl-mobile) .zoom-controls,
body.iphone-safe-layout:not(.show-webgl-mobile) .selected-popup{display:none!important}
body.iphone-safe-layout #viewerPanel{height:72svh;min-height:500px;background:#eaf2fa!important}


/* --- v10 desktop scroll + darker machine theme + label button --- */
body{overflow-y:auto !important; overflow-x:hidden !important;}
.app-shell{min-height:100svh !important; height:auto !important;}
.topbar{position:sticky; top:0; z-index:70;}
.workspace{flex:none !important; min-height:calc(100svh - 72px) !important; height:auto !important; align-items:start;}
.left-rail,.right-rail{overflow:visible !important; align-self:start;}
.center-stage{overflow:visible !important; align-self:start;}
.bottom-grid{align-items:start;}
.panel-card{overflow:visible;}
.viewer-panel{min-height:560px;}
#viewer{background:linear-gradient(180deg,#ebeced,#f4f4f5) !important;}
.tool-btn#btnLabels.active{background:var(--accent);color:#fff;}
@media (min-width:1121px){
  .workspace{padding-bottom:18px;}
  .left-rail,.right-rail{max-height:none !important;}
  .center-stage{grid-template-rows:auto minmax(520px,auto) auto !important;}
  .viewer-panel{height:auto;}
}


/* --- v13 rollback to v10 engine + AETEC brand 3D palette only --- */
#viewer{background:linear-gradient(180deg,#f1f3f5,#f8f8f9) !important;}
.viewer-panel{background:linear-gradient(180deg,#f0f2f4,#f8f8f9) !important;}


/* --- v17 advanced CAD/CAM + in-situ inspection controls --- */
.advanced-card{border-color:rgba(209,38,38,.18);background:linear-gradient(180deg,rgba(18,25,34,.98),rgba(10,14,20,.98))}
.cam-control-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:end;margin-bottom:10px}
.cam-control-row label,.process-toolbar label{display:flex;flex-direction:column;gap:6px;font-size:11px;color:#9db0c4;font-weight:700}
.cam-control-row select{height:36px;border-radius:10px;border:1px solid rgba(255,255,255,.1);background:#0f1620;color:#e5eef9;padding:0 10px;font-weight:700}
.cadcam-preview{display:grid;grid-template-columns:118px 1fr;gap:12px;align-items:center}
.cadcam-visual{height:120px;border-radius:14px;background:linear-gradient(145deg,#eef1f4,#cfd5dc);border:1px solid rgba(255,255,255,.12);position:relative;overflow:hidden;perspective:380px;box-shadow:inset 0 0 28px rgba(0,0,0,.12)}
.cad-part{position:absolute;left:38px;top:34px;width:62px;height:50px;background:linear-gradient(135deg,#7b838c,#424a52);box-shadow:inset -10px -12px 22px rgba(0,0,0,.28), inset 9px 9px 18px rgba(255,255,255,.18), 0 12px 18px rgba(0,0,0,.22);transform:rotateX(58deg) rotateZ(-24deg);border:3px solid #d12626}
.cad-part.part-b{border-radius:50%;height:62px}.cad-part.part-c{clip-path:polygon(12% 0,88% 6%,100% 62%,62% 100%,0 78%)}.cad-part.part-d{border-radius:12px 24px 10px 28px}
.toolpath-svg{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}.toolpath-svg path{fill:none;stroke:#d12626;stroke-width:3;stroke-linecap:round;stroke-dasharray:9 6;filter:drop-shadow(0 0 3px rgba(209,38,38,.35));animation:pathdash 1.8s linear infinite}.toolpath-svg path:nth-child(2){stroke:#7a2b31;stroke-width:2.4;animation-duration:2.4s}.toolpath-svg circle{fill:#fff;stroke:#d12626;stroke-width:2;animation:cutterMove 3.2s ease-in-out infinite}@keyframes pathdash{to{stroke-dashoffset:-60}}@keyframes cutterMove{0%{transform:translate(0,0)}50%{transform:translate(116px,-54px)}100%{transform:translate(0,0)}}
.cadcam-meta strong{display:block;font-size:18px;color:#fff}.cadcam-meta span{display:block;font-size:12px;color:#cbd7e4;margin-top:4px}.cadcam-meta small{display:block;color:#8fa2b8;margin-top:5px}.nc-block{margin-top:8px;padding:8px;border-radius:10px;background:#070a0f;border:1px solid rgba(209,38,38,.28);font-family:Consolas,Monaco,monospace;font-size:11px;color:#f3dede;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cam-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px}.cam-actions button,.cam-actions .download-btn{height:36px;border:1px solid rgba(255,255,255,.08);background:#152131;color:#eaf2fb;border-radius:10px;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;text-align:center}.cam-actions button:hover{border-color:rgba(209,38,38,.65);background:#22151a}.compact-actions{grid-template-columns:1fr 1fr}
.tool-mag-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:10px}.tool-mag-summary div,.inspection-macro-grid div{padding:9px;border-radius:10px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06)}.tool-mag-summary strong,.inspection-macro-grid strong{display:block;font-size:18px;color:#fff}.tool-mag-summary span,.inspection-macro-grid small{display:block;color:#8fa2b8;font-size:10px;margin-top:3px}.inspection-macro-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}.inspection-macro-grid label{display:block;color:#9db0c4;font-size:10px;text-transform:uppercase}.benchmark-list li{grid-template-columns:36px 1fr}.advanced-chip{display:inline-flex;align-items:center;gap:5px;border-radius:999px;padding:3px 8px;background:rgba(209,38,38,.12);border:1px solid rgba(209,38,38,.28);color:#ffb9b9;font-size:10px;font-weight:800;margin:2px 4px 2px 0}.cam-select-hint{margin-top:8px;font-size:11px;color:#9fb2c6}.tool-row-warn{color:#ffd66e}.tool-row-bad{color:#ff7777}.tool-row-ok{color:#78e399}
@media(max-width:900px){.cadcam-preview{grid-template-columns:1fr}.cadcam-visual{height:145px}.cam-actions{grid-template-columns:1fr}.inspection-macro-grid{grid-template-columns:1fr}.tool-mag-summary{grid-template-columns:1fr 1fr 1fr}}
