/* ============================================================
   CAMISETAS + CAMISETAS — Sistema de diseño global
   Paleta: Negro & Rojo | Estilo: Premium, moderno, minimalista
   ============================================================ */

:root{
  /* Marca */
  --rojo:        #d10f2d;
  --rojo-claro:  #ff2a45;
  --rojo-oscuro: #97091f;
  --negro:       #0b0b0d;
  --carbon:      #15151a;
  --carbon-2:    #1d1d24;
  --gris:        #8a8a93;
  --gris-claro:  #c9c9d1;
  --linea:       rgba(255,255,255,.08);
  --blanco:      #f6f6f8;
  --blanco-puro: #ffffff;
  --amarillo:    #ffd400;   /* acento tipo cinta de prevención */
  --amarillo-2:  #e6be00;

  /* Premium Gradients & Glows */
  --gradient-rojo: linear-gradient(135deg, var(--rojo-claro) 0%, var(--rojo) 100%);
  --glow-rojo: 0 0 25px rgba(255, 42, 69, 0.45);
  --trans-cubic: 0.5s cubic-bezier(0.16, 1, 0.3, 1);

  /* Tipografía */
  --f-display: 'Unbounded', system-ui, sans-serif;  /* títulos originales */
  --f-titulo:  'Unbounded', system-ui, sans-serif;
  --f-texto:   'Manrope', system-ui, sans-serif;     /* cuerpo legible */
  --f-mano:    'Caveat', cursive;                     /* mano alzada / lemas */

  /* Layout */
  --maxw: 1240px;
  --radio: 16px;
  --radio-sm: 10px;
  --sombra: 0 18px 50px rgba(0,0,0,.45);
  --sombra-roja: 0 14px 40px rgba(209,15,45,.35);
  --trans: .35s cubic-bezier(.16,1,.3,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden !important;max-width:100% !important;width:100% !important;}
body{
  font-family:var(--f-texto);
  background:var(--negro);
  color:var(--blanco);
  line-height:1.6;
  overflow-x:hidden !important;
  max-width:100% !important;
  width:100% !important;
  position:relative;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}
h1,h2,h3,h4{font-family:var(--f-display);font-weight:800;line-height:1.08;letter-spacing:-.03em}

/* Lema en mano alzada */
.mano{font-family:var(--f-mano);font-weight:700;letter-spacing:0;line-height:1}
.slogan-mano{
  font-family:var(--f-mano);font-weight:700;color:var(--rojo-claro);
  font-size:clamp(2.2rem,5vw,3.4rem);line-height:.95;display:inline-block;transform:rotate(-3deg);
}
.slogan-mano .blanco{color:#fff}

/* Glow backgrounds & gradients (premium) */
.glow-bg {
  position: absolute;
  width: min(500px, 80vw);
  height: min(500px, 80vw);
  background: radial-gradient(circle, rgba(209, 15, 45, 0.15) 0%, transparent 70%);
  border-radius: 50%;
  filter: blur(50px);
  z-index: 1;
  pointer-events: none;
  mix-blend-mode: screen;
  transform: translate3d(0,0,0);
}
.text-gradient {
  background: var(--gradient-rojo);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ---------- Utilidades ---------- */
.contenedor{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:24px}
.seccion{padding:96px 0}
.centro{text-align:center}
.rojo{color:var(--rojo-claro)}
.eyebrow{
  display:inline-block;font-family:var(--f-titulo);font-weight:700;
  font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--rojo-claro);margin-bottom:16px;
}
.titulo-seccion{font-size:clamp(2rem,4.5vw,3.2rem);margin-bottom:18px}
.subtitulo-seccion{color:var(--gris-claro);max-width:640px;margin:0 auto;font-size:1.05rem}
.subtitulo-seccion.izq{margin:0}

/* ---------- Botones ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--f-titulo);font-weight:700;font-size:.95rem;
  padding:15px 30px;border-radius:50px;border:1.5px solid transparent;
  cursor:pointer;transition:var(--trans-cubic);
  will-change:transform, box-shadow, background-color;
  transform:translate3d(0,0,0);
}
.btn svg{width:18px;height:18px;transition:transform var(--trans)}
.btn:hover svg{transform:translateX(4px)}
.btn-primario{background:var(--rojo);color:#fff;box-shadow:var(--sombra-roja)}
.btn-primario:hover{
  background:var(--rojo-claro);
  transform:translate3d(0, -4px, 0) scale(1.02);
  box-shadow: 0 12px 28px rgba(255, 42, 69, 0.45), 0 0 0 4px rgba(255, 42, 69, 0.15);
}
.btn-ghost{border-color:var(--linea);color:var(--blanco);background:rgba(255,255,255,.03)}
.btn-ghost:hover{
  border-color:var(--rojo-claro);
  color:var(--rojo-claro);
  transform:translate3d(0, -4px, 0) scale(1.02);
  box-shadow: 0 8px 20px rgba(255, 42, 69, 0.15);
}
.btn-blanco{background:#fff;color:var(--negro)}
.btn-blanco:hover{
  transform:translate3d(0, -4px, 0) scale(1.02);
  box-shadow: 0 15px 35px rgba(255,255,255,.25);
}

/* ============================================================
   TOPBAR + NAV
   ============================================================ */
.topbar{
  background: linear-gradient(90deg, #070709 0%, #15090d 50%, #070709 100%);
  position: relative;
  font-size:.78rem;color:var(--gris-claro);
  transition: var(--trans-cubic);
  letter-spacing: .03em;
}
.topbar::after{
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255, 42, 69, 0.35), transparent);
  box-shadow: 0 1px 8px rgba(255, 42, 69, 0.2);
  pointer-events: none;
}
.topbar .contenedor{display:flex;justify-content:space-between;align-items:center;gap:16px;min-height:38px;flex-wrap:wrap}
.topbar a{
  display:inline-flex;align-items:center;gap:6px;
  opacity:.8;
  transition: color var(--trans), opacity var(--trans), transform var(--trans-cubic);
}
.topbar a::before{
  content: "";
  width: 5px;
  height: 5px;
  background: var(--rojo-claro);
  border-radius: 50%;
  opacity: 0.6;
  transition: var(--trans-cubic);
  box-shadow: 0 0 5px var(--rojo-claro);
}
.topbar a:hover{
  opacity:1;
  color:#fff;
  transform: translate3d(0, -1px, 0);
}
.topbar a:hover::before{
  opacity: 1;
  transform: scale(1.3);
  box-shadow: 0 0 8px var(--rojo-claro);
}
.topbar .tb-derecha{display:flex;gap:22px}

.nav{
  position:sticky;top:0;z-index:900;
  background:rgba(11,11,13,.65);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border-bottom:1px solid rgba(255, 255, 255, 0.06);
  transition: background-color var(--trans-cubic), border-color var(--trans-cubic), box-shadow var(--trans-cubic);
}
.nav.compacta{
  background:rgba(11,11,13,.9);
  border-bottom-color: rgba(255, 42, 69, 0.25);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.4);
}
.nav .contenedor{
  display:flex;align-items:center;justify-content:space-between;
  min-height:92px;
  transition: min-height var(--trans-cubic);
}
.nav.compacta .contenedor{min-height:72px}
.nav-logo{display:flex;align-items:center;gap:14px}
.nav-logo img{
  height:76px;width:auto;
  filter:drop-shadow(0 4px 10px rgba(255, 42, 69, 0.25));
  transition: height var(--trans-cubic), transform var(--trans-cubic);
}
.nav.compacta .nav-logo img{height:54px}
.nav-logo:hover img{transform:scale(1.03)}
.nav-logo .wm{display:flex;flex-direction:column;line-height:1}
.nav-logo .wm small{font-family:var(--f-mano);font-weight:700;font-size:1.45rem;color:var(--rojo-claro)}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-links a{
  position:relative;padding:8px 16px;border-radius:30px;
  font-weight:600;font-size:.92rem;color:var(--gris-claro);
  border:1px solid transparent;
  transition:var(--trans-cubic);
  will-change: background-color, border-color, color, box-shadow;
}
.nav-links a:hover{
  color:#fff;
  background:rgba(255,255,255,.04);
}
.nav-links a.activo{
  color:#fff;
  background:rgba(255, 42, 69, 0.08);
  border-color:rgba(255, 42, 69, 0.25);
  box-shadow:inset 0 0 12px rgba(255, 42, 69, 0.05);
}
.nav-cta{margin-left:10px}
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-burger span{width:26px;height:2.5px;background:#fff;border-radius:2px;transition:var(--trans-cubic)}
.nav-burger.activo span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav-burger.activo span:nth-child(2){opacity:0}
.nav-burger.activo span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;overflow:hidden;
  padding:120px 0 110px;
  background:
    radial-gradient(1100px 520px at 78% -10%,rgba(209,15,45,.30),transparent 60%),
    radial-gradient(800px 600px at 0% 100%,rgba(209,15,45,.12),transparent 55%),
    var(--negro);
}
.hero-video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 1;
  pointer-events: none;
  opacity: 0.18;
}
.hero::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 180px; /* Perfect gradient fade coupling at the bottom */
  background: linear-gradient(to top, var(--negro) 0%, transparent 100%);
  z-index: 2;
  pointer-events: none;
}
.hero .contenedor{position:relative;z-index:3;display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
.hero h1{font-size:clamp(2.4rem,5.4vw,4.3rem);margin-bottom:22px}
.hero h1 em{font-style:normal;color:var(--rojo-claro)}
.hero p.lead{font-size:1.18rem;color:var(--gris-claro);max-width:560px;margin-bottom:34px}
.hero-acciones{display:flex;gap:16px;flex-wrap:wrap}
.hero-stats{display:flex;gap:20px;margin-top:46px;flex-wrap:wrap}
.hero-stats .st{
  background: rgba(255, 255, 255, 0.015);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 12px;
  padding: 16px 24px;
  backdrop-filter: blur(16px) saturate(180%);
  -webkit-backdrop-filter: blur(16px) saturate(180%);
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.3);
  transition: transform 0.25s cubic-bezier(0.23, 1, 0.32, 1), border-color 0.25s ease, background-color 0.25s ease;
  will-change: transform, border-color, background-color;
}
@media (hover: hover) and (pointer: fine) {
  .hero-stats .st:hover {
    background: rgba(255, 42, 69, 0.05);
    border-color: rgba(255, 42, 69, 0.3);
    transform: translateY(-4px);
    box-shadow: 0 10px 25px rgba(255, 42, 69, 0.15);
  }
}
.hero-stats .st b{display:block;font-family:var(--f-display);font-size:1.8rem;color:#fff;line-height:1.2}
.hero-stats .st span{font-size:.78rem;color:var(--gris);text-transform:uppercase;letter-spacing:.08em}

/* collage hero */
.hero-visual{position:relative;height:480px}
.hero-visual .blob{
  position:absolute;inset:auto;border-radius:24px;overflow:hidden;
  box-shadow:var(--sombra);border:1px solid var(--linea);
  animation:flotar 6s ease-in-out infinite;
  transition: border-color var(--trans-cubic), box-shadow var(--trans-cubic), transform var(--trans-cubic);
  will-change: transform, border-color, box-shadow;
}
.hero-visual .b1{width:62%;height:78%;right:0;top:0;z-index:2}
.hero-visual .b2{width:46%;height:52%;left:0;bottom:0;z-index:3;animation-delay:1.2s}
.hero-visual .b3{width:40%;height:44%;left:8%;top:4%;z-index:1;animation-delay:.6s;opacity:.92}
.hero-visual .blob img{
  width:100%;height:100%;object-fit:cover;
  transition: transform var(--trans-cubic);
  will-change: transform;
}
.hero-visual .blob:hover{
  border-color: rgba(255, 42, 69, 0.4);
  box-shadow: var(--sombra-roja), 0 0 20px rgba(255, 42, 69, 0.2);
}
.hero-visual .blob:hover img{
  transform: scale(1.06);
}
.hero-badge{
  position:absolute;z-index:4;right:-6px;bottom:18%;
  background:var(--rojo);color:#fff;font-family:var(--f-titulo);font-weight:800;
  padding:14px 20px;border-radius:14px;box-shadow:var(--sombra-roja);
  display:flex;align-items:center;gap:10px;font-size:.95rem;
}
@keyframes flotar{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}

/* ============================================================
   FRANJA MARCA / SCROLLER
   ============================================================ */
.marquee{
  background:var(--carbon);border-block:1px solid var(--linea);
  overflow:hidden;white-space:nowrap;padding:18px 0;
}
.marquee-track{display:inline-flex;gap:48px;animation:desliza 26s linear infinite;width:max-content;will-change:transform;}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee span{font-family:var(--f-titulo);font-weight:800;font-size:1.15rem;color:var(--gris);display:inline-flex;align-items:center;gap:48px}
.marquee span::after{content:"●";color:var(--rojo);font-size:.7rem}
@keyframes desliza{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================
   TARJETAS / GRIDS
   ============================================================ */
.grid{display:grid;gap:28px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}

.card{
  background:linear-gradient(180deg,var(--carbon),var(--carbon-2));
  border:1px solid var(--linea);border-radius:var(--radio);
  padding:34px 30px;transition:var(--trans-cubic);position:relative;overflow:hidden;
  transform:translate3d(0,0,0);
  will-change:transform, box-shadow, border-color;
}
.card::after{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:var(--rojo);transition:var(--trans-cubic)}
.card:hover{
  transform:translate3d(0, -8px, 0) scale(1.01);
  border-color:rgba(255, 42, 69, 0.4);
  box-shadow: 0 15px 35px rgba(209, 15, 45, 0.15), 0 0 20px rgba(209, 15, 45, 0.05);
}
.card:hover::after{width:100%}
.card .ic{
  width:56px;height:56px;border-radius:14px;display:grid;place-items:center;
  background:rgba(209,15,45,.12);color:var(--rojo-claro);margin-bottom:20px;
}
.card .ic svg{width:28px;height:28px}
.card h3{font-size:1.3rem;margin-bottom:10px}
.card p{color:var(--gris-claro);font-size:.97rem}

/* canvas de partículas para pasos */
.seccion-pasos {
  position: relative;
  overflow: hidden;
}
.particles-canvas {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 1;
}

/* desplegables interactivos de pasos */
.paso-idea {
  display: grid;
  grid-template-rows: 0fr;
  opacity: 0;
  overflow: hidden;
  transition: grid-template-rows 0.38s cubic-bezier(0.25, 1, 0.5, 1), opacity 0.3s ease, margin-top 0.35s ease;
  margin-top: 0;
}
.paso:hover .paso-idea {
  grid-template-rows: 1fr;
  opacity: 1;
  margin-top: 16px;
}
.paso-idea-inner {
  min-height: 0;
  border-top: 1px dashed rgba(255, 255, 255, 0.1);
  padding-top: 12px;
}
.paso-idea-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--f-display);
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--rojo-claro);
  margin-bottom: 6px;
}
.paso-idea-tag svg {
  width: 13px;
  height: 13px;
  stroke: var(--rojo-claro);
}
.paso-idea-inner p {
  color: rgba(255, 255, 255, 0.68);
  font-size: 0.85rem;
  line-height: 1.55;
  margin: 0;
}

/* ============================================================
   CATÁLOGO - BÚSQUEDA Y FILTRADO DILIGENTES
   ============================================================ */
/* Contenedor de Selectores de Categorías Visuales */
.cat-showcase-tabs {
  display: flex;
  justify-content: center;
  gap: 20px;
  margin-bottom: 45px;
  flex-wrap: wrap;
}

.cat-showcase-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  background: rgba(255, 255, 255, 0.015);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 20px;
  padding: 16px 20px;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
  width: 140px;
  position: relative;
  overflow: hidden;
  user-select: none;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.cat-showcase-card:hover {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 42, 69, 0.25);
  transform: translateY(-4px);
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.3);
}

/* Envoltura de la imagen en miniatura */
.cat-showcase-img-wrap {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: #e5e5e5;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 12px;
  border: 2px solid rgba(255, 255, 255, 0.1);
  overflow: hidden;
  transition: all 0.35s cubic-bezier(0.25, 0.8, 0.25, 1);
  box-shadow: inset 0 0 10px rgba(0, 0, 0, 0.05);
}

.cat-showcase-img-wrap img {
  width: 80%;
  height: 80%;
  object-fit: contain;
  transition: transform 0.35s cubic-bezier(0.25, 0.8, 0.25, 1);
}

.cat-showcase-card:hover .cat-showcase-img-wrap {
  border-color: var(--rojo-claro);
  transform: scale(1.05);
  box-shadow: 0 0 15px rgba(255, 42, 69, 0.25);
}

.cat-showcase-card:hover .cat-showcase-img-wrap img {
  transform: scale(1.1);
}

/* Etiqueta de la Categoría */
.cat-showcase-label {
  font-family: var(--f-titulo);
  font-weight: 700;
  font-size: 0.82rem;
  color: var(--gris-claro);
  text-align: center;
  transition: color 0.3s ease;
  line-height: 1.25;
}

.cat-showcase-card:hover .cat-showcase-label {
  color: #fff;
}

/* LED de Estado Activo */
.cat-showcase-led {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: transparent;
  margin-top: 8px;
  transition: all 0.3s ease;
}

/* Tarjeta Activa */
.cat-showcase-card.activo {
  background: rgba(212, 25, 32, 0.05);
  border-color: rgba(212, 25, 32, 0.3);
  box-shadow: 0 8px 20px rgba(212, 25, 32, 0.12);
}

.cat-showcase-card.activo .cat-showcase-img-wrap {
  border-color: var(--rojo-claro);
  box-shadow: 0 0 15px rgba(255, 42, 69, 0.35);
}

.cat-showcase-card.activo .cat-showcase-label {
  color: #fff;
}

.cat-showcase-card.activo .cat-showcase-led {
  background: var(--rojo-claro);
  box-shadow: 0 0 8px var(--rojo-claro), 0 0 3px var(--rojo-claro);
}

/* Paneles del Catálogo y Animación */
.cat-panels {
  position: relative;
  width: 100%;
}

.cat-panel {
  display: none;
  grid-template-columns: 1fr;
  gap: 30px;
}

.cat-panel.activo {
  display: grid;
  animation: catPanelSlideFadeIn 0.55s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}

@keyframes catPanelSlideFadeIn {
  from {
    opacity: 0;
    transform: translateY(16px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Fichas del Catálogo Re-diseñadas */
.producto-vitrina {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 40px;
  align-items: center;
  background: rgba(18, 18, 22, 0.45);
  border: 1px solid rgba(255, 255, 255, 0.04);
  border-radius: 24px;
  padding: 35px;
  transition: transform 0.35s var(--trans-cubic), border-color 0.35s ease, box-shadow 0.35s ease;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  animation: aparece 0.4s cubic-bezier(0.25, 0.8, 0.25, 1);
}
@keyframes aparece{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

.producto-vitrina:hover {
  transform: translateY(-6px);
  border-color: rgba(212, 25, 32, 0.25);
  box-shadow: 
    0 20px 45px rgba(0, 0, 0, 0.45), 
    0 0 25px rgba(212, 25, 32, 0.05);
}
.producto-foto {
  position: relative;
  border-radius: 18px;
  overflow: hidden;
  background: #e5e5e5;
  aspect-ratio: 1/1;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: inset 0 0 20px rgba(0,0,0,0.05);
}
.producto-foto img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 24px;
  transition: opacity 0.35s var(--trans-cubic), transform 0.35s var(--trans-cubic);
  transform: translate3d(0,0,0) scale(1);
  will-change: opacity, transform;
}
.producto-vitrina:hover .producto-foto img {
  transform: scale(1.04);
}
.producto-foto img.fade-out {
  opacity: 0;
  transform: translate3d(0, 0, 0) scale(0.95) rotate(-2deg);
}
.producto-foto .color-actual {
  position: absolute;
  left: 16px;
  bottom: 16px;
  background: rgba(11, 11, 13, 0.88);
  color: #fff;
  padding: 7px 14px;
  border-radius: 50px;
  font-size: 0.78rem;
  font-family: var(--f-titulo);
  font-weight: 700;
  letter-spacing: 0.02em;
  box-shadow: 0 4px 10px rgba(0,0,0,0.3);
  backdrop-filter: blur(4px);
}
.producto-info h4 {
  font-size: 1.5rem;
  font-family: var(--f-display);
  font-weight: 800;
  margin: 0 0 10px;
  color: #fff;
}
.producto-info p {
  color: var(--gris-claro);
  font-size: 0.92rem;
  line-height: 1.6;
  margin: 0 0 20px;
}
.doble-horma {
  display: inline-flex;
  gap: 8px;
  align-items: center;
  font-size: 0.8rem;
  color: var(--rojo-claro);
  margin-bottom: 20px;
  font-weight: 600;
}
.doble-horma svg {
  width: 14px;
  height: 14px;
  stroke: var(--rojo-claro);
}
.swatches-titulo {
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--gris);
  font-weight: 700;
  margin-bottom: 12px;
}
.swatches {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 30px;
}
.swatch {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  cursor: pointer;
  position: relative;
  border: 2px solid rgba(255, 255, 255, 0.18);
  transition: all 0.2s cubic-bezier(0.25, 0.8, 0.25, 1);
  will-change: transform, border-color, box-shadow;
  box-sizing: border-box;
}
.swatch:hover {
  transform: scale(1.15) translateY(-2px);
}
.swatch.activo {
  border-color: #fff;
  box-shadow: 0 0 0 3px var(--rojo-claro);
}
.producto-info .btn {
  width: 100%;
  justify-content: center;
  box-sizing: border-box;
  padding: 13px 24px;
}

@media (max-width: 768px) {
  .producto-vitrina {
    grid-template-columns: 1fr;
    gap: 24px;
    padding: 24px;
  }
  .producto-info h4 {
    font-size: 1.3rem;
  }
  .cat-showcase-tabs {
    justify-content: flex-start;
    overflow-x: auto;
    flex-wrap: nowrap;
    padding: 10px 4px 15px;
    gap: 12px;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }
  .cat-showcase-tabs::-webkit-scrollbar {
    display: none;
  }
  .cat-showcase-card {
    flex: 0 0 115px;
    width: 115px;
    padding: 12px 10px;
    border-radius: 16px;
  }
  .cat-showcase-img-wrap {
    width: 55px;
    height: 55px;
    margin-bottom: 8px;
  }
  .cat-showcase-label {
    font-size: 0.75rem;
  }
}

/* ============================================================
   SERVICIOS — destacado DTF
   ============================================================ */
.servicio-destacado{
  display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center;
  background:linear-gradient(120deg,rgba(209,15,45,.16),var(--carbon));
  border:1px solid rgba(209,15,45,.25);border-radius:24px;padding:46px;margin-bottom:50px;
}
.servicio-destacado .insignia{display:inline-flex;align-items:center;gap:8px;background:var(--amarillo);color:#111;font-family:var(--f-titulo);font-weight:800;font-size:.72rem;letter-spacing:.16em;padding:8px 16px;border-radius:6px;text-transform:uppercase;margin-bottom:18px;box-shadow:0 6px 18px rgba(255,212,0,.3)}
.servicio-destacado .insignia::before{content:"⚠"}
.tecnica-hero img,.tecnica-img{width:100%;height:auto;display:block;border-radius:16px}
/* Casilla de consentimiento (habeas data) */
.consent{display:flex;gap:10px;align-items:flex-start;font-size:.85rem;color:var(--gris-claro);margin:18px 0 4px;cursor:pointer;line-height:1.5}
.consent input{margin-top:3px;width:17px;height:17px;accent-color:var(--rojo);flex-shrink:0}
.consent a{color:var(--rojo-claro)}
.servicio-destacado h2{font-size:2.4rem;margin-bottom:14px}
.servicio-destacado p{color:var(--gris-claro);margin-bottom:18px}
.lista-check{display:grid;gap:12px;margin-bottom:8px}
.lista-check li{display:flex;gap:12px;align-items:flex-start;color:var(--blanco)}
.lista-check svg{width:20px;height:20px;color:var(--rojo-claro);flex-shrink:0;margin-top:3px}

/* ============================================================
   STATS / CTA BANNER
   ============================================================ */
.cta-banner{
  background:linear-gradient(120deg,var(--rojo-oscuro),var(--rojo));
  border-radius:24px;padding:60px 50px;text-align:center;position:relative;overflow:hidden;
}
.cta-banner::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 20%,rgba(255,255,255,.18),transparent 50%)}
.cta-banner h2{font-size:clamp(1.9rem,4vw,2.8rem);margin-bottom:14px;position:relative}
.cta-banner p{color:rgba(255,255,255,.9);max-width:560px;margin:0 auto 30px;position:relative}
.cta-banner .btn-blanco{position:relative}

/* ============================================================
   FORMULARIO
   ============================================================ */
.form-wrap{display:grid;grid-template-columns:.85fr 1.15fr;gap:50px;align-items:start}
.form-lateral h2{font-size:2.2rem;margin-bottom:16px}
.form-lateral p{color:var(--gris-claro);margin-bottom:26px}
.form-canales{display:grid;gap:14px}
.canal{display:flex;gap:14px;align-items:center;background:var(--carbon);border:1px solid var(--linea);border-radius:var(--radio);padding:16px 18px;transition:var(--trans)}
.canal:hover{border-color:var(--rojo);transform:translateX(4px)}
.canal .ic{width:46px;height:46px;border-radius:12px;background:rgba(209,15,45,.12);color:var(--rojo-claro);display:grid;place-items:center;flex-shrink:0}
.canal .ic svg{width:22px;height:22px}
.canal b{display:block;font-family:var(--f-titulo)}
.canal span{font-size:.85rem;color:var(--gris)}

.form-card{background:linear-gradient(180deg,var(--carbon),var(--carbon-2));border:1px solid var(--linea);border-radius:24px;padding:38px}
.campo{margin-bottom:20px}
.campo label{display:block;font-size:.85rem;font-weight:600;margin-bottom:8px;color:var(--gris-claro)}
.campo input,.campo select,.campo textarea{
  width:100%;background:var(--negro);border:1.5px solid var(--linea);border-radius:var(--radio-sm);
  padding:14px 16px;color:#fff;font-family:var(--f-texto);font-size:.96rem;
  transition:var(--trans-cubic);
  will-change:border-color, box-shadow;
}
.campo textarea{resize:vertical;min-height:120px}
.campo input:focus,.campo select:focus,.campo textarea:focus{
  outline:none;
  border-color:var(--rojo-claro);
  box-shadow:0 0 0 3px rgba(255, 42, 69, 0.25), 0 8px 24px rgba(255, 42, 69, 0.08);
}
.campo input.error,.campo select.error,.campo textarea.error{border-color:var(--rojo-claro)}
.campo .msg-error{display:none;color:var(--rojo-claro);font-size:.8rem;margin-top:6px}
.campo.invalido .msg-error{display:block}
.fila-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
/* Honeypot — oculto a humanos, visible a bots */
.hp-field{position:absolute!important;left:-9999px!important;top:auto;width:1px;height:1px;overflow:hidden}
.form-nota{font-size:.8rem;color:var(--gris);margin-top:14px;display:flex;gap:8px;align-items:flex-start}
.form-nota svg{width:16px;height:16px;flex-shrink:0;margin-top:2px;color:var(--rojo-claro)}
.form-alert{display:none;padding:14px 16px;border-radius:var(--radio-sm);margin-bottom:20px;font-size:.92rem}
.form-alert.ok{display:block;background:rgba(31,122,61,.18);border:1px solid #1f7a3d;color:#7ee2a0}
.form-alert.fail{display:block;background:rgba(209,15,45,.15);border:1px solid var(--rojo);color:#ff9aa8}

/* ============================================================
   FUNDACIÓN
   ============================================================ */
.fundacion-hero{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.fundacion-hero .texto h2{font-size:2.4rem;margin-bottom:16px}
.fundacion-hero .texto p{color:var(--gris-claro);margin-bottom:16px}
.cita{border-left:3px solid var(--rojo);padding-left:22px;font-family:var(--f-titulo);font-size:1.25rem;font-style:italic;color:#fff;margin:30px 0}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:#070708;border-top:1px solid var(--linea);padding:70px 0 30px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;margin-bottom:44px}
.footer h5{font-family:var(--f-titulo);font-size:1rem;margin-bottom:18px;color:#fff}
.footer p,.footer a{color:var(--gris);font-size:.92rem}
.footer-col a{display:block;margin-bottom:10px;transition:var(--trans)}
.footer-col a:hover{color:var(--rojo-claro)}
.footer-logo{display:flex;align-items:center;gap:13px;margin-bottom:18px}
.footer-logo img{height:130px;width:auto;filter:drop-shadow(0 4px 14px rgba(209,15,45,.3))}
.footer-social{display:flex;gap:12px;margin-top:18px}
.footer-social a{width:40px;height:40px;border-radius:10px;background:var(--carbon);border:1px solid var(--linea);display:grid;place-items:center;color:var(--gris-claro)}
.footer-social a:hover{background:var(--rojo);color:#fff;border-color:var(--rojo)}
.footer-social svg{width:18px;height:18px}
.footer-bar{border-top:1px solid var(--linea);padding-top:24px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.84rem;color:var(--gris)}
.footer-bar a:hover{color:#fff}
.ciudades{font-size:.8rem;color:#54545c;margin-top:8px;line-height:1.7}

/* ============================================================
   WIDGET CHAT FLOTANTE (n8n)
   ============================================================ */
#chat-launcher{
  position:fixed;right:22px;bottom:22px;z-index:950;
  width:64px;height:64px;border-radius:50%;border:0;cursor:pointer;
  background: var(--gradient-rojo) !important; /* Mantiene su fondo gradiente rojo original */
  box-shadow: 0 0 20px rgba(255, 42, 69, 0.4), 0 10px 25px rgba(0, 0, 0, 0.4);
  display:grid;place-items:center;
  transition: transform 0.25s cubic-bezier(0.25, 0.8, 0.25, 1), box-shadow 0.25s ease;
  overflow: hidden; /* Importante para recortar el haz de luz */
}

/* Haz de luz giratorio (Conic Gradient) - Gira en sentido contrario o color especial */
#chat-launcher::before {
  content: '';
  position: absolute;
  top: -150%;
  left: -150%;
  width: 400%;
  height: 400%;
  background: conic-gradient(
    from 0deg,
    transparent 0%,
    transparent 65%,
    #fff 80%, /* Haz blanco brillante que contrasta sobre el botón rojo */
    #ffd1d1 90%,
    #fff 95%,
    transparent 100%
  );
  z-index: -2;
  animation: border-beam-rotate 4s linear infinite;
  transition: animation-duration 0.3s ease;
}

/* Máscara interna para dejar solo el contorno láser visible */
#chat-launcher::after {
  content: '';
  position: absolute;
  inset: 2px; /* Grosor del borde láser */
  background: var(--gradient-rojo);
  border-radius: 50%;
  z-index: -1;
  transition: filter 0.3s ease;
}

#chat-launcher:hover{
  transform:scale(1.08) translateY(-2px);
  box-shadow: 0 0 35px rgba(255, 42, 69, 0.65), 0 12px 30px rgba(0, 0, 0, 0.4);
}
#chat-launcher:hover::before {
  animation-duration: 2s; /* Acelera el haz láser */
}
#chat-launcher:hover::after {
  filter: brightness(1.1); /* Efecto de brillo de fondo */
}

#chat-launcher.oculto{
  opacity:0;
  pointer-events:none;
  transform:scale(0.8);
}
#chat-launcher svg{
  width:30px;
  height:30px;
  position: relative;
  z-index: 2; /* Sobre las capas del borde */
}
#chat-launcher .punto{
  position:absolute;
  top:6px;
  right:8px;
  width:12px;
  height:12px;
  background:#2ec28a;
  border-radius:50%;
  border:2px solid var(--rojo);
  z-index: 3; /* Sobre todas las capas */
}
.chat-burbuja{
  position:fixed;right:96px;bottom:34px;z-index:949;
  background:rgba(11,11,13,0.95);
  color:var(--blanco);
  border:1px solid rgba(255, 42, 69, 0.4);
  padding:12px 18px;
  border-radius:16px 16px 2px 16px;
  font-size:.85rem;font-weight:500;max-width:250px;
  box-shadow:0 10px 30px rgba(0,0,0,0.5), 0 0 15px rgba(255,42,69,0.15);
  opacity:0;transform:translateY(10px);transition:var(--trans-cubic);pointer-events:none;
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  line-height:1.45;
}
.chat-burbuja.visible{opacity:1;transform:none}

/* ============================================================
   REVEAL ANIMACIONES
   ============================================================ */
/* Animación de entrada SOLO con CSS (no depende de JavaScript).
   Siempre termina en opacity:1, así el texto NUNCA queda oculto. */
.reveal{animation:revelar .7s cubic-bezier(.16,1,.3,1) both}
.reveal.d1{animation-delay:.1s}.reveal.d2{animation-delay:.2s}.reveal.d3{animation-delay:.3s}.reveal.d4{animation-delay:.4s}
@keyframes revelar{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}

/* ============================================================
   COTIZADOR — minimalista y elegante
   ============================================================ */
.cot-form{max-width:760px;margin:0 auto}
/* Cada paso: sin caja, separado por una línea fina */
.cot-bloque{padding:38px 0;border-top:1px solid var(--linea)}
.cot-bloque:first-of-type{border-top:0;padding-top:8px}
.cot-bloque > .cot-titulo{display:flex;align-items:baseline;gap:14px;margin-bottom:24px}
.cot-bloque > .cot-titulo .paso-num{
  font-family:var(--f-display);font-weight:700;font-size:.8rem;color:var(--rojo-claro);
  letter-spacing:.12em;
}
.cot-bloque > .cot-titulo .paso-txt{font-family:var(--f-display);font-weight:700;font-size:1.25rem;letter-spacing:-.01em}
.cot-sub{font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gris);margin:22px 0 12px}
.cot-sub:first-child{margin-top:0}

/* Inputs más limpios y aireados */
.cot-form .campo input,.cot-form .campo select,.cot-form .campo textarea{
  background:transparent;border:0;border-bottom:1.5px solid var(--linea);border-radius:0;
  padding:12px 2px;
  transition:var(--trans-cubic);
  will-change:border-color;
}
.cot-form .campo input:focus,.cot-form .campo select:focus,.cot-form .campo textarea:focus{
  box-shadow:none;border-bottom-color:var(--rojo-claro);
}
.cot-form .campo textarea{border:1.5px solid var(--linea);border-radius:12px;padding:14px 16px;transition:var(--trans-cubic)}
.cot-form .campo textarea:focus{border-color:var(--rojo-claro);box-shadow: 0 8px 24px rgba(255, 42, 69, 0.1)}

.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{position:relative;cursor:pointer;user-select:none}
.chip input{position:absolute;opacity:0;width:0;height:0}
.chip span{
  display:inline-flex;align-items:center;gap:9px;
  padding:10px 18px;border-radius:50px;border:1px solid var(--linea);
  background:transparent;color:var(--gris-claro);font-weight:500;font-size:.9rem;
  transition:var(--trans-cubic);
  will-change:border-color, background-color, transform, color, box-shadow;
}
.chip:hover span{border-color:var(--gris-claro);color:#fff;transform:translate3d(0, -2px, 0)}
.chip input:checked + span{
  background:rgba(255, 42, 69, 0.12);
  border-color:var(--rojo-claro);
  color:#fff;
  transform:translate3d(0, -2px, 0);
  box-shadow:0 6px 15px rgba(255, 42, 69, 0.15);
}
.chip input:checked + span .punto-color{box-shadow:0 0 0 2px var(--rojo-claro)}
.chip input:focus-visible + span{box-shadow:0 0 0 3px rgba(255, 42, 69, 0.3)}
.chip .punto-color{width:15px;height:15px;border-radius:50%;border:1px solid rgba(255,255,255,.25);transition:var(--trans-cubic)}

.tallas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:12px}
.talla{text-align:center}
.talla label{display:block;font-family:var(--f-display);font-weight:700;font-size:.82rem;margin-bottom:7px;color:var(--gris-claro)}
.talla input{width:100%;background:transparent;border:1px solid var(--linea);border-radius:10px;padding:11px 6px;color:#fff;text-align:center;font-size:1rem;font-family:var(--f-texto);transition:var(--trans)}
.talla input:focus{outline:none;border-color:var(--rojo-claro);background:rgba(209,15,45,.06)}

/* Barra de acción: total en vivo + dos formas de cotizar */
.cot-cierre{border-top:1px solid var(--linea);margin-top:6px;padding-top:30px}
.cot-total{display:flex;align-items:baseline;gap:10px;justify-content:center;font-size:.9rem;color:var(--gris);margin-bottom:22px}
.cot-total b{font-family:var(--f-display);color:#fff;font-size:1.8rem}
.cot-acciones{display:flex;gap:14px;flex-wrap:wrap}
.cot-acciones .btn{flex:1;justify-content:center;min-width:220px;padding:17px 30px}
.cot-ayuda{font-size:.85rem;color:var(--gris);text-align:center;margin-top:16px}
.cot-ayuda a{color:var(--rojo-claro)}

/* Canales de contacto minimalistas */
.contacto-canales{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.canal-min{
  display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px;
  padding:26px 16px;border:1px solid var(--linea);border-radius:16px;transition:var(--trans);
}
.canal-min:hover{border-color:var(--rojo);transform:translateY(-4px)}
.canal-min .ic{width:44px;height:44px;border-radius:12px;background:rgba(209,15,45,.12);color:var(--rojo-claro);display:grid;place-items:center;margin-bottom:6px}
.canal-min .ic svg{width:22px;height:22px}
.canal-min b{font-family:var(--f-display);font-weight:700;font-size:.98rem;color:#fff}
.canal-min small{font-size:.82rem;color:var(--gris)}
@media (max-width:640px){.contacto-canales{grid-template-columns:1fr}}

/* ============================================================
   SEPARADORES Y RITMO DE SECCIÓN  (más dinamismo)
   ============================================================ */
/* Fondos alternos */
.seccion--carbon{background:var(--carbon);position:relative}
.seccion--rojo{
  background:linear-gradient(135deg, #100609 0%, #1c0a10 50%, #0a0406 100%);
  position:relative;overflow:hidden;
  border-top: 1px solid rgba(255, 42, 69, 0.15);
  border-bottom: 1px solid rgba(255, 42, 69, 0.15);
}
.seccion--rojo::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 85% 15%,rgba(255,42,69,.12),transparent 50%);pointer-events:none}
.seccion--negro{background:#070708}

/* Borde diagonal entre secciones */
.skew-sep{position:relative}
.skew-top{clip-path:polygon(0 3.2vw,100% 0,100% 100%,0 100%)}
.skew-bottom{clip-path:polygon(0 0,100% 0,100% calc(100% - 3.2vw),0 100%)}
.skew-both{clip-path:polygon(0 3.2vw,100% 0,100% calc(100% - 3.2vw),0 100%)}

/* Divisor decorativo con rombo + emblema */
.divisor{display:flex;align-items:center;gap:18px;justify-content:center;margin:0 auto;max-width:520px;color:var(--linea)}
.divisor::before,.divisor::after{content:"";height:1px;flex:1;background:linear-gradient(90deg,transparent,rgba(255,255,255,.22),transparent)}
.divisor .rombo{width:11px;height:11px;background:var(--rojo);transform:rotate(45deg);box-shadow:0 0 0 5px rgba(209,15,45,.18)}

/* Eyebrow con guion y handwriting */
.titulo-deco{display:flex;flex-direction:column;align-items:center;gap:6px}
.titulo-deco .hw{font-family:var(--f-mano);font-weight:700;font-size:1.7rem;color:var(--rojo-claro);transform:rotate(-2deg)}

/* ============================================================
   CINTA / RIBBON con frase recurrente (marquee diagonal)
   ============================================================ */
.cinta{
  position:relative;background:var(--amarillo);transform:rotate(-2deg) scale(1.09);
  margin:40px 0;padding:24px 0;overflow:hidden !important;white-space:nowrap;
  box-shadow:0 14px 40px rgba(255,212,0,.22);
  max-width:100% !important;
}
/* franjas diagonales negras tipo cinta de prevención (arriba y abajo) */
.cinta::before,.cinta::after{content:"";position:absolute;left:0;right:0;height:8px;
  background:repeating-linear-gradient(45deg,#111 0 13px,var(--amarillo) 13px 26px)}
.cinta::before{top:0}.cinta::after{bottom:0}
.cinta-track{display:inline-flex;gap:46px;animation:desliza 30s linear infinite;width:max-content;will-change:transform;}
.cinta:hover .cinta-track{animation-play-state:paused}
.cinta span{
  font-family:var(--f-display);font-weight:800;font-size:1.05rem;color:#111;
  display:inline-flex;align-items:center;gap:46px;text-transform:uppercase;letter-spacing:.04em;
}
.cinta span b{font-family:var(--f-mano);font-weight:700;font-size:1.7rem;text-transform:none;letter-spacing:0;color:#111}
.cinta span::after{content:"⚠";color:#111;font-size:1rem}

/* Banda negra con la frase a gran tamaño */
.frase-band{
  background:var(--amarillo);text-align:center;padding:74px 0;position:relative;overflow:hidden;
  border-top:11px solid #111;border-bottom:11px solid #111;
  border-image:repeating-linear-gradient(45deg,#111 0 15px,var(--amarillo) 15px 30px) 11;
}
.frase-band::before{
  content:"HOY";position:absolute;inset:0;display:grid;place-items:center;
  font-family:var(--f-display);font-weight:800;font-size:30vw;color:rgba(0,0,0,.07);
  pointer-events:none;line-height:1;
}
.frase-band .q{
  position:relative;font-family:var(--f-mano);font-weight:700;
  font-size:clamp(2.2rem,6vw,4.4rem);color:#111;line-height:1;
}
.frase-band .q em{font-style:normal;color:#111;text-decoration:underline;text-decoration-thickness:4px;text-underline-offset:4px}
.frase-band .sub{position:relative;color:rgba(0,0,0,.72);margin-top:14px;font-size:1.02rem;font-weight:500}

/* ============================================================
   HERO — más dinámico
   ============================================================ */
.hero-texto .slogan-mano{margin-bottom:6px}
.hero h1 .subraya{position:relative;white-space:nowrap}
.hero h1 .subraya::after{
  content:"";position:absolute;left:0;right:0;bottom:.04em;height:.16em;
  background:var(--rojo);z-index:-1;border-radius:3px;transform:scaleX(0);transform-origin:left;
  animation:trazo 1s .5s cubic-bezier(.16,1,.3,1) forwards;
}
@keyframes trazo{to{transform:scaleX(1)}}
/* etiquetas flotantes sobre el collage */
.hero-tag{
  position:absolute;z-index:5;background:rgba(11,11,13,.86);backdrop-filter:blur(6px);
  border:1px solid var(--linea);color:#fff;font-family:var(--f-display);font-weight:700;
  font-size:.74rem;padding:8px 14px;border-radius:30px;display:inline-flex;align-items:center;gap:7px;
  animation:flotar 5s ease-in-out infinite;
}
.hero-tag i{width:7px;height:7px;border-radius:50%;background:var(--rojo-claro);font-style:normal}
.hero-tag.t1{top:8%;left:-4%}
.hero-tag.t2{bottom:6%;right:-2%;animation-delay:1.4s}
.hero-stats .st b{font-family:var(--f-display)}

/* ============================================================
   SECTOR INTERACTIVE SHOWCASE
   ============================================================ */
.seccion-sectores {
  position: relative;
  overflow: hidden;
}
.sector-tabs {
  display: flex;
  justify-content: center;
  gap: 16px;
  margin-top: 40px;
  margin-bottom: 36px;
}
.sector-tab {
  display: flex;
  align-items: center;
  gap: 10px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 50px;
  padding: 12px 24px;
  color: var(--gris-claro);
  cursor: pointer;
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 0.88rem;
  transition: var(--trans-cubic);
  position: relative;
}
.sector-tab .tab-icon {
  width: 18px;
  height: 18px;
  stroke: var(--gris);
  transition: stroke 0.3s ease;
}
.sector-tab:hover {
  background: rgba(255, 255, 255, 0.04);
  color: #fff;
  border-color: rgba(255, 255, 255, 0.15);
}
.sector-tab:hover .tab-icon {
  stroke: #fff;
}
.sector-tab.activo {
  background: rgba(212, 25, 32, 0.08);
  border-color: rgba(212, 25, 32, 0.35);
  color: #fff;
  box-shadow: 0 4px 20px rgba(212, 25, 32, 0.15);
}
.sector-tab.activo .tab-icon {
  stroke: var(--rojo-claro);
}
.sector-tab .led {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: transparent;
  transition: background-color 0.3s ease, box-shadow 0.3s ease;
}
.sector-tab.activo .led {
  background: var(--rojo-claro);
  box-shadow: 0 0 8px var(--rojo-claro);
}

/* Tablon de Contenido (Showcase) */
.sector-showcase {
  background: rgba(11, 11, 13, 0.45);
  border: 1px solid rgba(255, 255, 255, 0.04);
  border-radius: 24px;
  padding: 40px;
  position: relative;
  overflow: hidden;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  box-shadow: 0 20px 45px rgba(0, 0, 0, 0.4);
}
.sector-showcase::after {
  content: "";
  position: absolute;
  top: -50%;
  right: -30%;
  width: 400px;
  height: 400px;
  background: radial-gradient(circle, rgba(212, 25, 32, 0.04) 0%, transparent 70%);
  pointer-events: none;
}
.sector-showcase-grid {
  display: grid;
  grid-template-columns: 1.15fr 1.25fr;
  gap: 50px;
  align-items: center;
}

/* Columna de Metricas (Ficha Tecnica) */
.showcase-metrics {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.metric-item {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.metric-label {
  display: flex;
  justify-content: space-between;
  font-size: 0.85rem;
  color: var(--gris-claro);
}
.metric-label span {
  font-family: var(--f-texto);
  font-weight: 500;
}
.metric-label b {
  font-family: var(--f-display);
  font-weight: 800;
  color: #fff;
}
.metric-bar-container {
  width: 100%;
  height: 6px;
  background: rgba(255, 255, 255, 0.03);
  border-radius: 10px;
  overflow: hidden;
}
.metric-bar {
  height: 100%;
  background: linear-gradient(90deg, var(--rojo) 0%, var(--rojo-claro) 100%);
  border-radius: 10px;
  width: 0%; /* Animado via JS */
  transition: width 0.8s cubic-bezier(0.25, 1, 0.5, 1);
}
.showcase-recomienda {
  margin-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.showcase-recomienda small {
  font-family: var(--f-display);
  font-size: 0.7rem;
  font-weight: 800;
  text-transform: uppercase;
  color: var(--gris);
  letter-spacing: 0.06em;
}
.recomienda-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.rtag {
  font-size: 0.78rem;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  color: var(--gris-claro);
  padding: 6px 14px;
  border-radius: 8px;
  transition: var(--trans);
}
.rtag:hover {
  background: rgba(255, 255, 255, 0.04);
  color: #fff;
}

/* Columna de Detalles y Texto */
.showcase-content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.showcase-subtitle {
  font-family: var(--f-display);
  font-weight: 800;
  font-size: 0.72rem;
  text-transform: uppercase;
  color: var(--rojo-claro);
  letter-spacing: 0.08em;
  margin-bottom: 6px;
}
.showcase-title {
  font-family: var(--f-display);
  font-size: 1.8rem;
  font-weight: 800;
  color: #fff;
  margin: 0 0 10px;
}
.showcase-slogan {
  font-family: var(--f-mano);
  font-size: 1.45rem;
  font-weight: 700;
  color: var(--rojo-claro);
  margin: 0 0 16px;
  transform: rotate(-1deg);
}
.showcase-desc {
  font-size: 0.95rem;
  line-height: 1.6;
  color: var(--gris-claro);
  margin: 0 0 28px;
}
.showcase-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  gap: 20px;
  border-top: 1px solid rgba(255, 255, 255, 0.04);
  padding-top: 20px;
}

/* Botón de la Fundación con Borde Láser Giratorio */
.ft-fundacion {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 18px !important;
  color: #fff !important;
  font-size: 0.85rem;
  font-weight: 600;
  text-decoration: none;
  background: #160c11 !important; /* Fondo opaco mezclado para enmascarar */
  border: none !important; /* Quitamos el borde para usar el borde láser */
  position: relative;
  overflow: hidden;
  border-radius: 30px !important; /* Mantenemos su forma de píldora */
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
  transition: transform 0.2s cubic-bezier(0.23, 1, 0.32, 1), box-shadow 0.25s ease;
  z-index: 1;
}

/* El haz de luz giratorio (Conic Gradient) */
.ft-fundacion::before {
  content: '';
  position: absolute;
  top: -150%;
  left: -150%;
  width: 400%;
  height: 400%;
  background: conic-gradient(
    from 0deg,
    transparent 0%,
    transparent 65%,
    var(--rojo-claro) 80%,
    #ff6b6b 90%,
    var(--rojo-claro) 95%,
    transparent 100%
  );
  z-index: -2;
  animation: border-beam-rotate 4s linear infinite;
  transition: animation-duration 0.3s ease;
}

/* El fondo interno de la tarjeta que tapa el centro del gradiente conic */
.ft-fundacion::after {
  content: '';
  position: absolute;
  inset: 1.5px; /* Grosor del borde láser */
  background: #160c11;
  border-radius: 29px; /* Ligeramente menor que el border-radius del padre */
  z-index: -1;
  transition: background-color 0.3s ease;
}

.ft-fundacion svg {
  width: 16px;
  height: 16px;
  position: relative;
  z-index: 2; /* Aseguramos que quede sobre el fondo */
  animation: heartBeat 2.4s infinite ease-in-out;
}

@keyframes heartBeat {
  0%, 100% { transform: scale(1); }
  25% { transform: scale(1.15); }
  40% { transform: scale(1); }
  55% { transform: scale(1.15); }
  70% { transform: scale(1); }
}

@media (hover: hover) and (pointer: fine) {
  .ft-fundacion:hover {
    background: #220e17 !important; /* Ligero aclarado en hover */
    transform: translateY(-2px);
    box-shadow: 
      0 6px 20px rgba(255, 42, 69, 0.35), 
      0 0 10px rgba(255, 42, 69, 0.15);
  }
  .ft-fundacion:hover::before {
    animation-duration: 2s; /* Gira más rápido al pasar el ratón */
  }
  .ft-fundacion:hover::after {
    background: #220e17; /* Sincronizado con el fondo del hover */
  }
}

.ft-fundacion:active {
  transform: scale(0.96);
}

.showcase-info-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255, 255, 255, 0.01);
  border: 1px solid rgba(255, 255, 255, 0.03);
  padding: 8px 14px;
  border-radius: 12px;
  color: var(--gris);
  font-size: 0.82rem;
}
.showcase-info-pill span {
  font-family: var(--f-texto);
  font-weight: 500;
}
.pill-icon {
  width: 15px;
  height: 15px;
  stroke: var(--gris);
}
.btn-sm {
  padding: 9px 18px;
  font-size: 0.85rem;
}

/* Transicion de entrada de datos */
.showcase-anim-in {
  animation: showcaseSlideIn 0.4s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}
@keyframes showcaseSlideIn {
  0% {
    opacity: 0;
    transform: translateY(15px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

/* paso a paso proceso */
.pasos{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:p;position:relative;z-index:2}
.paso{
  position:relative;
  background:rgba(255, 255, 255, 0.02);
  border:1px solid rgba(255, 255, 255, 0.04);
  border-radius:18px;
  padding:30px 24px 24px;
  padding-top:58px;
  display:flex;
  flex-direction: column;
  height: 100%;
  transition:var(--trans-cubic);
  will-change:transform, border-color, box-shadow, background-color;
}
.paso:hover {
  transform:translate3d(0, -6px, 0);
  background:rgba(255, 255, 255, 0.04);
  border-color:rgba(255, 42, 69, 0.25);
  box-shadow:0 12px 35px rgba(0,0,0,.35);
}
.paso::before{
  counter-increment:p;content:"0" counter(p);position:absolute;top:18px;left:24px;
  font-family:var(--f-display);font-weight:800;font-size:1.8rem;color:var(--rojo-claro);opacity:.9;
  transition:var(--trans-cubic);
}
.paso:hover::before{
  color:#fff;
  transform:scale(1.05) translate3d(2px, 0, 0);
  text-shadow: 0 0 10px rgba(255, 42, 69, 0.6);
}
.paso h4{font-size:1.15rem;margin-bottom:8px;font-family:var(--f-display);color:#fff}
.paso p{color:var(--gris);font-size:.92rem;line-height:1.5;flex-grow:1}

/* ============================================================
   RESPONSIVE
   ============================================================ */
/* Tablet y abajo: menú hamburguesa (muchos enlaces + logo grande) */
@media (max-width:1024px){
  .nav .contenedor{min-height:76px}
  .nav-logo img{height:54px}
  .nav-logo .wm small{font-size:1.15rem}
  .nav-burger{display:flex}
  .nav-links{
    position:fixed;inset:76px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;
    background:rgba(11,11,13,.98);border-bottom:1px solid var(--linea);
    padding:14px 24px 26px;transform:translateY(-135%);transition:var(--trans-cubic);
    max-height:calc(100vh - 76px);overflow-y:auto;
  }
  .nav-links.abierto{transform:none}
  .nav-links a{
    padding:15px 12px;
    border-bottom:1px solid var(--linea);
    font-size:1rem;
    border-radius: 0;
    border: none;
    background: transparent;
  }
  .nav-links a:hover{
    background: rgba(255, 255, 255, 0.02);
  }
  .nav-links a.activo{
    color: var(--rojo-claro);
    background: rgba(255, 42, 69, 0.05);
    border-left: 4px solid var(--rojo-claro);
    box-shadow: none;
  }
  .nav-cta{margin:16px 0 0;text-align:center}
}
@media (max-width:980px){
  .hero .contenedor{grid-template-columns:1fr;gap:40px}
  .hero-visual{height:380px;order:-1}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .servicio-destacado,.producto-vitrina,.form-wrap,.fundacion-hero{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .sector-showcase-grid {grid-template-columns:1fr;gap:40px}
  .sector-showcase {padding:30px}
  .pasos{grid-template-columns:repeat(2,1fr)}
  .paso::after{display:none}
  .skew-top,.skew-bottom,.skew-both{clip-path:none}
  .cinta{transform:rotate(-2deg) scale(1.14);margin:30px 0}
}
@media (max-width:760px){
  .seccion{padding:60px 0}
  .hero{padding:64px 0 56px}
  .contenedor{padding-inline:18px}
  .topbar{font-size:.74rem}
  .topbar .contenedor{justify-content:center;gap:6px 18px;padding-block:6px;min-height:auto}
  .topbar .tb-izq, .topbar .tb-derecha{display:inline-flex}
  .grid-3,.grid-4,.grid-2{grid-template-columns:1fr}
  .sector-tabs {
    justify-content: flex-start;
    overflow-x: auto;
    padding-bottom: 12px;
    margin-top: 24px;
    margin-bottom: 24px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .sector-tabs::-webkit-scrollbar { display: none; }
  .sector-tab { flex: 0 0 auto; padding: 10px 18px; font-size: 0.82rem; }
  .sector-showcase { padding: 24px 20px; border-radius: 18px; }
  .sector-showcase-grid { gap: 30px; }
  .showcase-title { font-size: 1.5rem; }
  .showcase-desc { margin-bottom: 20px; }
  .showcase-footer { flex-direction: column; align-items: stretch; gap: 12px; }
  .showcase-info-pill { justify-content: center; }
  .pasos{grid-template-columns:1fr}
  .fila-2{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .form-card{padding:26px}
  .servicio-destacado{padding:30px}
  .hero-stats{gap:20px}
  .hero-acciones{width:100%}
  .hero-acciones .btn{flex:1 1 auto;justify-content:center}
  .cot-acciones .btn{min-width:0}
  .footer-logo img{height:104px}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1!important;transform:none!important}
}

/* Botón flotante Fundación (Impacto Social) */
/* Botón flotante Fundación (Impacto Social) con Borde Láser Giratorio */
.floating-fundacion {
  position: fixed;
  left: 20px;
  bottom: 20px;
  z-index: 948;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: 30px;
  background: #0d0c10 !important; /* Fondo opaco calculado (mezcla de fondo de la web con el tinte rojo) */
  border: none !important; /* Eliminamos borde normal */
  color: var(--blanco);
  font-family: var(--f-titulo);
  font-weight: 700;
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  box-shadow: 0 0 15px rgba(255, 42, 69, 0.2), 0 8px 25px rgba(0, 0, 0, 0.4);
  transition: transform 0.25s cubic-bezier(0.25, 0.8, 0.25, 1), box-shadow 0.25s ease;
  transform: translate3d(0, 0, 0);
  will-change: transform, box-shadow;
  white-space: nowrap;
  overflow: hidden; /* Importante para recortar el haz de luz */
}

/* Haz de luz giratorio (Conic Gradient) */
.floating-fundacion::before {
  content: '';
  position: absolute;
  top: -150%;
  left: -150%;
  width: 400%;
  height: 400%;
  background: conic-gradient(
    from 0deg,
    transparent 0%,
    transparent 65%,
    var(--rojo-claro) 80%,
    #ff6b6b 90%,
    var(--rojo-claro) 95%,
    transparent 100%
  );
  z-index: -2;
  animation: border-beam-rotate 4s linear infinite;
  transition: animation-duration 0.3s ease;
}

/* Máscara interna para dejar solo el borde láser visible */
.floating-fundacion::after {
  content: '';
  position: absolute;
  inset: 1.5px; /* Grosor de la línea del borde */
  background: #0d0c10;
  border-radius: 29px;
  z-index: -1;
  transition: background-color 0.3s ease;
}

.floating-fundacion svg {
  width: 13px;
  height: 13px;
  color: var(--rojo-claro);
  filter: drop-shadow(0 0 4px rgba(255, 42, 69, 0.55));
  position: relative;
  z-index: 2;
  transition: transform var(--trans-cubic);
}

@media (hover: hover) and (pointer: fine) {
  .floating-fundacion:hover {
    transform: translate3d(0, -3px, 0) scale(1.02);
    box-shadow: 0 0 25px rgba(255, 42, 69, 0.45), 0 10px 25px rgba(0, 0, 0, 0.4);
    background: #140d12 !important;
  }
  .floating-fundacion:hover::before {
    animation-duration: 2s; /* Gira más rápido al pasar el ratón */
  }
  .floating-fundacion:hover::after {
    background: #140d12;
  }
  .floating-fundacion:hover svg {
    transform: scale(1.15);
  }
}

@media (max-width: 760px) {
  .floating-fundacion {
    left: 15px;
    bottom: 15px;
    padding: 6px 10px;
    font-size: .65rem;
  }
}

/* Contenedor del Chatbot Flotante (Asistente IA) */
.chat-window-container {
  position: fixed;
  right: 22px;
  bottom: 96px;
  width: 380px;
  height: 540px;
  z-index: 949;
  background: rgba(11, 11, 13, 0.95);
  backdrop-filter: blur(16px) saturate(180%);
  -webkit-backdrop-filter: blur(16px) saturate(180%);
  border: 1px solid rgba(255, 42, 69, 0.35);
  border-radius: 18px;
  box-shadow: 0 15px 45px rgba(0, 0, 0, 0.6), 0 0 20px rgba(255, 42, 69, 0.15);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transition: transform var(--trans-cubic), opacity var(--trans-cubic), visibility var(--trans-cubic);
  transform: translateY(20px) scale(0.95);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
.chat-window-container.abierto {
  transform: translateY(0) scale(1);
  opacity: 1;
  visibility: visible;
  pointer-events: all;
}
.chat-window-container {
  --glass-bg: rgba(22, 22, 28, 0.75);
  --glass-border: rgba(255, 255, 255, 0.08);
  --brand-red: #ef233c;
  --brand-red-dark: #d90429;
  --brand-red-glow: rgba(239, 35, 60, 0.25);
  --brand-white: #ffffff;
  --brand-black: #0c0c0e;
  --text-main: #ffffff;
  --text-muted: #a1a1aa;
  --bubble-bot-bg: #ffffff;
  --bubble-bot-text: #121214;
  --bubble-user-bg: linear-gradient(135deg, #ef233c 0%, #d90429 100%);
  --bubble-user-text: #ffffff;
}

.chat-window-header {
  background: linear-gradient(135deg, var(--brand-red) 0%, rgba(12, 12, 14, 0.8) 100%);
  padding: 14px 18px;
  color: var(--brand-white);
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid var(--glass-border);
  position: relative;
  z-index: 10;
}

.chat-window-header-info {
  display: flex;
  align-items: center;
  gap: 10px;
}

.avatar-wrapper {
  position: relative;
}

.avatar {
  width: 40px;
  height: 40px;
  background: rgba(255, 255, 255, 0.1);
  border: 2px solid var(--brand-red);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  flex-shrink: 0;
  box-shadow: 0 0 10px var(--brand-red-glow);
}

.chat-window-header-info h4 {
  font-family: var(--f-display);
  font-size: .88rem;
  font-weight: 700;
  color: #fff;
  margin: 0;
}

.chat-window-header-info p {
  font-size: .72rem;
  color: var(--text-muted);
  margin: 2px 0 0 0;
  display: flex;
  align-items: center;
  gap: 5px;
}

.status-dot {
  width: 6px;
  height: 6px;
  background: #39ff14;
  border-radius: 50%;
  display: inline-block;
  box-shadow: 0 0 6px #39ff14;
  animation: pulse 2s infinite;
}

@keyframes pulse {
  0% { transform: scale(0.95); box-shadow: 0 0 0 0 rgba(57, 255, 20, 0.7); }
  70% { transform: scale(1); box-shadow: 0 0 0 6px rgba(57, 255, 20, 0); }
  100% { transform: scale(0.95); box-shadow: 0 0 0 0 rgba(57, 255, 20, 0); }
}

.chat-window-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}

.chat-window-actions button {
  background: none;
  border: 0;
  color: rgba(255, 255, 255, 0.75);
  cursor: pointer;
  padding: 8px;
  transition: var(--trans);
  display: flex;
  align-items: center;
  justify-content: center;
}

.chat-window-actions button:hover {
  color: var(--brand-white);
  transform: scale(1.1);
}

.chat-window-actions button svg {
  width: 16px;
  height: 16px;
}

#chat-window-close {
  font-size: 1.6rem;
  line-height: 1;
}

.messages {
  flex: 1;
  overflow-y: auto;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  background: rgba(12, 12, 14, 0.4);
  scroll-behavior: smooth;
}

.messages::-webkit-scrollbar {
  width: 5px;
}
.messages::-webkit-scrollbar-track {
  background: transparent;
}
.messages::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.1);
  border-radius: 10px;
}
.messages::-webkit-scrollbar-thumb:hover {
  background: var(--brand-red);
}

.msg {
  max-width: 85%;
  padding: 10px 14px;
  border-radius: 16px;
  font-size: 0.88rem;
  line-height: 1.45;
  position: relative;
  animation: fadeInUp 0.3s cubic-bezier(0.25, 1, 0.5, 1);
  word-break: break-word;
  white-space: pre-wrap;
}

@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(12px) scale(0.98); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

.msg.bot {
  background: var(--bubble-bot-bg);
  color: var(--bubble-bot-text);
  align-self: flex-start;
  border-bottom-left-radius: 4px;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.15);
}

.msg.user {
  background: var(--bubble-user-bg);
  color: var(--bubble-user-text);
  align-self: flex-end;
  border-bottom-right-radius: 4px;
  box-shadow: 0 4px 15px rgba(239, 35, 60, 0.15);
}

.msg.error {
  background: rgba(239, 35, 60, 0.1);
  color: #ff4d6d;
  border: 1px solid rgba(239, 35, 60, 0.2);
  align-self: center;
  font-size: 0.82rem;
  text-align: center;
  border-radius: 12px;
  max-width: 90%;
  padding: 8px 12px;
}

.msg-time {
  font-size: 0.62rem;
  opacity: 0.5;
  margin-top: 4px;
  text-align: right;
}
.msg.bot .msg-time {
  color: #6b7280;
}
.msg.user .msg-time {
  color: rgba(255, 255, 255, 0.7);
}

.msg-img {
  max-width: 100%;
  max-height: 180px;
  border-radius: 10px;
  margin-bottom: 4px;
  display: block;
  cursor: pointer;
  transition: opacity 0.2s;
  object-fit: cover;
}
.msg-img:hover {
  opacity: 0.9;
}

.msg-file-link {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  background: rgba(0,0,0,0.06);
  border-radius: 10px;
  color: inherit;
  text-decoration: none;
  font-weight: 500;
  font-size: 0.82rem;
  margin-bottom: 4px;
}
.msg.user .msg-file-link {
  background: rgba(255,255,255,0.15);
}

.typing-indicator {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.05);
  align-self: flex-start;
  border-radius: 16px;
  border-bottom-left-radius: 4px;
  padding: 10px 14px;
  display: none;
  animation: fadeInUp 0.2s ease;
}
.typing-indicator.visible {
  display: flex;
}
.typing-dots {
  display: flex;
  gap: 4px;
  align-items: center;
  height: 10px;
}
.typing-dots span {
  width: 5px;
  height: 5px;
  background: var(--text-muted);
  border-radius: 50%;
  animation: bounce 1.4s infinite ease-in-out both;
}
.typing-dots span:nth-child(1) { animation-delay: -0.32s; }
.typing-dots span:nth-child(2) { animation-delay: -0.16s; }

@keyframes bounce {
  0%, 80%, 100% { transform: scale(0); }
  40% { transform: scale(1.0); }
}

.preview-panel {
  background: rgba(18, 18, 22, 0.95);
  border-top: 1px solid var(--glass-border);
  padding: 8px 12px;
  display: none;
  align-items: center;
  gap: 10px;
  animation: slideUp 0.25s cubic-bezier(0.25, 1, 0.5, 1);
}
.preview-panel.active {
  display: flex;
}
@keyframes slideUp {
  from { transform: translateY(100%); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}

.preview-thumb {
  width: 42px;
  height: 42px;
  border-radius: 6px;
  object-fit: cover;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  flex-shrink: 0;
}
.preview-details {
  flex: 1;
  min-width: 0;
}
.preview-name {
  color: var(--text-main);
  font-size: 0.8rem;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.preview-size {
  color: var(--text-muted);
  font-size: 0.68rem;
  margin-top: 2px;
}
.preview-remove {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.08);
  border: none;
  color: #ff4d6d;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  transition: background 0.2s;
}
.preview-remove:hover {
  background: rgba(255, 255, 255, 0.15);
}

.input-area {
  padding: 10px 12px;
  background: rgba(12, 12, 14, 0.85);
  border-top: 1px solid var(--glass-border);
  display: flex;
  gap: 8px;
  align-items: flex-end;
  position: relative;
  z-index: 10;
}

.attach-btn {
  width: 38px;
  height: 38px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s, transform 0.15s, border-color 0.2s;
  flex-shrink: 0;
}
.attach-btn:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: var(--brand-red);
  transform: scale(1.05);
}
.attach-btn svg {
  width: 18px;
  height: 18px;
  fill: var(--text-muted);
  transition: fill 0.2s;
}
.attach-btn:hover svg {
  fill: var(--brand-red);
}

.input-wrap {
  flex: 1;
  position: relative;
}

.input-wrap textarea {
  width: 100%;
  border: 1.5px solid rgba(255, 255, 255, 0.08);
  border-radius: 20px;
  padding: 8px 14px;
  font-size: 0.88rem;
  font-family: inherit;
  resize: none;
  outline: none;
  max-height: 90px;
  line-height: 1.4;
  color: var(--text-main);
  background: rgba(255, 255, 255, 0.03);
  transition: border-color 0.25s, background 0.25s;
}

.input-wrap textarea:focus {
  border-color: var(--brand-red);
  background: rgba(255, 255, 255, 0.05);
}

.input-wrap textarea::placeholder {
  color: rgba(255, 255, 255, 0.3);
}

.send-btn {
  width: 38px;
  height: 38px;
  background: var(--bubble-user-bg);
  border: none;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 4px 10px rgba(239, 35, 60, 0.3);
  transition: transform 0.15s, box-shadow 0.15s, opacity 0.15s;
}
.send-btn:hover {
  transform: scale(1.08);
  box-shadow: 0 6px 12px rgba(239, 35, 60, 0.45);
}
.send-btn:active {
  transform: scale(0.96);
}
.send-btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}
.send-btn svg {
  width: 16px;
  height: 16px;
  fill: var(--brand-white);
  margin-left: 2px;
}

/* Modal for Image Fullscreen */
.img-modal {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.9);
  z-index: 10000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.img-modal.active {
  display: flex;
}
.img-modal img {
  max-width: 95vw;
  max-height: 90vh;
  border-radius: 8px;
  box-shadow: 0 10px 40px rgba(0,0,0,0.8);
  object-fit: contain;
}
.img-modal-close {
  position: absolute;
  top: 20px; right: 20px;
  color: white;
  font-size: 36px;
  cursor: pointer;
  background: none;
  border: none;
}

@media (max-width: 760px) {
  .chat-window-container {
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100% !important;
    height: 100% !important;
    height: 100dvh !important;
    border-radius: 0 !important;
    border: 0 !important;
    z-index: 10000 !important;
  }
  .chat-burbuja {
    right: 86px !important;
    bottom: 30px !important;
    max-width: calc(100vw - 110px) !important;
    font-size: 0.78rem !important;
    padding: 8px 12px !important;
  }
  .hero-badge {
    right: 10px !important;
    font-size: 0.8rem !important;
    padding: 10px 14px !important;
  }
}


/* Cookie Banner */
.cookie-banner { position: fixed; bottom: -100px; left: 0; width: 100%; background: rgba(10, 10, 10, 0.95); backdrop-filter: blur(10px); border-top: 1px solid rgba(255, 255, 255, 0.1); padding: 15px 20px; z-index: 9999; display: flex; justify-content: center; align-items: center; transition: bottom 0.4s ease-out; box-shadow: 0 -4px 20px rgba(0,0,0,0.5); }
.cookie-banner.visible { bottom: 0; }
.cookie-content { max-width: 900px; display: flex; flex-direction: column; md:flex-row; gap: 15px; align-items: center; justify-content: space-between; w-full }
.cookie-content p { color: rgba(255,255,255,0.8); font-size: 0.85rem; margin: 0; line-height: 1.4; text-align: center; }
.cookie-content p a { color: var(--rojo-claro); text-decoration: underline; }
.cookie-content button { white-space: nowrap; padding: 8px 24px; font-size: 0.9rem; }
@media (min-width: 768px) { .cookie-content { flex-direction: row; } .cookie-content p { text-align: left; } }

/* ============================================================
   NUEVO FOOTER MODERNO Y DINAMICO
   ============================================================ */
.footer-moderna {
  background: #040405;
  border-top: 1px solid rgba(255, 255, 255, 0.05);
  padding: 80px 0 40px;
  position: relative;
  overflow: hidden;
  color: var(--gris);
}

.footer-top {
  display: flex;
  flex-direction: column;
  gap: 50px;
  margin-bottom: 50px;
}
@media (min-width: 1024px) {
  .footer-top {
    flex-direction: row;
    justify-content: space-between;
  }
}

.ft-brand {
  flex: 0 0 320px;
}

.ft-logo {
  height: 80px;
  width: auto;
  margin-bottom: 25px;
  filter: drop-shadow(0 4px 14px rgba(209,15,45,0.4));
  transition: transform 0.4s ease;
}
.ft-logo:hover {
  transform: scale(1.05);
}

.ft-slogan {
  font-size: 0.95rem;
  line-height: 1.6;
  margin-bottom: 20px;
  color: rgba(255,255,255,0.7);
}

.ft-respaldo {
  font-size: 0.85rem;
  margin-bottom: 20px;
}
.ft-respaldo a {
  color: var(--rojo-claro);
  font-weight: 600;
  text-decoration: none;
}
.ft-respaldo a:hover {
  text-decoration: underline;
}

.ft-fundacion {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  background: rgba(255, 42, 69, 0.1);
  border: 1px solid rgba(255, 42, 69, 0.3);
  border-radius: 30px;
  color: #fff !important;
  font-size: 0.85rem;
  font-weight: 600;
  transition: all 0.3s ease;
  text-decoration: none;
}
.ft-fundacion svg {
  width: 16px;
  height: 16px;
}
.ft-fundacion:hover {
  background: rgba(255, 42, 69, 0.3);
  transform: translateY(-2px);
  box-shadow: 0 5px 15px rgba(255, 42, 69, 0.2);
}

.ft-links {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
  flex: 1;
  justify-content: flex-start;
}
@media (min-width: 768px) {
  .ft-links {
    justify-content: flex-end;
    gap: 80px;
  }
}

.ft-col h5 {
  color: #ffffff;
  font-family: var(--f-titulo);
  font-size: 1.1rem;
  margin-bottom: 25px;
  letter-spacing: 0.5px;
  position: relative;
  display: inline-block;
}
.ft-col h5::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -6px;
  width: 20px;
  height: 2px;
  background: var(--rojo);
  transition: width 0.3s ease;
}
.ft-col:hover h5::after {
  width: 100%;
}

@media (min-width: 768px) { .cookie-content { flex-direction: row; } .cookie-content p { text-align: left; } }

/* ============================================================
   NUEVO FOOTER MODERNO, INTERACTIVO Y ANIMADO
   ============================================================ */
.footer-moderna {
  background: #040405;
  border-top: 1px solid rgba(255, 255, 255, 0.04);
  padding: 80px 0 40px;
  position: relative;
  overflow: hidden;
  color: var(--gris);
}

/* Efecto de resplandor interactivo dinámico */
.footer-interactive-glow {
  position: absolute;
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, rgba(255, 42, 69, 0.12) 0%, rgba(255, 42, 69, 0) 70%);
  border-radius: 50%;
  pointer-events: none;
  transform: translate(-50%, -50%) scale(0.85);
  opacity: 0;
  transition: opacity 0.6s cubic-bezier(0.23, 1, 0.32, 1), transform 0.6s cubic-bezier(0.23, 1, 0.32, 1);
  z-index: 1;
}
.footer-interactive-glow.active {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.footer-top {
  display: flex;
  flex-direction: column;
  gap: 50px;
  margin-bottom: 50px;
}
@media (min-width: 1024px) {
  .footer-top {
    flex-direction: row;
    justify-content: space-between;
  }
}

.ft-brand {
  flex: 0 0 320px;
  position: relative;
  z-index: 2;
}

.ft-logo {
  height: 80px;
  width: auto;
  margin-bottom: 25px;
  filter: drop-shadow(0 4px 14px rgba(209, 15, 45, 0.25));
  transition: transform 0.4s cubic-bezier(0.23, 1, 0.32, 1), filter 0.4s ease;
}
@media (hover: hover) and (pointer: fine) {
  .ft-logo:hover {
    transform: translateY(-4px) scale(1.03);
    filter: drop-shadow(0 8px 24px rgba(255, 42, 69, 0.45));
  }
}

.ft-slogan {
  font-size: 0.95rem;
  line-height: 1.6;
  margin-bottom: 20px;
  color: rgba(255, 255, 255, 0.65);
}

.ft-respaldo {
  font-size: 0.85rem;
  margin-bottom: 20px;
  color: rgba(255, 255, 255, 0.5);
}
.ft-respaldo a {
  position: relative;
  display: inline-block;
  color: var(--rojo-claro);
  font-weight: 600;
  text-decoration: none;
  transition: color 0.2s ease;
}
.ft-respaldo a::after {
  content: '';
  position: absolute;
  width: 0;
  height: 1px;
  bottom: -1px;
  left: 0;
  background-color: var(--rojo-claro);
  transition: width 0.25s cubic-bezier(0.23, 1, 0.32, 1);
}
@media (hover: hover) and (pointer: fine) {
  .ft-respaldo a:hover {
    color: #fff;
  }
  .ft-respaldo a:hover::after {
    width: 100%;
  }
}

/* Botón de la Fundación unificado arriba */

.ft-links {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
  flex: 1;
  justify-content: flex-start;
  position: relative;
  z-index: 2;
}
@media (min-width: 768px) {
  .ft-links {
    justify-content: flex-end;
    gap: 80px;
  }
}

.ft-col h5 {
  color: #ffffff;
  font-family: var(--f-titulo);
  font-size: 1.1rem;
  margin-bottom: 25px;
  letter-spacing: 0.5px;
  position: relative;
  display: inline-block;
}
.ft-col h5::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -6px;
  width: 20px;
  height: 2px;
  background: var(--rojo);
  transition: width 0.3s cubic-bezier(0.23, 1, 0.32, 1);
}
.ft-col:hover h5::after {
  width: 100%;
}

.ft-col a {
  display: block;
  color: rgba(255, 255, 255, 0.6);
  font-size: 0.95rem;
  margin-bottom: 12px;
  text-decoration: none;
  position: relative;
  transition: transform 0.25s cubic-bezier(0.23, 1, 0.32, 1), color 0.25s ease;
}
.ft-col a:not(.btn)::before {
  content: '•';
  position: absolute;
  left: -12px;
  opacity: 0;
  color: var(--rojo-claro);
  transition: opacity 0.2s ease, transform 0.2s ease;
  transform: scale(0.5);
}
@media (hover: hover) and (pointer: fine) {
  .ft-col a:not(.btn):hover {
    color: #fff;
    transform: translateX(12px);
  }
  .ft-col a:not(.btn):hover::before {
    opacity: 1;
    transform: scale(1.2);
  }
}

.ft-contact-item {
  display: flex !important;
  align-items: center;
  gap: 10px;
  cursor: pointer;
}
.ft-contact-item svg {
  width: 18px;
  height: 18px;
  color: var(--rojo-claro);
  transition: transform 0.25s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}
@media (hover: hover) and (pointer: fine) {
  .ft-contact-item:hover svg {
    transform: scale(1.2) rotate(8deg);
  }
}

/* Botón de Cotización - Diseño Premium Laser Border Beam */
.ft-cta {
  padding: 12px 0 !important;
  font-size: 0.9rem !important;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #fff !important;
  background: #0a0a0d; /* Fondo ultra oscuro integrado */
  border: none !important; /* Elimina borde normal */
  position: relative;
  overflow: hidden;
  border-radius: 8px !important; /* Más redondeado y moderno */
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  width: 100% !important;
  box-sizing: border-box !important;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.6);
  transition: transform 0.25s cubic-bezier(0.25, 0.8, 0.25, 1), box-shadow 0.25s ease, letter-spacing 0.25s ease;
  z-index: 1;
}

/* El haz de luz giratorio (Conic Gradient) */
.ft-cta::before {
  content: '';
  position: absolute;
  top: -150%;
  left: -150%;
  width: 400%;
  height: 400%;
  background: conic-gradient(
    from 0deg,
    transparent 0%,
    transparent 65%,
    var(--rojo-claro) 80%,
    #ff6b6b 90%,
    var(--rojo-claro) 95%,
    transparent 100%
  );
  z-index: -2;
  animation: border-beam-rotate 4s linear infinite;
  transition: animation-duration 0.3s ease;
}

/* El fondo interno que enmascara el gradiente y simula el borde */
.ft-cta::after {
  content: '';
  position: absolute;
  inset: 1.5px; /* Grosor del borde láser */
  background: #0a0a0d;
  border-radius: 7px;
  z-index: -1;
  transition: background-color 0.3s ease;
}

@media (hover: hover) and (pointer: fine) {
  .ft-cta:hover {
    transform: translateY(-3px) scale(1.02);
    box-shadow: 
      0 8px 25px rgba(212, 25, 32, 0.45), 
      0 0 15px rgba(212, 25, 32, 0.2);
    letter-spacing: 0.08em;
    text-shadow: 0 0 8px rgba(255, 255, 255, 0.6);
  }
  .ft-cta:hover::before {
    animation-duration: 2s; /* Gira más rápido al pasar el ratón */
  }
  .ft-cta:hover::after {
    background: #0f0f14; /* Sutil aclarado de fondo */
  }
}

.ft-cta:active {
  transform: translateY(-1px) scale(0.98);
  box-shadow: 0 4px 10px rgba(212, 25, 32, 0.3);
}

/* Animación del Borde Láser */
@keyframes border-beam-rotate {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

.footer-mid {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  padding: 30px 0;
  border-top: 1px solid rgba(255, 255, 255, 0.05);
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  margin-bottom: 30px;
  position: relative;
  z-index: 2;
}
@media (min-width: 768px) {
  .footer-mid {
    flex-direction: row;
    justify-content: space-between;
  }
}

.ft-social {
  display: flex;
  gap: 15px;
}
.ft-social a {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  display: grid;
  place-items: center;
  color: rgba(255, 255, 255, 0.8);
  transition: transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1), background 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease, color 0.25s ease;
}
.ft-social svg {
  width: 20px;
  height: 20px;
}
@media (hover: hover) and (pointer: fine) {
  .ft-social a[data-ig]:hover {
    background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
    border-color: transparent;
    color: #fff;
    transform: translateY(-5px) scale(1.1);
    box-shadow: 0 8px 20px rgba(220, 39, 67, 0.4);
  }
  .ft-social a[data-fb]:hover {
    background: #1877f2;
    border-color: #1877f2;
    color: #fff;
    transform: translateY(-5px) scale(1.1);
    box-shadow: 0 8px 20px rgba(24, 119, 242, 0.4);
  }
  .ft-social a[data-tt]:hover {
    background: #010101;
    border-color: #010101;
    color: #fff;
    transform: translateY(-5px) scale(1.1);
    box-shadow: 3px 3px 0 rgba(0,242,234,0.6), -3px -3px 0 rgba(254,44,85,0.6), 0 8px 20px rgba(0, 0, 0, 0.6);
  }
}
.ft-social a:active {
  transform: scale(0.95);
}

.ft-legales {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 15px;
}
.ft-legales a {
  color: rgba(255, 255, 255, 0.5);
  font-size: 0.85rem;
  transition: color 0.25s ease, transform 0.25s ease;
  text-decoration: none;
}
@media (hover: hover) and (pointer: fine) {
  .ft-legales a:hover {
    color: #fff;
    transform: translateY(-1px);
  }
}
.ft-dot {
  width: 4px;
  height: 4px;
  background: rgba(255, 255, 255, 0.15);
  border-radius: 50%;
}

.footer-bottom {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 10px;
  position: relative;
  z-index: 2;
}
.footer-bottom p {
  margin: 0;
  font-size: 0.85rem;
  color: rgba(255, 255, 255, 0.4);
}
.ft-ciudades {
  letter-spacing: 1px;
  color: rgba(255, 255, 255, 0.3) !important;
}

/* Pills de Estado Horario Dinámicas */
.status-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 12px;
  font-size: 0.75rem;
  font-weight: 600;
  margin-left: 10px;
  vertical-align: middle;
  transition: all 0.3s ease;
}
.status-pill .status-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  display: inline-block;
}
.status-pill.status-open {
  background: rgba(57, 255, 20, 0.08);
  color: #39ff14;
  border: 1px solid rgba(57, 255, 20, 0.22);
  box-shadow: 0 0 10px rgba(57, 255, 20, 0.05);
}
.status-pill.status-open .status-dot {
  background: #39ff14;
  box-shadow: 0 0 6px #39ff14;
  animation: pulse-dot 2s infinite;
}
.status-pill.status-closed {
  background: rgba(255, 255, 255, 0.04);
  color: rgba(255, 255, 255, 0.45);
  border: 1px solid rgba(255, 255, 255, 0.08);
}
.status-pill.status-closed .status-dot {
  background: rgba(255, 255, 255, 0.3);
}
@keyframes pulse-dot {
  0% { transform: scale(0.95); box-shadow: 0 0 0 0 rgba(57, 255, 20, 0.7); }
  70% { transform: scale(1); box-shadow: 0 0 0 5px rgba(57, 255, 20, 0); }
  100% { transform: scale(0.95); box-shadow: 0 0 0 0 rgba(57, 255, 20, 0); }
}

/* Botón Scroll-to-Top circular estético */
.footer-scroll-top {
  position: absolute;
  bottom: 40px;
  right: 20px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.6);
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: transform 0.3s cubic-bezier(0.23, 1, 0.32, 1), background-color 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease, color 0.25s ease;
  z-index: 10;
}
.footer-scroll-top svg {
  width: 20px;
  height: 20px;
  transition: transform 0.3s cubic-bezier(0.23, 1, 0.32, 1);
}
@media (hover: hover) and (pointer: fine) {
  .footer-scroll-top:hover {
    background: var(--rojo);
    border-color: var(--rojo);
    color: #fff;
    transform: translateY(-5px);
    box-shadow: 0 8px 20px rgba(255, 42, 69, 0.3);
  }
  .footer-scroll-top:hover svg {
    transform: translateY(-2px);
  }
}
.footer-scroll-top:active {
  transform: translateY(-2px) scale(0.95);
}
@media (max-width: 760px) {
  .footer-scroll-top {
    position: static;
    margin: 20px auto 0;
  }
}

/* ============================================================
   LUPA DE PRE-PRENSA TEXTIL
   ============================================================ */
.seccion-preprensa {
  position: relative;
  overflow: hidden;
}
.loupe-simulator {
  display: grid;
  grid-template-columns: 1fr 1.35fr;
  gap: 36px;
  background: rgba(11, 11, 13, 0.4);
  border: 1px solid rgba(255, 255, 255, 0.04);
  border-radius: 24px;
  padding: 30px;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: 0 20px 45px rgba(0, 0, 0, 0.3);
}

/* Columna 1: Selectores */
.loupe-selector {
  display: flex;
  flex-direction: column;
  gap: 12px;
  justify-content: center;
}
.loupe-btn {
  display: flex;
  align-items: center;
  gap: 16px;
  background: rgba(255, 255, 255, 0.01);
  border: 1px solid rgba(255, 255, 255, 0.03);
  border-radius: 16px;
  padding: 16px 20px;
  text-align: left;
  cursor: pointer;
  transition: var(--trans-cubic);
}
.loupe-btn:hover {
  background: rgba(255, 255, 255, 0.03);
  border-color: rgba(255, 255, 255, 0.1);
  transform: translateX(4px);
}
.loupe-btn.active {
  background: rgba(212, 25, 32, 0.05);
  border-color: rgba(212, 25, 32, 0.25);
  box-shadow: 0 4px 15px rgba(212, 25, 32, 0.08);
}
.btn-indicator {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.1);
  transition: background-color 0.3s ease, box-shadow 0.3s ease;
}
.loupe-btn.active .btn-indicator {
  background: var(--rojo-claro);
  box-shadow: 0 0 10px var(--rojo-claro), 0 0 4px var(--rojo-claro);
}
.btn-text h4 {
  font-family: var(--f-display);
  font-size: 0.95rem;
  font-weight: 800;
  color: rgba(255, 255, 255, 0.85);
  margin: 0 0 3px;
  transition: color 0.3s ease;
}
.loupe-btn.active .btn-text h4 {
  color: #fff;
}
.btn-text p {
  font-family: var(--f-texto);
  font-size: 0.8rem;
  color: var(--gris);
  margin: 0;
}

/* Columna 2: Visor de Lupa */
.loupe-viewer-wrap {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.viewer-instructions {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--gris);
  font-size: 0.78rem;
}
.mouse-icon {
  width: 14px;
  height: 14px;
  stroke: var(--gris);
}
.loupe-viewer {
  position: relative;
  width: 100%;
  height: 320px;
  background: #0f0f12;
  border: 1px solid rgba(255, 255, 255, 0.04);
  border-radius: 20px;
  overflow: hidden;
  cursor: crosshair;
}

/* Telas CSS */
.fabric-texture {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
}
/* Patrón de Algodón Jersey */
.texture-jersey {
  background-color: #121216;
  background-image: 
    linear-gradient(90deg, rgba(255,255,255,0.015) 50%, transparent 50%),
    linear-gradient(rgba(255,255,255,0.01) 50%, transparent 50%);
  background-size: 4px 4px;
}
/* Patrón de Piqué Honeycomb */
.texture-pique {
  background-color: #15151b;
  background-image: 
    radial-gradient(rgba(255, 255, 255, 0.02) 25%, transparent 25%),
    radial-gradient(rgba(255, 255, 255, 0.01) 25%, transparent 25%);
  background-size: 8px 8px;
  background-position: 0 0, 4px 4px;
}
/* Patrón de Microfibra Rejilla */
.texture-microfiber {
  background-color: #0e0e11;
  background-image: 
    linear-gradient(rgba(255, 255, 255, 0.015) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.015) 1px, transparent 1px);
  background-size: 6px 6px;
}

/* Diseños en Muestras */
.mockup-normal, .mockup-zoom {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
}
.mockup-zoom {
  width: 250%; /* Factor de escala */
  height: 250%;
  left: 0;
  top: 0;
}
.preview-art {
  position: relative;
  z-index: 2;
  text-align: center;
  transition: transform 0.3s ease;
}

/* Artes de Muestra */
/* DTF Relieve */
.art-dtf {
  font-family: var(--f-display);
  font-weight: 800;
  font-size: 2.2rem;
  color: #fff;
  text-shadow: 
    0 1px 0 #bbb, 
    0 2px 0 #999, 
    0 3px 5px rgba(0,0,0,0.5), 
    0 0 15px rgba(212,25,32,0.4);
}
.art-dtf span {
  color: var(--rojo-claro);
  display: block;
  font-size: 0.9rem;
  font-family: var(--f-titulo);
  letter-spacing: 0.15em;
  margin-top: 4px;
}
/* Serigrafía Plana */
.art-serigrafia {
  font-family: var(--f-display);
  font-weight: 800;
  font-size: 2.4rem;
  color: #fff;
  border: 4px solid #fff;
  padding: 10px 24px;
  border-radius: 4px;
  letter-spacing: -0.02em;
  background: rgba(11,11,13,0.5);
  box-shadow: 0 4px 15px rgba(0,0,0,0.2);
}
/* Sublimación fusionada */
.art-sublimacion {
  font-family: var(--f-display);
  font-weight: 800;
  font-size: 2.2rem;
  background: linear-gradient(45deg, #ff007f, #7f00ff, #00f0ff);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 2px 8px rgba(127,0,255,0.4));
  mix-blend-mode: screen; /* Fusión molecular visual */
}
/* Bordado Puntadas 3D */
.art-bordado {
  font-family: var(--f-display);
  font-weight: 800;
  font-size: 2rem;
  color: #fbd400; /* Hilo dorado */
  text-shadow: 
    -1px -1px 0 rgba(255,255,255,0.1),
    1px 1px 0 rgba(0,0,0,0.8),
    0 4px 10px rgba(0,0,0,0.6);
  padding: 8px 16px;
  border: 2px dashed #fbd400;
  border-radius: 50px;
  position: relative;
  background: repeating-linear-gradient(45deg, rgba(0,0,0,0.05), rgba(0,0,0,0.05) 1px, transparent 1px, transparent 2px);
}

/* Lupa */
.loupe-lens {
  position: absolute;
  width: 160px;
  height: 160px;
  border-radius: 50%;
  border: 4px solid var(--rojo-claro);
  box-shadow: 
    0 15px 35px rgba(0,0,0,0.7), 
    inset 0 0 20px rgba(255,255,255,0.15),
    0 0 10px rgba(212,25,32,0.3);
  overflow: hidden;
  pointer-events: none;
  z-index: 5;
  opacity: 0;
  transform: scale(0.9);
  transition: opacity 0.25s ease, transform 0.25s ease, border-color 0.3s ease;
  will-change: left, top, opacity, transform;
}
.loupe-viewer:hover .loupe-lens {
  opacity: 1;
  transform: scale(1);
}
.lens-reflection {
  position: absolute;
  inset: 0;
  z-index: 6;
  background: linear-gradient(135deg, rgba(255,255,255,0.18) 0%, rgba(255,255,255,0.05) 45%, transparent 50%, transparent 100%);
  pointer-events: none;
}

/* Footer del Visor */
.viewer-tech-footer {
  display: flex;
  justify-content: space-between;
  font-size: 0.8rem;
  color: var(--gris);
  border-top: 1px solid rgba(255, 255, 255, 0.04);
  padding-top: 10px;
}
.viewer-tech-footer span {
  font-family: var(--f-texto);
  font-weight: 500;
}

/* Adaptación responsive */
@media (max-width: 980px) {
  .loupe-simulator {
    grid-template-columns: 1fr;
    gap: 30px;
    padding: 24px;
  }
  .loupe-selector {
    flex-direction: row;
    overflow-x: auto;
    gap: 12px;
    justify-content: flex-start;
    padding-bottom: 8px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .loupe-selector::-webkit-scrollbar { display: none; }
  .loupe-btn {
    flex: 0 0 auto;
    padding: 12px 16px;
  }
  .loupe-btn:hover {
    transform: none;
  }
  .loupe-viewer {
    height: 280px;
  }
  /* En tablets/móviles desactivamos la lupa dinámica para que no interfiera y mostramos el zoom estático a un lado */
  .loupe-lens {
    display: none !important;
  }
}

@media (max-width: 600px) {
  .loupe-btn {
    padding: 10px 14px;
  }
  .loupe-viewer {
    height: 240px;
  }
}


/* ============================================================
   SECCIÓN DE CARACTERÍSTICAS / BENEFICIOS PREMIUM (CATALOGO)
   ============================================================ */

/* Contenedor de tarjeta */
.benefit-card {
  background: rgba(20, 20, 22, 0.45);
  border: 1px solid rgba(255, 255, 255, 0.04);
  border-radius: 24px;
  padding: 35px 30px;
  position: relative;
  overflow: hidden;
  backdrop-filter: blur(12px) saturate(140%);
  -webkit-backdrop-filter: blur(12px) saturate(140%);
  transition: 
    transform 0.4s cubic-bezier(0.23, 1, 0.32, 1),
    border-color 0.4s cubic-bezier(0.23, 1, 0.32, 1),
    box-shadow 0.4s cubic-bezier(0.23, 1, 0.32, 1);
  display: flex;
  flex-direction: column;
  height: 100%;
}

/* Efecto Hover sobre la Tarjeta */
@media (hover: hover) and (pointer: fine) {
  .benefit-card:hover {
    transform: translateY(-6px);
    border-color: rgba(239, 35, 60, 0.35);
    box-shadow: 
      0 20px 40px rgba(0, 0, 0, 0.4),
      0 0 30px rgba(239, 35, 60, 0.12),
      inset 0 0 12px rgba(239, 35, 60, 0.06);
  }
}

/* Contenedor de Iconos (Redondas Píldoras con Halo LED) */
.benefit-icon-wrap {
  width: 52px;
  height: 52px;
  border-radius: 16px;
  background: rgba(239, 35, 60, 0.08);
  border: 1px solid rgba(239, 35, 60, 0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--rojo-claro);
  margin-bottom: 25px;
  transition: all 0.4s cubic-bezier(0.23, 1, 0.32, 1);
  box-shadow: 0 4px 10px rgba(239, 35, 60, 0.05);
  animation: benefit-float 5s ease-in-out infinite;
}

/* Variar el delay de animación flotante en cada tarjeta */
.benefit-card:nth-child(2) .benefit-icon-wrap {
  animation-delay: 1.5s;
}
.benefit-card:nth-child(3) .benefit-icon-wrap {
  animation-delay: 3s;
}

/* Hover del icono */
.benefit-card:hover .benefit-icon-wrap {
  color: #ffffff;
  background: var(--rojo);
  border-color: var(--rojo-claro);
  box-shadow: 0 0 20px rgba(239, 35, 60, 0.5);
  transform: scale(1.05) translateY(-2px);
}

.benefit-icon-wrap svg {
  width: 24px;
  height: 24px;
  stroke-width: 2.2px;
  transition: transform 0.4s ease;
}

.benefit-card:hover .benefit-icon-wrap svg {
  transform: rotate(6deg) scale(1.1);
}

/* Tipografía de la Tarjeta */
.benefit-card h3 {
  font-family: var(--f-titulo);
  font-size: 1.35rem;
  color: #ffffff;
  margin-bottom: 12px;
  font-weight: 700;
  letter-spacing: -0.01em;
}

.benefit-desc {
  font-size: 0.95rem;
  line-height: 1.6;
  color: var(--gris);
  margin-bottom: 0;
  transition: color 0.3s ease;
  flex-grow: 1;
}

.benefit-card:hover .benefit-desc {
  color: rgba(255, 255, 255, 0.9);
}

/* Links internos estilizados */
.benefit-link {
  color: var(--rojo-claro);
  text-decoration: none;
  font-weight: 600;
  position: relative;
  display: inline-block;
  transition: color 0.25s ease;
}

.benefit-link::after {
  content: '';
  position: absolute;
  width: 0;
  height: 1.5px;
  bottom: -1px;
  left: 0;
  background-color: var(--rojo-claro);
  transition: width 0.25s cubic-bezier(0.23, 1, 0.32, 1);
}

.benefit-link:hover {
  color: #ffffff;
}

.benefit-link:hover::after {
  width: 100%;
  background-color: #ffffff;
}

/* Bloque Desplegable Elástico (Elastic Grid Template Rows) */
.benefit-details-wrap {
  display: grid;
  grid-template-rows: 0fr;
  transition: 
    grid-template-rows 0.45s cubic-bezier(0.23, 1, 0.32, 1),
    opacity 0.45s cubic-bezier(0.23, 1, 0.32, 1),
    margin-top 0.45s cubic-bezier(0.23, 1, 0.32, 1);
  opacity: 0;
  overflow: hidden;
  margin-top: 0;
}

/* Hover de la Tarjeta despliega los detalles */
.benefit-card:hover .benefit-details-wrap {
  grid-template-rows: 1fr;
  opacity: 1;
  margin-top: 20px;
}

/* En dispositivos táctiles que no tienen hover nativo, o pantallas pequeñas,
   mostramos siempre un porcentaje de detalles o habilitamos su visualización clara */
@media (hover: none) {
  .benefit-details-wrap {
    grid-template-rows: 1fr;
    opacity: 1;
    margin-top: 20px;
  }
}

.benefit-details-content {
  min-height: 0;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  padding-top: 15px;
}

/* Lista de Especificaciones Técnicas */
.benefit-specs {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.benefit-specs li {
  font-size: 0.85rem;
  line-height: 1.5;
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.spec-label {
  font-weight: 700;
  color: var(--rojo-claro);
  text-transform: uppercase;
  font-size: 0.72rem;
  letter-spacing: 0.05em;
}

.spec-val {
  color: rgba(255, 255, 255, 0.7);
}

/* Animaciones */
@keyframes benefit-float {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-5px);
  }
}

/* Media query responsive para las tarjetas de beneficios */
@media (max-width: 768px) {
  .benefit-card {
    padding: 30px 24px;
    border-radius: 20px;
  }
  .benefit-icon-wrap {
    margin-bottom: 20px;
    animation: none; /* Desactivar flotación en móvil para evitar repaints */
  }
}

