@media (max-width: 768px) {
  .hero-section {
    min-height: 50vh;
    min-height: 50svh;
  }

  /* Bootstrap g-5 rows have negative margins wider than the container's
     padding on small viewports — collapse the horizontal gutter to stop
     the body from scrolling sideways. */
  .row.g-5 {
    --bs-gutter-x: 1.5rem;
  }

  .hero-slide-content {
    padding: 2rem 1.5rem 2.75rem;
    gap: 1.25rem;
  }

  .hero-carousel__indicators {
    bottom: 1rem;
  }

  .hero-copy {
    padding-top: 0;
  }

  h1.display-title {
    font-size: 45px;
    line-height: 49px;
  }
  .icon-link {
    width: 26px;
    height: 45px;
    font-size: 1.5rem;
    line-height: 1.5rem;
  }

  .newsletter-title {
    font-size: 35px;
  }
  #about-artist .portrait-frame {
    max-width: 75%;
    margin: 0 auto 1.75rem;
  }

  #about-artist .portrait-frame img {
    object-fit: contain !important;
  }

  #about-artist .copy-panel > .mini-badge {
    float: left;
    width: 44px;
    height: 44px;
    margin: 0 0.85rem 0 0;
    border-width: 1.5px;
  }

  #about-artist .copy-panel > .mini-badge img {
    padding: 5px;
  }

  #about-artist .copy-panel > .section-title {
    font-size: 1.55rem;
    line-height: 1.15;
    margin: 0 0 1.25rem;
    overflow: hidden;
    min-height: 44px;
    display: flex;
    align-items: center;
  }

  #about-artist .copy-panel > .lead-copy {
    clear: both;
  }

  #venue > .container > .row {
    flex-direction: column-reverse;
  }

  #venue .venue-visual {
    max-width: 75%;
    margin: 0 auto;
  }

  #venue .stats-row {
    text-align: center;
  }

  #venue .btn-brand {
    width: 100%;
  }
  .content-section {
    padding: 3rem 0;
  }

  .section-title {
    font-size: 32px;
    line-height: 39px;
  }
  .lead-copy {
    margin-top: 15px;
  }
  .stats-row {
    text-align: center;
  }
  .footer-links li + li,
  .footer-contact li + li {
    margin-top: 7px;
  }
  .footer-grid {
    padding: 7px 0;
  }
  .footer-top {
    padding-bottom: 15px;
  }
  .site-footer {
    padding: 25px 0 15px;
  }
  .footer-bottom {
    padding-top: 1rem;
    text-align: center;
  }
}

@media (max-width: 767.98px) {
  .newsletter-form {
    width: 100%;
    display: flex !important;
    flex-wrap: nowrap !important;
    align-items: stretch !important;
    gap: 0;
  }

  .newsletter-form > .col-md-6,
  .newsletter-form > .col-lg-5 {
    flex: 1 1 0% !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
  }

  .newsletter-form > .col-auto {
    flex: 0 0 auto !important;
    width: auto !important;
  }

  .newsletter-form .form-control {
    min-width: 0;
    width: 100%;
  }

  .newsletter-btn {
    width: 60px;
    min-width: 60px;
  }
}

@media (max-width: 991.98px) {
  .navbar-collapse {
    padding-top: 1.5rem;
  }

  .hero-copy {
    padding-top: 8rem;
  }

  .section-path {
    margin-bottom: 3rem;
  }

  .content-section {
    padding: 5rem 0;
  }

  .venue-section {
    padding-top: 0;
  }
}

@media (max-width: 767.98px) {
  .navbar {
    min-height: 78px;
  }

  .brand-mark {
    width: 50px;
    height: 50px;
    font-size: 0.9rem;
  }

  .display-title {
    font-size: clamp(3.35rem, 18vw, 5rem);
  }

  .hero-description,
  .lead-copy {
    font-size: 1rem;
    line-height: 1.8;
  }

  .section-kicker {
    font-size: 0.95rem;
    letter-spacing: 0.24em;
  }

  .section-kicker::before {
    width: 2.25rem;
  }

  .ticker-track {
    font-size: 0.9rem;
    letter-spacing: 0.18em;
  }

  .newsletter-section {
    padding: 4.5rem 0;
  }

  .newsletter-form .col-auto,
  .newsletter-form .col-md-6,
  .newsletter-form .col-lg-5 {
    width: 100%;
  }

  .newsletter-btn {
    width: 100%;
  }

  .footer-bottom {
    font-size: 0.88rem;
  }
}