/* InterieurMeester — Components
 * Reusable building blocks: buttons, cards, tables, pills, forms, chat, etc.
 * Depends on: tokens.css
 */

/* ═════════════════════════════════════════════
   Buttons
   ═════════════════════════════════════════════ */
.btn {
  font: inherit;
  font-size: var(--fs-body-sm);
  font-weight: 400;
  font-feature-settings: "ss01";
  padding: 8px var(--space-5);
  border-radius: var(--radius-xs);
  border: 1px solid var(--brand-light);
  background: #fff;
  color: var(--brand);
  cursor: pointer;
  transition: background .12s ease, border-color .12s ease, box-shadow .12s ease, color .12s ease;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.btn:hover { background: rgba(83, 58, 253, 0.05); }
.btn:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
  border-color: var(--brand);
}

.btn-primary {
  background: var(--brand);
  border-color: var(--brand);
  color: #fff;
  box-shadow: var(--shadow-button);
}
.btn-primary:hover {
  background: var(--brand-hover);
  border-color: var(--brand-hover);
}

.btn-ghost {
  border: 1px solid var(--border);
  color: var(--label);
  background: #fff;
}
.btn-ghost:hover { background: var(--bg-soft); }

.btn-danger {
  color: var(--danger-text);
  border-color: var(--danger-border);
  background: #fff;
}
.btn-danger:hover { background: var(--danger-bg); }

.btn-sm { padding: 6px var(--space-3); font-size: var(--fs-micro); }
.btn-block { width: 100%; justify-content: center; }

.btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  box-shadow: none;
}

/* Icon button (square, single glyph) */
.icon-btn {
  width: 30px;
  height: 30px;
  border-radius: var(--radius-xs);
  border: 1px solid var(--border);
  background: #fff;
  cursor: pointer;
  color: var(--body);
  font-size: var(--fs-body);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.icon-btn:hover {
  color: var(--danger-text);
  border-color: var(--danger-border);
  background: var(--danger-bg);
}

/* ═════════════════════════════════════════════
   Cards
   ═════════════════════════════════════════════ */
.card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-7) 26px;
  margin-bottom: var(--space-6);
  box-shadow: var(--shadow-ambient);
}
.card.elevated { box-shadow: var(--shadow-card); }
.card.flush { padding: 0; }

.card-eyebrow {
  font-family: var(--font-mono);
  font-size: var(--fs-nano);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--brand);
  margin: 0 0 6px 0;
}
.card-heading {
  font-size: var(--fs-h2);
  font-weight: 300;
  letter-spacing: var(--tracking-h2);
  color: var(--heading);
  margin: 0 0 var(--space-5) 0;
}
.card-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
}

/* ═════════════════════════════════════════════
   Forms
   ═════════════════════════════════════════════ */
.field { margin-bottom: var(--space-5); display: flex; flex-direction: column; }
.field-label,
label.field-label {
  display: block;
  font-size: var(--fs-micro);
  font-weight: 500;
  color: var(--label);
  letter-spacing: 0.2px;
  margin: 0 0 6px 0;
}

.input,
input[type="text"].input,
input[type="email"].input,
input[type="password"].input,
input[type="number"].input,
input[type="search"].input,
textarea.input,
select.input {
  width: 100%;
  font: inherit;
  font-size: var(--fs-body-sm);
  padding: 11px var(--space-4);
  border: 1px solid var(--border);
  border-radius: var(--radius-xs);
  background: #fff;
  color: var(--heading);
  outline: none;
  transition: border .12s, box-shadow .12s;
  font-feature-settings: "ss01";
}
.input::placeholder { color: var(--body); }
.input:focus {
  border-color: var(--brand);
  box-shadow: var(--shadow-focus);
}

textarea.input { resize: vertical; min-height: 42px; }

.form-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4) var(--space-6);
}
@media (max-width: 640px) {
  .form-grid { grid-template-columns: 1fr; }
}

.save-bar {
  display: flex;
  justify-content: flex-end;
  gap: var(--space-3);
  margin-top: var(--space-2);
}

/* ═════════════════════════════════════════════
   Tables
   ═════════════════════════════════════════════ */
.table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-body-sm);
  font-weight: 300;
}
.table th {
  text-align: left;
  font-weight: 400;
  color: var(--label);
  text-transform: uppercase;
  font-size: var(--fs-nano);
  letter-spacing: var(--tracking-mono);
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--border);
  font-family: var(--font-mono);
}
.table td {
  padding: var(--space-4);
  border-bottom: 1px solid var(--border);
  color: var(--label);
}
.table tr:last-child td { border-bottom: none; }
.table tr:hover td { background: var(--bg-soft); }

.td-id {
  color: var(--brand);
  font-family: var(--font-mono);
  font-size: var(--fs-micro);
  font-weight: 500;
}
.td-name { color: var(--heading); font-weight: 400; }
.td-dims {
  color: var(--label);
  font-family: var(--font-mono);
  font-size: var(--fs-micro);
  font-feature-settings: "tnum";
}

/* Inline editable inputs inside table cells (settings) */
.table td input.cell-input {
  font: inherit;
  font-size: var(--fs-caption);
  padding: 6px 8px;
  border: 1px solid transparent;
  border-radius: 3px;
  background: transparent;
  color: var(--heading);
  width: 100%;
  outline: none;
}
.table td input.cell-input:focus {
  border-color: var(--brand);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(83, 58, 253, 0.10);
}

/* Zone divider row (multi-zone tables) */
.zone-bar {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: 10px var(--space-4);
  background: linear-gradient(180deg, var(--bg-soft), #fff);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.zone-name {
  font-family: var(--font-mono);
  font-size: var(--fs-nano);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--brand);
}
.zone-meta { font-size: var(--fs-micro); color: var(--body); }

/* ═════════════════════════════════════════════
   Pills / badges
   ═════════════════════════════════════════════ */
.pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 2px 10px;
  border-radius: var(--radius-xs);
  font-size: var(--fs-nano);
  font-weight: 400;
  background: #fff;
  color: var(--label);
  border: 1px solid var(--border);
}
.pill .dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
}
.pill-brand {
  background: rgba(83, 58, 253, 0.06);
  color: var(--brand);
  border-color: var(--brand-lighter);
}
.pill-success {
  background: var(--success-bg);
  color: var(--success-text);
  border-color: var(--success-border);
}
.pill-warn {
  background: var(--warn-bg);
  color: var(--warn-text);
  border-color: var(--warn-border);
}
.pill-danger {
  background: var(--danger-bg);
  color: var(--danger-text);
  border-color: var(--danger-border);
}

.inline-code {
  font-family: var(--font-mono);
  font-size: var(--fs-micro);
  font-weight: 500;
  padding: 2px 8px;
  border-radius: var(--radius-xs);
  background: var(--bg-soft);
  color: var(--brand);
  border: 1px solid var(--border);
}

/* ═════════════════════════════════════════════
   Upload zone
   ═════════════════════════════════════════════ */
.upload {
  text-align: center;
  padding: 48px var(--space-7);
  border: 1px dashed var(--brand-lighter);
  border-radius: var(--radius-md);
  background: var(--bg-soft);
}
.upload-icon {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-lg);
  margin: 0 auto var(--space-5);
  background: #fff;
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  color: var(--brand);
  box-shadow: rgba(50, 50, 93, 0.10) 0px 6px 14px -6px;
}
.upload-title {
  font-size: var(--fs-h3);
  font-weight: 300;
  color: var(--heading);
  letter-spacing: var(--tracking-h3);
}
.upload-sub {
  color: var(--body);
  font-size: var(--fs-body-sm);
  margin: 6px 0 var(--space-5);
}

/* File-row (uploaded file list) */
.file-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: #fff;
  margin-top: 10px;
}
.file-meta { display: flex; align-items: center; gap: var(--space-3); font-size: var(--fs-caption); }
.file-icon {
  width: 32px;
  height: 32px;
  border-radius: var(--radius-md);
  background: rgba(83, 58, 253, 0.06);
  color: var(--brand);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: var(--fs-nano);
  font-weight: 500;
  border: 1px solid var(--brand-lighter);
}
.file-name { color: var(--heading); font-weight: 400; }
.file-sub { color: var(--body); font-size: var(--fs-micro); }

/* ═════════════════════════════════════════════
   Chat / message panel
   ═════════════════════════════════════════════ */
.chat {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.msg {
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius-md);
  font-size: var(--fs-body-sm);
  line-height: 1.5;
  font-weight: 300;
  max-width: 92%;
}
.msg-bot {
  background: var(--bg-soft);
  border: 1px solid var(--border);
  color: var(--label);
}
.msg-user {
  align-self: flex-end;
  background: rgba(83, 58, 253, 0.06);
  border: 1px solid var(--brand-lighter);
  color: var(--heading);
}
.msg-status {
  background: #fff;
  border: 1px dashed var(--brand-lighter);
  color: var(--brand);
  font-family: var(--font-mono);
  font-size: var(--fs-micro);
  font-weight: 500;
}
.msg-error {
  background: var(--danger-bg);
  border: 1px solid var(--danger-border);
  color: var(--danger-text);
}

.input-row {
  display: flex;
  gap: var(--space-2);
  margin-top: var(--space-4);
}
.input-row .input { flex: 1; }

.approval-bar {
  display: flex;
  gap: var(--space-3);
  margin-top: var(--space-6);
  padding-top: var(--space-6);
  border-top: 1px solid var(--border);
}

/* ═════════════════════════════════════════════
   Summary / data grids (key-value)
   ═════════════════════════════════════════════ */
.summary-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4) var(--space-6);
  font-size: var(--fs-body-sm);
}
.summary-grid .k { color: var(--body); font-size: var(--fs-caption); }
.summary-grid .v {
  color: var(--heading);
  font-weight: 400;
  text-align: right;
  font-feature-settings: "tnum";
}
.summary-grid .v.mono {
  font-family: var(--font-mono);
  font-size: var(--fs-caption);
  font-weight: 500;
}

.ctx-grid {
  display: grid;
  grid-template-columns: 1fr auto;
  row-gap: 10px;
  font-size: var(--fs-caption);
  font-weight: 300;
}
.ctx-grid > :nth-child(odd) { color: var(--body); }
.ctx-grid > :nth-child(even) {
  color: var(--heading);
  font-weight: 400;
  text-align: right;
}

/* Big price total */
.price-total {
  margin-top: var(--space-6);
  padding-top: var(--space-6);
  border-top: 1px solid var(--border);
  display: flex;
  align-items: baseline;
  justify-content: space-between;
}
.price-total .label {
  font-size: var(--fs-caption);
  color: var(--body);
  text-transform: uppercase;
  letter-spacing: var(--tracking-mono);
  font-family: var(--font-mono);
}
.price-total .val {
  font-size: var(--fs-h1);
  font-weight: 300;
  letter-spacing: -0.5px;
  color: var(--heading);
  font-feature-settings: "tnum";
}

/* ═════════════════════════════════════════════
   Download list (results)
   ═════════════════════════════════════════════ */
.dl-list { display: flex; flex-direction: column; gap: 10px; }
.dl {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
}
.dl:hover {
  border-color: var(--brand-lighter);
  background: var(--bg-soft);
}
.dl-name { font-size: var(--fs-body-sm); color: var(--heading); font-weight: 400; }
.dl-sub { font-size: var(--fs-micro); color: var(--body); font-family: var(--font-mono); }

/* ═════════════════════════════════════════════
   Project list (projects.html)
   ═════════════════════════════════════════════ */
.proj-list { display: flex; flex-direction: column; gap: var(--space-4); }
.proj {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-6) var(--space-7);
  display: grid;
  grid-template-columns: 1fr auto auto auto;
  align-items: center;
  gap: var(--space-7);
  box-shadow: var(--shadow-ambient);
  transition: background .12s ease, border-color .12s ease, box-shadow .12s ease, color .12s ease;
}
.proj:hover {
  border-color: var(--brand-lighter);
  box-shadow: var(--shadow-card);
}
.proj-main { min-width: 0; }
.proj-name {
  font-size: var(--fs-h3);
  font-weight: 400;
  color: var(--heading);
  letter-spacing: var(--tracking-h3);
  margin: 0 0 var(--space-1) 0;
}
.proj-meta {
  font-size: var(--fs-caption);
  color: var(--body);
  display: flex;
  gap: var(--space-4);
  flex-wrap: wrap;
  font-feature-settings: "tnum";
}
.proj-meta .mono {
  color: var(--label);
  font-size: var(--fs-micro);
  font-family: var(--font-mono);
}

.phase-ring {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: var(--fs-micro);
  color: var(--body);
}
.phase-dots { display: flex; gap: 3px; }
.phase-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--border);
}
.phase-dot.done { background: var(--brand); }
.phase-dot.active {
  background: var(--brand);
  box-shadow: 0 0 0 3px rgba(83, 58, 253, 0.18);
}

@media (max-width: 780px) {
  .proj {
    grid-template-columns: 1fr;
    align-items: flex-start;
  }
}

/* ═════════════════════════════════════════════
   Filter chips (projects/search)
   ═════════════════════════════════════════════ */
.filters {
  display: flex;
  gap: var(--space-3);
  margin-bottom: var(--space-6);
  font-size: var(--fs-caption);
  align-items: center;
}
.filters .input {
  flex: 1;
  max-width: 300px;
  font-size: var(--fs-caption);
  padding: 8px var(--space-3);
}
.chip {
  padding: 6px var(--space-3);
  border-radius: 999px;
  font-size: var(--fs-micro);
  font-weight: 400;
  background: #fff;
  border: 1px solid var(--border);
  color: var(--label);
  cursor: pointer;
}
.chip:hover { background: var(--bg-soft); }
.chip.active {
  background: rgba(83, 58, 253, 0.06);
  color: var(--brand);
  border-color: var(--brand-lighter);
}

/* ═════════════════════════════════════════════
   Usage cards (settings algemeen)
   ═════════════════════════════════════════════ */
.usage-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}
.usage-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-5) var(--space-6);
  box-shadow: var(--shadow-ambient);
}
.usage-label {
  font-size: var(--fs-nano);
  text-transform: uppercase;
  letter-spacing: var(--tracking-mono);
  color: var(--body);
  font-family: var(--font-mono);
  font-weight: 500;
}
.usage-value {
  font-size: 30px;
  font-weight: 300;
  color: var(--heading);
  letter-spacing: -0.5px;
  margin-top: 6px;
  font-feature-settings: "tnum";
}
.usage-sub {
  font-size: var(--fs-micro);
  color: var(--body);
  margin-top: 2px;
}
@media (max-width: 780px) {
  .usage-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ═════════════════════════════════════════════
   Toast notifications
   ═════════════════════════════════════════════ */
.toast {
  position: fixed;
  bottom: var(--space-7);
  right: var(--space-7);
  padding: var(--space-3) var(--space-5);
  border-radius: var(--radius-md);
  background: #fff;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-card);
  font-size: var(--fs-body-sm);
  color: var(--heading);
  z-index: 200;
  display: none;
  animation: toast-in .18s ease-out;
}
.toast.visible { display: block; }
@keyframes toast-in {
  from { transform: translateY(8px); opacity: 0; }
  to   { transform: translateY(0);  opacity: 1; }
}
.toast.success,
.toast-success {
  border-color: var(--success-border);
  color: var(--success-text);
  background: var(--success-bg);
}
.toast.error,
.toast-error {
  border-color: var(--danger-border);
  color: var(--danger-text);
  background: var(--danger-bg);
}

/* ═════════════════════════════════════════════
   Key-value row (settings: label left, input right)
   ═════════════════════════════════════════════ */
.kv-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--border);
}
.kv-row:last-child { border-bottom: none; }
.kv-row .kv-label {
  flex: 1;
  font-size: var(--fs-body-sm);
  color: var(--heading);
  font-weight: 400;
}
.kv-row .kv-label small {
  display: block;
  font-size: var(--fs-micro);
  color: var(--body);
  font-weight: 300;
  margin-top: 2px;
}
.kv-row .kv-control {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: var(--fs-caption);
  color: var(--body);
}
.kv-row .kv-control .input {
  width: 140px;
  padding: 8px var(--space-3);
  font-size: var(--fs-body-sm);
  text-align: right;
  font-feature-settings: "tnum";
}
.kv-row .kv-control .input.text { text-align: left; width: 220px; }

/* ═════════════════════════════════════════════
   Editable data tables (settings CRUD)
   ═════════════════════════════════════════════ */
.table tr.inactive { opacity: 0.4; }
.table tr.inactive td[contenteditable] { pointer-events: none; }

.table td[contenteditable="true"] {
  cursor: text;
  font-feature-settings: "tnum";
}
.table td[contenteditable="true"]:focus {
  outline: none;
  box-shadow: var(--shadow-focus);
  background: #fff;
  border-radius: 3px;
}

/* JS-hooked delete/restore buttons (settings CRUD) */
.table .btn-del {
  background: none;
  border: none;
  color: var(--body);
  cursor: pointer;
  font-size: var(--fs-body);
  padding: 2px 6px;
  border-radius: var(--radius-xs);
  transition: color .12s ease, background .12s ease;
  font-family: inherit;
}
.table .btn-del:hover {
  color: var(--danger-text);
  background: var(--danger-bg);
}
.table .btn-restore {
  background: none;
  border: none;
  color: var(--success-text);
  cursor: pointer;
  font-size: var(--fs-micro);
  text-decoration: underline;
  font-family: inherit;
  padding: 2px 6px;
}

/* Toolbar (search + add) */
.data-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-3) var(--space-6);
  gap: var(--space-3);
  border-bottom: 1px solid var(--border);
}
.data-toolbar .input {
  flex: 1;
  max-width: 340px;
  padding: 8px var(--space-3);
  font-size: var(--fs-caption);
}

/* Stat card grid (Algemeen tab — synonym for usage-grid) */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: var(--space-4);
}
.stat-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  text-align: center;
  box-shadow: var(--shadow-ambient);
}
.stat-value {
  font-size: 32px;
  font-weight: 300;
  color: var(--heading);
  letter-spacing: -0.5px;
  font-feature-settings: "tnum";
  line-height: 1.1;
}
.stat-label {
  font-size: var(--fs-micro);
  color: var(--body);
  margin-top: 6px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-mono);
  font-family: var(--font-mono);
  font-weight: 500;
}

/* ═════════════════════════════════════════════
   Focus-visible (a11y) — niet-button interactives
   ═════════════════════════════════════════════ */
.tab:focus-visible,
.phase-tab:focus-visible,
.chip:focus-visible,
.icon-btn:focus-visible,
.dl:focus-visible,
.proj:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
  border-radius: var(--radius-xs);
}

/* ═════════════════════════════════════════════
   Mobile touch targets (>= 44px)
   ═════════════════════════════════════════════ */
@media (max-width: 640px) {
  .btn,
  .icon-btn,
  .tab,
  .phase-tab,
  .chip,
  .input,
  textarea.input {
    min-height: 44px;
  }
}

/* ═════════════════════════════════════════════
   Dividers
   ═════════════════════════════════════════════ */
.divider {
  height: 1px;
  background: var(--border);
  margin: var(--space-6) 0;
  border: none;
}
