/* ============================================================
   吳維文 個人網站 — 設計系統
   風格沿用 URSI GASS 2026「行程手札」(dist)：報紙刊頭 / 古典襯線編輯風
   ============================================================ */
:root {
  --paper: #f4efe3;
  --surface: #fbf8f1;
  --ink: #23201a;
  --muted: #6f6757;
  --accent: #1d3557;
  --accent-soft: #e8ecf2;
  --gold: #9a7b4f;
  --highlight: #8a5224;
  --done: #3f6b3f;
  --border: #d9d0bd;
  --radius: 2px;
  --content-w: 760px;
  --serif: "Noto Serif TC", Georgia, "Times New Roman", "PMingLiU", "MingLiU", serif;
}
@media (min-width: 1024px) { :root { --content-w: 1100px; } }
@media (min-width: 1440px) { :root { --content-w: 1280px; } }

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--serif);
  color: var(--ink);
  background: var(--paper);
  line-height: 1.85;
  font-size: 17px;
}
a { color: var(--accent); }

.container { max-width: var(--content-w); margin: 0 auto; padding: 2.5rem 1.5rem 3rem; }

/* ---------- 刊頭 Masthead ---------- */
.masthead { background: var(--paper); border-top: 3px double var(--accent); border-bottom: 1px solid var(--border); }
.masthead-inner {
  max-width: var(--content-w); margin: 0 auto; padding: 1rem 1.5rem;
  display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: .4rem 1.5rem;
}
.brand { display: flex; align-items: center; gap: .7rem; text-decoration: none; color: var(--ink); }
.brand-avatar { width: 42px; height: 42px; border-radius: 50%; object-fit: cover; object-position: center 20%; border: 1px solid var(--border); flex-shrink: 0; background: var(--surface); }
.brand-text { display: flex; flex-direction: column; line-height: 1.25; }
.brand-title { font-size: 1.4rem; font-weight: 700; letter-spacing: .1em; }
.brand-kicker { font-size: .68rem; letter-spacing: .16em; color: var(--muted); }
.nav-wrap { display: flex; align-items: center; gap: 1.2rem; flex-wrap: wrap; }
.site-nav { display: flex; flex-wrap: wrap; gap: 1.4rem; }
.site-nav a {
  text-decoration: none; color: var(--muted); font-size: .98rem; letter-spacing: .05em;
  padding-bottom: 2px; border-bottom: 2px solid transparent; transition: color .15s, border-color .15s;
}
.site-nav a:hover { color: var(--accent); }
.site-nav a.active { color: var(--accent); font-weight: 700; border-bottom-color: var(--gold); }

/* ---------- 語言切換 ---------- */
.lang-toggle { display: inline-flex; border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
.lang-toggle button {
  font-family: var(--serif); font-size: .82rem; letter-spacing: .05em;
  background: var(--surface); color: var(--muted); border: none; padding: .25rem .6rem; cursor: pointer;
  transition: background .15s, color .15s;
}
.lang-toggle button + button { border-left: 1px solid var(--border); }
.lang-toggle button[aria-pressed="true"] { background: var(--accent); color: #fff; font-weight: 700; }

/* ---------- 標題與排版 ---------- */
h1 { font-size: 1.95rem; font-weight: 700; letter-spacing: .04em; margin: 0 0 .3rem; }
.lead { color: var(--muted); font-style: italic; margin: 0 0 1.5rem; padding-bottom: 1.25rem; border-bottom: 1px solid var(--border); }
h2 { font-size: 1.3rem; font-weight: 600; margin: 2.25rem 0 1rem; padding-bottom: .4rem; border-bottom: 1px solid var(--border); }
h3 { font-weight: 600; }
p { margin: 0 0 1rem; }

/* ---------- 卡片 / 標籤 ---------- */
.card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.3rem 1.5rem; }
.pill {
  display: inline-block; font-size: .68rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase;
  padding: .12rem .55rem; border: 1px solid var(--accent); border-radius: var(--radius); color: var(--accent); background: transparent; vertical-align: middle;
}
.pill.tbd { border-color: var(--muted); color: var(--muted); }
.pill.done { border-color: var(--done); color: var(--done); }
.pill.highlight { border-color: var(--highlight); color: var(--highlight); }

/* 技術棧小標籤 */
.tags { display: flex; flex-wrap: wrap; gap: .4rem; margin: .6rem 0 0; padding: 0; list-style: none; }
.tag {
  font-size: .72rem; letter-spacing: .03em; color: var(--muted);
  background: var(--accent-soft); border: 1px solid var(--border); border-radius: var(--radius); padding: .1rem .5rem;
}

/* ---------- 定義列表 ---------- */
.info { display: grid; grid-template-columns: max-content 1fr; gap: .4rem 1rem; margin: 0; }
.info dt { font-weight: 700; color: var(--muted); }
.info dd { margin: 0; }
@media (max-width: 480px) { .info { grid-template-columns: 1fr; gap: .1rem; } .info dd { margin-bottom: .5rem; } }

/* ---------- Hero (首頁) ---------- */
.hero-kicker { font-size: .74rem; letter-spacing: .2em; text-transform: uppercase; color: var(--gold); margin: 0 0 .6rem; }
.hero h1 { font-size: 2.4rem; }
.hero .role { font-size: 1.15rem; color: var(--accent); font-weight: 600; margin: .2rem 0 .8rem; }

/* ---------- 統計格 ---------- */
.grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; margin-bottom: 1.5rem; border: 1px solid var(--border); border-radius: var(--radius); background: var(--surface); }
.stat { display: flex; flex-direction: column; gap: .2rem; text-align: center; padding: 1.2rem .75rem; border-right: 1px solid var(--border); }
.stat:last-child { border-right: none; }
.stat-label { font-size: .72rem; letter-spacing: .16em; text-transform: uppercase; color: var(--muted); }
.stat-value { font-size: 1.5rem; font-weight: 700; color: var(--accent); }
.stat-note { font-size: .82rem; color: var(--muted); }
@media (max-width: 720px) { .grid { grid-template-columns: repeat(2, 1fr); } .stat:nth-child(2) { border-right: none; } .stat:nth-child(1), .stat:nth-child(2) { border-bottom: 1px solid var(--border); } }
@media (max-width: 420px) { .grid { grid-template-columns: 1fr; } .stat { border-right: none; border-bottom: 1px solid var(--border); } .stat:last-child { border-bottom: none; } }

/* ---------- 重點 / 海報卡 ---------- */
.feature { border-left: 4px solid var(--highlight); }

/* ---------- 快速前往 ---------- */
.quick { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: .75rem; }
.quick-link { display: flex; justify-content: space-between; align-items: center; text-decoration: none; color: var(--ink); font-weight: 600; transition: border-color .15s, color .15s; }
.quick-link .arr { color: var(--gold); }
.quick-link:hover { border-color: var(--accent); color: var(--accent); }

/* ---------- 時間軸 (經歷) ---------- */
.timeline { list-style: none; margin: 0; padding: 0; }
.tl-item { position: relative; padding: 0 0 1.6rem 1.6rem; border-left: 2px solid var(--border); }
.tl-item:last-child { border-left-color: transparent; padding-bottom: 0; }
.tl-item::before { content: ""; position: absolute; left: -7px; top: .55rem; width: 12px; height: 12px; border-radius: 50%; background: var(--paper); border: 2px solid var(--gold); }
.tl-period { font-size: .78rem; letter-spacing: .08em; color: var(--muted); text-transform: uppercase; }
.tl-role { margin: .15rem 0 .15rem; font-size: 1.08rem; }
.tl-org { color: var(--accent); font-weight: 600; }

/* ---------- 專案格 ---------- */
.proj-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1rem; }
.proj-card { display: flex; flex-direction: column; }
.proj-card[data-category] { display: flex; } /* Default visible */
.proj-card.hide { display: none !important; }

/* ---------- 專案過濾器 ---------- */
.filter-wrap { margin: 1.5rem 0 1.2rem; }
.filter-tabs { display: flex; flex-wrap: wrap; gap: .5rem; border-bottom: 1px solid var(--border); padding-bottom: .8rem; }
.filter-btn {
  font-family: var(--serif); font-size: .9rem; font-weight: 600; letter-spacing: .05em;
  background: var(--surface); color: var(--muted); border: 1px solid var(--border);
  padding: .35rem 1rem; cursor: pointer; border-radius: var(--radius);
  transition: all .15s;
}
.filter-btn:hover { border-color: var(--accent); color: var(--accent); }
.filter-btn.active { background: var(--accent); color: #fff; border-color: var(--accent); }

/* ---------- 技能 ---------- */
.skill-block { margin-bottom: 1rem; }
.skill-block .skill-label { font-size: .74rem; letter-spacing: .14em; text-transform: uppercase; color: var(--gold); margin: 0 0 .4rem; }

/* ---------- 研究圖 ---------- */
.fig-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: .8rem; margin: 1rem 0; }
.fig-row figure { margin: 0; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: .6rem; text-align: center; }
.fig-row img { display: block; width: 100%; height: auto; }
.fig-row figcaption { font-size: .78rem; color: var(--muted); margin-top: .4rem; }

/* ---------- 按鈕 / 連結格 ---------- */
.btn { display: inline-block; text-decoration: none; font-weight: 700; color: #fff; background: var(--accent); padding: .6rem 1.1rem; border-radius: var(--radius); letter-spacing: .04em; transition: background .15s; }
.btn:hover { background: var(--highlight); }
.btn.ghost { color: var(--accent); background: transparent; border: 1px solid var(--accent); }
.btn.ghost:hover { color: #fff; background: var(--accent); }
.links { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: .5rem; }
.links a { display: flex; justify-content: space-between; align-items: center; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: .7rem 1rem; text-decoration: none; font-weight: 600; color: var(--ink); transition: background .15s; }
.links a:hover { background: var(--accent-soft); }
.links a .arr { color: var(--gold); }

/* ---------- Footer ---------- */
.site-footer { text-align: center; color: var(--muted); font-size: .85rem; font-style: italic; padding: 1rem 1rem 3rem; }
.footer-rule { display: block; width: 60px; height: 1px; background: var(--gold); margin: 0 auto 1rem; }

/* ---------- 專案縮圖 ---------- */
.proj-card { overflow: hidden; }
.proj-thumb { display: block; margin: -1.3rem -1.5rem 1rem; border-bottom: 1px solid var(--border); background: var(--paper); aspect-ratio: 16 / 10; overflow: hidden; }
.proj-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* ---------- 獲獎與證明 ---------- */
.cred-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 1rem; }
.cred { display: flex; flex-direction: column; text-decoration: none; color: var(--ink); background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; transition: border-color .15s, box-shadow .15s; }
.cred:hover { border-color: var(--accent); box-shadow: 0 2px 10px rgba(29, 53, 87, .08); }
.cred-thumb { aspect-ratio: 4 / 3; background: var(--paper); border-bottom: 1px solid var(--border); overflow: hidden; }
.cred-thumb img { width: 100%; height: 100%; object-fit: cover; object-position: top center; display: block; }
.cred-body { padding: .7rem .9rem .8rem; }
.cred-title { font-size: .9rem; font-weight: 600; line-height: 1.4; color: var(--ink); }
.cred-meta { font-size: .76rem; color: var(--muted); margin-top: .2rem; }
.cred-link { display: inline-block; margin-top: .4rem; font-size: .76rem; color: var(--gold); letter-spacing: .03em; }

/* ---------- 可點擊專案卡 ---------- */
a.proj-card { color: var(--ink); text-decoration: none; transition: border-color .15s, box-shadow .15s, transform .15s; }
a.proj-card:hover { border-color: var(--accent); box-shadow: 0 3px 16px rgba(29, 53, 87, .10); transform: translateY(-2px); }
.card-more { margin-top: auto; padding-top: .7rem; color: var(--gold); font-weight: 600; font-size: .9rem; }

/* ---------- 專案詳情頁 ---------- */
.detail-back { display: inline-block; margin-bottom: 1rem; color: var(--muted); font-size: .92rem; text-decoration: none; }
.detail-back:hover { color: var(--accent); }
.detail-hero { margin: .6rem 0 1.5rem; border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; background: var(--surface); }
.detail-hero img { display: block; width: 100%; height: auto; }

/* ---------- 影片 ---------- */
.demo-video { width: 100%; max-width: 720px; display: block; margin: .4rem auto 0; border: 1px solid var(--border); border-radius: var(--radius); background: #000; }

/* ---------- 雙語切換 ---------- */
html[data-lang="en"] .zh { display: none !important; }
html[data-lang="zh"] .en { display: none !important; }
