:root{color-scheme:light;--bg:#fbfaf7;--paper:#fff;--ink:#20211f;--muted:#666b60;--line:#d8d1c6;--brand:#31584a;--brand-2:#8a5a34;--soft:#f1f5ef}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;line-height:1.65;overflow-x:hidden}
a{color:inherit}
img{max-width:100%;display:block;height:auto}
.site-header,.site-footer{max-width:1180px;margin:auto;padding:22px 24px;display:flex;gap:20px;align-items:center;justify-content:space-between;flex-wrap:wrap}
.site-header{border-bottom:1px solid var(--line);position:sticky;top:0;background:rgba(251,250,247,.95);backdrop-filter:blur(8px);z-index:100}
.brand{font-weight:800;text-decoration:none;font-size:1.25rem;letter-spacing:.01em;color:var(--ink)}
.site-header nav,.site-footer nav{display:flex;gap:22px;flex-wrap:wrap}
.site-header a,.site-footer a{text-decoration:none;color:var(--muted);font-weight:600;font-size:.95rem;transition:color .2s}
.site-header a:hover,.site-footer a:hover{color:var(--brand)}
.menu-button{display:none}
main{max-width:1180px;margin:auto;padding:0 24px 72px}
.breadcrumbs{display:flex;gap:8px;flex-wrap:wrap;margin:24px 0;color:var(--muted);font-size:.85rem}
.breadcrumbs a{color:var(--brand);text-decoration:none;font-weight:600}
.eyebrow{text-transform:uppercase;letter-spacing:.1em;color:var(--brand-2);font-size:.75rem;font-weight:800}
.masthead{padding:48px 0 32px;border-bottom:1px solid var(--line);text-align:center}
.masthead h1{font-family:Georgia,"Times New Roman",serif;font-size:clamp(3rem,10vw,7.5rem);line-height:.88;margin:12px 0 18px;letter-spacing:-.02em;font-weight:700}
.masthead p:not(.eyebrow){max-width:720px;margin:0 auto;color:var(--muted);font-size:1.2rem;line-height:1.5}
.cover-layout{display:grid;grid-template-columns:minmax(0,1.7fr) minmax(300px,.8fr);gap:48px;margin-top:42px;align-items:start}
.featured-story{background:var(--paper);border-bottom:1px solid var(--line);padding-bottom:24px}
.featured-story a,.card a,.side-item a{text-decoration:none;display:block}
.featured-story img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:8px;box-shadow:0 4px 20px rgba(0,0,0,.05)}
.featured-story span,.card span,.side-item .eyebrow{display:block;color:var(--brand-2);font-weight:800;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em}
.featured-story span{margin-top:22px}
.featured-story h2{font-family:Georgia,"Times New Roman",serif;font-size:clamp(1.8rem,5vw,3.5rem);line-height:1;margin:10px 0 14px;letter-spacing:-.01em;font-weight:700}
.featured-story p{color:var(--muted);font-size:1.1rem;max-width:760px;margin-bottom:0}
.side-list{border-top:4px solid var(--ink);background:var(--paper);padding-top:20px}
.side-list h2,.section-heading h2,.editor-note h2{font-family:Georgia,"Times New Roman",serif;font-size:1.8rem;line-height:1.1;margin:0 0 18px;font-weight:700}
.side-item{border-top:1px solid var(--line);padding:18px 0}
.side-item:first-of-type{border-top:0}
.side-item a{display:grid;grid-template-columns:100px 1fr;gap:18px;align-items:start}
.side-item img{width:100px;aspect-ratio:1;object-fit:cover;border-radius:6px;background:var(--soft);box-shadow:0 2px 8px rgba(0,0,0,.05)}
.side-item:hover .title{color:var(--brand)}
.side-item .title{display:block;margin-top:2px;font-family:Georgia,serif;font-size:1.1rem;line-height:1.25;transition:color .2s;font-weight:700;color:var(--ink);text-transform:none}
.side-item .eyebrow{margin-bottom:4px}
.section-heading{margin-top:72px}
.section-heading>p{max-width:760px;color:var(--muted);font-size:1.1rem}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:32px;margin-top:32px}
.grid.small{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.card{background:var(--paper);border:1px solid var(--line);border-radius:8px;overflow:hidden;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:0 12px 30px rgba(0,0,0,.08)}
.card a{display:flex;flex-direction:column;height:100%}
.card img{width:100%;aspect-ratio:16/10;object-fit:cover}
.card span{margin:20px 22px 0}
.card h3{font-family:Georgia,"Times New Roman",serif;font-size:1.3rem;line-height:1.2;margin:10px 22px;font-weight:700}
.card p{color:var(--muted);margin:0 22px 24px;font-size:.95rem;flex-grow:1}
.pill-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:18px;margin-top:24px}
.pill-grid a{background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:24px;text-decoration:none;transition:border-color .2s,background .2s}
.pill-grid a:hover{border-color:var(--brand);background:var(--soft)}
.pill-grid strong,.pill-grid span{display:block}
.pill-grid strong{font-size:1.1rem;font-family:Georgia,serif;font-weight:700}
.pill-grid span{color:var(--muted);margin-top:8px;font-size:.92rem;line-height:1.4}
.editor-note,.method,.note,.answer,.author-box{background:var(--soft);border:1px solid var(--line);border-radius:8px;padding:32px;margin:42px 0}
.method,.note,.answer{margin:42px 0}
.method h2:first-child,.note h2:first-child,.answer h2:first-child,.editor-note h2:first-child{margin-top:0}
.page-title{padding:48px 0 12px}
.page-title h1,.article h1{font-family:Georgia,"Times New Roman",serif;font-size:clamp(2.2rem,7vw,4.8rem);line-height:.95;margin:.1em 0 .3em;letter-spacing:-.02em;font-weight:700}
.page-title p,.lead{font-size:1.25rem;color:var(--muted);max-width:780px;line-height:1.5}
.article{max-width:800px;margin:auto}
.article .meta{color:var(--muted);font-weight:600;margin:20px 0 32px;font-size:.92rem;display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.article h2{font-family:Georgia,"Times New Roman",serif;font-size:1.85rem;line-height:1.15;margin-top:48px;margin-bottom:18px;font-weight:700}
.article h3{font-size:1.3rem;margin-top:32px;margin-bottom:12px;font-weight:600}
.article p,.article li{font-size:1.1rem;margin-bottom:1.2em}
.article ul,.article ol{padding-left:1.5rem;margin-bottom:1.5em}
.author-box{margin-top:52px;display:flex;flex-direction:column;gap:12px}
.author-box h2{margin-bottom:8px;font-weight:700}
.cover{width:100%;margin:32px 0 42px;border-radius:8px;aspect-ratio:16/9;object-fit:cover;box-shadow:0 8px 30px rgba(0,0,0,.1)}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:32px}
details{border-top:1px solid var(--line);padding:20px 0}
summary{font-weight:700;cursor:pointer;font-size:1.1rem}
.site-footer{border-top:1px solid var(--line);padding:48px 24px;color:var(--muted);display:grid;grid-template-columns:1.5fr 1fr 1.2fr;gap:48px;align-items:start}
.site-footer p{line-height:1.6;font-size:.95rem}
.site-footer strong{color:var(--ink);display:block;margin-bottom:18px;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;font-weight:800}
.site-footer nav{flex-direction:column;gap:12px}
.site-footer nav a{font-weight:600;font-size:.9rem}
@media (max-width:920px){
  .site-footer{grid-template-columns:1fr 1fr;gap:32px}
  .site-footer p{grid-column:span 2}
}
@media (max-width:820px){
  .site-header{padding:16px 20px}
  .site-footer{grid-template-columns:1fr;gap:32px;padding:42px 20px}
  .site-footer p{grid-column:span 1}
  .cover-layout,.grid,.grid.small,.pill-grid,.two-col,.article div[class*="grid-cols-1"]{grid-template-columns:1fr}
  .masthead{text-align:left;padding:32px 0}
  .masthead h1{font-size:4rem}
  .featured-story h2{font-size:2.2rem}
  .article h1{font-size:2.8rem}
  main{padding-inline:20px}
  .method,.note,.answer,.author-box{padding:24px}
  .side-item img{width:64px;height:64px}
  .side-item a{grid-template-columns:64px 1fr}
}
@media (max-width:480px){
  .masthead h1{font-size:3.2rem}
  .featured-story h2{font-size:1.8rem}
  .article h1{font-size:2.4rem}
  .page-title h1{font-size:2.6rem}
}