:root {
  --navy: #071321;
  --navy-2: #0d1d2f;
  --cream: #f4efe4;
  --beige: #c9bca5;
  --muted: #9d927e;
  --gold: #c6a45e;
  --graphite: #141414;
  --line: rgba(244, 239, 228, 0.18);
  --glass: rgba(244, 239, 228, 0.08);
  font-family: Inter, Arial, sans-serif;
}
* { box-sizing: border-box; }
body { margin: 0; background: var(--navy); color: var(--cream); }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; object-fit: cover; }
:focus-visible { outline: 2px solid var(--gold); outline-offset: 4px; }
.site-header { position: fixed; top: 0; left: 0; right: 0; z-index: 20; border-bottom: 1px solid var(--line); background: rgba(7, 19, 33, 0.62); backdrop-filter: blur(18px); }
.nav { width: min(1220px, calc(100% - 32px)); height: 76px; margin: 0 auto; display: grid; grid-template-columns: 1fr auto 1fr; gap: 24px; align-items: center; }
.brand { display: grid; gap: 1px; width: max-content; }
.brand span, .footer-brand span { font-family: "DM Serif Display", Georgia, serif; font-size: 28px; letter-spacing: 0; }
.brand small, .eyebrow { color: var(--beige); font-size: 11px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; }
.nav-links { display: flex; gap: 24px; color: rgba(244,239,228,.74); font-size: 13px; font-weight: 700; }
.nav-links a[aria-current="page"], .nav-links a:hover { color: var(--cream); }
.nav-actions { justify-self: end; display: flex; align-items: center; gap: 10px; }
.nav-cta, .primary, .secondary { min-height: 42px; display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; padding: 0 20px; font-weight: 800; border: 1px solid var(--cream); }
.nav-cta, .secondary { background: transparent; color: var(--cream); }
.primary { background: var(--cream); color: var(--navy); }
.menu-button { display: none; border: 1px solid var(--line); border-radius: 999px; height: 42px; padding: 0 14px; color: var(--cream); background: var(--glass); }
.hero-editorial { min-height: 100vh; position: relative; display: grid; align-items: end; isolation: isolate; }
.hero-photo { position: absolute; inset: 0; z-index: -2; background: var(--navy-2); }
.hero-photo::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(7,19,33,.94) 0%, rgba(7,19,33,.58) 42%, rgba(7,19,33,.18) 100%), linear-gradient(0deg, rgba(7,19,33,.92), rgba(7,19,33,0) 50%); }
.hero-photo img { width: 100%; height: 100%; }
.hero-overlay { width: min(1220px, calc(100% - 32px)); margin: 0 auto; padding: 150px 0 150px; max-width: 1220px; }
h1, h2, h3 { margin: 0; font-family: "DM Serif Display", Georgia, serif; font-weight: 400; letter-spacing: 0; line-height: .94; }
h1 { font-size: clamp(70px, 12vw, 170px); max-width: 1040px; }
h2 { font-size: clamp(46px, 7vw, 96px); }
h3 { font-size: 32px; }
p { line-height: 1.7; }
.hero-overlay p:not(.eyebrow) { max-width: 520px; color: rgba(244,239,228,.78); font-size: 18px; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 30px; }
.club-strip { position: absolute; left: 50%; bottom: 28px; transform: translateX(-50%); width: min(1220px, calc(100% - 32px)); display: grid; grid-template-columns: repeat(3, 1fr); border: 1px solid var(--line); background: rgba(7,19,33,.48); backdrop-filter: blur(14px); }
.club-strip span { padding: 18px 22px; border-right: 1px solid var(--line); color: var(--beige); display: flex; justify-content: space-between; gap: 12px; text-transform: uppercase; font-size: 12px; font-weight: 800; }
.club-strip span:last-child { border-right: 0; }
.club-strip b { color: var(--cream); }
.philosophy { min-height: 62vh; width: min(1060px, calc(100% - 32px)); margin: 0 auto; padding: 120px 0; display: grid; gap: 24px; }
.philosophy p:last-child { max-width: 620px; color: var(--beige); justify-self: end; font-size: 19px; }
.product-section, .journal-section { padding: 100px max(16px, calc((100vw - 1220px) / 2)); background: var(--cream); color: var(--graphite); }
.section-title { display: flex; align-items: end; justify-content: space-between; gap: 24px; margin-bottom: 34px; }
.section-title .eyebrow, .product-card span, .service-catalog span, .expert-list span, .journal-grid span { color: #756b5b; }
.product-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.product-card { background: #fffaf0; border: 1px solid rgba(20,20,20,.08); display: grid; }
.product-card picture { aspect-ratio: 4 / 5; background: #d9cfbf; }
.product-card img { width: 100%; height: 100%; }
.product-card div { padding: 18px; display: grid; gap: 8px; }
.product-card p { margin: 0; color: #6f6659; }
.product-card a, .service-catalog a { color: var(--graphite); font-weight: 800; text-decoration: underline; text-underline-offset: 5px; }
.lifestyle-board { padding: 100px max(16px, calc((100vw - 1220px) / 2)); display: grid; grid-template-columns: 1.2fr .8fr .8fr; gap: 14px; align-items: stretch; }
.lifestyle-board > div { grid-row: span 2; border: 1px solid var(--line); padding: 30px; display: grid; align-content: end; min-height: 520px; background: var(--glass); }
.lifestyle-board figure, .gallery-runway figure { margin: 0; display: grid; gap: 10px; }
.lifestyle-board picture, .gallery-runway picture { aspect-ratio: 1 / 1.18; overflow: hidden; background: var(--navy-2); }
.lifestyle-board img, .gallery-runway img { width: 100%; height: 100%; }
figcaption { color: var(--beige); font-size: 13px; }
.journal-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.journal-grid article { border: 1px solid rgba(20,20,20,.12); padding: 26px; min-height: 250px; display: grid; align-content: space-between; background: #fffaf0; }
.membership { width: min(980px, calc(100% - 32px)); margin: 0 auto; padding: 120px 0; text-align: center; display: grid; gap: 24px; justify-items: center; }
.catalog-hero { padding: 150px max(16px, calc((100vw - 1000px) / 2)) 60px; display: grid; gap: 20px; }
.catalog-hero p:not(.eyebrow) { max-width: 620px; color: var(--beige); font-size: 19px; }
.service-catalog { width: min(1100px, calc(100% - 32px)); margin: 0 auto; padding: 30px 0 100px; display: grid; gap: 1px; }
.service-catalog article { display: grid; grid-template-columns: 120px 1fr 1.2fr auto; gap: 22px; align-items: center; padding: 26px 0; border-top: 1px solid var(--line); }
.service-catalog div { display: grid; gap: 4px; justify-items: end; }
.ritual-detail { min-height: 100vh; display: grid; grid-template-columns: .9fr 1.1fr; align-items: stretch; }
.ritual-copy { padding: 130px 7vw 70px; display: grid; align-content: center; gap: 22px; }
.ritual-copy p:not(.eyebrow) { color: var(--beige); font-size: 19px; }
.ritual-detail picture { min-height: 100vh; background: var(--navy-2); }
.ritual-detail img { width: 100%; height: 100%; }
.ritual-facts { display: flex; flex-wrap: wrap; gap: 10px; }
.ritual-facts span { border: 1px solid var(--line); border-radius: 999px; padding: 10px 16px; }
.expert-list { width: min(1120px, calc(100% - 32px)); margin: 0 auto; padding: 20px 0 100px; display: grid; gap: 18px; }
.expert-list article { display: grid; grid-template-columns: 340px 1fr; gap: 34px; align-items: end; border-bottom: 1px solid var(--line); padding-bottom: 28px; }
.expert-list picture { aspect-ratio: 4 / 5; overflow: hidden; background: var(--navy-2); }
.expert-list img { width: 100%; height: 100%; }
.gallery-runway { padding: 30px max(16px, calc((100vw - 1220px) / 2)) 100px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.gallery-runway figure:nth-child(3n+1) { transform: translateY(36px); }
.booking-screen { min-height: 100vh; padding: 140px max(16px, calc((100vw - 1120px) / 2)) 80px; display: grid; grid-template-columns: 1.1fr 360px; gap: 40px; align-items: center; }
.booking-screen > div { display: grid; gap: 18px; }
.booking-screen p { max-width: 560px; color: var(--beige); font-size: 19px; }
.hours { display: flex; flex-wrap: wrap; gap: 10px; color: var(--beige); }
.qr-bot { margin: 0; display: grid; justify-items: center; gap: 16px; padding: 26px; border: 1px solid var(--line); background: var(--glass); text-align: center; }
.qr-bot img { width: 240px; height: 240px; background: var(--cream); }
.site-footer { padding: 46px max(16px, calc((100vw - 1220px) / 2)); border-top: 1px solid var(--line); display: flex; justify-content: space-between; gap: 28px; }
.footer-brand p, .footer-links { color: var(--beige); }
.footer-links { display: flex; flex-wrap: wrap; gap: 16px; justify-content: flex-end; }
@media (max-width: 920px) {
  .nav { grid-template-columns: 1fr auto; }
  .nav-links { display: none; position: absolute; left: 16px; right: 16px; top: 78px; padding: 18px; background: rgba(7,19,33,.94); border: 1px solid var(--line); }
  .nav-links.is-open { display: grid; }
  .menu-button { display: inline-flex; align-items: center; }
  .product-grid, .journal-grid, .gallery-runway { grid-template-columns: repeat(2, 1fr); }
  .lifestyle-board, .ritual-detail, .booking-screen, .expert-list article { grid-template-columns: 1fr; }
  .service-catalog article { grid-template-columns: 1fr; }
  .service-catalog div { justify-items: start; }
}
@media (max-width: 560px) {
  .nav-cta { display: none; }
  h1 { font-size: 62px; }
  h2 { font-size: 44px; }
  .hero-overlay { padding-bottom: 210px; }
  .club-strip, .product-grid, .journal-grid, .gallery-runway { grid-template-columns: 1fr; }
  .club-strip span { border-right: 0; border-bottom: 1px solid var(--line); }
  .site-footer { display: grid; }
  .footer-links { justify-content: flex-start; }
}
