/* ====================================================================
   Elements Health & Wellness Coaching
   The Art of Balanced Living · Michele "Emme" Ramsey
   Editorial Apothecary · warm, restrained, four-element accent system
   ==================================================================== */

:root {
  /* ink + paper — harmonized with the logo's warm maroon + cream */
  --ink:       #3A2620;
  --ink-soft:  #534039;
  --paper:     #F5EFE3;
  --paper-2:   #ECE4D2;
  --mute:      #948571;
  --rule:      #D5C9B4;

  /* brand accents */
  --gold:      #B8894D;
  --coral:     #C46A3E;
  --coral-ink: #9B4D29;

  /* element colors — muted from logo, used sparingly as accents */
  --earth:     #7A8C4F;
  --air:       #A7ADB2;
  --fire:      #C46A3E;
  --water:     #6F8B9C;

  /* type */
  --serif:     "Cormorant Garamond", "Playfair Display", Georgia, serif;
  --sans:      "Inter", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;
  --mono:      "IBM Plex Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;
  --script:    "Caveat", "Cormorant Garamond", cursive;

  /* layout */
  --page-max:  1440px;
  --gutter:    clamp(20px, 4vw, 56px);
  --rail:      clamp(16px, 2.5vw, 40px);
  --stack:     clamp(64px, 10vw, 140px);

  /* motion */
  --ease:      cubic-bezier(.2,.7,.2,1);
}

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

html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; }
}

body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  font-weight: 400;
  font-size: clamp(15px, 1.05vw, 17px);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

a { color: inherit; text-decoration: none; }
img, svg { display: block; max-width: 100%; }
button { font: inherit; }

/* ------------------------------------------------------------ type */
.serif,
.serif-display { font-family: var(--serif); font-weight: 500; letter-spacing: -0.01em; }
.serif-italic  { font-family: var(--serif); font-style: italic; font-weight: 400; }
.mono { font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.14em; text-transform: uppercase; font-weight: 500; }
.muted { color: var(--mute); }

.signature {
  font-family: var(--script);
  font-size: clamp(2rem, 3.5vw, 3rem);
  color: var(--gold);
  font-weight: 600;
  line-height: 1;
  display: inline-block;
  transform: rotate(-2deg);
  margin-top: 24px;
}
.signature--lg { font-size: clamp(2.8rem, 5vw, 4.2rem); }

/* ------------------------------------------------------------ nav */
.nav {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 50;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 18px var(--gutter);
  background: color-mix(in oklab, var(--paper) 86%, transparent);
  backdrop-filter: saturate(140%) blur(10px);
  -webkit-backdrop-filter: saturate(140%) blur(10px);
  border-bottom: 1px solid transparent;
  transition: transform .5s var(--ease), border-color .3s var(--ease);
}
.nav.is-scrolled { border-color: var(--rule); }
.nav.is-hidden { transform: translateY(-110%); }

.nav__mark { display: inline-flex; align-items: baseline; gap: 10px; }
.nav__mark-word { font-family: var(--serif); font-weight: 600; font-size: 1.25rem; letter-spacing: -0.005em; }
.nav__mark-sub { font-size: 0.62rem; transform: translateY(-2px); }

.nav__links { justify-self: center; display: flex; gap: clamp(14px, 2.5vw, 30px); }
.nav__links a {
  font-family: var(--mono);
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 8px 2px;
  position: relative;
}
.nav__links a::after {
  content: "";
  position: absolute; left: 0; right: 100%; bottom: 2px;
  height: 1px; background: currentColor;
  transition: right .4s var(--ease);
}
.nav__links a:hover::after,
.nav__links a:focus-visible::after { right: 0; }

.nav__cta {
  justify-self: end;
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--mono); font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase;
  padding: 10px 16px;
  border: 1px solid var(--ink);
  border-radius: 999px;
  transition: background .3s var(--ease), color .3s var(--ease);
}
.nav__cta:hover { background: var(--ink); color: var(--paper); }
.nav__cta-arrow { transition: transform .3s var(--ease); }
.nav__cta:hover .nav__cta-arrow { transform: translateX(3px); }

@media (max-width: 820px) {
  .nav { grid-template-columns: auto 1fr auto; gap: 10px; }
  .nav__links { display: none; }
}

/* ------------------------------------------------------------ buttons */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 16px 24px;
  font-family: var(--mono);
  font-size: 0.78rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  border-radius: 2px;
  cursor: pointer;
  transition: transform .3s var(--ease), background .3s var(--ease), color .3s var(--ease), border-color .3s var(--ease);
}
.btn--solid { background: var(--ink); color: var(--paper); }
.btn--solid:hover { background: var(--coral); color: var(--paper); }
.btn--ghost { background: transparent; color: var(--ink); border: 1px solid var(--ink); }
.btn--ghost:hover { background: var(--ink); color: var(--paper); }
.btn--xl { padding: 22px 32px; font-size: 0.85rem; }
.btn__arrow { transition: transform .3s var(--ease); }
.btn:hover .btn__arrow { transform: translateX(4px); }

/* ============================================================ HERO */
.hero {
  position: relative;
  min-height: 100svh;
  padding: calc(100px + var(--rail)) var(--gutter) var(--stack);
  overflow: hidden;
  isolation: isolate;
}

.hero__grid {
  position: relative; z-index: 2;
  max-width: var(--page-max); margin-inline: auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(32px, 6vw, 80px);
}

.hero__eyebrow { padding-top: clamp(8px, 2vw, 24px); }

.hero__heading {
  margin: 0;
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(3rem, 11vw, 10.5rem);
  line-height: 0.92;
  letter-spacing: -0.025em;
  text-wrap: balance;
}
.hero__heading .serif-display { display: block; }
.hero__heading .serif-italic { display: block; color: var(--coral-ink); font-weight: 500; }

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

.hero__ctas { display: flex; flex-wrap: wrap; gap: 14px; }

.hero__meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(16px, 3vw, 32px);
  padding-top: clamp(24px, 5vw, 56px);
  border-top: 1px solid var(--rule);
}
.hero__meta-cell { display: flex; flex-direction: column; gap: 8px; }
.hero__meta-cell .serif { font-size: 1.15rem; line-height: 1.3; }
@media (max-width: 680px) { .hero__meta { grid-template-columns: 1fr; } }

.hero__ambient { position: absolute; inset: 0; z-index: 0; pointer-events: none; }
.hero__ambient-layer {
  position: absolute; inset: -10%;
  filter: blur(40px);
  transform: translate3d(0,0,0);
  transition: transform 2s var(--ease);
  opacity: .8;
}
.hero__ambient-layer--a {
  top: -18%; left: -12%; width: 60%; height: 60%;
  background: radial-gradient(closest-side, rgba(122,140,79,0.18), transparent 72%);
}
.hero__ambient-layer--b {
  bottom: -14%; right: -10%; width: 55%; height: 55%;
  background: radial-gradient(closest-side, rgba(196,106,62,0.14), transparent 72%);
}
.hero__ambient-layer--c {
  top: 30%; left: 45%; width: 40%; height: 40%;
  background: radial-gradient(closest-side, rgba(111,139,156,0.12), transparent 72%);
}

/* ============================================================ PREMISE */
.premise {
  padding: var(--stack) var(--gutter);
  max-width: var(--page-max);
  margin-inline: auto;
  display: grid;
  grid-template-columns: minmax(160px, 1fr) minmax(0, 3fr);
  gap: clamp(20px, 4vw, 64px);
  border-top: 1px solid var(--rule);
}
.rail { padding-top: 12px; }
.premise__heading {
  margin: 0 0 28px;
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(2.2rem, 5.8vw, 5rem);
  line-height: 1.05;
  letter-spacing: -0.02em;
  text-wrap: balance;
}
.premise__heading .serif-italic { color: var(--coral-ink); }
.premise__body {
  max-width: 64ch;
  font-size: clamp(1.05rem, 1.25vw, 1.2rem);
  line-height: 1.65;
  color: var(--ink-soft);
  margin: 0 0 20px;
}
@media (max-width: 820px) { .premise { grid-template-columns: 1fr; } }

/* ============================================================ SECTION HEAD */
.section-head {
  max-width: var(--page-max);
  margin-inline: auto;
  padding: 0 var(--gutter);
  display: grid;
  grid-template-columns: minmax(160px, 1fr) minmax(0, 3fr);
  gap: clamp(20px, 4vw, 64px);
  align-items: end;
  margin-bottom: clamp(40px, 6vw, 80px);
}
.section-head > .mono { padding-top: 8px; }
.section-head__title {
  margin: 0;
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(2.4rem, 6.2vw, 6rem);
  line-height: 0.98;
  letter-spacing: -0.022em;
}
.section-head__title .serif-display { display: block; }
.section-head__title .serif-italic { display: block; color: var(--coral-ink); }
.section-head__deck {
  grid-column: 2;
  max-width: 64ch;
  font-size: clamp(1rem, 1.2vw, 1.15rem);
  color: var(--ink-soft);
  margin: 24px 0 0;
  line-height: 1.65;
}
@media (max-width: 820px) {
  .section-head { grid-template-columns: 1fr; }
  .section-head__deck { grid-column: 1; }
}

/* ============================================================ ELEMENTS / MANDALA */
.elements {
  padding: var(--stack) 0;
  border-top: 1px solid var(--rule);
}
.elements__mandala {
  max-width: var(--page-max);
  margin: 0 auto;
  padding: 0 var(--gutter);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}
.elements__logo {
  width: clamp(280px, 42vw, 520px);
  aspect-ratio: 1;
  object-fit: contain;
  filter: drop-shadow(0 10px 40px rgba(58,38,32,0.08));
  transition: transform .8s var(--ease);
}
.elements__logo:hover { transform: rotate(4deg) scale(1.02); }
.elements__caption { display: block; }

.elements__quadrants {
  list-style: none; margin: clamp(56px, 8vw, 110px) auto 0; padding: 0 var(--gutter);
  max-width: var(--page-max);
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px;
  background: var(--rule);
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}
.quad {
  background: var(--paper);
  padding: clamp(28px, 3vw, 44px);
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: background .5s var(--ease);
  position: relative;
  overflow: hidden;
}
.quad::before {
  content: "";
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: var(--element, var(--coral));
  transform-origin: left;
  transform: scaleX(.2);
  transition: transform .8s var(--ease);
}
.quad:hover::before { transform: scaleX(1); }
.quad--earth { --element: var(--earth); }
.quad--air   { --element: var(--air);   }
.quad--fire  { --element: var(--fire);  }
.quad--water { --element: var(--water); }

.quad__glyph {
  font-size: clamp(2.4rem, 3.2vw, 3.4rem);
  line-height: 1;
  color: var(--element, var(--ink));
  font-style: italic;
  opacity: .9;
}
.quad__name {
  font-size: clamp(1.6rem, 2.4vw, 2.4rem);
  line-height: 1;
  margin: 0;
  letter-spacing: -0.01em;
}
.quad__word { display: inline-block; }
.quad__body {
  margin: 0;
  font-size: 0.98rem;
  line-height: 1.6;
  color: var(--ink-soft);
}
@media (max-width: 980px) { .elements__quadrants { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .elements__quadrants { grid-template-columns: 1fr; } }

.pullquote {
  margin: clamp(64px, 9vw, 140px) auto 0;
  max-width: 1080px;
  padding: 0 var(--gutter);
  text-align: center;
}
.pullquote__body {
  font-family: var(--serif);
  font-size: clamp(1.8rem, 4vw, 3.4rem);
  line-height: 1.2;
  letter-spacing: -0.01em;
  margin: 0;
}
.pullquote__cite { display: block; margin-top: 24px; color: var(--mute); }

/* ============================================================ PRACTICE / SERVICES */
.practice {
  padding: var(--stack) 0;
  border-top: 1px solid var(--rule);
}
.services__grid {
  max-width: var(--page-max);
  margin: 0 auto;
  padding: 0 var(--gutter);
  display: grid;
  grid-template-columns: 1.3fr 1fr 1fr;
  gap: 1px;
  background: var(--rule);
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}
.service {
  background: var(--paper);
  padding: clamp(28px, 3.4vw, 52px);
  display: flex;
  flex-direction: column;
  gap: 18px;
  min-height: 440px;
  transition: background .5s var(--ease);
  position: relative;
}
.service--primary { background: var(--paper-2); }
.service:hover { background: var(--ink); color: var(--paper); }
.service:hover .service__meta li { border-color: color-mix(in oklab, var(--paper) 35%, transparent); }
.service:hover .service__meta .muted { color: color-mix(in oklab, var(--paper) 65%, transparent); }
.service:hover .service__index { color: var(--coral); }

.service__index {
  align-self: flex-start;
  font-size: 0.72rem;
  padding: 4px 10px;
  border: 1px solid currentColor;
  border-radius: 2px;
}
.service__title {
  margin: 0;
  font-size: clamp(1.8rem, 2.6vw, 2.8rem);
  line-height: 1.05;
  letter-spacing: -0.015em;
}
.service__deck { font-size: 1rem; line-height: 1.6; margin: 0; flex: 1; }
.service__meta { list-style: none; margin: 0; padding: 0; }
.service__meta li {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 12px;
  padding: 10px 0;
  border-top: 1px solid var(--rule);
  font-family: var(--mono);
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.service__meta li:last-child { border-bottom: 1px solid var(--rule); }
.service__link {
  display: inline-flex; align-items: center; gap: 10px;
  align-self: flex-start;
  font-family: var(--mono); font-size: 0.76rem; letter-spacing: 0.16em; text-transform: uppercase;
  padding-top: 6px;
}
.service__link span:last-child { transition: transform .3s var(--ease); }
.service__link:hover span:last-child { transform: translateX(4px); }

@media (max-width: 980px) {
  .services__grid { grid-template-columns: 1fr; }
  .service { min-height: 0; }
}

/* ============================================================ CREDENTIALS / STAMPS */
.credentials {
  padding: var(--stack) 0;
  border-top: 1px solid var(--rule);
}
.stamps {
  list-style: none; margin: 0 auto; padding: 0 var(--gutter);
  max-width: var(--page-max);
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 24px;
}
.stamp {
  background: var(--paper);
  border: 1px solid var(--ink);
  padding: 28px;
  min-height: 240px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 12px;
  transition: transform .4s var(--ease), background .4s var(--ease), color .4s var(--ease);
}
.stamp:hover { background: var(--ink); color: var(--paper); transform: translateY(-3px); }
.stamp:hover .muted { color: color-mix(in oklab, var(--paper) 65%, transparent); }
.stamp__title { font-size: clamp(1.35rem, 2.1vw, 2rem); line-height: 1.08; margin: 0; }
.stamp__kicker { display: block; }
.stamp__meta { display: block; font-size: 0.62rem; }
@media (max-width: 980px) { .stamps { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .stamps { grid-template-columns: 1fr; } }

/* ============================================================ ABOUT */
.about {
  padding: var(--stack) var(--gutter);
  max-width: var(--page-max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: clamp(32px, 6vw, 96px);
  align-items: start;
  border-top: 1px solid var(--rule);
}
.about__portrait { position: sticky; top: 100px; }
.about__portrait-frame {
  aspect-ratio: 3/4;
  background:
    linear-gradient(135deg, rgba(58,38,32,.08) 0%, transparent 60%),
    var(--paper-2);
  border: 1px solid var(--ink);
  position: relative;
  overflow: hidden;
}
.about__portrait-frame::before {
  content: "[EMME PORTRAIT]";
  position: absolute; inset: 0;
  display: grid; place-items: center;
  font-family: var(--mono); font-size: 0.68rem; letter-spacing: 0.2em; color: var(--mute);
}
.about__portrait-caption {
  position: absolute; bottom: 14px; left: 14px; right: 14px;
  display: flex; justify-content: space-between;
}
.about__copy > .mono { display: block; }
.about__heading {
  margin: 14px 0 28px;
  font-family: var(--serif); font-weight: 500;
  font-size: clamp(2.2rem, 5.2vw, 4.6rem); line-height: 1.0; letter-spacing: -0.022em;
  text-wrap: balance;
}
.about__heading .serif-display { display: block; }
.about__heading .serif-italic { display: inline; color: var(--coral-ink); }
.about__para {
  font-size: clamp(1rem, 1.15vw, 1.15rem);
  line-height: 1.7;
  max-width: 60ch;
  margin: 0 0 18px;
  color: var(--ink-soft);
}
.about__facts {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0;
  margin-top: 32px;
  font-family: var(--mono);
  font-size: 0.76rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.about__facts > div {
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
  padding: 14px 0;
  border-top: 1px solid var(--rule);
}
.about__facts dt, .about__facts dd { margin: 0; }
@media (max-width: 980px) {
  .about { grid-template-columns: 1fr; }
  .about__portrait { position: static; max-width: 380px; }
  .about__facts { grid-template-columns: 1fr; }
}

/* ============================================================ VOICES / TESTIMONIALS */
.voices {
  padding: var(--stack) 0;
  border-top: 1px solid var(--rule);
}
.voices__grid {
  max-width: var(--page-max);
  margin: 0 auto;
  padding: 0 var(--gutter);
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: clamp(20px, 3vw, 40px);
}
.voice {
  margin: 0;
  padding: clamp(24px, 3vw, 44px);
  position: relative;
  transition: background .4s var(--ease), color .4s var(--ease);
}
.voice--a { grid-column: 1 / span 7; background: var(--paper-2); }
.voice--b { grid-column: 8 / span 5; background: var(--paper); border: 1px solid var(--ink); }
.voice--c { grid-column: 3 / span 8; background: var(--ink); color: var(--paper); }
.voice--c .voice__cite .muted { color: color-mix(in oklab, var(--paper) 65%, transparent); }
.voice__body {
  font-family: var(--serif);
  font-size: clamp(1.4rem, 2.2vw, 2.2rem);
  line-height: 1.24;
  margin: 0 0 20px;
  text-wrap: pretty;
}
.voice__cite { display: flex; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
@media (max-width: 980px) {
  .voice--a, .voice--b, .voice--c { grid-column: 1 / -1; }
}

/* ============================================================ JOURNAL */
.journal {
  padding: var(--stack) 0;
  border-top: 1px solid var(--rule);
}
.journal__list {
  list-style: none; margin: 0 auto; padding: 0 var(--gutter);
  max-width: var(--page-max);
}
.journal__item {
  display: grid;
  grid-template-columns: 200px 1fr auto;
  gap: clamp(16px, 3vw, 40px);
  align-items: baseline;
  padding: 32px 0;
  border-top: 1px solid var(--rule);
  transition: padding .3s var(--ease);
}
.journal__item:last-child { border-bottom: 1px solid var(--rule); }
.journal__item:hover { padding-inline-start: 18px; }
.journal__meta { display: flex; flex-direction: column; gap: 4px; }
.journal__title {
  margin: 0;
  font-size: clamp(1.4rem, 2.4vw, 2.2rem);
  line-height: 1.18;
  letter-spacing: -0.015em;
  text-wrap: balance;
}
.journal__link { white-space: nowrap; }
@media (max-width: 820px) {
  .journal__item { grid-template-columns: 1fr; }
  .journal__link { justify-self: start; }
}

/* ============================================================ FAQ */
.faq {
  padding: var(--stack) 0;
  border-top: 1px solid var(--rule);
}
.faq__list {
  max-width: 960px;
  margin: 0 auto;
  padding: 0 var(--gutter);
}
.faq__item {
  padding: 28px 0;
  border-top: 1px solid var(--rule);
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: clamp(20px, 4vw, 60px);
}
.faq__item:last-child { border-bottom: 1px solid var(--rule); }
.faq__item dt {
  font-family: var(--serif);
  font-size: clamp(1.15rem, 1.8vw, 1.6rem);
  line-height: 1.2;
}
.faq__item dd {
  margin: 0;
  font-size: clamp(0.98rem, 1.05vw, 1.08rem);
  line-height: 1.65;
  color: var(--ink-soft);
}
@media (max-width: 820px) { .faq__item { grid-template-columns: 1fr; } }

/* ============================================================ CTA */
.cta {
  padding: var(--stack) var(--gutter);
  background: var(--ink);
  color: var(--paper);
  border-top: 1px solid var(--ink);
}
.cta__inner { max-width: 1100px; margin: 0 auto; }
.cta__inner > .mono { color: color-mix(in oklab, var(--paper) 55%, transparent); display: block; }
.cta__heading {
  margin: 18px 0 24px;
  font-family: var(--serif); font-weight: 500;
  font-size: clamp(2.6rem, 7vw, 7rem); line-height: 0.95; letter-spacing: -0.025em;
  text-wrap: balance;
}
.cta__heading .serif-display { display: block; }
.cta__heading .serif-italic { display: block; color: var(--gold); }
.cta__body {
  max-width: 60ch;
  font-size: clamp(1.05rem, 1.3vw, 1.25rem);
  line-height: 1.6;
  color: color-mix(in oklab, var(--paper) 85%, transparent);
  margin: 0 0 36px;
}
.cta .btn--solid { background: var(--coral); color: var(--paper); }
.cta .btn--solid:hover { background: var(--paper); color: var(--ink); }
.cta__fine { margin-top: 22px; color: color-mix(in oklab, var(--paper) 55%, transparent); }

/* ============================================================ FOOTER */
.foot { background: var(--paper); padding: clamp(48px, 6vw, 80px) var(--gutter) 32px; }
.foot__row {
  max-width: var(--page-max);
  margin: 0 auto 40px;
  display: grid;
  grid-template-columns: 1.2fr 2fr;
  gap: clamp(24px, 4vw, 60px);
  align-items: start;
}
.foot__brand { display: flex; flex-direction: column; gap: 8px; }
.foot__logo { width: 80px; height: 80px; object-fit: contain; margin-bottom: 8px; opacity: .95; }
.foot__mark { font-size: clamp(1.4rem, 2vw, 2rem); }
.foot__nav {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(20px, 3vw, 40px);
}
.foot__nav > div { display: flex; flex-direction: column; gap: 10px; }
.foot__nav a { font-family: var(--serif); font-size: 1.08rem; letter-spacing: -0.005em; }
.foot__nav a:hover { text-decoration: underline; text-underline-offset: 4px; }
.foot__rule { max-width: var(--page-max); margin: 0 auto; height: 1px; background: var(--rule); }
.foot__meta {
  max-width: var(--page-max);
  margin: 0 auto;
  padding-top: 20px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px;
}
.foot__meta a:hover { color: var(--ink); }
@media (max-width: 820px) {
  .foot__row { grid-template-columns: 1fr; }
  .foot__nav { grid-template-columns: 1fr 1fr; }
  .foot__meta { flex-direction: column; }
}

/* ============================================================ SCROLL REVEAL */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.is-in { opacity: 1; transform: translateY(0); }

/* ============================================================ SELECTION + FOCUS */
::selection { background: var(--ink); color: var(--gold); }
:focus-visible { outline: 2px solid var(--coral); outline-offset: 3px; border-radius: 2px; }
