/* ==========================================================
   SERVICE HOME TECH — PREMIUM B2B WEB
   Brand: navy #07152c · azul tech #37a7ff
   Type: Manrope (UI) + Space Grotesk (display)
   ========================================================== */
:root{
  --navy:#07152c;
  --navy-2:#0d2446;
  --navy-3:#13325f;
  --blue:#37a7ff;
  --blue-deep:#1664b8;
  --cyan:#83d7ff;
  --white:#ffffff;
  --paper:#f4f8fc;
  --ink:#081427;
  --muted:#8896ad;
  --muted-2:#5a6a85;
  --line:rgba(255,255,255,.08);
  --glass:rgba(255,255,255,.06);
  --glass-strong:rgba(255,255,255,.10);
  --green:#25d366;
  --radius-sm:14px;
  --radius:22px;
  --radius-lg:32px;
  --shadow-lg:0 30px 80px rgba(7,21,44,.55);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Manrope','Inter',system-ui,sans-serif;
  background:#040b1a;
  color:#e9eef7;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  font-weight:500;
}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

.container{width:min(1240px,calc(100% - 40px));margin:auto}

/* ---- TYPE ---- */
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 14px 8px 12px;
  border-radius:999px;
  background:linear-gradient(180deg,rgba(55,167,255,.18),rgba(55,167,255,.06));
  border:1px solid rgba(55,167,255,.32);
  color:#bfe1ff;
  font:700 11.5px/1 'Space Grotesk',sans-serif;
  letter-spacing:1.6px;
  text-transform:uppercase;
}
.eyebrow::before{
  content:"";width:6px;height:6px;border-radius:50%;
  background:var(--blue);box-shadow:0 0 12px var(--blue);
}
.h-display{
  font-family:'Space Grotesk','Manrope',sans-serif;
  font-weight:700;
  letter-spacing:-1.6px;
  line-height:1.02;
}
.h-display .accent{
  background:linear-gradient(120deg,#7cc7ff 0%,#37a7ff 45%,#bfe1ff 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.lead{font-size:17px;line-height:1.7;color:#aab9d2;font-weight:400;max-width:60ch}

/* ---- BUTTONS ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:15px 24px;border-radius:999px;
  font:800 14px/1 'Manrope',sans-serif;letter-spacing:.2px;
  transition:transform .25s cubic-bezier(.2,.7,.2,1), box-shadow .25s, background .25s;
  border:1px solid transparent;white-space:nowrap;
}
.btn svg{width:16px;height:16px}
.btn-primary{
  background:linear-gradient(135deg,#37a7ff 0%,#1664b8 100%);
  color:#fff;
  box-shadow:0 18px 40px rgba(55,167,255,.35), inset 0 1px 0 rgba(255,255,255,.25);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 24px 50px rgba(55,167,255,.45), inset 0 1px 0 rgba(255,255,255,.25)}
.btn-ghost{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.18);
  color:#eaf2ff;
  backdrop-filter:blur(10px);
}
.btn-ghost:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.3);transform:translateY(-2px)}
.btn-wa{
  background:linear-gradient(135deg,#25d366,#128c7e);color:#fff;
  box-shadow:0 14px 30px rgba(37,211,102,.32);
}
.btn-wa:hover{transform:translateY(-2px)}

/* ============================================================
   TOPBAR
   ============================================================ */
.topbar{
  position:fixed;top:0;left:0;right:0;z-index:60;
  padding:14px 0;
  transition:background .3s, backdrop-filter .3s, border-color .3s;
  border-bottom:1px solid transparent;
}
.topbar.scrolled{
  background:rgba(7,21,44,.72);
  backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:12px}
.brand .mark{
  width:42px;height:42px;border-radius:12px;
  background:linear-gradient(135deg,#37a7ff,#0d2446);
  display:grid;place-items:center;
  color:#fff;font:800 14px/1 'Space Grotesk',sans-serif;letter-spacing:1px;
  box-shadow:0 8px 24px rgba(55,167,255,.4), inset 0 1px 0 rgba(255,255,255,.3);
}
.brand-name{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:15px;letter-spacing:-.2px}
.brand-name small{display:block;font:500 11px/1.2 'Manrope',sans-serif;color:#8aa0c2;letter-spacing:.2px;margin-top:2px}
.links{display:flex;gap:6px}
.links a{
  padding:9px 14px;border-radius:999px;font-size:13.5px;font-weight:600;color:#c7d2e5;
  transition:background .2s, color .2s;
}
.links a:hover{background:rgba(255,255,255,.06);color:#fff}
.nav-cta{display:flex;align-items:center;gap:10px}

@media(max-width:880px){.links{display:none}}

/* ============================================================
   HERO  — 3D PRODUCT SHOWCASE
   (★ NUEVO HERO — bloque visual principal)
   ============================================================ */
.hero{
  position:relative;
  min-height:100vh;
  padding:120px 0 60px;
  background:
    radial-gradient(1200px 700px at 80% 10%, rgba(55,167,255,.22), transparent 60%),
    radial-gradient(900px 600px at 10% 90%, rgba(22,100,184,.25), transparent 60%),
    linear-gradient(180deg,#04101f 0%, #07152c 40%, #0a1c38 100%);
  overflow:hidden;
  isolation:isolate;
}
/* ---- Tech grid + glow background ---- */
.hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none}
.hero-grid{
  position:absolute;inset:-2px;
  background-image:
    linear-gradient(rgba(55,167,255,.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(55,167,255,.08) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse at 50% 40%, #000 30%, transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at 50% 40%, #000 30%, transparent 75%);
  opacity:.55;
}
.hero-orbits{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:1400px;height:1400px;opacity:.32}
.hero-orbits circle{fill:none;stroke:url(#orbitGrad);stroke-width:1}
.hero-particles{position:absolute;inset:0}
.hero-particles span{
  position:absolute;width:3px;height:3px;border-radius:50%;
  background:#7cc7ff;box-shadow:0 0 12px #37a7ff;
  opacity:.55;
  animation:float-p 12s ease-in-out infinite;
}
@keyframes float-p{0%,100%{transform:translateY(0)}50%{transform:translateY(-30px)}}

/* ---- Hero layout ---- */
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,1.15fr);gap:50px;align-items:center;min-height:calc(100vh - 180px)}

.hero-copy h1{
  font-family:'Space Grotesk',sans-serif;
  font-weight:700;
  font-size:clamp(38px,4.8vw,68px);
  line-height:1;
  letter-spacing:-2px;
  margin:22px 0 22px;
  color:#fff;
  text-wrap:balance;
}
.hero-copy h1 .accent{
  background:linear-gradient(120deg,#7cc7ff 0%,#37a7ff 50%,#bfe1ff 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero-copy .lead{font-size:17.5px;line-height:1.65;color:#b2c2dc;max-width:560px;margin-bottom:34px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:38px}

.proof{
  display:grid;grid-template-columns:repeat(2,1fr);gap:10px 14px;
  max-width:560px;
}
.proof-item{
  display:flex;align-items:center;gap:10px;
  padding:11px 14px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  font-size:13px;font-weight:600;color:#cfdcef;
  backdrop-filter:blur(8px);
}
.proof-item .dot{
  width:8px;height:8px;border-radius:50%;flex:0 0 8px;
  background:linear-gradient(135deg,#37a7ff,#83d7ff);
  box-shadow:0 0 10px rgba(55,167,255,.6);
}

/* ============================================================
   ★ NUEVO HERO — CARRUSEL CIRCULAR 3D (.product-orbit)
   ★ AJUSTAR ESCALA: --orbit-front-scale / --orbit-side-scale / --orbit-back-scale
   ★ AJUSTAR TAMAÑO ÓRBITA: --orbit-radius
   (Velocidad / autoplay y textos están en el <script> al final del archivo)
   ============================================================ */
.product-orbit{
  position:relative;
  height:min(620px, 70vh);
  width:100%;
  max-width:560px;
  margin-left:auto;
  margin-right:0;
  padding-bottom:130px;        /* espacio para la tarjeta inferior */
  perspective:1600px;
  transform-style:preserve-3d;
  --orbit-radius:185px;        /* radio orbital reducido */
  --orbit-depth:240px;         /* profundidad hacia atrás */
  --orbit-front-scale:1.18;    /* ESCALA producto activo (1.15–1.28) */
  --orbit-side-scale:.55;      /* escala laterales (.45–.65) */
  --orbit-back-scale:.3;       /* escala traseros (casi invisibles) */
  --orbit-anim:.95s;
  --orbit-ease:cubic-bezier(.6,.05,.2,1);
}
/* mask suave en bordes para que los productos no se corten brusco */
.product-orbit::before{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:25;
  background:
    linear-gradient(90deg, rgba(7,17,38,1) 0%, rgba(7,17,38,0) 12%, rgba(7,17,38,0) 88%, rgba(7,17,38,1) 100%);
  opacity:.55;
}

/* anillo HUD detrás — más sutil */
.orbit-tech-lines{
  position:absolute;left:50%;top:calc(50% - 65px);
  width:520px;height:520px;
  transform:translate(-50%,-50%);
  pointer-events:none;
  opacity:.4;
  animation:orbit-rotate 80s linear infinite;
}
.orbit-tech-lines circle{fill:none;stroke:rgba(124,199,255,.35);stroke-width:1}
.orbit-tech-lines .dash{stroke-dasharray:2 8;stroke:rgba(124,199,255,.45)}
.orbit-tech-lines .tick{stroke:rgba(124,199,255,.7);stroke-width:2}
@keyframes orbit-rotate{from{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}

.orbit-glow{
  position:absolute;left:50%;top:calc(50% - 65px);transform:translate(-50%,-50%);
  width:420px;height:420px;border-radius:50%;
  background:radial-gradient(circle, rgba(55,167,255,.32) 0%, rgba(55,167,255,0) 65%);
  filter:blur(8px);
  pointer-events:none;
  animation:orbit-pulse 6s ease-in-out infinite;
}
@keyframes orbit-pulse{0%,100%{opacity:.55;transform:translate(-50%,-50%) scale(1)}50%{opacity:.8;transform:translate(-50%,-50%) scale(1.06)}}

/* HUD reticle dots on the ring — más sutil */
.orbit-reticle{
  position:absolute;left:50%;top:calc(50% - 65px);
  width:440px;height:440px;
  transform:translate(-50%,-50%);
  pointer-events:none;
  opacity:.55;
}
.orbit-reticle span{
  position:absolute;width:6px;height:6px;border-radius:50%;
  background:#7cc7ff;box-shadow:0 0 10px #37a7ff;
  left:50%;top:50%;
  transform-origin:0 0;
}

/* el "anillo" que contiene los items — ocupa solo la parte superior */
.orbit-ring{
  position:absolute;left:0;right:0;top:0;
  height:calc(100% - 130px);
  display:grid;place-items:center;
  transform-style:preserve-3d;
}

/* items */
.orbit-item{
  position:absolute;
  left:50%;top:50%;
  width:min(280px, 56%);
  height:min(360px, 80%);
  margin-left:calc(min(280px,56%) / -2);
  margin-top:calc(min(360px,80%) / -2);
  display:flex;align-items:center;justify-content:center;
  transform-style:preserve-3d;
  transition:
    transform var(--orbit-anim) var(--orbit-ease),
    opacity var(--orbit-anim) var(--orbit-ease),
    filter var(--orbit-anim) var(--orbit-ease);
  will-change:transform,opacity,filter;
  pointer-events:none;
}
.orbit-item img{
  width:100%;height:100%;
  object-fit:contain;
  filter:drop-shadow(0 30px 50px rgba(0,0,0,.6));
  user-select:none;-webkit-user-drag:none;
  display:block;
}
.orbit-item .halo{
  position:absolute;inset:-10% -8%;
  background:radial-gradient(ellipse at center, rgba(55,167,255,.55) 0%, rgba(55,167,255,0) 60%);
  filter:blur(28px);
  z-index:-1;pointer-events:none;
  opacity:0;transition:opacity var(--orbit-anim) var(--orbit-ease);
}
.orbit-item .scan-frame, .orbit-item .scan-overlay, .orbit-item .scan-tag{display:none}

/* ESTADO ACTIVO: producto al frente, grande, luminoso */
.orbit-item.active{
  z-index:10;
  pointer-events:auto;
}
.orbit-item.active .halo{opacity:1}
.orbit-item.active img{
  filter:
    drop-shadow(0 40px 60px rgba(0,0,0,.7))
    drop-shadow(0 0 40px rgba(55,167,255,.55))
    drop-shadow(0 0 14px rgba(124,199,255,.5));
}

/* Líneas técnicas alrededor del activo */
.orbit-item.active .tech-lines{opacity:1}
.orbit-item .tech-lines{
  position:absolute;inset:-8% -10%;
  pointer-events:none;
  opacity:0;
  transition:opacity .6s ease;
  z-index:-1;
}
.orbit-item .tech-lines::before,
.orbit-item .tech-lines::after{
  content:"";position:absolute;border:1px solid rgba(124,199,255,.45);
}
.orbit-item .tech-lines::before{
  left:0;top:50%;transform:translateY(-50%);
  width:60px;height:1px;
  background:linear-gradient(90deg, transparent, #7cc7ff 60%, #7cc7ff);
  border:none;
}
.orbit-item .tech-lines::after{
  right:0;top:50%;transform:translateY(-50%);
  width:60px;height:1px;
  background:linear-gradient(270deg, transparent, #7cc7ff 60%, #7cc7ff);
  border:none;
}
.orbit-item .tech-corner{position:absolute;width:24px;height:24px;border:2px solid #7cc7ff;opacity:0;transition:opacity .6s ease}
.orbit-item.active .tech-corner{opacity:.9}
.orbit-item .tech-corner.tl{left:-4px;top:-4px;border-right:none;border-bottom:none}
.orbit-item .tech-corner.tr{right:-4px;top:-4px;border-left:none;border-bottom:none}
.orbit-item .tech-corner.bl{left:-4px;bottom:-4px;border-right:none;border-top:none}
.orbit-item .tech-corner.br{right:-4px;bottom:-4px;border-left:none;border-top:none}

/* ficha dinámica — DEBAJO del carrusel, nunca encima */
.orbit-caption{
  position:absolute;
  left:50%;bottom:30px;
  transform:translateX(-50%);
  width:min(420px, 92%);
  padding:14px 20px;
  background:rgba(7,21,44,.72);
  border:1px solid rgba(124,199,255,.28);
  border-radius:14px;
  backdrop-filter:blur(18px) saturate(140%);
  box-shadow:0 20px 50px rgba(0,0,0,.45);
  z-index:20;
  text-align:left;
  transition:opacity .35s ease, transform .35s ease;
}
.orbit-caption .oc-label{
  display:inline-flex;align-items:center;gap:8px;
  font:700 10.5px/1 'Space Grotesk',sans-serif;
  letter-spacing:1.6px;text-transform:uppercase;
  color:#7cc7ff;margin-bottom:8px;
}
.orbit-caption .oc-label::before{content:"";width:6px;height:6px;border-radius:50%;background:#37a7ff;box-shadow:0 0 10px #37a7ff;animation:oc-blink 1.6s ease-in-out infinite}
@keyframes oc-blink{0%,100%{opacity:1}50%{opacity:.35}}
.orbit-caption .oc-name{
  font-family:'Space Grotesk',sans-serif;font-weight:700;
  font-size:18px;line-height:1.15;letter-spacing:-.3px;color:#fff;margin-bottom:4px;
}
.orbit-caption .oc-desc{
  font-size:12.5px;line-height:1.5;color:#a8bcd8;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.orbit-caption.swap{opacity:0;transform:translateX(-50%) translateY(6px)}

/* controles */
.orbit-controls{
  position:absolute;left:0;right:0;top:calc(50% - 95px);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 4%;
  z-index:30;
  pointer-events:none;
}
.orbit-arrow{
  pointer-events:auto;
  width:44px;height:44px;border-radius:50%;
  display:grid;place-items:center;
  background:rgba(7,21,44,.55);
  border:1px solid rgba(124,199,255,.32);
  color:#cfe6ff;
  backdrop-filter:blur(10px);
  cursor:pointer;
  transition:background .25s, border-color .25s, transform .25s;
}
.orbit-arrow:hover{background:rgba(55,167,255,.18);border-color:rgba(124,199,255,.6);transform:scale(1.06)}
.orbit-arrow svg{width:18px;height:18px}

.orbit-dots{
  position:absolute;left:50%;bottom:0;
  transform:translateX(-50%);
  display:flex;gap:8px;
  z-index:30;
}
.orbit-dot{
  pointer-events:auto;
  width:8px;height:8px;border-radius:50%;
  background:rgba(124,199,255,.25);
  border:1px solid rgba(124,199,255,.35);
  cursor:pointer;
  transition:background .25s, transform .25s, width .25s;
}
.orbit-dot.active{
  background:#37a7ff;
  box-shadow:0 0 12px #37a7ff;
  width:22px;border-radius:6px;
}

/* ---- Hero metrics ---- */
.hero-metrics{
  position:relative;z-index:3;
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  margin-top:30px;
  padding:24px 28px;
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.08);
  border-radius:24px;
  backdrop-filter:blur(20px);
}
.hero-metric{padding:6px 18px;border-right:1px solid rgba(255,255,255,.08)}
.hero-metric:last-child{border-right:none}
.hero-metric strong{
  display:block;font-family:'Space Grotesk';font-size:30px;font-weight:700;color:#fff;letter-spacing:-.5px;
}
.hero-metric span{font-size:12.5px;color:#8fa3c2;letter-spacing:.3px;display:block;margin-top:4px}

/* ---- Hero scroll indicator ---- */
.scroll-cue{
  position:absolute;left:50%;bottom:18px;transform:translateX(-50%);
  z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:6px;
  color:#8fa3c2;font:600 11px/1 'Space Grotesk';letter-spacing:2px;text-transform:uppercase;
}
.scroll-cue .bar{
  width:1px;height:32px;background:linear-gradient(180deg,#37a7ff, transparent);
  animation:cue 1.8s ease-in-out infinite;
}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr;gap:30px;min-height:auto}
  .product-orbit{height:580px;margin:10px auto 0;max-width:520px;--orbit-radius:170px;--orbit-front-scale:1.2}
  .hero-metrics{grid-template-columns:repeat(2,1fr);gap:12px}
  .hero-metric{border-right:none;border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:14px}
  .hero-metric:nth-last-child(-n+2){border-bottom:none;padding-bottom:6px}
}
@media(max-width:560px){
  .hero{padding:100px 0 40px}
  .product-orbit{height:480px;padding-bottom:110px;--orbit-radius:120px;--orbit-front-scale:1.12;--orbit-side-scale:.5;--orbit-back-scale:.28}
  .orbit-tech-lines{width:360px;height:360px}
  .orbit-glow{width:280px;height:280px}
  .orbit-reticle{width:300px;height:300px}
  .hero-copy h1{font-size:38px;letter-spacing:-1.2px}
  .proof{grid-template-columns:1fr}
  .hero-metric strong{font-size:24px}
  .orbit-arrow{width:36px;height:36px}
  .orbit-caption{padding:12px 16px;width:min(320px,92%);bottom:24px}
  .orbit-caption .oc-name{font-size:16px}
  .orbit-caption .oc-desc{font-size:11.5px}
}

/* ============================================================
   SECTIONS — premium B2B
   ============================================================ */
.section{padding:120px 0;position:relative}
.section.tight{padding:80px 0}
.section-dark{background:#06122a;color:#e9eef7}
.section-deepdark{background:linear-gradient(180deg,#040b1a 0%, #0a1c38 100%);color:#e9eef7;position:relative;overflow:hidden}
.section-deepdark::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(800px 500px at 20% 10%, rgba(55,167,255,.14), transparent 60%),
    radial-gradient(700px 500px at 90% 80%, rgba(22,100,184,.18), transparent 60%);
  pointer-events:none;
}
.section-deepdark>*{position:relative;z-index:1}

.section-head{max-width:780px;margin:0 auto 56px;text-align:center}
.section-head h2{
  font-family:'Space Grotesk',sans-serif;
  font-weight:700;
  font-size:clamp(30px,3.6vw,48px);
  line-height:1.05;
  letter-spacing:-1.4px;
  margin:18px 0 14px;
  color:#fff;
  text-wrap:balance;
}
.section-head h2 .accent{
  background:linear-gradient(120deg,#7cc7ff,#37a7ff);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.section-head .lead{margin:0 auto;color:#9eb0cc}

/* ---- Reveal anim ---- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ============================================================
   MARQUEE TICKER
   ============================================================ */
.ticker{
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
  padding:22px 0;
  background:rgba(7,21,44,.6);
  overflow:hidden;
}
.ticker-track{
  display:flex;gap:64px;
  animation:tick 38s linear infinite;
  white-space:nowrap;
  width:max-content;
}
.ticker-track span{
  font:700 13px/1 'Space Grotesk';
  letter-spacing:3px;text-transform:uppercase;
  color:#8fa3c2;
  display:flex;align-items:center;gap:14px;
}
.ticker-track span::before{
  content:"";width:6px;height:6px;border-radius:50%;background:#37a7ff;box-shadow:0 0 10px #37a7ff;
}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================
   SOLUTIONS — glass cards grid
   ============================================================ */
.sol-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media(max-width:1000px){.sol-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.sol-grid{grid-template-columns:1fr}}

.sol-card{
  position:relative;
  padding:28px 24px 28px;
  background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.015));
  border:1px solid rgba(255,255,255,.08);
  border-radius:22px;
  backdrop-filter:blur(14px);
  overflow:hidden;
  transition:transform .35s, border-color .35s, background .35s;
}
.sol-card::before{
  content:"";position:absolute;inset:-1px;
  background:linear-gradient(135deg, rgba(55,167,255,.0), rgba(55,167,255,.35) 50%, rgba(55,167,255,0));
  -webkit-mask:linear-gradient(#000,#000) content-box, linear-gradient(#000,#000);
  -webkit-mask-composite:xor;mask-composite:exclude;
  padding:1px;border-radius:22px;opacity:0;transition:opacity .4s;
}
.sol-card:hover{transform:translateY(-6px);border-color:rgba(124,199,255,.3);background:linear-gradient(180deg, rgba(55,167,255,.08), rgba(55,167,255,.02))}
.sol-card:hover::before{opacity:1}
.sol-icon{
  width:48px;height:48px;border-radius:14px;
  background:linear-gradient(135deg, rgba(55,167,255,.2), rgba(22,100,184,.05));
  border:1px solid rgba(124,199,255,.28);
  display:grid;place-items:center;color:#7cc7ff;
  margin-bottom:18px;
}
.sol-icon svg{width:22px;height:22px}
.sol-card .label{font:700 11px/1 'Space Grotesk';letter-spacing:1.5px;text-transform:uppercase;color:#7cc7ff;margin-bottom:8px}
.sol-card h3{font-family:'Space Grotesk';font-size:19px;font-weight:700;color:#fff;letter-spacing:-.3px;margin-bottom:10px}
.sol-card p{font-size:14px;line-height:1.6;color:#a0b4d0}

/* ============================================================
   PROCESS — split layout
   ============================================================ */
.process-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
@media(max-width:980px){.process-grid{grid-template-columns:1fr;gap:40px}}

.process-list{display:flex;flex-direction:column;gap:14px}
.process-row{
  display:grid;grid-template-columns:64px 1fr;gap:18px;
  padding:22px 24px;
  background:rgba(255,255,255,.035);
  border:1px solid rgba(255,255,255,.07);
  border-radius:20px;
  transition:background .3s, border-color .3s;
}
.process-row:hover{background:rgba(55,167,255,.06);border-color:rgba(124,199,255,.25)}
.process-row .n{
  font-family:'Space Grotesk';font-weight:700;font-size:28px;
  color:#37a7ff;letter-spacing:-1px;line-height:1;
}
.process-row h3{font-family:'Space Grotesk';font-size:17px;font-weight:600;color:#fff;margin-bottom:6px}
.process-row p{font-size:14px;line-height:1.6;color:#a0b4d0}

/* ============================================================
   PRODUCTS — featured cards
   ============================================================ */
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:980px){.prod-grid{grid-template-columns:1fr 1fr}}
@media(max-width:620px){.prod-grid{grid-template-columns:1fr}}

.prod-card{
  position:relative;
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.015));
  border:1px solid rgba(255,255,255,.08);
  border-radius:24px;
  overflow:hidden;
  transition:transform .35s, border-color .35s;
}
.prod-card:hover{transform:translateY(-6px);border-color:rgba(124,199,255,.32)}
.prod-visual{
  position:relative;
  aspect-ratio:4/3;
  background:
    radial-gradient(circle at 50% 60%, rgba(55,167,255,.25) 0%, rgba(55,167,255,0) 60%),
    linear-gradient(180deg,#0d2446 0%,#07152c 100%);
  display:grid;place-items:center;
  overflow:hidden;
}
.prod-visual::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(55,167,255,.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(55,167,255,.08) 1px, transparent 1px);
  background-size:32px 32px;
  mask-image:radial-gradient(ellipse at center, #000 30%, transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse at center, #000 30%, transparent 70%);
  opacity:.7;
}
/* ★ CAMBIAR IMÁGENES — los src de las imágenes de producto están abajo */
.prod-visual img{
  position:relative;z-index:1;
  width:65%;height:80%;object-fit:contain;
  filter:drop-shadow(0 20px 35px rgba(0,0,0,.55)) drop-shadow(0 0 30px rgba(55,167,255,.18));
  transition:transform .6s cubic-bezier(.2,.7,.2,1);
}
.prod-card:hover .prod-visual img{transform:scale(1.06) rotate(-2deg)}
.prod-body{padding:24px 24px 26px}
.prod-body .label{font:700 11px/1 'Space Grotesk';letter-spacing:1.5px;text-transform:uppercase;color:#7cc7ff;margin-bottom:8px}
.prod-body h3{font-family:'Space Grotesk';font-size:22px;font-weight:700;color:#fff;letter-spacing:-.5px;margin-bottom:10px}
.prod-body p{font-size:14px;line-height:1.6;color:#a0b4d0;margin-bottom:16px}
.prod-features{display:flex;flex-direction:column;gap:8px}
.prod-features li{
  display:flex;align-items:flex-start;gap:10px;
  font-size:13.5px;color:#cfdcef;line-height:1.5;list-style:none;
}
.prod-features li::before{
  content:"";flex:0 0 6px;width:6px;height:6px;border-radius:50%;
  background:#37a7ff;box-shadow:0 0 8px #37a7ff;margin-top:7px;
}

/* ============================================================
   AUDIENCE / MERCADO  — stat-style cards
   ============================================================ */
.aud-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:900px){.aud-grid{grid-template-columns:1fr}}
.aud-card{
  padding:32px 28px;
  border-radius:22px;
  background:linear-gradient(180deg, rgba(55,167,255,.06), rgba(55,167,255,.01));
  border:1px solid rgba(124,199,255,.16);
  position:relative;overflow:hidden;
}
.aud-card .big{
  font-family:'Space Grotesk';font-weight:700;color:#37a7ff;
  font-size:54px;line-height:1;letter-spacing:-2px;margin-bottom:18px;
}
.aud-card h3{font-family:'Space Grotesk';font-size:19px;font-weight:700;color:#fff;margin-bottom:8px}
.aud-card p{font-size:14px;line-height:1.65;color:#a0b4d0}

/* ============================================================
   VALUE / PROPUESTA DE VALOR
   ============================================================ */
.value-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:900px){.value-grid{grid-template-columns:1fr}}
.value-card{
  position:relative;padding:30px 26px 30px;
  border-radius:22px;
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.012));
  border:1px solid var(--line);
  overflow:hidden;
}
.value-card::after{
  content:"";position:absolute;left:26px;right:26px;top:0;height:2px;
  background:linear-gradient(90deg,#37a7ff,transparent);
  opacity:.7;
}
.value-card .vc-num{
  font:700 11px/1 'Space Grotesk';letter-spacing:1.6px;text-transform:uppercase;
  color:#7cc7ff;margin-bottom:18px;
}
.value-card h3{font-family:'Space Grotesk';font-size:22px;font-weight:700;color:#fff;letter-spacing:-.4px;margin-bottom:12px}
.value-card p{font-size:14.5px;line-height:1.7;color:#a8b8d2}

/* ============================================================
   AUDIENCE TYPE — by client
   ============================================================ */
.audtype-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media(max-width:1000px){.audtype-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.audtype-grid{grid-template-columns:1fr}}
.audtype-card{
  position:relative;padding:28px 24px 26px;
  border-radius:22px;
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.015));
  border:1px solid var(--line);
  transition:transform .35s, border-color .35s;
  display:flex;flex-direction:column;
}
.audtype-card:hover{transform:translateY(-6px);border-color:rgba(124,199,255,.3)}
.at-icon{
  width:48px;height:48px;border-radius:14px;
  background:linear-gradient(135deg,rgba(55,167,255,.22),rgba(55,167,255,.06));
  border:1px solid rgba(55,167,255,.32);
  color:#bfe1ff;display:grid;place-items:center;margin-bottom:18px;
}
.at-icon svg{width:22px;height:22px}
.audtype-card h3{font-family:'Space Grotesk';font-size:18px;font-weight:700;color:#fff;letter-spacing:-.3px;margin-bottom:10px}
.audtype-card p{font-size:14px;line-height:1.65;color:#a0b4d0;margin-bottom:18px;flex:1}
.at-cta{
  font:700 13px/1 'Manrope';color:#7cc7ff;letter-spacing:.2px;
  border-top:1px solid rgba(124,199,255,.18);padding-top:14px;
  transition:color .2s,letter-spacing .25s;
}
.at-cta:hover{color:#bfe1ff;letter-spacing:.5px}

/* ============================================================
   EQUIPOS principales
   ============================================================ */
.eq-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
@media(max-width:880px){.eq-grid{grid-template-columns:1fr}}
.eq-card{
  position:relative;border-radius:24px;overflow:hidden;
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.015));
  border:1px solid var(--line);
  display:grid;grid-template-rows:auto 1fr;
  transition:transform .35s,border-color .35s;
}
.eq-card:hover{transform:translateY(-6px);border-color:rgba(124,199,255,.32)}
.eq-visual{
  position:relative;aspect-ratio:16/9;
  background:radial-gradient(60% 80% at 50% 60%, rgba(55,167,255,.22), transparent 70%),linear-gradient(180deg,#0b1e3a 0%,#07152c 100%);
  display:grid;place-items:center;overflow:hidden;
  border-bottom:1px solid var(--line);
}
.eq-visual.single img{max-width:62%;max-height:78%;object-fit:contain;filter:drop-shadow(0 25px 40px rgba(0,0,0,.5))}
.eq-img-stack{display:flex;gap:18px;align-items:flex-end;justify-content:center;width:100%;height:100%;padding:8% 6%}
.eq-img-stack img{height:78%;object-fit:contain;filter:drop-shadow(0 25px 40px rgba(0,0,0,.5));transition:transform .5s}
.eq-img-stack img:nth-child(2){height:90%}
.eq-card:hover .eq-img-stack img{transform:translateY(-4px)}
.eq-body{padding:24px 26px 26px;display:flex;flex-direction:column;gap:10px}
.eq-body .label{font:700 11px/1 'Space Grotesk';letter-spacing:1.5px;text-transform:uppercase;color:#7cc7ff}
.eq-body h3{font-family:'Space Grotesk';font-size:22px;font-weight:700;color:#fff;letter-spacing:-.4px}
.eq-body p{font-size:14.5px;line-height:1.65;color:#a8b8d2}
.eq-bullets{list-style:none;padding:0;margin:4px 0 6px;display:flex;flex-direction:column;gap:8px}
.eq-bullets li{position:relative;padding-left:22px;font-size:14px;line-height:1.55;color:#c7d4ec}
.eq-bullets li::before{
  content:"";position:absolute;left:0;top:7px;width:10px;height:10px;border-radius:50%;
  background:radial-gradient(circle,#7cc7ff,#1664b8);box-shadow:0 0 10px rgba(55,167,255,.6);
}
.eq-body .btn{align-self:flex-start;margin-top:8px}

/* ============================================================
   UNIDAD MODELO
   ============================================================ */
.model-wrap{
  display:grid;grid-template-columns:1.05fr 1fr;gap:60px;align-items:center;
  padding:48px;border-radius:32px;
  background:linear-gradient(135deg,rgba(55,167,255,.10),rgba(55,167,255,.02));
  border:1px solid rgba(124,199,255,.18);
}
@media(max-width:900px){.model-wrap{grid-template-columns:1fr;padding:32px;gap:36px}}
.model-cards{display:flex;flex-direction:column;gap:16px}
.model-row{
  display:grid;grid-template-columns:54px 1fr;gap:18px;align-items:flex-start;
  padding:20px 22px;border-radius:18px;
  background:rgba(7,21,44,.55);
  border:1px solid var(--line);
}
.mr-icon{
  width:54px;height:54px;border-radius:14px;
  background:linear-gradient(135deg,rgba(55,167,255,.22),rgba(55,167,255,.06));
  border:1px solid rgba(55,167,255,.32);color:#bfe1ff;
  display:grid;place-items:center;
}
.mr-icon svg{width:24px;height:24px}
.model-row h3{font-family:'Space Grotesk';font-size:17px;font-weight:700;color:#fff;margin-bottom:6px}
.model-row p{font-size:13.5px;line-height:1.6;color:#a8b8d2}

/* ============================================================
   AC / Aires
   ============================================================ */
.ac-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:36px}
@media(max-width:1000px){.ac-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.ac-grid{grid-template-columns:1fr}}
.ac-card{
  padding:28px 24px;border-radius:22px;
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.015));
  border:1px solid var(--line);
  transition:transform .35s,border-color .35s;
}
.ac-card:hover{transform:translateY(-6px);border-color:rgba(124,199,255,.3)}
.ac-icon{
  width:48px;height:48px;border-radius:14px;
  background:linear-gradient(135deg,rgba(55,167,255,.22),rgba(55,167,255,.06));
  border:1px solid rgba(55,167,255,.32);
  color:#bfe1ff;display:grid;place-items:center;margin-bottom:18px;
}
.ac-icon svg{width:22px;height:22px}
.ac-card h3{font-family:'Space Grotesk';font-size:18px;font-weight:700;color:#fff;letter-spacing:-.3px;margin-bottom:10px}
.ac-card p{font-size:14px;line-height:1.65;color:#a0b4d0}
.section-cta{display:flex;justify-content:center;margin-top:12px}

/* ============================================================
   CONTACTO — form + side card
   ============================================================ */
.contact-wrap{
  display:grid;grid-template-columns:1.4fr 1fr;gap:28px;align-items:start;
}
@media(max-width:980px){.contact-wrap{grid-template-columns:1fr}}
.contact-form{
  padding:36px;border-radius:28px;
  background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.012));
  border:1px solid var(--line);
  display:flex;flex-direction:column;gap:18px;
}
.contact-form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:620px){.contact-form .row{grid-template-columns:1fr}}
.contact-form .field{display:flex;flex-direction:column;gap:8px}
.contact-form label{
  font:700 11.5px/1 'Space Grotesk';letter-spacing:1.4px;text-transform:uppercase;
  color:#7cc7ff;
}
.contact-form input,
.contact-form select,
.contact-form textarea{
  width:100%;padding:14px 16px;
  background:rgba(7,21,44,.55);
  border:1px solid rgba(124,199,255,.18);
  border-radius:14px;color:#e9eef7;
  font:500 14.5px/1.4 'Manrope';
  transition:border-color .2s,background .2s;
}
.contact-form textarea{min-height:120px;resize:vertical;line-height:1.55}
.contact-form select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,#7cc7ff 50%),linear-gradient(135deg,#7cc7ff 50%,transparent 50%);background-position:calc(100% - 20px) 50%,calc(100% - 14px) 50%;background-size:6px 6px,6px 6px;background-repeat:no-repeat;padding-right:42px}
.contact-form select option{background:#07152c;color:#e9eef7}
.contact-form input::placeholder,
.contact-form textarea::placeholder{color:#6e7e98}
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus{outline:none;border-color:#37a7ff;background:rgba(7,21,44,.75)}
.checks{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:520px){.checks{grid-template-columns:1fr}}
.check{
  display:flex;align-items:center;gap:10px;
  padding:12px 14px;border-radius:12px;
  background:rgba(7,21,44,.5);
  border:1px solid rgba(124,199,255,.14);
  font-size:13.5px;color:#c7d4ec;cursor:pointer;
  font-weight:500;letter-spacing:0;text-transform:none;
}
.check input{accent-color:#37a7ff;width:16px;height:16px}
.check:hover{border-color:rgba(124,199,255,.32)}
.submit-row{display:flex;flex-wrap:wrap;align-items:center;gap:16px;margin-top:6px}
.submit-note{font-size:12.5px;color:#8896ad}

.contact-side{display:flex;flex-direction:column;gap:18px}
.contact-card{
  padding:32px;border-radius:24px;
  background:linear-gradient(180deg,rgba(55,167,255,.12),rgba(55,167,255,.02));
  border:1px solid rgba(124,199,255,.22);
}
.contact-card h3{font-family:'Space Grotesk';font-size:20px;font-weight:700;color:#fff;letter-spacing:-.3px;margin-bottom:10px}
.contact-card p{font-size:14px;line-height:1.65;color:#bfd0ec;margin-bottom:20px}
.contact-channels{display:flex;flex-direction:column;gap:12px}
.contact-channel{
  display:grid;grid-template-columns:46px 1fr;gap:14px;align-items:center;
  padding:14px 16px;border-radius:14px;
  background:rgba(7,21,44,.45);
  border:1px solid rgba(124,199,255,.18);
  transition:transform .25s,border-color .25s,background .25s;
}
.contact-channel:hover{transform:translateY(-2px);border-color:rgba(124,199,255,.38);background:rgba(7,21,44,.65)}
.cc-icon{
  width:46px;height:46px;border-radius:12px;display:grid;place-items:center;
  background:rgba(55,167,255,.14);color:#bfe1ff;
}
.cc-icon.wa{background:linear-gradient(135deg,#25d366,#128c7e);color:#fff}
.cc-icon svg{width:22px;height:22px}
.contact-channel b{display:block;font-family:'Space Grotesk';font-size:14.5px;color:#fff;letter-spacing:-.2px}
.contact-channel span{display:block;font-size:13px;color:#a0b4d0;margin-top:2px}

/* ============================================================
   CASE STUDY — feature panel
   ============================================================ */
.case-wrap{
  display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center;
  padding:60px 56px;
  background:
    radial-gradient(600px 400px at 100% 0%, rgba(55,167,255,.15), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border:1px solid rgba(255,255,255,.08);
  border-radius:32px;
  position:relative;overflow:hidden;
}
@media(max-width:960px){.case-wrap{grid-template-columns:1fr;padding:36px 28px;gap:32px}}
.case-visual{
  aspect-ratio:1/1;
  border-radius:24px;
  background:
    radial-gradient(circle at 50% 50%, rgba(55,167,255,.4) 0%, rgba(55,167,255,0) 60%),
    linear-gradient(180deg,#0d2446 0%,#07152c 100%);
  position:relative;overflow:hidden;
  display:grid;place-items:center;
}
.case-visual::before{
  content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(55,167,255,.08) 1px, transparent 1px),linear-gradient(90deg, rgba(55,167,255,.08) 1px, transparent 1px);
  background-size:40px 40px;
  mask-image:radial-gradient(ellipse at center, #000 30%, transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse at center, #000 30%, transparent 70%);
}
.case-visual .case-stat{
  position:relative;z-index:1;text-align:center;
}
.case-visual .case-stat strong{
  display:block;font-family:'Space Grotesk';font-weight:700;
  font-size:108px;line-height:1;letter-spacing:-4px;
  background:linear-gradient(120deg,#7cc7ff,#37a7ff);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.case-visual .case-stat span{display:block;margin-top:10px;color:#cfe6ff;font-size:14px;letter-spacing:1.5px;text-transform:uppercase;font-weight:700}
.case-list{display:flex;flex-direction:column;gap:14px;margin-top:24px}
.case-item{
  padding:18px 20px;border-left:2px solid #37a7ff;
  background:rgba(255,255,255,.03);
  border-radius:0 14px 14px 0;
}
.case-item b{display:block;color:#fff;font:700 15px/1.2 'Space Grotesk';margin-bottom:6px}
.case-item span{color:#a0b4d0;font-size:13.5px;line-height:1.55;display:block}

/* ============================================================
   CTA STRIP
   ============================================================ */
.cta-strip{
  position:relative;
  padding:80px 56px;
  border-radius:32px;
  overflow:hidden;
  background:
    radial-gradient(800px 400px at 0% 0%, rgba(55,167,255,.3), transparent 60%),
    radial-gradient(800px 400px at 100% 100%, rgba(22,100,184,.4), transparent 60%),
    linear-gradient(135deg,#0d2446,#07152c);
  border:1px solid rgba(124,199,255,.22);
  text-align:center;
}
.cta-strip::before{
  content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(55,167,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(55,167,255,.06) 1px,transparent 1px);
  background-size:50px 50px;
  mask-image:radial-gradient(ellipse at center,#000 30%,transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at center,#000 30%,transparent 75%);
}
.cta-strip>*{position:relative;z-index:1}
.cta-strip h2{font-family:'Space Grotesk';font-weight:700;font-size:clamp(28px,3.4vw,42px);letter-spacing:-1.2px;line-height:1.05;color:#fff;max-width:780px;margin:14px auto 14px;text-wrap:balance}
.cta-strip p{color:#bfd0ec;font-size:16.5px;line-height:1.65;max-width:640px;margin:0 auto 28px}
.cta-strip .hero-actions{justify-content:center;margin:0}
@media(max-width:680px){.cta-strip{padding:54px 24px}}

/* ============================================================
   FAQ
   ============================================================ */
.faq-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:960px){.faq-grid{grid-template-columns:1fr}}
.faq-card{
  padding:24px 24px;background:rgba(255,255,255,.035);
  border:1px solid rgba(255,255,255,.07);border-radius:18px;
}
.faq-card h3{font-family:'Space Grotesk';font-size:16px;font-weight:600;color:#fff;margin-bottom:8px}
.faq-card p{font-size:14px;line-height:1.65;color:#a0b4d0}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{
  background:#040b1a;
  padding:80px 0 36px;
  border-top:1px solid rgba(255,255,255,.06);
}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;align-items:start}
@media(max-width:780px){.footer-grid{grid-template-columns:1fr 1fr}}
.footer h4{font:700 12px/1 'Space Grotesk';letter-spacing:1.5px;text-transform:uppercase;color:#7cc7ff;margin-bottom:18px}
.footer a{display:block;padding:6px 0;color:#a0b4d0;font-size:14px}
.footer a:hover{color:#fff}
.footer-bottom{
  margin-top:50px;padding-top:24px;border-top:1px solid rgba(255,255,255,.06);
  display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;
  font-size:13px;color:#6b80a3;
}

/* ============================================================
   FLOAT WHATSAPP
   ============================================================ */
.float-wa{
  position:fixed;bottom:20px;right:20px;z-index:80;
  width:56px;height:56px;border-radius:50%;
  background:linear-gradient(135deg,#25d366,#128c7e);
  display:grid;place-items:center;color:#fff;
  box-shadow:0 14px 30px rgba(37,211,102,.45);
  transition:transform .25s;
}
.float-wa:hover{transform:scale(1.08)}
.float-wa svg{width:26px;height:26px}
.float-wa::after{
  content:"";position:absolute;inset:-6px;border-radius:50%;
  border:2px solid rgba(37,211,102,.5);
  animation:wa-ping 2s ease-out infinite;
}
@keyframes wa-ping{0%{transform:scale(1);opacity:.6}100%{transform:scale(1.5);opacity:0}}

/* small util */
.text-muted{color:#9eb0cc}
.divider{height:1px;background:linear-gradient(90deg,transparent,rgba(124,199,255,.25),transparent);margin:0}

/* ============================================================
   VALUE PROP — 3 cards
   ============================================================ */
.value-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:900px){.value-grid{grid-template-columns:1fr}}
.value-card{
  position:relative;padding:30px 28px;border-radius:22px;
  background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.012));
  border:1px solid rgba(255,255,255,.08);
  backdrop-filter:blur(14px);
  overflow:hidden;
  transition:transform .35s, border-color .35s, background .35s;
}
.value-card:hover{transform:translateY(-4px);border-color:rgba(124,199,255,.32)}
.value-card .vc-num{
  font-family:'Space Grotesk';font-weight:700;font-size:14px;letter-spacing:2px;
  color:#37a7ff;margin-bottom:14px;
}
.value-card h3{font-family:'Space Grotesk';font-size:22px;font-weight:700;color:#fff;letter-spacing:-.4px;margin-bottom:10px;line-height:1.15}
.value-card p{font-size:14.5px;line-height:1.6;color:#a0b4d0}

/* ============================================================
   AUDIENCE-TYPE CARDS — soluciones por tipo de cliente
   ============================================================ */
.audtype-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media(max-width:1100px){.audtype-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.audtype-grid{grid-template-columns:1fr}}
.audtype-card{
  position:relative;padding:28px 24px;border-radius:22px;
  background:linear-gradient(180deg, rgba(55,167,255,.07), rgba(55,167,255,.01));
  border:1px solid rgba(124,199,255,.18);
  overflow:hidden;
  transition:transform .35s, border-color .35s, background .35s;
  display:flex;flex-direction:column;gap:14px;
}
.audtype-card:hover{transform:translateY(-4px);border-color:rgba(124,199,255,.4);background:linear-gradient(180deg, rgba(55,167,255,.12), rgba(55,167,255,.02))}
.audtype-card .at-icon{
  width:46px;height:46px;border-radius:12px;
  background:linear-gradient(135deg, rgba(55,167,255,.22), rgba(22,100,184,.06));
  border:1px solid rgba(124,199,255,.3);
  display:grid;place-items:center;color:#7cc7ff;
}
.audtype-card .at-icon svg{width:22px;height:22px}
.audtype-card h3{font-family:'Space Grotesk';font-size:18px;font-weight:700;color:#fff;letter-spacing:-.3px;line-height:1.2}
.audtype-card p{font-size:13.5px;line-height:1.6;color:#a0b4d0;flex:1}
.audtype-card .at-cta{
  display:inline-flex;align-items:center;gap:6px;
  font:700 12.5px/1 'Space Grotesk';letter-spacing:.4px;
  color:#7cc7ff;margin-top:auto;
  transition:gap .2s, color .2s;
}
.audtype-card .at-cta:hover{gap:10px;color:#bfe1ff}

/* ============================================================
   EQUIPMENT CATEGORIES — 4 cards with bullets + CTA
   ============================================================ */
.eq-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
@media(max-width:780px){.eq-grid{grid-template-columns:1fr}}
.eq-card{
  position:relative;border-radius:24px;overflow:hidden;
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.015));
  border:1px solid rgba(255,255,255,.08);
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.3fr);
  transition:transform .35s, border-color .35s;
}
@media(max-width:560px){.eq-card{grid-template-columns:1fr}}
.eq-card:hover{transform:translateY(-4px);border-color:rgba(124,199,255,.32)}
.eq-visual{
  position:relative;
  aspect-ratio:1/1;
  background:
    radial-gradient(circle at 50% 55%, rgba(55,167,255,.22) 0%, rgba(55,167,255,0) 60%),
    linear-gradient(180deg,#0d2446 0%,#07152c 100%);
  display:grid;place-items:center;
  overflow:hidden;
}
@media(max-width:560px){.eq-visual{aspect-ratio:16/10}}
.eq-visual::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(55,167,255,.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(55,167,255,.08) 1px, transparent 1px);
  background-size:28px 28px;
  mask-image:radial-gradient(ellipse at center, #000 30%, transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse at center, #000 30%, transparent 70%);
  opacity:.6;
}
.eq-visual .eq-img-stack{
  position:relative;z-index:1;
  display:flex;align-items:flex-end;justify-content:center;
  gap:8px;width:88%;height:78%;
}
.eq-visual .eq-img-stack img{
  height:100%;width:auto;max-width:62%;object-fit:contain;
  filter:drop-shadow(0 20px 35px rgba(0,0,0,.55)) drop-shadow(0 0 25px rgba(55,167,255,.2));
  transition:transform .6s cubic-bezier(.2,.7,.2,1);
}
.eq-visual .eq-img-stack img:nth-child(2){height:78%;opacity:.85}
.eq-visual .eq-img-stack img:nth-child(3){height:64%;opacity:.65}
.eq-card:hover .eq-visual .eq-img-stack img:first-child{transform:scale(1.05) rotate(-2deg)}
.eq-visual.single img{
  position:relative;z-index:1;
  width:62%;height:78%;object-fit:contain;
  filter:drop-shadow(0 20px 35px rgba(0,0,0,.55)) drop-shadow(0 0 25px rgba(55,167,255,.2));
  transition:transform .6s cubic-bezier(.2,.7,.2,1);
}
.eq-card:hover .eq-visual.single img{transform:scale(1.06) rotate(-2deg)}
.eq-body{padding:28px 26px 26px;display:flex;flex-direction:column;gap:12px}
.eq-body .label{font:700 11px/1 'Space Grotesk';letter-spacing:1.5px;text-transform:uppercase;color:#7cc7ff}
.eq-body h3{font-family:'Space Grotesk';font-size:22px;font-weight:700;color:#fff;letter-spacing:-.5px;line-height:1.1}
.eq-body p{font-size:14px;line-height:1.6;color:#a0b4d0}
.eq-bullets{display:flex;flex-direction:column;gap:8px;list-style:none;padding:0;margin:4px 0 8px}
.eq-bullets li{
  display:flex;align-items:flex-start;gap:10px;
  font-size:13.5px;color:#cfdcef;line-height:1.5;
}
.eq-bullets li::before{
  content:"";flex:0 0 6px;width:6px;height:6px;border-radius:50%;
  background:#37a7ff;box-shadow:0 0 8px #37a7ff;margin-top:7px;
}
.eq-body .btn{align-self:flex-start;margin-top:6px;padding:12px 20px;font-size:13px}

/* ============================================================
   UNIDAD MODELO — split panel
   ============================================================ */
.model-wrap{
  display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center;
  padding:56px 52px;
  background:
    radial-gradient(700px 400px at 100% 0%, rgba(55,167,255,.18), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border:1px solid rgba(124,199,255,.18);
  border-radius:32px;
  position:relative;overflow:hidden;
}
@media(max-width:960px){.model-wrap{grid-template-columns:1fr;padding:36px 28px;gap:30px}}
.model-cards{display:grid;grid-template-columns:1fr;gap:12px}
.model-row{
  display:grid;grid-template-columns:42px 1fr;gap:16px;
  padding:18px 20px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);
  border-radius:16px;
  transition:background .3s, border-color .3s;
}
.model-row:hover{background:rgba(55,167,255,.08);border-color:rgba(124,199,255,.3)}
.model-row .mr-icon{
  width:42px;height:42px;border-radius:12px;
  background:linear-gradient(135deg, rgba(55,167,255,.22), rgba(22,100,184,.06));
  border:1px solid rgba(124,199,255,.3);
  display:grid;place-items:center;color:#7cc7ff;
}
.model-row .mr-icon svg{width:20px;height:20px}
.model-row h3{font-family:'Space Grotesk';font-size:16px;font-weight:600;color:#fff;margin-bottom:4px}
.model-row p{font-size:13.5px;line-height:1.55;color:#a0b4d0}

/* ============================================================
   AIRES SECTION — 4 cards
   ============================================================ */
.ac-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media(max-width:1024px){.ac-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.ac-grid{grid-template-columns:1fr}}
.ac-card{
  padding:26px 22px;border-radius:20px;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.012));
  border:1px solid rgba(255,255,255,.08);
  display:flex;flex-direction:column;gap:12px;
  transition:transform .3s, border-color .3s, background .3s;
}
.ac-card:hover{transform:translateY(-4px);border-color:rgba(124,199,255,.3);background:linear-gradient(180deg, rgba(55,167,255,.08), rgba(55,167,255,.02))}
.ac-icon{
  width:44px;height:44px;border-radius:12px;
  background:linear-gradient(135deg, rgba(55,167,255,.22), rgba(22,100,184,.06));
  border:1px solid rgba(124,199,255,.3);
  display:grid;place-items:center;color:#7cc7ff;
}
.ac-icon svg{width:20px;height:20px}
.ac-card h3{font-family:'Space Grotesk';font-size:17px;font-weight:600;color:#fff;line-height:1.2}
.ac-card p{font-size:13.5px;line-height:1.6;color:#a0b4d0}

/* ============================================================
   CONTACT FORM
   ============================================================ */
.contact-wrap{
  display:grid;grid-template-columns:1.45fr .9fr;gap:32px;align-items:start;
}
@media(max-width:980px){.contact-wrap{grid-template-columns:1fr}}
.contact-form{
  padding:36px 34px;
  background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.012));
  border:1px solid rgba(255,255,255,.08);
  border-radius:24px;
  backdrop-filter:blur(14px);
}
.contact-form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
@media(max-width:680px){.contact-form .row{grid-template-columns:1fr}}
.contact-form .field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.contact-form label{
  font:700 11px/1 'Space Grotesk';letter-spacing:1.4px;text-transform:uppercase;
  color:#9eb0cc;
}
.contact-form input[type="text"],
.contact-form input[type="email"],
.contact-form input[type="tel"],
.contact-form select,
.contact-form textarea{
  width:100%;padding:13px 16px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);
  border-radius:12px;
  color:#eaf2ff;font:500 14.5px/1.4 'Manrope',sans-serif;
  transition:border-color .25s, background .25s;
  font-family:inherit;
}
.contact-form select{
  appearance:none;-webkit-appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'><path d='M1 1.5l5 5 5-5' stroke='%237cc7ff' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat:no-repeat;background-position:right 16px center;
  padding-right:40px;
}
.contact-form select option{background:#0d2446;color:#fff}
.contact-form textarea{resize:vertical;min-height:110px}
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus{
  outline:none;border-color:rgba(124,199,255,.55);
  background:rgba(55,167,255,.07);
}
.contact-form input::placeholder,
.contact-form textarea::placeholder{color:#6b80a3}
.checks{
  display:grid;grid-template-columns:1fr 1fr;gap:8px 12px;
  margin-top:6px;
}
@media(max-width:560px){.checks{grid-template-columns:1fr}}
.check{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:10px;
  background:rgba(255,255,255,.035);
  border:1px solid rgba(255,255,255,.08);
  cursor:pointer;
  font-size:13px;color:#cfdcef;
  transition:background .2s, border-color .2s;
  user-select:none;
}
.check:hover{background:rgba(55,167,255,.08);border-color:rgba(124,199,255,.3)}
.check input{
  appearance:none;-webkit-appearance:none;
  width:16px;height:16px;border-radius:4px;
  border:1.5px solid rgba(124,199,255,.5);
  background:transparent;cursor:pointer;
  display:grid;place-items:center;
  transition:background .2s, border-color .2s;
  flex:0 0 16px;
}
.check input:checked{background:#37a7ff;border-color:#37a7ff}
.check input:checked::after{
  content:"";width:8px;height:5px;border-left:2px solid #fff;border-bottom:2px solid #fff;
  transform:rotate(-45deg) translateY(-1px);
}
.contact-form .submit-row{margin-top:8px;display:flex;flex-wrap:wrap;gap:12px;align-items:center}
.contact-form .submit-note{font-size:12.5px;color:#8fa3c2;line-height:1.5}

.contact-side{display:flex;flex-direction:column;gap:16px}
.contact-card{
  padding:28px 26px;border-radius:22px;
  background:linear-gradient(180deg, rgba(55,167,255,.1), rgba(55,167,255,.02));
  border:1px solid rgba(124,199,255,.22);
}
.contact-card h3{font-family:'Space Grotesk';font-size:18px;font-weight:700;color:#fff;margin-bottom:6px}
.contact-card p{font-size:14px;line-height:1.6;color:#bfd0ec;margin-bottom:18px}
.contact-channels{display:flex;flex-direction:column;gap:10px}
.contact-channel{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;border-radius:12px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  transition:background .25s, border-color .25s, transform .25s;
}
.contact-channel:hover{background:rgba(55,167,255,.1);border-color:rgba(124,199,255,.35);transform:translateX(3px)}
.contact-channel .cc-icon{
  width:36px;height:36px;border-radius:10px;
  display:grid;place-items:center;
  background:rgba(255,255,255,.06);color:#7cc7ff;flex:0 0 36px;
}
.contact-channel .cc-icon svg{width:18px;height:18px}
.contact-channel .cc-icon.wa{background:linear-gradient(135deg,#25d366,#128c7e);color:#fff}
.contact-channel b{display:block;color:#fff;font:700 14px/1.2 'Manrope';margin-bottom:2px}
.contact-channel span{font-size:12.5px;color:#9eb0cc}

/* SECTION CTA HELPER */
.section-cta{display:flex;justify-content:center;margin-top:36px}

/* ==========================================================
   SUBPÁGINAS · Tecnología Smart / Seguridad / Climatización / Tienda
   (estilos compartidos por las páginas internas)
   ========================================================== */
.subhero{
  padding:160px 0 60px;position:relative;overflow:hidden;
  background:radial-gradient(900px 500px at 80% 20%,rgba(55,167,255,.18),transparent 60%),#040b1a;
}
.subhero::before{
  content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(55,167,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(55,167,255,.06) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse at 50% 40%,#000 30%,transparent 75%);
  pointer-events:none;
}
.subhero .container{position:relative}
.subhero h1{
  font-family:'Space Grotesk','Manrope',sans-serif;font-weight:700;
  font-size:clamp(34px,5vw,62px);line-height:1.04;letter-spacing:-1.4px;
  color:#fff;margin:18px 0 18px;text-wrap:balance;max-width:22ch;
}
.subhero h1 .accent{
  background:linear-gradient(120deg,#7cc7ff 0%,#37a7ff 45%,#bfe1ff 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.subhero .lead{max-width:65ch;margin-bottom:28px}

.crumbs{
  font:600 12px/1 'Space Grotesk',sans-serif;letter-spacing:1.4px;
  text-transform:uppercase;color:#7cc7ff;display:flex;gap:10px;align-items:center;
}
.crumbs a{color:#7cc7ff;opacity:.7}
.crumbs a:hover{opacity:1}
.crumbs span{opacity:.4}

.feat-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.feat-card{
  padding:32px 30px;border-radius:24px;
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.015));
  border:1px solid var(--line);transition:transform .35s,border-color .35s;
  display:flex;flex-direction:column;gap:14px;
}
.feat-card:hover{transform:translateY(-6px);border-color:rgba(124,199,255,.32)}
.feat-card .label{
  font:700 11px/1 'Space Grotesk',sans-serif;letter-spacing:1.5px;
  text-transform:uppercase;color:#7cc7ff;
}
.feat-card h3{
  font-family:'Space Grotesk','Manrope',sans-serif;font-size:24px;
  font-weight:700;color:#fff;letter-spacing:-.4px;
}
.feat-card p{font-size:14.5px;line-height:1.65;color:#a8b8d2}
.feat-card ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:8px}
.feat-card li{position:relative;padding-left:22px;font-size:14px;line-height:1.55;color:#c7d4ec}
.feat-card li::before{
  content:"";position:absolute;left:0;top:7px;width:10px;height:10px;border-radius:50%;
  background:radial-gradient(circle,#7cc7ff,#1664b8);box-shadow:0 0 10px rgba(55,167,255,.5);
}
.feat-card .btn{align-self:flex-start;margin-top:6px}

.brand-strip{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.brand-chip{
  padding:10px 18px;border-radius:999px;
  background:rgba(255,255,255,.04);border:1px solid rgba(124,199,255,.22);
  font:700 13px/1 'Space Grotesk',sans-serif;letter-spacing:.5px;color:#bfe1ff;
}

.scen-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.scen-card{
  padding:24px 20px;border-radius:18px;background:rgba(7,21,44,.55);
  border:1px solid var(--line);text-align:left;
}
.scen-card h4{font-family:'Space Grotesk','Manrope',sans-serif;font-size:16px;color:#fff;margin-bottom:8px}
.scen-card p{font-size:13px;line-height:1.55;color:#a0b4d0}

@media(max-width:980px){.scen-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:900px){.feat-grid{grid-template-columns:1fr}}
@media(max-width:520px){.scen-grid{grid-template-columns:1fr}}

/* ==========================================================
   TIENDA (catálogo)
   ========================================================== */
.cat-filter{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:30px}
.chip{
  padding:10px 16px;border-radius:999px;
  background:rgba(255,255,255,.04);border:1px solid rgba(124,199,255,.22);
  font:700 12.5px/1 'Space Grotesk',sans-serif;letter-spacing:.4px;color:#bfe1ff;
  cursor:pointer;transition:background .2s,border-color .2s,transform .2s;
}
.chip:hover{transform:translateY(-2px);border-color:rgba(124,199,255,.45)}
.chip.on{
  background:linear-gradient(135deg,#37a7ff,#1664b8);color:#fff;
  border-color:transparent;box-shadow:0 10px 24px rgba(55,167,255,.32);
}

.prod-list{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.shop-card{
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.015));
  border:1px solid var(--line);border-radius:22px;overflow:hidden;
  display:flex;flex-direction:column;transition:transform .35s,border-color .35s;
}
.shop-card:hover{transform:translateY(-6px);border-color:rgba(124,199,255,.32)}
.shop-card.hide{display:none}
.shop-visual{
  aspect-ratio:4/3;
  background:radial-gradient(60% 80% at 50% 60%,rgba(55,167,255,.22),transparent 70%),linear-gradient(180deg,#0b1e3a,#07152c);
  display:grid;place-items:center;border-bottom:1px solid var(--line);
}
.shop-visual img{max-width:62%;max-height:78%;object-fit:contain;filter:drop-shadow(0 20px 32px rgba(0,0,0,.5))}
.shop-body{padding:22px 22px 24px;display:flex;flex-direction:column;gap:8px;flex:1}
.shop-body .label{
  font:700 11px/1 'Space Grotesk',sans-serif;letter-spacing:1.4px;
  text-transform:uppercase;color:#7cc7ff;
}
.shop-body h3{font-family:'Space Grotesk','Manrope',sans-serif;font-size:18px;font-weight:700;color:#fff;letter-spacing:-.3px}
.shop-body p{font-size:13.5px;line-height:1.6;color:#a8b8d2}
.price-note{font-size:12px;color:#7888a3;font-style:italic}
.shop-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:auto;padding-top:10px}
.shop-actions .btn{padding:11px 16px;font-size:12.5px;flex:1;min-width:140px}

@media(max-width:980px){.prod-list{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.prod-list{grid-template-columns:1fr}}

/* ==========================================================
   MOBILE TUNING
   ========================================================== */
@media(max-width:760px){
  .topbar .links{display:none}
  .nav-cta .btn-wa{padding:11px 16px;font-size:12.5px}
  .subhero{padding:130px 0 40px}
  .hero{padding-top:120px}
}
