/* refine.css — 全站视觉细化叠加层（在 visual-polish.css 之后、所有页面加载）
   内容：
   1) 排版细化：中文标题折行平衡，消除行尾孤字（如「口。」「本。」单独成行）
   2) 平板宽度导航修复（原 header-fix.css，并入本文件统一维护） */

/* ============ 1. 排版细化 ============ */
/* 标题按整体行长平衡折行；不支持的浏览器自动忽略，零风险渐进增强 */
h1,
h2,
h3 {
  text-wrap: balance;
}

/* 正文段落避免末行孤字 */
p,
.section-desc,
figcaption {
  text-wrap: pretty;
}

/* 窄屏下节标题与旁注改为上下堆叠（与 muse-head 既有模式一致），
   避免标题和说明挤成两条窄柱 */
@media (max-width: 640px) {
  .section-head {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }

  .section-desc {
    max-width: 100%;
  }
}

/* ============ 2. 平板宽度导航修复 ============
   问题：桌面导航(首页/资源库/工作台/专题/案例/教程 + 搜索框 + 工作台按钮)
   在 821~1180px 区间放不下，「案例」「教程」被 .tab-wrap 的 overflow 裁掉。
   方案：该区间复用既有的汉堡菜单（按钮与 #mobile-menu 各页均已内置，
   site.js 的绑定与宽度无关），不改任何原文件。 */

@media (min-width: 821px) and (max-width: 1180px) {
  .tab-wrap,
  .search-bar,
  .header-action {
    display: none;
  }

  .mobile-menu-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    padding: 0 16px;
    margin-left: auto;
    border: 1px solid rgba(255, 255, 255, .2);
    border-radius: 999px;
    color: rgba(255, 255, 255, .92);
    background: rgba(255, 255, 255, .09);
    font-size: 17px;
    font-weight: 650;
    cursor: pointer;
  }

  .mobile-menu-toggle[aria-expanded="true"] {
    color: #fff;
    background: rgba(34, 200, 212, .22);
    border-color: rgba(34, 200, 212, .45);
  }

  .mobile-menu {
    position: absolute;
    top: calc(var(--header-height, 64px) + 8px);
    left: 50%;
    transform: translateX(-50%);
    width: min(720px, calc(100vw - 32px));
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    padding: 12px;
    border: 1px solid rgba(255, 255, 255, .16);
    border-radius: 18px;
    background: rgba(16, 24, 32, .94);
    box-shadow: 0 22px 54px rgba(0, 0, 0, .24);
    backdrop-filter: blur(18px);
  }

  .mobile-menu[hidden] {
    display: none;
  }

  .mobile-menu a {
    display: inline-flex;
    min-height: 42px;
    align-items: center;
    justify-content: center;
    padding: 0 12px;
    border: 1px solid rgba(255, 255, 255, .1);
    border-radius: 12px;
    color: rgba(255, 255, 255, .9);
    background: rgba(255, 255, 255, .06);
    font-weight: 760;
    text-decoration: none;
  }

  .mobile-menu a:hover,
  .mobile-menu a.is-active {
    color: #fff;
    border-color: rgba(34, 200, 212, .36);
    background: rgba(34, 200, 212, .18);
  }
}
