*{
  margin:0;
  padding:0;
  box-sizing:border-box;
}
	
/* FUENTE SURA SANS */
/* ========================= */

@font-face {
  font-family: 'Sura Sans';
  src: url('fonts/SuraSans-Regular.woff') format('woff');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Sura Sans';
  src: url('fonts/SuraSans-Negrita.woff') format('woff');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}


/* HERO RESPONSIVE*/
/* ========================= */

.hero-section {
  position: relative;
  min-height: 90vh;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding: 0 clamp(24px, 8vw, 200px);
  overflow: hidden;
  color: #fff;
  perspective: 1200px;
}

/* Video */
.hero-section video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}


/* Texto */
.hero-content {
  max-width: 720px;
  width: 100%;
  z-index: 2;
}

.hero-content h2 { 
  font-weight: 400; 
  font-size: clamp(18px, 2.5vw, 28px);
}

.hero-content h1 {
  font-size: 68px;
  line-height: 0.95;
  font-weight: 700;
  margin-top: 10px;
  word-break: break-word;
}

.hero-content p {
  margin-top: 24px;
  font-size: clamp(18px, 2.5vw, 26px);
  max-width: 580px;
  line-height: 1.3;
  font-family: 'Sura Sans';
}
	
.hero-section .overlay {
  position: absolute;
  inset: 0;
  background: #00AEC7;
  mix-blend-mode: multiply;
  z-index: 1;
  pointer-events: none;
}

.btn {
  display: inline-block;
  margin-top: 30px;
  padding: 16px 28px;
  background:#2D6DF6;
  border-radius: 40px;
  font-weight:700;
  text-decoration:none;
  color:#fff;
  transition:.3s;
}

.btn:hover { 
  background:#0033A0; 
}

.banner-imageconexxion {
    position: absolute;
	max-width: 1070px!important;
    bottom: 40%;
    margin-left: 350px;
    transform: translateY(50%);
    max-width: 80px;
    height: auto;
    z-index: 2;
  }

  
@media(max-width:768px){

  .hero-section{
    justify-content:center;
    text-align:center;
    min-height:85vh;
  }

  .hero-content{
    max-width:100%;
  }

}

@media(max-width:480px){

  .hero-section{
    padding:0 20px;
    min-height:80vh;
  }

}
	
	/* ===== SECCIÓN ===== */

.intro-section {
  padding: 110px 350px;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
}
	
  .intro-soluciones {
  padding: 80px 20px 0px;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
}

/* ===== CONTENEDOR ===== */

.intro-container {
  max-width: 900px;
}

/* ===== TITULO ===== */

.intro-container h1 {
  font-size: 48px;
  line-height: 1.15;
  font-weight: 400;
  color: #3a3a3a;
  letter-spacing: 0px;
  margin-bottom: 40px;
}
	
	
/* ================================================= */
/* CARDS SERVICIOS */
/* ================================================= */

.cards-servicios .cards-section{
  padding:80px 0 120px;
}

.cards-servicios .cards-container{
  display:flex;
  gap:24px;
  width:100%;
  max-width:1200px; 
  margin: 70px auto;
  transition:all .5s ease;
}

.cards-servicios .card{
  flex:1;
  height:360px;
  border-radius:24px;
  overflow:hidden;
  position:relative;
  cursor:pointer;
  transition: all 0.6s cubic-bezier(.77,0,.18,1);
  color:white;
  display:flex;
  align-items:flex-end;
  padding:40px;
}

/* Overlay */
.cards-servicios .card::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
}

.cards-servicios .card-content{
  position:relative;
  z-index:2;
  width:100%;
  height:100%; 
  display:flex;
  flex-direction:column;
}

.cards-servicios .card h3{
  font-size:24px;
  font-weight:700;
  margin-top:228px; 
  max-width:180px;  
  line-height:1.2;
}

.cards-servicios .card-description{
  opacity:0;
  max-width:420px;
  margin-left:auto;
  transition:all .4s ease;
}

.cards-servicios .card-description p{
  font-size:20px;
  margin-bottom:22px;
}

.cards-servicios .card-description ul{
  list-style:disc;
  padding-left:20px;
  font-size:16px;
  line-height:1.6;
}

.cards-servicios .card-subtitulo{
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  font-size:16px;
}

/* Estado activo */

.cards-servicios .card.active{
  flex:3.2;
}
	
.cards-servicios .card.active h3{
  font-size:16px;
}

.cards-servicios .card.active .card-content{
  flex-direction:row;
  align-items:flex-end;
  justify-content:space-between;
}

.cards-servicios .card.active .card-description{
  opacity:1;
  padding:0px 30px 30px 120px;
}

/* Imágenes */

.cards-servicios .card:nth-child(1){
  background-image:url("https://conexxion.sura.com/documents/d/guest/abastecimiento");
  background-size:cover;
  background-position:30% 80%;
  background-repeat:no-repeat;
}

.cards-servicios .card:nth-child(2){
  background:url("https://conexxion.sura.com/documents/d/guest/soluciones-tecnologicas") left/cover;
}

.cards-servicios .card:nth-child(3){
  background:url("https://conexxion.sura.com/documents/d/guest/gestion-financiera") left/cover;
}

/* Responsive */

@media(max-width:900px){

  .cards-servicios .cards-container{
    flex-direction:column;
  }

  .cards-servicios .card{
    height:420px;
  }

  .cards-servicios .card.active{
    flex:unset;
  }

  .cards-servicios .card.active .card-content{
    flex-direction:column;
  }

  .cards-servicios .card-description{
    margin-left:0;
    margin-top:20px;
  }
	
  .cards-servicios .card.active h3{
    margin-top:0;
  }

  .cards-servicios .intro-section{
    padding:80px 40px;
  }

  .cards-servicios .hero-section{
    padding:0 40px;
  }
}

/* ========================= */
/* Intro y extras aislados */
/* ========================= */

.cards-servicios .intro-container .highlight{
  color:#3B6EEA;
  font-weight:600;
}

.cards-servicios .intro-container p{
  font-size:24px;
  line-height:1.4;
  font-weight:400;
  color:#555555;
  max-width:900px;
  margin:0 auto;
}

/* ========================= */
/* ICONOS */
/* ========================= */

.cards-servicios .icons-container{
  position:absolute;
  right:120px;
  top:50%;
  transform:translateY(-50%);
  width:500px;
  height:650px;
  pointer-events:none;
}

.cards-servicios .hero-icon{
  position:absolute;
  width:140px;
  opacity:0;
  transform:translateY(-300px);
  will-change:transform;
}

/* Posiciones */
.cards-servicios .icon1{ top:0px; left:260px; }
.cards-servicios .icon2{ top:140px; left:120px; }
.cards-servicios .icon3{ top:260px; left:300px; }
.cards-servicios .icon4{ top:380px; left:150px; }
.cards-servicios .icon5{ top:500px; left:320px; }

/* Animaciones */
@keyframes dropIn{
  to{
    transform:translateY(0);
    opacity:1;
  }
}

@keyframes float1{
  0%,100%{ transform:translateY(0); }
  50%{ transform:translateY(-18px); }
}
@keyframes float2{
  0%,100%{ transform:translateY(0); }
  50%{ transform:translateY(-25px); }
}
@keyframes float3{
  0%,100%{ transform:translateY(0); }
  50%{ transform:translateY(-15px); }
}

.cards-servicios .icon1{
  animation:dropIn .8s ease forwards .3s, float1 4s ease-in-out infinite 1.3s;
}
.cards-servicios .icon2{
  animation:dropIn .8s ease forwards 1.1s, float2 5s ease-in-out infinite 2s;
}
.cards-servicios .icon3{
  animation:dropIn .8s ease forwards 1.9s, float3 4.5s ease-in-out infinite 2.8s;
}
.cards-servicios .icon4{
  animation:dropIn .8s ease forwards 2.7s, float2 5.5s ease-in-out infinite 3.6s;
}
.cards-servicios .icon5{
  animation:dropIn .8s ease forwards 3.5s, float1 4.8s ease-in-out infinite 4.4s;
}

/* ========================= */
/* PILARES */
/* ========================= */

.pilares-section {
  background: #f2f2f2;
  padding: 100px 20px;
}

.container {
  max-width: 1200px;
  margin: auto;
}

.section-title {
  text-align: center;
  font-size: 42px;
  font-weight: 400;
  margin-bottom: 80px;
  color: #333;
}

.section-title span {
  color: #2D6DF6;
  font-weight: 700;
}

.pilares-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 60px;
}

.pilar {
  text-align: left;
}

.pilar-icon {
  margin-bottom: 25px;
}

.pilar-icon img {
  width: 124px;
  height: auto;
  display: block;
  transform: scale(1) translateY(0);
  transition: transform 0.25s cubic-bezier(0.34, 1.56, 0.64, 1); /* easing elástico */
}

.pilar:hover .pilar-icon img {
  transform: scale(1.2) translateY(-8px);
}

/* Opcional: micro rebote final */
.pilar:hover .pilar-icon img {
  animation: figmaBounce 0.5s ease-out forwards;
}

@keyframes figmaBounce {
  0%   { transform: scale(1) translateY(0); }
  40%  { transform: scale(1.22) translateY(-8px); }
  60%  { transform: scale(1.15) translateY(-4px); }
  80%  { transform: scale(1.18) translateY(-6px); }
  100% { transform: scale(1.2) translateY(-8px); }
}
.pilar h3 {
  color: #2D6DF6;
  font-size: 24px;
  margin-bottom: 15px;
  font-weight: 700;
}

.pilar p {
    color: #555;
    font-size: 16px;
    line-height: 1.3;
	font-family: 'Sura Sans';
}

/* Responsive */
@media (max-width: 1024px) {
  .pilares-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .pilares-grid {
    grid-template-columns: 1fr;
  }

  .section-title {
    font-size: 32px;
  }

  .hero-section{
    padding:0 60px;
  }

  .icons-container{
    display:none;
  }
}
	
	
	.stats-section{
  padding:120px 20px;
}

.stats-container{
  position:relative;
  max-width:1200px;
  margin:auto;
  min-height:650px;
  display:flex;
  justify-content:center;
  align-items:center;
}

/* Imagen detrás */

.stats-image{
  position:absolute;
  width:900px;
  max-width:100%;
  z-index:1;
  opacity:0.9; /* opcional para que no compita */
  pointer-events:none; /* no interfiere con hover */
}

/* Cajas */

.stat{
  position:absolute;
  background:#ffffff;
  padding: 20px 32px;
  border-radius:24px;
  max-width:290px; 
  box-shadow:0 10px 30px rgba(0,0,0,0.05);
  transition:all .3s ease;
  cursor:pointer;
  z-index:2;
}

/* Tamaño flexible */

.stat h3{
  font-size:28px;
  font-weight:700;
  color:#2D6DF6;
  margin-bottom:8px;
}

.stat p{
  font-size:16px;
  color:#555;
  line-height:1.4;
}

/* Hover */

.stat:hover{
  background:#DFEAFF;
  transform:translateY(-6px);
}

/* Posiciones ajustadas */

.stat-1{ top:0px; left:290px; }
.stat-2{ top:-50px; right:160px; }
.stat-3{ top:260px; right:20px; }
.stat-4{ bottom:-38px; right:200px; }
.stat-5{ bottom:9px; left:200px; }
.stat-6{ top:200px; left:40px;width: 220px; }

/* Responsive */

@media(max-width:1024px){

  .stats-container{
    flex-direction:column;
    min-height:auto;
  }

  .stats-image{
    position:relative;
    margin-bottom:40px;
  }

  .stat{
    position:relative;
    margin:20px 0;
    max-width:400px;
    width:100%;
  }

  .stat-1,
  .stat-2,
  .stat-3,
  .stat-4,
  .stat-5,
  .stat-6{
    top:auto;
    bottom:auto;
    left:auto;
    right:auto;
  }

}
	/* Logos */
	
	.practices-section{
  background:#f2f2f2;
  padding:100px 20px;
  text-align:center;
}

.practices-section h2{
  font-size:48px;
  font-weight:inherit;
  color:#4a4a4a;
  margin-bottom:80px;
}

.practices-section h2 span{
  color:#3B6EF5;
  font-weight:600;
}

.logos-container{
  max-width:1200px;
  margin:auto;
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:60px;
  align-items:center;
}

.logo-item{
  display:flex;
  justify-content:center;
  align-items:center;
}

.logo-item img{
  max-width: 180px !important;
  width:100%;
  opacity:0.6;
  filter: grayscale(100%);
  transition:all .3s ease;
}

/* Hover opcional */

.logo-item img:hover{
  opacity:1;
  filter: grayscale(0%);
  transform:scale(1.05);
}

/* Responsive */

@media(max-width:992px){
  .logos-container{
    grid-template-columns: repeat(2, 1fr);
    gap:40px;
  }

  .practices-section h2{
    font-size:36px;
  }
}

@media(max-width:600px){
  .logos-container{
    grid-template-columns: 1fr;
  }

  .practices-section{
    padding:60px 20px;
  }

  .practices-section h2{
    font-size:28px;
  }
}
	
	
/* Video */	
	
  .video-section{
  text-align:center;
  padding:100px 20px;
}

.video-player{
  width:100%;
  max-width:1127px;
  border-radius:20px;
  box-shadow:0 20px 40px rgba(0,0,0,0.1);
}
	
/* =========================
   FAQ SECTION
========================= */

.faq-section{
  padding:100px 120px;
}

.faq-container{
  max-width:1200px;
  margin:auto;
  display:grid;
  grid-template-columns: 320px 1fr;
  gap:80px;
  align-items:start;
}

/* =========================
   COLUMNA IZQUIERDA
========================= */

.faq-left h2{
  font-size:40px;
  font-weight:400;
  color:#4a4a4a;
  line-height:1.1;
  margin-bottom:40px;
}

.faq-btn{
  display:inline-flex;
  align-items:center;
  gap:12px;
  padding:14px 28px;
  border:1px solid #0033A0;
  border-radius:40px;
  text-decoration:none;
  color:#0033A0;
  font-weight:600;
  transition:all .3s ease;
}

.faq-btn:hover{
  background:#0033A0;
  color:white;
}

/* =========================
   ACORDEÓN
========================= */

.accordion-item {
  border-bottom: 1px solid #81B1FF;
  padding: 26px 28px;
  margin-bottom: 16px;
  transition: all .3s ease;
}

.accordion-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  cursor:pointer;
  gap:20px;
}

.accordion-left{
  display:flex;
  gap:20px;
  align-items:flex-start;
}


.accordion-title{
  font-size:18px;
  color:#2D6DF6;
  font-weight:600;
  line-height:1.3;
}

.accordion-icon{
  font-size:20px;
  color:#2F6DF6;
  transition:transform .3s ease;
  flex-shrink:0;
}

/* Contenido */

.accordion-content{
  max-height:0;
  overflow:hidden;
  transition:max-height .45s ease;
  margin-top:0;
  color:#3F3F41;
  line-height:1.6;
}

.accordion-item.active .accordion-content{
  max-height:500px; /* más flexible */
  margin-top:20px;
}

.accordion-item.active .accordion-icon{
  transform:rotate(180deg);
}

/* =========================
   RESPONSIVE
========================= */

@media(max-width:1024px){

  .faq-section{
    padding:80px 60px;
  }

  .faq-container{
    grid-template-columns:1fr;
    gap:50px;
  }

  .faq-left{
    text-align:center;
  }

  .faq-left h2{
    font-size:34px;
  }

  .faq-btn{
    justify-content:center;
  }

}

@media(max-width:640px){

  .faq-section{
    padding:60px 20px;
  }

  .faq-left h2{
    font-size:28px;
  }

  .accordion-item{
    padding:20px;
  }

  .accordion-title{
    font-size:16px;
  }

  .accordion-content{
    font-size:15px;
  }

}
	
/* ============================= */
/* GLASS CONTAINER */
/* ============================= */

.con-container {
    position: fixed;
    z-index: 9999;

    width: 462px;
    height: 86px;

    display: flex;
    align-items: center;
    justify-content: center;

    margin-left: 680px;
    margin-top: 70px;

    border-radius: 345px;
    overflow: hidden;

    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);

    background: linear-gradient(
        40deg,
        rgba(255, 255, 255, 0.18) 0%,
        rgba(255, 255, 255, 0.08) 60%
    );

    box-shadow:
        inset 0 2px 6px rgba(255, 255, 255, 0.25),
        inset 0 -8px 20px rgba(0, 0, 0, 0.25),
        0 10px 30px rgba(0, 0, 0, 0.35);

    border: 1px solid rgba(255, 255, 255, 0.25);
}

/* ============================= */
/* TEXT */
/* ============================= */

.word-mask{
  height:80px;
  overflow:hidden;
  position:relative;
  z-index:2;
}

.word-list{
  display:flex;
  flex-direction:column;
  animation: scrollWords 12s infinite;
  animation-delay:1.8s; /* After delay 1800ms */
}

/* Cada palabra */
.word{
  height:80px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:64px;
  line-height:1;
}

/* Con en Bold */
.con{
  font-weight:700;
  color:white;
}

/* Resto Light Italic */
.rest{
  font-weight:300;
  font-style:italic;
  color:white;
  margin-left:2px;
}

/* ============================= */
/* ANIMACIÓN tipo Smart Animate */
/* Duration 200ms */
/* Ease in and out back */
/* ============================= */

@keyframes scrollWords {

  0%   { transform: translateY(0); }
  15%  { transform: translateY(0); }

  /* transición 200ms con curva back */
  18%  { transform: translateY(-80px); }
  33%  { transform: translateY(-80px); }

  36%  { transform: translateY(-160px); }
  51%  { transform: translateY(-160px); }

  54%  { transform: translateY(-240px); }
  69%  { transform: translateY(-240px); }

  72%  { transform: translateY(-320px); }
  87%  { transform: translateY(-320px); }

  90%  { transform: translateY(-400px); }
  100% { transform: translateY(0); }
}

/* Aplicamos la curva global tipo easeInOutBack */
.word-list{
  animation-timing-function:cubic-bezier(0.68,-0.6,0.32,1.6);
}

@media(max-width:768px){
  .word{
    font-size:42px;
    height:50px;
  }
  .word-mask{
    height:50px;
  }
}


/* ============================= */
/* PAGINA INTERNA SERVICIOS */
/* ============================= */


/* BANNER */
.banner-wrapper{width:100%;position:relative;}
.banner-hero{position:relative;height:472px;display:flex;align-items:center;padding:0 8%;color:white;overflow:hidden;}
.banner-hero::before{content:"";position:absolute;inset:0;background:url("https://conexxion.sura.com/documents/d/guest/fondo-banner-serviciosti01") right center / cover no-repeat;z-index:1;}
.banner-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(15,25,35,0.85) 0%,rgba(15,25,35,0.65) 40%,rgba(15,25,35,0.00) 75%);z-index:2;}
.banner-content{position:relative;z-index:3;max-width:620px;}
.banner-pill{display:inline-block;padding:8px 18px;border:1px solid rgba(255,255,255,0.6);border-radius:50px;font-size:14px;margin-bottom:24px;}
.banner-title{font-size:62px;font-weight:700;line-height:1.05;margin:0 0 18px 0;width: 700px;font-family: 'Sura Sans';}
.banner-subtitle{font-size:32px;font-weight:300;margin:0;font-family: 'Sura Sans';}

/* INTRO */
.intro-section{
    padding: 110px 8%;
    text-align: center;
    font-size: 48px;
    font-family: 'Sura Sans';
    line-height: 0.9;
    color: #3F3F41;}
.intro-container{max-width:1030px;margin:0 auto;}
.intro-container h1{font-size:48px;font-weight:400;margin-bottom:40px;color:#3F3F41; line-height: 45px;}
.highlight{color:#3B6EEA;font-weight:600;}

/* DATA SECTION */
.data-section{padding:100px 18%;background:#f5f6f8;}
.data-container{max-width:1200px;margin:0 auto;}
.data-title{text-align:center;font-size:42px;font-weight:400;margin-bottom:80px;color:#3F3F41;line-height: 45px;font-family: 'Sura Sans';}
.data-title strong{color:#2f6fed;font-weight:600;}
.data-layout{display:grid;grid-template-columns:55% 45%;align-items:center;}
.data-image img{width:100%;max-width:560px;border-radius:20px;display:block;}
.data-card-column{display:flex;flex-direction:column;align-items:flex-start;}
.data-card{width:520px;height: 320px;background:white;padding:40px;border-radius:24px;box-shadow:0 25px 60px rgba(0,0,0,0.12);transition:.4s ease;margin-top:60px;transform:translateX(-25%);}
.data-card.animate{transform:translateX(-25%) translateY(-6px);}
.data-card:hover{transform:translateX(-25%) scale(1.03);box-shadow:0 35px 70px rgba(0,0,0,0.18);}

/* LISTA */
.data-list{list-style:none;padding:0;margin:0;}
.data-list li{margin-bottom:20px;font-size:18px;color:#3F3F41;padding-left:28px;position:relative;}
.data-list li::before{
  content:"";
  background:url("https://conexxion.sura.com/documents/d/guest/ico-lista") no-repeat center;
  width:20px;height:20px;
  position:absolute;left:0;top:2px;
}

/* CONTROLES */
.data-controls{display:flex;align-items:center;gap:20px;margin-top:30px;margin-left:120px;transform:translateX(-25%);}
.data-arrow{width:42px;height:42px;border-radius:50%;border:1px solid #2f6fed;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#2f6fed;transition:.3s;}
.data-arrow:hover{background:#2f6fed;color:white;}
.data-arrow.active{background:#2f6fed;color:white;}
.data-counter{font-size:16px;color:#777;}

/* RESPONSIVE */
@media(max-width:1024px){
  .data-layout{grid-template-columns:1fr;gap:40px;}
  .data-card{transform:none;width:100%;}
  .data-controls{transform:none;margin-left:0;}
}
@media(max-width:768px){
  .banner-title{font-size:40px;}
  .intro-container h1{font-size:32px;}
}
	
	
	/* CONTENEDOR */
	
	
 .section-beneficios {
  max-width: 1000px;
  margin: auto;
  padding: 120px;
}
	
.section-cifras {
    max-width: 1000px;
    margin: auto;
}

.section-container {
  margin-bottom: 40px;
}

.badge {
    display: inline-block;
    padding: 6px 16px !important;
    border: 1px solid #CFE0FF;
    border-radius: 20px!important;
    font-size: 14px!important;
    font-weight: normal!important;
    color: #3F3F41;
    margin-bottom: 20px;
}

.title-xl {
  font-size: 40px;
  font-weight: 700;
  color: #2D6DF6;
  margin: 0;
}

.title-md {
  font-size: 40px;
  font-weight: 400;
  color: #3F3F41;
  margin-top: 6px;
}


/* ========================= */
/* SECCION CAJAS ROTATIVAS */
/* ========================= */

.section-cajas{
  max-width:1200px;
  margin:120px auto;
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:80px;
  font-family: 'Sura Sans';
}

/* TEXTO IZQUIERDA */

.section-container{
  max-width:420px;
}

/* ========================= */
/* GRID CAJAS */
/* ========================= */

.cajas{
  margin-top:60px;
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:40px;
  max-width:720px;
}

/* Atenuar otras cajas */

.cajas:has(.caja:hover) .caja:not(:hover){
  opacity:0.5;
  transform:scale(0.95);
}

/* ========================= */
/* CAJA */
/* ========================= */

.caja{
  background:#F1F3F5;
  border-radius:24px;
  padding:40px;
  min-height:260px;
  position:relative;

  transition:all .4s cubic-bezier(.22,1,.36,1);
  transform-origin:center;
  box-shadow:0 10px 30px rgba(0,0,0,0.05);

  transform:rotate(0deg);
}

/* ROTACION EN HOVER */

.caja:nth-child(1):hover{ transform:rotate(-3deg) scale(1.05); }
.caja:nth-child(2):hover{ transform:rotate(3deg) scale(1.05); }
.caja:nth-child(3):hover{ transform:rotate(-2deg) scale(1.05); }
.caja:nth-child(4):hover{ transform:rotate(2deg) scale(1.05); }

.caja:hover{
  background:#DFEAFF;
  box-shadow:0 25px 70px rgba(47,111,237,0.25);
  z-index:2;
}

/* ========================= */
/* ICONO */
/* ========================= */

.icon{
  width:60px;
  height:60px;
  margin-bottom:20px;
  opacity:0.6;
}

/* ========================= */
/* TITULO */
/* ========================= */

.caja h3{
  font-size:24px;
  color:#2F6FED;
  margin-bottom:12px;
  font-weight:bold;
}

/* ========================= */
/* TEXTO */
/* ========================= */

.caja p{
  font-size:15px;
  color:#555;
  line-height:1.5;
}

/* ========================= */
/* RESPONSIVE */
/* ========================= */

@media(max-width:900px){

  .section-cajas{
    flex-direction:column;
  }

  .cajas{
    grid-template-columns:1fr;
  }

}

	
	/* WRAPPER */
.carousel-wrapper{
  display:flex;
  align-items:center;
  gap:40px;
  max-width:1200px;
  width:100%;
  position:relative;
}

/* BLOQUE IMAGEN + CONTROLES */
.image-block{
  position:relative;
  display:flex;
  align-items:center;
}

/* ---------- CONTROLES VERTICALES ---------- */

.data-controlador{
  position:absolute;
  left:-90px;              /* Se posiciona al lado izquierdo */
  top:50%;
  transform:translateY(-50%);
  display:flex;
  flex-direction:column;   /* Vertical */
  align-items:center;
  gap:20px;
}

.data-flecha{
  width:42px;
  height:42px;
  border-radius:50%;
  border:1px solid #2f6fed;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  color:#2f6fed;
  transition:.3s;
  user-select:none;
}

.data-flecha:hover{
  background:#2f6fed;
  color:white;
}

.data-flecha.active{
  background:#2f6fed;
  color:white;
}

.data-counter{
  font-size:16px;
  color:#777;
  display:flex;
  gap:4px;
}

/* ---------- IMAGEN ---------- */

.image-container{
  width:552px;
  height:436px;
  border-radius:20px;.vc-item:not(:last-child)::before
  overflow:hidden;
  flex-shrink:0;
}

.image-container img{
  width:100%;
  height:100%;
  object-fit:cover;
}

/* ---------- LISTA ---------- */

.list-container{
  height:436px;
  overflow:hidden;
  flex:1;
}

.list{
  display:flex;
  flex-direction:column;
  transition:transform .5s cubic-bezier(.22,1,.36,1);
}

.item{
  display:flex;
  gap:18px;
  padding:28px 0;
  position:relative;
}

/* Flecha entre ítems */
.item:not(:last-child)::after{
  content:"";
  position:absolute;
  left:18px;
  bottom:-12px;
  width:1px;
  height:20px;
  background:#C9CDD6;
}

.item:not(:last-child)::before{
  content:"";
  position:absolute;
  left:14px;
  bottom:-20px;
  border-left:5px solid transparent;
  border-right:5px solid transparent;
  border-top:6px solid #C9CDD6;
}

.item img{
  width:36px;
  height:36px;
  margin-top:6px;
}

.content h3{
  font-size:22px;
  font-weight:700;
  color:#3F3F41;
  margin-bottom:8px;
}

.content p{
  font-size:18px;
  color:#444;
  line-height:1.5;
}

.highlight{
  color:#2D6DF6;
  font-weight:700;
}

/* RESPONSIVE */
@media(max-width:1100px){
  .carousel-wrapper{
    flex-direction:column;
  }
  .data-controlador{
    position:relative;
    left:0;
    top:0;
    transform:none;
    flex-direction:row;
    margin-bottom:20px;
  }
}
	/* CAROUSEL VERTICAL */
/* ============================= */

.carousel-wrapper{
  display:flex;
  align-items:center;
  gap:60px;
  max-width:1200px;
  margin:120px auto;
  position:relative;
}

/* BLOQUE IMAGEN + CONTROLES */
.image-block{
  position:relative;
  display:flex;
  align-items:center;
}

/* CONTROLES VERTICALES */
.data-controlador{
  position:absolute;
  left:-90px;
  top:50%;
  transform:translateY(-50%);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:20px;
}

.data-flecha{
  width:42px;
  height:42px;
  border-radius:50%;
  border:1px solid #2f6fed;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  color:#2f6fed;
  transition:.3s;
  user-select:none;
}

.data-flecha:hover{
  background:#2f6fed;
  color:white;
}

.data-flecha.active{
  background:#2f6fed;
  color:white;
}

.data-counter{
  font-size:16px;
  color:#777;
}

/* IMAGEN */
.vc-image-container{
  width:552px;
  height:436px;
  border-radius:20px;
  overflow:hidden;
  flex-shrink:0;
}

.vc-image-container img{
  width:100%;
  height:100%;
  object-fit:cover;
}

/* LISTA */
.vc-list-container{
  height:436px;
  overflow:hidden;
  flex:1;
}

.vc-list{
  display:flex;
  flex-direction:column;
  transition:transform .5s cubic-bezier(.22,1,.36,1);
}

.vc-item{
  display:flex;
  padding:28px 0;
  position:relative;
}

/* Flecha gris entre ítems */
.vc-item:not(:last-child)::after {
    content: "";
    position: absolute;
    left: 26px;
    transform: translateX(-50%);
    bottom: 5px;
    width: 1px;
    height: 40px;
    background: #888B8D;
}

.vc-item:not(:last-child)::before{
  content:"";
  position:absolute;
  left:26px;
  transform:translateX(-50%);
  bottom:5px;
  border-left:5px solid transparent;
  border-right:5px solid transparent;
  border-top:6px solid #888B8D;
}

.vc-item img{
  width:60px;
  height:60px;
  margin-top:6px;
}

.vc-content h3{
  font-size:22px;
  font-weight:500;
  color:#3F3F41;
  margin-bottom:8px;
}

.vc-content p{
  font-size:18px;
  color:#444;
  line-height:1.5;
}

.highlight{
  color:#2D6DF6;
  font-weight:700;
}

/* RESPONSIVE */
@media(max-width:1100px){
  .carousel-wrapper{
    flex-direction:column;
  }
  .data-controlador{
    position:relative;
    left:0;
    top:0;
    transform:none;
    flex-direction:row;
    margin-bottom:20px;
  }
}
	.datos-container{
  max-width:900px;
  margin:30px auto 60px auto;
  text-align: center;
}

.datos-titulo{
  font-size:40px;
  font-weight:700;
  margin-bottom:20px;
  color:#3F3F41;
}

.resaltado{
  color:#2D6DF6; /* mismo azul que venías usando */
}

.datos-parrafo{
  font-size:24px;
  line-height:1.4;
  color:#444;
  max-width:800px;
}

/* BANNER CIERRE GLASS */
.glass-banner-wrapper{
  padding:120px 40px 80px;
  display:flex;
  justify-content:center;

  position:relative;
  z-index:2;
}

/* BANNER */
.glass-banner{
  position:relative;
  max-width:1100px;
  width:100%;
  height:350px;
  padding:80px;
  border-radius:28px;
  display:flex;
  align-items:center;

  background:rgba(255,255,255,0.55); /* más transparente */

  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);

  border:1px solid rgba(255,255,255,0.35);

  box-shadow:0 30px 60px rgba(0,0,0,0.08);
}

/* IMAGEN DE FONDO DERECHA */
.glass-banner::after{
content:"";
position:absolute;
top:0;
right:0;
width:34%;
height:100%;
background:url("https://conexxion.sura.com/documents/d/guest/mujer-taza-fondo") center/cover no-repeat;
border-top-right-radius:28px;
border-bottom-right-radius:28px;
z-index:1;
}

/* CONTENIDO */

.glass-content {
    position: relative;
    z-index: 2;
    max-width: 570px;
}

.glass-title{
display:flex;
align-items:center;
gap:20px;
margin-bottom:25px;
}

.icon-circle{
  width:60px;
  height:60px;

  background-image:url("https://conexxion.sura.com/documents/d/guest/ico-check");
  background-repeat:no-repeat;
  background-position:center;
  background-size:28px;

  display:flex;
  align-items:center;
  justify-content:center;
}

.glass-content h2 {
    font-size: 40px;
    color: #2D6DF6;
    font-weight: 450;
    font-family: 'Sura Sans';
    line-height: 0.9;
}

.glass-content p {
    font-size: 20px;
    color: #4B5563;
    line-height: 1.2;
    font-family: 'Sura Sans';
}

/* MUJER */
.glass-woman{
position:absolute;
right:-10px;
bottom:0;
z-index:3;
pointer-events:none;
}

.glass-woman img{
height:400px;
object-fit:contain;
filter:drop-shadow(0 30px 40px rgba(0,0,0,0.2));
}

/* SECCION INTERES */

.interest-section{
  background:#F3F4F6;
  width:100%;
  padding:230px 40px 160px;
  margin-top:-250px;
  text-align:center;

  position:relative;
  z-index:1;
}

.interest-section h3{
font-size:42px;
margin-bottom:60px;
color:#374151;
font-weight:600;
}

/* GRID */

.interest-grid{
  max-width:1200px;
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
}

/* CARD */

.interest-card{
background:white;
padding:22px 26px;
border-radius:16px;

display:flex;
align-items:center;
gap:14px;

box-shadow:0 10px 25px rgba(0,0,0,0.05);

transition:.25s;
cursor:pointer;
}

.interest-card:hover{
transform:translateY(-6px);
box-shadow:0 18px 35px rgba(0,0,0,0.08);
}

/* ICONO */

.interest-icon{
width:36px;
height:36px;

display:flex;
align-items:center;
justify-content:center;

color:#2D6DF6;
font-size:22px;
}

/* TEXTO */

.interest-card p{
font-size:16px;
color:#4B5563;
text-align:left;
}

/* RESPONSIVE */

@media(max-width:1100px){

.glass-banner{
padding:60px;
}

.glass-woman img{
height:420px;
}

.interest-grid{
grid-template-columns:repeat(2,1fr);
}

}

@media(max-width:768px){

.glass-banner{
flex-direction:column;
text-align:center;
padding:50px 30px;
}

.glass-banner::after{
display:none;
}

.glass-woman{
position:relative;
right:auto;
margin-top:40px;
}

.glass-woman img{
height:auto;
max-width:300px;
}

.interest-grid{
grid-template-columns:1fr;
}

}
