/* =============================================================================
   K-BOTANAS · Design System
   Tokens + componentes compartidos. Cargar ANTES de sidebar.css en todas las páginas.
   ========================================================================== */

:root {
  /* Cremas / fondos */
  --kb-cream: #f4f1ea;
  --kb-cream-soft: #f8f5ee;
  --kb-paper: #fbfaf5;
  --kb-card: #ffffff;
  --kb-line: #e8e2d3;
  --kb-line-soft: #efebdf;
  --kb-line-strong: #d9d1bd;

  /* Tinta (escala de 5 niveles) */
  --kb-ink:   #1f1a14;
  --kb-ink-2: #3a322a;
  --kb-ink-3: #6b6155;
  --kb-ink-4: #968b7c;
  --kb-ink-5: #b8ad9d;

  /* Acentos */
  --kb-green:           #2f6b3a;
  --kb-green-2:         #3d8b4d;
  --kb-green-soft:      #dde8d2;
  --kb-green-tint:      #eef2e3;
  --kb-terracotta:      #b04a2f;
  --kb-terracotta-2:    #c45a3c;
  --kb-terracotta-soft: #f3d9cc;
  --kb-terracotta-tint: #f7e6dc;
  --kb-mustard:         #c8923a;
  --kb-mustard-soft:    #f3e1bf;
  --kb-blue:            #3a5b8a;
  --kb-blue-soft:       #d8e0ed;
  --kb-blue-tint:       #e6ecf3;
  --kb-red:             #8a2a1f;
  --kb-red-soft:        #efd4cd;

  /* Estado */
  --kb-positive: #2f6b3a;
  --kb-warning:  #b8741f;
  --kb-danger:   #8a2a1f;

  /* Tipografía */
  --kb-font-display: "Fraunces", "Cooper Hewitt", Georgia, serif;
  --kb-font-sans:    "Inter", "Helvetica Neue", system-ui, sans-serif;
  --kb-font-mono:    "JetBrains Mono", "Menlo", monospace;

  /* Densidad / radios */
  --kb-base-size: 14px;
  --kb-radius:    10px;
  --kb-radius-sm: 6px;
  --kb-radius-lg: 14px;

  /* Sidebar / chrome */
  --kb-sidebar-w: 264px;

  /* ── Compat aliases (mapean tokens antiguos al sistema nuevo) ─────────── */
  --kb-red-dk:    var(--kb-terracotta);
  --kb-gold:      var(--kb-mustard);
  --kb-cream-2:   var(--kb-cream-soft);
  --kb-ink-soft:  var(--kb-ink-2);
  --kb-mute:      var(--kb-ink-3);
}

/* IMPORTANTE: --kb-red en el sistema nuevo es vino oscuro (#8a2a1f). Las
   páginas viejas usaban --kb-red como acento principal de marca; lo re-mapeamos
   a terracotta para mantener consistencia visual con el nuevo lenguaje. */
:root {
  --kb-red: var(--kb-terracotta);
}

[data-theme="dark"] {
  --kb-cream: #1a1714;
  --kb-cream-soft: #221d18;
  --kb-paper: #15110d;
  --kb-card: #221d18;
  --kb-line: #332b22;
  --kb-line-soft: #2a241d;
  --kb-line-strong: #3f372d;
  --kb-ink: #f4ede0;
  --kb-ink-2: #d9cfbe;
  --kb-ink-3: #a89c87;
  --kb-ink-4: #786d5b;
  --kb-ink-5: #4f4639;
  --kb-green: #6fa978;
  --kb-green-2: #82bd8b;
  --kb-green-soft: #2c3a2c;
  --kb-green-tint: #232b22;
  --kb-terracotta: #d97a5a;
  --kb-terracotta-2: #e58e6f;
  --kb-terracotta-soft: #4a2e22;
  --kb-terracotta-tint: #34241c;
  --kb-mustard: #d9a55a;
  --kb-mustard-soft: #3d2f1a;
  --kb-blue: #7a9bca;
  --kb-blue-soft: #2a3548;
  --kb-blue-tint: #232a36;
  --kb-red: #d97565;
  --kb-red-soft: #44241f;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--kb-font-sans);
  font-size: var(--kb-base-size);
  color: var(--kb-ink);
  background: var(--kb-cream);
  -webkit-font-smoothing: antialiased;
  font-feature-settings: "ss01", "cv11";
}

/* Tipografía utilitaria */
.kb-display { font-family: var(--kb-font-display); font-weight: 500; letter-spacing: -0.01em; }
.kb-mono    { font-family: var(--kb-font-mono); font-feature-settings: "tnum"; }
.kb-tnum    { font-variant-numeric: tabular-nums; }

h1, h2, h3, h4 { margin: 0; font-weight: 500; color: var(--kb-ink); }

/* Hairline decorativa terracotta */
.kb-section-bar {
  display: inline-block;
  width: 24px; height: 2px;
  background: var(--kb-terracotta);
  margin-bottom: 12px;
}

/* Pill / chip */
.kb-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 3px 10px; border-radius: 999px;
  font-size: 11.5px; font-weight: 500; letter-spacing: 0.01em;
  border: 1px solid var(--kb-line);
  background: var(--kb-cream-soft);
  color: var(--kb-ink-2);
  white-space: nowrap;
}
.kb-pill.green   { background: var(--kb-green-tint);      color: var(--kb-green);      border-color: color-mix(in oklab, var(--kb-green) 20%, transparent); }
.kb-pill.terra   { background: var(--kb-terracotta-tint); color: var(--kb-terracotta); border-color: color-mix(in oklab, var(--kb-terracotta) 20%, transparent); }
.kb-pill.mustard { background: var(--kb-mustard-soft);    color: var(--kb-mustard);    border-color: color-mix(in oklab, var(--kb-mustard) 25%, transparent); }
.kb-pill.blue    { background: var(--kb-blue-tint);       color: var(--kb-blue);       border-color: color-mix(in oklab, var(--kb-blue) 22%, transparent); }
.kb-pill.red     { background: var(--kb-red-soft);        color: var(--kb-red);        border-color: color-mix(in oklab, var(--kb-red) 25%, transparent); }

/* Dot indicator */
.kb-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--kb-ink-4); display: inline-block; }
.kb-dot.green   { background: var(--kb-green); }
.kb-dot.terra   { background: var(--kb-terracotta); }
.kb-dot.mustard { background: var(--kb-mustard); }
.kb-dot.red     { background: var(--kb-red); }

/* Stamp (mono pequeño tipo etiqueta) */
.kb-stamp {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--kb-font-mono); font-size: 11px;
  color: var(--kb-ink-3);
  padding: 2px 8px; border-radius: 4px;
  background: var(--kb-cream-soft);
  border: 1px solid var(--kb-line);
}

/* Botones */
.kb-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 8px 14px; border-radius: 8px;
  font-family: var(--kb-font-sans); font-size: 13px; font-weight: 500;
  border: 1px solid var(--kb-line-strong);
  background: var(--kb-card); color: var(--kb-ink);
  cursor: pointer; transition: all 0.15s;
}
.kb-btn:hover { background: var(--kb-cream-soft); border-color: var(--kb-ink-4); }
.kb-btn.primary { background: var(--kb-green); color: #f4f1ea; border-color: var(--kb-green); }
.kb-btn.primary:hover { background: var(--kb-green-2); border-color: var(--kb-green-2); }
.kb-btn.ghost { background: transparent; border-color: transparent; }
.kb-btn.ghost:hover { background: var(--kb-cream-soft); }
.kb-btn.danger { color: var(--kb-danger); border-color: color-mix(in oklab, var(--kb-danger) 30%, var(--kb-line-strong)); }

/* Cards */
.kb-card {
  background: var(--kb-card);
  border: 1px solid var(--kb-line);
  border-radius: var(--kb-radius);
}
.kb-card.flat { border-radius: var(--kb-radius-sm); }

/* Tabla */
.kb-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.kb-table thead th {
  text-align: left; font-weight: 500; color: var(--kb-ink-3);
  font-size: 11.5px; letter-spacing: 0.04em; text-transform: uppercase;
  padding: 10px 12px; border-bottom: 1px solid var(--kb-line);
}
.kb-table tbody td {
  padding: 12px; border-bottom: 1px solid var(--kb-line-soft);
  vertical-align: middle;
}
.kb-table tbody tr:hover td { background: var(--kb-cream-soft); }
.kb-table tbody tr:last-child td { border-bottom: none; }

/* Progress */
.kb-progress {
  height: 6px; background: var(--kb-line-soft); border-radius: 999px;
  overflow: hidden; position: relative;
}
.kb-progress > span {
  display: block; height: 100%; background: var(--kb-green); border-radius: 999px;
  transition: width 0.3s;
}
.kb-progress.terra > span   { background: var(--kb-terracotta); }
.kb-progress.mustard > span { background: var(--kb-mustard); }

/* Inputs */
.kb-input {
  font-family: var(--kb-font-sans); font-size: 13px;
  padding: 8px 12px; border-radius: 8px;
  border: 1px solid var(--kb-line-strong);
  background: var(--kb-card); color: var(--kb-ink);
  outline: none; transition: border-color 0.15s, box-shadow 0.15s;
}
.kb-input:focus {
  border-color: var(--kb-green);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--kb-green) 15%, transparent);
}

/* Scrollbar discreto */
.kb-scroll::-webkit-scrollbar { width: 8px; height: 8px; }
.kb-scroll::-webkit-scrollbar-track { background: transparent; }
.kb-scroll::-webkit-scrollbar-thumb { background: var(--kb-line-strong); border-radius: 4px; }

/* Toast */
.kb-toast {
  position: fixed; top: 20px; right: 20px;
  background: var(--kb-ink); color: var(--kb-cream);
  padding: 12px 18px; border-radius: 10px;
  box-shadow: 0 12px 32px rgba(31,26,20,.18);
  z-index: 9999; font-size: 13px;
  animation: kb-slide-in .25s ease;
  max-width: 320px;
}
.kb-toast.warn { background: var(--kb-mustard); color: var(--kb-ink); }
@keyframes kb-slide-in {
  from { transform: translateX(20px); opacity: 0; }
  to   { transform: translateX(0); opacity: 1; }
}
