/* ==========================================================================
   LARSEN STUDIO — "The Quiet Catalogue"
   ========================================================================== */

:root {
  /* color */
  --paper:          #F6F3EE;
  --surface:        #ECE7DD;
  --ink:            #211E1A;
  --ink-muted:      #5E584F;
  --accent:         #6B5942;
  --accent-deep:    #2E3833;
  --accent-on-dark: #C9B99F;
  --rule:           rgba(33, 30, 26, 0.14);
  --rule-strong:    rgba(33, 30, 26, 0.5);

  /* type */
  --font-display: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --font-text:    "Inter", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;

  --fs-hero:  clamp(2.6rem, 5.2vw, 4.75rem);
  --fs-h2:    clamp(1.875rem, 3.6vw, 3rem);
  --fs-h3:    clamp(1.375rem, 2.2vw, 1.875rem);
  --fs-lede:  clamp(1.125rem, 1.5vw, 1.3125rem);
  --fs-body:  1.0625rem;
  --fs-small: 0.9375rem;
  --fs-label: 0.8125rem;
  --fs-micro: 0.75rem;

  --track-label: 0.08em;
  --track-wide:  0.18em;

  /* spacing */
  --s-1: 0.5rem; --s-2: 1rem;  --s-3: 1.5rem; --s-4: 2rem;
  --s-5: 3rem;   --s-6: 4rem;  --s-7: 5rem;   --s-8: 7rem;
  --section-pad: clamp(7rem, 18vh, 14rem);
  --label-gap: 1.25rem;
  --field-gap: 3.5rem;

  /* layout */
  --max-w: 1360px;
  --margin: clamp(24px, 7vw, 112px);
  --gutter: 24px;
  --measure: 38rem;

  /* motion */
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --d-reveal: 750ms;
  --d-rule: 600ms;
  --d-hover: 450ms;
  --d-light: 1400ms;
  --d-stagger: 140ms;
}

/* ---------- reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; scroll-padding-top: 80px; }
body {
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-text);
  font-size: var(--fs-body);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { display: block; max-width: 100%; }
figure { margin: 0; }
a { color: inherit; }
::selection { background: var(--accent-deep); color: var(--paper); }

:focus-visible { outline: 2px solid var(--accent-deep); outline-offset: 3px; }

/* ---------- skip link ---------- */
.skip-link {
  position: absolute; left: -9999px; top: 0; z-index: 100;
  background: var(--ink); color: var(--paper);
  padding: 12px 20px; font-size: var(--fs-label);
  letter-spacing: var(--track-label); text-transform: uppercase;
  text-decoration: none;
}
.skip-link:focus { left: 0; }

/* ---------- shared pieces ---------- */
.plate-num {
  font-family: var(--font-text);
  font-size: var(--fs-micro);
  letter-spacing: var(--track-wide);
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-bottom: var(--s-3);
}

.section-title {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: var(--fs-h2);
  line-height: 1.15;
  margin-bottom: var(--s-5);
}

.kicker {
  font-size: var(--fs-label);
  letter-spacing: var(--track-label);
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-bottom: var(--s-6);
}

.cta-link {
  display: inline-block;
  padding: 14px 4px;
  margin: -8px -4px;
  color: var(--accent);
  font-size: var(--fs-label);
  letter-spacing: var(--track-label);
  text-transform: uppercase;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 6px;
  transition: color var(--d-hover) var(--ease);
}
.cta-link:hover, .cta-link:focus-visible { color: var(--accent-deep); }

.seam {
  border: 0;
  height: 1px;
  background: var(--rule);
  width: min(calc(100% - 2 * var(--margin)), calc(var(--max-w) - 2 * var(--margin)));
  margin-inline: auto;
}

.frame {
  position: relative;
  overflow: hidden;
  background: var(--surface);
}
.frame img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: filter var(--d-light) var(--ease);
}
.frame--43   { aspect-ratio: 4 / 3; }
.frame--34   { aspect-ratio: 3 / 4; }
.frame--1610 { aspect-ratio: 16 / 10; }
.frame--11   { aspect-ratio: 1 / 1; }
.frame--45   { aspect-ratio: 4 / 5; }
.plate:hover .frame img { filter: brightness(1.05) saturate(1.04); }

/* wall label — the site's signature */
.wall-label {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  margin-top: var(--label-gap);
}
.wall-label__rule { width: 32px; height: 1px; background: var(--accent); }
.wall-label__title {
  font-size: var(--fs-label);
  letter-spacing: var(--track-label);
  text-transform: uppercase;
  color: var(--ink);
}
.wall-label__material {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.125rem;
  color: var(--ink-muted);
}
.wall-label__note {
  font-size: var(--fs-small);
  color: var(--ink-muted);
  line-height: 1.55;
  max-width: 22rem;
}
.wall-label .plate-num { margin-bottom: 0.25rem; }

/* ---------- nav ---------- */
.nav {
  position: fixed; inset-inline: 0; top: 0; z-index: 10;
  border-bottom: 1px solid transparent;
  transition: background-color var(--d-hover) var(--ease), border-color var(--d-hover) var(--ease);
}
.nav--solid {
  background: rgba(246, 243, 238, 0.88);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  border-bottom-color: var(--rule);
}
@supports not (backdrop-filter: blur(10px)) {
  .nav--solid { background: var(--paper); }
}
.nav__inner {
  display: flex; justify-content: space-between; align-items: center;
  height: 64px;
  max-width: var(--max-w); margin-inline: auto; padding-inline: var(--margin);
}
.nav__wordmark {
  font-size: var(--fs-label);
  font-weight: 500;
  letter-spacing: var(--track-wide);
  text-transform: uppercase;
  text-decoration: none;
}
.nav__links { display: flex; align-items: center; gap: var(--s-4); }
.nav__link {
  font-size: var(--fs-label);
  text-decoration: underline 1px transparent;
  text-underline-offset: 6px;
  transition: text-decoration-color 200ms var(--ease);
}
.nav__link:hover, .nav__link:focus-visible { text-decoration-color: currentColor; }
.nav__cta {
  padding: 21px 4px;
  color: var(--accent);
  font-size: var(--fs-label);
  letter-spacing: var(--track-label);
  text-transform: uppercase;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 6px;
  transition: color var(--d-hover) var(--ease);
}
.nav__cta:hover, .nav__cta:focus-visible { color: var(--accent-deep); }

.nav-sentinel {
  position: absolute; top: 90vh; left: 0;
  width: 1px; height: 1px;
  pointer-events: none;
}

/* ---------- hero — the title wall ---------- */
.hero {
  min-height: 100svh;
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  column-gap: var(--gutter);
  align-content: center;
  max-width: var(--max-w);
  margin-inline: auto;
  padding-inline: var(--margin);
  padding-block: calc(64px + var(--s-4)) var(--s-6);
}
.hero__eyebrow {
  grid-column: 1 / 6; grid-row: 1;
  align-self: end;
  font-size: var(--fs-micro);
  letter-spacing: var(--track-wide);
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-bottom: var(--s-3);
}
.hero__title {
  grid-column: 1 / 7; grid-row: 2;
  font-family: var(--font-display);
  font-weight: 300;
  font-size: var(--fs-hero);
  line-height: 1.08;
}
.hero__line { display: block; }
.hero__line--italic { font-style: italic; }
.hero__fig { grid-column: 7 / 13; grid-row: 1 / 6; }
.hero__frame { height: min(76vh, 820px); }
.hero__sentence {
  grid-column: 1 / 5; grid-row: 3;
  font-size: var(--fs-small);
  color: var(--ink-muted);
  line-height: 1.6;
  max-width: 26rem;
  margin-top: var(--s-4);
}
.hero__cta-row { grid-column: 1 / 6; grid-row: 4; margin-top: var(--s-4); }
.hero__rule {
  grid-column: 1 / 6; grid-row: 5;
  width: 1px; height: 48px;
  background: var(--accent);
  margin-top: var(--s-5);
}

/* ---------- manifesto ---------- */
.manifesto {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  column-gap: var(--gutter);
  max-width: var(--max-w);
  margin-inline: auto;
  padding-inline: var(--margin);
  padding-block: var(--section-pad);
}
.manifesto > * { grid-column: 4 / 10; }
.manifesto__key {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: var(--fs-h2);
  line-height: 1.25;
  margin-bottom: var(--s-6);
}
.manifesto__key span { display: block; }
.manifesto__key .italic { font-style: italic; }
.manifesto__prose p {
  font-family: var(--font-display);
  font-size: var(--fs-lede);
  line-height: 1.7;
  max-width: var(--measure);
  margin-bottom: var(--s-4);
}
.manifesto__close {
  font-family: var(--font-display);
  font-size: var(--fs-lede);
  margin-top: var(--s-5);
}

/* ---------- work — the plates ---------- */
.work {
  max-width: var(--max-w);
  margin-inline: auto;
  padding-inline: var(--margin);
  padding-block: var(--section-pad);
}
.plate {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  column-gap: var(--gutter);
  margin-bottom: clamp(5rem, 10vh, 8rem);
}
.plate--2 .plate__frame { grid-column: 2 / 9; grid-row: 1; }
.plate--2 .plate__label { grid-column: 9 / 12; grid-row: 1; align-self: end; }
.plate--3 .plate__frame { grid-column: 6 / 13; grid-row: 1; }
.plate--3 .plate__label { grid-column: 3 / 6; grid-row: 1; align-self: center; }
.plate--4 .plate__frame { grid-column: 1 / 8; grid-row: 1; }
.plate--4 .plate__label { grid-column: 8 / 11; grid-row: 1; align-self: end; }
.plate--5 .plate__frame { grid-column: 5 / 12; grid-row: 1; }
.plate--5 .plate__label { grid-column: 2 / 5; grid-row: 1; align-self: center; }

.plate--triptych .triptych {
  grid-column: 2 / 13;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gutter);
}
.plate__label--row { grid-column: 2 / 13; }

.work__close {
  text-align: center;
  margin-top: var(--s-7);
}
.work__close-line {
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  margin-bottom: var(--s-3);
}
.work__credit {
  font-size: var(--fs-micro);
  color: var(--ink-muted);
  letter-spacing: 0.02em;
  max-width: var(--measure);
  margin: var(--s-6) auto 0;
}

/* ---------- services & method ---------- */
.services, .method {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  column-gap: var(--gutter);
  max-width: var(--max-w);
  margin-inline: auto;
  padding-inline: var(--margin);
  padding-block: var(--section-pad);
}
.services > *, .method > * { grid-column: 3 / 10; }

.services__list, .method__list {
  list-style: none;
  padding: 0;
  max-width: var(--measure);
}
.services__item {
  display: grid;
  grid-template-columns: 3rem 1fr;
  column-gap: var(--s-3);
  padding-block: var(--s-5);
  border-top: 1px solid var(--rule);
}
.services__item:last-child { border-bottom: 1px solid var(--rule); }
.services__num, .method__num {
  font-size: var(--fs-micro);
  letter-spacing: var(--track-wide);
  color: var(--accent);
  padding-top: 0.6rem;
}
.services__item h3, .method__item h3 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: var(--fs-h3);
  grid-column: 2;
  margin-bottom: var(--s-2);
}
.services__item p, .method__item p {
  grid-column: 2;
  font-size: var(--fs-body);
  line-height: 1.65;
}
.services__close {
  font-family: var(--font-display);
  font-size: var(--fs-lede);
  margin-top: var(--s-5);
}

.method__item {
  display: grid;
  grid-template-columns: 3rem 1fr;
  column-gap: var(--s-3);
  margin-bottom: var(--s-6);
}
.method__close {
  font-family: var(--font-display);
  font-size: var(--fs-lede);
  margin-top: var(--s-4);
}
.method__close .cta-link { margin-left: 0.5rem; }

/* ---------- studio ---------- */
.studio {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  column-gap: var(--gutter);
  max-width: var(--max-w);
  margin-inline: auto;
  padding-inline: var(--margin);
  padding-block: var(--section-pad);
}
.studio__fig { grid-column: 2 / 8; }
.studio__text { grid-column: 8 / 13; align-self: center; max-width: var(--measure); }
.studio__prose p { margin-bottom: var(--s-3); }
.studio__final {
  font-family: var(--font-display);
  font-size: var(--fs-lede);
  margin-top: var(--s-4);
}
.studio__loc {
  font-size: var(--fs-label);
  letter-spacing: var(--track-label);
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-top: var(--s-5);
}

/* ---------- interlude ---------- */
.interlude {
  position: relative;
  height: 70vh;
  min-height: 420px;
}
.interlude img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
}
.interlude::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(33,30,26,0.68) 0%, rgba(33,30,26,0.55) 30%, rgba(33,30,26,0.2) 55%, transparent 75%);
}
.interlude__line {
  position: absolute;
  inset-inline: var(--margin);
  bottom: 16%;
  z-index: 1;
  text-align: center;
}
.interlude__line em {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(1.75rem, 3.2vw, 2.75rem);
  color: var(--paper);
}

/* ---------- consultation ---------- */
.consultation {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  column-gap: var(--gutter);
  max-width: var(--max-w);
  margin-inline: auto;
  padding-inline: var(--margin);
  padding-block: var(--section-pad);
}
.consult-panel {
  grid-column: 4 / 10;
  background: var(--surface);
  padding: clamp(2.5rem, 5vw, 4.5rem);
}
.consult__lede {
  font-family: var(--font-display);
  font-size: var(--fs-lede);
  line-height: 1.6;
  margin-bottom: var(--s-2);
}
.consult__note {
  font-size: var(--fs-small);
  color: var(--ink-muted);
  margin-bottom: var(--s-6);
}

.field { position: relative; margin-bottom: var(--field-gap); }
.field--sub { margin-top: calc(var(--field-gap) * -0.5); }
.field__q {
  display: block;
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-lede);
  margin-bottom: 0.6rem;
}
.field__hint-label {
  display: block;
  font-size: var(--fs-micro);
  letter-spacing: var(--track-label);
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-bottom: 0.4rem;
}
input, select, textarea {
  width: 100%;
  border: 0;
  border-bottom: 1px solid var(--rule-strong);
  border-radius: 0;
  background: transparent;
  font-family: var(--font-text);
  font-size: var(--fs-body);
  color: var(--ink);
  padding: 12px 2px;
  transition: border-color var(--d-hover) var(--ease);
}
input:focus:not(:focus-visible),
select:focus:not(:focus-visible),
textarea:focus:not(:focus-visible) { outline: none; }
input:focus, select:focus, textarea:focus {
  border-bottom-color: var(--ink);
}
.field::after {
  content: "";
  position: absolute;
  left: 0; bottom: 0;
  width: 24px; height: 1px;
  background: var(--accent);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 400ms var(--ease);
}
.field:focus-within::after { transform: scaleX(1); }
select {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%236B5942' stroke-width='1.5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 4px center;
  padding-right: 28px;
  cursor: pointer;
}
textarea { resize: vertical; min-height: 96px; line-height: 1.6; }

.field__msg {
  font-size: var(--fs-small);
  color: var(--accent-deep);
  margin-top: 0.5rem;
}
.field.is-invalid input { border-bottom-color: var(--accent); }

.hp {
  position: absolute;
  left: -9999px;
  width: 1px; height: 1px;
  overflow: hidden;
}

.form-status {
  min-height: 1.5em;
  font-size: var(--fs-small);
  color: var(--accent-deep);
  margin-bottom: var(--s-3);
}

.submit {
  border: 1px solid var(--ink);
  background: transparent;
  color: var(--ink);
  font-family: var(--font-text);
  font-weight: 500;
  font-size: var(--fs-label);
  letter-spacing: var(--track-label);
  text-transform: uppercase;
  padding: 16px 32px;
  cursor: pointer;
  transition: background-color 500ms var(--ease), color 500ms var(--ease), border-color 500ms var(--ease);
}
.submit:hover, .submit:focus-visible {
  background: var(--accent-deep);
  border-color: var(--accent-deep);
  color: var(--paper);
}

#consult-form { transition: opacity var(--d-hover) var(--ease); }
#consult-form.is-sent { opacity: 0; pointer-events: none; }
.consult__privacy {
  font-size: var(--fs-micro);
  color: var(--ink-muted);
  margin-top: var(--s-3);
}
.form-status.is-confirm {
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  color: var(--ink);
  margin-bottom: 0;
}

/* ---------- footer ---------- */
.footer {
  background: var(--accent-deep);
  color: var(--paper);
  padding-block: var(--s-8) var(--s-6);
}
.footer__inner {
  max-width: var(--max-w);
  margin-inline: auto;
  padding-inline: var(--margin);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--s-3);
}
.footer__wordmark {
  font-size: var(--fs-label);
  font-weight: 500;
  letter-spacing: var(--track-wide);
  text-transform: uppercase;
}
.footer__tagline {
  font-family: var(--font-display);
  font-size: var(--fs-lede);
}
.footer__contact a {
  color: var(--paper);
  text-underline-offset: 4px;
  transition: color var(--d-hover) var(--ease);
}
.footer__contact a:hover, .footer__contact a:focus-visible { color: var(--accent-on-dark); }
.footer__times {
  font-size: var(--fs-label);
  letter-spacing: var(--track-label);
  text-transform: uppercase;
  font-variant-numeric: tabular-nums;
  display: flex;
  gap: 0.75rem;
}
.footer__legal { opacity: 0.6; font-size: var(--fs-micro); margin-top: var(--s-3); }

/* ==========================================================================
   Motion — one verb: arrive
   ========================================================================== */

html.js [data-reveal]:not([data-reveal="rule"]) {
  opacity: 0;
  transform: translateY(14px);
  transition: opacity var(--d-reveal) var(--ease), transform var(--d-reveal) var(--ease);
}
html.js [data-reveal].is-visible { opacity: 1; transform: none; }

html.js [data-reveal="rule"] {
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--d-rule) var(--ease);
}
html.js [data-reveal="rule"].is-visible { transform: scaleX(1); }

html.js [data-resolve] {
  opacity: 0.18;
  transition: opacity 700ms var(--ease);
}
html.js [data-resolve].is-visible { opacity: 1; }

html.js .plate__label.is-visible { transition-delay: 250ms; }

/* hero load choreography — runs once */
html.js .h-item {
  opacity: 0;
  transform: translateY(12px);
  transition: opacity var(--d-reveal) var(--ease), transform var(--d-reveal) var(--ease);
}
html.js .is-loaded .h-item { opacity: 1; transform: none; }
html.js .h-item--1 { transition-delay: 300ms; }
html.js .h-item--2 { transition-delay: 450ms; }
html.js .h-item--3 { transition-delay: 600ms; }
html.js .h-item--4 { transition-delay: 750ms; }
html.js .h-item--5 { transition-delay: 900ms; }

html.js .hero__img {
  opacity: 0;
  transform: scale(1.03);
  transition: opacity 1400ms var(--ease), transform 1400ms var(--ease);
}
html.js .is-loaded .hero__img { opacity: 1; transform: scale(1); }

html.js .hero .wall-label {
  opacity: 0;
  transition: opacity var(--d-reveal) var(--ease) 600ms;
}
html.js .is-loaded .hero .wall-label { opacity: 1; }

html.js .hero__rule {
  transform: scaleY(0);
  transform-origin: top;
  transition: transform 900ms var(--ease) 1200ms;
}
html.js .is-loaded .hero__rule { transform: scaleY(1); }

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

@media (max-width: 1023px) {
  .hero { align-content: start; padding-top: calc(64px + var(--s-5)); }
  .hero__eyebrow, .hero__title, .hero__fig, .hero__sentence, .hero__cta-row {
    grid-column: 1 / -1;
  }
  .hero__eyebrow  { grid-row: 1; }
  .hero__title    { grid-row: 2; }
  .hero__sentence { grid-row: 3; margin-top: var(--s-3); }
  .hero__cta-row  { grid-row: 4; margin-top: var(--s-2); }
  .hero__fig      { grid-row: 5; margin-top: var(--s-5); }
  .hero__rule     { display: none; }
  .hero__frame    { height: 58vh; }

  .manifesto > * { grid-column: 2 / 12; }
  .services > *, .method > * { grid-column: 2 / 12; }

  .plate--2 .plate__frame, .plate--4 .plate__frame { grid-column: 1 / 10; }
  .plate--3 .plate__frame, .plate--5 .plate__frame { grid-column: 4 / 13; }
  .plate--2 .plate__label, .plate--4 .plate__label { grid-column: 1 / 8; grid-row: 2; }
  .plate--3 .plate__label, .plate--5 .plate__label { grid-column: 4 / 11; grid-row: 2; }
  .plate--triptych .triptych { grid-column: 1 / 13; }
  .plate__label--row { grid-column: 1 / 13; }

  .studio__fig { grid-column: 2 / 12; }
  .studio__text { grid-column: 2 / 12; margin-top: var(--s-6); }

  .consult-panel { grid-column: 2 / 12; }
}

@media (max-width: 767px) {
  :root { --section-pad: clamp(4.5rem, 12vh, 7rem); }

  .nav__link { display: none; }

  .hero__frame { height: 56vh; }

  .manifesto > * { grid-column: 1 / -1; }
  .services > *, .method > * { grid-column: 1 / -1; }

  .plate { margin-bottom: var(--s-7); }
  .plate--2 .plate__frame, .plate--3 .plate__frame,
  .plate--4 .plate__frame, .plate--5 .plate__frame { grid-column: 1 / -1; }
  .plate--2 .plate__label, .plate--3 .plate__label,
  .plate--4 .plate__label, .plate--5 .plate__label { grid-column: 1 / -1; grid-row: 2; }

  .plate--triptych .triptych { grid-template-columns: 1fr; gap: var(--s-2); }

  .studio__fig, .studio__text { grid-column: 1 / -1; }

  .consult-panel { grid-column: 1 / -1; padding: 2rem 1.5rem; }

  .interlude { height: 56vh; min-height: 360px; }
}

@media (min-width: 560px) and (max-width: 767px) {
  .plate--triptych .triptych { grid-template-columns: repeat(3, 1fr); gap: 12px; }
}

@media (max-width: 479px) {
  :root { --field-gap: 2.5rem; }
}

/* ==========================================================================
   Reduced motion — identical temperament, no movement
   ========================================================================== */

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  html.js [data-reveal],
  html.js [data-resolve],
  html.js .h-item,
  html.js .hero__img,
  html.js .hero .wall-label,
  html.js .hero__rule {
    opacity: 1 !important;
    transform: none !important;
  }
  .plate:hover .frame img { filter: none !important; }
}
