@import url("https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,400&display=swap");

.logo img {
  width: 68px;
}

.site-header-inner {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  width: 100%;
  max-width: 80rem;
  margin-left: auto;
  margin-right: auto;
  min-width: 0;
  box-sizing: border-box;
}

.home-page .site-header {
  padding-left: 0;
  padding-right: 0;
}

.home-page .site-header .site-header-inner {
  flex: 0 1 auto;
  width: 100%;
  max-width: 80rem;
  margin-left: auto;
  margin-right: auto;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
  box-sizing: border-box;
}

@media (min-width: 1024px) {
  .home-page .site-header .site-header-inner {
    padding-left: 3rem;
    padding-right: 3rem;
  }
}

.site-header .logo {
  flex-shrink: 0;
}

.site-header .nav-toggle {
  flex-shrink: 0;
}

.site-header .nav-links {
  flex-wrap: nowrap;
}

.font-serif {
  font-family: "Georgia";
}

.reveal-on-scroll {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 0.65s ease, transform 0.65s ease;
  will-change: opacity, transform;
}

.reveal-on-scroll.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
  .reveal-on-scroll {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

.site-header .nav-links a {
  font-family: "DM Sans", ui-sans-serif, system-ui, sans-serif;
  font-size: 11px;
  letter-spacing: 0.25em;
  text-transform: uppercase;
}

.site-header .nav-links .btn {
  font-size: 11px;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: white !important
}

/* Homepage navbar behavior to match the live reference:
   transparent + white UI at top, then normal colors after scrolling. */
.home-page .site-header:not(.scrolled) {
  border-color: transparent;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
}

.home-page .site-header .logo img {
  transition: filter 0.5s ease;
}

.home-page .site-header:not(.scrolled) .logo img {
  filter: brightness(0) invert(1) drop-shadow(0 1px 2px rgb(0 0 0 / 0.3));
}

.home-page .site-header.scrolled .logo img {
  filter: none;
}

.home-page .site-header:not(.scrolled) .nav-links a {
  color: rgba(255, 255, 255, 0.85);
}

.home-page .site-header:not(.scrolled) .nav-links a:hover,
.home-page .site-header:not(.scrolled) .nav-links a[aria-current="page"] {
  color: #fff;
}

.home-page .site-header:not(.scrolled) .nav-toggle {
  border-color: rgba(255, 255, 255, 0.45);
  background: rgba(0, 0, 0, 0.14);
  color: #fff;
}

.home-page .site-header:not(.scrolled) .nav-links .btn-primary {
  border: 1px solid rgba(255, 255, 255, 0.75);
  background: transparent;
  color: #fff;
}

.home-page .site-header:not(.scrolled) .nav-links .btn-primary:hover {
  background: rgba(255, 255, 255, 0.12);
  color: #fff;
  box-shadow: none;
}

/* Inner pages: full-width #faf6f0 bar; content row max 80rem + padding (no inner “card”, ref: movaadventures.onhercules.app/trails) */
body:not(.home-page) .site-header,
body:not(.home-page) .site-header.scrolled {
  box-sizing: border-box;
  left: 0;
  right: 0;
  transform: none;
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
  justify-content: center;
  border-color: var(--color-mova-border);
  background: #faf6f0;
  box-shadow: 0 1px 3px rgb(0 0 0 / 0.06);
  backdrop-filter: none;
}

body:not(.home-page) .site-header.scrolled {
  box-shadow: 0 1px 3px rgb(0 0 0 / 0.08);
}

body:not(.home-page) .site-header .site-header-inner {
  flex: 0 1 auto;
  padding: 1rem 3rem;
  background: transparent;
  border: none;
  border-radius: 0;
  box-shadow: none;
}

body:not(.home-page) .site-header .logo {
  color: var(--color-mova-ink, #201914);
}

body:not(.home-page) .site-header .logo span {
  color: var(--color-mova-accent, #9d521a);
}

body:not(.home-page) .site-header .nav-links a,
body:not(.home-page) .site-header .nav-toggle {
  color: var(--color-mova-muted, #6f6258);
}

body:not(.home-page) .site-header .nav-links a:hover,
body:not(.home-page) .site-header .nav-links a[aria-current="page"] {
  color: var(--color-mova-ink, #201914);
}

body:not(.home-page) .site-header .logo img {
  filter: none;
}

/* Nav: Bouldering dropdown */
.site-header .nav-dropdown {
  position: relative;
}

.site-header .nav-dropdown-trigger {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0;
  border: 0;
  background: transparent;
  font-family: "DM Sans", ui-sans-serif, system-ui, sans-serif;
  font-size: 11px;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: inherit;
  cursor: pointer;
}

.site-header .nav-dropdown-chevron {
  flex-shrink: 0;
  transition: transform 0.2s ease;
}

.site-header .nav-dropdown.is-open .nav-dropdown-chevron {
  transform: rotate(180deg);
}

.site-header .nav-dropdown-menu {
  list-style: none;
  margin: 0;
  padding: 0.35rem 0;
}

.site-header .nav-dropdown-menu a {
  display: block;
  white-space: nowrap;
}

@media (min-width: 768px) {
  .site-header .nav-dropdown-menu {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%) translateY(2px);
    min-width: 11.5rem;
    padding: 0.5rem;
    padding-top: 0.4rem;
    border: 1px solid var(--color-mova-border, rgb(32 25 20 / 0.12));
    border-radius: 0.75rem;
    background: #fffaf4;
    box-shadow: 0 12px 32px rgb(32 25 20 / 0.12);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s ease;
    z-index: 60;
  }

  /* Invisible bridge so hover isn’t lost between trigger and menu */
  .site-header .nav-dropdown-menu::before {
    content: "";
    position: absolute;
    left: -0.5rem;
    right: -0.5rem;
    top: -0.65rem;
    height: 0.65rem;
  }

  .site-header .nav-dropdown-menu a {
    padding: 0.55rem 0.85rem;
    border-radius: 0.45rem;
    font-size: 10px;
    letter-spacing: 0.2em;
  }

  .site-header .nav-dropdown:hover .nav-dropdown-menu,
  .site-header .nav-dropdown:focus-within .nav-dropdown-menu,
  .site-header .nav-dropdown.is-open .nav-dropdown-menu {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateX(-50%) translateY(0);
  }
}

@media (max-width: 767px) {
  /* Mobile menu inherits items-center from .nav-links — align pop-up links left */
  .site-header .nav-links.is-open {
    align-items: stretch;
    text-align: left;
  }

  .site-header .nav-links.is-open > a,
  .site-header .nav-links.is-open .nav-dropdown-menu a {
    text-align: left;
  }

  .site-header .nav-dropdown {
    width: 100%;
  }

  .site-header .nav-dropdown-trigger {
    width: 100%;
    justify-content: space-between;
    padding: 0.5rem 0.75rem;
    border-radius: 0.5rem;
  }

  .site-header .nav-links.is-open .nav-dropdown-trigger {
    padding: 0.5rem 0.75rem;
  }

  .site-header .nav-dropdown-menu {
    display: none;
    padding: 0.15rem 0 0.35rem 0.75rem;
  }

  .site-header .nav-dropdown.is-open .nav-dropdown-menu {
    display: block;
  }

  .site-header .nav-dropdown-menu a {
    padding: 0.45rem 0.75rem;
    border-radius: 0.45rem;
  }

  /* Transparent home header: mobile menu panel is a light surface */
  .home-page .site-header:not(.scrolled) .nav-links.is-open {
    border-color: var(--color-mova-border, rgb(32 25 20 / 0.12));
    background: #fffaf4;
    box-shadow: 0 12px 32px rgb(32 25 20 / 0.12);
  }

  .home-page .site-header:not(.scrolled) .nav-links.is-open > a,
  .home-page .site-header:not(.scrolled) .nav-links.is-open .nav-dropdown-menu a {
    color: var(--color-mova-muted, #6f6258);
  }

  .home-page .site-header:not(.scrolled) .nav-links.is-open > a:hover,
  .home-page .site-header:not(.scrolled) .nav-links.is-open > a:focus-visible,
  .home-page .site-header:not(.scrolled) .nav-links.is-open .nav-dropdown-menu a:hover,
  .home-page .site-header:not(.scrolled) .nav-links.is-open .nav-dropdown-menu a:focus-visible {
    color: var(--color-mova-ink, #201914);
  }

  .home-page .site-header:not(.scrolled) .nav-links.is-open .nav-dropdown-trigger {
    color: var(--color-mova-muted, #6f6258);
  }

  .home-page .site-header:not(.scrolled) .nav-links.is-open .nav-dropdown-trigger:hover,
  .home-page .site-header:not(.scrolled) .nav-links.is-open .nav-dropdown.is-open .nav-dropdown-trigger {
    color: var(--color-mova-ink, #201914);
  }

  .home-page .site-header:not(.scrolled) .nav-links.is-open .btn-primary {
    border-color: var(--color-mova-accent, #9d521a);
    background: var(--color-mova-accent, #9d521a);
    color: #fff;
  }

  .home-page .site-header:not(.scrolled) .nav-links.is-open .btn-primary:hover {
    background: var(--color-mova-accent, #9d521a);
    color: #fff;
    box-shadow: 0 8px 24px rgb(157 82 26 / 0.35);
  }
}

.home-page .site-header:not(.scrolled) .nav-dropdown-trigger {
  color: rgba(255, 255, 255, 0.85);
}

.home-page .site-header:not(.scrolled) .nav-dropdown-trigger:hover,
.home-page .site-header:not(.scrolled) .nav-dropdown.is-open .nav-dropdown-trigger {
  color: #fff;
}

/* Dropdown panel is a light surface — override white nav link color */
.home-page .site-header:not(.scrolled) .nav-dropdown-menu a {
  color: var(--color-mova-muted, #6f6258);
}

.home-page .site-header:not(.scrolled) .nav-dropdown-menu a:hover,
.home-page .site-header:not(.scrolled) .nav-dropdown-menu a:focus-visible {
  color: var(--color-mova-ink, #201914);
  background: rgba(32, 25, 20, 0.06);
}

body:not(.home-page) .site-header .nav-dropdown-trigger {
  color: var(--color-mova-muted, #6f6258);
}

body:not(.home-page) .site-header .nav-dropdown-trigger:hover,
body:not(.home-page) .site-header .nav-dropdown.is-open .nav-dropdown-trigger {
  color: var(--color-mova-ink, #201914);
}

.home-page .hero-reference {
  position: relative;
  min-height: 100vh;
  min-height: max(100vh, 600px);
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  padding: 0;
}

.home-page .hero-reference::before {
  content: none;
}

.home-page .hero-reference .hero-media {
  position: absolute;
  inset: 0;
  background-image: url("../assets/hero-header-mova.jpeg");
  background-position: center;
  background-size: cover;
}

.home-page .hero-reference .hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(0, 0, 0, 0.72) 0%,
    rgba(0, 0, 0, 0.22) 45%,
    rgba(0, 0, 0, 0.12) 100%
  );
}

.home-page .hero-reference .hero-content {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 80rem;
  margin: 0 auto;
  padding: 0 1.5rem 5rem;
}

.home-page .hero-reference .eyebrow {
  margin-bottom: 1.5rem;
  color: rgba(255, 255, 255, 0.62);
  letter-spacing: 0.5em;
  font-size: 0.625rem;
}

.home-page .hero-reference h1,
.home-page .hero-reference h1 em {
  font-family: 'Fraunces';
}

.home-page .hero-reference h1 {
  margin-bottom: 2rem;
  max-width: 14ch;
  color: #fff;
  font-size: clamp(3rem, 8vw, 5.75rem);
  line-height: 1.05;
  font-weight: 300;
}

.home-page .hero-reference h1 em {
  font-style: italic;
}

.home-page .hero-reference .lead {
  max-width: 32rem;
  margin-bottom: 2.5rem;
  color: rgba(255, 255, 255, 0.76);
  font-weight: 300;
}

.home-page .hero-reference .hero-actions {
  gap: 1rem;
}

.home-page .hero-reference .btn {
  border-radius: 0;
  padding: 0.875rem 2rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  font-size: 0.69rem;
}

.home-page .hero-reference .btn-hero-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255, 255, 255, 0.5);
  color: #fff;
  text-decoration: none;
  transition: background-color 0.2s ease;
}

.home-page .hero-reference .btn-hero-outline:hover {
  background: rgba(255, 255, 255, 0.1);
  color: #fff;
}

.home-page .hero-reference .hero-scroll {
  position: absolute;
  right: 3rem;
  bottom: 2rem;
  z-index: 1;
  display: none;
  align-items: center;
  gap: 0.5rem;
  flex-direction: column;
}

.home-page .hero-reference .hero-scroll-line {
  width: 1px;
  height: 3rem;
  background: rgba(255, 255, 255, 0.4);
}

.home-page .hero-reference .hero-scroll span {
  color: rgba(255, 255, 255, 0.55);
  font-size: 0.56rem;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  transform: rotate(90deg) translateY(1rem);
  transform-origin: center;
}

@media (min-width: 768px) {
  .home-page .hero-reference .hero-content {
    padding-bottom: 7rem;
  }

  .home-page .hero-reference .hero-scroll {
    display: flex;
  }
}

@media (min-width: 1024px) {
  .home-page .hero-reference .hero-content {
    padding-left: 3rem;
    padding-right: 3rem;
  }
}

.home-page #experience {
  max-width: 56rem;
  margin: 0 auto;
  padding: 6rem 1.5rem;
  text-align: center;
}

.home-page #about-us {
  max-width: 80rem;
  margin: 0 auto;
  padding: 6rem 1.5rem 0;
  text-align: center;
}

.home-page #experience .experience-intro {
  max-width: 56rem;
  margin: 0 auto;
}

.home-page #about-us .experience-intro {
  max-width: 80rem;
  margin: 0 auto;
}

.home-page #experience .experience-rule,
.home-page #about-us .experience-rule {
  width: 3rem;
  height: 1px;
  margin: 0 auto 2.5rem;
  background: var(--color-mova-accent);
}

.home-page #experience .experience-intro .label,
.home-page #about-us .experience-intro .label {
  margin-bottom: 1.5rem;
  font-size: 0.625rem;
  letter-spacing: 0.45em;
  text-transform: uppercase;
}

.home-page #experience .experience-intro h2,
.home-page #about-us .experience-intro h2 {
  margin-bottom: 2rem;
  font-family: "Georgia";
  font-size: clamp(2.25rem, 6vw, 3rem);
  line-height: 1.2;
  font-weight: 500;
}

.home-page #experience .experience-intro h2 em,
.home-page #about-us .experience-intro h2 em {
  font-style: italic;
}

.home-page #experience .experience-intro p {
  margin: 0 auto;
  max-width: 42rem;
  color: var(--color-mova-muted);
  font-size: 1.125rem;
  font-weight: 300;
  line-height: 1.625;
}

.home-page #about-us .experience-intro p {
  margin: 0 auto;
  max-width: 56rem;
  color: var(--color-mova-muted);
  font-size: 1.125rem;
  font-weight: 300;
  line-height: 1.625;
}

.home-page #experience .experience-intro p + p,
.home-page #about-us .experience-intro p + p {
  margin-top: 1.5rem;
}

.home-page #about-us .about-intro-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  margin-top: 2rem;
  border: 1px solid var(--color-mova-accent);
  background: var(--color-mova-accent);
  padding: 0.875rem 2rem;
  color: #fff;
  text-decoration: none;
  font-size: 0.6875rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.home-page #about-us .about-intro-btn:hover {
  border-color: rgb(138 72 22);
  background: rgb(138 72 22);
  color: #fff;
}

.home-page #experience .experience-intro .experience-rule:last-child,
.home-page #about-us .experience-intro .experience-rule:last-child {
  margin-top: 2.5rem;
  margin-bottom: 0;
}

.home-page .stats-band {
  border-top: 1px solid #ddd6cd;
  border-bottom: 1px solid #ddd6cd;
}

.home-page .stats-band-inner {
  max-width: 80rem;
  margin: 0 auto;
  padding: 0 1.5rem;
}

.home-page .stats-band .stats {
  margin: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0;
}

@media (max-width: 767px) {
  .home-page .stats-band .stat:nth-child(5) {
    grid-column: 1 / -1;
    border-right: 0;
    border-top: 1px solid #ddd6cd;
    text-align: center;
  }
}

.home-page .stats-band .stat {
  border: 0;
  border-radius: 0;
  background: transparent;
  padding: 2.5rem 2rem;
}

.home-page .stats-band .stat:nth-child(odd) {
  border-right: 1px solid #ddd6cd;
}


.home-page .stats-band .stat strong {
  margin-bottom: 0.5rem;
  font-family: "Georgia";
  font-size: clamp(2.25rem, 5vw, 3rem);
  font-weight: 300;
}

.home-page .stats-band .stat span {
  font-size: 0.625rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
}

@media (min-width: 768px) {
  .home-page #experience {
    padding-top: 8rem;
    padding-bottom: 8rem;
  }

  .home-page #about-us {
    padding-top: 8rem;
    padding-bottom: 0;
  }

  .home-page .stats-band .stats {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }

  .home-page .stats-band .stat {
    border-bottom: 0;
  }

  .home-page .stats-band .stat:not(:last-child) {
    border-right: 1px solid #ddd6cd;
  }
}

@media (min-width: 1024px) {
  .home-page #experience {
    padding-left: 3rem;
    padding-right: 3rem;
  }

  .home-page #about-us {
    padding-left: 3rem;
    padding-right: 3rem;
  }

  .home-page .stats-band-inner {
    padding-left: 3rem;
    padding-right: 3rem;
  }
}

.home-page #offer {
  max-width: 80rem;
  margin: 0 auto;
  padding: 6rem 1.5rem;
}

.home-page #offer .offer-intro {
  margin-bottom: 4rem;
}

.home-page #offer .offer-intro .label {
  margin-bottom: 1rem;
  font-size: 0.625rem;
  letter-spacing: 0.45em;
  text-transform: uppercase;
}

.home-page #offer .offer-intro h2 {
  font-family: "Georgia";
  font-size: clamp(2.25rem, 6vw, 3rem);
  line-height: 1.2;
  font-weight: 300;
}

.home-page #offer .offer-intro h2 em {
  font-style: italic;
}

.home-page #offer .offer-grid {
  display: grid;
  gap: 1.5rem;
}

.home-page #offer .offer-link {
  display: block;
  color: inherit;
  text-decoration: none;
}

.home-page #offer .offer-media {
  position: relative;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  margin-bottom: 1.5rem;
}

.home-page #offer .offer-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.7s ease;
}

.home-page #offer .offer-media-placeholder {
  background: linear-gradient(135deg, rgba(167, 126, 77, 0.18), rgba(27, 29, 20, 0.82));
}

.home-page #offer .offer-placeholder {
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.75rem;
  letter-spacing: 0.35em;
  text-transform: uppercase;
 }

.home-page #offer .offer-media-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.12);
  transition: background-color 0.5s ease;
}

.home-page #offer .offer-icon {
  position: absolute;
  left: 1.25rem;
  bottom: 1.25rem;
  color: #fff;
  font-size: 1.25rem;
  line-height: 1;
}

.home-page #offer .offer-link:hover .offer-media img {
  transform: scale(1.05);
}

.home-page #offer .offer-link:hover .offer-media-overlay {
  background: rgba(0, 0, 0, 0.2);
}

.home-page #offer .offer-meta {
  margin-bottom: 0.25rem;
  color: var(--color-mova-muted);
  font-size: 0.625rem;
  letter-spacing: 0.4em;
  text-transform: uppercase;
}

.home-page #offer .offer-item h3 {
  margin-bottom: 0.75rem;
  font-family: "Georgia";
  color: var(--color-mova-ink);
  font-size: 2rem;
  font-weight: 300;
  transition: color 0.3s ease;
}

.home-page #offer .offer-link:hover h3 {
  color: var(--color-mova-accent);
}

.home-page #offer .offer-desc {
  margin-bottom: 1rem;
  color: var(--color-mova-muted);
  font-size: 0.875rem;
  line-height: 1.625;
  font-weight: 300;
}

.home-page #offer .offer-cta {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--color-mova-accent);
  font-size: 0.625rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
}

@media (min-width: 768px) {
  .home-page #offer {
    padding-top: 8rem;
    padding-bottom: 8rem;
  }

  .home-page #offer .offer-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (min-width: 1024px) {
  .home-page #offer {
    padding-left: 3rem;
    padding-right: 3rem;
  }
}

.home-page .feature-highlight {
  position: relative;
  height: 70vh;
  min-height: 400px;
  display: flex;
  align-items: center;
  overflow: hidden;
}

.home-page .feature-highlight .feature-highlight-media {
  position: absolute;
  inset: 0;
  background-image: url("../assets/stars.jpg");
  background-position: center;
  background-size: cover;
}

.home-page .feature-highlight .feature-highlight-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
}

.home-page .feature-highlight .feature-highlight-inner {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 80rem;
  margin: 0 auto;
  padding: 5% 1.5rem;
}

.home-page .feature-highlight .feature-highlight-content {
  max-width: 32rem;
}

.home-page .feature-highlight .feature-kicker {
  margin-bottom: 1.25rem;
  color: rgba(255, 255, 255, 0.5);
  font-size: 0.625rem;
  letter-spacing: 0.45em;
  text-transform: uppercase;
}

.home-page .feature-highlight h2 {
  margin-bottom: 1.5rem;
  color: #fff;
  font-family: "Georgia";
  font-size: clamp(2.25rem, 6vw, 3rem);
  line-height: 1.15;
  font-weight: 300;
}

.home-page .feature-highlight h2 em {
  font-style: italic;
}

.home-page .feature-highlight p {
  margin-bottom: 2rem;
  max-width: 24rem;
  color: rgba(255, 255, 255, 0.72);
  font-size: 1rem;
  line-height: 1.625;
  font-weight: 300;
}

.home-page .feature-highlight .feature-outline-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  border: 1px solid rgba(255, 255, 255, 0.5);
  padding: 0.875rem 2rem;
  color: #fff;
  text-decoration: none;
  font-size: 0.6875rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  transition: background-color 0.2s ease;
}

.home-page .feature-highlight .feature-outline-btn:hover {
  background: rgba(255, 255, 255, 0.1);
  color: #fff;
}

@media (min-width: 1024px) {
  .home-page .feature-highlight .feature-highlight-inner {
    padding: 5% 3rem;
  }
}

.home-page .visit-cta {
  max-width: 56rem;
  margin: 0 auto;
  padding: 6rem 1.5rem;
  text-align: center;
}

.home-page .visit-cta .visit-cta-rule {
  width: 3rem;
  height: 1px;
  margin: 0 auto 2.5rem;
  background: var(--color-mova-accent);
}

.home-page .visit-cta .visit-cta-kicker {
  margin-bottom: 1.5rem;
  color: var(--color-mova-muted);
  font-size: 0.625rem;
  letter-spacing: 0.45em;
  text-transform: uppercase;
}

.home-page .visit-cta h2 {
  margin-bottom: 2rem;
  color: var(--color-mova-ink);
  font-family: "Georgia";
  font-size: clamp(2.25rem, 6vw, 3rem);
  line-height: 1.2;
  font-weight: 300;
}

.home-page .visit-cta p {
  margin: 0 auto 2.5rem;
  max-width: 32rem;
  color: var(--color-mova-muted);
  font-size: 1rem;
  line-height: 1.625;
  font-weight: 300;
}

.home-page .visit-cta .visit-cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  border: 0;
  background: var(--color-mova-accent);
  padding: 1rem 2.5rem;
  color: #fff;
  text-decoration: none;
  font-size: 0.6875rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  transition: background-color 0.2s ease;
}

.home-page .visit-cta .visit-cta-btn:hover {
  background: var(--color-mova-sand);
  color: #fff;
}

@media (min-width: 768px) {
  .home-page .visit-cta {
    padding-top: 8rem;
    padding-bottom: 8rem;
  }
}

@media (min-width: 1024px) {
  .home-page .visit-cta {
    padding-left: 3rem;
    padding-right: 3rem;
  }
}

.site-footer {
  background: var(--color-mova-ink);
  color: var(--color-mova-deep);
  border-top: 0;
  padding: 0;
  text-align: left;
}

.site-footer .site-footer-inner {
  max-width: 80rem;
  margin: 0 auto;
  padding: 4rem 1.5rem;
}

.site-footer .site-footer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  margin-bottom: 4rem;
}

.site-footer .site-footer-logo {
  width: auto;
  height: 4rem;
  margin-bottom: 1rem;
  filter: brightness(0) invert(1);
}

.site-footer .site-footer-copy {
  max-width: 20rem;
  margin: 0;
  color: rgba(250, 246, 240, 0.7);
  font-size: 0.875rem;
  line-height: 1.625;
  font-weight: 300;
}

.site-footer .site-footer-heading {
  margin-bottom: 1.5rem;
  color: rgba(250, 246, 240, 0.5);
  font-size: 0.625rem;
  letter-spacing: 0.35em;
  text-transform: uppercase;
}

.site-footer .site-footer-nav,
.site-footer .site-footer-contact {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.site-footer .site-footer-nav a,
.site-footer .site-footer-contact a,
.site-footer .site-footer-contact p,
.site-footer a.site-footer-contact-link {
  color: rgba(250, 246, 240, 0.7);
  font-size: 0.875rem;
  line-height: 1.45;
  font-weight: 300;
  text-decoration: none;
  margin: 0;
}

.site-footer .site-footer-contact-row,
.site-footer a.site-footer-contact-link {
  display: flex;
  gap: 0.75rem;
}

.site-footer .site-footer-contact-row {
  align-items: flex-start;
}

.site-footer a.site-footer-contact-link {
  align-items: center;
}

.site-footer .site-footer-icon {
  color: #9d521a;
  flex-shrink: 0;
}

.site-footer .site-footer-icon--pin {
  margin-top: 0.125rem;
}

.site-footer .site-footer-at {
  color: #9d521a;
  font-size: 0.75rem;
  flex-shrink: 0;
}

.site-footer .site-footer-nav a:hover,
.site-footer .site-footer-contact a:hover,
.site-footer a.site-footer-contact-link:hover {
  color: var(--color-mova-deep);
}

.site-footer .site-footer-bottom {
  border-top: 1px solid rgba(250, 246, 240, 0.1);
  padding-top: 2rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  align-items: center;
  justify-content: space-between;
}

.site-footer .site-footer-bottom p {
  margin: 0;
  color: rgba(250, 246, 240, 0.4);
  font-size: 0.625rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  text-align: center;
}

.site-footer .site-footer-bottom p:last-child {
  letter-spacing: 0.2em;
}

@media (min-width: 768px) {
  .site-footer .site-footer-inner {
    padding-top: 5rem;
    padding-bottom: 5rem;
  }

  .site-footer .site-footer-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .site-footer .site-footer-bottom {
    flex-direction: row;
  }

  .site-footer .site-footer-bottom p {
    text-align: left;
  }
}

@media (min-width: 1024px) {
  .site-footer .site-footer-inner {
    padding-left: 3rem;
    padding-right: 3rem;
  }
}

.trails-page .trails-hero {
  position: relative;
  height: 55vh;
  min-height: 380px;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}

.trails-page .trails-hero-media {
  position: absolute;
  inset: 0;
  background-image: url("../assets/hero-header-mova.jpeg");
  background-position: center;
  background-size: cover;
}

.trails-page .trails-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.65), rgba(0, 0, 0, 0.2), transparent);
}

.trails-page .trails-hero-inner {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 80rem;
  margin: 0 auto;
  padding: 0 1.5rem 3.5rem;
}

.trails-page .trails-hero-kicker {
  margin-bottom: 1rem;
  color: rgba(255, 255, 255, 0.6);
  font-size: 0.625rem;
  letter-spacing: 0.5em;
  text-transform: uppercase;
}

.trails-page .trails-hero h1 {
  color: #fff;
  font-family: "Georgia";
  font-size: clamp(3rem, 7vw, 4.25rem);
  font-weight: 300;
  line-height: 1.1;
}

.trails-page .trails-intro {
  max-width: 48rem;
  margin: 0 auto;
  padding: 5rem 1.5rem;
  text-align: center;
}

.trails-page .trails-intro-rule {
  width: 2.5rem;
  height: 1px;
  background: var(--color-mova-accent);
  margin: 0 auto 2rem;
}

.trails-page .trails-intro h2 {
  margin-bottom: 1.5rem;
  font-family: "Georgia";
  font-size: clamp(2rem, 5vw, 2.75rem);
  font-weight: 300;
}

.trails-page .trails-intro h2 em {
  font-style: italic;
}

.trails-page .trails-intro p {
  color: var(--color-mova-muted);
  font-weight: 300;
  line-height: 1.65;
}

.trails-page .trails-intro-cta {
  margin-top: 1.75rem;
}

.trails-page .trails-main {
  max-width: 80rem;
  margin: 0 auto;
  padding: 0 1.5rem 6rem;
}

.trails-page .trails-main-grid {
  display: grid;
  gap: 2rem;
}

.trails-page .trails-route-panel {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.trails-page .trails-route-card {
  border: 1px solid var(--color-mova-border);
  background: rgb(237 227 214);
  padding: 1.5rem;
}

.trails-page .trails-tag {
  display: inline-block;
  margin-bottom: 0.5rem;
  padding: 0.3rem 0.55rem;
  background: rgba(157, 82, 26, 0.13);
  color: var(--color-mova-accent);
  font-size: 0.5625rem;
  letter-spacing: 0.35em;
  text-transform: uppercase;
}

.trails-page .trails-route-card h3 {
  font-family: "Georgia";
  font-size: 2rem;
  font-weight: 300;
}

.trails-page .trails-route-card#skeleton-gorge-on-trails h3,
.trails-page .trails-route-card#echo-valley-on-trails h3 {
  font-family: "Georgia";
  font-size: 1.5rem;
  font-weight: 300;
  line-height: 32px;
}

.trails-page .trails-route-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
}

.trails-page .trails-route-icon {
  margin-top: 0.25rem;
  flex-shrink: 0;
  color: var(--color-mova-muted);
}

.trails-page .trails-route-meta {
  display: flex;
  gap: 1.25rem;
  margin: 1rem 0;
  color: var(--color-mova-muted);
  font-size: 0.75rem;
}

.trails-page .trails-route-meta span {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}

.trails-page .trails-route-card p {
  color: var(--color-mova-muted);
  font-size: 0.92rem;
  line-height: 1.65;
}

.trails-page .trails-route-card ul.trails-highlights {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  margin-top: 1rem;
  margin-bottom: 1rem;
  padding: 0;
  list-style: none;
}

.trails-page .trails-route-card ul.trails-highlights li {
  display: block;
  position: relative;
  padding-left: 0.85rem;
  font-size: 0.95rem;
  font-weight: 300;
  line-height: 1.45;
  color: var(--color-mova-muted);
}

.trails-page .trails-route-card ul.trails-highlights li .trails-highlight-dot {
  position: absolute;
  left: 0;
  top: 0.42em;
}

.trails-page .trails-route-card ul.trails-highlights li strong {
  font-weight: 500;
  color: var(--color-mova-ink, #201914);
}

.trails-page .trails-highlight-dot {
  width: 0.25rem;
  height: 0.25rem;
  border-radius: 9999px;
  flex-shrink: 0;
  background-color: rgb(201, 124, 58);
}

.trails-page .trails-map-hint {
  margin-top: 1rem;
  font-size: 0.625rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.trails-page .trails-route-card .trails-map-hint {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  margin-top: 1rem;
  font-size: 0.92rem;
  font-weight: 300;
  line-height: 1.65;
  letter-spacing: normal;
  text-transform: none;
  color: var(--color-mova-muted);
}

.trails-page .trails-route-card .trails-map-hint svg {
  flex-shrink: 0;
}

.trails-page .trails-map-expand-trigger {
  border: 0;
  padding: 0;
  background: transparent;
  cursor: pointer;
}

.trails-page .trails-map {
  position: relative;
  height: 500px;
  min-height: 450px;
  border-radius: 0.125rem;
  overflow: hidden;
  z-index: 0;
}

.trails-page .trails-map-label {
  position: absolute;
  top: 1rem;
  left: 1rem;
  z-index: 1;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.25rem;
  border: 1px solid var(--color-mova-border);
  background: rgba(255, 250, 244, 0.9);
  backdrop-filter: blur(4px);
  padding: 0.6rem 0.9rem;
  font-size: 0.5625rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--color-mova-muted);
}

.trails-page .trails-map-label span {
  color: var(--color-mova-accent);
}

.trails-page .trails-route-leaflet-map {
  width: 100%;
  height: 100%;
  min-height: 240px;
}

.trails-page .trails-map-column--skeleton,
.trails-page .trails-map-column--echo {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.trails-page .trails-map-label .trails-map-expand-trigger {
  margin-left: 0.5rem;
  padding: 0 0.35rem;
  border: 0;
  background: transparent;
  font-size: 1rem;
  line-height: 1;
  color: var(--color-mova-accent);
  cursor: pointer;
  vertical-align: middle;
}

.trails-page .trails-map--single {
  height: 300px;
  min-height: 280px;
}

.trails-page .trails-map-legend {
  position: absolute;
  right: 1rem;
  bottom: 1rem;
  z-index: 1;
  margin: 0;
  padding: 0.65rem 0.85rem;
  list-style: none;
  border: 1px solid var(--color-mova-border);
  background: rgba(255, 250, 244, 0.92);
  backdrop-filter: blur(4px);
  font-size: 0.625rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-mova-muted);
}

.trails-page .trails-map-legend li {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  margin: 0.2rem 0;
}

.trails-page .trails-map-legend-swatch {
  flex-shrink: 0;
  width: 1.1rem;
  height: 0.2rem;
  border-radius: 1px;
  background: var(--trail-color, var(--color-mova-accent));
}

.trails-page .trails-map--error::before {
  content: "Map could not load trail data.";
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  text-align: center;
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-mova-muted);
  background: rgba(255, 250, 244, 0.9);
}

.trails-page .trails-route-leaflet-map .leaflet-control-attribution {
  font-size: 0.625rem;
}

.trails-page .trails-map-modal[hidden] {
  display: none;
}

.trails-page .trails-map-modal {
  position: fixed;
  inset: 0;
  z-index: 1100;
}

.trails-page .trails-map-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(10, 8, 6, 0.65);
}

.trails-page .trails-map-modal-dialog {
  position: relative;
  z-index: 1;
  width: min(94vw, 1120px);
  margin: 4vh auto;
  height: min(88vh, 900px);
  background: #111;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 0.35rem;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.trails-page .trails-map-modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem 1rem;
  background: rgba(20, 20, 20, 0.9);
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

.trails-page .trails-map-modal-title {
  margin: 0;
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.85);
}

.trails-page .trails-map-modal-close {
  border: 0;
  padding: 0.1rem 0.4rem;
  background: transparent;
  color: rgba(255, 255, 255, 0.9);
  font-size: 1.75rem;
  line-height: 1;
  cursor: pointer;
}

.trails-page #trails-leaflet-map-expanded {
  flex: 1;
  width: 100%;
  min-height: 420px;
}

.trails-page #trails-leaflet-map-expanded .leaflet-control-attribution {
  font-size: 0.625rem;
}

.trails-page .trails-checklist {
  border-top: 1px solid var(--color-mova-border);
  padding: 4rem 0 5rem;
}

.trails-page .trails-checklist-inner {
  max-width: 80rem;
  margin: 0 auto;
  padding: 0 1.5rem;
}

.trails-page .trails-checklist-kicker {
  margin-bottom: 2.5rem;
  font-size: 0.625rem;
  letter-spacing: 0.45em;
  text-transform: uppercase;
  color: var(--color-mova-muted);
}

.trails-page .trails-checklist-grid {
  display: grid;
  gap: 2rem;
}

.trails-page .trails-checklist h4 {
  margin-bottom: 1rem;
  font-family: "Georgia";
  font-size: 1.5rem;
  font-weight: 300;
}

.trails-page .trails-checklist ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 0.5rem;
}

.trails-page .trails-checklist li {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  color: var(--color-mova-muted);
  font-size: 0.975rem;
  font-weight: 300;
  line-height: 1.45;
}

.trails-page .trails-checklist .trails-li-dot {
  width: 0.25rem;
  height: 0.25rem;
  margin-top: 0.5rem;
  border-radius: 9999px;
  background-color: #9d521a;
  flex-shrink: 0;
}

.trails-page .trails-checklist.trails-checklist--longform {
  padding: 2.5rem 0 2.75rem;
}

.trails-page .trails-intro.trails-nima-gateway {
  max-width: none;
  border-top: 1px solid var(--color-mova-border);
  padding: 5rem 1.5rem 3rem;
  text-align: left;
}

.trails-page .trails-nima-gateway-inner {
  display: grid;
  gap: 2.5rem;
  align-items: center;
  max-width: 80rem;
  margin: 0 auto;
}

.trails-page .trails-nima-gateway .trails-intro-rule {
  margin: 0 0 2rem;
}

.trails-page .trails-nima-gateway-copy h2 {
  text-align: left;
}

.trails-page .trails-nima-gateway-media img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  display: block;
}

@media (min-width: 768px) {
  .trails-page .trails-nima-gateway-inner {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 3rem;
  }
}

@media (min-width: 1024px) {
  .trails-page .trails-intro.trails-nima-gateway {
    padding-left: 3rem;
    padding-right: 3rem;
  }
}

.trails-page .trails-intro.trails-waypoints-intro {
  border-top: 1px solid var(--color-mova-border);
  padding-bottom: 2.5rem;
}

.trails-page .trails-waypoints {
  padding: 0 1.5rem 2rem;
}

.trails-page .trails-waypoints-inner {
  max-width: 80rem;
  margin: 0 auto;
}

.trails-page .trails-waypoints-inner > p.trails-longform-waypoint-kicker:first-child {
  padding-top: 0;
}

@media (min-width: 1024px) {
  .trails-page .trails-intro.trails-waypoints-intro {
    padding-left: 3rem;
    padding-right: 3rem;
  }

  .trails-page .trails-waypoints {
    padding-left: 3rem;
    padding-right: 3rem;
  }
}

.trails-page .trails-checklist-lede {
  margin: -0.5rem 0 2.25rem;
  font-family: "DM Sans", ui-sans-serif, system-ui, sans-serif;
  font-size: 0.9375rem;
  font-weight: 300;
  line-height: 1.65;
  color: var(--color-mova-muted);
  padding-bottom: 5%;
}

.trails-page .trails-longform-inner .trails-checklist-inner {
  max-width: none;
  padding-left: 0;
  padding-right: 0;
}

@media (min-width: 768px) {
  .trails-page .trails-intro {
    padding-top: 5.5rem;
    padding-bottom: 5.5rem;
  }

  .trails-page .trails-intro.trails-nima-gateway {
    padding-bottom: 3.5rem;
  }

  .trails-page .trails-checklist {
    padding-top: 5rem;
    padding-bottom: 5rem;
  }

  .trails-page .trails-checklist-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .trails-page .trails-checklist.trails-checklist--longform {
    padding-top: 3rem;
    padding-bottom: 3.25rem;
  }

  .trails-page .trails-checklist-grid--quad {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1024px) {
  .trails-page .trails-hero-inner,
  .trails-page .trails-main,
  .trails-page .trails-checklist-inner {
    padding-left: 3rem;
    padding-right: 3rem;
  }

  .trails-page .trails-main-grid,
  .trails-page .trails-longform-trails-guide-row {
    grid-template-columns: 2fr 3fr;
  }

  .trails-page .trails-map:not(.trails-map--single) {
    height: auto;
  }

  .trails-page .trails-map-column--skeleton,
  .trails-page .trails-map-column--echo {
    gap: 1.25rem;
  }

  .trails-page .trails-map--single {
    height: 320px;
  }

  .trails-page .trails-longform-inner {
    padding-left: 3rem;
    padding-right: 3rem;
  }

  .trails-page .trails-checklist-grid--quad {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

/* —— Trails page · long-form trail story (Fraunces + DM Sans, route-card palette) —— */

.trails-page .trails-longform {
  border-top: 1px solid var(--color-mova-border);
  background: var(--color-mova-deep, #faf6f0);
  padding: clamp(3.5rem, 8vw, 5.5rem) 0 clamp(4rem, 9vw, 6rem);
}

/* If scroll-reveal ever targets these sections, do not hide them (tall blocks rarely hit IO threshold). */
.trails-page .trails-longform.reveal-on-scroll,
.trails-page .trails-waypoints.reveal-on-scroll {
  opacity: 1;
  transform: none;
}

.trails-page .trails-longform-inner {
  max-width: 80rem;
  margin: 0 auto;
  padding: 0 1.5rem;
}

.trails-page .trails-longform-rule {
  width: 2.5rem;
  height: 1px;
  margin: 0 auto 1.75rem;
  background: var(--color-mova-accent);
}

.trails-page .trails-longform-banner {
  position: relative;
  width: 100%;
  min-height: clamp(220px, 36vw, 360px);
  margin: 0 0 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  background-image: linear-gradient(
      to top,
      rgb(0 0 0 / 0.55) 0%,
      rgb(0 0 0 / 0.35) 50%,
      rgb(0 0 0 / 0.42) 100%
    ),
    url("../assets/mountains.jpg");
  background-size: cover;
  background-position: center;
}

.trails-page .trails-longform-banner h2 {
  margin: 0;
  padding: 0 1.25rem;
  font-family: "Georgia";
  font-size: clamp(2rem, 5vw, 2.75rem);
  font-weight: 300;
  line-height: 1.12;
  color: #fff;
}

.trails-page .trails-longform-inner > .trails-longform-route-hero {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100vw;
  max-width: 100vw;
  margin: clamp(1.75rem, 4vw, 2.5rem) calc(50% - 50vw);
  min-height: clamp(200px, 38vw, 400px);
  padding: clamp(2rem, 6vw, 3.5rem) 1.5rem;
  text-align: center;
  background-color: rgb(32 25 20);
  background-image: linear-gradient(
      to top,
      rgb(0 0 0 / 0.55) 0%,
      rgb(0 0 0 / 0.35) 50%,
      rgb(0 0 0 / 0.42) 100%
    ),
    url("../assets/mountains.jpg");
  background-size: cover, cover;
  background-position: center, center;
  background-repeat: no-repeat, no-repeat;
}

.trails-page .trails-longform-route-hero-title {
  position: relative;
  z-index: 1;
  margin: 0;
  max-width: min(36rem, 92vw);
  padding: 0 0.5rem;
  font-family: Georgia, ui-serif, serif;
  font-size: clamp(1.65rem, 4.5vw, 2.65rem);
  font-weight: 300;
  line-height: 1.18;
  letter-spacing: 0.02em;
  color: #fff;
  text-shadow: 0 2px 28px rgb(0 0 0 / 0.55), 0 1px 2px rgb(0 0 0 / 0.35);
}

.trails-page .trails-longform-inner > .trails-longform-route-hero + p {
  padding-top: 5%;
}

.trails-page .trails-longform-inner p {
  margin: 0;
  font-family: "DM Sans", ui-sans-serif, system-ui, sans-serif;
  font-size: 1.125rem;
  font-weight: 300;
  line-height: 1.65;
  color: var(--color-mova-muted);
}

.trails-page .trails-longform-inner p > span {
  color: inherit;
}

.trails-page .trails-longform-inner p > strong {
  font-weight: 500;
  color: var(--color-mova-ink, #201914);
}

.trails-page .trails-longform-inner p:has(> strong:only-child > span:only-child):not(.trails-longform-hero-title) {
  margin-top: 2.5rem;
  margin-bottom: 0.85rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid rgb(157 82 26 / 0.2);
  font-family: "Fraunces", "Georgia", ui-serif, serif;
  font-size: clamp(1.2rem, 2.5vw, 1.5rem);
  font-weight: 400;
  line-height: 1.28;
  letter-spacing: -0.015em;
  color: var(--color-mova-ink, #201914);
}

.trails-page .trails-longform-inner p:has(> strong:only-child > span:only-child):not(.trails-longform-hero-title) strong {
  font-weight: 400;
}

.trails-page .trails-longform-inner p:has(> strong:only-child > span:only-child):not(.trails-longform-hero-title) + p {
  margin-top: 0;
}

.trails-page .trails-longform-story-intro {
  /* max-width: 64rem; */
  margin: 0 auto;
  text-align: center;
  padding-bottom: 5%;
  padding-top: 5%;
}

.trails-page.hiking-page .trails-longform.hiking-mova-story {
  border-top: none;
  padding-top: clamp(1.75rem, 4vw, 2.5rem);
}

.trails-page.hiking-page .trails-longform-story-intro {
  text-align: left;
  padding-top: 0;
}

.trails-page.hiking-page .trails-longform-story-intro > p {
  margin-left: 0;
  margin-right: 0;
}

.trails-page.hiking-page .trails-longform-story-intro > h2.h2:first-child {
  border-bottom: none;
  padding-bottom: 0;
}

.trails-page .trails-longform-story-intro > p {
  margin-left: auto;
  margin-right: auto;
}

.trails-page .trails-longform-inner .h2 {
  margin-bottom: 1.5rem;
  font-family: "Georgia";
  font-size: clamp(2rem, 5vw, 2.75rem);
  font-weight: 300;
}

.trails-page .trails-longform-story-cluster {
  margin: 0.35rem auto 2.2rem;
  /* padding: clamp(1.25rem, 3vw, 2rem); */
}

.trails-page .trails-longform-story-intro > h2.h2:first-child {
  margin-top: 0;
  margin-bottom: 1rem;
  padding-bottom: 0.65rem;
  border-bottom: 1px solid rgb(157 82 26 / 0.25);
}

.trails-page .trails-longform-story-intro > p + p {
  margin-top: 0.9rem;
}

.trails-page .trails-longform-inner p:has(> strong:only-child > span:only-child):has(+ ul[type="disc"]):not(.trails-longform-experience-lead) {
  display: inline-flex;
  align-items: center;
  padding: 0.35rem 0.75rem;
  border: 1px solid rgb(157 82 26 / 0.25);
  border-radius: 9999px;
  background: rgb(157 82 26 / 0.1);
  margin-bottom: 0.7rem;
  border-bottom: none;
}

.trails-page .trails-longform-inner .trails-longform-experience-panel {
  margin: 1.35rem 0 2rem;
  padding: 0.85rem 1.1rem 1.05rem;
  border: 1px solid rgb(157 82 26 / 0.2);
  border-radius: 0.85rem;
  background: rgb(157 82 26 / 0.06);
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.trails-page .trails-longform-inner .trails-longform-experience-panel > p.trails-longform-experience-lead {
  margin: 0;
  padding: 0;
  border: none;
  border-bottom: none;
  border-radius: 0;
  background: transparent;
  font-family: "Fraunces", "Georgia", ui-serif, serif;
  font-size: clamp(1.2rem, 2.5vw, 1.5rem);
  font-weight: 400;
  line-height: 1.28;
  letter-spacing: -0.015em;
  color: var(--color-mova-ink, #201914);
}

.trails-page .trails-longform-inner .trails-longform-experience-panel > p.trails-longform-experience-lead strong {
  font-weight: 400;
}

.trails-page .trails-longform-inner .trails-longform-experience-panel > ul[type="disc"] {
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  gap: 0.65rem;
}

.trails-page .trails-longform-inner .trails-longform-experience-panel > ul[type="disc"] li {
  font-size: 0.94rem;
}

.trails-page .trails-longform-inner ul[type="disc"] {
  list-style: none;
  margin: 0 0 1.5rem;
  padding: 0;
  display: grid;
  gap: 0.5rem;
  padding: 2% 0;
}

.trails-page .trails-longform-inner p:has(> strong:only-child > span:only-child):has(+ ul[type="disc"]):not(.trails-longform-experience-lead) + ul[type="disc"] {
  margin-top: 0;
  margin-bottom: 2rem;
  padding: 1.05rem 1.1rem;
  border: 1px solid rgb(157 82 26 / 0.2);
  border-radius: 0.85rem;
  background: rgb(157 82 26 / 0.06);
  gap: 0.65rem;
}

.trails-page .trails-longform-inner ul[type="disc"] li {
  display: block;
  position: relative;
  padding-left: 0.85rem;
  font-family: "DM Sans", ui-sans-serif, system-ui, sans-serif;
  font-size: 1.075rem;
  font-weight: 300;
  line-height: 1.45;
  color: var(--color-mova-muted);
}

.trails-page .trails-longform-inner ul[type="disc"] li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.62em;
  width: 0.25rem;
  height: 0.25rem;
  border-radius: 9999px;
  background-color: #9d521a;
}

.trails-page .trails-longform-inner ul[type="disc"] li strong {
  font-weight: 500;
  color: var(--color-mova-ink, #201914);
}

.trails-page .trails-longform-inner p:has(> strong:only-child > span:only-child):has(+ ul[type="disc"]):not(.trails-longform-experience-lead) + ul[type="disc"] li {
  font-size: 0.84rem;
}

.trails-page .trails-longform-wildlife-strip-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: clamp(0.45rem, 2.5vw, 1.95rem);
  margin: 0.35rem 0 1.85rem;
}

.trails-page .trails-nima-gateway .trails-longform-wildlife-strip-row {
  margin: 0 0 2.25rem;
}

.trails-page .trails-longform-wildlife-strip {
  margin: 0;
  width: clamp(3rem, 15vw, 20.25rem);
  height: clamp(3rem, 15vw, 20.25rem);
  border-radius: 50%;
  overflow: hidden;
  border: 2px solid rgb(157 82 26 / 0.35);
  box-shadow: 0 2px 10px rgb(32 25 20 / 0.08);
  flex-shrink: 0;
  background: rgb(237 227 214);
}

.trails-page .trails-longform-wildlife-strip img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.trails-page .trails-longform-inner > figure.trails-longform-map {
  margin-left: 0;
  margin-right: 0;
}
.trails-page .trails-longform-inner .trails-longform-experience-panel > p.trails-longform-experience-lead {
  margin-top: 0rem !important;
    margin-bottom: 0.85rem;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid rgb(157 82 26 / 0.2);
    font-family: "Fraunces", "Georgia", ui-serif, serif;
    font-size: clamp(1.2rem, 2.5vw, 1.1rem) !important;
    font-weight: 400;
    line-height: 1.28;
    letter-spacing: -0.015em;
    color: var(--color-mova-ink, #201914);
}
.trails-page .trails-longform-map {
  position: relative;
  margin: 1.5rem 0 2rem;
  max-width: 100%;
  border-radius: 0.125rem;
  border: 1px dashed rgb(157 82 26 / 0.35);
  background: linear-gradient(
    145deg,
    rgb(250 246 240) 0%,
    rgb(237 227 214) 48%,
    rgb(244 236 226) 100%
  );
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.trails-page .trails-longform-map:not(.trails-longform-map--image) {
  min-height: clamp(200px, 42vw, 360px);
}

.trails-page .trails-longform-map::after {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    -45deg,
    transparent,
    transparent 10px,
    rgb(255 255 255 / 0.35) 10px,
    rgb(255 255 255 / 0.35) 11px
  );
  pointer-events: none;
  opacity: 0.5;
}

.trails-page .trails-longform-map.trails-longform-map--image {
  display: block;
  min-height: 0;
  height: fit-content;
  border-radius: 0.75rem;
  overflow: hidden;
  border: 1px solid rgb(32 25 20 / 0.08);
  background: linear-gradient(
    165deg,
    rgb(255 252 248) 0%,
    rgb(248 242 234) 45%,
    rgb(240 232 222) 100%
  );
  padding: 0;
  box-shadow:
    0 1px 0 rgb(255 255 255 / 0.55) inset,
    0 1px 2px rgb(32 25 20 / 0.05),
    0 14px 36px -10px rgb(32 25 20 / 0.14);
  transition: box-shadow 0.4s ease, border-color 0.4s ease;
}

.trails-page .trails-longform-map.trails-longform-map--image::after {
  display: none;
}

.trails-page .trails-longform-map.trails-longform-map--image img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
}

@media (hover: hover) and (prefers-reduced-motion: no-preference) {
  .trails-page .trails-longform-map.trails-longform-map--image:hover {
    border-color: rgb(157 82 26 / 0.18);
    box-shadow:
      0 1px 0 rgb(255 255 255 / 0.6) inset,
      0 2px 6px rgb(32 25 20 / 0.06),
      0 20px 44px -8px rgb(32 25 20 / 0.18);
  }
}

.trails-page .trails-longform-map-label {
  position: relative;
  z-index: 1;
  font-family: "DM Sans", ui-sans-serif, system-ui, sans-serif;
  font-size: 0.5625rem;
  font-weight: 500;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--color-mova-muted);
}

.trails-page .trails-longform-map + p,
.trails-page .trails-longform-map + ul {
  margin-top: 0.35rem;
}

.trails-page .trails-longform-lifestyle {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  margin: 2rem 0 0;
  align-items: stretch;
  border: 1px solid rgba(157, 82, 26, 0.14);
  border-radius: 1rem;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(250, 246, 240, 0.98), rgba(243, 235, 224, 0.98));
  box-shadow: 0 18px 40px rgba(45, 32, 20, 0.06);
}

.trails-page .trails-longform-lifestyle-media {
  position: relative;
  margin: 0;
  height: 100%;
  overflow: hidden;
  border: 0;
  background: rgb(237 227 214);
}

.trails-page .trails-longform-lifestyle-media img {
  width: 100%;
  min-height: 260px;
  height: 100%;
  object-fit: cover;
  display: block;
}

.trails-page .trails-longform-lifestyle-media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(27, 22, 17, 0.3), rgba(27, 22, 17, 0.04) 45%, transparent 72%);
  pointer-events: none;
}

.trails-page .trails-longform-lifestyle-label {
  position: absolute;
  left: 1.25rem;
  bottom: 1.25rem;
  z-index: 1;
  margin: 0;
  padding: 0.45rem 0.8rem;
  background: rgba(255, 255, 255, 0.88);
  color: var(--color-mova-ink, #201914);
  font-size: 0.625rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  backdrop-filter: blur(6px);
}

.trails-page .trails-longform-lifestyle-copy {
  padding: 1.5rem 1.5rem 1.75rem;
}

.trails-page .trails-longform-lifestyle-copy h3.trails-longform-section-h3 {
  margin-top: 0;
  margin-bottom: 0.85rem;
}

.trails-page .trails-longform-lifestyle-copy > p:last-child {
  margin-bottom: 0;
}

.trails-page .trails-longform-book-cta {
  margin-top: 1.5rem;
}

.trails-page .trails-longform-book-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.trails-page .trails-longform-lifestyle-list {
  grid-template-columns: 1fr;
}

.trails-page .trails-longform h3.trails-longform-section-h3 {
  font-family: Georgia, ui-serif, serif;
  font-size: 2rem;
  font-weight: 300;
  line-height: 1.2;
  color: var(--color-mova-ink, #201914);
}

.trails-page .trails-longform h3.trails-longform-section-h3.trails-longform-rock-heading {
  margin-top: clamp(3.5rem, 7vw, 5rem);
  margin-bottom: 0.4rem;
}

.trails-page .trails-longform h3.trails-longform-section-h3.trails-longform-skeleton-heading {
  margin-top: 5%;
  margin-bottom: 5%;
}

.trails-page .trails-guide-maps {
  margin: clamp(2.5rem, 5vw, 4rem) 0 clamp(2rem, 4vw, 3rem);
  padding-top: clamp(2rem, 4vw, 3rem);
  border-top: 1px solid var(--color-mova-border);
}

.trails-page .trails-guide-maps-title {
  margin: 0 0 0.75rem;
  font-family: Georgia, ui-serif, serif;
  font-size: clamp(1.75rem, 3vw, 2.25rem);
  font-weight: 300;
  line-height: 1.2;
  color: var(--color-mova-ink, #201914);
}

.trails-page .trails-guide-maps-lead {
  margin: 0 0 2rem;
  max-width: 42rem;
  font-size: 0.9375rem;
  line-height: 1.6;
  color: var(--color-mova-muted);
}

.trails-page .trails-guide-map-block {
  margin-bottom: clamp(2rem, 4vw, 2.75rem);
}

.trails-page .trails-guide-map-block:last-child {
  margin-bottom: 0;
}

.trails-page .trails-guide-map-heading {
  margin: 0 0 0.35rem;
  font-family: var(--font-display, "Fraunces", Georgia, serif);
  font-size: clamp(1.25rem, 2.2vw, 1.5rem);
  font-weight: 500;
  line-height: 1.25;
  color: var(--color-mova-ink, #201914);
}

.trails-page .trails-guide-map-meta {
  margin: 0 0 0.85rem;
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-mova-muted);
}

.trails-page .trails-guide-map-meta::before {
  content: "";
  display: inline-block;
  width: 1.25rem;
  height: 0.15rem;
  margin-right: 0.5rem;
  vertical-align: middle;
  background: var(--color-mova-accent);
}

.trails-page .trails-guide-leaflet-map {
  position: relative;
  width: 100%;
  height: clamp(360px, 52vh, 520px);
  min-height: 340px;
  border: 1px solid var(--color-mova-border);
  border-radius: 0.125rem;
  overflow: hidden;
  z-index: 0;
}

.trails-page .trails-guide-leaflet-map.trails-map--error::before {
  border-radius: 0.125rem;
}

.trails-page .trails-guide-leaflet-map .leaflet-control-attribution {
  font-size: 0.625rem;
}

@media (min-width: 1024px) {
  .trails-page .trails-guide-leaflet-map {
    height: clamp(420px, 48vh, 560px);
    min-height: 400px;
  }
}

.trails-page .trails-longform-map-pair {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.85rem;
  margin: 1.5rem 0 2rem;
}

.trails-page .trails-longform-map-pair .trails-longform-map {
  margin: 0;
}

.trails-page .trails-longform-map-pair .trails-longform-map.trails-longform-map--image {
  align-self: start;
  width: 100%;
}

.trails-page .trails-longform-inner p.trails-longform-waypoint-kicker {
  padding-top: 5%;
  margin-bottom: 0.85rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid rgb(157 82 26 / 0.2);
  font-family: "Fraunces", "Georgia", ui-serif, serif;
  font-size: clamp(1.2rem, 2.5vw, 1.5rem);
  font-weight: 400;
  line-height: 1.28;
  letter-spacing: -0.015em;
  color: var(--color-mova-ink, #201914);
}

.trails-page .trails-longform-waypoint-split {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  margin: 0.75rem 0 1.75rem;
  align-items: start;
}

.trails-page .trails-longform-waypoint-split .trails-longform-map {
  margin: 0;
  width: 100%;
}

.trails-page .trails-longform-waypoint-split .trails-longform-map.trails-longform-map--image {
  align-self: start;
}

.trails-page .trails-longform-waypoint-split-maps {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  width: 100%;
}

.trails-page .trails-longform-waypoint-split-copy > p:first-child {
  margin-top: 0;
}

.trails-page .trails-longform-waypoint-split-copy > p:last-child,
.trails-page .trails-longform-waypoint-split-copy > ul:last-child,
.trails-page .trails-longform-waypoint-split-copy > ol:last-child {
  margin-bottom: 0;
}

.trails-page .trails-longform-trails-guide-panel {
  display: flex;
  flex-direction: column;
  gap: clamp(2rem, 5vw, 3rem);
  margin: 0.5rem 0 0;
}

.trails-page .trails-longform-inner .trails-route-card .trails-route-card-kicker {
  margin: -0.15rem 0 0.65rem;
  font-size: 0.75rem;
  letter-spacing: 0.06em;
  color: var(--color-mova-muted);
}

.trails-page .trails-longform-inner .trails-route-card > p:not(.trails-route-card-kicker):not(.trails-map-hint) {
  margin: 0;
  font-size: 0.92rem;
  font-weight: 300;
  line-height: 1.65;
  color: var(--color-mova-muted);
}

.trails-page .trails-map .trails-guides-map-placeholder.trails-longform-map {
  position: absolute;
  inset: 0;
  z-index: 0;
  margin: 0;
  min-height: 100%;
  border-radius: 0.125rem;
}

.trails-page .trails-longform-inner .trails-longform-back--end {
  margin-top: 2rem;
  margin-bottom: 0;
}

.trails-page .trails-longform-inner .trails-longform-back a {
  font-weight: 500;
  color: var(--color-mova-accent, #9d521a);
  text-decoration: none;
}

.trails-page .trails-longform-inner .trails-longform-back a:hover {
  text-decoration: underline;
}

.trails-page .trails-longform-feature-box {
  margin: 1.15rem 0 1.8rem;
  padding: 1.5rem;
  border: 1px solid var(--color-mova-border);
  border-radius: 0;
  background: rgb(237 227 214);
}

.trails-page .trails-longform-feature-box > h3.trails-longform-section-h3:first-child {
  margin-top: 0;
  margin-bottom: 0.8rem;
}

.trails-page .trails-longform-feature-box > p:last-child,
.trails-page .trails-longform-feature-box > ul:last-child {
  margin-bottom: 0;
}

@media (min-width: 768px) {
  .trails-page .trails-longform-lifestyle {
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 1.35fr);
  }

  .trails-page .trails-longform-lifestyle-media img {
    min-height: 100%;
  }

  .trails-page .trails-longform-lifestyle-copy {
    padding: 2rem 2rem 2.15rem;
  }

  .trails-page .trails-longform-map-pair {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
  }

  .trails-page .trails-longform-waypoint-split {
    grid-template-columns: minmax(0, 0.52fr) minmax(0, 1fr);
    gap: 1.25rem;
    margin: 0.5rem 0 2rem;
  }

  .trails-page .trails-longform-map:not(.trails-longform-map--image) {
    min-height: clamp(240px, 36vw, 400px);
  }
}

/* —— Bouldering page (reference: movaadventures.onhercules.app/bouldering) —— */

.bouldering-page .boulder-hero {
  position: relative;
  height: 60vh;
  min-height: 400px;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}

.bouldering-page .boulder-hero-media {
  position: absolute;
  inset: 0;
  background-image: url("../assets/my boulders.jpeg");
  background-position: center;
  background-size: cover;
}

.bouldering-page .boulder-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0.2), transparent);
}

.bouldering-page .boulder-hero-inner {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 80rem;
  margin: 0 auto;
  padding: 0 1.5rem 3.5rem;
}

.bouldering-page .boulder-hero-kicker {
  margin-bottom: 1rem;
  color: rgba(255, 255, 255, 0.6);
  font-size: 0.625rem;
  letter-spacing: 0.5em;
  text-transform: uppercase;
}

.bouldering-page .boulder-hero h1 {
  margin: 0;
  color: #fff;
  font-family: "Georgia";
  font-size: clamp(3rem, 7vw, 4.25rem);
  font-weight: 300;
  line-height: 1.1;
}

.bouldering-page .boulder-hero-actions {
  margin-top: 1.75rem;
}

.bouldering-page .boulder-hero-actions .boulder-btn-solid {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  line-height: 1.1;
}

.bouldering-page .boulder-intro {
  max-width: 48rem;
  margin: 0 auto;
  padding: 5rem 1.5rem;
  text-align: center;
}

.bouldering-page .boulder-intro-rule {
  width: 2.5rem;
  height: 1px;
  margin: 0 auto 2rem;
  background: var(--color-mova-accent);
}

.bouldering-page .boulder-intro h2 {
  margin-bottom: 1.5rem;
  font-family: "Georgia";
  font-size: clamp(1.875rem, 5vw, 2.5rem);
  font-weight: 300;
  text-wrap: balance;
}

.bouldering-page .boulder-intro h2 em {
  font-style: italic;
}

.bouldering-page .boulder-intro p {
  margin: 0;
  color: var(--color-mova-muted);
  font-size: 1.125rem;
  font-weight: 300;
  line-height: 1.625;
}

.bouldering-page .boulder-distribution {
  border-top: 1px solid var(--color-mova-border);
}

.bouldering-page .boulder-distribution-inner {
  max-width: 80rem;
  margin: 0 auto;
  padding: 5rem 1.5rem;
}

.bouldering-page .boulder-distribution-kicker {
  margin-bottom: 3rem;
  font-size: 0.625rem;
  letter-spacing: 0.45em;
  text-transform: uppercase;
  color: var(--color-mova-muted);
}

.bouldering-page .boulder-dist-grid {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: 1fr;
}

.bouldering-page .boulder-dist-card {
  border: 1px solid var(--color-mova-border);
  padding: 1.5rem;
  background: var(--color-mova-surface);
}

.bouldering-page .boulder-dist-num {
  margin: 0 0 0.25rem;
  font-family: "Georgia";
  font-size: 1.875rem;
  font-weight: 300;
  color: var(--color-mova-accent);
}

.bouldering-page .boulder-dist-label {
  margin: 0 0 0.75rem;
  font-size: 0.5625rem;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: var(--color-mova-muted);
}

.bouldering-page .boulder-dist-grade {
  margin: 0 0 0.25rem;
  font-family: "Georgia";
  font-size: 1.25rem;
  font-weight: 300;
  color: var(--color-mova-ink);
}

.bouldering-page .boulder-dist-tier {
  margin: 0 0 1rem;
  font-size: 0.625rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--color-mova-accent);
}

.bouldering-page .boulder-dist-desc {
  margin: 0;
  font-size: 0.875rem;
  font-weight: 300;
  line-height: 1.625;
  color: var(--color-mova-muted);
}

.bouldering-page .boulder-split {
  border-top: 1px solid var(--color-mova-border);
  border-bottom: 1px solid var(--color-mova-border);
  background: var(--color-mova-elevated);
}

.bouldering-page .boulder-split-inner {
  max-width: 80rem;
  margin: 0 auto;
  padding: 5rem 1.5rem;
  display: grid;
  gap: 3rem;
  align-items: center;
  grid-template-columns: 1fr;
}

.bouldering-page .boulder-split-media img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  display: block;
}

.bouldering-page .boulder-split-rule {
  width: 2rem;
  height: 1px;
  margin-bottom: 2rem;
  background: var(--color-mova-accent);
}

.bouldering-page .boulder-split-kicker {
  margin-bottom: 1.25rem;
  font-size: 0.625rem;
  letter-spacing: 0.45em;
  text-transform: uppercase;
  color: var(--color-mova-muted);
}

.bouldering-page .boulder-split-copy h2 {
  margin: 0 0 1.5rem;
  font-family: "Georgia";
  font-size: clamp(1.875rem, 4vw, 2.5rem);
  font-weight: 300;
  line-height: 1.2;
  color: var(--color-mova-ink);
}

.bouldering-page .boulder-split-copy h2 em {
  font-style: italic;
}

.bouldering-page .boulder-split-copy p {
  margin: 0 0 1.5rem;
  color: var(--color-mova-muted);
  font-weight: 300;
  line-height: 1.625;
}

.bouldering-page .boulder-split-copy p:last-of-type {
  margin-bottom: 2.5rem;
}

.bouldering-page .boulder-text-link {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  font-size: 0.6875rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--color-mova-accent);
  text-decoration: none;
  transition: opacity 0.2s ease;
}

.bouldering-page .boulder-text-link:hover {
  opacity: 0.7;
}

/* Climber's Logbook */
.bouldering-page #boulder-logbook {
  scroll-margin-top: 6rem;
}

.bouldering-page .boulder-logbook {
  border-top: 1px solid var(--color-mova-border);
  background: rgb(250 248 246 / 0.9);
}

.bouldering-page .boulder-logbook-inner {
  max-width: 80rem;
  margin: 0 auto;
  padding: clamp(4rem, 8vw, 5.5rem) 1.5rem;
}

.bouldering-page .boulder-logbook-grid {
  display: grid;
  gap: 2.5rem 3rem;
  align-items: center;
  grid-template-columns: 1fr;
}

.bouldering-page .boulder-logbook-rule {
  width: 2rem;
  height: 1px;
  margin-bottom: 2rem;
  background: var(--color-mova-accent);
}

.bouldering-page .boulder-logbook-kicker {
  margin: 0 0 1.25rem;
  font-size: 0.625rem;
  letter-spacing: 0.45em;
  text-transform: uppercase;
  color: var(--color-mova-muted);
}

.bouldering-page .boulder-logbook-copy h2 {
  margin: 0 0 1.25rem;
  font-family: "Georgia", ui-serif, serif;
  font-size: clamp(1.875rem, 4vw, 2.5rem);
  font-weight: 300;
  line-height: 1.15;
  color: var(--color-mova-ink);
}

.bouldering-page .boulder-logbook-copy h2 em {
  font-style: italic;
}

.bouldering-page .boulder-logbook-lead {
  margin: 0 0 1.75rem;
  max-width: 36rem;
  color: var(--color-mova-muted);
  font-size: 1rem;
  font-weight: 300;
  line-height: 1.7;
}

.bouldering-page .boulder-logbook-features {
  list-style: none;
  margin: 0 0 2rem;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}

.bouldering-page .boulder-logbook-features li {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  font-size: 0.9rem;
  font-weight: 300;
  line-height: 1.5;
  color: var(--color-mova-muted);
}

.bouldering-page .boulder-logbook-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

.bouldering-page .boulder-logbook-visuals {
  display: grid;
  gap: 1.25rem;
}

.bouldering-page .boulder-logbook-mock {
  border: 1px solid var(--color-mova-border);
  background: #fff;
  box-shadow: 0 16px 40px rgb(32 25 20 / 0.08);
  overflow: hidden;
}

.bouldering-page .boulder-logbook-mock__chrome {
  padding: 1.25rem 1.35rem 1rem;
  border-bottom: 1px solid var(--color-mova-border);
  background: rgb(250 248 246 / 0.95);
}

.bouldering-page .boulder-logbook-mock__kicker {
  margin: 0 0 0.35rem;
  font-size: 0.5625rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--color-mova-muted);
}

.bouldering-page .boulder-logbook-mock__title {
  margin: 0;
  font-family: "Georgia", ui-serif, serif;
  font-size: 1.35rem;
  font-weight: 300;
  color: var(--color-mova-ink);
}

.bouldering-page .boulder-logbook-mock__filters {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.5rem;
  padding: 0.85rem 1.35rem;
  border-bottom: 1px solid var(--color-mova-border);
  background: rgb(246 242 236 / 0.6);
}

.bouldering-page .boulder-logbook-mock__filters span {
  padding: 0.45rem 0.5rem;
  border: 1px solid rgb(32 25 20 / 0.12);
  background: #fff;
  font-size: 0.625rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-align: center;
  color: var(--color-mova-muted);
}

.bouldering-page .boulder-logbook-mock__list {
  list-style: none;
  margin: 0;
  padding: 0.5rem 0;
}

.bouldering-page .boulder-logbook-mock__list li {
  padding: 0.85rem 1.35rem;
  border-bottom: 1px solid rgb(32 25 20 / 0.06);
}

.bouldering-page .boulder-logbook-mock__list li:last-child {
  border-bottom: 0;
}

.bouldering-page .boulder-logbook-mock__name {
  margin: 0 0 0.25rem;
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--color-mova-ink);
}

.bouldering-page .boulder-logbook-mock__meta {
  margin: 0;
  font-size: 0.75rem;
  letter-spacing: 0.04em;
  color: var(--color-mova-muted);
}

.bouldering-page .boulder-logbook-tradition {
  margin: 0;
}

.bouldering-page .boulder-logbook-tradition img {
  display: block;
  width: 100%;
  object-fit: cover;
}

.bouldering-page .boulder-logbook-tradition figcaption {
  margin-top: 0.65rem;
  font-size: 0.75rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-mova-muted);
  text-align: center;
}

.bouldering-page .boulder-ethics-inner {
  max-width: 80rem;
  margin: 0 auto;
  padding: 5rem 1.5rem;
}

.bouldering-page .boulder-ethics-grid {
  display: grid;
  gap: 3rem;
  align-items: center;
  grid-template-columns: 1fr;
}

.bouldering-page .boulder-ethics-kicker {
  margin-bottom: 1.25rem;
  font-size: 0.625rem;
  letter-spacing: 0.45em;
  text-transform: uppercase;
  color: var(--color-mova-muted);
}

.bouldering-page .boulder-ethics-copy h2 {
  margin: 0 0 2rem;
  font-family: "Georgia";
  font-size: clamp(1.75rem, 4vw, 2rem);
  font-weight: 300;
  color: var(--color-mova-ink);
}

.bouldering-page .boulder-ethics-copy h2 em {
  font-style: italic;
}

.bouldering-page .boulder-ethics-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.bouldering-page .boulder-ethics-list li {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  font-size: 0.875rem;
  font-weight: 300;
  color: var(--color-mova-muted);
  line-height: 1.45;
}

.bouldering-page .boulder-ethics-dot {
  width: 0.25rem;
  height: 0.25rem;
  margin-top: 0.5rem;
  border-radius: 9999px;
  flex-shrink: 0;
  background-color: #9d521a;
}

.bouldering-page .boulder-ethics-actions {
  margin-top: 2.5rem;
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

.bouldering-page .boulder-btn-solid {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  border: 0;
  background: var(--color-mova-accent);
  color: #fff;
  padding: 0.75rem 1.75rem;
  font-size: 0.6875rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  text-decoration: none;
  transition: background-color 0.2s ease;
}

.bouldering-page .boulder-btn-solid:hover {
  background: var(--color-mova-sand);
  color: #fff;
}

.bouldering-page .boulder-btn-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(32, 25, 20, 0.3);
  color: var(--color-mova-ink);
  padding: 0.75rem 1.75rem;
  font-size: 0.6875rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  text-decoration: none;
  transition: background-color 0.2s ease;
}

.bouldering-page .boulder-btn-outline:hover {
  background: rgba(32, 25, 20, 0.05);
}

.bouldering-page .boulder-ethics-media img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  display: block;
}

@media (min-width: 768px) {
  .bouldering-page .boulder-dist-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .bouldering-page .boulder-split-inner,
  .bouldering-page .boulder-ethics-grid,
  .bouldering-page .boulder-logbook-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1024px) {
  .bouldering-page .boulder-hero-inner,
  .bouldering-page .boulder-distribution-inner,
  .bouldering-page .boulder-split,
  .bouldering-page .boulder-logbook-inner,
  .bouldering-page .boulder-ethics-inner {
    padding-left: 3rem;
    padding-right: 3rem;
  }

  .bouldering-page .boulder-dist-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

/* —— Picnics page (reference: movaadventures.onhercules.app/picnics) —— */

.picnics-page {
  background: var(--color-mova-surface);
}

.picnics-page .picnic-hero {
  position: relative;
  height: 60vh;
  min-height: 400px;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}

.picnics-page .picnic-hero-media {
  position: absolute;
  inset: 0;
  background-image: url("../assets/my dams.jpeg");
  background-position: center;
  background-size: cover;
}

.picnics-page .picnic-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0.2), transparent);
}

.picnics-page .picnic-hero-inner {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 80rem;
  margin: 0 auto;
  padding: 0 1.5rem 3.5rem;
}

.picnics-page .picnic-hero-kicker {
  margin: 0 0 1rem;
  color: rgba(255, 255, 255, 0.6);
  font-size: 0.625rem;
  letter-spacing: 0.5em;
  text-transform: uppercase;
}

.picnics-page .picnic-hero h1 {
  margin: 0;
  color: #fff;
  font-family: "Georgia";
  font-size: clamp(3rem, 7vw, 4.25rem);
  font-weight: 300;
  line-height: 1.1;
}

.picnics-page .picnic-intro {
  max-width: 48rem;
  margin: 0 auto;
  padding: 5rem 1.5rem;
  text-align: center;
}

.picnics-page .picnic-intro-rule {
  width: 2.5rem;
  height: 1px;
  margin: 0 auto 2rem;
  background: var(--color-mova-accent);
}

.picnics-page .picnic-intro h2 {
  margin: 0 0 1.5rem;
  font-family: "Georgia";
  font-size: clamp(1.875rem, 5vw, 2.5rem);
  font-weight: 300;
  text-wrap: balance;
  color: var(--color-mova-ink);
}

.picnics-page .picnic-intro h2 em {
  font-style: italic;
}

.picnics-page .picnic-intro p {
  margin: 0;
  font-size: 1.125rem;
  font-weight: 300;
  line-height: 1.65;
  color: var(--color-mova-muted);
}

.picnics-page .picnic-experiences {
  padding-bottom: 6rem;
}

.picnics-page #picnic-book {
  scroll-margin-top: 6rem;
}

.picnics-page .picnic-experiences-inner {
  max-width: 80rem;
  margin: 0 auto;
  padding: 0 1.5rem;
}

.picnics-page .picnic-exp-kicker {
  margin: 0 0 3rem;
  font-size: 0.625rem;
  letter-spacing: 0.45em;
  text-transform: uppercase;
  color: var(--color-mova-muted);
}

.picnics-page .picnic-exp-grid {
  display: grid;
  gap: 2rem;
}

.picnics-page .picnic-exp-card {
  border: 1px solid var(--color-mova-border);
  overflow: hidden;
  background: var(--color-mova-surface);
}

.picnics-page .picnic-exp-card--featured {
  border-color: var(--color-mova-accent);
}

.picnics-page .picnic-exp-media {
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
}

.picnics-page .picnic-exp-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.picnics-page .picnic-exp-badge {
  position: absolute;
  top: 1rem;
  right: 1rem;
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.25rem 0.75rem;
  background: var(--color-mova-accent);
  color: #fff;
  font-size: 0.5625rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
}

.picnics-page .picnic-exp-body {
  padding: 2rem;
}

.picnics-page .picnic-exp-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}

.picnics-page .picnic-exp-left {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  min-width: 0;
}

.picnics-page .picnic-exp-icon {
  flex-shrink: 0;
  color: var(--color-mova-accent);
}

.picnics-page .picnic-exp-icon svg {
  display: block;
}

.picnics-page .picnic-exp-tag {
  margin: 0;
  font-size: 0.5625rem;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: var(--color-mova-muted);
}

.picnics-page .picnic-exp-left h3 {
  margin: 0;
  font-family: "Georgia";
  font-size: 1.5rem;
  font-weight: 300;
  color: var(--color-mova-ink);
}

.picnics-page .picnic-exp-meta {
  text-align: right;
  flex-shrink: 0;
}

.picnics-page .picnic-exp-meta p {
  margin: 0;
  font-size: 0.75rem;
  font-weight: 300;
  color: var(--color-mova-muted);
}

.picnics-page .picnic-exp-price {
  margin-top: 0.25rem !important;
  font-family: "Georgia";
  font-size: 1.125rem !important;
  color: var(--color-mova-accent) !important;
}

.picnics-page .picnic-exp-desc {
  margin: 0 0 1.5rem;
  font-size: 0.875rem;
  font-weight: 300;
  line-height: 1.65;
  color: var(--color-mova-muted);
}

.picnics-page .picnic-exp-list {
  list-style: none;
  margin: 0 0 2rem;
  padding: 0;
}

.picnics-page .picnic-exp-list li {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
  font-size: 0.75rem;
  font-weight: 300;
  color: var(--color-mova-muted);
}

.picnics-page .picnic-exp-list li:last-child {
  margin-bottom: 0;
}

.picnics-page .picnic-li-dot {
  width: 0.25rem;
  height: 0.25rem;
  border-radius: 9999px;
  flex-shrink: 0;
  background: var(--color-mova-accent);
}

.picnics-page .picnic-btn-outline,
.picnics-page .picnic-btn-solid {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 1.75rem;
  font-size: 0.6875rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  text-decoration: none;
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.picnics-page .picnic-btn-outline {
  border: 1px solid rgba(32, 25, 20, 0.3);
  color: var(--color-mova-ink);
  background: transparent;
}

.picnics-page .picnic-btn-outline:hover {
  background: rgba(32, 25, 20, 0.05);
}

.picnics-page .picnic-btn-solid {
  border: 1px solid var(--color-mova-accent);
  background: var(--color-mova-accent);
  color: #fff;
}

.picnics-page .picnic-btn-solid:hover {
  background: rgb(138 72 22);
  border-color: rgb(138 72 22);
  color: #fff;
}

.picnics-page .picnic-setting {
  border-top: 1px solid var(--color-mova-border);
}

.picnics-page .picnic-setting-inner {
  max-width: 80rem;
  margin: 0 auto;
  padding: 5rem 1.5rem;
}

.picnics-page .picnic-setting-grid {
  display: grid;
  gap: 3rem;
  align-items: center;
}

.picnics-page .picnic-setting-rule {
  width: 2rem;
  height: 1px;
  margin-bottom: 2rem;
  background: var(--color-mova-accent);
}

.picnics-page .picnic-setting-kicker {
  margin: 0 0 1.25rem;
  font-size: 0.625rem;
  letter-spacing: 0.45em;
  text-transform: uppercase;
  color: var(--color-mova-muted);
}

.picnics-page .picnic-setting-copy h2 {
  margin: 0 0 1.5rem;
  font-family: "Georgia";
  font-size: clamp(1.875rem, 5vw, 2.5rem);
  font-weight: 300;
  line-height: 1.2;
  color: var(--color-mova-ink);
}

.picnics-page .picnic-setting-copy h2 em {
  font-style: italic;
}

.picnics-page .picnic-setting-copy p {
  margin: 0 0 1.25rem;
  font-weight: 300;
  line-height: 1.65;
  color: var(--color-mova-muted);
}

.picnics-page .picnic-setting-copy p:last-child {
  margin-bottom: 0;
}

.picnics-page .picnic-setting-media img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  display: block;
}

@media (min-width: 768px) {
  .picnics-page .picnic-exp-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .picnics-page .picnic-setting-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1024px) {
  .picnics-page .picnic-hero-inner,
  .picnics-page .picnic-experiences-inner,
  .picnics-page .picnic-setting-inner {
    padding-left: 3rem;
    padding-right: 3rem;
  }
}

/* —— Celebrate page —— */

/* —— About page —— */

.about-page {
  background: var(--color-mova-surface);
}

.about-page .about-hero {
  position: relative;
  min-height: 400px;
  height: 60vh;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}

.about-page .about-hero-media {
  position: absolute;
  inset: 0;
  background-image: url("../assets/my dams.jpeg");
  background-position: center;
  background-size: cover;
}

.about-page .about-hero-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to top, rgba(0, 0, 0, 0.72), rgba(0, 0, 0, 0.2), transparent),
    linear-gradient(105deg, rgba(24, 18, 12, 0.5), rgba(24, 18, 12, 0));
}

.about-page .about-hero-inner,
.about-page .about-story-inner,
.about-page .about-dual-inner,
.about-page .about-rhythm-inner,
.about-page .about-cta-inner {
  width: 100%;
  max-width: 80rem;
  margin: 0 auto;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
}

.about-page .about-hero-inner {
  position: relative;
  z-index: 1;
  padding-bottom: 3.5rem;
}

.about-page .about-kicker {
  margin: 0 0 1rem;
  font-size: 0.625rem;
  letter-spacing: 0.45em;
  text-transform: uppercase;
  color: var(--color-mova-muted);
}

.about-page .about-hero .about-kicker {
  color: rgba(255, 255, 255, 0.65);
}

.about-page .about-hero h1 {
  margin: 0;
  color: #fff;
  font-family: "Georgia";
  font-size: clamp(3rem, 6vw, 4.25rem);
  font-weight: 300;
  line-height: 1.1;
}

.about-page .about-intro {
  max-width: 54rem;
  margin: 0 auto;
  padding: 5rem 1.5rem;
  text-align: center;
}

.about-page .about-intro-rule {
  width: 2.5rem;
  height: 1px;
  margin: 0 auto 2rem;
  background: var(--color-mova-accent);
}

.about-page .about-intro h2,
.about-page .about-story-copy h2,
.about-page .about-rhythm-head h2,
.about-page .about-cta h2 {
  margin: 0 0 1.5rem;
  color: var(--color-mova-ink);
  font-family: "Georgia";
  font-size: clamp(2rem, 5vw, 3rem);
  font-weight: 300;
  line-height: 1.15;
  text-wrap: balance;
}

.about-page .about-intro h2 em,
.about-page .about-story-copy h2 em,
.about-page .about-rhythm-head h2 em {
  font-style: italic;
}

.about-page .about-intro p,
.about-page .about-story-copy p,
.about-page .about-card p,
.about-page .about-rhythm-card p,
.about-page .about-cta p {
  margin: 0 0 1.25rem;
  color: var(--color-mova-muted);
  font-weight: 300;
  line-height: 1.7;
}

.about-page .about-intro p {
  font-size: 1.1rem;
}

.about-page .about-story,
.about-page .about-rhythm,
.about-page .about-cta {
  border-top: 1px solid var(--color-mova-border);
}

.about-page .about-story-inner,
.about-page .about-dual-inner,
.about-page .about-rhythm-inner,
.about-page .about-cta-inner {
  padding-top: 5rem;
  padding-bottom: 5rem;
}

.about-page .about-story-grid,
.about-page .about-dual-grid {
  display: grid;
  gap: 3rem;
  align-items: center;
}

.about-page .about-story-media img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  display: block;
}

.about-page .about-dual-grid {
  align-items: stretch;
}

.about-page .about-card {
  border: 1px solid var(--color-mova-border);
  background: #fff;
  padding: 2rem;
}

.about-page .about-card-media {
  margin: -2rem -2rem 1.5rem;
  overflow: hidden;
}

.about-page .about-card-media img {
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  display: block;
}

.about-page .about-card--accent {
  border-color: var(--color-mova-accent);
  box-shadow: 0 20px 40px rgba(85, 60, 30, 0.08);
}

.about-page .about-card-tag {
  margin: 0 0 0.5rem;
  color: var(--color-mova-muted);
  font-size: 0.5625rem;
  letter-spacing: 0.35em;
  text-transform: uppercase;
}

.about-page .about-card h3,
.about-page .about-rhythm-card h3 {
  margin: 0 0 1rem;
  color: var(--color-mova-ink);
  font-family: "Georgia";
  font-size: 1.55rem;
  font-weight: 300;
}

.about-page .about-rhythm-head {
  max-width: 54rem;
  margin-bottom: 2.5rem;
}

.about-page .about-rhythm-grid {
  display: grid;
  gap: 1.5rem;
}

.about-page .about-rhythm-card {
  border: 1px solid var(--color-mova-border);
  background: #fff;
  padding: 2rem;
}

.about-page .about-rhythm-icon {
  width: 4rem;
  height: 4rem;
  margin-bottom: 1.25rem;
}

.about-page .about-rhythm-icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.about-page .about-rhythm-card p,
.about-page .about-card p,
.about-page .about-cta p {
  margin-bottom: 0;
}

.about-page .about-cta {
  text-align: center;
}

.about-page .about-cta-inner {
  max-width: 56rem;
}

.about-page .about-cta h2 {
  font-size: clamp(2rem, 5vw, 2.8rem);
}

.about-page .about-cta p {
  margin: 0 auto;
  max-width: 42rem;
  font-size: 1rem;
}

.about-page .about-cta-actions {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  align-items: center;
  margin-top: 2rem;
}

.about-page .about-btn-solid,
.about-page .about-btn-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.85rem 1.8rem;
  font-size: 0.6875rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  text-decoration: none;
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.about-page .about-btn-solid {
  border: 1px solid var(--color-mova-accent);
  background: var(--color-mova-accent);
  color: #fff;
}

.about-page .about-btn-solid:hover {
  border-color: rgb(138 72 22);
  background: rgb(138 72 22);
  color: #fff;
}

.about-page .about-btn-outline {
  border: 1px solid rgba(32, 25, 20, 0.24);
  background: transparent;
  color: var(--color-mova-ink);
}

.about-page .about-btn-outline:hover {
  background: rgba(32, 25, 20, 0.05);
}

@media (min-width: 768px) {
  .about-page .about-story-grid,
  .about-page .about-dual-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .about-page .about-rhythm-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .about-page .about-cta-actions {
    flex-direction: row;
    justify-content: center;
  }
}

@media (min-width: 1024px) {
  .about-page .about-hero-inner,
  .about-page .about-story-inner,
  .about-page .about-dual-inner,
  .about-page .about-rhythm-inner,
  .about-page .about-cta-inner {
    padding-left: 3rem;
    padding-right: 3rem;
  }
}

.celebrate-page {
  background: var(--color-mova-surface);
}

.celebrate-page .celebrate-hero {
  position: relative;
  height: 60vh;
  min-height: 400px;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}

.celebrate-page .celebrate-hero-media {
  position: absolute;
  inset: 0;
  background-image: url("../assets/celebrate.png");
  background-position: center;
  background-size: cover;
}

.celebrate-page .celebrate-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0.2), transparent);
}

.celebrate-page .celebrate-hero-inner {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 80rem;
  margin: 0 auto;
  padding: 0 1.5rem 3.5rem;
}

.celebrate-page .celebrate-hero-kicker,
.celebrate-page .celebrate-section-kicker {
  margin: 0 0 1rem;
  color: var(--color-mova-muted);
  font-size: 0.625rem;
  letter-spacing: 0.5em;
  text-transform: uppercase;
}

.celebrate-page .celebrate-hero-kicker {
  color: rgba(255, 255, 255, 0.6);
}

.celebrate-page .celebrate-hero h1 {
  margin: 0;
  color: #fff;
  font-family: "Georgia";
  font-size: clamp(3rem, 7vw, 4.25rem);
  font-weight: 300;
  line-height: 1.1;
}

.celebrate-page .celebrate-intro-cta {
  margin-top: 1.75rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem 1rem;
  justify-content: center;
  align-items: center;
}

.celebrate-page .celebrate-plan-cta {
  margin-top: 1.75rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem 1rem;
  justify-content: center;
  align-items: center;
}

.celebrate-page .celebrate-hero-btn,
.celebrate-page .celebrate-btn-outline,
.celebrate-page .celebrate-btn-solid {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  padding: 0.85rem 1.8rem;
  font-size: 0.6875rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  text-decoration: none;
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.celebrate-page .celebrate-hero-btn,
.celebrate-page .celebrate-btn-solid {
  border: 1px solid var(--color-mova-accent);
  background: var(--color-mova-accent);
  color: #fff;
}

.celebrate-page .celebrate-hero-btn:hover,
.celebrate-page .celebrate-btn-solid:hover {
  background: rgb(138 72 22);
  border-color: rgb(138 72 22);
  color: #fff;
}

.celebrate-page .celebrate-btn-outline {
  border: 1px solid rgba(32, 25, 20, 0.24);
  background: transparent;
  color: var(--color-mova-ink);
}

.celebrate-page .celebrate-btn-outline:hover {
  background: rgba(32, 25, 20, 0.05);
}

.celebrate-page .celebrate-intro {
  max-width: 48rem;
  margin: 0 auto;
  padding: 5rem 1.5rem;
  text-align: center;
}

.celebrate-page #celebrate-plan,
.celebrate-page #celebrate-book {
  scroll-margin-top: 6rem;
}

.celebrate-page .celebrate-events {
  border-top: 1px solid var(--color-mova-border);
  background: rgb(246 236 224 / 0.35);
  padding: clamp(4rem, 8vw, 5.5rem) 0;
}

.celebrate-page .celebrate-events-inner {
  max-width: 80rem;
  margin: 0 auto;
  padding: 0 1.5rem;
  text-align: center;
}

.celebrate-page .celebrate-events-title {
  margin: 0 0 1rem;
  font-family: "Georgia", ui-serif, serif;
  font-size: clamp(2rem, 5vw, 2.75rem);
  font-weight: 300;
  line-height: 1.15;
  color: var(--color-mova-ink);
  text-wrap: balance;
}

.celebrate-page .celebrate-events-title em {
  font-style: italic;
}

.celebrate-page .celebrate-events-lead {
  max-width: 40rem;
  margin: 0 auto 2.75rem;
  color: var(--color-mova-muted);
  font-size: 1.05rem;
  font-weight: 300;
  line-height: 1.7;
}

.celebrate-page .celebrate-events-grid {
  display: grid;
  gap: 1.5rem;
  text-align: left;
}

.celebrate-page .celebrate-event-card {
  display: flex;
  flex-direction: column;
  border: 1px solid var(--color-mova-border);
  background: #fff;
  overflow: hidden;
  box-shadow: 0 12px 32px rgb(32 25 20 / 0.06);
  transition: border-color 0.25s ease, box-shadow 0.25s ease, transform 0.25s ease;
}

.celebrate-page .celebrate-event-card:hover {
  border-color: rgb(157 82 26 / 0.35);
  box-shadow: 0 18px 40px rgb(85 60 30 / 0.1);
  transform: translateY(-2px);
}

.celebrate-page .celebrate-event-card--featured {
  border-color: var(--color-mova-accent);
  box-shadow: 0 20px 44px rgb(85 60 30 / 0.12);
}

.celebrate-page .celebrate-event-media {
  position: relative;
  aspect-ratio: 16 / 10;
  overflow: hidden;
}

.celebrate-page .celebrate-event-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.45s ease;
}

.celebrate-page .celebrate-event-card:hover .celebrate-event-media img {
  transform: scale(1.03);
}

.celebrate-page .celebrate-event-badge {
  position: absolute;
  top: 1rem;
  right: 1rem;
  padding: 0.3rem 0.75rem;
  background: var(--color-mova-accent);
  color: #fff;
  font-size: 0.5625rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
}

.celebrate-page .celebrate-event-body {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: 1.75rem;
}

.celebrate-page .celebrate-event-tag {
  margin: 0 0 0.4rem;
  color: var(--color-mova-muted);
  font-size: 0.5625rem;
  letter-spacing: 0.35em;
  text-transform: uppercase;
}

.celebrate-page .celebrate-event-body h3 {
  margin: 0 0 0.75rem;
  font-family: "Georgia", ui-serif, serif;
  font-size: 1.45rem;
  font-weight: 300;
  color: var(--color-mova-ink);
}

.celebrate-page .celebrate-event-desc {
  margin: 0 0 1.5rem;
  flex: 1;
  color: var(--color-mova-muted);
  font-size: 0.92rem;
  font-weight: 300;
  line-height: 1.65;
}

.celebrate-page .celebrate-event-btn {
  align-self: flex-start;
  margin-top: auto;
}

.celebrate-page .celebrate-events-footnote {
  margin: 2.5rem 0 0;
  color: var(--color-mova-muted);
  font-size: 0.9rem;
  font-weight: 300;
}

.celebrate-page .celebrate-events-footnote a {
  color: var(--color-mova-accent);
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

.celebrate-page .celebrate-events-footnote a:hover {
  color: rgb(138 72 22);
}

.celebrate-page .celebrate-enquiry-inner.celebrate-enquiry-inner--solo {
  max-width: 48rem;
}

.celebrate-page .celebrate-enquiry-copy--solo {
  max-width: none;
  margin: 0 auto;
  padding: clamp(2rem, 4vw, 2.75rem);
  text-align: center;
  border: 1px solid var(--color-mova-border);
  background: #fff;
  box-shadow: 0 16px 40px rgb(85 60 30 / 0.08);
}

.celebrate-page .celebrate-intro-rule,
.celebrate-page .celebrate-why-rule {
  width: 2.5rem;
  height: 1px;
  background: var(--color-mova-accent);
}

.celebrate-page .celebrate-intro-rule {
  margin: 0 auto 2rem;
}

.celebrate-page .celebrate-intro h2,
.celebrate-page .celebrate-why-copy h2,
.celebrate-page .celebrate-enquiry-copy h2 {
  margin: 0 0 1.5rem;
  font-family: "Georgia";
  font-size: clamp(1.95rem, 5vw, 3rem);
  font-weight: 300;
  line-height: 1.15;
  color: var(--color-mova-ink);
  text-wrap: balance;
}

.celebrate-page .celebrate-intro h2 em,
.celebrate-page .celebrate-why-copy h2 em,
.celebrate-page .celebrate-enquiry-copy h2 em {
  font-style: italic;
}

.celebrate-page .celebrate-intro p,
.celebrate-page .celebrate-why-copy p,
.celebrate-page .celebrate-enquiry-copy p,
.celebrate-page .celebrate-card-copy {
  margin: 0 0 1.25rem;
  color: var(--color-mova-muted);
  font-size: 1rem;
  font-weight: 300;
  line-height: 1.7;
}

.celebrate-page .celebrate-intro p {
  max-width: none;
  font-size: 1.1rem;
}

.celebrate-page .celebrate-offerings,
.celebrate-page .celebrate-enquiry {
  border-top: 1px solid var(--color-mova-border);
}

.celebrate-page .celebrate-offerings-inner,
.celebrate-page .celebrate-why-inner,
.celebrate-page .celebrate-enquiry-inner {
  max-width: 80rem;
  margin: 0 auto;
  padding: 5rem 1.5rem;
}

.celebrate-page .celebrate-offerings-grid {
  display: grid;
  gap: 1.5rem;
  margin-top: 2rem;
}

.celebrate-page .celebrate-card {
  border: 1px solid var(--color-mova-border);
  background: #fff;
  padding: 2rem;
  box-shadow: 0 10px 28px rgb(32 25 20 / 0.05);
  transition: border-color 0.25s ease, box-shadow 0.25s ease;
}

.celebrate-page .celebrate-card:hover {
  border-color: rgb(157 82 26 / 0.3);
  box-shadow: 0 16px 36px rgb(85 60 30 / 0.08);
}

.celebrate-page .celebrate-card--featured {
  border-color: var(--color-mova-accent);
  box-shadow: 0 20px 40px rgba(85, 60, 30, 0.1);
}

.celebrate-page .celebrate-card-head {
  margin-bottom: 1rem;
}

.celebrate-page .celebrate-card-tag {
  margin: 0 0 0.5rem;
  color: var(--color-mova-muted);
  font-size: 0.5625rem;
  letter-spacing: 0.35em;
  text-transform: uppercase;
}

.celebrate-page .celebrate-card h3 {
  margin: 0;
  color: var(--color-mova-ink);
  font-family: "Georgia";
  font-size: 1.55rem;
  font-weight: 300;
}

.celebrate-page .celebrate-card-list,
.celebrate-page .celebrate-why-list {
  list-style: none;
  margin: 1.5rem 0 0;
  padding: 0;
}

.celebrate-page .celebrate-card-list li,
.celebrate-page .celebrate-why-list li {
  display: flex;
  gap: 0.65rem;
  align-items: flex-start;
  margin-bottom: 0.75rem;
  color: var(--color-mova-muted);
  font-size: 0.9rem;
  font-weight: 300;
  line-height: 1.6;
}

.celebrate-page .celebrate-card-list li:last-child,
.celebrate-page .celebrate-why-list li:last-child {
  margin-bottom: 0;
}

.celebrate-page .celebrate-card-dot {
  width: 0.32rem;
  height: 0.32rem;
  margin-top: 0.5rem;
  border-radius: 9999px;
  flex-shrink: 0;
  background: var(--color-mova-accent);
}

.celebrate-page .celebrate-why-inner {
  padding-top: 0;
}

.celebrate-page .celebrate-why-grid,
.celebrate-page .celebrate-enquiry-grid {
  display: grid;
  gap: 3rem;
  align-items: start;
}

.celebrate-page .celebrate-why-rule {
  margin-bottom: 2rem;
}

.celebrate-page .celebrate-why-media img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  display: block;
}

.celebrate-page .celebrate-text-link {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  margin-top: 2rem;
  color: var(--color-mova-accent);
  text-decoration: none;
  font-size: 0.6875rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
}

.celebrate-page .celebrate-form {
  border: 1px solid var(--color-mova-border);
  background: #fff;
  padding: 1.5rem;
}

.celebrate-page .celebrate-form-grid {
  display: grid;
  gap: 1rem;
}

.celebrate-page .celebrate-field {
  display: grid;
  gap: 0.5rem;
}

.celebrate-page .celebrate-field span,
.celebrate-page .celebrate-checklist legend {
  color: var(--color-mova-ink);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.celebrate-page .celebrate-field input,
.celebrate-page .celebrate-field select,
.celebrate-page .celebrate-field textarea {
  width: 100%;
  border: 1px solid rgba(32, 25, 20, 0.18);
  background: #fff;
  color: var(--color-mova-ink);
  padding: 0.9rem 1rem;
  font: inherit;
}

.celebrate-page .celebrate-field input:focus,
.celebrate-page .celebrate-field select:focus,
.celebrate-page .celebrate-field textarea:focus {
  outline: none;
  border-color: var(--color-mova-accent);
  box-shadow: 0 0 0 3px rgba(170, 112, 54, 0.12);
}

.celebrate-page .celebrate-field textarea {
  resize: vertical;
}

.celebrate-page .celebrate-checklist {
  margin: 1.5rem 0;
  border: 1px solid rgba(32, 25, 20, 0.12);
  padding: 1rem;
}

.celebrate-page .celebrate-checklist legend {
  padding: 0 0.25rem;
}

.celebrate-page .celebrate-checklist label {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.85rem;
  color: var(--color-mova-muted);
  font-size: 0.9375rem;
  font-weight: 300;
}

.celebrate-page .celebrate-checklist label:last-child {
  margin-bottom: 0;
}

.celebrate-page .celebrate-checklist input[type="checkbox"] {
  width: 1rem;
  height: 1rem;
  accent-color: var(--color-mova-accent);
  flex-shrink: 0;
}

.celebrate-page .celebrate-form-actions {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-top: 1.5rem;
}

.celebrate-page .celebrate-form-note {
  margin: 0;
  color: var(--color-mova-muted);
  font-size: 0.8125rem;
  font-weight: 300;
  line-height: 1.6;
}

@media (min-width: 768px) {
  .celebrate-page .celebrate-events-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.75rem;
  }

  .celebrate-page .celebrate-offerings-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .celebrate-page .celebrate-why-grid,
  .celebrate-page .celebrate-enquiry-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .celebrate-page .celebrate-form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .celebrate-page .celebrate-field--full {
    grid-column: 1 / -1;
  }
}

@media (min-width: 1024px) {
  .celebrate-page .celebrate-hero-inner,
  .celebrate-page .celebrate-events-inner,
  .celebrate-page .celebrate-offerings-inner,
  .celebrate-page .celebrate-why-inner,
  .celebrate-page .celebrate-enquiry-inner {
    padding-left: 3rem;
    padding-right: 3rem;
  }

  .celebrate-page .celebrate-form {
    padding: 2rem;
  }
}

/* —— Rentals page (reference: movaadventures.onhercules.app/rentals) —— */

.rentals-page {
  background: var(--color-mova-surface);
}

.rentals-page .rental-hero {
  position: relative;
  height: 55vh;
  min-height: 380px;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}

.rentals-page .rental-hero-media {
  position: absolute;
  inset: 0;
  background-image: url("../assets/rentals-header.jpeg");
  background-position: center;
  background-size: cover;
}

.rentals-page .rental-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0.2), transparent);
}

.rentals-page .rental-hero-inner {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 80rem;
  margin: 0 auto;
  padding: 0 1.5rem 3.5rem;
}

.rentals-page .rental-hero-kicker {
  margin: 0 0 1rem;
  color: rgba(255, 255, 255, 0.6);
  font-size: 0.625rem;
  letter-spacing: 0.5em;
  text-transform: uppercase;
}

.rentals-page .rental-hero h1 {
  margin: 0;
  color: #fff;
  font-family: "Georgia";
  font-size: clamp(3rem, 7vw, 4.25rem);
  font-weight: 300;
  line-height: 1.1;
}

.rentals-page .rental-intro {
  max-width: 48rem;
  margin: 0 auto;
  padding: 5rem 1.5rem;
  text-align: center;
}

.rentals-page .rental-intro-rule {
  width: 2.5rem;
  height: 1px;
  margin: 0 auto 2rem;
  background: var(--color-mova-accent);
}

.rentals-page .rental-intro h2 {
  margin: 0 0 1.5rem;
  font-family: "Georgia";
  font-size: clamp(1.875rem, 5vw, 2.5rem);
  font-weight: 300;
  text-wrap: balance;
  color: var(--color-mova-ink);
}

.rentals-page .rental-intro h2 em {
  font-style: italic;
}

.rentals-page .rental-intro p {
  margin: 0;
  font-size: 1.125rem;
  font-weight: 300;
  line-height: 1.65;
  color: var(--color-mova-muted);
}

.rentals-page .rental-catalog {
  padding-bottom: 6rem;
}

.rentals-page .rental-catalog-inner {
  max-width: 80rem;
  margin: 0 auto;
  padding: 0 1.5rem;
}

.rentals-page .rental-stack {
  display: flex;
  flex-direction: column;
  gap: 3rem;
}

.rentals-page .rental-row {
  display: grid;
  grid-template-columns: 1fr;
  border: 1px solid var(--color-mova-border);
  overflow: hidden;
  background: var(--color-mova-surface);
}

.rentals-page .rental-row--featured {
  border-color: var(--color-mova-accent);
}

.rentals-page .rental-row-media {
  position: relative;
  min-height: 0;
}

.rentals-page .rental-row-media img {
  width: 100%;
  height: 16rem;
  object-fit: cover;
  display: block;
}

.rentals-page .rental-row-body {
  padding: 2rem 2.5rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.rentals-page .rental-row-head {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1.5rem;
}

.rentals-page .rental-row-icon {
  flex-shrink: 0;
  color: var(--color-mova-accent);
}

.rentals-page .rental-row-icon svg {
  display: block;
}

.rentals-page .rental-row-divider {
  width: 1px;
  height: 2rem;
  flex-shrink: 0;
  background: var(--color-mova-border);
}

.rentals-page .rental-row-tag {
  margin: 0;
  font-size: 0.5625rem;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: var(--color-mova-muted);
}

.rentals-page .rental-row-head h3 {
  margin: 0;
  font-family: "Georgia";
  font-size: 1.5rem;
  font-weight: 300;
  color: var(--color-mova-ink);
}

.rentals-page .rental-row-desc {
  margin: 0 0 1.5rem;
  font-size: 0.875rem;
  font-weight: 300;
  line-height: 1.65;
  color: var(--color-mova-muted);
}

.rentals-page .rental-row-list {
  list-style: none;
  margin: 0 0 2rem;
  padding: 0;
}

.rentals-page .rental-row-list li {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
  font-size: 0.75rem;
  font-weight: 300;
  color: var(--color-mova-muted);
}

.rentals-page .rental-row-list li:last-child {
  margin-bottom: 0;
}

.rentals-page .rental-li-dot {
  width: 0.25rem;
  height: 0.25rem;
  margin-top: 0.375rem;
  border-radius: 9999px;
  flex-shrink: 0;
  background: var(--color-mova-accent);
}

.rentals-page .rental-row-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
}

.rentals-page .rental-row-footer > div p {
  margin: 0;
}

.rentals-page .rental-row-price {
  font-family: "Georgia";
  font-size: 1.5rem;
  color: var(--color-mova-accent);
}

.rentals-page .rental-row-avail {
  margin-top: 0.25rem !important;
  font-size: 0.625rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-mova-muted);
}

.rentals-page .rental-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 1.75rem;
  border: 1px solid var(--color-mova-accent);
  background: var(--color-mova-accent);
  color: #fff;
  font-size: 0.6875rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  text-decoration: none;
  transition: background-color 0.2s ease, border-color 0.2s ease;
}

.rentals-page .rental-btn:hover {
  background: rgb(138 72 22);
  border-color: rgb(138 72 22);
  color: #fff;
}

@media (min-width: 768px) {
  .rentals-page .rental-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .rentals-page .rental-row-media img {
    height: 100%;
    min-height: 100%;
  }

  .rentals-page .rental-row-media {
    min-height: 17rem;
  }

  .rentals-page .rental-row-media--md-second {
    order: 2;
  }

  .rentals-page .rental-row-body--md-first {
    order: 1;
  }
}

@media (min-width: 1024px) {
  .rentals-page .rental-hero-inner,
  .rentals-page .rental-catalog-inner {
    padding-left: 3rem;
    padding-right: 3rem;
  }
}

/* —— Waiver page (reference: movaadventures.onhercules.app/waiver) —— */

.waiver-page {
  background: var(--color-mova-surface);
  min-height: 100vh;
}

.waiver-wrap {
  min-height: 100vh;
}

.waiver-page .waiver-hero {
  position: relative;
  padding: 5rem 0;
  border-bottom: 1px solid var(--color-mova-border);
  overflow: hidden;
}

.waiver-page .waiver-hero-tint {
  position: absolute;
  inset: 0;
  background: rgb(246 236 224 / 0.4);
}

.waiver-page .waiver-hero-inner {
  position: relative;
  z-index: 1;
  max-width: 56rem;
  margin: 0 auto;
  padding: 0 1.5rem;
}

.waiver-page .waiver-hero-kicker {
  margin: 0 0 1rem;
  font-size: 0.625rem;
  letter-spacing: 0.5em;
  text-transform: uppercase;
  color: var(--color-mova-muted);
}

.waiver-page .waiver-hero h1 {
  margin: 0 0 1.5rem;
  font-family: "Georgia";
  font-size: clamp(3rem, 7vw, 4.25rem);
  font-weight: 300;
  line-height: 1.1;
  color: var(--color-mova-ink);
}

.waiver-page .waiver-hero-accent {
  font-style: italic;
  color: var(--color-mova-accent);
}

.waiver-page .waiver-hero-lead {
  margin: 0;
  max-width: 36rem;
  font-weight: 300;
  line-height: 1.65;
  color: var(--color-mova-muted);
}

.waiver-page .waiver-main {
  padding: 3.5rem 0 5rem;
}

.waiver-page .waiver-main-inner {
  max-width: 56rem;
  margin: 0 auto;
  padding: 0 1.5rem;
}

.waiver-page .waiver-clauses {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-bottom: 3rem;
}

.waiver-page .waiver-clause {
  border: 1px solid var(--color-mova-border);
  background: var(--color-mova-surface);
}

.waiver-page .waiver-clause-trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.5rem;
  border: 0;
  background: transparent;
  cursor: pointer;
  text-align: left;
  color: var(--color-mova-ink);
  transition: background-color 0.2s ease;
}

.waiver-page .waiver-clause-trigger:hover {
  background: rgb(246 236 224 / 0.4);
}

.waiver-page .waiver-clause-title {
  font-family: "Georgia";
  font-size: 1.125rem;
  font-weight: 300;
}

.waiver-page .waiver-clause-chevron {
  flex-shrink: 0;
  color: var(--color-mova-muted);
  transition: transform 0.2s ease;
}

.waiver-page .waiver-clause.is-open .waiver-clause-chevron {
  transform: rotate(180deg);
}

.waiver-page .waiver-clause-panel {
  padding: 0 1.5rem 1.5rem;
  border-top: 1px solid rgb(32 25 20 / 0.06);
}

.waiver-page .waiver-clause-panel[hidden] {
  display: none;
}

.waiver-page .waiver-clause-panel p {
  margin: 0;
  padding-top: 0.25rem;
  font-size: 0.875rem;
  font-weight: 300;
  line-height: 1.65;
  color: var(--color-mova-muted);
}

.waiver-page .waiver-acknowledge {
  display: block;
  margin: 0 0 2.5rem;
  padding: 0;
  border: 0;
  background: none;
  font-size: 0.6875rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--color-mova-muted);
  text-decoration: underline;
  text-underline-offset: 4px;
  cursor: pointer;
  transition: color 0.2s ease;
}

.waiver-page .waiver-acknowledge:hover {
  color: var(--color-mova-ink);
}

.waiver-page .waiver-form {
  border: 1px solid var(--color-mova-border);
  padding: 2rem;
  background: rgb(246 236 224 / 0.2);
  transition: opacity 0.25s ease;
}

.waiver-page .waiver-form--locked {
  opacity: 0.4;
  pointer-events: none;
}

.waiver-page .waiver-form:not(.waiver-form--locked) {
  opacity: 1;
  pointer-events: auto;
}

.waiver-page .waiver-form-kicker {
  margin: 0 0 1.5rem;
  font-size: 0.625rem;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--color-mova-muted);
}

.waiver-page .waiver-form-grid {
  display: grid;
  gap: 1.5rem;
  margin-bottom: 1.5rem;
}

.waiver-page .waiver-label {
  display: block;
  margin-bottom: 0.75rem;
  font-size: 0.625rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--color-mova-muted);
}

.waiver-page .waiver-input {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid var(--color-mova-border);
  background: var(--color-mova-surface);
  padding: 0.75rem 1rem;
  font-size: 0.875rem;
  font-weight: 300;
  color: var(--color-mova-ink);
  transition: border-color 0.2s ease;
}

.waiver-page .waiver-input:focus {
  outline: none;
  border-color: var(--color-mova-accent);
}

.waiver-page .waiver-input:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.waiver-page .waiver-input--readonly {
  background: rgb(246 236 224 / 0.5);
  color: var(--color-mova-muted);
}

.waiver-page .waiver-agree-label {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  margin-bottom: 2rem;
  cursor: pointer;
}

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

.waiver-page .waiver-agree-box {
  margin-top: 0.125rem;
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
  border: 1px solid var(--color-mova-muted);
  transition: border-color 0.2s ease, background-color 0.2s ease;
}

.waiver-page .waiver-agree-label:hover .waiver-agree-box {
  border-color: var(--color-mova-accent);
}

.waiver-page .waiver-agree-input:checked + .waiver-agree-box {
  border-color: var(--color-mova-accent);
  background: var(--color-mova-accent);
  box-shadow: inset 0 0 0 2px var(--color-mova-surface);
}

.waiver-page .waiver-agree-input:disabled + .waiver-agree-box {
  opacity: 0.5;
}

.waiver-page .waiver-agree-text {
  font-size: 0.875rem;
  font-weight: 300;
  line-height: 1.65;
  color: var(--color-mova-muted);
}

.waiver-page .waiver-agree-text strong {
  font-weight: 600;
  color: var(--color-mova-ink);
}

.waiver-page .waiver-submit {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.875rem 2rem;
  border: 1px solid var(--color-mova-accent);
  background: var(--color-mova-accent);
  color: #fff;
  font-size: 0.6875rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background-color 0.2s ease, border-color 0.2s ease, opacity 0.2s ease;
}

.waiver-page .waiver-submit:hover:not(:disabled) {
  background: rgb(138 72 22);
  border-color: rgb(138 72 22);
}

.waiver-page .waiver-submit:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

@media (min-width: 768px) {
  .waiver-page .waiver-hero {
    padding: 7rem 0;
  }

  .waiver-page .waiver-main {
    padding: 5rem 0 6rem;
  }

  .waiver-page .waiver-form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1024px) {
  .waiver-page .waiver-hero-inner,
  .waiver-page .waiver-main-inner {
    padding-left: 3rem;
    padding-right: 3rem;
  }
}

/* —— Logbook page (reference: movaadventures.onhercules.app/logbook) —— */

.logbook-page {
  background: var(--color-mova-surface);
}

.logbook-page .logbook-hero {
  position: relative;
  height: 55vh;
  min-height: 380px;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}

.logbook-page .logbook-hero-media {
  position: absolute;
  inset: 0;
  background-image: url("https://images.unsplash.com/photo-1770434368329-c70135f5eb62?crop=entropy&cs=tinysrgb&fit=max&fm=jpg&ixlib=rb-4.1.0&q=80&w=1920");
  background-position: center;
  background-size: cover;
}

.logbook-page .logbook-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0.2), transparent);
}

.logbook-page .logbook-hero-inner {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 80rem;
  margin: 0 auto;
  padding: 0 1.5rem 3.5rem;
}

.logbook-page .logbook-hero-kicker {
  margin: 0 0 1rem;
  color: rgba(255, 255, 255, 0.6);
  font-size: 0.625rem;
  letter-spacing: 0.5em;
  text-transform: uppercase;
}

.logbook-page .logbook-hero h1 {
  margin: 0;
  color: #fff;
  font-family: "Georgia";
  font-size: clamp(3rem, 7vw, 4.25rem);
  font-weight: 300;
  line-height: 1.1;
}

.logbook-page .logbook-intro {
  max-width: 48rem;
  margin: 0 auto;
  padding: 5rem 1.5rem;
  text-align: center;
}

.logbook-page .logbook-intro-rule {
  width: 2.5rem;
  height: 1px;
  margin: 0 auto 2rem;
  background: var(--color-mova-accent);
}

.logbook-page .logbook-intro h2 {
  margin: 0 0 1.5rem;
  font-family: "Georgia";
  font-size: clamp(1.875rem, 5vw, 2.5rem);
  font-weight: 300;
  text-wrap: balance;
  color: var(--color-mova-ink);
}

.logbook-page .logbook-intro h2 em {
  font-style: italic;
}

.logbook-page .logbook-intro p {
  margin: 0;
  font-size: 1.125rem;
  font-weight: 300;
  line-height: 1.65;
  color: var(--color-mova-muted);
}

.logbook-page .logbook-stats {
  border-top: 1px solid var(--color-mova-border);
  border-bottom: 1px solid var(--color-mova-border);
}

.logbook-page .logbook-stats-inner {
  max-width: 80rem;
  margin: 0 auto;
  padding: 0 1.5rem;
}

.logbook-page .logbook-stats-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.logbook-page .logbook-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  padding: 2rem 1.5rem;
  text-align: center;
}

.logbook-page .logbook-stat--divider {
  border-right: 1px solid var(--color-mova-border);
}

.logbook-page .logbook-stat-icon {
  color: var(--color-mova-accent);
}

.logbook-page .logbook-stat-icon svg {
  display: block;
}

.logbook-page .logbook-stat-value {
  margin: 0;
  font-family: "Georgia";
  font-size: 1.875rem;
  font-weight: 300;
  color: var(--color-mova-ink);
}

.logbook-page .logbook-stat-value--symbol {
  font-size: 2.25rem;
  line-height: 1;
}

.logbook-page .logbook-stat-label {
  margin: 0;
  font-size: 0.5625rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--color-mova-muted);
}

.logbook-page .logbook-database {
  padding: 5rem 0;
}

.logbook-page .logbook-database-inner {
  max-width: 80rem;
  margin: 0 auto;
  padding: 0 1.5rem;
}

.logbook-page .logbook-database-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
  margin-bottom: 2.5rem;
}

.logbook-page .logbook-database-kicker {
  margin: 0 0 0.5rem;
  font-size: 0.625rem;
  letter-spacing: 0.45em;
  text-transform: uppercase;
  color: var(--color-mova-muted);
}

.logbook-page .logbook-database-head h2 {
  margin: 0;
  font-family: "Georgia";
  font-size: clamp(1.75rem, 4vw, 2rem);
  font-weight: 300;
  color: var(--color-mova-ink);
}

.logbook-page .logbook-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 1.75rem;
  border: 1px solid var(--color-mova-accent);
  background: var(--color-mova-accent);
  color: #fff;
  font-size: 0.6875rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  text-decoration: none;
  transition: background-color 0.2s ease, border-color 0.2s ease;
}

.logbook-page .logbook-btn:hover {
  background: rgb(138 72 22);
  border-color: rgb(138 72 22);
  color: #fff;
}

.logbook-page button.logbook-btn {
  font-family: inherit;
  cursor: pointer;
}

.logbook-page .logbook-btn--wide {
  padding-left: 2.5rem;
  padding-right: 2.5rem;
  padding-top: 1rem;
  padding-bottom: 1rem;
}

.logbook-page .logbook-empty {
  padding: 6rem 1.5rem;
  text-align: center;
  border: 1px dashed var(--color-mova-border);
}

.logbook-page .logbook-empty-icon {
  display: block;
  margin: 0 auto 1.25rem;
  color: var(--color-mova-muted);
}

.logbook-page .logbook-empty-title {
  margin: 0 0 0.5rem;
  font-family: "Georgia";
  font-size: 1.5rem;
  font-weight: 300;
  color: var(--color-mova-ink);
}

.logbook-page .logbook-empty-copy {
  margin: 0 auto 2rem;
  max-width: 20rem;
  font-size: 0.875rem;
  font-weight: 300;
  color: var(--color-mova-muted);
}

.logbook-page .logbook-cta-band {
  padding: 5rem 1.5rem;
  text-align: center;
  background: var(--color-mova-ink);
}

.logbook-page .logbook-cta-inner {
  max-width: 42rem;
  margin: 0 auto;
}

.logbook-page .logbook-cta-kicker {
  margin: 0 0 1.5rem;
  font-size: 0.625rem;
  letter-spacing: 0.45em;
  text-transform: uppercase;
  color: rgba(250, 246, 240, 0.5);
}

.logbook-page .logbook-cta-band h2 {
  margin: 0 0 1.5rem;
  font-family: "Georgia";
  font-size: clamp(1.875rem, 5vw, 2.5rem);
  font-weight: 300;
  color: var(--color-mova-deep);
}

.logbook-page .logbook-cta-lead {
  margin: 0 0 2.5rem;
  font-weight: 300;
  line-height: 1.65;
  color: rgba(250, 246, 240, 0.7);
}

@media (min-width: 1024px) {
  .logbook-page .logbook-hero-inner,
  .logbook-page .logbook-stats-inner,
  .logbook-page .logbook-database-inner,
  .logbook-page .logbook-intro {
    padding-left: 3rem;
    padding-right: 3rem;
  }
}

/* Booking page shell: flow in styles/booking.css + booking.js */

/* Logbook: submit drawer (slide-over from right) */

.logbook-drawer-backdrop {
  position: fixed;
  inset: 0;
  z-index: 90;
  background: rgba(0, 0, 0, 0.45);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.25s ease, visibility 0.25s ease;
}

.logbook-drawer-backdrop.is-open {
  opacity: 1;
  visibility: visible;
}

.logbook-drawer {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  z-index: 100;
  width: 100%;
  max-width: 42rem;
  display: flex;
  flex-direction: column;
  background: var(--color-mova-surface);
  box-shadow: -12px 0 48px rgba(0, 0, 0, 0.2);
  overflow: hidden;
  transform: translateX(100%);
  transition: transform 0.3s ease;
  pointer-events: none;
}

.logbook-drawer.is-open {
  transform: translateX(0);
  pointer-events: auto;
}

.logbook-drawer-header {
  position: sticky;
  top: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid var(--color-mova-border);
  background: var(--color-mova-surface);
}

.logbook-drawer-kicker {
  margin: 0 0 0.125rem;
  font-size: 0.5625rem;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--color-mova-muted);
}

.logbook-drawer-title {
  margin: 0;
  font-family: "Georgia";
  font-size: 1.5rem;
  font-weight: 300;
  color: var(--color-mova-ink);
}

.logbook-drawer-close {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.5rem;
  border: 0;
  border-radius: 9999px;
  background: transparent;
  color: var(--color-mova-ink);
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.logbook-drawer-close:hover {
  background: rgb(246 236 224 / 0.5);
}

.logbook-drawer-body {
  flex: 1;
  overflow-y: auto;
  padding: 2rem 1.5rem;
}

.logbook-drawer-form {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.logbook-drawer-block {
  margin: 0;
}

.logbook-drawer-section-label {
  margin: 0 0 1.25rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--color-mova-border);
  font-size: 0.625rem;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--color-mova-muted);
}

.logbook-drawer-section-label--tight {
  margin-bottom: 0.5rem;
}

.logbook-drawer-grid {
  display: grid;
  gap: 1.25rem;
  grid-template-columns: 1fr;
}

.logbook-drawer-field--full {
  grid-column: 1 / -1;
}

.logbook-drawer-field--row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.logbook-drawer-label {
  display: block;
  margin-bottom: 0.5rem;
  font-size: 0.625rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--color-mova-muted);
}

.logbook-drawer-input,
.logbook-drawer-textarea,
.logbook-drawer-select {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid var(--color-mova-border);
  background: var(--color-mova-surface);
  padding: 0.75rem 1rem;
  font-size: 0.875rem;
  font-weight: 300;
  color: var(--color-mova-ink);
  transition: border-color 0.2s ease;
}

.logbook-drawer-input:focus,
.logbook-drawer-textarea:focus,
.logbook-drawer-select:focus {
  outline: none;
  border-color: var(--color-mova-accent);
}

.logbook-drawer-textarea {
  resize: none;
  min-height: 5rem;
}

.logbook-select-wrap {
  position: relative;
}

.logbook-drawer-select {
  appearance: none;
  padding-right: 2.5rem;
  cursor: pointer;
}

.logbook-select-chevron {
  position: absolute;
  right: 1rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-mova-muted);
  pointer-events: none;
}

.logbook-switch {
  position: relative;
  width: 2.5rem;
  height: 1.25rem;
  flex-shrink: 0;
  padding: 0;
  border: 0;
  border-radius: 9999px;
  background: var(--color-mova-border);
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.logbook-switch.is-on {
  background: var(--color-mova-accent);
}

.logbook-switch-knob {
  position: absolute;
  top: 0.125rem;
  left: 0.125rem;
  width: 1rem;
  height: 1rem;
  border-radius: 9999px;
  background: #fff;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12);
  transition: transform 0.2s ease;
}

.logbook-switch.is-on .logbook-switch-knob {
  transform: translateX(1.25rem);
}

.logbook-switch-label {
  font-size: 0.875rem;
  font-weight: 300;
  color: var(--color-mova-ink);
}

.logbook-stars {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}

.logbook-star {
  padding: 0;
  border: 0;
  background: transparent;
  color: rgba(111, 98, 88, 0.35);
  cursor: pointer;
  transition: transform 0.15s ease, color 0.15s ease;
}

.logbook-star:hover {
  transform: scale(1.1);
}

.logbook-star.is-active {
  color: var(--color-mova-accent);
}

.logbook-star.is-active svg {
  fill: currentColor;
  stroke: currentColor;
}

.logbook-star:not(.is-active) svg {
  fill: none;
}

.logbook-stars-caption {
  margin-left: 0.5rem;
  font-size: 0.75rem;
  font-weight: 300;
  color: var(--color-mova-muted);
  align-self: center;
}

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

.logbook-upload-trigger {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
  padding: 2.5rem 1rem;
  border: 1px dashed var(--color-mova-border);
  background: transparent;
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.logbook-upload-trigger:hover {
  background: rgb(246 236 224 / 0.4);
}

.logbook-upload-main {
  font-size: 0.875rem;
  font-weight: 300;
  color: var(--color-mova-muted);
}

.logbook-upload-hint {
  font-size: 0.75rem;
  font-weight: 300;
  color: rgba(111, 98, 88, 0.65);
}

.logbook-drawer-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  padding-top: 0.5rem;
}

.logbook-drawer-submit {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.875rem 2rem;
  border: 1px solid var(--color-mova-accent);
  background: var(--color-mova-accent);
  color: #fff;
  font-size: 0.6875rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background-color 0.2s ease, border-color 0.2s ease, opacity 0.2s ease;
}

.logbook-drawer-submit:hover:not(:disabled) {
  background: rgb(138 72 22);
  border-color: rgb(138 72 22);
}

.logbook-drawer-submit:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.logbook-drawer-cancel {
  padding: 0.875rem 1.75rem;
  border: 1px solid var(--color-mova-border);
  background: transparent;
  font-size: 0.6875rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--color-mova-ink);
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.logbook-drawer-cancel:hover {
  background: rgb(246 236 224 / 0.45);
}

@media (min-width: 640px) {
  .logbook-drawer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .logbook-drawer-field--full {
    grid-column: 1 / -1;
  }
}