/** Shopify CDN: Minification failed

Line 237:10 Expected identifier but found whitespace
Line 237:11 Unexpected "clamp("

**/
/* ============================================================
   URA — Immersive Site
   Built on the locked URA token system (colors_and_type.css).
   This layer adds the cinematic / atmosphere behaviours.
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; }

html { -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }

body {
  margin: 0;
  background: var(--ura-warm-ivory);
  color: var(--fg);
  font-family: var(--font-body);
  overflow-x: hidden;
}

/* Quiet, custom selection */
::selection { background: var(--ura-bronze-soft); color: var(--ura-charcoal); }

/* Hide scrollbars but keep scroll (quiet luxury) */
.no-bar { scrollbar-width: none; }
.no-bar::-webkit-scrollbar { display: none; }

img { display: block; max-width: 100%; }
button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
a { color: inherit; text-decoration: none; }

/* ---------- App root ---------- */
#root { position: relative; }

/* ============================================================
   SPLASH
   slow ivory-on-ivory fade with the closed-top U breathing in
   ============================================================ */
.splash {
  position: fixed; inset: 0; z-index: 1000;
  background: var(--ura-warm-ivory);
  display: grid; place-items: center; overflow: hidden;
  transition: opacity 1100ms var(--ease-ura), visibility 1100ms;
}
.splash.is-gone { opacity: 0; visibility: hidden; pointer-events: none; }
.splash__line--ink { color: var(--fg-accent); }
.splash--intro .splash__video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0; transition: opacity 900ms var(--ease-ura); }
.splash--intro .splash__video.is-on { opacity: 1; }
.splash__veil { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(20,28,23,0.25), rgba(20,28,23,0.55)); z-index: 1; }
.splash__brand { position: relative; z-index: 2; display: grid; place-items: center; }
.splash__mark {
  width: 78px; opacity: 0;
  animation: splashBreathe 2600ms var(--ease-ura) forwards;
}
.splash__line {
  position: absolute; bottom: -22vh;
  font-family: var(--font-display); font-weight: 500;
  font-size: 10px; letter-spacing: var(--tracking-mega);
  text-transform: uppercase; color: var(--fg-inverse-soft);
  opacity: 0; animation: fadeUp 1400ms var(--ease-ura) 700ms forwards;
}
@keyframes splashBreathe {
  0%   { opacity: 0; transform: translateY(10px) scale(0.96); }
  40%  { opacity: 1; transform: translateY(0) scale(1); }
  100% { opacity: 1; transform: translateY(0) scale(1.02); }
}

/* ============================================================
   NAV
   the only blurred surface in the system
   ============================================================ */
/* ---- Floating luxury navigation object ---- */
.nav {
  position: fixed; z-index: 90;
  top: clamp(14px, 2vh, 22px);
  left: clamp(14px, 3vw, 44px); right: clamp(14px, 3vw, 44px);
  height: 64px; padding: 0 clamp(18px, 2vw, 28px);
  display: flex; align-items: center; justify-content: space-between;
  border-radius: 12px;
  background: rgba(242, 233, 223, 0.80);
  backdrop-filter: blur(22px) saturate(1.2);
  -webkit-backdrop-filter: blur(22px) saturate(1.2);
  border: 1px solid rgba(176, 141, 87, 0.22);
  box-shadow: 0 30px 70px -34px rgba(22, 22, 22, 0.4), 0 4px 18px -10px rgba(31,51,40,0.18), inset 0 1px 0 rgba(255,255,255,0.6);
  color: var(--ura-charcoal);
  overflow: visible;
  transition: background var(--dur-slow) var(--ease-ura), color var(--dur-slow) var(--ease-ura),
              border-color var(--dur-slow), box-shadow var(--dur-slow), top var(--dur-slow) var(--ease-ura),
              height var(--dur-slow) var(--ease-ura);
}
/* bronze micro-reflection along the top edge */
.nav::before {
  content: ""; position: absolute; top: 0; left: 14%; right: 14%; height: 1px;
  background: linear-gradient(90deg, transparent, var(--ura-bronze-soft), var(--ura-heritage-bronze), var(--ura-bronze-soft), transparent);
  opacity: 0.7; pointer-events: none; z-index: 3;
}
/* travelling sheen — retired for the pill nav (kept off so the language dropdown isn't clipped) */
.nav::after { content: none; }
.nav--solid {
  background: rgba(242, 233, 223, 0.93);
  border-color: var(--line);
  box-shadow: 0 24px 60px -38px rgba(22, 22, 22, 0.3), 0 3px 12px -8px rgba(31,51,40,0.12), inset 0 1px 0 rgba(255,255,255,0.7);
  height: 58px;
}
.nav__logo { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); display: inline-flex; align-items: center; z-index: 4; }
.nav__wordmark { height: 50px; width: auto; transition: height var(--dur-slow) var(--ease-ura); image-rendering: auto; -webkit-backface-visibility: hidden; backface-visibility: hidden; transform: translateZ(0); }
.nav--solid .nav__wordmark { height: 42px; }
@media (max-width: 560px) { .nav { height: 58px; } .nav__wordmark, .nav--solid .nav__wordmark { height: 36px; } }
.nav__left { display: flex; align-items: center; position: relative; z-index: 4; }
.nav__right { display: flex; align-items: center; gap: clamp(8px, 1vw, 14px); position: relative; z-index: 4; }
.nav__icon-btn {
  width: 38px; height: 38px; display: inline-grid; place-items: center; border-radius: 6px;
  transition: background var(--dur-base);
}
.nav__icon-btn:hover { background: rgba(22,22,22,0.05); }
.nav__icon { width: 17px; height: 17px; stroke: currentColor; stroke-width: 1.3; fill: none; opacity: 0.9; }
.nav__div { width: 1px; height: 24px; background: currentColor; opacity: 0.2; margin: 0 2px; }
.nav__menu-btn {
  display: inline-flex; align-items: center; gap: 12px; height: 38px; padding: 0 8px 0 14px;
  border-radius: 6px;
  font-family: var(--font-display); font-weight: 500;
  font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
  transition: background var(--dur-base);
}
.nav__menu-btn:hover { background: rgba(22,22,22,0.05); }
.nav__menu-word { opacity: 0.92; }
.nav__menu-icon { display: inline-flex; flex-direction: column; justify-content: center; gap: 5px; width: 22px; height: 22px; align-items: flex-end; }
.nav__menu-icon span {
  display: block; height: 1.4px; background: currentColor; border-radius: 2px;
  transition: width var(--dur-base) var(--ease-ura), transform var(--dur-base) var(--ease-ura);
}
.nav__menu-icon span:nth-child(1) { width: 22px; }
.nav__menu-icon span:nth-child(2) { width: 14px; }
.nav__menu-btn:hover .nav__menu-icon span:nth-child(2) { width: 22px; }
.nav__menu-btn:hover .nav__menu-icon span:nth-child(1) { width: 14px; }
@media (max-width: 560px) {
  .nav__menu-word { display: none; }
  .nav__menu-btn { padding: 0 8px; }
}

/* ---- pill navigation: inline links + tools + language ---- */
.nav__links { display: flex; align-items: center; gap: 2px; position: relative; z-index: 4; }
.nav__link {
  font-family: var(--font-display); font-weight: 500; font-size: 11px;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--ura-charcoal);
  padding: 9px 15px; border-radius: 999px; position: relative; white-space: nowrap;
  transition: background 460ms var(--ease-ura), color 360ms var(--ease-ura),
              letter-spacing 460ms var(--ease-ura), padding 460ms var(--ease-ura),
              box-shadow 460ms var(--ease-ura);
}
.nav__link:hover {
  background: rgba(176, 141, 87, 0.13); color: var(--ura-heritage-bronze);
  letter-spacing: 0.2em; padding: 9px 20px;
  box-shadow: 0 8px 22px -12px rgba(31, 51, 40, 0.4);
}
.nav__link--visual { color: var(--ura-heritage-bronze); }
.nav__link--visual:hover { background: rgba(176, 141, 87, 0.2); }
.nav__tools { display: flex; align-items: center; gap: clamp(4px, 0.6vw, 8px); position: relative; z-index: 4; }
.nav__tools .nav__icon-btn { width: 36px; height: 36px; }

/* language selector */
.nav__lang { position: relative; }
.nav__lang-btn {
  display: inline-flex; align-items: center; gap: 6px; height: 36px; padding: 0 12px;
  border-radius: 999px; font-family: var(--font-display); font-weight: 500;
  font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ura-charcoal);
  transition: background var(--dur-base);
}
.nav__lang-btn:hover { background: rgba(176, 141, 87, 0.13); }
.nav__lang-caret { width: 7px; height: 7px; border-right: 1.3px solid currentColor; border-bottom: 1.3px solid currentColor; transform: translateY(-2px) rotate(45deg); transition: transform var(--dur-base) var(--ease-ura); }
.nav__lang.is-open .nav__lang-caret { transform: translateY(1px) rotate(-135deg); }
.nav__lang-menu {
  position: absolute; top: calc(100% + 12px); right: 0; min-width: 168px;
  background: rgba(242, 233, 223, 0.96); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(176, 141, 87, 0.28); border-radius: 12px; padding: 8px;
  box-shadow: 0 26px 60px -26px rgba(22, 22, 22, 0.45); 
  opacity: 0; visibility: hidden; transform: translateY(-8px);
  transition: opacity var(--dur-base) var(--ease-ura), transform var(--dur-base) var(--ease-ura), visibility var(--dur-base);
}
.nav__lang.is-open .nav__lang-menu { opacity: 1; visibility: visible; transform: none; }
.nav__lang-opt {
  display: flex; align-items: center; justify-content: space-between; width: 100%; gap: 16px;
  padding: 11px 14px; border-radius: 8px; font-family: var(--font-body); font-size: 14px;
  color: var(--ura-charcoal); transition: background var(--dur-base), color var(--dur-base); text-align: left;
}
.nav__lang-opt:hover { background: rgba(176, 141, 87, 0.12); color: var(--ura-heritage-bronze); }
.nav__lang-opt .code { font-family: var(--font-display); font-weight: 500; font-size: 10px; letter-spacing: 0.16em; color: var(--fg-soft); }
.nav__lang-opt.is-active { color: var(--ura-heritage-bronze); }
.nav__lang-opt.is-active .code { color: var(--ura-heritage-bronze); }

/* show inline links on desktop, collapse to hamburger on mobile */
.nav__menu-btn { display: none; }
@media (min-width: 921px) { .nav__menu-btn--mobile { display: none !important; } }
@media (max-width: 920px) {
  .nav__links { display: none; }
  .nav__lang { display: none; }
  .nav__tools .nav__icon-btn--search { display: none; }
  .nav__menu-btn { display: inline-flex; }
}

/* ============================================================
   MENU OVERLAY — full screen dark sage, architectural
   ============================================================ */
.menu {
  position: fixed; inset: 0; z-index: 120;
  background: radial-gradient(130% 110% at 18% 0%, #2c4636 0%, var(--ura-dark-sage) 55%, #142019 100%);
  color: var(--ura-warm-ivory);
  clip-path: inset(0 0 100% 0);
  transition: clip-path var(--dur-cinematic) var(--ease-cinematic);
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  overflow: hidden;
}
.menu.is-open { clip-path: inset(0 0 0 0); }
.menu__close {
  position: absolute; top: 24px; right: clamp(20px,4vw,56px); z-index: 5;
  font-family: var(--font-display); font-weight: 500; font-size: 11px;
  letter-spacing: 0.22em; text-transform: uppercase; color: var(--fg-inverse-soft);
  display: inline-flex; align-items: center; gap: 12px;
  transition: color var(--dur-base);
}
.menu__close:hover { color: var(--ura-warm-ivory); }
/* film grain + giant ghosted U + light drift */
.menu__grain { position: absolute; inset: 0; z-index: 0; pointer-events: none; opacity: 0.07; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }
.menu__ghost { position: absolute; left: -8%; top: 50%; transform: translateY(-50%); width: min(78vh, 56vw); color: rgba(242,233,223,0.04); z-index: 0; pointer-events: none; }
.menu__drift { position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background: radial-gradient(40% 50% at 30% 30%, rgba(176,141,87,0.10), transparent 70%);
  opacity: 0; transition: opacity 1200ms var(--ease-ura); animation: menuDrift 14s ease-in-out infinite alternate; }
.menu.is-open .menu__drift { opacity: 1; }
@keyframes menuDrift { from { transform: translate(-4%, -3%); } to { transform: translate(6%, 4%); } }
.menu__left { position: relative; z-index: 1; }
  padding: clamp(90px,11vh,150px) clamp(28px,5vw,90px) 60px;
  display: flex; flex-direction: column; justify-content: center;
}
.menu__nav { list-style: none; margin: 0; padding: 0; }
.menu__item { overflow: hidden; }
.menu__item + .menu__item { margin-top: clamp(6px, 1.2vh, 14px); }
.menu__link {
  display: inline-flex; align-items: baseline; gap: 18px;
  font-family: var(--font-display); font-weight: 200;
  font-size: clamp(34px, 5.4vw, 76px); line-height: 1.04;
  letter-spacing: -0.02em; color: var(--ura-warm-ivory);
  transform: translateY(110%);
  transition: transform var(--dur-slow) var(--ease-cinematic),
              color var(--dur-base) var(--ease-ura);
}
.menu.is-open .menu__link { transform: translateY(0); }
.menu__link:hover { color: var(--ura-heritage-bronze); }
.menu__link .idx {
  font-family: var(--font-body); font-weight: 400;
  font-size: 12px; letter-spacing: 0.1em; color: var(--fg-inverse-soft);
  transform: translateY(-0.7em);
}
.menu__link--visual:hover { color: var(--ura-heritage-bronze); }
.menu__sub {
  list-style: none; margin: 12px 0 0 0; padding: 0 0 0 42px;
  display: flex; gap: 28px; flex-wrap: wrap;
}
.menu__sublink {
  font-family: var(--font-body); font-weight: 400; font-size: 13px;
  letter-spacing: 0.04em; color: var(--fg-inverse-soft);
  position: relative; padding-bottom: 2px;
  transition: color var(--dur-base);
}
.menu__sublink:hover { color: var(--ura-heritage-bronze); }
.menu__meta {
  margin-top: clamp(40px,6vh,72px); display: flex; gap: 48px; flex-wrap: wrap;
  opacity: 0; transition: opacity var(--dur-slow) var(--ease-ura) 400ms;
}
.menu.is-open .menu__meta { opacity: 1; }
.menu__meta-block { }
.menu__meta-label {
  font-family: var(--font-display); font-weight: 500; font-size: 10px;
  letter-spacing: var(--tracking-eyebrow); text-transform: uppercase;
  color: var(--ura-heritage-bronze); margin-bottom: 10px;
}
.menu__meta-val { font-family: var(--font-body); font-size: 13px; color: var(--fg-inverse-soft); line-height: 1.8; }
.menu__lang-row { display: flex; gap: 10px; margin-top: clamp(28px,5vh,48px); }
.menu__lang-row button { font-family: var(--font-display); font-weight: 500; font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--fg-inverse-soft); padding: 10px 18px; border: 1px solid var(--line-inverse); border-radius: 999px; transition: color var(--dur-base), border-color var(--dur-base), background var(--dur-base); }
.menu__lang-row button:hover, .menu__lang-row button.is-active { color: var(--ura-warm-ivory); border-color: var(--ura-heritage-bronze); background: rgba(176,141,87,0.14); }
.menu__right { position: relative; overflow: hidden; }
.menu__img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; filter: grayscale(1) brightness(0.62) contrast(1.05);
  transform: scale(1.08); opacity: 0;
  transition: opacity var(--dur-cinematic) var(--ease-ura), transform 6000ms linear;
}
.menu.is-open .menu__img { opacity: 1; transform: scale(1); }
.menu__right::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(90deg, var(--ura-dark-sage), transparent 36%);
}
.menu__right-mark {
  position: absolute; bottom: 36px; right: 36px; width: 60px; opacity: 0.4; z-index: 2;
}
@media (max-width: 820px) {
  .menu { grid-template-columns: 1fr; }
  .menu__right { display: none; }
}

/* ============================================================
   CLOSED-TOP U — architectural watermark (recreated geometry)
   ============================================================ */
.u-mark { display: block; }
.u-mark path { fill: currentColor; }

/* ============================================================
   HERO
   ============================================================ */
.hero { position: relative; height: 100vh; min-height: 640px; overflow: hidden; background: var(--ura-warm-ivory); }
.hero__media { position: absolute; inset: 0; }
.hero__img {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
  opacity: 0; transition: opacity 2400ms var(--ease-ura);
  animation: heroBreathe 30s ease-in-out infinite alternate;
}
.hero__img.is-active { opacity: 1; }
@keyframes heroBreathe {
  from { transform: scale(1.0); }
  to   { transform: scale(1.06); }
}
/* gallery hero: finished brand compositions shown clean, gentle vignette only */
.hero--gallery .hero__vignette {
  position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(120% 90% at 50% 42%, transparent 58%, rgba(31,51,40,0.18) 100%),
              linear-gradient(180deg, transparent 62%, rgba(22,22,22,0.28) 100%);
}
.hero__foot { position: absolute; left: 0; right: 0; bottom: clamp(56px, 11vh, 120px); z-index: 3; display: flex; justify-content: center; }
.hero__dots { position: absolute; left: 50%; bottom: clamp(34px, 6vh, 64px); transform: translateX(-50%); z-index: 3; display: flex; gap: 10px; }
.hero__dot { width: 7px; height: 7px; border-radius: 50%; background: rgba(242,233,223,0.45); border: 1px solid rgba(31,51,40,0.25); transition: background var(--dur-base), transform var(--dur-base); }
.hero__dot.is-on { background: var(--ura-heritage-bronze); transform: scale(1.25); }
.hero__video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0; transition: opacity 1400ms var(--ease-ura); z-index: 1; }
.hero__video.is-ready { opacity: 1; }
.hero--video .hero__dots { display: none; }
.hero--single .hero__img { animation: none; transform: scale(1.06); transition: transform 120ms linear; will-change: transform; }
.hero__scrim {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(22,22,22,0.42) 0%, transparent 26%, transparent 52%, rgba(31,51,40,0.72) 100%);
}
.hero__content {
  position: absolute; inset: 0; z-index: 3;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; color: var(--ura-warm-ivory); padding: 0 24px;
}
.hero__eyebrow {
  font-family: var(--font-display); font-weight: 500; font-size: 11px;
  letter-spacing: var(--tracking-mega); text-transform: uppercase;
  color: var(--ura-warm-ivory); opacity: 0;
}
.hero__title {
  font-family: var(--font-display); font-weight: 200;
  font-size: clamp(42px, 6.4vw, 104px); line-height: 1.0; letter-spacing: -0.025em;
  margin: 22px 0 0; max-width: 16ch; opacity: 0;
}
.hero__title em { font-style: italic; font-weight: 200; }
.hero__statement {
  font-family: var(--font-display); font-weight: 300; font-size: clamp(16px, 1.7vw, 23px);
  line-height: 1.5; letter-spacing: 0; color: var(--fg-inverse-soft);
  max-width: 32ch; margin: clamp(22px,3vh,32px) auto 0; opacity: 0;
}
.hero__meta {
  font-family: var(--font-display); font-weight: 500; font-size: 10px;
  letter-spacing: var(--tracking-eyebrow); text-transform: uppercase;
  color: var(--ura-heritage-bronze); margin-top: clamp(20px,2.6vh,28px); opacity: 0;
}
.is-loaded .hero__statement { animation: fadeUp 1500ms var(--ease-ura) 850ms forwards; }
.is-loaded .hero__meta { animation: fadeUp 1400ms var(--ease-ura) 1050ms forwards; }
/* gallery hero CTA — bronze pill, legible on ivory & sage slides */
.hero--gallery .hero__cta {
  margin: 0; opacity: 0; padding: 18px 34px; border-radius: 999px;
  background: var(--ura-heritage-bronze); color: var(--ura-warm-ivory);
  box-shadow: 0 20px 44px -18px rgba(22,22,22,0.5);
  transition: background var(--dur-base) var(--ease-ura), gap var(--dur-base) var(--ease-ura);
}
.is-loaded .hero--gallery .hero__cta { animation: fadeUp 1400ms var(--ease-ura) 700ms forwards; }
.hero--gallery .hero__cta .arc { background: var(--ura-warm-ivory); }
.hero--gallery .hero__cta .arc::after { border-color: var(--ura-warm-ivory); }
.hero--gallery .hero__cta:hover { background: var(--ura-dark-sage); }
.hero--gallery .hero__cta:hover .arc { width: 46px; }
.hero__cta {
  margin-top: clamp(40px, 6vh, 70px); opacity: 0;
  display: inline-flex; align-items: center; gap: 16px;
  font-family: var(--font-display); font-weight: 500; font-size: 12px;
  letter-spacing: 0.26em; text-transform: uppercase; color: var(--ura-warm-ivory);
  padding: 18px 2px; position: relative;
}
.hero__cta .arc {
  width: 46px; height: 1px; background: var(--ura-warm-ivory); position: relative;
  transition: width var(--dur-slow) var(--ease-ura);
}
.hero__cta .arc::after {
  content: ""; position: absolute; right: 0; top: -3px;
  width: 7px; height: 7px; border-top: 1px solid var(--ura-warm-ivory);
  border-right: 1px solid var(--ura-warm-ivory); transform: rotate(45deg);
}
.hero__cta:hover .arc { width: 72px; }
.hero__cta-underline { }
.is-loaded .hero__eyebrow { animation: fadeUp 1400ms var(--ease-ura) 300ms forwards; }
.is-loaded .hero__title   { animation: fadeUp 1600ms var(--ease-ura) 600ms forwards; }
.is-loaded .hero__cta     { animation: fadeUp 1400ms var(--ease-ura) 1100ms forwards; }
.hero__scroll {
  position: absolute; bottom: 30px; left: 50%; transform: translateX(-50%);
  z-index: 3; color: var(--ura-warm-ivory); opacity: 0;
  font-family: var(--font-display); font-size: 9px; letter-spacing: 0.3em;
  text-transform: uppercase; display: flex; flex-direction: column; align-items: center; gap: 12px;
}
.is-loaded .hero__scroll { animation: fadeUp 1400ms var(--ease-ura) 1600ms forwards; }
.hero__scroll .rule { width: 1px; height: 42px; background: linear-gradient(var(--ura-warm-ivory), transparent); animation: scrollPulse 2400ms var(--ease-ura) infinite; transform-origin: top; }
@keyframes scrollPulse { 0%,100% { transform: scaleY(0.4); opacity: 0.4; } 50% { transform: scaleY(1); opacity: 1; } }

@keyframes fadeUp { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: translateY(0); } }

/* ============================================================
   SECTION SCAFFOLD
   ============================================================ */
.section { position: relative; }
.section--ivory { background: var(--ura-warm-ivory); color: var(--ura-charcoal); }
.section--sage  { background: var(--ura-dark-sage);  color: var(--ura-warm-ivory); }
.section--green { background: var(--ura-green);       color: var(--ura-warm-ivory); }
.wrap { max-width: 1440px; margin: 0 auto; padding-left: clamp(20px,5vw,90px); padding-right: clamp(20px,5vw,90px); }

.eyebrow {
  font-family: var(--font-display); font-weight: 500; font-size: 11px;
  letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: var(--ura-heritage-bronze);
}

/* reveal-on-scroll */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity 1200ms var(--ease-ura), transform 1200ms var(--ease-ura); }
.reveal.in { opacity: 1; transform: none; }
.reveal.d1 { transition-delay: 120ms; }
.reveal.d2 { transition-delay: 240ms; }
.reveal.d3 { transition-delay: 360ms; }

/* ============================================================
   MANIFESTO / ATMOSPHERE
   ============================================================ */
.manifesto { position: relative; padding: clamp(120px,20vh,240px) 0; overflow: hidden; }
.manifesto__u {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  width: min(70vw, 760px); color: rgba(242,233,223,0.045); z-index: 0; pointer-events: none;
}
.manifesto__inner { position: relative; z-index: 1; max-width: 1000px; }
.manifesto__lead {
  font-family: var(--font-display); font-weight: 200;
  font-size: clamp(30px,4.6vw,68px); line-height: 1.12; letter-spacing: -0.02em;
  margin-top: 36px;
}
.manifesto__lead .soft { color: var(--fg-inverse-soft); }
.manifesto__lead .bronze { color: var(--ura-heritage-bronze); }
.manifesto__foot { margin-top: clamp(48px,8vh,96px); display: flex; gap: 64px; flex-wrap: wrap; }
.manifesto__stat-k { font-family: var(--font-display); font-weight: 500; font-size: 10px; letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: var(--ura-heritage-bronze); }
.manifesto__stat-v { font-family: var(--font-display); font-weight: 200; font-size: clamp(28px,3vw,42px); margin-top: 12px; }

/* ============================================================
   ARCHIVE — waves of cinematic chapters (horizontal)
   ============================================================ */
.archive { background: var(--ura-warm-ivory); padding: clamp(90px,12vh,150px) 0 clamp(60px,8vh,110px); }
.archive__head { display: flex; align-items: flex-end; justify-content: space-between; gap: 40px; margin-bottom: 56px; }
.archive__title { font-family: var(--font-display); font-weight: 200; font-size: clamp(40px,6vw,96px); line-height: 1; letter-spacing: -0.03em; margin-top: 22px; }
.archive__note { max-width: 320px; font-size: 14px; line-height: 1.8; color: var(--fg-soft); }

.wave { margin-top: clamp(56px, 9vh, 110px); }
.wave__bar { display: flex; align-items: baseline; gap: 22px; padding-bottom: 22px; border-bottom: 1px solid var(--line); }
.wave__no { font-family: var(--font-display); font-weight: 200; font-size: clamp(40px,6vw,86px); line-height: 0.9; letter-spacing: -0.02em; color: var(--ura-green); }
.wave__name { font-family: var(--font-display); font-weight: 500; font-size: clamp(13px,1.4vw,16px); letter-spacing: 0.28em; text-transform: uppercase; }
.wave__sub { margin-left: auto; font-size: 12px; letter-spacing: 0.04em; color: var(--fg-soft); }

.rail {
  display: flex; gap: 20px; overflow-x: auto; padding: 34px 0 18px; scroll-snap-type: x mandatory;
  margin: 0 calc(-1 * clamp(20px,5vw,90px)); padding-left: clamp(20px,5vw,90px); padding-right: clamp(20px,5vw,90px);
}
.rail::-webkit-scrollbar { height: 0; }
.rail { scrollbar-width: none; }

.chapter {
  position: relative; flex: 0 0 auto; width: clamp(240px, 24vw, 330px); height: clamp(380px, 52vh, 500px);
  scroll-snap-align: start; overflow: hidden; background: var(--ura-dark-sage); cursor: pointer;
  border-radius: 2px;
}
.chapter__img {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
  filter: grayscale(1) brightness(0.66) contrast(1.04);
  transform: scale(1.04);
  transition: filter var(--dur-cinematic) var(--ease-cinematic), transform 2400ms var(--ease-ura), opacity var(--dur-cinematic);
}
.chapter__placeholder {
  position: absolute; inset: 0; background:
    radial-gradient(120% 80% at 30% 20%, #2a4233, var(--ura-dark-sage));
}
.chapter__glow {
  position: absolute; inset: 0; opacity: 0; mix-blend-mode: screen;
  transition: opacity var(--dur-cinematic) var(--ease-ura);
  background: radial-gradient(120% 90% at 50% 110%, var(--accent, transparent), transparent 62%);
}
.chapter__scrim { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(22,22,22,0.15), rgba(22,22,22,0.05) 40%, rgba(22,22,22,0.78)); }
.chapter__body { position: absolute; inset: 0; z-index: 2; display: flex; flex-direction: column; justify-content: flex-end; padding: 26px; color: var(--ura-warm-ivory); }
.chapter__code {
  font-family: var(--font-display); font-weight: 300; font-size: clamp(30px,3vw,42px);
  letter-spacing: 0.02em; line-height: 1; transition: transform var(--dur-slow) var(--ease-ura);
}
.chapter__name { font-family: var(--font-display); font-weight: 500; font-size: 11px; letter-spacing: 0.26em; text-transform: uppercase; margin-top: 12px; color: var(--fg-inverse-soft); transition: color var(--dur-base); }
.chapter__line { width: 0; height: 1px; background: var(--accent, var(--ura-heritage-bronze)); margin-top: 18px; transition: width var(--dur-slow) var(--ease-ura); }
.chapter__enter {
  position: absolute; top: 24px; right: 24px; z-index: 2; opacity: 0;
  font-family: var(--font-display); font-size: 9px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--ura-warm-ivory);
  display: inline-flex; align-items: center; gap: 8px; transition: opacity var(--dur-base) var(--ease-ura);
}
.chapter:hover .chapter__img { filter: grayscale(0) brightness(0.82) contrast(1.02); transform: scale(1.12); }
.chapter:hover .chapter__placeholder { filter: none; }
.chapter:hover .chapter__glow { opacity: 0.85; }
.chapter:hover .chapter__code { transform: translateY(-4px); }
.chapter:hover .chapter__name { color: var(--ura-warm-ivory); }
.chapter:hover .chapter__line { width: 54px; }
.chapter:hover .chapter__enter { opacity: 0.9; }
.rail__hint { margin-top: 14px; font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--fg-soft); display: flex; align-items: center; gap: 10px; }

/* ============================================================
   COUNTRY CHAPTER OVERLAY
   ============================================================ */
.chapter-view {
  position: fixed; inset: 0; z-index: 140; background: var(--ura-dark-sage); color: var(--ura-warm-ivory);
  clip-path: circle(0% at var(--ox,50%) var(--oy,50%));
  transition: clip-path 900ms var(--ease-cinematic);
  overflow: hidden;
}
.chapter-view.is-open { clip-path: circle(150% at var(--ox,50%) var(--oy,50%)); }
.chapter-view__media { position: absolute; inset: 0; }
.chapter-view__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transform: scale(1.08); animation: heroBreathe 30s ease-in-out infinite alternate; }
.chapter-view__placeholder { position: absolute; inset: 0; background: radial-gradient(120% 80% at 70% 10%, #2a4233, var(--ura-dark-sage)); }
.chapter-view__wash { position: absolute; inset: 0; opacity: 0.5; mix-blend-mode: soft-light; background: radial-gradient(100% 100% at 80% 0%, var(--accent, transparent), transparent 60%); }
.chapter-view__scrim { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(31,51,40,0.92) 0%, rgba(31,51,40,0.5) 44%, transparent 78%); }
.chapter-view__inner { position: relative; z-index: 2; height: 100%; display: flex; flex-direction: column; justify-content: center; padding: 0 clamp(28px,8vw,140px); max-width: 820px; }
.chapter-view__code { font-family: var(--font-display); font-weight: 200; font-size: clamp(64px,12vw,180px); line-height: 0.9; letter-spacing: -0.02em; }
.chapter-view__name { font-family: var(--font-display); font-weight: 500; font-size: 12px; letter-spacing: 0.34em; text-transform: uppercase; color: var(--ura-heritage-bronze); margin-bottom: 18px; }
.chapter-view__copy { margin-top: 30px; font-size: clamp(16px,1.5vw,20px); line-height: 1.8; color: var(--fg-inverse-soft); max-width: 46ch; }
.chapter-view__cta { margin-top: 48px; display: inline-flex; align-items: center; gap: 16px; font-family: var(--font-display); font-weight: 500; font-size: 12px; letter-spacing: 0.26em; text-transform: uppercase; }
.chapter-view__cta .arc { width: 46px; height: 1px; background: currentColor; transition: width var(--dur-slow) var(--ease-ura); position: relative; }
.chapter-view__cta:hover .arc { width: 72px; }
.chapter-view__close { position: absolute; top: 26px; right: clamp(20px,4vw,56px); z-index: 5; font-family: var(--font-display); font-weight: 500; font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--fg-inverse-soft); display: inline-flex; gap: 12px; align-items: center; }
.chapter-view__close:hover { color: var(--ura-warm-ivory); }
.chapter-view__index { position: absolute; bottom: 30px; right: clamp(28px,8vw,140px); z-index: 3; font-family: var(--font-display); font-size: 11px; letter-spacing: 0.2em; color: var(--fg-inverse-soft); }

/* poster variant — split layout, full-colour poster beside the copy */
.chapter-view__wash--poster { position: absolute; inset: 0; background: radial-gradient(90% 90% at 78% 30%, var(--accent, transparent), transparent 60%); opacity: 0.22; }
.chapter-view__inner--split { max-width: 1240px; width: 100%; margin: 0 auto; display: grid; grid-template-columns: 1fr 0.82fr; align-items: center; gap: clamp(32px, 5vw, 84px); padding: 0 clamp(28px,7vw,120px); }
.chapter-view__copy-col { max-width: 30ch; }
.chapter-view__poster-col { display: flex; justify-content: center; align-items: center; }
.chapter-view__poster { max-height: 82vh; max-width: 100%; width: auto; object-fit: contain; box-shadow: 0 50px 90px -30px rgba(0,0,0,0.7); border: 1px solid rgba(176,141,87,0.25); opacity: 0; transform: translateY(20px) scale(0.98); transition: opacity 900ms var(--ease-ura) 200ms, transform 1100ms var(--ease-ura) 200ms; }
.chapter-view.is-open .chapter-view__poster { opacity: 1; transform: none; }
@media (max-width: 820px) {
  .chapter-view__inner--split { grid-template-columns: 1fr; gap: 28px; padding: 90px clamp(24px,6vw,40px) 70px; align-content: center; }
  .chapter-view__poster-col { order: -1; }
  .chapter-view__poster { max-height: 42vh; }
  .chapter-view__copy-col { max-width: none; }
}

/* ============================================================
   EDITORIAL FILM (curtain reveal) + FOUNDER
   ============================================================ */
.film { position: relative; height: 100vh; min-height: 600px; overflow: hidden; background: var(--ura-dark-sage); }
.film__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transform: scale(1.06); transition: transform 4000ms var(--ease-ura); }
.film.in .film__img { transform: scale(1); }
.film__curtain { position: absolute; inset: 0; background: var(--ura-green); transform: translateY(0); transition: transform var(--dur-cinematic) var(--ease-cinematic); z-index: 2; }
.film.in .film__curtain { transform: translateY(-100%); }
.film__scrim { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(22,22,22,0.3), transparent 40%, rgba(22,22,22,0.6)); z-index: 1; }
.film__body { position: absolute; z-index: 3; left: 0; right: 0; bottom: clamp(48px,9vh,110px); color: var(--ura-warm-ivory); }
.film__body--visual { top: 0; bottom: 0; display: flex; align-items: center; justify-content: center; text-align: center; }
.film__body--visual .wrap { display: flex; flex-direction: column; align-items: center; }
.film__logo { width: min(64vw, 620px); height: auto; mix-blend-mode: screen; filter: drop-shadow(0 22px 56px rgba(0,0,0,0.5)); }
.film__body--visual .film__cta { margin-top: 30px; justify-content: center; }
.film__title { font-family: var(--font-display); font-weight: 200; font-size: clamp(34px,5vw,72px); line-height: 1.04; letter-spacing: -0.02em; max-width: 18ch; margin-top: 22px; }
.film__cta { margin-top: 34px; display: inline-flex; gap: 14px; align-items: center; font-family: var(--font-display); font-weight: 500; font-size: 11px; letter-spacing: 0.26em; text-transform: uppercase; }

.founder { padding: clamp(120px,20vh,240px) 0; position: relative; overflow: hidden; background: var(--ura-warm-ivory); color: var(--ura-charcoal); }
.founder__u { position: absolute; top: 48%; left: 50%; transform: translate(-50%,-50%); width: min(64vh,52vw); color: rgba(63,91,70,0.04); z-index: 0; pointer-events: none; }
.founder__glow { position: absolute; left: 50%; top: 52%; transform: translate(-50%,-50%); width: 72vw; height: 56vh; background: radial-gradient(closest-side, rgba(176,141,87,0.09), transparent 72%); z-index: 0; pointer-events: none; }
.founder__inner { max-width: 940px; margin: 0 auto; text-align: center; position: relative; z-index: 1; padding: 0 24px; }
.founder__rule { width: 1px; height: clamp(40px,7vh,72px); background: linear-gradient(var(--ura-heritage-bronze), transparent); margin: 0 auto clamp(28px,4.5vh,48px); }
.founder__quote { font-family: var(--font-display); font-weight: 200; font-size: clamp(26px,3.6vw,52px); line-height: 1.2; letter-spacing: -0.02em; color: var(--ura-charcoal); max-width: 22ch; margin-inline: auto; }
.founder__quote .bronze { color: var(--ura-heritage-bronze); }
.founder__sig { width: clamp(280px,40vw,520px); margin: clamp(34px,6vh,64px) auto 0; opacity: 1; }
.founder__seal { display: none; }

/* ---- Featured Collection (ivory editorial band) ---- */
.featured { background: var(--ura-warm-ivory); padding: clamp(80px,12vh,150px) 0; }
.featured__inner { display: grid; grid-template-columns: 0.9fr 1fr; gap: clamp(36px,6vw,96px); align-items: center; }
@media (max-width: 820px) { .featured__inner { grid-template-columns: 1fr; gap: 40px; } }
.featured__media { position: relative; aspect-ratio: 4/5; overflow: hidden; background: #ECE2D3; border: 1px solid var(--line); }
.featured__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform 3000ms var(--ease-ura); }
.featured__media:hover img { transform: scale(1.04); }
.featured__title { font-family: var(--font-display); font-weight: 200; font-size: clamp(34px,4.6vw,68px); line-height: 1.02; letter-spacing: -0.025em; margin: 18px 0 0; }
.featured__p { margin-top: 22px; font-size: clamp(15px,1.2vw,17px); line-height: 1.8; color: var(--fg-soft); max-width: 38ch; }
.featured__cta { margin-top: 34px; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { background: var(--ura-dark-sage); color: var(--fg-inverse-soft); padding: clamp(70px,11vh,130px) 0 48px; }
.footer__top { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 40px; }
@media (max-width: 820px) { .footer__top { grid-template-columns: 1fr 1fr; } }
.footer__brand-mark { width: 120px; }
.footer__tag { margin-top: 22px; font-family: var(--font-display); font-weight: 500; font-size: 10px; letter-spacing: 0.42em; text-transform: uppercase; color: var(--ura-heritage-bronze); }
.footer__col h5 { font-family: var(--font-display); font-weight: 500; font-size: 10px; letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: var(--ura-warm-ivory); margin: 0 0 20px; }
.footer__col ul { list-style: none; margin: 0; padding: 0; }
.footer__col li { margin-bottom: 13px; }
.footer__col a { font-family: var(--font-body); font-size: 13px; color: var(--fg-inverse-soft); transition: color var(--dur-base); }
.footer__col a:hover { color: var(--ura-heritage-bronze); }
.footer__news { margin-top: 18px; display: flex; align-items: center; border-bottom: 1px solid var(--line-inverse); max-width: 280px; }
.footer__news input { flex: 1; background: none; border: none; outline: none; color: var(--ura-warm-ivory); font-family: var(--font-body); font-size: 13px; padding: 10px 0; }
.footer__news input::placeholder { color: rgba(242,233,223,0.4); }
.footer__news button { color: var(--ura-heritage-bronze); font-size: 16px; padding: 6px; }
.footer__bottom { margin-top: clamp(54px,9vh,90px); padding-top: 26px; border-top: 1px solid var(--line-inverse); display: flex; justify-content: space-between; gap: 20px; flex-wrap: wrap; font-size: 11px; letter-spacing: 0.04em; }
.footer__bottom .heid { font-family: var(--font-display); font-weight: 500; letter-spacing: var(--tracking-mega); text-transform: uppercase; color: var(--ura-heritage-bronze); font-size: 9px; white-space: nowrap; }
.footer__division { color: var(--fg-inverse-soft); }
.footer__trust { margin-top: clamp(48px,8vh,84px); padding-top: clamp(32px,5vh,48px); border-top: 1px solid var(--line-inverse); display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.footer__trust-line { font-family: var(--font-display); font-weight: 500; font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--fg-inverse-soft); }
.footer__pay { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.footer__pay-k { font-family: var(--font-display); font-weight: 500; font-size: 9px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ura-heritage-bronze); margin-right: 6px; }
.footer .pay-mark { height: 30px; padding: 0 11px; border: 1px solid var(--line-inverse); border-radius: 5px; display: inline-flex; align-items: center; background: rgba(242,233,223,0.05); color: var(--fg-inverse-soft); }
.footer .pay-mark .pm { height: 15px; width: auto; display: block; }
.footer__social a:hover .pm, .pay-mark .pm { vertical-align: middle; }
@media (max-width: 700px) { .footer__trust { flex-direction: column; align-items: flex-start; } }

/* social brand icons */
.footer__social { display: flex; gap: 12px; margin-top: 2px; }
.footer__social a { width: 40px; height: 40px; border-radius: 50%; border: 1px solid var(--line-inverse); display: inline-grid; place-items: center; color: var(--fg-inverse-soft); transition: color var(--dur-base), border-color var(--dur-base), background var(--dur-base), transform var(--dur-base) var(--ease-ura); }
.footer__social a:hover { color: var(--ura-warm-ivory); border-color: var(--ura-heritage-bronze); background: rgba(176,141,87,0.12); transform: translateY(-2px); }
.footer__social svg { width: 18px; height: 18px; }

/* ============================================================
   custom cursor dot (elegant, desktop only)
   ============================================================ */
.cursor { position: fixed; top: 0; left: 0; width: 7px; height: 7px; border-radius: 50%; background: var(--ura-heritage-bronze); pointer-events: none; z-index: 999; transform: translate(-50%,-50%); transition: width 300ms var(--ease-ura), height 300ms var(--ease-ura), background 300ms, opacity 300ms; mix-blend-mode: difference; opacity: 0; }
.cursor.is-on { opacity: 1; }
.cursor.is-link { width: 38px; height: 38px; background: transparent; border: 1px solid var(--ura-heritage-bronze); }
@media (hover: none) { .cursor { display: none; } }

/* reduced motion */
@media (prefers-reduced-motion: reduce) {
  * { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.2s !important; }
}

/* ---- tweak: country-colour reflections off ---- */
[data-accents="off"] .chapter__glow { opacity: 0 !important; }
[data-accents="off"] .chapter:hover .chapter__img { filter: grayscale(1) brightness(0.82) contrast(1.02); }
[data-accents="off"] .chapter-view__wash { opacity: 0 !important; }

/* ---- tweak: calm motion (slows the breathing loops) ---- */
[data-motion="calm"] .hero__img { animation-duration: 44s; }
[data-motion="calm"] .chapter-view__img { animation-duration: 50s; }
[data-motion="calm"] .hero__img.is-active { transition-duration: 3600ms; }

/* ============================================================
   WORLD CUP ARCHIVE BOOK — floating collectible centerpiece
   ============================================================ */
.book-section { position: relative; background: var(--ura-dark-sage); color: var(--ura-warm-ivory); padding: clamp(96px,15vh,200px) 0 clamp(80px,12vh,150px); overflow: hidden; }
.book-section__u { position: absolute; top: 44%; left: 50%; transform: translate(-50%,-50%); width: min(86vh, 70vw); color: rgba(242,233,223,0.04); z-index: 0; pointer-events: none; }
.book-section__glow { position: absolute; left: 50%; top: 54%; transform: translate(-50%,-50%); width: 100vw; height: 86vh; background: radial-gradient(closest-side, rgba(176,141,87,0.14), rgba(176,141,87,0.04) 46%, transparent 72%); z-index: 0; pointer-events: none; }
.book-head { position: relative; z-index: 2; text-align: center; max-width: 820px; margin: 0 auto clamp(48px,8vh,96px); padding: 0 24px; }
.book-head__title { font-family: var(--font-display); font-weight: 300; font-size: clamp(38px,5.6vw,84px); line-height: 1.02; letter-spacing: -0.03em; margin-top: 22px; color: var(--ura-warm-ivory); text-shadow: 0 2px 30px rgba(20,28,23,0.5); }
.book-head__sub { margin: 24px auto 0; max-width: 52ch; font-size: 16px; line-height: 1.85; color: rgba(242,233,223,0.88); text-shadow: 0 1px 20px rgba(20,28,23,0.45); }

.book-stage {
  position: relative; z-index: 2; display: flex; justify-content: center; align-items: flex-start;
  perspective: 3000px; perspective-origin: 50% 38%;
  --pw: clamp(300px, 42vw, 560px);
  --ph: calc(var(--pw) * 1.4);
  animation: bookFloat 10s ease-in-out infinite alternate;
}
@keyframes bookFloat { from { transform: translateY(-7px); } to { transform: translateY(11px); } }
.book-scale { transform-origin: top center; }
.book {
  position: relative; width: calc(var(--pw) * 2); height: var(--ph);
  transform-style: preserve-3d;
  transform: rotateX(6deg);
  transition: transform var(--dur-cinematic) var(--ease-ura);
}
.book::after { /* floor reflection */
  content: ""; position: absolute; left: 4%; right: 4%; bottom: -58px; height: 84px;
  background: radial-gradient(closest-side, rgba(0,0,0,0.55), transparent 78%); filter: blur(9px); z-index: -1;
}
.book__base { position: absolute; inset: 0; display: flex; box-shadow: 0 60px 120px -40px rgba(0,0,0,0.6), 0 30px 60px -30px rgba(0,0,0,0.5); border-radius: 3px; }

/* a single page (half a spread) */
.page {
  position: relative; width: var(--pw); height: var(--ph); overflow: hidden;
  background:
    radial-gradient(120% 100% at var(--paper-x, 0%) 0%, #FBF6EF, var(--ura-warm-ivory) 60%, #EBE0D2);
  color: var(--ura-charcoal);
}
.page img { image-rendering: -webkit-optimize-contrast; }
.page--left { --paper-x: 100%; box-shadow: inset -28px 0 50px -30px rgba(22,22,22,0.55); border-radius: 3px 0 0 3px; }
.page--right { --paper-x: 0%;  box-shadow: inset  28px 0 50px -30px rgba(22,22,22,0.55); border-radius: 0 3px 3px 0; }
/* spine */
.book__base::after { content: ""; position: absolute; left: 50%; top: 0; bottom: 0; width: 2px; transform: translateX(-50%); background: linear-gradient(180deg, rgba(22,22,22,0.18), rgba(22,22,22,0.34), rgba(22,22,22,0.18)); z-index: 30; pointer-events: none; }
.page__pad { position: absolute; inset: 0; padding: clamp(22px, 2.6vw, 38px); display: flex; flex-direction: column; }
.page__no { position: absolute; bottom: 16px; font-family: var(--font-body); font-size: 10px; letter-spacing: 0.12em; color: var(--fg-soft); }
.page--left .page__no { right: 20px; } .page--right .page__no { left: 20px; }

/* faces / leaves */
.leaf { position: absolute; top: 0; width: var(--pw); height: var(--ph); transform-style: preserve-3d; z-index: 40; }
.leaf.anim { transition: transform 1180ms var(--ease-cinematic), box-shadow 1180ms var(--ease-ura); }
.leaf--next { left: var(--pw); transform-origin: left center; transform: rotateY(0deg); }
.leaf--next.turning { transform: rotateY(-180deg); }
.leaf--prev { left: 0; transform-origin: right center; transform: rotateY(0deg); }
.leaf--prev.turning { transform: rotateY(180deg); }
.leaf__face { position: absolute; inset: 0; backface-visibility: hidden; -webkit-backface-visibility: hidden; overflow: hidden; }
.leaf__face--back { transform: rotateY(180deg); }
.leaf__shade { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(22,22,22,0.16), transparent 30%); opacity: 0; transition: opacity 560ms var(--ease-ura); pointer-events: none; }
.leaf--next .leaf__shade { background: linear-gradient(90deg, rgba(22,22,22,0.18), transparent 34%); }
.leaf--prev .leaf__shade { background: linear-gradient(270deg, rgba(22,22,22,0.18), transparent 34%); }
.leaf.turning .leaf__shade { opacity: 1; }

/* ---- page content : cover ---- */
.pg-cover { align-items: center; justify-content: center; text-align: center; }
.pg-cover__frame { position: absolute; inset: 16px; border: 1px solid var(--line-bronze); }
.pg-cover__u { width: 44%; color: var(--ura-green); }
.pg-cover__u--emboss { color: rgba(63,91,70,0.10); filter: drop-shadow(0 1px 0 rgba(255,255,255,0.6)); }
.pg-cover__wm { width: 86px; margin-bottom: 18px; }
.pg-cover__eyebrow { font-family: var(--font-display); font-weight: 500; font-size: 10px; letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: var(--ura-heritage-bronze); }
.pg-cover__big { font-family: var(--font-display); font-weight: 200; font-size: clamp(30px,3.4vw,52px); line-height: 0.98; letter-spacing: -0.02em; margin-top: 14px; }
.pg-cover__rule { width: 40px; height: 1px; background: var(--ura-heritage-bronze); margin: 22px auto; }
.pg-cover__fine { font-family: var(--font-display); font-weight: 500; font-size: 9px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--fg-soft); }

/* ---- intro ---- */
.pg-intro { justify-content: center; }
.pg-intro__eyebrow { font-family: var(--font-display); font-weight: 500; font-size: 10px; letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: var(--ura-heritage-bronze); }
.pg-intro__h { font-family: var(--font-display); font-weight: 200; font-size: clamp(24px,2.8vw,40px); line-height: 1.08; letter-spacing: -0.02em; margin-top: 18px; }
.pg-intro__p { margin-top: 22px; font-size: clamp(12px,0.95vw,14px); line-height: 1.85; color: var(--fg-muted); max-width: 34ch; }
.pg-img { padding: 0; position: absolute; inset: 0; }
.pg-img img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: grayscale(0.55) contrast(1.02) brightness(0.98); }
.pg-img__cap { position: absolute; left: 0; right: 0; bottom: 0; padding: 22px; color: var(--ura-warm-ivory); background: linear-gradient(transparent, rgba(22,22,22,0.5)); font-family: var(--font-display); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; }

/* ---- divider ---- */
.pg-div { justify-content: center; }
.pg-div__no { font-family: var(--font-display); font-weight: 200; font-size: clamp(70px,10vw,140px); line-height: 0.82; letter-spacing: -0.03em; color: var(--ura-green); }
.pg-div__wave { font-family: var(--font-display); font-weight: 500; font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--ura-heritage-bronze); margin-top: 8px; }
.pg-div__name { font-family: var(--font-display); font-weight: 300; font-size: clamp(22px,2.6vw,38px); letter-spacing: -0.01em; margin-top: 14px; }
.pg-div__statement { font-family: var(--font-display); font-weight: 200; font-size: clamp(20px,2.3vw,32px); line-height: 1.22; letter-spacing: -0.015em; color: var(--ura-charcoal); }
.pg-div__hint { margin-top: auto; font-family: var(--font-display); font-size: 9px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--fg-soft); }

/* ---- country page ---- */
.pg-country { position: absolute; inset: 0; padding: 0; cursor: pointer; }
.pg-country__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: grayscale(1) brightness(0.82) contrast(1.05); transform: scale(1.03); transition: filter 1100ms var(--ease-cinematic), transform 2200ms var(--ease-ura); }
.pg-country__ph { position: absolute; inset: 0; background: radial-gradient(120% 90% at 30% 10%, #46604f, var(--ura-dark-sage)); filter: grayscale(1); transition: filter 1100ms var(--ease-cinematic); }
.pg-country__glow { position: absolute; inset: 0; opacity: 0; mix-blend-mode: screen; background: radial-gradient(120% 80% at 50% 120%, var(--accent, transparent), transparent 60%); transition: opacity 1100ms var(--ease-ura); }
.pg-country__scrim { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(22,22,22,0.12), rgba(22,22,22,0.05) 38%, rgba(22,22,22,0.74)); }
.pg-country__body { position: absolute; inset: 0; z-index: 2; display: flex; flex-direction: column; justify-content: flex-end; padding: clamp(20px,2.4vw,30px); color: var(--ura-warm-ivory); }
.pg-country__code { font-family: var(--font-display); font-weight: 300; font-size: clamp(26px,3vw,40px); line-height: 1; letter-spacing: 0.01em; }
.pg-country__name { font-family: var(--font-display); font-weight: 500; font-size: 10px; letter-spacing: 0.26em; text-transform: uppercase; color: var(--fg-inverse-soft); margin-top: 10px; transition: color var(--dur-base); }
.pg-country__enter { display: inline-flex; align-items: center; gap: 10px; margin-top: 18px; font-family: var(--font-display); font-weight: 500; font-size: 9px; letter-spacing: 0.24em; text-transform: uppercase; opacity: 0; transform: translateY(6px); transition: opacity var(--dur-base) var(--ease-ura), transform var(--dur-base) var(--ease-ura); }
.pg-country__enter .ln { width: 26px; height: 1px; background: var(--accent, var(--ura-heritage-bronze)); display: inline-block; }
.pg-country:hover .pg-country__img { filter: grayscale(0) brightness(0.9) contrast(1.02); transform: scale(1.09); }
.pg-country:hover .pg-country__ph { filter: grayscale(0); }
.pg-country:hover .pg-country__glow { opacity: 0.85; }
.pg-country:hover .pg-country__name { color: var(--ura-warm-ivory); }
.pg-country:hover .pg-country__enter { opacity: 0.95; transform: none; }
[data-accents="off"] .pg-country__glow { opacity: 0 !important; }
[data-accents="off"] .pg-country:hover .pg-country__img { filter: grayscale(1) brightness(0.9) contrast(1.02); }
[data-accents="off"] .pg-country:hover .pg-country__ph { filter: grayscale(1); }

/* ---- country poster page (B&W → colour on hover) ---- */
.pg-country--poster { background: #ECE2D3; }
.pg-poster { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: grayscale(1) contrast(1.02) brightness(0.98); transition: filter 900ms var(--ease-cinematic), transform 900ms var(--ease-ura); transform: scale(1.005); }
.pg-country--poster:hover .pg-poster { filter: grayscale(0) contrast(1.05) saturate(1.08) brightness(1.02); transform: scale(1.07); }
.pg-country--poster::after { content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none; opacity: 0; box-shadow: inset 0 0 0 2px var(--accent, transparent), inset 0 -70px 90px -40px var(--accent, transparent); transition: opacity 700ms var(--ease-ura); }
.pg-country--poster:hover::after { opacity: 0.55; }
[data-accents="off"] .pg-country--poster:hover .pg-poster { filter: grayscale(1) contrast(1.02); transform: scale(1.05); }
[data-accents="off"] .pg-country--poster::after { display: none; }
.pg-poster__enter { position: absolute; left: 0; right: 0; bottom: 0; z-index: 2; display: flex; align-items: center; justify-content: center; gap: 12px; padding: 30px 16px 16px; background: linear-gradient(transparent, rgba(31,51,40,0.9)); color: var(--ura-warm-ivory); font-family: var(--font-display); font-weight: 500; font-size: 9px; letter-spacing: 0.24em; text-transform: uppercase; opacity: 0; transform: translateY(8px); transition: opacity var(--dur-base) var(--ease-ura), transform var(--dur-base) var(--ease-ura); }
.pg-poster__enter .ln { width: 26px; height: 1px; background: var(--ura-heritage-bronze); display: inline-block; }
.pg-country--poster:hover .pg-poster__enter { opacity: 0.96; transform: none; }

/* mouse-tracking enamel colour reflection (each country's atmosphere colour) */
.pg-reflect {
  position: absolute; inset: 0; z-index: 1; pointer-events: none; opacity: 0;
  background: radial-gradient(38% 38% at var(--mx,50%) var(--my,50%), var(--accent, transparent), transparent 72%);
  mix-blend-mode: screen; transition: opacity 700ms var(--ease-ura);
}
.pg-gloss {
  position: absolute; inset: 0; z-index: 1; pointer-events: none; opacity: 0;
  background: radial-gradient(18% 18% at var(--mx,50%) var(--my,50%), rgba(255,255,255,0.42), transparent 70%);
  mix-blend-mode: soft-light; transition: opacity 700ms var(--ease-ura);
}
.pg-country--poster:hover .pg-reflect { opacity: 0.6; }
.pg-country--poster:hover .pg-gloss { opacity: 0.85; }
.pg-country:hover .pg-reflect { opacity: 0.5; }
[data-accents="off"] .pg-reflect, [data-accents="off"] .pg-gloss { display: none; }

/* ---- colophon ---- */
.pg-colophon { justify-content: center; text-align: center; align-items: center; }

/* ---- corner turn affordances ---- */
.book__corner { position: absolute; bottom: 0; width: 16%; height: 22%; z-index: 50; cursor: pointer; }
.book__corner--next { right: 0; }
.book__corner--prev { left: 0; }
.book__corner::after { content: ""; position: absolute; bottom: 0; width: 0; height: 0; opacity: 0; transition: opacity var(--dur-base); }
.book__corner--next::after { right: 0; border-style: solid; border-width: 0 0 34px 34px; border-color: transparent transparent rgba(176,141,87,0.5) transparent; }
.book__corner--prev::after { left: 0; border-style: solid; border-width: 34px 0 0 34px; border-color: transparent transparent transparent rgba(176,141,87,0.5); }
.book__corner:hover::after { opacity: 1; }

/* ---- controls ---- */
.book-nav { position: relative; z-index: 2; display: flex; align-items: center; justify-content: center; gap: clamp(20px,3vw,42px); margin-top: clamp(40px,6vh,72px); }
.book-nav__btn { width: 50px; height: 50px; border-radius: 50%; border: 1px solid var(--line-inverse); display: inline-grid; place-items: center; color: var(--ura-warm-ivory); transition: border-color var(--dur-base), background var(--dur-base), opacity var(--dur-base); }
.book-nav__btn:hover { border-color: var(--ura-heritage-bronze); background: rgba(176,141,87,0.10); }
.book-nav__btn[disabled] { opacity: 0.25; cursor: default; }
.book-nav__btn svg { width: 18px; height: 18px; stroke: currentColor; stroke-width: 1.4; fill: none; }
.book-nav__meta { min-width: 220px; text-align: center; }
.book-nav__chapter { font-family: var(--font-display); font-weight: 500; font-size: 10px; letter-spacing: 0.26em; text-transform: uppercase; color: var(--ura-heritage-bronze); }
.book-nav__progress { margin-top: 12px; height: 1px; width: 100%; background: var(--line-inverse); position: relative; }
.book-nav__progress span { position: absolute; left: 0; top: 0; height: 100%; background: var(--ura-heritage-bronze); transition: width var(--dur-slow) var(--ease-ura); }

@media (max-width: 600px) {
  .book__corner { display: none; }
}
