/* ============================================== */
/* Layout — secciones del index                   */
/* ============================================== */

@layer components {

  /* ============================================== */
  /* 1. Hero                                        */
  /* ============================================== */

  .hero {
    padding-top: var(--space-12);
  }

  .hero-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-12);
    align-items: center;
  }

  @media (min-width: 960px) {
    .hero-grid {
      grid-template-columns: 7fr 5fr;
      gap: var(--space-16);
    }
  }

  .hero-copy {
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
  }

  .hero h1 {
    margin: 0;
  }

  .hero-sub {
    font-size: var(--fs-body-lg);
    color: hsl(var(--ink-dim));
    max-width: 52ch;
    margin: 0;
  }

  .hero .store-badges {
    margin-top: var(--space-2);
  }

  .hero-secondary {
    font-size: var(--fs-sm);
    color: hsl(var(--ink-dim));
    letter-spacing: 0.02em;
    margin-top: var(--space-2);
    align-self: flex-start;
  }

  .hero-secondary:hover {
    color: hsl(var(--dorado));
    text-decoration: none;
  }

  .hero-image {
    aspect-ratio: 4 / 5;
    width: 100%;
    min-height: 320px;
  }

  @media (min-width: 960px) {
    .hero-image {
      aspect-ratio: 4 / 5;
      min-height: 480px;
      margin: 0;
    }
  }

  /* ============================================== */
  /* 2. Trayectoria                                 */
  /* ============================================== */

  .trayectoria {
    padding-block: var(--space-12);
    background: hsl(var(--bg-deep));
    border-top: 1px solid hsl(var(--line-soft));
    border-bottom: 1px solid hsl(var(--line-soft));
  }

  .trayectoria-line {
    font-family: var(--font-body);
    font-size: var(--fs-body-lg);
    font-weight: 500;
    text-align: center;
    color: hsl(var(--dorado));
    letter-spacing: 0.01em;
    margin: 0 auto;
    max-width: none;
  }

  /* ============================================== */
  /* 3. El gym                                      */
  /* ============================================== */

  .gym .overline {
    margin-bottom: var(--space-3);
  }

  .gym h2 {
    margin: 0 0 var(--space-8);
    max-width: 18ch;
  }

  .gym-text {
    font-size: var(--fs-body-lg);
    color: hsl(var(--ink-dim));
    max-width: 60ch;
    margin: 0 0 var(--space-12);
  }

  .gym-photos {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }

  .gym-photos .photo {
    width: 100%;
    margin: 0;
  }

  .photo-a { aspect-ratio: 4 / 5; }
  .photo-b { aspect-ratio: 1 / 1; }
  .photo-c { aspect-ratio: 1 / 1; }

  @media (min-width: 720px) {
    .gym-photos {
      grid-template-columns: 2fr 1fr;
      grid-template-rows: auto auto;
      gap: var(--space-6);
    }

    .photo-a {
      grid-column: 1;
      grid-row: 1 / span 2;
      aspect-ratio: 4 / 5;
    }

    .photo-b {
      grid-column: 2;
      grid-row: 1;
      aspect-ratio: 1 / 1;
    }

    .photo-c {
      grid-column: 2;
      grid-row: 2;
      aspect-ratio: 1 / 1;
      transform: translateY(var(--space-8));
    }
  }

  /* ============================================== */
  /* 4. La app                                      */
  /* ============================================== */

  .app-section {
    background: hsl(var(--bg-deep));
  }

  .app-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-12);
    align-items: center;
  }

  @media (min-width: 960px) {
    .app-grid {
      grid-template-columns: 5fr 7fr;
      gap: var(--space-16);
    }

    .app-mockup {
      order: -1;
    }
  }

  .app-copy .overline {
    margin-bottom: var(--space-3);
  }

  .app-copy h2 {
    margin: 0 0 var(--space-4);
    max-width: 22ch;
  }

  .app-sub {
    font-size: var(--fs-body-lg);
    color: hsl(var(--ink-dim));
    max-width: 56ch;
    margin: 0 0 var(--space-12);
  }

  .app-features {
    list-style: none;
    padding: 0;
    margin: 0 0 var(--space-12);
    display: flex;
    flex-direction: column;
    gap: var(--space-8);
    border-top: 1px solid hsl(var(--line-soft));
  }

  .app-features li {
    padding-top: var(--space-6);
    border-bottom: 1px solid hsl(var(--line-soft));
    padding-bottom: var(--space-6);
  }

  .app-features h3 {
    font-size: var(--fs-h3);
    margin: 0 0 var(--space-2);
  }

  .app-features p {
    color: hsl(var(--ink-dim));
    max-width: 50ch;
    margin: 0;
  }

  .app-mockup {
    aspect-ratio: 9 / 18;
    width: 100%;
    max-width: 320px;
    margin: 0 auto;
    min-height: 480px;
    transform: rotate(-2deg);
  }

  @media (min-width: 960px) {
    .app-mockup {
      max-width: 360px;
      min-height: 600px;
    }
  }

  /* ============================================== */
  /* 5. Pasos                                       */
  /* ============================================== */

  .pasos .overline {
    margin-bottom: var(--space-3);
  }

  .pasos h2 {
    margin: 0 0 var(--space-12);
    max-width: 22ch;
  }

  .pasos-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-12);
  }

  @media (min-width: 720px) {
    .pasos-list {
      grid-template-columns: repeat(3, 1fr);
      gap: var(--space-8);
    }
  }

  .pasos-list li {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
  }

  .paso-num {
    font-family: var(--font-display);
    font-size: clamp(3.5rem, 6vw + 1rem, 5rem);
    font-weight: 900;
    line-height: 0.95;
    color: hsl(var(--dorado));
    letter-spacing: -0.03em;
  }

  .pasos-list h3 {
    font-size: var(--fs-h3);
    margin: 0;
  }

  .pasos-list p {
    color: hsl(var(--ink-dim));
    max-width: 36ch;
    margin: 0;
  }

  .pasos-help {
    margin-top: var(--space-12);
    font-size: var(--fs-body);
    max-width: none;
  }

  /* ============================================== */
  /* 6. Visitanos                                   */
  /* ============================================== */

  .visitanos {
    background: hsl(var(--bg-deep));
  }

  .visitanos .overline {
    margin-bottom: var(--space-3);
  }

  .visitanos h2 {
    margin: 0 0 var(--space-12);
    max-width: 18ch;
  }

  .visitanos-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  @media (min-width: 720px) {
    .visitanos-grid {
      grid-template-columns: repeat(3, 1fr);
      gap: var(--space-12);
    }
  }

  .visitanos-block h4 {
    font-family: var(--font-body);
    font-size: var(--fs-xs);
    letter-spacing: var(--tracking-overline);
    text-transform: uppercase;
    font-weight: 600;
    color: hsl(var(--ink-dim));
    margin: 0 0 var(--space-3);
  }

  .visitanos-block p {
    font-size: var(--fs-body-lg);
    line-height: 1.6;
    margin: 0;
    max-width: none;
  }

  .visitanos-block a {
    color: hsl(var(--dorado));
    text-underline-offset: 4px;
  }

  .visitanos-block a:hover {
    color: hsl(var(--dorado-light));
  }

  /* ============================================== */
  /* 7. CTA final                                   */
  /* ============================================== */
  /* TODO: cuando entre la foto del gym, agregar    */
  /* <picture> de fondo con vignette y overlay.     */

  .cta-final {
    background:
      radial-gradient(
        ellipse at center,
        hsl(var(--bg-raised)) 0%,
        hsl(var(--bg-deep)) 70%
      );
    text-align: center;
    border-top: 1px solid hsl(var(--line-soft));
  }

  .cta-final h2 {
    font-size: var(--fs-display);
    line-height: var(--lh-display);
    letter-spacing: var(--tracking-display);
    margin: 0 0 var(--space-12);
    text-wrap: balance;
  }

  .cta-final .store-badges {
    justify-content: center;
  }
}
