/* ====================================================
   迁徙志 · 国家专栏页样式
   ==================================================== */

/* ===== 国家页头 ===== */
.country-hero{
  position:relative;
  min-height:420px;
  display:flex; align-items:flex-end;
  overflow:hidden;
}
@media (min-width:760px){ .country-hero{ min-height:520px; } }

.country-hero-bg{
  position:absolute; inset:0;
  background-size:cover; background-position:center;
}
.country-hero-overlay{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.35) 0%, rgba(10,8,6,.85) 100%);
}
.country-hero-content{
  position:relative;
  width:100%;
  padding:36px var(--gutter) 36px;
  color:#fff;
}
@media (min-width:760px){
  .country-hero-content{ padding:64px var(--gutter); }
}
.country-hero-meta{
  font-size:11px; letter-spacing:.24em; text-transform:uppercase;
  color:rgba(255,255,255,.65);
  font-weight:600;
  margin-bottom:14px;
}
.country-hero-flag{ font-size:48px; margin-bottom:8px; line-height:1; }
.country-hero-title{
  font-family:var(--serif);
  font-weight:700;
  font-size:48px;
  margin:0 0 14px;
  letter-spacing:-.02em;
  color:#fff;
}
@media (min-width:760px){ .country-hero-title{ font-size:80px; } }

.country-hero-dek{
  font-family:var(--serif);
  font-size:16px;
  color:rgba(255,255,255,.82);
  max-width:640px;
  margin:0 0 28px;
  line-height:1.65;
}
.country-hero-dek strong{ color:#F4C752; font-weight:600; }
@media (min-width:760px){ .country-hero-dek{ font-size:19px; } }

.country-stats{
  display:flex; gap:24px; flex-wrap:wrap;
  padding-top:24px;
  border-top:1px solid rgba(255,255,255,.18);
}
.country-stats > div{
  display:flex; flex-direction:column;
}
.cs-num{
  font-family:var(--serif); font-weight:700;
  font-size:28px;
  color:#fff;
}
.cs-label{
  font-size:11px; letter-spacing:.12em; text-transform:uppercase;
  color:rgba(255,255,255,.6);
  margin-top:2px;
}
@media (min-width:760px){
  .country-stats{ gap:48px; padding-top:32px; }
  .cs-num{ font-size:36px; }
}

/* ===== 主流路径 ===== */
.paths{ background:var(--cream); padding-bottom:48px; }
.path-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}
@media (min-width:760px){
  .path-grid{ grid-template-columns:repeat(2,1fr); gap:18px; }
}

.path-card{
  position:relative;
  background:var(--paper);
  border:1px solid var(--rule-soft);
  border-radius:2px;
  padding:24px 22px;
  transition:transform .15s ease, border-color .15s ease;
}
.path-card:hover{
  transform:translateY(-2px);
  border-color:var(--ink);
}
.path-num{
  font-family:var(--serif);
  font-size:14px; letter-spacing:.18em;
  color:var(--accent); font-weight:700;
  margin-bottom:10px;
}
.path-title{
  font-family:var(--serif);
  font-weight:700;
  font-size:22px;
  margin:0 0 8px;
}
.path-dek{
  font-size:14px; color:var(--ink-2);
  line-height:1.6;
  margin:0 0 18px;
}
.path-facts{
  list-style:none; padding:0; margin:0;
  border-top:1px solid var(--rule-soft);
}
.path-facts li{
  display:flex; justify-content:space-between; align-items:baseline;
  padding:10px 0;
  border-bottom:1px dashed var(--rule-soft);
  font-size:13px;
}
.path-facts li:last-child{ border-bottom:0; }
.path-facts span{ color:var(--ink-soft); letter-spacing:.04em; }
.path-facts strong{
  font-family:var(--serif); font-weight:700;
  font-size:15px; color:var(--ink);
}
.path-tag{
  position:absolute; top:18px; right:18px;
  font-size:11px; letter-spacing:.12em; text-transform:uppercase;
  padding:3px 8px; border-radius:2px;
  font-weight:600;
}
.path-tag.up{ background:#E6F4EA; color:#1E6B3D; }
.path-tag.warn{ background:#FEF3C7; color:#92560A; }
.path-tag.down{ background:#FEE2E2; color:#991B1B; }

/* ===== 时间线 ===== */
.timeline-section{ background:var(--paper); padding-bottom:48px; }
.timeline{
  list-style:none; padding:0; margin:0;
  position:relative;
}
.timeline::before{
  content:"";
  position:absolute;
  left:62px; top:8px; bottom:8px;
  width:1px;
  background:var(--rule-soft);
}
@media (min-width:760px){
  .timeline::before{ left:80px; }
}
.tl-item{
  position:relative;
  display:grid;
  grid-template-columns:54px 16px 1fr;
  gap:8px;
  padding:14px 0;
}
@media (min-width:760px){
  .tl-item{ grid-template-columns:72px 16px 1fr; gap:14px; padding:18px 0; }
}
.tl-date{
  font-family:var(--serif);
  font-size:14px; font-weight:700;
  color:var(--ink-soft);
  text-align:right;
  padding-top:2px;
}
.tl-dot{
  width:12px; height:12px; border-radius:50%;
  background:var(--accent);
  margin:6px auto 0;
  box-shadow:0 0 0 4px var(--paper);
  position:relative; z-index:1;
}
.tl-body h4{
  font-family:var(--serif); font-weight:700;
  font-size:17px; margin:0 0 4px;
  color:var(--ink);
}
.tl-body p{
  margin:0;
  font-size:14px; color:var(--ink-2);
  line-height:1.6;
}
@media (min-width:760px){
  .tl-body h4{ font-size:19px; }
  .tl-body p{ font-size:15px; }
}
