/* =========================================================================
   Regium Holdings — design tokens & global styles
   Palette per brand deck: Imperial Jade, Enchanted Emerald, Albino,
   Pyramid Gold, Blush Quartz. Type per deck: Aviano Serif → Cinzel,
   Proxima Nova → Montserrat (free Google equivalents).
   ========================================================================= */

:root {
  /* Brand palette — verbatim swatch names from the brand deck */
  --jade:        oklch(22% 0.035 165);    /* #0E2A23  Imperial Jade — primary surface */
  --jade-deep:   oklch(16% 0.030 165);    /* darker, used for footer / pressed */
  --emerald:     oklch(34% 0.070 165);    /* #175841  Enchanted Emerald — secondary band */
  --gold:        oklch(78% 0.092 75);     /* #E5B273  Pyramid Gold — primary accent */
  --gold-deep:   oklch(58% 0.095 70);     /* darker gold for body links on albino */
  --gold-soft:   oklch(88% 0.045 75);     /* warm sand wash */
  --albino:      oklch(94% 0.012 70);     /* #F4ECE3  Albino — light surface */
  --albino-deep: oklch(90% 0.015 70);     /* recessed light surface */
  --blush:       oklch(78% 0.075 15);     /* #EBA1B0  Blush Quartz — editorial accent */

  /* Roles — assigned to palette swatches */
  --bg:          var(--jade);
  --bg-alt:      var(--emerald);
  --bg-light:    var(--albino);
  --bg-light-alt:var(--albino-deep);

  --ink:         var(--albino);                  /* text on dark */
  --ink-soft:    oklch(82% 0.018 70);
  --ink-mute:    oklch(65% 0.020 70);
  --ink-dark:    var(--jade);                    /* text on light */
  --ink-dark-soft: oklch(34% 0.025 165);
  --ink-dark-mute: oklch(50% 0.020 165);

  --accent:      var(--gold);
  --accent-deep: var(--gold-deep);
  --rule-dark:   oklch(40% 0.020 165);           /* hairline on jade */
  --rule-light:  oklch(85% 0.012 70);            /* hairline on albino */

  /* Spacing */
  --s-1: 0.5rem; --s-2: 0.75rem; --s-3: 1.25rem; --s-4: 2rem;
  --s-5: 3rem;   --s-6: 4.5rem;  --s-7: 6rem;    --s-8: 7.5rem;
  --s-9: 9rem;   --s-10: 12rem;  --s-11: 16rem;

  --max-w: min(86rem, 92vw);
  --gutter: clamp(1rem, 1.5vw, 1.75rem);

  /* Typography families per deck */
  --serif: "Cinzel", "Trajan Pro", "Times New Roman", serif;        /* Aviano Serif sub */
  --sans:  "Montserrat", "Proxima Nova", system-ui, sans-serif;     /* Proxima Nova sub */

  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
}

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }

body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 1rem;
  line-height: 1.65;
  font-feature-settings: "ss01", "cv11";
  text-rendering: optimizeLegibility;
}

::selection { background: var(--gold); color: var(--jade); }
img, svg { display: block; max-width: 100%; }

a {
  color: inherit;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.24em;
  text-decoration-color: color-mix(in oklab, currentColor 30%, transparent);
  transition: color 200ms var(--ease-out), text-decoration-color 200ms var(--ease-out);
}
a:hover { color: var(--gold); text-decoration-color: var(--gold); }

button { font: inherit; cursor: pointer; }

:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 3px;
  border-radius: 1px;
}

.wrap { width: var(--max-w); margin-inline: auto; }
.rule { height: 1px; background: var(--rule-dark); border: 0; margin: 0; }

.meta {
  font-family: var(--sans);
  font-size: 0.78rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  font-weight: 500;
}

.lede {
  font-size: clamp(1.15rem, 1.6vw, 1.35rem);
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 62ch;
}

.figure-num {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(1.5rem, 4.5vw, 5.25rem);
  line-height: 0.95;
  letter-spacing: 0.02em;
  color: var(--gold);
  font-variant-numeric: lining-nums;
}

/* ----------- Header ----------- */

.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  backdrop-filter: saturate(140%) blur(10px);
  background: color-mix(in oklab, var(--jade) 85%, transparent);
  border-bottom: 1px solid var(--rule-dark);
}

.site-header__inner {
  width: var(--max-w);
  margin-inline: auto;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--s-4);
  padding: var(--s-3) 0;
}
@media (max-width: 48rem) {
  .site-header__inner { grid-template-columns: auto auto; gap: var(--s-3); }
}

.wordmark {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  color: var(--gold);
  line-height: 1;
}
.wordmark img, .wordmark svg { height: 2.4rem; width: auto; }
@media (max-width: 48rem) { .wordmark img, .wordmark svg { height: 1.7rem; } }

.nav {
  display: flex;
  gap: var(--s-5);
  justify-self: end;
  align-items: center;
}
.nav a {
  text-decoration: none;
  font-family: var(--sans);
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-soft);
  font-weight: 500;
}
.nav a:hover,
.nav a[aria-current="page"] { color: var(--gold); }

@media (max-width: 64rem) {
  .nav { gap: var(--s-3); }
  .nav a { font-size: 0.72rem; letter-spacing: 0.14em; }
}
@media (max-width: 48rem) {
  .nav { display: none; }
}

.nav-intro {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 0.95rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--jade);
  background: var(--gold);
  padding: 0.85em 1.4em;
  display: inline-flex;
  align-items: center;
  gap: 0.6em;
  transition: background 220ms var(--ease-out), color 220ms var(--ease-out);
  white-space: nowrap;
}
.nav-intro::after { content: "→"; font-family: var(--sans); transition: transform 240ms var(--ease-out); }
.nav-intro:hover { background: var(--albino); color: var(--jade); }
.nav-intro:hover::after { transform: translateX(4px); }
@media (max-width: 48rem) {
  .nav-intro { font-size: 0.78rem; padding: 0.7em 1em; letter-spacing: 0.12em; }
}

/* ----------- Hero ----------- */

.hero {
  padding: var(--s-9) 0 var(--s-8);
  border-bottom: 1px solid var(--rule-dark);
  position: relative;
  overflow: hidden;
}
.hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}
.hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center right;
  opacity: 0.45;
}

/* Ethereal Shadow — animated SVG-filter mask layer */
.ethereal {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  overflow: hidden;
}
.ethereal__svg {
  position: absolute;
  width: 0;
  height: 0;
}
.ethereal__mask {
  position: absolute;
  inset: -100px;
  background-color: color-mix(in oklab, var(--gold) 55%, var(--jade) 45%);
  -webkit-mask-image: url("/assets/img/ethereal-mask.png");
          mask-image: url("/assets/img/ethereal-mask.png");
  -webkit-mask-size: cover;
          mask-size: cover;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
  filter: url(#ethereal-filter) blur(4px);
  opacity: 0.55;
  mix-blend-mode: screen;
}
.ethereal__noise {
  position: absolute;
  inset: 0;
  background-image: url("/assets/img/ethereal-noise.png");
  background-size: 240px;
  background-repeat: repeat;
  opacity: 0.18;
  mix-blend-mode: overlay;
  pointer-events: none;
}
@media (prefers-reduced-motion: reduce) {
  .ethereal__mask { filter: blur(6px); }
  .ethereal__svg animate { display: none; }
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(110deg, var(--jade) 0%, color-mix(in oklab, var(--jade) 70%, transparent) 45%, transparent 80%),
    linear-gradient(0deg, color-mix(in oklab, var(--jade) 50%, transparent), transparent 60%);
  pointer-events: none;
  z-index: 2;
}
.hero__grid {
  position: relative;
  z-index: 3;
  width: var(--max-w);
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-6);
}
.hero__kicker {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  margin-bottom: var(--s-5);
  color: var(--gold);
}
.hero__kicker .bar { width: 3rem; height: 1px; background: var(--gold); }
.hero__kicker .meta { color: var(--gold); }

.hero__title {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(1.85rem, 7vw, 7rem);
  line-height: 1.0;
  letter-spacing: 0.015em;
  margin: 0;
  max-width: 18ch;
  color: var(--albino);
  text-transform: uppercase;
  overflow-wrap: break-word;
  word-break: normal;
  hyphens: auto;
}
.hero__title em {
  font-style: italic;
  font-weight: 400;
  color: var(--gold);
  text-transform: none;
  letter-spacing: 0;
  font-family: "Cormorant Garamond", "Cinzel", serif;
}

.hero__foot {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-5);
  align-items: end;
  margin-top: var(--s-7);
}
@media (min-width: 64rem) {
  .hero__foot { grid-template-columns: 1.2fr 1fr; gap: var(--s-8); }
}

.hero__lede {
  max-width: 48ch;
  font-size: clamp(1.05rem, 1.3vw, 1.25rem);
  color: var(--ink-soft);
  line-height: 1.6;
}

.hero__meta-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-3);
  padding-top: var(--s-3);
  border-top: 1px solid var(--gold);
}
@media (max-width: 36rem) {
  .hero__meta-row { gap: var(--s-2); }
  .hero__meta-row .figure-num { font-size: 1.4rem; }
  .hero__meta-row .meta { font-size: 0.62rem; letter-spacing: 0.14em; }
}
.hero__meta-row > div .figure-num { display: block; }
.hero__meta-row > div .meta { display: block; margin-top: var(--s-2); color: var(--ink-mute); letter-spacing: 0.18em; }

/* ----------- Section signature ----------- */

.section {
  padding: var(--s-9) 0;
  border-bottom: 1px solid var(--rule-dark);
}
.section--light {
  background: var(--bg-light);
  color: var(--ink-dark);
  border-bottom-color: var(--rule-light);
}
.section--light .meta { color: var(--ink-dark-mute); }
.section--light .figure-num { color: var(--gold-deep); }
.section--light a { color: var(--ink-dark); text-decoration-color: var(--rule-light); }
.section--light a:hover { color: var(--gold-deep); text-decoration-color: var(--gold-deep); }

.section--emerald { background: var(--emerald); }
.section--tall { padding: var(--s-10) 0; }

.section__head {
  width: var(--max-w);
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-4);
  margin-bottom: var(--s-7);
}
@media (min-width: 64rem) {
  .section__head { grid-template-columns: 22ch 1fr; gap: var(--s-7); }
}
.section__kicker {
  border-top: 1px solid var(--gold);
  padding-top: var(--s-2);
  font-family: var(--sans);
  font-size: 0.78rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 600;
}
.section--light .section__kicker { border-top-color: var(--gold-deep); color: var(--gold-deep); }

.section__title {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(1.45rem, 4vw, 3.5rem);
  line-height: 1.08;
  letter-spacing: 0.015em;
  margin: 0;
  max-width: 22ch;
  text-transform: uppercase;
  color: inherit;
  overflow-wrap: break-word;
}
.section__title em {
  font-style: italic;
  font-family: "Cormorant Garamond", serif;
  color: var(--gold);
  text-transform: none;
  letter-spacing: 0;
}
.section--light .section__title em { color: var(--gold-deep); }

/* ----------- Practice ----------- */

.practice {
  width: var(--max-w);
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1fr;
}
.practice > article {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-3);
  padding: var(--s-6) 0;
  border-top: 1px solid var(--rule-dark);
}
.practice > article:last-child { border-bottom: 1px solid var(--rule-dark); }

@media (min-width: 64rem) {
  .practice > article {
    grid-template-columns: 6ch 1fr 1fr;
    gap: var(--s-6);
    align-items: start;
  }
}

.practice__num {
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-weight: 400;
  font-size: 1.4rem;
  color: var(--gold);
  letter-spacing: 0.02em;
}
.practice__title {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(1.3rem, 2.4vw, 2.25rem);
  line-height: 1.1;
  letter-spacing: 0.03em;
  margin: 0;
  max-width: 18ch;
  text-transform: uppercase;
  color: var(--albino);
}
.practice__body { color: var(--ink-soft); max-width: 56ch; }
.practice__body p { margin: 0 0 var(--s-3); }
.practice__more {
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
  font-family: var(--sans);
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  text-decoration: none;
  font-weight: 600;
  color: var(--gold);
  border-bottom: 1px solid var(--gold);
  padding-bottom: 0.4em;
}
.practice__more::after { content: "→"; transition: transform 240ms var(--ease-out); }
.practice__more:hover::after { transform: translateX(4px); }

.practice__media {
  margin: 0;
  overflow: hidden;
  position: relative;
}
.practice__media img {
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  filter: saturate(0.92) contrast(1.02);
  transform: scale(1);
  transition: transform 1200ms var(--ease-out);
}
.practice > article:hover .practice__media img { transform: scale(1.03); }

@media (min-width: 64rem) {
  .practice > article {
    grid-template-columns: 6ch 1.1fr 0.9fr;
  }
}

/* ----------- Philosophy ----------- */

.philosophy { width: var(--max-w); margin-inline: auto; }
.philosophy__quote {
  font-family: "Cormorant Garamond", serif;
  font-weight: 400;
  font-style: italic;
  font-size: clamp(1.85rem, 3.4vw, 3.25rem);
  line-height: 1.18;
  letter-spacing: -0.005em;
  color: var(--albino);
  max-width: 28ch;
  margin: 0 0 var(--s-5);
}
.philosophy__quote::before { content: "“"; color: var(--gold); margin-left: -0.4em; }
.philosophy__quote::after { content: "”"; color: var(--gold); }
.philosophy__attr {
  color: var(--gold);
  font-family: var(--sans);
  font-size: 0.8rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.principles {
  width: var(--max-w);
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  margin-top: var(--s-8);
}
@media (min-width: 64rem) {
  .principles { grid-template-columns: repeat(3, 1fr); column-gap: var(--s-6); }
}
.principles > div {
  padding: var(--s-5) 0;
  border-top: 1px solid var(--gold);
}
.principles h3 {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.05rem;
  line-height: 1.2;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin: 0 0 var(--s-3);
  color: var(--albino);
}
.principles p { color: var(--ink-soft); margin: 0; max-width: 38ch; }

.philosophy__plate {
  width: var(--max-w);
  margin: var(--s-8) auto 0;
  overflow: hidden;
  border-top: 1px solid color-mix(in oklab, var(--gold) 60%, transparent);
  border-bottom: 1px solid color-mix(in oklab, var(--gold) 60%, transparent);
}
.philosophy__plate img {
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  opacity: 0.92;
}

.philosophy__seal {
  width: var(--max-w);
  margin: var(--s-7) auto 0;
  display: flex;
  justify-content: center;
}
.philosophy__seal img {
  width: 6.5rem;
  height: 6.5rem;
  object-fit: cover;
  border-radius: 50%;
  opacity: 0.95;
  box-shadow: 0 0 0 1px color-mix(in oklab, var(--gold) 50%, transparent);
}
.principles .num {
  display: block;
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-size: 1.1rem;
  color: var(--gold);
  margin-bottom: var(--s-3);
}

/* ----------- Insights (works on dark or light section) ----------- */

.insights { width: var(--max-w); margin-inline: auto; }
.insights__list { list-style: none; margin: 0; padding: 0; }
.insights__list li { border-top: 1px solid var(--rule-dark); }
.insights__list li:last-child { border-bottom: 1px solid var(--rule-dark); }
.section--light .insights__list li,
.section--light .insights__list li:last-child { border-color: var(--rule-light); }

.insights__item {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-3);
  padding: var(--s-5) 0;
  text-decoration: none;
  color: inherit;
  transition: padding 280ms var(--ease-out), background 280ms var(--ease-out);
}
.insights__item:hover { padding-inline: var(--s-3); background: color-mix(in oklab, var(--gold) 6%, transparent); }
.section--light .insights__item:hover { background: color-mix(in oklab, var(--gold-deep) 6%, transparent); }

@media (min-width: 64rem) {
  .insights__item { grid-template-columns: 14ch 1fr auto; gap: var(--s-6); align-items: baseline; }
}

.insights__date {
  font-family: var(--sans);
  font-variant-numeric: tabular-nums;
  color: var(--gold);
  font-size: 0.82rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 500;
}
.section--light .insights__date { color: var(--gold-deep); }

.insights__title {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(1.05rem, 1.7vw, 1.55rem);
  line-height: 1.3;
  letter-spacing: 0.02em;
  margin: 0;
  max-width: 50ch;
  text-transform: uppercase;
  overflow-wrap: break-word;
}
.insights__excerpt {
  font-family: var(--sans);
  font-size: 0.95rem;
  color: var(--ink-mute);
  margin: 0.4em 0 0;
  max-width: 60ch;
  text-transform: none;
  letter-spacing: 0;
  line-height: 1.55;
}
.section--light .insights__excerpt { color: var(--ink-dark-mute); }
.insights__cat {
  font-family: var(--sans);
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.section--light .insights__cat { color: var(--ink-dark-mute); }

/* ----------- Contact ----------- */

.contact__plate {
  width: var(--max-w);
  margin: 0 auto var(--s-7);
  overflow: hidden;
}
.contact__plate img {
  width: 100%;
  height: auto;
  aspect-ratio: 21 / 9;
  object-fit: cover;
}
.section--light .contact__plate { filter: none; }

.contact {
  width: var(--max-w);
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-7);
}
@media (min-width: 64rem) {
  .contact { grid-template-columns: 1.1fr 1fr; gap: var(--s-9); align-items: start; }
}
.contact__lead {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(1.55rem, 3.2vw, 3rem);
  line-height: 1.1;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--albino);
  margin: 0 0 var(--s-5);
  max-width: 14ch;
  overflow-wrap: break-word;
}
.section--light .contact__lead { color: var(--jade); }
.contact__lead em {
  font-style: italic;
  font-family: "Cormorant Garamond", serif;
  color: var(--gold);
  text-transform: none;
  letter-spacing: 0;
}
.section--light .contact__lead em { color: var(--gold-deep); }

.contact__detail { color: var(--ink-soft); max-width: 50ch; margin: 0 0 var(--s-5); }
.section--light .contact__detail { color: var(--ink-dark-soft); }

.contact__addresses { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-5); margin-top: var(--s-6); }
.contact__addresses h4 {
  font-family: var(--sans);
  font-size: 0.74rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 0 var(--s-2);
  font-weight: 600;
}
.section--light .contact__addresses h4 { color: var(--gold-deep); }
.contact__addresses p { margin: 0; color: var(--ink-soft); font-size: 0.95rem; line-height: 1.5; }
.section--light .contact__addresses p { color: var(--ink-dark-soft); }

/* ----------- Form ----------- */

.form { display: grid; gap: var(--s-4); }
.field { display: grid; gap: 0.4em; }
.field label {
  font-family: var(--sans);
  font-size: 0.74rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 600;
}
.section--light .field label { color: var(--gold-deep); }

.field input, .field select, .field textarea {
  font: inherit;
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--ink-soft);
  color: var(--albino);
  padding: var(--s-2) 0;
  border-radius: 0;
  font-size: 1.05rem;
}
.section--light .field input,
.section--light .field select,
.section--light .field textarea {
  border-bottom-color: var(--ink-dark);
  color: var(--ink-dark);
}
.field input:focus, .field select:focus, .field textarea:focus { outline: 0; border-bottom-color: var(--gold); }
.field textarea { resize: vertical; min-height: 5.5rem; }
.field select option { color: #000; }

.form__row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-4); }
@media (max-width: 40rem) { .form__row { grid-template-columns: 1fr; } }

.submit {
  margin-top: var(--s-3);
  display: inline-flex;
  align-items: center;
  gap: 0.6em;
  font-family: var(--serif);
  font-size: 0.92rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 400;
  background: var(--gold);
  color: var(--jade);
  border: 0;
  padding: 1.1em 1.8em;
  border-radius: 0;
  transition: background 240ms var(--ease-out);
  justify-self: start;
}
.submit:hover { background: var(--albino); }
.submit::after { content: "→"; transition: transform 240ms var(--ease-out); }
.submit:hover::after { transform: translateX(4px); }

/* ----------- Footer ----------- */

.site-footer {
  padding: var(--s-7) 0 var(--s-5);
  background: var(--jade-deep);
  color: var(--ink-soft);
  border-top: 1px solid var(--rule-dark);
}
.site-footer__inner {
  width: var(--max-w);
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-6);
}
@media (min-width: 64rem) {
  .site-footer__inner { grid-template-columns: 2fr 1fr 1fr 1fr; gap: var(--s-7); }
}
.site-footer .wordmark img,
.site-footer .wordmark svg { height: 2.6rem; }
.site-footer h5 {
  font-family: var(--sans);
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 0 var(--s-3);
  font-weight: 600;
}
.site-footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 0.6em; font-size: 0.92rem; }
.site-footer a { text-decoration: none; color: var(--ink-soft); }
.site-footer a:hover { color: var(--gold); }
.site-footer p { color: var(--ink-mute); font-size: 0.85rem; line-height: 1.55; max-width: 36ch; }

.legal {
  width: var(--max-w);
  margin: var(--s-7) auto 0;
  padding-top: var(--s-4);
  border-top: 1px solid var(--rule-dark);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: var(--s-3);
  font-size: 0.74rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

/* ----------- Page-load fade-in (no scroll dependency) ----------- */

@keyframes appear {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: none; }
}

[data-reveal] {
  animation: appear 700ms var(--ease-out) both;
  animation-delay: var(--reveal-delay, 0ms);
}

@media (prefers-reduced-motion: reduce) {
  [data-reveal] { animation: none; }
  * { animation: none !important; transition: none !important; }
}
