/* ===========================================================
   粗體誌 BOLDFACE — Neo-Brutalism 設計與城市文化線上誌
   配色與排版全以 CSS 變數控制
   =========================================================== */
:root{
  --ink:#141414;
  --paper:#f3efe4;
  --paper-2:#e7e1d2;
  --accent:#ffd400;   /* 強調黃 */
  --accent-2:#ff3b1f; /* 強調紅 */
  --accent-3:#1f4dff; /* 強調藍 */
  --white:#ffffff;
  --line:#141414;
  --shadow:6px 6px 0 var(--ink);
  --shadow-sm:4px 4px 0 var(--ink);
  --serif:"PingFang TC","Songti TC","Noto Serif TC",serif;
  --sans:"Helvetica Neue",Arial,"PingFang TC","Microsoft JhengHei",sans-serif;
  --mono:"SFMono-Regular",Consolas,"Liberation Mono",Menlo,monospace;
  --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ---------- 共用標記 / 標籤 ---------- */
.tag{
  display:inline-block;font-family:var(--mono);font-size:.72rem;
  letter-spacing:.12em;text-transform:uppercase;
  background:var(--ink);color:var(--paper);
  padding:4px 10px;border:2px solid var(--ink);
}
.tag.alt{background:var(--accent);color:var(--ink)}
.tag.red{background:var(--accent-2);color:var(--white)}
.tag.blue{background:var(--accent-3);color:var(--white)}

/* ---------- 頂部導覽 ---------- */
.skip{position:absolute;left:-999px}
.skip:focus{left:8px;top:8px;background:var(--accent);padding:8px;z-index:99;border:2px solid var(--ink)}
header.site{
  border-bottom:4px solid var(--ink);
  background:var(--paper);
  position:sticky;top:0;z-index:50;
}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:12px;font-weight:800}
.brand svg{display:block}
.brand .zh{font-size:1.35rem;letter-spacing:.04em}
.brand .en{font-family:var(--mono);font-size:.7rem;letter-spacing:.22em;background:var(--accent);padding:2px 6px;border:2px solid var(--ink)}
.nav ul{list-style:none;display:flex;gap:6px;align-items:center}
.nav ul a{
  font-family:var(--mono);font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;
  padding:8px 12px;border:2px solid transparent;
}
.nav ul a:hover,.nav ul a[aria-current="page"]{border:2px solid var(--ink);background:var(--accent);box-shadow:var(--shadow-sm)}
.navtoggle{display:none;font-family:var(--mono);font-size:.8rem;border:3px solid var(--ink);background:var(--accent);padding:8px 12px;cursor:pointer;text-transform:uppercase}

/* ---------- 區塊標題 ---------- */
.kicker{font-family:var(--mono);font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;display:inline-block;border-bottom:3px solid var(--ink);padding-bottom:4px;margin-bottom:18px}
h1,h2,h3{line-height:1.12;letter-spacing:-.01em}
h1{font-size:clamp(2.4rem,6vw,4.6rem);font-weight:800}
h2{font-size:clamp(1.8rem,3.6vw,2.8rem);font-weight:800;margin-bottom:18px}
h3{font-size:1.25rem;font-weight:800}
p{margin-bottom:1.05em}
.lead{font-size:1.18rem}

/* ---------- Hero ---------- */
.hero{border-bottom:4px solid var(--ink);background:var(--accent)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;min-height:74vh}
.hero-text{padding:56px 48px;display:flex;flex-direction:column;justify-content:center;border-right:4px solid var(--ink)}
.hero-text h1{margin:14px 0 18px}
.hero-text .lead{max-width:46ch}
.hero-media{position:relative;overflow:hidden;background:var(--ink)}
.hero-media img{width:100%;height:100%;object-fit:cover;filter:grayscale(.1) contrast(1.05)}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px}

/* ---------- 按鈕 ---------- */
.btn{
  display:inline-block;font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em;
  font-size:.85rem;font-weight:700;padding:14px 22px;border:3px solid var(--ink);
  background:var(--white);box-shadow:var(--shadow);transition:transform .08s,box-shadow .08s;cursor:pointer;
}
.btn:hover{transform:translate(2px,2px);box-shadow:var(--shadow-sm)}
.btn:active{transform:translate(6px,6px);box-shadow:0 0 0 var(--ink)}
.btn.solid{background:var(--ink);color:var(--paper)}
.btn.red{background:var(--accent-2);color:var(--white)}

/* ---------- 區段 ---------- */
section{padding:64px 0;border-bottom:4px solid var(--ink)}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:34px;flex-wrap:wrap}

/* ---------- 文章卡片格 ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:4px solid var(--ink);background:var(--ink)}
.cards.two{grid-template-columns:repeat(2,1fr)}
.card{background:var(--paper);border:2px solid var(--ink);display:flex;flex-direction:column}
.card .thumb{aspect-ratio:3/2;overflow:hidden;border-bottom:3px solid var(--ink);background:var(--paper-2)}
.card .thumb img{width:100%;height:100%;object-fit:cover}
.card .body{padding:22px;display:flex;flex-direction:column;gap:10px;flex:1}
.card .meta{font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:#555}
.card h3{margin:2px 0}
.card .more{margin-top:auto;font-family:var(--mono);font-size:.78rem;text-transform:uppercase;border-bottom:3px solid var(--accent-2);align-self:flex-start;padding-bottom:2px}
.card:hover h3{text-decoration:underline;text-decoration-thickness:3px}

/* ---------- 條列特色 ---------- */
.feature-row{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:4px solid var(--ink)}
.feature{padding:30px;border-right:3px solid var(--ink)}
.feature:last-child{border-right:none}
.feature .num{font-family:var(--mono);font-size:2.4rem;font-weight:800;color:var(--accent-2);line-height:1}
.feature h3{margin:10px 0 8px}

/* ---------- 雙欄 split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:0;border:4px solid var(--ink);align-items:stretch}
.split .pane{padding:40px}
.split .pane.media{padding:0;background:var(--ink);min-height:340px}
.split .pane.media img{width:100%;height:100%;object-fit:cover}
.split .pane.fill{background:var(--accent)}

/* ---------- 文章內文 ---------- */
.article{max-width:760px;margin:0 auto}
.article .hero-img{border:4px solid var(--ink);box-shadow:var(--shadow);margin:8px 0 36px;aspect-ratio:16/9;overflow:hidden}
.article .hero-img img{width:100%;height:100%;object-fit:cover}
.article-body p{font-size:1.08rem}
.article-body h2{margin-top:40px;font-size:1.7rem;border-left:8px solid var(--accent);padding-left:14px}
.article-body h3{margin-top:28px}
.article-body blockquote{border:3px solid var(--ink);background:var(--accent);padding:22px;margin:28px 0;font-size:1.3rem;font-weight:800;box-shadow:var(--shadow-sm)}
.article-body ul{margin:0 0 1.1em 1.3em}
.article-body li{margin-bottom:.4em}
.byline{font-family:var(--mono);font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;display:flex;gap:14px;flex-wrap:wrap;border-top:3px solid var(--ink);border-bottom:3px solid var(--ink);padding:14px 0;margin-bottom:30px}

/* ---------- 麵包屑 ---------- */
.crumbs{font-family:var(--mono);font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;padding:16px 0;color:#555}
.crumbs a:hover{color:var(--ink);text-decoration:underline}

/* ---------- 表單 ---------- */
.form{display:grid;gap:18px;max-width:620px}
.field label{display:block;font-family:var(--mono);font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}
.field input,.field textarea,.field select{
  width:100%;font-family:var(--sans);font-size:1rem;padding:13px 14px;
  border:3px solid var(--ink);background:var(--white);
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;box-shadow:var(--shadow-sm);background:#fffef5}
.note{font-family:var(--mono);font-size:.78rem;color:#555}

/* ---------- 跑馬燈 ---------- */
.marquee{overflow:hidden;border-bottom:4px solid var(--ink);background:var(--ink);color:var(--paper)}
.marquee div{display:inline-block;white-space:nowrap;font-family:var(--mono);text-transform:uppercase;letter-spacing:.2em;padding:12px 0;animation:scroll 28s linear infinite;font-size:.82rem}
.marquee span{padding:0 28px}
.marquee span b{color:var(--accent)}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- 頁尾 ---------- */
footer.site{background:var(--ink);color:var(--paper);padding:54px 0 30px}
footer.site .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:36px}
footer.site h4{font-family:var(--mono);font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);margin-bottom:14px}
footer.site a{color:var(--paper)}
footer.site a:hover{color:var(--accent);text-decoration:underline}
footer.site ul{list-style:none;display:grid;gap:8px;font-size:.95rem}
footer.site .fbrand{font-size:1.4rem;font-weight:800;margin-bottom:10px}
.colophon{border-top:2px solid #444;padding-top:18px;font-family:var(--mono);font-size:.74rem;letter-spacing:.04em;color:#bbb;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
.colophon b{color:var(--accent)}

/* ---------- 404 ---------- */
.err{min-height:60vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:60px 24px}
.err .big{font-size:clamp(5rem,18vw,12rem);font-weight:800;line-height:.9;color:var(--accent-2);-webkit-text-stroke:3px var(--ink)}

/* ---------- RWD ---------- */
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr}
  .hero-text{border-right:none;border-bottom:4px solid var(--ink);padding:40px 24px}
  .hero-media{min-height:46vh}
  .cards,.cards.two{grid-template-columns:1fr}
  .feature-row{grid-template-columns:1fr}
  .feature{border-right:none;border-bottom:3px solid var(--ink)}
  .feature:last-child{border-bottom:none}
  .split{grid-template-columns:1fr}
  .split .pane.media{min-height:240px}
  footer.site .cols{grid-template-columns:1fr;gap:28px}
  .nav ul{
    display:none;position:absolute;top:72px;left:0;right:0;flex-direction:column;gap:0;
    background:var(--paper);border-bottom:4px solid var(--ink);
  }
  .nav ul.open{display:flex}
  .nav ul li{border-top:2px solid var(--ink)}
  .nav ul a{display:block;padding:16px 24px}
  .nav ul a:hover,.nav ul a[aria-current="page"]{box-shadow:none}
  .navtoggle{display:inline-block}
}
@media(max-width:520px){
  .wrap{padding:0 16px}
  .hero-text{padding:32px 16px}
  section{padding:44px 0}
}
