/* =========================================
   BASE — Variables, reset y utilidades
   ========================================= */

:root {
  /* === PALETA === */

  /* Principal: teal del logo y derivados */
  --teal: #1E7682;
  --teal-oscuro: #0F4951;
  --teal-claro: #2A9BAA;
  --teal-muy-oscuro: #0A2E33;

  /* Acentos */
  --lima: #C5F408;          /* acción, CTAs, energía */
  --lima-suave: #D4F73C;    /* hover del lima */
  --cian: #44DCF1;          /* highlights, detalles, líneas */
  --cian-suave: #6FE5F4;    /* hover del cian */

  /* Neutros */
  --fondo: #F5FAFB;         /* blanco azulado para el body */
  --fondo-alt: #E8F4F6;     /* alternativa para secciones */
  --texto: #0F2F35;         /* oscuro alineado con teal */
  --texto-suave: #4A6970;
  --blanco: #ffffff;

  /* === Aliases semánticos (si en el futuro cambias la paleta, solo tocas estos) === */
  --color-principal: var(--teal);
  --color-principal-oscuro: var(--teal-oscuro);
  --color-principal-claro: var(--teal-claro);
  --color-accion: var(--lima);
  --color-accion-hover: var(--lima-suave);
  --color-detalle: var(--cian);

  /* === Tipografía === */
  --fuente-display: 'Cormorant Garamond', Georgia, serif;
  --fuente-cuerpo: 'Inter', system-ui, sans-serif;

  /* === Dimensiones === */
  --header-h: 90px;
  --player-h: 78px;
  --max-w: 1280px;

  /* === Sombras === */
  --sombra-suave: 0 4px 20px rgba(15, 73, 81, 0.08);
  --sombra-media: 0 8px 30px rgba(15, 73, 81, 0.15);
  --sombra-fuerte: 0 12px 40px rgba(15, 73, 81, 0.25);
  --sombra-lima: 0 8px 24px rgba(197, 244, 8, 0.35);

  /* === Transiciones === */
  --ease: cubic-bezier(0.4, 0, 0.2, 1);
}

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

html {
  scroll-behavior: smooth;
  scroll-padding-top: var(--header-h);
}

body {
  font-family: var(--fuente-cuerpo);
  color: var(--texto);
  background: var(--fondo);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

img, svg { display: block; max-width: 100%; }
a { color: inherit; }
button { font-family: inherit; }

/* === Botones === */
.btn {
  padding: 0.9rem 2rem;
  border-radius: 50px;
  text-decoration: none;
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.5px;
  transition: all 0.3s var(--ease);
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  border: none;
  cursor: pointer;
}

.btn-primary {
  background: var(--lima);
  color: var(--teal-muy-oscuro);
  box-shadow: var(--sombra-lima);
}
.btn-primary:hover {
  background: var(--lima-suave);
  transform: translateY(-3px);
  box-shadow: 0 12px 30px rgba(197, 244, 8, 0.5);
}

.btn-outline {
  background: transparent;
  color: var(--blanco);
  border: 1.5px solid rgba(255, 255, 255, 0.3);
}
.btn-outline:hover {
  background: rgba(68, 220, 241, 0.1);
  border-color: var(--cian);
  color: var(--cian);
}

/* === Reveal (animación al hacer scroll) === */
.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.9s var(--ease), transform 0.9s var(--ease);
}
.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* === Footer-spacer y contenedor sticky-player ===
   El reproductor ahora vive dentro de un contenedor con position: sticky
   que se queda anclado al fondo del viewport mientras el contenedor
   está visible, y se desplaza con él cuando llegamos al footer.
*/
.player-stage {
  position: relative;
  /* altura mínima para que el sticky tenga "pista" hasta justo antes del footer */
}

/* === Accesibilidad: respeta usuarios que prefieren menos animación === */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
  .reveal { opacity: 1; transform: none; }
}
