
:root{--bg:#fbfaf7;--fg:#23201b;--muted:#7a736a;--card:#fff;--line:#e8e2d8;
--accent:#9a6b3f;--accent2:#c9a06a;--chip:#f0ebe2;--maxw:760px}
/* 深藍夜間模式（非純黑，柔和不刺眼）。auto 跟隨系統、可手動切換 */
@media(prefers-color-scheme:dark){:root:not([data-theme=light]){--bg:#0f1726;--fg:#dde5f0;
--muted:#8b97ab;--card:#172234;--line:#26344a;--accent:#e0a978;--accent2:#7fa8d8;--chip:#1b283c}}
:root[data-theme=dark]{--bg:#0f1726;--fg:#dde5f0;--muted:#8b97ab;--card:#172234;
--line:#26344a;--accent:#e0a978;--accent2:#7fa8d8;--chip:#1b283c}
.themebtn{cursor:pointer;border:1px solid var(--line);background:var(--card);color:var(--fg);
border-radius:8px;padding:4px 10px;font-size:13px}
/* 收藏星號：用 SVG 避免字元變豆腐方框 */
.star{cursor:pointer;display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);
background:var(--card);color:var(--fg);border-radius:10px;padding:7px 14px;font-size:14px}
.star svg{fill:var(--muted);stroke:none}
.star.on{border-color:var(--accent);color:var(--accent)}.star.on svg{fill:var(--accent)}
.favmini{cursor:pointer;background:none;border:none;padding:2px 2px;line-height:0;flex:none}
.favmini svg{fill:#cdc6b9;stroke:none;display:block}
@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .favmini svg{fill:#3d4860}}
:root[data-theme=dark] .favmini svg{fill:#3d4860}
.favmini:hover svg{fill:var(--accent)}.favmini.on svg{fill:var(--accent)}
.pager{display:flex;gap:10px;justify-content:space-between;margin:28px 0 8px;flex-wrap:wrap}
.pager a{flex:1;min-width:0;background:var(--card);border:1px solid var(--line);border-radius:12px;
padding:12px 14px;font-size:14px;line-height:1.4}.pager a.next{text-align:right}
.pager .lbl{display:block;font-size:11px;color:var(--muted)}
.tools{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0}.tools button,.tools label{cursor:pointer;
border:1px solid var(--line);background:var(--card);color:var(--fg);border-radius:8px;padding:8px 14px;font-size:14px}
*{box-sizing:border-box}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--fg);
/* 拉丁字體排前面：英文+標點(含彎引號)用拉丁字體(窄)，只有中文字才 fallback 到 CJK 字體，
   否則 Windows 會用中文字體把英文彎引號排成全形、標點旁出現大空白(2026-06-17 凱文發現) */
font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,"Noto Sans TC","PingFang TC","Microsoft JhengHei",sans-serif;
line-height:1.75;font-size:17px}
a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 18px}
header.top{position:sticky;top:0;z-index:10;background:color-mix(in srgb,var(--bg) 88%,transparent);
backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
header.top .wrap{display:flex;gap:6px;align-items:center;flex-wrap:wrap;padding-top:10px;padding-bottom:10px}
.hublink{font-size:18px;text-decoration:none;line-height:1;padding:2px 4px}
.hublink:hover{text-decoration:none;transform:scale(1.1)}
.brand{font-weight:700;margin-right:auto;font-size:15px}
kbd{font-family:monospace;background:var(--chip);border:1px solid var(--line);border-radius:4px;padding:0 5px;font-size:11px}
#hk-help{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:100;display:flex;align-items:center;justify-content:center}
.hk-box{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:20px 24px;max-width:330px;width:90%}
.hk-box h3{margin:0 0 12px}.hk-box table{width:100%;border-collapse:collapse;font-size:15px}
.hk-box td{padding:6px 4px;border-bottom:1px solid var(--line)}
.hk-box td:first-child{font-family:monospace;color:var(--accent);white-space:nowrap;width:78px;font-weight:600}
.hk-hint{color:var(--muted);font-size:12px;margin:12px 0 0;text-align:center}
/* 設定面板（⚙️）*/
.pa-modal{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:100;display:flex;align-items:center;justify-content:center}
.pa-box{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:20px 24px;max-width:360px;width:90%}
.pa-box h3{margin:0 0 16px}
.set-row{margin:0 0 16px}.set-lab{font-size:13px;color:var(--muted);margin-bottom:7px}
.set-opts{display:flex;gap:8px;flex-wrap:wrap}
.set-opt{cursor:pointer;border:1px solid var(--line);background:var(--bg);color:var(--fg);
border-radius:9px;padding:8px 14px;font-size:14px}
.set-opt.on{border-color:var(--accent);color:var(--accent);background:var(--chip);font-weight:600}
.set-reset{cursor:pointer;border:1px solid var(--line);background:none;color:var(--muted);
border-radius:9px;padding:7px 14px;font-size:13px;margin-top:4px}
/* 標題醒目度（nav.al 風格：文章標題用強調色、放大；小節標題也上色）*/
:root[data-title=bold] article.essay h1{color:var(--accent);font-size:30px}
:root[data-title=bold] article.essay .body h2{color:var(--accent)}
:root[data-title=bold] ul.list li a{color:var(--fg);font-weight:600}
/* 內文字級 */
:root[data-fs=large] article.essay .body{font-size:20px;line-height:2.05}
:root[data-fs=large] ul.list li a{font-size:18px}
:root[data-fs=large]{--maxw:820px}
nav a{font-size:14px;padding:5px 10px;border-radius:8px;color:var(--fg)}
nav a:hover{background:var(--chip);text-decoration:none}
.hero{padding:34px 0 18px}.hero h1{font-size:30px;margin:0 0 6px;letter-spacing:.5px}
.hero .sub{color:var(--muted);font-size:15px;line-height:1.7}
.stats{display:flex;gap:8px;flex-wrap:wrap;margin:18px 0}
.stat{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:10px 14px;flex:1;min-width:120px}
.stat b{display:block;font-size:22px;color:var(--accent)}.stat span{font-size:12px;color:var(--muted)}
.chips{display:flex;gap:7px;flex-wrap:wrap;margin:10px 0}
.chip{background:var(--chip);border:1px solid var(--line);border-radius:999px;padding:4px 12px;font-size:13px;color:var(--fg)}
h2.sec{font-size:13px;letter-spacing:1.5px;color:var(--muted);text-transform:uppercase;
margin:34px 0 12px;border-bottom:1px solid var(--line);padding-bottom:6px}
ul.list{list-style:none;padding:0;margin:0}
ul.list li{padding:11px 0;border-bottom:1px solid var(--line);display:flex;align-items:flex-start;gap:10px}
ul.list li .t{flex:1;min-width:0}
ul.list li a{font-weight:500}.meta{color:var(--muted);font-size:13px}
.tag{font-size:11px;color:var(--accent2);border:1px solid var(--line);border-radius:6px;padding:1px 6px;margin-left:6px}
.tag-new{color:#fff;background:var(--accent);border-color:var(--accent);font-weight:600}
.updated{font-size:13px;color:var(--muted);margin:10px 0 4px}.updated b{color:var(--fg)}
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px 18px;margin:12px 0}
.card h3{margin:0 0 8px;font-size:16px}
.search{width:100%;padding:12px 16px;font-size:16px;border:1px solid var(--line);
border-radius:12px;background:var(--card);color:var(--fg);margin:8px 0}
article.essay{padding:24px 0 60px}article.essay h1{font-size:26px;line-height:1.4;margin:0 0 10px}
article.essay .pmeta{color:var(--muted);font-size:14px;margin-bottom:8px}
article.essay .body{font-size:18px;line-height:1.95}
article.essay .body p{margin:1.1em 0}
/* ▉ 子標題 → H2，加左側強調條，作為閱讀錨點 */
article.essay .body h2{font-size:20px;margin-top:1.9em;margin-bottom:.5em;padding-left:12px;
border-left:4px solid var(--accent2);line-height:1.45;scroll-margin-top:84px}
article.essay .body h3{font-size:18px;scroll-margin-top:84px}
article.essay .body blockquote{border-left:3px solid var(--accent2);margin:1em 0;padding:.2em 1em;color:var(--muted)}
article.essay .body img{max-width:100%;height:auto;border-radius:8px}
.xpost{background:var(--chip);border-radius:10px;padding:10px 14px;font-size:14px;margin:14px 0}
.backlink{display:inline-block;margin:20px 0;font-size:14px}
/* 文章頁頂部操作排（← 分類 + ★收藏）：捲動時釘在主頂欄（高約 52px）下方 */
.essay-actions{position:sticky;top:52px;z-index:9;background:var(--bg);
display:flex;justify-content:space-between;align-items:center;gap:10px;
padding:8px 0;border-bottom:1px solid var(--line)}
.essay-actions .backlink{margin:0}
footer{color:var(--muted);font-size:12px;text-align:center;padding:30px 0;border-top:1px solid var(--line)}
.gate{font-size:12px;color:var(--muted);border:1px dashed var(--line);border-radius:8px;padding:8px 12px;margin:14px 0}
/* 懸浮目錄（TOC）：桌機在右側空白處浮動，手機隱藏（內文已分節即可） */
.toc{display:none}
@media(min-width:1180px){.toc{display:block;position:fixed;top:88px;
right:max(18px,calc((100vw - var(--maxw))/2 - 232px));width:212px;max-height:74vh;overflow:auto;
font-size:13px;line-height:1.5;border-left:1px solid var(--line);padding:2px 0 2px 14px}
.toc .tt{color:var(--muted);font-size:11px;letter-spacing:1.2px;margin-bottom:8px}
.toc a{display:block;color:var(--muted);padding:4px 0;text-decoration:none;
overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.toc a:hover{color:var(--accent);white-space:normal}
.toc a.active{color:var(--accent);font-weight:600;border-left:2px solid var(--accent);
margin-left:-16px;padding-left:14px}}
/* Part B 句段畫線（highlights）：半透明底隨日/夜自適應 */
mark.hl{color:inherit;border-radius:2px;padding:.04em 0;cursor:pointer;scroll-margin-top:92px;
background:rgba(255,213,0,.32)}
mark.hl-y{background:rgba(255,213,0,.32)}
mark.hl-g{background:rgba(52,199,89,.30)}
mark.hl-b{background:rgba(10,132,255,.26)}
mark.hl-p{background:rgba(191,90,242,.32)}
mark.hl[data-note]::after{content:"✎";font-size:.7em;vertical-align:super;color:var(--accent2);margin-left:1px}
mark.hl.flash{animation:hlflash 1.4s ease}
@keyframes hlflash{0%,100%{box-shadow:0 0 0 0 transparent}30%{box-shadow:0 0 0 3px var(--accent)}}
.hl-toolbar{position:fixed;z-index:120;display:flex;gap:5px;background:var(--card);border:1px solid var(--line);
border-radius:10px;padding:6px 7px;box-shadow:0 6px 24px rgba(0,0,0,.28)}
.hl-dot{width:20px;height:20px;border-radius:50%;border:1px solid var(--line);padding:0;cursor:pointer}
.hl-pop{position:fixed;z-index:121;background:var(--card);border:1px solid var(--line);border-radius:12px;
padding:12px;width:280px;box-shadow:0 8px 30px rgba(0,0,0,.32)}
.hl-pop textarea{width:100%;box-sizing:border-box;border:1px solid var(--line);border-radius:8px;
background:var(--bg);color:var(--fg);padding:8px;font-size:14px;font-family:inherit;min-height:58px;resize:vertical}
.hl-pop .row{display:flex;gap:6px;align-items:center;margin-top:8px;flex-wrap:wrap}
.hl-pop .row .sp{margin-left:auto}
.hl-pop button{cursor:pointer;border:1px solid var(--line);background:var(--bg);color:var(--fg);
border-radius:7px;padding:6px 12px;font-size:13px}
.hl-pop button.del{color:#ff5a5f;border-color:#ff5a5f}
/* 複習頁 */
#startRev{cursor:pointer;border:1px solid var(--accent);background:var(--chip);color:var(--accent);
border-radius:9px;padding:9px 18px;font-size:15px;font-weight:600;margin:4px 0 14px}
.rv-essay{margin:0 0 22px}
.rv-essay h3{font-size:16px;margin:18px 0 8px;border-bottom:1px solid var(--line);padding-bottom:5px}
.rv-card{background:var(--card);border:1px solid var(--line);border-left:4px solid var(--accent2);
border-radius:10px;padding:11px 14px;margin:8px 0}
.rv-card.hl-y{border-left-color:#e6b800}.rv-card.hl-g{border-left-color:#34c759}
.rv-card.hl-b{border-left-color:#0a84ff}.rv-card.hl-p{border-left-color:#bf5af2}
.rv-q{display:block;font-size:16px;line-height:1.65;color:var(--fg)}
.rv-q:hover{text-decoration:none;color:var(--accent)}
.rv-note{color:var(--muted);font-size:14px;margin-top:6px}
.rv-done{margin-top:9px;cursor:pointer;border:1px solid var(--line);background:var(--bg);color:var(--fg);
border-radius:8px;padding:6px 14px;font-size:13px}
