/* ============================================================
   HITO HUB — CAPA DE SITIO (sobre style.css)
   Títulos más grandes + animados, iconografía Phosphor,
   grid bento. Carga DESPUÉS de style.css para sobrescribir.
   ============================================================ */

/* ── TÍTULOS MÁS GRANDES (Funnel Display) ── */
.hero-h1 { font-size: clamp(44px, 6.5vw, 88px); letter-spacing: -0.045em; line-height: 1.04; }
h2.section-title { font-size: clamp(34px, 5vw, 64px); line-height: 1.04; }
.cta-box h2 { font-size: clamp(34px, 5vw, 60px); line-height: 1.05; }

/* ── ICONOGRAFÍA PHOSPHOR (peso light, estilo Apple) ── */
/* Iconos negros con glow lima de marca, grandes, SIN caja oscura. */
.pain-card-icon, .activator-ico {
  width: auto; height: auto; background: none; border-radius: 0;
  display: block; margin-bottom: 24px;
}
.pain-card-icon i, .activator-ico i {
  font-size: 60px; line-height: 1; color: var(--c-ink);
  filter: drop-shadow(0 0 10px rgba(232,255,87,0.85)) drop-shadow(0 0 30px rgba(232,255,87,0.6));
  transition: color var(--dur) var(--ease);
}
.contact-ico i { font-size: 24px; color: var(--c-ink); line-height: 1; }
.check-list .icon i { font-size: 20px; line-height: 1; }
.check-list .icon.yes i { color: var(--c-ink); }
.check-list .icon.no  i { color: var(--c-muted); }
.trust-ico i { font-size: 19px; color: var(--c-muted); line-height: 1; }

/* ── HERO INTERNO FULL-BLEED (título de lado a lado) ── */
.internal .hero-box {
  width: 100vw; margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw);
  border-radius: 0;
  padding: 120px max(48px, calc(50vw - 600px)) 96px;
}
.internal .hero-box::before { display: none; } /* sin borde interior en banda */
.internal .hero-box::after { background: linear-gradient(90deg, rgba(17,25,12,0.96) 30%, rgba(17,25,12,0.55) 60%, rgba(17,25,12,0.06) 100%); }
.internal .hero-h1 { max-width: 760px; }
@media (max-width: 768px) {
  .internal .hero-box { padding: 80px 24px 64px; }
}

/* ── PARTNERS · CARRUSEL INFINITO (arrastrable) ── */
.partners-marquee {
  position: relative; overflow: hidden; touch-action: pan-y;
}
.partners-marquee::before, .partners-marquee::after {
  content: ''; position: absolute; top: 0; width: 90px; height: 100%; z-index: 2; pointer-events: none;
}
.partners-marquee::before { left: 0; background: linear-gradient(to right, var(--c-ink), transparent); }
.partners-marquee::after { right: 0; background: linear-gradient(to left, var(--c-ink), transparent); }
.partners-track {
  display: flex; align-items: center; gap: 64px;
  width: max-content; cursor: grab; will-change: transform;
}
.partners-track.dragging { cursor: grabbing; }
.partner-item { flex-shrink: 0; display: flex; align-items: center; user-select: none; -webkit-user-select: none; }
.partner-item img {
  height: 30px; width: auto; opacity: 0.7; pointer-events: none;
  transition: opacity var(--dur) var(--ease);
}
.partner-item:hover img { opacity: 1; }
@media (max-width: 600px) {
  .partners-marquee::before, .partners-marquee::after { width: 50px; }
  .partners-track { gap: 44px; }
}

/* ── CARDS CON SÍMBOLO DE MARCA (watermark "O") + HOVER ── */
.activator-card, .pain-card {
  position: relative; overflow: hidden;
  transition: background .28s var(--ease), border-color .28s var(--ease),
              box-shadow .28s var(--ease);
}
.activator-card::before, .pain-card::before {
  content: ''; position: absolute; z-index: 0; pointer-events: none;
  right: -62%; bottom: -55%; width: 155%; aspect-ratio: 757 / 797;
  background: url('../assets/simbolo.svg') no-repeat center / contain;
  opacity: 0.9; transition: opacity .28s var(--ease);
}
.activator-card > *, .pain-card > * { position: relative; z-index: 1; }

/* Variación de esquina/rotación por tarjeta (no idénticas); siempre ~30% visible */
.pain-grid > .pain-card:nth-child(2)::before,
.bento > .activator-card:nth-child(2)::before { right: auto; left: -62%; top: -55%; bottom: auto; transform: rotate(135deg); }
.pain-grid > .pain-card:nth-child(3)::before,
.bento > .activator-card:nth-child(3)::before { right: -60%; top: -58%; bottom: auto; transform: rotate(-55deg); }
.bento > .activator-card:nth-child(4)::before { left: -60%; bottom: -55%; right: auto; transform: rotate(40deg); }
.bento > .activator-card:nth-child(5)::before { right: -62%; top: -50%; bottom: auto; transform: rotate(15deg); }
.bento > .activator-card:nth-child(6)::before { left: -58%; bottom: -58%; right: auto; transform: rotate(-25deg); }

/* HOVER: fondo oscuro, texto claro, símbolo encendido + glow lima */
.activator-card:hover, .pain-card:hover {
  background: var(--c-ink); border-color: var(--c-ink);
  box-shadow: 0 0 0 1px rgba(232,255,87,0.4), 0 18px 60px rgba(232,255,87,0.28);
}
/* En hover, el símbolo pasa a contorno (línea) para que el texto blanco se lea */
.activator-card:hover::before, .pain-card:hover::before {
  opacity: 1; background-image: url('../assets/simbolo-line.svg');
}
.activator-card:hover h3, .pain-card:hover h3 { color: #fff; }
.activator-card:hover p, .pain-card:hover p { color: rgba(255,255,255,0.62); }
.activator-card:hover .activator-link { color: var(--c-accent); }
.activator-card:hover .activator-ico i, .pain-card:hover .pain-card-icon i { color: #fff; }

/* ── GRID BENTO (referente cipher) ── */
.bento {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 16px; margin-top: 48px;
}
.bento .activator-card {
  display: flex; flex-direction: column; justify-content: space-between;
  min-height: 230px;
}
.bento .activator-card.wide { grid-column: span 2; }
@media (max-width: 900px) {
  .bento { grid-template-columns: repeat(2, 1fr); }
  .bento .activator-card.wide { grid-column: span 2; }
}
@media (max-width: 560px) {
  .bento { grid-template-columns: 1fr; }
  .bento .activator-card.wide { grid-column: span 1; }
}

/* ── GRILLA ARQUITECTÓNICA (matriz + cruces, estilo cipher) ── */
.arch-grid {
  position: fixed; inset: 0; z-index: -1; pointer-events: none; overflow: hidden;
  background-image: url('../assets/grid-cell.svg');
  background-repeat: repeat;
  background-size: clamp(300px, 30vw, 480px) clamp(300px, 30vw, 480px);
  background-position: center center;
}
.arch-grid span { display: none; } /* (las líneas ahora son el tile de fondo) */
/* Scan lima en movimiento: una banda tenue recorre la grilla */
.arch-grid::after {
  content: ''; position: absolute; left: 0; right: 0; height: 180px;
  background: linear-gradient(to bottom, transparent, rgba(232,255,87,0.10), transparent);
  animation: gridScan 9s linear infinite; will-change: transform;
}
@keyframes gridScan {
  from { transform: translateY(-200px); }
  to   { transform: translateY(100vh); }
}
@media (prefers-reduced-motion: reduce) { .arch-grid::after { display: none; } }
/* La grilla va detrás (z-index:-1, sobre el fondo); el contenido transparente la deja ver. */

/* ── HOME HERO MONOLITO (pantalla completa, video scrub) ── */
.home-hero {
  position: relative; min-height: 100vh; overflow: hidden;
  display: flex; align-items: center; background: var(--c-ink);
}
.hero-video-wrap { position: absolute; inset: 0; z-index: 0; }
.hero-video-wrap video { width: 100%; height: 100%; object-fit: cover; display: block; }
.home-hero::after {
  content: ''; position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(90deg, rgba(0,0,0,0.6) 26%, rgba(0,0,0,0.13) 60%, rgba(17,25,12,0) 100%);
}
.home-hero-inner {
  position: relative; z-index: 2;
  max-width: var(--max); margin: 0 auto; padding: 0 48px; width: 100%;
}
.home-scroll-cue {
  position: absolute; bottom: 28px; left: 48px; z-index: 2;
  font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--c-on-dark-3);
}
@media (max-width: 768px) {
  .home-hero-inner { padding: 0 24px; }
  .home-scroll-cue { left: 24px; }
}

/* Nav transparente sobre el hero; sólido al hacer scroll */
.home nav {
  position: fixed; top: 0; left: 0; right: 0;
  background: transparent; border-bottom-color: transparent; backdrop-filter: none;
  transition: background .3s var(--ease), border-color .3s var(--ease);
}
.home nav .nav-logo-img { filter: brightness(0) invert(1); transition: filter .3s var(--ease); }
.home nav .nav-links a { color: rgba(255,255,255,0.72); }
.home nav .nav-links a:hover { color: #fff; background: rgba(255,255,255,0.1); }
.home nav:not(.scrolled) .nav-cta { background: var(--c-accent); color: var(--c-ink); }
.home nav.scrolled {
  background: rgba(245,245,245,0.92); backdrop-filter: blur(12px);
  border-bottom-color: var(--c-line);
}
.home nav.scrolled .nav-logo-img { filter: none; }
.home nav.scrolled .nav-links a { color: var(--c-muted); }
.home nav.scrolled .nav-links a:hover { color: var(--c-ink); }

/* ============================================================
   ESTADOS INICIALES DE ANIMACIÓN
   Solo activos cuando <html class="anim"> (lo pone anim-init.js
   únicamente si el usuario NO pidió reduced-motion). GSAP los
   revela. Si GSAP falla, site.js quita .anim y todo se ve.
   ============================================================ */
.anim .hero-box .hero-eyebrow,
.anim .hero-box .hero-h1,
.anim .hero-box .hero-sub,
.anim .hero-box .btn-primary,
.anim .hero-box .btn-microcopy,
.anim .eyebrow,
.anim h2.section-title,
.anim .section-intro,
.anim .pain-card,
.anim .feature-col,
.anim .level-card,
.anim .step,
.anim .activator-card,
.anim .check-list li,
.anim .cta-box > *,
.anim .content-body > *,
.anim .home-hero .home-hero-inner > * {
  opacity: 0;
}

/* ============================================================
   SHIM — Elementor nativo + nuestras clases (piloto híbrido)
   Asegura que layout y tipografía nuestros ganen sobre el kit.
   ============================================================ */
/* Contenedores con nuestras clases */
.e-con.section { max-width: var(--max); margin: 0 auto; padding: 96px 32px; }
.e-con.bento { display: grid; }
.bento .activator-card.e-con { min-height: 230px; display: flex; flex-direction: column; justify-content: space-between; }

/* Eyebrow nativo: hereda nuestro estilo del wrapper .eyebrow */
.eyebrow .elementor-heading-title {
  font-family: inherit !important; color: inherit !important;
  font-size: inherit !important; letter-spacing: inherit !important;
  line-height: inherit !important; font-weight: inherit !important;
  text-transform: inherit !important; margin: 0 !important;
}
/* Título de card (heading nativo): estilo EXPLÍCITO (antes heredaba → salía pequeño y light) */
.activator-card .elementor-heading-title {
  font-family: var(--font-display) !important;
  font-size: 19px !important; font-weight: 600 !important;
  letter-spacing: -0.02em !important; line-height: 1.25 !important;
  color: var(--c-ink) !important; margin: 0 0 10px !important;
}
.activator-card:hover .elementor-heading-title { color: #fff !important; }
/* Párrafos en peso regular (400) */
.hero-sub, .section-intro, .content-body p, .activator-card p,
.combo-card p, .comp-row p, .etapa p, .pain-card p, .step p,
.elementor-widget-text-editor p { font-weight: 400; }
/* El widget de texto hereda color/tamaño del contenedor */
.activator-card .elementor-widget-text-editor,
.section-intro .elementor-widget-container {
  color: inherit; font-size: inherit;
}
/* Quitar el margen por defecto de los widgets dentro de cards para respetar nuestro espaciado */
.activator-card .elementor-widget { margin: 0 !important; }
.activator-card .elementor-widget:not(:last-child) { margin-bottom: 10px !important; }
.e-con.two-col { display: grid; }
.e-con.content-body { max-width: 680px; }

/* Card como <a>: sin subrayado heredado en ningún texto interno */
a.activator-card, a.activator-card *,
.activator-card a, .activator-card .elementor-heading-title { text-decoration: none !important; }

/* ── Activación Compuesta: combo cards ── */
.combos { display: flex; flex-direction: column; gap: 16px; margin-top: 48px; }
.combo-card { background: #fff; border: 1px solid var(--c-line); border-radius: var(--r-md); padding: 36px; display: grid; grid-template-columns: 260px 1fr; gap: 32px; align-items: start; }
.combo-card.dark { background: var(--c-ink); border-color: var(--c-ink); }
.combo-card h3 { font-size: 20px; font-weight: 600; letter-spacing: -0.02em; margin: 0; }
.combo-card.dark h3 { color: #fff; }
.combo-card p { font-size: 15px; color: var(--c-muted); line-height: 1.75; margin: 0; }
.combo-card.dark p { color: rgba(255,255,255,0.6); }
.combo-tags { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 16px; }
.combo-tags span { background: var(--c-ink); color: #fff; font-size: 12px; font-weight: 600; padding: 4px 12px; border-radius: 20px; }
.combo-card.dark .combo-tags span { background: rgba(255,255,255,0.15); }
/* shims nativos */
.e-con.combos { display: flex; flex-direction: column; }
.e-con.combo-card { display: grid; }
.e-con.three-cols { display: grid; }
@media (max-width: 768px) { .combo-card, .e-con.combo-card { grid-template-columns: 1fr; gap: 16px; } }

/* ── Sistema HITO: filas de componentes ── */
.comp-list { display: flex; flex-direction: column; gap: 2px; margin-top: 48px; }
.comp-row { background: #fff; border: 1px solid var(--c-line); border-radius: var(--r-md); padding: 32px 36px; display: grid; grid-template-columns: 200px 1fr; gap: 24px; align-items: start; }
.comp-num { font-size: 11px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--c-muted); margin-bottom: 6px; }
.comp-row h3 { font-size: 18px; font-weight: 600; letter-spacing: -0.02em; margin: 0; }
.comp-row p { font-size: 15px; color: var(--c-muted); line-height: 1.7; margin: 0; }
.e-con.comp-list { display: flex; flex-direction: column; }
.e-con.comp-row { display: grid; }
@media (max-width: 768px) { .comp-row, .e-con.comp-row { grid-template-columns: 1fr; gap: 8px; } }

/* ── Cómo trabajamos: etapas ── */
.etapas { display: flex; flex-direction: column; gap: 2px; margin-top: 48px; }
.etapa { border-radius: var(--r-md); padding: 48px; display: grid; grid-template-columns: 1fr 2fr; gap: 40px; align-items: start; background: #fff; border: 1px solid var(--c-line); }
.etapa.dark { background: var(--c-ink); border-color: var(--c-ink); }
.etapa-num { font-size: 64px; font-weight: 700; letter-spacing: -0.04em; line-height: 1; margin-bottom: 16px; color: rgba(0,0,0,0.07); }
.etapa.dark .etapa-num { color: rgba(255,255,255,0.15); }
.etapa h3 { font-size: 28px; font-weight: 600; letter-spacing: -0.03em; margin: 0; }
.etapa.dark h3 { color: #fff; }
.etapa p { font-size: 16px; color: var(--c-muted); line-height: 1.75; margin: 0 0 24px; }
.etapa.dark p { color: rgba(255,255,255,0.6); }
.etapa-bullets { display: flex; flex-direction: column; gap: 10px; }
.etapa-bullet { display: flex; gap: 12px; font-size: 14px; color: var(--c-muted); }
.etapa-bullet::before { content: '\2192'; font-weight: 700; flex-shrink: 0; }
.etapa.dark .etapa-bullet { color: rgba(255,255,255,0.5); }
.etapa.dark .etapa-bullet::before { color: var(--c-accent); }
.e-con.etapas { display: flex; flex-direction: column; }
.e-con.etapa { display: grid; }
@media (max-width: 768px) { .etapa, .e-con.etapa { grid-template-columns: 1fr; gap: 20px; } }

/* ── Diagnóstico: shims nativos ── */
.e-con.steps-grid { display: grid; }
.steps-grid.steps-2 { grid-template-columns: 1fr 1fr; }
.e-con.for-whom { display: grid; }
@media (max-width: 768px) { .steps-grid.steps-2 { grid-template-columns: 1fr; } }
