/* =========================================================
   STONE — Design System
   Vibe: Editorial Luxury · Layout: Editorial Split
   ========================================================= */

:root {
  /* Palette */
  --paper:        #f4eee3;
  --paper-deep:   #ebe3d4;
  --ink:          #1a1612;
  --ink-soft:     #3a342d;
  --ink-mute:     #6b6358;
  --espresso:     #221b14;
  --ember:        #8a5a3a;
  --hairline:     rgba(26, 22, 18, 0.10);
  --hairline-soft:rgba(26, 22, 18, 0.05);
  --hairline-inv: rgba(244, 238, 227, 0.10);

  /* Type */
  --serif:    'Cormorant Garamond', 'Cormorant', ui-serif, Georgia, serif;
  --grotesk:  'Geist', ui-sans-serif, system-ui, sans-serif;

  /* Motion */
  --ease-fluid: cubic-bezier(0.32, 0.72, 0, 1);
  --ease-ink:   cubic-bezier(0.22, 1, 0.36, 1);

  /* Spacing scale */
  --gutter:     clamp(1.5rem, 4vw, 3rem);
  --section:    clamp(6rem, 14vh, 10rem);
}

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

/* Screen-reader-only utility — visually hidden, indexable, AT-readable */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Skip link — visible only on keyboard focus */
.skip-link {
  position: fixed;
  top: 0;
  left: 50%;
  transform: translate(-50%, -120%);
  padding: 0.75rem 1.5rem;
  background: var(--ink);
  color: var(--paper);
  font-family: var(--grotesk);
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: 0 0 12px 12px;
  z-index: 999;
  transition: transform 400ms var(--ease-fluid);
}
.skip-link:focus-visible {
  transform: translate(-50%, 0);
  outline: none;
}

/* Focus rings — keyboard a11y, harmonized with the palette */
:focus { outline: none; }
:focus-visible {
  outline: 2px solid var(--ink);
  outline-offset: 4px;
  border-radius: 6px;
}
.nav-links a:focus-visible,
.nav-mark:focus-visible {
  outline-offset: 6px;
}
.nav-cta:focus-visible,
.cta-primary:focus-visible {
  outline-offset: 4px;
  border-radius: 999px;
}

body {
  font-family: var(--grotesk);
  font-weight: 400;
  color: var(--ink);
  background: var(--paper);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  letter-spacing: 0.005em;
  line-height: 1.6;
  overflow-x: hidden;
}

@media (hover: hover) and (pointer: fine) {
  body {
    cursor: url('pick-cursor.svg') 9 1, auto;
  }

  a,
  button,
  [role="button"] {
    cursor: url('pick-cursor.svg') 9 1, pointer;
  }

  input,
  textarea {
    cursor: text;
  }
}

/* Paper grain overlay — fixed, never scrolls, GPU cheap */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  z-index: 100;
  pointer-events: none;
  opacity: 0.045;
  mix-blend-mode: multiply;
  background-image:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.6 0'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
}

/* Vignette wash to anchor the page edges */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  z-index: 99;
  pointer-events: none;
  background:
    radial-gradient(ellipse at center, transparent 55%, rgba(26, 22, 18, 0.08) 100%);
}

.pick-resonance {
  position: fixed;
  left: 0;
  top: 0;
  width: 3rem;
  height: 3rem;
  z-index: 240;
  pointer-events: none;
  border: 1px solid rgba(138, 90, 58, 0.38);
  border-radius: 64% 48% 72% 44% / 54% 44% 74% 46%;
  background:
    radial-gradient(circle at 34% 28%, rgba(244, 238, 227, 0.28), transparent 42%),
    rgba(138, 90, 58, 0.08);
  transform: translate3d(var(--x), var(--y), 0) translate(-50%, -50%) rotate(32deg) scale(0.55);
  opacity: 0;
  animation: pick-resonance 680ms var(--ease-ink) forwards;
}
@keyframes pick-resonance {
  0% {
    opacity: 0.62;
    transform: translate3d(var(--x), var(--y), 0) translate(-50%, -50%) rotate(32deg) scale(0.45);
  }
  42% {
    opacity: 0.34;
  }
  100% {
    opacity: 0;
    transform: translate3d(var(--x), var(--y), 0) translate(-50%, -50%) rotate(32deg) scale(2.2);
  }
}

body.is-resonating main,
body.is-resonating .footer {
  animation: page-resonance 520ms var(--ease-ink);
}
@keyframes page-resonance {
  0%, 100% { transform: translate3d(0, 0, 0); }
  18% { transform: translate3d(0.8px, -0.5px, 0); }
  34% { transform: translate3d(-0.7px, 0.45px, 0); }
  52% { transform: translate3d(0.45px, 0.35px, 0); }
  70% { transform: translate3d(-0.3px, -0.25px, 0); }
}

/* =========================================================
   Navigation — Fluid Glass Island
   ========================================================= */

.nav {
  position: fixed;
  top: 1.5rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 200;
  display: flex;
  align-items: center;
  gap: 0;
  padding: 0.5rem 0.5rem 0.5rem 1.25rem;
  background: rgba(244, 238, 227, 0.72);
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  border-radius: 999px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.4),
    0 1px 0 rgba(26, 22, 18, 0.04),
    0 12px 32px -16px rgba(26, 22, 18, 0.18);
  font-family: var(--grotesk);
  font-size: 0.78rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.nav-links {
  display: flex;
  gap: 1.5rem;
  align-items: center;
}
.nav-links a {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  color: var(--ink-soft);
  text-decoration: none;
  font-weight: 500;
  transition: color 400ms var(--ease-fluid);
  position: relative;
}
.nav-links a:hover { color: var(--ink); }

.nav-dot {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--ink);
  opacity: 0;
  transform: scale(0.6);
  transition:
    opacity 400ms var(--ease-fluid),
    transform 500ms var(--ease-fluid);
}
.nav-links a.is-active { color: var(--ink); }
.nav-links a.is-active .nav-dot {
  opacity: 1;
  transform: scale(1);
}

.nav-cta {
  margin-left: 1.5rem;
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.55rem 0.55rem 0.55rem 1.1rem;
  background: var(--ink);
  color: var(--paper);
  border-radius: 999px;
  text-decoration: none;
  font-weight: 500;
  font-size: 0.74rem;
  letter-spacing: 0.16em;
  transition: transform 400ms var(--ease-fluid), background 400ms var(--ease-fluid);
}
.nav-cta:hover { background: var(--espresso); }
.nav-cta:active { transform: scale(0.98); }
.nav-cta-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: rgba(244, 238, 227, 0.16);
  transition: transform 450ms var(--ease-fluid);
}
.nav-cta:hover .nav-cta-icon {
  transform: translate(2px, -1px);
}
.nav-cta-icon svg { width: 10px; height: 10px; stroke: var(--paper); }

/* =========================================================
   Hero — Editorial Split
   ========================================================= */

.hero {
  min-height: 100dvh;
  padding: clamp(7rem, 16vh, 10rem) var(--gutter) var(--section);
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: clamp(2rem, 5vw, 6rem);
  align-items: center;
  position: relative;
  max-width: 1600px;
  margin: 0 auto;
}

.hero-left {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 2.25rem;
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
  padding: 0.4rem 0.9rem;
  border: 1px solid var(--hairline);
  border-radius: 999px;
  background: rgba(244, 238, 227, 0.4);
  font-size: 0.66rem;
  font-weight: 500;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink-soft);
  width: fit-content;
}
.eyebrow-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--ember);
}

/* Brand watermark — fixed background, stays stationary on scroll */
.brand-watermark {
  position: fixed;
  top: 50%;
  left: 50%;
  width: min(82vw, 1500px);
  aspect-ratio: 2224 / 924;
  background-color: var(--espresso);
  -webkit-mask: url(stone_logo.svg) center / contain no-repeat;
          mask: url(stone_logo.svg) center / contain no-repeat;
  opacity: 0;
  z-index: 1;
  pointer-events: none;
  transform: translate(-50%, -50%);
  animation: watermark-bleed 1800ms var(--ease-ink) 300ms forwards;
  will-change: opacity;
}
@keyframes watermark-bleed {
  0%   { opacity: 0; }
  100% { opacity: 0.07; }
}

/* Lift all content above the watermark */
.hero,
.provenance,
.manifestations,
.rites { z-index: 2; }

.hero-headline {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(2.5rem, 5.8vw, 5rem);
  line-height: 1.02;
  letter-spacing: -0.015em;
  color: var(--ink);
  margin: 0;
  max-width: 18ch;
  text-wrap: balance;
}
.hero-headline em {
  font-style: italic;
  color: var(--ink-soft);
}

.hero-lede {
  font-family: var(--grotesk);
  font-size: clamp(1rem, 1.15vw, 1.125rem);
  line-height: 1.65;
  color: var(--ink-mute);
  max-width: 42ch;
  margin: 0;
}

.hero-meta {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  margin-top: 0.5rem;
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.hero-meta-rule {
  display: inline-block;
  width: 32px;
  height: 1px;
  background: var(--ink-mute);
}

/* Hero right — Plate (instrument display) */

.hero-plate {
  position: relative;
  width: 100%;
}

.plate-frame {
  position: relative;
  padding: 0.5rem;
  background: linear-gradient(180deg, rgba(26,22,18,0.04), rgba(26,22,18,0.02));
  border: 1px solid var(--hairline);
  border-radius: 1.5rem;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.5),
    0 30px 60px -40px rgba(26, 22, 18, 0.35);
}
.plate-inner {
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: calc(1.5rem - 0.5rem);
  background:
    /* warm spotlight upper-left */
    radial-gradient(ellipse 80% 60% at 28% 22%, rgba(255, 220, 170, 0.18), transparent 60%),
    /* ember wash lower-right */
    radial-gradient(ellipse at 75% 78%, rgba(168, 110, 70, 0.22), transparent 65%),
    /* warm wood-toned base */
    linear-gradient(165deg, #3a2a1d 0%, #261a12 55%, #15100a 100%);
  overflow: hidden;
  box-shadow:
    inset 0 1px 0 rgba(255, 220, 180, 0.10),
    inset 0 0 80px rgba(0, 0, 0, 0.55);
}
/* Fine wood-grain noise on the plate — subtle, not literal */
.plate-inner::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='400' height='400'><filter id='g'><feTurbulence type='fractalNoise' baseFrequency='0.012 0.6' numOctaves='2' seed='4'/><feColorMatrix values='0 0 0 0 0.4  0 0 0 0 0.28  0 0 0 0 0.18  0 0 0 0.5 0'/></filter><rect width='400' height='400' filter='url(%23g)'/></svg>"),
    radial-gradient(ellipse 50% 40% at 26% 18%, rgba(255, 220, 180, 0.20), transparent 70%);
  opacity: 0.35;
  mix-blend-mode: overlay;
  pointer-events: none;
}
.plate-inner::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 38%;
  background: linear-gradient(to top, rgba(0,0,0,0.55), transparent);
  pointer-events: none;
}
/* Museum nameplate — sits below the photographed plate */
.plate-caption {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.55rem 1.25rem;
  margin: 0.95rem 0.25rem 0.35rem;
  padding-top: 0.85rem;
  border-top: 1px solid var(--hairline);
  font-family: var(--grotesk);
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  color: var(--ink-soft);
}
.plate-caption dt {
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  font-size: 0.6rem;
  color: var(--ink-mute);
  padding-top: 0.1em;
}
.plate-caption dd {
  margin: 0;
  font-family: var(--serif);
  font-size: 0.95rem;
  letter-spacing: 0.005em;
  color: var(--ink);
  font-style: italic;
}

/* Plate corner serial */
.plate-serial {
  position: absolute;
  top: 1.5rem;
  right: 1.5rem;
  z-index: 3;
  font-family: var(--grotesk);
  font-size: 0.62rem;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: rgba(244, 238, 227, 0.7);
  text-align: right;
  line-height: 1.4;
  text-shadow: 0 1px 8px rgba(0, 0, 0, 0.6);
}
.plate-serial-num {
  display: block;
  font-family: var(--serif);
  font-size: 1.55rem;
  font-style: italic;
  letter-spacing: 0.02em;
  color: rgba(244, 238, 227, 0.92);
  margin-top: 0.35rem;
}

/* Status pill — sits on the image, opposite corner from serial */
.plate-status {
  position: absolute;
  top: 1.5rem;
  left: 1.5rem;
  z-index: 3;
  font-family: var(--grotesk);
  font-size: 0.6rem;
  font-weight: 500;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--paper);
  padding: 0.45rem 0.85rem;
  border: 1px solid rgba(244, 238, 227, 0.4);
  border-radius: 999px;
  background: rgba(26, 22, 18, 0.42);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

/* Photo variant of plate-inner — replaces the dark placeholder gradient */
.plate-inner--photo { background: #15100a; }
.plate-inner--photo img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  z-index: 1;
}
.plate-inner--photo::before {
  /* faint grain over the photo for editorial cohesion, lighter than placeholder version */
  opacity: 0.1;
  z-index: 2;
}
.plate-inner--photo::after {
  /* shorter bottom wash since caption sits below the frame, not inside */
  height: 22%;
  background: linear-gradient(to top, rgba(0,0,0,0.45), transparent);
  z-index: 2;
}

/* Scroll indicator */
.scroll-cue {
  position: absolute;
  bottom: 2.5rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-size: 0.62rem;
  font-weight: 500;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.scroll-cue-line {
  width: 1px;
  height: 28px;
  background: linear-gradient(to bottom, transparent, var(--ink-mute) 30%, var(--ink-mute) 70%, transparent);
  animation: scroll-pulse 2.4s var(--ease-fluid) infinite;
}
@keyframes scroll-pulse {
  0%, 100% { opacity: 0.4; transform: scaleY(1); }
  50% { opacity: 1; transform: scaleY(1.15); }
}

/* =========================================================
   About — The Builder
   ========================================================= */

.about {
  padding: var(--section) var(--gutter) calc(var(--section) * 1.1);
  max-width: 1600px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

.about-divider {
  width: 100%;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--hairline) 20%, var(--hairline) 80%, transparent);
  margin-bottom: var(--section);
}

.about-grid {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: clamp(2.5rem, 6vw, 7rem);
  align-items: start;
}

.about-portrait {
  position: sticky;
  top: 7rem;
}

.portrait-frame {
  position: relative;
  padding: 0.5rem;
  background: linear-gradient(180deg, rgba(26, 22, 18, 0.04), rgba(26, 22, 18, 0.02));
  border: 1px solid var(--hairline);
  border-radius: 1.5rem;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.5),
    0 30px 60px -40px rgba(26, 22, 18, 0.4);
}
.portrait-inner {
  position: relative;
  aspect-ratio: 5 / 4;
  border-radius: calc(1.5rem - 0.5rem);
  overflow: hidden;
  background: var(--paper-deep);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.4);
}
.portrait-inner img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 32%;
  display: block;
  filter: saturate(0.92) contrast(1.02);
}
.portrait-inner::after {
  /* gentle bottom vignette to anchor caption legibility */
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 32%;
  background: linear-gradient(to top, rgba(26, 22, 18, 0.28), transparent);
  pointer-events: none;
}

.portrait-caption {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.6rem 1.25rem;
  padding: 1.25rem 1.15rem 0.75rem;
  margin: 0;
  font-family: var(--grotesk);
  font-size: 0.72rem;
  color: var(--ink-soft);
}
.portrait-caption dt {
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  font-size: 0.6rem;
  color: var(--ink-mute);
  padding-top: 0.15em;
}
.portrait-caption dd {
  margin: 0;
  font-family: var(--serif);
  font-style: italic;
  font-size: 1rem;
  color: var(--ink);
}

/* Essay */
.about-essay {
  display: flex;
  flex-direction: column;
  gap: 1.75rem;
  max-width: 60ch;
}

.essay-opener {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(1.9rem, 3.4vw, 2.65rem);
  line-height: 1.18;
  letter-spacing: -0.008em;
  color: var(--ink);
  margin: 0.5rem 0 1rem;
  text-wrap: pretty;
}
.essay-opener .dropcap {
  font-style: italic;
  font-size: 1.35em;
  line-height: 0.9;
  float: left;
  padding: 0.15em 0.12em 0 0;
  color: var(--ink);
}

.essay {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}
.essay p {
  font-family: var(--grotesk);
  font-size: 1.0625rem;
  line-height: 1.78;
  color: var(--ink-soft);
  margin: 0;
  max-width: 60ch;
  text-wrap: pretty;
}

/* Single-line editorial breaks (the punctuation paragraphs) */
.essay p.essay-break {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.3rem, 1.9vw, 1.55rem);
  line-height: 1.4;
  color: var(--ink);
  padding: 1rem 0 0.5rem;
  margin: 0.5rem 0;
}

/* Pull quote — the keystone line */
.essay-quote {
  margin: 2.5rem 0 2rem;
  padding: 0 0 0 1.5rem;
  border-left: 1px solid var(--ember);
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.75rem, 2.8vw, 2.5rem);
  line-height: 1.2;
  letter-spacing: -0.005em;
  color: var(--ink);
  max-width: 22ch;
}

.essay-signature {
  margin-top: 1.5rem !important;
  font-family: var(--serif) !important;
  font-style: italic !important;
  font-size: 0.95rem !important;
  color: var(--ink-mute) !important;
  letter-spacing: 0.02em;
}

/* =========================================================
   Editorial Section — Provenance
   ========================================================= */

.provenance {
  /* optical asymmetry — bottom slightly heavier than top */
  padding: var(--section) var(--gutter) calc(var(--section) * 1.15);
  max-width: 1600px;
  margin: 0 auto;
  position: relative;
}

.provenance-divider {
  width: 100%;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--hairline) 20%, var(--hairline) 80%, transparent);
  margin-bottom: var(--section);
}

.provenance-grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: clamp(2.5rem, 6vw, 7rem);
  align-items: start;
}

.provenance-left {
  position: sticky;
  top: 8rem;
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.section-label {
  font-size: 0.66rem;
  font-weight: 500;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink-mute);
  display: flex;
  align-items: center;
  gap: 0.9rem;
}
.section-label::before {
  content: '';
  display: inline-block;
  width: 28px;
  height: 1px;
  background: var(--ink-mute);
}

.section-headline {
  font-family: var(--serif);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(2rem, 4.2vw, 3.75rem);
  line-height: 1.08;
  letter-spacing: -0.012em;
  color: var(--ink);
  margin: 0;
  max-width: 20ch;
  text-wrap: balance;
}
.section-headline span {
  font-style: normal;
  color: var(--ink-soft);
  display: block;
}

.section-body {
  font-size: 1rem;
  line-height: 1.7;
  color: var(--ink-mute);
  max-width: 42ch;
  margin: 0;
}

/* Right column — museum plate entries */

.plate-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  border-top: 1px solid var(--hairline);
}

.plate-entry {
  display: grid;
  grid-template-columns: 80px 1fr auto;
  gap: 1.5rem;
  padding: 2rem 0.5rem;
  border-bottom: 1px solid var(--hairline);
  align-items: baseline;
  transition: transform 600ms var(--ease-fluid);
}
.plate-entry:hover {
  transform: translateX(10px);
}
.plate-entry-num {
  font-family: var(--serif);
  font-style: italic;
  font-size: 2rem;
  color: var(--ink-soft);
  letter-spacing: 0.01em;
  line-height: 1;
  font-variant-numeric: tabular-nums oldstyle-nums;
}
.plate-entry-body {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}
.plate-entry-title {
  font-family: var(--serif);
  font-size: 1.5rem;
  font-weight: 400;
  letter-spacing: -0.005em;
  color: var(--ink);
  margin: 0;
  line-height: 1.2;
}
.plate-entry-spec {
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  color: var(--ink-mute);
  font-feature-settings: 'ss01';
}
.plate-entry-status {
  font-size: 0.66rem;
  font-weight: 500;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink-mute);
  padding: 0.4rem 0.85rem;
  border: 1px solid var(--hairline);
  border-radius: 999px;
  white-space: nowrap;
  align-self: center;
}
.plate-entry-status.voiced { color: var(--ember); }

/* =========================================================
   Editorial Section — Manifestations
   ========================================================= */

.manifestations {
  padding: var(--section) var(--gutter) calc(var(--section) * 1.15);
  max-width: 1600px;
  margin: 0 auto;
  position: relative;
}

.manifestations-divider {
  width: 100%;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--hairline) 20%, var(--hairline) 80%, transparent);
  margin-bottom: var(--section);
}

.manifestations-intro {
  max-width: 760px;
  margin: 0 auto clamp(4rem, 8vh, 6rem);
  display: flex;
  flex-direction: column;
  gap: 1.75rem;
  text-align: left;
}
.manifestations-intro .section-body { max-width: 56ch; }

/* Manifestation article */
.manifestation {
  display: flex;
  flex-direction: column;
  gap: clamp(3rem, 6vh, 5rem);
  max-width: 1300px;
  margin: 0 auto;
}

/* Article header — number, title, status pill */
.m-head {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 1.5rem 2rem;
  align-items: end;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--hairline);
}
.m-num {
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(3rem, 6vw, 4.75rem);
  line-height: 0.85;
  color: var(--ink-soft);
  letter-spacing: 0.01em;
  font-variant-numeric: oldstyle-nums;
}
.m-titleblock {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}
.m-title {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(1.75rem, 3vw, 2.4rem);
  letter-spacing: -0.008em;
  color: var(--ink);
  margin: 0;
  line-height: 1.1;
}
.m-subtitle {
  font-family: var(--grotesk);
  font-size: 0.74rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.m-status {
  font-family: var(--grotesk);
  font-size: 0.62rem;
  font-weight: 500;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--ink-mute);
  padding: 0.45rem 0.95rem;
  border: 1px solid var(--hairline);
  border-radius: 999px;
  white-space: nowrap;
  align-self: center;
}
.m-status.voiced { color: var(--ember); border-color: rgba(138, 90, 58, 0.4); }

/* Hero figure — wide editorial plate */
.m-hero {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}
.m-hero-frame {
  position: relative;
  padding: 0.5rem;
  background: linear-gradient(180deg, rgba(26,22,18,0.04), rgba(26,22,18,0.02));
  border: 1px solid var(--hairline);
  border-radius: 1.5rem;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.5),
    0 40px 80px -50px rgba(26, 22, 18, 0.45);
}
.m-hero-frame img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  object-position: center 38%;
  border-radius: calc(1.5rem - 0.5rem);
  filter: saturate(0.96) contrast(1.02);
}
.m-hero-caption {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0 0.5rem;
  font-family: var(--grotesk);
  font-size: 0.68rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.m-hero-rule {
  flex: 0 0 28px;
  height: 1px;
  background: var(--ink-mute);
  display: inline-block;
}

/* Body grid — prose left, specs sticky right */
.m-body {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
  gap: clamp(2.5rem, 5vw, 5rem);
  align-items: start;
}

.m-prose {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  max-width: 60ch;
}
.m-prose p {
  font-family: var(--grotesk);
  font-size: 1.0625rem;
  line-height: 1.78;
  color: var(--ink-soft);
  margin: 0;
  text-wrap: pretty;
}
.m-prose .m-lead {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.35rem, 2vw, 1.65rem);
  line-height: 1.35;
  color: var(--ink);
  margin-bottom: 0.5rem;
}
.m-prose .essay-break {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.25rem, 1.8vw, 1.5rem);
  line-height: 1.4;
  color: var(--ink);
  padding: 0.75rem 0 0.25rem;
  margin: 0.25rem 0;
}
.m-prose .essay-quote {
  margin: 2rem 0 1.5rem;
  padding: 0 0 0 1.5rem;
  border-left: 1px solid var(--ember);
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(1.5rem, 2.4vw, 2rem);
  line-height: 1.22;
  letter-spacing: -0.005em;
  color: var(--ink);
  max-width: 24ch;
}

/* Specifications — the scannable spec block */
.m-specs {
  position: sticky;
  top: 7rem;
  margin: 0;
}
.m-specs-inner {
  padding: 1.75rem 1.5rem;
  background: rgba(244, 238, 227, 0.55);
  border: 1px solid var(--hairline);
  border-radius: 1.25rem;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.5),
    0 20px 40px -28px rgba(26, 22, 18, 0.2);
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
.m-specs-label {
  font-family: var(--grotesk);
  font-size: 0.66rem;
  font-weight: 500;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--ink-mute);
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--hairline);
  display: flex;
  align-items: center;
  gap: 0.9rem;
}
.m-specs-label::before {
  content: '';
  display: inline-block;
  width: 24px;
  height: 1px;
  background: var(--ink-mute);
}

.m-spec-group {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}
.m-spec-group-title {
  font-family: var(--serif);
  font-style: italic;
  font-size: 0.95rem;
  letter-spacing: 0.01em;
  color: var(--ember);
  padding-bottom: 0.35rem;
  border-bottom: 1px solid var(--hairline-soft);
  margin-bottom: 0.25rem;
}
.m-spec-list {
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}
.m-spec-list > div {
  display: grid;
  grid-template-columns: 9rem 1fr;
  gap: 0.75rem 1rem;
  align-items: baseline;
}
.m-spec-list dt {
  font-family: var(--grotesk);
  font-size: 0.66rem;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  padding-top: 0.15em;
}
.m-spec-list dd {
  margin: 0;
  font-family: var(--serif);
  font-style: italic;
  font-size: 1rem;
  line-height: 1.45;
  color: var(--ink);
  letter-spacing: 0.005em;
  text-wrap: pretty;
}

/* Detail figure pair */
.m-details {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(1.5rem, 3vw, 2.5rem);
}
.m-detail {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.m-detail-frame {
  position: relative;
  padding: 0.5rem;
  background: linear-gradient(180deg, rgba(26,22,18,0.04), rgba(26,22,18,0.02));
  border: 1px solid var(--hairline);
  border-radius: 1.25rem;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.5),
    0 24px 50px -32px rgba(26, 22, 18, 0.35);
}
.m-detail-frame img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  border-radius: calc(1.25rem - 0.5rem);
  filter: saturate(0.96) contrast(1.02);
}
.m-detail figcaption {
  font-family: var(--serif);
  font-style: italic;
  font-size: 0.95rem;
  color: var(--ink-mute);
  padding: 0 0.5rem;
  letter-spacing: 0.01em;
}

/* Codas — Story and Voice */
.m-codas {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2.5rem, 5vw, 4.5rem);
  padding-top: clamp(1.5rem, 3vh, 2.5rem);
  border-top: 1px solid var(--hairline);
}
.m-coda {
  display: flex;
  flex-direction: column;
  gap: 1.1rem;
  max-width: 52ch;
}
.m-section-label {
  font-family: var(--grotesk);
  font-size: 0.66rem;
  font-weight: 500;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--ink-mute);
  display: flex;
  align-items: center;
  gap: 0.9rem;
  margin-bottom: 0.5rem;
}
.m-section-label::before {
  content: '';
  display: inline-block;
  width: 24px;
  height: 1px;
  background: var(--ember);
}
.m-coda p {
  font-family: var(--grotesk);
  font-size: 1.0625rem;
  line-height: 1.78;
  color: var(--ink-soft);
  margin: 0;
  text-wrap: pretty;
}
.m-coda .essay-break {
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(1.2rem, 1.7vw, 1.45rem);
  line-height: 1.4;
  color: var(--ink);
  padding-top: 0.5rem;
  margin-top: 0.25rem;
}

/* =========================================================
   Rites — Process Gallery
   ========================================================= */

.rites {
  padding: var(--section) var(--gutter) calc(var(--section) * 1.1);
  max-width: 1600px;
  margin: 0 auto;
  position: relative;
}
.rites-divider {
  width: 100%;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--hairline) 20%, var(--hairline) 80%, transparent);
  margin-bottom: var(--section);
}
.rites-intro {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(280px, 0.55fr);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: end;
  margin-bottom: clamp(3rem, 7vh, 5rem);
}
.rites-intro .section-label {
  grid-column: 1 / -1;
}
.rites-intro .section-body {
  max-width: 44ch;
}
.rites-gallery {
  position: relative;
}
.rites-stage {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: start;
}
.rites-active {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.95rem;
}
.rites-active img {
  display: block;
  width: 100%;
  height: auto;
  max-height: min(72vh, 760px);
  aspect-ratio: 16 / 10;
  object-fit: contain;
  background: rgba(26, 22, 18, 0.05);
  border-radius: 1.15rem;
  border: 1px solid var(--hairline);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.45),
    0 24px 52px -38px rgba(26, 22, 18, 0.38);
}
.rites-active figcaption {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding: 0 0.25rem;
  color: var(--ink-mute);
  font-size: 0.68rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.rites-active figcaption span:first-child {
  color: var(--ink-soft);
  font-weight: 500;
}
.rites-active figcaption span:last-child {
  font-family: var(--serif);
  font-style: italic;
  font-size: 1rem;
  letter-spacing: 0.01em;
  text-transform: none;
  text-align: right;
}
.rites-actions {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  gap: 0.65rem;
}
.rites-control {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.6rem;
  height: 2.6rem;
  border: 1px solid var(--hairline);
  border-radius: 999px;
  background: rgba(244, 238, 227, 0.68);
  color: var(--ink);
  cursor: pointer;
  transition: transform 300ms var(--ease-fluid), background 300ms var(--ease-fluid);
}
.rites-control:hover {
  background: rgba(235, 227, 212, 0.82);
}
.rites-control:active {
  transform: scale(0.96);
}
.rites-control svg {
  width: 0.85rem;
  height: 0.85rem;
}
.rites-thumbs {
  display: flex;
  gap: 0.75rem;
  overflow-x: auto;
  overflow-y: hidden;
  overscroll-behavior-x: contain;
  scroll-snap-type: x proximity;
  scroll-padding-inline: 0.25rem;
  padding: 1rem 0.25rem 0.9rem;
  scrollbar-width: thin;
  scrollbar-color: rgba(26, 22, 18, 0.28) transparent;
}
.rites-thumbs::-webkit-scrollbar {
  height: 0.55rem;
}
.rites-thumbs::-webkit-scrollbar-track {
  background: transparent;
}
.rites-thumbs::-webkit-scrollbar-thumb {
  background: rgba(26, 22, 18, 0.22);
  border-radius: 999px;
}
.rites-thumb {
  flex: 0 0 clamp(5.25rem, 9vw, 7.5rem);
  aspect-ratio: 1 / 1;
  padding: 0.28rem;
  border: 1px solid transparent;
  border-radius: 0.82rem;
  background: transparent;
  cursor: pointer;
  opacity: 0.64;
  scroll-snap-align: start;
  transition: opacity 300ms var(--ease-fluid), border-color 300ms var(--ease-fluid), background 300ms var(--ease-fluid), transform 300ms var(--ease-fluid);
}
.rites-thumb:hover,
.rites-thumb.is-active {
  opacity: 1;
  border-color: rgba(138, 90, 58, 0.5);
  background: rgba(244, 238, 227, 0.68);
}
.rites-thumb:active {
  transform: scale(0.97);
}
.rites-thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 0.6rem;
  border: 1px solid var(--hairline);
  filter: saturate(0.94) contrast(1.02);
}

/* =========================================================
   Invoke Section
   ========================================================= */

.invoke {
  padding: var(--section) var(--gutter) calc(var(--section) * 1.2);
  max-width: 1300px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}
.invoke-inner {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(320px, 0.72fr);
  gap: clamp(2.5rem, 6vw, 6rem);
  align-items: start;
}
.invoke .section-headline { font-size: clamp(2.25rem, 5vw, 4.25rem); }
.invoke-copy {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  max-width: 720px;
}
.invoke-text {
  display: flex;
  flex-direction: column;
  gap: 1.15rem;
}
.invoke-text p {
  font-size: 1.02rem;
  line-height: 1.78;
  color: var(--ink-soft);
  margin: 0;
  max-width: 58ch;
  text-wrap: pretty;
}
.contact-links {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0;
  border-top: 1px solid var(--hairline);
  border-left: 1px solid var(--hairline);
  max-width: 620px;
}
.contact-links a {
  min-height: 4.5rem;
  display: flex;
  align-items: center;
  padding: 1rem 1.15rem;
  border-right: 1px solid var(--hairline);
  border-bottom: 1px solid var(--hairline);
  color: var(--ink-soft);
  text-decoration: none;
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(1rem, 1.4vw, 1.18rem);
  line-height: 1.2;
  transition: color 400ms var(--ease-fluid), background 400ms var(--ease-fluid);
}
.contact-links a:hover {
  color: var(--ink);
  background: rgba(26, 22, 18, 0.035);
}

.contact-form {
  position: sticky;
  top: 7rem;
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
  padding: clamp(1.25rem, 2.5vw, 1.75rem);
  background: rgba(244, 238, 227, 0.64);
  border: 1px solid var(--hairline);
  border-radius: 1.25rem;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.52),
    0 24px 54px -38px rgba(26, 22, 18, 0.28);
}
.form-field {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}
.form-field label {
  font-size: 0.64rem;
  font-weight: 500;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.form-field input,
.form-field textarea {
  width: 100%;
  border: 1px solid var(--hairline);
  border-radius: 0.75rem;
  background: rgba(255, 252, 246, 0.58);
  color: var(--ink);
  font: inherit;
  font-size: 0.95rem;
  line-height: 1.5;
  padding: 0.85rem 0.95rem;
  transition: border-color 300ms var(--ease-fluid), background 300ms var(--ease-fluid), box-shadow 300ms var(--ease-fluid);
}
.form-field textarea {
  resize: vertical;
  min-height: 9.5rem;
}
.form-field input:focus,
.form-field textarea:focus {
  border-color: rgba(138, 90, 58, 0.5);
  background: rgba(255, 252, 246, 0.82);
  box-shadow: inset 0 0 0 1px rgba(138, 90, 58, 0.14);
}
.form-field.is-invalid input,
.form-field.is-invalid textarea {
  border-color: rgba(138, 60, 42, 0.7);
}
.form-error {
  min-height: 1.15rem;
  margin: 0;
  font-size: 0.72rem;
  line-height: 1.4;
  color: #7a3328;
}
.contact-submit {
  border: 0;
  cursor: pointer;
  margin-top: 0.25rem;
}
.contact-submit:disabled {
  cursor: wait;
  opacity: 0.72;
}
.form-status {
  min-height: 1.25rem;
  margin: -0.35rem 0 0;
  font-size: 0.76rem;
  line-height: 1.5;
  color: var(--ink-mute);
}
.form-status.is-success { color: var(--ember); }
.form-status.is-error { color: #7a3328; }

.cta-primary {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.85rem 0.85rem 0.85rem 1.6rem;
  background: var(--ink);
  color: var(--paper);
  border-radius: 999px;
  text-decoration: none;
  font-family: var(--grotesk);
  font-weight: 500;
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  width: fit-content;
  margin-top: 1rem;
  transition: transform 400ms var(--ease-fluid), background 400ms var(--ease-fluid);
}
.cta-primary:hover { background: var(--espresso); }
.cta-primary:active { transform: scale(0.98); }
.cta-primary-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: rgba(244, 238, 227, 0.16);
  transition: transform 450ms var(--ease-fluid);
}
.cta-primary:hover .cta-primary-icon {
  transform: translate(2px, -1px);
}
.cta-primary-icon svg { width: 12px; height: 12px; stroke: var(--paper); }

/* =========================================================
   Footer
   ========================================================= */

.footer {
  position: relative;
  z-index: 2;
  padding: 3rem var(--gutter) 3.5rem;
  max-width: 1600px;
  margin: 0 auto;
  border-top: 1px solid var(--hairline);
}
.footer-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
  flex-wrap: wrap;
}
.footer-mark {
  display: flex;
  align-items: center;
  font-family: var(--grotesk);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink);
}
.footer-mark-dot {
  display: inline-block;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--ink);
  margin-right: 0.7rem;
}
.footer-meta {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  font-family: var(--grotesk);
  font-size: 0.74rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.footer-meta a {
  color: var(--ink-soft);
  text-decoration: none;
  transition: color 400ms var(--ease-fluid);
  letter-spacing: 0.06em;
  text-transform: none;
  font-family: var(--serif);
  font-style: italic;
  font-size: 0.95rem;
}
.footer-meta a:hover { color: var(--ink); }
.footer-rule {
  display: inline-block;
  width: 20px;
  height: 1px;
  background: var(--ink-mute);
}
.footer-copy {
  font-family: var(--grotesk);
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  font-variant-numeric: tabular-nums;
}

/* =========================================================
   Reveal motion — ink-bleed entry
   ========================================================= */

[data-reveal] {
  opacity: 0;
  transform: translateY(20px);
  filter: blur(8px);
  transition:
    opacity 1200ms var(--ease-ink),
    transform 1200ms var(--ease-ink),
    filter 1200ms var(--ease-ink);
}
[data-reveal].is-visible {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}
[data-reveal-delay="1"] { transition-delay: 100ms; }
[data-reveal-delay="2"] { transition-delay: 220ms; }
[data-reveal-delay="3"] { transition-delay: 360ms; }
[data-reveal-delay="4"] { transition-delay: 520ms; }
[data-reveal-delay="5"] { transition-delay: 700ms; }

/* =========================================================
   Responsive
   ========================================================= */

@media (max-width: 920px) {
  .hero {
    grid-template-columns: 1fr;
    gap: 3rem;
    padding-top: clamp(8rem, 18vh, 10rem);
    min-height: auto;
  }
  .hero-plate { max-width: 480px; margin: 0 auto; }
  .provenance-grid { grid-template-columns: 1fr; gap: 3rem; }
  .provenance-left { position: static; }
  .plate-entry { grid-template-columns: 60px 1fr; }
  .plate-entry-status { grid-column: 2; justify-self: start; margin-top: 0.5rem; }
  .scroll-cue { display: none; }
  .m-body { grid-template-columns: 1fr; gap: 3rem; }
  .m-specs { position: static; }
  .m-details,
  .m-codas { grid-template-columns: 1fr; }
  .about-grid { grid-template-columns: 1fr; gap: 3rem; }
  .about-portrait { position: static; max-width: 520px; margin: 0 auto; }
  .rites-intro { grid-template-columns: 1fr; align-items: start; }
  .rites-stage { grid-template-columns: 1fr; }
  .rites-actions { flex-direction: row; justify-content: flex-start; order: -1; }
  .invoke-inner { grid-template-columns: 1fr; }
  .contact-form { position: static; }
}

@media (max-width: 640px) {
  .nav {
    padding: 0.4rem 0.4rem 0.4rem 1rem;
    font-size: 0.64rem;
  }
  .nav-mark { margin-right: 1rem; }
  .nav-links { gap: 0.62rem; }
  .nav-links a { letter-spacing: 0.08em; }
  .nav-cta { margin-left: 0.55rem; padding: 0.45rem; }
  .nav-cta-text { display: none; }
  .nav-cta-icon { width: 26px; height: 26px; }

  .hero { padding: 7rem 1.25rem 4rem; }
  .manifestations { padding: 4rem 1.25rem 5rem; }
  .manifestations-divider { margin-bottom: 4rem; }
  .manifestations-intro { margin-bottom: 3.5rem; }
  .manifestation { gap: 3rem; }
  .m-head {
    grid-template-columns: auto 1fr;
    align-items: start;
    gap: 1rem;
  }
  .m-status {
    grid-column: 2;
    justify-self: start;
    align-self: start;
    margin-top: 0.35rem;
  }
  .m-subtitle {
    font-size: 0.68rem;
    letter-spacing: 0.16em;
    line-height: 1.55;
  }
  .m-hero-caption {
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 0.5rem 0.75rem;
    line-height: 1.45;
  }
  .m-hero-rule { display: none; }
  .m-prose p,
  .m-coda p {
    font-size: 1rem;
    line-height: 1.72;
  }
  .m-specs-inner {
    padding: 1.25rem;
    border-radius: 1rem;
    gap: 1.35rem;
  }
  .m-spec-list { gap: 0.85rem; }
  .m-spec-list > div {
    grid-template-columns: 1fr;
    gap: 0.2rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid var(--hairline-soft);
  }
  .m-spec-list > div:last-child {
    padding-bottom: 0;
    border-bottom: 0;
  }
  .m-spec-list dt {
    font-size: 0.6rem;
    letter-spacing: 0.18em;
    padding-top: 0;
  }
  .m-spec-list dd {
    font-size: 0.98rem;
    line-height: 1.38;
    overflow-wrap: anywhere;
  }
  .m-details { gap: 2rem; }
  .m-codas { gap: 2.5rem; }
  .about { padding: 4rem 1.25rem 5rem; }
  .provenance { padding: 4rem 1.25rem 5rem; }
  .rites { padding: 4rem 1.25rem 5rem; }
  .rites-active img {
    max-height: none;
    aspect-ratio: 4 / 5;
  }
  .rites-active figcaption {
    flex-direction: column;
    gap: 0.25rem;
  }
  .rites-active figcaption span:last-child { text-align: left; }
  .rites-thumb { flex-basis: 5.1rem; }
  .invoke { padding: 4rem 1.25rem 5rem; }
  .contact-links { grid-template-columns: 1fr; }
  .plate-caption { left: 0.75rem; right: 0.75rem; bottom: 0.75rem; }
  .footer { padding: 2.5rem 1.25rem 3rem; }
  .footer-inner { flex-direction: column; align-items: flex-start; gap: 1.25rem; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
  }
  [data-reveal] { opacity: 1; transform: none; filter: none; }
  .pick-resonance { display: none; }
}
