/* ── 設計代幣 ── */
:root{
  --bg:#fafaf8;--surface:#ffffff;--surface-alt:#f4f3ef;
  --fg:#1c1c1a;--fg-muted:#6b6b65;--fg-faint:#a8a89f;
  --accent:#3d5a99;--accent-light:#e8edf7;
  --border:#e8e8e2;--border-strong:#d0d0c8;
  --serif:'Noto Serif TC','Georgia',serif;
  --sans:'Noto Sans TC','Helvetica Neue',sans-serif;
  --max-content:72rem;--radius:8px;--radius-sm:4px;
}
@media(prefers-color-scheme:dark){:root{
  --bg:#111110;--surface:#1a1a18;--surface-alt:#222220;
  --fg:#e8e8e2;--fg-muted:#888882;--fg-faint:#555550;
  --accent:#7aa2e0;--accent-light:#1e2a40;
  --border:#2c2c28;--border-strong:#3c3c38;
}}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bg);color:var(--fg);
  line-height:1.75;font-size:15px;font-weight:300}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline;text-underline-offset:3px}
img{max-width:100%;height:auto}

/* ── 頂部導覽 ── */
.site-header{position:sticky;top:0;z-index:100;
  background:rgba(250,250,248,.92);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border)}
@media(prefers-color-scheme:dark){
  .site-header{background:rgba(17,17,16,.92)}}
.site-header-inner{max-width:var(--max-content);margin:0 auto;
  padding:0 2rem;height:56px;display:flex;align-items:center;gap:2rem}
.site-logo{font-family:var(--serif);font-weight:700;font-size:1.1rem;
  color:var(--fg);letter-spacing:.03em;white-space:nowrap}
.site-logo span{color:var(--accent)}
.site-logo:hover{text-decoration:none}
.header-search{flex:1;max-width:360px;position:relative}
.header-search input{width:100%;padding:.45rem .9rem .45rem 2.4rem;
  border:1px solid var(--border-strong);border-radius:99px;
  background:var(--surface);font-family:var(--sans);font-size:.85rem;
  color:var(--fg);outline:none;transition:border-color .2s,box-shadow .2s}
.header-search input:focus{border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-light)}
.header-search-icon{position:absolute;left:.8rem;top:50%;
  transform:translateY(-50%);color:var(--fg-muted);font-size:.85rem;pointer-events:none}
.header-nav{margin-left:auto;display:flex;gap:1.5rem}
.header-nav a{font-size:.85rem;font-weight:400;color:var(--fg-muted);transition:color .15s}
.header-nav a:hover{color:var(--fg);text-decoration:none}
.header-nav a.active{color:var(--accent);font-weight:500}

/* ── section-label ── */
.section-label{font-size:.7rem;font-weight:500;letter-spacing:.12em;
  text-transform:uppercase;color:var(--fg-faint);margin-bottom:.8rem}

/* ══ 首頁 ══ */
.page-home{max-width:var(--max-content);margin:0 auto;padding:2.5rem 2rem 4rem}
.hero{margin-bottom:2.5rem;padding-bottom:2rem;border-bottom:1px solid var(--border)}
.hero-tagline{font-family:var(--serif);font-size:1.9rem;font-weight:700;
  line-height:1.3;color:var(--fg);margin-bottom:.4rem}
.hero-tagline span{color:var(--accent)}
.hero-sub{font-size:.9rem;color:var(--fg-muted);margin-bottom:1.5rem}
.stats-row{display:flex;gap:1.5rem;flex-wrap:wrap}
.stat-card{background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:.9rem 1.4rem;min-width:120px;text-align:center}
.stat-num{font-family:var(--serif);font-size:1.8rem;font-weight:700;
  color:var(--accent);line-height:1}
.stat-label{font-size:.75rem;color:var(--fg-muted);margin-top:.3rem;font-weight:400}

.dashboard{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}
@media(max-width:720px){.dashboard{grid-template-columns:1fr}}

/* 最近更新 */
.recent-list{list-style:none}
.recent-item{display:flex;gap:.9rem;padding:.7rem 0;
  border-bottom:1px solid var(--border);align-items:flex-start}
.recent-item:last-child{border-bottom:none}
.recent-date{font-size:.75rem;color:var(--fg-faint);white-space:nowrap;
  padding-top:.15rem;min-width:4.5rem;font-weight:400}
.recent-title{font-size:.9rem;font-weight:500;color:var(--fg);
  display:block;line-height:1.4}
.recent-title:hover{color:var(--accent);text-decoration:none}
.recent-cat{font-size:.72rem;color:var(--fg-muted);margin-top:.15rem}

/* 分類卡片 */
.categories-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.cat-card{background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:1rem 1.1rem;
  transition:border-color .2s,box-shadow .2s,transform .15s;
  position:relative;overflow:hidden;display:block}
.cat-card::before{content:'';position:absolute;left:0;top:0;bottom:0;
  width:3px;background:var(--cat-color,var(--accent));
  border-radius:var(--radius) 0 0 var(--radius)}
.cat-card:hover{border-color:var(--cat-color,var(--accent));
  box-shadow:0 2px 12px rgba(0,0,0,.06);transform:translateY(-1px);text-decoration:none}
.cat-icon{font-size:1.2rem;margin-bottom:.35rem}
.cat-name{font-size:.85rem;font-weight:500;color:var(--fg);display:block;margin-bottom:.15rem}
.cat-count{font-size:.75rem;color:var(--fg-muted)}

/* ══ 分類列表頁 ══ */
.page-list{max-width:var(--max-content);margin:0 auto;padding:2rem 2rem 4rem}
.page-list-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}
.page-list-cat-badge{display:inline-flex;align-items:center;gap:.4rem;
  font-size:.75rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;
  color:white;border-radius:var(--radius-sm);padding:.3rem .8rem;margin-bottom:.8rem}
.page-list-title{font-family:var(--serif);font-size:1.8rem;font-weight:700;
  color:var(--fg);margin-bottom:.4rem}
.page-list-sub{font-size:.9rem;color:var(--fg-muted)}

.article-list{list-style:none;margin-top:1rem}
.article-list-item{padding:1.2rem 0;border-bottom:1px solid var(--border);
  display:grid;grid-template-columns:1fr auto;gap:1rem;align-items:start}
.article-list-item:last-child{border-bottom:none}
.article-list-title{font-family:var(--serif);font-size:1.05rem;font-weight:600;
  color:var(--fg);margin-bottom:.3rem;display:block;line-height:1.35}
.article-list-title:hover{color:var(--accent);text-decoration:none}
.article-list-summary{font-size:.85rem;color:var(--fg-muted);line-height:1.6;margin-bottom:.5rem}
.article-list-tags{display:flex;flex-wrap:wrap;gap:.3rem}
.article-list-date{font-size:.78rem;color:var(--fg-faint);white-space:nowrap;
  padding-top:.2rem;text-align:right}

/* ══ 標籤頁 ══ */
.page-tag{max-width:var(--max-content);margin:0 auto;padding:2rem 2rem 4rem}
.page-tag-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}
.tag-badge{display:inline-block;font-size:.9rem;font-weight:500;
  color:var(--accent);background:var(--accent-light);
  border-radius:var(--radius-sm);padding:.3rem .8rem;margin-bottom:.8rem}
.page-tag-title{font-family:var(--serif);font-size:1.6rem;font-weight:700;
  color:var(--fg);margin-bottom:.4rem}
.page-tag-sub{font-size:.9rem;color:var(--fg-muted)}

/* ══ 文章頁 ══ */
.page-article{max-width:var(--max-content);margin:0 auto;padding:2rem 2rem 4rem;
  display:grid;grid-template-columns:1fr 220px;gap:3rem;align-items:start}
@media(max-width:860px){.page-article{grid-template-columns:1fr}.article-toc{display:none}}
.article-breadcrumb{font-size:.78rem;color:var(--fg-muted);margin-bottom:1.5rem;
  display:flex;align-items:center;flex-wrap:wrap;gap:.4rem}
.article-breadcrumb a{color:var(--fg-muted)}
.article-breadcrumb a:hover{color:var(--accent);text-decoration:none}
.article-breadcrumb .sep{color:var(--fg-faint)}
.article-cat-badge{display:inline-block;font-size:.7rem;font-weight:500;
  letter-spacing:.08em;text-transform:uppercase;color:white;
  border-radius:var(--radius-sm);padding:.2rem .6rem;margin-bottom:1rem}
.article-title{font-family:var(--serif);font-size:2.1rem;font-weight:700;
  line-height:1.25;color:var(--fg);margin-bottom:1rem}
.article-meta{display:flex;gap:1rem;align-items:center;flex-wrap:wrap;
  font-size:.8rem;color:var(--fg-muted);margin-bottom:2rem;
  padding-bottom:1.2rem;border-bottom:2px solid var(--fg)}
.article-tags{display:flex;gap:.4rem;flex-wrap:wrap}

/* 標籤通用 */
.tag{font-size:.72rem;padding:.15rem .55rem;border-radius:var(--radius-sm);
  background:var(--surface-alt);color:var(--fg-muted);
  border:1px solid var(--border);display:inline-block}
.tag-link{font-size:.72rem;padding:.15rem .55rem;border-radius:var(--radius-sm);
  background:var(--surface-alt);color:var(--fg-muted);
  border:1px solid var(--border);display:inline-block;
  transition:border-color .15s,color .15s}
.tag-link:hover{border-color:var(--accent);color:var(--accent);text-decoration:none}

/* 文章內文 */
.article-body{font-size:.95rem;line-height:1.9;color:var(--fg)}
.article-body h2{font-family:var(--serif);font-size:1.35rem;font-weight:600;
  margin:2.5rem 0 .8rem;color:var(--fg);padding-bottom:.4rem;
  border-bottom:1px solid var(--border)}
.article-body h3{font-family:var(--serif);font-size:1.1rem;font-weight:600;
  margin:1.8rem 0 .5rem;color:var(--fg)}
.article-body h4{font-size:.95rem;font-weight:500;margin:1.2rem 0 .4rem}
.article-body p{margin-bottom:1.2rem}
.article-body ul,.article-body ol{padding-left:1.5rem;margin-bottom:1.2rem}
.article-body li{margin-bottom:.4rem}
.article-body blockquote{border-left:3px solid var(--accent);padding:.5rem 1rem;
  color:var(--fg-muted);margin:1.5rem 0;font-style:italic;
  background:var(--accent-light);border-radius:0 var(--radius-sm) var(--radius-sm) 0}
.article-body pre{background:#1e1e1e;color:#d4d4d4;padding:1.2rem;
  border-radius:var(--radius);overflow-x:auto;font-size:.85rem;margin:1.5rem 0}
.article-body code{font-size:.88em;background:var(--surface-alt);
  padding:.1em .35em;border-radius:var(--radius-sm);border:1px solid var(--border)}
.article-body pre code{background:none;border:none;padding:0;color:inherit}
.article-body table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.88rem}
.article-body th,.article-body td{border:1px solid var(--border);padding:.5rem .8rem;text-align:left}
.article-body th{background:var(--surface-alt);font-weight:500;font-size:.8rem}
.article-body a{color:var(--accent)}
.private-link{color:var(--fg-faint);font-style:italic}

/* TOC */
.article-toc{position:sticky;top:72px}
.toc-label{font-size:.7rem;font-weight:500;letter-spacing:.1em;
  text-transform:uppercase;color:var(--fg-faint);margin-bottom:.6rem}
.toc-list{list-style:none;border-left:2px solid var(--border)}
.toc-item a{display:block;padding:.3rem .8rem;font-size:.8rem;
  color:var(--fg-muted);transition:color .15s}
.toc-item a:hover{color:var(--accent);text-decoration:none}
.toc-item.toc-h3 a{padding-left:1.4rem;font-size:.75rem}

/* 相關頁面 */
.related-section{margin-top:3rem}
.related-label{font-size:.7rem;font-weight:500;letter-spacing:.1em;
  text-transform:uppercase;color:var(--fg-faint);margin-bottom:.8rem}
.related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem}
.related-card{background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:.8rem 1rem;font-size:.85rem;
  color:var(--fg);transition:border-color .2s,box-shadow .2s;display:block}
.related-card:hover{border-color:var(--accent);box-shadow:0 2px 8px rgba(0,0,0,.05);
  text-decoration:none;color:var(--accent)}
.related-card-cat{font-size:.7rem;color:var(--fg-muted);margin-top:.2rem}

/* ══ 404 ══ */
.page-404{max-width:var(--max-content);margin:0 auto;
  padding:6rem 2rem;text-align:center}
.page-404-num{font-family:var(--serif);font-size:6rem;font-weight:700;
  color:var(--border-strong);line-height:1;margin-bottom:1rem}
.page-404-title{font-family:var(--serif);font-size:1.5rem;font-weight:600;
  color:var(--fg);margin-bottom:.75rem}
.page-404-sub{font-size:.9rem;color:var(--fg-muted);margin-bottom:2rem}
.btn-home{display:inline-block;background:var(--accent);color:white;
  padding:.6rem 1.4rem;border-radius:99px;font-size:.85rem;font-weight:500;
  transition:opacity .15s}
.btn-home:hover{opacity:.85;text-decoration:none;color:white}

/* ══ 頁腳 ══ */
.page-footer{max-width:var(--max-content);margin:0 auto;padding:1.5rem 2rem;
  border-top:1px solid var(--border);font-size:.78rem;color:var(--fg-faint);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}

/* ══ Pagefind ══ */
.search-container{margin:1rem 0 2rem}

/* ══ RWD ══ */
@media(max-width:640px){
  .site-header-inner{padding:0 1rem;gap:1rem}
  .header-nav{display:none}
  .page-home,.page-list,.page-tag,.page-article,.page-404{padding-left:1rem;padding-right:1rem}
  .hero-tagline{font-size:1.5rem}
  .stats-row{gap:.75rem}
  .stat-card{min-width:90px;padding:.7rem 1rem}
  .categories-grid{grid-template-columns:1fr}
  .article-title{font-size:1.6rem}
  .article-list-item{grid-template-columns:1fr}
  .article-list-date{text-align:left}
}
