/* 专业介绍详情：专业概览 / 编号区块 / 实训与获奖 Swiper 轮播 */

.zyss-detail-page .page-banner {
  height: 100vh;
  min-height: 100vh;
  max-height: 100vh;
  padding-top: 0;
  background: var(--theme-hero-visual-bg);
  overflow: hidden;
}

.zyss-detail-page .page-banner img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.min-w-0 {
  min-width: 0;
}

/* 专业详情页：主内容区最大宽度 1200px，并保留与视口的水平边距 */
.zyss-detail-page .page-sub__content.container {
  max-width: 1200px;
  --zyss-detail-side-extra: 1.35rem;
  padding-left: calc(var(--bs-gutter-x, 1.5rem) * 0.5 + var(--zyss-detail-side-extra));
  padding-right: calc(var(--bs-gutter-x, 1.5rem) * 0.5 + var(--zyss-detail-side-extra));
}

@media (min-width: 768px) {
  .zyss-detail-page .page-sub__content.container {
    --zyss-detail-side-extra: 2rem;
  }
}

@media (min-width: 1200px) {
  .zyss-detail-page .page-sub__content.container {
    --zyss-detail-side-extra: 3.25rem;
  }
}

/* 正文区与 school-overview、zyss/index 等一致：外层 .container 控制最大宽度 */

/* 左侧本页目录 + 右侧正文（lg 起双栏，正文占比收窄）
 * 桌面端侧栏列需与正文等高（stretch），内层 .page-sidenav 的 position:sticky 才能相对视口粘顶；
 * 若侧栏列为 flex-start 且高度仅等于导航高度，sticky 无滚动行程，表现为随页整体上移。 */
.zyss-detail__aside {
  align-self: stretch;
}

@media (max-width: 991.98px) {
  .zyss-detail__aside {
    order: -1;
  }
}

/* 专业详情：粘顶时略高于正文叠层；目录过长时在侧栏内滚动（sticky/top 见 inner.css .page-sidenav） */
@media (min-width: 992px) {
  .zyss-detail__aside .page-sidenav {
    z-index: 5;
    max-height: calc(100vh - 7rem);
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
}

/* 锚点跳转时避开 fixed 顶栏 */
#sec-overview,
#sec-objectives,
#sec-lab,
#sec-courses-certs,
#sec-employment,
#sec-courses,
#sec-awards {
  scroll-margin-top: 6rem;
}

@media (min-width: 992px) {
  #sec-overview,
  #sec-objectives,
  #sec-lab,
  #sec-courses-certs,
  #sec-employment,
  #sec-courses,
  #sec-awards {
    scroll-margin-top: 6.75rem;
  }
}

.zyss-detail {
  --zyss-detail-radius: 0.5rem;
  --zyss-detail-radius-lg: 0.65rem;
  padding-bottom: 0.25rem;
}

/* ========== 各板块统一：白底、边框、内边距、轻阴影 ========== */
.zyss-detail__block {
  margin-bottom: 1.15rem;
  padding: clamp(0.9rem, 2.2vw, 1.25rem);
  border-radius: var(--zyss-detail-radius-lg);
  background: var(--theme-body-bg);
  border: 1px solid var(--theme-border-light);
  box-shadow: 0 2px 14px rgba(0, 0, 0, 0.05);
}

/* ========== 专业概览：内层仅负责排版，卡片样式由 .zyss-detail__block ========== */
.zyss-detail__top-combo {
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  position: relative;
}

.zyss-detail__top-combo-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  align-items: start;
}

.zyss-detail__top-combo-main {
  min-width: 0;
}

.zyss-detail__top-combo-rule {
  height: 1px;
  background: color-mix(in srgb, var(--theme-primary) 28%, var(--theme-border-light));
  margin: 0.5rem 0 0.55rem;
  max-width: 5.5rem;
}

.zyss-detail__lead--on-hero {
  color: var(--theme-heading);
  font-weight: 600;
}

.zyss-detail__intro-extra {
  font-size: 0.875rem;
  line-height: 1.65;
  color: var(--theme-text-muted);
}

/* 专业名称：非 h1–h6，视觉与板块标题层级区分，与下方板块标题（h3）并列展示 */
.zyss-detail__overview-name {
  font-size: clamp(1.25rem, 2.8vw, 1.65rem);
  font-weight: 800;
  line-height: 1.22;
  color: var(--theme-heading);
  margin: 0 0 0.3rem;
}

.zyss-detail__hero-college {
  margin: 0;
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.4;
  color: var(--theme-text-muted);
}

/* 三块信息卡排在专业概览正文下方整行展示 */
.zyss-detail__hero-stats {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 0.5rem;
  width: 100%;
}

.zyss-detail__stat-card,
.zyss-detail__stat-card--wide {
  flex: 1 1 0;
  min-width: 7.5rem;
}

@media (max-width: 575.98px) {
  .zyss-detail__stat-card,
  .zyss-detail__stat-card--wide {
    flex: 1 1 100%;
    min-width: 0;
  }
}

.zyss-detail__stat-card {
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
  padding: 0.5rem 0.65rem;
  background: var(--theme-section-muted-bg);
  border: 1px solid var(--theme-border-light);
  border-radius: var(--zyss-detail-radius);
}

.zyss-detail__stat-card-icon {
  font-size: 1rem;
  margin-bottom: 0;
  color: var(--theme-primary);
}

.zyss-detail__stat-card-label {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  color: var(--theme-text-muted);
}

.zyss-detail__stat-card-value {
  font-size: 0.8125rem;
  font-weight: 700;
  line-height: 1.3;
  word-break: break-word;
  color: var(--theme-heading);
}

.zyss-detail__lead {
  font-size: 0.9375rem;
  color: var(--theme-heading);
  font-weight: 600;
  line-height: 1.55;
  margin-bottom: 0.45rem;
}

.zyss-detail__objectives-inner {
  max-width: 58rem;
}

.zyss-detail__objectives-text {
  font-size: 0.875rem;
  line-height: 1.65;
  color: var(--theme-text-muted);
}

.zyss-detail__section-lead {
  font-size: 0.875rem;
  line-height: 1.65;
  color: var(--theme-text-muted);
  max-width: 58rem;
}

/* ========== 板块标题（h3） ========== */
.zyss-detail__section-head {
  display: block;
  font-size: clamp(1rem, 1.9vw, 1.2rem);
  font-weight: 800;
  color: var(--theme-heading);
  margin: 0 0 0.65rem;
  line-height: 1.3;
}

.zyss-detail__section-head--light {
  color: #fff;
}

/* ========== 章节：间距由外层 .zyss-detail__block 承担 ========== */
.zyss-detail__section {
  margin-bottom: 0;
}

/* ========== 教学特色 / 就业：一深一浅双卡 ========== */
.zyss-detail__split-band {
  margin-bottom: 1.35rem;
}

.zyss-detail__accent-panel {
  height: 100%;
  padding: 0.9rem 1rem;
  border-radius: var(--zyss-detail-radius-lg);
  background: linear-gradient(160deg, var(--theme-primary-dark) 0%, var(--theme-primary) 55%, color-mix(in srgb, var(--theme-primary-light) 75%, var(--theme-primary)) 100%);
  color: #fff;
  box-shadow: 0 14px 36px rgba(var(--theme-primary-rgb), 0.28);
}

.zyss-detail__plain-panel {
  height: 100%;
  padding: 0.9rem 1rem;
  border-radius: var(--zyss-detail-radius-lg);
  background: var(--theme-body-bg);
  border: 1px solid var(--theme-border-light);
  box-shadow: 0 8px 26px rgba(0, 0, 0, 0.05);
}

.zyss-detail__panel-title {
  font-size: 0.95rem;
  font-weight: 800;
  margin: 0 0 0.45rem;
  padding-bottom: 0.35rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.22);
}

.zyss-detail__plain-panel .zyss-detail__panel-title {
  color: var(--theme-heading);
  border-bottom-color: color-mix(in srgb, var(--theme-primary) 22%, transparent);
}

.zyss-detail__accent-panel .zyss-detail__panel-title {
  color: #fff;
}

.zyss-detail__panel-text {
  font-size: 0.875rem;
  line-height: 1.65;
  opacity: 0.95;
}

.zyss-detail__plain-panel .zyss-detail__panel-text {
  color: var(--theme-text-muted);
  opacity: 1;
}

.zyss-detail__courses-section {
  margin-bottom: 0;
}

.zyss-detail__courses-text {
  font-size: 0.875rem;
  line-height: 1.75;
  color: var(--theme-text-muted);
  max-width: 58rem;
}

.zyss-detail__courses-text p {
  margin-bottom: 0.65rem;
}

.zyss-detail__courses-text p:last-child {
  margin-bottom: 0;
}

/* ========== 优秀学子：深色条带 ========== */
.zyss-detail__alumni-section {
  margin-bottom: 1.35rem;
  padding: 0.9rem 1rem;
  border-radius: var(--zyss-detail-radius-lg);
  background: linear-gradient(120deg, #1a2332 0%, color-mix(in srgb, var(--theme-primary-dark) 55%, #1a2332) 100%);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.15);
}

.zyss-detail__alumni-card {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem;
  margin-top: 0.1rem;
}

.zyss-detail__alumni-photo {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
  border: 3px solid rgba(255, 255, 255, 0.35);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.25);
}

.zyss-detail__alumni-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.zyss-detail__alumni-body {
  flex: 1;
  min-width: 200px;
}

.zyss-detail__alumni-name {
  font-weight: 800;
  font-size: 0.95rem;
  color: #fff;
  margin-bottom: 0.2rem;
}

.zyss-detail__alumni-text {
  font-size: 0.8125rem;
  line-height: 1.55;
  color: rgba(255, 255, 255, 0.82);
}

/* ========== 实训环境 / 获奖情况：共用 Swiper 轮播 ========== */
.zyss-detail__awards-section {
  margin-bottom: 0;
}

.zyss-detail__detail-carousel {
  --swiper-theme-color: #fff;
  --swiper-navigation-size: 1.1rem;
  border-radius: var(--zyss-detail-radius-lg);
  overflow: hidden;
  border: 1px solid var(--theme-border-light);
  box-shadow: 0 8px 26px rgba(0, 0, 0, 0.08);
}

/* 已包在 .zyss-detail__block 内时避免外框双线 */
.zyss-detail__block .zyss-detail__detail-carousel {
  border: none;
  box-shadow: none;
}

.zyss-detail__detail-carousel .swiper-slide {
  height: auto;
}

.zyss-detail__carousel-slide {
  position: relative;
  aspect-ratio: 21 / 9;
  min-height: 200px;
  background: var(--theme-section-muted-bg);
}

@media (max-width: 767.98px) {
  .zyss-detail__carousel-slide {
    aspect-ratio: 16 / 10;
    min-height: 180px;
  }
}

.zyss-detail__carousel-slide img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.zyss-detail__carousel-slide-scrim {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 48%;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.78), transparent);
  pointer-events: none;
  z-index: 1;
}

.zyss-detail__carousel-slide-cap {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 2;
  padding: 0.65rem 0.85rem 0.75rem;
  margin: 0;
  padding-right: 3.5rem;
  font-size: 0.8125rem;
  font-weight: 600;
  line-height: 1.5;
  color: #fff;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.45);
}

.zyss-detail__detail-carousel .swiper-button-prev,
.zyss-detail__detail-carousel .swiper-button-next {
  width: 2.35rem;
  height: 2.35rem;
  background: rgba(0, 0, 0, 0.38);
  border-radius: 50%;
  color: #fff;
  z-index: 3;
}

.zyss-detail__detail-carousel .swiper-button-prev::after,
.zyss-detail__detail-carousel .swiper-button-next::after {
  font-size: 0.78rem;
  font-weight: 700;
}

.zyss-detail__detail-carousel .swiper-button-prev:hover,
.zyss-detail__detail-carousel .swiper-button-next:hover {
  background: rgba(0, 0, 0, 0.5);
}

.zyss-detail__detail-carousel .swiper-pagination {
  bottom: 0.5rem !important;
  z-index: 3;
}

.zyss-detail__detail-carousel .swiper-pagination-bullet {
  background: #fff;
  opacity: 0.45;
}

.zyss-detail__detail-carousel .swiper-pagination-bullet-active {
  opacity: 1;
  background: #fff;
}
