/* Class change page styles */

body:not([data-class-change-page]) .guide-nav-shell {
  width: fit-content;
  max-width: 100%;
  grid-template-columns: minmax(11rem, 13rem) auto;
  margin: 0 auto;
}

body:not([data-class-change-page]) .layout--guide-nav .guide-main {
  width: fit-content;
  max-width: none;
}

#class-change-sections {
  display: grid;
  justify-items: start;
  gap: 1rem;
}

#class-change-sections > .village-card {
  width: fit-content;
  max-width: 100%;
}

.class-change-route {
  display: grid;
  gap: 0.45rem;
}

.class-change-route__title {
  margin: 0;
  color: var(--text);
  font-size: 1rem;
  font-weight: 800;
  line-height: 1.35;
}

.class-change-route__original {
  display: block;
  margin-top: 0.12rem;
  color: var(--text-muted);
  font-size: 0.84rem;
  font-weight: 600;
}

.class-change-links {
  display: grid;
  gap: 0.42rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.class-change-links li {
  margin: 0;
}

.class-change-links .quest-name-link {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.08rem;
}

.class-change-links .quest-name-link--featured {
  padding: 0.42rem 0.55rem;
  border: 1px solid rgba(51, 255, 167, 0.22);
  border-radius: 8px;
  background: rgba(51, 255, 167, 0.06);
}

.class-change-link-badge {
  display: inline-flex;
  align-items: center;
  min-height: 1.35rem;
  margin-bottom: 0.2rem;
  padding: 0 0.38rem;
  border-radius: 999px;
  background: rgba(51, 255, 167, 0.14);
  color: var(--accent);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.04em;
}

.class-change-links .quest-name-link .quest-original {
  margin-top: 0;
}

.class-change-cell--empty {
  color: var(--text-muted);
}

.class-change-cell--empty .class-change-route__title {
  color: var(--text-muted);
  font-weight: 700;
}

.class-change-brief {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin: 0;
}

.class-change-brief span {
  display: inline-flex;
  align-items: center;
  min-height: 1.75rem;
  padding: 0.12rem 0.55rem;
  border: 1px solid rgba(51, 255, 167, 0.18);
  border-radius: 999px;
  background: rgba(51, 255, 167, 0.07);
  color: var(--accent);
  font-size: 0.82rem;
  font-weight: 750;
}

.class-change-section-note {
  margin: 0;
  color: var(--text-muted);
  line-height: 1.65;
}

.class-change-table .quest-col-name,
.class-change-table .quest-col-start,
.class-change-table .quest-col-reward {
  width: 33.33%;
}

.class-change-table--overview .quest-col-name {
  width: 34%;
}

.class-change-table--overview .quest-col-start,
.class-change-table--overview .quest-col-reward {
  width: 22%;
}

.class-change-overview-route {
  display: grid;
  gap: 0.24rem;
}

.class-change-overview-route strong {
  font-size: 0.98rem;
  line-height: 1.4;
}

.class-change-phase {
  display: grid;
  gap: 0.45rem;
  align-items: start;
}

.class-change-phase strong {
  font-size: 0.98rem;
  line-height: 1.35;
}

.class-change-phase--empty strong {
  color: var(--text-muted);
}

.class-change-phase__badge {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 1.35rem;
  padding: 0 0.42rem;
  border-radius: 999px;
  background: rgba(51, 255, 167, 0.12);
  color: var(--accent);
  font-size: 0.72rem;
  font-weight: 800;
}

.class-change-phase__link {
  width: fit-content;
}

.class-tree-board {
  display: grid;
  width: fit-content;
  max-width: 100%;
  gap: 1rem;
  padding: 1rem 1.1rem 1.15rem;
}

.class-tree-group {
  overflow: hidden;
  border-top: 1px solid #323232;
}

.class-tree-group:first-child {
  border-top: 0;
}

.class-tree-group__head {
  padding: 0.9rem 0 0.8rem;
  border-bottom: 1px solid #343434;
}

.class-tree-group__head h3 {
  margin: 0;
  font-size: 1.08rem;
  line-height: 1.35;
}

.class-tree-group__head .quest-original {
  margin-top: 0.18rem;
}

.class-tree-subgroup + .class-tree-subgroup {
  border-top: 1px solid #303030;
}

.class-tree-layout {
  display: grid;
  grid-template-columns: minmax(10.5rem, 12rem) minmax(0, 1fr);
  gap: 0;
}

.class-tree-layout--no-root {
  grid-template-columns: minmax(0, 1fr);
}

.class-tree-root {
  display: flex;
  align-items: center;
  padding: 0.9rem 0.8rem 0.9rem 0;
  border-right: 1px solid #303030;
}

.class-tree-root .class-tree-node {
  width: 11rem;
}

.class-tree-branches {
  display: grid;
}

.class-tree-branch {
  display: grid;
  grid-template-columns: 1.35rem minmax(0, 1fr);
  align-items: center;
  min-height: 6.2rem;
  padding: 0.9rem 0;
  border-top: 1px solid #303030;
}

.class-tree-branch:first-child {
  border-top: 0;
}

.class-tree-layout--no-root .class-tree-branch {
  grid-template-columns: minmax(0, 1fr);
  padding-left: 0;
}

.class-tree-layout--no-root .class-tree-branch__joint {
  display: none;
}

.class-tree-branch__joint {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
}

.class-tree-branch__joint::before {
  content: "";
  position: absolute;
  left: 0.15rem;
  top: 50%;
  width: 0.82rem;
  border-top: 2px solid rgba(51, 255, 167, 0.28);
}

.class-tree-branch__joint::after {
  content: "";
  position: absolute;
  left: 0.15rem;
  top: 0;
  bottom: 0;
  border-left: 2px solid rgba(51, 255, 167, 0.18);
}

.class-tree-branch__joint--empty::before,
.class-tree-branch__joint--empty::after {
  display: none;
}

.class-tree-branch:first-child .class-tree-branch__joint::after {
  top: 50%;
}

.class-tree-branch:last-child .class-tree-branch__joint::after {
  bottom: 50%;
}

.class-tree-branch__line {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 0.45rem;
}

.class-tree-node {
  display: grid;
  align-content: center;
  width: 11rem;
  min-height: 5.9rem;
  padding: 0.65rem 0.72rem;
  border: 1px solid rgba(51, 255, 167, 0.16);
  border-radius: 10px;
  background: rgba(51, 255, 167, 0.05);
  color: var(--text);
  text-decoration: none;
}

.class-tree-node strong {
  font-size: 0.94rem;
  line-height: 1.3;
}

.class-tree-node:hover,
.class-tree-node:focus-visible {
  border-color: rgba(51, 255, 167, 0.3);
  background: rgba(51, 255, 167, 0.1);
  color: var(--accent);
}

.class-tree-node--empty:hover,
.class-tree-node--empty:focus-visible {
  color: var(--text);
}

.class-tree-node__original {
  margin-top: 0.18rem;
  color: var(--text-muted);
  font-size: 0.76rem;
  font-weight: 600;
}

.class-tree-arrow {
  display: inline-grid;
  place-items: center;
  align-self: center;
  color: var(--accent);
  font-size: 0.92rem;
  font-weight: 800;
}

.class-change-detail-list {
  display: grid;
  gap: 1rem;
  padding: 1rem 1.1rem 1.15rem;
}

.class-change-detail-card {
  padding: 1rem;
  border: 1px solid #3a3a3a;
  border-radius: 10px;
  background: linear-gradient(180deg, #262626, #212121);
  scroll-margin-top: 1rem;
}

.class-change-detail-card--quest-only {
  padding: 0;
  border: none;
  background: transparent;
  box-shadow: none;
  scroll-margin-top: 1rem;
}

.class-change-detail-card > .class-change-quest-card--split {
  margin-top: 0.75rem;
}

.class-change-detail-card--quest-only > .class-change-quest-card--split {
  margin-top: 0;
}

.class-change-detail-header {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: start;
}

.class-change-detail-title-wrap {
  display: grid;
  gap: 0.3rem;
}

.class-change-detail-title-wrap h3 {
  margin: 0;
  font-size: 1.08rem;
  line-height: 1.35;
}

.class-change-detail-button {
  flex: 0 0 auto;
}

.class-change-detail-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.9rem;
  margin-top: 0.9rem;
}

.class-change-detail-grid--compact {
  grid-template-columns: minmax(0, 1fr);
  margin-top: 0.75rem;
}

.class-change-detail-item {
  display: grid;
  gap: 0.45rem;
}

.class-change-detail-item--full {
  grid-column: 1 / -1;
}

.class-change-detail-meta,
.class-change-empty {
  margin: 0;
  color: var(--text-muted);
  line-height: 1.7;
}

.class-change-detail-value {
  margin: 0;
  color: var(--text);
  line-height: 1.7;
}

.class-change-detail-links {
  display: grid;
  gap: 0.5rem;
  margin-top: 0.9rem;
}

.class-change-detail-quest-list {
  display: grid;
  gap: 0.75rem;
  margin-top: 0.9rem;
}

.class-change-detail-inline {
  display: grid;
  gap: 0.18rem;
}

.class-change-detail-summary + .class-change-detail-summary {
  margin-top: 0.75rem;
}

.class-change-pill-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.class-change-pill {
  display: inline-flex;
  align-items: center;
  min-height: 1.9rem;
  padding: 0.2rem 0.65rem;
  border: 1px solid rgba(51, 255, 167, 0.18);
  border-radius: 999px;
  background: rgba(51, 255, 167, 0.06);
  color: var(--text);
  font-size: 0.84rem;
  line-height: 1.35;
}

.class-change-pill--wide {
  border-radius: 10px;
}

.class-change-quest-card {
  padding: 0.9rem 1rem;
  border: 1px solid #353535;
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.1);
}

/* 转职任务详情卡：标题行可展开，右侧 Wiki 纵跨详情区 */
.class-change-quest-card--split {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  column-gap: 0.65rem;
  row-gap: 0.75rem;
  align-items: stretch;
}

.class-change-quest-card__head--split {
  grid-column: 1;
  grid-row: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  min-height: 0;
  align-self: start;
}

.class-change-quest-card--split > .class-change-quest-wiki-link {
  grid-column: 2;
  grid-row: 1 / -1;
  align-self: stretch;
  justify-self: stretch;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 2.85rem;
  padding: 0.35rem 0.55rem;
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(0, 0, 0, 0.22);
  color: var(--text-muted);
  font-size: 0.76rem;
  font-weight: 700;
  text-decoration: none;
}

.class-change-quest-card--split > .class-change-quest-wiki-link:hover,
.class-change-quest-card--split > .class-change-quest-wiki-link:focus-visible {
  color: var(--accent);
  border-color: rgba(51, 255, 167, 0.35);
  background: rgba(51, 255, 167, 0.08);
  outline: none;
}

.class-change-quest-card--split > .class-change-quest-body {
  grid-column: 1;
  grid-row: 2;
  margin-top: 0;
}

.class-change-quest-body details {
  margin: 1rem 0;
  border: 1px solid rgba(51, 255, 167, 0.18);
  border-radius: 12px;
  background:
    linear-gradient(180deg, rgba(51, 255, 167, 0.05), rgba(51, 255, 167, 0.02)),
    rgba(255, 255, 255, 0.015);
  overflow: hidden;
}

.class-change-quest-body details > summary {
  position: relative;
  list-style: none;
  cursor: pointer;
  padding: 0.9rem 3rem 0.9rem 1rem;
  font-weight: 700;
  color: var(--text);
  background: rgba(51, 255, 167, 0.06);
  border-bottom: 1px solid rgba(51, 255, 167, 0.12);
  transition: background-color 0.18s ease, color 0.18s ease;
}

.class-change-quest-body details > summary::-webkit-details-marker {
  display: none;
}

.class-change-quest-body details > summary::after {
  content: "";
  position: absolute;
  right: 1rem;
  top: 50%;
  width: 0.6rem;
  height: 0.6rem;
  border-right: 2px solid rgba(51, 255, 167, 0.9);
  border-bottom: 2px solid rgba(51, 255, 167, 0.9);
  transform: translateY(-65%) rotate(45deg);
  transition: transform 0.18s ease;
}

.class-change-quest-body details[open] > summary::after {
  transform: translateY(-35%) rotate(225deg);
}

.class-change-quest-body details > summary:hover,
.class-change-quest-body details > summary:focus-visible {
  background: rgba(51, 255, 167, 0.1);
  color: var(--accent);
  outline: none;
}

.class-change-quest-body details > :not(summary) {
  padding-left: 1rem;
  padding-right: 1rem;
}

.class-change-quest-body details > hr:last-child {
  margin-bottom: 1rem;
}

.class-change-quest-head-toggle {
  position: relative;
  flex: 1;
  width: 100%;
  min-width: 0;
  margin: 0;
  padding: 0.42rem 2.2rem 0.42rem 0.55rem;
  border: 1px solid rgba(51, 255, 167, 0.22);
  border-radius: 8px;
  background: rgba(51, 255, 167, 0.06);
  color: var(--text);
  font: inherit;
  text-align: left;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.08rem;
}

.class-change-quest-head-static {
  flex: 1;
  width: 100%;
  min-width: 0;
  margin: 0;
  padding: 0.42rem 0.55rem;
  border: 1px solid rgba(51, 255, 167, 0.18);
  border-radius: 8px;
  background: rgba(51, 255, 167, 0.05);
  color: var(--text);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.08rem;
  text-decoration: none;
}

.class-change-quest-head-static:hover,
.class-change-quest-head-static:focus-visible {
  border-color: rgba(51, 255, 167, 0.35);
  background: rgba(51, 255, 167, 0.1);
  color: var(--text);
  outline: none;
}

.class-change-quest-card--wiki-only > .class-change-quest-wiki-link {
  grid-row: 1;
}

.class-change-quest-card--split.is-pinned > .class-change-quest-card__head--split {
  min-height: var(--ccq-pin-height, 0);
}

.class-change-quest-card--split.is-pinned .class-change-quest-head-toggle {
  position: fixed;
  left: var(--ccq-pin-left, 0);
  top: 12px;
  width: var(--ccq-pin-width, auto);
  z-index: 30;
  background: #1f4738;
  border-color: #2fd691;
  box-shadow: 0 0 0 1px rgba(47, 214, 145, 0.18);
}

.class-change-quest-head-toggle::after {
  content: "";
  position: absolute;
  right: 0.9rem;
  top: 50%;
  width: 0.6rem;
  height: 0.6rem;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  color: rgba(255, 255, 255, 0.72);
  transform: translateY(-62%) rotate(45deg);
  transition: transform 160ms ease, color 160ms ease;
}

.class-change-quest-head-toggle:hover,
.class-change-quest-head-toggle:focus-visible {
  border-color: rgba(51, 255, 167, 0.35);
  background: rgba(51, 255, 167, 0.1);
  outline: none;
}

.class-change-quest-head-toggle[aria-expanded="true"] {
  border-color: rgba(51, 255, 167, 0.42);
  background: rgba(51, 255, 167, 0.12);
}

.class-change-quest-head-toggle[aria-expanded="true"]::after {
  color: var(--accent);
  transform: translateY(-38%) rotate(-135deg);
}

.class-change-quest-head-toggle__zh {
  font-weight: 800;
  font-size: 1rem;
  line-height: 1.35;
}

.class-change-quest-head-toggle .quest-original {
  margin-top: 0;
  color: var(--text-muted);
}

.class-change-quest-body {
  margin-top: 0.75rem;
}

.class-change-quest-meta-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.8rem 1rem;
  margin-top: 0.8rem;
}

.class-change-reward-list {
  margin: 0;
  padding-left: 1.1rem;
  color: var(--text);
  line-height: 1.7;
}

.class-change-reward-list li + li {
  margin-top: 0.18rem;
}

.class-change-step-list {
  margin: 0;
  padding-left: 1.2rem;
  color: var(--text);
  line-height: 1.75;
}

.class-change-step-list li + li {
  margin-top: 0.32rem;
}

.class-change-wiki-html {
  color: var(--text);
  line-height: 1.65;
}

.class-change-wiki-html--npc {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem 0.65rem;
}

.class-change-wiki-html--rewards .mb-8 {
  margin-bottom: 0.55rem;
}

.class-change-wiki-html--rewards .mb-8:last-child {
  margin-bottom: 0;
}

.class-change-wiki-html .item-name {
  margin: 0.12rem 0.4rem 0.12rem 0;
  vertical-align: middle;
}

.class-change-location-block .class-change-detail-value {
  margin-bottom: 0.35rem;
}

.class-change-wiki-html--guide {
  font-size: 0.95rem;
  display: flow-root;
  min-width: 0;
}

/*
 * guide.css 里 .lightbox 是全屏对话框根节点（position:fixed）。MW2 Wiki 把同名 class 用在流程里的 <img>，
 * 会与站点样式冲突。这里仅把「任务流程」里的图按正文排版；点击放大由 class-change-detail-page.js 接管。
 */
.class-change-wiki-html--guide img.lightbox {
  position: static !important;
  inset: auto !important;
  z-index: auto !important;
  display: block !important;
  max-width: min(100%, 36rem) !important;
  max-height: none !important;
  width: auto !important;
  height: auto !important;
  margin: 0 auto !important;
  padding: 0 !important;
  flex: none !important;
  align-items: unset !important;
  justify-content: unset !important;
  cursor: zoom-in;
}

.class-change-wiki-html--guide p {
  margin: 0.45rem 0;
  line-height: 1.65;
}

.class-change-wiki-html--guide hr {
  margin: 0.75rem 0;
  border: 0;
  border-top: 1px solid #353535;
}

.class-change-wiki-html--guide figure {
  margin: 0.55rem 0;
}

.class-change-wiki-html--guide figure img {
  display: block;
  max-width: min(100%, 36rem);
  height: auto;
  margin: 0 auto;
  border-radius: 8px;
}

/* Wiki .slick：多图与多个独立 <figure> 一致——单列竖排，每张上限 36rem，禁止横排缩略图条 */
.class-change-wiki-html--guide .slick {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.65rem;
  width: 100%;
  max-width: min(100%, 36rem);
  margin: 0.55rem auto;
  clear: both;
}

.class-change-wiki-html--guide .slick figure {
  margin: 0;
  min-width: 0;
}

.class-change-wiki-html--guide .slick figure img,
.class-change-wiki-html--guide .slick figure img.lightbox {
  display: block;
  max-width: 100% !important;
  width: auto !important;
  height: auto;
  margin: 0 auto;
  border-radius: 8px;
}

/* 与 #lightbox 并存：仅一张图时隐藏上一张/下一张 */
#lightbox.lightbox--wiki-single .lightbox__nav {
  display: none;
}

@media (max-width: 900px) {
  .class-change-detail-header {
    flex-direction: column;
  }

  .class-change-detail-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .class-change-quest-meta-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .class-tree-layout {
    grid-template-columns: minmax(0, 1fr);
  }

  .class-tree-root {
    border-right: 0;
    border-bottom: 1px solid #303030;
    padding-right: 0;
  }

  .class-tree-branch {
    grid-template-columns: 1.4rem minmax(0, 1fr);
    min-height: 0;
    padding-top: 0.85rem;
    padding-bottom: 0.85rem;
  }

  .class-tree-branch__line {
    flex-direction: column;
    align-items: stretch;
  }

  .class-tree-node {
    width: 100%;
    min-width: 0;
  }

  .class-tree-arrow {
    justify-self: start;
    padding-left: 0.2rem;
  }

  .class-change-table {
    min-width: 64rem;
  }
}
