/* Save everything between these tags in a file named: styles.css */
:root{
  --black:#000000;
  --white:#FFFFFF;
  --blue-100:#0b76a0;
  --blue-200:#096688; /* según especificación */
  --blue-300:#1B1C56; /* principal */
  --gray-300:#DADADA;
  --gray-100:#F4F4F4;
  --blue-light:#60C7EF;

  --radius: 16px;
  --shadow: 0 8px 24px rgba(0,0,0,.08);
}

*{
  box-sizing:border-box
}

html{
  scroll-behavior:smooth
}

body{
  margin:0; 
  font-family: system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial; 
  color:#1a1a1a; 
  background:var(--white);
}

img{
  max-width:100%; 
  display:block
}

.container{
  width:min(1200px,92vw); 
  margin-inline:auto
}

.section{
  padding:64px 0
}

.section-head{
  margin-bottom:24px
}

.section-head h2{
  margin:0 0 6px 0; 
  color:var(--blue-300)
}

.btn{
  display:inline-block; 
  padding:.9rem 1.1rem; 
  border-radius:999px; 
  font-weight:600; 
  text-decoration:none; 
  border:2px solid transparent; 
  transition:.2s ease;
}

.btn-primary{
  background:var(--blue-300); 
  color:var(--white)
}

.btn-primary:hover{
  filter:brightness(1.1)
}

.btn-secondary{
  background:var(--blue-300); 
  color:var(--white)
}

.btn-secondary:hover{
  filter:brightness(1.05)
}

.btn-outline{
  background:transparent; 
  border-color:var(--blue-300); 
  color:var(--blue-300)
}

.btn-outline:hover{
  background:var(--blue-300); 
  color:var(--white)
}

.btn.full{
  display:block; 
  text-align:center
}

.card{
  background:var(--white); 
  border:1px solid var(--gray-300); 
  border-radius:var(--radius); 
  padding:20px; 
  box-shadow:var(--shadow)
}

.pill{
  display:inline-block; 
  padding:.4rem .8rem; 
  border-radius:999px; 
  background:var(--gray-100); 
  margin:6px; 
  border:1px solid var(--gray-300)
}

.bullets{
  padding-left:18px
}

.checklist{
  padding-left:18px
}

/* Header */
.site-header{
  position:sticky; 
  top:0; z-index:50; 
  background:var(--white); 
  border-bottom:1px solid var(--gray-300)
}

.header-row{
  display:flex; 
  align-items:center; 
  justify-content:space-between; 
  gap:16px; 
  padding:12px 0
}

.brand{
  font-weight:800; 
  color:var(--blue-300); 
  text-decoration:none; 
  font-size:1.2rem
}

.brand span{
  color:var(--blue-100)
}

.nav ul{
  list-style:none; 
  padding:0; 
  margin:0; 
  display:flex; 
  gap:18px
}

.nav a{
  color:var(--gray-100); 
  text-decoration:none; 
  padding:8px 10px; 
  border-radius:8px
}

.nav a.active, .nav a:hover{
  color:var(--blue-300); 
  background:var(--gray-100)
}

.nav-toggle{
  display:none; 
  background:none; 
  border:0; 
  cursor:pointer
}

.nav-toggle .bar{
  display:block; 
  width:24px; 
  height:2px; 
  background:#F4F4F4; 
  margin:5px 0
}

@media (max-width: 900px){
  .nav{
    position:fixed; 
    inset: 100px 0 auto 0; 
    background:var(--white); 
    border-bottom:1px solid var(--gray-300); 
    transform:translateY(-130%); 
    transition:.25s;
  }

  .nav a{
    color: var(--blue-300);
  }
  
  .nav.open{
    transform:translateY(0)
  }
  
  .nav ul{
    flex-direction:column; 
    padding:16px
  }
  
  .nav-toggle{
    display:block
  }
}

.logo-idm2{
  height: 80px;
}

/* Hero / Slider */
.hero{
  padding-top:0
}

.hero-slider{
  position:relative; 
  overflow:hidden
}

.slide{
  position:relative; 
  min-height:64vh; 
  display:grid; 
  place-items:center
}

.slide-bg{
  position:absolute; 
  inset:0; 
  background-size:cover; 
  background-position:center; 
  opacity:.9
}

.gradient.bg-1{
  background-image: url("/assets/images/digital.jpg");
  background-position: center;
  background-size: cover;
}

.gradient.bg-2{
  background-image: url("/assets/images/ciberseguridad.jpg");
  background-position: center;
  background-size: cover;
}

.gradient.bg-3{
  background-image: url("/assets/images/centro_de_datos.jpg");
  background-position: center;
  background-size: cover;
}

.slide-content{
  position:relative; 
  text-align:center; 
  color:var(--gray-100); 
  padding:40px 0
}

.slide-content h1{
  font-size:clamp(1.6rem, 4vw, 2.6rem); 
  margin:0 0 10px
}

.slide-content p{
  opacity:.95; 
  margin:0 0 16px
}

.actions{
  display:flex; 
  gap:12px; 
  justify-content:center; 
  flex-wrap:wrap
}

.slider-controls{
  position:absolute; 
  inset:auto 0 10px 0; 
  display:flex; 
  align-items:center; 
  justify-content:center; 
  gap:12px
}

.slider-controls .prev,.slider-controls .next{
  background:rgba(0,0,0,.35); 
  color:#fff; 
  border:0; 
  width:36px; 
  height:36px; 
  border-radius:50%; 
  cursor:pointer
}

.slider-controls .dots{
  display:flex; 
  gap:8px
}

.slider-controls .dots button{
  width:10px; 
  height:10px; 
  border-radius:50%; 
  border:0;
  background:rgba(255,255,255,.6); cursor:pointer
}

.slider-controls .dots button.active{
  background:#fff
}

/* Quick verticals */
.quick-verticals{
  display:grid; 
  grid-template-columns:repeat(5,1fr); 
  gap:14px; 
  margin-top:28px
}

.quick-card{
  background:var(--white); 
  border:1px solid var(--gray-300); 
  padding:14px; border-radius:14px; 
  text-align:center; 
  text-decoration:none; 
  color:#222; 
  box-shadow:var(--shadow)
}

.quick-card:hover{
  transform:translateY(-2px)
}

.icon-circle{
  width:40px; 
  height:40px; 
  border-radius:10%; 
  display:grid; 
  place-items:center; 
  margin:0 auto 8px; 
  transform: scale(1);
}

.first-column{
  color: var(--blue-100);
}

.second-column{
  color: var(--blue-300)
}

.third-column{
  color: var(--blue-light);
}

/* Featured solutions + CTA */
.featured-solutions{
  display:grid; 
  grid-template-columns:repeat(3,1fr); 
  gap:18px; 
  margin:24px auto
}

.feature{
  background:var(--white); 
  border:1px solid var(--gray-300); 
  border-radius:var(--radius); 
  padding:18px; 
  text-align:center; 
  box-shadow:var(--shadow);
}

.about-card{
  text-align: left;
  padding: 40px;
}

.head-about{
  display: flex;
  align-items: center;
  justify-content: start;
}

.about-icon{
  color: var(--blue-300);
  transform: scale(1.5);
  margin: 10px;
}

.feat-icon{
  font-size:28px; 
  margin-bottom:8px
}

.cta{
  background:linear-gradient(90deg, var(--blue-300), var(--blue-100)); 
  color:var(--white); 
  text-align:center; 
  padding:28px; 
  border-radius:var(--radius)
}

/* Nosotros */
.about-grid{
  display:grid; 
  grid-template-columns:repeat(2,1fr); 
  gap:18px;
}

.featured-about{
  display:grid; 
  grid-template-columns:repeat(2,1fr); 
  gap:18px; 
  margin:24px auto;
}

.certs-cases{
  display:grid; 
  grid-template-columns:repeat(2,1fr); 
  gap:18px; 
  margin-top:18px
}

.partners{
  margin-top:18px
}

.logo-grid{
  display:grid; 
  grid-template-columns:repeat(4,1fr); 
  gap:14px
}

.logo-card{
  display:grid; 
  place-items:center; 
  padding:20px; 
  border:1px dashed var(--blue-300); 
  color:var(--blue-300); 
  border-radius:12px; 
  font-weight:700
}

.logo-image{
  height: 40px;
}

.featured-choose{
  display:grid; 
  grid-template-columns:repeat(3,1fr); 
  gap:18px; 
  margin:24px auto
}

/* Verticales */
.vertical-list{
  display:grid; 
  gap:16px;
  grid-template-columns: repeat(2, 1fr);
}

.vertical-card{ 
  gap:16px; border:1px solid var(--gray-300); 
  border-radius:var(--radius); 
  overflow:hidden; 
  background:var(--white); 
  box-shadow:var(--shadow)
}

.v-media{
  height: 200px;
}

.v-media img{
  width: 100%;
  height: 230px;
}

.v-body{
  padding:18px
}

.problem{
  margin:.25rem 0 .6rem
}

.solutions{
  padding-left:18px; 
  margin:0 0 .8rem
}

/* Soluciones tecnológicas */
.solutions-grid{
  display:grid; 
  grid-template-columns:repeat(4,1fr); 
  gap:16px
}

.solution-card{
  background:var(--white); 
  border:1px solid var(--gray-300); 
  border-radius:var(--radius); 
  padding:18px; 
  text-align:center; 
  box-shadow:var(--shadow)
}

.sol-icon{
  font-size:28px; 
  margin-bottom:6px
}

.list-solutions{
  text-align: left;
}

.list-solutions li::marker{
  color: var(--blue-300);
}

.card-icon{
  color: white;
  background: linear-gradient(var(--blue-300), var(--blue-100));
  border-radius: 6px;
  transform: scale(2);
  padding: 2px;
  margin-top: 10px;
}

/* Marcas */
.brand-grid{
  display:grid; 
  grid-template-columns:repeat(4,1fr); 
  gap:16px}

.brand-card{
  background:var(--white); 
  border:1px solid var(--gray-300); 
  border-radius:var(--radius); 
  padding:18px; 
  box-shadow:var(--shadow);
}

.brand-logo{
  display:inline-block; 
  font-weight:800; 
  color:var(--blue-300); 
  margin-bottom:6px;
  display: flex;
  justify-content: center;
  width: 100%;
}

.marcas-aliadas{
  height: 50px;
}

/* Casos de éxito */
.success-slider{
  position:relative; 
  overflow:hidden
}

.success-track{
  display:flex; 
  gap:16px; 
  transition:transform .4s ease
}

.success-card{
  min-width:calc(100% - 2px); 
  background:var(--white); 
  border:1px solid var(--gray-300); 
  border-radius:var(--radius);
  padding:18px; 
  box-shadow:var(--shadow)
}

.metrics{
  padding-left:18px
}

.succ-controls{
  position:absolute; 
  inset:0; display:flex; 
  justify-content:space-between; 
  align-items:center; 
  pointer-events:none
}

.succ-controls button{
  pointer-events:auto; 
  background:var(--blue-300); 
  color:var(--white); 
  border:0; 
  width:36px; 
  height:36px; 
  border-radius:50%; 
  opacity:.9
}

/* Recursos */
.resources {
  background: linear-gradient(180deg, var(--gray-100), #fff);
} 

.resources .section-head{
  display:flex; 
  flex-wrap:wrap; 
  align-items:center; 
  justify-content:space-between; 
  gap:12px
}

.resources .filters{
  display:flex; 
  gap:8px; 
  background:var(--white); 
  border:1px solid var(--gray-300); 
  padding:6px; 
  border-radius:999px
}

.filter-btn{
  border:0;
  padding:8px 14px; 
  border-radius:999px; 
  background:transparent; 
  cursor:pointer; 
  font-weight:600; 
  color:#333
}

.filter-btn.active{
  background:var(--blue-300); 
  color:var(--white)
}

.resource-grid{
  display:grid; 
  grid-template-columns:repeat(3,1fr); 
  gap:16px
}

.resource-card{
  position:relative; 
  display:flex; 
  flex-direction:column; 
  gap:8px; 
  background:var(--white); 
  border:1px solid var(--gray-300); 
  border-radius:var(--radius); 
  padding:18px; 
  box-shadow:var(--shadow); 
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease
}

.resource-card:hover{
  transform:translateY(-3px); 
  border-color:var(--blue-light)
}

.rc-icon{
  width:44px; 
  height:44px; 
  border-radius:12px; 
  display:grid; 
  place-items:center; 
  background:var(--gray-100); 
  font-size:20px
}

.rc-meta{
  display:flex; 
  align-items:center; 
  justify-content:space-between; 
  gap:10px; 
  font-size:.92rem; 
  color:#555
}

.rc-badge{
  display:inline-block; 
  padding:.2rem .55rem;
  border-radius:999px; 
  font-size:.78rem; 
  font-weight:700
}

.rc-blog{
  background:rgba(11,118,160,.12); 
  color:var(--blue-100)
}

.rc-webinar{
  background:rgba(9,102,135,.12); 
  color:var(--blue-200)
}

.rc-doc{
  background:rgba(27,28,86,.12); 
  color:var(--blue-300)
}

.rc-link{
  margin-top:auto; 
  text-decoration:none; 
  font-weight:700; 
  color:var(--blue-300)
}

@media (max-width:1100px){
  .resource-grid{
    grid-template-columns:repeat(2,1fr)
  }
}

@media (max-width:700px){
  .resource-grid{
    grid-template-columns:1fr
  }
  
  .resources .filters{
    width:100%; 
    justify-content:center
  }
}

/* Contacto */
.contact-grid{
  display:grid; 
  grid-template-columns: 1.1fr .9fr; 
  gap:18px}

.field{
  display:flex; 
  flex-direction:column; 
  gap:6px; 
  margin-bottom:12px
}

input, textarea{
  padding:12px 14px;
  border-radius:12px; 
  border:1px solid var(--gray-300); 
  font:inherit
}

input:focus, textarea:focus{
  outline:3px solid rgba(27,28,86,.15); 
  border-color:var(--blue-300)
}

.form-note{
  font-size:.95rem; 
  margin-top:8px
}

.info h3{
  margin-top:0
}

/* Footer */
.site-footer{
  background:var(--blue-300); 
  color:var(--white); 
  padding-top:28px
}

.footer-grid{
  display:grid; 
  grid-template-columns:2fr 1fr 1fr; 
  gap:20px; 
  align-items:flex-start
}

.footer-brand{
  color:var(--white); 
  text-decoration:none
}

.site-footer nav h4{
  margin:.2rem 0
}

.site-footer nav a{
  color:var(--white)
}

.site-footer nav ul{
  list-style:none; 
  padding:0; 
  margin:.4rem 0 0;
  display:grid; 
  gap:6px
}

.copy{
  margin-top:14px; 
  padding:12px 0; 
  text-align:center; 
  background:rgba(0,0,0,.15)
}

.socials{
  display:flex; 
  gap:10px; 
  margin-top:8px
}

.soc{
  display:grid; 
  place-items:center; 
  width:28px; 
  height:28px; 
  border-radius:50%; 
  border:1px solid rgba(255,255,255,.7); 
  color:#fff; 
  text-decoration:none
}

/* Back to top */
.back-to-top{
  position:fixed; 
  right:14px; 
  bottom:14px; 
  width:40px; 
  height:40px; 
  border-radius:50%; 
  border:0; 
  background:var(--blue-300); 
  color:#fff; 
  display:none; 
  place-items:center; 
  box-shadow:var(--shadow)
}

.back-to-top.show{
  display:grid
}

/* Responsive */
@media (max-width: 1100px){
  .featured-solutions{
    grid-template-columns:1fr
  }
  
  .solutions-grid{
    grid-template-columns:repeat(2,1fr)
  }
  
  .brand-grid{
    grid-template-columns:repeat(2,1fr)
  }
}

@media (max-width: 900px){
  .about-grid{
    grid-template-columns:1fr
  }
  
  .certs-cases{
    grid-template-columns:1fr
  }
  
  .logo-grid{
    grid-template-columns:repeat(2,1fr)
  }
  
  .vertical-card{
    grid-template-columns:1fr
  }
  
  .resources-grid{
    grid-template-columns:1fr
  }
  
  .contact-grid{
    grid-template-columns:1fr
  }
  
  .footer-grid{
    grid-template-columns:1fr
  }
  
  .quick-verticals{
    grid-template-columns:repeat(3,1fr)
  }
}

@media (max-width: 600px){
  .quick-verticals{
    grid-template-columns:repeat(2,1fr)
  }

  .vertical-list{
    grid-template-columns: repeat(1, 1fr);
  }
}

