/* ============================================================
   WONDERLAB · Smart Events — Design System
   Dark warm + auroras + LED palette + Bricolage Grotesque
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  /* Night warm bg */
  --bg:         #0A0807;
  --bg-2:       #110D0A;
  --bg-3:       #1A1410;
  /* Ink — paleta de grises aclarada para mejor contraste sobre fondos
     oscuros y sobre fotos. Los eyebrows/leads se leen mucho mejor. */
  --ink:        #F4EFE6;  /* texto principal */
  --ink-2:      #E0DAD0;  /* leads y bajadas (era #C9C0B0) */
  --ink-soft:   #B4ABA0;  /* eyebrows / meta uppercase (era #8E8576) */
  --ink-ghost:  #7A7466;  /* separadores muy tenues (era #5A5347) */
  --ink-dim:    #E0DAD0;  /* alias de ink-2 */
  /* Lines */
  --line:       rgba(244,239,230,.08);
  --line-strong:rgba(244,239,230,.20);
  /* LED palette */
  --led-pink:    #FF2D7F;
  --led-magenta: #E03DA6;
  --led-violet:  #7B4CFF;
  --led-cobalt:  #2E5BFF;
  --led-cyan:    #00DCC6;
  --led-lime:    #C8FF3D;
  --led-amber:   #FFB627;
  --led-orange:  #FF6B2E;
  /* Type */
  --f-display: 'Bricolage Grotesque', system-ui, sans-serif;
  --f-serif:   'Instrument Serif', Georgia, serif;
  --f-mono:    'JetBrains Mono', ui-monospace, monospace;
  --w-mono: var(--f-mono);

  --ease: cubic-bezier(.2,.8,.2,1);
  --ambient-intensity: .9;
  --aurora-dur: 32s;

  --section-color: var(--led-pink);
}

html { scroll-behavior: smooth; }
body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--f-display);
  font-weight: 400;
  line-height: 1.4;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  font-variant-ligatures: contextual;
  position: relative;
  min-height: 100vh;
}

body[data-section="corporativo"] { --section-color: var(--led-pink); }
body[data-section="social"]      { --section-color: var(--led-violet); }
body[data-section="nosotros"]    { --section-color: var(--led-cyan); }
body[data-section="mansion"]     { --section-color: var(--led-amber); }
body[data-section="blog"]        { --section-color: var(--led-lime); }
body[data-section="contacto"]    { --section-color: var(--led-pink); }

/* Acento bi-color para botones / hovers / filetes. Cada sección define
   sus 2 colores temáticos. Reemplaza el degradé arcoíris en cards y CTAs. */
:root {
  --accent-from: var(--led-pink);
  --accent-to:   var(--led-violet);
}
body[data-section="corporativo"] {
  --accent-from: var(--led-pink);
  --accent-to:   var(--led-amber);
}
body[data-section="social"],
body.theme-social,
body[data-section="mansion"] {
  --accent-from: var(--led-violet);
  --accent-to:   var(--led-cyan);
}
body[data-section="nosotros"] {
  --accent-from: var(--led-cyan);
  --accent-to:   var(--led-violet);
}
body[data-section="blog"] {
  --accent-from: var(--led-lime);
  --accent-to:   var(--led-cyan);
}
body[data-section="contacto"],
body[data-section="home"] {
  --accent-from: var(--led-pink);
  --accent-to:   var(--led-violet);
}

/* Énfasis en titulares y bajadas:
   - <span class="grad"> ahora pinta el texto con gradiente animado (lo
     usamos para resaltar palabras dentro de un título).
   - <em> y <span class="italic"> quedan como texto plano del mismo
     tipo que el título contenedor (se eliminó la versión serif italic
     para unificar tipografía en todo el sitio). */
.grad {
  background: linear-gradient(95deg,
    var(--led-pink) 0%, var(--led-amber) 22%,
    var(--led-lime) 44%, var(--led-cyan) 64%,
    var(--led-violet) 86%, var(--led-pink) 100%);
  background-size: 220% 100%;
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  animation: glowShift 12s ease-in-out infinite alternate;
  letter-spacing: -0.015em;
}
em, .italic {
  font-style: normal;
  font-weight: inherit;
  font-family: inherit;
  color: inherit;
  letter-spacing: inherit;
}

.glow {
  background: linear-gradient(95deg,
    var(--led-pink) 0%, var(--led-amber) 22%,
    var(--led-lime) 44%, var(--led-cyan) 64%,
    var(--led-violet) 86%, var(--led-pink) 100%);
  background-size: 220% 100%;
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  animation: glowShift 12s ease-in-out infinite alternate;
}
.glow.glow-cool {
  background: linear-gradient(95deg, var(--led-cyan), var(--led-violet), var(--led-pink), var(--led-cyan));
  background-size: 220% 100%;
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  animation: glowShift 14s ease-in-out infinite alternate;
}
@keyframes glowShift { 0% { background-position: 0% 50%; } 100% { background-position: 100% 50%; } }

/* ============================================================
   AMBIENT LAYER — auroras + canvas + connection SVG
   ============================================================ */
.ambient {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
  opacity: var(--ambient-intensity, .9);
  transform: translateZ(0);
  will-change: transform;
}
.aurora {
  position: absolute;
  border-radius: 50%;
  filter: blur(110px);
  mix-blend-mode: screen;
  opacity: .6;
  will-change: transform;
  transform: translateZ(0);
  contain: layout style paint;
}
.aurora.a1 {
  width: 720px; height: 720px;
  top: -180px; left: -120px;
  background:
    radial-gradient(circle at 30% 30%, var(--led-pink), transparent 55%),
    radial-gradient(circle at 70% 30%, var(--led-amber), transparent 55%),
    radial-gradient(circle at 60% 70%, var(--led-violet), transparent 55%);
  animation: drift1 var(--aurora-dur) ease-in-out infinite alternate;
}
.aurora.a2 {
  width: 820px; height: 820px;
  top: 30%; right: -200px;
  background:
    radial-gradient(circle at 30% 30%, var(--led-cyan), transparent 55%),
    radial-gradient(circle at 70% 40%, var(--led-violet), transparent 55%),
    radial-gradient(circle at 40% 80%, var(--led-pink), transparent 55%);
  animation: drift2 calc(var(--aurora-dur) * 1.3) ease-in-out infinite alternate;
  opacity: .5;
}
.aurora.a3 {
  width: 680px; height: 680px;
  top: 62%; left: 10%;
  background:
    radial-gradient(circle at 40% 40%, var(--led-lime), transparent 55%),
    radial-gradient(circle at 70% 70%, var(--led-cyan), transparent 55%),
    radial-gradient(circle at 30% 80%, var(--led-amber), transparent 55%);
  animation: drift3 calc(var(--aurora-dur) * 1.7) ease-in-out infinite alternate;
  opacity: .45;
}
.aurora.a4 {
  width: 900px; height: 900px;
  bottom: -200px; right: 10%;
  background:
    radial-gradient(circle at 50% 50%, var(--led-pink), transparent 55%),
    radial-gradient(circle at 30% 70%, var(--led-violet), transparent 55%),
    radial-gradient(circle at 80% 30%, var(--led-orange), transparent 55%);
  animation: drift4 calc(var(--aurora-dur) * 1.5) ease-in-out infinite alternate;
  opacity: .5;
}
@keyframes drift1 { 0% { transform: translate3d(0,0,0) scale(1) rotate(0deg); } 100% { transform: translate3d(120px,80px,0) scale(1.15) rotate(40deg); } }
@keyframes drift2 { 0% { transform: translate3d(0,0,0) scale(1) rotate(0deg); } 100% { transform: translate3d(-100px,140px,0) scale(1.1) rotate(-30deg); } }
@keyframes drift3 { 0% { transform: translate3d(0,0,0) scale(1) rotate(0deg); } 100% { transform: translate3d(80px,-120px,0) scale(1.2) rotate(50deg); } }
@keyframes drift4 { 0% { transform: translate3d(0,0,0) scale(1) rotate(0deg); } 100% { transform: translate3d(-160px,-90px,0) scale(1.05) rotate(-45deg); } }

#starfield {
  position: fixed;
  inset: 0;
  width: 100%; height: 100%;
  pointer-events: none;
  /* z-index 3: arriba de los videos de fondo (.hero-video-wrap z:0,
     .page-header-video z:0) y debajo del header/content (z:10+).
     Position fixed para que los puntos cubran todo el viewport
     constantemente, sin tener que estirarse al scroll. */
  z-index: 3;
}
.connections {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  opacity: .35;
}
.connections .line { stroke-dasharray: 12 8; animation: dash 14s linear infinite; }
.connections .line.line-2 { animation-duration: 18s; animation-direction: reverse; }
.connections .line.line-3 { animation-duration: 20s; }
.connections .line.line-4 { animation-duration: 16s; animation-direction: reverse; }
@keyframes dash { to { stroke-dashoffset: -200; } }
.connections .nodes circle {
  filter: drop-shadow(0 0 4px currentColor);
  animation: nodePulse 3s ease-in-out infinite;
}
.connections .nodes circle:nth-child(2n)  { animation-delay: .6s; }
.connections .nodes circle:nth-child(3n)  { animation-delay: 1.2s; }
.connections .nodes circle:nth-child(5n)  { animation-delay: 1.8s; }
.connections .nodes circle:nth-child(7n)  { animation-delay: 2.4s; }
@keyframes nodePulse {
  0%,100% { opacity: .9; transform: scale(1); }
  50%     { opacity: .25; transform: scale(.5); }
}

section, header, footer { position: relative; z-index: 1; }

/* ============================================================
   HEADER (fixed)
   ============================================================ */
.site-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 50;
  padding: 22px 36px;
  display: flex; align-items: center; justify-content: space-between;
  background: rgba(10,8,7,.6);
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  border-bottom: 1px solid var(--line);
  gap: 24px;
}
/* Línea fina animada en degradé bi-color debajo del header. Los 2 colores
   vienen del body (varían por sección Corp/Social/Mansión/etc). */
.site-header::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: -1px;
  height: 1px;
  background: linear-gradient(90deg,
    var(--accent-from),
    var(--accent-to),
    var(--accent-from));
  background-size: 250% 100%;
  animation: headerRainbow 10s linear infinite;
  pointer-events: none;
  opacity: .85;
}
@keyframes headerRainbow {
  0%   { background-position:   0% 50%; }
  100% { background-position: 300% 50%; }
}
.logo, .topbar-logo {
  display: inline-flex; align-items: center;
  text-decoration: none;
  line-height: 0;
}
/* Hamburger — solo aparece en mobile (override más abajo).
   Uso posición absoluta para los 3 spans para que la cruz X sea
   perfectamente simétrica (las 2 líneas se cruzan en el centro exacto). */
.nav-hamburger {
  display: none;
  background: transparent; border: 0;
  width: 44px; height: 44px;
  padding: 0;
  cursor: pointer;
  position: relative;
  border-radius: 8px;
  z-index: 51;
}
.nav-hamburger span {
  display: block;
  position: absolute;
  left: 50%; top: 50%;
  width: 22px; height: 2px;
  background: var(--ink);
  border-radius: 2px;
  transition: transform .3s var(--ease), opacity .2s;
  transform-origin: center;
}
.nav-hamburger span:nth-child(1) { transform: translate(-50%, calc(-50% - 7px)); }
.nav-hamburger span:nth-child(2) { transform: translate(-50%, -50%); }
.nav-hamburger span:nth-child(3) { transform: translate(-50%, calc(-50% + 7px)); }

body.is-nav-open .nav-hamburger span:nth-child(1) {
  transform: translate(-50%, -50%) rotate(45deg);
}
body.is-nav-open .nav-hamburger span:nth-child(2) {
  opacity: 0;
  transform: translate(-50%, -50%);
}
body.is-nav-open .nav-hamburger span:nth-child(3) {
  transform: translate(-50%, -50%) rotate(-45deg);
}
.logo-img {
  display: block;
  height: 28px;
  width: auto;
  user-select: none;
  -webkit-user-drag: none;
}
.logo-small .logo-img { height: 22px; }

/* NAV */
.nav { display: flex; align-items: center; gap: 2px; flex: 1; justify-content: center; }
.nav-item { position: relative; }
.nav-trigger {
  background: transparent; border: 0;
  color: var(--ink); cursor: pointer;
  font-family: var(--f-display); font-size: 15px; font-weight: 400;
  padding: 9px 14px;
  border-radius: 999px;
  display: inline-flex; align-items: center; gap: 7px;
  text-decoration: none;
  transition: background .22s var(--ease), color .22s;
  white-space: nowrap;
}
.nav-trigger i {
  font-size: 17px; margin-right: 2px;
}
.nav-trigger .caret {
  width: 6px; height: 6px;
  border-right: 1.4px solid currentColor;
  border-bottom: 1.4px solid currentColor;
  transform: rotate(45deg) translateY(-2px);
  transition: transform .25s var(--ease);
  opacity: .7;
}
.nav-trigger:hover,
.nav-item.is-open .nav-trigger,
.nav-trigger.is-active {
  background: rgba(244,239,230,.08);
}
.nav-item.is-open .nav-trigger .caret {
  transform: rotate(225deg) translateX(-2px);
}

.dropdown {
  position: absolute;
  top: calc(100% + 10px);
  left: 50%;
  transform: translateX(-50%) translateY(-6px);
  min-width: 360px;
  max-width: 720px;
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s var(--ease), transform .3s var(--ease);
  z-index: 100;
  padding-top: 8px;
}
.dropdown.wide { min-width: 620px; }
.nav-item.is-open .dropdown {
  opacity: 1; pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}
.dropdown::before {
  content: '';
  position: absolute;
  top: 0; left: 50%;
  transform: translateX(-50%);
  width: 0; height: 0;
  border-left: 9px solid transparent;
  border-right: 9px solid transparent;
  border-bottom: 9px solid rgba(15,12,10,.88);
  z-index: 2;
  filter: drop-shadow(0 -1px 0 var(--line-strong));
}
.dropdown::after {
  content: '';
  position: absolute;
  top: 7px; left: 50%;
  transform: translateX(-50%);
  width: 19px; height: 3px;
  background: rgba(15,12,10,.88);
  z-index: 3;
}
.dropdown-inner {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 22px;
  background: rgba(15,12,10,.88);
  backdrop-filter: blur(22px) saturate(140%);
  -webkit-backdrop-filter: blur(22px) saturate(140%);
  border: 1px solid var(--line-strong);
  border-radius: 22px;
  box-shadow:
    0 30px 60px -20px rgba(0,0,0,.7),
    0 0 0 1px rgba(255,255,255,.03) inset;
  position: relative;
}
.dd-cols {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}
.dropdown.wide .dd-cols {
  grid-template-columns: 1fr 1fr;
  gap: 28px;
}
.dd-col { display: flex; flex-direction: column; gap: 4px; }
.dd-label {
  font-family: var(--f-mono); font-size: 10px;
  color: var(--ink-soft); letter-spacing: .18em; text-transform: uppercase;
  padding: 4px 8px 12px;
  display: flex; align-items: center; gap: 10px;
}
.dd-led {
  width: 6px; height: 6px; border-radius: 50%;
  box-shadow: 0 0 8px currentColor;
}
.dd-link {
  display: flex; flex-direction: column; gap: 2px;
  text-decoration: none; color: var(--ink);
  padding: 10px 12px;
  border-radius: 12px;
  transition: background .2s, transform .2s var(--ease);
  position: relative;
}
.dd-link:hover {
  background: rgba(244,239,230,.06);
  transform: translateX(3px);
}
.dd-link .dd-name {
  font-family: var(--f-display); font-weight: 500; font-size: 15px;
  letter-spacing: -0.015em;
  line-height: 1.2;
}
.dd-link .dd-meta {
  font-family: var(--f-display); font-weight: 400; font-size: 12px;
  color: var(--ink-soft);
  line-height: 1.3;
}

/* Primera opción destacada — acento sutil:
   fondo levemente más visible + indicador chico a la izquierda. */
.dd-link-featured {
  position: relative;
  background: rgba(255,255,255,.04);
}
.dd-link-featured::before {
  content: '';
  position: absolute;
  left: 4px; top: 50%;
  transform: translateY(-50%);
  width: 3px;
  height: 22px;
  border-radius: 2px;
  background: linear-gradient(180deg, var(--led-pink), var(--led-violet));
  box-shadow: 0 0 8px rgba(255,45,127,.4);
}
.dd-link-featured .dd-name {
  font-weight: 600;
  color: #fff;
}

/* Bloque de contacto al pie del dropdown */
.dd-contact {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 14px 12px 4px;
  margin-top: 4px;
  border-top: 1px solid rgba(255,255,255,.08);
}
.dd-contact-item {
  display: flex;
  flex-direction: column;
  gap: 1px;
  text-decoration: none;
  color: var(--ink);
  font-family: var(--f-display);
  font-size: 13.5px;
  font-weight: 500;
  letter-spacing: -0.005em;
  padding: 4px 0;
  transition: color .2s;
}
.dd-contact-item:hover { color: var(--led-cyan); }
.dd-contact-label {
  font-family: var(--f-mono); font-size: 9.5px;
  letter-spacing: .18em; text-transform: uppercase;
  color: var(--ink-soft);
  font-weight: 400;
}

/* Header right */
.header-right, .topbar-right { display: flex; align-items: center; gap: 14px; }
.lang {
  font-family: var(--f-mono); font-size: 11px;
  color: var(--ink-soft); letter-spacing: .04em;
  display: inline-flex; align-items: center; gap: 4px;
}
.lang a {
  color: var(--ink-soft); text-decoration: none;
  transition: color .2s;
}
.lang a:hover { color: var(--ink); }
.lang a.on { color: var(--ink); font-weight: 500; }
.lang b { color: var(--ink); font-weight: 500; }

.cta-mini, .cta-pill {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--ink); color: var(--bg);
  padding: 10px 18px; border-radius: 999px;
  text-decoration: none; font-weight: 500; font-size: 14px;
  font-family: var(--f-display);
  transition: background .25s, transform .25s var(--ease);
  position: relative; overflow: hidden;
}
.cta-mini::after, .cta-pill::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(95deg, var(--accent-from), var(--accent-to));
  opacity: 0; transition: opacity .25s; z-index: -1;
}
.cta-mini:hover, .cta-pill:hover { transform: translateY(-2px); }
.cta-mini:hover::after, .cta-pill:hover::after { opacity: 1; }
.cta-mini .led {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--led-lime); box-shadow: 0 0 8px var(--led-lime);
  animation: blink 1.8s ease-in-out infinite;
}
@keyframes blink {
  0%,100% { opacity: 1; transform: scale(1); }
  50%     { opacity: .35; transform: scale(.8); }
}

/* ============================================================
   HERO (homepage)
   ============================================================ */
.hero {
  padding: 180px 36px 110px;
  min-height: 100vh;
  overflow: hidden;
  display: flex; flex-direction: column; justify-content: center;
}
.hero-video-wrap {
  position: absolute; inset: 0; z-index: 0;
  overflow: hidden;
  pointer-events: none;
  /* Negro mientras el video aún no cargó. Antes mostraba un poster
     (hero-mosaic.jpg) que se veía como flash de imagen estática
     hasta que arrancaba el loop — ahora directo a negro. */
  background: #000;
}
.hero-video, .hero-media {
  position: absolute;
  top: 50%; left: 50%;
  min-width: 100%; min-height: 100%;
  width: auto; height: auto;
  transform: translate(-50%, -50%);
  object-fit: cover;
  /* Antes brightness(.7) — ahora dejamos el video casi tal cual,
     solo un toque de saturación para que los colores del fondo
     se sientan. */
  filter: saturate(1.1) contrast(1.02) brightness(.92);
}
.hero-video-tint, .hero-overlay {
  position: absolute; inset: 0;
  /* Overlay más liviano: solo un viñeteo suave abajo para asegurar
     legibilidad del texto, y casi transparente arriba/centro. */
  background:
    radial-gradient(ellipse 80% 60% at 50% 80%, rgba(10,8,7,.25) 0%, rgba(10,8,7,.55) 100%),
    linear-gradient(180deg, rgba(10,8,7,.2) 0%, rgba(10,8,7,0) 30%, rgba(10,8,7,.7) 100%);
}
.hero-grain { display: none; }
.hero-ribbon {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  width: 100%; height: 100%;
  animation: ribbonFloat 22s ease-in-out infinite alternate;
  will-change: transform;
}
.hero-ribbon svg { width: 100%; height: 100%; display: block; }
@keyframes ribbonFloat {
  0%   { transform: translate3d(0, 0, 0) scale(1); }
  100% { transform: translate3d(0, -40px, 0) scale(1.04); }
}
.hero-inner, .hero-content {
  position: relative; z-index: 5;
  max-width: 1480px;
  margin: 0 auto;
  width: 100%;
}
.hero-marker {
  display: inline-flex; align-items: center; gap: 14px;
  font-family: var(--f-mono); font-size: 11px;
  color: var(--ink-2); letter-spacing: .16em; text-transform: uppercase;
  margin-bottom: 44px;
  padding-left: 24px;
  position: relative;
  flex-wrap: wrap;
}
.hero-marker-dot {
  position: absolute; left: 0; top: 50%;
  width: 10px; height: 10px; transform: translateY(-50%);
  border-radius: 50%;
  background: var(--section-color);
  box-shadow: 0 0 12px var(--section-color), 0 0 0 0 rgba(255,45,127,.5);
  animation: ringPulse 1.6s ease-out infinite;
}
.hero-marker .sep { color: var(--ink-ghost); }
.hero-marker i {
  font-size: 14px; text-transform: none; letter-spacing: 0;
  color: var(--ink);
}
@keyframes ringPulse {
  0%   { box-shadow: 0 0 10px var(--section-color), 0 0 0 0 rgba(255,45,127,.55); }
  100% { box-shadow: 0 0 10px var(--section-color), 0 0 0 16px rgba(255,45,127,0); }
}

h1.hero-title,
.hero h1,
.hero-content h1 {
  font-family: var(--f-display);
  font-weight: 500;
  font-size: clamp(52px, 8.5vw, 144px);
  line-height: .92;
  letter-spacing: -0.045em;
  max-width: 20ch;
  font-variation-settings: "wdth" 100, "opsz" 96;
  text-wrap: balance;
}
.hero h1 em, .hero h1 .italic,
.hero-title em, .hero-title .italic {
  letter-spacing: -0.015em;
}

.hero-meta {
  margin-top: 60px;
  display: flex;
  align-items: center;
  gap: 28px;
  max-width: 1280px;
}
.hero-meta > .lead { flex: 1 1 0; margin-top: 0; }
.hero-meta > .hero-jump { flex: 1 1 0; display: flex; }
@media (max-width: 720px) {
  .hero-meta { flex-direction: column; align-items: stretch; gap: 28px; }
}
.lead {
  font-family: var(--f-display);
  font-weight: 400;
  font-size: 22px; line-height: 1.45;
  color: var(--ink-2);
  max-width: 52ch;
  margin-top: 32px;
}
/* Hero lead: usa todo el ancho de su columna en el flex (no se limita a 32ch) */
.hero .lead { max-width: none; }
.lead em,
.lead .grad,
.lead .italic {
  color: var(--ink); font-size: 1.05em;
}

.cta-row {
  display: flex; gap: 14px; flex-wrap: wrap; align-items: center;
  margin-top: 36px;
}

/* Buttons */
.btn-primary {
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--ink); color: var(--bg);
  padding: 18px 28px; border-radius: 999px;
  text-decoration: none; font-weight: 500; font-size: 16px;
  font-family: var(--f-display);
  transition: transform .3s var(--ease), color .3s, padding-right .3s var(--ease);
  position: relative; overflow: hidden;
  z-index: 1;
  border: none;
  cursor: pointer;
}
.btn-primary::after {
  content: ''; position: absolute; inset: 0; border-radius: 999px;
  background: linear-gradient(95deg, var(--accent-from), var(--accent-to));
  opacity: 0; transition: opacity .35s; z-index: -1;
}
.btn-primary:hover { transform: translateY(-2px); padding-right: 36px; }
.btn-primary:hover::after { opacity: 1; }
.btn-primary .arrow { font-size: 19px; }

.btn-link {
  font-family: var(--f-display);
  font-size: 15px; color: var(--ink); text-decoration: none;
  padding: 14px 4px;
  display: inline-flex; align-items: center; gap: 8px;
  border-bottom: 1px solid var(--ink);
  transition: color .25s, border-color .25s;
}
.btn-link:hover { color: var(--section-color); border-color: var(--section-color); }

/* ============================================================
   HERO JUMP BUTTONS — anchor a #corporativo y #social
   Botones destacados que reemplazan al cta-row del hero.
   ============================================================ */
.hero-jump {
  margin-top: 0;
  display: flex;
  gap: 14px;
  flex: 1;
  align-items: stretch;
}
.hero-jump > .hero-jump-btn { flex: 1 1 0; }
.hero-jump-btn {
  position: relative;
  display: flex; align-items: center; gap: 16px;
  padding: 18px 22px;
  background: rgba(255,255,255,.04);
  border: 1.5px solid rgba(255,255,255,.12);
  border-radius: 18px;
  text-decoration: none;
  color: var(--ink);
  overflow: hidden;
  isolation: isolate;
  transition: transform .4s var(--ease), border-color .4s, background .4s, box-shadow .4s;
  box-shadow: 0 10px 30px -14px rgba(0,0,0,.55);
  height: 100%;
}
.hero-jump-btn::before {
  /* Aurora interno encendido por default (opacity .45). Está siempre
     visible para que el botón sea protagónico, sube a .75 en hover. */
  content: ''; position: absolute; inset: -50%;
  background:
    radial-gradient(circle at 25% 30%, var(--c1, var(--led-pink)), transparent 45%),
    radial-gradient(circle at 80% 70%, var(--c2, var(--led-violet)), transparent 50%);
  filter: blur(50px);
  opacity: .45;
  z-index: -1;
  transition: opacity .5s, transform 1s var(--ease);
  animation: cardDrift 18s ease-in-out infinite alternate;
}
.hero-jump-btn:hover {
  transform: translateY(-4px);
  background: rgba(255,255,255,.07);
  border-color: var(--c1, var(--ink));
  box-shadow:
    0 24px 60px -20px rgba(0,0,0,.65),
    0 0 0 1px var(--c1, var(--ink)),
    0 10px 40px -10px var(--c1, transparent);
}
.hero-jump-btn:hover::before { opacity: .75; transform: scale(1.12); }

.hero-jump-corp { --c1: var(--led-pink);   --c2: var(--led-violet); }
.hero-jump-social { --c1: var(--led-violet); --c2: var(--led-cyan);   }

.hjb-led { display: none; }
.hjb-eyebrow { display: none; }
.hjb-label {
  flex: 1; display: flex; flex-direction: column; gap: 4px;
  min-width: 0;
}
.hjb-title {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(17px, 1.6vw, 20px);
  letter-spacing: -0.025em; line-height: 1.1;
  color: #fff;
}
.hjb-desc {
  font-family: var(--f-display); font-weight: 400;
  font-size: 12.5px; line-height: 1.4;
  color: rgba(255,255,255,.78);
  margin-top: 0;
}
.hjb-arrow {
  flex: 0 0 auto;
  /* Flecha recta, sin italic (era serif italic que la inclinaba). */
  font-family: var(--f-display); font-weight: 500;
  font-style: normal;
  font-size: 22px;
  line-height: 1;
  color: var(--c1);
  transition: transform .4s var(--ease);
  text-shadow: 0 0 12px var(--c1);
}
.hero-jump-btn:hover .hjb-arrow { transform: translateY(5px); }

@media (max-width: 720px) {
  .hero-jump { flex-direction: column; gap: 14px; max-width: 480px; }
  .hero-jump-btn { padding: 28px 22px; gap: 14px; min-height: 110px; }
  .hjb-title { font-size: 20px; }
  .hjb-desc { font-size: 13px; line-height: 1.45; }
  .hjb-arrow { font-size: 28px; }
}

/* Stats */
.stat-strip, .stats, .stats-block {
  margin-top: 110px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
  padding-top: 36px;
  border-top: 1px solid var(--line-strong);
}
.stats-block { max-width: 1480px; margin-left: auto; margin-right: auto; }
.stat-strip .item, .stats > div, .stats-block .item {
  display: flex; flex-direction: column; gap: 14px;
}
.stat-strip .num, .stats .stat-num, .stats-block .num {
  font-family: var(--f-display); font-weight: 500;
  font-size: clamp(48px, 7vw, 100px);
  color: var(--ink); letter-spacing: -0.055em; line-height: .9;
  font-variation-settings: "wdth" 100, "opsz" 96;
}
.stat-strip .num em, .stats .stat-num .grad, .stats-block .num .grad, .stats-block .num em {
  background: linear-gradient(95deg, var(--led-pink), var(--led-amber), var(--led-cyan));
  background-size: 200% 100%;
  -webkit-background-clip: text; background-clip: text; color: transparent;
  animation: glowShift 10s ease-in-out infinite alternate;
  letter-spacing: -0.015em;
}
/* "K" del +110K — misma altura que el número, no cap-height del serif italic */
.stat-strip .num em,
.stats-block .num em {
  font-size: .62em;
  vertical-align: baseline;
  line-height: 1;
  display: inline-block;
  padding-right: .05em;
}
.stat-strip .lbl, .stats .stat-label, .stats-block .lbl {
  font-family: var(--f-mono); font-size: 12px; color: var(--ink-soft);
  text-transform: uppercase; letter-spacing: .14em;
  line-height: 1.35;
}

/* ============================================================
   PAGE HEADER (interior pages)
   ============================================================ */
.page-header {
  padding: 180px 36px 80px;
  position: relative;
  overflow: hidden;
}
/* Variante con video de fondo: hero más grande, alto mínimo para que el
   video respire y la composición sea cinemática. */
.page-header.has-video {
  padding: 220px 36px 140px;
  min-height: 88vh;
  display: flex; align-items: center;
}
.page-header.has-video .inner {
  width: 100%;
}

/* YouTube embebido como background — cubre el hero manteniendo 16:9
   con la técnica clásica: width 100vw, min-width 177.77vh (para que
   cuando el viewport sea más alto que ancho, el iframe siga cubriendo). */
.yt-bg {
  position: absolute; inset: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
}
.yt-bg-iframe {
  position: absolute;
  top: 50%; left: 50%;
  width: 100vw;
  height: 56.25vw;       /* 16:9 a partir del ancho */
  min-width: 177.78vh;   /* 16:9 a partir del alto cuando es portrait */
  min-height: 100%;
  transform: translate(-50%, -50%) scale(1.05); /* +5% para esconder los bordes */
  border: 0;
  pointer-events: none;
}
/* Video background opcional para el page-header (eventos-corporativos, etc.) */
.page-header-video {
  position: absolute; inset: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
}
.page-header-video-el,
.page-header-photo-el {
  position: absolute;
  top: 50%; left: 50%;
  min-width: 100%; min-height: 100%;
  width: 100%; height: 100%;
  transform: translate(-50%, -50%);
  object-fit: cover;
  filter: saturate(1.1) contrast(1.02) brightness(.85);
}
.page-header-video-tint {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 50% 80%, rgba(10,8,7,.35) 0%, rgba(10,8,7,.6) 100%),
    linear-gradient(180deg, rgba(10,8,7,.45) 0%, rgba(10,8,7,.2) 30%, rgba(10,8,7,.85) 100%);
}
.page-header .inner {
  max-width: 1480px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}
.crumb {
  font-family: var(--f-mono); font-size: 11px;
  color: var(--ink-soft); letter-spacing: .14em; text-transform: uppercase;
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 28px;
  padding-left: 24px;
  position: relative;
  line-height: 1.6;
  width: fit-content;
  max-width: 100%;
  white-space: nowrap;
}

/* Wrapper inyectado vía JS cuando hay .crumb seguido de .eyebrow.
   En desktop quedan en la misma línea separados por un gap. En mobile
   cada uno mantiene su línea (column). */
.ph-meta-row { display: flex; flex-direction: column; gap: 0; }
.ph-meta-row .crumb,
.ph-meta-row .eyebrow { margin-bottom: 0; }
@media (min-width: 820px) {
  .ph-meta-row {
    flex-direction: row;
    align-items: center;
    gap: 28px;
    margin-bottom: 28px;
    flex-wrap: wrap;
  }
}
.crumb::before {
  content: ''; position: absolute; left: 0;
  /* Centrado con la PRIMERA línea, no con el bloque completo, para que
     cuando el crumb wrappee a varias líneas el dot quede en la línea 1. */
  top: calc(0.8em - 5px);
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--section-color);
  box-shadow: 0 0 12px var(--section-color);
  animation: blink 2.4s ease-in-out infinite;
}
.crumb a {
  color: var(--ink-2); text-decoration: none;
  transition: color .2s;
}
.crumb a:hover { color: var(--ink); }
.crumb .sep { color: var(--ink-ghost); }

.eyebrow {
  font-family: var(--f-mono); font-size: 11px;
  color: var(--ink-2); letter-spacing: .18em; text-transform: uppercase;
  display: flex; align-items: center; gap: 12px;
  padding-left: 24px;
  position: relative;
  margin-bottom: 24px;
  line-height: 1.6;
  width: fit-content;
  max-width: 100%;
  white-space: nowrap;
}
.eyebrow .live {
  position: absolute; left: 0;
  /* Mismo criterio que .crumb::before — anclado a la primera línea
     para que no se baje cuando el texto wrappee. */
  top: calc(0.8em - 5px);
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--led-lime);
  box-shadow: 0 0 12px var(--led-lime);
  animation: ringPulse 1.6s ease-out infinite;
}

.page-header h1 {
  font-family: var(--f-display);
  font-weight: 500;
  font-size: clamp(48px, 7.5vw, 128px);
  line-height: .92;
  letter-spacing: -0.045em;
  max-width: 22ch;
  font-variation-settings: "wdth" 100, "opsz" 96;
  text-wrap: balance;
}
.page-header h1 em,
.page-header h1 .italic {
  letter-spacing: -0.015em;
}
.page-header .lead {
  margin-top: 32px;
  max-width: 60ch;
}

/* ============================================================
   SECTIONS shared
   ============================================================ */
.section,
.services,
.cases-section,
.brands-section {
  padding: 100px 36px;
  max-width: 1480px;
  margin: 0 auto;
}
.section.alt {
  background: rgba(255,255,255,.015);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  max-width: none;
  padding: 100px 36px;
}
.section.alt > * { max-width: 1480px; margin-left: auto; margin-right: auto; }

.section-head {
  display: flex; justify-content: space-between; align-items: end;
  margin-bottom: 60px; gap: 64px; max-width: 1280px;
}
.section-head > div { flex: 1; }
.section-head h2 {
  font-family: var(--f-display); font-weight: 500;
  font-size: clamp(42px, 6vw, 92px);
  letter-spacing: -0.045em; line-height: .98; margin-top: 18px;
  text-wrap: balance;
  font-variation-settings: "wdth" 100, "opsz" 96;
}
.section-head h2 em,
.section-head h2 .grad,
.section-head h2 .italic {
  color: var(--ink);
  letter-spacing: -0.015em;
}
.section-head > p {
  color: var(--ink-2);
  max-width: 36ch;
  font-size: 16px;
  line-height: 1.5;
}
.section-label, .meta {
  font-family: var(--f-mono); font-size: 11px;
  color: var(--ink-soft); letter-spacing: .18em; text-transform: uppercase;
  display: inline-flex; align-items: center; gap: 12px;
  white-space: nowrap;
}
.section-label .label-led,
.meta::before {
  content: '';
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--section-color);
  box-shadow: 0 0 10px var(--section-color);
  animation: blink 2.4s ease-in-out infinite;
}

/* ============================================================
   BENTO CARDS (home services)
   ============================================================ */
.bento {
  display: grid;
  gap: 16px;
  grid-template-columns: 1.4fr 1fr 1fr;
  /* Filas más bajas para cards físicamente más chicas. El contenido
     mantiene su tamaño legible. */
  grid-template-rows: 260px 230px;
}
.bento.bento-social,
.services:nth-of-type(2) .bento {
  grid-template-columns: 1.6fr 1fr;
  grid-template-rows: 245px 245px;
}

/* ============================================================
   BENTO CORP v2 — featured grande + FdA chica arriba,
   3 cards mini angostas abajo
   ============================================================ */
.bento.bento-corp-v2 {
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  grid-template-rows: 340px 170px !important;
  gap: 14px;
}
.bento.bento-corp-v2 .card { min-width: 0; }
/* Fila 1: featured ocupa 4 cols, side ocupa 2 cols */
.bento-corp-v2 .card-corp-main { grid-column: 1 / 5; grid-row: 1; }
.bento-corp-v2 .card-corp-side { grid-column: 5 / 7; grid-row: 1; }
/* Fila 2: Eventos Virtuales LARGO a la izquierda (4 cols), Híbridos y
   TeamPlay chicos a la derecha (1 col cada uno).
   Order en HTML: TeamPlay(nth=3), Híbridos(nth=4), Virtuales(nth=5).
   Visualmente queremos: Virtuales | Híbridos | TeamPlay. */
.bento-corp-v2 .card-corp-mini:nth-of-type(5) { grid-column: 1 / 5; grid-row: 2; } /* Virtuales izq, ancho */
.bento-corp-v2 .card-corp-mini:nth-of-type(4) { grid-column: 5 / 6; grid-row: 2; } /* Híbridos chico */
.bento-corp-v2 .card-corp-mini:nth-of-type(3) { grid-column: 6 / 7; grid-row: 2; } /* TeamPlay chico */

/* Cards chicas (Híbridos y TeamPlay): ocultar la bajada, solo
   título + flecha para que entre todo. Eventos Virtuales conserva
   la bajada porque tiene 4 cols de ancho. */
.bento-corp-v2 .card-corp-mini:nth-of-type(3) p,
.bento-corp-v2 .card-corp-mini:nth-of-type(4) p { display: none; }
.bento-corp-v2 .card-corp-mini:nth-of-type(3),
.bento-corp-v2 .card-corp-mini:nth-of-type(4) {
  padding: 14px 16px;
}
.bento-corp-v2 .card-corp-mini:nth-of-type(3) h3,
.bento-corp-v2 .card-corp-mini:nth-of-type(4) h3 {
  font-size: clamp(15px, 1.3vw, 19px);
  line-height: 1;
}
/* Las card-corp-mini son angostas en alto, contenido más concentrado */
.card-corp-mini {
  padding: 16px 20px;
  border-radius: 16px;
  position: relative;
}
.card-corp-mini .card-body {
  display: flex; flex-direction: column; gap: 4px;
  height: 100%; justify-content: center;
}
.card-corp-mini h3 {
  font-size: clamp(18px, 1.6vw, 22px);
  margin-top: 4px;
  letter-spacing: -0.025em;
}
.card-corp-mini p {
  font-size: 12.5px; line-height: 1.4;
  color: var(--ink-2);
  margin: 2px 0 0;
}
.card-corp-mini .card-idx {
  font-family: var(--f-mono); font-size: 10px;
  color: var(--ink-soft); letter-spacing: .14em;
}
.card-mini-arrow {
  position: absolute;
  top: 14px; right: 18px;
  font-size: 22px !important;
  line-height: 1;
  color: var(--ink);
  transition: transform .35s var(--ease);
}
.card-corp-mini:hover .card-mini-arrow { transform: translate(4px, -2px); }

.card {
  position: relative;
  border-radius: 20px;
  padding: 22px 24px;
  overflow: hidden;
  text-decoration: none;
  color: var(--ink);
  display: flex; flex-direction: column; justify-content: space-between;
  background: var(--bg-2);
  border: 1px solid var(--line);
  transition: transform .5s var(--ease), border-color .5s;
  isolation: isolate;
}
.card:hover { transform: translateY(-6px); border-color: var(--line-strong); }

.card-aurora {
  position: absolute; inset: -40%; z-index: 0; pointer-events: none;
  background:
    radial-gradient(circle at 25% 30%, var(--c1, #FF2D7F), transparent 40%),
    radial-gradient(circle at 80% 20%, var(--c2, #FFB627), transparent 45%),
    radial-gradient(circle at 50% 90%, var(--c3, #7B4CFF), transparent 45%);
  filter: blur(50px);
  opacity: .65;
  transition: opacity .6s, transform 1.2s var(--ease);
  animation: cardDrift 18s ease-in-out infinite alternate;
}
.card:hover .card-aurora { opacity: 1; transform: scale(1.15); }
@keyframes cardDrift {
  0%   { transform: translate(0,0) rotate(0deg); }
  100% { transform: translate(12%,-8%) rotate(20deg); }
}
.card > *:not(.card-aurora):not(.card-img):not(.card-bg):not(.card-overlay) { position: relative; z-index: 2; }

.card-top { display: flex; justify-content: space-between; align-items: start; }
.card-badge {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--f-mono); font-size: 11px; font-weight: 500;
  letter-spacing: .14em; text-transform: uppercase;
  padding: 8px 14px;
  border: 1px solid rgba(255,255,255,.25);
  background: rgba(0,0,0,.35);
  backdrop-filter: blur(6px);
  border-radius: 999px;
  color: var(--ink);
  width: fit-content;
}
.card-badge .dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--ink);
  box-shadow: 0 0 8px var(--ink);
}
.card-idx, .card-num {
  display: inline-block;
  font-family: var(--f-mono); font-size: 11px;
  letter-spacing: .14em;
  color: var(--ink);
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(0,0,0,.5);
  border: 1px solid rgba(255,255,255,.18);
  backdrop-filter: blur(6px);
  margin-bottom: 14px;
  width: fit-content;
}
.card h3 {
  font-family: var(--f-display); font-weight: 500;
  font-size: clamp(22px, 2.1vw, 30px);
  letter-spacing: -0.03em; line-height: 1.02; margin-top: 8px;
  font-variation-settings: "wdth" 100, "opsz" 96;
}
.card-featured h3, .card.featured h3, .card.featured-social h3 {
  font-size: clamp(26px, 2.8vw, 40px);
}
.card p { font-size: 14px; line-height: 1.5; }
.card h3 em,
.card h3 .grad,
.card h3 .italic {
  letter-spacing: -0.015em;
}
.card p {
  margin-top: 14px;
  color: var(--ink-2); font-size: 14px; line-height: 1.5;
  max-width: 42ch;
}
.card-featured p, .card.featured p, .card.featured-social p { font-size: 15px; }
.card-foot, .card-footer {
  display: flex; justify-content: space-between; align-items: end;
  margin-top: 10px;
}
.tags, .card-tags { display: flex; gap: 6px; flex-wrap: wrap; }
.tags span, .card-tags span {
  font-family: var(--f-mono); font-size: 10.5px;
  color: var(--ink); letter-spacing: .08em;
  padding: 5px 10px;
  border: 1px solid rgba(255,255,255,.25);
  background: rgba(0,0,0,.35);
  border-radius: 999px;
  backdrop-filter: blur(6px);
}
.card .arrow, .card-arrow {
  font-size: 28px; color: var(--ink);
  transition: transform .35s var(--ease);
}
.card:hover .arrow, .card:hover .card-arrow { transform: translate(6px, -2px); }

/* Card CTA — solo en cards featured grandes (botón notable abajo-derecha) */
.card-cta {
  display: inline-flex; align-items: center; gap: 9px;
  background: var(--ink); color: var(--bg);
  padding: 11px 18px; border-radius: 999px;
  font-family: var(--f-display); font-weight: 500; font-size: 13.5px;
  letter-spacing: -0.005em;
  position: relative; overflow: hidden;
  z-index: 1;
  transition: transform .3s var(--ease), padding-right .3s var(--ease);
  box-shadow: 0 8px 24px -8px rgba(0,0,0,.5);
}
.card-cta::after {
  content: ''; position: absolute; inset: 0; border-radius: 999px;
  background: linear-gradient(95deg, var(--accent-from), var(--accent-to));
  opacity: 0; transition: opacity .35s; z-index: -1;
}
.card:hover .card-cta { transform: translateY(-2px); padding-right: 26px; }
.card:hover .card-cta::after { opacity: 1; }
.card-cta .arrow {
  font-size: 18px; color: var(--bg);
  transition: transform .35s var(--ease);
}
.card:hover .card-cta .arrow { transform: translate(4px, -1px); }

.card-featured, .card.featured, .card.featured-social, .card.tall { grid-row: span 2; }
.card-wide, .card.wide { grid-column: span 2; }

/* card-photo / with-photo: image bg + aurora screen */
.card-photo .card-img,
.card.with-photo .card-bg {
  position: absolute; inset: 0; z-index: 0;
  background-size: cover; background-position: center;
  /* Más oscura por default para que el texto sobre la foto siempre
     se lea. brightness 0.42 (antes 0.55) + saturate normal. */
  filter: grayscale(.4) contrast(1.05) brightness(.42);
  transition: filter .6s var(--ease), transform .8s var(--ease);
}
/* Capa adicional de tint gradiente abajo en cards con foto, así los
   textos del card-body y card-foot quedan sobre fondo más oscuro
   independiente de qué muestra la foto. */
.card-photo::after {
  content: '';
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(180deg, rgba(10,10,10,0) 0%, rgba(10,10,10,.15) 35%, rgba(10,10,10,.7) 100%);
  pointer-events: none;
}
.card-photo .card-aurora,
.card.with-photo .card-aurora { mix-blend-mode: screen; opacity: .55; }
.card-photo:hover .card-img,
.card.with-photo:hover .card-bg {
  filter: grayscale(0) contrast(1) brightness(.5);
  transform: scale(1.04);
}
/* Texto blanco bien legible sobre fotos: text-shadow suave + font-weight
   un poco más alto, sin perder el look del diseño. */
.card-photo h3 {
  color: #fff;
  text-shadow: 0 2px 14px rgba(0,0,0,.55);
  font-weight: 600;
}
.card-photo p {
  color: rgba(255,255,255,.95);
  text-shadow: 0 1px 8px rgba(0,0,0,.45);
}
.card-photo:hover .card-aurora,
.card.with-photo:hover .card-aurora { opacity: .55; }
.card-featured .card-aurora,
.card.featured .card-aurora,
.card.featured-social .card-aurora { filter: blur(40px); opacity: .8; }
.card-overlay { display: none; }

/* Auto-assign aurora colors to with-photo cards in legacy markup */
.bento .card.with-photo:nth-of-type(2) { --c1: #FFB627; --c2: #FF6B2E; }
.bento .card.with-photo:nth-of-type(3) { --c1: #C8FF3D; --c2: #00DCC6; }
.bento .card.with-photo:nth-of-type(4) { --c1: #00DCC6; --c2: #2E5BFF; }
.bento .card.with-photo:nth-of-type(5) { --c1: #7B4CFF; --c2: #FF2D7F; }
.bento .card.featured { --c1: #FF2D7F; --c2: #7B4CFF; --c3: #FFB627; }
.bento .card.featured-social { --c1: #FF2D7F; --c2: #7B4CFF; --c3: #00DCC6; }
.bento .card.with-photo { --c3: transparent; }

/* Ensure card content with-photo legacy markup positioned correctly */
.card.with-photo > div { position: relative; z-index: 2; }

/* ============================================================
   CASES grid
   ============================================================ */
.cases-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-template-rows: 260px 260px;
  gap: 16px;
}
.case, .case-card {
  position: relative; overflow: hidden;
  border-radius: 22px;
  text-decoration: none; color: var(--ink);
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 26px;
  border: 1px solid var(--line);
  transition: transform .5s var(--ease);
  isolation: isolate;
}
.case:hover, .case-card:hover { transform: translateY(-6px); }
.case-img, .case-bg {
  position: absolute; inset: 0; z-index: 0;
  background-size: cover; background-position: center;
  transition: transform .8s var(--ease), filter .5s;
  filter: grayscale(1) contrast(1.1) brightness(.85);
}
.case::after, .case-card::after {
  content: ''; position: absolute; inset: 0; z-index: 1;
  background: var(--tint, linear-gradient(135deg, var(--led-pink) 0%, var(--led-violet) 100%));
  mix-blend-mode: screen;
  opacity: .75;
  transition: opacity .5s;
}
.case::before, .case-card::before {
  content: ''; position: absolute; inset: 0; z-index: 2;
  background: linear-gradient(180deg, transparent 35%, rgba(0,0,0,.7) 100%);
}
.case:hover .case-img,
.case-card:hover .case-bg { transform: scale(1.06); filter: grayscale(0) contrast(1) brightness(1); }
.case:hover::after,
.case-card:hover::after { opacity: .15; }

.case .case-content,
.case-card .case-brand,
.case-card h3 { position: relative; z-index: 3; }
.case-brand {
  font-family: var(--f-mono); font-size: 11px; font-weight: 500;
  letter-spacing: .18em; text-transform: uppercase;
  color: var(--ink); opacity: .9; margin-bottom: 10px;
}
.case h3, .case-card h3 {
  font-family: var(--f-display); font-weight: 500;
  font-size: 24px; letter-spacing: -0.03em; line-height: 1.1;
  color: var(--ink);
  text-wrap: balance;
  font-variation-settings: "wdth" 100, "opsz" 96;
}
.case h3 em, .case h3 .grad, .case h3 .italic,
.case-card h3 em, .case-card h3 .grad, .case-card h3 .italic {
  letter-spacing: -0.015em;
}
.case.span-2, .case-card.span-2 { grid-column: span 2; }
.case.span-3, .case-card.span-3 { grid-column: span 3; }
.case.tall,   .case-card.tall   { grid-row: span 2; }
.case-overlay { display: none; }

/* Tint colors for case-card by nth */
.cases-grid .case-card:nth-child(6n+1) { --tint: linear-gradient(135deg, #FF2D7F 0%, #7B4CFF 100%); }
.cases-grid .case-card:nth-child(6n+2) { --tint: linear-gradient(135deg, #FFB627 0%, #FF6B2E 100%); }
.cases-grid .case-card:nth-child(6n+3) { --tint: linear-gradient(135deg, #00DCC6 0%, #2E5BFF 100%); }
.cases-grid .case-card:nth-child(6n+4) { --tint: linear-gradient(135deg, #C8FF3D 0%, #00DCC6 100%); }
.cases-grid .case-card:nth-child(6n+5) { --tint: linear-gradient(135deg, #7B4CFF 0%, #FF2D7F 100%); }
.cases-grid .case-card:nth-child(6n+6) { --tint: linear-gradient(135deg, #FFB627 0%, #FF2D7F 100%); }

/* ============================================================
   FEATURE GRID
   ============================================================ */
.feature-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.feature {
  position: relative;
  border-radius: 24px;
  padding: 36px 30px;
  background: var(--bg-2);
  border: 1px solid var(--line);
  overflow: hidden;
  isolation: isolate;
  min-height: 260px;
  display: flex; flex-direction: column;
  gap: 14px;
  transition: transform .5s var(--ease), border-color .5s;
}
.feature::before {
  content: ''; position: absolute; inset: -40%; z-index: -1;
  background:
    radial-gradient(circle at 25% 30%, var(--c1, var(--section-color)), transparent 45%),
    radial-gradient(circle at 80% 70%, var(--c2, var(--led-violet)), transparent 50%);
  filter: blur(60px);
  opacity: .25;
  transition: opacity .6s, transform 1.2s var(--ease);
  animation: cardDrift 22s ease-in-out infinite alternate;
}
.feature:hover {
  transform: translateY(-4px);
  border-color: var(--line-strong);
}
.feature:hover::before { opacity: .55; transform: scale(1.1); }
.feature .num {
  font-family: var(--f-mono); font-size: 10px;
  color: var(--ink-soft); letter-spacing: .14em; text-transform: uppercase;
}
.feature h3 {
  font-family: var(--f-display); font-weight: 500;
  font-size: clamp(22px, 2.4vw, 32px);
  letter-spacing: -0.035em; line-height: 1.05;
  font-variation-settings: "wdth" 100, "opsz" 96;
  margin-top: 4px;
}
.feature h3 em,
.feature h3 .grad,
.feature h3 .italic {
  letter-spacing: -0.015em;
  color: var(--ink);
}
.feature p {
  color: var(--ink-2); font-size: 14px; line-height: 1.5;
  max-width: 42ch;
}

.feature-grid .feature:nth-child(7n+1) { --c1: var(--led-pink);    --c2: var(--led-violet); }
.feature-grid .feature:nth-child(7n+2) { --c1: var(--led-amber);   --c2: var(--led-orange); }
.feature-grid .feature:nth-child(7n+3) { --c1: var(--led-cyan);    --c2: var(--led-cobalt); }
.feature-grid .feature:nth-child(7n+4) { --c1: var(--led-lime);    --c2: var(--led-cyan); }
.feature-grid .feature:nth-child(7n+5) { --c1: var(--led-violet);  --c2: var(--led-pink); }
.feature-grid .feature:nth-child(7n+6) { --c1: var(--led-orange);  --c2: var(--led-amber); }
.feature-grid .feature:nth-child(7n+7) { --c1: var(--led-pink);    --c2: var(--led-cyan); }

/* ============================================================
   SERVICES GRID
   ============================================================ */
.services-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.svc-card {
  position: relative;
  border-radius: 22px;
  padding: 28px 24px;
  background: var(--bg-2);
  border: 1px solid var(--line);
  display: flex; flex-direction: column;
  gap: 14px;
  min-height: 220px;
  transition: transform .4s var(--ease), border-color .4s, background .4s;
  overflow: hidden;
  isolation: isolate;
}
.svc-card::before {
  content: ''; position: absolute; inset: -40%; z-index: -1;
  background:
    radial-gradient(circle at 25% 30%, var(--c1, var(--section-color)), transparent 45%),
    radial-gradient(circle at 80% 70%, var(--c2, var(--led-violet)), transparent 50%);
  filter: blur(60px);
  opacity: .25;
  transition: opacity .6s, transform 1.2s var(--ease);
  animation: cardDrift 22s ease-in-out infinite alternate;
}
.svc-card:hover {
  transform: translateY(-4px);
  border-color: var(--line-strong);
  background: rgba(255,255,255,.025);
}
.svc-card:hover::before { opacity: .55; transform: scale(1.1); }

/* Lógica INVERTIDA en .section.alt (sólo aplicable al módulo de
   'Tipos de evento' en eventos-corporativos): las cards arrancan
   con la luz LED encendida fuerte y se CALMAN al hover. Sirve para
   diferenciar visualmente este módulo del de 'Nuestros servicios'
   que está en la misma página con la lógica normal. */
.section.alt .svc-card::before { opacity: .55; transform: scale(1.05); }
.section.alt .svc-card:hover::before { opacity: .2; transform: scale(1); }
.svc-card .icon-wrap {
  width: 56px; height: 56px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 14px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--line);
}
.svc-card .icon-wrap img {
  width: 36px; height: 36px;
  object-fit: contain;
  filter: brightness(0) invert(1) opacity(.85);
}
.svc-card h3 {
  font-family: var(--f-display); font-weight: 500;
  font-size: 18px;
  letter-spacing: -0.025em; line-height: 1.15;
  font-variation-settings: "wdth" 100, "opsz" 96;
}
.svc-card p {
  font-family: var(--f-display); font-weight: 400;
  color: var(--ink-2); font-size: 13px; line-height: 1.5;
}

/* Pares de luces LED — siguen la misma lógica que .feature pero por
   ciclo de 8 cards (la sección de servicios tiene más cards). Cada par
   crea un aurora distinto en cada tarjeta para variar el ambiente. */
.services-grid .svc-card:nth-child(8n+1) { --c1: var(--led-pink);    --c2: var(--led-violet); }
.services-grid .svc-card:nth-child(8n+2) { --c1: var(--led-amber);   --c2: var(--led-orange); }
.services-grid .svc-card:nth-child(8n+3) { --c1: var(--led-cyan);    --c2: var(--led-cobalt); }
.services-grid .svc-card:nth-child(8n+4) { --c1: var(--led-violet);  --c2: var(--led-pink); }
.services-grid .svc-card:nth-child(8n+5) { --c1: var(--led-lime);    --c2: var(--led-cyan); }
.services-grid .svc-card:nth-child(8n+6) { --c1: var(--led-orange);  --c2: var(--led-amber); }
.services-grid .svc-card:nth-child(8n+7) { --c1: var(--led-cobalt);  --c2: var(--led-violet); }
.services-grid .svc-card:nth-child(8n+8) { --c1: var(--led-pink);    --c2: var(--led-cyan); }

/* ============================================================
   SPLIT SECTION
   ============================================================ */
.split-section {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 64px;
  align-items: center;
  padding: 100px 36px;
  max-width: 1480px;
  margin: 0 auto;
}
.split-text .meta { margin-bottom: 16px; }
.split-text h2 {
  font-family: var(--f-display); font-weight: 500;
  font-size: clamp(36px, 5vw, 72px);
  letter-spacing: -0.045em; line-height: 1;
  font-variation-settings: "wdth" 100, "opsz" 96;
  margin-bottom: 24px;
  text-wrap: balance;
}
.split-text h2 em,
.split-text h2 .grad,
.split-text h2 .italic {
  color: var(--ink); letter-spacing: -0.015em;
}
.split-text p {
  color: var(--ink-2); font-size: 17px; line-height: 1.55;
  max-width: 56ch;
  margin-bottom: 16px;
}
.split-media {
  position: relative;
  border-radius: 28px;
  overflow: hidden;
  background: var(--bg-2);
  border: 1px solid var(--line);
  min-height: 400px;
  display: flex; align-items: center; justify-content: center;
  padding: 40px;
  isolation: isolate;
}
.split-media::before {
  content: ''; position: absolute; inset: -30%;
  background:
    radial-gradient(circle at 30% 30%, var(--led-pink), transparent 45%),
    radial-gradient(circle at 70% 70%, var(--led-violet), transparent 45%);
  filter: blur(60px);
  opacity: .5;
  z-index: -1;
  animation: cardDrift 18s ease-in-out infinite alternate;
}
.split-media img {
  max-width: 100%; max-height: 100%;
  object-fit: contain;
}

/* Variante "clean": split-section sin auroras detrás del texto, sobre fondo
   negro plano para que la lectura tenga máximo contraste. */
.split-section.split-clean {
  background: var(--bg);
  position: relative;
  z-index: 1;
  border-radius: 28px;
}

/* Variante "cover" del media: imagen como fondo full bleed, sin aurora interno
   ni padding alrededor de la imagen. */
.split-media.split-media-cover {
  padding: 0;
  background: var(--bg-2);
}
.split-media.split-media-cover::before {
  display: none;
}
.split-media.split-media-cover img {
  width: 100%;
  height: 100%;
  max-width: none; max-height: none;
  object-fit: cover;
  position: absolute;
  inset: 0;
}

/* ============================================================
   BRANDS — marquee
   ============================================================ */
.brands-section { padding-bottom: 140px; }
.brands-head {
  text-align: center;
  max-width: 900px; margin: 0 auto 56px;
}
.brands-head h2 {
  font-family: var(--f-display); font-weight: 500;
  font-size: clamp(36px, 4.5vw, 64px);
  letter-spacing: -0.045em; line-height: 1.05;
  text-wrap: balance;
  font-variation-settings: "wdth" 100, "opsz" 96;
}
.brands-head h2 em,
.brands-head h2 .grad,
.brands-head h2 .italic {
  color: var(--ink);
  letter-spacing: -0.015em;
}
.brands-head p {
  font-family: var(--f-mono); font-size: 12px;
  color: var(--ink-soft); text-transform: uppercase; letter-spacing: .14em;
  margin-top: 14px;
  white-space: nowrap;
}

.marquee,
.logos-marquee {
  overflow-x: hidden;
  overflow-y: visible;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%);
  mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%);
  margin: 0 -36px;
  padding: 8px 0; /* espacio para hover lift sin recortarse */
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.marquee-track,
.logos-row .logos-track {
  display: flex; gap: 16px; width: max-content;
  animation: scrollX 60s linear infinite;
}
.logos-row { overflow-x: hidden; overflow-y: visible; }
.logos-row[data-dir="right"] .logos-track,
.marquee-track.marquee-reverse {
  animation: scrollXR 70s linear infinite;
}
.logos-row .logos-track { animation-duration: var(--dur, 60s); }
@keyframes scrollX  { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@keyframes scrollXR { from { transform: translateX(-50%); } to { transform: translateX(0); } }
.marquee:hover .marquee-track,
.logos-marquee:hover .logos-track { animation-play-state: paused; }

.logo-tile {
  flex: 0 0 auto;
  width: 200px; height: 100px;
  display: flex; align-items: center; justify-content: center;
  padding: 18px 24px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(255,255,255,.025);
  position: relative;
  overflow: hidden;
  transition: border-color .35s, background .35s, transform .35s;
}
.logo-tile img {
  max-width: 100%; max-height: 100%;
  object-fit: contain;
  filter: brightness(0) invert(1);
  opacity: .55;
  transition: filter .4s, opacity .4s;
}
.logo-tile::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse 70% 90% at 50% 50%, var(--glow-c, var(--led-pink)) 0%, transparent 70%);
  opacity: 0; transition: opacity .35s;
}
.logo-tile:hover { border-color: var(--glow-c, var(--led-pink)); background: rgba(255,255,255,.04); transform: translateY(-2px); }
.logo-tile:hover::before { opacity: .18; }
.logo-tile:hover img { filter: brightness(0) invert(1) drop-shadow(0 0 6px var(--glow-c, var(--led-pink))); opacity: 1; }

/* ============================================================
   PRESS section
   ============================================================ */
.press-cat { margin-bottom: 100px; max-width: 1480px; margin-left: auto; margin-right: auto; }
.press-cat:last-child { margin-bottom: 0; }
.press-cat-head {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 36px;
  gap: 24px;
  flex-wrap: wrap;
}
.press-cat-head h2 {
  font-family: var(--f-display); font-weight: 500;
  font-size: clamp(32px, 4vw, 56px);
  letter-spacing: -0.045em; line-height: 1;
  font-variation-settings: "wdth" 100, "opsz" 96;
}
.press-cat-head h2 em,
.press-cat-head h2 .grad,
.press-cat-head h2 .italic {
  color: var(--ink);
  letter-spacing: -0.015em;
}
.press-cat-head .count {
  font-family: var(--f-mono); font-size: 11px;
  color: var(--ink-soft); letter-spacing: .14em; text-transform: uppercase;
}
.press-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.press-card {
  position: relative;
  border-radius: 18px;
  overflow: hidden;
  background: var(--bg-2);
  border: 1px solid var(--line);
  text-decoration: none;
  color: var(--ink);
  display: flex; flex-direction: column;
  transition: transform .4s var(--ease), border-color .4s;
}
.press-card:hover {
  transform: translateY(-4px);
  border-color: var(--line-strong);
}
.press-card .img-wrap {
  aspect-ratio: 4/3;
  overflow: hidden;
  background: rgba(255,255,255,.02);
}
.press-card .img-wrap img {
  width: 100%; height: 100%; object-fit: cover;
  filter: grayscale(.4) contrast(1.05);
  transition: filter .5s, transform .8s var(--ease);
}
.press-card:hover .img-wrap img {
  filter: grayscale(0);
  transform: scale(1.05);
}
.press-card .body {
  padding: 18px 18px 22px;
  display: flex; flex-direction: column; gap: 4px;
}
.press-card .body strong {
  font-family: var(--f-display); font-weight: 500;
  font-size: 15px;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.press-card .body span {
  font-family: var(--f-display); font-weight: 400;
  font-size: 13px;
  color: var(--ink-soft);
  line-height: 1.4;
}

/* ============================================================
   POSTS (blog)
   ============================================================ */
.posts-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}
.post-card {
  border-radius: 22px;
  overflow: hidden;
  background: var(--bg-2);
  border: 1px solid var(--line);
  text-decoration: none;
  color: var(--ink);
  display: flex; flex-direction: column;
  transition: transform .4s var(--ease), border-color .4s;
}
.post-card:hover {
  transform: translateY(-4px);
  border-color: var(--line-strong);
}
.post-card .img-wrap {
  aspect-ratio: 16/9;
  overflow: hidden;
  background: rgba(255,255,255,.02);
}
.post-card .img-wrap img {
  width: 100%; height: 100%; object-fit: cover;
  filter: grayscale(.3) contrast(1.05);
  transition: filter .5s, transform .8s var(--ease);
}
.post-card:hover .img-wrap img {
  filter: grayscale(0);
  transform: scale(1.04);
}
.post-card .body {
  padding: 28px;
  display: flex; flex-direction: column; gap: 14px;
}
.post-card .body .meta {
  color: var(--ink-soft);
}
.post-card .body h3 {
  font-family: var(--f-display); font-weight: 500;
  font-size: clamp(24px, 2.4vw, 32px);
  letter-spacing: -0.035em; line-height: 1.1;
  font-variation-settings: "wdth" 100, "opsz" 96;
}
.post-card .body p {
  font-family: var(--f-display); font-weight: 400;
  color: var(--ink-2); font-size: 15px; line-height: 1.55;
}

/* ============================================================
   FORM (contacto)
   ============================================================ */
.form-section {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 56px;
  align-items: start;
  padding: 80px 36px 120px;
  max-width: 1480px;
  margin: 0 auto;
}
.form-wrap {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: 28px;
  padding: 48px;
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.form-wrap::before {
  content: ''; position: absolute; inset: -30%;
  background:
    radial-gradient(circle at 20% 20%, var(--led-pink), transparent 50%),
    radial-gradient(circle at 80% 80%, var(--led-violet), transparent 50%);
  filter: blur(80px);
  opacity: .25;
  z-index: -1;
  animation: cardDrift 22s ease-in-out infinite alternate;
}
.form-wrap h3 {
  font-family: var(--f-display); font-weight: 500;
  font-size: clamp(28px, 3vw, 42px);
  letter-spacing: -0.035em; line-height: 1.05;
  font-variation-settings: "wdth" 100, "opsz" 96;
}
.form-wrap h3 .grad,
.form-wrap h3 em {
  color: var(--ink); letter-spacing: -0.015em;
}
.form-wrap .hint {
  font-family: var(--f-mono); font-size: 11px;
  color: var(--ink-soft); letter-spacing: .14em; text-transform: uppercase;
  margin-top: 14px;
}
.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin-top: 32px;
}
.form-field { display: flex; flex-direction: column; gap: 8px; }
.form-field.full { grid-column: span 2; }
.form-field label {
  font-family: var(--f-mono); font-size: 10px;
  color: var(--ink-soft); letter-spacing: .14em; text-transform: uppercase;
}
.form-field input,
.form-field select,
.form-field textarea {
  background: rgba(10,8,7,.4);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 14px 16px;
  color: var(--ink);
  font-family: var(--f-display); font-size: 15px;
  transition: border-color .25s, background .25s, box-shadow .25s;
  width: 100%;
}
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus {
  outline: none;
  border-color: var(--led-pink);
  background: rgba(10,8,7,.7);
  box-shadow: 0 0 0 3px rgba(255,45,127,.18);
}
.form-field textarea {
  resize: vertical;
  min-height: 100px;
}
.form-submit { margin-top: 28px; }
.form-submit button {
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--ink); color: var(--bg);
  padding: 18px 28px; border-radius: 999px;
  text-decoration: none; font-weight: 500; font-size: 16px;
  font-family: var(--f-display);
  border: none;
  cursor: pointer;
  transition: transform .3s var(--ease), padding-right .3s var(--ease);
  position: relative; overflow: hidden;
}
.form-submit button::after {
  content: ''; position: absolute; inset: 0; border-radius: 999px;
  background: linear-gradient(95deg, var(--accent-from), var(--accent-to));
  opacity: 0; transition: opacity .35s; z-index: -1;
}
.form-submit button:hover { transform: translateY(-2px); padding-right: 36px; }
.form-submit button:hover::after { opacity: 1; }
.form-extra {
  font-family: var(--f-mono); font-size: 11px;
  color: var(--ink-soft); letter-spacing: .12em; text-transform: uppercase;
  margin-top: 16px;
}
.honey { position: absolute; left: -9999px; }

.contact-info {
  display: flex; flex-direction: column;
  gap: 14px;
}
.info-card {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 22px 24px;
  display: flex; flex-direction: column; gap: 6px;
}
.info-card .label {
  font-family: var(--f-mono); font-size: 10px;
  color: var(--ink-soft); letter-spacing: .18em; text-transform: uppercase;
}
.info-card .val {
  font-family: var(--f-display); font-weight: 500; font-size: 17px;
  letter-spacing: -0.015em;
}
.info-card .val a {
  color: var(--ink); text-decoration: none;
  transition: color .25s;
}
.info-card .val a:hover { color: var(--led-pink); }

/* ============================================================
   CTA BAND
   ============================================================ */
.cta-band {
  text-align: center;
  padding: 120px 36px;
  position: relative;
  overflow: hidden;
  isolation: isolate;
  max-width: 1480px;
  margin: 0 auto;
}
.cta-band::before {
  content: ''; position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: clamp(400px, 60vw, 800px); aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 30%, var(--led-pink), transparent 50%),
    radial-gradient(circle at 70% 70%, var(--led-violet), transparent 50%),
    radial-gradient(circle at 50% 50%, var(--led-cyan), transparent 60%);
  filter: blur(80px);
  opacity: .4;
  z-index: -1;
  animation: drift1 30s ease-in-out infinite alternate;
}
.cta-band h2 {
  font-family: var(--f-display); font-weight: 500;
  font-size: clamp(36px, 5vw, 72px);
  letter-spacing: -0.045em; line-height: 1;
  font-variation-settings: "wdth" 100, "opsz" 96;
  text-wrap: balance;
  max-width: 22ch;
  margin: 0 auto;
}
.cta-band h2 em,
.cta-band h2 .grad,
.cta-band h2 .italic {
  color: var(--ink); letter-spacing: -0.015em;
}
.cta-band .cta-row {
  justify-content: center;
  margin-top: 40px;
}

/* ============================================================
   CLOSING
   ============================================================ */
.closing {
  padding: 180px 36px 200px;
  text-align: center;
  position: relative;
  overflow: hidden;
  max-width: none;
}
/* Closing con foto de fondo (oficina / espacio WonderLab) */
.closing.has-photo {
  background-size: cover;
  background-position: center;
}
.closing-photo-tint {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(10,10,10,.75) 0%, rgba(10,10,10,.6) 50%, rgba(10,10,10,.9) 100%),
    linear-gradient(135deg, rgba(255,45,127,.18) 0%, rgba(123,76,255,.18) 50%, rgba(34,225,255,.12) 100%);
  z-index: 0;
}
.closing.has-photo .closing-quote,
.closing.has-photo .cta-row { position: relative; z-index: 1; }
.closing-aurora {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: clamp(580px, 75vw, 1100px); aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(circle at 25% 30%, var(--led-pink), transparent 50%),
    radial-gradient(circle at 75% 30%, var(--led-amber), transparent 50%),
    radial-gradient(circle at 80% 75%, var(--led-cyan), transparent 50%),
    radial-gradient(circle at 25% 75%, var(--led-violet), transparent 50%),
    radial-gradient(circle at 50% 50%, var(--led-lime), transparent 60%);
  filter: blur(90px);
  opacity: .55;
  z-index: 0;
  animation: drift1 26s ease-in-out infinite alternate;
}
.closing-quote {
  position: relative; z-index: 1;
  font-family: var(--f-display); font-weight: 500;
  font-size: clamp(40px, 5.5vw, 92px);
  letter-spacing: -0.045em; line-height: 1.02;
  max-width: 22ch; margin: 0 auto;
  text-wrap: balance;
  font-variation-settings: "wdth" 100, "opsz" 96;
}
.closing-quote em,
.closing-quote .grad,
.closing-quote .italic {
  color: var(--ink);
  letter-spacing: -0.015em;
}
.closing .cta-row {
  justify-content: center;
  margin-top: 56px;
  position: relative; z-index: 1;
}

/* ============================================================
   FOOTER
   ============================================================ */
footer.foot {
  padding: 50px 36px 36px;
  border-top: 1px solid var(--line);
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 24px;
  font-family: var(--f-mono); font-size: 11px;
  color: var(--ink-soft); letter-spacing: .06em;
}
footer.foot .left, footer.foot .right { display: flex; align-items: center; gap: 14px; }
footer.foot .foot-nav { display: flex; gap: 22px; flex-wrap: wrap; }
footer.foot .foot-nav a {
  color: var(--ink-2); text-decoration: none; font-size: 13px;
  transition: color .25s;
}
footer.foot .foot-nav a:hover { color: var(--led-pink); }

/* ============================================================
   CASES SECTION (eventos-corporativos)
   ============================================================ */
.case-studies {
  padding: 120px 80px 96px;
  position: relative;
}
/* ============================================================
   CASES ACCORDION (home) — 6 strips, hover expande la elegida
   ============================================================ */
.cases-accordion {
  display: flex;
  gap: 8px;
  height: 460px;
  margin-top: 8px;
}
.case-strip {
  position: relative;
  flex: 1; min-width: 0;
  border-radius: 18px;
  overflow: hidden;
  text-decoration: none;
  background-size: cover; background-position: center;
  border: 1px solid var(--line);
  transition: flex .55s var(--ease, cubic-bezier(.2,.8,.2,1)),
              border-color .35s, box-shadow .45s;
  display: flex; align-items: flex-end;
  cursor: pointer;
}
.cases-accordion:hover .case-strip { flex: 0.55; }
.cases-accordion .case-strip:hover {
  flex: 3.4;
  border-color: var(--c1, var(--ink));
  box-shadow: 0 30px 60px -20px rgba(0,0,0,.6),
              0 0 0 1px var(--c1, transparent);
}
.case-strip-tint {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(10,10,10,.05) 0%, rgba(10,10,10,.4) 50%, rgba(10,10,10,.92) 100%),
    linear-gradient(135deg, color-mix(in srgb, var(--c1,#000) 22%, transparent) 0%, color-mix(in srgb, var(--c2,#000) 18%, transparent) 100%);
  pointer-events: none;
  transition: opacity .45s;
}
.case-strip:hover .case-strip-tint { opacity: .75; }
.case-strip-meta {
  position: relative; z-index: 1;
  padding: 22px 24px;
  color: #fff;
  width: 100%;
}
.case-strip-brand {
  font-family: var(--f-mono); font-size: 11px;
  letter-spacing: .14em; text-transform: uppercase;
  color: rgba(255,255,255,.75);
  margin-bottom: 6px;
  transition: color .35s;
}
.case-strip:hover .case-strip-brand { color: rgba(255,255,255,.95); }
.case-strip-title {
  font-family: var(--f-display); font-weight: 500;
  font-size: clamp(18px, 1.8vw, 26px);
  line-height: 1.1; letter-spacing: -0.025em;
  color: #fff;
  max-width: 22ch;
  margin: 0;
  text-wrap: balance;
  opacity: 0; transform: translateY(8px);
  transition: opacity .35s ease .1s, transform .4s var(--ease, cubic-bezier(.2,.8,.2,1)) .1s;
}
.case-strip-title em,
.case-strip-title .grad,
.case-strip-title .italic {
  letter-spacing: -0.005em;
  color: #fff;
}
.case-strip:hover .case-strip-title { opacity: 1; transform: translateY(0); }

@media (max-width: 800px) {
  .cases-accordion {
    flex-wrap: wrap;
    height: auto;
  }
  .case-strip {
    flex: 1 1 calc(50% - 4px);
    aspect-ratio: 4/3;
  }
  .cases-accordion:hover .case-strip { flex: 1 1 calc(50% - 4px); }
  .cases-accordion .case-strip:hover { flex: 1 1 calc(50% - 4px); }
  .case-strip-title { opacity: 1; transform: none; }
}

/* CTA bajo el bloque de cases en home */
.cases-cta {
  margin-top: 36px; display: flex; justify-content: flex-end;
}
.cases-cta-link {
  font-family: var(--f-display); font-weight: 500;
  font-size: 16px; color: var(--ink);
  display: inline-flex; align-items: center; gap: 10px;
  padding: 12px 4px;
  border-bottom: 1px solid var(--line);
  transition: border-color .3s, gap .3s;
}
.cases-cta-link .arrow {
  font-size: 22px; line-height: 1;
  transition: transform .3s var(--ease);
}
.cases-cta-link:hover { border-color: var(--ink); gap: 16px; }
.cases-cta-link:hover .arrow { transform: translate(4px, -2px); }

.cs-head { max-width: 880px; margin-bottom: 56px; }
.cs-head .meta {
  font-family: var(--f-mono); font-size: 12px;
  color: var(--ink-soft); letter-spacing: .14em; text-transform: uppercase;
}
.cs-head h2 {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(40px, 5vw, 64px); letter-spacing: -0.02em;
  line-height: 1.02; color: var(--ink);
}
.cs-head .cs-lead {
  margin-top: 16px; font-size: 18px; line-height: 1.5;
  color: var(--ink-soft); max-width: 640px;
}
.cs-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.cs-card {
  position: relative;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--line);
  border-radius: 22px;
  overflow: hidden;
  cursor: pointer;
  transition: transform .45s var(--ease), border-color .35s, box-shadow .45s;
  display: flex; flex-direction: column;
}
.cs-card:hover {
  transform: translateY(-6px);
  border-color: var(--c1, var(--ink));
  box-shadow: 0 24px 48px -16px rgba(0,0,0,.55),
              0 0 0 1px var(--c1, var(--ink)),
              0 12px 32px -12px var(--c1, transparent);
}
.cs-card.is-hidden { display: none; }

.cs-card-img {
  position: relative;
  aspect-ratio: 16/10;
  background-size: cover; background-position: center;
  overflow: hidden;
}
.cs-card-img-tint {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(10,10,10,.2) 0%, rgba(10,10,10,.55) 100%),
    linear-gradient(135deg, color-mix(in srgb, var(--c1, #000) 28%, transparent) 0%, color-mix(in srgb, var(--c2, #000) 22%, transparent) 100%);
  pointer-events: none;
  transition: opacity .45s;
}
.cs-card:hover .cs-card-img-tint { opacity: .75; }
.cs-card-logo-wrap {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  z-index: 2;
}
.cs-card-logo {
  max-width: 200px; max-height: 70px;
  width: auto; height: auto;
  filter: brightness(0) invert(1) drop-shadow(0 6px 20px rgba(0,0,0,.7));
  transition: transform .5s var(--ease);
}
.cs-card:hover .cs-card-logo { transform: scale(1.06); }
.cs-card-arrow {
  position: absolute; top: 16px; right: 18px;
  width: 36px; height: 36px;
  background: rgba(0,0,0,.65); color: #fff;
  display: flex; align-items: center; justify-content: center;
  border-radius: 999px; font-size: 16px;
  border: 1px solid rgba(255,255,255,.22);
  backdrop-filter: blur(6px);
  z-index: 3;
  transition: transform .3s var(--ease), background .3s;
}
.cs-card:hover .cs-card-arrow {
  transform: translate(2px, -2px);
  background: var(--c1, var(--ink));
  border-color: var(--c1, var(--ink));
}

.cs-card-body { padding: 24px 26px 28px; flex: 1; display: flex; flex-direction: column; }
.cs-card-eyebrow {
  font-family: var(--f-mono); font-size: 11px;
  color: rgba(255,255,255,.7); letter-spacing: .12em; text-transform: uppercase;
  margin-bottom: 12px;
}
.cs-card-title {
  font-family: var(--f-display); font-weight: 600;
  font-size: 21px; line-height: 1.2; letter-spacing: -0.015em;
  color: #fff; margin: 0 0 14px;
}
.cs-card-summary {
  font-size: 14.5px; line-height: 1.6;
  color: rgba(255,255,255,.82);
  margin: 0 0 20px;
}
.cs-card-tags {
  margin-top: auto;
  display: flex; flex-wrap: wrap; gap: 6px;
}
.cs-tag {
  font-family: var(--f-mono); font-size: 11px;
  padding: 4px 10px; border-radius: 999px;
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.85);
  letter-spacing: .04em;
}

/* MODAL */
.cs-modal {
  position: fixed; inset: 0; z-index: 9999;
  opacity: 0; pointer-events: none;
  transition: opacity .35s ease;
}
.cs-modal.is-open { opacity: 1; pointer-events: auto; }
.cs-modal-backdrop {
  position: absolute; inset: 0;
  background: rgba(0,0,0,.78);
  backdrop-filter: blur(8px);
}
.cs-modal-shell {
  position: relative;
  width: min(960px, 92vw);
  max-height: 88vh;
  margin: 6vh auto 0;
  background: #0e0e0e;
  border: 1px solid var(--line);
  border-radius: 20px;
  overflow: hidden;
  display: flex; flex-direction: column;
  transform: translateY(20px) scale(.98);
  transition: transform .4s var(--ease);
}
.cs-modal.is-open .cs-modal-shell { transform: translateY(0) scale(1); }
.cs-modal-close {
  position: absolute; top: 14px; right: 16px; z-index: 5;
  width: 38px; height: 38px;
  background: rgba(0,0,0,.55); color: #fff;
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 999px; font-size: 22px; line-height: 1;
  cursor: pointer;
  backdrop-filter: blur(8px);
  transition: background .25s, transform .25s;
}
.cs-modal-close:hover { background: var(--led-pink); transform: rotate(90deg); }
.cs-modal-content { overflow-y: auto; flex: 1; }

.cs-modal-hero {
  position: relative;
  background-size: cover; background-position: center;
  padding: 64px 56px 56px;
  min-height: 420px;
  display: flex; flex-direction: column; justify-content: flex-end;
  overflow: hidden;
}
.cs-modal-hero::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg, color-mix(in srgb, var(--c1, #000) 24%, transparent) 0%, color-mix(in srgb, var(--c2, #000) 18%, transparent) 100%);
  z-index: 1;
}
.cs-modal-hero::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(10,10,10,.1) 0%, rgba(10,10,10,.35) 50%, rgba(10,10,10,.9) 100%);
  z-index: 1;
}
.cs-modal-hero-logo {
  position: absolute; top: 32px; left: 56px;
  z-index: 2;
  padding: 14px 22px;
  background: rgba(0,0,0,.5);
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 14px;
  backdrop-filter: blur(10px);
}
.cs-modal-hero-logo img {
  max-width: 140px; max-height: 50px;
  display: block;
  filter: brightness(0) invert(1);
}
.cs-modal-hero-inner { position: relative; z-index: 2; max-width: 760px; }
.cs-modal-eyebrow {
  font-family: var(--f-mono); font-size: 11px;
  letter-spacing: .14em; text-transform: uppercase;
  color: rgba(255,255,255,.85); margin-bottom: 12px;
}
.cs-modal-title {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(26px, 3.2vw, 38px); line-height: 1.1; letter-spacing: -0.02em;
  color: #fff; margin: 0;
  text-shadow: 0 2px 18px rgba(0,0,0,.45);
}
.cs-modal-meta {
  padding: 18px 56px;
  border-bottom: 1px solid var(--line);
}
.cs-modal-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.cs-modal-tag {
  font-family: var(--f-mono); font-size: 11px;
  padding: 5px 12px; border-radius: 999px;
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.85);
  letter-spacing: .04em;
}
.cs-modal-body { padding: 36px 56px 44px; display: flex; flex-direction: column; gap: 36px; }
.cs-modal-section { display: flex; flex-direction: column; gap: 14px; }
.cs-modal-h {
  font-family: var(--f-mono); font-size: 11px;
  color: rgba(255,255,255,.6); letter-spacing: .14em; text-transform: uppercase;
}
.cs-modal-section p {
  font-size: 16px; line-height: 1.6;
  color: rgba(255,255,255,.95);
  margin: 0;
}
.cs-svc-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 18px; }
.cs-svc {
  display: flex; gap: 18px;
  padding: 18px 20px;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--line);
  border-radius: 14px;
  transition: border-color .3s, transform .3s;
}
.cs-svc:hover { border-color: rgba(255,255,255,.25); transform: translateX(4px); }
.cs-svc-icon {
  font-size: 28px; line-height: 1;
  flex: 0 0 auto;
  width: 48px; height: 48px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,.06);
  border-radius: 12px;
}
.cs-svc-name {
  font-family: var(--f-display); font-weight: 600;
  font-size: 16px; letter-spacing: -0.01em;
  color: #fff; margin-bottom: 6px;
}
.cs-svc-desc { font-size: 14.5px; line-height: 1.6; color: rgba(255,255,255,.82); }

.cs-modal-nav {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 24px;
  border-top: 1px solid var(--line);
  background: rgba(0,0,0,.4);
}
.cs-nav-btn {
  background: transparent; color: var(--ink);
  border: 1px solid var(--line);
  padding: 9px 16px; border-radius: 999px;
  font-family: var(--f-display); font-weight: 500; font-size: 13px;
  cursor: pointer;
  transition: border-color .25s, background .25s;
}
.cs-nav-btn:hover { border-color: var(--ink); background: rgba(255,255,255,.04); }
.cs-nav-indicator {
  font-family: var(--f-mono); font-size: 12px;
  color: var(--ink-soft); letter-spacing: .08em;
}

/* ============================================================
   CONTACT MODAL (Corp + Social toggle)
   ============================================================ */
.ct-modal {
  position: fixed; inset: 0; z-index: 9998;
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  padding-top: max(24px, env(safe-area-inset-top, 0px) + 24px);
  padding-bottom: max(24px, env(safe-area-inset-bottom, 0px) + 16px);
}
.ct-modal[hidden] { display: none; }
.ct-modal-overlay {
  position: absolute; inset: 0;
  background: rgba(8,6,5,.55);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  animation: wlFadeIn .3s ease;
}
@keyframes ctSlideUp {
  from { transform: translateY(28px) scale(.98); opacity: 0; }
  to   { transform: translateY(0)    scale(1);   opacity: 1; }
}
@keyframes ctRainbow {
  0%   { background-position:   0% 50%; }
  100% { background-position: 300% 50%; }
}
.ct-modal-shell {
  position: relative;
  width: min(880px, 100%);
  max-height: calc(100vh - 48px);
  border-radius: 20px;
  overflow: hidden;
  /* Filete bi-color animado alrededor del modal. Los colores rotan según
     el toggle Corp/Social (ver .is-corp / .is-social más abajo). */
  padding: 2px;
  background:
    linear-gradient(135deg,
      var(--accent-from) 0%,
      var(--accent-to) 50%,
      var(--accent-from) 100%);
  background-size: 250% 100%;
  animation: ctSlideUp .4s cubic-bezier(.2,.8,.2,1), ctRainbow 6s linear infinite;
  box-shadow:
    0 30px 80px -20px rgba(255,45,127,.3),
    0 18px 48px -16px rgba(123,76,255,.25),
    0 6px 24px -10px rgba(34,225,255,.18);
}
.ct-modal-shell::before {
  /* Capa interna oscura — el background gradient se ve solo en el borde */
  content: '';
  position: absolute; inset: 2px;
  background: #0e0e0e;
  border-radius: 18px;
  z-index: 0;
}
.ct-modal-close {
  position: absolute;
  top: max(16px, env(safe-area-inset-top, 0px) + 8px);
  right: 16px; z-index: 5;
  width: 44px; height: 44px;
  background: rgba(255,255,255,.08); color: #fff;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .25s, transform .25s;
}
.ct-modal-close:hover { background: rgba(255,255,255,.16); transform: rotate(90deg); }

.ct-modal-grid {
  position: relative; z-index: 1;
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  height: 100%;
  max-height: calc(100vh - 48px);
  overflow: hidden;
  border-radius: 18.5px;
}
.ct-form-col {
  padding: 28px 30px 26px;
  overflow-y: auto;
  max-height: calc(100vh - 48px);
}
.ct-info-col {
  background: linear-gradient(155deg, rgba(255,45,127,.08) 0%, rgba(123,76,255,.08) 50%, rgba(34,225,255,.08) 100%);
  border-left: 1px solid rgba(255,255,255,.08);
  padding: 28px 26px 24px;
  display: flex; flex-direction: column; gap: 16px;
  overflow-y: auto;
}

.ct-eyebrow {
  font-family: var(--f-mono); font-size: 10.5px;
  color: rgba(255,255,255,.65);
  letter-spacing: .14em; text-transform: uppercase;
  margin-bottom: 8px;
}
.ct-title {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(22px, 2.4vw, 28px); line-height: 1.1;
  letter-spacing: -0.02em; color: #fff;
  margin: 0 0 18px;
}

.ct-toggle {
  display: inline-flex; gap: 3px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 3px;
  margin-bottom: 18px;
}
.ct-toggle-btn {
  border: 0; background: transparent;
  color: rgba(255,255,255,.65);
  padding: 8px 18px; border-radius: 999px;
  font-family: var(--f-display); font-weight: 500; font-size: 13px;
  cursor: pointer;
  transition: background .25s, color .25s;
}
.ct-toggle-btn:hover { color: #fff; }
.ct-toggle-btn.is-active {
  background: #fff; color: #0a0a0a;
}

.ct-form { display: none; flex-direction: column; gap: 10px; }
.ct-form.is-active { display: flex; }
.ct-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.ct-form label { display: flex; flex-direction: column; gap: 4px; }
.ct-form label > span {
  font-family: var(--f-mono); font-size: 10px;
  letter-spacing: .12em; text-transform: uppercase;
  color: rgba(255,255,255,.6);
}
.ct-form input,
.ct-form select,
.ct-form textarea {
  font-family: var(--f-display); font-weight: 500;
  font-size: 14px; color: #fff;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 9px 12px;
  transition: border-color .2s, background .2s;
  appearance: none; -webkit-appearance: none;
  font-family: inherit;
}
.ct-form textarea { font-family: var(--f-display); resize: vertical; min-height: 60px; }
.ct-form select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='none' stroke='%23ffffff80' stroke-width='1.6' d='M2 4l4 4 4-4'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 11px;
  padding-right: 32px; cursor: pointer;
}
.ct-form input:focus,
.ct-form select:focus,
.ct-form textarea:focus {
  outline: none;
  border-color: var(--led-pink);
  background: rgba(255,45,127,.05);
}
/* Cuando el toggle del modal cambia entre Corp/Social, los colores del
   filete y los focos también cambian. */
.ct-modal.is-corp {
  --accent-from: var(--led-pink);
  --accent-to:   var(--led-amber);
}
.ct-modal.is-social {
  --accent-from: var(--led-violet);
  --accent-to:   var(--led-cyan);
}
.ct-modal.is-corp   .ct-form input:focus,
.ct-modal.is-corp   .ct-form select:focus,
.ct-modal.is-corp   .ct-form textarea:focus { border-color: var(--led-pink); background: rgba(255,45,127,.06); }
.ct-modal.is-social .ct-form input:focus,
.ct-modal.is-social .ct-form select:focus,
.ct-modal.is-social .ct-form textarea:focus { border-color: var(--led-violet); background: rgba(123,76,255,.08); }
.ct-form input::placeholder,
.ct-form textarea::placeholder { color: rgba(255,255,255,.32); }

.ct-tel { display: grid; grid-template-columns: 96px 1fr; gap: 6px; }
.ct-tel-country { padding-right: 24px !important; background-position: right 8px center; }
.ct-tel-hint {
  display: block;
  margin-top: 7px;
  font-family: var(--f-display);
  font-size: 12.5px;
  line-height: 1.4;
  color: rgba(255,255,255,.62);
  letter-spacing: -0.005em;
}
.ct-tel-hint strong {
  font-weight: 500;
  color: var(--led-cyan);
}

.ct-submit {
  margin-top: 8px;
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  background: var(--ink); color: var(--bg);
  border: 0; border-radius: 10px;
  padding: 12px 20px;
  font-family: var(--f-display); font-weight: 600; font-size: 14px;
  cursor: pointer;
  transition: transform .25s, box-shadow .25s, background .25s, color .25s;
  position: relative; overflow: hidden;
  z-index: 1;
}
.ct-submit::after {
  content: ''; position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(95deg, var(--led-pink), var(--led-violet), var(--led-cyan));
  opacity: 0; transition: opacity .35s;
}
.ct-submit:hover { transform: translateY(-2px); color: #fff; box-shadow: 0 18px 36px -10px rgba(255,45,127,.45); }
.ct-submit:hover::after { opacity: 1; }
.ct-submit:disabled { opacity: .6; cursor: not-allowed; transform: none; }

/* INFO SIDEBAR */
.ct-info-map {
  position: relative;
  display: block;
  width: 100%;
  aspect-ratio: 4/3;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--line);
  margin-bottom: 4px;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
  transition: transform .35s var(--ease), border-color .35s;
}
.ct-info-map:hover {
  transform: translateY(-2px);
  border-color: var(--led-cyan);
}
.ct-info-map:hover .ct-info-map-overlay .ct-info-eyebrow { color: var(--led-cyan); }
.ct-info-map iframe,
.ct-info-map img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  border: 0;
}
/* Solo el iframe del mapa lleva filtro dark, la foto de oficina queda
   con sus colores reales. */
.ct-info-map iframe {
  filter: invert(.92) hue-rotate(180deg) saturate(.8) brightness(.95);
}
.ct-info-map-overlay {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 18px 16px 16px;
  /* Gradient más oscuro y más alto: arranca a media foto y termina
     casi opaco abajo. Antes pasaba de 0% transparente a 85% en el último
     pixel; ahora arrancamos antes y llegamos a 95% para que el texto
     'Buschiazzo 3036' tenga buen contraste sobre la zona inferior de
     la foto sin importar lo que muestre. */
  background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.55) 40%, rgba(0,0,0,.95) 100%);
  pointer-events: none;
}
.ct-info-map-overlay .ct-info-eyebrow { color: rgba(255,255,255,.85); margin-bottom: 3px; }
.ct-info-map-overlay .ct-info-text {
  color: #fff; line-height: 1.3;
  font-weight: 500;
  text-shadow: 0 1px 6px rgba(0,0,0,.55);
}

.ct-info-card { display: flex; flex-direction: column; gap: 4px; }
.ct-info-eyebrow {
  font-family: var(--f-mono); font-size: 10px;
  letter-spacing: .14em; text-transform: uppercase;
  color: rgba(255,255,255,.55);
}
.ct-info-text {
  font-family: var(--f-display); font-weight: 500;
  font-size: 14px; line-height: 1.45;
  color: #fff;
  text-decoration: none;
  transition: color .2s;
}
a.ct-info-text:hover { color: var(--led-pink); }
.ct-info-social-row {
  margin-top: auto;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,.08);
}
.ct-info-link {
  font-family: var(--f-display); font-weight: 500; font-size: 13px;
  color: rgba(255,255,255,.82); text-decoration: none;
  transition: color .2s;
}
.ct-info-link:hover { color: var(--led-pink); }

body.ct-modal-open { overflow: hidden; }

@media (max-width: 820px) {
  .ct-modal-grid { grid-template-columns: 1fr; max-height: calc(100vh - 48px); }
  .ct-info-col {
    border-left: 0;
    border-top: 1px solid var(--line);
    padding: 28px 24px;
  }
  .ct-form-col { padding: 32px 24px 24px; }
  .ct-row { grid-template-columns: 1fr; }
}
@media (max-width: 500px) {
  .ct-modal { padding: 10px; }
  .ct-modal-shell { border-radius: 16px; }
}

/* ============================================================
   WHATSAPP FAB + MODAL
   ============================================================ */
.wa-fab {
  position: fixed; right: 22px; bottom: 22px;
  z-index: 9990;
  display: inline-flex; align-items: center; gap: 0;
  width: 60px; height: 60px;
  background: #25D366; color: #0a0a0a;
  border-radius: 999px;
  padding: 0;
  text-decoration: none;
  box-shadow: 0 8px 28px -6px rgba(37,211,102,.55), 0 2px 8px rgba(0,0,0,.3);
  transition: width .35s var(--ease, cubic-bezier(.2,.8,.2,1)), transform .25s, box-shadow .25s, padding .35s;
  overflow: hidden;
  white-space: nowrap;
}
.wa-fab svg {
  width: 30px; height: 30px;
  flex: 0 0 auto;
  margin: 0 15px;
  color: #fff;
  transition: color .25s;
}
.wa-fab .wa-fab-label {
  font-family: var(--f-display); font-weight: 600;
  font-size: 14px; letter-spacing: -0.005em;
  color: #fff;
  max-width: 0; opacity: 0; padding-right: 0;
  transition: max-width .35s var(--ease), opacity .25s, padding-right .35s;
}
.wa-fab:hover {
  width: 168px; padding-right: 6px;
  transform: translateY(-2px);
  box-shadow: 0 14px 36px -6px rgba(37,211,102,.7), 0 4px 12px rgba(0,0,0,.4);
}
.wa-fab:hover .wa-fab-label { max-width: 120px; opacity: 1; padding-right: 14px; }
.wa-fab:hover svg { margin-left: 18px; margin-right: 8px; }

@keyframes wlWaPulse {
  0%   { box-shadow: 0 8px 28px -6px rgba(37,211,102,.55), 0 0 0 0    rgba(37,211,102,.55); }
  70%  { box-shadow: 0 8px 28px -6px rgba(37,211,102,.55), 0 0 0 18px rgba(37,211,102,0);   }
  100% { box-shadow: 0 8px 28px -6px rgba(37,211,102,.55), 0 0 0 0    rgba(37,211,102,0);   }
}
.wa-fab { animation: wlWaPulse 2.6s ease-out infinite; }
.wa-fab:hover { animation: none; }

/* MODAL */
.wa-modal {
  position: fixed; inset: 0; z-index: 10000;
  display: flex; align-items: flex-end; justify-content: center;
}
.wa-modal[hidden] { display: none; }
.wa-modal-overlay {
  position: absolute; inset: 0;
  background: rgba(0,0,0,.78);
  backdrop-filter: blur(8px);
  animation: wlFadeIn .25s ease;
}
@keyframes wlFadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes wlSlideUp { from { transform: translateY(40px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }

.wa-modal-panel {
  position: relative;
  width: min(440px, calc(100vw - 16px));
  max-height: 92vh;
  margin: 0 8px 8px;
  background: #0e0e0e;
  border: 1px solid var(--line);
  border-radius: 20px;
  overflow-y: auto;
  padding: 28px 24px 24px;
  animation: wlSlideUp .35s cubic-bezier(.2,.8,.2,1);
}
@media (min-width: 720px) {
  .wa-modal { align-items: center; }
  .wa-modal-panel { margin: 0; }
}
.wa-modal-close {
  position: absolute; top: 10px; right: 10px;
  width: 44px; height: 44px;
  background: rgba(255,255,255,.08); color: #fff;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .25s, transform .25s;
}
.wa-modal-close svg { width: 18px; height: 18px; display: block; }
.wa-modal-close:hover { background: rgba(255,255,255,.16); transform: rotate(90deg); }

.wa-modal-header { display: flex; flex-direction: column; gap: 14px; margin-bottom: 22px; }
.wa-modal-header-icon {
  width: 48px; height: 48px;
  border-radius: 14px;
  background: #25D366; color: #fff;
  display: flex; align-items: center; justify-content: center;
}
.wa-modal-header-icon svg { width: 28px; height: 28px; }
.wa-modal-header h3 {
  font-family: var(--f-display); font-weight: 600;
  font-size: 20px; line-height: 1.25; letter-spacing: -0.015em;
  color: #fff; margin: 0; max-width: 30ch;
}

/* FORM */
.wa-form { display: flex; flex-direction: column; gap: 14px; }
.wa-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.wa-form label { display: flex; flex-direction: column; gap: 6px; }
.wa-form label > span {
  font-family: var(--f-mono); font-size: 11px;
  letter-spacing: .12em; text-transform: uppercase;
  color: rgba(255,255,255,.65);
}
.wa-form input,
.wa-form select {
  font-family: var(--f-display); font-weight: 500;
  font-size: 15px; color: #fff;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 12px 14px;
  transition: border-color .2s, background .2s;
  appearance: none;
  -webkit-appearance: none;
}
.wa-form select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='none' stroke='%23ffffff80' stroke-width='1.6' d='M2 4l4 4 4-4'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  background-size: 12px;
  padding-right: 36px;
  cursor: pointer;
}
.wa-form input:focus,
.wa-form select:focus {
  outline: none;
  border-color: #25D366;
  background: rgba(37,211,102,.06);
}
.wa-form input::placeholder { color: rgba(255,255,255,.35); }

.wa-tel { display: grid; grid-template-columns: 110px 1fr; gap: 8px; }
.wa-tel-country { padding-right: 28px !important; background-position: right 10px center; }

.wa-submit {
  margin-top: 6px;
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  background: #25D366; color: #fff;
  border: 0; border-radius: 12px;
  padding: 14px 18px;
  font-family: var(--f-display); font-weight: 600; font-size: 15px;
  cursor: pointer;
  transition: background .25s, transform .25s, box-shadow .25s;
  box-shadow: 0 8px 24px -8px rgba(37,211,102,.55);
}
.wa-submit svg { width: 20px; height: 20px; }
.wa-submit:hover {
  background: #1faa50;
  transform: translateY(-2px);
  box-shadow: 0 12px 28px -8px rgba(37,211,102,.7);
}
.wa-submit:disabled { opacity: .6; cursor: not-allowed; transform: none; }

body.wa-modal-open { overflow: hidden; }

@media (prefers-reduced-motion: reduce) {
  .wa-fab { animation: none; }
}

@media (max-width: 500px) {
  .wa-fab { right: 16px; bottom: 16px; }
}

/* ============================================================
   FIESTÓN PAGE — Hero cards + testimonios carousel
   ============================================================ */
.page-header.fieston-hero {
  min-height: 0;
  /* Contenido más cerca del menú: padding-top reducido respecto al
     default de .has-video (220px). El menú queda ~96px y dejamos
     solo el aire necesario abajo del título. */
  padding: 130px 36px 70px;
  display: block;
}
.page-header.fieston-hero .lead { max-width: 56ch; margin-bottom: 36px; }

.fieston-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  max-width: 820px;
  margin-top: 8px;
}
@keyframes fcRainbow {
  0%   { background-position:   0% 50%; }
  100% { background-position: 300% 50%; }
}
.fieston-card {
  position: relative;
  display: block;
  padding: 1px; /* espacio mínimo, solo aparece en hover */
  border-radius: 22px;
  background:
    linear-gradient(rgba(255,255,255,.04), rgba(255,255,255,.04)) padding-box,
    linear-gradient(rgba(255,255,255,.12), rgba(255,255,255,.12)) border-box;
  border: 1px solid transparent;
  text-decoration: none;
  color: var(--ink);
  overflow: hidden;
  isolation: isolate;
  transition: transform .35s var(--ease), box-shadow .35s, background .35s;
  box-shadow: 0 12px 36px -16px rgba(0,0,0,.55);
}
.fieston-card:hover {
  transform: scale(1.025);
  background:
    linear-gradient(rgba(255,255,255,.06), rgba(255,255,255,.06)) padding-box,
    linear-gradient(135deg,
      var(--c1, var(--led-pink)) 0%,
      var(--c2, var(--led-violet)) 50%,
      var(--c1, var(--led-pink)) 100%) border-box;
  background-size: auto, 250% 100%;
  animation: fcRainbow 4s linear infinite;
  box-shadow: 0 24px 60px -16px rgba(0,0,0,.7);
}
/* Inner wrapper para que el padding del filete no rompa el contenido */
.fieston-card-inner {
  border-radius: 20px;
  padding: 26px 28px;
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background: var(--bg-2);
}
.fieston-card-social { --c1: var(--led-pink);   --c2: var(--led-violet); }
.fieston-card-bodas { --c1: var(--led-violet); --c2: var(--led-cyan); }

.fieston-card-tint { display: none; } /* placeholder reservado por si en el futuro lleva foto */
.fieston-card-body {
  display: flex; flex-direction: column; gap: 6px;
  padding: 26px 28px;
  border-radius: 20px;
  background: rgba(14,14,14,.92);
  position: relative;
  z-index: 1;
}
.fieston-card-title {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(28px, 3vw, 38px); line-height: 1; letter-spacing: -0.03em;
  color: #fff; margin: 0 0 10px;
}
.fieston-card-title .italic {
  letter-spacing: -0.015em;
}
.fieston-card-desc {
  font-size: 14.5px; line-height: 1.5;
  color: rgba(255,255,255,.85);
  margin: 0 0 18px;
  max-width: 38ch;
}
.fieston-card-cta {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--f-display); font-weight: 500; font-size: 14px;
  color: #fff;
  border-bottom: 1px solid rgba(255,255,255,.3);
  padding-bottom: 4px;
  width: fit-content;
  transition: border-color .3s, gap .3s;
}
.fieston-card-cta .arrow {
  font-size: 20px; color: var(--c1);
  text-shadow: 0 0 10px var(--c1);
  transition: transform .3s var(--ease);
}
.fieston-card:hover .fieston-card-cta { border-color: var(--c1); gap: 12px; }
.fieston-card:hover .fieston-card-cta .arrow { transform: translate(3px, -2px); }

@media (max-width: 720px) {
  .fieston-cards { grid-template-columns: 1fr; gap: 14px; max-width: 480px; }
  .fieston-card-body { padding: 22px 22px; }
}

/* ============================================================
   TESTIMONIOS — carrusel 2 por slide
   ============================================================ */
.testimonials { position: relative; }
.testimonials-track {
  display: flex;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  gap: 0;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
  scrollbar-width: none;
}
.testimonials-track::-webkit-scrollbar { display: none; }
.testimonials-track { cursor: grab; user-select: none; }
.testimonials-track.is-dragging { cursor: grabbing; scroll-behavior: auto; }
.testimonials-track.is-dragging * { pointer-events: none; }
.testimonial-slide {
  flex: 0 0 100%;
  scroll-snap-align: start;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
}
.testimonial-card {
  position: relative;
  padding: 28px 28px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--line);
  border-radius: 22px;
  /* Layout horizontal: avatar grande a la izquierda, texto al costado */
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 24px;
  align-items: center;
  isolation: isolate;
  overflow: hidden;
}
/* Avatar circular con borde gradient violet → cyan (estilo FiestÓN) */
.testimonial-avatar {
  position: relative;
  width: 140px; height: 140px;
  border-radius: 999px;
  padding: 3px;
  background: linear-gradient(135deg, var(--led-violet) 0%, var(--led-pink) 50%, var(--led-cyan) 100%);
  flex: 0 0 auto;
}
.testimonial-avatar img {
  width: 100%; height: 100%;
  border-radius: 999px;
  object-fit: cover;
  display: block;
  background: var(--bg-2);
}
.testimonial-avatar-placeholder {
  display: flex; align-items: center; justify-content: center;
}
.testimonial-avatar-placeholder span {
  width: 100%; height: 100%;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--bg-2), var(--bg-3));
  display: flex; align-items: center; justify-content: center;
  font-family: var(--f-display); font-weight: 600;
  font-size: 48px; color: #fff;
}
/* Texto al costado del avatar */
.testimonial-card > .testimonial-quote,
.testimonial-card > .testimonial-meta { grid-column: 2; }
.testimonial-card > .testimonial-quote { align-self: end; margin-top: 0; }
.testimonial-card > .testimonial-meta { align-self: start; }
.testimonial-card::before {
  content: ''; position: absolute; inset: -50%;
  background:
    radial-gradient(circle at 20% 20%, var(--led-pink), transparent 45%),
    radial-gradient(circle at 80% 80%, var(--led-violet), transparent 50%);
  filter: blur(60px);
  opacity: .18;
  z-index: -1;
  transition: opacity .5s;
}
.testimonial-card:hover::before { opacity: .35; }
.testimonial-quote {
  font-family: var(--f-display); font-weight: 400;
  font-size: clamp(15px, 1.4vw, 19px); line-height: 1.55;
  color: rgba(255,255,255,.95);
  margin: 0;
  flex: 1;
}
.testimonial-meta {
  border-top: 1px solid var(--line);
  padding-top: 16px;
}
.testimonial-name {
  font-family: var(--f-display); font-weight: 600;
  font-size: 16px; letter-spacing: -0.015em;
  color: #fff;
  margin-bottom: 3px;
}
.testimonial-role {
  font-family: var(--f-mono); font-size: 11px;
  letter-spacing: .12em; text-transform: uppercase;
  color: rgba(255,255,255,.65);
}

.testimonials-nav {
  display: flex; align-items: center; justify-content: center;
  gap: 18px; margin-top: 28px;
}
.testimonials-btn {
  background: rgba(255,255,255,.06);
  color: #fff;
  border: 1px solid var(--line);
  width: 42px; height: 42px;
  border-radius: 999px;
  font-family: var(--f-display); font-size: 18px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .25s, border-color .25s, transform .25s;
}
.testimonials-btn:hover { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.3); transform: translateY(-2px); }
.testimonials-dots { display: flex; gap: 8px; }
.testimonials-dot {
  width: 8px; height: 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.25);
  cursor: pointer;
  transition: background .3s, transform .3s;
  border: 0; padding: 0;
}
.testimonials-dot.is-active { background: var(--led-pink); transform: scale(1.3); box-shadow: 0 0 8px var(--led-pink); }

@media (max-width: 800px) {
  .testimonial-slide { grid-template-columns: 1fr; gap: 14px; }
  .testimonial-card {
    padding: 24px 22px;
    grid-template-columns: 100px 1fr;
    gap: 18px;
  }
  .testimonial-avatar { width: 100px; height: 100px; }
  .testimonial-avatar-placeholder span { font-size: 36px; }
}

/* ============================================================
   MANSION — Video tour + 2 stages
   ============================================================ */
.mansion-video {
  position: relative;
  border-radius: 22px;
  overflow: hidden;
  aspect-ratio: 16/9;
  background: #000;
  border: 1px solid var(--line);
  box-shadow: 0 30px 80px -30px rgba(0,0,0,.7), 0 0 0 1px rgba(255,255,255,.04);
}
.mansion-video-el {
  width: 100%; height: 100%;
  display: block;
  object-fit: cover;
}
/* Botón play overlay — pill horizontal estilo CTA del sitio */
.mansion-video-play {
  position: absolute;
  left: 50%; top: 50%; transform: translate(-50%, -50%);
  display: inline-flex; align-items: center; gap: 12px;
  padding: 14px 24px 14px 20px;
  background: var(--bg);
  color: var(--ink);
  border: 0; border-radius: 999px;
  font-family: var(--f-display); font-weight: 600; font-size: 15px;
  letter-spacing: -0.005em;
  cursor: pointer;
  z-index: 2;
  box-shadow: 0 14px 36px -8px rgba(0,0,0,.55), 0 0 0 1px rgba(255,255,255,.06);
  transition: opacity .35s ease, visibility .35s, transform .3s var(--ease, cubic-bezier(.2,.8,.2,1)), box-shadow .3s;
  position: absolute; /* re-aplica por orden de transform */
}
.mansion-video-play::before {
  content: ''; position: absolute; inset: 0; border-radius: 999px; z-index: -1;
  background: linear-gradient(95deg, var(--led-pink), var(--led-violet), var(--led-cyan));
  opacity: 0; transition: opacity .35s;
}
.mansion-video-play:hover {
  transform: translate(-50%, -52%);
  color: #fff;
  box-shadow: 0 18px 44px -8px rgba(255,45,127,.45), 0 0 0 1px rgba(255,255,255,.1);
}
.mansion-video-play:hover::before { opacity: 1; }
.mansion-video.is-playing .mansion-video-play {
  opacity: 0; visibility: hidden; pointer-events: none;
}
.mansion-video-play svg {
  width: 18px; height: 18px;
  position: relative; z-index: 1;
  margin-left: 2px;
}
.mvp-ring { display: none; }
.mvp-label {
  font-family: var(--f-display); font-size: 15px;
  font-weight: 600; letter-spacing: -0.005em;
  position: relative; z-index: 1;
}

/* STAGES — compactas: solo título + bajada sobre foto */
.mansion-stages {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
.mansion-stage {
  position: relative;
  aspect-ratio: 16/10;
  min-height: 280px;
  border-radius: 18px;
  overflow: hidden;
  background-size: cover;
  background-position: center;
  display: flex; align-items: flex-end;
  border: 1px solid var(--line);
  transition: transform .45s var(--ease, cubic-bezier(.2,.8,.2,1));
}
.mansion-stage:hover { transform: translateY(-4px); }
.mansion-stage-tint {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(10,10,10,.05) 0%, rgba(10,10,10,.35) 50%, rgba(10,10,10,.9) 100%);
  pointer-events: none;
}
.mansion-stage-body {
  position: relative; z-index: 1;
  padding: 22px 24px 22px;
  color: #fff;
}
.mansion-stage-title {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(22px, 2.4vw, 30px); line-height: 1.08;
  letter-spacing: -0.02em;
  color: #fff; margin: 0 0 8px;
}
.mansion-stage-desc {
  font-size: 14.5px; line-height: 1.5;
  color: rgba(255,255,255,.88);
  margin: 0;
}

/* Video player en split — override del .split-media:
   sin padding, sin min-height, sin flex centering. El wrapper toma
   exactamente el tamaño del video y aplica border-radius limpio. */
.split-media.mansion-video {
  padding: 0;
  min-height: 0;
  display: block;
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid var(--line);
  box-shadow: 0 24px 60px -24px rgba(0,0,0,.6);
  background: #000;
  align-self: stretch;
  isolation: isolate;
}
.split-media.mansion-video::before {
  /* el aurora glow del .split-media ::before queda oculto detrás del video */
  display: none;
}
.split-media.mansion-video .mansion-video-el {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: inherit;
}

@media (max-width: 1000px) {
  .split-media.mansion-video { width: 100%; }
}

/* ============================================================
   MANSION SITE BUTTON — botón destacado al sitio externo
   Filete arcoíris animado + interior oscuro + flecha
   ============================================================ */
@keyframes mansionBtnRainbow {
  0%   { background-position:   0% 50%; }
  100% { background-position: 300% 50%; }
}
.mansion-site-btn {
  display: inline-flex;
  margin-top: 32px;
  padding: 2px;
  border-radius: 18px;
  /* Mansion es propiedad social → violet → cyan (heredados de accent-* del body) */
  background:
    linear-gradient(135deg,
      var(--accent-from) 0%,
      var(--accent-to) 50%,
      var(--accent-from) 100%);
  background-size: 250% 100%;
  animation: mansionBtnRainbow 6s linear infinite;
  text-decoration: none;
  color: var(--ink);
  box-shadow:
    0 24px 60px -16px rgba(255,45,127,.28),
    0 14px 36px -12px rgba(123,76,255,.22),
    0 4px 18px -8px rgba(34,225,255,.16);
  transition: transform .35s var(--ease), box-shadow .35s;
  isolation: isolate;
}
.mansion-site-btn:hover {
  transform: translateY(-3px) scale(1.01);
  box-shadow:
    0 32px 80px -16px rgba(255,45,127,.42),
    0 18px 48px -12px rgba(123,76,255,.32),
    0 6px 24px -8px rgba(34,225,255,.22);
}
.mansion-site-btn-inner {
  display: flex;
  align-items: center;
  gap: 22px;
  padding: 20px 28px;
  background: #0e0e0e;
  border-radius: 16px;
  min-width: 0;
  position: relative;
  z-index: 1;
}
.mansion-site-btn-label {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.mansion-site-btn-eyebrow {
  font-family: var(--f-mono);
  font-size: 10.5px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-soft);
}
.mansion-site-btn-title {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: clamp(18px, 1.7vw, 22px);
  letter-spacing: -0.025em;
  line-height: 1.1;
  color: #fff;
}
.mansion-site-btn-arrow {
  flex: 0 0 auto;
  font-family: var(--f-display);
  font-weight: 500;
  font-size: 28px;
  line-height: 1;
  background: linear-gradient(95deg, var(--led-pink), var(--led-amber), var(--led-cyan));
  background-size: 200% 100%;
  -webkit-background-clip: text; background-clip: text; color: transparent;
  animation: glowShift 10s ease-in-out infinite alternate;
  transition: transform .35s var(--ease);
}
.mansion-site-btn:hover .mansion-site-btn-arrow {
  transform: translate(4px, -4px);
}
@media (max-width: 720px) {
  .mansion-site-btn-inner { padding: 18px 22px; gap: 16px; }
  .mansion-site-btn-title { font-size: 17px; }
  .mansion-site-btn-arrow { font-size: 26px; }
}

/* ============================================================
   FAQ — accordion semántico con <details>/<summary>
   ============================================================ */
.faq { padding: 100px 36px; max-width: 1100px; margin: 0 auto; }
.faq-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 32px;
}
.faq-item {
  background: rgba(255,255,255,.03);
  border: 1px solid var(--line);
  border-radius: 16px;
  overflow: hidden;
  transition: background .25s, border-color .25s;
}
.faq-item[open] {
  background: rgba(255,255,255,.05);
  border-color: rgba(255,255,255,.18);
}
.faq-item summary {
  list-style: none;
  cursor: pointer;
  padding: 22px 26px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  font-family: var(--f-display);
  font-weight: 500;
  font-size: clamp(16px, 1.6vw, 19px);
  color: var(--ink);
  letter-spacing: -0.01em;
  line-height: 1.35;
  transition: color .2s;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary:hover { color: #fff; }
.faq-q { flex: 1; min-width: 0; }
.faq-icon {
  flex: 0 0 auto;
  position: relative;
  width: 18px; height: 18px;
}
.faq-icon::before,
.faq-icon::after {
  content: '';
  position: absolute;
  background: var(--ink);
  border-radius: 1px;
  transition: transform .3s var(--ease), opacity .2s;
}
.faq-icon::before {
  top: 8px; left: 0; right: 0;
  height: 2px;
}
.faq-icon::after {
  top: 0; bottom: 0; left: 8px;
  width: 2px;
}
.faq-item[open] .faq-icon::after { transform: rotate(90deg); opacity: 0; }
.faq-item[open] summary { padding-bottom: 14px; }
.faq-a {
  padding: 0 26px 24px;
  font-family: var(--f-display);
  font-size: 15.5px;
  line-height: 1.65;
  color: var(--ink-2);
  max-width: 76ch;
}

@media (max-width: 800px) {
  .faq { padding: 70px 20px; }
  .faq-item summary { padding: 18px 20px; font-size: 15.5px; }
  .faq-item[open] summary { padding-bottom: 10px; }
  .faq-a { padding: 0 20px 20px; font-size: 14.5px; line-height: 1.6; }
}
@media (max-width: 800px) {
  .mansion-stages { grid-template-columns: 1fr; gap: 14px; }
  .mansion-stage { min-height: 220px; aspect-ratio: 16/10; }
  .mansion-stage-body { padding: 18px 20px 18px; }
  .mvp-ring { width: 76px; height: 76px; }
  .mansion-video-play svg { width: 30px; height: 30px; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1200px) {
  .feature-grid { grid-template-columns: repeat(2, 1fr); }
  .services-grid { grid-template-columns: repeat(3, 1fr); }
  .press-grid { grid-template-columns: repeat(3, 1fr); }
  .cs-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 800px) {
  .case-studies { padding: 80px 22px 64px; }
  .cs-grid { grid-template-columns: 1fr; gap: 20px; }
  .cs-modal-shell { width: 96vw; margin: 4vh auto 0; max-height: 92vh; border-radius: 16px; }
  .cs-modal-hero { padding: 40px 24px 32px; }
  .cs-modal-meta { padding: 14px 24px; }
  .cs-modal-body { padding: 24px 24px 30px; gap: 24px; }
}

@media (max-width: 1100px) {
  .bento { grid-template-columns: 1fr 1fr; grid-template-rows: auto; }
  .bento .card.featured, .bento .card-featured { grid-row: span 2; grid-column: span 2; }
  .card-wide, .card.wide { grid-column: span 2; }
  .cases-grid { grid-template-columns: 1fr 1fr; grid-template-rows: auto; }
  .case.span-2, .case.span-3,
  .case-card.span-2, .case-card.span-3 { grid-column: span 1; }
  .case.tall, .case-card.tall { grid-row: span 2; }
  .stat-strip, .stats, .stats-block { grid-template-columns: 1fr 1fr; gap: 36px; }
  .split-section { grid-template-columns: 1fr; gap: 36px; }
  .split-media { min-height: 320px; }
  .form-section { grid-template-columns: 1fr; gap: 36px; }
  .services-grid { grid-template-columns: repeat(2, 1fr); }
  .press-grid { grid-template-columns: repeat(2, 1fr); }
  .posts-grid { grid-template-columns: 1fr; }
}

@media (max-width: 800px) {
  /* ── HEADER ── */
  .site-header { padding: 12px 16px; gap: 10px; }
  .logo-img { height: 24px; }
  .cta-mini, .cta-pill { padding: 8px 14px; font-size: 13px; height: auto; }
  .cta-mini .led { width: 8px; height: 8px; }
  .lang { font-size: 11px; }

  /* ── NAV MOBILE: hamburger + dropdown panel (no full-screen) ── */
  .nav-hamburger { display: inline-flex; order: 99; margin-left: 4px; }
  .lang { display: none; }
  .nav {
    display: none;
    position: fixed;
    top: calc(56px + env(safe-area-inset-top, 0px));
    right: 12px;
    left: auto;
    width: min(320px, calc(100vw - 24px));
    max-height: calc(100vh - 76px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px));
    padding: 8px;
    background: rgba(15,12,10,.94);
    backdrop-filter: blur(22px) saturate(140%);
    -webkit-backdrop-filter: blur(22px) saturate(140%);
    border: 1px solid var(--line-strong);
    border-radius: 18px;
    box-shadow: 0 24px 60px -16px rgba(0,0,0,.7), 0 0 0 1px rgba(255,255,255,.03) inset;
    overflow-y: auto;
    flex-direction: column;
    align-items: stretch;
    gap: 2px;
    z-index: 49;
    opacity: 0;
    transform: translateY(-6px) scale(.98);
    transform-origin: top right;
    transition: opacity .22s var(--ease), transform .25s var(--ease);
    pointer-events: none;
  }
  body.is-nav-open .nav {
    display: flex;
    opacity: 1;
    transform: translateY(0) scale(1);
    pointer-events: auto;
  }
  /* Item del nav: trigger ancho completo + acordeón interno */
  .nav-item { width: 100%; }
  .nav-trigger {
    width: 100%; text-align: left;
    padding: 12px 14px; font-size: 15px;
    font-weight: 500;
    border-bottom: 0;
    border-radius: 10px;
    display: flex; align-items: center; justify-content: space-between;
    gap: 8px;
    color: var(--ink);
    transition: background .2s;
  }
  .nav-trigger:hover, .nav-item.is-open > .nav-trigger {
    background: rgba(255,255,255,.05);
  }
  /* Caret indica acordeón (rota cuando abierto) */
  .nav-trigger .caret {
    display: inline-block;
    width: 8px; height: 8px;
    border-right: 1.5px solid var(--ink-soft);
    border-bottom: 1.5px solid var(--ink-soft);
    transform: rotate(45deg);
    transition: transform .25s var(--ease);
    margin-left: auto;
    margin-bottom: 3px;
  }
  .nav-item.is-open > .nav-trigger .caret {
    transform: rotate(-135deg);
    margin-bottom: -2px;
  }
  /* Dropdown como acordeón cerrado por default, abre al .is-open */
  .nav-item.has-dropdown .dropdown {
    position: static;
    transform: none;
    opacity: 0;
    pointer-events: none;
    min-width: 0;
    max-width: none;
    padding-top: 0;
    margin: 0;
    max-height: 0;
    overflow: hidden;
    transition: max-height .3s var(--ease), opacity .2s;
  }
  .nav-item.has-dropdown.is-open .dropdown {
    opacity: 1;
    pointer-events: auto;
    max-height: 600px;
  }
  .dropdown::before, .dropdown::after { display: none; }
  .dropdown-inner {
    padding: 4px 6px 8px;
    background: transparent;
    border: 0;
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    border-radius: 0;
  }
  .dropdown.wide .dd-cols, .dropdown .dd-cols { grid-template-columns: 1fr; gap: 2px; }
  .dd-link { padding: 9px 12px 9px 18px; }
  .dd-link .dd-name { font-size: 14px; }
  .dd-link .dd-meta { font-size: 11.5px; }
  .dd-link-featured::before { left: 7px; height: 18px; }

  /* ── HERO ── */
  .hero { padding: 110px 20px 70px; }
  h1.hero-title, .hero h1, .hero-content h1 { font-size: clamp(40px, 10vw, 64px); }
  .hero-marker { gap: 6px 10px; font-size: 10.5px; flex-wrap: wrap; }
  .hero-meta { flex-direction: column; align-items: stretch; gap: 26px; }
  .lead { font-size: 17px; line-height: 1.55; }

  /* ── KPIs (+800, +110K, 9, ∞) ── */
  .stat-strip, .stats, .stats-block { margin-top: 50px; grid-template-columns: 1fr 1fr; gap: 22px; }
  .stat-strip .item .num, .stats .stat-num, .stats-block .item .num {
    font-size: clamp(38px, 9vw, 56px);
  }

  /* ── SECTIONS / PADDING LATERAL UNIFICADO ── */
  .section, .services, .cases-section, .brands-section,
  .cta-band, .form-section, .split-section,
  .case-studies, .form-section, section.section { padding: 70px 20px; }
  .page-header { padding: 110px 20px 50px; }
  .section-head { flex-direction: column; align-items: start; gap: 22px; }
  .section-head h2 { font-size: clamp(34px, 8.5vw, 52px); }

  /* ── BENTO / CARDS ── */
  .bento,
  .bento.bento-social,
  .bento.bento-corp-v2,
  .services .bento,
  .services:nth-of-type(2) .bento {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto !important;
    gap: 16px;
  }
  .bento .card.featured, .bento .card-featured,
  .bento .card.featured-social { grid-row: auto; grid-column: auto; }
  .card-wide, .card.wide { grid-column: auto; }
  /* Reset cards específicas del bento corp v2 en mobile (apilarlas todas) */
  .bento-corp-v2 .card-corp-main,
  .bento-corp-v2 .card-corp-side,
  .bento-corp-v2 .card-corp-mini,
  .bento-corp-v2 .card-corp-mini:nth-of-type(3),
  .bento-corp-v2 .card-corp-mini:nth-of-type(4),
  .bento-corp-v2 .card-corp-mini:nth-of-type(5) {
    grid-column: auto;
    grid-row: auto;
  }
  /* Mostrar descripciones y restaurar paddings de las minis 3 y 4 en mobile */
  .bento-corp-v2 .card-corp-mini:nth-of-type(3) p,
  .bento-corp-v2 .card-corp-mini:nth-of-type(4) p { display: block; }
  .bento-corp-v2 .card-corp-mini:nth-of-type(3),
  .bento-corp-v2 .card-corp-mini:nth-of-type(4),
  .bento-corp-v2 .card-corp-mini { padding: 24px 22px; }
  .bento-corp-v2 .card-corp-mini h3,
  .bento-corp-v2 .card-corp-mini:nth-of-type(3) h3,
  .bento-corp-v2 .card-corp-mini:nth-of-type(4) h3 {
    font-size: 26px; line-height: 1.05;
  }
  .bento-corp-v2 .card-corp-mini p { font-size: 14.5px; line-height: 1.45; }
  /* Cards corp tomen altura natural (no fixed 340/170) */
  .bento-corp-v2 .card-corp-main,
  .bento-corp-v2 .card-corp-side,
  .bento-corp-v2 .card-corp-mini { min-height: 220px; height: auto; }
  .card { min-height: 260px; }
  .card-body h3 { font-size: 26px; }
  .card-cta { padding: 10px 16px; font-size: 13px; white-space: nowrap; }
  /* En cards featured grandes, card-foot pasa a columna */
  .card-featured .card-foot,
  .card.featured .card-foot { flex-direction: column; align-items: flex-start; gap: 14px; }
  .card-featured .tags,
  .card.featured .tags { width: 100%; flex-wrap: wrap; }

  /* ── CASES (home) ── */
  .cases-grid { grid-template-columns: 1fr; gap: 14px; }
  .case, .case-card { min-height: 220px; }
  .case.tall, .case-card.tall { grid-row: auto; }
  .case h3, .case-card h3 { font-size: 22px; }
  .cases-cta { justify-content: flex-start; }

  /* ── CASE STUDIES (eventos-corporativos) ── */
  .case-studies { padding: 60px 20px 50px; }
  .cs-grid { grid-template-columns: 1fr; gap: 16px; }
  .cs-head { margin-bottom: 36px; }
  .cs-head h2 { font-size: clamp(32px, 8.5vw, 44px); }
  .cs-card-img { aspect-ratio: 16/10; }
  .cs-card-logo { max-width: 55%; max-height: 50%; }
  .cs-card-body { padding: 18px 20px 22px; }
  .cs-card-title { font-size: 18px; }
  .cs-card-summary { font-size: 13.5px; }

  /* Modal de caso */
  .cs-modal-shell { width: 96vw; margin: 4vh auto 0; max-height: 92vh; border-radius: 16px; }
  .cs-modal-hero { padding: 48px 22px 28px; min-height: 280px; }
  .cs-modal-hero-logo { top: 20px; left: 20px; padding: 10px 16px; }
  .cs-modal-hero-logo img { max-width: 110px; max-height: 40px; }
  .cs-modal-title { font-size: clamp(20px, 5vw, 26px); }
  .cs-modal-meta { padding: 14px 22px; }
  .cs-modal-body { padding: 22px 22px 26px; gap: 24px; }
  .cs-svc { padding: 14px 16px; gap: 14px; }
  .cs-svc-icon { width: 40px; height: 40px; font-size: 22px; }
  .cs-modal-nav { padding: 12px 16px; flex-wrap: wrap; gap: 10px; }

  /* ── CLOSING / FOOTER ── */
  .closing { padding: 90px 20px 110px; }
  footer.foot { padding: 28px 20px; flex-direction: column; align-items: start; gap: 14px; }

  /* ── MARQUEE ── */
  .marquee, .logos-marquee { margin: 0 -20px; gap: 10px; }
  .logo-tile { width: 150px; height: 80px; padding: 14px 18px; }

  /* ── FORMS / FEATURE / SERVICES GRIDS ── */
  .feature-grid { grid-template-columns: 1fr; }
  .services-grid { grid-template-columns: 1fr; }
  .press-grid { grid-template-columns: 1fr 1fr; }
  .form-wrap { padding: 24px; }
  .form-grid { grid-template-columns: 1fr; gap: 14px; }
  .form-field.full { grid-column: auto; }

  /* ── CTA ROWS ── */
  .cta-row { flex-direction: column; align-items: stretch; gap: 12px; }
  .cta-row .btn-primary, .cta-row .btn-link { width: 100%; text-align: center; }
  .cta-band h2 { font-size: clamp(36px, 9vw, 56px); }

  /* ── CONTACT MODAL ── */
  .ct-modal { padding: 10px; }
  .ct-modal-shell { max-height: calc(100vh - 20px); border-radius: 16px; }
  .ct-modal-grid { grid-template-columns: 1fr; max-height: calc(100vh - 20px); }
  .ct-info-col { border-left: 0; border-top: 1px solid var(--line); padding: 24px 22px; }
  .ct-form-col { padding: 28px 22px 22px; }
  .ct-row { grid-template-columns: 1fr; gap: 14px; }
  .ct-title { font-size: clamp(24px, 6.5vw, 30px); margin-bottom: 22px; }
  .ct-toggle-btn { padding: 9px 18px; font-size: 13px; }
  .ct-modal-close { width: 34px; height: 34px; top: 14px; right: 14px; }

  /* ── WA FAB + MODAL ── */
  .wa-modal-panel { padding: 24px 20px 20px; border-radius: 18px; }
  .wa-modal-header h3 { font-size: 18px; }
  .wa-form-row { grid-template-columns: 1fr; gap: 14px; }
  .wa-form input, .wa-form select { font-size: 14.5px; padding: 11px 13px; }
}

@media (max-width: 500px) {
  /* ── HEADER ── */
  .site-header { padding: 10px 14px; gap: 8px; }
  .logo-img { height: 22px; }
  .cta-mini, .cta-pill { padding: 7px 12px; font-size: 12.5px; }
  .lang { font-size: 10.5px; }

  /* ── HERO ── */
  .hero { padding: 92px 16px 56px; }
  h1.hero-title, .hero h1, .hero-content h1 { font-size: clamp(36px, 11vw, 52px); max-width: 100%; }
  .hero-marker { font-size: 10px; gap: 6px 8px; }
  .hero-marker .sep { display: none; }

  /* ── KPIs ── */
  .stat-strip, .stats, .stats-block { grid-template-columns: 1fr 1fr; gap: 18px; margin-top: 40px; }

  /* ── PADDING LATERAL UNIFICADO 16px ── */
  .section, .services, .cases-section, .brands-section,
  .cta-band, .form-section, .split-section,
  .case-studies, section.section { padding: 56px 16px; }
  .page-header { padding: 100px 16px 40px; }
  .closing { padding: 80px 16px 100px; }
  footer.foot { padding: 24px 16px; }

  /* ── HEADINGS chicos ── */
  .section-head h2 { font-size: clamp(30px, 9vw, 40px); }
  .cs-head h2 { font-size: clamp(28px, 9vw, 36px); }
  .cta-band h2 { font-size: clamp(32px, 10vw, 44px); }
  .case h3, .case-card h3 { font-size: 20px; }
  .cs-card-title { font-size: 17px; }

  /* ── BENTO ── */
  .card { min-height: 240px; }
  .card-body h3 { font-size: 24px; }
  .card-body { padding: 22px 22px 18px; }
  .card-foot { padding: 18px 22px 20px; }

  /* ── MARQUEE ── */
  .marquee, .logos-marquee { margin: 0 -16px; }
  .logo-tile { width: 130px; height: 72px; }
  .brands-head h2 { font-size: clamp(28px, 9vw, 38px); }

  /* ── PRESS / BLOG ── */
  .press-grid, .posts-grid { grid-template-columns: 1fr; }

  /* ── CONTACT MODAL ── */
  .ct-modal { padding: 6px; }
  .ct-modal-shell { border-radius: 14px; max-height: calc(100vh - 12px); }
  .ct-modal-grid { max-height: calc(100vh - 12px); }
  .ct-form-col { padding: 24px 18px 20px; }
  .ct-info-col { padding: 22px 18px; gap: 16px; }
  .ct-info-text { font-size: 14.5px; }
  .ct-title { font-size: 22px; margin-bottom: 20px; }
  .ct-toggle { padding: 3px; }
  .ct-toggle-btn { padding: 8px 14px; font-size: 12.5px; }
  .ct-tel { grid-template-columns: 92px 1fr; }
  .ct-submit { padding: 13px 18px; font-size: 14px; }

  /* ── WA FAB + MODAL ── */
  .wa-fab { right: 14px; bottom: 14px; width: 54px; height: 54px; }
  .wa-fab svg { width: 26px; height: 26px; margin: 0 14px; }
  .wa-fab:hover { width: 154px; }
  .wa-modal-panel { padding: 22px 16px 18px; }
  .wa-tel { grid-template-columns: 92px 1fr; }

  /* ── CTA cards ── */
  .card-cta { padding: 9px 14px; font-size: 12.5px; }
}

@media (max-width: 380px) {
  h1.hero-title, .hero h1, .hero-content h1 { font-size: clamp(32px, 12vw, 44px); }
  .ct-tel, .wa-tel { grid-template-columns: 84px 1fr; }
  .stat-strip, .stats, .stats-block { grid-template-columns: 1fr 1fr; gap: 14px; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .aurora,
  .closing-aurora,
  .cta-band::before,
  .form-wrap::before,
  .split-media::before,
  .card-aurora,
  .feature::before {
    animation-duration: 0s !important;
  }
  .hero-ribbon { animation: none; }
  .glow, .stat-strip .num em, .stats-block .num .grad, .stats-block .num em,
  .stats .stat-num .grad {
    animation: none;
    background-position: 0% 50%;
  }
}
