*,
*::before,
*::after{ box-sizing: border-box; }

html, body{ margin: 0; padding: 0; }

body{
  font-family: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  overflow-x: hidden;
  background: linear-gradient(to right, #1F355E, #5F8FB6, #8FAEC7);
}

img{ max-width: 100%; height: auto; display: block; }

/* Compensación del header fijo */
main{ padding-top: 98px; }

/* =========================
   1) HEADER (fixed)
   ========================= */
.site-header{
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  background: #fff;
  border-bottom: 1px solid #e5e7eb;
  z-index: 9999;
}


/* CONTENEDOR */
.header-inner{
  max-width: 1600px;
  margin: 0 auto;
  height: 96px;
  padding: 0 60px;

  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 40px;
}

/* ================= LOGO ================= */
.logo img{
  height: 50px;
  width: auto;
  display: block;
}

/* ================= BOTÓN HAMBURGUESA ================= */
.menu-toggle{
  display: none;
  width: 44px;
  height: 44px;
  border: none;
  background: transparent;
  cursor: pointer;
}
.menu-toggle span{
  display: block;
  width: 26px;
  height: 3px;
  background: #111;
  border-radius: 999px;
  margin: 5px auto;
}


/* ================= NAV DESKTOP ================= */
.main-nav{
  display: flex;
  align-items: center;
  justify-content: center; /* 🔥 CENTRADO */
  gap: 40px;
}
.nav-list{
  display: flex;
  align-items: center;
  gap: 36px;              /* 🔥 ESPACIO ENTRE ITEMS */
  list-style: none;
  margin: 0;
  padding: 0;
}

.nav-item{ position: relative; }

.nav-link{
  background: none;
  border: none;
  cursor: pointer;
  font-size: 14px;
  font-weight: 600;
  color: #333;
  padding: 8px 4px;
}
.nav-item.has-dropdown > .nav-link::after{
  content: "▾";
  margin-left: 6px;
  font-size: 12px;
}


/* ================= DROPDOWN DESKTOP ================= */
.dropdown{
  position: absolute;
  top: calc(100% + 14px);
  left: 0;
  min-width: 260px;
  background: #fff;
  border-radius: 14px;
  padding: 10px 0;
  list-style: none;
  border: 1px solid #e5e7eb;
  box-shadow: 0 18px 40px rgba(0,0,0,.12);

  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition: .2s ease;
}

.dropdown a{
  display: block;
  padding: 12px 20px;
  text-decoration: none;
  font-size: 13px;
  color: #333;
}
.dropdown a:hover{
  background: #f5f5f5;
}

/* Hover desktop */
@media (min-width: 901px){
  .nav-item:hover .dropdown{
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
  }}

/* ================= BLOQUE DERECHO ================= */
.nav-extra{
  display: flex;
  align-items: center;
  gap: 18px;
}

/* País */
.country-box{
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 600;
}

.country-flag img{
  width: 26px;
  height: 18px;
  border-radius: 3px;
}


/* Botones */
.nav-buttons{
  display: flex;
  gap: 10px;
}
.btn{
  padding: 9px 16px;
  border-radius: 10px;
  font-size: 12px;
  font-weight: 700;
  text-decoration: none;
}

.btn-outline{
  background: #fff;
  border: 1px solid #0c4452;
  color: #0c4452;
}
.btn-primary{
  background:#314f8f;
  border: 1px solid #314f8f;
  color:#ffffff;
}
/* Redes */
.nav-social{
  display: flex;
  align-items: center;
  gap: 12px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.nav-social li{
  display: flex;
}

/* ICONOS REDES (outline, sin deformar) */
.nav-social a{
  width: 38px;
  height: 38px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  border: 1px solid rgba(0,0,0,.12);
  color: #111;
  text-decoration: none;
}


/* SVG normalizado */
.nav-social a svg{
  width: 22px;
  height: 22px;
  display: block;
  flex: 0 0 auto;
  fill: currentColor;
}


/* Hover general */
.nav-social a:hover{
  transform: translateY(-2px);
  box-shadow: 0 10px 22px rgba(0,0,0,.15);
  color:#fff;
}



/* Colores por red en hover */
.nav-social a[aria-label="Facebook"]:hover{ background:#1877f2; }
.nav-social a[aria-label="Instagram"]:hover{
  background: linear-gradient(135deg,#f58529,#dd2a7b,#8134af,#515bd4);
}
.nav-social a[aria-label="WhatsApp"]:hover{ background:#25d366; }
/* Icono blanco al hover */
.nav-social a:hover svg{
  fill: #ffffff;
}


/* ================= MÓVIL ================= */
@media (max-width: 900px){

  .header-inner{
    grid-template-columns: auto auto;
    padding: 0 16px;
  }

  .menu-toggle{
    display: block;
  }

  .main-nav{
    position: absolute;
    top: 96px;
    left: 0;
    width: 100%;
    background: #fff;
    flex-direction: column;
    align-items: stretch;
    padding: 20px;
    gap: 20px;

    opacity: 0;
    pointer-events: none;
    transform: translateY(-10px);
    transition: .25s ease;
  }

  .site-header.is-open .main-nav{
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
  }

  .nav-list{
    flex-direction: column;
    gap: 10px;
  }

  .nav-link{
    width: 100%;
    text-align: left;
    padding: 14px;
    border-radius: 12px;
    background: #f7f7f9;
  }

  /* Dropdown móvil */
  .dropdown{
    position: static;
    opacity: 1;
    visibility: visible;
    transform: none;
    box-shadow: none;
    border: none;
    padding: 0;
    display: none;
  }

  .nav-item.is-open > .dropdown{
    display: block;
  }

  .dropdown a{
    margin-top: 6px;
    border-radius: 10px;
    border: 1px solid #e5e7eb;
  }

  .nav-extra{
    flex-direction: column;
    align-items: stretch;
    gap: 14px;
    border-top: 1px solid #eee;
    padding-top: 16px;
  }

  .nav-buttons{
    flex-direction: column;
  }

  .nav-buttons a{
    width: 100%;
    text-align: center;
  }

  .nav-social{
    justify-content: center;
  }
}
 /* final del header



/* ====== COMIENZO DE FOOTER   ====== */
/* ================= FOOTER WMAX ================= */

.site-footer{
  background:#fff;
  border-top:1px solid #e6e9ef;
}

/* CONTENEDOR PRINCIPAL */
.footer-inner{
  max-width:1400px;
  margin:0 auto;
  padding:70px 40px;   /* ⬅️ MÁS GRANDE */
  display:grid;
  grid-template-columns: 260px 1.6fr 1.2fr 260px;
  gap:60px;
  align-items:flex-start;
}

/* LOGO */
.footer-logo img{
  max-width:200px;
}

/* DIRECCIÓN */
.footer-location h4,
.footer-social h4{
  font-size:16px;
  font-weight:800;
  margin-bottom:14px;
}

.footer-location p{
  font-size:14.5px;
  line-height:1.6;
  color:#2f3646;
}

/* LINK MAPA */
.footer-map-link{
  display:inline-block;
  margin-top:10px;
  font-weight:700;
  color:#1d4ed8;
  text-decoration:none;
}

/* =========================
   MENÚ ORGANIZADO (PRODUCTOS)
   ========================= */
.footer-menu-strip{
  display:flex;
  align-items:flex-start;
}

.footer-menu-links{
  display:grid;
  grid-template-columns: 1fr;
  gap:12px;            /* ⬅️ orden vertical */
}

.footer-menu-links a{
  font-size:15px;
  font-weight:600;
  color:#1b1f2a;
  text-decoration:none;
  position:relative;
  padding-left:14px;
  transition:all .25s ease;
}

/* pequeño indicador visual */
.footer-menu-links a::before{
  content:"›";
  position:absolute;
  left:0;
  color:#2563eb;
  font-weight:800;
}

.footer-menu-links a:hover{
  color:#2563eb;
  transform:translateX(4px);
}

/* =========================
   REDES SOCIALES
   ========================= */
.social-footer{
  display:flex;
  gap:14px;
  list-style: none;/* =========================
   quitar lista
   ========================= */
}

.social-footer a{
  width:44px;
  height:44px;
  border-radius:50%;
  border:1px solid #d6dbe6;
  display:grid;
  place-items:center;
  font-weight:800;
  color:#1b1f2a;
  text-decoration:none;
  transition:all .25s ease;

}

.social-footer a:hover{
  transform:translateY(-3px) scale(1.05);
  border-color:#2563eb;
  color:#2563eb;
}

/* =========================
   BARRA INFERIOR
   ========================= */
.footer-bottom{
  border-top:1px solid #e6e9ef;
  padding:22px;
  text-align:center;
  font-size:14px;
  color:#3b4456;
}

/* =========================
   RESPONSIVE
   ========================= */
@media(max-width:1100px){
  .footer-inner{
    grid-template-columns:1fr 1fr;
    gap:40px;
    padding:60px 28px;
  }
}

@media(max-width:640px){
  .footer-inner{
    grid-template-columns:1fr;
    text-align:center;
  }

  .footer-menu-links{
    align-items:center;
  }

  .footer-menu-links a::before{
    display:none;
  }

  .social-footer{
    justify-content:center;
  }
}

/* ====== TERMINA  DE FOOTER   ====== */

/* ======inicio de banner   ====== */
/* =================================================
   WMAX BANNER + CARDS (AISLADO / NO ROMPE TU SITIO)
   Estilo: Tecno Azul + Banner Horizontal
================================================= */

/* Reset mínimo SOLO para el módulo */
.wmax-hero, .wmax-section{
  font-family: 'Roboto', system-ui, -apple-system, Segoe UI, Arial, sans-serif;
}

.wmax-hero *, .wmax-section *{
  box-sizing: border-box;
}

.wmax-hero img, .wmax-section img{
  display: block;
  max-width: 100%;
}

/* Variables */
:root{
  --tecno-bg:#070b22;
  --tecno-panel:#0c1438;
  --tecno-border:rgba(0,170,255,.35);
  --tecno-accent:#00b4ff;
  --tecno-glow:rgba(0,180,255,.55);
  --white:#eaf7ff;
}

/* =================================================
   BANNER HORIZONTAL
================================================= */
.wmax-hero{
  width: 100%;
  padding: 24px 16px;
}

.wmax-hero-inner{
  max-width: 1200px;          /* ✅ no se sale del layout */
  margin: 0 auto;

  display: grid;
  grid-template-columns: 1.0fr .5fr;
  gap: 18px;
  align-items: center;

  /* ✅ Horizontal controlado */
  min-height: 480px;
  height: clamp(380px, 20vw, 460px);

  padding: 22px;
  border-radius: 22px;
  overflow: hidden;


  
}

/* Columna izquierda */
.wmax-hero-left{
  min-width: 0; /* ✅ evita desbordes */
}

.wmax-hero-badge{
  display:inline-block;
  padding:8px 14px;
  border-radius:999px;
  font-weight:900;
  font-size:.82rem;
  letter-spacing:.08em;

 

  color: var(--white);
  box-shadow:0 0 18px var(--tecno-glow);
}

.wmax-hero-title{
  margin: 12px 0 10px;
  font-size: clamp(1.7rem, 3.2vw, 2.8rem);
  font-weight: 900;
  line-height: 1.05;
  color: var(--white);
  text-shadow: 0 0 22px var(--tecno-glow);
}

.wmax-hero-desc{
  margin: 0 0 14px;
  max-width: 62ch;
  font-size: clamp(.98rem, .9vw + .85rem, 1.12rem);
  line-height: 1.6;
  color: rgba(235,245,255,.95);
}

/* Botones */
.wmax-hero-actions{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}

.wmax-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 11px 16px;
  border-radius: 14px;
  font-weight: 900;
  text-decoration: none;
  white-space: nowrap;
  border: 1px solid rgba(255,255,255,.12);
}

.wmax-btn-primary{
  background: linear-gradient(135deg,#008cff,#00e0ff);
  color:#001524;
  box-shadow: 0 0 26px var(--tecno-glow);
}

.wmax-btn-ghost{

  border: 1px solid var(--tecno-border);
  color: var(--white);
}

/* Chips */
.wmax-hero-chips{
  display:flex;
  flex-wrap: wrap;
  gap: 8px;
}

.wmax-chip{
  padding: 7px 10px;
  border-radius: 999px;
  font-weight: 800;
  font-size: .86rem;
  color: var(--white);
  background: rgba(0,180,255,.12);
  border: 1px solid var(--tecno-border);
  box-shadow: inset 0 0 12px rgba(0,180,255,.22);
}

/* Columna derecha (imagen) */
.wmax-hero-right{
  min-width: 0;
}



/* HUD line */


/* =================================================
   SECCIÓN + CARDS
================================================= */
.wmax-section{
  width: 100%;
  padding: 28px 16px 44px;
}

.wmax-section-head{
  max-width: 1200px;
  margin: 0 auto 16px;
  text-align: center;
}

.wmax-section-title{
  margin: 0 0 8px;
  font-size: clamp(1.6rem, 2.6vw, 2.4rem);
  font-weight: 900;
  color: var(--white);
  text-shadow: 0 0 18px var(--tecno-glow);
}

.wmax-section-sub{
  margin: 0 auto;
  max-width: 860px;
  font-size: clamp(1rem, 1.1vw, 1.15rem);
  line-height: 1.55;
  color: rgba(235,245,255,.95);
}

/* Grid cards */
.wmax-cards{
  max-width: 1200px;
  margin: 18px auto 0;
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.wmax-card{
  border-radius: 18px;
  overflow:hidden;
  border: 1px solid var(--tecno-border);
  background: linear-gradient(180deg, rgba(0,180,255,.08), rgba(0,0,0,.35));
  box-shadow: 0 18px 45px rgba(0,0,0,.65);
  transition: transform .25s ease, box-shadow .25s ease;
}

@media (hover:hover){
  .wmax-card:hover{
    transform: translateY(-6px);
    box-shadow: 0 0 40px var(--tecno-glow), 0 22px 55px rgba(0,0,0,.75);
  }
}
.wmax-hero-right{
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}

.wmax-hero-media{
  width: 100%;
  max-width: 3600px; /* control visual desktop */
  position: relative;
}

.wmax-hero-media img{
  width: 100%;
  height: auto;
  max-height: 95vh;
  object-fit: contain;
  display: block;
}
@media (max-width: 768px){
  .wmax-hero-media img{
    max-height: 60vh;
  }
}

.wmax-card-body{
  padding: 14px 14px 16px;
}

.wmax-card-body h3{
  margin: 0 0 8px;
  font-size: clamp(1.1rem, 1.2vw + .85rem, 1.4rem);
  font-weight: 900;
  line-height: 1.15;
  color: var(--white);
  text-shadow: 0 0 12px rgba(0,180,255,.28);
}

.wmax-card-body p{
  margin: 0 0 12px;
  line-height: 1.5;
  color: rgba(235,245,255,.95);
}

.wmax-card-meta{
  display:flex;
  flex-wrap:wrap;
  gap: 8px;
}

.wmax-pill{
  padding: 6px 10px;
  border-radius: 999px;
  font-weight: 900;
  font-size: .82rem;
  color: var(--white);
  background: rgba(0,180,255,.12);
  border: 1px solid var(--tecno-border);
  box-shadow: inset 0 0 10px rgba(0,180,255,.25);
}

/* CTA */
.wmax-cta{
  max-width: 1200px;
  margin: 18px auto 0;
  display:flex;
  justify-content:center;
}

/* =================================================
   RESPONSIVE
================================================= */
@media (max-width: 980px){
  .wmax-hero-inner{
    grid-template-columns: 1fr;
    height: auto;
  }
  .wmax-hero-media{
    height: clamp(220px, 44vw, 320px);
  }
  .wmax-cards{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 560px){
  .wmax-cards{
    grid-template-columns: 1fr;
  }
  .wmax-btn{
    width: 100%;
  }
}
/* =================================================
  AQUI INICIA VINILOS 
================================================= */

/* =================================================
   VINILOS – BANNER + CARDS (TECNO AZUL)
   NO TOCA tus clases pq-*
================================================= */
:root{
  --vin-bg:#070b22;
  --vin-panel:#0c1438;
  --vin-border:rgba(0,170,255,.35);
  --vin-glow:rgba(0,180,255,.55);
  --vin-accent:#00b4ff;
  --vin-text:#eaf7ff;
}

.vin-banner, .vin-section{ font-family: 'Roboto', system-ui, Arial, sans-serif; }
.vin-banner *, .vin-section *{ box-sizing:border-box; }
.vin-banner img, .vin-section img{ display:block; max-width:100%; }

/* ================== BANNER ================== */
.vin-banner{
  position: relative;
  padding: 24px 16px;
}

.vin-banner-bg{
  display:none; /* reservado por si luego quieres partículas o fondo extra */
}

.vin-banner-grid{
  max-width: 1200px;
  margin: 0 auto;

  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 18px;
  align-items:center;

  min-height: 280px;
  height: clamp(280px, 20vw, 360px); /* horizontal */
  padding: 22px;

  border-radius: 22px;
  overflow:hidden;

  background:
    radial-gradient(900px 320px at 85% 15%, rgba(0,180,255,.22), transparent 60%),
    linear-gradient(135deg, var(--vin-bg), var(--vin-panel));

  border: 1px solid var(--vin-border);
  box-shadow: 0 22px 60px rgba(0,0,0,.55);
}

.vin-banner-copy{ min-width:0; }

.vin-badge{
  display:inline-block;
  padding:8px 14px;
  border-radius:999px;
  font-weight:900;
  font-size:.82rem;
  letter-spacing:.08em;
  color: var(--vin-text);
  background: rgba(0,180,255,.14);
  border: 1px solid var(--vin-border);
  box-shadow: 0 0 18px var(--vin-glow);
}

.vin-title{
  margin: 12px 0 10px;
  font-size: clamp(1.7rem, 3.2vw, 2.8rem);
  font-weight: 900;
  line-height: 1.05;
  color: var(--vin-text);
  text-shadow: 0 0 22px var(--vin-glow);
}

.vin-sub{
  margin: 0 0 14px;
  max-width: 62ch;
  font-size: clamp(.98rem, .9vw + .85rem, 1.12rem);
  line-height: 1.6;
  color: rgba(235,245,255,.95);
}

.vin-actions{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}

.vin-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 11px 16px;
  border-radius: 14px;
  font-weight: 900;
  text-decoration:none;
  white-space: nowrap;
  border: 1px solid rgba(255,255,255,.12);
}

.vin-btn-primary{
  background: linear-gradient(135deg,#008cff,#00e0ff);
  color:#001524;
  box-shadow: 0 0 26px var(--vin-glow);
}

.vin-btn-ghost{
  background: rgba(0,180,255,.08);
  border: 1px solid var(--vin-border);
  color: var(--vin-text);
}

.vin-chips{
  display:flex;
  flex-wrap: wrap;
  gap: 8px;
}

.vin-chip{
  padding: 7px 10px;
  border-radius: 999px;
  font-weight: 800;
  font-size: .86rem;
  color: var(--vin-text);
  background: rgba(0,180,255,.12);
  border: 1px solid var(--vin-border);
  box-shadow: inset 0 0 12px rgba(0,180,255,.22);
}

/* Media derecha */
.vin-banner-media{
  position: relative;
  width: 100%;
  height: 100%;
  border-radius: 18px;
  overflow:hidden;
  display:grid;
  place-items:center;
  background:
    radial-gradient(circle at center, rgba(0,180,255,.20), transparent 68%),
    linear-gradient(135deg, var(--vin-bg), var(--vin-panel));
  border: 1px solid var(--vin-border);
}

.vin-banner-media img{
  width: min(92%, 520px);
  height: auto;
  max-height: 82%;
  object-fit: contain;
  filter:
    drop-shadow(0 0 22px var(--vin-glow))
    drop-shadow(0 28px 50px rgba(0,0,0,.8));
}

.vin-hud{
  position:absolute;
  left: 14px;
  right: 14px;
  bottom: 14px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--vin-accent), transparent);
  opacity: .95;
}

/* ================== CARDS ================== */
.vin-section{
  padding: 28px 16px 44px;
}

.vin-head{
  max-width: 1200px;
  margin: 0 auto 16px;
  text-align: center;
}

.vin-head-title{
  margin: 0 0 8px;
  font-size: clamp(1.6rem, 2.6vw, 2.4rem);
  font-weight: 900;
  color: var(--vin-text);
  text-shadow: 0 0 18px var(--vin-glow);
}

.vin-head-sub{
  margin: 0 auto;
  max-width: 860px;
  font-size: clamp(1rem, 1.1vw, 1.15rem);
  line-height: 1.55;
  color: rgba(235,245,255,.95);
}

/* Grid */
.vin-grid{
  max-width: 1200px;
  margin: 18px auto 0;
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

.vin-card{
  border-radius: 18px;
  overflow:hidden;
  border: 1px solid var(--vin-border);
  background: linear-gradient(180deg, rgba(0,180,255,.08), rgba(0,0,0,.35));
  box-shadow: 0 18px 45px rgba(0,0,0,.65);
  transition: transform .25s ease, box-shadow .25s ease;
}

@media (hover:hover){
  .vin-card:hover{
    transform: translateY(-6px);
    box-shadow: 0 0 40px var(--vin-glow), 0 22px 55px rgba(0,0,0,.75);
  }
}

.vin-media{
  height: clamp(150px, 14vw, 190px);
  display:grid;
  place-items:center;
  background:
    radial-gradient(circle at center, rgba(0,180,255,.18), transparent 72%),
    linear-gradient(135deg, var(--vin-bg), var(--vin-panel));
}

.vin-media img{
  width: min(92%, 260px);
  height: auto;
  max-height: 84%;
  object-fit: contain;
  filter:
    drop-shadow(0 0 16px var(--vin-glow))
    drop-shadow(0 18px 32px rgba(0,0,0,.85));
}

.vin-body{
  padding: 14px 14px 16px;
}

.vin-body h3{
  margin: 0 0 8px;
  font-size: clamp(1.05rem, 1.1vw + .85rem, 1.25rem);
  font-weight: 900;
  line-height: 1.15;
  color: var(--vin-text);
}

.vin-body p{
  margin: 0;
  line-height: 1.5;
  color: rgba(235,245,255,.95);
}

.vin-cta{
  max-width: 1200px;
  margin: 18px auto 0;
  display:flex;
  justify-content:center;
}

/* ================== RESPONSIVE ================== */
@media (max-width: 1050px){
  .vin-grid{ grid-template-columns: repeat(3, minmax(0,1fr)); }
}

@media (max-width: 980px){
  .vin-banner-grid{
    grid-template-columns: 1fr;
    height: auto;
  }
  .vin-banner-media{
    height: clamp(220px, 44vw, 320px);
  }
  .vin-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}

@media (max-width: 560px){
  .vin-grid{ grid-template-columns: 1fr; }
  .vin-btn{ width: 100%; }
}
 /* ================== comienza elpoliestileno  ================== */

/* =================================================
   POLIESTILENO – ESTILO INTERACTIVO (px-*)
================================================= */
/* =================================================
   POLIESTILENO – ESTILO INTERACTIVO (px-*)
================================================= */
:root{
  --px-bg:#070b22;
  --px-panel:#0c1438;
  --px-border:rgba(0,170,255,.35);
  --px-glow:rgba(0,180,255,.55);
  --px-accent:#00b4ff;
  --px-text:#eaf7ff;
}

.px-hero,.px-section{font-family:'Roboto',system-ui,Arial,sans-serif;}
.px-hero *,.px-section *{box-sizing:border-box;}
.px-hero img,.px-section img{display:block;max-width:100%;}

/* ================= HERO ================= */
.px-hero{ padding: 24px 16px; }
.px-hero-inner{
  max-width: 1200px; margin: 0 auto;
  border-radius: 26px; overflow:hidden;
  border: 1px solid var(--px-border);
  background:
    radial-gradient(900px 360px at 85% 18%, rgba(0,180,255,.22), transparent 60%),
    linear-gradient(135deg, var(--px-bg), var(--px-panel));
  box-shadow: 0 26px 70px rgba(0,0,0,.65);
  position: relative;
}

/* efecto scan global */
.px-hero-inner::after{
  content:"";
  position:absolute; inset:-40%;
  background: linear-gradient(90deg, transparent, rgba(0,180,255,.18), transparent);
  transform: rotate(12deg);
  animation: pxScan 4.2s linear infinite;
  pointer-events:none;
  opacity:.9;
}
@keyframes pxScan{
  0%{ transform: translateX(-45%) rotate(12deg); }
  100%{ transform: translateX(45%) rotate(12deg); }
}

.px-grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 16px;
  align-items:center;
  padding: 28px;
  position: relative;
  z-index: 1;
}

.px-badge{
  display:inline-block;
  padding:8px 14px;
  border-radius:999px;
  font-weight:900;
  font-size:.82rem;
  letter-spacing:.08em;
  color: var(--px-text);
  background: rgba(0,180,255,.14);
  border: 1px solid var(--px-border);
  box-shadow: 0 0 18px var(--px-glow);
}

.px-title{
  margin: 12px 0 10px;
  font-size: clamp(2rem, 4vw, 3.1rem);
  font-weight: 900;
  line-height: 1.05;
  color: var(--px-text);
  text-shadow: 0 0 24px var(--px-glow);
}

.px-desc{
  margin: 0 0 16px;
  max-width: 62ch;
  font-size: clamp(1rem, 1.1vw, 1.15rem);
  line-height: 1.6;
  color: rgba(235,245,255,.95);
}

.px-actions{
  display:flex; flex-wrap:wrap; gap:10px;
  margin-bottom: 14px;
}

.px-btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding: 11px 16px;
  border-radius: 14px;
  font-weight: 900;
  text-decoration:none;
  border: 1px solid rgba(255,255,255,.12);
}

.px-btn-primary{
  background: linear-gradient(135deg,#008cff,#00e0ff);
  color:#001524;
  box-shadow: 0 0 26px var(--px-glow);
}

.px-btn-ghost{
  background: rgba(0,180,255,.08);
  border: 1px solid var(--px-border);
  color: var(--px-text);
}

.px-metrics{
  display:flex; flex-wrap:wrap; gap:10px;
}

.px-metric{
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(0,180,255,.10);
  border: 1px solid var(--px-border);
  box-shadow: inset 0 0 14px rgba(0,180,255,.18);
  min-width: 150px;
}
.px-metric b{ display:block; color:var(--px-text); }
.px-metric span{ display:block; color:rgba(235,245,255,.92); font-size:.86rem; margin-top:2px; }

/* ================= VISUAL ================= */
.px-visual{ position: relative; min-height: 320px; }
.px-frame{
  position: relative;
  width: 100%;
  height: clamp(260px, 22vw, 360px);
  border-radius: 22px;
  overflow:hidden;
  display:grid;
  place-items:center;
  border: 1px solid var(--px-border);
  background:
    radial-gradient(circle at center, rgba(0,180,255,.22), transparent 70%),
    linear-gradient(135deg, var(--px-bg), var(--px-panel));
  transform-style: preserve-3d;
}

.px-frame img{
  width: min(92%, 520px);
  height:auto;
  max-height: 82%;
  object-fit: contain;
  filter: drop-shadow(0 0 22px var(--px-glow)) drop-shadow(0 28px 55px rgba(0,0,0,.85));
  transform: translateZ(18px);
}

/* scan dentro del frame */
.px-scan{
  position:absolute; inset:-40%;
  background: linear-gradient(90deg, transparent, rgba(0,180,255,.22), transparent);
  transform: rotate(-10deg);
  animation: pxScan2 3.6s linear infinite;
  pointer-events:none;
}
@keyframes pxScan2{
  0%{ transform: translateX(-55%) rotate(-10deg); }
  100%{ transform: translateX(55%) rotate(-10deg); }
}

.px-hud{
  position:absolute; left:14px; right:14px; bottom:14px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--px-accent), transparent);
  opacity:.95;
}

/* bolitas flotantes */
.px-float{
  position:absolute;
  width: 14px; height:14px;
  border-radius: 999px;
  background: rgba(0,180,255,.55);
  filter: blur(.2px);
  box-shadow: 0 0 18px rgba(0,180,255,.8);
  opacity:.85;
  animation: pxFloat 3.2s ease-in-out infinite;
}
.px-f1{ top: 18px; right: 26px; animation-delay: .0s; }
.px-f2{ bottom: 24px; right: 54px; width:10px; height:10px; animation-delay: .6s; }
.px-f3{ top: 62px; left: 14px; width:8px; height:8px; animation-delay: 1.1s; }

@keyframes pxFloat{
  0%,100%{ transform: translateY(0); }
  50%{ transform: translateY(-10px); }
}

/* ================= CARDS ================= */
.px-section{ padding: 26px 16px 52px; }
.px-head{ max-width:1200px; margin: 0 auto 14px; text-align:center; }
.px-head-title{
  margin:0 0 8px;
  font-size: clamp(1.7rem, 2.6vw, 2.4rem);
  font-weight:900;
  color: var(--px-text);
  text-shadow: 0 0 18px var(--px-glow);
}
.px-head-sub{ margin:0 auto; max-width: 820px; color: rgba(235,245,255,.95); line-height:1.55; }

.px-cards{
  max-width: 1200px;
  margin: 16px auto 0;
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 16px;
}

.px-card{
  position:relative;
  border-radius: 18px;
  overflow:hidden;
  border: 1px solid var(--px-border);
  background: linear-gradient(180deg, rgba(0,180,255,.08), rgba(0,0,0,.35));
  box-shadow: 0 18px 45px rgba(0,0,0,.65);
  transform-style: preserve-3d;
  transition: transform .18s ease, box-shadow .18s ease;
}

.px-card-media{
  position:relative;
  height: 200px;
  display:grid;
  place-items:center;
  background:
    radial-gradient(circle at center, rgba(0,180,255,.18), transparent 72%),
    linear-gradient(135deg, var(--px-bg), var(--px-panel));
}

.px-card-media img{
  width: min(90%, 221px);
  height:auto;
  max-height: 80%;
  object-fit: contain;
  filter: drop-shadow(0 0 16px var(--px-glow)) drop-shadow(0 18px 32px rgba(0,0,0,.85));
  transform: translateZ(14px);
}

/* glow de la card (sigue el mouse) */
.px-card-glow{
  position:absolute; inset:-60px;
  background: radial-gradient(circle at var(--mx, 50%) var(--my, 50%), rgba(0,180,255,.35), transparent 55%);
  opacity: 0;
  transition: opacity .18s ease;
  pointer-events:none;
}

.px-card-body{ padding: 14px 14px 16px; }
.px-card-body h3{
  margin:0 0 8px;
  font-size: 1.2rem;
  font-weight: 900;
  color: var(--px-text);
}
.px-card-body p{
  margin:0;
  color: rgba(235,245,255,.95);
  line-height: 1.5;
}

.px-card-cta{
  display:block;
  text-align:center;
  padding: 12px 14px;
  font-weight: 900;
  text-decoration:none;
  color:#001524;
  background: linear-gradient(135deg,#008cff,#00e0ff);
}

/* hover */
@media (hover:hover){
  .px-card:hover{
    box-shadow: 0 0 40px var(--px-glow), 0 22px 55px rgba(0,0,0,.75);
  }
  .px-card:hover .px-card-glow{ opacity: 1; }
}

/* ================= RESPONSIVE ================= */
@media (max-width: 980px){
  .px-grid{ grid-template-columns: 1fr; }
  .px-visual{ min-height: 260px; }
  .px-cards{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 560px){
  .px-cards{ grid-template-columns: 1fr; }
  .px-btn{ width: 100%; }
}

 
  /* ================== fin elpoliestileno  ================== */
    /* ================== boton de whatsapp ================== */

.btn-whatsapp-float{
  position: fixed;
  right: 22px;
  bottom: 22px;
  z-index: 9999;

  display: inline-flex;
  align-items: center;
  gap: 10px;

  padding: 14px 18px;
  background: #25D366;
  color: #fff;
  text-decoration: none;

  font-family: "Inter", system-ui, sans-serif;
  font-size: 15px;
  font-weight: 700;

  border-radius: 50px;
  box-shadow: 0 12px 30px rgba(0,0,0,.35);

  transition: transform .2s ease, box-shadow .2s ease;
}

.btn-whatsapp-float svg{
  width: 26px;
  height: 26px;
  flex-shrink: 0;
}

.btn-whatsapp-float:hover{
  transform: translateY(-4px) scale(1.04);
  box-shadow: 0 18px 40px rgba(0,0,0,.45);
}

/* Móvil: solo icono */
@media (max-width: 520px){
  .btn-whatsapp-float span{
    display: none;
  }
  .btn-whatsapp-float{
    padding: 14px;
  }
}
  

/* AQUI MANUAL DE MARCA  */

/* =================================================
   HERO ULTRA (pq-hero--ultra)
================================================= */
.pq-hero--ultra{ padding: 14px 16px 34px; }
.pq-hero--ultra *{ box-sizing:border-box; }
.pq-hero--ultra img{ display:block; max-width:100%; }

.pq-hero--ultra .pq-hero-inner{
  max-width: 1320px;
  margin: 0 auto;
  position: relative;
  overflow: hidden;
  border-radius: 34px;
  border: 1px solid rgba(0,170,255,.35);
  background: linear-gradient(135deg, #070b22, #0c1438);
  box-shadow: 0 34px 110px rgba(0,0,0,.72);

  /* ✅ banner grande */
  min-height: 620px;
  height: clamp(620px, 55vw, 820px);
}

/* ---------- Fondo animado ---------- */
.pq-ultra-bg{ position:absolute; inset:0; pointer-events:none; }

.pq-grid{
  position:absolute; inset:0;
  background:
    linear-gradient(rgba(0,180,255,.10) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,180,255,.10) 1px, transparent 1px);
  background-size: 56px 56px;
  opacity: .22;
  mask-image: radial-gradient(circle at 55% 35%, rgba(0,0,0,1), transparent 70%);
  transform: translateZ(0);
  animation: pqGridMove 10s linear infinite;
}
@keyframes pqGridMove{
  0%{ background-position: 0 0, 0 0; }
  100%{ background-position: 120px 120px, 120px 120px; }
}

.pq-particles{
  position:absolute; inset:-30%;
  background:
    radial-gradient(circle, rgba(0,180,255,.30) 1px, transparent 2px),
    radial-gradient(circle, rgba(255,255,255,.16) 1px, transparent 2px);
  background-size: 90px 90px, 140px 140px;
  opacity: .35;
  filter: blur(.2px);
  animation: pqParticles 12s linear infinite;
}
@keyframes pqParticles{
  0%{ transform: translate3d(-2%, -2%, 0); }
  100%{ transform: translate3d(2%, 2%, 0); }
}

.pq-sweep{
  position:absolute; inset:-40%;
  background: linear-gradient(90deg, transparent, rgba(0,180,255,.18), transparent);
  transform: rotate(14deg);
  animation: pqSweep 4.6s linear infinite;
  opacity: .85;
}
@keyframes pqSweep{
  0%{ transform: translateX(-55%) rotate(14deg); }
  100%{ transform: translateX(55%) rotate(14deg); }
}

/* ---------- Layout ---------- */
.pq-ultra-content{
  position: relative;
  z-index: 2;
  height: 100%;
  padding: clamp(26px, 3vw, 54px);

  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 26px;
  align-items:center;
}

/* ---------- Texto ---------- */
.pq-ultra-badge{
  display:inline-flex;
  padding: 10px 16px;
  border-radius: 999px;
  font-weight: 900;
  font-size: .86rem;
  letter-spacing: .08em;
  color: #eaf7ff;
  background: rgba(0,180,255,.14);
  border: 1px solid rgba(0,170,255,.35);
  box-shadow: 0 0 22px rgba(0,180,255,.55);
  margin-bottom: 12px;
}

.pq-ultra-title{
  margin: 0 0 12px;
  font-size: clamp(2.6rem, 5vw, 4.1rem);
  font-weight: 900;
  line-height: 1.0;
  color: #eaf7ff;
  text-shadow: 0 0 28px rgba(0,180,255,.55);
  position: relative;
}

.pq-ultra-title-glow{
  position:absolute; inset:-30px -20px;
  background: radial-gradient(circle at 25% 40%, rgba(0,180,255,.28), transparent 60%);
  filter: blur(6px);
  opacity: .95;
  pointer-events:none;
}

.pq-ultra-desc{
  margin: 0 0 18px;
  max-width: 66ch;
  font-size: clamp(1.05rem, 1.25vw, 1.25rem);
  line-height: 1.7;
  color: rgba(235,245,255,.96);
}

/* Botones */
.pq-ultra-actions{
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}

.pq-ultra-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 13px 20px;
  border-radius: 18px;
  font-weight: 900;
  text-decoration:none;
  white-space: nowrap;
  border: 1px solid rgba(255,255,255,.12);
  position: relative;
  overflow:hidden;
}

.pq-ultra-primary{
  background: linear-gradient(135deg,#008cff,#00e0ff);
  color:#001524;
  box-shadow: 0 0 30px rgba(0,180,255,.60);
}
.pq-ultra-primary::after{
  content:"";
  position:absolute; inset:-60%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.35), transparent);
  transform: rotate(16deg);
  animation: pqBtnShine 2.8s linear infinite;
  opacity: .8;
}
@keyframes pqBtnShine{
  0%{ transform: translateX(-55%) rotate(16deg); }
  100%{ transform: translateX(55%) rotate(16deg); }
}

.pq-ultra-ghost{
  background: rgba(0,180,255,.08);
  border: 1px solid rgba(0,170,255,.35);
  color:#eaf7ff;
}

/* KPIs */
.pq-ultra-kpis{
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.pq-kpi{
  padding: 12px 12px;
  border-radius: 18px;
  background: rgba(0,180,255,.10);
  border: 1px solid rgba(0,170,255,.30);
  box-shadow: inset 0 0 14px rgba(0,180,255,.18);
}
.pq-kpi b{ display:block; color:#eaf7ff; font-size: .98rem; }
.pq-kpi span{ display:block; color: rgba(235,245,255,.92); font-size: .86rem; margin-top: 2px; }

/* ---------- Orbita / Visual ---------- */
.pq-orbit{
  position: relative;
  width: 100%;
  height: clamp(360px, 28vw, 520px);
  display:grid;
  place-items:center;
  perspective: 900px;
}

.pq-orbit-ring{
  position:absolute;
  width: 92%;
  height: 92%;
  border-radius: 999px;
  border: 1px solid rgba(0,180,255,.30);
  box-shadow: 0 0 26px rgba(0,180,255,.28);
  animation: pqRotate 10s linear infinite;
  opacity: .8;
}
.pq-ring2{
  width: 72%;
  height: 72%;
  animation-duration: 14s;
  opacity: .55;
}
@keyframes pqRotate{
  0%{ transform: rotate(0deg); }
  100%{ transform: rotate(360deg); }
}

.pq-ultra-card{
  width: min(92%, 540px);
  height: 100%;
  max-height: 460px;
  border-radius: 26px;
  overflow:hidden;
  display:grid;
  place-items:center;
  border: 1px solid rgba(0,170,255,.35);
  background:
    radial-gradient(circle at center, rgba(0,180,255,.22), transparent 70%),
    linear-gradient(135deg, #070b22, #0c1438);

  transform-style: preserve-3d;
  transition: transform .18s ease;
  box-shadow: 0 30px 80px rgba(0,0,0,.75);
}

.pq-ultra-card img{
  width: min(92%, 680px);
  height:auto;
  max-height: 86%;
  object-fit: contain;
  transform: translateZ(18px);
  filter:
    drop-shadow(0 0 24px rgba(0,180,255,.55))
    drop-shadow(0 34px 70px rgba(0,0,0,.88));
}

.pq-ultra-hud{
  position:absolute;
  left:16px; right:16px; bottom:16px;
  height: 1px;
  background: linear-gradient(90deg, transparent, #00b4ff, transparent);
  opacity:.95;
}

/* nodos */
.pq-node{
  position:absolute;
  width: 10px; height:10px;
  border-radius: 999px;
  background: rgba(0,180,255,.75);
  box-shadow: 0 0 18px rgba(0,180,255,.95);
  animation: pqNode 2.8s ease-in-out infinite;
}
.pq-n1{ top: 18%; left: 16%; }
.pq-n2{ bottom: 22%; right: 18%; animation-delay: .6s; }
.pq-n3{ top: 32%; right: 12%; width: 8px; height: 8px; animation-delay: 1.2s; }
@keyframes pqNode{
  0%,100%{ transform: scale(1); opacity: .9; }
  50%{ transform: scale(1.25); opacity: .55; }
}

/* Scroll indicador */
.pq-scroll{
  position:absolute;
  left: 50%;
  bottom: 16px;
  transform: translateX(-50%);
  display:flex;
  flex-direction: column;
  align-items:center;
  gap: 6px;
  z-index: 3;
  opacity: .9;
}
.pq-scroll-dot{
  width: 10px; height: 18px;
  border-radius: 999px;
  border: 1px solid rgba(0,180,255,.45);
  position: relative;
}
.pq-scroll-dot::after{
  content:"";
  position:absolute;
  top: 3px; left: 50%;
  transform: translateX(-50%);
  width: 4px; height: 4px;
  border-radius: 999px;
  background: rgba(0,180,255,.9);
  animation: pqScroll 1.2s ease-in-out infinite;
}
@keyframes pqScroll{
  0%,100%{ transform: translateX(-50%) translateY(0); opacity: .95; }
  50%{ transform: translateX(-50%) translateY(8px); opacity: .55; }
}
.pq-scroll-text{
  font-weight: 900;
  letter-spacing: .12em;
  font-size: .72rem;
  color: rgba(235,245,255,.85);
}

/* Responsive */
@media (max-width: 980px){
  .pq-ultra-content{ grid-template-columns: 1fr; }
  .pq-ultra-kpis{ grid-template-columns: repeat(2, minmax(0,1fr)); }
  .pq-hero--ultra .pq-hero-inner{
    height: auto;
    min-height: 0;
  }
  .pq-orbit{ height: clamp(320px, 62vw, 440px); }
}
@media (max-width: 560px){
  .pq-ultra-btn{ width: 100%; }
}

/* FIN MANUAL DE MARCA  */

/* empezar roll up   */

/* ===== HERO APPLE (reutilizable) ===== */
.hero-apple{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 28px;
  align-items:center;
  padding: 48px 18px;
  border-radius: 22px;
  background: radial-gradient(1200px 600px at 10% 10%, rgba(0,255,200,.10), transparent 55%),
              radial-gradient(900px 600px at 90% 20%, rgba(120,120,255,.12), transparent 55%),
              #0b1020;
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 20px 60px rgba(0,0,0,.35);
  overflow:hidden;
}

.hero-apple h1{
  margin:0 0 10px;
  font-size: clamp(28px, 4vw, 48px);
  line-height: 1.05;
  color:#fff;
  letter-spacing:.5px;
}
.hero-apple h1 span{
  display:inline-block;
  margin-top: 6px;
  opacity:.95;
  color:#bde7ff;
}
.hero-apple p{
  margin: 0 0 14px;
  color: rgba(255,255,255,.78);
  max-width: 52ch;
}

.hero-visual{
  position:relative;
  display:flex;
  justify-content:center;
  align-items:center;
}
.hero-visual img{
  width: min(100%, 520px);
  height:auto;
  object-fit:contain;
  filter: drop-shadow(0 22px 40px rgba(0,0,0,.45));
  transform: translateY(4px);
}

.hero-badges{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top: 10px;
}
.badge{
  padding: 8px 12px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  color:#fff;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.12);
}

/* ===== SECCIÓN ROLL UP TECH ===== */
.rollup-tech{
  padding: 34px 0 10px;
}

.rollup-head{
  text-align:center;
  margin-bottom: 18px;
}
.rollup-title{
  margin:0;
  color:#fff;
  letter-spacing: 2px;
  font-size: clamp(22px, 3.2vw, 34px);
}
.rollup-sub{
  margin: 8px auto 0;
  color: rgba(255,255,255,.70);
  max-width: 70ch;
}

/* GRID organizado con espacio */
.rollup-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  padding: 14px 6px 0;
}

/* Card tech */
.ru-card{
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 18px;
  overflow:hidden;
  box-shadow: 0 18px 44px rgba(0,0,0,.35);
  transition: transform .18s ease, border-color .18s ease;
}
.ru-card:hover{
  transform: translateY(-4px);
  border-color: rgba(0,255,200,.25);
}

.ru-media{
  position:relative;
  background: #0a0f1f;
  padding: 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height: 220px; /* mismo alto para que no se descuadre */
}
.ru-media img{
  width: 100%;
  max-width: 320px;
  height: auto;
  object-fit: contain;
}

.ru-hud{
  position:absolute;
  inset: 10px;
  border-radius: 14px;
  border: 1px dashed rgba(0,255,200,.18);
  pointer-events:none;
}

.ru-body{
  padding: 14px 14px 16px;
}
.ru-body h4{
  margin:0 0 8px;
  color:#fff; /* letras blancas */
  font-size: 16px;
}
.ru-body p{
  margin:0 0 12px;
  color: rgba(255,255,255,.72); /* blanco suave */
  font-size: 13px;
  line-height: 1.35;
  min-height: 38px; /* asegura alineación */
}

.ru-chip{
  display:inline-block;
  font-size: 20px;
  font-weight: 800;
  color:#0b1020;
  background: linear-gradient(90deg, #00ffc8, #7aa6ff);
  padding: 8px 12px;
  border-radius: 999px;
}

/* ===== RESPONSIVE ===== */
@media (max-width: 980px){
  .hero-apple{
    grid-template-columns: 1fr;
    padding: 34px 14px;
  }
  .rollup-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 560px){
  .rollup-grid{
    grid-template-columns: 1fr;
  }
  .ru-media{
    min-height: 210px;
  }
}

.ru-price{
  margin: 4px 0 10px;
  font-size: 22px;
  font-weight: 900;
  color:#fff;
  letter-spacing: .2px;
}

.ru-list{
  margin: 0 0 12px;
  padding-left: 16px;
  color: rgba(255,255,255,.78);
  font-size: 13px;
  line-height: 1.35;
}
.ru-list li{ margin: 4px 0; }

.ru-actions{
  margin-top: 10px;
  display:flex;
  gap:10px;
}

.ru-btn-wa{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:100%;
  padding: 12px 12px;
  border-radius: 14px;
  font-weight: 900;
  text-decoration:none;
  background: #25D366;
  color:#0b1f12;
  transition: transform .18s ease, filter .18s ease;
}
.ru-btn-wa:hover{
  transform: translateY(-2px);
  filter: brightness(1.05);
}



/* fin de roll up  */



/* HERO */
.hero-arana{
display:grid;
grid-template-columns:1.1fr .9fr;
align-items:center;
gap:30px;
padding:60px 20px;
background:linear-gradient(135deg,#09122b,#0c1e45);
border-radius:22px;
color:#fff;
}

.hero-arana-content h1{
font-size:48px;
margin-bottom:15px;
}

.hero-arana-content p{
opacity:.85;
max-width:500px;
}

.hero-arana-tags{
margin-top:15px;
display:flex;
gap:10px;
flex-wrap:wrap;
}
.hero-arana-tags span{
background:#00ffc8;
color:#000;
padding:6px 12px;
border-radius:50px;
font-weight:700;
font-size:13px;
}

.hero-arana-img img{
max-width:420px;
width:100%;
}


/* GRID */
.arana-section{
padding:60px 20px;
}

.arana-title{
text-align:center;
font-size:32px;
margin-bottom:40px;
}

.arana-grid{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
gap:25px;
}


/* CARD */
.arana-card{
background:#0c1838;
border-radius:18px;
padding:20px;
text-align:center;
color:#fff;
transition:.3s;
}

.arana-card:hover{
transform:translateY(-8px);
box-shadow:0 20px 40px rgba(0,0,0,.4);
}

.arana-card img{
width:100%;
height:200px;
object-fit:contain;
margin-bottom:15px;
}

.arana-card h3{
margin-bottom:10px;
}

.arana-card p{
opacity:.8;
font-size:14px;
min-height:40px;
}

.arana-price{
font-size:26px;
font-weight:bold;
margin:15px 0;
color:#00ffc8;
}


/* BOTON */
.arana-btn{
display:inline-block;
background:#25D366;
color:#fff;
padding:12px 18px;
border-radius:10px;
text-decoration:none;
font-weight:bold;
transition:.3s;
}

.arana-btn:hover{
background:#1da851;
}


/* RESPONSIVE */
@media(max-width:900px){
.hero-arana{
grid-template-columns:1fr;
text-align:center;
}
.hero-arana-img{
order:-1;
}
}
.tech-title{
  font-family: "Bebas Neue", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: clamp(36px, 5.2vw, 72px);
  color: #fff;
  margin: 0 0 38px;
  letter-spacing: 2px;
  text-shadow: 
    0 0 10px rgba(0,229,255,.45),
    0 0 25px rgba(123,92,255,.35);
    
}


/* Subtítulo */
.tech-subtitle{
  font-size: clamp(22px, 3.2vw, 42px);
  margin-top: -18px;
  opacity: .85;
  letter-spacing: 3px;
  text-align: center; /* 🔥 CENTRADO */
}



/* =========================
   POPMAN - STYLE v2 (Glass/Neon)
   ========================= */
.pm2{
  max-width: 1200px;
  margin: 0 auto;
  padding: 34px 16px 64px;
}

.pm2-title{
  font-family: "Bebas Neue", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: clamp(36px, 5.2vw, 72px);
  color: #fff;
  margin: 0 0 16px;
  letter-spacing: 2px;
  text-shadow: 0 0 10px rgba(0,229,255,.35), 0 0 26px rgba(123,92,255,.28);
}
.pm2-title span{ color:#7b5cff; }
.pm2-center{ text-align:center; }

/* ===== HERO ===== */
.pm2-hero{
  margin-bottom: 22px;
}
.pm2-hero-inner{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 18px;
  align-items:center;
}

.pm2-copy{
  text-align:left;
}
.pm2-desc{
  color: rgba(255,255,255,.86);
  line-height: 1.6;
  margin: 0 0 16px;
  max-width: 60ch;
}

.pm2-stats{
  display:flex;
  flex-wrap:wrap;
  gap: 12px;
  margin: 0 0 18px;
}
.pm2-stat{
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.18);
  backdrop-filter: blur(10px);
  border-radius: 16px;
  padding: 10px 12px;
  min-width: 150px;
}
.pm2-stat-k{
  display:block;
  color: rgba(255,255,255,.75);
  font-size: 12px;
  letter-spacing: 1px;
  text-transform: uppercase;
}
.pm2-stat-v{
  display:block;
  color:#fff;
  font-weight: 800;
  margin-top: 2px;
}

.pm2-actions{
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
}
.pm2-btn{
  text-decoration:none;
  color:#fff;
  font-weight: 900;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(0,0,0,.18);
  transition: transform .15s ease, box-shadow .15s ease;
}
.pm2-btn:hover{ transform: translateY(-1px); }
.pm2-btn-primary{
  border-color: rgba(123,92,255,.55);
  box-shadow: 0 0 18px rgba(123,92,255,.22);
}
.pm2-btn-ghost{
  border-color: rgba(0,229,255,.30);
  background: rgba(0,229,255,.10);
}

/* ===== 3D PARALLAX STAGE ===== */
.pm2-stage{
  display:flex;
  justify-content:center;
}
.pm2-parallax{
  width: min(520px, 96vw);
  height: 330px;
  position: relative;
  border-radius: 26px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.14);
  background: radial-gradient(900px 420px at 20% 20%, rgba(0,229,255,.14), transparent 60%),
              radial-gradient(900px 420px at 80% 70%, rgba(123,92,255,.12), transparent 60%),
              rgba(0,0,0,.22);
  transform-style: preserve-3d;
  will-change: transform;
  box-shadow: 0 22px 55px rgba(0,0,0,.35);
}

.pm2-shine{
  position:absolute;
  inset:-80px;
  background: radial-gradient(circle at var(--sx,50%) var(--sy,50%),
            rgba(255,255,255,.18), transparent 45%);
  filter: blur(18px);
  opacity: .9;
  pointer-events:none;
}

.pm2-layer{
  position:absolute;
  inset:0;
  transform: translate3d(0,0,0);
  will-change: transform;
}

.pm2-layer-bg{
  background:
    radial-gradient(2px 2px at 10% 20%, rgba(255,255,255,.55) 40%, transparent 41%),
    radial-gradient(2px 2px at 30% 70%, rgba(255,255,255,.35) 40%, transparent 41%),
    radial-gradient(2px 2px at 80% 30%, rgba(255,255,255,.40) 40%, transparent 41%),
    radial-gradient(2px 2px at 70% 85%, rgba(255,255,255,.30) 40%, transparent 41%);
  opacity:.65;
}

.pm2-layer-lines{
  background:
    linear-gradient(transparent 0, rgba(255,255,255,.06) 1px, transparent 2px);
  background-size: 100% 18px;
  opacity:.35;
  mix-blend-mode: screen;
}

.pm2-layer-img{
  width: 85%;
  height: 100%;
  object-fit: contain;
  position:absolute;
  right: -8px;
  bottom: -18px;
  filter: drop-shadow(0 20px 40px rgba(0,0,0,.45));
}

.pm2-layer-card{
  inset:auto;
  left: 16px;
  bottom: 16px;
  width: 62%;
  max-width: 320px;
  padding: 14px 14px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.24);
  backdrop-filter: blur(12px);
}

.pm2-chip{
  display:inline-block;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(123,92,255,.18);
  color:#fff;
  font-weight: 900;
  letter-spacing: 2px;
}

.pm2-mini{
  margin-top: 10px;
  color:#fff;
}
.pm2-mini strong{ display:block; }
.pm2-mini span{ display:block; opacity:.82; margin-top: 3px; font-size: 13px; }

/* ===== GRID CARDS ===== */
.pm2-grid{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 16px;
  margin-top: 18px;
}

.pm2-card{
  grid-column: span 6;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.18);
  backdrop-filter: blur(10px);
  overflow:hidden;
  transform-style: preserve-3d;
  will-change: transform;
  box-shadow: 0 18px 45px rgba(0,0,0,.30);
  transition: transform .15s ease, box-shadow .15s ease;
}

.pm2-card-top{
  display:flex;
  gap: 12px;
  align-items:center;
  padding: 14px 14px 8px;
}

.pm2-thumb{
  width: 108px;
  height: 108px;
  object-fit: contain;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  padding: 8px;
}

.pm2-head h3{
  margin: 0;
  color:#fff;
  font-size: 20px;
}
.pm2-size{
  margin: 6px 0 0;
  color: rgba(255,255,255,.8);
  font-weight: 700;
}

.pm2-list{
  margin: 0;
  padding: 0 18px 12px 34px;
  color: rgba(255,255,255,.88);
  line-height: 1.45;
}
.pm2-list li{ margin: 7px 0; }
.pm2-list b{ color:#fff; }

.pm2-card-bottom{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  padding: 12px 14px 16px;
  border-top: 1px solid rgba(255,255,255,.10);
}

.pm2-price span{
  display:block;
  font-size: 12px;
  color: rgba(255,255,255,.75);
  letter-spacing: 1px;
  text-transform: uppercase;
}
.pm2-price strong{
  display:block;
  color:#fff;
  font-size: 20px;
  text-shadow: 0 0 12px rgba(0,229,255,.16);
}

.pm2-wa{
  text-decoration:none;
  color:#fff;
  font-weight: 900;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(0,229,255,.28);
  background: rgba(0,229,255,.10);
  transition: transform .15s ease, box-shadow .15s ease;
  white-space: nowrap;
}
.pm2-wa:hover{
  transform: translateY(-1px);
  box-shadow: 0 0 18px rgba(0,229,255,.18);
}

/* ===== RESPONSIVE ===== */
@media (max-width: 980px){
  .pm2-hero-inner{ grid-template-columns: 1fr; }
  .pm2-copy{ text-align:center; }
  .pm2-stats{ justify-content:center; }
  .pm2-actions{ justify-content:center; }
  .pm2-card{ grid-column: span 12; }
}
.pm2-parallax{
  width: min(980px, 96vw);     /* MÁS ANCHO */
  height: clamp(420px, 46vw, 560px); /* MÁS ALTO (responsive) */
  position: relative;
  border-radius: 28px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.14);
  background: radial-gradient(1200px 520px at 20% 20%, rgba(0,229,255,.14), transparent 60%),
              radial-gradient(1100px 520px at 80% 70%, rgba(123,92,255,.12), transparent 60%),
              rgba(0,0,0,.22);
  transform-style: preserve-3d;
  will-change: transform;
  box-shadow: 0 28px 70px rgba(0,0,0,.38);
}
.pm2-layer-img{
  width: min(78%, 720px);   /* más grande */
  height: 100%;
  object-fit: contain;
  position:absolute;
  right: -20px;
  bottom: -26px;
  transform-origin: center;
  filter: drop-shadow(0 22px 55px rgba(0,0,0,.50));
}
.pm2-layer-card{
  inset:auto;
  left: 22px;
  bottom: 22px;
  width: min(52%, 420px);
  padding: 16px 16px;
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.26);
  backdrop-filter: blur(14px);
}
@media (max-width: 640px){
  .pm2-parallax{
    width: 96vw;
    height: 420px; /* grande pero controlado en móvil */
  }
  .pm2-layer-img{
    width: 92%;
    right: -26px;
    bottom: -34px;
  }
  .pm2-layer-card{
    width: calc(100% - 28px);
    left: 14px;
    bottom: 14px;
  }
}
.pm2-thumb{
  width: 160px;              /* MÁS GRANDE */
  height: 160px;
  object-fit: contain;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.14);
  background: radial-gradient(
    120px 120px at 30% 20%,
    rgba(123,92,255,.18),
    rgba(255,255,255,.06)
  );
  padding: 12px;
  flex-shrink: 0;
  box-shadow: 
    0 18px 40px rgba(0,0,0,.35),
    inset 0 0 18px rgba(123,92,255,.18);
}
.pm2-thumb{
  width: 160px;              /* MÁS GRANDE */
  height: 160px;
  object-fit: contain;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.14);
  background: radial-gradient(
    120px 120px at 30% 20%,
    rgba(123,92,255,.18),
    rgba(255,255,255,.06)
  );
  padding: 12px;
  flex-shrink: 0;
  box-shadow: 
    0 18px 40px rgba(0,0,0,.35),
    inset 0 0 18px rgba(123,92,255,.18);
}
.pm2-card:hover .pm2-thumb{
  transform: translateY(-6px) scale(1.04);
  box-shadow:
    0 26px 60px rgba(0,0,0,.45),
    inset 0 0 22px rgba(123,92,255,.25);
}
@media (max-width: 640px){
  .pm2-thumb{
    width: 140px;
    height: 140px;
  }
}
.pm2-wa{
  position: relative;
  z-index: 50;
  pointer-events: auto;
}

.pm2-card *{
  pointer-events: auto;
}

/* Si tienes capas decorativas encima, fuerza que no bloqueen clic */
.pm2-shine,
.pm2-layer-lines,
.pm2-layer-bg{
  pointer-events: none;
}
.pm2-card-top{
  display: flex;
  gap: 18px;
  align-items: center;
  padding-bottom: 10px;
}
.pm2-head h3{
  font-size: 24px;
  margin: 0;
}
.pm2-size{
  font-size: 16px;
  font-weight: 700;
  margin-top: 8px;
}
.pm2-wa{
  padding: 14px 18px;
  border-radius: 14px;
  font-size: 15px;
  font-weight: 900;
  cursor: pointer;
}
@media (max-width: 980px){
  .pm2-grid{
    grid-template-columns: 1fr;   /* 1 columna */
  }
  .pm2-card{
    min-height: auto;
  }
}

@media (max-width: 520px){
  .pm2-thumb{
    width: 160px;
    height: 160px;
  }
}
.pm2{
  max-width: 1400px;   /* antes 1200 */
  margin: 0 auto;
  padding: 40px 18px 70px;
}
.pm2-thumb{
  width: 300px;                   /* 🔥 más grande */
  height: 300px;
  object-fit: contain;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  padding: 14px;
  flex-shrink: 0;
  box-shadow: 0 18px 45px rgba(0,0,0,.35);
}


/* ===== BOTÓN DESCUENTO WMAX ===== */

.btn-descuento{
  position: fixed;
  bottom: 120px;
  left: 20px; /* ahora queda a la izquierda */
  display: flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg,#ff0066,#ff3c00);
  color: white;
  font-weight: 700;
  padding: 12px 18px;
  border-radius: 40px;
  text-decoration: none;
  font-size:    35px; 
  z-index: 9999;
  box-shadow: 0 8px 25px rgba(0,0,0,.35);
  animation: pulsePromo 2s infinite;
}

.btn-descuento:hover{
  transform: scale(1.05);
}

.icono-descuento{
  font-size: 18px;
  font-weight: bold;
}

@keyframes pulsePromo{
  0%{ transform: scale(1); }
  50%{ transform: scale(1.08); }
  100%{ transform: scale(1); }
}

/* BOTÓN WHATSAPP EN LAS CARDS */
.wmax-card-btn{
  background:#25D366;
  color:#fff;
  padding:10px 16px;
  border-radius:25px;
  font-weight:600;
  text-decoration:none;
  display:inline-block;
  margin-top:15px;   /* baja el botón un poco */
  transition:0.3s;
}

/* HOVER */
.wmax-card-btn:hover{
  background:#1ebe5b;
  color:#fff;
}

.vin-btn-whatsapp{
  background:#25D366;
  color:#fff;
  text-decoration:none;
  padding:10px 14px;
  border-radius:25px;
  display:inline-block;
  margin-top:12px;
  font-weight:600;
  font-size:14px;
  transition:0.3s;
}

.vin-btn-whatsapp:hover{
  background:#1ebe5b;
  color:#fff;
}

.talonarios-productos{

padding:80px 20px;
background:#f5f5f5;
text-align:center;

}

.titulo-talonarios{

font-size:42px;
margin-bottom:60px;
font-weight:700;
color:#333;

}

.titulo-talonarios span{

background:linear-gradient(90deg,#667eea,#6c75de,#706dd2,#7364c6,#755cba,#7653ae,#764ba2);
-webkit-background-clip:text;
-webkit-text-fill-color:transparent;

}

.grid-talonarios{

max-width:1200px;
margin:auto;

display:grid;
grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
gap:40px;

}

.card-talonario{

background:white;
padding:40px 30px;
border-radius:20px;

box-shadow:0 15px 40px rgba(0,0,0,0.08);

transition:0.3s;

}

.card-talonario:hover{

transform:translateY(-10px);

}

.tag-tamano{

display:inline-block;
padding:10px 20px;

background:linear-gradient(90deg,#667eea,#6c75de,#706dd2,#7364c6,#755cba,#7653ae,#764ba2);
color:white;

font-weight:700;
border-radius:30px;
margin-bottom:20px;

}

.card-talonario h3{

font-size:24px;
margin-bottom:10px;

}

.precio{

font-size:40px;
font-weight:700;
color:#444;
margin-bottom:20px;

}

.card-talonario ul{

list-style:none;
padding:0;
margin-bottom:30px;

}

.card-talonario li{

padding:10px 0;
border-bottom:1px solid #eee;

}

.btn-cotizar{

display:inline-block;

background:linear-gradient(90deg,#667eea,#6c75de,#706dd2,#7364c6,#755cba,#7653ae,#764ba2);

color:white;
padding:12px 28px;

border-radius:30px;
font-weight:700;

transition:0.3s;

}

.btn-cotizar:hover{

transform:scale(1.05);

}


