/* ============================================================
   THE PERENNIAL REVIEW — Ghost theme stylesheet
   Consolidated from the approved static prototype (style.css +
   each page's <style> block). Tokens are unchanged — do not drift.
   Palette: cream (reading) · warm grey (structure) · gold + red (accent)
   ============================================================ */
:root{
  /* reading surfaces — warm cream */
  --cream:#F5F0E6; --cream2:#FBF8F1;
  /* structural surfaces — visible warm grey */
  --grey:#DAD7CD;      /* true structural grey — cards, bands */
  --grey2:#E4E1D8;     /* lighter grey panel */
  --grey3:#CFCBC0;     /* deeper grey for footer / strong zones */
  /* ink + text */
  --ink:#2B2A28; --soft:#6B6862; --faint:#928E85;
  /* accents */
  --gold:#A07E38; --gold-deep:#836428; --gold-soft:#CBB075;
  --red:#9E3328; --red-soft:#C25542;
  --rule:#C9C4B6;      /* hairline, slightly greyer now */
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--cream);color:var(--ink);font-family:'Spectral',Georgia,serif;line-height:1.62;-webkit-font-smoothing:antialiased}
::selection{background:var(--gold-soft);color:#1a1a1a}
.wrap{max-width:1180px;margin:0 auto;padding:0 26px}
.narrow{max-width:760px;margin:0 auto;padding:0 26px}
img{max-width:100%;height:auto;display:block}

/* ---- shared type utilities ---- */
.eyebrow{font-family:'Newsreader',serif;font-size:11.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-weight:600}
.byline{font-family:'Newsreader',serif;font-size:12px;letter-spacing:.09em;text-transform:uppercase;color:var(--faint)}
.dek{font-style:italic;color:var(--soft)}
a.read{font-family:'Newsreader',serif;font-size:12.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--red);text-decoration:none;display:inline-flex;align-items:center;gap:7px;transition:gap .25s,color .2s}
a.read:hover{gap:12px;color:var(--red-soft)}

/* ---- utility strip ---- */
.strip{border-bottom:1px solid var(--rule);background:var(--grey2)}
.strip .wrap{display:flex;justify-content:space-between;align-items:center;padding:9px 26px}
.strip .season{font-family:'Newsreader',serif;font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--soft)}
.strip .season b{color:var(--red);font-weight:600}
.strip .util{display:flex;gap:20px;font-family:'Newsreader',serif;font-size:11.5px;letter-spacing:.1em;text-transform:uppercase}
.strip .util a{color:var(--soft);text-decoration:none;transition:color .2s}
.strip .util a:hover{color:var(--gold)}
@media(max-width:640px){.strip .util{display:none}}

/* ---- masthead ---- */
.mast{text-align:center;padding:38px 0 20px}
.mast .kicker{font-family:'Newsreader',serif;font-size:11.5px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.mast h1{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(34px,6.4vw,64px);letter-spacing:.005em;line-height:.98;color:var(--ink)}
.mast h1 a{color:inherit;text-decoration:none}
.mast .ornament{display:flex;align-items:center;justify-content:center;gap:16px;margin:16px 0 0}
.mast .ornament .ln{height:1px;width:54px;background:linear-gradient(90deg,transparent,var(--gold-soft))}
.mast .ornament .ln.r{background:linear-gradient(90deg,var(--gold-soft),transparent)}
.mast .ornament .dot{width:6px;height:6px;background:var(--red);transform:rotate(45deg)}
.mast .tag{font-style:italic;color:var(--soft);margin-top:13px;font-size:clamp(14px,1.6vw,17px)}

/* ---- nav ---- */
nav.main{border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);margin-top:20px;background:var(--cream2)}
nav.main .wrap{display:flex;justify-content:center;gap:30px;flex-wrap:wrap;padding:13px 26px}
nav.main a{font-family:'Newsreader',serif;font-size:14px;color:var(--ink);text-decoration:none;letter-spacing:.03em;opacity:.82;position:relative;padding:2px 0;transition:opacity .2s,color .2s}
nav.main a:hover,nav.main a.on{opacity:1;color:var(--gold)}
nav.main a::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:var(--red);transform:scaleX(0);transition:transform .25s}
nav.main a:hover::after,nav.main a.on::after{transform:scaleX(1)}

/* ---- section header row ---- */
.secrow{display:flex;justify-content:space-between;align-items:center;border-bottom:2px solid var(--ink);padding-bottom:11px;margin-bottom:26px}
.secrow h3{font-family:'Newsreader',serif;font-size:13px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink);display:flex;align-items:center;gap:10px}
.secrow h3 .di{width:6px;height:6px;background:var(--red);transform:rotate(45deg)}
.secrow a{font-family:'Newsreader',serif;font-size:12px;letter-spacing:.08em;color:var(--soft);text-decoration:none;transition:color .2s}
.secrow a:hover{color:var(--gold)}

/* ---- cards (grey surface now) ---- */
.card{background:var(--grey2);border:1px solid var(--rule);transition:transform .25s,box-shadow .25s,border-color .25s;cursor:pointer;display:flex;flex-direction:column;overflow:hidden;text-decoration:none;color:inherit}
.card:hover{transform:translateY(-5px);box-shadow:0 16px 30px rgba(43,42,40,.10);border-color:var(--gold-soft)}
.card .thumb{height:5px;background:linear-gradient(90deg,var(--gold),var(--gold-soft))}
.card .thumb.img{height:170px;background-size:cover;background-position:center}
.card .body{padding:26px 24px 24px;display:flex;flex-direction:column;flex:1}
.card .tag{font-family:'Newsreader',serif;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:13px}
.card h4{font-family:'Fraunces',serif;font-weight:500;font-size:22px;line-height:1.18;margin-bottom:11px;letter-spacing:-.01em;color:var(--ink)}
.card p{color:var(--soft);font-size:15px;flex:1}
.card .by{font-family:'Newsreader',serif;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-top:18px;padding-top:14px;border-top:1px solid var(--rule)}

/* ---- footer (deeper grey zone) ---- */
footer.site{margin-top:54px;border-top:3px solid var(--gold);background:var(--grey3)}
footer.site .wrap{padding:46px 26px 56px}
.frow{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px;margin-bottom:34px}
.fbrand .fm{font-family:'Fraunces',serif;font-size:24px;margin-bottom:10px}
.fbrand p{color:var(--soft);font-size:14px;font-style:italic;max-width:260px}
.fcol h6{font-family:'Newsreader',serif;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.fcol a{display:block;font-family:'Spectral',serif;font-size:14.5px;color:var(--soft);text-decoration:none;margin-bottom:9px;transition:color .2s;cursor:pointer}
.fcol a:hover{color:var(--ink)}
.fbase{border-top:1px solid var(--rule);padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-family:'Newsreader',serif;font-size:12px;letter-spacing:.06em;color:var(--faint)}
@media(max-width:760px){.frow{grid-template-columns:1fr 1fr}}

/* ---- newsletter block ---- */
.news{margin:48px 0 0;border:1px solid var(--gold-soft);background:var(--grey2);padding:46px 40px;text-align:center;position:relative}
.news::before,.news::after{content:"";position:absolute;width:22px;height:22px;border:1px solid var(--red)}
.news::before{top:12px;left:12px;border-right:none;border-bottom:none}
.news::after{bottom:12px;right:12px;border-left:none;border-top:none}
.news .lab{font-family:'Newsreader',serif;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--red);margin-bottom:13px}
.news h3{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(23px,3vw,32px);margin-bottom:12px}
.news p{color:var(--soft);max-width:470px;margin:0 auto 22px;font-style:italic}
.news .signup{display:flex;max-width:420px;margin:0 auto;border:1px solid var(--ink)}
.news .signup input{flex:1;border:none;background:var(--cream2);padding:14px 16px;font-family:'Spectral',serif;font-size:14px;color:var(--ink);outline:none}
.news .signup button{background:var(--red);color:#F8F3E9;border:none;padding:0 24px;font-family:'Newsreader',serif;font-size:12px;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;transition:background .2s}
.news .signup button:hover{background:var(--red-soft)}
.news .msg{font-family:'Newsreader',serif;font-size:12px;letter-spacing:.08em;text-transform:uppercase;margin-top:16px;min-height:1em}
.news .msg.ok{color:var(--gold-deep)}
.news .msg.err{color:var(--red)}
.news-form [data-members-success],.news-form [data-members-error]{display:none}
.news-form.success .signup{display:none}
.news-form.success [data-members-success]{display:block}
.news-form.error [data-members-error]{display:block}

/* ---- page intro header (shared by About / sections / archive) ---- */
.pagehead{text-align:center;padding:48px 0 36px;border-bottom:1px solid var(--rule);background:var(--cream2)}
.pagehead .crumb{font-family:'Newsreader',serif;font-size:11.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--red);font-weight:600;margin-bottom:18px}
.pagehead h1{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(30px,5vw,48px);line-height:1.08;letter-spacing:-.01em;margin-bottom:18px}
.pagehead .sub{font-family:'Fraunces',serif;font-style:italic;font-weight:300;font-size:clamp(16px,2.2vw,21px);color:var(--soft);max-width:580px;margin:0 auto;line-height:1.45}

/* ============================================================
   HOMEPAGE (index)
   ============================================================ */
.hero{display:grid;grid-template-columns:1.08fr .92fr;margin:36px 0 26px;border:1px solid var(--rule);background:var(--cream2);overflow:hidden}
.hero .txt{padding:50px 48px}
.hero .eyebrow{display:block;margin-bottom:18px}
.hero h2{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(30px,4vw,48px);line-height:1.05;letter-spacing:-.015em;margin-bottom:18px}
.hero h2 .drop,.hero h2::first-letter{color:var(--red)}
.hero .dek{font-size:clamp(17px,1.9vw,20px);line-height:1.5;margin-bottom:22px}
.hero .meta{display:flex;align-items:center;gap:14px;margin-bottom:24px}
.hero .meta .pip{width:4px;height:4px;border-radius:50%;background:var(--gold-soft)}
.hero .art{background:var(--grey);position:relative;min-height:380px;overflow:hidden;border-left:1px solid var(--rule)}
.hero .art svg{position:absolute;inset:0;width:100%;height:100%}
.hero .art img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero .art .cap{position:absolute;left:18px;bottom:14px;font-family:'Newsreader',serif;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint)}
@media(max-width:840px){.hero{grid-template-columns:1fr}.hero .art{min-height:210px;order:-1;border-left:none;border-bottom:1px solid var(--rule)}.hero .txt{padding:34px 26px}}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding-bottom:14px}
@media(max-width:840px){.grid{grid-template-columns:1fr}}
.band{margin:44px 0;background:var(--grey);border:1px solid var(--rule);display:grid;grid-template-columns:1fr 1fr;overflow:hidden;position:relative}
.band::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--gold),var(--red))}
.band .side{padding:44px 44px}
.band .side.l{border-right:1px solid var(--rule)}
.band .lab{font-family:'Newsreader',serif;font-size:11px;letter-spacing:.24em;text-transform:uppercase;margin-bottom:16px}
.band .side.l .lab{color:var(--red)}.band .side.r .lab{color:var(--gold)}
.band .shloka{font-family:'Fraunces',serif;font-style:italic;font-size:22px;line-height:1.42;color:var(--ink)}
.band .src{font-family:'Newsreader',serif;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-top:14px}
.band .study h5{font-family:'Fraunces',serif;font-weight:500;font-size:20px;color:var(--ink);margin-bottom:11px}
.band .study p{font-size:15.5px;line-height:1.6;color:var(--soft)}
@media(max-width:760px){.band{grid-template-columns:1fr}.band .side.l{border-right:none;border-bottom:1px solid var(--rule)}.band .side{padding:32px 26px}}
.twoup{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.wide{background:var(--grey2);border:1px solid var(--rule);padding:32px;cursor:pointer;transition:border-color .25s,transform .25s;text-decoration:none;color:inherit;display:block}
.wide:hover{border-color:var(--gold-soft);transform:translateY(-3px)}
.wide .tag{font-family:'Newsreader',serif;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:13px}
.wide h4{font-family:'Fraunces',serif;font-weight:500;font-size:25px;line-height:1.15;margin-bottom:11px}
.wide p{color:var(--soft);font-size:15.5px;margin-bottom:16px}
@media(max-width:760px){.twoup{grid-template-columns:1fr}}

/* ============================================================
   ARTICLE (post)
   ============================================================ */
.progress{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--red));width:0;z-index:100;transition:width .1s linear}
.topbar{position:sticky;top:0;z-index:90;background:rgba(251,248,241,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--rule)}
.topbar .in{max-width:1080px;margin:0 auto;padding:11px 26px;display:flex;justify-content:space-between;align-items:center}
.topbar .home{font-family:'Fraunces',serif;font-size:17px;font-weight:500;color:var(--ink);text-decoration:none;letter-spacing:.01em}
.topbar .home .dot{color:var(--red)}
.topbar .meta{font-family:'Newsreader',serif;font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint)}
.topbar .meta a{color:var(--gold);text-decoration:none}
@media(max-width:600px){.topbar .meta{display:none}}
.article{max-width:680px;margin:0 auto;padding:0 26px}
header.art-head{padding:60px 0 44px;text-align:center;border-bottom:1px solid var(--rule)}
.art-head .crumb{font-family:'Newsreader',serif;font-size:11.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--red);font-weight:600;margin-bottom:24px}
.art-head .crumb a{color:inherit;text-decoration:none}
.art-head h1{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(32px,5.4vw,52px);line-height:1.08;letter-spacing:-.015em;margin-bottom:24px}
.art-head .dek{font-family:'Fraunces',serif;font-style:italic;font-weight:300;font-size:clamp(18px,2.4vw,23px);line-height:1.45;color:var(--soft);max-width:560px;margin:0 auto 30px}
.art-head .meta{display:flex;align-items:center;justify-content:center;gap:14px;font-family:'Newsreader',serif;font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint)}
.art-head .meta .pip{width:4px;height:4px;border-radius:50%;background:var(--gold-soft)}
.art-head .meta .au{color:var(--ink)}
.feature-image{max-width:1080px;margin:30px auto 0;padding:0 26px}
.feature-image img{width:100%;border:1px solid var(--rule)}
.motif{display:flex;justify-content:center;padding:30px 0 6px}
.motif svg{width:70px;height:70px;opacity:.9}
.body{padding:6px 0 30px;font-size:19px;line-height:1.78;color:#34322E}
.body p{margin-bottom:26px}
.body > p.lead:first-of-type::first-letter,.body > p:first-of-type::first-letter,.pr-essay > p.lead:first-of-type::first-letter,.pr-essay > p:first-of-type::first-letter{font-family:'Fraunces',serif;font-weight:600;float:left;font-size:76px;line-height:.78;padding:8px 12px 0 0;color:var(--red)}
.pr-essay > p{margin-bottom:26px}
.pr-essay > p.lead{font-size:20px}
.body p.lead{font-size:20px}
.body h2{font-family:'Fraunces',serif;font-weight:500;font-size:27px;line-height:1.2;margin:46px 0 18px;letter-spacing:-.01em;color:var(--ink)}
.body h2 .num{font-family:'Newsreader',serif;font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:6px;font-weight:600}
.body h3{font-family:'Fraunces',serif;font-weight:500;font-size:22px;line-height:1.25;margin:36px 0 14px;color:var(--ink)}
.body ul,.body ol{margin:0 0 26px 22px}
.body li{margin-bottom:8px}
.body a{color:var(--gold-deep);text-decoration:underline;text-underline-offset:2px}
.body img{margin:30px auto;border:1px solid var(--rule)}
.body figcaption{text-align:center;font-family:'Newsreader',serif;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-top:10px}
.body blockquote{margin:40px -30px;padding:8px 30px;border-left:3px solid var(--red);background:linear-gradient(90deg,var(--grey2),transparent)}
.body blockquote p{font-family:'Fraunces',serif;font-style:italic;font-weight:400;font-size:25px;line-height:1.38;color:var(--ink);margin:0}
@media(max-width:600px){.body blockquote{margin:34px 0}}
.body .sc{font-variant:small-caps;letter-spacing:.04em;font-weight:500;color:var(--ink)}
.body em,.body i{font-style:italic}
.body .sa{font-style:italic;color:var(--gold-deep)}
.pull{margin:40px -30px;padding:8px 30px;border-left:3px solid var(--red);background:linear-gradient(90deg,var(--grey2),transparent)}
.pull p{font-family:'Fraunces',serif;font-style:italic;font-weight:400;font-size:25px;line-height:1.38;color:var(--ink);margin:0}
@media(max-width:600px){.pull{margin:34px 0}}
.svs{margin:42px 0;border:1px solid var(--rule);background:var(--cream2);overflow:hidden;position:relative}
.svs::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--gold),var(--red))}
.svs .row{display:grid;grid-template-columns:1fr 1fr}
.svs .col{padding:30px 30px}
.svs .col.l{border-right:1px solid var(--rule)}
.svs .lab{font-family:'Newsreader',serif;font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;margin-bottom:14px}
.svs .col.l .lab{color:var(--red)}
.svs .col.r .lab{color:var(--gold)}
.svs .verse{font-family:'Fraunces',serif;font-style:italic;font-size:19px;line-height:1.4;color:var(--ink)}
.svs .src{font-family:'Newsreader',serif;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-top:12px}
.svs .gloss{font-size:15.5px;line-height:1.6;color:var(--soft)}
@media(max-width:600px){.svs .row{grid-template-columns:1fr}.svs .col.l{border-right:none;border-bottom:1px solid var(--rule)}}
.divider{display:flex;align-items:center;justify-content:center;gap:14px;margin:40px 0}
.divider .ln{height:1px;width:50px;background:var(--rule)}
.divider .dot{width:6px;height:6px;background:var(--red);transform:rotate(45deg)}
.fn{font-size:12px;vertical-align:super;color:var(--red);text-decoration:none;font-family:'Newsreader',serif;padding:0 1px}
.endmark{text-align:center;margin:36px 0 10px;color:var(--red);font-size:20px}
.closing{font-family:'Fraunces',serif;font-style:italic;font-size:18px;line-height:1.5;color:var(--soft);text-align:center;max-width:520px;margin:0 auto 10px}
.author{margin:50px 0 0;padding:30px;border:1px solid var(--rule);background:var(--grey2);display:flex;gap:22px;align-items:flex-start}
.author .av{width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,var(--gold-soft),var(--red));flex-shrink:0;background-size:cover;background-position:center}
.author h5{font-family:'Newsreader',serif;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.author p{font-size:15px;color:var(--soft);line-height:1.6}
.notes{margin:44px 0 0;padding-top:26px;border-top:1px solid var(--rule)}
.notes h6{font-family:'Newsreader',serif;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--faint);margin-bottom:16px}
.notes ol{padding-left:18px}
.notes li{font-size:14px;line-height:1.6;color:var(--soft);margin-bottom:10px}
.next{margin:54px 0;padding-bottom:10px}
.next .secrow{display:flex;justify-content:space-between;align-items:center;border-bottom:2px solid var(--ink);padding-bottom:10px;margin-bottom:24px}
.next .secrow h3{font-family:'Newsreader',serif;font-size:12.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink);display:flex;align-items:center;gap:10px}
.next .secrow h3 .di{width:6px;height:6px;background:var(--red);transform:rotate(45deg)}
.next .secrow a{font-family:'Newsreader',serif;font-size:12px;color:var(--soft);text-decoration:none}
.next .two{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.next .nc{background:var(--cream2);border:1px solid var(--rule);padding:24px;cursor:pointer;transition:transform .25s,border-color .25s;text-decoration:none;color:inherit;display:block}
.next .nc:hover{transform:translateY(-3px);border-color:var(--gold-soft)}
.next .nc .tag{font-family:'Newsreader',serif;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:11px}
.next .nc h4{font-family:'Fraunces',serif;font-weight:500;font-size:20px;line-height:1.2;margin-bottom:8px}
.next .nc p{font-size:14px;color:var(--soft)}
@media(max-width:600px){.next .two{grid-template-columns:1fr}}
.signup-mini{margin:30px 0 0;border:1px solid var(--gold-soft);background:var(--cream2);padding:36px 30px;text-align:center;position:relative}
.signup-mini .lab{font-family:'Newsreader',serif;font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--red);margin-bottom:12px}
.signup-mini h3{font-family:'Fraunces',serif;font-weight:500;font-size:25px;margin-bottom:18px}
.signup-mini .f{display:flex;max-width:380px;margin:0 auto;border:1px solid var(--ink)}
.signup-mini input{flex:1;border:none;background:var(--cream);padding:12px 14px;font-family:'Spectral',serif;font-size:14px;outline:none;color:var(--ink)}
.signup-mini button{background:var(--red);color:#F8F3E9;border:none;padding:0 22px;font-family:'Newsreader',serif;font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:background .2s}
.signup-mini button:hover{background:var(--red-soft)}
.signup-mini .msg{font-family:'Newsreader',serif;font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;margin-top:14px;min-height:1em}
.signup-mini .msg.ok{color:var(--gold-deep)}
.signup-mini .msg.err{color:var(--red)}
.mini-form [data-members-success],.mini-form [data-members-error]{display:none}
.mini-form.success .f{display:none}
.mini-form.success [data-members-success]{display:block}
.mini-form.error [data-members-error]{display:block}
footer.post{margin-top:50px;border-top:3px solid var(--gold);background:var(--grey2);text-align:center;padding:36px 26px 50px}
footer.post .fm{font-family:'Fraunces',serif;font-size:21px;margin-bottom:8px}
footer.post .line{font-family:'Fraunces',serif;font-style:italic;color:var(--soft);font-size:15px;margin-bottom:18px}
footer.post .links{display:flex;justify-content:center;gap:20px;flex-wrap:wrap;font-family:'Newsreader',serif;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--faint)}
footer.post .links a{color:inherit;text-decoration:none;transition:color .2s}
footer.post .links a:hover,footer.post .links span:hover{color:var(--gold)}
footer.post .links span{cursor:pointer;transition:color .2s}

/* ============================================================
   SECTION / ESSAYS index
   ============================================================ */
.filters{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;padding:26px 0 0}
.filters a{font-family:'Newsreader',serif;font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--soft);background:var(--grey2);border:1px solid var(--rule);padding:8px 16px;cursor:pointer;transition:all .2s;text-decoration:none}
.filters a:hover{color:var(--ink);border-color:var(--gold-soft)}
.filters a.on{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.list{padding:30px 0 10px}
.entry{display:grid;grid-template-columns:130px 1fr auto;gap:26px;padding:28px 0;border-bottom:1px solid var(--rule);align-items:baseline;text-decoration:none;color:inherit;transition:background .2s}
.entry:hover{background:var(--cream2)}
.entry:hover h3{color:var(--gold-deep)}
.entry .sec{font-family:'Newsreader',serif;font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--red);padding-top:5px}
.entry h3{font-family:'Fraunces',serif;font-weight:500;font-size:24px;line-height:1.18;margin-bottom:8px;transition:color .2s}
.entry p{color:var(--soft);font-size:15.5px;margin-bottom:8px}
.entry .by{font-family:'Newsreader',serif;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint)}
.entry .when{font-family:'Newsreader',serif;font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);white-space:nowrap;padding-top:5px}
@media(max-width:680px){.entry{grid-template-columns:1fr;gap:6px}.entry .sec{padding-top:0}.entry .when{padding-top:0}}
.emptynote{text-align:center;color:var(--faint);font-style:italic;padding:50px 0}

/* ============================================================
   ARCHIVE
   ============================================================ */
.toggle{display:flex;justify-content:center;gap:0;padding:26px 0 0}
.toggle a{font-family:'Newsreader',serif;font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--soft);background:var(--grey2);border:1px solid var(--rule);padding:9px 22px;cursor:pointer;transition:all .2s;text-decoration:none}
.toggle a.on{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.issue{margin:38px 0;border:1px solid var(--rule);background:var(--cream2);overflow:hidden}
.issue .ihead{display:flex;justify-content:space-between;align-items:baseline;padding:26px 30px;background:var(--grey);border-bottom:1px solid var(--rule);position:relative}
.issue .ihead::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--gold),var(--red))}
.issue .ihead .l .vol{font-family:'Newsreader',serif;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--red);margin-bottom:6px}
.issue .ihead .l h2{font-family:'Fraunces',serif;font-weight:500;font-size:28px}
.issue .ihead .l .theme{font-style:italic;color:var(--soft);font-size:15px;margin-top:4px}
.issue .ihead .when{font-family:'Newsreader',serif;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint)}
.issue .contents{padding:8px 30px 16px}
.ci{display:grid;grid-template-columns:150px 1fr auto;gap:22px;padding:16px 0;border-bottom:1px solid var(--rule);align-items:baseline;text-decoration:none;color:inherit;transition:padding-left .2s}
.ci:last-child{border-bottom:none}
.ci:hover{padding-left:8px}
.ci:hover h4{color:var(--gold-deep)}
.ci .sec{font-family:'Newsreader',serif;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--red)}
.ci h4{font-family:'Fraunces',serif;font-weight:500;font-size:19px;line-height:1.2;transition:color .2s}
.ci .rt{font-family:'Newsreader',serif;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);white-space:nowrap}
@media(max-width:680px){.ci{grid-template-columns:1fr;gap:4px}}
.forth{margin:38px 0;border:1px dashed var(--rule);padding:30px;text-align:center;background:var(--grey2)}
.forth .vol{font-family:'Newsreader',serif;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--faint);margin-bottom:8px}
.forth h2{font-family:'Fraunces',serif;font-weight:500;font-size:24px;color:var(--soft);margin-bottom:6px}
.forth p{font-style:italic;color:var(--faint);font-size:14px}
.yearlabel{font-family:'Newsreader',serif;font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);text-align:center;margin:44px 0 0;padding-bottom:10px;border-bottom:1px solid var(--rule)}

/* ============================================================
   ABOUT
   ============================================================ */
.about-body{padding:46px 0 20px;font-size:18px;line-height:1.75;color:#34322E}
.about-body p{margin-bottom:24px}
.about-body p.lead{font-size:21px;font-family:'Fraunces',serif;font-weight:400;line-height:1.5;color:var(--ink);margin-bottom:30px}
.about-body p.lead .drop{color:var(--red);font-weight:600}
.about-body h2{font-family:'Fraunces',serif;font-weight:500;font-size:25px;margin:42px 0 16px;color:var(--ink)}
.about-body h2 .num{font-family:'Newsreader',serif;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:5px;font-weight:600}
.about-body .sc{font-variant:small-caps;letter-spacing:.04em;font-weight:500}
.about-body .sa{font-style:italic;color:var(--gold-deep)}
.about-body a{color:var(--gold-deep);text-decoration:underline;text-underline-offset:2px}
.credo{margin:38px 0;padding:32px 34px;background:var(--grey);border:1px solid var(--rule);position:relative}
.credo::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--gold),var(--red))}
.credo p{font-family:'Fraunces',serif;font-style:italic;font-size:21px;line-height:1.45;color:var(--ink);margin:0}
.principles{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin:36px 0}
.principle{background:var(--grey2);border:1px solid var(--rule);padding:26px}
.principle .n{font-family:'Fraunces',serif;font-size:30px;color:var(--red);line-height:1;margin-bottom:10px}
.principle h4{font-family:'Fraunces',serif;font-weight:500;font-size:19px;margin-bottom:8px}
.principle p{font-size:14.5px;color:var(--soft);margin:0;line-height:1.6}
@media(max-width:680px){.principles{grid-template-columns:1fr}}
.editors{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin:34px 0}
.editor{display:flex;gap:18px;align-items:flex-start;background:var(--cream2);border:1px solid var(--rule);padding:24px}
.editor .av{width:50px;height:50px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--gold-soft),var(--red))}
.editor h4{font-family:'Fraunces',serif;font-weight:500;font-size:18px;margin-bottom:6px}
.editor p{font-size:14px;color:var(--soft);line-height:1.55;margin:0}
@media(max-width:680px){.editors{grid-template-columns:1fr}}

/* ============================================================
   MEMBERSHIP
   ============================================================ */
.intro{text-align:center;max-width:600px;margin:40px auto 10px;font-size:18px;line-height:1.7;color:#34322E}
.tiers{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin:40px 0}
.tier{border:1px solid var(--rule);background:var(--cream2);padding:38px 34px;display:flex;flex-direction:column;position:relative}
.tier.feat{background:var(--grey);border-color:var(--gold-soft)}
.tier.feat::before{content:"Supporting";position:absolute;top:-11px;left:34px;background:var(--red);color:var(--cream);font-family:'Newsreader',serif;font-size:10px;letter-spacing:.18em;text-transform:uppercase;padding:4px 12px}
.tier .name{font-family:'Newsreader',serif;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.tier .price{font-family:'Fraunces',serif;font-size:38px;color:var(--ink);line-height:1;margin-bottom:6px}
.tier .price small{font-size:15px;color:var(--faint);font-family:'Newsreader',serif;letter-spacing:.05em}
.tier .blurb{font-style:italic;color:var(--soft);font-size:15px;margin-bottom:22px;padding-bottom:22px;border-bottom:1px solid var(--rule)}
.tier ul{list-style:none;flex:1;margin-bottom:24px}
.tier li{font-size:15px;color:#34322E;padding:8px 0 8px 26px;position:relative;line-height:1.5}
.tier li::before{content:"✦";position:absolute;left:0;color:var(--red);font-size:12px;top:10px}
.tier li.muted{color:var(--faint)}
.tier li.muted::before{color:var(--faint);content:"·"}
.tier .cta{display:block;text-align:center;font-family:'Newsreader',serif;font-size:13px;letter-spacing:.12em;text-transform:uppercase;padding:14px;text-decoration:none;transition:background .2s,color .2s;cursor:pointer;width:100%;border:none}
.tier .cta.ghost{border:1px solid var(--ink);color:var(--ink);background:transparent}
.tier .cta.ghost:hover{background:var(--ink);color:var(--cream)}
.tier .cta.solid{background:var(--red);color:var(--cream);border:1px solid var(--red)}
.tier .cta.solid:hover{background:var(--red-soft);border-color:var(--red-soft)}
.tier .cta.disabled{opacity:.55;cursor:not-allowed;pointer-events:none}
@media(max-width:680px){.tiers{grid-template-columns:1fr}}
.note{text-align:center;max-width:560px;margin:14px auto 0;font-size:14px;color:var(--faint);font-style:italic;line-height:1.6}

/* ============================================================
   CONTACT
   ============================================================ */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin:46px 0}
.cintro p{font-size:17px;line-height:1.7;color:#34322E;margin-bottom:20px}
.cintro h3{font-family:'Fraunces',serif;font-weight:500;font-size:20px;margin:28px 0 10px}
.channels{list-style:none}
.channels li{padding:12px 0;border-bottom:1px solid var(--rule);font-size:15px;color:var(--soft)}
.channels li a{color:var(--gold-deep);text-decoration:none}
.channels li b{font-family:'Newsreader',serif;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:3px}
.form{background:var(--grey2);border:1px solid var(--rule);padding:34px}
.form label{font-family:'Newsreader',serif;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--soft);display:block;margin:0 0 6px}
.form input,.form select,.form textarea{width:100%;border:1px solid var(--rule);background:var(--cream2);padding:11px 13px;font-family:'Spectral',serif;font-size:15px;color:var(--ink);margin-bottom:18px;outline:none}
.form input:focus,.form select:focus,.form textarea:focus{border-color:var(--gold)}
.form textarea{min-height:120px;resize:vertical}
.form button{background:var(--red);color:var(--cream);border:none;padding:13px 28px;font-family:'Newsreader',serif;font-size:12px;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;transition:background .2s}
.form button:hover{background:var(--red-soft)}
@media(max-width:680px){.contact{grid-template-columns:1fr;gap:30px}}

/* ---- Ghost members / generic page body ---- */
.page-body{padding:46px 0 20px;font-size:18px;line-height:1.75;color:#34322E}
.page-body p{margin-bottom:24px}
.page-body h2{font-family:'Fraunces',serif;font-weight:500;font-size:25px;margin:42px 0 16px;color:var(--ink)}
.page-body h3{font-family:'Fraunces',serif;font-weight:500;font-size:20px;margin:32px 0 12px;color:var(--ink)}
.page-body a{color:var(--gold-deep);text-decoration:underline;text-underline-offset:2px}
.page-body ul,.page-body ol{margin:0 0 24px 22px}
.page-body img{margin:28px auto;border:1px solid var(--rule)}
.page-body blockquote{margin:30px 0;padding:8px 24px;border-left:3px solid var(--red);background:linear-gradient(90deg,var(--grey2),transparent)}
.page-body blockquote p{font-family:'Fraunces',serif;font-style:italic;font-size:20px;color:var(--ink);margin:0}

/* pagination */
.pagination{display:flex;justify-content:center;gap:24px;align-items:center;padding:30px 0 10px;font-family:'Newsreader',serif;font-size:12.5px;letter-spacing:.1em;text-transform:uppercase}
.pagination a{color:var(--red);text-decoration:none}
.pagination .page-number{color:var(--faint)}

/* ============================================================
   KOENIG editor cards (content the owner inserts in the dashboard)
   ============================================================ */
.body :where(.kg-card,figure){margin:30px 0}
.body .kg-card + .kg-card{margin-top:30px}
.kg-width-wide{position:relative;width:75vw;min-width:100%;left:50%;transform:translateX(-50%);max-width:1080px}
.kg-width-full{position:relative;width:100vw;left:50%;transform:translateX(-50%);max-width:100vw}
.kg-image{display:block;margin:0 auto;width:100%;border:1px solid var(--rule)}
.kg-width-full .kg-image{width:100%}
.kg-image-card figcaption,.kg-embed-card figcaption,.kg-gallery-card figcaption{text-align:center;font-family:'Newsreader',serif;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-top:10px}
.kg-gallery-container{display:flex;flex-direction:column;margin:0 auto;max-width:1080px}
.kg-gallery-row{display:flex;flex-direction:row;justify-content:center}
.kg-gallery-image{margin:6px}
.kg-gallery-image img{display:block;width:100%;height:100%;border:1px solid var(--rule)}
.kg-bookmark-card{width:100%}
.kg-bookmark-container{display:flex;min-height:148px;color:var(--ink);text-decoration:none;border:1px solid var(--rule);background:var(--cream2)}
.kg-bookmark-content{display:flex;flex-direction:column;flex-grow:1;justify-content:flex-start;padding:20px}
.kg-bookmark-title{font-family:'Fraunces',serif;font-weight:500;font-size:16px;color:var(--ink)}
.kg-bookmark-description{font-size:14px;color:var(--soft);margin-top:8px}
.kg-bookmark-metadata{font-family:'Newsreader',serif;font-size:12px;color:var(--faint);margin-top:14px}
.kg-bookmark-thumbnail{position:relative;min-width:33%;max-height:100%}
.kg-bookmark-thumbnail img{width:100%;height:100%;object-fit:cover}
.kg-button-card{display:flex;margin:30px 0}
.kg-button-card.kg-align-center{justify-content:center}
.kg-btn{display:inline-block;padding:13px 28px;font-family:'Newsreader',serif;font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;text-decoration:none;background:var(--red);color:var(--cream);transition:background .2s}
.kg-btn:hover{background:var(--red-soft)}
.kg-callout-card{display:flex;gap:12px;padding:20px 24px;margin:30px 0;border:1px solid var(--rule);background:var(--grey2)}
.kg-callout-emoji{font-size:18px}
.kg-callout-text{font-size:16px;color:#34322E}
.kg-toggle-card{margin:30px 0;border:1px solid var(--rule)}
.kg-toggle-heading{display:flex;justify-content:space-between;align-items:center;padding:18px 20px;cursor:pointer}
.kg-toggle-heading-text{font-family:'Fraunces',serif;font-size:18px}
.kg-toggle-content{padding:0 20px 18px}
.kg-header-card{padding:60px 26px;text-align:center;background:var(--grey)}
.kg-header-card h2{font-family:'Fraunces',serif;font-weight:500}
.kg-embed-card,.kg-video-card,.kg-audio-card{display:flex;flex-direction:column;align-items:center;margin:30px 0}
.kg-embed-card iframe{max-width:100%}
@media(max-width:600px){.kg-width-wide{width:100%;left:0;transform:none}}
