:root {
  --navy: #0b1827;
  --navy-soft: #142438;
  --ivory: #f2ede3;
  --paper: #e8e0d3;
  --gold: #aa8954;
  --gold-light: #d1b37d;
  --ink: #182230;
  --muted: #706a61;
  --line-dark: rgba(11, 24, 39, 0.16);
  --line-light: rgba(242, 237, 227, 0.18);
  --serif: "Bodoni 72", Didot, "Iowan Old Style", Baskerville, "Times New Roman", serif;
  --sans: Inter, "Helvetica Neue", Arial, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--ivory); color: var(--ink); font-family: var(--sans); font-size: 16px; line-height: 1.65; }
body.menu-open { overflow: hidden; }
img { display: block; max-width: 100%; }
a { color: inherit; }
button, input, select, textarea { font: inherit; }
::selection { background: var(--gold); color: var(--navy); }

.skip-link { position: fixed; z-index: 1000; top: 12px; left: 12px; transform: translateY(-150%); padding: 12px 18px; background: var(--ivory); color: var(--navy); }
.skip-link:focus { transform: translateY(0); }
:focus-visible { outline: 2px solid var(--gold-light); outline-offset: 4px; }

.site-header { position: fixed; z-index: 100; inset: 0 0 auto; display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; min-height: 92px; padding: 17px clamp(22px, 5vw, 78px); color: var(--ivory); border-bottom: 1px solid rgba(242, 237, 227, 0.13); transition: background-color .5s ease, min-height .5s ease, color .5s ease; }
.site-header.is-scrolled { min-height: 74px; color: var(--navy); background: rgba(242, 237, 227, 0.93); border-color: var(--line-dark); backdrop-filter: blur(14px); }
.wordmark { display: inline-flex; flex-direction: column; justify-self: start; width: max-content; text-decoration: none; }
.wordmark span { color: var(--gold-light); font-family: var(--serif); font-size: 27px; line-height: 1; letter-spacing: .24em; }
.site-header.is-scrolled .wordmark span { color: #8f6b36; }
.wordmark small { margin-top: 6px; font-size: 8px; line-height: 1; letter-spacing: .19em; text-transform: uppercase; }
.site-header nav { display: flex; gap: 34px; }
.site-header nav a, .header-request { font-size: 10px; font-weight: 600; letter-spacing: .16em; text-decoration: none; text-transform: uppercase; }
.site-header nav a { opacity: .72; transition: opacity .25s ease; }
.site-header nav a:hover { opacity: 1; }
.header-request { justify-self: end; border-bottom: 1px solid currentColor; padding-bottom: 3px; }

.hero { position: relative; min-height: 100svh; display: flex; align-items: flex-end; overflow: hidden; padding: 155px clamp(22px, 7vw, 108px) clamp(72px, 9vh, 112px); color: var(--ivory); background: var(--navy); }
.hero__image { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center; scale: 1.015; animation: hero-settle 2.4s cubic-bezier(.2, .6, .2, 1) both; }
.hero__veil { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(4, 12, 22, .9) 0%, rgba(7, 17, 29, .7) 34%, rgba(7, 17, 29, .15) 68%), linear-gradient(0deg, rgba(4, 10, 17, .45), transparent 45%); }
.hero__content { position: relative; z-index: 1; width: min(720px, 100%); }
.eyebrow { margin: 0 0 22px; color: var(--gold-light); font-size: 10px; font-weight: 600; letter-spacing: .28em; text-transform: uppercase; }
h1, h2, h3, p { margin-top: 0; }
h1, h2, h3 { font-family: var(--serif); font-weight: 400; }
.hero h1 { margin-bottom: 30px; font-size: clamp(64px, 8vw, 118px); line-height: .84; letter-spacing: -.045em; }
.hero__subhead { margin-bottom: 28px; font-family: var(--serif); font-size: clamp(22px, 2.1vw, 31px); line-height: 1.25; }
.hero__support { margin-bottom: 36px; color: rgba(242, 237, 227, .72); font-size: 13px; letter-spacing: .03em; }
.button { display: inline-flex; align-items: center; justify-content: center; min-height: 54px; padding: 17px 29px; border: 1px solid transparent; border-radius: 0; font-size: 10px; font-weight: 700; letter-spacing: .2em; text-decoration: none; text-transform: uppercase; cursor: pointer; transition: color .3s ease, background-color .3s ease, border-color .3s ease; }
.button--dark { color: var(--ivory); background: rgba(11, 24, 39, .84); border-color: rgba(242, 237, 227, .48); }
.button--dark:hover { color: var(--navy); background: var(--ivory); border-color: var(--ivory); }
.button--gold { width: 100%; color: var(--navy); background: var(--gold-light); }
.button--gold:hover { color: var(--ivory); background: var(--navy-soft); }
.microcopy { margin: 13px 0 0; color: rgba(242, 237, 227, .62); font-size: 10px; letter-spacing: .04em; }
.hero__scroll { position: absolute; z-index: 2; right: clamp(22px, 5vw, 78px); bottom: 55px; display: flex; align-items: center; gap: 18px; color: rgba(242, 237, 227, .75); font-size: 9px; letter-spacing: .2em; text-decoration: none; text-transform: uppercase; writing-mode: vertical-rl; }
.hero__scroll i { display: block; width: 1px; height: 52px; background: rgba(242, 237, 227, .5); }

.section-pad { padding: clamp(90px, 12vw, 175px) clamp(22px, 7vw, 108px); }
.house { display: grid; grid-template-columns: .82fr 1.18fr; gap: clamp(55px, 10vw, 160px); align-items: center; min-height: 900px; }
.house h2, .allocation h2, .circle h2, .consideration h2 { margin-bottom: 40px; color: var(--navy); font-size: clamp(58px, 7vw, 104px); line-height: .88; letter-spacing: -.045em; }
.house__copy { max-width: 620px; }
.house__copy .lead { font-family: var(--serif); font-size: clamp(24px, 2.3vw, 34px); line-height: 1.35; }
.house__copy > p:last-child { max-width: 500px; color: var(--muted); }
.house__visual { margin: 0; }
.house__visual img { width: 100%; background: var(--paper); }
.house__visual figcaption { display: flex; justify-content: space-between; gap: 30px; padding-top: 16px; color: var(--muted); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; }
.house__visual figcaption span { color: var(--gold); }

.ritual { display: grid; grid-template-columns: 1.08fr .92fr; min-height: 900px; background: var(--navy); color: var(--ivory); }
.ritual__visual { min-height: 720px; overflow: hidden; }
.ritual__visual img { width: 100%; height: 100%; object-fit: cover; }
.ritual__copy { display: flex; flex-direction: column; justify-content: center; }
.ritual h2 { margin-bottom: 44px; font-size: clamp(65px, 7vw, 105px); line-height: .9; }
.ritual__statement { font-family: var(--serif); font-size: clamp(27px, 3vw, 43px); line-height: 1.25; }
.ritual__copy > p:not(.eyebrow):last-of-type { color: rgba(242, 237, 227, .62); }
.ritual__sequence { display: grid; grid-template-columns: 1fr 1fr; margin-top: 50px; border-top: 1px solid var(--line-light); }
.ritual__sequence span { display: flex; gap: 17px; padding: 18px 5px; border-bottom: 1px solid var(--line-light); font-size: 10px; font-weight: 600; letter-spacing: .17em; text-transform: uppercase; }
.ritual__sequence span:nth-child(odd) { border-right: 1px solid var(--line-light); }
.ritual__sequence b { color: var(--gold-light); font-weight: 400; }

.allocation { background: var(--paper); }
.allocation__header { display: grid; grid-template-columns: 1fr .72fr; gap: 9vw; align-items: end; margin-bottom: 85px; }
.allocation__intro { max-width: 520px; color: var(--muted); }
.release-date { margin: 30px 0 0; color: var(--navy); font-size: 11px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; }
.allocation__stage { position: relative; display: grid; grid-template-columns: 1.15fr .85fr; background: var(--navy); color: var(--ivory); }
.allocation__stage > img { width: 100%; height: 100%; object-fit: cover; }
.allocation__list { display: flex; flex-direction: column; justify-content: center; margin: 0; padding: 55px clamp(28px, 5vw, 75px); list-style: none; }
.allocation__list li { display: grid; grid-template-columns: 90px 1fr; gap: 20px; align-items: baseline; padding: 19px 0; border-bottom: 1px solid var(--line-light); }
.allocation__list span { color: var(--gold-light); font-size: 9px; letter-spacing: .14em; text-transform: uppercase; }
.allocation__list strong { font-family: var(--serif); font-size: clamp(18px, 1.7vw, 25px); font-weight: 400; }
.allocation__detail { display: grid; grid-template-columns: .7fr 1.3fr; align-items: center; gap: clamp(50px, 10vw, 160px); margin-top: clamp(80px, 10vw, 150px); }
.allocation__detail figure { margin: 0; max-height: 650px; overflow: hidden; background: #d8cfc1; }
.allocation__detail img { width: 100%; height: 100%; object-fit: cover; }
.allocation__detail blockquote { margin: 0; }
.allocation__detail blockquote p { font-family: var(--serif); font-size: clamp(35px, 4.8vw, 73px); line-height: 1.08; letter-spacing: -.025em; }
.allocation__detail cite { color: var(--gold); font-size: 9px; font-style: normal; letter-spacing: .2em; text-transform: uppercase; }

.circle { background: var(--ivory); }
.circle__header { display: grid; grid-template-columns: 1fr 1fr; column-gap: 10vw; align-items: end; margin-bottom: 80px; }
.circle__header .eyebrow { grid-column: 1 / -1; }
.circle__header h2 { margin-bottom: 0; }
.circle__header > p:last-child { max-width: 540px; color: var(--muted); }
.privileges { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid var(--line-dark); border-left: 1px solid var(--line-dark); }
.privilege { min-height: 390px; padding: 34px; border-right: 1px solid var(--line-dark); border-bottom: 1px solid var(--line-dark); }
.privilege > span { color: var(--gold); font-family: var(--serif); }
.privilege__label { margin: 100px 0 10px; color: var(--gold); font-size: 9px; letter-spacing: .18em; text-transform: uppercase; }
.privilege h3 { margin-bottom: 22px; color: var(--navy); font-size: clamp(27px, 2.5vw, 39px); line-height: 1.1; }
.privilege > p:last-child { max-width: 310px; color: var(--muted); font-size: 13px; }

.consideration { display: grid; grid-template-columns: .75fr 1.25fr; gap: clamp(60px, 10vw, 160px); background: var(--navy); color: var(--ivory); }
.consideration h2 { color: var(--ivory); }
.consideration__intro > p:not(.eyebrow) { max-width: 520px; color: rgba(242, 237, 227, .65); }
.consideration__note { display: flex; gap: 20px; align-items: flex-start; margin-top: 55px; padding-top: 25px; border-top: 1px solid var(--line-light); }
.consideration__note span { display: grid; flex: 0 0 42px; place-items: center; width: 42px; height: 42px; border: 1px solid rgba(209, 179, 125, .55); border-radius: 50%; color: var(--gold-light); font-family: var(--serif); }
.consideration__note p { margin: 0; font-size: 11px; }
.form-panel { min-height: 760px; padding: clamp(28px, 5vw, 68px); background: var(--ivory); color: var(--ink); }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.field { margin-bottom: 25px; }
.field label { display: flex; justify-content: space-between; gap: 15px; margin-bottom: 8px; color: var(--navy); font-size: 10px; font-weight: 700; letter-spacing: .11em; text-transform: uppercase; }
.field label span { color: var(--muted); font-weight: 400; letter-spacing: .06em; }
.field input, .field select, .field textarea { width: 100%; min-height: 51px; padding: 12px 2px; color: var(--navy); border: 0; border-bottom: 1px solid #a49d92; border-radius: 0; outline: 0; background: transparent; }
.field textarea { resize: vertical; }
.field select { appearance: none; background: linear-gradient(45deg, transparent 50%, var(--navy) 50%) calc(100% - 10px) 50% / 5px 5px no-repeat, linear-gradient(135deg, var(--navy) 50%, transparent 50%) calc(100% - 5px) 50% / 5px 5px no-repeat; }
.field input:focus, .field select:focus, .field textarea:focus { border-bottom-color: var(--gold); box-shadow: 0 1px 0 var(--gold); }
.field [aria-invalid="true"] { border-bottom-color: #9a2c2c; }
.field-error { display: block; min-height: 17px; padding-top: 4px; color: #882727; font-size: 10px; }
.email-suggestion { margin-top: 10px; padding: 15px 16px; border: 1px solid rgba(170, 137, 84, .35); color: var(--navy); background: rgba(170, 137, 84, .08); }
.email-suggestion p { margin: 0 0 12px; font: 14px/1.5 var(--serif); }
.email-suggestion div { display: flex; flex-wrap: wrap; gap: 16px; }
.email-suggestion button { padding: 0; border: 0; background: transparent; color: var(--navy); cursor: pointer; font-size: 9px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }
.email-suggestion button:hover, .email-suggestion button:focus-visible { color: var(--gold); outline: none; }
.form-disclaimer { margin: 15px auto 0; max-width: 500px; color: var(--muted); font-size: 10px; text-align: center; }
.form-status { min-height: 18px; margin: 14px auto 0; max-width: 540px; color: var(--muted); font-size: 10px; text-align: center; }
.form-status.is-error { color: #72564c; }
.button:disabled { cursor: wait; opacity: .62; }
.confirmation { min-height: 620px; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; }
.confirmation[hidden] { display: none; }
.confirmation__mark { display: grid; place-items: center; width: 72px; height: 72px; margin: 15px 0 35px; color: var(--gold); border: 1px solid rgba(170, 137, 84, .5); border-radius: 50%; font-family: var(--serif); font-size: 30px; }
.confirmation h3 { max-width: 570px; margin-bottom: 25px; color: var(--navy); font-size: clamp(38px, 4vw, 60px); line-height: 1.05; }
.confirmation p:not(.eyebrow) { margin-bottom: 8px; color: var(--muted); }
.confirmation .confirmation__reference { margin: 24px 0 8px; color: var(--navy); font-family: var(--serif); font-size: 24px; }
.text-button { margin-top: 42px; padding: 7px 0; color: var(--navy); border: 0; border-bottom: 1px solid currentColor; background: transparent; font-size: 10px; font-weight: 700; letter-spacing: .17em; text-transform: uppercase; cursor: pointer; }

.site-footer { display: grid; grid-template-columns: 1fr auto; gap: 35px; align-items: start; padding: 70px clamp(22px, 7vw, 108px); background: #08131f; color: var(--ivory); }
.wordmark--footer span { color: var(--gold-light); }
.site-footer nav { display: flex; gap: 30px; }
.site-footer nav a { color: rgba(242, 237, 227, .7); font-size: 10px; letter-spacing: .12em; text-decoration: none; text-transform: uppercase; }
.site-footer > p { grid-column: 1 / -1; margin: 30px 0 0; font-family: var(--serif); font-size: 22px; }
.site-footer > small { grid-column: 1 / -1; color: rgba(242, 237, 227, .42); font-size: 9px; letter-spacing: .12em; text-transform: uppercase; }
.mobile-request { display: none; }

.js .reveal { opacity: 0; transform: translateY(22px); transition: opacity .9s cubic-bezier(.2, .6, .2, 1), transform .9s cubic-bezier(.2, .6, .2, 1); }
.reveal--delay { transition-delay: .12s; }
.reveal--delay-2 { transition-delay: .24s; }
.js .reveal.is-visible { opacity: 1; transform: none; }

@keyframes hero-settle { from { opacity: .3; scale: 1.06; } to { opacity: 1; scale: 1.015; } }

@media (max-width: 1050px) {
  .site-header { grid-template-columns: 1fr auto; }
  .site-header nav { display: none; }
  .house { grid-template-columns: 1fr 1fr; gap: 55px; }
  .allocation__stage { grid-template-columns: 1fr; }
  .allocation__stage > img { max-height: 720px; }
  .allocation__list { display: grid; grid-template-columns: 1fr 1fr; }
  .allocation__list li:nth-child(odd) { padding-right: 25px; }
  .allocation__list li:nth-child(even) { padding-left: 25px; border-left: 1px solid var(--line-light); }
  .consideration { grid-template-columns: 1fr; }
}

@media (max-width: 760px) {
  body { font-size: 15px; padding-bottom: 72px; }
  .site-header { min-height: 72px; padding: 14px 20px; }
  .site-header.is-scrolled { min-height: 66px; }
  .wordmark span { font-size: 23px; }
  .header-request { display: none; }
  .hero { min-height: 800px; padding: 125px 20px 72px; }
  .hero__image { object-position: 61% center; }
  .hero__veil { background: linear-gradient(180deg, rgba(5, 13, 23, .1) 0%, rgba(5, 13, 23, .48) 38%, rgba(5, 13, 23, .96) 78%); }
  .hero h1 { font-size: clamp(59px, 18vw, 78px); }
  .hero__scroll { display: none; }
  .section-pad { padding: 95px 20px; }
  .house { grid-template-columns: 1fr; min-height: auto; }
  .house h2, .allocation h2, .circle h2, .consideration h2 { font-size: clamp(54px, 16vw, 76px); }
  .house__visual { order: -1; }
  .ritual { grid-template-columns: 1fr; min-height: auto; }
  .ritual__visual { min-height: 470px; }
  .ritual__copy { min-height: 650px; }
  .allocation__header, .circle__header { grid-template-columns: 1fr; gap: 35px; margin-bottom: 55px; }
  .allocation__list { grid-template-columns: 1fr; padding: 35px 24px; }
  .allocation__list li:nth-child(n) { padding: 17px 0; border-left: 0; }
  .allocation__detail { grid-template-columns: 1fr; }
  .allocation__detail figure { max-height: 520px; }
  .allocation__detail blockquote p { font-size: 40px; }
  .privileges { grid-template-columns: 1fr; }
  .privilege { min-height: 300px; }
  .privilege__label { margin-top: 60px; }
  .consideration { gap: 55px; }
  .form-panel { padding: 35px 20px; }
  .field-row { grid-template-columns: 1fr; gap: 0; }
  .site-footer { grid-template-columns: 1fr; padding-bottom: 95px; }
  .site-footer nav { flex-wrap: wrap; }
  .site-footer > p, .site-footer > small { grid-column: auto; }
  .mobile-request { position: fixed; z-index: 120; display: block; right: 12px; bottom: 12px; left: 12px; padding: 17px 18px; color: var(--navy); background: var(--gold-light); box-shadow: 0 9px 35px rgba(0, 0, 0, .3); font-size: 10px; font-weight: 700; letter-spacing: .18em; text-align: center; text-decoration: none; text-transform: uppercase; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}
