:root{
  --bg:#050505;
  --bg2:#0b0b0b;
  --card:rgba(255,255,255,.06);
  --card2:rgba(255,255,255,.09);
  --line:rgba(255,255,255,.10);
  --text:rgba(255,255,255,.92);
  --muted:rgba(255,255,255,.70);
  --muted2:rgba(255,255,255,.55);
  --accent:#7c3aed;   /* púrpura neón */
  --accent2:#22d3ee;  /* cian */
  --shadow: 0 18px 60px rgba(0,0,0,.55);
  --radius: 18px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Manrope, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background:radial-gradient(1200px 700px at 20% 0%, rgba(124,58,237,.18), transparent 55%),
             radial-gradient(900px 600px at 85% 15%, rgba(34,211,238,.14), transparent 55%),
             linear-gradient(180deg, var(--bg), var(--bg2));
  color:var(--text);
}

a{color:inherit; text-decoration:none}
.container{width:min(1150px, 92vw); margin-inline:auto}

.scroll-progress{
  position:fixed; inset:0 0 auto 0; height:3px;
  background:linear-gradient(90deg, var(--accent), var(--accent2));
  width:0%;
  z-index:9999;
}

.header{
  position:sticky; top:0; z-index:999;
  background:rgba(0,0,0,.55);
  backdrop-filter: blur(14px);
  border-bottom:1px solid var(--line);
}

.nav{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 0;
}

.brand{display:flex; align-items:center; gap:10px}
.logo{height:34px; width:auto}
.logo-fallback{
  font-weight:800; letter-spacing:.22em;
}

.nav__links{
  display:flex; gap:18px; align-items:center;
}
.nav__links a{
  opacity:.85;
  padding:10px 10px;
  border-radius:999px;
  transition: .2s ease;
}
.nav__links a:hover{
  opacity:1;
  background:rgba(255,255,255,.06);
}
.nav__links .pill{
  border:1px solid var(--line);
  background:rgba(255,255,255,.05);
}

.nav__toggle{
  display:none;
  width:44px; height:40px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  border-radius:12px;
  cursor:pointer;
}
.nav__toggle span{
  display:block; height:2px; width:18px;
  background:rgba(255,255,255,.85);
  margin:5px auto;
  border-radius:2px;
}

.hero{
  position:relative;
  padding:62px 0 38px;
}
.hero__bg{
  position:absolute; inset:0;
  background:
    radial-gradient(700px 380px at 10% 20%, rgba(124,58,237,.22), transparent 60%),
    radial-gradient(650px 400px at 90% 35%, rgba(34,211,238,.14), transparent 60%);
  pointer-events:none;
  filter: blur(0px);
}
.hero__grid{
  position:relative;
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:26px;
  align-items:stretch;
}

.badge{
  display:inline-flex; align-items:center; gap:10px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.05);
  padding:9px 12px;
  border-radius:999px;
  font-size:13px;
  color:var(--muted);
}

h1{
  margin:16px 0 12px;
  font-size:clamp(34px, 4.2vw, 54px);
  line-height:1.05;
  letter-spacing:-.02em;
}
.glow{
  background:linear-gradient(90deg, var(--accent), var(--accent2));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  text-shadow: 0 0 32px rgba(124,58,237,.20);
}

.sub{
  color:var(--muted);
  font-size:16px;
  line-height:1.7;
  margin:0 0 18px;
}

.cta-row{display:flex; gap:12px; flex-wrap:wrap}
.btn{
  border:1px solid var(--line);
  padding:12px 16px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  cursor:pointer;
  transition:.2s ease;
  font-weight:700;
  letter-spacing:.01em;
}
.btn--primary{
  border-color:rgba(124,58,237,.35);
  background:linear-gradient(90deg, rgba(124,58,237,.95), rgba(34,211,238,.75));
  color:#070707;
  box-shadow: 0 14px 45px rgba(124,58,237,.22);
}
.btn--primary:hover{transform: translateY(-1px)}
.btn--ghost{
  background:rgba(255,255,255,.04);
}
.btn--ghost:hover{background:rgba(255,255,255,.07)}

.trust{
  display:flex; gap:14px; flex-wrap:wrap;
  margin-top:18px;
}
.trust__item{
  display:flex; align-items:center; gap:10px;
  color:var(--muted2);
  font-size:13px;
}
.dot{
  width:8px; height:8px; border-radius:999px;
  background:linear-gradient(90deg, var(--accent), var(--accent2));
  box-shadow:0 0 22px rgba(34,211,238,.25);
}

.hero__media{position:relative}
.glass{
  border:1px solid var(--line);
  background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.04));
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.card{padding:16px}
.card__top h3{margin:0}
.card__top p{margin:6px 0 0; color:var(--muted); font-size:13px}
.mockups{
  width:100%;
  margin:14px 0 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(0,0,0,.35);
}
.card__bottom{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:10px;
  margin-top:4px;
}
.kpi{
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.04);
  border-radius:14px;
  padding:10px;
}
.kpi strong{display:block; font-size:12px; color:var(--muted2)}
.kpi span{display:block; margin-top:2px; font-weight:800}

.floating{
  position:absolute;
  right:14px;
  bottom:-14px;
  display:flex;
  gap:10px;
  align-items:center;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.55);
  backdrop-filter: blur(10px);
  border-radius: 16px;
  padding:10px 12px;
  box-shadow: var(--shadow);
}
.floating__icon{
  width:36px; height:36px; border-radius:14px;
  display:grid; place-items:center;
  background:rgba(124,58,237,.16);
  border:1px solid rgba(124,58,237,.22);
}
.floating__title{font-weight:800; font-size:13px}
.floating__sub{color:var(--muted); font-size:12px}

.section{padding:64px 0}
.section--alt{
  background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.00));
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.section__head{
  margin-bottom:18px;
}
.section__head h2{
  margin:0;
  font-size:clamp(24px, 2.8vw, 34px);
  letter-spacing:-.02em;
}
.section__head p{
  margin:8px 0 0;
  color:var(--muted);
  line-height:1.6;
}

.grid{display:grid; gap:14px}
.cards{grid-template-columns: repeat(3, 1fr)}

/* =======================
   CARDS COLOREADAS (SOLO VISUAL)
   - Servicios, Equipos, Beneficios, Contacto
   ======================= */

/* Servicios */
.service{
  position:relative;
  border:1px solid rgba(255,255,255,.10);
  background:
    radial-gradient(120% 140% at 0% 0%, rgba(124,58,237,.14), transparent 58%),
    radial-gradient(120% 140% at 100% 0%, rgba(34,211,238,.10), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border-radius: var(--radius);
  padding:16px;
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.05),
    0 12px 35px rgba(0,0,0,.45);
  transition:.2s ease;
}
.service::before{
  content:"";
  position:absolute;
  left:0; top:10px; bottom:10px;
  width:4px;
  border-radius:999px;
  background:linear-gradient(180deg, var(--accent), var(--accent2));
  opacity:.92;
  box-shadow: 0 0 26px rgba(34,211,238,.18);
}
.service:hover{
  transform: translateY(-2px);
  background:
    radial-gradient(120% 140% at 0% 0%, rgba(124,58,237,.18), transparent 58%),
    radial-gradient(120% 140% at 100% 0%, rgba(34,211,238,.14), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.025));
  box-shadow:
    0 30px 80px rgba(0,0,0,.65),
    0 0 45px rgba(124,58,237,.18);
}
.service h3{margin:0 0 8px}
.service p{margin:0 0 12px; color:var(--muted); line-height:1.65}
.service ul{
  margin:0 0 12px; padding-left:18px;
  color:var(--muted2);
}

/* Combinaciones de color (Servicios 6) */
#servicios .service:nth-child(1)::before{ background:linear-gradient(180deg,#22d3ee,#38bdf8); }
#servicios .service:nth-child(2)::before{ background:linear-gradient(180deg,#7c3aed,#a78bfa); }
#servicios .service:nth-child(3)::before{ background:linear-gradient(180deg,#10b981,#34d399); }
#servicios .service:nth-child(4)::before{ background:linear-gradient(180deg,#f59e0b,#fb7185); }
#servicios .service:nth-child(5)::before{ background:linear-gradient(180deg,#60a5fa,#22d3ee); }
#servicios .service:nth-child(6)::before{ background:linear-gradient(180deg,#a78bfa,#22d3ee); }

.link{
  display:inline-flex;
  gap:8px;
  font-weight:800;
  opacity:.92;
}
.link:hover{opacity:1; text-decoration:underline}

.section__cta{
  display:flex; gap:12px; flex-wrap:wrap;
  margin-top:18px;
}

/* ===== (viejo) chips de marcas: lo dejo por si lo usas ===== */
.brands{
  display:flex; gap:12px; flex-wrap:wrap;
  margin-top:14px;
}
.brand-chip{
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
  padding:12px 14px;
  border-radius:999px;
  font-weight:800;
}

/* ✅ NUEVO: marcas con mockups (para tu HTML actual) */
.brands-mockups{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:14px;
  margin-top:14px;
}

/* usamos figure.brand-mockup del HTML */
.brand-mockup{
  margin:0;
  border:1px solid rgba(255,255,255,.10);
  border-radius: var(--radius);
  padding:14px 14px 12px;
  background:
    radial-gradient(120% 140% at 0% 0%, rgba(124,58,237,.14), transparent 58%),
    radial-gradient(120% 140% at 100% 0%, rgba(34,211,238,.10), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  box-shadow: 0 12px 35px rgba(0,0,0,.40);
  transition:.2s ease;
  text-align:center;
  overflow:hidden;
  position:relative;
}

.brand-mockup:hover{
  transform: translateY(-2px);
  box-shadow:
    0 30px 80px rgba(0,0,0,.65),
    0 0 45px rgba(34,211,238,.12);
}

/* imagen */
.brand-mockup img{
  width:100%;
  height:148px;
  object-fit:contain;
  display:block;
  margin:2px auto 10px;
  filter: drop-shadow(0 18px 28px rgba(0,0,0,.65));
}

/* texto abajo (figcaption) */
.brand-mockup figcaption{
  font-weight:900;
  letter-spacing:.10em;
  font-size:12px;
  color:rgba(255,255,255,.88);
}

/* fallback cuando no carga la imagen */
.brand-fallback{
  height:148px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(0,0,0,.35);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:6px;
  margin-bottom:10px;
}
.brand-fallback__icon{
  width:44px; height:44px;
  border-radius:16px;
  display:grid; place-items:center;
  background:rgba(34,211,238,.12);
  border:1px solid rgba(34,211,238,.22);
  box-shadow: 0 0 26px rgba(34,211,238,.10);
  font-size:20px;
}
.brand-fallback__name{
  font-weight:900;
  letter-spacing:.08em;
}
.brand-fallback__sub{
  font-size:12px;
  color:var(--muted2);
}

/* responsive marcas mockups */
@media (max-width: 720px){
  .brands-mockups{ grid-template-columns: 1fr; }
  .brand-mockup img{ height:170px; }
}

.note{
  margin-top:16px;
  border:1px dashed rgba(34,211,238,.28);
  background:rgba(34,211,238,.06);
  padding:14px 16px;
  border-radius:16px;
  color:rgba(255,255,255,.82);
}

.equip{grid-template-columns: repeat(3, 1fr)}

/* Equipos */
.equip-card{
  position:relative;
  border:1px solid rgba(255,255,255,.10);
  background:
    radial-gradient(120% 140% at 0% 0%, rgba(124,58,237,.14), transparent 58%),
    radial-gradient(120% 140% at 100% 0%, rgba(34,211,238,.10), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border-radius: var(--radius);
  padding:16px;
}
.equip-card::before{
  content:"";
  position:absolute;
  left:0; top:10px; bottom:10px;
  width:4px;
  border-radius:999px;
  background:linear-gradient(180deg, var(--accent), var(--accent2));
  opacity:.92;
  box-shadow: 0 0 26px rgba(34,211,238,.18);
}
.equip-card p{color:var(--muted); line-height:1.65}

/* Combinaciones de color (Equipos 3) */
#equipos .equip-card:nth-child(1)::before{ background:linear-gradient(180deg,#38bdf8,#22d3ee); }
#equipos .equip-card:nth-child(2)::before{ background:linear-gradient(180deg,#7c3aed,#38bdf8); }
#equipos .equip-card:nth-child(3)::before{ background:linear-gradient(180deg,#10b981,#7c3aed); }

.perks{grid-template-columns: repeat(4, 1fr)}

/* Beneficios */
.perk{
  position:relative;
  border:1px solid rgba(255,255,255,.10);
  background:
    radial-gradient(120% 140% at 0% 0%, rgba(124,58,237,.14), transparent 58%),
    radial-gradient(120% 140% at 100% 0%, rgba(34,211,238,.10), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border-radius: var(--radius);
  padding:16px;
}
.perk::before{
  content:"";
  position:absolute;
  left:0; top:10px; bottom:10px;
  width:4px;
  border-radius:999px;
  background:linear-gradient(180deg, var(--accent), var(--accent2));
  opacity:.92;
  box-shadow: 0 0 26px rgba(34,211,238,.18);
}
.perk p{margin:8px 0 0; color:var(--muted); line-height:1.6}

/* Combinaciones de color (Perks 4) */
#beneficios .perk:nth-child(1)::before{ background:linear-gradient(180deg,#a78bfa,#22d3ee); }
#beneficios .perk:nth-child(2)::before{ background:linear-gradient(180deg,#f59e0b,#fb7185); }
#beneficios .perk:nth-child(3)::before{ background:linear-gradient(180deg,#10b981,#38bdf8); }
#beneficios .perk:nth-child(4)::before{ background:linear-gradient(180deg,#60a5fa,#a78bfa); }

.banner{
  margin-top:18px;
  border:1px solid rgba(124,58,237,.25);
  background:linear-gradient(90deg, rgba(124,58,237,.12), rgba(34,211,238,.08));
  border-radius: var(--radius);
  padding:16px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}
.banner h3{margin:0}
.banner p{margin:6px 0 0; color:var(--muted)}

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

/* Contacto */
.contact-card{
  position:relative;
  border:1px solid rgba(255,255,255,.10);
  background:
    radial-gradient(120% 140% at 0% 0%, rgba(124,58,237,.14), transparent 58%),
    radial-gradient(120% 140% at 100% 0%, rgba(34,211,238,.10), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border-radius: var(--radius);
  padding:16px;
}
.contact-card::before{
  content:"";
  position:absolute;
  left:0; top:10px; bottom:10px;
  width:4px;
  border-radius:999px;
  background:linear-gradient(180deg, var(--accent), var(--accent2));
  opacity:.92;
  box-shadow: 0 0 26px rgba(34,211,238,.18);
}

/* Combinaciones de color (Contacto 2) */
#contacto .contact-card:nth-child(1)::before{ background:linear-gradient(180deg,#22d3ee,#7c3aed); }
#contacto .contact-card:nth-child(2)::before{ background:linear-gradient(180deg,#fb7185,#f59e0b); }

.small{color:var(--muted); margin-top:6px}
.field{display:block; margin-top:12px}
.field span{display:block; font-size:12px; color:var(--muted2); margin-bottom:6px}
input, textarea{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.35);
  color:var(--text);
  outline:none;
}
input:focus, textarea:focus{
  border-color: rgba(34,211,238,.35);
  box-shadow: 0 0 0 3px rgba(34,211,238,.10);
}
.row{display:flex; gap:12px; flex-wrap:wrap; margin-top:12px}
.hint{margin:10px 0 0; color:var(--muted2); font-size:12px; line-height:1.5}

.footer{
  border-top:1px solid rgba(255,255,255,.08);
  padding:26px 0;
  background:rgba(0,0,0,.35);
}
.footer__grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr 1fr;
  gap:18px;
  align-items:center;
}
.footer__brand{font-weight:900; letter-spacing:.22em}
.footer__text{margin:10px 0 0; color:var(--muted); font-size:13px}
.footer__links{display:flex; gap:12px; flex-wrap:wrap; justify-content:center}
.footer__links a{opacity:.8}
.footer__links a:hover{opacity:1; text-decoration:underline}
.footer__cta{justify-self:end; text-align:right}
.footer__mini{margin-top:10px; color:var(--muted2); font-size:12px}

.wa-float{
  position:fixed;
  right:16px;
  bottom:16px;
  z-index:999;
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  border-radius:999px;
  background:rgba(34,211,238,.10);
  border:1px solid rgba(34,211,238,.25);
  box-shadow: var(--shadow);
  backdrop-filter: blur(10px);
}
.wa-float__icon{
  width:34px; height:34px; border-radius:999px;
  display:grid; place-items:center;
  background:rgba(34,211,238,.16);
  border:1px solid rgba(34,211,238,.22);
}
.wa-float__text{font-weight:900}

@media (max-width: 980px){
  .hero__grid{grid-template-columns: 1fr; }
  .cards{grid-template-columns: 1fr}
  .equip{grid-template-columns: 1fr} /* ✅ FIX: era "1 fr" */
  .perks{grid-template-columns: 1fr 1fr}
  .footer__grid{grid-template-columns: 1fr; text-align:center}
  .footer__cta{justify-self:center; text-align:center}
  .floating{position:static; margin-top:12px}
}

@media (max-width: 720px){
  .nav__toggle{display:block}
  .nav__links{
    position:absolute;
    right:4vw; top:64px;
    width:min(420px, 92vw);
    padding:12px;
    border:1px solid var(--line);
    border-radius:16px;
    background:rgba(0,0,0,.75);
    backdrop-filter: blur(14px);
    display:none;
    flex-direction:column;
    align-items:stretch;
  }
  .nav__links a{padding:12px 12px}
  .nav__links.is-open{display:flex}
  .contact{grid-template-columns:1fr}
  .perks{grid-template-columns:1fr}
}
/* ==========================
   FIX Marcas (mockups)
   - evita tarjetas "blancas"
   - centra mejor la imagen
   - look premium igual al resto
   ========================== */

.brands-mockups{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:14px;
  margin-top:14px;
}

/* Card premium igual al estilo general */
.brand-mockup{
  margin:0;
  position:relative;
  border-radius: var(--radius);
  padding:14px 14px 12px;
  border:1px solid rgba(255,255,255,.10);
  background:
    radial-gradient(110% 130% at 0% 0%, rgba(124,58,237,.16), transparent 60%),
    radial-gradient(110% 130% at 100% 0%, rgba(34,211,238,.12), transparent 58%),
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.04),
    0 12px 35px rgba(0,0,0,.45);
  overflow:hidden;
  text-align:center;
  transition:.2s ease;
}

/* barra de color (como servicios) */
.brand-mockup::before{
  content:"";
  position:absolute;
  left:0; top:10px; bottom:10px;
  width:4px;
  border-radius:999px;
  background: linear-gradient(180deg, var(--accent), var(--accent2));
  opacity:.95;
  box-shadow: 0 0 26px rgba(34,211,238,.18);
}

.brand-mockup:hover{
  transform: translateY(-2px);
  box-shadow:
    0 30px 80px rgba(0,0,0,.65),
    0 0 40px rgba(124,58,237,.18);
}

/* Contenedor interno oscuro para “matar” cualquier blanco del PNG */
.brand-mockup img{
  width:100%;
  height:140px;
  object-fit:contain;
  display:block;
  margin:2px auto 10px;
  padding:10px;
  border-radius:14px;
  background: rgba(0,0,0,.35);            /* <<< esto elimina el “white card look” */
  border: 1px solid rgba(255,255,255,.08);
  filter: drop-shadow(0 18px 28px rgba(0,0,0,.65));
}

/* texto */
.brand-mockup figcaption{
  font-weight:900;
  letter-spacing:.10em;
  font-size:12px;
  color:rgba(255,255,255,.88);
}

/* fallback (por si algún png no carga) */
.brand-fallback{
  height:140px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(0,0,0,.35);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:6px;
  margin:2px auto 10px;
}
.brand-fallback__icon{
  width:44px; height:44px;
  border-radius:16px;
  display:grid; place-items:center;
  background:rgba(34,211,238,.12);
  border:1px solid rgba(34,211,238,.22);
  box-shadow: 0 0 26px rgba(34,211,238,.10);
  font-size:20px;
}
.brand-fallback__name{ font-weight:900; letter-spacing:.08em; }
.brand-fallback__sub{ font-size:12px; color:var(--muted2); }

/* móvil */
@media (max-width: 720px){
  .brands-mockups{ grid-template-columns: 1fr; }
  .brand-mockup img{ height:160px; }
}
