/* Second Chapter — article page */
.article-wrap{max-width:720px;margin:0 auto;padding:0 var(--gutter);}
.article-head{padding:64px 0 38px;text-align:center;}
.article-head .eyebrow{margin-bottom:22px;}
.article-title{font-family:var(--font-display);font-weight:600;font-size:clamp(38px,5vw,62px);line-height:1.06;letter-spacing:-.015em;margin:0 0 24px;}
.article-dek{font-family:var(--font-serif);font-size:22px;line-height:1.5;color:var(--muted);max-width:600px;margin:0 auto 34px;}
.byline{display:flex;align-items:center;justify-content:center;gap:14px;}
.byline .mono{width:46px;height:46px;border-radius:50%;background:var(--ink);color:var(--gold-soft);font-family:var(--font-display);font-weight:600;font-size:17px;display:flex;align-items:center;justify-content:center;}
.byline-text{text-align:left;}
.byline-name{font-family:var(--font-sans);font-size:14px;font-weight:600;}
.byline-meta{font-family:var(--font-sans);font-size:13px;color:var(--muted);margin-top:2px;}

.article-cover{max-width:1040px;margin:8px auto 0;padding:0 var(--gutter);}
.article-cover image-slot,.article-cover .ph{width:100%;height:480px;}
.cover-cap{font-family:var(--font-sans);font-size:12.5px;color:var(--muted);margin-top:12px;text-align:center;}

/* body */
.prose{font-family:var(--font-serif);font-size:19.5px;line-height:1.75;color:#23303c;}
.prose.lead-in > p:first-of-type::first-letter{font-family:var(--font-display);font-weight:600;font-size:68px;line-height:.7;float:left;margin:8px 12px 0 0;color:var(--gold-deep);}
.prose p{margin:0 0 26px;}
.prose h2{font-family:var(--font-display);font-weight:600;font-size:32px;margin:46px 0 18px;line-height:1.1;}
.prose .pullquote{font-family:var(--font-display);font-weight:500;font-size:30px;line-height:1.28;color:var(--ink);border-top:1px solid var(--gold);border-bottom:1px solid var(--gold);padding:30px 0;margin:42px 0;text-align:center;}
.prose figure{margin:40px 0;}
.prose figure .ph{height:360px;}
.prose figcaption{font-family:var(--font-sans);font-size:12.5px;color:var(--muted);margin-top:10px;}
.prose a.inline{color:var(--gold-deep);border-bottom:1px solid var(--gold);}

/* paywall */
.locked{position:relative;}
.locked.is-locked .locked-body{max-height:240px;overflow:hidden;-webkit-mask-image:linear-gradient(180deg,#000 40%,transparent);mask-image:linear-gradient(180deg,#000 40%,transparent);}
.paywall{display:none;border:1px solid var(--line);background:var(--paper-soft);padding:44px 40px;text-align:center;margin:8px 0 10px;}
.locked.is-locked .paywall{display:block;}
.paywall .arch-mini{width:46px;margin:0 auto 18px;}
.paywall h3{font-family:var(--font-display);font-weight:600;font-size:30px;margin:0 0 12px;}
.paywall p{font-family:var(--font-serif);font-size:17px;color:var(--muted);max-width:440px;margin:0 auto 24px;}
.paywall-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}
.paywall-note{font-family:var(--font-sans);font-size:12.5px;color:var(--muted);margin-top:18px;}
.paywall-note a{color:var(--gold-deep);border-bottom:1px solid var(--gold);}

/* author bio */
.author-card{display:flex;gap:20px;align-items:flex-start;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:30px 0;margin:48px 0;}
.author-card .mono{width:64px;height:64px;border-radius:50%;background:var(--ink);color:var(--gold-soft);font-family:var(--font-display);font-weight:600;font-size:22px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.author-card h4{font-family:var(--font-display);font-size:22px;margin:0 0 4px;}
.author-card .role{font-family:var(--font-sans);font-size:12.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:10px;}
.author-card p{font-family:var(--font-serif);font-size:16px;color:var(--muted);margin:0;line-height:1.6;}

/* community / comments */
.community-block{background:var(--paper-soft);border-top:1px solid var(--line-soft);}
.comments{max-width:760px;margin:0 auto;padding:0 var(--gutter);}
.comments-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:8px;flex-wrap:wrap;gap:10px;}
.comments-head h2{font-family:var(--font-display);font-size:34px;}
.comments-sub{font-family:var(--font-serif);font-size:17px;color:var(--muted);margin:0 0 30px;max-width:560px;}
.composer{display:flex;gap:14px;margin-bottom:18px;align-items:flex-start;}
.composer .mono{width:44px;height:44px;border-radius:50%;background:var(--gold);color:#fff;font-family:var(--font-display);font-weight:600;font-size:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.composer .grow{flex:1;}
.composer-actions{display:flex;justify-content:space-between;align-items:center;margin-top:10px;}
.composer-actions .hint{font-family:var(--font-sans);font-size:12px;color:var(--muted);}
.composer-locked{position:relative;}
.composer-locked .lock-over{position:absolute;inset:0;background:rgba(242,235,223,.74);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;gap:12px;font-family:var(--font-sans);font-size:14px;font-weight:500;color:var(--ink);}
.is-member .composer-locked .lock-over{display:none;}

.comment{display:flex;gap:14px;padding:24px 0;border-top:1px solid var(--line-soft);}
.comment .mono{width:44px;height:44px;border-radius:50%;background:var(--ink);color:var(--gold-soft);font-family:var(--font-display);font-weight:600;font-size:15px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.comment.staff .mono{background:var(--gold);color:#fff;}
.comment .c-name{font-family:var(--font-sans);font-size:14px;font-weight:600;}
.comment .c-role{font-family:var(--font-sans);font-size:12px;color:var(--muted);}
.comment .c-badge{font-family:var(--font-sans);font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:var(--gold);padding:2px 7px;border-radius:3px;margin-left:8px;}
.comment .c-time{font-family:var(--font-sans);font-size:12px;color:var(--muted-2);margin-left:auto;}
.comment .c-body{font-family:var(--font-serif);font-size:16.5px;line-height:1.6;margin:8px 0 10px;color:#2a3640;}
.comment .c-actions{display:flex;gap:20px;font-family:var(--font-sans);font-size:12.5px;color:var(--muted);}
.comment .c-actions span{cursor:pointer;}
.comment .c-actions span:hover{color:var(--gold-deep);}
.comment .reply{margin-left:34px;border-left:2px solid var(--gold-soft);padding-left:20px;}

/* related */
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;}
.rel-card .ph{height:170px;margin-bottom:16px;}

/* demo toggle */
.demo-toggle{position:fixed;right:20px;bottom:20px;z-index:120;display:flex;align-items:center;gap:10px;background:var(--ink);color:var(--paper);font-family:var(--font-sans);font-size:13px;font-weight:500;padding:11px 16px;border-radius:100px;box-shadow:0 14px 40px -16px rgba(0,0,0,.55);cursor:pointer;border:0;}
.demo-toggle .sw{width:34px;height:19px;border-radius:100px;background:rgba(234,224,209,.28);position:relative;transition:background .2s;}
.demo-toggle .sw::after{content:"";position:absolute;top:2px;left:2px;width:15px;height:15px;border-radius:50%;background:var(--paper);transition:left .2s;}
.is-member .demo-toggle .sw{background:var(--gold);}
.is-member .demo-toggle .sw::after{left:17px;}

@media (max-width:860px){
  .article-cover image-slot,.article-cover .ph{height:280px;}
  .related-grid{grid-template-columns:1fr;}
}
