/* Mobile styles: loaded after tablet.css */
@media (max-width: 560px) {
  .container {
    width: min(100% - 28px, var(--max));
  }

  .brand-logo {
    width: min(235px, 68vw);
    max-height: 68px;
  }

  .menu-toggle {
    min-width: 2.8rem;
    min-height: 2.8rem;
  }

  .tagline {
    font-size: 1rem;
  }

  .hero-inner,
  .page-hero .container {
    min-height: 470px;
    padding: 3rem 0 4rem;
  }

  .hero-card {
    max-width: 100%;
    padding: 1.25rem;
  }

  .hero h1,
  .page-hero h1 {
    font-size: clamp(2rem, 10vw, 2.65rem);
  }

  .button-row,
  .notice-card {
    flex-direction: column;
    align-items: stretch;
  }

  .notice {
    padding-top: 1.25rem;
  }

  .notice-card {
    gap: 0.8rem;
    padding: 1rem;
    text-align: center;
  }

  .notice-card p span {
    display: block;
    margin-top: 0.5rem;
  }

  .notice-card h3 {
    margin: 0;
  }

  .notice-icon {
    align-self: center;
  }

  .btn {
    width: 100%;
  }

  .section,
  .muted {
    padding: 3rem 0;
  }

  .notice + .section {
    padding-top: 4rem;
  }

  .section-title {
    font-size: clamp(1.75rem, 9vw, 2.35rem);
  }

  .card-body {
    padding: 2.4rem 1.25rem 1.4rem;
  }

  .image-stack {
    min-height: 0;
    display: grid;
    gap: 1rem;
  }

  .image-stack img:first-child,
  .image-stack img:last-child,
  .love-image-main,
  .play-image-main,
  .love-image-small .play-image-small {
    position: static;
    width: 100%;
    transform: none;
  }

  .love-image-small {
    top: 9rem;
  }

  .testimonial-grid {
    gap: 3rem;
  }

  .love-gallery,
  .play-gallery {
    display: grid;
    gap: 1rem;
    min-height: 0;
    padding-right: 0;
  }

  .info-item {
    grid-template-columns: 3.25rem 1fr;
  }

  .info-icon {
    width: 3.25rem;
    height: 3.25rem;
    font-size: 3.25rem;
  }

  .gallery-grid {
    grid-template-columns: 1fr;
  }

  .gallery-carousel-stage {
    min-height: 420px;
  }

  .gallery-slide figcaption {
    padding: 1rem;
  }

  .gallery-carousel-controls {
    gap: 0.75rem;
  }

  .carousel-control {
    width: 2.75rem;
    height: 2.75rem;
  }
}
