/* ============================================================
   Design system — Gabinete de Enfermería
   Capa de tema sobre Bootstrap 5 (vendoreado). Componentes propios
   con nomenclatura BEM (.bloque__elemento--modificador).
   Mobile-first: los ajustes de pantallas grandes van en @media min-width.
   ============================================================ */

/* ---------- 1. Design tokens (paleta clínica teal + neutros slate) ---------- */
:root {
  --gab-primary: #0d9488;        /* teal-600: acción principal */
  --gab-primary-dark: #0f766e;   /* teal-700: hover / links */
  --gab-primary-soft: #ccfbf1;   /* teal-100: fondos de acento */
  --gab-ink: #0f172a;            /* texto principal */
  --gab-slate: #475569;          /* texto secundario */
  --gab-muted: #64748b;          /* texto terciario / labels */
  --gab-bg: #f1f5f9;             /* fondo de la app */
  --gab-surface: #ffffff;        /* tarjetas / header */
  --gab-border: #e2e8f0;         /* bordes sutiles */
  --gab-radius: 0.75rem;
  --gab-shadow: 0 1px 2px rgb(15 23 42 / 0.06), 0 4px 12px rgb(15 23 42 / 0.05);
}

/* ---------- 2. Base ---------- */
body {
  background: var(--gab-bg);
  color: var(--gab-ink);
  -webkit-tap-highlight-color: transparent;
}

a { color: var(--gab-primary-dark); }
a:hover { color: var(--gab-primary); }

/* Foco visible consistente (accesibilidad teclado) */
:focus-visible {
  outline: 3px solid rgb(13 148 136 / 0.45);
  outline-offset: 1px;
}

/* Títulos de página (todas las vistas usan h1.h4) */
h1.h4 { font-weight: 700; letter-spacing: -0.01em; }

textarea { min-height: 90px; }

/* ---------- 3. Re-tematización de Bootstrap (primario azul → teal) ---------- */
.btn { border-radius: 0.55rem; font-weight: 500; }

.btn-primary {
  --bs-btn-bg: var(--gab-primary);
  --bs-btn-border-color: var(--gab-primary);
  --bs-btn-hover-bg: var(--gab-primary-dark);
  --bs-btn-hover-border-color: var(--gab-primary-dark);
  --bs-btn-active-bg: var(--gab-primary-dark);
  --bs-btn-active-border-color: var(--gab-primary-dark);
}
.btn-outline-primary {
  --bs-btn-color: var(--gab-primary-dark);
  --bs-btn-border-color: var(--gab-primary);
  --bs-btn-hover-bg: var(--gab-primary);
  --bs-btn-hover-border-color: var(--gab-primary);
  --bs-btn-active-bg: var(--gab-primary-dark);
  --bs-btn-active-border-color: var(--gab-primary-dark);
}
.text-bg-primary { background-color: var(--gab-primary) !important; }

.form-control:focus, .form-select:focus, .form-check-input:focus {
  border-color: var(--gab-primary);
  box-shadow: 0 0 0 0.25rem rgb(13 148 136 / 0.15);
}
.form-check-input:checked {
  background-color: var(--gab-primary);
  border-color: var(--gab-primary);
}
.pagination {
  --bs-pagination-active-bg: var(--gab-primary);
  --bs-pagination-active-border-color: var(--gab-primary);
  --bs-pagination-color: var(--gab-primary-dark);
}
.badge { border-radius: 999px; font-weight: 600; }

/* ---------- 4. Tarjetas y tablas ---------- */
.card {
  border: 1px solid var(--gab-border);
  border-radius: var(--gab-radius);
  box-shadow: var(--gab-shadow);
}
.card-header {
  background: var(--gab-surface);
  border-bottom-color: var(--gab-border);
  border-top-left-radius: var(--gab-radius) !important;
  border-top-right-radius: var(--gab-radius) !important;
}
/* Las tablas dentro de cards heredan el redondeo inferior */
.card .table { margin-bottom: 0; }
.card .table > :last-child > tr:last-child > * { border-bottom: 0; }

/* Encabezados de tabla estilo "panel de gestión" */
.table thead th {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--gab-muted);
  background: #f8fafc;
  border-bottom-width: 1px;
}
.table-sm td, .table-sm th { vertical-align: middle; }
.table-hover tbody tr:hover { background-color: #f0fdfa; }

/* ---------- 5. Header de la app (.app-header) ---------- */
.app-header {
  background: var(--gab-surface);
  border-bottom: 1px solid var(--gab-border);
}
.app-header__brand { display: flex; align-items: center; }
/* Wordmark Armonía Salud (mismo logo que la app de extracciones) */
.app-header__logo-img { height: 40px; width: auto; }
.app-header .nav-link {
  color: var(--gab-slate);
  font-weight: 500;
  border-radius: 0.5rem;
  padding: 0.45rem 0.75rem;
  margin: 0.1rem 0.1rem;
}
.app-header .nav-link:hover { background: var(--gab-bg); color: var(--gab-ink); }
.app-header .nav-link.active {
  background: var(--gab-primary-soft);
  color: var(--gab-primary-dark);
}

/* Bloque usuario + rol + salir (derecha del header) */
.app-header__user {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  flex-wrap: wrap;
  padding-block: 0.35rem;
}
.app-header__user-name { font-size: 0.85rem; color: var(--gab-slate); }
.app-header__role { font-size: 0.7rem; }
.app-header__role--admin { background: var(--gab-ink); color: #fff; }
.app-header__role--recepcion { background: #e0e7ff; color: #3730a3; }
.app-header__role--profesional { background: var(--gab-primary-soft); color: var(--gab-primary-dark); }

/* ---------- 6. Tarjetas de indicadores del dashboard (.stat-card) ---------- */
.stat-card {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  height: 100%;
  padding: 1rem;
  background: var(--gab-surface);
  border: 1px solid var(--gab-border);
  border-radius: var(--gab-radius);
  box-shadow: var(--gab-shadow);
}
.stat-card__icon {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  font-size: 1.25rem;
}
.stat-card__icon--teal { background: var(--gab-primary-soft); color: var(--gab-primary-dark); }
.stat-card__icon--green { background: #dcfce7; color: #15803d; }
.stat-card__icon--amber { background: #fef3c7; color: #b45309; }
.stat-card__icon--red { background: #fee2e2; color: #b91c1c; }
.stat-card__label {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--gab-muted);
}
.stat-card__value { font-size: 1.35rem; font-weight: 700; line-height: 1.2; }
.stat-card__hint { font-size: 0.78rem; color: var(--gab-muted); }
@media (min-width: 768px) {
  .stat-card__value { font-size: 1.6rem; }
}

/* ---------- 7. Login (.auth) ---------- */
.page-auth {
  background:
    radial-gradient(60rem 30rem at 110% -10%, rgb(20 184 166 / 0.18), transparent),
    radial-gradient(50rem 25rem at -10% 110%, rgb(13 148 136 / 0.14), transparent),
    var(--gab-bg);
  min-height: 100vh;
}
.auth { max-width: 400px; margin-inline: auto; }
.auth__logo-img { max-width: 290px; width: 100%; height: auto; }

/* ---------- 8. Footer ---------- */
.app-footer {
  color: var(--gab-muted);
  font-size: 0.78rem;
  text-align: center;
  padding: 1.5rem 1rem 2rem;
}

/* ---------- 9. Autocomplete de pacientes ---------- */
.autocomplete-results {
  position: absolute;
  z-index: 1050;
  width: 100%;
  max-height: 260px;
  overflow-y: auto;
}
.autocomplete-results .list-group-item { cursor: pointer; }

/* ---------- 10. FullCalendar acorde al tema ---------- */
.fc .fc-toolbar-title { font-size: 1.1rem; font-weight: 700; }
.fc .fc-button-primary {
  background: var(--gab-primary);
  border-color: var(--gab-primary);
}
.fc .fc-button-primary:hover,
.fc .fc-button-primary:not(:disabled).fc-button-active {
  background: var(--gab-primary-dark);
  border-color: var(--gab-primary-dark);
}
@media (max-width: 576px) {
  .fc .fc-toolbar { flex-direction: column; gap: 0.5rem; }
}
