/* ====================================================
   迁徙志 · 文章页样式
   ==================================================== */

.back-link{
  font-family:var(--serif);
  font-size:14px; color:var(--ink-soft);
}
.back-link:hover{ color:var(--accent); }

.article{ background:var(--cream); padding-bottom:0; }

/* ===== 文章页头 ===== */
.art-head{
  padding:36px 0 28px;
  border-bottom:1px solid var(--rule-soft);
}
@media (min-width:760px){ .art-head{ padding:64px 0 40px; } }

.art-kicker{ margin-bottom:18px; }
.art-section{
  display:inline-block;
  font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--accent); font-weight:700;
  padding:4px 0;
  border-top:2px solid var(--accent);
  border-bottom:2px solid var(--accent);
}

.art-title{
  font-family:var(--serif);
  font-weight:700;
  font-size:32px;
  line-height:1.2;
  letter-spacing:-.01em;
  margin:0 0 20px;
  color:var(--ink);
}
.art-title em{ color:var(--accent); font-style:italic; }
@media (min-width:760px){ .art-title{ font-size:48px; } }
@media (min-width:1024px){ .art-title{ font-size:58px; } }

.art-dek{
  font-family:var(--serif);
  font-size:18px; line-height:1.6;
  color:var(--ink-2);
  margin:0 0 28px;
  max-width:720px;
}
@media (min-width:760px){ .art-dek{ font-size:22px; } }

.art-byline{
  display:flex; align-items:center; justify-content:space-between;
  padding-top:18px;
  border-top:1px dashed var(--rule-soft);
}
.byline-author{ display:flex; align-items:center; gap:12px; }
.byline-avatar{
  width:42px; height:42px; border-radius:50%;
  background:var(--ink); color:var(--cream);
  display:grid; place-items:center;
  font-family:var(--serif); font-weight:700; font-size:18px;
}
.byline-name{
  font-family:var(--serif); font-weight:700;
  font-size:15px; color:var(--ink);
}
.byline-meta{
  font-size:12px; color:var(--ink-soft);
  display:flex; gap:6px; align-items:center;
}

/* ===== 大图 ===== */
.art-hero{
  margin:0;
  padding:0;
}
.art-hero-img{
  width:100%;
  aspect-ratio:3/2;
  background-size:cover; background-position:center;
}
@media (min-width:760px){
  .art-hero-img{ aspect-ratio:21/9; max-height:560px; }
}
.art-hero figcaption{
  max-width:var(--max);
  margin:0 auto;
  padding:10px var(--gutter) 0;
  font-size:12px; color:var(--ink-soft);
  font-family:var(--serif); letter-spacing:.04em;
}

/* ===== 正文 ===== */
.art-body{
  max-width:680px;
  padding-top:36px;
  padding-bottom:48px;
}
.art-body p{
  font-family:var(--serif);
  font-size:17px;
  line-height:1.85;
  color:var(--ink);
  margin:0 0 1.4em;
  letter-spacing:.01em;
}
@media (min-width:760px){
  .art-body p{ font-size:19px; line-height:1.9; }
}

.art-body strong{ color:var(--ink); font-weight:700; }
.art-body em{ color:var(--accent); font-style:italic; }

.art-lede{ font-size:18px; }
.dropcap{
  float:left;
  font-family:var(--serif);
  font-size:64px; line-height:.85;
  font-weight:700;
  color:var(--accent);
  margin:6px 10px 0 0;
  padding:0;
}
@media (min-width:760px){
  .dropcap{ font-size:84px; margin-right:14px; }
}

.art-body h2{
  font-family:var(--serif);
  font-weight:700;
  font-size:24px;
  line-height:1.3;
  margin:2.4em 0 .8em;
  color:var(--ink);
  position:relative;
  padding-left:14px;
}
.art-body h2::before{
  content:""; position:absolute; left:0; top:.35em; bottom:.35em;
  width:3px; background:var(--accent);
}
@media (min-width:760px){ .art-body h2{ font-size:30px; } }

.art-quote{
  margin:2em -8px;
  padding:24px 24px;
  background:var(--paper);
  border-left:3px solid var(--accent);
  font-family:var(--serif);
  font-size:20px;
  line-height:1.55;
  color:var(--ink-2);
  font-style:italic;
}
.art-quote cite{
  display:block;
  margin-top:14px;
  font-size:13px;
  color:var(--ink-soft);
  font-style:normal;
  letter-spacing:.04em;
}
@media (min-width:760px){
  .art-quote{ margin-left:-40px; margin-right:-40px; padding:32px 40px; font-size:24px; }
}

.art-list{
  font-family:var(--serif);
  font-size:17px;
  line-height:1.85;
  color:var(--ink);
  padding-left:1.4em;
  margin:0 0 1.6em;
}
.art-list li{ margin-bottom:.7em; }
@media (min-width:760px){ .art-list{ font-size:19px; } }

/* 文章内对比表 */
.comp-table-art{
  width:100%;
  border-collapse:collapse;
  margin:1.8em 0;
  font-family:var(--serif);
  font-size:14px;
  background:var(--paper);
  border:1px solid var(--rule-soft);
}
.comp-table-art th,
.comp-table-art td{
  padding:12px 14px;
  text-align:left;
  border-bottom:1px solid var(--rule-soft);
  border-right:1px solid var(--rule-soft);
  vertical-align:top;
}
.comp-table-art th{
  background:var(--cream-2);
  color:var(--ink);
  font-weight:700;
  letter-spacing:.02em;
}
.comp-table-art tr:first-child th{
  background:var(--ink);
  color:var(--cream);
  letter-spacing:.04em;
}
.comp-table-art td strong{ color:var(--accent); font-weight:700; }
@media (max-width:760px){
  .comp-table-art{ font-size:13px; }
  .comp-table-art th, .comp-table-art td{ padding:10px 10px; }
}

.art-end{ position:relative; }
.art-mark{
  display:inline-block;
  color:var(--accent);
  font-weight:700;
  margin-left:6px;
}

/* ===== 分享提示 ===== */
.art-share{
  background:var(--ink);
  color:var(--cream);
  padding:36px 0;
}
.art-share-inner{ text-align:center; }
.art-share-title{
  font-family:var(--serif);
  font-size:20px;
  margin:0 0 10px;
  color:var(--cream);
}
.art-share-hint{
  font-size:13px;
  color:rgba(245,241,234,.65);
  margin:0;
}
.art-share-hint strong{ color:#F4C752; }

/* ===== 相关阅读 ===== */
.art-related{
  background:var(--paper);
  padding-bottom:48px;
}
