/* =====================================================================
   article.css — 靜態深度頁(/dish/ /spot/ /city/)專用樣式
   feat-* 規則原樣取自 index.html,確保靜態頁與 SPA 深度頁外觀一致。
   靜態頁為獨立文件:用 prefers-color-scheme 自動深色,不依賴 SPA 的 body.dark。
   ===================================================================== */
:root{
  --bg:#FAF8F4; --paper:#FFFFFF; --green:#1A3D3A; --orange:#C75B39;
  --ink:#1F1814; --muted:#8A7E6F; --line:#E5DFD3; --gold:#D9A14B;
  --shadow:0 4px 24px rgba(31,24,20,.10);
  --serif:"Noto Serif TC", Georgia, serif;
}
@media (prefers-color-scheme: dark){
  :root{
    --bg:#2A241D; --paper:#221C16; --green:#9DBBB2; --orange:#E8A06E;
    --ink:#F2ECE3; --muted:#A89B8C; --line:rgba(242,236,227,.14); --gold:#E6BC6A;
    --shadow:0 6px 28px rgba(0,0,0,.45);
  }
}
*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  font-family:Inter, system-ui, "PingFang TC", "Noto Sans TC", "Microsoft JhengHei", sans-serif;
  color:var(--ink); background:var(--bg); line-height:1.6;
}
a{ color:inherit; }

/* ---------- 頂部列(品牌 + 語言) ---------- */
.site-bar{
  position:sticky; top:0; z-index:10;
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:11px 20px; background:color-mix(in srgb, var(--bg) 88%, transparent);
  backdrop-filter:blur(8px); border-bottom:1px solid var(--line);
}
.site-bar .brand{ font-family:var(--serif); font-weight:700; font-size:16px; letter-spacing:.04em; color:var(--green); text-decoration:none; }
.site-bar .brand span{ color:var(--orange); }
.site-bar .langs{ display:flex; gap:6px; font-size:12.5px; }
.site-bar .langs a{ padding:4px 10px; border-radius:999px; border:1px solid var(--line); text-decoration:none; color:var(--muted); }
.site-bar .langs a.on{ background:var(--green); color:var(--paper); border-color:var(--green); }

/* ---------- 麵包屑 ---------- */
.crumbs{ max-width:1200px; margin:0 auto; padding:16px 40px 0; font-size:12.5px; color:var(--muted); }
.crumbs a{ text-decoration:none; color:var(--muted); }
.crumbs a:hover{ color:var(--orange); }
.crumbs .sep{ margin:0 7px; opacity:.6; }

/* ---------- 文章主體(取自 index.html .feat-*) ---------- */
.feat-wrap{ max-width:1200px; margin:0 auto; padding:0 40px 90px; }
.feat-hero{ position:relative; height:min(58vh,500px); margin-bottom:8px; }
.feat-hero img{ width:100%; height:100%; object-fit:cover; display:block; }
/* 靜態頁多半無代表圖(build 期不抓 wiki) → noimg 整塊上墨綠底,標題用淺色字才讀得到 */
.feat-hero.noimg{ height:auto; background:var(--green); }
.feat-hero.noimg img{ display:none; }
.feat-hero .scrim{ position:absolute; inset:0;
  background:linear-gradient(to top, rgba(18,14,11,.86) 0%, rgba(18,14,11,.12) 52%, rgba(18,14,11,.34) 100%); }
.feat-hero.noimg .scrim{ display:none; }
.feat-hero .htext{ position:absolute; left:0; right:0; bottom:0; padding:34px 40px; max-width:1200px; margin:0 auto; color:#F5EFE6; }
.feat-hero.noimg .htext{ position:static; padding:54px 40px 40px; }
.feat-hero h1{ font-family:var(--serif); font-size:clamp(27px,5vw,42px); font-weight:700; letter-spacing:.03em; line-height:1.22; }
.feat-hero .sub{ font-size:13.5px; opacity:.82; margin-top:8px; letter-spacing:.05em; }
.feat-hero .meta{ display:flex; flex-wrap:wrap; gap:8px 10px; margin-top:16px; font-size:12.5px; }
.feat-hero .meta span{ background:rgba(255,255,255,.17); padding:5px 12px; border-radius:999px; backdrop-filter:blur(4px); }

.feat-lead{ font-family:var(--serif); font-size:21px; line-height:1.9; color:var(--ink); margin:30px 0 8px; max-width:920px; }
.feat-h{ font-family:var(--serif); font-size:23px; font-weight:700; color:var(--green); letter-spacing:.05em;
  margin:44px 0 18px; padding-bottom:9px; border-bottom:2px solid var(--orange); display:inline-block; }
.feat-p{ font-size:15.5px; line-height:2; color:var(--ink); margin-bottom:15px; }
.feat-fig{ margin:10px 0 26px; }
.feat-fig img{ width:100%; border-radius:14px; display:block; box-shadow:var(--shadow); }
.feat-fig figcaption{ font-size:12px; color:var(--muted); margin-top:9px; letter-spacing:.03em; text-align:center; }

.feat-split{ display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center; margin:14px 0 32px; }
.feat-split.rev .feat-split-txt{ order:2; }
.feat-split-txt .feat-p:last-child{ margin-bottom:0; }
.feat-split figure{ margin:0; }
.feat-split img{ width:100%; aspect-ratio:4/3; object-fit:cover; border-radius:14px; box-shadow:var(--shadow); display:block; }
.feat-split figcaption{ font-size:12px; color:var(--muted); margin-top:9px; text-align:center; }

.feat-duo{ display:grid; grid-template-columns:1fr 1fr; gap:18px; margin:10px 0 28px; }
.feat-duo figure{ margin:0; }
.feat-duo img{ width:100%; aspect-ratio:16/10; object-fit:cover; border-radius:12px; box-shadow:var(--shadow); display:block; }
.feat-duo figcaption{ font-size:12px; color:var(--muted); margin-top:8px; text-align:center; }

.feat-trio{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin:10px 0 28px; }
.feat-trio figure{ margin:0; }
.feat-trio img{ width:100%; aspect-ratio:3/4; object-fit:cover; border-radius:12px; box-shadow:var(--shadow); display:block; }
.feat-trio figcaption{ font-size:12px; color:var(--muted); margin-top:8px; text-align:center; }

.feat-cards{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:16px; margin:10px 0 28px; }
.feat-card{ padding:20px; border:1px solid var(--line); border-radius:14px; background:var(--paper); box-shadow:var(--shadow); }
.feat-card .ic{ font-size:27px; display:block; line-height:1; margin-bottom:12px; }
.feat-card .ct b{ display:block; font-size:15.5px; margin-bottom:7px; color:var(--ink); letter-spacing:.02em; }
.feat-card .ct span{ font-size:13.5px; line-height:1.85; color:var(--muted); }
.feat-tips2{ display:grid; grid-template-columns:1fr 1fr; gap:18px; align-items:start; margin:8px 0 28px; }
.feat-tips2 .feat-tips{ margin:0; }
.feat-tips{ background:rgba(199,123,69,.07); border:1px solid var(--line); border-radius:14px; padding:19px 22px; margin:8px 0 26px; }
.feat-tips h4{ font-family:var(--serif); font-size:15.5px; color:var(--orange); letter-spacing:.08em; margin-bottom:12px; }
.feat-tips ul{ list-style:none; }
.feat-tips li{ position:relative; font-size:14px; line-height:1.8; color:var(--ink); margin-bottom:9px; padding-left:18px; }
.feat-tips li::before{ content:'›'; position:absolute; left:2px; color:var(--orange); font-weight:700; }
.feat-foot{ font-size:11.5px; color:var(--muted); line-height:1.9; margin-top:34px; padding-top:18px; border-top:1px solid var(--line); }

/* ---------- 文章底部交叉連結 ---------- */
.xlinks{ display:flex; flex-wrap:wrap; gap:12px; margin:30px 0 0; }
.xlinks a{
  display:inline-flex; align-items:center; gap:7px; padding:11px 18px; border-radius:10px;
  font-size:13.5px; font-weight:600; letter-spacing:.04em; text-decoration:none;
  border:1px solid var(--line); background:var(--paper); color:var(--ink); box-shadow:var(--shadow);
  transition:opacity .15s ease;
}
.xlinks a.primary{ background:var(--green); color:var(--paper); border-color:var(--green); }
.xlinks a:hover{ opacity:.9; }

/* ---------- 城市彙整頁 ---------- */
.city-head{ max-width:1200px; margin:0 auto; padding:30px 40px 6px; }
.city-head h1{ font-family:var(--serif); font-size:clamp(26px,4.5vw,40px); font-weight:700; color:var(--green); letter-spacing:.03em; }
.city-head .sub{ font-size:14px; color:var(--muted); margin-top:8px; letter-spacing:.05em; }
.city-head .lead{ font-family:var(--serif); font-size:18px; line-height:1.85; color:var(--ink); margin-top:18px; max-width:920px; }
.city-sec{ max-width:1200px; margin:0 auto; padding:8px 40px; }
.city-sec h2{ font-family:var(--serif); font-size:21px; font-weight:700; color:var(--green); letter-spacing:.05em;
  margin:34px 0 16px; padding-bottom:8px; border-bottom:2px solid var(--orange); display:inline-block; }
.item-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:16px; }
.item-card{
  display:block; padding:18px 20px; border:1px solid var(--line); border-radius:14px;
  background:var(--paper); box-shadow:var(--shadow); text-decoration:none; color:var(--ink);
  transition:transform .12s ease, box-shadow .12s ease;
}
.item-card:hover{ transform:translateY(-2px); box-shadow:0 8px 30px rgba(31,24,20,.16); }
.item-card .ic{ font-size:22px; }
.item-card .nm{ font-family:var(--serif); font-size:17px; font-weight:700; margin:8px 0 4px; color:var(--ink); }
.item-card .nm small{ display:block; font-family:inherit; font-weight:500; font-size:12px; color:var(--muted); margin-top:3px; letter-spacing:.02em; }
.item-card .ar{ font-size:12.5px; color:var(--muted); }
.item-card .nt{ font-size:13px; color:var(--muted); line-height:1.7; margin-top:8px;
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }

.page-foot{ max-width:1200px; margin:0 auto; padding:40px; font-size:11.5px; color:var(--muted); line-height:1.9; border-top:1px solid var(--line); }
.page-foot a{ color:var(--muted); }

/* ---------- 響應式 ---------- */
@media (max-width:767px){
  .crumbs{ padding:14px 18px 0; }
  .feat-wrap{ padding:0 18px 70px; }
  .feat-hero{ height:min(48vh,360px); }
  .feat-hero .htext{ padding:24px 18px; }
  .feat-lead{ font-size:18px; }
  .feat-split{ grid-template-columns:1fr; gap:18px; }
  .feat-split.rev .feat-split-txt{ order:0; }
  .feat-trio{ grid-template-columns:1fr 1fr; }
  .feat-tips2{ grid-template-columns:1fr; }
  .city-head, .city-sec{ padding-left:18px; padding-right:18px; }
  .page-foot{ padding:30px 18px; }
}
