/* ══ PILL ════════════════════════════════════════════════ */
.pill {
  display:      inline-flex;
  align-items:  center;
  gap:          8px;
  padding:      5px 14px;
  border-radius: 999px;
  border:       1px solid var(--bd);
  background:   var(--surface);
  font-family:  var(--font-mono);
  font-size:    0.63rem;
  letter-spacing: 0.13em;
  color:        var(--t2);
  margin-bottom: 20px;
}

.dot {
  width:         5px;
  height:        5px;
  border-radius: 50%;
  background:    var(--accent-a);
  flex-shrink:   0;
  animation:     blink 2.4s ease-in-out infinite;
}
@keyframes blink {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.25; }
}

/* ══ BUTTONS ═════════════════════════════════════════════ */
.btn-primary {
  display:      inline-flex;
  align-items:  center;
  gap:          8px;
  padding:      10px 28px;
  border-radius: var(--r-sm);
  background:   var(--accent-a);
  color:        #06060a;
  font-family:  var(--font-sans);
  font-size:    0.85rem;
  font-weight:  500;
  border:       none;
  transition:   opacity var(--dur-fast), transform var(--dur-fast);
}
.btn-primary:hover {
  opacity:   0.88;
  transform: translateY(-1px);
}
.btn-primary:active { transform: none; opacity: 0.8; }

.btn-ghost {
  display:      inline-flex;
  align-items:  center;
  gap:          8px;
  padding:      10px 22px;
  border-radius: var(--r-sm);
  border:       1px solid var(--bd-h);
  background:   transparent;
  color:        var(--t2);
  font-family:  var(--font-sans);
  font-size:    0.85rem;
  font-weight:  300;
  transition:   color var(--dur-fast), border-color var(--dur-fast);
}
.btn-ghost:hover {
  color:        var(--t1);
  border-color: rgba(255,255,255,0.3);
}

.btn-sm { padding: 7px 18px; font-size: 0.78rem; }

/* ══ GLASS SURFACE ════════════════════════════════════════ */
.glass {
  background:  var(--surface);
  border:      1px solid var(--bd);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition:
    border-color var(--dur-fast),
    background   var(--dur-fast);
}
.glass:hover {
  border-color: var(--bd-h);
  background:   var(--surface-h);
}

/* ══ CAP TAG ════════════════════════════════════════════ */
.cap-tag {
  display:      inline-flex;
  padding:      6px 16px;
  border-radius: 999px;
  border:       1px solid var(--bd);
  font-size:    0.78rem;
  color:        var(--t2);
  font-weight:  300;
  white-space:  nowrap;
  transition:   border-color var(--dur-fast), color var(--dur-fast);
}
.cap-tag:hover { border-color: var(--accent-a); color: var(--accent-a); }

/* ══ ACCENT HELPERS ══════════════════════════════════════ */
.accent-a { color: var(--accent-a); }
.accent-b { color: var(--accent-b); }
.accent-c { color: var(--accent-c); }

/* ══ VALUE ROW ═══════════════════════════════════════════ */
.value-row {
  display:               grid;
  grid-template-columns: 150px 1fr 1fr;
  gap:                   52px;
  align-items:           start;
  padding:               40px 0;
  border-top:            1px solid var(--bd);
  transition:            border-color var(--dur-fast);
}
.value-row:last-of-type { border-bottom: 1px solid var(--bd); }
.value-row:hover        { border-top-color: var(--bd-h); }

.value-meta {
  display:        flex;
  flex-direction: column;
  gap:            7px;
}
.big-num {
  font-family:  var(--font-mono);
  font-size:    2.1rem;
  font-weight:  300;
  color:        var(--t3);
  line-height:  1;
}
.value-title {
  font-family:  var(--font-serif);
  font-size:    1.45rem;
  font-weight:  300;
  line-height:  1;
}
.value-body {
  font-size:   0.9rem;
  color:       var(--t2);
  line-height: 1.92;
  font-weight: 300;
}
.value-tags {
  display:       flex;
  flex-wrap:     wrap;
  gap:           8px;
  align-content: flex-start;
}

/* ══ CATALOG TABS ════════════════════════════════════════ */
.catalog-tabs {
  display:      flex;
  gap:          2px;
  margin-bottom: 32px;
  border-bottom: 1px solid var(--bd);
  overflow-x:   auto;
  scrollbar-width: none;
}
.catalog-tabs::-webkit-scrollbar { display: none; }

.tab {
  padding:        10px 20px;
  background:     transparent;
  border:         none;
  border-bottom:  2px solid transparent;
  color:          var(--t3);
  font-family:    var(--font-sans);
  font-size:      0.82rem;
  font-weight:    300;
  cursor:         pointer;
  white-space:    nowrap;
  margin-bottom:  -1px;
  transition:     color var(--dur-fast), border-color var(--dur-fast);
}
.tab:hover  { color: var(--t2); }
.tab.active { color: var(--accent-a); border-bottom-color: var(--accent-a); }

/* ══ CATALOG GRID ════════════════════════════════════════ */
.catalog-grid {
  display:               grid;
  grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
  gap:                   10px;
}

/* ══ DATA CARD ═══════════════════════════════════════════ */
.data-card {
  background:    var(--surface);
  border:        1px solid var(--bd);
  border-radius: var(--r-md);
  padding:       20px;
  cursor:        pointer;
  transition:
    border-color var(--dur-fast),
    background   var(--dur-fast),
    transform    var(--dur-fast);
}
.data-card:hover {
  border-color: var(--bd-h);
  background:   var(--surface-h);
  transform:    translateY(-2px);
}
.data-card.hidden { display: none; }

.card-accent {
  width:         24px;
  height:        2px;
  border-radius: 1px;
  margin-bottom: 14px;
}
.cat-climate    .card-accent { background: var(--accent-a); }
.cat-ecology    .card-accent { background: #6ee7b7; }
.cat-economy    .card-accent { background: var(--accent-c); }
.cat-governance .card-accent { background: var(--accent-b); }

.card-cat {
  font-family:     var(--font-mono);
  font-size:       0.57rem;
  letter-spacing:  0.2em;
  text-transform:  uppercase;
  color:           var(--t3);
  margin-bottom:   8px;
}
.card-name {
  font-size:   0.88rem;
  font-weight: 500;
  color:       var(--t1);
  line-height: 1.3;
  margin-bottom: 3px;
}
.card-name-zh {
  font-size:     0.75rem;
  color:         var(--t2);
  margin-bottom: 10px;
  font-weight:   300;
}
.card-desc {
  font-size:   0.73rem;
  color:       var(--t3);
  line-height: 1.65;
}

/* ══ SCENARIO CARDS ══════════════════════════════════════ */
.scenarios-grid {
  display:               grid;
  grid-template-columns: repeat(2, 1fr);
  gap:                   14px;
}
.scenario-card {
  border-radius: var(--r-lg);
  padding:       32px;
}
.scenario-num {
  font-family:    var(--font-mono);
  font-size:      0.6rem;
  letter-spacing: 0.2em;
  color:          var(--t3);
  margin-bottom:  16px;
}
.scenario-card h3 {
  font-family:   var(--font-serif);
  font-size:     1.12rem;
  font-weight:   400;
  color:         var(--t1);
  margin-bottom: 12px;
  line-height:   1.3;
}
.scenario-card p {
  font-size:     0.84rem;
  color:         var(--t2);
  line-height:   1.85;
  margin-bottom: 22px;
}
.scenario-sources {
  display:  flex;
  gap:      8px;
  flex-wrap: wrap;
}
.scenario-sources span {
  font-family:    var(--font-mono);
  font-size:      0.6rem;
  letter-spacing: 0.1em;
  color:          var(--accent-a);
  padding:        3px 10px;
  border:         1px solid rgba(74,244,200,0.2);
  border-radius:  4px;
}

/* ══ HORIZON CARDS (ROADMAP) ══════════════════════════════ */
.horizon-grid {
  display:               grid;
  grid-template-columns: repeat(3, 1fr);
  gap:                   14px;
}
.horizon-card {
  border-radius: var(--r-lg);
  padding:       28px;
}
.horizon-badge {
  display:        inline-block;
  font-family:    var(--font-mono);
  font-size:      0.58rem;
  letter-spacing: 0.12em;
  color:          var(--accent-b);
  border:         1px solid var(--accent-b-20);
  border-radius:  4px;
  padding:        3px 10px;
  margin-bottom:  18px;
}
.horizon-card h3 {
  font-family:   var(--font-serif);
  font-size:     1.05rem;
  font-weight:   400;
  color:         var(--t1);
  margin-bottom: 10px;
  line-height:   1.3;
}
.horizon-card p {
  font-size:   0.82rem;
  color:       var(--t2);
  line-height: 1.85;
}

/* ══ RESPONSIVE ══════════════════════════════════════════ */
@media (max-width: 1024px) {
  .value-row {
    grid-template-columns: 130px 1fr;
    gap: 32px;
  }
  .value-tags { grid-column: 2; }
}

@media (max-width: 768px) {
  .value-row {
    grid-template-columns: 1fr;
    gap: 18px;
    padding: 30px 0;
  }
  .value-tags { grid-column: 1; }
  .scenarios-grid  { grid-template-columns: 1fr; }
  .horizon-grid    { grid-template-columns: 1fr; }
}

@media (max-width: 600px) {
  .catalog-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }
  .scenario-card,
  .horizon-card { padding: 22px; }
}

@media (max-width: 400px) {
  .catalog-grid { grid-template-columns: 1fr; }
}
