/* === MENÚ HAMBURGUESA DESPLEGABLE === */
html, body{
   overflow-x:hidden;
   margin:0;
   padding:0;
}

*{
   box-sizing:border-box;
   max-width:100%;
}

#globalbar-nav {
   display: flex !important;
   transition: all 0.4s ease;
   align-items: start;
   justify-content: center;
   align-content: center;    
   z-index: 1; /* el logo queda por encima */
   margin-left: 1px; /* deja espacio al logo */
   margin-top: 4px;
   position: static !important;
   width: auto !important;
   height: auto !important;
   background: none !important;
   padding-top: 0 !important;
}

#globalbar-nav ul a {
   color: white;
   text-decoration: none;
   font-family: sans-serif;
   cursor: pointer !important;
}

#globalbar-nav.active {
  display: flex !important;
  position: fixed !important;
  top: 0;
  left: 0;
  width: 100%;
  height: 100dvh;
  background-color: #2b2a4c;
  text-align: center;
  padding-top: 120px;
  z-index: 99999 !important;
  overflow: hidden; 
}
 
#globalbar-nav.active ul {
   list-style: none;
   padding: 0;
   margin: 0;
   width: 100%;
   text-align: center;
   flex-direction: column !important;
   justify-content: center;
   align-items: center;
   height: auto;
   gap: 0;

}

#globalbar-nav li {
   display: inline-flex;
   align-items: center;
   justify-content: center;
   min-width: 60px;
   padding-left: 12px !important;
   padding-right: 12px !important;
   padding-top: 8px;
   padding-bottom: 8px;
   cursor: pointer !important;
}

#globalbar-nav.active li {
   display: block !important;
   padding: 15px 0 !important;
   border-bottom: 1px solid rgba(255,255,255,0.1);
}

#globalbar-nav.active li a {
  color: #fff;
  font-size: 18px !important;
  text-decoration: none;
}

#globalbar-nav.active li a:hover {
  /*color: transparent !important;*/
}

#globalbar-nav li a {
   display: flex;
   text-align: center;
   margin-top: 8px;
   margin-bottom: 8px;
}

#globalbar-nav li a:hover {
   color: #FF7979;
}

#globalbar-nav:hover {
   color: #FF7979;
}

#globalbar-nav ul {
   display: flex !important;
   gap: -4px;
   list-style: none;
   align-items: center;
   margin: 0;
   padding: 0;
   height: 100%;
   cursor: pointer !important; 
   list-style-type: none;
}

#globalbar-nav ul li {
  display: flex;
  align-items: center;     /* centra los enlaces dentro del li */
}

#globalbar-nav ul li a {
  color: white;
  text-decoration: none;
  font-size: 14px;
  font-weight: 500;
  padding: 5px 2px 10px;       /* añade un poco de espacio arriba y abajo */
  display: inline-block;
  line-height: 1;
}

#globalbar-nav ul li a:hover {
  color: #F77677;
  cursor: pointer !important;
}

#sides-nav {
   display: flex !important;
   width: fit-content;
   align-items: center;
   justify-content: start;
   display: flex;
   padding-left: 8px;
   padding-top: 6px;
   font-size: 12pt !important;
}
/* Quitar bullets */
nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

/* Enlaces del menú */
nav ul li a {
  color: #ffffff;           /* o el color que uses */
  text-decoration: none;    /* quita el subrayado */
  font-weight: 500;
}

.info-scroll {
   max-height: 360px;        /* Altura del scroll */
   overflow-y: auto;
   background: #ffffff;
   border: 1px solid #e5e5e5;
   border-radius: 10px;
   padding: 10px 12px;
}

/* Item individual */
.info-scroll {
   max-height: 360px;
   overflow-y: auto;
   background: #ffffff;
   border: 1px solid #e5e5e5;
   border-radius: 10px;
   padding: 12px;
   text-align: center;   /* 🔹 CENTRADO GENERAL */
}

.info-item {
   padding: 16px 10px;
   border-bottom: 1px solid #e0e0e0;
   cursor: pointer;
   transition: background 0.2s ease;
}

.info-item:last-child {
   border-bottom: none;
}

.info-item:hover {
   background: #f7f7f7;
}

.info-categoria {
   display: block;
   font-size: 0.85rem;
   font-weight: 600;
   color: #444;
   margin-bottom: 6px;
}

.info-titulo {
   margin: 0;
   font-size: 0.95rem;
   font-weight: 600;
   color: #000;
   line-height: 1.3;
}

.info-link {
   display: inline-block;
   margin-top: 8px;
   font-size: 0.85rem;
   color: #005bbb;
   font-weight: 600;
}

/************Botones Programas Visores****background: linear-gradient(to bottom, #9a8fb3, #f0a51a 45%);*********/

.contenedor{
   max-width: 2500px;
	width: 100%;
	margin: 0 auto;
   display: flex;
   justify-content: space-between;
   align-items: center;
   height: 700px;
   gap: 280px;
   border: none;
   box-shadow: none;
   background: transparent;
}

.contenedor{
   position: relative;
}

.contenedor::before{
   content: "";
   position: absolute;
   top: 0;
   left: 50%;
   transform: translateX(-50%);
   width: 2px;
   height: 55%;
   background: white;
	margin-top: 195px;
}

.columna{
   flex: 1;
   display: flex;
   flex-direction: column;
   align-items: center;
   text-align: center;
 }

.columna:last-child{
   border-right: none;
   border-left: none;	
}

.columna:first-child .card-boton{
   width: 390px;
   padding: 25px 15px;
}

.columna:first-child .card-boton img{
   width: 310px;
}

.columna:first-child .card-boton:hover{
   transform: translateY(-10px) scale(1.03);
}

.grid-botones{
   display: flex;
   justify-content: row;
	gap: 40px;
	flex-wrap: nowrap;
   align-items: center;
   background: transparent !important;
}

.columna h2{
   color: #2f4fa3;
   font-size: 42px;
   font-weight: 700;
   margin-bottom: 40px;
}

.visores{
   flex: 1;
   display: flex;
   border-right: none !important;
	justify-content: center;
	align-items: center;
}

.visores .card-boton{
   width: 100px;
   padding: 15px 10px;
}

.visores .card-boton:hover{
   transform: translateY(-5px) scale(1.02);
}

.visores .grid-botones{
   display: flex;
   justify-content: flex-end;
   align-items: center;
   gap: 60px;
   width: 100%;
	margin-top: 35px;
	margin-left: -80px !important;
}

.visores img{
   max-width: 190px;
   height: auto;
   display: block;
}

.visores-grid{
   display: flex;
   justify-content: center;
   gap: 90px;
   flex-wrap: nowrap;
}

.visores .card-flip{
   width: 190px;
   height: 220px;
}

.visores .card-flip-inner{
   height: 200px;
}

.visores .card-front img{
   width: 100%;
   height: auto;
   object-fit: contain;
}

.grid-botones{
   display: flex;
   justify-content: center;
   gap: 60px;
   flex-wrap: nowrap;
	margin-top: 35px;

}

.card-boton{
   display: flex;
   flex-direction: column;
   align-items: center;    
   justify-content: center;
   text-align: center;
   padding: 30px 20px;
}

.card-boton img{
   display: block;
   margin: 0 auto;    
   transition: transform 0.3s ease;
}

.card-boton:hover img{
   transform: scale(1.08);
}

.card-boton:hover{
   transform: translateY(-8px);
   box-shadow: 0 18px 35px rgba(0,0,0,0.15);
}

.contenedor,
.columna,
.grid-botones{
   background: transparent !important;
   border: none !important;
   box-shadow: none !important;
   background: transparent !important;
}
/* 
.card-flip{
   width: 270px;
   height: 220px;
}
 */
.card-flip img{
   width: 100%;
   height: 100%;
   object-fit: cover;
}

/*CONTENEDOR PRINCIPAL*/
.card-flip{
   width: 210px;
   height: 330px;
	perspective: 1000px;
	margin-left: 155px;
	padding: 10px;
}

.card-flip-inner{
   position: relative;
   width: 100%;
   height: 350px;
   transition: transform 0.6s;
   transform-style: preserve-3d;
}

.card-flip:hover .card-flip-inner{
   transform: rotateY(180deg);
}

.card-front,
.card-back{
   position: absolute;
   width: 100%;
   height: 100%;
   backface-visibility: hidden;
   border-radius: 12px;
   display: flex;
   align-items: center;
   justify-content: center;
   flex-direction: column;
   padding: 15px;
   box-shadow: 0 8px 20px rgba(0,0,0,0.1);
}

.card-front{
   background: #ffffff;
}

.card-front img{
   width: 180px;
}

.card-back{
   background: #1f4fa3;
   color: white;
   transform: rotateY(180deg);
   text-align: center;
}

.card-back img{
	width: 130px;
}

.card-back h4{
   margin: 0 0 5px 0;
	color: white;
	font-size: 14px;
}

.card-back p{
   font-size: 14px;
   margin-bottom: 12px;
	color: white;
}

.btn-ver{
   background: white;
   color: #1f4fa3;
   padding: 8px 15px;
   text-decoration: none;
   border-radius: 6px;
   font-size: 14px;
   font-weight: bold;
   transition: 0.3s;
}

.btn-ver:hover{
   background: #eaeaea;
}

.btn-conoce{
   display:inline-block;
   padding:6px 22px;
   background:white;
   color:#3d5aa9;
   font-weight:600;
   font-size:14px;
   text-decoration:none;
   border-radius:50px;
   border:1px solid #d9d9d9;
   box-shadow: inset 0 1px 0 rgba(255,255,255,0.9),
               0 2px 4px rgba(0,0,0,0.15);
}

.btn-conoce:hover{
   background: #eaeaea;
}

/* Sección Quienes Somos tu implan */

.quienes-section{
   width:100%;
   background: transparent;
   padding-bottom:60px;
   overflow: hidden;
}

.quienes-header{
   display:flex;
   align-items:flex-start;
   max-width:1200px;
   margin:auto;
   gap:40px;
   position:relative;
}
 
/* imagen */

.quienes-imagen{
   width:100%;
   position:relative;
   overflow:hidden;
	margin-left: -1750px;
}

.quienes-imagen img{
   width:100%;
   height:650px;
   object-fit:cover;
   display:block;
}

/* texto sobre imagen */

.titulo-quienes{
   position:absolute;
   top:20px;
   left: -190px;
   font-family:Montserrat;
   font-size:48px;
   color:#fff;
   font-weight:bold;
   z-index:10;
}

.quienes-texto{
	width:65%;
   margin-top: 520px;
	margin-left: 480px;
	background:rgba(47,140,183,0.35);
   text-align:justify;
   color:#fff;
   padding:25px 35px;
   border-radius:40px;
   line-height:1.6;
	z-index:10;
}

.quienes-cards{
   display:flex;
   flex-direction:column;
   gap:40px;
   color:#2F57A5;
   max-width:1200px;
   margin:auto;
   align-items:center; /* centra el eje */
}

/*Politica de Calidad*/
.politica-section{
   width:100%;
   background: transparent;
   padding-bottom:60px;
   margin-top:90px;
   margin-bottom:0;
}

.bloque{
   width:620px;
   display:flex;
   flex-direction:column;
}

.bloque h3{
   font-family:'Montserrat', sans-serif;
   font-weight:bold;
   font-size:30px;
   color:#2F57A5;
   margin-bottom:10px;
}

.card{
   width:100%;
   max-width:720px;
   padding:30px;
   border-radius:30px;
   background:#FCDDA2;
	transform:translateX(520px);
}

.card ul{
   margin:0;
   padding-left:20px;
}

.card p,
.card li{
   color:#2F57A5;
   text-align:justify;
   font-family:'Montserrat', sans-serif;
}

.card h3{
   text-align:center;
   color:#3c63a5;
   margin-bottom:10px;
   font-size:clamp(22px, 4vw, 36px);
}

.titulo-mision{
   transform:translateX(520px);
}

.titulo-vision{
   transform:translateX(-310px);
}

.titulo-valores{
   transform:translateX(520px);
}

.mision{
   background:#f38a1c;
   align-self:flex-start;
	transform:translateX(520px);
}

.vision{
   background:#FBCC73;
   align-self:flex-end;
	transform:translateX(-310px);
}

.valores{
   background:#FCDDA2 !important;
   align-self:flex-start;
	transform:translateX(720px);
}

/* DIRECTORA */

.directora-section{
   background:transparent;
   background-size:cover;
   background-position:center;
   padding:80px 0;
   margin-bottom:0;
   margin-top:0;
   border-radius:25px;
}

.directora-container{
   display:flex;
   justify-content:center;
   align-items:center;
   gap:80px;
   max-width:1000px;
   margin:auto;
   border-radius:25px;
}

.directora-texto{
   background:#2F57A5;
   padding:30px;
   border-radius:25px;
   width:380px;
}

.directora-texto h3{
   font-family:Montserrat;
   font-weight:bold;
   font-size:26px;
   color:#ffffff;
   margin-bottom:10px;
}

.directora-texto p{
   color:#ffffff;
   text-align:justify;
   font-family:Montserrat;
}

.directora-foto{
   position:relative;
   width:220px;
   border-radius:25px;
}

.directora-foto img{
   width:100%;
   position:relative;
   z-index:2;
   border-radius:25px;
}

.marco{
   position:absolute;
   width:100%;
   height:100%;
   background:#2F57A5;
   top:-20px;
   right:-20px;
   z-index:1;
   border-radius:25px;
}

.nombre-directora{
   text-align:right;
   margin-right:585px;
   margin-top:20px;
   font-family:Montserrat;
   color:#000000;
   font-size:14px;
}

/* SERVICIOS */

.servicios-section{
   width:100%;
   background:#f5f5f5;
   padding-bottom:60px;
}

.servicios-imagen{
   width:100%;
   max-width:950px;
   margin:auto;
}

.servicios-imagen img{
   width:100%;
   display:block;
   margin-right:-20px;
}

/* LIGAS */

.ligas-section{
   background:transparent;
   padding:80px 0;
}

.ligas-section footer{
   display:flex;
   justify-content:space-around; /* distribuye */
   align-items:center;
   max-width:1200px;
   margin:auto;
	margin-bottom: 0;
}

.ligas-section img{
   width:100px;
   height:auto;
   display:block;
}

.ligas-section footer div{
   text-align:center;
   transition:all 0.3s ease;
}

.ligas-section footer img{
   width:100px;
   height:auto;
   display:block;
   margin:auto;
   transition:all 0.3s ease;
	margin-bottom: 0;
}

/* HOVER */

.ligas-section footer div:hover img{
   transform:translateY(-8px) scale(1.08);
   filter:brightness(1.15);
}

/* ajustes tablets */
@media (max-width:768px){

   .quienes-header{
      flex-direction:column;
      align-items:center;
   }

   .quienes-imagen{
      margin-left:0;
      width:100%;
   }

   .quienes-imagen img{
      height:380px;
   }

   .titulo-quienes{
      left:20px;
      top:20px;
      font-size:32px;
   }

   .quienes-texto{
      width:90%;
      margin:20px auto;
   }

   .titulo-mision,
   .titulo-vision,
   .titulo-valores{
      transform:none;
      text-align:center;
   }

   .mision,
   .vision,
   .valores{
      transform:none;
      align-self:center;
   }

   .card{
      transform:none;
      max-width:90%;
   }

}

/* laptops 1440x900 */

@media (max-width:1440px) and (max-height:900px){

   .titulo-quienes{
      position:absolute;
      top:20px;
      left: -190px;
      font-family:Montserrat;
      font-size:48px;
      color:#fff;
      font-weight:bold;
      z-index:10;
   }
   
   .quienes-texto{
   	width:65%;
      margin-top: 260px;
   	margin-left: 680px;
   	background:rgba(47,140,183,0.35);
      text-align:justify;
      color:#fff;
      padding:25px 35px;
      border-radius:40px;
      line-height:1.6;
   	z-index:10;
   }
   
   .quienes-imagen img{
      height:520px;
   }
   
   .quienes-imagen{
      width:100%;
      position:relative;
      overflow:hidden;
   	margin-left: -1450px;
   }
   
   .quienes-cards{
      gap:30px;
   }
   
   .titulo-quienes{
      position:absolute;
      top:20px;
      left: -90px;
      font-family:Montserrat;
      font-size:48px;
      color:#fff;
      font-weight:bold;
      z-index:10;
   }
   
   .card{
      padding:25px;
      width:100%;
      max-width:380px;
   }

   .card h3{
      text-align:center;
      color:#3c63a5;
      margin-bottom:10px;
      font-size:clamp(22px, 4vw, 36px);
   }
  
   /**************titulos************/
	
   .titulo-mision{
      transform:translateX(-440px);
   }
   
   .titulo-vision{
      transform:translateX(-520px);
   }
   
   .titulo-valores{
      transform:translateX(400px);
   }
   
   /**************tarjetas************/
   .mision{
      background:#f38a1c;
      align-self:flex-start;
   	transform:translateX(520px);
   }

   .vision{
      background:#f0a43c;
      align-self:flex-end;
   	transform:translateX(-310px);
   }
   
   .valores{
      background:#FCDDA2 !important;
      align-self:flex-start;
   	transform:translateX(420px);
   }
}

/* laptops pequeñas */

@media (max-height:800px){

.quienes-texto{
   top:240px;
   width:440px;
}

.card{
   width:350px;
}

}
/* *{
    outline:2px solid red;
 }*/