.page-slug-home-editable {
  /* Display substitute for live Gardenia (see docs/HERO_SEO.md) */
  --monroe-font-display: "Bebas Neue", "Arial Narrow", sans-serif;
  --monroe-font-subtitle: "Montserrat", "Segoe UI", sans-serif;
  --monroe-color-impact-green: rgb(6, 129, 16);
  /* Shared layout rhythm — one scale for section gaps, gutters, and card padding */
  --monroe-home-content-max: var(--monroe-site-content-max, 1320px);
  --monroe-home-section-gutter: clamp(1rem, 4.2vw, 1.75rem);
  --monroe-home-stack-gap: clamp(2.25rem, 5.2vw, 3.5rem);
  --monroe-home-card-pad: clamp(1.5rem, 3.4vw, 2.5rem);
  --monroe-home-band-pad-y: clamp(2.75rem, 6.5vw, 4.5rem);
  --monroe-home-hero-pad-x: clamp(1rem, 3.5vw, 1.5rem);
  background-color: #f9f7f2;
  background-image: var(--monroe-site-bg);
  background-repeat: no-repeat, no-repeat, no-repeat, no-repeat, repeat;
  background-size: auto, auto, auto, auto, var(--monroe-paw-tile-size) auto;
  background-position: 0 0, 0 0, 0 0, 0 0, center 0;
  color: #1d2a2a;
}

/*
 * Responsive breakpoints (theme-wide):
 * - 768px  — primary phone / small tablet (homepage bands, inner shell, grids)
 * - 1200px — global nav drawer vs desktop bar (style.css; matches data-monroe-nav-drawer-max)
 * - 1400px — homepage fixed “On this page” rail (below this: sticky horizontal pills)
 * Prefer 768 over legacy 781/782 when adding new rules.
 */

.page-slug-home-editable .home-editable-shell {
  /* Horizontal overflow handled on body; shell stays visible so full-bleed sections work. */
  overflow-x: visible;
  overflow-y: visible;
}

.page-slug-home-editable .wp-site-blocks,
.page-slug-home-editable .site,
.page-slug-home-editable .site-content {
  margin: 0;
}

.page-slug-home-editable .home-editable-shell > .wp-block-group__inner-container {
  display: flex;
  flex-direction: column;
  gap: var(--monroe-home-stack-gap);
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

.page-slug-home-editable .home-editable-compare-bar {
  position: sticky;
  top: var(--monroe-nav-height, 0px);
  z-index: 20;
  margin-bottom: -2rem;
  backdrop-filter: blur(14px);
  background: rgba(16, 24, 24, 0.72);
  color: #f8f6f1;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.page-slug-home-editable .home-editable-compare-bar .wp-block-group__inner-container {
  max-width: var(--monroe-home-content-max);
  margin: 0 auto;
  padding: 0.9rem var(--monroe-home-section-gutter);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.page-slug-home-editable .home-editable-compare-bar p {
  margin: 0;
  font: 500 0.92rem/1.4 "Jost", "Segoe UI", sans-serif;
  letter-spacing: 0.02em;
}

.page-slug-home-editable .home-editable-compare-bar .wp-block-buttons {
  margin: 0;
}

.page-slug-home-editable .home-editable-compare-bar .wp-block-button__link {
  background: #fff;
  color: #111818;
  border-radius: 999px;
  padding: 0.8rem 1.15rem;
  font: 600 0.82rem/1 "Jost", "Segoe UI", sans-serif;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.page-slug-home-editable .home-editable-compare-bar .is-style-outline .wp-block-button__link {
  background: transparent;
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.35);
}

/*
  Hero height: avoid stacking min-height + heavy padding with the fixed-nav offset on
  .wp-block-cover__inner-container (style.css). Inline cover min-height from the editor
  is overridden here so the band stays proportionate on large displays.
*/
@media (max-width: 768px), (prefers-reduced-motion: reduce) {
  .page-slug-home-editable .home-editable-hero .wp-block-cover__video-background,
  body[data-page-alias="home-editable"] .home-editable-hero .wp-block-cover__video-background {
    display: none !important;
  }

  .page-slug-home-editable .home-editable-hero.wp-block-cover,
  .page-slug-home-editable .wp-block-cover.home-editable-hero,
  body[data-page-alias="home-editable"] .home-editable-hero.wp-block-cover,
  body[data-page-alias="home-editable"] .wp-block-cover.home-editable-hero {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
  }
}

.page-slug-home-editable .home-editable-hero.wp-block-cover,
.page-slug-home-editable .wp-block-cover.home-editable-hero {
  /* Wins over block editor inline min-height on the cover block */
  min-height: clamp(260px, 34vh, 420px) !important;
  /* Core `wp-block-cover` uses overflow:hidden; that clips CTA edges, hover lift, and shadows. */
  overflow: visible !important;
  padding: 0 var(--monroe-home-hero-pad-x) clamp(2.25rem, 4vw, 3rem);
  box-sizing: border-box;
}

.page-slug-home-editable .home-editable-hero-panel {
  max-width: 720px;
  margin-inline: auto;
  padding: 0.35rem 0 0.65rem;
  text-align: center;
}

.page-slug-home-editable .home-editable-hero-display {
  margin: 0 0 0.5rem;
  font-family: var(--monroe-font-display);
  font-size: clamp(2.25rem, 5.2vw, 3.75rem);
  font-weight: 400;
  line-height: 1.02;
  letter-spacing: 0.02em;
  text-transform: none;
  color: #fff;
}

.page-slug-home-editable .home-editable-hero .wp-block-buttons {
  margin-top: 1.15rem;
  margin-bottom: 0.75rem;
  padding-bottom: 2px;
}

.page-slug-home-editable .home-editable-hero .wp-block-cover__inner-container {
  width: 100%;
  max-width: var(--monroe-home-content-max);
  overflow: visible;
  padding-bottom: 2px;
}

.page-slug-home-editable .home-editable-hero .wp-block-cover__background {
  background:
    linear-gradient(120deg, rgba(11, 23, 24, 0.74) 12%, rgba(11, 23, 24, 0.38) 56%, rgba(11, 23, 24, 0.72) 100%),
    linear-gradient(180deg, rgba(0, 0, 0, 0.15), rgba(0, 0, 0, 0.4));
}

.page-slug-home-editable .home-editable-logo {
  max-width: 250px;
  margin-bottom: 1.2rem;
}

.page-slug-home-editable .home-editable-kicker {
  margin: 0 0 0.9rem;
  color: #f8d37d;
  font: 700 0.78rem/1.2 "Jost", "Segoe UI", sans-serif;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.page-slug-home-editable .home-editable-hero-title {
  margin: 0;
  color: rgb(255, 255, 255);
  font-family: var(--monroe-font-subtitle);
  font-size: clamp(1.05rem, 2.1vw, 1.375rem);
  font-weight: 500;
  line-height: 1.35;
}

.page-slug-home-editable .home-editable-hero-copy {
  /* Hidden: welcome text belongs in the intro section, not the hero (parity with live Duda hero). */
  display: none;
}

.page-slug-home-editable .home-editable-hero .wp-block-button__link {
  background: #2bb8f3;
  color: #082021;
  border-radius: 999px;
  padding: 1rem 1.45rem;
  font: 700 0.84rem/1 "Jost", "Segoe UI", sans-serif;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.page-slug-home-editable .home-editable-hero .is-style-outline .wp-block-button__link {
  background: transparent;
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.36);
}

.page-slug-home-editable .home-editable-hero .wp-block-button__link:hover,
.page-slug-home-editable .home-editable-hero .wp-block-button__link:focus {
  transform: translateY(-2px);
  box-shadow: 0 22px 36px rgba(8, 15, 15, 0.24);
}

.page-slug-home-editable .home-editable-section {
  padding: 0 var(--monroe-home-section-gutter);
  box-sizing: border-box;
}

.page-slug-home-editable .home-editable-section > .wp-block-group__inner-container,
.page-slug-home-editable .home-editable-band > .wp-block-group__inner-container {
  max-width: var(--monroe-home-content-max);
  margin: 0 auto;
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
}

.page-slug-home-editable .home-editable-intro-card,
.page-slug-home-editable .home-editable-feature-card,
.page-slug-home-editable .home-editable-events-card,
.page-slug-home-editable .home-editable-donate-card,
.page-slug-home-editable .home-editable-faq-card,
.page-slug-home-editable .home-editable-accomplishments-card,
.page-slug-home-editable .home-editable-games-card,
.page-slug-home-editable .home-editable-news-card,
.page-slug-home-editable .home-editable-contact-card {
  border-radius: 28px;
  border: 1px solid rgba(36, 72, 67, 0.12);
  box-shadow: 0 28px 60px rgba(31, 53, 51, 0.1);
  overflow: hidden;
}

.page-slug-home-editable .home-editable-intro-card {
  /* Keep flush below the hero — negative margins pull this card over the video and cover the CTAs (later sibling stacks above the cover). */
  margin-top: 0;
  background: linear-gradient(140deg, rgba(255, 250, 240, 0.94), rgba(255, 255, 255, 0.98));
  padding: var(--monroe-home-card-pad);
  position: relative;
  z-index: 3;
}

.page-slug-home-editable .home-editable-intro-card h2,
.page-slug-home-editable .home-editable-feature-card h2,
.page-slug-home-editable .home-editable-events-card h2,
.page-slug-home-editable .home-editable-donate-card h2,
.page-slug-home-editable .home-editable-faq-card h2,
.page-slug-home-editable .home-editable-band h2,
.page-slug-home-editable .home-editable-contact-card h2 {
  margin-top: 0;
  color: #153635;
  font-family: "Abril Fatface", Georgia, serif;
  font-size: clamp(2rem, 4vw, 3.6rem);
  line-height: 1;
}

.page-slug-home-editable .home-editable-contact-card h2.home-editable-heading-impact,
.page-slug-home-editable h2.home-editable-heading-impact {
  color: var(--monroe-color-impact-green);
  font-family: var(--monroe-font-display);
  font-size: clamp(1.75rem, 3.2vw, 2.25rem);
  font-weight: 400;
  line-height: 1.08;
  letter-spacing: 0.02em;
}

/* Intro card h2 uses impact style (matching live Gardenia/green heading) */
.page-slug-home-editable .home-editable-intro-card h2 {
  color: var(--monroe-color-impact-green);
  font-family: var(--monroe-font-display);
  font-size: clamp(1.75rem, 3.2vw, 2.25rem);
  font-weight: 400;
}

.page-slug-home-editable .home-editable-feature-card p,
.page-slug-home-editable .home-editable-events-card p,
.page-slug-home-editable .home-editable-donate-card p,
.page-slug-home-editable .home-editable-faq-card p,
.page-slug-home-editable .home-editable-accomplishments-card p,
.page-slug-home-editable .home-editable-games-card p,
.page-slug-home-editable .home-editable-band p,
.page-slug-home-editable .home-editable-contact-card p {
  font: 400 1.02rem/1.8 "Questrial", "Segoe UI", sans-serif;
  color: #405757;
}

/* Intro body copy: Montserrat on cream (parity); must follow generic card paragraph rules. */
.page-slug-home-editable .home-editable-intro-card p:not(.home-editable-pill) {
  font-family: var(--monroe-font-subtitle);
  font-size: 1.125rem;
  line-height: 1.5;
  color: #111818;
}

.page-slug-home-editable .home-editable-stat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 1rem;
}

.page-slug-home-editable .home-editable-stat {
  min-height: 100%;
  padding: 1.25rem;
  border-radius: 22px;
  background: #173a39;
  color: #fff;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.page-slug-home-editable .home-editable-stat.is-accent {
  background: linear-gradient(140deg, #0d766e, #164e63);
}

.page-slug-home-editable .home-editable-stat strong {
  display: block;
  margin-bottom: 0.35rem;
  color: #ffd27b;
  font: 700 0.76rem/1.2 "Jost", "Segoe UI", sans-serif;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.page-slug-home-editable .home-editable-stat h3 {
  margin: 0 0 0.55rem;
  color: #fff;
  font-family: "Abril Fatface", Georgia, serif;
  font-size: 1.75rem;
  line-height: 1.02;
}

.page-slug-home-editable .home-editable-stat p {
  margin: 0;
  color: rgba(255, 255, 255, 0.84);
  font-size: 0.95rem;
  line-height: 1.6;
}

/* Stat grid sits in the intro card’s right column; intro body `p` color is higher-specificity — keep tile copy light. */
.page-slug-home-editable .home-editable-intro-card .home-editable-stat p,
body[data-page-alias="home-editable"] .home-editable-intro-card .home-editable-stat p {
  color: rgba(255, 255, 255, 0.9);
  font-family: "Questrial", "Segoe UI", sans-serif;
  font-size: 0.95rem;
  line-height: 1.6;
}

.page-slug-home-editable .home-editable-feature-card {
  background: #fff;
}

.page-slug-home-editable .home-editable-events-card,
.page-slug-home-editable .home-editable-donate-card,
.page-slug-home-editable .home-editable-faq-card,
.page-slug-home-editable .home-editable-accomplishments-card {
  background: linear-gradient(140deg, rgba(255, 255, 255, 0.98), rgba(249, 246, 239, 0.96));
  padding: var(--monroe-home-card-pad);
}

/* --------------------------------------------------------------------------
   Donate band — three-up “Give” row (Donate / Wish list / Volunteer)
   -------------------------------------------------------------------------- */
.page-slug-home-editable .wp-block-columns.home-editable-give-grid,
body[data-page-alias="home-editable"] .wp-block-columns.home-editable-give-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1rem, 2.4vw, 1.5rem);
  width: 100%;
  max-width: min(1100px, 100%);
  margin: clamp(1.35rem, 3.5vw, 2.25rem) auto 0;
  padding-top: clamp(1.1rem, 2.8vw, 1.75rem);
  border-top: 1px solid rgba(36, 72, 67, 0.12);
  box-sizing: border-box;
}

@media (max-width: 768px) {
  .page-slug-home-editable .wp-block-columns.home-editable-give-grid,
  body[data-page-alias="home-editable"] .wp-block-columns.home-editable-give-grid {
    grid-template-columns: 1fr;
    max-width: none;
    width: 100%;
    margin-left: 0;
    margin-right: 0;
  }
}

.page-slug-home-editable .home-editable-give-grid > .wp-block-column,
body[data-page-alias="home-editable"] .home-editable-give-grid > .wp-block-column {
  min-width: 0;
  display: flex;
}

.page-slug-home-editable .home-editable-give-tile,
body[data-page-alias="home-editable"] .home-editable-give-tile {
  flex: 1;
  display: flex;
  flex-direction: column;
  width: 100%;
  min-height: 100%;
  margin: 0;
  padding: clamp(1.2rem, 2.8vw, 1.55rem);
  border-radius: 20px;
  border: 1px solid rgba(36, 72, 67, 0.11);
  background: linear-gradient(168deg, #ffffff 0%, rgba(252, 250, 246, 0.98) 55%, rgba(245, 250, 248, 0.92) 100%);
  box-shadow: 0 12px 32px rgba(17, 41, 41, 0.07);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.page-slug-home-editable .home-editable-give-tile:hover,
body[data-page-alias="home-editable"] .home-editable-give-tile:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 40px rgba(15, 118, 110, 0.1);
}

.page-slug-home-editable .home-editable-give-tile h3,
body[data-page-alias="home-editable"] .home-editable-give-tile h3 {
  margin: 0 0 0.45rem;
  padding-bottom: 0.5rem;
  border-bottom: 2px solid rgba(15, 118, 110, 0.2);
  font-family: "Abril Fatface", Georgia, serif;
  font-size: clamp(1.28rem, 2.4vw, 1.52rem);
  font-weight: 400;
  line-height: 1.12;
  color: #153635;
  letter-spacing: 0.01em;
}

.page-slug-home-editable .home-editable-give-tile p,
body[data-page-alias="home-editable"] .home-editable-give-tile p {
  margin: 0 0 1rem;
  flex: 1 1 auto;
  font: 400 0.97rem/1.62 "Questrial", "Segoe UI", sans-serif;
  color: #3d5555;
}

.page-slug-home-editable .home-editable-give-tile .wp-block-button,
body[data-page-alias="home-editable"] .home-editable-give-tile .wp-block-button {
  margin-top: auto;
  margin-bottom: 0;
  width: 100%;
}

.page-slug-home-editable .home-editable-give-tile .wp-block-button .wp-block-button__link,
body[data-page-alias="home-editable"] .home-editable-give-tile .wp-block-button .wp-block-button__link {
  width: 100%;
  box-sizing: border-box;
  justify-content: center;
  text-align: center;
  padding-top: 0.65rem;
  padding-bottom: 0.65rem;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-weight: 600;
  font-size: 0.92rem;
}

.page-slug-home-editable .home-editable-give-tile .wp-block-button.is-style-outline .wp-block-button__link,
body[data-page-alias="home-editable"] .home-editable-give-tile .wp-block-button.is-style-outline .wp-block-button__link {
  border-width: 2px;
}

/* In-page nav (`/#Volunteer`, etc.): `front-page.php` may set `id` on tiles. */
.page-slug-home-editable .home-editable-give-tile[id],
body[data-page-alias="home-editable"] .home-editable-give-tile[id] {
  scroll-margin-top: calc(
    var(--monroe-nav-height, 96px) + var(--monroe-sticky-wayfinding-offset, 0px) + var(--monroe-scroll-anchor-gap, 12px)
  );
}

/* --------------------------------------------------------------------------
   Membership tiers (pricing grid inside .home-editable-donate-card)
   -------------------------------------------------------------------------- */
.page-slug-home-editable .home-editable-membership-intro,
body[data-page-alias="home-editable"] .home-editable-membership-intro {
  max-width: 52rem;
  margin-bottom: clamp(1.25rem, 3vw, 2rem);
}

.page-slug-home-editable .home-editable-membership-intro > h2.wp-block-heading,
body[data-page-alias="home-editable"] .home-editable-membership-intro > h2.wp-block-heading {
  margin-top: 0;
}

.page-slug-home-editable .wp-block-columns.home-editable-membership-grid,
body[data-page-alias="home-editable"] .wp-block-columns.home-editable-membership-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(1rem, 2.8vw, 1.75rem);
  align-items: stretch;
  width: 100%;
  margin-top: 0;
  margin-bottom: 0;
}

@media (max-width: 1100px) {
  .page-slug-home-editable .wp-block-columns.home-editable-membership-grid,
  body[data-page-alias="home-editable"] .wp-block-columns.home-editable-membership-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 560px) {
  .page-slug-home-editable .wp-block-columns.home-editable-membership-grid,
  body[data-page-alias="home-editable"] .wp-block-columns.home-editable-membership-grid {
    grid-template-columns: 1fr;
  }
}

.page-slug-home-editable .home-editable-membership-grid > .wp-block-column,
body[data-page-alias="home-editable"] .home-editable-membership-grid > .wp-block-column {
  min-width: 0;
  display: flex;
}

.monroe-membership-under-construction {
  margin: 0;
  padding: clamp(1.25rem, 2.5vw, 1.75rem) clamp(1.25rem, 3vw, 2rem);
  border-radius: 16px;
  border: 1px solid rgba(23, 58, 57, 0.14);
  background: linear-gradient(180deg, rgba(47, 125, 11, 0.07), rgba(47, 125, 11, 0.03));
  box-shadow: 0 12px 28px rgba(17, 41, 41, 0.06);
  text-align: center;
}

.monroe-membership-under-construction p {
  margin: 0;
  max-width: 52ch;
  margin-inline: auto;
  font-size: clamp(1rem, 1.05rem + 0.2vw, 1.125rem);
  line-height: 1.65;
  color: #334155;
}

.monroe-membership-plans-shared--under-construction .home-editable-membership-intro {
  margin-bottom: clamp(0.75rem, 1.5vw, 1rem);
}

/* Monroe Content Hub shortcode grid (homepage + membership page) */
.home-editable-donate-card .home-editable-membership-grid--dynamic,
.monroe-membership-plans-shared .home-editable-membership-grid--dynamic,
.monroe-native-inner--membership .home-editable-membership-grid--dynamic {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(1rem, 2.8vw, 1.75rem);
  align-items: stretch;
  width: 100%;
  margin: 0;
  list-style: none;
  padding: 0;
}

@media (max-width: 1100px) {
  .home-editable-donate-card .home-editable-membership-grid--dynamic,
  .monroe-membership-plans-shared .home-editable-membership-grid--dynamic,
  .monroe-native-inner--membership .home-editable-membership-grid--dynamic {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 560px) {
  .home-editable-donate-card .home-editable-membership-grid--dynamic,
  .monroe-membership-plans-shared .home-editable-membership-grid--dynamic,
  .monroe-native-inner--membership .home-editable-membership-grid--dynamic {
    grid-template-columns: 1fr;
  }
}

.home-editable-donate-card .home-editable-membership-card-wrap,
.monroe-membership-plans-shared .home-editable-membership-card-wrap {
  min-width: 0;
  display: flex;
}

.home-editable-donate-card .home-editable-membership-card,
.monroe-membership-plans-shared .home-editable-membership-card {
  width: 100%;
  height: 100%;
  margin: 0;
  padding: clamp(1.25rem, 3vw, 1.65rem);
  border-radius: 24px;
  border: 1px solid rgba(36, 72, 67, 0.14);
  background: #fff;
  box-shadow: 0 18px 42px rgba(17, 41, 41, 0.09);
  display: flex;
  flex-direction: column;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.home-editable-donate-card .home-editable-membership-card.is-featured,
.monroe-membership-plans-shared .home-editable-membership-card.is-featured {
  position: relative;
  border: 2px solid #0f766e;
  box-shadow:
    0 18px 42px rgba(15, 118, 110, 0.18),
    0 0 0 1px rgba(15, 118, 110, 0.08);
  padding-top: clamp(2.35rem, 4vw, 2.75rem);
}

.home-editable-donate-card .home-editable-membership-card.is-featured::before,
.monroe-membership-plans-shared .home-editable-membership-card.is-featured::before {
  content: "Popular";
  position: absolute;
  top: 0.65rem;
  left: 50%;
  transform: translateX(-50%);
  padding: 0.28rem 0.85rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #0f766e, #134e4a);
  color: #fff;
  font: 700 0.68rem/1 "Jost", "Segoe UI", sans-serif;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.page-slug-home-editable .home-editable-membership-card,
body[data-page-alias="home-editable"] .home-editable-membership-card {
  width: 100%;
  height: 100%;
  margin: 0;
  padding: clamp(1.25rem, 3vw, 1.65rem);
  border-radius: 24px;
  border: 1px solid rgba(36, 72, 67, 0.14);
  background: #fff;
  box-shadow: 0 18px 42px rgba(17, 41, 41, 0.09);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.page-slug-home-editable .home-editable-membership-card.is-featured,
body[data-page-alias="home-editable"] .home-editable-membership-card.is-featured {
  position: relative;
  border: 2px solid #0f766e;
  box-shadow:
    0 18px 42px rgba(15, 118, 110, 0.18),
    0 0 0 1px rgba(15, 118, 110, 0.08);
  padding-top: clamp(2.35rem, 4vw, 2.75rem);
}

.page-slug-home-editable .home-editable-membership-card.is-featured::before,
body[data-page-alias="home-editable"] .home-editable-membership-card.is-featured::before {
  content: "Popular";
  position: absolute;
  top: 0.65rem;
  left: 50%;
  transform: translateX(-50%);
  padding: 0.28rem 0.85rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #0f766e, #134e4a);
  color: #fff;
  font: 700 0.68rem/1 "Jost", "Segoe UI", sans-serif;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.page-slug-home-editable .home-editable-membership-card > .wp-block-group__inner-container,
body[data-page-alias="home-editable"] .home-editable-membership-card > .wp-block-group__inner-container {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 100%;
  gap: 0;
}

.page-slug-home-editable .home-editable-membership-price,
body[data-page-alias="home-editable"] .home-editable-membership-price {
  margin: 0 0 0.35rem;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-weight: 800;
  font-size: clamp(2rem, 4vw, 2.65rem);
  line-height: 1.05;
  letter-spacing: -0.03em;
  color: #153635;
}

.page-slug-home-editable .home-editable-membership-period,
body[data-page-alias="home-editable"] .home-editable-membership-period {
  font-weight: 600;
  font-size: 0.42em;
  letter-spacing: 0.02em;
  color: rgba(21, 54, 53, 0.72);
  vertical-align: baseline;
  margin-left: 0.08em;
}

.page-slug-home-editable .home-editable-membership-card h3.wp-block-heading,
body[data-page-alias="home-editable"] .home-editable-membership-card h3.wp-block-heading {
  margin: 0 0 1rem;
  font-size: clamp(1.25rem, 2.4vw, 1.45rem);
  line-height: 1.2;
  color: #153635;
}

.page-slug-home-editable .home-editable-membership-perks,
body[data-page-alias="home-editable"] .home-editable-membership-perks {
  flex: 1 1 auto;
  margin: 0 0 1.25rem;
  padding: 0;
  padding-left: 0;
  list-style: none;
}

.page-slug-home-editable .home-editable-membership-perks li,
body[data-page-alias="home-editable"] .home-editable-membership-perks li {
  position: relative;
  margin: 0 0 0.55rem;
  padding-left: 1.45rem;
  font-size: 0.95rem;
  line-height: 1.45;
  color: #405757;
}

.page-slug-home-editable .home-editable-membership-perks li::before,
body[data-page-alias="home-editable"] .home-editable-membership-perks li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.35em;
  width: 0.55rem;
  height: 0.55rem;
  border-radius: 50%;
  background: #0f766e;
  box-shadow: 0 0 0 2px rgba(15, 118, 110, 0.2);
}

.page-slug-home-editable .home-editable-membership-card .wp-block-buttons,
body[data-page-alias="home-editable"] .home-editable-membership-card .wp-block-buttons {
  margin-top: auto;
  margin-bottom: 0;
  justify-content: center;
}

.page-slug-home-editable .home-editable-membership-card .wp-block-button,
body[data-page-alias="home-editable"] .home-editable-membership-card .wp-block-button {
  width: 100%;
}

.page-slug-home-editable .home-editable-membership-card .wp-block-button__link,
body[data-page-alias="home-editable"] .home-editable-membership-card .wp-block-button__link {
  width: 100%;
  justify-content: center;
  text-align: center;
  padding: 0.85rem 1.25rem;
}

@media (prefers-reduced-motion: reduce) {
  .page-slug-home-editable .home-editable-membership-card:hover,
  body[data-page-alias="home-editable"] .home-editable-membership-card:hover {
    transform: none;
  }
}

@media (hover: hover) and (pointer: fine) {
  .page-slug-home-editable .home-editable-membership-card:hover,
  body[data-page-alias="home-editable"] .home-editable-membership-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 22px 48px rgba(17, 41, 41, 0.12);
  }
}

/* Coarse / no-hover: never leave cards translated after tap */
@media (hover: none), (pointer: coarse) {
  .page-slug-home-editable .home-editable-membership-card:hover,
  body[data-page-alias="home-editable"] .home-editable-membership-card:hover {
    transform: none;
  }
}

@media (max-width: 768px) {
  .page-slug-home-editable .home-editable-membership-card.is-featured,
  body[data-page-alias="home-editable"] .home-editable-membership-card.is-featured {
    padding-top: clamp(1.25rem, 3vw, 1.65rem);
  }

  .page-slug-home-editable .home-editable-membership-card.is-featured::before,
  body[data-page-alias="home-editable"] .home-editable-membership-card.is-featured::before {
    position: static;
    transform: none;
    display: table;
    margin: 0 auto 0.75rem;
    left: auto;
  }
}

.page-slug-home-editable .home-editable-feature-card .wp-block-columns {
  gap: 0;
}

.page-slug-home-editable .home-editable-feature-media img {
  width: 100%;
  height: 100%;
  min-height: 420px;
  object-fit: cover;
}

.page-slug-home-editable .home-editable-upcoming-event-hero__grid,
body[data-page-alias="home-editable"] .home-editable-upcoming-event-hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  gap: 0;
  align-items: stretch;
}

.page-slug-home-editable .home-editable-upcoming-event-hero__media-col,
body[data-page-alias="home-editable"] .home-editable-upcoming-event-hero__media-col {
  min-height: 100%;
}

.page-slug-home-editable .home-editable-upcoming-event-hero__media,
body[data-page-alias="home-editable"] .home-editable-upcoming-event-hero__media {
  margin: 0;
  height: 100%;
  min-height: 420px;
}

.page-slug-home-editable .home-editable-upcoming-event-hero__media img,
body[data-page-alias="home-editable"] .home-editable-upcoming-event-hero__media img {
  width: 100%;
  height: 100%;
  min-height: 420px;
  object-fit: cover;
  display: block;
}

.page-slug-home-editable .home-editable-upcoming-event-hero__media--placeholder,
body[data-page-alias="home-editable"] .home-editable-upcoming-event-hero__media--placeholder {
  min-height: 420px;
  background: linear-gradient(135deg, rgba(15, 118, 110, 0.18), rgba(80, 200, 120, 0.22));
}

.page-slug-home-editable .home-editable-upcoming-event-hero__copy,
body[data-page-alias="home-editable"] .home-editable-upcoming-event-hero__copy {
  padding: var(--monroe-home-card-pad);
}

.page-slug-home-editable .home-editable-upcoming-event-hero__date,
body[data-page-alias="home-editable"] .home-editable-upcoming-event-hero__date {
  margin-bottom: 0.85rem;
}

.page-slug-home-editable .home-editable-upcoming-event-hero__kicker,
body[data-page-alias="home-editable"] .home-editable-upcoming-event-hero__kicker {
  margin-bottom: 0.65rem;
}

@media (max-width: 768px) {
  .page-slug-home-editable .home-editable-upcoming-event-hero__grid,
  body[data-page-alias="home-editable"] .home-editable-upcoming-event-hero__grid {
    grid-template-columns: 1fr;
  }

  .page-slug-home-editable .home-editable-upcoming-event-hero__media,
  body[data-page-alias="home-editable"] .home-editable-upcoming-event-hero__media,
  .page-slug-home-editable .home-editable-upcoming-event-hero__media img,
  body[data-page-alias="home-editable"] .home-editable-upcoming-event-hero__media img,
  .page-slug-home-editable .home-editable-upcoming-event-hero__media--placeholder,
  body[data-page-alias="home-editable"] .home-editable-upcoming-event-hero__media--placeholder {
    min-height: 260px;
  }
}

.page-slug-home-editable .home-editable-events-band,
body[data-page-alias="home-editable"] .home-editable-events-band {
  display: flex;
  flex-direction: column;
  gap: clamp(1.25rem, 2.5vw, 2rem);
  scroll-margin-top: calc(
    var(--monroe-nav-height, 96px) + var(--monroe-sticky-wayfinding-offset, 0px) + var(--monroe-scroll-anchor-gap, 12px)
  );
}

.page-slug-home-editable .home-editable-events-band .home-editable-events-artwork,
body[data-page-alias="home-editable"] .home-editable-events-band .home-editable-events-artwork {
  margin: 0;
}

.page-slug-home-editable .home-editable-events-artwork .hs-media,
body[data-page-alias="home-editable"] .home-editable-events-artwork .hs-media {
  background: #f8fafc;
}

.page-slug-home-editable .home-editable-events-artwork .hs-media img,
body[data-page-alias="home-editable"] .home-editable-events-artwork .hs-media img {
  object-fit: contain;
  object-position: center bottom;
}

.page-slug-home-editable .home-editable-events-artwork .hs-media--qr,
body[data-page-alias="home-editable"] .home-editable-events-artwork .hs-media--qr,
.home-editable-events-artwork .hs-media--qr {
  align-self: stretch;
}

.page-slug-home-editable .home-editable-upcoming-event-section,
body[data-page-alias="home-editable"] .home-editable-upcoming-event-section {
  margin-top: clamp(2rem, 4vw, 3rem);
  padding: 0 var(--monroe-home-section-gutter);
  box-sizing: border-box;
}

.page-slug-home-editable .home-editable-events-band .home-editable-upcoming-event-section,
body[data-page-alias="home-editable"] .home-editable-events-band .home-editable-upcoming-event-section {
  margin-top: 0;
  padding: 0;
}

.page-slug-home-editable #FeaturedPets,
body[data-page-alias="home-editable"] #FeaturedPets {
  margin-top: clamp(2rem, 4vw, 3rem);
  scroll-margin-top: calc(
    var(--monroe-nav-height, 96px) + var(--monroe-sticky-wayfinding-offset, 0px) + var(--monroe-scroll-anchor-gap, 12px)
  );
}

.page-slug-home-editable #FeaturedPets > h2.wp-block-heading,
body[data-page-alias="home-editable"] #FeaturedPets > h2.wp-block-heading {
  margin-top: 0;
  margin-bottom: 0.65rem;
  color: #153635;
  font-family: "Abril Fatface", Georgia, serif;
  font-size: clamp(2rem, 4vw, 3.6rem);
  line-height: 1.05;
}

.page-slug-home-editable #FeaturedPets > p.wp-block-paragraph,
body[data-page-alias="home-editable"] #FeaturedPets > p.wp-block-paragraph {
  max-width: 42rem;
  margin-top: 0;
  margin-bottom: 1.15rem;
  color: #3d524f;
}

.page-slug-home-editable .home-editable-feature-copy {
  padding: var(--monroe-home-card-pad);
}

.page-slug-home-editable .home-editable-section-label {
  margin: 0 0 0.75rem;
  color: #0f766e;
  font: 700 0.8rem/1.2 "Jost", "Segoe UI", sans-serif;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.page-slug-home-editable .home-editable-band {
  padding: var(--monroe-home-band-pad-y) var(--monroe-home-section-gutter);
  box-sizing: border-box;
  background:
    radial-gradient(circle at top right, rgba(13, 118, 110, 0.12), transparent 28%),
    #fffdf9;
}

.page-slug-home-editable .home-editable-band .home-editable-band-head {
  max-width: 760px;
  margin-bottom: 2rem;
}

.page-slug-home-editable .home-editable-pet-grid {
  gap: 1.25rem;
}

.page-slug-home-editable .home-editable-pet-card {
  height: 100%;
  border-radius: 26px;
  overflow: hidden;
  border: 1px solid rgba(36, 72, 67, 0.12);
  background: #fff;
  box-shadow: 0 24px 48px rgba(17, 41, 41, 0.08);
}

.page-slug-home-editable .home-editable-pet-card img {
  width: 100%;
  aspect-ratio: 4 / 4.2;
  object-fit: cover;
}

.page-slug-home-editable .home-editable-pet-card .wp-block-group__inner-container {
  padding: 1.35rem;
}

.page-slug-home-editable .home-editable-pet-card h3 {
  margin: 0 0 0.5rem;
  color: #153635;
  font-family: "Abril Fatface", Georgia, serif;
  font-size: 1.7rem;
}

.page-slug-home-editable .home-editable-pet-card p {
  margin-bottom: 1rem;
}

.page-slug-home-editable .home-editable-pet-card .wp-block-button__link,
.page-slug-home-editable .home-editable-feature-card .wp-block-button__link,
.page-slug-home-editable .home-editable-news-card .wp-block-button__link,
.page-slug-home-editable .home-editable-contact-card .wp-block-button__link {
  background: #173a39;
  color: #fff;
  border-radius: 999px;
  padding: 0.95rem 1.2rem;
  font: 700 0.8rem/1 "Jost", "Segoe UI", sans-serif;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.page-slug-home-editable .home-editable-feature-card .wp-block-button__link:hover,
.page-slug-home-editable .home-editable-pet-card .wp-block-button__link:hover,
.page-slug-home-editable .home-editable-news-card .wp-block-button__link:hover,
.page-slug-home-editable .home-editable-contact-card .wp-block-button__link:hover,
.page-slug-home-editable .home-editable-feature-card .wp-block-button__link:focus,
.page-slug-home-editable .home-editable-pet-card .wp-block-button__link:focus,
.page-slug-home-editable .home-editable-news-card .wp-block-button__link:focus,
.page-slug-home-editable .home-editable-contact-card .wp-block-button__link:focus {
  transform: translateY(-2px);
  box-shadow: 0 18px 34px rgba(17, 41, 41, 0.16);
}

.page-slug-home-editable .home-editable-news-card.is-style-monroe-news-band,
body[data-page-alias="home-editable"] .home-editable-news-card.is-style-monroe-news-band {
  background: linear-gradient(135deg, #1f4c49, #2f736c);
  color: #fff;
  padding: var(--monroe-home-card-pad);
  overflow: visible;
}

/* White copy only on the band intro blocks — not on the newsletter embed (paragraphs there must stay dark). */
.page-slug-home-editable .home-editable-news-card.is-style-monroe-news-band .wp-block-group__inner-container > h2.wp-block-heading,
body[data-page-alias="home-editable"] .home-editable-news-card.is-style-monroe-news-band .wp-block-group__inner-container > h2.wp-block-heading {
  color: #fff;
}

.page-slug-home-editable .home-editable-news-card.is-style-monroe-news-band .wp-block-group__inner-container > p.wp-block-paragraph:not(.home-editable-section-label),
body[data-page-alias="home-editable"] .home-editable-news-card.is-style-monroe-news-band .wp-block-group__inner-container > p.wp-block-paragraph:not(.home-editable-section-label) {
  color: rgba(255, 255, 255, 0.9);
}

/* Monroe block style “Inset panel” — cream card (registered in functions.php; no theme.json hook). */
.page-slug-home-editable .is-style-monroe-inset-panel {
  box-sizing: border-box;
  width: 100%;
  max-width: 100%;
  margin-top: clamp(1rem, 3vw, 1.75rem);
  padding: var(--monroe-home-card-pad);
  border-radius: 22px;
  background: var(--wp--custom--monroe--surface--inset-bg, #fbfaf7);
  border: 1px solid var(--wp--custom--monroe--surface--inset-border, rgba(23, 58, 57, 0.18));
  box-shadow: 0 18px 42px rgba(17, 41, 41, 0.12);
  color: var(--wp--custom--monroe--surface--inset-text, #1f3332);
}

.page-slug-home-editable .home-editable-banner.is-style-monroe-inset-panel .home-editable-pill {
  background: var(--wp--custom--monroe--surface--inset-pill-bg, rgba(15, 118, 110, 0.16));
  color: var(--wp--custom--monroe--surface--inset-pill-text, #0a5f59);
}

.page-slug-home-editable .home-editable-banner.is-style-monroe-inset-panel h3.wp-block-heading {
  margin-top: 0;
  color: #153635;
}

.page-slug-home-editable .home-editable-banner.is-style-monroe-inset-panel p:not(.home-editable-pill) {
  color: #405757;
}

.page-slug-home-editable .home-editable-news-card.is-style-monroe-news-band .home-editable-banner.is-style-monroe-inset-panel .wp-block-buttons {
  margin-top: 1rem;
}

.page-slug-home-editable .home-editable-news-card.is-style-monroe-news-band .wp-block-group__inner-container,
body[data-page-alias="home-editable"] .home-editable-news-card.is-style-monroe-news-band .wp-block-group__inner-container {
  overflow: visible;
}

/*
 * Vet sponsor embed (.sponsor-widget-shell) ships inline CSS for a light canvas.
 * On the news band (dark teal gradient), reset header/title/subtitle to light text.
 * Sponsor cards keep their own light tile backgrounds + dark copy.
 */
.page-slug-home-editable .home-editable-news-card.is-style-monroe-news-band .sponsor-widget-shell,
body[data-page-alias="home-editable"] .home-editable-news-card.is-style-monroe-news-band .sponsor-widget-shell {
  color: rgba(248, 250, 251, 0.96);
}

.page-slug-home-editable .home-editable-news-card.is-style-monroe-news-band .sponsor-widget-shell .sponsor-widget,
body[data-page-alias="home-editable"] .home-editable-news-card.is-style-monroe-news-band .sponsor-widget-shell .sponsor-widget {
  color: rgba(248, 250, 251, 0.96);
}

.page-slug-home-editable .home-editable-news-card.is-style-monroe-news-band .sponsor-widget-shell .sponsor-widget__title,
body[data-page-alias="home-editable"] .home-editable-news-card.is-style-monroe-news-band .sponsor-widget-shell .sponsor-widget__title {
  background: none !important;
  -webkit-background-clip: unset !important;
  background-clip: unset !important;
  color: #f8fafc !important;
  -webkit-text-fill-color: #f8fafc !important;
  text-shadow: 0 2px 24px rgba(0, 0, 0, 0.35);
}

.page-slug-home-editable .home-editable-news-card.is-style-monroe-news-band .sponsor-widget-shell .sponsor-widget__title::after,
body[data-page-alias="home-editable"] .home-editable-news-card.is-style-monroe-news-band .sponsor-widget-shell .sponsor-widget__title::after {
  background: linear-gradient(90deg, rgba(167, 243, 208, 0.95) 0%, rgba(45, 212, 191, 0.92) 100%);
  box-shadow: 0 6px 18px rgba(16, 185, 129, 0.35);
}

.page-slug-home-editable .home-editable-news-card.is-style-monroe-news-band .sponsor-widget-shell .sponsor-widget__subtitle,
body[data-page-alias="home-editable"] .home-editable-news-card.is-style-monroe-news-band .sponsor-widget-shell .sponsor-widget__subtitle {
  color: rgba(255, 255, 255, 0.88) !important;
}

.page-slug-home-editable .home-editable-auction-sponsors,
body[data-page-alias="home-editable"] .home-editable-auction-sponsors {
  margin-top: clamp(1.25rem, 3vw, 2rem);
}

/* Sponsor grids (Community Vet Partners + Furry Friends Auction) center their cards,
   especially when they collapse to a single column on mobile (the widget's own CSS
   leaves the lone column left-aligned). Higher specificity beats the widget's inline <style>. */
.page-slug-home-editable .sponsor-widget-shell .sponsor-grid,
body[data-page-alias="home-editable"] .sponsor-widget-shell .sponsor-grid {
  justify-content: center;
  justify-items: center;
}

.page-slug-home-editable .sponsor-widget-shell .sponsor-widget__header,
body[data-page-alias="home-editable"] .sponsor-widget-shell .sponsor-widget__header {
  text-align: center;
}

@media (max-width: 768px) {
  .page-slug-home-editable .sponsor-widget-shell .sponsor-widget__title,
  body[data-page-alias="home-editable"] .sponsor-widget-shell .sponsor-widget__title {
    font-size: clamp(1.35rem, 6vw, 1.9rem) !important;
    line-height: 1.15 !important;
    overflow-wrap: break-word;
    word-break: break-word;
    padding-inline: 0.5rem;
  }

  .page-slug-home-editable .sponsor-widget-shell .sponsor-grid,
  body[data-page-alias="home-editable"] .sponsor-widget-shell .sponsor-grid {
    grid-template-columns: minmax(0, 320px);
    margin-inline: auto;
  }

  .page-slug-home-editable .sponsor-widget-shell .sponsor-card,
  body[data-page-alias="home-editable"] .sponsor-widget-shell .sponsor-card {
    width: 100%;
    margin-inline: auto;
  }
}

.page-slug-home-editable .home-editable-news-card .wp-block-button__link {
  background: #fff;
  color: #153635;
}

/* The bundled newsletter widget (.hs-news-section) was getting cut off on the right on narrow
   screens. Two causes: (1) no box-sizing reset, so padded boxes added padding on top of width;
   (2) its inner `1fr` grid (.hs-grid) items default to `min-width:auto`, forcing the track to the
   item's min-content width (~302px) and blowing past the ~265px container — which .hs-card then
   clips via overflow:hidden. Fix box-sizing + let grid items shrink + allow long content to wrap. */
.page-slug-home-editable .monroe-home-newsletter-slot .hs-news-section,
.page-slug-home-editable .monroe-home-newsletter-slot .hs-news-section *,
body[data-page-alias="home-editable"] .monroe-home-newsletter-slot .hs-news-section,
body[data-page-alias="home-editable"] .monroe-home-newsletter-slot .hs-news-section * {
  box-sizing: border-box;
}

.page-slug-home-editable .monroe-home-newsletter-slot .hs-news-section,
body[data-page-alias="home-editable"] .monroe-home-newsletter-slot .hs-news-section {
  overflow-wrap: anywhere;
}

.page-slug-home-editable .monroe-home-newsletter-slot .hs-news-section .hs-card,
.page-slug-home-editable .monroe-home-newsletter-slot .hs-news-section .hs-body,
.page-slug-home-editable .monroe-home-newsletter-slot .hs-news-section .hs-grid,
.page-slug-home-editable .monroe-home-newsletter-slot .hs-news-section .hs-grid > *,
.page-slug-home-editable .monroe-home-newsletter-slot .hs-news-section .hs-box,
body[data-page-alias="home-editable"] .monroe-home-newsletter-slot .hs-news-section .hs-card,
body[data-page-alias="home-editable"] .monroe-home-newsletter-slot .hs-news-section .hs-body,
body[data-page-alias="home-editable"] .monroe-home-newsletter-slot .hs-news-section .hs-grid,
body[data-page-alias="home-editable"] .monroe-home-newsletter-slot .hs-news-section .hs-grid > *,
body[data-page-alias="home-editable"] .monroe-home-newsletter-slot .hs-news-section .hs-box {
  min-width: 0;
}

/* Inner newsletter card must span the full band (shortcode wrapper was shrinking to a grey sliver). */
.page-slug-home-editable .home-editable-news-card .wp-block-shortcode,
.page-slug-home-editable .home-editable-news-card .monroe-home-newsletter-slot,
.page-slug-home-editable .home-editable-newsletter-section .wp-block-shortcode,
.page-slug-home-editable .home-editable-newsletter-section .monroe-home-newsletter-slot,
body[data-page-alias="home-editable"] .home-editable-news-card .wp-block-shortcode,
body[data-page-alias="home-editable"] .home-editable-news-card .monroe-home-newsletter-slot {
  width: 100%;
  max-width: none;
  min-width: 0;
  display: block;
  clear: both;
  margin-top: clamp(1rem, 3vw, 1.75rem);
  box-sizing: border-box;
}

.page-slug-home-editable .home-editable-news-card .monroe-home-newsletter-slot .hs-news-section,
.page-slug-home-editable .home-editable-news-card .monroe-home-newsletter-slot #hs-news-2025review,
.page-slug-home-editable .home-editable-news-card .wp-block-shortcode .hs-news-section,
.page-slug-home-editable .home-editable-news-card .wp-block-shortcode #hs-news-2025review,
body[data-page-alias="home-editable"] .home-editable-news-card .monroe-home-newsletter-slot .hs-news-section,
body[data-page-alias="home-editable"] .home-editable-news-card .monroe-home-newsletter-slot #hs-news-2025review {
  width: 100%;
  max-width: none;
  box-sizing: border-box;
  position: relative !important;
  inset: auto !important;
  opacity: 1 !important;
  visibility: visible !important;
  display: block !important;
  overflow: visible;
}

/* Read more / show less collapse for long homepage prose (newsletter letter etc.) */
.monroe-home-newsletter-slot.is-collapsible {
  position: relative;
  max-height: var(--monroe-readmore-max, 520px);
  overflow: hidden;
}

.monroe-home-newsletter-slot.is-collapsible::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 120px;
  pointer-events: none;
  background: linear-gradient(to bottom, rgba(255, 250, 242, 0), rgba(255, 250, 242, 0.96));
}

.monroe-home-newsletter-slot.is-collapsible.is-expanded {
  max-height: none;
  overflow: visible;
}

.monroe-home-newsletter-slot.is-collapsible.is-expanded::after {
  display: none;
}

.monroe-readmore-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  margin: 0.9rem auto 0;
  padding: 0.55rem 1.4rem;
  border-radius: 999px;
  border: 1px solid rgba(15, 118, 110, 0.4);
  background: #fffaf2;
  color: #0b534e;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-weight: 700;
  font-size: 0.82rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  cursor: pointer;
}

.monroe-readmore-toggle:hover,
.monroe-readmore-toggle:focus-visible {
  background: rgba(15, 118, 110, 0.1);
  outline: none;
}

.monroe-readmore-toggle:focus-visible {
  outline: 2px solid #0f766e;
  outline-offset: 2px;
}

.home-editable-newsletter-section .home-editable-news-card {
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

.home-editable-newsletter-section .monroe-readmore-toggle {
  align-self: center;
}

.page-slug-home-editable .home-editable-news-card .hs-news-section .hs-lightbox,
.page-slug-home-editable .home-editable-news-card #hs-news-2025review .hs-lightbox,
body[data-page-alias="home-editable"] .home-editable-news-card .hs-news-section .hs-lightbox {
  position: fixed !important;
  inset: 0;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.page-slug-home-editable .home-editable-news-card .hs-news-section .hs-lightbox.active,
.page-slug-home-editable .home-editable-news-card #hs-news-2025review .hs-lightbox.active,
body[data-page-alias="home-editable"] .home-editable-news-card .hs-news-section .hs-lightbox.active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.page-slug-home-editable .home-editable-news-card .hs-lightbox [data-hs-lb-img]:not([src]),
.page-slug-home-editable .home-editable-news-card .hs-lightbox:not(.active) [data-hs-lb-img],
body[data-page-alias="home-editable"] .home-editable-news-card .hs-lightbox [data-hs-lb-img]:not([src]) {
  display: none !important;
}

/* Embedded newsletter HTML defines its own palette; undo inherited band colors. */
.page-slug-home-editable .home-editable-news-card #hs-news-2025review,
.page-slug-home-editable .home-editable-news-card .hs-news-section,
body[data-page-alias="home-editable"] .home-editable-news-card #hs-news-2025review,
body[data-page-alias="home-editable"] .home-editable-news-card .hs-news-section {
  color: var(--hs-ink, #0f172a);
}

.page-slug-home-editable .home-editable-news-card #hs-news-2025review .hs-letter,
.page-slug-home-editable .home-editable-news-card #hs-news-2025review .hs-letter p,
.page-slug-home-editable .home-editable-news-card #hs-news-2025review .hs-improvements li,
.page-slug-home-editable .home-editable-news-card .hs-news-section .hs-letter,
.page-slug-home-editable .home-editable-news-card .hs-news-section .hs-letter p,
.page-slug-home-editable .home-editable-news-card .hs-news-section .hs-improvements li,
body[data-page-alias="home-editable"] .home-editable-news-card #hs-news-2025review .hs-letter,
body[data-page-alias="home-editable"] .home-editable-news-card #hs-news-2025review .hs-letter p,
body[data-page-alias="home-editable"] .home-editable-news-card #hs-news-2025review .hs-improvements li,
body[data-page-alias="home-editable"] .home-editable-news-card .hs-news-section .hs-letter,
body[data-page-alias="home-editable"] .home-editable-news-card .hs-news-section .hs-letter p,
body[data-page-alias="home-editable"] .home-editable-news-card .hs-news-section .hs-improvements li {
  color: var(--hs-muted, #475569);
}

.page-slug-home-editable .home-editable-news-card #hs-news-2025review .hs-head .hs-title,
.page-slug-home-editable .home-editable-news-card #hs-news-2025review .hs-section-title,
.page-slug-home-editable .home-editable-news-card .hs-news-section .hs-head .hs-title,
.page-slug-home-editable .home-editable-news-card .hs-news-section .hs-section-title,
body[data-page-alias="home-editable"] .home-editable-news-card #hs-news-2025review .hs-head .hs-title,
body[data-page-alias="home-editable"] .home-editable-news-card #hs-news-2025review .hs-section-title,
body[data-page-alias="home-editable"] .home-editable-news-card .hs-news-section .hs-head .hs-title,
body[data-page-alias="home-editable"] .home-editable-news-card .hs-news-section .hs-section-title {
  color: var(--hs-teal, #0f766e);
}

.page-slug-home-editable .home-editable-sponsors {
  padding: var(--monroe-home-band-pad-y) var(--monroe-home-section-gutter)
    clamp(3rem, 7vw, 5rem);
  box-sizing: border-box;
}

.page-slug-home-editable .home-editable-sponsors > .wp-block-group__inner-container {
  margin: 0 auto;
  width: 100%;
  max-width: var(--monroe-home-content-max);
  min-width: 0;
  box-sizing: border-box;
}

/* Shortcode/HTML wrappers must span the sponsors band (otherwise marquee shrinks left). */
.page-slug-home-editable .home-editable-sponsors .wp-block-shortcode,
.page-slug-home-editable .home-editable-sponsors .wp-block-html {
  width: 100%;
  max-width: none;
}

.page-slug-home-editable .home-editable-sponsor-grid {
  gap: 1rem;
}

.page-slug-home-editable .home-editable-sponsor {
  height: 100%;
  padding: 1.4rem;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(36, 72, 67, 0.12);
  box-shadow: 0 22px 44px rgba(17, 41, 41, 0.08);
}

.page-slug-home-editable .home-editable-sponsor img {
  width: 100%;
  height: 110px;
  object-fit: contain;
}

.page-slug-home-editable .home-editable-sponsor p {
  margin: 1rem 0 0;
  text-align: center;
  font: 600 0.95rem/1.4 "Jost", "Segoe UI", sans-serif;
  color: #193736;
}

.page-slug-home-editable .home-editable-contact-card {
  background:
    linear-gradient(135deg, rgba(255, 249, 233, 0.94), rgba(255, 255, 255, 0.98)),
    #fff;
  padding: var(--monroe-home-card-pad);
}

.page-slug-home-editable .home-editable-contact-card .wp-block-buttons {
  margin-top: 1.4rem;
}

.page-slug-home-editable .home-editable-events-grid,
.page-slug-home-editable .home-editable-action-grid,
.page-slug-home-editable .home-editable-faq-grid {
  gap: 1.2rem;
}

.page-slug-home-editable .home-editable-event-tile,
.page-slug-home-editable .home-editable-action-tile,
.page-slug-home-editable .home-editable-faq-tile {
  height: 100%;
  padding: 1.35rem;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(24, 58, 57, 0.1);
  box-shadow: 0 18px 38px rgba(17, 41, 41, 0.08);
}

.page-slug-home-editable .home-editable-event-tile h3,
.page-slug-home-editable .home-editable-action-tile h3,
.page-slug-home-editable .home-editable-faq-tile h3 {
  margin: 0 0 0.55rem;
  color: #153635;
  font-family: "Abril Fatface", Georgia, serif;
  font-size: 1.7rem;
  line-height: 1.06;
}

.page-slug-home-editable .home-editable-event-kicker {
  margin: 0 0 0.65rem;
  color: #0f766e;
  font: 700 0.74rem/1.2 "Jost", "Segoe UI", sans-serif;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.page-slug-home-editable .home-editable-event-tile p,
.page-slug-home-editable .home-editable-action-tile p,
.page-slug-home-editable .home-editable-faq-tile p {
  margin-bottom: 1rem;
}

.page-slug-home-editable .home-editable-social-split .wp-block-columns,
.page-slug-home-editable .home-editable-faq-grid .wp-block-columns,
.page-slug-home-editable .home-editable-action-grid .wp-block-columns {
  align-items: stretch;
}

.page-slug-home-editable .home-editable-social-card {
  height: 100%;
  padding: var(--monroe-home-card-pad);
  border-radius: 28px;
  background: linear-gradient(160deg, #163433, #245857);
  color: #fff;
  box-shadow: 0 24px 48px rgba(17, 41, 41, 0.16);
}

/* Feed-only social band: no intro copy — centered Facebook widget. */
.page-slug-home-editable .home-editable-social-section--feed-only,
body[data-page-alias="home-editable"] .home-editable-social-section--feed-only {
  padding-block: clamp(0.5rem, 2vw, 1rem);
}

.page-slug-home-editable .home-editable-social-card--feed-only,
body[data-page-alias="home-editable"] .home-editable-social-card--feed-only {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: clamp(0.75rem, 2vw, 1.25rem);
  background: transparent;
  box-shadow: none;
  border-radius: 0;
}

.page-slug-home-editable .home-editable-social-card--feed-only .home-editable-social-embed,
body[data-page-alias="home-editable"] .home-editable-social-card--feed-only .home-editable-social-embed {
  margin-top: 0;
  width: 100%;
  max-width: 500px;
  margin-inline: auto;
}

.page-slug-home-editable .home-editable-social-card h2,
.page-slug-home-editable .home-editable-social-card p {
  color: #fff;
}

.page-slug-home-editable .home-editable-social-card p {
  color: rgba(255, 255, 255, 0.84);
}

.page-slug-home-editable .home-editable-social-card .wp-block-button__link {
  background: #fff;
  color: #163433;
}

.page-slug-home-editable .home-editable-news-card .home-editable-section-label,
.page-slug-home-editable .home-editable-social-card .home-editable-section-label {
  color: #ffd27b;
}

.page-slug-home-editable .home-editable-news-card .wp-block-buttons,
.page-slug-home-editable .home-editable-social-card .wp-block-buttons {
  margin-top: 1.2rem;
}

/* Facebook Page plugin — bundled embed (shortcode); avoids wp_kses stripping iframes from HTML blocks.
   The FB plugin renders at a FIXED pixel width (max 500) set in its URL, so the iframe element width
   must match that width or the feed looks clipped/zoomed (too narrow) or gutter-gapped (too wide).
   `initFacebookEmbed()` in legacy-fixes.js measures the container and sizes the iframe + URL to match. */
.page-slug-home-editable .home-editable-social-embed,
body[data-page-alias="home-editable"] .home-editable-social-embed {
  margin-top: clamp(1.25rem, 3vw, 1.75rem);
  width: 100%;
  max-width: 500px;
  margin-inline: auto;
}

.page-slug-home-editable .home-editable-social-embed__frame,
body[data-page-alias="home-editable"] .home-editable-social-embed__frame {
  background: linear-gradient(135deg, #50c878, #72cbff);
  padding: 2px;
  border-radius: 18px;
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.22);
}

.page-slug-home-editable .home-editable-social-embed__chrome,
body[data-page-alias="home-editable"] .home-editable-social-embed__chrome {
  border-radius: 16px;
  overflow: hidden;
  background: #ffffff;
}

.page-slug-home-editable .home-editable-social-embed__viewport,
body[data-page-alias="home-editable"] .home-editable-social-embed__viewport {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
  overflow: visible;
  background: #ffffff;
  min-height: 630px;
}

.page-slug-home-editable .home-editable-social-embed__iframe,
body[data-page-alias="home-editable"] .home-editable-social-embed__iframe {
  position: relative;
  z-index: 2;
  display: block;
  flex-shrink: 0;
  width: 500px;
  max-width: 100%;
  /* JS sets exact px width + height to match the FB plugin URL params. */
  height: 690px;
  border: 0;
  background: #ffffff;
}

.page-slug-home-editable .home-editable-social-embed__loader,
body[data-page-alias="home-editable"] .home-editable-social-embed__loader {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.85rem;
  padding: 1.25rem;
  background: linear-gradient(180deg, #f8fafc 0%, #eef2f7 100%);
  transition: opacity 0.25s ease, visibility 0.25s ease;
}

.page-slug-home-editable .home-editable-social-embed.is-loading .home-editable-social-embed__loader,
body[data-page-alias="home-editable"] .home-editable-social-embed.is-loading .home-editable-social-embed__loader {
  opacity: 1;
  visibility: visible;
}

.page-slug-home-editable .home-editable-social-embed:not(.is-loading) .home-editable-social-embed__loader,
body[data-page-alias="home-editable"] .home-editable-social-embed:not(.is-loading) .home-editable-social-embed__loader {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.page-slug-home-editable .home-editable-social-embed__loader-shimmer,
body[data-page-alias="home-editable"] .home-editable-social-embed__loader-shimmer {
  width: min(220px, 70%);
  height: 10px;
  border-radius: 999px;
  background: linear-gradient(90deg, #dbe4ee 0%, #f5f8fb 45%, #dbe4ee 100%);
  background-size: 200% 100%;
  animation: monroe-fb-shimmer 1.2s ease-in-out infinite;
}

.page-slug-home-editable .home-editable-social-embed__loader-text,
body[data-page-alias="home-editable"] .home-editable-social-embed__loader-text {
  font: 600 13px/1.35 system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  color: #64748b;
}

@keyframes monroe-fb-shimmer {
  0% {
    background-position: 100% 0;
  }
  100% {
    background-position: -100% 0;
  }
}

.page-slug-home-editable .home-editable-social-embed__cta,
body[data-page-alias="home-editable"] .home-editable-social-embed__cta {
  margin-top: 10px;
  text-align: center;
}

.page-slug-home-editable .home-editable-social-embed__open,
body[data-page-alias="home-editable"] .home-editable-social-embed__open {
  display: inline-block;
  text-decoration: none;
  border-radius: 999px;
  padding: 12px 18px;
  font: 800 14px/1 system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: #0a121c;
  background: linear-gradient(135deg, #50c878, #72cbff);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.28);
}

@media (max-width: 768px) {
  .page-slug-home-editable .home-editable-social-card--feed-only .home-editable-social-embed,
  body[data-page-alias="home-editable"] .home-editable-social-card--feed-only .home-editable-social-embed {
    max-width: 100%;
  }

  .page-slug-home-editable .home-editable-social-embed__viewport,
  body[data-page-alias="home-editable"] .home-editable-social-embed__viewport {
    min-height: 590px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .page-slug-home-editable .home-editable-social-embed__loader-shimmer,
  body[data-page-alias="home-editable"] .home-editable-social-embed__loader-shimmer {
    animation: none;
  }
}

.page-slug-home-editable .home-editable-social-card .home-editable-social-embed__open:hover,
.page-slug-home-editable .home-editable-social-card .home-editable-social-embed__open:focus-visible,
body[data-page-alias="home-editable"] .home-editable-social-card .home-editable-social-embed__open:hover,
body[data-page-alias="home-editable"] .home-editable-social-card .home-editable-social-embed__open:focus-visible {
  color: #0a121c;
  transform: translateY(-1px);
}

.page-slug-home-editable .home-editable-runtime-card {
  overflow: visible;
}

.page-slug-home-editable .home-editable-runtime-block {
  margin-top: 1.5rem;
}

.page-slug-home-editable .home-editable-runtime-block:first-child {
  margin-top: 0;
}

.page-slug-home-editable .monroe-home-widget {
  width: 100%;
  max-width: 100%;
  overflow: hidden;
}

.page-slug-home-editable .monroe-home-widget img,
.page-slug-home-editable .monroe-home-widget video,
.page-slug-home-editable .monroe-home-widget iframe {
  max-width: 100%;
}

.page-slug-home-editable .monroe-home-widget iframe {
  display: block;
  width: 100%;
  min-height: 560px;
  border: 0;
}

.page-slug-home-editable .monroe-home-widget--social_feed iframe {
  min-height: 600px;
}

.page-slug-home-editable .monroe-home-widget--auction_banner {
  margin-inline: auto;
  max-width: 900px;
  text-align: center;
}

.page-slug-home-editable .monroe-home-widget--auction_banner img {
  width: auto !important;
  max-width: min(900px, 100%) !important;
  height: auto !important;
  border-radius: 12px;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.12);
}

.page-slug-home-editable .home-editable-sponsors .monroe-home-widget + .monroe-home-widget,
.page-slug-home-editable .home-editable-runtime-card .wp-block-buttons {
  margin-top: 1.5rem;
}

.page-slug-home-editable .home-editable-contact-card {
  text-align: center;
}

.page-slug-home-editable .home-editable-contact-card > .wp-block-group__inner-container {
  max-width: min(960px, var(--monroe-home-content-max));
  margin: 0 auto;
}

.page-slug-home-editable .home-editable-contact-card p {
  margin-inline: auto;
  max-width: 48rem;
}

.page-slug-home-editable .home-editable-contact-card .wp-block-buttons {
  justify-content: center;
}

.page-slug-home-editable .home-editable-contact-card .home-editable-pill {
  margin-inline: auto;
}

.page-slug-home-editable .home-editable-contact-card .wp-block-buttons .wp-block-button:last-child .wp-block-button__link {
  background: #2bb8f3;
  color: #082021;
}

.page-slug-home-editable .home-editable-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  margin: 0 0 1rem;
  padding: 0.35rem 0.7rem;
  border-radius: 999px;
  background: rgba(15, 118, 110, 0.12);
  color: #0f766e;
  font: 700 0.76rem/1 "Jost", "Segoe UI", sans-serif;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

@media (max-width: 960px) {
  .page-slug-home-editable .home-editable-feature-media img {
    min-height: 320px;
  }

  .page-slug-home-editable .monroe-home-widget iframe,
  .page-slug-home-editable .monroe-home-widget--social_feed iframe,
  body[data-page-alias="home-editable"] .monroe-home-widget iframe,
  body[data-page-alias="home-editable"] .monroe-home-widget--social_feed iframe {
    min-height: clamp(280px, 52vh, 520px);
  }
}

@media (max-width: 768px) {
  .page-slug-home-editable,
  body[data-page-alias="home-editable"] {
    --monroe-home-stack-gap: 1.65rem;
    --monroe-home-band-pad-y: 2.1rem;
  }

  /* Consistent section heading scale on mobile (unify serif/sans/all-caps variants) */
  .page-slug-home-editable .home-editable-section > .home-editable-feature-card h2,
  .page-slug-home-editable .home-editable-section > .home-editable-news-card h2,
  .page-slug-home-editable .home-editable-section > .home-editable-intro-card h2,
  .page-slug-home-editable .home-editable-section .wp-block-heading:not(.home-editable-hero-title):not(h3) {
    font-size: clamp(1.5rem, 5.2vw, 1.95rem);
    line-height: 1.18;
  }

  .page-slug-home-editable .home-editable-compare-bar,
  body[data-page-alias="home-editable"] .home-editable-compare-bar {
    position: static;
    margin-bottom: 0;
  }

  .page-slug-home-editable .home-editable-compare-bar .wp-block-group__inner-container,
  body[data-page-alias="home-editable"] .home-editable-compare-bar .wp-block-group__inner-container {
    flex-direction: column;
    align-items: flex-start;
  }

  .page-slug-home-editable .home-editable-hero.wp-block-cover,
  .page-slug-home-editable .wp-block-cover.home-editable-hero,
  body[data-page-alias="home-editable"] .home-editable-hero.wp-block-cover,
  body[data-page-alias="home-editable"] .wp-block-cover.home-editable-hero {
    min-height: clamp(220px, 42vh, 380px) !important;
    padding: 0 var(--monroe-home-hero-pad-x) 2.75rem;
  }

  .page-slug-home-editable .home-editable-hero-display,
  body[data-page-alias="home-editable"] .home-editable-hero-display {
    font-size: clamp(2rem, 6.2vw, 3.5rem);
  }

  .page-slug-home-editable .home-editable-intro-card,
  .page-slug-home-editable .home-editable-news-card,
  .page-slug-home-editable .home-editable-contact-card,
  .page-slug-home-editable .home-editable-events-card,
  .page-slug-home-editable .home-editable-faq-card,
  .page-slug-home-editable .home-editable-games-card,
  body[data-page-alias="home-editable"] .home-editable-intro-card,
  body[data-page-alias="home-editable"] .home-editable-news-card,
  body[data-page-alias="home-editable"] .home-editable-contact-card,
  body[data-page-alias="home-editable"] .home-editable-games-card,
  body[data-page-alias="home-editable"] .home-editable-events-card,
  body[data-page-alias="home-editable"] .home-editable-faq-card {
    padding: 1.35rem 1.15rem;
  }

  .page-slug-home-editable .home-editable-accomplishments-card,
  body[data-page-alias="home-editable"] .home-editable-accomplishments-card {
    padding: 1.35rem 1.15rem clamp(2.25rem, 5.5vw, 3rem);
  }

  .page-slug-home-editable .monroe-accomplishments-widget,
  body[data-page-alias="home-editable"] .monroe-accomplishments-widget {
    gap: clamp(2rem, 5vw, 2.75rem);
  }

  .page-slug-home-editable .home-editable-accomplishments-band,
  body[data-page-alias="home-editable"] .home-editable-accomplishments-band,
  .page-slug-home-editable .home-editable-games-band,
  body[data-page-alias="home-editable"] .home-editable-games-band {
    margin: 1.25rem auto;
    padding: 0;
  }

  .monroe-reveal-target {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .page-slug-home-editable .home-editable-intro-card .wp-block-columns,
  .page-slug-home-editable .home-editable-feature-card .wp-block-columns,
  .page-slug-home-editable .home-editable-faq-grid .wp-block-columns,
  body[data-page-alias="home-editable"] .home-editable-intro-card .wp-block-columns,
  body[data-page-alias="home-editable"] .home-editable-feature-card .wp-block-columns,
  body[data-page-alias="home-editable"] .home-editable-faq-grid .wp-block-columns {
    flex-direction: column !important;
  }

  .page-slug-home-editable .home-editable-feature-card .wp-block-columns > .wp-block-column,
  body[data-page-alias="home-editable"] .home-editable-feature-card .wp-block-columns > .wp-block-column {
    flex-basis: 100% !important;
  }

  .page-slug-home-editable .home-editable-feature-media img,
  body[data-page-alias="home-editable"] .home-editable-feature-media img {
    min-height: 260px;
  }

  .page-slug-home-editable .home-editable-stat-grid--hero,
  body[data-page-alias="home-editable"] .home-editable-stat-grid--hero {
    grid-template-columns: 1fr;
  }

  .page-slug-home-editable .home-editable-news-card .hs-head,
  body[data-page-alias="home-editable"] .home-editable-news-card .hs-head {
    flex-direction: column;
    align-items: stretch;
    gap: 0.75rem;
  }

  .page-slug-home-editable .home-editable-news-card .hs-head .hs-actions,
  body[data-page-alias="home-editable"] .home-editable-news-card .hs-head .hs-actions {
    flex-wrap: wrap;
    white-space: normal;
  }

  .page-slug-home-editable .home-editable-games-teasers,
  body[data-page-alias="home-editable"] .home-editable-games-teasers {
    grid-template-columns: 1fr;
  }

  .page-slug-home-editable .home-editable-paypal-giving-split,
  body[data-page-alias="home-editable"] .home-editable-paypal-giving-split {
    grid-template-columns: 1fr;
  }
}

/* Custom Block Styles for Enhanced Editing Experience */
.page-slug-home-editable .wp-block-button.is-style-monroe-cta .wp-block-button__link {
  background-color: #0f766e;
  color: #ffffff;
  border-radius: 0.5rem;
  padding: 0.875rem 1.5rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  transition: all 0.2s ease;
}

.page-slug-home-editable .wp-block-button.is-style-monroe-cta .wp-block-button__link:hover {
  background-color: #0a5a52;
  transform: translateY(-1px);
}

.page-slug-home-editable .wp-block-button.is-style-monroe-outline .wp-block-button__link {
  background-color: transparent;
  color: #0f766e;
  border: 2px solid #0f766e;
  border-radius: 0.5rem;
  padding: 0.75rem 1.5rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  transition: all 0.2s ease;
}

.page-slug-home-editable .wp-block-button.is-style-monroe-outline .wp-block-button__link:hover {
  background-color: #0f766e;
  color: #ffffff;
}

.page-slug-home-editable .wp-block-group.is-style-monroe-section {
  margin-bottom: 3rem;
}

.page-slug-home-editable .wp-block-group.is-style-monroe-card {
  background: rgba(255, 255, 255, 0.8);
  border-radius: 1rem;
  padding: 2rem;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
  backdrop-filter: blur(10px);
}

.page-slug-home-editable .wp-block-group.is-style-monroe-hero-panel {
  max-width: 1200px;
  margin: 0 auto;
  text-align: center;
  color: #ffffff;
}

.page-slug-home-editable .wp-block-cover.is-style-monroe-hero {
  min-height: clamp(260px, 34vh, 420px) !important;
  background-position: center;
  background-size: cover;
}

.page-slug-home-editable .wp-block-paragraph.is-style-monroe-kicker {
  font-size: 1.125rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.9);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 1rem;
}

.page-slug-home-editable .wp-block-paragraph.is-style-monroe-pill {
  display: inline-block;
  background: rgba(15, 118, 110, 0.9);
  color: #ffffff;
  padding: 0.5rem 1rem;
  border-radius: 2rem;
  font-size: 0.875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 1.5rem;
}

.page-slug-home-editable .wp-block-paragraph.is-style-monroe-section-label {
  font-size: 0.875rem;
  font-weight: 600;
  color: #0f766e;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 0.5rem;
}

.page-slug-home-editable .wp-block-heading.is-style-monroe-hero-title {
  font-size: clamp(2.5rem, 5vw, 4rem);
  font-weight: 700;
  color: #ffffff;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
  margin-bottom: 1rem;
  line-height: 1.1;
}

.page-slug-home-editable .wp-block-columns.is-style-monroe-feature-grid {
  gap: 2rem;
}

.page-slug-home-editable .wp-block-columns.is-style-monroe-feature-grid .wp-block-column {
  background: rgba(255, 255, 255, 0.9);
  border-radius: 1rem;
  padding: 2rem;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  transition: transform 0.2s ease;
}

.page-slug-home-editable .wp-block-columns.is-style-monroe-feature-grid .wp-block-column:hover {
  transform: translateY(-2px);
}

/* Lazy loading for images */
.page-slug-home-editable .wp-block-image img {
  transition: opacity 0.3s ease;
}

.page-slug-home-editable .wp-block-image img[loading="lazy"] {
  opacity: 0;
}

.page-slug-home-editable .wp-block-image img[loading="lazy"].loaded {
  opacity: 1;
}

/* Accessibility improvements */
.page-slug-home-editable .wp-block-button .wp-block-button__link:focus {
  outline: 2px solid #0f766e;
  outline-offset: 2px;
}

.page-slug-home-editable .wp-block-group:focus-within {
  outline: 2px solid #0f766e;
  outline-offset: 2px;
}

/* Shop Page Styles */
.page-slug-shop {
  background:
    radial-gradient(circle at top left, rgba(28, 116, 108, 0.18), transparent 34%),
    linear-gradient(180deg, #f5efe3 0%, #f9f7f2 30%, #ffffff 100%);
  color: #1d2a2a;
}

.page-slug-shop .monroe-shop-hero {
  margin-bottom: 0;
  text-align: center;
}

.page-slug-shop .monroe-shop-hero h1 {
  font-size: clamp(2.5rem, 5vw, 4rem);
  margin-bottom: 1rem;
  color: #ffffff;
}

.page-slug-shop .monroe-shop-hero p {
  font-size: 1.25rem;
  margin-bottom: 2rem;
  color: rgba(255, 255, 255, 0.9);
}

.page-slug-shop .monroe-shop-content {
  padding: 4rem 2rem;
}

.page-slug-shop .square-store-embed {
  border-radius: 1rem;
  overflow: hidden;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
  background: #f8f9fa;
}

.page-slug-shop .square-store-embed iframe {
  border: none;
  width: 100%;
  min-height: 600px;
}

.page-slug-shop .monroe-shop-sidebar {
  background: rgba(15, 118, 110, 0.05);
  padding: 2rem;
  border-radius: 1rem;
  border: 1px solid rgba(15, 118, 110, 0.1);
}

.page-slug-shop .monroe-shop-sidebar h3,
.page-slug-shop .monroe-shop-sidebar h4 {
  color: #0f766e;
  margin-top: 0;
}

.page-slug-shop .monroe-shop-sidebar ul {
  list-style: none;
  padding: 0;
  margin: 1rem 0;
}

.page-slug-shop .monroe-shop-sidebar li {
  padding-left: 1.5rem;
  margin-bottom: 0.5rem;
  position: relative;
}

.page-slug-shop .monroe-shop-sidebar li:before {
  content: '✓';
  position: absolute;
  left: 0;
  color: #0f766e;
  font-weight: bold;
}

.page-slug-shop .wp-block-columns.is-style-monroe-feature-grid .wp-block-column {
  background: rgba(255, 255, 255, 0.9);
  border-radius: 1rem;
  padding: 2rem;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  transition: transform 0.2s ease;
  text-align: center;
}

.page-slug-shop .wp-block-columns.is-style-monroe-feature-grid .wp-block-column:hover {
  transform: translateY(-2px);
}

.page-slug-shop .wp-block-columns.is-style-monroe-feature-grid h4 {
  color: #0f766e;
  margin-top: 0;
}

/* Animal Search Widget Styles */
.monroe-animal-search-widget {
  background: rgba(255, 255, 255, 0.95);
  border-radius: 1rem;
  padding: 2rem;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
  margin: 2rem 0;
  backdrop-filter: blur(10px);
}

.animal-search-header {
  text-align: center;
  margin-bottom: 2rem;
}

.animal-search-title {
  color: #0f766e;
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
}

.animal-search-subtitle {
  color: #666;
  font-size: 1.1rem;
  margin: 0;
  max-width: 600px;
  margin: 0 auto;
}

.animal-search-filters {
  background: #f8f9fa;
  border-radius: 0.75rem;
  padding: 1.5rem;
  margin-bottom: 2rem;
  border: 1px solid rgba(15, 118, 110, 0.1);
}

.animal-search-controls {
  box-sizing: border-box;
}

.filter-row--primary {
  margin-bottom: 1rem;
}

.animal-search-query-row {
  margin-bottom: 1rem;
}

.animal-search-query-combo {
  display: flex;
  width: 100%;
  align-items: stretch;
}

.animal-search-q {
  box-sizing: border-box;
  flex: 1 1 auto;
  min-width: 0;
  width: 100%;
  padding: 0.75rem 1rem;
  border: 2px solid #e9ecef;
  border-right-width: 0;
  border-radius: 0.5rem 0 0 0.5rem;
  font-size: 1rem;
  background: #fff;
}

.animal-search-q:focus {
  outline: none;
  border-color: #0f766e;
  box-shadow: 0 0 0 3px rgba(15, 118, 110, 0.1);
  position: relative;
  z-index: 1;
}

.animal-search-submit {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 3rem;
  padding: 0 0.75rem;
  border: 2px solid #0f766e;
  border-radius: 0 0.5rem 0.5rem 0;
  background: #0f766e;
  color: #fff;
  cursor: pointer;
  font-size: 1.25rem;
  line-height: 1;
  transition: background 0.2s ease, border-color 0.2s ease;
}

.animal-search-submit:hover {
  background: #0a5a52;
  border-color: #0a5a52;
}

.animal-search-submit:focus-visible {
  outline: 2px solid #0f766e;
  outline-offset: 2px;
}

.animal-search-advanced {
  margin: 0.75rem 0 1rem;
  border-radius: 0.5rem;
  border: 1px solid rgba(15, 118, 110, 0.15);
  background: rgba(255, 255, 255, 0.9);
}

.animal-search-advanced-summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  min-height: 2.75rem;
  padding: 0 0.9rem;
  margin: 0;
  font-weight: 700;
  color: #0f766e;
  font-family: inherit;
}

.animal-search-advanced-summary::-webkit-details-marker {
  display: none;
}

.animal-search-advanced-inner {
  padding: 0 0.75rem 0.95rem;
}

.animal-search-advanced-inner .filter-row--advanced {
  margin-bottom: 0;
}

.animal-search-sort-row {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  margin: 1rem 0 0;
}

.animal-search-sort-row label {
  display: block;
  font-weight: 600;
  color: #0f766e;
  font-size: 0.9rem;
}

.animal-sort {
  width: 100%;
  padding: 0.75rem;
  border: 2px solid #e9ecef;
  border-radius: 0.5rem;
  font-size: 1rem;
  background: #fff;
}

.animal-sort:focus {
  outline: none;
  border-color: #0f766e;
  box-shadow: 0 0 0 3px rgba(15, 118, 110, 0.1);
}

.animal-search-results > .animal-search-summary {
  margin: 0 0 1rem;
  min-height: 1.35em;
  font-weight: 650;
  color: rgba(29, 42, 42, 0.88);
}

@media (min-width: 769px) {
  .animal-search-results > .animal-search-summary {
    text-align: right;
  }
}

@media (max-width: 768px) {
  .animal-search-results > .animal-search-summary {
    text-align: center;
  }
}

.filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  margin-bottom: 1.5rem;
  align-items: end;
}

.filter-group {
  flex: 1;
  min-width: 200px;
}

.filter-group label {
  display: block;
  font-weight: 600;
  color: #0f766e;
  margin-bottom: 0.5rem;
  font-size: 0.9rem;
}

.animal-filter {
  width: 100%;
  padding: 0.75rem;
  border: 2px solid #e9ecef;
  border-radius: 0.5rem;
  font-size: 1rem;
  background: white;
  transition: border-color 0.2s ease;
}

.animal-filter:focus {
  outline: none;
  border-color: #0f766e;
  box-shadow: 0 0 0 3px rgba(15, 118, 110, 0.1);
}

.search-actions {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}

.search-button, .reset-button {
  padding: 0.875rem 1.5rem;
  border: none;
  border-radius: 0.5rem;
  font-weight: 600;
  font-size: 1rem;
  cursor: pointer;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.search-button {
  background: #0f766e;
  color: white;
}

.search-button:hover {
  background: #0a5a52;
  transform: translateY(-1px);
}

.reset-button {
  background: #6c757d;
  color: white;
}

.reset-button:hover {
  background: #5a6268;
}

.animal-search-results {
  position: relative;
  min-height: 200px;
}

.results-loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 3rem;
  color: #666;
}

.loading-spinner {
  width: 40px;
  height: 40px;
  border: 4px solid #f3f3f3;
  border-top: 4px solid #0f766e;
  border-radius: 50%;
  animation: spin 1s linear infinite;
  margin-bottom: 1rem;
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

.results-empty[hidden] {
  display: none !important;
}

.results-empty {
  text-align: center;
  padding: 3rem;
}

.empty-state {
  max-width: 400px;
  margin: 0 auto;
}

.empty-icon {
  font-size: 3rem;
  margin-bottom: 1rem;
}

.empty-state h4 {
  color: #0f766e;
  margin-bottom: 1rem;
}

.empty-state p {
  color: #666;
  margin-bottom: 1.5rem;
}

.results-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 1.5rem;
  margin-bottom: 2rem;
}

/* Avoid bare “grid” / “list” classes — they collide with WP core layout utilities. */
.results-grid.monroe-pet-results--list {
  grid-template-columns: 1fr;
}

.results-grid.monroe-pet-results--list .animal-card {
  display: flex;
  flex-direction: row;
}

.results-grid.monroe-pet-results--list .animal-image {
  flex: 0 0 200px;
  margin-right: 1.5rem;
}

.animal-card {
  position: relative;
  background: white;
  border-radius: 1rem;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  transition: transform 0.22s ease, box-shadow 0.22s ease;
  border: 1px solid #e9ecef;
}

.animal-card:focus-within {
  transform: translateY(-4px);
  box-shadow: 0 14px 28px rgba(17, 41, 41, 0.14);
}

@media (hover: hover) and (pointer: fine) {
  .animal-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 14px 28px rgba(17, 41, 41, 0.14);
  }
}

/* Coarse / no-hover: avoid hover-lift sticking after tap */
@media (hover: none), (pointer: coarse) {
  .animal-card:hover {
    transform: none;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  }
}

.animal-card:focus-visible {
  outline: 2px solid #0f766e;
  outline-offset: 2px;
}

.monroe-pet-badge {
  position: absolute;
  top: 0.75rem;
  left: 0.75rem;
  z-index: 2;
  display: inline-block;
  padding: 0.28rem 0.65rem;
  border-radius: 999px;
  background: rgba(15, 118, 110, 0.94);
  color: #fff;
  font: 700 0.68rem/1.2 "Jost", "Segoe UI", sans-serif;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.monroe-pet-badge--available {
  background: rgba(23, 58, 57, 0.88);
}

.animal-card.placeholder {
  animation: pulse 1.5s ease-in-out infinite;
}

@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.7; }
}

.animal-image {
  position: relative;
  aspect-ratio: 4 / 3;
  width: 100%;
  min-height: 200px;
  background: linear-gradient(145deg, #e8f4f2 0%, #f8f9fa 55%, #eef6f5 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.5rem;
  color: #0f766e;
  overflow: hidden;
}

.animal-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.animal-image.is-placeholder::before {
  content: "Photo coming soon";
  font: 600 0.82rem/1.3 "Jost", "Segoe UI", sans-serif;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #2a5f5c;
}

.animal-info {
  padding: 1.5rem;
}

.animal-info h4 {
  color: #0f766e;
  margin: 0 0 0.5rem 0;
  font-size: 1.25rem;
}

.animal-info p {
  color: #666;
  margin: 0.25rem 0;
  font-size: 0.9rem;
}

.animal-info .animal-details {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  margin: 1rem 0;
}

.detail-item {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.85rem;
  color: #666;
}

.detail-item strong {
  color: #0f766e;
}

.results-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1rem;
  margin-top: 2rem;
  padding-top: 2rem;
  border-top: 1px solid #e9ecef;
}

.pagination-btn {
  padding: 0.75rem 1.5rem;
  border: 2px solid #0f766e;
  background: white;
  color: #0f766e;
  border-radius: 0.5rem;
  cursor: pointer;
  font-weight: 600;
  transition: all 0.2s ease;
}

.pagination-btn:hover:not(:disabled) {
  background: #0f766e;
  color: white;
}

.pagination-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.page-info {
  font-weight: 600;
  color: #666;
}

.animal-search-footer {
  text-align: center;
  margin-top: 2rem;
  padding-top: 2rem;
  border-top: 1px solid #e9ecef;
}

.adoption-info {
  color: #666;
  margin: 0;
}

.adoption-info a {
  color: #0f766e;
  text-decoration: none;
  font-weight: 600;
}

.adoption-info a:hover {
  text-decoration: underline;
}

/* Mobile responsiveness for animal search */
@media (max-width: 768px) {
  .monroe-animal-search-widget {
    padding: clamp(1rem, 3.5vw, 1.25rem);
    max-width: 100%;
    box-sizing: border-box;
    overflow-x: clip;
  }

  .animal-search-header {
    margin-bottom: 1rem;
  }

  .animal-search-title {
    font-size: 1.4rem;
    line-height: 1.2;
    padding-inline: 0.15rem;
  }

  .animal-search-subtitle {
    font-size: 0.95rem;
    line-height: 1.45;
    padding-inline: 0.25rem;
  }

  .animal-search-filters {
    padding: 0;
    margin-bottom: 1.1rem;
    background: transparent;
    border: 0;
    box-shadow: none;
  }

  .animal-search-controls {
    max-width: min(28rem, 100%);
    margin-inline: auto;
    padding: 1rem 1rem 1.1rem;
    background: #fff;
    border-radius: 1rem;
    box-shadow:
      0 6px 20px rgba(17, 41, 41, 0.08),
      0 1px 0 rgba(15, 118, 110, 0.06);
    border: 1px solid rgba(15, 118, 110, 0.1);
  }

  .animal-search-advanced {
    background: #fff;
    border-color: rgba(15, 118, 110, 0.12);
  }

  .animal-filter,
  .animal-sort {
    min-height: 44px;
    padding-top: 0.65rem;
    padding-bottom: 0.65rem;
  }

  .animal-search-query-row {
    margin-bottom: 0.85rem;
  }

  .animal-search-q {
    min-height: 44px;
    font-size: 16px;
  }

  .animal-search-submit {
    min-width: 3.25rem;
    min-height: 44px;
  }

  .animal-search-sort-row {
    margin-top: 0.85rem;
  }

  .animal-search-advanced-summary {
    min-height: 44px;
    padding-inline: 0.85rem;
  }

  /* Primary search is beside the query field — avoid duplicate "Search pets" in tab order on narrow screens */
  .monroe-animal-search-widget .search-actions .search-button {
    display: none !important;
  }

  .search-actions {
    flex-direction: column;
    gap: 0.6rem;
    margin-top: 0.85rem;
  }

  .search-button,
  .reset-button {
    width: 100%;
    justify-content: center;
    min-height: 48px;
    font-size: 1rem;
  }

  .animal-search-results > .animal-search-summary {
    position: sticky;
    top: calc(var(--monroe-nav-height, 96px) + env(safe-area-inset-top, 0px) + 0.35rem);
    z-index: 3;
    margin: -0.15rem -0.35rem 0.85rem;
    padding: 0.55rem 0.85rem;
    background: rgba(255, 255, 255, 0.94);
    border-radius: 0.65rem;
    border: 1px solid rgba(15, 118, 110, 0.1);
    box-shadow: 0 8px 20px rgba(17, 41, 41, 0.06);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    text-align: center;
    line-height: 1.35;
  }

  .filter-row {
    flex-direction: column;
    gap: 0.85rem;
  }

  .filter-group label {
    font-size: 0.82rem;
  }

  .filter-group {
    min-width: auto;
    width: 100%;
  }

  .results-grid.monroe-pet-results--grid {
    grid-template-columns: repeat(auto-fill, minmax(min(240px, 100%), 1fr));
    gap: clamp(0.85rem, 2.5vw, 1rem);
  }

  .animal-info {
    padding: 1rem 1.1rem;
  }

  .results-pagination {
    flex-direction: column;
    gap: 0.65rem;
    padding-top: 1.5rem;
  }

  .pagination-btn {
    min-height: 48px;
    min-width: min(180px, 100%);
    width: auto;
    padding-inline: 1.35rem;
  }

  .page-info {
    order: -1;
  }

  .results-grid.monroe-pet-results--list .animal-card {
    flex-direction: column;
  }

  .results-grid.monroe-pet-results--list .animal-image {
    flex: none;
    margin-right: 0;
    margin-bottom: 1rem;
  }

  .monroe-animal-search-widget .animal-search-footer {
    margin-top: 1.5rem;
    padding-top: 1.35rem;
  }
}

.page-slug-home-editable .home-editable-section .monroe-animal-search-widget,
.monroe-adopt-page .monroe-adopt-search .monroe-animal-search-widget {
  overflow-x: clip;
}

@media (max-width: 480px) {
  .results-grid.monroe-pet-results--grid {
    grid-template-columns: 1fr;
  }

  .monroe-animal-search-widget .animal-card .animal-info {
    padding: 0.85rem 1rem;
  }

  .monroe-animal-search-widget--compact .filter-row--primary {
    grid-template-columns: 1fr;
  }
}

/* --------------------------------------------------------------------------
   Homepage margin index — mobile sticky pills + desktop fixed rail
   Desktop rail at 1400px+ only: at 1200–1399px keep horizontal pills so laptops
   (often 1280–1366 CSS px with OS scaling) are not squeezed by rail + left pad.
   -------------------------------------------------------------------------- */
@media (max-width: 1399px) {
  body.page-slug-home-editable,
  body[data-page-alias="home-editable"] {
    --monroe-sticky-wayfinding-offset: 4.5rem;
  }
}

@media (max-width: 1200px) {
  body.monroe-native-inner--dog-and-cat-shelter {
    --monroe-sticky-wayfinding-offset: 4.5rem;
  }
}

.home-editable-page-index-shell {
  display: block;
}

.home-editable-page-index--desktop {
  display: none;
}

.home-editable-page-index--mobile {
  display: block;
  position: sticky;
  top: calc(var(--monroe-nav-height, 96px) + env(safe-area-inset-top, 0px));
  z-index: 110;
  margin: 0;
  padding: 0.5rem max(0.65rem, env(safe-area-inset-right, 0px)) 0.55rem
    max(0.65rem, env(safe-area-inset-left, 0px));
  background: rgba(255, 250, 242, 0.97);
  border-bottom: 1px solid rgba(25, 55, 54, 0.12);
  box-shadow: 0 8px 20px rgba(15, 30, 29, 0.08);
  font-family: "Jost", "Segoe UI", sans-serif;
  -webkit-overflow-scrolling: touch;
}

.home-editable-page-index--mobile .home-editable-page-index__list {
  list-style: none;
  margin: 0;
  padding: 0 0 0.15rem;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: stretch;
  gap: 0.45rem;
  overflow-x: auto;
  scroll-snap-type: x proximity;
  scrollbar-width: thin;
}

.home-editable-page-index--mobile .home-editable-page-index__item {
  flex: 0 0 auto;
  scroll-snap-align: start;
}

.home-editable-page-index--mobile .home-editable-page-index__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0.4rem 0.85rem;
  border-radius: 999px;
  border: 1px solid rgba(25, 55, 54, 0.14);
  background: #fff;
  font-size: 0.78rem;
  font-weight: 700;
  color: #163433;
  text-decoration: none;
  line-height: 1.2;
  white-space: nowrap;
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.home-editable-page-index--mobile .home-editable-page-index__link:hover {
  background: rgba(15, 118, 110, 0.08);
  color: #0f766e;
  border-color: rgba(15, 118, 110, 0.35);
}

.home-editable-page-index--mobile .home-editable-page-index__link.is-active {
  background: rgba(15, 118, 110, 0.16);
  color: #0b534e;
  border-color: #0f766e;
  box-shadow: inset 0 0 0 1px rgba(15, 118, 110, 0.25);
}

@media (min-width: 1400px) {
  /* Align rail + main column offset with the same horizontal grid as .monroe-global-nav__inner */
  body.page-slug-home-editable,
  body[data-page-alias="home-editable"] {
    --monroe-xl-nav-sync-inset: max(
      env(safe-area-inset-left, 0px),
      calc((100% - min(100%, 1320px)) / 2 + 1.4rem)
    );
    --monroe-xl-index-rail-width: 11rem;
    --monroe-xl-index-rail-gap: 1rem;
    --monroe-xl-main-pad-for-rail: calc(
      var(--monroe-xl-nav-sync-inset) + var(--monroe-xl-index-rail-width) + var(--monroe-xl-index-rail-gap)
    );
  }

  .home-editable-page-index--mobile {
    display: none;
  }

  .home-editable-page-index--desktop {
    display: block;
    position: fixed;
    z-index: 120;
    box-sizing: border-box;
    left: var(--monroe-xl-nav-sync-inset, max(0.65rem, env(safe-area-inset-left, 0px)));
    top: calc(var(--monroe-nav-height, 96px) + 1rem);
    width: var(--monroe-xl-index-rail-width, 11rem);
    max-height: calc(100dvh - var(--monroe-nav-height, 96px) - 2rem);
    overflow: auto;
    overscroll-behavior: contain;
    scrollbar-width: thin;
    margin: 0;
    padding: 0.85rem 1rem;
    border-radius: 1rem;
    background: rgba(255, 250, 242, 0.96);
    border: 1px solid rgba(25, 55, 54, 0.12);
    box-shadow: 0 18px 38px rgba(15, 30, 29, 0.1);
    font-family: "Jost", "Segoe UI", sans-serif;
  }

  .home-editable-page-index--desktop .home-editable-page-index__title {
    margin: 0 0 0.6rem;
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: rgba(22, 52, 51, 0.72);
  }

  .home-editable-page-index--desktop .home-editable-page-index__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
  }

  .home-editable-page-index--desktop .home-editable-page-index__link {
    display: block;
    min-height: 0;
    padding: 0.35rem 0.45rem;
    border-radius: 0.45rem;
    border: none;
    background: transparent;
    font-size: 0.82rem;
    font-weight: 600;
    color: #163433;
    text-decoration: none;
    line-height: 1.25;
    white-space: normal;
    transition: background 0.15s ease, color 0.15s ease;
  }

  .home-editable-page-index--desktop .home-editable-page-index__link:hover {
    background: rgba(15, 118, 110, 0.08);
    color: #0f766e;
  }

  .home-editable-page-index--desktop .home-editable-page-index__link.is-active {
    background: rgba(15, 118, 110, 0.14);
    color: #0b534e;
    box-shadow: inset 2px 0 0 #0f766e;
  }
}

/* Short viewports (scaled laptops, 1080p TVs): compact rail so ~16 links fit without a nested scroll. */
@media (min-width: 1400px) and (max-height: 860px) {
  .home-editable-page-index--desktop {
    padding: 0.65rem 0.75rem;
  }

  .home-editable-page-index--desktop .home-editable-page-index__title {
    margin-bottom: 0.4rem;
    font-size: 0.62rem;
  }

  .home-editable-page-index--desktop .home-editable-page-index__list {
    gap: 0.1rem;
  }

  .home-editable-page-index--desktop .home-editable-page-index__link {
    padding: 0.22rem 0.35rem;
    font-size: 0.74rem;
    line-height: 1.2;
  }
}

/* --------------------------------------------------------------------------
   Sponsor marquee seed markup (#sponsorMarqueeWidget + .logo-track)
   Matches legacy-fixes.js (animation restart on .logo-track).
   -------------------------------------------------------------------------- */
#sponsorMarqueeWidget.sponsor-marquee {
  --monroe-marquee-gap: 36px;
  --monroe-marquee-speed: 26s;
  width: 100%;
  max-width: none;
  margin: 0;
  padding-block: clamp(0.45rem, 1.5vw, 0.85rem);
  box-sizing: border-box;
}

.page-slug-home-editable #sponsorMarqueeWidget.sponsor-marquee {
  width: 100%;
  max-width: none;
}

/* Slider viewport: block layout — do not use flex here or the track can collapse narrow. */
#sponsorMarqueeWidget .logo-slider {
  position: relative;
  display: block;
  width: 100%;
  max-width: none;
  overflow: hidden;
  margin-inline: 0;
}

#sponsorMarqueeWidget .logo-slider::before,
#sponsorMarqueeWidget .logo-slider::after {
  content: "";
  position: absolute;
  top: 0;
  width: 72px;
  height: 100%;
  z-index: 2;
  pointer-events: none;
}

#sponsorMarqueeWidget .logo-slider::before {
  left: 0;
  background: linear-gradient(to right, #fffaf2, transparent);
}

#sponsorMarqueeWidget .logo-slider::after {
  right: 0;
  background: linear-gradient(to left, #fffaf2, transparent);
}

#sponsorMarqueeWidget .logo-track {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: flex-start;
  width: max-content;
  max-width: none;
  min-width: max-content;
  will-change: transform;
  animation: monroe-home-logo-marquee var(--monroe-marquee-speed) linear infinite;
}

#sponsorMarqueeWidget .logo-set {
  display: inline-flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
  flex-shrink: 0;
  gap: var(--monroe-marquee-gap);
  padding-right: var(--monroe-marquee-gap);
}

#sponsorMarqueeWidget .logo-set img {
  display: block;
  height: auto;
  max-height: 120px;
  width: auto;
  max-width: 250px;
  object-fit: contain;
  user-select: none;
}

@media (prefers-reduced-motion: reduce) {
  /* Keep logos in horizontal rows; wrap sets to multiple rows instead of one skinny column. */
  .page-slug-home-editable #sponsorMarqueeWidget .logo-track,
  body[data-page-alias="home-editable"] #sponsorMarqueeWidget .logo-track {
    animation: none;
    justify-content: center;
    align-items: flex-start;
    flex-wrap: wrap;
    flex-direction: row;
    width: 100%;
    max-width: var(--monroe-home-content-max);
    min-width: 0;
    margin-inline: auto;
    row-gap: 1rem;
    column-gap: var(--monroe-marquee-gap);
  }

  #sponsorMarqueeWidget .logo-set {
    flex-wrap: wrap;
    justify-content: center;
    flex: 1 1 auto;
    min-width: min(100%, 420px);
  }

  #sponsorMarqueeWidget .logo-slider::before,
  #sponsorMarqueeWidget .logo-slider::after {
    display: none;
  }
}

@keyframes monroe-home-logo-marquee {
  0% {
    transform: translate3d(0, 0, 0);
  }

  100% {
    transform: translate3d(-50%, 0, 0);
  }
}

@media (max-width: 768px) {
  #sponsorMarqueeWidget .logo-set img {
    max-height: 70px;
    max-width: 160px;
  }
}

/* --------------------------------------------------------------------------
   Animal search: use full width of the section column (no vw/transform breakout —
   those clipped to a “sliver” when layout / overflow / nav padding changed).
   -------------------------------------------------------------------------- */
.page-slug-home-editable .home-editable-section .monroe-animal-search-widget {
  position: relative;
  width: 100%;
  max-width: none;
  min-width: 0;
  margin: 0;
  padding: var(--monroe-home-card-pad);
  box-sizing: border-box;
}

.page-slug-home-editable .home-editable-section .monroe-animal-search-widget .animal-search-results,
.page-slug-home-editable .home-editable-section .monroe-animal-search-widget .results-grid {
  min-width: 0;
}

.page-slug-home-editable .home-editable-section .monroe-animal-search-widget .results-grid.monroe-pet-results--grid {
  grid-template-columns: repeat(auto-fill, minmax(min(240px, 100%), 1fr));
}

/*
 * The CSV carousel is a single child of .results-grid. Without spanning, CSS Grid
 * auto-placement puts it in column 1 only — one ~260px track, so the marquee looks
 * “squished left”. Span every track when the bundled widget is present.
 */
.monroe-animal-search-widget .results-grid > .featured-pets-section {
  grid-column: 1 / -1;
  width: 100%;
  min-width: 0;
}

.cta-button {
  display: inline-block;
  padding: 0.65rem 1.2rem;
  border-radius: 999px;
  background: #0f766e;
  color: #fff !important;
  font-weight: 600;
  font-size: 0.9rem;
  text-decoration: none;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.cta-button:hover,
.cta-button:focus {
  transform: translateY(-1px);
  box-shadow: 0 10px 22px rgba(15, 118, 110, 0.25);
}

.page-slug-home-editable .monroe-home-widget--featured_pets {
  overflow: visible;
}

/* Bundled CSV carousel (#featuredPetsWidget) — full width inside search / runtime shells */
.page-slug-home-editable .featured-pets-section #featuredPetsWidget,
.page-slug-home-editable .monroe-home-widget--featured_pets #featuredPetsWidget {
  width: 100%;
  max-width: 100%;
  min-width: 0;
}

/* --------------------------------------------------------------------------
   PayPal Giving split band (home-editable-content.html)
   -------------------------------------------------------------------------- */
.page-slug-home-editable .home-editable-paypal-giving {
  margin-top: clamp(0.75rem, 2.2vw, 1.5rem);
}

.page-slug-home-editable .home-editable-paypal-giving-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(1rem, 3vw, 2rem);
  align-items: stretch;
}

.page-slug-home-editable .home-editable-paypal-giving-split__col {
  min-width: 0;
}

.page-slug-home-editable .pp-giving-wrapper {
  height: 100%;
}

.page-slug-home-editable .pp-giving-widget {
  background: rgba(255, 255, 255, 0.96);
  border-radius: 1rem;
  overflow: hidden;
  border: 1px solid rgba(15, 118, 110, 0.12);
  box-shadow: 0 12px 36px rgba(17, 41, 41, 0.08);
}

.page-slug-home-editable .pp-widget-header {
  padding: 1rem 1.25rem;
  background: linear-gradient(135deg, #0f766e 0%, #134e4a 100%);
  color: #fff;
}

.page-slug-home-editable .pp-widget-header h3 {
  margin: 0 0 0.35rem;
  font-size: 1.15rem;
  font-family: "Abril Fatface", Georgia, serif;
  font-weight: 400;
}

.page-slug-home-editable .pp-widget-header p {
  margin: 0;
  font-size: 0.85rem;
  opacity: 0.92;
}

.page-slug-home-editable .pp-content {
  position: relative;
  min-height: 480px;
  background: #f8faf9;
}

.page-slug-home-editable .pp-content iframe {
  display: block;
  width: 100%;
  min-height: 480px;
  border: 0;
  background: transparent;
}

.page-slug-home-editable .pp-content--cta {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 1rem;
  padding: clamp(1.5rem, 4vw, 2.5rem);
}

.page-slug-home-editable .pp-cta-text {
  margin: 0;
  font-size: 1rem;
  line-height: 1.6;
  color: #163433;
  max-width: 36ch;
}

.page-slug-home-editable .pp-cta-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0.75rem 1.75rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #0f766e 0%, #134e4a 100%);
  color: #fff;
  font-weight: 800;
  text-decoration: none;
  box-shadow: 0 12px 28px rgba(15, 118, 110, 0.28);
  transition: transform 0.12s ease, box-shadow 0.12s ease;
}

.page-slug-home-editable .pp-cta-btn:hover,
.page-slug-home-editable .pp-cta-btn:focus-visible {
  transform: translateY(-2px);
  box-shadow: 0 16px 34px rgba(15, 118, 110, 0.38);
  outline: none;
}

.page-slug-home-editable .pp-cta-note {
  font-size: 0.82rem;
  color: rgba(22, 52, 51, 0.7);
}

.page-slug-home-editable .pp-loader {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  background: rgba(248, 250, 249, 0.92);
  transition: opacity 0.35s ease;
  z-index: 1;
}

.page-slug-home-editable .pp-loader.hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.page-slug-home-editable .pp-spinner-ring {
  width: 40px;
  height: 40px;
  border: 3px solid rgba(15, 118, 110, 0.15);
  border-top-color: #0f766e;
  border-radius: 50%;
  animation: spin 0.85s linear infinite;
}

.page-slug-home-editable .pp-loader-text {
  font-size: 0.88rem;
  color: #163433;
}

.page-slug-home-editable .pp-loader-fallback {
  display: inline-block;
  margin-top: 0.35rem;
  font-size: 0.86rem;
  font-weight: 600;
  color: #0f766e;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.page-slug-home-editable .pp-loader-fallback:hover,
.page-slug-home-editable .pp-loader-fallback:focus-visible {
  color: #134e4a;
}

.page-slug-home-editable .home-editable-lazy-embed__placeholder {
  margin: 0 0 1rem;
  padding: 1.25rem 1rem;
  text-align: center;
  font-size: 0.9rem;
  color: rgba(22, 52, 51, 0.78);
  border-radius: 12px;
  background: rgba(15, 118, 110, 0.06);
  border: 1px dashed rgba(15, 118, 110, 0.22);
}

.page-slug-home-editable .results-error .empty-state {
  text-align: center;
  padding: 1.5rem 1rem;
}

.page-slug-home-editable .offline-donations {
  margin-top: 1rem;
  padding: 1rem 1.15rem;
  border-radius: 0.75rem;
  background: rgba(15, 118, 110, 0.06);
  border: 1px dashed rgba(15, 118, 110, 0.25);
}

.page-slug-home-editable .offline-donations-header h4 {
  margin: 0 0 0.25rem;
  font-size: 1rem;
}

.page-slug-home-editable .offline-donations-header p {
  margin: 0;
  font-size: 0.82rem;
  color: rgba(22, 52, 51, 0.75);
}

.page-slug-home-editable .offline-donations-amount {
  font-size: 1.75rem;
  font-weight: 800;
  color: #0f766e;
  letter-spacing: -0.02em;
}

.page-slug-home-editable .offline-donations-label {
  font-size: 0.82rem;
  color: rgba(22, 52, 51, 0.72);
}

@media (max-width: 900px) {
  .page-slug-home-editable .home-editable-paypal-giving-split {
    grid-template-columns: 1fr;
  }

  .page-slug-home-editable .pp-content,
  .page-slug-home-editable .pp-content iframe {
    min-height: 420px;
  }
}

/* --------------------------------------------------------------------------
   Regression guards — keep last in this file so they win over block styles.
   Saved HTML / editor inline styles can reintroduce negative margins on the
   intro card; core `.wp-block-cover` keeps overflow:hidden without overrides.
   -------------------------------------------------------------------------- */
body.page-slug-home-editable .home-editable-hero ~ .home-editable-section .home-editable-intro-card,
body[data-page-alias="home-editable"] .home-editable-hero ~ .home-editable-section .home-editable-intro-card {
  margin-top: 0 !important;
}

body.page-slug-home-editable .home-editable-hero.wp-block-cover,
body.page-slug-home-editable .wp-block-cover.home-editable-hero,
body[data-page-alias="home-editable"] .home-editable-hero.wp-block-cover,
body[data-page-alias="home-editable"] .wp-block-cover.home-editable-hero {
  overflow: visible !important;
}

body.page-slug-home-editable .home-editable-shell,
body[data-page-alias="home-editable"] .home-editable-shell {
  overflow-x: visible;
  overflow-y: visible;
}

@media (max-width: 768px) {
  body.page-slug-home-editable .home-editable-shell,
  body[data-page-alias="home-editable"] .home-editable-shell {
    overflow-x: clip;
  }
}

/* --------------------------------------------------------------------------
   Inner pages / listings — same band + type scale as homepage pilot (block HTML)
   -------------------------------------------------------------------------- */
body.monroe-inner-page.monroe-rebuild-no-runtime #monroe-main {
  width: 100%;
}

.monroe-inner-page-shell {
  box-sizing: border-box;
  width: 100%;
  min-height: 100%;
  padding: clamp(1.5rem, 4vw, 2.75rem) clamp(1rem, 4.5vw, 1.75rem) clamp(3rem, 7vw, 5rem);
  /* Surface gradient: style.css (matches homepage). */
  color: #1d2a2a;
}

.monroe-inner-page-shell__content {
  width: 100%;
  max-width: min(var(--monroe-site-content-max, 1320px), 100%);
  margin: 0 auto;
}

@media (max-width: 768px) {
  /* Symmetric gutters + notches; avoids uneven horizontal padding on phones */
  .monroe-inner-page-shell {
    padding-top: clamp(1.25rem, 5vw, 1.65rem);
    padding-bottom: clamp(2.35rem, 7vw, 3.25rem);
    padding-left: max(1rem, env(safe-area-inset-left, 0px));
    padding-right: max(1rem, env(safe-area-inset-right, 0px));
  }

  .monroe-inner-page-shell__content {
    min-width: 0;
  }

  /* Slightly tighter vertical rhythm so stacked sections don’t feel cramped */
  .monroe-native-inner .monroe-native-stack {
    margin: clamp(1.35rem, 3.2vw, 1.85rem) 0;
  }
}

.monroe-inner-page-shell .alignfull {
  width: 100%;
  max-width: 100%;
  margin-left: 0;
  margin-right: 0;
}

.monroe-inner-page-shell h1,
.monroe-inner-page-shell h2,
.monroe-inner-page-shell h3 {
  font-family: "Abril Fatface", Georgia, serif;
  font-weight: 400;
  color: #153635;
}

.monroe-inner-page-shell h1 {
  font-size: clamp(2rem, 4.2vw, 2.85rem);
  line-height: 1.12;
  margin-top: 0;
}

.monroe-inner-page-shell h2 {
  font-size: clamp(1.65rem, 3.2vw, 2.35rem);
  line-height: 1.18;
}

.monroe-inner-page-shell h3 {
  font-size: clamp(1.35rem, 2.6vw, 1.85rem);
  line-height: 1.22;
}

.monroe-inner-page-shell p,
.monroe-inner-page-shell li {
  font-family: "Questrial", "Segoe UI", sans-serif;
  font-size: 1.05rem;
  line-height: 1.72;
  color: #2a3d3d;
}

.monroe-inner-page-shell a:not(.wp-block-button__link):not(.monroe-event-flyers__lightbox-download):not(.monroe-event-flyers__lightbox-more) {
  color: #0f766e;
  text-underline-offset: 2px;
}

.monroe-inner-page-shell a:not(.wp-block-button__link):not(.monroe-event-flyers__lightbox-download):not(.monroe-event-flyers__lightbox-more):hover,
.monroe-inner-page-shell a:not(.wp-block-button__link):not(.monroe-event-flyers__lightbox-download):not(.monroe-event-flyers__lightbox-more):focus {
  color: #0a5f59;
}

.monroe-inner-page-shell .wp-block-button__link {
  font-family: "Jost", "Segoe UI", sans-serif;
}

body.monroe-inner-listing .monroe-inner-page-shell .wp-block-post-title,
body.monroe-inner-listing .monroe-inner-page-shell .wp-block-query-title {
  font-family: "Abril Fatface", Georgia, serif;
  color: #153635;
}

/* --------------------------------------------------------------------------
   Adopt page (page-adopt.php): hero, quick links, full-width animal search
   -------------------------------------------------------------------------- */
.monroe-adopt-page .monroe-adopt-hero {
  margin: 0 0 clamp(1rem, 2vw, 1.5rem);
  padding-bottom: clamp(0.85rem, 1.8vw, 1.25rem);
  border-bottom: 1px solid rgba(23, 58, 57, 0.12);
}

.monroe-adopt-page .monroe-adopt-eyebrow {
  font-family: "Jost", "Segoe UI", sans-serif;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-size: 0.78rem;
  color: #0f766e;
  margin: 0 0 0.5rem;
}

.monroe-adopt-page .monroe-adopt-lead {
  max-width: 48rem;
  margin: 0;
  color: #2a3d3d;
}

.monroe-adopt-page .monroe-adopt-quick {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 0 0 clamp(1rem, 2vw, 1.35rem);
  max-width: 100%;
  overflow-x: clip;
}

.monroe-adopt-page .monroe-adopt-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0.45rem 0.95rem;
  border-radius: 999px;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-weight: 700;
  font-size: 0.8rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
  border: 1.5px solid rgba(15, 118, 110, 0.35);
  color: #0f766e;
  background: rgba(255, 255, 255, 0.92);
  transition: transform 0.12s ease, box-shadow 0.15s ease, background 0.15s ease;
}

.monroe-adopt-page .monroe-adopt-pill:hover,
.monroe-adopt-page .monroe-adopt-pill:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 8px 20px rgba(15, 118, 110, 0.18);
  color: #0a5f59;
}

.monroe-adopt-page .monroe-adopt-pill--primary {
  background: linear-gradient(135deg, #0d9488, #14b8a6);
  color: #fffaf2 !important;
  border-color: transparent;
  box-shadow: 0 6px 18px rgba(13, 148, 136, 0.22);
}

.monroe-adopt-page .monroe-adopt-pill--primary:hover,
.monroe-adopt-page .monroe-adopt-pill--primary:focus-visible {
  color: #fff !important;
  box-shadow: 0 10px 26px rgba(13, 148, 136, 0.32);
}

.monroe-adopt-page .monroe-adopt-pill--ghost {
  background: transparent;
  border-color: rgba(23, 58, 57, 0.2);
}

.monroe-adopt-page .monroe-adopt-pill--current {
  box-shadow: 0 0 0 2px rgba(15, 118, 110, 0.45), 0 8px 20px rgba(15, 118, 110, 0.12);
}

.monroe-adopt-page .monroe-adopt-pill--primary.monroe-adopt-pill--current {
  box-shadow: 0 0 0 2px rgba(255, 250, 242, 0.85), 0 10px 26px rgba(13, 148, 136, 0.35);
}

.monroe-adopt-page .monroe-adopt-search .monroe-animal-search-widget {
  position: relative;
  width: 100%;
  max-width: none;
  min-width: 0;
  margin: 0;
  padding: clamp(0.75rem, 2vw, 1rem) clamp(0.85rem, 2.2vw, 1.15rem) clamp(1rem, 2.5vw, 1.35rem);
  box-sizing: border-box;
}

.monroe-adopt-page .monroe-adopt-search .monroe-animal-search-widget .animal-search-results,
.monroe-adopt-page .monroe-adopt-search .monroe-animal-search-widget .results-grid {
  min-width: 0;
}

.monroe-adopt-page .monroe-adopt-search .monroe-animal-search-widget .results-grid.monroe-pet-results--grid {
  grid-template-columns: repeat(auto-fill, minmax(min(240px, 100%), 1fr));
}

.monroe-adopt-page .featured-pets-section #featuredPetsWidget,
.monroe-adopt-page .monroe-home-widget--featured_pets #featuredPetsWidget {
  width: 100%;
  max-width: 100%;
  min-width: 0;
}

.monroe-adopt-page .monroe-adopt-next {
  margin-top: clamp(2rem, 4vw, 3rem);
  padding-top: clamp(1.5rem, 3vw, 2.25rem);
  border-top: 1px solid rgba(23, 58, 57, 0.12);
}

.monroe-adopt-page .monroe-adopt-next h2 {
  margin-top: 0;
}

.monroe-adopt-page .monroe-adopt-next p {
  max-width: 42rem;
}

/* Adopt search — native integration */
.monroe-animal-search-widget--no-header .animal-search-header {
  display: none;
}

.monroe-adopt-page .monroe-adopt-search .monroe-animal-search-widget {
  background: rgba(255, 255, 255, 0.82);
  border: 1px solid rgba(23, 58, 57, 0.08);
  border-radius: 1rem;
  box-shadow: 0 8px 28px rgba(15, 30, 29, 0.05);
}

/* Compact adopt toolbar — slim sticky strip, extras scroll away */
.monroe-animal-search-widget--compact .animal-search-filters {
  background: transparent;
  border: 0;
  padding: 0;
  margin: 0 0 0.65rem;
}

.monroe-animal-search-widget--compact .animal-search-controls {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}

.monroe-adopt-page .monroe-animal-search-widget--compact .animal-search-toolbar {
  position: sticky;
  top: calc(var(--monroe-nav-height, 96px) + env(safe-area-inset-top, 0px));
  z-index: 40;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 0.45rem;
  padding: 0.45rem 0;
  margin: 0 -0.15rem;
  background: rgba(255, 250, 242, 0.92);
  border-bottom: 1px solid rgba(23, 58, 57, 0.06);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 6px 16px rgba(15, 30, 29, 0.04);
}

@media (max-width: 639px) {
  .monroe-adopt-page .monroe-animal-search-widget--compact .animal-search-toolbar {
    position: relative;
    top: auto;
    z-index: 1;
    box-shadow: none;
    border-bottom: 0;
    padding: 0 0 0.35rem;
  }
}

.monroe-animal-search-widget--compact .animal-search-query-row {
  margin: 0;
  order: 1;
}

.monroe-animal-search-widget--compact .filter-row--primary {
  order: 2;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.45rem;
  margin: 0;
}

.monroe-animal-search-widget--compact .animal-search-sort-row {
  order: 3;
  flex-direction: row;
  align-items: center;
  gap: 0.45rem;
  margin: 0;
}

.monroe-animal-search-widget--compact .animal-search-toolbar-actions {
  order: 4;
  display: flex;
  justify-content: flex-end;
}

.monroe-animal-search-widget--compact .filter-group label,
.monroe-animal-search-widget--compact .animal-search-sort-row label {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.monroe-animal-search-widget--compact .animal-filter,
.monroe-animal-search-widget--compact .animal-sort,
.monroe-animal-search-widget--compact .animal-search-q {
  min-height: 2.35rem;
  padding: 0.4rem 0.65rem;
  font-size: 0.875rem;
  border-width: 1px;
  border-radius: 0.55rem;
  border-color: rgba(23, 58, 57, 0.14);
  background: #fff;
}

.monroe-animal-search-widget--compact .animal-search-q {
  border-right-width: 0;
  border-radius: 0.55rem 0 0 0.55rem;
}

.monroe-animal-search-widget--compact .animal-search-submit {
  min-width: 2.5rem;
  min-height: 2.35rem;
  padding: 0 0.55rem;
  font-size: 1rem;
  border-width: 1px;
  border-radius: 0 0.55rem 0.55rem 0;
}

.monroe-animal-search-widget--compact .reset-button--compact {
  min-height: 2.35rem;
  padding: 0.35rem 0.85rem;
  font-size: 0.8125rem;
  font-weight: 650;
  border-radius: 999px;
  background: transparent;
  color: #0f766e;
  border: 1px solid rgba(15, 118, 110, 0.35);
}

.monroe-animal-search-widget--compact .reset-button--compact:hover {
  background: rgba(15, 118, 110, 0.08);
}

.monroe-animal-search-widget--compact .animal-search-footer {
  display: none;
}

.monroe-adopt-page .animal-search-summary.has-count {
  display: block;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-weight: 650;
  color: #3d5554;
  margin: 0 0 0.75rem;
  font-size: 0.8125rem;
  letter-spacing: 0.02em;
}

@media (min-width: 640px) {
  .monroe-adopt-page .monroe-animal-search-widget--compact .animal-search-toolbar {
    grid-template-columns: minmax(0, 1.6fr) minmax(7rem, 0.75fr) minmax(7rem, 0.75fr) minmax(7.5rem, 0.85fr) auto;
    grid-template-areas:
      "search type gender sort reset";
    align-items: center;
    gap: 0.4rem;
    padding: 0.4rem 0;
  }

  .monroe-animal-search-widget--compact .animal-search-query-row {
    grid-area: search;
  }

  .monroe-animal-search-widget--compact .filter-row--primary {
    display: contents;
  }

  .monroe-animal-search-widget--compact .filter-row--primary .filter-group:first-child {
    grid-area: type;
  }

  .monroe-animal-search-widget--compact .filter-row--primary .filter-group:last-child {
    grid-area: gender;
  }

  .monroe-animal-search-widget--compact .animal-search-sort-row {
    grid-area: sort;
  }

  .monroe-animal-search-widget--compact .animal-search-toolbar-actions {
    grid-area: reset;
  }
}

@media (min-width: 960px) {
  .monroe-adopt-page .monroe-animal-search-widget--compact .animal-search-toolbar {
    grid-template-columns: minmax(0, 2fr) 6.5rem 6.5rem 7rem auto;
    gap: 0.5rem;
  }
}

/* Interactive pet cards */
.animal-card--interactive {
  cursor: pointer;
}

.animal-card--interactive .animal-view-profile {
  margin: 0.85rem 0 0;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-weight: 700;
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #0f766e;
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 0.18s ease, transform 0.18s ease;
}

.animal-card--interactive:focus-within .animal-view-profile,
.animal-card--interactive:hover .animal-view-profile {
  opacity: 1;
  transform: none;
}

.animal-breed {
  margin: 0 0 0.5rem;
  font-size: 0.92rem;
  color: #4a5f5f;
}

.animal-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin: 0.35rem 0 0;
}

.animal-chip {
  display: inline-flex;
  align-items: center;
  padding: 0.22rem 0.55rem;
  border-radius: 999px;
  background: rgba(15, 118, 110, 0.1);
  color: #134e4a;
  font: 600 0.72rem/1.2 "Jost", "Segoe UI", sans-serif;
  letter-spacing: 0.02em;
}

/* Skeleton loading */
.results-loading {
  padding: 1.5rem 0 2rem;
}

.results-loading__message {
  text-align: center;
  color: #64748b;
  margin: 1rem 0 0;
  font-size: 0.95rem;
}

.results-skeleton-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(240px, 100%), 1fr));
  gap: 1.25rem;
}

.animal-card--skeleton .animal-image {
  background: linear-gradient(
    110deg,
    #e8f4f2 8%,
    #f4fbf9 18%,
    #e8f4f2 33%
  );
  background-size: 200% 100%;
  animation: monroe-skeleton-shimmer 1.4s ease-in-out infinite;
}

.animal-card--skeleton .animal-info {
  padding: 1rem 1.15rem 1.15rem;
}

.skeleton-line {
  height: 0.85rem;
  border-radius: 0.35rem;
  margin-bottom: 0.55rem;
  background: linear-gradient(
    110deg,
    #e8ecec 8%,
    #f5f7f7 18%,
    #e8ecec 33%
  );
  background-size: 200% 100%;
  animation: monroe-skeleton-shimmer 1.4s ease-in-out infinite;
}

.skeleton-line--title {
  width: 68%;
  height: 1rem;
}

.skeleton-line--short {
  width: 45%;
}

.skeleton-chips {
  height: 1.35rem;
  width: 80%;
  border-radius: 999px;
  margin-top: 0.65rem;
  background: linear-gradient(
    110deg,
    #e8ecec 8%,
    #f5f7f7 18%,
    #e8ecec 33%
  );
  background-size: 200% 100%;
  animation: monroe-skeleton-shimmer 1.4s ease-in-out infinite;
}

@keyframes monroe-skeleton-shimmer {
  0% {
    background-position: 200% 0;
  }
  100% {
    background-position: -200% 0;
  }
}

.empty-state-reset {
  border: none;
  cursor: pointer;
  font: inherit;
}

.filter-group--species[hidden] {
  display: none !important;
}

/* Petango profile modal */
.monroe-pet-profile-modal {
  padding: 0;
  border: none;
  max-width: min(640px, calc(100vw - 1.5rem));
  width: 100%;
  max-height: min(94vh, 900px);
  background: transparent;
}

.monroe-pet-profile-modal::backdrop {
  background: rgba(10, 18, 28, 0.62);
  backdrop-filter: blur(3px);
}

.monroe-pet-profile-modal.is-open {
  position: fixed;
  inset: 0;
  z-index: 10050;
  margin: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  background: rgba(10, 18, 28, 0.62);
}

.monroe-pet-profile-modal__panel {
  display: flex;
  flex-direction: column;
  width: 100%;
  max-height: min(94vh, 900px);
  background: #fff;
  border-radius: 1.1rem;
  box-shadow: 0 16px 48px rgba(15, 118, 110, 0.18);
  overflow: hidden;
  animation: monroe-modal-in 0.22s ease;
}

@keyframes monroe-modal-in {
  from {
    opacity: 0;
    transform: translateY(24px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: none;
  }
}

.monroe-pet-profile-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.15rem;
  border-bottom: 1px solid #e2e8f0;
  flex-shrink: 0;
}

.monroe-pet-profile-modal__title {
  margin: 0;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-size: 1.25rem;
  font-weight: 700;
  color: #0f766e;
}

.monroe-pet-profile-modal__close {
  flex-shrink: 0;
  width: 2.5rem;
  height: 2.5rem;
  border: none;
  border-radius: 999px;
  background: transparent;
  color: #64748b;
  font-size: 1.75rem;
  line-height: 1;
  cursor: pointer;
  transition: background 0.12s ease, color 0.12s ease;
}

.monroe-pet-profile-modal__close:hover,
.monroe-pet-profile-modal__close:focus-visible {
  background: #e0f2fe;
  color: #0d9488;
  outline: none;
}

.monroe-pet-profile-modal__body {
  position: relative;
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
  background: #fff;
}

.monroe-pet-profile-modal__iframe {
  flex: 1 1 auto;
  width: 100%;
  min-height: min(70vh, 640px);
  border: 0;
  background: #fff;
}

.monroe-pet-profile-modal__error {
  margin: 0;
  padding: 2rem 1.25rem;
  text-align: center;
  color: #64748b;
}

.monroe-pet-profile-modal__error[hidden] {
  display: none !important;
}

@media (max-width: 768px) {
  .monroe-adopt-page .monroe-adopt-search .animal-search-filters {
    margin-left: 0;
    margin-right: 0;
    padding-left: 0;
    padding-right: 0;
  }

  .monroe-animal-search-widget--compact .animal-search-controls {
    max-width: none;
    margin-inline: 0;
    padding: 0;
    background: transparent;
    border: 0;
    box-shadow: none;
  }

  .monroe-adopt-page .monroe-animal-search-widget--compact .animal-search-toolbar {
    padding: 0.35rem 0 0.45rem;
    margin: 0;
  }

  .monroe-pet-profile-modal__iframe {
    min-height: min(75vh, 720px);
  }

  .animal-card--interactive .animal-view-profile {
    opacity: 1;
    transform: none;
  }
}

/* --------------------------------------------------------------------------
   Adoptions page (consolidated policy + application)
   -------------------------------------------------------------------------- */
.monroe-adoptions-page .monroe-adoptions-hero {
  margin: 0 0 clamp(1rem, 2vw, 1.5rem);
  padding-bottom: clamp(0.85rem, 1.8vw, 1.25rem);
  border-bottom: 1px solid rgba(23, 58, 57, 0.12);
}

.monroe-adoptions-page .monroe-adoptions-eyebrow {
  font-family: "Jost", "Segoe UI", sans-serif;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-size: 0.78rem;
  color: #0f766e;
  margin: 0 0 0.5rem;
}

.monroe-adoptions-page .monroe-adoptions-lead {
  max-width: 42rem;
  margin: 0;
  color: #2a3d3d;
}

.monroe-adoptions-steps {
  list-style: none;
  margin: 0 0 clamp(1rem, 2vw, 1.35rem);
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 14rem), 1fr));
  gap: 0.65rem;
}

.monroe-adoptions-step {
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
  padding: 0.85rem 1rem;
  border-radius: 0.85rem;
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid rgba(23, 58, 57, 0.08);
}

.monroe-adoptions-step__num {
  flex-shrink: 0;
  width: 1.75rem;
  height: 1.75rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(15, 118, 110, 0.14);
  color: #0f766e;
  font: 700 0.82rem/1 "Jost", "Segoe UI", sans-serif;
}

.monroe-adoptions-step strong {
  display: block;
  font-family: "Jost", "Segoe UI", sans-serif;
  color: #163433;
  margin-bottom: 0.2rem;
}

.monroe-adoptions-step p {
  margin: 0;
  font-size: 0.88rem;
  color: #4a5f5f;
  line-height: 1.45;
}

.monroe-adoptions-quick {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 0 0 clamp(1.25rem, 2.5vw, 1.75rem);
}

.monroe-adoptions-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0.45rem 0.95rem;
  border-radius: 999px;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-weight: 700;
  font-size: 0.8rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
  border: 1.5px solid rgba(15, 118, 110, 0.35);
  color: #0f766e;
  background: rgba(255, 255, 255, 0.92);
  transition: transform 0.12s ease, box-shadow 0.15s ease, background 0.15s ease;
}

.monroe-adoptions-pill:hover,
.monroe-adoptions-pill:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 8px 20px rgba(15, 118, 110, 0.18);
  color: #0a5f59;
}

.monroe-adoptions-pill--primary {
  background: linear-gradient(135deg, #0d9488, #14b8a6);
  color: #fffaf2 !important;
  border-color: transparent;
  box-shadow: 0 6px 18px rgba(13, 148, 136, 0.22);
}

.monroe-adoptions-pill--ghost {
  background: transparent;
  border-color: rgba(23, 58, 57, 0.2);
}

.monroe-adoptions-section {
  margin: 0 0 clamp(1.5rem, 3vw, 2rem);
  padding: clamp(1rem, 2.5vw, 1.35rem) 0;
  scroll-margin-top: calc(var(--monroe-nav-height, 96px) + 1rem);
}

.monroe-adoptions-section h2 {
  margin: 0 0 0.85rem;
  color: #163433;
  font-family: "Jost", "Segoe UI", sans-serif;
}

.monroe-adoptions-section--muted {
  padding: clamp(1rem, 2.5vw, 1.25rem);
  border-radius: 0.85rem;
  background: rgba(255, 255, 255, 0.65);
  border: 1px solid rgba(23, 58, 57, 0.07);
}

.monroe-adoptions-section--form {
  padding-top: 0.5rem;
}

.monroe-adoptions-prose {
  max-width: 42rem;
  color: #2a3d3d;
}

.monroe-adoptions-prose p {
  margin: 0 0 0.75rem;
}

.monroe-adoptions-prose p:last-child {
  margin-bottom: 0;
}

.monroe-adoptions-checklist {
  margin: 1rem 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 0.45rem;
  max-width: 36rem;
}

.monroe-adoptions-checklist li {
  position: relative;
  padding-left: 1.35rem;
  font-size: 0.92rem;
  color: #2a3d3d;
}

.monroe-adoptions-checklist li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.45rem;
  width: 0.55rem;
  height: 0.55rem;
  border-radius: 999px;
  background: #14b8a6;
}

.monroe-adoptions-form-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 0.75rem 1rem;
  margin-bottom: 0.75rem;
  max-width: 640px;
  margin-inline: auto;
}

.monroe-adoptions-form-header h2 {
  margin: 0;
}

.monroe-adoptions-form-actions {
  margin: 0;
}

.monroe-adoptions-page .monroe-adopt-form-embed {
  border-radius: 0.85rem;
  box-shadow: 0 10px 32px rgba(15, 30, 29, 0.08);
  max-width: 640px;
  margin-inline: auto;
}

.monroe-adoptions-page .monroe-google-form-embed__hint {
  max-width: 640px;
  margin-inline: auto;
}

.monroe-adoptions-contact {
  margin-top: clamp(1.5rem, 3vw, 2rem);
  padding-top: clamp(1.25rem, 2.5vw, 1.75rem);
  border-top: 1px solid rgba(23, 58, 57, 0.12);
}

.monroe-adoptions-contact h2 {
  margin: 0 0 0.65rem;
  font-size: 1.1rem;
  color: #163433;
}

.monroe-adoptions-contact-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem 1.25rem;
}

.monroe-adoptions-contact-list a {
  font-weight: 650;
  color: #0f766e;
  text-decoration: none;
}

.monroe-adoptions-contact-list a:hover {
  text-decoration: underline;
}

/* --------------------------------------------------------------------------
   Memorials / memorial (native program pages)
   -------------------------------------------------------------------------- */
.monroe-memorials-page .monroe-memorials-hero {
  margin: 0 0 clamp(1.5rem, 3vw, 2.25rem);
  padding-bottom: clamp(1.25rem, 2.5vw, 1.75rem);
  border-bottom: 1px solid rgba(23, 58, 57, 0.12);
}

.monroe-memorials-page .monroe-memorials-eyebrow {
  font-family: "Jost", "Segoe UI", sans-serif;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-size: 0.78rem;
  color: #0f766e;
  margin: 0 0 0.5rem;
}

.monroe-memorials-page .monroe-memorials-lead {
  max-width: 48rem;
  margin: 0;
  color: #2a3d3d;
}

.monroe-memorials-page .monroe-memorials-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 320px), 1fr));
  gap: clamp(1.25rem, 3vw, 1.75rem);
  margin-bottom: clamp(2rem, 4vw, 3rem);
}

.monroe-memorials-page .monroe-memorials-card {
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(23, 58, 57, 0.12);
  border-radius: 18px;
  padding: clamp(1.25rem, 2.5vw, 1.75rem);
  box-shadow: 0 8px 28px rgba(15, 30, 29, 0.06);
}

.monroe-memorials-page .monroe-memorials-card h2 {
  margin-top: 0;
  font-size: clamp(1.35rem, 2.4vw, 1.65rem);
}

.monroe-memorials-page .monroe-memorials-list {
  margin: 1rem 0 0;
  padding-left: 1.25rem;
  color: #2a3d3d;
}

.monroe-memorials-page .monroe-memorials-note {
  color: #3d524f;
  font-size: 0.98rem;
  margin-top: 1rem;
}

.monroe-memorials-page .monroe-memorials-actions {
  flex-wrap: wrap;
  margin-top: 1rem;
}

.monroe-memorials-page .monroe-memorials-planned {
  padding: clamp(1.5rem, 3vw, 2rem);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid rgba(23, 58, 57, 0.1);
  margin-bottom: clamp(1.75rem, 3vw, 2.5rem);
}

.monroe-memorials-page .monroe-memorials-quote {
  margin: 1rem 0 1.5rem;
  padding: 1rem 1.25rem;
  border-left: 4px solid #0f766e;
  background: rgba(240, 253, 250, 0.65);
  border-radius: 0 12px 12px 0;
}

.monroe-memorials-page .monroe-memorials-quote p {
  margin: 0 0 0.35rem;
  font-style: italic;
}

.monroe-memorials-page .monroe-memorials-quote cite {
  font-style: normal;
  font-size: 0.95rem;
  color: #475569;
}

.monroe-memorials-page .monroe-memorials-planned-cta {
  margin-bottom: 0;
}

.monroe-memorials-page .monroe-memorials-related {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  padding-top: 0.5rem;
}

.monroe-memorials-page .monroe-memorials-related-link {
  display: inline-flex;
  align-items: center;
  padding: 0.5rem 1rem;
  border-radius: 999px;
  border: 1.5px solid rgba(15, 118, 110, 0.35);
  color: #0f766e;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-weight: 600;
  font-size: 0.88rem;
  text-decoration: none;
}

.monroe-memorials-page .monroe-memorials-related-link:hover,
.monroe-memorials-page .monroe-memorials-related-link:focus-visible {
  color: #0a5f59;
  box-shadow: 0 6px 16px rgba(15, 118, 110, 0.15);
}

/* Memorial & tributes honor roll (/memorial/) */
.monroe-memorial-tribute-page .monroe-tribute-board {
  --t-teal: #0f766e;
  --t-teal-2: #0d9488;
  --t-ink: #153635;
  --t-muted: #3d524f;
  --t-gold: #b45309;
  --t-border: rgba(23, 58, 57, 0.12);
  --t-surface: rgba(255, 255, 255, 0.96);
  --t-r-lg: 20px;
  --t-r-md: 14px;
  --t-shadow: 0 14px 40px rgba(15, 30, 29, 0.08);
  --t-shadow-sm: 0 2px 12px rgba(15, 30, 29, 0.06);
  max-width: 1080px;
  margin: 0 auto clamp(1.5rem, 3vw, 2.5rem);
  font-family: "Montserrat", "Jost", "Segoe UI", sans-serif;
  color: var(--t-ink);
  border-radius: var(--t-r-lg);
  border: 1px solid var(--t-border);
  background: var(--t-surface);
  box-shadow: var(--t-shadow);
  overflow: hidden;
}

.monroe-memorial-tribute-page .monroe-tribute-hero {
  text-align: center;
  padding: clamp(1.75rem, 4vw, 2.5rem) clamp(1.1rem, 3vw, 1.75rem) clamp(1.35rem, 3vw, 1.75rem);
  border-bottom: 1px solid var(--t-border);
  background:
    radial-gradient(ellipse 90% 120% at 50% -30%, rgba(15, 118, 110, 0.14), transparent 62%),
    linear-gradient(180deg, #fffaf2 0%, #ffffff 100%);
}

.monroe-memorial-tribute-page .monroe-tribute-hero__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.45rem;
  max-width: 40rem;
  margin: 0 auto;
}

.monroe-memorial-tribute-page .monroe-tribute-hero__eyebrow {
  margin: 0;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #0f766e;
}

.monroe-memorial-tribute-page .monroe-tribute-hero__title {
  margin: 0;
  font-family: "Abril Fatface", Georgia, serif;
  font-weight: 400;
  font-size: clamp(2rem, 4.5vw, 2.75rem);
  line-height: 1.1;
  letter-spacing: 0.01em;
  color: #153635;
}

.monroe-memorial-tribute-page .monroe-tribute-intro {
  padding: clamp(1.15rem, 2.5vw, 1.5rem) clamp(1.1rem, 3vw, 1.75rem) clamp(1.35rem, 3vw, 1.85rem);
  text-align: center;
  border-bottom: 1px solid var(--t-border);
  background: #fff;
}

.monroe-memorial-tribute-page .monroe-tribute-intro__text {
  max-width: 52rem;
  margin: 0 auto 0.75rem;
  color: var(--t-muted);
  line-height: 1.65;
  font-size: 1.05rem;
}

.monroe-memorial-tribute-page .monroe-tribute-intro__note {
  max-width: 48rem;
  margin: 0 auto 1.15rem;
  color: #5a6f6c;
  font-size: 0.95rem;
  line-height: 1.55;
}

.monroe-memorial-tribute-page .monroe-tribute-intro__actions {
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin-top: 0.25rem;
}

.monroe-memorial-tribute-page .monroe-tribute-btn.monroe-tribute-btn--primary {
  border-radius: 999px;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-size: 0.82rem;
  padding: 0.65rem 1.35rem;
  border: 1px solid rgba(255, 255, 255, 0.2);
  background: linear-gradient(180deg, var(--t-teal) 0%, #0b6b64 100%);
  color: #fff;
  box-shadow: 0 10px 24px rgba(13, 148, 136, 0.22);
  transition: transform 0.15s ease, box-shadow 0.15s ease, filter 0.15s ease;
}

.monroe-memorial-tribute-page .monroe-tribute-btn.monroe-tribute-btn--primary:hover,
.monroe-memorial-tribute-page .monroe-tribute-btn.monroe-tribute-btn--primary:focus-visible {
  transform: translateY(-1px);
  filter: brightness(1.03);
  box-shadow: 0 14px 30px rgba(13, 148, 136, 0.28);
}

.monroe-memorial-tribute-page .monroe-tribute-btn.monroe-tribute-btn--ghost {
  border-radius: 999px;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  font-size: 0.8rem;
  padding: 0.62rem 1.25rem;
  border: 2px solid rgba(15, 118, 110, 0.4);
  color: var(--t-teal);
  background: rgba(255, 255, 255, 0.9);
  transition: background 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
}

.monroe-memorial-tribute-page .monroe-tribute-btn.monroe-tribute-btn--ghost:hover,
.monroe-memorial-tribute-page .monroe-tribute-btn.monroe-tribute-btn--ghost:focus-visible {
  background: rgba(15, 118, 110, 0.06);
  color: #0a5f59;
  box-shadow: 0 6px 18px rgba(15, 118, 110, 0.12);
}

.monroe-memorial-tribute-page .monroe-tribute-roll {
  padding: 0 0 clamp(1.25rem, 2.5vw, 1.75rem);
  background: linear-gradient(180deg, #f8faf9 0%, #fff 55%);
}

.monroe-memorial-tribute-page .monroe-tribute-roll__head {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5rem 1rem;
  padding: 1.25rem clamp(1rem, 3vw, 1.5rem) 0.35rem;
  border-bottom: 1px solid rgba(23, 58, 57, 0.08);
}

.monroe-memorial-tribute-page .monroe-tribute-roll__heading {
  margin: 0;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-size: clamp(1.15rem, 2vw, 1.35rem);
  font-weight: 800;
  color: var(--t-ink);
}

.monroe-memorial-tribute-page .monroe-tribute-roll__sub {
  margin: 0;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--t-muted);
  letter-spacing: 0.04em;
}

.monroe-memorial-tribute-page .monroe-tribute-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 240px), 1fr));
  gap: clamp(0.85rem, 2vw, 1.1rem);
  padding: clamp(1rem, 2.5vw, 1.35rem);
}

.monroe-memorial-tribute-page .monroe-tribute-plaque {
  position: relative;
  margin: 0;
  padding: 1.1rem 1rem 1rem;
  text-align: center;
  border-radius: var(--t-r-md);
  border: 1px solid rgba(23, 58, 57, 0.1);
  background:
    radial-gradient(ellipse 140% 80% at 50% 0%, rgba(45, 212, 191, 0.09), transparent 55%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(255, 250, 242, 0.92));
  box-shadow: var(--t-shadow-sm);
  min-height: 132px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.monroe-memorial-tribute-page .monroe-tribute-plaque::before {
  content: "";
  position: absolute;
  inset: 9px;
  border-radius: 11px;
  border: 1px solid rgba(23, 58, 57, 0.07);
  pointer-events: none;
}

.monroe-memorial-tribute-page .monroe-tribute-plaque:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(15, 30, 29, 0.1);
  border-color: rgba(13, 148, 136, 0.28);
}

@media (hover: none), (pointer: coarse) {
  .monroe-memorial-tribute-page .monroe-tribute-plaque:hover {
    transform: none;
    box-shadow: var(--t-shadow-sm);
    border-color: rgba(23, 58, 57, 0.1);
  }
}

.monroe-memorial-tribute-page .monroe-tribute-plaque__type {
  margin: 0 0 0.45rem;
  padding-bottom: 0.35rem;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--t-muted);
  border-bottom: 2px solid rgba(23, 58, 57, 0.1);
}

.monroe-memorial-tribute-page .monroe-tribute-plaque__name {
  margin: 0 0 0.25rem;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-size: clamp(1.05rem, 1.8vw, 1.22rem);
  font-weight: 800;
  line-height: 1.2;
  color: var(--t-ink);
}

.monroe-memorial-tribute-page .monroe-tribute-plaque__meta {
  margin: 0;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--t-muted);
}

.monroe-memorial-tribute-page .monroe-tribute-plaque--honor .monroe-tribute-plaque__type {
  color: var(--t-teal);
  border-color: rgba(13, 148, 136, 0.35);
}

.monroe-memorial-tribute-page .monroe-tribute-plaque--birthday .monroe-tribute-plaque__type {
  color: var(--t-gold);
  border-color: rgba(180, 83, 9, 0.35);
}

.monroe-memorial-tribute-page .monroe-tribute-plaque--birthday .monroe-tribute-plaque__name {
  color: var(--t-gold);
}

.monroe-memorial-tribute-page .monroe-tribute-empty {
  margin: 0;
  padding: 2rem 1.25rem;
  text-align: center;
  color: var(--t-muted);
}

.monroe-memorial-tribute-page .monroe-tribute-foot {
  padding: 1rem 1.25rem 1.35rem;
  text-align: center;
  font-size: 0.98rem;
  color: var(--t-muted);
  border-top: 1px solid var(--t-border);
  background: rgba(255, 250, 242, 0.45);
}

.monroe-memorial-tribute-page .monroe-tribute-foot a {
  color: var(--t-teal);
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.monroe-memorial-tribute-page .monroe-tribute-foot a:hover,
.monroe-memorial-tribute-page .monroe-tribute-foot a:focus-visible {
  color: #0a5f59;
}

@media (prefers-reduced-motion: reduce) {
  .monroe-memorial-tribute-page .monroe-tribute-plaque,
  .monroe-memorial-tribute-page .monroe-tribute-btn.monroe-tribute-btn--primary,
  .monroe-memorial-tribute-page .monroe-tribute-btn.monroe-tribute-btn--ghost {
    transition: none;
  }

  .monroe-memorial-tribute-page .monroe-tribute-plaque:hover,
  .monroe-memorial-tribute-page .monroe-tribute-btn.monroe-tribute-btn--primary:hover,
  .monroe-memorial-tribute-page .monroe-tribute-btn.monroe-tribute-btn--ghost:hover {
    transform: none;
  }
}

@media (max-width: 640px) {
  .monroe-memorial-tribute-page .monroe-tribute-grid {
    grid-template-columns: 1fr;
  }
}

/* --------------------------------------------------------------------------
   Native inner landing (template-parts/native-inner-landing.php)
   -------------------------------------------------------------------------- */
.monroe-native-inner .monroe-native-hero {
  margin: 0 0 clamp(1.5rem, 3vw, 2.25rem);
  padding-bottom: clamp(1.25rem, 2.5vw, 1.75rem);
  border-bottom: 1px solid rgba(23, 58, 57, 0.12);
}

.monroe-native-inner .monroe-native-eyebrow {
  font-family: "Jost", "Segoe UI", sans-serif;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-size: 0.78rem;
  color: #0f766e;
  margin: 0 0 0.5rem;
}

.monroe-native-inner .monroe-native-lead {
  max-width: 48rem;
  margin: 0 0 1rem;
  color: #2a3d3d;
}

.monroe-native-inner .monroe-native-stack {
  margin: clamp(1.5rem, 3vw, 2.25rem) 0;
  max-width: 52rem;
}

.monroe-native-inner .monroe-native-list {
  margin: 0.75rem 0 0;
  padding-left: 1.25rem;
}

.monroe-native-inner .monroe-native-actions {
  margin-top: 1rem;
  flex-wrap: wrap;
  gap: 0.65rem;
}

.monroe-native-inner .monroe-native-anchor-section {
  scroll-margin-top: calc(var(--monroe-nav-height, 96px) + 12px);
}

.monroe-native-inner .monroe-native-widget-slot {
  margin: clamp(1.25rem, 2.5vw, 2rem) 0;
}

.monroe-native-inner .monroe-native-related,
.monroe-native-inner .monroe-native-foot {
  margin-top: 1.5rem;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-size: 0.95rem;
}

.monroe-native-inner .monroe-native-related {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem 1.25rem;
}

.monroe-native-inner .monroe-native-related a {
  font-weight: 600;
}

.monroe-native-inner .monroe-native-nowrap {
  white-space: nowrap;
}

/* Dog & Cat Shelter native page: FAQ, Instagram embed */
.monroe-native-inner--dog-and-cat-shelter .monroe-native-stack h3 {
  font-family: "Jost", "Segoe UI", sans-serif;
  font-size: clamp(1.05rem, 2.2vw, 1.2rem);
  font-weight: 700;
  color: #153635;
  margin: 1.35rem 0 0.45rem;
}

.monroe-native-inner--dog-and-cat-shelter .monroe-native-stack h3:first-of-type {
  margin-top: 0.35rem;
}

.monroe-native-inner--dog-and-cat-shelter .monroe-native-faq-stack .monroe-native-details {
  margin: 0.65rem 0 0;
  padding: 0.65rem 0.85rem;
  border: 1px solid rgba(23, 58, 57, 0.15);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.65);
}

.monroe-native-inner--dog-and-cat-shelter .monroe-native-faq-stack .monroe-native-details summary {
  font-weight: 600;
  cursor: pointer;
  color: #0f766e;
}

.monroe-native-inner--dog-and-cat-shelter .monroe-native-faq-stack .monroe-native-details[open] summary {
  margin-bottom: 0.5rem;
}

.monroe-native-inner--dog-and-cat-shelter .monroe-native-faq-stack .monroe-native-details p {
  margin: 0.5rem 0 0;
  color: #2a3d3d;
}

.monroe-native-inner--dog-and-cat-shelter .monroe-native-instagram-embed {
  margin-top: 1rem;
  max-width: 540px;
}

.monroe-native-inner--dog-and-cat-shelter .monroe-native-instagram-embed .instagram-media {
  margin: 0 !important;
  max-width: 100% !important;
  min-width: 0 !important;
}

.monroe-native-inner--dog-and-cat-shelter .monroe-native-instagram-fallback-note {
  font-size: 0.9rem;
  color: #3d5554;
}

.monroe-native-inner--dog-and-cat-shelter .monroe-native-widget-slot {
  max-width: none;
}

.monroe-native-inner--dog-and-cat-shelter .monroe-native-widget-slot .monroe-home-widget {
  width: 100%;
  max-width: none;
}

.monroe-native-inner--dog-and-cat-shelter .monroe-native-stack {
  overflow: visible;
}

.monroe-native-inner--dog-and-cat-shelter #sponsorMarqueeWidget.sponsor-marquee,
.monroe-native-inner--dog-and-cat-shelter .monroe-sponsor-marquee {
  width: 100%;
  max-width: none;
}

.monroe-native-inner--dog-and-cat-shelter .monroe-home-widget--community_vet .sponsor-widget-shell,
.monroe-native-inner--dog-and-cat-shelter .monroe-home-widget--community_vet .sponsor-widget {
  padding: 0;
  max-width: none;
}

.monroe-native-inner--dog-and-cat-shelter .monroe-home-widget--community_vet .sponsor-grid {
  margin-top: 0.5rem;
}

/* --------------------------------------------------------------------------
   Visual polish — scroll reveal, pills, trust, hero stats, empty widgets
   -------------------------------------------------------------------------- */
.monroe-reveal-target {
  opacity: 0;
  transform: translate3d(0, 16px, 0);
  transition: opacity 0.55s ease, transform 0.55s ease;
}

.monroe-reveal-target.is-revealed {
  opacity: 1;
  transform: none;
}

@media (prefers-reduced-motion: reduce) {
  .monroe-reveal-target {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .monroe-sponsor-marquee__track img,
  #sponsorMarqueeWidget .logo-set img {
    transition: none;
  }
}

.monroe-inner-page-pills {
  position: sticky;
  top: calc(var(--monroe-nav-height, 96px) + 8px);
  z-index: 15;
  display: flex;
  flex-wrap: nowrap;
  gap: 0.5rem;
  margin: 0 0 clamp(1rem, 2vw, 1.35rem);
  padding: 0.5rem 0;
  overflow-x: auto;
  scroll-snap-type: x proximity;
  -webkit-overflow-scrolling: touch;
}

@media (max-width: 768px) {
  .monroe-inner-page-pills {
    top: calc(var(--monroe-nav-height, 96px) + 4px);
    margin-bottom: clamp(0.85rem, 2vw, 1.15rem);
    padding-top: 0.35rem;
    padding-bottom: 0.35rem;
    padding-left: max(0px, env(safe-area-inset-left, 0px));
    padding-right: max(0px, env(safe-area-inset-right, 0px));
    gap: 0.45rem;
  }
}

.monroe-inner-page-pills__link {
  flex: 0 0 auto;
  scroll-snap-align: start;
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  padding: 0.45rem 0.95rem;
  border-radius: 999px;
  border: 1px solid rgba(23, 58, 57, 0.18);
  background: rgba(255, 255, 255, 0.92);
  color: #163433;
  font: 600 0.82rem/1.2 "Jost", "Segoe UI", sans-serif;
  text-decoration: none;
  white-space: nowrap;
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.monroe-inner-page-pills__link:hover,
.monroe-inner-page-pills__link:focus-visible {
  border-color: rgba(15, 118, 110, 0.45);
  color: #0f766e;
}

.monroe-inner-page-pills__link.is-active,
.monroe-inner-page-pills__link[aria-current="true"] {
  background: rgba(15, 118, 110, 0.14);
  border-color: #0f766e;
  color: #0b534e;
}

.monroe-native-inner .monroe-native-stack h2[id],
.monroe-native-inner .monroe-native-anchor-section {
  scroll-margin-top: calc(
    var(--monroe-nav-height, 96px) + var(--monroe-sticky-wayfinding-offset, 0px) + var(--monroe-scroll-anchor-gap, 12px)
  );
}

.monroe-trust-row {
  margin: clamp(1.25rem, 2.5vw, 2rem) 0;
}

.monroe-trust-row__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr));
  gap: 0.85rem;
}

.monroe-trust-row__item {
  padding: 1rem 1.1rem;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(23, 58, 57, 0.12);
  box-shadow: 0 12px 28px rgba(17, 41, 41, 0.06);
}

.monroe-trust-row__label {
  display: block;
  font: 700 0.95rem/1.25 "Jost", "Segoe UI", sans-serif;
  color: #0f766e;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.monroe-trust-row__detail {
  display: block;
  margin-top: 0.35rem;
  font-size: 0.92rem;
  line-height: 1.45;
  color: #2a3d3d;
}

.monroe-day-in-life {
  margin: clamp(1.25rem, 2.5vw, 2rem) 0;
}

.monroe-day-in-life__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 240px), 1fr));
  gap: 1rem;
  margin-top: 0.85rem;
}

.monroe-day-in-life__card {
  padding: 0;
  border-radius: 18px;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(23, 58, 57, 0.12);
  box-shadow: 0 16px 34px rgba(17, 41, 41, 0.08);
}

.monroe-day-in-life__media {
  aspect-ratio: 16 / 10;
  width: 100%;
  overflow: hidden;
  background: #e8f0ef;
}

.monroe-day-in-life__media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.monroe-day-in-life__card h3 {
  margin: 0.85rem 1rem 0.35rem;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-size: 1.05rem;
  color: #153635;
}

.monroe-day-in-life__card p {
  margin: 0 1rem 1rem;
  font-size: 0.92rem;
  color: #2a3d3d;
}

.monroe-widget-empty {
  padding: clamp(1.25rem, 2.5vw, 1.75rem);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.94);
  border: 1px dashed rgba(15, 118, 110, 0.35);
  text-align: center;
}

.monroe-widget-empty__title {
  margin: 0 0 0.5rem;
  font-family: "Abril Fatface", Georgia, serif;
  font-size: 1.45rem;
  color: #153635;
}

.monroe-widget-empty p {
  margin: 0.35rem 0;
  color: #2a3d3d;
}

.page-slug-home-editable .home-editable-hero-stats,
body[data-page-alias="home-editable"] .home-editable-hero-stats {
  margin-top: 1.15rem;
}

.page-slug-home-editable .home-editable-stat-grid--hero,
body[data-page-alias="home-editable"] .home-editable-stat-grid--hero {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 180px), 1fr));
  gap: 0.65rem;
}

.page-slug-home-editable .home-editable-stat-grid--hero .home-editable-stat,
body[data-page-alias="home-editable"] .home-editable-stat-grid--hero .home-editable-stat {
  padding: 0.85rem 0.95rem;
  border-radius: 14px;
  background: rgba(11, 23, 24, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.14);
  backdrop-filter: blur(8px);
}

.page-slug-home-editable .home-editable-stat-grid--hero .home-editable-stat strong,
.page-slug-home-editable .home-editable-stat-grid--hero .home-editable-stat h3,
.page-slug-home-editable .home-editable-stat-grid--hero .home-editable-stat p,
body[data-page-alias="home-editable"] .home-editable-stat-grid--hero .home-editable-stat strong,
body[data-page-alias="home-editable"] .home-editable-stat-grid--hero .home-editable-stat h3,
body[data-page-alias="home-editable"] .home-editable-stat-grid--hero .home-editable-stat p {
  color: rgba(255, 255, 255, 0.95);
}

.page-slug-home-editable .home-editable-stat-grid--hero .home-editable-stat.is-accent,
body[data-page-alias="home-editable"] .home-editable-stat-grid--hero .home-editable-stat.is-accent {
  background: rgba(15, 118, 110, 0.72);
}

/* --------------------------------------------------------------------------
   Membership page (/membership/) — hero, benefits, tier grid (matches homepage)
   -------------------------------------------------------------------------- */
.monroe-native-inner--membership .monroe-membership-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
  gap: clamp(1.25rem, 3vw, 2.5rem);
  align-items: center;
  margin: 0 0 clamp(2rem, 4vw, 3rem);
  padding: clamp(1.35rem, 3vw, 2rem);
  border-radius: 28px;
  border: 1px solid rgba(15, 118, 110, 0.14);
  background:
    radial-gradient(120% 90% at 0% 0%, rgba(43, 184, 243, 0.14), transparent 55%),
    radial-gradient(90% 80% at 100% 100%, rgba(15, 118, 110, 0.16), transparent 50%),
    linear-gradient(145deg, #f7fbf9 0%, #eef6f4 48%, #fffaf2 100%);
  box-shadow: 0 22px 50px rgba(17, 41, 41, 0.08);
  overflow: hidden;
}

.monroe-native-inner--membership .monroe-membership-hero__media {
  border-radius: 20px;
  overflow: hidden;
  min-height: 260px;
  box-shadow: 0 16px 40px rgba(17, 41, 41, 0.12);
}

.monroe-native-inner--membership .monroe-membership-hero__media img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 260px;
  object-fit: cover;
}

@media (max-width: 768px) {
  .monroe-native-inner--membership .monroe-membership-hero__media,
  .monroe-native-inner--membership .monroe-membership-hero__media img {
    min-height: 180px;
  }
}

.monroe-native-inner--membership .monroe-membership-hero__copy h1 {
  margin: 0 0 0.65rem;
  font-family: "Abril Fatface", Georgia, serif;
  font-size: clamp(2rem, 4.8vw, 2.85rem);
  line-height: 1.08;
  color: #153635;
}

.monroe-native-inner--membership .monroe-membership-benefits {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1rem, 2.5vw, 1.5rem);
  margin: 0 0 clamp(2rem, 4vw, 2.75rem);
}

.monroe-native-inner--membership .monroe-membership-benefit {
  padding: clamp(1.1rem, 2.5vw, 1.45rem);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid rgba(36, 72, 67, 0.12);
  box-shadow: 0 12px 28px rgba(17, 41, 41, 0.06);
}

.monroe-native-inner--membership .monroe-membership-benefit h2 {
  margin: 0 0 0.45rem;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-size: clamp(1.05rem, 2.2vw, 1.2rem);
  color: #0f766e;
}

.monroe-native-inner--membership .monroe-membership-benefit p {
  margin: 0;
  color: #405757;
  font-size: 0.95rem;
  line-height: 1.5;
}

.monroe-native-inner--membership .monroe-membership-plans {
  margin: 0 0 clamp(2rem, 4vw, 2.75rem);
  padding: clamp(1.5rem, 3.5vw, 2.25rem);
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(247, 251, 249, 0.98) 100%);
  border: 1px solid rgba(36, 72, 67, 0.1);
  box-shadow: 0 20px 48px rgba(17, 41, 41, 0.07);
}

.monroe-native-inner--membership .monroe-membership-plans,
.monroe-native-inner--membership .monroe-membership-surface {
  max-width: none;
}

.monroe-native-inner--membership .home-editable-membership-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(1rem, 2.8vw, 1.75rem);
  align-items: stretch;
  width: 100%;
  margin: 0;
  list-style: none;
  padding: 0;
}

.monroe-native-inner--membership .home-editable-membership-card-wrap {
  min-width: 0;
  display: flex;
  margin: 0;
}

.monroe-native-inner--membership .home-editable-membership-intro {
  max-width: 52rem;
  margin-bottom: clamp(1.25rem, 3vw, 2rem);
}

.monroe-native-inner--membership .home-editable-membership-intro > h2.wp-block-heading {
  margin-top: 0;
}

.monroe-native-inner--membership .home-editable-membership-card {
  width: 100%;
  height: 100%;
  margin: 0;
  padding: clamp(1.25rem, 3vw, 1.65rem);
  border-radius: 24px;
  border: 1px solid rgba(36, 72, 67, 0.14);
  background: #fff;
  box-shadow: 0 18px 42px rgba(17, 41, 41, 0.09);
  display: flex;
  flex-direction: column;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.monroe-native-inner--membership .home-editable-membership-card.is-featured {
  position: relative;
  border: 2px solid #0f766e;
  box-shadow:
    0 18px 42px rgba(15, 118, 110, 0.18),
    0 0 0 1px rgba(15, 118, 110, 0.08);
  padding-top: clamp(2.35rem, 4vw, 2.75rem);
}

.monroe-native-inner--membership .home-editable-membership-card.is-featured::before {
  content: "Popular";
  position: absolute;
  top: 0.65rem;
  left: 50%;
  transform: translateX(-50%);
  padding: 0.28rem 0.85rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #0f766e, #134e4a);
  color: #fff;
  font: 700 0.68rem/1 "Jost", "Segoe UI", sans-serif;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.monroe-native-inner--membership .home-editable-membership-price {
  margin: 0 0 0.35rem;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-weight: 800;
  font-size: clamp(2rem, 4vw, 2.65rem);
  line-height: 1.05;
  letter-spacing: -0.03em;
  color: #153635;
}

.monroe-native-inner--membership .home-editable-membership-period {
  font-weight: 600;
  font-size: 0.42em;
  letter-spacing: 0.02em;
  color: rgba(21, 54, 53, 0.72);
}

.monroe-native-inner--membership .home-editable-membership-card h3.wp-block-heading {
  margin: 0 0 1rem;
  font-size: clamp(1.25rem, 2.4vw, 1.45rem);
  line-height: 1.2;
  color: #153635;
}

.monroe-native-inner--membership .home-editable-membership-perks {
  flex: 1 1 auto;
  margin: 0 0 1.25rem;
  padding: 0;
  list-style: none;
}

.monroe-native-inner--membership .home-editable-membership-perks li {
  position: relative;
  margin: 0 0 0.55rem;
  padding-left: 1.45rem;
  font-size: 0.95rem;
  line-height: 1.45;
  color: #405757;
}

.monroe-native-inner--membership .home-editable-membership-perks li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.35em;
  width: 0.55rem;
  height: 0.55rem;
  border-radius: 50%;
  background: #0f766e;
  box-shadow: 0 0 0 2px rgba(15, 118, 110, 0.2);
}

.monroe-native-inner--membership .home-editable-membership-card .wp-block-buttons {
  margin-top: auto;
  margin-bottom: 0;
}

.monroe-native-inner--membership .home-editable-membership-card .wp-block-button {
  width: 100%;
}

.monroe-native-inner--membership .home-editable-membership-card .wp-block-button__link {
  width: 100%;
  justify-content: center;
  text-align: center;
  padding: 0.85rem 1.25rem;
}

.monroe-native-inner--membership .monroe-membership-how {
  max-width: 52rem;
}

.monroe-native-inner--membership .monroe-membership-steps {
  margin: 0.75rem 0 0;
  padding-left: 1.35rem;
  color: #2a3d3d;
}

.monroe-native-inner--membership .monroe-membership-steps li {
  margin-bottom: 0.65rem;
  line-height: 1.5;
}

.monroe-native-inner--membership .monroe-membership-cta-band {
  margin: clamp(2rem, 4vw, 3rem) 0 0;
  padding: clamp(1.75rem, 4vw, 2.5rem);
  border-radius: 24px;
  text-align: center;
  background: linear-gradient(135deg, #0f766e 0%, #134e4a 55%, #163433 100%);
  color: #fff;
  box-shadow: 0 24px 52px rgba(15, 118, 110, 0.22);
}

.monroe-native-inner--membership .monroe-membership-cta-band h2 {
  margin: 0 0 0.5rem;
  font-family: "Abril Fatface", Georgia, serif;
  font-size: clamp(1.65rem, 3.5vw, 2.2rem);
  color: #fff;
}

.monroe-native-inner--membership .monroe-membership-cta-band p {
  margin: 0 auto 1.25rem;
  max-width: 36rem;
  color: rgba(255, 255, 255, 0.92);
}

.monroe-native-inner--membership #Plans {
  scroll-margin-top: calc(var(--monroe-nav-height, 96px) + 12px);
}

@media (max-width: 1100px) {
  .monroe-native-inner--membership .monroe-membership-hero {
    grid-template-columns: 1fr;
  }

  .monroe-native-inner--membership .home-editable-membership-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .monroe-native-inner--membership .monroe-membership-benefits {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 560px) {
  .monroe-native-inner--membership .home-editable-membership-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  /* Touch devices often keep :hover after tap; translateY then stacks cards over neighbors. */
  .monroe-native-inner--membership .home-editable-membership-grid {
    align-items: start;
    gap: clamp(1.2rem, 4.5vw, 1.85rem);
  }

  .monroe-native-inner--membership .home-editable-membership-card-wrap {
    position: relative;
    z-index: 0;
    isolation: isolate;
  }

  .monroe-native-inner--membership .home-editable-membership-card,
  .monroe-native-inner--membership .home-editable-membership-card:hover {
    transform: none;
    transition: box-shadow 0.2s ease;
  }

  .monroe-native-inner--membership .monroe-membership-hero {
    padding: clamp(1rem, 4vw, 1.5rem);
    margin-bottom: clamp(1.35rem, 4vw, 2rem);
  }

  .monroe-native-inner--membership .monroe-membership-benefits {
    margin-bottom: clamp(1.35rem, 4vw, 2rem);
  }

  .monroe-native-inner--membership .monroe-membership-plans {
    padding: clamp(1.15rem, 4vw, 1.75rem);
    margin-bottom: clamp(1.35rem, 4vw, 2.25rem);
  }

  .monroe-native-inner--membership .home-editable-membership-intro {
    margin-bottom: clamp(1rem, 3vw, 1.35rem);
  }

  .monroe-native-inner--membership .monroe-membership-how {
    margin-top: 0.25rem;
  }

  .monroe-native-inner--membership .monroe-membership-cta-band {
    margin-top: clamp(1.5rem, 4vw, 2.25rem);
    padding: clamp(1.5rem, 4vw, 2rem);
  }

  /* In-flow ribbon: absolute Popular label can visually intrude into the row gap above */
  .monroe-native-inner--membership .home-editable-membership-card.is-featured {
    padding-top: clamp(1.2rem, 3.2vw, 1.5rem);
  }

  .monroe-native-inner--membership .home-editable-membership-card.is-featured::before {
    position: static;
    transform: none;
    display: table;
    margin: 0 auto 0.75rem;
    left: auto;
  }
}

@media (hover: hover) and (pointer: fine) {
  .monroe-native-inner--membership .home-editable-membership-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 22px 48px rgba(17, 41, 41, 0.12);
  }
}

@media (hover: none), (pointer: coarse) {
  .monroe-native-inner--membership .home-editable-membership-card:hover {
    transform: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  .monroe-native-inner--membership .home-editable-membership-card:hover {
    transform: none;
  }
}

/* --------------------------------------------------------------------------
   Events page — year calendar (shortcode: [monroe_events_calendar year="2026"])
   Matches native inner shell: cream/teal, Jost + Abril rhythm.
   -------------------------------------------------------------------------- */
.monroe-events-calendar {
  margin: clamp(1.25rem, 3vw, 2rem) 0 clamp(1.5rem, 3vw, 2.25rem);
  width: 100%;
  max-width: 100%;
}

.monroe-events-calendar__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 260px), 1fr));
  gap: clamp(1rem, 2.5vw, 1.35rem);
}

.monroe-events-calendar__month {
  box-sizing: border-box;
  padding: clamp(1rem, 2.4vw, 1.35rem);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(23, 58, 57, 0.12);
  box-shadow: 0 14px 34px rgba(17, 41, 41, 0.07);
}

.monroe-events-calendar__month-title {
  margin: 0 0 0.75rem;
  font-family: "Abril Fatface", Georgia, serif;
  font-weight: 400;
  font-size: clamp(1.15rem, 2.4vw, 1.45rem);
  line-height: 1.15;
  color: #153635;
  text-align: center;
}

.monroe-events-calendar__table {
  width: 100%;
}

.monroe-events-calendar__weekdays {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 2px;
  margin-bottom: 0.35rem;
}

.monroe-events-calendar__weekday {
  font-family: "Jost", "Segoe UI", sans-serif;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-align: center;
  color: #0f766e;
  padding: 0.2rem 0;
}

.monroe-events-calendar__week {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 2px;
}

.monroe-events-calendar__week + .monroe-events-calendar__week {
  margin-top: 2px;
}

.monroe-events-calendar__day {
  box-sizing: border-box;
  min-height: 2.15rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  font-family: "Questrial", "Segoe UI", sans-serif;
  font-size: 0.88rem;
  color: #1d2a2a;
  background: rgba(248, 250, 250, 0.85);
  border: 1px solid transparent;
}

.monroe-events-calendar__day--pad {
  background: transparent;
  border-color: transparent;
  min-height: 2.15rem;
}

.monroe-events-calendar__day--weekend .monroe-events-calendar__day-num {
  color: #2d6a66;
}

.monroe-events-calendar__day--today {
  background: rgba(15, 118, 110, 0.12);
  border-color: rgba(15, 118, 110, 0.45);
  font-weight: 700;
}

.monroe-events-calendar__day--event {
  position: relative;
  flex-direction: column;
  gap: 0.15rem;
  padding-top: 0.2rem;
  padding-bottom: 0.15rem;
}

a.monroe-events-calendar__day {
  text-decoration: none;
  color: inherit;
}

a.monroe-events-calendar__day:hover,
a.monroe-events-calendar__day:focus-visible {
  border-color: rgba(15, 118, 110, 0.55);
  background: rgba(15, 118, 110, 0.16);
  transform: translateY(-1px);
}

.monroe-events-calendar__day--event-upcoming {
  background: rgba(80, 200, 120, 0.18);
  border-color: rgba(15, 118, 110, 0.35);
}

.monroe-events-calendar__day-dot {
  display: block;
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: linear-gradient(135deg, #0f766e, #50c878);
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.85);
}

.monroe-events-calendar__legend,
.monroe-events-calendar-widget__legend {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  margin: 0 0 0.85rem;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-size: 0.82rem;
  font-weight: 600;
  color: #2a4a49;
}

.monroe-events-calendar__legend-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(135deg, #0f766e, #50c878);
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.9);
}

/* Homepage + embed: compact calendar widget ([monroe_events_calendar_widget]) */
.monroe-events-calendar-widget {
  margin-top: clamp(1rem, 2.5vw, 1.5rem);
}

.monroe-events-calendar-widget__head {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5rem 1rem;
  margin-bottom: 1rem;
}

.monroe-events-calendar-widget__title {
  margin: 0;
  font-family: "Abril Fatface", Georgia, serif;
  font-size: clamp(1.25rem, 2.5vw, 1.55rem);
  font-weight: 400;
  line-height: 1.15;
  color: #153635;
}

.monroe-events-calendar-widget__layout {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(220px, 0.85fr);
  gap: clamp(1rem, 2.5vw, 1.5rem);
  align-items: start;
}

.monroe-events-calendar-widget__months {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 240px), 1fr));
  gap: clamp(0.85rem, 2vw, 1.1rem);
}

.monroe-events-calendar__month--compact {
  padding: clamp(0.85rem, 2vw, 1rem);
  border-radius: 16px;
}

.monroe-events-calendar__month--compact .monroe-events-calendar__month-title {
  font-size: clamp(1rem, 2vw, 1.15rem);
  margin-bottom: 0.55rem;
}

.monroe-events-calendar__month--compact .monroe-events-calendar__day {
  min-height: 1.85rem;
  font-size: 0.8rem;
}

.monroe-events-calendar-widget__upcoming {
  padding: clamp(0.9rem, 2vw, 1.1rem);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(23, 58, 57, 0.1);
}

.monroe-events-calendar-widget__upcoming-title {
  margin: 0 0 0.75rem;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #0f766e;
}

.monroe-events-calendar-widget__empty {
  margin: 0;
  font-size: 0.92rem;
  line-height: 1.55;
  color: #405757;
}

.monroe-events-calendar-widget__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.55rem;
}

.monroe-events-calendar-widget__list-link {
  display: grid;
  gap: 0.15rem;
  padding: 0.65rem 0.75rem;
  border-radius: 12px;
  text-decoration: none;
  background: rgba(248, 250, 250, 0.95);
  border: 1px solid rgba(15, 118, 110, 0.12);
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.monroe-events-calendar-widget__list-link:hover,
.monroe-events-calendar-widget__list-link:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(15, 118, 110, 0.35);
  box-shadow: 0 10px 22px rgba(17, 41, 41, 0.08);
}

.monroe-events-calendar-widget__list-date {
  font-family: "Jost", "Segoe UI", sans-serif;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #0f766e;
}

.monroe-events-calendar-widget__list-title {
  font-family: "Questrial", "Segoe UI", sans-serif;
  font-size: 0.95rem;
  line-height: 1.35;
  color: #153635;
}

.monroe-events-calendar-widget__actions {
  margin: 0.85rem 0 0;
}

.monroe-events-calendar-widget__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.55rem 0.95rem;
  border-radius: 999px;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-decoration: none;
  color: #0a121c;
  background: linear-gradient(135deg, #50c878, #72cbff);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.12);
}

.page-slug-home-editable .home-editable-news-card .monroe-events-calendar-widget__title,
body[data-page-alias="home-editable"] .home-editable-news-card .monroe-events-calendar-widget__title {
  color: #153635;
}

.page-slug-home-editable .home-editable-news-card .monroe-events-calendar-widget__legend,
body[data-page-alias="home-editable"] .home-editable-news-card .monroe-events-calendar-widget__legend {
  color: #405757;
}

@media (max-width: 820px) {
  .monroe-events-calendar-widget__layout {
    grid-template-columns: 1fr;
  }
}

.monroe-events-calendar__year-heading {
  margin: clamp(1.25rem, 3vw, 1.75rem) 0 0.75rem;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-size: clamp(1rem, 2.2vw, 1.2rem);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #0f766e;
}

.monroe-events-calendar__day-num {
  line-height: 1;
}

@media (max-width: 520px) {
  .monroe-events-calendar__month-title {
    font-size: 1.1rem;
  }

  .monroe-events-calendar__day {
    min-height: 1.95rem;
    font-size: 0.82rem;
  }
}

/* Events page — staff-uploaded flyers (/events/#EventFlyers) */
.monroe-event-flyers {
  margin: 0 0 clamp(2rem, 4vw, 2.75rem);
}

.monroe-event-flyers__lead {
  max-width: 42rem;
  margin: 0 0 1.25rem;
}

.monroe-event-flyers__empty {
  margin: 0;
  padding: 1.25rem 1.35rem;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.92);
  border: 1px dashed rgba(15, 118, 110, 0.35);
  color: #2a3d3d;
}

.monroe-event-flyers__grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 240px), 1fr));
  gap: clamp(1rem, 2.5vw, 1.5rem);
}

.monroe-event-flyers__item {
  margin: 0;
  min-width: 0;
  scroll-margin-top: calc(
    var(--monroe-nav-height, 96px) + var(--monroe-sticky-wayfinding-offset, 0px) + var(--monroe-scroll-anchor-gap, 12px)
  );
}

.monroe-event-flyers__card {
  display: flex;
  flex-direction: column;
  height: 100%;
  width: 100%;
  text-decoration: none;
  color: inherit;
  border-radius: 16px;
  overflow: hidden;
  background: #fff;
  border: 1px solid rgba(23, 58, 57, 0.12);
  box-shadow: 0 12px 28px rgba(17, 41, 41, 0.08);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
  font: inherit;
  text-align: left;
  cursor: pointer;
  padding: 0;
  appearance: none;
  -webkit-appearance: none;
}

.monroe-event-flyers__card:hover,
.monroe-event-flyers__card:focus-visible {
  transform: translateY(-2px);
  box-shadow: 0 16px 36px rgba(15, 118, 110, 0.16);
}

.monroe-event-flyers__card--static {
  cursor: default;
}

.monroe-event-flyers__card--static:hover,
.monroe-event-flyers__card--static:focus-visible {
  transform: none;
  box-shadow: 0 12px 28px rgba(17, 41, 41, 0.08);
}

@media (hover: none), (pointer: coarse) {
  .monroe-event-flyers__card:hover,
  .monroe-event-flyers__card:focus-visible {
    transform: none;
    box-shadow: 0 12px 28px rgba(17, 41, 41, 0.08);
  }
}

.monroe-event-flyers__image {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  background: #f4f7f6;
}

.monroe-event-flyers__placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 200px;
  padding: 1rem;
  text-align: center;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-size: 0.9rem;
  color: rgba(42, 61, 61, 0.65);
  background: #eef5f4;
}

.monroe-event-flyers__body {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  padding: 0.85rem 1rem 1rem;
}

.monroe-event-flyers__title {
  font-family: "Jost", "Segoe UI", sans-serif;
  font-weight: 700;
  font-size: 1rem;
  line-height: 1.3;
  color: #153635;
}

.monroe-event-flyers__date {
  font-family: "Jost", "Segoe UI", sans-serif;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #0f766e;
}

.monroe-event-flyers__excerpt {
  font-family: "Questrial", "Segoe UI", sans-serif;
  font-size: 0.95rem;
  line-height: 1.45;
  color: #2a3d3d;
}

.monroe-event-flyers__card:focus-visible {
  outline: 2px solid #0f766e;
  outline-offset: 3px;
}

body.monroe-event-flyers-lb-open {
  overflow: hidden;
}

.monroe-event-flyers__lightbox {
  position: fixed;
  inset: 0;
  z-index: 2600;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: max(clamp(0.75rem, 3vw, 1.5rem), env(safe-area-inset-top))
    max(clamp(0.75rem, 3vw, 1.5rem), env(safe-area-inset-right))
    max(clamp(0.75rem, 3vw, 1.5rem), env(safe-area-inset-bottom))
    max(clamp(0.75rem, 3vw, 1.5rem), env(safe-area-inset-left));
  background: rgba(8, 20, 20, 0.78);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.25s ease, visibility 0.25s ease;
}

.monroe-event-flyers__lightbox.is-active {
  opacity: 1;
  visibility: visible;
}

.monroe-event-flyers__lightbox-inner {
  position: relative;
  display: flex;
  flex-direction: column;
  width: min(920px, 96vw);
  max-height: min(94vh, 980px);
  background: #fff;
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.45);
  transform: scale(0.96);
  transition: transform 0.25s cubic-bezier(0.22, 1, 0.36, 1);
}

.monroe-event-flyers__lightbox.is-active .monroe-event-flyers__lightbox-inner {
  transform: scale(1);
}

.monroe-event-flyers__lightbox-figure {
  margin: 0;
  background: #0b1515;
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.monroe-event-flyers__lightbox-image {
  display: block;
  width: 100%;
  max-height: min(68vh, 720px);
  object-fit: contain;
}

.monroe-event-flyers__lightbox-meta {
  padding: 0.85rem 1.15rem 0;
}

.monroe-event-flyers__lightbox-title {
  margin: 0;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-size: 1.1rem;
  font-weight: 700;
  color: #153635;
}

.monroe-event-flyers__lightbox-title:empty {
  display: none;
}

.monroe-event-flyers__lightbox-date {
  margin: 0.2rem 0 0;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #0f766e;
}

.monroe-event-flyers__lightbox-date:empty {
  display: none;
}

.monroe-event-flyers__lightbox-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  padding: 0.85rem 1.15rem 1.15rem;
  background: #fff;
}

.monroe-event-flyers__lightbox-download,
.monroe-event-flyers__lightbox-more {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.75rem;
  padding: 0.55rem 1.1rem;
  border-radius: 999px;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-size: 0.92rem;
  font-weight: 700;
  text-decoration: none;
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.monroe-inner-page-shell .monroe-event-flyers__lightbox-download,
.monroe-event-flyers__lightbox-download {
  color: #fff;
  background-color: #0f766e;
  border: 1px solid #0f766e;
}

.monroe-inner-page-shell .monroe-event-flyers__lightbox-download:hover,
.monroe-inner-page-shell .monroe-event-flyers__lightbox-download:focus-visible,
.monroe-inner-page-shell .monroe-event-flyers__lightbox-download:visited,
.monroe-event-flyers__lightbox-download:hover,
.monroe-event-flyers__lightbox-download:focus-visible,
.monroe-event-flyers__lightbox-download:visited {
  color: #fff;
  background-color: #0d655f;
  border-color: #0d655f;
}

.monroe-inner-page-shell .monroe-event-flyers__lightbox-more,
.monroe-event-flyers__lightbox-more {
  color: #153635;
  background-color: #fff;
  border: 1px solid rgba(23, 58, 57, 0.2);
}

.monroe-inner-page-shell .monroe-event-flyers__lightbox-more:hover,
.monroe-inner-page-shell .monroe-event-flyers__lightbox-more:focus-visible,
.monroe-event-flyers__lightbox-more:hover,
.monroe-event-flyers__lightbox-more:focus-visible {
  border-color: #0f766e;
  color: #0f766e;
  background-color: #fff;
}

.monroe-event-flyers__lightbox-more[hidden] {
  display: none;
}

.monroe-event-flyers__lightbox-close,
.monroe-event-flyers__lightbox-prev,
.monroe-event-flyers__lightbox-next {
  position: absolute;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.75rem;
  height: 2.75rem;
  min-width: 2.75rem;
  min-height: 2.75rem;
  border: 0;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.94);
  color: #153635;
  font-size: 1.35rem;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.18);
}

.monroe-event-flyers__lightbox-close {
  top: max(0.75rem, env(safe-area-inset-top));
  right: max(0.75rem, env(safe-area-inset-right));
}

.monroe-event-flyers__lightbox-prev {
  top: 50%;
  left: 0.75rem;
  transform: translateY(-50%);
}

.monroe-event-flyers__lightbox-next {
  top: 50%;
  right: 0.75rem;
  transform: translateY(-50%);
}

.monroe-event-flyers__lightbox-close:hover,
.monroe-event-flyers__lightbox-close:focus-visible,
.monroe-event-flyers__lightbox-prev:hover,
.monroe-event-flyers__lightbox-prev:focus-visible,
.monroe-event-flyers__lightbox-next:hover,
.monroe-event-flyers__lightbox-next:focus-visible {
  background: #fff;
  color: #0f766e;
  outline: 2px solid #0f766e;
  outline-offset: 2px;
}

@media (max-width: 640px) {
  .monroe-event-flyers__lightbox-prev,
  .monroe-event-flyers__lightbox-next {
    display: none;
  }

  .monroe-event-flyers__lightbox-actions {
    flex-direction: column;
  }

  .monroe-event-flyers__lightbox-download,
  .monroe-event-flyers__lightbox-more {
    width: 100%;
  }
}

@media (prefers-reduced-motion: reduce) {
  .monroe-event-flyers__lightbox,
  .monroe-event-flyers__lightbox-inner {
    transition: none;
  }

  .monroe-event-flyers__lightbox-inner {
    transform: scale(1);
  }
}

/* Newsletter archive (/newsletter/) + single issue */
.monroe-newsletter-archive__grid {
  list-style: none;
  margin: 1rem 0 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 260px), 1fr));
  gap: 1rem;
}

.monroe-newsletter-archive__item {
  margin: 0;
}

.monroe-newsletter-archive__card {
  display: flex;
  flex-direction: column;
  height: 100%;
  text-decoration: none;
  color: inherit;
  border-radius: 14px;
  overflow: hidden;
  background: #fff;
  border: 1px solid rgba(23, 58, 57, 0.12);
  box-shadow: 0 10px 24px rgba(17, 41, 41, 0.08);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.monroe-newsletter-archive__card:hover,
.monroe-newsletter-archive__card:focus-visible {
  transform: translateY(-2px);
  box-shadow: 0 14px 32px rgba(15, 118, 110, 0.14);
}

.monroe-newsletter-archive__thumb {
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  display: block;
}

.monroe-newsletter-archive__body {
  padding: 0.85rem 1rem 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}

.monroe-newsletter-archive__badge {
  align-self: flex-start;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #fff;
  background: #0f766e;
  padding: 0.15rem 0.45rem;
  border-radius: 4px;
}

.monroe-newsletter-archive__title {
  font-family: "Jost", "Segoe UI", sans-serif;
  font-weight: 700;
  font-size: 1.05rem;
  color: #153635;
}

.monroe-newsletter-archive__date {
  font-size: 0.82rem;
  color: #0f766e;
  font-weight: 600;
}

.monroe-newsletter-archive__excerpt {
  font-family: "Questrial", "Segoe UI", sans-serif;
  font-size: 0.92rem;
  line-height: 1.45;
  color: #2a3d3d;
}

.monroe-newsletter-archive__empty,
.monroe-newsletter-empty {
  margin: 0;
  padding: 1rem 1.15rem;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.92);
  border: 1px dashed rgba(15, 118, 110, 0.35);
}

.monroe-newsletter-single {
  max-width: var(--monroe-site-content-max, 1320px);
  margin: 0 auto;
  padding: 0 1rem 2rem;
}

/* Accomplishments widget (native bundled counter) */
.page-slug-home-editable .home-editable-accomplishments-band {
  margin: 2.5rem auto;
  max-width: var(--monroe-site-content-max, 1320px);
  padding: 0 1.25rem;
}

/* Humane Games homepage teaser */
.page-slug-home-editable .home-editable-games-band,
body[data-page-alias="home-editable"] .home-editable-games-band {
  margin: 2.5rem auto 2rem;
  max-width: var(--monroe-site-content-max, 1320px);
  padding: 0 1.25rem;
}

.page-slug-home-editable .home-editable-games-card {
  text-align: center;
  padding: clamp(1.65rem, 3.5vw, 2.35rem) clamp(1.15rem, 3vw, 1.85rem);
  background: linear-gradient(155deg, rgba(232, 248, 243, 0.92), rgba(255, 250, 240, 0.98));
}

.page-slug-home-editable .home-editable-games-card .home-editable-pill {
  margin-bottom: clamp(0.85rem, 2vw, 1.1rem);
}

.page-slug-home-editable .home-editable-games-head {
  max-width: 40rem;
  margin: 0 auto clamp(1.35rem, 3vw, 1.75rem);
}

.page-slug-home-editable .home-editable-games-head #home-games-heading {
  margin: 0 0 0.65rem;
}

.page-slug-home-editable .home-editable-games-intro {
  max-width: 36rem;
  margin: 0 auto;
  line-height: 1.55;
}

.page-slug-home-editable .home-editable-games-teasers {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(0.85rem, 2.2vw, 1.15rem);
  margin: 0 auto clamp(1.5rem, 3vw, 1.85rem);
  padding: 0;
  list-style: none;
  max-width: 44rem;
  width: 100%;
}

.page-slug-home-editable .home-editable-games-teasers__item {
  min-width: 0;
  display: flex;
}

.page-slug-home-editable .home-editable-games-teasers__link {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 0.5rem;
  width: 100%;
  min-height: 100%;
  padding: clamp(0.95rem, 2.5vw, 1.15rem) clamp(0.75rem, 2vw, 0.95rem) clamp(1rem, 2.5vw, 1.15rem);
  border-radius: 16px;
  border: 2px solid rgba(107, 196, 166, 0.35);
  background: rgba(255, 255, 255, 0.94);
  text-decoration: none;
  color: inherit;
  transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}

.page-slug-home-editable .home-editable-games-teasers__link:hover,
.page-slug-home-editable .home-editable-games-teasers__link:focus-visible {
  transform: translateY(-3px);
  border-color: var(--mint, #6bc4a6);
  box-shadow: 0 12px 28px rgba(44, 28, 25, 0.12);
  outline: none;
}

.page-slug-home-editable .home-editable-games-teasers__icon {
  font-size: clamp(1.75rem, 4vw, 2.25rem);
  line-height: 1;
}

.page-slug-home-editable .home-editable-games-teasers__title {
  font-family: "Jost", "Segoe UI", sans-serif;
  font-size: 1.05rem;
  font-weight: 800;
  color: #153635;
}

.page-slug-home-editable .home-editable-games-teasers__desc {
  font-size: 0.86rem;
  line-height: 1.5;
  color: #405757;
  max-width: 14rem;
}

.page-slug-home-editable .home-editable-games-cta {
  margin-top: 0.15rem;
}

@media (max-width: 480px) {
  .page-slug-home-editable .home-editable-games-teasers {
    grid-template-columns: 1fr;
    max-width: 20rem;
    gap: 0.75rem;
  }

  .page-slug-home-editable .home-editable-games-teasers__desc {
    max-width: none;
  }
}

@media (min-width: 900px) {
  .page-slug-home-editable .home-editable-games-teasers {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    max-width: 52rem;
  }
}

.page-slug-home-editable .home-editable-accomplishments-card,
body[data-page-alias="home-editable"] .home-editable-accomplishments-card {
  text-align: center;
  padding:
    clamp(1.65rem, 3.5vw, 2.35rem)
    clamp(1.15rem, 3vw, 1.85rem)
    clamp(2.75rem, 5.5vw, 3.5rem);
  background:
    radial-gradient(circle at 50% 0%, rgba(15, 118, 110, 0.08), transparent 42%),
    linear-gradient(155deg, rgba(232, 248, 243, 0.92), rgba(255, 250, 240, 0.98));
  overflow: visible;
}

.page-slug-home-editable .home-editable-accomplishments-card .home-editable-pill,
body[data-page-alias="home-editable"] .home-editable-accomplishments-card .home-editable-pill {
  margin: 0 auto clamp(0.85rem, 2vw, 1.1rem);
}

.page-slug-home-editable .home-editable-accomplishments-card .home-editable-heading-impact,
body[data-page-alias="home-editable"] .home-editable-accomplishments-card .home-editable-heading-impact {
  margin: 0 0 0.55rem;
}

.page-slug-home-editable .home-editable-accomplishments-card > p.has-text-align-center:not(.home-editable-pill),
body[data-page-alias="home-editable"] .home-editable-accomplishments-card > p.has-text-align-center:not(.home-editable-pill) {
  max-width: 34rem;
  margin: 0 auto clamp(1.35rem, 3vw, 1.75rem);
  font-size: clamp(0.95rem, 2.2vw, 1.02rem);
  line-height: 1.55;
  color: rgba(64, 87, 87, 0.92);
}

.page-slug-home-editable .monroe-accomplishments-widget,
body[data-page-alias="home-editable"] .monroe-accomplishments-widget {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(2.25rem, 5vw, 3rem);
  width: 100%;
  margin-top: 0;
  max-width: min(920px, 100%);
  margin-inline: auto;
}

.page-slug-home-editable .monroe-accomplishments-widget__tabs,
body[data-page-alias="home-editable"] .monroe-accomplishments-widget__tabs,
.monroe-accomplishments-widget__tabs {
  display: inline-flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 0.25rem;
  margin: 0;
  padding: 0.3rem;
  border-radius: 999px;
  background: rgba(15, 118, 110, 0.1);
  border: 1px solid rgba(15, 118, 110, 0.12);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55);
}

.page-slug-home-editable .monroe-accomplishments-widget__panel,
body[data-page-alias="home-editable"] .monroe-accomplishments-widget__panel,
.monroe-accomplishments-widget__panel {
  width: 100%;
  margin: 0;
  padding: 0;
}

.monroe-accomplishments-widget__panel[hidden] {
  display: none !important;
}

.monroe-accomplishments-widget__tab {
  appearance: none;
  border: 0;
  background: transparent;
  color: #0f766e;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  min-height: 2.75rem;
  padding: 0.5rem 1.15rem;
  border-radius: 999px;
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
}

.monroe-accomplishments-widget__tab:hover,
.monroe-accomplishments-widget__tab:focus-visible {
  outline: none;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 2px 8px rgba(15, 118, 110, 0.1);
}

.monroe-accomplishments-widget__tab.is-active {
  background: linear-gradient(135deg, #0f766e, #068110);
  color: #fff;
  box-shadow: 0 6px 18px rgba(15, 118, 110, 0.22);
}

.monroe-accomplishments-widget__tab.is-active:hover,
.monroe-accomplishments-widget__tab.is-active:focus-visible {
  background: linear-gradient(135deg, #0f766e, #068110);
  color: #fff;
}

.monroe-accomplishments-widget__stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(0.85rem, 2.5vw, 1.25rem);
  width: 100%;
}

@media (max-width: 768px) and (min-width: 481px) {
  .monroe-accomplishments-widget__stats {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.5rem;
  }

  .monroe-accomplishments-stat.is-tile {
    padding: 0.75rem 0.35rem;
    border-radius: 18px;
    min-width: 0;
  }

  .monroe-accomplishments-stat__value {
    font-size: clamp(1.35rem, 4.2vw, 1.85rem);
  }

  .monroe-accomplishments-stat__label {
    font-size: 0.68rem;
    letter-spacing: 0.1em;
    line-height: 1.25;
    max-width: 100%;
    hyphens: auto;
  }
}

@media (max-width: 480px) {
  .monroe-accomplishments-widget__stats {
    grid-template-columns: 1fr;
    gap: 0.65rem;
    max-width: 20rem;
    margin-inline: auto;
  }

  .monroe-accomplishments-stat.is-tile {
    padding: 1rem 0.85rem;
    border-radius: 18px;
  }

  .monroe-accomplishments-stat__value {
    font-size: clamp(1.75rem, 6vw, 2.15rem);
  }

  .monroe-accomplishments-stat__label {
    font-size: 0.68rem;
    letter-spacing: 0.1em;
    line-height: 1.3;
  }
}

.monroe-accomplishments-stat.is-tile {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  min-height: 100%;
  padding: clamp(1.15rem, 2.8vw, 1.5rem) clamp(0.85rem, 2vw, 1rem);
  text-align: center;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid rgba(36, 72, 67, 0.11);
  box-shadow: 0 12px 32px rgba(17, 41, 41, 0.07);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.monroe-accomplishments-stat.is-tile.is-accent {
  background: linear-gradient(145deg, #0f766e, #068110);
  border-color: transparent;
  box-shadow: 0 14px 36px rgba(15, 118, 110, 0.18);
}

.monroe-accomplishments-stat__value {
  display: inline-block;
  font-family: "Abril Fatface", Georgia, serif;
  font-size: clamp(2.35rem, 4.8vw, 3.25rem);
  font-weight: 400;
  line-height: 1;
  color: #068110;
  font-variant-numeric: tabular-nums;
  min-width: 2.5ch;
  text-align: center;
}

.monroe-accomplishments-stat.is-tile.is-accent .monroe-accomplishments-stat__value {
  color: #fff;
}

.monroe-accomplishments-stat__label {
  font-family: "Jost", "Segoe UI", sans-serif;
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  line-height: 1.35;
  color: #0f766e;
}

.monroe-accomplishments-stat.is-tile.is-accent .monroe-accomplishments-stat__label {
  color: rgba(255, 255, 255, 0.92);
}

@media (hover: hover) and (pointer: fine) {
  .monroe-accomplishments-stat.is-tile:not(.is-accent):hover {
    transform: translateY(-2px);
    box-shadow: 0 18px 40px rgba(15, 118, 110, 0.1);
  }
}

@media (hover: none), (pointer: coarse) {
  .monroe-accomplishments-stat.is-tile:hover {
    transform: none;
  }
}

.page-slug-home-editable .home-editable-accomplishments-band .elfsight-app-b278cc4e-7651-4706-a00a-8ad9664a8d9d,
.page-slug-home-editable .home-editable-events-card .elfsight-app-72b5086d-995a-4a78-98e2-4174f19fb28c {
  min-height: 120px;
}

/* Homepage contact form */
.monroe-contact-form-wrap,
.page-slug-home-editable .monroe-contact-form-wrap {
  margin-top: 1.25rem;
  text-align: left;
}

.monroe-contact-form__hp,
.page-slug-home-editable .monroe-contact-form__hp {
  position: absolute;
  left: -9999px;
  height: 0;
  overflow: hidden;
}

.monroe-contact-form__lead,
.page-slug-home-editable .monroe-contact-form__lead {
  text-align: center;
  margin-bottom: 1rem;
}

.monroe-contact-form__grid,
.page-slug-home-editable .monroe-contact-form__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

@media (max-width: 640px) {
  .monroe-contact-form__grid,
  .page-slug-home-editable .monroe-contact-form__grid {
    grid-template-columns: 1fr;
  }
}

.monroe-contact-form__field label,
.page-slug-home-editable .monroe-contact-form__field label {
  display: block;
  font-weight: 600;
  margin-bottom: 0.35rem;
  color: #1d2a2a;
}

.monroe-contact-form__field input,
.monroe-contact-form__field textarea,
.page-slug-home-editable .monroe-contact-form__field input,
.page-slug-home-editable .monroe-contact-form__field textarea {
  width: 100%;
  padding: 0.65rem 0.75rem;
  border: 1px solid rgba(15, 118, 110, 0.35);
  border-radius: 6px;
  font-family: inherit;
  font-size: 1rem;
}

.monroe-contact-form__field input:focus-visible,
.monroe-contact-form__field textarea:focus-visible,
.page-slug-home-editable .monroe-contact-form__field input:focus-visible,
.page-slug-home-editable .monroe-contact-form__field textarea:focus-visible {
  outline: 2px solid #0f766e;
  outline-offset: 2px;
  border-color: #0f766e;
}

.monroe-contact-form__field input[aria-invalid="true"],
.monroe-contact-form__field textarea[aria-invalid="true"],
.page-slug-home-editable .monroe-contact-form__field input[aria-invalid="true"],
.page-slug-home-editable .monroe-contact-form__field textarea[aria-invalid="true"] {
  border-color: #b45309;
}

.monroe-contact-form__submit,
.page-slug-home-editable .monroe-contact-form__submit {
  text-align: center;
  margin-top: 1rem;
}

.monroe-contact-form__button,
.page-slug-home-editable .monroe-contact-form__button {
  cursor: pointer;
  border: none;
}

.monroe-contact-form__notice,
.page-slug-home-editable .monroe-contact-form__notice {
  padding: 1rem 1.25rem;
  border-radius: 8px;
  margin-bottom: 1rem;
  text-align: center;
}

.monroe-contact-form__notice--success,
.page-slug-home-editable .monroe-contact-form__notice--success {
  background: #d4edda;
  border: 1px solid #c3e6cb;
  color: #155724;
}

.monroe-contact-form__notice--error,
.page-slug-home-editable .monroe-contact-form__notice--error {
  background: #fff3cd;
  border: 1px solid #ffeaa7;
  color: #856404;
}

.page-slug-home-editable .monroe-contact-form__notice ul {
  margin: 0;
  padding-left: 1.25rem;
  text-align: left;
}

/* Artwork contest form (/artwork-contest/) */
.monroe-native-inner--artwork-contest.monroe-inner-page-shell {
  padding-top: clamp(0.65rem, 2vw, 1.15rem);
}

.monroe-artwork-contest-page {
  max-width: min(52rem, 100%);
  margin-inline: auto;
}

/* Hero banner — compact */
.monroe-artwork-contest-hero {
  position: relative;
  margin: 0 0 clamp(0.85rem, 2.5vw, 1.15rem);
  padding: clamp(0.85rem, 2.5vw, 1.25rem);
  border-radius: clamp(14px, 2.5vw, 20px);
  border: 1px solid rgba(15, 118, 110, 0.16);
  background:
    radial-gradient(110% 85% at 0% 0%, rgba(255, 210, 123, 0.22), transparent 52%),
    radial-gradient(90% 75% at 100% 0%, rgba(43, 184, 243, 0.14), transparent 48%),
    linear-gradient(152deg, #f8fcfb 0%, #eef6f3 55%, #fffaf2 100%);
  box-shadow:
    0 12px 32px rgba(17, 41, 41, 0.07),
    inset 0 1px 0 rgba(255, 255, 255, 0.85);
  overflow: hidden;
}

.monroe-artwork-contest-hero__glow {
  position: absolute;
  inset: -40% -20% auto auto;
  width: min(220px, 45vw);
  height: min(220px, 45vw);
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 210, 123, 0.28) 0%, transparent 68%);
  pointer-events: none;
}

.monroe-artwork-contest-hero__inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, auto);
  gap: clamp(0.75rem, 2.5vw, 1.35rem);
  align-items: center;
}

.monroe-artwork-contest-hero__badges {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.45rem;
  margin-bottom: 0.45rem;
}

.monroe-artwork-contest-hero__eyebrow {
  display: inline-flex;
  align-items: center;
  padding: 0.28rem 0.65rem;
  border-radius: 999px;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #0f766e;
  background: rgba(15, 118, 110, 0.1);
  border: 1px solid rgba(15, 118, 110, 0.18);
}

.monroe-artwork-contest-hero__deadline {
  display: inline-flex;
  align-items: center;
  padding: 0.28rem 0.65rem;
  border-radius: 999px;
  font-family: "Jost", "Segoe UI", sans-serif;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #7c4a03;
  background: rgba(255, 210, 123, 0.45);
  border: 1px solid rgba(255, 180, 60, 0.45);
}

.monroe-artwork-contest-hero__copy h1 {
  margin: 0 0 0.35rem;
  font-family: "Abril Fatface", Georgia, serif;
  font-size: clamp(1.35rem, 4vw, 1.85rem);
  line-height: 1.1;
  letter-spacing: -0.01em;
  color: #153635;
  text-wrap: balance;
}

.monroe-artwork-contest-hero__lead {
  margin: 0 0 0.55rem;
  max-width: 32rem;
  font-size: clamp(0.88rem, 2.1vw, 0.96rem);
  line-height: 1.45;
  color: rgba(21, 54, 53, 0.82);
}

.monroe-artwork-contest-hero__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem 0.45rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.monroe-artwork-contest-hero__meta li {
  display: inline-flex;
  align-items: center;
  padding: 0.28rem 0.58rem;
  border-radius: 999px;
  font-size: 0.76rem;
  font-weight: 600;
  color: #2a4a48;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(23, 58, 57, 0.1);
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.04);
}

.monroe-artwork-contest-hero__visual {
  display: flex;
  justify-content: center;
  align-items: center;
}

.monroe-artwork-contest-hero__frame {
  width: min(100%, 9.5rem);
  padding: 0.5rem;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(23, 58, 57, 0.1);
  box-shadow:
    0 10px 24px rgba(17, 41, 41, 0.08),
    0 0 0 1px rgba(255, 255, 255, 0.6) inset;
  transform: none;
}

.monroe-artwork-contest-hero__frame--qr {
  text-align: center;
}

.monroe-artwork-contest-hero__qr,
.monroe-artwork-contest-hero__frame--qr .monroe-artwork-contest-qr {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 7.5rem;
}

.monroe-artwork-contest-hero__qr svg,
.monroe-artwork-contest-hero__frame--qr .monroe-artwork-contest-qr svg {
  display: block;
  width: 100%;
  max-width: 7.5rem;
  height: auto;
  border-radius: 8px;
}

.monroe-artwork-contest-hero__qr-caption,
.monroe-artwork-contest-hero__frame--qr .monroe-artwork-contest-qr-caption {
  margin: 0.45rem 0 0;
  font-size: 0.72rem;
  font-weight: 600;
  line-height: 1.35;
  letter-spacing: 0.02em;
  color: rgba(21, 54, 53, 0.72);
}

.monroe-artwork-contest-hero__frame img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 12px;
  object-fit: contain;
}

@media (min-width: 640px) {
  .monroe-artwork-contest-hero__frame {
    width: min(100%, 10.5rem);
  }

  .monroe-artwork-contest-hero__qr svg,
  .monroe-artwork-contest-hero__frame--qr .monroe-artwork-contest-qr svg {
    max-width: 8.5rem;
  }
}

@media (max-width: 719px) {
  .monroe-artwork-contest-hero__inner {
    grid-template-columns: 1fr;
    text-align: left;
  }

  .monroe-artwork-contest-hero__badges,
  .monroe-artwork-contest-hero__meta {
    justify-content: flex-start;
  }

  .monroe-artwork-contest-hero__visual {
    display: none;
  }
}

/* Form card */
.monroe-artwork-contest-card {
  background: #fff;
  border: 1px solid rgba(23, 58, 57, 0.12);
  border-radius: clamp(14px, 2.5vw, 18px);
  box-shadow: 0 10px 32px rgba(15, 23, 42, 0.07);
  overflow: hidden;
}

.monroe-artwork-contest-card__header {
  padding: clamp(0.75rem, 2vw, 0.95rem) clamp(0.95rem, 2.5vw, 1.15rem) clamp(0.6rem, 1.8vw, 0.75rem);
  border-bottom: 1px solid rgba(23, 58, 57, 0.08);
  background: linear-gradient(180deg, #fbfaf7 0%, #fff 100%);
}

.monroe-artwork-contest-card__header h2 {
  margin: 0 0 0.15rem;
  font-size: clamp(1.05rem, 2.8vw, 1.2rem);
  font-size: clamp(1.05rem, 2.8vw, 1.15rem);
  line-height: 1.3;
  color: #173a39;
}

.monroe-artwork-contest-card__header p {
  margin: 0;
  font-size: clamp(0.88rem, 2.4vw, 0.92rem);
  color: rgba(23, 58, 57, 0.72);
}

.monroe-artwork-contest-card__body {
  padding: clamp(1rem, 3vw, 1.35rem) clamp(1rem, 3vw, 1.35rem) clamp(1.25rem, 3.5vw, 1.5rem);
}

.monroe-artwork-contest-form-wrap,
.monroe-native-inner--artwork-contest .monroe-artwork-contest-form-wrap {
  max-width: none;
  margin: 0;
}

.monroe-artwork-contest-form {
  display: grid;
  gap: 0.85rem 1rem;
}

@media (min-width: 720px) {
  .monroe-artwork-contest-form {
    grid-template-columns: 1fr 1fr;
    align-items: start;
  }

  .monroe-artwork-contest-form__field--full,
  .monroe-artwork-contest-form__address,
  .monroe-artwork-contest-form__terms,
  .monroe-artwork-contest-form__field--checkbox,
  .monroe-artwork-contest-form__submit,
  .monroe-artwork-contest-form__feedback {
    grid-column: 1 / -1;
  }
}

.monroe-artwork-contest-form__hp {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.monroe-artwork-contest-form__grid {
  display: contents;
}

.monroe-artwork-contest-form__field {
  margin: 0;
}

.monroe-artwork-contest-form__field label,
.monroe-artwork-contest-form-wrap .monroe-artwork-contest-form__field label {
  display: block;
  margin-bottom: 0.3rem;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  color: #173a39;
}

.monroe-artwork-contest-form__field input:not([type="checkbox"]),
.monroe-artwork-contest-form__field textarea,
.monroe-artwork-contest-form__field input[type="file"] {
  width: 100%;
  max-width: 100%;
  padding: 0.62rem 0.75rem;
  border: 1px solid rgba(23, 58, 57, 0.16);
  border-radius: 10px;
  box-sizing: border-box;
  font: inherit;
  font-size: 16px;
  background: #fff;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
  -webkit-appearance: none;
  appearance: none;
}

.monroe-artwork-contest-form__field input:not([type="checkbox"]):focus-visible,
.monroe-artwork-contest-form__field textarea:focus-visible,
.monroe-artwork-contest-form__field input[type="file"]:focus-visible {
  outline: none;
  border-color: #0f766e;
  box-shadow: 0 0 0 3px rgba(15, 118, 110, 0.14);
}

.monroe-artwork-contest-form__field textarea {
  min-height: 4.5rem;
  resize: vertical;
}

.monroe-artwork-contest-form__field--checkbox {
  display: flex;
  align-items: flex-start;
  gap: 0.55rem;
  padding: 0.75rem 0.85rem;
  border-radius: 10px;
  background: rgba(15, 118, 110, 0.05);
  border: 1px solid rgba(15, 118, 110, 0.12);
}

.monroe-artwork-contest-form__field--checkbox input {
  width: 1.1rem;
  height: 1.1rem;
  min-width: 1.1rem;
  margin-top: 0.1rem;
  flex-shrink: 0;
  padding: 0;
  border: none;
  border-radius: 4px;
  background: transparent;
  box-shadow: none;
  cursor: pointer;
  accent-color: #0f766e;
  -webkit-appearance: auto;
  appearance: auto;
}

.monroe-artwork-contest-form__field--checkbox label {
  margin: 0;
  font-size: 0.9rem;
  font-weight: 500;
  line-height: 1.45;
  cursor: pointer;
}

.monroe-artwork-contest-form__address {
  margin: 0;
}

.monroe-artwork-contest-form__address > label {
  display: block;
  margin-bottom: 0.3rem;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  color: #173a39;
}

.monroe-artwork-contest-form__address-grid {
  display: grid;
  gap: 0.55rem;
}

@media (min-width: 720px) {
  .monroe-artwork-contest-form__address-grid {
    grid-template-columns: 1fr 1fr;
  }

  .monroe-artwork-contest-form__address-line {
    grid-column: 1 / -1;
  }
}

.monroe-artwork-contest-form__address-field {
  margin: 0;
}

.monroe-artwork-contest-form__address-field label {
  display: block;
  margin-bottom: 0.25rem;
  font-size: 0.78rem;
  font-weight: 600;
  color: rgba(23, 58, 57, 0.75);
}

.monroe-artwork-contest-form__address-field input {
  width: 100%;
  max-width: 100%;
  padding: 0.62rem 0.75rem;
  border: 1px solid rgba(23, 58, 57, 0.16);
  border-radius: 10px;
  box-sizing: border-box;
  font: inherit;
  font-size: 16px;
  background: #fff;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.monroe-artwork-contest-form__address-field input:focus-visible {
  outline: none;
  border-color: #0f766e;
  box-shadow: 0 0 0 3px rgba(15, 118, 110, 0.14);
}

.monroe-artwork-contest-form__terms {
  padding: 0.85rem 1rem;
  border-radius: 10px;
  margin: 0;
  font-size: 0.88rem;
  line-height: 1.5;
  color: rgba(23, 58, 57, 0.85);
  background: #f6f8f8;
  border: 1px solid rgba(23, 58, 57, 0.1);
}

.monroe-artwork-contest-form__terms p {
  margin: 0.35rem 0 0;
}

.monroe-artwork-contest-form__terms strong {
  display: block;
  margin-bottom: 0.15rem;
  font-size: 0.92rem;
  color: #173a39;
}

.monroe-artwork-contest-form__submit {
  margin: 0.15rem 0 0;
  display: flex;
  justify-content: flex-end;
}

.monroe-artwork-contest-form__button {
  min-width: 11rem;
  min-height: 2.75rem;
  width: auto;
  padding-inline: 1.5rem !important;
}

@media (max-width: 719px) {
  .monroe-artwork-contest-form__submit {
    justify-content: stretch;
  }

  .monroe-artwork-contest-form__button {
    width: 100%;
    min-height: 3rem;
  }

  .monroe-artwork-contest-card {
    border-radius: 16px;
  }
}

.monroe-artwork-contest-form__notice,
.monroe-artwork-contest-form-wrap .monroe-artwork-contest-form__notice {
  padding: 0.85rem 1rem;
  border-radius: 10px;
  margin-bottom: 0;
  text-align: left;
}

.monroe-artwork-contest-form__notice--success {
  background: #def7ec;
  color: #03543f;
  border: 1px solid #bcf0da;
}

.monroe-artwork-contest-form__notice--error {
  background: #fde8e8;
  color: #9b1c1c;
  border: 1px solid #f8b4b4;
}

.monroe-artwork-contest-form__notice--closed {
  background: #eff6ff;
  color: #1e429f;
  border: 1px solid #c3dafe;
}

.monroe-artwork-contest-form__notice ul {
  margin: 0;
  padding-left: 1.25rem;
}

.monroe-artwork-contest-form__field .required {
  color: #dc2626;
}

/* Google Form embed — height from Customizer; 640px column matches Google’s embed width */
.monroe-google-form-embed,
.monroe-adopt-form-embed {
  margin: 0.75rem auto 1rem;
  max-width: 640px;
  width: 100%;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 8px 28px rgba(15, 23, 42, 0.08);
  overflow: hidden;
  line-height: 0;
}

.monroe-google-form-embed iframe,
.monroe-adopt-form-embed iframe {
  display: block;
  width: 100%;
  height: var(--monroe-form-embed-h-active, var(--monroe-form-embed-h, 2200px));
  margin: 0;
  padding: 0;
  border: none;
  background: #fff;
  vertical-align: top;
}

@media (max-width: 768px) {
  .monroe-google-form-embed:not(.monroe-google-form-embed--submitted) iframe,
  .monroe-adopt-form-embed:not(.monroe-google-form-embed--submitted) iframe {
    height: var(
      --monroe-form-embed-h-active,
      var(--monroe-form-embed-h-mobile, var(--monroe-form-embed-h, 2800px))
    );
  }
}

.monroe-google-form-embed__hint {
  margin: 0.65rem auto 0;
  max-width: 640px;
  font-size: 0.92rem;
  line-height: 1.5;
  color: rgba(15, 23, 42, 0.62);
}

@media (max-width: 768px) {
  .monroe-native-inner .monroe-native-form-apply,
  .monroe-adoptions-page #Application {
    display: flex;
    flex-direction: column;
    gap: 0;
  }

  .monroe-adoptions-page .monroe-adoptions-form-header {
    display: contents;
  }

  .monroe-adoptions-page #Application > h2,
  .monroe-adoptions-page .monroe-adoptions-form-header h2 {
    order: 0;
    margin-bottom: 0.75rem;
  }

  .monroe-native-inner .monroe-native-form-apply .monroe-native-actions,
  .monroe-adoptions-page .monroe-adoptions-form-actions {
    order: 1;
    margin-top: 0;
    margin-bottom: 0.75rem;
    flex-wrap: wrap;
    width: 100%;
  }

  .monroe-native-inner .monroe-native-form-apply .monroe-google-form-embed,
  .monroe-native-inner .monroe-native-form-apply .monroe-adopt-form-embed,
  .monroe-adoptions-page .monroe-google-form-embed,
  .monroe-adoptions-page .monroe-adopt-form-embed {
    order: 2;
  }

  .monroe-native-inner .monroe-native-form-apply .monroe-google-form-embed__hint,
  .monroe-adoptions-page .monroe-google-form-embed__hint {
    order: 3;
  }

  .monroe-adoptions-page .monroe-adoptions-form-actions .wp-block-button,
  .monroe-adoptions-page .monroe-adoptions-form-actions .wp-block-button__link {
    flex: 1 1 auto;
    min-width: min(100%, 12rem);
    min-height: 44px;
    justify-content: center;
  }
}

/* --------------------------------------------------------------------------
   Games page (/games/) — blended teal hero + warm play panel
   -------------------------------------------------------------------------- */
.monroe-native-inner--games.monroe-inner-page-shell {
  padding-top: clamp(1rem, 2.5vw, 1.5rem);
  padding-bottom: clamp(1.75rem, 4vw, 2.5rem);
}

.monroe-native-inner--games .monroe-games-page {
  max-width: min(var(--monroe-site-content-max, 1320px), 100%);
}

.monroe-native-inner--games .monroe-native-stack {
  max-width: none;
}

.monroe-native-inner--games .monroe-games-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: clamp(0.85rem, 2vw, 1.5rem);
  align-items: start;
  margin: 0 0 clamp(1.25rem, 2.5vw, 1.75rem);
  padding: clamp(0.9rem, 2vw, 1.25rem);
  border-radius: 22px;
  border: 1px solid rgba(15, 118, 110, 0.14);
  background:
    radial-gradient(120% 90% at 0% 0%, rgba(43, 184, 243, 0.12), transparent 55%),
    radial-gradient(90% 80% at 100% 100%, rgba(15, 118, 110, 0.14), transparent 50%),
    linear-gradient(145deg, #f7fbf9 0%, #eef6f4 48%, #fffaf2 100%);
  box-shadow: 0 22px 50px rgba(17, 41, 41, 0.08);
}

.monroe-native-inner--games .monroe-games-hero__copy h1 {
  margin: 0 0 0.45rem;
  font-family: "Abril Fatface", Georgia, serif;
  font-size: clamp(1.75rem, 4vw, 2.35rem);
  line-height: 1.08;
  color: #153635;
}

.monroe-native-inner--games .monroe-games-hero__copy .monroe-native-lead {
  margin-bottom: 0.65rem;
  font-size: clamp(0.95rem, 2vw, 1.05rem);
  line-height: 1.5;
}

.monroe-native-inner--games .monroe-games-hero__copy .monroe-games-feature-pills {
  margin-bottom: 0.75rem;
}

.monroe-games-how--hero {
  margin: 0 0 0.65rem;
  padding: 0.55rem 0.7rem;
  box-shadow: 0 6px 16px rgba(17, 41, 41, 0.04);
}

.monroe-games-how--hero .monroe-games-how__summary {
  margin: 0;
  padding: 0.15rem 0;
  font-family: "Questrial", "Segoe UI", sans-serif;
  font-size: clamp(0.95rem, 1.8vw, 1.05rem);
  font-weight: 700;
  color: #153635;
  cursor: pointer;
  list-style: none;
}

.monroe-games-how--hero .monroe-games-how__summary::-webkit-details-marker {
  display: none;
}

.monroe-games-how--hero .monroe-games-how__summary::after {
  content: " ›";
  font-size: 0.9em;
  opacity: 0.55;
}

.monroe-games-how--hero[open] .monroe-games-how__summary::after {
  content: " ∨";
}

.monroe-games-how--hero[open] .monroe-games-how__summary {
  margin-bottom: 0.45rem;
}

.monroe-games-how--hero .monroe-games-how__steps {
  gap: 0.45rem;
  margin-top: 0.15rem;
}

.monroe-games-how--hero .monroe-games-how__steps li {
  gap: 0.5rem;
  font-size: 0.86rem;
  line-height: 1.4;
}

.monroe-games-how--hero .monroe-games-how__step-num {
  width: 1.35rem;
  height: 1.35rem;
  font-size: 0.72rem;
}

.monroe-games-feature-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.monroe-games-feature-pills li {
  display: inline-flex;
  align-items: center;
  padding: 0.3rem 0.65rem;
  border-radius: 999px;
  background: rgba(15, 118, 110, 0.1);
  color: #134e4a;
  font-size: 0.8rem;
  font-weight: 700;
}

.monroe-games-how {
  margin: 0 0 clamp(2rem, 4vw, 2.75rem);
  padding: clamp(1.25rem, 3vw, 1.75rem);
  border-radius: 20px;
  border: 1px solid rgba(23, 58, 57, 0.1);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 12px 28px rgba(17, 41, 41, 0.06);
}

.monroe-games-how h2 {
  margin: 0 0 1rem;
  font-size: clamp(1.25rem, 2.5vw, 1.55rem);
  color: #153635;
}

.monroe-games-how__steps {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 0.85rem;
}

.monroe-games-how__steps li {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.85rem;
  align-items: start;
  line-height: 1.5;
  color: #2a3d3d;
}

.monroe-games-how__step-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 999px;
  background: #0f766e;
  color: #fff;
  font-size: 0.85rem;
  font-weight: 700;
  flex-shrink: 0;
}

.monroe-games-cta-band {
  margin: clamp(1.15rem, 2.5vw, 1.65rem) 0 0;
  padding: clamp(1.1rem, 2.5vw, 1.5rem);
  border-radius: 20px;
  text-align: center;
  background: linear-gradient(135deg, #0f766e 0%, #134e4a 55%, #163433 100%);
  color: #fff;
  box-shadow: 0 24px 52px rgba(15, 118, 110, 0.22);
}

.monroe-games-cta-band h2 {
  margin: 0 0 0.35rem;
  font-family: "Abril Fatface", Georgia, serif;
  font-size: clamp(1.35rem, 3vw, 1.75rem);
  color: #fff;
}

.monroe-games-cta-band p {
  margin: 0 auto 0.85rem;
  font-size: 0.95rem;
  line-height: 1.45;
  max-width: 36rem;
  color: rgba(255, 255, 255, 0.92);
  line-height: 1.55;
}

.monroe-games-cta-band__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.65rem;
}

.monroe-games-cta-band__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.65rem 1.15rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.45);
  color: #fff;
  font-weight: 700;
  text-decoration: none;
  transition: transform 150ms ease, background 150ms ease;
}

.monroe-games-cta-band__link:hover,
.monroe-games-cta-band__link:focus-visible {
  transform: translateY(-2px);
  background: rgba(255, 255, 255, 0.12);
  outline: none;
}

.monroe-games-cta-band__link--primary {
  background: #fff;
  color: #134e4a;
  border-color: #fff;
}

.monroe-games-cta-band__link--primary:hover,
.monroe-games-cta-band__link--primary:focus-visible {
  background: #f0fdf9;
}

@media (max-width: 900px) {
  .monroe-native-inner--games .monroe-games-hero {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .monroe-games-cta-band__actions {
    flex-direction: column;
    align-items: stretch;
  }

  .monroe-games-cta-band__link {
    width: 100%;
  }
}
