/* ═══════════════════════════════════════════════════════════════════════════
   style.css — Sistema de Carnets UC · Modelo B (Enterprise)
   ═══════════════════════════════════════════════════════════════════════════ */

:root {
  --uc-rojo:      #4B6CB7;
  --uc-rojo-dark: #3A5599;
  --uc-dorado:    #93A8D6;
  --slate-50:     #F8FAFC;
  --slate-100:    #F1F5F9;
  --slate-200:    #E2E8F0;
  --slate-400:    #94A3B8;
  --slate-600:    #475569;
  --slate-800:    #1E293B;
}

/* ── Base ──────────────────────────────────────────────────────────────────── */
body {
  background: var(--slate-50);
  color: var(--slate-800);
  font-family: system-ui, -apple-system, "Segoe UI", sans-serif;
  font-size: .9rem;
}

/* ── Colores de marca ──────────────────────────────────────────────────────── */
.bg-uc     { background-color: var(--uc-rojo) !important; }
.text-uc   { color: var(--uc-rojo) !important; }
.border-uc { border-color: var(--uc-rojo) !important; }

.btn-uc {
  background-color: var(--uc-rojo);
  border-color:     var(--uc-rojo);
  color: #fff;
  font-weight: 600;
  font-size: .85rem;
}
.btn-uc:hover, .btn-uc:focus {
  background-color: var(--uc-rojo-dark);
  border-color:     var(--uc-rojo-dark);
  color: #fff;
}

/* ── Navbar ────────────────────────────────────────────────────────────────── */
.navbar {
  background: #fff !important;
  border-bottom: 1px solid var(--slate-200);
  box-shadow: 0 1px 3px rgba(0,0,0,.06);
  min-height: 56px;
}
.navbar-brand {
  font-weight: 700;
  font-size: .95rem;
  color: var(--uc-rojo) !important;
  letter-spacing: -.01em;
  display: flex;
  align-items: center;
  gap: .5rem;
}
.navbar-brand .brand-dot {
  width: 8px; height: 8px;
  background: var(--uc-dorado);
  border-radius: 50%;
  display: inline-block;
  flex-shrink: 0;
}
.nav-main .nav-link {
  font-size: .85rem;
  font-weight: 500;
  color: var(--slate-600);
  padding: .4rem .75rem;
  border-radius: 6px;
  transition: background .15s, color .15s;
}
.nav-main .nav-link:hover {
  background: var(--slate-100);
  color: var(--slate-800);
}
.nav-main .nav-link.active {
  color: var(--uc-rojo);
  background: #EEF1F9;
  font-weight: 600;
}
.nav-main .nav-link i { font-size: .9rem; }

/* ── Layout principal ──────────────────────────────────────────────────────── */
main {
  min-height: calc(100vh - 57px);
  padding: 1.75rem 2rem;
}
@media (max-width: 767px) {
  main { padding: 1rem; }
}

/* ── Page header ───────────────────────────────────────────────────────────── */
.page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.25rem;
}
.page-title {
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--slate-800);
  margin: 0;
}
.page-subtitle {
  font-size: .8rem;
  color: var(--slate-400);
  margin: .1rem 0 0;
}

/* ── Breadcrumb ────────────────────────────────────────────────────────────── */
.breadcrumb {
  font-size: .78rem;
  margin-bottom: .25rem;
}
.breadcrumb-item a { color: var(--slate-400); text-decoration: none; }
.breadcrumb-item a:hover { color: var(--uc-rojo); }
.breadcrumb-item.active { color: var(--slate-600); }
.breadcrumb-item + .breadcrumb-item::before { color: var(--slate-400); }

/* ── Cards ─────────────────────────────────────────────────────────────────── */
.card {
  border: 1px solid var(--slate-200) !important;
  border-radius: 10px !important;
  box-shadow: 0 1px 3px rgba(0,0,0,.05) !important;
}
.card-header {
  background: #fff !important;
  border-bottom: 1px solid var(--slate-200) !important;
  padding: .9rem 1.25rem !important;
  border-radius: 10px 10px 0 0 !important;
}

/* ── Toolbar de tabla ──────────────────────────────────────────────────────── */
.table-toolbar {
  display: flex;
  align-items: center;
  gap: .5rem;
  padding: .75rem 1rem;
  border-bottom: 1px solid var(--slate-200);
  flex-wrap: wrap;
}
.table-toolbar .form-control,
.table-toolbar .form-select {
  background: var(--slate-50);
}
.table-toolbar .form-control:focus,
.table-toolbar .form-select:focus {
  background: #fff;
}
.table-toolbar .input-group-text {
  background: var(--slate-50);
  border-color: var(--slate-200);
  color: var(--slate-400);
  padding: .35rem .55rem;
}
.search-input { width: 220px; }

/* ── Tabla principal ───────────────────────────────────────────────────────── */
.table {
  margin: 0;
  border-collapse: separate;
  border-spacing: 0;
}
.table thead th {
  font-size: .72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--slate-600);
  background: var(--slate-100) !important;
  border-bottom: 1px solid var(--slate-200) !important;
  border-top: none;
  padding: .65rem 1rem;
  white-space: nowrap;
}
.table tbody td {
  font-size: .855rem;
  color: var(--slate-800);
  padding: .75rem 1rem;
  border-bottom: 1px solid var(--slate-200) !important;
  border-top: none;
  vertical-align: middle;
}
.table tbody tr:last-child td { border-bottom: none !important; }
.table tbody tr:hover td { background: var(--slate-50); }
.table-name { font-weight: 600; color: var(--slate-800); }
.table-mono { font-family: "SF Mono", ui-monospace, monospace; font-size: .82rem; color: var(--slate-600); }

/* ── Badges de tipo (links de impresión) ───────────────────────────────────── */
.badge-tipo {
  display: inline-flex;
  align-items: center;
  gap: .25rem;
  font-size: .72rem;
  font-weight: 500;
  padding: .25em .6em;
  border-radius: 4px;
  border: 1px solid transparent;
  margin: 1px;
  text-decoration: none;
  transition: all .15s;
  background: var(--slate-100) !important;
  color: var(--slate-700) !important;
  border-color: var(--slate-200) !important;
}
.badge-tipo:hover {
  background: #EEF1F9 !important;
  color: var(--uc-rojo) !important;
  border-color: #C5CEEA !important;
}

/* ── Badges de estado ──────────────────────────────────────────────────────── */
.badge-status {
  font-size: .72rem;
  font-weight: 500;
  padding: .28em .65em;
  border-radius: 20px;
  letter-spacing: .01em;
}
.badge-active   { background: #DCFCE7; color: #166534; }
.badge-inactive { background: #FEE2E2; color: #991B1B; }

/* ── Botones de acción en tabla ────────────────────────────────────────────── */
.btn-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px; height: 30px;
  border-radius: 6px;
  border: 1px solid var(--slate-200);
  background: #fff;
  color: var(--slate-600);
  font-size: .85rem;
  transition: all .15s;
  text-decoration: none;
  cursor: pointer;
}
.btn-action:hover { border-color: var(--slate-400); color: var(--slate-800); background: var(--slate-100); }
.btn-action.danger:hover { border-color: #FCA5A5; color: #DC2626; background: #FEF2F2; }
.btn-action.success:hover { border-color: #86EFAC; color: #16A34A; background: #F0FDF4; }

/* ── Paginación ────────────────────────────────────────────────────────────── */
.pagination-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .75rem 1rem;
  border-top: 1px solid var(--slate-200);
  font-size: .8rem;
  color: var(--slate-600);
}
.pagination { margin: 0; gap: 2px; }
.page-link {
  font-size: .8rem;
  padding: .3rem .6rem;
  border-radius: 6px !important;
  border: 1px solid var(--slate-200);
  color: var(--slate-600);
  background: #fff;
  transition: all .15s;
  min-width: 32px;
  text-align: center;
}
.page-link:hover { background: var(--slate-100); border-color: var(--slate-300); color: var(--slate-800); }
.page-item.active .page-link {
  background: var(--uc-rojo);
  border-color: var(--uc-rojo);
  color: #fff;
}
.page-item.disabled .page-link { color: var(--slate-400); background: var(--slate-50); }

/* ── Formulario / Modal ────────────────────────────────────────────────────── */
.modal-content { border: none; border-radius: 12px; box-shadow: 0 20px 60px rgba(0,0,0,.15); }
.modal-header {
  padding: 1.1rem 1.5rem;
  border-bottom: 1px solid var(--slate-200);
}
.modal-header.modal-header-uc {
  background: var(--uc-rojo);
  color: #fff;
  border-radius: 12px 12px 0 0;
}
.modal-footer {
  padding: .9rem 1.5rem;
  border-top: 1px solid var(--slate-200);
}
.modal-body { padding: 1.5rem; }

.input-group-text {
  font-size: .875rem;
  border-color: var(--slate-200);
  color: var(--slate-400);
  background: var(--slate-50);
  padding: .4rem .75rem;
}
.form-label {
  font-size: .8rem;
  font-weight: 600;
  color: var(--slate-600);
  margin-bottom: .3rem;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.form-control, .form-select {
  font-size: .875rem;
  border-color: var(--slate-200);
  border-radius: 7px;
  color: var(--slate-800);
  height: 38px;
  padding: .4rem .75rem;
}
textarea.form-control { height: auto; }
.form-control:focus, .form-select:focus {
  border-color: var(--uc-rojo);
  box-shadow: 0 0 0 3px rgba(75,108,183,.12);
}

/* ── Sección títulos en formulario ────────────────────────────────────────── */
.section-title {
  font-size: .7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .09em;
  color: var(--slate-400);
  border-bottom: 1px solid var(--slate-200);
  padding-bottom: .5rem;
  margin-bottom: 1rem;
}

/* ── Fila de asignación ────────────────────────────────────────────────────── */
.asig-row {
  background: var(--slate-50);
  border: 1px solid var(--slate-200);
  border-radius: 8px;
  padding: .75rem 1rem;
  margin-bottom: .5rem;
  position: relative;
}
.asig-row .btn-remove-asig {
  position: absolute;
  top: .6rem; right: .75rem;
  width: 28px; height: 28px;
}

/* ── Tarjetas estadísticas ─────────────────────────────────────────────────── */
.stat-card { border-radius: 10px !important; transition: box-shadow .2s; }
.stat-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,.09) !important; }
.stat-icon {
  width: 48px; height: 48px;
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.35rem;
  flex-shrink: 0;
}
.stat-value { font-size: 1.65rem; font-weight: 700; line-height: 1.1; color: var(--slate-800); }
.stat-label { font-size: .72rem; color: var(--slate-400); font-weight: 600; text-transform: uppercase; letter-spacing: .06em; }

/* ── Accesos rápidos ───────────────────────────────────────────────────────── */
.quick-link { transition: box-shadow .2s, transform .15s; border-radius: 10px !important; cursor: pointer; }
.quick-link:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0,0,0,.09) !important; }

/* ── Focus ring ────────────────────────────────────────────────────────────── */
:focus-visible { outline: 2px solid var(--uc-rojo); outline-offset: 2px; }

/* ── Spinner ────────────────────────────────────────────────────────────────── */
.spinner-border.text-uc { color: var(--uc-rojo) !important; }

/* ── Input uppercase ───────────────────────────────────────────────────────── */
input.text-uppercase { text-transform: uppercase; }
input.text-uppercase::placeholder { text-transform: none; }

/* ── Empty state ───────────────────────────────────────────────────────────── */
.empty-state { padding: 3rem 1rem; text-align: center; color: var(--slate-400); }
.empty-state i { font-size: 2.5rem; display: block; margin-bottom: .75rem; opacity: .35; }
