:root{--ink:#0f172a;--muted:#6b7280;--brand:#0077c9;--brand2:#0ea5e9;--bg:#ffffff;--paper:#ffffff;--accent:#ffd54a}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{height:100%;overflow-x:hidden}
body{min-height:100vh;display:flex;flex-direction:column;margin:0;font-family:'Poppins',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:
	linear-gradient(180deg, #cdd8ea 0%, #d5dff0 30%, #dde5f0 70%, #d8e2ee 100%);background-attachment:fixed;background-repeat:no-repeat}

/* Ensure white cards keep dark text for readability on dark page background */
.card, .cat, .cat .body, .cat h3, .cat p { color: var(--ink); }
.wrapper{max-width:1200px;width:80%;margin:0 auto;padding:0 16px}
@media(max-width:768px){.wrapper{width:95%}}
@media(max-width:480px){.wrapper{width:100%;padding:0 12px}}
.site-header{background:linear-gradient(180deg,#0b1230 0%, #07102a 100%);color:#ffffff;border-bottom:4px solid rgba(0,0,0,0.06);position:sticky;top:0;z-index:999;width:100%}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand a{color:var(--accent);text-decoration:none;font-weight:800}
.brand small{display:block;color:#93c5fd;font-size:15px}
.nav{display:flex;flex:1;justify-content:center;gap:12px}
.nav a{color:rgba(255,255,255,0.92);text-decoration:none;margin:0 6px;font-weight:600;font-size:clamp(12px,1.5vw,16px)}
.nav a.active,.nav a:hover{color:var(--accent)}
.nav-right{display:flex;gap:20px;align-items:center}
.nav-dropdown{position:relative;display:inline-block}
.nav-dropdown-toggle{background:none;border:none;color:#bfdbfe;font-weight:600;cursor:pointer;padding:0;font-size:inherit;font-family:inherit}
.nav-dropdown-toggle:hover{color:#fff}
.nav-dropdown-menu{display:none;position:absolute;top:calc(100% - 4px);right:0;background:#1e293b;border-radius:8px;min-width:200px;box-shadow:0 4px 12px rgba(0,0,0,0.3);z-index:1000;padding-top:12px}
.nav-dropdown:hover .nav-dropdown-menu{display:block}
.nav-dropdown-menu a{display:block;color:#cbd5e1;text-decoration:none;padding:10px 16px;margin:0;font-weight:400;border-bottom:1px solid #334155;transition:background-color 0.2s}
.nav-dropdown-menu a:last-child{border-bottom:none}
.nav-dropdown-menu a:hover{background:#334155;color:#fff}
.cta a{background:var(--accent);color:var(--brand);text-decoration:none;padding:10px 14px;border-radius:10px;font-weight:800}
.hero{background:transparent;color:#e2f2ff;padding:0;width:100%}
.hero img{width:100%;height:auto;display:block;border-radius:0}

/* Hero overlay text with staggered entrance */
.hero-overlay{position:absolute;inset:0;display:flex;align-items:center;z-index:5;padding:0 clamp(24px,6vw,80px);pointer-events:none}
.hero-overlay-content{display:flex;flex-direction:column;align-items:flex-start;max-width:600px}
.hero-overlay-line{opacity:0;transform:translateY(28px);animation:heroFadeUp .9s cubic-bezier(.23,1,.32,1) forwards}
.hero-line-1{font-size:clamp(16px,4vw,44px);font-weight:900;color:#fff;margin:0 0 10px;text-shadow:0 3px 20px rgba(0,0,0,0.5),0 1px 3px rgba(0,0,0,0.35);line-height:1.15;text-transform:uppercase;letter-spacing:.5px;animation-delay:.4s}
.hero-line-2{font-size:clamp(11px,2.2vw,22px);font-weight:400;color:#e2f2ff;margin:0 0 16px;text-shadow:0 2px 14px rgba(0,0,0,0.45);line-height:1.45;animation-delay:.85s}
.hero-line-3{animation-delay:1.3s;pointer-events:auto}
.hero-overlay-btn{display:inline-block;background:#fff;color:#0b1230;font-weight:700;font-size:clamp(10px,1.4vw,15px);padding:10px 28px;border-radius:6px;text-decoration:none;text-transform:uppercase;letter-spacing:.5px;transition:background .2s,transform .2s,box-shadow .2s;box-shadow:0 4px 16px rgba(0,0,0,0.25)}
.hero-overlay-btn:hover{background:#00e0ff;color:#0b1230;transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.3)}
@keyframes heroFadeUp{0%{opacity:0;transform:translateY(28px)}100%{opacity:1;transform:translateY(0)}}
@media(max-width:768px){
  .hero-overlay{padding:0 20px;align-items:center}
  .hero-overlay-content{max-width:90%}
  .hero-line-1{font-size:clamp(15px,5vw,28px);margin-bottom:6px}
  .hero-line-2{font-size:clamp(11px,3vw,16px);margin-bottom:12px}
  .hero-overlay-btn{padding:8px 18px;font-size:12px}
}
@media(max-width:480px){
  .hero-overlay{padding:0 14px}
  .hero-overlay-content{max-width:95%}
  .hero-line-1{font-size:14px;margin-bottom:4px}
  .hero-line-2{font-size:11px;margin-bottom:8px;line-height:1.35}
  .hero-overlay-btn{padding:6px 14px;font-size:10px;border-radius:4px}
}
.slides-container .slide img{width:100%;height:auto;max-height:520px;object-fit:cover;display:block;border-radius:0}
.hero h1{font-size:clamp(28px,4.6vw,48px);margin:0 0 6px}
.hero p{color:#cbd5e1}

/* Homepage hero accent color (from user attachment) */
.hero-accent{color:#0b3a5a}
.btn{display:inline-block;background:transparent;color:#00e0ff;padding:10px 24px;border-radius:6px;text-decoration:none;font-weight:600;font-size:14px;border:2px solid rgba(14,230,255,0.28);transition:background .2s,color .2s,border-color .2s,transform .2s;cursor:pointer;font-family:inherit;line-height:1.4}
.btn:hover{color:#fff;border-color:rgba(14,230,255,0.6);transform:translateY(-2px)}
.btn.alt{border-color:rgba(14,230,255,0.18);color:#00e0ff}
.btn.alt:hover{border-color:rgba(14,230,255,0.6);color:#fff}
button.btn,.form .btn{background:#0b1230;color:#00e0ff;border:2px solid rgba(14,230,255,0.4);font-family:inherit;padding:12px 32px;border-radius:8px;font-size:16px;font-weight:700}
button.btn:hover,.form .btn:hover{background:#0f1a3d;color:#fff;border-color:rgba(14,230,255,0.7)}
/* Anchor variant for filled primary buttons */
.btn.primary, a.btn.primary{display:inline-block;background:#0b1230;color:#00e0ff;border:2px solid rgba(14,230,255,0.4);padding:12px 32px;border-radius:8px;font-size:16px;font-weight:700;text-decoration:none}
.btn.primary:hover, a.btn.primary:hover{background:#0f1a3d;color:#fff;border-color:rgba(14,230,255,0.7)}
.section{padding:clamp(20px,4vw,34px) 0}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;width:100%;margin:0}
.card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:18px;box-shadow:0 6px 20px rgba(2,6,23,.06)}
.card img{max-width:100%;border-radius:10px}
.card.service{display:flex;flex-direction:column;align-items:center;text-align:center;transition:all 0.3s ease;border:none;box-shadow:0 4px 15px rgba(37,99,235,.08);padding:28px 24px;height:100%;min-height:320px}
.card.service:hover{transform:translateY(-8px);box-shadow:0 12px 30px rgba(37,99,235,.15);border-color:var(--brand)}
.service-icon{width:70px;height:70px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:var(--brand);font-size:0px;flex-shrink:0}
.service-icon img{width:100%;height:100%;object-fit:contain;object-position:center;max-width:none}
.card.service h3{margin:12px 0 8px;font-size:20px;color:var(--ink);font-weight:700}
.card.service p{margin:0;color:var(--muted);font-size:14px;line-height:1.6}

/* Nuestros Servicios - sección con servicios destacados */
/* Servicios - diseño con fondo oscuro y tarjetas */
.services-section{padding:clamp(32px,5vw,64px) 0 clamp(40px,6vw,80px);background:linear-gradient(180deg,#0b1230 0%, #07102a 100%);border-radius:16px;margin:18px auto;color:#fff;position:relative;overflow:visible;z-index:10;width:90%}
@media(max-width:1024px){.services-section{width:92%}}
@media(max-width:768px){.services-section{width:96%;border-radius:12px}}
@media(max-width:480px){.services-section{width:100%;border-radius:0;margin:10px 0}}
.services-section:before{content:'';position:absolute;right:-10%;bottom:-5%;width:80%;height:60%;background:radial-gradient(closest-side,rgba(14,120,200,0.12),transparent 60%);transform:rotate(-18deg);opacity:0.9}
.services-section:before{pointer-events:none}
.services-section .wrapper{max-width:100%;width:100%}
.services-section h2{color:#ffffff;font-size:clamp(16px,3.5vw,36px);text-align:center;font-weight:800;margin:6px 0 6px;word-break:break-word}
.services-section p{color:rgba(255,255,255,0.8);text-align:center;margin-bottom:28px}
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;align-items:stretch;position:relative;z-index:11}

/* Service card — tarjeta dentro de la sección oscura */
.service-card{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.08);border-radius:14px;padding:28px 22px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px;transition:transform .3s ease,box-shadow .3s ease,background .3s ease;min-height:260px}
.service-card:hover{transform:translateY(-6px);background:rgba(255,255,255,0.10);box-shadow:0 12px 32px rgba(0,0,0,0.25)}
.service-card .icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;margin-bottom:8px;flex-shrink:0}
.service-card .icon img{width:100%;height:100%;object-fit:contain}
.service-card h3{margin:6px 0 4px;font-size:18px;font-weight:700;color:#fff;line-height:1.3}
.service-card h3 a{color:inherit;text-decoration:none}
.service-card p{margin:0;font-size:14px;color:rgba(255,255,255,0.72);line-height:1.6;flex:1}
.service-meta{margin-top:auto;padding-top:12px;width:100%;text-align:center}
.service-cta{color:#00e0ff;font-weight:600;font-size:14px;text-decoration:none;transition:color .2s;display:inline-block;padding:8px 20px;border:2px solid rgba(14,230,255,0.28);border-radius:6px}
.service-cta:hover{color:#fff;text-decoration:none;border-color:rgba(14,230,255,0.6)}

/* Service card con imágenes grandes - SOLO para página de servicios */
.services-page .service-card{height:480px;min-height:auto}
.services-page .service-card .icon{width:300px;height:200px;margin-bottom:12px;border-radius:8px;overflow:hidden;flex-shrink:0}
.services-page .service-card .icon img{object-fit:cover}
.services-page .service-card h3{min-height:50px;display:flex;align-items:center;justify-content:center}
.services-page .service-card p{overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;max-height:4.2em}

@media (max-width:1400px){.services-grid{gap:20px}}
@media (max-width:1200px){.services-grid{grid-template-columns:repeat(2,1fr);gap:20px}.service-card{min-height:auto}}

/* Medios de pago grid: 3 cols desktop, 2 tablet, 1 mobile */
.medios-pago-grid{grid-template-columns:repeat(3,1fr);max-width:1100px;margin:0 auto}
@media (max-width:768px){.medios-pago-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.medios-pago-grid{grid-template-columns:1fr}}

/* Desarrollos grid: 3 cols desktop, 2 tablet, 1 mobile */
.desarrollos-grid{grid-template-columns:repeat(3,1fr)}
@media (max-width:768px){.desarrollos-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.desarrollos-grid{grid-template-columns:1fr}}

@media (max-width:1024px){.services-grid{grid-template-columns:repeat(2,1fr);gap:16px}}
@media (max-width:768px){.services-grid{grid-template-columns:repeat(2,1fr);gap:14px}.services-page .service-card{height:420px}.services-page .service-card .icon{width:240px;height:160px}}
@media (max-width:640px){.services-grid{grid-template-columns:repeat(2,1fr);gap:10px}.service-card{align-items:center;text-align:center;padding:16px 12px}.services-page .service-card{height:390px;min-height:auto}.services-page .service-card p{-webkit-line-clamp:5;max-height:6.5em;overflow:hidden}.services-page .service-card .icon{width:100%;max-width:200px;height:133px}.service-card h3{font-size:15px}.service-card p{font-size:13px}}
@media (max-width:480px){.services-grid{grid-template-columns:1fr;gap:16px}.services-page .service-card{height:auto;min-height:360px}.services-page .service-card .icon{max-width:100%;height:180px}}

/* Desarrollo detail items */
.desarrollo-detail-list{margin:6px 0 0;padding-left:0;list-style-type:none;color:#e2f2ff;font-size:13px;line-height:1.4;flex:1;overflow-y:auto;width:100%}
.desarrollo-detail-item{margin-bottom:6px;white-space:normal;overflow:visible;text-overflow:clip;font-weight:600;padding-left:18px;position:relative;font-size:13px;line-height:1.4}
.desarrollo-detail-item .check-icon{position:absolute;left:0;color:#0ea5e9}
.desarrollo-cta{margin-top:auto;padding-top:12px;flex-shrink:0;width:100%;text-align:center}

/* Desarrollos page cards */
.desarrollos-page .service-card{min-height:620px;padding:18px 16px}
.desarrollos-page .service-card p{flex:0;margin-bottom:30px;font-size:15px}
.desarrollos-page .service-card h3{flex-shrink:0;font-size:16px}

@media (max-width:1200px){.desarrollos-page .service-card{min-height:580px}}
@media (max-width:640px){.desarrollo-detail-item{font-size:12px}.desarrollos-page .service-card{min-height:auto;padding:14px 12px}}
@media (max-width:480px){.desarrollos-page .service-card{min-height:auto}}

/* CTA Banner - ¿Te gustaría saber más? */
.cta-banner{padding:48px 0;background:transparent;width:80%;margin-left:auto;margin-right:auto}
@media(max-width:768px){.cta-banner{width:96%;padding:24px 0}}
@media(max-width:480px){.cta-banner{width:100%;padding:16px 0}}
.cta-banner .wrapper{width:100%;max-width:100%}
.cta-banner-inner{
  display:flex;
  align-items:center;
  gap:0;
  background:linear-gradient(180deg,#0b1230 0%,#07102a 100%);
  border-radius:20px;
  overflow:hidden;
  min-height:200px;
  position:relative;
}
.cta-img-wrap{
  position:relative;
  flex:0 0 260px;
  min-height:220px;
  display:flex;
  align-items:flex-end;
  justify-content:center;
}
.cta-circle-bg{
  position:absolute;
  left:-30px;
  top:50%;
  transform:translateY(-50%);
  width:220px;
  height:220px;
  border-radius:50%;
  background:rgba(10,40,110,0.55);
}
.cta-circle-cyan{
  position:absolute;
  left:60px;
  bottom:-24px;
  width:120px;
  height:120px;
  border-radius:50%;
  background:#00d4e8;
  opacity:0.85;
}
.cta-person{
  position:relative;
  z-index:2;
  width:200px;
  height:auto;
  display:block;
  margin-bottom:0;
}
.cta-dots{
  position:absolute;
  bottom:28px;
  left:12px;
  display:flex;
  gap:7px;
  z-index:3;
}
.cta-dots span{
  width:10px;
  height:10px;
  border-radius:50%;
  background:#00d4e8;
  opacity:0.7;
}
.cta-dots span:last-child{opacity:1;background:#fff}
.cta-text{
  flex:1;
  padding:36px 48px 36px 24px;
  color:#fff;
}
.cta-text h2{
  margin:0 0 12px;
  font-size:clamp(22px,3vw,34px);
  font-weight:800;
  color:#fff;
}
.cta-text p{
  margin:0 0 24px;
  font-size:clamp(14px,1.6vw,18px);
  color:rgba(255,255,255,0.92);
  line-height:1.6;
}
.cta-text strong{color:#fff}
.cta-btn{
  display:inline-block;
  background:transparent;
  border:2px solid rgba(255,255,255,0.7);
  color:#fff;
  font-weight:700;
  font-size:15px;
  padding:10px 28px;
  border-radius:999px;
  text-decoration:none;
  transition:background .2s,color .2s;
}
.cta-btn:hover{background:#00d4e8;border-color:#00d4e8;color:#0a2870}
@media(max-width:760px){
  .cta-banner-inner{flex-direction:column;text-align:center}
  .cta-img-wrap{min-height:160px;flex:unset;width:100%}
  .cta-person{width:140px;margin:0 auto}
  .cta-text{padding:24px 20px}
}

/* Stats strip - tarjetas azul claro */
.stats-section{padding:56px 0;background:transparent;width:80%;margin-left:auto;margin-right:auto}
@media(max-width:768px){.stats-section{width:96%;padding:32px 0}}
@media(max-width:480px){.stats-section{width:100%;padding:24px 0}}
.stats-section .wrapper{width:100%;max-width:100%}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;width:100%}
.stat-card{background:#bfdbfe;border-radius:16px;padding:28px 20px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px}
.stat-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;margin-bottom:4px}
.stat-num{font-size:clamp(28px,3.5vw,42px);font-weight:800;color:#0f172a;line-height:1}
.stat-label{font-size:14px;color:#1e3a5f;font-weight:500;line-height:1.4}
@media(max-width:980px){.stats-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.stats-grid{grid-template-columns:1fr}}

/* Botón Otras Soluciones centrado y estilo tipo píldora */
.other-solutions-wrap{display:flex;justify-content:center;margin-top:48px}
.other-solutions-btn{display:inline-flex;align-items:center;gap:12px;padding:12px 30px;border-radius:999px;border:2px solid rgba(14,230,255,0.28);background:transparent;color:#fff;font-weight:800;font-size:clamp(15px,2vw,20px);text-decoration:none}
.other-solutions-btn{position:relative;z-index:20}
.other-solutions-btn .arrow-pill{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:999px;border:2px solid rgba(14,230,255,0.18);background:linear-gradient(90deg,rgba(14,230,255,0.08),transparent);color:#00f0ff}
.other-solutions-btn:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(2,6,23,0.45)}

/* duplicate services-grid queries removed – see primary rules above */

/* small detail line for service blocks */
.service-detail{color:var(--muted);font-size:14px;line-height:1.5}
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.cat{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}
.cat img{width:100%;height:200px;object-fit:cover}
.cat .body{padding:12px}
.site-footer{background:linear-gradient(180deg,#0b1230 0%, #07102a 100%);color:#cfe8ff;margin-top:auto}
.site-footer .wrapper{padding:24px 18px}
.footer-block{margin:10px 0}
.partners-section{background:transparent;padding:40px 0;width:80%;margin-left:auto;margin-right:auto}
@media(max-width:768px){.partners-section{width:96%;padding:24px 0}}
@media(max-width:480px){.partners-section{width:100%;padding:16px 0}}
.partners-section .wrapper{width:100%;max-width:100%}
.carousel-container{width:100%;overflow:hidden;background:#fff;padding:20px 0}
.carousel{position:relative;overflow:hidden}
.carousel .track{display:flex;gap:24px;width:max-content;padding:0 24px}
.carousel .item{min-width:160px;min-height:80px;background:transparent;display:grid;place-items:center;padding:12px;flex-shrink:0;transition:none}
.carousel .item img{max-width:140px;max-height:70px;object-fit:contain;background:transparent}
@keyframes scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.slides-container{overflow:visible;display:flex;gap:24px}
.slides-container.slider{gap:0}
.slides-container .slide{flex:1 1 0;min-width:0;box-sizing:border-box;padding:0}

/* Spacing for desarrollos slider: increased top gap to separate from containers */
.desarrollos-slider{margin-top:56px}

/* On large screens, slider fills full width */
@media (min-width:1200px){
	.slides-container .slide img{max-height:580px;}
}

/* On small screens reduce max height */
@media (max-width:640px){
	.slides-container .slide img{max-height:240px}
}

/* Make category banners visually integrate with the page background */
.cat img,
.section img.banner{border-radius:12px !important;box-shadow:0 8px 20px rgba(2,6,23,0.08) !important;background:transparent !important}

/* Carousel items should not appear as separate cards */
.carousel-container{background:transparent;padding:10px 0}
.carousel{background:transparent}
.carousel .item{background:transparent;box-shadow:none;border:none}
.carousel .item img{max-width:140px;max-height:45px;object-fit:contain}
.alert{padding:12px 16px;border-radius:8px;margin-bottom:16px}
.alert-success{background:#d1fae5;color:#065f46;border-left:4px solid #10b981}
.alert-danger{background:#fee2e2;color:#7f1d1d;border-left:4px solid #ef4444}
.form input,.form textarea, .form select{width:100%;padding:12px;border:1px solid #cbd5e1;border-radius:10px;margin:6px 0}
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:10px;border-bottom:1px solid #e2e8f0;text-align:left}
@media (max-width:980px){ .hero .wrapper{grid-template-columns:1fr} .grid-3,.cat-grid{grid-template-columns:1fr 1fr;width:100%;margin:0} .services-section h2{font-size:clamp(22px,3.5vw,38px)} }
@media (max-width:640px){
  .grid-3,.cat-grid{grid-template-columns:1fr}
  .card.service{padding:20px 16px}
  .service-icon{width:60px;height:60px}
  .card.service h3{font-size:18px}
  .services-section{border-radius:10px;margin:10px 0}
  .other-solutions-wrap{margin-top:28px}
  .cta-banner{padding:24px 0}
  .cta-text{padding:20px 16px}
  .stats-section{padding:32px 0}
  .stat-card{padding:20px 14px}
}
@media (max-width:400px){
  .wrapper{padding:0 10px}
  .services-grid{gap:12px}
  .service-card{padding:16px 12px;min-height:auto}
  .services-section{margin:8px 0}
  .page-hero-title{font-size:clamp(18px,6vw,32px)}
  .dark-banner p{font-size:13px}
  .cta-text h2{font-size:20px}
  .stat-num{font-size:26px}
}

/* Mobile-only nav extras (Nosotros / Ayuda dropdowns in hamburger) */
.nav-mobile-extras{display:none}
@media(max-width:768px){
  .nav-mobile-extras{display:flex;flex-direction:column;width:100%;border-top:1px solid rgba(255,255,255,0.07);margin-top:6px;padding-top:6px}
  .nav-mobile-extras .nav-dropdown{width:100%}
  .nav-mobile-extras .nav-dropdown-toggle{width:100%;text-align:left;padding:11px 14px;display:block;color:#cbd5e1;border-radius:8px;font-size:inherit}
  .nav-mobile-extras .nav-dropdown-menu{position:static;box-shadow:none;background:rgba(255,255,255,0.04);border-radius:8px;margin:4px 0 4px 12px;padding:0;min-width:unset;display:none}
  .nav-mobile-extras .nav-dropdown-menu.open{display:block}
}

/* Responsive section utility - replaces inline width:80% on page sections */
.section-80{width:80%;margin-left:auto;margin-right:auto}
@media(max-width:768px){.section-80{width:96%}}
@media(max-width:480px){.section-80{width:100%}}

/* Responsive table wrapper for client dashboard */
.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%}
@media(max-width:640px){
  .table th,.table td{padding:8px 6px;font-size:13px}
  .site-footer .wrapper{padding:20px 10px}
}

/* Hamburger button and mobile nav styles */
.hamburger{display:none;background:none;border:none;padding:8px;margin-left:8px;align-items:center;justify-content:center;cursor:pointer}
.hamburger .hamburger-box{display:inline-block;width:28px;height:20px;position:relative}
.hamburger .hamburger-inner{position:absolute;top:50%;left:0;right:0;height:2px;background:#cbd5e1;transform:translateY(-50%);transition:all .25s ease}
.hamburger .hamburger-inner::before,.hamburger .hamburger-inner::after{content:'';position:absolute;left:0;right:0;height:2px;background:#cbd5e1;transition:all .25s ease}
.hamburger .hamburger-inner::before{top:-8px}
.hamburger .hamburger-inner::after{top:8px}
.hamburger[aria-expanded="true"] .hamburger-inner{background:transparent}
.hamburger[aria-expanded="true"] .hamburger-inner::before{transform:translateY(8px) rotate(45deg)}
.hamburger[aria-expanded="true"] .hamburger-inner::after{transform:translateY(-8px) rotate(-45deg)}

@media (max-width:768px){
  .hamburger{display:inline-flex}
  .header-inner{gap:8px;flex-wrap:nowrap}
  .brand a strong{font-size:36px !important}
  .brand a small{font-size:15px !important}
	.nav{
		display:none;
		position:absolute;
		left:0;right:0;
		top:100%;
		background:linear-gradient(180deg,#0b1326,#0e1a38);
		padding:12px 18px;
		flex-direction:column;
		align-items:flex-start;
		gap:4px;
		border-top:1px solid rgba(255,255,255,0.06);
		z-index:1500;
		width:100%;
		box-shadow:0 8px 20px rgba(0,0,0,0.3);
	}
	.nav.open{display:flex}
	.nav a{display:block;padding:11px 14px;width:100%;margin:0;color:#cbd5e1;border-radius:8px}
	.nav a.active,.nav a:hover{color:#fff;background:rgba(255,255,255,0.06)}
	.nav-right{display:none}
	/* touch-friendly dropdowns inside mobile nav */
	.nav-dropdown{width:100%}
	.nav-dropdown-toggle{width:100%;text-align:left;padding:11px 14px;display:block;color:#cbd5e1;border-radius:8px}
	.nav-dropdown-menu{position:static;box-shadow:none;background:rgba(255,255,255,0.04);border-radius:8px;margin:4px 0 4px 12px;padding:0;min-width:unset;display:none}
	.nav-dropdown-menu.open{display:block}
}

/* Hero title matching nav item style + entrance animation */
.page-hero-title{color:#ffffff;font-weight:800;font-size:clamp(22px,4.5vw,48px);line-height:1.1;margin:0 0 -5px}
.page-hero-title.hero-accent{color:#0b3a5a}

/* Hero intro block — dark card used on inner pages */
.hero-intro{width:80%;margin:24px auto 0}
.hero-intro-inner{background:transparent;border-radius:20px;padding:clamp(32px,5vw,56px) clamp(24px,5vw,72px);text-align:center;position:relative;overflow:hidden}
.hero-intro-inner:before{display:none}
.hero-intro-sub{font-size:clamp(14px,1.8vw,18px);color:rgba(255,255,255,0.82);line-height:1.7;max-width:720px;margin-left:auto;margin-right:auto}
.hero-intro-sub.hero-accent{color:#0b3a5a}
@media(max-width:768px){.hero-intro{width:96%}.hero-intro-inner{padding:28px 20px}}
@media(max-width:480px){.hero-intro{width:100%;margin:12px 0 0}.hero-intro-inner{padding:22px 14px}}
/* Dark/transparent promo banner under hero */
.dark-banner{background:transparent;color:#fff;padding:8px 0;margin-top:6px}
.dark-banner .wrapper{max-width:1200px;margin:0 auto;text-align:center}
.dark-banner p{margin:0;font-size:18px;color:#ffffff;font-weight:700;margin-top:0;text-shadow:0 6px 20px rgba(2,6,23,0.45);background:transparent;padding:0;border-radius:0}
@media (max-width:640px){.dark-banner p{font-size:15px;padding:0 8px;margin-top:-6px}}
@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}100%{opacity:1;transform:translateY(0)}}

/* Reveal on scroll utility */
.reveal-on-scroll{opacity:0;transform:translateY(12px);transition:opacity .6s ease,transform .6s ease}
.reveal-on-scroll.visible{opacity:1;transform:translateY(0)}

/* Floating WhatsApp button - pill left */
.whatsapp-float{position:fixed;left:20px;bottom:28px;z-index:99999}
.whatsapp-float a{display:inline-flex;align-items:center;gap:10px;padding:12px 20px 12px 14px;border-radius:999px;background:#1dae57;color:#fff;text-decoration:none;font-family:'Poppins',sans-serif;font-weight:700;font-size:15px;box-shadow:0 6px 24px rgba(0,0,0,0.22);transition:transform .18s ease,box-shadow .18s ease,background .18s ease;white-space:nowrap}
.whatsapp-float a:hover{background:#17963f;transform:translateY(-3px);box-shadow:0 12px 32px rgba(0,0,0,0.28)}
.whatsapp-float a svg{width:26px;height:26px;flex-shrink:0}
.whatsapp-float a::before{display:none}
@keyframes whatsapp-pulse{0%{box-shadow:0 0 0 0 rgba(29,174,87,0.4)}70%{box-shadow:0 0 0 14px rgba(29,174,87,0)}100%{box-shadow:0 0 0 0 rgba(29,174,87,0)}}
@media(max-width:640px){.whatsapp-float{left:12px;bottom:16px}.whatsapp-float a{font-size:13px;padding:10px 16px 10px 12px;gap:8px}.whatsapp-float a svg{width:22px;height:22px}}

/* IP page styles */
.ip-page .ip-container{width:100%;max-width:980px;margin:24px auto;padding:0 12px}
.ip-page .info-panel{background:#0f172a11;border-radius:12px;padding:20px;color:var(--muted);line-height:1.7;border:1px solid rgba(2,6,23,0.04)}
.ip-page .info-panel p{margin:0 0 8px;text-align:justify;text-justify:inter-word}
/* separate info and ip panels for visual breathing room */
.ip-page .info-panel{margin-bottom:18px}
/* IP panel visuals to match site cards */
.ip-page .ip-panel{
  background:var(--card-bg, rgba(11,18,38,0.86));
  border-radius:12px;
  padding:22px;
  text-align:center;
  box-shadow:0 10px 30px rgba(2,6,23,0.45);
  max-width:720px;
  margin:0 auto;
}
.ip-page .ip-panel .ip-display{font-size:clamp(26px,5.6vw,56px);font-weight:800;color:var(--fg,#ffffff);padding:12px 0}
.ip-page .ip-panel .ip-label{color:var(--muted,#94a3b8);font-size:14px;margin-bottom:8px}
.ip-page .ip-panel .ip-actions{margin-top:14px;display:flex;align-items:center;justify-content:center;gap:12px}
.ip-page .ip-panel .ip-actions .btn{padding:10px 16px;border-radius:8px;font-weight:700}
@media (max-width:640px){
  .ip-page .ip-display{font-size:22px;padding:10px 8px}
  .ip-page .ip-panel{padding:16px}
  .ip-page .ip-container{margin:12px auto}
  .ip-page .page-hero-title{text-align:center}
}

/* Increase spacing between the page title and the IP block */
.ip-page .page-hero-title{margin-bottom:28px}

/* Desarrollos banner with dark overlay to improve white text contrast */
.desarrollos-banner{max-width:400px;width:100%;margin:0 auto;border-radius:0;overflow:visible;position:relative;height:400px}
.desarrollos-banner__bg{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;transform:translateZ(0);border-radius:0}
.desarrollos-banner__overlay{position:absolute;inset:0;background:transparent;pointer-events:none;border-radius:0}
@media(max-width:900px){.desarrollos-banner{max-width:360px;height:360px}}
@media(max-width:480px){.desarrollos-banner{max-width:320px;height:320px}}

/* General subtitle used in hero and pages to match diseños */
.hero-subtitle{color:var(--muted);max-width:880px;margin:12px auto 0;font-family:inherit}
@media (max-width:640px){.hero-subtitle{max-width:100%;padding:0 12px}}
