/* SOHO Suites — Guest Portal | luxury minimalism, urbanwolf-inspired */

@import url('https://fonts.googleapis.com/css2?family=Bodoni+Moda:ital,opsz,wght@0,6..96,400;0,6..96,500;0,6..96,600;0,6..96,700;1,6..96,400&family=Jost:wght@300;400;500;600&display=swap');

:root {
  /* warm neutrals */
  --ink:        #0F0E0C;
  --ink-soft:   #2A2724;
  --paper:      #FAF8F3;
  --paper-2:    #F2EEE6;
  --line:       #D8D2C7;
  --mute:       #8A8378;
  --gold:       #B08642;
  --gold-deep:  #8C6A33;
  --danger:     #B0351F;

  /* fonts */
  --serif: 'Bodoni Moda', 'Times New Roman', serif;
  --sans:  'Jost', system-ui, -apple-system, sans-serif;

  /* rhythm */
  --container: 1280px;
  --gutter: clamp(1.25rem, 4vw, 3rem);
}

[data-theme="dark"] {
  --ink:      #F2EEE6;
  --ink-soft: #C9C2B6;
  --paper:    #0F0E0C;
  --paper-2:  #181613;
  --line:     #2C2823;
  --mute:     #8A8378;
}

* { box-sizing: border-box; }
html {
  scroll-behavior: smooth;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
html::-webkit-scrollbar { width: 0; height: 0; display: none; }
body { scrollbar-width: none; }
body::-webkit-scrollbar { width: 0; height: 0; display: none; }
body.is-modal-open { overflow: hidden; }

html { overflow-x: clip; }
body {
  margin: 0;
  font-family: var(--sans);
  background: var(--paper);
  color: var(--ink);
  font-size: 16px;
  line-height: 1.6;
  font-weight: 400;
  letter-spacing: 0.005em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: clip;
}

/* typography */
.font-serif { font-family: var(--serif); }
.eyebrow {
  font-family: var(--sans);
  font-size: 0.72rem;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  font-weight: 500;
  color: var(--mute);
}
.display {
  font-family: var(--serif);
  font-weight: 400;
  font-style: normal;
  line-height: 1.05;
  letter-spacing: -0.01em;
  font-size: clamp(2.4rem, 6vw, 5rem);
}
.display-sm {
  font-family: var(--serif);
  font-weight: 400;
  line-height: 1.1;
  font-size: clamp(1.75rem, 3.5vw, 2.75rem);
  letter-spacing: -0.005em;
}
.lede {
  font-size: clamp(1rem, 1.2vw, 1.125rem);
  line-height: 1.65;
  color: var(--ink-soft);
  max-width: 56ch;
}

/* container */
.wrap {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--gutter);
}

/* nav */
.nav {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.25rem var(--gutter);
  background: transparent;
  transition: background 250ms ease, color 250ms ease, border 250ms ease;
  color: var(--paper);
  border-bottom: 1px solid transparent;
}
.nav--solid {
  background: var(--paper);
  color: var(--ink);
  border-bottom-color: var(--line);
  backdrop-filter: saturate(120%) blur(8px);
}
.nav__logo {
  font-family: var(--serif);
  font-size: 1.25rem;
  letter-spacing: 0.18em;
  font-weight: 500;
  text-transform: uppercase;
  color: inherit;
  text-decoration: none;
}
.nav__menu {
  display: flex;
  align-items: center;
  gap: 2rem;
  font-size: 0.8rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 400;
}
.nav__menu a { color: inherit; text-decoration: none; opacity: 0.85; transition: opacity 200ms; }
.nav__menu a:hover { opacity: 1; }
.nav__lang {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  border-left: 1px solid currentColor;
  padding-left: 1.25rem;
  opacity: 0.8;
}
.nav__lang button {
  background: none;
  border: none;
  color: inherit;
  cursor: pointer;
  font: inherit;
  letter-spacing: inherit;
  padding: 0 0.25rem;
  opacity: 0.55;
}
.nav__lang button.is-active { opacity: 1; font-weight: 500; }

/* ---------- mobile nav (hamburger + slide panel) ---------- */
.nav__toggle {
  display: none;
  width: 42px;
  height: 42px;
  background: transparent;
  border: 0;
  cursor: pointer;
  padding: 0;
  align-items: center;
  justify-content: center;
  position: relative;
  color: inherit;
}
.nav__toggle span {
  position: absolute;
  left: 11px;
  right: 11px;
  height: 1.5px;
  background: currentColor;
  border-radius: 1px;
  transition: transform 280ms cubic-bezier(.77,0,.175,1), opacity 200ms ease, top 280ms ease;
}
.nav__toggle span:nth-child(1) { top: 14px; }
.nav__toggle span:nth-child(2) { top: 20px; }
.nav__toggle span:nth-child(3) { top: 26px; }
body.nav-open .nav__toggle span:nth-child(1) { top: 20px; transform: rotate(45deg); }
body.nav-open .nav__toggle span:nth-child(2) { opacity: 0; }
body.nav-open .nav__toggle span:nth-child(3) { top: 20px; transform: rotate(-45deg); }

@media (max-width: 860px) {
  .nav {
    padding: 0.9rem var(--gutter);
    mix-blend-mode: normal;
    background: rgba(15,14,12,0.0);
  }
  .nav__logo { font-size: 1rem; letter-spacing: 0.14em; }
  .nav__toggle { display: inline-flex; }

  .nav__menu {
    position: fixed;
    top: 0; left: 0;
    width: 100vw;
    height: 100vh;
    height: 100dvh;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 0.4rem;
    padding: 5rem var(--gutter) 2rem;
    background: var(--paper);
    color: var(--ink);
    transform: translateY(-100%);
    transition: transform 420ms cubic-bezier(.77,0,.175,1);
    z-index: 49;
    font-size: 1.05rem;
    letter-spacing: 0.18em;
    overflow-y: auto;
    overscroll-behavior: contain;
  }
  body.nav-open .nav__menu {
    transform: translateY(0);
  }
  body.nav-open { overflow: hidden; }
  body.nav-open .nav { color: var(--ink); }

  .nav__menu a {
    font-family: var(--serif, Georgia, serif);
    font-size: 1.5rem;
    letter-spacing: -0.005em;
    text-transform: none;
    opacity: 1;
    padding: 0.3rem 0;
    line-height: 1.15;
  }
  .nav__menu a::after { display: none; }

  .nav__lang {
    margin-top: 1.5rem;
    padding-left: 0;
    border-left: 0;
    border-top: 1px solid rgba(15,14,12,0.15);
    padding-top: 1.25rem;
    width: 100%;
  }

  /* nav hidden over hero, revealed once scrolled past it (same as desktop) */
  body.past-hero .nav { background: var(--paper); color: var(--ink); border-bottom: 1px solid var(--line); }
  /* on mobile, NEVER transform .nav — would scope fixed-positioned menu to nav's tiny box */
  .nav.is-hidden { transform: none !important; }
  body.nav-open .nav { transform: none !important; }
}

/* hero */
.hero {
  position: relative;
  min-height: 100dvh;
  display: grid;
  place-items: center;
  text-align: center;
  color: var(--paper);
  overflow: hidden;
  isolation: isolate;
}
.hero__bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  background-size: cover;
  background-position: center;
  filter: brightness(0.7);
  transform: scale(1.02);
  transition: transform 800ms cubic-bezier(.22,.61,.36,1);
}
.hero__veil {
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(180deg, rgba(15,14,12,0.25) 0%, rgba(15,14,12,0.05) 35%, rgba(15,14,12,0.55) 100%);
}
.hero__inner {
  padding: 8rem var(--gutter) 6rem;
  max-width: 60rem;
}
.hero .eyebrow { color: rgba(250,248,243,0.75); }
.hero .display { color: var(--paper); margin: 1.25rem 0 1.5rem; }
.hero .lede { color: rgba(250,248,243,0.85); margin: 0 auto; }

/* button */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  font-family: var(--sans);
  font-size: 0.78rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 500;
  padding: 1rem 2rem;
  border: 1px solid currentColor;
  background: transparent;
  color: inherit;
  cursor: pointer;
  text-decoration: none;
  transition: background 220ms ease, color 220ms ease, transform 220ms ease;
}
.btn:hover { background: currentColor; }
.btn:hover .btn__label { color: var(--paper); }
[data-theme="dark"] .btn:hover .btn__label { color: var(--ink); }
.btn__label { transition: color 220ms; }
.btn--solid {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}
.btn--solid:hover { background: var(--gold); border-color: var(--gold); }
.btn--solid:hover .btn__label { color: var(--paper); }
.btn--gold {
  background: var(--gold);
  border-color: var(--gold);
  color: var(--paper);
}
.btn--gold:hover { background: var(--gold-deep); border-color: var(--gold-deep); }
.btn--ghost { border-color: rgba(0,0,0,0.18); }
.btn--lg { padding: 1.15rem 2.4rem; font-size: 0.82rem; }

/* scroll indicator */
.scroll-hint {
  position: absolute;
  bottom: 2.5rem;
  left: 50%;
  transform: translateX(-50%);
  color: rgba(250,248,243,0.75);
  font-size: 0.7rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
}
.scroll-hint__line {
  width: 1px;
  height: 48px;
  background: currentColor;
  animation: drip 2.4s ease-in-out infinite;
  transform-origin: top;
}
@keyframes drip {
  0%   { transform: scaleY(0); }
  50%  { transform: scaleY(1); }
  100% { transform: scaleY(0); transform-origin: bottom; }
}

/* section */
.section { padding: clamp(4rem, 10vw, 8rem) 0; }
.section-tight { padding: clamp(3rem, 6vw, 5rem) 0; }
.section__head { max-width: 44rem; margin-bottom: 3.5rem; }
.section__head--center { margin-left: auto; margin-right: auto; text-align: center; }

/* split row */
.split {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  align-items: start;
}
@media (min-width: 900px) { .split { grid-template-columns: 1fr 1fr; gap: 5rem; } }

/* card */
.card {
  background: var(--paper);
  border: 1px solid var(--line);
  padding: 2rem;
  transition: border-color 220ms ease, transform 280ms ease;
}
.card:hover { border-color: var(--ink); }
.card--inset { background: var(--paper-2); }

/* form (minimal underline) */
.field {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding: 1rem 0 0.85rem;
  border-bottom: 1px solid var(--line);
  transition: border-color 200ms ease;
}
.field:focus-within { border-color: var(--ink); }
.field label {
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--mute);
  font-weight: 500;
}
.field input,
.field select,
.field textarea {
  background: transparent;
  border: none;
  outline: none;
  font: inherit;
  color: var(--ink);
  font-size: 1.05rem;
  padding: 0;
}
.field input::placeholder { color: var(--line); }
.field--required label::after { content: ' *'; color: var(--gold); }

/* form grid */
.form-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0 2.5rem;
}
@media (min-width: 700px) {
  .form-grid--2 { grid-template-columns: 1fr 1fr; }
  .form-grid--3 { grid-template-columns: 1fr 1fr 1fr; }
  .form-grid .col-span-2 { grid-column: span 2; }
}

/* upload zone */
.scan-zone {
  border: 1px dashed var(--line);
  background: var(--paper-2);
  padding: 2.5rem 2rem;
  text-align: center;
  cursor: pointer;
  transition: border-color 220ms ease, background 220ms ease;
}
.scan-zone:hover { border-color: var(--gold); background: var(--paper); }
.scan-zone__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  border: 1px solid var(--line);
  margin-bottom: 1rem;
}

/* reservation chip */
.chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 2.5rem;
  padding: 1.5rem 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.chip {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}
.chip__label {
  font-size: 0.68rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--mute);
}
.chip__value {
  font-family: var(--serif);
  font-size: 1.35rem;
}

/* progress dots */
.steps {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--mute);
}
.steps__dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--line);
}
.steps__dot.is-on { background: var(--ink); }
.steps__dot.is-done { background: var(--gold); }

/* add-on card with hover image swap */
.addon {
  position: relative;
  border: 1px solid var(--line);
  background: var(--paper);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: border-color 220ms ease;
}
.addon:hover { border-color: var(--ink); }
.addon__media {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
}
.addon__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: opacity 500ms ease, transform 700ms cubic-bezier(.22,.61,.36,1);
}
.addon__img--alt { opacity: 0; }
.addon:hover .addon__img--main { opacity: 0; transform: scale(1.04); }
.addon:hover .addon__img--alt { opacity: 1; transform: scale(1.04); }
.addon__body {
  padding: 1.75rem 1.75rem 2rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  flex: 1;
}
.addon__title {
  font-family: var(--serif);
  font-size: 1.55rem;
  line-height: 1.15;
}
.addon__desc {
  color: var(--ink-soft);
  font-size: 0.92rem;
  line-height: 1.55;
  flex: 1;
}
.addon__foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 1px solid var(--line);
  padding-top: 1.25rem;
  margin-top: 0.5rem;
}
.addon__price {
  font-family: var(--serif);
  font-size: 1.2rem;
}
.addon__add {
  font-size: 0.74rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 500;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--ink);
  padding: 0.4rem 0.6rem;
  margin-right: -0.6rem;
  transition: color 200ms ease;
}
.addon__add:hover { color: var(--gold); }
.addon__add.is-added { color: var(--gold); }
.addon__badge {
  position: absolute;
  top: 1rem;
  left: 1rem;
  z-index: 2;
  background: var(--paper);
  color: var(--ink);
  font-size: 0.68rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 0.4rem 0.7rem;
}

/* cart rail */
.cart-rail {
  border: 1px solid var(--line);
  padding: 2rem;
  background: var(--paper);
}
.cart-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 0;
  border-bottom: 1px solid var(--line);
  font-size: 0.95rem;
}
.cart-row:last-of-type { border-bottom: none; }
.cart-row__title { color: var(--ink); }
.cart-row__price { font-family: var(--serif); }

/* tax callout */
.tax-note {
  display: flex;
  gap: 1.25rem;
  align-items: flex-start;
  background: var(--paper-2);
  border-left: 2px solid var(--gold);
  padding: 1.5rem 1.75rem;
  margin-top: 2rem;
}
.tax-note__title {
  font-family: var(--serif);
  font-size: 1.15rem;
  margin-bottom: 0.35rem;
}
.tax-note__body {
  font-size: 0.9rem;
  color: var(--ink-soft);
  line-height: 1.55;
}

/* footer */
.foot {
  border-top: 1px solid var(--line);
  padding: 3rem 0 2rem;
  font-size: 0.82rem;
  color: var(--mute);
}
.foot__row {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 1.5rem;
  align-items: center;
}
.foot a { color: inherit; text-decoration: none; }
.foot a:hover { color: var(--ink); }

/* utility */
.divider { height: 1px; background: var(--line); margin: 3rem 0; }
.text-center { text-align: center; }
.muted { color: var(--mute); }
.gold { color: var(--gold); }

/* reveal on scroll */
.reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 700ms ease, transform 700ms ease;
}
.reveal.is-in { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    transition-duration: 0.001ms !important;
  }
}

/* ========================================================
   PREMIUM MOTION — added pass
   ======================================================== */

/* ken burns — slow cinematic zoom + pan on hero bg */
@keyframes kenburns {
  0%   { transform: scale(1.0)  translate3d(0, 0, 0); }
  50%  { transform: scale(1.08) translate3d(-1.5%, -1%, 0); }
  100% { transform: scale(1.0)  translate3d(0, 0, 0); }
}
.kenburns {
  animation: kenburns 28s ease-in-out infinite;
  will-change: transform;
}

/* image clip-path reveal — photos arrive like a curtain lifting */
@keyframes clipReveal {
  from { clip-path: inset(0 100% 0 0); }
  to   { clip-path: inset(0 0 0 0); }
}
.clip-reveal { animation: clipReveal 1400ms cubic-bezier(.77,0,.175,1) both; }
.clip-reveal--delay { animation-delay: 200ms; }

/* split-text: each word/letter slides up from below a mask */
.split-line {
  display: inline-block;
  overflow: hidden;
  vertical-align: bottom;
  line-height: 1.05;
}
.split-word {
  display: inline-block;
  transform: translateY(110%);
  opacity: 0;
  transition: transform 1100ms cubic-bezier(.22,.61,.36,1), opacity 800ms ease;
  will-change: transform, opacity;
}
.split-word.is-in {
  transform: translateY(0);
  opacity: 1;
}

/* word fade for lede */
.word-fade > span {
  display: inline-block;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 700ms ease, transform 700ms cubic-bezier(.22,.61,.36,1);
}
.word-fade.is-in > span { opacity: 1; transform: none; }

/* MAGNETIC CTA — premium button that gently follows the cursor */
.btn-magnetic {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.85rem;
  padding: 1.15rem 2.4rem;
  font-family: var(--sans);
  font-size: 0.82rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 500;
  color: var(--paper);
  background: var(--ink);
  border: 1px solid var(--ink);
  cursor: pointer;
  overflow: hidden;
  isolation: isolate;
  text-decoration: none;
  transition: transform 450ms cubic-bezier(.18,.89,.32,1.28),
              color 320ms ease,
              border-color 320ms ease;
  will-change: transform;
}
.btn-magnetic::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--gold);
  transform: translateY(101%);
  transition: transform 520ms cubic-bezier(.77,0,.175,1);
  z-index: -1;
}
.btn-magnetic:hover::before { transform: translateY(0); }
.btn-magnetic:hover { border-color: var(--gold); color: var(--paper); }
.btn-magnetic__label {
  display: inline-block;
  transition: transform 420ms cubic-bezier(.77,0,.175,1), letter-spacing 420ms ease;
}
.btn-magnetic:hover .btn-magnetic__label { letter-spacing: 0.28em; }
.btn-magnetic__arrow {
  display: inline-flex;
  position: relative;
  width: 22px;
  height: 14px;
  overflow: hidden;
}
.btn-magnetic__arrow svg {
  position: absolute;
  top: 0; left: 0;
  transition: transform 420ms cubic-bezier(.77,0,.175,1), opacity 320ms ease;
}
.btn-magnetic__arrow svg + svg { transform: translateX(-130%); }
.btn-magnetic:hover .btn-magnetic__arrow svg:first-child { transform: translateX(130%); opacity: 0; }
.btn-magnetic:hover .btn-magnetic__arrow svg + svg { transform: translateX(0); opacity: 1; }

/* press feedback */
.btn-magnetic:active { transform: scale(0.985) !important; }

/* animated underline links */
.uline {
  position: relative;
  text-decoration: none;
  color: var(--ink);
  padding-bottom: 2px;
}
.uline::after {
  content: '';
  position: absolute;
  left: 0; bottom: 0;
  width: 100%;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: right center;
  transition: transform 480ms cubic-bezier(.77,0,.175,1);
}
.uline:hover::after { transform: scaleX(1); transform-origin: left center; }

/* cursor spotlight (gold halo following cursor) */
.spotlight {
  position: absolute;
  pointer-events: none;
  width: 480px;
  height: 480px;
  border-radius: 50%;
  background: radial-gradient(circle at center, rgba(176,134,66,0.28) 0%, rgba(176,134,66,0.08) 35%, transparent 65%);
  transform: translate(-50%, -50%);
  mix-blend-mode: screen;
  opacity: 0;
  transition: opacity 600ms ease;
  z-index: 1;
}
.spotlight.is-on { opacity: 1; }

/* floating gold dot — micro accent that breathes */
.pulse-dot {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--gold);
  margin-right: 0.65rem;
  vertical-align: middle;
  animation: pulse 2.4s ease-in-out infinite;
  box-shadow: 0 0 0 0 rgba(176,134,66,0.5);
}
@keyframes pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(176,134,66,0.55); }
  50%      { box-shadow: 0 0 0 10px rgba(176,134,66,0); }
}

/* marquee (accolades strip) */
.marquee {
  overflow: hidden;
  white-space: nowrap;
  mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
}
.marquee__track {
  display: inline-flex;
  gap: 3rem;
  padding-right: 3rem;
  animation: marquee 38s linear infinite;
}
@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.marquee__item {
  font-family: var(--serif);
  font-style: italic;
  font-size: 1.1rem;
  color: var(--mute);
  display: inline-flex;
  align-items: center;
  gap: 1rem;
}
.marquee__item::after {
  content: '✦';
  color: var(--gold);
  font-style: normal;
  font-size: 0.85rem;
}

/* page-load fade */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: none; }
}
.fade-in    { animation: fadeUp 900ms 100ms cubic-bezier(.22,.61,.36,1) both; }
.fade-in-2  { animation: fadeUp 900ms 350ms cubic-bezier(.22,.61,.36,1) both; }
.fade-in-3  { animation: fadeUp 900ms 600ms cubic-bezier(.22,.61,.36,1) both; }
.fade-in-4  { animation: fadeUp 900ms 850ms cubic-bezier(.22,.61,.36,1) both; }

/* input gold glow on focus */
.token-input:focus-within {
  border-bottom-color: var(--gold) !important;
}
.token-input:focus-within input::placeholder { opacity: 0.4; }

/* ---------- ghost magnetic (secondary CTA) ---------- */
.btn-ghost-magnetic {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.85rem;
  padding: 1rem 2rem;
  font-family: var(--sans);
  font-size: 0.78rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 500;
  color: var(--ink);
  background: transparent;
  border: 1px solid var(--line);
  cursor: pointer;
  overflow: hidden;
  isolation: isolate;
  text-decoration: none;
  transition: transform 450ms cubic-bezier(.18,.89,.32,1.28),
              border-color 320ms ease, color 320ms ease;
  will-change: transform;
}
.btn-ghost-magnetic::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--ink);
  transform: translateX(-101%);
  transition: transform 520ms cubic-bezier(.77,0,.175,1);
  z-index: -1;
}
.btn-ghost-magnetic:hover { color: var(--paper); border-color: var(--ink); }
.btn-ghost-magnetic:hover::before { transform: translateX(0); }
.btn-ghost-magnetic svg { transition: transform 420ms cubic-bezier(.77,0,.175,1); }
.btn-ghost-magnetic:hover svg { transform: translateX(4px); }

/* ---------- gold offer ribbon ---------- */
.offer {
  position: relative;
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.95rem 1.2rem;
  margin: 1.75rem 0;
  background: linear-gradient(95deg, rgba(176,134,66,0.10) 0%, rgba(176,134,66,0.04) 50%, rgba(176,134,66,0.10) 100%);
  border-left: 2px solid var(--gold);
  font-size: 0.88rem;
  color: var(--ink-soft);
  overflow: hidden;
}
.offer__shine {
  position: absolute;
  top: 0; bottom: 0;
  width: 80px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.5), transparent);
  transform: skewX(-22deg) translateX(-200%);
  animation: shine 5.5s ease-in-out infinite;
  pointer-events: none;
}
@keyframes shine {
  0%, 30% { transform: skewX(-22deg) translateX(-200%); }
  55%     { transform: skewX(-22deg) translateX(900%); }
  100%    { transform: skewX(-22deg) translateX(900%); }
}
.offer__icon {
  flex-shrink: 0;
  color: var(--gold);
}
.offer strong {
  font-family: var(--serif);
  font-weight: 400;
  font-style: italic;
  color: var(--ink);
  font-size: 1.05rem;
}

/* ---------- floating concierge pill ---------- */
.concierge {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  z-index: 60;
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.85rem 1.2rem 0.85rem 0.9rem;
  background: var(--ink);
  color: var(--paper);
  border-radius: 999px;
  cursor: pointer;
  text-decoration: none;
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  box-shadow: 0 20px 50px -20px rgba(15,14,12,0.55);
  transform: translateY(160%);
  opacity: 0;
  pointer-events: none;
  transition: transform 700ms cubic-bezier(.22,.61,.36,1), opacity 500ms ease, padding-right 450ms cubic-bezier(.77,0,.175,1), gap 450ms ease;
  max-width: 92vw;
}
body.past-hero .concierge {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}
.concierge__avatars {
  display: inline-flex;
  align-items: center;
}
.concierge__avatars span {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 2px solid var(--ink);
  margin-left: -10px;
  background-size: cover;
  background-position: center;
}
.concierge__avatars span:first-child { margin-left: 0; }
.concierge__avatars span:nth-child(1) { background-image: url('https://images.unsplash.com/photo-1494790108377-be9c29b29330?w=120&q=80&auto=format&fit=crop&crop=faces'); }
.concierge__avatars span:nth-child(2) { background-image: url('https://images.unsplash.com/photo-1500648767791-00dcc994a43e?w=120&q=80&auto=format&fit=crop&crop=faces'); }
.concierge__dot {
  position: absolute;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: #4ADE80;
  border: 2px solid var(--ink);
  bottom: 8px;
  left: 36px;
  box-shadow: 0 0 0 0 rgba(74,222,128,0.55);
  animation: pulseGreen 2.2s ease-in-out infinite;
}
@keyframes pulseGreen {
  0%, 100% { box-shadow: 0 0 0 0 rgba(74,222,128,0.6); }
  50%      { box-shadow: 0 0 0 8px rgba(74,222,128,0); }
}
.concierge__copy { display: inline-flex; flex-direction: column; line-height: 1.2; }
.concierge__copy small {
  font-size: 0.62rem;
  letter-spacing: 0.2em;
  opacity: 0.6;
  margin-bottom: 0.2rem;
  text-transform: uppercase;
}
.concierge__extra {
  max-width: 0;
  overflow: hidden;
  white-space: nowrap;
  opacity: 0;
  transition: max-width 480ms cubic-bezier(.77,0,.175,1), opacity 280ms 80ms ease, margin-left 480ms cubic-bezier(.77,0,.175,1);
  margin-left: 0;
  font-family: var(--serif);
  font-style: italic;
  font-size: 0.92rem;
  letter-spacing: 0.02em;
  text-transform: none;
  color: rgba(250,248,243,0.85);
}
.concierge:hover .concierge__extra {
  max-width: 14rem;
  opacity: 1;
  margin-left: 0.6rem;
}
.concierge:hover { background: var(--gold-deep); }

/* ---------- virtual tour overlay link ---------- */
.tour-link {
  position: absolute;
  bottom: 1.75rem;
  right: 1.75rem;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.85rem 1.2rem;
  color: var(--paper);
  background: rgba(15,14,12,0.32);
  backdrop-filter: blur(10px) saturate(140%);
  -webkit-backdrop-filter: blur(10px) saturate(140%);
  border: 1px solid rgba(250,248,243,0.25);
  border-radius: 999px;
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  text-decoration: none;
  transition: background 320ms ease, border-color 320ms ease, transform 320ms ease;
}
.tour-link:hover {
  background: rgba(176,134,66,0.85);
  border-color: rgba(176,134,66,0.95);
  transform: translateY(-2px);
}
.tour-link__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: var(--paper);
  color: var(--ink);
  flex-shrink: 0;
  transition: transform 320ms ease;
}
.tour-link:hover .tour-link__icon { transform: rotate(360deg); }

/* ---------- divider between primary and secondary CTA ---------- */
.or-divider {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin: 1.5rem 0;
  font-size: 0.68rem;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--mute);
}
.or-divider::before, .or-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--line);
}

/* ===========================================================
   MOTION v2 — scroll-driven, cursor, counters, parallax, tilt
   =========================================================== */

/* Custom cursor (desktop only, fine pointer) */
@media (pointer: fine) {
  body { cursor: none; }
  a, button, input, label, .concierge, .nav__lang button { cursor: none; }
  .cursor-dot, .cursor-ring {
    position: fixed;
    top: 0; left: 0;
    pointer-events: none;
    z-index: 9999;
    transform: translate3d(-100px, -100px, 0);
    will-change: transform;
  }
  .cursor-dot {
    width: 6px; height: 6px;
    background: var(--gold);
    border-radius: 50%;
    margin: -3px 0 0 -3px;
    transition: opacity 200ms ease, transform 80ms linear;
  }
  .cursor-ring {
    width: 38px; height: 38px;
    border: 1px solid rgba(176,134,66,0.85);
    border-radius: 50%;
    margin: -19px 0 0 -19px;
    transition: width 280ms cubic-bezier(.18,.89,.32,1.28),
                height 280ms cubic-bezier(.18,.89,.32,1.28),
                margin 280ms cubic-bezier(.18,.89,.32,1.28),
                border-color 220ms ease,
                background 220ms ease,
                mix-blend-mode 220ms ease,
                opacity 220ms ease;
  }
  .cursor-ring.is-hover {
    width: 72px; height: 72px;
    margin: -36px 0 0 -36px;
    border-color: rgba(176,134,66,0.95);
    background: rgba(176,134,66,0.12);
    mix-blend-mode: normal;
  }
  .cursor-ring.is-text {
    width: 14px; height: 14px;
    margin: -7px 0 0 -7px;
    background: var(--gold);
    border-color: var(--gold);
  }
}
@media (pointer: coarse) {
  .cursor-dot, .cursor-ring { display: none; }
}

/* ---------- scroll-driven reveal (animation-timeline + IO fallback) ---------- */
.scroll-rise {
  opacity: 0;
  transform: translateY(48px);
  transition: opacity 900ms cubic-bezier(.22,.61,.36,1),
              transform 900ms cubic-bezier(.22,.61,.36,1);
}
.scroll-rise.is-in { opacity: 1; transform: none; }

@supports (animation-timeline: view()) {
  .scroll-rise {
    animation: scrollRise linear both;
    animation-timeline: view();
    animation-range: entry 0% cover 28%;
    transition: none;
  }
  @keyframes scrollRise {
    from { opacity: 0; transform: translateY(48px); }
    to   { opacity: 1; transform: none; }
  }
}

.scroll-clip {
  clip-path: inset(0 100% 0 0);
  transition: clip-path 1400ms cubic-bezier(.77,0,.175,1);
}
.scroll-clip.is-in { clip-path: inset(0 0 0 0); }

@supports (animation-timeline: view()) {
  .scroll-clip {
    clip-path: inset(0 100% 0 0);
    animation: clipOpen linear both;
    animation-timeline: view();
    animation-range: entry 10% cover 45%;
    transition: none;
  }
  @keyframes clipOpen {
    to { clip-path: inset(0 0 0 0); }
  }
}

/* gentle hero parallax — bg moves slower than scroll (Safari-safe via JS var) */
.full-hero__bg { transform: translate3d(0, var(--py, 0px), 0) scale(1.02); }

/* hero text rises slower than its container — drives a feeling of depth */
.full-hero__inner > div:first-child { transform: translate3d(0, calc(var(--py, 0px) * -0.4), 0); will-change: transform; }

/* slow hue/tone shift on dark sections — barely perceptible breathing */
@keyframes hueDrift {
  0%, 100% { filter: hue-rotate(0deg) brightness(1); }
  50%      { filter: hue-rotate(8deg) brightness(1.04); }
}
.hue-drift { animation: hueDrift 28s ease-in-out infinite; }

/* floating decorative orb behind hero — drifts diagonally */
.orb {
  position: absolute;
  pointer-events: none;
  border-radius: 50%;
  filter: blur(60px);
  opacity: 0.45;
  mix-blend-mode: screen;
}
.orb--gold {
  width: 480px; height: 480px;
  background: radial-gradient(circle, rgba(176,134,66,0.5), transparent 70%);
  top: 20%; left: -10%;
  animation: orbDrift 22s ease-in-out infinite;
}
.orb--ink {
  width: 380px; height: 380px;
  background: radial-gradient(circle, rgba(15,14,12,0.6), transparent 70%);
  bottom: 10%; right: -8%;
  animation: orbDrift 28s ease-in-out infinite reverse;
}
@keyframes orbDrift {
  0%, 100% { transform: translate3d(0, 0, 0) scale(1); }
  50%      { transform: translate3d(8%, -6%, 0) scale(1.1); }
}

/* counter — number animates up on scroll-in */
.counter { display: inline-block; font-variant-numeric: tabular-nums; }

/* 3D tilt amenity cards */
.tilt {
  transform: perspective(800px) rotateX(var(--rx, 0deg)) rotateY(var(--ry, 0deg)) translateZ(0);
  transform-style: preserve-3d;
  transition: transform 260ms cubic-bezier(.22,.61,.36,1);
  will-change: transform;
}
.tilt > * { transform: translateZ(20px); }
.tilt .amenity__icon { transform: translateZ(40px); }

/* secondary marquee strip — "MOTION TAPE" — runs slow, gold accents */
.tape {
  background: var(--ink);
  color: var(--paper);
  padding: 1.5rem 0;
  overflow: hidden;
  white-space: nowrap;
  mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
}
.tape__track {
  display: inline-flex;
  gap: 4rem;
  padding-right: 4rem;
  animation: tape 32s linear infinite;
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(1.4rem, 3vw, 2.4rem);
}
.tape:hover .tape__track { animation-play-state: paused; }
.tape__item {
  display: inline-flex;
  align-items: center;
  gap: 2.5rem;
}
.tape__item::after {
  content: '✦';
  color: var(--gold);
  font-style: normal;
  font-size: 0.7em;
}
@keyframes tape { to { transform: translateX(-50%); } }

/* gallery — staggered scroll-tied scale on each cell */
.g-cell { transition: transform 700ms cubic-bezier(.22,.61,.36,1); }
@supports (animation-timeline: view()) {
  .g-cell {
    animation: cellLift linear both;
    animation-timeline: view();
    animation-range: entry 0% cover 40%;
  }
  @keyframes cellLift {
    from { opacity: 0; transform: translateY(40px) scale(0.97); }
    to   { opacity: 1; transform: none; }
  }
}

/* hero meta — numbers tick up smoothly */
.hero-meta__value .counter { transition: color 220ms ease; }

/* nav link slide-underline */
.nav__menu a {
  position: relative;
  padding-bottom: 4px;
}
.nav__menu a::after {
  content: '';
  position: absolute;
  left: 0; bottom: 0;
  width: 100%;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: right;
  transition: transform 380ms cubic-bezier(.77,0,.175,1);
}
.nav__menu a:hover::after { transform: scaleX(1); transform-origin: left; }

/* scroll-snap photo strip (horizontal premium gallery) */
.strip {
  display: flex;
  gap: 1rem;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  overscroll-behavior-x: contain;
  padding: 0 var(--gutter) 2rem;
  margin: 0 calc(var(--gutter) * -1);
  scrollbar-width: none;
}
.strip::-webkit-scrollbar { display: none; }
.strip__card {
  flex: 0 0 min(85vw, 720px);
  scroll-snap-align: center;
  aspect-ratio: 5 / 6;
  position: relative;
  overflow: hidden;
  background: var(--ink);
}
.strip__card img {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1400ms cubic-bezier(.22,.61,.36,1);
}
.strip__card:hover img { transform: scale(1.05); }
.strip__card .cap {
  position: absolute;
  left: 1.5rem; bottom: 1.5rem;
  color: var(--paper);
  z-index: 2;
}
.strip__card .cap small {
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  opacity: 0.7;
}
.strip__card .cap b {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.65rem;
  display: block;
  margin-top: 0.4rem;
}
.strip__card::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(15,14,12,0.55), transparent 50%);
  z-index: 1;
}

/* slow gold ring around active spotlight zone */
.gold-ring {
  position: absolute;
  width: 280px; height: 280px;
  border: 1px solid rgba(176,134,66,0.35);
  border-radius: 50%;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  animation: ringPulse 6s ease-in-out infinite;
  pointer-events: none;
}
@keyframes ringPulse {
  0%, 100% { transform: translate(-50%, -50%) scale(0.7); opacity: 0; }
  50%      { transform: translate(-50%, -50%) scale(1.4); opacity: 0.6; }
}

/* page-bottom progress bar (reading progress) */
.progress {
  position: fixed;
  top: 0; left: 0;
  width: 100%;
  height: 2px;
  background: var(--gold);
  z-index: 100;
  transform-origin: left;
  transform: scaleX(var(--scrollp, 0));
  transition: transform 80ms linear;
  pointer-events: none;
}

/* booking watermark drift */
.booking::before {
  animation: drift 26s ease-in-out infinite;
}
@keyframes drift {
  0%, 100% { transform: translate(0, 0); }
  50%      { transform: translate(-1.5%, 0.5%); }
}

/* POI list — gold distance pulses on hover */
.poi-list li { transition: background 280ms ease, padding-left 320ms cubic-bezier(.77,0,.175,1); position: relative; }
.poi-list li::before {
  content: '';
  position: absolute;
  left: -1rem; top: 50%;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--gold);
  transform: translateY(-50%) scale(0);
  transition: transform 380ms cubic-bezier(.18,.89,.32,1.28);
}
.poi-list li:hover { padding-left: 1rem; background: var(--paper-2); }
.poi-list li:hover::before { transform: translateY(-50%) scale(1); }

/* address-strip — long arrow that draws */
.draw-arrow {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
}
.draw-arrow svg { stroke-dasharray: 100; stroke-dashoffset: 100; transition: stroke-dashoffset 720ms cubic-bezier(.77,0,.175,1); }
.draw-arrow:hover svg { stroke-dashoffset: 0; }

/* breathing star (★) */
.star-breath { display: inline-block; animation: starBreath 3.4s ease-in-out infinite; }
@keyframes starBreath {
  0%, 100% { transform: scale(1); opacity: 1; }
  50%      { transform: scale(1.15); opacity: 0.85; }
}

/* nav scroll-direction hide */
.nav { transition: transform 380ms cubic-bezier(.77,0,.175,1), background 250ms ease, color 250ms ease; }
.nav.is-hidden { transform: translateY(-100%); }

/* ===========================================================
   DUAL-ROW INFINITE DRIFT GALLERY — replaces static editorial grid
   =========================================================== */
.drift-gallery {
  padding: clamp(4rem, 8vw, 7rem) 0;
  background: var(--paper-2);
  overflow: hidden;
}
.drift-gallery__head {
  max-width: var(--container);
  margin: 0 auto 3.5rem;
  padding: 0 var(--gutter);
}
.drift-row {
  display: flex;
  gap: 1.25rem;
  margin-bottom: 1.25rem;
  width: max-content;
  will-change: transform;
}
.drift-row--ltr { animation: driftL 60s linear infinite; }
.drift-row--rtl { animation: driftR 75s linear infinite; }

@keyframes driftL {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
@keyframes driftR {
  from { transform: translateX(-50%); }
  to   { transform: translateX(0); }
}

.drift-card {
  position: relative;
  flex: 0 0 auto;
  width: clamp(260px, 32vw, 460px);
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--ink);
  cursor: pointer;
}
.drift-card--tall { aspect-ratio: 3 / 4; }
.drift-card--wide { aspect-ratio: 16 / 9; width: clamp(380px, 46vw, 620px); }
.drift-card img {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1200ms cubic-bezier(.22,.61,.36,1), filter 600ms ease;
}
.drift-card:hover img { transform: scale(1.07); filter: brightness(1.05); }
.drift-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(15,14,12,0.55), transparent 50%);
  opacity: 0;
  transition: opacity 380ms;
}
.drift-card:hover::after { opacity: 1; }
.drift-card__cap {
  position: absolute;
  left: 1.25rem;
  bottom: 1rem;
  z-index: 2;
  color: var(--paper);
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 380ms ease, transform 380ms cubic-bezier(.22,.61,.36,1);
}
.drift-card:hover .drift-card__cap {
  opacity: 1;
  transform: none;
}
.drift-card__cap small {
  font-size: 0.66rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  opacity: 0.8;
}
.drift-card__cap b {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.3rem;
  line-height: 1.2;
  display: block;
  margin-top: 0.3rem;
}

/* respect reduced motion */
@media (prefers-reduced-motion: reduce) {
  .drift-row { animation: none; }
}

/* ===========================================================
   FAMILY STORY SECTION
   =========================================================== */
.story {
  padding: clamp(5rem, 10vw, 9rem) 0;
  background: var(--paper);
  position: relative;
  overflow: hidden;
}
.story__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3.5rem;
  align-items: center;
}
@media (min-width: 900px) {
  .story__grid { grid-template-columns: 1.1fr 1.2fr; gap: 6rem; }
}
.story__media {
  position: relative;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  isolation: isolate;
}
.story__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1400ms cubic-bezier(.22,.61,.36,1);
}
.story__media:hover img { transform: scale(1.04); }
.story__media::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(15,14,12,0.25));
  z-index: 1;
}
.story__media-cap {
  position: absolute;
  z-index: 2;
  bottom: 1.5rem; left: 1.5rem;
  color: var(--paper);
  font-family: var(--serif);
  font-style: italic;
  font-size: 0.95rem;
  max-width: 16rem;
  line-height: 1.4;
}
.story__media-cap::before {
  content: '';
  display: block;
  width: 24px;
  height: 1px;
  background: var(--paper);
  margin-bottom: 0.7rem;
}
.story__copy h2 {
  font-family: var(--serif);
  font-weight: 400;
  line-height: 1.05;
  letter-spacing: -0.01em;
  font-size: clamp(2.2rem, 4.5vw, 3.6rem);
  margin: 1rem 0 1.5rem;
}
.story__copy h2 em { font-style: italic; }
.story__copy p {
  color: var(--ink-soft);
  font-size: 1.05rem;
  line-height: 1.75;
  margin: 0 0 1.25rem;
  max-width: 38rem;
}
.story__copy p.lede-serif {
  font-family: var(--serif);
  font-style: italic;
  font-size: 1.35rem;
  line-height: 1.55;
  color: var(--ink);
  margin-bottom: 2rem;
}
.story__sign {
  margin-top: 2.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--line);
  display: flex;
  align-items: center;
  gap: 1.25rem;
}
.story__sign-mark {
  font-family: var(--serif);
  font-style: italic;
  font-size: 1.9rem;
  color: var(--gold);
  line-height: 1;
}
.story__sign-meta { display: flex; flex-direction: column; gap: 0.2rem; line-height: 1.2; }
.story__sign-meta strong { font-family: var(--serif); font-weight: 400; font-size: 1.05rem; }
.story__sign-meta small { font-size: 0.7rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--mute); }

/* decorative giant serif "II" or year behind story */
.story::before {
  content: '2026';
  position: absolute;
  top: 2rem;
  right: 2rem;
  font-family: var(--serif);
  font-size: clamp(7rem, 18vw, 18rem);
  color: rgba(176,134,66,0.06);
  letter-spacing: -0.04em;
  line-height: 0.8;
  pointer-events: none;
  user-select: none;
}

/* ===========================================================
   REVIEW CAROUSEL — real Airbnb quotes
   =========================================================== */
.review-deck {
  display: flex;
  gap: 1.5rem;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  overscroll-behavior-x: contain;
  padding: 0.5rem var(--gutter) 2rem;
  margin: 4rem calc(var(--gutter) * -1) 0;
  scrollbar-width: none;
}
.review-deck::-webkit-scrollbar { display: none; }

.review-card {
  flex: 0 0 min(86vw, 28rem);
  scroll-snap-align: center;
  background: rgba(250,248,243,0.04);
  border: 1px solid rgba(250,248,243,0.12);
  padding: 2rem 1.75rem 1.75rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  color: var(--paper);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: border-color 320ms ease, background 320ms ease, transform 320ms cubic-bezier(.22,.61,.36,1);
}
.review-card:hover {
  border-color: rgba(176,134,66,0.6);
  background: rgba(250,248,243,0.06);
  transform: translateY(-4px);
}
.review-card__stars {
  color: var(--gold);
  letter-spacing: 0.2em;
  font-size: 0.9rem;
}
.review-card__quote {
  font-family: var(--serif);
  font-style: italic;
  font-size: 1.05rem;
  line-height: 1.5;
  flex: 1;
  margin: 0;
  position: relative;
  padding-left: 0.5rem;
  color: var(--paper);
}
.review-card__quote::before {
  content: '“';
  position: absolute;
  top: -0.5rem; left: -0.6rem;
  font-size: 2.6rem;
  color: var(--gold);
  line-height: 1;
  font-style: normal;
}
.review-card__cite {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  padding-top: 1.25rem;
  border-top: 1px solid rgba(250,248,243,0.15);
  margin-top: 0.5rem;
}
.review-card__name {
  font-family: var(--serif);
  font-size: 1.1rem;
}
.review-card__where {
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(250,248,243,0.6);
}

/* drift the cards subtly on scroll-in (optional pulse) */
.review-deck { mask-image: linear-gradient(90deg, transparent, #000 4%, #000 96%, transparent); }

/* bottom stat strip for reviews */
.review-strip {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  margin-top: 4rem;
  padding-top: 3rem;
  border-top: 1px solid rgba(250,248,243,0.15);
}
@media (min-width: 800px) { .review-strip { grid-template-columns: repeat(5, 1fr); } }

/* override the legacy .review-grid stat style for the new .review-strip */
.review-strip .review-stat {
  padding: 1.25rem 1rem 0;
  border-right: 1px solid rgba(250,248,243,0.15);
  text-align: center;
}
.review-strip .review-stat:last-child { border-right: none; }

/* ===========================================================
   THE SPACE — verbatim 7-bullet section
   =========================================================== */
.the-space {
  padding: clamp(5rem, 10vw, 8rem) 0;
  background: var(--paper);
}
.space-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
}
@media (min-width: 700px) { .space-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .space-grid { grid-template-columns: repeat(3, 1fr); } }
.space-item {
  position: relative;
  padding: 2rem 1.75rem 1.75rem;
  background: var(--paper-2);
  border: 1px solid transparent;
  transition: background 280ms ease, border-color 280ms ease, transform 280ms cubic-bezier(.22,.61,.36,1);
}
.space-item:hover {
  background: var(--paper);
  border-color: var(--gold);
  transform: translateY(-3px);
}
.space-item__num {
  font-family: var(--serif);
  font-style: italic;
  color: var(--gold);
  font-size: 1.1rem;
  letter-spacing: 0.04em;
}
.space-item h3 {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.45rem;
  line-height: 1.2;
  margin: 0.75rem 0 0.75rem;
}
.space-item p {
  color: var(--ink-soft);
  font-size: 0.95rem;
  line-height: 1.6;
  margin: 0;
}
.space-item--wide { grid-column: 1 / -1; }
@media (min-width: 1100px) {
  .space-item--wide { grid-column: span 3; }
}

/* ===========================================================
   FLAT PICKER — choose your suite
   =========================================================== */
.flatpick {
  padding: clamp(5rem, 10vw, 8rem) 0;
  background: var(--paper-2);
}
.flatpick__head {
  max-width: var(--container);
  margin: 0 auto 3rem;
  padding: 0 var(--gutter);
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 2rem;
  flex-wrap: wrap;
}
.flatpick__head h2 { margin: 0.75rem 0 0; }
.flatpick__legend {
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--mute);
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}
.flatpick__legend span {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--gold);
  animation: pulse 2s ease-in-out infinite;
}

/* main stage: hero on left, details on right */
.flatpick__stage {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--gutter);
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
  margin-bottom: 2.5rem;
}
@media (min-width: 1024px) {
  .flatpick__stage { grid-template-columns: 1.5fr 1fr; gap: 3rem; }
}

.flatpick__hero {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--ink);
  cursor: pointer;
}
.flatpick__hero img {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  opacity: 0;
  transform: scale(1.04);
  transition: opacity 600ms ease, transform 1400ms cubic-bezier(.22,.61,.36,1);
}
.flatpick__hero img.is-active {
  opacity: 1;
  transform: scale(1);
}
.flatpick__hero img.is-active.is-fading {
  opacity: 0;
}
.flatpick__hero-tag {
  position: absolute;
  top: 1.25rem;
  left: 1.25rem;
  z-index: 3;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--serif);
  font-size: 1.1rem;
  padding: 0.6rem 1rem;
  letter-spacing: 0.08em;
}
.flatpick__hero-grad {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background: linear-gradient(180deg, transparent 50%, rgba(15,14,12,0.6) 100%);
}
.flatpick__hero-cta {
  position: absolute;
  right: 1.25rem;
  bottom: 1.25rem;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.7rem 1.1rem;
  color: var(--paper);
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  background: rgba(15,14,12,0.45);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(250,248,243,0.3);
  transition: background 320ms ease;
}
.flatpick__hero:hover .flatpick__hero-cta { background: var(--gold); border-color: var(--gold); }

/* details panel */
.flatpick__details {
  background: var(--paper);
  padding: 2rem 2rem 2rem;
  border: 1px solid var(--line);
  position: relative;
  overflow: hidden;
}
.flatpick__details::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 0;
  height: 2px;
  background: var(--gold);
  transition: width 600ms cubic-bezier(.22,.61,.36,1);
}
.flatpick__details.is-selected::before { width: 100%; }

.flatpick__code {
  font-size: 0.72rem;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--gold);
}
.flatpick__name {
  font-family: var(--serif);
  font-size: 1.85rem;
  line-height: 1.1;
  margin: 0.5rem 0 1rem;
  transition: opacity 320ms ease;
}
.flatpick__name.is-changing { opacity: 0; }
.flatpick__desc {
  color: var(--ink-soft);
  font-size: 0.94rem;
  line-height: 1.6;
  margin: 0 0 1.5rem;
  transition: opacity 320ms ease;
}
.flatpick__desc.is-changing { opacity: 0; }

.flatpick__chips {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  border-top: 1px solid var(--line);
  margin-bottom: 1.5rem;
}
.flatpick__chip {
  padding: 1rem 0;
  border-bottom: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
.flatpick__chip-label {
  font-size: 0.66rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--mute);
}
.flatpick__chip-value {
  font-family: var(--serif);
  font-size: 1.2rem;
  transition: opacity 280ms ease;
}
.flatpick__chip-value.is-changing { opacity: 0; }

.flatpick__cta {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  margin-top: 1.5rem;
}
.flatpick__cta .btn-magnetic { width: 100%; justify-content: center; }
.flatpick__hint {
  text-align: center;
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--mute);
  margin: 0;
}

/* expanded detail photos (shown only after click selection) */
.flatpick__expand {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--gutter);
  max-height: 0;
  overflow: hidden;
  transition: max-height 700ms cubic-bezier(.22,.61,.36,1), opacity 500ms ease, margin-bottom 500ms ease;
  opacity: 0;
}
.flatpick.is-expanded .flatpick__expand {
  max-height: 1000px;
  opacity: 1;
  margin-bottom: 3rem;
}
.flatpick__mini-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
  padding-top: 1.5rem;
}
@media (min-width: 700px) {
  .flatpick__mini-grid { grid-template-columns: repeat(4, 1fr); }
}
.flatpick__mini {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--ink);
}
.flatpick__mini img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1000ms cubic-bezier(.22,.61,.36,1);
}
.flatpick__mini:hover img { transform: scale(1.06); }

/* thumb row */
.flatpick__thumbs {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--gutter);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
}
@media (min-width: 700px)  { .flatpick__thumbs { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1100px) { .flatpick__thumbs { grid-template-columns: repeat(5, 1fr); gap: 1.25rem; } }

.flatpick__thumb {
  position: relative;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  cursor: pointer;
  background: var(--ink);
  border: 1px solid transparent;
  transition: border-color 300ms ease, transform 320ms cubic-bezier(.22,.61,.36,1);
  isolation: isolate;
}
.flatpick__thumb img {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  filter: brightness(0.78);
  transition: filter 380ms ease, transform 800ms cubic-bezier(.22,.61,.36,1);
}
.flatpick__thumb:hover img,
.flatpick__thumb.is-active img { filter: brightness(1); transform: scale(1.05); }
.flatpick__thumb:hover { transform: translateY(-4px); }
.flatpick__thumb.is-active {
  border-color: var(--gold);
}
.flatpick__thumb.is-active::after {
  content: '';
  position: absolute;
  inset: 0;
  border: 2px solid var(--gold);
  pointer-events: none;
  z-index: 2;
}
.flatpick__thumb-meta {
  position: absolute;
  left: 1rem;
  bottom: 0.85rem;
  z-index: 2;
  color: var(--paper);
}
.flatpick__thumb-code {
  font-size: 0.66rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  opacity: 0.8;
}
.flatpick__thumb-name {
  font-family: var(--serif);
  font-size: 1.15rem;
  line-height: 1.1;
  margin-top: 0.25rem;
}
.flatpick__thumb-badge {
  position: absolute;
  top: 0.85rem;
  right: 0.85rem;
  z-index: 2;
  background: var(--paper);
  color: var(--ink);
  font-size: 0.6rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 0.3rem 0.55rem;
  opacity: 0;
  transform: translateY(-6px);
  transition: opacity 300ms ease, transform 300ms cubic-bezier(.22,.61,.36,1);
}
.flatpick__thumb.is-active .flatpick__thumb-badge {
  opacity: 1;
  transform: none;
}
.flatpick__thumb::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(0deg, rgba(15,14,12,0.65), transparent 55%);
  pointer-events: none;
}

/* ===========================================================
   FLATS — Belarosa-style stacked swiper-per-flat
   =========================================================== */
.flats {
  padding: clamp(5rem, 10vw, 8rem) 0;
  background: var(--paper-2);
}
.flat-tabs {
  display: flex;
  gap: 0;
  overflow-x: auto;
  scrollbar-width: none;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  margin-top: 2.5rem;
}
.flat-tabs::-webkit-scrollbar { display: none; }
.flat-tab {
  display: inline-flex;
  flex: 0 0 auto;
  flex-direction: column;
  gap: 0.4rem;
  padding: 1.25rem 1.5rem;
  border-right: 1px solid var(--line);
  text-decoration: none;
  color: var(--ink-soft);
  min-width: 12rem;
  transition: background 280ms ease, color 280ms ease;
}
.flat-tab:last-child { border-right: none; }
.flat-tab:hover { background: var(--paper); color: var(--ink); }
.flat-tab.is-active { background: var(--ink); color: var(--paper); }
.flat-tab.is-active .flat-tab__num { color: var(--gold); }
.flat-tab__num {
  font-family: var(--serif);
  font-style: italic;
  font-size: 1rem;
  color: var(--gold);
}
.flat-tab__name {
  font-size: 0.82rem;
  letter-spacing: 0.04em;
  font-weight: 500;
}

.flat-stack {
  display: flex;
  flex-direction: column;
  gap: clamp(4rem, 8vw, 7rem);
}

.flat-block {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
  align-items: center;
  scroll-margin-top: 6rem;
}
@media (min-width: 960px) {
  .flat-block { grid-template-columns: 1.4fr 1fr; gap: 4rem; }
  .flat-block--reverse { grid-template-columns: 1fr 1.4fr; }
  .flat-block--reverse .flat-block__info { order: -1; }
}

.flat-block__gallery {
  position: relative;
  min-width: 0;
  overflow: hidden;
  width: 100%;
}
.flat-swiper {
  position: relative;
  width: 100%;
  min-width: 0;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--ink);
  cursor: grab;
}
.flat-swiper .swiper,
.flat-swiper .swiper-wrapper { height: 100%; will-change: transform; }
.flat-swiper .swiper-slide {
  width: 100%;
  height: 100%;
  display: flex;
}
.flat-swiper .swiper-slide img { display: block; }
.flat-swiper:active { cursor: grabbing; }
.flat-swiper .swiper-slide img {
  width: 100%; height: 100%;
  object-fit: cover;
  user-select: none;
  pointer-events: none;
  transition: transform 1200ms cubic-bezier(.22,.61,.36,1);
}
.flat-swiper .swiper-slide-active img { transform: scale(1.02); }

.flat-swiper__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 5;
  width: 52px; height: 52px;
  display: inline-flex;
  align-items: center; justify-content: center;
  border: none;
  border-radius: 50%;
  background: rgba(15,14,12,0.45);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  color: var(--paper);
  cursor: pointer;
  transition: background 320ms ease, transform 320ms cubic-bezier(.22,.61,.36,1);
}
.flat-swiper__arrow:hover { background: var(--gold); transform: translateY(-50%) scale(1.1); }
.flat-swiper__arrow:disabled { opacity: 0.3; pointer-events: none; }
.flat-swiper__arrow--prev { left: 1rem; }
.flat-swiper__arrow--next { right: 1rem; }

.flat-swiper__count {
  position: absolute;
  bottom: 1rem;
  left: 1rem;
  z-index: 5;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--serif);
  font-size: 0.9rem;
  padding: 0.4rem 0.85rem;
  letter-spacing: 0.04em;
  display: inline-flex;
}

.flat-swiper__pagination {
  position: absolute !important;
  bottom: 1rem !important;
  right: 1rem !important;
  left: auto !important;
  width: auto !important;
  z-index: 5;
  display: inline-flex;
  gap: 0.4rem;
}
.flat-swiper__pagination .swiper-pagination-bullet {
  width: 24px; height: 2px;
  border-radius: 0;
  background: rgba(250,248,243,0.5);
  opacity: 1;
  margin: 0 !important;
  transition: background 280ms ease, width 380ms cubic-bezier(.22,.61,.36,1);
}
.flat-swiper__pagination .swiper-pagination-bullet-active {
  background: var(--gold);
  width: 44px;
}

.flat-block__info {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.flat-block__info .eyebrow { color: var(--mute); }
.flat-block__name {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(1.8rem, 3.5vw, 2.75rem);
  line-height: 1.05;
  letter-spacing: -0.005em;
  margin: 0.75rem 0 0.4rem;
}
.flat-block__code {
  font-size: 0.72rem;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 0 1.5rem;
}
.flat-block__desc {
  color: var(--ink-soft);
  font-size: 1rem;
  line-height: 1.65;
  margin: 0 0 2rem;
  max-width: 32rem;
}
.flat-block__chips {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  border-top: 1px solid var(--line);
  margin-bottom: 2rem;
}
.flat-block__chip {
  padding: 1rem 0;
  border-bottom: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.flat-block__chip span {
  font-size: 0.66rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--mute);
}
.flat-block__chip strong {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.2rem;
}
.flat-block__cta { margin-top: 0.5rem; }

/* ===========================================================
   LIGHTBOX
   =========================================================== */
.lightbox {
  position: fixed;
  inset: 0;
  z-index: 200;
  background: rgba(15,14,12,0.96);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 4rem 2rem;
  opacity: 0;
  transition: opacity 320ms ease;
}
.lightbox.is-open {
  display: flex;
  opacity: 1;
}
.lightbox__img {
  max-width: 92vw;
  max-height: 86vh;
  object-fit: contain;
  box-shadow: 0 30px 60px -20px rgba(0,0,0,0.8);
  transform: scale(0.96);
  opacity: 0;
  transition: transform 520ms cubic-bezier(.22,.61,.36,1), opacity 320ms ease;
}
.lightbox.is-open .lightbox__img {
  transform: scale(1);
  opacity: 1;
}
.lightbox__close {
  position: absolute;
  top: 1.5rem; right: 1.5rem;
  width: 48px; height: 48px;
  background: rgba(250,248,243,0.08);
  border: 1px solid rgba(250,248,243,0.25);
  border-radius: 50%;
  color: var(--paper);
  cursor: pointer;
  display: inline-flex;
  align-items: center; justify-content: center;
  transition: background 250ms, transform 250ms;
}
.lightbox__close:hover { background: var(--gold); border-color: var(--gold); transform: rotate(90deg); }
.lightbox__caption {
  position: absolute;
  bottom: 1.5rem;
  color: rgba(250,248,243,0.7);
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

/* hide flat-picker old styles (now unused) */
.flatpick { display: none; }

/* ---------- hosts modal ---------- */
button.concierge {
  border: 0;
  font: inherit;
  font-family: var(--sans, inherit);
}

.hosts-modal {
  position: fixed;
  inset: 0;
  z-index: 220;
  background: rgba(15,14,12,0.72);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 2rem 1rem;
  opacity: 0;
  transition: opacity 280ms ease;
}
.hosts-modal.is-open { display: flex; opacity: 1; }

.hosts-modal__panel {
  position: relative;
  width: min(560px, 100%);
  max-height: 90vh;
  overflow-y: auto;
  scrollbar-gutter: stable;
  scrollbar-width: thin;
  scrollbar-color: rgba(15,14,12,0.25) transparent;
  background: var(--paper, #faf8f3);
  color: var(--ink, #0f0e0c);
  border-radius: 1.25rem;
  padding: 2.25rem 1.75rem 1.75rem;
  box-shadow: 0 40px 80px -20px rgba(0,0,0,0.55);
  transform: translateY(16px) scale(0.98);
  opacity: 0;
  transition: transform 420ms cubic-bezier(.22,.61,.36,1), opacity 280ms ease;
}
.hosts-modal.is-open .hosts-modal__panel {
  transform: translateY(0) scale(1);
  opacity: 1;
}

.hosts-modal__close {
  position: absolute;
  top: 0.85rem; right: 0.85rem;
  width: 38px; height: 38px;
  background: rgba(15,14,12,0.06);
  border: 1px solid rgba(15,14,12,0.1);
  border-radius: 50%;
  color: var(--ink);
  cursor: pointer;
  display: inline-flex;
  align-items: center; justify-content: center;
  transition: background 220ms, transform 220ms;
}
.hosts-modal__close:hover { background: var(--gold, #c9a35a); border-color: var(--gold, #c9a35a); transform: rotate(90deg); }

.hosts-modal__avatars {
  display: inline-flex;
  margin-bottom: 1rem;
}
.hosts-modal__avatars span {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  border: 3px solid var(--paper, #faf8f3);
  margin-left: -16px;
  background-size: cover;
  background-position: center;
  box-shadow: 0 6px 18px -6px rgba(0,0,0,0.25);
}
.hosts-modal__avatars span:first-child { margin-left: 0; }
.hosts-modal__avatars span:nth-child(1) { background-image: url('https://images.unsplash.com/photo-1494790108377-be9c29b29330?w=160&q=80&auto=format&fit=crop&crop=faces'); }
.hosts-modal__avatars span:nth-child(2) { background-image: url('https://images.unsplash.com/photo-1500648767791-00dcc994a43e?w=160&q=80&auto=format&fit=crop&crop=faces'); }

.hosts-modal__eyebrow {
  font-size: 0.68rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold-deep, #8a6d2e);
  margin: 0 0 0.4rem;
}
.hosts-modal__title {
  font-family: var(--serif, Georgia, serif);
  font-size: 1.55rem;
  line-height: 1.2;
  margin: 0 0 1rem;
  letter-spacing: -0.01em;
}
.hosts-modal__letter p {
  font-size: 0.96rem;
  line-height: 1.6;
  margin: 0 0 0.75rem;
  color: rgba(15,14,12,0.82);
}
.hosts-modal__sig {
  font-family: var(--serif, Georgia, serif);
  font-style: italic;
  color: var(--ink) !important;
  margin-top: 1rem !important;
}

.hosts-modal__picker { margin-top: 1.25rem; }
.hosts-modal__picker-q {
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(15,14,12,0.55);
  margin: 0 0 0.6rem;
}
.hosts-modal__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}
.hosts-chip {
  background: transparent;
  border: 1px solid rgba(15,14,12,0.18);
  border-radius: 999px;
  padding: 0.45rem 0.85rem;
  font-size: 0.8rem;
  letter-spacing: 0.02em;
  color: var(--ink);
  cursor: pointer;
  transition: background 180ms, border-color 180ms, color 180ms;
  font-family: inherit;
}
.hosts-chip:hover { border-color: var(--ink); }
.hosts-chip.is-active {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}

.hosts-modal__cta {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  margin-top: 1.5rem;
  padding: 0.9rem 1.4rem;
  background: var(--ink);
  color: var(--paper);
  border-radius: 999px;
  text-decoration: none;
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  transition: background 220ms, gap 220ms;
}
.hosts-modal__cta:hover {
  background: var(--gold-deep, #8a6d2e);
  gap: 0.85rem;
}

.hosts-modal__panel::-webkit-scrollbar { width: 6px; }
.hosts-modal__panel::-webkit-scrollbar-track { background: transparent; }
.hosts-modal__panel::-webkit-scrollbar-thumb {
  background: rgba(15,14,12,0.18);
  border-radius: 3px;
}
.hosts-modal__panel::-webkit-scrollbar-thumb:hover { background: rgba(15,14,12,0.32); }

@media (max-width: 480px) {
  .hosts-modal__panel { padding: 1.75rem 1.25rem 1.25rem; border-radius: 1rem; }
  .hosts-modal__title { font-size: 1.3rem; }
  .concierge {
    bottom: 1rem;
    right: 1rem;
    padding: 0.65rem 0.95rem 0.65rem 0.7rem;
    font-size: 0.68rem;
    letter-spacing: 0.14em;
    gap: 0.55rem;
  }
  .concierge__avatars span { width: 24px; height: 24px; margin-left: -8px; }
  .concierge__copy span { font-size: 0.7rem; }
  .concierge__copy small { font-size: 0.55rem; }
  .concierge__extra { display: none; }
}

/* lenis overrides — keep scroll feel smooth */
html.lenis, html.lenis body { height: auto; }
.lenis.lenis-smooth { scroll-behavior: auto !important; }
.lenis.lenis-smooth [data-lenis-prevent] { overscroll-behavior: contain; }
.lenis.lenis-stopped { overflow: clip; }

/* scroll-driven accent variable hookup */
:root { --accent-strength: 0; }
@supports (animation-timeline: scroll()) {
  body {
    animation: accentDrift linear both;
    animation-timeline: scroll();
  }
  @keyframes accentDrift {
    0%   { --accent-strength: 0; }
    50%  { --accent-strength: 1; }
    100% { --accent-strength: 0; }
  }
}

/* ===== Shared nav + footer additions ===== */

/* Nav primary CTA (replaces inline style="opacity:1; font-weight:500;") */
.nav__menu .nav__cta {
  font-weight: 500;
  opacity: 1;
}

/* Footer brand block (extracted from inline) */
.full-foot__brand-name { font-size: 1.6rem; }
.full-foot__blurb { line-height: 1.7; max-width: 24rem; margin: 0 0 1.25rem; }
.full-foot__contact { font-size: 0.85rem; }
.full-foot__email {
  color: var(--gold);
  padding: 0 !important;
  display: inline !important;
}

