/* ── Google Fonts ──────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

/* ── Design tokens ─────────────────────────────────── */
:root {
  /* Typography */
  --sans: 'IBM Plex Sans', system-ui, sans-serif;
  --mono: 'IBM Plex Mono', 'Courier New', monospace;
  --font-primary: var(--sans);
  --font-mono:    var(--mono);

  /* Claude Design palette */
  --ink:       #0c0014;
  --gray-900:  #0c0014;
  --gray-800:  #221a2c;
  --gray-700:  #3a3343;
  --gray-600:  #5a525f;
  --gray-500:  #7a7480;
  --gray-400:  #a59fa8;
  --gray-300:  #cbc6cd;
  --gray-200:  #e6e2e4;
  --gray-150:  #ece8ea;
  --gray-100:  #f1eeef;
  --gray-50:   #f9f7f6;
  --line:      #e6e2e4;
  --line-strong: #d6d2d4;

  /* Semantic — light mode */
  --bg:          #f9f7f6;
  --canvas:      #f9f7f6;
  --surface:     #ffffff;
  --surface2:    #f1eeef;
  --border:      #e6e2e4;
  --border-strong: #d6d2d4;
  --text:        #0c0014;
  --text-muted:  #7a7480;
  --text-sub:    #5a525f;

  /* Accents */
  --accent:    #0c0014;
  --accent-dk: #221a2c;

  /* Functional */
  --danger:    #d9291c;
  --success:   #1a7a4a;
  --warn:      #f2d335;
  --warn-text: #7a6300;
  --info:      #122d64;
  --highlight: #53e8f6;

  /* Brand colors (kept for compatibility) */
  --color-white:      #ffffff;
  --color-black:      #0c0014;
  --color-magenta:    #bf1ba4;
  --color-magenta-dk: #9a1585;
  --color-blue:       #122d64;
  --color-yellow:     #f2d335;
  --color-cyan:       #53e8f6;

  /* Shadows */
  --shadow-1: 0 1px 0 rgba(17,17,20,.02), 0 1px 2px rgba(17,17,20,.04);
  --shadow-2: 0 4px 16px rgba(17,17,20,.06);

  /* Radii */
  --radius:      10px;
  --radius-sm:   6px;
  --radius-pill: 999px;

  /* Sidebar */
  --sidebar-w:           232px;
  --sidebar-bg:          #ffffff;
  --sidebar-surface:     #f1eeef;
  --sidebar-border:      #e6e2e4;
  --sidebar-text:        #5a525f;
  --sidebar-text-active: #ffffff;
  --sidebar-accent:      #0c0014;
}

/* ── Dark mode ──────────────────────────────────────── */
[data-theme="dark"] {
  --bg:          #0c0014;
  --canvas:      #0c0014;
  --surface:     #140a20;
  --surface2:    #1f1030;
  --border:      #2d1d44;
  --border-strong: #3d2d54;
  --text:        #f9f7f6;
  --text-muted:  #8a7e96;
  --text-sub:    #7a7080;
  --accent:      #e9e4eb;
  --accent-dk:   #d9d4db;
  --danger:      #f04444;
  --success:     #2ecf7a;
  --warn:        #f2d335;
  --warn-text:   #f2d335;
  --info:        #3a6fd8;
  --sidebar-bg:          #0c0014;
  --sidebar-surface:     #1a0e28;
  --sidebar-border:      #2d1d44;
  --sidebar-text:        rgba(255,255,255,0.50);
  --sidebar-text-active: #0c0014;
}

/* ── Reset ─────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 400;
  line-height: 1.45;
  background: var(--bg);
  color: var(--text);
  height: 100vh;
  overflow: hidden;
  -webkit-font-smoothing: antialiased;
  font-feature-settings: "ss01", "cv11";
  transition: background 0.2s, color 0.2s;
}

/* ── Layout ────────────────────────────────────────── */
#app { display: flex; height: 100vh; }

/* ── Sidebar ───────────────────────────────────────── */
.sidebar {
  width: var(--sidebar-w);
  background: var(--sidebar-bg);
  border-right: 1px solid var(--sidebar-border);
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  padding: 20px 0 16px;
}

.sidebar__logo {
  display: flex;
  flex-direction: column;
  padding: 0 18px 22px;
  border-bottom: 1px solid var(--sidebar-border);
}
.logo-text {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -0.3px;
}
[data-theme="dark"] .logo-text { color: #f9f7f6; }
.logo-sub {
  font-size: 0.62rem;
  color: var(--sidebar-text);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 500;
  margin-top: 1px;
}

.sidebar-logo-img {
  max-width: 168px;
  max-height: 48px;
  object-fit: contain;
  object-position: left center;
}

.sidebar__nav { display: flex; flex-direction: column; gap: 1px; padding: 12px 10px; flex: 1; overflow-y: auto; }
.nav-spacer { margin-top: auto; padding-top: 8px; border-top: 1px solid var(--sidebar-border); }
.nav-separator { height: 1px; background: var(--sidebar-border); margin: 8px 4px; flex-shrink: 0; }

.nav-item {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 8px 10px;
  border-radius: var(--radius-sm);
  border: none;
  background: none;
  color: var(--sidebar-text);
  font-family: var(--sans);
  font-size: 11.5px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.13s, color 0.13s;
  text-align: left;
  width: 100%;
}
.nav-item:hover {
  background: var(--sidebar-surface);
  color: var(--ink);
}
[data-theme="dark"] .nav-item:hover { color: #f9f7f6; }
.nav-item.active {
  background: var(--ink);
  color: #ffffff;
  font-weight: 600;
}
[data-theme="dark"] .nav-item.active {
  background: #f9f7f6;
  color: #0c0014;
}
.nav-icon {
  font-size: 0.9rem;
  width: 16px;
  text-align: center;
  flex-shrink: 0;
  opacity: 0.8;
}

/* ── Submenús ──────────────────────────────────────── */
.nav-group { display: flex; flex-direction: column; }
.nav-group .nav-item { width: 100%; }

.nav-chevron {
  margin-left: auto;
  font-size: 0.8rem;
  color: var(--sidebar-text);
  transition: transform 0.18s;
  line-height: 1;
  opacity: 0.7;
}
.nav-group.is-open .nav-chevron { transform: rotate(90deg); }

.nav-sub {
  display: none;
  flex-direction: column;
  gap: 0;
  padding: 2px 0 4px 34px;
}
.nav-group.is-open .nav-sub { display: flex; }

.nav-sub-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  background: none;
  border: none;
  padding: 5px 8px;
  border-radius: var(--radius-sm);
  font-family: var(--sans);
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--sidebar-text);
  cursor: pointer;
  text-align: left;
  transition: background 0.1s, color 0.1s;
  white-space: nowrap;
  gap: 6px;
}
.nav-sub-item:hover {
  background: var(--sidebar-surface);
  color: var(--ink);
}
[data-theme="dark"] .nav-sub-item:hover { color: #f9f7f6; }
.nav-sub-item.is-active {
  color: var(--ink);
  font-weight: 700;
}
[data-theme="dark"] .nav-sub-item.is-active { color: #f9f7f6; }

.nav-sub-badge {
  flex-shrink: 0;
  min-width: 18px;
  height: 16px;
  padding: 0 5px;
  background: var(--gray-100);
  color: var(--gray-700);
  border-radius: var(--radius-pill);
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}
.nav-sub-item.is-active .nav-sub-badge {
  background: var(--ink);
  color: #ffffff;
}
[data-theme="dark"] .nav-sub-badge { background: rgba(255,255,255,0.1); color: rgba(255,255,255,0.7); }
[data-theme="dark"] .nav-sub-item.is-active .nav-sub-badge { background: rgba(255,255,255,0.9); color: #0c0014; }

/* ── Main area ─────────────────────────────────────── */
.main { flex: 1; display: flex; flex-direction: column; overflow: hidden; }

/* ── Topbar ────────────────────────────────────────── */
.topbar {
  display: flex;
  align-items: center;
  padding: 12px 24px;
  border-bottom: 1px solid var(--line);
  background: var(--canvas);
  z-index: 10;
  gap: 12px;
  min-height: 52px;
}
.topbar__title {
  font-size: 20px;
  font-weight: 600;
  color: var(--ink);
  letter-spacing: -0.3px;
  flex: 1;
  line-height: 1.2;
}
[data-theme="dark"] .topbar__title { color: #f9f7f6; }

/* ── Theme toggle ──────────────────────────────────── */
.theme-toggle {
  display: flex;
  align-items: center;
  gap: 6px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-pill);
  padding: 5px 12px 5px 9px;
  cursor: pointer;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 500;
  color: var(--text-muted);
  transition: background 0.13s, color 0.13s, border-color 0.13s;
  white-space: nowrap;
  flex-shrink: 0;
}
.theme-toggle:hover { background: var(--gray-100); color: var(--text); border-color: var(--border-strong); }
.theme-toggle__icon { font-size: 0.9rem; line-height: 1; }

/* ── Content ───────────────────────────────────────── */
.content { flex: 1; overflow-y: auto; padding: 24px; background: var(--bg); }
.content--god { background: #e6e2e4; }
[data-theme="dark"] .content--god { background: var(--bg); }
.content:has(.cal-container) { padding: 0; overflow: hidden; display: flex; flex-direction: column; }

/* ── Buttons ───────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 7px 14px;
  border-radius: var(--radius-sm);
  border: 1px solid transparent;
  font-family: var(--sans);
  font-size: 12.5px;
  font-weight: 500;
  cursor: pointer;
  transition: opacity 0.13s, background 0.13s, border-color 0.13s;
  white-space: nowrap;
  line-height: 1.4;
}
.btn:disabled { opacity: 0.38; cursor: not-allowed; }
.btn:not(:disabled):hover { opacity: 0.88; }

.btn--primary {
  background: var(--ink);
  color: #ffffff;
  border-color: var(--ink);
  font-weight: 600;
}
[data-theme="dark"] .btn--primary { background: #f9f7f6; color: #0c0014; border-color: #f9f7f6; }

.btn--danger  { background: var(--danger); color: #fff; border-color: var(--danger); }
.btn--ghost   {
  background: var(--surface);
  color: var(--text);
  border-color: var(--border-strong);
}
.btn--ghost:not(:disabled):hover { background: var(--gray-50); }
.btn--info    { background: var(--info); color: #fff; border-color: var(--info); }
.btn--sm      { padding: 4px 10px; font-size: 11.5px; }

/* ── Cards / Grid ──────────────────────────────────── */
.grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 14px; }

.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  box-shadow: var(--shadow-1);
  transition: border-color 0.13s, box-shadow 0.13s;
}
.card:hover { border-color: var(--border-strong); box-shadow: var(--shadow-2); }
.card__title   { font-weight: 600; font-size: 0.9rem; }
.card__meta    { font-size: 0.78rem; color: var(--text-muted); }
.card__actions { display: flex; gap: 8px; margin-top: auto; padding-top: 12px; }

/* ── Badges de estado ──────────────────────────────── */
.badge {
  display: inline-block;
  padding: 3px 9px;
  border-radius: var(--radius-pill);
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  border: 1px solid transparent;
  line-height: 1.4;
}

/* Proyectos */
.badge--borrador    { color: var(--gray-500); border-color: var(--gray-300); background: transparent; }
.badge--activo      { background: var(--ink); color: #ffffff; border-color: var(--ink); }
.badge--pausado     { color: var(--gray-400); border: 1px dashed var(--gray-400); background: transparent; }
.badge--terminado   { background: var(--gray-700); color: #ffffff; border-color: var(--gray-700); }
.badge--facturado   { background: var(--ink); color: #ffffff; border-color: var(--ink); }
.badge--archivado   { color: var(--gray-400); background: var(--gray-50); border-color: var(--gray-200); }
.badge--pendiente   { color: var(--gray-600); border-color: var(--gray-300); background: transparent; }
.badge--en_progreso { background: var(--gray-700); color: #ffffff; border-color: var(--gray-700); }
.badge--hecha       { background: var(--ink); color: #ffffff; border-color: var(--ink); }
.badge--pending     { color: var(--gray-600); border-color: var(--gray-300); background: transparent; }
.badge--in_progress { background: var(--gray-700); color: #ffffff; border-color: var(--gray-700); }
.badge--completed   { background: var(--ink); color: #ffffff; border-color: var(--ink); }
.badge--alta        { color: var(--danger); border-color: var(--danger); background: rgba(217,41,28,.07); }
.badge--media       { color: var(--warn-text); border-color: var(--warn); background: rgba(242,211,53,.12); }
.badge--baja        { color: var(--gray-500); border-color: var(--gray-300); background: transparent; }

/* Facturas */
.badge--emitida      { color: var(--gray-700); border-color: var(--gray-300); background: transparent; }
.badge--pagada       { background: var(--ink); color: #ffffff; border-color: var(--ink); }
.badge--vencida      { color: var(--danger); border-color: var(--danger); background: rgba(217,41,28,.07); }
.badge--cancelada    { color: var(--gray-500); border-color: var(--gray-300); background: transparent; }
.badge--rectificativa { color: #c2410c; border-color: #c2410c; background: rgba(194,65,12,.07); }

/* Presupuestos */
.badge--enviado    { color: var(--info); border-color: var(--info); background: rgba(18,45,100,.07); }
.badge--aceptado   { background: var(--ink); color: #ffffff; border-color: var(--ink); }
.badge--rechazado  { color: var(--danger); border-color: var(--danger); background: rgba(217,41,28,.07); }
.badge--convertido { background: var(--gray-700); color: #ffffff; border-color: var(--gray-700); }

/* Gastos */
.badge--pagado  { background: var(--ink); color: #ffffff; border-color: var(--ink); }
.badge--anulado { color: var(--gray-500); border-color: var(--gray-300); background: transparent; }

/* Facturas — pago */
.badge--pagado-pago     { background: var(--ink); color: #ffffff; border-color: var(--ink); }
.badge--pendiente-pago  { color: var(--danger); border-color: var(--danger); background: rgba(217,41,28,.07); }

/* Dark mode badge overrides */
[data-theme="dark"] .badge--borrador    { color: var(--text-muted); border-color: #3d3550; }
[data-theme="dark"] .badge--activo      { background: #f9f7f6; color: #0c0014; border-color: #f9f7f6; }
[data-theme="dark"] .badge--pausado     { color: var(--color-yellow); border-color: var(--color-yellow); }
[data-theme="dark"] .badge--terminado   { background: #4a4060; color: #f9f7f6; border-color: #4a4060; }
[data-theme="dark"] .badge--facturado   { background: #f9f7f6; color: #0c0014; border-color: #f9f7f6; }
[data-theme="dark"] .badge--archivado   { color: var(--text-muted); background: var(--surface2); border-color: var(--border); }
[data-theme="dark"] .badge--pendiente   { color: var(--color-cyan); border-color: #1a4a5a; background: transparent; }
[data-theme="dark"] .badge--en_progreso { background: #2ecf7a; color: #0c0014; border-color: #2ecf7a; }
[data-theme="dark"] .badge--hecha       { background: var(--color-cyan); color: #0c0014; border-color: var(--color-cyan); }
[data-theme="dark"] .badge--pending     { color: var(--color-cyan); border-color: #1a4a5a; background: transparent; }
[data-theme="dark"] .badge--in_progress { background: #2ecf7a; color: #0c0014; border-color: #2ecf7a; }
[data-theme="dark"] .badge--completed   { background: var(--color-cyan); color: #0c0014; border-color: var(--color-cyan); }
[data-theme="dark"] .badge--alta        { color: #f04444; border-color: #f04444; background: rgba(240,68,68,.1); }
[data-theme="dark"] .badge--media       { color: var(--color-yellow); border-color: var(--color-yellow); background: rgba(242,211,53,.1); }
[data-theme="dark"] .badge--baja        { color: var(--text-muted); border-color: #3d3550; }
[data-theme="dark"] .badge--emitida     { color: #60a5fa; border-color: #1a3060; background: transparent; }
[data-theme="dark"] .badge--pagada      { background: #2ecf7a; color: #0c0014; border-color: #2ecf7a; }
[data-theme="dark"] .badge--vencida     { color: #f04444; border-color: #f04444; background: rgba(240,68,68,.1); }
[data-theme="dark"] .badge--cancelada   { color: var(--text-muted); border-color: #3d3550; background: transparent; }
[data-theme="dark"] .badge--rectificativa { color: #fb923c; border-color: #fb923c; background: rgba(251,146,60,.1); }
[data-theme="dark"] .badge--enviado     { color: #60a5fa; border-color: #1a3060; background: rgba(96,165,250,.08); }
[data-theme="dark"] .badge--aceptado    { background: #2ecf7a; color: #0c0014; border-color: #2ecf7a; }
[data-theme="dark"] .badge--rechazado   { color: #f04444; border-color: #f04444; background: rgba(240,68,68,.1); }
[data-theme="dark"] .badge--convertido  { background: #4a4060; color: #f9f7f6; border-color: #4a4060; }
[data-theme="dark"] .badge--pagado      { background: #2ecf7a; color: #0c0014; border-color: #2ecf7a; }
[data-theme="dark"] .badge--anulado     { color: var(--text-muted); border-color: #3d3550; background: transparent; }
[data-theme="dark"] .badge--pagado-pago    { background: #2ecf7a; color: #0c0014; border-color: #2ecf7a; }
[data-theme="dark"] .badge--pendiente-pago { color: #f04444; border-color: #f04444; background: rgba(240,68,68,.1); }

/* ── Empty state ───────────────────────────────────── */
.empty {
  text-align: center;
  color: var(--text-muted);
  padding: 60px 0;
  font-size: 0.88rem;
}

/* ── Tabla genérica ────────────────────────────────── */
.table-wrap { overflow-x: auto; }
table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12.5px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
th {
  text-align: left;
  padding: 9px 14px;
  background: var(--gray-50);
  color: var(--gray-500);
  font-weight: 600;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
}
td {
  padding: 11px 14px;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
  color: var(--text);
}
tr:last-child td { border-bottom: none; }
tr:hover td { background: var(--gray-50); }
.actions-cell { display: flex; gap: 6px; }

td.mono, .mono { font-family: var(--mono); font-size: 12px; }

/* ── Modal ─────────────────────────────────────────── */
.modal-overlay {
  position: fixed; inset: 0;
  background: rgba(12,0,20,0.55);
  display: flex; align-items: center; justify-content: center;
  z-index: 100;
  backdrop-filter: blur(2px);
}
.modal-overlay[hidden] { display: none; }
.modal {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  width: 100%;
  max-width: 480px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 20px 60px rgba(12,0,20,0.18);
}
.modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--border);
}
.modal__title  { font-size: 14px; font-weight: 600; color: var(--text); }
.modal__close  {
  background: none; border: none;
  color: var(--text-muted);
  font-size: 1rem;
  cursor: pointer;
  line-height: 1;
  transition: color 0.13s;
  padding: 2px 6px;
  border-radius: var(--radius-sm);
}
.modal__close:hover { color: var(--text); background: var(--surface2); }
.modal__body   { padding: 20px; overflow-y: auto; }
.modal__footer { display: flex; gap: 8px; justify-content: flex-end; padding: 14px 20px; border-top: 1px solid var(--border); }

/* ── Formularios ───────────────────────────────────── */
.form-group { display: flex; flex-direction: column; gap: 5px; margin-bottom: 14px; }
.form-group label {
  font-size: 10.5px;
  color: var(--gray-500);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.form-group input,
.form-group select,
.form-group textarea {
  background: var(--surface);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  color: var(--text);
  padding: 7px 11px;
  font-size: 13px;
  font-family: var(--sans);
  transition: border-color 0.13s, box-shadow 0.13s;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  outline: none;
  border-color: var(--ink);
  box-shadow: 0 0 0 2px rgba(12,0,20,0.1);
}
[data-theme="dark"] .form-group input:focus,
[data-theme="dark"] .form-group select:focus,
[data-theme="dark"] .form-group textarea:focus {
  border-color: #a59fa8;
  box-shadow: 0 0 0 2px rgba(165,159,168,0.15);
}
.form-group input:disabled,
.form-group select:disabled,
.form-group textarea:disabled {
  background: var(--gray-100);
  color: var(--text-muted);
  cursor: not-allowed;
  opacity: 0.7;
}
.form-group textarea { resize: vertical; min-height: 80px; }

.pw-wrap { position: relative; display: flex; }
.pw-wrap input { flex: 1; padding-right: 36px !important; }
.pw-eye {
  position: absolute; right: 1px; top: 1px; bottom: 1px; width: 34px;
  background: transparent; border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: var(--text-muted); border-radius: 0 5px 5px 0;
}
.pw-eye:hover { color: var(--text); }

.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.form-row--addr { grid-template-columns: 100px 1fr 1fr; }
.form-group--sm { min-width: 0; }
.form-group small { color: var(--text-muted); font-weight: 400; font-size: 11.5px; }

.fp-num-row {
  display: flex;
  align-items: stretch;
  margin-bottom: 4px;
}
.fp-prefix-tag {
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 600;
  color: var(--text-muted);
  background: var(--gray-100);
  border: 1px solid var(--border-strong);
  border-right: none;
  border-radius: var(--radius-sm) 0 0 var(--radius-sm);
  padding: 0 10px;
  display: flex;
  align-items: center;
  white-space: nowrap;
  user-select: none;
}
.fp-num-row input {
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0 !important;
  width: 72px;
  min-width: 0;
}
.fp-codigo-preview {
  font-family: var(--mono);
  font-size: 11.5px;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: 1px;
  display: block;
  min-height: 1em;
}
[data-theme="dark"] .fp-codigo-preview { color: var(--accent); }

/* ── Clientes toolbar ──────────────────────────────── */
.clientes-toolbar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 18px;
}
.search-input {
  flex: 1;
  max-width: 320px;
  background: var(--surface);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  color: var(--text);
  padding: 7px 12px;
  font-size: 13px;
  font-family: var(--sans);
  transition: border-color 0.13s, box-shadow 0.13s;
}
.search-input:focus {
  outline: none;
  border-color: var(--ink);
  box-shadow: 0 0 0 2px rgba(12,0,20,.1);
}
[data-theme="dark"] .search-input:focus { border-color: #a59fa8; box-shadow: 0 0 0 2px rgba(165,159,168,.15); }
.clientes-count { font-size: 11.5px; color: var(--text-muted); }

/* ── Clientes grid ─────────────────────────────────── */
.clientes-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 14px;
}

.cliente-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  box-shadow: var(--shadow-1);
  transition: border-color 0.13s, box-shadow 0.13s;
}
.cliente-card:hover { border-color: var(--border-strong); box-shadow: var(--shadow-2); }

.cliente-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.matricula-badge {
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  background: var(--ink);
  color: #ffffff;
  padding: 3px 9px;
  border-radius: var(--radius-pill);
}
[data-theme="dark"] .matricula-badge { background: #f9f7f6; color: #0c0014; }

.cliente-card__actions { display: flex; gap: 6px; }
.cliente-card__nombre { font-size: 14px; font-weight: 600; line-height: 1.2; }
.cliente-card__cif { font-family: var(--mono); font-size: 11.5px; color: var(--text-muted); }
.cliente-card__contacto { display: flex; flex-wrap: wrap; gap: 4px 12px; font-size: 12px; color: var(--text-muted); }
.cliente-card__dir { font-size: 11.5px; color: var(--text-muted); border-top: 1px solid var(--border); padding-top: 8px; }
.cliente-card__proyectos { margin-top: auto; padding-top: 10px; border-top: 1px solid var(--border); }
.proyectos-label { display: flex; justify-content: space-between; font-size: 11.5px; color: var(--text-muted); }

/* ── Dashboard ─────────────────────────────────────── */
.dash-loading { color: var(--text-muted); padding: 20px; font-size: 13px; }

.dash-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.dash-widget {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px 20px 16px;
  box-shadow: var(--shadow-1);
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-height: 170px;
  max-height: 250px;
  transition: border-color 0.13s, box-shadow 0.13s;
}
.dash-widget:hover { border-color: var(--border-strong); box-shadow: var(--shadow-2); }

.dash-widget__label {
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--gray-500);
}

.dash-widget__value {
  font-family: var(--sans);
  font-size: 30px;
  font-weight: 500;
  line-height: 1;
  color: var(--text);
  letter-spacing: -0.5px;
}
.dash-widget__value .val-unit {
  font-size: 18px;
  color: var(--gray-500);
  font-weight: 400;
}
.dash-widget__sub { font-size: 12px; color: var(--text-muted); }
.dash-widget__ok  { font-size: 12px; color: var(--success); font-weight: 600; }

/* Value color modifiers */
.dv--blue    { color: var(--info) !important; }
.dv--red     { color: var(--danger) !important; }
.dv--green   { color: var(--success) !important; }
.dv--warn    { color: var(--warn-text) !important; }
.dv--cyan    { color: #0e8fa0 !important; }
.dv--magenta { color: var(--color-magenta) !important; }

[data-theme="dark"] .dv--blue    { color: #60a5fa !important; }
[data-theme="dark"] .dv--warn    { color: var(--color-yellow) !important; }
[data-theme="dark"] .dv--cyan    { color: var(--color-cyan) !important; }
[data-theme="dark"] .dv--magenta { color: #e879d0 !important; }

/* Barra comparativa */
.dash-compbar-wrap { display: flex; flex-direction: column; gap: 6px; margin-top: auto; }
.dash-compbar-labels {
  display: flex;
  justify-content: space-between;
  font-size: 12px;
  font-weight: 600;
}
.dash-compbar {
  height: 8px;
  border-radius: var(--radius-pill);
  background: var(--gray-200);
  overflow: hidden;
  display: flex;
}
.dash-compbar__ing { height: 100%; background: var(--ink); transition: width 0.4s; }
[data-theme="dark"] .dash-compbar__ing { background: #f9f7f6; }
.dash-compbar__gas { height: 100%; background: var(--danger); transition: width 0.4s; }

/* Barra split */
.dash-pend { display: flex; flex-direction: column; gap: 7px; margin-top: auto; }
.dash-pend__rows {
  display: flex;
  flex-direction: column;
  gap: 3px;
  font-size: 11.5px;
  font-weight: 500;
}
.dash-split-bar {
  height: 8px;
  border-radius: var(--radius-pill);
  background: var(--gray-200);
  overflow: hidden;
  display: flex;
}
.dash-split-bar > div { height: 100%; transition: width 0.4s; }

/* IVA */
.dash-iva { display: flex; flex-direction: column; gap: 10px; flex: 1; }
.dash-iva__section { display: flex; flex-direction: column; gap: 5px; }
.dash-iva__section--dim { opacity: 0.6; }
.dash-iva__qtitle {
  font-size: 11px;
  font-weight: 700;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 2px;
}
.dash-iva__badge {
  font-size: 10px;
  background: var(--gray-100);
  color: var(--gray-700);
  padding: 1px 7px;
  border-radius: var(--radius-pill);
  font-weight: 700;
  letter-spacing: 0.04em;
  border: 1px solid var(--gray-200);
}
.dash-iva__badge--dim { background: var(--surface2); color: var(--text-muted); border-color: var(--border); }
[data-theme="dark"] .dash-iva__badge { background: rgba(255,255,255,0.08); color: rgba(255,255,255,0.7); border-color: rgba(255,255,255,0.1); }
.dash-iva__row {
  display: flex;
  justify-content: space-between;
  font-size: 12px;
  color: var(--text-muted);
}
.dash-iva__row span:last-child {
  font-family: var(--mono);
  font-weight: 600;
  color: var(--text);
}
.dash-iva__row--dest span:last-child { color: var(--ink); font-size: 13px; }
[data-theme="dark"] .dash-iva__row--dest span:last-child { color: var(--accent); }
.dash-iva__divider { border: none; border-top: 1px solid var(--border); }

/* Delta */
.dash-delta {
  display: inline-flex;
  align-items: center;
  font-size: 11px;
  font-weight: 700;
  font-family: var(--mono);
  padding: 2px 8px;
  border-radius: var(--radius-pill);
  white-space: nowrap;
  line-height: 1.4;
}
.dash-delta--up   { background: var(--gray-100); color: var(--success); border: 1px solid rgba(26,122,74,.2); }
.dash-delta--down { background: rgba(217,41,28,.07); color: var(--danger); border: 1px solid rgba(217,41,28,.2); }
[data-theme="dark"] .dash-delta--up   { background: rgba(46,207,122,.12); color: var(--success); border-color: rgba(46,207,122,.2); }
[data-theme="dark"] .dash-delta--down { background: rgba(240,68,68,.12); color: var(--danger); border-color: rgba(240,68,68,.2); }

.dash-row-base { display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; }
.dash-widget--full { grid-column: 1 / -1; }

/* Top clientes */
.dash-top-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.dash-toggle {
  display: flex;
  background: var(--gray-100);
  border-radius: var(--radius-sm);
  padding: 3px;
  gap: 2px;
  border: 1px solid var(--border);
}
.dash-toggle__btn {
  background: none;
  border: none;
  padding: 4px 12px;
  border-radius: 4px;
  font-family: var(--sans);
  font-size: 11.5px;
  font-weight: 500;
  color: var(--text-muted);
  cursor: pointer;
  transition: background 0.13s, color 0.13s;
  white-space: nowrap;
}
.dash-toggle__btn:hover { color: var(--text); }
.dash-toggle__btn.is-active {
  background: var(--surface);
  color: var(--ink);
  font-weight: 700;
  box-shadow: var(--shadow-1);
}
[data-theme="dark"] .dash-toggle__btn.is-active { background: var(--surface2); color: var(--text); }

.dash-client-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
  gap: 0 32px;
}
.dash-client-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 9px 0;
  border-bottom: 1px solid var(--border);
}
.dash-client-row:last-child { border-bottom: none; }
.dash-client-rank {
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 700;
  color: var(--text-muted);
  min-width: 16px;
  text-align: center;
}
.dash-client-info { flex: 1; min-width: 0; }
.dash-client-name {
  font-size: 13px;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  display: flex;
  align-items: center;
  gap: 6px;
}
.dash-client-mat {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text-muted);
  background: var(--gray-100);
  padding: 1px 6px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
}
.dash-client-bar-wrap { height: 3px; background: var(--gray-200); border-radius: var(--radius-pill); margin-top: 5px; overflow: hidden; }
.dash-client-bar { height: 100%; background: var(--ink); border-radius: var(--radius-pill); transition: width 0.45s; }
[data-theme="dark"] .dash-client-bar { background: #f9f7f6; }
.dash-client-stats { display: flex; flex-direction: column; align-items: flex-end; gap: 2px; min-width: 110px; }
.dash-client-total { font-family: var(--mono); font-size: 13px; font-weight: 600; }
.dash-client-count { font-size: 11px; color: var(--text-muted); }

/* Pill badge */
.dash-pill {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: var(--radius-pill);
  font-size: 11.5px;
  font-weight: 700;
  border: 1px solid transparent;
}
.dash-pill--warn {
  background: var(--gray-100);
  color: var(--warn-text);
  border-color: var(--gray-200);
}
[data-theme="dark"] .dash-pill--warn { color: var(--color-yellow); background: rgba(242,211,53,.1); border-color: rgba(242,211,53,.2); }

.dash-proy-row { display: flex; align-items: center; gap: 8px; margin-top: 2px; }
.dash-pres-tasa { display: flex; align-items: center; justify-content: space-between; margin-top: 4px; }
.dash-tasa-val { font-family: var(--mono); font-size: 1.1rem; font-weight: 700; color: var(--success); }
.dash-widget__link {
  margin-top: auto;
  align-self: flex-start;
  font-size: 12px;
  padding: 4px 10px;
  color: var(--text-muted);
  background: none;
  border: none;
  cursor: pointer;
  text-decoration: underline;
}
.dash-empty { color: var(--text-muted); font-size: 12.5px; padding: 16px 0; }

/* ── Toast ─────────────────────────────────────────── */
.toast-wrap {
  position: fixed;
  bottom: 24px;
  right: 24px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  z-index: 200;
}
.toast {
  padding: 10px 16px;
  border-radius: var(--radius-sm);
  font-size: 13px;
  font-weight: 500;
  color: #fff;
  background: var(--ink);
  box-shadow: var(--shadow-2);
  animation: toast-in 0.18s ease;
  border: 1px solid rgba(255,255,255,0.1);
}
.toast--ok    { background: var(--success); }
.toast--error { background: var(--danger); }
.toast--warn  { background: #92620a; }
@keyframes toast-in { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }

/* ── Responsive ────────────────────────────────────── */
@media (max-width: 900px) { .dash-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .dash-grid { grid-template-columns: 1fr; } }

/* ── Scrollbar ─────────────────────────────────────── */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--gray-300); border-radius: var(--radius-pill); }
[data-theme="dark"] ::-webkit-scrollbar-thumb { background: #3d2d54; }

/* ── View toggle ───────────────────────────────────── */
.view-toggle {
  display: flex;
  align-items: center;
  gap: 6px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-pill);
  padding: 5px 12px 5px 9px;
  cursor: pointer;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 500;
  color: var(--text-muted);
  transition: background 0.13s, color 0.13s, border-color 0.13s;
  white-space: nowrap;
  flex-shrink: 0;
}
.view-toggle:hover { background: var(--gray-100); color: var(--text); border-color: var(--border-strong); }
.view-toggle__icon { display: block; flex-shrink: 0; }

/* ── Proyectos — toolbar ───────────────────────────── */
.proy-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 16px;
  flex-wrap: wrap;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 10px 14px;
  box-shadow: var(--shadow-1);
}
.proy-toolbar__estado {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-sub);
  padding: 4px 10px;
  background: var(--gray-100);
  border: 1px solid var(--border);
  border-radius: var(--radius-pill);
  white-space: nowrap;
}

.proy-filter {
  background: var(--surface);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  color: var(--text);
  padding: 6px 10px;
  font-family: var(--sans);
  font-size: 12.5px;
  cursor: pointer;
  transition: border-color 0.13s;
}
.proy-filter:focus { outline: none; border-color: var(--ink); }

.proy-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 14px;
}

/* ── Proyecto card ─────────────────────────────────── */
.proy-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  box-shadow: var(--shadow-1);
  transition: border-color 0.13s, box-shadow 0.13s;
}
.proy-card:hover { border-color: var(--border-strong); box-shadow: var(--shadow-2); }
.proy-card__head { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.proy-card__codigo {
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  color: var(--text-muted);
  text-transform: uppercase;
}
.proy-card__nombre { font-size: 14px; font-weight: 600; line-height: 1.3; color: var(--text); }
.proy-card__cliente { font-size: 12px; color: var(--text-muted); }
.proy-card__cliente--none { font-style: italic; }
.proy-card__desc {
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.proy-card__foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: auto;
  padding-top: 10px;
  border-top: 1px solid var(--border);
  gap: 8px;
}
.proy-card__horas { font-family: var(--mono); font-size: 11px; color: var(--text-muted); }
.proy-card__actions { display: flex; gap: 6px; }

/* ── Dashboard stats ───────────────────────────────── */
.stats { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 14px; margin-bottom: 24px; }
.stat-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 18px;
  box-shadow: var(--shadow-1);
}
.stat-card__value { font-family: var(--mono); font-size: 1.8rem; font-weight: 600; color: var(--ink); }
[data-theme="dark"] .stat-card__value { color: var(--accent); }
.stat-card__label { font-size: 10.5px; color: var(--text-muted); margin-top: 4px; text-transform: uppercase; letter-spacing: 0.14em; font-weight: 600; }

/* ── Proyectos — botón vista ───────────────────────── */
.btn-vista {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 6px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-pill);
  padding: 5px 12px 5px 10px;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 500;
  color: var(--text-muted);
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
  transition: background 0.13s, color 0.13s, border-color 0.13s;
}
.btn-vista:hover { background: var(--gray-100); color: var(--text); border-color: var(--border-strong); }

/* ── Lote action buttons — base mixin ─────────────── */
.btn-duplicar, .btn-archivar, .btn-borrar-lote, .btn-pendiente-lote,
.btn-pdf-lote, .btn-rectificar-lote, .btn-cobrar,
.btn-convertir-pres, .btn-aceptar-pres, .btn-rechazar-pres, .btn-enviar-pres,
.btn-borrador, .btn-activar, .btn-pausar, .btn-terminar, .btn-facturar {
  display: flex;
  align-items: center;
  gap: 6px;
  border-radius: var(--radius-pill);
  padding: 5px 11px;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 500;
  white-space: nowrap;
  flex-shrink: 0;
  transition: background 0.13s, color 0.13s, border-color 0.13s, opacity 0.13s;
  /* disabled default */
  background: var(--gray-100);
  border: 1px solid var(--border);
  color: var(--gray-400);
  opacity: 0.5;
  cursor: not-allowed;
}

/* Enabled state base */
.btn-duplicar:not(:disabled),
.btn-archivar:not(:disabled),
.btn-borrar-lote:not(:disabled),
.btn-pendiente-lote:not(:disabled),
.btn-pdf-lote:not(:disabled),
.btn-rectificar-lote:not(:disabled),
.btn-cobrar:not(:disabled),
.btn-convertir-pres:not(:disabled),
.btn-aceptar-pres:not(:disabled),
.btn-rechazar-pres:not(:disabled),
.btn-enviar-pres:not(:disabled),
.btn-borrador:not(:disabled),
.btn-activar:not(:disabled),
.btn-pausar:not(:disabled),
.btn-terminar:not(:disabled),
.btn-facturar:not(:disabled) {
  opacity: 1;
  cursor: pointer;
}

/* Duplicar — neutral ink */
.btn-duplicar:not(:disabled) { color: var(--gray-700); border-color: var(--border-strong); background: var(--surface); }
.btn-duplicar:not(:disabled):hover { background: var(--gray-100); }

/* Archivar — warn */
.btn-archivar:not(:disabled) { color: var(--warn-text); border-color: var(--warn); background: rgba(242,211,53,.08); }
.btn-archivar:not(:disabled):hover { background: rgba(242,211,53,.18); }
[data-theme="dark"] .btn-archivar:not(:disabled) { color: var(--color-yellow); }

/* Borrar — danger */
.btn-borrar-lote:not(:disabled) { color: var(--danger); border-color: var(--danger); background: rgba(217,41,28,.06); }
.btn-borrar-lote:not(:disabled):hover { background: rgba(217,41,28,.14); }
[data-theme="dark"] .btn-borrar-lote:not(:disabled) { color: #f04444; border-color: #f04444; background: rgba(240,68,68,.06); }

/* Pendiente (facturas) */
.btn-pendiente-lote:not(:disabled) { color: #991b1b; border-color: #991b1b; background: rgba(153,27,27,.06); }
.btn-pendiente-lote:not(:disabled):hover { background: rgba(153,27,27,.14); }
[data-theme="dark"] .btn-pendiente-lote:not(:disabled) { color: #f04444; border-color: #f04444; background: rgba(240,68,68,.06); }
[data-theme="dark"] .btn-pendiente-lote:not(:disabled):hover { background: rgba(240,68,68,.14); }

/* PDF */
.btn-pdf-lote:not(:disabled) { color: var(--info); border-color: var(--info); background: rgba(18,45,100,.06); }
.btn-pdf-lote:not(:disabled):hover { background: rgba(18,45,100,.14); }
[data-theme="dark"] .btn-pdf-lote:not(:disabled) { color: #60a5fa; border-color: #60a5fa; background: rgba(96,165,250,.06); }
[data-theme="dark"] .btn-pdf-lote:not(:disabled):hover { background: rgba(96,165,250,.14); }

/* Rectificar */
.btn-rectificar-lote:not(:disabled) { color: #c2410c; border-color: #c2410c; background: rgba(194,65,12,.06); }
.btn-rectificar-lote:not(:disabled):hover { background: rgba(194,65,12,.14); }
[data-theme="dark"] .btn-rectificar-lote:not(:disabled) { color: #fb923c; border-color: #fb923c; background: rgba(251,146,60,.06); }

/* Cobrar — success */
.btn-cobrar:not(:disabled) { color: #166534; border-color: #166534; background: rgba(22,101,52,.06); }
.btn-cobrar:not(:disabled):hover { background: rgba(22,101,52,.14); }
[data-theme="dark"] .btn-cobrar:not(:disabled) { color: #2ecf7a; border-color: #2ecf7a; background: rgba(46,207,122,.06); }
[data-theme="dark"] .btn-cobrar:not(:disabled):hover { background: rgba(46,207,122,.14); }

/* Convertir presupuesto */
.btn-convertir-pres:not(:disabled) { color: #9a1585; border-color: #9a1585; background: rgba(154,21,133,.06); }
.btn-convertir-pres:not(:disabled):hover { background: rgba(154,21,133,.14); }
[data-theme="dark"] .btn-convertir-pres:not(:disabled) { color: #e879d0; border-color: #e879d0; background: rgba(232,121,208,.06); }
[data-theme="dark"] .btn-convertir-pres:not(:disabled):hover { background: rgba(232,121,208,.14); }

/* Aceptar / Rechazar presupuesto */
.btn-aceptar-pres:not(:disabled) { color: #166534; border-color: #166534; background: rgba(22,101,52,.06); }
.btn-aceptar-pres:not(:disabled):hover { background: rgba(22,101,52,.14); }
[data-theme="dark"] .btn-aceptar-pres:not(:disabled) { color: #2ecf7a; border-color: #2ecf7a; background: rgba(46,207,122,.06); }
[data-theme="dark"] .btn-aceptar-pres:not(:disabled):hover { background: rgba(46,207,122,.14); }
.btn-rechazar-pres:not(:disabled) { color: #991b1b; border-color: #991b1b; background: rgba(153,27,27,.06); }
.btn-rechazar-pres:not(:disabled):hover { background: rgba(153,27,27,.14); }
[data-theme="dark"] .btn-rechazar-pres:not(:disabled) { color: #f04444; border-color: #f04444; background: rgba(240,68,68,.06); }

/* Enviar presupuesto */
.btn-enviar-pres:not(:disabled) { color: #122d64; border-color: #122d64; background: rgba(18,45,100,.06); }
.btn-enviar-pres:not(:disabled):hover { background: rgba(18,45,100,.14); }
[data-theme="dark"] .btn-enviar-pres:not(:disabled) { color: #7aa3e8; border-color: #7aa3e8; background: rgba(122,163,232,.06); }

/* Estado botones proyectos */
.btn-borrador:not(:disabled) { color: var(--gray-600); border-color: var(--gray-400); background: var(--gray-100); }
.btn-borrador:not(:disabled):hover { background: var(--gray-200); }
[data-theme="dark"] .btn-borrador:not(:disabled) { color: #aaa; border-color: #aaa; background: rgba(170,170,170,.06); }

.btn-activar:not(:disabled) { color: #166534; border-color: #166534; background: rgba(22,101,52,.06); }
.btn-activar:not(:disabled):hover { background: rgba(22,101,52,.14); }
[data-theme="dark"] .btn-activar:not(:disabled) { color: #2ecf7a; border-color: #2ecf7a; background: rgba(46,207,122,.06); }

.btn-pausar:not(:disabled) { color: var(--warn-text); border-color: var(--warn); background: rgba(242,211,53,.08); }
.btn-pausar:not(:disabled):hover { background: rgba(242,211,53,.18); }
[data-theme="dark"] .btn-pausar:not(:disabled) { color: var(--color-yellow); }

.btn-terminar:not(:disabled) { color: #122d64; border-color: #122d64; background: rgba(18,45,100,.06); }
.btn-terminar:not(:disabled):hover { background: rgba(18,45,100,.14); }
[data-theme="dark"] .btn-terminar:not(:disabled) { color: #4a7fd4; border-color: #4a7fd4; background: rgba(74,127,212,.06); }

.btn-facturar:not(:disabled) { color: var(--gray-700); border-color: var(--gray-400); background: var(--gray-100); }
.btn-facturar:not(:disabled):hover { background: var(--gray-200); }

/* ── Modal submit buttons — cambio de estado ────────── */
.btn--borrador  { background: var(--gray-500) !important; color: #fff !important; font-weight: 700 !important; border-color: var(--gray-500) !important; }
.btn--borrador:hover { opacity: 0.88 !important; }
.btn--activar   { background: #166534 !important; color: #fff !important; font-weight: 700 !important; border-color: #166534 !important; }
.btn--activar:hover { opacity: 0.88 !important; }
[data-theme="dark"] .btn--activar { background: #0d5c2e !important; border-color: #0d5c2e !important; }
.btn--archive   { background: var(--warn) !important; color: #0c0014 !important; font-weight: 700 !important; border-color: var(--warn) !important; }
.btn--archive:hover { opacity: 0.88 !important; }
.btn--pendiente { background: #991b1b !important; color: #fff !important; font-weight: 700 !important; border-color: #991b1b !important; }
.btn--pendiente:hover { opacity: 0.88 !important; }
.btn--rectificar { background: #c2410c !important; color: #fff !important; font-weight: 700 !important; border-color: #c2410c !important; }
.btn--rectificar:hover { opacity: 0.88 !important; }
.btn--enviar    { background: #122d64 !important; color: #fff !important; border-color: #122d64 !important; }
.btn--enviar:hover { opacity: 0.88 !important; }
[data-theme="dark"] .btn--enviar { background: #1e4a9e !important; border-color: #1e4a9e !important; }
.btn--aceptado  { background: #166534 !important; color: #fff !important; border-color: #166534 !important; }
.btn--aceptado:hover { opacity: 0.88 !important; }
[data-theme="dark"] .btn--aceptado { background: #15803d !important; border-color: #15803d !important; }
.btn--rechazado { background: #991b1b !important; color: #fff !important; border-color: #991b1b !important; }
.btn--rechazado:hover { opacity: 0.88 !important; }
[data-theme="dark"] .btn--rechazado { background: #c22626 !important; border-color: #c22626 !important; }
.btn--convert   { background: #9a1585 !important; color: #fff !important; border-color: #9a1585 !important; }
.btn--convert:hover { opacity: 0.88 !important; }
[data-theme="dark"] .btn--convert { background: #bf1ba4 !important; border-color: #bf1ba4 !important; }
.btn--success   { background: var(--success) !important; color: #fff !important; border-color: var(--success) !important; }
.btn--success:hover { opacity: 0.88 !important; }
.btn--warning   { background: var(--warn); color: #1a1a1a; border-color: var(--warn); }
.btn--warning:hover { opacity: 0.88; }

/* ── Botón PDF — topbar detalle ─────────────────────── */
.btn-pdf-detalle {
  display: flex;
  align-items: center;
  gap: 6px;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 6px 13px;
  font-family: var(--sans);
  font-size: 12.5px;
  font-weight: 500;
  color: var(--text-muted);
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
  transition: background 0.13s, color 0.13s, border-color 0.13s;
}
.btn-pdf-detalle:hover { color: var(--info); border-color: var(--info); background: rgba(18,45,100,.06); }
[data-theme="dark"] .btn-pdf-detalle:hover { color: #60a5fa; border-color: #60a5fa; background: rgba(96,165,250,.06); }

/* ── Proyectos — search ────────────────────────────── */
.proy-search { flex: 1; min-width: 0; max-width: 260px; }

/* ── Proyectos — tabla ─────────────────────────────── */
.proy-table-wrap { overflow-x: auto; }
.proy-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12.5px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
.proy-table th {
  text-align: left;
  padding: 9px 14px;
  background: var(--gray-50);
  color: var(--gray-500);
  font-weight: 600;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
}
.proy-table td { padding: 11px 14px; border-bottom: 1px solid var(--border); vertical-align: middle; }
.proy-table tr:last-child td { border-bottom: none; }
.proy-table tbody tr:hover td { background: var(--gray-50); }
.proy-table .td--check  { width: 36px; padding-right: 4px; }
.proy-table .td--horas  { width: 70px; text-align: right; }
.proy-table .td--fecha  { width: 110px; }
.proy-table .td--actions { width: 140px; }
.proy-table .td--cliente { max-width: 180px; }
.proy-table .td--nombre  { min-width: 160px; }

/* Checkboxes */
.proy-table input[type="checkbox"],
.fact-table input[type="checkbox"],
table input[type="checkbox"] {
  width: 14px;
  height: 14px;
  border: 1.5px solid var(--gray-300);
  border-radius: 3px;
  accent-color: var(--ink);
  cursor: pointer;
}

/* Cabeceras ordenables */
.th--sortable { cursor: pointer; user-select: none; }
.th--sortable:hover { color: var(--text); }
.th--sorted { color: var(--ink); }
[data-theme="dark"] .th--sorted { color: var(--accent); }
.sort-icon { display: inline-block; margin-left: 4px; font-size: 0.65rem; opacity: 0.35; vertical-align: middle; }
.sort-icon--on { opacity: 1; color: var(--ink); }
[data-theme="dark"] .sort-icon--on { color: var(--accent); }

/* Links en lista */
.proy-nombre-link { cursor: pointer; font-weight: 500; color: var(--text); transition: color 0.12s; }
.proy-nombre-link:hover { color: var(--ink); text-decoration: underline; }
.cli-nombre-link  { cursor: pointer; font-weight: 500; color: var(--text); transition: color 0.12s; }
.cli-nombre-link:hover { color: var(--ink); text-decoration: underline; }
.list-link { color: var(--text-muted); text-decoration: none; transition: color 0.12s; }
.list-link:hover { color: var(--ink); text-decoration: underline; }
.list-none { color: var(--text-muted); font-style: italic; }

.list-matricula {
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  background: var(--ink);
  color: #fff;
  padding: 1px 6px;
  border-radius: var(--radius-pill);
  margin-right: 4px;
}
[data-theme="dark"] .list-matricula { background: #f9f7f6; color: #0c0014; }

/* ── Clientes — tabla ──────────────────────────────── */
.cli-table .td--mat   { width: 110px; }
.cli-table .td--cif   { width: 120px; }
.cli-table .td--email { min-width: 140px; }
.cli-table .td--tel   { width: 120px; }
.cli-table .td--loc   { width: 130px; }
.cli-table .td--pais  { width: 100px; }

/* ── Facturas — toolbar ────────────────────────────── */
.fact-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 16px;
  flex-wrap: wrap;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 10px 14px;
  box-shadow: var(--shadow-1);
}
.fact-toolbar__estado {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-sub);
  padding: 4px 10px;
  background: var(--gray-100);
  border: 1px solid var(--border);
  border-radius: var(--radius-pill);
  white-space: nowrap;
}
.fact-search { flex: 1; min-width: 0; max-width: 260px; }

/* ── Facturas — tabla ──────────────────────────────── */
.fact-table-wrap { overflow-x: auto; }
.fact-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12.5px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
.fact-table th {
  text-align: left;
  padding: 9px 14px;
  background: var(--gray-50);
  color: var(--gray-500);
  font-weight: 600;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
}
.fact-table td { padding: 11px 14px; border-bottom: 1px solid var(--border); vertical-align: middle; }
.fact-table tr:last-child td { border-bottom: none; }
.fact-table tbody tr:hover td { background: var(--gray-50); }
.fact-table .td--check  { width: 36px; padding-right: 4px; }
.fact-table .td--estado { width: 110px; }
.fact-table .td--fecha  { width: 100px; }
.fact-table .td--num    { width: 130px; }
.fact-table .td--pago   { width: 100px; }
.fact-table .td--money  { width: 110px; text-align: right; font-family: var(--mono); font-size: 12px; }
.fact-table .td--saldo  { width: 110px; text-align: right; font-family: var(--mono); font-size: 12px; font-weight: 600; }
.fact-table .td--actions { width: 120px; }

.saldo-pendiente { color: var(--danger); }
.fact-num-link {
  cursor: pointer;
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 700;
  color: var(--ink);
  transition: opacity 0.12s;
  letter-spacing: 0.04em;
}
.fact-num-link:hover { opacity: 0.65; text-decoration: underline; }
[data-theme="dark"] .fact-num-link { color: var(--accent); }
.fact-cliente-cif { display: block; font-size: 10.5px; color: var(--text-muted); font-family: var(--mono); margin-top: 2px; }

/* ── Facturas — detalle / edición ─────────────────── */
.fact-detail { display: flex; flex-direction: column; gap: 0; }
.fact-detail__topbar {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}
.btn-volver {
  display: flex;
  align-items: center;
  gap: 6px;
  background: none;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 6px 13px;
  font-family: var(--sans);
  font-size: 12.5px;
  color: var(--text-muted);
  cursor: pointer;
  transition: border-color 0.13s, color 0.13s;
  flex-shrink: 0;
}
.btn-volver:hover { border-color: var(--border-strong); color: var(--text); }
.fact-detail__title { font-size: 15px; font-weight: 700; flex: 1; }
.fact-detail__topbar .btn--primary { flex-shrink: 0; }

.fact-detail__body {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 22px;
  box-shadow: var(--shadow-1);
}
.fact-detail__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px 20px;
}
.fact-detail__grid .form-group { margin-bottom: 0; }

.fact-section-title {
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--gray-500);
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 2px;
}

/* ── Líneas de factura ────────────────────────────── */
.lineas-wrap { display: flex; flex-direction: column; gap: 10px; }
.lineas-table-wrap { overflow-x: auto; }
.lineas-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12.5px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  overflow: hidden;
}
.lineas-table th {
  text-align: left;
  padding: 8px 10px;
  background: var(--gray-50);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--gray-500);
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
}
.lineas-table td { padding: 5px 4px; border-bottom: 1px solid var(--border); vertical-align: middle; }
.lineas-table tr:last-child td { border-bottom: none; }
.lineas-table .th--desc  { min-width: 220px; }
.lineas-table .th--cant  { width: 80px;  text-align: right; }
.lineas-table .th--price { width: 110px; text-align: right; }
.lineas-table .th--iva   { width: 90px;  text-align: center; }
.lineas-table .th--imp   { width: 110px; text-align: right; }
.lineas-table .th--del   { width: 36px; }

.linea-input {
  width: 100%;
  background: transparent;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  color: var(--text);
  padding: 5px 8px;
  font-size: 12.5px;
  font-family: var(--sans);
  transition: border-color 0.12s, background 0.12s;
}
.linea-input:focus { outline: none; border-color: var(--ink); background: var(--gray-50); }
.linea-input:hover { background: var(--gray-50); }
.linea-input--num  { text-align: right; font-family: var(--mono); font-size: 12px; }
.linea-input--sel  { text-align: center; cursor: pointer; }
.td--linea-imp { text-align: right; font-family: var(--mono); font-size: 12px; color: var(--text); white-space: nowrap; padding-right: 10px; }

.btn-remove-linea {
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  font-size: 1rem;
  padding: 4px 8px;
  border-radius: var(--radius-sm);
  transition: color 0.12s, background 0.12s;
}
.btn-remove-linea:hover { color: var(--danger); background: rgba(217,41,28,.08); }

.btn-add-linea {
  align-self: flex-start;
  background: none;
  border: 1px dashed var(--border-strong);
  border-radius: var(--radius-sm);
  color: var(--text-muted);
  padding: 6px 14px;
  font-family: var(--sans);
  font-size: 12.5px;
  cursor: pointer;
  transition: border-color 0.13s, color 0.13s;
}
.btn-add-linea:hover { border-color: var(--ink); color: var(--ink); }
[data-theme="dark"] .btn-add-linea:hover { border-color: var(--accent); color: var(--accent); }

/* ── Totales ──────────────────────────────────────── */
.fact-totals {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 6px;
  padding-top: 12px;
  border-top: 1px solid var(--border);
}
.fact-totals__row { display: flex; gap: 24px; align-items: baseline; font-size: 13px; }
.fact-totals__row span:first-child { color: var(--text-muted); min-width: 90px; text-align: right; }
.fact-totals__row span:last-child  { font-family: var(--mono); font-size: 13px; min-width: 110px; text-align: right; }
.fact-totals__row--total span:first-child { color: var(--text); font-weight: 700; }
.fact-totals__row--total span:last-child  { font-size: 17px; font-weight: 700; color: var(--text); }

/* ── Ajustes ──────────────────────────────────────── */
.ajustes-wrap { max-width: 660px; display: flex; flex-direction: column; gap: 24px; }
.ajustes-version { font-size: 11px; color: #7a7480; font-family: 'IBM Plex Sans', var(--sans); letter-spacing: 0.02em; }

/* ── Mayúsculas en vistas lista ───────────────────── */
.proy-nombre-link { text-transform: uppercase; }
.td--cliente      { text-transform: uppercase; }
.cli-nombre-link  { text-transform: uppercase; }
.ajustes-section {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 22px 24px;
  box-shadow: var(--shadow-1);
}
.ajustes-section__title {
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--gray-500);
  margin-bottom: 16px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border);
}
.ajustes-section .form-group { margin-bottom: 12px; }
.ajustes-num-preview {
  font-family: var(--mono);
  font-size: 15px;
  font-weight: 700;
  color: var(--ink);
  padding: 8px 0 4px;
  letter-spacing: 0.1em;
}
[data-theme="dark"] .ajustes-num-preview { color: var(--accent); }
.ajustes-footer { display: flex; justify-content: flex-end; }
.ajustes-iban { font-family: var(--mono); letter-spacing: 0.1em; font-size: 13px; }

.logo-upload-area { display: flex; flex-direction: column; gap: 16px; }
.logo-preview {
  width: 100%;
  max-width: 320px;
  height: 80px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--bg);
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding: 0 16px;
  overflow: hidden;
}
[data-theme="dark"] .logo-preview { background: var(--surface-raised, #1a1025); }
.logo-preview-img {
  max-width: 168px;
  max-height: 48px;
  object-fit: contain;
  object-position: left center;
}
.logo-preview-placeholder {
  font-family: var(--sans, 'IBM Plex Sans', sans-serif);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.05em;
  color: var(--text-muted);
}
.logo-upload-controls { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.logo-upload-hint { font-size: 11.5px; color: var(--text-muted); line-height: 1.7; }

/* ── IBAN / Método de pago ────────────────────────── */
.fact-pago-box {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 11px 14px;
  background: var(--gray-50);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: 13px;
}
.fact-pago-box__label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--gray-500);
  white-space: nowrap;
}
.fact-pago-box__method { font-weight: 600; color: var(--text); white-space: nowrap; }
.fact-pago-box__iban { font-family: var(--mono); font-size: 12px; color: var(--text-muted); letter-spacing: 0.06em; }

/* ── Rectificativa — sección ─────────────────────── */
.fact-rect-section {
  padding: 14px 18px;
  background: rgba(194,65,12,.05);
  border: 1px solid rgba(194,65,12,.2);
  border-radius: var(--radius-sm);
}
[data-theme="dark"] .fact-rect-section { background: rgba(251,146,60,.06); border-color: rgba(251,146,60,.2); }
.fact-rect-section__title {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #c2410c;
  margin-bottom: 14px;
}
[data-theme="dark"] .fact-rect-section__title { color: #fb923c; }
.fact-rect-section .form-group { margin-bottom: 10px; }
.fact-rect-section .form-group:last-child { margin-bottom: 0; }

/* ── Toggle estado de pago ───────────────────────── */
.fact-pago-status-bar {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 16px;
  background: var(--gray-50);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
}
.fact-pago-status-bar__label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--gray-500);
  white-space: nowrap;
}
.fact-pago-toggle { display: flex; gap: 6px; flex-wrap: wrap; }
.fact-pago-toggle__btn {
  padding: 5px 14px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--border-strong);
  background: var(--surface);
  color: var(--text-muted);
  font-family: var(--sans);
  font-size: 12.5px;
  font-weight: 500;
  cursor: pointer;
  transition: border-color 0.13s, background 0.13s, color 0.13s;
}
.fact-pago-toggle__btn:hover { border-color: var(--border-strong); color: var(--text); }
.fact-pago-toggle__btn--pagado.is-active {
  background: rgba(26,122,74,.1);
  border-color: #166534;
  color: #166534;
  font-weight: 600;
}
.fact-pago-toggle__btn--pendiente.is-active {
  background: rgba(217,41,28,.08);
  border-color: var(--danger);
  color: var(--danger);
  font-weight: 600;
}
[data-theme="dark"] .fact-pago-toggle__btn--pagado.is-active   { background: rgba(46,207,122,.12); border-color: #2ecf7a; color: #2ecf7a; }
[data-theme="dark"] .fact-pago-toggle__btn--pendiente.is-active { background: rgba(240,68,68,.12); border-color: #f04444; color: #f04444; }

/* ── Convertir a factura — popup ─────────────────── */
.conv-estado-sel { display: flex; align-items: center; gap: 10px; margin-top: 14px; flex-wrap: wrap; }
.conv-estado-sel__label { font-size: 12px; font-weight: 600; color: var(--text-muted); white-space: nowrap; }
.conv-estado-opt {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
  cursor: pointer;
  padding: 5px 12px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: var(--surface);
  transition: border-color 0.13s, background 0.13s;
}
.conv-estado-opt:has(input:checked) {
  border-color: var(--ink);
  background: var(--gray-100);
  color: var(--ink);
}
[data-theme="dark"] .conv-estado-opt:has(input:checked) { border-color: var(--accent); background: rgba(249,247,246,.08); color: var(--accent); }
.conv-estado-opt input[type="radio"] { accent-color: var(--ink); }

/* ── Confirm message ─────────────────────────────── */
.dup-confirm-msg {
  font-size: 13.5px;
  color: var(--text);
  line-height: 1.6;
  padding: 4px 0 8px;
}

/* ── Login overlay ───────────────────────────────── */
.login-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: var(--bg);
  display: flex;
  align-items: center;
  justify-content: center;
}
.login-overlay[hidden] { display: none; }
.login-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 40px 36px;
  width: 360px;
  max-width: 92vw;
  box-shadow: var(--shadow-2);
}
.login-logo {
  display: flex;
  align-items: baseline;
  gap: 6px;
  justify-content: center;
  margin-bottom: 6px;
}
.login-subtitle {
  text-align: center;
  font-size: 13px;
  color: var(--text-muted);
  margin: 0 0 26px;
}
.login-error {
  background: rgba(217,41,28,.07);
  color: var(--danger);
  border: 1px solid rgba(217,41,28,.25);
  border-radius: var(--radius-sm);
  padding: 9px 13px;
  font-size: 13px;
  margin-bottom: 16px;
}
[data-theme="dark"] .login-error { background: rgba(240,68,68,.1); color: #f87171; border-color: #7f1d1d; }
.login-btn { width: 100%; margin-top: 10px; }
.login-card .form-group { margin-bottom: 14px; }

/* ── Topbar user info ────────────────────────────── */
.topbar-user {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12.5px;
}
.topbar-user[hidden] { display: none; }
.topbar-user__name { color: var(--text); font-weight: 600; }
.topbar-user__rol {
  font-size: 11px;
  padding: 3px 10px;
  border-radius: var(--radius-pill);
  background: var(--gray-100);
  color: var(--gray-600);
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border: 1px solid var(--gray-200);
}
[data-theme="dark"] .topbar-user__rol { background: rgba(255,255,255,0.08); color: rgba(255,255,255,0.6); border-color: rgba(255,255,255,0.1); }

/* ── Gastos ──────────────────────────────────────── */
.badge-recurrente {
  display: inline-block;
  margin-left: 6px;
  font-size: 10px;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: var(--radius-pill);
  background: var(--gray-100);
  color: var(--info);
  vertical-align: middle;
  white-space: nowrap;
  border: 1px solid rgba(18,45,100,.2);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.badge-recurrente--ocurrencia {
  background: var(--surface2);
  color: var(--text-muted);
  border-color: var(--border);
}
[data-theme="dark"] .badge-recurrente { background: rgba(96,165,250,.1); color: #60a5fa; border-color: rgba(96,165,250,.2); }
[data-theme="dark"] .badge-recurrente--ocurrencia { background: var(--surface2); color: var(--text-muted); border-color: var(--border); }

.gasto-categoria {
  display: inline-block;
  font-size: 11px;
  font-weight: 600;
  padding: 2px 9px;
  border-radius: var(--radius-pill);
  background: var(--gray-100);
  color: var(--gray-600);
  border: 1px solid var(--gray-200);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.gasto-filtros-estado { display: flex; gap: 6px; flex-wrap: wrap; }
.gasto-filtro-btn {
  padding: 4px 12px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text-muted);
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.13s, color 0.13s, border-color 0.13s;
}
.gasto-filtro-btn:hover { background: var(--gray-100); color: var(--text); border-color: var(--border-strong); }
.gasto-filtro-btn.is-active { background: var(--ink); color: #fff; border-color: var(--ink); }
[data-theme="dark"] .gasto-filtro-btn.is-active { background: #f9f7f6; color: #0c0014; border-color: #f9f7f6; }

.gastos-tfoot td { border-top: 1px solid var(--border-strong); padding-top: 10px; font-weight: 700; }

/* ── Paginación ──────────────────────────────────── */
.pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
  padding: 14px 2px 4px;
}
.pagination__info { font-size: 12px; color: var(--text-muted); }
.pagination__controls { display: flex; align-items: center; gap: 3px; }
.pag-btn {
  padding: 4px 10px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--surface);
  color: var(--text);
  cursor: pointer;
  font-size: 12px;
  font-family: var(--sans);
  line-height: 1.5;
  transition: background 0.1s, border-color 0.1s;
  white-space: nowrap;
}
.pag-btn:hover:not(:disabled) { background: var(--gray-100); border-color: var(--border-strong); }
.pag-btn:disabled { opacity: 0.35; cursor: default; }
.pag-btn--active { background: var(--ink); color: #fff; border-color: var(--ink); font-weight: 700; }
.pag-btn--active:hover { background: var(--gray-800); border-color: var(--gray-800); opacity: 1; }
[data-theme="dark"] .pag-btn--active { background: #f9f7f6; color: #0c0014; border-color: #f9f7f6; }
.pag-ellipsis { padding: 4px 5px; color: var(--text-muted); font-size: 12px; user-select: none; }

/* ── Backup section ──────────────────────────────── */
.backup-actions { display: flex; flex-direction: column; gap: 18px; }
.backup-action { display: flex; flex-direction: column; gap: 8px; }
.backup-action__desc { margin: 0; font-size: 12.5px; color: var(--text-muted); line-height: 1.5; }

/* ── Calendario ──────────────────────────────────── */
.cal-container { display: flex; flex-direction: column; flex: 1; min-height: 0; overflow: hidden; }

.cal-toolbar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 20px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  background: var(--canvas);
}

.cal-nav-group { display: flex; align-items: center; gap: 3px; }
.cal-hoy-btn   { font-size: 11px !important; padding: 4px 10px !important; }

.cal-title {
  flex: 1;
  font-size: 15px;
  font-weight: 600;
  color: var(--text);
  letter-spacing: -0.2px;
}

.cal-view-group {
  display: flex;
  background: var(--surface2);
  border-radius: var(--radius-sm);
  padding: 2px;
  gap: 1px;
}

.cal-view-btn {
  background: none;
  border: none;
  padding: 5px 13px;
  border-radius: calc(var(--radius-sm) - 2px);
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 500;
  color: var(--text-muted);
  cursor: pointer;
  transition: background 0.12s, color 0.12s;
}
.cal-view-btn:hover   { background: var(--surface); color: var(--text); }
.cal-view-btn.is-active {
  background: var(--surface);
  color: var(--text);
  font-weight: 600;
  box-shadow: var(--shadow-1);
}

.cal-filter-select {
  height: 28px;
  padding: 0 8px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--surface);
  color: var(--text);
  font-family: var(--sans);
  font-size: 12px;
  cursor: pointer;
  max-width: 160px;
}

.cal-body { flex: 1; min-height: 0; overflow-y: auto; overflow-x: hidden; display: flex; flex-direction: column; }

/* ── Mes ─────────────────────────────────────────── */
.cal-month      { display: flex; flex-direction: column; flex: 1; min-height: 0; }
.cal-month-body { flex: 1; display: flex; flex-direction: column; min-height: 0; }

.cal-month-header {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  background: var(--canvas);
  z-index: 2;
}
.cal-month-header-day {
  padding: 6px 0;
  font-size: 10px;
  font-weight: 600;
  color: var(--text-muted);
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.cal-week-row {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  grid-template-rows: 1fr auto;
  border-bottom: 1px solid var(--border);
  flex: 1;
  min-height: 0;
}

.cal-day-cell {
  border-right: 1px solid var(--border);
  padding: 4px 6px;
  min-height: 28px;
  cursor: default;
}
.cal-day-cell:last-child { border-right: none; }
.cal-day-cell--outside   { background: var(--surface2); }
.cal-day-cell--outside .cal-day-num { color: var(--text-muted); }

.cal-day-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  font-size: 12px;
  font-weight: 500;
  color: var(--text);
}
.cal-day-num--hoy {
  background: var(--color-magenta);
  color: #fff;
  font-weight: 700;
}

.cal-week-events {
  grid-column: 1 / -1;
  position: relative;
  pointer-events: none;
}

/* ── Event bars ──────────────────────────────────── */
.cal-event-bar {
  position: absolute;
  height: 20px;
  border-radius: 4px;
  display: flex;
  align-items: center;
  padding: 0 6px;
  overflow: hidden;
  cursor: default;
  transition: filter 0.1s;
  z-index: 1;
  user-select: none;
}
.cal-event-bar:hover { filter: brightness(1.14); }
.cal-event-bar--task { height: 16px; border-radius: 3px; opacity: 0.82; }
.cal-event-bar--continues-l { border-top-left-radius: 0; border-bottom-left-radius: 0; }
.cal-event-bar--continues-r { border-top-right-radius: 0; border-bottom-right-radius: 0; }
.cal-event-bar--dragging     { opacity: 0.45; }

.cal-event-bar__label {
  font-size: 10.5px;
  font-weight: 600;
  color: #fff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1;
}
.cal-event-bar--task .cal-event-bar__label { font-size: 10px; font-weight: 500; }

/* ── Project group (jerarquía proyecto > tareas) ─── */
.cal-project-group {
  position: absolute;
  overflow: hidden;
  border-radius: 4px;
  pointer-events: none;
  z-index: 1;
}
.cal-pg--continues-l { border-top-left-radius: 0; border-bottom-left-radius: 0; }
.cal-pg--continues-r { border-top-right-radius: 0; border-bottom-right-radius: 0; }

.cal-pg__header {
  height: 22px;
  display: flex;
  align-items: center;
  padding: 0 8px;
  font-size: 11px;
  font-weight: 600;
  color: #fff;
  cursor: pointer;
  pointer-events: auto;
  user-select: none;
  border-radius: 3px 3px 0 0;
}
.cal-pg--continues-l .cal-pg__header { border-top-left-radius: 0; }
.cal-pg--continues-r .cal-pg__header { border-top-right-radius: 0; }
.cal-pg__header:hover { filter: brightness(1.12); }
.cal-pg__header.cal-pg--dragging { opacity: 0.45; }

.cal-pg__header-label {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-height: 1;
}

.cal-pg__task {
  height: 18px;
  display: flex;
  align-items: center;
  padding: 0 6px 0 14px;
  font-size: 10px;
  color: #fff;
  cursor: pointer;
  pointer-events: auto;
  user-select: none;
  border-top: 1px solid rgba(255,255,255,0.18);
}
.cal-pg__task:hover { filter: brightness(1.12); }
.cal-pg__task.cal-pg--dragging { opacity: 0.45; }

.cal-pg__task-label {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-height: 1;
}

.cal-drop-over { background: rgba(191,27,164,0.1) !important; outline: 1px dashed var(--color-magenta); }

/* ── Semana ──────────────────────────────────────── */
.cal-semana { display: flex; flex-direction: column; flex: 1; min-height: 0; }

.cal-semana-header {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  background: var(--canvas);
  z-index: 2;
}
.cal-semana-header-day {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 10px 4px;
  gap: 4px;
  border-right: 1px solid var(--border);
}
.cal-semana-header-day:last-child { border-right: none; }

.cal-day-label {
  font-size: 10px;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.cal-semana-header-day--hoy .cal-day-label { color: var(--color-magenta); }

.cal-day-num-lg {
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  font-size: 15px;
  font-weight: 500;
  color: var(--text);
}
.cal-day-num-lg--hoy {
  background: var(--color-magenta);
  color: #fff;
  font-weight: 700;
}

.cal-semana-body   { position: relative; flex: 1; min-height: 80px; display: flex; flex-direction: column; }
.cal-semana-grid   { display: grid; grid-template-columns: repeat(7, 1fr); flex: 1; }
.cal-semana-col    { border-right: 1px solid var(--border); min-height: 80px; }
.cal-semana-col:last-child { border-right: none; }

/* ── Año ─────────────────────────────────────────── */
.cal-año {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: repeat(3, 1fr);
  gap: 16px;
  padding: 20px 24px;
  flex: 1;
  min-height: 0;
  box-sizing: border-box;
}
@media (max-width: 1200px) { .cal-año { grid-template-columns: repeat(3, 1fr); grid-template-rows: repeat(4, 1fr); } }
@media (max-width: 860px)  { .cal-año { grid-template-columns: repeat(2, 1fr); grid-template-rows: repeat(6, 1fr); } }

.cal-año-mes {
  cursor: pointer;
  border-radius: var(--radius);
  padding: 12px;
  border: 1px solid var(--border);
  background: var(--surface);
  transition: box-shadow 0.15s, border-color 0.15s;
  min-height: 0;
  overflow: hidden;
}
.cal-año-mes:hover { border-color: var(--border-strong); box-shadow: var(--shadow-2); }

.cal-año-mes-title {
  font-size: 11px;
  font-weight: 700;
  color: var(--text);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 8px;
}

.cal-año-mes-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 1px;
}

.cal-año-dia-label {
  font-size: 7.5px;
  font-weight: 600;
  color: var(--text-muted);
  text-align: center;
  padding: 1px 0 3px;
  text-transform: uppercase;
}

.cal-año-dia {
  font-size: 8.5px;
  text-align: center;
  padding: 2px 1px;
  border-radius: 2px;
  color: var(--text-muted);
  line-height: 1.5;
}
.cal-año-dia--hoy {
  background: var(--color-magenta);
  color: #fff;
  font-weight: 700;
  border-radius: 50%;
}
.cal-año-dia--activo {
  color: #fff;
  background: var(--ev-color, #9988bb);
  font-weight: 600;
  border-radius: 2px;
}
.cal-año-dia--activo.cal-año-dia--hoy {
  background: var(--color-magenta);
  outline: 2px solid var(--ev-color, #9988bb);
  outline-offset: 1px;
}
.cal-año-dia--task-only {
  color: #fff;
  background: var(--ev-color, #9988bb);
  border-radius: 2px;
  opacity: 0.55;
}
.cal-año-dia--task-only.cal-año-dia--hoy {
  background: var(--color-magenta);
  opacity: 1;
  outline: 2px solid var(--ev-color, #9988bb);
  outline-offset: 1px;
}

/* ── Colores panel (modal) ───────────────────────── */
.cal-colores-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
  max-height: 60vh;
  overflow-y: auto;
}
.cal-colores-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
}
.cal-colores-item:last-child { border-bottom: none; }
.cal-colores-nombre {
  font-size: 13px;
  color: var(--text);
  flex: 1;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.cal-color-picker {
  width: 36px;
  height: 28px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 2px;
  cursor: pointer;
  background: none;
  flex-shrink: 0;
}

/* ── Reuniones en calendario ─────────────────────── */
.cal-week-meetings {
  grid-column: 1 / -1;
  position: relative;
  pointer-events: none;
  border-top: 1px dashed var(--border);
}

.cal-meeting-bar {
  position: absolute;
  height: 20px;
  background: #0d9e8c;
  border-radius: 3px;
  display: flex;
  align-items: center;
  padding: 0 5px;
  gap: 4px;
  overflow: hidden;
  pointer-events: auto;
  cursor: pointer;
  transition: filter 0.1s;
  z-index: 2;
  user-select: none;
}
.cal-meeting-bar:hover { filter: brightness(1.15); }
[data-theme="dark"] .cal-meeting-bar { background: #0bbfa9; }

.cal-meeting-label {
  font-size: 10px;
  font-weight: 600;
  color: #fff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1;
}

/* Punto indicador en vista año */
.cal-año-dia--meeting {
  position: relative;
}
.cal-año-dia--meeting::after {
  content: '';
  position: absolute;
  bottom: 1px;
  left: 50%;
  transform: translateX(-50%);
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: #0d9e8c;
}
[data-theme="dark"] .cal-año-dia--meeting::after { background: #0bbfa9; }

/* ── God Mode sidebar ──────────────────────────────── */
.nav-god-header {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #9b5de5;
  padding: 6px 10px 2px;
  user-select: none;
}
[data-theme="dark"] .nav-god-header { color: #c084fc; }

.nav-item--god {
  color: var(--ink);
}
.nav-item--god:hover { background: rgba(155,93,229,.1); }
.nav-item--god.active {
  background: #7c3aed;
  color: #fff;
}
[data-theme="dark"] .nav-item--god.active { background: #7c3aed; color: #f9f7f6; }

/* ── Nóminas — tabla y controles ───────────────────── */
.nom-table th, .nom-table td { white-space: nowrap; }

.nom-masked {
  letter-spacing: .05em;
  color: var(--text-muted);
  font-size: 13px;
}

.nom-verify-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  white-space: nowrap;
}

.nom-verify-indicator {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 600;
  color: #16a34a;
  background: rgba(22,163,74,.1);
  border: 1px solid rgba(22,163,74,.25);
  border-radius: 6px;
  padding: 4px 10px;
  white-space: nowrap;
}
[data-theme="dark"] .nom-verify-indicator {
  color: #4ade80;
  background: rgba(74,222,128,.08);
  border-color: rgba(74,222,128,.2);
}

.input--readonly {
  background: var(--surface2);
  color: var(--text-muted);
  cursor: default;
  pointer-events: none;
}

/* ── Mis Tareas ──────────────────────────────────────── */
.mt-container { padding: 0 0 40px; }

.mt-toolbar { margin-bottom: 20px; }

#mt-grupos-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* Grupo */
.mt-grupo {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  overflow: hidden;
}

.mt-grupo-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px 10px 9px 8px;
  user-select: none;
}

.mt-grupo-header:hover .mt-grupo-actions { opacity: 1; }

.mt-grupo-colorbar {
  width: 4px;
  height: 18px;
  border-radius: 2px;
  flex-shrink: 0;
}

.mt-grupo-nombre {
  font-weight: 600;
  font-size: 13px;
  flex: 1;
  color: var(--text);
}

.mt-grupo-badge {
  font-size: 11px;
  font-weight: 600;
  background: var(--surface2);
  color: var(--text-muted);
  border-radius: 10px;
  padding: 1px 7px;
  flex-shrink: 0;
}

.mt-grupo-actions {
  display: flex;
  align-items: center;
  gap: 1px;
  opacity: 0;
  transition: opacity 0.15s;
  flex-shrink: 0;
}

/* Botones icono */
.mt-btn-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border: none;
  background: transparent;
  border-radius: 4px;
  cursor: pointer;
  color: var(--text-muted);
  transition: background 0.1s, color 0.1s;
  padding: 0;
  flex-shrink: 0;
}
.mt-btn-icon:hover { background: var(--surface2); color: var(--text); }
.mt-btn-icon--danger:hover { background: rgba(217,41,28,.1); color: var(--danger); }
[data-theme="dark"] .mt-btn-icon--danger:hover { background: rgba(240,68,68,.1); }

/* Drag handles */
.mt-drag-handle {
  cursor: grab;
  color: var(--text-muted);
  opacity: 0.35;
  display: flex;
  align-items: center;
  flex-shrink: 0;
  transition: opacity 0.12s;
}
.mt-drag-handle:active { cursor: grabbing; }
.mt-grupo-handle { opacity: 0.35; }
.mt-grupo-header:hover .mt-grupo-handle { opacity: 0.7; }
.mt-task-handle { opacity: 0; }
.mt-task:hover .mt-task-handle { opacity: 0.5; }
.mt-handle-icon { display: block; }

/* Lista de tareas — animación de colapso */
.mt-tasks-list {
  overflow: hidden;
  max-height: 9999px;
  transition: max-height 0.28s ease, opacity 0.2s ease;
}
.mt-grupo--collapsed .mt-tasks-list {
  max-height: 0;
  opacity: 0;
}

.mt-tasks-empty {
  padding: 10px 14px 12px 38px;
  color: var(--text-muted);
  font-size: 12px;
  font-style: italic;
}

/* Tarea */
.mt-task {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 8px 10px 8px 8px;
  border-top: 1px solid var(--border);
  transition: background 0.1s;
  position: relative;
  cursor: grab;
}
.mt-task:hover { background: var(--surface2); }
.mt-is-dragging .mt-task { cursor: grabbing; }
.mt-check-wrap,
.mt-btn-edit-task,
.mt-btn-del-task { cursor: pointer; }
.mt-task--done { opacity: 0.45; }
.mt-task--done .mt-task-nombre { text-decoration: line-through; }

/* Checkbox personalizado */
.mt-check-wrap {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  margin-top: 1px;
  cursor: pointer;
}
.mt-check-wrap input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  pointer-events: none;
}
.mt-check-box {
  width: 15px;
  height: 15px;
  border: 1.5px solid var(--border-strong);
  border-radius: 3px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s, border-color 0.15s;
  flex-shrink: 0;
}
.mt-check-wrap input:checked + .mt-check-box {
  background: var(--accent);
  border-color: var(--accent);
}
.mt-check-wrap input:checked + .mt-check-box::after {
  content: '';
  width: 7px;
  height: 4px;
  border-left: 1.5px solid var(--surface);
  border-bottom: 1.5px solid var(--surface);
  transform: rotate(-45deg) translateY(-1px);
  display: block;
}

/* Punto de color */
.mt-task-colordot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: 4px;
}

/* Contenido de la tarea */
.mt-task-content {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.mt-task-nombre {
  font-size: 13px;
  color: var(--text);
  cursor: pointer;
  word-break: break-word;
  line-height: 1.4;
}
.mt-task-nombre:hover { color: var(--accent); text-decoration: underline; text-underline-offset: 2px; }
.mt-task-notas {
  font-size: 11px;
  color: var(--text-muted);
  word-break: break-word;
  line-height: 1.4;
}

/* Acciones de tarea (visibles al hover) */
.mt-task-actions {
  display: flex;
  gap: 1px;
  opacity: 0;
  transition: opacity 0.12s;
  flex-shrink: 0;
}
.mt-task:hover .mt-task-actions { opacity: 1; }

/* Sortable ghost */
.mt-sortable-ghost {
  opacity: 0.35;
  background: var(--surface2);
}

/* Color picker */
.mt-color-row {
  display: flex;
  align-items: center;
  gap: 10px;
}
.mt-color-input {
  width: 38px;
  height: 28px;
  padding: 2px;
  border: 1px solid var(--border);
  border-radius: 4px;
  cursor: pointer;
  background: var(--surface);
  flex-shrink: 0;
}
.mt-color-input:disabled { opacity: 0.35; cursor: not-allowed; }
.mt-toggle-wrap {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  font-size: 13px;
  color: var(--text);
}
.mt-toggle-wrap input[type="checkbox"] { cursor: pointer; }

/* ── MASTERBOARD ─────────────────────────────────── */
.nav-item--masterboard {
  color: var(--color-magenta) !important;
  font-weight: 700;
  letter-spacing: 0.04em;
}
.nav-item--masterboard:hover {
  background: rgba(191, 27, 164, 0.12);
}
.nav-item--masterboard.active {
  background: var(--color-magenta);
  color: #fff !important;
}
[data-theme="dark"] .nav-item--masterboard.active {
  background: var(--color-magenta-dk);
}

.mb-desglose {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.mb-chart-legend {
  display: flex;
  gap: 12px;
  font-size: 10px;
  color: var(--text-muted);
  margin-top: 4px;
}
.mb-legend-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 2px;
  margin-right: 3px;
  vertical-align: middle;
}

.mb-personal-table tfoot td {
  border-top: 1px solid var(--border);
  padding-top: 6px;
  font-size: 13px;
}

.mb-nom-header {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 4px;
}
.mb-nom-selectors {
  display: flex;
  gap: 6px;
}
.mb-nom-sel {
  font-size: 12px;
  padding: 3px 7px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: var(--surface2);
  color: var(--text);
  cursor: pointer;
}
.mb-nom-verify-wrap {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 8px;
}
.mb-nom-controls {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.mb-master-controls {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
}

.td--num {
  text-align: right;
}
.td--empty {
  text-align: center;
  color: var(--text-muted);
  font-style: italic;
  padding: 16px;
}

.dash-empty {
  color: var(--text-muted);
  font-size: 12px;
  margin: 8px 0;
}

/* ── Suscripciones ──────────────────────────────────── */

.sus-resumen {
  display: grid;
  grid-template-columns: repeat(3, 1fr) 1.5fr;
  gap: 16px;
  margin-bottom: 20px;
}

@media (max-width: 1100px) {
  .sus-resumen { grid-template-columns: 1fr 1fr; }
  .sus-widget--prox { grid-column: 1 / -1; }
}

.sus-widget {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 16px 20px;
}

.sus-widget__label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--text-muted);
  margin-bottom: 6px;
}

.sus-widget__value {
  font-size: 26px;
  font-weight: 700;
  color: var(--text);
  line-height: 1.1;
}

.sus-widget__sub {
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 3px;
}

.sus-prox-list {
  margin-top: 6px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.sus-prox-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
}

.sus-prox-nombre {
  flex: 1;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sus-prox-fecha { color: var(--text-muted); min-width: 70px; text-align: right; }
.sus-prox-importe { font-weight: 600; min-width: 70px; text-align: right; }
.sus-prox-empty { font-size: 13px; color: var(--text-muted); margin: 4px 0; }

.sus-toolbar { gap: 10px; }

.sus-cat-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-right: 6px;
  flex-shrink: 0;
  vertical-align: middle;
}

.sus-cat-wrap {
  display: flex;
  align-items: center;
  white-space: nowrap;
}

.sus-tabla { width: 100%; }
.sus-tabla th,
.sus-tabla td { text-align: left; }
.sus-tabla th:nth-child(6),
.sus-tabla td:nth-child(6) { text-align: center; }
.sus-tabla th:nth-child(7),
.sus-tabla td:nth-child(7) { text-align: right; }
.sus-tabla td:nth-child(7) .actions-cell { justify-content: flex-end; }
.sus-table-wrap { overflow-x: auto; }

/* Category manager in modal */
.sus-cat-manager {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px 12px;
  margin-top: 4px;
  margin-bottom: 12px;
}

.sus-cat-manager-header { margin-bottom: 8px; }

.sus-cat-manager-label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-muted);
}

.sus-cat-list-wrap {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 8px;
  max-height: 140px;
  overflow-y: auto;
}

.sus-cat-item {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 13px;
}

.sus-cat-item-nombre { flex: 1; }
.sus-cat-count { font-size: 11px; color: var(--text-muted); }

.sus-cat-new-row {
  display: flex;
  gap: 6px;
  align-items: center;
}

.sus-cat-new-row input {
  flex: 1;
  padding: 5px 8px;
  font-size: 13px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--surface);
  color: var(--text);
}

.sus-no-cats {
  font-size: 12px;
  color: var(--text-muted);
  margin: 0 0 6px;
}

.badge--activa    { background: #d1fae5; color: #065f46; }
.badge--pausada   { background: #fef3c7; color: #92400e; }
.badge--cancelada { background: #fee2e2; color: #991b1b; }

[data-theme="dark"] .badge--activa    { background: #064e3b; color: #6ee7b7; }
[data-theme="dark"] .badge--pausada   { background: #78350f; color: #fcd34d; }
[data-theme="dark"] .badge--cancelada { background: #7f1d1d; color: #fca5a5; }

/* ── Festivos en calendario ──────────────────────────── */
.cal-day-cell--holiday {
  background: #fef3c7;
}
[data-theme="dark"] .cal-day-cell--holiday { background: rgba(234,179,8,.08); }

.cal-day-holiday-name {
  display: block;
  font-size: 9.5px;
  color: #92400e;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-top: 1px;
}
[data-theme="dark"] .cal-day-holiday-name { color: #fcd34d; }

/* Semana: header día festivo */
.cal-semana-header-day--holiday { background: #fef3c7; }
[data-theme="dark"] .cal-semana-header-day--holiday { background: rgba(234,179,8,.08); }

.cal-semana-holiday-name {
  font-size: 9px;
  color: #92400e;
  font-weight: 600;
  text-align: center;
  line-height: 1.2;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  padding: 0 4px;
}
[data-theme="dark"] .cal-semana-holiday-name { color: #fcd34d; }

/* Semana: columna festivo */
.cal-semana-col--holiday { background: rgba(254,243,199,.5); }
[data-theme="dark"] .cal-semana-col--holiday { background: rgba(234,179,8,.05); }

/* Año: día festivo */
.cal-año-dia--holiday {
  background: #fef3c7;
  border-radius: 2px;
  color: #92400e;
  font-weight: 600;
}
[data-theme="dark"] .cal-año-dia--holiday { background: rgba(234,179,8,.18); color: #fcd34d; }

/* Año: día time-off */
.cal-año-dia--timeoff {
  color: #fff;
  background: var(--ev-color, #f97316);
  border-radius: 2px;
  opacity: 0.8;
}

/* ── Time-off bars en calendario ─────────────────────── */
.cal-week-timeoff {
  grid-column: 1 / -1;
  position: relative;
  pointer-events: none;
  border-top: 1px dashed rgba(100,116,139,.3);
}

.cal-timeoff-bar {
  position: absolute;
  height: 20px;
  border-radius: 4px;
  display: flex;
  align-items: center;
  padding: 0 7px;
  overflow: hidden;
  user-select: none;
  transition: filter .1s;
  z-index: 1;
}
.cal-timeoff-bar:hover { filter: brightness(1.12); }
.cal-timeoff-bar--cont-l { border-top-left-radius: 0; border-bottom-left-radius: 0; }
.cal-timeoff-bar--cont-r { border-top-right-radius: 0; border-bottom-right-radius: 0; }

.cal-timeoff-label {
  font-size: 10.5px;
  font-weight: 600;
  color: #fff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1;
}

/* ── Panel de vacaciones ─────────────────────────────── */
.cal-vac-panel {
  position: fixed;
  top: 0;
  right: 0;
  width: 900px;
  max-width: 100vw;
  height: 100vh;
  background: var(--surface);
  border-left: 1px solid var(--border);
  box-shadow: -8px 0 32px rgba(0,0,0,.12);
  display: flex;
  flex-direction: column;
  z-index: 200;
  overflow: hidden;
}

.cal-vac-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.cal-vac-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
  margin: 0;
}
.cal-vac-close {
  width: 28px;
  height: 28px;
  border: none;
  background: transparent;
  cursor: pointer;
  font-size: 14px;
  color: var(--text-muted);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .1s, color .1s;
}
.cal-vac-close:hover { background: var(--surface2); color: var(--text); }

.cal-vac-tabs {
  display: flex;
  gap: 0;
  padding: 8px 20px 0;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.cal-vac-tab {
  padding: 7px 16px;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 500;
  color: var(--text-muted);
  cursor: pointer;
  transition: color .12s, border-color .12s;
  margin-bottom: -1px;
}
.cal-vac-tab:hover { color: var(--text); }
.cal-vac-tab.is-active { color: var(--text); border-bottom-color: var(--accent); font-weight: 600; }

.cal-vac-body {
  flex: 1;
  overflow-y: auto;
  padding: 16px 20px 24px;
}
.cal-vac-loading { color: var(--text-muted); font-size: 13px; padding: 20px 0; }

.cal-vac-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
  flex-wrap: wrap;
}
.cal-vac-balance {
  font-size: 12.5px;
  color: var(--text-muted);
}
.cal-vac-balance strong { color: var(--text); }

.cal-vac-balance-info {
  font-size: 12.5px;
  color: var(--text-muted);
  background: #fef3c7;
  border: 1px solid #fde68a;
  border-radius: var(--radius-sm);
  padding: 7px 12px;
  margin-bottom: 12px;
}
[data-theme="dark"] .cal-vac-balance-info { background: rgba(234,179,8,.1); border-color: rgba(234,179,8,.2); }

.cal-vac-days-info {
  font-size: 12.5px;
  color: var(--text-muted);
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 7px 12px;
  margin-bottom: 12px;
}
.cal-vac-days-info strong { color: var(--text); font-size: 14px; }

/* Tabla de solicitudes */
.cal-vac-table-wrap {
  overflow-x: auto;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  margin-bottom: 20px;
}
.cal-vac-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12.5px;
}
.cal-vac-table th {
  padding: 8px 10px;
  text-align: left;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-muted);
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
  background: var(--surface2);
}
.cal-vac-table td {
  padding: 9px 10px;
  vertical-align: middle;
  border-bottom: 1px solid var(--border);
  color: var(--text);
}
.cal-vac-table tbody tr:last-child td { border-bottom: none; }
.cal-vac-table tbody tr:hover td { background: var(--surface2); }
.cal-vac-td-dates { white-space: nowrap; font-family: var(--mono); font-size: 11.5px; }
.cal-vac-td-notes { max-width: 140px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; color: var(--text-muted); }
.cal-vac-td-reason { max-width: 140px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; color: var(--danger); font-size: 12px; }
.cal-vac-td-actions { white-space: nowrap; display: flex; gap: 4px; align-items: center; }

/* Badges de estado */
.cal-vac-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: var(--radius-pill);
  font-size: 11px;
  font-weight: 600;
  white-space: nowrap;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.cal-vac-badge--pending  { background: #fef3c7; color: #92400e; border: 1px solid #fde68a; }
.cal-vac-badge--approved { background: #d1fae5; color: #065f46; border: 1px solid #a7f3d0; }
.cal-vac-badge--rejected { background: #fee2e2; color: #991b1b; border: 1px solid #fca5a5; }
[data-theme="dark"] .cal-vac-badge--pending  { background: rgba(234,179,8,.15);  color: #fcd34d; border-color: rgba(234,179,8,.25); }
[data-theme="dark"] .cal-vac-badge--approved { background: rgba(16,185,129,.15); color: #6ee7b7; border-color: rgba(16,185,129,.25); }
[data-theme="dark"] .cal-vac-badge--rejected { background: rgba(239,68,68,.15);  color: #fca5a5; border-color: rgba(239,68,68,.25); }

/* Botones extra-pequeños */
.btn--xs {
  padding: 2px 8px;
  font-size: 11px;
  border-radius: var(--radius-sm);
  font-weight: 600;
}
.btn--success {
  background: #16a34a;
  color: #fff;
  border: none;
  cursor: pointer;
  font-family: var(--sans);
  border-radius: var(--radius-sm);
  transition: background .12s;
}
.btn--success:hover { background: #15803d; }
[data-theme="dark"] .btn--success { background: #16a34a; }
[data-theme="dark"] .btn--success:hover { background: #15803d; }

/* Filtros gestión */
.cal-vac-gfiltros {
  display: flex;
  gap: 8px;
  margin-bottom: 14px;
  flex-wrap: wrap;
}

/* Balance por trabajador */
.cal-vac-balances-title {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--text-muted);
  margin: 4px 0 10px;
}
.cal-vac-balances { display: flex; flex-direction: column; gap: 6px; }
.cal-vac-wbal {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12.5px;
}
.cal-vac-wbal-name {
  width: 140px;
  flex-shrink: 0;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.cal-vac-wbal-bar-wrap {
  flex: 1;
  height: 8px;
  background: var(--surface2);
  border-radius: 4px;
  overflow: hidden;
  border: 1px solid var(--border);
}
.cal-vac-wbal-bar {
  display: block;
  height: 100%;
  background: #f97316;
  border-radius: 4px;
  transition: width .3s ease;
}
.cal-vac-wbal-nums {
  width: 50px;
  flex-shrink: 0;
  text-align: right;
  color: var(--text-muted);
  font-family: var(--mono);
  font-size: 12px;
}
