:root {
  --paper: #f4f1ea;
  --paper-2: #ece7dc;
  --ink: #1b1916;
  --muted: #6f685c;
  --accent: #b5462f;
  --line: rgba(27, 25, 22, .16);
  --serif: "Fraunces", Georgia, "Times New Roman", serif;
  --sans: "Hanken Grotesk", system-ui, -apple-system, Segoe UI, sans-serif;
  --wrap: 1180px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0; background: var(--paper); color: var(--ink);
  font-family: var(--sans); font-size: 18px; line-height: 1.6;
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
}
img { display: block; max-width: 100%; }
a { color: inherit; }
em { font-style: italic; }

.wrap { width: 100%; max-width: var(--wrap); margin-inline: auto; padding-inline: clamp(20px, 5vw, 56px); }

.skip { position: absolute; left: -9999px; background: var(--ink); color: var(--paper); padding: 10px 16px; }
.skip:focus { left: 16px; top: 16px; z-index: 99; }

.display { font-family: var(--serif); font-weight: 340; font-optical-sizing: auto;
  letter-spacing: -.015em; line-height: .98; margin: 0; }
.kicker, .marker { font-size: .74rem; font-weight: 600; text-transform: uppercase;
  letter-spacing: .22em; color: var(--accent); }
.muted { color: var(--muted); }

/* Masthead */
.masthead { position: sticky; top: 0; z-index: 40; background: color-mix(in srgb, var(--paper) 88%, transparent);
  backdrop-filter: blur(8px); border-bottom: 1px solid var(--line); }
.masthead__inner { display: flex; align-items: baseline; justify-content: space-between; gap: 20px; padding-block: 18px; }
.wordmark { font-family: var(--serif); font-weight: 500; font-size: 1.12rem; letter-spacing: -.01em; text-decoration: none; }
.masthead nav { display: flex; flex-wrap: wrap; justify-content: flex-end; align-items: center; gap: clamp(13px, 2.6vw, 28px); }
.masthead nav > a { text-decoration: none; font-size: .82rem; text-transform: uppercase; letter-spacing: .12em;
  font-weight: 600; color: var(--muted); padding-block: 6px; transition: color .15s; }
.masthead nav > a:hover { color: var(--ink); }
.masthead nav .ext { color: var(--accent); }
.lang { display: inline-flex; border: 1.5px solid var(--ink); border-radius: 999px; overflow: hidden;
  font-size: .76rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; }
.lang a { padding: 6px 13px; line-height: 1; color: var(--ink); text-decoration: none; transition: background .15s, color .15s; }
.lang a + a { border-left: 1.5px solid var(--ink); }
.lang a[aria-current="page"] { background: var(--ink); color: var(--paper); }
.lang a:not([aria-current]):hover { background: rgba(27, 25, 22, .08); }

/* Hero */
.hero { display: grid; grid-template-columns: 1.25fr 1fr; gap: clamp(28px, 6vw, 72px);
  align-items: end; padding-top: clamp(48px, 9vw, 120px); padding-bottom: clamp(40px, 6vw, 72px); }
.hero__text .kicker { margin: 0 0 26px; }
.hero h1 { font-size: clamp(3rem, 9.5vw, 7rem); }
.hero h1 em { color: var(--accent); }
.standfirst { font-size: clamp(1.1rem, 1.7vw, 1.35rem); color: #443f37; max-width: 34ch; margin: 30px 0 30px; }
.hero__meta { display: flex; align-items: center; flex-wrap: wrap; gap: 14px; font-size: .95rem; }
.hero__meta .dot { color: var(--line); }
.textlink { font-weight: 600; text-decoration: none; border-bottom: 2px solid var(--accent);
  padding-bottom: 2px; color: var(--ink); transition: color .15s, border-color .15s; }
.textlink:hover { color: var(--accent); }
.textlink span { display: inline-block; transition: transform .2s; }
.textlink:hover span { transform: translateX(5px); }
.hero__portrait { margin: 0; }
.hero__portrait img { width: 100%; aspect-ratio: 1 / 1; object-fit: cover; object-position: 50% 30%;
  filter: grayscale(100%) contrast(1.04); border: 1px solid var(--line); }
.hero__portrait figcaption { margin-top: 12px; font-size: .76rem; text-transform: uppercase;
  letter-spacing: .18em; color: var(--muted); }

/* Running rule */
.rule { display: flex; flex-wrap: wrap; gap: clamp(20px, 5vw, 64px); padding-block: 22px;
  border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
  font-size: .76rem; text-transform: uppercase; letter-spacing: .2em; color: var(--muted); }

/* Bands (about / projects) */
.band { display: grid; grid-template-columns: 200px 1fr; gap: clamp(24px, 5vw, 64px);
  padding-block: clamp(56px, 9vw, 120px); border-bottom: 1px solid var(--line); }
.band .marker { margin: 6px 0 0; position: sticky; top: 96px; align-self: start; }
.band__body { max-width: 62ch; }
.band__body--wide { max-width: none; }
.lede { font-family: var(--serif); font-weight: 360; font-size: clamp(1.45rem, 2.6vw, 2.1rem);
  line-height: 1.28; letter-spacing: -.01em; margin: 0 0 1.4em; }
.band__body p:not(.lede) { color: #443f37; margin: 0 0 1.25em; }
.band__body p:last-child { margin-bottom: 0; }

/* Project index */
.index { list-style: none; margin: 2.2em 0 0; padding: 0; counter-reset: none; }
.index__row { display: grid; grid-template-columns: 64px 1fr auto; gap: clamp(16px, 3vw, 40px);
  align-items: baseline; padding: 30px 0; border-top: 1px solid var(--line); transition: padding-left .25s ease; }
.index__row:hover { padding-left: 12px; }
.index__no { font-family: var(--serif); font-weight: 320; font-size: 1.5rem; color: var(--muted);
  font-feature-settings: "tnum"; }
.index__main h3 { font-family: var(--serif); font-weight: 400; font-size: clamp(1.5rem, 3vw, 2.3rem);
  letter-spacing: -.01em; margin: 0 0 .35em; transition: color .2s; }
.index__row:hover h3 { color: var(--accent); }
.index__main p { margin: 0; color: #443f37; max-width: 56ch; font-size: 1rem; }
.index__main h3 a { text-decoration: none; color: inherit; }
.index__main h3 .arr { font-size: .46em; vertical-align: super; color: var(--muted); margin-left: .12em; transition: color .2s; }
.index__row:hover .index__main h3 .arr { color: var(--accent); }
.index__meta { display: flex; flex-direction: column; align-items: flex-end; gap: 10px; text-align: right; }
.index__tag { font-size: .72rem; text-transform: uppercase; letter-spacing: .16em; color: var(--muted); white-space: nowrap; }
.index__links { display: flex; flex-direction: column; align-items: flex-end; gap: 5px; }
.index__links a { font-size: .72rem; text-transform: uppercase; letter-spacing: .12em; color: var(--muted);
  text-decoration: none; white-space: nowrap; transition: color .15s; }
.index__links a:hover { color: var(--accent); }

/* Contact */
.contact { padding-block: clamp(64px, 10vw, 140px); }
.marker--light { color: var(--accent); }
.contact__head { font-size: clamp(3rem, 11vw, 8rem); margin: 22px 0 .35em; }
.contact__head em { color: var(--accent); }
.contact__email { display: inline-block; font-family: var(--serif); font-size: clamp(1.4rem, 4vw, 2.6rem);
  text-decoration: none; border-bottom: 2px solid var(--accent); padding-bottom: 4px; }
.contact__grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 28px;
  margin: clamp(40px, 6vw, 64px) 0 0; border-top: 1px solid var(--line); padding-top: 28px; }
.contact__grid dt { font-size: .72rem; text-transform: uppercase; letter-spacing: .18em; color: var(--muted); margin-bottom: 8px; }
.contact__grid dd { margin: 0; font-size: 1.05rem; }
.contact__grid a { text-decoration: none; border-bottom: 1px solid var(--line); }
.contact__grid a:hover { border-color: var(--accent); }

/* Footer */
.foot { display: flex; justify-content: space-between; gap: 16px; padding-block: 30px;
  border-top: 1px solid var(--line); font-size: .82rem; text-transform: uppercase; letter-spacing: .14em; color: var(--muted); }

@media (max-width: 820px) {
  body { font-size: 17px; }
  .hero { grid-template-columns: 1fr; align-items: start; gap: 36px; }
  .hero__portrait { order: -1; max-width: 260px; }
  .hero__portrait img { aspect-ratio: 1; }
  .band { grid-template-columns: 1fr; gap: 18px; }
  .band .marker { position: static; }
  .index__row { grid-template-columns: 40px 1fr; }
  .index__meta { grid-column: 2; align-items: flex-start; text-align: left; flex-direction: row;
    flex-wrap: wrap; gap: 10px 18px; margin-top: 4px; }
  .index__links { flex-direction: row; flex-wrap: wrap; align-items: flex-start; gap: 14px; }
  .contact__grid { grid-template-columns: 1fr; gap: 22px; }
}
