/* ============================================
   Runtime — reglas mínimas para que la landing
   funcione con vanilla JS en lugar de React
   (mount/unmount → toggle por atributo/clase).
   No altera el diseño visual.
   ============================================ */

[hidden] { display: none !important; }

/* WhatsApp widget: el FAB alterna ícono según estado abierto */
.wa-widget:not(.wa-widget--open) .wa-fab__icon-close { display: none; }
.wa-widget.wa-widget--open .wa-fab__icon-open { display: none; }
.wa-fab__icon-open,
.wa-fab__icon-close { display: flex; align-items: center; justify-content: center; }

/* Showcase: solo la vista activa visible */
.showcase__view { display: block; }
.showcase__view[hidden] { display: none !important; }

/* ============================================
   Planes: lista de beneficios colapsable
   ============================================ */
/* Selector más específico que `.plan__features li` (sections.css) para
   poder ganar el display por defecto de los <li>. */
.plan__features li.plan__feature--extra { display: none; }
.plan--expanded .plan__features li.plan__feature--extra { display: flex; }

.plan__more {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 6px;
  padding: 4px 0;
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--brand-500);
  cursor: pointer;
  background: none;
  border: 0;
  transition: color 0.15s ease;
}
.plan__more:hover { color: var(--brand-600); }
.plan__more-count { color: var(--text-faint); }
.plan__more-chev {
  display: inline-flex;
  transition: transform 0.2s ease;
}
.plan--expanded .plan__more-chev { transform: rotate(180deg); }

/* Plan destacado (fondo oscuro): el botón necesita contraste claro */
.plan.recommended .plan__more { color: rgba(255, 255, 255, 0.85); }
.plan.recommended .plan__more:hover { color: #fff; }
.plan.recommended .plan__more-count { color: rgba(255, 255, 255, 0.5); }

/* ============================================
   Nav — menú hamburguesa para mobile
   ============================================ */
.nav__hamburger {
  display: none;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  align-items: center;
  justify-content: center;
  color: var(--text-soft);
  background: none;
  border: 0;
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease;
}
.nav__hamburger:hover { background: var(--surface-2); color: var(--text); }
.nav__hamburger-open,
.nav__hamburger-close { display: inline-flex; align-items: center; }
.nav__hamburger-close { display: none; }
.nav--mobile-open .nav__hamburger-open { display: none; }
.nav--mobile-open .nav__hamburger-close { display: inline-flex; }

/* Panel desplegable mobile */
.nav__mobile {
  pointer-events: auto;
  width: min(100%, 1100px);
  background: color-mix(in srgb, var(--bg) 94%, transparent);
  backdrop-filter: saturate(140%) blur(14px);
  -webkit-backdrop-filter: saturate(140%) blur(14px);
  border: 1px solid var(--border);
  border-radius: var(--r-4);
  box-shadow: var(--shadow-md);
  padding: 10px;
  flex-direction: column;
  gap: 2px;
  display: none;
}
.nav__mobile-link {
  padding: 11px 14px;
  border-radius: var(--r-2);
  font-size: 15px;
  font-weight: 500;
  color: var(--text-soft);
  transition: background 0.15s ease, color 0.15s ease;
}
.nav__mobile-link:hover { background: var(--surface-2); color: var(--text); }
.nav__mobile-divider { height: 1px; background: var(--border); margin: 6px 4px; }
.nav__mobile-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  margin-top: 4px;
  padding: 12px 14px;
  border-radius: var(--r-full);
  background: var(--text);
  color: var(--bg);
  font-size: 15px;
  font-weight: 500;
  transition: background 0.15s ease, color 0.15s ease;
}
.nav__mobile-cta:hover { background: var(--brand-500); color: #fff; }

@media (max-width: 820px) {
  .nav { flex-direction: column; align-items: center; gap: 8px; }
  .nav__hamburger { display: inline-flex; }
  .nav__mobile:not([hidden]) { display: flex; }
}
