/* Shared CSS for posts/*.html and blog index. */
*{box-sizing:border-box;margin:0;padding:0;}
html,body{
  min-height:100%;
  background:#efeae0;
  color:#0e0e0e;
  font-family:"General Sans","Inter",-apple-system,BlinkMacSystemFont,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;
}
main{
  display:flex; align-items:stretch;
  min-height:100vh;
  padding:0 clamp(28px, 6vw, 96px);
  gap:clamp(24px, 6vw, 80px);
}
.name-col{
  flex:1 1 auto;
  align-self:flex-start;
  position:sticky;
  top:0;
  height:100vh;
  display:flex; align-items:center;
}
.name{
  font-weight:500;
  font-size:clamp(44px, 7vw, 96px);
  line-height:1;
  letter-spacing:-0.03em;
  margin:0;
  display:block;
  color:#0e0e0e;
  text-decoration:none;
  transition:color .2s ease;
}
.name:hover{color:#a23f1a;}
.content-col{
  flex:0 0 auto;
  max-width:min(640px, 55vw);
  padding:clamp(80px, 14vh, 180px) 0 64px;
}
.crumb{
  display:inline-block;
  font-size:13px;
  color:#7a7468;
  letter-spacing:0.04em;
  text-decoration:none;
  margin-bottom:32px;
  transition:color .2s ease;
}
.crumb:hover{color:#a23f1a;}

/* index ("blog" page) */
.section-label{
  font-size:13px;
  font-weight:600;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:#7a7468;
  margin:0 0 24px 0;
}
h1.page-title{
  font-size:clamp(28px, 3.6vw, 44px);
  font-weight:600;
  letter-spacing:-0.025em;
  line-height:1.1;
  margin:0 0 36px 0;
  color:#0e0e0e;
}
.posts{list-style:none; margin:0; padding:0;}
.post-preview{margin:0;}
.post-preview a{
  display:block;
  padding:28px 0;
  text-decoration:none;
  color:inherit;
  border-bottom:1px solid rgba(14,14,14,0.12);
  transition:padding-left .2s ease;
}
.post-preview:first-child a{
  border-top:1px solid rgba(14,14,14,0.12);
}
.post-preview a:hover{padding-left:8px;}
.post-preview a:hover .pp-title{color:#a23f1a;}
.pp-title{
  font-size:clamp(22px, 2.4vw, 30px);
  font-weight:500;
  letter-spacing:-0.02em;
  line-height:1.2;
  margin:0 0 8px 0;
  color:#0e0e0e;
}
.pp-date{
  display:block;
  font-size:13px;
  color:#7a7468;
  letter-spacing:0.04em;
  margin-bottom:10px;
}
.pp-blurb{
  font-size:clamp(15px, 1.3vw, 17px);
  font-weight:400;
  line-height:1.55;
  color:#3a3a3a;
  margin:0;
}

/* article (individual post) */
h1.post-title{
  font-size:clamp(28px, 3.6vw, 44px);
  font-weight:600;
  letter-spacing:-0.025em;
  line-height:1.1;
  margin:0 0 10px 0;
  color:#0e0e0e;
}
.post-date{
  display:block;
  font-size:13px;
  color:#7a7468;
  letter-spacing:0.04em;
  margin-bottom:36px;
}

/* graphic cards (text-based) */
.post-graphic{
  border:1px solid rgba(14,14,14,0.18);
  padding:clamp(40px, 6vh, 72px) clamp(24px, 4vw, 48px);
  margin:0 0 40px 0;
  border-radius:2px;
  text-align:center;
}
.post-graphic .gline{
  font-size:clamp(28px, 4vw, 52px);
  font-weight:600;
  letter-spacing:-0.025em;
  line-height:1.05;
  margin:0 0 6px 0;
  color:#0e0e0e;
}
.post-graphic .gaccent{color:#a23f1a;}
.post-graphic .gstat{
  font-size:clamp(80px, 14vw, 160px);
  font-weight:700;
  letter-spacing:-0.05em;
  line-height:1;
  margin:0;
  color:#0e0e0e;
}
.post-graphic .gcaption{
  font-size:clamp(15px, 1.5vw, 17px);
  font-weight:400;
  line-height:1.5;
  margin:20px auto 0;
  max-width:380px;
  color:#3a3a3a;
}
.post-graphic .gmeta{
  font-size:11px;
  font-weight:600;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:#7a7468;
  margin:0 0 24px 0;
}
.post-graphic .gtiny{
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:#7a7468;
  margin:28px 0 0 0;
}
.post-graphic .gtiny a{color:inherit; text-decoration:underline; text-underline-offset:3px;}
.post-graphic .gtiny a:hover{color:#a23f1a;}
.post-graphic .gsmall{
  font-size:clamp(13px, 1.2vw, 15px);
  font-weight:500;
  letter-spacing:0.06em;
  color:#3a3a3a;
  margin:14px 0 0 0;
}
.post-graphic .grule{
  width:48px; height:2px; background:#a23f1a;
  margin:18px auto; border:none;
}

/* photo figure */
.gfx{margin:0 0 40px 0;}
.gfx figcaption{
  text-align:center;
  font-size:12px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:#7a7468;
  margin-top:14px;
  font-weight:500;
}
.gfx figcaption a{
  color:inherit;
  text-decoration:underline;
  text-decoration-thickness:1px;
  text-underline-offset:3px;
  transition:color .2s ease;
}
.gfx figcaption a:hover{color:#a23f1a;}
.gfx-photo__img{
  display:block;
  width:100%;
  height:auto;
  border-radius:4px;
  border:1px solid rgba(14,14,14,0.12);
}
.gfx-photo.is-portrait{
  max-width:340px;
  margin-left:auto;
  margin-right:auto;
}

/* 1-in-5 stat card */
.gfx-stat__sheet{
  background:#0a0d10;
  background-image:radial-gradient(ellipse 80% 50% at 50% 0%, rgba(122,240,200,0.16), transparent 60%);
  color:#fff;
  padding:clamp(36px,5vw,60px) clamp(22px,4vw,40px) clamp(22px,3vw,32px);
  border-radius:4px;
  box-shadow:0 20px 60px -20px rgba(0,0,0,0.4);
  text-align:center;
  position:relative;
  overflow:hidden;
  aspect-ratio:1 / 1;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.gfx-stat__hero{
  font-family:"General Sans","Helvetica Neue",sans-serif;
  font-weight:800;
  font-size:clamp(72px,16vw,160px);
  line-height:0.95;
  letter-spacing:-0.04em;
  color:#7af0c8;
  text-shadow:0 0 60px rgba(122,240,200,0.32);
  margin-top:clamp(8px,2vh,20px);
}
.gfx-stat__people{
  display:flex; justify-content:center; align-items:flex-end;
  gap:clamp(10px,2.5vw,18px);
  margin:8px 0;
}
.gfx-stat__person{
  width:clamp(36px,8vw,58px); height:auto;
  color:#1a232a; flex-shrink:0;
}
.gfx-stat__person--on{color:#7af0c8;}
.gfx-stat__cap{
  font-family:"General Sans","Helvetica Neue",sans-serif;
  font-weight:700;
  font-size:clamp(12px,1.5vw,16px);
  letter-spacing:0.04em; line-height:1.4;
  color:#e3eaee; max-width:34ch; margin:0 auto;
  text-transform:uppercase;
}
.gfx-stat__cap-on{color:#94b8c4;}
.gfx-stat__footer{
  display:flex; justify-content:space-between; align-items:center;
  margin-top:clamp(16px,3vh,28px);
  font-size:10px; letter-spacing:0.2em; font-weight:700;
}
.gfx-stat__brand{display:inline-flex; align-items:center; gap:6px; color:#9aaeb8;}
.gfx-stat__dot{
  width:6px; height:6px; border-radius:50%;
  background:#7af0c8; display:inline-block;
}
.gfx-stat__src{
  color:#5e6f78; text-decoration:none;
  transition:color .2s ease;
}
.gfx-stat__src:hover{color:#7af0c8;}

/* prose */
.prose p{
  font-size:18px;
  line-height:1.65;
  margin:0 0 1.2em 0;
  font-weight:400;
  color:#1a1a1a;
}
.prose a{
  color:#0e0e0e;
  text-decoration:underline;
  text-decoration-thickness:1.5px;
  text-underline-offset:3px;
  transition:color .2s ease;
}
.prose a:hover{color:#a23f1a;}
.prose h3{
  font-size:21px;
  font-weight:600;
  letter-spacing:-0.015em;
  line-height:1.2;
  margin:2em 0 0.5em 0;
  color:#0e0e0e;
}
.prose ol,
.prose ul{
  font-size:18px;
  line-height:1.65;
  margin:0 0 1.2em 0;
  padding-left:1.4em;
  color:#1a1a1a;
}
.prose li{margin:0 0 0.4em 0;}
.prose strong{font-weight:600; color:#0e0e0e;}

/* paste-pattern card duo */
.gfx-paste__cards{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.gfx-paste__card{
  background:rgba(255,255,255,0.55);
  border:1px solid rgba(14,14,14,0.12);
  border-radius:10px;
  padding:24px;
  display:flex; flex-direction:column;
}
.gfx-paste__card--alt{
  background:rgba(255,255,255,0.85);
  border-color:rgba(14,14,14,0.22);
}
.gfx-paste__eyebrow{
  display:inline-block;
  font-size:10px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  font-weight:700;
  color:#7a7468;
  margin:0 0 14px 0;
  font-family:ui-monospace,"SF Mono",Menlo,monospace;
}
.gfx-paste__title{
  font-size:17px;
  font-weight:600;
  letter-spacing:-0.01em;
  color:#0e0e0e;
  margin:0 0 8px 0;
  line-height:1.25;
}
.gfx-paste__desc{
  font-size:13px;
  font-weight:400;
  color:#3a3a3a;
  line-height:1.5;
  margin:0;
  flex:1 0 auto;
}
.gfx-paste__time{
  font-size:12px;
  font-weight:500;
  color:#0e0e0e;
  margin:14px 0 0 0;
  letter-spacing:0.02em;
}
@media (max-width:520px){
  .gfx-paste__cards{grid-template-columns:1fr;}
}

/* post nav */
.post-nav{
  margin-top:56px;
  padding-top:24px;
  border-top:1px solid rgba(14,14,14,0.12);
  display:flex; justify-content:space-between; gap:24px;
}
.post-nav a{
  font-size:13px;
  color:#7a7468;
  letter-spacing:0.04em;
  text-decoration:none;
  transition:color .2s ease;
  max-width:48%;
  line-height:1.4;
}
.post-nav a:hover{color:#a23f1a;}
.post-nav .nav-next{text-align:right;}
.post-nav .nav-label{
  display:block;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.14em;
  color:#9b948a;
  margin-bottom:4px;
  font-weight:600;
}

@media (max-width:760px){
  main{flex-direction:column; align-items:flex-start; padding:64px clamp(28px, 6vw, 96px); gap:40px;}
  .name-col{position:static; height:auto; align-self:flex-start;}
  .content-col{align-self:flex-start; max-width:100%; padding:0;}
  .post-graphic{padding:40px 20px;}
}
@media (max-width:520px){
  .gfx-stat__sheet{aspect-ratio:auto;}
  .gfx-stat__hero{font-size:clamp(64px,18vw,120px);}
}
