:root{
  --azul-d2d:#2f9bd1;
  --azul-fondo:#cfefff;
  --gris-fondo:#e6e6e6;
  --azul-hover:#4fa3d9;
  --azul-cliente:#b5e8ff;
}
main{
  padding-top:80px;
}

@font-face {
  font-family: 'Telegraf';
  src: url('/fonts/Telegraf.woff2') format('woff2');
  font-weight: 400 700;
  font-style: normal;
  font-display: swap;
}

*{margin:0;padding:0;box-sizing:border-box;font-family:'Segoe UI',sans-serif;}


.navbar{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  padding:20px 15%;
  background:#fff;
  position:sticky;
  top:0;
  z-index:1000;
}

.nav-center{
  display:flex;
  justify-content:center;
  align-items:center; /* 👈 CLAVE */
  gap:30px;
}

.nav-item{
  text-decoration:none;
  color:#000;
  font-weight:600;
  padding:10px 14px;
  transition:background .25s ease, color .25s ease;
}

.nav-item:hover{
  background:var(--azul-d2d);
  color:#fff;
}

.nav-item.active{
  background:#6fa8dc;
  color:#fff;
}

/* Dropdown Menu Styles */
.dropdown{
  position:relative;
}

.dropdown-content{
  display:none;
  position:absolute;
  top:100%;
  left:0;
  background:#fff;
  min-width:180px;
  box-shadow:0 8px 20px rgba(0,0,0,.15);
}

.dropdown-content a{
  display:block;
  padding:12px 16px;
  color:#000;
  text-decoration:none;
}

.dropdown-content a:hover{
  background:var(--azul-d2d);
  color:#fff;
}

.dropdown:hover .dropdown-content{
  display:block;
}


/* Dropdown Menu Styles */

.logo{height:75px;}

.nav-links{
  display:flex;
  gap:20px;
}

.nav-links a{
  text-decoration:none;
  color:#000;
  font-weight:600;
}

.hamburger{
  display:none;
  flex-direction:column;
  cursor:pointer;
}

.hamburger span{
  width:25px;
  height:3px;
  background:var(--azul-d2d);
  margin:4px 0;
}

.hero{
  display:flex;
  min-height:90vh;
}

.hero-text{
  flex:1;
  padding:80px;
  background:var(--gris-fondo);

    display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:flex-start; /* 👈 CLAVE */
}

.hero-text h1{
  font-family: 'Telegraf', sans-serif;
  font-weight: 700;
  font-size: 52px;
  color: var(--azul-d2d);
  line-height: 1.2;
  margin-bottom: 20px;
}

.hero-subtitle{
 font-family: 'Telegraf', sans-serif;
  font-weight: 400;
  font-size: 28px;
  color: #ffffff;
  margin-bottom: 30px;
}

.hero-image{
  flex:0.7;
  background:url('../img/principal.jpg') center/cover no-repeat;
}

.btn-primary{
   font-family: 'Telegraf', sans-serif;
  font-weight:700; 
  display:inline-block;
  margin-top:25px;
  padding:15px 30px;
  background:var(--azul-d2d);
  color:#fff;
  border-radius:8px;
  text-decoration:none;
}

.section{
  padding:80px 10%;
  text-align:center;
}

.section.blue{background:var(--azul-fondo);}
.section.white{background:#fff;}

.services{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
  gap:30px;
  margin-top:40px;
}

.service-box{
  background:#fff;
  padding:30px;
  border-radius:12px;
}

/* Setion nosotros */
.section-about{
  position:relative;
  background:#ffffff;
  padding:100px 0;
  overflow:hidden; /* 👈 para la imagen de esquina */
}

.about-inner{
  max-width:1200px;       /* 👈 mismo ancho visual */
  margin:0 auto;
  padding:0 6%;
}

.about-text h2{
  font-family:'Telegraf', sans-serif;
  font-weight:700;
  font-size:57.7px;
  color:var(--azul-d2d);
  margin-bottom:25px;
}

.about-text p{
  font-family:'Telegraf', sans-serif;
  font-weight:400;          /* 👈 SIN negrita */
  font-size:22px;
  line-height:1.8;
  color:#000;               /* 👈 negro normal */
  background:none;          /* 👈 quita fondo azul */
  max-width:750px;
  text-align:justify;
}


.about-decoration{
  position:absolute;
  bottom:-100px;
  right:-40px;
  width:460px;
  height:460px;
  background:url('../img/nosotros.png') no-repeat center/contain;
  opacity:0.9;
  pointer-events:none;
}

/* fin nosotros */ 

/*servicios */
.section-services{
  background:var(--azul-fondo);
  padding:100px 6%;
  text-align:center;
}

.section-services h2{
  font-family:'Telegraf', sans-serif;
  font-weight:700;
  font-size:42px;
  color:#3a8ec1;
  margin-bottom:70px;
}

.services-grid{
  max-width:1200px;
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:60px;
}

.service-item{
  text-align:left;
}

.service-icon{
  width:56px;
  height:56px;
  border-radius:50%;
  background:#3a8ec1;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:28px;
  font-weight:700;
  margin:0 auto 25px;
}

.service-item h3{
  font-family:'Telegraf', sans-serif;
  font-weight:700;
  font-size:24px;
  color:#3a8ec1;
  text-align:center;
  margin-bottom:20px;
}

.service-item ul{
  list-style:disc;
  padding-left:40px;
}

.service-item li{
  font-family:'Telegraf', sans-serif;
  font-size:22px;
  line-height:1.8;
  margin-bottom:6px;
}

@media(max-width:900px){

  .section-services{
    padding:70px 6%;
  }

  .section-services h2{
    font-size:32px;
    margin-bottom:50px;
  }

  .services-grid{
    grid-template-columns:1fr;
    gap:50px;
  }

  .service-item{
    text-align:center;
  }

  .service-item ul{
    padding-left:0;
    list-style-position:inside;
  }
}

/* responsive servicios */

/* responsive iso */

.section-certificaciones{
  background:#e6e6e6;          /* gris claro */
  padding:100px 0;
}

.cert-inner{
  max-width:1200px;
  margin:0 auto;
  padding:0 6%;
}

.section-certificaciones h2{
  font-family:'Telegraf', sans-serif;
  font-weight:700;
  font-size:50px;
  color:var(--azul-d2d);
  text-align:center;
  margin-bottom:30px;
}

.cert-intro{
  font-family:'Telegraf', sans-serif;
  font-size:19px;
  line-height:1.8;
  text-align:center;
  max-width:900px;
  margin:0 auto 20px;
  text-align:justify;
}

.cert-icons{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:40px;
  margin:50px 0 40px;
  text-align:center;
}

.cert-item img{
  width:120px;
  margin-bottom:12px;
}

.cert-item span{
  font-family:'Telegraf', sans-serif;
  font-weight:700;
  font-size:16px;
}

.cert-item small{
  display:block;
  font-weight:400;
  font-size:13px;
}

.cert-subtitle{
  font-family:'Telegraf', sans-serif;
  font-size:19px;
  line-height:1.8;
  text-align:center;
  max-width:900px;
  margin:0 auto 20px;
  text-align:justify;
}

.cert-list{
  max-width:600px;
  margin-left:20px;
  margin-bottom:25px;
  margin:0 120px 20px;
}

.cert-list li{
  font-family:'Telegraf', sans-serif;
  font-size:19px;
  line-height:1.8;
  margin-bottom:6px;
}

.cert-footer{
 font-family:'Telegraf', sans-serif;
  font-size:19px;
  line-height:1.8;
  text-align:center;
  max-width:900px;
  margin:0 auto 20px;
  text-align:justify;
}

@media(max-width:900px){

  .section-certificaciones{
    padding:70px 0;
  }

  .section-certificaciones h2{
    font-size:32px;
  }

  .cert-icons{
    grid-template-columns:repeat(2, 1fr);
    gap:30px;
  }

  .cert-intro,
  .cert-subtitle,
  .cert-footer{
    text-align:center;
  }

  .cert-list{
    margin:0 auto 25px;
    padding-left:20px;
  }
}
/* responsive iso */

/* responsive marcas*/

.section-socios{
  background:#ffffff;
  padding:100px 0;
  text-align:center;
}

.section-socios h2{
  font-family:'Telegraf', sans-serif;
  font-weight:700;
  font-size:42px;
  color:var(--azul-d2d);
  margin-bottom:60px;
}

.socios-image{
  max-width:1200px;     /* 👈 MISMO ANCHO QUE TODO */
  margin:0 auto;
  padding:0 0%;
}

.socios-image img{
  width:100%;
  height:auto;
  display:block;
  margin:0 auto;
}

@media(max-width:900px){

  .section-socios{
    padding:70px 0;
  }

  .section-socios h2{
    font-size:32px;
    margin-bottom:40px;
  }

  .socios-image{
    padding:0 5%;
  }
}
/*responsive socios*/

/* responsive clientes*/

.section-clientes{
  background:var(--azul-cliente);
  padding:100px 0;
  text-align:center;
}

.section-clientes h2{
  font-family:'Telegraf', sans-serif;
  font-weight:700;
  font-size:42px;
  color:var(--azul-d2d);
  margin-bottom:60px;
}

.clientes-image{
  max-width:1200px;     /* 👈 MISMO ANCHO QUE TODO */
  margin:0 auto;
  padding:0 0%;
}

.clientes-image img{
  width:100%;
  height:auto;
  display:block;
  margin:0 auto;
}

@media(max-width:900px){

  .section-clientes{
    padding:70px 0;
  }

  .section-clientes h2{
    font-size:32px;
    margin-bottom:40px;
  }

  .clientes-image{
    padding:0 5%;
  }
}
/*responsive clientes*/
@media(max-width:900px){
  .section-about{
    padding:70px 0;
  }

  .about-text h2{
    font-size:32px;
    text-align:center;
  }

  .about-text p{
    text-align:center;
    margin:0 auto;
  }

  .about-decoration{
    width:180px;
    height:180px;
    bottom:-30px;
    right:-30px;
  }
}

/* section nosotros*/
/* ANIMACIONES 
.animate{
  opacity:0;
  transform:translateY(40px);
  transition:all .8s ease;
}*/

.animate.show{
  opacity:1;
  transform:translateY(0);
}

.delay1{transition-delay:.2s;}
.delay2{transition-delay:.4s;}
.delay3{transition-delay:.6s;}

/* FOOTER */
.footer{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
  padding:60px 10%;
  background:#eaeaea;
}

/* RESPONSIVE */
@media(max-width:900px){
  .navbar{
    grid-template-columns:auto auto;
  }

  .nav-center{
    position:absolute;
    top:80px;
    left:0;
    width:100%;
    background:#fff;
    flex-direction:column;
    align-items:center;
    display:none;
  }

  .nav-center.active{
    display:flex;
  }

  .hamburger{
    display:flex;
    padding-left: 90%;
  }

  .dropdown-content{
    position:static;
    box-shadow:none;
  }
}

/*footer*/
.footer-d2d{
  background:#e6e6e6;
  padding:80px 0;
}

.footer-inner{
  max-width:1200px;
  margin:0 auto;
  padding:0 6%;
  display:grid;
  grid-template-columns:1.2fr 1.5fr 1.8fr;
  gap:60px;
  align-items:flex-start;
}

.footer-logo{
  display:flex;
  align-items:center;     /* 👈 centra vertical */
  height:100%;
}

.footer-logo img{
  max-width:620px;   /* antes 200px */
}

.footer-contact h3,
.footer-policies h3{
  font-family:'Telegraf', sans-serif;
  font-weight:700;
  font-size:32px;
  color:var(--azul-d2d);
  margin-bottom:15px;
}

.footer-contact p{
  font-family:'Telegraf', sans-serif;
  font-size:17px;
  line-height:1.6;
  color:var(--azul-d2d);
  margin-bottom:12px;
}

.footer-contact a{
  color:var(--azul-d2d);
  text-decoration:none;
}

.footer-bold{
  font-weight:700;
  margin-top:10px;
}

.map-btn{
  display:inline-block;
  background:#b7dff5;
  color:#000;
  padding:8px 14px;
  border-radius:20px;
  font-size:14px;
  margin:10px 0 20px;
}

.footer-social{
  margin-bottom:30px;
}

.social-icons{
  display:flex;
  gap:15px;
  margin-top:10px;
}

.social-icons img{
  width:50px;
  opacity:.8;
  transition:opacity .2s;
}

.social-icons img:hover{
  opacity:1;
}

.footer-policies ul{
  list-style:disc;
  padding-left:20px;
  color:var(--azul-d2d);
}

.footer-policies li{
  font-family:'Telegraf', sans-serif;
  font-size:16px;
  margin-bottom:8px;
}

@media(max-width:900px){

  .footer-inner{
    grid-template-columns:1fr;
    gap:40px;
    text-align:center;
  }

  .footer-policies ul{
    padding-left:0;
    list-style-position:inside;
  }

  .social-icons{
    justify-content:center;
  }

  .footer-logo img{
    margin:0 auto;
  }

   .footer-logo{
    justify-content:center;
  }
}
/*footer*/

/*footer2*/
.footer2-d2d{
  background:var(--azul-cliente);
  padding:80px 0;
}

.footer2-inner{
  max-width:1200px;
  margin:0 auto;
  padding:0 6%;
  display:grid;
  grid-template-columns:1.2fr 1.5fr 1.8fr;
  gap:60px;
  align-items:flex-start;
}

.footer2-logo{
  display:flex;
  align-items:center;     /* 👈 centra vertical */
  height:100%;
}

.footer2-logo img{
  max-width:620px;   /* antes 200px */
}

.footer2-contact h3,
.footer2-policies h3{
  font-family:'Telegraf', sans-serif;
  font-weight:700;
  font-size:32px;
  color:var(--azul-d2d);
  margin-bottom:15px;
}

.footer2-contact p{
  font-family:'Telegraf', sans-serif;
  font-size:17px;
  line-height:1.6;
  color:var(--azul-d2d);
  margin-bottom:12px;
}

.footer2-contact a{
  color:var(--azul-d2d);
  text-decoration:none;
}

.footer2-bold{
  font-weight:700;
  margin-top:10px;
}

.map2-btn{
  display:inline-block;
  background:#b7dff5;
  color:#000;
  padding:8px 14px;
  border-radius:20px;
  font-size:14px;
  margin:10px 0 20px;
}

.footer2-social{
  margin-bottom:30px;
}

.social-icons{
  display:flex;
  gap:15px;
  margin-top:10px;
}

.social-icons img{
  width:50px;
  opacity:.8;
  transition:opacity .2s;
}

.social-icons img:hover{
  opacity:1;
}

.footer2-policies ul{
  list-style:disc;
  padding-left:20px;
  color:var(--azul-d2d);
}

.footer2-policies li{
  font-family:'Telegraf', sans-serif;
  font-size:16px;
  margin-bottom:8px;
}

@media(max-width:900px){

  .footer2-inner{
    grid-template-columns:1fr;
    gap:40px;
    text-align:center;
  }

  .footer2-policies ul{
    padding-left:0;
    list-style-position:inside;
  }

  .social-icons{
    justify-content:center;
  }

  .footer2-logo img{
    margin:0 auto;
  }

   .footer2-logo{
    justify-content:center;
  }
}
/*footer2*/

/*---------------------------------------NOSOTROS----------------------------------------*/

.about-section{
 background:#e6e6e6;   
}

.about-container{
  max-width:1200px;
  margin:0 auto;
}

.about-title{
  font-family:'Telegraf', sans-serif;
  font-size:42px;
  font-weight:700;
  color:var(--azul-d2d);
  margin-bottom:20px;
  text-align: left;
}

.about-text{
  font-size:18px;
  line-height:1.7;
  color:#000;
  text-align:justify;
  margin-bottom:60px;
}

/* GRID VISIÓN / MISIÓN */
.about-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
}

.about-subtitle{
  font-family:'Telegraf', sans-serif;
  font-size:32px;
  font-weight:700;
  color:var(--azul-d2d);
  margin-bottom:15px;
  text-align: left;
}

.about-box p{
  font-size:18px;
  line-height:1.7;
  text-align:justify;
  color:#000;
}

/* RESPONSIVE */
@media(max-width:900px){
  .about-grid{
    grid-template-columns:1fr;
  }

  .about-title{
    font-size:34px;
  }

  .about-subtitle{
    font-size:28px;
  }
}

/* CERTIFICACIONES */
.certifications-section{
  background:#fff;
}

.certifications-container{
  max-width:1200px;
  margin:0 auto;
  display:grid;
  grid-template-columns:1.4fr 0.6fr;
  gap:60px;
  align-items:center;
}

.certifications-title{
  font-family:'Telegraf', sans-serif;
  font-size:40px;
  font-weight:700;
  color:var(--azul-d2d);
  margin-bottom:20px;
  text-align: left;
}

.certifications-intro{
  font-size:18px;
  line-height:1.7;
  margin-bottom:20px;
  color:#000;
  text-align: left;
}

.certifications-list{
  margin-left:20px;
  margin-bottom:30px;
  text-align: left;
}

.certifications-list li{
  font-size:18px;
  line-height:1.6;
  margin-bottom:6px;
}

.certifications-list {
  list-style:disc;
  padding-left:40px;
}


.certifications-icon{
  display:flex;
  justify-content:center;
}

.certifications-icon img{
  max-width:260px;
  opacity:1; /* look corporativo suave */
}

/* RESPONSIVE */
@media(max-width:900px){
  .certifications-container{
    grid-template-columns:1fr;
    text-align:left;
  }

  .certifications-icon{
    margin-top:40px;
  }

  .certifications-icon img{
    max-width:200px;
  }
}

/* CLIENTES POR SECTORES */
.clients-section{
  background:var(--azul-cliente); /* tu celeste claro */
}

.clients-container{
  max-width:1200px;
  margin:0 auto;
  display:grid;
  grid-template-columns:1.4fr 0.6fr;
  gap:60px;
  align-items:center;
}

.clients-title{
  font-family:'Telegraf', sans-serif;
  font-size:40px;
  font-weight:700;
  color:var(--azul-d2d);
  margin-bottom:20px;
  text-align: left;
}

.clients-intro{
  font-size:18px;
  line-height:1.7;
  margin-bottom:25px;
  color:#000;
  text-align: left;
}

.clients-list{
  list-style:none;
  padding:0;
  margin-bottom:30px;
  text-align: left;
}

.clients-list li{
  font-size:18px;
  line-height:1.7;
  margin-bottom:20px;
}

.clients-list strong{
  color:#000;
}

.clients-closing{
  font-size:18px;
  line-height:1.7;
  color:#000;
  text-align:justify;
}

/* ICONO */
.clients-icon{
  display:flex;
  justify-content:center;
}

.clients-icon img{
  max-width:260px;
  opacity:1; /* decorativo, no protagonista */
}

/* RESPONSIVE */
@media(max-width:900px){
  .clients-container{
    grid-template-columns:1fr;
  }

  .clients-icon{
    margin-top:40px;
  }

  .clients-icon img{
    max-width:200px;
  }
}

/* COMPROMISO ÉTICO Y AMBIENTAL */
.ethics-section{
  background:#e6e6e6; /* mismo gris que Nosotros */
}

.ethics-container{
  max-width:1200px;
  margin:0 auto;
}

.ethics-title{
  font-family:'Telegraf', sans-serif;
  font-size:40px;
  font-weight:700;
  color:var(--azul-d2d);
  margin-bottom:20px;
  text-align: left;
}

.ethics-text{
  font-size:18px;
  line-height:1.7;
  text-align:justify;
  color:#000;
  margin-bottom:20px;
  text-align: justify;
}

.ethics-list{
  margin:20px 0 30px 25px;
  padding-left: 40px;
}

.ethics-list li{
  font-size:18px;
  line-height:1.7;
  margin-bottom:6px;
  text-align: left;
}

 

/* RESPONSIVE */
@media(max-width:900px){
  .ethics-title{
    font-size:32px;
  }
}

/*---------------------------------------Servicios----------------------------------------*/
/* SERVICIOS */
.infra-section{
  background: var(--azul-cliente);
}

.infra-container{
  max-width:1200px;
  margin:0 auto;
}

/* TÍTULO PRINCIPAL */
.infra-main-title{
  font-family:'Telegraf', sans-serif;
  font-size:42px;
  font-weight:700;
  color:var(--azul-d2d);
  margin-bottom:40px;
  text-align: left;
}

/* GRID */
.infra-grid{
  display:grid;
  grid-template-columns:300px 1fr;
  gap:40px;
  align-items:center;
}

/* ICONO */
.infra-icon img{
  width:100%;
  max-width:260px;
  opacity:0.9;
}

/* CONTENIDO */
.infra-title{
  font-family:'Telegraf', sans-serif;
  font-size:26px;
  font-weight:700;
  color:var(--azul-d2d);
  margin-bottom:15px;
  text-align: left;
}

.infra-text{
  font-size:18px;
  line-height:1.7;
  text-align:justify;
  margin-bottom:20px;
}

.infra-list{
  margin-left:40px;
}

.infra-list li{
  font-size:18px;
  line-height:1.7;
  margin-bottom:10px;
  text-align: left;
}

/* RESPONSIVE */
@media(max-width:900px){

  .infra-grid{
    grid-template-columns:1fr;
    text-align:left;
  }

  .infra-icon{
    text-align:center;
  }

  .infra-icon img{
    max-width:200px;
    margin-bottom:30px;
  }

  .infra-main-title{
    font-size:34px;
  }
}

/* VARIANTE FONDO GRIS */
.infra-section.gray{
  background:#e6e6e6;
}

/* GRID INVERTIDO */
.infra-grid.reverse{
  grid-template-columns:1fr 300px;
}

/* RESPONSIVE */
@media(max-width:900px){

  .infra-grid.reverse{
    grid-template-columns:1fr;
  }

}

/* ===========================
   INFRA – SERVICIOS
=========================== */

.respa-section{
  background:#ffffff;
  padding:80px 0;
}

.respa-container{
  max-width:1200px;
  margin:0 auto;
  padding:0 6%;
}

.respa-grid{
  display:grid;
  grid-template-columns:300px 1fr;
  gap:60px;
  align-items:center;
}

.respa-icon img{
  width:100%;
  max-width:260px;
  opacity:0.85;
}

.respa-title{
  font-family:'Telegraf', sans-serif;
  font-size:26px;
  font-weight:700;
  color:var(--azul-d2d);
  margin-bottom:15px;
  text-align: left;
}

.respa-text{
  font-size:18px;
  line-height:1.7;
  margin-bottom:15px;
  text-align:justify;
}

.respa-list{
  margin-left:20px;
  padding-left: 40px;
}

.respa-list li{
  font-size:18px;
  line-height:1.7;
  margin-bottom:10px;
  text-align: left;
}

/* ===========================
   RESPONSIVE
=========================== */
@media(max-width:900px){

  .respa-grid{
    grid-template-columns:1fr;
    text-align:left;
  }

  .respa-icon{
    text-align:center;
  }

  .respa-icon img{
    max-width:200px;
    margin-bottom:30px;
  }

}

/* ===========================
   FIN SERVICIOS respaldo */

   /* ===========================
   SOPORTE Y MONITOREO
=========================== */

.sopor-section{
  background:var(--azul-cliente); /* celeste D2D */
  padding:80px 0;
}

.sopor-container{
  max-width:1200px;
  margin:0 auto;
  padding:0 6%;
}

.sopor-grid{
  display:grid;
  grid-template-columns:1fr 300px;
  gap:60px;
  align-items:center;
}

.sopor-title{
  font-family:'Telegraf', sans-serif;
  font-size:28px;
  font-weight:700;
  color:var(--azul-d2d);
  margin-bottom:15px;
  text-align: left;
}

.sopor-text{
  font-size:18px;
  line-height:1.7;
  margin-bottom:15px;
  text-align:justify;
}

.sopor-list{
  margin-left:20px;
  padding-left: 40px;
}

.sopor-list li{
  font-size:18px;
  line-height:1.7;
  margin-bottom:10px;
  text-align: left;
}

.sopor-icon img{
  width:100%;
  max-width:260px;
  opacity:0.85;
}

/* ===========================
   RESPONSIVE
=========================== */
@media(max-width:900px){

  .sopor-grid{
    grid-template-columns:1fr;
  }

  .sopor-icon{
    text-align:center;
  }

  .sopor-icon img{
    max-width:200px;
    margin-top:30px;
  }

}
/* ===========================
   FIN SOPORTE Y MONITOREO*/

   /* ===========================
   CONSULTORÍA TECNOLÓGICA
=========================== */

.consul-section{
  background:#e6e6e6;
  padding:80px 0;
}

.consul-container{
  max-width:1200px;
  margin:0 auto;
  padding:0 6%;
}

.consul-grid{
  display:grid;
  grid-template-columns:300px 1fr;
  gap:60px;
  align-items:center;
}

.consul-icon img{
  width:100%;
  max-width:260px;
  opacity:0.85;
}

.consul-title{
  font-family:'Telegraf', sans-serif;
  font-size:26px;
  font-weight:700;
  color:var(--azul-d2d);
  margin-bottom:15px;
  text-align: left;
}

.consul-text{
  font-size:18px;
  line-height:1.7;
  margin-bottom:15px;
  text-align:justify;
}

.consul-list{
  margin-left:20px;
  padding-left: 40px;
}

.consul-list li{
  font-size:18px;
  line-height:1.7;
  margin-bottom:10px;
  text-align: left;
}

/* ===========================
   RESPONSIVE
=========================== */
@media(max-width:900px){

  .consul-grid{
    grid-template-columns:1fr;
  }

  .consul-icon{
    text-align:center;
  }

  .consul-icon img{
    max-width:200px;
    margin-bottom:30px;
  }

}
/* ===========================
   FIN CONSULTORÍA TECNOLÓGICA */


/*----------------------------------------SOCIOS--------------------------------------*/ 

/* ===========================
   SOCIOS TECNOLÓGICOS
=========================== */

.socio-section{
  background:#e6e6e6;
  padding:80px 0;
}

.socio-container{
  max-width:1200px;
  margin:0 auto;
  padding:0 6%;
}

.socio-title{
  font-family:'Telegraf', sans-serif;
  font-size:38px;
  font-weight:700;
  color:var(--azul-d2d);
  margin-bottom:20px;
  text-align: left;
}

.socio-intro{
  font-size:18px;
  line-height:1.7;
  text-align:justify;
  margin-bottom:40px;
}

.socio-subtitle{
  font-family:'Telegraf', sans-serif;
  font-size:30px;
  font-weight:700;
  color:var(--azul-d2d);
  margin-bottom:30px;
  text-align: left;
}

/* GRID MARCA */
.socio-grid{
  display:grid;
  grid-template-columns:300px 1fr;
  gap:50px;
  align-items:center;
}

.socio-logo img{
  max-width:260px;
  width:100%;
}

.socio-content p{
  font-size:18px;
  line-height:1.7;
  text-align:justify;
}

.socio-highlight{
  margin-top:15px;
  font-weight:700;
}

/* ===========================
   RESPONSIVE
=========================== */
@media(max-width:900px){

  .socio-grid{
    grid-template-columns:1fr;
    text-align:left;
  }

  .socio-logo{
    text-align:center;
    margin-bottom:25px;
  }

  .socio-logo img{
    max-width:200px;
  }

}


/* ===========================
   SOCIOS TECNOLÓGICOS – LISTA
=========================== */

.socio2-section{
  background:#ffffff;
  padding:80px 0;
}

.socio2-container{
  max-width:1200px;
  margin:0 auto;
  padding:0 6%;
}

.socio2-item{
  display:grid;
  grid-template-columns:220px 1fr;
  gap:40px;
  align-items:center;
  padding:35px 0;
  border-bottom:1px solid #ddd;
}

.socio2-item:last-child{
  border-bottom:none;
}

.socio2-logo img{
  width:100%;
  max-width:200px;
}

.socio2-text p{
  font-size:18px;
  line-height:1.7;
  text-align:justify;
}

/* ===========================
   RESPONSIVE
=========================== */
@media(max-width:900px){

  .socio2-item{
    grid-template-columns:1fr;
  }

  .socio2-logo{
    text-align:center;
    margin-bottom:20px;
  }

  .socio2-logo img{
    max-width:170px;
  }

}
/* ===========================
   FIN SOCIOS TECNOLÓGICOS – LISTA*/

   /*----------------------------------------FIN SOCIOS--------------------------------------*/

   /*----------------------------------------aws--------------------------------------*/
   /* ===========================
   AWS – HERO
=========================== */

.aws-section{
  background:#e6e6e6;
  padding:90px 0;
}

.aws-container{
  max-width:1200px;
  margin:0 auto;
  padding:0 6%;
}

.aws-grid{
  display:grid;
  grid-template-columns:1fr 260px;
  gap:60px;
  align-items:center;
}

.aws-title{
  font-family:'Telegraf', sans-serif;
  font-size:36px;
  font-weight:700;
  line-height:1.3;
  margin-bottom:20px;
  text-align: justify;
}

.aws-text{
  font-size:18px;
  line-height:1.7;
  text-align:justify;
}

.aws-logo img{
  width:100%;
  max-width:220px;
}

/* RESPONSIVE */
@media(max-width:900px){
  .aws-grid{
    grid-template-columns:1fr;
  }

  .aws-logo{
    text-align:center;
    margin-top:30px;
  }
}

/* ===========================
   AWS – SERVICIOS
=========================== */

.aws1-section{
  background:var(--azul-cliente);
  padding:80px 0;
}

.aws1-container{
  max-width:1200px;
  margin:0 auto;
  padding:0 6%;
}

.aws1-title{
  font-family:'Telegraf', sans-serif;
  font-size:34px;
  font-weight:700;
  margin-bottom:40px;
  text-align: left;
}

.aws1-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
}

.aws1-col h4{
  font-size:20px;
  font-weight:700;
  margin-bottom:10px;
  text-align: left;
}

.aws1-col ul{
  margin-bottom:30px;
  margin-left:20px;
  padding-left: 40px;
}

.aws1-col li{
  font-size:17px;
  line-height:1.6;
  margin-bottom:8px;
  text-align: left;
}

/* RESPONSIVE */
@media(max-width:900px){
  .aws1-grid{
    grid-template-columns:1fr;
  }
}

/* ===========================
   FIN AWS – SERVICIOS*/

   /* ===========================
   AWS – BENEFICIOS
=========================== */

.aws2{
  background:#fff;
  padding:80px 0;
  text-align:center;
}

.aws2-container{
  max-width:1200px;
  margin:0 auto;
  padding:0 6%;
}

.aws2-title{
  font-family:'Telegraf', sans-serif;
  font-size:30px;
  font-weight:700;
  margin-bottom:30px;
  text-align: left;
}

.aws2-list{
  list-style:disc;
  text-align:left;
  margin:0 auto 30px;  
  padding-left: 40px;
}

.aws2-list li{
  font-size:17px;
  margin-bottom:10px;
  line-height:1.6;
}

.aws2-cta-text{
  font-weight:600;
  margin-bottom:20px;
}

.aws2-btn{
  display:inline-block;
  background:var(--azul-d2d);
  color:#fff;
  padding:14px 30px;
  border-radius:30px;
  font-weight:700;
  text-decoration:none;
  transition:background .3s ease;
}

.aws2-btn:hover{
  background:var(--azul-hover);
}
/* ===========================
   FIN AWS – BENEFICIOS*/

   /* ===========================
   AWS – CASO DE ÉXITO
=========================== */

.aws3{
  background:#e6e6e6;
  padding:80px 0;
}

.aws3-container{
  max-width:1000px;
  margin:0 auto;
  padding:0 6%;
}

.aws3-title{
  font-family:'Telegraf', sans-serif;
  font-size:28px;
  font-weight:700;
  margin-bottom:20px;
  text-align: left;
}

.aws3-meta{
  margin-bottom:20px;
  text-align: left;
}

.aws3-meta p{
  margin-bottom:6px;
  font-size:16px;
}

.aws3-text{
  font-size:17px;
  line-height:1.7;
  text-align:justify;
}

/* ===========================
   FIN AWS – CASO DE ÉXITO*/

   /*----------------------------------------FIN aws--------------------------------------*/

   /*----------------------------------------politica--------------------------------------*/

.politic{
  background:var(--azul-cliente);
  padding:80px 0;
  text-align:center;
}

.politic-container{
  max-width:1200px;
  margin:0 auto;
  padding:0 6%;
}

.politic-title{
  font-family:'Telegraf', sans-serif;
  font-size:30px;
  font-weight:700;
  color:var(--azul-d2d);
  margin-bottom:25px;
  text-align: left;
}

.politic-desc{
  font-size:17px;
  line-height:1.6;
  margin-bottom:18px;
  text-align: left;
}

.politic-image{
  margin-top:30px;
}

.politic-image img{
  max-width:750px;
  width:100%;
  height:auto;
}

/*----------------------------------------FIN politica--------------------------------------*/

   /* ===========================
   POLÍTICA DE CUMPLIMIENTO ETICO*/
.politic1{
  background:#e6e6e6;
  padding:80px 0;
}

.politic1-container{
  max-width:1200px;
  margin:0 auto;
  padding:0 6%;
}

.politic1-title{
  font-family:'Telegraf', sans-serif;
  font-size:30px;
  font-weight:700;
  color:var(--azul-d2d);
  margin-bottom:30px;
  text-align: left;
}

.politic1 p{
  font-size:16.5px;
  line-height:1.7;
  margin-bottom:18px;
  text-align:justify;
  color:#000;
}

.politic1 strong{
  font-weight:700;
}

/* ===========================
   FIN POLÍTICA DE CUMPLIMIENTO ETICO*/

/* ===========================
   MEDIDAS ANTICORRUPCION===================*/

   .politic2{
  background:#ffffff;
  padding:80px 0;
}

.politic2-container{
  max-width:1200px;
  margin:0 auto;
  padding:0 6%;
}

.politic2-title{
  font-family:'Telegraf', sans-serif;
  font-size:22px;
  font-weight:700;
  color:#000;
  margin-bottom:22px;
  text-transform:uppercase;
  text-align: left;
}

.politic2 p{
  font-size:16.5px;
  line-height:1.7;
  margin-bottom:18px;
  text-align:justify;
  color:#000;
}
/* ===========================
   FIN MEDIDAS ANTICORRUPCION*/

   /* ===========================
   Etica de Negocio===================*/
.politic3{
  background:var(--azul-cliente); /* celeste corporativo */
  padding:80px 0;
}

.politic3-container{
  max-width:1200px;
  margin:0 auto;
  padding:0 6%;
}

.politic3-title{
  font-family:'Telegraf', sans-serif;
  font-size:22px;
  font-weight:700;
  color:#000;
  margin-bottom:22px;
  text-transform:uppercase;
  text-align: left;
}

.politic3 p{
  font-size:16.5px;
  line-height:1.7;
  margin-bottom:18px;
  text-align:justify;
  color:#000;
}
/* ===========================
   FIN POLÍTICA DE ÉTICA DE NEGOCIOS*/

/* ===========================
  PAGO DE COMISIONES===================*/

  .politic4{
  background:#f2f2f2; /* gris claro corporativo */
  padding:80px 0;
}

.politic4-container{
  max-width:1200px;
  margin:0 auto;
  padding:0 6%;
}

.politic4-title{
  font-family:'Telegraf', sans-serif;
  font-size:20px;
  font-weight:700;
  color:#000;
  margin-bottom:18px;
  text-transform:uppercase;
  text-align: left;
}

.politic4-subtitle{
  font-family:'Telegraf', sans-serif;
  font-size:18px;
  font-weight:700;
  color:#000;
  margin:35px 0 18px;
  text-transform:uppercase;
  text-align: left;
}

.politic4 p{
  font-size:16.5px;
  line-height:1.7;
  margin-bottom:16px;
  text-align:justify;
  color:#000;
}
/* ===========================
   FIN POLÍTICA DE RESPONSABILIDAD SOCIAL*/

/*---------------------------------------Cumplimiento etico----------------------------------------*/

.politic5{
  background:#ffffff;
  padding:80px 0;
}

.politic5-container{
  max-width:1200px;
  margin:0 auto;
  padding:0 6%;
}

.politic5-title{
  font-family:'Telegraf', sans-serif;
  font-size:26px;
  font-weight:700;
  color:var(--azul-d2d);
  margin-bottom:25px;
  text-align: left;
}

.politic5-text{
  font-size:16.5px;
  line-height:1.7;
  color:#000;
  margin-bottom:18px;
  text-align:justify;
}

.politic5-download{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-top:10px;
  padding:14px 22px;
  background:var(--azul-d2d);
  color:#fff;
  font-weight:600;
  border-radius:8px;
  text-decoration:none;
  transition:background .25s ease, transform .2s ease;
}

.politic5-download:hover{
  background:var(--azul-hover);
  transform:translateY(-2px);
}
/*---------------------------------------Fin Cumplimiento etico----------------------------------------*/

/*---------------------------------------Contactanos--------------------------------------*/

.contacto{
  position:relative;
  background:var(--azul-fondo);
  padding:90px 0;
  overflow:hidden;
}

.contacto-container{
  max-width:900px;
  margin:0 auto;
  padding:0 6%;
  text-align:center;
}

.contacto-title{
  font-family:'Telegraf', sans-serif;
  font-size:28px;
  font-weight:700;
  color:#2f9bd1;
  margin-bottom:10px;
}

.contacto-subtitle{
  font-size:16.5px;
  margin-bottom:35px;
}

.contacto-form{
  position:relative;
  z-index:2;
}

/* GRID FORM */
.contacto-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
}

.campo{
  display:flex;
  flex-direction:column;
  text-align:left;
}

.campo label{
  font-size:14px;
  margin-bottom:6px;
}

.campo input,
.campo textarea{
  padding:10px 12px;
  border-radius:6px;
  border:1px solid #ccc;
  font-size:14px;
}

.campo-full{
  grid-column:1 / -1;
}

/* CHECK */
.contacto-check{
  margin:25px 0;
  text-align:left;
  font-size:14px;
}

/* BOTÓN */
.contacto-btn{
  background:#0077b6;
  color:#fff;
  border:none;
  padding:12px 40px;
  border-radius:25px;
  font-weight:600;
  cursor:pointer;
  transition:background .25s ease, transform .2s ease;
}

.contacto-btn:hover{
  background:#005f8f;
  transform:translateY(-2px);
}

/* IMAGEN ESQUINA */
.contacto-bg{
  position:absolute;
  bottom:-10px;
  right:-10px;
  width:460px;
  height:460px;
  background:url('../img/nosotros.png') no-repeat bottom right;
  background-size:contain;
  opacity:.6;
  pointer-events:none;
}

/* RESPONSIVE */
@media(max-width:768px){
  .contacto-grid{
    grid-template-columns:1fr;
  }

  .contacto-bg{
    width:180px;
    height:180px;
    opacity:.4;
  }
}
/*---------------------------------------Fin Contactanos--------------------------------------*/

/*---------------------------------------footer de contactanos--------------------------------------*/

.contact1{
  background:#f2f2f2;
  padding:90px 0;
}

.contact1-container{
  max-width:1200px;
  margin:0 auto;
  padding:0 6%;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  align-items:center;
}

/* TEXTO */
.contact1-info{
  display:flex;
  flex-direction:column;
  gap:30px;
}

.contact1-block h3{
  font-family:'Telegraf', sans-serif;
  font-size:20px;
  font-weight:700;
  color:var(--azul-d2d);
  margin-bottom:10px;
}

.contact1-block p{
  font-size:16px;
  line-height:1.6;
  margin-bottom:4px;
  color:#000;
}

/* IMAGEN */
.contact1-image img{
  width:100%;
  height:auto;
  border-radius:4px;
  object-fit:cover;
  box-shadow:0 8px 25px rgba(0,0,0,.12);
}

/* RESPONSIVE */
@media(max-width:900px){
  .contact1-container{
    grid-template-columns:1fr;
  }

  .contact1-image{
    order:-1;
  }
}
/*---------------------------------------Fin footer de contactanos--------------------------------------*/
/*---------------------------------------Descarga de recursos--------------------------------------*/
.contact3{
  background:#ffffff;
  padding:60px 0;
}

.contact3-container{
  max-width:1200px;
  margin:0 auto;
  padding:0 6%;
}

.contact3-title{
  font-family:'Telegraf', sans-serif;
  font-size:22px;
  font-weight:700;
  color:var(--azul-d2d);
  margin-bottom:15px;
  text-align: left;
}

.contact3-text{
  font-size:15.5px;
  line-height:1.65;
  color:#000;
  margin-bottom:14px;
  text-align:justify;
}

.contact3-download{
  display:inline-block;
  margin-top:10px;
  font-size:15px;
  font-weight:600;
  color:var(--azul-d2d);
  text-decoration:none;
  transition:color .25s ease, transform .2s ease;
}

.contact3-download:hover{
  color:var(--azul-hover);
  transform:translateX(4px);
}
/*---------------------------------------Fin Descarga de recursos--------------------------------------*/