
:root {
  --ivory: #f8f8f8;
  --soft-white: #fffdf8;
  --charcoal: #1a1a18;
  --muted: #77756f;
  --blue-gray: #76818a;
  --blue-gray-dark: #56616a;
  --champagne: #d5c3a0;
  --line: #e8dfd1;
  --editorial-width: 1132px;
  --editorial-gutter: clamp(42px, 9.6vw, 185px);
  --editorial-container: min(var(--editorial-width), calc(100% - var(--editorial-gutter)));
  --editorial-accent: #aab3c8;
}

.seo-page-title {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

@media (min-width: 641px) {
  main.events-redesign .event-hero h1 {
    color: #ffffff !important;
  }

  main.events-redesign .event-hero .event-eyebrow,
  main.events-redesign .event-hero-copy > p:not(.event-eyebrow) {
    color: #d9dee8 !important;
  }
}

.home-final-cta .final-cta-heading,
.home-final-cta .final-cta-heading span {
  color: #ffffff !important;
}

/* Home mobile atmosphere invitation. */
@media (max-width: 640px) {
  .home-wedding-preview .mobile-atmosphere-trigger {
    display: grid;
    min-height: 0;
    grid-template-columns: 1fr;
    justify-items: center;
    gap: 20px;
    padding: 38px 0 32px;
    text-align: center;
  }

  .home-wedding-preview .mobile-atmosphere-label {
    display: grid;
    justify-items: center;
    gap: 18px;
  }

  .home-wedding-preview .mobile-atmosphere-label-text {
    display: block;
    color: #394047;
    font-size: 10.4px;
    letter-spacing: .18em;
    line-height: 1.5;
    text-align: center;
  }

  .home-wedding-preview .mobile-atmosphere-featured {
    display: block;
    color: #394047;
    font-family: Montserrat, sans-serif;
    font-size: 10.4px;
    font-weight: 400;
    letter-spacing: 0;
    line-height: 1.7;
    text-align: center;
    text-transform: none;
  }

  .home-wedding-preview .mobile-atmosphere-icon {
    font-size: 18px;
    line-height: 1;
  }
}

@media (max-width: 640px) {
  .about-editorial-redesign .about-closing-invitation h2 {
    width: 100%;
    text-align: center !important;
  }
}

/* Shared mobile action-button sizing and tighter Events CTA ending. */
@media (max-width: 640px) {
  main.events-redesign .event-contact-cta {
    padding-bottom: 21px !important;
  }

  main.events-redesign .event-listening-guide .event-listening-button,
  main.song-list-redesign .song-button,
  main.song-collection-page .song-collection-actions a,
  main .contact-page .event-tab,
  main .contact-page .form-submit {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 143px !important;
    min-width: 143px !important;
    max-width: 143px !important;
    height: 36px !important;
    min-height: 36px !important;
    max-height: 36px !important;
    padding: 0 !important;
    font-size: 10.4px !important;
    font-weight: 400 !important;
    letter-spacing: 1.04px !important;
    line-height: 1.2 !important;
  }

  main.events-redesign .event-listening-guide .event-listening-button {
    margin-right: auto !important;
    margin-left: auto !important;
  }

  main.song-collection-page .song-collection-actions {
    justify-content: center !important;
  }

  main .contact-page .event-choice-grid {
    grid-template-columns: repeat(2, 143px) !important;
    justify-content: center !important;
    gap: 12px !important;
  }

  main .contact-page .form-submit {
    margin-right: auto !important;
    margin-left: auto !important;
  }
}

/* Final mobile button spacing override. */
@media (max-width: 640px) {
  main.events-redesign .event-contact-cta {
    margin-bottom: -7px !important;
    padding-bottom: 0 !important;
  }

  main.events-redesign .event-listening-guide .event-listening-button,
  main.song-list-redesign .song-button,
  main.song-collection-page .song-collection-actions a,
  main .contact-page .event-tab,
  main .contact-page .form-submit {
    width: 143px !important;
    min-width: 143px !important;
    max-width: 143px !important;
    height: 36px !important;
    min-height: 36px !important;
    max-height: 36px !important;
    padding: 0 !important;
  }
}

/* Events mobile copy refinements. */
@media (max-width: 640px) {
  main.events-redesign .event-contact-cta > :not(.event-contact-cta-image) {
    transform: translateY(-56px);
  }
}

/* Events mobile CTA: longer, softer image-to-copy transition. */
@media (max-width: 640px) {
  main.events-redesign .event-contact-cta {
    padding-top: 348px !important;
  }

  main.events-redesign .event-contact-cta-image {
    height: 336px !important;
    background:
      linear-gradient(
        to bottom,
        rgba(250, 250, 250, 0) 0%,
        rgba(250, 250, 250, .03) 28%,
        rgba(250, 250, 250, .16) 52%,
        rgba(250, 250, 250, .5) 72%,
        rgba(250, 250, 250, .86) 89%,
        #fafafa 100%
      ),
      url("images/placeholders/adam-event-CAT-portrait.jpg") center center / cover no-repeat !important;
  }

  main.events-redesign .event-contact-cta .event-premium-label {
    text-align: center !important;
  }

  main.events-redesign .event-contact-cta .event-button {
    margin-right: auto !important;
    margin-left: auto !important;
  }
}

/* Unified compact mobile collection players. */
@media (max-width: 640px) {
  main.events-redesign .event-contact-cta-image {
    background:
      linear-gradient(
        to bottom,
        rgba(250, 250, 250, 0) 0%,
        rgba(250, 250, 250, .03) 28%,
        rgba(250, 250, 250, .16) 52%,
        rgba(250, 250, 250, .5) 72%,
        rgba(250, 250, 250, .86) 89%,
        #fafafa 100%
      ),
      url("images/placeholders/adam-event-CAT-portrait.jpg") center center / cover no-repeat !important;
  }

  main .song-collection-tracks,
  main.events-redesign .event-corporate-player.song-collection-tracks {
    display: grid !important;
    grid-template-rows: 54px minmax(0, 1fr) !important;
    width: 100% !important;
    height: 300px !important;
    min-height: 300px !important;
    max-height: 300px !important;
    border-radius: 0 !important;
    overflow: hidden !important;
  }

  main .song-collection-player-header,
  main.events-redesign .event-corporate-player .song-collection-player-header {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    min-height: 54px !important;
    padding: 7px 12px !important;
  }

  main .song-collection-player-meta h2,
  main.events-redesign .event-corporate-player .song-collection-player-meta h2 {
    max-width: 168px !important;
    margin: 0 !important;
    font-size: 11px !important;
    line-height: 1.3 !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }

  main .song-collection-player-controls,
  main.events-redesign .event-corporate-player .song-collection-player-controls {
    gap: 1px !important;
  }

  main .song-collection-player-controls button,
  main.events-redesign .event-corporate-player .song-collection-player-controls button {
    width: 28px !important;
    min-width: 28px !important;
    height: 28px !important;
    min-height: 28px !important;
    font-size: 18px !important;
  }

  main .song-collection-player-controls .song-collection-main-play,
  main.events-redesign .event-corporate-player .song-collection-player-controls .song-collection-main-play {
    width: 34px !important;
    min-width: 34px !important;
    height: 34px !important;
    min-height: 34px !important;
    margin-left: 3px !important;
    font-size: 11px !important;
  }

  main .song-collection-track-area,
  main.events-redesign .event-corporate-player .song-collection-track-area {
    display: grid !important;
    grid-template-rows: 28px minmax(0, 1fr) !important;
    min-height: 0 !important;
    padding: 0 12px 8px !important;
  }

  main .song-collection-track-header,
  main.events-redesign .event-corporate-player .song-collection-track-header {
    padding: 7px 0 5px !important;
  }

  main .song-detail-list,
  main.events-redesign .event-corporate-player .song-detail-list {
    min-height: 0 !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
  }

  main.song-collection-page .song-detail-song,
  main.events-redesign .event-corporate-player.song-collection-page .song-detail-song {
    display: grid !important;
    grid-template-columns: 20px minmax(82px, .75fr) minmax(142px, 1.25fr) !important;
    gap: 6px !important;
    align-items: center !important;
    min-height: 38px !important;
    padding: 4px 0 !important;
    border-top: 1px solid rgba(255, 255, 255, .24) !important;
  }

  main.song-collection-page .song-detail-song:last-child,
  main.events-redesign .event-corporate-player.song-collection-page .song-detail-song:last-child {
    border-bottom: 1px solid rgba(255, 255, 255, .24) !important;
  }

  main .song-track-number,
  main.events-redesign .event-corporate-player .song-track-number {
    font-size: 7.5px !important;
  }

  main .song-track-meta,
  main.events-redesign .event-corporate-player .song-track-meta {
    grid-column: 2 !important;
    gap: 0 !important;
    min-width: 0 !important;
  }

  main .song-detail-title,
  main.events-redesign .event-corporate-player .song-detail-title {
    overflow: hidden !important;
    font-size: 10px !important;
    line-height: 1.2 !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }

  main .song-track-artist,
  main.events-redesign .event-corporate-player .song-track-artist {
    font-size: 7px !important;
    line-height: 1.2 !important;
  }

  main .song-inline-player,
  main.events-redesign .event-corporate-player .song-inline-player {
    display: grid !important;
    grid-column: 3 !important;
    grid-template-columns: 22px minmax(0, 1fr) 28px !important;
    gap: 5px !important;
    align-items: center !important;
    width: 100% !important;
  }

  main .song-inline-play,
  main.events-redesign .event-corporate-player .song-inline-play {
    display: grid !important;
    width: 22px !important;
    height: 22px !important;
    place-items: center !important;
  }

  main .song-inline-wave,
  main.events-redesign .event-corporate-player .song-inline-wave {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    height: 18px !important;
  }

  main .song-inline-time,
  main.events-redesign .event-corporate-player .song-inline-time {
    display: block !important;
    width: 28px !important;
    font-size: 7px !important;
    text-align: right !important;
  }
}

@media (max-width: 640px) {
  .song-player .song-player-main {
    display: grid !important;
    width: min(280px, calc(100vw - 62px)) !important;
    grid-template-columns: 1fr !important;
    justify-items: center !important;
    margin-right: auto !important;
    margin-left: auto !important;
  }

  .song-player .song-player-title,
  .song-player .song-player-wave {
    box-sizing: border-box !important;
    width: 100% !important;
    max-width: none !important;
    margin-right: auto !important;
    margin-left: auto !important;
    text-align: center !important;
  }

  .song-player .song-player-title {
    justify-content: center !important;
  }

  .song-player .song-player-wave {
    position: relative !important;
    left: auto !important;
    transform: none !important;
  }

  .home-page .site-footer {
    position: relative !important;
    left: 50% !important;
    box-sizing: border-box !important;
    width: 100vw !important;
    max-width: none !important;
    margin-right: 0 !important;
    margin-left: 0 !important;
    transform: translateX(-50%) !important;
  }
}

/* Final restored mobile collection waveforms and full-width home footer block. */
@media (max-width: 640px) {
  main.song-collection-page .song-detail-song,
  main.events-redesign .event-corporate-player.song-collection-page .song-detail-song {
    grid-template-columns: 20px minmax(82px, .75fr) minmax(142px, 1.25fr) !important;
    gap: 6px !important;
    min-height: 38px !important;
    padding: 4px 0 !important;
  }

  main .song-inline-player,
  main.events-redesign .event-corporate-player .song-inline-player {
    display: grid !important;
    width: 100% !important;
    grid-template-columns: 22px minmax(0, 1fr) 28px !important;
    gap: 5px !important;
    align-items: center !important;
  }

  main .song-inline-play,
  main.events-redesign .event-corporate-player .song-inline-play {
    width: 22px !important;
    height: 22px !important;
  }

  main .song-inline-wave,
  main.events-redesign .event-corporate-player .song-inline-wave {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    height: 18px !important;
  }

  main .song-inline-time,
  main.events-redesign .event-corporate-player .song-inline-time {
    display: block !important;
    width: 28px !important;
    font-size: 7px !important;
    text-align: right !important;
  }

  .song-player .song-player-main {
    width: 100% !important;
    justify-items: center !important;
  }

  .song-player .song-player-wave {
    position: relative !important;
    left: 50% !important;
    width: min(280px, calc(100vw - 62px)) !important;
    max-width: none !important;
    margin-right: 0 !important;
    margin-left: 0 !important;
    transform: translateX(-50%) !important;
  }

  .home-page .site-footer {
    position: relative !important;
    left: 50% !important;
    box-sizing: border-box !important;
    width: 100vw !important;
    max-width: none !important;
    margin-right: 0 !important;
    margin-left: 0 !important;
    transform: translateX(-50%) !important;
  }
}

/* Restore mobile collection waveforms and full-width home footer block. */
@media (max-width: 640px) {
  main.song-collection-page .song-detail-song,
  main.events-redesign .event-corporate-player.song-collection-page .song-detail-song {
    grid-template-columns: 20px minmax(82px, .75fr) minmax(142px, 1.25fr) !important;
    gap: 6px !important;
    min-height: 38px !important;
    padding: 4px 0 !important;
  }

  main .song-inline-player,
  main.events-redesign .event-corporate-player .song-inline-player {
    display: grid !important;
    width: 100% !important;
    grid-template-columns: 22px minmax(0, 1fr) 28px !important;
    gap: 5px !important;
    align-items: center !important;
  }

  main .song-inline-play,
  main.events-redesign .event-corporate-player .song-inline-play {
    width: 22px !important;
    height: 22px !important;
  }

  main .song-inline-wave,
  main.events-redesign .event-corporate-player .song-inline-wave {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    height: 18px !important;
  }

  main .song-inline-time,
  main.events-redesign .event-corporate-player .song-inline-time {
    display: block !important;
    width: 28px !important;
    font-size: 7px !important;
    text-align: right !important;
  }

  .song-player .song-player-main {
    width: 100% !important;
    justify-items: center !important;
  }

  .song-player .song-player-wave {
    position: relative !important;
    left: 50% !important;
    width: min(280px, calc(100vw - 62px)) !important;
    max-width: none !important;
    margin-right: 0 !important;
    margin-left: 0 !important;
    transform: translateX(-50%) !important;
  }

  .home-page .site-footer {
    position: relative !important;
    left: 50% !important;
    box-sizing: border-box !important;
    width: 100vw !important;
    max-width: none !important;
    margin-right: 0 !important;
    margin-left: 0 !important;
    transform: translateX(-50%) !important;
  }
}

/* Final centered Song List collection action buttons. */
.song-collection-page .song-collection-actions {
  justify-content: center !important;
  text-align: center !important;
}

.song-collection-page .song-collection-actions a {
  margin-right: auto !important;
  margin-left: auto !important;
}

/* Center Song List collection action buttons. */
.song-collection-page .song-collection-actions {
  justify-content: center !important;
  text-align: center !important;
}

.song-collection-page .song-collection-actions a {
  margin-right: auto !important;
  margin-left: auto !important;
}

/* Final Song List headings and shared solid CTA buttons. */
@media (max-width: 640px) {
  .song-list-redesign .song-featured-editorial-title,
  .song-list-redesign .song-collection-page-title,
  .song-list-redesign .song-collection-copy h2,
  .song-list-redesign .song-preview-notes h2,
  .song-list-redesign .song-collection-custom h2 {
    font-size: 31.2px !important;
    font-weight: 400 !important;
    letter-spacing: -1.248px !important;
    line-height: 34.32px !important;
  }

  .weddings-redesign .wedding-hero-actions {
    width: 100% !important;
    align-items: center !important;
  }

  .weddings-redesign .wedding-hero-actions .wedding-button,
  .about-editorial-redesign .about-closing-invitation .about-filled-button {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 143px !important;
    min-width: 143px !important;
    max-width: 143px !important;
    height: 36px !important;
    min-height: 36px !important;
    max-height: 36px !important;
    margin-right: auto !important;
    margin-left: auto !important;
    padding: 0 !important;
    border: 0 !important;
    background: #f2f3f5 !important;
    color: #7f8ea2 !important;
    font-size: 10.4px !important;
    font-weight: 400 !important;
    letter-spacing: 1.04px !important;
    line-height: 1.2 !important;
  }
}

/* Song List headings and shared solid CTA buttons. */
@media (max-width: 640px) {
  .song-list-redesign .song-featured-editorial-title,
  .song-list-redesign .song-collection-page-title,
  .song-list-redesign .song-collection-copy h2,
  .song-list-redesign .song-preview-notes h2,
  .song-list-redesign .song-collection-custom h2 {
    font-size: 31.2px !important;
    font-weight: 400 !important;
    letter-spacing: -1.248px !important;
    line-height: 34.32px !important;
  }

  .weddings-redesign .wedding-hero-actions {
    width: 100% !important;
    align-items: center !important;
  }

  .weddings-redesign .wedding-hero-actions .wedding-button,
  .about-editorial-redesign .about-closing-invitation .about-filled-button {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 143px !important;
    min-width: 143px !important;
    max-width: 143px !important;
    height: 36px !important;
    min-height: 36px !important;
    max-height: 36px !important;
    margin-right: auto !important;
    margin-left: auto !important;
    padding: 0 !important;
    border: 0 !important;
    background: #f2f3f5 !important;
    color: #7f8ea2 !important;
    font-size: 10.4px !important;
    font-weight: 400 !important;
    letter-spacing: 1.04px !important;
    line-height: 1.2 !important;
  }
}

/* Final About mobile full-width closing color block. */
@media (max-width: 640px) {
  .about-editorial-redesign .about-closing-invitation {
    position: relative !important;
    left: 50% !important;
    box-sizing: border-box !important;
    width: 100vw !important;
    max-width: none !important;
    margin-right: 0 !important;
    margin-left: 0 !important;
    padding-right: max(31px, calc((100vw - 328px) / 2)) !important;
    padding-left: max(31px, calc((100vw - 328px) / 2)) !important;
    transform: translateX(-50%) !important;
  }
}

/* About mobile closing invitation uses a full-width color block. */
@media (max-width: 640px) {
  .about-editorial-redesign .about-closing-invitation {
    position: relative !important;
    left: 50% !important;
    box-sizing: border-box !important;
    width: 100vw !important;
    max-width: none !important;
    margin-right: 0 !important;
    margin-left: 0 !important;
    padding-right: max(31px, calc((100vw - 328px) / 2)) !important;
    padding-left: max(31px, calc((100vw - 328px) / 2)) !important;
    transform: translateX(-50%) !important;
  }
}

.home-final-cta .final-cta-heading,
.home-final-cta .final-cta-heading span {
  color: #ffffff !important;
}

/* Final compact home atmosphere invitation spacing. */
@media (max-width: 640px) {
  .home-wedding-preview .mobile-atmosphere-trigger {
    gap: 10px !important;
    padding-top: 19px !important;
    padding-bottom: 16px !important;
  }

  .home-wedding-preview .mobile-atmosphere-label {
    gap: 9px !important;
  }

  .home-wedding-preview .mobile-atmosphere-featured {
    margin-bottom: 0 !important;
  }
}

/* Compact home atmosphere invitation spacing. */
@media (max-width: 640px) {
  .home-wedding-preview .mobile-atmosphere-trigger {
    gap: 10px !important;
    padding-top: 19px !important;
    padding-bottom: 16px !important;
  }

  .home-wedding-preview .mobile-atmosphere-label {
    gap: 9px !important;
  }

  .home-wedding-preview .mobile-atmosphere-featured {
    margin-bottom: 0 !important;
  }
}

/* Final open-mobile-navigation scroll lock. */
@media (max-width: 640px) {
  html:has(body.nav-is-open),
  body.nav-is-open {
    height: 100dvh !important;
    overflow: hidden !important;
    overscroll-behavior: none !important;
    touch-action: none !important;
  }

  body.nav-is-open .site-header .site-nav.is-open {
    height: 100dvh !important;
    overflow: hidden !important;
    overscroll-behavior: none !important;
    touch-action: none !important;
  }

  body.nav-is-open .site-header .site-nav.is-open a,
  body.nav-is-open .site-header .site-nav.is-open button {
    touch-action: manipulation !important;
  }
}

/* Lock the open mobile navigation in place. */
@media (max-width: 640px) {
  html:has(body.nav-is-open),
  body.nav-is-open {
    height: 100dvh !important;
    overflow: hidden !important;
    overscroll-behavior: none !important;
    touch-action: none !important;
  }

  body.nav-is-open .site-header .site-nav.is-open {
    height: 100dvh !important;
    overflow: hidden !important;
    overscroll-behavior: none !important;
    touch-action: none !important;
  }

  body.nav-is-open .site-header .site-nav.is-open a,
  body.nav-is-open .site-header .site-nav.is-open button {
    touch-action: manipulation !important;
  }
}

/* Final Moses-inspired AG mark inside the open mobile navigation. */
@media (max-width: 640px) {
  body.nav-is-open .site-header > .wordmark {
    opacity: 0 !important;
    pointer-events: none !important;
  }

  .site-header .site-nav .mobile-nav-logo,
  .site-header .site-nav.is-open .mobile-nav-logo {
    position: absolute !important;
    top: max(24px, calc(14px + env(safe-area-inset-top))) !important;
    left: 50% !important;
    display: grid !important;
    width: 62px !important;
    min-width: 62px !important;
    height: 62px !important;
    min-height: 62px !important;
    place-items: center !important;
    padding: 0 !important;
    border: 0 !important;
    transform: translateX(-50%) !important;
  }

  .site-header .site-nav .mobile-nav-logo img {
    display: block !important;
    width: 58px !important;
    height: 58px !important;
    object-fit: contain !important;
  }

  .site-header .site-nav,
  .site-header .site-nav.is-open {
    padding-top: max(122px, calc(108px + env(safe-area-inset-top))) !important;
  }
}

/* Moses-inspired AG mark inside the open mobile navigation. */
@media (max-width: 640px) {
  body.nav-is-open .site-header > .wordmark {
    opacity: 0 !important;
    pointer-events: none !important;
  }

  .site-header .site-nav .mobile-nav-logo,
  .site-header .site-nav.is-open .mobile-nav-logo {
    position: absolute !important;
    top: max(24px, calc(14px + env(safe-area-inset-top))) !important;
    left: 50% !important;
    display: grid !important;
    width: 62px !important;
    min-width: 62px !important;
    height: 62px !important;
    min-height: 62px !important;
    place-items: center !important;
    padding: 0 !important;
    border: 0 !important;
    transform: translateX(-50%) !important;
  }

  .site-header .site-nav .mobile-nav-logo img {
    display: block !important;
    width: 58px !important;
    height: 58px !important;
    object-fit: contain !important;
  }

  .site-header .site-nav,
  .site-header .site-nav.is-open {
    padding-top: max(122px, calc(108px + env(safe-area-inset-top))) !important;
  }
}

/* Final home mobile atmosphere invitation. */
@media (max-width: 640px) {
  .home-wedding-preview .mobile-atmosphere-trigger {
    display: grid !important;
    min-height: 0 !important;
    grid-template-columns: 1fr !important;
    justify-items: center !important;
    gap: 10px !important;
    padding: 19px 0 16px !important;
    text-align: center !important;
  }

  .home-wedding-preview .mobile-atmosphere-label {
    display: grid !important;
    justify-items: center !important;
    gap: 9px !important;
  }

  .home-wedding-preview .mobile-atmosphere-label-text {
    display: block !important;
    font-size: 10.4px !important;
    letter-spacing: .18em !important;
    line-height: 1.5 !important;
    text-align: center !important;
  }

  .home-wedding-preview .mobile-atmosphere-featured {
    display: block !important;
    color: #394047 !important;
    font-family: Montserrat, sans-serif !important;
    font-size: 10.4px !important;
    font-weight: 400 !important;
    letter-spacing: 0 !important;
    line-height: 1.7 !important;
    text-align: center !important;
    text-transform: none !important;
  }

  .home-wedding-preview .mobile-atmosphere-icon {
    font-size: 18px !important;
    line-height: 1 !important;
  }
}

/* Final global mobile text gutter. */
@media (max-width: 640px) {
  :root {
    --mobile-text-width: min(calc(100vw - 62px), 328px);
  }

  .artist-copy,
  .why-adam-intro,
  .why-adam-list,
  .ceremony-intro-headline,
  .ceremony-intro-copy,
  .ceremony-feeling-copy,
  .service-copy,
  .final-cta-copy,
  .about-editorial-redesign .about-hero-copy,
  .about-editorial-redesign .about-journey-header,
  .about-editorial-redesign .journey-block,
  .about-editorial-redesign .about-timeline-copy,
  .about-editorial-redesign .about-closing-copy,
  .weddings-redesign .wedding-hero-copy,
  .weddings-redesign .wedding-section-intro,
  .weddings-redesign .wedding-row-copy,
  .weddings-redesign .wedding-personalized-heading,
  .weddings-redesign .wedding-personalized-copy,
  .weddings-redesign .wedding-personalized-features,
  .weddings-redesign .wedding-final-copy,
  .events-redesign .event-hero-copy,
  .events-redesign .event-about-adam-copy,
  .events-redesign .event-listening-intro,
  .events-redesign .event-listening-guide,
  .events-redesign .event-client-reasons,
  .song-list-redesign .song-featured-copy,
  .song-list-redesign .song-collection-copy,
  .song-list-redesign .song-collection-custom,
  .faq-page .faq-background-title,
  .faq-page .faq-side-label,
  .faq-page .faq-questions,
  .contact-page,
  .contact-page .contact-copy,
  .contact-page .event-selection {
    box-sizing: border-box !important;
    width: var(--mobile-text-width) !important;
    max-width: var(--mobile-text-width) !important;
    margin-right: auto !important;
    margin-left: auto !important;
  }

  .events-redesign .event-contact-cta > p {
    box-sizing: border-box !important;
    width: var(--mobile-text-width) !important;
    max-width: var(--mobile-text-width) !important;
    margin-right: auto !important;
    margin-left: auto !important;
  }

  .home-final-cta .final-cta-copy,
  .about-editorial-redesign .about-closing-invitation,
  .events-redesign .event-contact-cta {
    padding-right: 31px !important;
    padding-left: 31px !important;
  }
}

/* Global mobile text gutter: equal left and right space on every page. */
@media (max-width: 640px) {
  :root {
    --mobile-text-width: min(calc(100vw - 62px), 328px);
  }

  .artist-copy,
  .why-adam-intro,
  .why-adam-list,
  .ceremony-intro-headline,
  .ceremony-intro-copy,
  .ceremony-feeling-copy,
  .service-copy,
  .final-cta-copy,
  .about-editorial-redesign .about-hero-copy,
  .about-editorial-redesign .about-journey-header,
  .about-editorial-redesign .journey-block,
  .about-editorial-redesign .about-timeline-copy,
  .about-editorial-redesign .about-closing-copy,
  .weddings-redesign .wedding-hero-copy,
  .weddings-redesign .wedding-section-intro,
  .weddings-redesign .wedding-row-copy,
  .weddings-redesign .wedding-personalized-heading,
  .weddings-redesign .wedding-personalized-copy,
  .weddings-redesign .wedding-personalized-features,
  .weddings-redesign .wedding-final-copy,
  .events-redesign .event-hero-copy,
  .events-redesign .event-about-adam-copy,
  .events-redesign .event-listening-intro,
  .events-redesign .event-listening-guide,
  .events-redesign .event-client-reasons,
  .song-list-redesign .song-featured-copy,
  .song-list-redesign .song-collection-copy,
  .song-list-redesign .song-collection-custom,
  .faq-page .faq-background-title,
  .faq-page .faq-side-label,
  .faq-page .faq-questions,
  .contact-page,
  .contact-page .contact-copy,
  .contact-page .event-selection {
    box-sizing: border-box !important;
    width: var(--mobile-text-width) !important;
    max-width: var(--mobile-text-width) !important;
    margin-right: auto !important;
    margin-left: auto !important;
  }

  .events-redesign .event-contact-cta > p {
    box-sizing: border-box !important;
    width: var(--mobile-text-width) !important;
    max-width: var(--mobile-text-width) !important;
    margin-right: auto !important;
    margin-left: auto !important;
  }

  .home-final-cta .final-cta-copy,
  .about-editorial-redesign .about-closing-invitation,
  .events-redesign .event-contact-cta {
    padding-right: 31px !important;
    padding-left: 31px !important;
  }
}

@media (max-width: 640px) {
  .about-editorial-redesign .about-closing-invitation h2 {
    width: 100% !important;
    text-align: center !important;
  }
}

/* Final shared mobile action-button sizing and Events CTA ending. */
@media (max-width: 640px) {
  main.events-redesign .event-contact-cta {
    padding-bottom: 21px !important;
  }

  main.events-redesign .event-listening-guide .event-listening-button,
  main.song-list-redesign .song-button,
  main.song-collection-page .song-collection-actions a,
  main .contact-page .event-tab,
  main .contact-page .form-submit {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 143px !important;
    min-width: 143px !important;
    max-width: 143px !important;
    height: 36px !important;
    min-height: 36px !important;
    max-height: 36px !important;
    padding: 0 !important;
    font-size: 10.4px !important;
    font-weight: 400 !important;
    letter-spacing: 1.04px !important;
    line-height: 1.2 !important;
  }

  main.events-redesign .event-listening-guide .event-listening-button {
    margin-right: auto !important;
    margin-left: auto !important;
  }

  main.song-collection-page .song-collection-actions {
    justify-content: center !important;
  }

  main .contact-page .event-choice-grid {
    grid-template-columns: repeat(2, 143px) !important;
    justify-content: center !important;
    gap: 12px !important;
  }

  main .contact-page .form-submit {
    margin-right: auto !important;
    margin-left: auto !important;
  }
}

/* Final Events mobile alignment, spacing, and page-scroll behavior. */
@media (max-width: 640px) {
  main.events-redesign .event-contact-cta .event-premium-label {
    width: 100% !important;
    margin-right: auto !important;
    margin-left: auto !important;
    text-align: center !important;
  }

  main.events-redesign .event-listening-guide {
    margin-top: 56px !important;
  }

  main.events-redesign .event-corporate-player,
  main.events-redesign .event-corporate-player .song-collection-track-area,
  main.events-redesign .event-corporate-player .song-detail-list {
    overscroll-behavior: auto !important;
    touch-action: pan-y !important;
  }

  main.events-redesign .event-corporate-player .song-detail-list {
    overflow-y: hidden !important;
  }
}

/* Events mobile alignment, spacing, and page-scroll behavior. */
@media (max-width: 640px) {
  main.events-redesign .event-contact-cta .event-premium-label {
    width: 100% !important;
    margin-right: auto !important;
    margin-left: auto !important;
    text-align: center !important;
  }

  main.events-redesign .event-listening-guide {
    margin-top: 56px !important;
  }

  main.events-redesign .event-corporate-player,
  main.events-redesign .event-corporate-player .song-collection-track-area,
  main.events-redesign .event-corporate-player .song-detail-list {
    overscroll-behavior: auto !important;
    touch-action: pan-y !important;
  }

  main.events-redesign .event-corporate-player .song-detail-list {
    overflow-y: hidden !important;
  }
}

/* Final Events mobile CTA copy position. */
@media (max-width: 640px) {
  main.events-redesign .event-contact-cta > :not(.event-contact-cta-image) {
    transform: translateY(-56px) !important;
  }
}

/* Final Events mobile CTA transition and alignment. */
@media (max-width: 640px) {
  main.events-redesign .event-contact-cta {
    padding-top: 348px !important;
  }

  main.events-redesign .event-contact-cta-image {
    height: 336px !important;
    background:
      linear-gradient(
        to bottom,
        rgba(250, 250, 250, 0) 0%,
        rgba(250, 250, 250, .03) 28%,
        rgba(250, 250, 250, .16) 52%,
        rgba(250, 250, 250, .5) 72%,
        rgba(250, 250, 250, .86) 89%,
        #fafafa 100%
      ),
      url("images/placeholders/adam-event-CAT-portrait.jpg") center center / cover no-repeat !important;
  }

  main.events-redesign .event-contact-cta .event-premium-label {
    text-align: center !important;
  }

  main.events-redesign .event-contact-cta .event-button {
    margin-right: auto !important;
    margin-left: auto !important;
  }
}

/* Events and FAQ mobile correction pass. */
@media (max-width: 640px) {
  main.events-redesign .event-hero-copy > p:not(.event-eyebrow) {
    text-align: center !important;
  }

  main.events-redesign .event-about-adam-portrait-mobile {
    height: auto !important;
    aspect-ratio: auto !important;
    overflow: visible !important;
  }

  main.events-redesign .event-about-adam-portrait-mobile img {
    display: block !important;
    width: 100% !important;
    height: auto !important;
    object-fit: contain !important;
    object-position: center !important;
  }

  main.events-redesign .event-contact-cta-image {
    background:
      linear-gradient(to bottom, rgba(250, 250, 250, .05) 0%, rgba(250, 250, 250, .18) 58%, #fafafa 100%),
      url("images/footer-cta-adam-piano1.jpg") center 42% / cover no-repeat !important;
  }

  main.events-redesign .event-featured-listening-inner {
    width: 100% !important;
    margin: 24px 0 0 !important;
  }

  main.events-redesign .event-corporate-player.song-collection-tracks {
    display: block !important;
    height: auto !important;
    min-height: 0 !important;
    border-radius: 0 !important;
    overflow: visible !important;
  }

  main.events-redesign .event-corporate-player .song-collection-player-header {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    min-height: 74px !important;
    padding: 12px 14px !important;
  }

  main.events-redesign .event-corporate-player .song-collection-player-meta h2 {
    max-width: 172px !important;
    font-size: 12px !important;
    line-height: 1.35 !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }

  main.events-redesign .event-corporate-player .song-collection-player-controls {
    gap: 2px !important;
  }

  main.events-redesign .event-corporate-player .song-collection-player-controls button {
    width: 30px !important;
    min-width: 30px !important;
    height: 30px !important;
    min-height: 30px !important;
    font-size: 21px !important;
  }

  main.events-redesign .event-corporate-player .song-collection-player-controls .song-collection-main-play {
    width: 40px !important;
    min-width: 40px !important;
    height: 40px !important;
    min-height: 40px !important;
    margin-left: 4px !important;
    font-size: 13px !important;
  }

  main.events-redesign .event-corporate-player .song-collection-track-area {
    display: block !important;
    padding: 0 14px 12px !important;
  }

  main.events-redesign .event-corporate-player .song-collection-track-header {
    padding: 9px 0 7px !important;
  }

  main.events-redesign .event-corporate-player .song-detail-list {
    overflow: visible !important;
  }

  main.events-redesign .event-corporate-player.song-collection-page .song-detail-song {
    display: grid !important;
    grid-template-columns: 24px minmax(0, 1fr) 30px !important;
    gap: 8px !important;
    align-items: center !important;
    min-height: 58px !important;
    padding: 8px 0 !important;
  }

  main.events-redesign .event-corporate-player .song-track-meta {
    grid-column: 2 !important;
    min-width: 0 !important;
  }

  main.events-redesign .event-corporate-player .song-detail-title {
    overflow: hidden !important;
    font-size: 12px !important;
    line-height: 1.35 !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }

  main.events-redesign .event-corporate-player .song-track-artist {
    font-size: 8px !important;
  }

  main.events-redesign .event-corporate-player .song-inline-player {
    display: block !important;
    grid-column: 3 !important;
    width: 30px !important;
  }

  main.events-redesign .event-corporate-player .song-inline-play {
    display: grid !important;
    width: 30px !important;
    height: 30px !important;
    place-items: center !important;
  }

  main.events-redesign .event-corporate-player .song-inline-wave,
  main.events-redesign .event-corporate-player .song-inline-time {
    display: none !important;
  }

  main .faq-background-title,
  main .faq-side-label {
    text-align: center !important;
  }

  main .faq-categories::after {
    display: block !important;
    flex: 0 0 148px !important;
    content: "" !important;
  }
}

.event-about-adam-portrait-mobile,
.event-contact-cta-image {
  display: none;
}

/* Events and FAQ mobile: editorial proportions based on the Moses reference. */
@media (max-width: 640px) {
  .events-redesign .event-hero {
    display: flex;
    height: auto;
    min-height: 0;
    flex-direction: column;
    overflow: visible;
    background: #fafafa;
  }

  .events-redesign .event-hero-placeholder {
    position: relative;
    inset: auto;
    order: 1;
    width: 100%;
    height: auto;
    min-height: 0;
    aspect-ratio: 1 / 1;
    border: 0;
  }

  .events-redesign .event-hero-placeholder::after {
    display: none;
  }

  .events-redesign .event-hero-placeholder img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
  }

  .events-redesign .event-hero-copy {
    position: static;
    order: 2;
    align-items: center;
    width: min(100% - 62px, 328px);
    margin: 0 auto;
    padding: 28px 0 31px;
    color: #333333;
    text-align: center;
  }

  .events-redesign .event-hero .event-eyebrow {
    order: 2;
    margin: 7px 0 0;
    color: #7f8ea2 !important;
    font-size: 9.36px !important;
    line-height: 18.72px !important;
    text-align: center;
  }

  .events-redesign .event-hero h1 {
    order: 1;
    margin: 0;
    color: #333333 !important;
    font-size: 31.2px !important;
    letter-spacing: -1.248px !important;
    line-height: 34.32px !important;
    text-align: center;
    text-shadow: none;
  }

  .events-redesign .event-hero-copy > p:not(.event-eyebrow) {
    order: 3;
    margin: 28px 0 0;
    color: #333333 !important;
    font-size: 11.5px !important;
    line-height: 1.65 !important;
    text-align: left;
  }

  .events-redesign .event-hero .event-button {
    order: 4;
    display: flex;
    width: 143px;
    min-width: 143px;
    height: 36px !important;
    min-height: 36px !important;
    margin: 39px auto 0;
    padding: 0 !important;
    border: 0 !important;
    background: #f2f3f5 !important;
    color: #7f8ea2 !important;
    font-size: 10.4px !important;
    letter-spacing: 1.04px !important;
  }

  .events-redesign .event-premium-section,
  .events-redesign .event-about-adam,
  .events-redesign .event-discovery {
    width: 100%;
    max-width: none;
    margin: 0;
    padding: 46px 31px;
  }

  .events-redesign .event-about-adam {
    display: block;
    background: #f2f3f5;
  }

  .events-redesign .event-about-adam-copy {
    width: 100%;
    max-width: 328px;
    margin: 0 auto;
  }

  .events-redesign .event-about-adam-copy h2,
  .events-redesign .event-listening-guide h2,
  .events-redesign .event-contact-cta .event-premium-label {
    margin: 0 0 28px;
    color: #7f8ea2 !important;
    font-size: 31.2px !important;
    font-weight: 400;
    letter-spacing: -1.248px !important;
    line-height: 34.32px !important;
    text-transform: none;
  }

  .events-redesign .event-about-adam-copy > .event-premium-label {
    margin-bottom: 8px;
  }

  .events-redesign .event-about-adam-portrait:not(.event-about-adam-portrait-mobile) {
    display: none;
  }

  .events-redesign .event-about-adam-portrait-mobile {
    display: block;
    width: 100%;
    height: auto;
    margin: 0 0 31px;
    aspect-ratio: 328 / 189;
    overflow: hidden;
  }

  .events-redesign .event-about-adam-portrait-mobile img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 23%;
  }

  .events-redesign .event-about-adam-copy p:not(.event-premium-label),
  .events-redesign .event-listening-intro > p:not(.event-premium-label),
  .events-redesign .event-listening-guide p,
  .events-redesign .event-client-reasons-grid p,
  .events-redesign .event-contact-cta p:not(.event-premium-label) {
    font-size: 11.5px !important;
    line-height: 1.65 !important;
  }

  .events-redesign .event-discovery-top,
  .events-redesign .event-client-reasons-grid {
    display: block;
  }

  .events-redesign .event-client-reasons {
    margin-top: 52px;
  }

  .events-redesign .event-client-reasons-grid article {
    display: grid;
    grid-template-columns: 32px 1fr;
    gap: 13px;
    padding: 26px 0;
    border-top: 1px solid rgba(127, 142, 162, .24);
  }

  .events-redesign .event-client-reasons-grid article h2 {
    font-size: 22px !important;
    line-height: 1.1 !important;
  }

  .events-redesign .event-contact-cta {
    position: relative;
    display: block;
    width: 100%;
    min-height: 0;
    padding: 270px 31px 42px;
    overflow: hidden;
    background: #fafafa;
    color: #333333;
    text-align: left;
  }

  .events-redesign .event-contact-cta-image {
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    display: block;
    height: 232px;
    background:
      linear-gradient(to bottom, rgba(250, 250, 250, .08), #fafafa 100%),
      url("images/placeholders/corporate-event.jpg") center center / cover no-repeat;
  }

  .events-redesign .event-contact-cta .event-premium-label {
    position: relative;
    margin-bottom: 28px;
    text-align: center;
  }

  .events-redesign .event-contact-cta p:not(.event-premium-label) {
    position: relative;
    color: #333333 !important;
  }

  .events-redesign .event-contact-cta .event-button {
    position: relative;
    display: flex;
    width: 143px;
    min-width: 143px;
    height: 36px !important;
    min-height: 36px !important;
    margin: 39px auto 0;
    padding: 0 !important;
    border: 0 !important;
    background: #f2f3f5 !important;
    color: #7f8ea2 !important;
    font-size: 10.4px !important;
    letter-spacing: 1.04px !important;
  }

  .faq-page {
    width: 100%;
    max-width: none;
    min-height: 0;
    padding: 42px 31px 64px;
    background: #fafafa;
  }

  .faq-layout {
    display: flex;
    width: 100%;
    max-width: 328px;
    flex-direction: column;
    margin: 0 auto;
  }

  .faq-background-title {
    position: static;
    order: 1;
    display: block;
    margin: 0;
    color: #333333 !important;
    font-family: "Bodoni Moda", Georgia, serif;
    font-size: 60px !important;
    font-weight: 300;
    letter-spacing: -3px !important;
    line-height: 1 !important;
    opacity: 1 !important;
    text-transform: uppercase;
  }

  .faq-background-title span {
    display: inline;
  }

  .faq-side-label {
    position: static;
    order: 2;
    margin: 7px 0 0;
    color: #7f8ea2 !important;
    font-family: Montserrat, sans-serif;
    font-size: 9.36px !important;
    letter-spacing: .16em !important;
    line-height: 18.72px !important;
    text-transform: uppercase;
    transform: none;
  }

  .faq-categories {
    display: flex;
    width: calc(100vw - 31px);
    max-width: none;
    margin: 16px 0 0;
    padding: 0 31px 7px 0;
    gap: 0;
    overflow-x: auto;
    scrollbar-width: none;
  }

  .faq-categories::-webkit-scrollbar {
    display: none;
  }

  .faq-category {
    flex: 0 0 auto;
    min-width: 134px;
    padding: 7px 12px 9px;
    border: 0;
    border-bottom: 1px solid transparent;
    background: transparent;
    color: #333333;
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: 15px;
    font-weight: 400;
    letter-spacing: 0;
    line-height: 1.2;
    text-transform: none;
  }

  .faq-category:first-child {
    padding-left: 0;
  }

  .faq-category.is-active {
    border-bottom-color: #7f8ea2;
    background: transparent;
    color: #7f8ea2;
  }

  .faq-questions {
    order: 3;
    width: 100%;
    margin-top: 14px;
  }

  .faq-panel {
    display: none;
  }

  .faq-panel.is-active {
    display: block;
  }

  .faq-question {
    margin: 0 0 22px;
    padding: 0;
    border: 0;
    background: transparent;
  }

  .faq-question h2 {
    margin: 0 0 2px;
    color: #333333;
    font-family: Montserrat, sans-serif;
    font-size: 11px !important;
    font-weight: 500;
    letter-spacing: 0 !important;
    line-height: 1.7 !important;
    text-transform: none;
  }

  .faq-question p,
  .faq-contact-note p {
    margin: 0;
    color: #394047;
    font-size: 10.4px !important;
    line-height: 18.72px !important;
  }

  .faq-contact-note {
    margin-top: 42px;
    padding: 30px 0 0;
    border-top: 1px solid rgba(127, 142, 162, .24);
    text-align: left;
  }

  .faq-contact-button {
    display: flex;
    width: 143px;
    min-width: 143px;
    height: 36px !important;
    min-height: 36px !important;
    margin: 28px 0 0;
    padding: 0 !important;
    border: 0 !important;
    background: #f2f3f5 !important;
    color: #7f8ea2 !important;
    font-size: 10.4px !important;
    letter-spacing: 1.04px !important;
  }
}

@media (max-width: 640px) {
.home-wedding-preview .mobile-featured-song-name {
    font-family: Montserrat, sans-serif !important;
    font-size: 9.5px !important;
    font-weight: 400 !important;
    letter-spacing: 1.9px !important;
    line-height: 13.775px !important;
  }
}
/* Final mobile CTA flow override. */
@media (max-width: 640px) {
  .home-final-cta {
    display: flex !important;
    flex-direction: column;
    min-height: 0;
    margin: 0;
    padding: 0 0 48px;
    background: #fafafa;
  }

  .home-final-cta::before {
    display: none;
    content: none;
  }

  .home-final-cta .final-cta-image {
    position: relative !important;
    inset: auto !important;
    order: 1;
    width: 100%;
    height: 232px;
    min-height: 232px;
  }

  .home-final-cta .final-cta-image::after {
    display: none;
    content: none;
  }

  .home-final-cta .final-cta-copy {
    position: relative;
    order: 2;
    align-items: center;
    width: min(100% - 62px, 328px);
    min-height: 0;
    margin: 0 auto;
    padding: 28px 0 0 !important;
  }

  .home-final-cta .final-cta-heading {
    position: absolute;
    right: 0;
    bottom: calc(100% + 10px);
    left: 0;
    z-index: 3;
    margin: 0;
  }

  .home-final-cta .final-cta-copy .button {
    width: 143px !important;
    min-width: 143px !important;
    height: 36px !important;
    min-height: 36px !important;
  }
}

@media (max-width: 640px) {
.home-final-cta {
    display: flex;
    flex-direction: column;
    min-height: 0;
    margin: 0;
    padding: 0 0 48px;
    background: #fafafa;
    overflow: hidden;
  }
.home-final-cta::before {
    display: none;
    content: none;
  }
.home-final-cta .final-cta-image {
    position: relative;
    inset: auto;
    order: 1;
    width: 100%;
    height: 232px;
    min-height: 232px;
    overflow: hidden;
  }
.home-final-cta .final-cta-image::after {
    display: block;
    background:
      linear-gradient(to bottom, rgba(250, 250, 250, 0) 42%, #fafafa 100%),
      rgba(0, 0, 0, .08);
  }
.home-final-cta .final-cta-image img {
    width: 100%;
    height: 100%;
    object-position: center 34%;
    filter: grayscale(100%);
  }
.home-final-cta .final-cta-copy {
    position: relative;
    z-index: 2;
    order: 2;
    align-items: center;
    width: min(100% - 62px, 328px);
    margin: 0 auto;
    padding: 28px 0 0;
    text-align: left;
  }
.home-final-cta .final-cta-heading {
    align-self: stretch;
    margin-bottom: 28px;
  }
.home-final-cta .final-cta-copy p {
    width: 100%;
    margin: 0 0 19px;
    font-size: 11.5px;
    line-height: 1.65;
    text-align: left;
  }
.home-final-cta .final-cta-copy p:last-of-type {
    margin-bottom: 28px;
  }
.home-final-cta .final-cta-copy .button {
    display: flex;
    width: 143px !important;
    min-width: 143px !important;
    height: 36px !important;
    min-height: 36px !important;
    margin: 0 auto;
    padding: 0 !important;
    border: 0 !important;
    background: #f2f3f5 !important;
    color: #7f8ea2 !important;
    font-size: 10.4px !important;
    font-weight: 400;
    letter-spacing: 1.04px !important;
    line-height: 1;
    text-align: center;
  }
}

@font-face {
  font-family: "Majesty";
  src:
    local("Majesty"),
    url("fonts/Majesty.woff2") format("woff2"),
    url("fonts/Majesty.woff") format("woff"),
    url("fonts/Majesty.otf") format("opentype");
  font-display: swap;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--ivory);
  color: #20252b;
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 22.22px;
  letter-spacing: 0;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.home-page {
  background: #f8f8f8;
}
.home-page .site-header {
  background: rgba(248, 248, 248, .92);
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
.site-header {
  position: sticky;
  top: 0;
  z-index: 40;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  padding: 24px clamp(22px, 5vw, 70px);
  background: rgba(248, 248, 248, 0.92);
  border-bottom: 1px solid rgba(118, 129, 138, 0.18);
  backdrop-filter: blur(18px);
}
.wordmark {
  color: #20252b;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(20px, 2vw, 30px);
  font-weight: 400;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  white-space: nowrap;
}
.site-nav {
  display: flex;
  align-items: center;
  gap: clamp(18px, 2.4vw, 42px);
  color: #20252b;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 12.87px;
  font-weight: 400;
  letter-spacing: 1.93px;
  line-height: 1;
  text-transform: uppercase;
}
.site-nav a { padding: 8px 0; border-bottom: 1px solid transparent; }
.site-nav a:hover,
.site-nav a[aria-current="page"] { color: var(--charcoal); border-color: var(--blue-gray); }
.nav-dropdown {
  position: relative;
  display: flex;
  align-items: center;
}
.nav-submenu {
  position: absolute;
  top: 100%;
  left: 50%;
  display: grid;
  min-width: 92px;
  padding: 14px 18px;
  background: rgba(248, 248, 248, 0.96);
  border: 1px solid rgba(118, 129, 138, 0.18);
  opacity: 0;
  pointer-events: none;
  transform: translate(-50%, 8px);
  transition: opacity .2s ease, transform .2s ease;
}
.nav-submenu a {
  padding: 6px 0;
  white-space: nowrap;
}
.nav-dropdown:hover .nav-submenu,
.nav-dropdown:focus-within .nav-submenu {
  opacity: 1;
  pointer-events: auto;
  transform: translate(-50%, 0);
}
.nav-toggle {
  display: none;
  width: 42px;
  height: 42px;
  border: 1px solid var(--line);
  background: transparent;
}
.nav-toggle span {
  display: block;
  width: 18px;
  height: 1px;
  margin: 7px auto;
  background: var(--charcoal);
}
.home-hero {
  position: relative;
  min-height: 64vh;
  height: 64vh;
  overflow: hidden;
  background: var(--charcoal);
}
.hero-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.small-label {
  margin: 0 0 18px;
  color: #4f5d6b;
  font-family: Montserrat, sans-serif;
  font-size: 13px;
  font-weight: 300;
  letter-spacing: .28em;
  text-transform: uppercase;
}
.script-note {
  margin: 0 0 18px;
  color: #4f5d6b;
  font-family: Montserrat, sans-serif;
  font-size: 13px;
  font-weight: 300;
  letter-spacing: .28em;
  line-height: 1.4;
  text-transform: uppercase;
}
h1,
h2,
h3 {
  margin: 0;
  font-family: "Bodoni Moda", "Cormorant Garamond", Georgia, serif;
  font-weight: 300;
  line-height: .96;
}
h1 { font-size: clamp(44px, 6.4vw, 88px); }
h2 { font-size: clamp(38px, 5vw, 76px); }
h3 { font-size: clamp(30px, 3.4vw, 52px); }
p {
  margin: 0 0 30px;
  color: #20252b;
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 22.22px;
}
.button,
.text-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: max-content;
  min-width: 150px;
  height: 46px;
  padding: 0 22px;
  color: #4f5d6b;
  background: #f1f2f2;
  border: 1px solid #f1f2f2;
  font-family: Montserrat, sans-serif;
  font-size: 12px;
  font-weight: 300;
  letter-spacing: .22em;
  text-transform: uppercase;
  text-decoration: none;
  transition: all .25s ease;
}
.button:hover,
.text-link:hover {
  color: #111111;
  background: #dde3ea;
  border-color: #dde3ea;
}
.button-dark {
  color: #4f5d6b;
  background: #f1f2f2;
  border-color: #f1f2f2;
}
.button-outline {
  color: #667589;
  background: transparent;
  border-color: #8f9aaf;
}
.button-outline:hover {
  color: #ffffff;
  background: #8f9aaf;
  border-color: #8f9aaf;
}
.section-grid,
.artist-introduction,
.experience-section,
.inquiry-section,
.page-hero,
.credentials-line,
.contact-page,
.home-awards,
.why-adam,
.home-wedding-preview,
.home-testimonial,
.home-contact-preview {
  width: var(--editorial-container);
  margin: 0 auto;
}
.section-grid {
  display: grid;
  grid-template-columns: .86fr 1.14fr;
  gap: clamp(62px, 10vw, 168px);
  align-items: center;
  padding: clamp(110px, 15vw, 210px) 0;
}
.artist-introduction {
  display: grid;
  grid-template-columns: minmax(260px, 0.42fr) minmax(320px, 0.58fr);
  gap: clamp(54px, 8vw, 118px);
  align-items: center;
  padding: clamp(78px, 10vw, 138px) 0 clamp(88px, 11vw, 150px);
}
.moses-style-artist {
  max-width: 988px;
  margin: 0 auto;
  padding-top: 110px;
  padding-bottom: 80px;
  grid-template-columns: minmax(0, 430px) minmax(0, 448px);
  column-gap: clamp(54px, 8vw, 110px);
  align-items: start;
}
.artist-image {
  position: relative;
  width: 100%;
  max-width: 430px;
  height: auto;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  justify-self: start;
}
.mobile-artist-heading,
.mobile-artist-image-label {
  display: none;
}
.artist-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  filter: grayscale(100%);
}
.artist-copy {
  max-width: 448px;
  width: 100%;
  text-align: left;
  transform: translateY(-32px);
}
.artist-signature-group {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  width: fit-content;
  margin: 0 auto 24px;
  gap: 0;
}
.meet-label {
  margin-top: 28px;
  color: #20252b;
  font-family: Montserrat, sans-serif;
  font-size: 11px;
  font-weight: 400;
  letter-spacing: .26em;
  text-transform: uppercase;
  white-space: nowrap;
}
.pianist-signature {
  display: block;
  width: 220px;
  height: auto;
  margin-left: -18px;
}
.artist-copy h2 {
  margin-top: 0;
  margin-bottom: 8px;
  color: #111111;
  font-family: "Bodoni Moda", "Cormorant Garamond", Didot, serif;
  font-size: 58px;
  font-weight: 300;
  line-height: .88;
  letter-spacing: 0;
  text-transform: uppercase;
}
.artist-copy .artist-name {
  display: block;
  width: fit-content;
  font-family: "Cormorant Garamond", serif !important;
  font-size: 26px !important;
  line-height: 1 !important;
  font-weight: 400 !important;
  letter-spacing: .02em !important;
  color: #000000 !important;
  margin-bottom: 8px !important;
  margin-top: 0 !important;
  transform: none !important;
  text-align: left;
}
.artist-body {
  max-width: 448px;
  color: #000000;
  font-family: Montserrat, sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 22.22px;
  text-align: left;
}
.artist-body p {
  margin-top: 0;
  margin-bottom: 30px;
  color: #000000;
  font-family: Montserrat, sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 22.22px;
  text-align: left;
}
.artist-body p:last-child {
  margin-bottom: 0;
}
.artist-copy .artist-subtitle {
  display: block;
  width: fit-content;
  margin-top: 0 !important;
  margin-bottom: 34px !important;
  color: #000000 !important;
  font-family: Montserrat, sans-serif;
  font-size: 11px !important;
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: .22em;
  text-transform: uppercase;
  text-align: left;
}
.artist-copy .learn-more {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 132px;
  height: 38px;
  margin: 36px auto 0;
  padding: 0;
  color: #667589;
  background: transparent;
  border: 1px solid #8f9aaf;
  font-family: Montserrat, sans-serif;
  font-size: 10.5px;
  font-weight: 300;
  letter-spacing: .18em;
  text-transform: uppercase;
  text-decoration: none;
  text-align: left;
  transition: all .25s ease;
}
.artist-copy .learn-more:hover {
  color: #ffffff;
  background: #8f9aaf;
}
.home-awards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  padding: 0 0 clamp(90px, 11vw, 150px);
}
.home-awards span {
  display: grid;
  min-height: 118px;
  place-items: center;
  padding: 24px;
  color: #4f5d6b;
  border: 1px solid var(--line);
  font-family: Montserrat, sans-serif;
  font-size: 13px;
  font-weight: 300;
  letter-spacing: .28em;
  line-height: 1.8;
  text-align: center;
  text-transform: uppercase;
}
.why-adam {
  width: min(1134px, calc(100% - 186px));
  padding: clamp(52px, 5vw, 60px) 0 clamp(58px, 7vw, 96px);
}
.why-adam-main {
  display: grid;
  grid-template-columns: minmax(0, .35fr) minmax(0, .65fr);
  column-gap: clamp(70px, 8vw, 118px);
  align-items: start;
}
.why-adam-intro {
  position: sticky;
  top: 118px;
}
.why-adam-intro .small-label {
  margin-bottom: 16px;
  color: #667589;
  text-align: left;
}
.why-adam-intro h2 {
  margin: 0 0 18px;
  color: #4a4a4a;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(32px, 3.33vw, 50px);
  font-weight: 400;
  letter-spacing: -.02em;
  line-height: .92;
}
.why-adam-intro p:not(.small-label) {
  max-width: 330px;
  margin: 0 0 8px;
  color: #20252b;
  font-family: Montserrat, sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 19px;
}
.why-adam-intro::after {
  content: "";
  display: block;
  width: min(260px, 100%);
  height: 1px;
  margin-top: 14px;
  background: rgba(143, 154, 175, .46);
}
.why-adam-list {
  border-top: 1px solid rgba(143, 154, 175, .42);
}
.why-adam-list article {
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr);
  column-gap: 36px;
  padding: 24px 0 26px;
  border-bottom: 1px solid rgba(143, 154, 175, .32);
}
.why-adam-list span {
  color: var(--editorial-accent);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 21px;
  font-weight: 300;
  letter-spacing: .02em;
  line-height: 1.25;
}
.why-adam-list h3 {
  margin: 0 0 10px;
  color: #4a4a4a;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(34px, 3.1vw, 38px);
  font-weight: 400;
  letter-spacing: -.01em;
  line-height: 1.05;
  text-transform: none;
}
.why-adam-list p {
  grid-column: 2;
  max-width: 620px;
  margin: 0 0 9px;
  color: #20252b;
  font-family: Montserrat, sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 22.22px;
}
.why-adam-list p:last-child {
  margin-bottom: 0;
}
.why-adam .brand-statement {
  margin: calc(clamp(34px, 4vw, 52px) + 54px) auto 0;
  color: var(--editorial-accent);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(25px, 2.6vw, 36px);
  font-style: italic;
  font-weight: 300;
  letter-spacing: .01em;
  line-height: 1.22;
  text-align: center;
}
.home-wedding-preview {
  width: min(1132px, calc(100% - clamp(42px, 9.6vw, 185px)));
  padding: 0 0 clamp(48px, 6vw, 82px);
  border-top: 1px solid var(--line);
  border-bottom: 0;
}
.service-preview {
  display: block;
}
.service-tabs {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  gap: 1px clamp(18px, 3vw, 34.98px);
  margin-bottom: 76px;
}
.service-tab {
  min-height: 42.16px;
  padding: 10.29px 20.58px;
  color: #20252b;
  background: transparent;
  border: 0;
  font-family: Montserrat, sans-serif;
  font-size: 10.29px;
  font-weight: 400;
  letter-spacing: 1.03px;
  line-height: 20.58px;
  text-transform: uppercase;
  transition: background 200ms ease, color 200ms ease;
  cursor: pointer;
}
.service-tab.is-active,
.service-tab:hover {
  color: #ffffff;
  background: #667589;
}
.service-panel {
  display: none;
  grid-template-columns: minmax(0, 562px) minmax(0, 360px);
  gap: 0;
  align-items: start;
  justify-content: space-between;
}
.service-panel.is-active {
  display: grid;
}
.ceremony-panel.is-active {
  display: block;
  padding-top: 28px;
  opacity: 1;
  transform: translateY(0);
  transition: opacity 400ms ease-out, transform 400ms ease-out;
}
.ceremony-intro-row {
  display: grid;
  grid-template-columns: minmax(0, 385px) minmax(0, 643px);
  column-gap: clamp(42px, 7.6vw, 104px);
  align-items: start;
  margin-bottom: 92px;
  min-height: 310px;
  opacity: 1;
  transition: opacity 300ms ease;
}
.ceremony-intro-headline {
  width: 100%;
  margin-bottom: 0;
}
.ceremony-intro-headline h2 {
  max-width: 385px;
  margin: 0;
  color: var(--editorial-accent);
  font-family: "Bodoni Moda", "Cormorant Garamond", Didot, serif;
  font-size: clamp(32px, 3.33vw, 50px);
  font-weight: 300;
  letter-spacing: -1.85px;
  line-height: 50.81px;
}
.ceremony-intro-copy {
  width: 100%;
  max-width: 643px;
  margin-left: 0;
  margin-bottom: 0;
}
.ceremony-intro-copy h3 {
  margin: 0 0 34px;
  color: #20252b;
  font-family: "Bodoni Moda", "Cormorant Garamond", Didot, serif;
  font-size: 23.52px;
  font-weight: 300;
  letter-spacing: 0;
  line-height: 28.22px;
}
.ceremony-intro-copy p {
  margin: 0 0 19px;
  color: #20252b;
  font-family: Montserrat, sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 20.6px;
}
.ceremony-intro-copy p:last-of-type {
  margin-bottom: 0;
}
.ceremony-intro-copy .button {
  width: max-content;
  min-width: 150px;
  height: 38px;
  margin-top: 28px;
  font-size: 10.29px;
  letter-spacing: 1.03px;
  line-height: 1;
}
.ceremony-music-row {
  display: grid;
  grid-template-columns: minmax(0, .78fr) minmax(0, 1.28fr) minmax(0, .65fr);
  gap: clamp(32px, 4vw, 54px);
  align-items: start;
}
.ceremony-feeling,
.ceremony-performance,
.ceremony-collection {
  align-self: start;
}
.ceremony-feeling,
.ceremony-performance {
  opacity: 1;
  transition: opacity 300ms ease;
}
.is-content-fading,
.is-content-entering {
  opacity: 0;
}
.ceremony-feeling {
  transform: translateY(-52px);
}
.service-panel > h2 {
  max-width: 420px;
  color: var(--editorial-accent);
  font-family: "Bodoni Moda", "Cormorant Garamond", Didot, serif;
  font-size: 46.19px;
  font-weight: 300;
  letter-spacing: -1.85px;
  line-height: 50.81px;
}
.service-feature {
  max-width: 562px;
}
.service-feature h2 {
  max-width: 420px;
  margin: 0;
  color: var(--editorial-accent);
  font-family: "Bodoni Moda", "Cormorant Garamond", Didot, serif;
  font-size: 36.95px;
  font-weight: 300;
  letter-spacing: -1.48px;
  line-height: 40.65px;
}
.ceremony-video-frame {
  position: relative;
  width: 100%;
  max-width: 562px;
  margin-top: 34px;
}
.ceremony-feature-video {
  display: block;
  width: 100%;
  max-width: 562px;
  aspect-ratio: 16 / 9;
  border-radius: 0;
  object-fit: cover;
}
.ceremony-video-title {
  position: absolute;
  left: 16px;
  bottom: 2px;
  z-index: 2;
  color: #ffffff;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 10.8px;
  font-weight: 400;
  letter-spacing: 1.62px;
  line-height: 1;
  opacity: 1;
  pointer-events: none;
  text-transform: uppercase;
  text-shadow: 0 1px 8px rgba(0, 0, 0, .65);
  transition: opacity .25s ease;
}
.ceremony-video-frame.is-playing .ceremony-video-title {
  opacity: 0;
}
.ceremony-video-frame.is-playing:hover .ceremony-video-title,
.ceremony-video-frame.is-playing:focus-within .ceremony-video-title {
  opacity: 1;
}
.service-copy {
  max-width: 360px;
}
.service-copy h3 {
  margin: 0 0 34px;
  color: #20252b;
  font-family: "Bodoni Moda", "Cormorant Garamond", Didot, serif;
  font-size: 23.52px;
  font-weight: 300;
  letter-spacing: 0;
  line-height: 28.22px;
}
.service-copy p {
  margin: 0 0 28px;
  color: #20252b;
  font-family: Montserrat, sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 22.22px;
}
.service-copy .button {
  width: max-content;
  min-width: 150px;
  height: 38px;
  margin-top: 36px;
  font-size: 10.29px;
  letter-spacing: 1.03px;
  line-height: 1;
}
.ceremony-feeling h3 {
  margin: 0 0 32px;
  color: var(--editorial-accent);
  font-family: "Majesty", "Cormorant Garamond", Georgia, serif;
  font-size: 58px;
  font-weight: 400;
  letter-spacing: 0;
  line-height: .9;
  text-align: left;
  transform: none;
}
.ceremony-feeling h3 {
  font-family: "Bodoni Moda", "Cormorant Garamond", Didot, serif;
  font-size: 23.52px;
  font-weight: 300;
  letter-spacing: 0;
  line-height: 28.22px;
}
.ceremony-feeling-copy p {
  margin: 0 0 22px;
  color: #20252b;
  font-family: Montserrat, sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 22.22px;
  text-align: left;
}
.ceremony-feeling-copy p:last-child {
  color: #667589;
  font-size: 14.35px;
  font-style: italic;
  text-align: left;
  transform: none;
}
.ceremony-feeling-copy .ceremony-mood {
  margin-bottom: 24px;
  color: #667589;
  font-size: 10.29px;
  letter-spacing: 1.03px;
  line-height: 20.58px;
  text-align: left;
  text-transform: uppercase;
  transform: none;
}
.ceremony-feeling .button {
  width: max-content;
  min-width: 150px;
  height: 38px;
  margin-top: 34px;
  font-size: 10.29px;
  letter-spacing: 1.03px;
  line-height: 1;
}
.ceremony-performance .ceremony-video-frame {
  max-width: 520px;
  margin-top: 0;
}
.ceremony-performance .ceremony-feature-video {
  max-width: 520px;
}
.ceremony-collection {
  display: grid;
  justify-items: start;
}
.ceremony-song {
  width: max-content;
  max-width: 100%;
  padding: 0 0 11px;
  margin: 0 0 11px;
  color: #20252b;
  background: transparent;
  border: 0;
  border-bottom: 1px solid transparent;
  font-family: "Bodoni Moda", "Cormorant Garamond", Georgia, serif;
  font-size: 18.5px;
  font-weight: 400;
  letter-spacing: 0;
  line-height: 21px;
  text-align: left;
  white-space: normal;
  cursor: pointer;
  transition: color .25s ease, border-color .25s ease, transform .25s ease;
}
.ceremony-song:hover,
.ceremony-song.is-active {
  color: var(--editorial-accent);
  border-color: var(--editorial-accent);
}
.ceremony-song.is-active {
  transform: translateX(8px);
}
.ceremony-explore-music {
  min-width: 0;
  height: 38px;
  margin-top: 18px;
  padding: 0 18px;
  font-size: 9.5px;
  letter-spacing: 1.03px;
  line-height: 1;
  white-space: nowrap;
}
.home-testimonial {
  padding: clamp(90px, 12vw, 165px) 0;
  text-align: center;
}
.home-testimonial blockquote {
  width: min(820px, 100%);
  margin: 0 auto;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(38px, 5vw, 76px);
  line-height: 1.05;
}
.home-testimonial span {
  display: block;
  margin-top: 28px;
  color: #4f5d6b;
  font-family: Montserrat, sans-serif;
  font-size: 13px;
  font-weight: 300;
  letter-spacing: .28em;
  text-transform: uppercase;
}
.home-contact-preview {
  padding: clamp(84px, 10vw, 138px) 0 clamp(94px, 12vw, 160px);
  text-align: center;
  border-top: 1px solid var(--line);
}
.home-contact-preview h2 {
  width: min(720px, 100%);
  margin: 0 auto 34px;
  font-size: clamp(38px, 4.8vw, 72px);
}
.home-contact-preview .button,
.inquiry-section .button {
  margin: 0 auto;
}
.portrait-frame img {
  width: 100%;
  aspect-ratio: 4 / 5.65;
  object-fit: cover;
  object-position: center;
}
.adam-portrait-placeholder {
  display: grid;
  width: 100%;
  aspect-ratio: 4 / 5.65;
  place-items: center;
  align-content: center;
  gap: 10px;
  color: var(--charcoal);
  background:
    linear-gradient(135deg, rgba(118, 129, 138, 0.22), rgba(213, 195, 160, 0.2)),
    var(--soft-white);
  border: 1px solid var(--line);
}
.adam-portrait-placeholder span {
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(42px, 6vw, 82px);
  line-height: .9;
  text-align: center;
  text-transform: uppercase;
}
.adam-portrait-placeholder small {
  color: #4f5d6b;
  font-family: Montserrat, sans-serif;
  font-size: 13px;
  font-weight: 300;
  letter-spacing: .28em;
  text-transform: uppercase;
}
.adam-portrait-placeholder.tall-placeholder {
  aspect-ratio: 4 / 6;
}
.adam-portrait-placeholder.quiet {
  aspect-ratio: 4 / 5.25;
}
.adam-portrait-placeholder.quiet span {
  font-size: clamp(28px, 4vw, 54px);
}
.portrait-frame.tall img { aspect-ratio: 4 / 6; }
.editorial-copy p:not(.script-note) {
  margin-top: 24px;
  margin-bottom: 30px;
  color: #20252b;
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 22.22px;
}
.artist-subtitle {
  margin-top: 0 !important;
  margin-bottom: 34px !important;
  color: #4f5d6b !important;
  font-family: Montserrat, sans-serif;
  font-size: 13px !important;
  font-weight: 300;
  line-height: 1.4;
  letter-spacing: .28em;
  text-transform: uppercase;
}
.editorial-copy .artist-subtitle {
  color: #4f5d6b !important;
  font-family: Montserrat, sans-serif !important;
  font-size: 13px !important;
  font-weight: 300 !important;
  line-height: 1.4 !important;
  letter-spacing: .28em !important;
  text-transform: uppercase !important;
}
.section-heading {
  max-width: 760px;
  margin: 0 auto clamp(70px, 10vw, 130px);
  text-align: center;
}
.experience-section {
  padding: clamp(96px, 13vw, 190px) 0;
}
.page-flow { padding-top: 0; }
.experience-row {
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: clamp(58px, 8vw, 126px);
  align-items: center;
  margin-bottom: clamp(90px, 13vw, 180px);
}
.experience-row.reverse { grid-template-columns: .9fr 1.1fr; }
.experience-row.reverse img { order: 2; }
.experience-row img {
  width: 100%;
  aspect-ratio: 1 / 1.12;
  object-fit: cover;
}
.experience-row p:not(.small-label) {
  margin-top: 24px;
  margin-bottom: 30px;
  color: #20252b;
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 22.22px;
}
.video-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}
.video-card {
  min-height: 310px;
  background: linear-gradient(135deg, rgba(118,129,138,.34), rgba(213,195,160,.22)), var(--charcoal);
}
.video-grid span {
  display: block;
  margin-top: 16px;
  color: #4f5d6b;
  font-family: Montserrat, sans-serif;
  font-size: 13px;
  font-weight: 300;
  letter-spacing: .28em;
  text-transform: uppercase;
}
.inquiry-section {
  padding: clamp(100px, 12vw, 170px) 0;
  text-align: center;
  border-top: 1px solid var(--line);
}
.inline-form {
  display: grid;
  grid-template-columns: repeat(3, 1fr) auto;
  gap: 12px;
  margin: 44px auto 0;
  width: min(900px, 100%);
}
input,
select,
textarea {
  width: 100%;
  min-height: 48px;
  padding: 13px 14px;
  color: #20252b;
  background: transparent;
  border: 1px solid var(--line);
  border-radius: 0;
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.75;
}
textarea { resize: vertical; }
.page-hero {
  padding: clamp(92px, 13vw, 175px) 0 clamp(62px, 8vw, 110px);
  text-align: center;
  width: var(--editorial-container);
}
.page-hero h1 {
  width: min(880px, 100%);
  margin: 0 auto;
  color: var(--editorial-accent);
}
.faq-page {
  width: min(1220px, calc(100% - 42px));
  margin: 0 auto;
  padding: clamp(82px, 10vh, 118px) 0 clamp(44px, 6vh, 72px);
}
.faq-topline {
  width: min(1020px, 100%);
  margin: 0 auto 26px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 28px;
}
.faq-kicker {
  position: absolute;
  top: -99px;
  left: 0;
  z-index: 2;
  width: 249px;
  margin: 0;
  color: #20252b;
  font-family: "Bodoni Moda", "Cormorant Garamond", Georgia, serif;
  font-size: 18.2px;
  font-weight: 400;
  letter-spacing: .08em;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
  white-space: nowrap;
}
.faq-side-label {
  position: absolute;
  top: -77px;
  left: 0;
  display: block;
  margin: 0;
  color: #8f9aaf;
  font-family: Montserrat, sans-serif;
  font-size: 10.5px;
  font-weight: 400;
  letter-spacing: .26em;
  line-height: 1.6;
  text-transform: uppercase;
  writing-mode: horizontal-tb;
  transform: none;
  transform-origin: center;
  z-index: 2;
  white-space: nowrap;
}
.faq-topline .button {
  width: 150px;
  height: 46px;
  font-size: 10.29px;
  letter-spacing: .18em;
}
.faq-categories {
  width: min(1020px, 100%);
  margin: 0 auto 20px;
  display: flex;
  position: relative;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  border-bottom: 0;
}
.faq-category {
  position: relative;
  display: block;
  padding: 0 0 16px;
  color: #20252b;
  background: transparent;
  border: 0;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(18px, 1.43vw, 19px);
  font-weight: 400;
  letter-spacing: -.01em;
  line-height: 1;
  white-space: nowrap;
  cursor: pointer;
  transition: color 200ms ease;
}
.faq-category::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  height: 1px;
  background: transparent;
}
.faq-category.is-active {
  color: #20252b;
}
.faq-category.is-active::after {
  background: transparent;
}
.faq-category:hover {
  color: #8f9aaf;
}
.faq-category-indicator {
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 0;
  height: 1px;
  background: #8f9aaf;
  pointer-events: none;
  transition: all 300ms ease;
}
.faq-layout {
  position: relative;
  isolation: isolate;
  width: min(1020px, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 152px minmax(0, 1fr);
  column-gap: 62px;
  align-items: start;
}
.faq-title {
  display: grid;
  gap: 0;
  color: #98a4b8;
  margin-left: 58px;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 92px;
  font-weight: 500;
  letter-spacing: -.045em;
  line-height: .98;
}
.faq-title span {
  display: block;
}
.faq-background-title {
  position: absolute;
  top: 140px;
  left: 0;
  z-index: 0;
  display: block;
  width: 176px;
  height: 520px;
  color: #98a4b8;
  font-family: "Bodoni Moda", "Cormorant Garamond", Georgia, serif;
  font-size: clamp(56px, 4.59vw, 73px);
  font-weight: 400;
  letter-spacing: -.075em;
  line-height: .78;
  opacity: .9;
  pointer-events: none;
  text-align: left;
  text-transform: uppercase;
  white-space: nowrap;
}
.faq-background-title span {
  display: block;
  position: absolute;
  writing-mode: vertical-rl;
}
.faq-background-title span:first-child {
  left: 0;
  top: -136px;
  transform: rotate(180deg);
}
.faq-background-title span:last-child {
  left: 64px;
  top: 0;
  transform: rotate(180deg);
}
.faq-questions {
  padding-top: 4px;
  position: relative;
  left: 0;
  width: min(620px, 100%);
  max-width: 100%;
  min-height: 472px;
  margin: 0 auto;
  z-index: 1;
  grid-column: 1 / -1;
  transition: height 400ms ease-out;
}
.faq-panel {
  display: none;
  opacity: 0;
  transform: translateY(10px);
}
.faq-panel.is-active {
  display: block;
  opacity: 1;
  transform: translateY(0);
  transition: opacity 400ms ease-out, transform 400ms ease-out;
}
.faq-panel.is-transitioning-out {
  display: block;
  opacity: 0;
  transform: translateY(0);
  transition: opacity 300ms ease;
}
.faq-panel.is-transitioning-in {
  opacity: 0;
  transform: translateY(10px);
}
.faq-question {
  max-width: 620px;
  margin-bottom: 24px;
}
.faq-question h2 {
  margin: 0 0 3px;
  color: #20252b;
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 12.35px;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 22.22px;
}
.faq-question p {
  margin: 0;
  color: #20252b;
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 22.22px;
}
.faq-contact-note {
  max-width: 620px;
  margin-top: 38px;
  padding-top: 28px;
  border-top: 1px solid rgba(118, 129, 138, 0.42);
}
.faq-contact-note p {
  margin: 0 0 28px;
  color: #20252b;
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.8;
}
.faq-contact-note a:not(.faq-contact-button) {
  font-weight: 500;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.faq-contact-button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 150px;
  height: 46px;
  margin: 0 auto;
  padding: 0;
  color: #4f5d6b;
  background: #f1f2f2;
  border: 1px solid #f1f2f2;
  font-family: Montserrat, sans-serif;
  font-size: 12px;
  font-weight: 300;
  letter-spacing: .22em;
  line-height: 1;
  text-transform: uppercase;
  text-decoration: none;
  transition: all .25s ease;
}
.faq-contact-button:hover {
  color: #111111;
  background: #dde3ea;
  border-color: #dde3ea;
}
.faq-redesign {
  --faq-bg: #f4f1eb;
  --faq-alt: #f7f5f0;
  --faq-text: #222222;
  --faq-secondary: #5e5e5e;
  --faq-accent: #aab4c8;
  --faq-border: #d9d4cb;
  background: var(--faq-bg);
  color: var(--faq-text);
}
.faq-redesign .faq-hero {
  display: grid;
  justify-items: center;
  width: min(920px, calc(100% - 80px));
  margin: 0 auto;
  padding: 150px 0 120px;
  text-align: center;
}
.faq-redesign .faq-eyebrow {
  margin: 0 0 30px;
  color: var(--faq-accent);
  font-family: Montserrat, sans-serif;
  font-size: 13px;
  font-weight: 400;
  letter-spacing: .28em;
  line-height: 1.6;
  text-transform: uppercase;
}
.faq-redesign .faq-hero h1 {
  max-width: 860px;
  margin: 0;
  color: var(--faq-text);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(72px, 7vw, 90px);
  font-weight: 400;
  letter-spacing: -.015em;
  line-height: .95;
}
.faq-redesign .faq-hero p:not(.faq-eyebrow) {
  max-width: 760px;
  margin: 34px auto 0;
  color: var(--faq-secondary);
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 18px;
  font-weight: 300;
  line-height: 1.8;
}
.faq-redesign .faq-page {
  display: grid;
  grid-template-columns: 220px minmax(0, 800px);
  gap: clamp(70px, 8vw, 140px);
  width: min(1160px, calc(100% - 100px));
  margin: 0 auto;
  padding: 0 0 150px;
}
.faq-sticky-nav {
  position: sticky;
  top: 120px;
  display: grid;
  align-self: start;
  gap: 18px;
  padding-top: 10px;
}
.faq-nav-link {
  color: var(--faq-accent);
  font-family: Montserrat, sans-serif;
  font-size: 11px;
  font-weight: 400;
  letter-spacing: .25em;
  line-height: 1.8;
  text-decoration: none;
  text-transform: uppercase;
  transition: color .25s ease, transform .25s ease;
}
.faq-nav-link:hover,
.faq-nav-link.is-active {
  color: var(--faq-text);
}
.faq-nav-link.is-active {
  transform: translateX(8px);
}
.faq-content {
  min-width: 0;
}
.faq-redesign .faq-section {
  scroll-margin-top: 130px;
  padding: 0 0 86px;
  margin-bottom: 88px;
  border-bottom: 1px solid var(--faq-border);
}
.faq-redesign .faq-section:last-child {
  margin-bottom: 0;
}
.faq-section-number {
  margin: 0 0 14px;
  color: var(--faq-accent);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 42px;
  font-weight: 400;
  line-height: 1;
}
.faq-redesign .faq-section h2 {
  margin: 0 0 44px;
  color: var(--faq-text);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(44px, 4vw, 56px);
  font-weight: 400;
  line-height: 1;
}
.faq-redesign .faq-accordion-item {
  border-top: 1px solid var(--faq-border);
}
.faq-redesign .faq-accordion-item:last-of-type {
  border-bottom: 1px solid var(--faq-border);
}
.faq-accordion-trigger {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  width: 100%;
  padding: 28px 0;
  border: 0;
  background: transparent;
  color: var(--faq-text);
  cursor: pointer;
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 20px;
  font-weight: 500;
  line-height: 1.45;
  text-align: left;
}
.faq-accordion-icon {
  position: relative;
  width: 18px;
  height: 18px;
  margin-left: 28px;
}
.faq-accordion-icon::before,
.faq-accordion-icon::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 1px;
  background: var(--faq-accent);
}
.faq-accordion-icon::after {
  transform: rotate(90deg);
  transition: transform .25s ease;
}
.faq-accordion-item.is-open .faq-accordion-icon::after {
  transform: rotate(0deg);
}
.faq-accordion-panel {
  max-height: 0;
  overflow: hidden;
  transition: max-height .34s ease;
}
.faq-accordion-panel p {
  margin: 0;
  padding: 0 58px 30px 0;
  color: var(--faq-secondary);
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 18px;
  font-weight: 300;
  line-height: 1.8;
}
.faq-redesign .faq-contact-note {
  max-width: 760px;
  margin: 52px 0 0;
  padding-top: 34px;
  border-top: 1px solid var(--faq-border);
}
.faq-redesign .faq-contact-note p {
  margin: 0 0 36px;
  color: var(--faq-secondary);
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 17px;
  font-weight: 300;
  line-height: 1.9;
}
.faq-redesign .faq-contact-note a:not(.faq-contact-button) {
  color: var(--faq-text);
}
.faq-redesign .faq-contact-button,
.faq-song-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 190px;
  min-height: 52px;
  padding: 0 28px;
  border: 1px solid var(--faq-accent);
  background: transparent;
  color: #7d8aa0;
  font-family: Montserrat, sans-serif;
  font-size: 11px;
  font-weight: 400;
  letter-spacing: .22em;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;
  transition: background-color .25s ease, border-color .25s ease, color .25s ease;
}
.faq-redesign .faq-contact-button {
  margin: 0;
}
.faq-redesign .faq-contact-button:hover,
.faq-song-button:hover {
  background: var(--faq-accent);
  border-color: var(--faq-accent);
  color: #ffffff;
}
.faq-song-button {
  margin-top: 34px;
}
.faq-editorial {
  --faq-bg: #f4f1eb;
  --faq-text: #222222;
  --faq-secondary: #5e5e5e;
  --faq-accent: #aab4c8;
  --faq-border: #d9d4cb;
  position: relative;
  overflow: hidden;
  background: var(--faq-bg);
  color: var(--faq-text);
}
.faq-editorial .faq-page {
  position: relative;
  z-index: 1;
  display: block;
  width: min(1220px, calc(100% - 90px));
  margin: 0 auto;
  padding: 120px 0 150px;
}
.faq-background-word {
  position: absolute;
  top: 178px;
  left: 50%;
  z-index: -1;
  color: var(--faq-accent);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(220px, 22vw, 280px);
  font-weight: 500;
  letter-spacing: -.055em;
  line-height: .8;
  opacity: .055;
  pointer-events: none;
  transform: translateX(-50%);
  white-space: nowrap;
}
.faq-category-nav {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: clamp(24px, 3.2vw, 58px);
  margin: 0 0 118px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--faq-border);
}
.faq-category-link {
  position: relative;
  color: var(--faq-text);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(24px, 2.7vw, 42px);
  font-weight: 400;
  letter-spacing: -.02em;
  line-height: 1;
  text-decoration: none;
  white-space: nowrap;
  transition: color .25s ease;
}
.faq-category-link::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -25px;
  height: 1px;
  background: transparent;
  transition: background-color .25s ease;
}
.faq-category-link:hover,
.faq-category-link.is-active {
  color: var(--faq-accent);
}
.faq-category-link:hover::after,
.faq-category-link.is-active::after {
  background: var(--faq-accent);
}
.faq-editorial .faq-content {
  width: min(800px, 100%);
  margin-left: auto;
}
.faq-editorial .faq-section {
  scroll-margin-top: 116px;
  padding: 0 0 92px;
  margin: 0 0 96px;
  border-bottom: 1px solid var(--faq-border);
}
.faq-editorial .faq-section:last-of-type {
  margin-bottom: 0;
}
.faq-editorial .faq-section h2 {
  margin: 0 0 58px;
  color: var(--faq-text);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(46px, 4.8vw, 64px);
  font-weight: 400;
  letter-spacing: -.02em;
  line-height: 1;
}
.faq-editorial .faq-question {
  max-width: 780px;
  margin: 0 0 60px;
}
.faq-editorial .faq-question:last-child {
  margin-bottom: 0;
}
.faq-editorial .faq-question h3 {
  margin: 0 0 14px;
  color: var(--faq-text);
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.45;
}
.faq-editorial .faq-question p {
  margin: 0;
  color: var(--faq-secondary);
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 18px;
  font-weight: 300;
  line-height: 1.8;
}
.faq-editorial .faq-song-button {
  margin: 8px 0 0;
}
.faq-editorial .faq-contact-note {
  max-width: 800px;
  margin: 96px 0 0;
  padding-top: 44px;
  border-top: 1px solid var(--faq-border);
}
.faq-editorial .faq-contact-note p {
  margin: 0 0 42px;
  color: var(--faq-secondary);
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 18px;
  font-weight: 300;
  line-height: 1.9;
}
.faq-editorial .faq-contact-note a:not(.faq-contact-button) {
  color: var(--faq-text);
  font-weight: 500;
  text-decoration: underline;
  text-underline-offset: 4px;
}
.faq-editorial .faq-contact-button,
.faq-editorial .faq-song-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 190px;
  min-height: 52px;
  padding: 0 28px;
  border: 1px solid var(--faq-accent);
  background: transparent;
  color: #7d8aa0;
  font-family: Montserrat, sans-serif;
  font-size: 11px;
  font-weight: 400;
  letter-spacing: .22em;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;
  transition: background-color .25s ease, border-color .25s ease, color .25s ease;
}
.faq-editorial .faq-contact-button:hover,
.faq-editorial .faq-song-button:hover {
  background: var(--faq-accent);
  border-color: var(--faq-accent);
  color: #ffffff;
}
.about-story { padding-top: 0; }
.credentials-line {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  padding-bottom: clamp(90px, 12vw, 160px);
}
.credentials-line span {
  padding: 28px;
  border: 1px solid var(--line);
  color: #4f5d6b;
  font-family: Montserrat, sans-serif;
  font-size: 13px;
  font-weight: 300;
  letter-spacing: .28em;
  text-align: center;
  text-transform: uppercase;
}
.contact-page {
  display: block;
  width: min(906px, calc(100% - 42px));
  padding: clamp(105px, 13vw, 178px) 0 125px;
}
.contact-script-title {
  margin: 0 0 54px;
  color: #20252b;
  font-family: "Snell Roundhand", "Brush Script MT", "Segoe Script", cursive;
  font-size: clamp(62px, 7vw, 110px);
  font-weight: 400;
  letter-spacing: 0;
  line-height: .88;
  text-align: center;
}
.contact-copy {
  max-width: 866px;
  margin: 0 auto;
}
.contact-copy p {
  margin: 0 0 24px;
  color: #000000;
  font-family: Montserrat, sans-serif;
  font-size: 12.35px;
  font-weight: 300;
  line-height: 22.22px;
}
.contact-copy p:last-of-type {
  margin-bottom: 0;
}
.contact-copy .direct-email {
  display: inline;
  margin: 0;
  color: inherit;
  font: inherit;
  letter-spacing: 0;
}
.event-selection {
  display: grid;
  justify-items: center;
  width: min(906px, 100%);
  margin: clamp(74px, 9vw, 118px) auto 0;
  padding: 0;
  background: transparent;
  border: 0;
}
.contact-form-label {
  margin: 0 0 28px;
  color: #20252b;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(42px, 5vw, 72px);
  font-weight: 400;
  letter-spacing: .02em;
  line-height: .95;
  text-align: center;
}
.event-selection .small-label {
  margin: 0 0 34px;
  color: #20252b;
  text-align: center;
}
.event-question {
  margin: 0 0 34px;
  color: #20252b;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 34px;
  font-weight: 600;
  letter-spacing: 0;
  line-height: 1.1;
  text-align: center;
  text-transform: none;
}
.event-choice-grid {
  display: flex;
  justify-content: center;
  gap: 50px;
  width: 100%;
}
.event-tab {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 10px 30px;
  color: #667589;
  background: #f1f2f3;
  border: 0;
  font-family: Montserrat, sans-serif;
  font-size: 15px;
  font-weight: 400;
  letter-spacing: 1.65px;
  text-align: center;
  text-transform: uppercase;
  transition: background 200ms ease, color 200ms ease;
  cursor: pointer;
}
.event-tab:first-child {
  width: 166px;
}
.event-tab:last-child {
  width: 292px;
}
.event-tab:hover,
.event-tab.is-active {
  color: #ffffff;
  background: #667589;
}
.event-form {
  display: none;
  width: min(866px, 100%);
  margin-top: 58px;
  color: #20252b;
  opacity: 0;
  transform: translateY(10px);
}
.event-form.is-active {
  display: block;
  opacity: 1;
  transform: translateY(0);
  transition: opacity 400ms ease-out, transform 400ms ease-out;
}
.event-form.is-transitioning-out {
  display: block;
  opacity: 0;
  transform: translateY(0);
  transition: opacity 300ms ease;
}
.event-form.is-transitioning-in {
  opacity: 0;
  transform: translateY(10px);
}
.form-grid {
  display: grid;
  gap: 15px 38px;
}
.form-grid.two-columns {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.event-form label {
  display: block;
  margin-bottom: 15px;
  color: #20252b;
  font-family: Montserrat, sans-serif;
  font-size: 14px;
  font-weight: 400;
  letter-spacing: 0;
  line-height: 20px;
}
.event-form .form-grid label {
  margin-bottom: 0;
}
.event-form label span {
  color: #b76a5d;
}
.event-form input,
.event-form select,
.event-form textarea {
  width: 100%;
  height: 36px;
  min-height: 0;
  margin-top: 3px;
  padding: 8px 12px;
  color: #20252b;
  background: #ffffff;
  border: 1px solid #cfd4d9;
  border-radius: 0;
  font-family: Montserrat, sans-serif;
  font-size: 14px;
  font-weight: 400;
  line-height: 20px;
}
.event-form textarea {
  height: auto;
  min-height: 80px;
  padding-right: 16px;
}
.event-form input::placeholder,
.event-form textarea::placeholder {
  color: #aab2bd;
}
.form-submit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 135px;
  min-width: 0;
  height: 40px;
  margin: 42px 0 0 auto;
  padding: 0;
  color: #667589;
  background: #f2f2f2;
  border: 1px solid #f2f2f2;
  font-family: Montserrat, sans-serif;
  font-size: 14.4px;
  font-weight: 400;
  letter-spacing: 2.4px;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .25s ease, color .25s ease;
}
.form-submit:hover {
  color: #20252b;
  background: #ececec;
  border-color: #ececec;
}
.contact-social-placeholder {
  width: min(1220px, calc(100% - 42px));
  margin: 0 auto;
  padding: clamp(62px, 8vw, 105px) 0 clamp(90px, 11vw, 150px);
  text-align: center;
  border-top: 1px solid var(--line);
}
.contact-social-placeholder .small-label {
  margin-bottom: 28px;
}
.contact-social-placeholder div {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: clamp(24px, 4vw, 54px);
}
.contact-social-placeholder a {
  color: #20252b;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 13px;
  font-weight: 400;
  letter-spacing: .2em;
  text-transform: uppercase;
}
.final-cta {
  width: min(1220px, calc(100% - 42px));
  margin: clamp(8px, 2vw, 28px) auto clamp(92px, 11vw, 156px);
  display: grid;
  grid-template-columns: minmax(0, .82fr) minmax(0, 1.18fr);
  min-height: 510px;
  background: #f7f4ed;
  border: 0;
}
.home-final-cta {
  position: relative;
  width: 100%;
  margin-left: 0;
  margin-right: 0;
  margin-bottom: 0;
  padding-bottom: 0;
  overflow: hidden;
}
.home-final-cta .final-cta-copy {
  position: relative;
  z-index: 2;
  padding-left: max(92px, calc((100vw - 1132px) / 2));
}
.home-final-cta .final-cta-image {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.home-final-cta .final-cta-image::after {
  background: linear-gradient(90deg, rgba(251, 248, 240, .04), rgba(32, 37, 43, .12));
}
.home-final-cta .final-cta-image img {
  object-position: right 38%;
}
.home-final-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    90deg,
    rgba(247, 244, 237, 1) 0%,
    rgba(247, 244, 237, .98) 28%,
    rgba(247, 244, 237, .72) 41%,
    rgba(247, 244, 237, .30) 54%,
    rgba(247, 244, 237, .06) 66%,
    rgba(247, 244, 237, 0) 78%
  );
  pointer-events: none;
}
.final-cta-copy {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  padding: clamp(56px, 7vw, 96px);
}
.final-cta h2 {
  max-width: 560px;
  color: var(--editorial-accent);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(46px, 5.4vw, 82px);
  font-weight: 500;
  letter-spacing: -.035em;
  line-height: .92;
}
.home-final-cta .final-cta-heading {
  display: inline-grid;
  width: fit-content;
  max-width: none;
}
.home-final-cta .cta-heading-small {
  display: block;
  justify-self: start;
  width: auto;
  margin-bottom: 8px;
  font-family: Montserrat, sans-serif;
  font-size: 15px;
  font-weight: 300;
  letter-spacing: .18em;
  line-height: 1;
  text-align: left;
}
.home-final-cta .cta-heading-large {
  display: block;
}
.final-cta p {
  max-width: 520px;
  margin: 0 0 18px;
  color: #20252b;
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 22.22px;
}
.final-cta h2 + p {
  margin-top: 34px;
}
.final-cta p:last-of-type {
  margin-bottom: 38px;
}
.final-cta-image {
  position: relative;
  min-height: 510px;
  overflow: hidden;
}
.final-cta-image::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(251, 248, 240, .12), rgba(32, 37, 43, .16));
  pointer-events: none;
}
.final-cta-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(100%);
}
.about-page {
  padding: clamp(86px, 10vw, 136px) 0 0;
}
.about-editorial-section {
  width: min(1120px, calc(100% - 42px));
  margin: 0 auto clamp(96px, 12vw, 168px);
  display: grid;
  grid-template-columns: minmax(0, .92fr) minmax(0, 1fr);
  gap: clamp(56px, 7vw, 108px);
  align-items: center;
}
.about-editorial-section.reverse {
  grid-template-columns: minmax(0, .92fr) minmax(0, 1fr);
}
.about-image img {
  width: 100%;
  aspect-ratio: 4 / 5.25;
  object-fit: cover;
  object-position: center;
  filter: grayscale(100%);
}
.about-copy h1,
.about-copy h2,
.about-values h2 {
  margin: 0 0 20px;
  color: #20252b;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(44px, 5vw, 72px);
  font-weight: 500;
  letter-spacing: -.025em;
  line-height: .94;
}
.about-copy .small-label,
.about-values .small-label {
  margin-bottom: 18px;
}
.about-copy .artist-subtitle {
  margin-bottom: 34px !important;
}
.about-copy p:not(.small-label):not(.artist-subtitle),
.about-values p {
  margin-bottom: 24px;
  color: #20252b;
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 22.22px;
}
.about-values {
  width: min(1120px, calc(100% - 42px));
  margin: 0 auto clamp(96px, 12vw, 168px);
  padding: clamp(70px, 8vw, 112px) 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  text-align: center;
}
.about-values h2 {
  margin-bottom: clamp(48px, 6vw, 82px);
}
.about-value-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(34px, 5vw, 78px);
  text-align: left;
}
.about-value-grid h3 {
  margin-bottom: 24px;
  color: #98a4b8;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(34px, 3.6vw, 52px);
  font-weight: 500;
  letter-spacing: -.035em;
  line-height: .94;
}
.about-final-cta {
  min-height: 390px;
  grid-template-columns: minmax(0, .92fr) minmax(0, 1.08fr);
  margin-bottom: 0;
}
.about-final-cta .final-cta-copy {
  padding-top: clamp(54px, 6vw, 78px);
  padding-bottom: clamp(54px, 6vw, 78px);
}
.about-final-cta .final-cta-image {
  min-height: 390px;
}
.about-editorial-redesign {
  --about-bg: #f8f8f8;
  --about-text: #333333;
  --about-body: #20252b;
  --about-accent: #aab3c8;
  --about-line: rgba(170, 179, 200, .42);
  padding: 0;
  background: var(--about-bg);
  color: var(--about-text);
}
.about-editorial-redesign .about-section {
  width: var(--editorial-container);
  margin: 0 auto;
}
.about-placeholder {
  display: grid;
  place-items: center;
  min-height: 240px;
  border: 1px solid var(--about-line);
  background: rgba(255, 255, 255, .08);
  color: var(--about-accent);
}
.about-placeholder span {
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 12px;
  font-weight: 300;
  letter-spacing: .34em;
  line-height: 1.5;
  text-align: center;
  text-transform: uppercase;
}
.placeholder-frame {
  position: relative;
  overflow: hidden;
  padding: 0;
  border-color: #C7D1E3;
  background: #F4F1EB;
}
.placeholder-image {
  display: block;
  width: 100%;
  height: 100%;
  min-height: inherit;
  object-fit: cover;
}
.about-eyebrow {
  margin: 0 0 24px;
  color: var(--about-text);
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 14px;
  font-weight: 300;
  letter-spacing: 4px;
  line-height: 1.4;
  text-transform: uppercase;
}
.about-hero-copy .about-eyebrow {
  margin-bottom: 18px;
  color: #333333;
  font-size: 11px;
  font-weight: 400;
  letter-spacing: .24em;
  line-height: 1.35;
}
.about-hero-redesign {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: clamp(64px, 7vw, 112px);
  align-items: center;
  width: var(--editorial-container);
  min-height: 78vh;
  margin: 0 auto;
  padding: 58px 0;
}
.about-hero-placeholder {
  min-height: 520px;
  height: min(68vh, 680px);
}
.about-hero-copy h1,
.about-centered-heading h2,
.about-philosophy h2,
.about-beyond-copy h2,
.about-cta h2 {
  margin: 0;
  color: var(--about-text);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-weight: 400;
  letter-spacing: -.025em;
}
.about-hero-copy h1 {
  max-width: 720px;
  font-size: clamp(46px, 3.85vw, 72px);
  line-height: .98;
}
.about-hero-copy p:not(.about-eyebrow),
.journey-block p,
.about-timeline p,
.about-philosophy p,
.about-beyond-copy p:not(.about-eyebrow),
.about-cta p {
  color: var(--about-text);
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 22.22px;
}
.about-hero-copy p:not(.about-eyebrow) {
  max-width: 520px;
  margin: 28px 0 0;
}
.about-hero-copy p:not(.about-eyebrow) + p:not(.about-eyebrow) {
  margin-top: 20px;
}
.about-outline-button,
.about-filled-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 170px;
  height: 48px;
  margin-top: 42px;
  padding: 0 28px;
  border: 1px solid var(--about-accent);
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 12px;
  font-weight: 300;
  letter-spacing: .22em;
  line-height: 1;
  text-align: center;
  text-decoration: none;
  text-transform: uppercase;
  transition: background .25s ease, color .25s ease, border-color .25s ease;
}
.about-outline-button {
  background: transparent;
  color: var(--about-accent);
}
.about-outline-button:hover {
  background: var(--about-accent);
  color: #ffffff;
}
.about-journey {
  padding-top: 0;
}
.about-journey-heading {
  margin-bottom: 46px;
  text-align: left;
}
.about-journey-heading .about-eyebrow {
  margin-bottom: 18px;
  color: #333333;
  font-size: 11px;
  font-weight: 400;
  letter-spacing: .24em;
  line-height: 1.35;
}
.about-journey-heading h2 {
  max-width: 720px;
  margin: 0;
  color: var(--about-text);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(46px, 3.85vw, 72px);
  font-weight: 400;
  letter-spacing: -.025em;
  line-height: .98;
}
.about-centered-heading {
  text-align: center;
}
.about-centered-heading h2 {
  font-size: clamp(48px, 5vw, 68px);
  line-height: .98;
}
.about-divider {
  width: 100%;
  height: 1px;
  margin: 44px 0 58px;
  background: var(--about-line);
}
.about-journey-grid,
.about-timeline-grid,
.about-beyond {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(0, 1fr);
  gap: clamp(68px, 7vw, 110px);
  align-items: start;
}
.about-journey-grid {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: clamp(64px, 7vw, 112px);
}
.journey-block {
  position: relative;
  padding: 0;
  border-bottom: 0;
  overflow: hidden;
}
.journey-block + .journey-block {
  margin-top: 38px;
}
.journey-number {
  position: absolute;
  top: 0;
  left: -10px;
  z-index: 0;
  color: rgba(170, 179, 200, .18);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 118px;
  font-weight: 400;
  letter-spacing: -.03em;
  line-height: .78;
}
.journey-block h3,
.timeline-entry h3 {
  position: relative;
  z-index: 1;
  margin: 0 0 16px;
  color: var(--about-text);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 34px;
  font-weight: 400;
  line-height: 1;
}
.journey-block p {
  position: relative;
  z-index: 1;
  max-width: 480px;
  margin: 0;
}
.about-childhood-placeholder {
  min-height: 560px;
}
.about-timeline-section {
  padding-top: 128px;
}
.about-timeline-grid {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: clamp(64px, 7vw, 112px);
}
.about-timeline-placeholder {
  min-height: 0;
  aspect-ratio: 4 / 5;
}
.about-timeline-copy {
  min-height: 100%;
}
.about-timeline-heading {
  margin-bottom: 24px;
  text-align: left;
}
.about-timeline-heading h2 {
  max-width: 720px;
  margin: 0;
  color: var(--about-text);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(46px, 3.85vw, 72px);
  font-weight: 400;
  letter-spacing: -.025em;
  line-height: .98;
}
.about-timeline {
  position: relative;
  padding: 0 0 0 42px;
  border-left: 1px solid var(--about-accent);
}
.timeline-entry {
  position: relative;
  margin: 0 0 8px;
}
.timeline-entry:last-child {
  margin-bottom: 0;
}
.timeline-entry::before {
  content: "";
  position: absolute;
  top: 8px;
  left: -49px;
  width: 13px;
  height: 13px;
  border: 1px solid var(--about-accent);
  border-radius: 50%;
  background: var(--about-bg);
}
.timeline-entry-featured::before {
  background: var(--about-accent);
}
.timeline-entry-featured h3,
.timeline-entry-featured p {
  color: var(--about-accent);
}
.timeline-entry h3 {
  margin-bottom: 3px;
}
.timeline-entry p {
  margin: 0;
  color: var(--about-accent);
  letter-spacing: .18em;
  text-transform: uppercase;
}
.timeline-arrow {
  margin: -6px 0 4px;
  color: var(--about-accent);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 20px;
  line-height: 1;
}
.about-philosophy {
  padding-top: 128px;
  text-align: center;
}
.about-philosophy h2 {
  max-width: 1000px;
  margin: 0 auto;
  font-size: clamp(48px, 5.4vw, 72px);
  line-height: 1;
}
.about-philosophy p {
  max-width: 760px;
  margin: 38px auto 48px;
}
.about-landscape-placeholder {
  min-height: 420px;
}
.about-beyond {
  padding-top: 220px;
  align-items: center;
}
.about-square-placeholder {
  aspect-ratio: 1 / 1;
  min-height: 0;
}
.about-beyond-copy h2 {
  font-size: clamp(46px, 4.7vw, 64px);
  line-height: .98;
}
.about-beyond-copy p:not(.about-eyebrow) {
  max-width: 520px;
  margin: 42px 0 0;
}
.about-cta {
  padding-top: 128px;
  padding-bottom: 145px;
  text-align: center;
}
.about-cta h2 {
  color: var(--about-text);
  font-size: clamp(54px, 6vw, 80px);
  line-height: .96;
}
.about-cta p {
  max-width: 560px;
  margin: 34px auto 0;
}
.about-filled-button {
  background: var(--about-accent);
  color: #ffffff;
}
.about-filled-button:hover {
  background: transparent;
  color: var(--about-accent);
}
.about-closing {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: clamp(64px, 7vw, 112px);
  align-items: stretch;
  padding-top: 128px;
  padding-bottom: 128px;
}
.about-closing-copy h2 {
  max-width: 600px;
  margin: 0;
  color: var(--about-text);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(46px, 3.85vw, 72px);
  font-weight: 400;
  letter-spacing: -.025em;
  line-height: .98;
}
.about-closing-copy {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-self: stretch;
}
.about-closing-reflection h2 {
  font-size: clamp(42px, 3.4vw, 62px);
}
.about-closing-copy p {
  max-width: 510px;
  margin: 28px 0 0;
  color: var(--about-text);
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 22.22px;
}
.about-closing-copy p + p {
  margin-top: 10px;
}
.about-closing-reflection p:first-of-type,
.about-closing-invitation p:first-of-type {
  margin-top: 24px;
}
.about-closing-invitation {
  padding-top: 52px;
}
.about-closing-invitation p + p {
  margin-top: 16px;
}
.about-closing-image {
  min-height: 0;
  aspect-ratio: auto;
}
.weddings-redesign {
  --wedding-bg: #f8f8f8;
  --wedding-text: #333333;
  --wedding-accent: #aab3c8;
  --wedding-line: rgba(170, 179, 200, .38);
  background: var(--wedding-bg);
  color: var(--wedding-text);
}
.weddings-redesign .wedding-section {
  width: var(--editorial-container);
  margin: 0 auto;
}
.wedding-placeholder {
  position: relative;
  display: grid;
  place-items: center;
  overflow: hidden;
  border: 1px solid var(--wedding-line);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, .18), rgba(170, 179, 200, .07)),
    rgba(255, 255, 255, .06);
  color: var(--wedding-accent);
}
.wedding-placeholder span {
  position: relative;
  z-index: 2;
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 12px;
  font-weight: 300;
  letter-spacing: .34em;
  line-height: 1.6;
  text-align: center;
  text-transform: uppercase;
}
.wedding-eyebrow {
  margin: 0 0 22px;
  color: var(--wedding-accent);
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 14px;
  font-weight: 300;
  letter-spacing: 4px;
  line-height: 1.4;
  text-transform: uppercase;
}
.wedding-hero {
  position: relative;
  min-height: 85vh;
  overflow: hidden;
}
.wedding-hero-placeholder {
  position: absolute;
  inset: 0;
  min-height: 100%;
  border: 0;
}
.wedding-hero-placeholder::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(90deg, rgba(246, 243, 237, .84) 0%, rgba(246, 243, 237, .62) 36%, rgba(246, 243, 237, .10) 74%),
    radial-gradient(circle at 67% 47%, rgba(51, 51, 51, .08), rgba(51, 51, 51, 0) 28%),
    linear-gradient(0deg, rgba(51, 51, 51, .08), rgba(51, 51, 51, .02));
  pointer-events: none;
}
.wedding-hero-copy {
  position: relative;
  z-index: 3;
  display: flex;
  min-height: 85vh;
  width: var(--editorial-container);
  margin: 0 auto;
  padding: 0 0 9vh;
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-start;
}
.wedding-hero-copy h1,
.wedding-section-intro h2,
.wedding-row-copy h3,
.wedding-statement-grid h2,
.wedding-why h2,
.wedding-why-grid h3,
.wedding-testimonial-placeholder h2,
.wedding-final-copy h2 {
  margin: 0;
  color: var(--wedding-text);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-weight: 400;
  letter-spacing: -.025em;
}
.wedding-hero-copy h1 {
  max-width: 720px;
  font-size: clamp(42px, 5.5vw, 76px);
  line-height: .95;
}
.wedding-hero-copy h1,
.wedding-section-intro h2,
.wedding-statement-grid h2,
.wedding-why h2,
.wedding-testimonial-placeholder h2,
.wedding-final-copy h2 {
  color: var(--wedding-accent);
}
.wedding-hero-copy > p:not(.wedding-eyebrow) {
  max-width: 560px;
  margin: 30px 0 0;
  color: var(--wedding-text);
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 16px;
  font-weight: 300;
  line-height: 1.8;
}
.wedding-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 28px;
  align-items: center;
  margin-top: 42px;
}
.wedding-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 166px;
  min-height: 48px;
  padding: 0 28px;
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 12px;
  font-weight: 300;
  letter-spacing: .22em;
  line-height: 1;
  text-align: center;
  text-decoration: none;
  text-transform: uppercase;
  transition: background .25s ease, color .25s ease, border-color .25s ease;
}
.wedding-button-filled {
  min-height: 54px;
  padding: 0 34px;
  color: var(--wedding-bg);
  background: var(--wedding-accent);
  border: 1px solid var(--wedding-accent);
}
.wedding-button-filled:hover,
.wedding-button-outline:hover {
  color: var(--wedding-bg);
  background: var(--wedding-accent);
  border-color: var(--wedding-accent);
}
.wedding-button-outline {
  color: #7f8ca2;
  background: transparent;
  border: 1px solid var(--wedding-accent);
}
.wedding-text-link {
  color: var(--wedding-text);
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 12px;
  font-weight: 300;
  letter-spacing: .22em;
  text-transform: uppercase;
  border-bottom: 1px solid transparent;
  transition: border-color .25s ease, color .25s ease;
}
.wedding-text-link:hover {
  color: #7f8ca2;
  border-color: #7f8ca2;
}
.wedding-experience {
  padding-top: 160px;
}
.wedding-section-intro {
  max-width: 720px;
  margin: 0 auto 96px;
  text-align: center;
}
.wedding-experience .wedding-section-intro {
  margin-bottom: 36px;
}
.wedding-section-intro h2,
.wedding-statement-grid h2,
.wedding-why h2 {
  font-size: clamp(46px, 5vw, 68px);
  line-height: .98;
}
.wedding-section-intro > p:not(.wedding-eyebrow) {
  margin: 34px auto 0;
  color: var(--wedding-text);
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 16px;
  font-weight: 300;
  line-height: 1.8;
}
.wedding-experience-row {
  display: grid;
  grid-template-columns: minmax(0, .92fr) minmax(0, 1.08fr);
  gap: clamp(60px, 8vw, 118px);
  align-items: center;
  padding: 88px 0;
  border-top: 1px solid var(--wedding-line);
}
.wedding-experience > .wedding-experience-row:first-of-type {
  padding-top: 58px;
  border-top: 0;
}
.wedding-experience-row:last-child {
  border-bottom: 1px solid var(--wedding-line);
}
.wedding-row-reverse {
  grid-template-columns: minmax(0, 1.08fr) minmax(0, .92fr);
}
.wedding-row-copy {
  max-width: 520px;
}
.wedding-row-copy h3 {
  font-size: clamp(40px, 4.3vw, 52px);
  line-height: 1;
}
.wedding-row-copy p:not(.wedding-eyebrow) {
  margin: 30px 0 36px;
  color: var(--wedding-text);
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 16px;
  font-weight: 300;
  line-height: 1.8;
}
.wedding-row-placeholder {
  aspect-ratio: 16 / 10;
  min-height: 360px;
}
.wedding-personalized {
  padding: 150px 0;
  border-top: 1px solid var(--wedding-line);
  border-bottom: 1px solid var(--wedding-line);
}
.wedding-statement-grid {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
  gap: clamp(70px, 9vw, 130px);
  align-items: start;
}
.wedding-statement-copy p {
  max-width: 660px;
  margin: 0 0 30px;
  color: var(--wedding-text);
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 16px;
  font-weight: 300;
  line-height: 1.8;
}
.wedding-why {
  padding-top: 150px;
  padding-bottom: 150px;
}
.wedding-why-grid {
  display: grid;
  gap: 0;
  border-top: 1px solid rgba(170, 179, 200, .24);
}
.wedding-why-grid article {
  position: relative;
  display: grid;
  grid-template-columns: minmax(86px, .22fr) minmax(0, 1fr);
  gap: clamp(30px, 5vw, 76px);
  align-items: start;
  padding: 58px 0 62px;
  border-bottom: 1px solid rgba(170, 179, 200, .24);
}
.wedding-why-grid span {
  display: block;
  color: rgba(170, 179, 200, .24);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(72px, 8vw, 116px);
  font-weight: 400;
  letter-spacing: -.06em;
  line-height: .75;
}
.wedding-why-grid h3 {
  max-width: 760px;
  font-size: clamp(46px, 5.4vw, 76px);
  line-height: .95;
}
.wedding-why-grid p {
  max-width: 680px;
  margin: 24px 0 0;
  color: var(--wedding-text);
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 22.22px;
}
.wedding-why-grid p + p {
  margin-top: 14px;
}
.wedding-centered-button {
  margin: 58px auto 0;
}
.wedding-testimonial-placeholder {
  max-width: 760px;
  padding: 170px 0;
  text-align: center;
}
.wedding-testimonial-placeholder h2 {
  font-size: clamp(46px, 5vw, 68px);
  line-height: 1;
}
.wedding-testimonial-placeholder > p {
  margin: 34px auto 0;
  color: var(--wedding-text);
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 15px;
  font-weight: 300;
  line-height: 1.8;
}
.wedding-testimonial-placeholder blockquote {
  position: relative;
  max-width: 680px;
  margin: 62px auto 26px;
  color: var(--wedding-text);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(34px, 4vw, 52px);
  font-weight: 400;
  line-height: 1.12;
}
.wedding-testimonial-placeholder blockquote::before {
  content: "“";
  position: absolute;
  top: -54px;
  left: 50%;
  color: rgba(170, 179, 200, .42);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 110px;
  line-height: 1;
  transform: translateX(-50%);
}
.wedding-testimonial-placeholder cite {
  color: var(--wedding-accent);
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 12px;
  font-style: normal;
  font-weight: 300;
  letter-spacing: .28em;
  text-transform: uppercase;
}
.wedding-final-cta {
  position: relative;
  min-height: 560px;
  margin: 0;
  overflow: hidden;
  margin-top: 0;
}
.wedding-cta-placeholder {
  position: absolute;
  inset: 0;
  min-height: 100%;
  border: 0;
}
.wedding-cta-placeholder::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(90deg, rgba(246, 243, 237, .98) 0%, rgba(246, 243, 237, .88) 34%, rgba(246, 243, 237, .30) 68%, rgba(246, 243, 237, 0) 86%);
  pointer-events: none;
}
.wedding-final-copy {
  position: relative;
  z-index: 3;
  width: var(--editorial-container);
  min-height: 560px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
}
.wedding-final-copy h2 {
  max-width: 560px;
  color: var(--wedding-accent);
  font-size: clamp(52px, 6vw, 82px);
  line-height: .92;
}
.wedding-final-copy p {
  max-width: 520px;
  margin: 0 0 14px;
  color: var(--wedding-text);
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 15px;
  font-weight: 300;
  line-height: 1.8;
}
.wedding-final-copy h2 + p {
  margin-top: 30px;
}
.wedding-final-copy p:last-of-type {
  margin-bottom: 32px;
}
.events-redesign {
  --event-bg: #f8f8f8;
  --event-alt: #f8f8f8;
  --event-text: #222222;
  --event-secondary: #5e5e5e;
  --event-accent: #aab3c8;
  --event-border: #d9d4cb;
  background: var(--event-bg);
  color: var(--event-text);
}
.events-redesign .event-section {
  width: var(--editorial-container);
  margin: 0 auto;
}
.event-placeholder {
  display: grid;
  place-items: center;
  min-height: 260px;
  overflow: hidden;
  border: 1px solid var(--event-border);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, .22), rgba(170, 180, 200, .08)),
    rgba(255, 255, 255, .08);
  color: var(--event-accent);
  transition: transform .45s ease, border-color .45s ease;
}
.event-placeholder:hover {
  border-color: rgba(170, 180, 200, .72);
  transform: scale(1.012);
}
.event-placeholder span {
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 12px;
  font-weight: 300;
  letter-spacing: .32em;
  line-height: 1.6;
  text-align: center;
  text-transform: uppercase;
}
.event-eyebrow {
  margin: 0 0 24px;
  color: var(--event-accent);
  font-family: Montserrat, "Avenir Next", Inter, sans-serif;
  font-size: 13px;
  font-weight: 300;
  letter-spacing: .25em;
  line-height: 1.4;
  text-transform: uppercase;
}
.event-hero {
  position: relative;
  display: grid;
  min-height: 0;
  aspect-ratio: 16 / 9;
  overflow: hidden;
}
.event-hero-placeholder {
  position: absolute;
  inset: 0;
  min-height: 100%;
  border-left: 0;
  border-right: 0;
}
.event-hero-placeholder::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(244, 241, 235, 0) 0%, rgba(244, 241, 235, .1) 32%, rgba(244, 241, 235, .42) 62%, rgba(244, 241, 235, .55) 100%),
    linear-gradient(0deg, rgba(34, 34, 34, .05), rgba(34, 34, 34, .01));
}
.event-hero-copy {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  width: var(--editorial-container);
  min-height: 100%;
  margin: 0 auto;
  padding: 72px 0;
}
.events-redesign .event-hero .event-eyebrow {
  color: rgba(255, 255, 255, .87);
}
.events-redesign .event-hero h1 {
  color: #d9dee8;
}
.events-redesign .event-hero-copy > p:not(.event-eyebrow) {
  color: rgba(255, 255, 255, .65);
}
.events-redesign .event-hero .event-button {
  min-width: 166px;
  min-height: 48px;
  padding: 0 28px;
  color: #7f8ca2;
  background: transparent;
  border: 1px solid #aab3c8;
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  letter-spacing: .22em;
}
.events-redesign .event-hero .event-button:hover,
.events-redesign .event-hero .event-button:focus-visible {
  color: #f6f3ed;
  background: #aab3c8;
  border-color: #aab3c8;
}
.event-hero h1,
.event-difference h2,
.event-centered-heading h2,
.event-final-copy h2 {
  margin: 0;
  color: var(--event-text);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-weight: 400;
  letter-spacing: -.02em;
}
.event-hero h1 {
  max-width: 860px;
  font-size: clamp(42px, 6vw, 90px);
  line-height: .95;
}
.event-hero h1,
.event-difference h2,
.event-centered-heading h2,
.event-final-copy h2 {
  color: var(--event-accent);
}
.event-hero-copy > p:not(.event-eyebrow),
.event-difference-copy p:not(.event-eyebrow),
.event-final-copy p:not(.event-eyebrow) {
  max-width: 650px;
  margin: 34px 0 0;
  color: var(--event-secondary);
  font-family: Montserrat, "Avenir Next", Inter, sans-serif;
  font-size: clamp(16px, 1.35vw, 20px);
  font-weight: 300;
  line-height: 1.8;
}
.event-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 170px;
  min-height: 52px;
  margin-top: 42px;
  padding: 0 32px;
  font-family: Montserrat, "Avenir Next", Inter, sans-serif;
  font-size: 12px;
  font-weight: 300;
  letter-spacing: .25em;
  line-height: 1;
  text-transform: uppercase;
  transition: background .25s ease, color .25s ease, border-color .25s ease;
}
.event-button-filled {
  color: var(--event-bg);
  background: var(--event-accent);
  border: 1px solid var(--event-accent);
}
.event-button-filled:hover,
.event-button-outline:hover {
  color: var(--event-bg);
  background: var(--event-accent);
  border-color: var(--event-accent);
}
.event-button-outline {
  color: #7f8ca2;
  background: transparent;
  border: 1px solid var(--event-accent);
}
.events-redesign .event-final-cta .event-button-filled:hover,
.events-redesign .event-final-cta .event-button-filled:focus-visible {
  color: #fffdf8;
  background: #8794aa;
  border-color: #8794aa;
}
.event-difference {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
  gap: clamp(70px, 8vw, 130px);
  align-items: center;
  padding: 170px 0;
}
.event-difference h2,
.event-final-copy h2 {
  max-width: 720px;
  font-size: clamp(42px, 5vw, 76px);
  line-height: .95;
}
.event-large-placeholder {
  min-height: 580px;
}
.event-types,
.event-repertoire-preview {
  padding: 150px 0;
  border-top: 1px solid var(--event-border);
  border-bottom: 1px solid var(--event-border);
}
.event-centered-heading {
  max-width: 760px;
  margin: 0 auto 82px;
  text-align: center;
}
.event-centered-heading h2 {
  font-size: clamp(42px, 4.8vw, 72px);
  line-height: .95;
}
.event-card-grid,
.event-experience-grid,
.event-repertoire-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 24px;
}
.event-card-grid article {
  min-height: 360px;
  padding: 34px 28px 32px;
  border: 1px solid var(--event-border);
  background: rgba(247, 245, 240, .46);
}
.event-card-grid span,
.event-experience-grid span {
  display: block;
  margin-bottom: 34px;
  color: var(--event-accent);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 36px;
  font-weight: 400;
  line-height: 1;
}
.event-card-grid h3,
.event-experience-grid h3,
.event-repertoire-grid h3 {
  margin: 0 0 30px;
  color: var(--event-text);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(32px, 3vw, 44px);
  font-weight: 400;
  letter-spacing: -.02em;
  line-height: 1;
}
.event-card-grid p,
.event-repertoire-grid p {
  margin: 0 0 13px;
  color: var(--event-secondary);
  font-family: Montserrat, "Avenir Next", Inter, sans-serif;
  font-size: 14px;
  font-weight: 300;
  line-height: 1.7;
}
.event-experience {
  padding: 160px 0;
}
.event-experience-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(44px, 6vw, 90px);
}
.event-experience-grid article {
  padding-top: 34px;
  border-top: 1px solid var(--event-border);
}
.event-experience-grid p {
  margin: 0;
  color: var(--event-secondary);
  font-family: Montserrat, "Avenir Next", Inter, sans-serif;
  font-size: 16px;
  font-weight: 300;
  line-height: 1.8;
}
.event-repertoire-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(40px, 5vw, 80px);
}
.event-repertoire-grid article {
  padding: 34px 0 0;
  border-top: 1px solid var(--event-border);
}
.event-centered-button {
  margin: 62px auto 0;
}
.event-final-cta {
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr);
  gap: clamp(70px, 8vw, 130px);
  align-items: center;
  width: var(--editorial-container);
  margin: 0 auto;
  padding: 160px 0 180px;
}
.event-final-placeholder {
  min-height: 620px;
}
/* Premium Events page content following the unchanged hero. */
.event-premium-section {
  width: var(--editorial-container);
  margin: 0 auto;
  padding: 128px 0;
}
.event-premium-label {
  margin: 0;
  color: var(--event-accent);
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 13px;
  font-weight: 300;
  letter-spacing: .32em;
  line-height: 1.5;
  text-transform: uppercase;
}
.event-client-reasons > .event-premium-label {
  margin-bottom: 40px;
}
.event-client-reasons-grid {
  display: grid;
  gap: 0;
}
.event-client-reasons-grid article {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr);
  column-gap: 20px;
  row-gap: 0;
  padding: 15px 0;
  border-top: 1px solid rgba(170, 179, 200, .5);
}
.event-client-reasons-grid span {
  display: block;
  position: relative;
  z-index: 0;
  align-self: start;
  margin-top: 0;
  color: rgba(170, 179, 200, .22);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 72px;
  font-weight: 400;
  letter-spacing: -.05em;
  line-height: .78;
}
.event-client-reasons-grid h2,
.event-about-adam h2 {
  margin: 0;
  color: var(--event-text);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(42px, 4vw, 64px);
  font-weight: 400;
  letter-spacing: -.025em;
  line-height: 1;
}
.event-client-reasons-grid p,
.event-premium-heading > p:not(.event-premium-label),
.event-about-adam-copy > p:not(.event-premium-label),
.event-contact-cta > p:not(.event-premium-label) {
  color: var(--event-text);
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 22.22px;
}
.event-client-reasons-grid p {
  max-width: 360px;
  margin: 8px 0 0;
}
.event-client-reasons-grid article > div {
  display: contents;
}
.event-client-reasons-grid article h2 {
  position: relative;
  z-index: 1;
  grid-column: 2;
}
.event-client-reasons-grid article p {
  grid-column: 1 / -1;
  max-width: none;
}
.event-discovery {
  padding-top: 128px;
  padding-bottom: 128px;
}
.event-discovery-top {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, .82fr);
  gap: clamp(70px, 9vw, 145px);
  align-items: start;
}
.event-video-showcase {
  min-height: 0;
  margin-top: 0;
}
.event-premium-heading {
  display: grid;
  grid-template-columns: minmax(220px, .75fr) minmax(0, 1.25fr);
  gap: clamp(50px, 8vw, 130px);
  align-items: start;
  margin-bottom: 48px;
}
.event-premium-heading > p:not(.event-premium-label) {
  max-width: 620px;
  margin: 0;
}
.event-video-frame {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 100%;
  background: #202020;
}
.event-video-frame video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.event-video-overlay {
  position: absolute;
  inset: 0;
  display: grid;
  align-content: start;
  max-width: 100%;
  padding: clamp(28px, 5vw, 70px);
  color: #fff;
  background: linear-gradient(180deg, rgba(10, 12, 14, .68), rgba(10, 12, 14, 0) 58%);
  pointer-events: none;
  opacity: 1;
  transition: opacity .35s ease;
}
.event-video-frame.is-playing .event-video-overlay {
  opacity: 0;
}
.event-video-overlay .event-premium-label {
  color: rgba(255, 255, 255, .82);
}
.event-video-overlay > p:not(.event-premium-label) {
  max-width: 560px;
  margin: 20px 0 0;
  color: rgba(255, 255, 255, .88);
  font-size: 12.35px;
  line-height: 22.22px;
}
.event-featured-listening {
  min-height: 0;
  padding: 0;
  background: transparent;
}
.event-listening-intro {
  margin-bottom: 24px;
}
.event-listening-intro .event-premium-label {
  margin-bottom: 12px;
}
.event-listening-intro > p:not(.event-premium-label),
.event-listening-guide p {
  margin: 0;
  color: var(--event-text);
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 22.22px;
}
.event-featured-listening-inner {
  display: block;
  width: 100%;
  height: 360px;
  margin: 0 auto;
}
.event-spotify-wrap {
  position: relative;
  min-height: 0;
  overflow: hidden;
  border-radius: 0;
  background: #202020;
}
.event-featured-cover {
  position: absolute;
  z-index: 3;
  top: 12px;
  left: 12px;
  display: grid;
  place-items: start;
  width: 128px;
  height: 128px;
  padding: 6px;
  color: rgba(255, 255, 255, .92);
  background: #202020;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 20px;
  font-weight: 400;
  line-height: .92;
  pointer-events: none;
}
.event-featured-cover span {
  display: grid;
  align-content: end;
  width: 92px;
  height: 92px;
  padding: 10px;
  background: #8796ad;
}
.event-featured-cover::after {
  position: absolute;
  top: 96px;
  left: 128px;
  width: 250px;
  height: 36px;
  background: #202020;
  content: "";
}
.event-featured-overlay {
  position: absolute;
  z-index: 2;
  top: 18px;
  right: 76px;
  left: 152px;
  width: auto;
  min-height: 104px;
  padding: 0 10px;
  color: #fff;
  background: rgba(31, 31, 31, .96);
  pointer-events: none;
}
.event-featured-overlay .event-premium-label {
  color: rgba(255, 255, 255, .82);
}
.event-featured-overlay > p:not(.event-premium-label) {
  margin: 0;
  color: rgba(255, 255, 255, .76);
  font-size: 11.5px;
  line-height: 18px;
}
.event-spotify-player {
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
  border-radius: 0;
}
.event-corporate-player.song-collection-tracks {
  align-self: stretch;
  width: 100%;
  height: 100%;
  border-radius: 0;
}
.event-listening-guide {
  max-width: 620px;
  margin-top: 24px;
  padding-top: 0;
  border-top: 0;
}
.event-listening-guide h2 {
  margin: 0 0 12px;
  color: var(--event-text);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 34px;
  font-weight: 400;
  line-height: 1;
}
.event-listening-guide p + p {
  margin-top: 8px;
}
.event-listening-guide .event-listening-button {
  min-height: 52px;
  margin-top: 8.5px;
}
.event-corporate-player .song-collection-player-header {
  padding: 8px 14px;
}
.event-corporate-player .song-collection-player-meta h2 {
  font-size: 15px;
}
.event-corporate-player .song-collection-track-area {
  padding-bottom: 6px;
}
.event-corporate-player.song-collection-page .song-detail-song {
  min-height: 34px;
  padding-top: 3px;
  padding-bottom: 3px;
}
.event-corporate-player .song-inline-player {
  grid-template-columns: 26px minmax(80px, 1fr) 30px;
  gap: 8px;
}
.event-corporate-player .song-inline-play {
  width: 24px;
  height: 24px;
}
.event-corporate-player .song-inline-wave {
  height: 20px;
}
.event-about-adam {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, .82fr);
  gap: clamp(70px, 9vw, 145px);
  align-items: start;
  padding-top: 128px;
  padding-bottom: 0;
}
.event-about-adam-copy .event-premium-label {
  margin-bottom: 30px;
}
.event-about-adam-copy h2 {
  margin-bottom: 42px;
}
.event-about-adam-copy > p:not(.event-premium-label) {
  max-width: 650px;
  margin: 0;
}
.event-about-adam-copy > p:not(.event-premium-label) + p {
  margin-top: 20px;
}
.event-about-adam-portrait {
  margin: 0;
  aspect-ratio: 4 / 5;
  overflow: hidden;
}
.event-about-adam-portrait img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.event-contact-cta {
  position: relative;
  isolation: isolate;
  display: grid;
  align-content: center;
  justify-items: start;
  width: 100%;
  min-height: clamp(430px, 42vw, 640px);
  margin: 0;
  padding: 116px max(24px, calc((100% - var(--editorial-width)) / 2)) 132px;
  overflow: hidden;
  background: url("images/placeholders/adam-event-CAT-portrait.jpg") center / cover no-repeat;
  text-align: left;
}
.event-contact-cta::before {
  position: absolute;
  z-index: -1;
  inset: 0;
  background: rgba(18, 20, 23, .5);
  content: "";
}
.event-contact-cta .event-premium-label {
  max-width: 470px;
  color: rgba(255, 255, 255, .94);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(46px, 3.85vw, 72px);
  font-weight: 400;
  letter-spacing: -.025em;
  line-height: .98;
  text-transform: uppercase;
}
.event-contact-cta > p:not(.event-premium-label) {
  max-width: 430px;
  margin: 34px 0 0;
  color: rgba(255, 255, 255, .82);
  font-family: Montserrat, "Avenir Next", Inter, sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 22.22px;
}
.event-contact-cta .event-button {
  margin-top: 42px;
  color: rgba(255, 255, 255, .94);
  border-color: rgba(255, 255, 255, .72);
}
.event-contact-cta .event-button:hover {
  color: #20252b;
  background: rgba(255, 255, 255, .9);
  border-color: rgba(255, 255, 255, .9);
}
/* Match Weddings and Events typography to the About hero's editorial system. */
.weddings-redesign .wedding-hero-copy h1,
.weddings-redesign .wedding-section-intro h2,
.weddings-redesign .wedding-statement-grid h2,
.weddings-redesign .wedding-why h2,
.weddings-redesign .wedding-testimonial-placeholder h2,
.weddings-redesign .wedding-final-copy h2,
.events-redesign .event-hero h1,
.events-redesign .event-difference h2,
.events-redesign .event-centered-heading h2,
.events-redesign .event-final-copy h2 {
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(46px, 3.85vw, 72px);
  font-weight: 400;
  letter-spacing: -.025em;
  line-height: .98;
}
.weddings-redesign .wedding-row-copy h3,
.weddings-redesign .wedding-why-grid h3,
.events-redesign .event-card-grid h3,
.events-redesign .event-experience-grid h3,
.events-redesign .event-repertoire-grid h3 {
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(30px, 3vw, 44px);
  font-weight: 400;
  letter-spacing: -.025em;
  line-height: 1;
}
.weddings-redesign .wedding-hero-copy > p:not(.wedding-eyebrow),
.weddings-redesign .wedding-section-intro > p:not(.wedding-eyebrow),
.weddings-redesign .wedding-row-copy p:not(.wedding-eyebrow),
.weddings-redesign .wedding-statement-copy p,
.weddings-redesign .wedding-why-grid p,
.weddings-redesign .wedding-testimonial-placeholder > p,
.weddings-redesign .wedding-final-copy p,
.events-redesign .event-hero-copy > p:not(.event-eyebrow),
.events-redesign .event-difference-copy p:not(.event-eyebrow),
.events-redesign .event-card-grid p,
.events-redesign .event-experience-grid p,
.events-redesign .event-repertoire-grid p,
.events-redesign .event-final-copy p:not(.event-eyebrow) {
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 22.22px;
}
.events-redesign .event-section,
.events-redesign .event-hero-copy,
.events-redesign .event-final-cta {
  animation: eventFadeUp .75s ease both;
}

@keyframes eventFadeUp {
from {
    opacity: 0;
    transform: translateY(18px);
  }
to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: reduce) {
.events-redesign .event-section,
.events-redesign .event-hero-copy,
.events-redesign .event-final-cta {
    animation: none;
  }
}
.song-list-redesign {
  --song-bg: #f8f8f8;
  --song-text: #222222;
  --song-secondary: #5e5e5e;
  --song-accent: #aab3c8;
  --song-border: #d9d4cb;
  background: var(--song-bg);
  color: var(--song-text);
  padding-bottom: 0;
}
.song-overview-page {
  min-height: calc(100vh - 79px);
  padding-bottom: 0;
}
.song-overview {
  display: grid;
  grid-template-columns: minmax(250px, .75fr) minmax(0, 2.25fr);
  gap: clamp(44px, 6vw, 84px);
  align-items: center;
  min-height: calc(100vh - 79px);
  padding: 42px 0;
}
.song-overview-intro {
  align-self: center;
}
.song-overview-intro .song-eyebrow {
  margin-bottom: 14px;
}
.song-overview-intro h1 {
  max-width: 360px;
  margin: 0;
  color: var(--song-text);
  font-family: Montserrat, sans-serif;
  font-size: clamp(32px, 3.33vw, 50px);
  font-weight: 400;
  letter-spacing: normal;
  line-height: 1.1;
}
.song-overview-intro > p:not(.song-eyebrow) {
  max-width: 350px;
  margin: 22px 0 0;
  color: var(--song-secondary);
  font-family: Montserrat, sans-serif;
  font-size: 13px;
  font-weight: 300;
  line-height: 1.75;
}
.song-overview .song-collection-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(22px, 2.4vw, 34px);
  padding: 0;
}
.song-overview .song-cover {
  box-shadow: 0 14px 30px rgba(34, 34, 34, .07);
}
.song-overview .song-card-title {
  margin-top: 10px;
  font-size: 12.5px;
  line-height: 1.3;
}
.song-section,
.song-hero {
  width: var(--editorial-container);
  margin: 0 auto;
}
.song-hero {
  display: grid;
  justify-items: center;
  padding: 78px 0 58px;
  text-align: center;
}
.song-eyebrow {
  margin: 0 0 18px;
  color: var(--song-accent);
  font-family: Montserrat, sans-serif;
  font-size: 11px;
  font-weight: 400;
  letter-spacing: .28em;
  line-height: 1.6;
  text-transform: uppercase;
}
.song-hero h1 {
  max-width: 700px;
  margin: 0;
  color: var(--song-text);
  font-family: Montserrat, sans-serif;
  font-size: clamp(32px, 3.33vw, 50px);
  font-weight: 400;
  letter-spacing: normal;
  line-height: 1.1;
}
.song-hero p:not(.song-eyebrow),
.song-custom-grid > div:last-child p {
  max-width: 760px;
  margin: 26px auto 0;
  color: #20252b;
  font-family: Montserrat, sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 19px;
}
.song-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 210px;
  min-height: 54px;
  margin-top: 46px;
  padding: 0 28px;
  border: 1px solid var(--song-accent);
  color: #7d8aa0;
  font-family: Montserrat, sans-serif;
  font-size: 12px;
  font-weight: 300;
  letter-spacing: .22em;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;
  transition: background-color .25s ease, color .25s ease, border-color .25s ease;
}
.song-button:hover {
  background: var(--song-accent);
  color: #ffffff;
  border-color: var(--song-accent);
}
.song-collections {
  padding: 78px 0 92px;
  border-top: 0;
}
.song-custom h2,
.song-collection-detail h2 {
  margin: 0;
  color: var(--song-text);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(44px, 5vw, 68px);
  font-weight: 400;
  letter-spacing: -.01em;
  line-height: 1;
}
.song-featured-collection,
.song-collection-card {
  display: grid;
  width: 100%;
  border: 0;
  background: transparent;
  color: inherit;
  cursor: pointer;
  font: inherit;
  text-align: left;
  text-decoration: none;
}
.song-collection-card:focus,
.song-sample-button:focus,
.song-player-button:focus,
.song-collection-card:focus-visible,
.song-sample-button:focus-visible,
.song-player-button:focus-visible {
  outline: 1px solid var(--song-accent);
  outline-offset: 4px;
}
.song-featured-collection {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(24px, 3vw, 38px);
  align-items: stretch;
  max-width: none;
  margin: 0 auto;
  padding: 0 0 46px;
  border-bottom: 0;
  cursor: default;
}
.song-cover {
  position: relative;
  display: block;
  overflow: hidden;
  aspect-ratio: 1 / 1;
  background: #e7e2d8;
  box-shadow: 0 22px 44px rgba(34, 34, 34, .08);
}
.song-featured-cover {
  width: 100%;
  min-width: 0;
  aspect-ratio: 4 / 3;
}
.song-cover::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(34, 34, 34, .18) 0%, rgba(34, 34, 34, .04) 38%, rgba(34, 34, 34, .58) 100%);
  opacity: .78;
  pointer-events: none;
  transition: opacity .28s ease, background-color .28s ease;
}
.song-cover img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(.82) contrast(.96);
  transform: scale(1.01);
  transition: transform .45s ease, filter .45s ease;
}
.song-collection-card:hover .song-cover img,
.song-collection-card.is-active .song-cover img {
  filter: saturate(.95) contrast(1);
  transform: scale(1.03);
}
.song-collection-card:hover .song-cover::after,
.song-collection-card.is-active .song-cover::after {
  opacity: 1;
  background:
    linear-gradient(180deg, rgba(34, 34, 34, .34) 0%, rgba(34, 34, 34, .12) 36%, rgba(34, 34, 34, .68) 100%);
}
.song-cover::before {
  content: "♪";
  position: absolute;
  top: 18px;
  left: 18px;
  z-index: 2;
  display: grid;
  width: 36px;
  height: 36px;
  place-items: center;
  border: 1px solid rgba(255, 255, 255, .72);
  border-radius: 999px;
  color: #ffffff;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 23px;
  font-weight: 400;
  line-height: 1;
}
.song-cover-brand,
.song-cover-listen {
  position: absolute;
  z-index: 2;
  color: #ffffff;
  pointer-events: none;
}
.song-cover-brand {
  right: 22px;
  bottom: 24px;
  left: 22px;
  font-family: Montserrat, sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  letter-spacing: normal;
  line-height: 1.1;
}
.song-cover-listen {
  right: 22px;
  bottom: 22px;
  left: 22px;
  opacity: 0;
  transform: translateY(8px);
  font-family: Montserrat, sans-serif;
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .22em;
  line-height: 1.5;
  text-transform: uppercase;
  transition: opacity .28s ease, transform .28s ease;
}
.song-collection-card:hover .song-cover-brand,
.song-collection-card.is-active .song-cover-brand {
  transform: translateY(-34px);
}
.song-cover-brand {
  transition: transform .28s ease;
}
.song-collection-card:hover .song-cover-listen,
.song-collection-card.is-active .song-cover-listen {
  opacity: 1;
  transform: translateY(0);
}
.song-featured-copy {
  display: flex;
  min-width: 0;
  flex-direction: column;
  align-items: flex-start;
  justify-content: space-between;
  padding: 0 0 12px;
}
.song-featured-cover-link,
.song-featured-details {
  color: inherit;
  text-decoration: none;
}
.song-featured-title-frame {
  display: grid;
  gap: 0;
  width: 100%;
  padding: 28px 30px 30px;
  border: 1px solid rgba(170, 179, 200, .78);
  color: var(--song-text);
  cursor: default;
}
.song-featured-title-frame .song-eyebrow {
  margin-bottom: 16px;
}
.song-featured-editorial-title {
  color: #333333;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(46px, 3.85vw, 72px);
  font-weight: 400;
  letter-spacing: -.025em;
  line-height: .98;
}
.song-featured-editorial-copy {
  margin-top: 24px;
  color: #333333;
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 22.22px;
}
.song-featured-details {
  display: grid;
  justify-items: start;
  width: 100%;
  padding-top: 36px;
}
.song-card-kicker {
  display: block;
  margin: 0 0 18px;
  color: #7d8aa0;
  font-family: Montserrat, sans-serif;
  font-size: 11px;
  font-weight: 400;
  letter-spacing: .28em;
  line-height: 1.5;
  text-transform: uppercase;
}
.song-card-title {
  display: block;
  margin-top: 18px;
  color: var(--song-text);
  font-family: Montserrat, sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  letter-spacing: normal;
  line-height: 1.1;
}
.song-featured-collection .song-card-title {
  margin-top: 0;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(30px, 2.8vw, 42px);
  font-weight: 400;
  letter-spacing: -.025em;
  line-height: 1;
}
.song-card-description {
  display: block;
  max-width: 540px;
  margin-top: auto;
  color: #20252b;
  font-family: Montserrat, sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 19px;
}
.song-card-action {
  display: inline-flex;
  gap: 18px;
  align-items: center;
  margin-top: 34px;
  color: #7d8aa0;
  font-family: Montserrat, sans-serif;
  font-size: 11px;
  font-weight: 400;
  letter-spacing: .18em;
  line-height: 1.4;
  text-transform: uppercase;
}
.song-card-action span {
  font-size: 22px;
  font-weight: 300;
  letter-spacing: 0;
  transition: transform .25s ease;
}
.song-featured-details:hover .song-card-action span {
  transform: translate(-5px, 5px);
}
.song-collection-card.is-active .song-card-title,
.song-collection-card.is-active .song-card-action {
  color: #7d8aa0;
}
.song-collection-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 48px clamp(24px, 3vw, 38px);
  padding-top: 0;
}

@media (min-width: 981px) {
.about-hero-copy {
    position: relative;
  }
.about-hero-copy .about-eyebrow {
    position: absolute;
    top: -33px;
    left: 0;
    margin: 0;
  }
.about-hero-copy h1 {
    position: relative;
    top: 2.5px;
  }
.song-list-redesign .song-featured-collection {
    align-items: start;
  }
.song-list-redesign .song-featured-copy {
    aspect-ratio: 4 / 3;
    padding-bottom: 0;
  }
.song-list-redesign .song-featured-title-frame {
    padding: 20px 24px 22px;
  }
.song-list-redesign .song-featured-title-frame .song-eyebrow {
    margin-bottom: 10px;
  }
.song-list-redesign .song-featured-editorial-title {
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: clamp(40px, 3.2vw, 54px);
    font-weight: 400;
    letter-spacing: -.025em;
    line-height: .98;
  }
.song-list-redesign .song-featured-editorial-copy {
    margin-top: 16px;
  }
.song-list-redesign .song-featured-details {
    padding-top: 16px;
  }
.song-list-redesign .song-card-kicker {
    margin-bottom: 10px;
  }
.song-list-redesign .song-featured-collection .song-card-title {
    font-size: clamp(32px, 2.7vw, 38px);
    letter-spacing: -.025em;
    line-height: 1;
  }
.song-list-redesign .song-card-description {
    margin-top: 8px;
  }
.song-list-redesign .song-card-action {
    margin-top: 16px;
  }
}
.song-collection-grid .song-card-description {
  font-size: 12.35px;
  line-height: 19px;
}
.song-collection-detail {
  margin: 54px 0 0;
  padding: 38px 0 42px;
  border-top: 1px solid var(--song-border);
  border-bottom: 1px solid var(--song-border);
  animation: songDetailIn .32s ease both;
}
.song-collection-grid .song-collection-detail {
  grid-column: 1 / -1;
}
.song-collection-detail[hidden] {
  display: none;
}

@keyframes songDetailIn {
from {
    opacity: 0;
    transform: translateY(10px);
  }
to {
    opacity: 1;
    transform: translateY(0);
  }
}
.song-detail-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 32px;
  align-items: end;
  margin-bottom: 26px;
}
.song-detail-count {
  margin: 0;
  color: #7d8aa0;
  font-family: Montserrat, sans-serif;
  font-size: 11px;
  font-weight: 400;
  letter-spacing: .24em;
  line-height: 1.6;
  text-transform: uppercase;
}
.song-detail-list {
  display: grid;
  margin: 0;
  padding: 0;
  margin: 0;
  list-style: none;
}
.song-detail-song {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 24px;
  align-items: center;
  padding: 17px 0;
  border-top: 1px solid var(--song-border);
}
.song-detail-song:last-child {
  border-bottom: 1px solid var(--song-border);
}
.song-detail-title {
  color: var(--song-text);
  font-family: Montserrat, sans-serif;
  font-size: 15.35px;
  font-weight: 400;
  letter-spacing: normal;
  line-height: 1.1;
}
.song-sample-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 0 16px;
  border: 0;
  background: transparent;
  color: #7d8aa0;
  cursor: pointer;
  font-family: Montserrat, sans-serif;
  font-size: 11px;
  font-weight: 400;
  letter-spacing: .18em;
  text-transform: uppercase;
  transition: color .2s ease;
}
.song-sample-button:hover,
.song-sample-button.is-active {
  color: var(--song-text);
}
.song-audio-note {
  max-width: 720px;
  margin: 34px 0 0;
  color: #20252b;
  font-family: Montserrat, sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 19px;
}
.song-custom {
  padding: 86px 0;
  border-top: 1px solid var(--song-border);
  border-bottom: 1px solid var(--song-border);
}
.song-custom-grid {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
  gap: clamp(70px, 9vw, 150px);
  align-items: center;
}
.song-custom-grid > div:last-child p {
  margin: 0;
}
.song-custom .song-button {
  margin-top: 42px;
}
.song-player {
  --song-text: #222222;
  --song-accent: #aab3c8;
  position: static;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: clamp(18px, 3vw, 36px);
  align-items: center;
  min-height: 76px;
  padding: 14px clamp(22px, 5vw, 70px);
  background: rgba(248, 248, 248, .96);
  border-top: 1px solid rgba(170, 179, 200, .62);
  box-shadow: none;
}
.song-player-controls {
  display: flex;
  gap: 8px;
  align-items: center;
}
.song-player-button {
  display: inline-grid;
  width: 38px;
  height: 38px;
  place-items: center;
  border: 1px solid rgba(170, 179, 200, .78);
  border-radius: 999px;
  background: transparent;
  color: var(--song-text);
  cursor: pointer;
  font-family: Montserrat, sans-serif;
  font-size: 18px;
  font-weight: 300;
  line-height: 1;
}
.song-player-toggle {
  width: auto;
  min-width: 70px;
  padding: 0 16px;
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
}
.song-player-title,
.song-player-time {
  margin: 0;
  color: var(--song-text);
  font-family: Montserrat, sans-serif;
  font-size: 11px;
  font-weight: 400;
  letter-spacing: .12em;
  line-height: 1.4;
  text-transform: uppercase;
}
.song-player-main {
  display: grid;
  grid-template-columns: auto minmax(180px, 1fr);
  gap: 24px;
  align-items: center;
  min-width: 0;
}
.song-player-title {
  display: flex;
  gap: 0 12px;
  align-items: center;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.song-player-artist {
  color: inherit;
  font-size: inherit;
  letter-spacing: inherit;
}
.song-player-wave {
  position: relative;
  height: 20px;
  margin-top: 0;
  overflow: hidden;
}
.song-player-wave-bars {
  position: absolute;
  inset: 0;
  display: flex;
  gap: 2px;
  align-items: center;
  color: rgba(125, 138, 160, .28);
}
.song-player-wave-bars span {
  display: block;
  flex: 1 1 0;
  min-width: 1px;
  max-width: 2px;
  border-radius: 999px;
  background: currentColor;
}
.song-player-wave-progress {
  position: absolute;
  inset: 0 auto 0 0;
  width: 0;
  overflow: hidden;
  transition: width .2s linear;
}
.song-player-wave-progress .song-player-wave-bars {
  inset: 0 auto 0 0;
  width: var(--footer-wave-width, 100%);
  color: #7d8aa0;
}
.song-player-time {
  color: #7d8aa0;
  white-space: nowrap;
}
.song-collection-page {
  min-height: 0;
  height: auto;
  padding-bottom: 0;
  overflow: visible;
}
.song-collection-view {
  display: grid;
  grid-template-rows: auto auto auto;
  align-content: start;
  gap: 0;
  width: var(--editorial-container);
  min-height: 0;
  height: auto;
  margin: 0 auto;
  padding: 63px 0 92px;
}
.song-collection-page-title {
  color: rgba(125, 138, 160, .68);
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: clamp(14px, 1.35vw, 18px);
  font-weight: 300;
  letter-spacing: .52em;
  line-height: 1.4;
  text-align: center;
  text-transform: uppercase;
}
.song-collection-main-grid {
  display: grid;
  grid-template-columns: minmax(250px, .72fr) minmax(0, 1.38fr);
  gap: clamp(52px, 7vw, 100px);
  align-items: start;
  margin-top: 42px;
}
.song-collection-summary {
  display: grid;
  align-content: start;
  padding-top: 0;
}
.song-back-link {
  justify-self: start;
  margin-bottom: 18px;
  color: #7d8aa0;
  font-family: Montserrat, sans-serif;
  font-size: 10px;
  font-weight: 400;
  letter-spacing: .18em;
  line-height: 1.5;
  text-decoration: none;
  text-transform: uppercase;
}
.song-collection-art {
  display: block;
  width: 100%;
  height: auto;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}
.song-collection-copy {
  display: grid;
  align-content: start;
  min-height: 0;
}
.song-collection-kicker {
  margin: 0 0 15px;
  color: #4f5d6b;
  font-family: Montserrat, sans-serif;
  font-size: 11px;
  font-weight: 300;
  letter-spacing: .28em;
  line-height: 1.5;
  text-transform: uppercase;
}
.song-collection-copy h2 {
  margin: 0;
  color: var(--song-text);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(38px, 3.6vw, 52px);
  font-weight: 400;
  letter-spacing: normal;
  line-height: .95;
}
.song-collection-copy > [data-collection-description] {
  max-width: 330px;
  margin: 24px 0 0;
  color: #20252b;
  font-family: Montserrat, sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 22.22px;
}
.song-collection-custom {
  margin: 0;
  padding: 0;
  border: 0;
  text-align: center;
}
.song-collection-custom p {
  margin: 7px 0 0;
  color: #20252b;
  font-family: Montserrat, sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 22.22px;
}
.song-collection-custom a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  margin-top: 14px;
  padding: 0 18px;
  border: 1px solid var(--song-accent);
  color: #7d8aa0;
  font-family: Montserrat, sans-serif;
  font-size: 9px;
  font-weight: 400;
  letter-spacing: .18em;
  line-height: 1.5;
  text-decoration: none;
  text-transform: uppercase;
  transition: background-color .2s ease, color .2s ease;
}
.song-collection-actions {
  display: flex;
  justify-content: center;
  gap: 7px;
}
.song-preview-notes {
  margin: 24px 0 0;
  padding: 18px 0 0;
  border-top: 1px solid var(--song-border);
  text-align: left;
}
.song-preview-notes h2,
.song-preview-notes p {
  margin: 0;
  color: #20252b;
  font-family: Montserrat, sans-serif;
  font-weight: 400;
}
.song-preview-notes h2 {
  font-size: 16px;
  line-height: 1.5;
}
.song-preview-notes p {
  margin: 6px 0 0;
  font-size: 12.35px;
  line-height: 22.22px;
}
.song-collection-custom a:hover {
  background: var(--song-accent);
  color: #ffffff;
}
.song-collection-custom h2 {
  margin: 0;
  color: #20252b;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 23px;
  font-weight: 400;
  line-height: 1;
}
.song-collection-support {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  align-items: start;
  width: min(100%, 620px);
  margin: 42px auto 0;
  padding-top: 0;
  border-top: 0;
}
.song-collection-tracks {
  align-self: start;
  display: grid;
  grid-template-rows: 22% minmax(0, 78%);
  width: 100%;
  height: var(--collection-art-height, 360px);
  color: #ffffff;
  background: #77869d;
  border-radius: 6px;
  overflow: hidden;
}
.song-collection-player-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 7px 14px;
  background: #77869d;
}
.song-collection-player-meta {
  min-width: 0;
}
.song-collection-player-label,
.song-collection-player-meta h2,
.song-collection-player-current {
  margin: 0;
  color: #ffffff;
  font-family: Montserrat, sans-serif;
}
.song-collection-player-label {
  font-size: 9px;
  font-weight: 400;
  letter-spacing: .18em;
  line-height: 1.5;
  text-transform: uppercase;
}
.song-collection-player-meta h2 {
  overflow: hidden;
  margin-top: 0;
  font-size: 17px;
  font-weight: 500;
  line-height: 1.15;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.song-collection-player-current {
  display: flex;
  gap: 8px;
  margin-top: 4px;
  font-size: 11px;
  font-weight: 400;
  line-height: 1.3;
}
.song-collection-player-current span:last-child {
  opacity: .68;
  font-size: 9px;
  text-transform: uppercase;
}
.song-collection-player-controls {
  display: flex;
  gap: 7px;
  align-items: center;
}
.song-collection-player-controls button {
  display: grid;
  width: 28px;
  height: 28px;
  place-items: center;
  padding: 0;
  border: 0;
  background: transparent;
  color: #ffffff;
  cursor: pointer;
  font-family: Montserrat, sans-serif;
  font-size: 11px;
}
.song-collection-player-controls .song-collection-main-play {
  width: 36px;
  height: 36px;
  margin-left: 4px;
  border-radius: 50%;
  background: #ffffff;
  color: #5f6f87;
  font-size: 15px;
  box-shadow: 0 8px 22px rgba(34, 34, 34, .16);
}
.song-collection-track-area {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  min-height: 0;
  padding: 0 14px 10px;
  background: #64738a;
}
.song-collection-track-header {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  padding: 7px 8px 5px;
}
.song-collection-track-header p,
.song-collection-track-area .song-collection-note {
  margin: 0;
  color: rgba(255, 255, 255, .72);
  font-family: Montserrat, sans-serif;
  font-size: 8px;
  font-weight: 400;
  letter-spacing: .18em;
  line-height: 1.5;
  text-transform: uppercase;
}
.song-collection-page .song-detail-song {
  grid-template-columns: 24px minmax(0, .8fr) minmax(190px, 1.2fr);
  min-height: 38px;
  padding: 5px 8px;
  border-top-color: rgba(255, 255, 255, .12);
  cursor: pointer;
  transition: background-color .2s ease, padding .2s ease;
}
.song-track-number,
.song-track-artist {
  color: rgba(255, 255, 255, .62);
  font-family: Montserrat, sans-serif;
  font-size: 8px;
  font-weight: 400;
  line-height: 1.3;
}
.song-track-number {
  text-align: center;
}
.song-track-meta {
  display: grid;
  gap: 2px;
  min-width: 0;
}
.song-track-artist {
  text-transform: none;
}
.song-track-meta .song-detail-title {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.song-collection-page .song-detail-song:hover,
.song-collection-page .song-detail-song:focus-visible,
.song-collection-page .song-detail-song.is-active {
  background: rgba(255, 255, 255, .13);
  outline: 0;
}
.song-collection-page .song-detail-title {
  color: #ffffff;
}
.song-collection-page .song-detail-list {
  min-height: 0;
  overflow-x: hidden;
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-color: rgba(125, 138, 160, .55) transparent;
  scrollbar-width: thin;
}
.song-collection-page .song-detail-list::-webkit-scrollbar {
  width: 5px;
}
.song-collection-page .song-detail-list::-webkit-scrollbar-track {
  background: transparent;
}
.song-collection-page .song-detail-list::-webkit-scrollbar-thumb {
  background: rgba(125, 138, 160, .45);
}
.song-collection-page .song-sample-button {
  min-height: 30px;
  padding-right: 0;
  font-size: 10px;
  pointer-events: none;
}
.song-inline-player {
  display: grid;
  grid-template-columns: 30px minmax(90px, 1fr) 34px;
  gap: 12px;
  align-items: center;
  min-width: 0;
  color: #7d8aa0;
  pointer-events: none;
}
.song-inline-play {
  display: grid;
  width: 28px;
  height: 28px;
  place-items: center;
  border: 1px solid rgba(255, 255, 255, .62);
  border-radius: 50%;
  color: #ffffff;
  font-family: Montserrat, sans-serif;
  font-size: 9px;
  line-height: 1;
}
.song-inline-wave {
  position: relative;
  display: block;
  height: 24px;
  overflow: hidden;
}
.song-inline-wave-bars {
  position: absolute;
  inset: 0;
  display: flex;
  gap: 2px;
  align-items: center;
  color: rgba(255, 255, 255, .32);
}
.song-inline-wave-bars span {
  display: block;
  flex: 1 1 0;
  min-width: 1px;
  max-width: 2px;
  border-radius: 999px;
  background: currentColor;
}
.song-inline-wave-progress {
  position: absolute;
  inset: 0 auto 0 0;
  z-index: 1;
  width: 0;
  overflow: hidden;
  transition: width .2s linear;
}
.song-inline-wave-progress .song-inline-wave-bars {
  inset: 0 auto 0 0;
  width: var(--inline-wave-width, 100%);
  color: #ffffff;
}
.song-inline-time {
  color: rgba(255, 255, 255, .82);
  font-family: Montserrat, sans-serif;
  font-size: 10px;
  font-weight: 400;
  line-height: 1;
  text-align: right;
}
.song-collection-note {
  max-width: 560px;
  padding: 7px 8px 0;
  border-top: 1px solid rgba(255, 255, 255, .12);
  color: rgba(255, 255, 255, .65);
  font-size: 8px;
  font-weight: 400;
  letter-spacing: .02em;
  line-height: 1.45;
  text-transform: none;
}
.song-collection-document {
  display: block;
  min-height: 100vh;
  height: auto;
  overflow: auto;
}
.song-collection-document .site-header,
.song-collection-document .site-footer,
.song-collection-document .song-player {
  min-height: 0;
}
.site-footer {
  display: grid;
  justify-items: center;
  align-content: center;
  gap: 10px;
  min-height: 170px;
  padding: 30px clamp(22px, 5vw, 70px);
  color: #ffffff;
  background: #8f9db3;
  border-top: 0;
  text-align: center;
}
.footer-brand {
  color: #ffffff;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(22px, 2.2vw, 32px);
  font-weight: 400;
  letter-spacing: .12em;
  line-height: 1;
  text-transform: uppercase;
}
.site-footer p,
.site-footer small,
.footer-email,
.footer-nav {
  margin: 0;
  color: #ffffff;
  font-family: Montserrat, sans-serif;
  font-size: 11px;
  font-weight: 300;
  letter-spacing: .22em;
  line-height: 1.8;
}
.footer-nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  text-transform: uppercase;
}
.footer-email {
  letter-spacing: .08em;
  text-transform: none;
}

@keyframes slowDrift {
from { transform: scale(1) translate3d(-1%, -1%, 0); }
to { transform: scale(1.08) translate3d(1%, 1%, 0); }
}

@media (max-width: 980px) {
.nav-toggle { display: block; }
.site-nav {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    display: none;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: 22px;
    background: var(--ivory);
    border-bottom: 1px solid var(--line);
  }
.site-nav.is-open { display: flex; }
.site-nav a { padding: 16px 0; }
.nav-dropdown {
    display: grid;
    align-items: stretch;
  }
.nav-submenu {
    position: static;
    min-width: 0;
    padding: 0 0 0 18px;
    background: transparent;
    border: 0;
    opacity: 1;
    pointer-events: auto;
    transform: none;
  }
.nav-submenu a { padding: 10px 0 16px; }
.section-grid,
.artist-introduction,
.about-editorial-section,
.about-editorial-section.reverse,
.about-value-grid,
.final-cta,
.home-awards,
.home-wedding-preview,
.experience-row,
.experience-row.reverse,
.inline-form,
.credentials-line,
.contact-page,
.faq-layout,
.video-grid {
    grid-template-columns: 1fr;
  }
.final-cta-image {
    min-height: 360px;
    order: -1;
  }
.final-cta-copy {
    padding: 48px 28px 56px;
  }
.about-page {
    padding-top: 64px;
  }
.about-editorial-section {
    gap: 42px;
  }
.about-editorial-section.reverse .about-image {
    order: -1;
  }
.about-editorial-redesign .about-section,
.about-hero-redesign {
    width: min(100% - 42px, 680px);
  }
.about-hero-redesign {
    grid-template-columns: 1fr;
    min-height: auto;
    padding: 48px 0 12px;
  }
.about-hero-placeholder {
    min-height: 420px;
    height: min(58vh, 520px);
    aspect-ratio: auto;
  }
.about-journey,
.about-timeline-section,
.about-philosophy,
.about-cta {
    padding-top: 82px;
  }
.about-journey-grid,
.about-timeline-grid,
.about-closing,
.about-beyond {
    grid-template-columns: 1fr;
    gap: 52px;
  }
.about-closing {
    padding-top: 82px;
    padding-bottom: 96px;
  }
.about-divider {
    margin: 32px 0 42px;
  }
.about-journey-heading {
    margin-bottom: 38px;
  }
.journey-block + .journey-block {
    margin-top: 34px;
  }
.about-childhood-placeholder,
.about-landscape-placeholder {
    min-height: 330px;
  }
.timeline-photos .about-placeholder {
    min-height: 150px;
  }
.about-cta {
    padding-bottom: 96px;
  }
.weddings-redesign .wedding-section,
.wedding-hero-copy,
.wedding-final-copy {
    width: min(100% - 42px, 680px);
  }
.wedding-hero,
.wedding-hero-copy {
    min-height: 70vh;
  }
.wedding-hero-copy {
    padding-bottom: 72px;
  }
.wedding-experience {
    padding-top: 110px;
  }
.wedding-section-intro {
    margin-bottom: 66px;
  }
.wedding-experience .wedding-section-intro {
    margin-bottom: 36px;
  }
.wedding-experience-row,
.wedding-row-reverse,
.wedding-statement-grid,
.wedding-why-grid {
    grid-template-columns: 1fr;
  }
.wedding-experience-row {
    gap: 40px;
    padding: 62px 0;
  }
.wedding-experience > .wedding-experience-row:first-of-type {
    padding-top: 42px;
  }
.wedding-row-copy {
    max-width: none;
  }
.wedding-row-placeholder {
    min-height: 260px;
  }
.wedding-personalized,
.wedding-testimonial-placeholder {
    padding: 110px 0;
  }
.wedding-why {
    padding-top: 110px;
  }
.wedding-button {
    width: 100%;
  }
.wedding-hero-actions {
    width: 100%;
    align-items: stretch;
  }
.wedding-text-link {
    width: fit-content;
    margin: 0 auto;
    padding: 12px 0;
  }
.wedding-final-copy,
.wedding-final-cta {
    min-height: 480px;
  }
.events-redesign .event-section,
.event-hero-copy,
.event-final-cta {
    width: min(100% - 42px, 680px);
  }
.event-hero,
.event-hero-copy {
    min-height: 70vh;
  }
.event-difference,
.event-card-grid,
.event-experience-grid,
.event-repertoire-grid,
.event-final-cta {
    grid-template-columns: 1fr;
  }
.event-difference,
.event-types,
.event-experience,
.event-repertoire-preview {
    padding: 110px 0;
  }
.event-centered-heading {
    margin-bottom: 58px;
  }
.event-large-placeholder,
.event-final-placeholder {
    min-height: 360px;
  }
.event-card-grid article {
    min-height: 0;
  }
.event-final-cta {
    gap: 52px;
    padding: 110px 0 120px;
  }
.event-button {
    width: 100%;
  }
.song-section,
.song-hero {
    width: min(100% - 42px, 680px);
  }
.song-hero {
    padding: 76px 0 58px;
  }
.song-hero h1 {
    font-size: clamp(32px, 3.33vw, 50px);
  }
.song-hero p:not(.song-eyebrow),
.song-custom-grid > div:last-child p {
    font-size: 16px;
  }
.song-list-redesign {
    padding-bottom: 0;
  }
.song-overview-page {
    min-height: calc(100vh - 79px);
    padding-bottom: 0;
  }
.song-overview {
    grid-template-columns: 1fr;
    align-content: start;
    min-height: calc(100vh - 79px);
    padding: 34px 0;
    gap: 28px;
  }
.song-overview-intro h1,
.song-overview-intro > p:not(.song-eyebrow) {
    max-width: 620px;
  }
.song-overview .song-collection-grid {
    grid-template-columns: none;
    grid-auto-flow: column;
    grid-auto-columns: minmax(160px, 42vw);
    gap: 20px;
    overflow-x: auto;
    padding: 0 0 14px;
    scroll-snap-type: x proximity;
  }
.song-overview .song-collection-card {
    scroll-snap-align: start;
  }
.song-collection-view {
    align-content: start;
    height: auto;
    min-height: auto;
    padding: 56px 0 80px;
    gap: 32px;
  }
.song-collection-document {
    display: block;
    height: auto;
    min-height: 100vh;
    overflow: auto;
  }
.song-collection-page {
    height: auto;
    overflow: visible;
  }
.song-collection-main-grid {
    grid-template-columns: 1fr;
    gap: 28px;
  }
.song-collection-summary {
    display: block;
  }
.song-back-link {
    grid-column: 1 / -1;
  }
.song-collection-art {
    width: 100%;
    height: auto;
  }
.song-collection-copy {
    margin-top: 0;
  }
.song-collection-copy > [data-collection-description] {
    max-width: 520px;
  }
.song-collection-tracks {
    width: 100%;
    height: auto;
    margin-top: 0 !important;
  }
.song-collection-support {
    width: min(100%, 620px);
  }
.song-collections,
.song-custom {
    padding: 72px 0;
  }
.song-featured-collection,
.song-collection-grid,
.song-custom-grid {
    grid-template-columns: 1fr;
    gap: 38px;
  }
.song-overview .song-collection-grid {
    grid-template-columns: none;
    gap: 20px;
  }
.song-featured-collection {
    padding-bottom: 52px;
  }
.song-collection-grid {
    padding-top: 52px;
  }
.song-collection-detail h2 {
    font-size: clamp(38px, 12vw, 58px);
  }
.song-detail-header,
.song-detail-song,
.song-player {
    grid-template-columns: 1fr;
  }
.song-detail-song {
    gap: 10px;
    justify-items: start;
  }
.song-collection-page .song-detail-song {
    grid-template-columns: minmax(0, 1fr) auto;
    justify-items: stretch;
  }
.song-player {
    gap: 10px;
    justify-items: stretch;
    min-height: 116px;
  }
.song-player-controls {
    justify-content: center;
  }
.song-player-title,
.song-player-time {
    text-align: center;
  }
.song-button {
    width: 100%;
  }
.why-adam {
    width: min(1220px, calc(100% - 42px));
    padding-top: 72px;
  }
.why-adam-main {
    grid-template-columns: 1fr;
    gap: 52px;
  }
.why-adam-intro {
    position: static;
  }
.why-adam-intro p:not(.small-label),
.why-adam-list p {
    max-width: none;
  }
.why-adam-list article {
    grid-template-columns: 46px minmax(0, 1fr);
    column-gap: 22px;
  }
.why-adam .brand-statement {
    margin-top: 52px;
  }
.faq-page {
    padding: 64px 0 108px;
  }
.faq-redesign .faq-hero {
    width: min(100% - 42px, 680px);
    padding: 110px 0 78px;
  }
.faq-redesign .faq-hero h1 {
    font-size: clamp(42px, 13vw, 56px);
  }
.faq-redesign .faq-hero p:not(.faq-eyebrow) {
    font-size: 16px;
  }
.faq-redesign .faq-page {
    grid-template-columns: 1fr;
    gap: 54px;
    width: min(100% - 42px, 680px);
    padding: 0 0 110px;
  }
.faq-sticky-nav {
    position: static;
    grid-template-columns: 1fr;
    gap: 0;
    padding-top: 0;
    border-top: 1px solid var(--faq-border);
  }
.faq-nav-link {
    padding: 15px 0;
    border-bottom: 1px solid var(--faq-border);
  }
.faq-nav-link.is-active {
    transform: none;
  }
.faq-redesign .faq-section {
    scroll-margin-top: 90px;
    padding-bottom: 70px;
    margin-bottom: 72px;
  }
.faq-redesign .faq-section h2 {
    margin-bottom: 34px;
    font-size: 42px;
  }
.faq-accordion-trigger {
    padding: 22px 0;
    font-size: 18px;
  }
.faq-accordion-panel p {
    padding-right: 0;
    font-size: 16px;
  }
.faq-redesign .faq-contact-note p {
    font-size: 16px;
  }
.faq-editorial .faq-page {
    width: min(100% - 42px, 680px);
    padding: 82px 0 110px;
  }
.faq-background-word {
    top: 150px;
    font-size: clamp(126px, 34vw, 220px);
  }
.faq-category-nav {
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 18px 28px;
    margin-bottom: 72px;
  }
.faq-category-link {
    font-size: clamp(22px, 8vw, 34px);
  }
.faq-category-link::after {
    bottom: -10px;
  }
.faq-editorial .faq-content {
    width: 100%;
    margin-left: 0;
  }
.faq-editorial .faq-section {
    scroll-margin-top: 90px;
    padding-bottom: 66px;
    margin-bottom: 70px;
  }
.faq-editorial .faq-section h2 {
    margin-bottom: 38px;
    font-size: 42px;
  }
.faq-editorial .faq-question {
    margin-bottom: 42px;
  }
.faq-editorial .faq-question h3 {
    font-size: 18px;
  }
.faq-editorial .faq-question p,
.faq-editorial .faq-contact-note p {
    font-size: 16px;
  }
.faq-topline {
    align-items: flex-start;
    margin-bottom: 48px;
  }
.faq-categories {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
    margin-bottom: 52px;
    border-bottom: 0;
    transform: none;
  }
.faq-category {
    width: 100%;
    padding: 16px 0;
    border-bottom: 1px solid rgba(143, 154, 175, .42);
    font-size: 28px;
    text-align: left;
  }
.faq-category::after {
    display: none;
  }
.faq-category-indicator {
    display: none;
  }
.faq-layout {
    gap: 42px;
    transform: none;
  }
.faq-side-label {
    position: static;
    height: auto;
    writing-mode: horizontal-tb;
    transform: none;
    margin-bottom: 22px;
  }
.faq-title {
    display: flex;
    gap: 16px;
    font-size: 64px;
    line-height: 1;
  }
.faq-background-title {
    top: 60px;
    left: 0;
    width: 100%;
    font-size: clamp(150px, 42vw, 220px);
    opacity: .8;
  }
.faq-questions {
    padding-top: 0;
    left: 0;
  }
.faq-contact-button {
    transform: none;
  }
.service-tabs,
.service-panel,
.service-panel.is-active {
    grid-template-columns: 1fr;
  }
.service-tabs {
    gap: 1px;
  }
.service-panel {
    gap: 36px;
  }
.ceremony-panel.is-active {
    display: block;
  }
.ceremony-intro-row,
.ceremony-music-row {
    grid-template-columns: 1fr;
    gap: 42px;
  }
.ceremony-intro-row {
    margin-bottom: 72px;
    min-height: 0;
  }
.ceremony-intro-headline,
.ceremony-intro-copy {
    width: 100%;
    max-width: 100%;
  }
.ceremony-feeling h3 {
    font-size: 58px;
  }
.artist-image {
    justify-self: center;
  }
.experience-row.reverse img { order: 0; }
}

@media (max-width: 640px) {
:root {
    --editorial-container: min(100% - 48px, 1220px);
  }
html,
body {
    overflow-x: hidden;
  }
body {
    font-size: 12.35px;
  }
.site-header {
    min-height: 70px;
    padding: 16px 24px;
  }
.wordmark {
    max-width: 260px;
    font-size: 16px;
    letter-spacing: .12em;
    line-height: 1.25;
  }
.nav-toggle {
    width: 40px;
    height: 40px;
    flex: 0 0 40px;
  }
.site-nav {
    padding: 18px 24px 22px;
  }
.site-nav a {
    min-height: 44px;
    padding: 13px 0;
    font-size: 12px;
    letter-spacing: .22em;
  }
.nav-submenu {
    padding-left: 0;
  }
.nav-submenu a {
    color: #7d8aa0;
    font-size: 11px;
  }
.site-footer {
    padding: 42px 24px 46px;
    gap: 10px;
  }
.footer-brand {
    font-size: 24px;
    letter-spacing: .16em;
    line-height: 1.15;
  }
.site-footer p,
.footer-email,
.site-footer small {
    font-size: 10px;
    line-height: 1.6;
  }
.home-hero {
    min-height: 58vh;
    height: 58vh;
  }
.artist-introduction,
.moses-style-artist,
.why-adam,
.home-wedding-preview,
.weddings-redesign .wedding-section,
.wedding-hero-copy,
.wedding-final-copy,
.events-redesign .event-section,
.event-hero-copy,
.event-final-cta,
.song-section,
.song-hero,
.contact-page,
.about-editorial-redesign .about-section,
.about-hero-redesign {
    width: min(100% - 48px, 680px);
  }
.artist-introduction,
.moses-style-artist {
    gap: 30px;
    padding: 64px 0 58px;
  }
.artist-image {
    width: min(100%, 330px);
    max-width: none;
    justify-self: center;
    aspect-ratio: 4 / 5;
  }
.artist-copy {
    max-width: none;
    transform: none;
  }
.artist-signature-group {
    margin: 0 0 20px;
  }
.pianist-signature {
    width: 176px;
  }
.meet-label,
.small-label,
.script-note,
.song-eyebrow,
.about-eyebrow,
.wedding-eyebrow,
.event-eyebrow {
    font-size: 10px;
    letter-spacing: .22em;
  }
.artist-body p,
.why-adam-intro p:not(.small-label),
.why-adam-list p,
.ceremony-intro-copy p,
.about-hero-copy p:not(.about-eyebrow),
.journey-block p,
.about-timeline p,
.about-philosophy p,
.about-cta p,
.weddings-redesign .wedding-hero-copy > p:not(.wedding-eyebrow),
.weddings-redesign .wedding-section-intro > p:not(.wedding-eyebrow),
.weddings-redesign .wedding-row-copy p:not(.wedding-eyebrow),
.weddings-redesign .wedding-statement-copy p,
.weddings-redesign .wedding-why-grid p,
.weddings-redesign .wedding-final-copy p,
.events-redesign .event-hero-copy > p:not(.event-eyebrow),
.events-redesign .event-difference-copy p:not(.event-eyebrow),
.events-redesign .event-card-grid p,
.events-redesign .event-experience-grid p,
.events-redesign .event-repertoire-grid p,
.events-redesign .event-final-copy p:not(.event-eyebrow),
.song-hero p:not(.song-eyebrow),
.song-overview-intro > p:not(.song-eyebrow),
.song-featured-editorial-copy,
.song-card-description,
.contact-copy p {
    font-size: 12.35px;
    line-height: 22.22px;
  }
.why-adam {
    padding: 62px 0 68px;
  }
.why-adam-main {
    gap: 34px;
  }
.why-adam-intro h2,
.weddings-redesign .wedding-hero-copy h1,
.weddings-redesign .wedding-section-intro h2,
.weddings-redesign .wedding-statement-grid h2,
.weddings-redesign .wedding-why h2,
.weddings-redesign .wedding-testimonial-placeholder h2,
.weddings-redesign .wedding-final-copy h2,
.events-redesign .event-hero h1,
.events-redesign .event-difference h2,
.events-redesign .event-centered-heading h2,
.events-redesign .event-final-copy h2,
.about-hero-copy h1,
.about-journey-heading h2,
.about-timeline-heading h2,
.about-centered-heading h2,
.about-philosophy h2,
.about-cta h2 {
    font-size: clamp(38px, 11.5vw, 48px);
    line-height: .98;
    letter-spacing: -.02em;
  }
.why-adam-list article {
    grid-template-columns: 32px minmax(0, 1fr);
    column-gap: 18px;
    padding: 22px 0 24px;
  }
.why-adam-list h3,
.weddings-redesign .wedding-row-copy h3,
.weddings-redesign .wedding-why-grid h3,
.events-redesign .event-card-grid h3,
.events-redesign .event-experience-grid h3,
.events-redesign .event-repertoire-grid h3 {
    font-size: clamp(28px, 8.4vw, 36px);
    line-height: 1.02;
  }
.service-tabs {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1px;
    margin-bottom: 44px;
  }
.service-tab {
    width: 100%;
    min-height: 46px;
    padding: 12px 14px;
  }
.ceremony-panel.is-active {
    padding-top: 0;
  }
.ceremony-intro-row {
    gap: 30px;
    margin-bottom: 56px;
  }
.ceremony-intro-headline h2 {
    max-width: 100%;
    font-size: clamp(38px, 11vw, 46px);
    letter-spacing: -.01em;
    line-height: 1.06;
  }
.ceremony-intro-copy h3 {
    margin-bottom: 22px;
  }
.ceremony-intro-copy .button,
.button,
.wedding-button,
.event-button,
.song-button,
.form-submit {
    width: 100%;
    min-height: 46px;
  }
.ceremony-music-row {
    gap: 34px;
  }
.ceremony-feeling {
    transform: none;
  }
.ceremony-feeling h3 {
    font-size: clamp(42px, 13vw, 56px);
    line-height: .98;
  }
.ceremony-video-frame,
.ceremony-feature-video {
    max-width: none;
  }
.about-hero-placeholder {
    min-height: 0;
    height: auto;
    aspect-ratio: 4 / 5;
  }
.about-hero-redesign {
    gap: 34px;
    padding: 46px 0 8px;
  }
.about-hero-copy .about-eyebrow {
    margin-bottom: 14px;
  }
.about-hero-copy p:not(.about-eyebrow) {
    max-width: none;
    margin-top: 24px;
  }
.about-hero-copy p:not(.about-eyebrow) + p:not(.about-eyebrow) {
    margin-top: 18px;
  }
.about-journey,
.about-timeline-section,
.about-philosophy,
.about-cta {
    padding-top: 66px;
  }
.about-closing {
    gap: 34px;
    padding-top: 66px;
    padding-bottom: 76px;
  }
.about-closing-image {
    aspect-ratio: 4 / 5;
  }
.about-closing-copy {
    gap: 58px;
  }
.about-closing-invitation {
    padding-top: 0;
  }
.about-closing-copy h2 {
    font-size: clamp(38px, 11.5vw, 48px);
    line-height: .98;
    letter-spacing: -.02em;
  }
.about-closing-copy p {
    max-width: none;
    font-size: 12.35px;
    line-height: 22.22px;
  }
.about-centered-heading {
    margin-bottom: 44px;
  }
.journey-block {
    padding: 0;
  }
.about-journey-heading {
    margin-bottom: 34px;
  }
.about-timeline-heading {
    margin-bottom: 34px;
  }
.journey-block + .journey-block {
    margin-top: 30px;
  }
.timeline-item {
    gap: 20px;
    padding-bottom: 32px;
  }
.wedding-hero,
.wedding-hero-copy,
.event-hero,
.event-hero-copy {
    min-height: 62vh;
  }
.event-hero {
    aspect-ratio: auto;
  }
.wedding-hero-copy,
.event-hero-copy {
    padding: 54px 0 58px;
  }
.wedding-hero-copy > p:not(.wedding-eyebrow),
.event-hero-copy > p:not(.event-eyebrow) {
    margin-top: 24px;
  }
.event-hero-copy > p:not(.event-eyebrow) br {
    display: none;
  }
.wedding-hero-actions,
.event-button {
    margin-top: 30px;
  }
.wedding-experience,
.wedding-why,
.event-difference,
.event-types,
.event-experience,
.event-repertoire-preview {
    padding: 72px 0;
  }
.wedding-section-intro,
.event-centered-heading {
    margin-bottom: 42px;
    text-align: left;
  }
.wedding-experience .wedding-section-intro {
    margin-bottom: 30px;
  }
.wedding-experience-row {
    gap: 28px;
    padding: 48px 0;
  }
.wedding-experience > .wedding-experience-row:first-of-type {
    padding-top: 30px;
  }
.wedding-row-placeholder,
.event-large-placeholder,
.event-final-placeholder {
    min-height: 0;
    aspect-ratio: 4 / 3;
  }
.wedding-personalized,
.wedding-testimonial-placeholder {
    padding: 72px 0;
  }
.wedding-final-copy,
.wedding-final-cta {
    min-height: 0;
  }
.wedding-final-cta,
.event-final-cta {
    gap: 34px;
    padding: 72px 0 86px;
  }
.event-card-grid,
.event-experience-grid,
.event-repertoire-grid {
    gap: 18px;
  }
.event-card-grid article {
    min-height: 0;
    padding: 26px 22px 28px;
  }
.song-overview {
    min-height: 0;
    padding: 42px 0 70px;
    gap: 34px;
  }
.song-overview-intro h1,
.song-hero h1 {
    font-size: clamp(30px, 9.5vw, 38px);
    line-height: 1.12;
  }
.song-featured-collection {
    grid-template-columns: 1fr;
    gap: 24px;
    padding-bottom: 34px;
  }
.song-featured-title-frame {
    padding: 22px 20px 24px;
  }
.song-featured-editorial-title {
    font-size: clamp(34px, 10vw, 42px);
  }
.song-featured-details {
    padding-top: 0;
  }
.song-card-action {
    min-height: 44px;
    margin-top: 20px;
  }
.song-cover::before {
    top: 14px;
    left: 14px;
    width: 32px;
    height: 32px;
    font-size: 20px;
  }
.song-cover-brand {
    right: 16px;
    bottom: 18px;
    left: 16px;
  }
.song-overview .song-collection-grid {
    grid-auto-columns: minmax(180px, 70vw);
    gap: 18px;
  }
.song-collections {
    padding: 56px 0 80px;
  }
.song-collection-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 28px 18px;
    padding-top: 0;
  }
.song-collection-grid .song-cover-brand {
    font-size: 10.5px;
  }
.song-collection-grid .song-card-title {
    margin-top: 9px;
    font-size: 12px;
    line-height: 1.25;
  }
.song-collection-view {
    width: min(100% - 48px, 680px);
    padding: 42px 0 72px;
    gap: 26px;
  }
.song-collection-page-title {
    font-size: 13px;
    letter-spacing: .48em;
  }
.song-collection-main-grid {
    gap: 26px;
    margin-top: 28px;
  }
.song-collection-copy h2 {
    font-size: clamp(38px, 12vw, 46px);
  }
.song-collection-tracks {
    height: min(64vh, 560px);
    min-height: 430px;
    border-radius: 5px;
  }
.song-collection-player-header {
    grid-template-columns: minmax(0, 1fr) auto;
    padding: 14px 14px;
  }
.song-collection-player-meta h2 {
    font-size: 14px;
    line-height: 1.25;
  }
.song-collection-player-controls {
    gap: 4px;
  }
.song-collection-player-controls button {
    width: 32px;
    height: 32px;
  }
.song-collection-player-controls .song-collection-main-play {
    width: 42px;
    height: 42px;
    margin-left: 2px;
  }
.song-collection-track-area {
    padding: 0 10px 10px;
  }
.song-collection-page .song-detail-song {
    grid-template-columns: 22px minmax(0, 1fr);
    gap: 8px 12px;
    min-height: 58px;
    padding: 9px 4px;
  }
.song-inline-player {
    grid-column: 2;
    grid-template-columns: 28px minmax(0, 1fr) 32px;
    gap: 9px;
    width: 100%;
  }
.song-inline-wave {
    min-width: 0;
  }
.song-track-number,
.song-track-artist,
.song-inline-time {
    font-size: 9px;
  }
.song-collection-page .song-detail-title {
    font-size: 15px;
  }
.song-preview-notes h2 {
    font-size: 14px;
  }
.song-collection-support {
    margin-top: 32px;
  }
.song-collection-actions {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
  }
.song-collection-custom a {
    width: 100%;
    min-height: 44px;
    margin-top: 0;
  }
.song-player {
    grid-template-columns: 1fr;
    gap: 12px;
    min-height: 0;
    padding: 16px 24px 18px;
  }
.song-player-main {
    grid-template-columns: 1fr;
    gap: 10px;
  }
.song-player-title {
    justify-content: center;
    white-space: normal;
  }
.song-player-wave {
    width: 100%;
    max-width: 280px;
    margin: 0 auto;
  }
.song-player-time {
    text-align: center;
  }
.contact-page {
    padding: 70px 0 92px;
  }
.contact-script-title {
    margin-bottom: 34px;
    font-size: clamp(54px, 17vw, 72px);
    line-height: .92;
  }
.contact-copy p {
    margin-bottom: 20px;
  }
.event-selection {
    margin-top: 58px;
  }
.event-question {
    margin-bottom: 24px;
    font-size: 28px;
  }
.event-choice-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
  }
.event-tab,
.event-tab:first-child,
.event-tab:last-child {
    width: 100%;
    min-height: 46px;
    font-size: 12px;
  }
.event-form {
    margin-top: 42px;
  }
.form-grid,
.form-grid.two-columns {
    grid-template-columns: 1fr;
  }
input,
select,
textarea {
    font-size: 16px;
  }
}
/* Disabled global typography experiment. */
@media (max-width: 0px) {
:root {
  --editorial-label: #8f98ac;
  --editorial-heading: #333333;
}

/* Shared deep warm-gray eyebrow and section-label color. */
.meet-label,
.small-label,
.script-note,
.about-eyebrow,
.wedding-eyebrow,
.event-eyebrow,
.event-premium-label,
.song-eyebrow,
.song-card-kicker {
  color: #333333;
}

.meet-label,
.small-label,
.script-note,
.about-eyebrow,
.wedding-eyebrow,
.event-eyebrow,
.event-premium-label,
.song-eyebrow,
.song-card-kicker {
  color: var(--editorial-label);
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 11px;
  font-weight: 400;
  letter-spacing: .26em;
  line-height: 1.5;
  text-transform: uppercase;
}

.why-adam-intro h2,
.ceremony-intro-headline h2,
.service-panel > h2,
.about-hero-copy h1,
.about-journey-heading h2,
.about-timeline-heading h2,
.about-closing-reflection h2,
.about-closing-invitation h2,
.weddings-redesign .wedding-hero-copy h1,
.weddings-redesign .wedding-section-intro h2,
.weddings-redesign .wedding-personalized-heading h2,
.weddings-redesign .wedding-final-copy h2,
.events-redesign .event-hero h1,
.events-redesign .event-about-adam-copy h2,
.events-redesign .event-listening-guide h2,
.events-redesign .event-final-copy h2,
.song-featured-editorial-title,
.song-overview-intro h1,
.song-hero h1,
.contact-script-title {
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(32px, 3.33vw, 50px);
  font-weight: 400;
  letter-spacing: -.02em;
  line-height: .96;
}

.why-adam-list h3,
.ceremony-intro-copy h3,
.ceremony-feeling h3,
.service-copy h3,
.journey-block h3,
.timeline-entry h3,
.weddings-redesign .wedding-row-copy h3,
.weddings-redesign .wedding-personalized-features h3,
.events-redesign .event-client-reasons-grid article h2,
.song-card-title {
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(28px, 2.65vw, 36px);
  font-weight: 400;
  letter-spacing: -.015em;
  line-height: 1.05;
}

.artist-body p,
.why-adam-intro p:not(.small-label),
.why-adam-list p,
.ceremony-intro-copy p,
.service-copy p,
.about-hero-copy p:not(.about-eyebrow),
.journey-block p,
.about-timeline p,
.about-closing-copy p,
.weddings-redesign .wedding-row-copy p:not(.wedding-eyebrow),
.weddings-redesign .wedding-personalized-copy p,
.weddings-redesign .wedding-final-copy p,
.events-redesign .event-about-adam-copy p,
.events-redesign .event-listening-guide p,
.events-redesign .event-client-reasons-grid p,
.events-redesign .event-contact-cta p:not(.event-premium-label),
.song-featured-editorial-copy,
.song-card-description,
.contact-copy p {
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: clamp(13px, 1vw, 15px);
  font-weight: 400;
  line-height: 1.75;
}

.button,
.wedding-button,
.event-button,
.song-button,
.form-submit,
.about-filled-button,
.artist-copy .learn-more {
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 11px;
  font-weight: 400;
  letter-spacing: .2em;
  line-height: 1;
  text-transform: uppercase;
}

/* Unify all eyebrow and section-label colors with the About page. */
main .meet-label,
main .small-label,
main .script-note,
main .about-eyebrow,
main .wedding-eyebrow,
main .event-eyebrow,
main .event-premium-label,
main .song-eyebrow,
main .song-card-kicker {
  color: #333333 !important;
}

@media (min-width: 901px) {
  .weddings-redesign .wedding-personalized-centered {
    padding-top: 89px;
  }

  .weddings-redesign .wedding-experience {
    padding-top: 88px;
  }

  .weddings-redesign .wedding-experience::before {
    display: none;
  }

  .weddings-redesign .wedding-experience .wedding-section-intro {
    margin-bottom: 88px;
  }

  .weddings-redesign .wedding-experience-row {
    position: relative;
    isolation: isolate;
  }

  .weddings-redesign .wedding-experience-row::before {
    content: "";
    position: absolute;
    inset: 0 50% 0 auto;
    z-index: -1;
    width: 100vw;
    background: #f8f8f8;
    transform: translateX(50%);
  }
}

/* Shared supporting-title scale and filled-button hover behavior. */
.weddings-redesign .wedding-personalized-features h3 {
  font-size: clamp(22px, 1.75vw, 24px);
  line-height: 1.2;
}

.primary-button,
.wedding-button-filled,
.event-button-filled,
.about-filled-button,
.form-submit {
  transition: color .3s ease, background-color .3s ease, border-color .3s ease;
}

.primary-button:hover,
.primary-button:focus-visible,
.wedding-button-filled:hover,
.wedding-button-filled:focus-visible,
.event-button-filled:hover,
.event-button-filled:focus-visible,
.about-filled-button:hover,
.about-filled-button:focus-visible,
.form-submit:hover,
.form-submit:focus-visible {
  color: #ffffff !important;
  background: #8f98ac !important;
  border-color: #8f98ac !important;
}

/* Final shared supporting-title and solid-button states. */
.weddings-redesign .wedding-personalized-features h3 {
  font-size: clamp(22px, 1.75vw, 24px) !important;
  line-height: 1.2 !important;
}

a.primary-button,
button.primary-button {
  color: #333333 !important;
  background: #c7d1e3 !important;
  border-color: #c7d1e3 !important;
}

a.primary-button:hover,
a.primary-button:focus-visible,
button.primary-button:hover,
button.primary-button:focus-visible {
  color: #ffffff !important;
  background: #8f98ac !important;
  border-color: #8f98ac !important;
}

.weddings-redesign .wedding-personalized-features p {
  font-size: clamp(13px, 1vw, 15px);
  font-weight: 400;
  line-height: 1.75;
}

/* Unified primary calls to action. */
.primary-button {
  color: #333333 !important;
  background: #c7d1e3 !important;
  border-color: #c7d1e3 !important;
}

.primary-button:hover,
.primary-button:focus-visible {
  color: #ffffff !important;
  background: #8f98ac !important;
  border-color: #8f98ac !important;
}

/* Events hero eyebrow follows its hero title color. */
.events-redesign .event-hero .event-eyebrow {
  color: #d9dee8 !important;
}

/* Active unified primary calls to action. */
a.primary-button,
button.primary-button {
  color: #333333 !important;
  background: #c7d1e3 !important;
  border-color: #c7d1e3 !important;
}

a.primary-button:hover,
a.primary-button:focus-visible,
button.primary-button:hover,
button.primary-button:focus-visible {
  color: #ffffff !important;
  background: #8f98ac !important;
  border-color: #8f98ac !important;
}

.events-redesign .event-hero .event-eyebrow {
  color: #d9dee8 !important;
}

/* Disabled final mature wedding-brand experiment. */
@media (max-width: 0px) {
/* Final mature wedding-brand controls and labels. */
main .meet-label,
main .small-label,
main .script-note,
main .about-eyebrow,
main .wedding-eyebrow,
main .event-eyebrow,
main .event-premium-label,
main .song-eyebrow,
main .song-card-kicker {
  color: #a7b2c8 !important;
}

.button-outline,
.wedding-button-outline,
.event-button-outline,
.song-button,
.faq-contact-button,
.faq-song-button {
  min-height: 52px !important;
  height: 52px !important;
  width: auto !important;
  min-width: max-content;
  padding-right: 40px !important;
  padding-left: 40px !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  letter-spacing: .22em !important;
  border-width: 1px !important;
  border-style: solid;
  transition: all .3s ease !important;
}

.button-outline:hover,
.wedding-button-outline:hover,
.event-button-outline:hover,
.song-button:hover,
.faq-contact-button:hover,
.faq-song-button:hover {
  color: #ffffff;
}

.weddings-redesign .wedding-personalized-centered {
  padding-bottom: 54px;
}

.weddings-redesign .wedding-personalized-features {
  margin-top: 14px;
}

.weddings-redesign .wedding-personalized-features article {
  min-height: 120px;
  padding-top: 46px;
}

.weddings-redesign .wedding-personalized-features h3 {
  margin-bottom: 8px;
}

.weddings-redesign .wedding-button-outline,
.events-redesign .event-button-outline,
.button-outline,
.song-button,
.faq-contact-button,
.faq-song-button {
  min-height: 52px !important;
  height: 52px !important;
  padding-right: 40px !important;
  padding-left: 40px !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  letter-spacing: .22em !important;
  border-width: 1px !important;
  transition: all .3s ease !important;
}

/* Final site-wide eyebrow and outline-button refinement. */
main .meet-label,
main .small-label,
main .script-note,
main .about-eyebrow,
main .wedding-eyebrow,
main .event-eyebrow,
main .event-premium-label,
main .song-eyebrow,
main .song-card-kicker {
  color: #a7b2c8 !important;
}

.button-outline,
.wedding-button-outline,
.event-button-outline,
.song-button,
.faq-contact-button,
.faq-song-button {
  min-height: 52px !important;
  height: 52px !important;
  padding-right: 40px !important;
  padding-left: 40px !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  letter-spacing: .22em !important;
  border-width: 1px !important;
  border-style: solid;
  transition: all .3s ease !important;
}

.button-outline:hover,
.wedding-button-outline:hover,
.event-button-outline:hover,
.song-button:hover,
.faq-contact-button:hover,
.faq-song-button:hover {
  color: #ffffff;
}

.weddings-redesign .wedding-personalized-centered {
  padding-bottom: 54px;
}

.weddings-redesign .wedding-personalized-features {
  margin-top: 14px;
}

.weddings-redesign .wedding-personalized-features article {
  min-height: 120px;
  padding-top: 46px;
}

.weddings-redesign .wedding-personalized-features h3 {
  margin-bottom: 8px;
}

}

main .meet-label,
main .small-label,
main .script-note,
main .about-eyebrow,
main .wedding-eyebrow,
main .events-redesign .event-eyebrow,
main .events-redesign .event-premium-label,
main .song-eyebrow,
main .song-card-kicker {
  color: #8f98ac;
  font-size: 11px;
  font-weight: 400;
  letter-spacing: .26em;
  line-height: 1.5;
}

main .button,
main .wedding-button,
main .events-redesign .event-button,
main .song-button,
main .form-submit,
main .about-filled-button,
main .artist-copy .learn-more {
  font-size: 11px;
  font-weight: 400;
  letter-spacing: .2em;
  line-height: 1;
}

@media (max-width: 640px) {
  .why-adam-intro h2,
  .ceremony-intro-headline h2,
  .service-panel > h2,
  .about-hero-copy h1,
  .about-journey-heading h2,
  .about-timeline-heading h2,
  .about-closing-reflection h2,
  .about-closing-invitation h2,
  .weddings-redesign .wedding-hero-copy h1,
  .weddings-redesign .wedding-section-intro h2,
  .weddings-redesign .wedding-personalized-heading h2,
  .weddings-redesign .wedding-final-copy h2,
  .events-redesign .event-hero h1,
  .events-redesign .event-about-adam-copy h2,
  .events-redesign .event-listening-guide h2,
  .events-redesign .event-final-copy h2,
  .song-featured-editorial-title,
  .song-overview-intro h1,
  .song-hero h1,
  .contact-script-title {
    font-size: clamp(38px, 11.5vw, 48px);
    line-height: .98;
  }

  .why-adam-list h3,
  .ceremony-intro-copy h3,
  .ceremony-feeling h3,
  .service-copy h3,
  .journey-block h3,
  .timeline-entry h3,
  .weddings-redesign .wedding-row-copy h3,
  .weddings-redesign .wedding-personalized-features h3,
  .events-redesign .event-client-reasons-grid article h2,
  .song-card-title {
    font-size: clamp(28px, 8.4vw, 36px);
    line-height: 1.05;
  }
}

main .meet-label,
main .small-label,
main .script-note,
main .about-eyebrow,
main .wedding-eyebrow,
main .events-redesign .event-eyebrow,
main .events-redesign .event-premium-label,
main .song-eyebrow,
main .song-card-kicker {
  color: #8f98ac;
  font-size: 11px;
  font-weight: 400;
  letter-spacing: .26em;
  line-height: 1.5;
}

main .button,
main .wedding-button,
main .events-redesign .event-button,
main .song-button,
main .form-submit,
main .about-filled-button,
main .artist-copy .learn-more {
  font-size: 11px;
  font-weight: 400;
  letter-spacing: .2em;
  line-height: 1;
}

@media (max-width: 640px) {
  .why-adam-intro h2,
  .ceremony-intro-headline h2,
  .service-panel > h2,
  .about-hero-copy h1,
  .about-journey-heading h2,
  .about-timeline-heading h2,
  .about-closing-reflection h2,
  .about-closing-invitation h2,
  .weddings-redesign .wedding-hero-copy h1,
  .weddings-redesign .wedding-section-intro h2,
  .weddings-redesign .wedding-personalized-heading h2,
  .weddings-redesign .wedding-final-copy h2,
  .events-redesign .event-hero h1,
  .events-redesign .event-about-adam-copy h2,
  .events-redesign .event-listening-guide h2,
  .events-redesign .event-final-copy h2,
  .song-featured-editorial-title,
  .song-overview-intro h1,
  .song-hero h1,
  .contact-script-title {
    font-size: clamp(38px, 11.5vw, 48px);
    line-height: .98;
  }

  .why-adam-list h3,
  .ceremony-intro-copy h3,
  .ceremony-feeling h3,
  .service-copy h3,
  .journey-block h3,
  .timeline-entry h3,
  .weddings-redesign .wedding-row-copy h3,
  .weddings-redesign .wedding-personalized-features h3,
  .events-redesign .event-client-reasons-grid article h2,
  .song-card-title {
    font-size: clamp(28px, 8.4vw, 36px);
    line-height: 1.05;
  }
}

}

@media (max-width: 900px) {
.event-discovery-top {
    gap: 48px;
  }
.event-about-adam {
    grid-template-columns: 1fr 1fr;
    gap: 48px;
  }
}

@media (max-width: 640px) {
.event-premium-section {
    padding: 72px 0;
  }
.event-premium-label {
    font-size: 11px;
    letter-spacing: .27em;
  }
.event-client-reasons > .event-premium-label {
    margin-bottom: 38px;
    text-align: left;
  }
.event-client-reasons-grid article {
    grid-template-columns: 32px minmax(0, 1fr);
    gap: 14px;
    padding: 20px 0;
  }
.event-client-reasons-grid span {
    margin: 4px 0 0;
  }
.event-client-reasons-grid h2,
.event-about-adam h2 {
    font-size: 40px;
  }
.event-client-reasons-grid p {
    max-width: none;
    margin-top: 10px;
  }
.event-premium-heading {
    grid-template-columns: 1fr;
    gap: 20px;
    margin-bottom: 30px;
  }
.event-discovery-top {
    grid-template-columns: 1fr;
    gap: 72px;
  }
.event-featured-listening-inner {
    display: block;
    height: 440px;
  }
.event-listening-intro {
    margin-bottom: 28px;
  }
.event-listening-guide {
    margin-top: 28px;
    padding-top: 24px;
  }
.event-featured-cover {
    top: 10px;
    left: 10px;
    width: 112px;
    height: 112px;
    padding: 5px;
    font-size: 18px;
  }
.event-featured-cover span {
    width: 80px;
    height: 80px;
    padding: 9px;
  }
.event-featured-cover::after {
    top: 82px;
    left: 108px;
    width: 180px;
  }
.event-featured-overlay {
    top: 14px;
    right: 14px;
    left: 132px;
    width: auto;
    min-height: 88px;
  }
.event-video-showcase {
    margin-top: 0;
  }
.event-featured-listening {
    padding: 0;
  }
.event-featured-listening .event-premium-heading {
    margin-bottom: 30px;
  }
.event-video-overlay {
    padding: 24px;
  }
.event-video-frame {
    height: auto;
    aspect-ratio: 16 / 9;
  }
.event-video-overlay > p:not(.event-premium-label) {
    margin-top: 12px;
  }
.event-spotify-player {
    height: 352px;
  }
.event-about-adam {
    grid-template-columns: 1fr;
    gap: 42px;
    padding-top: 72px;
    padding-bottom: 0;
  }
.event-about-adam-copy h2 {
    margin-bottom: 28px;
  }
.event-about-adam-copy > p:not(.event-premium-label) + p {
    margin-top: 16px;
  }
.event-about-adam-portrait {
    aspect-ratio: 4 / 5;
  }
.event-contact-cta {
    width: 100%;
    min-height: 520px;
    padding: 78px 24px 88px;
    background-position: center;
  }
.event-contact-cta .event-premium-label {
    font-size: clamp(38px, 11.5vw, 48px);
  }
.event-contact-cta > p:not(.event-premium-label) {
    margin-top: 26px;
  }
.event-contact-cta .event-button {
    width: 100%;
    margin-top: 30px;
  }
}
/* Wedding editorial refinements. */
.weddings-redesign .wedding-hero-placeholder::after {
  background:
    linear-gradient(90deg, rgba(246, 243, 237, .84) 0%, rgba(246, 243, 237, .62) 36%, rgba(246, 243, 237, .10) 74%),
    radial-gradient(circle at 67% 47%, rgba(51, 51, 51, .08), rgba(51, 51, 51, 0) 28%),
    linear-gradient(0deg, rgba(51, 51, 51, .08), rgba(51, 51, 51, .02));
}
.weddings-redesign .wedding-why {
  padding-top: 128px;
  padding-bottom: 128px;
}
.weddings-redesign .wedding-experience-row + .wedding-experience-row {
  padding-top: 0;
  border-top: 0;
}
.weddings-redesign .wedding-experience-row,
.weddings-redesign .wedding-experience-row:last-child,
.weddings-redesign .wedding-personalized-centered {
  border-top: 0;
  border-bottom: 0;
}
.weddings-redesign .wedding-eyebrow {
  color: #8f98ac;
}
.weddings-redesign .wedding-hero-copy h1,
.weddings-redesign .wedding-section-intro h2,
.weddings-redesign .wedding-personalized-heading h2,
.weddings-redesign .wedding-final-copy h2 {
  color: #8f98ac;
  opacity: 1;
}
.weddings-redesign .wedding-button-outline {
  color: #8e9bb6;
  border: 1px solid #a5b1c8;
  letter-spacing: .12em;
  transition: all .25s ease;
}
.weddings-redesign .wedding-button-outline:hover {
  color: #ffffff;
  background: #8e9bb6;
  border-color: #8e9bb6;
}
.weddings-redesign .wedding-text-link {
  color: #8e9bb6;
  letter-spacing: .12em;
  transition: all .25s ease;
}
.weddings-redesign .wedding-personalized-centered {
  position: relative;
  isolation: isolate;
  padding-top: 0;
  padding-bottom: 128px;
}
.weddings-redesign .wedding-personalized-centered::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  z-index: -1;
  width: 100vw;
  background: #f8f8f8;
  transform: translateX(-50%);
}

@media (min-width: 901px) {
.weddings-redesign .wedding-experience {
    position: relative;
    isolation: isolate;
  }
.weddings-redesign .wedding-experience::before {
    content: "";
    position: absolute;
    inset: 0 50% 0 auto;
    z-index: -1;
    width: 100vw;
    background: #f8f8f8;
    transform: translateX(50%);
  }
.weddings-redesign .wedding-personalized-centered {
    padding-top: 89px;
  }
.weddings-redesign .wedding-personalized-centered::before {
    display: none;
  }
.weddings-redesign .wedding-experience-row,
.weddings-redesign .wedding-experience > .wedding-experience-row:first-of-type {
    padding-top: 0;
    padding-bottom: 0;
  }
.weddings-redesign .wedding-row-reverse .wedding-row-placeholder {
    transform: translateX(3px);
  }
}
/* Events outline button color alignment. */
.events-redesign .event-hero .event-button {
  color: #aab3c8;
}
.events-redesign .event-contact-cta .event-button {
  color: #aab3c8;
}
.events-redesign .event-contact-cta .event-button {
  border-color: #aab3c8;
}
.events-redesign .event-client-reasons-grid article h2 {
  font-size: clamp(22px, 1.75vw, 24px);
  line-height: 1.2;
}
.events-redesign .event-client-reasons-grid span {
  color: #aab3c8;
  opacity: .5;
}
/* Match supporting editorial titles and numbers to the shared reference styles. */
.events-redesign .event-listening-guide h2,
.journey-block h3,
.timeline-entry h3,
.why-adam-list h3 {
  font-size: clamp(22px, 1.75vw, 24px);
  line-height: 1.2;
}
.journey-number,
.why-adam-list span {
  color: #aab3c8;
  opacity: .5;
}
.events-redesign .event-listening-guide h2 {
  font-size: clamp(22px, 1.75vw, 24px) !important;
  line-height: 1.2 !important;
}
.weddings-redesign .wedding-personalized-centered .wedding-personalized-column {
  max-width: 820px;
  margin: 0 auto;
  text-align: center;
}
.weddings-redesign .wedding-why-split {
  display: grid;
  grid-template-columns: minmax(0, .76fr) minmax(0, 1.24fr);
  gap: clamp(70px, 8vw, 128px);
  align-items: center;
  padding-top: 0;
  padding-bottom: 128px;
}
.weddings-redesign .wedding-personalized-heading h2,
.weddings-redesign .wedding-why-heading h2 {
  margin: 0;
  color: var(--wedding-accent);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(32px, 3.33vw, 50px);
  font-weight: 400;
  letter-spacing: -.02em;
  line-height: .92;
}
.weddings-redesign .wedding-personalized-copy {
  max-width: 720px;
  margin-top: 52px;
  margin-right: auto;
  margin-left: auto;
}
.weddings-redesign .wedding-personalized-copy p,
.weddings-redesign .wedding-why-list p {
  margin: 0;
  color: var(--wedding-text);
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 22.22px;
}
.weddings-redesign .wedding-personalized-copy p + p {
  margin-top: 24px;
}
.weddings-redesign .wedding-personalized-copy .wedding-button {
  margin-top: 38px;
  margin-right: auto;
  margin-left: auto;
}
.weddings-redesign .wedding-personalized-centered {
  padding-top: 0;
  padding-bottom: 74px;
}
.weddings-redesign .wedding-personalized-copy {
  margin-top: 28px;
}
.weddings-redesign .wedding-personalized-copy p + p {
  margin-top: 14px;
}
.weddings-redesign .wedding-personalized-copy .wedding-button {
  margin-top: 28px;
}
.weddings-redesign .wedding-personalized-features {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(32px, 5vw, 72px);
  margin-top: 18px;
  text-align: left;
}
.weddings-redesign .wedding-personalized-features article {
  position: relative;
  min-height: 174px;
  padding: 52px 0 0 22px;
  border-top: 0;
}
.weddings-redesign .wedding-personalized-features span {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0;
  color: rgba(183, 191, 209, .5);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(80px, 7vw, 100px);
  font-weight: 400;
  letter-spacing: -.06em;
  line-height: .78;
  pointer-events: none;
}
.weddings-redesign .wedding-personalized-features h3 {
  position: relative;
  z-index: 1;
  margin: 0 0 12px;
  color: var(--wedding-text);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(32px, 2.65vw, 36px);
  font-weight: 400;
  letter-spacing: -.015em;
  line-height: 1;
}
.weddings-redesign .wedding-personalized-features p {
  position: relative;
  z-index: 1;
  margin: 0;
  color: var(--wedding-text);
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: clamp(16px, 1.2vw, 17px);
  font-weight: 300;
  line-height: 1.85;
}
.weddings-redesign .wedding-personalized-button {
  display: flex;
  width: max-content;
  margin: 38px auto 0;
}
.weddings-redesign .wedding-why-heading {
  position: sticky;
  top: 118px;
}
.weddings-redesign .wedding-why-list {
  border-top: 0;
}
.weddings-redesign .wedding-why-list article {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 20px;
  padding: 15px 0 16px;
  border-bottom: 0;
}
.weddings-redesign .wedding-why-list span {
  color: var(--wedding-accent);
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 10px;
  font-weight: 400;
  letter-spacing: .18em;
  line-height: 1.6;
}
.weddings-redesign .wedding-why-list h3 {
  margin: 0 0 18px;
  color: var(--wedding-text);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(26px, 2.4vw, 34px);
  font-weight: 400;
  letter-spacing: -.015em;
  line-height: 1;
}
.weddings-redesign .wedding-why-list p + p {
  margin-top: 12px;
}
/* Keep the homepage's primary editorial headings consistent with The Difference. */
.ceremony-intro-headline h2,
.ceremony-feeling h3,
.service-panel > h2 {
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(32px, 3.33vw, 50px);
  font-weight: 400;
  letter-spacing: -.02em;
  line-height: .92;
}
.weddings-redesign .wedding-why-grid {
  grid-template-columns: 1fr;
  gap: 0;
  border-top: 1px solid rgba(170, 179, 200, .24);
}
/* Shared primary heading system,
based on the homepage's The Difference title. */
.page-hero h1,
.contact-script-title,
.about-hero-copy h1,
.about-journey-heading h2,
.about-timeline-heading h2,
.about-centered-heading h2,
.about-philosophy h2,
.about-beyond-copy h2,
.about-cta h2,
.about-closing-reflection h2,
.about-closing-invitation h2,
.weddings-redesign .wedding-hero-copy h1,
.weddings-redesign .wedding-section-intro h2,
.weddings-redesign .wedding-statement-grid h2,
.weddings-redesign .wedding-why h2,
.weddings-redesign .wedding-final-copy h2,
.events-redesign .event-hero h1,
.events-redesign .event-difference h2,
.events-redesign .event-centered-heading h2,
.events-redesign .event-listening-guide h2,
.events-redesign .event-about-adam-copy h2,
.events-redesign .event-final-copy h2,
.song-overview-intro h1,
.song-hero h1,
.song-custom h2,
.song-collection-detail h2,
.song-collection-page-title,
.song-collection-copy h2,
.song-collection-custom h2 {
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(32px, 3.33vw, 50px);
  font-weight: 400;
  letter-spacing: -.02em;
  line-height: .92;
}
.weddings-redesign .wedding-why-grid article {
  display: grid;
  grid-template-columns: minmax(86px, .22fr) minmax(0, 1fr);
  gap: clamp(30px, 5vw, 76px);
  align-items: start;
  padding: 58px 0 62px;
  border-top: 0;
  border-bottom: 1px solid rgba(170, 179, 200, .24);
}
.weddings-redesign .wedding-why-grid span {
  margin: 0;
  color: rgba(170, 179, 200, .24);
  font-size: clamp(72px, 8vw, 116px);
  letter-spacing: -.06em;
  line-height: .75;
}
.weddings-redesign .wedding-why-grid h3 {
  max-width: 760px;
  font-size: clamp(46px, 5.4vw, 76px);
  line-height: .95;
}
.weddings-redesign .wedding-why-grid p {
  max-width: 680px;
  margin: 24px 0 0;
  font-size: 12.35px;
  font-weight: 400;
  line-height: 22.22px;
}
.weddings-redesign .wedding-why-grid p + p {
  margin-top: 14px;
}

@media (max-width: 980px) {
.weddings-redesign .wedding-why {
    padding-top: 110px;
    padding-bottom: 110px;
  }
.weddings-redesign .wedding-personalized-centered,
.weddings-redesign .wedding-why-split {
    padding-top: 110px;
    padding-bottom: 110px;
  }
.weddings-redesign .wedding-personalized-centered {
    padding-top: 72px;
    padding-bottom: 76px;
  }
.weddings-redesign .wedding-personalized-features {
    grid-template-columns: 1fr;
    gap: 30px;
    margin-top: 32px;
  }
.weddings-redesign .wedding-why-split {
    grid-template-columns: 1fr;
    gap: 100px;
  }
.weddings-redesign .wedding-why-heading {
    position: static;
  }
}

@media (max-width: 640px) {
.weddings-redesign .wedding-why {
    padding-top: 72px;
    padding-bottom: 72px;
  }
.weddings-redesign .wedding-why-grid article {
    grid-template-columns: 1fr;
    gap: 18px;
    padding: 40px 0 44px;
  }
.weddings-redesign .wedding-why-grid span {
    font-size: 72px;
  }
.weddings-redesign .wedding-why-grid h3 {
    font-size: clamp(38px, 11.5vw, 48px);
  }
.weddings-redesign .wedding-personalized-centered,
.weddings-redesign .wedding-why-split {
    padding-top: 72px;
    padding-bottom: 72px;
  }
.weddings-redesign .wedding-personalized-centered {
    padding-top: 58px;
    padding-bottom: 62px;
  }
.weddings-redesign .wedding-personalized-features {
    gap: 26px;
    margin-top: 28px;
  }
.weddings-redesign .wedding-personalized-features article {
    min-height: 0;
    padding-top: 50px;
  }
.weddings-redesign .wedding-personalized-button {
    margin-top: 34px;
  }
.weddings-redesign .wedding-why-split {
    gap: 72px;
  }
.weddings-redesign .wedding-personalized-heading h2,
.weddings-redesign .wedding-why-heading h2 {
    font-size: clamp(38px, 11.5vw, 48px);
    line-height: .98;
  }
.weddings-redesign .wedding-personalized-copy {
    margin-top: 36px;
  }
.weddings-redesign .wedding-why-list article {
    grid-template-columns: 28px minmax(0, 1fr);
    gap: 14px;
    padding: 13px 0 14px;
  }
.page-hero h1,
.contact-script-title,
.about-hero-copy h1,
.about-journey-heading h2,
.about-timeline-heading h2,
.about-centered-heading h2,
.about-philosophy h2,
.about-beyond-copy h2,
.about-cta h2,
.about-closing-reflection h2,
.about-closing-invitation h2,
.weddings-redesign .wedding-hero-copy h1,
.weddings-redesign .wedding-section-intro h2,
.weddings-redesign .wedding-statement-grid h2,
.weddings-redesign .wedding-why h2,
.weddings-redesign .wedding-final-copy h2,
.events-redesign .event-hero h1,
.events-redesign .event-difference h2,
.events-redesign .event-centered-heading h2,
.events-redesign .event-listening-guide h2,
.events-redesign .event-about-adam-copy h2,
.events-redesign .event-final-copy h2,
.song-overview-intro h1,
.song-hero h1,
.song-custom h2,
.song-collection-detail h2,
.song-collection-page-title,
.song-collection-copy h2,
.song-collection-custom h2 {
    font-size: clamp(38px, 11.5vw, 48px);
    line-height: .98;
  }
}
/* Final shared deep warm-gray eyebrow and section-label color. */
main .meet-label,
main .small-label,
main .script-note,
main .about-eyebrow,
main .wedding-eyebrow,
main .event-eyebrow,
main .event-premium-label,
main .song-eyebrow,
main .song-card-kicker {
  color: #333333 !important;
}

@media (min-width: 901px) {
.weddings-redesign .wedding-personalized-centered {
    padding-top: 89px;
  }
}
/* Final Wedding Experience block alignment. */
@media (min-width: 901px) {
  .weddings-redesign .wedding-experience {
    padding-top: 88px;
  }

  .weddings-redesign .wedding-experience::before {
    display: none;
  }

  .weddings-redesign .wedding-experience .wedding-section-intro {
    margin-bottom: 88px;
  }

  .weddings-redesign .wedding-experience-row {
    position: relative;
    isolation: isolate;
  }

  .weddings-redesign .wedding-experience-row::before {
    content: "";
    position: absolute;
    inset: 0 50% 0 auto;
    z-index: -1;
    display: block;
    width: 100vw;
    background: #f8f8f8;
    transform: translateX(50%);
  }
}
/* Final shared supporting-title and solid-button states. */
.weddings-redesign .wedding-personalized-features h3 {
  font-size: clamp(22px, 1.75vw, 24px) !important;
  line-height: 1.2 !important;
}
a.primary-button,
button.primary-button {
  color: #333333 !important;
  background: #c7d1e3 !important;
  border-color: #c7d1e3 !important;
}
a.primary-button:hover,
a.primary-button:focus-visible,
button.primary-button:hover,
button.primary-button:focus-visible {
  color: #ffffff !important;
  background: #8f98ac !important;
  border-color: #8f98ac !important;
}
.weddings-redesign .wedding-personalized-features p {
  font-size: clamp(13px, 1vw, 15px) !important;
  font-weight: 400 !important;
  line-height: 1.75 !important;
}

@media (min-width: 901px) {
.events-redesign .event-client-reasons > .event-premium-label {
    margin-bottom: 16px;
  }
.events-redesign .event-featured-listening-inner {
    height: 270px;
  }
.events-redesign .event-listening-guide .event-listening-button {
    margin-top: 5.1px;
  }
}
/* Contact editorial split introduction. */
.contact-page {
  width: min(1180px, calc(100% - 84px));
}
.contact-intro {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, .8fr);
  gap: clamp(48px, 6vw, 92px);
  align-items: center;
}
.contact-script-mark {
  display: flex;
  align-items: center;
  min-height: 360px;
}
.contact-script-mark img {
  display: block;
  width: 170%;
  max-width: none;
  height: auto;
  transform: translateX(-4%);
}
.contact-copy {
  max-width: 460px;
  margin: 0;
}
.contact-copy p {
  color: #333333;
  font-size: clamp(13px, 1vw, 15px);
  font-weight: 400;
  line-height: 1.75;
}
.event-question {
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(22px, 1.75vw, 24px);
  font-weight: 400;
  line-height: 1.2;
}
.contact-page .event-selection {
  margin-top: 64px;
}
.event-choice-grid {
  gap: 18px;
}
.event-tab,
.event-tab:first-child,
.event-tab:last-child {
  width: auto;
  min-width: 220px;
  min-height: 52px;
  padding: 0 40px;
  border: 1px solid #c7d1e3;
  font-size: 13px;
  font-weight: 400;
  letter-spacing: .22em;
}
.event-tab.is-active {
  color: #ffffff !important;
  background: #8f98ac !important;
  border-color: #8f98ac !important;
}

@media (max-width: 900px) {
.contact-page {
    width: min(906px, calc(100% - 42px));
  }
.contact-intro {
    grid-template-columns: 1fr;
    gap: 48px;
  }
.contact-script-mark {
    min-height: 0;
  }
.contact-script-mark img {
    width: min(620px, 100%);
    max-width: 100%;
    margin: 0 auto;
    transform: none;
  }
.contact-copy {
    max-width: 680px;
    margin: 0 auto;
  }
}

@media (max-width: 640px) {
.contact-intro {
    gap: 34px;
  }
.event-tab,
.event-tab:first-child,
.event-tab:last-child {
    width: 100%;
    min-width: 0;
  }
}
/* Contact layout follows the reference's restrained two-column rhythm. */
.contact-page {
  width: min(1160px, calc(100% - 84px));
  padding-top: 52px;
  padding-bottom: 92px;
}
.contact-intro {
  grid-template-columns: minmax(0, .82fr) minmax(0, 1.18fr);
  gap: clamp(72px, 9vw, 140px);
  align-items: start;
}
.contact-script-mark {
  align-items: flex-start;
  min-height: 0;
}
.contact-script-mark img {
  width: 112%;
  max-width: none;
  transform: translate(-5%, -4%);
}
.contact-copy {
  max-width: 620px;
}
.contact-copy p {
  margin-bottom: 22px;
}
.contact-page .event-selection {
  margin-top: 48px;
}
.event-question {
  margin-bottom: 20px;
}
.event-choice-grid {
  gap: 42px;
}

@media (max-width: 900px) {
.contact-page {
    padding-top: 64px;
  }
.contact-script-mark img {
    width: min(620px, 100%);
    transform: none;
  }
}

@media (min-width: 901px) {
.contact-page {
    padding-top: 78px;
  }
.contact-intro {
    align-items: center;
  }
.contact-script-mark {
    align-items: center;
  }
.contact-script-mark img {
    flex: none;
    width: 80%;
    margin-left: 50%;
    transform: translateX(-50%);
  }
}
/* FAQ filled calls to action match the shared solid-button system. */
.faq-editorial .faq-contact-button,
.faq-editorial .faq-song-button,
.faq-redesign .faq-contact-button,
.faq-redesign .faq-song-button,
.faq-contact-button,
.faq-song-button {
  min-height: 52px !important;
  height: 52px !important;
  padding-right: 40px !important;
  padding-left: 40px !important;
  color: #333333 !important;
  background: #c7d1e3 !important;
  border: 1px solid #c7d1e3 !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  letter-spacing: .22em !important;
  white-space: nowrap;
  transition: color .3s ease, background-color .3s ease, border-color .3s ease !important;
}
.faq-editorial .faq-contact-button:hover,
.faq-editorial .faq-contact-button:focus-visible,
.faq-editorial .faq-song-button:hover,
.faq-editorial .faq-song-button:focus-visible,
.faq-redesign .faq-contact-button:hover,
.faq-redesign .faq-contact-button:focus-visible,
.faq-redesign .faq-song-button:hover,
.faq-redesign .faq-song-button:focus-visible,
.faq-contact-button:hover,
.faq-contact-button:focus-visible,
.faq-song-button:hover,
.faq-song-button:focus-visible {
  color: #ffffff !important;
  background: #8f98ac !important;
  border-color: #8f98ac !important;
}
/* Home sections follow the About page's single-sided 128px rhythm. */
@media (min-width: 901px) {
  .home-hero + .artist-introduction,
  .home-hero + .moses-style-artist,
  .why-adam,
  .home-wedding-preview {
    padding-top: 128px !important;
  }

  .artist-introduction,
  .moses-style-artist,
  .why-adam,
  .home-wedding-preview {
    padding-bottom: 0 !important;
  }

  .home-wedding-preview .service-tabs {
    margin-bottom: 22px;
  }

  .home-final-cta {
    margin-top: 22.2px !important;
  }
}
/* Events value-point lead sentences sit one subtle step above body copy. */
.events-redesign .event-client-reasons-grid article p:first-of-type {
  font-size: clamp(15px, 1.1vw, 17px);
  line-height: 1.7;
}

@media (min-width: 901px) {
.events-redesign .event-client-reasons-grid article span,
.events-redesign .event-client-reasons-grid article h2 {
    align-self: center;
  }
.events-redesign .event-client-reasons-grid article p:first-of-type {
    margin-top: -8px;
  }
.events-redesign .event-listening-guide .event-listening-button {
    margin-top: 20px;
  }
.events-redesign .event-client-reasons-grid article {
    padding-top: 0;
  }
}
/* Mobile-only refinement pass. Desktop presentation remains unchanged. */
@media (max-width: 640px) {
  /* Shared readability and touch targets */
  body {
    font-size: 14px;
  }

  .nav-toggle {
    width: 44px;
    height: 44px;
    flex-basis: 44px;
  }

  .site-header .wordmark,
  .footer-brand,
  .footer-email {
    min-height: 44px;
    display: inline-flex;
    align-items: center;
  }

  .footer-email {
    padding: 12px 0;
  }

  .artist-body p,
  .why-adam-intro p:not(.small-label),
  .why-adam-list p,
  .ceremony-intro-copy p,
  .ceremony-feeling p,
  .service-copy p,
  .about-hero-copy p:not(.about-eyebrow),
  .journey-block p,
  .about-timeline p,
  .about-closing-copy p,
  .weddings-redesign .wedding-hero-copy > p:not(.wedding-eyebrow),
  .weddings-redesign .wedding-section-intro > p:not(.wedding-eyebrow),
  .weddings-redesign .wedding-row-copy p:not(.wedding-eyebrow),
  .weddings-redesign .wedding-personalized-copy p,
  .weddings-redesign .wedding-personalized-features p,
  .weddings-redesign .wedding-final-copy p,
  .events-redesign .event-hero-copy > p:not(.event-eyebrow),
  .events-redesign .event-about-adam-copy p,
  .events-redesign .event-listening-intro > p:not(.event-premium-label),
  .events-redesign .event-listening-guide p,
  .events-redesign .event-client-reasons-grid p,
  .events-redesign .event-contact-cta p:not(.event-premium-label),
  .song-featured-editorial-copy,
  .song-card-description,
  .contact-copy p {
    font-size: 14px !important;
    line-height: 1.75 !important;
  }

  .song-collection-player-controls button,
  .song-collection-player-controls .song-collection-main-play {
    width: 44px;
    height: 44px;
    min-width: 44px;
    min-height: 44px;
  }

  .event-corporate-player .song-inline-player {
    grid-template-columns: 44px minmax(70px, 1fr) 34px;
  }

  .event-corporate-player .song-inline-play {
    width: 44px;
    height: 44px;
  }

  .event-corporate-player.song-collection-page .song-detail-song {
    min-height: 52px;
  }

  /* Contact: stack the editorial introduction and restore full-width reading. */
  .contact-page {
    width: min(100% - 48px, 680px);
    padding-top: 50px;
    padding-bottom: 72px;
  }

  .contact-intro {
    display: grid;
    grid-template-columns: 1fr;
    gap: 34px;
  }

  .contact-script-mark {
    justify-content: center;
    width: 100%;
  }

  .contact-script-mark img {
    width: min(300px, 88%);
    max-width: 100%;
    margin: 0 auto;
    transform: none;
  }

  .contact-copy {
    width: 100%;
    max-width: none;
    margin: 0;
  }

  .contact-copy p {
    margin-bottom: 18px;
  }

  .contact-page .event-selection {
    margin-top: 42px;
  }

  /* Events: retain the portrait while giving mobile hero copy a calm dark veil. */
  .events-redesign .event-hero-placeholder::after {
    background:
      linear-gradient(180deg, rgba(18, 18, 18, .18), rgba(18, 18, 18, .36)),
      linear-gradient(90deg, rgba(18, 18, 18, .28), rgba(18, 18, 18, .08));
  }

  .events-redesign .event-hero .event-eyebrow,
  .events-redesign .event-hero h1,
  .events-redesign .event-hero-copy > p:not(.event-eyebrow) {
    color: rgba(255, 255, 255, .94) !important;
    text-shadow: 0 2px 12px rgba(0, 0, 0, .72);
  }

  .events-redesign .event-hero .event-button {
    color: #ffffff;
    border-color: rgba(255, 255, 255, .82);
    background: rgba(20, 20, 20, .12);
    text-shadow: 0 1px 8px rgba(0, 0, 0, .6);
  }

  /* About: reduce headline dominance and improve long-form rhythm. */
  .about-hero-redesign {
    gap: 22px;
    padding-top: 30px;
    padding-bottom: 0;
  }

  .about-hero-placeholder {
    aspect-ratio: 1 / 1;
  }

  .about-hero-copy h1 {
    font-size: clamp(38px, 10.5vw, 42px);
    line-height: 1;
  }

  .about-hero-copy p:not(.about-eyebrow) {
    margin-top: 20px;
  }

  .about-hero-copy p:not(.about-eyebrow) + p:not(.about-eyebrow) {
    margin-top: 16px;
  }

  .about-journey,
  .about-timeline-section {
    padding-top: 48px;
  }

  .about-closing {
    padding-top: 48px;
    padding-bottom: 58px;
  }

  .journey-number {
    left: -4px;
    font-size: 96px;
    opacity: .62;
  }

  .journey-block + .journey-block {
    margin-top: 24px;
  }

  /* Home: preserve the image-led pacing while removing avoidable mobile height. */
  .artist-introduction,
  .moses-style-artist {
    gap: 22px;
    padding-top: 46px;
    padding-bottom: 42px;
  }

  .why-adam {
    padding-top: 46px;
    padding-bottom: 46px;
  }

  .why-adam-main {
    gap: 20px;
  }

  .why-adam-list article {
    padding-top: 16px;
    padding-bottom: 18px;
  }

  .home-wedding-preview {
    padding-bottom: 38px;
  }

  .ceremony-panel.is-active {
    padding-top: 0;
  }

  .ceremony-intro-row {
    gap: 20px;
    min-height: 0;
    margin-bottom: 32px;
  }

  .ceremony-intro-copy h3 {
    margin-bottom: 16px;
  }

  .ceremony-music-row {
    gap: 20px;
  }

  /* Weddings: modest contrast and tighter editorial pacing. */
  .weddings-redesign .wedding-hero-placeholder::after {
    background:
      linear-gradient(180deg, rgba(246, 243, 237, .12), rgba(246, 243, 237, .46)),
      linear-gradient(90deg, rgba(246, 243, 237, .62), rgba(246, 243, 237, .12));
  }

  .weddings-redesign .wedding-hero-copy h1 {
    color: #7f8ba3;
    text-shadow: 0 1px 12px rgba(246, 243, 237, .45);
  }

  .weddings-redesign .wedding-experience {
    padding-top: 50px;
    padding-bottom: 50px;
  }

  .weddings-redesign .wedding-experience-row {
    gap: 20px;
    padding-top: 32px;
    padding-bottom: 32px;
  }

  .weddings-redesign .wedding-personalized-centered {
    padding-top: 42px;
    padding-bottom: 44px;
  }

  .weddings-redesign .wedding-personalized-features {
    gap: 20px;
    margin-top: 22px;
  }

  .weddings-redesign .wedding-personalized-features article {
    padding-top: 30px;
  }

  /* Events content pacing */
  .events-redesign .event-premium-section {
    padding-top: 50px;
    padding-bottom: 50px;
  }

  .events-redesign .event-about-adam {
    gap: 28px;
    padding-top: 50px;
  }

  .events-redesign .event-discovery-top {
    gap: 44px;
  }

  .events-redesign .event-client-reasons > .event-premium-label {
    margin-bottom: 24px;
  }

  .events-redesign .event-client-reasons-grid article {
    padding-top: 16px;
    padding-bottom: 18px;
  }

  /* Song List: preserve two columns while improving small-card legibility. */
  .song-list-redesign .song-collection-grid {
    gap: 30px 18px;
  }

  .song-list-redesign .song-collection-grid .song-cover::after {
    opacity: .9;
  }

  .song-list-redesign .song-collection-grid .song-cover-brand {
    right: 12px;
    bottom: 14px;
    left: 12px;
    font-size: 11px;
    line-height: 1.25;
    text-shadow: 0 1px 8px rgba(0, 0, 0, .35);
  }

  .song-list-redesign .song-collection-grid .song-card-title {
    margin-top: 10px;
    font-size: 13px;
    line-height: 1.35;
  }

  /* Reference-informed mobile heading rhythm: fewer awkward line breaks. */
  .why-adam-intro h2,
  .about-journey-heading h2,
  .about-timeline-heading h2,
  .about-centered-heading h2,
  .about-closing-reflection h2,
  .about-closing-invitation h2,
  .weddings-redesign .wedding-hero-copy h1,
  .weddings-redesign .wedding-section-intro h2,
  .weddings-redesign .wedding-personalized-heading h2,
  .weddings-redesign .wedding-final-copy h2,
  .events-redesign .event-hero h1,
  .events-redesign .event-about-adam-copy h2,
  .events-redesign .event-contact-cta .event-premium-label {
    font-size: clamp(37px, 10.7vw, 42px);
    line-height: 1;
  }

  .about-journey-heading,
  .about-timeline-heading,
  .wedding-section-intro {
    margin-bottom: 28px;
  }

  .events-redesign .event-client-reasons-grid p {
    margin-top: 7px;
  }
}
/* Mobile scale system informed by the restrained proportions of the UX reference. */
@media (max-width: 640px) {
  .site-header {
    position: relative;
    justify-content: center;
    min-height: 104px;
    padding: 18px 24px;
  }

  .wordmark {
    display: flex;
    flex-direction: column;
    align-items: center;
    max-width: none;
    color: #20252b;
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: 17px;
    font-weight: 500;
    letter-spacing: .26em;
    line-height: 1.05;
    text-align: center;
    text-transform: uppercase;
  }

  .wordmark span:last-child {
    margin-top: 5px;
    font-size: 9px;
    letter-spacing: .34em;
  }

  .nav-toggle {
    position: absolute;
    right: 24px;
  }

  .home-hero {
    min-height: 0;
    height: 78.8vw;
  }

  .hero-video {
    object-position: 51% 53%;
  }

  .home-hero + .artist-introduction,
  .home-hero + .moses-style-artist {
    padding-top: 38px;
  }

  .artist-introduction,
  .moses-style-artist {
    display: flex;
    flex-direction: column;
    gap: 0;
  }

  .mobile-artist-heading {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    width: 100%;
    margin-bottom: 8px;
  }

  .mobile-artist-heading .meet-label {
    margin-top: 25px;
  }

  .mobile-artist-heading .pianist-signature {
    width: 170px;
    margin-left: -16px;
  }

  .artist-image {
    width: min(100%, 330px);
    order: 2;
  }

  .mobile-artist-image-label {
    position: absolute;
    top: 16px;
    left: 16px;
    z-index: 2;
    display: flex;
    flex-direction: column;
    color: #ffffff;
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: 21px;
    font-weight: 500;
    letter-spacing: .15em;
    line-height: 1;
    text-transform: uppercase;
    text-shadow: 0 1px 8px rgba(0, 0, 0, .35);
  }

  .mobile-artist-image-label small {
    margin-top: 7px;
    font-family: Montserrat, "Avenir Next", sans-serif;
    font-size: 8px;
    font-weight: 400;
    letter-spacing: .18em;
  }

  .artist-copy {
    order: 3;
    margin-top: 26px;
  }

  .artist-copy .artist-signature-group,
  .artist-copy .artist-name,
  .artist-copy .artist-subtitle {
    display: none;
  }

  body {
    font-size: 13px;
  }

  .artist-body p,
  .why-adam-intro p:not(.small-label),
  .why-adam-list p,
  .ceremony-intro-copy p,
  .ceremony-feeling p,
  .service-copy p,
  .about-hero-copy p:not(.about-eyebrow),
  .journey-block p,
  .about-timeline p,
  .about-closing-copy p,
  .weddings-redesign .wedding-hero-copy > p:not(.wedding-eyebrow),
  .weddings-redesign .wedding-section-intro > p:not(.wedding-eyebrow),
  .weddings-redesign .wedding-row-copy p:not(.wedding-eyebrow),
  .weddings-redesign .wedding-personalized-copy p,
  .weddings-redesign .wedding-personalized-features p,
  .weddings-redesign .wedding-final-copy p,
  .events-redesign .event-hero-copy > p:not(.event-eyebrow),
  .events-redesign .event-about-adam-copy p,
  .events-redesign .event-listening-intro > p:not(.event-premium-label),
  .events-redesign .event-listening-guide p,
  .events-redesign .event-client-reasons-grid p,
  .events-redesign .event-contact-cta p:not(.event-premium-label),
  .song-featured-editorial-copy,
  .song-card-description,
  .contact-copy p {
    font-size: 13px !important;
    line-height: 1.7 !important;
  }

  main .meet-label,
  main .small-label,
  main .script-note,
  main .about-eyebrow,
  main .wedding-eyebrow,
  main .event-eyebrow,
  main .event-premium-label,
  main .song-eyebrow,
  main .song-card-kicker {
    font-size: 9.5px !important;
    letter-spacing: .2em !important;
    line-height: 1.45 !important;
  }

  .why-adam-intro h2,
  .about-hero-copy h1,
  .about-journey-heading h2,
  .about-timeline-heading h2,
  .about-centered-heading h2,
  .about-closing-reflection h2,
  .about-closing-invitation h2,
  .weddings-redesign .wedding-hero-copy h1,
  .weddings-redesign .wedding-section-intro h2,
  .weddings-redesign .wedding-personalized-heading h2,
  .weddings-redesign .wedding-final-copy h2,
  .events-redesign .event-hero h1,
  .events-redesign .event-about-adam-copy h2,
  .events-redesign .event-contact-cta .event-premium-label {
    font-size: clamp(36px, 10vw, 40px);
    line-height: 1.02;
    letter-spacing: -.02em;
  }

  .ceremony-intro-headline h2,
  .song-featured-editorial-title,
  .song-overview-intro h1,
  .song-hero h1,
  .song-collection-copy h2 {
    font-size: clamp(30px, 8.6vw, 34px);
    line-height: 1.06;
  }

  .ceremony-intro-copy h3,
  .ceremony-feeling h3,
  .service-copy h3,
  .journey-block h3,
  .timeline-entry h3,
  .weddings-redesign .wedding-row-copy h3,
  .weddings-redesign .wedding-personalized-features h3,
  .events-redesign .event-client-reasons-grid article h2,
  .events-redesign .event-listening-guide h2,
  .song-card-title {
    font-size: clamp(20px, 6vw, 24px);
    line-height: 1.12;
  }

  .button,
  .primary-button,
  .wedding-button,
  .event-button,
  .song-button,
  .form-submit,
  .about-filled-button,
  .about-outline-button,
  .artist-copy .learn-more,
  .event-tab,
  .event-tab:first-child,
  .event-tab:last-child {
    min-height: 44px !important;
    height: 44px !important;
    padding-right: 24px !important;
    padding-left: 24px !important;
    font-size: 10.5px !important;
    letter-spacing: .17em !important;
  }

  .artist-introduction,
  .moses-style-artist,
  .why-adam,
  .weddings-redesign .wedding-experience,
  .weddings-redesign .wedding-personalized-centered,
  .events-redesign .event-premium-section {
    padding-top: 48px;
    padding-bottom: 48px;
  }

  .about-journey,
  .about-timeline-section,
  .about-closing {
    padding-top: 48px;
  }

  .wedding-section-intro,
  .about-journey-heading,
  .about-timeline-heading {
    margin-bottom: 24px;
  }

  .weddings-redesign .wedding-experience-row {
    padding-top: 28px;
    padding-bottom: 28px;
  }

  .events-redesign .event-client-reasons-grid article,
  .why-adam-list article {
    padding-top: 14px;
    padding-bottom: 16px;
  }
}
/* Wedding value copy and full-width experience color block. */
.weddings-redesign .wedding-personalized-features {
  grid-template-columns: 1fr;
  gap: 0;
  max-width: 980px;
  margin: 48px auto 0;
}
.weddings-redesign .wedding-personalized-features article {
  display: grid;
  grid-template-columns: 120px minmax(0, 1fr);
  min-height: 0;
  padding: 42px 0 46px;
  border-top: 1px solid rgba(170, 179, 200, .42);
}
.weddings-redesign .wedding-personalized-features article:last-child {
  border-bottom: 1px solid rgba(170, 179, 200, .42);
}
.weddings-redesign .wedding-personalized-features span {
  grid-row: 1 / span 2;
  align-self: start;
  margin-top: 4px;
}
.weddings-redesign .wedding-personalized-features h3 {
  margin: 0 0 18px;
  font-size: clamp(30px, 2.7vw, 40px);
}
.weddings-redesign .wedding-personalized-features p {
  max-width: 800px;
  margin: 0;
  line-height: 1.9;
}
.weddings-redesign .wedding-experience-row {
  position: relative;
  isolation: isolate;
}
.weddings-redesign .wedding-experience-row::before {
  content: "";
  position: absolute;
  inset: 0 50% 0 auto;
  z-index: -1;
  width: 100vw;
  background: #f6f3ed;
  transform: translateX(50%);
}

@media (max-width: 640px) {
.weddings-redesign .wedding-personalized-features {
    margin-top: 28px;
  }
.weddings-redesign .wedding-personalized-features article {
    grid-template-columns: 48px minmax(0, 1fr);
    padding: 30px 0 34px;
  }
.weddings-redesign .wedding-personalized-features h3 {
    margin-bottom: 12px;
    font-size: 24px;
  }
}
/* Wedding personalized section: editorial two-column layout. */
.weddings-redesign .wedding-personalized-centered {
  display: grid;
  grid-template-columns: minmax(0, .82fr) minmax(0, 1.18fr);
  gap: clamp(72px, 8vw, 132px);
  align-items: start;
  padding-top: 96px;
  padding-bottom: 96px;
}
.weddings-redesign .wedding-personalized-centered .wedding-personalized-column {
  max-width: none;
  margin: 0;
  text-align: left;
}
.weddings-redesign .wedding-personalized-copy {
  max-width: 520px;
  margin: 38px 0 0;
}
.weddings-redesign .wedding-personalized-copy p + p {
  margin-top: 24px;
}
.weddings-redesign .wedding-personalized-features {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  max-width: none;
  margin: 0;
}
.weddings-redesign .wedding-personalized-features article {
  position: relative;
  display: block;
  min-height: 0;
  padding: 34px 0 38px 76px;
  border-top: 1px solid rgba(170, 179, 200, .42);
}
.weddings-redesign .wedding-personalized-features article:last-child {
  border-bottom: 1px solid rgba(170, 179, 200, .42);
}
.weddings-redesign .wedding-personalized-features span {
  position: absolute;
  top: 38px;
  left: 0;
  margin: 0;
  font-size: 22px;
  line-height: 1;
}
.weddings-redesign .wedding-personalized-features h3 {
  margin: 0 0 14px;
  font-size: clamp(30px, 2.7vw, 40px);
  line-height: 1.05;
}
.weddings-redesign .wedding-personalized-features p {
  max-width: none;
  margin: 0;
  line-height: 1.85;
}

@media (max-width: 980px) {
.weddings-redesign .wedding-personalized-centered {
    grid-template-columns: 1fr;
    gap: 48px;
    padding-top: 72px;
    padding-bottom: 76px;
  }
.weddings-redesign .wedding-personalized-copy {
    max-width: 720px;
  }
}

@media (max-width: 640px) {
.weddings-redesign .wedding-personalized-centered {
    gap: 34px;
    padding-top: 52px;
    padding-bottom: 58px;
  }
.weddings-redesign .wedding-personalized-copy {
    margin-top: 24px;
  }
.weddings-redesign .wedding-personalized-features article {
    padding: 28px 0 30px 46px;
  }
.weddings-redesign .wedding-personalized-features span {
    top: 31px;
    font-size: 18px;
  }
.weddings-redesign .wedding-personalized-features h3 {
    margin-bottom: 10px;
    font-size: 24px;
  }
}
/* Wedding value cards: narrow,
staggered editorial composition. */
.weddings-redesign .wedding-personalized-features {
  row-gap: 0;
}
.weddings-redesign .wedding-personalized-features article {
  display: grid;
  grid-template-columns: 62px 1fr;
  grid-template-rows: 76px auto;
  column-gap: 10px;
  row-gap: 0;
  width: 440px;
  padding: 0;
  background: transparent;
  border: 0;
}
.weddings-redesign .wedding-personalized-features article + article {
  margin-top: 10px;
}
.weddings-redesign .wedding-personalized-features article:nth-child(odd) {
  justify-self: start;
}
.weddings-redesign .wedding-personalized-features article:nth-child(even) {
  justify-self: end;
}
.weddings-redesign .wedding-personalized-features article:last-child {
  border: 0;
}
.weddings-redesign .wedding-personalized-features span {
  position: static;
  grid-column: 1;
  grid-row: 1;
  align-self: center;
  justify-self: end;
  color: #aab3c8;
  font-size: 54px;
  letter-spacing: -.06em;
  line-height: 1;
  opacity: .5;
}
.weddings-redesign .wedding-personalized-features h3 {
  max-width: 276px;
}
.weddings-redesign .wedding-personalized-features .wedding-feature-logo-title {
  grid-column: 2;
  grid-row: 1;
  align-self: center;
  width: 420px;
  max-width: none;
  height: 76px;
  margin: 0;
  overflow: visible;
}
.weddings-redesign .wedding-personalized-features .wedding-feature-logo-title img {
  display: block;
  width: auto;
  max-width: 100%;
  height: 76px;
  object-fit: contain;
  object-position: left center;
}
.weddings-redesign .wedding-personalized-features p {
  grid-column: 2;
  grid-row: 2;
  width: 310px;
  max-width: 310px;
  margin: 0;
}
.about-journey-heading h2 {
  color: #aab3c8;
}

@media (min-width: 981px) {
.about-editorial-redesign .about-hero-redesign {
    align-items: center;
    min-height: 0;
    padding-top: 76px;
    padding-bottom: 96px;
  }
.about-editorial-redesign .about-hero-copy {
    align-self: center;
    margin-top: 0;
  }
.about-editorial-redesign .about-timeline-section,
.about-editorial-redesign .about-closing {
    padding-top: 96px;
  }
.about-editorial-redesign .about-closing {
    padding-bottom: 96px;
  }
.events-redesign .event-about-adam {
    padding-top: 96px;
  }
.events-redesign .event-discovery {
    padding-top: 96px;
    padding-bottom: 96px;
  }
}

@media (max-width: 980px) {
.weddings-redesign .wedding-personalized-centered .wedding-personalized-column {
    position: static;
  }
.weddings-redesign .wedding-personalized-features article {
    width: min(100%, 440px);
  }
}
.home-wedding-preview .ceremony-feeling h3 {
  margin-bottom: 10px;
  font-family: "Bodoni Moda", "Cormorant Garamond", Didot, serif;
  font-size: 23.52px;
  font-weight: 300;
  letter-spacing: 0;
  line-height: 28.22px;
  white-space: nowrap;
}

@media (min-width: 981px) {
.weddings-redesign .wedding-personalized-centered .wedding-personalized-column {
    position: sticky;
    top: 120px;
    align-self: start;
  }
.why-adam-list {
    display: grid;
    border-top: 0;
  }
.why-adam-list article {
    grid-template-columns: 54px minmax(0, 1fr);
    column-gap: 14px;
    width: min(100%, 400px);
    padding: 0;
    border-bottom: 0;
  }
.why-adam-list article + article {
    margin-top: 29px;
  }
.why-adam-list article:nth-child(odd) {
    justify-self: start;
  }
.why-adam-list article:nth-child(even) {
    justify-self: end;
  }
.why-adam-list span {
    align-self: start;
    justify-self: end;
    padding-top: 3px;
    font-size: 34px;
    line-height: 1;
  }
.why-adam-list h3 {
    margin-bottom: 14px;
    color: var(--editorial-accent);
  }
.why-adam-list p {
    grid-column: 2;
    max-width: 320px;
    margin: 0;
  }
.why-adam,
.home-wedding-preview {
    position: relative;
    isolation: isolate;
  }
.why-adam::before,
.home-wedding-preview::before {
    position: absolute;
    left: 50%;
    z-index: -1;
    width: 100vw;
    background: #f6f3ed;
    content: "";
    transform: translateX(-50%);
  }
.why-adam::before {
    bottom: 0;
    height: calc(53px + 42.78125px);
  }
.home-wedding-preview {
    border-top: 0;
  }
.home-wedding-preview::before {
    top: 0;
    height: 75px;
  }

}

@media (max-width: 640px) {
.weddings-redesign .wedding-personalized-features {
    row-gap: 0;
  }
.weddings-redesign .wedding-personalized-features article {
    grid-template-columns: 44px 1fr;
    grid-template-rows: 62px auto;
    column-gap: 6px;
    row-gap: 0;
    width: 100%;
    padding: 0;
  }
.weddings-redesign .wedding-personalized-features span {
    font-size: 40px;
  }
.weddings-redesign .wedding-personalized-features .wedding-feature-logo-title {
    width: min(84vw, 340px);
    height: 62px;
    margin: 0;
  }
.weddings-redesign .wedding-personalized-features .wedding-feature-logo-title img {
    height: 62px;
  }
.weddings-redesign .wedding-personalized-features p {
    width: 100%;
    max-width: 310px;
  }
}
.service-carousel-controls,
.mobile-service-title-nav,
.mobile-atmosphere-trigger,
.mobile-atmosphere-title-nav,
.mobile-featured-song-name,
.mobile-submenu-toggle {
  display: none;
}

.mobile-nav-logo {
  display: none;
}
/* Mobile editorial system. Desktop presentation remains unchanged. */
@media (max-width: 640px) {
  body.nav-is-open {
    overflow: hidden;
  }

  .site-header {
    min-height: 78px;
    padding: 16px 24px;
    border-bottom-color: rgba(170, 179, 200, .22);
  }

  .wordmark {
    position: relative;
    z-index: 62;
    gap: 0;
    font-size: 16px;
    letter-spacing: .24em;
    line-height: 1.05;
  }

  .wordmark span:last-child {
    margin-top: 4px;
    font-family: Montserrat, sans-serif;
    font-size: 7px;
    letter-spacing: .42em;
  }

  .nav-toggle {
    position: relative;
    z-index: 62;
    display: block;
    width: 36px;
    height: 36px;
    flex: 0 0 36px;
    border: 0;
  }

  .nav-toggle span {
    width: 19px;
    margin: 6px auto;
    background: #333333;
    transition: transform .35s ease, opacity .25s ease;
  }

  .nav-toggle[aria-expanded="true"] span:first-child {
    transform: translateY(3.5px) rotate(45deg);
  }

  .nav-toggle[aria-expanded="true"] span:last-child {
    transform: translateY(-3.5px) rotate(-45deg);
  }

  .site-nav,
  .site-nav.is-open {
    position: fixed;
    z-index: 60;
    inset: 0;
    width: 100vw;
    height: 100dvh;
    min-height: 100dvh;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    gap: 0;
    padding: 142px 32px 48px;
    background: rgba(248, 248, 248, .985);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(-12px);
    transition: opacity .35s ease, transform .4s ease, visibility .35s ease;
  }

  .site-nav.is-open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
  }

  .site-nav::before {
    margin-bottom: 34px;
    color: #aab3c8;
    content: "ADAM GRAVELLE PIANO";
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: 13px;
    letter-spacing: .28em;
    text-align: center;
  }

  .site-nav > a {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 58px;
    padding: 0;
    border-top: 1px solid rgba(170, 179, 200, .3);
    border-bottom: 0;
    color: #333333;
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: 15px;
    font-weight: 400;
    letter-spacing: .25em;
  }

  .site-nav > a:last-child {
    border-bottom: 1px solid rgba(170, 179, 200, .3);
  }

  .site-nav .nav-dropdown {
    display: none;
  }

  .home-hero {
    height: 54vh;
    min-height: 430px;
    max-height: 560px;
  }

  .artist-introduction,
  .moses-style-artist,
  .why-adam,
  .home-wedding-preview {
    width: min(100% - 40px, 430px);
  }

  .artist-introduction,
  .moses-style-artist {
    gap: 16px;
    padding-top: 64px;
    padding-bottom: 28px;
  }

  .mobile-artist-heading {
    margin-bottom: -8px;
  }

  .artist-image {
    width: 100%;
    aspect-ratio: 4 / 5;
  }

  .artist-body {
    max-width: 31ch;
    margin: 0 auto;
    text-align: center;
  }

  .artist-copy {
    max-width: none;
    text-align: center;
    transform: none;
  }

  .artist-body p {
    margin-bottom: 24px;
    text-align: center;
  }

  .artist-copy .learn-more {
    display: inline-flex;
    width: 125px;
    min-width: 125px;
    height: 32px;
    margin-top: 28px;
    padding: 0;
    border: 0;
    background: #f2f3f5;
    color: #7f8ea2;
    font-size: 10.4px;
    font-weight: 400;
    letter-spacing: 1.04px;
    white-space: nowrap;
  }

  .artist-body p,
  .why-adam-intro p:not(.small-label),
  .why-adam-list p,
  .ceremony-intro-copy p,
  .ceremony-feeling p {
    font-size: 13px !important;
    line-height: 1.78 !important;
  }

  .why-adam {
    padding-top: 0;
    padding-bottom: 0;
  }

  .why-adam-main {
    display: block;
  }

  .why-adam-intro {
    position: static;
    width: 100vw;
    max-width: none;
    margin-left: calc(50% - 50vw);
    padding: 28px max(31px, calc((100vw - 328px) / 2));
    background: #f6f3ed;
  }

  .why-adam-intro .small-label {
    margin-bottom: 11px;
  }

  .why-adam-intro p:not(.small-label) {
    max-width: 328px;
    margin-right: 0;
    margin-bottom: 19px;
    margin-left: 0;
    font-size: 11.5px !important;
    line-height: 1.65 !important;
    letter-spacing: 0;
    text-align: left;
  }

  .why-adam-intro p:not(.small-label):last-of-type {
    margin-bottom: 0;
  }

  .why-adam-intro h2 {
    max-width: none;
    margin-bottom: 16px;
    color: #aab3c8;
    font-size: 31.2px;
    line-height: 34.32px;
    letter-spacing: -1.248px;
    white-space: nowrap;
  }

  .why-adam-intro::after {
    display: none;
    content: none;
  }

  .why-adam-list {
    display: flex;
    flex-direction: column;
    gap: 19px;
    height: auto;
    margin-top: 28px;
    border-top: 0;
    overflow: visible;
    overscroll-behavior: auto;
    scroll-snap-type: none;
  }

  .why-adam-list article,
  .why-adam-list article + article {
    display: grid;
    flex: 0 0 auto;
    grid-template-columns: 38px minmax(0, 1fr);
    align-content: start;
    column-gap: 14px;
    width: 100%;
    min-height: 0;
    margin: 0;
    padding: 0;
    border: 0;
  }

  .why-adam-list span {
    grid-row: 1 / span 2;
    align-self: center;
    padding-top: 0;
    color: #aab3c8;
    font-size: 48px;
    line-height: 1;
    text-align: center;
    opacity: .55;
  }

  .why-adam-list h3 {
    grid-column: 2;
    grid-row: 1;
    max-width: none;
    margin: 0 0 19px;
    color: #aab3c8;
    font-size: 19.968px;
    line-height: 1.1;
  }

  .why-adam-list p {
    grid-column: 2;
    grid-row: 2;
    max-width: none;
    margin: 0;
    font-size: 11.5px !important;
    line-height: 1.65 !important;
  }

  .why-adam .brand-statement {
    width: 100vw;
    margin-top: 28px;
    margin-left: calc(50% - 50vw);
    padding: 28px max(31px, calc((100vw - 328px) / 2));
    background: #f6f3ed;
    font-size: 25px;
    line-height: 1.28;
  }

  .home-wedding-preview {
    padding-top: 28px !important;
    padding-bottom: 84px !important;
    border-top: 0;
  }

  .service-tabs {
    display: none;
  }

  .service-carousel-controls {
    display: none;
  }

  .ceremony-intro-row {
    display: block;
    margin-bottom: 64px;
  }

  .ceremony-intro-headline {
    display: none;
  }

  .ceremony-intro-copy {
    text-align: center;
  }

  .ceremony-intro-copy > h3 {
    display: none;
  }

  .mobile-service-title-nav {
    display: grid;
    grid-template-columns: 22px minmax(0, 1fr) 22px;
    align-items: center;
    gap: 4px;
    margin-bottom: 26px;
  }

  .mobile-service-title-nav button {
    width: 22px;
    height: 22px;
    padding: 0;
    border: 0;
    background: transparent;
    color: #7f8ea2;
    font-size: 22px;
    font-weight: 400;
  }

  .mobile-service-title {
    color: #394047;
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: 19.017px;
    font-weight: 400;
    letter-spacing: 0;
    line-height: 22.82px;
  }

  .ceremony-intro-copy p {
    max-width: 31ch;
    margin-right: auto;
    margin-bottom: 18px;
    margin-left: auto;
  }

  .ceremony-intro-copy .button {
    display: inline-flex;
  }

  .ceremony-intro-copy .button,
  .ceremony-explore-music,
  .button,
  .wedding-button,
  .event-button,
  .song-button,
  .form-submit {
    width: auto;
    min-width: 190px;
    min-height: 48px;
    margin-top: 30px;
    padding-right: 24px;
    padding-left: 24px;
  }

  .ceremony-music-row {
    display: grid;
    gap: 48px;
  }

  .mobile-atmosphere-trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    min-height: 54px;
    margin: 0;
    padding: 0;
    border: 0;
    border-top: 1px solid rgba(127, 142, 162, .24);
    border-bottom: 1px solid rgba(127, 142, 162, .24);
    background: transparent;
    color: #394047;
    font-family: Montserrat, sans-serif;
    font-size: 10.4px;
    font-weight: 400;
    letter-spacing: .14em;
    text-align: left;
    text-transform: uppercase;
  }

  .mobile-atmosphere-icon {
    color: #7f8ea2;
    font-size: 18px;
    letter-spacing: 0;
  }

  .mobile-atmosphere-label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
  }

  .mobile-click-hand {
    color: #7f8ea2;
    font-family: Arial, sans-serif;
    font-size: 15px;
    line-height: 1;
    transform: translateY(-1px);
  }

  .ceremony-music-row:not(.is-mobile-open) {
    display: none;
  }

  .ceremony-music-row.is-mobile-open {
    display: flex;
    flex-direction: column;
    gap: 0;
    padding-top: 26px;
  }

  .ceremony-feeling {
    order: 1;
    transform: none;
  }

  .ceremony-performance {
    order: 2;
  }

  .ceremony-collection {
    order: 3;
    width: 100%;
    padding-top: 4px;
  }

  .mobile-featured-song-name {
    display: flex;
    align-items: center;
    min-height: 23px;
    justify-content: center;
    margin: 0 0 10px;
    color: #333333;
    font-family: Montserrat, sans-serif;
    font-size: 9.5px !important;
    font-weight: 400;
    letter-spacing: 1.9px !important;
    line-height: 13.775px !important;
    text-transform: uppercase;
    text-align: center;
  }

  .mobile-atmosphere-title-nav {
    display: grid;
    grid-template-columns: 22px minmax(0, 1fr) 22px;
    align-items: center;
    gap: 4px;
    min-height: 23px;
    margin-bottom: 10px;
  }

  .mobile-atmosphere-title-nav button {
    width: 22px;
    height: 22px;
    padding: 0;
    border: 0;
    background: transparent;
    color: #7f8ea2;
    font-size: 22px;
    font-weight: 400;
    line-height: 1;
  }

  .mobile-atmosphere-title {
    color: #394047;
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: 19.017px;
    font-weight: 400;
    letter-spacing: 0;
    line-height: 22.82px;
    text-align: center;
  }

  .home-wedding-preview .ceremony-feeling h3 {
    display: none;
  }

  .ceremony-feeling-copy .ceremony-mood {
    margin-bottom: 20px;
    color: #7f8ea2;
    text-align: center;
  }

  .ceremony-video-frame,
  .ceremony-performance .ceremony-video-frame,
  .ceremony-feature-video,
  .ceremony-performance .ceremony-feature-video {
    width: 100%;
    max-width: none;
  }

  .ceremony-song {
    display: none;
  }

  .ceremony-explore-music {
    display: flex;
    width: 125px !important;
    min-width: 125px !important;
    height: 32px !important;
    min-height: 32px !important;
    margin-top: 28px;
    margin-right: auto;
    margin-left: auto;
    padding: 0 !important;
    border: 0;
    background: #f2f3f5;
    color: #7f8ea2;
    font-size: 10.4px !important;
    font-weight: 400;
    letter-spacing: 1.04px !important;
    line-height: 1;
    text-align: center;
  }

  .site-footer {
    padding-top: 54px;
    padding-bottom: 58px;
  }

  .site-footer .footer-nav {
    width: calc(100vw - 20px);
    max-width: none;
    flex-wrap: nowrap;
    gap: 4px;
    margin-bottom: 0;
    font-size: 8px;
    letter-spacing: .176em;
    line-height: 1.6;
    white-space: nowrap;
  }
}
/* Shared mobile header,
measured from the Moses Lin mobile reference at 390px. */
@media (max-width: 640px) {
  .site-header,
  .home-page .site-header {
    position: relative;
    top: auto;
    z-index: 60;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 0;
    height: 76px;
    padding: 0;
    background: #fafafa;
    border-bottom: 0;
    backdrop-filter: none;
  }

  .site-header .wordmark {
    position: absolute;
    top: 20px;
    left: 50%;
    z-index: 62;
    display: flex;
    width: 150px;
    min-height: 0;
    height: 35px;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2px;
    max-width: none;
    color: #394047;
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: .31em;
    line-height: .9;
    text-align: center;
    text-transform: uppercase;
    white-space: nowrap;
    transform: translateX(-50%);
  }

  .site-header .wordmark span:last-child {
    margin: 0;
    padding-left: .38em;
    color: #394047;
    font-family: Montserrat, sans-serif;
    font-size: 8px;
    font-weight: 400;
    letter-spacing: .48em;
    line-height: 1;
  }

  .site-header .nav-toggle {
    position: absolute;
    top: 16px;
    right: 24px;
    z-index: 62;
    display: grid;
    width: 49px;
    min-width: 49px;
    height: 44px;
    place-content: center end;
    padding: 0 8px 0 0;
    border: 0;
    background: transparent;
  }

  .site-header .nav-toggle span {
    display: block;
    width: 28px;
    height: 1px;
    margin: 3px 0;
    background: #7f8ea2;
    transform-origin: center;
  }

  .site-header .nav-toggle span:nth-child(2) {
    width: 20px;
    margin-left: auto;
  }

  .site-header .nav-toggle[aria-expanded="true"] span:first-child {
    transform: translateY(7px) rotate(45deg);
  }

  .site-header .nav-toggle[aria-expanded="true"] span:nth-child(2) {
    opacity: 0;
  }

  .site-header .nav-toggle[aria-expanded="true"] span:last-child {
    transform: translateY(-7px) rotate(-45deg);
  }

  .site-header .site-nav,
  .site-header .site-nav.is-open {
    z-index: 61;
    padding: 144px 32px 42px;
    background: #f2f3f5;
  }

  .site-header .site-nav::before {
    display: none;
    content: none;
  }

  .site-header .site-nav > a {
    justify-content: center;
    width: 100%;
    min-height: 55px;
    padding: 0;
    border-top: 0;
    border-bottom: 1px solid rgba(127, 142, 162, .22);
    color: #394047;
    font-family: Montserrat, sans-serif;
    font-size: 13px;
    font-weight: 400;
    letter-spacing: .15em;
    text-align: center;
  }

  .site-header .site-nav .nav-dropdown {
    position: relative;
    display: grid;
    width: 100%;
    border-bottom: 1px solid rgba(127, 142, 162, .22);
  }

  .site-header .site-nav .nav-dropdown-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 55px;
    padding: 0;
    border: 0;
    color: #394047;
    font-family: Montserrat, sans-serif;
    font-size: 13px;
    font-weight: 400;
    letter-spacing: 1.95px;
    text-align: center;
  }

  .site-header .mobile-submenu-toggle {
    position: absolute;
    top: 0;
    right: 0;
    display: grid;
    width: 55px;
    height: 55px;
    place-items: center;
    padding: 0;
    border: 0;
    background: transparent;
    color: #7f8ea2;
    font-size: 18px;
    transition: transform .25s ease;
  }

  .site-header .nav-dropdown.is-mobile-open .mobile-submenu-toggle {
    transform: rotate(90deg);
  }

  .site-header .site-nav .nav-submenu {
    position: static;
    display: grid;
    max-height: 0;
    overflow: hidden;
    padding: 0;
    background: transparent;
    border: 0;
    opacity: 1;
    pointer-events: none;
    transform: none;
    transition: max-height .3s ease;
  }

  .site-header .nav-dropdown.is-mobile-open .nav-submenu {
    max-height: 55px;
    pointer-events: auto;
  }

  .site-header .site-nav .nav-submenu a {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0;
    color: #7f8ea2;
    font-family: Montserrat, sans-serif;
    font-size: 10.4px;
    letter-spacing: 1.04px;
    text-align: center;
    text-transform: uppercase;
  }

  /* Shared mobile editorial body rhythm, based on the Moses mobile proportions. */
  .artist-copy,
  .artist-body,
  .about-editorial-redesign .about-hero-copy,
  .about-editorial-redesign .journey-block,
  .about-editorial-redesign .about-timeline-copy,
  .about-editorial-redesign .about-closing-copy,
  .weddings-redesign .wedding-hero-copy,
  .events-redesign .event-hero-copy,
  .events-redesign .event-about-adam-copy,
  .contact-copy,
  .ceremony-intro-copy,
  .service-copy {
    text-align: left;
  }

  .artist-body,
  .about-editorial-redesign .about-hero-copy,
  .about-editorial-redesign .journey-block,
  .about-editorial-redesign .about-timeline-copy,
  .about-editorial-redesign .about-closing-copy,
  .events-redesign .event-about-adam-copy,
  .contact-copy {
    width: min(100%, 328px);
    max-width: 328px;
    margin-right: auto;
    margin-left: auto;
  }

  .artist-body p,
  .about-hero-copy p:not(.about-eyebrow),
  .journey-block p,
  .about-timeline p,
  .about-closing-copy p,
  .weddings-redesign .wedding-hero-copy > p:not(.wedding-eyebrow),
  .events-redesign .event-hero-copy > p:not(.event-eyebrow),
  .events-redesign .event-about-adam-copy > p:not(.event-premium-label),
  .contact-copy p,
  .ceremony-intro-copy p,
  .service-copy p {
    max-width: none;
    margin-right: 0;
    margin-bottom: 19px;
    margin-left: 0;
    font-family: Montserrat, sans-serif;
    font-size: 11.5px !important;
    font-weight: 400;
    line-height: 1.65 !important;
    letter-spacing: 0;
    text-align: left;
  }

  .artist-body p:last-child,
  .about-hero-copy p:not(.about-eyebrow):last-child,
  .journey-block p:last-child,
  .about-timeline p:last-child,
  .about-closing-copy p:last-child,
  .events-redesign .event-about-adam-copy > p:not(.event-premium-label):last-child,
  .contact-copy p:last-child,
  .ceremony-intro-copy p:last-of-type,
  .service-copy p:last-of-type {
    margin-bottom: 0;
  }

  main .artist-copy .learn-more {
    display: flex;
    width: 125px !important;
    min-width: 125px !important;
    height: 32px !important;
    min-height: 32px !important;
    margin: 28px auto 0;
    padding: 0 !important;
    border: 0;
    background: #f2f3f5;
    color: #7f8ea2;
    font-size: 10.4px !important;
    font-weight: 400;
    letter-spacing: 1.04px !important;
    line-height: 1;
    text-align: center;
  }

  .ceremony-intro-copy .button,
  .ceremony-explore-music {
    display: flex;
    width: fit-content !important;
    min-width: 125px !important;
    height: 32px !important;
    min-height: 32px !important;
    margin: 28px auto 0;
    padding: 0 20px !important;
    border: 0 !important;
    background: #f2f3f5 !important;
    color: #7f8ea2 !important;
    font-size: 10.4px !important;
    font-weight: 400;
    letter-spacing: 1.04px !important;
    line-height: 1;
    text-align: center;
  }

  .why-adam-intro h2,
  .why-adam-list h3,
  .why-adam-list span,
  .brand-statement,
  .home-wedding-preview .ceremony-feeling h3 {
    opacity: 1;
  }
}

@media (max-width: 640px) {
.home-wedding-preview .mobile-featured-song-name {
    font-family: Montserrat, sans-serif !important;
    font-size: 9.5px !important;
    font-weight: 400 !important;
    letter-spacing: 1.9px !important;
    line-height: 13.775px !important;
  }
}
/* Final mobile CTA flow override. */
@media (max-width: 640px) {
  .home-final-cta {
    display: flex !important;
    flex-direction: column;
    min-height: 0;
    margin: 0;
    padding: 0 0 48px;
    background: #fafafa;
  }

  .home-final-cta::before {
    display: none;
    content: none;
  }

  .home-final-cta .final-cta-image {
    position: relative !important;
    inset: auto !important;
    order: 1;
    width: 100%;
    height: 232px;
    min-height: 232px;
  }

  .home-final-cta .final-cta-image::after {
    display: none !important;
    content: none !important;
    background: none !important;
  }

  .home-final-cta .final-cta-copy {
    position: relative;
    order: 2;
    align-items: center;
    width: min(100% - 62px, 328px);
    min-height: 0;
    margin: 0 auto;
    padding: 28px 0 0 !important;
  }

  .home-final-cta .final-cta-heading {
    position: absolute;
    right: 0;
    bottom: calc(100% + 10px);
    left: 0;
    z-index: 3;
    margin: 0;
  }

  .home-final-cta .final-cta-copy .button {
    width: 143px !important;
    min-width: 143px !important;
    height: 36px !important;
    min-height: 36px !important;
  }
}
/* Mobile completion pass: consistent gutters,
comfortable touch targets,
and a calmer footer. */
@media (max-width: 640px) {
  html,
  body {
    max-width: 100%;
    overflow-x: clip;
  }

  .site-header .site-nav,
  .site-header .site-nav.is-open {
    padding-top: max(132px, calc(104px + env(safe-area-inset-top)));
    padding-bottom: max(40px, calc(24px + env(safe-area-inset-bottom)));
    background: rgba(248, 248, 248, .995);
  }

  .site-header .site-nav > a,
  .site-header .site-nav .nav-dropdown-toggle {
    min-height: 60px;
  }

  .weddings-redesign .wedding-personalized-centered .wedding-personalized-column,
  .weddings-redesign .wedding-personalized-heading,
  .weddings-redesign .wedding-personalized-copy {
    width: min(100% - 48px, 328px);
    max-width: 328px;
    margin-right: auto;
    margin-left: auto;
  }

  .mobile-service-title-nav,
  .mobile-atmosphere-title-nav {
    grid-template-columns: 44px minmax(0, 1fr) 44px;
    gap: 0;
  }

  .mobile-service-title-nav button,
  .mobile-atmosphere-title-nav button {
    width: 44px;
    height: 44px;
    touch-action: manipulation;
  }

  main .artist-copy .learn-more,
  .ceremony-intro-copy .button,
  .ceremony-explore-music,
  .home-final-cta .final-cta-copy .button {
    height: 44px !important;
    min-height: 44px !important;
  }

  .site-footer {
    padding-right: 24px;
    padding-left: 24px;
  }

  .site-footer .footer-nav {
    width: min(100%, 328px);
    flex-wrap: wrap;
    justify-content: center;
    gap: 0 8px;
    font-size: 8.5px;
    letter-spacing: .14em;
    white-space: normal;
  }

  .site-footer .footer-nav a {
    display: inline-flex;
    min-height: 32px;
    align-items: center;
  }
}
.about-mobile-hero-heading {
  display: none;
}
.about-mobile-journey-image,
.about-mobile-timeline-heading,
.about-mobile-closing-image,
.about-mobile-closing-heading {
  display: none;
}
/* About mobile hero: wide portrait with editorial title overlay. */
@media (max-width: 640px) {
  .about-editorial-redesign {
    padding-top: 0;
  }

  .about-editorial-redesign .about-hero-redesign {
    display: block;
    width: 100%;
    max-width: none;
    margin: 0;
    padding-top: 0;
  }

  .about-editorial-redesign .about-hero-placeholder {
    position: relative;
    width: 100%;
    max-width: none;
    height: 54vh;
    min-height: 430px;
    max-height: 560px;
    aspect-ratio: auto;
    margin: 0;
    overflow: hidden;
  }

  .about-editorial-redesign .about-hero-placeholder::after {
    position: absolute;
    inset: 0;
    display: block;
    background: linear-gradient(180deg, rgba(0, 0, 0, .48) 0%, rgba(0, 0, 0, .12) 48%, transparent 72%);
    content: "";
    pointer-events: none;
  }

  .about-editorial-redesign .about-hero-placeholder img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
  }

  .about-mobile-hero-heading {
    position: absolute;
    top: auto;
    bottom: 14px;
    left: max(31px, calc((100vw - 328px) / 2));
    z-index: 2;
    display: block;
    width: min(76%, 300px);
    color: #ffffff;
    text-align: left;
    text-shadow: 0 2px 14px rgba(0, 0, 0, .48);
  }

  .about-mobile-hero-heading p {
    margin: 0 0 10px;
    color: #ffffff !important;
    font-family: Montserrat, sans-serif;
    font-size: 9.5px;
    font-weight: 400;
    letter-spacing: .2em;
    line-height: 1.45;
    text-transform: uppercase;
  }

  .about-mobile-hero-heading h1 {
    margin: 0;
    color: #ffffff;
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: 27px;
    font-weight: 400;
    letter-spacing: -.01em;
    line-height: 1.06;
  }

  .about-editorial-redesign .about-hero-copy {
    width: min(100% - 62px, 328px);
    max-width: 328px;
    margin: 0 auto;
    padding-top: 22px;
  }

  .about-editorial-redesign .about-hero-copy .about-eyebrow,
  .about-editorial-redesign .about-hero-copy > h1 {
    display: none;
  }

  .about-mobile-journey-image {
    display: block;
    width: 100%;
    margin: 0 0 28px;
    aspect-ratio: 4 / 5;
    overflow: hidden;
  }

  .about-mobile-journey-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .about-editorial-redesign .about-childhood-placeholder {
    display: none;
  }

  .about-editorial-redesign .about-timeline-placeholder {
    position: relative;
  }

  .about-editorial-redesign .about-timeline-placeholder::after {
    position: absolute;
    inset: 45% 0 0;
    display: block;
    background: linear-gradient(180deg, transparent, rgba(0, 0, 0, .56));
    content: "";
    pointer-events: none;
  }

  .about-mobile-timeline-heading {
    position: absolute;
    right: 24px;
    bottom: 24px;
    left: 24px;
    z-index: 2;
    display: block;
    color: #ffffff;
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: 27px;
    font-weight: 400;
    letter-spacing: -.02em;
    line-height: 1.02;
    text-align: left;
    text-shadow: 0 2px 14px rgba(0, 0, 0, .52);
  }

  .about-mobile-timeline-heading {
    width: 190px;
  }

  .about-editorial-redesign .about-timeline-heading {
    display: none;
  }

  .about-editorial-redesign .about-journey-heading h2 {
    white-space: nowrap;
  }

  .about-editorial-redesign .about-journey-heading h2 br {
    display: none;
  }

  .about-editorial-redesign .about-mobile-hero-heading h1,
  .about-editorial-redesign .about-journey-heading h2,
  .about-editorial-redesign .about-mobile-timeline-heading,
  .about-editorial-redesign .about-closing-reflection h2,
  .about-editorial-redesign .about-closing-invitation h2 {
    font-size: 31.2px;
    letter-spacing: -1.248px;
    line-height: 34.32px;
  }

  .about-editorial-redesign .journey-block h3,
  .about-editorial-redesign .timeline-entry h3 {
    font-size: 19.017px;
    letter-spacing: 0;
    line-height: 22.82px;
  }

  .about-mobile-closing-image {
    position: relative;
    display: block;
    width: 100%;
    margin: 24px 0 0;
    aspect-ratio: 4 / 5;
    overflow: hidden;
  }

  .about-mobile-closing-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .about-mobile-closing-heading {
    position: static;
    display: block;
    margin: 0 0 24px;
    color: var(--about-text);
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: 31.2px;
    font-weight: 400;
    letter-spacing: -1.248px;
    line-height: 34.32px;
    text-align: left;
    text-shadow: none;
  }

  .about-editorial-redesign .about-closing-reflection > h2 {
    display: none;
  }

  .about-editorial-redesign > .about-closing > .about-closing-image {
    display: none;
  }

  .about-editorial-redesign .about-filled-button {
    display: flex;
    width: 143px;
    min-width: 143px;
    height: 44px !important;
    min-height: 44px !important;
    margin: 28px auto 0;
    padding: 0 !important;
    border: 0;
    background: #f2f3f5;
    color: #7f8ea2;
    font-family: Montserrat, sans-serif;
    font-size: 10.4px !important;
    font-weight: 400;
    letter-spacing: 1.04px !important;
    line-height: 10.4px;
    text-align: center;
  }
}
/* Keep every blue editorial text treatment fully opaque across the site. */
.journey-number,
.why-adam-list span,
.wedding-why-grid span,
.wedding-testimonial-placeholder blockquote::before,
.event-client-reasons-grid span,
.weddings-redesign .wedding-personalized-features span,
.faq-background-title {
  color: #aab3c8 !important;
  opacity: 1 !important;
}
.song-collection-page-title {
  color: #7d8aa0 !important;
  opacity: 1 !important;
}

/* About number hierarchy and a tighter global footer rhythm. */
.about-editorial-redesign .journey-number {
  opacity: .7 !important;
}

.site-footer {
  gap: 8px;
  min-height: 154px;
  padding-top: 24px;
  padding-bottom: 24px;
}

@media (max-width: 640px) {
  .site-footer {
    padding-top: 43px;
    padding-bottom: 46px;
  }

  .about-editorial-redesign .about-closing-invitation {
    position: relative;
    width: 100vw;
    max-width: none;
    margin-top: 0;
    margin-left: calc(50% - 50vw);
    padding: 29px max(31px, calc((100vw - 328px) / 2)) 48px;
    background: #f6f3ed;
  }

  .about-editorial-redesign .about-closing {
    padding-bottom: 0;
  }
}

.wedding-mobile-image-heading,
.wedding-mobile-cta-heading {
  display: none;
}

/* Weddings mobile: image-led editorial flow aligned with the Moses reference. */
@media (max-width: 640px) {
  .weddings-redesign .wedding-hero {
    height: 64vh;
    min-height: 520px;
    max-height: 620px;
  }

  .weddings-redesign .wedding-hero-copy {
    width: min(100% - 48px, 345px);
    padding-bottom: 36px;
  }

  .weddings-redesign .wedding-hero-copy h1 {
    font-size: 31.2px;
    letter-spacing: -1.248px;
    line-height: 34.32px;
  }

  .weddings-redesign .wedding-hero-copy > p:not(.wedding-eyebrow) {
    max-width: 328px;
    margin-top: 22px;
    font-size: 11.5px !important;
    line-height: 1.65 !important;
  }

  .weddings-redesign .wedding-experience {
    width: 100%;
    max-width: none;
    padding: 0;
  }

  .weddings-redesign .wedding-experience .wedding-section-intro {
    width: min(100% - 62px, 328px);
    margin: 0 auto;
    padding: 42px 0;
  }

  .weddings-redesign .wedding-section-intro h2,
  .weddings-redesign .wedding-personalized-heading h2,
  .weddings-redesign .wedding-final-copy h2 {
    font-size: 31.2px;
    letter-spacing: -1.248px;
    line-height: 34.32px;
  }

  .weddings-redesign .wedding-experience-row,
  .weddings-redesign .wedding-experience-row:last-child,
  .weddings-redesign .wedding-experience > .wedding-experience-row:first-of-type {
    display: flex;
    width: 100%;
    max-width: none;
    flex-direction: column;
    gap: 0;
    margin: 0;
    padding: 0 0 48px;
    border: 0;
  }

  .weddings-redesign .wedding-row-placeholder,
  .weddings-redesign .wedding-row-reverse .wedding-row-placeholder {
    position: relative;
    order: 1;
    width: 100%;
    height: auto;
    min-height: 0;
    aspect-ratio: 4 / 5;
    border: 0;
  }

  .weddings-redesign .wedding-row-placeholder::after,
  .weddings-redesign .wedding-cta-placeholder::after {
    position: absolute;
    inset: 48% 0 0;
    z-index: 1;
    display: block;
    background: linear-gradient(180deg, transparent, rgba(0, 0, 0, .58));
    content: "";
    pointer-events: none;
  }

  .weddings-redesign .wedding-row-placeholder img {
    object-fit: cover;
  }

  .weddings-redesign .wedding-row-placeholder:nth-child(1) img {
    object-position: center;
  }

  .wedding-mobile-image-heading {
    position: absolute;
    right: 31px;
    bottom: 28px;
    left: 31px;
    z-index: 2;
    display: block;
    color: #ffffff;
    text-align: left;
    text-shadow: 0 2px 14px rgba(0, 0, 0, .52);
  }

  .wedding-mobile-image-heading span {
    display: block;
    margin-bottom: 8px;
    font-family: Montserrat, sans-serif;
    font-size: 9.5px;
    font-weight: 400;
    letter-spacing: .2em;
    line-height: 1.45;
    text-transform: uppercase;
  }

  .wedding-mobile-image-heading h3 {
    margin: 0;
    color: #ffffff;
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: 31.2px;
    font-weight: 400;
    letter-spacing: -1.248px;
    line-height: 34.32px;
  }

  .weddings-redesign .wedding-row-copy {
    order: 2;
    width: min(100% - 62px, 328px);
    max-width: 328px;
    margin: 0 auto;
    padding-top: 28px;
  }

  .weddings-redesign .wedding-row-copy .wedding-eyebrow,
  .weddings-redesign .wedding-row-copy h3 {
    display: none;
  }

  .weddings-redesign .wedding-row-copy p:not(.wedding-eyebrow),
  .weddings-redesign .wedding-personalized-copy p,
  .weddings-redesign .wedding-personalized-features p,
  .weddings-redesign .wedding-final-copy p {
    margin: 0 0 19px;
    font-size: 11.5px !important;
    line-height: 1.65 !important;
  }

  .weddings-redesign .wedding-personalized-centered {
    padding-top: 42px;
    padding-bottom: 48px;
  }

  .weddings-redesign .wedding-final-cta {
    display: flex;
    width: 100%;
    max-width: none;
    flex-direction: column;
    gap: 0;
    padding: 0;
  }

  .weddings-redesign .wedding-cta-placeholder {
    position: relative;
    order: 1;
    width: 100%;
    min-height: 0;
    aspect-ratio: 4 / 5;
    border: 0;
  }

  .wedding-mobile-cta-heading {
    position: absolute;
    right: 31px;
    bottom: 28px;
    left: 31px;
    z-index: 2;
    display: block;
    color: #ffffff;
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: 31.2px;
    font-weight: 400;
    letter-spacing: -1.248px;
    line-height: 34.32px;
    text-align: left;
    text-shadow: 0 2px 14px rgba(0, 0, 0, .52);
  }

  .weddings-redesign .wedding-final-copy {
    order: 2;
    width: min(100% - 62px, 328px);
    max-width: 328px;
    min-height: 0;
    margin: 0 auto;
    padding: 28px 0 31px;
  }

  .weddings-redesign .wedding-final-copy h2 {
    display: none;
  }

  .weddings-redesign .wedding-final-copy .wedding-button {
    display: flex;
    width: 143px;
    min-width: 143px;
    height: 44px !important;
    min-height: 44px !important;
    margin: 28px auto 0;
    padding: 0 !important;
    border: 0;
    background: #f2f3f5;
    color: #7f8ea2;
    font-size: 10.4px !important;
    letter-spacing: 1.04px !important;
  }
}

/* Moses Weddings reference: square hero image and shallow image-led closing CTA. */
@media (max-width: 640px) {
  .weddings-redesign .wedding-hero {
    display: block;
    height: auto;
    min-height: 0;
    max-height: none;
    overflow: visible;
    background: #fafafa;
  }

  .weddings-redesign .wedding-hero-placeholder {
    position: relative;
    inset: auto;
    width: 100%;
    height: auto;
    min-height: 0;
    aspect-ratio: 1 / 1;
  }

  .weddings-redesign .wedding-hero-placeholder::after {
    position: absolute;
    inset: 0;
    z-index: 1;
    display: block;
    background:
      linear-gradient(90deg, rgba(246, 243, 237, .84) 0%, rgba(246, 243, 237, .62) 36%, rgba(246, 243, 237, .10) 74%),
      radial-gradient(circle at 67% 47%, rgba(51, 51, 51, .08), rgba(51, 51, 51, 0) 28%),
      linear-gradient(0deg, rgba(51, 51, 51, .08), rgba(51, 51, 51, .02));
    content: "";
  }

  .weddings-redesign .wedding-hero-placeholder img {
    object-fit: cover;
    object-position: center center;
  }

  .weddings-redesign .wedding-hero-copy {
    position: static;
    align-items: center;
    width: min(100% - 62px, 328px);
    min-height: 0;
    margin: 0 auto;
    padding: 28px 0 31px;
    text-align: center;
  }

  .weddings-redesign .wedding-hero-copy .wedding-eyebrow {
    order: 2;
    margin: 7px 0 0;
  }

  .weddings-redesign .wedding-hero-copy h1 {
    order: 1;
    color: #333333;
    text-align: center;
    text-shadow: none;
  }

  .weddings-redesign .wedding-hero-copy > p:not(.wedding-eyebrow) {
    order: 3;
    margin-top: 28px;
    text-align: left;
  }

  .weddings-redesign .wedding-hero-actions {
    order: 4;
    align-items: center;
    margin-top: 39px;
  }

  .weddings-redesign .wedding-hero-actions .wedding-button {
    width: 143px;
    min-width: 143px;
    height: 36px !important;
    min-height: 36px !important;
    margin: 0;
    padding: 0 !important;
    border: 0;
    background: #f2f3f5;
    color: #7f8ea2;
    font-size: 10.4px !important;
    font-weight: 400;
    letter-spacing: 1.04px !important;
    line-height: 10.4px;
  }

  .weddings-redesign .wedding-final-cta {
    display: block;
    min-height: 0;
    overflow: visible;
    background: #fafafa;
  }

  .weddings-redesign .wedding-cta-placeholder {
    position: relative;
    inset: auto;
    width: 100%;
    height: auto;
    min-height: 0;
    aspect-ratio: 390 / 232;
    overflow: visible;
  }

  .weddings-redesign .wedding-cta-placeholder::after {
    position: absolute;
    inset: 0;
    z-index: 1;
    display: block;
    background:
      linear-gradient(to bottom, rgba(250, 250, 250, .12) 0%, #fafafa 100%),
      rgba(0, 0, 0, .15);
    content: "";
  }

  .weddings-redesign .wedding-cta-placeholder img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
  }

  .wedding-mobile-cta-heading {
    right: 31px;
    bottom: -30px;
    left: 31px;
    color: #7f8ea2;
    font-size: 31.2px;
    letter-spacing: -1.248px;
    line-height: 34.32px;
    text-align: center;
    text-shadow: none;
  }

  .weddings-redesign .wedding-final-copy {
    position: static;
    width: min(100% - 62px, 328px);
    min-height: 0;
    margin: 0 auto;
    padding: 66px 0 31px;
  }

  .weddings-redesign .wedding-hero-copy > p:not(.wedding-eyebrow):last-of-type,
  .weddings-redesign .wedding-final-copy p:last-of-type {
    margin-bottom: 0;
  }

  .weddings-redesign .wedding-final-copy .wedding-button {
    width: 143px;
    min-width: 143px;
    height: 36px !important;
    min-height: 36px !important;
    margin: 39px auto 0;
  }

  .weddings-redesign .wedding-personalized-features .wedding-feature-logo-title {
    max-width: 100%;
    overflow: visible;
  }

  .weddings-redesign .wedding-personalized-features .wedding-feature-logo-title img {
    width: auto;
    max-width: 100%;
    height: 48px;
    object-fit: contain;
  }
}

/* Final Events / FAQ mobile ordering and legacy-style overrides. */
@media (max-width: 640px) {
  main.events-redesign .event-hero {
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
  }

  main.events-redesign .event-hero-placeholder {
    position: relative !important;
    inset: auto !important;
    height: auto !important;
    min-height: 0 !important;
    aspect-ratio: 1 / 1 !important;
  }

  main.events-redesign .event-hero-placeholder::after {
    display: none !important;
  }

  main.events-redesign .event-hero-copy {
    position: static !important;
    justify-content: flex-start !important;
    width: min(100% - 62px, 328px) !important;
    height: auto !important;
    min-height: 0 !important;
    padding: 28px 0 31px !important;
  }

  main.events-redesign .event-hero h1 {
    color: #333333 !important;
    text-shadow: none !important;
  }

  main.events-redesign .event-hero .event-eyebrow {
    color: #7f8ea2 !important;
    text-shadow: none !important;
  }

  main.events-redesign .event-hero-copy > p:not(.event-eyebrow) {
    margin-top: 28px !important;
    color: #333333 !important;
    font-size: 11.5px !important;
    line-height: 1.65 !important;
    text-shadow: none !important;
  }

  main.events-redesign .event-hero .event-button,
  main.events-redesign .event-contact-cta .event-button {
    width: 143px !important;
    min-width: 143px !important;
    height: 36px !important;
    min-height: 36px !important;
    margin-top: 39px !important;
    padding: 0 !important;
    border: 0 !important;
    background: #f2f3f5 !important;
    color: #7f8ea2 !important;
    font-size: 10.4px !important;
    letter-spacing: 1.04px !important;
    text-shadow: none !important;
  }

  main.events-redesign .event-premium-section,
  main.events-redesign .event-about-adam,
  main.events-redesign .event-discovery {
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 46px 31px !important;
  }

  main.events-redesign .event-about-adam {
    display: block !important;
    background: #f2f3f5 !important;
  }

  main.events-redesign .event-about-adam-copy {
    width: 100% !important;
    max-width: 328px !important;
    margin: 0 auto !important;
  }

  main.events-redesign .event-about-adam-portrait:not(.event-about-adam-portrait-mobile) {
    display: none !important;
  }

  main.events-redesign .event-about-adam-portrait-mobile {
    display: block !important;
    width: 100% !important;
    height: auto !important;
    margin: 0 0 31px !important;
    aspect-ratio: 328 / 189 !important;
  }

  main.events-redesign .event-about-adam-copy h2,
  main.events-redesign .event-listening-guide h2,
  main.events-redesign .event-contact-cta .event-premium-label {
    color: #7f8ea2 !important;
    font-size: 31.2px !important;
    letter-spacing: -1.248px !important;
    line-height: 34.32px !important;
    text-transform: none !important;
  }

  main.events-redesign .event-about-adam-copy p:not(.event-premium-label),
  main.events-redesign .event-listening-intro > p:not(.event-premium-label),
  main.events-redesign .event-listening-guide p,
  main.events-redesign .event-client-reasons-grid p,
  main.events-redesign .event-contact-cta p:not(.event-premium-label) {
    font-size: 11.5px !important;
    line-height: 1.65 !important;
  }

  main.events-redesign .event-contact-cta {
    position: relative !important;
    display: block !important;
    width: 100% !important;
    min-height: 0 !important;
    padding: 348px 31px 0 !important;
    background: #fafafa !important;
    color: #333333 !important;
    text-align: left !important;
  }

  main.events-redesign .event-contact-cta::before {
    display: none !important;
    content: none !important;
  }

  main.events-redesign .event-contact-cta-image {
    position: absolute !important;
    top: 0 !important;
    right: 0 !important;
    left: 0 !important;
    display: block !important;
    height: 336px !important;
    background:
      linear-gradient(
        to bottom,
        rgba(250, 250, 250, 0) 0%,
        rgba(250, 250, 250, .03) 28%,
        rgba(250, 250, 250, .16) 52%,
        rgba(250, 250, 250, .5) 72%,
        rgba(250, 250, 250, .86) 89%,
        #fafafa 100%
      ),
      url("images/placeholders/adam-event-CAT-portrait.jpg") center center / cover no-repeat !important;
  }

  main.events-redesign .event-contact-cta p:not(.event-premium-label) {
    color: #333333 !important;
  }

  main .faq-page {
    display: flex !important;
    width: 100% !important;
    max-width: none !important;
    min-height: 0 !important;
    flex-direction: column !important;
    padding: 42px 31px 64px !important;
    background: #fafafa !important;
  }

  main .faq-layout {
    display: contents !important;
  }

  main .faq-background-title {
    position: static !important;
    order: 1 !important;
    display: block !important;
    width: 100% !important;
    margin: 0 !important;
    color: #333333 !important;
    font-size: 60px !important;
    letter-spacing: -3px !important;
    line-height: 1 !important;
    opacity: 1 !important;
    transform: none !important;
    height: auto !important;
    min-height: 0 !important;
  }

  main .faq-background-title span {
    position: static !important;
    display: inline-block !important;
    width: auto !important;
    height: auto !important;
    writing-mode: horizontal-tb !important;
    transform: none !important;
  }

  main .faq-side-label {
    position: static !important;
    order: 2 !important;
    width: 100% !important;
    margin: 7px 0 0 !important;
    color: #7f8ea2 !important;
    font-size: 9.36px !important;
    letter-spacing: .16em !important;
    line-height: 18.72px !important;
    transform: none !important;
  }

  main .faq-categories {
    order: 3 !important;
    display: flex !important;
    width: calc(100vw - 31px) !important;
    max-width: none !important;
    margin: 16px 0 0 !important;
    padding: 0 31px 7px 0 !important;
    gap: 0 !important;
    overflow-x: auto !important;
  }

  main .faq-category,
  main .faq-category:first-child,
  main .faq-category:last-child {
    flex: 0 0 auto !important;
    width: auto !important;
    min-width: 134px !important;
    padding: 7px 12px 9px !important;
    border: 0 !important;
    border-bottom: 1px solid transparent !important;
    background: transparent !important;
    color: #333333 !important;
    font-family: "Cormorant Garamond", Georgia, serif !important;
    font-size: 15px !important;
    letter-spacing: 0 !important;
    line-height: 1.2 !important;
    text-align: center !important;
    text-transform: none !important;
  }

  main .faq-category:first-child {
    padding-left: 0 !important;
  }

  main .faq-category.is-active {
    border-bottom-color: #7f8ea2 !important;
    color: #7f8ea2 !important;
  }

  main .faq-questions {
    order: 4 !important;
    width: 100% !important;
    max-width: 328px !important;
    margin: 14px auto 0 !important;
  }

  main .faq-question {
    margin: 0 0 22px !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
  }

  main .faq-question h2 {
    margin: 0 0 2px !important;
    font-family: Montserrat, sans-serif !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    letter-spacing: 0 !important;
    line-height: 1.7 !important;
    text-transform: none !important;
  }

  main .faq-question p,
  main .faq-contact-note p {
    font-size: 10.4px !important;
    line-height: 18.72px !important;
  }

  main .faq-contact-button {
    width: 143px !important;
    min-width: 143px !important;
    height: 36px !important;
    min-height: 36px !important;
    padding: 0 !important;
    border: 0 !important;
    background: #f2f3f5 !important;
    color: #7f8ea2 !important;
    font-size: 10.4px !important;
    letter-spacing: 1.04px !important;
  }
}

/* Final mobile fixes requested for Events and FAQ. */
@media (max-width: 640px) {
  main.events-redesign .event-hero-copy > p:not(.event-eyebrow) {
    text-align: center !important;
  }

  main.events-redesign .event-about-adam-portrait-mobile {
    height: auto !important;
    aspect-ratio: auto !important;
    overflow: visible !important;
  }

  main.events-redesign .event-about-adam-portrait-mobile img {
    display: block !important;
    width: 100% !important;
    height: auto !important;
    object-fit: contain !important;
    object-position: center !important;
  }

  main.events-redesign .event-contact-cta-image {
    background:
      linear-gradient(to bottom, rgba(250, 250, 250, .05) 0%, rgba(250, 250, 250, .18) 58%, #fafafa 100%),
      url("images/footer-cta-adam-piano1.jpg") center 42% / cover no-repeat !important;
  }

  main.events-redesign .event-featured-listening-inner {
    width: 100% !important;
    margin: 24px 0 0 !important;
  }

  main.events-redesign .event-corporate-player.song-collection-tracks {
    display: block !important;
    height: auto !important;
    min-height: 0 !important;
    border-radius: 0 !important;
    overflow: visible !important;
  }

  main.events-redesign .event-corporate-player .song-collection-player-header {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    min-height: 74px !important;
    padding: 12px 14px !important;
  }

  main.events-redesign .event-corporate-player .song-collection-player-meta h2 {
    max-width: 172px !important;
    font-size: 12px !important;
    line-height: 1.35 !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }

  main.events-redesign .event-corporate-player .song-collection-player-controls {
    gap: 2px !important;
  }

  main.events-redesign .event-corporate-player .song-collection-player-controls button {
    width: 30px !important;
    min-width: 30px !important;
    height: 30px !important;
    min-height: 30px !important;
    font-size: 21px !important;
  }

  main.events-redesign .event-corporate-player .song-collection-player-controls .song-collection-main-play {
    width: 40px !important;
    min-width: 40px !important;
    height: 40px !important;
    min-height: 40px !important;
    margin-left: 4px !important;
    font-size: 13px !important;
  }

  main.events-redesign .event-corporate-player .song-collection-track-area {
    display: block !important;
    padding: 0 14px 12px !important;
  }

  main.events-redesign .event-corporate-player .song-detail-list {
    overflow: visible !important;
  }

  main.events-redesign .event-corporate-player.song-collection-page .song-detail-song {
    display: grid !important;
    grid-template-columns: 24px minmax(0, 1fr) 30px !important;
    gap: 8px !important;
    align-items: center !important;
    min-height: 58px !important;
    padding: 8px 0 !important;
  }

  main.events-redesign .event-corporate-player .song-track-meta {
    grid-column: 2 !important;
    min-width: 0 !important;
  }

  main.events-redesign .event-corporate-player .song-detail-title {
    overflow: hidden !important;
    font-size: 12px !important;
    line-height: 1.35 !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }

  main.events-redesign .event-corporate-player .song-track-artist {
    font-size: 8px !important;
  }

  main.events-redesign .event-corporate-player .song-inline-player {
    display: block !important;
    grid-column: 3 !important;
    width: 30px !important;
  }

  main.events-redesign .event-corporate-player .song-inline-play {
    display: grid !important;
    width: 30px !important;
    height: 30px !important;
    place-items: center !important;
  }

  main.events-redesign .event-corporate-player .song-inline-wave,
  main.events-redesign .event-corporate-player .song-inline-time {
    display: none !important;
  }

  main .faq-background-title,
  main .faq-side-label {
    text-align: center !important;
  }
}

@media (max-width: 640px) {
  main .faq-categories::after {
    display: block !important;
    flex: 0 0 148px !important;
    content: "" !important;
  }
}

/* Final shared mobile player sizing across Events and Song List collections. */
@media (max-width: 640px) {
  main.events-redesign .event-contact-cta-image {
    background:
      linear-gradient(
        to bottom,
        rgba(250, 250, 250, 0) 0%,
        rgba(250, 250, 250, .03) 28%,
        rgba(250, 250, 250, .16) 52%,
        rgba(250, 250, 250, .5) 72%,
        rgba(250, 250, 250, .86) 89%,
        #fafafa 100%
      ),
      url("images/placeholders/adam-event-CAT-portrait.jpg") center center / cover no-repeat !important;
  }

  main.events-redesign .event-featured-listening-inner {
    height: 300px !important;
  }

  main .song-collection-tracks,
  main.events-redesign .event-corporate-player.song-collection-tracks {
    display: grid !important;
    grid-template-rows: 54px minmax(0, 1fr) !important;
    height: 300px !important;
    min-height: 300px !important;
    max-height: 300px !important;
    border-radius: 0 !important;
    overflow: hidden !important;
  }

  main .song-collection-player-header,
  main.events-redesign .event-corporate-player .song-collection-player-header {
    min-height: 54px !important;
    padding: 7px 12px !important;
  }

  main .song-collection-player-meta h2,
  main.events-redesign .event-corporate-player .song-collection-player-meta h2 {
    max-width: 168px !important;
    font-size: 11px !important;
    line-height: 1.3 !important;
  }

  main .song-collection-player-controls button,
  main.events-redesign .event-corporate-player .song-collection-player-controls button {
    width: 28px !important;
    min-width: 28px !important;
    height: 28px !important;
    min-height: 28px !important;
    font-size: 18px !important;
  }

  main .song-collection-player-controls .song-collection-main-play,
  main.events-redesign .event-corporate-player .song-collection-player-controls .song-collection-main-play {
    width: 34px !important;
    min-width: 34px !important;
    height: 34px !important;
    min-height: 34px !important;
    font-size: 11px !important;
  }

  main .song-collection-track-area,
  main.events-redesign .event-corporate-player .song-collection-track-area {
    display: grid !important;
    grid-template-rows: 28px minmax(0, 1fr) !important;
    min-height: 0 !important;
    padding: 0 12px 8px !important;
  }

  main .song-detail-list,
  main.events-redesign .event-corporate-player .song-detail-list {
    min-height: 0 !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    overscroll-behavior: auto !important;
    touch-action: pan-y !important;
  }

  main.events-redesign .event-corporate-player .song-detail-list {
    overflow-y: hidden !important;
  }

  main.song-collection-page .song-detail-song,
  main.events-redesign .event-corporate-player.song-collection-page .song-detail-song {
    display: grid !important;
    grid-template-columns: 20px minmax(82px, .75fr) minmax(142px, 1.25fr) !important;
    gap: 6px !important;
    align-items: center !important;
    min-height: 38px !important;
    padding: 4px 0 !important;
    border-top: 1px solid rgba(255, 255, 255, .28) !important;
  }

  main.song-collection-page .song-detail-song:last-child,
  main.events-redesign .event-corporate-player.song-collection-page .song-detail-song:last-child {
    border-bottom: 1px solid rgba(255, 255, 255, .28) !important;
  }

  main .song-track-meta,
  main.events-redesign .event-corporate-player .song-track-meta {
    grid-column: 2 !important;
    gap: 0 !important;
  }

  main .song-detail-title,
  main.events-redesign .event-corporate-player .song-detail-title {
    font-size: 10px !important;
    line-height: 1.2 !important;
  }

  main .song-track-artist,
  main.events-redesign .event-corporate-player .song-track-artist {
    font-size: 7px !important;
    line-height: 1.2 !important;
  }

  main .song-inline-player,
  main.events-redesign .event-corporate-player .song-inline-player {
    display: grid !important;
    grid-column: 3 !important;
    grid-template-columns: 22px minmax(0, 1fr) 28px !important;
    gap: 5px !important;
    align-items: center !important;
    width: 100% !important;
  }

  main .song-inline-play,
  main.events-redesign .event-corporate-player .song-inline-play {
    display: grid !important;
    width: 22px !important;
    height: 22px !important;
    place-items: center !important;
  }

  main .song-inline-wave,
  main.events-redesign .event-corporate-player .song-inline-wave {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    height: 18px !important;
  }

  main .song-inline-time,
  main.events-redesign .event-corporate-player .song-inline-time {
    display: block !important;
    width: 28px !important;
    font-size: 7px !important;
    text-align: right !important;
  }
}

@media (max-width: 640px) {
  .home-page .why-adam-intro {
    position: static !important;
    top: auto !important;
    right: auto !important;
    bottom: auto !important;
    left: auto !important;
    box-sizing: border-box !important;
    width: 100vw !important;
    max-width: none !important;
    margin-right: 0 !important;
    margin-left: calc(50% - 50vw) !important;
    padding-right: max(31px, calc((100vw - 328px) / 2)) !important;
    padding-left: max(31px, calc((100vw - 328px) / 2)) !important;
  }

  .song-player .song-player-main {
    width: 100% !important;
    justify-items: center !important;
  }

  .song-player .song-player-wave {
    position: relative !important;
    left: auto !important;
    width: min(280px, calc(100vw - 62px)) !important;
    max-width: none !important;
    margin-right: auto !important;
    margin-left: auto !important;
    transform: none !important;
  }

  .home-page .site-footer {
    position: relative !important;
    left: 50% !important;
    box-sizing: border-box !important;
    width: 100vw !important;
    max-width: none !important;
    margin-right: 0 !important;
    margin-left: 0 !important;
    transform: translateX(-50%) !important;
  }
}

/* Home CTA image mask and title legibility. */
.home-final-cta .final-cta-image::after {
  display: block !important;
  content: "" !important;
  background:
    linear-gradient(to bottom, rgba(250, 250, 250, .15) 0%, rgba(250, 250, 250, .15) 100%),
    rgba(0, 0, 0, .15) !important;
}

.home-final-cta .final-cta-heading,
.home-final-cta .final-cta-heading span {
  text-shadow: 0 2px 12px rgba(0, 0, 0, .45) !important;
}

/* Match every solid call-to-action to the Contact form buttons. */
.primary-button,
.button:not(.button-outline),
.wedding-button-filled,
.event-button-filled,
.about-filled-button,
.faq-contact-button,
.faq-song-button,
.form-submit {
  color: #667589 !important;
  background-color: #f2f2f2 !important;
  border-color: #f2f2f2 !important;
}

.primary-button:hover,
.primary-button:focus-visible,
.button:not(.button-outline):hover,
.button:not(.button-outline):focus-visible,
.wedding-button-filled:hover,
.wedding-button-filled:focus-visible,
.event-button-filled:hover,
.event-button-filled:focus-visible,
.about-filled-button:hover,
.about-filled-button:focus-visible,
.faq-contact-button:hover,
.faq-contact-button:focus-visible,
.faq-song-button:hover,
.faq-song-button:focus-visible,
.form-submit:hover,
.form-submit:focus-visible {
  color: #667589 !important;
  background-color: #ececec !important;
  border-color: #ececec !important;
}

/* Footer navigation is 20% darker than white. */
.site-footer .footer-nav a {
  color: #cccccc !important;
}

/* Ensure page-specific button rules cannot override the shared solid palette. */
.primary-button.primary-button.primary-button.primary-button,
.wedding-button-filled.wedding-button-filled.wedding-button-filled,
.event-button-filled.event-button-filled.event-button-filled,
.about-filled-button.about-filled-button.about-filled-button,
.faq-contact-button.faq-contact-button.faq-contact-button,
.faq-song-button.faq-song-button.faq-song-button,
.form-submit.form-submit.form-submit {
  color: #667589 !important;
  background-color: #c7d1e3 !important;
  border-color: #c7d1e3 !important;
}

.primary-button.primary-button.primary-button.primary-button:hover,
.primary-button.primary-button.primary-button.primary-button:focus-visible,
.wedding-button-filled.wedding-button-filled.wedding-button-filled:hover,
.event-button-filled.event-button-filled.event-button-filled:hover,
.about-filled-button.about-filled-button.about-filled-button:hover,
.faq-contact-button.faq-contact-button.faq-contact-button:hover,
.faq-song-button.faq-song-button.faq-song-button:hover,
.form-submit.form-submit.form-submit:hover {
  color: #667589 !important;
  background-color: #b9c5d9 !important;
  border-color: #b9c5d9 !important;
}

/* Footer navigation matches the footer wordmark. */
.site-footer .footer-nav a {
  color: #ffffff !important;
}

/* Events player scrolls internally, then chains scrolling to the page at its edges. */
@media (max-width: 640px) {
  main.events-redesign .event-corporate-player .song-detail-list {
    overflow-x: hidden !important;
    overflow-y: auto !important;
    overscroll-behavior-y: auto !important;
    touch-action: pan-y !important;
    -webkit-overflow-scrolling: touch;
  }
}

/* Final shared solid-button palette from the Contact reference. */
body .primary-button,
body .button:not(.button-outline),
body .wedding-button-filled,
body .event-button-filled,
body .about-filled-button,
body .faq-contact-button,
body .faq-song-button,
body .form-submit {
  color: #667589 !important;
  background-color: #c7d1e3 !important;
  border-color: #c7d1e3 !important;
}

body .primary-button:hover,
body .primary-button:focus-visible,
body .button:not(.button-outline):hover,
body .button:not(.button-outline):focus-visible,
body .wedding-button-filled:hover,
body .event-button-filled:hover,
body .about-filled-button:hover,
body .faq-contact-button:hover,
body .faq-song-button:hover,
body .form-submit:hover {
  color: #667589 !important;
  background-color: #b9c5d9 !important;
  border-color: #b9c5d9 !important;
}

/* Selected calls to action match the Wedding hero Check Availability button. */
body .reference-solid-button {
  display: flex !important;
  box-sizing: border-box !important;
  width: 143px !important;
  min-width: 143px !important;
  height: 36px !important;
  min-height: 36px !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: #c7d1e3 !important;
  color: #667589 !important;
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif !important;
  font-size: 10.4px !important;
  font-weight: 400 !important;
  letter-spacing: 1.04px !important;
  line-height: 12.48px !important;
  text-align: center !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
}

body .reference-solid-button:hover,
body .reference-solid-button:focus-visible {
  border: 0 !important;
  background: #b9c5d9 !important;
  color: #667589 !important;
}

html body main .reference-solid-button.reference-solid-button.reference-solid-button.reference-solid-button {
  display: flex !important;
  box-sizing: border-box !important;
  width: 143px !important;
  min-width: 143px !important;
  max-width: 143px !important;
  height: 36px !important;
  min-height: 36px !important;
  max-height: 36px !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: #c7d1e3 !important;
  color: #667589 !important;
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif !important;
  font-size: 10.4px !important;
  font-weight: 400 !important;
  letter-spacing: 1.04px !important;
  line-height: 12.48px !important;
  text-align: center !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
}

/* Center the visible footer waveform bars inside their already-centered track. */
.song-player .song-player-wave-bars {
  justify-content: center !important;
}

/* Events page buttons share the requested solid palette. */
body main.events-redesign .event-button {
  background-color: #c7d1e3 !important;
  border-color: #c7d1e3 !important;
  color: #667589 !important;
}

body main.events-redesign .event-button:hover,
body main.events-redesign .event-button:focus-visible {
  background-color: #b9c5d9 !important;
  border-color: #b9c5d9 !important;
  color: #667589 !important;
}

html body main.events-redesign .event-button.event-button.event-button {
  background-color: #c7d1e3 !important;
  border-color: #c7d1e3 !important;
  color: #667589 !important;
}

html body main.events-redesign .event-button.event-button.event-button:hover,
html body main.events-redesign .event-button.event-button.event-button:focus-visible {
  background-color: #b9c5d9 !important;
  border-color: #b9c5d9 !important;
  color: #667589 !important;
}

.weddings-redesign .wedding-collection-link {
  display: inline-block;
  margin-top: 12px;
  color: #667589;
  font-family: Montserrat, "Avenir Next", "Helvetica Neue", sans-serif;
  font-size: 11px;
  font-weight: 400;
  letter-spacing: .14em;
  line-height: 1.5;
  text-transform: uppercase;
}

.weddings-redesign .wedding-collection-link:hover,
.weddings-redesign .wedding-collection-link:focus-visible {
  color: #8f98ac;
}

/* Mobile homepage playback and spacing fixes. */
.home-page .home-hero,
.home-page .hero-video {
  opacity: 1;
  filter: none;
  mix-blend-mode: normal;
}

.home-page .hero-video {
  display: block;
  background: var(--charcoal);
  pointer-events: none;
}

.home-page .hero-video::-webkit-media-controls,
.home-page .hero-video::-webkit-media-controls-enclosure,
.home-page .hero-video::-webkit-media-controls-panel,
.home-page .hero-video::-webkit-media-controls-overlay-play-button,
.home-page .hero-video::-webkit-media-controls-start-playback-button {
  display: none !important;
  -webkit-appearance: none;
}

@media (max-width: 640px) {
  .home-page .site-header {
    height: 64px;
  }

  .home-page .site-header .wordmark {
    top: 14px;
  }

  .home-page .site-header .nav-toggle {
    top: 10px;
  }

  .home-page .pianist-signature {
    background: transparent;
  }
}

/* Restore the Weddings desktop editorial block and even image rhythm. */
@media (min-width: 901px) {
  .weddings-redesign .wedding-experience {
    --wedding-experience-gap: 36px;
    position: relative;
    isolation: isolate;
  }

  .weddings-redesign .wedding-experience::before {
    position: absolute !important;
    top: calc(88px + 200.21875px + 88px) !important;
    right: 50% !important;
    bottom: 0 !important;
    left: auto !important;
    z-index: -1 !important;
    display: block !important;
    width: 100vw !important;
    background: #f6f3ed !important;
    content: "" !important;
    transform: translateX(50%) !important;
  }

  .weddings-redesign .wedding-experience-row::before {
    display: none !important;
    content: none !important;
  }

  .weddings-redesign .wedding-experience-row,
  .weddings-redesign .wedding-experience > .wedding-experience-row:first-of-type,
  .weddings-redesign .wedding-experience-row + .wedding-experience-row {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }

  .weddings-redesign .wedding-experience-row + .wedding-experience-row {
    margin-top: var(--wedding-experience-gap) !important;
  }

  .weddings-redesign .wedding-experience-row {
    align-items: start !important;
  }

  .weddings-redesign .wedding-row-copy {
    box-sizing: border-box;
    padding-top: 0;
  }

  .weddings-redesign .wedding-experience > .wedding-experience-row:first-of-type .wedding-row-copy {
    padding-top: 0;
  }

  .weddings-redesign .wedding-row-reverse .wedding-row-placeholder {
    transform: translate(3px, -19.76171875px) !important;
  }
}

@media (min-width: 641px) {
  main.events-redesign .event-corporate-player .song-collection-player-controls button:not(.song-collection-main-play) {
    width: 40px !important;
    min-width: 40px !important;
    height: 40px !important;
    min-height: 40px !important;
    font-size: 25px !important;
    line-height: 1 !important;
  }

  main.events-redesign .event-corporate-player .song-collection-player-controls {
    gap: 5px !important;
  }
}

@media (min-width: 641px) {
  .home-page .moses-style-artist .artist-image {
    height: 482px;
    aspect-ratio: auto;
  }

  .home-page .moses-style-artist .artist-image img {
    object-position: center center;
  }

  .home-page .moses-style-artist .artist-copy .learn-more {
    margin-top: 28px;
  }
}

@media (min-width: 981px) {
  .about-editorial-redesign .about-hero-redesign {
    position: relative;
    isolation: isolate;
  }

  .about-editorial-redesign .about-hero-redesign::before {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 50%;
    z-index: -1;
    width: 100vw;
    height: auto;
    background: #f6f3ed;
    content: "";
    transform: translateX(-50%);
  }

  .about-editorial-redesign .about-hero-placeholder {
    height: 515px;
    min-height: 0;
  }

  .about-editorial-redesign .about-hero-placeholder img {
    object-position: center top;
  }

  .about-editorial-redesign .about-hero-copy {
    transform: none;
  }
}

@media (max-width: 640px) {
  .home-wedding-preview .ceremony-panel,
  .home-wedding-preview .ceremony-intro-row,
  .home-wedding-preview .ceremony-feeling,
  .home-wedding-preview .ceremony-performance,
  .home-wedding-preview .ceremony-video-title,
  .home-wedding-preview .service-tab,
  .home-wedding-preview .ceremony-intro-copy,
  .home-wedding-preview .ceremony-intro-copy p,
  .home-wedding-preview .ceremony-intro-copy .button {
    animation: none !important;
    transition: none !important;
  }

  .home-wedding-preview .is-content-fading,
  .home-wedding-preview .is-content-entering {
    opacity: 1;
  }

  .home-wedding-preview .mobile-service-title-nav,
  .home-wedding-preview .mobile-atmosphere-title-nav {
    grid-template-columns: 28px minmax(0, 1fr) 28px;
    width: 100%;
  }

  .home-wedding-preview .mobile-service-title,
  .home-wedding-preview .mobile-atmosphere-title {
    min-width: 0;
    overflow-wrap: anywhere;
  }

  .home-wedding-preview .mobile-service-title-nav button,
  .home-wedding-preview .mobile-atmosphere-title-nav button {
    width: 28px;
    min-width: 28px;
    touch-action: manipulation;
  }

  .home-wedding-preview .mobile-atmosphere-trigger {
    touch-action: manipulation;
  }

  .home-wedding-preview .ceremony-intro-copy .button {
    overflow: hidden;
    contain: paint;
    isolation: isolate;
    transition: none !important;
  }
}
