/* ============================================================
   global.css — 全站基础：reset / 字体 / nav / footer / 按钮
                breadcrumb / skip-link / focus / 安全区
   依赖：tokens.css
   ============================================================ */

/* ===== Reset ===== */
*, *::before, *::after {
  margin: 0; padding: 0; box-sizing: border-box;
}
html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}
body {
  font-family: -apple-system, BlinkMacSystemFont, 'Inter', 'Helvetica Neue',
               'PingFang SC', 'Microsoft YaHei', '微软雅黑', sans-serif;
  font-size: var(--fs-body);
  line-height: var(--lh-relax);
  color: var(--black-text);
  background: var(--white-warm);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img, svg, video {
  max-width: 100%;
  display: block;
}
a {
  color: inherit;
  text-decoration: none;
  touch-action: manipulation;
  -webkit-tap-highlight-color: var(--gold-tint-12);
}
button {
  font-family: inherit;
  cursor: pointer;
  background: none;
  border: none;
}

/* ===== Lucide 图标默认样式 ===== */
[data-lucide], .lucide {
  width: 24px;
  height: 24px;
  stroke-width: 1.5;
  color: var(--gold-primary);
  display: inline-block;
  vertical-align: middle;
  flex-shrink: 0;
}

/* ===== Skip Link（跳至主内容，键盘可达性） ===== */
.skip-link {
  position: absolute;
  top: -100px;
  left: var(--space-md);
  background: var(--black-pure);
  color: var(--gold-primary);
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius);
  z-index: 10000;
  transition: top var(--transition-base);
  font-weight: var(--fw-semibold);
}
.skip-link:focus {
  top: var(--space-md);
}

/* ===== 全局 focus-visible（古金 2px 描边） ===== */
:focus-visible {
  outline: 2px solid var(--gold-primary);
  outline-offset: 2px;
  border-radius: var(--radius);
}
:focus:not(:focus-visible) {
  outline: none;
}

/* ===== 容器 ===== */
.container {
  max-width: var(--container-wide);
  margin: 0 auto;
  padding-left: var(--space-md);
  padding-right: var(--space-md);
}
.container-narrow { max-width: var(--container-narrow); margin: 0 auto; padding: 0 var(--space-md); }
.container-base   { max-width: var(--container-base);   margin: 0 auto; padding: 0 var(--space-md); }

/* ===== 固定导航 ===== */
nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  background: rgba(10, 10, 10, 0.96);
  box-shadow: 0 1px 0 var(--gold-tint-25);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 var(--space-xl);
  height: var(--nav-height-desktop);
  padding-top: env(safe-area-inset-top, 0);
}
@supports (backdrop-filter: blur(8px)) {
  nav {
    background: rgba(10, 10, 10, 0.85);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
  }
}
.nav-logo {
  color: var(--gold-primary);
  font-weight: var(--fw-bold);
  font-size: 16px;
  letter-spacing: 0.3px;
  white-space: nowrap;
}
.nav-links {
  display: flex;
  gap: var(--space-sm);
  align-items: center;
}
.nav-links a {
  color: rgba(255, 255, 255, 0.85);
  font-size: 14px;
  padding: 10px 16px;
  border-radius: var(--radius);
  transition: background var(--transition-base), color var(--transition-base);
  white-space: nowrap;
}
.nav-links a:hover {
  background: var(--gold-tint-12);
  color: var(--gold-primary);
}
.nav-links a.active,
.nav-links a[aria-current="page"] {
  background: var(--gold-tint-12);
  color: var(--gold-primary);
  font-weight: var(--fw-semibold);
}

/* ===== 移动端汉堡菜单 ===== */
.nav-toggle {
  display: none;
  width: 44px;
  height: 44px;
  align-items: center;
  justify-content: center;
  color: var(--gold-primary);
  background: transparent;
  border-radius: var(--radius);
}
.nav-toggle:hover { background: var(--gold-tint-12); }

/* ===== Footer ===== */
footer {
  background: var(--black-pure);
  color: rgba(255, 255, 255, 0.7);
  padding: var(--space-xl) 0;
  padding-bottom: max(var(--space-xl), env(safe-area-inset-bottom));
  text-align: center;
  font-size: var(--fs-sm);
  line-height: var(--lh-relax);
}
footer a {
  color: var(--gold-primary);
}
footer a:hover {
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* ===== 按钮系统（玄黑底古金字 / 古金底玄黑字） ===== */
.btn,
.btn-primary,
.btn-outline,
.cta-btn,
.cta-btn-outline,
.cta-main {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  padding: 14px 32px;
  border-radius: var(--radius);
  font-weight: var(--fw-semibold);
  font-size: 15px;
  line-height: 1;
  transition: background var(--transition-base), color var(--transition-base),
              border-color var(--transition-base), box-shadow var(--transition-base);
  min-height: 48px; /* 触控目标 */
}

/* 主按钮：玄黑底 + 古金字 */
.btn-primary,
.cta-btn,
.cta-main {
  background: var(--black-pure);
  color: var(--gold-primary);
  border: 1px solid var(--black-pure);
  box-shadow: var(--shadow-2);
}
.btn-primary:hover,
.cta-btn:hover,
.cta-main:hover,
.btn-primary:focus-visible,
.cta-btn:focus-visible,
.cta-main:focus-visible {
  background: var(--black-soft);
  border-color: var(--gold-primary);
  box-shadow: var(--shadow-3);
}
.btn-primary:active,
.cta-btn:active,
.cta-main:active {
  box-shadow: var(--shadow-1);
}

/* 次级按钮：古金描边 + 古金字（去胶囊） */
.btn-outline,
.cta-btn-outline {
  background: transparent;
  color: var(--gold-deep);
  border: 1px solid var(--gold-primary);
}
.btn-outline:hover,
.cta-btn-outline:hover,
.btn-outline:focus-visible,
.cta-btn-outline:focus-visible {
  background: var(--gold-tint-12);
  border-color: var(--gold-deep);
}

/* 按钮加载态 */
[aria-busy="true"] {
  opacity: 0.6;
  pointer-events: none;
  position: relative;
}

/* ===== 面包屑 ===== */
.breadcrumb {
  padding: 12px 0;
  background: var(--white-ivory);
  border-bottom: 1px solid var(--gold-tint-25);
  font-size: var(--fs-sm);
}
.breadcrumb .container,
.breadcrumb .inner {
  color: var(--gray-700);
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  flex-wrap: wrap;
}
.breadcrumb a {
  color: var(--gold-deep);
  transition: color var(--transition-fast);
}
.breadcrumb a:hover {
  color: var(--black-pure);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.breadcrumb span[aria-hidden="true"],
.breadcrumb .sep {
  color: var(--gold-tint-40);
  font-weight: var(--fw-medium);
}

/* ===== Section 标题（共享） ===== */
.section-header { text-align: center; margin-bottom: var(--space-2xl); }
.section-tag {
  display: inline-block;
  background: var(--gold-tint-12);
  border: 1px solid var(--gold-primary);
  color: var(--gold-deep);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  padding: 6px 16px;
  border-radius: var(--radius);
  margin-bottom: var(--space-sm);
  letter-spacing: 0.5px;
}
.section-title {
  font-size: var(--fs-h2);
  font-weight: var(--fw-heavy);
  color: var(--black-pure);
  margin-bottom: var(--space-sm);
  line-height: var(--lh-tight);
  border-left: 4px solid var(--gold-primary);
  padding-left: var(--space-md);
  display: inline-block;
}
.section-sub {
  font-size: 17px;
  color: var(--gray-700);
  line-height: var(--lh-relax);
}

/* ===== 通用徽章（替代各种 hero-tag/pillar-badge/adv-badge） ===== */
.badge,
.hero-tag,
.pillar-badge,
.adv-badge,
.card-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--gold-tint-12);
  border: 1px solid var(--gold-primary);
  color: var(--gold-deep);
  font-size: 13px;
  font-weight: var(--fw-semibold);
  padding: 4px 12px;
  border-radius: var(--radius);
  letter-spacing: 0.5px;
}

/* ===== 移动端响应式 ===== */
@media (max-width: 768px) {
  nav {
    padding: 0 var(--space-md);
    height: var(--nav-height-mobile);
  }
  .nav-logo {
    font-size: 15px;
    max-width: 200px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .nav-links {
    display: none; /* 桌面 nav 隐藏，由汉堡菜单接管 */
  }
  .nav-toggle {
    display: inline-flex;
  }

  /* 移动端抽屉菜单（默认隐藏） */
  body.nav-open .nav-links {
    display: flex;
    position: fixed;
    top: var(--nav-height-mobile);
    left: 0; right: 0;
    background: rgba(10, 10, 10, 0.98);
    flex-direction: column;
    align-items: stretch;
    padding: var(--space-md) 0;
    gap: 0;
    max-height: calc(100vh - var(--nav-height-mobile));
    overflow-y: auto;
    box-shadow: var(--shadow-4);
  }
  body.nav-open .nav-links a {
    padding: 14px var(--space-lg);
    border-radius: 0;
    font-size: 16px;
    min-height: 48px;
    display: flex;
    align-items: center;
  }
  body.nav-open .nav-links a + a {
    border-top: 1px solid rgba(255, 255, 255, 0.06);
  }
  body.nav-open {
    overflow: hidden;
  }

  .container { padding: 0 var(--space-md); }

  .section-title { font-size: 24px; }
  .section-sub { font-size: 15px; }

  .btn, .btn-primary, .btn-outline,
  .cta-btn, .cta-btn-outline, .cta-main {
    width: 100%;
    padding: 14px var(--space-md);
  }
}

/* 横屏窄高屏 */
@media (orientation: landscape) and (max-height: 500px) {
  nav { height: 48px; }
  body { padding-top: 48px; }
}
