html {
  font-size: 14px;
}

@media (min-width: 768px) {
  html {
    font-size: 16px;
  }
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem var(--bs-body-bg), 0 0 0 0.25rem #258cfb;
}

/* ============================================================
   Tema GOP VisitControl (claro/oscuro vía data-bs-theme)
   ============================================================ */
:root {
  --gop-primary: #0b5ed7;
  --gop-primary-dark: #0a4fb3;
  --gop-sidebar-ancho: 250px;
  --gop-sidebar-bg: #10243e;
  --gop-sidebar-color: #c9d6e8;
  --gop-sidebar-activo: #1d3a5f;
}

[data-bs-theme="dark"] {
  --gop-sidebar-bg: #0a1626;
  --gop-sidebar-color: #b6c4d8;
  --gop-sidebar-activo: #16293f;
}

.gop-body {
  min-height: 100vh;
  background-color: var(--bs-tertiary-bg);
}

/* ---------- Barra lateral ---------- */
.gop-sidebar {
  width: var(--gop-sidebar-ancho);
  /* Ancho del cajón en móvil/tablet: Bootstrap usa --bs-offcanvas-width (400px
     por defecto); se alinea con el ancho de escritorio. */
  --bs-offcanvas-width: var(--gop-sidebar-ancho);
  /* !important: en >=992px Bootstrap fuerza 'background-color: transparent
     !important' sobre .offcanvas-lg; sin esto la barra quedaría transparente. */
  background-color: var(--gop-sidebar-bg) !important;
  color: var(--gop-sidebar-color);
  border: none;
}

@media (min-width: 992px) {
  .gop-sidebar {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    z-index: 1030;
  }
}

.gop-sidebar-brand {
  display: flex;
  align-items: center;
  gap: .55rem;
  padding: 1rem 1.25rem;
  color: #fff;
  text-decoration: none;
  font-size: 1.05rem;
  border-bottom: 1px solid rgba(255, 255, 255, .08);
}

.gop-sidebar-brand i {
  font-size: 1.3rem;
}

.gop-sidebar-nav {
  overflow-y: auto;
}

.gop-sidebar-link {
  display: flex;
  align-items: center;
  gap: .65rem;
  color: var(--gop-sidebar-color);
  padding: .65rem 1.25rem;
  border-left: 3px solid transparent;
}

.gop-sidebar-link i {
  font-size: 1.1rem;
}

.gop-sidebar-link:hover {
  color: #fff;
  background-color: rgba(255, 255, 255, .06);
}

.gop-sidebar-link.activo {
  color: #fff;
  background-color: var(--gop-sidebar-activo);
  border-left-color: var(--gop-primary);
}

/* ---------- Contenido a la derecha de la barra ---------- */
.gop-contenido {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

@media (min-width: 992px) {
  .gop-contenido.con-sidebar {
    margin-left: var(--gop-sidebar-ancho);
  }
}

.gop-topbar {
  background-color: var(--bs-body-bg);
  border-bottom: 1px solid var(--bs-border-color);
  min-height: 56px;
}

/* ---------- Tarjetas de módulo ---------- */
.gop-modulo-icono {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 0.6rem;
  background-color: rgba(11, 94, 215, .12);
  color: var(--gop-primary);
  font-size: 1.25rem;
}

.card {
  border-radius: 0.6rem;
}
