/* ============================================================
   LB System — Design System
   Paleta: rojo vibrante, blanco, negro profundo, gris sutil
   ============================================================ */

:root {
  color-scheme: light;
  /* Paleta */
  --bg: #F5F5F7;
  --bg-soft: #EEEEF2;
  --surface: #FFFFFF;
  --surface-2: #FAFAFC;
  --ink: #0E0E12;
  --ink-2: #1A1A20;
  --text: #17171C;
  --text-soft: #6B6B76;
  --text-muted: #9A9AA4;
  --border: #ECECEF;
  --border-strong: #DCDCE2;
  --invert-surface: #0E0E12;      /* Tarjetas oscuras tipo summary */
  --invert-surface-2: #1A1A20;
  --invert-text: #FFFFFF;
  --invert-text-soft: rgba(255,255,255,0.72);
  --invert-text-muted: rgba(255,255,255,0.5);
  --invert-border: rgba(255,255,255,0.14);

  --red: #E60013;
  --red-600: #D1000E;
  --red-700: #B4000C;
  --red-soft: #FFE7EA;
  --red-softer: #FFF2F4;

  --green: #12B886;
  --green-soft: #E6F7F1;
  --amber: #F59E0B;
  --amber-soft: #FEF3E2;
  --blue: #2F6FED;
  --blue-soft: #E6EEFF;

  --shadow-tint: rgba(15,15,18,0.08);

  /* Tipografía */
  --font-sans: "Inter", "SF Pro Display", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-display: "Inter", "SF Pro Display", -apple-system, sans-serif;

  /* Radios */
  --r-sm: 10px;
  --r-md: 16px;
  --r-lg: 22px;
  --r-xl: 28px;
  --r-pill: 999px;

  /* Sombras */
  --shadow-xs: 0 1px 2px rgba(15, 15, 18, 0.04);
  --shadow-sm: 0 2px 8px rgba(15, 15, 18, 0.04), 0 1px 2px rgba(15, 15, 18, 0.03);
  --shadow-md: 0 8px 24px rgba(15, 15, 18, 0.06), 0 2px 6px rgba(15, 15, 18, 0.03);
  --shadow-lg: 0 20px 48px rgba(15, 15, 18, 0.10), 0 4px 12px rgba(15, 15, 18, 0.04);
  --shadow-red: 0 10px 30px rgba(230, 0, 19, 0.25);
  --shadow-dark: 0 10px 30px rgba(15, 15, 18, 0.25);

  /* Transiciones */
  --ease-out: cubic-bezier(0.2, 0.9, 0.3, 1);
  --ease-in-out: cubic-bezier(0.45, 0, 0.15, 1);
  --t-fast: 160ms;
  --t-med: 280ms;
  --t-slow: 500ms;

  /* Layout */
  --sidebar-w: 260px;
  --sidebar-w-collapsed: 76px;
  --topbar-h: 72px;
}

/* =============================================================
   Dark theme overrides
   ============================================================= */
:root[data-theme="dark"] {
  color-scheme: dark;
  --bg: #0A0A0E;
  --bg-soft: #15151C;
  --surface: #131314;
  --surface-2: #1C1C24;
  --ink: #FFFFFF;
  --ink-2: #EFEFF2;
  --text: #F4F4F6;
  --text-soft: #A8A8B2;
  --text-muted: #70707C;
  --border: #24242C;
  --border-strong: #333340;
  --invert-surface: #FFFFFF;
  --invert-surface-2: #F4F4F6;
  --invert-text: #0E0E12;
  --invert-text-soft: rgba(14,14,18,0.75);
  --invert-text-muted: rgba(14,14,18,0.5);
  --invert-border: rgba(14,14,18,0.14);

  --red-soft: rgba(230,0,19,0.22);
  --red-softer: rgba(230,0,19,0.1);

  --green-soft: rgba(18,184,134,0.2);
  --amber-soft: rgba(245,158,11,0.2);
  --blue-soft: rgba(47,111,237,0.22);

  --shadow-tint: rgba(0,0,0,0.5);
  --shadow-xs: 0 1px 2px rgba(0,0,0,0.5);
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.45), 0 1px 2px rgba(0,0,0,0.3);
  --shadow-md: 0 8px 24px rgba(0,0,0,0.5), 0 2px 6px rgba(0,0,0,0.3);
  --shadow-lg: 0 20px 48px rgba(0,0,0,0.6), 0 4px 12px rgba(0,0,0,0.3);
}

/* Overrides semánticos en dark mode */
:root[data-theme="dark"] .nav a.active {
  background: var(--red);
  color: #fff;
}
:root[data-theme="dark"] .nav a.active .icon { color: #fff; }
:root[data-theme="dark"] .nav a.active::after { background: #fff; }
:root[data-theme="dark"] .user-card { background: var(--bg-soft); }
:root[data-theme="dark"] .user-card .avatar { background: var(--red); color: #fff; }
:root[data-theme="dark"] .btn-dark { background: #fff; color: #0E0E12; }
:root[data-theme="dark"] .btn-dark:hover { background: #EFEFF2; box-shadow: 0 10px 30px rgba(255,255,255,0.15); }
:root[data-theme="dark"] .btn-ghost { background: var(--surface-2); border-color: var(--border); color: var(--text); }
:root[data-theme="dark"] .btn-ghost:hover { background: var(--bg-soft); border-color: var(--border-strong); }
:root[data-theme="dark"] .btn-link { color: var(--text); }
:root[data-theme="dark"] .btn-link:hover { background: var(--bg-soft); }
:root[data-theme="dark"] .btn-danger { background: rgba(230,0,19,0.15); color: #FF8A92; border-color: rgba(230,0,19,0.3); }
:root[data-theme="dark"] .btn-danger:hover { background: var(--red); color: #fff; border-color: var(--red); }

:root[data-theme="dark"] .kpi.kpi-dark,
:root[data-theme="dark"] .card-dark,
:root[data-theme="dark"] .summary {
  background: #000;
  border: 1px solid var(--border);
}

:root[data-theme="dark"] .toast { background: var(--red); color: #fff; }
:root[data-theme="dark"] .toast .icon-wrap { background: rgba(255,255,255,0.18); }
:root[data-theme="dark"] .toast.success { background: var(--green); }

:root[data-theme="dark"] .qa .icon-wrap {
  background: var(--red);
  color: #fff;
}
:root[data-theme="dark"] .qa.red .icon-wrap { background: var(--red); }

:root[data-theme="dark"] .modal-backdrop { background: rgba(0,0,0,0.68); }

:root[data-theme="dark"] .detail-hero .avatar {
  background: linear-gradient(135deg, #333 0%, var(--red) 120%);
}

:root[data-theme="dark"] .service-card {
  background: var(--surface);
  border-color: var(--border);
}
:root[data-theme="dark"] .service-card.selected {
  background: linear-gradient(180deg,
    color-mix(in srgb, var(--brand-primary, var(--red)) 14%, var(--surface)) 0%,
    var(--surface) 100%);
  border-color: var(--brand-primary, var(--red));
}

:root[data-theme="dark"] .search .input,
:root[data-theme="dark"] .input,
:root[data-theme="dark"] .textarea,
:root[data-theme="dark"] .select {
  background-color: var(--surface);
  border-color: var(--border);
  color: var(--text);
}
:root[data-theme="dark"] .input:focus,
:root[data-theme="dark"] .textarea:focus,
:root[data-theme="dark"] .select:focus {
  border-color: var(--border-strong);
  box-shadow: 0 0 0 4px rgba(255,255,255,0.05);
}
:root[data-theme="dark"] .input::placeholder,
:root[data-theme="dark"] .textarea::placeholder { color: var(--text-muted); }
:root[data-theme="dark"] .select {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23A8A8B2' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
}
:root[data-theme="dark"] .date-field {
  background: var(--surface);
  border-color: var(--border);
}
:root[data-theme="dark"] .date-field .date-ico {
  background: rgba(230,0,19,0.12);
  border-right-color: var(--border);
}
:root[data-theme="dark"] .date-picker { background: var(--surface); border-color: var(--border); }
:root[data-theme="dark"] .date-picker .dp-nav { background: var(--bg-soft); color: #fff; }
:root[data-theme="dark"] .date-picker .dp-nav:hover { background: var(--border-strong); color: #fff; }
:root[data-theme="dark"] .date-picker .dp-day:hover { background: var(--bg-soft); }
:root[data-theme="dark"] .date-picker .dp-day.today { box-shadow: inset 0 0 0 1.5px rgba(230,0,19,0.45); }
:root[data-theme="dark"] .date-picker .dp-btn.dp-today { background: #fff; color: #000; }
:root[data-theme="dark"] .date-picker .dp-btn.dp-today:hover { background: #EFEFF2; }

:root[data-theme="dark"] .seg-tabs { background: var(--bg-soft); }
:root[data-theme="dark"] .seg-tab.active { background: var(--red); color: #fff; }

:root[data-theme="dark"] .kpi-red { background: var(--red); } /* stays */
:root[data-theme="dark"] .login-right { background: #000; }
:root[data-theme="dark"] .sidebar { border-right-color: var(--border); }

:root[data-theme="dark"] .chip {
  background: color-mix(in srgb, var(--brand-primary, var(--red)) 18%, transparent);
  color: color-mix(in srgb, var(--brand-primary, var(--red)) 60%, #fff);
}
:root[data-theme="dark"] .badge-plain { background: var(--bg-soft); color: var(--text-soft); }
:root[data-theme="dark"] .badge-dark { background: #fff; color: #000; }

:root[data-theme="dark"] .custom-svc {
  background: linear-gradient(180deg, rgba(230,0,19,0.14) 0%, var(--surface) 100%);
}

/* Calendario de tareas en dark: día seleccionado */
:root[data-theme="dark"] .cal-day.selected {
  background: #FFFFFF;
  border-color: #FFFFFF;
}
:root[data-theme="dark"] .cal-day.selected .cal-day-num { color: #0E0E12; }
:root[data-theme="dark"] .cal-day.today.selected .cal-day-num {
  background: var(--red);
  color: #fff;
}
:root[data-theme="dark"] .cal-day.selected .cal-task {
  background: rgba(14,14,18,0.12);
  color: #0E0E12;
}
:root[data-theme="dark"] .cal-day.selected .cal-task.alta {
  background: var(--red);
  color: #fff;
}
:root[data-theme="dark"] .cal-day.selected .cal-task.media {
  background: rgba(245,158,11,0.6);
  color: #2A1800;
}
:root[data-theme="dark"] .cal-day.selected .cal-task.baja {
  background: rgba(47,111,237,0.45);
  color: #0A1F4A;
}
:root[data-theme="dark"] .cal-day.selected .cal-task.completa {
  color: rgba(14,14,18,0.55);
}
:root[data-theme="dark"] .cal-day.selected .cal-more { color: rgba(14,14,18,0.65); }

::-webkit-scrollbar-thumb { background: var(--border-strong); border-color: var(--bg); }

/* =============================================================
   Tareas · Calendario grande
   ============================================================= */
.tareas-grid {
  display: grid;
  grid-template-columns: 1.8fr 1fr;
  gap: 20px;
  align-items: start;
}
@media (max-width: 1100px) {
  .tareas-grid { grid-template-columns: 1fr; }
}

.calendar-card {
  background: var(--surface);
  border-radius: var(--r-xl);
  padding: 24px;
  box-shadow: var(--shadow-sm);
}
.calendar-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
}
.calendar-head .cal-title {
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.025em;
  text-transform: capitalize;
}
.calendar-head .cal-nav {
  display: flex;
  gap: 6px;
  align-items: center;
}
.calendar-head .cal-nav .btn-icon {
  background: var(--bg-soft);
  width: 36px; height: 36px;
}
.calendar-head .cal-nav .btn-icon:hover {
  background: var(--ink);
  color: #fff;
}
.calendar-head .cal-today-btn {
  background: var(--bg-soft);
  color: var(--text);
  border: none;
}
.calendar-head .cal-today-btn:hover { background: var(--border); color: var(--ink); }

.calendar-weekdays {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 6px;
  margin-bottom: 8px;
}
.calendar-weekdays span {
  text-align: center;
  font-size: 11px;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 6px 0;
}
.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 6px;
}
.cal-day {
  aspect-ratio: 1;
  min-height: 72px;
  border-radius: 14px;
  background: var(--surface-2);
  border: 1px solid transparent;
  padding: 8px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  cursor: pointer;
  transition: background var(--t-fast), border-color var(--t-fast), transform var(--t-fast);
  position: relative;
  overflow: hidden;
}
.cal-day:hover { background: var(--bg-soft); border-color: var(--border); }
.cal-day.outside { opacity: 0.4; }
.cal-day.today .cal-day-num {
  background: var(--red);
  color: #fff;
  border-radius: 50%;
  width: 22px; height: 22px;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 11px;
  font-weight: 700;
}
.cal-day.selected {
  background: var(--ink);
  border-color: var(--ink);
}
.cal-day.selected .cal-day-num { color: #fff; }
.cal-day.selected .cal-task { background: rgba(255,255,255,0.16); color: #fff; }
.cal-day.selected .cal-task.alta { background: rgba(230,0,19,0.35); color: #fff; }
.cal-day .cal-day-num {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  flex-shrink: 0;
  align-self: flex-start;
}
.cal-day .cal-tasks {
  display: flex;
  flex-direction: column;
  gap: 3px;
  overflow: hidden;
  width: 100%;
}
.cal-day .cal-task {
  font-size: 10px;
  font-weight: 600;
  padding: 3px 6px;
  border-radius: 6px;
  background: var(--red-softer);
  color: var(--red-700);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.2;
}
.cal-day .cal-task.completa { opacity: 0.55; text-decoration: line-through; }
.cal-day .cal-task.media { background: var(--amber-soft); color: var(--amber); }
.cal-day .cal-task.baja { background: var(--blue-soft); color: var(--blue); }
.cal-day .cal-task.alta { background: var(--red); color: #fff; }
.cal-day .cal-more {
  font-size: 10px;
  color: var(--text-muted);
  font-weight: 600;
  padding: 2px 4px;
}
@media (max-width: 720px) {
  .calendar-card { padding: 14px; }
  .calendar-head { margin-bottom: 12px; }
  .calendar-head .cal-title { font-size: 18px; }

  .calendar-grid,
  .calendar-weekdays {
    grid-template-columns: repeat(7, 40px);
    justify-content: space-between;
    gap: 10px 0;
  }
  .calendar-weekdays { gap: 0; padding: 0; }
  .calendar-weekdays span { padding: 4px 0; font-size: 10px; }

  .cal-day {
    width: 40px;
    height: 40px;
    min-height: 0;
    aspect-ratio: auto;
    padding: 4px;
    gap: 2px;
    border-radius: 10px;
    box-sizing: border-box;
  }
  .cal-day .cal-day-num { font-size: 12px; }
  .cal-day.today .cal-day-num { width: 18px; height: 18px; font-size: 9px; }

  .cal-day .cal-tasks {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 3px;
    margin-top: auto;
    align-items: center;
    justify-content: center;
  }
  .cal-day .cal-task {
    width: 5px;
    height: 5px;
    padding: 0;
    font-size: 0;
    line-height: 0;
    border-radius: 50%;
    color: transparent;
    flex: none;
    text-indent: -9999px;
    overflow: hidden;
  }
  .cal-day .cal-task.completa { text-decoration: none; opacity: 0.4; }
  .cal-day .cal-more { display: none; }

  /* Dots solid-color (las vars *-soft se ven muy claras como puntito) */
  .cal-day .cal-task { background: var(--red); }
  .cal-day .cal-task.alta { background: var(--red); }
  .cal-day .cal-task.media { background: var(--amber); }
  .cal-day .cal-task.baja { background: var(--blue); }
  .cal-day.selected .cal-task { background: rgba(255,255,255,0.75); }
  .cal-day.selected .cal-task.alta { background: #fff; }
  .cal-day.selected .cal-task.media { background: var(--amber); }
  .cal-day.selected .cal-task.baja { background: #B7CCFF; }
}

/* Tareas panel lateral */
.tareas-side {
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: sticky;
  top: calc(var(--topbar-h) + 12px);
}
@media (max-width: 1100px) { .tareas-side { position: static; } }

.task-card {
  display: flex;
  gap: 12px;
  padding: 12px 14px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--surface);
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
  align-items: flex-start;
}
.task-card:hover { border-color: var(--border-strong); box-shadow: var(--shadow-sm); }
.task-card.done { opacity: 0.6; }

/* Banding por prioridad: borde izquierdo grueso + fondo tintado */
.task-card.prio-alta {
  border-left: 4px solid #DC2626;
  background: linear-gradient(90deg, color-mix(in srgb, #DC2626 8%, var(--surface)) 0%, var(--surface) 35%);
}
.task-card.prio-media {
  border-left: 4px solid var(--amber);
  background: linear-gradient(90deg, color-mix(in srgb, var(--amber) 8%, var(--surface)) 0%, var(--surface) 35%);
}
.task-card.prio-baja {
  border-left: 4px solid var(--blue);
  background: linear-gradient(90deg, color-mix(in srgb, var(--blue) 6%, var(--surface)) 0%, var(--surface) 35%);
}
.task-card.prio-alta .t-title { font-weight: 700; }
.task-card.prio-alta:not(.done) .t-title { color: #B91C1C; }
.task-card.done.prio-alta .t-title { color: var(--text-soft); }
.task-card.done .t-title { text-decoration: line-through; color: var(--text-soft); }
.task-check {
  width: 22px; height: 22px;
  border-radius: 7px;
  border: 1.5px solid var(--border-strong);
  flex-shrink: 0;
  margin-top: 1px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: transparent;
  transition: all var(--t-fast);
}
.task-check:hover { border-color: var(--red); }
.task-check svg { width: 13px; height: 13px; }
.task-card.done .task-check { background: var(--red); border-color: var(--red); color: #fff; }
.task-body { flex: 1; min-width: 0; }
.task-body .t-title { font-size: 14px; font-weight: 600; letter-spacing: -0.01em; display: block; line-height: 1.35; }
.task-body .t-meta {
  display: flex; align-items: center; gap: 8px; margin-top: 4px;
  font-size: 12px; color: var(--text-soft);
  flex-wrap: wrap;
}
.task-body .t-desc {
  font-size: 12px;
  color: var(--text-soft);
  margin-top: 4px;
  line-height: 1.45;
  word-break: break-word;
}
.task-actions {
  display: flex; gap: 4px; opacity: 0;
  transition: opacity var(--t-fast);
}
.task-card:hover .task-actions { opacity: 1; }
.task-actions .btn-icon { width: 28px; height: 28px; padding: 6px; background: var(--bg-soft); }
.task-actions .btn-icon svg.icon { width: 14px; height: 14px; }

.priority-dot {
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--text-muted);
  flex-shrink: 0;
}
.priority-dot.alta {
  background: #DC2626;
  box-shadow: 0 0 0 3px color-mix(in srgb, #DC2626 22%, transparent);
}
.priority-dot.media { background: var(--amber); }
.priority-dot.baja  { background: var(--blue); }

/* Pill de prioridad — indicador notorio dentro del task-card */
.prio-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 3px 10px;
  border-radius: var(--r-pill);
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  line-height: 1.3;
}
.prio-pill.prio-alta {
  background: color-mix(in srgb, #DC2626 14%, transparent);
  color: #B91C1C;
}
.prio-pill.prio-media {
  background: color-mix(in srgb, var(--amber) 18%, transparent);
  color: #B45309;
}
.prio-pill.prio-baja {
  background: color-mix(in srgb, var(--blue) 14%, transparent);
  color: #1E40AF;
}
.t-meta-sep { font-size: 11.5px; color: var(--text-muted); font-weight: 500; }

/* Calendar cells: alta más notorio */
.cal-day .cal-task.alta { font-weight: 700; }
.cal-day .cal-task.alta::before {
  content: "!"; font-weight: 900; margin-right: 3px;
}

/* Dark theme: ajusta tints + colores de texto del prio-pill */
:root[data-theme="dark"] .prio-pill.prio-alta  { background: color-mix(in srgb, #DC2626 26%, transparent); color: #FCA5A5; }
:root[data-theme="dark"] .prio-pill.prio-media { background: color-mix(in srgb, var(--amber) 28%, transparent); color: #FCD34D; }
:root[data-theme="dark"] .prio-pill.prio-baja  { background: color-mix(in srgb, var(--blue) 26%, transparent); color: #93C5FD; }
:root[data-theme="dark"] .task-card.prio-alta:not(.done) .t-title { color: #FCA5A5; }

.kpi-tareas-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.kpi-tareas-grid .mini-kpi {
  padding: 14px;
  background: var(--surface);
  border-radius: var(--r-lg);
  border: 1px solid var(--border);
}
.kpi-tareas-grid .mini-kpi b { font-size: 22px; font-weight: 700; letter-spacing: -0.02em; display: block; }
.kpi-tareas-grid .mini-kpi span { font-size: 11px; color: var(--text-soft); text-transform: uppercase; letter-spacing: 0.08em; font-weight: 600; }
.kpi-tareas-grid .mini-kpi.accent { background: var(--red-softer); border-color: transparent; color: var(--red-700); }
.kpi-tareas-grid .mini-kpi.accent b, .kpi-tareas-grid .mini-kpi.accent span { color: var(--red-700); }
@media (max-width: 640px) { .kpi-tareas-grid { grid-template-columns: repeat(2, 1fr); } }

/* Theme toggle button */
.theme-toggle {
  position: relative;
  width: 40px; height: 40px;
  border-radius: var(--r-pill);
  background: var(--bg-soft);
  color: var(--ink);
  display: flex; align-items: center; justify-content: center;
  transition: background var(--t-fast), transform var(--t-fast);
  cursor: pointer;
}
.theme-toggle:hover { background: var(--border); transform: rotate(-6deg); }
.theme-toggle svg { width: 18px; height: 18px; transition: transform var(--t-fast); }

/* ============================================================
   Reset / Base
   ============================================================ */
*,
*::before,
*::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  /* No usar overflow-x:hidden en el root: rompe position:sticky del sidebar.
     El overflow horizontal se previene mediante minmax(0, 1fr) en grids
     y min-width:0 en flex items (ya aplicado en este archivo). */
  max-width: 100vw;
}
body {
  font-family: var(--font-sans);
  background: var(--bg);
  color: var(--text);
  font-size: 15px;
  line-height: 1.5;
  font-feature-settings: "cv11", "ss01", "ss03";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  max-width: 100vw;
}
button, input, select, textarea { font: inherit; color: inherit; }
button { background: none; border: none; cursor: pointer; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
h1, h2, h3, h4, h5, h6 { margin: 0; letter-spacing: -0.02em; }
p { margin: 0; }
input, textarea, select { outline: none; }

::selection { background: var(--red-soft); color: var(--red-700); }

svg.icon { width: 18px; height: 18px; flex-shrink: 0; display: inline-block; vertical-align: middle; }
.btn svg.icon { width: 16px; height: 16px; }
.btn-icon svg.icon { width: 18px; height: 18px; }

/* Scrollbar (webkit) */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border-strong); border-radius: 20px; border: 2px solid var(--bg); }
::-webkit-scrollbar-thumb:hover { background: var(--text-muted); }

/* ============================================================
   Utilidades
   ============================================================ */
.hidden { display: none !important; }
.stack-v { display: flex; flex-direction: column; }
.stack-h { display: flex; flex-direction: row; align-items: center; }
.gap-4 { gap: 4px; } .gap-8 { gap: 8px; } .gap-12 { gap: 12px; }
.gap-16 { gap: 16px; } .gap-20 { gap: 20px; } .gap-24 { gap: 24px; }
.mt-4 { margin-top: 4px; } .mt-8 { margin-top: 8px; } .mt-12 { margin-top: 12px; }
.mt-16 { margin-top: 16px; } .mt-24 { margin-top: 24px; } .mt-32 { margin-top: 32px; }
.text-soft { color: var(--text-soft); }
.text-muted { color: var(--text-muted); }
.text-red { color: var(--red); }
.text-sm { font-size: 13px; }
.text-xs { font-size: 12px; }
.text-lg { font-size: 17px; }
.text-xl { font-size: 20px; }
.fw-500 { font-weight: 500; } .fw-600 { font-weight: 600; } .fw-700 { font-weight: 700; }
/* min-width:0 permite que el flex item se contraiga por debajo del ancho de su
   contenido (sin esto, un texto largo expande el padre y desborda el viewport). */
.flex-1 { flex: 1; min-width: 0; }
.grow { flex-grow: 1; }
.center { display: flex; align-items: center; justify-content: center; }
@media (max-width: 640px) { .hide-sm { display: none !important; } }

.btn-group { display: flex; gap: 10px; flex-wrap: wrap; }
@media (max-width: 640px) {
  .btn-group { flex-direction: column; align-items: stretch; }
  .btn-group .btn { width: 100%; justify-content: center; }
}

.mobile-project {
  display: block;
  padding: 16px;
  background: var(--surface);
  border-radius: var(--r-lg);
  margin-bottom: 10px;
  transition: transform var(--t-fast), box-shadow var(--t-fast);
}
.mobile-project:active { transform: scale(0.99); }
.mobile-project .mp-top { display: flex; align-items: flex-start; gap: 12px; }
.mobile-project .mp-ico {
  width: 40px; height: 40px;
  border-radius: 12px;
  background: var(--bg-soft);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.mobile-project .mp-body { flex: 1; min-width: 0; }
.mobile-project .mp-body b { font-weight: 600; font-size: 15px; display: block; line-height: 1.3; }
.mobile-project .mp-body .mp-sub { font-size: 13px; color: var(--text-soft); margin-top: 4px; }
.mobile-project .mp-foot {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: 12px; padding-top: 12px; border-top: 1px dashed var(--border);
  gap: 10px;
}
.mobile-project .mp-foot b { font-size: 15px; font-weight: 700; }

.proyecto-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 16px;
  text-decoration: none;
  color: var(--text);
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.proyecto-row:hover { border-color: var(--border-strong); box-shadow: var(--shadow-sm); }
.proyecto-row .pr-ico {
  width: 44px; height: 44px;
  border-radius: 14px;
  background: var(--bg-soft);
  display: flex; align-items: center; justify-content: center;
  color: var(--ink);
  flex-shrink: 0;
}
.proyecto-row .pr-body { flex: 1; min-width: 0; }
.proyecto-row .pr-title {
  display: flex; align-items: center; gap: 8px;
  flex-wrap: wrap;
}
.proyecto-row .pr-title b { font-weight: 600; font-size: 14px; line-height: 1.3; }
.proyecto-row .pr-sub {
  font-size: 13px; color: var(--text-soft);
  margin-top: 4px;
  overflow: hidden; text-overflow: ellipsis;
}
.proyecto-row .pr-arrow { color: var(--text-muted); flex-shrink: 0; }
@media (max-width: 640px) {
  .proyecto-row .pr-arrow { display: none; }
  .proyecto-row .pr-title { flex-direction: column; align-items: flex-start; gap: 6px; }
}

/* ============================================================
   Columna "Próximo a vencer"
   ============================================================ */
.vencer-cell {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.vencer-date {
  font-size: 11px;
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
}
.vencer-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: var(--r-pill);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: -0.005em;
  white-space: nowrap;
  width: fit-content;
}
.vencer-badge svg.icon { width: 12px; height: 12px; }
.vencer-ok { background: var(--green-soft); color: var(--green); }
.vencer-warn { background: var(--amber-soft); color: var(--amber); }
.vencer-urgent { background: #FFEDEF; color: var(--red-700); }
.vencer-today {
  background: var(--red);
  color: #fff;
  box-shadow: 0 4px 12px rgba(230, 0, 19, 0.26);
  animation: vencerPulse 2.4s ease-in-out infinite;
}
.vencer-overdue {
  background: var(--ink);
  color: #fff;
}
.vencer-done { background: #EEEBFF; color: #6A4BFF; }
.vencer-void { background: var(--bg-soft); color: var(--text-soft); }
.vencer-none { background: var(--bg-soft); color: var(--text-muted); }

@keyframes vencerPulse {
  0%, 100% { box-shadow: 0 4px 12px rgba(230, 0, 19, 0.26); }
  50% { box-shadow: 0 4px 22px rgba(230, 0, 19, 0.5); }
}

/* ============================================================
   Animaciones globales
   ============================================================ */
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(16px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes fadeInDown {
  from { opacity: 0; transform: translateY(-12px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes scaleIn {
  from { opacity: 0; transform: scale(0.96); }
  to { opacity: 1; transform: scale(1); }
}
@keyframes slideInRight {
  from { opacity: 0; transform: translateX(24px); }
  to { opacity: 1; transform: translateX(0); }
}
@keyframes shimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}
@keyframes pulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50% { transform: scale(1.05); opacity: 0.85; }
}
@keyframes floatSoft {
  0%, 100% { transform: translateY(0) rotate(0deg); }
  50% { transform: translateY(-8px) rotate(1deg); }
}
@keyframes spin { to { transform: rotate(360deg); } }

.fade-in { animation: fadeIn var(--t-med) var(--ease-out); }
.fade-up { animation: fadeInUp 540ms var(--ease-out); }
.scale-in { animation: scaleIn 360ms var(--ease-out); }

/* Stagger usa --stagger-i (asignado por JS) para escalar a N elementos.
   Si no se asigna, los nth-child sirven como fallback hasta el #12. */
.stagger > * {
  opacity: 0;
  animation: fadeInUp 520ms var(--ease-out) forwards;
  animation-delay: calc(var(--stagger-i, 0) * 50ms + 40ms);
}
.stagger > *:nth-child(1)  { animation-delay: 40ms; }
.stagger > *:nth-child(2)  { animation-delay: 90ms; }
.stagger > *:nth-child(3)  { animation-delay: 140ms; }
.stagger > *:nth-child(4)  { animation-delay: 190ms; }
.stagger > *:nth-child(5)  { animation-delay: 240ms; }
.stagger > *:nth-child(6)  { animation-delay: 290ms; }
.stagger > *:nth-child(7)  { animation-delay: 340ms; }
.stagger > *:nth-child(8)  { animation-delay: 390ms; }
.stagger > *:nth-child(9)  { animation-delay: 440ms; }
.stagger > *:nth-child(10) { animation-delay: 490ms; }
.stagger > *:nth-child(11) { animation-delay: 540ms; }
.stagger > *:nth-child(12) { animation-delay: 590ms; }
/* Cuando JS asigna --stagger-i, nuestro calc() lo gana porque el selector
   compuesto tiene mayor especificidad que los nth-child plenos. */
.stagger > [style*="--stagger-i"] {
  animation-delay: calc(var(--stagger-i, 0) * 50ms + 40ms) !important;
}

/* ============================================================
   Botones
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 11px 20px;
  border-radius: var(--r-pill);
  font-weight: 600;
  font-size: 14px;
  letter-spacing: -0.01em;
  transition: transform var(--t-fast) var(--ease-out),
              background var(--t-fast) var(--ease-out),
              box-shadow var(--t-fast) var(--ease-out),
              color var(--t-fast) var(--ease-out);
  white-space: nowrap;
  user-select: none;
}
.btn:active { transform: scale(0.97); }
.btn .icon { width: 16px; height: 16px; }

.btn-primary {
  background: var(--brand-primary, var(--red));
  color: #fff;
  box-shadow: 0 10px 30px color-mix(in srgb, var(--brand-primary, var(--red)) 25%, transparent);
}
.btn-primary:hover {
  background: color-mix(in srgb, var(--brand-primary, var(--red)) 90%, #000);
  transform: translateY(-1px);
  box-shadow: 0 14px 34px color-mix(in srgb, var(--brand-primary, var(--red)) 32%, transparent);
}

.btn-dark {
  background: var(--ink);
  color: #fff;
}
.btn-dark:hover { background: var(--ink-2); transform: translateY(-1px); box-shadow: var(--shadow-dark); }

.btn-ghost {
  background: var(--surface);
  color: var(--ink);
  border: 1px solid var(--border);
}
.btn-ghost:hover { background: var(--bg); border-color: var(--border-strong); }

.btn-soft {
  background: var(--red-soft);
  color: var(--red-700);
}
.btn-soft:hover { background: #FFD8DD; }

.btn-link {
  background: transparent;
  color: var(--text);
  padding: 8px 14px;
}
.btn-link:hover { background: var(--bg-soft); }

.btn-danger {
  background: #FFF2F4;
  color: var(--red-700);
  border: 1px solid #FFD8DD;
}
.btn-danger:hover { background: var(--red); color: #fff; border-color: var(--red); }

.btn-sm { padding: 7px 14px; font-size: 13px; }
.btn-lg { padding: 14px 26px; font-size: 15px; }
.btn-icon {
  padding: 10px;
  width: 40px;
  height: 40px;
  border-radius: var(--r-pill);
}
.btn-icon.btn-sm { width: 34px; height: 34px; padding: 7px; }
.btn-block { width: 100%; }

/* Arrow-button estilo referencia */
.btn-arrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: rgba(255,255,255,0.18);
  color: #fff;
  transition: transform var(--t-med) var(--ease-out), background var(--t-fast);
}
.btn-arrow:hover { background: #fff; color: var(--red); transform: translateX(2px); }

/* ============================================================
   Tarjetas
   ============================================================ */
.card {
  background: var(--surface);
  border-radius: var(--r-xl);
  padding: 24px;
  box-shadow: var(--shadow-sm);
  transition: transform var(--t-med) var(--ease-out), box-shadow var(--t-med) var(--ease-out);
}
.card:hover { box-shadow: var(--shadow-md); }

.card-tight { padding: 18px; border-radius: var(--r-lg); }
.card-loose { padding: 32px; }
.card-dark { background: var(--ink); color: #fff; }
.card-red { background: var(--red); color: #fff; }

.section { padding: 28px 0; }
.section-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}
.section-head h2 { font-size: 26px; font-weight: 700; letter-spacing: -0.03em; }
.section-head .sub { color: var(--text-soft); font-size: 14px; margin-top: 4px; }

/* ============================================================
   Formularios
   ============================================================ */
.field { display: flex; flex-direction: column; gap: 6px; }
.field label {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-soft);
  letter-spacing: -0.005em;
}
.input, .textarea, .select {
  width: 100%;
  padding: 13px 16px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  font-size: 14px;
  color: var(--text);
  transition: border-color var(--t-fast), box-shadow var(--t-fast), background var(--t-fast);
}
.input:focus, .textarea:focus, .select:focus {
  border-color: var(--ink);
  box-shadow: 0 0 0 4px rgba(15,15,18,0.05);
}
.input::placeholder, .textarea::placeholder { color: var(--text-muted); }
.textarea { min-height: 100px; resize: vertical; font-family: inherit; }
.select {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236B6B76' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 36px;
}

.field-row { display: grid; gap: 16px; }
.field-row.cols-2 { grid-template-columns: 1fr 1fr; }
.field-row.cols-3 { grid-template-columns: repeat(3, 1fr); }
.field-row.cols-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 860px) {
  .field-row.cols-2, .field-row.cols-3, .field-row.cols-4 { grid-template-columns: 1fr; }
}

.input-icon { position: relative; }
.input-icon .input { padding-left: 44px; }
.input-icon .icon {
  position: absolute;
  left: 14px; top: 50%;
  transform: translateY(-50%);
  color: var(--text-muted);
  width: 18px; height: 18px;
}

.switch {
  position: relative;
  display: inline-block;
  width: 44px; height: 26px;
}
.switch input { opacity: 0; width: 0; height: 0; }
.switch .slider {
  position: absolute;
  inset: 0;
  background: var(--border-strong);
  border-radius: 999px;
  transition: background var(--t-fast);
  cursor: pointer;
}
.switch .slider::before {
  content: "";
  position: absolute;
  width: 20px; height: 20px;
  left: 3px; top: 3px;
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 2px 6px rgba(0,0,0,0.12);
  transition: transform var(--t-fast);
}
.switch input:checked + .slider { background: var(--red); }
.switch input:checked + .slider::before { transform: translateX(18px); }

/* ============================================================
   Badges / Chips / Pills
   ============================================================ */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: var(--r-pill);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: -0.005em;
  white-space: nowrap;
  flex-shrink: 0;
}
.badge::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 50%;
  background: currentColor;
}
.badge-red { background: var(--red-soft); color: var(--red-700); }
.badge-green { background: var(--green-soft); color: var(--green); }
.badge-amber { background: var(--amber-soft); color: var(--amber); }
.badge-blue { background: var(--blue-soft); color: var(--blue); }
.badge-dark { background: #1A1A20; color: #fff; }
.badge-gray { background: var(--bg-soft); color: var(--text-soft); }
.badge-plain { background: var(--bg-soft); color: var(--text); }
.badge-plain::before { display: none; }

.chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: var(--r-pill);
  background: var(--red-softer);
  color: var(--red-700);
  font-size: 12px;
  font-weight: 600;
}

/* Estado de proyecto helper — 4 estados: en_proceso, completado, cancelado, retrasado */
.status-en-proceso { background: var(--blue-soft);  color: var(--blue);  }
.status-completado { background: var(--green-soft); color: var(--green); }
.status-cancelado  { background: #FFE7EA;           color: #B4000C;      }
.status-retrasado  { background: var(--amber-soft); color: #B45309;      }
/* Compat: legacy class names (por si quedaron datos sin migrar) */
.status-pagado     { background: var(--green-soft); color: var(--green); }
.status-terminado  { background: var(--green-soft); color: var(--green); }
.status-en-evaluacion-por-el-cliente { background: var(--blue-soft); color: var(--blue); }

/* ============================================================
   Layout: App Shell
   ============================================================ */
.app-shell {
  display: grid;
  /* minmax(0, 1fr) garantiza que la columna del contenido NO se expanda por
     hijos con contenido largo (texto sin wrap). Critical para mobile zoom out. */
  grid-template-columns: var(--sidebar-w) minmax(0, 1fr);
  min-height: 100vh;
  transition: grid-template-columns var(--t-med) var(--ease-out);
}
.app-shell.collapsed { grid-template-columns: var(--sidebar-w-collapsed) minmax(0, 1fr); }

.sidebar-scrim {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(15, 15, 18, 0.5);
  z-index: 19;
  animation: fadeIn var(--t-med);
}

.sidebar {
  background: var(--surface);
  border-right: 1px solid var(--border);
  padding: 20px 14px 16px;
  position: sticky;
  top: 0;
  height: 100vh;
  height: 100dvh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  z-index: 20;
}
.sidebar-scroll {
  flex: 1 1 auto;
  overflow-y: auto;
  margin: 0 -14px;
  padding: 0 14px;
  -webkit-overflow-scrolling: touch;
}
.sidebar .brand {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 8px 20px;
}
.sidebar .brand img { width: 38px; height: 38px; object-fit: contain; }
.sidebar .brand .brand-text {
  display: flex; flex-direction: column;
  line-height: 1.15;
  transition: opacity var(--t-fast);
}
.sidebar .brand .brand-text b { font-size: 15px; letter-spacing: -0.02em; }
.sidebar .brand .brand-text span { font-size: 11px; color: var(--text-soft); text-transform: uppercase; letter-spacing: 0.12em; }

.nav-section-label {
  padding: 18px 12px 8px;
  font-size: 11px;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-weight: 600;
}

.nav {
  display: flex; flex-direction: column; gap: 3px;
}
.nav a {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 11px 12px;
  border-radius: 14px;
  color: var(--text-soft);
  font-weight: 500;
  font-size: 14px;
  transition: background var(--t-fast), color var(--t-fast), transform var(--t-fast);
  position: relative;
}
.nav a .icon {
  width: 20px; height: 20px; flex-shrink: 0;
  color: var(--brand-primary, var(--text-muted));
  transition: color var(--t-fast);
}
.nav a:hover {
  background: var(--bg);
  color: var(--ink);
}
.nav a:hover .icon {
  color: color-mix(in srgb, var(--brand-primary, var(--ink)) 80%, var(--ink));
}
.nav a.active {
  background: var(--ink);
  color: #fff;
}
.nav a.active .icon { color: #fff !important; }
.nav a.active::after {
  content: "";
  position: absolute;
  right: 10px; top: 50%;
  transform: translateY(-50%);
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--red);
}

.sidebar .sidebar-foot {
  flex-shrink: 0;
  padding-top: 14px;
  padding-bottom: max(0px, env(safe-area-inset-bottom, 0px));
  margin-top: 8px;
  border-top: 1px solid var(--border);
  background: var(--surface);
}

.user-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px;
  border-radius: 14px;
  background: var(--bg);
  cursor: pointer;
  transition: background var(--t-fast);
}
.user-card:hover { background: var(--bg-soft); }
.user-card .avatar {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--ink);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 14px;
  flex-shrink: 0;
}
.user-card .name {
  font-size: 13px; font-weight: 600;
  line-height: 1.2;
}
.user-card .role {
  font-size: 11px;
  color: var(--text-soft);
}

/* Main area */
.main {
  min-width: 0;
  display: flex;
  flex-direction: column;
}
.topbar {
  height: var(--topbar-h);
  padding: 0 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  background: var(--surface);
  position: sticky;
  top: 0;
  z-index: 10;
  border-bottom: 1px solid var(--border);
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.topbar.scrolled {
  border-bottom-color: color-mix(in srgb, var(--brand-primary, var(--red)) 35%, var(--border));
}
:root[data-theme="dark"] .topbar { background: var(--surface); }

/* El contenedor del search (menuTrigger + search) toma el ancho disponible
   en el topbar, para que el .search pueda crecer hasta su max-width. */
.topbar > .stack-h.gap-12 { flex: 1; min-width: 0; }
.search {
  flex: 1; max-width: 840px;
}
.topbar-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.content {
  padding: 12px 32px 80px;
}

.page-head {
  padding: 12px 0 24px;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
}
.page-head h1 {
  font-size: 34px;
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 1.1;
}
.page-head .sub {
  color: var(--text-soft);
  font-size: 15px;
  margin-top: 6px;
}
.page-head .actions { display: flex; gap: 10px; flex-wrap: wrap; }

.crumbs {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--text-soft);
  margin-bottom: 6px;
}
.crumbs a:hover { color: var(--ink); }
.crumbs .sep { color: var(--text-muted); }

/* Indicador de sync con servidor (topbar) */
.sync-indicator {
  display: inline-flex; align-items: center; justify-content: center;
  width: 38px; height: 38px;
  border: 1px solid var(--border);
  background: var(--surface-2);
  border-radius: 50%;
  cursor: pointer;
  color: var(--text-soft);
  transition: all var(--t-fast);
}
.sync-indicator:hover { background: var(--bg-soft); border-color: var(--border-strong); }
.sync-indicator .icon { width: 16px; height: 16px; }
.sync-indicator[data-state="syncing"] { color: var(--blue); }
.sync-indicator[data-state="syncing"] .icon { animation: syncSpin 1s linear infinite; }
.sync-indicator[data-state="saved"] { color: var(--green); border-color: color-mix(in srgb, var(--green) 35%, var(--border)); }
.sync-indicator[data-state="error"],
.sync-indicator[data-state="offline"] { color: var(--amber); border-color: color-mix(in srgb, var(--amber) 35%, var(--border)); }
@keyframes syncSpin { to { transform: rotate(360deg); } }

/* Mobile menu */
.menu-trigger {
  display: none;
  width: 42px; height: 42px;
  align-items: center; justify-content: center;
  border-radius: 12px;
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--text);
  cursor: pointer;
  transition: all var(--t-fast) var(--ease-out);
  flex-shrink: 0;
}
.menu-trigger:hover {
  background: var(--bg-soft);
  border-color: color-mix(in srgb, var(--brand-primary, var(--red)) 35%, var(--border-strong));
  color: var(--brand-primary, var(--text));
}
.menu-trigger:active { transform: scale(0.94); }
.menu-trigger .icon { width: 22px; height: 22px; color: currentColor; }

/* ============================================================
   Dashboard KPI cards
   ============================================================ */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 20px;
}
.kpi {
  grid-column: span 4;
  background: var(--surface);
  border-radius: var(--r-xl);
  padding: 22px;
  position: relative;
  overflow: hidden;
  transition: transform var(--t-med) var(--ease-out), box-shadow var(--t-med) var(--ease-out);
}
.kpi:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.kpi .head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}
.kpi .icon-wrap {
  width: 42px; height: 42px;
  border-radius: 14px;
  background: var(--bg-soft);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ink);
}
.kpi .icon-wrap .icon { width: 20px; height: 20px; }
.kpi .label {
  font-size: 13px;
  color: var(--text-soft);
  font-weight: 500;
}
.kpi .value {
  font-size: 38px;
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 1.05;
  margin-top: 4px;
}
.kpi .delta {
  margin-top: 8px;
  font-size: 12px;
  color: var(--text-soft);
}
.kpi.kpi-red {
  background: var(--red);
  color: #fff;
}
.kpi.kpi-red .label, .kpi.kpi-red .delta { color: rgba(255,255,255,0.82); }
.kpi.kpi-red .icon-wrap { background: rgba(255,255,255,0.16); color: #fff; }
.kpi.kpi-dark {
  background: var(--ink);
  color: #fff;
}
.kpi.kpi-dark .label, .kpi.kpi-dark .delta { color: rgba(255,255,255,0.7); }
.kpi.kpi-dark .icon-wrap { background: rgba(255,255,255,0.08); color: #fff; }

.kpi.span-4 { grid-column: span 4; }
.kpi.span-3 { grid-column: span 3; }
.kpi.span-6 { grid-column: span 6; }

@media (max-width: 1100px) {
  .kpi { grid-column: span 6; }
  .kpi.span-3, .kpi.span-4 { grid-column: span 6; }
}
@media (max-width: 600px) {
  /* En mobile: 2 por renglón. Todos los kpi miden lo mismo (incluso el de
     ingresos que en desktop era span-4 y el de tareas que era span-6). */
  .kpi-grid { gap: 12px; }
  .kpi, .kpi.span-3, .kpi.span-4, .kpi.span-6 { grid-column: span 6; }
  /* Reducir padding interior para que la información no se sienta apretada */
  .kpi { padding: 16px 14px; min-width: 0; overflow: hidden; }
  .kpi .icon-wrap { width: 34px; height: 34px; border-radius: 11px; flex-shrink: 0; }
  .kpi .icon-wrap .icon { width: 16px; height: 16px; }
  .kpi .head > div:first-child { min-width: 0; flex: 1; }
  .kpi .label { font-size: 11px; overflow-wrap: break-word; }
  /* font-size más pequeño y compacto para que valores como "$17,800.00"
     quepan en una sola línea en cards de ~170px de ancho. */
  .kpi .value {
    font-size: 22px;
    font-weight: 700;
    letter-spacing: -0.03em;
    line-height: 1.1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  /* La card de Ingresos siempre va al final ocupando full width en mobile
     (es el 9°, impar). Como tiene espacio sobrado, dejamos el valor más
     grande y sin truncar. */
  .kpi.kpi-ingresos .value {
    font-size: 32px;
    white-space: normal;
    text-overflow: clip;
    overflow: visible;
  }
  .kpi .delta { font-size: 11px; overflow-wrap: break-word; }
  /* Si la cantidad total es impar, el último kpi cae solo en su fila → full width */
  .kpi-grid .kpi:last-child:nth-child(odd) { grid-column: span 12; }
}

/* Dashboard two-column */
.dash-grid {
  margin-top: 20px;
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
  gap: 20px;
}
@media (max-width: 1100px) { .dash-grid { grid-template-columns: minmax(0, 1fr); } }

/* Activity list */
.activity-list { display: flex; flex-direction: column; gap: 2px; }
.activity {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 12px;
  border-radius: 14px;
  transition: background var(--t-fast);
}
.activity:hover { background: var(--bg); }
.activity .dot {
  width: 40px; height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--red-soft);
  color: var(--red);
}
.activity .dot.dark { background: var(--ink); color: #fff; }
.activity .dot.green { background: var(--green-soft); color: var(--green); }
.activity .dot.amber { background: var(--amber-soft); color: var(--amber); }
.activity .info { flex: 1; min-width: 0; }
.activity .info b { display: block; font-weight: 600; font-size: 14px; }
.activity .info span { font-size: 12px; color: var(--text-soft); }
.activity .time { font-size: 12px; color: var(--text-muted); white-space: nowrap; }

/* Quick actions grid — auto-fit: si solo cabe 1 card por fila (sidebar+col
   derecha estrecha), se vuelve 1 columna. Min de 200px protege contra
   palabras rotas verticalmente. */
.quick-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 12px;
}
.qa {
  padding: 18px;
  background: var(--surface-2);
  border-radius: var(--r-lg);
  display: flex;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  transition: transform var(--t-fast), background var(--t-fast);
  border: 1px solid var(--border);
  min-width: 0;
  overflow: hidden;
}
.qa > .icon-wrap { flex-shrink: 0; }
.qa > div:not(.icon-wrap) {
  flex: 1;
  min-width: 0;
}
.qa b {
  display: block;
  /* overflow-wrap: normal evita que se rompan palabras a la mitad.
     Las palabras largas tipo "Registrar" caben porque min-width del grid es 200px. */
  overflow-wrap: normal;
  overflow: hidden;
  text-overflow: ellipsis;
}
.qa span {
  display: block;
  font-size: 12px;
  color: var(--text-soft);
  overflow-wrap: normal;
}
.qa:hover { transform: translateY(-1px); background: var(--surface); border-color: var(--border-strong); }
.qa .icon-wrap {
  width: 40px; height: 40px;
  background: var(--ink);
  color: #fff;
  border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
}
.qa.red .icon-wrap { background: var(--red); }
.qa b { display: block; font-size: 14px; font-weight: 600; }
.qa span { font-size: 12px; color: var(--text-soft); }

/* ============================================================
   Tabla de datos
   ============================================================ */
.data-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
}
.data-table thead th {
  text-align: left;
  padding: 14px 16px;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-soft);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  border-bottom: 1px solid var(--border);
  background: transparent;
}
.data-table thead th.align-right { text-align: right; }
.data-table tbody td.align-right { text-align: right; }

.data-table.sortable .th-sort {
  cursor: pointer;
  user-select: none;
  transition: color var(--t-fast), background var(--t-fast);
}
.data-table.sortable .th-sort span { display: inline-block; vertical-align: middle; }
.data-table.sortable .th-sort .sort-ico {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px; height: 18px;
  margin-left: 4px;
  color: var(--text-muted);
  opacity: 0.55;
  transition: opacity var(--t-fast), color var(--t-fast), transform var(--t-fast);
  vertical-align: middle;
}
.data-table.sortable .th-sort .sort-ico svg { width: 14px; height: 14px; }
.data-table.sortable .th-sort:hover {
  color: var(--ink);
  background: var(--bg);
}
.data-table.sortable .th-sort:hover .sort-ico { opacity: 1; }
.data-table.sortable .th-sort.active {
  color: var(--red);
}
.data-table.sortable .th-sort.active .sort-ico {
  color: var(--red);
  opacity: 1;
}
.data-table.sortable .th-sort.align-right { text-align: right; }
.data-table.sortable .th-sort.align-right .sort-ico { margin-left: 4px; }

/* Selector de orden solo visible en móvil */
.select.mobile-sort { display: none; }
@media (max-width: 960px) {
  .select.mobile-sort { display: block; min-width: 220px; }
}
.data-table tbody td {
  padding: 16px;
  border-bottom: 1px solid var(--border);
  font-size: 14px;
  vertical-align: middle;
}
.data-table tbody tr {
  transition: background var(--t-fast);
  cursor: pointer;
}
.data-table tbody tr:hover { background: var(--bg); }
.data-table tbody tr:last-child td { border-bottom: none; }

.table-wrap {
  background: var(--surface);
  border-radius: var(--r-xl);
  overflow: hidden;
  padding: 6px 6px 0;
}

.table-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px 14px;
  flex-wrap: wrap;
}
.table-toolbar .filters { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }

.cell-user {
  display: flex;
  align-items: center;
  gap: 12px;
}
.cell-user .avatar {
  width: 38px; height: 38px;
  border-radius: 50%;
  background: var(--ink);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: -0.02em;
  flex-shrink: 0;
}
.cell-user .avatar.red { background: var(--red); }
.cell-user .avatar.gradient {
  background: linear-gradient(135deg, #1A1A20 0%, #E60013 120%);
}
.cell-user .info b { font-weight: 600; font-size: 14px; display: block; }
.cell-user .info span { font-size: 12px; color: var(--text-soft); }

/* Mobile card list (replaces table on small screens) */
.mobile-list { display: none; }
.mobile-item {
  background: var(--surface);
  border-radius: var(--r-lg);
  padding: 16px;
  margin-bottom: 10px;
  transition: transform var(--t-fast), box-shadow var(--t-fast);
}
.mobile-item:active { transform: scale(0.99); }

/* ============================================================
   Servicios grid (tarjetas seleccionables)
   ============================================================ */
.services-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 14px;
}
.service-card {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--r-lg);
  padding: 18px;
  cursor: pointer;
  transition: all var(--t-med) var(--ease-out);
  position: relative;
  overflow: hidden;
}
.service-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--brand-primary, var(--red)) 14%, transparent),
    transparent 60%);
  opacity: 0;
  transition: opacity var(--t-med);
  pointer-events: none;
}
.service-card:hover {
  border-color: var(--border-strong);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}
.service-card.selected {
  border-color: var(--brand-primary, var(--red));
  background: linear-gradient(180deg,
    color-mix(in srgb, var(--brand-primary, var(--red)) 6%, var(--surface)) 0%,
    var(--surface) 100%);
  box-shadow: 0 8px 28px color-mix(in srgb, var(--brand-primary, var(--red)) 18%, transparent);
}
.service-card.selected::before { opacity: 1; }
.service-card .head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 8px;
}
.service-card .title { font-weight: 700; font-size: 15px; letter-spacing: -0.01em; line-height: 1.25; }
.service-card .desc {
  font-size: 13px;
  color: var(--text-soft);
  line-height: 1.5;
  margin-bottom: 14px;
}
.service-card .price {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 1px dashed var(--border);
  padding-top: 12px;
}
.service-card .price b { font-size: 18px; font-weight: 700; letter-spacing: -0.02em; }
.service-card .price span { font-size: 11px; color: var(--text-soft); text-transform: uppercase; letter-spacing: 0.1em; }

.service-card .check {
  width: 28px; height: 28px;
  border-radius: 50%;
  border: 1.5px solid var(--border-strong);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--t-fast);
  flex-shrink: 0;
}
.service-card .check svg {
  width: 14px; height: 14px;
  color: transparent;
  transition: color var(--t-fast);
}
.service-card.selected .check {
  background: var(--brand-primary, var(--red));
  border-color: var(--brand-primary, var(--red));
}
.service-card.selected .check svg { color: #fff; }

/* Summary card */
.summary {
  background: var(--ink);
  color: #fff;
  border-radius: var(--r-xl);
  padding: 26px;
  position: sticky;
  top: calc(var(--topbar-h) + 12px);
}
.summary h3 { font-size: 18px; font-weight: 700; letter-spacing: -0.02em; }
.summary .line {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 0;
  font-size: 14px;
  color: rgba(255,255,255,0.72);
  border-bottom: 1px dashed rgba(255,255,255,0.12);
}
.summary .line b { color: #fff; font-weight: 600; }
.summary .line.total {
  font-size: 22px;
  color: #fff;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,0.16);
  border-bottom: none;
  margin-top: 6px;
}
.summary .line.total b { font-size: 26px; font-weight: 700; letter-spacing: -0.02em; }

/* Inputs embebidos en summary */
.summary .summary-input {
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.14);
  color: #fff;
  max-width: 140px;
  text-align: right;
  padding: 9px 12px;
  font-weight: 600;
}
.summary .summary-input:focus {
  border-color: rgba(255, 255, 255, 0.45);
  background: rgba(255, 255, 255, 0.12);
  box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.08);
}

/* Modo de cotización */
.pricing-modes {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin: 14px 0 16px;
}
.pm-btn {
  text-align: left;
  padding: 12px 14px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.72);
  cursor: pointer;
  transition: all var(--t-fast);
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.pm-btn:hover { background: rgba(255, 255, 255, 0.1); }
.pm-btn b { font-size: 13px; font-weight: 600; color: #fff; letter-spacing: -0.005em; }
.pm-btn span { font-size: 11px; line-height: 1.4; }
.pm-btn.active {
  background: var(--red);
  border-color: var(--red);
  color: rgba(255, 255, 255, 0.9);
}
.pm-btn.active b, .pm-btn.active span { color: #fff; }

/* Campo fecha con icono - premium custom */
.date-field {
  position: relative;
  display: flex;
  align-items: stretch;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  transition: border-color var(--t-fast), box-shadow var(--t-fast), background var(--t-fast);
  overflow: hidden;
}
.date-field:hover { border-color: var(--border-strong); }
.date-field:focus-within,
.date-field.open { border-color: var(--ink); box-shadow: 0 0 0 4px rgba(15,15,18,0.05); }
.date-field .date-ico {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  background: var(--red-softer);
  color: var(--red);
  pointer-events: none;
  flex-shrink: 0;
  border-right: 1px solid var(--border);
}
.date-field .date-ico svg { width: 18px; height: 18px; }
.date-field .date-trigger {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding: 13px 16px 13px 14px;
  background: transparent;
  border: none;
  cursor: pointer;
  font: inherit;
  color: var(--text);
  font-weight: 500;
  letter-spacing: -0.01em;
  text-align: left;
  min-width: 0;
}
.date-field .date-trigger .date-text {
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.date-field .date-trigger .date-text.is-placeholder { color: var(--text-muted); font-weight: 400; }
.date-field .date-trigger:focus { outline: none; }
.date-field .date-caret {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 12px;
  color: var(--text-muted);
  pointer-events: none;
  flex-shrink: 0;
  transition: transform var(--t-fast);
}
.date-field .date-caret svg { width: 14px; height: 14px; }
.date-field.open .date-caret { transform: rotate(180deg); }

/* ============================================================
   Date Picker · calendario flotante
   ============================================================ */
.date-picker {
  background: var(--surface);
  border-radius: var(--r-lg);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-lg);
  padding: 16px;
  min-width: 280px;
  max-width: 320px;
  z-index: 60;
  animation: scaleIn 200ms var(--ease-out);
  transform-origin: top left;
  font-family: var(--font-sans);
}
.date-picker .dp-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 12px;
}
.date-picker .dp-month {
  font-weight: 700;
  font-size: 14px;
  letter-spacing: -0.015em;
  text-transform: capitalize;
  flex: 1;
  text-align: center;
}
.date-picker .dp-nav {
  width: 32px;
  height: 32px;
  border-radius: 10px;
  background: var(--bg-soft);
  color: var(--ink);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background var(--t-fast), color var(--t-fast), transform var(--t-fast);
  cursor: pointer;
}
.date-picker .dp-nav:hover { background: var(--ink); color: #fff; }
.date-picker .dp-nav:active { transform: scale(0.94); }
.date-picker .dp-nav svg { width: 14px; height: 14px; }
.date-picker .dp-weekdays {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 2px;
  margin-bottom: 6px;
}
.date-picker .dp-weekdays span {
  text-align: center;
  font-size: 10px;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 0;
}
.date-picker .dp-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 2px;
}
.date-picker .dp-day {
  aspect-ratio: 1;
  min-height: 36px;
  border-radius: 10px;
  background: transparent;
  color: var(--text);
  font-size: 13px;
  font-weight: 500;
  font-variant-numeric: tabular-nums;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background var(--t-fast), color var(--t-fast), transform var(--t-fast);
}
.date-picker .dp-day:hover { background: var(--bg-soft); }
.date-picker .dp-day:active { transform: scale(0.94); }
.date-picker .dp-day.outside { color: var(--text-muted); opacity: 0.45; }
.date-picker .dp-day.today {
  color: var(--red);
  font-weight: 700;
  box-shadow: inset 0 0 0 1.5px var(--red-soft);
}
.date-picker .dp-day.selected {
  background: var(--red);
  color: #fff;
  font-weight: 700;
  box-shadow: 0 4px 14px rgba(230, 0, 19, 0.28);
}
.date-picker .dp-day.selected:hover { background: var(--red-600); }
.date-picker .dp-foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px dashed var(--border);
}
.date-picker .dp-btn {
  padding: 6px 12px;
  border-radius: var(--r-pill);
  font-size: 12px;
  font-weight: 600;
  color: var(--text-soft);
  transition: background var(--t-fast), color var(--t-fast);
  cursor: pointer;
}
.date-picker .dp-btn:hover { background: var(--bg-soft); color: var(--ink); }
.date-picker .dp-btn.dp-today { background: var(--ink); color: #fff; }
.date-picker .dp-btn.dp-today:hover { background: var(--ink-2); }

/* ============================================================
   Segmented control (Por días | Por fecha)
   ============================================================ */
.seg-field { display: flex; flex-direction: column; gap: 10px; }
.seg-tabs {
  display: inline-flex;
  padding: 3px;
  background: var(--bg-soft);
  border-radius: var(--r-pill);
  gap: 2px;
  align-self: flex-start;
}
.seg-tab {
  padding: 6px 14px;
  border-radius: var(--r-pill);
  font-size: 12px;
  font-weight: 600;
  color: var(--text-soft);
  transition: background var(--t-fast), color var(--t-fast);
  cursor: pointer;
}
.seg-tab:hover { color: var(--ink); }
.seg-tab.active {
  background: var(--ink);
  color: #fff;
}
.seg-panes { position: relative; }
.seg-pane[hidden] { display: none; }
.input-suffix {
  position: relative;
  display: flex;
  align-items: center;
}
.input-suffix .input { padding-right: 56px; }
.input-suffix .suffix-txt {
  position: absolute;
  right: 16px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-muted);
  pointer-events: none;
}

/* Servicio personalizado card dentro del form */
.custom-svc {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  background: linear-gradient(180deg, #FFF8F9 0%, #fff 100%);
  border: 1.5px solid var(--red);
  border-radius: var(--r-lg);
  box-shadow: 0 6px 18px rgba(230, 0, 19, 0.08);
}
.custom-svc .cs-ico {
  width: 36px; height: 36px;
  background: var(--red);
  color: #fff;
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.custom-svc .cs-body { flex: 1; min-width: 0; }
.custom-svc .cs-head { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.custom-svc .cs-head b { font-weight: 600; font-size: 14px; }
.custom-svc .cs-desc { font-size: 13px; color: var(--text-soft); margin-top: 2px; line-height: 1.45; }
.custom-svc .cs-price b { font-size: 15px; font-weight: 700; letter-spacing: -0.01em; }
@media (max-width: 640px) {
  .custom-svc { flex-wrap: wrap; }
  .custom-svc .cs-body { flex: 1 1 100%; order: 2; margin-left: 48px; margin-top: 2px; }
  .custom-svc .cs-price { order: 1; margin-left: auto; }
}

/* ============================================================
   Modal
   ============================================================ */
.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(15,15,18,0.52);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  animation: fadeIn var(--t-med) var(--ease-out);
}
.modal {
  background: var(--surface);
  border-radius: var(--r-xl);
  max-width: 640px;
  width: 100%;
  max-height: 92vh;
  overflow-y: auto;
  animation: scaleIn 320ms var(--ease-out);
  box-shadow: var(--shadow-lg);
}
.modal.modal-wide { max-width: 960px; }
.modal .modal-head {
  padding: 24px 28px 12px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.modal .modal-head h3 {
  font-size: 22px; font-weight: 700;
  letter-spacing: -0.025em;
}
.modal .modal-head .sub {
  color: var(--text-soft);
  font-size: 13px;
  margin-top: 4px;
}
.modal .modal-body { padding: 12px 28px; }
.modal .modal-foot {
  padding: 16px 28px 24px;
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  border-top: 1px solid var(--border);
  margin-top: 20px;
}

/* ============================================================
   Toasts
   ============================================================ */
.toast-stack {
  position: fixed;
  right: 24px;
  bottom: 24px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  z-index: 100;
  max-width: calc(100vw - 48px);
}
.toast {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 18px 12px 14px;
  background: var(--ink);
  color: #fff;
  border-radius: var(--r-pill);
  box-shadow: var(--shadow-dark);
  font-size: 13px;
  font-weight: 500;
  animation: slideInRight 360ms var(--ease-out);
}
.toast .icon-wrap {
  width: 24px; height: 24px;
  border-radius: 50%;
  background: var(--red);
  display: flex; align-items: center; justify-content: center;
}
.toast.success .icon-wrap { background: var(--green); }
.toast.closing { animation: fadeOutRight 240ms var(--ease-out) forwards; }
@keyframes fadeOutRight {
  to { opacity: 0; transform: translateX(20px); }
}

/* ============================================================
   Empty state
   ============================================================ */
.empty {
  padding: 60px 24px;
  text-align: center;
}
.empty .illus {
  width: 72px; height: 72px;
  background: var(--bg-soft);
  color: var(--text-muted);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 18px;
}
.empty h3 { font-size: 18px; font-weight: 700; }
.empty p { color: var(--text-soft); font-size: 14px; margin-top: 6px; }
.empty .actions { margin-top: 20px; display: flex; gap: 10px; justify-content: center; }

/* ============================================================
   Login
   ============================================================ */
.login-shell {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  background: var(--surface);
  overflow: hidden;
}
.login-left {
  padding: 48px 60px;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}
.login-brand {
  display: flex;
  align-items: center;
  gap: 12px;
}
.login-brand img { width: 44px; height: 44px; }
.login-brand b { font-size: 18px; font-weight: 700; letter-spacing: -0.02em; }
.login-brand span { font-size: 11px; color: var(--text-soft); display: block; text-transform: uppercase; letter-spacing: 0.14em; }

.login-form-wrap {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  max-width: 420px;
  width: 100%;
}
.login-form-wrap h1 {
  font-size: 40px;
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 1.1;
}
.login-form-wrap .sub {
  color: var(--text-soft);
  margin-top: 10px;
  font-size: 15px;
}
.login-form { margin-top: 32px; display: flex; flex-direction: column; gap: 16px; }
.login-foot {
  margin-top: 32px;
  color: var(--text-muted);
  font-size: 12px;
}

.login-right {
  background: var(--ink);
  color: #fff;
  position: relative;
  overflow: hidden;
  padding: 48px;
  display: flex;
  align-items: flex-end;
}
.login-right::before {
  content: "";
  position: absolute;
  top: -140px; right: -140px;
  width: 480px; height: 480px;
  background: radial-gradient(circle, color-mix(in srgb, var(--brand-primary, var(--red)) 90%, transparent), transparent 70%);
  border-radius: 50%;
  filter: blur(2px);
  animation: floatSoft 8s var(--ease-in-out) infinite;
}
.login-right::after {
  content: "";
  position: absolute;
  bottom: -200px; left: -120px;
  width: 420px; height: 420px;
  background: radial-gradient(circle, color-mix(in srgb, var(--brand-primary, var(--red)) 45%, transparent), transparent 70%);
  border-radius: 50%;
  animation: floatSoft 10s var(--ease-in-out) infinite reverse;
}
.login-hero {
  position: relative;
  z-index: 2;
  max-width: 440px;
}
.login-hero .chip-dark {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  border-radius: var(--r-pill);
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.16);
  font-size: 12px;
  font-weight: 500;
  color: rgba(255,255,255,0.85);
  backdrop-filter: blur(10px);
}
.login-hero h2 {
  font-size: 42px;
  font-weight: 700;
  letter-spacing: -0.035em;
  margin-top: 18px;
  line-height: 1.1;
}
.login-hero p { margin-top: 14px; font-size: 15px; color: rgba(255,255,255,0.72); line-height: 1.55; }

.login-hero .mini-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 32px;
}
.login-hero .mini-card {
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: var(--r-lg);
  padding: 16px;
  backdrop-filter: blur(14px);
}
.login-hero .mini-card b { font-size: 26px; font-weight: 700; letter-spacing: -0.03em; }
.login-hero .mini-card span { display: block; font-size: 12px; color: rgba(255,255,255,0.65); margin-top: 4px; }

@media (max-width: 980px) {
  .login-shell { grid-template-columns: 1fr; }
  .login-right { display: none; }
  .login-left { padding: 32px 24px; }
}

/* ============================================================
   Detalle cliente / proyecto
   ============================================================ */
.detail-hero {
  /* Decoración movida a background-image (radial-gradient) en lugar de un
     pseudo-elemento absolute con offsets negativos: no contribuye al
     scrollWidth ni se revela al hacer zoom out en mobile. */
  background:
    radial-gradient(
      circle at calc(100% + 60px) -60px,
      color-mix(in srgb, var(--brand-primary, var(--red)) 6%, transparent),
      transparent 280px
    ),
    var(--surface);
  border-radius: var(--r-xl);
  padding: 28px;
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 20px;
  position: relative;
  overflow: hidden;
  /* Garantías de ancho: sin estos, en algunos browsers móviles el flex
     container colapsa a fit-content cuando se hace zoom out. */
  width: 100%;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
}
.detail-hero .avatar {
  width: 72px; height: 72px;
  border-radius: 24px;
  background: linear-gradient(135deg, var(--ink), var(--brand-primary, var(--red)));
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700;
  font-size: 28px;
  letter-spacing: -0.04em;
  flex-shrink: 0;
  box-shadow: var(--shadow-md);
}
.detail-hero h2 { font-size: 26px; font-weight: 700; letter-spacing: -0.03em; word-break: break-word; }
.detail-hero .flex-1 { min-width: 0; }
.detail-hero .sub { color: var(--text-soft); font-size: 14px; margin-top: 6px; display: flex; align-items: center; gap: 12px; flex-wrap: wrap; min-width: 0; }
.detail-hero .sub > * { max-width: 100%; min-width: 0; }
.detail-hero .actions { margin-left: auto; display: flex; gap: 10px; flex-wrap: wrap; }

.detail-grid {
  display: grid;
  /* minmax(0, ...) en lugar de '2fr 1fr' / '1fr' previene que un hijo con
     contenido largo (h2, palabras sin breaks) expanda la columna más allá
     del padre — bug visible al hacer zoom out en mobile. */
  grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
  gap: 20px;
}
@media (max-width: 1100px) {
  .detail-grid { grid-template-columns: minmax(0, 1fr); }
}

.kv-list { display: grid; grid-template-columns: 1fr 1fr; gap: 8px 20px; }
.kv {
  display: flex;
  flex-direction: column;
  padding: 12px 0;
  border-bottom: 1px dashed var(--border);
}
.kv span { font-size: 12px; color: var(--text-soft); text-transform: uppercase; letter-spacing: 0.06em; font-weight: 600; }
.kv b { font-size: 15px; margin-top: 4px; font-weight: 600; }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 960px) {
  .app-shell { grid-template-columns: 1fr; }
  .sidebar {
    position: fixed;
    left: 0; top: 0;
    width: var(--sidebar-w);
    transform: translateX(-100%);
    transition: transform var(--t-med) var(--ease-out);
    box-shadow: var(--shadow-lg);
    padding-top: 16px;
  }
  .sidebar.open { transform: translateX(0); }
  .menu-trigger { display: inline-flex; }
  /* Topbar de 2 filas en móvil: header cohesivo con search adentro */
  .topbar {
    padding: calc(14px + env(safe-area-inset-top, 0px)) 16px 16px;
    height: auto;
    min-height: auto;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px 10px;
    background: var(--surface);
    border-bottom: 1px solid var(--border);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }
  .topbar.scrolled { box-shadow: 0 2px 12px rgba(0,0,0,0.04); }
  .topbar > .stack-h.gap-12 { display: contents; }
  .topbar #menuTrigger { order: 1; }
  .topbar-actions { order: 2; margin-left: auto; }
  .topbar .search {
    order: 3;
    flex: 0 0 100%;
    width: 100%;
    max-width: none;
    min-width: 0;
    margin: 0;
  }
  /* Search dentro del header: input con fondo sutil para destacar sin romper continuidad */
  .topbar .search .input {
    background: var(--bg);
    border-color: transparent;
  }
  .topbar .search .input:focus {
    background: var(--surface);
    border-color: color-mix(in srgb, var(--brand-primary, var(--red)) 35%, var(--border));
  }
  .content { padding: 24px 16px 100px; }
  .sidebar-scrim.show { display: block; }
  .page-head h1 { font-size: 26px; }
  .data-table { display: none; }
  .mobile-list { display: block; }
  .table-toolbar { padding: 14px 12px; }
  .detail-hero {
    flex-direction: column;
    align-items: flex-start;
    padding: 22px;
    gap: 14px;
  }
  .detail-hero .avatar { width: 56px; height: 56px; font-size: 22px; border-radius: 18px; }
  .detail-hero h2 { font-size: 22px; }
  .detail-hero .sub { gap: 8px; row-gap: 6px; }
  .detail-hero .sub > * { word-break: break-word; max-width: 100%; }
  .detail-hero .actions { margin-left: 0; width: 100%; display: flex; gap: 8px; flex-wrap: wrap; }
  .detail-hero .actions .btn { flex: 1 1 auto; justify-content: center; }
  .summary { position: static; }
  .kv-list { grid-template-columns: 1fr; }
  .quick-grid { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .page-head h1 { font-size: 24px; }
  .kpi .value { font-size: 32px; }
  .card { padding: 18px; border-radius: 20px; }
  .card-loose { padding: 22px; border-radius: 22px; }
  .detail-hero { padding: 18px; border-radius: 20px; }
  .detail-hero .actions .btn { flex: 1 1 100%; }
  /* No pisar el padding del topbar móvil definido en @media 720px */
  .content { padding: 24px 14px 100px; }
  .kv-list { gap: 0; }
  .summary { padding: 22px; border-radius: 22px; }
}

/* ============================================================
   BRAND SWITCHER (topbar) + BRAND MENU (popover)
   ============================================================ */
.brand-switch { display: inline-flex; align-items: center; }

.brand-pill {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px 6px 6px;
  border-radius: var(--r-pill);
  background: var(--surface-2);
  border: 1px solid color-mix(in srgb, var(--brand-primary, var(--red)) 25%, var(--border));
  color: var(--brand-primary, var(--text));
  font-size: 13px; font-weight: 600;
  cursor: pointer;
  transition: background var(--t-fast) var(--ease-out), border-color var(--t-fast);
  max-width: 220px;
}
.brand-pill:hover {
  background: color-mix(in srgb, var(--brand-primary, var(--red)) 6%, var(--surface-2));
  border-color: color-mix(in srgb, var(--brand-primary, var(--red)) 50%, var(--border));
}
.brand-pill img { width: 24px; height: 24px; border-radius: 6px; object-fit: cover; background: var(--bg); }
.brand-pill .icon { width: 14px; height: 14px; color: var(--text-soft); margin-left: 2px; }
.brand-pill-label {
  max-width: 130px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.brand-pill-initials {
  display: inline-flex; align-items: center; justify-content: center;
  width: 24px; height: 24px; border-radius: 6px;
  background: var(--red); color: #fff;
  font-size: 11px; font-weight: 700; letter-spacing: -0.02em;
  flex-shrink: 0;
}
.brand-pill-empty {
  border-style: dashed;
  color: var(--text-soft);
}
.brand-pill-empty .icon { width: 18px; height: 18px; }

@media (max-width: 720px) {
  .brand-pill .brand-pill-label { display: none; }
  .brand-pill { padding: 6px; }
}

.brand-menu {
  position: absolute;
  z-index: 200;
  max-width: calc(100vw - 24px);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-lg);
  padding: 6px;
  animation: brandMenuIn 140ms var(--ease-out);
}
@keyframes brandMenuIn { from { opacity: 0; transform: translateY(-6px) scale(0.98); } to { opacity: 1; transform: translateY(0) scale(1); } }

.brand-menu-head {
  font-size: 11px; font-weight: 700; color: var(--text-muted);
  letter-spacing: 0.04em; text-transform: uppercase;
  padding: 8px 10px 6px;
}
.brand-menu-sep { height: 1px; background: var(--border); margin: 4px 0; }
.brand-opt {
  display: flex; align-items: center; gap: 10px;
  width: 100%;
  padding: 8px 10px;
  background: transparent;
  border: 0;
  border-radius: 10px;
  color: var(--text);
  cursor: pointer;
  text-align: left;
  font-size: 13px;
  text-decoration: none;
  transition: background var(--t-fast);
}
.brand-opt:hover { background: var(--bg-soft); }
.brand-opt.is-active { background: var(--red-softer); color: var(--red-700); }
.brand-opt img { width: 28px; height: 28px; border-radius: 7px; object-fit: cover; background: var(--bg); }
.brand-opt .brand-pill-initials { width: 28px; height: 28px; border-radius: 7px; font-size: 12px; }
.brand-opt-label { flex: 1; display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.brand-opt-label b { font-weight: 600; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.brand-opt-meta { font-size: 11px; color: var(--text-muted); font-weight: 500; }
.brand-opt .icon { width: 16px; height: 16px; color: currentColor; margin-left: auto; }
.brand-opt-action { color: var(--text-soft); font-weight: 500; }
.brand-opt-action:hover { color: var(--text); }

/* Hero del detalle de propuesta — siempre oscuro, glow con color de marca */
.prop-hero {
  background: linear-gradient(180deg, #0E0E12 0%, #15151C 100%);
  color: #fff;
  border-radius: 24px;
  padding: 32px;
  margin: -8px -8px 24px;
  position: relative;
  overflow: hidden;
}
.prop-hero-glow {
  position: absolute;
  top: -80px; right: -80px;
  width: 280px; height: 280px;
  background: radial-gradient(circle, color-mix(in srgb, var(--brand-primary, #E60013) 70%, transparent), transparent 70%);
  border-radius: 50%;
  pointer-events: none;
}
.prop-hero-glow::after {
  content: "";
  position: absolute;
  inset: -40px;
  background: radial-gradient(circle, color-mix(in srgb, var(--brand-primary, #E60013) 22%, transparent), transparent 70%);
  border-radius: 50%;
}
.prop-hero-inner { position: relative; z-index: 2; }
.prop-hero-badge {
  background: rgba(255,255,255,0.1) !important;
  color: #fff !important;
  border: 1px solid rgba(255,255,255,0.16);
}
.prop-hero-title {
  font-size: 32px; font-weight: 700; letter-spacing: -0.03em;
  margin: 12px 0 0; line-height: 1.15;
  color: #fff;
}
.prop-hero-lead {
  color: rgba(255,255,255,0.7);
  margin: 10px 0 0;
  max-width: 620px;
}

/* Empty state inline (b + span) */
.empty-state {
  display: flex; flex-direction: column; gap: 6px;
  align-items: center;
  text-align: center;
  padding: 40px 20px;
  background: var(--surface-2);
  border: 1px dashed var(--border);
  border-radius: var(--r-md);
  color: var(--text-muted);
}
.empty-state b { display: block; font-size: 15px; color: var(--text); font-weight: 700; }
.empty-state span { display: block; font-size: 13px; max-width: 420px; line-height: 1.5; }

/* Brief card rows (lista admin de briefs) */
.brief-card-row {
  display: grid;
  grid-template-columns: minmax(120px, auto) 1fr auto auto;
  gap: 14px;
  align-items: center;
  padding: 14px 16px;
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  text-decoration: none;
  color: var(--text);
  transition: all var(--t-fast);
}
.brief-card-row:hover { background: var(--bg-soft); border-color: var(--border-strong); transform: translateX(2px); }
.brief-card-row .bcr-id { display: flex; flex-direction: column; gap: 2px; }
.brief-card-row .bcr-id b { font-family: monospace; font-size: 13px; color: var(--red-700); letter-spacing: 0.02em; }
.brief-card-row .bcr-id span { font-size: 11px; color: var(--text-muted); }
.brief-card-row .bcr-body { min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.brief-card-row .bcr-body b { font-size: 14px; }
.brief-card-row .bcr-body span { font-size: 12px; color: var(--text-muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.brief-card-row .bcr-meta { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.brief-card-row .icon { color: var(--text-muted); flex-shrink: 0; }
@media (max-width: 720px) {
  .brief-card-row { grid-template-columns: 1fr; gap: 8px; }
  .brief-card-row .icon { display: none; }
}

.text-mono { font-family: monospace; }

/* Tabs (Ajustes) */
.tabs {
  display: flex;
  gap: 4px;
  border-bottom: 1px solid var(--border);
  margin: 0 0 18px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.tab {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 14px;
  border-radius: 10px 10px 0 0;
  color: var(--text-soft);
  text-decoration: none;
  font-weight: 600; font-size: 13px;
  transition: color var(--t-fast), background var(--t-fast);
  border-bottom: 2px solid transparent;
  white-space: nowrap;
}
.tab:hover { background: var(--bg-soft); color: var(--text); }
.tab.active { color: var(--brand-primary, var(--red)); border-bottom-color: var(--brand-primary, var(--red)); }
.tab .icon { width: 16px; height: 16px; }

/* En mobile: grid 2 columnas (sin scroll horizontal). Las tabs se acomodan
   en múltiples filas dentro del viewport. */
@media (max-width: 700px) {
  .tabs {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px;
    border-bottom: 0;
    overflow-x: visible;
    background: var(--bg-soft);
    padding: 6px;
    border-radius: 14px;
  }
  .tab {
    justify-content: center;
    padding: 11px 10px;
    border-radius: 10px;
    background: transparent;
    border-bottom: 0;
    white-space: normal;
    text-align: center;
    line-height: 1.2;
    min-width: 0;
  }
  .tab span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .tab.active {
    background: var(--surface);
    color: var(--brand-primary, var(--red));
    border-bottom: 0;
    box-shadow: 0 1px 3px rgba(0,0,0,0.06);
  }
}

/* Marcas */
.brand-row {
  display: flex; align-items: center; gap: 14px;
  padding: 12px 14px;
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
}
.brand-row img { width: 36px; height: 36px; border-radius: 9px; object-fit: cover; background: var(--bg); flex-shrink: 0; }
.brand-row-body { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.brand-row-body b { font-size: 14px; }
.brand-row-body span { font-size: 12px; color: var(--text-muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.brand-row-actions { display: flex; gap: 6px; flex-shrink: 0; }
.brand-reorder {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex-shrink: 0;
  margin-right: 4px;
}
.brand-reorder .btn-icon {
  width: 28px;
  height: 22px;
  border-radius: 7px;
  padding: 0;
  background: var(--bg-soft);
  border: 1px solid var(--border);
}
.brand-reorder .btn-icon:hover:not(:disabled) {
  background: var(--brand-primary, var(--red));
  border-color: var(--brand-primary, var(--red));
  color: #fff;
}
.brand-reorder .btn-icon:disabled {
  opacity: 0.35;
  cursor: not-allowed;
}
.brand-reorder .btn-icon svg { width: 14px; height: 14px; }
@media (max-width: 600px) {
  .brand-reorder { flex-direction: row; }
}

/* Form de marca */
.brand-form-section {
  padding: 16px;
  background: var(--bg-soft);
  border-radius: var(--r-md);
  border: 1px solid var(--border);
}
.brand-form-section h4 {
  margin: 0 0 12px;
  font-size: 13px; font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase; letter-spacing: 0.05em;
}
.color-input {
  width: 44px; height: 38px; padding: 4px;
  border: 1px solid var(--border); border-radius: 8px;
  background: transparent; cursor: pointer;
  flex-shrink: 0;
}

/* Logo upload widget */
.logo-upload {
  display: flex; flex-direction: column; gap: 8px;
  padding: 12px;
  background: var(--surface);
  border: 1px dashed var(--border-strong);
  border-radius: var(--r-md);
}
.logo-preview {
  display: flex; align-items: center; justify-content: center;
  height: 90px; border-radius: 10px;
  border: 1px solid var(--border);
  overflow: hidden;
}
.logo-preview img { max-width: 80%; max-height: 80%; object-fit: contain; }
.logo-preview-square {
  aspect-ratio: 1 / 1;
  height: auto;
  width: 100%;
  max-width: 160px;
  margin: 0 auto;
}
.logo-preview-square img { aspect-ratio: 1 / 1; object-fit: contain; }
.logo-actions { display: flex; gap: 6px; flex-wrap: wrap; }

/* Brief field row (campos personalizados) */
.brand-field-row {
  display: grid;
  grid-template-columns: 1fr 1fr auto auto;
  gap: 8px;
  align-items: center;
}
@media (max-width: 720px) {
  .brand-field-row { grid-template-columns: 1fr 1fr; }
  .brand-field-row label, .brand-field-row [data-del] { grid-column: span 1; }
}

/* Banner que muestra la marca asignada (heredada de la activa) */
.brand-lock-banner {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 14px;
  background: color-mix(in srgb, var(--brand-primary, var(--red)) 8%, var(--surface-2));
  border: 1px solid color-mix(in srgb, var(--brand-primary, var(--red)) 30%, var(--border));
  border-radius: 12px;
  margin-bottom: 8px;
}
.brand-lock-banner .icon { width: 18px; height: 18px; color: var(--brand-primary, var(--red)); flex-shrink: 0; }
.brand-lock-banner b { display: block; font-size: 13px; color: var(--text); font-weight: 700; }
.brand-lock-banner span { display: block; font-size: 12px; color: var(--text-muted); margin-top: 2px; }

/* Selector bloqueado (marca heredada del cliente) */
.select.is-locked, .input.is-locked {
  background: var(--bg-soft);
  color: var(--text-soft);
  cursor: not-allowed;
  border-style: dashed;
}
.marca-lock-note {
  display: inline-flex; align-items: center; gap: 6px;
}
.marca-lock-note .icon { width: 12px; height: 12px; color: var(--text-muted); }

/* Servicio marcado como "incluido por defecto en briefs" */
.service-card.is-default { border-color: var(--brand-primary, var(--red)); }
.srv-default-tag {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: 10px;
  padding: 5px 10px;
  border-radius: var(--r-pill);
  background: var(--red-softer);
  color: var(--red-700);
  font-size: 11px; font-weight: 600;
}
.srv-default-tag .icon { width: 12px; height: 12px; }

/* Override de precio en el formulario de proyecto */
.service-card.has-override .price b { color: var(--red-700); }
.override-area {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px dashed var(--border);
}
.override-label {
  font-size: 11px; font-weight: 600; color: var(--text-muted);
  letter-spacing: 0.04em; text-transform: uppercase;
  display: block; margin-bottom: 6px;
}
.override-row {
  display: flex; align-items: center; gap: 6px;
  position: relative;
}
.override-prefix {
  font-size: 13px; color: var(--text-soft); font-weight: 600;
}
.override-input {
  flex: 1;
  padding: 8px 12px;
  font-size: 13px;
}
.override-reset { flex-shrink: 0; }
.override-hint {
  display: block; font-size: 10.5px; color: var(--text-muted);
  margin-top: 6px;
}

/* Brand chip — etiqueta inline con color de la marca (variable --c) */
.brand-chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 2px 8px;
  border-radius: var(--r-pill);
  background: color-mix(in srgb, var(--c, var(--red)) 10%, var(--surface));
  color: var(--c, var(--red));
  font-size: 11.5px; font-weight: 600;
  line-height: 1.4;
  white-space: nowrap;
}
.brand-chip::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--c, var(--red));
}

/* Flash visual cuando un input de precio se ha capeado al máximo permitido */
.price-input input.price-capped {
  background: color-mix(in srgb, var(--amber-soft) 60%, transparent);
  transition: background 0.4s ease-out;
}

/* Botón guardar duplicado del formulario de proyecto: solo en mobile */
.form-save-mobile {
  display: none;
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px solid var(--border);
  gap: 10px;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
}
.form-save-mobile .btn { flex: 1 1 auto; justify-content: center; }
@media (max-width: 960px) {
  /* En mobile mostramos el panel inferior. La barra superior tiene los mismos
     botones; el inferior es para no tener que hacer scroll arriba. */
  .form-save-mobile { display: flex; }
}

/* ============================================================
   Mobile overflow defensivo — fuerza que cards y flex items respeten
   su contenedor en Safari iOS y al hacer zoom out. Estos fixes son
   defensivos porque min-width:auto (default de flex items) puede
   empujar al padre más allá del viewport con contenido largo.
   ============================================================ */
@media (max-width: 960px) {
  /* Cards no pueden ser más anchos que su padre */
  .card,
  .summary,
  .payments-panel,
  .active-clients-card,
  .dash-chart-card,
  .detail-hero,
  .table-wrap {
    min-width: 0;
    max-width: 100%;
    box-sizing: border-box;
  }
  /* Flex containers genéricos: permitir que se contraigan */
  .stack-h, .stack-v {
    min-width: 0;
  }
  /* Items de servicios incluidos (HTML con stack-h.gap-12 inline-styled) */
  .card .stack-h.gap-12,
  .card .stack-h.gap-12 > * {
    min-width: 0;
  }
  /* Romper SOLO palabras realmente largas (URLs, IDs) sin partir palabras
     normales. overflow-wrap: break-word respeta los espacios; word-break:
     break-word (que tenía antes) era demasiado agresivo y rompía carácter
     por carácter cuando el contenedor era muy estrecho. */
  .card .text-sm,
  .card .text-soft,
  .detail-hero h2,
  .conf-text,
  p {
    overflow-wrap: break-word;
  }
  /* Section heads con título largo */
  .section-head, .section-head > div {
    min-width: 0;
  }
  .section-head h2 {
    overflow-wrap: break-word;
  }
  /* Items con botones al final (ej: propuestaRowHTML): los botones bajan a
     la siguiente línea si no caben, en lugar de comprimir el texto. */
  .card .stack-h.gap-12 {
    flex-wrap: wrap;
  }
  .card .stack-h.gap-12 > .stack-h.gap-8 {
    flex-wrap: wrap;
  }
}

/* Print styles */
@media print {
  .sidebar, .topbar, .no-print { display: none !important; }
  .content { padding: 0; }
  body { background: #fff; }
}

/* ============================================================
   Filas de tareas en detalle de cliente
   ============================================================ */
.cli-task-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--surface);
  cursor: pointer;
  transition: background var(--t-fast), border-color var(--t-fast);
}
.cli-task-row:hover { background: var(--bg-soft); border-color: var(--border-strong); }
.cli-task-row.is-overdue { border-color: color-mix(in srgb, var(--brand-primary, var(--red)) 35%, var(--border)); }
.cli-task-row.is-done { opacity: 0.6; }
.cli-task-row.is-done .cli-task-body b { text-decoration: line-through; }
.cli-task-check {
  flex-shrink: 0;
  width: 26px; height: 26px;
  border-radius: 50%;
  border: 2px solid var(--border);
  background: var(--surface);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: transparent;
  transition: all var(--t-fast);
}
.cli-task-check:hover { border-color: var(--brand-primary, var(--red)); }
.cli-task-row.is-done .cli-task-check {
  background: var(--green);
  border-color: var(--green);
  color: #fff;
}
.cli-task-check svg { width: 14px; height: 14px; }
.cli-task-body { flex: 1; min-width: 0; }
.cli-task-body b { display: block; font-size: 14px; font-weight: 600; }
.cli-task-body span { display: block; font-size: 12px; color: var(--text-muted); margin-top: 2px; }

/* ============================================================
   Notificaciones (campanita)
   ============================================================ */
.notif-bell { position: relative; }
.notif-badge {
  position: absolute;
  top: 4px; right: 4px;
  min-width: 16px; height: 16px;
  padding: 0 4px;
  border-radius: 999px;
  background: var(--text-muted);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  line-height: 16px;
  text-align: center;
  pointer-events: none;
  border: 1.5px solid var(--surface);
  box-sizing: content-box;
}
.notif-badge.is-danger {
  background: var(--brand-primary, var(--red));
  animation: notifPulse 2s ease-in-out infinite;
}
@keyframes notifPulse {
  0%, 100% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--brand-primary, var(--red)) 50%, transparent); }
  50% { box-shadow: 0 0 0 5px color-mix(in srgb, var(--brand-primary, var(--red)) 0%, transparent); }
}

.notif-panel {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  z-index: 95;
  width: min(380px, calc(100vw - 24px));
  max-height: min(70vh, 540px);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  animation: fadeInDown 180ms var(--ease-out);
  /* Reset crítico: el panel está anclado dentro del botón <button class="notif-bell">,
     y los botones heredan white-space: nowrap por user agent. Si no lo reseteamos,
     los títulos largos NO hacen wrap y desbordan el panel. */
  white-space: normal;
  text-align: left;
  cursor: default;
  font-family: inherit;
}
.notif-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
}
.notif-head b { font-size: 14px; display: block; }
.notif-head .notif-sub {
  display: block;
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 2px;
}
.notif-close {
  border: 0;
  background: transparent;
  width: 28px; height: 28px;
  border-radius: 50%;
  color: var(--text-muted);
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
}
.notif-close:hover { background: var(--bg-soft); color: var(--text); }

.notif-empty {
  padding: 32px 16px;
  text-align: center;
  color: var(--text-muted);
}
.notif-empty-ico {
  width: 44px; height: 44px;
  margin: 0 auto 10px;
  border-radius: 50%;
  background: var(--green-soft);
  color: var(--green);
  display: flex; align-items: center; justify-content: center;
}
.notif-empty b { display: block; font-size: 14px; color: var(--text); margin-bottom: 4px; }
.notif-empty span { font-size: 12px; }

.notif-list {
  overflow-y: auto;
  /* overflow-x: hidden previene barra horizontal aunque el contenido intente
     desbordar; combinado con max-width:100% en items y body. */
  overflow-x: hidden;
  max-height: 460px;
  padding: 6px;
}
.notif-item {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 12px 12px 14px;
  border-radius: 10px;
  cursor: pointer;
  transition: background var(--t-fast);
  border-left: 3px solid transparent;
  margin-bottom: 2px;
  /* Garantía de que el item no expande el panel cuando el título es largo */
  min-width: 0;
  max-width: 100%;
}
.notif-item:hover { background: var(--bg-soft); }
.notif-item.notif-sev-danger { border-left-color: var(--brand-primary, var(--red)); }
.notif-item.notif-sev-warn { border-left-color: var(--amber); }
.notif-item.notif-sev-info { border-left-color: var(--blue); }

.notif-ico {
  flex-shrink: 0;
  width: 32px; height: 32px;
  border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  background: var(--bg-soft);
  color: var(--text-soft);
}
.notif-sev-danger .notif-ico {
  background: color-mix(in srgb, var(--brand-primary, var(--red)) 14%, transparent);
  color: var(--brand-primary, var(--red));
}
.notif-sev-warn .notif-ico {
  background: var(--amber-soft);
  color: var(--amber);
}
.notif-sev-info .notif-ico {
  background: var(--blue-soft);
  color: var(--blue);
}
/* Sobrescribe regla .input-icon .icon que afecta SVGs cuando el bell está
   dentro de un wrapper con position:relative — defensivo */
.notif-panel .notif-ico svg {
  position: static !important;
  transform: none !important;
  width: 16px !important;
  height: 16px !important;
  color: inherit !important;
}
.notif-body { flex: 1; min-width: 0; max-width: 100%; }
.notif-line {
  /* Cambio crítico: layout vertical (column) en lugar de row, para que el badge
     "Pronto/Urgente" caiga DEBAJO del título cuando es largo. Eso elimina la
     barra horizontal y el contenido cortado. */
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 6px;
  min-width: 0;
}
.notif-line b {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  line-height: 1.3;
  /* Permite que el título se rompa en múltiples líneas si es muy largo */
  overflow-wrap: break-word;
  word-break: break-word;
  max-width: 100%;
}
.notif-sev {
  flex-shrink: 0;
  font-size: 9.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 2px 7px;
  border-radius: 999px;
  background: var(--bg-soft);
  color: var(--text-muted);
}
.notif-sev-danger .notif-sev {
  background: var(--brand-primary, var(--red));
  color: #fff;
}
.notif-sev-warn .notif-sev {
  background: var(--amber);
  color: #fff;
}
.notif-sev-info .notif-sev {
  background: var(--blue);
  color: #fff;
}
.notif-sub2 {
  display: block;
  font-size: 11.5px;
  color: var(--text-muted);
  margin-top: 3px;
  overflow-wrap: break-word;
  word-break: break-word;
  max-width: 100%;
}
.notif-task-done {
  flex-shrink: 0;
  width: 32px; height: 32px;
  border: 1px solid var(--border);
  background: var(--surface);
  border-radius: 50%;
  color: var(--text-muted);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--t-fast);
  align-self: center;
}
.notif-task-done:hover {
  background: var(--green);
  border-color: var(--green);
  color: #fff;
}
.notif-task-done svg {
  width: 16px !important;
  height: 16px !important;
  position: static !important;
  transform: none !important;
}

/* En mobile el panel se renderiza como hijo directo de <body> (ver app.js)
   con la clase .is-mobile, fuera del .notif-bell. Esto evita que herede el
   flujo del topbar y elimina el "salto" inicial de la animación.

   Anclado debajo del topbar (top:70px) y bordes de 8px con animación
   suave desde arriba. */
.notif-panel.is-mobile {
  position: fixed;
  top: 70px;
  right: 8px;
  left: 8px;
  bottom: auto;
  width: auto;
  max-width: none;
  max-height: calc(100vh - 90px);
  transform-origin: top center;
  animation: notifDropIn 220ms var(--ease-out);
}
@keyframes notifDropIn {
  from { opacity: 0; transform: translateY(-8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ============================================================
   Dropdown de búsqueda global (Cmd+K)
   ============================================================ */
.topbar .search { position: relative; }
.global-search-dropdown {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  z-index: 90;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-lg);
  padding: 6px;
  max-height: min(70vh, 460px);
  overflow-y: auto;
  animation: fadeInDown 160ms var(--ease-out);
}
.global-search-dropdown .gsd-empty {
  padding: 20px 14px;
  color: var(--text-muted);
  font-size: 13px;
  text-align: center;
}
.global-search-dropdown .gsd-group-title {
  padding: 10px 12px 6px;
  font-size: 11px;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.global-search-dropdown .gsd-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 10px;
  cursor: pointer;
  text-decoration: none;
  color: var(--text);
  transition: background var(--t-fast);
}
.global-search-dropdown .gsd-item:hover,
.global-search-dropdown .gsd-item.is-active {
  background: color-mix(in srgb, var(--brand-primary, var(--red)) 8%, var(--surface));
}
.global-search-dropdown .gsd-ico {
  flex-shrink: 0;
  width: 36px; height: 36px;
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  /* Fondo 100% del color de marca + icono blanco para máximo contraste */
  background: var(--brand-primary, var(--red));
  color: #fff;
}
/* Sobrescribe la regla .input-icon .icon (position:absolute) que afecta a los
   SVGs dentro del dropdown porque éste vive bajo .input-icon.search */
.global-search-dropdown .gsd-ico svg,
.global-search-dropdown .gsd-ico .icon {
  position: static !important;
  transform: none !important;
  top: auto !important;
  left: auto !important;
  width: 18px !important;
  height: 18px !important;
  color: #fff !important;
}
.global-search-dropdown .gsd-ico svg path,
.global-search-dropdown .gsd-ico svg circle,
.global-search-dropdown .gsd-ico svg line,
.global-search-dropdown .gsd-ico svg polyline,
.global-search-dropdown .gsd-ico svg polygon,
.global-search-dropdown .gsd-ico svg rect {
  stroke: #fff !important;
}
.global-search-dropdown .gsd-body {
  flex: 1;
  min-width: 0;
}
.global-search-dropdown .gsd-body b {
  display: block;
  font-size: 14px;
  font-weight: 600;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.global-search-dropdown .gsd-body span {
  display: block;
  font-size: 12px;
  color: var(--text-muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.global-search-dropdown .gsd-foot {
  padding: 10px 12px;
  margin-top: 4px;
  border-top: 1px solid var(--border);
  font-size: 11px;
  color: var(--text-muted);
  text-align: center;
}
.global-search-dropdown .gsd-foot b {
  display: inline-block;
  padding: 1px 6px;
  background: var(--bg-soft);
  border-radius: 4px;
  font-family: monospace;
  font-size: 10.5px;
}

/* ============================================================
   form-label — espaciado consistente entre etiqueta e input
   (usado en editor de montaje y otros formularios sueltos)
   ============================================================ */
.form-label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 5px;
  letter-spacing: -0.005em;
}
@media (max-width: 700px) {
  .form-label { margin-bottom: 4px; font-size: 12.5px; }
}

/* ============================================================
   .select-field — Campo de selección custom con look de marca
   (espejo estructural de .date-field, integra --brand-primary)
   ============================================================ */
.select-field {
  position: relative;
  display: flex;
  align-items: stretch;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
  /* overflow: hidden hace que .sf-ico (con fondo de marca) respete las
     esquinas redondeadas del wrapper. El dropdown se appende a <body>,
     no es hijo, así que no se corta. */
  overflow: hidden;
  cursor: pointer;
}
.select-field:hover { border-color: color-mix(in srgb, var(--brand-primary, var(--red)) 35%, var(--border)); }
.select-field.open,
.select-field:focus-within {
  border-color: var(--brand-primary, var(--ink));
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--brand-primary, var(--ink)) 14%, transparent);
}
.select-field.is-locked {
  background: color-mix(in srgb, var(--brand-primary, var(--red)) 5%, var(--surface));
  border-color: color-mix(in srgb, var(--brand-primary, var(--red)) 30%, var(--border));
  cursor: not-allowed;
}
.select-field .sf-ico {
  display: flex; align-items: center; justify-content: center;
  width: 42px;
  background: color-mix(in srgb, var(--brand-primary, var(--red)) 8%, var(--surface));
  color: var(--brand-primary, var(--red));
  border-right: 1px solid var(--border);
  flex-shrink: 0;
  /* Refuerzo: esquinas izquierdas redondeadas en el propio ícono.
     Garantiza el efecto incluso si algún ancestor ignora el overflow:hidden. */
  border-top-left-radius: calc(var(--r-md) - 1px);
  border-bottom-left-radius: calc(var(--r-md) - 1px);
}
.select-field .sf-ico svg { width: 18px; height: 18px; }
.select-field .sf-trigger {
  flex: 1;
  display: flex;
  align-items: center;
  padding: 12px 14px 12px 14px;
  background: transparent;
  border: none;
  cursor: inherit;
  font-weight: 500;
  font-size: 14px;
  color: var(--text);
  text-align: left;
  min-width: 0;
}
.select-field .sf-text {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.select-field .sf-text.is-placeholder {
  color: var(--text-muted);
  font-weight: 400;
}
.select-field .sf-caret {
  display: flex; align-items: center; justify-content: center;
  padding: 0 12px;
  color: var(--text-muted);
  transition: transform var(--t-fast);
}
.select-field.open .sf-caret { transform: rotate(180deg); color: var(--brand-primary, var(--red)); }
.select-field.is-locked .sf-caret { display: none; }
.select-field .sf-lock {
  display: none;
  align-items: center; justify-content: center;
  padding: 0 12px;
  color: var(--brand-primary, var(--red));
}
.select-field.is-locked .sf-lock { display: flex; }
.select-field .sf-lock svg { width: 14px; height: 14px; }

/* Dropdown menu */
.select-field-menu {
  position: absolute;
  z-index: 80;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-lg);
  padding: 6px;
  min-width: 240px;
  max-height: 320px;
  overflow-y: auto;
  animation: scaleIn 180ms var(--ease-out);
}
.select-field-menu .sfm-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 10px;
  cursor: pointer;
  font-size: 14px;
  color: var(--text);
  transition: background var(--t-fast);
}
.select-field-menu .sfm-item:hover {
  background: color-mix(in srgb, var(--brand-primary, var(--red)) 8%, var(--surface));
}
.select-field-menu .sfm-item.selected {
  background: color-mix(in srgb, var(--brand-primary, var(--red)) 14%, var(--surface));
  color: var(--brand-primary, var(--red));
  font-weight: 600;
}
.select-field-menu .sfm-empty {
  padding: 14px 12px;
  color: var(--text-muted);
  font-size: 13px;
  text-align: center;
}
.select-field-menu .sfm-search {
  padding: 8px 10px;
  margin-bottom: 4px;
  border-bottom: 1px solid var(--border);
}
.select-field-menu .sfm-search input {
  width: 100%;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  font-size: 13px;
  background: var(--bg);
  color: var(--text);
  outline: none;
}
.select-field-menu .sfm-search input:focus {
  border-color: var(--brand-primary, var(--red));
}

/* ============================================================
   .price-input — input numérico con prefijo $ sobre fondo oscuro (.summary)
   ============================================================ */
.summary .price-input {
  display: flex;
  align-items: center;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(255, 255, 255, 0.4);
  border-radius: 12px;
  overflow: hidden;
  max-width: 160px;
  transition: box-shadow var(--t-fast), border-color var(--t-fast);
}
.summary .price-input:focus-within {
  border-color: var(--brand-primary, var(--red));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--brand-primary, var(--red)) 30%, transparent);
}
.summary .price-input .pi-prefix {
  padding: 0 4px 0 10px;
  color: var(--brand-primary, var(--red));
  font-weight: 700;
  font-size: 15px;
}
.summary .price-input input {
  flex: 1;
  min-width: 0;
  border: 0;
  background: transparent;
  padding: 9px 10px 9px 4px;
  color: var(--ink);
  font-weight: 600;
  font-size: 14px;
  text-align: right;
  outline: none;
  /* Quita las flechitas spinner de input number */
  -moz-appearance: textfield;
  appearance: textfield;
}
.summary .price-input input::-webkit-outer-spin-button,
.summary .price-input input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* ============================================================
   .brand-lock-banner extension — versión compacta para selects bloqueados
   ============================================================ */
.client-lock-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  background: color-mix(in srgb, var(--brand-primary, var(--red)) 6%, var(--surface));
  border: 1px solid color-mix(in srgb, var(--brand-primary, var(--red)) 28%, var(--border));
  border-radius: var(--r-md);
}
.client-lock-card .clc-ico {
  display: flex; align-items: center; justify-content: center;
  width: 38px; height: 38px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--brand-primary, var(--red)) 14%, var(--surface));
  color: var(--brand-primary, var(--red));
  flex-shrink: 0;
}
.client-lock-card .clc-body { flex: 1; min-width: 0; }
.client-lock-card .clc-body b { display: block; font-size: 14px; color: var(--text); }
.client-lock-card .clc-body span {
  display: block;
  font-size: 12px;
  color: var(--text-muted);
  margin-top: 2px;
}

/* ============================================================
   Estado read-only en formulario de proyecto
   ============================================================ */
.estado-readonly {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 14px;
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
}
.estado-readonly .badge { margin: 0; }
.estado-readonly .er-hint {
  font-size: 12px;
  color: var(--text-muted);
  margin-left: auto;
}
@media (max-width: 700px) {
  .estado-readonly { flex-wrap: wrap; }
  .estado-readonly .er-hint { margin-left: 0; flex-basis: 100%; }
}

/* ============================================================
   Detalle de proyecto: panel de pagos
   ============================================================ */
.payments-panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.payments-panel h3 {
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 4px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.payment-toggle {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  background: var(--bg-soft);
  border-radius: 12px;
  cursor: pointer;
  transition: background var(--t-fast);
}
.payment-toggle:hover { background: color-mix(in srgb, var(--brand-primary, var(--red)) 6%, var(--bg-soft)); }
.payment-toggle.is-on {
  background: color-mix(in srgb, var(--green) 12%, var(--surface));
  border: 1px solid color-mix(in srgb, var(--green) 30%, var(--border));
}
.payment-toggle .pt-body { flex: 1; min-width: 0; }
.payment-toggle .pt-body b { display: block; font-size: 14px; color: var(--text); }
.payment-toggle .pt-body span {
  display: block;
  font-size: 12px;
  color: var(--text-muted);
  margin-top: 1px;
}
.payment-cancel-btn {
  width: 100%;
  padding: 11px 14px;
  border: 1px solid var(--border-strong);
  background: var(--surface);
  color: var(--red);
  font-weight: 600;
  border-radius: 12px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: all var(--t-fast);
}
.payment-cancel-btn:hover {
  background: var(--red-softer);
  border-color: var(--red);
}
.payment-cancel-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* ============================================================
   Vista de clientes: filtros + sección "con proyectos activos"
   ============================================================ */
.clientes-filters {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin: 12px 0 0;
}
.clientes-filters .filter-group {
  display: flex;
  align-items: center;
  gap: 6px;
}
.clientes-filters label {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-muted);
  white-space: nowrap;
}
.clientes-filters select {
  padding: 7px 28px 7px 12px;
  font-size: 13px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--surface);
  color: var(--text);
  cursor: pointer;
  font-family: inherit;
}
.clientes-filters select:focus {
  border-color: var(--brand-primary, var(--red));
  outline: none;
}
.active-clients-card {
  margin: 18px 0;
  padding: 18px 20px;
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--brand-primary, var(--red)) 8%, var(--surface)),
    var(--surface));
  border: 1px solid color-mix(in srgb, var(--brand-primary, var(--red)) 22%, var(--border));
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-sm);
}
.active-clients-card .acc-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}
.active-clients-card .acc-title { display: flex; align-items: center; gap: 10px; }
.active-clients-card .acc-title b {
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
}
.active-clients-card .acc-title .acc-count {
  background: var(--brand-primary, var(--red));
  color: #fff;
  padding: 2px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
}
.active-clients-card .acc-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 10px;
}
.active-clients-card .acc-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  cursor: pointer;
  transition: all var(--t-fast);
  color: var(--text);
  text-decoration: none;
}
.active-clients-card .acc-item:hover {
  border-color: var(--brand-primary, var(--red));
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}
.active-clients-card .acc-item .avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--ink);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 12px;
  flex-shrink: 0;
}
.active-clients-card .acc-item .acc-name {
  flex: 1;
  min-width: 0;
}
.active-clients-card .acc-item .acc-name b {
  display: block;
  font-size: 13px;
  font-weight: 600;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.active-clients-card .acc-item .acc-name span {
  display: block;
  font-size: 11px;
  color: var(--text-muted);
}

/* ============================================================
   Dashboard: KPI cards clickeables + gráfica
   ============================================================ */
.kpi.is-clickable { cursor: pointer; }
.kpi.is-clickable:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}
.kpi.is-clickable:active { transform: translateY(0); }

/* Toolbar compartido (controles de rango + export) */
.dash-charts-toolbar {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 18px 22px;
  margin-top: 22px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 14px;
  box-shadow: var(--shadow-sm);
}
.dash-charts-toolbar .dash-chart-custom { width: 100%; order: 3; }

/* Grid de 2 gráficas separadas */
.dash-charts-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 18px;
  margin-top: 14px;
}
@media (max-width: 1100px) {
  .dash-charts-grid { grid-template-columns: minmax(0, 1fr); }
}

/* Tarjeta individual de cada gráfica con efecto glow de marca */
.chart-glow {
  position: relative;
  isolation: isolate;
}
.chart-glow::before {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: calc(var(--r-lg) + 2px);
  padding: 1px;
  background: linear-gradient(140deg,
    color-mix(in srgb, var(--brand-primary, var(--red)) 60%, transparent),
    transparent 45%,
    color-mix(in srgb, var(--brand-primary, var(--red)) 35%, transparent) 100%);
  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  z-index: 1;
  opacity: 0.7;
}
.chart-glow.chart-projects {
  box-shadow:
    0 0 0 1px var(--border),
    0 18px 40px -16px color-mix(in srgb, var(--brand-primary, var(--red)) 50%, transparent),
    0 6px 18px -8px color-mix(in srgb, var(--brand-primary, var(--red)) 35%, transparent);
}
.chart-glow.chart-income {
  box-shadow:
    0 0 0 1px var(--border),
    0 18px 40px -16px color-mix(in srgb, var(--ink) 25%, transparent),
    0 6px 18px -8px color-mix(in srgb, var(--ink) 18%, transparent);
}
.chart-glow:hover {
  transform: translateY(-2px);
  transition: transform var(--t-fast);
}
.chart-glow .dcc-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}
.chart-glow h3 {
  margin: 0;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--text);
}
.chart-glow .chart-icon {
  width: 36px; height: 36px;
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.chart-projects .chart-icon {
  background: color-mix(in srgb, var(--brand-primary, var(--red)) 12%, var(--surface));
  color: var(--brand-primary, var(--red));
}
.chart-income .chart-icon {
  background: color-mix(in srgb, var(--ink) 88%, transparent);
  color: #fff;
}
.chart-glow .chart-icon svg { width: 18px; height: 18px; }

.dash-chart-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 22px;
  margin-top: 22px;
  box-shadow: var(--shadow-sm);
}
/* Variante compacta para dos columnas */
.dash-charts-grid .dash-chart-card {
  margin-top: 0;
  padding: 18px;
}
.dash-chart-card .dcc-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 18px;
}
.dash-chart-card h2 {
  font-size: 18px;
  font-weight: 700;
  margin: 0;
  letter-spacing: -0.01em;
}
.dash-chart-card .dcc-sub { font-size: 12px; color: var(--text-muted); }
.dash-chart-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
@media (max-width: 700px) {
  .dash-chart-actions { width: 100%; justify-content: space-between; }
}
.dash-chart-range {
  display: inline-flex;
  background: var(--bg-soft);
  border-radius: 999px;
  padding: 3px;
  gap: 2px;
}
.dash-chart-range .dcr-btn {
  padding: 7px 14px;
  font-size: 12.5px;
  font-weight: 600;
  border: 0;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  border-radius: 999px;
  transition: all var(--t-fast);
}
.dash-chart-range .dcr-btn.active {
  background: var(--surface);
  color: var(--text);
  box-shadow: 0 1px 3px rgba(0,0,0,0.06);
}
.dash-chart-custom {
  display: none;
  align-items: center;
  gap: 8px;
  margin-top: 10px;
  flex-wrap: wrap;
}
.dash-chart-custom.is-visible { display: flex; }
.dash-chart-custom .dcc-label {
  font-size: 12px;
  color: var(--text-muted);
  font-weight: 600;
}
.dash-chart-canvas-wrap {
  position: relative;
  width: 100%;
  min-height: 240px;
}
@media (max-width: 700px) {
  .dash-chart-card { padding: 16px; }
  .dash-chart-canvas-wrap { min-height: 200px; }
}
