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

/*
p {
    font-size: 1.1em;
    font-weight: 300;
    line-height: 1.7em;
    color: #999;
}

a,
a:hover,
a:focus {
    color: inherit;
    text-decoration: none;
    transition: all 0.3s;
}

.navbar {
    padding: 15px 10px;
    background: #fff;
    border: none;
    border-radius: 0;
    margin-bottom: 40px;
    box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.1);
}

.navbar-btn {
    box-shadow: none;
    outline: none !important;
    border: none;
}

.line {
    width: 100%;
    height: 1px;
    border-bottom: 1px dashed #ddd;
    margin: 40px 0;
}

i, span {
    display: inline-block;
}

/* SIDEBAR */
/*
.wrapper {
    display: flex;
    align-items: stretch;
}

#sidebar {
    min-width: 250px;
    max-width: 250px;
    background: #5b455b;
    color: #fff;
    transition: all 0.3s;
}

#sidebar.active {
    min-width: 80px;
    max-width: 80px;
    text-align: center;
}

#sidebar.active .sidebar-header h3,
#sidebar.active .CTAs {
    display: none;
}

#sidebar.active .sidebar-header strong {
    display: block;
}

#sidebar ul li a {
    text-align: left;
}

#sidebar.active ul li a {
    padding: 20px 10px;
    text-align: center;
    font-size: 0.85em;
}

#sidebar.active ul li a i {
    margin-right: 0;
    display: block;
    font-size: 1.8em;
    margin-bottom: 5px;
}

#sidebar.active ul ul a {
    padding: 10px !important;
}

#sidebar.active .dropdown-toggle::after {
    top: auto;
    bottom: 10px;
    right: 50%;
    -webkit-transform: translateX(50%);
    -ms-transform: translateX(50%);
    transform: translateX(50%);
}

#sidebar .sidebar-header {
    padding: 20px;
    background: #5b455b;
}

#sidebar .sidebar-header strong {
    display: none;
    font-size: 1.8em;
}

#sidebar ul.components {
    padding: 20px 0;
    border-bottom: 1px solid #5b455b;
}

#sidebar ul li a {
    padding: 10px;
    font-size: 1.1em;
    display: block;
}

#sidebar ul li a:hover {
    color: #5b455b;
    background: #fff;
}

#sidebar ul li a i {
    margin-right: 10px;
}

#sidebar ul li.active>a,
a[aria-expanded="true"] {
    color: #fff;
    background: #5b455b;
}

a[data-toggle="collapse"] {
    position: relative;
}

.dropdown-toggle::after {
    display: block;
    position: absolute;
    top: 50%;
    right: 20px;
    transform: translateY(-50%);
}

ul ul a {
    font-size: 0.9em !important;
    padding-left: 30px !important;
    background: #725672;
}

ul.back {
    padding: 15px;
}

ul.back a {
    text-align: center;
    font-size: 0.9em !important;
    display: block;
    border-radius: 5px;
    margin-bottom: 5px;
}

a.download {
    background: #fff;
    color: #5b455b;
}

a.article,
a.article:hover {
    background: #fff !important;
    color: #725672 !important;
}

/* ---------------------------------------------------
    CONTENT STYLE
----------------------------------------------------- */

#content {
    width: 100%;
    padding: 20px;
    min-height: 100vh;
    transition: all 0.3s;
}

/* ---------------------------------------------------
    MEDIAQUERIES
----------------------------------------------------- */

@media (max-width: 768px) {
    #sidebar {
        min-width: 80px;
        max-width: 80px;
        text-align: center;
        margin-left: -80px !important;
    }
    .dropdown-toggle::after {
        top: auto;
        bottom: 10px;
        right: 50%;
        -webkit-transform: translateX(50%);
        -ms-transform: translateX(50%);
        transform: translateX(50%);
    }
    #sidebar.active {
        margin-left: 0 !important;
    }
    #sidebar .sidebar-header h3,
    #sidebar .CTAs {
        display: none;
    }
    #sidebar .sidebar-header strong {
        display: block;
    }
    #sidebar ul li a {
        padding: 20px 10px;
    }
    #sidebar ul li a span {
        font-size: 0.85em;
    }
    #sidebar ul li a i {
        margin-right: 0;
        display: block;
    }
    #sidebar ul ul a {
        padding: 10px !important;
    }
    #sidebar ul li a i {
        font-size: 1.3em;
    }
    #sidebar {
        margin-left: 0;
    }
    #sidebarCollapse span {
        display: none;
    }
}

/* GLOBAL */
.fa-twitter { background: #55ACEE; color: white; }
.fa-youtube { background: #C4302B; color: white; }
/* .fa-whatsapp { background: #34AF23; color: white; } */

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

.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;}

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

@media(max-width: 1440px){
    .portada__texto--empresas{
        top: 16rem;
        transform: translateX(250px);
    }
}

@media(max-width: 1200px){
    .portada__texto--empresas{
        top: 14rem;
        transform: translateX(200px);
        max-width: 500px;
    }
}

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

@media(max-width: 600px){
    .portada__texto--empresas{
        top: 10rem;
        transform: translateX(60px);
        max-width: 150px;
    }
    .posicion-titulo__en{
        top: 10rem;
    }
    .posicion-titulo__es, .posicion-titulo__por{
        top: 9rem;
    }
}

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

.bg-scalabl-claro{
    background-color: #7A5D7A;
}


.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;
}

.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: -1.2em;
    right: 0em;
}
#icon_copy_url:hover{
    cursor: pointer;
    transform: scale(1.2);
}
#tbUrl{
    width: 100%;
}

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

@media (min-width: 768px) {
    .card-columns {
        column-count: 3;
        column-gap: 0.5rem;
    }
}

@media (min-width: 992px) {
    .card-columns {
        column-count: 3;
        column-gap: 0.5rem;
    }
}

@media (min-width: 1200px) {
    .card-columns {
        column-count: 3;
        column-gap: 0.5rem;
    }
}

/* 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;
}

.image-card{
    /*width: 150px !important;
    height: 150px !important;
    object-fit: cover;*/
    object-fit: cover !important;
    background-color: white;
}

/*
.card{
    transition: all 0.2s ease-in-out;
    transform: scale(0.96); 
}
*/

.card:hover{
    box-shadow: 5px 5px 5px rgba(0,0,0,0.3);
   /* transform: scale(1); */
}

.loading-empresa{
    display: none;
}

.card-title{
    font-weight: regular !important;
    font-size: 20px;
    padding: 0 10px;
}

.nombre-alumni{
    display: flex;
    justify-content: center;
    color: rgb(100, 100, 100);
    font-size: 15px;
}

.fa {
    transform: translateY(14%);
    margin-right: 5px;
    color: #5b455b;
}

.card-body{
    color: rgb(34, 34, 34);
    padding-top: 0 !important;
    margin-bottom: 30px;
    margin-top: 10px;
}

.industria{
    color: #5b455b;
    margin: auto;
    font-weight: bold;
}

.icons a{
    text-decoration: none;
}

.line{
    width: 100%;
    height: 2px;
    background-color: grey;
}

.modal-el{
    color: white !important;
}

.modal-oc{
    color: white !important;
}

.btn-ocultar{
    color: white !important;
}

.btn-no-ocultar{
    color: white !important;
}

.icons{
    position: absolute;
    width: 100%;
    bottom: 25px;
}

.icon{
    transition: all 0.05s ease-in-out;
}

.icon:hover{
    transform: scale(1.1);
    opacity: 0.8;
}




/* 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);
}

/* ======================================================== */
/* === 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;
}

  @media (min-width: 992px){
    .pod-side .card,
    .pod-side .cardContRandom{ transform: scale(.96); transform-origin: top right; }
  }
  .pod-side .card-title,
  .pod-side .cardContRandom__titulo{ font-size: .95rem; }