
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Arial,Helvetica,sans-serif;background:#061528;color:#fff}a{color:inherit}img{max-width:100%}
.topbar{height:78px;background:#061528;display:flex;align-items:center;gap:22px;padding:0 3%;position:sticky;top:0;z-index:50;border-bottom:1px solid rgba(255,255,255,.18)}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;min-width:260px}.brand img{width:70px;filter:drop-shadow(0 0 8px #fff)}.brand span{font-size:27px;font-weight:900;line-height:.9}.brand small{display:block;font-size:12px;letter-spacing:.8px;font-weight:700;text-transform:uppercase}
nav{display:flex;gap:20px;align-items:center;flex:1;justify-content:center}nav a{text-decoration:none;text-transform:uppercase;font-weight:900;font-size:14px;border-bottom:3px solid transparent;padding:28px 0}.active,nav a:hover{border-bottom-color:#ff9f1c;color:#ff9f1c}
.portal-btn{text-decoration:none;text-transform:uppercase;border:1px solid #1d9bf0;border-radius:5px;padding:10px 18px;font-weight:900;text-align:center;font-size:13px}.portal-btn span{display:block;font-size:11px;color:#fff}.social-top{display:flex;gap:14px}.social-top a{width:30px;height:30px;border-radius:50%;background:#0a6edb;text-align:center;line-height:30px;text-decoration:none;font-weight:900}
.hero-premium{min-height:360px;background:linear-gradient(90deg,rgba(4,17,34,.96),rgba(4,17,34,.72),rgba(4,17,34,.18)),url('assets/mockup-premium.png') center/cover;display:grid;grid-template-columns:1fr 1fr;align-items:center;padding:42px 6%;border-bottom:4px solid #fff}
.hero-copy h1{font-size:clamp(34px,5vw,62px);line-height:1.05;margin:0;text-transform:uppercase;font-weight:900}.hero-copy h1 span{color:#ff9f1c}.hero-copy p{font-size:20px;font-weight:700}.hero-icons{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:26px}.hero-icons div{display:flex;flex-direction:column;gap:5px}.hero-icons i{width:42px;height:42px;border:2px solid #fff;border-radius:50%;display:grid;place-items:center;font-style:normal}.hero-icons b{text-transform:uppercase}.hero-icons small{color:#d8e8ff}.hero-logo-block{text-align:center}.hero-logo-block img{max-width:420px;filter:drop-shadow(0 0 7px #fff) drop-shadow(0 0 22px rgba(255,255,255,.6))}
.division-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:8px 2%;background:#fff}.division{min-height:290px;text-decoration:none;display:flex;align-items:center;padding:34px 4%;background-size:cover;background-position:center;position:relative;overflow:hidden}.division:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(3,12,27,.95),rgba(3,12,27,.35))}.energia-card{background-image:url('assets/energia.png')}.tech-card{background-image:url('assets/tecnologia.png')}.division-text{position:relative;max-width:520px}.division h2{font-size:34px;text-transform:uppercase;margin:0}.division h2 span{display:block;color:#ff9f1c;font-size:46px}.division h2 .blue{color:#1d9bf0;font-size:31px}.division h3{text-transform:uppercase;font-size:19px}.division li{margin:8px 0}.division li::marker{color:#ff9f1c}button,.cta{background:#ff9f1c;color:#fff;border:0;border-radius:6px;padding:13px 26px;text-transform:uppercase;font-weight:900;text-decoration:none;display:inline-block}.blue-btn,.blue-cta{background:#0a8fe8}
.stats-strip{display:grid;grid-template-columns:repeat(5,1fr);background:#081b33;border-top:2px solid #fff;border-bottom:2px solid #fff;padding:18px 2%;gap:8px}.stats-strip div{display:flex;flex-direction:column;border-right:1px solid rgba(255,255,255,.45);padding:0 20px}.stats-strip div:last-child{border-right:0}.stats-strip b{font-size:24px;text-transform:uppercase}.stats-strip span{color:#dbeafe}
.testimonials{background:#061528;padding:18px 4% 26px}.testimonials h2{text-align:center;text-transform:uppercase;margin:0 0 12px}.testimonials h2 span{color:#ff9f1c}.testimonial-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}.testimonial-grid article,.cards-dark>div,form,.contact-card{background:linear-gradient(180deg,#0b223d,#07172b);border:1px solid rgba(255,255,255,.15);border-radius:10px;padding:18px;box-shadow:0 12px 30px rgba(0,0,0,.25)}.stars{color:#ffb21c;font-size:22px}.testimonial-grid small{display:block;color:#dbeafe}
.footer{display:grid;grid-template-columns:repeat(5,1fr);gap:15px;background:#f8fafc;color:#071a38;padding:18px 4%;align-items:center}.foot-item{display:flex;gap:12px;align-items:center}.foot-item b{display:block}.foot-item small{display:block}.ico{font-size:34px}.copyright{font-size:13px}
.subhero{min-height:390px;display:flex;align-items:center;background-size:cover;background-position:center;padding:70px 6%;border-bottom:4px solid #fff}.subhero>div{max-width:760px;background:rgba(3,12,27,.56);padding:30px;border-left:5px solid #ff9f1c}.subhero h1{font-size:clamp(42px,6vw,76px);margin:0;text-transform:uppercase}.subhero h1 span{color:#ff9f1c}.subhero .blue{color:#1d9bf0}.subhero p{font-size:22px}.gas-bg{background-image:linear-gradient(90deg,rgba(3,12,27,.96),rgba(3,12,27,.3)),url('assets/energia.png')}.tech-bg{background-image:linear-gradient(90deg,rgba(3,12,27,.96),rgba(3,12,27,.3)),url('assets/tecnologia.png')}.nosotros-bg{background-image:linear-gradient(90deg,rgba(3,12,27,.86),rgba(3,12,27,.3)),url('assets/nosotros-banner.png')}.portafolio-bg{background-image:linear-gradient(90deg,rgba(3,12,27,.86),rgba(3,12,27,.3)),url('assets/portafolio-banner.png')}.casos-bg{background-image:linear-gradient(90deg,rgba(3,12,27,.86),rgba(3,12,27,.3)),url('assets/casos-banner.png')}.blog-bg{background-image:linear-gradient(90deg,rgba(3,12,27,.86),rgba(3,12,27,.3)),url('assets/blog-banner.png')}.faq-bg{background-image:linear-gradient(90deg,rgba(3,12,27,.86),rgba(3,12,27,.3)),url('assets/faq-banner.png')}.contacto-bg{background-image:linear-gradient(90deg,rgba(3,12,27,.86),rgba(3,12,27,.3)),url('assets/contacto-banner.png')}
.premium-content{padding:60px 6%;max-width:1240px;margin:auto}.premium-content h2{font-size:40px;text-transform:uppercase}.cards-dark{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:22px}.cards-dark h3{color:#ff9f1c}.blog-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.blog-list article{background:#0b223d;border:1px solid rgba(255,255,255,.15);border-radius:10px;padding:20px}.faq details{background:#0b223d;margin:13px 0;padding:18px;border-radius:10px;border:1px solid rgba(255,255,255,.15)}.faq summary{font-weight:900;cursor:pointer}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}input,select,textarea{width:100%;margin:8px 0;padding:14px;border-radius:6px;border:0}.map{margin-top:26px;background:#0b223d;padding:12px;border-radius:18px}
.portal-hero-v3{min-height:75vh;background:radial-gradient(circle at 80% 20%,rgba(29,155,240,.35),transparent 35%),linear-gradient(135deg,#061528,#0b223d 60%,#061528);display:grid;place-items:center;text-align:center;padding:50px}.portal-hero-v3 img{max-width:560px;filter:drop-shadow(0 0 7px #fff) drop-shadow(0 0 22px rgba(255,255,255,.7))}.portal-hero-v3 h1{font-size:70px;text-transform:uppercase;margin:10px;color:#ff9f1c}
.wa-float{position:fixed;right:28px;bottom:28px;width:64px;height:64px;background:#25D366;border-radius:50%;display:grid;place-items:center;z-index:90;box-shadow:0 14px 35px rgba(0,0,0,.4)}.wa-float img{width:44px}
@media(max-width:1050px){.topbar{height:auto;flex-wrap:wrap;padding:12px 4%}nav{order:3;width:100%;justify-content:flex-start}.hero-premium,.division-grid,.testimonial-grid,.contact-grid{grid-template-columns:1fr}.stats-strip,.footer{grid-template-columns:1fr 1fr}.hero-icons{grid-template-columns:1fr 1fr}.social-top{display:none}}
@media(max-width:640px){.stats-strip,.footer{grid-template-columns:1fr}.hero-copy h1{font-size:36px}.division h2 span{font-size:36px}.subhero h1{font-size:40px}.portal-btn{display:none}}


/* Ajustes finales legales, SEO y producción */
.legal-links{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  align-items:center;
  justify-content:center;
  font-size:13px;
}
.legal-links a{
  color:inherit;
  text-decoration:none;
  border-bottom:1px solid rgba(255,255,255,.35);
}
.legal-links a:hover{
  color:#ff9f1c;
}
.legal-page{
  max-width:1100px;
  margin:auto;
  padding:70px 6%;
}
.legal-page h1{
  font-size:clamp(34px,5vw,60px);
  text-transform:uppercase;
}
.legal-page h2{
  color:#ff9f1c;
  margin-top:34px;
}
.legal-page p,.legal-page li{
  color:#dbeafe;
  line-height:1.75;
  font-size:18px;
}
.notice-box{
  background:linear-gradient(180deg,#0b223d,#07172b);
  border:1px solid rgba(255,255,255,.15);
  border-radius:14px;
  padding:22px;
  margin:24px 0;
}
.analytics-note{
  display:none;
}


/* =========================================================
   AJUSTES RESPONSIVE FINALES
   Laptop, PC, tablet y celulares
   ========================================================= */

body{
  overflow-x:hidden;
}

.topbar{
  min-height:78px;
}

.brand{
  flex-shrink:0;
}

.brand img{
  max-width:70px;
  height:auto;
}

.hero-premium,
.subhero,
.portal-hero-v3{
  background-size:cover;
  background-position:center;
}

.hero-copy,
.hero-content,
.subhero > div{
  max-width:900px;
}

/* Pantallas grandes PC */
@media (min-width:1200px){
  .topbar{
    padding-left:4%;
    padding-right:4%;
  }

  .hero-premium{
    min-height:560px;
    grid-template-columns:1.15fr .85fr;
  }

  .premium-content{
    max-width:1280px;
  }
}

/* Laptop normal */
@media (max-width:1199px){
  .topbar{
    gap:14px;
  }

  nav{
    gap:12px;
  }

  nav a{
    font-size:12px;
  }

  .portal-btn{
    padding:9px 12px;
    font-size:12px;
  }

  .hero-premium{
    grid-template-columns:1fr .75fr;
    padding:48px 5%;
  }

  .hero-copy h1{
    font-size:clamp(36px,5vw,56px);
  }

  .hero-logo-block img{
    max-width:330px;
  }

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

  .stats-strip{
    grid-template-columns:repeat(3,1fr);
  }

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

/* Tablet */
@media (max-width:980px){
  .topbar{
    height:auto;
    min-height:auto;
    padding:12px 5%;
    display:grid;
    grid-template-columns:1fr auto;
    align-items:center;
  }

  .brand{
    min-width:0;
  }

  .brand img{
    width:58px;
  }

  .brand span{
    font-size:22px;
  }

  .brand small{
    font-size:10px;
  }

  nav{
    grid-column:1 / -1;
    width:100%;
    display:flex;
    justify-content:flex-start;
    gap:8px;
    overflow-x:auto;
    padding:8px 0 2px;
    -webkit-overflow-scrolling:touch;
  }

  nav a{
    white-space:nowrap;
    padding:10px 12px;
    background:rgba(255,255,255,.06);
    border-radius:999px;
    border-bottom:0;
    font-size:12px;
  }

  nav a.active,
  nav a:hover{
    background:#ff9f1c;
    color:#061528;
    border-bottom:0;
  }

  .portal-btn{
    grid-column:2;
    grid-row:1;
    font-size:11px;
    padding:8px 10px;
  }

  .social-top{
    display:none;
  }

  .hero-premium{
    min-height:auto;
    grid-template-columns:1fr;
    padding:60px 6%;
    text-align:left;
  }

  .hero-logo-block{
    display:none;
  }

  .hero-copy h1{
    font-size:clamp(34px,8vw,54px);
  }

  .hero-copy p{
    font-size:18px;
  }

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

  .division-grid{
    grid-template-columns:1fr;
    padding:0;
    gap:0;
  }

  .division{
    min-height:360px;
    padding:42px 6%;
  }

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

  .testimonial-grid,
  .contact-grid{
    grid-template-columns:1fr;
  }

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

  .subhero{
    min-height:360px;
    padding:60px 6%;
  }

  .premium-content{
    padding:55px 6%;
  }
}

/* Celulares */
@media (max-width:640px){
  .topbar{
    padding:10px 4%;
  }

  .brand img{
    width:52px;
  }

  .brand span{
    font-size:19px;
  }

  .brand small{
    font-size:9px;
    letter-spacing:.3px;
  }

  .portal-btn{
    display:inline-block;
    font-size:10px;
    padding:7px 8px;
    max-width:126px;
  }

  .portal-btn span{
    font-size:9px;
  }

  nav{
    gap:7px;
  }

  nav a{
    font-size:11px;
    padding:9px 10px;
  }

  .hero-premium{
    padding:48px 5%;
    background-position:center;
  }

  .hero-copy h1{
    font-size:32px;
    line-height:1.1;
  }

  .hero-copy p{
    font-size:16px;
  }

  .hero-icons{
    grid-template-columns:1fr;
    gap:12px;
  }

  .hero-icons div{
    background:rgba(6,21,40,.72);
    padding:12px;
    border-radius:12px;
    border:1px solid rgba(255,255,255,.12);
  }

  .division{
    min-height:430px;
    padding:35px 5%;
  }

  .division h2{
    font-size:27px;
  }

  .division h2 span{
    font-size:34px;
  }

  .division h2 .blue{
    font-size:25px;
  }

  .division h3{
    font-size:16px;
  }

  .division li{
    font-size:15px;
  }

  .stats-strip{
    grid-template-columns:1fr;
    padding:18px 5%;
  }

  .stats-strip div{
    border-right:0;
    border-bottom:1px solid rgba(255,255,255,.25);
    padding:14px 0;
  }

  .stats-strip div:last-child{
    border-bottom:0;
  }

  .testimonials{
    padding:36px 5%;
  }

  .testimonial-grid{
    gap:18px;
  }

  .subhero{
    min-height:330px;
    padding:46px 5%;
  }

  .subhero > div{
    padding:22px;
    width:100%;
  }

  .subhero h1{
    font-size:34px;
    line-height:1.08;
  }

  .subhero p{
    font-size:17px;
  }

  .premium-content{
    padding:42px 5%;
  }

  .premium-content h2{
    font-size:30px;
  }

  .cards-dark{
    grid-template-columns:1fr;
    gap:16px;
  }

  .blog-list{
    grid-template-columns:1fr;
  }

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

  input,select,textarea{
    font-size:16px;
  }

  .map iframe{
    height:320px;
  }

  .portal-hero-v3{
    min-height:70vh;
    padding:40px 5%;
  }

  .portal-hero-v3 img{
    max-width:92%;
  }

  .portal-hero-v3 h1{
    font-size:42px;
  }

  .footer{
    grid-template-columns:1fr;
    text-align:left;
  }

  .foot-item{
    align-items:flex-start;
  }

  .wa-float{
    right:16px;
    bottom:16px;
    width:56px;
    height:56px;
  }

  .wa-float img{
    width:38px;
  }

  .legal-page{
    padding:44px 5%;
  }
}

/* Celulares pequeños */
@media (max-width:390px){
  .brand span{
    font-size:17px;
  }

  .portal-btn{
    max-width:110px;
    font-size:9px;
  }

  nav a{
    font-size:10px;
  }

  .hero-copy h1{
    font-size:29px;
  }

  .division h2 span{
    font-size:30px;
  }

  .subhero h1{
    font-size:30px;
  }
}


/* =========================================================
   AJUSTE FINAL DE MENU Y LOGO
   ========================================================= */

/* Header más limpio */
.topbar{
  min-height:82px;
  height:auto;
  padding:8px 3%;
  gap:14px;
  display:flex;
  align-items:center;
}

.brand.logo-only,
.brand{
  min-width:auto!important;
  width:auto!important;
  flex:0 0 auto;
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
}

/* Oculta cualquier texto residual del logo en menú */
.brand span,
.brand small{
  display:none!important;
}

/* Logo más grande y visible */
.brand img{
  width:auto!important;
  height:78px!important;
  max-width:230px!important;
  object-fit:contain!important;
  filter:
    drop-shadow(0 0 4px #ffffff)
    drop-shadow(0 0 12px rgba(255,255,255,.85))
    drop-shadow(0 0 22px rgba(255,255,255,.45))!important;
}

/* Menú más compacto para que no se salga */
nav{
  flex:1 1 auto;
  min-width:0;
  display:flex;
  justify-content:center;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}

nav a{
  font-size:12px!important;
  padding:9px 6px!important;
  line-height:1.1;
  white-space:nowrap;
}

/* Portal más pequeño */
.portal-btn{
  flex:0 0 auto;
  padding:8px 12px!important;
  font-size:11px!important;
  line-height:1.05;
  min-width:82px;
  max-width:96px;
}

.portal-btn span{
  font-size:9px!important;
}

/* Redes más compactas */
.social-top{
  flex:0 0 auto;
  gap:8px!important;
}

.social-top a{
  width:26px!important;
  height:26px!important;
  line-height:26px!important;
  font-size:13px!important;
}

/* Laptop mediana */
@media (max-width:1180px){
  .topbar{
    padding:8px 2%;
    gap:9px;
  }

  .brand img{
    height:70px!important;
    max-width:205px!important;
  }

  nav{
    gap:7px;
  }

  nav a{
    font-size:11px!important;
    padding:8px 4px!important;
  }

  .portal-btn{
    max-width:84px;
    padding:7px 8px!important;
    font-size:10px!important;
  }

  .social-top{
    display:none!important;
  }
}

/* Tablet: menú en segunda línea y logo centrado/visible */
@media (max-width:980px){
  .topbar{
    display:grid!important;
    grid-template-columns:1fr auto;
    align-items:center;
    padding:10px 5%;
  }

  .brand.logo-only,
  .brand{
    justify-content:flex-start;
  }

  .brand img{
    height:82px!important;
    max-width:260px!important;
  }

  .portal-btn{
    grid-column:2;
    grid-row:1;
    max-width:92px;
  }

  nav{
    grid-column:1 / -1;
    width:100%;
    justify-content:flex-start!important;
    overflow-x:auto;
    flex-wrap:nowrap!important;
    gap:8px;
    padding:8px 0 4px;
    scrollbar-width:thin;
  }

  nav a{
    flex:0 0 auto;
    padding:10px 12px!important;
    background:rgba(255,255,255,.07);
    border-radius:999px;
    border-bottom:0!important;
  }

  nav a.active,
  nav a:hover{
    background:#ff9f1c;
    color:#061528!important;
  }
}

/* Celular */
@media (max-width:640px){
  .topbar{
    padding:8px 4%;
  }

  .brand img{
    height:72px!important;
    max-width:230px!important;
  }

  .portal-btn{
    font-size:9px!important;
    max-width:78px;
    padding:6px 7px!important;
  }

  .portal-btn span{
    font-size:8px!important;
  }

  nav{
    gap:7px;
  }

  nav a{
    font-size:10px!important;
    padding:9px 10px!important;
  }
}

/* Celular muy pequeño */
@media (max-width:390px){
  .brand img{
    height:64px!important;
    max-width:195px!important;
  }

  .portal-btn{
    max-width:70px;
    font-size:8px!important;
  }
}


/* =========================================================
   CJPAONIC - AJUSTES FINALES TODAS LAS FASES
   ========================================================= */

/* Menú logo limpio y compacto */
.topbar{min-height:82px;height:auto;padding:8px 3%;gap:14px;display:flex;align-items:center;overflow:visible}
.brand.logo-only,.brand{min-width:auto!important;width:auto!important;flex:0 0 auto;display:flex;align-items:center;justify-content:center;text-decoration:none}
.brand span,.brand small{display:none!important}
.brand img{width:auto!important;height:78px!important;max-width:230px!important;object-fit:contain!important;filter:drop-shadow(0 0 4px #fff) drop-shadow(0 0 12px rgba(255,255,255,.85)) drop-shadow(0 0 22px rgba(255,255,255,.45))!important}
nav{flex:1 1 auto;min-width:0;display:flex;justify-content:center;align-items:center;gap:10px;flex-wrap:wrap}
nav a{font-size:12px!important;padding:9px 6px!important;line-height:1.1;white-space:nowrap}
.portal-btn{flex:0 0 auto;padding:8px 12px!important;font-size:11px!important;line-height:1.05;min-width:82px;max-width:96px}.portal-btn span{font-size:9px!important}
.social-top{flex:0 0 auto;gap:8px!important}.social-top a{width:26px!important;height:26px!important;line-height:26px!important;font-size:13px!important}

/* Footer corporativo 4 columnas */
.footer{display:none!important}
.footer-corporativo{background:#020b17;color:#fff;padding:46px 5% 0;border-top:1px solid rgba(255,255,255,.12);display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:28px}
.footer-col{display:flex;flex-direction:column;gap:9px}
.footer-col h3{color:#ff9f1c;margin:0 0 8px;text-transform:uppercase;font-size:16px}
.footer-col a{color:#dbeafe;text-decoration:none;line-height:1.35}
.footer-col a:hover{color:#ff9f1c}
.footer-col p{color:#dbeafe;margin:0;line-height:1.5}
.footer-brand img{width:220px;max-width:100%;filter:drop-shadow(0 0 6px #fff) drop-shadow(0 0 18px rgba(255,255,255,.55))}
.footer-brand span{color:#ff9f1c;font-weight:900}
.footer-social{display:flex;flex-wrap:wrap;gap:8px}
.footer-social a{background:#0a6edb;padding:8px 10px;border-radius:999px;font-size:13px;font-weight:800}
.footer-bottom{grid-column:1 / -1;margin-top:20px;padding:18px 0;text-align:center;border-top:1px solid rgba(255,255,255,.14);color:#b8c7dd;font-size:14px}

/* Legal */
.legal-page{max-width:1100px;margin:auto;padding:70px 6%}.legal-page h1{font-size:clamp(34px,5vw,60px);text-transform:uppercase}.legal-page h2{color:#ff9f1c;margin-top:34px}.legal-page p,.legal-page li{color:#dbeafe;line-height:1.75;font-size:18px}.notice-box{background:linear-gradient(180deg,#0b223d,#07172b);border:1px solid rgba(255,255,255,.15);border-radius:14px;padding:22px;margin:24px 0}

/* Portal visual */
.portal-pro{min-height:84vh}.portal-pro>div{max-width:1000px}.portal-label{color:#ff9f1c;text-transform:uppercase;font-weight:900;letter-spacing:2px}.portal-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:26px 0}.portal-cards article{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);border-radius:16px;padding:18px}.portal-cards h3{color:#ff9f1c;margin-top:0}.portal-cards p{font-size:15px;color:#dbeafe}

/* Responsive final */
body{overflow-x:hidden}
@media(max-width:1180px){.topbar{padding:8px 2%;gap:9px}.brand img{height:70px!important;max-width:205px!important}nav{gap:7px}nav a{font-size:11px!important;padding:8px 4px!important}.portal-btn{max-width:84px;padding:7px 8px!important;font-size:10px!important}.social-top{display:none!important}.footer-corporativo{grid-template-columns:1fr 1fr}}
@media(max-width:980px){.topbar{display:grid!important;grid-template-columns:1fr auto;align-items:center;padding:10px 5%}.brand{justify-content:flex-start}.brand img{height:82px!important;max-width:260px!important}.portal-btn{grid-column:2;grid-row:1;max-width:92px}nav{grid-column:1 / -1;width:100%;justify-content:flex-start!important;overflow-x:auto;flex-wrap:nowrap!important;gap:8px;padding:8px 0 4px;scrollbar-width:thin}nav a{flex:0 0 auto;padding:10px 12px!important;background:rgba(255,255,255,.07);border-radius:999px;border-bottom:0!important}.active,nav a:hover{background:#ff9f1c;color:#061528!important;border-bottom:0!important}.portal-cards{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.topbar{padding:8px 4%}.brand img{height:72px!important;max-width:230px!important}.portal-btn{font-size:9px!important;max-width:78px;padding:6px 7px!important}.portal-btn span{font-size:8px!important}nav{gap:7px}nav a{font-size:10px!important;padding:9px 10px!important}.footer-corporativo{grid-template-columns:1fr;padding:36px 6% 0}.footer-brand img{width:190px}.portal-cards{grid-template-columns:1fr}.legal-page{padding:44px 5%}}
@media(max-width:390px){.brand img{height:64px!important;max-width:195px!important}.portal-btn{max-width:70px;font-size:8px!important}}


/* =========================================================
   LOGO GRANDE FINAL EN TODAS LAS PAGINAS
   ========================================================= */

/* Header con logo protagonista */
.topbar{
  min-height:128px!important;
  height:auto!important;
  padding:12px 4%!important;
  gap:22px!important;
  align-items:center!important;
}

/* Logo principal del menú */
.brand.logo-only,
.brand{
  flex:0 0 auto!important;
  min-width:auto!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
}

.brand img{
  height:118px!important;
  width:auto!important;
  max-width:360px!important;
  object-fit:contain!important;
  filter:
    drop-shadow(0 0 6px #ffffff)
    drop-shadow(0 0 18px rgba(255,255,255,.95))
    drop-shadow(0 0 34px rgba(255,255,255,.55))!important;
}

/* Menú centrado junto al logo */
nav{
  flex:1 1 auto!important;
  justify-content:center!important;
  align-items:center!important;
  gap:13px!important;
}

nav a{
  font-size:12px!important;
  padding:10px 7px!important;
}

/* Portal compacto */
.portal-btn{
  max-width:105px!important;
  padding:9px 14px!important;
}

/* Logo grande en portada */
.hero-logo-block img,
.portal-hero-v3 img{
  max-width:560px!important;
  filter:
    drop-shadow(0 0 8px #ffffff)
    drop-shadow(0 0 24px rgba(255,255,255,.9))
    drop-shadow(0 0 45px rgba(255,255,255,.55))!important;
}

/* Logo grande en footer */
.footer-brand img{
  width:320px!important;
  max-width:100%!important;
  filter:
    drop-shadow(0 0 7px #ffffff)
    drop-shadow(0 0 20px rgba(255,255,255,.85))
    drop-shadow(0 0 38px rgba(255,255,255,.45))!important;
}

/* Laptop */
@media(max-width:1180px){
  .topbar{
    min-height:115px!important;
    padding:10px 3%!important;
    gap:14px!important;
  }

  .brand img{
    height:104px!important;
    max-width:320px!important;
  }

  nav{
    gap:8px!important;
  }

  nav a{
    font-size:11px!important;
    padding:8px 5px!important;
  }

  .portal-btn{
    max-width:90px!important;
    padding:8px 9px!important;
  }
}

/* Tablet */
@media(max-width:980px){
  .topbar{
    min-height:auto!important;
    display:grid!important;
    grid-template-columns:1fr auto!important;
    padding:12px 5%!important;
  }

  .brand{
    justify-content:flex-start!important;
  }

  .brand img{
    height:112px!important;
    max-width:340px!important;
  }

  .portal-btn{
    grid-column:2!important;
    grid-row:1!important;
  }

  nav{
    grid-column:1 / -1!important;
    width:100%!important;
    justify-content:flex-start!important;
    overflow-x:auto!important;
    flex-wrap:nowrap!important;
    padding:10px 0 4px!important;
  }
}

/* Celular */
@media(max-width:640px){
  .topbar{
    padding:10px 4%!important;
  }

  .brand img{
    height:90px!important;
    max-width:275px!important;
  }

  .portal-btn{
    max-width:78px!important;
    font-size:9px!important;
    padding:6px 7px!important;
  }

  nav a{
    font-size:10px!important;
    padding:9px 10px!important;
  }

  .hero-logo-block img,
  .portal-hero-v3 img{
    max-width:92%!important;
  }

  .footer-brand img{
    width:260px!important;
  }
}

/* Celular pequeño */
@media(max-width:390px){
  .brand img{
    height:78px!important;
    max-width:230px!important;
  }

  .footer-brand img{
    width:230px!important;
  }
}


/* =========================================================
   CORRECCION PRODUCCION HOSTINGER - HEADER ESTABLE
   ========================================================= */

*{box-sizing:border-box}
html,body{max-width:100%;overflow-x:hidden}

.topbar{
  height:auto!important;
  min-height:auto!important;
  display:grid!important;
  grid-template-columns:auto 1fr auto auto!important;
  grid-template-areas:
    "logo space portal social"
    "nav nav nav nav"!important;
  align-items:center!important;
  gap:10px 18px!important;
  padding:10px 4% 8px!important;
  overflow:visible!important;
}

.brand.logo-only,
.brand{
  grid-area:logo!important;
  min-width:0!important;
  width:auto!important;
  max-width:360px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:flex-start!important;
}

.brand span,
.brand small{
  display:none!important;
}

.brand img{
  display:block!important;
  height:118px!important;
  width:auto!important;
  max-width:360px!important;
  object-fit:contain!important;
  filter:
    drop-shadow(0 0 6px #ffffff)
    drop-shadow(0 0 18px rgba(255,255,255,.9))
    drop-shadow(0 0 34px rgba(255,255,255,.5))!important;
}

.topbar nav,
nav{
  grid-area:nav!important;
  width:100%!important;
  max-width:100%!important;
  min-width:0!important;
  display:flex!important;
  flex-wrap:wrap!important;
  justify-content:center!important;
  align-items:center!important;
  gap:8px!important;
  padding:6px 0 0!important;
  overflow:visible!important;
}

.topbar nav a,
nav a{
  flex:0 0 auto!important;
  white-space:nowrap!important;
  font-size:12px!important;
  line-height:1!important;
  padding:10px 10px!important;
  border-radius:999px!important;
  border-bottom:0!important;
  background:rgba(255,255,255,.05)!important;
}

.topbar nav a.active,
.topbar nav a:hover,
nav a.active,
nav a:hover{
  background:#ff9f1c!important;
  color:#061528!important;
  border-bottom:0!important;
}

.portal-btn{
  grid-area:portal!important;
  justify-self:end!important;
  min-width:100px!important;
  max-width:118px!important;
  padding:9px 12px!important;
  font-size:11px!important;
  line-height:1.05!important;
  text-align:center!important;
  white-space:normal!important;
}

.portal-btn span{
  font-size:9px!important;
}

.social-top{
  grid-area:social!important;
  display:flex!important;
  gap:8px!important;
  justify-self:end!important;
}

.social-top a{
  width:28px!important;
  height:28px!important;
  line-height:28px!important;
  font-size:13px!important;
}

.hero-logo-block img,
.portal-hero-v3 img{
  max-width:min(560px,92vw)!important;
  filter:
    drop-shadow(0 0 8px #ffffff)
    drop-shadow(0 0 24px rgba(255,255,255,.9))
    drop-shadow(0 0 45px rgba(255,255,255,.55))!important;
}

.footer-brand img{
  width:320px!important;
  max-width:100%!important;
  height:auto!important;
}

@media(max-width:1366px){
  .topbar{
    padding:9px 3% 7px!important;
    gap:8px 14px!important;
  }

  .brand img{
    height:104px!important;
    max-width:315px!important;
  }

  .topbar nav a,
  nav a{
    font-size:11px!important;
    padding:9px 9px!important;
  }
}

@media(max-width:1100px){
  .topbar{
    grid-template-columns:auto 1fr auto!important;
    grid-template-areas:
      "logo space portal"
      "nav nav nav"!important;
  }

  .social-top{
    display:none!important;
  }

  .brand img{
    height:96px!important;
    max-width:285px!important;
  }

  .topbar nav,
  nav{
    justify-content:flex-start!important;
    flex-wrap:nowrap!important;
    overflow-x:auto!important;
    scrollbar-width:thin;
    -webkit-overflow-scrolling:touch;
  }

  .topbar nav a,
  nav a{
    font-size:11px!important;
    padding:9px 11px!important;
  }
}

@media(max-width:760px){
  .topbar{
    grid-template-columns:1fr auto!important;
    grid-template-areas:
      "logo portal"
      "nav nav"!important;
    padding:9px 4% 8px!important;
  }

  .brand{
    max-width:260px!important;
  }

  .brand img{
    height:86px!important;
    max-width:255px!important;
  }

  .portal-btn{
    min-width:78px!important;
    max-width:88px!important;
    padding:7px 8px!important;
    font-size:9px!important;
  }

  .portal-btn span{
    font-size:8px!important;
  }

  .topbar nav,
  nav{
    padding-top:8px!important;
  }

  .topbar nav a,
  nav a{
    font-size:10px!important;
    padding:9px 10px!important;
  }
}

@media(max-width:430px){
  .brand{
    max-width:220px!important;
  }

  .brand img{
    height:76px!important;
    max-width:220px!important;
  }

  .portal-btn{
    min-width:68px!important;
    max-width:74px!important;
    font-size:8px!important;
    padding:6px 6px!important;
  }

  .portal-btn span{
    display:block!important;
    font-size:7px!important;
  }

  .topbar nav a,
  nav a{
    font-size:10px!important;
    padding:8px 9px!important;
  }
}

@media(max-width:360px){
  .brand img{
    height:66px!important;
    max-width:190px!important;
  }
}


/* =========================================================
   HEADER SEGURO DEFINITIVO PARA HOSTINGER
   Diseño estable: logo arriba, menu abajo, portal separado
   ========================================================= */

html, body {
  width:100% !important;
  max-width:100% !important;
  overflow-x:hidden !important;
}

.topbar {
  position:sticky !important;
  top:0 !important;
  z-index:9999 !important;
  width:100% !important;
  height:auto !important;
  min-height:0 !important;
  display:flex !important;
  flex-direction:column !important;
  align-items:center !important;
  justify-content:center !important;
  gap:8px !important;
  padding:12px 20px 10px !important;
  background:#061528 !important;
  border-bottom:1px solid rgba(255,255,255,.18) !important;
  box-shadow:0 8px 24px rgba(0,0,0,.25) !important;
  overflow:visible !important;
}

/* Logo principal: grande, centrado y sin texto adicional */
.topbar .brand,
.topbar .brand.logo-only {
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
  display:flex !important;
  justify-content:center !important;
  align-items:center !important;
  margin:0 auto !important;
  padding:0 !important;
  text-decoration:none !important;
  flex:none !important;
  grid-area:unset !important;
}

.topbar .brand span,
.topbar .brand small {
  display:none !important;
}

.topbar .brand img {
  display:block !important;
  width:auto !important;
  height:128px !important;
  max-height:128px !important;
  max-width:min(430px, 92vw) !important;
  object-fit:contain !important;
  margin:0 auto !important;
  filter:
    drop-shadow(0 0 7px #ffffff)
    drop-shadow(0 0 20px rgba(255,255,255,.95))
    drop-shadow(0 0 36px rgba(255,255,255,.55)) !important;
}

/* Menu centrado, compacto y siempre dentro de pantalla */
.topbar nav,
body .topbar nav {
  width:100% !important;
  max-width:1180px !important;
  display:flex !important;
  flex-direction:row !important;
  flex-wrap:wrap !important;
  justify-content:center !important;
  align-items:center !important;
  gap:8px !important;
  margin:0 auto !important;
  padding:4px 0 0 !important;
  overflow:visible !important;
  grid-area:unset !important;
  flex:none !important;
}

.topbar nav a,
body .topbar nav a {
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  flex:0 0 auto !important;
  white-space:nowrap !important;
  text-decoration:none !important;
  text-transform:uppercase !important;
  font-size:12px !important;
  line-height:1 !important;
  font-weight:900 !important;
  color:#ffffff !important;
  padding:10px 12px !important;
  border-radius:999px !important;
  background:rgba(255,255,255,.07) !important;
  border:1px solid rgba(255,255,255,.10) !important;
  border-bottom:1px solid rgba(255,255,255,.10) !important;
}

.topbar nav a.active,
.topbar nav a:hover {
  background:#ff9f1c !important;
  color:#061528 !important;
}

/* Portal como boton independiente debajo/derecha pero estable */
.topbar .portal-btn {
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:auto !important;
  min-width:120px !important;
  max-width:none !important;
  margin:2px auto 0 !important;
  padding:9px 18px !important;
  border-radius:999px !important;
  background:#0a6edb !important;
  border:1px solid rgba(255,255,255,.18) !important;
  color:#ffffff !important;
  text-align:center !important;
  text-decoration:none !important;
  text-transform:uppercase !important;
  font-size:12px !important;
  line-height:1.05 !important;
  font-weight:900 !important;
  grid-area:unset !important;
  flex:none !important;
}

.topbar .portal-btn span {
  display:inline !important;
  margin-left:6px !important;
  font-size:10px !important;
  color:#dbeafe !important;
}

/* Redes ocultas en header para no saturar; siguen en footer */
.topbar .social-top {
  display:none !important;
}

/* Ajuste del contenido para no quedar escondido */
.hero-premium,
.subhero,
.portal-hero-v3 {
  margin-top:0 !important;
}

/* Footer logo más visible */
.footer-brand img {
  width:320px !important;
  max-width:100% !important;
  height:auto !important;
}

/* Laptop */
@media (max-width:1200px) {
  .topbar .brand img {
    height:118px !important;
    max-height:118px !important;
  }

  .topbar nav a {
    font-size:11px !important;
    padding:9px 10px !important;
  }
}

/* Tablet */
@media (max-width:900px) {
  .topbar {
    padding:10px 12px 9px !important;
    gap:7px !important;
  }

  .topbar .brand img {
    height:104px !important;
    max-height:104px !important;
    max-width:90vw !important;
  }

  .topbar nav {
    justify-content:flex-start !important;
    flex-wrap:nowrap !important;
    overflow-x:auto !important;
    padding:5px 0 4px !important;
    scrollbar-width:thin !important;
    -webkit-overflow-scrolling:touch !important;
  }

  .topbar nav a {
    font-size:11px !important;
    padding:9px 11px !important;
  }

  .topbar .portal-btn {
    padding:8px 14px !important;
    font-size:11px !important;
  }
}

/* Celular */
@media (max-width:600px) {
  .topbar {
    padding:9px 10px 8px !important;
  }

  .topbar .brand img {
    height:88px !important;
    max-height:88px !important;
    max-width:92vw !important;
  }

  .topbar nav {
    gap:7px !important;
  }

  .topbar nav a {
    font-size:10px !important;
    padding:8px 10px !important;
  }

  .topbar .portal-btn {
    min-width:0 !important;
    padding:8px 14px !important;
    font-size:10px !important;
  }

  .topbar .portal-btn span {
    font-size:9px !important;
  }

  .footer-brand img {
    width:250px !important;
  }
}

/* Celular pequeño */
@media (max-width:380px) {
  .topbar .brand img {
    height:78px !important;
    max-height:78px !important;
  }

  .topbar nav a {
    font-size:9px !important;
    padding:8px 9px !important;
  }

  .topbar .portal-btn span {
    display:none !important;
  }
}
