/* ============================================================
   changecomms — Oscar Hillerstrom
   Confident. Minimal. Near-monochrome. Colour only as thin marks.
   Ink #0C1A28 (deep blue-black) on white. Signal yellow #F9A800
   used only as hairlines / ticks — never a block.
   Type: Geist (sans) + Geist Mono (labels). Motion: crisp, fast.
   ============================================================ */

:root{
  --ink:#0C1A28;
  --ink-soft:#39474F;
  --paper:#F8FAFC;
  --mist:#EFF3F6;
  --slate:#5B6772;
  --slate-lt:#929BA3;
  --signal:#FBBF24;
  --signal-dk:#E0A50C;
  --brand-blue:#123A5E;
  --line:#E7E9EC;
  --line-2:#EFF1F3;
  --swap-ghost:#7E868D;

  --sans:'Geist','Geist Sans',system-ui,-apple-system,'Segoe UI',sans-serif;
  --mono:'Geist Mono',ui-monospace,'SF Mono',Menlo,Consolas,monospace;

  --maxw:1080px;
  --measure:60ch;
  --ease:cubic-bezier(.22,1,.36,1);
  --ease-lux:cubic-bezier(.16,1,.3,1);

  --s1:.5rem; --s2:1rem; --s3:1.5rem; --s4:2rem;
  --s5:3rem; --s6:4.5rem; --s7:7rem; --s8:10rem;
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--sans);
  font-size:clamp(1.02rem,.98rem + .2vw,1.12rem);
  line-height:1.6;font-weight:400;letter-spacing:-.006em;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}

/* layout */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.5rem,5vw,3rem)}
.section{padding-block:clamp(4rem,9vw,8.5rem)}
.section--tight{padding-block:clamp(3rem,6vw,5rem)}
.prose{max-width:var(--measure)}
.rule{height:1px;background:var(--line);border:0;margin:0}

/* type */
h1,h2,h3{font-family:var(--sans);font-weight:600;color:var(--ink);margin:0;
  letter-spacing:-.025em;line-height:1.04}
h1{font-size:clamp(2.85rem,2rem + 4.6vw,5.3rem);line-height:.98;letter-spacing:-.038em}
h2{font-size:clamp(1.7rem,1.3rem + 1.7vw,2.45rem);letter-spacing:-.026em}
h3{font-size:clamp(1.2rem,1.08rem + .55vw,1.45rem);letter-spacing:-.02em}
p{margin:0 0 var(--s3)}
p:last-child{margin-bottom:0}
strong{font-weight:600;color:var(--ink)}

.eyebrow{font-family:var(--mono);font-size:.72rem;font-weight:500;
  text-transform:uppercase;letter-spacing:.18em;color:var(--slate);
  margin:0 0 var(--s4);display:flex;align-items:center}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--signal);
  margin-right:.8rem;flex:0 0 auto}

.lead{font-size:clamp(1.18rem,1.04rem + .65vw,1.5rem);line-height:1.46;
  color:var(--ink-soft);font-weight:400;letter-spacing:-.014em}
.muted{color:var(--slate)}
.small{font-size:.85rem;line-height:1.5}

a{color:var(--ink);text-decoration:none}
p a,.inline{text-decoration:underline;text-decoration-color:var(--signal);
  text-decoration-thickness:1.5px;text-underline-offset:3px;transition:color .16s}
p a:hover,.inline:hover{color:var(--signal-dk)}

/* scroll-depth indicator (thin yellow) */
.progress{position:fixed;top:0;left:0;height:2px;width:100%;background:var(--signal);
  transform:scaleX(0);transform-origin:0 50%;z-index:60;will-change:transform}

/* nav */
.nav{position:sticky;top:0;z-index:40;background:rgba(248,250,252,.80);
  backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--line);transition:box-shadow .4s var(--ease-lux),background .4s var(--ease-lux)}
.nav--scrolled{background:rgba(248,250,252,.92);box-shadow:0 10px 30px -26px rgba(12,26,40,.55)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;
  gap:var(--s3);flex-wrap:wrap;padding-block:var(--s3)}
.brand{font-size:1.08rem;font-weight:600;letter-spacing:-.02em;color:var(--ink);
  display:inline-flex;align-items:center;gap:.55rem}
.nav__links{display:flex;flex-wrap:wrap;gap:.45rem clamp(1.1rem,3vw,2.25rem);align-items:center;justify-content:flex-end}
.nav__links a{font-size:.92rem;font-weight:500;color:var(--slate);white-space:nowrap;
  padding-bottom:3px;border-bottom:1.5px solid transparent;
  transition:color .16s,border-color .16s}
.nav__links a:hover{color:var(--ink)}
.nav__links a[aria-current="page"]{color:var(--ink);border-color:var(--signal)}

/* hero */
.hero{padding-block:clamp(4.5rem,11vw,9rem) clamp(3.5rem,7vw,6rem)}
.hero h1{max-width:16ch}

/* centrepiece: the change swap — ink hands from one column to the other */
.hero h1.swap{max-width:none}
.swap{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.4rem,4vw,3.25rem);
  font-size:clamp(2rem,1.35rem + 2.7vw,3.55rem);line-height:1.04;
  letter-spacing:-.03em;font-weight:600}
.swap-line{display:block;color:var(--ink)}
@supports ((-webkit-background-clip:text) or (background-clip:text)){
  .swap-line{
    background-image:linear-gradient(100deg,var(--ink) 0%,var(--ink) 38%,
      var(--swap-ghost) 62%,var(--swap-ghost) 100%);
    background-size:260% 100%;background-repeat:no-repeat;background-position:0% 0;
    -webkit-background-clip:text;background-clip:text;
    -webkit-text-fill-color:transparent;color:transparent;
    animation:swapWash 11s ease-in-out infinite;
  }
  .swap-line.b{animation-delay:-5.5s}
}
@media (max-width:760px){
  .swap{grid-template-columns:1fr;gap:.1rem;font-size:clamp(2.3rem,8vw,3rem)}
}
.hero .lead{margin-top:var(--s4);max-width:46ch}
@media (min-width:760px){.hero .lead--nowrap{white-space:nowrap;max-width:none}}
.hero__need{margin-top:var(--s5);max-width:56ch;color:var(--ink-soft);font-size:1rem;line-height:1.62}
.hero__cta{margin-top:var(--s5);display:flex;gap:var(--s4);align-items:center;flex-wrap:wrap}
.hero__proof{margin-top:var(--s6);font-family:var(--mono);font-size:.76rem;
  letter-spacing:.04em;color:var(--slate-lt);text-transform:uppercase;line-height:1.7}

/* buttons */
.btn{display:inline-block;font-family:var(--sans);font-weight:600;font-size:.95rem;
  letter-spacing:-.01em;line-height:1;padding:.92rem 1.6rem;border-radius:7px;
  cursor:pointer;background:var(--ink);color:#fff;border:1px solid var(--ink);
  transition:background .16s,transform .16s,box-shadow .16s}
.btn:hover{background:#15293a;transform:translateY(-1px);
  box-shadow:0 8px 22px -10px rgba(12,26,40,.45);color:#fff}
.btn--ghost{background:transparent;color:var(--ink);border-color:#CBD2D8}
.btn--ghost:hover{background:var(--ink);color:#fff;border-color:var(--ink);box-shadow:none}
.link-arrow{font-family:var(--sans);font-weight:600;font-size:.95rem;color:var(--ink);
  display:inline-flex;align-items:center}
.link-arrow::after{content:"\2192";margin-left:.45rem;transition:margin .16s}
.link-arrow:hover::after{margin-left:.7rem}

/* two-line range (home) */
.range{margin-top:var(--s6);display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(1.75rem,5vw,4rem)}
.range .tag{font-family:var(--mono);font-size:.72rem;font-weight:500;
  text-transform:uppercase;letter-spacing:.12em;color:var(--slate-lt);
  display:block;margin-bottom:var(--s2)}
.range p{font-size:1.1rem;color:var(--ink-soft);max-width:34ch}

/* clients line */
.clients{margin-top:var(--s6);font-family:var(--mono);font-size:.78rem;
  text-transform:uppercase;letter-spacing:.06em;color:var(--slate-lt);
  display:flex;flex-wrap:wrap;gap:.4rem 0;line-height:1.8}
.clients .sep{color:var(--line);padding:0 .7rem}
.clients span{white-space:nowrap}

/* selected work (NOT a CV) */
.work{margin-top:var(--s6)}
.work-item{padding-block:var(--s6);border-top:1px solid var(--line)}
.work-item:first-child{border-top:0;padding-top:0}
.work-item__year{font-family:var(--mono);font-size:.74rem;color:var(--slate-lt);
  text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--s2)}
.work-item h3{margin-bottom:var(--s3)}
.work-item p{color:var(--ink-soft);max-width:62ch}

/* recognition line */
.recognition{max-width:62ch;color:var(--ink-soft)}
.recognition strong{color:var(--ink)}

/* quote */
.quote{margin:0;max-width:30ch}
.quote--wide{max-width:38ch}
.quote blockquote{margin:0;font-weight:500;
  font-size:clamp(1.55rem,1.15rem + 1.8vw,2.4rem);line-height:1.26;
  color:var(--ink);letter-spacing:-.025em;text-wrap:balance}
.quote blockquote::before{content:"\201C";color:var(--signal)}
.quote blockquote::after{content:"\201D";color:var(--signal)}
.quote figcaption{margin-top:var(--s4)}
.quote__name{display:block;font-weight:600;color:var(--ink);font-size:.96rem;letter-spacing:-.01em}
.quote__role{display:block;font-family:var(--mono);font-size:.72rem;color:var(--slate);
  text-transform:uppercase;letter-spacing:.07em;margin-top:.35rem;line-height:1.4}
.quote figcaption .ph{color:var(--slate-lt);text-transform:none;letter-spacing:0}

/* contact */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;
  gap:clamp(2rem,6vw,5rem);margin-top:var(--s6);align-items:start}
.contact-details dl{margin:0;display:grid;gap:var(--s4)}
.contact-details dt{font-family:var(--mono);font-size:.72rem;text-transform:uppercase;
  letter-spacing:.12em;color:var(--slate-lt);margin-bottom:.4rem}
.contact-details dd{margin:0;font-size:1.22rem;font-weight:500;color:var(--ink);letter-spacing:-.015em}
.contact-details dd a:hover{color:var(--signal-dk)}
.embed-box{border:1px solid var(--line);border-radius:10px;background:#FCFCFD;
  padding:clamp(2.5rem,5vw,4rem) var(--s4);text-align:center;color:var(--slate);
  min-height:280px;display:flex;flex-direction:column;justify-content:center;gap:var(--s3)}

/* footer (white, thin rule — no block) */
.foot{padding-block:var(--s6);border-top:1px solid var(--line)}
.foot__inner{display:flex;justify-content:space-between;gap:var(--s4);
  flex-wrap:wrap;align-items:flex-end}
.foot__brand{font-size:1.02rem;color:var(--ink);font-weight:600;letter-spacing:-.02em}
.foot__tag{font-family:var(--mono);color:var(--slate-lt);font-size:.76rem;
  margin-top:.5rem;letter-spacing:.03em}
.foot__links{font-size:.9rem;text-align:right;line-height:1.95}
.foot__links a{color:var(--slate)}
.foot__links a:hover{color:var(--ink)}
.foot__copy{font-family:var(--mono);font-size:.7rem;color:var(--slate-lt);
  margin-top:var(--s5);letter-spacing:.04em}

/* a11y */
:focus-visible{outline:2px solid var(--signal);outline-offset:3px;border-radius:3px}
.skip{position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;
  padding:.6rem 1rem;z-index:70;border-radius:0 0 7px 0}
.skip:focus{left:0;top:0}

/* motion: restrained, cinematic */
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@keyframes revealHead{from{opacity:0;clip-path:inset(0 0 100% 0);transform:translateY(12px)}
  to{opacity:1;clip-path:inset(0 0 0 0);transform:none}}
@keyframes drawRule{from{transform:scaleX(0)}to{transform:scaleX(1)}}
.rise{animation:rise .8s var(--ease-lux) backwards}
h1.rise{animation:revealHead 1s var(--ease-lux) backwards}
.rise.d1{animation-delay:.08s}.rise.d2{animation-delay:.18s}
.rise.d3{animation-delay:.3s}.rise.d4{animation-delay:.42s}
.js .hero .eyebrow::before,.js .section--tight .eyebrow::before{
  transform-origin:left center;animation:drawRule .85s var(--ease-lux) .12s backwards}

@keyframes swapWash{0%{background-position:0% 0}50%{background-position:100% 0}100%{background-position:0% 0}}

/* scroll reveal */
.js .reveal{opacity:0;transform:translateY(18px)}
.js .reveal.in{opacity:1;transform:none;
  transition:opacity .8s var(--ease-lux),transform .8s var(--ease-lux)}
/* headings wipe in from a clean edge */
.js .reveal :is(h1,h2){clip-path:inset(0 0 100% 0);transition:clip-path .95s var(--ease-lux)}
.js .reveal.in :is(h1,h2){clip-path:inset(0 0 0 0)}
/* the accent rule draws in */
.js .reveal .eyebrow::before{transform:scaleX(0);transform-origin:left center;
  transition:transform .7s var(--ease-lux) .06s}
.js .reveal.in .eyebrow::before{transform:scaleX(1)}

@media (prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important}
  .js .reveal{opacity:1 !important;transform:none !important}
  .js .reveal :is(h1,h2){clip-path:none !important}
  .js .reveal .eyebrow::before,
  .js .hero .eyebrow::before,.js .section--tight .eyebrow::before{transform:none !important}
  .progress{display:none}
}

/* responsive — desktop / pad / mobile */
@media (max-width:1024px){
  :root{--maxw:920px}
}
@media (max-width:820px){
  .range,.contact-grid{grid-template-columns:1fr}
  .range{gap:var(--s5)}
}
@media (max-width:600px){
  .nav__inner{padding-block:var(--s2)}
  .foot__inner{flex-direction:column;align-items:flex-start}
  .foot__links{text-align:left}
  .clients .sep,.hero__proof .sep{padding:0 .5rem}
}

/* ---- what I know -> what it means for you ---- */
.know{margin-top:var(--s6)}
.know__heads{display:grid;grid-template-columns:1fr 1.5fr;gap:clamp(1.5rem,4vw,3.5rem);
  padding-bottom:var(--s3);border-bottom:1px solid var(--ink)}
.know__heads span{font-family:var(--mono);font-size:.72rem;text-transform:uppercase;
  letter-spacing:.14em;color:var(--slate)}
.know-item{display:grid;grid-template-columns:1fr 1.5fr;gap:clamp(1.5rem,4vw,3.5rem);
  padding-block:var(--s4);border-bottom:1px solid var(--line);align-items:baseline}
.know-item__claim{font-weight:600;font-size:1.18rem;color:var(--ink);letter-spacing:-.018em}
.know-item__benefit{color:var(--ink-soft);font-size:1.06rem;line-height:1.5;max-width:44ch}
.know-item__benefit .hi{color:var(--ink);font-weight:600}
.know-closer{margin-top:var(--s6);font-size:clamp(1.5rem,1.1rem + 1.7vw,2.25rem);
  font-weight:600;letter-spacing:-.026em;color:var(--ink);max-width:22ch;line-height:1.16}
@media (max-width:760px){
  .know__heads{display:none}
  .know-item{grid-template-columns:1fr;gap:.45rem;padding-block:var(--s3)}
  .know-item__claim{font-size:1.12rem}
}

/* ---- work showcase: browser-frame previews ---- */
.showcase{margin-top:var(--s6);display:grid;gap:clamp(2.5rem,5vw,4.5rem)}
.site-card__frame{display:block;border:1px solid var(--line);border-radius:12px;overflow:hidden;
  background:#fff;box-shadow:0 1px 2px rgba(12,26,40,.05);
  transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.site-card__frame:hover,.site-card__frame:focus-visible{transform:translateY(-5px);
  box-shadow:0 26px 52px -24px rgba(12,26,40,.30)}
.site-card__bar{display:flex;align-items:center;gap:.7rem;padding:.7rem 1rem;
  background:var(--mist);border-bottom:1px solid var(--line)}
.site-card__dots{display:flex;gap:.4rem}
.site-card__dots i{width:10px;height:10px;border-radius:50%;background:#D4DADF;display:block}
.site-card__url{font-family:var(--mono);font-size:.74rem;color:var(--slate);background:#fff;
  border:1px solid var(--line);border-radius:5px;padding:.28rem .75rem;margin-left:.3rem;letter-spacing:.01em}
.site-card__view{position:relative;height:clamp(220px,42vw,430px);overflow:hidden;background:#fff}
.site-card__shot{width:100%;height:auto;display:block;transition:transform 6.5s var(--ease)}
.site-card__frame:hover .site-card__shot{transform:translateY(calc(-100% + clamp(220px,42vw,430px)))}
/* hero variant: single-screen capture fills the frame with a gentle zoom (no scroll) */
.site-card--hero .site-card__view{height:auto;aspect-ratio:16/10}
.site-card--hero .site-card__shot{position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:top center;transition:transform 6s var(--ease)}
.site-card--hero .site-card__frame:hover .site-card__shot{transform:scale(1.045)}
@media (prefers-reduced-motion:reduce){
  .site-card__frame:hover .site-card__shot,
  .site-card--hero .site-card__frame:hover .site-card__shot{transform:none}
}
.site-card__ph{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:var(--s2);text-align:center;background:linear-gradient(180deg,#fff,var(--mist))}
.site-card__ph b{font-size:clamp(1.4rem,1.1rem + 1.4vw,2rem);font-weight:600;
  letter-spacing:-.026em;color:var(--ink)}
.site-card__ph span{font-family:var(--mono);font-size:.72rem;color:var(--slate-lt);
  text-transform:uppercase;letter-spacing:.1em}
.site-card__cap{margin-top:var(--s4)}
.site-card__cap h3{margin-bottom:var(--s2)}
.site-card__cap p{color:var(--ink-soft);max-width:64ch}

/* ---- article / writing ---- */
.article{max-width:68ch}
.article .lead{color:var(--ink);font-size:clamp(1.26rem,1.05rem + .95vw,1.65rem);
  line-height:1.42;margin-bottom:var(--s5);letter-spacing:-.018em}
.article h2{font-size:clamp(1.4rem,1.1rem + 1.2vw,1.9rem);margin-top:var(--s6);margin-bottom:var(--s3)}
.article p{font-size:1.12rem;line-height:1.68;color:var(--ink-soft);margin-bottom:var(--s4)}
.article p strong{color:var(--ink);font-weight:600}
.article blockquote{margin:var(--s5) 0;padding:.2rem 0 .2rem var(--s4);border-left:2px solid var(--signal);
  font-size:clamp(1.3rem,1.05rem + 1vw,1.7rem);font-weight:600;line-height:1.3;
  color:var(--ink);letter-spacing:-.022em}

/* ---- closing credo ---- */
.credo{font-size:clamp(1.3rem,1.05rem + .95vw,1.7rem);font-weight:500;color:var(--ink);
  letter-spacing:-.022em;line-height:1.32;max-width:26ch}
.credo::before{content:"";display:block;width:30px;height:2px;background:var(--signal);margin-bottom:var(--s4)}

/* ---- animated logo mark: two C's (opening right) draw closed -> target ---- */
.mark{width:25px;height:25px;display:block;flex:0 0 auto;overflow:visible}
.mark__c{fill:none;stroke-width:3.4;stroke-linecap:round;transform-origin:20px 20px;
  transform:rotate(45deg);stroke-dasharray:72 28}
.mark__c--a{stroke:var(--brand-blue);animation:cClose 6s var(--ease) infinite}
.mark__c--b{stroke:var(--signal);stroke-width:3;animation:cClose 6s var(--ease) infinite .15s}
.mark__dot{fill:var(--signal);opacity:0;transform-origin:20px 20px;animation:cDot 6s var(--ease) infinite}
@keyframes cClose{0%,20%{stroke-dasharray:72 28}44%,72%{stroke-dasharray:100 0}96%,100%{stroke-dasharray:72 28}}
@keyframes cDot{0%,46%{opacity:0;transform:scale(0)}58%,70%{opacity:1;transform:scale(1)}84%,100%{opacity:0;transform:scale(0)}}
@media (prefers-reduced-motion:reduce){
  .mark__c{animation:none}
  .mark__dot{animation:none;opacity:0}
}

/* ---- client wall: flip-to-link tiles ---- */
.logos{margin-top:var(--s5);display:grid;grid-template-columns:repeat(auto-fit,minmax(125px,1fr));
  border-top:1px solid var(--line);border-left:1px solid var(--line)}
.logo{position:relative;min-height:92px;display:block;text-decoration:none;perspective:700px;
  border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.logo__flip{position:absolute;inset:0;transform-style:preserve-3d;transition:transform .55s var(--ease)}
.logo:hover .logo__flip,.logo:focus-visible .logo__flip{transform:rotateY(180deg)}
.logo__face{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  text-align:center;padding:.85rem .7rem;backface-visibility:hidden;-webkit-backface-visibility:hidden;
  font-weight:600;font-size:.74rem;letter-spacing:.02em;text-transform:uppercase;line-height:1.3}
.logo__front{color:var(--slate)}
.logo__back{color:#fff;background:var(--ink);transform:rotateY(180deg);
  font-family:var(--mono);font-weight:500;letter-spacing:.06em}
@media (prefers-reduced-motion:reduce){
  .logo__flip{transition:none}
  .logo:hover .logo__flip,.logo:focus-visible .logo__flip{transform:none}
  .logo:hover .logo__front,.logo:focus-visible .logo__front{color:var(--ink)}
}

/* ---- video: click to play ---- */
.video{position:relative;aspect-ratio:16/9;border-radius:12px;overflow:hidden;
  background:var(--ink);border:1px solid var(--line);margin-top:var(--s4);max-width:640px}
.video__play{position:absolute;inset:0;width:100%;height:100%;border:0;padding:0;cursor:pointer;
  background:none;display:block}
.video__play img{width:100%;height:100%;object-fit:cover;display:block;opacity:.82;transition:opacity .25s,transform .35s var(--ease)}
.video__play:hover img{opacity:.95;transform:scale(1.03)}
.video__btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:64px;height:64px;border-radius:50%;background:rgba(255,255,255,.95);
  display:flex;align-items:center;justify-content:center;transition:transform .2s var(--ease),background .2s}
.video__btn::before{content:"";margin-left:4px;border-style:solid;border-width:11px 0 11px 18px;
  border-color:transparent transparent transparent var(--ink)}
.video__play:hover .video__btn{transform:translate(-50%,-50%) scale(1.08);background:#fff}
.video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* ---- headshot ---- */
.headshot{width:118px;height:118px;border-radius:14px;object-fit:cover;display:block;
  border:1px solid var(--line)}
.person{display:flex;gap:var(--s3);align-items:center}
.person__name{font-weight:600;font-size:1.12rem;color:var(--ink);letter-spacing:-.015em}
.person__role{color:var(--slate);font-size:.92rem;margin-top:.2rem}
.person__role a{color:var(--slate);text-decoration:underline;text-decoration-color:var(--signal);text-underline-offset:2px}
.person__role a:hover{color:var(--signal-dk)}

/* ---- thought-leadership: essay index ---- */
.essays{list-style:none;margin:var(--s5) 0 0;padding:0;border-top:1px solid var(--line)}
.essay{border-bottom:1px solid var(--line)}
.essay a{display:block;padding:var(--s4) 0;text-decoration:none;transition:padding-left .22s var(--ease)}
.essay a:hover,.essay a:focus-visible{padding-left:.5rem}
.essay__title{display:block;font-size:1.1rem;font-weight:600;color:var(--ink);letter-spacing:-.01em}
.essay__arr{color:var(--signal-dk);font-weight:500;margin-left:.12em}
.essay__desc{display:block;margin-top:.32rem;color:var(--slate);font-size:.94rem;line-height:1.5;max-width:64ch}
@media (prefers-reduced-motion:reduce){.essay a:hover,.essay a:focus-visible{padding-left:0}}
