/* =========================================================
   desenho-tecnico.css — Configurador / Desenho Técnico ER|ES
   Porte do artefato Claude Designer, COM ESCOPO em .vpdt para
   não colidir com o CSS do VP Gestão. Variáveis locais p/ fidelidade.
   ========================================================= */

.vpdt {
  --vp-yellow:#FFD400; --vp-yellow-700:#B89800; --vp-yellow-100:#FFF4B8; --vp-yellow-50:#FFFBE5;
  --vp-black:#0E0E0E; --vp-ink:#1A1A1A; --vp-graphite:#2B2B2B;
  --vp-steel:#8A8A8A; --vp-steel-300:#B8B8B8; --vp-steel-200:#D4D4D4; --vp-steel-100:#E8E8E8; --vp-steel-50:#F4F4F4;
  --vp-white:#FFFFFF; --vp-paper:#FAFAF7;
  --fg1:#0E0E0E; --fg2:#2B2B2B; --fg3:#8A8A8A;
  --border:#D4D4D4; --border-strong:#B8B8B8; --status-ok:#2F8A3E;
  --font-display:'Mulish','Sora','Inter',system-ui,sans-serif;
  --font-body:'Mulish','Barlow','Inter',system-ui,sans-serif;
  --font-mono:'JetBrains Mono','IBM Plex Mono',ui-monospace,monospace;
  --r-sm:2px; --r-md:4px;
  --shadow-sm:0 1px 2px rgba(14,14,14,.06),0 1px 1px rgba(14,14,14,.04);
  --shadow-yellow:0 6px 18px rgba(255,212,0,.35);
  --dur-fast:120ms; --dur-base:200ms; --dur-slow:320ms; --ease-out:cubic-bezier(.2,.7,.2,1);
}
.vpdt * { box-sizing: border-box; }
.vpdt button { font-family: inherit; }

/* product tabs (ER / MW) */
.vpdt .prodtabs { display:flex; gap:4px; background:var(--vp-steel-50); padding:4px; border-radius:var(--r-md); border:1px solid var(--border); width:fit-content; }
.vpdt .prodtab { display:flex; align-items:center; gap:8px; border:0; cursor:pointer; background:transparent; color:var(--fg3); padding:8px 16px; border-radius:var(--r-sm); font-family:var(--font-body); font-weight:700; font-size:12px; letter-spacing:.08em; text-transform:uppercase; transition:all var(--dur-base) var(--ease-out); }
.vpdt .prodtab:hover { color:var(--fg1); }
.vpdt .prodtab.is-on { background:var(--vp-black); color:var(--vp-white); box-shadow:var(--shadow-sm); }

/* theme toggle */
.vpdt .themebar { display:flex; gap:4px; }
.vpdt .themebar button { border:1px solid var(--border); background:var(--vp-white); color:var(--fg2); font-family:var(--font-mono); font-size:11px; padding:6px 12px; border-radius:var(--r-sm); cursor:pointer; text-transform:capitalize; }
.vpdt .themebar button.is-on { background:var(--vp-black); color:var(--vp-yellow); border-color:var(--vp-black); }

/* workbench grid */
.vpdt .bench { height: 680px; display:grid; grid-template-columns:320px 1fr 360px; min-height:0; border:1px solid var(--border); border-radius:var(--r-md); overflow:hidden; background:var(--vp-white); margin-top:16px; }
.vpdt .panel { min-height:0; display:flex; flex-direction:column; background:var(--vp-white); }
.vpdt .panel--controls { border-right:1px solid var(--border); }
.vpdt .panel--spec { border-left:1px solid var(--border); background:var(--vp-paper); }
.vpdt .panel__scroll { overflow-y:auto; padding:20px 20px 40px; }
.vpdt .panel__scroll::-webkit-scrollbar { width:8px; }
.vpdt .panel__scroll::-webkit-scrollbar-thumb { background:var(--vp-steel-200); border-radius:8px; }

/* control groups */
.vpdt .grp { margin-bottom:26px; }
.vpdt .grp__title { font-family:var(--font-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--fg3); padding-bottom:10px; margin-bottom:16px; border-bottom:1px solid var(--border); }
.vpdt .ctl { margin-bottom:20px; }
.vpdt .ctl__head { display:flex; justify-content:space-between; align-items:baseline; gap:8px; }
.vpdt .ctl__label { font-family:var(--font-body); font-weight:700; font-size:13px; color:var(--fg1); }
.vpdt .ctl__val { font-family:var(--font-mono); font-weight:700; font-size:16px; color:var(--fg1); }
.vpdt .ctl__unit { color:var(--fg3); font-weight:500; font-size:12px; margin-left:1px; }
.vpdt .ctl__sub { font-size:11px; color:var(--fg3); margin-top:2px; }
.vpdt .ctl__scale { display:flex; justify-content:space-between; font-family:var(--font-mono); font-size:10px; color:var(--vp-steel-300); margin-top:4px; }

/* range */
.vpdt .vp-range { -webkit-appearance:none; appearance:none; width:100%; height:4px; border-radius:999px; margin:14px 0 2px; cursor:pointer; }
.vpdt .vp-range::-webkit-slider-thumb { -webkit-appearance:none; appearance:none; width:20px; height:20px; border-radius:50%; background:var(--vp-white); border:3px solid var(--vp-black); cursor:grab; box-shadow:var(--shadow-sm); transition:transform var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast); }
.vpdt .vp-range::-webkit-slider-thumb:hover { transform:scale(1.12); box-shadow:var(--shadow-yellow); }
.vpdt .vp-range::-moz-range-thumb { width:20px; height:20px; border-radius:50%; background:var(--vp-white); border:3px solid var(--vp-black); cursor:grab; }

/* segmented */
.vpdt .seg { display:flex; gap:4px; background:var(--vp-steel-50); border:1px solid var(--border); border-radius:var(--r-md); padding:4px; margin-top:10px; }
.vpdt .seg__b { flex:1; border:0; background:transparent; cursor:pointer; padding:9px 6px; border-radius:var(--r-sm); color:var(--fg2); font-family:var(--font-mono); font-size:12px; font-weight:500; transition:all var(--dur-base) var(--ease-out); white-space:nowrap; }
.vpdt .seg__b:hover { color:var(--fg1); }
.vpdt .seg__b.is-on { background:var(--vp-yellow); color:var(--vp-black); font-weight:700; box-shadow:var(--shadow-sm); }

/* option list */
.vpdt .optlist { display:flex; flex-direction:column; gap:6px; margin-top:10px; }
.vpdt .opt { display:flex; align-items:center; gap:10px; text-align:left; cursor:pointer; background:var(--vp-white); border:1px solid var(--border); border-radius:var(--r-md); padding:11px 12px; transition:all var(--dur-base) var(--ease-out); width:100%; }
.vpdt .opt:hover { border-color:var(--border-strong); }
.vpdt .opt.is-on { border-color:var(--vp-black); border-width:2px; padding:10px 11px; background:var(--vp-paper); }
.vpdt .opt__radio { flex:0 0 auto; width:14px; height:14px; border-radius:50%; border:2px solid var(--vp-steel-300); position:relative; transition:all var(--dur-base); }
.vpdt .opt.is-on .opt__radio { border-color:var(--vp-black); }
.vpdt .opt.is-on .opt__radio::after { content:""; position:absolute; inset:2px; border-radius:50%; background:var(--vp-yellow); }
.vpdt .opt__main { flex:1; min-width:0; display:flex; flex-direction:column; gap:1px; }
.vpdt .opt__label { font-family:var(--font-body); font-weight:700; font-size:12.5px; color:var(--fg1); line-height:1.2; }
.vpdt .opt__desc { font-size:11px; color:var(--fg3); line-height:1.3; }
.vpdt .opt__code { font-family:var(--font-mono); font-size:10px; color:var(--fg3); background:var(--vp-steel-50); padding:3px 6px; border-radius:var(--r-sm); white-space:nowrap; }
.vpdt .opt.is-on .opt__code { background:var(--vp-yellow-100); color:var(--vp-yellow-700); }

/* stage */
.vpdt .stage { min-height:0; display:flex; flex-direction:column; background:var(--vp-paper); position:relative; }
.vpdt .stage__head { flex:0 0 auto; display:flex; justify-content:space-between; align-items:flex-start; padding:16px 28px; }
.vpdt .stage__eyebrow { font-family:var(--font-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--fg3); }
.vpdt .stage__title { font-family:var(--font-display); font-weight:800; font-size:20px; text-transform:uppercase; color:var(--fg1); margin-top:2px; }
.vpdt .stage__legend { display:flex; gap:16px; }
.vpdt .stage__legend span { display:flex; align-items:center; gap:6px; font-family:var(--font-mono); font-size:10px; color:var(--fg3); text-transform:uppercase; letter-spacing:.06em; }
.vpdt .lg { width:14px; height:3px; display:inline-block; border-radius:2px; }
.vpdt .lg--rail { background:var(--vp-yellow); }
.vpdt .lg--deck { background:var(--fg1); }
.vpdt .lg--dim { background:var(--vp-steel-300); height:1px; }
.vpdt .stage__canvas { flex:1 1 auto; min-height:0; padding:0 20px; display:flex; align-items:center; justify-content:center; }
.vpdt .stage__canvas svg { max-height:100%; }
.vpdt .stage__foot { flex:0 0 auto; display:flex; gap:1px; background:var(--border); border-top:1px solid var(--border); }
.vpdt .chip-stat { flex:1; background:var(--vp-white); padding:12px 18px; display:flex; flex-direction:column; gap:2px; }
.vpdt .chip-stat span { font-family:var(--font-mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--fg3); }
.vpdt .chip-stat strong { font-family:var(--font-display); font-weight:800; font-size:20px; color:var(--fg1); }

/* spec panel */
.vpdt .sku { background:var(--vp-black); color:var(--vp-white); padding:16px; border-radius:var(--r-md); margin-bottom:22px; }
.vpdt .sku__eyebrow { font-family:var(--font-mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--vp-steel); margin-bottom:8px; }
.vpdt .sku__code { font-family:var(--font-mono); font-weight:700; font-size:14px; color:var(--vp-yellow); letter-spacing:.02em; word-break:break-all; cursor:pointer; line-height:1.4; }
.vpdt .sku__copy { margin-top:12px; width:100%; background:transparent; border:1px solid var(--vp-graphite); color:var(--vp-steel-200); padding:8px; border-radius:var(--r-sm); font-family:var(--font-mono); font-size:11px; letter-spacing:.06em; text-transform:uppercase; cursor:pointer; transition:all var(--dur-base); }
.vpdt .sku__copy:hover { border-color:var(--vp-yellow); color:var(--vp-yellow); }
.vpdt .specbox { display:flex; flex-direction:column; }
.vpdt .sr { display:flex; justify-content:space-between; align-items:baseline; padding:9px 0; border-bottom:1px solid var(--border); gap:10px; }
.vpdt .sr:last-child { border-bottom:0; }
.vpdt .sr__l { font-size:12.5px; color:var(--fg2); }
.vpdt .sr__v { font-family:var(--font-mono); font-weight:700; font-size:14px; color:var(--fg1); white-space:nowrap; }
.vpdt .sr__u { color:var(--fg3); font-weight:400; font-size:11px; }
.vpdt .sr--accent { background:var(--vp-yellow-50); margin:0 -8px; padding:9px 8px; border-radius:var(--r-sm); border-bottom:1px solid var(--vp-yellow-100); }
.vpdt .oem { display:flex; flex-direction:column; gap:1px; background:var(--border); border:1px solid var(--border); border-radius:var(--r-md); overflow:hidden; }
.vpdt .oem__row { display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:8px; background:var(--vp-white); padding:10px 12px; }
.vpdt .oem__row.is-off { opacity:.55; }
.vpdt .oem__dot { width:8px; height:8px; border-radius:50%; background:var(--vp-steel-300); }
.vpdt .oem__dot.ok { background:var(--status-ok); }
.vpdt .oem__brand { font-weight:700; font-size:12.5px; color:var(--fg1); }
.vpdt .oem__model { font-family:var(--font-mono); font-size:11px; color:var(--fg3); grid-column:2; justify-self:start; }
.vpdt .oem__state { font-family:var(--font-mono); font-size:10px; text-transform:uppercase; letter-spacing:.06em; color:var(--fg3); }
.vpdt .oem__row:not(.is-off) .oem__state { color:var(--status-ok); }
.vpdt .oem__note { font-size:11px; color:var(--fg3); margin:10px 2px 0; line-height:1.45; }
.vpdt .spec__actions { display:flex; flex-direction:column; gap:8px; margin-top:26px; }
.vpdt .spec__cta, .vpdt .spec__pdf { width:100%; justify-content:center; padding:11px; border-radius:var(--r-sm); font-family:var(--font-body); font-weight:700; font-size:13px; cursor:pointer; border:1px solid var(--vp-black); }
.vpdt .spec__cta { background:var(--vp-yellow); color:var(--vp-black); border-color:var(--vp-yellow); }
.vpdt .spec__pdf { background:transparent; color:var(--fg1); }
.vpdt .spec__sla { text-align:center; font-family:var(--font-mono); font-size:10px; color:var(--fg3); margin:12px 0 0; letter-spacing:.03em; }

/* themes (stage only) */
.vpdt.theme-blueprint .stage, .vpdt.theme-carbon .stage { background:var(--vp-black); }
.vpdt.theme-blueprint .stage__eyebrow, .vpdt.theme-carbon .stage__eyebrow { color:var(--vp-steel); }
.vpdt.theme-blueprint .stage__title, .vpdt.theme-carbon .stage__title { color:var(--vp-white); }
.vpdt.theme-blueprint .stage__legend span, .vpdt.theme-carbon .stage__legend span { color:var(--vp-steel); }
.vpdt.theme-blueprint .lg--deck, .vpdt.theme-carbon .lg--deck { background:var(--vp-white); }
.vpdt.theme-blueprint .chip-stat, .vpdt.theme-carbon .chip-stat { background:var(--vp-ink); }
.vpdt.theme-blueprint .chip-stat strong, .vpdt.theme-carbon .chip-stat strong { color:var(--vp-white); }
.vpdt.theme-blueprint .stage__foot, .vpdt.theme-carbon .stage__foot { background:var(--vp-graphite); border-top-color:var(--vp-graphite); }
.vpdt.theme-carbon .stage__canvas { background:radial-gradient(ellipse at center,#161616 0%,#0E0E0E 75%); }

@media (max-width:1180px) { .vpdt .bench { grid-template-columns:280px 1fr 320px; } }
