   LAWS VIEW
═══════════════════════════════════ */
.laws-search {
  position: sticky; top: var(--hdr-h); z-index: 40;
  background: var(--c-bg); border-bottom: 1px solid var(--c-border);
  padding: 12px 16px;
}

/* Laws sub-tabs (全部 / 高頻) */
.laws-tabs {
  display: flex; gap: 4px; padding: 8px 12px;
  background: var(--c-bg); border-bottom: 1px solid var(--c-border);
  position: sticky; top: var(--hdr-h); z-index: 41;
}
.laws-tab {
  flex: 1; padding: 10px 14px; font-size: .88rem; font-weight: 600;
  background: transparent; border: 1px solid transparent; border-radius: 8px;
  color: var(--c-muted); cursor: pointer; transition: all .15s;
}
.laws-tab.active {
  background: var(--c-surface); color: var(--c-primary);
  border-color: var(--c-border); box-shadow: var(--shadow-sm);
}
@media (hover:hover) { .laws-tab:hover:not(.active) { color: var(--c-text); } }
.laws-tab + .laws-search { top: calc(var(--hdr-h) + 50px); }

/* Hot laws view */
.law-hot-list { padding: 0 0 80px; }
.law-hot-list.hidden { display: none; }
.law-hot-loading { padding: 40px; text-align: center; color: var(--c-muted); }
.law-hot-hdr {
  padding: 18px 20px 14px; background: var(--c-surface);
  border-bottom: 1px solid var(--c-border);
}
.law-hot-hdr h2 {
  font-size: 1.18rem; font-weight: 700; margin: 0 0 4px;
  color: var(--c-text);
}
.law-hot-hdr p { font-size: .82rem; color: var(--c-muted); margin: 0 0 14px; }
.law-hot-progress { margin-bottom: 12px; }
.lhp-bar {
  width: 100%; height: 6px; background: var(--c-surface2);
  border-radius: 3px; overflow: hidden; margin-bottom: 4px;
}
.lhp-fill { height: 100%; background: var(--c-primary); transition: width .3s; }
.lhp-text { font-size: .76rem; color: var(--c-muted); }
.lhp-text strong { color: var(--c-text); }

.law-hot-exam-toggle {
  display: inline-flex; gap: 0; background: var(--c-surface2);
  border-radius: 999px; padding: 3px;
}
.lhe-btn {
  padding: 6px 16px; font-size: .82rem; font-weight: 600;
  background: transparent; border: none; color: var(--c-muted);
  border-radius: 999px; cursor: pointer; transition: all .15s;
}
.lhe-btn.active {
  background: var(--c-surface); color: var(--c-primary);
  box-shadow: var(--shadow-sm);
}

.law-filter-chips {
  display: flex; gap: 6px; flex-wrap: wrap;
  padding: 12px 20px; background: var(--c-bg);
  border-bottom: 1px solid var(--c-border); position: sticky;
  top: calc(var(--hdr-h) + 50px); z-index: 30;
}
.law-filter-chip {
  padding: 5px 12px; font-size: .76rem; font-weight: 600;
  background: var(--c-surface); border: 1px solid var(--c-border);
  border-radius: 999px; color: var(--c-muted); cursor: pointer;
  transition: all .15s; white-space: nowrap;
}
.law-filter-chip.active {
  background: var(--c-primary); color: var(--c-primary-fg, #fff);
  border-color: var(--c-primary);
}
@media (hover:hover) {
  .law-filter-chip:hover:not(.active) { border-color: var(--c-primary); color: var(--c-primary); }
}

.hot-rows { padding: 0; }
.hot-row {
  display: flex; align-items: center; gap: 12px; width: 100%;
  padding: 12px 20px; background: var(--c-surface);
  border: none; border-bottom: 1px solid var(--c-border);
  cursor: pointer; text-align: left; font-family: inherit;
  transition: background .12s;
}
.hot-row.viewed { opacity: .7; }
.hot-row.viewed .hot-arrow { color: var(--c-success); }
@media (hover:hover) {
  .hot-row:hover { background: var(--c-surface2); }
}
.hot-row:active { background: var(--c-surface2); }
.hot-heat { font-size: .92rem; flex-shrink: 0; min-width: 50px; }
.hot-meta { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.hot-law { font-size: .78rem; color: var(--c-muted); font-weight: 500; }
.hot-art { font-size: .98rem; color: var(--c-text); font-weight: 700; font-family: var(--ff-mono); }
.hot-cnt {
  display: flex; flex-direction: column; align-items: flex-end; gap: 2px;
  flex-shrink: 0; font-size: .82rem; color: var(--c-text);
}
.hot-cnt strong { color: var(--c-primary); font-size: 1rem; }
.hot-cnt small { font-size: .68rem; color: var(--c-muted); }
.hot-arrow { color: var(--c-muted); font-size: 1.1rem; flex-shrink: 0; width: 14px; text-align: center; }

/* Inline-expand 高頻速記條文（點 row 直接展開不跳頁） */
.hot-row-wrap { display: block; }
.hot-row-body {
  background: var(--c-paper); border-bottom: 1px solid var(--c-border);
  padding: 14px 20px 16px;
  animation: hotInlineFadeIn .18s ease-out;
}
@keyframes hotInlineFadeIn {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.hot-inline-loading, .hot-inline-empty, .hot-inline-deleted {
  font-size: .85rem; color: var(--c-muted); padding: 4px 0;
}
.hot-inline-deleted { color: var(--c-warning, #b45309); font-weight: 600; }
.hot-inline-art {
  font-size: .92rem; line-height: 1.75; color: var(--c-text);
  white-space: pre-wrap; word-break: break-word;
  border-left: 3px solid var(--c-primary); padding: 2px 0 2px 12px;
  font-family: 'Noto Serif TC', 'PingFang TC', serif;
}
.hot-inline-actions {
  display: flex; gap: 8px; margin-top: 12px; flex-wrap: wrap;
}
.hot-inline-open, .hot-inline-quiz {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 6px 12px; border-radius: 8px;
  background: var(--c-surface2); border: 1px solid var(--c-border);
  font-size: .8rem; color: var(--c-text); cursor: pointer;
  transition: all .12s;
}
@media (hover:hover) {
  .hot-inline-open:hover, .hot-inline-quiz:hover {
    background: var(--c-surface3); border-color: var(--c-primary);
  }
}
/* < sm 小手機收緊內距 */
@media (max-width: 479.98px) {
  .hot-row-body { padding: 12px 16px 14px; }
  .hot-inline-art { font-size: .88rem; }
}

/* Inline high-freq chip on explanation feedback */
.hot-chip {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: 10px; padding: 6px 12px;
  background: linear-gradient(135deg, rgba(217,119,6,.10), rgba(178,58,43,.06));
  border: 1px solid rgba(217,119,6,.30); border-radius: 999px;
  font-size: .82rem; font-weight: 600; color: var(--c-warning, #b45309);
  cursor: pointer; transition: all .15s; font-family: inherit;
}
@media (hover:hover) {
  .hot-chip:hover {
    background: linear-gradient(135deg, rgba(217,119,6,.20), rgba(178,58,43,.10));
    transform: translateY(-1px);
  }
}
[data-theme="dark"] .hot-chip {
  background: linear-gradient(135deg, rgba(229,178,106,.14), rgba(224,113,88,.08));
  border-color: rgba(229,178,106,.40);
  color: var(--c-warning);
}
/* < sm 小手機收緊內距 */
@media (max-width: 479.98px) {
  .law-hot-hdr { padding: 14px 16px 12px; }
  .law-hot-hdr h2 { font-size: 1.05rem; }
  .law-filter-chips { padding: 10px 14px; gap: 5px; }
  .law-filter-chip { padding: 4px 10px; font-size: .72rem; }
  .hot-row { padding: 11px 16px; gap: 10px; }
}
.search-wrap { position: relative; }
.search-wrap svg {
  position: absolute; left: 11px; top: 50%; transform: translateY(-50%);
  width: 18px; height: 18px; color: var(--c-muted); pointer-events: none;
}
.search-inp {
  width: 100%; padding: 9px 14px 9px 36px;
  background: var(--c-surface); border: 1.5px solid var(--c-border);
  border-radius: var(--r-md);
  /* 16px to prevent iOS Safari auto-zoom on focus */
  font-size: 16px; color: var(--c-text);
  transition: border-color .15s;
}
.search-inp:focus { outline: none; border-color: var(--c-primary); }

.law-groups { padding: 10px 16px 20px; }

/* Exam block */
.law-exam-block { margin-bottom: 16px; }
.law-exam-hdr {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px; border-radius: var(--r-md);
  background: var(--c-surface2); border-left: 3px solid;
  margin-bottom: 6px;
}
.law-exam-name { font-size: .92rem; font-weight: 800; flex: 1; }

/* Subject block */
.law-subj-block { margin-bottom: 6px; }
.law-subj-btn {
  width: 100%; display: flex; align-items: center; gap: 8px;
  padding: 10px 14px; border-radius: var(--r-md);
  background: var(--c-surface); border: 1px solid var(--c-border);
  font-size: .85rem; font-weight: 700; color: var(--c-text);
  cursor: pointer; transition: all .15s; text-align: left;
}
.law-subj-btn:hover { background: var(--c-surface2); }
.subj-num {
  width: 20px; height: 20px; border-radius: 50%;
  background: var(--c-primary-10); color: var(--c-primary);
  font-size: .72rem; font-weight: 800; display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.subj-name { flex: 1; }
.grp-cnt { font-size: .7rem; padding: 2px 7px; background: var(--c-surface2); color: var(--c-muted); border-radius: 10px; font-weight: 600; flex-shrink: 0; }
.law-subj-btn .chev { width: 15px; height: 15px; color: var(--c-muted); transition: transform .2s; flex-shrink: 0; }
.law-subj-btn.open .chev { transform: rotate(180deg); }

.law-items { display: none; padding: 4px 0 4px 12px; }
.law-subj-btn.open + .law-items { display: block; }
/* Legacy support */
.law-group-btn.open + .law-items { display: block; }

.law-card {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px; border-radius: var(--r-sm);
  background: var(--c-surface); border: 1px solid var(--c-border);
  margin-bottom: 5px; cursor: pointer; transition: all .15s;
}
.law-card:hover { border-color: var(--c-primary); background: var(--c-primary-10); }
.law-card.unavailable { cursor: default; opacity: .6; }
.law-card.unavailable:hover { border-color: var(--c-border); background: var(--c-surface); }
.law-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--c-primary); flex-shrink: 0; }
.law-dot.unavail { background: var(--c-muted); }
.law-card-body { flex: 1; min-width: 0; }
.law-card h4 { font-size: .86rem; font-weight: 600; display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.law-note { font-size: .68rem; color: var(--c-muted); background: var(--c-surface2); padding: 1px 7px; border-radius: 8px; font-weight: 500; }
.law-meta { font-size: .73rem; color: var(--c-muted); margin-top: 2px; }
.law-search-results { padding: 4px 0; }

/* 「法規名+條號」直接跳轉卡 — 朱印紅高亮、最上方 */
.law-direct-jump { margin-bottom: 10px; }
.law-direct-jump .art-search-hdr {
  color: var(--c-vermilion, var(--c-primary));
  font-weight: 700;
}
.law-direct-card {
  border-color: var(--c-vermilion, var(--c-primary)) !important;
  background: color-mix(in oklch, var(--c-vermilion, var(--c-primary)) 6%, var(--c-surface)) !important;
  display: flex; align-items: center; gap: 12px;
  cursor: pointer;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.law-direct-card:hover {
  transform: translateY(-1px);
  background: color-mix(in oklch, var(--c-vermilion, var(--c-primary)) 12%, var(--c-surface)) !important;
  box-shadow: 0 6px 16px -8px color-mix(in oklch, var(--c-vermilion, var(--c-primary)) 35%, transparent);
}
.law-direct-card .law-dot {
  background: var(--c-vermilion, var(--c-primary)) !important;
}
.law-direct-art {
  font-family: var(--ff-mono, monospace);
  color: var(--c-vermilion, var(--c-primary));
  font-weight: 800;
  letter-spacing: .02em;
  margin-left: 4px;
}
.law-direct-arrow {
  flex-shrink: 0;
  font-size: 1.3rem; font-weight: 700;
  color: var(--c-vermilion, var(--c-primary));
  margin-left: auto;
  transition: transform .18s ease;
}
.law-direct-card:hover .law-direct-arrow { transform: translateX(4px); }
.law-no-items {
  padding: 10px 12px; border-radius: var(--r-sm);
  font-size: .8rem; color: var(--c-muted); font-style: italic;
  background: var(--c-surface2); border: 1px dashed var(--c-border);
}

/* Bookmark summary panel above law list */
.bookmarks-panel {
  margin: 0 0 14px 0; padding: 12px 14px;
  background: var(--c-surface); border: 1px solid var(--c-border);
  border-radius: var(--r-md);
}
.bookmarks-hdr {
  font-size: .78rem; font-weight: 700; color: var(--c-muted);
  text-transform: uppercase; letter-spacing: .06em; margin-bottom: 8px;
}
.bookmarks-list {
  display: flex; flex-wrap: wrap; gap: 6px;
}
.bookmark-chip {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 10px; border-radius: 20px; font-size: .78rem; font-weight: 600;
  background: var(--c-primary-10); color: var(--c-primary);
  border: 1px solid var(--c-primary-20); cursor: pointer; transition: all .15s;
}
.bookmark-chip:hover { background: var(--c-primary-20); }
.bookmark-chip-cnt {
  font-size: .7rem; background: var(--c-primary); color: #fff;
  border-radius: 10px; padding: 0 5px; min-width: 16px; text-align: center;
}

/* Legacy group button (kept for backward compat) */
.law-group-btn {
  width: 100%; display: flex; align-items: center; gap: 10px;
  padding: 11px 14px; border-radius: var(--r-md);
  background: var(--c-surface); border: 1px solid var(--c-border);
  font-size: .88rem; font-weight: 700; color: var(--c-text);
  cursor: pointer; transition: all .15s;
}

/* ═══════════════════════════════════
   LAW DETAIL VIEW
═══════════════════════════════════ */
/* Sticky wrapper: back-bar + jump bar always visible */
.law-sticky-header {
  position: sticky; top: var(--hdr-h); z-index: 40;
  background: var(--c-bg);
}
.law-detail-bar {
  background: var(--c-bg); border-bottom: 1px solid var(--c-border);
  padding: 10px 16px;
  display: flex; align-items: center; gap: 12px;
}
.law-detail-bar h2 { font-size: .98rem; font-weight: 700; flex: 1; min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
/* 手機 sticky header 收緊：左右 padding 12 → 行距 8、按鈕間距 8、換法規只剩 icon */
@media (max-width: 540px) {
  .law-detail-bar { padding: 8px 12px; gap: 8px; }
  .law-detail-bar h2 { font-size: .92rem; }
  .law-switch-btn { padding: 6px 8px !important; font-size: 0 !important; gap: 0 !important; }
  .law-switch-btn svg { width: 16px !important; height: 16px !important; }
}

.toc-bar {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 16px;
  background: var(--c-surface2); border-bottom: 1px solid var(--c-border);
}
/* breadcrumb 永遠單行 + ellipsis，手機完全隱藏（資訊已在 h2 + sticky 裡，非關鍵）*/
.law-bc {
  flex-shrink: 0;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  max-width: 200px;
}
@media (max-width: 540px) {
  .law-bc { display: none !important; }
}
/* 手機 toc-bar：toc-scroll-wrap 獨佔一行，art-jump 用 12-grid 排成 2 列
   按鈕保留 iOS HIG 44px 觸控高度，只重新分配水平空間 */
@media (max-width: 540px) {
  .toc-bar { padding: 6px 10px; gap: 6px; flex-wrap: wrap; }
  .toc-scroll-wrap { width: 100%; }
  .toc-art-jump {
    width: 100%;
    display: grid !important;
    grid-template-columns: repeat(12, 1fr);
    gap: 6px;
    row-gap: 8px;
    align-items: stretch;
  }
  /* Row 1：上一條(4) | 第N條 input(3) | jump 箭頭(2) | 下一條(3) = 12  */
  .toc-art-jump > .btn {
    margin: 0 !important;
    padding: 0 4px !important;
    font-size: .8rem !important;
    border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    white-space: nowrap;
  }
  .toc-art-jump > .btn:nth-of-type(1) { grid-column: span 4; }   /* 上一條 */
  .toc-art-jump > .toc-art-inp        { grid-column: span 3; }   /* 第N條 */
  .toc-art-jump > .toc-art-btn        { grid-column: span 2; }   /* > 跳轉 */
  .toc-art-jump > .btn:nth-of-type(2) { grid-column: span 3; }   /* 下一條 */
  .toc-art-inp {
    width: 100% !important;
    min-width: 0 !important;
    padding: 0 8px !important;
    text-align: center;
    border-radius: 10px !important;
  }
  .toc-art-btn {
    width: 100% !important;
    min-width: 0 !important;
    border-radius: 10px !important;
  }
  /* Row 2：全文(4) | 曉臻(4) | 1.0×(4) = 12 */
  .toc-art-jump > .tts-play-all-chip { grid-column: span 4; }
  .toc-art-jump > .tts-voice-chip    { grid-column: span 4; }
  .toc-art-jump > .tts-speed-chip    { grid-column: span 4; }
  .tts-play-all-chip,
  .tts-voice-chip,
  .tts-speed-chip {
    margin: 0 !important;
    padding: 0 6px !important;
    min-height: 40px !important;
    font-size: .8rem !important;
    justify-content: center !important;
    width: 100%;
  }
  /* art-result 是 jump 失敗才有字的 span — 平常空字串就不佔格 */
  #art-result:empty { display: none; }
  #art-result:not(:empty) { grid-column: span 12; font-size: .72rem; }
}

/* law-aux-rows：往下捲動時收起整塊（progress + toc-bar），往上捲時恢復
   只對手機生效，最大化閱讀空間。

   抖動防呆：max-height collapse 會 reflow 觸發 phantom scroll，靠
   JS 端 450ms cooldown lock + 大 threshold（HIDE=70 / SHOW=50）
   讓 phantom scroll 落在鎖內無效。動畫期間還有 toggle 也會被擋下。 */
.law-aux-rows {
  overflow: hidden;
  max-height: 320px;
  opacity: 1;
  transition: max-height .25s ease, opacity .2s ease;
  will-change: max-height, opacity;
}
.law-sticky-header.aux-hidden .law-aux-rows {
  max-height: 0;
  opacity: 0;
  pointer-events: none;
}
/* 桌機不需要 auto-hide（畫面寬鬆） */
@media (min-width: 541px) {
  .law-sticky-header.aux-hidden .law-aux-rows {
    max-height: 320px; opacity: 1; pointer-events: auto;
  }
}

/* 高頻速記 — 朗讀全部按鈕（hero 內，僅有條文時顯示） */
.hot-play-all {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: 12px;
  padding: 8px 16px;
  background: var(--c-vermilion, var(--c-primary));
  color: white;
  border: none; border-radius: 99px;
  font-family: var(--ff-serif-cn);
  font-size: 13.5px; font-weight: 700;
  letter-spacing: .02em;
  cursor: pointer;
  transition: filter .15s, transform .15s;
  box-shadow: 0 4px 14px -4px color-mix(in oklch, var(--c-vermilion, #b23a2b) 50%, transparent);
}
.hot-play-all:hover { filter: brightness(1.08); transform: translateY(-1px); }
[data-theme="dark"] .hot-play-all { color: var(--c-primary-fg, white); }

/* 序列播放時當前條文高亮 */
.law-article.seq-playing,
.hot-row.seq-playing {
  background: color-mix(in oklch, var(--c-vermilion, #b23a2b) 10%, transparent) !important;
  outline: 2px solid var(--c-vermilion, var(--c-primary));
  outline-offset: -1px;
  transition: background .3s, outline .3s;
}

/* Floating 序列播放控制條（右下角） */
.seq-player {
  position: fixed;
  right: 16px; bottom: 16px;
  z-index: 90;
  display: flex; align-items: center; gap: 12px;
  padding: 12px 16px;
  background: var(--c-surface);
  border: 1.5px solid var(--c-vermilion, var(--c-primary));
  border-radius: 12px;
  box-shadow: 0 12px 32px -8px color-mix(in oklch, var(--c-vermilion, #b23a2b) 28%, rgba(0,0,0,.18));
  font-family: var(--ff-serif-cn);
  max-width: calc(100vw - 32px);
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .25s, transform .25s;
}
.seq-player.show { opacity: 1; transform: translateY(0); }
.seq-player .sp-info { min-width: 0; flex: 1; }
.seq-player .sp-label {
  font-size: 13px; font-weight: 700;
  color: var(--c-ink, var(--c-text));
  letter-spacing: 0;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  max-width: 220px;
  display: inline-flex; align-items: center; gap: 6px;
}
.seq-player .sp-progress {
  font-family: var(--ff-mono);
  font-size: 11px; color: var(--c-muted);
  letter-spacing: .05em; margin-top: 2px;
  font-feature-settings: 'tnum' 1;
}
/* loading 狀態：spinner + 整個 player 微脈動，讓使用者知道在載入不是當機 */
.seq-player.loading {
  border-color: color-mix(in oklch, var(--c-vermilion, #b23a2b) 70%, transparent);
  animation: sp-pulse 1.6s ease-in-out infinite;
}
.seq-player.loading .sp-label {
  color: var(--c-vermilion, var(--c-primary));
}
.sp-spinner {
  display: inline-block;
  width: 12px; height: 12px;
  border: 2px solid color-mix(in oklch, var(--c-vermilion, #b23a2b) 30%, transparent);
  border-top-color: var(--c-vermilion, var(--c-primary));
  border-radius: 50%;
  animation: sp-spin .8s linear infinite;
  flex-shrink: 0;
}
.seq-player:not(.loading) .sp-spinner { display: none; }
@keyframes sp-spin { to { transform: rotate(360deg); } }
@keyframes sp-pulse {
  0%,100% { box-shadow: 0 12px 32px -8px color-mix(in oklch, var(--c-vermilion, #b23a2b) 28%, rgba(0,0,0,.18)); }
  50%     { box-shadow: 0 12px 32px -4px color-mix(in oklch, var(--c-vermilion, #b23a2b) 55%, rgba(0,0,0,.18)); }
}
@media (prefers-reduced-motion: reduce) {
  .seq-player.loading { animation: none; }
  .sp-spinner { animation: none; }
}
.seq-player .sp-stop {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 14px;
  background: var(--c-vermilion, var(--c-primary));
  color: white; border: none; border-radius: 99px;
  font-family: var(--ff-serif-cn);
  font-size: 13px; font-weight: 700;
  cursor: pointer; flex-shrink: 0;
  transition: filter .15s;
}
.seq-player .sp-stop:hover { filter: brightness(1.08); }
[data-theme="dark"] .seq-player .sp-stop { color: var(--c-primary-fg, white); }
@media (max-width: 540px) {
  .seq-player { right: 8px; bottom: 8px; padding: 10px 12px; gap: 8px; }
  .seq-player .sp-label { max-width: 130px; font-size: 12.5px; }
  .seq-player .sp-stop { padding: 5px 11px; font-size: 12px; }
}
@media (prefers-reduced-motion: reduce) {
  .seq-player { transition: none; }
}

/* 明日預告區塊（home page Tomorrow's Hook）── editorial 朱印紅卡 */
.home-tomorrow {
  position: relative;
  margin: clamp(28px, 4vw, 48px) auto;
  max-width: clamp(760px, 92vw, 960px);
  padding: clamp(20px, 2.6vw, 36px) clamp(20px, 3vw, 44px);
  background: linear-gradient(135deg, var(--c-surface) 0%, color-mix(in oklch, var(--c-vermilion, #b23a2b) 4%, var(--c-surface)) 100%);
  border: 1px solid color-mix(in oklch, var(--c-vermilion, #b23a2b) 22%, var(--c-border));
  border-left: 4px solid var(--c-vermilion, var(--c-primary));
  border-radius: 14px;
}
.home-tomorrow .ht-eyebrow {
  font-family: var(--ff-mono);
  font-size: clamp(11px, .85vw, 13px);
  font-weight: 600;
  letter-spacing: .12em; text-transform: uppercase;
  color: var(--c-vermilion);
  margin-bottom: 8px;
}
.home-tomorrow .ht-title {
  font-family: var(--ff-serif-cn);
  font-size: clamp(17px, 1.6vw, 22px);
  font-weight: 800;
  color: var(--c-ink, var(--c-text));
  margin-bottom: 14px;
  letter-spacing: -.01em;
}
.home-tomorrow .ht-list {
  display: grid; gap: 6px;
  margin-bottom: 16px;
}
.home-tomorrow .ht-item {
  display: flex; align-items: center; gap: 8px;
  font-family: var(--ff-serif-cn);
  font-size: clamp(13.5px, 1.1vw, 15.5px);
  line-height: 1.5;
  color: var(--c-text);
  padding: 4px 0;
}
.home-tomorrow .ht-item strong {
  color: var(--c-vermilion);
  font-weight: 800;
  font-feature-settings: 'tnum' 1, 'lnum' 1;
}
.home-tomorrow .ht-item.ht-due strong {
  font-size: 1.15em;
}
.home-tomorrow .ht-ico {
  flex-shrink: 0;
  font-size: 16px;
  width: 24px;
  text-align: center;
}
.home-tomorrow .ht-foot {
  border-top: 1px dashed var(--c-rule);
  padding-top: 12px;
}
.home-tomorrow .ht-slot-btn {
  background: transparent;
  border: 1px solid var(--c-border);
  border-radius: 99px;
  padding: 8px 16px;
  font-family: var(--ff-serif-cn);
  font-size: clamp(13px, .95vw, 15px);
  color: var(--c-ink-2, var(--c-muted));
  cursor: pointer;
  transition: all .15s;
  letter-spacing: .01em;
}
.home-tomorrow .ht-slot-btn:hover {
  border-color: var(--c-vermilion);
  color: var(--c-vermilion);
  background: color-mix(in oklch, var(--c-vermilion, #b23a2b) 6%, transparent);
}
.home-tomorrow .ht-slot-btn strong {
  color: var(--c-vermilion);
  font-weight: 800;
}

/* 60 秒快測 CTA（guest only — Sarah Chen 提案）*/
.home-quick-trial {
  position: relative;
  margin: clamp(20px, 3vw, 32px) auto 0;
  max-width: 540px;
  padding: clamp(16px, 2.2vw, 24px);
  background: var(--c-vermilion, var(--c-primary));
  color: white;
  border-radius: 14px;
  text-align: center;
  cursor: pointer;
  transition: transform .25s, box-shadow .25s, filter .15s;
  border: none;
  font-family: var(--ff-serif-cn);
  display: block; width: 100%;
  box-shadow: 0 10px 28px -10px color-mix(in oklch, var(--c-vermilion, #b23a2b) 50%, transparent);
}
.home-quick-trial:hover {
  transform: translateY(-2px);
  filter: brightness(1.06);
}
[data-theme="dark"] .home-quick-trial { color: var(--c-primary-fg, white); }
.home-quick-trial .qt-eyebrow {
  font-family: var(--ff-mono);
  font-size: clamp(11px, .85vw, 13px);
  letter-spacing: .12em;
  opacity: .85;
  margin-bottom: 6px;
  text-transform: uppercase;
}
.home-quick-trial .qt-h {
  font-size: clamp(18px, 2vw, 26px);
  font-weight: 800;
  letter-spacing: -.01em;
  margin-bottom: 4px;
}
.home-quick-trial .qt-sub {
  font-size: clamp(13px, 1vw, 15px);
  opacity: .9;
  letter-spacing: .02em;
}

/* 60 秒快測結果 modal */
.quick-trial-result {
  position: fixed; inset: 0; z-index: 9998;
  display: flex; align-items: center; justify-content: center;
  background: rgba(0, 0, 0, .6); backdrop-filter: blur(6px);
  padding: 20px;
  opacity: 0;
  transition: opacity .3s;
}
.quick-trial-result.show { opacity: 1; }
.quick-trial-result .qtr-card {
  background: var(--c-surface);
  border: 2px solid var(--c-vermilion, var(--c-primary));
  border-radius: 16px;
  padding: 28px 24px 24px;
  max-width: min(440px, 100%);
  width: 100%;
  box-shadow: 0 24px 60px -12px rgba(0,0,0,.4);
  text-align: center;
  font-family: var(--ff-serif-cn);
  transform: translateY(20px) scale(.96);
  transition: transform .35s cubic-bezier(.2, .9, .3, 1.1);
}
.quick-trial-result.show .qtr-card { transform: translateY(0) scale(1); }
.qtr-eyebrow {
  font-family: var(--ff-mono);
  font-size: 11px; font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--c-vermilion);
  margin-bottom: 16px;
}
.qtr-score-row {
  display: flex; align-items: baseline; justify-content: center;
  gap: 18px; margin-bottom: 14px;
}
.qtr-score {
  font-family: var(--ff-serif-cn);
  font-size: 64px; font-weight: 900;
  line-height: 1;
  color: var(--c-vermilion);
  letter-spacing: -.04em;
  font-feature-settings: 'tnum' 1, 'lnum' 1;
}
.qtr-score small { font-size: .35em; opacity: .55; font-weight: 700; margin-left: 4px; }
.qtr-meta {
  text-align: left;
}
.qtr-pct {
  font-family: var(--ff-serif-cn);
  font-size: 22px; font-weight: 800;
  color: var(--c-ink, var(--c-text));
  margin-bottom: 2px;
}
.qtr-time {
  font-family: var(--ff-mono);
  font-size: 12px;
  color: var(--c-muted);
  letter-spacing: .03em;
}
.qtr-badge {
  display: inline-block;
  padding: 4px 16px;
  border-radius: 99px;
  font-family: var(--ff-serif-cn);
  font-size: 14px;
  font-weight: 800;
  margin-bottom: 14px;
  letter-spacing: .03em;
}
.qtr-badge.qtb-high { background: var(--c-vermilion); color: white; }
[data-theme="dark"] .qtr-badge.qtb-high { color: var(--c-primary-fg, white); }
.qtr-badge.qtb-mid {
  background: color-mix(in oklch, #d4a847 20%, transparent);
  color: #a37c1f;
  border: 1px solid color-mix(in oklch, #d4a847 50%, transparent);
}
[data-theme="dark"] .qtr-badge.qtb-mid { color: #d4b563; }
.qtr-badge.qtb-low {
  background: var(--c-surface2);
  color: var(--c-muted);
  border: 1px solid var(--c-border);
}
.qtr-suggestion {
  font-family: var(--ff-serif-cn);
  font-size: 14px;
  line-height: 1.6;
  color: var(--c-text);
  margin: 0 0 22px;
  text-wrap: pretty;
}
.qtr-actions {
  display: flex; flex-direction: column; gap: 8px;
}
.qtr-cta-primary {
  padding: 13px 20px;
  background: var(--c-vermilion, var(--c-primary));
  color: white;
  border: none; border-radius: 10px;
  font-family: var(--ff-serif-cn);
  font-size: 14.5px; font-weight: 800;
  cursor: pointer;
  transition: filter .15s, transform .15s;
}
.qtr-cta-primary:hover { filter: brightness(1.06); transform: translateY(-1px); }
[data-theme="dark"] .qtr-cta-primary { color: var(--c-primary-fg, white); }
.qtr-cta-ghost {
  padding: 11px 20px;
  background: transparent;
  color: var(--c-muted);
  border: 1px solid var(--c-border);
  border-radius: 10px;
  font-family: var(--ff-serif-cn);
  font-size: 13.5px; font-weight: 600;
  cursor: pointer;
  transition: all .15s;
}
.qtr-cta-ghost:hover {
  border-color: var(--c-vermilion, var(--c-primary));
  color: var(--c-vermilion, var(--c-primary));
}

/* 編輯級 toast（取代 native alert）— 朱印紅左 hairline + 思源宋字 */
.editorial-toast {
  position: fixed;
  top: calc(var(--hdr-h, 56px) + 12px);
  left: 50%;
  transform: translateX(-50%) translateY(-20px);
  z-index: 9997;
  display: inline-flex; align-items: center; gap: 10px;
  padding: 12px 16px 12px 14px;
  background: var(--c-surface);
  border: 1.5px solid var(--c-border);
  border-left: 4px solid var(--c-vermilion, var(--c-primary));
  border-radius: 10px;
  box-shadow: 0 12px 32px -8px rgba(0,0,0,.18);
  font-family: var(--ff-serif-cn);
  font-size: 13.5px;
  line-height: 1.45;
  color: var(--c-ink, var(--c-text));
  max-width: min(440px, calc(100vw - 32px));
  opacity: 0;
  transition: opacity .25s, transform .35s cubic-bezier(.2, .9, .3, 1.1);
  pointer-events: auto;
}
.editorial-toast.show {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}
.editorial-toast .et-icon {
  flex-shrink: 0;
  display: inline-flex; align-items: center; justify-content: center;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--c-vermilion);
  color: white;
  font-size: 13px;
  font-weight: 800;
  font-family: var(--ff-mono);
}
[data-theme="dark"] .editorial-toast .et-icon { color: var(--c-primary-fg, white); }
.editorial-toast .et-msg {
  flex: 1; min-width: 0;
  text-wrap: pretty;
}
.editorial-toast .et-close {
  flex-shrink: 0;
  background: transparent; border: none;
  color: var(--c-muted);
  cursor: pointer;
  font-size: 14px;
  width: 24px; height: 24px;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  transition: background .15s, color .15s;
}
.editorial-toast .et-close:hover {
  background: var(--c-surface2);
  color: var(--c-text);
}
/* type variants */
.editorial-toast.et-error {
  border-left-color: var(--c-danger, #dc2626);
}
.editorial-toast.et-error .et-icon {
  background: var(--c-danger, #dc2626);
}
.editorial-toast.et-success {
  border-left-color: var(--c-success, #059669);
}
.editorial-toast.et-success .et-icon {
  background: var(--c-success, #059669);
}
.editorial-toast.et-warn {
  border-left-color: #d4a847;
}
.editorial-toast.et-warn .et-icon {
  background: #d4a847;
}

/* TTS 編輯級提示 modal（取代系統 alert/confirm） */
.tts-modal-overlay {
  position: fixed; inset: 0; z-index: 9998;
  display: flex; align-items: center; justify-content: center;
  background: rgba(15, 15, 16, .65); backdrop-filter: blur(8px);
  padding: 20px;
  opacity: 0;
  transition: opacity .25s;
}
.tts-modal-overlay.show { opacity: 1; }
.tts-modal-card {
  background: var(--c-surface);
  border: 1.5px solid var(--c-rule, var(--c-border));
  border-left: 4px solid var(--c-vermilion, var(--c-primary));
  border-radius: 14px;
  padding: 26px 28px 24px;
  max-width: min(440px, 100%); width: 100%;
  box-shadow: 0 24px 60px -12px rgba(0, 0, 0, .35);
  font-family: var(--ff-serif-cn);
  transform: translateY(16px) scale(.96);
  transition: transform .35s cubic-bezier(.2, .9, .3, 1.1);
}
.tts-modal-overlay.show .tts-modal-card { transform: translateY(0) scale(1); }
.tts-modal-eyebrow {
  font-family: var(--ff-mono);
  font-size: 11px; letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--c-vermilion, var(--c-primary));
  margin-bottom: 12px;
}
.tts-modal-title {
  font-family: var(--ff-serif-cn);
  font-size: clamp(20px, 2.2vw, 26px);
  font-weight: 800;
  letter-spacing: -.02em;
  color: var(--c-ink, var(--c-text));
  margin: 0 0 14px;
  line-height: 1.3;
}
.tts-modal-body {
  font-family: var(--ff-serif-cn);
  font-size: 14.5px;
  line-height: 1.7;
  color: var(--c-text);
  margin-bottom: 20px;
  text-wrap: pretty;
}
.tts-modal-body p { margin: 0 0 10px; }
.tts-modal-body p:last-child { margin-bottom: 0; }
.tts-modal-body strong {
  color: var(--c-vermilion, var(--c-primary));
  font-weight: 800;
}
.tts-modal-body ol {
  padding-left: 22px;
  margin: 8px 0 0;
}
.tts-modal-body ol li {
  margin-bottom: 6px;
  font-size: 13.5px;
  line-height: 1.6;
}
.tts-modal-err {
  font-family: var(--ff-mono);
  font-size: 11.5px;
  color: var(--c-muted);
  background: var(--c-surface2);
  border-radius: 6px;
  padding: 8px 12px;
  margin: 6px 0 12px !important;
  word-break: break-all;
}
.tts-modal-actions {
  display: flex; flex-direction: column-reverse; gap: 8px;
  margin-top: 8px;
}
@media (min-width: 480px) {
  .tts-modal-actions { flex-direction: row; justify-content: flex-end; }
}
.tts-modal-cta {
  flex: 1; padding: 12px 20px;
  background: var(--c-vermilion, var(--c-primary)); color: white;
  border: none; border-radius: 10px;
  font-family: var(--ff-serif-cn);
  font-size: 14.5px; font-weight: 800;
  letter-spacing: .02em;
  cursor: pointer;
  transition: filter .15s, transform .15s;
}
.tts-modal-cta:hover { filter: brightness(1.06); transform: translateY(-1px); }
[data-theme="dark"] .tts-modal-cta { color: var(--c-primary-fg, white); }
.tts-modal-ghost {
  flex: 0 0 auto; padding: 11px 20px;
  background: transparent; color: var(--c-muted);
  border: 1px solid var(--c-border); border-radius: 10px;
  font-family: var(--ff-serif-cn);
  font-size: 13.5px; font-weight: 600;
  cursor: pointer;
  transition: all .15s;
}
.tts-modal-ghost:hover {
  color: var(--c-vermilion);
  border-color: var(--c-vermilion);
}

/* TTS「朗讀全文」朱印紅實心 chip — 跟音色/速度 chip 並列在 toc-bar */
.tts-play-all-chip {
  display: inline-flex; align-items: center; gap: 5px;
  flex-shrink: 0;
  padding: 4px 11px; min-height: 32px;
  background: var(--c-vermilion, var(--c-primary));
  color: white;
  border: 1.5px solid var(--c-vermilion, var(--c-primary));
  border-radius: 99px;
  font-family: var(--ff-serif-cn);
  font-size: .76rem; font-weight: 700;
  cursor: pointer;
  transition: filter .15s, transform .15s, box-shadow .2s;
  box-shadow: 0 2px 8px -2px color-mix(in oklch, var(--c-vermilion, #b23a2b) 50%, transparent);
}
.tts-play-all-chip:hover { filter: brightness(1.08); transform: translateY(-1px); }
[data-theme="dark"] .tts-play-all-chip { color: var(--c-primary-fg, white); }
.tts-play-all-chip svg { opacity: .95; }
@media (max-width: 540px) {
  /* 手機 art-jump grid 已給 chip min-height 40px；不再回到 28px */
  .tts-play-all-chip { font-size: .8rem !important; }
}

/* TTS 倍速 / 音色切換 chip — 共用樣式 */
.tts-speed-chip, .tts-voice-chip {
  display: inline-flex; align-items: center; gap: 4px;
  flex-shrink: 0;
  padding: 4px 10px; min-height: 32px;
  background: var(--c-surface);
  border: 1.5px solid var(--c-border);
  border-radius: 99px;
  font-family: var(--ff-mono);
  font-size: .72rem; font-weight: 700;
  color: var(--c-muted);
  letter-spacing: .03em;
  cursor: pointer;
  transition: border-color .15s, color .15s, background .15s;
}
.tts-speed-chip:hover, .tts-voice-chip:hover {
  border-color: var(--c-vermilion, var(--c-primary));
  color: var(--c-vermilion, var(--c-primary));
  background: color-mix(in oklch, var(--c-vermilion, #b23a2b) 6%, var(--c-surface));
}
.tts-speed-chip.active-speed,
.tts-voice-chip.active-voice {
  background: var(--c-vermilion, var(--c-primary));
  border-color: var(--c-vermilion, var(--c-primary));
  color: white;
}
[data-theme="dark"] .tts-speed-chip.active-speed,
[data-theme="dark"] .tts-voice-chip.active-voice { color: var(--c-primary-fg, white); }
.tts-speed-chip svg, .tts-voice-chip svg { opacity: .85; }
.tts-voice-chip span { font-family: var(--ff-serif-cn); font-weight: 700; }
.tts-voice-chip.is-fallback {
  border-style: dashed;
  border-color: color-mix(in oklch, #d4a847 60%, transparent);
  color: #a37c1f;
}
[data-theme="dark"] .tts-voice-chip.is-fallback { color: #d4b563; }
.toc-scroll-wrap { display: flex; align-items: center; flex: 1; min-width: 0; gap: 4px; }
.toc-arrow {
  flex-shrink: 0; width: 22px; height: 22px; border-radius: 50%;
  background: var(--c-surface); border: 1px solid var(--c-border);
  font-size: 1rem; line-height: 1; display: flex; align-items: center; justify-content: center;
  color: var(--c-muted); cursor: pointer; transition: all .15s;
}
.toc-arrow:hover { border-color: var(--c-primary); color: var(--c-primary); }
.toc-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; flex: 1; min-width: 0; }
.toc-scroll::-webkit-scrollbar { display: none; }
.toc-row { display: flex; gap: 6px; width: max-content; padding: 1px 0; }
.toc-link {
  display: flex; align-items: center; gap: 5px;
  padding: 4px 12px; border-radius: 20px;
  background: var(--c-surface); border: 1px solid var(--c-border);
  font-size: .78rem; font-weight: 600; white-space: nowrap; cursor: pointer;
  transition: all .15s;
}
.toc-link:hover { border-color: var(--c-primary); color: var(--c-primary); }
.toc-link .cnt { font-size: .68rem; color: var(--c-muted); }

/* Compact article jump — lives inline in toc-bar */
.toc-art-jump { display: flex; align-items: center; gap: 4px; flex-shrink: 0; }
.toc-art-inp {
  width: 72px; padding: 4px 7px;
  background: var(--c-surface); border: 1.5px solid var(--c-border);
  border-radius: var(--r-sm); font-size: .78rem; color: var(--c-text);
  transition: border-color .15s;
}
.toc-art-inp:focus { outline: none; border-color: var(--c-primary); }
.toc-art-btn {
  width: 28px; height: 28px; border-radius: var(--r-sm); flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  background: var(--c-primary); color: white;
}
.toc-art-btn svg { width: 14px; height: 14px; }
#art-result { font-size: .72rem; color: var(--c-danger); white-space: nowrap; max-width: 60px; overflow: hidden; text-overflow: ellipsis; }

/* ═══════════════════════════════════
   LAW IN-PAGE SEARCH
═══════════════════════════════════ */
.law-search-bar {
  display: flex; align-items: center; gap: 6px;
  padding: 7px 16px;
  background: var(--c-surface); border-bottom: 1px solid var(--c-border);
  position: sticky;
  top: calc(var(--hdr-h) + 44px);
  z-index: 40;
}
.law-search-bar.hidden { display: none; }
.law-search-icon { width: 16px; height: 16px; color: var(--c-muted); flex-shrink: 0; }
.law-search-inp {
  flex: 1; padding: 5px 10px;
  background: var(--c-surface2); border: 1.5px solid var(--c-primary);
  border-radius: var(--r-sm);
  /* 16px to prevent iOS Safari auto-zoom on focus */
  font-size: 16px; color: var(--c-text);
}
.law-search-inp:focus { outline: none; }
.law-search-cnt { font-size: .72rem; color: var(--c-muted); white-space: nowrap; flex-shrink: 0; min-width: 36px; text-align: center; }
.law-search-nav-btn {
  width: 26px; height: 26px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--c-muted); border: 1px solid var(--c-border); flex-shrink: 0;
  transition: all .15s;
}
.law-search-nav-btn:hover:not(:disabled) { color: var(--c-primary); border-color: var(--c-primary); }
.law-search-nav-btn:disabled { opacity: .4; cursor: not-allowed; }
.law-search-nav-btn svg { width: 12px; height: 12px; }
.law-search-close {
  width: 26px; height: 26px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  color: var(--c-muted); font-size: 1.1rem; line-height: 1; transition: color .15s;
}
.law-search-close:hover { color: var(--c-danger); }
mark.law-match { background: rgba(217,119,6,.25); border-radius: 2px; color: inherit; }
mark.law-match.current { background: rgba(217,119,6,.7); color: #fff; border-radius: 2px; }

/* ═══════════════════════════════════
