/* Franklin Society — a money & ideas journal. Deliberately NOT the playful spoke look:
   serif headlines, a parchment/ink palette, narrow editorial column, restrained. */
:root{
  --ink:#1a1714; --paper:#f4efe6; --paper2:#ebe3d4; --rule:#d8cdb8;
  --accent:#7a1f1f; --accent2:#2d4a3e; --muted:#6b6155; --link:#7a1f1f;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font:18px/1.65 "Iowan Old Style","Palatino Linotype",Palatino,Georgia,serif;
}
.wrap{max-width:760px;margin:0 auto;padding:0 22px}
a{color:var(--link);text-decoration:none}
a:hover{text-decoration:underline}

/* masthead — newspaper nameplate, not a logo chip */
header.site{border-bottom:3px double var(--ink);background:var(--paper)}
header.site .nav{display:flex;align-items:baseline;justify-content:space-between;
  padding:18px 22px;flex-wrap:wrap;gap:8px;max-width:920px;margin:0 auto}
.brand{font-weight:700;font-size:30px;letter-spacing:.02em;color:var(--ink);
  font-variant:small-caps}
.brand .est{display:block;font:italic 12px/1 Georgia,serif;color:var(--muted);
  letter-spacing:.18em;margin-top:4px;font-variant:normal}
header.site nav{font:13px/1 ui-sans-serif,system-ui,sans-serif;letter-spacing:.06em;
  text-transform:uppercase}
header.site nav a{color:var(--ink);margin-left:18px;border-bottom:1px solid transparent}
header.site nav a:hover{border-color:var(--accent);text-decoration:none}

/* dateline strip */
.dateline{background:var(--ink);color:var(--paper);font:italic 13px/1.4 Georgia,serif;
  text-align:center;padding:7px 10px;letter-spacing:.04em}

/* hero */
.lede{max-width:920px;margin:0 auto;padding:46px 22px 30px;
  display:grid;grid-template-columns:1.5fr 1fr;gap:40px;align-items:start}
.lede h1{font-size:43px;line-height:1.08;margin:.1em 0 .35em;font-weight:700}
.lede h1 em{color:var(--accent);font-style:italic}
.lede p{font-size:19px;color:#3a342c;margin:0 0 18px}
.kicker{font:600 12px/1 ui-sans-serif,sans-serif;text-transform:uppercase;
  letter-spacing:.16em;color:var(--accent2)}
.side{border-left:1px solid var(--rule);padding-left:24px}
.side h3{font:600 12px/1 ui-sans-serif,sans-serif;text-transform:uppercase;
  letter-spacing:.14em;color:var(--muted);margin:0 0 14px}
.side ul{list-style:none;margin:0;padding:0}
.side li{padding:9px 0;border-bottom:1px solid var(--rule)}
.side li a{color:var(--ink);font-size:16px}
.side li span{display:block;font:italic 13px Georgia,serif;color:var(--muted)}

.btn{display:inline-block;background:var(--ink);color:var(--paper);
  font:600 14px ui-sans-serif,sans-serif;padding:11px 22px;letter-spacing:.04em}
.btn:hover{background:var(--accent);text-decoration:none}

/* section rules */
.band{background:var(--paper2);border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);margin-top:34px}
.band .wrap{max-width:920px;padding:34px 22px}
.band h2{font-size:14px;text-transform:uppercase;letter-spacing:.16em;
  font-family:ui-sans-serif,sans-serif;color:var(--muted);margin:0 0 20px;font-weight:600}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card h4{margin:0 0 6px;font-size:19px;line-height:1.25}
.card p{margin:0;font-size:15px;color:#4a443b}
.card .tag{font:600 11px ui-sans-serif,sans-serif;letter-spacing:.12em;
  text-transform:uppercase;color:var(--accent2)}

/* article body */
main.read{padding:40px 0 20px}
.post .meta{font:600 12px ui-sans-serif,sans-serif;letter-spacing:.12em;
  text-transform:uppercase;color:var(--muted)}
.post h1{font-size:38px;line-height:1.12;margin:.2em 0 .3em}
.post .lead{font-size:21px;color:#3a342c;font-style:italic;margin:0 0 26px}
.post figure{margin:26px 0}
.post img{width:100%;height:auto;display:block;border:1px solid var(--rule)}
.post figcaption{font:italic 13px Georgia,serif;color:var(--muted);margin-top:6px}
.post h2{font-size:25px;margin:1.5em 0 .4em;border-bottom:1px solid var(--rule);
  padding-bottom:.2em}
.post h3{font-size:20px;margin:1.3em 0 .3em}
.post p{margin:0 0 1.05em}
.post blockquote{margin:1.4em 0;padding:.2em 0 .2em 22px;border-left:3px solid var(--accent);
  font-style:italic;color:#403a31}
.post ul,.post ol{margin:0 0 1.1em 1.2em}
.post li{margin:.3em 0}
.related{margin-top:40px;border-top:3px double var(--ink);padding-top:22px}
.related h3{font:600 12px ui-sans-serif,sans-serif;text-transform:uppercase;
  letter-spacing:.14em;color:var(--muted)}
.related a{display:block;padding:8px 0;border-bottom:1px solid var(--rule);color:var(--ink)}

footer.site{border-top:3px double var(--ink);margin-top:50px;background:var(--paper)}
footer.site .wrap{max-width:920px;padding:26px 22px;font:14px Georgia,serif;color:var(--muted)}
footer.site a{color:var(--muted)}
.disc{font:italic 13px Georgia,serif;color:var(--muted);margin-top:8px}

@media(max-width:720px){
  .lede,.cards{grid-template-columns:1fr;gap:24px}
  .side{border-left:0;border-top:1px solid var(--rule);padding:20px 0 0}
  .lede h1{font-size:33px}.post h1{font-size:29px}
}

/* auto: article cards for the homepage "Latest" section + /articles.html (build-spoke-index.cjs) */
.fresh{max-width:1180px;margin:34px auto 12px;padding:0 18px}
.fresh-h{display:flex;align-items:center;gap:14px;margin:0 0 20px}
.fresh-h h2{margin:0;font-size:1.5rem}
.fresh-h .ln{flex:1;height:1px;background:rgba(128,128,128,.28)}
.fresh-h .fresh-all{font-size:.85rem;text-decoration:none;white-space:nowrap;opacity:.8}
.fresh-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:22px}
.fresh-card{display:flex;flex-direction:column;text-decoration:none;color:inherit;border-radius:14px;overflow:hidden;background:rgba(128,128,128,.07);box-shadow:0 1px 3px rgba(0,0,0,.09);transition:transform .15s ease,box-shadow .15s ease}
.fresh-card:hover{transform:translateY(-3px);box-shadow:0 10px 26px rgba(0,0,0,.16)}
.fresh-card .ph{aspect-ratio:16/10;background-size:cover;background-position:center;background-color:rgba(128,128,128,.15)}
.fresh-card .bd{padding:15px 17px 18px}
.fresh-card .d{margin:0 0 7px;font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;opacity:.55}
.fresh-card h3{margin:0 0 7px;font-size:1.12rem;line-height:1.28}
.fresh-card .dek{margin:0;opacity:.8;font-size:.92rem;line-height:1.45}
