/* ============================================
   LAYOUT — containers, grids, responsive rules
   Loaded last so responsive overrides win cleanly.
   ============================================ */

.container {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 clamp(20px, 4vw, 48px);
}

/* Releases grid */
.releases-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 24px;
}

/* Bio grid */
.bio-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 5vw, 80px);
  align-items: center;
}

/* Press grid */
.press-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 24px;
}

/* Contact grid */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: clamp(32px, 5vw, 80px);
}

/* Form row */
.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

/* Footer layout */
.footer__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px;
}

/* ============================================
   RESPONSIVE BREAKPOINTS
   ============================================ */

@media (max-width: 768px) {
  .nav__hamburger { display: flex; }
  .nav__links {
    position: fixed;
    top: var(--nav-h);
    left: 0;
    right: 0;
    bottom: 0;
    background: var(--bg-black);
    flex-direction: column;
    justify-content: center;
    gap: 32px;
    transform: translateX(100%);
    transition: transform 0.4s ease;
  }
  .nav__links.open { transform: translateX(0); }
  .nav__links a { font-size: 1rem; }

  .bio-grid { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; }
}

@media (max-width: 600px) {
  .show-item {
    grid-template-columns: 60px 1fr;
    gap: 12px;
    padding: 16px;
  }
  .show-item__action {
    grid-column: 1 / -1;
    display: flex;
    justify-content: flex-end;
  }
  .show-item__day { font-size: 1.3rem; }

  .footer__inner {
    flex-direction: column;
    text-align: center;
    gap: 12px;
  }
}

@media (max-width: 500px) {
  .form-row { grid-template-columns: 1fr; }
}

@media (max-width: 400px) {
  .releases-grid { grid-template-columns: 1fr; }
}

/* ============================================
   REDUCED MOTION
   Component-scoped overrides + global catch-all
   ============================================ */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .reveal { opacity: 1; transform: none; transition: none; }
  .nav__logo .led { animation: none; }
  .btn:hover { transform: none; }
  .hero__scroll-line { animation: none; opacity: 0.5; }

  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
