:root{
  --blue:#002d74;
  --blue2:#001f52;
  --green:#93d500;
  --bg:#06102a;
  --text:#0b1325;
  --muted:#5a647a;
  --card:#ffffff;
  --line:rgba(255,255,255,.14);
  --shadow:0 18px 50px rgba(0,0,0,.18);
  --radius:18px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--text);overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

.container{width:min(1160px,92vw);margin:0 auto}

.header{
  position:sticky;top:0;z-index:60;
  background:rgba(0,45,116,.92);
  backdrop-filter: blur(10px);
  border-bottom:1px solid rgba(255,255,255,.10);
}
.header.container{width:100%}
.header__inner{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:18px 0}
.brand__logo{height:44px;width:auto}

.nav{display:flex;align-items:center;gap:16px}
.nav a{color:rgba(255,255,255,.92);font-weight:800;font-size:13px;letter-spacing:.2px}
.nav a:hover{color:var(--green)}
.nav__toggle{display:none;background:transparent;border:0;cursor:pointer;padding:10px;border-radius:12px}
.nav__toggle span{display:block;width:22px;height:2px;background:#fff;margin:5px 0;border-radius:2px}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  background:linear-gradient(90deg,var(--green), #b6ff2a);
  color:#0b1325;border:0;padding:12px 16px;border-radius:14px;
  font-weight:900;font-size:14px;cursor:pointer;box-shadow:0 14px 26px rgba(147,213,0,.22)
}
.btn:hover{transform:translateY(-1px)}
.btn--ghost{background:transparent;color:#fff;box-shadow:none;border:1px solid rgba(255,255,255,.35)}
.btn--ghost:hover{background:rgba(255,255,255,.08)}
.btn--sm{padding:10px 12px;border-radius:12px;font-size:13px}

.hero{
  position:relative;
  color:#fff;
  background: radial-gradient(1200px 600px at 25% 0%, rgba(147,213,0,.18), transparent 60%),
              radial-gradient(900px 500px at 85% 0%, rgba(255,255,255,.10), transparent 55%),
              linear-gradient(180deg, var(--bg), #050914);
  overflow:hidden;
  min-height: 86vh;   /* prueba 74–86vh según te guste */
  padding: 80px 0 56px; /* un poco más de aire arriba/abajo */
}
.hero__bg{
  position:absolute;inset:0;
  background-image:linear-gradient(180deg, rgba(3,6,15,.35), rgba(3,6,15,.88)), url("assets/hero.jpg");
  background-size:cover;background-position: 50% 50%;
  opacity:.62;
  transform:scale(1.00);
}
.hero__inner{position:relative;display:grid;grid-template-columns: 1.25fr .85fr;gap:22px;align-items:start}

.pill{
  display:inline-flex;align-items:center;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.16);
  padding:8px 12px;border-radius:999px;
  font-weight:900;font-size:12px;letter-spacing:.3px
}
.hero h1{margin:14px 0 10px;font-size:44px;line-height:1.03;letter-spacing:-1px}
.lead{margin:0;color:rgba(255,255,255,.86);font-size:16px;line-height:1.65;max-width:66ch}
.hero__cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}

.hero__badges{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:22px}
.badge{
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.14);
  border-radius:var(--radius);
  padding:14px;
}
.badge__k{font-weight:900;font-size:12px;color:rgba(255,255,255,.80);text-transform:uppercase;letter-spacing:.4px}
.badge__v{margin-top:6px;font-weight:800}

.hero__panel{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  border-radius:var(--radius);
  padding:18px;
  box-shadow: var(--shadow);
}
.hero__panel h3{margin:0 0 12px;font-size:16px}
.checklist{margin:0;padding-left:18px;color:rgba(255,255,255,.88);line-height:1.55}
.hero__quick{display:grid;gap:10px;margin-top:14px}
.quick{
  display:flex;align-items:center;justify-content:center;
  padding:12px 14px;border-radius:14px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.14);
  font-weight:900;
}
.quick:hover{background:rgba(255,255,255,.16)}

.section{padding:58px 0;background:#fff}
.section--alt{background:#f4f7ff}
.section__head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.section__head h2{margin:0;font-size:28px;letter-spacing:-.4px}
.muted{color:var(--muted)}
.small{font-size:12px}

.grid{display:grid;gap:16px}
.grid--4{grid-template-columns:repeat(4,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--2{grid-template-columns:repeat(2,1fr)}

.card{
  background:var(--card);
  border:1px solid rgba(0,0,0,.06);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:0 10px 24px rgba(0,0,0,.06);
}
.card__img{width:100%;height:170px;object-fit:cover}
.card__body{padding:16px}
.card__icon{font-size:26px;padding:16px 16px 0}
.card h3{margin:0 0 8px}
.card p{margin:0 0 10px;color:rgba(11,19,37,.80);line-height:1.6}
.bullets{margin:0;padding-left:18px;color:rgba(11,19,37,.78);line-height:1.6}
.bullets li{margin:4px 0}

.chips{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px}
.chip{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 12px;border-radius:999px;
  background:rgba(0,45,116,.06);
  border:1px solid rgba(0,45,116,.14);
  color:var(--blue);font-weight:900;font-size:12px
}

.galleryMini{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:10px;
}
.galleryMini figure{
  margin:0;background:#fff;border:1px solid rgba(0,0,0,.06);
  border-radius:16px;overflow:hidden;box-shadow:0 10px 20px rgba(0,0,0,.06)
}
.galleryMini img{height:120px;width:100%;object-fit:cover}
.galleryMini figcaption{padding:10px 10px;font-weight:900;font-size:12px;color:rgba(11,19,37,.75)}

.timeline{display:grid;gap:12px}
.step{
  display:grid;grid-template-columns:44px 1fr;gap:12px;
  background:#fff;border:1px solid rgba(0,0,0,.06);
  border-radius:var(--radius);padding:14px;
}
.step__n{
  width:44px;height:44px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(90deg,var(--blue2),var(--blue));
  color:#fff;font-weight:1000;
}
.step__b h3{margin:0 0 4px}
.step__b p{margin:0;color:rgba(11,19,37,.78);line-height:1.55}

.callout{
  margin-top:18px;
  display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;
  background:linear-gradient(90deg, rgba(0,45,116,.10), rgba(147,213,0,.08));
  border:1px solid rgba(0,45,116,.16);
  border-radius:var(--radius);
  padding:16px;
}

.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.chipBtn{
  border:1px solid rgba(0,0,0,.10);
  background:#fff;
  padding:10px 12px;border-radius:999px;
  font-weight:1000;font-size:12px;cursor:pointer;
}
.chipBtn.is-active{border-color:rgba(0,45,116,.35);background:rgba(0,45,116,.06);color:var(--blue)}

.gallery{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:10px;
}
.gallery__item{
  border:0;padding:0;background:transparent;cursor:pointer;
  border-radius:16px;overflow:hidden;
  box-shadow:0 12px 26px rgba(0,0,0,.08);
}
.gallery__item img{width:100%;height:170px;object-fit:cover;display:block;transform:scale(1.02)}
.gallery__item:hover img{transform:scale(1.06)}

.lightbox{
  position:fixed;inset:0;display:none;place-items:center;
  background:rgba(0,0,0,.82);z-index:80;padding:22px;
}
.lightbox.is-open{display:grid}
.lightbox img{max-width:min(1200px,96vw);max-height:86vh;border-radius:18px}
.lightbox__close{
  position:absolute;top:18px;right:18px;
  border:0;border-radius:14px;
  padding:10px 12px;cursor:pointer;
  background:rgba(255,255,255,.14);color:#fff;font-weight:1000
}

.contactBtns{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}

.footer{
  background-color: #002d74; /* Azul corporativo DINAMAC */
  color: #ffffff; padding:24px 0 18px
}
.footer__inner{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.footer__logo{height:30px;width:auto}
.footer__links{display:flex;gap:14px;flex-wrap:wrap;opacity:.92;font-weight:900;font-size:13px}
.footer__links a:hover{color:var(--green)}
.footer__bottom{opacity:.75;font-size:12px;margin-top:14px;border-top:1px solid rgba(255,255,255,.12);padding-top:14px}

/* Responsive (tablet/móvil) */
@media (max-width: 1040px){
  .hero__inner{grid-template-columns:1fr}
  .hero h1{font-size:36px}
  .hero__badges{grid-template-columns:1fr}
  .grid--4{grid-template-columns:1fr}
  .grid--3{grid-template-columns:1fr}
  .grid--2{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .galleryMini{grid-template-columns:repeat(2,1fr)}
  .nav{display:none}
  .nav.is-open{
    display:flex;flex-direction:column;align-items:flex-start;
    position:absolute;right:4vw;top:60px;
    background:rgba(0,45,116,.96);
    border:1px solid rgba(255,255,255,.12);
    border-radius:18px;padding:14px;gap:12px;
    box-shadow:0 18px 40px rgba(0,0,0,.22);
    min-width:220px;
  }
  .nav__toggle{display:block}
}

/* Ajuste HERO solo móvil (teléfonos) */
@media (max-width: 680px){
  .hero{
    min-height:69vh;       
    padding:20px 0 0px;   /* reduce altura vertical */
  }

  .hero__bg{
    transform:none;              
    opacity:.55;                 
    background-repeat:no-repeat; /* evita repetición */
    background-size:160% auto;   
    background-position:50% 40%; 
  }

  .hero h1{
    font-size:30px;
    line-height:1.08;
    letter-spacing:-0.6px;
    margin:10px 0 8px;
  }

  .lead{font-size:14px;line-height:1.55}

  .hero__cta{gap:10px;margin-top:14px}
  .hero__badges{margin-top:14px;gap:10px}

  /* Compacta un poco el panel para que no empuje tanto */
  .hero__panel{padding:14px}
}

/* Cards con contenido directo (sin .card__body) */
.card--padded{padding:18px}
.card--padded h3{margin-top:0}

/* Mapa */
.mapWrap{margin-top:18px}
.mapTitle{margin:0 0 10px}
.map{height:340px;border-radius:var(--radius);border:1px solid rgba(0,0,0,.08);overflow:hidden;box-shadow:0 10px 24px rgba(0,0,0,.06)}
@media (max-width: 720px){.map{height:300px}}
