@import "https://fonts.googleapis.com/css?family=Poppins:300,400,500,600,700";

.fa-facebook { background: #3B5998; color: white; }
.fa-twitter { background: #55ACEE; color: white; }
.fa-linkedin { background: #0E76A8; color: white; }
.fa-youtube { background: #C4302B; color: white; }
/* .fa-whatsapp { background: #34AF23; color: white; } */
.fa-instagram { background: #634D40; color: white; }

.text-scalabl, .color-scalabl{color: #5b455b !important;}
.text-blanco{color: #fff !important;}
.text-negro{color: #000 !important;}
.text-gray{color: gray !important;}
.bg-scalabl{background-color: #5b455b !important;}
.bg-grisclaro{background-color: #f7f7f7 !important;}

body{
    font-family: 'Poppins', sans-serif;
}

h2 p{
    font-size: 24px;
}

h2 p span{
    color:black !important;
}

.turquesa-grow{
    color: #5CE1E6;
  }

/*Imagen de Portada*/
.portada__texto--sbr{
    font-family: 'Poppins', sans-serif;
    text-align: center;
    color: #ffffff;
    position: absolute;
    top: 22rem;
    transform: translateX(300px);
    max-width: 650px;
}

@media(max-width: 1440px){
    .portada__texto--sbr{
        top: 12rem;
        transform: translateX(300px);
        max-width: 450px;
    }
}

@media(max-width: 1200px){
    .portada__texto--sbr{
        top: 10rem;
        transform: translateX(250px);
    }
}

@media(max-width: 992px){
    .portada__texto--sbr{
        top: 12rem;
        transform: translateX(150px);
        max-width: 300px;
    }
}

@media(max-width: 600px){
    .portada__texto--sbr{
        top: 8.5rem;
        transform: translateX(70px);
        max-width: 150px;
    }
    .posicion-titulo__en{
        top: 9.5rem;
    }
    .posicion-titulo__es{
        top: 8.2rem;
    }
    .posicion-titulo__por{
        top: 8rem;
    }
}

.btn-scalabl {
    color:#fff ;
    border-color: #5b455b;
    background-color: #5b455b;
}
.btn-scalabl:active, .btn-scalabl:focus {
    outline: none !important;
    box-shadow: none;
    background-color: #5b455b !important;
}
.btn-scalabl:hover {
    opacity: 0.8;
    background-color: #5b455b;
    border-color: #5b455b;
    color: #fff;
}

.btn-outline-scalabl {
    color:#5b455b ;
    border-color: #5b455b;
    background-color: #f7f7f7;
}
.btn-outline-scalabl:active, .btn-outline-scalabl:focus {
    outline: none !important;
    box-shadow: none;
    background-color: #fff !important;
}
.btn-outline-scalabl:hover {
    opacity: 0.8;
    background-color: #5b455b;
    border-color: #5b455b;
    color: #fff;
}

.bg-nota{background-color: #f7f7f7;}
.bg-nota:hover{
	-webkit-box-shadow: 1px 1px 5px 1px rgba(0,0,0,0.36);
	box-shadow: 1px 1px 5px 1px rgba(0,0,0,0.36);
}

.card-footer{
	background-color: #f7f7f7;
	border: 0;
}

.link-nota{
	color: #000;
	text-decoration: none;
}

.link-nota:hover{
	cursor: pointer;
	text-decoration: none;
	color: #000;
}

.link-share{
	padding-top: 5px;
	color: #000;
	background-color: #f7f7f7;
	border: 0;
	z-index: 1;
}
.link-share:hover{
	cursor: pointer;
	opacity: 0.8;
}
.link-share:active, .link-share:focus{
	outline: none;
}
.link-share i{
	margin-right: 10px;
}

.modal-footer{
	border: 0;
}
/* Style all font awesome icons */
.fa-social {
    padding: 0.5em 0.6em 0.4em;
    font-size: 20px;
    text-align: center;
    text-decoration: none;
    border-radius: 3px;
}

/* Add a hover effect if you want */
.fa-social:hover {
    opacity: 0.7;
    text-decoration: none;
}


.card-nota-individual{
	border: 0;
}

.card-banner{border: 0;}
.card-banner:hover{opacity: 0.8;}
.card-banner img{border-radius: 4px;}

.alert-nota:hover{cursor: pointer};
.btnCerrarAlert:hover{
	cursor: pointer;
	opacity: 0.8;
}

.ba-etiqueta:hover{cursor: pointer; opacity: 0.8;}

.tabla-notas td, .tabla-notas th, .tabla-banners td, .tabla-banners th{vertical-align: middle;}
.link-a-nota{color: #000;}
.link-a-nota:hover{cursor: pointer; opacity: 0.8; color: gray; text-decoration: none;}

.logo-scalabl-admin, .logo-scalabl-admin:hover{
	color: #fff !important;
	border-radius: 20px;
	text-decoration: none;
}

.logo-scalabl-admin:hover{
    opacity: .8;
}

.link-menu-admin{
	color: gray;
	text-decoration: none;
}
.link-menu-admin:hover{
	cursor: pointer;
	opacity: 0.8;
	color: #000;
}

.img-banner-fran:hover{opacity: 0.8;}
.link-ver-banner:hover{cursor: pointer; opacity: 0.8;}

.mensaje-nota_mostrar_actualizado-ok, .mensaje-nota_mostrar_actualizado-error{
	display: none;
}

.img-notas-recomendadas-fran{
	height: 200px !important;
	object-fit: cover;
}

#btnBannerCursoOnline:hover{cursor: pointer;}
.span-validar-form-curso-online{display: none;}

.input-url-share{
    position: relative;
    width: 90%;
    margin: auto;
    background-color: khaki;
}
#icon_copy_url{
    position: absolute;
    top: 0.5em;
    right: -1.5em;
}
#icon_copy_url:hover{
    cursor: pointer;
    transform: scale(1.2);
}
#tbUrl{
    width: 100%;
}

@media (max-width: 576px) {
    .titulo{
        font-size: 1.8em !important;
    }
}

@media (min-width: 576px) {
    .card-columns {
        column-count: 1;
    }
}

@media (min-width: 768px) {
    .card-columns {
        column-count: 1;
    }
}

@media (min-width: 992px) {
    .card-columns {
        column-count: 2;
    }
}

@media (min-width: 1200px) {
    .card-columns {
        column-count: 2;
    }
}

/* buscador */
.fa-search{
    color: lightgrey;
}

.fa-search:hover{
    cursor: pointer;
    color: gray;
}

#tb_buscar{
    border: 0;
    border-top: 2px solid lightgrey;
    border-bottom: 2px solid lightgrey;
    padding: 15px 15px;
    letter-spacing: 1px;
}
#tb_buscar:focus{

    -webkit-box-shadow: none;
    box-shadow: none;
}
        
.loading-notas{
    display: none;
}

.nota-banner{
    display: none !important;
}

@media (max-width: 576px) {
    .banner-desktop{
        display: none;
    }

    .nota-banner{
        display: block !important;
    }
}

/* Btn flotante wpp */
.floating{
	position:fixed;
	bottom: 50px;
	right: 50px;
	background-color: #198754;
  width: 65px;
  height: 65px;
	color:#FFF;
	border-radius:50px;
	text-align:center;
  font-size:30px;
	box-shadow: 2px 2px 3px #999;
  z-index:100;
}

.floating i{
  color: #fff !important;
}

.float-button{
	margin-top:16px;
  color: #fff !important;
}

.float-button:hover,.floating:hover{
    color: #FFF;
    transform: scale(1.05);
}
/* / Btn flotante wpp */

/* ======================================================== */
/* === FIX FINAL: AJUSTE DE DIMENSIONES (ANCHO Y ALTURA) === */
/* ======================================================== */
@media (max-width: 991.98px) {
    
    /* 1. Contenedor de Colapso (Corrige Altura y Mantiene Posición) */
    .nuevo-header-nav-container .collapse,
    .nuevo-header-nav .collapse {
        /* Dimensiones y Margen del Recuadro Flotante */
        position: fixed !important; 
        top: 60px !important; 
        
        /* CRÍTICO: Eliminamos el bottom para que el recuadro se ajuste a la altura del contenido */
        bottom: auto !important; 
        height: auto !important; 
        
        /* Mantenemos el margen lateral de 10px */
        left: 10px !important; 
        right: 10px !important; 
        width: auto !important; 

        /* Estilo visual */
        background-color: white !important;
        border-radius: 12px !important; 
        box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3) !important;
        z-index: 99999;
        
        /* Limpieza de transición */
        transition: none !important;
        transform: none !important;
        padding: 0 !important; 
        overflow-y: auto; 
    }
    
    /* 2. CRÍTICO: ELIMINAR EL ESPACIO BLANCO SOBRANTE Y AJUSTAR PADDING LISTA */
    .navbar-collapse .navbar-nav {
        /* Padding vertical: 20px arriba, 20px abajo, 50px izquierda (para la cruz) */
        padding: 20px 20px 20px 50px !important; 
        margin: 0 !important;
        width: 100%;
        flex-direction: column !important;
        align-items: flex-start !important; 
    }

    /* 3. Posición de la Cruz (Queda en Superior Izquierda) */
    .menu-close-button {
        position: absolute !important; 
        top: 15px !important; 
        left: 20px !important;  /* Posición Izquierda */
        right: auto !important; 
        bottom: auto !important; 
        
        /* Estilo y Fix de Click-Through */
        z-index: 100001 !important; 
        background-color: white !important; 
        padding: 15px !important; 
        font-size: 1rem !important; 
        border-radius: 5px; 
        cursor: pointer;
    }
    
    /* Reglas secundarias de items */
    .navbar-collapse .navbar-nav li {
        width: 100%;
        border-bottom: 1px solid #f2f2f2;
    }
    .navbar-collapse .navbar-nav li:last-child {
        border-bottom: none !important;
    }
    .navbar-collapse .navbar-nav li a.dropdown-item {
        color: #5B455B !important; 
        padding: 12px 0 !important;
        display: block !important;
        text-align: left;
        white-space: normal !important; 
        word-break: break-word !important; 
    }
    .nuevo-header-nav-container .collapsing,
    .nuevo-header-nav .collapsing {
        transition: none !important;
        transform: none !important;
    }
}

/* ======================================================== */
/* === FIX: CONTENEDOR Y TAMAÑO DE IMAGEN (PORTADA) ======= */
/* ======================================================== */

/* Contenedor principal de la imagen */
.portada {
    width: 100%; 
    /* CRÍTICO: Oculta cualquier parte de la imagen que se desborde, evitando el scroll horizontal */
    overflow: hidden; 
    margin: 0;
    padding: 0;
}

/* Ajuste de imagen para móvil */
@media (max-width: 768px) {
    .portada {
        /* Limita la altura máxima para evitar que sea una tira muy larga */
        max-height: 250px; 
    }
    .portada .banner-img {
        /* Fuerza la imagen a ocupar el 100% del ancho del contenedor */
        width: 100%;
        height: auto; 
        display: block; 
    }
}

/* Posición del botón X para el menú flotante */
.menu-close-button {
    position: absolute !important; 
    top: 15px; 
    right: 20px; 
    z-index: 100000;
}

/* Posición del botón X para el menú flotante (Añadir a estilos.css) */
.menu-close-button {
    /* Mantenemos la posición absoluta dentro del recuadro */
    position: absolute !important; 
    top: 15px !important; 
    bottom: auto !important; /* CRÍTICO: Anula el 'bottom' que estiraba la caja */
    right: 20px; 
    z-index: 100001 !important; /* Más alto para asegurar la prioridad */
    
    /* Corrige el tamaño y el área de clic */
    font-size: 1rem !important; 
    padding: 10px !important; 
    background-color: white !important; 
    border-radius: 5px; 
    cursor: pointer;
}

.btn-whatsapp-flotante{
    position: fixed;
    bottom : 5%;
    right: 5%;
    width: 5%;
    z-index: 9999;
}
.btn-whatsapp-flotante:hover{
    cursor: pointer;
}
.btn-whatsapp-flotante img{
    width: 100%;
    z-index: 9999;
    border-radius: 50%;
}
.btn-whatsapp-flotante img:hover{
    opacity: 0.8;
}

.portada-pepe {
    width: 100%;
    max-width: 100%;
    margin: 0 0 32px 0;
    padding: 0;
    overflow: hidden; /* por si la imagen quiere “salirse” */
}

.portada-pepe .banner-link {
    display: block;
    width: 100%;
}

.portada-pepe picture {
    display: block;
    width: 100%;
}

.portada-pepe .banner-img {
    display: block;
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    object-fit: cover;
    object-position: center;
}

/* === FIX TARJETAS SBR (NOTAS) === */

.bg-nota {
    background-color: #f7f7f7;              /* vuelve el gris que tenías */
    border-radius: 4px;
    border: 1px solid #e5e5e5;              /* “borde” suave y visible */
    display: flex;
    flex-direction: column;
    height: 100%;
    padding-top: 1rem;                      /* respetando tu diseño */
    padding-bottom: 0.75rem;
}

.bg-nota:hover {
    box-shadow: 0 2px 8px rgba(0,0,0,0.16);
    transition: box-shadow 0.2s ease, transform 0.2s ease;
    transform: translateY(-2px);
}

/* el contenido crece y empuja el footer hacia abajo */
.bg-nota .card-body {
    flex: 1 1 auto;
    padding-left: 0;
    padding-right: 0;
}

/* footer claramente dentro de la tarjeta */
.bg-nota .card-footer {
    background-color: transparent;
    border: 0;
    padding-left: 0;
    padding-right: 0;
    margin-top: 0.5rem;
}

/* Limitar longitud del texto dentro de las cards */
.bg-nota .card-body .card-text {
    font-size: 0.875rem;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 3;        /* número de líneas visibles */
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.link-nota {
    color: inherit;
    text-decoration: none;
}

.link-nota:hover {
    text-decoration: none;
    color: inherit;
}

.link-nota h5 {
    font-size: 1rem;
    line-height: 1.3;
}

/* Botón compartir dentro de la card */
.link-share {
    padding-top: 5px;
    color: #000;
    background-color: #f7f7f7;
    border: 0;
    z-index: 1;
}

.link-share:hover {
    cursor: pointer;
    opacity: 0.8;
}

.link-share:active,
.link-share:focus {
    outline: none;
}

/* Spinner de carga (por si lo usas con JS) */
.loading-notas {
    display: none;
}

/* Botón flotante WhatsApp (reutilizado) */
.floating {
	position: fixed;
	bottom: 50px;
	right: 50px;
	background-color: #198754;
    width: 65px;
    height: 65px;
	color: #FFF;
	border-radius: 50px;
	text-align: center;
    font-size: 30px;
	box-shadow: 2px 2px 3px #999;
    z-index: 100;
}

.floating i {
  color: #fff !important;
}

.float-button {
	margin-top: 16px;
    color: #fff !important;
}

.float-button:hover,
.floating:hover {
    color: #FFF;
    transform: scale(1.05);
}

/* Botón outline violeta reutilizable */
.btn-outline-scalabl {
    color:#5b455b;
    border-color: #5b455b;
    background-color: #fff;
}

.btn-outline-scalabl:hover {
    opacity: 0.8;
    background-color: #5b455b;
    border-color: #5b455b;
    color: #fff;
}

/* === FIX GLOBAL OVERFLOW EN SBR === */
html, body {
    max-width: 100%;
    overflow-x: hidden;
}

