/* ===== Health Wire advertorial template ===== */
:root{
  --red:#c8102e;
  --ink:#16181c;
  --navy:#0b1f3a;
  --line:#e2e4e8;
  --muted:#6b7077;
  --link:#1463c4;
  --bg:#ffffff;
  --maxw:680px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:"Libre Franklin",-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);
  background:#f4f5f7;
  line-height:1.6;
  font-size:18px;
}
a{color:inherit;text-decoration:none}

/* disclosure */
.ad-disclosure{
  text-align:center;font-size:11px;letter-spacing:.14em;color:#9aa0a8;
  background:#fff;border-bottom:1px solid var(--line);padding:5px 12px;font-weight:600;
}

/* utility bar */
.util-bar{background:var(--ink);color:#cfd3d9;font-size:12px}
.util-inner{max-width:1100px;margin:0 auto;padding:7px 16px;display:flex;justify-content:space-between;align-items:center}
.util-date{letter-spacing:.02em}
.util-links a{margin-left:16px;color:#cfd3d9}
.util-links a:hover{color:#fff}

/* masthead */
.masthead{background:#fff;border-bottom:1px solid var(--line)}
.mast-inner{max-width:1100px;margin:0 auto;padding:14px 16px;display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:10px}
.brand-mark{
  background:var(--red);color:#fff;font-weight:900;font-size:20px;
  width:40px;height:40px;display:grid;place-items:center;border-radius:3px;letter-spacing:-.02em;
}
.brand-name{font-weight:900;font-size:30px;letter-spacing:-.03em;color:var(--ink)}
.brand-thin{font-weight:400;color:var(--red)}
.mast-cta{
  background:var(--red);color:#fff;border:0;font-weight:800;font-size:12px;letter-spacing:.06em;
  padding:9px 16px;border-radius:3px;cursor:pointer
}

/* section nav */
.section-nav{background:var(--navy);position:sticky;top:0;z-index:30}
.section-inner{max-width:1100px;margin:0 auto;padding:0 16px;display:flex;align-items:center;gap:2px;overflow-x:auto}
.section-nav a{color:#dfe6f0;font-size:12.5px;font-weight:700;letter-spacing:.05em;padding:12px 12px;white-space:nowrap;border-bottom:3px solid transparent}
.section-nav a:hover{background:rgba(255,255,255,.06)}
.section-nav a.active{border-bottom-color:var(--red);color:#fff}
.nav-search{margin-left:auto;color:#dfe6f0;font-size:18px;padding:0 6px}

/* article */
.article{max-width:var(--maxw);margin:0 auto;background:#fff;padding:30px 22px 10px;border-left:1px solid var(--line);border-right:1px solid var(--line)}
.kicker{color:var(--red);font-weight:800;font-size:12.5px;letter-spacing:.08em;margin-bottom:12px}
.headline{
  font-family:"Noto Serif",Georgia,serif;font-weight:900;color:#111;
  font-size:38px;line-height:1.14;letter-spacing:-.01em;margin-bottom:16px
}
.standfirst{font-size:20px;color:#33373d;line-height:1.5;margin-bottom:22px;font-weight:400}

/* byline */
.byline{display:flex;align-items:center;gap:12px;padding:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.avatar{background:var(--navy);color:#fff;font-weight:800;font-size:14px;width:42px;height:42px;border-radius:50%;display:grid;place-items:center;flex:0 0 auto}
.byline-text{display:flex;flex-direction:column}
.by-name{font-weight:800;font-size:15px}
.by-meta{color:var(--muted);font-size:13px}

/* hero */
.hero{margin:22px 0}
.hero-img{
  position:relative;aspect-ratio:16/9;border-radius:4px;overflow:hidden;
  background:linear-gradient(135deg,#2a3340,#11161d);
  display:grid;place-items:center;
}
.live-bug{position:absolute;top:12px;left:12px;background:var(--red);color:#fff;font-weight:800;font-size:11px;letter-spacing:.06em;padding:4px 9px;border-radius:3px}
.chyron{position:absolute;left:0;right:0;bottom:0}
.chyron-tag{background:var(--red);color:#fff;font-weight:900;font-size:12px;letter-spacing:.08em;display:inline-block;padding:5px 12px}
.chyron-text{background:rgba(11,31,58,.93);color:#fff;font-weight:800;font-size:16px;letter-spacing:.01em;padding:9px 14px;text-transform:uppercase}
.img-note{color:#7c8694;font-size:12px;letter-spacing:.04em;position:absolute;top:46%;text-align:center;width:90%}
.hero figcaption,.inline-img figcaption{color:var(--muted);font-size:13px;line-height:1.45;margin-top:8px;font-style:italic}

/* share */
.share-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:14px 0;border-bottom:1px solid var(--line);margin-bottom:8px}
.share{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:700;color:#fff;padding:8px 12px;border-radius:3px}
.share b{font-size:14px}
.share span{font-weight:800;opacity:.9}
.share.fb{background:#1877f2}
.share.tw{background:#111}
.share.email{background:#5b6470}
.share-count{margin-left:auto;color:var(--muted);font-size:12.5px;font-weight:600}

/* body */
.body-copy{padding-top:8px}
.body-copy p{margin:0 0 18px}
.body-copy h2{font-family:"Noto Serif",Georgia,serif;font-size:26px;font-weight:900;line-height:1.2;margin:30px 0 14px;color:#111}
.body-copy a{color:var(--link);text-decoration:underline}
.pull{
  border-left:4px solid var(--red);background:#faf6f2;
  font-family:"Noto Serif",Georgia,serif;font-size:22px;line-height:1.4;font-weight:700;color:#1c1f24;
  padding:16px 20px;margin:24px 0
}
.pull em{color:var(--red);font-style:italic}

/* placeholders / inline images */
.ph{background:repeating-linear-gradient(45deg,#eef0f3,#eef0f3 12px,#e6e9ed 12px,#e6e9ed 24px);
  border:1px solid var(--line);border-radius:4px;display:grid;place-items:center;color:#8a929c;font-size:12.5px;text-align:center;padding:18px}
.ph-wide{aspect-ratio:16/8}
.ph-sq{aspect-ratio:1/1}
.inline-img{margin:22px 0}

/* test log */
.test-head{border-top:3px solid var(--red);padding-top:18px}
.log{display:flex;flex-direction:column;gap:14px;margin:18px 0}
.log-row{display:flex;gap:14px;align-items:flex-start;background:#f8f9fb;border:1px solid var(--line);border-radius:6px;padding:14px}
.log-day{background:var(--navy);color:#fff;font-weight:900;font-size:13px;letter-spacing:.04em;padding:7px 10px;border-radius:3px;flex:0 0 auto;min-width:62px;text-align:center}
.log-body{display:flex;gap:14px;align-items:flex-start}
.log-body .ph-sq{width:96px;flex:0 0 96px}
.log-body p{margin:0;font-size:16px;line-height:1.5}
.results-disc{font-size:13px;color:var(--muted);font-style:italic}

/* compare */
.compare{display:flex;gap:14px;margin:18px 0 8px}
.compare-col{flex:1;border:1px solid var(--line);border-radius:8px;overflow:hidden}
.compare-col h3{padding:12px;font-size:16px;text-align:center;color:#fff;font-weight:800}
.compare-col.shot h3{background:#6b7077}
.compare-col.method h3{background:var(--red)}
.compare-col ul{list-style:none;padding:6px 0}
.compare-col li{font-size:14px;padding:9px 14px;border-bottom:1px solid var(--line);line-height:1.35}
.compare-col li:last-child{border-bottom:0}
.compare-col.shot li{color:#4a4f56}
.compare-col.method li{font-weight:600}
.compare-col.method li::before{content:"✓ ";color:var(--red);font-weight:900}
.compare-col.shot li::before{content:"✕ ";color:#9aa0a8;font-weight:900}

/* CTA box */
.cta-box{border:2px solid var(--red);border-radius:10px;padding:26px 22px;margin:28px 0;text-align:center;background:#fff;box-shadow:0 8px 28px rgba(200,16,46,.12)}
.cta-flag{display:inline-block;background:var(--red);color:#fff;font-weight:900;font-size:12px;letter-spacing:.07em;padding:6px 14px;border-radius:3px;margin-bottom:14px}
.cta-head{font-family:"Noto Serif",Georgia,serif;font-size:28px;font-weight:900;margin:0 0 8px;color:#111}
.cta-sub{font-size:16px;color:#41464d;margin-bottom:18px}
.cta-btn{display:inline-block;background:var(--red);color:#fff;font-weight:900;font-size:19px;letter-spacing:.02em;padding:16px 36px;border-radius:6px;box-shadow:0 4px 0 #8f0b20;transition:transform .06s}
.cta-btn:active{transform:translateY(2px);box-shadow:0 2px 0 #8f0b20}
.cta-fine{font-size:12.5px;color:var(--muted);margin-top:14px}
.signoff{font-family:"Noto Serif",Georgia,serif;font-style:italic;font-size:20px;color:#2a2e34;border-top:1px solid var(--line);padding-top:18px}

/* comments */
.comments{border-top:8px solid #f0f1f4;margin-top:24px;padding:18px 0}
.comments-head{display:flex;justify-content:space-between;font-size:14px;font-weight:700;color:#33373d;padding-bottom:12px}
.c-sort{color:var(--muted);font-weight:600}
.composer{display:flex;gap:10px;align-items:center;margin-bottom:18px}
.avatar.sm{width:34px;height:34px;font-size:12px}
.composer-field{flex:1;border:1px solid var(--line);border-radius:20px;padding:9px 16px;color:#9aa0a8;font-size:14px}
.comment-list{list-style:none}
.comment{display:flex;gap:10px;margin-bottom:16px}
.c-body{background:#f2f3f5;border-radius:14px;padding:10px 14px;flex:1}
.c-name{font-weight:800;font-size:14px}
.c-text{font-size:14.5px;line-height:1.45;margin:2px 0 4px}
.c-actions{font-size:12px;color:var(--muted)}
.c-actions a{color:var(--link);font-weight:700}
.c-likes{margin-left:8px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:1px 7px}
.c1{background:#b5651d}.c2{background:#7a4eab}.c3{background:#1463c4}.c4{background:#c8102e}.c5{background:#2e8b57}
.comments-disc{font-size:12px;color:var(--muted);font-style:italic;margin-top:6px}

/* sticky cta */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:50;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;gap:14px;padding:11px 16px;box-shadow:0 -4px 18px rgba(0,0,0,.18)}
.sticky-text{font-weight:700;font-size:14.5px}
.sticky-btn{background:var(--red);color:#fff;font-weight:900;font-size:14px;padding:10px 20px;border-radius:5px}

/* footer */
.site-footer{background:var(--navy);color:#aeb9c8;margin-top:30px;padding:34px 16px 90px}
.foot-cols{max-width:var(--maxw);margin:0 auto;display:flex;gap:24px;flex-wrap:wrap}
.foot-cols div{min-width:120px}
.foot-cols h4{color:#fff;font-size:13px;letter-spacing:.05em;margin-bottom:10px;text-transform:uppercase}
.foot-cols a{display:block;font-size:13.5px;color:#aeb9c8;padding:3px 0}
.foot-cols a:hover{color:#fff}
.foot-legal{max-width:var(--maxw);margin:24px auto 0;border-top:1px solid rgba(255,255,255,.12);padding-top:16px}
.foot-ad{font-size:11.5px;line-height:1.55;color:#8595a8;margin-bottom:12px}
.foot-legal>p:last-child{font-size:12px}
.foot-legal a{color:#c3cedd;text-decoration:underline}

/* responsive */
@media(max-width:560px){
  body{font-size:17px}
  .headline{font-size:29px}
  .standfirst{font-size:18px}
  .body-copy h2{font-size:22px}
  .pull{font-size:19px}
  .compare{flex-direction:column}
  .brand-name{font-size:24px}
  .util-links{display:none}
  .log-body{flex-direction:column}
  .log-body .ph-sq{width:100%;flex:none}
  .cta-head{font-size:23px}
  .cta-btn{font-size:17px;padding:15px 26px;width:100%}
}

/* ===== long-form components ===== */
.editors-note{background:#f4f6f9;border:1px solid var(--line);border-left:4px solid var(--navy);padding:14px 16px;font-size:15px;line-height:1.55;color:#3a3f46;margin:18px 0;border-radius:0 4px 4px 0}
.editors-note strong{color:var(--ink)}

.inline-cta{background:#fff7f8;border:1px dashed var(--red);border-radius:6px;padding:12px 16px;font-size:16px;margin:22px 0}
.inline-cta a{color:var(--red);font-weight:800;text-decoration:underline}

.checklist{list-style:none;margin:0 0 18px;padding:0}
.checklist li{position:relative;padding:9px 0 9px 32px;border-bottom:1px solid var(--line);font-size:17px;line-height:1.45}
.checklist li::before{content:"✓";position:absolute;left:0;top:9px;color:#fff;background:var(--red);width:21px;height:21px;border-radius:50%;font-size:12px;font-weight:900;display:grid;place-items:center}

.stat-strip{display:flex;gap:10px;margin:26px 0;text-align:center}
.stat{flex:1;background:var(--navy);color:#fff;border-radius:8px;padding:16px 8px}
.stat-num{display:block;font-family:"Noto Serif",Georgia,serif;font-weight:900;font-size:25px;color:#fff;line-height:1.1}
.stat-lbl{display:block;font-size:12px;color:#c3cedd;margin-top:5px;line-height:1.3}

.loopdiagram{display:flex;gap:8px;align-items:center;justify-content:center;flex-wrap:wrap;background:#f8f9fb;border:1px solid var(--line);border-radius:8px;padding:22px 14px}
.loop-step{background:var(--navy);color:#fff;font-weight:800;font-size:14px;letter-spacing:.04em;padding:11px 16px;border-radius:6px}
.loop-step.repeat{background:var(--red)}
.loop-arrow{color:var(--red);font-weight:900;font-size:20px}

.testi-grid{display:flex;gap:14px;margin:18px 0 8px}
.testi{flex:1;background:#f8f9fb;border:1px solid var(--line);border-radius:10px;padding:18px;text-align:center}
.testi .ph-av,.testi-photo{width:76px;height:76px;border-radius:50%;margin:0 auto 10px;object-fit:cover;display:block}
.stars{color:#f5a623;font-size:15px;letter-spacing:2px;margin-bottom:8px}
.testi-text{font-size:14.5px;line-height:1.5;color:#2a2e34;margin-bottom:10px;text-align:left}
.testi-name{font-size:13px;font-weight:800;color:var(--muted)}

.guarantee{display:flex;gap:18px;align-items:center;background:#fff;border:2px solid #2e8b57;border-radius:10px;padding:18px 20px;margin:24px 0}
.guar-badge{flex:0 0 auto;width:76px;height:76px;border-radius:50%;background:#2e8b57;color:#fff;display:grid;place-content:center;text-align:center;font-family:"Noto Serif",Georgia,serif;font-weight:900;font-size:25px;line-height:1}
.guar-badge span{display:block;font-size:11px;letter-spacing:.1em;font-weight:700}
.guar-text h3{font-size:18px;margin-bottom:5px}
.guar-text p{font-size:15px;line-height:1.5;margin:0;color:#3a3f46}

.faq{margin:14px 0}
.faq details{border:1px solid var(--line);border-radius:6px;margin-bottom:8px;overflow:hidden}
.faq summary{cursor:pointer;padding:14px 40px 14px 16px;font-weight:700;font-size:16px;list-style:none;position:relative;background:#fafbfc}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:16px;top:12px;color:var(--red);font-weight:900;font-size:20px}
.faq details[open] summary::after{content:"\2013"}
.faq details p{padding:12px 16px 14px;font-size:15.5px;line-height:1.55;color:#3a3f46;margin:0;border-top:1px solid var(--line)}

.cta-box.final{background:#0b1f3a;border-color:#0b1f3a}
.cta-box.final .cta-head{color:#fff}
.cta-box.final .cta-fine{color:#aeb9c8}
.editor-ps{font-size:15.5px;line-height:1.6;color:#3a3f46;background:#f4f6f9;border-radius:6px;padding:14px 16px;margin-top:18px}
.editor-ps a{color:var(--red);font-weight:700;text-decoration:underline}

/* real images */
.hero-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero .live-bug,.hero .chyron{z-index:2}
.log-photo{width:96px;height:96px;flex:0 0 96px;border-radius:6px;object-fit:cover}

@media(max-width:700px){ .brand-name{font-size:22px} }
@media(max-width:560px){
  .stat-strip{flex-direction:column}
  .testi-grid{flex-direction:column}
  .guarantee{flex-direction:column;text-align:center}
  .loop-step{font-size:12px;padding:9px 11px}
  .loop-arrow{font-size:16px}
  .brand-name{font-size:18px}
  .log-photo{width:100%;height:170px;flex:none}
}

/* ===== two-column layout + sidebar + live comments ===== */
.read-progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:60;background:transparent}
#readBar{display:block;height:100%;width:0;background:var(--red);transition:width .1s linear}

.page{max-width:1080px;margin:0 auto;background:#fff;display:flex;gap:30px;align-items:flex-start}
.article{margin:0;border-left:0;border-right:0;max-width:680px}
.sidebar{flex:0 0 320px;position:sticky;top:54px;align-self:flex-start;padding:30px 18px 20px}

.widget{background:#fff;border:1px solid var(--line);border-radius:8px;margin-bottom:18px;overflow:hidden}
.widget-h{font-size:12.5px;font-weight:900;letter-spacing:.07em;text-transform:uppercase;color:#fff;background:var(--navy);padding:10px 14px;margin:0}
.trend-list{list-style:none}
.trend-list li{display:flex;gap:11px;align-items:center;padding:11px 12px;border-bottom:1px solid var(--line)}
.trend-list li:last-child{border-bottom:0}
.thumb{flex:0 0 58px;height:44px;border-radius:4px}
.t1{background:linear-gradient(135deg,#c8102e,#7a0a1c)}
.t2{background:linear-gradient(135deg,#0b1f3a,#1d4e79)}
.t3{background:linear-gradient(135deg,#2e8b57,#1b5e3a)}
.t4{background:linear-gradient(135deg,#b5651d,#7a430f)}
.t5{background:linear-gradient(135deg,#5b6470,#33373d)}
.trend-list a{font-size:13px;font-weight:600;line-height:1.32;color:#1c1f24}
.trend-list a:hover{color:var(--red)}

.promo{border:2px solid var(--red);text-align:center;padding-bottom:16px}
.promo-tag{display:block;background:var(--red);color:#fff;font-size:10px;letter-spacing:.13em;font-weight:800;padding:5px;text-align:center}
.promo-img{aspect-ratio:4/3;background:repeating-linear-gradient(45deg,#eef0f3,#eef0f3 12px,#e6e9ed 12px,#e6e9ed 24px);display:grid;place-items:center;color:#8a929c;font-size:12px}
.promo-h{font-family:"Noto Serif",Georgia,serif;font-weight:900;font-size:18px;margin:12px 14px 5px;color:#111;line-height:1.2}
.promo-h2{font-family:"Noto Serif",Georgia,serif;font-weight:900;font-size:17px;margin:14px 14px 5px;color:#111;line-height:1.2}
.promo-sub{font-size:13px;color:#41464d;margin:0 14px 12px;line-height:1.45}
.promo-btn{display:inline-block;background:var(--red);color:#fff;font-weight:800;font-size:14px;padding:10px 22px;border-radius:5px}
.promo-btn.ghost{background:#fff;color:var(--red);border:2px solid var(--red)}

.pop-list{list-style:none;counter-reset:pop;padding:4px 0}
.pop-list li{counter-increment:pop;display:flex;gap:11px;align-items:flex-start;padding:10px 14px;border-bottom:1px solid var(--line)}
.pop-list li:last-child{border-bottom:0}
.pop-list li::before{content:counter(pop);font-family:"Noto Serif",Georgia,serif;font-weight:900;font-size:20px;color:var(--red);line-height:1;flex:0 0 auto}
.pop-list a{font-size:13px;font-weight:600;color:#1c1f24;line-height:1.32}
.pop-list a:hover{color:var(--red)}

.widget.news{padding:16px;background:#f4f6f9}
.widget.news h4{font-size:15px;margin-bottom:6px;color:#111}
.news-sub{font-size:13px;color:var(--muted);margin-bottom:11px;line-height:1.4}
.news-input{width:100%;padding:10px 12px;border:1px solid #cdd2d9;border-radius:6px;font-size:14px;margin-bottom:8px;font-family:inherit}
.news-btn{width:100%;background:var(--navy);color:#fff;font-weight:800;font-size:14px;padding:11px;border-radius:6px;border:0;cursor:pointer}
.news-btn:hover{background:#13294b}

.comments-head{align-items:center}
.c-tabs{display:flex;gap:4px}
.c-tab{border:0;background:none;font-size:13px;font-weight:700;color:var(--muted);cursor:pointer;padding:5px 10px;border-radius:5px}
.c-tab.active{background:#eef0f3;color:var(--ink)}
.composer{align-items:flex-start;gap:10px}
.composer-main{flex:1;min-width:0}
.composer-name{display:block;width:100%;max-width:240px;border:1px solid #cdd2d9;border-radius:6px;padding:8px 11px;font-size:13px;margin-bottom:7px;font-family:inherit}
.composer-text{display:block;width:100%;border:1px solid #cdd2d9;border-radius:12px;padding:10px 13px;font-size:14px;line-height:1.5;resize:vertical;font-family:inherit;min-height:46px}
.composer-text:focus,.composer-name:focus{outline:none;border-color:var(--link)}
.composer-row{display:flex;justify-content:space-between;align-items:center;margin-top:7px;gap:10px}
.composer-hint{font-size:11.5px;color:var(--muted)}
.composer-post{background:var(--link);color:#fff;border:0;font-weight:800;font-size:13px;padding:9px 22px;border-radius:20px;cursor:pointer}
.composer-post:hover{background:#0f4fa0}
.avatar.you{background:#1463c4}
.avatar.author{background:var(--red)}
.c-loc{color:var(--muted);font-weight:600;font-size:12px}
.badge-author{background:var(--red);color:#fff;font-size:9.5px;font-weight:800;padding:1px 6px;border-radius:3px;margin-left:5px;letter-spacing:.04em;vertical-align:1px}
.replies{list-style:none;margin:10px 0 0;padding-left:8px;border-left:2px solid var(--line)}
.comment.reply{margin-bottom:8px}
.more-replies{display:inline-block;font-size:12.5px;color:var(--link);font-weight:700;margin-top:5px;cursor:pointer}
.more-replies:hover{text-decoration:underline}
.c-actions a{cursor:pointer;user-select:none}
.c-actions a.liked{color:var(--red);font-weight:800}
.comment.new>.c-body{animation:cflash 1.4s ease}
@keyframes cflash{0%{background:#fff5d6}100%{background:#f2f3f5}}
.c6{background:#0b7285}.c7{background:#9c36b5}.c8{background:#e8590c}.c9{background:#2b8a3e}

@media(max-width:900px){
  .page{flex-direction:column;gap:0;max-width:var(--maxw)}
  .article{max-width:none}
  .sidebar{position:static;flex:auto;width:100%;border-top:8px solid #f0f1f4;padding:22px 22px 10px}
}

/* real photos */
img.avatar{display:block;object-fit:cover}
img.promo-img{display:block;width:100%;aspect-ratio:4/3;object-fit:cover;background:none}


/* cross-link thumbnails + homepage */
img.thumb{object-fit:cover;display:block}
.home-wrap{max-width:1080px;margin:0 auto;background:#fff;padding:28px 22px 44px}
.home-lead{font-family:"Noto Serif",Georgia,serif;font-size:30px;font-weight:900;margin-bottom:4px;color:#111;line-height:1.15}
.home-sub{color:var(--muted);font-size:16px;margin-bottom:22px;border-bottom:3px solid var(--red);padding-bottom:16px}
.home-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.acard{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:#fff;transition:box-shadow .12s}
.acard:hover{box-shadow:0 10px 26px rgba(0,0,0,.10)}
.acard-img{aspect-ratio:16/9;overflow:hidden;background:#11161d}
.acard-img img{width:100%;height:100%;object-fit:cover;display:block}
.acard-body{padding:14px 15px 16px}
.acard-kicker{color:var(--red);font-weight:800;font-size:11px;letter-spacing:.07em}
.acard h3{font-family:"Noto Serif",Georgia,serif;font-size:18px;line-height:1.25;margin-top:6px;color:#111}
@media(max-width:760px){.home-grid{grid-template-columns:1fr}}


/* publication shell: prose, author pages, byline review */
.prose-wrap{max-width:760px;margin:0 auto;background:#fff;padding:30px 22px 52px;border-left:1px solid var(--line);border-right:1px solid var(--line)}
.prose-kicker{color:var(--red);font-weight:800;font-size:12.5px;letter-spacing:.07em}
.prose h1{font-family:"Noto Serif",Georgia,serif;font-size:34px;font-weight:900;line-height:1.16;margin:6px 0 6px;color:#111}
.prose .dek{color:#41464d;font-size:18px;margin-bottom:18px;border-bottom:1px solid var(--line);padding-bottom:18px}
.prose h2{font-family:"Noto Serif",Georgia,serif;font-size:22px;font-weight:800;margin:26px 0 10px;color:#111}
.prose p,.prose li{font-size:17px;line-height:1.7;color:#2a2e34;margin-bottom:14px}
.prose ul{padding-left:22px;margin-bottom:14px}
.prose a{color:var(--link);text-decoration:underline}
.by-meta.reviewed{color:var(--muted)}
.by-meta.reviewed a{color:var(--muted);text-decoration:underline}
.contrib-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:8px}
.contrib{display:flex;gap:14px;align-items:flex-start;border:1px solid var(--line);border-radius:8px;padding:14px}
.contrib img{width:64px;height:64px;border-radius:50%;object-fit:cover;flex:0 0 auto}
.contrib h3{font-size:17px;margin:0}
.contrib h3 a{text-decoration:none;color:#111}
.contrib .role{color:var(--red);font-weight:700;font-size:12px;letter-spacing:.04em}
.contrib p{font-size:14px;line-height:1.5;color:#41464d;margin:6px 0 0}
.author-head{display:flex;gap:20px;align-items:center;margin-bottom:8px}
.author-head img{width:96px;height:96px;border-radius:50%;object-fit:cover}
.author-head .role{color:var(--red);font-weight:800;font-size:13px;letter-spacing:.04em}
.author-head h1{margin:3px 0 0}
@media(max-width:640px){.contrib-grid{grid-template-columns:1fr}}
