/* Valco Firmware Uploader — app styling on the Valco design tokens.
   Tokens (color, type, spacing, Maven Pro) come from valco-tokens.css,
   linked before this file. Monochrome; accents only for functional state. */

* { box-sizing: border-box; }

body { margin: 0; background: var(--bg-page); color: var(--fg-1); }

/* ---------- Top bar ---------- */
.topbar {
  display: flex; align-items: center; gap: var(--space-8);
  padding: var(--space-4) var(--space-8);
  background: var(--valco-white);
  border-bottom: var(--border-w-hair) solid var(--border-subtle);
}
.topbar .brand { display: inline-flex; align-items: center; }
.topbar .brand img { height: 24px; display: block; }
.topbar nav { display: flex; gap: var(--space-6); }
.topbar nav a {
  font-size: var(--fs-eyebrow); font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wider); text-transform: uppercase;
  text-decoration: none; color: var(--fg-3);
}
.topbar nav a:hover { color: var(--fg-1); }
.topbar .user {
  margin-left: auto; display: flex; align-items: center; gap: var(--space-3);
  font-size: var(--fs-body-sm); color: var(--fg-2);
}
.topbar .user img { width: 28px; height: 28px; border-radius: var(--radius-sm); }
.topbar .logout {
  color: var(--fg-1); text-decoration: none;
  border-bottom: var(--border-w-thick) solid var(--valco-ink); padding-bottom: 1px;
}

/* ---------- Layout ---------- */
.container { max-width: 1040px; margin: var(--space-10) auto; padding: 0 var(--space-8); }

.card {
  background: var(--bg-elevated);
  border: var(--border-w-hair) solid var(--border-subtle);
  border-radius: var(--radius-md);
  padding: var(--space-6) var(--space-8);
  margin-bottom: var(--space-6);
}
.card h2 { margin: 0 0 var(--space-5); }
.card h3 { margin: var(--space-6) 0 var(--space-3); }
.muted { color: var(--fg-3); }
/* Small, light qualifier inside a heading, e.g. "Firmwares (production — read-only)". */
.h-note { font-size: var(--fs-h4); font-weight: var(--fw-regular); color: var(--fg-3); letter-spacing: var(--ls-normal); }
.mono { font-family: var(--font-mono); font-size: var(--fs-body-sm); }

/* ---------- Forms ---------- */
.grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-4) var(--space-6); }
.switcher, .upload-form { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-4) var(--space-6); align-items: start; }
.field { display: flex; flex-direction: column; gap: var(--space-2); }
.field-wide { grid-column: 1 / -1; }
.field label {
  font-size: var(--fs-eyebrow); font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wider); text-transform: uppercase; color: var(--fg-2);
}
.field input[type=text], .field input[type=number], .field select, .field textarea, .field input[type=file] {
  width: 100%;
  border: var(--border-w-hair) solid var(--border-default);
  border-radius: var(--radius-sm);
  font: inherit; color: var(--fg-1); background: var(--valco-white);
}
/* Single-line controls share one fixed height so selects and inputs match. */
.field input[type=text], .field input[type=number], .field select {
  height: 42px;
  padding: 0 var(--space-3);
  line-height: normal;
}
.field input[type=file] { padding: var(--space-2) var(--space-3); }
.field textarea { padding: var(--space-3); resize: vertical; min-height: 2.6em; line-height: var(--lh-relaxed); }
.field input:focus-visible, .field select:focus-visible, .field textarea:focus-visible {
  outline: var(--border-w-thick) solid var(--valco-ink); outline-offset: 1px; border-color: var(--valco-ink);
}
.field input:disabled, .field input[readonly], .field textarea:disabled, .field select:disabled {
  background: var(--bg-muted); color: var(--fg-3); opacity: 1;
}
.field small { color: var(--fg-3); font-size: var(--fs-caption); }
/* Live validation: red border + message when the typed version already exists. */
.field input.input-error { border-color: #b91c1c; }
.field input.input-error:focus-visible { outline-color: #b91c1c; border-color: #b91c1c; }
.field .field-error { color: #b91c1c; }

/* ---------- Buttons (monochrome only) ---------- */
.btn {
  display: inline-block; padding: var(--space-3) var(--space-5);
  border: var(--border-w-hair) solid var(--border-strong);
  border-radius: var(--radius-sm); background: var(--valco-white); color: var(--valco-ink);
  font: inherit; font-weight: var(--fw-bold); font-size: var(--fs-body-sm);
  letter-spacing: var(--ls-wide); text-transform: uppercase; text-decoration: none;
  cursor: pointer; transition: background var(--dur-1) var(--ease-standard),
              color var(--dur-1) var(--ease-standard), transform var(--dur-1) var(--ease-standard);
}
.btn:hover { background: var(--valco-ink); color: var(--valco-white); }
.btn:active { transform: scale(0.98); }
.btn-primary { background: var(--valco-ink); color: var(--valco-white); border-color: var(--valco-ink); }
.btn-primary:hover { background: var(--valco-black); }
.btn-danger { color: #b91c1c; border-color: #b91c1c; border-width: var(--border-w-thick); }
.btn-danger:hover { background: #b91c1c; color: var(--valco-white); border-color: #b91c1c; }
.form-actions { display: flex; gap: var(--space-4); margin-top: var(--space-6); }

/* ---------- Collapsible disclosure ---------- */
.disclosure summary {
  cursor: pointer; list-style: none; user-select: none;
  display: flex; align-items: center; gap: var(--space-3);
  font-size: var(--fs-h3); font-weight: var(--fw-bold); line-height: var(--lh-snug);
  color: var(--fg-1);
}
.disclosure summary::-webkit-details-marker { display: none; }
.disclosure summary::before {
  content: ""; flex: none; width: 0; height: 0;
  border-left: 6px solid var(--fg-3);
  border-top: 5px solid transparent; border-bottom: 5px solid transparent;
  transition: transform var(--dur-1) var(--ease-standard);
}
.disclosure[open] summary::before { transform: rotate(90deg); }
.disclosure-body { margin-top: var(--space-5); }

/* ---------- Tables ---------- */
.table { width: 100%; border-collapse: collapse; }
.table th, .table td {
  text-align: left; padding: var(--space-3) var(--space-3);
  border-bottom: var(--border-w-hair) solid var(--border-subtle);
}
.table th {
  font-size: var(--fs-eyebrow); font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wider); text-transform: uppercase; color: var(--fg-3);
}
.table td { font-size: var(--fs-body-sm); color: var(--fg-2); }

/* ---------- Repeatable branch rows ---------- */
.fw-row {
  border: var(--border-w-hair) solid var(--border-subtle);
  border-radius: var(--radius-md); padding: var(--space-5);
  margin-bottom: var(--space-4);
}
/* Uniform size for the card's action buttons (Move up / Move down / Remove). */
.fw-row .form-actions .btn { width: 12rem; text-align: center; white-space: nowrap; }
/* Production read-only view: space the per-variant Remove button from the fields above. */
.fw-row .remove-prod-form { margin-top: var(--space-5); }

/* ---------- Flash / state (functional accents only) ---------- */
.flash {
  padding: var(--space-3) var(--space-4); margin-bottom: var(--space-5);
  background: var(--bg-subtle); color: var(--fg-1);
  border: var(--border-w-hair) solid var(--border-subtle);
  border-left: 3px solid var(--neutral-500); border-radius: var(--radius-sm);
  font-size: var(--fs-body-sm);
}
.flash-success { border-left-color: var(--accent-success); }
.flash-warning { border-left-color: var(--accent-warning); }
.flash-error   { border-left-color: var(--accent-error); }
.flash ul { margin: var(--space-2) 0 0; padding-left: var(--space-5); }

/* ---------- Modal (confirmation) ---------- */
.modal-scrim {
  position: fixed; inset: 0; z-index: 100;
  background: rgba(0, 0, 0, 0.4);            /* no blur, per brand */
  display: flex; align-items: center; justify-content: center;
  padding: var(--space-4);
}
.modal-scrim[hidden] { display: none; }
.modal {
  background: var(--valco-white);
  border: var(--border-w-hair) solid var(--border-subtle);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-3);
  max-width: 440px; width: 100%;
  padding: var(--space-8);
}
.modal h3 { margin: 0 0 var(--space-3); }
.modal p { margin: 0 0 var(--space-6); }
.modal-actions { display: flex; justify-content: flex-end; gap: var(--space-3); }

/* ---------- Login ---------- */
.login-card {
  max-width: 460px; margin: var(--space-24) auto var(--space-16); text-align: center;
  background: var(--valco-white); border: var(--border-w-hair) solid var(--border-subtle);
  border-radius: var(--radius-md); padding: var(--space-12) var(--space-10);
}
.login-card .brand-mark { height: 36px; margin-bottom: var(--space-8); }
.login-card h1 { font-size: var(--fs-h2); margin: 0 0 var(--space-3); }
.login-card p { margin: 0 auto var(--space-8); max-width: 34ch; }
.login-card .btn { width: 100%; padding: var(--space-4); }
