/* NEXTT Hero Banner — shop.nextt.mx */
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&display=swap');

/* ─────────────── Wrapper que respeta el container Bootstrap (≤1320px) ─────────────── */
.nextt-hero-wrap{
  width:100%;
  max-width:1320px;
  margin:8px auto 48px;
  padding:0 12px;
  font-family:'Outfit',sans-serif;
}

.nextt-hero{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(1200px 600px at 15% 0%,rgba(233,30,140,.18),transparent 55%),
    radial-gradient(1000px 700px at 100% 100%,rgba(53,184,198,.14),transparent 55%),
    linear-gradient(180deg,#0B0B12 0%,#07070B 100%);
  border-radius:24px;
  font-family:'Outfit',sans-serif;
  min-height:560px;
  display:flex;
  align-items:center;
  border:1px solid rgba(255,255,255,.06);
  box-shadow:
    0 40px 80px -20px rgba(0,0,0,.55),
    0 16px 32px -12px rgba(233,30,140,.15),
    inset 0 1px 0 rgba(255,255,255,.06);
}
.nextt-hero *{box-sizing:border-box}

.nextt-hero__bg{
  position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:1;border-radius:inherit;
}
.nextt-hero__glow{
  position:absolute;border-radius:50%;filter:blur(100px);opacity:.5;
}
.nextt-hero__glow--magenta{
  width:620px;height:620px;background:#E91E8C;
  top:-220px;left:-140px;
  animation:nextt-pulse-a 9s ease-in-out infinite;
}
.nextt-hero__glow--cyan{
  width:560px;height:560px;background:#35B8C6;
  bottom:-200px;right:-120px;
  animation:nextt-pulse-b 11s ease-in-out infinite;
}
.nextt-hero__glow--purple{
  width:400px;height:400px;background:#6B5CA5;
  top:40%;left:42%;opacity:.24;
  animation:nextt-pulse-c 13s ease-in-out infinite;
}
@keyframes nextt-pulse-a{0%,100%{transform:translate(0,0) scale(1);opacity:.5}50%{transform:translate(40px,30px) scale(1.15);opacity:.7}}
@keyframes nextt-pulse-b{0%,100%{transform:translate(0,0) scale(1);opacity:.4}50%{transform:translate(-30px,-40px) scale(1.2);opacity:.6}}
@keyframes nextt-pulse-c{0%,100%{transform:translate(-50%,-50%) scale(1);opacity:.24}50%{transform:translate(-48%,-52%) scale(1.15);opacity:.36}}

.nextt-hero__grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse at center,black 20%,transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at center,black 20%,transparent 75%);
}

.nextt-hero__inner{
  position:relative;z-index:2;
  width:100%;
  padding:72px 56px;
  display:grid;grid-template-columns:1.08fr 1fr;gap:56px;
  align-items:center;
}

.nextt-hero__content{color:#F0F0F5;animation:nextt-fade-up .9s ease both}
.nextt-hero__badge{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 16px 8px 10px;
  background:linear-gradient(135deg,rgba(233,30,140,.14),rgba(233,30,140,.06));
  border:1px solid rgba(233,30,140,.38);
  color:#FF77BE;
  border-radius:999px;
  font-size:12.5px;font-weight:600;
  letter-spacing:.04em;
  margin-bottom:26px;
  backdrop-filter:blur(8px);
}
.nextt-hero__badge-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:18px;height:18px;background:#E91E8C;color:#fff;border-radius:50%;font-size:10px;
  box-shadow:0 2px 8px rgba(233,30,140,.6);
}

.nextt-hero__title{
  font-size:clamp(2.4rem,5.2vw,4.4rem);
  font-weight:800;
  line-height:1.02;
  letter-spacing:-0.035em;
  margin:0 0 22px;
  color:#FFFFFF;
}
.nextt-hero__accent{
  color:#35B8C6;
  font-weight:900;
}

.nextt-hero__sub{
  font-size:clamp(1rem,1.35vw,1.18rem);
  color:#B8B8C8;
  line-height:1.6;
  margin:0 0 34px;
  max-width:540px;
  font-weight:400;
}

.nextt-hero__ctas{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:44px}

/* Specificity bump + !important to beat theme `a{color:#777}` */
.nextt-hero .nextt-hero__cta,
.nextt-hero a.nextt-hero__cta{
  display:inline-flex;align-items:center;gap:8px;
  padding:15px 32px;
  border-radius:12px;
  font-weight:600;font-size:15px;
  text-decoration:none !important;
  transition:all .3s cubic-bezier(.2,.8,.2,1);
  letter-spacing:.01em;
  line-height:1;
}
.nextt-hero .nextt-hero__cta--primary,
.nextt-hero a.nextt-hero__cta--primary,
.nextt-hero a.nextt-hero__cta--primary:link,
.nextt-hero a.nextt-hero__cta--primary:visited{
  background:linear-gradient(135deg,#F02B96 0%,#D01879 100%);
  color:#ffffff !important;
  box-shadow:
    0 1px 0 rgba(255,255,255,.25) inset,
    0 -2px 8px rgba(0,0,0,.25) inset,
    0 8px 28px rgba(233,30,140,.45),
    0 2px 6px rgba(233,30,140,.3);
  border:1px solid rgba(255,255,255,.12);
}
.nextt-hero .nextt-hero__cta--primary:hover,
.nextt-hero a.nextt-hero__cta--primary:hover{
  transform:translateY(-3px);
  box-shadow:
    0 1px 0 rgba(255,255,255,.3) inset,
    0 -2px 8px rgba(0,0,0,.25) inset,
    0 14px 36px rgba(233,30,140,.6),
    0 4px 10px rgba(233,30,140,.35);
  color:#ffffff !important;
}
.nextt-hero .nextt-hero__cta--outline,
.nextt-hero a.nextt-hero__cta--outline,
.nextt-hero a.nextt-hero__cta--outline:link,
.nextt-hero a.nextt-hero__cta--outline:visited{
  background:rgba(255,255,255,.04);
  color:#F0F0F5 !important;
  border:1.5px solid rgba(255,255,255,.22);
  backdrop-filter:blur(10px);
}
.nextt-hero .nextt-hero__cta--outline:hover,
.nextt-hero a.nextt-hero__cta--outline:hover{
  border-color:#4FCDDB;
  color:#4FCDDB !important;
  background:rgba(53,184,198,.08);
  transform:translateY(-3px);
}
.nextt-hero__cta-arrow{transition:transform .3s;display:inline-block}
.nextt-hero__cta:hover .nextt-hero__cta-arrow{transform:translateX(4px)}

.nextt-hero__trust{
  display:flex;gap:44px;padding-top:30px;
  border-top:1px solid rgba(255,255,255,.08);
}
.nextt-hero__trust-item{display:flex;flex-direction:column;gap:2px}
.nextt-hero__trust-item strong{
  font-size:30px;font-weight:800;
  background:linear-gradient(135deg,#FF4DA3,#4FCDDB);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  line-height:1;
  letter-spacing:-0.02em;
}
.nextt-hero__trust-item span{
  font-size:11.5px;color:#8A8A9A;
  text-transform:uppercase;letter-spacing:.14em;font-weight:600;
}

.nextt-hero__visual{
  position:relative;height:480px;
  animation:nextt-fade-up 1.1s ease .1s both;
}
.nextt-hero__product{
  position:absolute;
  border-radius:22px;
  overflow:hidden;
  background:
    radial-gradient(circle at 30% 20%,rgba(255,255,255,.10),rgba(255,255,255,.02) 60%),
    linear-gradient(160deg,rgba(255,255,255,.06),rgba(255,255,255,.01));
  border:1px solid rgba(255,255,255,.12);
  box-shadow:
    0 30px 80px rgba(0,0,0,.55),
    0 10px 30px rgba(0,0,0,.35),
    inset 0 1px 0 rgba(255,255,255,.14);
  backdrop-filter:blur(12px);
  transition:transform .5s cubic-bezier(.2,.8,.2,1);
}
.nextt-hero__product img{
  width:100%;height:100%;object-fit:contain;padding:20px;
  display:block;
  filter:drop-shadow(0 20px 40px rgba(233,30,140,.35));
}
.nextt-hero__product--1{
  width:62%;height:62%;
  top:8%;right:14%;
  animation:nextt-float-a 7s ease-in-out infinite;
  z-index:3;
}
.nextt-hero__product--2{
  width:44%;height:44%;
  top:48%;right:2%;
  animation:nextt-float-b 8s ease-in-out infinite;
  z-index:2;
}
.nextt-hero__product--2 img{filter:drop-shadow(0 20px 40px rgba(53,184,198,.4))}
.nextt-hero__product--3{
  width:42%;height:42%;
  bottom:8%;left:4%;
  animation:nextt-float-c 9s ease-in-out infinite;
  z-index:1;
}
.nextt-hero__product--3 img{filter:drop-shadow(0 20px 40px rgba(107,92,165,.4))}
@keyframes nextt-float-a{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-18px) rotate(1deg)}}
@keyframes nextt-float-b{0%,100%{transform:translateY(0) rotate(3deg)}50%{transform:translateY(-14px) rotate(-2deg)}}
@keyframes nextt-float-c{0%,100%{transform:translateY(0) rotate(-4deg)}50%{transform:translateY(-12px) rotate(2deg)}}

/* ─────────────── GEWO Badge — sello institucional ─────────────── */
.nextt-hero__gewo-badge{
  position:absolute;top:-6px;left:6%;z-index:4;
  display:flex;align-items:center;gap:12px;
  padding:11px 18px 11px 14px;
  background:linear-gradient(180deg,#11111A 0%,#08080C 100%);
  border:1px solid rgba(255,255,255,.14);
  border-radius:10px;
  box-shadow:
    0 1px 0 rgba(255,255,255,.08) inset,
    0 -1px 0 rgba(0,0,0,.5) inset,
    0 14px 40px rgba(0,0,0,.5),
    0 0 0 1px rgba(0,0,0,.4);
  transform:rotate(-3deg);
}
.nextt-hero__gewo-badge::before{
  content:"";
  position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:linear-gradient(180deg,rgba(255,255,255,.06),transparent 40%);
}
.nextt-hero__gewo-seal{
  width:28px;height:28px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(circle at 30% 30%,#FFF2C4,#E8C260 55%,#A97F2E 100%);
  box-shadow:
    0 0 0 1px rgba(0,0,0,.35),
    0 0 0 2px rgba(232,194,96,.25),
    0 2px 6px rgba(0,0,0,.4),
    inset 0 1px 0 rgba(255,255,255,.6);
  flex-shrink:0;
}
.nextt-hero__gewo-seal svg{width:14px;height:14px;color:#3A2608}
.nextt-hero__gewo-lines{display:flex;flex-direction:column;line-height:1}
.nextt-hero__gewo-text{
  font-size:18px;font-weight:800;
  color:#F4F4F8;
  letter-spacing:.24em;
  font-feature-settings:"ss01";
  text-shadow:0 1px 0 rgba(0,0,0,.6);
}
.nextt-hero__gewo-sub{
  font-size:8.5px;color:#8A8A9A;letter-spacing:.3em;
  text-transform:uppercase;font-weight:700;margin-top:5px;
}

@keyframes nextt-fade-up{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}

/* Tablet */
@media(max-width:991px){
  .nextt-hero-wrap{padding:0 12px;margin:8px auto 32px}
  .nextt-hero{min-height:auto;border-radius:20px}
  .nextt-hero__inner{grid-template-columns:1fr;gap:40px;padding:52px 32px;text-align:center}
  .nextt-hero__sub{margin-left:auto;margin-right:auto}
  .nextt-hero__ctas{justify-content:center}
  .nextt-hero__trust{justify-content:center}
  .nextt-hero__visual{height:360px;max-width:500px;margin:0 auto}
}
/* Mobile */
@media(max-width:600px){
  .nextt-hero{border-radius:18px}
  .nextt-hero__inner{padding:40px 20px}
  .nextt-hero__title{font-size:2.2rem}
  .nextt-hero__sub{font-size:.98rem}
  .nextt-hero .nextt-hero__cta{padding:13px 22px;font-size:14px;flex:1;justify-content:center;min-width:140px}
  .nextt-hero__trust{gap:22px;flex-wrap:wrap}
  .nextt-hero__trust-item strong{font-size:22px}
  .nextt-hero__visual{height:280px}
  .nextt-hero__gewo-badge{padding:8px 12px;gap:8px}
  .nextt-hero__gewo-seal{width:22px;height:22px}
  .nextt-hero__gewo-text{font-size:14px;letter-spacing:.2em}
  .nextt-hero__gewo-sub{font-size:7.5px}
}

/* Eliminar margen superior del home cuando hero está presente */
.page-home #content-wrapper,
.page-home .page-home{padding-top:0}

/* ─────────────── Ventajas NEXTT ─────────────── */
.nextt-advantages{
  font-family:'Outfit',sans-serif;
  padding:64px 12px;
  background:#FAFAFC;
  border-top:1px solid #EDEDF2;
  border-bottom:1px solid #EDEDF2;
}
.nextt-advantages__inner{
  max-width:1320px;margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
}
.nextt-adv-card{
  display:flex;flex-direction:column;align-items:flex-start;
  padding:28px 24px;
  background:#fff;
  border-radius:16px;
  border:1px solid #ECECF0;
  transition:all .3s cubic-bezier(.2,.8,.2,1);
}
.nextt-adv-card:hover{
  transform:translateY(-4px);
  box-shadow:0 16px 40px rgba(233,30,140,.08), 0 4px 12px rgba(0,0,0,.04);
  border-color:rgba(233,30,140,.2);
}
.nextt-adv-card__icon{
  display:flex;align-items:center;justify-content:center;
  width:52px;height:52px;
  background:linear-gradient(135deg,rgba(233,30,140,.1),rgba(53,184,198,.1));
  color:#E91E8C;
  border-radius:12px;
  margin-bottom:16px;
}
.nextt-adv-card__icon svg{width:26px;height:26px}
.nextt-adv-card h3{
  font-size:17px;font-weight:700;color:#0A0A0F;
  margin:0 0 6px;letter-spacing:-0.01em;
}
.nextt-adv-card p{
  font-size:14px;color:#6A6A78;margin:0;line-height:1.5;
}
a.nextt-adv-card--link,
a.nextt-adv-card--link:link,
a.nextt-adv-card--link:visited{
  text-decoration:none;
  color:inherit;
  cursor:pointer;
}
a.nextt-adv-card--link:hover h3{color:#E91E8C;}
@media(max-width:991px){.nextt-advantages__inner{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.nextt-advantages__inner{grid-template-columns:1fr}.nextt-advantages{padding:40px 16px}}

/* ─────────────── Categorías featured (collage editorial) ─────────────── */
.nextt-cats{
  font-family:'Outfit',sans-serif;
  padding:80px 12px;
  max-width:1320px;margin:0 auto;
}
.nextt-cats__header{text-align:center;margin-bottom:48px}
.nextt-cats__label{
  display:inline-block;
  color:#35B8C6;font-size:12px;font-weight:700;
  text-transform:uppercase;letter-spacing:.22em;
  margin-bottom:12px;
}
.nextt-cats__title{
  font-size:clamp(1.9rem,3.5vw,2.7rem);
  font-weight:800;color:#0A0A0F;
  letter-spacing:-0.025em;margin:0;
  line-height:1.1;
}
.nextt-cats__grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:22px;
}
.nextt-cat-card{
  position:relative;display:block;
  aspect-ratio:3/4;
  border-radius:20px;overflow:hidden;
  text-decoration:none !important;color:#fff !important;
  transition:all .5s cubic-bezier(.2,.8,.2,1);
  isolation:isolate;
  background:#0A0A0F;
  box-shadow:
    0 1px 0 rgba(255,255,255,.05) inset,
    0 20px 50px -20px rgba(0,0,0,.4);
  border:1px solid rgba(255,255,255,.06);
}
.nextt-cat-card:hover{
  transform:translateY(-6px);
  box-shadow:
    0 1px 0 rgba(255,255,255,.08) inset,
    0 30px 70px -15px rgba(0,0,0,.5),
    0 0 0 1px rgba(233,30,140,.25);
  text-decoration:none;
}

/* Capa base: gradiente temático por categoría */
.nextt-cat-card__base{
  position:absolute;inset:0;z-index:0;
  transition:transform .7s cubic-bezier(.2,.8,.2,1);
}
.nextt-cat-card:hover .nextt-cat-card__base{transform:scale(1.05)}
.nextt-cat-card--hules .nextt-cat-card__base{
  background:
    radial-gradient(circle at 30% 20%,rgba(233,30,140,.55),transparent 55%),
    radial-gradient(circle at 80% 80%,rgba(107,92,165,.4),transparent 55%),
    linear-gradient(160deg,#1A0814 0%,#2E0A1E 45%,#07070B 100%);
}
.nextt-cat-card--maderas .nextt-cat-card__base{
  background:
    radial-gradient(circle at 70% 25%,rgba(107,92,165,.55),transparent 55%),
    radial-gradient(circle at 20% 80%,rgba(53,184,198,.3),transparent 55%),
    linear-gradient(160deg,#0F0A1A 0%,#1A1430 45%,#07070B 100%);
}
.nextt-cat-card--raquetas .nextt-cat-card__base{
  background:
    radial-gradient(circle at 50% 25%,rgba(53,184,198,.5),transparent 55%),
    radial-gradient(circle at 30% 85%,rgba(233,30,140,.3),transparent 55%),
    linear-gradient(160deg,#0A1416 0%,#0E2A30 45%,#07070B 100%);
}
.nextt-cat-card--textil .nextt-cat-card__base{
  background:
    radial-gradient(circle at 30% 25%,rgba(233,30,140,.4),transparent 55%),
    radial-gradient(circle at 75% 75%,rgba(53,184,198,.4),transparent 55%),
    linear-gradient(160deg,#0A0A0F 0%,#1A1A25 50%,#07070B 100%);
}

/* Collage de imágenes de producto */
.nextt-cat-card__collage{
  position:absolute;inset:0;z-index:1;pointer-events:none;
}
.nextt-cat-card__photo{
  position:absolute;
  border-radius:12px;
  overflow:hidden;
  background:radial-gradient(circle at 30% 25%,rgba(255,255,255,.12),rgba(255,255,255,.02) 60%);
  border:1px solid rgba(255,255,255,.12);
  box-shadow:
    0 12px 30px rgba(0,0,0,.55),
    0 4px 10px rgba(0,0,0,.4),
    inset 0 1px 0 rgba(255,255,255,.12);
  backdrop-filter:blur(8px);
  transition:transform .6s cubic-bezier(.2,.8,.2,1);
}
.nextt-cat-card__photo img{
  width:100%;height:100%;object-fit:contain;padding:8px;display:block;
  filter:drop-shadow(0 8px 16px rgba(0,0,0,.5));
}

/* Arreglos: 5 fotos flotantes con posiciones únicas por categoría */
.nextt-cat-card__photo--a{width:52%;aspect-ratio:1/1;top:8%;left:8%;transform:rotate(-6deg);z-index:3}
.nextt-cat-card__photo--b{width:42%;aspect-ratio:1/1;top:4%;right:6%;transform:rotate(5deg);z-index:4}
.nextt-cat-card__photo--c{width:44%;aspect-ratio:1/1;top:30%;left:26%;transform:rotate(2deg);z-index:5}
.nextt-cat-card__photo--d{width:38%;aspect-ratio:1/1;top:38%;right:3%;transform:rotate(-4deg);z-index:2}
.nextt-cat-card__photo--e{width:36%;aspect-ratio:1/1;top:42%;left:4%;transform:rotate(7deg);z-index:1}

.nextt-cat-card:hover .nextt-cat-card__photo--a{transform:rotate(-8deg) translateY(-4px)}
.nextt-cat-card:hover .nextt-cat-card__photo--b{transform:rotate(7deg) translateY(-6px)}
.nextt-cat-card:hover .nextt-cat-card__photo--c{transform:rotate(1deg) translateY(-8px) scale(1.03)}
.nextt-cat-card:hover .nextt-cat-card__photo--d{transform:rotate(-6deg) translateY(-4px)}
.nextt-cat-card:hover .nextt-cat-card__photo--e{transform:rotate(9deg) translateY(-3px)}

/* Overlay oscuro para legibilidad del texto */
.nextt-cat-card__overlay{
  position:absolute;inset:0;z-index:6;pointer-events:none;
  background:
    linear-gradient(180deg,transparent 0%,transparent 40%,rgba(7,7,11,.7) 75%,rgba(7,7,11,.95) 100%);
}

.nextt-cat-card__content{
  position:absolute;inset:0;z-index:7;
  padding:28px;
  display:flex;flex-direction:column;justify-content:flex-end;
  pointer-events:none;
}
.nextt-cat-card__kicker{
  font-size:11px;font-weight:700;color:#4FCDDB;
  text-transform:uppercase;letter-spacing:.22em;
  margin-bottom:8px;
}
.nextt-cat-card__content h3{
  font-size:clamp(1.35rem,1.9vw,1.8rem);font-weight:800;
  margin:0 0 6px;letter-spacing:-0.02em;color:#fff;
  line-height:1.05;
}
.nextt-cat-card__content p{
  font-size:13px;color:rgba(255,255,255,.72);
  margin:0 0 18px;line-height:1.4;
}
.nextt-cat-card__cta{
  display:inline-flex;align-items:center;gap:6px;
  font-size:13px;font-weight:700;
  color:#fff !important;
  padding:9px 16px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.22);
  border-radius:10px;
  backdrop-filter:blur(10px);
  align-self:flex-start;
  transition:all .3s;
  pointer-events:auto;
}
.nextt-cat-card:hover .nextt-cat-card__cta{
  background:#E91E8C;border-color:#E91E8C;
  box-shadow:0 6px 20px rgba(233,30,140,.45);
}

@media(max-width:991px){
  .nextt-cats__grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:540px){
  .nextt-cats__grid{grid-template-columns:1fr;gap:16px}
  .nextt-cats{padding:50px 16px}
  .nextt-cat-card{aspect-ratio:16/10}
  .nextt-cat-card__photo--a{width:42%;top:12%;left:6%}
  .nextt-cat-card__photo--b{width:34%;top:8%;right:10%}
  .nextt-cat-card__photo--c{width:36%;top:24%;left:32%}
  .nextt-cat-card__photo--d{width:30%;top:40%;right:12%}
  .nextt-cat-card__photo--e{width:28%;top:44%;left:10%}
}

/* Ocultar títulos/bloques demo residuales */
.page-home h1.h1:has(+ .elementor-widget){display:none}
