/* Treat Thompson — editorial / archival personal site
   Palette: warm cream paper, ink, teal accent. Type: Cormorant Garamond (display),
   Newsreader (reading), DM Sans (nav + labels). */

:root{
  --paper:#F6F2E9;
  --card:#FBF8F1;
  --ink:#1F1E1A;
  --ink-soft:#33312C;
  --muted:#8A857A;
  --faint:#A39C8C;
  --line:#E2DBCB;
  --line-2:#D8D0BE;
  --teal:#1F7A8C;
  --teal-deep:#0C3A45;
  --disp:'Cormorant Garamond',Georgia,serif;
  --read:'Newsreader',Georgia,serif;
  --ui:'DM Sans',system-ui,-apple-system,sans-serif;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--ui);font-size:16px;line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ---------- layout: sidebar + main ---------- */
.layout{max-width:980px;margin:0 auto;padding:48px 40px 56px;display:flex;gap:56px}
.sidebar{width:184px;flex:none}
.sidebar.sticky{position:sticky;top:48px;align-self:flex-start}
.brand{font-family:var(--disp);font-size:22px;font-weight:600;line-height:1.04;color:var(--ink)}
.brand a:hover{color:var(--teal)}
.loc{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);margin:7px 0 24px}
.nav{display:flex;flex-direction:column;gap:1px}
.nav a{font-size:14px;color:var(--ink-soft);padding:5px 0;transition:color .15s}
.nav a:hover{color:var(--teal)}
.nav a.active{color:var(--teal)}
.nav .ext{font-size:10px;color:var(--faint);vertical-align:1px;margin-left:2px}
.side-sub{display:inline-block;margin-top:26px;font-size:12.5px;color:var(--teal)}
.side-sub:hover{color:var(--teal-deep)}
.main{flex:1;min-width:0}

/* ---------- shared bits ---------- */
.label{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--teal);margin:0 0 8px}
.more{display:inline-block;font-size:12.5px;color:var(--teal);margin-top:14px}
.more:hover{color:var(--teal-deep)}
.page-title{font-family:var(--disp);font-weight:600;font-size:34px;line-height:1.02;margin:0 0 4px}
.page-sub{font-family:var(--read);font-style:italic;font-size:16px;color:var(--muted);margin:0 0 22px}

/* ---------- home ---------- */
.hello{font-family:var(--disp);font-weight:600;font-size:32px;margin:0 0 12px}
.intro{font-family:var(--read);font-size:17px;line-height:1.62;color:var(--ink-soft);max-width:48ch;margin:0 0 34px}
.post-list{list-style:none;margin:0;padding:0}
.post-row{display:flex;justify-content:space-between;align-items:baseline;gap:16px;
  padding:11px 0;border-top:1px solid var(--line)}
.post-row .t{font-family:var(--disp);font-weight:600;font-size:19px;line-height:1.15;transition:color .15s}
.post-row:hover .t{color:var(--teal)}
.post-row .d{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);flex:none}
.section{margin-top:40px}

/* drawings grid (home + cartooning) */
.draw-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:18px;margin-top:14px}
.draw{display:block}
.draw .frame{background:var(--card);border:1px solid var(--line-2);aspect-ratio:4/5;
  position:relative;overflow:hidden}
.draw .frame img{width:100%;height:100%;object-fit:cover}
.draw .cap{font-family:var(--read);font-style:italic;font-size:12.5px;color:var(--muted);margin-top:7px}
.empty{font-family:var(--read);font-style:italic;font-size:15px;color:var(--muted);
  padding:20px 0;border-top:1px solid var(--line)}

/* ---------- writing index ---------- */
.chips{display:flex;gap:9px;margin-bottom:6px;flex-wrap:wrap}
.chip{font-family:var(--ui);font-size:11px;letter-spacing:.06em;text-transform:uppercase;
  padding:6px 14px;border-radius:40px;border:.5px solid var(--line-2);color:var(--muted);
  background:transparent;cursor:pointer;transition:.15s}
.chip:hover{border-color:var(--teal);color:var(--teal)}
.chip.active{background:var(--teal);border-color:var(--teal);color:var(--paper)}

/* ---------- testimonial wall + subscribe ---------- */
.wall{margin-top:48px;padding-top:30px;border-top:2px solid var(--ink)}
.wall h2{font-family:var(--disp);font-weight:600;font-size:24px;margin:0 0 20px}
.quotes{column-count:3;column-gap:22px}
.quote{break-inside:avoid;margin:0 0 20px;display:inline-block;width:100%}
.quote p{font-family:var(--read);font-size:13.5px;line-height:1.5;color:var(--ink-soft);margin:0 0 7px}
.quote .by{font-size:11px;color:var(--muted);font-weight:500}
.quotes.hidden-extra .extra{display:none}
.showall{font-size:12.5px;color:var(--teal);cursor:pointer;background:none;border:none;
  padding:0;font-family:var(--ui);margin-top:4px}
.showall:hover{color:var(--teal-deep)}
.subscribe{margin-top:30px;background:var(--card);border:1px solid var(--line);padding:22px 24px}
.subscribe h3{font-family:var(--disp);font-weight:600;font-size:20px;margin:0 0 12px}
.sub-form{display:flex;gap:8px;max-width:400px}
.sub-form input{flex:1;border:1px solid var(--line-2);background:#fff;padding:10px 12px;
  font-size:14px;font-family:var(--ui);color:var(--ink);border-radius:0}
.sub-form input:focus{outline:none;border-color:var(--teal)}
.sub-form button{background:var(--teal);color:var(--paper);border:none;padding:10px 22px;
  font-size:14px;font-weight:500;font-family:var(--ui);cursor:pointer}
.sub-form button:hover{background:var(--teal-deep)}

/* ---------- article ---------- */
.back{font-size:13px;color:var(--teal);display:inline-block;margin-bottom:20px}
.back:hover{color:var(--teal-deep)}
.art-meta{font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--faint);margin-bottom:10px}
.art-title{font-family:var(--disp);font-weight:600;font-size:40px;line-height:1.05;margin:0 0 12px;max-width:20ch}
.art-deck{font-family:var(--read);font-style:italic;font-size:19px;color:var(--ink-soft);
  margin:0 0 26px;padding-bottom:22px;border-bottom:1px solid var(--line);max-width:36ch}
.prose{font-family:var(--read);font-size:18px;line-height:1.72;color:var(--ink-soft);max-width:62ch}
.prose p{margin:0 0 18px}
.prose p:first-of-type::first-letter{font-family:var(--disp);font-weight:600;float:left;
  font-size:3.6em;line-height:.78;padding:8px 10px 0 0;color:var(--teal)}
.prose h2,.prose h3{font-family:var(--disp);font-weight:600;color:var(--ink);line-height:1.15;margin:32px 0 12px}
.prose h2{font-size:27px}.prose h3{font-size:22px}
.prose a{color:var(--teal);text-decoration:underline;text-underline-offset:2px}
.prose blockquote{margin:24px 0;padding-left:18px;border-left:2px solid var(--teal);
  font-style:italic;color:var(--ink)}
.prose ul,.prose ol{padding-left:22px}
.prose li{margin:0 0 8px}
.prose img{margin:24px 0;border:1px solid var(--line)}
.art-foot{margin-top:40px;padding-top:18px;border-top:1px solid var(--line)}

/* ---------- footer ---------- */
.foot{display:flex;justify-content:space-between;align-items:center;margin-top:46px;
  padding-top:16px;border-top:1px solid var(--line);font-size:12px;color:var(--muted);
  flex-wrap:wrap;gap:8px}
.foot a{color:var(--teal)}
.foot a:hover{color:var(--teal-deep)}

/* ---------- responsive ---------- */
@media(max-width:720px){
  .layout{flex-direction:column;gap:28px;padding:32px 24px 40px}
  .sidebar{width:auto}
  .sidebar.sticky{position:static}
  .loc{margin-bottom:14px}
  .nav{flex-direction:row;flex-wrap:wrap;gap:18px}
  .side-sub{margin-top:14px}
  .quotes{column-count:1}
  .art-title{font-size:32px}
}
@media(max-width:520px){
  .hello,.page-title{font-size:27px}
  .quotes{column-count:1}
}
