/* ================================================================
   wanhedna · 全局修复补丁 · 2026-04-23
   放在最后加载 · 样式优先级最高 · 覆盖现有规则
   ================================================================ */

/* ── TP0-B · 医院卡片标题 · 单行省略号 · 全局 ───────────────── */
.sc-hosp-name,
.hosp-name {
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
  min-width: 0;
}
.sc-hosp-card .sc-hosp-head,
.sc-hosp-card > *,
.hosp-card > * {
  min-width: 0;
}

/* ── TP0-E · Footer 深渐变 + 金色分隔 ─────────── */
footer {
  background: linear-gradient(180deg, #0F172A 0%, #0B1220 50%, #070A15 100%) !important;
  position: relative;
  overflow: hidden;
}
footer::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(96,165,250,0.45), rgba(232,180,120,0.35), rgba(96,165,250,0.45), transparent);
  pointer-events: none;
}
footer::after {
  content: "";
  position: absolute;
  top: -120px; right: -120px;
  width: 480px; height: 480px;
  background: radial-gradient(circle, rgba(96,165,250,0.06) 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}
footer > * {
  position: relative;
  z-index: 1;
}
.foot-grid {
  border-bottom: 1px solid rgba(232,180,120,0.08) !important;
  padding-bottom: 36px !important;
}
.foot-certs {
  border-bottom: 1px solid rgba(232,180,120,0.08) !important;
  padding: 20px 0 !important;
  gap: 22px !important;
}
.foot-certs .cert {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  font-size: 11.5px;
  color: rgba(255,255,255,0.72);
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(232,180,120,0.14);
  border-radius: 20px;
  transition: all 0.25s;
}
.foot-certs .cert:hover {
  background: rgba(232,180,120,0.06);
  border-color: rgba(232,180,120,0.28);
  color: rgba(255,255,255,0.95);
}
.foot-certs .cert svg {
  width: 13px; height: 13px;
  color: rgba(232,180,120,0.65);
}
.foot-btm {
  padding-top: 22px !important;
  color: rgba(255,255,255,0.42);
}
.foot-btm a { color: rgba(255,255,255,0.65) !important; transition: color 0.2s; }
.foot-btm a:hover { color: rgba(232,180,120,0.9) !important; }
.foot-compliance {
  border-left: 2px solid rgba(232,180,120,0.55) !important;
  background: rgba(255,255,255,0.02) !important;
  color: rgba(255,255,255,0.6) !important;
}

/* ── TP0-F · 首单立减浮窗隐藏 ─────────── */
.sticky-cta,
.hero-form-tag {
  display: none !important;
}

/* ================================================================
   TP0-G · 右下浮动按钮美化
   ================================================================ */
.float-side-v2 {
  position: fixed !important;
  right: 18px !important;
  bottom: 32px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  z-index: 60 !important;
}
.float-side-v2 .float-btn {
  position: relative;
  width: 54px; height: 54px;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 2px;
  padding: 0;
  color: #1e293b;
  font-size: 10.5px; font-family: inherit; font-weight: 500;
  letter-spacing: 0.3px; line-height: 1.1;
  text-align: center; text-decoration: none;
  cursor: pointer;
  border: 1px solid rgba(255,255,255,0.7);
  border-radius: 14px;
  background: rgba(255,255,255,0.78);
  backdrop-filter: blur(12px) saturate(140%);
  -webkit-backdrop-filter: blur(12px) saturate(140%);
  box-shadow:
    0 4px 12px rgba(15,23,42,0.06),
    0 1px 3px rgba(15,23,42,0.04),
    inset 0 1px 0 rgba(255,255,255,0.8);
  transition: transform .25s cubic-bezier(.34,1.56,.64,1), box-shadow .25s, background .25s;
}
.float-side-v2 .float-btn:hover {
  transform: translateX(-4px) scale(1.04);
  box-shadow: 0 10px 24px rgba(15,23,42,0.14), 0 2px 6px rgba(15,23,42,0.08);
}
.float-side-v2 .fb-icon { display: inline-flex; align-items: center; justify-content: center; width: 20px; height: 20px; }
.float-side-v2 .fb-icon svg { width: 18px; height: 18px; display: block; }
.float-side-v2 .fb-lbl { font-size: 10px; opacity: .85; }

.float-side-v2 .fb-phone {
  background: linear-gradient(135deg, #1677FF 0%, #7C3AED 100%) !important;
  border-color: transparent !important; color: #fff !important;
  box-shadow: 0 6px 20px rgba(118,88,234,0.35), 0 2px 6px rgba(22,119,255,0.22);
}
.float-side-v2 .fb-phone:hover {
  background: linear-gradient(135deg, #2563EB 0%, #8B5CF6 100%) !important;
  box-shadow: 0 12px 28px rgba(118,88,234,0.48), 0 4px 12px rgba(22,119,255,0.3);
}
.float-side-v2 .fb-phone .fb-icon svg {
  animation: fbPhoneRing 2.6s ease-in-out infinite;
  transform-origin: 50% 40%;
}
@keyframes fbPhoneRing {
  0%, 58%, 100% { transform: rotate(0); }
  62% { transform: rotate(-18deg); }
  66% { transform: rotate(16deg); }
  70% { transform: rotate(-14deg); }
  74% { transform: rotate(10deg); }
  78% { transform: rotate(-6deg); }
  82% { transform: rotate(0); }
}
.float-side-v2 .fb-phone .fb-ring {
  position: absolute; inset: -4px;
  border-radius: 16px;
  border: 2px solid rgba(124,58,237,0.55);
  opacity: 0; pointer-events: none;
  animation: fbRingPulse 2.2s ease-out infinite;
}
@keyframes fbRingPulse {
  0% { transform: scale(.95); opacity: .65; }
  70% { transform: scale(1.22); opacity: 0; }
  100% { transform: scale(1.22); opacity: 0; }
}

.float-side-v2 .fb-chat {
  background: linear-gradient(135deg, #10B981 0%, #059669 100%) !important;
  border-color: transparent !important; color: #fff !important;
  box-shadow: 0 6px 18px rgba(16,185,129,0.3), 0 2px 5px rgba(5,150,105,0.2);
}
.float-side-v2 .fb-chat:hover {
  background: linear-gradient(135deg, #059669 0%, #047857 100%) !important;
  box-shadow: 0 12px 26px rgba(16,185,129,0.42), 0 4px 10px rgba(5,150,105,0.28);
}
.float-side-v2 .fb-chat .fb-icon svg { animation: fbChatBob 2.2s ease-in-out infinite; }
@keyframes fbChatBob {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-2.5px); }
}
.float-side-v2 .fb-chat .fb-dot {
  position: absolute; top: 8px; right: 10px;
  width: 8px; height: 8px;
  background: #EF4444; border: 2px solid #fff;
  border-radius: 50%;
  animation: fbDotPulse 1.8s ease-in-out infinite;
}
@keyframes fbDotPulse {
  0%, 100% { transform: scale(1); box-shadow: 0 0 0 0 rgba(239,68,68,0.6); }
  50% { transform: scale(1.12); box-shadow: 0 0 0 5px rgba(239,68,68,0); }
}

.float-side-v2 .fb-qr {
  background: rgba(255,255,255,0.82) !important;
  color: #1e293b !important;
}
.float-side-v2 .fb-qr .fb-icon-qr {
  position: relative; overflow: hidden;
  display: inline-flex; align-items: center; justify-content: center;
}
.float-side-v2 .fb-qr .fb-scan {
  position: absolute;
  left: -2px; right: -2px; top: 0;
  height: 1.5px;
  background: linear-gradient(90deg, transparent, #1677FF, transparent);
  box-shadow: 0 0 8px rgba(22,119,255,0.6);
  animation: fbScan 2.2s linear infinite;
}
@keyframes fbScan {
  0% { top: 0; opacity: 0; }
  10% { opacity: 1; }
  85% { opacity: 1; }
  100% { top: 18px; opacity: 0; }
}

.float-side-v2 .fb-top {
  background: rgba(255,255,255,0.82) !important;
  color: #1e293b !important;
}
.float-side-v2 .fb-top .fb-icon svg { animation: fbTopBob 2s ease-in-out infinite; }
@keyframes fbTopBob {
  0%, 100% { transform: translateY(1px); opacity: .75; }
  50% { transform: translateY(-2px); opacity: 1; }
}
.float-side-v2 .fb-top:hover .fb-icon svg { animation-duration: 0.8s; color: #1677FF; }

.float-side-v2 .float-qr-pop { right: calc(100% + 14px); }

@media (max-width: 640px) {
  .float-side-v2 { right: 12px !important; bottom: 20px !important; gap: 8px !important; }
  .float-side-v2 .float-btn { width: 48px; height: 48px; }
  .float-side-v2 .fb-icon svg { width: 16px; height: 16px; }
  .float-side-v2 .fb-lbl { font-size: 9px; }
}


/* ================================================================
   TP0-I · 740 城市模块修复 · 产品页/疾病页/遗传病页全局生效
   修：SVG 无尺寸导致放大镜超大 · 搜索框崩版 · 城市 chip 无样式
   覆盖 class：.pr-cities · .pr-cities-search · .pr-cities-tabs · 
            .pr-tab · .pr-cities-list · .pr-prov-block · .pr-city-chip
   ================================================================ */

.pr-cities {
  max-width: 1200px;
  margin: 48px auto;
  padding: 36px 24px;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  box-shadow: 0 1px 3px rgba(15,23,42,0.04);
}

.pr-cities .pr-section-h2 {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 8px;
  font-size: 22px;
  font-weight: 800;
  color: #0f172a;
  line-height: 1.35;
}
.pr-cities .pr-section-h2 svg.ic {
  width: 22px !important;
  height: 22px !important;
  flex-shrink: 0;
  color: #DC2626;
}

.pr-cities .pr-section-sub {
  margin: 0 0 24px;
  font-size: 13.5px;
  line-height: 1.75;
  color: #64748b;
}

/* ── 搜索框 · 最大的 bug 来源（放大镜 SVG 撑满）────────── */
.pr-cities-search {
  position: relative;
  max-width: 520px;
  margin: 0 0 20px;
}
.pr-cities-search svg.ic {
  position: absolute !important;
  left: 14px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 18px !important;
  height: 18px !important;
  color: #94a3b8;
  pointer-events: none;
}
.pr-cities-search input {
  width: 100%;
  height: 44px;
  padding: 0 16px 0 44px;
  font-size: 14px;
  font-family: inherit;
  color: #0f172a;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  outline: none;
  transition: all .2s;
  box-sizing: border-box;
}
.pr-cities-search input:focus {
  border-color: #1677FF;
  background: #fff;
  box-shadow: 0 0 0 3px rgba(22,119,255,0.12);
}
.pr-cities-search input::placeholder {
  color: #94a3b8;
}

/* ── 七大区域 tab ──────────── */
.pr-cities-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 22px;
  padding-bottom: 18px;
  border-bottom: 1px solid #e2e8f0;
}
.pr-tab {
  display: inline-flex;
  align-items: center;
  padding: 7px 16px;
  font-size: 13px;
  font-family: inherit;
  font-weight: 600;
  color: #475569;
  background: #f1f5f9;
  border: 1px solid #e2e8f0;
  border-radius: 20px;
  cursor: pointer;
  transition: all .2s;
}
.pr-tab:hover {
  background: #e2e8f0;
  color: #1e293b;
}
.pr-tab.pr-tab-active,
.pr-tab-active {
  background: linear-gradient(135deg, #1677FF 0%, #7C3AED 100%);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 2px 8px rgba(22,119,255,0.28);
}

/* ── 省份块 ──────────── */
.pr-cities-list {
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.pr-prov-block {
  padding: 16px 18px;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
}

.pr-prov-h4 {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 12px;
  font-size: 14px;
  font-weight: 700;
  color: #0f172a;
}
.pr-prov-h4 svg.ic {
  width: 15px !important;
  height: 15px !important;
  color: #1565C0;
  flex-shrink: 0;
}
.pr-prov-count {
  margin-left: auto;
  padding: 2px 9px;
  font-size: 11px;
  font-weight: 600;
  color: #64748b;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
}

/* ── 城市 chip 网格 ──────────── */
.pr-city-chips {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(78px, 1fr));
  gap: 8px;
}

.pr-city-chip {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 3px;
  padding: 8px 10px;
  font-size: 13px;
  color: #334155;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  text-decoration: none;
  text-align: center;
  transition: all .2s;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.pr-city-chip:hover {
  background: linear-gradient(135deg, #1677FF 0%, #7C3AED 100%);
  color: #fff;
  border-color: transparent;
  transform: translateY(-1px);
  box-shadow: 0 4px 10px rgba(22,119,255,0.25);
}

.pr-city-chip .ic-check {
  width: 11px !important;
  height: 11px !important;
  color: #10B981;
  flex-shrink: 0;
}
.pr-city-chip:hover .ic-check {
  color: #fff;
}

/* ── 空状态 fallback ──────────── */
.pr-cities-empty {
  padding: 32px 20px;
  text-align: center;
  color: #64748b;
  font-size: 14px;
  line-height: 1.8;
}
.pr-cities-empty .pr-cities-link {
  color: #1565C0;
  font-weight: 600;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.pr-cities-empty .pr-cities-link svg {
  width: 14px !important;
  height: 14px !important;
}
.pr-cities-empty .tel-link {
  color: #DC2626;
  font-weight: 600;
}

/* ── 额外兜底 · 疾病页如果用了 .dc-cities-grid 同理保护 ── */
.dc-cities-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(78px, 1fr));
  gap: 8px;
}
.dc-city-chip {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 8px 10px;
  font-size: 13px;
  color: #334155;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  text-decoration: none;
  transition: all .2s;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dc-city-chip:hover {
  background: linear-gradient(135deg, #1677FF 0%, #7C3AED 100%);
  color: #fff;
  border-color: transparent;
  transform: translateY(-1px);
}

/* ── 最后兜底 · 任何 svg 没设尺寸 + 在 pr-cities 或 dc-cities 内 + 无 class  ── */
.pr-cities svg:not([width]):not([height]),
.dc-cities-section svg:not([width]):not([height]) {
  max-width: 24px;
  max-height: 24px;
}

/* ── 移动端 ── */
@media (max-width: 640px) {
  .pr-cities {
    margin: 24px 12px;
    padding: 24px 16px;
  }
  .pr-cities .pr-section-h2 { font-size: 18px; }
  .pr-city-chips,
  .dc-cities-grid {
    grid-template-columns: repeat(auto-fill, minmax(68px, 1fr));
    gap: 6px;
  }
  .pr-city-chip,
  .dc-city-chip { font-size: 12px; padding: 7px 6px; }
  .pr-tab { font-size: 12px; padding: 6px 12px; }
}
