@import url("tokens.css");

/* ── Reset ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }
body {
  font-family: var(--font-ui);
  font-size: var(--text-sm);
  color: var(--color-text);
  background: var(--color-bg);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

/* ── Topbar ── */
.topbar {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) var(--space-4);
  background: var(--color-surface);
  border-bottom: var(--border-width) solid var(--color-border);
  box-shadow: var(--shadow-sm);
  z-index: 10;
  flex-wrap: wrap;
  min-height: 48px;
}

.brand {
  font-weight: 700;
  font-size: var(--text-base);
  color: var(--color-text);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.brand span { white-space: nowrap; }

/* ── Toolbar ── */
.toolbar {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  flex-wrap: wrap;
  flex: 1;
}

.sep {
  width: 1px;
  height: 22px;
  background: var(--color-border);
  margin: 0 var(--space-2);
  flex-shrink: 0;
}

/* Primary button style (file upload label, etc.) */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-1-5) var(--space-3);
  font: inherit;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  background: var(--color-surface);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--radius-sm);
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.12s, color 0.12s, border-color 0.12s;
}
.btn:hover {
  background: var(--color-bg-hover);
  color: var(--color-text);
}
.btn.primary {
  background: var(--color-accent);
  color: #fff;
  border-color: var(--color-accent);
  font-weight: 600;
}
.btn.primary:hover {
  background: var(--color-accent-dark);
  border-color: var(--color-accent-dark);
}
.btn.danger:hover {
  background: var(--color-danger-subtle);
  color: var(--color-danger);
  border-color: var(--color-danger-border);
}
.btn.ghost {
  width: 100%;
  justify-content: center;
  color: var(--color-text-muted);
  background: transparent;
  border-color: transparent;
  margin-top: var(--space-2);
}
.btn.ghost:hover {
  background: var(--color-bg-hover);
  border-color: var(--color-border);
  color: var(--color-text);
}

/* Tool button (toolbar tools: select, line, area…) */
.tool {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-1-5) var(--space-3);
  font: inherit;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  background: transparent;
  border: var(--border-width) solid transparent;
  border-radius: var(--radius-sm);
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.12s, color 0.12s, border-color 0.12s;
}
.tool:hover {
  background: var(--color-bg-hover);
  color: var(--color-text);
}
.tool.active {
  background: var(--color-accent-subtle);
  color: var(--color-accent);
  border-color: var(--color-accent-border);
  font-weight: 600;
}

/* Snap button active variant (violet removed — use accent) */
.snap-btn.active {
  background: var(--color-accent-subtle);
  color: var(--color-accent);
  border-color: var(--color-accent-border);
}

/* Unit selector */
.unit-label {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  white-space: nowrap;
}
.unit-select {
  padding: var(--space-1-5) var(--space-2);
  min-width: 60px;
  cursor: pointer;
  font: inherit;
  font-size: var(--text-xs);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-surface);
  color: var(--color-text);
}
.unit-select:hover { border-color: var(--color-accent-border); }

/* ── Layout ── */
.layout { flex: 1; display: flex; min-height: 0; }

/* ── Canvas area ── */
.canvas-wrap {
  flex: 1;
  position: relative;
  overflow: hidden;
  background: var(--color-canvas-bg);
  /* Subtle grid pattern matching design mockup */
  background-image:
    linear-gradient(var(--color-canvas-grid) 1px, transparent 1px),
    linear-gradient(90deg, var(--color-canvas-grid) 1px, transparent 1px),
    linear-gradient(var(--color-canvas-grid-major) 1px, transparent 1px),
    linear-gradient(90deg, var(--color-canvas-grid-major) 1px, transparent 1px);
  background-size: 20px 20px, 20px 20px, 100px 100px, 100px 100px;
  background-position: 0 0, 0 0, 0 0, 0 0;
}
.canvas-wrap.dragging {
  outline: 2px dashed var(--color-accent);
  outline-offset: -8px;
}
#canvas { display: block; width: 100%; height: 100%; }

/* Empty state */
.empty {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  pointer-events: none;
  padding: var(--space-5);
}
.empty h2 {
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: var(--space-2);
}
.empty p {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-1);
}

/* Status bar */
.status {
  position: absolute;
  left: var(--space-3);
  bottom: var(--space-3);
  background: var(--color-statusbar-bg);
  color: var(--color-text-muted);
  padding: var(--space-1-5) var(--space-3);
  border-radius: var(--radius-sm);
  border: var(--border-width) solid var(--color-border);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  box-shadow: var(--shadow-sm);
  max-width: calc(100% - 24px);
}

/* ── Right panel ── */
.panel {
  width: 280px;
  flex-shrink: 0;
  background: var(--color-surface);
  border-left: var(--border-width) solid var(--color-border);
  padding: var(--space-4);
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.panel h3 {
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-muted);
  margin-top: var(--space-1-5);
}

/* Measurement list */
.meas-list { display: flex; flex-direction: column; gap: var(--space-1-5); }
.meas-row {
  display: grid;
  grid-template-columns: 1fr auto auto auto;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-1-5) var(--space-2);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--radius-sm);
  border-left: 3px solid var(--color-text-muted);
  background: var(--color-surface);
  transition: background 0.1s;
}
.meas-row:hover { background: var(--color-bg-hover); }
.meas-row.line { border-left-color: var(--color-accent); }
.meas-row.area { border-left-color: #16a34a; }
.meas-row.point { border-left-color: #db2777; }

.meas-label {
  border: none;
  font: inherit;
  font-size: var(--text-sm);
  font-weight: 600;
  width: 100%;
  background: transparent;
  color: var(--color-text);
}
.meas-label:focus {
  outline: var(--border-width) solid var(--color-accent-border);
  border-radius: var(--radius-xs);
}
.meas-val {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-variant-numeric: tabular-nums;
  color: var(--color-text-muted);
  white-space: nowrap;
}
.meas-del {
  border: none;
  background: transparent;
  color: var(--color-text-muted);
  cursor: pointer;
  font-size: var(--text-sm);
  padding: 2px var(--space-1);
  border-radius: var(--radius-xs);
  transition: color 0.1s;
}
.meas-del:hover { color: var(--color-danger); }

/* Totals block */
.totals {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  padding: var(--space-3);
  background: var(--color-totals-bg);
  border-radius: var(--radius-sm);
  border: var(--border-width) solid var(--color-border);
}
.totals div {
  display: flex;
  justify-content: space-between;
  font-size: var(--text-xs);
}
.totals span { color: var(--color-text-muted); }
.totals b {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-weight: 700;
  color: var(--color-text);
}

/* Export grid */
.export-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-1-5);
}

/* ── Restore banner ── */
.restore-banner {
  display: flex;
  align-items: center;
  gap: var(--space-2-5);
  flex-wrap: wrap;
  padding: var(--space-2) var(--space-4);
  background: var(--color-warning-banner-bg);
  border-bottom: var(--border-width) solid var(--color-warning-banner-border);
  border-left: 3px solid var(--color-warning-text);
  font-size: var(--text-xs);
}
.restore-banner span {
  flex: 1;
  color: var(--color-warning-text);
  font-weight: 600;
}

/* Muted helper */
.muted {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}

/* ── Partidas ── */
.partidas-bar {
  display: flex;
  gap: var(--space-1-5);
  align-items: center;
}
.partida-select {
  flex: 1;
  min-width: 0;
  padding: var(--space-1-5) var(--space-2);
  font: inherit;
  font-size: var(--text-xs);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-surface);
  color: var(--color-text);
  cursor: pointer;
}
.partida-select:hover { border-color: var(--color-accent-border); }

.partidas-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.partida-row {
  display: flex;
  align-items: center;
  gap: var(--space-1-5);
  padding: var(--space-1-5) var(--space-2);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-bg-alt);
  transition: background 0.1s;
}
.partida-row.active {
  border-color: var(--color-accent-border);
  background: var(--color-accent-subtle);
}
.partida-row:hover { background: var(--color-bg-hover); }
.partida-row.active:hover { background: var(--color-accent-subtle); }

.partida-info {
  flex: 1;
  min-width: 0;
  overflow: hidden;
}
.partida-codigo {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--color-accent);
}
.partida-desc {
  font-size: var(--text-xs);
  color: var(--color-text);
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.partida-subtotal {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--color-text-muted);
  white-space: nowrap;
  flex-shrink: 0;
}
.partida-actions {
  display: flex;
  gap: var(--space-1);
  flex-shrink: 0;
}
.partida-btn {
  border: none;
  background: transparent;
  color: var(--color-text-muted);
  cursor: pointer;
  font-size: var(--text-xs);
  padding: 2px 4px;
  border-radius: var(--radius-xs);
  transition: color 0.1s;
}
.partida-btn:hover { color: var(--color-text); }
.partida-btn.del:hover { color: var(--color-danger); }

/* Measurement row partida badge */
.meas-partida {
  font-size: 10px;
  font-family: var(--font-mono);
  color: var(--color-text-muted);
  background: var(--color-bg-alt);
  border: var(--border-width) solid var(--color-border-subtle);
  border-radius: var(--radius-xs);
  padding: 1px 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 80px;
  cursor: pointer;
}
.meas-partida:hover {
  border-color: var(--color-accent-border);
  color: var(--color-accent);
}

/* ── Responsive ── */
@media (max-width: 760px) {
  .layout { flex-direction: column; }
  .panel {
    width: 100%;
    border-left: none;
    border-top: var(--border-width) solid var(--color-border);
    max-height: 45%;
  }
}
