/* ═══════════════════════════════════════════════════════════════
   SAFA LOUNGE — صالة صفاء
   Premium Travel Hospitality · Design Option 01
   Brand: Deep Teal #396373 · Sage #95A185 · Charcoal #252525
          Gold #C8A26F · Paper #F2F0EA  (Brand Guideline 2026)
   ═══════════════════════════════════════════════════════════════ */

:root {
  /* palette */
  --teal:       #396373;
  --teal-deep:  #2C4E5C;
  --teal-ink:   #1E3944;
  --sage:       #95A185;
  --sage-soft:  #B7BFA9;
  --gold:       #C8A26F;
  --maroon:     #6B2F2F;
  --ink:        #252525;
  --paper:      #F2F0EA;
  --paper-2:    #E9E6DC;
  --cream:      #FAF9F5;
  --line:       rgba(37, 57, 68, 0.14);
  --line-light: rgba(250, 249, 245, 0.18);

  /* type */
  --font-display: "Marcellus", "Times New Roman", serif;
  --font-sans:    "Jost", "Helvetica Neue", sans-serif;
  --font-ar:      "Tajawal", sans-serif;
  --font-ar-cal:  "Amiri", serif;

  --fs-hero:  clamp(3rem, 9.2vw, 8.2rem);
  --fs-h2:    clamp(2.1rem, 5.4vw, 4.4rem);
  --fs-h3:    clamp(1.25rem, 2.2vw, 1.7rem);
  --fs-body:  clamp(1rem, 1.15vw, 1.125rem);
  --fs-small: 0.8125rem;

  /* motion */
  --ease-out:  cubic-bezier(0.22, 1, 0.36, 1);
  --ease-luxe: cubic-bezier(0.83, 0, 0.17, 1);
  --dur: 0.6s;

  /* layout */
  --gutter: clamp(1.25rem, 4vw, 4rem);
  --max: 90rem;

  /* pattern: interlocking circles (brand primary pattern) */
  --pattern-light: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='112' height='112' viewBox='0 0 112 112'%3E%3Cg fill='none' stroke='%23FAF9F5' stroke-opacity='0.10'%3E%3Ccircle cx='56' cy='56' r='46'/%3E%3Ccircle cx='0' cy='56' r='46'/%3E%3Ccircle cx='112' cy='56' r='46'/%3E%3Ccircle cx='56' cy='0' r='46'/%3E%3Ccircle cx='56' cy='112' r='46'/%3E%3C/g%3E%3C/svg%3E");
  --pattern-dark: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='112' height='112' viewBox='0 0 112 112'%3E%3Cg fill='none' stroke='%23396373' stroke-opacity='0.10'%3E%3Ccircle cx='56' cy='56' r='46'/%3E%3Ccircle cx='0' cy='56' r='46'/%3E%3Ccircle cx='112' cy='56' r='46'/%3E%3Ccircle cx='56' cy='0' r='46'/%3E%3Ccircle cx='56' cy='112' r='46'/%3E%3C/g%3E%3C/svg%3E");
}

/* ── reset ─────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}
html.lenis { height: auto; scroll-behavior: auto; }
.lenis.lenis-smooth { scroll-behavior: auto !important; }

body {
  font-family: var(--font-sans);
  font-weight: 300;
  font-size: var(--fs-body);
  line-height: 1.65;
  color: var(--ink);
  background: var(--paper);
  -webkit-font-smoothing: antialiased;
  overflow-x: clip;
}

img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }
ul { list-style: none; }
i { font-style: normal; }
[lang="ar"] { font-family: var(--font-ar); }

::selection { background: var(--teal); color: var(--paper); }

::-webkit-scrollbar { width: 9px; }
::-webkit-scrollbar-track { background: var(--paper-2); }
::-webkit-scrollbar-thumb { background: var(--teal); border-radius: 0; }

.container {
  width: 100%;
  max-width: var(--max);
  margin-inline: auto;
  padding-inline: var(--gutter);
}

/* logo mark as recolorable mask */
.icon-mask {
  display: inline-block;
  width: 1em;
  aspect-ratio: 304 / 512;
  background: currentColor;
  -webkit-mask: url("../logo/icon.png") no-repeat center / contain;
          mask: url("../logo/icon.png") no-repeat center / contain;
}

/* eyebrow dash ornament */
.eyebrow-dash {
  display: inline-block;
  width: 2.25rem;
  height: 1px;
  background: currentColor;
  vertical-align: middle;
  margin-inline-end: 0.85rem;
  position: relative;
  top: -1px;
}
.eyebrow-dash::after {
  content: "";
  position: absolute;
  right: -2px;
  top: 50%;
  width: 5px;
  height: 5px;
  margin-top: -2.5px;
  background: currentColor;
  transform: rotate(45deg);
}

/* ═══ CURSOR (dot + trailing ring + label) ═════════════════── */
.cursor { position: fixed; inset: 0; z-index: 999; pointer-events: none; opacity: 0; transition: opacity .3s; }
body.cursor-on .cursor { opacity: 1; }

.cursor__dot {
  position: fixed;
  top: 0; left: 0;
  width: 7px; height: 7px;
  margin: -3.5px 0 0 -3.5px;
  border-radius: 50%;
  background: var(--gold);
  transition: opacity .25s, scale .35s var(--ease-out);
}
.cursor__ring {
  position: fixed;
  top: 0; left: 0;
  width: 38px; height: 38px;
  margin: -19px 0 0 -19px;
  border-radius: 50%;
  border: 1px solid color-mix(in srgb, var(--gold) 75%, transparent);
  display: grid;
  place-items: center;
  transition: width .5s var(--ease-out), height .5s var(--ease-out),
              margin .5s var(--ease-out), background-color .4s, border-color .4s;
}
body.cursor-hover .cursor__dot { scale: 0.4; }
body.cursor-hover .cursor__ring {
  width: 64px; height: 64px;
  margin: -32px 0 0 -32px;
  background: color-mix(in srgb, var(--gold) 18%, transparent);
  border-color: var(--gold);
  backdrop-filter: blur(1.5px);
}
.cursor__label {
  font-size: 0.58rem;
  font-weight: 500;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--paper);
  opacity: 0;
  transform: scale(0.6);
  transition: opacity .3s, transform .4s var(--ease-out);
  white-space: nowrap;
}
body.cursor-labeled .cursor__dot { opacity: 0; }
body.cursor-labeled .cursor__ring {
  width: 86px; height: 86px;
  margin: -43px 0 0 -43px;
  background: color-mix(in srgb, var(--teal-ink) 72%, transparent);
  border-color: color-mix(in srgb, var(--gold) 60%, transparent);
  backdrop-filter: blur(3px);
}
body.cursor-labeled .cursor__label { opacity: 1; transform: scale(1); }
@media (hover: none), (pointer: coarse) { .cursor { display: none; } }

/* ═══ LOADER ═══════════════════════════════════════════════── */
.loader {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  background:
    var(--pattern-light),
    linear-gradient(160deg, var(--teal) 0%, var(--teal-deep) 55%, var(--teal-ink) 100%);
  color: var(--paper);
  transition: transform 1s var(--ease-luxe), visibility 0s linear 1s;
}
.loader.is-done { transform: translateY(-101%); visibility: hidden; }

.loader__inner { text-align: center; }
.loader__mark { display: grid; place-items: center; }
.loader__icon {
  font-size: clamp(4.5rem, 12vh, 7.5rem);
  color: var(--paper);
  animation: loaderPulse 2.2s var(--ease-out) infinite;
}
@keyframes loaderPulse {
  0%, 100% { opacity: 0.92; transform: translateY(0); }
  50%       { opacity: 1;    transform: translateY(-6px); }
}
.loader__name { margin-top: 1.5rem; display: grid; gap: 0.55rem; }
.loader__name [lang="ar"] { font-size: 1.5rem; font-weight: 400; letter-spacing: 0; }
.loader__name em {
  font-family: var(--font-display);
  font-style: normal;
  font-size: 0.95rem;
  letter-spacing: 0.55em;
  margin-right: -0.55em;
  color: var(--sage-soft);
}
.loader__foot {
  position: absolute;
  left: var(--gutter); right: var(--gutter); bottom: 2rem;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  border-top: 1px solid var(--line-light);
  padding-top: 1.1rem;
}
.loader__tag { font-size: var(--fs-small); letter-spacing: 0.3em; text-transform: uppercase; color: var(--sage-soft); }
.loader__count { font-family: var(--font-display); font-size: clamp(2rem, 5vw, 3.4rem); line-height: 1; }

/* ═══ NAV ══════════════════════════════════════════════════── */
.nav {
  position: fixed;
  inset-inline: 0;
  top: 0;
  z-index: 100;
  color: var(--paper);
  transition: transform .55s var(--ease-luxe), color .4s;
}
body[data-scroll-dir="down"] .nav { transform: translateY(-100%); }
.nav__progress {
  position: absolute;
  left: 0; right: 0; top: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--gold), var(--sage));
  transform: scaleX(0);
  transform-origin: left;
  z-index: 2;
}

.nav__bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
  padding: 1.1rem var(--gutter);
  transition: background-color .4s, box-shadow .4s, padding .4s;
}
.nav.is-solid { color: var(--teal-ink); }
.nav.is-solid .nav__bar {
  background: color-mix(in srgb, var(--paper) 92%, transparent);
  backdrop-filter: blur(12px);
  box-shadow: 0 1px 0 var(--line);
  padding-block: 0.8rem;
}

.nav__brand { display: flex; align-items: center; gap: 0.8rem; }
.nav__icon { font-size: 2.4rem; transition: color .4s; }
.nav__brand-text { display: grid; line-height: 1.25; }
.nav__brand-text strong {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 0.98rem;
  letter-spacing: 0.28em;
}
.nav__brand-text [lang="ar"] { font-size: 0.78rem; letter-spacing: 0.02em; opacity: 0.8; }

.nav__links { display: flex; gap: clamp(1.2rem, 2.5vw, 2.6rem); }
.nav__links a {
  font-size: 0.82rem;
  font-weight: 400;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  position: relative;
  padding-block: 0.35rem;
}
.nav__links a::after {
  content: "";
  position: absolute;
  left: 0; bottom: 0;
  width: 100%; height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: right;
  transition: transform .5s var(--ease-luxe);
}
.nav__links a:hover::after { transform: scaleX(1); transform-origin: left; }

.nav__actions { display: flex; align-items: center; gap: 1rem; }

.nav__burger {
  display: none;
  width: 44px; height: 44px;
  position: relative;
}
.nav__burger span {
  position: absolute;
  left: 10px; right: 10px;
  height: 1.5px;
  background: currentColor;
  transition: transform .45s var(--ease-luxe), top .45s var(--ease-luxe);
}
.nav__burger span:nth-child(1) { top: 18px; }
.nav__burger span:nth-child(2) { top: 26px; }
body.menu-open .nav__burger span:nth-child(1) { top: 22px; transform: rotate(45deg); }
body.menu-open .nav__burger span:nth-child(2) { top: 22px; transform: rotate(-45deg); }

/* ═══ MOBILE MENU ══════════════════════════════════════════── */
.menu {
  position: fixed;
  inset: 0;
  z-index: 90;
  background: linear-gradient(160deg, var(--teal) 0%, var(--teal-ink) 100%);
  color: var(--paper);
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(5rem, 14vh, 8rem) var(--gutter) 3rem;
  clip-path: inset(0 0 100% 0);
  visibility: hidden;
  transition: clip-path .8s var(--ease-luxe), visibility 0s linear .8s;
}
body.menu-open .menu { clip-path: inset(0 0 0% 0); visibility: visible; transition-delay: 0s; }
.menu__pattern { position: absolute; inset: 0; background: var(--pattern-light); pointer-events: none; }

.menu__links { display: grid; }
.menu__links a {
  display: flex;
  align-items: baseline;
  gap: 1.1rem;
  padding: 0.9rem 0;
  border-bottom: 1px solid var(--line-light);
  font-family: var(--font-display);
  font-size: clamp(1.7rem, 6.5vw, 3rem);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .6s var(--ease-out), transform .6s var(--ease-out);
}
body.menu-open .menu__links a { opacity: 1; transform: none; }
body.menu-open .menu__links a:nth-child(1) { transition-delay: .22s; }
body.menu-open .menu__links a:nth-child(2) { transition-delay: .30s; }
body.menu-open .menu__links a:nth-child(3) { transition-delay: .38s; }
body.menu-open .menu__links a:nth-child(4) { transition-delay: .46s; }
body.menu-open .menu__links a:nth-child(5) { transition-delay: .54s; }
.menu__links i { font-size: 0.8rem; font-family: var(--font-sans); color: var(--sage-soft); letter-spacing: 0.2em; }
.menu__links em { margin-left: auto; font-style: normal; font-size: 1.2rem; color: var(--sage-soft); }
.menu__foot { margin-top: 2.5rem; font-size: var(--fs-small); letter-spacing: 0.12em; opacity: 0.75; display: grid; gap: 0.3rem; }

/* ═══ BUTTONS ══════════════════════════════════════════════── */
.btn {
  --btn-bg: var(--teal);
  --btn-fg: var(--paper);
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.9rem;
  padding: 1.02rem 1.9rem;
  border-radius: 99px;
  background: var(--btn-bg);
  color: var(--btn-fg);
  font-size: 0.8rem;
  font-weight: 500;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  overflow: hidden;
  transition: background-color .45s var(--ease-out), color .45s var(--ease-out),
              border-color .45s var(--ease-out);
}
.btn__label { position: relative; display: inline-block; overflow: clip; }
.btn__label-in {
  position: relative;
  display: inline-block;
  transition: transform .5s var(--ease-luxe);
}
.btn__label-in::after {
  content: attr(data-btn-text);
  position: absolute;
  left: 0;
  top: 1.55em;
  white-space: nowrap;
}
.btn:hover .btn__label-in { transform: translateY(-1.55em); }

.btn__icon {
  display: grid;
  place-items: center;
  width: 1.5rem; height: 1.5rem;
  border-radius: 50%;
}
.btn__icon svg { width: 1rem; height: 1rem; transition: transform .5s var(--ease-luxe); }
.btn:hover .btn__icon svg { transform: translateX(4px); }

.btn--solid:hover { background: var(--gold); color: var(--teal-ink); }

.btn--ghost {
  --btn-bg: transparent;
  --btn-fg: var(--paper);
  box-shadow: inset 0 0 0 1px var(--line-light);
}
.btn--ghost:hover { background: var(--paper); color: var(--teal-ink); }

.btn--pill {
  --btn-bg: transparent;
  --btn-fg: currentColor;
  padding: 0.72rem 1.5rem;
  box-shadow: inset 0 0 0 1px currentColor;
}
.btn--pill:hover { background: var(--gold); color: var(--teal-ink); box-shadow: inset 0 0 0 1px var(--gold); }

.btn--lg { padding: 1.3rem 2.5rem; font-size: 0.9rem; }

.link-underline {
  display: inline-block;
  font-size: 0.82rem;
  font-weight: 500;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--teal);
  position: relative;
  padding-bottom: 0.5rem;
}
.link-underline::before,
.link-underline::after {
  content: "";
  position: absolute;
  left: 0; bottom: 0;
  width: 100%; height: 1.5px;
  background: currentColor;
  transform-origin: left;
  transition: transform .55s var(--ease-luxe) .25s;
}
.link-underline::after { transform: scaleX(0); transform-origin: right; transition-delay: 0s; }
.link-underline:hover::before { transform: scaleX(0); transform-origin: right; transition-delay: 0s; }
.link-underline:hover::after { transform: scaleX(1); transform-origin: left; transition-delay: .25s; }

/* ═══ SECTION HEAD ═════════════════════════════════════════── */
.section-head { position: relative; padding-block: clamp(4rem, 9vw, 7.5rem) clamp(2.5rem, 5vw, 4rem); }
.section-head__eyebrow {
  font-size: var(--fs-small);
  font-weight: 400;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--teal);
  margin-bottom: 1.6rem;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.35rem;
}
.section-head__eyebrow em { font-style: normal; color: var(--sage); font-size: 1rem; margin-inline-start: 0.5rem; letter-spacing: 0.1em; }
.section-head__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: var(--fs-h2);
  line-height: 1.06;
  text-transform: uppercase;
  letter-spacing: 0.015em;
  color: var(--teal-ink);
  max-width: 18ch;
}
.section-head__ghost {
  position: absolute;
  right: 0;
  bottom: 0;
  font-family: var(--font-ar-cal);
  font-size: clamp(6rem, 16vw, 15rem);
  line-height: 1;
  color: var(--teal);
  opacity: 0.06;
  pointer-events: none;
  user-select: none;
}
.section-head__note { max-width: 44ch; margin-top: 1.6rem; color: inherit; opacity: 0.8; }
.section-head--onDark .section-head__eyebrow { color: var(--sage-soft); }
.section-head--onDark .section-head__title { color: var(--paper); }

/* ═══ HERO ═════════════════════════════════════════════════── */
.hero {
  position: relative;
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  color: var(--paper);
  overflow: clip;
}
.hero__media {
  position: absolute;
  inset: -12% 0 0 0;
  z-index: -2;
}
.hero__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: 60% 65%;
  transform: scale(1.08);
}
.hero__tint {
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(180deg, rgba(30, 57, 68, 0.55) 0%, rgba(30, 57, 68, 0.18) 38%, rgba(30, 57, 68, 0.62) 78%, rgba(23, 44, 53, 0.86) 100%),
    linear-gradient(20deg, rgba(57, 99, 115, 0.55) 0%, rgba(57, 99, 115, 0.08) 55%);
}
.hero__ar {
  position: absolute;
  top: 14vh;
  right: clamp(1rem, 6vw, 6rem);
  z-index: 0;
  font-family: var(--font-ar-cal);
  font-size: clamp(8rem, 24vh, 17rem);
  line-height: 1;
  color: var(--paper);
  opacity: 0.12;
  pointer-events: none;
  user-select: none;
}

.hero__content {
  position: relative;
  z-index: 1;
  padding: 0 var(--gutter);
  margin-top: clamp(7rem, 18vh, 11rem);
  max-width: var(--max);
  width: 100%;
  margin-inline: auto;
}
.hero__eyebrow {
  font-size: var(--fs-small);
  font-weight: 400;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--sage-soft);
  margin-bottom: 1.8rem;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}
.hero__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: var(--fs-hero);
  line-height: 1.02;
  letter-spacing: 0.01em;
  text-transform: uppercase;
  text-wrap: balance;
}
.hero__sub {
  max-width: 46ch;
  margin-top: 1.9rem;
  font-size: clamp(1rem, 1.3vw, 1.2rem);
  font-weight: 300;
  color: color-mix(in srgb, var(--paper) 88%, transparent);
}
.hero__cta { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 2.6rem; }

.hero__stats {
  position: relative;
  margin-top: clamp(3rem, 7vh, 5.5rem);
  border-top: 1px solid var(--line-light);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  max-width: var(--max);
  width: calc(100% - 2 * var(--gutter));
  margin-inline: auto;
  padding-block: 1.6rem 2.1rem;
  gap: 1.5rem;
}
.hero__stat strong {
  display: block;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.7rem, 3.2vw, 2.7rem);
  line-height: 1.1;
}
.hero__stat strong i { color: var(--gold); }
.hero__stat > span {
  display: block;
  font-size: var(--fs-small);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--sage-soft);
}

.hero__scroll {
  position: absolute;
  right: var(--gutter);
  bottom: 2rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.7rem;
  font-size: 0.7rem;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  writing-mode: vertical-rl;
  color: var(--sage-soft);
}
.hero__scroll-line {
  width: 1px;
  height: 3.4rem;
  background: linear-gradient(to bottom, transparent, var(--paper));
  overflow: hidden;
  position: relative;
}
.hero__scroll-line::after {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--gold);
  transform: translateY(-100%);
  animation: scrollLine 2.2s var(--ease-luxe) infinite;
}
@keyframes scrollLine {
  0% { transform: translateY(-100%); }
  55% { transform: translateY(0); }
  100% { transform: translateY(100%); }
}

/* ═══ RIBBON ═══════════════════════════════════════════════── */
.ribbon {
  background: var(--teal-ink);
  color: var(--paper);
  overflow: clip;
  padding-block: 1.05rem;
  border-block: 1px solid rgba(250, 249, 245, 0.08);
}
.ribbon__track {
  display: flex;
  align-items: center;
  gap: 3.2rem;
  width: max-content;
  animation: marquee 26s linear infinite;
}
.ribbon__track span {
  font-family: var(--font-display);
  font-size: 1.05rem;
  letter-spacing: 0.34em;
  text-transform: uppercase;
  white-space: nowrap;
}
.ribbon__track span[lang="ar"] { font-family: var(--font-ar); font-weight: 400; font-size: 1.2rem; letter-spacing: 0; }
.ribbon__track .icon-mask { font-size: 1.5rem; color: var(--gold); flex: none; }
@keyframes marquee { to { transform: translateX(-50%); } }

/* ═══ INTRO ════════════════════════════════════════════════── */
.intro { padding-block: clamp(5rem, 11vw, 10rem); background: var(--paper); position: relative; }
.intro::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--pattern-dark);
  opacity: 0.35;
  pointer-events: none;
  mask-image: linear-gradient(to bottom, black, transparent 45%);
}
.intro__kicker {
  font-size: var(--fs-small);
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--teal);
  margin-bottom: clamp(2.5rem, 5vw, 4rem);
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.3rem;
}
.intro__kicker [lang="ar"] { font-size: 1.05rem; color: var(--sage); letter-spacing: 0.05em; }

.intro__lines { display: grid; gap: 0.4rem; }
.intro__line {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: clamp(0.8rem, 2vw, 1.6rem);
  font-family: var(--font-display);
  font-size: clamp(1.9rem, 5vw, 4.3rem);
  line-height: 1.12;
  text-transform: uppercase;
  letter-spacing: 0.015em;
  color: var(--teal-ink);
}
.intro__line:nth-child(2) { margin-inline-start: clamp(0rem, 6vw, 5rem); }
.intro__line:nth-child(3) { margin-inline-start: clamp(0rem, 2vw, 1.5rem); }
.intro__line:nth-child(4) { margin-inline-start: clamp(0rem, 9vw, 8rem); }

.intro__chip {
  flex: none;
  display: inline-block;
  width: clamp(4.6rem, 9vw, 8.2rem);
  aspect-ratio: 3 / 2;
  border-radius: 99px;
  overflow: hidden;
  position: relative;
  box-shadow: 0 10px 28px rgba(30, 57, 68, 0.18);
}
.intro__chip--tall { aspect-ratio: 1 / 1.15; border-radius: 99px 99px 12px 12px; width: clamp(4rem, 7vw, 6.4rem); }
.intro__chip img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s var(--ease-out); }
.intro__chip:hover img { transform: scale(1.12); }

/* ═══ EXPERIENCE (sticky parallax panels) ══════════════════── */
.experience { background: var(--paper-2); padding-bottom: 0; position: relative; }

.exp-stack { padding-bottom: clamp(4rem, 8vw, 7rem); }
.exp-panel {
  position: sticky;
  top: clamp(4.6rem, 9vh, 6.5rem);
  height: min(80svh, 46rem);
  border-radius: clamp(18px, 2vw, 30px);
  overflow: clip;
  margin-bottom: clamp(1.6rem, 4vh, 3rem);
  background: var(--teal-ink);
  color: var(--paper);
  box-shadow: 0 28px 70px rgba(20, 39, 48, 0.35);
  transform-origin: center top;
}
.exp-panel:last-child { margin-bottom: 0; }
.exp-panel__media { position: absolute; inset: 0; }
.exp-panel__media img {
  width: 100%;
  height: 124%;
  margin-top: -12%;
  object-fit: cover;
}
.exp-panel__dim {
  position: absolute;
  inset: 0;
  z-index: 2;
  background: var(--teal-ink);
  opacity: 0;
  pointer-events: none;
}
.exp-panel__scrim {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(200deg, rgba(30, 57, 68, 0.42) 0%, rgba(30, 57, 68, 0) 42%),
    linear-gradient(180deg, rgba(30, 57, 68, 0) 34%, rgba(23, 44, 53, 0.86) 100%);
}
.exp-panel__body {
  position: absolute;
  inset: 0;
  padding: clamp(1.4rem, 3.5vw, 3rem);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 0.7rem;
}
.exp-panel__no {
  position: absolute;
  top: clamp(1rem, 2.6vw, 2.2rem);
  left: clamp(1.4rem, 3.5vw, 3rem);
  font-family: var(--font-display);
  font-size: clamp(2.6rem, 6vw, 5rem);
  line-height: 1;
  color: transparent;
  -webkit-text-stroke: 1px color-mix(in srgb, var(--paper) 65%, transparent);
}
.exp-panel__ar {
  position: absolute;
  top: clamp(1.2rem, 2.8vw, 2.4rem);
  right: clamp(1.4rem, 3.5vw, 3rem);
  font-family: var(--font-ar-cal);
  font-size: clamp(1.6rem, 3.4vw, 2.8rem);
  color: color-mix(in srgb, var(--sage-soft) 85%, transparent);
}
.exp-panel__body h3 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.7rem, 4.2vw, 3.3rem);
  line-height: 1.05;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  max-width: 16ch;
}
.exp-panel__body > p {
  max-width: 52ch;
  font-size: clamp(0.95rem, 1.15vw, 1.08rem);
  color: color-mix(in srgb, var(--paper) 86%, transparent);
}
.exp-panel__tag {
  align-self: flex-start;
  margin-top: 0.5rem;
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  border: 1px solid var(--line-light);
  border-radius: 99px;
  padding: 0.42rem 1rem;
  background: color-mix(in srgb, var(--teal-ink) 55%, transparent);
}
.exp-panel__tag [lang="ar"] { letter-spacing: 0.05em; font-size: 0.85rem; }

/* amenities ticker */
.amenities {
  border-block: 1px solid var(--line);
  background: var(--paper);
  overflow: clip;
  padding-block: 1.3rem;
}
.amenities__track {
  display: flex;
  align-items: center;
  gap: 2.6rem;
  width: max-content;
  animation: marquee 38s linear infinite;
}
.amenities__track span {
  font-size: 0.85rem;
  font-weight: 400;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--teal);
  white-space: nowrap;
}
.amenities__track i { color: var(--gold); font-size: 0.6rem; }

/* ═══ JOURNEY ══════════════════════════════════════════════── */
.journey { background: var(--paper); }
.journey__pin { min-height: 100svh; display: flex; flex-direction: column; justify-content: center; overflow: clip; padding-block: clamp(2rem, 4vh, 4rem); }
.journey .section-head { padding-block: 0 clamp(2rem, 5vh, 3.5rem); width: 100%; }

.journey__viewport { width: 100%; }
.journey__track {
  display: flex;
  gap: clamp(1.5rem, 3vw, 3rem);
  width: max-content;
  padding-inline: var(--gutter);
  will-change: transform;
}
.j-panel {
  width: clamp(17rem, 30vw, 26rem);
  flex: none;
}
.j-panel__media {
  aspect-ratio: 4 / 5;
  overflow: clip;
  border-radius: 999px 999px 14px 14px;
  background: var(--teal-ink);
}
.j-panel:nth-child(even) .j-panel__media { border-radius: 14px; }
.j-panel__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 1s var(--ease-out); }
.j-panel:hover .j-panel__media img { transform: scale(1.05); }
.j-panel__body { padding-top: 1.3rem; display: grid; grid-template-columns: auto 1fr; gap: 0.2rem 1.1rem; align-items: baseline; }
.j-panel__no { font-family: var(--font-display); color: var(--gold); font-size: 1.05rem; }
.j-panel__body h3 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.5rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--teal-ink);
}
.j-panel__body p { grid-column: 2; color: color-mix(in srgb, var(--ink) 75%, transparent); font-size: 0.95rem; max-width: 30ch; }

.j-panel--end { display: grid; place-items: center; width: clamp(16rem, 28vw, 24rem); }
.j-panel__endcard {
  text-align: center;
  display: grid;
  gap: 1.1rem;
  justify-items: center;
  padding: 2.5rem;
  border: 1px solid var(--line);
  border-radius: 999px 999px 18px 18px;
  background: var(--paper-2);
  aspect-ratio: 4 / 5;
  width: 100%;
  align-content: center;
}
.j-panel__endcard .icon-mask { font-size: 3.2rem; color: var(--teal); }
.j-panel__endcard p[lang="ar"] { font-family: var(--font-ar-cal); font-size: 1.35rem; color: var(--teal); }
.j-panel__endcard p:last-child { font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.12em; font-size: 0.95rem; color: var(--teal-ink); }

.journey__progress {
  margin: clamp(2rem, 4vh, 3rem) var(--gutter) 0;
  height: 1px;
  background: var(--line);
  position: relative;
  overflow: hidden;
}
.journey__progress span {
  position: absolute;
  inset: 0;
  background: var(--teal);
  transform: scaleX(0);
  transform-origin: left;
}

/* ═══ VALUES ═══════════════════════════════════════════════── */
.values {
  position: relative;
  background: linear-gradient(165deg, var(--teal) 0%, var(--teal-deep) 50%, var(--teal-ink) 100%);
  color: var(--paper);
  padding-bottom: clamp(5rem, 10vw, 8rem);
}
.values__pattern {
  position: absolute; inset: 0;
  background: var(--pattern-light);
  mask-image: linear-gradient(to bottom, black, transparent 60%);
  pointer-events: none;
}

.values__list { border-top: 1px solid var(--line-light); }
.values__row { border-bottom: 1px solid var(--line-light); }
.values__head {
  width: 100%;
  display: grid;
  grid-template-columns: 3.2rem 1fr auto 3rem;
  align-items: center;
  gap: 1.2rem;
  padding-block: clamp(1.2rem, 2.6vw, 2rem);
  text-align: left;
  transition: opacity .4s, padding-inline-start .5s var(--ease-luxe);
}
.values__list:hover .values__row:not(:hover) .values__head { opacity: 0.45; }
.values__head:hover { padding-inline-start: 0.8rem; }

.values__no { font-family: var(--font-display); color: var(--gold); font-size: 0.95rem; }
.values__word {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.6rem, 4.2vw, 3.1rem);
  letter-spacing: 0.03em;
  text-transform: uppercase;
  line-height: 1.05;
}
.values__ar { font-size: clamp(1.1rem, 2.4vw, 1.7rem); color: var(--sage-soft); font-weight: 400; }
.values__plus { position: relative; width: 1.1rem; height: 1.1rem; justify-self: end; }
.values__plus::before, .values__plus::after {
  content: "";
  position: absolute;
  background: var(--sage-soft);
  transition: transform .5s var(--ease-luxe);
}
.values__plus::before { left: 0; right: 0; top: 50%; height: 1.5px; margin-top: -0.75px; }
.values__plus::after { top: 0; bottom: 0; left: 50%; width: 1.5px; margin-left: -0.75px; }
.values__head[aria-expanded="true"] .values__plus::after { transform: rotate(90deg) scaleY(0); }

.values__body {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows .6s var(--ease-luxe);
}
.values__body > p {
  overflow: hidden;
  max-width: 62ch;
  color: color-mix(in srgb, var(--paper) 78%, transparent);
  padding-inline-start: calc(3.2rem + 1.2rem);
}
.values__row.is-open .values__body { grid-template-rows: 1fr; }
.values__row.is-open .values__body > p { padding-bottom: clamp(1.4rem, 2.6vw, 2rem); }

/* ═══ VISION ═══════════════════════════════════════════════── */
.vision { background: var(--paper); padding-block: clamp(5rem, 10vw, 9rem); position: relative; }
.vision__grid {
  display: grid;
  grid-template-columns: minmax(0, 5fr) minmax(0, 6fr);
  gap: clamp(2.5rem, 6vw, 6rem);
  align-items: center;
}
.vision__media {
  position: relative;
  aspect-ratio: 4 / 5;
  overflow: clip;
  clip-path: url(#archClip);
}
.vision__media img { width: 100%; height: 110%; object-fit: cover; }
.vision__badge {
  position: absolute;
  left: 1.2rem; bottom: 1.2rem;
  background: color-mix(in srgb, var(--paper) 92%, transparent);
  backdrop-filter: blur(8px);
  color: var(--teal-ink);
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  line-height: 1.5;
  padding: 0.9rem 1.2rem;
  border-radius: 12px;
  display: flex;
  align-items: center;
  gap: 0.8rem;
}
.vision__badge .icon-mask { font-size: 1.9rem; color: var(--teal); }

.vision__quote {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.5rem, 3.1vw, 2.5rem);
  line-height: 1.28;
  color: var(--teal-ink);
  margin-block: 1.8rem 2rem;
  text-wrap: balance;
}
.vision__mission { max-width: 52ch; color: color-mix(in srgb, var(--ink) 80%, transparent); }
.vision__mission strong { color: var(--teal); font-weight: 500; }
.vision__tagline {
  margin-top: 2.4rem;
  padding-top: 1.6rem;
  border-top: 1px solid var(--line);
  display: flex;
  align-items: baseline;
  gap: 1.4rem;
  flex-wrap: wrap;
}
.vision__tagline [lang="ar"] { font-family: var(--font-ar-cal); font-size: clamp(1.5rem, 2.6vw, 2.1rem); color: var(--teal); }
.vision__tagline em { font-style: normal; font-size: 0.82rem; letter-spacing: 0.3em; text-transform: uppercase; color: var(--sage); }

/* guests strip */
.guests { margin-top: clamp(4rem, 8vw, 7rem); }
.guests__label {
  font-size: var(--fs-small);
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--teal);
  margin-bottom: 1.6rem;
}
.guests__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid var(--line);
  border-left: 1px solid var(--line);
}
.guests__card {
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 1.8rem 1.5rem 2.2rem;
  display: grid;
  gap: 2.6rem;
  align-content: space-between;
  transition: background-color .5s var(--ease-out), color .5s var(--ease-out);
}
.guests__card:hover { background: var(--teal); color: var(--paper); }
.guests__card i { font-family: var(--font-display); color: var(--gold); }
.guests__card p { font-family: var(--font-display); font-size: 1.1rem; line-height: 1.35; text-transform: uppercase; letter-spacing: 0.05em; }

/* ═══ GALLERY ══════════════════════════════════════════════── */
.gallery { background: var(--paper-2); padding-bottom: clamp(5rem, 10vw, 9rem); overflow: clip; }
.gallery__rows { display: grid; gap: clamp(1.5rem, 3vw, 2.5rem); }
.gallery__row {
  display: flex;
  gap: clamp(1.2rem, 2.5vw, 2.2rem);
  width: max-content;
  will-change: transform;
  padding-inline: var(--gutter);
}
.polaroid {
  flex: none;
  width: clamp(13rem, 22vw, 19rem);
  background: var(--cream);
  padding: 0.65rem 0.65rem 1rem;
  box-shadow: 0 18px 40px rgba(30, 57, 68, 0.14);
  transition: transform .6s var(--ease-out), box-shadow .6s var(--ease-out);
}
.gallery__row .polaroid:nth-child(4n-3) { rotate: 2.2deg; }
.gallery__row .polaroid:nth-child(4n-2) { rotate: -1.8deg; margin-top: 1.6rem; }
.gallery__row .polaroid:nth-child(4n-1) { rotate: 1.2deg; }
.gallery__row .polaroid:nth-child(4n)   { rotate: -2.4deg; margin-top: 1rem; }
.polaroid:hover { transform: translateY(-8px) rotate(0deg) scale(1.02); box-shadow: 0 26px 54px rgba(30, 57, 68, 0.22); z-index: 2; }
.polaroid img { aspect-ratio: 4 / 3; object-fit: cover; width: 100%; }
.polaroid figcaption {
  padding-top: 0.7rem;
  text-align: center;
  font-size: 0.72rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--teal);
}

/* ═══ FOOTER ═══════════════════════════════════════════════── */
.footer {
  position: relative;
  background: linear-gradient(170deg, var(--teal-deep) 0%, var(--teal-ink) 70%);
  color: var(--paper);
  padding-top: clamp(5rem, 11vw, 9rem);
  overflow: clip;
}
.footer__pattern {
  position: absolute; inset: 0;
  background: var(--pattern-light);
  mask-image: radial-gradient(120% 70% at 50% 0%, black, transparent 75%);
  pointer-events: none;
}
.footer__cta { text-align: center; display: grid; justify-items: center; gap: 1.4rem; position: relative; }
.footer__ar { font-family: var(--font-ar-cal); font-size: clamp(1.6rem, 3.4vw, 2.6rem); color: var(--sage-soft); }
.footer__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2.4rem, 7vw, 6rem);
  line-height: 1.04;
  text-transform: uppercase;
  letter-spacing: 0.01em;
}
.footer__cta .btn { margin-top: 1rem; }

.footer__info {
  margin-top: clamp(4rem, 9vw, 7rem);
  padding-block: clamp(2.5rem, 5vw, 4rem);
  border-top: 1px solid var(--line-light);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2.5rem;
  position: relative;
}
.footer__col h4 {
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 1.1rem;
}
.footer__col p { font-size: 0.95rem; color: color-mix(in srgb, var(--paper) 80%, transparent); margin-bottom: 0.6rem; }
.footer__nav { display: grid; gap: 0.55rem; justify-items: start; }
.footer__nav a {
  font-size: 0.9rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  opacity: 0.85;
  transition: opacity .3s, transform .4s var(--ease-out);
}
.footer__nav a:hover { opacity: 1; transform: translateX(6px); }
.footer__col--brand { display: grid; justify-items: end; align-content: start; }
.footer__logo { width: clamp(7rem, 10vw, 9.5rem); opacity: 0.95; }

.footer__base {
  border-top: 1px solid var(--line-light);
  padding-block: 1.6rem 2rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem 2.5rem;
  justify-content: space-between;
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  color: color-mix(in srgb, var(--paper) 62%, transparent);
  position: relative;
}

/* ═══ ANIM PRE-STATES (JS adds .anim-ready) ════════════════── */
.anim-ready [data-reveal] { opacity: 0; transform: translateY(34px); filter: blur(10px); }
.anim-ready [data-hero-fade] { opacity: 0; transform: translateY(26px); }
.anim-ready .w { display: inline-block; overflow: clip; vertical-align: bottom; padding-block: 0.08em; margin-block: -0.08em; }
.anim-ready .w-in { display: inline-block; transform: translateY(115%); will-change: transform; }
.anim-ready [data-intro-chip] { transform: scale(0); }

/* ═══ RESPONSIVE ═══════════════════════════════════════════── */
@media (max-width: 64em) {
  .about { grid-template-columns: 1fr; }
  .about__media { max-width: 26rem; }
  .guests__grid { grid-template-columns: repeat(2, 1fr); }
  .footer__info { grid-template-columns: repeat(2, 1fr); }
  .footer__col--brand { justify-items: start; grid-row: 1; grid-column: 2; }
  .vision__grid { grid-template-columns: 1fr; }
  .vision__media { max-width: 30rem; }
}

@media (max-width: 48em) {
  .nav__links { display: none; }
  .nav__cta { display: none; }
  .nav__burger { display: block; }

  .hero__stats { grid-template-columns: repeat(2, 1fr); gap: 1.2rem; }
  .hero__scroll { display: none; }
  .hero__ar { top: 10vh; opacity: 0.09; }

  .exp-panel { height: min(72svh, 34rem); top: 4.4rem; }
  .exp-panel__body h3 { max-width: 12ch; }
  .exp-panel__scrim {
    background:
      linear-gradient(200deg, rgba(30, 57, 68, 0.5) 0%, rgba(30, 57, 68, 0.08) 45%),
      linear-gradient(180deg, rgba(30, 57, 68, 0.05) 18%, rgba(23, 44, 53, 0.92) 78%);
  }
  .about__cols { grid-template-columns: 1fr; }

  /* journey: native horizontal scroll on touch */
  .journey__pin { min-height: 0; padding-block: clamp(3rem, 8vw, 5rem); }
  .journey__viewport { overflow-x: auto; scroll-snap-type: x mandatory; scrollbar-width: none; }
  .journey__viewport::-webkit-scrollbar { display: none; }
  .j-panel { scroll-snap-align: start; width: min(76vw, 22rem); }
  .journey__progress { display: none; }
  .journey .section-head { padding-top: 0; }

  .values__head { grid-template-columns: 2.2rem 1fr auto 2rem; gap: 0.8rem; }
  .values__body > p { padding-inline-start: 0; }

  .gallery__row { padding-inline: 1rem; }
}

@media (max-width: 30em) {
  .hero__cta .btn { width: 100%; justify-content: center; }
  .guests__grid { grid-template-columns: 1fr; }
  .footer__info { grid-template-columns: 1fr; }
  .footer__col--brand { grid-row: auto; grid-column: 1; justify-items: start; }
}


/* ═══ JOURNEY COUNTER ══════════════════════════════════════── */
.journey__counter {
  position: absolute;
  right: var(--gutter);
  bottom: clamp(2rem, 5vh, 3.5rem);
  display: flex;
  align-items: baseline;
  gap: 0.5rem;
  font-family: var(--font-display);
  color: var(--teal-ink);
}
.journey__counter span { font-size: clamp(2.4rem, 5vw, 4rem); line-height: 1; color: var(--teal); }
.journey__counter i { color: var(--gold); font-size: 1.3rem; }
.journey__counter b { font-weight: 400; font-size: 1rem; letter-spacing: 0.14em; color: var(--sage); }

/* ═══ UNVEIL (PINNED ZOOM) ═════════════════════════════════── */
.unveil { background: var(--paper-2); position: relative; }
.unveil__pin {
  height: 100svh;
  display: grid;
  place-items: center;
  overflow: clip;
  position: relative;
}
.unveil__media {
  position: relative;
  width: min(34vw, 30rem);
  height: min(58vh, 36rem);
  border-radius: 50vw 50vw 18px 18px;
  overflow: clip;
  will-change: width, height, border-radius;
}
.unveil__media img {
  width: 100%; height: 116%;
  object-fit: cover;
  will-change: transform;
}
.unveil__veil {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(30, 57, 68, 0.15) 0%, rgba(30, 57, 68, 0.66) 100%);
  opacity: 0;
}
.unveil__caption {
  position: absolute;
  z-index: 2;
  inset-inline: var(--gutter);
  bottom: clamp(3rem, 9vh, 6rem);
  text-align: center;
  color: var(--paper);
  display: grid;
  gap: 1rem;
  pointer-events: none;
}
.unveil__ar { font-family: var(--font-ar-cal); font-size: clamp(1.5rem, 3vw, 2.4rem); color: var(--sage-soft); }
.unveil__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2rem, 5.4vw, 4.6rem);
  line-height: 1.05;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  text-shadow: 0 2px 30px rgba(15, 30, 37, 0.4);
}
.anim-ready [data-unveil-fade] { opacity: 0; transform: translateY(30px); }

@media (max-width: 48em) {
  .unveil__pin { height: 78svh; }
  .unveil__media { width: 62vw; height: 46vh; }
}
html.static .unveil__pin { height: auto; padding-block: 4rem; }
html.static .unveil__caption { position: static; color: var(--teal-ink); margin-top: 2rem; text-shadow: none; }
html.static .unveil__ar { color: var(--teal); }

/* ═══ CHAR SPLIT (hero title) ══════════════════════════════── */
.ch { display: inline-block; white-space: pre; }
.anim-ready .hero__title .ch { will-change: transform, opacity; }

/* ═══ JS-DRIVEN MARQUEE (velocity reactive) ════════════════── */
.marquee-js { animation: none !important; }

/* ═══ HERO TILT DEPTH ══════════════════════════════════════── */
.hero { perspective: 1200px; }
.hero__content { transform-style: preserve-3d; will-change: transform; }


/* ═══ ABOUT (after manifesto) ══════════════════════════════── */
.about {
  margin-top: clamp(3.5rem, 7vw, 6rem);
  display: grid;
  grid-template-columns: minmax(0, 5fr) minmax(0, 7fr);
  gap: clamp(2.5rem, 6vw, 6rem);
  align-items: center;
  position: relative;
}
.about__media {
  position: relative;
  aspect-ratio: 4 / 5;
  overflow: clip;
  clip-path: url(#archClip);
}
.about__media img { width: 100%; height: 112%; object-fit: cover; }
.about__badge {
  position: absolute;
  left: 1.1rem; bottom: 1.1rem;
  display: flex;
  align-items: center;
  gap: 0.8rem;
  background: color-mix(in srgb, var(--paper) 92%, transparent);
  backdrop-filter: blur(8px);
  color: var(--teal-ink);
  font-size: 0.68rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  line-height: 1.55;
  padding: 0.85rem 1.15rem;
  border-radius: 12px;
}
.about__badge .icon-mask { font-size: 1.9rem; color: var(--teal); flex: none; }

.about__lead {
  font-family: var(--font-display);
  font-size: clamp(1.35rem, 2.4vw, 2rem);
  line-height: 1.42;
  color: var(--teal-ink);
  max-width: 30ch;
}
.about__lead strong { font-weight: 400; color: var(--teal); white-space: nowrap; }
.about__cols {
  margin-top: clamp(1.8rem, 3.5vw, 2.8rem);
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1.5rem, 3vw, 2.5rem);
}
.about__col h4 {
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--teal);
  margin-bottom: 0.8rem;
  display: flex;
  align-items: center;
}
.about__col h4 .eyebrow-dash { width: 1.4rem; margin-inline-end: 0.6rem; }
.about__col p { font-size: 0.95rem; color: color-mix(in srgb, var(--ink) 76%, transparent); max-width: 36ch; }
.about__chips {
  margin-top: clamp(1.8rem, 3.5vw, 2.6rem);
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
}
.about__chips li {
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--teal);
  border: 1px solid var(--line);
  border-radius: 99px;
  padding: 0.5rem 1.05rem;
  transition: background-color .4s var(--ease-out), color .4s var(--ease-out), border-color .4s;
}
.about__chips li:hover { background: var(--teal); border-color: var(--teal); color: var(--paper); }
.about .link-underline { margin-top: clamp(1.8rem, 3.5vw, 2.6rem); }

/* ═══ LIGHTBOX ═════════════════════════════════════════════── */
.lightbox {
  position: fixed;
  inset: 0;
  z-index: 160;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  padding: clamp(1rem, 3vw, 2.5rem);
  gap: clamp(0.6rem, 2vw, 1.5rem);
  opacity: 0;
  visibility: hidden;
  transition: opacity .45s var(--ease-out), visibility 0s linear .45s;
}
.lightbox.is-open { opacity: 1; visibility: visible; transition-delay: 0s; }
.lightbox__backdrop {
  position: absolute;
  inset: 0;
  background:
    var(--pattern-light),
    linear-gradient(165deg, color-mix(in srgb, var(--teal-deep) 96%, transparent), color-mix(in srgb, var(--teal-ink) 97%, transparent));
  backdrop-filter: blur(10px);
}
.lightbox__stage {
  position: relative;
  display: grid;
  justify-items: center;
  gap: 1rem;
  max-height: 100%;
}
.lightbox__stage img {
  max-width: min(82vw, 70rem);
  max-height: 76vh;
  width: auto;
  border-radius: 14px;
  box-shadow: 0 40px 110px rgba(10, 22, 28, 0.6);
  transform: scale(0.94);
  opacity: 0;
  transition: transform .6s var(--ease-out), opacity .5s;
}
.lightbox.is-open .lightbox__stage img { transform: scale(1); opacity: 1; }
.lightbox__meta {
  display: flex;
  align-items: baseline;
  gap: 1.4rem;
  color: var(--paper);
  font-size: 0.75rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
}
.lightbox__count { color: var(--sage-soft); font-family: var(--font-display); letter-spacing: 0.18em; }
.lightbox__btn {
  position: relative;
  z-index: 2;
  width: 52px; height: 52px;
  border-radius: 50%;
  border: 1px solid var(--line-light);
  color: var(--paper);
  display: grid;
  place-items: center;
  transition: background-color .35s, color .35s, border-color .35s, transform .35s var(--ease-out);
}
.lightbox__btn svg { width: 1.15rem; height: 1.15rem; }
.lightbox__btn:hover { background: var(--gold); border-color: var(--gold); color: var(--teal-ink); transform: scale(1.06); }
.lightbox__close { position: absolute; top: clamp(1rem, 3vw, 2rem); right: clamp(1rem, 3vw, 2rem); }
@media (max-width: 48em) {
  .lightbox { grid-template-columns: 1fr; }
  .lightbox__nav { position: fixed; bottom: 1.2rem; z-index: 3; }
  .lightbox__nav--prev { left: 1.2rem; }
  .lightbox__nav--next { right: 1.2rem; }
  .lightbox__stage img { max-width: 92vw; max-height: 66vh; }
}

/* ═══ STATIC SNAPSHOT MODE (?static=1 — dev/preview only) ══── */
html.static .hero { min-height: 820px; }
html.static .journey__pin { min-height: auto; }

/* ═══ REDUCED MOTION ═══════════════════════════════════════── */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation-duration: 0.001s !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001s !important;
  }
  .anim-ready [data-reveal],
  .anim-ready [data-hero-fade],
  .anim-ready [data-intro-chip],
  .anim-ready .w-in,
  .anim-ready [data-unveil-fade] {
    opacity: 1 !important;
    transform: none !important;
    scale: 1 !important;
    filter: none !important;
  }
}
