:root {
  --ink: var(--bcr-ink);
  --forest: var(--bcr-forest);
  --sand: var(--bcr-sand);
  --paper: var(--bcr-paper);
  --gold: var(--bcr-gold);
  --ink-rgb: 22, 35, 29;
  --paper-rgb: 251, 250, 246;
  --line: rgba(var(--ink-rgb), 0.16);
  --serif: var(--bcr-display);
  --sans: var(--bcr-sans);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--paper); color: var(--ink); font-family: var(--sans); overflow-x: hidden; }
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
.skip-link { position: fixed; left: 1rem; top: -4rem; z-index: 20; background: var(--paper); padding: .8rem 1rem; }
.skip-link:focus { top: 1rem; }

.site-header {
  align-items: center; display: grid; grid-template-columns: 1fr auto 1fr; height: 84px;
  padding: 0 clamp(1.25rem, 4vw, 5rem); position: fixed; width: 100%; z-index: 10; color: var(--paper);
  background: linear-gradient(180deg, rgba(var(--ink-rgb), .74), rgba(var(--ink-rgb), .28));
  border-bottom: 1px solid rgba(var(--paper-rgb), .22); backdrop-filter: blur(16px) saturate(120%);
  transition: background .3s ease, height .3s ease, box-shadow .3s ease;
}
.site-header.scrolled { background: rgba(var(--ink-rgb), .9); box-shadow: 0 12px 35px rgba(var(--ink-rgb), .16); height: 76px; }
.bcr-logo {
  --display-size: clamp(3rem, 5.85vw, 6.75rem);
  --icon-size: clamp(4.625rem, 7.5vw, 8.75rem);
  --icon-gap: clamp(1rem, 1.75vw, 1.5rem);
  --sub-size: clamp(.84rem, 1.64vw, 1.875rem);
  --sub-shift: clamp(4.625rem, 9vw, 10.4rem);
  --sub-gap: clamp(.25rem, .45vw, .56rem);
  align-items: center;
  color: var(--paper);
  display: inline-flex;
  gap: var(--icon-gap);
  text-decoration: none;
}
.bcr-logo img { flex: 0 0 auto; height: var(--icon-size); transform: translateY(-.25rem); width: var(--icon-size); }
.bcr-logo span { display: grid; line-height: 1; }
.bcr-logo b { font-family: var(--serif); font-size: var(--display-size); font-style: italic; font-weight: 500; letter-spacing: -.065em; line-height: .82; text-transform: lowercase; white-space: nowrap; }
.bcr-logo em { font-family: var(--sans); font-size: var(--sub-size); font-style: normal; font-weight: 700; letter-spacing: .13em; margin-left: var(--sub-shift); margin-top: var(--sub-gap); text-transform: uppercase; white-space: nowrap; }
.bcr-logo--site {
  --display-size: 2.875rem;
  --icon-size: 3.625rem;
  --icon-gap: .875rem;
  --sub-size: .8125rem;
  --sub-shift: 4.4375rem;
  --sub-gap: .25rem;
}
.desktop-nav { display: flex; gap: clamp(1.7rem, 2.8vw, 3.35rem); font-size: .68rem; letter-spacing: .13em; text-transform: uppercase; }
.desktop-nav a, .site-footer nav a { transition: opacity .25s; }
.desktop-nav a:hover, .site-footer nav a:hover { opacity: .62; }
.site-header > .button { justify-self: end; }
.menu-toggle, .mobile-nav { display: none; }

.button {
  align-items: center; background: var(--forest); border: 1px solid var(--forest); color: var(--paper); display: inline-flex;
  font-size: .67rem; font-weight: 700; justify-content: center; letter-spacing: .13em; min-height: 52px;
  padding: .9rem 1.45rem; text-transform: uppercase; transition: background .25s, color .25s, transform .25s;
}
.button:hover { background: transparent; color: var(--forest); transform: translateY(-2px); }
.button-small { background: rgba(var(--paper-rgb), .12); border-color: rgba(var(--paper-rgb), .55); min-height: 42px; padding: .7rem 1.4rem; }
.button-small:hover, .button-light:hover { background: var(--paper); color: var(--forest); }
.button-light { background: var(--paper); border-color: var(--paper); color: var(--forest); }

.hero { align-items: end; display: flex; min-height: min(90svh, 980px); overflow: hidden; padding: 10rem clamp(1.25rem, 8vw, 9rem) clamp(4rem, 7vw, 6rem); position: relative; color: var(--paper); }
.hero-image, .hero-shade { height: 100%; inset: 0; position: absolute; width: 100%; }
.hero-image { object-fit: cover; object-position: center 60%; }
.hero-shade { background: linear-gradient(90deg, rgba(var(--ink-rgb), .86) 0%, rgba(var(--ink-rgb), .4) 56%, rgba(var(--ink-rgb), .12) 100%), linear-gradient(0deg, rgba(var(--ink-rgb), .46), transparent 55%); }
.hero-content { max-width: 910px; position: relative; z-index: 1; }
.eyebrow { align-items: center; display: flex; gap: .8rem; font-size: .65rem; font-weight: 700; letter-spacing: .2em; margin: 0 0 1.5rem; text-transform: uppercase; }
.eyebrow::before { background: var(--gold); content: ""; height: 1px; width: 36px; }
.eyebrow.light { color: rgba(var(--paper-rgb), .82); }
h1, h2, h3, p { margin-top: 0; }
h1, h2, h3 { font-family: var(--serif); font-weight: 500; text-wrap: balance; }
h1 { font-size: clamp(3.05rem, 7.2vw, 7.55rem); letter-spacing: -.055em; line-height: .94; margin-bottom: 2rem; }
h1 em, h2 em { color: var(--gold); font-weight: 500; }
.hero-content > p:not(.eyebrow) { font-size: clamp(.95rem, 1.35vw, 1.1rem); line-height: 1.85; margin-bottom: 2rem; max-width: 680px; }
.scroll-cue { align-items: center; bottom: 3rem; display: flex; font-size: .6rem; gap: .8rem; letter-spacing: .18em; position: absolute; right: clamp(1.25rem, 5vw, 5rem); text-transform: uppercase; z-index: 2; }
.scroll-cue span { border: 1px solid rgba(var(--paper-rgb), .5); border-radius: 50%; display: grid; height: 40px; place-content: center; width: 40px; }

.page-hero {
  --hero-pad: clamp(1.25rem, 7vw, 8rem);
  --hero-gap: clamp(2rem, 6vw, 6rem);
  align-items: center;
  background: var(--forest);
  color: var(--paper);
  display: grid;
  gap: var(--hero-gap);
  grid-template-columns: .86fr 1.14fr;
  min-height: min(88svh, 920px);
  overflow: hidden;
  padding: 9rem var(--hero-pad) 5rem;
}
.page-hero-wide {
  --hero-copy: clamp(30rem, 32vw, 34rem);
  --hero-gap: clamp(4rem, 5vw, 6rem);
  align-items: center;
  grid-template-columns: minmax(28rem, var(--hero-copy)) minmax(0, 54rem);
  justify-content: center;
  padding-left: clamp(2rem, 6vw, 7rem);
  padding-right: clamp(2rem, 6vw, 7rem);
}
.page-hero-copy { max-width: var(--hero-copy, 740px); min-width: 0; }
.page-hero-copy h1 { font-size: clamp(3rem, 4.85vw, 5.35rem); }
.page-hero-copy > p:not(.eyebrow) { color: rgba(var(--paper-rgb), .78); font-size: clamp(.98rem, 1.4vw, 1.15rem); line-height: 1.85; margin-bottom: 2rem; max-width: 640px; }
.page-hero-media { aspect-ratio: 16 / 9; min-height: 0; min-width: 0; position: relative; width: 100%; }
.page-hero-media::before { border: 1px solid rgba(var(--paper-rgb), .22); content: ""; inset: clamp(1rem, 2vw, 1.5rem) clamp(-.75rem, -1vw, -.5rem) clamp(-.75rem, -1vw, -.5rem) clamp(1rem, 2vw, 1.5rem); position: absolute; }
.page-hero-media img { height: 100%; object-fit: cover; position: absolute; width: 100%; }

.guide-index-hero {
  align-items: end;
  background: var(--forest);
  color: var(--paper);
  display: flex;
  min-height: 0;
  padding: 8.25rem clamp(1.25rem, 8vw, 9rem) 3.5rem;
}
.guide-index-hero > div { max-width: 760px; }
.guide-index-hero h1 { font-size: clamp(2.8rem, 4.8vw, 4.9rem); line-height: 1; margin-bottom: 1.4rem; }
.guide-index-hero p:not(.eyebrow) { color: rgba(var(--paper-rgb), .78); font-size: clamp(1rem, 1.35vw, 1.15rem); line-height: 1.8; max-width: 690px; }
.guide-index-section { background: var(--paper); padding: clamp(3.25rem, 6vw, 6rem) clamp(1.25rem, 7vw, 8rem); }
.guide-index-heading { max-width: 760px; }
.guide-index-heading span,
.guide-index-card span,
.guide-index-card b,
.guide-meta,
.guide-sidebar span {
  font-family: var(--sans);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.guide-index-heading span { color: var(--forest); display: block; margin-bottom: .9rem; }
.guide-index-heading h2 { font-size: clamp(1.85rem, 2.4vw, 2.65rem); line-height: 1.12; margin-bottom: .8rem; }
.guide-index-heading p { color: rgba(var(--ink-rgb), .72); font-size: .96rem; line-height: 1.75; margin-bottom: 0; }
.guide-index-grid { display: grid; gap: clamp(1rem, 2vw, 1.5rem); grid-template-columns: repeat(3, minmax(0, 1fr)); margin-top: clamp(2rem, 4vw, 3.5rem); }
.guide-index-card { background: var(--sand); border: 1px solid rgba(var(--ink-rgb), .12); min-height: 100%; transition: transform .25s ease; }
.guide-index-card:hover { transform: translateY(-3px); }
.guide-index-card a { display: grid; grid-template-rows: auto auto auto 1fr auto; height: 100%; }
.guide-index-card img { aspect-ratio: 16 / 10; height: auto; object-fit: cover; width: 100%; }
.guide-index-card span { color: var(--forest); padding: 1.15rem 1.15rem 0; }
.guide-index-card h3 { font-family: var(--sans); font-size: clamp(1rem, 1.2vw, 1.15rem); font-weight: 700; letter-spacing: 0; line-height: 1.35; margin: .55rem 1.15rem .75rem; }
.guide-index-card p { color: rgba(var(--ink-rgb), .72); font-size: .86rem; line-height: 1.65; margin: 0 1.15rem 1.15rem; }
.guide-index-card b { align-self: end; border-top: 1px solid rgba(var(--ink-rgb), .14); color: var(--forest); padding: .9rem 1.15rem 1rem; }
.guide-pagination { display: flex; flex-wrap: wrap; gap: .5rem; justify-content: center; margin-top: clamp(2rem, 4vw, 3.5rem); }
.guide-pagination a { border: 1px solid rgba(var(--ink-rgb), .2); display: grid; font-size: .8rem; font-weight: 700; height: 2.5rem; place-items: center; width: 2.5rem; }
.guide-pagination a[aria-current="page"] { background: var(--forest); border-color: var(--forest); color: var(--paper); }
.guide-article-hero {
  align-items: center;
  background: var(--forest);
  color: var(--paper);
  display: grid;
  gap: clamp(2.5rem, 5vw, 4.75rem);
  grid-template-columns: minmax(0, 1fr) minmax(24rem, .95fr);
  min-height: 0;
  padding: 8.5rem clamp(1.25rem, 7vw, 8rem) 3.75rem;
}
.guide-article-hero-copy { max-width: 700px; }
.guide-article-hero h1 { font-size: clamp(2.85rem, 4.25vw, 4.85rem); line-height: 1; margin-bottom: 1.45rem; }
.guide-article-hero-copy > p:not(.eyebrow) { color: rgba(var(--paper-rgb), .78); font-size: clamp(1rem, 1.35vw, 1.16rem); line-height: 1.8; margin-bottom: 2rem; max-width: 680px; }
.guide-meta { color: rgba(var(--paper-rgb), .72); display: flex; flex-wrap: wrap; gap: .75rem 1.2rem; }
.guide-meta span + span::before { color: var(--gold); content: "/"; margin-right: 1.2rem; }
.guide-article-hero-image { margin: 0; position: relative; }
.guide-article-hero-image::before {
  border: 1px solid rgba(var(--paper-rgb), .22);
  content: "";
  inset: 1.1rem -1rem -1rem 1.1rem;
  position: absolute;
}
.guide-article-hero-image img { aspect-ratio: 16 / 10; height: auto; object-fit: cover; position: relative; width: 100%; }
.guide-article-shell {
  align-items: start;
  background: var(--paper);
  display: grid;
  gap: clamp(2rem, 5vw, 5rem);
  grid-template-columns: minmax(13rem, 18rem) minmax(0, 760px);
  justify-content: center;
  padding: clamp(3.5rem, 8vw, 7rem) clamp(1.25rem, 6vw, 6rem);
}
.guide-sidebar {
  border-top: 1px solid var(--line);
  position: sticky;
  top: 7rem;
}
.guide-sidebar span { color: var(--forest); display: block; padding: 1rem 0; }
.guide-sidebar nav { border-top: 1px solid var(--line); display: grid; }
.guide-sidebar a { border-bottom: 1px solid var(--line); color: rgba(var(--ink-rgb), .72); font-size: .88rem; line-height: 1.45; padding: .85rem 0; transition: color .2s ease; }
.guide-sidebar a:hover { color: var(--ink); }
.guide-article-content { color: rgba(var(--ink-rgb), .82); font-size: clamp(1rem, 1.1vw, 1.08rem); line-height: 1.85; }
.guide-article-content > * + * { margin-top: 1.15rem; }
.guide-article-content h2,
.guide-article-content h3 { color: var(--ink); letter-spacing: 0; scroll-margin-top: 7rem; }
.guide-article-content h2 { font-size: clamp(2.05rem, 3vw, 3.05rem); line-height: 1.08; margin-top: clamp(3rem, 5vw, 4.75rem); }
.guide-article-content h3 { font-family: var(--sans); font-size: clamp(1.18rem, 1.55vw, 1.45rem); font-weight: 700; line-height: 1.35; margin-top: 2.2rem; }
.guide-article-content p { margin-bottom: 0; }
.guide-article-content a { border-bottom: 1px solid rgba(var(--ink-rgb), .35); color: var(--forest); font-weight: 700; }
.guide-article-content figure { margin: clamp(2rem, 4vw, 3.5rem) 0; }
.guide-article-content figure img { aspect-ratio: 16 / 9; object-fit: cover; width: 100%; }
.guide-final-cta h2 { max-width: 850px; }

.inquire-hero {
  align-items: center;
  background: var(--forest);
  color: var(--paper);
  display: grid;
  gap: clamp(2.5rem, 5vw, 5rem);
  grid-template-columns: minmax(0, .92fr) minmax(24rem, .78fr);
  min-height: min(82svh, 820px);
  padding: clamp(7.5rem, 12vw, 10rem) clamp(1.25rem, 7vw, 8rem) clamp(4rem, 7vw, 6rem);
}
.inquire-hero-copy {
  border-top: 1px solid rgba(var(--paper-rgb), .22);
  max-width: 48rem;
  padding-top: clamp(2rem, 4vw, 4rem);
}
.inquire-hero-copy h1 { font-size: clamp(3rem, 5.1vw, 5.75rem); }
.inquire-hero-copy > p:not(.eyebrow) {
  color: rgba(var(--paper-rgb), .78);
  font-size: clamp(1rem, 1.35vw, 1.15rem);
  line-height: 1.85;
  max-width: 660px;
}
.inquire-contact-panel {
  border: 1px solid rgba(var(--paper-rgb), .22);
  display: grid;
  gap: 1px;
  padding: clamp(.85rem, 1.5vw, 1.25rem);
  position: relative;
}
.inquire-contact-panel::before {
  border: 1px solid rgba(var(--paper-rgb), .12);
  content: "";
  inset: clamp(1rem, 2vw, 1.5rem) clamp(-.65rem, -1vw, -.5rem) clamp(-.65rem, -1vw, -.5rem) clamp(1rem, 2vw, 1.5rem);
  position: absolute;
}
.inquire-contact-panel > img {
  height: clamp(4.5rem, 8vw, 7rem);
  margin: clamp(1rem, 2vw, 1.5rem) auto;
  position: relative;
  width: clamp(4.5rem, 8vw, 7rem);
}
.inquire-contact-panel > div {
  background: var(--paper);
  color: var(--ink);
  display: grid;
  gap: .85rem;
  padding: clamp(1.35rem, 2.5vw, 2rem);
  position: relative;
}
.inquire-contact-panel span,
.inquire-details-grid span,
.inquire-fit-list span {
  color: var(--forest);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.inquire-contact-panel h2 {
  font-family: var(--sans);
  font-size: clamp(1.35rem, 2vw, 1.85rem);
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.18;
  margin-bottom: 0;
  overflow-wrap: anywhere;
}
.inquire-contact-panel p {
  color: rgba(var(--ink-rgb), .72);
  line-height: 1.7;
  margin-bottom: .35rem;
}
.inquire-contact-panel .button { justify-self: start; }
.inquire-details {
  background: var(--paper);
  display: grid;
  gap: clamp(2.5rem, 6vw, 6rem);
  grid-template-columns: minmax(12rem, .45fr) minmax(0, 1.55fr);
  padding: clamp(4rem, 8vw, 7rem) clamp(1.25rem, 7vw, 8rem);
}
.inquire-details-grid {
  display: grid;
  gap: 1px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.inquire-details-grid article {
  background: var(--sand);
  border-top: 1px solid rgba(var(--ink-rgb), .14);
  min-height: 270px;
  padding: clamp(1.4rem, 2.5vw, 2rem);
}
.inquire-details-grid h2 {
  font-family: var(--sans);
  font-size: clamp(1.2rem, 1.6vw, 1.45rem);
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.25;
  margin: 1.15rem 0 .8rem;
}
.inquire-details-grid p {
  color: rgba(var(--ink-rgb), .72);
  line-height: 1.75;
}
.inquire-fit {
  align-items: start;
  background: var(--ink);
  color: var(--paper);
  display: grid;
  gap: clamp(2.5rem, 6vw, 6rem);
  grid-template-columns: minmax(0, 1fr) minmax(21rem, .72fr);
  padding: clamp(4rem, 8vw, 7rem) clamp(1.25rem, 7vw, 8rem);
}
.inquire-fit-copy { max-width: 760px; }
.inquire-fit-copy h2 { font-size: clamp(2.45rem, 4vw, 4.35rem); }
.inquire-fit-copy p {
  color: rgba(var(--paper-rgb), .78);
  font-size: clamp(1rem, 1.25vw, 1.12rem);
  line-height: 1.85;
}
.inquire-fit-copy strong { color: var(--paper); }
.inquire-fit-list {
  border: 1px solid rgba(var(--paper-rgb), .2);
  padding: clamp(1.5rem, 3vw, 2.5rem);
}
.inquire-fit-list span { color: var(--gold); display: block; margin-bottom: 1.2rem; }
.inquire-fit-list ul { display: grid; gap: 1rem; list-style: none; margin: 0; padding: 0; }
.inquire-fit-list li {
  border-top: 1px solid rgba(var(--paper-rgb), .16);
  color: rgba(var(--paper-rgb), .78);
  line-height: 1.65;
  padding-top: 1rem;
}

.accommodation-hero {
  align-items: center;
  background: var(--forest);
  color: var(--paper);
  display: grid;
  gap: clamp(3.5rem, 5.5vw, 6rem);
  grid-template-columns: minmax(27rem, .46fr) minmax(0, .54fr);
  min-height: min(88svh, 920px);
  overflow: hidden;
  padding: clamp(6rem, 10vw, 9rem) clamp(2rem, 7vw, 8rem) clamp(4rem, 7vw, 6rem);
}
.accommodation-hero-copy {
  border-top: 1px solid rgba(var(--paper-rgb), .22);
  max-width: 38rem;
  min-width: 0;
  padding-top: clamp(2rem, 4vw, 4rem);
}
.accommodation-hero-copy h1 { font-size: clamp(3rem, 5.1vw, 5.75rem); }
.accommodation-hero-copy > p:not(.eyebrow) { color: rgba(var(--paper-rgb), .78); font-size: clamp(.98rem, 1.3vw, 1.15rem); line-height: 1.85; margin-bottom: 2rem; max-width: 640px; }
.accommodation-hero-frame { background: var(--sand); padding: clamp(1rem, 2vw, 1.8rem); }
.accommodation-hero-media { aspect-ratio: 4 / 3; border: 1px solid var(--sand); max-height: 700px; min-width: 0; position: relative; width: 100%; }
.accommodation-hero-media img { height: 100%; object-fit: cover; width: 100%; }

.transport-hero {
  align-items: center;
  background: var(--ink);
  color: var(--paper);
  display: grid;
  gap: clamp(3rem, 5vw, 5.5rem);
  grid-template-columns: minmax(28rem, .48fr) minmax(0, .52fr);
  min-height: min(90svh, 940px);
  overflow: hidden;
  padding: clamp(6rem, 10vw, 9rem) clamp(2rem, 7vw, 8rem) clamp(4rem, 7vw, 6rem);
}
.transport-hero-copy {
  border-top: 1px solid rgba(var(--paper-rgb), .22);
  max-width: 40rem;
  min-width: 0;
  padding-top: clamp(2rem, 4vw, 4rem);
}
.transport-hero-copy h1 { font-size: clamp(3rem, 5.1vw, 5.75rem); }
.transport-hero-copy > p:not(.eyebrow) { color: rgba(var(--paper-rgb), .78); font-size: clamp(.98rem, 1.3vw, 1.15rem); line-height: 1.85; margin-bottom: 2rem; max-width: 660px; }
.transport-hero-frame { aspect-ratio: 4 / 3; border: 1px solid rgba(var(--paper-rgb), .18); padding: clamp(.75rem, 1.35vw, 1.2rem); }
.transport-hero-frame img { height: 100%; object-fit: cover; width: 100%; }
.transport-hero--executive .transport-hero-frame img { object-position: center center; }

.section { padding: clamp(5rem, 10vw, 10rem) clamp(1.25rem, 7vw, 8rem); }
.intro { display: grid; gap: 8vw; grid-template-columns: .65fr 2fr; }
.section-kicker { border-top: 1px solid var(--line); display: flex; gap: 1.3rem; padding-top: 1rem; }
.section-kicker span { color: var(--gold); font-family: var(--serif); font-size: .8rem; }
.section-kicker p { font-size: .65rem; letter-spacing: .13em; line-height: 1.8; text-transform: uppercase; }
h2 { font-size: clamp(2.6rem, 5vw, 5.6rem); letter-spacing: -.05em; line-height: 1.02; margin-bottom: 2rem; }
.lead { color: rgba(var(--ink-rgb), .72); font-size: clamp(1rem, 1.4vw, 1.2rem); line-height: 1.85; max-width: 900px; }
.transport-intro { gap: clamp(2rem, 4vw, 4.5rem); grid-template-columns: .42fr .58fr; padding-bottom: clamp(3rem, 5vw, 5rem); padding-top: clamp(3.5rem, 6vw, 6rem); }
.transport-intro .intro-copy { max-width: 900px; }
.transport-intro h2 {
  font-family: var(--sans);
  font-size: clamp(1.85rem, 3.2vw, 3.65rem);
  font-weight: 600;
  letter-spacing: 0;
  line-height: 1.08;
  margin-bottom: 1.4rem;
}
.transport-intro .lead { font-size: clamp(.95rem, 1.08vw, 1.05rem); line-height: 1.75; max-width: 780px; }

.services { display: grid; grid-template-columns: repeat(3, 1fr); }
.service-card { min-height: 660px; overflow: hidden; position: relative; color: var(--paper); }
.service-card::after { background: linear-gradient(0deg, rgba(var(--ink-rgb), .92), rgba(var(--ink-rgb), 0) 65%); content: ""; inset: 0; position: absolute; }
.service-card img { height: 100%; object-fit: cover; position: absolute; transition: transform .7s ease; width: 100%; }
.service-card:nth-child(2) img { object-position: 53% center; }
.service-card:hover img { transform: scale(1.035); }
.service-card-content { bottom: 0; padding: clamp(1.5rem, 4vw, 3.5rem); position: absolute; z-index: 1; }
.service-card span, .guide-card span { color: var(--gold); font-size: .6rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; }
.service-card h3 { font-size: clamp(3rem, 5vw, 5rem); margin: .5rem 0 1rem; }
.service-card p { font-size: .82rem; line-height: 1.75; max-width: 390px; }
.service-card a, .text-link { border-bottom: 1px solid rgba(var(--paper-rgb), .5); display: flex; font-size: .62rem; font-weight: 700; justify-content: space-between; letter-spacing: .15em; margin-top: 1.8rem; padding-bottom: .8rem; text-transform: uppercase; }
.text-link-dark { border-color: var(--line); color: var(--forest); max-width: 340px; }

.transport-services { background: var(--ink); display: grid; gap: 1px; grid-template-columns: repeat(3, 1fr); }
.transport-service-card { background: var(--forest); color: var(--paper); min-height: 680px; overflow: hidden; position: relative; }
.transport-service-card::after { background: linear-gradient(0deg, rgba(var(--ink-rgb), .94), rgba(var(--ink-rgb), .2) 72%); content: ""; inset: 0; position: absolute; }
.transport-service-card img { height: 100%; object-fit: cover; position: absolute; transition: transform .7s ease; width: 100%; }
.transport-service-card:hover img { transform: scale(1.035); }
.transport-service-card > div { bottom: 0; padding: clamp(1.5rem, 3vw, 3rem); position: absolute; z-index: 1; }
.transport-service-card span, .vehicle-card span { color: var(--gold); font-size: .58rem; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; }
.transport-service-card h2 { font-family: var(--sans); font-size: clamp(1.75rem, 2.6vw, 3.1rem); font-weight: 600; letter-spacing: 0; line-height: 1.04; margin: .8rem 0 1rem; }
.transport-service-card p { color: rgba(var(--paper-rgb), .78); font-size: .82rem; line-height: 1.75; max-width: 420px; }
.transport-service-card a { border-bottom: 1px solid rgba(var(--paper-rgb), .5); display: flex; font-size: .62rem; font-weight: 700; justify-content: space-between; letter-spacing: .15em; margin-top: 1.8rem; max-width: 340px; padding-bottom: .8rem; text-transform: uppercase; }

.section-band { padding: 0 clamp(1.25rem, 4vw, 5rem) clamp(4rem, 7vw, 6rem); }
.stay-types { display: grid; gap: 1rem; grid-template-columns: repeat(4, 1fr); }
.stay-card { background: var(--forest); color: var(--paper); min-height: clamp(560px, 43vw, 640px); overflow: hidden; position: relative; }
.stay-card::after { background: linear-gradient(0deg, rgba(var(--ink-rgb), .92), rgba(var(--ink-rgb), .18) 70%); content: ""; inset: 0; position: absolute; }
.stay-card img { height: 100%; object-fit: cover; position: absolute; transition: transform .7s ease; width: 100%; }
.stay-card:nth-child(3) img { object-position: 62% center; }
.stay-card:hover img { transform: scale(1.035); }
.stay-card > div { bottom: 0; padding: clamp(1.35rem, 2.5vw, 2.2rem); position: absolute; z-index: 1; }
.stay-card span, .selection-row span, .location-list span { color: var(--gold); font-size: .58rem; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; }
.stay-card h2 { font-size: clamp(1.9rem, 2.7vw, 3rem); line-height: 1; margin: .7rem 0 1rem; }
.stay-card p { color: rgba(var(--paper-rgb), .78); font-size: .78rem; line-height: 1.75; margin-bottom: 0; }

.concierge { background: var(--forest); color: var(--paper); display: grid; gap: 3rem; grid-template-columns: 1.4fr .6fr; overflow: hidden; padding: clamp(5rem, 10vw, 10rem) clamp(1.25rem, 10vw, 12rem); }
.concierge-copy { max-width: 790px; }
.concierge-copy > p:not(.eyebrow), .special-copy > p:not(.eyebrow), .final-cta p { color: rgba(var(--paper-rgb), .74); line-height: 1.85; max-width: 660px; }
.concierge-art { align-items: center; display: flex; justify-content: center; opacity: .88; }
.concierge-mark { height: clamp(8rem, 14vw, 13.5rem); width: clamp(8rem, 14vw, 13.5rem); }
.homepage-concierge { gap: clamp(3rem, 7vw, 7rem); grid-template-columns: minmax(0, 1.35fr) minmax(22rem, .65fr); }
.homepage-concierge .concierge-copy { align-self: center; }
.concierge-mark-panel {
  align-self: center;
  border: 1px solid rgba(var(--paper-rgb), .18);
  display: grid;
  min-height: 360px;
  opacity: 1;
  place-items: center;
  position: relative;
}
.concierge-mark-panel::after {
  border: 1px solid rgba(213, 184, 117, .34);
  content: "";
  inset: 1rem -1rem -1rem 1rem;
  position: absolute;
}
.concierge-mark-panel .concierge-mark {
  height: clamp(10rem, 16vw, 16rem);
  position: relative;
  width: clamp(10rem, 16vw, 16rem);
  z-index: 1;
}

.section-heading { max-width: 800px; }
.testimonial-grid { display: grid; gap: 1px; grid-template-columns: repeat(3, 1fr); margin-top: 4rem; background: var(--line); border: 1px solid var(--line); }
blockquote { background: var(--paper); margin: 0; min-height: 340px; padding: clamp(1.8rem, 4vw, 3.5rem); }
blockquote > span { color: var(--gold); font-family: var(--serif); font-size: 4rem; line-height: .7; }
blockquote p { font-family: var(--serif); font-size: clamp(1.15rem, 1.8vw, 1.6rem); line-height: 1.55; margin: 2rem 0 3rem; }
blockquote footer { font-size: .68rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }
blockquote small { color: rgba(var(--ink-rgb), .55); display: block; font-size: .58rem; font-weight: 500; margin-top: .45rem; }

.why { display: grid; grid-template-columns: 1fr 1fr; background: var(--sand); }
.why-image { min-height: 780px; }
.why-image img { height: 100%; object-fit: cover; width: 100%; }
.why-copy { padding: clamp(4rem, 8vw, 9rem); }
.why ul { list-style: none; margin: 4rem 0 0; padding: 0; }
.why li { border-top: 1px solid var(--line); display: grid; gap: 1.2rem; grid-template-columns: 35px 1fr; padding: 1.5rem 0; }
.why li b { color: var(--gold); font-family: var(--serif); font-size: .75rem; }
.why li span { color: rgba(var(--ink-rgb), .72); font-size: .82rem; line-height: 1.7; }
.why li strong { color: var(--ink); font-weight: 700; }

.stay-selection { background: var(--paper); }
.selection-stack { display: grid; gap: clamp(2rem, 5vw, 5rem); margin-top: clamp(4rem, 7vw, 7rem); }
.selection-row { align-items: stretch; display: grid; gap: clamp(2.5rem, 5vw, 5.5rem); grid-template-columns: minmax(0, 1.15fr) minmax(380px, .85fr); }
.selection-row img { height: 100%; min-height: 500px; object-fit: cover; width: 100%; }
.selection-row > div { align-self: center; padding: clamp(1.75rem, 4vw, 4.25rem) 0; }
.selection-row h3 { font-size: clamp(2.35rem, 4vw, 4.15rem); letter-spacing: -.045em; line-height: 1; margin: .8rem 0 1.4rem; }
.selection-row p { color: rgba(var(--ink-rgb), .72); font-size: clamp(.95rem, 1.08vw, 1rem); line-height: 1.9; max-width: 720px; }
.selection-row:nth-child(even) img { order: 2; }
.selection-row:nth-child(even) { grid-template-columns: minmax(380px, .85fr) minmax(0, 1.15fr); }

.vehicle-section { background: var(--sand); }
.vehicle-grid { display: grid; gap: 1px; margin-top: clamp(3rem, 6vw, 5rem); background: var(--line); border: 1px solid var(--line); grid-template-columns: repeat(3, 1fr); }
.vehicle-card { background: var(--paper); min-height: 600px; padding: clamp(1.5rem, 3vw, 2.8rem); }
.vehicle-card h3 { font-size: clamp(1.55rem, 2.5vw, 2.7rem); line-height: 1.08; margin: .8rem 0 1rem; }
.vehicle-card p { color: rgba(var(--ink-rgb), .72); font-size: .88rem; line-height: 1.8; }
.vehicle-card ul { color: rgba(var(--ink-rgb), .74); display: grid; gap: .9rem; list-style: none; margin: 2rem 0 0; padding: 0; }
.vehicle-card li { border-top: 1px solid var(--line); font-size: .76rem; font-weight: 700; letter-spacing: .08em; line-height: 1.65; padding-top: .75rem; text-transform: uppercase; }

.transport-vehicles { background: var(--paper); }
.transport-vehicles .section-heading h2 { font-family: var(--sans); font-size: clamp(2rem, 3.6vw, 4.2rem); font-weight: 600; letter-spacing: 0; }
.transport-vehicle-stack { display: grid; gap: clamp(2rem, 4vw, 3.5rem); margin-top: clamp(2.5rem, 5vw, 4rem); }
.transport-vehicle-row { align-items: stretch; border-top: 1px solid var(--line); display: grid; gap: clamp(2rem, 4vw, 4rem); grid-template-columns: minmax(22rem, 1.06fr) minmax(0, .94fr); padding-top: clamp(2rem, 4vw, 3.5rem); }
.transport-vehicle-row:nth-child(even) { grid-template-columns: minmax(22rem, 1.06fr) minmax(0, .94fr); }
.transport-vehicle-row:nth-child(even) img { order: 0; }
.transport-vehicle-row img { aspect-ratio: 16 / 8.5; height: 100%; min-height: 360px; object-fit: cover; width: 100%; }
.transport-vehicle-row > div { align-self: center; padding-top: 0; }
.transport-vehicle-row span,
.transport-proof-grid span { color: var(--gold); display: block; font-size: .63rem; font-weight: 800; letter-spacing: .16em; margin-bottom: .85rem; text-transform: uppercase; }
.transport-vehicle-row h3 { font-family: var(--sans); font-size: clamp(1.55rem, 2.3vw, 2.7rem); font-weight: 600; letter-spacing: 0; line-height: 1.12; margin: 0 0 1rem; max-width: 760px; }
.transport-vehicle-row p { color: rgba(var(--ink-rgb), .72); line-height: 1.85; max-width: 720px; }
.transport-vehicle-row ul { color: var(--ink); display: grid; gap: .75rem; list-style: none; margin: 1.6rem 0 0; padding: 0; }
.transport-vehicle-row li { border-top: 1px solid var(--line); font-size: .78rem; font-weight: 800; letter-spacing: .08em; line-height: 1.6; padding-top: .75rem; text-transform: uppercase; }

.location-band { background: var(--ink); color: var(--paper); display: grid; gap: clamp(3rem, 8vw, 8rem); grid-template-columns: .82fr 1.18fr; padding: clamp(5rem, 10vw, 10rem) clamp(1.25rem, 8vw, 9rem); }
.location-copy { max-width: 760px; }
.location-copy p:not(.eyebrow) { color: rgba(var(--paper-rgb), .74); line-height: 1.85; }
.location-planner { align-self: center; display: grid; gap: 1px; grid-template-columns: repeat(2, 1fr); background: rgba(var(--paper-rgb), .18); border: 1px solid rgba(var(--paper-rgb), .18); }
.location-planner article { background: var(--ink); min-height: 250px; padding: clamp(1.5rem, 3vw, 3rem); }
.location-planner h3 { font-size: clamp(1.8rem, 2.6vw, 3rem); line-height: 1.05; margin: .8rem 0 1rem; }
.location-planner p { color: rgba(var(--paper-rgb), .72); line-height: 1.8; margin: 0; }
.location-list { display: grid; grid-column: 1 / -1; grid-template-columns: repeat(3, 1fr); }
.location-list span { background: var(--ink); border-top: 1px solid rgba(var(--paper-rgb), .18); color: var(--paper); padding: 1.2rem 1rem; }

.destination-stays-section {
  background: var(--ink);
  color: var(--paper);
  display: grid;
  gap: clamp(3rem, 7vw, 7rem);
  grid-template-columns: minmax(24rem, .5fr) minmax(0, .5fr);
  padding: clamp(5rem, 9vw, 9rem) clamp(1.25rem, 7vw, 8rem);
}
.destination-stays-copy { align-self: center; max-width: 760px; }
.destination-stays-copy > p:not(.eyebrow) {
  color: rgba(var(--paper-rgb), .74);
  font-size: clamp(1rem, 1.35vw, 1.16rem);
  line-height: 1.85;
  margin-bottom: 2rem;
  max-width: 820px;
}
.destination-index {
  align-self: center;
  display: grid;
  gap: 0 clamp(1.5rem, 3vw, 2rem);
  grid-template-columns: repeat(2, 1fr);
}
.destination-link {
  align-items: center;
  border-top: 1px solid rgba(var(--paper-rgb), .18);
  display: flex;
  font-size: .63rem;
  font-weight: 800;
  justify-content: space-between;
  letter-spacing: .14em;
  min-height: 72px;
  padding: 1rem 0;
  text-transform: uppercase;
}
.destination-link span:last-child { color: var(--gold); margin-left: 1rem; }

.trust-layout { display: grid; gap: clamp(3rem, 7vw, 7rem); grid-template-columns: minmax(25rem, .48fr) minmax(0, .52fr); }
.trust-feature { align-self: start; max-width: 760px; position: sticky; top: 8rem; }
.trust-feature .eyebrow { font-size: clamp(.74rem, 1vw, .86rem); letter-spacing: .14em; margin-bottom: 1.6rem; }
.trust-feature h2 { font-size: clamp(3rem, 5.6vw, 6.2rem); }
.trust-feature p:not(.eyebrow) { color: rgba(var(--ink-rgb), .72); font-size: clamp(1rem, 1.25vw, 1.12rem); line-height: 1.82; max-width: 720px; }
.trust-list { align-self: center; display: grid; }
.trust-list article { border-top: 1px solid var(--line); display: grid; gap: clamp(1.25rem, 2.5vw, 2rem); grid-template-columns: 4.5rem 1fr; padding: clamp(1.4rem, 2.8vw, 2.35rem) 0; }
.trust-list article:last-child { border-bottom: 1px solid var(--line); }
.trust-list b { color: var(--gold); font-family: var(--serif); font-size: clamp(2.25rem, 4vw, 4.4rem); font-weight: 500; line-height: .9; }
.trust-list span { color: var(--gold); display: block; font-size: .63rem; font-weight: 800; letter-spacing: .16em; margin-bottom: .7rem; text-transform: uppercase; }
.trust-list h3 { font-size: clamp(1.35rem, 2.2vw, 2.25rem); line-height: 1.08; margin: 0 0 .7rem; }
.trust-list p { color: rgba(var(--ink-rgb), .7); font-size: .9rem; line-height: 1.82; margin: 0; max-width: 620px; }

.transport-proof { background: var(--paper); }
.transport-proof--simple { background: var(--sand); }
.transport-proof--simple.section { padding-bottom: clamp(3.5rem, 6vw, 6rem); padding-top: clamp(3.5rem, 6vw, 6rem); }
.transport-proof-heading { align-items: end; display: grid; gap: clamp(1.5rem, 4vw, 4rem); grid-template-columns: .44fr .56fr; margin-bottom: clamp(2rem, 4vw, 3.5rem); }
.transport-proof-heading .eyebrow { font-size: clamp(.78rem, 1vw, .95rem); letter-spacing: .14em; margin: 0; }
.transport-proof-heading h2 { font-family: var(--sans); font-size: clamp(1.45rem, 2.1vw, 2.55rem); font-weight: 600; letter-spacing: 0; line-height: 1.18; margin: 0; max-width: 820px; }
.transport-proof-grid { border-bottom: 1px solid rgba(var(--ink-rgb), .18); border-top: 1px solid rgba(var(--ink-rgb), .18); display: grid; grid-template-columns: repeat(4, 1fr); }
.transport-proof-grid article { border-right: 1px solid rgba(var(--ink-rgb), .18); min-height: 190px; padding: clamp(1.35rem, 2.5vw, 2.1rem); }
.transport-proof-grid article:last-child { border-right: 0; }
.transport-proof-grid b { color: var(--gold); display: block; font-family: var(--sans); font-size: .76rem; font-weight: 800; letter-spacing: .14em; line-height: 1; margin-bottom: 1.4rem; }
.transport-proof-grid span { color: var(--ink); font-size: clamp(1rem, 1.28vw, 1.35rem); letter-spacing: 0; line-height: 1.18; margin-bottom: .75rem; text-transform: none; }
.transport-proof-grid p { color: rgba(var(--ink-rgb), .72); font-size: clamp(.9rem, 1vw, 1rem); line-height: 1.65; margin: 0; }

.transport-air-section {
  background: var(--ink);
  color: var(--paper);
  display: grid;
  gap: clamp(2rem, 5vw, 5rem);
  grid-template-columns: minmax(0, 1.08fr) minmax(25rem, .92fr);
  padding: clamp(2rem, 5vw, 5rem);
}
.transport-air-section img { height: 100%; min-height: 660px; object-fit: cover; width: 100%; }
.transport-air-copy { align-self: center; padding: clamp(2rem, 5vw, 5rem); }
.transport-air-copy h2 {
  font-family: var(--sans);
  font-size: clamp(2rem, 3.4vw, 4rem);
  font-weight: 600;
  letter-spacing: 0;
  line-height: 1.06;
}
.transport-air-copy > p:not(.eyebrow) { color: rgba(var(--paper-rgb), .74); line-height: 1.85; max-width: 660px; }

.experience-hero {
  align-items: center;
  background: var(--forest);
  color: var(--paper);
  display: grid;
  gap: clamp(3.5rem, 5.5vw, 6rem);
  grid-template-columns: minmax(27rem, .43fr) minmax(0, .57fr);
  min-height: min(88svh, 920px);
  overflow: hidden;
  padding: clamp(6rem, 10vw, 9rem) clamp(2rem, 7vw, 8rem) clamp(4rem, 7vw, 6rem);
}
.experience-hero-copy {
  border-top: 1px solid rgba(var(--paper-rgb), .22);
  max-width: 38rem;
  min-width: 0;
  padding-top: clamp(2rem, 4vw, 4rem);
}
.experience-hero-copy h1 { font-size: clamp(3rem, 5.1vw, 5.75rem); }
.experience-hero-copy > p:not(.eyebrow) { color: rgba(var(--paper-rgb), .78); font-size: clamp(.98rem, 1.3vw, 1.15rem); line-height: 1.85; margin-bottom: 2rem; max-width: 640px; }
.experience-hero-frame { border: 1px solid rgba(var(--paper-rgb), .2); padding: clamp(.75rem, 1.2vw, 1.1rem); }
.experience-hero-media { aspect-ratio: 16 / 10; border: 1px solid rgba(var(--paper-rgb), .14); max-height: 700px; min-width: 0; overflow: hidden; position: relative; width: 100%; }
.experience-hero-media img { height: 100%; object-fit: cover; width: 100%; }
.experience-memory-stack {
  aspect-ratio: 16 / 10;
  cursor: pointer;
  max-height: 700px;
  min-height: 420px;
  min-width: 0;
  position: relative;
  width: 100%;
}
.experience-memory-stack:focus-visible { outline: 2px solid var(--gold); outline-offset: .8rem; }
.experience-memory-photo {
  background:
    radial-gradient(circle at 18% 22%, rgba(var(--ink-rgb), .045), transparent 18%),
    radial-gradient(circle at 76% 34%, rgba(213, 184, 117, .1), transparent 16%),
    linear-gradient(135deg, rgba(var(--paper-rgb), .96), rgba(242, 237, 227, .96));
  box-shadow: 0 24px 70px rgba(var(--ink-rgb), .26);
  height: 100%;
  inset: 0;
  margin: 0;
  padding: clamp(.75rem, 1.35vw, 1.25rem) clamp(.75rem, 1.35vw, 1.25rem) clamp(1.25rem, 2vw, 2rem);
  position: absolute;
  transform-origin: 50% 75%;
  transition: transform .82s cubic-bezier(.2, .8, .2, 1), box-shadow .82s ease;
}
.experience-memory-photo::before {
  background-image:
    linear-gradient(90deg, rgba(var(--ink-rgb), .035) 1px, transparent 1px),
    linear-gradient(0deg, rgba(var(--ink-rgb), .03) 1px, transparent 1px);
  background-size: 9px 9px, 11px 11px;
  content: "";
  inset: 0;
  opacity: .45;
  pointer-events: none;
  position: absolute;
}
.experience-memory-photo::after {
  bottom: clamp(.35rem, .8vw, .75rem);
  color: rgba(var(--ink-rgb), .5);
  content: attr(data-caption);
  font-family: var(--sans);
  font-size: .56rem;
  font-weight: 800;
  left: clamp(.8rem, 1.5vw, 1.35rem);
  letter-spacing: .14em;
  position: absolute;
  text-transform: uppercase;
}
.experience-memory-photo img { height: 100%; object-fit: cover; position: relative; width: 100%; }
.experience-memory-photo--back-left { transform: translate3d(-1.4rem, 1.1rem, 0) rotate(-5deg); z-index: 1; }
.experience-memory-photo--back-right { transform: translate3d(1.3rem, .7rem, 0) rotate(4deg); z-index: 2; }
.experience-memory-photo--middle { transform: translate3d(.3rem, -.55rem, 0) rotate(-2deg); z-index: 3; }
.experience-memory-photo--top { box-shadow: 0 30px 80px rgba(var(--ink-rgb), .32); transform: translate3d(0, 0, 0) rotate(0deg); z-index: 4; }
.experience-memory-stack.is-loading .experience-memory-photo:nth-child(1) { animation: experiencePhotoDrop 1.45s cubic-bezier(.2, .8, .2, 1) .12s both; }
.experience-memory-stack.is-loading .experience-memory-photo:nth-child(2) { animation: experiencePhotoDrop 1.55s cubic-bezier(.2, .8, .2, 1) .55s both; }
.experience-memory-stack.is-loading .experience-memory-photo:nth-child(3) { animation: experiencePhotoDrop 1.6s cubic-bezier(.2, .8, .2, 1) .98s both; }
.experience-memory-stack.is-loading .experience-memory-photo:nth-child(4) { animation: experiencePhotoDrop 1.7s cubic-bezier(.2, .8, .2, 1) 1.42s both; }
@keyframes experiencePhotoDrop {
  0% { opacity: 0; transform: translate3d(0, -13rem, 0) rotate(10deg) scale(.94); }
  46% { opacity: 1; transform: translate3d(0, -2.6rem, 0) rotate(-3deg) scale(.98); }
  72% { opacity: 1; transform: translate3d(0, .95rem, 0) rotate(1.5deg) scale(1.01); }
  100% { opacity: 1; }
}
@media (prefers-reduced-motion: reduce) {
  .experience-memory-photo { animation: none !important; opacity: 1; transition: none; }
}

.experience-intro { background: var(--paper); padding-bottom: clamp(3rem, 5vw, 5rem); padding-top: clamp(3.5rem, 6vw, 6rem); }
.experience-intro h2 { font-size: clamp(2.15rem, 4vw, 4.5rem); max-width: 980px; }
.experience-intro .lead { max-width: 840px; }
.experience-intro .intro-copy > p:not(.eyebrow):not(.lead) { color: rgba(var(--ink-rgb), .68); line-height: 1.85; max-width: 860px; }

.experience-card-section { background: var(--ink); color: var(--paper); padding: clamp(4rem, 8vw, 8rem) clamp(1rem, 4vw, 4rem); }
.experience-card-heading { align-items: end; display: grid; gap: clamp(2rem, 5vw, 5rem); grid-template-columns: minmax(18rem, .34fr) minmax(0, .66fr); margin: 0 auto clamp(2rem, 4vw, 4rem); max-width: 1500px; }
.experience-card-heading h2 { font-size: clamp(2.4rem, 4.5vw, 5.3rem); line-height: 1.02; margin: 0; max-width: 980px; }
.experience-card-grid { display: grid; gap: 1px; grid-template-columns: repeat(4, 1fr); margin: 0 auto; max-width: 1600px; }
.experience-card { background: var(--forest); color: var(--paper); min-height: clamp(500px, 38vw, 620px); overflow: hidden; position: relative; }
.experience-card::after { background: linear-gradient(0deg, rgba(var(--ink-rgb), .94), rgba(var(--ink-rgb), .14) 74%); content: ""; inset: 0; position: absolute; }
.experience-card img { height: 100%; object-fit: cover; position: absolute; transition: transform .7s ease; width: 100%; }
.experience-card:hover img { transform: scale(1.035); }
.experience-card > div { bottom: 0; padding: clamp(1.2rem, 2.4vw, 2rem); position: absolute; z-index: 1; }
.experience-card span, .experience-detail-card span { color: var(--gold); display: block; font-size: .58rem; font-weight: 800; letter-spacing: .16em; margin-bottom: .75rem; text-transform: uppercase; }
.experience-card h3 { font-size: clamp(1.8rem, 2.55vw, 3rem); line-height: 1; margin: 0 0 .8rem; }
.experience-card p { color: rgba(var(--paper-rgb), .76); font-size: .78rem; line-height: 1.7; max-width: 390px; }
.experience-card a { border-bottom: 1px solid rgba(var(--paper-rgb), .48); display: flex; font-size: .58rem; font-weight: 800; justify-content: space-between; letter-spacing: .14em; margin-top: 1.4rem; max-width: 290px; padding-bottom: .7rem; text-transform: uppercase; }

.experience-catalog-section { background: var(--sand); color: var(--ink); padding: clamp(4rem, 7vw, 7rem) clamp(1.25rem, 6vw, 7rem); }
.experience-catalog-heading { align-items: end; display: grid; gap: clamp(1.5rem, 4vw, 4rem); grid-template-columns: minmax(0, .58fr) minmax(18rem, .42fr); margin: 0 auto clamp(2rem, 4vw, 3.5rem); max-width: 1480px; }
.experience-catalog-heading h2 { font-size: clamp(2.1rem, 3.7vw, 4.2rem); line-height: 1.04; margin: 0; max-width: 780px; }
.experience-catalog-heading > p { color: rgba(var(--ink-rgb), .68); font-size: .92rem; line-height: 1.8; margin: 0; }
.experience-popular-grid { display: grid; gap: 1rem; grid-template-columns: repeat(4, 1fr); margin: 0 auto; max-width: 1480px; }
.experience-popular-card { background: var(--paper); border: 1px solid var(--line); display: grid; grid-template-rows: auto 1fr; min-height: 0; }
.experience-popular-card img { aspect-ratio: 16 / 9.5; height: 100%; object-fit: cover; width: 100%; }
.experience-popular-card > div { display: flex; flex-direction: column; padding: clamp(1.1rem, 1.7vw, 1.55rem); }
.experience-popular-card span { color: var(--gold); display: block; font-size: .58rem; font-weight: 800; letter-spacing: .15em; margin-bottom: .5rem; text-transform: uppercase; }
.experience-popular-card h3 { font-family: var(--sans); font-size: clamp(1.05rem, 1.35vw, 1.35rem); font-weight: 700; letter-spacing: 0; line-height: 1.2; margin: 0 0 .65rem; }
.experience-popular-card p { color: rgba(var(--ink-rgb), .68); font-size: .8rem; line-height: 1.68; margin: 0; }
.experience-popular-card a { align-items: center; border-bottom: 1px solid rgba(var(--ink-rgb), .22); display: flex; font-size: .58rem; font-weight: 800; justify-content: space-between; letter-spacing: .14em; margin-top: auto; padding-top: 1rem; padding-bottom: .65rem; text-transform: uppercase; }

.experience-memory-band { background: var(--forest); color: var(--paper); padding: clamp(4rem, 8vw, 8rem) clamp(1rem, 4vw, 4rem); }
.experience-memory-copy { margin: 0 auto clamp(2.5rem, 5vw, 5rem); max-width: 1280px; }
.experience-memory-copy h2 { font-size: clamp(2.8rem, 5.5vw, 6.5rem); line-height: 1; margin: 0; max-width: 1100px; }
.experience-memory-gallery { display: grid; gap: .8rem; grid-template-columns: 1.1fr .9fr 1fr; margin: 0 auto; max-width: 1500px; min-height: 680px; }
.experience-memory-gallery figure { margin: 0; overflow: hidden; position: relative; }
.experience-memory-gallery figure:nth-child(2) { margin-top: 5rem; }
.experience-memory-gallery figure:nth-child(3) { margin-top: 2rem; }
.experience-memory-gallery figure::after { background: linear-gradient(0deg, rgba(var(--ink-rgb), .8), transparent 55%); content: ""; inset: 0; position: absolute; }
.experience-memory-gallery img { height: 100%; object-fit: cover; width: 100%; }
.experience-memory-gallery figcaption { bottom: 1.1rem; font-size: .58rem; font-weight: 800; left: 1.1rem; letter-spacing: .16em; position: absolute; text-transform: uppercase; z-index: 1; }

.featured-experience-section { background: var(--paper); display: grid; gap: clamp(2rem, 4vw, 3.5rem); padding: clamp(4rem, 7vw, 7rem) clamp(1.25rem, 6vw, 7rem); }
.featured-experience { align-items: center; background: var(--sand); border: 1px solid var(--line); display: grid; gap: clamp(2rem, 4vw, 4rem); grid-template-columns: minmax(24rem, .54fr) minmax(0, .46fr); margin: 0 auto; max-width: 1540px; padding: clamp(1rem, 2vw, 1.6rem); width: 100%; }
.featured-experience--reverse { grid-template-columns: minmax(0, .46fr) minmax(24rem, .54fr); }
.featured-experience--reverse .featured-experience-media { order: 2; }
.featured-experience--reverse .featured-experience-copy { order: 1; }
.featured-experience-media { align-self: center; height: clamp(360px, 30vw, 440px); overflow: hidden; width: 100%; }
.featured-experience-media img { height: 100%; object-fit: cover; width: 100%; }
.featured-experience-copy { align-self: center; padding: clamp(1.5rem, 4vw, 4rem) clamp(1rem, 3vw, 3rem); }
.featured-experience-copy span { color: var(--gold); display: block; font-size: .62rem; font-weight: 800; letter-spacing: .16em; margin-bottom: .8rem; text-transform: uppercase; }
.featured-experience-copy h2 { font-size: clamp(2.25rem, 4vw, 4.35rem); line-height: 1.04; margin-bottom: 1.3rem; max-width: 760px; }
.featured-experience-copy > p:not(.eyebrow) { color: rgba(var(--ink-rgb), .72); font-size: clamp(.94rem, 1.05vw, 1.04rem); line-height: 1.85; max-width: 700px; }

.experience-details { background: var(--paper); }
.experience-detail-grid { display: grid; gap: clamp(2rem, 4vw, 4rem); margin-top: clamp(3rem, 6vw, 5rem); }
.experience-detail-card { align-items: stretch; border-top: 1px solid var(--line); display: grid; gap: clamp(2rem, 5vw, 5rem); grid-template-columns: minmax(22rem, .9fr) minmax(0, 1.1fr); padding-top: clamp(2rem, 4vw, 4rem); }
.experience-detail-card:nth-child(even) { grid-template-columns: minmax(0, 1.1fr) minmax(22rem, .9fr); }
.experience-detail-card:nth-child(even) img { order: 2; }
.experience-detail-card img { aspect-ratio: 16 / 10; height: 100%; min-height: 420px; object-fit: cover; width: 100%; }
.experience-detail-card > div { align-self: center; }
.experience-detail-card h3 { font-size: clamp(2.1rem, 3.6vw, 4rem); line-height: 1.02; margin: 0 0 1rem; max-width: 840px; }
.experience-detail-card p { color: rgba(var(--ink-rgb), .72); line-height: 1.82; max-width: 780px; }
.experience-detail-card .text-link { margin-top: 1.8rem; }

.experiences-final-cta .final-cta-bg {
  background-image: linear-gradient(rgba(var(--ink-rgb), .36), rgba(var(--ink-rgb), .78)), url("../assets/images/costa-rica-experiences-final-volcano.webp");
}
.experiences-final-cta { min-height: 620px; text-align: center; }
.experiences-final-cta .final-cta-bg {
  background-image: linear-gradient(rgba(var(--ink-rgb), .42), rgba(var(--ink-rgb), .78)), url("../assets/images/costa-rica-experiences-final-volcano.webp");
}
.experiences-final-cta > div:last-child { max-width: 900px; padding-left: 0; }
.experiences-final-cta .eyebrow { justify-content: center; }
.experiences-final-cta h2 { font-size: clamp(2.4rem, 4.8vw, 5.4rem); max-width: 980px; }
.experiences-final-cta p { margin-left: auto; margin-right: auto; }

.special { background: var(--ink); color: var(--paper); display: grid; grid-template-columns: 1.1fr .9fr; padding: clamp(2rem, 5vw, 5rem); }
.special-gallery { display: grid; gap: .65rem; grid-template-columns: repeat(3, 1fr); grid-template-rows: 1.25fr .75fr; min-height: 700px; }
.special-gallery figure { margin: 0; overflow: hidden; position: relative; }
.special-gallery figure::after { background: linear-gradient(0deg, rgba(var(--ink-rgb), .84), transparent 55%); content: ""; inset: 0; position: absolute; }
.special-gallery .special-feature { grid-column: 1 / -1; }
.special-gallery img { height: 100%; object-fit: cover; transition: transform .6s ease; width: 100%; }
.special-gallery figure:hover img { transform: scale(1.025); }
.special-gallery figcaption { bottom: 1rem; font-size: .55rem; font-weight: 700; left: 1rem; letter-spacing: .16em; position: absolute; text-transform: uppercase; z-index: 1; }
.special-copy { align-self: center; padding: clamp(3rem, 8vw, 8rem); }
.text-link.light { max-width: 330px; }

.section-heading.split { align-items: end; display: grid; gap: 4rem; grid-template-columns: 1.3fr .7fr; max-width: none; }
.section-heading.split > p { color: rgba(var(--ink-rgb), .72); font-size: .9rem; line-height: 1.85; }
.guide-grid { display: grid; gap: 1rem; grid-template-columns: repeat(4, 1fr); margin-top: 4rem; }
.guide-card { background: var(--forest); color: var(--paper); min-height: 520px; overflow: hidden; position: relative; transition: transform .3s ease; }
.guide-card::after { background: linear-gradient(0deg, rgba(var(--ink-rgb), .95) 0%, rgba(var(--ink-rgb), .34) 75%); content: ""; inset: 0; position: absolute; }
.guide-card img { height: 100%; object-fit: cover; position: absolute; transition: transform .6s ease; width: 100%; }
.guide-card > div { bottom: 0; padding: 2rem; position: absolute; z-index: 1; }
.guide-card h3 { font-size: clamp(1.7rem, 2.4vw, 2.6rem); line-height: 1.1; margin: .9rem 0 1rem; }
.guide-card p { color: rgba(var(--paper-rgb), .74); font-size: .75rem; line-height: 1.75; }
.guide-card b { display: block; font-size: .58rem; letter-spacing: .16em; margin-top: 1.8rem; text-transform: uppercase; }
.guide-card:hover { transform: translateY(-5px); }
.guide-card:hover img { transform: scale(1.035); }

.faq-section { background: var(--sand); }
.faq-heading { align-items: end; display: grid; gap: clamp(2rem, 5vw, 5rem); grid-template-columns: minmax(0, 1fr) minmax(18rem, .62fr); margin-bottom: clamp(2rem, 4vw, 3.5rem); }
.faq-heading h2 { font-size: clamp(2.25rem, 4vw, 4rem); margin-bottom: 0; }
.faq-heading > p { color: rgba(var(--ink-rgb), .68); font-size: .86rem; line-height: 1.75; margin: 0; }
.faq-list { display: grid; gap: 1px; background: var(--line); border: 1px solid var(--line); }
.faq-list details { background: var(--paper); }
.faq-list summary { cursor: pointer; font-family: var(--sans); font-size: clamp(.92rem, 1.15vw, 1.05rem); font-weight: 700; line-height: 1.4; list-style: none; padding: 1rem clamp(1rem, 2.5vw, 2rem); }
.faq-list summary::-webkit-details-marker { display: none; }
.faq-list summary::after { color: var(--gold); content: "+"; float: right; font-family: var(--sans); font-size: 1rem; font-weight: 700; margin-left: 1rem; }
.faq-list details[open] summary::after { content: "-"; }
.faq-list p { color: rgba(var(--ink-rgb), .7); font-size: .84rem; line-height: 1.75; margin: 0; max-width: 920px; padding: 0 clamp(1rem, 2.5vw, 2rem) 1.1rem; }

.final-cta { align-items: center; color: var(--paper); display: flex; justify-content: center; min-height: 680px; padding: 5rem 1.25rem; position: relative; text-align: center; }
.final-cta-bg { background: linear-gradient(rgba(var(--ink-rgb), .5), rgba(var(--ink-rgb), .78)), url("../assets/images/replicate-prediction-kxt38dy4dxrmw0cy3v9s6gvqzw.webp") center/cover; inset: 0; position: absolute; }
.accommodation-cta {
  min-height: 720px;
  padding: clamp(5rem, 9vw, 8rem) clamp(1.25rem, 8vw, 9rem);
}
.accommodation-cta .final-cta-bg {
  background-image: linear-gradient(rgba(var(--ink-rgb), .25), rgba(var(--ink-rgb), .74)), url("../assets/images/costa-rica-tamarindo-luxury-villa-ocean-view-terrace.webp");
}
.accommodation-final-cta .final-cta-bg {
  background-image: linear-gradient(rgba(var(--ink-rgb), .54), rgba(var(--ink-rgb), .82)), url("../assets/images/costa-rica-luxury-stay-sunset-pool.webp");
}
.transportation-cta .final-cta-bg {
  background-image: linear-gradient(rgba(var(--ink-rgb), .5), rgba(var(--ink-rgb), .8)), url("../assets/images/costa-rica-destination-private-transfer-suv.webp");
}
.transportation-cta h2 {
  font-family: var(--sans);
  font-size: clamp(2.1rem, 4vw, 4.6rem);
  font-weight: 600;
  letter-spacing: 0;
  line-height: 1.06;
}
.final-cta > div:last-child { max-width: 900px; position: relative; }
.final-cta .eyebrow { justify-content: center; }
.final-cta p { margin-left: auto; margin-right: auto; }
.site-footer { align-items: center; background: var(--ink); color: var(--paper); display: grid; gap: 2rem; grid-template-columns: 1fr 1fr; padding: 4rem clamp(1.25rem, 7vw, 8rem); }
.bcr-logo--footer {
  --display-size: 4.125rem;
  --icon-size: 5.125rem;
  --icon-gap: 1.3125rem;
  --sub-size: 1.125rem;
  --sub-shift: 6.375rem;
  --sub-gap: .375rem;
}
.site-footer > p { color: rgba(var(--paper-rgb), .58); font-family: var(--serif); font-style: italic; justify-self: end; }
.site-footer nav { display: flex; flex-wrap: wrap; gap: 1.8rem; font-size: .59rem; letter-spacing: .15em; text-transform: uppercase; }
.site-footer small { color: rgba(var(--paper-rgb), .42); font-size: .55rem; justify-self: end; letter-spacing: .1em; text-transform: uppercase; }
.whatsapp { align-items: center; bottom: 1.2rem; display: inline-flex; gap: .55rem; position: fixed; right: 1.2rem; z-index: 12; }
.whatsapp-label { background: white; border-radius: 999px; box-shadow: 0 8px 24px rgba(37,211,102,.18); color: #4a4a4a; font-family: var(--sans); font-size: .82rem; font-weight: 700; line-height: 1; opacity: 0; padding: .62rem .85rem; transform: translateX(.5rem); transition: opacity .2s ease, transform .2s ease; white-space: nowrap; }
.whatsapp-icon { align-items: center; background: #25d366; border-radius: 50%; box-shadow: 0 10px 26px rgba(37,211,102,.34); display: grid; height: 54px; justify-content: center; transition: transform .25s ease; width: 54px; }
.whatsapp svg { fill: white; height: 30px; width: 30px; }
.whatsapp:hover .whatsapp-label { opacity: 1; transform: none; }
.whatsapp:hover .whatsapp-icon { transform: scale(1.05); }

.reveal { opacity: 0; transform: translateY(24px); transition: opacity .8s ease, transform .8s ease; }
.reveal.visible { opacity: 1; transform: none; }

@media (max-width: 1100px) {
  .desktop-nav { gap: 1rem; font-size: .59rem; }
}

@media (max-width: 980px) {
  .site-header { grid-template-columns: 1fr auto; height: 80px; }
  .desktop-nav, .site-header > .button { display: none; }
  .bcr-logo--site {
    --display-size: 2.6rem;
    --icon-size: 3.25rem;
    --icon-gap: .75rem;
    --sub-size: .72rem;
    --sub-shift: 4rem;
    --sub-gap: .25rem;
  }
  .menu-toggle { background: transparent; border: 0; display: grid; gap: 6px; padding: .7rem; }
  .menu-toggle span { background: var(--paper); display: block; height: 1px; width: 28px; }
  .mobile-nav { background: var(--ink); display: flex; flex-direction: column; gap: 1.5rem; left: 0; opacity: 0; padding: 7rem 2rem 3rem; pointer-events: none; position: absolute; top: 0; transform: translateY(-1rem); transition: .3s; width: 100%; z-index: -1; }
  .site-header.menu-open .mobile-nav { opacity: 1; pointer-events: auto; transform: none; }
  .page-hero, .accommodation-hero, .transport-hero, .experience-hero, .guide-article-hero, .guide-article-shell, .intro, .concierge, .why, .special, .location-band, .destination-stays-section, .transport-air-section, .inquire-hero, .inquire-details, .inquire-fit { grid-template-columns: 1fr; }
  .page-hero { padding-top: 8rem; }
  .page-hero-media { min-height: 500px; }
  .accommodation-hero { padding-top: 8rem; }
  .transport-hero { padding-top: 8rem; }
  .services { grid-template-columns: 1fr; }
  .service-card { min-height: 560px; }
  .transport-services { grid-template-columns: 1fr; }
  .transport-service-card { min-height: 560px; }
  .experience-hero-media, .experience-memory-stack { min-height: 520px; }
  .experience-card-heading, .experience-catalog-heading, .featured-experience, .experience-detail-card, .experience-detail-card:nth-child(even) { grid-template-columns: 1fr; }
  .experience-card-grid { grid-template-columns: repeat(2, 1fr); }
  .experience-popular-grid { grid-template-columns: repeat(2, 1fr); }
  .experience-memory-gallery { grid-template-columns: 1fr; min-height: 0; }
  .experience-memory-gallery figure { min-height: 520px; }
  .experience-memory-gallery figure:nth-child(2), .experience-memory-gallery figure:nth-child(3) { margin-top: 0; }
  .experience-detail-card:nth-child(even) img { order: 0; }
  .featured-experience-media { height: 420px; }
  .featured-experience--reverse .featured-experience-media,
  .featured-experience--reverse .featured-experience-copy { order: 0; }
  .guide-index-heading { grid-template-columns: 1fr; }
  .guide-index-grid { grid-template-columns: 1fr 1fr; }
  .guide-sidebar { position: static; }
  .guide-sidebar nav { grid-template-columns: 1fr 1fr; gap: 0 1.5rem; }
  .stay-types { grid-template-columns: 1fr 1fr; }
  .stay-card { min-height: 560px; }
  .selection-row, .selection-row:nth-child(even) { grid-template-columns: 1fr; }
  .selection-row:nth-child(even) img { order: 0; }
  .selection-row img { min-height: 460px; }
  .location-planner, .trust-layout, .faq-heading, .vehicle-grid, .transport-vehicle-row, .transport-vehicle-row:nth-child(even), .transport-proof-heading { grid-template-columns: 1fr; }
  .transport-vehicle-row:nth-child(even) img { order: 0; }
  .transport-proof-grid { grid-template-columns: 1fr 1fr; }
  .inquire-details-grid { grid-template-columns: 1fr; }
  .transport-proof-grid article:nth-child(2) { border-right: 0; }
  .transport-proof-grid article:nth-child(-n + 2) { border-bottom: 1px solid rgba(var(--ink-rgb), .18); }
  .location-list { grid-template-columns: 1fr 1fr; }
  .trust-feature { position: static; }
  .testimonial-grid { grid-template-columns: 1fr; }
  blockquote { min-height: 0; }
  .why-image { max-height: 620px; min-height: 500px; }
  .special-gallery { min-height: 620px; }
  .guide-grid { grid-template-columns: 1fr 1fr; }
  .site-footer { grid-template-columns: 1fr; }
  .site-footer > p, .site-footer small { justify-self: start; }
}

@media (max-width: 620px) {
  .hero { align-items: center; padding-top: 8rem; }
  h1 { font-size: clamp(2.85rem, 13.5vw, 4rem); letter-spacing: -.06em; }
  h2 { font-size: clamp(2.1rem, 9vw, 3.2rem); letter-spacing: -.045em; }
  .hero-content { min-width: 0; width: 100%; }
  .hero-content > p:not(.eyebrow) { font-size: .9rem; }
  .scroll-cue { display: none; }
  .section { padding: 5rem 1.25rem; }
  .intro { gap: 3rem; }
  .section-kicker { max-width: 220px; }
  .page-hero { gap: 2rem; padding: 7rem 1.25rem 1.25rem; }
  .page-hero-copy h1 { font-size: clamp(2.85rem, 13vw, 4rem); }
  .page-hero-media { min-height: 380px; }
  .page-hero-media::before { display: none; }
  .accommodation-hero { gap: 2rem; padding: 7rem 1.25rem 1.25rem; }
  .accommodation-hero-copy { padding-top: 2rem; }
  .accommodation-hero-copy h1 { font-size: clamp(2.85rem, 13vw, 4rem); }
  .accommodation-hero-frame { padding: .75rem; }
  .transport-hero { gap: 2rem; padding: 7rem 1.25rem 1.25rem; }
  .transport-hero-copy { padding-top: 2rem; }
  .transport-hero-copy h1 { font-size: clamp(2.85rem, 13vw, 4rem); }
  .transport-hero-frame { padding: .75rem; }
  .inquire-hero { gap: 2rem; min-height: 0; padding: 7rem 1.25rem 3rem; }
  .inquire-hero-copy { padding-top: 2rem; }
  .inquire-hero-copy h1 { font-size: clamp(2.85rem, 13vw, 4rem); }
  .inquire-contact-panel::before { display: none; }
  .inquire-details, .inquire-fit { padding: 4rem 1.25rem; }
  .inquire-details-grid article { min-height: 0; }
  .guide-index-hero { padding: 7rem 1.25rem 3rem; }
  .guide-index-hero h1 { font-size: clamp(2.45rem, 10vw, 3.35rem); }
  .guide-index-section { padding: 3.5rem 1.25rem; }
  .guide-index-heading h2 { font-size: clamp(1.65rem, 7vw, 2.15rem); }
  .guide-index-grid { grid-template-columns: 1fr; }
  .guide-article-hero { gap: 2rem; min-height: 0; padding: 7rem 1.25rem 1.25rem; }
  .guide-article-hero h1 { font-size: clamp(2.45rem, 10vw, 3.35rem); }
  .guide-article-hero-image::before { display: none; }
  .guide-article-shell { padding: 4rem 1.25rem; }
  .guide-sidebar nav { grid-template-columns: 1fr; }
  .guide-sidebar nav { max-height: 280px; overflow: auto; }
  .guide-article-content h2 { font-size: clamp(1.85rem, 8vw, 2.55rem); }
  .experience-hero-copy { padding-top: 2rem; }
  .experience-hero-copy h1 { font-size: clamp(3rem, 13vw, 4.4rem); }
  .experience-hero-media { min-height: 360px; }
  .experience-memory-stack { min-height: 330px; }
  .experience-memory-photo { padding-bottom: 1.35rem; }
  .experience-card-section { padding: 4rem 1.25rem; }
  .experience-card-grid { grid-template-columns: 1fr; }
  .experience-card { min-height: 470px; }
  .experience-catalog-section { padding: 4rem 1.25rem; }
  .experience-popular-grid { grid-template-columns: 1fr; }
  .experience-memory-band { padding: 4rem 1.25rem; }
  .experience-memory-copy h2 { font-size: clamp(2.25rem, 10vw, 3.4rem); }
  .experience-memory-gallery figure { min-height: 370px; }
  .featured-experience-section { padding: 4rem 1.25rem; }
  .featured-experience { gap: 0; padding: .75rem; }
  .featured-experience-media { height: 320px; }
  .featured-experience-copy { padding: 2rem 1rem; }
  .experiences-final-cta { min-height: 560px; padding: 4rem 1.25rem; }
  .experience-detail-card { gap: 1.5rem; }
  .experience-detail-card img { min-height: 320px; }
  .experience-detail-card h3 { font-size: clamp(2rem, 9vw, 3rem); }
  .concierge, .why-copy, .special-copy { padding: 4rem 1.25rem; }
  .concierge-art { display: none; }
  .section-band { padding: 0 1.25rem 5rem; }
  .stay-types, .location-planner, .location-list, .destination-index { grid-template-columns: 1fr; }
  .stay-card { min-height: 460px; }
  .transport-service-card { min-height: 480px; }
  .vehicle-card { min-height: 0; }
  .transport-vehicle-stack { gap: 3.5rem; margin-top: 3rem; }
  .transport-vehicle-row { gap: 1.5rem; }
  .transport-vehicle-row img { min-height: 300px; }
  .transport-vehicle-row h3 { font-size: clamp(2rem, 9vw, 3rem); }
  .transport-proof-grid { grid-template-columns: 1fr; }
  .transport-proof-grid article { border-bottom: 1px solid rgba(var(--ink-rgb), .18); border-right: 0; min-height: 0; }
  .transport-proof-grid article:last-child { border-bottom: 0; }
  .selection-stack { gap: 3rem; margin-top: 3rem; }
  .selection-row img { min-height: 330px; }
  .selection-row > div { padding: 0; }
  .location-band { padding: 4rem 1.25rem; }
  .destination-stays-section { padding: 4rem 1.25rem; }
  .transport-air-section { padding: 1.25rem; }
  .transport-air-section img { min-height: 340px; }
  .transport-air-copy { padding: 3rem 1rem; }
  .location-planner article { min-height: 0; padding: 2rem 1.25rem; }
  .trust-list article { grid-template-columns: 1fr; }
  .why-image { min-height: 390px; }
  .special { padding: 1.25rem; }
  .special-gallery { grid-template-rows: 1fr .7fr .7fr; min-height: 820px; }
  .special-gallery figure { grid-column: 1 / -1; }
  .section-heading.split { display: block; }
  .guide-grid { grid-template-columns: 1fr; }
  .guide-card { min-height: 450px; }
  .final-cta { min-height: 600px; }
  .site-footer nav { gap: 1rem; }
  .whatsapp { bottom: .75rem; right: .75rem; }
  .whatsapp-label { display: none; }
  .whatsapp-icon { height: 52px; width: 52px; }
}
