:root{
  --bg:oklch(98% 0.004 95);
  --paper:oklch(96% 0.006 90);
  --surface:oklch(100% 0.002 95);
  --fg:oklch(20% 0.018 70);
  --muted:oklch(48% 0.012 70);
  --rule:oklch(20% 0.018 70);
  --border:oklch(88% 0.008 90);
  --accent:oklch(46% 0.13 28);
  --font-display:'Iowan Old Style','Charter','Apple Garamond',Georgia,'Times New Roman',serif;
  --font-body:-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
  --font-mono:ui-monospace,'SFMono-Regular',Menlo,Consolas,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--fg);font-family:var(--font-body);font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;text-wrap:pretty}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:var(--fg);color:var(--bg)}

.wrap{max-width:1240px;margin:0 auto;padding:0 32px}
@media (max-width:720px){.wrap{padding:0 20px}}

/* topbar */
.topbar{border-bottom:1px solid var(--border);background:var(--bg)}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;padding:10px 0;font:11px/1 var(--font-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.topbar a:hover{color:var(--fg)}
.topbar-links{display:flex;gap:22px}
@media (max-width:720px){.topbar-date{display:none}}

/* masthead */
.masthead{text-align:center;padding:36px 0 26px;border-bottom:2px solid var(--rule)}
.masthead .mast-emblem{width:62px;height:auto;margin:0 auto 16px;opacity:.92}
.masthead .kicker{font:11px/1 var(--font-mono);letter-spacing:.32em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.masthead h1{font-family:var(--font-display);font-weight:500;font-size:clamp(44px,8vw,96px);line-height:.95;letter-spacing:-.02em}
.masthead h1 .ital{font-style:italic;font-weight:400}
.masthead .tagline{margin-top:14px;font-family:var(--font-display);font-style:italic;font-size:clamp(15px,1.5vw,18px);color:var(--muted)}

/* mini masthead (inner pages) */
.mini-mast{padding:18px 0;border-bottom:2px solid var(--rule);text-align:center}
.mini-mast a{font-family:var(--font-display);font-weight:500;font-size:28px;letter-spacing:-.01em}
.mini-mast a .ital{font-style:italic;font-weight:400}

/* nav */
.nav{border-bottom:1px solid var(--border);background:var(--bg);position:sticky;top:0;z-index:10}
.nav-bar{position:relative}
.nav-toggle{display:none}
.nav-burger{display:none}
.nav-menu-label{display:none}
.nav-inner{display:flex;justify-content:center;flex-wrap:wrap;gap:0;padding:0}
.nav a{display:block;padding:14px 18px;font:11px/1 var(--font-mono);letter-spacing:.22em;text-transform:uppercase;color:var(--fg);position:relative}
.nav a:hover{color:var(--accent)}
.nav a.active::after{content:"";position:absolute;left:18px;right:18px;bottom:-1px;height:2px;background:var(--accent)}
@media (max-width:720px){
  .nav-bar{display:flex;align-items:center;flex-wrap:wrap;min-height:50px}
  .nav-menu-label{display:block;font:11px/1 var(--font-mono);letter-spacing:.24em;text-transform:uppercase;color:var(--muted)}
  .nav-burger{display:flex;flex-direction:column;justify-content:center;gap:5px;cursor:pointer;margin-left:auto;padding:14px 0}
  .nav-burger span{display:block;width:24px;height:2px;background:var(--fg);transition:transform .25s,opacity .25s}
  .nav-inner{display:none;flex-direction:column;width:100%;border-top:1px solid var(--border)}
  .nav-toggle:checked ~ .nav-inner{display:flex}
  .nav-inner a{padding:15px 2px;border-bottom:1px solid var(--border);letter-spacing:.22em}
  .nav-inner a:last-child{border-bottom:0}
  .nav a.active::after{display:none}
  .nav-inner a.active{color:var(--accent)}
  .nav-toggle:checked ~ .nav-burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle:checked ~ .nav-burger span:nth-child(2){opacity:0}
  .nav-toggle:checked ~ .nav-burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}

/* breadcrumb */
.crumb{padding:16px 0;font:11px/1 var(--font-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border)}
.crumb a:hover{color:var(--accent)}

/* hero */
.hero{padding:48px 0 56px;border-bottom:1px solid var(--border)}
.hero-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:48px}
@media (max-width:900px){.hero-grid{grid-template-columns:1fr;gap:32px}}
.hero .eyebrow{font:11px/1 var(--font-mono);letter-spacing:.24em;text-transform:uppercase;color:var(--accent);margin-bottom:18px}
.hero h2{font-family:var(--font-display);font-weight:500;font-size:clamp(34px,4.4vw,60px);line-height:1.02;letter-spacing:-.015em;margin-bottom:22px}
.hero h2 em{font-style:italic;font-weight:400}
.hero p.lead{font-size:18px;line-height:1.55;color:var(--fg);max-width:54ch;margin-bottom:24px}
.hero .byline{font:11px/1.4 var(--font-mono);letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.hero-fig{margin-bottom:22px;border:1px solid var(--border)}
.hero-fig img{width:100%;height:auto;filter:grayscale(1) contrast(1.02)}
.hero-fig figcaption{font:10px/1.3 var(--font-mono);letter-spacing:.16em;text-transform:uppercase;color:var(--muted);padding:8px 12px;border-top:1px solid var(--border)}
.hero-aside{border-left:1px solid var(--border);padding-left:32px}
@media (max-width:900px){.hero-aside{border-left:0;padding-left:0;border-top:1px solid var(--border);padding-top:28px}}
.hero-aside h3{font:11px/1 var(--font-mono);letter-spacing:.24em;text-transform:uppercase;color:var(--muted);margin-bottom:18px}
.hero-aside ol{list-style:none;counter-reset:c}
.hero-aside li{counter-increment:c;display:grid;grid-template-columns:32px 1fr;gap:14px;padding:14px 0;border-bottom:1px solid var(--border)}
.hero-aside li:last-child{border-bottom:0}
.hero-aside li::before{content:counter(c,decimal-leading-zero);font-family:var(--font-mono);font-size:13px;color:var(--muted);padding-top:2px}
.hero-aside li a{grid-column:2;font-family:var(--font-display);font-size:18px;line-height:1.25;display:block}
.hero-aside li a:hover{color:var(--accent)}
.hero-aside li small{grid-column:2;font:10px/1.3 var(--font-mono);letter-spacing:.16em;text-transform:uppercase;color:var(--muted);display:block;margin-top:4px;white-space:nowrap}

/* section heading */
.section-head{display:flex;align-items:baseline;justify-content:space-between;padding:32px 0 18px;border-bottom:1px solid var(--rule);margin-bottom:28px}
.section-head h2{font-family:var(--font-display);font-weight:500;font-size:28px;letter-spacing:-.01em}
.section-head h2 em{font-style:italic;font-weight:400;color:var(--accent)}
.section-head .more{font:11px/1 var(--font-mono);letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.section-head .more:hover{color:var(--accent)}

/* featured grid */
section.featured{padding:48px 0;border-bottom:1px solid var(--border)}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
@media (max-width:900px){.grid-3{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.grid-3{grid-template-columns:1fr}}
.card{display:flex;flex-direction:column;gap:10px}
.card .kicker{font:10px/1 var(--font-mono);letter-spacing:.22em;text-transform:uppercase;color:var(--accent)}
.card h3{font-family:var(--font-display);font-weight:500;font-size:22px;line-height:1.18;letter-spacing:-.005em}
.card h3 a:hover{color:var(--accent)}
.card p{font-size:14.5px;line-height:1.55;color:var(--muted);max-width:42ch}
.card .meta{font:10px/1.2 var(--font-mono);letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:auto;padding-top:8px;border-top:1px solid var(--border)}

/* two-column feature */
section.feature{padding:48px 0;border-bottom:1px solid var(--border);background:var(--paper)}
.feature-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
@media (max-width:900px){.feature-grid{grid-template-columns:1fr;gap:28px}}
.feature-grid h2{font-family:var(--font-display);font-weight:500;font-size:clamp(32px,3.5vw,46px);line-height:1.04;letter-spacing:-.012em}
.feature-grid h2 em{font-style:italic;font-weight:400}
.feature-grid .body{font-size:16px;line-height:1.7}
.feature-grid .body p{margin-bottom:14px}
.feature-grid .body p:first-of-type:first-letter{font-family:var(--font-display);font-size:54px;float:left;line-height:.9;padding-right:8px;padding-top:6px;color:var(--accent)}
.feature-grid .body .more{font:11px/1 var(--font-mono);letter-spacing:.2em;text-transform:uppercase;color:var(--accent);border-bottom:1px solid var(--accent);padding-bottom:3px;display:inline-block;margin-top:6px}

/* list rows */
section.index-list{padding:48px 0;border-bottom:1px solid var(--border)}
.ilist{border-top:1px solid var(--rule)}
.ilist .row{display:grid;grid-template-columns:80px 1fr 1fr 140px;gap:24px;align-items:baseline;padding:18px 0;border-bottom:1px solid var(--border)}
.ilist .row:hover{background:var(--paper)}
.ilist .row .num{font-family:var(--font-mono);font-size:13px;color:var(--muted)}
.ilist .row h3{font-family:var(--font-display);font-weight:500;font-size:20px;line-height:1.2}
.ilist .row .desc{color:var(--muted);font-size:14px;line-height:1.5}
.ilist .row .meta{font:10px/1.3 var(--font-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--muted);text-align:right}
@media (max-width:900px){.ilist .row{grid-template-columns:60px 1fr;gap:14px}.ilist .row .desc,.ilist .row .meta{grid-column:2}.ilist .row .meta{margin-top:4px;text-align:left}}

/* authors strip */
section.authors{padding:48px 0;border-bottom:1px solid var(--border);background:var(--paper)}
.authors-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
@media (max-width:900px){.authors-grid{grid-template-columns:repeat(2,1fr)}}
.author{padding:20px;background:var(--surface);border:1px solid var(--border)}
.author .years{font:10px/1 var(--font-mono);letter-spacing:.2em;color:var(--muted);text-transform:uppercase;margin-bottom:8px}
.author h3{font-family:var(--font-display);font-weight:500;font-size:24px;line-height:1.1;margin-bottom:6px}
.author h3 a:hover{color:var(--accent)}
.author p{font-size:13px;line-height:1.5;color:var(--muted)}
.author .tag{display:inline-block;margin-top:10px;font:10px/1 var(--font-mono);letter-spacing:.16em;color:var(--accent);text-transform:uppercase}

/* pull quote */
section.pull{padding:72px 0;text-align:center;border-bottom:1px solid var(--border)}
.pull blockquote{font-family:var(--font-display);font-weight:400;font-style:italic;font-size:clamp(26px,3vw,40px);line-height:1.2;letter-spacing:-.005em;max-width:24ch;margin:0 auto}
.pull cite{display:block;font:11px/1 var(--font-mono);letter-spacing:.24em;text-transform:uppercase;color:var(--muted);margin-top:22px;font-style:normal}

/* article (fiche / pillar) */
header.fiche{padding:48px 0 36px;border-bottom:1px solid var(--rule)}
header.fiche .eyebrow{font:11px/1 var(--font-mono);letter-spacing:.24em;text-transform:uppercase;color:var(--accent);margin-bottom:16px}
header.fiche h1{font-family:var(--font-display);font-weight:500;font-size:clamp(36px,5vw,64px);line-height:1.04;letter-spacing:-.015em;max-width:20ch;margin-bottom:18px}
header.fiche h1 em{font-style:italic;font-weight:400}
header.fiche .sub{font-family:var(--font-display);font-style:italic;font-size:clamp(18px,1.6vw,22px);color:var(--muted);margin-bottom:22px;max-width:56ch}
header.fiche .byline{font:11px/1.5 var(--font-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}

/* facts strip */
.facts{display:grid;grid-template-columns:repeat(6,1fr);border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--paper)}
@media (max-width:900px){.facts{grid-template-columns:repeat(3,1fr)}}
@media (max-width:520px){.facts{grid-template-columns:repeat(2,1fr)}}
.fact{padding:18px 20px;border-right:1px solid var(--border)}
.fact:last-child{border-right:0}
.fact .k{font:10px/1 var(--font-mono);letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.fact .v{font-family:var(--font-display);font-size:18px;line-height:1.2;color:var(--fg)}
.fact .v small{font-family:var(--font-body);font-size:12px;color:var(--muted);display:block;margin-top:2px}

/* main layout */
main{padding:48px 0 72px}
.layout{display:grid;grid-template-columns:1fr 320px;gap:56px;align-items:start}
@media (max-width:1024px){.layout{grid-template-columns:1fr;gap:36px}}

/* article body */
.body h2{font-family:var(--font-display);font-weight:500;font-size:28px;letter-spacing:-.005em;margin:36px 0 14px;padding-top:14px;border-top:1px solid var(--border)}
.body h2:first-child{border-top:0;padding-top:0;margin-top:0}
.body h2 em{font-style:italic;font-weight:400;color:var(--accent)}
.body h3{font-family:var(--font-display);font-weight:500;font-size:21px;margin:24px 0 10px}
.body p{font-size:17px;line-height:1.75;margin-bottom:14px;max-width:64ch}
.body p.lead{font-size:19px;line-height:1.65}
.body p.lead::first-letter{font-family:var(--font-display);font-size:64px;float:left;line-height:.9;padding-right:10px;padding-top:6px;color:var(--accent)}
.body ul,.body ol{margin:0 0 16px 22px}
.body li{font-size:16.5px;line-height:1.7;margin-bottom:7px;max-width:62ch}
.body a.inline{border-bottom:1px solid var(--accent);color:var(--fg)}
.body a.inline:hover{color:var(--accent)}
.author-figure{margin:0 0 10px}
.author-figure img{width:190px;height:auto;float:left;margin:6px 24px 10px 0;border:1px solid var(--border);filter:grayscale(1) contrast(1.03)}
.author-figure figcaption{float:left;clear:left;width:190px;margin:-4px 24px 14px 0;font:10px/1.4 var(--font-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
@media (max-width:520px){.author-figure img,.author-figure figcaption{float:none;clear:none;width:auto;max-width:230px;margin:0 0 10px}}

/* author cards grid */
.author img{width:100%;height:170px;object-fit:cover;display:block;margin-bottom:12px;border:1px solid var(--border);filter:grayscale(1) contrast(1.03)}
.vh{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.author-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px;margin:24px 0 36px}
.author-card{display:flex;gap:16px;text-decoration:none;color:var(--fg);border:1px solid var(--border);background:var(--surface);padding:14px;transition:box-shadow .15s,border-color .15s}
.author-card:hover{box-shadow:0 6px 22px oklch(20% 0.018 70 / .10);border-color:var(--rule)}
.author-card img{width:84px;height:108px;object-fit:cover;flex:none;border:1px solid var(--border);filter:grayscale(1) contrast(1.03)}
.author-card .ac-name{font-family:var(--font-display);font-size:19px;line-height:1.15;margin:2px 0 2px}
.author-card .ac-years{font:10px/1.4 var(--font-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:7px}
.author-card .ac-desc{font-size:13.5px;line-height:1.5;color:var(--muted)}

/* text passage */
.passage{margin:24px 0 36px;padding:36px 40px;background:var(--paper);border-top:2px solid var(--rule);border-bottom:2px solid var(--rule);position:relative}
@media (max-width:520px){.passage{padding:28px 22px}}
.passage::before{content:"\00A7";position:absolute;top:-18px;left:36px;background:var(--bg);padding:0 10px;font-family:var(--font-display);font-size:32px;color:var(--accent);line-height:1}
.passage .scene{font:11px/1 var(--font-mono);letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:18px}
.passage .didascalie{font-family:var(--font-display);font-style:italic;color:var(--muted);font-size:15px;margin-bottom:14px}
.passage .verse{font-family:var(--font-display);font-size:19px;line-height:1.7;color:var(--fg)}
.passage .verse .speaker{display:block;font-style:italic;color:var(--accent);font-size:14px;letter-spacing:.04em;text-transform:uppercase;margin:18px 0 8px}
.passage .verse .speaker:first-child{margin-top:0}
.passage .verse p{margin-bottom:10px;max-width:none}
.passage .verse .num{font-family:var(--font-mono);font-size:11px;color:var(--muted);float:right;margin-left:14px}
.passage .source{font:10px/1.4 var(--font-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:22px;padding-top:14px;border-top:1px dotted var(--border)}

/* callout */
.callout{margin:24px 0;padding:22px 26px;border-left:3px solid var(--accent);background:var(--surface);font-size:15px;line-height:1.6}
.callout .k{font:10px/1 var(--font-mono);letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:10px}
.callout p{font-size:15px;max-width:none;margin:0}

/* hints */
.hints{margin:24px 0;border:1px solid var(--border)}
.hints h3{font-family:var(--font-display);font-weight:500;font-size:22px;padding:18px 22px;border-bottom:1px solid var(--border);background:var(--paper);margin:0}
.hints ol{list-style:none;counter-reset:hint;margin:0}
.hints li{counter-increment:hint;display:grid;grid-template-columns:46px 1fr;gap:14px;padding:18px 22px;border-bottom:1px solid var(--border);margin:0}
.hints li:last-child{border-bottom:0}
.hints li::before{content:counter(hint,decimal-leading-zero);font-family:var(--font-mono);font-size:13px;color:var(--accent);padding-top:2px;letter-spacing:.1em}
.hints li strong{font-family:var(--font-display);font-weight:500;font-size:16px;display:block;margin-bottom:4px;color:var(--fg)}
.hints li span{font-size:14.5px;color:var(--muted);line-height:1.55}

/* aside / TOC */
aside.fiche-aside{position:sticky;top:20px}
@media (max-width:1024px){aside.fiche-aside{position:static}}
.aside-block{border:1px solid var(--border);background:var(--surface);padding:22px;margin-bottom:20px}
.aside-block h3{font:11px/1 var(--font-mono);letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.aside-block ol,.aside-block ul{list-style:none}
.aside-block .toc li{padding:6px 0;font-size:14.5px;line-height:1.4}
.aside-block .toc li a:hover{color:var(--accent)}
.aside-block .toc li small{font-family:var(--font-mono);font-size:10.5px;color:var(--muted);margin-right:8px;letter-spacing:.1em}
.aside-block.action{background:var(--fg);color:var(--bg);border-color:var(--fg)}
.aside-block.action h3{color:var(--bg);opacity:.65;border-color:rgba(255,255,255,.18)}
.aside-block.action p{font-size:14px;line-height:1.55;margin-bottom:14px;opacity:.85}
.aside-block.action a.btn{display:inline-block;padding:10px 16px;border:1px solid var(--bg);font:11px/1 var(--font-mono);letter-spacing:.22em;text-transform:uppercase;margin-top:4px;margin-right:6px}
.aside-block.action a.btn:hover{background:var(--bg);color:var(--fg)}
.aside-block .related li{padding:10px 0;border-bottom:1px dotted var(--border);font-size:14px;line-height:1.4}
.aside-block .related li:last-child{border-bottom:0}
.aside-block .related li small{font:10px/1 var(--font-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--accent);display:block;margin-bottom:4px}
.aside-block .related li a:hover{color:var(--accent)}

/* prev/next */
.prevnext{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:2px solid var(--rule);border-bottom:1px solid var(--border)}
@media (max-width:720px){.prevnext{grid-template-columns:1fr}}
.prevnext a{display:block;padding:28px 32px;font-size:15px;line-height:1.4}
.prevnext a:first-child{border-right:1px solid var(--border)}
@media (max-width:720px){.prevnext a:first-child{border-right:0;border-bottom:1px solid var(--border)}}
.prevnext small{display:block;font:10px/1 var(--font-mono);letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.prevnext a:hover small{color:var(--accent)}
.prevnext .title{font-family:var(--font-display);font-size:18px}
.prevnext .next{text-align:right}

/* footer */
footer.site{padding:56px 0 32px;background:var(--surface);border-top:2px solid var(--rule)}
.foot-grid{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:32px;margin-bottom:36px}
@media (max-width:900px){.foot-grid{grid-template-columns:1fr 1fr}}
.foot-grid h4{font:11px/1 var(--font-mono);letter-spacing:.24em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.foot-grid ul{list-style:none}
.foot-grid li{padding:4px 0;font-size:14px}
.foot-grid li a:hover{color:var(--accent)}
.foot-grid .brand h3{font-family:var(--font-display);font-weight:500;font-size:24px;letter-spacing:-.01em;margin-bottom:8px}
.foot-grid .brand p{font-size:13px;color:var(--muted);line-height:1.55;max-width:34ch}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:20px;border-top:1px solid var(--border);font:10px/1 var(--font-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
@media (max-width:600px){.foot-bottom{flex-direction:column;gap:10px;align-items:flex-start}}

/* compact footer (fiche) */
footer.mini{padding:36px 0;background:var(--surface);border-top:2px solid var(--rule);font:11px/1.5 var(--font-mono);letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.foot-inner{display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px}
