/* ════════════════════════════════════════════════════════════
   autocad_vps — Estación de trabajo técnica
   Paleta oscura · acento cian · selección ámbar
   ════════════════════════════════════════════════════════════ */
:root{
  /* Superficies */
  --bg:        #0c0f14;
  --bg-canvas: #0e1116;
  --surface-1: #141922;
  --surface-2: #1a212c;
  --surface-3: #222b38;
  --line:      #2a3340;
  --line-soft: #1e2530;

  /* Texto */
  --text:      #e6ecf3;
  --text-dim:  #9aa7b6;
  --text-mute: #5e6b7a;

  /* Acentos */
  --accent:    #22d3ee;       /* cian — herramientas / activo */
  --accent-dk: #0e7490;
  --accent-gl: rgba(34,211,238,.16);
  --amber:     #f59e0b;       /* selección */
  --amber-gl:  rgba(245,158,11,.18);
  --danger:    #f06262;
  --grid:      rgba(122,140,162,.07);
  --grid-bold: rgba(122,140,162,.14);

  --radius:   10px;
  --radius-s: 7px;
  --ease:     cubic-bezier(.2,.8,.2,1);
  --topbar-h: 52px;
  --status-h: 30px;
  --rail-w:   52px;
  --panel-w:  274px;

  --font: 'Inter', system-ui, sans-serif;
  --mono: 'JetBrains Mono', ui-monospace, monospace;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  overflow:hidden;
  -webkit-font-smoothing:antialiased;
  display:grid;
  grid-template-rows:var(--topbar-h) 1fr var(--status-h);
}
button{font-family:inherit;cursor:pointer;color:inherit;border:none;background:none}
svg.ic,.ic{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}

/* ░░░ Barra superior ░░░ */
.topbar{
  display:flex;align-items:center;gap:18px;
  padding:0 14px;
  background:linear-gradient(180deg,var(--surface-1),var(--bg));
  border-bottom:1px solid var(--line);
  z-index:30;
}
.brand{display:flex;align-items:center;gap:11px}
.brand-mark{width:30px;height:30px;color:var(--accent);
  filter:drop-shadow(0 0 8px var(--accent-gl))}
.brand-text{display:flex;flex-direction:column;line-height:1.05}
.brand-name{font-weight:700;font-size:15px;letter-spacing:-.2px}
.brand-dim{color:var(--text-mute);font-weight:500}
.brand-sub{font-size:10px;color:var(--text-mute);letter-spacing:1.4px;text-transform:uppercase;font-weight:500}

.topbar-actions{display:flex;align-items:center;gap:7px;margin-left:auto}
.btn{
  display:inline-flex;align-items:center;gap:7px;
  height:34px;padding:0 13px;font-size:13px;font-weight:500;
  color:var(--text-dim);
  background:var(--surface-2);
  border:1px solid var(--line);
  border-radius:var(--radius-s);
  transition:.16s var(--ease);
  white-space:nowrap;
}
.btn:hover:not(:disabled){background:var(--surface-3);color:var(--text);border-color:var(--line)}
.btn:active:not(:disabled){transform:translateY(1px)}
.btn:disabled{opacity:.4;cursor:not-allowed}
.btn-accent{
  color:#05222a;
  background:linear-gradient(180deg,var(--accent),#13b6d4);
  border-color:transparent;font-weight:600;
}
.btn-accent:hover:not(:disabled){filter:brightness(1.08);color:#05222a}
.btn-accent:disabled{background:var(--surface-2);color:var(--text-dim)}
.export-group{display:flex;gap:2px}
.export-group .btn{border-radius:0}
.export-group .btn:first-child{border-radius:var(--radius-s) 0 0 var(--radius-s)}
.export-group .btn:last-child{border-radius:0 var(--radius-s) var(--radius-s) 0}
.sep{width:1px;height:22px;background:var(--line);margin:0 4px}
.badge-fmt{
  font-family:var(--mono);font-size:11px;font-weight:600;
  padding:4px 8px;border-radius:5px;letter-spacing:.5px;
  color:var(--accent);background:var(--accent-gl);
  border:1px solid color-mix(in srgb,var(--accent) 30%,transparent);
}

/* ░░░ Workspace ░░░ */
.workspace{
  display:grid;
  grid-template-columns:var(--rail-w) var(--panel-w) 1fr;
  min-height:0;
}

/* Riel de herramientas */
.toolrail{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  padding:10px 0;
  background:var(--bg);
  border-right:1px solid var(--line);
}
.tool{
  width:38px;height:38px;border-radius:var(--radius-s);
  display:grid;place-items:center;color:var(--text-mute);
  transition:.14s var(--ease);position:relative;
}
.tool svg{width:19px;height:19px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.tool:hover{background:var(--surface-2);color:var(--text-dim)}
.tool.active{color:var(--accent);background:var(--accent-gl)}
.tool.active::before{
  content:"";position:absolute;left:-10px;top:8px;bottom:8px;width:3px;
  border-radius:3px;background:var(--accent);box-shadow:0 0 10px var(--accent);
}
.tool-danger:hover{color:var(--danger)}
.rail-sep{width:24px;height:1px;background:var(--line);margin:5px 0}

/* Panel izquierdo */
.panel{
  display:flex;flex-direction:column;
  background:var(--surface-1);
  border-right:1px solid var(--line);
  min-height:0;
}
.panel-block{display:flex;flex-direction:column;border-bottom:1px solid var(--line-soft);min-height:0}
.panel-block.grow{flex:1}
.panel-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:11px 14px 8px;font-size:11px;font-weight:600;
  letter-spacing:1.1px;text-transform:uppercase;color:var(--text-mute);
}
.chip{
  font-family:var(--mono);font-size:10px;font-weight:600;
  min-width:20px;text-align:center;padding:2px 6px;border-radius:20px;
  background:var(--surface-3);color:var(--text-dim);
}
.layers{overflow-y:auto;max-height:38vh;padding:0 8px 10px}
.layer{
  display:flex;align-items:center;gap:9px;
  padding:7px 8px;border-radius:var(--radius-s);font-size:12.5px;
  color:var(--text-dim);transition:.12s var(--ease);
}
.layer:hover{background:var(--surface-2);color:var(--text)}
.layer-sw{width:13px;height:13px;border-radius:4px;flex-shrink:0;border:1px solid rgba(255,255,255,.14)}
.layer-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:var(--mono);font-size:11.5px}
.layer-eye{width:26px;height:26px;display:grid;place-items:center;border-radius:5px;color:var(--text-mute);flex-shrink:0}
.layer-eye:hover{background:var(--surface-3);color:var(--text)}
.layer.off{opacity:.45}
.layer.off .layer-name{text-decoration:line-through}

.props{padding:4px 14px 14px;overflow-y:auto;font-size:13px}
.props-empty{color:var(--text-mute);font-size:12.5px;padding:14px 2px;line-height:1.6}
.prop-row{display:flex;justify-content:space-between;gap:10px;padding:7px 0;border-bottom:1px solid var(--line-soft)}
.prop-row:last-child{border:none}
.prop-k{color:var(--text-mute);font-size:11.5px;text-transform:uppercase;letter-spacing:.4px}
.prop-v{font-family:var(--mono);font-size:12px;color:var(--text);text-align:right;word-break:break-word}
.prop-type{
  display:inline-flex;align-items:center;gap:6px;margin-bottom:6px;
  font-family:var(--mono);font-size:11px;font-weight:600;color:var(--amber);
  background:var(--amber-gl);padding:4px 9px;border-radius:5px;
}

/* ░░░ Viewport ░░░ */
.viewport{position:relative;background:var(--bg-canvas);overflow:hidden}
#canvas{display:block;width:100%;height:100%;cursor:crosshair}
.viewport.tool-pan #canvas{cursor:grab}
.viewport.panning #canvas{cursor:grabbing}

/* Dropzone */
.dropzone{
  position:absolute;inset:0;display:grid;place-items:center;z-index:10;
  background:radial-gradient(120% 80% at 50% 40%,rgba(34,211,238,.05),transparent 60%),var(--bg-canvas);
  transition:.2s var(--ease);
}
.dropzone.hidden{opacity:0;pointer-events:none}
.dropzone.dragover{background:radial-gradient(120% 80% at 50% 40%,rgba(34,211,238,.14),transparent 65%),var(--bg-canvas)}
.dropzone.dragover .dz-inner{border-color:var(--accent);transform:scale(1.015)}
.dz-inner{
  text-align:center;padding:46px 60px;border-radius:18px;
  border:1.5px dashed var(--line);background:rgba(20,25,34,.5);
  backdrop-filter:blur(2px);transition:.2s var(--ease);
}
.dz-icon{width:62px;height:62px;color:var(--accent);margin-bottom:18px;opacity:.85;
  filter:drop-shadow(0 0 14px var(--accent-gl))}
.dz-inner h2{font-size:21px;font-weight:600;letter-spacing:-.3px}
.dz-inner p{color:var(--text-mute);font-size:13px;margin-top:6px}
.dz-actions{display:flex;gap:9px;justify-content:center;margin-top:22px}
.dz-formats{display:flex;gap:7px;justify-content:center;margin-top:24px}
.fmt-pill{
  font-family:var(--mono);font-size:10.5px;font-weight:600;letter-spacing:.6px;
  padding:4px 11px;border-radius:20px;color:var(--accent);
  background:var(--accent-gl);border:1px solid color-mix(in srgb,var(--accent) 24%,transparent);
}
.fmt-pill.ghost{color:var(--text-mute);background:var(--surface-2);border-color:var(--line)}

/* Zoom dock */
.zoom-dock{
  position:absolute;right:14px;bottom:14px;z-index:12;
  display:flex;flex-direction:column;gap:1px;
  background:var(--line);border:1px solid var(--line);border-radius:9px;overflow:hidden;
  box-shadow:0 8px 24px rgba(0,0,0,.4);
}
.zbtn{
  width:34px;height:32px;display:grid;place-items:center;
  background:var(--surface-2);color:var(--text-dim);font-size:16px;transition:.12s var(--ease);
}
.zbtn:hover{background:var(--surface-3);color:var(--accent)}

.tool-hint{
  position:absolute;left:50%;bottom:18px;transform:translateX(-50%);z-index:12;
  font-family:var(--mono);font-size:12px;color:var(--accent);
  background:rgba(14,17,22,.9);border:1px solid color-mix(in srgb,var(--accent) 30%,transparent);
  padding:7px 14px;border-radius:20px;backdrop-filter:blur(4px);
  box-shadow:0 4px 16px rgba(0,0,0,.4);
}

/* ░░░ Barra de estado ░░░ */
.statusbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:0 14px;font-family:var(--mono);font-size:11.5px;
  background:var(--surface-1);border-top:1px solid var(--line);color:var(--text-mute);
}
.st-left,.st-right{display:flex;align-items:center;gap:16px}
.st-item b{color:var(--text-dim);font-weight:500}
.st-coord{
  color:var(--accent);font-weight:600;letter-spacing:.8px;
  background:var(--accent-gl);padding:3px 9px;border-radius:5px;font-size:10.5px;
}

/* ░░░ Toasts ░░░ */
.toasts{position:fixed;bottom:42px;left:50%;transform:translateX(-50%);z-index:100;display:flex;flex-direction:column;gap:8px;align-items:center}
.toast{
  display:flex;align-items:center;gap:10px;
  padding:11px 16px;font-size:13px;border-radius:9px;
  background:var(--surface-3);border:1px solid var(--line);color:var(--text);
  box-shadow:0 10px 30px rgba(0,0,0,.45);
  animation:toast-in .26s var(--ease);
}
.toast.ok{border-color:color-mix(in srgb,var(--accent) 40%,transparent)}
.toast.ok b{color:var(--accent)}
.toast.err{border-color:color-mix(in srgb,var(--danger) 45%,transparent)}
.toast.err b{color:var(--danger)}
.toast-dot{width:7px;height:7px;border-radius:50%;background:var(--accent)}
.toast.err .toast-dot{background:var(--danger)}
@keyframes toast-in{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* Scrollbars */
::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:9px;border:2px solid var(--surface-1)}
::-webkit-scrollbar-thumb:hover{background:var(--line)}

/* Responsive: colapsa panel en pantallas chicas */
@media(max-width:860px){
  :root{--panel-w:0px}
  .panel{display:none}
}
