/* ==========================================================================
   @layer: page
   @page: home
   @section: global-page-scope
   @label: Global Page Scope / Environment Setup
   @purpose: Establishes canvas background and base page container styles for S6O9 homepage
   @scope: body.s6o9, .s6o9-home
   @risk: medium
   ========================================================================== */

body.s6o9,
html body.s6o9,
.s6o9 .site,
.s6o9 .site-content,
.s6o9 .elementor,
.s6o9 .s6o9-home {
  background: var(--s6o9-canvas);
}

.s6o9 .s6o9-home {
  margin: 0;
  padding: 0;
  gap: 0;
  overflow-x: clip;
  color: var(--s6o9-ink);
}

/* ==========================================================================
   @layer: page
   @page: home
   @section: arrival-macro
   @label: SECTION 01 — Arrival / Host Trust
   @purpose: Top homepage macro containing hero, host card, and topbar utility navigation
   @scope: #home-arrival, .s6o9-home-arrival
   @risk: high
   ========================================================================== */

/* - - - - - -  hide topbar for testing - - - - - - */
.s6o9-event-detail-topbar--inline {
  display: none !important;
}

/* --------------------------------------------------------------------------
   @subsection: home-macro-base
   @parent: global-page-scope
   @purpose: Base styles for all top-level homepage macro containers establishing flex column layout
   @scope: .s6o9-home-macro
   -------------------------------------------------------------------------- */

.s6o9 .s6o9-home-macro {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  margin: 0;
  padding: 0;
  gap: 0;
  overflow: visible;
  isolation: isolate;
}

.s6o9 .s6o9-home-macro > .e-con-inner {
  display: flex;
  flex-direction: column;
  margin: 0;
  padding: 0;
  gap: 0;
}

/* --------------------------------------------------------------------------
   @subsection: arrival-shell
   @parent: arrival-macro
   @purpose: Arrival macro container shell establishing positioning and isolation context
   @scope: #home-arrival, .s6o9-home-arrival
   -------------------------------------------------------------------------- */

.s6o9 #home-arrival.s6o9-home-arrival {
  position: relative;
  margin: 0;
  padding: 0;
  gap: 0;
  overflow: visible;
  isolation: isolate;
  background: var(--s6o9-canvas);
}

.s6o9 #home-arrival.s6o9-home-arrival > .e-con-inner {
  margin: 0;
  padding: 0;
  gap: 0;
}

/* ---- @component: arrival-topbar | @parent: arrival-macro | @scope: .s6o9-home-arrival__topbar ---- */

.s6o9 .s6o9-home-arrival__topbar {
  position: relative;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 44px;
  min-height: 44px;
  padding: 0 42px;
  margin: 0;
  background: #f2d7c9;
}

/* Hide login/register */
.s6o9 .s6o9-home-arrival__auth {
  display: none;
}

.s6o9 .s6o9-home-arrival__brand,
.s6o9 .s6o9-home-arrival__brand .elementor-heading-title,
.s6o9 .s6o9-home-arrival__brand p,
.s6o9 .s6o9-home-arrival__auth,
.s6o9 .s6o9-home-arrival__auth p,
.s6o9 .s6o9-home-arrival__auth a {
  margin: 0;
  font-family: var(--s6o9-font-condensed) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase;
  color: var(--s6o9-rust-solid);
  text-decoration: none;
}

/* ---- @component: arrival-hero | @parent: arrival-macro | @scope: .s6o9-home-arrival__hero ---- */

.s6o9 .s6o9-home-arrival__hero {
  position: relative;
  z-index: 1;
  height: 93vh;
  min-height: 93vh;
  margin: 0;
  padding: 0;
  overflow: hidden;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}

.s6o9 .s6o9-home-arrival__hero::after {
  content: '';
  position: absolute;
  inset: auto 0 0 0;
  height: 220px;
  pointer-events: none;
  background: linear-gradient(
    180deg,
    rgba(26, 20, 16, 0) 0%,
    rgba(26, 20, 16, 0.14) 55%,
    rgba(26, 20, 16, 0.26) 100%
  );
  mix-blend-mode: multiply;
}

/* --------------------------------------------------------------------------
   @subsection: host-card
   @parent: arrival-macro
   @purpose: Host introduction card with portrait, atmospheric background, and biographical content
   @scope: .s6o9-home-arrival__host-wrap, .s6o9-home-host-card
   -------------------------------------------------------------------------- */

.s6o9 .s6o9-home-arrival__host-wrap {
  position: relative;
  z-index: 5;
  margin: -150px 0 0;
  margin-bottom: 0;
  padding: 0 90px;
  overflow: visible;
  width: 100vw;
}

.s6o9 .s6o9-home-arrival__host-wrap::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: -1;
  background: url(https://staging.station6over9.com/wp-content/uploads/2026/05/gnr-bg_smoke1.jpg)
    left 60% / cover no-repeat;
  mask-image: linear-gradient(
    to bottom,
    rgba(0, 0, 0, 0) 0,
    rgba(0, 0, 0, 0.82) 130px,
    rgba(0, 0, 0, 1) 150px,
    rgba(0, 0, 0, 0.32) 28%,
    rgba(0, 0, 0, 0.58) 68%,
    rgba(0, 0, 0, 0.84) 100%
  );
  -webkit-mask-image: linear-gradient(
    to bottom,
    rgba(0, 0, 0, 0) 0,
    rgba(0, 0, 0, 0.82) 130px,
    rgba(0, 0, 0, 1) 150px,
    rgba(0, 0, 0, 0.32) 28%,
    rgba(0, 0, 0, 0.58) 68%,
    rgba(0, 0, 0, 0.84) 100%
  );
  left: -5vw;
  width: 120vw;
}

.s6o9 .s6o9-home-host-card {
  --host-title-size: 6vw;
  --host-body-size: 1.12vw;
  --host-image-width: 52vw;
  --host-image-top: -13.5vw;
  --host-image-left: -1.5vw;
  position: relative;
  display: grid;
  grid-template-columns: 50% 50%;
  width: 100%;
  min-height: 0;
  height: auto;
  margin: 0 auto;
  overflow: visible;
  isolation: isolate;
  border-radius: 30px 30px 0 0;
  background: transparent;
  padding: 0;
}

.s6o9 .s6o9-home-host-card::before {
  content: '';
  position: absolute;
  left: -14vw;
  top: 17em;
  width: 90%;
  height: 100%;
  z-index: 1;
  pointer-events: none;
  background: radial-gradient(
    ellipse 58% 72% at 50% 50%,
    rgba(251, 205, 181, 0.88) 0%,
    rgba(251, 205, 181, 0.72) 34%,
    rgba(251, 205, 181, 0.38) 62%,
    rgba(251, 205, 181, 0) 80%
  );
}

.s6o9 .s6o9-home-host-card::after {
  content: '';
  position: absolute;
  left: -5%;
  top: -10%;
  width: 60%;
  height: 90%;
  z-index: 0;
  pointer-events: none;
  background: radial-gradient(
    ellipse 80% 75% at 35% 45%,
    rgba(63, 37, 30, 0.08) 0%,
    rgba(63, 37, 30, 0.04) 45%,
    rgba(63, 37, 30, 0) 75%
  );
}

/* ---- @component: host-card-typography | @parent: host-card | @scope: .s6o9-home-host-card__content, __eyebrow, __title, __body ---- */

.s6o9 .s6o9-home-host-card__content {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  padding: 5.4vw 6vw 8vw;
  padding-right: 0;
  padding-bottom: 4vw;
  padding-left: 3em;
}

/* Host card - using .s6o9-editorial-intro global component (with __title variant) */

.s6o9 .s6o9-home-host-card__eyebrow .elementor-heading-title {
  margin: 0 0 20px;
  padding-bottom: 16px;
  border-bottom: 1px solid rgba(181, 82, 60, 0.28);
  color: var(--s6o9-rust-solid);
  font-family: 'Roboto', sans-serif;
  font-size: 1.28em;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.26em;
  text-transform: uppercase;

  opacity: 0;
}

.s6o9 .s6o9-home-host-card__title .elementor-heading-title {
  max-width: 760px;
  margin: 0;
  color: var(--s6o9-ink-strong);
  font-family: var(--s6o9-font-display);
  font-size: var(--host-title-size);
  font-weight: 500;
  line-height: 1.05;
  letter-spacing: -0.03em;
}

.s6o9 .s6o9-home-host-card__title .elementor-heading-title em {
  color: var(--s6o9-rust-solid);
  font-style: italic;
}

.s6o9 .s6o9-home-host-card__body {
  max-width: 38vw;
  margin-top: 16px;
}

.s6o9 .s6o9-home-host-card__body p {
  margin: 0 0 1.15em;
  color: rgba(63, 37, 30, 0.92) !important;
  font-family: var(--s6o9-font-body) !important;
  font-size: var(--host-body-size) !important;
  font-weight: 500 !important;
  line-height: 1.58 !important;
}

.s6o9 .s6o9-home-host-card__body p:last-child {
  margin-bottom: 0;
}

/* ---- @component: host-card-portrait | @parent: host-card | @scope: .s6o9-home-host-card__media ---- */

.s6o9 .s6o9-home-host-card__media {
  position: relative;
  z-index: 2;
  min-height: 100%;
  overflow: visible;
  padding: 0;
}

.s6o9 .s6o9-home-host-card__media .elementor-widget-image,
.s6o9 .s6o9-home-host-card__media .elementor-widget-container {
  position: static;
  width: auto;
  height: 140%;
  margin: 0;
}

.s6o9 .s6o9-home-host-card__portrait img,
.s6o9 .s6o9-home-host-card__media img {
  position: absolute;
  /* top: var(--host-image-top); */
  bottom: 0;
  left: var(--host-image-left);
  width: var(--host-image-width);
  max-width: none;
  height: auto;
  z-index: 2;
  /* backdrop-filter: drop-shadow(0 -18px 24px rgba(63, 37, 30, 0.82));
  filter: drop-shadow(0 18px 24px rgba(63, 37, 30, 0.12)) saturate(0.98); */
  mask-image: linear-gradient(to top, transparent 0, black 15px);
}

/* ---- @component: host-card-cta | @parent: host-card | @scope: .s6o9-home-host-card__cta ---- */

.s6o9 .s6o9-home-host-card__cta {
  margin-top: 1vw;
}

/* .s6o9 .s6o9-home-host-card__cta .elementor-button {
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--s6o9-rust-solid) !important;
  font-family: var(--s6o9-font-body) !important;
  font-size: 1.2vw !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.28em;
  box-shadow: none;
}

.s6o9 .s6o9-home-host-card__cta .elementor-button:hover,
.s6o9 .s6o9-home-host-card__cta .elementor-button:focus-visible {
  color: var(--s6o9-cta-pink) !important;
  background: transparent;
  text-decoration: underline;
  text-underline-offset: 0.22em;
} */

/* ---- @component: arrival-seam | @parent: arrival-macro | @scope: .s6o9-home-arrival__seam ---- */

.s6o9 #home-arrival > .elementor-widget-shortcode,
.s6o9 #home-arrival .s6o9-home-arrival__seam {
  position: relative;
  z-index: 6;
  margin-top: 0;
}

/* Shortcode should be: [s6o9_seam position="top" full="true"] */
.s6o9 #home-arrival .s6o9-section-xition-seam {
  margin-top: -10px;
}

/* --- Responsive: Section 01 / Arrival --- */

/* Hold responsive work until desktop composition is approved. */

/* ==========================================================================
   @layer: page
   @page: home
   @section: participate-macro
   @label: SECTION 02 — Participate / Pathways / Culture
   @purpose: Homepage macro containing Pathways and Culture sections describing event types and values
   @scope: #home-participate, .s6o9-home-participate, .s6o9-home-pathways, .s6o9-home-culture
   @risk: high
   ========================================================================== */

/* --------------------------------------------------------------------------
   @subsection: participate-shell
   @parent: participate-macro
   @purpose: Participate macro container shell establishing positioning and isolation context
   @scope: #home-participate, .s6o9-home-participate
   -------------------------------------------------------------------------- */

.s6o9 #home-participate.s6o9-home-participate {
  position: relative;
  margin: 0;
  padding: 0;
  gap: 0;
  overflow: visible;
  isolation: isolate;
  background: var(--s6o9-canvas);
}

.s6o9 #home-participate.s6o9-home-participate > .e-con-inner {
  margin: 0;
  padding: 0;
  gap: 0;
}

/* --------------------------------------------------------------------------
   @subsection: pathways-section
   @parent: participate-macro
   @purpose: Pathways section with 3-column grid (intro, image stack, event type cards)
   @scope: .s6o9-home-pathways
   -------------------------------------------------------------------------- */

.s6o9 .s6o9-home-pathways,
.s6o9 .s6o9-home-culture {
  --section-intro-heading-size: 5em;
  --section-intro-body-size: 1.5em;
}

.s6o9 .s6o9-home-pathways {
  --pathway-heading-size: var(--section-intro-heading-size);
  --pathway-body-size: var(--section-intro-body-size);
  --pathway-callout-size: 1.5em;
  --pathway-card-number-size: 3.3em;
  --pathway-card-title-size: 2.35em;
  --pathway-card-text-size: 1.35em;
  --pathway-card-link-size: 1.1875em;

  position: relative;
  padding-block: 96px;
  padding-top: clamp(6rem, 8vw, 10rem);
  overflow: visible;
  isolation: isolate;
}

.s6o9 .s6o9-home-pathways::before {
  content: '';
  position: absolute;
  left: -20vw;
  top: 0;
  width: 90vw;
  height: 100%;
  z-index: 0;
  background: url('https://staging.station6over9.com/wp-content/uploads/2026/05/gnr-bg_smoke1.jpg')
    center top / cover no-repeat;
  opacity: 0.85;
  mix-blend-mode: multiply;
  pointer-events: none;
  mask-image: radial-gradient(
    ellipse at 20% 35%,
    rgba(0, 0, 0, 0.85) 0%,
    rgba(0, 0, 0, 0.45) 45%,
    rgba(0, 0, 0, 0) 68%
  );
  -webkit-mask-image: radial-gradient(
    ellipse at 20% 35%,
    rgba(0, 0, 0, 0.85) 0%,
    rgba(0, 0, 0, 0.45) 45%,
    rgba(0, 0, 0, 0) 68%
  );
}

.s6o9 .s6o9-home-pathways::after {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  background: radial-gradient(
    ellipse at 50% 20%,
    rgba(239, 220, 202, 0.5) 0%,
    rgba(239, 220, 202, 0) 60%
  );
  pointer-events: none;
}

/* --- Component: Pathways 3-column grid --- */

.s6o9 .s6o9-pathways-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 29% 29% 32%;
  grid-template-rows: auto auto auto;
  column-gap: 5%;
  row-gap: 24px;
  align-items: start;
}

/* Grid positioning for intro (spans all rows) */
.s6o9 .s6o9-pathways__intro {
  grid-column: 1;
  grid-row: 1 / 4;
}

/* Grid positioning for row 1 */
.s6o9 .s6o9-pathway-image--1 {
  grid-column: 2;
  grid-row: 1;
}

.s6o9 .s6o9-pathway-card--1 {
  grid-column: 3;
  grid-row: 1;
  align-self: center;
}

/* Grid positioning for row 2 */
.s6o9 .s6o9-pathway-image--2 {
  grid-column: 2;
  grid-row: 2;
}

.s6o9 .s6o9-pathway-card--2 {
  grid-column: 3;
  grid-row: 2;
  align-self: center;
}

/* Grid positioning for row 3 */
.s6o9 .s6o9-pathway-image--3 {
  grid-column: 2;
  grid-row: 3;
}

.s6o9 .s6o9-pathway-card--3 {
  grid-column: 3;
  grid-row: 3;
  align-self: center;
}

/* --- Component: Pathways intro (left column) --- */

.s6o9 .s6o9-pathways__intro {
  display: flex;
  flex-direction: column;
  gap: 0;
  padding: 200px 0 0 0;
  max-width: 480px;
}

/* Pathways-specific overrides removed - now using .s6o9-editorial-intro global component */
/* Keep only layout-specific properties below */

.s6o9 .s6o9-pathways__eyebrow {
  display: none;
}

.s6o9 .s6o9-pathways__body {
  max-width: 460px;
  padding-bottom: 1.5em;
  color: var(--s6o9-ink); /* Override global ink-soft with ink */
}

/* --- Component: Pathways image stack (center column) --- */

.s6o9 .s6o9-pathways__images {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.s6o9 .s6o9-pathway-image {
  font-family: 'Roboto', sans-serif;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 0px 12px rgba(63, 37, 30, 0.24);
}

.s6o9 .s6o9-pathway-image img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
}

.s6o9 .s6o9-pathway-image::before {
  content: '';
  position: absolute;
  inset: 0;
  background-color: var(--ec-peach);
  mix-blend-mode: color;
  opacity: 0.4;
}

/* --- Component: Pathways cards (right column) --- */

.s6o9 .s6o9-pathways__cards {
  display: flex;
  flex-direction: column;
  gap: 60px;
}

.s6o9 .s6o9-pathway-card {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 8px 47px;
  align-items: baseline;
  font-family: 'Roboto', sans-serif;
}

.s6o9 .s6o9-pathway-card__number {
  grid-column: 1;
  grid-row: 1;
  margin: 0;
  font-family: 'EB Garamond', serif;
}

.s6o9 .s6o9-pathway-card__number .elementor-heading-title {
  margin: 0;
  padding-bottom: 33px;
  border-bottom: 2px solid var(--s6o9-rust-solid);
  color: var(--s6o9-rust-solid);
  font-family: var(--s6o9-font-display);
  font-size: var(--pathway-card-number-size);
  font-weight: 600;
  letter-spacing: -0.05em;
  line-height: 1;
}

.s6o9 .s6o9-pathway-card__title {
  grid-column: 2;
  grid-row: 1;
  margin: 0;
  font-family: 'EB Garamond', serif;
}

.s6o9 .s6o9-pathway-card__title .elementor-heading-title {
  margin: 0;
  color: var(--s6o9-ink-strong);
  font-family: 'EB Garamond', serif;
  font-size: var(--pathway-card-title-size);
  font-weight: 500;
  line-height: 1.25;
}

.s6o9 .s6o9-pathway-card__desc {
  grid-column: 1 / -1;
  grid-row: 2;
  margin: 8px 0 12px;
  color: var(--s6o9-ink);
  font-family: 'Roboto', sans-serif;
  font-size: var(--pathway-card-text-size);
  font-weight: 400;
  line-height: 1.6;
}

.s6o9 .s6o9-pathway-card__link {
  grid-column: 1 / -1;
  grid-row: 3;
}

.s6o9
  .s6o9-pathway-card__link
  .elementor-button.elementor-button-link.elementor-size-sm {
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--s6o9-rust-solid) !important;
  font-family: var(--s6o9-font-body);
  font-size: var(--pathway-card-link-size);
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
  box-shadow: none;
}

.s6o9 .s6o9-pathway-card__link .elementor-button:hover,
.s6o9 .s6o9-pathway-card__link .elementor-button:focus-visible {
  color: var(--s6o9-cta-pink);
  background: transparent;
  text-decoration: underline;
  text-underline-offset: 0.22em;
}

/* --------------------------------------------------------------------------
   @subsection: culture-section
   @parent: participate-macro
   @purpose: Culture section with 2-column grid (intro and values list with icons)
   @scope: .s6o9-home-culture
   -------------------------------------------------------------------------- */

.s6o9 .s6o9-home-culture {
  position: relative;
  padding-block: 96px;
  overflow: visible;
  isolation: isolate;
}

.s6o9 .s6o9-home-culture::before {
  content: '';
  position: absolute;
  left: -15vw;
  top: -240px;
  width: 80vw;
  height: calc(100% + 240px);
  z-index: 0;
  background: url('https://staging.station6over9.com/wp-content/uploads/2026/05/gnr-bg_smoke1.jpg')
    left center / cover no-repeat;
  opacity: 0.75;
  mix-blend-mode: multiply;
  pointer-events: none;
  mask-image: radial-gradient(
    ellipse at 30% 50%,
    rgba(0, 0, 0, 0.85) 0%,
    rgba(0, 0, 0, 0.4) 50%,
    rgba(0, 0, 0, 0) 70%
  );
  -webkit-mask-image: radial-gradient(
    ellipse at 30% 50%,
    rgba(0, 0, 0, 0.85) 0%,
    rgba(0, 0, 0, 0.4) 50%,
    rgba(0, 0, 0, 0) 70%
  );
}

/* ============================================================
   GLOBAL COMPONENT: Editorial Intro (Eyebrow → Heading → Body)
   ============================================================

   Used across 8+ sections for consistent eyebrow/heading pattern.

   Base sizing: Set font-size on .s6o9-editorial-intro to scale all children proportionally.
   Base alignment: Set text-align on .s6o9-editorial-intro to align all children.

   Modifiers:
   - .s6o9-editorial-intro--center : Center-aligned intro
   - .s6o9-editorial-intro--large : 20% larger
   - .s6o9-editorial-intro--small : 15% smaller

   ============================================================ */

.s6o9 .s6o9-editorial-intro {
  display: flex;
  flex-direction: column;
  gap: 0;
  padding: 0;
}

.s6o9 .s6o9-editorial-intro .s6o9-editorial-intro__eyebrow.elementor-widget {
  margin: 0 0 1.625em;
}

.s6o9 .s6o9-editorial-intro__eyebrow .elementor-heading-title {
  margin: 0;
  color: var(--s6o9-rust-solid);
  font-family: 'Roboto', sans-serif;
  font-size: 1.1em;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.26em;
  text-transform: uppercase;
}

.s6o9 .s6o9-editorial-intro__eyebrow::after {
  content: '';
  display: block;
  width: 4.875em;
  height: 0.15em;
  margin-top: 1.625em;
  background: var(--s6o9-rust-solid);
}

.s6o9 .s6o9-editorial-intro__heading {
  margin: 0;
}

.s6o9 .s6o9-editorial-intro__heading .elementor-heading-title {
  margin: 0;
  color: var(--s6o9-ink-strong);
  font-family: var(--s6o9-font-display);
  font-size: 5em;
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: -0.03em;
}

.s6o9 .s6o9-editorial-intro__heading em,
.s6o9 .s6o9-editorial-intro__heading i {
  color: var(--s6o9-rust-solid);
  font-style: italic;
}

.s6o9 .s6o9-editorial-intro__body {
  margin: 1.75em 0 1.5em 0;
  color: var(--s6o9-ink-soft);
  font-family: 'Roboto', sans-serif;
  font-size: 1.5em;
  font-weight: 500;
  line-height: 1.7;
}

.s6o9 .s6o9-editorial-intro__body p {
  margin: 0 0 1.15em;
  color: inherit;
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
}

.s6o9 .s6o9-editorial-intro__body p:last-child {
  margin-bottom: 0;
}

.s6o9 .s6o9-editorial-intro__callout {
  margin: 0;
  color: var(--s6o9-ink-strong);
  font-family: 'Roboto', sans-serif;
  font-size: 1.5em;
  font-weight: 600;
  line-height: 1.4;
}

.s6o9 .s6o9-editorial-intro__callout .elementor-heading-title {
  margin: 0;
  color: inherit;
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
}

/* --- Modifier: Center aligned --- */

.s6o9 .s6o9-editorial-intro--center {
  text-align: center;
}

.s6o9 .s6o9-editorial-intro--center .s6o9-editorial-intro__eyebrow::after {
  margin-left: auto;
  margin-right: auto;
}

/* --- Modifier: Large (120%) --- */

.s6o9 .s6o9-editorial-intro--large {
  font-size: 1.2em;
}

/* --- Modifier: Small (85%) --- */

.s6o9 .s6o9-editorial-intro--small {
  font-size: 0.85em;
}

.s6o9 .s6o9-editorial-intro--ex-ex-small {
  font-size: 0.45em;
}

/* --- Component: Culture 2-column grid --- */

.s6o9 .s6o9-culture-grid {
  --culture-heading-size: var(--section-intro-heading-size);
  --culture-body-size: var(--section-intro-body-size);
  --culture-value-title-size: 1.3em;
  --culture-value-desc-size: 1.15em;

  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 42% 1fr;
  gap: 75px;
  align-items: start;
}

/* --- Component: Culture intro (left column) --- */

.s6o9 .s6o9-culture__intro {
  display: flex;
  flex-direction: column;
  gap: 0;
  max-width: 420px;
}

/* Culture section spacing - will be overridden when .s6o9-editorial-intro classes are added in Elementor */

.s6o9 .s6o9-culture__intro .s6o9-culture__eyebrow.elementor-widget {
  margin: 0 0 26px;
}

.s6o9 .s6o9-culture__eyebrow .elementor-heading-title {
  margin: 0;
  color: var(--s6o9-rust-solid);
  font-family: 'Roboto', sans-serif;
  font-size: 1.1em;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.26em;
  text-transform: uppercase;
}

.s6o9 .s6o9-culture__eyebrow::after {
  content: '';
  display: block;
  width: 78px;
  height: 3px;
  margin-top: 26px;
  background: var(--s6o9-rust-solid);
  opacity: 0.82;
}

.s6o9 .s6o9-culture__heading {
  margin: 0;
}

.s6o9 .s6o9-culture__heading .elementor-heading-title {
  margin: 0;
  color: var(--s6o9-ink-strong);
  font-family: var(--s6o9-font-display);
  font-size: var(--culture-heading-size);
  font-weight: 500;
  line-height: 1.05;
  letter-spacing: -0.03em;
}

.s6o9 .s6o9-culture__heading em,
.s6o9 .s6o9-culture__heading i {
  color: var(--s6o9-rust-solid);
  font-style: italic;
}

.s6o9 .s6o9-culture__body {
  margin: 1.75em 0 1.5em 0;
  max-width: 460px;
  color: var(--s6o9-ink-soft);
  font-family: 'Roboto', sans-serif;
  font-size: var(--culture-body-size);
  font-weight: 500;
  line-height: 1.7;
}

.s6o9 .s6o9-culture__body p {
  margin: 0 0 1.15em;
  color: inherit;
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
}

.s6o9 .s6o9-culture__body p:last-child {
  margin-bottom: 0;
}

/* --- Component: Culture values list (right column) --- */

.s6o9 .s6o9-culture__values {
  display: flex;
  flex-direction: column;
  gap: 48px;
  max-width: 575px;
}

/* --- Component: Culture value row (icon + text pair) --- */

.s6o9 .s6o9-culture__value {
  padding: 0 !important;
  gap: 32px !important;
}

.s6o9 .s6o9-culture-value {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 32px;
  align-items: center;
}

.s6o9 .s6o9-culture-value__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  align-self: flex-start;
  width: auto;
  font-size: 7em;
  padding: 0 !important;
}

.s6o9 .s6o9-culture-value__icon .elementor-widget {
  padding: 0 !important;
  margin: 0 !important;
  line-height: 1 !important;
}

.s6o9 .s6o9-culture-value__icon i,
.s6o9 .s6o9-culture-value__icon svg,
.s6o9 .s6o9-culture-value__icon img {
  height: 1em;
  width: auto;
  object-fit: contain;
  color: var(--s6o9-rust-solid);
  stroke: var(--s6o9-rust-solid);
  fill: none;
  stroke-width: 1.5;
}

.s6o9 .s6o9-culture-value__text {
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-width: 520px;
  align-self: flex-start;
}

.s6o9 .s6o9-culture-value__title {
  margin: 0;
}

.s6o9 .s6o9-culture-value__title .elementor-heading-title {
  margin: 0;
  color: var(--s6o9-ink-strong);
  font-family: 'Roboto', sans-serif;
  font-size: var(--culture-value-title-size);
  font-weight: 600;
  line-height: 1.4;
}

.s6o9 .s6o9-culture-value__desc {
  margin: 0;
  color: var(--s6o9-ink-soft);
  font-family: 'Roboto', sans-serif !important;
  font-size: var(--culture-value-desc-size) !important;
  font-weight: 400;
  line-height: 1.5;
}

.s6o9 .s6o9-culture-value__desc p {
  margin: 0 0 0.8em;
  color: inherit;
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
}

.s6o9 .s6o9-culture-value__desc p:last-child {
  margin-bottom: 0;
}

/* --- Component: Participate exit seam --- */

.s6o9 #home-participate > .elementor-widget-shortcode,
.s6o9 #home-participate .s6o9-home-participate__seam {
  position: relative;
  z-index: 6;
  margin-top: 0;
}

/* --- Responsive: Section 02 / Participate --- */

/* Hold responsive work until desktop composition is approved. */

/* ==========================================================================
   @layer: page
   @page: home
   @section: membership-macro
   @label: SECTION 03 — Membership
   @purpose: Homepage macro containing membership information and links (minimal placeholder section)
   @scope: #home-membership, .s6o9-home-membership
   @risk: low
   ========================================================================== */

/* --------------------------------------------------------------------------
   @subsection: membership-shell
   @parent: membership-macro
   @purpose: Membership macro container shell establishing positioning and isolation context
   @scope: #home-membership, .s6o9-home-membership
   -------------------------------------------------------------------------- */

.s6o9 #home-membership.s6o9-home-membership {
  position: relative;
  margin: 0;
  padding: 0;
  gap: 0;
  overflow: visible;
  isolation: isolate;
  background: var(--s6o9-canvas);
}

.s6o9 #home-membership.s6o9-home-membership > .e-con-inner {
  margin: 0;
  padding: 0;
  gap: 0;
}

/* --- Component: Membership section shell --- */

.s6o9 .s6o9-home-membership-section {
  position: relative;
  height: 45px;
  opacity: 0;
}

/* --- Component: Membership 3-column grid --- */

.s6o9 .s6o9-membership-grid {
  display: grid;
  grid-template-columns: 420px 1fr 280px;
  gap: 0 60px;
  align-items: start;
}

/* Membership - using .s6o9-editorial-intro global component */

.s6o9 .s6o9-membership__heading {
  margin: 0;
}

.s6o9-membership__body.elementor-widget-text-editor {
  margin: 0;
  color: var(--s6o9-ink);
  font-family: var(--s6o9-font-body);
  font-size: 1.0625em;
  font-weight: 400;
  line-height: 1.65;
}

.s6o9-membership__body.elementor-widget-text-editor p {
  margin: 0 0 1.15em;
  color: var(--s6o9-ink);
  font-family: var(--s6o9-font-body);
  font-size: 1.0625em;
  font-weight: 400;
  line-height: 1.65;
}

.s6o9-membership__body.elementor-widget-text-editor p:last-child {
  margin-bottom: 0;
}

/* --- Component: Membership links (right column) --- */

.s6o9 .s6o9-membership__links {
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: flex-start;
}

.s6o9 .s6o9-membership__link .elementor-button {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 44px;
  padding: 0;
  margin: 0;
  background: none;
  border: none;
  color: var(--s6o9-rust-solid);
  font-family: var(--s6o9-font-body);
  font-size: 1.0625em;
  font-weight: 600;
  line-height: 1;
  text-decoration: none;
  transition: color 0.2s ease;
}

.s6o9 .s6o9-membership__link .elementor-button:hover {
  color: var(--s6o9-ink-strong);
}

.s6o9 .s6o9-membership__link .elementor-button-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
}

.s6o9 .s6o9-membership__link .elementor-button-icon svg {
  width: 100%;
  height: 100%;
  fill: currentColor;
}

/* --- Responsive: Section 03 / Membership --- */

/* Hold responsive work until desktop composition is approved. */

/* ==========================================================================
   @layer: page
   @page: home
   @section: offerings-macro
   @label: SECTION 04 — Offerings (Events / Stays / Art)
   @purpose: Homepage macro containing Events, Stays, and Art sections with atmospheric transitions
   @scope: #home-offerings, .s6o9-home-offerings, .s6o9-home-events, .s6o9-home-stays, .s6o9-home-art
   @risk: high
   ========================================================================== */

/* --------------------------------------------------------------------------
   @subsection: offerings-shell
   @parent: offerings-macro
   @purpose: Offerings macro container with atmospheric background treatment and padding
   @scope: #home-offerings, .s6o9-home-offerings
   -------------------------------------------------------------------------- */

.s6o9 #home-offerings.s6o9-home-offerings {
  background: var(--s6o9-canvas);
  position: relative;
  overflow: visible;
  isolation: isolate;
  padding-bottom: 64px;
}

/* Macro atmospheric layer (Events → Stays transition) */
.s6o9 #home-offerings.s6o9-home-offerings::before {
  content: '';
  position: absolute;
  right: -28vw;
  top: -2%;
  width: 120vw;
  height: 120vh;
  z-index: 0;
  pointer-events: none;
  background-image: url('https://staging.station6over9.com/wp-content/uploads/2026/05/gnr-bg_smoke1.jpg');
  background-size: cover;
  background-repeat: no-repeat;
  background-position: 68% 44%;
  opacity: 0.75;
  mix-blend-mode: multiply;
  transform: scaleX(-1);
  -webkit-mask-image:
    radial-gradient(
      ellipse 74vw 72vh at 62% 34%,
      rgba(0, 0, 0, 0.9) 0%,
      rgba(0, 0, 0, 0.62) 30%,
      rgba(0, 0, 0, 0.32) 55%,
      rgba(0, 0, 0, 0.1) 76%,
      rgba(0, 0, 0, 0) 100%
    ),
    linear-gradient(
      to bottom,
      rgba(0, 0, 0, 0) 0%,
      rgba(0, 0, 0, 0.85) 16%,
      rgba(0, 0, 0, 0.85) 72%,
      rgba(0, 0, 0, 0) 100%
    );
  mask-image:
    radial-gradient(
      ellipse 74vw 72vh at 62% 34%,
      rgba(0, 0, 0, 0.9) 0%,
      rgba(0, 0, 0, 0.62) 30%,
      rgba(0, 0, 0, 0.32) 55%,
      rgba(0, 0, 0, 0.1) 76%,
      rgba(0, 0, 0, 0) 100%
    ),
    linear-gradient(
      to bottom,
      rgba(0, 0, 0, 0) 0%,
      rgba(0, 0, 0, 0.85) 16%,
      rgba(0, 0, 0, 0.85) 72%,
      rgba(0, 0, 0, 0) 100%
    );
  -webkit-mask-composite: source-in;
  mask-composite: intersect;
}

/* Macro atmospheric layer (Stays → Art transition) */
.s6o9 #home-offerings.s6o9-home-offerings::after {
  content: '';
  position: absolute;
  left: -20vw;
  bottom: 0;
  width: 90vw;
  height: 65%;
  z-index: 0;
  background: url('https://staging.station6over9.com/wp-content/uploads/2026/05/gnr-bg_smoke1.jpg')
    left 60% / cover no-repeat;
  opacity: 0.7;
  mix-blend-mode: multiply;
  pointer-events: none;
  mask-image: radial-gradient(
    ellipse 80vw 70vh at 25% 65%,
    rgba(0, 0, 0, 0.8) 0%,
    rgba(0, 0, 0, 0.45) 40%,
    rgba(0, 0, 0, 0.15) 60%,
    rgba(0, 0, 0, 0) 78%
  );
  -webkit-mask-image: radial-gradient(
    ellipse 80vw 70vh at 25% 65%,
    rgba(0, 0, 0, 0.8) 0%,
    rgba(0, 0, 0, 0.45) 40%,
    rgba(0, 0, 0, 0.15) 60%,
    rgba(0, 0, 0, 0) 78%
  );
}

/* --------------------------------------------------------------------------
   @subsection: events-section
   @parent: offerings-macro
   @purpose: Events section with eyebrow/heading intro and featured event cards shortcode
   @scope: .s6o9-home-events
   -------------------------------------------------------------------------- */

.s6o9 .s6o9-home-events {
  position: relative;
  z-index: 1;
  isolation: isolate;
  display: flex;
  flex-direction: column;
}

/* Events → Stays atmospheric layer */
.s6o9 #home-offerings .s6o9-home-events::after {
  content: '';
  position: absolute;
  right: 0;
  top: 48%;
  width: 105vw;
  height: 120vh;
  z-index: 0;
  pointer-events: none;
  background-image: url('https://staging.station6over9.com/wp-content/uploads/2026/05/gnr-bg_smoke1.jpg');
  background-size: cover;
  background-repeat: no-repeat;
  background-position: 66% 42%;
  opacity: 1;
  mix-blend-mode: multiply;
  transform: scaleX(-1);
  -webkit-mask-image:
    radial-gradient(
      ellipse 72vw 80vh at 60% 32%,
      rgba(0, 0, 0, 0.82) 0%,
      rgba(0, 0, 0, 0.52) 30%,
      rgba(0, 0, 0, 0.28) 54%,
      rgba(0, 0, 0, 0.12) 73%,
      rgba(0, 0, 0, 0) 100%
    ),
    linear-gradient(
      to bottom,
      rgba(0, 0, 0, 0) 0%,
      rgba(0, 0, 0, 0.75) 10%,
      rgba(0, 0, 0, 0.75) 72%,
      rgba(0, 0, 0, 0) 100%
    );
  mask-image:
    radial-gradient(
      ellipse 72vw 80vh at 60% 32%,
      rgba(0, 0, 0, 0.82) 0%,
      rgba(0, 0, 0, 0.52) 30%,
      rgba(0, 0, 0, 0.28) 54%,
      rgba(0, 0, 0, 0.12) 73%,
      rgba(0, 0, 0, 0) 100%
    ),
    linear-gradient(
      to bottom,
      rgba(0, 0, 0, 0) 0%,
      rgba(0, 0, 0, 0.75) 10%,
      rgba(0, 0, 0, 0.75) 72%,
      rgba(0, 0, 0, 0) 100%
    );
  -webkit-mask-composite: source-in;
  mask-composite: intersect;
}

.s6o9 .s6o9-home-events__intro {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 12px;
  max-width: var(--s6o9-width-max-fixed);
  margin-inline: auto;
}

/* Events intro - using .s6o9-editorial-intro global component */
/* No section-specific margins - global component handles all spacing */

.s6o9 .s6o9-events__cards {
  position: relative;
  z-index: 1;
  width: 100%;
  margin-top: 40px;
}

.s6o9 #home-offerings .s6o9-home-events {
  padding-bottom: 7em;
}

/* --------------------------------------------------------------------------
   @subsection: stays-section
   @parent: offerings-macro
   @purpose: Stays section with eyebrow/heading intro and lodging room cards
   @scope: .s6o9-home-stays
   -------------------------------------------------------------------------- */

.s6o9 .s6o9-home-stays {
  align-self: flex-start;
  position: relative;
  z-index: 1;
}

.s6o9 #home-offerings .s6o9-home-stays {
  padding-top: 7em;
  padding-bottom: 7em;
}

/* Inner container - 2-column grid with media extending left */
.s6o9 .s6o9-stays__inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 490px;
  gap: 60px;
  align-items: stretch;
  width: 90vw;
  max-width: 90vw;
  margin-left: 0;
  margin-right: auto;
}

/* Left column - media/gallery */
.s6o9 .s6o9-stays__media {
  display: flex;
  flex-direction: column;
}

.s6o9 #home-offerings .s6o9-stays__media {
  display: flex;
  align-self: stretch;
  min-height: 0;
}

.s6o9 #home-offerings .s6o9-stays__media .elementor-widget-html,
.s6o9 #home-offerings .s6o9-stays__media .elementor-widget-container {
  display: flex;
  flex: 1 1 auto;
  width: 100%;
  min-height: 0;
}

.s6o9 .s6o9-stays__gallery {
  width: 100%;
}

/* Right column - content */
.s6o9 .s6o9-stays__content {
  display: flex;
  flex-direction: column;
  gap: 40px;
  padding-top: 20px;
}

/* Intro container (eyebrow + features) */
.s6o9 .s6o9-stays__intro {
  display: flex;
  flex-direction: column;
  gap: 32px;
}

/* Stays eyebrow - using .s6o9-editorial-intro global component */

.s6o9 .s6o9-stays__eyebrow {
  margin: 0;
}

.s6o9 .s6o9-stays__heading .elementor-heading-title {
  font-size: 2.5em;
}

/* Features list with bullet dots */
.s6o9 .s6o9-stays__features {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin: 0;
}

.s6o9 .s6o9-stays__feature {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  margin: 0;
}

.s6o9 .s6o9-stays__feature .elementor-heading-title {
  margin: 0;
  font-family: var(--s6o9-font-display);
  font-size: 1.75em;
  font-weight: 500;
  line-height: 1.3;
  letter-spacing: -0.01em;
  color: var(--s6o9-ink-strong);
}

.s6o9 .s6o9-stays__feature .elementor-heading-title::before {
  content: '•';
  display: inline-block;
  margin-right: 16px;
  color: var(--s6o9-ink-strong);
  font-size: 1.2em;
  line-height: 1;
}

/* Stays body - standalone (not part of intro) */

.s6o9 .s6o9-stays__body {
  display: flex;
  flex-direction: column;
}

.s6o9 .s6o9-stays__body .elementor-text-editor,
.s6o9 .s6o9-stays__body p {
  font-family: var(--s6o9-font-body);
  font-size: 1.25em;
  line-height: 1.6;
  color: var(--s6o9-ink-medium);
}

.s6o9 .s6o9-stays__body p {
  margin: 0 0 1.2em;
}

.s6o9 .s6o9-stays__body p:last-child {
  margin-bottom: 0;
}

/* Diamond divider */
.s6o9 .s6o9-stays__divider {
  width: 100%;
  height: 1px;
  margin: 24px 0;
  position: relative;
  background: transparent;
}

.s6o9 .s6o9-stays__divider::before {
  content: '◆';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  color: var(--s6o9-rust-solid);
  font-size: 8px;
  line-height: 1;
}

/* Room choices container */
.s6o9 .s6o9-stays__choices {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* Individual room card */
.s6o9 .s6o9-stays__room-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 20px 24px;
  background: rgba(255, 255, 255, 0.5);
  border: 1px solid rgba(143, 63, 50, 0.15);
  border-radius: 8px;
  transition: all 0.2s ease;
}

.s6o9 .s6o9-stays__room-card:hover {
  background: rgba(255, 255, 255, 0.8);
  border-color: rgba(143, 63, 50, 0.25);
  transform: translateX(4px);
}

/* Room card info (left side) */
.s6o9 .s6o9-room-card__info {
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
}

.s6o9 .s6o9-room-card__name {
  margin: 0;
}

.s6o9 .s6o9-room-card__name .elementor-heading-title {
  margin: 0;
  font-family: var(--s6o9-font-display);
  font-size: 1.375em;
  font-weight: 500;
  line-height: 1.2;
  color: var(--s6o9-ink-strong);
}

.s6o9 .s6o9-room-card__details {
  margin: 0;
  font-family: var(--s6o9-font-body);
  font-size: 0.9375em;
  line-height: 1.4;
  color: var(--s6o9-ink-medium);
}

.s6o9 .s6o9-room-card__details p {
  margin: 0;
}

.s6o9 .s6o9-room-card__cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 4px;
  font-family: var(--s6o9-font-body);
  font-size: 1em;
  font-weight: 600;
  color: var(--s6o9-rust-solid);
  text-decoration: none;
  transition: gap 0.2s ease;
}

.s6o9 .s6o9-room-card__cta:hover {
  gap: 12px;
}

/* Airbnb icon (right side) */
.s6o9 .s6o9-room-card__icon {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  opacity: 0.8;
  transition: opacity 0.2s ease;
}

.s6o9 .s6o9-stays__room-card:hover .s6o9-room-card__icon {
  opacity: 1;
}

/* --------------------------------------------------------------------------
   @subsection: art-section
   @parent: offerings-macro
   @purpose: Art section with full-width Rick texture gallery strip
   @scope: .s6o9-home-art
   -------------------------------------------------------------------------- */

.s6o9 .s6o9-home-art {
  position: relative;
  z-index: 1;
  padding-top: 7em;
}

/* Inner container - 3-column grid */
.s6o9 .s6o9-art__inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1.2fr 1fr;
  gap: 60px;
  align-items: stretch;
}

/* Left column - portrait */
.s6o9 .s6o9-art__portrait {
  display: flex;
  flex-direction: column;
}

.s6o9 .s6o9-art__portrait-image {
  width: 100%;
  height: 100%;
}

.s6o9 .s6o9-art__portrait-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 8px;
}

/* Middle column - content */
.s6o9 .s6o9-art__content {
  display: flex;
  flex-direction: column;
  gap: 32px;
  padding-top: 40px;
}

/* Art section - using .s6o9-editorial-intro global component */

.s6o9 .s6o9-art__intro {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.s6o9 .s6o9-art__eyebrow {
  margin: 0;
}

.s6o9 .s6o9-art__heading {
  margin: 0;
}

.s6o9 .s6o9-art__body {
  display: flex;
  flex-direction: column;
}

.s6o9 .s6o9-art__body .elementor-text-editor,
.s6o9 .s6o9-art__body p {
  font-family: var(--s6o9-font-body);
  font-size: 1.25em;
  line-height: 1.65;
  color: var(--s6o9-ink-medium);
}

.s6o9 .s6o9-art__body p {
  margin: 0 0 1.2em;
}

.s6o9 .s6o9-art__body p:last-child {
  margin-bottom: 0;
}

/* Primary CTA button - pink rounded rectangle */
.s6o9 .s6o9-art__cta {
  /* display: inline-flex;
  align-items: center;
  gap: 8px;
  align-self: flex-start;
  padding: 14px 28px;
  font-family: var(--s6o9-font-body);
  font-size: 1.0625em;
  font-weight: 600;
  color: #fff;
  background: rgba(143, 63, 50, 0.6);
  border: none;
  border-radius: 8px;
  text-decoration: none;
  transition: all 0.2s ease; */
  margin: 2em 0;
}

/* .s6o9 .s6o9-art__cta:hover {
  background: rgba(143, 63, 50, 0.7);
} */

/* Secondary CTA - just rust text with icon */
.s6o9 .s6o9-art__secondary-cta {
  /* display: inline-flex;
  align-items: center;
  gap: 8px;
  align-self: flex-start;
  padding: 0;
  font-family: var(--s6o9-font-body);
  font-size: 1em;
  font-weight: 500;
  color: var(--s6o9-rust-solid);
  background: transparent;
  border: none;
  text-decoration: none; */
  transition: color 0.2s ease;
}

.s6o9 .s6o9-art__secondary-cta:hover {
  color: rgba(143, 63, 50, 0.8);
}

/* Right column - gallery */
.s6o9 .s6o9-art__gallery {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 16px;
  height: 100%;
}

/* Gallery images */
.s6o9 .s6o9-art__gallery-image {
  width: 100%;
  height: 100%;
}

.s6o9 .s6o9-art__gallery-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 8px;
}

/* Tall botanical image - spans both rows */
.s6o9 .s6o9-art__gallery-image--tall {
  grid-column: 1;
  grid-row: 1 / 3;
  height: 100%;
  object-fit: cover;
}

/* Landscape seascape - top right */
.s6o9 .s6o9-art__gallery-image--landscape {
  grid-column: 2;
  grid-row: 1;
  height: 100%;
  object-fit: cover;
}

/* Square portrait - bottom right */
.s6o9 .s6o9-art__gallery-image--square {
  grid-column: 2;
  grid-row: 2;
  height: 100%;
  object-fit: cover;
}

/* ==========================================================================
   @layer: page
   @page: home
   @section: final-macro
   @label: SECTION 05 — Final CTA / Contact (Before You Decide / Here to Help)
   @purpose: Homepage macro containing final decision support and help/contact sections with atmospheric treatment
   @scope: #home-final, .s6o9-home-final, .s6o9-decide, .s6o9-help
   @risk: medium
   ========================================================================== */

/* --------------------------------------------------------------------------
   @subsection: final-shell
   @parent: final-macro
   @purpose: Final macro container with Rick texture atmospheric treatment and cooler ink tones
   @scope: #home-final, .s6o9-home-final
   -------------------------------------------------------------------------- */

.s6o9 #home-final.s6o9-home-final {
  background: var(--s6o9-canvas);
  position: relative;
  overflow: visible;
  isolation: isolate;
  padding-top: 64px;

  /* Section-local color adjustments - cooler ink tones, brighter rust */
  --s6o9-help-ink-heading: #3d2b26; /* Deeper warm brown for headings */
  --s6o9-help-ink-body: #4f5366; /* Cool slate for body */
  --s6o9-help-ink-body-soft: rgba(
    79,
    83,
    102,
    0.7
  ); /* Softer contrast - reduced from 0.78 */
  --s6o9-help-rust-bright: #a95543;
  overflow: hidden;
}

/* Atmospheric treatment - large Rick texture wash (LEFT side, dissolves continuously) */
.s6o9 #home-final.s6o9-home-final::before {
  content: '';
  position: absolute;
  left: -25vw;
  top: -5%;
  width: 95vw;
  height: 110%;
  z-index: 0;
  background: url('https://staging.station6over9.com/wp-content/uploads/2026/05/gnr-bg_smoke1.jpg')
    left center / cover no-repeat;
  opacity: 0.65;
  mix-blend-mode: multiply;
  pointer-events: none;
  mask-image: radial-gradient(
    ellipse 85vw 95vh at 18% 45%,
    rgba(0, 0, 0, 0.75) 0%,
    rgba(0, 0, 0, 0.35) 38%,
    rgba(0, 0, 0, 0.12) 58%,
    rgba(0, 0, 0, 0) 75%
  );
  -webkit-mask-image: radial-gradient(
    ellipse 85vw 95vh at 18% 45%,
    rgba(0, 0, 0, 0.75) 0%,
    rgba(0, 0, 0, 0.35) 38%,
    rgba(0, 0, 0, 0.12) 58%,
    rgba(0, 0, 0, 0) 75%
  );
}

/* Subtle warmth/depth layer */
.s6o9 #home-final.s6o9-home-final::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  width: 60%;
  height: 60%;
  z-index: 0;
  background: radial-gradient(
    ellipse at 25% 75%,
    rgba(239, 220, 202, 0.4) 0%,
    rgba(239, 220, 202, 0) 55%
  );
  pointer-events: none;
}

/* --------------------------------------------------------------------------
   @subsection: before-you-decide
   @parent: final-macro
   @purpose: Decision support section with eyebrow/heading and explanatory content
   @scope: .s6o9-decide
   -------------------------------------------------------------------------- */

.s6o9 .s6o9-home-decide {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 56px;
  display: none;
}

/* Decide section - using .s6o9-editorial-intro global component */

.s6o9 .s6o9-decide__intro {
  display: flex;
  flex-direction: column;
  gap: 0;
  align-items: center;
  max-width: 900px;
}

.s6o9 .s6o9-decide__eyebrow {
  margin: 0;
  position: relative;
}

.s6o9 .s6o9-decide__eyebrow .elementor-heading-title {
  opacity: 0.85; /* Override global */
}

.s6o9 .s6o9-decide__eyebrow::after {
  content: '◆'; /* Override global decorative line */
  display: block;
  margin-top: 20px;
  font-size: 7px;
  color: var(--s6o9-rust-solid);
  opacity: 0.5;
  width: auto;
  height: auto;
  background: none;
}

.s6o9 .s6o9-decide__heading {
  margin: 0;
}

.s6o9 .s6o9-decide__body {
  display: flex;
  flex-direction: column;
  max-width: 620px;
}

.s6o9 .s6o9-decide__body .elementor-text-editor,
.s6o9 .s6o9-decide__body p {
  font-family: var(--s6o9-font-body);
  font-size: 1.25em;
  line-height: 1.8;
  color: var(--s6o9-ink-medium);
}

.s6o9 .s6o9-decide__body p {
  margin: 0 0 1.6em;
}

.s6o9 .s6o9-decide__body p:last-child {
  margin-bottom: 0;
}

/* CTA container - tighter integration */
.s6o9 .s6o9-decide__ctas {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  margin-top: 8px;
}

/* Primary CTA button */
.s6o9 .s6o9-decide__cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 18px 36px;
  font-family: var(--s6o9-font-body);
  font-size: 1.125em;
  font-weight: 600;
  color: #fff;
  background: rgba(143, 63, 50, 0.65);
  border: none;
  border-radius: 8px;
  text-decoration: none;
  transition: all 0.2s ease;
}

.s6o9 .s6o9-decide__cta:hover {
  background: rgba(143, 63, 50, 0.75);
}

/* Secondary CTA - text link */
.s6o9 .s6o9-decide__secondary-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 0;
  font-family: var(--s6o9-font-body);
  font-size: 0.9375em;
  font-weight: 500;
  color: var(--s6o9-rust-solid);
  background: transparent;
  border: none;
  text-decoration: none;
  transition: color 0.2s ease;
  opacity: 0.9;
}

.s6o9 .s6o9-decide__secondary-cta:hover {
  opacity: 1;
}

/* --------------------------------------------------------------------------
   @subsection: here-to-help
   @parent: final-macro
   @purpose: Contact/help section with 2-column grid (contact methods and form)
   @scope: .s6o9-help
   -------------------------------------------------------------------------- */

.s6o9 .s6o9-home-help {
  position: relative;
  z-index: 1;
}

/* Inner container - 50/50 layout for substantial form presence */
.s6o9 .s6o9-help__inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 70px;
  align-items: start;
}

/* Left column - explicit relationship spacing */
.s6o9 .s6o9-help__contact {
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* Help section - using .s6o9-editorial-intro global component */

.s6o9 .s6o9-help__intro {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: 32px;
}

.s6o9 .s6o9-help__intro .s6o9-help__eyebrow.elementor-widget {
  margin: 0 0 18px;
  position: relative;
}

.s6o9 .s6o9-help__intro .s6o9-help__heading.elementor-widget {
  margin: 0 0 28px;
}

.s6o9 .s6o9-help__body.elementor-widget-text-editor,
.s6o9 .s6o9-help__body p {
  margin: 0;
  color: var(--s6o9-help-ink-body, var(--s6o9-ink)); /* Override global */
}

/* Contact methods - explicit top spacing */
.s6o9 .s6o9-help__methods {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: 42px; /* More breathing room before value props */
  padding: 0;
}

/* Individual method - horizontal media object (clickable row) */
.s6o9 .s6o9-help__method {
  display: grid;
  grid-template-columns: 62px 1fr; /* Slightly larger icon column */
  gap: 24px; /* More breathing room between icon and text */
  align-items: center;
  padding: 26px 0; /* More vertical spacing */
  background: transparent;
  border: 0;
  border-bottom: 1px solid rgba(143, 63, 50, 0.12);
  text-decoration: none;
}

.s6o9 .s6o9-help__method:last-child {
  border-bottom: 0;
}

.s6o9 .s6o9-help__method:hover,
.s6o9 .s6o9-help__method:focus-visible {
  opacity: 0.88;
}

/* Icon badge - Image widget */
.s6o9 .s6o9-help__method .s6o9-help__icon {
  width: 84px;
  height: 84px;
  min-width: 84px;
  min-height: 84px;
  max-width: 84px;
  max-height: 84px;
  margin: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #f0ceb8;
  border-radius: 50%;
  flex-shrink: 0;
}

.s6o9 .s6o9-help__method .s6o9-help__icon .elementor-widget-container {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.s6o9 .s6o9-help__method .s6o9-help__icon img {
  display: block;
  width: 42px;
  height: 42px;
  object-fit: contain;
  opacity: 1;
}

/* Text stack */
.s6o9 .s6o9-help__method-text {
  display: flex;
  flex-direction: column;
  gap: 6px; /* Slightly more breathing room */
  padding-top: 1px;
  padding-left: 2em;
}

/* Method title - EB Garamond for authority and elegance */
.s6o9 .s6o9-help__method-title,
.s6o9 .s6o9-help__method-title .elementor-heading-title {
  margin: 0;
  font-family:
    'EB Garamond', serif; /* Explicit EB Garamond (not Roboto/Condensed) */
  font-size: 1.35em; /* Slightly larger for stronger hierarchy */
  font-weight: 500;
  line-height: 1.3;
  color: var(--s6o9-help-ink-heading, var(--s6o9-ink-strong));
}

/* Intro line */
.s6o9 .s6o9-help__method-intro {
  margin: 0;
  font-family: 'Roboto', sans-serif;
  font-size: 1.0625rem; /* 17px - larger per feedback */
  font-weight: 400;
  line-height: 1.5;
  color: var(--s6o9-help-ink-body, var(--s6o9-ink));
}

.s6o9 .s6o9-help__method-intro p {
  margin: 0;
  font-size: 1em;
  line-height: inherit;
}

/* Phone/email value */
.s6o9 .s6o9-help__method-value {
  margin: 0;
  font-family: 'Roboto', sans-serif;
  font-size: 1.375rem; /* 22px - larger per feedback */
  font-weight: 600;
  line-height: 1.4;
  color: var(--s6o9-help-rust-bright, var(--s6o9-rust-solid));
}

.s6o9 .s6o9-help__method-value p {
  margin: 0;
  font-size: 1em;
  font-weight: inherit;
  line-height: inherit;
  color: inherit;
}

/* Support line */
.s6o9 .s6o9-help__method-support {
  margin: 0;
  font-family: 'Roboto', sans-serif;
  font-size: 1.0625rem; /* 17px - larger per feedback */
  font-weight: 400;
  line-height: 1.5;
  color: var(--s6o9-help-ink-body, var(--s6o9-ink));
}

.s6o9 .s6o9-help__method-support p {
  margin: 0;
  font-size: 1em;
  line-height: inherit;
}

/* Value props container - more presence */
.s6o9 .s6o9-help__values {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px; /* Tighter spacing to match mock */
  margin-top: 0;
  display: none;
}

/* Individual value prop */
.s6o9 .s6o9-help__value {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 10px; /* Tighter - was too much space between icon and text */
}

/* Value icon - increased presence */
.s6o9 .s6o9-help__value-icon {
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #f0ceb8;
  border-radius: 50%;
  color: var(--s6o9-help-rust-bright, var(--s6o9-rust-solid));
  opacity: 0.75;
  flex-shrink: 0;
}

.s6o9 .s6o9-help__value-icon i {
  font-size: 24px;
}

/* Value title */
.s6o9 .s6o9-help__value-title {
  margin: 0;
}

/* Value title - proper specificity to override Elementor */
.s6o9 .s6o9-help__values .elementor-widget-heading .elementor-heading-title,
.s6o9 .s6o9-help__value-title .elementor-heading-title {
  margin: 0;
  font-family: 'Roboto', sans-serif;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.3;
  color: var(--s6o9-help-ink-heading, var(--s6o9-ink-strong));
}

/* Value description - increased presence */
.s6o9 .s6o9-help__value-desc .elementor-text-editor,
.s6o9 .s6o9-help__value-desc p {
  margin: 0;
  font-family: 'Roboto', sans-serif; /* Explicit Roboto (NOT Condensed) */
  font-size: 0.875rem; /* Fixed size - not using Condensed */
  font-weight: 400;
  line-height: 1.5;
  color: var(
    --s6o9-help-ink-body,
    var(--s6o9-ink)
  ); /* Darker - not too light */
  opacity: 1;
}

/* Right column - form (warm, paper-like, substantial surface - target ~645px) */
.s6o9 .s6o9-help__form-wrapper {
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 645px;
  gap: 32px;
  padding: 56px 52px 52px;
  background: rgba(250, 243, 235, 0.92);
  border: 1px solid rgba(63, 37, 30, 0.16);
  border-radius: 14px;
  box-shadow:
    0 18px 42px rgba(63, 37, 30, 0.1),
    0 2px 8px rgba(63, 37, 30, 0.06),
    inset 0 1px 0 rgba(255, 255, 255, 0.45);
}

/* Form envelope icon - generous breathing room */
.s6o9 .s6o9-help__form-icon {
  align-self: center;
  width: 96px;
  height: 96px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(143, 63, 50, 0.09);
  border-radius: 50%;
  color: var(--s6o9-rust-solid);
  opacity: 0.85;
  margin-bottom: 8px;
}

.s6o9 .s6o9-help__form-icon i {
  font-size: 39px;
}

.s6o9 .s6o9-help__form-icon img {
  width: 42px;
  height: 42px;
  object-fit: contain;
}

/* Form heading - substantial authority */
.s6o9 .s6o9-help__form-heading {
  margin: 0;
  text-align: center;
}

.s6o9 .s6o9-help__form-heading .elementor-heading-title {
  margin: 0;
  font-family: var(--s6o9-font-display);
  font-size: 3em; /* Per feedback */
  font-weight: 500;
  line-height: 1.25;
  letter-spacing: -0.01em;
  color: var(--s6o9-help-ink-heading, var(--s6o9-ink-strong));
}

.s6o9 .s6o9-help__form-heading::before {
  content: '';
  display: block;
  width: 36px;
  height: 1px;
  margin: 0 auto 18px;
  background: var(--s6o9-rust-solid);
  opacity: 0.3;
}

/* Form styling */
.s6o9 .s6o9-help__form {
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* Override Elementor default - NO Roboto Condensed in this section */
.s6o9 .s6o9-help__form .elementor-field-label,
.s6o9 .s6o9-help__form label {
  font-family: 'Roboto', sans-serif;
  font-size: 1.0625rem; /* 17px - larger per feedback */
  font-weight: 600;
  color: var(--s6o9-help-ink-heading, var(--s6o9-ink-strong));
  margin-bottom: 8px;
}

/* Form field spacing - more space between input and next label */
.s6o9 .s6o9-help__form .elementor-field-group {
  margin-bottom: 28px; /* Increased per feedback */
}

.s6o9 .s6o9-help__form .elementor-field-group + .elementor-field-group {
  margin-top: 1em;
}

.s6o9 .s6o9-help__form .e-form__buttons {
  margin-bottom: 0;
}

.s6o9 .s6o9-help__form input[type='text'],
.s6o9 .s6o9-help__form input[type='email'],
.s6o9 .s6o9-help__form textarea {
  width: 100%;
  padding: 18px 20px;
  font-family: var(--s6o9-font-body);
  font-size: 1em;
  line-height: 1.4;
  color: var(--s6o9-help-ink-body, var(--s6o9-ink-strong));
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(63, 37, 30, 0.18);
  border-radius: 7px;
  transition: all 0.2s ease;
}

.s6o9 .s6o9-help__form input[type='text']:focus,
.s6o9 .s6o9-help__form input[type='email']:focus,
.s6o9 .s6o9-help__form textarea:focus {
  outline: none;
  border-color: rgba(143, 63, 50, 0.4);
  background: #fff;
  box-shadow: 0 0 0 4px rgba(143, 63, 50, 0.09);
}

.s6o9 .s6o9-help__form textarea {
  min-height: 160px;
  resize: vertical;
}

.s6o9 .s6o9-help__form button[type='submit'] {
  width: fit-content;
  padding: 16px 28px;
  font-family: var(--s6o9-font-body);
  font-size: 1em;
  font-weight: 600;
  color: #fff;
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.32) 0%,
      rgba(255, 255, 255, 0) 100%
    ),
    var(--s6o9-cta-pink);
  border: none;
  border-radius: 8px;
  cursor: pointer;
  transition: all 1s ease;
  box-shadow:
    0 10px 24px rgba(128, 52, 70, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.s6o9 .s6o9-help__form button[type='submit']:hover {
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.4) 0%,
      rgba(255, 255, 255, 0) 100%
    ),
    var(--s6o9-cta-pink-hover);
  box-shadow:
    0 12px 28px rgba(128, 52, 70, 0.24),
    inset 0 1px 0 rgba(255, 255, 255, 0.32);
  transform: translateY(-1px);
}

/* Privacy notice */
.s6o9 .s6o9-help__form-notice {
  padding-top: 14px;
  border-top: 1px solid rgba(143, 63, 50, 0.08);
}

.s6o9 .s6o9-help__form-notice .elementor-text-editor,
.s6o9 .s6o9-help__form-notice p {
  margin: 0;
  font-family: var(--s6o9-font-body);
  font-size: 0.75em;
  line-height: 1.5;
  color: var(--s6o9-ink-medium);
  text-align: center;
  opacity: 0.85;
}

/* --- Responsive: Section 04 / Events --- */

@media (max-width: 1024px) {
  .s6o9 .s6o9-events-intro__heading .elementor-heading-title {
    font-size: 2.5em;
  }
}

@media (max-width: 767px) {
  .s6o9 .s6o9-events-intro__heading .elementor-heading-title {
    font-size: 2em;
  }

  .s6o9 .s6o9-home-events__intro {
    gap: 16px;
  }

  .s6o9 .s6o9-events__cards {
    margin-top: 24px;
  }
}

/* .s6o9-home-pathways::before {
  animation: atmosphere-breathe 12s ease-in-out 1;
}

@keyframes atmosphere-breathe {
  0%   { opacity: .18; }
  50%  { opacity: .28; }
  100% { opacity: .18; }
} */

/* ============================================================
   HOME MOBILE LAUNCH PATCH — 2026-05-31
   ============================================================ */

@media (max-width: 767px) {
  /* ============================================================
     GLOBAL: Section Headline System & Rhythm
     ============================================================ */

  /* Section headlines - consistent scale */
  .s6o9 .s6o9-pathways__heading .elementor-heading-title,
  .s6o9 .s6o9-culture__heading .elementor-heading-title,
  .s6o9 .s6o9-events-intro__heading .elementor-heading-title,
  .s6o9 .s6o9-art__heading .elementor-heading-title,
  .s6o9 .s6o9-help__heading .elementor-heading-title {
    font-size: 2.75rem !important;
    line-height: 1.15 !important;
    letter-spacing: -0.03em !important;
  }

  /* Stays headline - slightly smaller due to length, same family */
  .s6o9 .s6o9-stays__heading .elementor-heading-title {
    font-size: 2.35rem !important;
    line-height: 1.15 !important;
    letter-spacing: -0.03em !important;
  }

  /* Section spacing - consistent rhythm */
  .s6o9 #home-pathways,
  .s6o9 .s6o9-home-culture,
  .s6o9 #home-events,
  .s6o9 #home-stays,
  .s6o9 .s6o9-home-art,
  .s6o9 #home-help {
    padding-top: 80px !important;
    padding-bottom: 80px !important;
  }

  /* ============================================================
     HERO / HOST CARD — Mobile Recomposition
     ============================================================ */

  /* HERO: Reduce hero image height */
  .s6o9 .s6o9-home-arrival__hero {
    height: 50vh;
    min-height: 50vh;
  }

  /* HOST WRAP: Remove excessive desktop padding and negative margin */
  .s6o9 .s6o9-home-arrival__host-wrap {
    padding: 0;
    margin-top: -150px;
    padding-top: 63px;
  }

  /* HOST CARD: Remove grid, stack vertically */
  .s6o9 .s6o9-home-host-card {
    display: flex !important;
    flex-direction: column;
    grid-template-columns: none;
    border-radius: 20px 20px 0 0;
    position: relative;
  }

  .s6o9 .s6o9-home-host-card > * {
    width: 100% !important;
  }

  /* HOST CARD: Remove atmospheric treatments on mobile */
  .s6o9 .s6o9-home-host-card::before,
  .s6o9 .s6o9-home-host-card::after {
    display: none;
  }

  /* HOST CARD: Content - increased horizontal padding */
  .s6o9 .s6o9-home-host-card__content {
    padding: 32px 28px;
    width: 100%;
  }

  /* HOST CARD: Title - mobile sizing */
  .s6o9 .s6o9-home-host-card__title .elementor-heading-title {
    font-size: 3.5rem;
    max-width: 100%;
  }

  /* HOST CARD: Body - full width */
  .s6o9 .s6o9-home-host-card__body {
    max-width: 100%;
    margin-top: 0;
    font-size: 1.125rem !important;
  }

  .s6o9 .s6o9-home-host-card__body p {
    font-size: 1.125rem !important;
    line-height: 1.65 !important;
  }

  /* HOST CARD: CTA - spacing */
  .s6o9 .s6o9-home-host-card__cta {
    margin-top: 24px;
  }

  /* HOST CARD: Media/Portrait - overlap bottom-right of HERO image in circle */
  .s6o9 .s6o9-home-host-card__media {
    position: absolute;
    top: -91px;
    right: -57px;
    width: 225px;
    height: 225px;
    min-width: 225px;
    min-height: 225px;
    max-width: 225px;
    max-height: 225px;
    padding: 0;
    z-index: 100;
    background: var(--s6o9-canvas);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
  }

  .s6o9 .s6o9-home-host-card__media .elementor-widget-image,
  .s6o9 .s6o9-home-host-card__media .elementor-widget-container {
    position: static;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .s6o9 .s6o9-home-host-card__portrait img,
  .s6o9 .s6o9-home-host-card__media img {
    position: static;
    width: 100%;
    height: 100%;
    object-fit: cover;
    left: auto;
    bottom: auto;
    mask-image: none;
    border-radius: 0;
  }

  /* ============================================================
     STAYS SECTION — Mobile Recomposition
     ============================================================ */

  /* STAYS: Stack content before media - override desktop grid */
  .s6o9 #home-offerings .s6o9-stays__inner,
  .s6o9 .s6o9-stays__inner.s6o9-lodging-preview {
    display: flex !important;
    flex-direction: column !important;
    grid-template-columns: none !important;
    gap: 40px !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 20px !important;
    min-height: auto !important;
    max-height: none !important;
  }

  /* STAYS: Content appears first */
  .s6o9 .s6o9-stays__content {
    order: 1;
    padding: 0;
    gap: 32px;
  }

  /* STAYS: Intro - eyebrow, headline, body */
  .s6o9 .s6o9-stays__intro {
    gap: 20px;
  }

  /* STAYS: Heading size for mobile */
  .s6o9 .s6o9-stays__heading .elementor-heading-title {
    font-size: 2.25rem;
  }

  /* STAYS: Features list */
  .s6o9 .s6o9-stays__features {
    gap: 12px;
  }

  .s6o9 .s6o9-stays__feature .elementor-heading-title {
    font-size: 1.25rem;
  }

  /* STAYS: Media/Gallery appears after content */
  .s6o9 .s6o9-stays__media {
    order: 2;
    width: 100vw;
    margin-left: calc(-50vw + 50%);
    margin-right: calc(-50vw + 50%);
  }

  /* STAYS: Gallery container - full width breakout */
  .s6o9 #home-offerings .s6o9-stays__media .elementor-widget-html,
  .s6o9 #home-offerings .s6o9-stays__media .elementor-widget-container {
    width: 100%;
    padding: 0;
    margin: 0;
  }

  /* STAYS: Gallery - rebuild as 2-column masonry for mobile */
  .s6o9 .s6o9-lodging-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    grid-template-rows: repeat(6, 140px) !important;
    gap: 8px !important;
    width: 100% !important;
    max-width: 100% !important;
    min-height: auto !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  /* STAYS: Mobile grid positioning - 7 images in clean rectangle */

  /* A - Bedroom 1 (large, left, rows 1-2) */
  .s6o9 .s6o9-lodging-grid__item--a {
    grid-column: 1 !important;
    grid-row: 1 / 3 !important;
    background-size: cover;
  }

  /* B - Bedroom 3 (right, row 1) */
  .s6o9 .s6o9-lodging-grid__item--b {
    grid-column: 2 !important;
    grid-row: 1 !important;
  }

  /* C - Bath 2 (right, row 2) */
  .s6o9 .s6o9-lodging-grid__item--c {
    grid-column: 2 !important;
    grid-row: 2 !important;
  }

  /* D - Kitchen (large, spans both columns, rows 3-4) */
  .s6o9 .s6o9-lodging-grid__item--d {
    grid-column: 1 / 3 !important;
    grid-row: 3 / 5 !important;
  }

  /* E - Bath 1 (left, row 5) */
  .s6o9 .s6o9-lodging-grid__item--e {
    grid-column: 1 !important;
    grid-row: 5 !important;
  }

  /* F - Bedroom 2 (right, row 5) */
  .s6o9 .s6o9-lodging-grid__item--f {
    grid-column: 2 !important;
    grid-row: 5 !important;
  }

  /* G - Pool (spans both columns, row 6) */
  .s6o9 .s6o9-lodging-grid__item--g {
    grid-column: 1 / 3 !important;
    grid-row: 6 !important;
  }

  /* STAYS: Grid items - ensure full coverage */
  .s6o9 .s6o9-lodging-grid__item {
    width: 100%;
    height: 100%;
    min-height: 0;
    box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.34);
  }

  /* ART: Stack 3-column grid to single column */
  .s6o9 .s6o9-art__inner {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  /* ART: Portrait - reduce height by half */
  .s6o9 .s6o9-art__portrait {
    max-height: 250px;
  }

  .s6o9 .s6o9-art__portrait-image {
    height: 250px;
  }

  /* ART: Gallery - restructure for mobile */
  .s6o9 .s6o9-art__gallery {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 16px;
    height: auto;
  }

  /* ART: 1st gallery image - 25% height, 100% width */
  .s6o9 .s6o9-art__gallery-image:first-child {
    width: 100%;
    height: 150px; /* 25% of typical mobile portrait height */
  }

  /* ART: 2nd and 3rd images - side by side */
  .s6o9 .s6o9-art__gallery-image:nth-child(2),
  .s6o9 .s6o9-art__gallery-image:nth-child(3) {
    width: calc(50% - 8px);
    height: 250px; /* Match original height */
  }

  /* ART: Reduce top padding */
  .s6o9 .s6o9-home-art {
    padding-top: 4em;
  }

  /* ART: Reduce content padding and gaps */
  .s6o9 .s6o9-art__content {
    gap: 24px;
    padding-top: 0;
  }

  /* PATHWAYS: Recompose to single-column narrative stack */
  .s6o9 .s6o9-pathways-grid {
    display: flex;
    flex-direction: column;
    gap: 32px;
  }

  /* PATHWAYS: Reset intro - remove desktop padding, full width */
  .s6o9 .s6o9-pathways__intro {
    padding: 0;
    max-width: 100%;
    order: -1; /* Ensure intro appears first */
  }

  .s6o9 .s6o9-pathways__body {
    max-width: 100%;
  }

  /* PATHWAYS: Pathway cards - text blocks */
  .s6o9 .s6o9-pathway-card--1 {
    order: 1;
  }

  .s6o9 .s6o9-pathway-card--2 {
    order: 3;
  }

  .s6o9 .s6o9-pathway-card--3 {
    order: 5;
  }

  /* PATHWAYS: Images - after their corresponding text */
  .s6o9 .s6o9-pathway-image--1 {
    order: 2;
  }

  .s6o9 .s6o9-pathway-image--2 {
    order: 4;
  }

  .s6o9 .s6o9-pathway-image--3 {
    order: 6;
  }

  /* PATHWAYS: Card number - 2rem */
  .s6o9 .s6o9-pathway-card__number .elementor-heading-title {
    font-size: 2rem !important;
  }

  /* PATHWAYS: Card title - 1.5rem */
  .s6o9 .s6o9-pathway-card__title .elementor-heading-title {
    font-size: 1.5rem !important;
  }

  /* CULTURE: Recompose to single-column stack */
  .s6o9 .s6o9-culture-grid {
    display: flex;
    flex-direction: column;
    gap: 40px;
  }

  /* CULTURE: Intro full width */
  .s6o9 .s6o9-culture__intro {
    max-width: 100%;
  }

  /* CULTURE: Values list full width */
  .s6o9 .s6o9-culture__values {
    max-width: 100%;
    gap: 32px;
  }

  /* CULTURE: Each value (icon + text) - keep side-by-side but adjust gap */
  .s6o9 .s6o9-culture-value {
    gap: 20px;
  }

  /* CULTURE: Icon size - 2x larger and centered */
  .s6o9 .s6o9-culture-value__icon {
    font-size: 8em;
    align-self: center;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    text-align: center;
  }

  .s6o9 .s6o9-culture-value__icon .elementor-widget-container {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    text-align: center;
  }

  .s6o9 .s6o9-culture-value__icon i,
  .s6o9 .s6o9-culture-value__icon svg {
    margin-left: auto;
    margin-right: auto;
  }

  /* CULTURE: Value row - center icons above text */
  .s6o9 .s6o9-culture-value {
    display: flex !important;
    flex-direction: column;
    grid-template-columns: none;
    gap: 20px;
    align-items: center;
    text-align: center;
  }

  /* CULTURE: Text container - centered */
  .s6o9 .s6o9-culture-value__text {
    text-align: center;
    align-items: center;
  }

  .s6o9 .s6o9-culture-value__title,
  .s6o9 .s6o9-culture-value__desc {
    text-align: center;
  }

  /* STAYS: Recompose to single-column narrative flow */
  .s6o9 .s6o9-stays__inner {
    display: flex;
    flex-direction: column;
    gap: 40px;
    width: 100%;
    max-width: 100%;
  }

  /* STAYS: Content column - remove desktop padding */
  .s6o9 .s6o9-stays__content {
    padding-top: 0;
    gap: 32px;
  }

  /* STAYS: Intro adjustments */
  .s6o9 .s6o9-stays__intro {
    gap: 24px;
  }

  /* HELP: Recompose to single-column stack */
  .s6o9 .s6o9-help__inner {
    display: flex;
    flex-direction: column;
    gap: 40px;
  }

  /* HELP: Contact methods - reduce spacing */
  .s6o9 .s6o9-help__methods {
    margin-bottom: 32px;
  }

  /* HELP: Individual method - stack icon above text */
  .s6o9 .s6o9-help__method {
    display: flex !important;
    flex-direction: column;
    grid-template-columns: none;
    gap: 12px;
    padding: 20px 0;
    align-items: center;
    text-align: center;
  }

  .s6o9 .s6o9-help__method .s6o9-help__icon {
    width: 70px;
    height: 70px;
    min-width: 70px;
    min-height: 70px;
    max-width: 70px;
    max-height: 70px;
  }

  /* HELP: Form container - horizontal padding */
  .s6o9 .s6o9-help__form-wrapper {
    padding-left: 24px;
    padding-right: 24px;
  }

  /* HELP: Form heading - 2rem */
  .s6o9 .s6o9-help__form-heading .elementor-heading-title {
    font-size: 2rem !important;
  }

  /* HELP: Form icon - 75% of current size */
  .s6o9 .s6o9-help__form-icon {
    transform: scale(0.75);
  }
}
