/* =====================================================
 * disease-city.css · 疾病×城市 & 疾病总览页专属样式
 * 前缀 dc- · 医疗蓝主题 #1565C0
 * 基于 service-city-product.css 扩展
 * ===================================================== */

/* ========= 疾病页容器 ========= */
.dc-page {
  --theme: #1565C0;
}

/* Hero 医学色调 */
.dc-hero {
  background: linear-gradient(135deg, #f8fcff 0%, #eef5fb 100%);
  border-bottom: 3px solid #1565C0;
}

/* ========= 医疗免责提示条 ========= */
.sc-notice-medical {
  background: #FEF3C7;
  border-color: #F59E0B;
  border-left-color: #D97706;
  color: #78350F;
}
.sc-notice-medical .sc-notice-ic {
  color: #D97706;
}
.sc-notice-medical strong {
  color: #78350F;
}

/* ========= 疾病基础信息网格 ========= */
.dc-info-section {
  background: #fafafa;
}
.dc-info-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 12px;
}
.dc-info-card {
  background: #fff;
  border: 1px solid #e5e5e5;
  border-radius: 8px;
  padding: 14px 16px;
  transition: border-color 0.2s;
}
.dc-info-card:hover {
  border-color: #1565C0;
}
.dc-info-label {
  font-size: 12px;
  color: #888;
  margin-bottom: 4px;
}
.dc-info-value {
  font-size: 15px;
  font-weight: 600;
  color: #1a1a1a;
  line-height: 1.5;
}
.dc-info-value a {
  color: #1565C0;
  text-decoration: none;
}
.dc-info-value a:hover {
  text-decoration: underline;
}

/* ========= 内容段（症状/治疗/预后/检测）========= */
.dc-content-section {
  background: #fff;
}
.dc-content-section .sc-h2 {
  color: #1565C0;
}

.dc-prose {
  font-size: 15px;
  line-height: 1.85;
  color: #333;
  max-width: 900px;
  white-space: pre-wrap;
  word-wrap: break-word;
}
.dc-prose p {
  margin: 0 0 14px;
}

/* ========= 本地城市列表（疾病总览页）========= */
.dc-cities-section {
  background: #f8fcff;
}
.dc-cities-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 10px;
}
.dc-city-chip {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: #fff;
  border: 1px solid #dbeafe;
  border-radius: 8px;
  padding: 10px 14px;
  text-decoration: none;
  color: #1e40af;
  transition: all 0.15s;
  font-size: 14px;
}
.dc-city-chip:hover {
  background: #1565C0;
  color: #fff;
  border-color: #1565C0;
  transform: translateY(-1px);
}
.dc-city-name {
  font-weight: 600;
}
.dc-city-arrow {
  color: #94a3b8;
  font-size: 18px;
}
.dc-city-chip:hover .dc-city-arrow {
  color: #fff;
}

/* ========= 疾病目录页（按分类）========= */
.dc-cat-section {
  border-bottom: 1px solid #eee;
}
.dc-disease-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 14px;
}
.dc-disease-card {
  display: block;
  background: #fff;
  border: 1px solid #e5e5e5;
  border-radius: 10px;
  padding: 16px 18px;
  text-decoration: none;
  transition: all 0.2s;
}
.dc-disease-card:hover {
  border-color: #1565C0;
  box-shadow: 0 4px 12px rgba(21, 101, 192, 0.1);
  transform: translateY(-2px);
}
.dc-disease-name {
  font-size: 16px;
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom: 8px;
}
.dc-disease-card:hover .dc-disease-name {
  color: #1565C0;
}
.dc-disease-gene {
  font-size: 13px;
  color: #1565C0;
  font-weight: 600;
  margin-bottom: 4px;
  font-family: 'JetBrains Mono', monospace;
}
.dc-disease-meta {
  font-size: 12px;
  color: #777;
  margin-bottom: 2px;
}

/* ========= 医学免责声明（底部固定）========= */
.dc-medical-disclaimer {
  background: #fffbeb;
  border-left-color: #F59E0B;
  border-left-width: 4px;
  color: #78350F;
  line-height: 1.8;
  font-size: 13px;
}
.dc-medical-disclaimer strong {
  color: #78350F;
  font-weight: 700;
}

/* ========= 响应式 ========= */
@media (max-width: 768px) {
  .dc-info-grid {
    grid-template-columns: 1fr 1fr;
  }
  .dc-cities-grid {
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  }
  .dc-disease-grid {
    grid-template-columns: 1fr;
  }
}


/* ════════════════════════════════════════════
   2026-04-28 · disease-city 页面整体美化
   ════════════════════════════════════════════ */

/* 整体容器 */
.dc-page{
  background: linear-gradient(180deg, #f7fafc 0%, #fff 200px);
}

.sc-wrap{
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
}

/* Hero · 蓝青渐变背景 */
.sc-hero.dc-hero{
  background: linear-gradient(135deg, #1565C0 0%, #00ACC1 100%);
  padding: 32px 0 36px;
  color: #fff;
  margin-bottom: 28px;
}
.sc-hero.dc-hero .sc-h1{
  color: #fff;
  font-size: 28px;
  font-weight: 800;
  line-height: 1.35;
  margin-bottom: 14px;
}
.sc-hero.dc-hero .sc-intro{
  color: rgba(255,255,255,.92);
  font-size: 15px;
  line-height: 1.7;
  max-width: 800px;
}

/* breadcrumb 在蓝底上变白 */
.sc-hero .sc-breadcrumb,
.sc-hero .sc-breadcrumb a{
  color: rgba(255,255,255,.85) !important;
}

/* meta 标签美化 */
.sc-meta{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 16px;
}
.sc-meta-item{
  background: rgba(255,255,255,.18);
  color: #fff;
  padding: 5px 12px;
  border-radius: 12px;
  font-size: 12.5px;
  border: 1px solid rgba(255,255,255,.22);
}

/* CTA 按钮 */
.sc-cta{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}
.sc-btn-primary{
  background: #fff;
  color: #1565C0 !important;
  padding: 10px 22px;
  border-radius: 22px;
  font-size: 14px;
  font-weight: 700;
  box-shadow: 0 4px 14px rgba(0,0,0,.12);
  text-decoration: none !important;
}
.sc-btn-primary:hover{
  transform: translateY(-1px);
  box-shadow: 0 8px 20px rgba(0,0,0,.18);
}
.sc-btn-secondary{
  background: rgba(255,255,255,.16);
  color: #fff !important;
  padding: 10px 22px;
  border: 1px solid rgba(255,255,255,.4);
  border-radius: 22px;
  font-size: 14px;
  font-weight: 600;
  text-decoration: none !important;
}
.sc-btn-secondary:hover{
  background: rgba(255,255,255,.26);
}

/* notice / 合规提示 */
.sc-notice{
  background: #fef3c7;
  border-left: 4px solid #f59e0b;
  padding: 12px 16px;
  border-radius: 6px;
  margin: 18px 0;
  display: flex;
  gap: 10px;
  align-items: flex-start;
}
.sc-notice-ic{
  flex-shrink: 0;
  font-size: 18px;
}
.sc-notice-body{
  font-size: 13px;
  color: #92400e;
  line-height: 1.6;
}

/* 节标题 · 蓝条左侧 */
.sc-section{
  margin-bottom: 36px;
}
.sc-h2{
  font-size: 22px;
  font-weight: 800;
  color: #0f172a;
  margin-bottom: 20px;
  padding-left: 14px;
  border-left: 5px solid #1565C0;
  line-height: 1.2;
}

/* dc-info-grid · 信息卡片 */
.dc-info-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 14px;
  margin-bottom: 28px;
}
.dc-info-card{
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  padding: 16px 18px;
  box-shadow: 0 1px 3px rgba(0,0,0,.04);
  transition: all .2s;
}
.dc-info-card:hover{
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0,0,0,.08);
  border-color: #1565C0;
}
.dc-info-label{
  font-size: 11.5px;
  color: #64748b;
  margin-bottom: 6px;
  text-transform: uppercase;
  letter-spacing: 1px;
}
.dc-info-value{
  font-size: 15px;
  color: #0f172a;
  font-weight: 700;
  line-height: 1.4;
}

/* FAQ 区 */
.sc-faq-list{
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 16px;
}
.sc-faq-item{
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  padding: 16px 20px;
  box-shadow: 0 1px 3px rgba(0,0,0,.03);
  transition: all .2s;
}
.sc-faq-item:hover{
  border-color: #1565C0;
  box-shadow: 0 2px 8px rgba(21,101,192,.08);
}
.sc-faq-q{
  font-size: 15px;
  font-weight: 700;
  color: #0f172a;
  margin-bottom: 8px;
  display: flex;
  align-items: flex-start;
  gap: 8px;
}
.sc-faq-q::before{
  content: "Q";
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  background: #1565C0;
  color: #fff;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 800;
}
.sc-faq-a{
  font-size: 13.5px;
  color: #475569;
  line-height: 1.7;
  padding-left: 30px;
}

/* 相关推荐 */
.sc-related-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px;
}
.sc-related-card{
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  padding: 16px 18px;
  text-decoration: none;
  display: block;
  transition: all .2s;
}
.sc-related-card:hover{
  border-color: #1565C0;
  box-shadow: 0 4px 14px rgba(21,101,192,.1);
  transform: translateY(-2px);
}
.sc-rel-label{
  font-size: 11px;
  color: #1565C0;
  font-weight: 700;
  margin-bottom: 6px;
  text-transform: uppercase;
}
.sc-rel-title{
  font-size: 15px;
  color: #0f172a;
  font-weight: 700;
  margin-bottom: 6px;
  line-height: 1.4;
}
.sc-rel-desc{
  font-size: 12.5px;
  color: #64748b;
  line-height: 1.5;
}

/* 合规尾 */
.sc-compliance{
  background: #f8fafc;
  border-top: 1px solid #e2e8f0;
  padding: 18px 24px;
  font-size: 12px;
  color: #94a3b8;
  line-height: 1.7;
  border-radius: 8px;
  margin-top: 32px;
}

/* 移动端 */
@media (max-width: 768px){
  .sc-hero.dc-hero{
    padding: 22px 0 26px;
  }
  .sc-hero.dc-hero .sc-h1{
    font-size: 22px;
  }
  .sc-h2{
    font-size: 19px;
  }
  .sc-wrap{
    padding: 0 16px;
  }
  .dc-info-grid{
    grid-template-columns: 1fr 1fr;
  }
}

/* 2026-04-29 · 相关推荐卡片真布局 */
.sc-related-grid{
  display:grid !important;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr)) !important;
  gap:14px !important;
}
.sc-related-card{
  display:flex !important;
  flex-direction:column !important;
  gap:6px !important;
  padding:18px 20px !important;
  background:#fff !important;
  border:1px solid #e2e8f0 !important;
  border-radius:10px !important;
  text-decoration:none !important;
  transition:all .2s !important;
  text-align:left !important;
}
.sc-related-card:hover{
  border-color:#1565C0 !important;
  box-shadow:0 4px 14px rgba(21,101,192,.12) !important;
  transform:translateY(-2px) !important;
}
.sc-rel-label{
  font-size:11px !important;
  color:#1565C0 !important;
  font-weight:700 !important;
  text-transform:uppercase !important;
  letter-spacing:1px !important;
  margin:0 !important;
  display:inline-block !important;
}
.sc-rel-title{
  font-size:15.5px !important;
  color:#0f172a !important;
  font-weight:700 !important;
  line-height:1.4 !important;
  margin:0 !important;
}
.sc-rel-desc{
  font-size:12.5px !important;
  color:#64748b !important;
  line-height:1.6 !important;
  margin:0 !important;
}

/* hero meta 蓝条容器加大 · 让数字更醒目 */
.sc-meta{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:8px !important;
  margin:16px 0 !important;
}
.sc-meta-item{
  display:inline-flex !important;
  align-items:center !important;
  gap:6px !important;
  background:rgba(255,255,255,.18) !important;
  border:1px solid rgba(255,255,255,.28) !important;
  color:#fff !important;
  padding:6px 14px !important;
  border-radius:14px !important;
  font-size:13px !important;
  font-weight:600 !important;
}
.sc-meta-item .sc-ic{
  width:14px !important;
  height:14px !important;
  flex-shrink:0 !important;
}
