/* ai-new.css — cnchuzhou.com 齿研社
   seed=9316（位置加权 Σ char[i]*(i+1)，domain="cnchuzhou.com"）
   PC 布局: T-A / HE3 / NA5 / H2 / D5 / N1 / S3 / P1 / Q3 / T5 / F5
   主题色：齿研社 teal（青绿）+ 海蓝辅色 */

/* ==============================
   主题色变量（自动从 logo 提取）
   ============================== */
:root {
  --color-primary:        #2C7A6F;
  --color-primary-dark:   #1E5A51;
  --color-primary-light:  #E6F2EF;
  --color-primary-accent: #6FB3A6;
  --color-accent:         #3C6E9C;
  --color-accent-dark:    #244763;
  --color-secondary:      #F2F8F6;
  --color-secondary-dark: #CFE3DE;
  --color-primary-rgb:        44, 122, 111;
  --color-primary-dark-rgb:   30, 90, 81;
  --color-primary-accent-rgb: 111, 179, 166;
  --color-primary-light-rgb:  230, 242, 239;
  --color-accent-rgb:         60, 110, 156;
  --color-bg:       #F2F8F6;
  --color-bg-white: #ffffff;
  --color-bg-light: #E0EFEB;
  --color-text-dark:    #14302B;
  --color-text-normal:  #2C4540;
  --color-text-light:   #5E7570;
  --color-text-lighter: #93A8A2;
  --color-text-white:   #DCEAE6;
  --color-border:       rgba(30, 90, 81, 0.20);
  --color-border-light: rgba(44, 122, 111, 0.16);
}

body { background: var(--color-bg); color: var(--color-text-normal); }

/* Tab 切换 / 占位（功能性，保留） */
.news-mode { display: none !important; }
.ind-xm-list.news-mode,
.ind-wd-list.news-mode,
.ind-rc-list.news-mode,
.ind-yh-list.news-mode,
.ind-doc-list.news-mode,
.ind-zx-list.news-mode,
.ind-hos-list.news-mode { display: none !important; }
.filter_img { filter: blur(15px) !important; }

/* 文本行数截断（供 camp1/camp2 元素使用） */
.camp1 { display: -webkit-box; -webkit-line-clamp: 1; -webkit-box-orient: vertical; overflow: hidden; }
.camp2 { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

/* ===== PC首页区块 BEGIN ===== */

/* ==============================
   HE3：Header — 分块卡片悬浮型
   浅灰底 + 3 张白色圆角卡片：品牌 / 搜索 / 电话+二维码
   ============================== */
body { padding-top: 0; }

.site-header {
  position: relative;
  z-index: 120;
  background: linear-gradient(180deg, #EEF6F3 0%, #E1EFEB 100%);
  padding: 18px 0 22px;
  border-bottom: 1px solid var(--color-border-light);
}
.site-header__wrap {
  max-width: 1240px;
  margin: 0 auto;
  box-sizing: border-box;
  display: grid;
  grid-template-columns: minmax(260px, auto) 1fr minmax(280px, auto);
  gap: 18px;
  align-items: stretch;
  justify-content: space-between;
  padding: 0 24px;
}
.site-header__card {
  background: #fff;
  border-radius: 14px;
  box-shadow: 0 4px 16px rgba(var(--color-primary-dark-rgb), 0.08);
  padding: 14px 18px;
  display: flex;
  align-items: center;
  gap: 14px;
  transition: transform .25s ease, box-shadow .25s ease;
}
.site-header__card:hover {
  transform: translateY(-3px);
  box-shadow: 0 10px 24px rgba(var(--color-primary-dark-rgb), 0.18);
}
.site-header__brand { text-decoration: none; }
.site-header__logo { display: block; height: 46px; width: auto; flex-shrink: 0; }
.site-header__brand-text { min-width: 0; }
.site-header__brand-name {
  font-size: 20px;
  font-weight: 800;
  color: var(--color-primary-dark);
  margin: 0;
  line-height: 1.1;
  letter-spacing: .04em;
}
.site-header__brand-slogan {
  font-size: 11px;
  color: var(--color-text-light);
  margin: 4px 0 0;
  letter-spacing: .1em;
  text-transform: uppercase;
}
.site-header__search { padding: 8px 8px 8px 18px; }
.site-header__input {
  flex: 1;
  border: none;
  outline: none;
  background: transparent;
  font-size: 14px;
  color: var(--color-text-dark);
  min-width: 0;
}
.site-header__input::placeholder { color: var(--color-text-lighter); }
.site-header__btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: none;
  background: linear-gradient(120deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
  color: #fff;
  padding: 10px 22px;
  border-radius: 10px;
  cursor: pointer;
  font-size: 14px;
  white-space: nowrap;
  transition: filter .2s;
}
.site-header__btn:hover { filter: brightness(1.08); }
.site-header__btn-icon { width: 16px; height: 16px; }
.site-header__info { position: relative; justify-content: space-between; }
.site-header__tel {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: var(--color-text-dark);
  border-left: 3px solid var(--color-primary);
  padding-left: 10px;
}
.site-header__tel-label { font-size: 11px; color: var(--color-text-light); letter-spacing: .12em; }
.site-header__tel-num {
  font-size: 20px;
  font-weight: 800;
  color: var(--color-primary-dark);
  line-height: 1.1;
  margin-top: 2px;
  font-family: 'Arial', sans-serif;
}
.site-header__qr {
  position: relative;
  width: 46px;
  height: 46px;
  border-radius: 8px;
  overflow: hidden;
  cursor: pointer;
  border: 1px solid var(--color-border-light);
}
.site-header__qr-img { width: 100%; height: 100%; object-fit: cover; transition: transform .2s; }
.site-header__qr::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(var(--color-primary-dark-rgb), 0.4);
  opacity: 0;
  transition: opacity .25s;
  pointer-events: none;
}
.site-header__qr:hover::after { opacity: 1; }
.site-header__qr:hover .site-header__qr-img {
  position: fixed;
  top: 100px; right: 30px;
  width: 200px; height: 200px;
  z-index: 9999;
  box-shadow: 0 12px 32px rgba(0,0,0,.25);
  border-radius: 8px;
}

/* ==============================
   NA5：Nav — 毛玻璃透明
   半透明白底 + backdrop-filter 模糊，深色文字，滚动后加阴影
   ============================== */
.site-nav {
  position: sticky;
  top: 0;
  z-index: 110;
  background: rgba(255, 255, 255, 0.72);
  -webkit-backdrop-filter: blur(14px) saturate(180%);
  backdrop-filter: blur(14px) saturate(180%);
  border-bottom: 1px solid var(--color-border-light);
  transition: box-shadow .25s ease, background .25s ease;
}
.site-nav.scrolled {
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 4px 18px rgba(var(--color-primary-dark-rgb), 0.14);
}
.site-nav__shell { max-width: 1240px; margin: 0 auto; padding: 0 24px; }
.site-nav__list { display: flex; gap: 4px; justify-content: space-between; }
.site-nav__item a {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 14px 22px;
  color: var(--color-text-normal);
  text-decoration: none;
  font-size: 15px;
  font-weight: 600;
  position: relative;
  transition: color .2s;
}
.site-nav__item a::after {
  content: '';
  position: absolute;
  left: 18px; right: 18px; bottom: 8px;
  height: 3px;
  border-radius: 3px;
  background: var(--color-primary);
  transform: scaleX(0);
  transition: transform .25s ease;
}
.site-nav__item a:hover { color: var(--color-primary-dark); }
.site-nav__item a:hover::after { transform: scaleX(1); }
.site-nav__item.active a { color: var(--color-primary-dark); font-weight: 800; }
.site-nav__item.active a::after { transform: scaleX(1); }

/* ==============================
   T-A：板块标题 — 渐变色块横幅
   整块主色渐变背景 + 超大半透明英文背景字，白色标题/Tab/更多
   ============================== */
.container > section { margin-top: 36px; }
.sec-head {
  position: relative;
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 18px 28px;
  border-radius: 10px;
  background: linear-gradient(120deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
  overflow: hidden;
  margin-bottom: 22px;
}
.sec-head::before {
  content: attr(data-en);
  position: absolute;
  right: 18px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 76px;
  font-weight: 900;
  color: #fff;
  opacity: .08;
  letter-spacing: .1em;
  pointer-events: none;
  user-select: none;
  line-height: 1;
  text-transform: uppercase;
}
.sec-head__main {
  position: relative;
  z-index: 1;
  flex: 1;
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 22px;
  flex-wrap: wrap;
}
.sec-head__title-row { display: flex; align-items: center; gap: 12px; }
.sec-head__mark {
  width: 5px;
  height: 30px;
  border-radius: 3px;
  background: rgba(255,255,255,.65);
  flex-shrink: 0;
}
.sec-head__title-stack { min-width: 0; }
.sec-head__title {
  font-size: 22px;
  font-weight: 800;
  color: #fff;
  margin: 0;
  line-height: 1.2;
  display: flex;
  align-items: baseline;
  gap: 8px;
}
.sec-head__en {
  font-size: 11px;
  font-weight: 700;
  color: rgba(255,255,255,.7);
  letter-spacing: .14em;
  text-transform: uppercase;
}
.sec-head__desc { font-size: 12.5px; color: rgba(255,255,255,.78); margin: 4px 0 0; letter-spacing: .03em; }
.sec-head__tabs { display: inline-flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.sec-head__tabs .title {
  display: inline-flex;
  align-items: center;
  padding: 6px 16px;
  font-size: 13px;
  color: rgba(255,255,255,.85);
  border: 1px solid rgba(255,255,255,.45);
  border-radius: 18px;
  cursor: pointer;
  transition: all .2s;
  text-decoration: none;
}
.sec-head__tabs .title:hover { background: rgba(255,255,255,.16); color: #fff; }
.sec-head__tabs .title.current,
.sec-head__tabs .title.on {
  color: #fff;
  background: rgba(255,255,255,.22);
  border-color: #fff;
  font-weight: 700;
}
.sec-head__side { position: relative; z-index: 1; display: flex; align-items: center; }
.sec-head__more a {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: #fff;
  text-decoration: none;
  font-size: 13px;
  font-weight: 600;
  white-space: nowrap;
  border: 1px solid rgba(255,255,255,.5);
  padding: 5px 16px;
  border-radius: 20px;
  transition: background .2s, gap .2s;
}
.sec-head__more a:hover { background: rgba(255,255,255,.16); gap: 8px; }
.sec-head__more-ico { display: inline-block; transition: transform .2s; }
.sec-head__more a:hover .sec-head__more-ico { transform: translateX(2px); }

/* ==============================
   通用容器宽度
   ============================== */
.container { max-width: 1240px; margin: 0 auto; padding: 0 24px; box-sizing: border-box; }
.index-hos-con { margin-bottom: 40px; }
.index-hos-box { background: transparent; }
.ind-yh-list, .ind-doc-list, .ind-zx-list, .ind-hos-list,
.ind-xm-list, .ind-wd-list, .ind-rc-list { display: block; }

/* ==============================
   H2：医院 — 纯文字时间轴（图片作为圆形节点，所有字段保留）
   左主色竖线 + 圆形 Logo 节点；右：机构名 / 地址 / 科室标签 / 时间
   ============================== */
.hos-list {
  position: relative !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
  padding-left: 92px !important;
}
.hos-card {
  position: relative;
  display: flex !important;
  flex-direction: column;
  justify-content: center;
  gap: 6px;
  min-height: 96px;
  padding: 16px 0 16px 20px;
  border-bottom: 1px dashed var(--color-border-light);
  text-decoration: none;
  color: inherit;
  box-sizing: border-box;
}
.hos-card:last-child { border-bottom: none; }
.hos-card__media {
  position: absolute;
  left: -78px;
  top: 50%;
  transform: translateY(-50%);
  width: 64px;
  height: 64px;
  min-width: 64px;
  border-radius: 50%;
  overflow: hidden;
  border: 3px solid #fff;
  box-shadow: 0 0 0 2px var(--color-primary), 0 4px 12px rgba(var(--color-primary-dark-rgb), .2);
  display: block;
  z-index: 2;
  transition: transform .25s ease;
}
.hos-card:hover .hos-card__media { transform: translateY(-50%) scale(1.06); }
.hos-card__img {
  position: absolute;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
}
.hos-card__view {
  position: absolute;
  left: 0; bottom: 0;
  width: 100%;
  text-align: center;
  background: rgba(var(--color-primary-dark-rgb), .82);
  color: #fff;
  font-size: 9px;
  padding: 1px 0;
  opacity: 0;
  transition: opacity .25s ease;
}
.hos-card:hover .hos-card__view { opacity: 1; }
.hos-card__title {
  font-size: 17px;
  font-weight: 700;
  color: var(--color-text-dark);
  margin: 0;
  line-height: 1.4;
  transition: color .2s;
}
.hos-card:hover .hos-card__title { color: var(--color-primary-dark); }
.hos-card__info {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--color-text-light);
}
.hos-card__label {
  background: var(--color-primary-light);
  color: var(--color-primary-dark);
  padding: 2px 8px;
  border-radius: 3px;
  font-weight: 600;
  flex-shrink: 0;
}
.hos-card__text { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.hos-card__tags { display: flex; flex-wrap: wrap; gap: 6px; max-height: 24px; overflow: hidden; }
.hos-card__tag {
  display: inline-block;
  font-size: 11px;
  color: var(--color-primary-dark);
  background: var(--color-primary-light);
  padding: 3px 10px;
  border-radius: 12px;
  text-decoration: none;
  transition: background .2s, color .2s;
}
.hos-card__tag:hover { background: var(--color-primary); color: #fff; }
.hos-card__foot { font-size: 11px; color: var(--color-text-lighter); }

/* ==============================
   D5：医生 — 杂志大图错位（单列，奇偶左右交错）
   3:4 大头像 + 主色装饰条；姓名/职称/医院/简介/时间/立即预约 均保留
   ============================== */
.doc-list { display: flex !important; flex-direction: column !important; gap: 16px !important; }
.doc-card {
  position: relative;
  display: flex !important;
  flex-direction: row !important;
  gap: 0;
  background: #fff;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 2px 14px rgba(var(--color-primary-dark-rgb), .08);
  transition: transform .25s ease, box-shadow .25s ease;
  text-decoration: none;
  color: inherit;
}
.doc-card:nth-child(even) { flex-direction: row-reverse !important; }
.doc-card:hover { transform: translateY(-4px); box-shadow: 0 12px 28px rgba(var(--color-primary-dark-rgb), .16); }
.doc-card__avatar {
  position: relative;
  width: 190px;
  min-width: 190px;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  flex-shrink: 0;
}
.doc-card__img {
  position: absolute;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
  object-position: top;
  transition: transform .4s ease;
}
.doc-card:hover .doc-card__img { transform: scale(1.06); }
.doc-card__badge {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 2;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 6px;
  box-shadow: 0 3px 8px rgba(var(--color-primary-dark-rgb), .28);
}
.doc-card__body {
  flex: 1;
  min-width: 0;
  padding: 20px 26px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
}
.doc-card__body::before {
  content: '';
  position: absolute;
  top: 22px;
  left: 0;
  width: 4px;
  height: 26px;
  border-radius: 2px;
  background: var(--color-primary);
}
.doc-card:nth-child(even) .doc-card__body::before { left: auto; right: 0; }
.doc-card__head { display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap; margin: 0 0 8px; }
.doc-card__name { font-size: 19px; font-weight: 800; color: var(--color-text-dark); margin: 0; }
.doc-card__title {
  font-size: 12px;
  color: var(--color-primary-dark);
  background: var(--color-primary-light);
  padding: 2px 10px;
  border-radius: 12px;
  font-weight: 600;
}
.doc-card__hospital {
  font-size: 12.5px;
  color: var(--color-text-light);
  margin: 0;
  flex-basis: 100%;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.doc-card__hospital::before { content: '🏥'; font-size: 11px; opacity: .7; }
.doc-card__intro {
  font-size: 13px;
  color: var(--color-text-normal);
  margin: 0 0 12px;
  line-height: 1.6;
}
.doc-card__meta { font-size: 12px; color: var(--color-text-lighter); margin: 0 0 12px; }
.doc-card__btn {
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  font-size: 13px;
  color: #fff;
  background: linear-gradient(120deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
  padding: 7px 22px;
  border-radius: 20px;
  white-space: nowrap;
  box-shadow: 0 4px 12px rgba(var(--color-primary-dark-rgb), .25);
  transition: transform .2s, filter .2s;
}
.doc-card:hover .doc-card__btn { transform: translateY(-2px); filter: brightness(1.06); }

/* ==============================
   N1：资讯 — 头条横版 + 下方双列（首条大图，其余小缩略图双列）
   ============================== */
.news-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 16px !important;
}
.news-card {
  display: flex !important;
  flex-direction: row;
  gap: 12px;
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 2px 10px rgba(var(--color-primary-dark-rgb), .06);
  text-decoration: none;
  color: inherit;
  transition: transform .25s ease, box-shadow .25s ease;
}
.news-card:hover { transform: translateY(-4px); box-shadow: 0 12px 24px rgba(var(--color-primary-dark-rgb), .14); }
.news-card__media {
  position: relative;
  width: 116px;
  min-width: 116px;
  flex-shrink: 0;
  overflow: hidden;
}
.news-card__img {
  position: absolute;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
  transition: transform .35s ease;
}
.news-card:hover .news-card__img { transform: scale(1.06); }
.news-card__badge {
  position: absolute;
  top: 8px; left: 8px;
  font-size: 10px;
  color: #fff;
  background: var(--color-primary);
  padding: 2px 8px;
  border-radius: 4px;
  font-weight: 600;
}
.news-card__content { flex: 1; min-width: 0; padding: 12px 14px 12px 0; display: flex; flex-direction: column; }
.news-card__title { font-size: 14px; font-weight: 700; color: var(--color-text-dark); margin: 0 0 6px; line-height: 1.4; transition: color .2s; }
.news-card:hover .news-card__title { color: var(--color-primary-dark); }
.news-card__desc { font-size: 12px; color: var(--color-text-light); margin: 0 0 8px; line-height: 1.55; }
.news-card__bottom { margin-top: auto; display: flex; align-items: center; justify-content: space-between; gap: 12px; font-size: 11.5px; color: var(--color-text-lighter); }
.news-card__date { display: inline-flex; align-items: center; gap: 4px; }
.news-card__date::before { content: '🕐'; opacity: .7; }
.news-card__action { color: var(--color-primary); font-weight: 600; }
.news-card__action::after { content: ' →'; display: inline-block; transition: transform .2s; }
.news-card:hover .news-card__action::after { transform: translateX(3px); }
/* 首条头条：横版全宽大图 */
.news-grid .news-card:first-child {
  grid-column: 1 / -1 !important;
}
.news-grid .news-card:first-child .news-card__media {
  width: 46%;
  min-width: 46%;
  aspect-ratio: 16 / 9;
}
.news-grid .news-card:first-child .news-card__content { padding: 22px 26px; justify-content: center; }
.news-grid .news-card:first-child .news-card__title { font-size: 21px; -webkit-line-clamp: 2; }
.news-grid .news-card:first-child .news-card__desc { font-size: 13.5px; -webkit-line-clamp: 3; }

/* ==============================
   S3：分享 — 大引号纯文字卡（2列，缩略图作小圆头像保留）
   ============================== */
.share-list {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 16px !important;
}
.share-card {
  position: relative;
  display: flex !important;
  flex-direction: column;
  background: linear-gradient(135deg, #fff 0%, var(--color-secondary) 100%);
  border: 1px solid var(--color-border-light);
  border-radius: 16px;
  padding: 34px 22px 18px;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: transform .25s ease, box-shadow .25s ease;
}
.share-card:hover { transform: translateY(-4px); box-shadow: 0 12px 26px rgba(var(--color-primary-dark-rgb), .14); }
.share-card::before {
  content: '\201C';
  position: absolute;
  left: 14px;
  top: -6px;
  font-size: 90px;
  font-family: Georgia, serif;
  font-weight: 900;
  color: rgba(var(--color-primary-rgb), .18);
  line-height: 1;
  pointer-events: none;
}
.share-card__media {
  position: absolute;
  top: 18px; right: 18px;
  width: 46px; height: 46px;
  border-radius: 50%;
  overflow: hidden;
  border: 2px solid rgba(var(--color-primary-rgb), .25);
  z-index: 1;
}
.share-card__img { width: 100% !important; height: 100% !important; object-fit: cover; }
.share-card__overlay { display: none; }
.share-card__content { display: flex; flex-direction: column; flex: 1; }
.share-card__title { font-size: 15px; font-weight: 800; color: var(--color-text-dark); margin: 6px 0 8px; line-height: 1.4; padding-right: 54px; transition: color .2s; }
.share-card:hover .share-card__title { color: var(--color-primary-dark); }
.share-card__desc { font-size: 13px; color: var(--color-text-normal); line-height: 1.7; margin: 0 0 12px; }
.share-card__footer {
  margin-top: auto;
  padding-top: 10px;
  border-top: 1px dashed rgba(var(--color-primary-rgb), .2);
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 11px;
  color: var(--color-text-lighter);
}
.share-card__time { display: inline-flex; align-items: center; gap: 3px; }
.share-card__more { color: var(--color-primary); font-weight: 700; }
.share-card__arrow { display: inline-block; transition: transform .2s; }
.share-card:hover .share-card__arrow { transform: translateX(3px); }

/* ==============================
   P1：项目 — 3列竖版价签（图上文下 + 红色优惠价）
   ============================== */
.project-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 18px !important;
}
.project-card {
  position: relative;
  display: flex !important;
  flex-direction: column;
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 2px 12px rgba(var(--color-primary-dark-rgb), .07);
  text-decoration: none;
  color: inherit;
  transition: transform .25s ease, box-shadow .25s ease;
}
.project-card:hover { transform: translateY(-6px); box-shadow: 0 12px 28px rgba(var(--color-primary-dark-rgb), .16); }
.project-card__media { position: relative; width: 100%; aspect-ratio: 16 / 11; overflow: hidden; }
.project-card__img {
  position: absolute;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
  transition: transform .4s ease;
}
.project-card:hover .project-card__img { transform: scale(1.07); }
.project-card__body { padding: 14px 16px 16px; display: flex; flex-direction: column; gap: 8px; }
.project-card__title { font-size: 15px; font-weight: 700; color: var(--color-text-dark); margin: 0; line-height: 1.4; transition: color .2s; }
.project-card:hover .project-card__title { color: var(--color-primary-dark); }
.project-card__desc { font-size: 12px; color: var(--color-text-light); line-height: 1.55; margin: 0; }
.project-card__price {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 4px 6px;
  background: rgba(229, 57, 53, .06);
  border-radius: 8px;
  padding: 6px 10px;
}
.project-card__price-label { font-size: 12px; color: #E53935; font-weight: 600; }
.project-card__price-num { font-size: 22px; font-weight: 900; color: #E53935 !important; line-height: 1; }
.project-card__price-origin { font-size: 11px; color: #aaa; text-decoration: line-through; margin-left: 2px; }
.project-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 10px;
  border-top: 1px dashed var(--color-border-light);
  font-size: 11px;
  color: var(--color-text-lighter);
}
.project-card__meta { display: inline-flex; align-items: center; gap: 4px; }
.project-card__more { color: var(--color-primary); font-weight: 600; }
.project-card__more::after { content: ' →'; display: inline-block; transition: transform .2s; }
.project-card:hover .project-card__more::after { transform: translateX(3px); }

/* ==============================
   Q3：问答 — 大字背景装饰（单列，超大序号 + 问上答下）
   ============================== */
.qa-list { display: flex !important; flex-direction: column !important; gap: 14px !important; counter-reset: qa-idx; }
.qa-card {
  position: relative;
  display: block !important;
  background: linear-gradient(135deg, #fff 0%, var(--color-secondary) 100%);
  border: 1px solid var(--color-border-light);
  border-radius: 14px;
  padding: 20px 22px 18px 76px;
  overflow: hidden;
  counter-increment: qa-idx;
  text-decoration: none;
  color: inherit;
  transition: transform .2s ease, box-shadow .25s ease;
}
.qa-card:hover { transform: translateY(-3px); box-shadow: 0 10px 24px rgba(var(--color-primary-dark-rgb), .12); }
.qa-card::before {
  content: '0' counter(qa-idx);
  position: absolute;
  left: 8px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 56px;
  font-weight: 900;
  font-family: Georgia, serif;
  color: rgba(var(--color-primary-rgb), .16);
  letter-spacing: -.04em;
  line-height: 1;
  pointer-events: none;
}
.qa-card__icon {
  position: absolute;
  left: 22px;
  top: 20px;
  width: 30px;
  height: 30px;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
  color: #fff;
  border-radius: 8px;
  font-weight: 800;
  font-size: 15px;
  display: none;
  align-items: center;
  justify-content: center;
}
.qa-card__main { display: flex; flex-direction: column; gap: 8px; min-width: 0; }
.qa-card__header { display: flex; align-items: flex-start; justify-content: space-between; gap: 10px; }
.qa-card__question {
  font-size: 16px;
  font-weight: 800;
  color: var(--color-text-dark);
  margin: 0;
  line-height: 1.45;
  flex: 1;
  transition: color .2s;
}
.qa-card:hover .qa-card__question { color: var(--color-primary-dark); }
.qa-card__status {
  font-size: 11px;
  color: #fff;
  background: var(--color-primary);
  padding: 2px 10px;
  border-radius: 12px;
  font-weight: 700;
  white-space: nowrap;
  flex-shrink: 0;
  margin-top: 2px;
}
.qa-card__answer {
  font-size: 13px;
  color: var(--color-text-light);
  line-height: 1.7;
  margin: 0;
  padding: 8px 0 0;
  border-top: 1px dashed rgba(var(--color-primary-rgb), .2);
  position: relative;
  padding-left: 22px;
}
.qa-card__answer::before {
  content: 'A';
  position: absolute;
  left: 0; top: 9px;
  width: 16px; height: 16px;
  background: rgba(var(--color-primary-rgb), .14);
  color: var(--color-primary-dark);
  border-radius: 4px;
  font-size: 11px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
}
.qa-card__footer { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-top: 4px; font-size: 11px; color: var(--color-text-lighter); }
.qa-card__meta { display: inline-flex; align-items: center; gap: 4px; }
.qa-card__time { display: inline-flex; align-items: center; gap: 3px; }
.qa-card__action { color: var(--color-primary); font-weight: 600; transition: gap .2s; }
.qa-card:hover .qa-card__action { color: var(--color-primary-dark); }

/* ==============================
   T1：热词 — 胶囊标签云（flex-wrap 自由排列，# 前缀，首位/二三位高亮）
   ============================== */
.ind-rc-list { padding: 4px 0 8px; }
.hot-grid {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
}
.hot-chip {
  display: inline-flex !important;
  align-items: center;
  padding: 8px 18px !important;
  background: #fff !important;
  border: 1px solid var(--color-border-light) !important;
  color: var(--color-text-normal) !important;
  border-radius: 999px !important;
  width: auto !important;
  white-space: nowrap;
  text-decoration: none;
  font-weight: 500;
  box-shadow: 0 1px 4px rgba(var(--color-primary-dark-rgb), .05);
  transition: all .2s ease;
}
.hot-chip::before { content: '#'; color: var(--color-primary); margin-right: 4px; font-weight: 900; transition: color .2s; }
.hot-chip__body { display: inline-flex; align-items: baseline; gap: 6px; min-width: 0; }
.hot-chip__label { margin: 0; font-size: 13.5px; font-weight: 600; color: inherit; }
.hot-chip__time { font-size: 11px; color: var(--color-text-lighter); transition: color .2s; }
.hot-chip:hover {
  background: var(--color-primary) !important;
  color: #fff !important;
  border-color: var(--color-primary) !important;
  transform: translateY(-2px);
  box-shadow: 0 6px 14px rgba(var(--color-primary-dark-rgb), .22);
}
.hot-chip:hover::before, .hot-chip:hover .hot-chip__time { color: rgba(255,255,255,.85); }
/* 第 1 名渐变高亮 */
.hot-chip:nth-child(1) {
  background: linear-gradient(120deg, var(--color-primary) 0%, var(--color-primary-dark) 100%) !important;
  color: #fff !important;
  border-color: transparent !important;
  font-weight: 700;
}
.hot-chip:nth-child(1)::before,
.hot-chip:nth-child(1) .hot-chip__time { color: rgba(255,255,255,.85); }
/* 2-3 名浅主色底高亮 */
.hot-chip:nth-child(2),
.hot-chip:nth-child(3) {
  background: var(--color-primary-light) !important;
  color: var(--color-primary-dark) !important;
  border-color: var(--color-primary-accent) !important;
  font-weight: 600;
}

/* ==============================
   F5：Footer — 图片背景虚化（深色磨砂 + 毛玻璃内容卡）
   ============================== */
#footer {
  position: relative;
  margin-top: 56px;
  background:
    radial-gradient(circle at 18% 20%, rgba(var(--color-primary-rgb), .55) 0%, transparent 55%),
    radial-gradient(circle at 85% 80%, rgba(var(--color-accent-rgb), .5) 0%, transparent 55%),
    linear-gradient(135deg, #0E2C27 0%, #12352E 55%, #0C2723 100%);
  color: rgba(255,255,255,.82) !important;
  overflow: hidden;
}
#footer::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(8, 24, 21, .35);
  -webkit-backdrop-filter: blur(2px);
  backdrop-filter: blur(2px);
  pointer-events: none;
}
#footer .containers {
  position: relative;
  z-index: 1;
  display: grid !important;
  grid-template-columns: 200px 1fr 120px !important;
  gap: 36px !important;
  align-items: center;
  padding: 40px 24px 32px !important;
  max-width: 1240px;
  margin: 0 auto;
  box-sizing: border-box;
}
#footer .logo { height: 52px; width: auto; filter: brightness(0) invert(1); }
#footer .footer-copyright-con {
  text-align: center;
  font-size: 13px;
  line-height: 1.9;
  color: rgba(255,255,255,.78);
  padding: 6px 24px;
  border-left: 1px solid rgba(255,255,255,.14);
  border-right: 1px solid rgba(255,255,255,.14);
}
#footer .footer-copyright-con p { margin: 3px 0; }
#footer .footer-copyright-con .beizhu { font-size: 12px; color: rgba(255,255,255,.6); }
#footer a { color: var(--color-primary-accent); text-decoration: none; transition: color .2s; }
#footer a:hover { color: #fff; }
#footer .code {
  width: 100px; height: 100px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.2);
  padding: 5px;
  background: rgba(255,255,255,.95);
  box-shadow: 0 8px 22px rgba(0,0,0,.25);
  transition: transform .25s ease;
}
#footer .code:hover { transform: translateY(-4px); }
#footer .footer-bottom {
  position: relative;
  z-index: 1;
  background: rgba(0,0,0,.28);
  text-align: center;
  font-size: 12px;
  padding: 13px 24px;
  color: rgba(255,255,255,.7);
  letter-spacing: .05em;
}

/* ==============================
   首页响应式（≤960px）
   ============================== */
@media (max-width: 960px) {
  .site-header__wrap { grid-template-columns: 1fr; gap: 12px; }
  .site-header__info { justify-content: flex-start; }
  .site-nav__list { flex-wrap: wrap; }

  .sec-head { flex-direction: column; align-items: flex-start; gap: 12px; }
  .sec-head::before { font-size: 54px; }

  .doc-card, .doc-card:nth-child(even) { flex-direction: column !important; }
  .doc-card__avatar { width: 100%; min-width: 0; aspect-ratio: 16 / 9; }
  .doc-card__body::before { display: none; }

  .news-grid { grid-template-columns: 1fr !important; }
  .news-grid .news-card:first-child { flex-direction: column; }
  .news-grid .news-card:first-child .news-card__media { width: 100%; min-width: 0; }

  .share-list { grid-template-columns: 1fr !important; }
  .project-grid { grid-template-columns: repeat(2, minmax(0,1fr)) !important; }

  #footer .containers { grid-template-columns: 1fr !important; text-align: center; gap: 20px !important; }
  #footer .logo, #footer .code { margin: 0 auto; }
  #footer .footer-copyright-con { border-left: none; border-right: none; }
}
@media (max-width: 600px) {
  .project-grid { grid-template-columns: 1fr !important; }
  .hos-list { padding-left: 72px !important; }
  .hos-list::before { left: 26px; }
  .hos-card__media { left: -60px; width: 50px; height: 50px; min-width: 50px; }
}

/* ===== PC首页区块 END ===== */

/* ===== 列表页 / 详情页样式（非首页，保留不动） ===== */
.regional-filter,
.regionalFiltering {
  background: #fff;
  border-radius: 10px;
  box-shadow: 0 2px 12px rgba(19, 74, 153, 0.06);
  padding: 4px 18px;
  margin: 18px 0;
  border: 1px solid var(--color-border-light);
}
.regional-filter__row,
.regionalFilteringBox {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 12px 0;
  border-bottom: 1px dashed var(--color-border-light);
}
.regional-filter__row:last-child,
.regionalFilteringBox:last-child {
  border-bottom: none;
}
.regional-filter__label,
.regionalFilteringLeft {
  flex-shrink: 0;
  width: 56px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px 0;
}
.regional-filter__label-text,
.regionalFilteringLeft > span {
  display: inline-block;
  font-size: 13px;
  font-weight: 700;
  color: var(--color-primary-dark);
  background: var(--color-primary-light);
  padding: 4px 12px;
  border-radius: 14px;
  letter-spacing: .04em;
  line-height: 1.4;
}
.regional-filter__options,
.regionalFilteringRight {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 6px 8px;
  padding: 2px 0;
}
.regional-filter__link,
.regional-filter__options a,
.regionalFilteringRight a {
  display: inline-flex;
  align-items: center;
  padding: 4px 14px;
  font-size: 13px;
  color: var(--color-text-normal);
  text-decoration: none;
  border-radius: 14px;
  white-space: nowrap;
  line-height: 1.6;
  transition: background .2s, color .2s, transform .2s;
}
.regional-filter__link:hover,
.regional-filter__options a:hover,
.regionalFilteringRight a:hover {
  color: var(--color-primary-dark);
  background: var(--color-primary-light);
}
.regional-filter__link.cursorActive,
.regional-filter__options a.cursorActive,
.regionalFilteringRight a.cursorActive {
  color: #fff;
  background: linear-gradient(120deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
  font-weight: 600;
  box-shadow: 0 3px 10px rgba(19, 74, 153, 0.22);
}
.regional-filter__link.cursorActive:hover,
.regional-filter__options a.cursorActive:hover,
.regionalFilteringRight a.cursorActive:hover {
  filter: brightness(1.06);
  color: #fff;
  background: linear-gradient(120deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
}

/* ==============================
   .hospital-tabs — 列表页标题条 + 在线咨询按钮
   结构：.hospital-tabs > .hospital-tab-item--title (.badge + .text)
                      + button.hospital-tab-item--consult
   ============================== */
.hospital-tabs,
.yy-list-tabs {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  background: #fff;
  border-radius: 10px;
  padding: 14px 20px;
  margin: 18px 0;
  box-shadow: 0 2px 12px rgba(19, 74, 153, 0.06);
  border-left: 4px solid var(--color-primary);
  width: 100%;
  box-sizing: border-box;
}
.hospital-tab-item--title {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex: 1;
  min-width: 0;
}
.hospital-tab-item__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  padding: 4px 12px;
  border-radius: 6px;
  letter-spacing: .08em;
  box-shadow: 0 3px 8px rgba(19, 74, 153, 0.22);
  flex-shrink: 0;
  white-space: nowrap;
}
.hospital-tab-item__text {
  font-size: 16px;
  font-weight: 700;
  color: var(--color-text-dark);
  letter-spacing: .02em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.hospital-tab-item--consult {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: none;
  cursor: pointer;
  font-size: 13.5px;
  font-weight: 700;
  padding: 9px 22px;
  border-radius: 22px;
  color: #fff;
  background: linear-gradient(120deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
  box-shadow: 0 4px 14px rgba(19, 74, 153, 0.28);
  transition: transform .2s ease, box-shadow .2s ease, filter .2s;
  white-space: nowrap;
  position: relative;
  flex-shrink: 0;
}
.hospital-tab-item--consult::before {
  content: '💬';
  font-size: 14px;
  filter: grayscale(1) brightness(2);
}
.hospital-tab-item--consult:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(19, 74, 153, 0.38);
  filter: brightness(1.08);
}
.hospital-tab-item--consult:active {
  transform: translateY(0);
  box-shadow: 0 3px 8px rgba(19, 74, 153, 0.28);
}

/* ==============================
   .yycard — 医院/医生列表页卡片（list_hospital / list_doctor）
   ============================== */
.content_con {
  gap: 0;
}

.content_con .yycard.card_con,
.content_con .yycard.yylist_acrdcon {
  height: auto;
  min-height: 0;
  align-items: stretch;
  justify-content: flex-start;
  gap: 0;
  margin: 0 0 16px;
  padding: 0;
  border: none;
  border-bottom: none;
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 2px 12px rgba(19, 74, 153, 0.07);
  overflow: hidden;
  transition: transform .25s ease, box-shadow .25s ease;
}

.content_con .yycard:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 24px rgba(19, 74, 153, 0.14);
}

.content_con .yycard__media {
  flex: 0 0 200px;
  width: 200px;
  max-width: 200px;
  align-self: stretch;
  display: block;
  position: relative;
  overflow: hidden;
  background: var(--color-primary-light);
}

.content_con .yycard__img,
.content_con .yycard .card_img {
  width: 100% !important;
  height: 100% !important;
  min-height: 148px;
  max-height: none;
  object-fit: cover;
  filter: none !important;
  transition: transform .35s ease;
}

.content_con .yycard:hover .yycard__img {
  transform: scale(1.05);
}

.content_con .yycard__body,
.content_con .yycard .card_textcon {
  flex: 1;
  min-width: 0;
  width: auto;
  margin: 0;
  padding: 16px 18px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 10px;
}

.content_con .yycard__title-link {
  text-decoration: none;
}

.content_con .yycard__title,
.content_con .yycard .list_tit {
  margin: 0;
  font-size: 17px;
  font-weight: 700;
  line-height: 1.45;
  color: var(--color-text-dark);
  transition: color .2s ease;
}

.content_con .yycard:hover .yycard__title {
  color: var(--color-primary-dark);
}

.content_con .yycard__projects,
.content_con .yycard .xm_con {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  width: 100%;
}

.content_con .yycard__projects-label,
.content_con .yycard .xm_tex {
  flex-shrink: 0;
  font-size: 12px;
  font-weight: 600;
  color: var(--color-primary-dark);
  background: var(--color-primary-light);
  padding: 3px 10px;
  border-radius: 4px;
  line-height: 1.5;
  min-width: auto;
}

.content_con .yycard__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  flex: 1;
  min-width: 0;
  max-height: 52px;
  overflow: hidden;
}

.content_con .yycard__tag,
.content_con .yycard .xm_but {
  display: inline-block;
  max-width: 120px;
  padding: 3px 10px;
  font-size: 11px;
  line-height: 1.4;
  color: var(--color-primary-dark);
  background: #fff;
  border: 1px solid var(--color-border-light);
  border-radius: 12px;
  text-decoration: none;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: background .2s ease, color .2s ease, border-color .2s ease;
}

.content_con .yycard__tag:hover,
.content_con .yycard .xm_but:hover {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #fff;
}

.content_con .yycard__meta {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.content_con .yycard__meta-item {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 12.5px;
  line-height: 1.5;
  color: var(--color-text-light);
}

.content_con .yycard__meta-ico {
  flex-shrink: 0;
  width: 16px;
  height: 16px;
  margin-top: 2px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  opacity: .85;
}

.content_con .yycard__meta-ico--addr {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%232C7A6F'%3E%3Cpath d='M12 2C8.13 2 5 5.13 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.87-3.13-7-7-7zm0 9.5a2.5 2.5 0 1 1 0-5 2.5 2.5 0 0 1 0 5z'/%3E%3C/svg%3E");
}

.content_con .yycard__meta-ico--time {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%232C7A6F'%3E%3Cpath d='M11.99 2C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zM12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8zm.5-13H11v6l5.25 3.15.75-1.23-4.5-2.67z'/%3E%3C/svg%3E");
}

.content_con .yycard__meta-ico--intro {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%232C7A6F'%3E%3Cpath d='M14 2H6c-1.1 0-2 .9-2 2v16c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V8l-6-6zm2 16H8v-2h8v2zm0-4H8v-2h8v2zm-3-5V3.5L18.5 9H13z'/%3E%3C/svg%3E");
}

.content_con .yycard__meta-text {
  flex: 1;
  min-width: 0;
}

.content_con .yycard__meta-text--intro {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.content_con .yycard__actions,
.content_con .yycard .card_button {
  flex: 0 0 auto;
  width: auto;
  min-width: 108px;
  height: auto;
  margin: 0;
  padding: 16px 18px 16px 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 10px;
  box-sizing: border-box;
}

.content_con .yycard__actions .but_item {
  width: 100%;
  min-width: 96px;
  height: 38px;
  margin: 0;
  font-size: 13px;
  font-weight: 600;
  border-radius: 8px;
  cursor: pointer;
  transition: transform .2s ease, box-shadow .2s ease, filter .2s ease;
}

.content_con .yycard__actions .but_item--primary {
  border: none;
  color: #fff;
  background: linear-gradient(120deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
  box-shadow: 0 4px 12px rgba(19, 74, 153, 0.25);
}

.content_con .yycard__actions .but_item--primary:hover {
  transform: translateY(-1px);
  filter: brightness(1.06);
  box-shadow: 0 6px 16px rgba(19, 74, 153, 0.32);
}

.content_con .yycard__actions .but_item--outline,
.content_con .yycard__actions .but_yh {
  border: 1px solid var(--color-primary);
  background: #fff;
  color: var(--color-primary-dark);
}

.content_con .yycard__actions .but_item--outline:hover,
.content_con .yycard__actions .but_yh:hover {
  background: var(--color-primary-light);
  transform: translateY(-1px);
}

/* ==============================
   .aside-head — 列表页侧边栏栏目标题（推荐医生 / 热门资讯等）
   ============================== */
.aside_con {
  padding: 12px 14px 16px;
  gap: 0;
}

.aside_con .aside_titcon.aside-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin: 0;
  padding: 12px 14px;
  border-bottom: none;
  background: linear-gradient(90deg, var(--color-primary-light) 0%, #fff 72%);
  border-left: 4px solid var(--color-primary);
  border-radius: 8px;
  box-shadow: 0 1px 8px rgba(19, 74, 153, 0.06);
  font-size: inherit;
  font-weight: normal;
  color: inherit;
}

.aside_con .aside-head:not(:first-of-type) {
  margin-top: 14px;
}

.aside_con .aside-head__title,
.aside_con .aside_tit.aside-head__title {
  margin: 0;
  flex: 1;
  min-width: 0;
  font-size: 15px;
  font-weight: 700;
  color: var(--color-text-dark);
  letter-spacing: .02em;
  line-height: 1.35;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.aside_con .aside-head__more,
.aside_con a.aside_more.aside-head__more {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  flex-shrink: 0;
  padding: 5px 11px;
  font-size: 12px;
  font-weight: 600;
  line-height: 1;
  color: var(--color-primary-dark);
  background: #fff;
  border: 1px solid var(--color-border-light);
  border-radius: 16px;
  text-decoration: none;
  transition: color .2s ease, background .2s ease, border-color .2s ease, transform .2s ease, box-shadow .2s ease;
}

.aside_con .aside-head__more:hover,
.aside_con a.aside_more.aside-head__more:hover {
  color: #fff;
  background: linear-gradient(120deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
  border-color: transparent;
  box-shadow: 0 3px 10px rgba(19, 74, 153, 0.22);
  transform: translateY(-1px);
}

.aside_con .aside-head__more-ico {
  display: inline-block;
  font-size: 14px;
  line-height: 1;
  transition: transform .2s ease;
}

.aside_con .aside-head__more:hover .aside-head__more-ico {
  transform: translateX(2px);
}

.aside_con .aside-head + .card_con,
.aside_con .aside-head + a.card_rightcon {
  margin-top: 10px;
}



/* 空结果提示 */
.none_yy {
  background: linear-gradient(135deg, var(--color-primary-light) 0%, #fff 100%);
  border: 1px dashed var(--color-primary-accent);
  color: var(--color-primary-dark);
  font-size: 13.5px;
  font-weight: 600;
  text-align: center;
  padding: 14px 18px;
  margin: 14px 0;
  border-radius: 8px;
  position: relative;
}
.none_yy::before {
  content: 'ℹ️ ';
  margin-right: 4px;
}

/* ==============================
   响应式（≤960px）
   ============================== */
@media (max-width: 960px) {
  .site-header__wrap {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  .site-header__info { justify-content: flex-start; }
  .site-nav__list { flex-wrap: wrap; }

  .sec-head { flex-direction: column; }
  .sec-head::before {
    writing-mode: horizontal-tb;
    width: 100%;
    height: 30px;
    padding: 0;
  }
  .sec-head__main { padding: 14px 16px; }
  .sec-head__side { padding: 0 16px 14px; }

  .hos-list,
  .doc-list,
  .share-list { grid-template-columns: 1fr !important; }
  .hos-list .hos-card:first-child { flex-direction: column !important; }
  .hos-list .hos-card:first-child .hos-card__media { width: 100% !important; min-width: 0 !important; aspect-ratio: 16 / 10 !important; }
  .share-card:nth-child(1) { grid-column: span 1 !important; grid-row: span 1 !important; }

  .project-card,
  .project-card:nth-child(even) { flex-direction: column !important; }
  .project-card__media { width: 100%; min-width: 0; aspect-ratio: 16 / 10; }

  #footer .containers {
    grid-template-columns: 1fr !important;
    text-align: center;
  }
  #footer .logo,
  #footer .code { margin: 0 auto; }

  .regional-filter,
  .regionalFiltering { padding: 4px 12px; }
  .regional-filter__row,
  .regionalFilteringBox {
    flex-direction: column;
    gap: 8px;
    padding: 10px 0;
  }
  .regional-filter__label,
  .regionalFilteringLeft {
    width: auto;
    justify-content: flex-start;
    padding: 0;
  }

  .content_con .yycard.card_con,
  .content_con .yycard.yylist_acrdcon {
    flex-direction: column;
  }
  .content_con .yycard__media {
    flex: none;
    width: 100%;
    max-width: none;
    aspect-ratio: 16 / 10;
  }
  .content_con .yycard__img,
  .content_con .yycard .card_img {
    min-height: 0;
  }
  .content_con .yycard__actions,
  .content_con .yycard .card_button {
    flex-direction: row;
    width: 100%;
    min-width: 0;
    padding: 0 16px 16px;
    border-left: none;
    border-top: 1px solid var(--color-border-light);
  }
  .content_con .yycard__actions .but_item {
    flex: 1;
  }

  .page_con.page-nav {
    gap: 6px;
    padding: 14px 10px;
  }
  .page_con.page-nav a,
  .page_con.page-nav span {
    min-width: 34px;
    height: 34px;
    padding: 0 10px;
    font-size: 13px;
  }
  .page_con.page-nav a.a1 {
    padding: 0 12px;
    font-size: 12px;
  }
}
