/* AVIO Turnos — tema corporativo sobre Bootstrap 5 (vendoreado en /static/vendor/). */

@font-face {
  font-family: "Plus Jakarta Sans";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/plus-jakarta-sans/plus-jakarta-sans-latin-400-normal.woff2") format("woff2");
}
@font-face {
  font-family: "Plus Jakarta Sans";
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/plus-jakarta-sans/plus-jakarta-sans-latin-500-normal.woff2") format("woff2");
}
@font-face {
  font-family: "Plus Jakarta Sans";
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/plus-jakarta-sans/plus-jakarta-sans-latin-600-normal.woff2") format("woff2");
}
@font-face {
  font-family: "Plus Jakarta Sans";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/plus-jakarta-sans/plus-jakarta-sans-latin-700-normal.woff2") format("woff2");
}

:root {
  --azul-corp: #0b1a3b;
  --azul-medio: #1e3a6e;
  --azul-accent: #3b7ddd;
  --gris-fondo: #f5f7fa;
  --gris-texto: #1f2a44;
  --rojo: #dc2626;
  --naranja: #ea580c;
  --amarillo: #ca8a04;
  --verde: #16a34a;

  /* Override Bootstrap primary tokens. */
  --bs-primary: var(--azul-corp);
  --bs-primary-rgb: 11, 26, 59;
  --bs-link-color: var(--azul-accent);
  --bs-link-hover-color: var(--azul-medio);
  --bs-body-font-family: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --bs-body-bg: var(--gris-fondo);
  --bs-body-color: var(--gris-texto);
}

body {
  font-family: var(--bs-body-font-family);
  background: var(--bs-body-bg);
  color: var(--bs-body-color);
}

/* Navbar corporativo. */
.navbar-avio {
  background: var(--azul-corp);
}
.navbar-avio .navbar-brand,
.navbar-avio .nav-link {
  color: rgba(255, 255, 255, 0.92);
  font-weight: 500;
}
.navbar-avio .nav-link:hover,
.navbar-avio .nav-link.active {
  color: white;
}
.navbar-avio .nav-link.active {
  font-weight: 600;
}
.navbar-avio .navbar-text {
  color: rgba(255, 255, 255, 0.75);
  font-size: 0.875rem;
}

/* Botones primarios usando azul corporativo. */
.btn-primary {
  --bs-btn-bg: var(--azul-corp);
  --bs-btn-border-color: var(--azul-corp);
  --bs-btn-hover-bg: var(--azul-medio);
  --bs-btn-hover-border-color: var(--azul-medio);
  --bs-btn-active-bg: var(--azul-medio);
  --bs-btn-active-border-color: var(--azul-medio);
}

/* Card auth (login, OTP). */
.tarjeta-auth {
  max-width: 420px;
  margin: 64px auto;
  padding: 32px 28px;
  background: white;
  border-radius: 12px;
  box-shadow: 0 4px 20px rgba(11, 26, 59, 0.08);
}

/* Página interna. */
.pagina {
  padding: 24px 0 64px;
}
.pagina h1 {
  color: var(--azul-corp);
  font-weight: 700;
  font-size: 1.6rem;
}
.pagina .lead-section {
  color: #6b7280;
  margin-bottom: 24px;
}

/* Estados / pills. */
.pill {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 600;
  line-height: 1.4;
}
.pill-rojo    { background: #fee2e2; color: var(--rojo); }
.pill-naranja { background: #ffedd5; color: var(--naranja); }
.pill-amarillo{ background: #fef9c3; color: var(--amarillo); }
.pill-verde   { background: #dcfce7; color: var(--verde); }
.pill-azul    { background: #dbeafe; color: var(--azul-medio); }
.pill-gris    { background: #e5e7eb; color: #4b5563; }

/* Tablas con cabecera azul. */
.tabla-avio thead th {
  background: var(--azul-corp);
  color: white;
  font-weight: 600;
  border-bottom: 0;
  white-space: nowrap;
}

.codigo-otp {
  font-size: 1.75rem;
  letter-spacing: 0.6rem;
  text-align: center;
  font-variant-numeric: tabular-nums;
}

/* FullCalendar overrides mínimos. */
.fc {
  --fc-border-color: #e5e7eb;
  --fc-button-bg-color: var(--azul-corp);
  --fc-button-border-color: var(--azul-corp);
  --fc-button-hover-bg-color: var(--azul-medio);
  --fc-button-hover-border-color: var(--azul-medio);
  --fc-button-active-bg-color: var(--azul-medio);
  --fc-today-bg-color: rgba(59, 125, 221, 0.08);
}
.fc .fc-toolbar-title { color: var(--azul-corp); font-weight: 700; }
.dia-resumen {
  font-size: 0.78rem;
  line-height: 1.25;
  padding: 2px 4px;
}
.dia-resumen .pendiente { color: var(--rojo); font-weight: 600; }
.dia-resumen .completo  { color: var(--verde); font-weight: 600; }

/* Filas de recurrencia. */
.recurrencia-fila td {
  vertical-align: middle;
}
.recurrencia-fila .dias-semana {
  display: inline-flex;
  gap: 4px;
}
.recurrencia-fila .dias-semana label {
  font-size: 0.78rem;
  font-weight: 600;
  width: 30px;
  text-align: center;
  border: 1px solid #d1d5db;
  border-radius: 6px;
  padding: 4px 0;
  cursor: pointer;
  user-select: none;
  background: white;
}
.recurrencia-fila .dias-semana input[type="checkbox"] {
  display: none;
}
.recurrencia-fila .dias-semana input[type="checkbox"]:checked + label {
  background: var(--azul-corp);
  color: white;
  border-color: var(--azul-corp);
}

/* Misc */
.pequeno { font-size: 0.85rem; color: #6b7280; }
.errores { color: var(--rojo); font-size: 0.85rem; margin: 4px 0 0; padding: 0; list-style: none; }
