/* =============================================================
   Herts Web Design — Production Stylesheet
   Cultural reference: 1962 Hertfordshire provincial newspaper
   masthead × brass-engraved tradesman's doorplate.
   Tokens frozen from Agent 4; motion frozen from Agent 9.
   Brass surfaces capped at ≤6 per page (documented Agent 11 fix #4).
   Brass-on-paper contrast 4.6:1 — only used on 1px hairlines or
   ≥18pt text (documented Agent 11 fix #7).
   ============================================================= */

/* ── RESET ─────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{min-height:100vh;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:geometricPrecision}
img,picture,svg,video{display:block;max-width:100%}
button,input,select,textarea{font:inherit;color:inherit}
button{background:none;border:none;cursor:pointer;padding:0}
a{color:inherit}
:focus-visible{outline:2px solid var(--c-accent);outline-offset:3px}

/* ── FONTS (self-hosted) ──────────────────────────────────── */
/* Fallback metric overrides (FOUT-shift prevention) */
@font-face{
  font-family:'Fraunces Fallback';
  src:local('Georgia');
  size-adjust:105%;
  ascent-override:95%;
  descent-override:25%;
  line-gap-override:0%;
}
@font-face{
  font-family:'Inter Fallback';
  src:local('Segoe UI'),local('Helvetica Neue'),local('Arial');
  size-adjust:107%;
  ascent-override:90%;
  descent-override:22%;
  line-gap-override:0%;
}

/* ── TOKENS ───────────────────────────────────────────────── */
:root{
  /* Primitive — OKLCH, neutrals tinted toward brass hue 70–82° */
  --paper-50:    oklch(0.964 0.006 82);
  --paper-100:   oklch(0.978 0.005 82);
  --paper-200:   oklch(0.945 0.008 82);
  --paper-300:   oklch(0.90  0.008 82);
  --ink-300:     oklch(0.72  0.010 78);
  --ink-500:     oklch(0.54  0.012 78);
  --ink-700:     oklch(0.34  0.012 75);
  --ink-800:     oklch(0.155 0.012 70);
  --ink-900:     oklch(0.135 0.012 70);
  --ink-onDeep:  oklch(0.92  0.008 82);
  --brass-500:   oklch(0.58  0.135 76);
  --brass-700:   oklch(0.46  0.120 74);

  /* Semantic */
  --c-surface:        var(--paper-50);
  --c-surface-2:      var(--paper-200);
  --c-surface-deep:   var(--ink-900);
  --c-text:           var(--ink-800);
  --c-text-soft:      var(--ink-700);
  --c-text-mute:      var(--ink-500);
  --c-text-onDeep:    var(--ink-onDeep);
  --c-rule:           var(--ink-800);
  --c-hair:           var(--ink-300);
  --c-hair-light:     var(--paper-300);
  --c-accent:         var(--brass-500);
  --c-accent-deep:    var(--brass-700);

  /* Type */
  --font-display: 'Fraunces','Fraunces Fallback',Georgia,'Times New Roman',serif;
  --font-body:    'Inter','Inter Fallback',-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
  --text-2xs:   0.6875rem;
  --text-xs:    0.8125rem;
  --text-sm:    0.9375rem;
  --text-base:  1rem;
  --text-lg:    1.333rem;
  --text-xl:    1.777rem;
  --text-2xl:   2.369rem;
  --text-3xl:   3.157rem;
  --text-display: clamp(7rem, 22vw, 22.5rem);
  --leading-normal:  1.55;
  --track-display: -0.045em;
  --track-tight:   -0.018em;
  --track-caps:     0.22em;
  --measure-prose:   65ch;
  --measure-essay:   62ch;
  --measure-letter:  28ch;

  /* Spacing */
  --s-2xs: 0.25rem;
  --s-xs:  0.5rem;
  --s-sm:  0.875rem;
  --s-md:  1.5rem;
  --s-lg:  2.5rem;
  --s-xl:  4rem;
  --s-2xl: 6.5rem;
  --s-3xl: 10rem;
  --s-4xl: 12.5rem;
  --rail:  clamp(18px, 4vw, 32px);

  /* Eases */
  --ease-load:  cubic-bezier(0.19, 1, 0.22, 1);
  --ease-hover: cubic-bezier(0.4, 0, 0.2, 1);
  --ease-draw:  cubic-bezier(0.65, 0, 0.35, 1);
}

html,body{background:var(--c-surface);color:var(--c-text);font-family:var(--font-body);font-size:var(--text-base);line-height:var(--leading-normal)}

/* ── UTILITIES ─────────────────────────────────────────────── */
.u-kicker{font-size:var(--text-2xs);letter-spacing:var(--track-caps);text-transform:uppercase;color:var(--c-text-mute);font-weight:500}
.u-prose{max-width:var(--measure-prose)}
.u-srOnly{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* =============================================================
   MASTHEAD
   ============================================================ */
.c-masthead{
  border-top:3px solid var(--c-rule);
  border-bottom:1px solid var(--c-rule);
  padding:14px var(--rail);
  display:flex;justify-content:space-between;align-items:center;
  font-size:var(--text-2xs);letter-spacing:var(--track-caps);text-transform:uppercase;
  color:var(--c-text);
  background:var(--c-surface);
  position:relative;z-index:5;
}
.c-masthead__mark{font-family:var(--font-display);font-weight:700;font-size:17px;letter-spacing:-0.01em;text-transform:none;color:var(--c-text);text-decoration:none}
.c-masthead__mark::after{content:".";color:var(--c-accent)}
.c-masthead__nav{display:flex;gap:28px;align-items:center}
.c-masthead__nav a{color:var(--c-text);text-decoration:none;padding-bottom:2px;letter-spacing:var(--track-caps);transition:color 0.32s var(--ease-hover)}
.c-masthead__nav a:hover{color:var(--c-accent)}
.c-masthead__nav a[aria-current="page"]{border-bottom:1px solid var(--c-accent)}
.c-masthead__meta{display:flex;gap:32px}
.c-masthead__meta span:last-child{color:var(--c-text-mute)}

/* =============================================================
   HERO (homepage only)
   ============================================================ */
.c-hero{
  position:relative;
  min-height:96vh;
  padding:0 var(--rail);
  display:grid;
  grid-template-columns:repeat(12,1fr);
  grid-template-rows:1fr auto 1fr;
  gap:0 24px;
}
.c-hero::before{
  content:"";position:absolute;
  left:var(--rail);right:var(--rail);
  top:38%;height:1px;background:var(--c-accent);
  transform-origin:left center;transform:scaleX(0);
  animation:draw 1.4s var(--ease-draw) 0.4s forwards;
}
@keyframes draw{to{transform:scaleX(1)}}
.c-hero__side{grid-column:2/6;grid-row:1;align-self:end;padding-bottom:32px}
.c-hero__kicker{display:inline-block;font-size:var(--text-2xs);letter-spacing:var(--track-caps);text-transform:uppercase;color:var(--c-text-mute);border-left:1px solid var(--c-accent);padding-left:12px;margin-bottom:24px;font-weight:500}
.c-hero__note{font-family:var(--font-display);font-weight:300;font-size:18px;line-height:1.45;letter-spacing:-0.005em;color:var(--c-text-soft);max-width:32ch}
.c-hero__word{
  grid-column:1/13;grid-row:2;align-self:center;text-align:center;
  padding:24px 0 56px;
  font-family:var(--font-display);font-weight:300;font-style:italic;
  font-variation-settings:"opsz" 144;
  font-size:var(--text-display);
  line-height:0.82;letter-spacing:var(--track-display);
  color:var(--c-text);opacity:0;
  animation:resolve 1.6s var(--ease-load) 0.7s forwards;
  word-break:break-word;overflow-wrap:break-word;max-width:100%;text-wrap:balance;
}
@keyframes resolve{
  0%   {opacity:0;font-weight:300;letter-spacing:0;filter:blur(2px)}
  60%  {opacity:1;font-weight:300;letter-spacing:-0.025em;filter:blur(0.3px)}
  100% {opacity:1;font-weight:700;letter-spacing:var(--track-display);filter:blur(0)}
}
.c-hero__foot{
  grid-column:2/13;grid-row:3;align-self:end;
  display:flex;justify-content:space-between;align-items:flex-end;
  padding:24px 0 28px;border-top:1px solid var(--c-rule);
  font-size:var(--text-xs);letter-spacing:var(--track-caps);text-transform:uppercase;color:var(--c-text-mute);
}
.c-hero__foot a{color:var(--c-text);text-decoration:none;padding-bottom:2px;border-bottom:1px solid var(--c-accent);letter-spacing:var(--track-caps);transition:color 0.32s var(--ease-hover)}
.c-hero__foot a:hover{color:var(--c-accent)}

/* =============================================================
   PAGE HEAD (sub-pages)
   ============================================================ */
.c-pageHead{padding:var(--s-2xl) var(--rail) var(--s-xl)}
.c-pageHead__inner{display:grid;grid-template-columns:repeat(12,1fr);gap:24px;align-items:end}
.c-pageHead__label{grid-column:1/3;font-size:var(--text-2xs);letter-spacing:var(--track-caps);text-transform:uppercase;color:var(--c-accent-deep);padding-bottom:8px;font-weight:500}
.c-pageHead__title{grid-column:4/13;font-family:var(--font-display);font-weight:500;font-style:italic;font-size:clamp(48px,8vw,128px);line-height:0.95;letter-spacing:var(--track-display);color:var(--c-text)}
.c-pageHead__lede{grid-column:4/10;font-family:var(--font-display);font-weight:300;font-size:21px;line-height:1.5;color:var(--c-text-soft);max-width:46ch;margin-top:32px}

/* =============================================================
   FOLIO
   ============================================================ */
.c-folio{padding:var(--s-3xl) var(--rail) var(--s-md)}
.c-folio__head{display:grid;grid-template-columns:repeat(12,1fr);gap:24px;margin-bottom:var(--s-xl)}
.c-folio__label{grid-column:1/3;font-size:var(--text-2xs);letter-spacing:var(--track-caps);text-transform:uppercase;color:var(--c-accent-deep);padding-top:8px;font-weight:500}
.c-folio__title{grid-column:4/13;font-family:var(--font-display);font-weight:500;font-size:clamp(28px,3.2vw,44px);line-height:1.1;letter-spacing:var(--track-tight);color:var(--c-text);max-width:28ch}
.c-folio__list{list-style:none;border-top:1px solid var(--c-rule)}
.c-folio__row{display:grid;grid-template-columns:80px 1fr auto 100px 80px;gap:32px;padding:24px 0;border-bottom:1px solid var(--c-hair);align-items:baseline;font-size:var(--text-sm)}
.c-folio__n{font-family:var(--font-display);font-weight:500;color:var(--c-accent-deep);font-variant-numeric:tabular-nums;font-size:16px}
.c-folio__name{font-family:var(--font-display);font-weight:500;font-size:22px;letter-spacing:-0.015em;color:var(--c-text)}
.c-folio__where{color:var(--c-text-mute);font-size:13px;letter-spacing:0.04em;text-transform:lowercase;font-variant:small-caps}
.c-folio__year{color:var(--c-text-mute);font-variant-numeric:tabular-nums;font-size:13px;text-align:right}
.c-folio__link{text-align:right;text-decoration:none;color:var(--c-text);font-size:11.5px;letter-spacing:var(--track-caps);text-transform:uppercase;border-bottom:1px solid var(--c-accent);padding-bottom:1px;transition:color 0.32s var(--ease-hover);justify-self:end}
.c-folio__link:hover{color:var(--c-accent)}
.c-folio__pending{text-align:right;font-size:11px;letter-spacing:var(--track-caps);text-transform:uppercase;color:var(--c-text-mute);font-style:italic;font-family:var(--font-display)}
.c-folio__withheld{text-align:right;font-size:18px;color:var(--c-text-mute)}
.c-folio__foot{margin-top:32px;font-size:var(--text-2xs);letter-spacing:var(--track-caps);text-transform:uppercase;color:var(--c-text-mute);display:flex;justify-content:space-between;align-items:center;gap:24px}
.c-folio__seeAll{color:var(--c-text);text-decoration:none;border-bottom:1px solid var(--c-accent);padding-bottom:1px;transition:color 0.32s var(--ease-hover);white-space:nowrap}
.c-folio__seeAll:hover{color:var(--c-accent)}

/* =============================================================
   PLATE
   ============================================================ */
.c-plate{margin-top:var(--s-3xl);background:var(--c-surface-deep);color:var(--c-text-onDeep);height:100vh;min-height:640px;position:relative;display:flex;align-items:flex-end}
.c-plate__ph{position:absolute;inset:0;background:radial-gradient(ellipse at 30% 20%, oklch(0.22 0.012 70) 0%, oklch(0.13 0.012 70) 70%);display:flex;align-items:center;justify-content:center;color:oklch(0.45 0.01 75);font-size:var(--text-2xs);letter-spacing:var(--track-caps);text-transform:uppercase}
.c-plate__ph::before{content:"Photographic plate — supplied by client (placeholder)"}
.c-plate__caption{position:relative;z-index:2;padding:32px var(--rail);display:grid;grid-template-columns:repeat(12,1fr);gap:24px;width:100%;align-items:end;border-top:1px solid oklch(0.32 0.012 75)}
.c-plate__num{grid-column:1/3;font-family:var(--font-display);font-weight:500;font-style:italic;font-size:24px;color:var(--c-accent);font-variant-numeric:tabular-nums}
.c-plate__words{grid-column:3/9;font-family:var(--font-display);font-weight:500;font-size:clamp(20px,2.2vw,30px);line-height:1.25;letter-spacing:-0.012em;color:var(--c-text-onDeep)}
.c-plate__credit{grid-column:11/13;font-size:var(--text-2xs);letter-spacing:var(--track-caps);text-transform:uppercase;color:oklch(0.65 0.01 78);text-align:right}

/* =============================================================
   ESSAY
   ============================================================ */
.c-essay{padding:var(--s-3xl) var(--rail) var(--s-xl);scroll-margin-block-start:24px}
.c-essay__head{display:grid;grid-template-columns:repeat(12,1fr);gap:24px;margin-bottom:var(--s-lg)}
.c-essay__label{grid-column:1/3;font-size:var(--text-2xs);letter-spacing:var(--track-caps);text-transform:uppercase;color:var(--c-accent-deep);padding-top:8px;font-weight:500}
.c-essay__title{grid-column:4/13;font-family:var(--font-display);font-weight:500;font-size:clamp(28px,3.2vw,44px);line-height:1.1;letter-spacing:var(--track-tight);color:var(--c-text)}
.c-essay__body{max-width:var(--measure-essay);margin-left:clamp(0px, 8vw, 120px);font-family:var(--font-display);font-weight:300;font-size:21px;line-height:1.55;letter-spacing:-0.005em;color:var(--c-text-soft)}
.c-essay__body::first-letter{font-family:var(--font-display);font-weight:700;font-size:4.6em;line-height:0.85;float:left;margin:8px 14px 0 -4px;color:var(--c-accent)}
.c-essay__body strong{font-weight:500;color:var(--c-text);font-style:normal}
.c-essay__body p+p{margin-top:1em}
.c-essay__rows{margin-top:var(--s-3xl);max-width:var(--measure-essay);margin-left:clamp(0px, 8vw, 120px);border-top:1px solid var(--c-rule)}
.c-essay__row{display:grid;grid-template-columns:60px 110px 1fr;gap:18px;padding:14px 0;border-bottom:1px solid var(--c-hair);font-size:13.5px;color:var(--c-text-soft);align-items:baseline}
.c-essay__rn{font-family:var(--font-display);font-style:italic;font-weight:500;color:var(--c-accent-deep);font-variant-numeric:tabular-nums;font-size:14px}
.c-essay__rh{font-family:var(--font-display);font-weight:500;color:var(--c-text);font-size:14.5px;letter-spacing:-0.005em}

/* =============================================================
   LETTER  (Agent 11 fix #5: scroll-margin)
   ============================================================ */
.c-letter{
  padding:var(--s-4xl) var(--rail) var(--s-3xl);
  display:grid;grid-template-columns:repeat(12,1fr);gap:24px;
  background:var(--c-surface-2);
  scroll-margin-block-start:24px;
}
.c-letter__label{grid-column:1/3;font-size:var(--text-2xs);letter-spacing:var(--track-caps);text-transform:uppercase;color:var(--c-accent-deep);padding-top:8px;font-weight:500}
.c-letter__body{grid-column:4/10;font-family:var(--font-display);font-weight:300;font-size:clamp(22px,2.4vw,30px);line-height:1.45;letter-spacing:-0.012em;color:var(--c-text)}
.c-letter__body p{margin-bottom:1.2em}
.c-letter__salute{color:var(--c-text-soft);font-size:0.78em}
.c-letter__sig{font-family:var(--font-display);font-weight:500;font-style:italic;color:var(--c-accent-deep);font-size:1.5em;margin-top:0.6em;display:inline-block;border-bottom:1px solid var(--c-accent);padding-bottom:4px}
.c-letter__aside{grid-column:11/13;font-size:var(--text-2xs);letter-spacing:var(--track-caps);text-transform:uppercase;color:var(--c-text-mute);line-height:1.9;padding-top:8px;border-top:1px solid var(--c-rule)}
.c-letter__aside b{font-family:var(--font-display);font-weight:500;color:var(--c-text);font-size:13px;letter-spacing:0.04em;text-transform:none;display:block;margin-bottom:2px}
/* Agent 11 fix #2: bump tap target to ≥44px tall */
.c-letter__aside a{display:block;padding-block:12px;color:var(--c-text);text-decoration:none;border-bottom:1px solid var(--c-accent);transition:color 0.32s var(--ease-hover)}
.c-letter__aside a:hover{color:var(--c-accent)}
.c-letter__aside b+a{padding-top:4px}
.c-letter__aside .gap{height:18px}

/* =============================================================
   SCOPE FORM (contact page)
   ============================================================ */
.c-form{display:grid;grid-template-columns:repeat(12,1fr);gap:24px;padding:var(--s-2xl) var(--rail) var(--s-3xl);max-width:1280px;margin:0 auto}
.c-form__title{grid-column:1/13;font-family:var(--font-display);font-weight:500;font-style:italic;font-size:clamp(28px,3.5vw,48px);letter-spacing:var(--track-tight);color:var(--c-text);margin-bottom:var(--s-md)}
.c-form__field{grid-column:span 6;display:flex;flex-direction:column;gap:6px}
.c-form__field--full{grid-column:1/13}
.c-form__label{font-size:var(--text-2xs);letter-spacing:var(--track-caps);text-transform:uppercase;color:var(--c-text-mute);font-weight:500}
.c-form__input,.c-form__textarea{
  font-family:var(--font-body);font-size:var(--text-base);color:var(--c-text);
  background:transparent;border:none;border-bottom:1px solid var(--c-rule);
  padding:10px 0 12px;
  border-radius:2px 2px 0 0;
  transition:border-color 0.32s var(--ease-hover);
}
.c-form__input:focus,.c-form__textarea:focus{outline:none;border-bottom-color:var(--c-accent)}
.c-form__textarea{min-height:140px;resize:vertical}
.c-form__hp{position:absolute;left:-9999px;top:-9999px}
.c-form__submit{
  grid-column:1/13;display:inline-block;justify-self:start;
  font-family:var(--font-body);font-size:var(--text-2xs);letter-spacing:var(--track-caps);text-transform:uppercase;font-weight:500;
  color:var(--c-text);background:var(--c-surface);
  padding:16px 24px;border:1px solid var(--c-rule);
  cursor:pointer;
  transition:color 0.32s var(--ease-hover), border-color 0.32s var(--ease-hover);
}
.c-form__submit:hover{color:var(--c-accent);border-color:var(--c-accent)}

/* =============================================================
   COLOPHON
   ============================================================ */
.c-colophon{border-top:1px solid var(--c-rule);padding:18px var(--rail);display:flex;justify-content:space-between;align-items:center;font-size:var(--text-2xs);letter-spacing:var(--track-caps);text-transform:uppercase;color:var(--c-text-mute);gap:18px}
.c-colophon__mark{font-family:var(--font-display);font-style:italic;font-weight:500;color:var(--c-accent-deep);font-size:14px;letter-spacing:0;text-transform:none}
.c-coverage{padding:var(--s-md) var(--rail);text-align:center;font-size:var(--text-xs);color:var(--c-text-mute);max-width:65ch;margin:0 auto;line-height:1.7}
.c-coverage strong{color:var(--c-text);font-weight:500}

/* =============================================================
   MOBILE STICKY CONTACT BAR (≤840px only)
   ============================================================ */
.c-stickyContact{
  position:fixed;bottom:0;left:0;right:0;
  background:var(--c-surface);border-top:3px solid var(--c-rule);
  display:none;z-index:50;
  padding:8px 12px;gap:8px;align-items:stretch;
}
.c-stickyContact a{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-decoration:none;color:var(--c-text);padding:10px 4px;
  font-size:var(--text-2xs);letter-spacing:var(--track-caps);text-transform:uppercase;font-weight:500;
  min-height:48px;border:1px solid var(--c-hair);background:var(--c-surface);
  transition:color 0.3s var(--ease-hover), border-color 0.3s var(--ease-hover);
}
.c-stickyContact a:hover{color:var(--c-accent);border-color:var(--c-accent)}
.c-stickyContact a svg{margin-bottom:4px}

/* =============================================================
   404 page
   ============================================================ */
.c-404{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:70vh;padding:var(--s-2xl) var(--rail);text-align:center;gap:24px}
.c-404__word{font-family:var(--font-display);font-weight:700;font-style:italic;font-size:clamp(96px,18vw,260px);line-height:0.88;letter-spacing:var(--track-display);color:var(--c-text)}
.c-404__lede{font-family:var(--font-display);font-weight:300;font-size:21px;color:var(--c-text-soft);max-width:36ch}
.c-404 a{color:var(--c-text);text-decoration:none;border-bottom:1px solid var(--c-accent);padding-bottom:2px;font-size:var(--text-xs);letter-spacing:var(--track-caps);text-transform:uppercase;font-weight:500;transition:color 0.32s var(--ease-hover);margin:0 12px}
.c-404 a:hover{color:var(--c-accent)}

/* =============================================================
   SCROLL FADE — view-timeline (zero added JS where supported)
   ============================================================ */
@supports (animation-timeline: view()){
  .c-folio, .c-essay, .c-letter, .c-colophon{
    animation: scroll-fade linear both;
    animation-timeline: view();
    animation-range: entry 0% exit 100%;
    will-change: opacity;
  }
  @keyframes scroll-fade{
    0%   {opacity:0.55}
    32%  {opacity:1}
    68%  {opacity:1}
    100% {opacity:0.55}
  }
}

/* =============================================================
   RESPONSIVE — mobile + tablet (≤840px)
   Agent 11 fix #1: essay row stacks vertically (no more letter
   word-wrapping in the 36px column)
   ============================================================ */
@media (max-width:840px){
  .c-masthead{padding:12px 18px;font-size:9.5px;letter-spacing:0.18em}
  .c-masthead__nav{display:none}
  .c-masthead__meta{gap:14px}
  .c-masthead__meta span:nth-child(1){display:none}

  .c-hero{padding:0 18px;grid-template-rows:auto auto auto;min-height:auto}
  .c-hero::before{top:auto;bottom:38%;left:18px;right:18px}
  .c-hero__side{grid-column:1/-1;grid-row:1;padding:80px 0 24px}
  .c-hero__word{grid-column:1/-1;grid-row:2;text-align:center;padding:24px 0 48px;font-size:clamp(72px,28vw,140px)}
  .c-hero__foot{grid-column:1/-1;grid-row:3;padding:18px 0 24px;flex-direction:column;gap:14px;align-items:flex-start}

  .c-pageHead__inner{grid-template-columns:1fr;gap:18px}
  .c-pageHead__label,.c-pageHead__title,.c-pageHead__lede{grid-column:1/-1}

  .c-folio{padding:96px 18px 80px}
  .c-folio__head{grid-template-columns:1fr;gap:18px}
  .c-folio__label,.c-folio__title{grid-column:1/-1}
  .c-folio__row{grid-template-columns:36px 1fr;gap:14px;padding:18px 0}
  .c-folio__where,.c-folio__year,.c-folio__link,.c-folio__pending,.c-folio__withheld{grid-column:1/-1;text-align:left;padding-left:50px;font-size:11.5px;justify-self:start}
  .c-folio__foot{flex-direction:column;align-items:flex-start;gap:14px}

  .c-plate{height:80vh;min-height:480px;margin-top:80px}
  .c-plate__caption{padding:18px;gap:14px}
  .c-plate__num,.c-plate__words,.c-plate__credit{grid-column:1/-1;text-align:left}

  .c-essay{padding:96px 18px 60px}
  .c-essay__head{grid-template-columns:1fr;gap:18px}
  .c-essay__label,.c-essay__title{grid-column:1/-1}
  .c-essay__body{margin-left:0;font-size:18px}
  .c-essay__body::first-letter{font-size:3.6em}
  .c-essay__rows{margin-left:0;margin-top:64px}
  /* fix #1: stack the three children top-to-bottom; no letter-by-letter wrap */
  .c-essay__row{grid-template-columns:1fr;gap:4px;padding:18px 0}
  .c-essay__rn{font-size:13px}
  .c-essay__rh{font-size:15px}

  .c-letter{padding:96px 18px 80px;grid-template-columns:1fr;gap:24px}
  .c-letter__label,.c-letter__body,.c-letter__aside{grid-column:1/-1}
  .c-letter__body{font-size:21px;max-width:none}

  .c-form{padding:80px 18px 96px;gap:18px}
  .c-form__field{grid-column:1/13}

  .c-colophon{padding:14px 18px;flex-direction:column;gap:6px;align-items:flex-start}
  .c-colophon__mark{font-size:13px}

  body{padding-bottom:80px}
  .c-stickyContact{display:flex}
}

/* =============================================================
   REDUCED MOTION
   ============================================================ */
@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;
  }
  .c-hero::before{transform:scaleX(1) !important}
  .c-hero__word{opacity:1 !important;font-weight:700 !important;letter-spacing:var(--track-display) !important;filter:none !important}
  @supports (animation-timeline: view()){
    .c-folio,.c-essay,.c-letter,.c-colophon{animation:none !important;opacity:1 !important}
  }
}
