/* theme_user.css — variables de color (López Coronado) */
:root{
  --primary-color: #105b63;
  --secondary-color: #18929d;
  --active-color: #a2dda0;
  --soft-color: #f9fefb;
  --highlight-color: rgba(236,138,52,0.5);
  --text-color: #111;
}

/* --- HERO: asegurar márgenes y comportamiento en móviles --- */

/* Evita recortes de la sombra y sube capa del bloque visual */
.hero__visual {
  position: relative;
  z-index: 2;
  overflow: visible;
}

/* Sombra (override suave sobre theme.css si quieres más presencia) */
.hero__visual img {
  display: block;
  max-width: 100%;
  height: auto;
  border-radius: 0.5rem;
  box-shadow:
    0 18px 48px rgba(0, 0, 0, 0.22),
    0 10px 20px rgba(0, 0, 0, 0.12);
}

/* iPhone y móviles estrechos */
@media (max-width: 430px) {
  /* Respeta el notch y da aire lateral */
  .hero {
    padding-left: max(1rem, env(safe-area-inset-left));
    padding-right: max(1rem, env(safe-area-inset-right));
  }

  /* Una columna en vertical; el aire lateral lo pone .hero */
  .hero__inner {
    grid-template-columns: 1fr;
    gap: 1.25rem;
    padding: 2rem 0;
  }
}

/* iPad vertical (un poco más ancho) */
@media (min-width: 431px) and (max-width: 820px) and (orientation: portrait) {
  .hero {
    padding-left: max(1rem, env(safe-area-inset-left));
    padding-right: max(1rem, env(safe-area-inset-right));
  }
  .hero__inner {
    grid-template-columns: 1fr;
    gap: 1.5rem;
    padding: 3rem 0;
  }
}

/* --- FORMULARIO: respiro a la derecha en móvil --- */
.contact form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding-right: 1rem;
}
.contact form input,
.contact form textarea,
.contact form button {
  width: 100%;
  box-sizing: border-box;
}

/* --- REVEAL: animación de entrada suave --- */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 600ms ease, transform 600ms ease;
  will-change: opacity, transform;
}
.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}
/* Stagger opcional via data-delay (en ms) */
.reveal[data-delay] { transition-delay: calc(var(--reveal-delay, 0ms)); }

/* Accesibilidad: respeta reduce motion */
@media (prefers-reduced-motion: reduce) {
  .reveal {
    transition: none;
    transform: none;
    opacity: 1;
  }
}

/* Un pelín más de presencia en pantallas grandes */
@media (min-width: 992px) {
  .reveal { transform: translateY(28px); }
}