/* ============================================================
   layout.css — 顶栏 / 三栏布局 / 侧栏 / 页内TOC / 响应式
   ============================================================ */

/* ---------- 顶栏 ---------- */
.topbar {
  position: sticky; top: 0; z-index: var(--z-topbar);
  height: var(--topbar-h);
  display: flex; align-items: center; gap: var(--s-3);
  padding: 0 var(--s-5);
  background: color-mix(in srgb, var(--bg-1) 82%, transparent);
  backdrop-filter: saturate(140%) blur(14px);
  -webkit-backdrop-filter: saturate(140%) blur(14px);
  border-bottom: 1px solid var(--line-soft);
}
.topbar__menu {
  display: none;
  background: none; border: 1px solid var(--line); color: var(--txt-1);
  width: 38px; height: 38px; border-radius: var(--r-sm); cursor: pointer; font-size: 1.1rem;
}
.topbar__brand { display: flex; align-items: center; gap: var(--s-3); color: var(--txt-1); font-weight: 700; }
.topbar__brand:hover { color: var(--txt-1); }
.brand-mark { width: 30px; height: 30px; flex: none; }
.brand-text { font-size: .98rem; letter-spacing: .01em; }
.brand-text small { display:block; font-size: var(--f-2xs); color: var(--txt-3); font-weight: 500; letter-spacing: .12em; }
/* 品牌分隔:设计化渐变小圆点 + 外发光 */
.brand-sep { display:inline-block; width:6px; height:6px; border-radius:50%; margin:0 9px; vertical-align:middle;
  background: var(--grad-brand); box-shadow: 0 0 6px -1px var(--c-teal); }
.topbar__crumb {
  margin-left: var(--s-2); padding-left: var(--s-4);
  border-left: 1px solid var(--line); color: var(--txt-3); font-size: var(--f-sm);
}
.topbar__spacer { flex: 1; }
.topbar__theme {
  background: var(--panel); border: 1px solid var(--line); color: var(--txt-1);
  width: 38px; height: 38px; border-radius: var(--r-sm); cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  transition: border-color var(--t-fast), transform var(--t-fast);
}
.topbar__theme:hover { border-color: var(--c-teal); transform: translateY(-1px); }
.topbar__theme svg { width: 18px; height: 18px; }

/* ---------- 三栏布局 ---------- */
.layout {
  display: grid;
  grid-template-columns: var(--sidebar-w) minmax(0, 1fr) var(--toc-w);
  align-items: start;
  max-width: 1640px; margin: 0 auto;
}
.layout--wide { display: block; } /* 落地页:单列全宽 */

/* ---------- 侧栏(全站导航) ---------- */
.sidebar {
  position: sticky; top: var(--topbar-h);
  height: calc(100vh - var(--topbar-h));
  overflow-y: auto; overscroll-behavior: contain;
  padding: var(--s-5) var(--s-3) var(--s-7) var(--s-5);
  border-right: 1px solid var(--line-soft);
  z-index: var(--z-sidebar);
}
.sidebar__title {
  font-size: var(--f-2xs); letter-spacing: .16em; text-transform: uppercase;
  color: var(--txt-4); margin: 0 0 var(--s-3) var(--s-2); font-weight: 600;
}
.navlist { list-style: none; margin: 0 0 var(--s-5); padding: 0; }
.navlist__item { margin: 1px 0; }
.navlist__link {
  display: flex; align-items: center; gap: var(--s-3);
  padding: var(--s-2) var(--s-3); border-radius: var(--r-sm);
  color: var(--txt-2); font-size: var(--f-sm); line-height: 1.35;
  border: 1px solid transparent;
  transition: background var(--t-fast), color var(--t-fast);
}
.navlist__link:hover { background: var(--panel); color: var(--txt-1); }
.navlist__num {
  font-family: var(--f-num); font-size: var(--f-2xs); font-weight: 700;
  color: var(--txt-4); min-width: 26px;
  border: 1px solid var(--line); border-radius: var(--r-xs);
  text-align: center; padding: 1px 0; flex: none;
}
.navlist__item.is-active > .navlist__link {
  background: var(--grad-brand-soft); color: var(--txt-1);
  border-color: color-mix(in srgb, var(--c-teal) 35%, transparent);
}
.navlist__item.is-active .navlist__num { color: var(--c-teal); border-color: var(--c-teal); }

/* 当前模块展开的章节子导航 */
.navsub { list-style: none; margin: var(--s-1) 0 var(--s-3) 0; padding: 0 0 0 38px; }
.navsub__link {
  display: block; padding: 3px var(--s-2); border-radius: var(--r-xs);
  font-size: var(--f-xs); color: var(--txt-3);
  border-left: 2px solid var(--line); margin-left: 2px;
}
.navsub__link:hover { color: var(--txt-1); border-left-color: var(--c-teal); }

.sidebar__foot { font-size: var(--f-2xs); color: var(--txt-4); padding: var(--s-3) var(--s-2); line-height: 1.6; }
.sidebar__foot a { color: var(--txt-3); }

/* ---------- 内容主区 ---------- */
.main {
  min-width: 0;
  padding: var(--s-7) clamp(var(--s-4), 4vw, var(--s-8)) var(--s-9);
}
.main__inner { max-width: var(--content-max); margin: 0 auto; }

/* ---------- 页内 TOC(右栏) ---------- */
.toc {
  position: sticky; top: var(--topbar-h);
  height: calc(100vh - var(--topbar-h));
  overflow-y: auto;
  padding: var(--s-7) var(--s-4) var(--s-7) 0;
  font-size: var(--f-xs);
}
.toc__title {
  font-size: var(--f-2xs); letter-spacing: .16em; text-transform: uppercase;
  color: var(--txt-4); margin: 0 0 var(--s-3); font-weight: 600;
}
.toc__list { list-style: none; margin: 0; padding: 0; border-left: 1px solid var(--line); }
.toc__item a {
  display: block; padding: 4px var(--s-3); color: var(--txt-3);
  border-left: 2px solid transparent; margin-left: -1px; line-height: 1.4;
  transition: color var(--t-fast), border-color var(--t-fast);
}
.toc__item a:hover { color: var(--txt-1); }
.toc__item--sub a { padding-left: var(--s-5); font-size: var(--f-2xs); color: var(--txt-4); }
.toc__item.is-active > a { color: var(--c-teal); border-left-color: var(--c-teal); font-weight: 600; }

/* ---------- 上一页 / 下一页 ---------- */
.prevnext {
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-4);
  margin-top: var(--s-8); padding-top: var(--s-6); border-top: 1px solid var(--line);
}
.prevnext__link {
  display: flex; flex-direction: column; gap: 3px;
  padding: var(--s-4) var(--s-5); border: 1px solid var(--line); border-radius: var(--r-md);
  background: var(--panel); transition: border-color var(--t-fast), transform var(--t-fast), background var(--t-fast);
}
.prevnext__link:hover { border-color: var(--c-teal); transform: translateY(-2px); background: var(--panel-hover); }
.prevnext__dir { font-size: var(--f-2xs); letter-spacing: .14em; text-transform: uppercase; color: var(--txt-4); }
.prevnext__title { color: var(--txt-1); font-weight: 600; font-size: var(--f-sm); }
.prevnext__link--next { text-align: right; align-items: flex-end; }
.prevnext__link--disabled { opacity: .35; pointer-events: none; }

/* ---------- 移动端抽屉遮罩 ---------- */
.scrim {
  position: fixed; inset: 0; z-index: var(--z-drawer);
  background: rgba(3,6,14,.6); backdrop-filter: blur(2px);
  opacity: 0; visibility: hidden; transition: opacity var(--t-mid);
}
.scrim.is-open { opacity: 1; visibility: visible; }

/* ============================================================
   响应式
   ============================================================ */

/* 收起右侧 TOC */
@media (max-width: 1180px) {
  .layout { grid-template-columns: var(--sidebar-w) minmax(0,1fr); }
  .toc { display: none; }
}

/* 平板 / 手机:侧栏抽屉化,单栏 */
@media (max-width: 900px) {
  :root { --topbar-h: 54px; }
  .layout { grid-template-columns: 1fr; }
  .topbar__menu { display: inline-flex; align-items: center; justify-content: center; }
  .topbar__crumb { display: none; }
  .brand-text { font-size: .9rem; }

  .sidebar {
    position: fixed; top: 0; left: 0; z-index: calc(var(--z-drawer) + 1);
    width: min(86vw, 320px); height: 100vh;
    background: var(--bg-2); border-right: 1px solid var(--line);
    transform: translateX(-104%); transition: transform var(--t-mid) var(--ease);
    padding-top: var(--s-5);
    box-shadow: var(--sh-3);
  }
  .sidebar.is-open { transform: translateX(0); }
  .main { padding: var(--s-5) var(--s-4) var(--s-8); }

  /* 顶栏在窄屏保持单行、不溢出 */
  .topbar { gap: var(--s-2); padding: 0 var(--s-3); }
  .brand-text { font-size: .92rem; line-height: 1.15; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .brand-text small { display: none; }
  .topbar__brand { min-width: 0; overflow: hidden; }
}

@media (max-width: 560px) {
  .prevnext { grid-template-columns: 1fr; }
  .main { padding-left: var(--s-3); padding-right: var(--s-3); }
}

/* 桌面端隐藏抽屉相关 */
@media (min-width: 901px) {
  .scrim { display: none; }
}
