@font-face {
  font-family: "Lato";
  src: url("/css/base/Lato/Lato-Thin.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
}

@font-face {
  font-family: "Lato";
  src: url("/css/base/Lato/Lato-ThinItalic.ttf") format("truetype");
  font-weight: 400;
  font-style: italic;
}

@font-face {
  font-family: "Lato";
  src: url("/css/base/Lato/Lato-Light.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
}

@font-face {
  font-family: "Lato";
  src: url("/css/base/Lato/Lato-LightItalic.ttf") format("truetype");
  font-weight: 400;
  font-style: italic;
}

@font-face {
  font-family: "Lato";
  src: url("/css/base/Lato/Lato-Regular.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
}

@font-face {
  font-family: "Lato";
  src: url("/css/base/Lato/Lato-Italic.ttf") format("truetype");
  font-weight: 400;
  font-style: italic;
}

@font-face {
  font-family: "Lato";
  src: url("/css/base/Lato/Lato-Bold.ttf") format("truetype");
  font-weight: 700;
  font-style: normal;
}

@font-face {
  font-family: "Lato";
  src: url("/css/base/Lato/Lato-BoldItalic.ttf") format("truetype");
  font-weight: 700;
  font-style: italic;
}

@font-face {
  font-family: "Lato";
  src: url("/css/base/Lato/Lato-Black.ttf") format("truetype");
  font-weight: 900;
  font-style: normal;
}

@font-face {
  font-family: "Lato";
  src: url("/css/base/Lato/Lato-BlackItalic.ttf") format("truetype");
  font-weight: 900;
  font-style: italic;
}

body {
  font-size: clamp(14px, 1rem + 0.4vw, 18px);
  line-height: 1.6;
}

p,
li,
span,
button {
  font-size: 1em;
  /* hereda del body */
}

/* Botón del acordeón responsivo */
.accordion-button {
  font-size: clamp(12px, 1rem + 0.3vw, 18px);
}

.borderUno {
  border: solid 1px #6ca6ff;
}

/* Si quieres que el texto sea más pequeño en pantallas pequeñas */
.accordion-button-sm {
  font-size: 0.875rem;
  /* Botón más pequeño */
}

/* ============================ 
   MENÚ Y VISTAS RESPONSIVAS
   ============================ */

/* Menú de navegación para móviles */
.navbar-mobile {
  display: flex;
}

/* Menú de navegación para escritorio */
.navbar-desktop {
  display: none;
}

.fondoDesenfoque {
  backdrop-filter: blur(5px);
  background: rgba(209, 231, 255, 0.2);
  backdrop-filter: blur(8px);
}

.borderBottom {
  border-bottom: 0.2px solid #d1e7ff;
}

.borderEnd {
  border-right: 0.2px solid #d1e7ff;
}

.borderTop {
  border-top: 0.2px solid #d1e7ff;
}

.navbar-nav .nav-link.active,
.navbar-nav .nav-link.show {
  color: #003acc;
}

.navbar-nav .nav-link:hover {
  color: #003acc;
}

/*Cambio a minusculas*/
.text-capitalize-fix {
  text-transform: lowercase;
}

.text-capitalize-fix::first-letter {
  text-transform: uppercase;
}

/* Cambio de visibilidad según el tamaño de pantalla */
@media (min-width: 992px) {
  /* Escritorio */
  .navbar-mobile {
    display: none;
  }

  .navbar-desktop {
    display: flex;
  }
}

body {
  font-family: "Lato", sans-serif;
  font-weight: 400;
  /* Regular por defecto */
}

.main_general {
  padding-top: 120px;
}

@media (max-width: 765px) {
  .main_general {
    padding-top: 160px;
  }
}

@media (max-width: 576px) {
  .main_general {
    padding-top: 180px;
  }
}

.backgroundUno {
  background-color: rgb(16, 44, 85);
}

.backgroundDos {
  background-color: #d1e7ff;
}

.backgroundTres {
  background-color: #f0f7ff;
}

.backgroundCuatro {
  background-color: #12438b;
}

.backgroundCinco {
  background-color: #0058ffbf;
}

.backgroundSeis {
  background-color: #9cc9ff;
}

.backgroundSiete {
  background-color: rgba(156, 201, 255, 0.75);
}

.backgroundOcho {
  background-color: rgba(126, 176, 216, 0.804);
}

.backgroundNueve {
  background-color: #f7f7f7;
}

.backgroundDiez {
  background-color: #fafafa;
}

.backgroundOnce {
  background-color: #00a019;
}

.backgroundDoce {
  background-color: rgb(9, 26, 52);
}

.backgroundTrece {
  background-color: #f8f9fa;
}

.backgroundCatorce {
  background-color: #102c55;
}

.backgroundQuience {
  background-color: #ffffff;
}

.colorUno {
  color: #0056b3;
}

.colorDos {
  color: #454545;
}

.colorTres {
  color: #0058ff;
}

.colorCuatro {
  color: #d1e7ff;
}

.colorCinco {
  color: #a4bcdd;
}

.colorSeis {
  color: #0275de;
}

.colorSiete {
  color: #707070;
}

.colorOcho {
  color: #00a019;
}

.borderOcho {
  border: solid 8px #f0f7ff;
}

.borderTopUno {
  border-top: 1px solid #93c4fc !important;
}

.borderDos {
  border: #e41c1c;
}

/*Botones*/
.btnEstiloUho {
  border-radius: 999px;
  background-color: #ffffff !important;
  /* Color original */
  border-color: #ffffff;
  color: #102c55;
}

.btnEstiloUho:hover {
  background-color: #12438b !important;
  /* Nuevo color en hover */
  border-color: #12438b !important;
  color: #d1e7ff;
}

/*Breadcrumb*/
.breadcrumb-item + .breadcrumb-item::before {
  content: "|";
  padding: 0.25 0.25rem;
  color: #6c757d;
  /* Color opcional */
}

.breadcrumb a {
  color: #12438b;
  text-decoration: none;
}

.breadcrumb a:hover {
  text-decoration: underline;
  color: #0056b3;
}

.breadcrumb-scroll {
  overflow-x: auto;
  white-space: nowrap;
  padding: 0.5rem 0;
  background-color: #f8f9fa;
  border-radius: 0.375rem;
}

.breadcrumb {
  flex-wrap: nowrap !important;
}

.breadcrumb-item {
  max-width: 250px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.breadcrumb-item a {
  text-decoration: none;
  display: inline-block;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.badge-nuevo {
  position: absolute;
  top: 5px;
  /* Le damos un poquito más de espacio */
  right: 0px;
  /* Y también del lado derecho */
  background: #2059d5;
  /* Blanco se ve mejor en azul */
  color: white;
  /* Color azul del fondo */
  padding: 5px 20px;
  /* Más padding para que se vea mejor */
  border-radius: 20px 0 0 20px;
  /* Más redondeado como en la imagen */
  font-size: 1.2rem;
  font-weight: bold;
  z-index: 10;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
  /* Sombrita para que resalte */
}

.btn-editar {
  --bs-btn-hover-color: #fff;
  /* color del texto */
  --bs-btn-hover-bg: #0058ff;
  /* fondo rojo */
  --bs-btn-hover-border-color: #0058ff;
  /* borde rojo */
}

.btn-editar_dos {
  --bs-btn-hover-color: white;
  /* color del texto */
  --bs-btn-hover-bg: #0058ff;
  /* fondo rojo */
  --bs-btn-hover-border-color: #0058ff;
  /* borde rojo */
}

.btn-editar_dos a {
  text-decoration: none;
  /* quita subrayado siempre */
}

/* Solo en hover del botón, cambiar el color del link */
.btn-editar_dos:hover a {
  color: white !important;
  /* color del texto solo al pasar el mouse */
}

.footer {
  background: #f6faff;
  padding: 64px 24px 40px;
}

.footer-container {
  max-width: 1200px;
  margin: 0 auto;
  text-align: center;
}

.footer-logo img {
  height: 42px;
  margin-bottom: 24px;
}

.footer-divider {
  border: none;
  border-top: 1px solid #e5e7eb;
  margin: 32px 0;
}

.footer-columns {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 48px;
  text-align: left;
}

.contact-col {
  text-align: center;
}

.marketing-col {
  text-align: end;
}

.footer-col h4 {
  font-size: 15px;
  color: #374151;
  margin-bottom: 12px;
}

.footer-col ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-col li {
  margin-bottom: 10px;
}

.footer-col a {
  color: #6b7280;
  text-decoration: none;
}

.footer-col a:hover {
  color: #111827;
}

.footer-social {
  list-style: none;
  display: flex;
  justify-content: flex-end;
  gap: 20px;
  padding: 0;
  margin: 0px 0;
  flex-wrap: wrap;
  flex-direction: row-reverse;
}

.tl_filter_select_gray_color_text {
  color: #b0b0b0;
}

.custom_loader {
  margin: 60px auto 30px auto;
  width: 50px;
  padding: 8px;
  aspect-ratio: 1;
  border-radius: 50%;
  background: #102c55;
  --_m: conic-gradient(#0000 10%, #000), linear-gradient(#000 0 0) content-box;
  -webkit-mask: var(--_m);
  mask: var(--_m);
  -webkit-mask-composite: source-out;
  mask-composite: subtract;
  animation: l3 1s infinite linear;
}

@keyframes l3 {
  to {
    transform: rotate(1turn);
  }
}

.footer-social a {
  font-size: 20px;
  color: #9ca3af;
  transition:
    transform 0.2s ease,
    color 0.2s ease;
}

.login_error_message_container {
  display: flex;
  justify-content: space-between;
  background-color: #edd6d4;
  border: darken(#edd6d4, 20%) 2px solid;
  border-radius: 10px;
  width: 90%;
  margin: 10px auto;

  padding: 10px;
}

.login_error_message {
  color: #b83c37;
  height: 100%;
  display: flex;
  align-items: center;
  font-size: 16px;
  text-align: center;
}

.register_error_message_container {
  display: flex;
  justify-content: space-between;
  background-color: #edd6d4;
  border: darken(#edd6d4, 20%) 2px solid;
  border-radius: 10px;
  width: 90%;
  margin: 10px auto;
  padding: 10px;
}

.register_error_message {
  color: #b83c37;
  height: 100%;
  display: flex;
  align-items: center;
  font-size: 16px;
  text-align: center;
}

.button_text_link_login_modal {
  border: none;
  outline: none;
  background-color: transparent;
  color: #0066ff;
  text-decoration: none;
}

.button_text_link_login_modal:hover {
  color: #6da6fc;
}

  /* ESTILOS PARA EL AVISO DE COOKIES */
.cookie-banner {
            position: fixed;
            right: 20px;
            bottom: 20px;
            top: auto;
            left: auto;
            z-index: 9999;
            border: 1.5px solid rgba(22, 85, 255, 0.2);
            background: linear-gradient(135deg, #d9e9ff 0%, #e6f2ff 100%);
            border-radius: 14px;
            padding: 18px 20px;
            max-width: 420px;
            width: auto;
            box-shadow: 0 8px 22px rgba(0, 0, 0, 0.12);
            display: block;
            max-width: 350px;
            align-items: center;
            gap: 12px;
        }

        .cookie-text p {
            margin: 0;
            font-size: 14px;
            line-height: 1.4;
            color: #2c3e50;
            margin-right: 8px;
            padding: 0 0 1rem 0;
        }

        .cookie-buttons {
            display: flex;
            gap: 10px;
            flex-wrap: wrap;
        }

        .btn-info {
            color: #fff;
            background-color: #0058ff;
            border-color: #0058ff;
            padding: 10px 18px;
            border-radius: 30px;
            text-decoration: none;
            font-weight: 400;
            font-size: 1rem;
            display: inline-block;
            width: 100%;
            text-align: center;
            cursor: pointer;
        }

        /* Para la animación de salida */
        .cookie-banner.hide {
            transform: translateY(20px); /* Cambiamos X por Y para que "caiga" al esconderse */
            opacity: 0;
            pointer-events: none;
        }

        .btn-info-secun {
            color: #0058ff;
            background-color: #fff;
            border: 1.5px solid #0058ff;
            padding: 10px 18px;
            border-radius: 30px;
            text-decoration: none;
            font-weight: 400;
            font-size: 1rem;
            display: inline-block;
            width: 100%;
            text-align: center;
            cursor: pointer;
        }

        @media (max-width: 767px) {
            .cookie-banner {
                left: 16px;
                right: 16px;
                bottom: 16px;
                max-width: none;
                padding: 16px;
            }

            .cookie-text p {
                font-size: 13px;
            }
        }

        /* Animations / visible default for cookie banner */
        .cookie-banner {
            transform: translateX(0);
            opacity: 1;
            transition: transform 360ms cubic-bezier(.2, .9, .2, 1), opacity 360ms ease;
        }

        .cookie-banner.show {
            transform: translateX(0);
            opacity: 1;
        }

        .cookie-banner.hide {
            transform: translateX(24px);
            opacity: 0;
            pointer-events: none;
        }


.recover_password_error_message_container {
  display: flex;
  justify-content: space-between;
  background-color: #edd6d4;
  border: darken(#edd6d4, 20%) 2px solid;
  border-radius: 10px;
  width: 90%;
  margin: 10px auto;
  padding: 10px;
}

.def_label_container {
  background-color: #DCEEFF;
  padding-top: 50px;
  padding-bottom: 50px;
  font-size: 24px; 
  font-weight: 600;
  color: #1655A1;
}

.def_label_message {
  margin-right: 30px;
}

.def_label_date {
  margin-left: 30px;
}

.recover_password_error_message {
  color: #b83c37;
  height: 100%;
  display: flex;
  align-items: center;
  font-size: 16px;
  text-align: center;
}

.footer-social a:hover {
  transform: translateY(-2px);
}

.footer-countries {
  font-size: 13px;
  color: #9ca3af;
}

.footer-social img {
  width: 30px;
  height: 30px;
  display: block;
}

.bi-heart:hover {
  color: inherit !important;
  background: none !important;
  /* background: purple; */
  transform: none !important;
  cursor: default; /* Opcional: para que el puntero no cambie */
}

.bi:hover {
  color: inherit !important;
  background: none !important;
  /* background: purple; */
  transform: none !important;
  cursor: default; /* Opcional: para que el puntero no cambie */
}

/* Color del día seleccionado */
.is-selected .pika-button {
    background: #0058ffbf !important;
    box-shadow: none !important;
    border-radius: 4px !important;
}

/* Color del hoy (today) */
.is-today .pika-button {
    color: #0058ffbf !important;
    font-weight: bold;
}

/* Hover sobre los días */
.pika-button:hover {
    background: #0058ff26 !important; /* Azul clarito */
    color: #0058ff !important;
    border-radius: 4px !important;
}

/* Estilo para los dropdowns de Mes y Año */
.pika-select {
    padding: 3px;
    border: 1px solid #ddd;
    border-radius: 4px;
    outline: none;
}

.modal-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(2, 66, 131, 0.3); /* Azul oscuro con 70% de opacidad */
    z-index: 1060; /* Por encima del contenido del modal */
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 0.375rem; /* Para que coincida con los bordes del modal */
    transition: opacity 0.3s ease;
}

/* Alineación del loader y texto */
.overlay-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

/* Asegurar que el modal-content sea el punto de referencia */
.modal-content {
    position: relative;
}

 


/* Estilos para Select2 */
        .select2-container--bootstrap-5 .select2-selection {
            min-height: 38px;
            padding: 0.375rem 0.75rem;
            font-size: 1rem;
            border: 1px solid #dee2e6;
        }

        .select2-container--bootstrap-5 .select2-selection--single .select2-selection__rendered {
            line-height: 1.5;
            padding-left: 0;
        }

        .select2-container--bootstrap-5 .select2-dropdown {
            border: 1px solid #dee2e6;
            border-radius: 0.375rem;
        }

        .select2-container--bootstrap-5 .select2-search--dropdown .select2-search__field {
            border: 1px solid #dee2e6;
            border-radius: 0.375rem;
            padding: 0.375rem 0.75rem;
        }

        .select2-container--bootstrap-5 .select2-results__option--highlighted {
            background-color: #0066ff;
            color: white;
        }

        /* ===== CUSTOM SELECT2 STYLES ===== */
        .select2-container--open .select2-dropdown {
            border-radius: 12px;
            box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1);
            border: 1px solid #eef2f6;
            overflow: hidden;
        }

        .select2-search--dropdown {
            position: relative;
            padding: 10px 12px 5px 12px;
        }

        .select2-search--dropdown .select2-search__field {
            border-radius: 50px !important;
            padding-left: 38px !important;
            height: 42px !important;
            border: 1px solid #e0e6ed !important;
            background-color: #fcfcfc;
            font-size: 0.95rem;
            outline: none !important;
        }

        .select2-search--dropdown .select2-search__field:focus {
            border-color: #1655ff !important;
            box-shadow: 0 0 0 3px rgba(22, 85, 255, 0.1) !important;
            background-color: #fff;
        }

        /* Icono de búsqueda inyectado via JS */
        .custom-search-icon {
            position: absolute;
            left: 26px;
            /* Ajustar según el padding del contenedor */
            top: 25px;
            /* Ajustar verticalmente */
            transform: translateY(-50%);
            color: #1655ff;
            z-index: 1001;
            pointer-events: none;
            font-size: 1rem;
        }

        /* Opciones del dropdown */
        .select2-results__option {
            padding: 10px 15px;
            font-size: 0.95rem;
            border-bottom: 1px solid #f9f9f9;
        }

        .select2-results__option--highlighted {
            background-color: #f0f4ff !important;
            color: #1655ff !important;
            font-weight: 600;
        }

        .select2-results__option--selected {
            background-color: #e6f0ff !important;
            color: #0d47a1 !important;
        }



        .register_error_message {
          font-size: 17px;
        }


/* 📱 MÓVIL */
@media (max-width: 767px) {
  .footer-columns {
    grid-template-columns: 1fr;
    gap: 0px;
    text-align: center;
    justify-items: center;
  }

  .contact-col {
    text-align: center;
 
  }

  .marketing-col {
    text-align: center;
  }
}



@media (max-width: 990px) {
  
  .def_label_container {
    flex-direction: column;
    /* margin-top: 150px; */
    align-items: center;
  }

  .def_label_message {
    font-size: 19px;
    text-align: center;
    margin: 0 auto 15px auto;
  }

  .def_label_date {
    font-size: 19px;
    text-align: center;
    margin: 0 auto;
  } 
}

@media (max-width: 767px) {

  .def_label_container {
    margin-top: 70px;
  }

}


.banner {
  position: sticky;
  top: 100px;
  right: 0;
  width: 100%;
}
