/* =========================
   NUEVA PALETA DE 8 COLORES 4T
========================= */
:root {
  /* 1. Guinda Claro / Rojo 4T */
  --c-guinda-claro: #9F2241;
  /* 2. Verde 4T */
  --c-verde-4t: #235B4E;
  /* 3. Dorado Claro / Arena */
  --c-arena: #DDC9A3;
  /* 4. Gris Claro */
  --c-gris-claro: #98989A;
  /* 5. Guinda Oscuro */
  --c-guinda-oscuro: #691C32;
  /* 6. Verde Oscuro */
  --c-verde-oscuro: #10312B;
  /* 7. Dorado */
  --c-dorado: #BC955C;
  /* 8. Gris Oscuro */
  --c-gris-oscuro: #6F7271;

  /* Redireccion */
  --c-primary: var(--c-guinda-claro);
  --c-primary-2: var(--c-guinda-oscuro);
  --c-secondary: var(--c-dorado);
  --c-secondary-2: var(--c-arena);
  --c-bg: #F8F9FA;
  --c-text: #353D4A;
  --c-white: #FFFFFF;
  --c-border: #E1E2E4;
}

/* Fondo general */
body {
  background: var(--c-bg) !important;
  color: var(--c-text) !important;
}
/* =========================
   BOOTSTRAP (sobreescritura integral)
========================= */

/* --- ENLACES --- */
a { color: var(--c-guinda-claro) !important; }
a:hover { color: var(--c-guinda-oscuro) !important; }

/* --- TEXTOS (.text-*) --- */
.text-primary   { color: var(--c-guinda-claro) !important; }
.text-success   { color: var(--c-verde-4t) !important; }
.text-danger    { color: var(--c-guinda-oscuro) !important; }
.text-warning   { color: var(--c-dorado) !important; }
.text-info      { color: var(--c-arena) !important; }
.text-dark      { color: var(--c-verde-oscuro) !important; }
.text-secondary { color: var(--c-gris-oscuro) !important; }
.text-light     { color: var(--c-gris-claro) !important; }

/* --- FONDOS (.bg-*) --- */
.bg-primary   { background-color: var(--c-guinda-claro) !important; }
.bg-success   { background-color: var(--c-verde-4t) !important; }
.bg-danger    { background-color: var(--c-guinda-oscuro) !important; }
.bg-warning   { background-color: var(--c-dorado) !important; }
.bg-info      { background-color: var(--c-arena) !important; }
.bg-dark      { background-color: var(--c-verde-oscuro) !important; color: white !important;} 
.bg-secondary { background-color: var(--c-gris-oscuro) !important; }
.bg-light     { background-color: var(--c-gris-claro) !important; }

/* --- ETIQUETAS / BADGES --- */
.badge-primary,   .label-primary   { background-color: var(--c-guinda-claro) !important; color: white !important; }
.badge-success,   .label-success   { background-color: var(--c-verde-4t) !important; color: white !important; }
.badge-danger,    .label-danger    { background-color: var(--c-guinda-oscuro) !important; color: white !important; }
.badge-warning,   .label-warning   { background-color: var(--c-dorado) !important; color: white !important; }
.badge-info,      .label-info      { background-color: var(--c-arena) !important; color: var(--c-text) !important; }
.badge-dark,      .label-dark      { background-color: var(--c-verde-oscuro) !important; color: white !important; }
.badge-secondary, .label-secondary { background-color: var(--c-gris-oscuro) !important; color: white !important; }
.badge-light,     .label-default   { background-color: var(--c-gris-claro) !important; color: var(--c-text) !important; }

/* --- ETIQUETAS INVERSAS (OUTLINE) --- */
.badge-inverse-primary, .label-inverse-primary { background-color: transparent !important; color: var(--c-guinda-claro) !important; border: 1px solid var(--c-guinda-claro) !important; }
.badge-inverse-success, .label-inverse-success { background-color: transparent !important; color: var(--c-verde-4t) !important; border: 1px solid var(--c-verde-4t) !important; }
.badge-inverse-danger,  .label-inverse-danger  { background-color: transparent !important; color: var(--c-guinda-oscuro) !important; border: 1px solid var(--c-guinda-oscuro) !important; }
.badge-inverse-warning, .label-inverse-warning { background-color: transparent !important; color: var(--c-dorado) !important; border: 1px solid var(--c-dorado) !important; }
.badge-inverse-info,    .label-inverse-info    { background-color: transparent !important; color: var(--c-arena) !important; border: 1px solid var(--c-arena) !important; }
.badge-inverse-secondary, .label-inverse-secondary { background-color: transparent !important; color: var(--c-gris-oscuro) !important; border: 1px solid var(--c-gris-oscuro) !important; }
.badge-inverse-dark,    .label-inverse-dark    { background-color: transparent !important; color: var(--c-verde-oscuro) !important; border: 1px solid var(--c-verde-oscuro) !important; }
.btn-outline-danger { color: var(--c-guinda-oscuro) !important; border-color: var(--c-guinda-oscuro) !important; background: transparent; }
.btn-outline-danger:hover { background-color: var(--c-guinda-oscuro) !important; color: white !important; }

/* Warning */
.btn-warning { background-color: var(--c-dorado) !important; border-color: var(--c-dorado) !important; color: white !important;}
.btn-warning:hover, .btn-warning:focus { background-color: #9d7c4a !important; border-color: #9d7c4a !important; color: white !important; }
.btn-outline-warning { color: var(--c-dorado) !important; border-color: var(--c-dorado) !important; background: transparent; }
.btn-outline-warning:hover { background-color: var(--c-dorado) !important; color: white !important; }

/* Info */
.btn-info { background-color: var(--c-arena) !important; border-color: var(--c-arena) !important; color: var(--c-text) !important;}
.btn-info:hover, .btn-info:focus { background-color: #c9b48b !important; border-color: #c9b48b !important; color: var(--c-text) !important; }
.btn-outline-info { color: #bba475 !important; border-color: var(--c-arena) !important; background: transparent; }
.btn-outline-info:hover { background-color: var(--c-arena) !important; color: var(--c-text) !important; }

/* Secondary */
.btn-secondary { background-color: var(--c-gris-oscuro) !important; border-color: var(--c-gris-oscuro) !important; color: white !important;}
.btn-secondary:hover, .btn-secondary:focus { background-color:  #535655 !important; border-color: #535655 !important; color: white !important; }
.btn-outline-secondary { color: var(--c-gris-oscuro) !important; border-color: var(--c-gris-oscuro) !important; background: transparent; }
.btn-outline-secondary:hover { background-color: var(--c-gris-oscuro) !important; color: white !important; }

/* --- CONTROLES DE FORMULARIO (INPUTS Y SELECTS) --- */
.form-control-primary {
    border-color: var(--c-guinda-claro) !important;
    color: var(--c-guinda-claro) !important;
}
.form-control-primary:focus {
    border-color: var(--c-guinda-oscuro) !important;
    box-shadow: 0 0 0 0.15rem rgba(159, 34, 65, 0.25) !important;
}

/* --- CONTROLES DE FORMULARIO GURUABLE (CHECKS Y RADIOS) --- */
.checkbox-fade.fade-in-primary .cr,
.checkbox-fade.fade-in-primary input[type="checkbox"]:checked + .cr,
.radio-fade.fade-in-primary .cr,
.radio-fade.fade-in-primary input[type="radio"]:checked + .cr {
    border-color: var(--c-guinda-claro) !important;
}
.checkbox-fade.fade-in-primary .cr-icon,
.radio-fade.fade-in-primary .cr-icon {
    color: var(--c-guinda-claro) !important;
}

/* Checkbox con borde sólido Guruable */
.border-checkbox-section .border-checkbox-group-primary .border-checkbox-label:before {
    border-color: var(--c-guinda-claro) !important;
}
.border-checkbox-section .border-checkbox-group-primary .border-checkbox:checked + .border-checkbox-label:after,
.border-checkbox-section .border-checkbox-group-primary .border-checkbox:checked + .border-checkbox-label:before {
    background-color: var(--c-guinda-claro) !important;
    border-color: var(--c-guinda-claro) !important;
}

/* Clases de texto heredadas de Guruable (.txt-*) */
.txt-primary { color: var(--c-guinda-claro) !important; }
.txt-warning { color: var(--c-dorado) !important; }
.txt-success { color: var(--c-verde-4t) !important; }
.txt-danger  { color: var(--c-guinda-oscuro) !important; }

/* --- PAGINACIÓN --- */
.pagination .page-link {
  color: var(--c-guinda-claro) !important;
}
.pagination .page-link:hover {
  color: var(--c-guinda-oscuro) !important;
  background-color: #f8f9fa !important;
  border-color: #dee2e6 !important;
}
.pagination .page-item.active .page-link,
.pagination .page-item.active .page-link:hover {
  z-index: 3 !important;
  color: white !important;
  background-color: var(--c-guinda-claro) !important;
  border-color: var(--c-guinda-claro) !important;
}
.pagination .page-item.disabled .page-link {
  color: var(--c-gris-claro) !important;
}


/* =========================
   CLASES DE COLOR DEL TEMA GURUABLE (.bg-c-*)
========================= */

/* -- AZULES / INFO -> Guinda Claro -- */
.bg-c-blue, .bg-c-lite-blue {
  background: var(--c-guinda-claro) !important;
}
.text-c-blue { color: var(--c-guinda-claro) !important; }
.bg-c-info {
  background: var(--c-arena) !important;
}

/* -- AMARILLOS / WARNING -> Dorado -- */
.bg-c-yellow, .bg-c-warning {
  background: var(--c-dorado) !important;
}
.text-c-yellow { color: var(--c-dorado) !important; }

/* -- ROJOS / PINK / DANGER -> Guinda Oscuro -- */
.bg-c-pink, .bg-c-red, .bg-c-danger {
  background: var(--c-guinda-oscuro) !important;
}
.text-c-pink, .text-c-red { color: var(--c-guinda-oscuro) !important; }

/* -- VERDES / LITE-GREEN / SUCCESS -> Verde 4T -- */
.bg-c-green, .bg-c-lite-green, .bg-c-success {
  background: var(--c-verde-4t) !important;
}
.text-c-green { color: var(--c-verde-4t) !important; }

/* -- NUEVAS EXTENSIONES -- */
.bg-c-dark { background: var(--c-verde-oscuro) !important;}
.bg-c-lite-gray { background: var(--c-gris-claro) !important;}
.bg-c-gray { background: var(--c-gris-oscuro) !important;}


/* =========================
   SIDEBAR / HEADER (pcoded)
========================= */
.pcoded-navbar {
  background: var(--c-bg) !important;
  border-right: 1px solid var(--c-border) !important;
}

/* textos/iconos sidebar */
.pcoded-navbar .pcoded-item>li>a,
.pcoded-navbar .pcoded-item>li>a .pcoded-mtext {
  color: var(--c-text) !important;
}

.pcoded-navbar .pcoded-item>li>a:hover {
  background: var(--c-white) !important;
}

.pcoded-navbar .pcoded-item>li>a .pcoded-micon i {
  color: var(--c-dorado) !important;
}

.pcoded-navbar .pcoded-item>li>a:hover .pcoded-micon i {
  color: var(--c-arena) !important;
}

/* ACTIVO Y HOVER SIDEBAR */
.pcoded[theme-layout="vertical"] .pcoded-navbar[active-item-theme] .pcoded-item > li.active > a,
.pcoded-navbar .pcoded-item > li.active > a,
.pcoded-navbar .pcoded-item > li.active > a .pcoded-mtext,
.pcoded-navbar .pcoded-item > li.pcoded-trigger > a,
.pcoded-navbar .pcoded-item > li.pcoded-trigger > a .pcoded-mtext,
.pcoded-navbar .pcoded-item .pcoded-submenu > li.active > a,
.pcoded-navbar .pcoded-item .pcoded-submenu > li.active > a .pcoded-mtext,
.pcoded-navbar .pcoded-item > li > a:hover,
.pcoded-navbar .pcoded-item > li > a:hover .pcoded-mtext,
.pcoded-navbar .pcoded-item .pcoded-submenu > li > a:hover,
.pcoded-navbar .pcoded-item .pcoded-submenu > li > a:hover .pcoded-mtext {
  color: var(--c-dorado) !important;
}

.pcoded-navbar .pcoded-item .pcoded-submenu > li.active > a:before,
.pcoded-navbar .pcoded-item .pcoded-submenu > li > a:hover:before {
  color: var(--c-dorado) !important;
}

/* Header blanco completo */
.pcoded .pcoded-header,
.pcoded .header-navbar {
  background: #fff !important;
}

.pcoded .pcoded-header .navbar-logo {
  background: #fff !important;
}

/* Iconos y texto del header en guinda/oscuro */
.pcoded .pcoded-header .ti-menu,
.pcoded .pcoded-header .ti-fullscreen,
.pcoded .pcoded-header .ti-angle-down,
.pcoded .pcoded-header .nav-left span {
  color: #611232 !important;
}

/* Aunque tengan class="text-white" */
.pcoded .pcoded-header .text-white {
  color: #611232 !important;
}

.pcoded .pcoded-header {
  border-bottom: 1px solid #E1E2E4 !important;
}

.btn-icon-only {
  background: transparent !important;
  border: 0 !important;
  padding: 0 .35rem !important;
  box-shadow: none !important;
  line-height: 1 !important;
  cursor: pointer !important;
}

.btn-icon-only i {
  font-size: 20px;
  vertical-align: middle;
}

.btn-icon-only:focus {
  outline: none !important;
  box-shadow: none !important;
}

.btn-icon-only[disabled] {
  cursor: not-allowed !important;
  opacity: .35;
  pointer-events: none;
}

.btnReenviar i {
  color: #611232;
}

.btnEliminar i {
  color: var(--c-guinda-oscuro);
}

.pcoded-header .navbar-logo .mobile-menu {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* ÍCONO BLANCO FORZADO */
.pcoded-header .navbar-logo .mobile-menu .icon_blanco { color: #ffffff !important; }
/* Icons styling */
.swal2-icon.swal2-success {
  border-color: var(--c-verde-4t) !important;
  color: var(--c-verde-4t) !important;
}
.swal2-icon.swal2-success [class^="swal2-success-line"] {
  background-color: var(--c-verde-4t) !important;
}
.swal2-icon.swal2-success .swal2-success-ring {
  border-color: rgba(35, 91, 78, 0.3) !important;
}

.swal2-icon.swal2-warning {
  border-color: var(--c-dorado) !important;
  color: var(--c-dorado) !important;
}
.swal2-icon.swal2-warning .swal2-icon-content {
  color: var(--c-dorado) !important;
}

.swal2-icon.swal2-info,
.swal2-icon.swal2-question {
  border-color: var(--c-dorado) !important;
  color: var(--c-dorado) !important;
}
.swal2-icon.swal2-info .swal2-icon-content,
.swal2-icon.swal2-question .swal2-icon-content {
  color: var(--c-dorado) !important;
}

.swal2-icon.swal2-error {
  border-color: var(--c-guinda-oscuro) !important;
  color: var(--c-guinda-oscuro) !important;
}
.swal2-icon.swal2-error [class^="swal2-x-mark-line"] {
  background-color: var(--c-guinda-oscuro) !important;
}

/* Botones Principales (Guinda) */
.swal2-styled.swal2-confirm {
  background-color: var(--c-guinda-claro) !important;
  color: var(--c-white) !important;
  border-radius: 4px !important;
  font-weight: 500 !important;
}

.swal2-styled.swal2-confirm:hover {
  background-color: var(--c-guinda-oscuro) !important;
}

.swal2-styled.swal2-confirm:focus {
  box-shadow: 0 0 0 3px rgba(159, 34, 65, 0.5) !important;
}

/* Deny / Destructive (Guinda text) */
.swal2-styled.swal2-deny {
  background-color: transparent !important;
  color: var(--c-guinda-oscuro) !important;
  border: 1px solid var(--c-guinda-oscuro) !important;
}

.swal2-styled.swal2-deny:hover {
  background-color: rgba(105, 28, 50, 0.1) !important;
}

/* Cancel Button (Gris/Outline) */
.swal2-styled.swal2-cancel {
  background-color: transparent !important;
  color: var(--c-text) !important;
  border: 1px solid var(--c-border) !important;
}

.swal2-styled.swal2-cancel:hover {
  background-color: #e2e6ea !important;
}

/* =========================
   OVERRIDE DE TIPOGRAFÍA (CABECERA PCODED)
========================= */
.page-header-title h4,
.page-header-title span,
.breadcrumb-item a {
  text-transform: none !important;
}

/* =========================
   SELECT2 INSTITUCIONAL (GUINDA / BLANCO)
========================= */
.select2-container--default .select2-selection--single,
.select2-container .select2-selection--single,
.select2-container--classic .select2-selection--single {
    height: 40px !important; 
    border: 1px solid var(--c-border) !important; 
    padding-top: 5px !important; 
    background-color: var(--c-white) !important;
    background: var(--c-white) !important;
    background-image: none !important;
    border-radius: 4px !important;
    box-shadow: none !important;
}
.select2-container--classic .select2-selection--single {
    background-image: none !important;
}
.select2-container--default .select2-selection--single .select2-selection__rendered,
.select2-container--classic .select2-selection--single .select2-selection__rendered {
    color: var(--c-text) !important;
    font-weight: 500;
}
.select2-container--default .select2-selection--single .select2-selection__arrow,
.select2-container--classic .select2-selection--single .select2-selection__arrow {
    top: 6px !important;
    background: transparent !important;
    background-image: none !important;
    border: none !important;
}
.select2-container--default.select2-container--open .select2-selection--single,
.select2-container--classic.select2-container--open .select2-selection--single {
    border-color: var(--c-guinda-claro) !important;
    background-color: var(--c-white) !important; 
    box-shadow: 0 0 0 0.15rem rgba(159, 34, 65, 0.25) !important;
}
.select2-results__option--highlighted[aria-selected],
.select2-results__option--highlighted {
    background-color: var(--c-guinda-claro) !important;
    color: var(--c-white) !important;
}
.select2-container--default .select2-selection--single .select2-selection__placeholder,
.select2-container--classic .select2-selection--single .select2-selection__placeholder {
    color: var(--c-gris-claro) !important;
}

/* Erradicar el azul de select2 dentro de input-groups de Bootstrap o plantillas agresivas */
.input-group .select2-container--default .select2-selection--single,
.input-group .select2-container--classic .select2-selection--single,
.form-group .select2-container--default .select2-selection--single,
select.form-control + .select2-container .select2-selection--single {
    background-color: var(--c-white) !important;
    background: var(--c-white) !important;
    background-image: none !important;
}
/* -- TARJETAS ACTIVAS -- */
.card-active-4t { /* Igual que las demas tarjetas */ }

/* === AULA VIRTUAL (ALUMNO) === */
.card-4t-shadow { border-radius: 8px; border: 1px solid var(--c-border); box-shadow: 0 1px 3px rgba(0,0,0,0.05); }
.text-4t-sm { font-size: 13px !important; }
.text-4t-md { font-size: 14px !important; font-weight: 500; }
.text-4t-title { font-size: 15px !important; font-weight: 600; color: var(--c-text); }
.chat-4t-container { max-height: 300px; overflow-y: auto; margin-bottom: 10px; padding-right: 5px; }
.avatar-4t-sm { width: 30px; height: 30px; border-radius: 50%; background: #f0f0f0; display: inline-flex; align-items: center; justify-content: center; }
.msg-4t-bubble { display: inline-block; padding: 8px 12px; border-radius: 8px; font-size: 13px; max-width: 85%; text-align: left; word-break: break-word; }
.msg-4t-mio { background-color: var(--c-guinda-claro); color: #fff; }
.msg-4t-otro { background-color: #f1f3f5; color: #333; }
.icon-4t-circle { width: 40px; height: 40px; border-radius: 50%; display: flex; align-items: center; justify-content: center; color: #fff; }

/* --- FIX MISSING --- */
.pcoded-header .navbar-logo .mobile-menu .icon_blanco { color: #ffffff !important; font-size: 16px !important; line-height: 1 !important; }
.swal2-title { color: var(--c-guinda-claro) !important; }
.swal2-container { z-index: 99999 !important; }


/* Extensiones para Asignaturas */
.bg-c-soft { background-color: #f8f9fa !important; }
.shadow-soft-4t { box-shadow: 0 2px 4px rgba(0,0,0,0.04) !important; border: 1px solid var(--c-border) !important; }

/* Fuerza bruta para SweetAlert2 V11 */
div:where(.swal2-icon).swal2-info,
body .swal2-icon.swal2-info {
  border-color: var(--c-dorado) !important;
  color: var(--c-dorado) !important;
}
div:where(.swal2-icon).swal2-info .swal2-icon-content,
body .swal2-icon.swal2-info .swal2-icon-content {
  color: var(--c-dorado) !important;
}

div:where(.swal2-icon).swal2-question,
body .swal2-icon.swal2-question {
  border-color: var(--c-dorado) !important;
  color: var(--c-dorado) !important;
}
div:where(.swal2-icon).swal2-question .swal2-icon-content,
body .swal2-icon.swal2-question .swal2-icon-content {
  color: var(--c-dorado) !important;
}

div:where(.swal2-icon).swal2-success,
body .swal2-icon.swal2-success {
  border-color: var(--c-verde-4t) !important;
  color: var(--c-verde-4t) !important;
}
div:where(.swal2-icon).swal2-success [class^="swal2-success-line"],
body .swal2-icon.swal2-success [class^="swal2-success-line"] {
  background-color: var(--c-verde-4t) !important;
}

div:where(.swal2-icon).swal2-error,
body .swal2-icon.swal2-error {
  border-color: var(--c-guinda-oscuro) !important;
  color: var(--c-guinda-oscuro) !important;
}
div:where(.swal2-icon).swal2-error [class^="swal2-x-mark-line"],
body .swal2-icon.swal2-error [class^="swal2-x-mark-line"] {
  background-color: var(--c-guinda-oscuro) !important;
}

div:where(.swal2-icon).swal2-warning,
body .swal2-icon.swal2-warning {
  border-color: var(--c-dorado) !important;
  color: var(--c-dorado) !important;
}
div:where(.swal2-icon).swal2-warning .swal2-icon-content,
body .swal2-icon.swal2-warning .swal2-icon-content {
  color: var(--c-dorado) !important;
}

/* Variables globales SWAL2 */
div:where(.swal2-container) {
    --swal2-info: #BC955C !important;
    --swal2-question: #BC955C !important;
    --swal2-warning: #BC955C !important;
    --swal2-error: #691C32 !important;
    --swal2-success: #235B4E !important;
}

/* ULTRA SOBREESCRITURA SWAL2 PARA SOLUCIONAR CACHE/ESPECIFICIDAD */
html body div.swal2-container.swal2-shown div.swal2-popup div.swal2-icon.swal2-info {
    border-color: #BC955C !important;
    color: #BC955C !important;
}
html body div.swal2-container.swal2-shown div.swal2-popup div.swal2-icon.swal2-info .swal2-icon-content {
    color: #BC955C !important;
}
html body div.swal2-container.swal2-shown div.swal2-popup div.swal2-icon.swal2-warning {
    border-color: #BC955C !important;
    color: #BC955C !important;
}
html body div.swal2-container.swal2-shown div.swal2-popup div.swal2-icon.swal2-warning .swal2-icon-content {
    color: #BC955C !important;
}
html body div.swal2-container.swal2-shown div.swal2-popup div.swal2-icon.swal2-question {
    border-color: #BC955C !important;
    color: #BC955C !important;
}
html body div.swal2-container.swal2-shown div.swal2-popup div.swal2-icon.swal2-question .swal2-icon-content {
    color: #BC955C !important;
}
html body div.swal2-container.swal2-shown div.swal2-popup div.swal2-icon.swal2-success {
    border-color: #235B4E !important;
    color: #235B4E !important;
}
html body div.swal2-container.swal2-shown div.swal2-popup div.swal2-icon.swal2-success [class^='swal2-success-line'] {
    background-color: #235B4E !important;
}
html body div.swal2-container.swal2-shown div.swal2-popup div.swal2-icon.swal2-error {
    border-color: #691C32 !important;
    color: #691C32 !important;
}
html body div.swal2-container.swal2-shown div.swal2-popup div.swal2-icon.swal2-error [class^='swal2-x-mark-line'] {
    background-color: #691C32 !important;
}

/* Forzar salto de linea en la tabla del modal de historial */
#tbodyHistorial td {
    white-space: normal !important;
    word-break: break-word;
}

/* =========================
   REESCRITURA DE ICONOS WIDGET (COLORES 4T)
========================= */
.user-detail .icofont-ui-user { color: var(--c-guinda-claro) !important; }
.user-detail .icofont-id-card { color: var(--c-guinda-oscuro) !important; }
.user-detail .icofont-barcode { color: var(--c-verde-4t) !important; }
.user-detail .icofont-hat-alt { color: var(--c-dorado) !important; }
.user-detail .icofont-book-alt { color: var(--c-arena) !important; }
.user-detail .icofont-ui-touch-phone { color: var(--c-verde-oscuro) !important; }
.user-detail .icofont-ui-email { color: var(--c-gris-oscuro) !important; }
.user-detail .icofont-users { color: var(--c-guinda-claro) !important; }

/* ==========================================================================
   FULLCALENDAR 4T THEME INTEGRATION
   ========================================================================== */
:root {
  --fc-button-bg-color: var(--c-guinda);
  --fc-button-border-color: var(--c-guinda);
  --fc-button-hover-bg-color: var(--c-guinda-oscuro);
  --fc-button-hover-border-color: var(--c-guinda-oscuro);
  --fc-button-active-bg-color: var(--c-guinda-oscuro);
  --fc-button-active-border-color: var(--c-guinda-oscuro);
  --fc-today-bg-color: rgba(179, 141, 69, 0.15); /* Dorado muy claro */
}

.fc-toolbar-title {
  color: var(--c-verde-oscuro) !important;
  font-weight: 600 !important;
  text-transform: capitalize;
}

.fc-col-header-cell-cushion {
  color: var(--c-guinda) !important;
  font-weight: bold;
}

.fc-daygrid-day-number {
  color: #333 !important;
}

.fc-event {
  border-radius: 4px;
  padding: 2px 4px;
  font-size: 11px;
}

/* ==========================================================================
   MODO OSCURO PREMIUM (Mexican 4T Aesthetic)
   ========================================================================== */
body.dark-mode {
  --c-bg: #121212;
  --c-text: #e0e0e0;
  --c-white: #1e1e1e;
  --c-border: #2d2d2d;
  --c-gris-claro: #2c2c2c;
  --c-arena: #8a7355;
  
  background-color: var(--c-bg) !important;
  color: var(--c-text) !important;
}

body.dark-mode .pcoded-content,
body.dark-mode .pcoded-inner-content,
body.dark-mode .main-body {
  background-color: var(--c-bg) !important;
}

/* Cabecera & Logo */
body.dark-mode .pcoded-header {
  background: #1a1a1a !important;
  border-bottom: 2px solid var(--c-dorado) !important;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.4) !important;
}
body.dark-mode .pcoded-header a {
  color: #ffffff !important;
}
body.dark-mode .pcoded-header .navbar-logo {
  background-color: #1a1a1a !important;
}
body.dark-mode .pcoded-header .nav-left h4 {
  color: #ffffff !important;
}
body.dark-mode .pcoded-header .nav-right .show-notification {
  background-color: #1e1e1e !important;
  box-shadow: 0 10px 30px rgba(0,0,0,0.5) !important;
  border: 1px solid #2d2d2d !important;
}
body.dark-mode .pcoded-header .nav-right .show-notification li h6 {
  color: #ffffff !important;
}
body.dark-mode .pcoded-header .nav-right .show-notification li:hover {
  background-color: #2a2a2a !important;
}
body.dark-mode .pcoded-header .nav-right .show-notification p.text-muted {
  color: #aaaaaa !important;
}
body.dark-mode .pcoded-header .nav-right .show-notification .hover-bg-light:hover {
  background-color: #2a2a2a !important;
}
body.dark-mode .pcoded-header .nav-right .profile-notification {
  background-color: #1e1e1e !important;
}
body.dark-mode .pcoded-header .nav-right .profile-notification a {
  color: #e0e0e0 !important;
}
body.dark-mode .pcoded-header .nav-right .profile-notification li:hover {
  background-color: #2a2a2a !important;
}

/* Sidebar / Navbar */
body.dark-mode .pcoded-navbar {
  background: #1a1a1a !important;
  box-shadow: 2px 0 10px rgba(0, 0, 0, 0.3) !important;
  border-right: 1px solid #2d2d2d !important;
}
body.dark-mode .pcoded-navbar .pcoded-item > li > a {
  color: #e0e0e0 !important;
}
body.dark-mode .pcoded-navbar .pcoded-item > li > a > .pcoded-micon {
  color: var(--c-dorado) !important;
  border-color: #3d3d3d !important;
}
body.dark-mode .pcoded-navbar .pcoded-item > li > a:hover {
  background-color: #2a2a2a !important;
  color: var(--c-dorado) !important;
}
body.dark-mode .pcoded-navbar .pcoded-item > li > a:hover > .pcoded-micon {
  background-color: #2d2318 !important;
  border-color: var(--c-dorado) !important;
}
body.dark-mode .pcoded-navbar .pcoded-item > li.active > a {
  background-color: #2d2318 !important;
  color: var(--c-dorado) !important;
}
body.dark-mode .pcoded-navbar .pcoded-item > li.active > a > .pcoded-micon {
  color: var(--c-dorado) !important;
  border-color: var(--c-dorado) !important;
}
body.dark-mode .pcoded-navbar[navbar-theme="themelight1"] .pcoded-navigatio-lavel {
  background-color: #222222 !important;
  color: #888888 !important;
}
body.dark-mode .pcoded-navbar .pcoded-item .pcoded-hasmenu .pcoded-submenu {
  background-color: #1f1f1f !important;
}
body.dark-mode .pcoded-navbar .pcoded-item .pcoded-hasmenu .pcoded-submenu > li > a {
  color: #cccccc !important;
}
body.dark-mode .pcoded-navbar .pcoded-item .pcoded-hasmenu .pcoded-submenu > li > a:hover {
  color: var(--c-dorado) !important;
  background-color: #2a2a2a !important;
}

/* Tarjetas (Cards) */
body.dark-mode .card {
  background-color: var(--c-white) !important;
  border: 1px solid var(--c-border) !important;
  box-shadow: 0 4px 20px rgba(0,0,0,0.2) !important;
}
body.dark-mode .card .card-header {
  background-color: rgba(255, 255, 255, 0.02) !important;
  border-bottom: 1px solid var(--c-border) !important;
}
body.dark-mode .card .card-header h5,
body.dark-mode .card .card-header h4,
body.dark-mode .card .card-header span {
  color: #ffffff !important;
}
body.dark-mode .card-block,
body.dark-mode .card-body {
  color: var(--c-text) !important;
}
body.dark-mode .page-header.card {
  background-color: #1e1e1e !important;
}
body.dark-mode .page-header h5 {
  color: #ffffff !important;
}
body.dark-mode .page-header span {
  color: #aaaaaa !important;
}

/* Widgets e Indicadores */
body.dark-mode .text-muted {
  color: #aaaaaa !important;
}
body.dark-mode .text-inverse,
body.dark-mode .text-dark {
  color: #ffffff !important;
}
body.dark-mode .card.widget-card,
body.dark-mode .card.statistic-card {
  background-color: #1e1e1e !important;
}
body.dark-mode .card.widget-card h4,
body.dark-mode .card.widget-card h3,
body.dark-mode .card.widget-card h2 {
  color: #ffffff !important;
}
body.dark-mode .card.widget-card span {
  color: #bbbbbb !important;
}

/* Formularios */
body.dark-mode .form-control,
body.dark-mode .custom-select,
body.dark-mode select {
  background-color: #252525 !important;
  color: #e0e0e0 !important;
  border: 1px solid #3d3d3d !important;
}
body.dark-mode .form-control:focus,
body.dark-mode .custom-select:focus {
  border-color: var(--c-dorado) !important;
  background-color: #2d2d2d !important;
  color: #ffffff !important;
}
body.dark-mode label {
  color: #cccccc !important;
}

/* Tablas */
body.dark-mode table.table,
body.dark-mode .table {
  color: var(--c-text) !important;
}
body.dark-mode .table thead th {
  background-color: #252525 !important;
  color: #ffffff !important;
  border-bottom: 2px solid var(--c-border) !important;
}
body.dark-mode .table td,
body.dark-mode .table th {
  border-top: 1px solid var(--c-border) !important;
  color: var(--c-text) !important;
}
body.dark-mode .table-hover tbody tr:hover {
  background-color: rgba(255, 255, 255, 0.04) !important;
  color: #ffffff !important;
}

/* Modales */
body.dark-mode .modal-content {
  background-color: #1e1e1e !important;
  color: #e0e0e0 !important;
  border: 1px solid #2d2d2d !important;
}
body.dark-mode .modal-header {
  border-bottom: 1px solid #2d2d2d !important;
}
body.dark-mode .modal-header h5,
body.dark-mode .modal-header h6,
body.dark-mode .modal-header .modal-title {
  color: #ffffff !important;
}
body.dark-mode .modal-footer {
  border-top: 1px solid #2d2d2d !important;
}
body.dark-mode .modal .close {
  color: #ffffff !important;
  text-shadow: none !important;
}

/* Paginación y DataTables */
body.dark-mode .page-link {
  background-color: #252525 !important;
  border-color: #3d3d3d !important;
  color: var(--c-text) !important;
}
body.dark-mode .page-item.active .page-link {
  background-color: var(--c-guinda-claro) !important;
  border-color: var(--c-guinda-claro) !important;
  color: #ffffff !important;
}
body.dark-mode .dataTables_wrapper {
  color: var(--c-text) !important;
}
body.dark-mode .dataTables_wrapper select,
body.dark-mode .dataTables_wrapper input {
  background-color: #252525 !important;
  color: #ffffff !important;
  border: 1px solid #3d3d3d !important;
}

/* Footer visual */
body.dark-mode div[style*="background:#fafafa"] {
  background-color: #1a1a1a !important;
  border-top: 1px solid #2d2d2d !important;
  color: #aaaaaa !important;
}

/* SweetAlert2 en Modo Oscuro */
body.dark-mode .swal2-popup {
  background-color: #1e1e1e !important;
  color: #ffffff !important;
}
body.dark-mode .swal2-title,
body.dark-mode .swal2-html-container {
  color: #ffffff !important;
}

/* FullCalendar corrección color de fecha */
body.dark-mode .fc-daygrid-day-number {
  color: #e0e0e0 !important;
}

/* Botón flotante o menú items con fondo gris */
body.dark-mode .bg-light,
body.dark-mode .hover-bg-light:hover {
  background-color: #2a2a2a !important;
}

/* Sobrescritura de colores para pestañas (Bootstrap tabs / md-tabs) */
.md-tabs .nav-item .nav-link.active,
.md-tabs .nav-item .nav-link.active:focus,
.md-tabs .nav-item .nav-link.active:hover {
  color: var(--c-guinda-claro) !important;
}
.md-tabs .nav-item .nav-link.active ~ .slide {
  background-color: var(--c-guinda-claro) !important;
}


/* TIMELINE SERVICIO SOCIAL */
.card-notification.border-theme-done:before { border-color: var(--c-verde-4t) !important; }
.card-notification.border-theme-active:before { border-color: var(--c-dorado) !important; }
.card-notification.border-theme-pending:before { border-color: var(--c-gris-claro) !important; }

/* TIMELINE HORIZONTAL (PROGRESO) */
.timeline-container { position: relative; display: flex; justify-content: space-between; align-items: flex-start; padding: 20px 0; }
.timeline-line { position: absolute; top: 37px; left: 6%; right: 6%; height: 3px; background: var(--c-border); z-index: 1; }
.timeline-step { flex: 1; text-align: center; position: relative; z-index: 2; }
.timeline-icon {
    width: 38px; height: 38px; border-radius: 50%; background: var(--c-white); border: 3px solid var(--c-border);
    display: inline-flex; align-items: center; justify-content: center; font-weight: bold; font-size: 14px; margin: 0 auto;
    transition: all 0.3s ease;
}
.timeline-step.done .timeline-icon { border-color: var(--c-verde-4t); background: var(--c-verde-4t); color: var(--c-white); box-shadow: 0 0 0 3px rgba(35, 91, 78, 0.2); }
.timeline-step.active .timeline-icon { border-color: var(--c-guinda-claro); color: var(--c-guinda-claro); background: var(--c-white); box-shadow: 0 0 0 3px rgba(159, 34, 65, 0.2); }



.orden-inspeccion-card {
    border: 1px solid #d9dee7;
    border-radius: 6px;
    box-shadow: 0 6px 18px rgba(30, 41, 59, 0.08);
    background: #ffffff;
    overflow: hidden;
}

.orden-inspeccion-header {
    padding: 26px 34px 18px 34px;
    border-bottom: 1px solid #edf0f5;
}

.orden-inspeccion-title {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 0;
    color: #1f2937;
    font-size: 20px;
    font-weight: 700;
}

.orden-inspeccion-title i {
    color: #353d4a;
    font-size: 18px;
}

.orden-inspeccion-line {
    width: 38px;
    height: 3px;
    background: var(--c-guinda-claro);
    margin-top: 16px;
    border-radius: 4px;
}

.orden-section {
    padding: 24px 34px;
    border-bottom: 1px solid #edf0f5;
}

.orden-section:last-child {
    border-bottom: none;
}

.orden-label {
    font-weight: 700;
    color: #1f2937;
    margin-bottom: 10px;
    font-size: 14px;
}

.orden-help {
    color: #7b8494;
    font-size: 12px;
    margin-top: 8px;
    margin-bottom: 0;
}

.orden-control-row {
    display: flex;
    align-items: stretch;
    gap: 14px;
}

.orden-icon-box {
    width: 52px;
    min-width: 52px;
    height: 52px;
    border-radius: 4px;
    background: #f6f7fa;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--c-guinda-claro);
    font-size: 18px;
}

.orden-inspeccion-card .form-control,
.orden-inspeccion-card .select2-container--default .select2-selection--single {
    height: 52px;
    border-radius: 4px;
    border: 1px solid #cfd6e1;
    color: #353d4a;
    font-size: 14px;
    box-shadow: none;
}

.orden-inspeccion-card .select2-container--default .select2-selection--single .select2-selection__rendered {
    line-height: 52px;
}

.orden-inspeccion-card .select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 50px;
}

.orden-inspeccion-card .form-control:focus {
    border-color: var(--c-guinda-claro);
    box-shadow: 0 0 0 0.12rem rgba(155, 34, 71, 0.12);
}

.azar-box {
    display: flex;
    align-items: center;
    gap: 14px;
    height: 100%;
}

.btn-azar {
    min-width: 150px;
    height: 58px;
    border: 1px solid var(--c-dorado);
    color: var(--c-dorado);
    background: transparent;
    border-radius: 3px;
    font-weight: 700;
    transition: all 0.2s ease-in-out;
}

.btn-azar:hover {
    background: rgba(179, 141, 69, 0.08);
    color: var(--c-guinda-claro);
    border-color: var(--c-guinda-claro);
}

.azar-text {
    color: #7b8494;
    font-size: 12px;
    line-height: 1.5;
    margin: 0;
    max-width: 260px;
}

.notificacion-box {
    background: #f8f9fb;
    border: 1px solid #edf0f5;
    border-radius: 4px;
    padding: 20px 22px;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 28px;
}

.radio-option {
    display: flex;
    align-items: center;
    gap: 9px;
    color: #353d4a;
    font-size: 14px;
    margin-bottom: 0;
    cursor: pointer;
}

.radio-option input {
    accent-color: var(--c-guinda-claro);
}

.radio-option i {
    color: #353d4a;
    font-size: 16px;
}

.orden-actions {
    padding: 26px 34px;
    display: flex;
    justify-content: flex-end;
    background: #ffffff;
}

.btn-programar-outline {
    min-width: 230px;
    height: 56px;
    border: 1px solid var(--c-guinda-claro);
    color: var(--c-guinda-claro);
    background: transparent;
    border-radius: 3px;
    font-weight: 700;
    font-size: 15px;
    transition: all 0.2s ease-in-out;
}

.btn-programar-outline:hover {
    background: rgba(155, 34, 71, 0.08);
    color: var(--c-guinda);
    border-color: var(--c-guinda);
}

.btn-programar-outline i {
    margin-right: 8px;
}

@media (max-width: 768px) {
    .orden-inspeccion-header,
    .orden-section,
    .orden-actions {
        padding-left: 20px;
        padding-right: 20px;
    }

    .orden-control-row {
        flex-direction: column;
    }

    .orden-icon-box {
        width: 100%;
    }

    .azar-box {
        flex-direction: column;
        align-items: flex-start;
    }

    .btn-azar,
    .btn-programar-outline {
        width: 100%;
    }

    .orden-actions {
        justify-content: center;
    }

    .notificacion-box {
        flex-direction: column;
        align-items: flex-start;
        gap: 14px;
    }
}


/* BITACORA Y MAPA PREMIUM STYLES */
.bitacora-card { border: 1px solid #d9dee7; border-radius: 6px; background: #ffffff; box-shadow: 0 6px 18px rgba(30, 41, 59, 0.08); overflow: hidden; height: 100%; }
.bitacora-card-header { padding: 22px 26px 14px 26px; border-bottom: 1px solid #edf0f5; background: #ffffff; }
.bitacora-title { display: flex; align-items: center; gap: 12px; margin: 0; color: #1f2937; font-size: 18px; font-weight: 700; }
.bitacora-title i { color: #9b2247; font-size: 18px; }
.bitacora-line { width: 38px; height: 3px; background: #9b2247; margin-top: 14px; border-radius: 4px; }
.bitacora-card-body { padding: 22px 26px 26px 26px; }
.mapa-contenedor { position: relative; width: 100%; height: 455px; border: 1px solid #d9dee7; border-radius: 6px; overflow: hidden; background: #f3f4f6; }
#map { width: 100%; height: 100%; }
.mapa-leyenda { position: absolute; right: 16px; bottom: 16px; background: rgba(255, 255, 255, 0.96); border: 1px solid #d9dee7; border-radius: 6px; padding: 10px 14px; box-shadow: 0 4px 12px rgba(30, 41, 59, 0.12); z-index: 500; }
.mapa-leyenda-item { display: flex; align-items: center; gap: 8px; color: #353d4a; font-size: 12px; margin-bottom: 6px; }
.mapa-leyenda-item:last-child { margin-bottom: 0; }
.leyenda-dot { width: 11px; height: 11px; border-radius: 50%; display: inline-block; }
.dot-programada { background: #9b2247; }
.dot-proceso { background: #b38d45; }
.dot-completada { background: #2f8f46; }
.stats-row { margin-top: 18px; }
.stat-card { border: 1px solid #edf0f5; border-radius: 6px; background: #ffffff; padding: 18px; display: flex; align-items: center; gap: 14px; height: 100%; transition: all 0.2s ease-in-out; }
.stat-card:hover { transform: translateY(-2px); box-shadow: 0 6px 16px rgba(30, 41, 59, 0.08); }
.stat-icon { width: 52px; min-width: 52px; height: 52px; border-radius: 6px; display: flex; align-items: center; justify-content: center; font-size: 24px; }
.stat-programadas { background: rgba(155, 34, 71, 0.08); color: #9b2247; }
.stat-proceso { background: rgba(179, 141, 69, 0.12); color: #b38d45; }
.stat-completadas { background: rgba(47, 143, 70, 0.10); color: #2f8f46; }
.stat-mes { background: rgba(53, 61, 74, 0.08); color: #353d4a; }
.stat-number { margin: 0; color: #1f2937; font-size: 28px; font-weight: 700; line-height: 1; }
.stat-label { margin: 5px 0 0 0; color: #6b7280; font-size: 13px; }
.visitas-lista { padding: 22px; max-height: 625px; overflow-y: auto; }
.visita-item { border: 1px solid #edf0f5; border-radius: 6px; background: #ffffff; padding: 14px; display: flex; gap: 14px; margin-bottom: 14px; transition: all 0.2s ease-in-out; cursor: pointer; }
.visita-item:hover { border-color: rgba(155, 34, 71, 0.28); box-shadow: 0 6px 16px rgba(30, 41, 59, 0.08); }
.visita-fecha { width: 64px; min-width: 64px; border-radius: 6px; background: rgba(155, 34, 71, 0.06); text-align: center; padding: 10px 6px; }
.visita-fecha.proceso { background: rgba(179, 141, 69, 0.10); }
.visita-fecha.completada { background: rgba(47, 143, 70, 0.10); }
.visita-dia { display: block; color: #9b2247; font-size: 26px; font-weight: 800; line-height: 1; }
.visita-fecha.proceso .visita-dia { color: #b38d45; }
.visita-fecha.completada .visita-dia { color: #2f8f46; }
.visita-mes { display: block; margin-top: 6px; color: #353d4a; font-size: 11px; font-weight: 700; text-transform: uppercase; }
.visita-info { flex: 1; min-width: 0; }
.visita-nombre { margin: 0; color: #1f2937; font-size: 14px; font-weight: 700; text-transform: uppercase; }
.visita-lugar { margin: 4px 0 0 0; color: #6b7280; font-size: 12px; }
.visita-direccion { margin: 8px 0 0 0; color: #6b7280; font-size: 12px; display: flex; align-items: center; gap: 6px; }
.visita-direccion i { color: #6b7280; }
.visita-status { align-self: center; padding: 5px 10px; border-radius: 50px; font-size: 10px; font-weight: 800; text-transform: uppercase; white-space: nowrap; }
.status-programada { background: #9b2247; color: #ffffff; }
.status-proceso { background: #b38d45; color: #ffffff; }
.status-completada { background: #2f8f46; color: #ffffff; }
.btn-bitacora-outline { width: 100%; height: 46px; border: 1px solid #9b2247; color: #9b2247; background: transparent; border-radius: 4px; font-weight: 700; transition: all 0.2s ease-in-out; }
.btn-bitacora-outline:hover { background: rgba(155, 34, 71, 0.08); color: #7b1738; border-color: #7b1738; }
.info-card { margin-top: 26px; border: 1px solid #d9dee7; border-radius: 6px; background: #ffffff; box-shadow: 0 6px 18px rgba(30, 41, 59, 0.08); padding: 20px 26px; display: flex; align-items: flex-start; gap: 16px; }
.info-icon { width: 38px; min-width: 38px; height: 38px; border-radius: 6px; background: rgba(155, 34, 71, 0.08); color: #9b2247; display: flex; align-items: center; justify-content: center; font-size: 18px; }
.info-title { margin: 0; color: #9b2247; font-size: 15px; font-weight: 700; }
.info-text { margin: 6px 0 0 0; color: #7b8494; font-size: 13px; }
@media (max-width: 991px) { .mapa-contenedor { height: 380px; } .visitas-lista { max-height: none; } }
@media (max-width: 768px) { .bitacora-card-header, .bitacora-card-body, .visitas-lista { padding-left: 18px; padding-right: 18px; } .visita-item { flex-direction: column; } .visita-status { align-self: flex-start; } .mapa-contenedor { height: 330px; } }

/* GIANT MODAL STYLES */
.modal-orden-inspeccion .modal-dialog { max-width: 1320px; }
.modal-orden-inspeccion .modal-content { border: none; border-radius: 10px; overflow: hidden; box-shadow: 0 18px 50px rgba(0, 0, 0, 0.28); }
.modal-orden-header { background: linear-gradient(135deg, #7b1738, #9b2247); color: #ffffff; padding: 22px 30px; display: flex; align-items: center; justify-content: space-between; }
.modal-orden-title { margin: 0; font-size: 22px; font-weight: 800; display: flex; align-items: center; gap: 12px; }
.modal-orden-close { color: #ffffff; opacity: 1; font-size: 24px; font-weight: 400; background: transparent; border: 0; outline: none; cursor: pointer; }
.modal-orden-body { background: #f5f7fb; padding: 26px; }
.orden-layout { display: grid; grid-template-columns: 48% 52%; gap: 24px; }
.orden-panel { background: #ffffff; border: 1px solid #e1e6ef; border-radius: 8px; box-shadow: 0 8px 22px rgba(30, 41, 59, 0.08); overflow: hidden; }
.orden-panel-header { padding: 18px 22px; border-bottom: 1px solid #edf0f5; display: flex; align-items: center; justify-content: space-between; }
.orden-panel-title { margin: 0; color: #1f2937; font-size: 15px; font-weight: 800; text-transform: uppercase; letter-spacing: .5px; display: flex; align-items: center; gap: 9px; }
.orden-panel-title i { color: #9b2247; }
.btn-descargar-pdf { height: 38px; border: 1px solid #9b2247; background: #9b2247; color: #ffffff; border-radius: 5px; font-size: 13px; font-weight: 700; padding: 0 16px; cursor: pointer; }
.btn-descargar-pdf:hover { background: #7b1738; color: #ffffff; }
.orden-datos-body { padding: 22px; }
.orden-info-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
.orden-info-card { border: 1px solid #edf0f5; border-radius: 7px; padding: 16px; background: #ffffff; min-height: 105px; }
.orden-info-card-full { grid-column: 1 / -1; }
.orden-info-label { margin: 0 0 10px 0; color: #7b8494; font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .7px; display: flex; align-items: center; gap: 7px; }
.orden-info-label i { color: #9b2247; }
.orden-info-title { margin: 0; color: #1f2937; font-size: 16px; font-weight: 800; line-height: 1.3; }
.orden-info-sub { margin: 6px 0 0 0; color: #7b8494; font-size: 13px; line-height: 1.45; }
.orden-map-preview { height: 190px; border: 1px solid #d9dee7; border-radius: 6px; overflow: hidden; background: #f1f1f1; margin-top: 12px; }
.orden-actions-modal { display: flex; justify-content: center; gap: 14px; padding: 22px 0 0; }
.btn-modal-cerrar { min-width: 130px; height: 42px; border: 1px solid #6b7280; color: #353d4a; background: transparent; border-radius: 5px; font-weight: 700; cursor: pointer; }
.btn-modal-cerrar:hover { background: #f1f3f6; }
.btn-modal-imprimir { min-width: 190px; height: 42px; border: 1px solid #9b2247; color: #ffffff; background: #9b2247; border-radius: 5px; font-weight: 700; box-shadow: 0 8px 18px rgba(155, 34, 71, 0.22); cursor: pointer; }
.btn-modal-imprimir:hover { background: #7b1738; color: #ffffff; }
.orden-print-wrapper { background: #2f343b; padding: 22px; max-height: 720px; overflow-y: auto; overflow-x: auto; text-align: center; }
.orden-print-sheet { background: #ffffff; width: 21.59cm; min-height: 27.94cm; margin: 0 auto; padding: 1.2cm; color: #111827; box-shadow: 0 10px 30px rgba(0,0,0,.28); box-sizing: border-box; text-align: left; transform: scale(0.75); transform-origin: top center; margin-bottom: -25%; }
.print-header { display: grid; grid-template-columns: 90px 1fr 210px; gap: 18px; align-items: center; border-bottom: 3px solid #9b2247; padding-bottom: 18px; margin-bottom: 20px; }
.print-logo-box { width: 82px; height: 82px; border: 2px solid #9b2247; color: #9b2247; font-weight: 900; font-size: 24px; display: flex; align-items: center; justify-content: center; line-height: 1; text-align: center; }
.print-school { font-size: 12px; font-weight: 900; text-transform: uppercase; line-height: 1.35; }
.print-doc-title { text-align: right; }
.print-doc-title h4 { margin: 0; color: #9b2247; font-size: 16px; font-weight: 900; text-transform: uppercase; }
.print-doc-title p { margin: 5px 0 0; font-size: 11px; color: #4b5563; }
.print-section { margin-bottom: 10px; border: 1px solid #d9dee7; }
.print-section-title { background: #9b2247; color: #ffffff; display: inline-block; padding: 6px 12px; font-size: 11px; font-weight: 900; text-transform: uppercase; margin-top: -1px; margin-left: -1px; }
.print-section-body { padding: 8px 14px; }
.print-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.print-data-row { display: grid; grid-template-columns: 110px 1fr; gap: 4px; margin-bottom: 4px; font-size: 11px; line-height: 1.35; }
.print-data-row strong { color: #374151; }
.print-map { height: 170px; border: 1px solid #d9dee7; background: #f3f4f6; overflow: hidden; }
.print-observaciones { font-size: 11px; line-height: 1.5; color: #374151; }

.print-firma-line { border-top: 1px solid #6b7280; padding-top: 8px; font-weight: 700; }
@media (max-width: 1200px) { .orden-layout { grid-template-columns: 1fr; } .modal-orden-inspeccion .modal-dialog { max-width: 95%; } }
@media (max-width: 768px) { .modal-orden-body { padding: 16px; } .orden-info-grid { grid-template-columns: 1fr; } .orden-actions-modal { flex-direction: column; } .btn-modal-cerrar, .btn-modal-imprimir { width: 100%; } }

/* FSS Structure overrides for Modal (Screen Preview) */
#doc-wrapper.pdf-page { width: 21.59cm; min-height: 27.94cm; margin: 0 auto; background: white; padding: 1.5cm; padding-bottom: 4cm; box-sizing: border-box; position: relative; color: #111827; box-shadow: 0 10px 30px rgba(0,0,0,.28); text-align: left; transform: scale(0.7); transform-origin: top left; margin-bottom: -30%; }
#dgeti-header { width: 100%; box-sizing: border-box; background: white; padding-bottom: 10px; margin-bottom: 15px; }
#dgeti-footer { position: absolute; bottom: 0; left: 0; width: 100%; height: 4cm; text-align: center; z-index: 1;}
#dgeti-footer img { width: 100%; height: 100%; object-fit: cover; }
#dgeti-footer .footer-text { position: absolute; bottom: 8.5mm; left: 0; width: 100%; box-sizing: border-box; padding: 0 1.5cm; text-align: left; color: #b78a3c; font-size: 7.5pt; font-family: 'Montserrat', sans-serif; line-height: 1.3; }
.print-firmas { width: 100%; font-size: 10px; }
#printNombreJefeEscolar, #printNombreSupervisorFirma, #printNombreAlumnoFirma { font-size: 10px; }


/* AI_GUIDELINES Header Border */
.card-header-4t { border-top: 4px solid var(--c-guinda-claro) !important; box-shadow: 0 4px 15px rgba(0,0,0,0.1) !important; }

/* Overwrite input group addons to match institution theme */
.input-group-addon { background-color: transparent !important; border-color: var(--c-guinda-claro) !important; color: var(--c-guinda-claro) !important; font-weight: 600; }


/* =========================
   COMPONENTES GADGETS (Apegado a AI_GUIDELINES)
========================= */
.task-initial-avatar {
    width: 40px;
    height: 40px;
    line-height: 40px;
    border-radius: 50%;
    font-size: 16px;
}

.progress-mini-inline {
    width: 50px;
    height: 6px;
}

.table-text-dark {
    color: #2c3e50;
}

.badge-rounded-red {
    background-color: var(--c-guinda-claro, #9F2241) !important;
    border-radius: 50%;
    padding: 8px;
    min-width: 32px;
    text-align: center;
}

/* WIDGET CUSTOMERS */
.widget-customer-number {
    font-size: 36px !important;
}

.widget-customer-chart {
    height: 180px;
    width: 100%;
    margin-top: 15px;
}

/* WIDGET VISITAS ACTIVAS */
.visita-empty-icon { opacity: 0.5; }
.visita-empty-text { font-size: 13px; }
.visita-avatar-box {
    width: 45px;
    height: 45px;
    border-radius: 50%;
    background-color: #f4f6f8;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #e9ecef;
}
.visita-name { font-size: 14px; }
.visita-subtitle { font-size: 12px; font-weight: 500; text-transform: none; }
.visita-time-text { font-size: 12px; }
.visita-clock-box { border-left: 1px solid #e9ecef; }
.visita-elapsed-text { font-size: 13px; font-weight: 500; }
.visita-progress-container {
    height: 8px;
    border-radius: 10px;
    margin-top: 8px;
    background-color: #f0f0f0;
}
.visita-progress-bar { border-radius: 10px; }

/* INICIO PREFECTURA EXTRACTED CLASSES */
.page-header-4t { border-top: 4px solid var(--c-dorado); box-shadow: 0 4px 15px rgba(0,0,0,0.1); }
.border-top-verde-4t { border-top: 4px solid var(--c-verde-4t); }
.border-top-dorado { border-top: 4px solid var(--c-dorado); }
.border-top-guinda-claro { border-top: 4px solid var(--c-guinda-claro); }
.border-top-guinda-oscuro { border-top: 4px solid var(--c-guinda-oscuro); }

.bg-verde-4t-icon { background-color: var(--c-verde-4t) !important; color: white; }
.bg-dorado-icon { background-color: var(--c-dorado) !important; color: white; }
.bg-guinda-claro-icon { background-color: var(--c-guinda-claro) !important; color: white; }
.bg-guinda-oscuro-icon { background-color: var(--c-guinda-oscuro) !important; color: white; }

.section-title-4t { border-bottom: 2px solid var(--c-dorado); padding-bottom: 5px; }
.chart-subtitle { font-size: 13px; }
.chart-350 { width: 100%; height: 350px; }
.chart-300 { width: 100%; height: 300px; }

/* Botones Primarios y de Contorno (Override de Bootstrap para tema 4T) */
.btn-primary {
    background-color: var(--c-guinda-claro) !important;
    border-color: var(--c-guinda-claro) !important;
    color: #fff !important;
}
.btn-primary:hover, .btn-primary:focus, .btn-primary:active {
    background-color: var(--c-guinda-oscuro) !important;
    border-color: var(--c-guinda-oscuro) !important;
    color: #fff !important;
}
.btn-outline-primary {
    color: var(--c-guinda-claro) !important;
    border-color: var(--c-guinda-claro) !important;
    background-color: transparent !important;
}
.btn-outline-primary:hover, .btn-outline-primary:focus, .btn-outline-primary:active, .btn-outline-primary.active {
    background-color: var(--c-guinda-claro) !important;
    border-color: var(--c-guinda-claro) !important;
    color: #fff !important;
}
