/* Guide Me static site styles
 * 设计意图：纸色暖底 + 衬线标题 + 克制深棕，承接"读古书"的手感。
 * 不做营销页 / 不堆动效 / 不抢正文注意力。
 */

:root {
  /* 纸色系——比纯灰白暖一档，长读不刺眼 */
  --bg: #f6f1e6;          /* 米黄纸底 */
  --bg-soft: #efe9da;     /* 更深一点的纸色，用作 footer / 区段底 */
  --surface: #fdfaf2;     /* 卡片底色，略亮于 bg */
  --surface-hover: #fbf6e8;

  --text: #2a2520;        /* 暖墨色，不用纯黑 */
  --text-muted: #5d544a;  /* 暖灰，正文辅助 */
  --text-faint: #8a8174;  /* 更淡，breadcrumb / 计数 */

  --border: #d9d0bc;      /* 暖边框，跟纸色同族 */
  --border-soft: #e6dfcc;
  --rule: #c9bfa6;        /* 装饰性细线，比 border 更克制 */

  --accent: #5a3d2b;      /* 深棕，标题 / 城市名 / 章节 chip */
  --accent-soft: #7a5a45;
  --link: #2a5b86;        /* 蓝色稍微调暖一点点 */
  --link-hover: #143052;

  --max-text: 40em;       /* 正文阅读宽度上限 */
  --max-content: 960px;   /* 首页/城市页主区域上限 */

  --serif: Georgia, "Songti SC", "STSong", "Source Han Serif CN", "Noto Serif CJK SC", "Times New Roman", serif;
  --sans: -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Source Han Sans CN", sans-serif;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--text);
  font-family: var(--sans);
  line-height: 1.78;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

a { color: var(--link); text-decoration: none; }
a:hover { color: var(--link-hover); text-decoration: underline; text-underline-offset: 2px; }

img { max-width: 100%; height: auto; display: block; }

::selection { background: rgba(90,61,43,0.18); color: var(--text); }

/* ---------- Site header ---------- */

.site-header {
  border-bottom: 1px solid var(--border);
  background: var(--surface);
}
.site-header-inner {
  max-width: var(--max-content);
  margin: 0 auto;
  padding: 14px 24px;
  display: flex;
  align-items: baseline;
  gap: 24px;
  flex-wrap: wrap;
}
.site-title {
  font-family: var(--serif);
  font-weight: 600;
  font-size: 19px;
  color: var(--accent);
  letter-spacing: 0.03em;
}
.site-title:hover { color: var(--accent); text-decoration: none; }

.breadcrumb { color: var(--text-faint); font-size: 14px; }
.breadcrumb a { color: var(--text-faint); }
.breadcrumb a:hover { color: var(--link); }
.breadcrumb .sep { margin: 0 6px; color: var(--rule); }
.breadcrumb .current { color: var(--text-muted); }

/* ---------- Main column ---------- */

main {
  max-width: var(--max-content);
  margin: 0 auto;
  padding: 40px 24px 72px;
}

/* 文章页用更窄的列；通过 article 选择器收窄 */
main > article.article {
  max-width: var(--max-text);
  margin: 0 auto;
  padding: 8px 0 0;
}

/* ---------- Headings ---------- */

h1, h2, h3, h4 {
  font-family: var(--serif);
  color: var(--text);
  letter-spacing: -0.005em;
}

h2 {
  font-size: 22px;
  font-weight: 600;
  margin: 48px 0 18px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--rule);
  color: var(--accent);
}
h3 { font-size: 18px; font-weight: 600; margin: 0 0 8px; }
h4 { font-size: 17px; font-weight: 600; margin: 0 0 6px; }

.section-hint {
  color: var(--text-muted);
  margin: -10px 0 18px;
  font-size: 15px;
  line-height: 1.65;
}

/* ---------- Hero (homepage + city page) ---------- */

.hero, .city-hero {
  margin: 0 0 48px;
  padding: 8px 0 28px;
  border-bottom: 1px solid var(--rule);
  position: relative;
}
.hero::after, .city-hero::after {
  /* 一条克制的装饰短线，把 hero 跟下面拉开层次 */
  content: "";
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 48px;
  height: 2px;
  background: var(--accent);
}

.hero h1, .city-hero h1 {
  font-family: var(--serif);
  font-size: 38px;
  font-weight: 700;
  line-height: 1.25;
  margin: 4px 0 14px;
  letter-spacing: -0.01em;
  color: var(--text);
}

.hero-tagline {
  font-family: var(--serif);
  font-size: 19px;
  color: var(--accent);
  margin: 0 0 18px;
  line-height: 1.6;
  font-style: italic;
}

.hero-intro {
  color: var(--text-muted);
  margin: 0 0 12px;
  max-width: 38em;
  font-size: 16.5px;
  line-height: 1.78;
}
.hero-intro:last-child { margin-bottom: 0; }

/* 首页第一段引文式段落：如果 hero-intro 是 hero 区第一段，可以加大 */
.hero > .hero-intro:first-of-type {
  font-size: 17.5px;
}

/* ---------- Homepage city list (改成 grid) ---------- */

.city-list ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}

.city-card {
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 22px 24px;
  background: var(--surface);
  transition: border-color 0.18s ease, background 0.18s ease, transform 0.18s ease;
  position: relative;
}
.city-card:hover {
  border-color: var(--accent);
  background: var(--surface-hover);
}
.city-card a { display: block; color: var(--text); }
.city-card a:hover { text-decoration: none; }
.city-card h3 {
  color: var(--accent);
  margin: 0 0 10px;
  font-size: 21px;
  display: flex;
  align-items: baseline;
  gap: 10px;
  flex-wrap: wrap;
}
.city-card .count {
  font-family: var(--sans);
  font-weight: normal;
  color: var(--text-faint);
  font-size: 13px;
  letter-spacing: 0.02em;
}
.city-card p {
  margin: 0;
  color: var(--text-muted);
  font-size: 15.5px;
  line-height: 1.72;
}
.city-card p strong { color: var(--text); font-weight: 600; }

/* ---------- Usage block ---------- */

.usage p {
  color: var(--text-muted);
  max-width: 38em;
  line-height: 1.78;
}

/* ---------- City page: approach list ---------- */

.city-approach { margin-bottom: 56px; }
.approach-intro {
  color: var(--text-muted);
  margin: -10px 0 22px;
  font-size: 15px;
  max-width: 40em;
  line-height: 1.72;
}
.approach-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 14px;
}
.approach-list li {
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 16px 18px;
  background: var(--surface);
  transition: border-color 0.18s ease, background 0.18s ease;
}
.approach-list li:hover {
  border-color: var(--accent);
  background: var(--surface-hover);
}
.approach-list li > a {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
  color: var(--text);
  font-weight: 600;
  font-size: 16px;
  font-family: var(--serif);
}
.approach-list li > a:hover { text-decoration: none; color: var(--accent); }
.approach-list .approach-label { flex: 1; }
.approach-list .approach-count {
  color: var(--text-faint);
  font-size: 13px;
  font-weight: normal;
  font-family: var(--sans);
  letter-spacing: 0.02em;
}
.approach-blurb {
  margin: 0;
  color: var(--text-muted);
  font-size: 14.5px;
  line-height: 1.68;
}

/* anchor offset */
.city-groups-section .group { scroll-margin-top: 24px; }

/* ---------- City map ---------- */

.city-map-section { margin-bottom: 56px; }
#city-map {
  height: 480px;
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--bg-soft);
}
.map-legend {
  margin-top: 14px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px 18px;
  font-size: 14px;
  color: var(--text-muted);
}
.legend-item { display: inline-flex; align-items: center; gap: 6px; }
.dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex: none;
}
.map-pop { font-size: 14px; max-width: 240px; font-family: var(--sans); }
.map-pop h4 { margin: 0 0 4px; font-size: 15px; color: var(--accent); }
.map-pop .subtitle { color: var(--text-muted); margin: 0 0 6px; font-size: 13px; }
.map-pop p { margin: 0 0 8px; color: var(--text); line-height: 1.65; }
.map-pop a { font-weight: 600; }

/* ---------- City page: groups ---------- */

.city-groups-section .group {
  margin-bottom: 28px;
  padding: 22px 24px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 6px;
}
.group-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 6px;
}
.group-header h3 { margin: 0; color: var(--accent); }
.group-intro {
  color: var(--text-muted);
  margin: 0 0 16px;
  font-size: 15px;
  line-height: 1.72;
}
.group-list { list-style: none; padding: 0; margin: 0; }
.group-list li {
  border-top: 1px solid var(--border-soft);
  padding: 14px 0;
}
.group-list li:first-child { border-top: none; padding-top: 4px; }
.group-list li:last-child { padding-bottom: 4px; }
.group-list a { display: block; color: var(--text); }
.group-list a:hover { text-decoration: none; }
.group-list a:hover h4 { color: var(--link); }
.group-list h4 {
  margin: 0;
  font-size: 16.5px;
  font-family: var(--serif);
  font-weight: 600;
  transition: color 0.15s ease;
}
.group-list .subtitle {
  color: var(--text-muted);
  margin: 3px 0 5px;
  font-size: 14px;
}
.group-list .summary {
  color: var(--text-muted);
  margin: 0;
  font-size: 14.5px;
  line-height: 1.7;
}

/* ---------- Article ---------- */

.article-header {
  margin-bottom: 28px;
  padding-bottom: 22px;
  border-bottom: 1px solid var(--rule);
}

.article-group {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--text-muted);
  margin-bottom: 10px;
  letter-spacing: 0.04em;
  text-transform: none;
}

.article-title {
  font-family: var(--serif);
  font-size: 32px;
  font-weight: 700;
  line-height: 1.32;
  margin: 0 0 6px;
  letter-spacing: -0.012em;
  color: var(--text);
}

.article-subtitle {
  color: var(--text-muted);
  margin: 10px 0 0;
  font-size: 16.5px;
  font-style: italic;
  line-height: 1.6;
}

.article-locmap-wrap { margin: 0 0 36px; }
#article-locmap {
  height: 240px;
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--bg-soft);
}
.article-locmap-hint {
  margin: 8px 0 0;
  font-size: 13px;
  color: var(--text-faint);
  text-align: right;
}
.article-locmap-hint a { color: var(--text-faint); text-decoration: underline; }
.article-locmap-hint a:hover { color: var(--link); }

/* Article body —— 长读优化 */
.article-body {
  font-size: 17px;
  line-height: 1.85;
  color: var(--text);
}

.article-body h2 {
  font-size: 21px;
  margin-top: 44px;
  margin-bottom: 14px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--rule);
  color: var(--accent);
}
.article-body h3 {
  font-size: 18px;
  margin-top: 28px;
  margin-bottom: 8px;
  color: var(--accent);
}
.article-body p {
  margin: 18px 0;
  /* 中文段落微调：稍大字距让长段不挤 */
}
.article-body p strong { color: var(--text); font-weight: 600; }
.article-body p em { color: var(--accent-soft); font-style: italic; }
.article-body a { text-decoration: underline; text-underline-offset: 2px; text-decoration-color: rgba(42,91,134,0.4); }
.article-body a:hover { text-decoration-color: var(--link-hover); }

.article-body ul, .article-body ol {
  margin: 16px 0;
  padding-left: 1.6em;
}
.article-body li { margin: 6px 0; line-height: 1.78; }

/* Figure：作为证据，不是装饰 */
.article-body figure {
  margin: 32px 0;
}
.article-body figure img {
  width: 100%;
  border-radius: 3px;
  border: 1px solid var(--border);
  background: var(--bg-soft);
}
.article-body figcaption {
  font-size: 14px;
  color: var(--text-muted);
  margin-top: 10px;
  line-height: 1.68;
  font-style: normal;            /* 不再 italic，更像图注 */
  padding-left: 12px;
  border-left: 2px solid var(--border);
}
.article-body figcaption em { font-style: italic; }
.article-body figcaption a { color: var(--text-muted); text-decoration: underline; text-decoration-color: var(--border); }
.article-body figcaption a:hover { color: var(--link); text-decoration-color: var(--link); }

.article-body blockquote {
  border-left: 3px solid var(--accent);
  margin: 22px 0;
  padding: 4px 18px;
  color: var(--text-muted);
  font-style: italic;
  background: var(--bg-soft);
  border-radius: 0 4px 4px 0;
}
.article-body blockquote p { margin: 8px 0; }

.article-body code {
  background: rgba(90,61,43,0.07);
  padding: 2px 6px;
  border-radius: 3px;
  font-size: 0.9em;
  font-family: "SF Mono", Menlo, Consolas, monospace;
  color: var(--accent);
}

.article-body hr {
  border: none;
  border-top: 1px solid var(--rule);
  margin: 32px auto;
  width: 30%;
}

.article-foot-nav {
  margin-top: 56px;
  padding-top: 24px;
  border-top: 1px solid var(--rule);
  font-size: 14.5px;
}
.article-foot-nav a { color: var(--accent); }
.article-foot-nav a:hover { color: var(--link); }

/* ---------- Footer ---------- */

.site-footer {
  border-top: 1px solid var(--border);
  background: var(--bg-soft);
  margin-top: 80px;
  padding: 28px 0 32px;
}
.site-footer-inner {
  max-width: var(--max-content);
  margin: 0 auto;
  padding: 0 24px;
  font-size: 13.5px;
  color: var(--text-faint);
  line-height: 1.7;
}
.site-footer-inner p { margin: 0; }
.site-footer-inner a { color: var(--text-muted); text-decoration: underline; text-decoration-color: var(--border); }
.site-footer-inner a:hover { color: var(--link); text-decoration-color: var(--link); }

/* ---------- Responsive ---------- */

/* 中等屏幕：iPad / 小笔记本——城市卡片两列 */
@media (min-width: 768px) {
  .city-list ul {
    grid-template-columns: repeat(2, 1fr);
    gap: 18px;
  }
}

/* 大屏：桌面——首页城市卡片可以三列，但只在城市数量足够时才视觉合理；
   留两列也行，三列对 5 城市更紧凑。这里用 minmax 折中 */
@media (min-width: 1100px) {
  .city-list ul {
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  }
}

/* iPad / 小笔记本字号微调 */
@media (max-width: 1024px) {
  .hero h1, .city-hero h1 { font-size: 34px; }
  .article-title { font-size: 30px; }
}

/* 中等屏 / 大手机 */
@media (max-width: 768px) {
  main { padding: 32px 22px 56px; }
  .hero h1, .city-hero h1 { font-size: 30px; }
  .hero-tagline { font-size: 17.5px; }
  .article-title { font-size: 27px; }
  .article-body { font-size: 16.5px; }
  .city-card { padding: 20px 22px; }
  .city-groups-section .group { padding: 20px 22px; }
}

/* 手机 */
@media (max-width: 640px) {
  body { font-size: 16px; line-height: 1.75; }
  main { padding: 24px 18px 48px; }
  main > article.article { padding: 4px 0 0; }

  .site-header-inner { padding: 12px 18px; gap: 10px; }
  .site-title { font-size: 17.5px; }

  .hero, .city-hero { margin-bottom: 36px; padding-bottom: 22px; }
  .hero h1, .city-hero h1 { font-size: 26px; }
  .hero-tagline { font-size: 16.5px; }
  .hero-intro { font-size: 16px; }

  h2 { font-size: 19px; margin-top: 36px; }
  .article-body h2 { font-size: 19px; margin-top: 36px; }
  .article-body h3 { font-size: 17px; }

  .article-title { font-size: 24px; }
  .article-subtitle { font-size: 15.5px; }
  .article-body { font-size: 16px; line-height: 1.8; }
  .article-body figure { margin: 24px 0; }

  #city-map { height: 60vh; max-height: 420px; }
  #article-locmap { height: 200px; }

  .city-card, .city-groups-section .group { padding: 16px 18px; }
  .city-card h3 { font-size: 19px; }

  .approach-list { gap: 12px; }
}

/* 极小屏（旧手机 / 横屏窄） */
@media (max-width: 480px) {
  main { padding: 20px 16px 40px; }
  .hero h1, .city-hero h1 { font-size: 24px; }
  .article-title { font-size: 22px; }
  .city-card h3 { flex-direction: column; align-items: flex-start; gap: 4px; }
  .approach-list { grid-template-columns: 1fr; }
}

/* 打印 / 高对比 */
@media print {
  body { background: #fff; color: #000; font-size: 12pt; }
  .site-header, .site-footer, .article-foot-nav,
  .city-map-section, .article-locmap-wrap { display: none; }
  main { max-width: 100%; padding: 0; }
  .article-body figure img { border: 1px solid #999; }
  a { color: #000; text-decoration: underline; }
}

/* ---------- Navigation poster enhancement ---------- */
.nav-poster {
  margin: 0 0 36px;
  border-radius: 6px;
  overflow: hidden;
  border: 1px solid var(--border);
  background: var(--bg-soft);
}
.nav-poster img {
  width: 100%;
  display: block;
}
.nav-poster-caption {
  padding: 12px 16px;
  font-size: 13.5px;
  color: var(--text-muted);
  line-height: 1.6;
  background: var(--surface);
  border-top: 1px solid var(--border-soft);
  display: flex;
  align-items: center;
  gap: 8px;
}
.nav-poster-caption .poster-label {
  font-family: var(--serif);
  font-weight: 600;
  color: var(--accent);
  font-size: 14px;
  white-space: nowrap;
}
@media (max-width: 560px) {
  .nav-poster-caption {
    display: block;
  }
  .nav-poster-caption .poster-label {
    display: block;
    margin-bottom: 4px;
  }
}
