/* =============================================================
   Mitchell & Associates CPA · Design System
   -------------------------------------------------------------
   Aesthetic: Corporate, restrained, opinionated.
   The brief asks for trust and professionalism. The default
   answer for a CPA site is navy-on-white + a polite serif.
   We are reaching past that.

   Palette: Off-white paper (#FFFFFF) ground, deep blue-ink
   (#0F1A33) as the dominant text/structure color, oxblood
   (#5A0E1F) as the single saturated accent used SPARINGLY for
   the eyebrow bar, key headlines, primary CTAs, and one accent
   audience card. Muted slate (#566B85) carries supporting
   prose. Borders sit on #D9DEE8.

   Type: IBM Plex Sans across display and body. The display
   role uses weight 700 with tight tracking. The body role uses
   weight 400 at a generous line-height. IBM Plex Mono carries
   ledger numerals, deadline dates, eyebrow text, and stat
   labels, the editorial moment.

   Corners: Subtle (4px base). Buttons, cards, and inputs all
   share the same scale. Pills are reserved for genuinely
   pill-shaped UI (the live-hours indicator).

   Rhythm: Mobile-first. Section padding is fluid:
   clamp(64px, 9vw, 160px) vertical. Sections alternate density:
   the deadline ledger is dense; the statement section breathes.

   Motion: Hover transitions 180ms cubic-bezier(.2,.7,.2,1).
   Reveals 600ms cubic-bezier(.16,1,.3,1). Reveal classes are
   visible by default; the hidden state is gated behind html.js
   so the page is fully readable without JS.

   Signature moves:
   - Dotted-leader ledger rows for filing deadlines
   - Numbered service cards with vertical accent rail
   - Oxblood pull-quote section as the page's contrast moment
   - Custom SVG cross-hatch brand mark
   - "Next deadline" countdown card flanking the hero
   ============================================================= */

/* ---------- TOKENS ---------- */
:root {
  --color-bg:      var(--theme-background, #FFFFFF);
  --color-paper:   #F6F4EE;
  --color-ink:     var(--theme-text, #0F1A33);
  --color-ink-2:   #1E2A47;
  --color-muted:   var(--theme-muted, #566B85);
  --color-border:  var(--theme-border, #D9DEE8);
  --color-border-strong: #B4BFD0;
  --color-accent:  var(--theme-accent, #5A0E1F);
  --color-accent-2: #7A1A2C;
  --color-surface-soft: #F4F6FA;

  --radius-sm: 2px;
  --radius-base: var(--theme-radius, 4px);
  --radius-lg: 8px;
  --radius-xl: 12px;
  --radius-full: 9999px;

  --font-display: var(--theme-heading-font, 'IBM Plex Sans', 'Söhne', system-ui, sans-serif);
  --font-body:    var(--theme-body-font, 'IBM Plex Sans', system-ui, sans-serif);
  --font-mono:    'IBM Plex Mono', ui-monospace, SFMono-Regular, monospace;

  --fs-xs:   0.8125rem;
  --fs-sm:   0.9375rem;
  --fs-base: 1.0625rem;
  --fs-lg:   1.1875rem;
  --fs-xl:   clamp(1.25rem, 1.6vw, 1.5rem);
  --fs-2xl:  clamp(1.625rem, 2.4vw, 2.125rem);
  --fs-3xl:  clamp(2rem, 3.2vw, 2.75rem);
  --fs-4xl:  clamp(2.5rem, 4.6vw, 3.75rem);
  --fs-display: clamp(2.75rem, 5.2vw, 4.5rem);

  --space-1: calc(0.25rem * var(--theme-density, 1));
  --space-2: calc(0.5rem * var(--theme-density, 1));
  --space-3: calc(0.75rem * var(--theme-density, 1));
  --space-4: calc(1rem * var(--theme-density, 1));
  --space-5: calc(1.5rem * var(--theme-density, 1));
  --space-6: calc(2rem * var(--theme-density, 1));
  --space-7: calc(3rem * var(--theme-density, 1));
  --space-8: calc(4rem * var(--theme-density, 1));
  --space-9: calc(6rem * var(--theme-density, 1));
  --space-10: calc(8rem * var(--theme-density, 1));

  --section-pad: calc(clamp(64px, 9vw, 144px) * var(--theme-density, 1));
  --container-pad: calc(clamp(24px, 4vw, 48px) * var(--theme-density, 1));
  --container-max: 1200px;

  --ease-out:   cubic-bezier(.2,.7,.2,1);
  --ease-quint: cubic-bezier(.16,1,.3,1);
  --dur-fast: calc(120ms * var(--theme-motion, 1));
  --dur-base: calc(200ms * var(--theme-motion, 1));
  --dur-slow: calc(600ms * var(--theme-motion, 1));

  --shadow-sm: 0 1px 2px rgba(15,26,51,.05);
  --shadow-md: 0 6px 24px -8px rgba(15,26,51,.15);
  --shadow-lg: 0 24px 60px -30px rgba(15,26,51,.35);
}

/* ---------- RESET ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  line-height: 1.65;
  color: var(--color-ink);
  background: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img, svg, video { display: block; max-width: 100%; }
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  font-weight: 600;
  line-height: 1.12;
  letter-spacing: -0.015em;
  text-wrap: balance;
  color: var(--color-ink);
}
p { text-wrap: pretty; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: 0; background: transparent; color: inherit; }
ul, ol { padding: 0; list-style: none; }
:focus-visible { outline: 2px solid var(--color-accent); outline-offset: 3px; border-radius: var(--radius-sm); }
::selection { background: var(--color-accent); color: #fff; }

/* ---------- SKIP LINK ---------- */
.skip-link { position: absolute; left: -9999px; top: 0; }
.skip-link:focus {
  left: 1rem; top: 1rem; z-index: 9999;
  padding: 0.75rem 1rem;
  background: var(--color-ink); color: #fff;
  outline: 2px solid var(--color-accent);
}

/* ---------- LAYOUT ---------- */
.container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding-left: var(--container-pad);
  padding-right: var(--container-pad);
}

/* ---------- TYPE UTILITIES ---------- */
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.625rem;
  font-family: var(--font-mono);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-muted);
  margin: 0;
}
.eyebrow__bar {
  width: 28px; height: 1px;
  background: var(--color-accent);
  display: inline-block;
}
.eyebrow--small { font-size: 0.6875rem; letter-spacing: 0.18em; }
.eyebrow--invert { color: rgba(255,255,255,0.7); }
.eyebrow--invert .eyebrow__bar { background: #fff; }

.section-title {
  font-size: var(--fs-3xl);
  font-weight: 600;
  letter-spacing: -0.018em;
  margin-top: 0.75rem;
  max-width: 22ch;
}
.section-lede {
  margin-top: 1rem;
  font-size: var(--fs-lg);
  color: var(--color-muted);
  max-width: 60ch;
}
.section-lede--right { margin-left: auto; text-align: left; }
.section-header { margin-bottom: clamp(2.5rem, 5vw, 4.5rem); }
.section-header--split {
  display: grid;
  gap: var(--space-6);
  align-items: end;
}
@media (min-width: 900px) {
  .section-header--split { grid-template-columns: 1.1fr 0.9fr; }
  .section-header--split .section-lede { max-width: 42ch; }
}
.section-header--center { text-align: center; }
.section-header--center .eyebrow,
.section-header--center .section-title,
.section-header--center .section-lede {
  margin-left: auto; margin-right: auto;
}
.section-header--center .section-title { max-width: 24ch; }

/* ---------- BUTTONS ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.875rem 1.5rem;
  font-family: var(--font-display);
  font-size: 0.9375rem;
  font-weight: 500;
  letter-spacing: 0.005em;
  border-radius: var(--radius-base);
  border: 1px solid transparent;
  transition: transform var(--dur-base) var(--ease-out),
              background-color var(--dur-base) var(--ease-out),
              color var(--dur-base) var(--ease-out),
              border-color var(--dur-base) var(--ease-out),
              box-shadow var(--dur-base) var(--ease-out);
  white-space: nowrap;
  text-align: center;
}
.btn-sm { padding: 0.5rem 0.875rem; font-size: 0.8125rem; }

.btn-primary {
  background: var(--color-accent);
  color: #fff;
  border-color: var(--color-accent);
}
.btn-primary:hover {
  background: var(--color-accent-2);
  border-color: var(--color-accent-2);
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}
.btn-primary:active { transform: translateY(0); }

.btn-primary--invert { background: #fff; color: var(--color-ink); border-color: #fff; }
.btn-primary--invert:hover { background: var(--color-accent); color: #fff; border-color: var(--color-accent); }

.btn-ghost {
  background: transparent;
  color: var(--color-ink);
  border-color: var(--color-border-strong);
}
.btn-ghost:hover {
  background: var(--color-ink);
  color: #fff;
  border-color: var(--color-ink);
  transform: translateY(-1px);
}
.btn-ghost--invert { color: #fff; border-color: rgba(255,255,255,0.4); }
.btn-ghost--invert:hover { background: #fff; color: var(--color-ink); border-color: #fff; }

/* ---------- HEADER ---------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255,255,255,0.94);
  backdrop-filter: saturate(140%) blur(8px);
  border-bottom: 1px solid var(--color-border);
}
.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-5);
  padding-top: 1.05rem;
  padding-bottom: 1.05rem;
}
.brand {
  display: inline-flex; align-items: center; gap: 0.625rem;
  font-family: var(--font-display);
  color: var(--color-ink);
}
.brand__glyph {
  color: var(--color-accent);
  display: inline-flex;
  transition: transform var(--dur-base) var(--ease-out);
}
.brand:hover .brand__glyph { transform: rotate(6deg); }
.brand__name {
  font-size: 0.9375rem;
  font-weight: 600;
  letter-spacing: -0.005em;
}
.brand__suffix {
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  color: var(--color-muted);
  margin-left: 0.25rem;
}

.primary-nav { display: flex; align-items: center; }
.primary-nav ul {
  display: none;
  gap: 0.25rem;
  align-items: center;
}
.primary-nav a {
  position: relative;
  display: inline-block;
  padding: 0.5rem 0.875rem;
  font-size: 0.9375rem;
  color: var(--color-ink-2);
  border-radius: var(--radius-base);
  transition: color var(--dur-base) var(--ease-out);
}
.primary-nav a::after {
  content: "";
  position: absolute;
  left: 0.875rem; right: 0.875rem; bottom: 0.35rem;
  height: 1px;
  background: var(--color-accent);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--dur-base) var(--ease-out);
}
.primary-nav a:hover { color: var(--color-ink); }
.primary-nav a:hover::after,
.primary-nav a[aria-current="page"]::after { transform: scaleX(1); }
.primary-nav a[aria-current="page"] { color: var(--color-ink); }
.primary-nav .nav-portal {
  color: var(--color-muted);
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 0.45rem 0.75rem;
}
.primary-nav .nav-cta {
  background: var(--color-ink);
  color: #fff;
  padding: 0.6rem 1rem;
  margin-left: 0.5rem;
}
.primary-nav .nav-cta:hover { background: var(--color-accent); color: #fff; }
.primary-nav .nav-cta::after { display: none; }

.nav-toggle {
  display: inline-flex;
  flex-direction: column;
  gap: 5px;
  padding: 10px;
  border-radius: var(--radius-base);
  border: 1px solid var(--color-border);
}
.nav-toggle__bar {
  width: 22px; height: 1.5px;
  background: var(--color-ink);
  transition: transform var(--dur-base) var(--ease-out), opacity var(--dur-base) var(--ease-out);
}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 899px) {
  .primary-nav ul {
    display: none;
    position: absolute;
    top: 100%; left: 0; right: 0;
    background: #fff;
    border-bottom: 1px solid var(--color-border);
    flex-direction: column;
    align-items: stretch;
    padding: var(--space-5) var(--container-pad) var(--space-6);
    gap: 0.25rem;
  }
  .primary-nav ul.is-open { display: flex; }
  .primary-nav a { padding: 0.85rem 0.5rem; font-size: 1.0625rem; }
  .primary-nav .nav-cta { margin-left: 0; margin-top: 0.5rem; text-align: center; }
}
@media (min-width: 900px) {
  .primary-nav ul { display: flex; }
  .nav-toggle { display: none; }
}

/* ---------- HERO ---------- */
.hero {
  padding: clamp(48px, 7vw, 96px) 0 clamp(64px, 8vw, 112px);
  background:
    linear-gradient(180deg, #fff 0%, var(--color-paper) 100%);
  position: relative;
  overflow: hidden;
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(var(--color-border) 1px, transparent 1px),
    linear-gradient(90deg, var(--color-border) 1px, transparent 1px);
  background-size: 64px 64px;
  background-position: -1px -1px;
  opacity: 0.18;
  mask-image: linear-gradient(180deg, transparent, #000 30%, #000 70%, transparent);
  pointer-events: none;
}
.hero__grid {
  position: relative;
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--container-pad);
  display: grid;
  gap: clamp(2.5rem, 5vw, 4.5rem);
  align-items: start;
}
@media (min-width: 960px) {
  .hero__grid { grid-template-columns: 1.55fr 1fr; align-items: center; }
}
.hero__content { max-width: 720px; }
.hero__title {
  font-size: var(--fs-display);
  font-weight: 600;
  line-height: 1.04;
  letter-spacing: -0.025em;
  margin-top: 1.5rem;
  max-width: 18ch;
}
.hero__title em {
  font-style: italic;
  color: var(--color-accent);
  font-weight: 500;
}
.hero__lede {
  font-size: var(--fs-lg);
  color: var(--color-muted);
  margin-top: 1.5rem;
  max-width: 52ch;
}
.hero__ctas {
  display: flex; flex-wrap: wrap; gap: 0.75rem;
  margin-top: 2rem;
}
.hero__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
  margin-top: 3rem;
  padding-top: 2rem;
  border-top: 1px solid var(--color-border);
  max-width: 560px;
}
.hero__stats > div { display: flex; flex-direction: column; gap: 0.25rem; }
.hero__stats dt {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-muted);
}
.hero__stats dd {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--color-ink);
}

/* Next deadline card */
.hero__deadline {
  background: var(--color-ink);
  color: #fff;
  padding: clamp(1.75rem, 3vw, 2.5rem);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  position: relative;
  overflow: hidden;
}
.hero__deadline::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 4px; height: 100%;
  background: var(--color-accent);
}
.deadline__label {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.6);
  margin-bottom: 0.75rem;
}
.deadline__date {
  font-family: var(--font-mono);
  font-size: clamp(1.5rem, 2.4vw, 1.875rem);
  font-weight: 500;
  color: #fff;
  letter-spacing: -0.01em;
  margin-bottom: 0.5rem;
}
.deadline__title {
  font-family: var(--font-display);
  font-size: 1.125rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
  color: #fff;
}
.deadline__meta {
  font-size: 0.875rem;
  color: rgba(255,255,255,0.65);
  margin-bottom: 1.5rem;
}
.deadline__list {
  border-top: 1px solid rgba(255,255,255,0.12);
  padding-top: 1.25rem;
  display: flex; flex-direction: column;
  gap: 0.65rem;
  margin-bottom: 1.5rem;
}
.deadline__list li {
  display: flex;
  gap: 0.875rem;
  font-size: 0.875rem;
  color: rgba(255,255,255,0.78);
}
.deadline__list span {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  color: rgba(255,255,255,0.5);
  letter-spacing: 0.06em;
  min-width: 56px;
}
.deadline__link {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #fff;
  border-bottom: 1px solid var(--color-accent);
  padding-bottom: 2px;
  display: inline-block;
  transition: border-color var(--dur-base) var(--ease-out);
}
.deadline__link:hover { border-color: #fff; }

/* ---------- BAND (services band) ---------- */
.band {
  background: var(--color-ink);
  color: #fff;
  padding: clamp(2rem, 3.5vw, 3rem) 0;
}
.band__row {
  display: grid;
  gap: var(--space-5);
  align-items: center;
}
@media (min-width: 900px) {
  .band__row { grid-template-columns: 0.9fr 1.1fr; }
}
.band__intro {
  font-size: 1.0625rem;
  color: rgba(255,255,255,0.78);
  max-width: 36ch;
}
.band__list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1.25rem;
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.band__list li {
  position: relative;
  padding-left: 1rem;
}
.band__list li::before {
  content: "";
  position: absolute;
  left: 0; top: 50%;
  width: 6px; height: 1px;
  background: var(--color-accent);
}

/* ---------- SERVICES PREVIEW (home) ---------- */
.services-preview { padding: var(--section-pad) 0; }
.services-grid {
  display: grid;
  gap: 0;
  border-top: 1px solid var(--color-border);
}
.service-card {
  padding: clamp(2rem, 3.5vw, 3rem) 0;
  border-bottom: 1px solid var(--color-border);
  display: grid;
  gap: var(--space-4);
  align-items: start;
  position: relative;
  transition: background-color var(--dur-base) var(--ease-out);
}
.service-card:hover { background: var(--color-paper); }
.service-card:hover .service-card__num { color: var(--color-accent); }
@media (min-width: 768px) {
  .service-card {
    grid-template-columns: 80px 1.1fr 1.4fr auto;
    gap: var(--space-6);
    padding-left: var(--space-5);
    padding-right: var(--space-5);
    margin-left: calc(var(--space-5) * -1);
    margin-right: calc(var(--space-5) * -1);
  }
}
.service-card__num {
  font-family: var(--font-mono);
  font-size: 0.875rem;
  letter-spacing: 0.08em;
  color: var(--color-muted);
  transition: color var(--dur-base) var(--ease-out);
}
.service-card__title {
  font-size: var(--fs-2xl);
  font-weight: 600;
  letter-spacing: -0.012em;
  max-width: 18ch;
}
.service-card__body {
  color: var(--color-muted);
  max-width: 44ch;
}
.service-card__link {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-ink);
  border-bottom: 1px solid var(--color-accent);
  padding-bottom: 2px;
  justify-self: start;
  transition: color var(--dur-base) var(--ease-out), border-color var(--dur-base) var(--ease-out);
  white-space: nowrap;
}
.service-card__link:hover { color: var(--color-accent); }

/* ---------- STATEMENT (pull quote) ---------- */
.statement {
  background: var(--color-accent);
  color: #fff;
  padding: clamp(80px, 12vw, 160px) 0;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.statement::before, .statement::after {
  content: "";
  position: absolute;
  width: 220px; height: 220px;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 50%;
  pointer-events: none;
}
.statement::before { top: -110px; left: -80px; }
.statement::after  { bottom: -110px; right: -80px; }
.statement__eyebrow {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.7);
  margin-bottom: 2rem;
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
}
.statement__eyebrow::before, .statement__eyebrow::after {
  content: ""; width: 28px; height: 1px; background: rgba(255,255,255,0.4);
}
.statement__quote {
  font-family: var(--font-display);
  font-size: clamp(1.875rem, 3.6vw, 3rem);
  font-weight: 500;
  font-style: italic;
  line-height: 1.18;
  letter-spacing: -0.015em;
  color: #fff;
  max-width: 22ch;
  margin: 0 auto;
}
.statement__attr {
  margin-top: 2rem;
  font-family: var(--font-mono);
  font-size: 0.8125rem;
  letter-spacing: 0.06em;
  color: rgba(255,255,255,0.75);
}

/* ---------- AUDIENCES ---------- */
.audiences { padding: var(--section-pad) 0; }
.audience-grid {
  display: grid;
  gap: var(--space-5);
  grid-template-columns: 1fr;
}
@media (min-width: 720px) { .audience-grid { grid-template-columns: repeat(3, 1fr); } }
.audience {
  padding: clamp(1.75rem, 2.6vw, 2.25rem);
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-base);
  display: flex; flex-direction: column;
  gap: 1rem;
  transition: transform var(--dur-base) var(--ease-out), border-color var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
}
.audience:hover { transform: translateY(-2px); border-color: var(--color-ink); box-shadow: var(--shadow-md); }
.audience h3 {
  font-size: 1.375rem;
  font-weight: 600;
}
.audience p { color: var(--color-muted); }
.audience__list {
  margin-top: auto;
  padding-top: 1.25rem;
  border-top: 1px solid var(--color-border);
  display: flex; flex-direction: column;
  gap: 0.45rem;
  font-size: 0.9375rem;
}
.audience__list li {
  position: relative;
  padding-left: 1.25rem;
  color: var(--color-ink-2);
}
.audience__list li::before {
  content: "+";
  position: absolute; left: 0; top: 0;
  color: var(--color-accent);
  font-weight: 600;
  font-family: var(--font-mono);
}
.audience--accent {
  background: var(--color-ink);
  border-color: var(--color-ink);
  color: #fff;
}
.audience--accent h3 { color: #fff; }
.audience--accent p { color: rgba(255,255,255,0.75); }
.audience--accent .audience__list { border-color: rgba(255,255,255,0.16); }
.audience--accent .audience__list li { color: rgba(255,255,255,0.85); }
.audience--accent .audience__list li::before { color: #fff; }
.audience--accent:hover { border-color: var(--color-accent); }

/* ---------- TRUST / TESTIMONIALS ---------- */
.trust { padding: var(--section-pad) 0; background: var(--color-paper); }
.testimonials {
  display: grid;
  gap: var(--space-5);
}
@media (min-width: 900px) { .testimonials { grid-template-columns: repeat(3, 1fr); } }
.testimonial {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-base);
  padding: clamp(1.5rem, 2.4vw, 2rem);
  display: flex; flex-direction: column;
  gap: 1.25rem;
}
.testimonial blockquote { position: relative; padding-top: 1.5rem; }
.testimonial blockquote::before {
  content: "“";
  position: absolute;
  top: -0.5rem; left: 0;
  font-family: var(--font-display);
  font-size: 3rem;
  line-height: 1;
  color: var(--color-accent);
}
.testimonial p {
  font-size: 1.0625rem;
  line-height: 1.55;
  color: var(--color-ink);
}
.testimonial figcaption {
  margin-top: auto;
  padding-top: 1.25rem;
  border-top: 1px solid var(--color-border);
  display: flex; flex-direction: column;
  gap: 0.15rem;
}
.testimonial__name { font-weight: 600; color: var(--color-ink); font-size: 0.9375rem; }
.testimonial__role {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  letter-spacing: 0.04em;
  color: var(--color-muted);
}

/* ---------- CTA SECTION ---------- */
.cta {
  background: var(--color-ink);
  color: #fff;
  padding: clamp(64px, 8vw, 112px) 0;
}
.cta__inner {
  display: grid;
  gap: var(--space-6);
  align-items: end;
}
@media (min-width: 900px) {
  .cta__inner { grid-template-columns: 1.4fr 1fr; align-items: center; }
}
.cta__title {
  font-size: var(--fs-3xl);
  color: #fff;
  margin-top: 1rem;
  max-width: 22ch;
  font-weight: 600;
}
.cta__lede {
  margin-top: 1rem;
  color: rgba(255,255,255,0.7);
  max-width: 52ch;
}
.cta__actions {
  display: flex; flex-wrap: wrap; gap: 0.75rem;
  justify-content: flex-start;
}
@media (min-width: 900px) { .cta__actions { justify-content: flex-end; } }

/* ---------- FOOTER ---------- */
.site-footer {
  background: #0A1226;
  color: rgba(255,255,255,0.78);
  padding: clamp(48px, 6vw, 80px) 0 var(--space-7);
}
.site-footer__inner {
  display: grid;
  gap: var(--space-7);
}
@media (min-width: 900px) {
  .site-footer__inner { grid-template-columns: 1.2fr 2fr; }
}
.site-footer__brand { display: flex; flex-direction: column; gap: 1rem; }
.site-footer__brand .brand__glyph { color: var(--color-accent); }
.site-footer__about {
  font-size: 0.9375rem;
  color: rgba(255,255,255,0.65);
  max-width: 38ch;
}
.site-footer__nav {
  display: grid;
  gap: var(--space-6);
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}
.site-footer__heading {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.5);
  margin-bottom: 1rem;
}
.site-footer__nav ul { display: flex; flex-direction: column; gap: 0.55rem; font-size: 0.9375rem; }
.site-footer__nav a {
  color: rgba(255,255,255,0.78);
  transition: color var(--dur-base) var(--ease-out);
}
.site-footer__nav a:hover { color: #fff; }

.site-footer__meta {
  grid-column: 1 / -1;
  margin-top: var(--space-6);
  padding-top: var(--space-5);
  border-top: 1px solid rgba(255,255,255,0.12);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: var(--space-3);
  font-size: 0.8125rem;
  color: rgba(255,255,255,0.55);
}
.site-footer__meta a { color: rgba(255,255,255,0.75); border-bottom: 1px solid rgba(255,255,255,0.2); }
.site-footer__meta a:hover { color: #fff; border-color: var(--color-accent); }
.site-footer__license { max-width: 60ch; }

/* ---------- PAGE HERO (interior pages) ---------- */
.page-hero {
  padding: clamp(48px, 6vw, 96px) 0 clamp(48px, 6vw, 96px);
  border-bottom: 1px solid var(--color-border);
  background:
    linear-gradient(180deg, var(--color-paper), #fff);
}
.page-hero__title {
  font-size: var(--fs-4xl);
  font-weight: 600;
  line-height: 1.08;
  letter-spacing: -0.022em;
  margin-top: 1rem;
  max-width: 22ch;
}
.page-hero__lede {
  margin-top: 1.5rem;
  font-size: var(--fs-lg);
  color: var(--color-muted);
  max-width: 56ch;
}
.breadcrumbs { margin-bottom: 1.5rem; }
.breadcrumbs ol {
  display: flex; flex-wrap: wrap; gap: 0.4rem;
  font-family: var(--font-mono);
  font-size: 0.75rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-muted);
}
.breadcrumbs li + li::before { content: "/"; margin-right: 0.4rem; color: var(--color-border-strong); }
.breadcrumbs a { color: var(--color-muted); border-bottom: 1px solid transparent; transition: color var(--dur-base) var(--ease-out), border-color var(--dur-base) var(--ease-out); }
.breadcrumbs a:hover { color: var(--color-ink); border-color: var(--color-accent); }
.breadcrumbs [aria-current="page"] { color: var(--color-ink); }

/* ---------- SERVICES PAGE ---------- */
.service {
  padding: clamp(64px, 8vw, 112px) 0;
  border-bottom: 1px solid var(--color-border);
}
.service--alt { background: var(--color-paper); }
.service__grid {
  display: grid;
  gap: var(--space-7);
}
@media (min-width: 900px) {
  .service__grid { grid-template-columns: 220px 1fr; align-items: start; }
}
.service__rail {
  display: flex; flex-direction: column;
  gap: 0.5rem;
  position: sticky; top: 100px;
  align-self: start;
}
.service__num {
  font-family: var(--font-mono);
  font-size: 0.875rem;
  letter-spacing: 0.08em;
  color: var(--color-accent);
}
.service__label {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-ink);
  border-top: 1px solid var(--color-ink);
  padding-top: 0.75rem;
  width: 80%;
  max-width: 180px;
}
.service__title {
  font-size: var(--fs-3xl);
  font-weight: 600;
  letter-spacing: -0.018em;
  max-width: 22ch;
  margin-bottom: 1rem;
}
.service__body > p { font-size: var(--fs-lg); color: var(--color-ink-2); max-width: 64ch; }
.service__sub {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-top: 2.5rem;
  margin-bottom: 1rem;
  font-weight: 500;
}

.checklist {
  display: grid;
  gap: 0.65rem;
}
@media (min-width: 720px) {
  .checklist { grid-template-columns: repeat(2, 1fr); column-gap: var(--space-6); }
}
.checklist li {
  position: relative;
  padding-left: 1.75rem;
  font-size: 1rem;
  color: var(--color-ink-2);
  line-height: 1.5;
}
.checklist li::before {
  content: "";
  position: absolute;
  left: 0; top: 0.55rem;
  width: 12px; height: 1px;
  background: var(--color-accent);
}

/* ---------- ABOUT / STORY ---------- */
.story { padding: var(--section-pad) 0; }
.story__grid {
  display: grid;
  gap: var(--space-8);
}
@media (min-width: 960px) {
  .story__grid { grid-template-columns: 1.6fr 1fr; align-items: start; }
}
.story__chapter {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-top: 3rem;
  margin-bottom: 0.75rem;
}
.story__body > .story__chapter:first-of-type { margin-top: 0; }
.story__title {
  font-size: var(--fs-2xl);
  font-weight: 600;
  letter-spacing: -0.012em;
  margin-bottom: 1rem;
  max-width: 28ch;
}
.story__body > p { color: var(--color-ink-2); max-width: 60ch; font-size: var(--fs-lg); }

.story__side { display: flex; flex-direction: column; gap: var(--space-5); position: sticky; top: 100px; }
.story__card {
  background: var(--color-paper);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-base);
  padding: var(--space-6);
}
.story__card--credentials { background: var(--color-ink); color: #fff; border-color: var(--color-ink); }
.story__card--credentials .eyebrow { color: rgba(255,255,255,0.65); }
.story__card--credentials .eyebrow__bar { background: #fff; }

.story__stats {
  margin-top: 1.5rem;
  display: grid;
  gap: 0.85rem;
}
.story__stats > div {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  border-bottom: 1px dotted var(--color-border-strong);
  padding-bottom: 0.5rem;
}
.story__stats dt {
  font-size: 0.875rem;
  color: var(--color-muted);
}
.story__stats dd {
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: 1rem;
  color: var(--color-ink);
}

.creds {
  margin-top: 1.5rem;
  display: flex; flex-direction: column;
  gap: 0.9rem;
}
.creds li {
  display: grid;
  grid-template-columns: 88px 1fr;
  gap: 0.75rem;
  align-items: baseline;
  padding-bottom: 0.85rem;
  border-bottom: 1px solid rgba(255,255,255,0.12);
}
.creds li:last-child { border-bottom: 0; padding-bottom: 0; }
.creds__cert {
  font-family: var(--font-mono);
  font-size: 0.8rem;
  letter-spacing: 0.08em;
  color: #fff;
}
.creds__org {
  font-size: 0.875rem;
  color: rgba(255,255,255,0.7);
  line-height: 1.45;
}

/* People */
.people { padding: var(--section-pad) 0; background: var(--color-paper); }
.people__grid {
  display: grid;
  gap: var(--space-6);
  grid-template-columns: 1fr;
}
@media (min-width: 720px) { .people__grid { grid-template-columns: repeat(2, 1fr); } }
.person {
  background: #fff;
  padding: clamp(1.75rem, 2.6vw, 2.25rem);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-base);
  display: flex; flex-direction: column;
  gap: 1rem;
  transition: transform var(--dur-base) var(--ease-out), border-color var(--dur-base) var(--ease-out);
}
.person:hover { transform: translateY(-2px); border-color: var(--color-ink); }
.person__monogram {
  width: 60px; height: 60px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--color-ink);
  color: #fff;
  font-family: var(--font-display);
  font-weight: 600;
  letter-spacing: 0.02em;
  border-radius: var(--radius-base);
  font-size: 1.125rem;
}
.person h3 { font-size: 1.375rem; font-weight: 600; }
.person__role {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-accent);
}
.person p { color: var(--color-muted); }

/* Values */
.values { padding: var(--section-pad) 0; }
.values__list {
  display: grid;
  gap: 0;
  border-top: 1px solid var(--color-border);
}
.values__list li {
  display: grid;
  grid-template-columns: 60px 1fr;
  gap: var(--space-5);
  align-items: start;
  padding: clamp(1.5rem, 2.6vw, 2.25rem) 0;
  border-bottom: 1px solid var(--color-border);
}
@media (min-width: 720px) {
  .values__list li { grid-template-columns: 80px 1.1fr 2fr; gap: var(--space-6); }
}
.values__num {
  font-family: var(--font-mono);
  font-size: 0.875rem;
  letter-spacing: 0.08em;
  color: var(--color-accent);
}
.values__list h3 {
  font-size: 1.375rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  max-width: 22ch;
}
.values__list p {
  color: var(--color-muted);
  max-width: 60ch;
}

/* ---------- RESOURCES PAGE ---------- */
.deadlines { padding: var(--section-pad) 0; }
.ledger {
  border-top: 1px solid var(--color-ink);
}
.ledger li {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.25rem;
  padding: 1.25rem 0;
  border-bottom: 1px solid var(--color-border);
  position: relative;
  align-items: baseline;
  transition: padding-left var(--dur-base) var(--ease-out);
}
.ledger li:hover { padding-left: 0.75rem; background: var(--color-paper); }
.ledger li:hover .ledger__date { color: var(--color-accent); }
@media (min-width: 720px) {
  .ledger li { grid-template-columns: 140px 1fr 160px; gap: var(--space-5); align-items: baseline; }
}
.ledger__date {
  font-family: var(--font-mono);
  font-size: 1rem;
  font-weight: 500;
  color: var(--color-ink);
  letter-spacing: 0.02em;
  transition: color var(--dur-base) var(--ease-out);
}
.ledger__item {
  font-size: 1.0625rem;
  color: var(--color-ink-2);
  line-height: 1.5;
  position: relative;
}
@media (min-width: 720px) {
  .ledger__item::after {
    content: "";
    position: absolute;
    left: 0; right: 0; bottom: 0.55em;
    border-bottom: 1px dotted var(--color-border-strong);
    z-index: -1;
  }
  .ledger__item {
    background: linear-gradient(to right, transparent 0, transparent 0) padding-box;
  }
}
.ledger__form {
  font-family: var(--font-mono);
  font-size: 0.8125rem;
  letter-spacing: 0.06em;
  color: var(--color-muted);
}
@media (min-width: 720px) {
  .ledger__form { text-align: right; }
}

/* Checklists section */
.checklists { padding: var(--section-pad) 0; background: var(--color-paper); }
.checklists__grid {
  display: grid;
  gap: var(--space-5);
  grid-template-columns: 1fr;
}
@media (min-width: 720px) { .checklists__grid { grid-template-columns: repeat(3, 1fr); } }
.checklist-card {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-base);
  padding: clamp(1.5rem, 2.4vw, 2rem);
  display: flex; flex-direction: column;
}
.checklist-card h3 {
  font-size: 1.25rem;
  font-weight: 600;
  margin-bottom: 1.25rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--color-border);
}
.checklist-card .checklist { grid-template-columns: 1fr; }
.checklist-card .checklist li { font-size: 0.9375rem; }

/* FAQ */
.faq { padding: var(--section-pad) 0; }
.faq__list { border-top: 1px solid var(--color-border); }
.faq__item {
  border-bottom: 1px solid var(--color-border);
}
.faq__item summary {
  cursor: pointer;
  list-style: none;
  padding: 1.5rem 3rem 1.5rem 0;
  font-family: var(--font-display);
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--color-ink);
  position: relative;
  transition: color var(--dur-base) var(--ease-out);
}
.faq__item summary::-webkit-details-marker { display: none; }
.faq__item summary::after {
  content: "+";
  position: absolute;
  right: 0; top: 50%;
  transform: translateY(-50%);
  font-family: var(--font-mono);
  font-size: 1.5rem;
  color: var(--color-accent);
  transition: transform var(--dur-base) var(--ease-out);
  line-height: 1;
}
.faq__item[open] summary { color: var(--color-accent); }
.faq__item[open] summary::after { transform: translateY(-50%) rotate(45deg); }
.faq__item summary:hover { color: var(--color-accent); }
.faq__body {
  padding: 0 3rem 1.5rem 0;
  color: var(--color-muted);
  max-width: 64ch;
}
.faq__body p { font-size: 1rem; line-height: 1.65; }

/* ---------- CONTACT PAGE ---------- */
.contact-grid { padding: clamp(48px, 6vw, 80px) 0; border-bottom: 1px solid var(--color-border); }
.channels {
  display: grid;
  gap: var(--space-5);
  grid-template-columns: 1fr;
}
@media (min-width: 800px) { .channels { grid-template-columns: repeat(3, 1fr); } }
.channel {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-base);
  padding: clamp(1.5rem, 2.4vw, 2rem);
  display: flex; flex-direction: column;
  gap: 0.75rem;
  transition: transform var(--dur-base) var(--ease-out), border-color var(--dur-base) var(--ease-out);
}
.channel:hover { transform: translateY(-2px); border-color: var(--color-ink); }
.channel__num {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  color: var(--color-muted);
}
.channel h2 { font-size: 1.375rem; font-weight: 600; }
.channel p { color: var(--color-muted); }
.channel__link {
  margin-top: auto;
  padding-top: 1rem;
  font-family: var(--font-mono);
  font-size: 0.8rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-ink);
  border-top: 1px solid var(--color-border);
}
.channel__link:hover { color: var(--color-accent); }
.channel--accent {
  background: var(--color-ink);
  color: #fff;
  border-color: var(--color-ink);
}
.channel--accent h2 { color: #fff; }
.channel--accent p { color: rgba(255,255,255,0.75); }
.channel--accent .channel__num { color: rgba(255,255,255,0.55); }
.channel--accent .channel__link { color: #fff; border-color: rgba(255,255,255,0.18); }
.channel--accent .channel__link:hover { color: var(--color-paper); }

.booking { padding: var(--section-pad) 0; background: var(--color-paper); }

.message { padding: var(--section-pad) 0; }
.message__grid {
  display: grid;
  gap: var(--space-7);
}
@media (min-width: 960px) { .message__grid { grid-template-columns: 0.9fr 1.3fr; align-items: start; } }
.message__intro p { color: var(--color-muted); margin-top: 1rem; max-width: 44ch; }
.message__meta {
  margin-top: 2rem;
  padding-top: 2rem;
  border-top: 1px solid var(--color-border);
  display: grid;
  gap: 1rem;
}
.message__meta > div { display: grid; grid-template-columns: 80px 1fr; align-items: baseline; gap: 0.75rem; }
.message__meta dt {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-muted);
}
.message__meta dd { font-size: 0.9375rem; color: var(--color-ink); }
.message__meta a { border-bottom: 1px solid var(--color-accent); }

/* Form */
.form {
  background: var(--color-paper);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-base);
  padding: clamp(1.75rem, 2.8vw, 2.5rem);
  display: flex; flex-direction: column;
  gap: var(--space-5);
}
.field { display: flex; flex-direction: column; gap: 0.5rem; }
.field label {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-muted);
  font-weight: 500;
}
.field__opt { color: var(--color-border-strong); text-transform: none; letter-spacing: 0; }
.field input,
.field select,
.field textarea {
  font: inherit;
  padding: 0.85rem 0.95rem;
  background: #fff;
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-base);
  color: var(--color-ink);
  transition: border-color var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
  width: 100%;
}
.field textarea { resize: vertical; min-height: 140px; }
.field input:focus,
.field select:focus,
.field textarea:focus {
  outline: none;
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(90,14,31,0.12);
}
.field input[aria-invalid="true"],
.field textarea[aria-invalid="true"] { border-color: #B91C1C; }
.error { font-size: 0.8125rem; color: #B91C1C; }
.field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
}
@media (max-width: 640px) { .field-row { grid-template-columns: 1fr; } }
.form-status { font-size: 0.9375rem; min-height: 1.5em; }
.form-status--success { color: #166534; }
.form-status--error { color: #B91C1C; }
.form__note { font-size: 0.8125rem; color: var(--color-muted); }
.form__note a { border-bottom: 1px solid var(--color-accent); }

/* Visit */
.visit { padding: var(--section-pad) 0; border-top: 1px solid var(--color-border); }
.visit__grid {
  display: grid;
  gap: var(--space-7);
}
@media (min-width: 900px) { .visit__grid { grid-template-columns: 1fr 1.1fr; align-items: center; } }
.visit p { color: var(--color-muted); margin-top: 1rem; max-width: 52ch; }
.visit__address {
  font-style: normal;
  margin-top: 1.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--color-border);
  font-family: var(--font-mono);
  font-size: 0.9375rem;
  line-height: 1.7;
  color: var(--color-ink);
}
.visit__map iframe {
  border-radius: var(--radius-base);
  border: 1px solid var(--color-border);
  filter: grayscale(0.18) contrast(1.02);
}

/* ---------- LEGAL ---------- */
.legal { padding: clamp(48px, 6vw, 80px) 0 var(--section-pad); }
.legal .container { max-width: var(--container-max); }
.legal h1 { font-size: var(--fs-4xl); font-weight: 600; max-width: 18ch; }
.legal__updated {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-top: 1rem;
  margin-bottom: var(--space-7);
}
.legal section { margin-bottom: var(--space-7); }
.legal h2 {
  font-size: 1.375rem;
  font-weight: 600;
  margin-bottom: 0.75rem;
  padding-top: 0.5rem;
  border-top: 1px solid var(--color-border);
  padding-top: 1.25rem;
}
.legal p { color: var(--color-ink-2); margin-bottom: 0.85rem; }
.legal a { border-bottom: 1px solid var(--color-accent); }
.legal .checklist { margin: 0.75rem 0; }
.legal code {
  font-family: var(--font-mono);
  font-size: 0.875em;
  background: var(--color-paper);
  padding: 0.1em 0.4em;
  border-radius: var(--radius-sm);
}

/* ---------- COOKIE BANNER ---------- */
.cookie-banner {
  position: fixed;
  left: 1rem; right: 1rem; bottom: 1rem;
  z-index: 100;
  padding: 1rem 1.25rem;
  background: var(--color-ink);
  color: #fff;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
}
.cookie-banner__content {
  display: flex; flex-direction: column;
  gap: 1rem;
}
.cookie-banner__text {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.5;
  color: rgba(255,255,255,0.85);
}
.cookie-banner__text a { color: #fff; border-bottom: 1px solid var(--color-accent); }
.cookie-banner__actions { display: flex; gap: 0.5rem; flex-shrink: 0; justify-content: flex-end; }
.cookie-banner .btn-ghost {
  border-color: rgba(255,255,255,0.3);
  color: #fff;
}
.cookie-banner .btn-ghost:hover { background: #fff; color: var(--color-ink); border-color: #fff; }
@media (min-width: 768px) {
  .cookie-banner {
    left: auto; right: 1.5rem; bottom: 1.5rem;
    max-width: 30rem;
  }
  .cookie-banner__content { flex-direction: row; align-items: center; }
}

/* ---------- REVEAL ANIMATIONS ----------
   Default state = visible. JS gates the hidden state behind html.js.
   Falls back to visible if JS, IntersectionObserver, or reduced motion. */
.reveal-fade, .reveal-clip { opacity: 1; transform: none; }

html.js .reveal-fade {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 600ms var(--ease-quint), transform 600ms var(--ease-quint);
}
html.js .reveal-fade.is-visible { opacity: 1; transform: translateY(0); }

html.js .reveal-clip {
  clip-path: inset(0 100% 0 0);
  transition: clip-path 700ms var(--ease-quint);
}
html.js .reveal-clip.is-visible { clip-path: inset(0 0 0 0); }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  .reveal-fade, .reveal-clip { opacity: 1 !important; transform: none !important; clip-path: none !important; }
}
