/* 子頁共用樣式：延續筆記本紙感，但垂直捲動、語意化、無 JS（給人掃描、給機器抽取） */
:root{
  --paper:#f4ece0; --paper2:#efe5d4; --ink:#2b2620; --soft:#5c554a; --faint:#9a9082;
  --rule:#ddd0bb; --pen:#b23b2e; --pencil:#34597a;
  --serif:"Noto Serif TC","Songti TC",Georgia,serif;
  --mono:"JetBrains Mono",monospace;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  background:var(--paper);color:var(--ink);font-family:var(--serif);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  background-image:linear-gradient(var(--rule) 1px,transparent 1px);
  background-size:100% 38px;line-height:1.9;
}
::selection{background:var(--pen);color:var(--paper);}
a{color:var(--pen);text-decoration:none;border-bottom:1px solid rgba(178,59,46,.35);transition:border-color .2s;}
a:hover{border-bottom-color:var(--pen);}
:focus-visible{outline:2px solid var(--pen);outline-offset:3px;border-radius:2px;}

.wrap{max-width:760px;margin:0 auto;padding:0 24px 80px;}

/* 頂部導覽 */
.nav{display:flex;align-items:baseline;gap:18px;padding:26px 0 10px;font-family:var(--mono);font-size:13.5px;flex-wrap:wrap;}
.nav .home{font-weight:700;color:var(--ink);border-bottom:none;margin-right:auto;}
.nav a{color:var(--soft);border-bottom-color:transparent;}
.nav a:hover,.nav a[aria-current]{color:var(--pen);border-bottom-color:var(--pen);}

h1{font-size:clamp(28px,5vw,40px);line-height:1.3;margin:38px 0 6px;font-weight:900;}
.tagline{color:var(--soft);font-size:16.5px;margin-bottom:8px;}
h2{font-size:clamp(21px,3.4vw,26px);margin:54px 0 14px;font-weight:700;
  padding-bottom:8px;border-bottom:2px solid var(--rule);}
h3{font-size:18px;margin:28px 0 8px;font-weight:700;}
p{margin:12px 0;color:var(--soft);}
p b,li b{color:var(--ink);}
ul,ol{margin:12px 0 12px 1.4em;color:var(--soft);}
li{margin:6px 0;}
.kicker{font-family:var(--mono);font-size:12.5px;letter-spacing:.12em;color:var(--faint);margin-top:46px;}

/* 事實表（機器抽取友善） */
dl.facts{display:grid;grid-template-columns:max-content 1fr;gap:8px 22px;margin:16px 0;}
dl.facts dt{font-family:var(--mono);font-size:13px;color:var(--faint);padding-top:3px;white-space:nowrap;}
dl.facts dd{color:var(--soft);}
dl.facts dd b{color:var(--ink);}

/* 卡片（作品列表） */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:18px;margin:18px 0;}
.pcard{background:#fffdf7;border:1px solid #e3d9c6;padding:14px 16px 16px;box-shadow:2px 4px 12px rgba(43,38,32,.08);}
.pcard img{display:block;width:100%;height:110px;object-fit:cover;object-position:top;border:1px solid #e7ddc9;margin-bottom:10px;}
.pcard .nm{font-weight:700;font-size:16.5px;color:var(--ink);}
.pcard .meta{font-family:var(--mono);font-size:10.5px;color:var(--pen);margin:2px 0 6px;}
.pcard p{font-size:13.5px;line-height:1.65;margin:0 0 8px;}
.pcard a{font-family:var(--mono);font-size:12px;}

/* 步驟 */
ol.steps{counter-reset:s;list-style:none;margin:18px 0;}
ol.steps>li{counter-increment:s;position:relative;padding:0 0 18px 52px;}
ol.steps>li::before{content:counter(s);position:absolute;left:0;top:2px;width:34px;height:34px;
  border:2px solid var(--pen);border-radius:50%;color:var(--pen);font-family:var(--mono);font-weight:700;
  display:flex;align-items:center;justify-content:center;font-size:16px;background:#fffdf7;}
ol.steps b{display:block;color:var(--ink);font-size:16.5px;}

/* FAQ */
.faq details{border-bottom:1px solid var(--rule);padding:4px 0;}
.faq summary{cursor:pointer;font-weight:700;color:var(--ink);padding:10px 0;font-size:16px;list-style-position:outside;}
.faq summary:hover{color:var(--pen);}
.faq details p{margin:4px 0 14px;}

/* 重點框 */
.callout{background:#fffdf7;border:1px solid #e3d9c6;border-left:4px solid var(--pen);
  padding:14px 18px;margin:20px 0;box-shadow:2px 4px 12px rgba(43,38,32,.06);}
.callout p{margin:4px 0;}

/* case 頁 hero 圖 */
.shot-lg{display:block;width:100%;border:1px solid #e3d9c6;box-shadow:2px 5px 16px rgba(43,38,32,.12);margin:20px 0;}

/* 頁尾 */
footer{margin-top:70px;padding-top:18px;border-top:2px solid var(--rule);
  font-family:var(--mono);font-size:13px;color:var(--faint);display:flex;gap:14px;flex-wrap:wrap;}
footer a{color:var(--pen);}

table{border-collapse:collapse;width:100%;margin:14px 0;font-size:14.5px;}
th,td{text-align:left;padding:8px 12px;border-bottom:1px solid var(--rule);color:var(--soft);}
th{font-family:var(--mono);font-size:12.5px;color:var(--faint);font-weight:400;}
td b{color:var(--ink);}

@media (max-width:560px){
  dl.facts{grid-template-columns:1fr;gap:2px;}
  dl.facts dt{margin-top:10px;}
}
