
:root {
  --black: #0d2140;
  --surface: #102848;
  --surface2: #163354;
  --surface3: #1d3e62;
  --white: #f0f8ff;
  --gray: #90b8d8;
  --gray2: #b8d4e8;
  --accent: #00c8f0;
  --accent2: #00aed4;
  --gold: #FFD60A;
  --green: #00f5a0;
  --red: #ff4d6d;
  --purple: #7b2ff7;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;font-size:16px;background:#0d2140;}
body{
  font-family:-apple-system,'Helvetica Neue',Helvetica,Arial,sans-serif;
  background:#0d2140;color:#f0f8ff;
  overflow-x:hidden;min-height:100vh;
}

/* ─── NAV ─── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  height:58px;
  background:rgba(13,33,64,0.88);
  backdrop-filter:saturate(180%) blur(20px);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
  border-bottom:1px solid rgba(255,255,255,0.07);
  display:grid;grid-template-columns:170px minmax(0,1fr) 48px;
  align-items:center;
  padding:0 22px;
}
.nav-logo{
  position:static;transform:none;justify-self:start;z-index:3;
  display:flex;align-items:center;justify-content:flex-start;
  width:54px;height:54px;text-decoration:none;cursor:pointer;
}
.nav-logo img{width:48px;height:48px;object-fit:contain;display:block;}
.nav-links{
  display:flex;align-items:center;justify-content:center;gap:0;list-style:none;
  position:static;left:auto;top:auto;transform:none;
  height:58px;width:100%;max-width:980px;justify-self:center;
}
.nav-links > li{position:relative;}
.nav-links > li > a, .nav-links > li > span{
  color:rgba(232,244,253,0.72);text-decoration:none;
  font-size:15.6px;font-weight:400;letter-spacing:0.005em;
  padding:0 10px;height:58px;display:flex;align-items:center;
  cursor:pointer;transition:color .2s;white-space:nowrap;
}
.nav-links > li > a:hover,
.nav-links > li > span:hover,
.nav-links > li > a.active{color:var(--white);}
.nav-links > li > a.nav-cta{color:var(--accent);}
/* dropdown */
.dropdown{
  position:absolute;top:58px;left:50%;transform:translateX(-50%);
  background:rgba(16,40,72,0.98);
  backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:14px;padding:8px 0;min-width:220px;
  opacity:0;pointer-events:none;
  transition:opacity .2s,transform .2s;
  transform:translateX(-50%) translateY(-6px);
}
.nav-links > li:hover .dropdown{
  opacity:1;pointer-events:all;
  transform:translateX(-50%) translateY(0);
}
.dropdown a{
  display:block;padding:11px 20px;font-size:15px;
  color:rgba(232,244,253,0.82);text-decoration:none;
  transition:color .15s,background .15s;
}
.dropdown a:hover{color:var(--white);background:rgba(255,255,255,0.05);}
.dropdown-arrow::after{content:'⌄';font-size:11px;margin-left:4px;opacity:0.6;}
.nav-hamburger{
  position:static;right:auto;top:auto;transform:none;justify-self:end;
  display:none;background:none;border:none;color:var(--white);
  font-size:22px;cursor:pointer;padding:4px;
}

@media(max-width:1180px){
  .nav-links > li > a, .nav-links > li > span{font-size:14.5px;padding:0 6px;}
  .nav-links > li > a, .nav-links > li > span{font-size:13.5px;padding:0 5px;}
  .nav-logo img{width:44px;height:44px;}
}

/* mobile menu */
.mobile-menu{
  display:none;position:fixed;top:58px;left:0;right:0;bottom:0;
  background:rgba(13,33,64,0.97);backdrop-filter:blur(20px);
  z-index:190;padding:24px;overflow-y:auto;
  flex-direction:column;gap:4px;
}
.mobile-menu.open{display:flex;}
.mobile-menu a{
  color:var(--white);text-decoration:none;font-size:18px;font-weight:300;
  padding:14px 0;border-bottom:1px solid rgba(255,255,255,0.06);
  display:block;
}
.mobile-menu .m-section{
  font-size:11px;color:var(--gray);letter-spacing:.1em;text-transform:uppercase;
  padding:20px 0 8px;font-weight:500;
}

/* ─── PAGE SYSTEM ─── */
.page{display:none;padding-top:58px;min-height:100vh;}
.page.active{display:block;}

/* ─── SHARED COMPONENTS ─── */
.eyebrow{
  font-size:12px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--accent);font-weight:500;margin-bottom:12px;display:block;
}
.eyebrow-gold{color:var(--gold);}
.eyebrow-green{color:var(--green);}

.section-hero{
  min-height:100vh;display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  text-align:center;padding:80px 24px 60px;
  position:relative;overflow:hidden;
}

.section-hero h1{
  font-size:clamp(38px,7vw,88px);font-weight:200;
  letter-spacing:-0.03em;line-height:1.04;color:var(--white);
  max-width:900px;
}
.section-hero h1 em{
  font-style:normal;
  background:linear-gradient(135deg,#00b4d8 0%,#0096c7 60%,#005f8a 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.section-hero p.lead{
  margin-top:20px;font-size:clamp(16px,2.2vw,20px);
  font-weight:300;color:#a8c4dc;max-width:560px;line-height:1.55;
}
.hero-glow{
  position:absolute;border-radius:50%;filter:blur(80px);
  pointer-events:none;opacity:.12;
}

.btn-primary{
  background:var(--accent);color:#fff;padding:14px 26px;
  border-radius:980px;text-decoration:none;font-size:15px;font-weight:400;
  display:inline-block;transition:background .2s,transform .15s;border:none;cursor:pointer;
}
.btn-primary:hover{background:var(--accent2);transform:scale(1.02);}
.btn-ghost{
  color:#00c8f0;padding:13px 28px;border-radius:980px;
  text-decoration:none;font-size:clamp(14px,1.5vw,16px);font-weight:400;
  border:1.5px solid rgba(0,200,240,.55);display:inline-flex;
  align-items:center;gap:6px;cursor:pointer;background:transparent;
  transition:all .25s;letter-spacing:-.01em;
}
.btn-ghost:hover{
  background:rgba(0,200,240,.12);
  border-color:#00c8f0;
  transform:scale(1.02);
  box-shadow:0 4px 18px rgba(0,200,240,.2);
}
.btn-wa{
  background:#00c896;color:#fff;padding:14px 26px;
  border-radius:980px;text-decoration:none;font-size:15px;font-weight:400;
  display:inline-flex;align-items:center;gap:8px;
  transition:opacity .2s,transform .15s;border:none;cursor:pointer;
}
.btn-wa:hover{opacity:.9;transform:scale(1.02);}
.action-row{
  display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:36px;
}

.container{max-width:1440px;margin:0 auto;padding:0 48px;}
.section{padding:90px 48px;}
.section-sm{padding:60px 48px;}

.section-header{text-align:center;margin-bottom:56px;}
.section-header h2{
  font-size:clamp(26px,4vw,52px);font-weight:200;
  letter-spacing:-0.025em;line-height:1.08;color:var(--white);
}
.section-header p{
  margin-top:14px;font-size:17px;color:#8ab0cc;font-weight:300;
  max-width:500px;margin-left:auto;margin-right:auto;line-height:1.6;
}

/* CARDS */
.card{
  background:var(--surface2);border-radius:20px;padding:36px 32px;
  position:relative;overflow:hidden;transition:transform .3s,background .3s;
  border:1px solid rgba(0,200,240,0.14);
}
.card:hover{transform:translateY(-3px);background:#1d3e62;}
.card-icon{font-size:34px;margin-bottom:20px;display:block;}
.card-tag{
  font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--accent);font-weight:500;margin-bottom:8px;display:block;
}
.card h3{
  font-size:clamp(20px,2.5vw,28px);font-weight:300;
  letter-spacing:-0.02em;color:var(--white);margin-bottom:10px;
}
.card p{font-size:14px;color:#8ab0cc;line-height:1.65;font-weight:300;}
.card-link{
  display:inline-flex;align-items:center;gap:6px;
  margin-top:18px;font-size:13px;font-weight:500;letter-spacing:.02em;
  color:#00c8f0;
  background:transparent;
  border:1.5px solid rgba(0,200,240,.45);
  border-radius:980px;
  padding:9px 20px;
  cursor:pointer;
  text-decoration:none;
  transition:background .22s, color .22s, border-color .22s, transform .18s, box-shadow .22s;
}
.card-link:hover{
  background:#00c8f0;
  color:#0d2140;
  border-color:#00c8f0;
  transform:translateY(-2px);
  box-shadow:0 6px 22px rgba(0,200,240,.28);
}
.card-link::after{content:'→'; margin-left:2px;}
.card-glow{
  position:absolute;border-radius:50%;filter:blur(60px);
  opacity:.14;pointer-events:none;
}

/* BENTO GRID */
.bento{display:grid;grid-template-columns:repeat(12,1fr);gap:14px;}
.b-7{grid-column:span 7;} .b-5{grid-column:span 5;}
.b-4{grid-column:span 4;} .b-6{grid-column:span 6;}
.b-8{grid-column:span 8;} .b-12{grid-column:span 12;}

/* PILLS ROW */
.pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px;justify-content:center;}
.pill{
  padding:8px 18px;border-radius:980px;
  border:1px solid rgba(0,200,240,.2);
  font-size:13px;color:#b8d4e8;font-weight:400;
  background:rgba(255,255,255,.03);transition:all .2s;
}
.pill:hover{border-color:rgba(255,255,255,.3);color:var(--white);}
.pill-gold{border-color:rgba(255,214,10,.3);color:var(--gold);background:rgba(255,214,10,.05);}
.pill-green{border-color:rgba(0,245,160,.3);color:var(--green);background:rgba(0,245,160,.05);}
.pill-blue{border-color:rgba(0,180,216,.3);color:var(--accent);background:rgba(0,180,216,.06);}

/* DIVIDER */
.divider{border:none;border-top:1px solid rgba(0,200,240,.1);margin:0;}

/* STATS BAR */
.stats-bar{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 18% 28%, rgba(0,200,240,.18) 0%, transparent 28%),
    radial-gradient(circle at 82% 18%, rgba(0,245,160,.10) 0%, transparent 26%),
    linear-gradient(135deg,#091827 0%,#102848 52%,#0b1d36 100%);
  border-top:1px solid rgba(0,200,240,.15);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.stats-bar::before{
  content:'';
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(90deg, rgba(0,200,240,.08) 1px, transparent 1px),
    linear-gradient(0deg, rgba(0,200,240,.06) 1px, transparent 1px),
    radial-gradient(circle, rgba(255,255,255,.28) 1px, transparent 2px);
  background-size:96px 96px,96px 96px,34px 34px;
  opacity:.24;
  animation:communityGridMove 28s linear infinite;
  pointer-events:none;
}
.stats-bar::after{
  content:'';
  position:absolute;
  inset:-20%;
  background:
    radial-gradient(circle at 28% 55%, rgba(0,200,240,.30) 0 2px, transparent 3px),
    radial-gradient(circle at 42% 38%, rgba(255,255,255,.45) 0 2px, transparent 3px),
    radial-gradient(circle at 58% 62%, rgba(0,245,160,.35) 0 2px, transparent 3px),
    radial-gradient(circle at 72% 42%, rgba(0,200,240,.28) 0 2px, transparent 3px),
    linear-gradient(35deg, transparent 0 42%, rgba(0,200,240,.10) 42.2% 42.8%, transparent 43%),
    linear-gradient(145deg, transparent 0 47%, rgba(0,245,160,.08) 47.2% 47.8%, transparent 48%);
  opacity:.55;
  filter:blur(.15px);
  animation:communityFloat 18s ease-in-out infinite alternate;
  pointer-events:none;
}
.stats-bar > *{position:relative;z-index:2;}
.stats-inner{
  max-width:960px;margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);
  border-left:1px solid rgba(255,255,255,.06);
}
.stat-item{
  padding:52px 36px;text-align:center;
  border-right:1px solid rgba(255,255,255,.06);
}
.stat-num{
  font-size:clamp(44px,6vw,72px);font-weight:100;
  letter-spacing:-0.04em;color:var(--white);display:block;line-height:1;
}
.stat-lbl{font-size:13px;color:#8ab0cc;margin-top:8px;font-weight:300;}


@keyframes communityGridMove{
  from{background-position:0 0,0 0,0 0;}
  to{background-position:96px 96px,96px 96px,34px 34px;}
}
@keyframes communityFloat{
  from{transform:translate3d(-1.5%, -1%, 0) scale(1);}
  to{transform:translate3d(1.5%, 1%, 0) scale(1.035);}
}

/* FEATURE ROW */
.feature-row{
  display:grid;grid-template-columns:1fr 1fr;gap:48px;
  align-items:center;max-width:1000px;margin:0 auto;
}
.feature-row.reverse{direction:rtl;}
.feature-row.reverse > *{direction:ltr;}
.feature-text .eyebrow{margin-bottom:12px;}
.feature-text h2{
  font-size:clamp(28px,3.5vw,46px);font-weight:200;
  letter-spacing:-0.025em;line-height:1.08;margin-bottom:16px;
}
.feature-text p{font-size:16px;color:var(--gray);line-height:1.7;font-weight:300;margin-bottom:20px;}
.feature-visual{
  background:var(--surface2);border-radius:24px;
  padding:48px;display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(255,255,255,.06);min-height:300px;
  font-size:80px;position:relative;overflow:hidden;
}

/* CHECKLIST */
.checklist{list-style:none;display:flex;flex-direction:column;gap:12px;}
.checklist li{
  display:flex;align-items:flex-start;gap:10px;
  font-size:15px;color:var(--gray2);line-height:1.5;
}
.checklist li::before{
  content:'✓';color:var(--green);font-weight:600;
  flex-shrink:0;margin-top:1px;
}

/* VERTICAL GRID */
.vertical-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:16px;
}
.vertical-card{
  position:relative;border-radius:16px;overflow:hidden;
  height:200px;cursor:pointer;display:block;text-decoration:none;
  transition:transform .3s ease, box-shadow .3s ease;
  background:linear-gradient(135deg, #163354 0%, #0d2140 100%);
}
.vertical-card:nth-child(1){background:linear-gradient(135deg,#1a3a5c,#0d2140);}
.vertical-card:nth-child(2){background:linear-gradient(135deg,#1a4030,#0d2140);}
.vertical-card:nth-child(3){background:linear-gradient(135deg,#2a2a1a,#0d2140);}
.vertical-card:nth-child(4){background:linear-gradient(135deg,#1a2a4a,#0d2140);}
.vertical-card:nth-child(5){background:linear-gradient(135deg,#2a1a3a,#0d2140);}
.vertical-card:nth-child(6){background:linear-gradient(135deg,#1a3a3a,#0d2140);}
.vertical-card:nth-child(7){background:linear-gradient(135deg,#3a1a1a,#0d2140);}
.vertical-card:nth-child(8){background:linear-gradient(135deg,#1a3050,#0d2140);}
.vertical-card:nth-child(9){background:linear-gradient(135deg,#2a3a1a,#0d2140);}
.vertical-card:nth-child(10){background:linear-gradient(135deg,#1a2a3a,#0d2140);}
.vertical-card:nth-child(11){background:linear-gradient(135deg,#162540,#0d2140);}
.vertical-card:hover{
  transform:translateY(-6px);
  box-shadow:0 20px 40px rgba(0,200,240,.2);
}
.vertical-card img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s ease, filter .3s ease;
  filter:brightness(.75) saturate(1.1);
}
.vertical-card:hover img{transform:scale(1.06);filter:brightness(.45) saturate(1.2);}
.vertical-card-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top, rgba(6,11,20,.85) 0%, rgba(6,11,20,.1) 55%, transparent 100%);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:20px;
}
.vertical-card-overlay span{
  font-size:11px;color:var(--accent);letter-spacing:.1em;
  text-transform:uppercase;font-weight:500;margin-bottom:6px;display:block;
}
.vertical-card h4{
  font-size:16px;font-weight:400;color:var(--white);
  line-height:1.2;letter-spacing:-0.01em;
}
/* Hacer que "Gobierno" (el 11vo) ocupe el espacio de 2 columnas para balancear */
.vertical-card.span2{ grid-column: span 2; }

/* CONTACT FORM */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-group{display:flex;flex-direction:column;gap:8px;}
.form-group.full{grid-column:span 2;}
.form-group label{font-size:12px;color:#b8d4e8;font-weight:400;letter-spacing:.04em;text-transform:uppercase;}
.form-group input, .form-group textarea, .form-group select{
  background:var(--surface2);border:1px solid rgba(0,200,240,.15);
  border-radius:10px;padding:14px 16px;color:var(--white);
  font-size:15px;font-family:inherit;outline:none;
  transition:border-color .2s;
}
.form-group input:focus, .form-group textarea:focus, .form-group select:focus{
  border-color:var(--accent);
}
.form-group textarea{resize:vertical;min-height:120px;}
.form-group select option{background:#1c1c1e;}
.form-success{
  background:rgba(0,245,160,.08);border:1px solid rgba(0,245,160,.25);
  border-radius:14px;padding:24px;text-align:center;display:none;
}
.form-success.show{display:block;}
.form-success p{color:var(--green);font-size:16px;font-weight:300;}

/* ACCORDION */
.accordion{display:flex;flex-direction:column;gap:2px;}
.acc-item{
  background:var(--surface2);border-radius:14px;overflow:hidden;
  border:1px solid rgba(255,255,255,.06);
}
.acc-header{
  padding:20px 24px;display:flex;justify-content:space-between;align-items:center;
  cursor:pointer;transition:background .2s;
}
.acc-header:hover{background:rgba(255,255,255,.03);}
.acc-header h4{font-size:16px;font-weight:400;color:var(--white);}
.acc-arrow{color:var(--gray);font-size:20px;transition:transform .3s;flex-shrink:0;}
.acc-item.open .acc-arrow{transform:rotate(45deg);}
.acc-body{
  max-height:0;overflow:hidden;transition:max-height .4s ease;
  font-size:14px;color:var(--gray);line-height:1.7;font-weight:300;
}
.acc-body-inner{padding:0 24px 20px;}

/* TABLE */
.price-table{width:100%;border-collapse:collapse;}
.price-table th{
  text-align:left;padding:14px 20px;font-size:12px;
  letter-spacing:.06em;text-transform:uppercase;color:var(--gray);font-weight:500;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.price-table td{
  padding:8px 12px;font-size:14px;color:var(--gray2);
  border-bottom:1px solid rgba(255,255,255,.04);font-weight:300;
}
.price-table tr:hover td{background:rgba(255,255,255,.02);color:var(--white);}
.price-table td:first-child{color:var(--white);font-weight:400;}

/* TIMELINE */
.timeline{display:flex;flex-direction:column;gap:0;max-width:600px;margin:0 auto;}
.tl-item{display:flex;gap:24px;padding-bottom:36px;position:relative;}
.tl-item:not(:last-child)::before{
  content:'';position:absolute;left:18px;top:38px;bottom:0;
  width:1px;background:rgba(255,255,255,.08);
}
.tl-dot{
  width:36px;height:36px;border-radius:50%;background:var(--accent);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;font-size:14px;
}
.tl-content h4{font-size:16px;font-weight:400;margin-bottom:6px;}
.tl-content p{font-size:14px;color:var(--gray);line-height:1.6;font-weight:300;}
.tl-year{font-size:11px;color:var(--accent);letter-spacing:.06em;margin-bottom:4px;font-weight:500;}

/* FOOTER */
footer{
  border-top:1px solid rgba(0,200,240,.12);
  padding:60px 0 32px;
}
.footer-grid{
  max-width:1160px;margin:0 auto;padding:0 24px;
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;
}
.f-brand{font-size:22px;font-weight:200;color:var(--white);margin-bottom:12px;}
.f-desc{font-size:13px;color:#90b8d8;line-height:1.75;font-weight:300;}
.f-title{font-size:12px;color:var(--white);font-weight:500;margin-bottom:16px;letter-spacing:.02em;}
.f-links{list-style:none;display:flex;flex-direction:column;gap:10px;}
.f-links a{font-size:13px;color:var(--gray);text-decoration:none;font-weight:300;cursor:pointer;}
.f-links a:hover{color:var(--white);}
.footer-bottom{
  max-width:1160px;margin:0 auto;padding:24px 24px 0;
  border-top:1px solid rgba(0,200,240,.1);margin-top:58px;
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:12px;
}
.footer-bottom p{font-size:12px;color:var(--gray);font-weight:300;}
.social-row{display:flex;gap:16px;}
.social-row a{font-size:13px;color:var(--gray);text-decoration:none;}
.social-row a:hover{color:var(--white);}

/* CTA BAND */
.cta-band{
  padding:100px 24px;text-align:center;
  background:radial-gradient(ellipse 70% 55% at 50% 100%,rgba(0,200,240,.30) 0%,transparent 68%);
}
.cta-band h2{
  font-size:clamp(32px,5vw,64px);font-weight:200;
  letter-spacing:-0.025em;max-width:700px;margin:0 auto 20px;line-height:1.06;
}
.cta-band p{
  font-size:18px;color:var(--gray);font-weight:300;
  max-width:480px;margin:0 auto 36px;line-height:1.6;
}

/* AWARD BAND */
.award-band{
  background:linear-gradient(135deg,#163560 0%,#102848 100%);
  border-top:1px solid rgba(0,200,240,.18);
  border-bottom:1px solid rgba(0,200,240,.18);
  padding:60px 24px;text-align:center;
}
.award-band h2{
  font-size:clamp(26px,4vw,44px);font-weight:200;
  letter-spacing:-0.02em;max-width:680px;margin:0 auto 14px;
}
.award-band p{font-size:16px;color:var(--gray);max-width:500px;margin:0 auto;line-height:1.6;font-weight:300;}

/* PAGE TRANSITION */
.page{animation:pageFade .35s ease;}
@keyframes pageFade{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:none;}}

/* REVEAL */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .65s ease,transform .65s ease;}
.reveal.vis{opacity:1;transform:none;}

/* ─── RESPONSIVE ─── */
/* ═══════════════════════════════════════════
   RESPONSIVE — Mobile first, todos los tamaños
═══════════════════════════════════════════ */

/* ── TABLET (≤1024px) ── */
@media(max-width:1024px){
  .container{max-width:100%;padding:0 32px;}
  .section{padding:72px 32px;}
  .section-sm{padding:48px 32px;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px;}
  .vertical-grid{grid-template-columns:repeat(3,1fr);}
  .vertical-card.span2{grid-column:span 3;}
}

/* ── MOBILE GRANDE / TABLET PEQUEÑA (≤900px) ── */
@media(max-width:900px){
  /* Nav */
  .nav-links{display:none;}
  .nav-hamburger{display:flex;}

  /* Bento grid → todo full width */
  .b-7,.b-5,.b-4,.b-6,.b-8,.b-12{grid-column:span 12;}

  /* Stats */
  .stats-inner{grid-template-columns:1fr 1fr;}
  .stat-item:last-child{grid-column:span 2;border-right:none;}

  /* Feature rows */
  .feature-row{grid-template-columns:1fr;gap:32px;}
  .feature-row.reverse{direction:ltr;}
  .feature-visual{min-height:220px;font-size:60px;}

  /* Forms */
  .form-grid{grid-template-columns:1fr;}
  .form-group.full{grid-column:span 1;}

  /* Footer */
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px;}

  /* Verticals */
  .vertical-grid{grid-template-columns:repeat(2,1fr);}
  .vertical-card.span2{grid-column:span 2;}
  .vertical-card{height:160px;}

  /* Spacing */
  .container{padding:0 20px;}
  .section{padding:64px 20px;}
  .section-sm{padding:40px 20px;}

  /* Contact grid */
  #contact-grid{grid-template-columns:1fr !important;}

  /* Card img height */
  .card-img-wrap{height:140px;}

  /* Hero showcase wrap */
  .hero-product-showcase{gap:10px;}
  .showcase-item{width:110px;padding:12px;}
  .showcase-item img{width:60px;height:45px;}
  .showcase-item p{font-size:10px;}
}

/* ── MOBILE (≤640px) ── */
@media(max-width:640px){
  /* Nav */
  .nav-logo span{font-size:15px;}

  /* Hero */
  .section-hero{padding:70px 16px 50px;}
  .section-hero h1{font-size:clamp(32px,10vw,52px);}
  .section-hero p.lead{font-size:15px;max-width:100%;}
  .action-row{flex-direction:column;align-items:center;gap:12px;}
  .action-row a, .action-row button{width:100%;max-width:320px;text-align:center;justify-content:center;}

  /* Hero showcase → 2 filas de 3-4 */
  .hero-product-showcase{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:8px;
    width:100%;
    margin-top:28px;
  }
  .showcase-item{width:auto;padding:10px 6px;border-radius:12px;}
  .showcase-item img{width:100%;height:36px;object-fit:contain;}
  .showcase-item p{font-size:9px;margin-top:6px;}

  /* Bento cards */
  .card{padding:24px 20px;}
  .card h3{font-size:18px;}
  .card-img-wrap{height:130px;}

  /* Stats */
  .stats-inner{grid-template-columns:1fr;}
  .stat-item{border-right:none;padding:36px 24px;}
  .stat-item:last-child{grid-column:span 1;}
  .stat-num{font-size:52px;}

  /* Section headers */
  .section-header{margin-bottom:36px;}
  .section-header h2{font-size:clamp(24px,7vw,36px);}
  .section-header p{font-size:15px;}

  /* Verticals → 2 col */
  .vertical-grid{grid-template-columns:repeat(2,1fr);gap:10px;}
  .vertical-card{height:130px;}
  .vertical-card.span2{grid-column:span 2;}
  .vertical-card h4{font-size:13px;}
  .vertical-card-overlay span{font-size:9px;}
  .vertical-card-overlay{padding:14px;}

  /* Feature row */
  .feature-row{gap:24px;}
  .feature-text h2{font-size:clamp(22px,6vw,32px);}
  .feature-visual{min-height:180px;}

  /* Footer */
  .footer-grid{grid-template-columns:1fr;}
  .footer-bottom{flex-direction:column;text-align:center;gap:16px;}
  .social-row{justify-content:center;}

  /* CTA band */
  .cta-band{padding:64px 16px;}
  .cta-band h2{font-size:clamp(26px,8vw,40px);}
  .cta-band p{font-size:15px;}

  /* Pills */
  .pills{gap:8px;}
  .pill{padding:6px 14px;font-size:12px;}

  /* Award band */
  .award-band{padding:40px 16px;}
  .award-band h2{font-size:clamp(22px,6vw,32px);}

  /* Container */
  .container{padding:0 16px;}
  .section{padding:52px 16px;}
  .section-sm{padding:36px 16px;}

  /* Accordion */
  .acc-header h4{font-size:14px;}
  .acc-header{padding:16px 18px;}
  .acc-body-inner{padding:0 18px 16px;}

  /* Ship cards */
  .shipping-cards{gap:12px;}

  /* Checklist */
  .checklist li{font-size:14px;}

  /* Timeline */
  .tl-content h4{font-size:15px;}

  /* Buttons */
  .btn-primary,.btn-ghost,.btn-wa{
    padding:13px 22px;font-size:14px;
  }
}

/* ── MOBILE PEQUEÑO (≤390px) ── */
@media(max-width:390px){
  .hero-product-showcase{grid-template-columns:repeat(3,1fr);}
  .showcase-item p{display:none;}
  .vertical-card{height:110px;}
  .section-hero h1{font-size:clamp(28px,9vw,44px);}
  .card{padding:20px 16px;}
}

/* ── MONITOR GRANDE (≥1440px) ── */
/* ─────────────────────────────────────────────────────────
   HERO RESPONSIVO POR TAMAÑO DE PANTALLA
   Notebooks 13"-15.4"  → ancho típico 1280px–1440px
   Monitores 17"+        → ancho típico 1440px+
   ──────────────────────────────────────────────────────── */

/* ── PANTALLAS MENOS DE 16" (hasta 1366px) ── */
@media(min-width:641px) and (max-width:1366px){
  .section-hero{
    min-height:unset !important;
    height:100vh;
    padding-top:56px !important;
    padding-bottom:12px !important;
    justify-content:center;
    overflow:hidden;
    gap:0;
    box-sizing:border-box;
  }
  .section-hero h1{
    font-size:clamp(24px,3.5vw,42px) !important;
    margin-bottom:0;
    line-height:1.05;
  }
  .section-hero p.lead{
    font-size:clamp(12px,1.1vw,14px) !important;
    margin-top:8px !important;
    max-width:440px;
    line-height:1.4;
  }
  .action-row{margin-top:12px !important;gap:10px;}
  .hero-product-showcase{
    margin-top:12px !important;
    gap:8px;
  }
  .showcase-item{width:88px;padding:8px 5px;}
  .showcase-item img{width:52px;height:38px;}
  .showcase-item p{font-size:9px;margin-top:4px;}
  .hero-glow{opacity:.08;}
  .eyebrow{font-size:11px;margin-bottom:6px;}
}

@media(min-width:1440px){
  .container{max-width:1400px;padding:0 60px;}
  .section{padding:100px 60px;}
  .vertical-grid{grid-template-columns:repeat(4,1fr);}
  .vertical-card{height:220px;}
  .vertical-card h4{font-size:17px;}
  .card h3{font-size:clamp(22px,2vw,30px);}
}

/* ── MONITOR MUY GRANDE (≥1920px) ── */
@media(min-width:1920px){
  .container{max-width:1700px;padding:0 80px;}
  .section{padding:110px 80px;}
  .section-hero h1{font-size:100px;}
  .vertical-card{height:260px;}
}

/* ═══════════════════ PÁGINAS VERTICALES ═══════════════════ */
.v-hero{
  min-height:75vh;display:flex;align-items:flex-end;
  padding:80px 48px 72px;position:relative;
}
.v-hero-content{
  max-width:700px;position:relative;z-index:2;
}
.v-hero-content h1{
  font-size:clamp(36px,6vw,80px);font-weight:200;
  letter-spacing:-0.03em;line-height:1.06;color:#f0f8ff;margin:12px 0 18px;
}
.v-hero-content h1 em{
  font-style:normal;
  background:linear-gradient(135deg,#00c8f0 0%,#0096c7 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.v-hero-content p{
  font-size:clamp(15px,1.8vw,18px);color:#a8c4dc;font-weight:300;
  line-height:1.65;max-width:580px;margin-bottom:32px;
}
.v-content{
  padding-top:72px;padding-bottom:72px;
  display:flex;flex-direction:column;gap:80px;
}
.v-section{}
.v-section-inner{
  display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;
}
.v-section:nth-child(even) .v-section-inner{direction:rtl;}
.v-section:nth-child(even) .v-section-inner > *{direction:ltr;}
.v-section-img{border-radius:16px;overflow:hidden;aspect-ratio:4/3;}
.v-section-img img{
  width:100%;height:100%;object-fit:cover;
  filter:brightness(.9) saturate(1.1);
  transition:transform .5s ease;
}
.v-section-img:hover img{transform:scale(1.04);}
.v-section-text h3{
  font-size:clamp(22px,2.5vw,32px);font-weight:300;
  letter-spacing:-0.02em;color:#f0f8ff;margin-bottom:16px;line-height:1.15;
}
.v-section-text p{
  font-size:15px;color:#8ab0cc;line-height:1.75;font-weight:300;margin-bottom:20px;
}
.v-section-text-full{grid-column:span 2;}
.v-list{
  list-style:none;display:flex;flex-direction:column;gap:10px;
}
.v-list li{
  display:flex;align-items:flex-start;gap:12px;
  font-size:14px;color:#a8c4dc;line-height:1.5;font-weight:300;
}
.v-list li::before{
  content:"";width:6px;height:6px;border-radius:50%;
  background:#00c8f0;flex-shrink:0;margin-top:6px;
}
@media(max-width:900px){
  .v-hero{padding:80px 24px 56px;}
  .v-section-inner{grid-template-columns:1fr;gap:28px;}
  .v-section:nth-child(even) .v-section-inner{direction:ltr;}
  .v-content{gap:56px;padding-top:58px;padding-bottom:48px;}
  .v-section-text-full{grid-column:span 1;}
}
@media(max-width:640px){
  .v-hero{min-height:60vh;padding:70px 16px 48px;}
  .v-hero-content h1{font-size:clamp(30px,9vw,46px);}
  .v-content{gap:40px;padding-top:36px;padding-bottom:36px;}
}

/* ═══ AWARD PILL TOOLTIPS ═══ */
.award-pill-wrap{
  position:relative;display:inline-block;
}
.award-pill{
  cursor:pointer;
  transition:background .2s, color .2s, transform .2s;
}
.award-pill:hover{
  background:rgba(255,214,10,.25);
  transform:translateY(-2px);
}
.award-tip{
  display:none;
  position:fixed;
  width:300px;
  background:#0f1e35;
  border:1px solid rgba(255,214,10,.4);
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,.8);
  z-index:99999;
  animation:tipFade .2s ease;
}
.award-tip.active{display:block;}
.award-tip img{
  width:100%;height:170px;
  object-fit:cover;
  display:block;
  filter:brightness(.88) saturate(1.1);
}
.award-tip-body{padding:14px 16px 16px;}
.award-tip-body h4{
  font-size:13px;font-weight:600;
  color:#FFD60A;margin-bottom:7px;letter-spacing:.02em;
}
.award-tip-body p{
  font-size:12px;color:#a8c4dc;line-height:1.55;font-weight:300;margin:0;
}
@keyframes tipFade{
  from{opacity:0;transform:translateY(-6px);}
  to{opacity:1;transform:translateY(0);}
}
@media(max-width:640px){
  .award-tip{width:260px;}
  .award-tip img{height:140px;}
}
/* ═══ AWARD SLIDESHOW ═══ */
.award-slideshow{
  position:relative;
  min-height:520px;
  overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(circle at 50% 0%, rgba(0,200,240,.18) 0%, transparent 42%),
    radial-gradient(circle at 15% 80%, rgba(255,214,10,.10) 0%, transparent 35%),
    linear-gradient(135deg,#071120 0%,#0d2140 52%,#102848 100%);
}
.award-slides{
  position:absolute;
  inset:0;
  display:block;
  z-index:0;
}
.award-slide{
  position:absolute;
  inset:0;
  opacity:0;
  background-size:cover;
  background-repeat:no-repeat;
  background-position:center center;
  transition:opacity 1.2s ease;
  filter:brightness(.48) saturate(1.05);
}
.award-slide.active{opacity:1;}
.award-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(
    to bottom,
    rgba(8,18,36,.66) 0%,
    rgba(8,18,36,.34) 40%,
    rgba(8,18,36,.74) 100%
  );
}
.award-content{
  position:relative;z-index:2;
  text-align:center;
  padding:72px 24px;
  max-width:800px;
}
.award-content h2{
  font-size:clamp(30px,5vw,60px);
  font-weight:200;letter-spacing:-0.025em;
  color:#f0f8ff;margin:14px 0 18px;line-height:1.08;
}
.award-content p{
  font-size:clamp(15px,1.8vw,18px);
  color:#a8c4dc;font-weight:300;line-height:1.65;
  max-width:580px;margin:0 auto;
}
.award-dots{display:none;}
.award-dot{display:none;}
.award-dot.active{display:none;}
@media(max-width:640px){
  .award-slideshow{min-height:400px;}
  .award-content{padding:56px 16px;}
}
/* ─── SOCIAL CARDS ─── */
.social-section{
  position:relative;
  overflow:hidden;
  padding:60px 0;
  border-top:1px solid rgba(0,200,240,.08);
  border-bottom:1px solid rgba(0,200,240,.08);
  background:
    radial-gradient(circle at 25% 40%, rgba(131,58,180,.12) 0%, transparent 28%),
    radial-gradient(circle at 76% 35%, rgba(255,0,0,.08) 0%, transparent 24%),
    radial-gradient(circle at 50% 95%, rgba(0,200,240,.16) 0%, transparent 34%),
    linear-gradient(135deg,#0b1d36 0%,#102848 100%);
}
.social-section::before{
  content:'';
  position:absolute;
  inset:0;
  background-image:
    radial-gradient(circle at 12% 24%, rgba(0,200,240,.38) 0 2px, transparent 3px),
    radial-gradient(circle at 30% 76%, rgba(255,255,255,.28) 0 2px, transparent 3px),
    radial-gradient(circle at 55% 28%, rgba(0,245,160,.28) 0 2px, transparent 3px),
    radial-gradient(circle at 78% 72%, rgba(0,200,240,.36) 0 2px, transparent 3px),
    linear-gradient(25deg, transparent 0 44%, rgba(0,200,240,.10) 44.2% 44.8%, transparent 45%),
    linear-gradient(150deg, transparent 0 52%, rgba(255,255,255,.06) 52.2% 52.8%, transparent 53%);
  opacity:.48;
  animation:communityFloat 20s ease-in-out infinite alternate;
  pointer-events:none;
}
.social-section .container{position:relative;z-index:2;}
.social-cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  max-width:900px;
  margin:0 auto;
}
.social-card{
  display:flex;align-items:center;gap:18px;
  padding:24px 28px;border-radius:18px;
  text-decoration:none;
  border:1px solid rgba(255,255,255,.08);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  position:relative;overflow:hidden;
}
.social-card::before{
  content:'';position:absolute;inset:0;opacity:0;
  transition:opacity .25s ease;border-radius:18px;
}
.social-card:hover{transform:translateY(-5px);}
.social-card:hover::before{opacity:1;}

/* Instagram — gradiente morado/rosa */
.social-ig{background:rgba(131,58,180,.08);}
.social-ig::before{background:linear-gradient(135deg,rgba(131,58,180,.15),rgba(253,29,29,.1),rgba(252,176,69,.08));}
.social-ig:hover{box-shadow:0 16px 40px rgba(131,58,180,.25);border-color:rgba(131,58,180,.35);}
.social-ig .social-card-icon{color:#e1306c;}

/* TikTok — negro con cyan/rojo */
.social-tk{background:rgba(0,200,240,.06);}
.social-tk::before{background:linear-gradient(135deg,rgba(0,0,0,.2),rgba(0,200,240,.1));}
.social-tk:hover{box-shadow:0 16px 40px rgba(0,200,240,.2);border-color:rgba(0,200,240,.3);}
.social-tk .social-card-icon{color:#f0f8ff;}

/* YouTube — rojo */
.social-yt{background:rgba(255,0,0,.06);}
.social-yt::before{background:linear-gradient(135deg,rgba(255,0,0,.12),rgba(180,0,0,.06));}
.social-yt:hover{box-shadow:0 16px 40px rgba(255,0,0,.2);border-color:rgba(255,80,80,.3);}
.social-yt .social-card-icon{color:#ff4444;}

.social-card-icon{
  width:52px;height:52px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.06);flex-shrink:0;
  border:1px solid rgba(255,255,255,.1);
}
.social-card-icon svg{width:24px;height:24px;}
.social-card-info{
  display:flex;flex-direction:column;gap:3px;flex:1;
}
.social-card-name{
  font-size:15px;font-weight:500;color:#f0f8ff;letter-spacing:-.01em;
}
.social-card-handle{
  font-size:12px;color:#7a9cbd;font-weight:400;
}
.social-card-count{
  font-size:13px;color:#00c8f0;font-weight:500;margin-top:4px;
}
.social-card-arrow{
  font-size:18px;color:#3a6a8a;
  transition:transform .2s, color .2s;
  flex-shrink:0;
}
.social-card:hover .social-card-arrow{
  transform:translateX(4px);color:#00c8f0;
}
@media(max-width:900px){
  .social-cards{grid-template-columns:1fr;max-width:480px;}
}
@media(max-width:640px){
  .social-section{padding:40px 0;}
  .social-card{padding:18px 20px;gap:14px;}
  .social-card-icon{width:44px;height:44px;}
  .social-card-icon svg{width:20px;height:20px;}
}
/* ─── PRODUCT IMAGES ─── */
.prod-img{
  width:100%;height:100%;object-fit:contain;
  border-radius:12px;filter:drop-shadow(0 8px 32px rgba(0,180,216,0.18));
  transition:transform .4s ease;max-height:260px;
}
.feature-visual:hover .prod-img{transform:scale(1.04);}
.prod-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:12px;
  width:100%;
}
.prod-grid-img{
  width:100%;aspect-ratio:4/3;object-fit:contain;
  border-radius:10px;background:rgba(0,180,216,.04);padding:8px;
  filter:drop-shadow(0 4px 16px rgba(0,180,216,0.12));
  transition:transform .3s;
}
.prod-grid-img:hover{transform:scale(1.05);}
.card-img-wrap{
  width:100%;height:160px;display:flex;align-items:center;
  justify-content:center;margin-bottom:16px;
  overflow:hidden;border-radius:12px;
  background:transparent;position:relative;
}
.card-img-wrap img{
  width:100%;height:100%;object-fit:contain;
  border-radius:0;padding:10px;
  transition:transform .4s ease;
}
.card:hover .card-img-wrap img{transform:scale(1.06);}
.card-img-wrap::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to top, rgba(10,22,40,.25) 0%, transparent 55%);
  pointer-events:none;
}
.hero-product-showcase{
  display:flex;gap:16px;align-items:center;justify-content:center;
  margin-top:40px;flex-wrap:wrap;
}
.showcase-item{
  background:rgba(0,200,240,.09);border:1px solid rgba(0,200,240,.22);
  border-radius:16px;padding:15px;width:132px;text-align:center;
  transition:all .3s;
}
.showcase-item:hover{background:rgba(0,180,216,.1);transform:translateY(-4px);}
.showcase-item img{width:78px;height:58px;object-fit:contain;margin-bottom:8px;}
.showcase-item p{font-size:11px;color:#b8d4e8;font-weight:400;}


/* ─── SEO CONTENT BLOCKS — visibles, livianos y alineados a la estética Boaz ─── */
.seo-section{padding-top:70px;padding-bottom:70px;}
.seo-panel{
  background:linear-gradient(135deg,rgba(22,51,84,.92),rgba(13,33,64,.96));
  border:1px solid rgba(0,200,240,.16);
  border-radius:26px;
  padding:42px;
  box-shadow:0 18px 55px rgba(0,0,0,.22);
  position:relative;overflow:hidden;
}
.seo-panel::before{
  content:'';position:absolute;right:-120px;top:-120px;width:260px;height:260px;
  border-radius:50%;background:rgba(0,200,240,.14);filter:blur(50px);pointer-events:none;
}
.seo-panel h2{
  font-size:clamp(24px,3.2vw,42px);font-weight:200;letter-spacing:-.025em;
  line-height:1.12;margin-bottom:18px;color:var(--white);max-width:900px;
}
.seo-panel p{font-size:15px;color:#a8c4dc;line-height:1.75;font-weight:300;max-width:980px;margin-bottom:14px;}
.seo-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:32px;margin-top:22px;align-items:start;}
.seo-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:10px 18px;}
.seo-list li{font-size:14px;color:#b8d4e8;line-height:1.45;display:flex;gap:10px;align-items:flex-start;}
.seo-list li::before{content:'✓';color:var(--green);font-weight:700;flex-shrink:0;}
.seo-related{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-start;align-content:flex-start;}
.seo-related a{padding:9px 16px;border-radius:980px;border:1px solid rgba(0,200,240,.28);color:#00c8f0;text-decoration:none;font-size:13px;background:rgba(0,200,240,.06);transition:all .22s;}
.seo-related a:hover{background:rgba(0,200,240,.15);border-color:#00c8f0;color:#f0f8ff;transform:translateY(-2px);}
.seo-note{margin-top:22px;font-size:13px!important;color:#90b8d8!important;border-top:1px solid rgba(255,255,255,.07);padding-top:18px;}
@media(max-width:900px){.seo-panel{padding:30px 24px}.seo-grid{grid-template-columns:1fr;gap:24px}.seo-list{grid-template-columns:1fr}.seo-section{padding-top:50px;padding-bottom:50px}}
@media(max-width:640px){.seo-panel{padding:24px 18px;border-radius:20px}.seo-panel p{font-size:14px}.seo-related a{font-size:12px;padding:8px 13px}}


/* Multipágina SEO: cada archivo contiene una sola página activa. */


/* ─── PÁGINAS DE PRODUCTO / CAJONES HERO ─── */
.showcase-item[role="button"]{cursor:pointer;}
.showcase-item[role="button"]:focus{outline:2px solid rgba(0,200,240,.65);outline-offset:4px;}
.solution-brand-page{background:linear-gradient(180deg,#071120 0%,#0a1628 48%,#071120 100%);min-height:100vh;}
.solution-brand-hero{padding:150px 24px 80px;position:relative;overflow:hidden;border-bottom:1px solid rgba(0,200,240,.14);}
.solution-brand-hero:before{content:"";position:absolute;inset:-30%;background:radial-gradient(circle at 50% 20%,rgba(0,200,240,.18),transparent 34%),radial-gradient(circle at 85% 20%,rgba(0,255,180,.08),transparent 28%);pointer-events:none;}
.solution-brand-hero-inner{position:relative;z-index:1;text-align:center;max-width:920px;}
.solution-brand-hero h1{font-size:clamp(38px,6vw,78px);line-height:1.05;font-weight:200;letter-spacing:-.035em;color:#f0f8ff;margin:14px auto 20px;}
.solution-brand-hero p{font-size:clamp(16px,1.8vw,20px);line-height:1.65;color:#a8c4dc;font-weight:300;max-width:760px;margin:0 auto;}
.brand-tech-section{padding:80px 24px 40px;display:flex;flex-direction:column;gap:28px;}
.brand-tech-card{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(260px,.75fr);gap:34px;align-items:center;background:rgba(8,22,40,.82);border:1px solid rgba(0,200,240,.18);border-radius:28px;padding:34px;box-shadow:0 30px 90px rgba(0,0,0,.22);overflow:hidden;position:relative;}
.brand-tech-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,200,240,.08),transparent 45%);pointer-events:none;}
.brand-tech-copy{position:relative;z-index:1;}
.brand-tech-copy h2{font-size:clamp(26px,3.4vw,44px);line-height:1.13;font-weight:250;letter-spacing:-.03em;color:#f0f8ff;margin:10px 0 16px;}
.brand-tech-copy p{font-size:16px;line-height:1.72;color:#a8c4dc;max-width:760px;margin:0 0 24px;}
.tech-grid-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;}
.tech-grid-list span{border:1px solid rgba(0,200,240,.14);background:rgba(0,200,240,.055);border-radius:999px;padding:10px 14px;color:#cbe5f7;font-size:13px;line-height:1.25;}
.brand-logo-panel{position:relative;z-index:1;min-height:230px;border-radius:24px;border:1px solid rgba(255,255,255,.08);background:radial-gradient(circle at 50% 45%,rgba(255,255,255,.10),rgba(255,255,255,.025) 52%,rgba(0,0,0,.16));display:flex;align-items:center;justify-content:center;text-align:center;font-weight:900;letter-spacing:-.04em;font-size:clamp(42px,5vw,76px);box-shadow:inset 0 0 60px rgba(0,0,0,.24);}
.hikvision-logo{color:#e31d1a;}
.hikvision-logo span{color:#dce5ec;}
.dahua-logo{color:#fff;background:radial-gradient(circle at 50% 45%,rgba(225,30,45,.32),rgba(70,8,16,.26) 58%,rgba(0,0,0,.16));}
.axis-logo{color:#fff;background:linear-gradient(135deg,rgba(160,0,0,.34),rgba(0,0,0,.26));font-family:Arial Black,Arial,sans-serif;letter-spacing:.02em;}
.floating-price-cta{position:fixed;right:24px;bottom:24px;z-index:999;background:linear-gradient(135deg,#00d49f,#00c8f0);color:#02111f;text-decoration:none;font-weight:800;font-size:13px;letter-spacing:.04em;border-radius:999px;padding:16px 22px;box-shadow:0 18px 45px rgba(0,200,240,.28);border:1px solid rgba(255,255,255,.28);transition:transform .25s,box-shadow .25s;}
.floating-price-cta:hover{transform:translateY(-3px);box-shadow:0 24px 60px rgba(0,200,240,.38);}
@media(max-width:900px){.brand-tech-card{grid-template-columns:1fr;padding:26px;}.brand-logo-panel{min-height:160px;}.tech-grid-list{grid-template-columns:1fr;}.floating-price-cta{left:16px;right:16px;text-align:center;bottom:16px;font-size:12px;}}




/* Floating CTAs originales Boaz */
.float-asesor{
  position:fixed;
  right:24px;
  bottom:24px;
  z-index:10000;
  opacity:0;
  pointer-events:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:48px;
  padding:14px 22px;
  border-radius:999px;
  background:linear-gradient(135deg,#25D366,#15a45a);
  color:#fff;
  text-decoration:none;
  font-weight:700;
  font-size:14px;
  letter-spacing:-.01em;
  box-shadow:0 14px 44px rgba(37,211,102,.45);
  transition:opacity .25s ease, transform .25s ease, box-shadow .25s ease;
}
.float-asesor:hover{transform:translateY(-3px) scale(1.04);box-shadow:0 18px 56px rgba(37,211,102,.55);}
.float-asesor.is-visible{opacity:1;pointer-events:all;}
.btn-subir{
  position:fixed;
  right:24px;
  bottom:88px;
  z-index:10000;
  width:46px;
  height:46px;
  padding:0;
  border-radius:50%;
  border:1px solid rgba(0,200,240,.35);
  background:#162540;
  color:#00c8f0;
  font-weight:800;
  font-size:22px;
  line-height:1;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 12px 32px rgba(0,0,0,.28);
  opacity:0;
  pointer-events:none;
  transform:translateY(8px);
  transition:opacity .25s ease, transform .25s ease, background .25s ease, color .25s ease, border-color .25s ease;
}
.btn-subir.is-visible{opacity:1;pointer-events:all;transform:translateY(0);}
.btn-subir:hover{background:#00c8f0;color:#0d2140;transform:translateY(-3px);}
.btn-home{
  position:fixed;
  right:24px;
  bottom:144px;
  z-index:10000;
  min-height:34px;
  padding:8px 14px;
  border-radius:999px;
  border:1px solid rgba(0,200,240,.30);
  background:#162540;
  color:#a8c4dc;
  font-weight:700;
  font-size:12px;
  letter-spacing:.01em;
  cursor:pointer;
  text-decoration:none;
  display:none;
  align-items:center;
  justify-content:center;
  gap:8px;
  box-shadow:0 12px 32px rgba(0,0,0,.28);
  opacity:0;
  pointer-events:none;
  transform:translateY(8px);
  transition:opacity .25s ease, transform .25s ease, background .25s ease, color .25s ease, border-color .25s ease;
}
body:not([data-page="home"]) .btn-home{display:inline-flex;}
.btn-home.is-visible{opacity:1;pointer-events:all;transform:translateY(0);}
.btn-home:hover{background:#00c8f0;color:#0d2140;transform:translateY(-3px);}
body[data-page="camaras-ip"] .floating-price-cta{right:24px;bottom:24px;}
body[data-page="camaras-ip"] .float-asesor{bottom:88px;}
body[data-page="camaras-ip"] .btn-subir{bottom:152px;}
body[data-page="camaras-ip"] .btn-home{bottom:208px;}
@media(max-width:640px){
  .float-asesor{left:16px;right:16px;bottom:18px;text-align:center;font-size:13px;padding:13px 18px;}
  .btn-subir{right:16px;bottom:78px;width:44px;height:44px;font-size:20px;}
  .btn-home{right:16px;bottom:132px;}
  body[data-page="camaras-ip"] .floating-price-cta{left:16px;right:16px;bottom:16px;text-align:center;}
  body[data-page="camaras-ip"] .float-asesor{left:16px;right:16px;bottom:78px;}
  body[data-page="camaras-ip"] .btn-subir{right:16px;bottom:138px;}
  body[data-page="camaras-ip"] .btn-home{right:16px;bottom:192px;}
}

/* Hikvision product ecosystem block - Cámaras IP */
.hikvision-product-split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
  align-items:stretch;
  margin:28px 0 28px;
}
.hikvision-tech-detail,
.hikvision-product-photo{
  border:1px solid rgba(0,200,240,.16);
  background:linear-gradient(135deg,rgba(8,22,42,.92),rgba(8,32,58,.72));
  border-radius:24px;
  overflow:hidden;
  box-shadow:0 18px 60px rgba(0,0,0,.22);
}
.hikvision-tech-detail{
  padding:28px;
}
.hikvision-tech-detail h3{
  color:#f0f8ff;
  font-size:clamp(22px,2.2vw,32px);
  font-weight:300;
  line-height:1.15;
  margin:8px 0 18px;
  letter-spacing:-.025em;
}
.hikvision-tech-detail ul{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
  list-style:none;
  margin:0;
  padding:0;
}
.hikvision-tech-detail li{
  position:relative;
  padding-left:20px;
  color:#b8d3e6;
  line-height:1.55;
  font-size:15px;
}
.hikvision-tech-detail li::before{
  content:"";
  position:absolute;
  left:0;
  top:.72em;
  width:7px;
  height:7px;
  border-radius:50%;
  background:#00c8f0;
  box-shadow:0 0 16px rgba(0,200,240,.7);
}
.hikvision-product-photo{
  min-height:420px;
  display:flex;
}
.hikvision-product-photo img{
  width:100%;
  height:100%;
  min-height:420px;
  object-fit:cover;
  display:block;
}
@media(max-width:900px){
  .hikvision-product-split{grid-template-columns:1fr;}
  .hikvision-product-photo{min-height:280px;}
  .hikvision-product-photo img{min-height:280px;}
}


/* Hikvision ecosystem 2026 - visible block in Cámaras IP */
.hikvision-ecosystem-2026{
  padding:46px 24px 18px;
}
.hikvision-ecosystem-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:26px;
  align-items:stretch;
  background:rgba(8,22,40,.86);
  border:1px solid rgba(0,200,240,.18);
  border-radius:30px;
  padding:28px;
  box-shadow:0 30px 90px rgba(0,0,0,.24);
  overflow:hidden;
  position:relative;
}
.hikvision-ecosystem-grid:before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 78% 20%,rgba(0,200,240,.16),transparent 32%),linear-gradient(135deg,rgba(0,200,240,.06),transparent 48%);
  pointer-events:none;
}
.hikvision-ecosystem-copy,
.hikvision-ecosystem-photo{
  position:relative;
  z-index:1;
}
.hikvision-ecosystem-copy{
  padding:10px 4px 10px 6px;
}
.hikvision-ecosystem-copy h2{
  color:#f0f8ff;
  font-size:clamp(26px,3vw,44px);
  font-weight:250;
  letter-spacing:-.03em;
  line-height:1.1;
  margin:10px 0 16px;
}
.hikvision-ecosystem-copy p{
  color:#a8c4dc;
  line-height:1.65;
  font-size:16px;
  margin:0 0 22px;
}
.hikvision-tech-columns{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
  list-style:none;
  padding:0;
  margin:0;
}
.hikvision-tech-columns li{
  position:relative;
  color:#c9def0;
  line-height:1.5;
  font-size:15px;
  padding-left:20px;
}
.hikvision-tech-columns li:before{
  content:"";
  position:absolute;
  left:0;
  top:.7em;
  width:7px;
  height:7px;
  border-radius:50%;
  background:#00c8f0;
  box-shadow:0 0 16px rgba(0,200,240,.75);
}
.hikvision-ecosystem-photo{
  border-radius:24px;
  overflow:hidden;
  border:1px solid rgba(0,200,240,.22);
  background:#061225;
  min-height:520px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.hikvision-ecosystem-photo img{
  width:100%;
  height:100%;
  min-height:520px;
  object-fit:cover;
  display:block;
}
@media(max-width:980px){
  .hikvision-ecosystem-grid{grid-template-columns:1fr;padding:22px;}
  .hikvision-ecosystem-photo{min-height:300px;}
  .hikvision-ecosystem-photo img{min-height:300px;}
}


/* Logos reales para página Cámaras IP */
.brand-logo-img-panel{
  background:rgba(255,255,255,.96) !important;
  border:1px solid rgba(0,200,240,.22);
  padding:34px 28px;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:220px;
}
.brand-logo-img{
  display:block;
  max-width:100%;
  max-height:150px;
  width:auto;
  height:auto;
  object-fit:contain;
}
.hikvision-logo-img{max-height:120px;}
.dahua-logo-img{max-height:170px;}
@media(max-width:760px){
  .brand-logo-img-panel{min-height:160px;padding:24px 18px;}
  .brand-logo-img{max-height:110px;}
  .dahua-logo-img{max-height:125px;}
}


/* v22: placas de marca blancas, logos PNG limpios sin fondo interno */
.brand-logo-img-panel{
  background:radial-gradient(circle at 50% 45%,#ffffff 0%,#f2f5f7 54%,#dfe6eb 100%) !important;
  border:1px solid rgba(220,235,245,.9) !important;
  box-shadow:inset 0 0 50px rgba(0,0,0,.08),0 20px 50px rgba(0,0,0,.18) !important;
  overflow:hidden;
}
.brand-logo-img{
  display:block;
  width:auto;
  max-width:82%;
  max-height:132px;
  object-fit:contain;
  background:transparent !important;
}
.hikvision-logo-img{max-height:126px;max-width:86%;}
.dahua-logo-img{max-height:140px;max-width:82%;}
.axis-logo-img{max-height:150px;max-width:82%;}
@media(max-width:900px){.brand-logo-img{max-width:86%;max-height:110px;}}


/* Ajustes v28: páginas de productos sin botón asesor flotante */
body[data-page="camaras-ip"] .float-asesor,
body[data-page="redes"] .float-asesor{display:none !important;}
body[data-page="camaras-ip"] .floating-price-cta,
body[data-page="redes"] .float-precios-redes{right:24px;bottom:24px;}
body[data-page="camaras-ip"] .btn-subir,
body[data-page="redes"] .btn-subir{bottom:88px;}
body[data-page="camaras-ip"] .btn-home,
body[data-page="redes"] .btn-home{bottom:144px;}
@media(max-width:640px){
  body[data-page="camaras-ip"] .floating-price-cta,
  body[data-page="redes"] .float-precios-redes{left:16px;right:16px;bottom:16px;text-align:center;}
  body[data-page="camaras-ip"] .btn-subir,
  body[data-page="redes"] .btn-subir{right:16px;bottom:78px;}
  body[data-page="camaras-ip"] .btn-home,
  body[data-page="redes"] .btn-home{right:16px;bottom:132px;}
}


/* COMMUNITY IMAGE CAROUSEL */
.community-carousel{
  position:absolute;
  inset:0;
  z-index:0;
  overflow:hidden;
  pointer-events:none;
}
.community-carousel span{
  position:absolute;
  inset:-4%;
  background-size:cover;
  background-position:center center;
  opacity:0;
  transform:scale(1.04);
  filter:brightness(.42) saturate(1.16) contrast(1.08);
  animation:communityImageFade 24s infinite;
}
.community-carousel span:nth-child(2){animation-delay:6s;}
.community-carousel span:nth-child(3){animation-delay:12s;}
.community-carousel span:nth-child(4){animation-delay:18s;}
.stats-bar::before,.social-section::before{z-index:1;}
.stats-bar::after{z-index:1;}
.stats-bar > *:not(.community-carousel){position:relative;z-index:3;}
.social-section .container{position:relative;z-index:3;}
.social-section::after{
  content:'';
  position:absolute;
  inset:0;
  z-index:2;
  pointer-events:none;
  background:linear-gradient(180deg,rgba(8,18,34,.48),rgba(8,18,34,.68));
}
@keyframes communityImageFade{
  0%{opacity:0;transform:scale(1.04) translateX(0);}
  7%{opacity:.72;}
  25%{opacity:.72;transform:scale(1.09) translateX(-1.4%);}
  32%{opacity:0;}
  100%{opacity:0;}
}


/* === SOPORTE TECNICO BOAZ === */
.support-page{background:#071120;color:#eaf6ff;min-height:100vh;}
.support-hero{position:relative;padding:130px 0 74px;background:linear-gradient(180deg,rgba(5,14,28,.58),rgba(5,14,28,.82)),url('soporte-tecnico-bg.webp') center center/cover no-repeat;overflow:hidden;border-bottom:1px solid rgba(0,200,240,.16);}
.support-hero:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.032) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.032) 1px,transparent 1px);background-size:52px 52px;mask-image:linear-gradient(to bottom,rgba(0,0,0,.75),transparent);}
.support-hero-inner{position:relative;z-index:1;max-width:1050px;text-align:center;}
.support-hero h1{font-size:clamp(34px,5.2vw,68px);font-weight:200;letter-spacing:-.04em;line-height:1.04;margin:14px auto 20px;color:#f1f8ff;max-width:980px;}
.support-hero p{max-width:760px;margin:0 auto;color:#b6cce0;font-size:clamp(16px,1.6vw,19px);line-height:1.7;font-weight:300;}
.support-hero-pills{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:30px;}
.support-hero-pills span{border:1px solid rgba(0,200,240,.28);background:rgba(0,30,55,.48);border-radius:999px;padding:10px 16px;color:#ccecff;font-size:13px;}
.support-grid-section{display:grid;grid-template-columns:.92fr 1.08fr;gap:28px;padding:70px 24px;align-items:start;}
.support-copy-card,.support-form-card{background:linear-gradient(145deg,rgba(12,32,58,.86),rgba(5,18,34,.94));border:1px solid rgba(0,200,240,.22);box-shadow:0 24px 70px rgba(0,0,0,.28);border-radius:28px;padding:34px;}
.support-copy-card h2,.support-form-card h2{font-size:clamp(26px,3vw,42px);line-height:1.12;font-weight:250;letter-spacing:-.035em;margin:10px 0 18px;color:#f0f8ff;}
.support-copy-card p,.support-form-intro,.support-note{color:#b6cce0;line-height:1.75;font-weight:300;}
.support-service-list{display:grid;gap:14px;margin-top:26px;}
.support-service-list div{border:1px solid rgba(0,200,240,.18);background:rgba(0,20,40,.48);border-radius:18px;padding:16px 18px;}
.support-service-list strong{display:block;color:#00c8f0;margin-bottom:6px;letter-spacing:.01em;}
.support-service-list span{display:block;color:#b9d0e4;line-height:1.55;font-size:14px;}
.support-form{display:grid;gap:16px;margin-top:20px;}
.support-form label{display:grid;gap:8px;color:#d9edff;font-size:14px;font-weight:500;}
.support-form input,.support-form select,.support-form textarea{width:100%;border:1px solid rgba(0,200,240,.23);background:rgba(3,14,28,.82);color:#f0f8ff;border-radius:14px;padding:14px 15px;font:inherit;outline:none;transition:border .2s,box-shadow .2s,background .2s;}
.support-form input:focus,.support-form select:focus,.support-form textarea:focus{border-color:#00c8f0;box-shadow:0 0 0 3px rgba(0,200,240,.12);background:rgba(4,20,38,.95);}
.support-form textarea{resize:vertical;min-height:130px;}
.form-row.two{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.conditional-panel{display:none;border:1px solid rgba(0,200,240,.2);border-radius:22px;background:rgba(0,22,42,.45);padding:18px;margin-top:4px;gap:16px;}
.conditional-panel.active{display:grid;}
.support-submit{border:0;border-radius:999px;padding:16px 22px;background:linear-gradient(135deg,#10d3ad,#00c8f0);color:#061525;font-weight:800;text-transform:uppercase;letter-spacing:.04em;cursor:pointer;box-shadow:0 18px 48px rgba(0,200,240,.22);}
.support-submit.secondary{background:linear-gradient(135deg,#00c8f0,#7be7ff);}
.support-note{font-size:13px;margin-top:18px;border-top:1px solid rgba(255,255,255,.08);padding-top:14px;}
@media(max-width:980px){.support-grid-section{grid-template-columns:1fr;padding:50px 18px}.form-row.two{grid-template-columns:1fr}.support-copy-card,.support-form-card{padding:24px}.support-hero{padding-top:112px}}

/* Ajustes v36: página control de acceso */
body[data-page="control-acceso"] .float-asesor{display:none !important;}
body[data-page="control-acceso"] .btn-subir{bottom:88px;}
body[data-page="control-acceso"] .btn-home{bottom:144px;}
@media(max-width:640px){body[data-page="control-acceso"] .btn-subir{right:16px;bottom:78px;}body[data-page="control-acceso"] .btn-home{right:16px;bottom:132px;}}

/* v40: menú centrado con logo Boaz fijo a la izquierda */
@media(max-width:760px){
  nav{height:58px;grid-template-columns:70px 1fr 48px;padding:0 16px;}
  .nav-links{display:none;}
  .nav-hamburger{display:flex;align-items:center;justify-content:center;}
  .mobile-menu{top:58px;}
  .nav-logo{width:50px;height:50px;}
  .nav-logo img{width:46px;height:46px;}
}


/* Hero hover carousel: cambia el fondo del inicio al pasar por cada cajón */
.hero-hover-bg{
  position:absolute;
  inset:0;
  z-index:2;
  pointer-events:none;
  opacity:0;
  background-color:#071120;
  /* La primera capa es el degradado; la segunda es la imagen del rubro.
     La imagen queda contenida completa, sin crop ni zoom. */
  background-size:100% 100%, contain;
  background-position:center center, center center;
  background-repeat:no-repeat, no-repeat;
  transition:opacity .75s ease, filter .75s ease;
  transform:none;
  filter:blur(0);
}
.hero-hover-bg.active{
  opacity:1;
  transform:none;
}
.hero-hover-bg.is-changing{
  opacity:.55;
  filter:blur(2px);
}
.hero-hover-bg:after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 50% 35%, rgba(0,200,240,.16), transparent 42%),
    linear-gradient(to bottom, rgba(7,17,32,.38) 0%, rgba(7,17,32,.52) 45%, rgba(7,17,32,.82) 100%);
}
.hero-product-showcase .showcase-item{cursor:pointer;}
.hero-product-showcase .showcase-item:hover{
  transform:translateY(-5px) scale(1.03);
  border-color:rgba(0,200,240,.55);
  box-shadow:0 18px 46px rgba(0,200,240,.18);
}
@media(max-width:760px){
  .hero-hover-bg{display:none;}
}

/* Oculta el copy central durante el hover sin mover el layout.
   No se contrae ni cambia márgenes: así el mouse no entra/sale en loop y no titila. */
.hero-main-copy{
  transition:opacity .45s ease, filter .45s ease;
  will-change:opacity, filter;
}
.section-hero.hero-product-hover-active .hero-main-copy{
  opacity:0 !important;
  filter:blur(4px);
  pointer-events:none;
}
.section-hero.hero-product-hover-active .action-row{
  opacity:0;
  pointer-events:none;
  transition:opacity .35s ease;
}
.section-hero.hero-product-hover-active .hero-product-showcase{
  transition:transform .35s ease;
}


/* v52: hovers con imágenes oficiales del usuario, entrada suave y contenida */
.hero-hover-bg{
  background-size:100% 100%, contain !important;
  background-position:center center, center center !important;
  background-repeat:no-repeat, no-repeat !important;
  transition:opacity .95s ease, filter .95s ease !important;
}
.hero-hover-bg.is-changing{opacity:.42 !important;filter:blur(3px) saturate(.9) !important;}
.section-hero.hero-product-hover-active .hero-main-copy,
.section-hero.hero-product-hover-active .action-row{visibility:hidden !important;opacity:0 !important;pointer-events:none !important;}


/* v53: hover más luminoso y sin oscurecer tanto las imágenes */
.hero-hover-bg{
  background-size:100% 100%, contain !important;
  background-position:center center, center center !important;
  background-repeat:no-repeat, no-repeat !important;
  transition:opacity 1.05s ease, filter 1.05s ease !important;
  filter:brightness(1.18) saturate(1.08) contrast(1.03) !important;
}
.hero-hover-bg.active{
  opacity:1 !important;
}
.hero-hover-bg.is-changing{
  opacity:.72 !important;
  filter:brightness(1.08) saturate(1.02) blur(1.5px) !important;
}
.hero-hover-bg:after{
  background:
    radial-gradient(circle at 50% 38%, rgba(0,200,240,.08), transparent 44%),
    linear-gradient(to bottom, rgba(7,17,32,.16) 0%, rgba(7,17,32,.22) 48%, rgba(7,17,32,.44) 100%) !important;
}
.section-hero.hero-product-hover-active .hero-main-copy,
.section-hero.hero-product-hover-active .action-row{
  visibility:hidden !important;
  opacity:0 !important;
  pointer-events:none !important;
}


/* v54: hovers finales sin overlay oscuro, más luminosos y con imágenes oficiales nuevas */
.hero-hover-bg{
  background-size:contain !important;
  background-position:center center !important;
  background-repeat:no-repeat !important;
  background-color:#02070f !important;
  opacity:0 !important;
  filter:brightness(1.08) saturate(1.08) contrast(1.02) !important;
  transition:opacity 1.05s ease, filter 1.05s ease !important;
}
.hero-hover-bg.active{
  opacity:1 !important;
}
.hero-hover-bg.is-changing{
  opacity:.86 !important;
  filter:brightness(1.02) saturate(1.03) contrast(1.01) blur(.8px) !important;
}
.hero-hover-bg::after{
  display:none !important;
  content:none !important;
  background:none !important;
}
.section-hero.hero-product-hover-active .hero-main-copy,
.section-hero.hero-product-hover-active .action-row{
  visibility:hidden !important;
  opacity:0 !important;
  pointer-events:none !important;
}


/* === V55 FIX DEFINITIVO BOTONES FLOTANTES EN SUBPÁGINAS === */
body[data-page="camaras-ip"] .btn-home,
body[data-page="redes"] .btn-home,
body[data-page="control-acceso"] .btn-home,
body[data-page="ups-energia"] .btn-home,
body[data-page="camaras-ip"] .btn-subir,
body[data-page="redes"] .btn-subir,
body[data-page="control-acceso"] .btn-subir,
body[data-page="ups-energia"] .btn-subir,
body[data-page="camaras-ip"] .float-asesor,
body[data-page="redes"] .float-asesor,
body[data-page="control-acceso"] .float-asesor,
body[data-page="ups-energia"] .float-asesor{
  position:fixed !important;
  right:28px !important;
  z-index:99999 !important;
  opacity:1 !important;
  pointer-events:auto !important;
  visibility:visible !important;
  transform:none !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  box-sizing:border-box !important;
  font-family:inherit !important;
}
body[data-page="camaras-ip"] .btn-home,
body[data-page="redes"] .btn-home,
body[data-page="control-acceso"] .btn-home,
body[data-page="ups-energia"] .btn-home{
  bottom:222px !important;
  background:rgba(8,22,40,.92) !important;
  border:1px solid rgba(0,200,240,.45) !important;
  color:#cfe7f5 !important;
  padding:12px 18px !important;
  border-radius:999px !important;
  text-decoration:none !important;
  font-weight:800 !important;
  box-shadow:0 12px 35px rgba(0,0,0,.22) !important;
}
body[data-page="camaras-ip"] .btn-subir,
body[data-page="redes"] .btn-subir,
body[data-page="control-acceso"] .btn-subir,
body[data-page="ups-energia"] .btn-subir{
  bottom:156px !important;
  width:54px !important;
  height:54px !important;
  border-radius:50% !important;
  background:rgba(8,22,40,.92) !important;
  border:1px solid rgba(0,200,240,.55) !important;
  color:#00c8f0 !important;
  font-size:26px !important;
  cursor:pointer !important;
  text-decoration:none !important;
}
body[data-page="camaras-ip"] .float-asesor,
body[data-page="redes"] .float-asesor,
body[data-page="control-acceso"] .float-asesor,
body[data-page="ups-energia"] .float-asesor{
  bottom:92px !important;
  background:linear-gradient(135deg,#00e0b8,#00b4d8) !important;
  color:#fff !important;
  border:none !important;
  border-radius:999px !important;
  padding:15px 26px !important;
  font-weight:900 !important;
  text-decoration:none !important;
  box-shadow:0 18px 60px rgba(0,224,184,.34) !important;
}
body[data-page="camaras-ip"] .floating-price-cta,
body[data-page="redes"] .float-precios-redes,
body[data-page="control-acceso"] .float-precios-redes,
body[data-page="ups-energia"] .float-precios-redes{
  position:fixed !important;
  right:28px !important;
  bottom:24px !important;
  z-index:99998 !important;
}
@media(max-width:900px){
  body[data-page="camaras-ip"] .btn-home,
  body[data-page="redes"] .btn-home,
  body[data-page="control-acceso"] .btn-home,
  body[data-page="ups-energia"] .btn-home{right:16px !important;bottom:214px !important;}
  body[data-page="camaras-ip"] .btn-subir,
  body[data-page="redes"] .btn-subir,
  body[data-page="control-acceso"] .btn-subir,
  body[data-page="ups-energia"] .btn-subir{right:16px !important;bottom:150px !important;width:50px !important;height:50px !important;}
  body[data-page="camaras-ip"] .float-asesor,
  body[data-page="redes"] .float-asesor,
  body[data-page="control-acceso"] .float-asesor,
  body[data-page="ups-energia"] .float-asesor{right:16px !important;bottom:86px !important;padding:14px 20px !important;}
  body[data-page="camaras-ip"] .floating-price-cta,
  body[data-page="redes"] .float-precios-redes,
  body[data-page="control-acceso"] .float-precios-redes,
  body[data-page="ups-energia"] .float-precios-redes{left:16px !important;right:16px !important;bottom:18px !important;text-align:center !important;}
}

/* === V56: hover con imágenes sobre fondo blanco + overlay oscuro restaurado === */
.hero-hover-bg{
  background-size:contain !important;
  background-position:center center !important;
  background-repeat:no-repeat !important;
  background-color:#ffffff !important;
  opacity:0 !important;
  filter:none !important;
  transition:opacity 1s ease, filter 1s ease !important;
}
.hero-hover-bg.active{
  opacity:1 !important;
}
.hero-hover-bg.is-changing{
  opacity:.68 !important;
  filter:blur(1.2px) saturate(.96) !important;
}
.hero-hover-bg::after{
  display:block !important;
  content:"" !important;
  position:absolute !important;
  inset:0 !important;
  pointer-events:none !important;
  background:
    radial-gradient(circle at 50% 35%, rgba(0,200,240,.12), transparent 44%),
    linear-gradient(to bottom, rgba(7,17,32,.30) 0%, rgba(7,17,32,.42) 46%, rgba(7,17,32,.72) 100%) !important;
}
.section-hero.hero-product-hover-active .hero-main-copy,
.section-hero.hero-product-hover-active .action-row{
  visibility:hidden !important;
  opacity:0 !important;
  pointer-events:none !important;
}


/* === V57: hovers actualizados con imágenes del usuario + fondo claro y overlay oscuro controlado === */
.hero-hover-bg{
  background-size:contain !important;
  background-position:center center !important;
  background-repeat:no-repeat !important;
  background-color:#f6f9ff !important;
  opacity:0 !important;
  filter:none !important;
  transition:opacity 1s ease, filter 1s ease !important;
}
.hero-hover-bg.active{opacity:1 !important;}
.hero-hover-bg.is-changing{opacity:.70 !important;filter:blur(1px) saturate(.98) !important;}
.hero-hover-bg::after{
  display:block !important;
  content:"" !important;
  position:absolute !important;
  inset:0 !important;
  pointer-events:none !important;
  background:
    radial-gradient(circle at 50% 35%, rgba(0,200,240,.10), transparent 44%),
    linear-gradient(to bottom, rgba(7,17,32,.28) 0%, rgba(7,17,32,.40) 48%, rgba(7,17,32,.68) 100%) !important;
}
.section-hero.hero-product-hover-active .hero-main-copy,
.section-hero.hero-product-hover-active .action-row{
  visibility:hidden !important;
  opacity:0 !important;
  pointer-events:none !important;
}
/* V57: botones flotantes visibles en páginas internas principales */
body[data-page="camaras-ip"] .btn-home, body[data-page="redes"] .btn-home, body[data-page="control-acceso"] .btn-home, body[data-page="ups-energia"] .btn-home,
body[data-page="camaras-ip"] .btn-subir, body[data-page="redes"] .btn-subir, body[data-page="control-acceso"] .btn-subir, body[data-page="ups-energia"] .btn-subir,
body[data-page="camaras-ip"] .float-asesor, body[data-page="redes"] .float-asesor, body[data-page="control-acceso"] .float-asesor, body[data-page="ups-energia"] .float-asesor{
  opacity:1 !important; visibility:visible !important; display:flex !important; pointer-events:auto !important; z-index:999999 !important;
}


/* === V58 FINAL: hovers reemplazados realmente + fondo claro + overlay oscuro controlado === */
.hero-hover-bg{
  position:absolute !important;
  inset:0 !important;
  z-index:1 !important;
  background-color:#edf5ff !important;
  background-size:contain !important;
  background-position:center center !important;
  background-repeat:no-repeat !important;
  opacity:0 !important;
  transform:scale(1) !important;
  transition:opacity .65s ease, filter .65s ease !important;
  filter:saturate(1.05) contrast(1.04) brightness(1.02) !important;
  pointer-events:none !important;
}
.hero-hover-bg.active{
  opacity:1 !important;
}
.hero-hover-bg.is-changing{
  opacity:.72 !important;
  filter:blur(1px) saturate(1.02) contrast(1.03) brightness(1.02) !important;
}
.hero-hover-bg::after{
  content:"" !important;
  position:absolute !important;
  inset:0 !important;
  background:linear-gradient(180deg, rgba(2,10,24,.32), rgba(2,10,24,.46)) !important;
  pointer-events:none !important;
}
.section-hero.hero-product-hover-active .hero-main-copy,
.section-hero.hero-product-hover-active .action-row{
  opacity:0 !important;
  visibility:hidden !important;
  pointer-events:none !important;
  transition:opacity .35s ease, visibility .35s ease !important;
}
.page-floats,
.float-asesor,
.btn-home,
.btn-subir{
  z-index:99999 !important;
}
.float-asesor{display:flex !important;visibility:visible !important;opacity:1 !important;}
.btn-home,.btn-subir{display:flex !important;visibility:visible !important;opacity:1 !important;}


/* === V59 FINAL: hovers actualizados con fondo gradiente completo === */
.hero-hover-bg{
  background-size:cover !important;
  background-position:center center !important;
  background-repeat:no-repeat !important;
  background-color:#eaf4ff !important;
  filter:saturate(1.06) contrast(1.03) brightness(1.02) !important;
}
.hero-hover-bg::after{
  background:linear-gradient(180deg, rgba(2,10,24,.35), rgba(2,10,24,.50)) !important;
}
.hero-hover-bg.active{opacity:1 !important;}
.hero-hover-bg.is-changing{opacity:.72 !important;filter:blur(1px) saturate(1.04) contrast(1.02) brightness(1.02) !important;}

/* === V60: hovers sin zoom - mantener proporción/tamaño original dentro del bloque === */
.hero-hover-bg{
  background-size:contain !important;
  background-position:center center !important;
  background-repeat:no-repeat !important;
  background-color:#eaf4ff !important;
  transform:none !important;
}
.hero-hover-bg.active{
  opacity:1 !important;
  transform:none !important;
}
.hero-hover-bg.is-changing{
  opacity:.72 !important;
  transform:none !important;
  filter:blur(.6px) saturate(1.04) contrast(1.02) brightness(1.02) !important;
}


/* === V62: hover de cajones sin imágenes de fondo ===
   Se elimina el cambio de imagen del hero al posicionarse sobre los cajones.
   Mantiene el fondo original del hero y deja visible el texto central. */
.hero-hover-bg,
.hero-hover-bg.active,
.hero-hover-bg.is-changing{
  display:none !important;
  opacity:0 !important;
  visibility:hidden !important;
  background-image:none !important;
}
.section-hero.hero-product-hover-active .hero-main-copy,
.section-hero.hero-product-hover-active .action-row{
  visibility:visible !important;
  opacity:1 !important;
  pointer-events:auto !important;
  transform:none !important;
}
.section-hero.hero-product-hover-active .hero-product-showcase{
  transform:none !important;
}


/* === V63 FINAL: hover exacto por cajón, sin crop, sin zoom y sin titileo === */
.section-hero{position:relative !important; overflow:hidden !important;}
#boazHeroHover.boaz-hero-hover{
  position:absolute !important;
  inset:0 !important;
  z-index:2 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  opacity:0 !important;
  visibility:hidden !important;
  pointer-events:none !important;
  background:linear-gradient(135deg,#f9d6f4 0%,#dbe8ff 54%,#cdefff 100%) !important;
  transition:opacity .55s ease, visibility .55s ease !important;
}
#boazHeroHover.boaz-hero-hover.active{
  opacity:1 !important;
  visibility:visible !important;
}
#boazHeroHover.boaz-hero-hover img{
  width:100% !important;
  height:100% !important;
  object-fit:contain !important;
  object-position:center center !important;
  display:block !important;
  transform:none !important;
  filter:none !important;
}
#boazHeroHover.boaz-hero-hover::after{display:none !important;content:none !important;}
.hero-hover-bg,.hero-hover-bg.active,.hero-hover-bg.is-changing{display:none !important;opacity:0 !important;visibility:hidden !important;background-image:none !important;}
.section-hero.hero-product-hover-active .hero-main-copy,
.section-hero.hero-product-hover-active .action-row{
  opacity:0 !important;
  visibility:hidden !important;
  pointer-events:none !important;
  transition:opacity .28s ease, visibility .28s ease !important;
}
.section-hero:not(.hero-product-hover-active) .hero-main-copy,
.section-hero:not(.hero-product-hover-active) .action-row{
  opacity:1 !important;
  visibility:visible !important;
}
.section-hero.hero-product-hover-active .hero-product-showcase,
.section-hero .hero-product-showcase{
  transform:none !important;
  position:relative !important;
  z-index:20 !important;
}
.section-hero > div[style*="z-index:10"]{z-index:15 !important;}
.section-hero .showcase-item{position:relative !important;z-index:25 !important;}


/* === V65: hover final sin recorte, fondo gradiente uniforme === */
#boazHeroHover.boaz-hero-hover{
  background:linear-gradient(135deg,#f9d6f4 0%,#dbe8ff 54%,#cdefff 100%) !important;
  opacity:0 !important;
  visibility:hidden !important;
}
#boazHeroHover.boaz-hero-hover.active{
  opacity:1 !important;
  visibility:visible !important;
}
#boazHeroHover.boaz-hero-hover img{
  width:100% !important;
  height:100% !important;
  object-fit:contain !important;
  object-position:center center !important;
  transform:none !important;
  filter:none !important;
}
#boazHeroHover.boaz-hero-hover::after{display:none !important;content:none !important;}
.section-hero.hero-product-hover-active .hero-eyebrow,
.section-hero.hero-product-hover-active .hero-title,
.section-hero.hero-product-hover-active .hero-main-copy,
.section-hero.hero-product-hover-active .action-row{
  opacity:0 !important;
  visibility:hidden !important;
  pointer-events:none !important;
}

/* === V66: cajones legibles sobre fondos claros del hover === */
.section-hero .hero-product-showcase .showcase-item{
  position:relative !important;
  overflow:hidden !important;
  background:rgba(5,22,42,.72) !important;
  border:1px solid rgba(0,200,240,.45) !important;
  box-shadow:0 12px 34px rgba(0,0,0,.32), inset 0 1px 0 rgba(255,255,255,.08) !important;
  backdrop-filter:blur(10px) saturate(1.15) !important;
  -webkit-backdrop-filter:blur(10px) saturate(1.15) !important;
}
.section-hero .hero-product-showcase .showcase-item::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:0;
  background:linear-gradient(to bottom, rgba(7,21,39,.88) 0%, rgba(8,26,48,.70) 58%, rgba(5,18,34,.92) 100%) !important;
  opacity:.92;
  pointer-events:none;
}
.section-hero .hero-product-showcase .showcase-item img,
.section-hero .hero-product-showcase .showcase-item p{
  position:relative !important;
  z-index:2 !important;
}
.section-hero .hero-product-showcase .showcase-item img{
  filter:drop-shadow(0 4px 9px rgba(0,0,0,.45)) !important;
}
.section-hero .hero-product-showcase .showcase-item p{
  color:#f0f8ff !important;
  font-weight:600 !important;
  text-shadow:0 2px 8px rgba(0,0,0,.82), 0 0 14px rgba(0,200,240,.24) !important;
}
.section-hero.hero-product-hover-active .hero-product-showcase .showcase-item{
  background:rgba(4,18,34,.78) !important;
  border-color:rgba(0,200,240,.55) !important;
}
.section-hero.hero-product-hover-active .hero-product-showcase .showcase-item:hover{
  background:rgba(6,28,52,.92) !important;
  border-color:rgba(0,220,255,.92) !important;
  box-shadow:0 16px 44px rgba(0,0,0,.42),0 0 0 1px rgba(0,220,255,.18),0 0 30px rgba(0,200,240,.22) !important;
}
.section-hero.hero-product-hover-active .hero-product-showcase .showcase-item:hover::before{
  background:linear-gradient(to bottom, rgba(3,16,31,.95) 0%, rgba(6,29,53,.82) 58%, rgba(3,13,26,.96) 100%) !important;
  opacity:.96;
}


/* === V67: cajones más claros y hover activado solo en zona central === */
.section-hero .hero-product-showcase .showcase-item{
  background:rgba(7,28,52,.46) !important;
  border-color:rgba(0,200,240,.40) !important;
  box-shadow:0 10px 28px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.10) !important;
  backdrop-filter:blur(8px) saturate(1.08) !important;
  -webkit-backdrop-filter:blur(8px) saturate(1.08) !important;
}
.section-hero .hero-product-showcase .showcase-item::before{
  background:linear-gradient(to bottom, rgba(7,21,39,.52) 0%, rgba(8,30,55,.38) 58%, rgba(5,18,34,.60) 100%) !important;
  opacity:.58 !important;
}
.section-hero .hero-product-showcase .showcase-item img{
  opacity:.96 !important;
  filter:drop-shadow(0 3px 7px rgba(0,0,0,.38)) !important;
}
.section-hero .hero-product-showcase .showcase-item p{
  color:#f4fbff !important;
  text-shadow:0 2px 7px rgba(0,0,0,.78), 0 0 10px rgba(0,200,240,.18) !important;
}
.section-hero.hero-product-hover-active .hero-product-showcase .showcase-item{
  background:rgba(7,28,52,.42) !important;
  border-color:rgba(0,200,240,.38) !important;
}
.section-hero.hero-product-hover-active .hero-product-showcase .showcase-item::before{
  opacity:.48 !important;
}
.section-hero.hero-product-hover-active .hero-product-showcase .showcase-item.hover-center-active,
.section-hero.hero-product-hover-active .hero-product-showcase .showcase-item:hover{
  background:rgba(6,30,56,.64) !important;
  border-color:rgba(0,220,255,.78) !important;
  box-shadow:0 14px 38px rgba(0,0,0,.34),0 0 0 1px rgba(0,220,255,.14),0 0 24px rgba(0,200,240,.18) !important;
}
.section-hero.hero-product-hover-active .hero-product-showcase .showcase-item.hover-center-active::before,
.section-hero.hero-product-hover-active .hero-product-showcase .showcase-item:hover::before{
  background:linear-gradient(to bottom, rgba(5,20,38,.70) 0%, rgba(7,33,60,.52) 58%, rgba(4,17,32,.76) 100%) !important;
  opacity:.68 !important;
}
.section-hero .hero-product-showcase .showcase-item::after{
  content:"";
  position:absolute;
  left:18%; right:18%; top:16%; bottom:16%;
  border-radius:18px;
  border:1px solid rgba(0,220,255,.0);
  opacity:0;
  pointer-events:none;
  transition:opacity .25s ease,border-color .25s ease;
  z-index:1;
}
.section-hero .hero-product-showcase .showcase-item.hover-center-active::after{
  opacity:.28;
  border-color:rgba(0,220,255,.45);
}

/* === V68: Sistemas de Alarmas hover con imagen propia y mismo gradiente pastel === */
#boazHeroHover.boaz-hero-hover{background:linear-gradient(135deg,#f9d6f4 0%,#dbe8ff 54%,#cdefff 100%) !important;}
#boazHeroHover.boaz-hero-hover img{object-fit:contain !important;object-position:center center !important;transform:none !important;}

/* V69 - hover final alarmas: imagen completa, sin zoom ni recorte */
.hero-hover-bg, .hero-hover-layer, .hero-bg-hover {
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-position: center center !important;
}


/* === V70: Alarmas hover corregido sin corte === */
#boazHeroHover.boaz-hero-hover{
  background:linear-gradient(135deg,#f9d6f4 0%,#dbe8ff 54%,#cdefff 100%) !important;
}
#boazHeroHover.boaz-hero-hover img{
  width:100% !important;
  height:100% !important;
  object-fit:contain !important;
  object-position:center center !important;
  transform:none !important;
  filter:none !important;
}
#boazHeroHover.boaz-hero-hover::after{display:none !important;content:none !important;}

/* V71 - Página Sistemas Profesionales de Monitoreo */
.equipment-page{background:#08182b;color:#eef7ff;min-height:100vh;padding-top:92px;}
.equipment-hero{padding:90px 0 55px;text-align:center;}
.equipment-hero h1{font-size:clamp(42px,6vw,82px);line-height:.98;max-width:1120px;margin:18px auto;color:#f4fbff;font-weight:300;letter-spacing:-.04em;}
.equipment-hero p{max-width:860px;margin:24px auto 0;color:#b9d2e8;font-size:20px;line-height:1.7;}
.hero-cta-row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:34px}.btn-primary,.btn-secondary{border-radius:999px;padding:14px 24px;text-decoration:none;font-weight:700}.btn-primary{background:linear-gradient(135deg,#03e0b1,#00c7ff);color:#042033}.btn-secondary{border:1px solid rgba(0,215,255,.55);color:#8feaff}.monitoring-intro{padding:20px 0 40px}.monitoring-intro>div{border:1px solid rgba(0,215,255,.18);background:linear-gradient(135deg,rgba(0,215,255,.08),rgba(2,240,189,.04));border-radius:26px;padding:34px}.monitoring-intro h2{font-size:clamp(30px,4vw,52px);font-weight:300;margin:0 0 12px}.monitoring-intro p{font-size:18px;line-height:1.75;color:#bdd5e8}.monitoring-blocks{display:flex;flex-direction:column;gap:26px;padding-bottom:90px}.monitoring-block{display:grid;grid-template-columns:1.08fr .92fr;gap:34px;align-items:center;border:1px solid rgba(0,215,255,.18);border-radius:30px;padding:30px;background:linear-gradient(135deg,rgba(11,37,66,.94),rgba(6,21,38,.98));box-shadow:0 30px 80px rgba(0,0,0,.25)}.monitoring-block:nth-child(even){grid-template-columns:.92fr 1.08fr}.monitoring-block:nth-child(even) .monitoring-copy{order:2}.monitoring-block:nth-child(even) .monitoring-visual{order:1}.monitoring-copy h2{font-size:clamp(30px,4vw,54px);font-weight:300;line-height:1.05;margin:10px 0 20px;color:#f4fbff}.monitoring-copy ul{display:grid;gap:12px;margin:0;padding:0;list-style:none}.monitoring-copy li{position:relative;padding-left:24px;color:#c8dff0;font-size:17px;line-height:1.55}.monitoring-copy li:before{content:'•';position:absolute;left:0;color:#00d7ff;font-size:24px;line-height:1}.monitoring-visual{border-radius:24px;overflow:hidden;background:#061225;border:1px solid rgba(0,215,255,.22);min-height:360px;display:flex;align-items:center;justify-content:center}.monitoring-visual img{width:100%;height:100%;min-height:360px;object-fit:cover;display:block}.monitoring-page .floating-price-cta,.monitoring-page~.floating-price-cta{display:block!important;opacity:1!important;visibility:visible!important}.btn-home,.btn-subir,.float-asesor{z-index:9999!important}@media(max-width:900px){.monitoring-block,.monitoring-block:nth-child(even){grid-template-columns:1fr}.monitoring-block:nth-child(even) .monitoring-copy,.monitoring-block:nth-child(even) .monitoring-visual{order:initial}.monitoring-visual,.monitoring-visual img{min-height:250px}.equipment-hero{padding-top:60px}}

/* V95 - Biometría: quitar apariencia de fondo blanco y unificar gradiente */
body[data-page="biometria"] .monitoring-visual{
  background: linear-gradient(135deg,#f3dcff 0%,#d8eaff 52%,#aeefff 100%) !important;
  border:1px solid rgba(0,215,255,.28) !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.18), 0 22px 60px rgba(0,0,0,.22);
}
body[data-page="biometria"] .monitoring-visual img{
  width:100% !important;
  height:100% !important;
  object-fit:contain !important;
  padding:18px !important;
  background:transparent !important;
}


/* Carrusel de marcas Boaz */
.brand-carousel-section{
  position:relative;
  overflow:hidden;
  padding:88px 0 96px;
  border-top:1px solid rgba(0,200,240,.12);
  border-bottom:1px solid rgba(0,200,240,.10);
  background:
    radial-gradient(circle at 18% 18%, rgba(0,196,255,.16), transparent 34%),
    radial-gradient(circle at 86% 42%, rgba(0,245,160,.10), transparent 30%),
    linear-gradient(135deg, #091c33 0%, #102d4f 44%, #071525 100%);
}
.brand-carousel-section::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(255,255,255,.025), transparent 32%, rgba(0,200,240,.045));
  pointer-events:none;
}
.brand-carousel-inner{
  position:relative;
  z-index:1;
  max-width:1180px;
  margin:0 auto;
  padding:0 22px;
  text-align:center;
}
.brand-carousel-inner .boaz-logo-carousel{
  margin-left:calc(-50vw + 50%);
  margin-right:calc(-50vw + 50%);
  width:100vw;
}
.brand-carousel-kicker{
  margin:0 0 14px;
  font-size:12px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:#00d7ff;
  font-weight:700;
}
.brand-carousel-title{
  margin:0 auto 14px;
  max-width:760px;
  font-size:clamp(30px,4vw,52px);
  line-height:1.05;
  font-weight:200;
  color:#eef7ff;
}
.brand-carousel-copy{
  margin:0 auto 38px;
  max-width:850px;
  color:rgba(210,229,245,.78);
  font-size:16px;
  line-height:1.7;
}
.boaz-logo-carousel{
  position:relative;
  overflow:hidden;
  width:100%;
  padding:10px 0 14px;
  -webkit-mask-image:linear-gradient(to right, transparent 0, #000 7%, #000 93%, transparent 100%);
  mask-image:linear-gradient(to right, transparent 0, #000 7%, #000 93%, transparent 100%);
}
.boaz-logo-track{
  display:flex;
  gap:22px;
  width:max-content;
  animation:boazBrandScroll 44s linear infinite;
}
.boaz-logo-track:hover{animation-play-state:paused;}
.boaz-logo-card{
  width:190px;
  height:104px;
  flex:0 0 auto;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:8px 12px;
  border-radius:22px;
  border:1px solid rgba(0,200,240,.22);
  background:linear-gradient(145deg, rgba(241,250,255,.98) 0%, rgba(222,243,255,.94) 48%, rgba(233,224,255,.92) 100%);
  box-shadow:0 18px 45px rgba(0,0,0,.20), inset 0 1px 0 rgba(255,255,255,.65);
  transition:transform .22s ease, border-color .22s ease, box-shadow .22s ease;
  cursor:pointer;
  text-decoration:none;
}
.boaz-logo-card:hover{
  transform:translateY(-4px);
  border-color:rgba(0,215,255,.58);
  box-shadow:0 24px 60px rgba(0,215,255,.14), inset 0 1px 0 rgba(255,255,255,.78);
}
.boaz-logo-card img{
  display:block;
  max-width:110%;
  max-height:96px;
  width:auto;
  height:auto;
  object-fit:contain;
  filter:saturate(1.12) contrast(1.04);
}
.boaz-logo-fallback{
  color:#163452;
  font-size:18px;
  font-weight:800;
  letter-spacing:.02em;
  text-align:center;
}
@keyframes boazBrandScroll{
  0%{transform:translateX(0);}
  100%{transform:translateX(-50%);}
}
@media (max-width: 768px){
  .brand-carousel-section{padding:64px 0 72px;}
  .brand-carousel-copy{font-size:14px;}
  .boaz-logo-card{width:154px;height:86px;border-radius:18px;padding:8px 10px;}
  .boaz-logo-card img{max-height:70px;}
  .boaz-logo-track{gap:16px;animation-duration:36s;}
}

/* === V121: cajones del hero con el mismo fondo azul del carrusel de soluciones (.card) === */
.section-hero .hero-product-showcase .showcase-item{
  background:radial-gradient(120% 120% at 82% 112%, rgba(0,180,216,.20) 0%, rgba(0,150,199,.07) 38%, transparent 60%), linear-gradient(150deg, #163354 0%, #1a3a5e 55%, #1d3e62 100%) !important;
  border:1px solid rgba(0,200,240,.18) !important;
  box-shadow:0 14px 38px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.06) !important;
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
}
.section-hero .hero-product-showcase .showcase-item::before{
  background:linear-gradient(160deg, rgba(255,255,255,.05) 0%, transparent 40%, rgba(0,180,216,.05) 100%) !important;
  opacity:1 !important;
}
.section-hero .hero-product-showcase .showcase-item img{
  filter:drop-shadow(0 4px 10px rgba(0,0,0,.45)) !important;
}
.section-hero .hero-product-showcase .showcase-item p{
  color:#e8f4ff !important;
  font-weight:500 !important;
  text-shadow:0 1px 4px rgba(0,0,0,.45) !important;
}
.section-hero .hero-product-showcase .showcase-item:hover,
.section-hero.hero-product-hover-active .hero-product-showcase .showcase-item:hover{
  background:radial-gradient(120% 120% at 82% 112%, rgba(0,200,240,.26) 0%, rgba(0,150,199,.10) 40%, transparent 62%), linear-gradient(150deg, #1a3a5e 0%, #1d3e62 55%, #224a73 100%) !important;
  border-color:rgba(0,215,255,.55) !important;
  box-shadow:0 18px 48px rgba(0,0,0,.34), 0 0 22px rgba(0,200,240,.16), inset 0 1px 0 rgba(255,255,255,.10) !important;
}
.section-hero.hero-product-hover-active .hero-product-showcase .showcase-item{
  background:radial-gradient(120% 120% at 82% 112%, rgba(0,180,216,.18) 0%, rgba(0,150,199,.06) 38%, transparent 60%), linear-gradient(150deg, #163354 0%, #1a3a5e 55%, #1d3e62 100%) !important;
  border-color:rgba(0,200,240,.22) !important;
}

/* V107 BOAZ - Gradiente cian del carrusel + contraste reforzado en Nuestras soluciones */
.bento > .card{
  background: linear-gradient(135deg, rgba(236, 248, 255, .96), rgba(222, 244, 255, .94) 48%, rgba(241, 225, 255, .92)) !important;
  border: 1px solid rgba(181, 233, 255, .78) !important;
  box-shadow: 0 18px 38px rgba(0, 229, 255, .10), inset 0 1px 0 rgba(255,255,255,.72) !important;
}
.bento > .card:hover{
  background: linear-gradient(135deg, rgba(236, 248, 255, .96), rgba(222, 244, 255, .94) 48%, rgba(241, 225, 255, .92)) !important;
  box-shadow: 0 24px 48px rgba(0, 229, 255, .16), inset 0 1px 0 rgba(255,255,255,.78) !important;
}
.bento > .card h3{
  color:#061a33 !important;
  font-weight:500 !important;
  text-shadow:0 1px 0 rgba(255,255,255,.22);
}
.bento > .card p{
  color:#12324a !important;
  font-weight:400 !important;
}
.bento > .card p strong{
  color:#021325 !important;
  font-weight:700 !important;
}
.bento > .card .card-tag{
  color:#005f86 !important;
  font-weight:800 !important;
  letter-spacing:.12em;
}
.bento > .card .card-link{
  color:#005f86 !important;
  border-color:rgba(0,95,134,.62) !important;
  background:rgba(255,255,255,.42) !important;
  font-weight:700 !important;
}
.bento > .card .card-link:hover{
  background:#00c8f0 !important;
  color:#061a33 !important;
  border-color:#00c8f0 !important;
}


/* BOAZ RETAIL - imágenes de bloques con fondo gradient cian/lila */
body[data-page="retail"] .v-section-img{
  background:
    radial-gradient(circle at 18% 18%, rgba(255,255,255,.58) 0%, rgba(255,255,255,0) 36%),
    linear-gradient(135deg,#f9d6f4 0%,#dbe8ff 54%,#cdefff 100%) !important;
  border:1px solid rgba(0,200,240,.24);
  box-shadow:0 24px 70px rgba(0,0,0,.24), inset 0 1px 0 rgba(255,255,255,.34);
  padding:24px;
  display:flex;
  align-items:center;
  justify-content:center;
}
body[data-page="retail"] .v-section-img img{
  width:100%;
  height:100%;
  object-fit:contain !important;
  filter:drop-shadow(0 18px 28px rgba(8,18,34,.20)) saturate(1.08) contrast(1.02) !important;
}
body[data-page="retail"] .v-section-img:hover img{transform:scale(1.03);}
@media(max-width:640px){
  body[data-page="retail"] .v-section-img{padding:16px;}
}


/* BOAZ BARRIOS - imágenes de bloques con fondo gradient cian/lila */
body[data-page="barrios"] .v-section-img{
  background:
    radial-gradient(circle at 18% 18%, rgba(255,255,255,.58) 0%, rgba(255,255,255,0) 36%),
    linear-gradient(135deg,#f9d6f4 0%,#dbe8ff 54%,#cdefff 100%) !important;
  border:1px solid rgba(0,200,240,.24);
  box-shadow:0 24px 70px rgba(0,0,0,.24), inset 0 1px 0 rgba(255,255,255,.34);
  padding:24px;
  display:flex;
  align-items:center;
  justify-content:center;
}
body[data-page="barrios"] .v-section-img img{
  width:100%;
  height:100%;
  object-fit:contain !important;
  filter:drop-shadow(0 18px 28px rgba(8,18,34,.20)) saturate(1.08) contrast(1.02) !important;
}
body[data-page="barrios"] .v-section-img:hover img{transform:scale(1.03);}
body[data-page="barrios"] .v-section-text h4{
  font-size:18px;
  font-weight:500;
  color:#f0f8ff;
  margin:12px 0;
}
@media(max-width:640px){
  body[data-page="barrios"] .v-section-img{padding:16px;}
}

/* Gradient cards para bloques de Bancos & Fintechs */
.img-gradient-card{
  border-radius:24px;
  padding:28px;
  background:linear-gradient(135deg,#f5c7f2 0%,#d9e7ff 46%,#b9f3ff 100%);
  border:1px solid rgba(255,255,255,.45);
  box-shadow:0 22px 70px rgba(0,200,240,.12);
  aspect-ratio:4/3;
  display:flex;
  align-items:center;
  justify-content:center;
}
.img-gradient-card img{
  width:100%;
  height:100%;
  object-fit:contain;
  filter:none;
}
.img-gradient-card:hover img{transform:scale(1.02);}


/* === FIX HERO FONDOS VERTICALES === */
.v-hero{background-color:#0b2440;background-blend-mode:normal;overflow:hidden;}
.v-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 72% 30%,rgba(0,200,240,.16),transparent 30%);pointer-events:none;z-index:1;}
.v-hero-content{position:relative;z-index:2;}

/* Logo Boaz en menú con fondo blanco para mejorar contraste */
.nav-logo{
  width:50px !important;
  height:50px !important;
  border-radius:999px !important;
  background:#ffffff !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  box-shadow:0 0 0 1px rgba(255,255,255,.55), 0 8px 24px rgba(0,200,240,.16) !important;
  overflow:hidden !important;
}
.nav-logo img{
  width:47px !important;
  height:47px !important;
  object-fit:contain !important;
  display:block !important;
}
@media(max-width:760px){
  .nav-logo{width:46px !important;height:46px !important;}
  .nav-logo img{width:43px !important;height:43px !important;}
}

/* === AJUSTE FINAL LOGO MENÚ SIN FONDO + CLAIM === */
nav{
  grid-template-columns:1fr auto 1fr !important;
}
.nav-logo{
  width:auto !important;
  height:58px !important;
  border-radius:0 !important;
  background:transparent !important;
  box-shadow:none !important;
  overflow:visible !important;
  display:flex !important;
  align-items:center !important;
  justify-content:flex-start !important;
  gap:12px !important;
  min-width:330px !important;
}
.nav-logo img{
  width:46px !important;
  height:46px !important;
  object-fit:contain !important;
  display:block !important;
  filter:drop-shadow(0 0 5px rgba(0,200,240,.95)) drop-shadow(0 0 14px rgba(0,245,160,.32)) brightness(1.25) contrast(1.15) !important;
}
.nav-logo-text{
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
  line-height:1.05 !important;
  letter-spacing:.055em !important;
  text-transform:uppercase !important;
  white-space:nowrap !important;
  color:rgba(232,244,253,.88) !important;
  font-family:-apple-system,'Helvetica Neue',Helvetica,Arial,sans-serif !important;
}
.nav-logo-text strong{
  font-size:13px !important;
  font-weight:500 !important;
  color:#f0f8ff !important;
}
.nav-logo-text em{
  margin-top:3px !important;
  font-size:12px !important;
  font-style:normal !important;
  font-weight:400 !important;
  color:#00c8f0 !important;
  letter-spacing:.08em !important;
}
@media(max-width:1100px){
  nav{grid-template-columns:1fr auto 1fr !important;}
  .nav-logo{min-width:270px !important;gap:10px !important;}
  .nav-logo img{width:42px !important;height:42px !important;}
  .nav-logo-text strong{font-size:11px !important;}
  .nav-logo-text em{font-size:10.5px !important;}
}
@media(max-width:760px){
  nav{grid-template-columns:250px minmax(0,1fr) 44px !important;padding:0 14px !important;}
  .nav-logo{min-width:230px !important;height:58px !important;gap:9px !important;}
  .nav-logo img{width:40px !important;height:40px !important;}
  .nav-logo-text strong{font-size:10px !important;letter-spacing:.035em !important;}
  .nav-logo-text em{font-size:9.5px !important;letter-spacing:.06em !important;}
}
@media(max-width:430px){
  nav{grid-template-columns:205px minmax(0,1fr) 40px !important;}
  .nav-logo{min-width:195px !important;gap:7px !important;}
  .nav-logo img{width:36px !important;height:36px !important;}
  .nav-logo-text strong{font-size:8.7px !important;}
  .nav-logo-text em{font-size:8.4px !important;}
}

/* FOOTER BRAND LOGO + CLAIM */
.footer-brand-claim{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:16px;
}
.footer-brand-claim img{
  width:54px;
  height:54px;
  object-fit:contain;
  display:block;
  filter:drop-shadow(0 0 5px rgba(0,200,240,.95)) drop-shadow(0 0 14px rgba(0,245,160,.32)) brightness(1.25) contrast(1.15);
}
.footer-logo-text{
  display:flex;
  flex-direction:column;
  justify-content:center;
  line-height:1.05;
  letter-spacing:.055em;
  text-transform:uppercase;
  white-space:nowrap;
  font-family:-apple-system,'Helvetica Neue',Helvetica,Arial,sans-serif;
}
.footer-logo-text strong{
  font-size:15px;
  font-weight:500;
  color:#f0f8ff;
}
.footer-logo-text em{
  margin-top:4px;
  font-size:13px;
  font-style:normal;
  font-weight:400;
  color:#00c8f0;
  letter-spacing:.08em;
}
@media(max-width:520px){
  .footer-brand-claim{gap:10px;}
  .footer-brand-claim img{width:46px;height:46px;}
  .footer-logo-text strong{font-size:12px;}
  .footer-logo-text em{font-size:11px;}
}

/* Footer contact icons */
.footer-contact-link{display:inline-flex !important;align-items:center;gap:9px;line-height:1.35;}
.footer-contact-link .contact-icon{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 18px;}
.footer-contact-link .contact-icon svg{width:18px;height:18px;display:block;}
.footer-contact-link .contact-icon-whatsapp svg{fill:#25D366;}
.footer-contact-link .contact-icon-mail svg{fill:#00CFFF;}
.footer-contact-link .contact-icon-location svg{fill:#FF3B30;}
.footer-contact-link .contact-icon-form svg{fill:#A970FF;}
.footer-contact-link:hover .contact-icon svg{filter:drop-shadow(0 0 6px rgba(0,207,255,.35));}
@media(max-width:640px){.footer-contact-link{justify-content:flex-start}.footer-contact-link .contact-icon{width:17px;height:17px;flex-basis:17px}.footer-contact-link .contact-icon svg{width:17px;height:17px}}

/* === V69: MÓVIL — cajones del hero con el fondo CLARO del carrusel (resaltan sobre el navy sin video) === */
@media (max-width:768px){
  .section-hero .hero-product-showcase .showcase-item,
  .section-hero.hero-product-hover-active .hero-product-showcase .showcase-item{
    background:linear-gradient(145deg, rgba(241,250,255,.98) 0%, rgba(222,243,255,.94) 48%, rgba(233,224,255,.92) 100%) !important;
    border:1px solid rgba(0,200,240,.30) !important;
    box-shadow:0 14px 38px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.65) !important;
    backdrop-filter:none !important;
    -webkit-backdrop-filter:none !important;
  }
  .section-hero .hero-product-showcase .showcase-item::before{
    background:none !important;
    opacity:0 !important;
  }
  .section-hero .hero-product-showcase .showcase-item img{
    filter:drop-shadow(0 3px 7px rgba(0,0,0,.22)) !important;
  }
  .section-hero .hero-product-showcase .showcase-item p{
    color:#0d2140 !important;
    font-weight:600 !important;
    text-shadow:none !important;
  }
  .section-hero .hero-product-showcase .showcase-item:hover{
    background:linear-gradient(145deg, rgba(241,250,255,.98) 0%, rgba(222,243,255,.94) 48%, rgba(233,224,255,.92) 100%) !important;
    border-color:rgba(0,215,255,.55) !important;
    box-shadow:0 14px 38px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.65) !important;
  }
}

/* === FAQ (acordeón) === */
.boaz-faq-item{
  border:1px solid rgba(0,200,240,.18);
  border-radius:14px;
  background:rgba(22,52,84,.45);
  margin-bottom:12px;
  overflow:hidden;
}
.boaz-faq-item summary{
  list-style:none; cursor:pointer;
  padding:18px 22px; font-size:17px; font-weight:500; color:#f0f8ff;
  display:flex; align-items:center; justify-content:space-between; gap:14px;
}
.boaz-faq-item summary::-webkit-details-marker{ display:none; }
.boaz-faq-item summary::after{
  content:'+'; color:#00c8f0; font-size:26px; font-weight:300; line-height:1; flex:0 0 auto;
}
.boaz-faq-item[open] summary::after{ content:'\2212'; }
.boaz-faq-item summary:hover{ color:#00c8f0; }
.boaz-faq-a{ padding:0 22px 20px; }
.boaz-faq-a p{ color:#a8c4dc; font-size:15.5px; line-height:1.65; margin:0; }
@media(max-width:768px){
  .boaz-faq-item summary{ font-size:15.5px; padding:16px 18px; }
  .boaz-faq-a{ padding:0 18px 18px; }
}

/* === Mapa de contacto === */
.boaz-map-embed{
  width:100%; border:0; display:block; border-radius:16px;
  box-shadow:0 12px 34px rgba(0,0,0,.30); margin-top:18px;
}

/* === Iconos sociales arriba a la derecha (todas las páginas) === */
.boaz-social-top{
  position:fixed; top:0; right:14px; height:58px; z-index:300;
  display:flex; align-items:center; gap:9px;
}
.boaz-social-top a{
  width:32px; height:32px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  text-decoration:none; box-shadow:0 4px 12px rgba(0,0,0,.30);
  transition:transform .18s ease, box-shadow .18s ease;
}
.boaz-social-top a:hover{ transform:scale(1.12); box-shadow:0 6px 16px rgba(0,0,0,.40); }
.boaz-social-top a svg{ width:17px; height:17px; fill:#fff; display:block; }
.boaz-social-top .s-yt{ background:#FF0000; }
.boaz-social-top .s-ig{ background:radial-gradient(circle at 30% 107%,#fdf497 0%,#fdf497 5%,#fd5949 45%,#d6249f 60%,#285AEB 90%); }
.boaz-social-top .s-tt{ background:#000000; }
.boaz-social-top .s-li{ background:#0A66C2; }
@media(max-width:980px){ .boaz-social-top{ display:none; } }

/* === Sección YouTube: recuadro 16:9 con zoom suave (nítido, sin recorte) === */
.yt-frame{
  display:block; position:relative; width:92%; max-width:900px; margin:36px auto 0;
  aspect-ratio:16/9; border-radius:18px; overflow:hidden;
  border:1px solid rgba(0,200,240,.22);
  box-shadow:0 24px 60px rgba(0,0,0,.45);
  background:#0d2140;
}
.yt-kenburns{ position:absolute; inset:0; overflow:hidden; }
.yt-kenburns img{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; object-position:center;
  opacity:0; transform:scale(1.0);
  filter:brightness(.88) saturate(1.04);
  transition:opacity 1.2s ease;
  will-change:opacity, transform;
}
.yt-kenburns img.is-on{ opacity:1; animation:ytZoom 8s ease-out forwards; }
@keyframes ytZoom{ from{ transform:scale(1.0); } to{ transform:scale(1.18); } }
.yt-frame-play{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; z-index:2; transition:transform .25s ease; pointer-events:auto; }
.yt-frame-play svg{ width:68px; height:48px; filter:drop-shadow(0 6px 16px rgba(0,0,0,.55)); opacity:.92; }
.yt-frame:hover .yt-frame-play{ transform:scale(1.08); }
.yt-frame:hover .yt-kenburns img.is-on{ filter:brightness(.98) saturate(1.06); }
@media (prefers-reduced-motion: reduce){ .yt-kenburns img.is-on{ animation:none; transform:scale(1.02); } }
@media (max-width:560px){ .yt-frame{ width:94%; border-radius:14px; } .yt-frame-play svg{ width:54px; height:38px; } }

/* === Grilla de marcas (página lista de precios, dentro del candado) === */
.boaz-brand-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:24px;
  max-width:1340px; margin:10px auto 0;
}
.boaz-brand-tile{
  display:flex; align-items:center; justify-content:center;
  height:230px; padding:24px 32px; border-radius:28px;
  background:linear-gradient(135deg, rgba(236,248,255,.96), rgba(222,244,255,.94) 48%, rgba(241,225,255,.92));
  border:1px solid rgba(181,233,255,.78);
  box-shadow:0 18px 40px rgba(0,229,255,.12), inset 0 1px 0 rgba(255,255,255,.72);
  text-decoration:none; overflow:hidden;
  transition:transform .2s ease, box-shadow .2s ease;
}
.boaz-brand-tile:hover{
  transform:translateY(-5px);
  box-shadow:0 28px 56px rgba(0,229,255,.26), inset 0 1px 0 rgba(255,255,255,.85);
}
.boaz-brand-tile img{
  max-width:82%; max-height:150px; width:auto; height:auto;
  object-fit:contain; object-position:center; display:block;
}
/* Celulares y tablets: 1 por línea */
@media(max-width:980px){
  .boaz-brand-grid{ grid-template-columns:1fr; max-width:520px; gap:18px; }
  .boaz-brand-tile{ height:170px; border-radius:22px; }
  .boaz-brand-tile img{ max-height:120px; }
}

/* Marca con lista de precios disponible */
.boaz-brand-tile.price-list-ready{position:relative;border-color:rgba(229,27,35,.5);box-shadow:0 12px 34px rgba(229,27,35,.12)}
.boaz-brand-tile.price-list-ready:hover{border-color:#e51b23;box-shadow:0 18px 42px rgba(229,27,35,.22)}
.brand-list-badge{position:absolute;right:9px;bottom:9px;padding:5px 8px;border-radius:999px;background:#e51b23;color:#fff;font-size:9px;font-weight:900;letter-spacing:.08em;line-height:1}


/* === Filtro visual por categoría en la lista de precios === */
.boaz-category-section{
  max-width:1340px;
  margin:0 auto 34px;
}
.boaz-category-heading{
  text-align:center;
  max-width:850px;
  margin:0 auto 22px;
}
.boaz-category-heading h3{
  margin:8px 0 8px;
  color:var(--white);
  font-size:clamp(24px,3vw,38px);
  line-height:1.15;
}
.boaz-category-heading p{
  color:var(--gray2);
  margin:0 auto;
  line-height:1.65;
}
.boaz-category-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
}
.boaz-category-card{
  min-height:112px;
  padding:20px 18px;
  border-radius:22px;
  border:1px solid rgba(181,233,255,.78);
  background:linear-gradient(135deg,rgba(236,248,255,.96),rgba(222,244,255,.94) 48%,rgba(241,225,255,.92));
  box-shadow:0 14px 32px rgba(0,229,255,.10),inset 0 1px 0 rgba(255,255,255,.72);
  color:#102442;
  font:inherit;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease,filter .2s ease;
}
.boaz-category-card span{
  font-size:14px;
  font-weight:900;
  letter-spacing:.055em;
  line-height:1.3;
}
.boaz-category-card:hover,
.boaz-category-card:focus-visible{
  transform:translateY(-4px);
  box-shadow:0 22px 44px rgba(0,229,255,.22),inset 0 1px 0 rgba(255,255,255,.88);
  outline:none;
}
.boaz-category-card.is-active{
  border-color:#00c8f0;
  box-shadow:0 0 0 3px rgba(0,200,240,.22),0 22px 48px rgba(0,200,240,.28);
  transform:translateY(-4px);
}
.boaz-category-status{
  min-height:32px;
  margin:16px 2px 0;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  flex-wrap:wrap;
  color:var(--gray2);
  font-size:13px;
}
#boaz-clear-category{
  border:1px solid rgba(0,200,240,.38);
  background:rgba(0,200,240,.10);
  color:#7be6ff;
  border-radius:999px;
  padding:8px 13px;
  font-weight:800;
  cursor:pointer;
}
#boaz-clear-category:hover{background:rgba(0,200,240,.18);}
.boaz-brand-tile{position:relative;isolation:isolate;}
.boaz-brand-tile.is-category-dimmed{
  opacity:.42;
  filter:grayscale(.9) saturate(.25) brightness(.62);
  transform:scale(.985);
  box-shadow:none !important;
  pointer-events:none;
  user-select:none;
}
.boaz-brand-tile.is-category-dimmed::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:8;
  border-radius:inherit;
  background:linear-gradient(135deg,rgba(8,18,35,.62),rgba(18,25,40,.74));
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.04);
}
.boaz-brand-tile.is-category-match{
  border-color:rgba(0,200,240,.75);
  box-shadow:0 20px 46px rgba(0,200,240,.22),inset 0 1px 0 rgba(255,255,255,.86);
}
.boaz-brand-grid.has-category-filter .boaz-brand-tile.is-category-match:hover{
  transform:translateY(-6px);
  box-shadow:0 28px 58px rgba(0,200,240,.30),inset 0 1px 0 rgba(255,255,255,.9);
}
@media(max-width:1080px){
  .boaz-category-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media(max-width:620px){
  .boaz-category-section{margin-bottom:26px;}
  .boaz-category-grid{grid-template-columns:1fr;gap:12px;}
  .boaz-category-card{min-height:82px;border-radius:18px;padding:16px;}
  .boaz-category-card span{font-size:13px;}
}


/* === V31: las marcas filtradas suben al inicio y quedan visibles === */
.boaz-brand-grid{
  scroll-margin-top:96px;
}
.boaz-brand-grid.has-category-filter .boaz-brand-tile{
  transition:order 0s,opacity .22s ease,filter .22s ease,transform .22s ease,box-shadow .22s ease;
}


/* === V32: productos visibles dentro de los selectores de tecnología === */
.boaz-category-card{
  position:relative;
  overflow:hidden;
  min-height:178px;
  padding:18px 18px 17px;
  align-items:flex-end;
  justify-content:flex-start;
  isolation:isolate;
}
.boaz-category-card::before{
  content:"";
  position:absolute;
  inset:auto 0 0;
  height:58%;
  background:linear-gradient(0deg,rgba(242,250,255,.98) 18%,rgba(242,250,255,.80) 58%,rgba(242,250,255,0));
  z-index:1;
  pointer-events:none;
}
.boaz-category-label{
  position:relative;
  z-index:3;
  max-width:84%;
  text-align:left;
  text-shadow:0 1px 0 rgba(255,255,255,.7);
}
.boaz-category-visual{
  position:absolute;
  inset:5px 5px 32px 5px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:0;
  z-index:0;
  pointer-events:none;
}
.boaz-category-visual img{
  width:43%;
  height:112px;
  object-fit:contain;
  border-radius:14px;
  filter:drop-shadow(0 9px 10px rgba(15,45,76,.22));
  transform:translateY(-4px) rotate(-3deg);
  transition:transform .25s ease,filter .25s ease;
}
.boaz-category-visual img+img{margin-left:-17%;transform:translateY(3px) rotate(4deg);}
.boaz-category-visual img:nth-child(3){margin-left:-18%;transform:translateY(-7px) rotate(8deg);}
.boaz-category-card:hover .boaz-category-visual img:first-child,
.boaz-category-card:focus-visible .boaz-category-visual img:first-child{transform:translate(-5px,-8px) rotate(-5deg) scale(1.04);}
.boaz-category-card:hover .boaz-category-visual img:nth-child(2),
.boaz-category-card:focus-visible .boaz-category-visual img:nth-child(2){transform:translate(2px,-2px) rotate(4deg) scale(1.04);}
.boaz-category-card:hover .boaz-category-visual img:nth-child(3),
.boaz-category-card:focus-visible .boaz-category-visual img:nth-child(3){transform:translate(7px,-10px) rotate(8deg) scale(1.04);}
@media(max-width:720px){
  .boaz-category-card{min-height:158px;}
  .boaz-category-visual img{height:96px;}
  .boaz-category-label{max-width:95%;font-size:12px!important;}
}

/* === V34: imágenes provistas por BOAZ en los selectores y nuevas categorías === */
.boaz-category-visual.category-art{
  inset:4px 5px 29px;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  overflow:hidden;
}
.boaz-category-visual.category-art img,
.boaz-category-visual.category-art img+img,
.boaz-category-visual.category-art img:nth-child(3){
  width:100%;
  height:145px;
  max-width:100%;
  margin:0;
  padding:0;
  object-fit:contain;
  object-position:center bottom;
  border-radius:0;
  opacity:.96;
  filter:drop-shadow(0 11px 12px rgba(15,45,76,.24));
  transform:translateY(2px) scale(.98);
  transition:transform .25s ease,filter .25s ease,opacity .25s ease;
}
.boaz-category-card:hover .boaz-category-visual.category-art img,
.boaz-category-card:focus-visible .boaz-category-visual.category-art img,
.boaz-category-card:hover .boaz-category-visual.category-art img:first-child,
.boaz-category-card:focus-visible .boaz-category-visual.category-art img:first-child{
  transform:translateY(-2px) scale(1.035);
  filter:drop-shadow(0 15px 15px rgba(15,45,76,.30));
}
.boaz-category-card::before{
  height:61%;
  background:linear-gradient(0deg,rgba(242,250,255,.99) 17%,rgba(242,250,255,.88) 48%,rgba(242,250,255,.22) 82%,rgba(242,250,255,0));
}
@media(min-width:1280px){
  .boaz-category-grid{grid-template-columns:repeat(5,minmax(0,1fr));}
}
@media(max-width:720px){
  .boaz-category-visual.category-art img{height:126px;}
}


/* === V35: imágenes de categorías más altas, nítidas y con menor overlay === */
.boaz-category-visual.category-art{
  inset:-8px 3px 38px;
  align-items:center;
  overflow:visible;
}
.boaz-category-visual.category-art img,
.boaz-category-visual.category-art img+img,
.boaz-category-visual.category-art img:nth-child(3){
  height:164px;
  opacity:1;
  object-position:center center;
  transform:translateY(-13px) scale(1.065);
  filter:drop-shadow(0 13px 14px rgba(15,45,76,.28));
}
.boaz-category-card:hover .boaz-category-visual.category-art img,
.boaz-category-card:focus-visible .boaz-category-visual.category-art img,
.boaz-category-card:hover .boaz-category-visual.category-art img:first-child,
.boaz-category-card:focus-visible .boaz-category-visual.category-art img:first-child{
  transform:translateY(-17px) scale(1.105);
  filter:drop-shadow(0 17px 18px rgba(15,45,76,.34));
}
.boaz-category-card::before{
  height:46%;
  background:linear-gradient(0deg,rgba(242,250,255,.97) 10%,rgba(242,250,255,.67) 54%,rgba(242,250,255,.12) 84%,rgba(242,250,255,0));
}
.boaz-category-label{
  text-shadow:0 1px 0 rgba(255,255,255,.95),0 0 10px rgba(255,255,255,.8);
}
@media(max-width:720px){
  .boaz-category-visual.category-art{inset:-4px 3px 34px;}
  .boaz-category-visual.category-art img{height:145px;transform:translateY(-10px) scale(1.04);}
}

/* === V39: títulos de categorías centrados en la parte inferior === */
.boaz-category-card{
  align-items:flex-end;
  justify-content:center;
}
.boaz-category-label{
  width:100%;
  max-width:100%;
  margin:0 auto;
  text-align:center;
  display:block;
}
@media(max-width:720px){
  .boaz-category-label{
    width:100%;
    max-width:100%;
    text-align:center;
  }
}


/* === V40: selector de tecnologías móvil en dos columnas === */
@media(max-width:620px){
  .boaz-category-section{
    width:100%;
    max-width:100%;
    margin-left:auto;
    margin-right:auto;
    overflow:hidden;
  }
  .boaz-category-grid{
    width:100%;
    max-width:100%;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:10px;
  }
  .boaz-category-card{
    width:100%;
    min-width:0;
    min-height:0;
    aspect-ratio:1 / 1.08;
    padding:10px 7px 11px;
    border-radius:17px;
    box-sizing:border-box;
  }
  .boaz-category-visual.category-art{
    inset:-1px 2px 34px;
    overflow:hidden;
  }
  .boaz-category-visual.category-art img,
  .boaz-category-visual.category-art img+img,
  .boaz-category-visual.category-art img:nth-child(3){
    width:100%;
    max-width:100%;
    height:104px;
    object-fit:contain;
    object-position:center center;
    transform:translateY(-3px) scale(1.02);
  }
  .boaz-category-card:hover .boaz-category-visual.category-art img,
  .boaz-category-card:focus-visible .boaz-category-visual.category-art img,
  .boaz-category-card:hover .boaz-category-visual.category-art img:first-child,
  .boaz-category-card:focus-visible .boaz-category-visual.category-art img:first-child{
    transform:translateY(-5px) scale(1.045);
  }
  .boaz-category-card::before{
    height:43%;
  }
  .boaz-category-label,
  .boaz-category-card span.boaz-category-label{
    width:100%;
    max-width:100%;
    font-size:10.5px!important;
    line-height:1.18;
    letter-spacing:.025em;
    text-align:center;
    overflow-wrap:anywhere;
  }
}

/* V57 — Entrada de autoridad para “EXPERTOS EN SOLUCIONES” */
.hero-expert-intro{
  display:inline-block;
  position:relative;
  z-index:12;
  opacity:0;
  transform-origin:center center;
  will-change:transform,opacity,filter,letter-spacing;
  animation:boazExpertArrival 2.35s cubic-bezier(.16,.86,.22,1) .28s forwards;
}
.hero-expert-intro::after{
  content:"";
  position:absolute;
  left:50%;bottom:-10px;
  width:0;height:2px;
  transform:translateX(-50%);
  border-radius:999px;
  background:linear-gradient(90deg,transparent,#00c8f0,#64f0c8,transparent);
  box-shadow:0 0 18px rgba(0,200,240,.72);
  animation:boazExpertLine 1.25s ease 1.25s forwards;
}
@keyframes boazExpertArrival{
  0%{
    opacity:0;
    transform:perspective(900px) translateZ(-720px) scale(.24);
    filter:blur(17px);
    letter-spacing:.48em;
    text-shadow:0 0 0 rgba(0,200,240,0);
  }
  42%{
    opacity:.95;
    filter:blur(2px);
  }
  68%{
    opacity:1;
    transform:perspective(900px) translateZ(115px) scale(1.72);
    filter:blur(0);
    letter-spacing:.22em;
    text-shadow:0 0 28px rgba(0,200,240,.72),0 0 58px rgba(69,116,255,.38);
  }
  84%{
    transform:perspective(900px) translateZ(-15px) scale(.94);
    letter-spacing:.17em;
  }
  100%{
    opacity:1;
    transform:perspective(900px) translateZ(0) scale(1);
    filter:none;
    letter-spacing:.18em;
    text-shadow:0 0 15px rgba(0,200,240,.34);
  }
}
@keyframes boazExpertLine{
  0%{width:0;opacity:0;}
  45%{opacity:1;}
  100%{width:72%;opacity:.78;}
}

/* V57 — Acceso prioritario al Portal de Clientes en menú móvil */
.mobile-menu .mobile-portal-clientes{
  display:grid;
  grid-template-columns:28px 1fr;
  grid-template-rows:auto auto;
  column-gap:10px;
  align-items:center;
  margin:0 0 12px;
  padding:14px 16px;
  border:1px solid rgba(0,207,224,.58);
  border-radius:14px;
  background:linear-gradient(125deg,rgba(0,198,238,.22),rgba(58,88,220,.18),rgba(54,227,183,.14));
  box-shadow:0 10px 30px rgba(0,0,0,.22),inset 0 0 22px rgba(0,200,240,.07);
  color:#f3fbff;
  font-size:17px;
  font-weight:650;
  border-bottom:1px solid rgba(0,207,224,.58);
}
.mobile-menu .mobile-portal-clientes > span:first-child{
  grid-row:1 / span 2;
  font-size:22px;
  line-height:1;
}
.mobile-menu .mobile-portal-clientes > span:nth-child(2){line-height:1.2;}
.mobile-menu .mobile-portal-clientes small{
  grid-column:2;
  margin-top:3px;
  color:#9ed9ea;
  font-size:11px;
  font-weight:400;
  letter-spacing:.01em;
}
.mobile-menu .mobile-portal-clientes:active{
  transform:scale(.985);
  background:linear-gradient(125deg,rgba(0,198,238,.34),rgba(58,88,220,.25));
}

@media(max-width:700px){
  .hero-expert-intro{font-size:12px !important;}
  @keyframes boazExpertArrival{
    0%{opacity:0;transform:scale(.28);filter:blur(14px);letter-spacing:.34em;}
    65%{opacity:1;transform:scale(1.42);filter:blur(0);letter-spacing:.2em;text-shadow:0 0 24px rgba(0,200,240,.65);}
    84%{transform:scale(.95);}
    100%{opacity:1;transform:scale(1);filter:none;letter-spacing:.18em;text-shadow:0 0 12px rgba(0,200,240,.3);}
  }
}
@media(prefers-reduced-motion:reduce){
  .hero-expert-intro{opacity:1;transform:none;filter:none;animation:none;}
  .hero-expert-intro::after{width:72%;opacity:.65;animation:none;}
}

/* === V82: MOBILE HOME - reducir espacio superior antes del bloque Portal/E-Shop === */
@media (max-width: 640px){
  body[data-page="home"] .section-hero{
    min-height: auto !important;
    justify-content: flex-start !important;
    padding-top: 0 !important;
    padding-bottom: 42px !important;
  }
  body[data-page="home"] .section-hero > div[style*="z-index:10"]{
    padding-top: 8px !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
  }
  body[data-page="home"] .home-client-shop-hub{
    position: relative !important;
    top: auto !important;
    left: auto !important;
    transform: none !important;
    width: min(92vw, 370px) !important;
    margin: 6px auto 42px !important;
  }
  body[data-page="home"] .home-client-shop-hub a{
    min-height: 42px !important;
  }
}
@media (max-width: 390px){
  body[data-page="home"] .section-hero > div[style*="z-index:10"]{
    padding-top: 4px !important;
  }
  body[data-page="home"] .home-client-shop-hub{
    margin-top: 4px !important;
    margin-bottom: 34px !important;
  }
}
