@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@400;600;700&family=JetBrains+Mono:wght@400;500&family=Inter:wght@400;500;600;700&display=swap');

:root {
  --bg: #fafaf8;
  --fg: #1a1a1a;
  --fg-muted: #6b7280;
  --accent: #d14d41;
  --accent-light: #fef2f2;
  --cross: #7c3aed;
  --cross-bg: #f5f3ff;
  --border: #e5e5e2;
  --card: #fff;
  --card-shadow: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);
  --radius: 8px;
  --font-ui: 'Inter', 'PingFang SC', system-ui, sans-serif;
  --font-body: 'Noto Serif SC', Georgia, serif;
  --font-mono: 'JetBrains Mono', monospace;
  /* 液态玻璃 */
  --glass-blur: blur(28px) saturate(190%);
  --glass-blur-light: blur(18px) saturate(175%);
  --glass-bg: rgba(255, 255, 255, 0.42);
  --glass-bg-strong: rgba(255, 255, 255, 0.55);
  --glass-bg-subtle: rgba(255, 255, 255, 0.28);
  --glass-border: rgba(255, 255, 255, 0.82);
  --glass-border-outer: rgba(255, 255, 255, 0.55);
  --glass-rim: rgba(0, 0, 0, 0.06);
  --glass-highlight: inset 0 1px 0 rgba(255, 255, 255, 0.95), inset 0 -1px 0 rgba(255, 255, 255, 0.25);
  --glass-shadow: 0 4px 6px rgba(0, 0, 0, 0.04), 0 16px 40px rgba(0, 0, 0, 0.1);
  --glass-shadow-lg: 0 8px 16px rgba(0, 0, 0, 0.06), 0 24px 56px rgba(0, 0, 0, 0.14);
  --glass-dark-bg: rgba(22, 22, 22, 0.72);
  --glass-dark-border: rgba(255, 255, 255, 0.18);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html {
  height: 100%;
  background: #eef0f4;
}
body {
  font-family: var(--font-ui);
  position: relative;
  isolation: isolate;
  background-color: transparent;
  color: var(--fg);
  line-height: 1.6;
  font-size: 15px;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}
/* 固定彩色光晕层 — 玻璃必须「透」到这层才有效果 */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -2;
  pointer-events: none;
  background:
    radial-gradient(circle 520px at 12% 18%, rgba(209, 77, 65, 0.28), transparent 68%),
    radial-gradient(circle 480px at 88% 12%, rgba(124, 58, 237, 0.24), transparent 65%),
    radial-gradient(circle 560px at 78% 88%, rgba(46, 168, 229, 0.22), transparent 68%),
    radial-gradient(circle 420px at 22% 82%, rgba(245, 158, 11, 0.16), transparent 62%),
    linear-gradient(155deg, #f8f6f3 0%, #eef2f8 45%, #f5f0fa 100%);
}
body::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  opacity: 0.45;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
}

/* ── 液态玻璃：基础层（不依赖 backdrop-filter，始终可见）── */
.site-header,
.site-footer,
.date-toolbar,
.list-controls,
.lab-feed,
.page-header,
.search-form,
.stats-section,
.report-frame-wrap,
.modal-card,
.hl-toolbar-sheet,
.hl-mark-sheet,
.toc-drawer,
.fav-menu,
.paper-card,
.history-card,
.highlight-item,
.plugin-hero,
.plugin-steps,
.plugin-config,
.plugin-menu,
.plugin-faq,
.rss-card,
.stats-hero-card,
.stats-table-wrap {
  border: 1px solid var(--glass-border-outer);
  box-shadow: var(--glass-highlight), var(--glass-shadow);
}
.site-header,
.site-footer,
.date-toolbar,
.list-controls,
.lab-feed,
.page-header,
.search-form,
.stats-section,
.report-frame-wrap {
  background: var(--glass-bg);
}
.paper-card,
.history-card,
.highlight-item,
.plugin-hero,
.plugin-steps,
.plugin-config,
.plugin-menu,
.plugin-faq,
.rss-card,
.stats-hero-card,
.stats-table-wrap {
  background: var(--glass-bg-strong);
}
.modal-card,
.hl-toolbar-sheet,
.hl-mark-sheet,
.toc-drawer,
.fav-menu {
  background: var(--glass-bg-strong);
  border-color: var(--glass-border);
}
.page-header {
  padding: 18px 22px;
  border-radius: var(--radius);
  margin-bottom: 24px;
}
.site-main {
  position: relative;
  /* 不要设 z-index，否则会创建堆叠上下文，导致内部 .toc-drawer/.toc-backdrop/.fab-stack
     这种 fixed 浮层无法越过外层 .site-header（sticky, z-index:50）—— 目录打不开/点不动 */
}

/* ── 液态玻璃：blur 增强层 ── */
@supports (backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px)) {
  .site-header,
  .site-footer,
  .date-toolbar,
  .list-controls,
  .lab-feed,
  .page-header,
  .search-form,
  .stats-section,
  .report-frame-wrap,
  .paper-card,
  .history-card,
  .highlight-item,
  .plugin-hero,
  .plugin-steps,
  .plugin-config,
  .plugin-menu,
  .plugin-faq,
  .rss-card,
  .stats-hero-card,
  .stats-table-wrap,
  .rss-link-wrap,
  .empty-hint.big,
  .modal-card,
  .hl-toolbar-sheet,
  .hl-mark-sheet,
  .toc-drawer,
  .fav-menu,
  .comments-area,
  .site-search,
  .auth-user,
  .fab,
  .hl-comment-display,
  .footer-beian,
  .loading-indicator {
    -webkit-backdrop-filter: var(--glass-blur-light);
    backdrop-filter: var(--glass-blur-light);
  }
  .modal-card,
  .hl-toolbar-sheet,
  .hl-mark-sheet,
  .toc-drawer,
  .fav-menu {
    -webkit-backdrop-filter: var(--glass-blur);
    backdrop-filter: var(--glass-blur);
  }
  .rss-link-wrap,
  .empty-hint.big {
    background: var(--glass-bg-subtle);
    border: 1px solid var(--glass-border-outer);
    box-shadow: var(--glass-highlight), var(--glass-shadow);
  }
  .empty-hint.big {
    border-radius: var(--radius);
    max-width: 560px;
    margin: 40px auto;
  }
  .modal-overlay {
    background: rgba(15, 15, 15, 0.32);
    backdrop-filter: blur(6px) saturate(120%);
    -webkit-backdrop-filter: blur(6px) saturate(120%);
  }
  .hl-toolbar-sheet,
  .hl-mark-sheet {
    background: var(--glass-bg-strong);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border-color: var(--glass-border-outer);
    box-shadow: var(--glass-highlight), var(--glass-shadow-lg);
  }
  .hl-toolbar:not(.hl-toolbar-bottom) {
    background: var(--glass-dark-bg);
    backdrop-filter: var(--glass-blur-light);
    -webkit-backdrop-filter: var(--glass-blur-light);
    border: 1px solid var(--glass-dark-border);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1), 0 8px 28px rgba(0, 0, 0, 0.22);
  }
  .toc-drawer {
    background: var(--glass-bg-strong);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border-left-color: var(--glass-border-outer);
    box-shadow: -8px 0 40px rgba(0, 0, 0, 0.1);
  }
  .toc-backdrop {
    background: rgba(10, 10, 10, 0.28);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
  }
  .fav-menu {
    background: var(--glass-bg-strong);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border-color: var(--glass-border-outer);
    box-shadow: var(--glass-highlight), var(--glass-shadow-lg);
  }
  .comments-area {
    background: var(--glass-bg-subtle);
    backdrop-filter: var(--glass-blur-light);
    -webkit-backdrop-filter: var(--glass-blur-light);
    border-color: var(--glass-border-outer);
    box-shadow: var(--glass-highlight);
  }
  .site-search {
    background: var(--glass-bg-subtle);
    backdrop-filter: blur(12px) saturate(160%);
    -webkit-backdrop-filter: blur(12px) saturate(160%);
    border: 1px solid var(--glass-border-outer);
    box-shadow: var(--glass-highlight);
  }
  .auth-user {
    background: var(--glass-bg-subtle);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid var(--glass-border-outer);
  }
  .fab {
    background: var(--glass-bg-strong);
    backdrop-filter: var(--glass-blur-light);
    -webkit-backdrop-filter: var(--glass-blur-light);
    border-color: var(--glass-border-outer);
    box-shadow: var(--glass-highlight), 0 4px 16px rgba(0, 0, 0, 0.1);
  }
  .fab:hover {
    background: var(--accent);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }
  .hl-comment-display {
    background: var(--glass-bg-subtle);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border-color: var(--glass-border-outer);
    box-shadow: var(--glass-highlight);
  }
  .footer-beian {
    background: var(--glass-bg-subtle);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border-color: var(--glass-border-outer);
  }
  .analysis-section {
    background: rgba(255, 255, 255, 0.72);
    border-color: var(--glass-border-outer);
  }
  .analysis-section summary {
    background: rgba(255, 255, 255, 0.82);
    color: var(--fg);
    font-weight: 600;
  }
  /* 详细解读正文：玻璃模式下背景更不透明，文字加深，避免透出彩色光晕导致「颜色奇怪」 */
  .analysis-content {
    background: #fff;
    color: #1a1a1a;
  }
  .analysis-content strong { color: #1a1a1a; }
  .abstract {
    border-color: var(--glass-border-outer);
    background: rgba(255, 255, 255, 0.72);
  }
  .abstract summary {
    background: rgba(255, 255, 255, 0.82);
    color: var(--fg);
    font-weight: 600;
  }
  .abstract p {
    background: #fff;
    color: #2b2b29;
  }
  .visit-pill {
    background: rgba(240, 253, 250, 0.62);
    backdrop-filter: blur(12px) saturate(165%);
    -webkit-backdrop-filter: blur(12px) saturate(165%);
    border-color: rgba(153, 246, 228, 0.65);
    box-shadow: var(--glass-highlight), 0 2px 10px rgba(15, 118, 110, 0.1);
  }
  .visit-pill:hover {
    background: rgba(204, 251, 241, 0.78);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
  }
  .visit-pill.is-active {
    background: linear-gradient(135deg, rgba(20, 184, 166, 0.92), rgba(13, 148, 136, 0.92));
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
  }
  .github-link {
    background: var(--glass-dark-bg);
    backdrop-filter: blur(14px) saturate(150%);
    -webkit-backdrop-filter: blur(14px) saturate(150%);
    border: 1px solid var(--glass-dark-border);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12), 0 4px 14px rgba(0, 0, 0, 0.18);
  }
  .fav-tab:not(.active) {
    background: rgba(255, 255, 255, 0.62);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border-color: var(--glass-border-outer);
    box-shadow: var(--glass-highlight);
  }
  .nav-btn.outline,
  .lc-btn:not(.active) {
    background: rgba(255, 255, 255, 0.45);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border-color: var(--glass-border-outer);
  }
  .nav-btn.outline:hover,
  .lc-btn:not(.active):hover {
    background: rgba(255, 255, 255, 0.72);
  }
  .ia-btn {
    background: rgba(255, 255, 255, 0.42);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border-color: var(--glass-border-outer);
  }
  .search-form input,
  .search-form select,
  .rss-form select,
  .rss-form input,
  .fav-newfolder-input,
  .hl-mark-input {
    background: rgba(255, 255, 255, 0.55);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border-color: var(--glass-border-outer);
  }
  .stats-table-wrap summary {
    background: rgba(255, 255, 255, 0.55);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
  }
  .stats-table th {
    background: rgba(255, 255, 255, 0.48);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
  }
  .stats-table tr.is-today td {
    background: rgba(236, 254, 255, 0.72);
  }
  .hour-col[data-tip]::after,
  .day-col[data-tip]::after {
    background: var(--glass-dark-bg);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid var(--glass-dark-border);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.22);
  }
  .plugin-faq details {
    background: rgba(255, 255, 255, 0.55);
    border-color: var(--glass-border-outer);
  }
  .loading-indicator {
    background: rgba(255, 255, 255, 0.5);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px dashed var(--glass-border-outer);
    border-radius: var(--radius);
  }
  code {
    background: rgba(243, 243, 240, 0.72);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
  }
}

@media (prefers-reduced-motion: reduce) {
  body::after { display: none; }
}

a { color: inherit; text-decoration: none; }
code { font-family: var(--font-mono); font-size: .9em; background: #f3f3f0; padding: 1px 6px; border-radius: 3px; }

/* ── 顶栏 ── */
.site-header {
  background: var(--glass-bg-strong);
  border-bottom: 1px solid var(--glass-border-outer);
  position: sticky; top: 0; z-index: 50;
  transition: transform .28s ease;
}
/* 仅当顶栏较高（>20vh）且页面已下滚时，向下滚隐藏、向上滚显示。
   触发由 .site-header-autohide.is-hidden 控制（JS 添加），见 app.js */
.site-header.site-header-autohide.is-hidden {
  transform: translateY(-100%);
}
.site-header-inner {
  max-width: 1180px; margin: 0 auto;
  padding: 12px 24px;
  display: flex; align-items: center; gap: 24px; flex-wrap: wrap;
}
.brand {
  display: flex; align-items: center; gap: 8px;
  font-weight: 700; font-size: 17px;
}
.brand-emoji { font-size: 22px; }
.brand-text { letter-spacing: -.2px; }

.site-nav { display: flex; gap: 4px; }
.site-nav a {
  padding: 8px 14px; border-radius: 6px;
  color: var(--fg-muted); font-weight: 500;
  transition: all .15s;
}
.site-nav a:hover { background: #f3f3f0; color: var(--fg); }
.site-nav a.active { background: var(--accent); color: #fff; }

.site-search {
  display: flex; gap: 4px;
  background: #f3f3f0;
  border-radius: 10px; padding: 4px; flex: 0 1 280px;
}
.site-search input {
  flex: 1; border: none; background: transparent;
  padding: 6px 10px; font-size: 14px; outline: none;
  font-family: var(--font-ui);
}
.site-search button {
  border: none; background: var(--fg); color: #fff;
  padding: 4px 12px; border-radius: 6px; cursor: pointer; font-size: 14px;
}

/* ── 主体 ── */
.site-main {
  flex: 1; max-width: 1180px; width: 100%;
  margin: 0 auto; padding: 28px 24px;
}

.page-header { margin-bottom: 24px; }
/* glass 模式下由 @supports 块补充 padding / border */
.page-header h1 { font-size: 26px; font-weight: 700; margin-bottom: 4px; }
.page-header .subtitle { color: var(--fg-muted); font-size: 14px; }

.empty-hint {
  text-align: center; color: var(--fg-muted);
  padding: 40px 20px;
}
.empty-hint.big { padding: 80px 20px; }
.empty-hint.big h1 { font-size: 28px; margin-bottom: 12px; color: var(--fg); }

/* ── 日期页 ── */
.date-toolbar {
  display: flex; align-items: center; gap: 16px;
  flex-wrap: wrap; margin-bottom: 20px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border-outer);
  border-radius: var(--radius); padding: 16px 20px;
  box-shadow: var(--glass-highlight), var(--glass-shadow);
}
.date-toolbar-left { flex: 1; min-width: 240px; }
.date-toolbar-right { display: flex; gap: 8px; flex-wrap: wrap; }

.date-title {
  font-size: 22px; font-weight: 700; display: flex; align-items: center; gap: 10px;
  font-family: var(--font-mono);
}
.today-pill {
  display: inline-block; background: var(--accent); color: #fff;
  font-size: 11px; padding: 3px 10px; border-radius: 12px;
  font-family: var(--font-ui); letter-spacing: 1px;
}
.date-stats {
  margin-top: 6px; color: var(--fg-muted); font-size: 13px;
  display: flex; gap: 16px; flex-wrap: wrap;
}
.nav-btn {
  display: inline-flex; align-items: center;
  padding: 6px 12px; border-radius: 6px;
  background: var(--fg); color: #fff;
  font-size: 13px; font-weight: 500;
  transition: opacity .15s;
}
.nav-btn:hover { opacity: .85; }
.nav-btn.outline { background: transparent; color: var(--fg); border: 1px solid var(--border); }
.nav-btn.outline:hover { background: #f3f3f0; opacity: 1; }
.nav-btn.action-download { background: #0f766e; }
.nav-btn.action-zotero { background: #1f6feb; }

.report-frame-wrap {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border-outer);
  border-radius: var(--radius); overflow: hidden;
  box-shadow: var(--glass-highlight), var(--glass-shadow);
}
.report-frame {
  width: 100%; height: calc(100vh - 220px); min-height: 600px;
  border: 0; display: block;
}

/* ── 历史 ── */
.history-grid {
  display: grid; gap: 16px;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
}
.history-card {
  background: var(--glass-bg-strong);
  border: 1px solid var(--glass-border-outer);
  border-radius: var(--radius); padding: 18px;
  box-shadow: var(--glass-highlight), var(--glass-shadow);
  transition: transform .12s, box-shadow .12s;
}
.history-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--glass-highlight), 0 10px 28px rgba(0, 0, 0, 0.1);
  border-color: rgba(209, 77, 65, 0.35);
}
.history-date {
  font-family: var(--font-mono); font-size: 18px;
  font-weight: 600; color: var(--fg); margin-bottom: 6px;
}
.history-stats { color: var(--fg-muted); font-size: 13px; display: flex; gap: 12px; }
.history-cats {
  margin-top: 8px; font-size: 12px; color: var(--fg-muted);
  font-family: var(--font-mono);
}
.history-model {
  margin-top: 4px; font-size: 11px; color: var(--fg-muted);
  font-family: var(--font-mono);
}

/* ── 搜索 ── */
.search-form {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border-outer);
  border-radius: var(--radius); padding: 18px;
  margin-bottom: 24px;
  box-shadow: var(--glass-highlight), var(--glass-shadow);
}
.search-form-row {
  display: grid; gap: 12px;
  grid-template-columns: 2fr 1fr 1fr auto;
  align-items: end;
}
.search-form label {
  display: flex; flex-direction: column; gap: 4px;
  font-size: 12px; color: var(--fg-muted); font-weight: 500;
  text-transform: uppercase; letter-spacing: .5px;
}
.search-form input, .search-form select {
  font-family: var(--font-ui); font-size: 14px;
  border: 1px solid var(--border); border-radius: 6px;
  padding: 8px 10px; background: #fff; outline: none;
}
.search-form input:focus, .search-form select:focus { border-color: var(--accent); }
.search-form button {
  height: 36px; padding: 0 20px; border: none; cursor: pointer;
  background: var(--accent); color: #fff; font-weight: 600;
  border-radius: 6px; font-size: 14px;
}

.search-summary { color: var(--fg-muted); margin-bottom: 16px; }
.search-summary strong { color: var(--accent); }

/* ── RSS ── */
.rss-card {
  background: var(--glass-bg-strong);
  border: 1px solid var(--glass-border-outer);
  border-radius: var(--radius);
  padding: 18px;
  margin-bottom: 22px;
  box-shadow: var(--glass-highlight), var(--glass-shadow);
}
.rss-form {
  display: grid;
  gap: 12px;
  grid-template-columns: 1fr 180px auto;
  align-items: end;
}
.rss-form label {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 12px;
  color: var(--fg-muted);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: .5px;
}
.rss-form select,
.rss-form input {
  font-family: var(--font-ui);
  font-size: 14px;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 8px 10px;
  background: #fff;
  outline: none;
}
.rss-form button {
  height: 36px;
  padding: 0 16px;
  border: none;
  cursor: pointer;
  background: var(--accent);
  color: #fff;
  font-weight: 600;
  border-radius: 6px;
  font-size: 14px;
}
.rss-link-wrap {
  margin-top: 14px;
  border: 1px dashed var(--border);
  border-radius: 8px;
  padding: 10px 12px;
  background: #fdfdfc;
}
.rss-link-title {
  color: var(--fg-muted);
  font-size: 12px;
  margin-bottom: 6px;
}
.rss-link {
  display: block;
  word-break: break-all;
  line-height: 1.45;
}

/* ── Zotero 插件页 ── */
.plugin-hero {
  display: grid; gap: 24px;
  grid-template-columns: 1.4fr 1fr;
  background: var(--glass-bg-strong);
  border: 1px solid var(--glass-border-outer);
  border-radius: var(--radius); padding: 28px;
  box-shadow: var(--glass-highlight), var(--glass-shadow);
  margin-bottom: 26px; align-items: center;
}
.plugin-hero-left h2 {
  font-size: 22px; font-weight: 700; margin-bottom: 8px;
  font-family: var(--font-mono);
}
.plugin-hero-left p { color: var(--fg-muted); margin-bottom: 14px; }
.plugin-feature-list { list-style: none; padding: 0; display: grid; gap: 6px; }
.plugin-feature-list li { font-size: 14px; color: var(--fg); }
.plugin-hero-right { display: flex; flex-direction: column; align-items: center; gap: 10px; }
.plugin-download-btn {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  text-align: center; padding: 24px 32px; min-width: 240px;
  background: linear-gradient(135deg, #1f6feb, #2da44e);
  color: #fff; border-radius: 12px;
  box-shadow: 0 8px 24px rgba(31, 111, 235, .25);
  transition: transform .15s, box-shadow .15s;
}
.plugin-download-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(31, 111, 235, .3);
}
.plugin-download-btn.disabled {
  background: #d1d5db; color: #4b5563;
  box-shadow: none; cursor: not-allowed;
}
.plugin-download-icon { font-size: 30px; }
.plugin-download-title { font-size: 18px; font-weight: 700; letter-spacing: .3px; }
.plugin-download-sub { font-size: 12px; opacity: .85; font-family: var(--font-mono); }
.plugin-download-hint { font-size: 12px; color: var(--fg-muted); }

.plugin-steps, .plugin-config, .plugin-menu, .plugin-faq {
  background: var(--glass-bg-strong);
  border: 1px solid var(--glass-border-outer);
  border-radius: var(--radius); padding: 22px 26px;
  box-shadow: var(--glass-highlight), var(--glass-shadow);
  margin-bottom: 22px;
}
.plugin-steps h2, .plugin-config h2, .plugin-menu h2, .plugin-faq h2 {
  font-size: 18px; font-weight: 700; margin-bottom: 12px;
}
.plugin-steps ol { padding-left: 22px; display: grid; gap: 8px; color: var(--fg); }
.plugin-steps li { line-height: 1.7; }
.plugin-config .subtitle { color: var(--fg-muted); margin-bottom: 10px; }
.config-block {
  background: #1a1a1a; color: #f8f8f2;
  padding: 16px 18px; border-radius: 8px;
  font-family: var(--font-mono); font-size: 13px;
  overflow-x: auto; white-space: pre;
}
.config-block code { background: transparent; color: inherit; padding: 0; }
.plugin-faq details {
  border: 1px solid var(--border); border-radius: 8px;
  padding: 10px 14px; margin-bottom: 8px; background: #fdfdfc;
}
.plugin-faq summary {
  cursor: pointer; font-weight: 600; color: var(--fg);
  list-style: none;
}
.plugin-faq summary::before { content: "▸ "; color: var(--accent); }
.plugin-faq details[open] summary::before { content: "▾ "; }
.plugin-faq p { margin-top: 8px; color: var(--fg-muted); line-height: 1.7; }

@media (max-width: 720px) {
  .plugin-hero { grid-template-columns: 1fr; padding: 20px; }
}

.search-results, .paper-list { display: flex; flex-direction: column; gap: 16px; }

/* ── 列表控制栏（排序 / 展开折叠） ── */
.list-controls {
  display: flex; flex-wrap: wrap; gap: 14px 24px;
  align-items: center; justify-content: space-between;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border-outer);
  border-radius: var(--radius); padding: 10px 16px;
  box-shadow: var(--glass-highlight), var(--glass-shadow);
  margin-bottom: 16px;
}
.lc-group { display: flex; align-items: center; flex-wrap: wrap; gap: 8px; }
.lc-label { font-size: 13px; color: var(--fg-muted); font-weight: 600; margin-right: 2px; }
.lc-btn {
  font-family: var(--font-ui); font-size: 13px; font-weight: 500;
  padding: 5px 12px; border-radius: 6px; cursor: pointer;
  background: transparent; color: var(--fg);
  border: 1px solid var(--border); transition: all .15s;
}
.lc-btn:hover { background: #f3f3f0; }
.lc-btn.active {
  background: var(--accent); color: #fff; border-color: var(--accent);
}

.paper-index {
  display: inline-block; font-family: var(--font-mono);
  font-size: 12px; font-weight: 600; color: var(--fg-muted);
  margin-right: 6px;
}

/* ── 实验室动态栏（新闻/公告） ── */
.lab-feed {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border-outer);
  border-left: 3px solid var(--accent);
  border-radius: var(--radius);
  padding: 12px 16px;
  margin-bottom: 16px;
  box-shadow: var(--glass-highlight), var(--glass-shadow);
}
.lab-feed-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 8px;
}
.lab-feed-title { font-size: 14px; font-weight: 700; color: var(--fg); }
.lab-feed-more { font-size: 12px; color: var(--accent); font-weight: 500; }
.lab-feed-list { list-style: none; display: flex; flex-direction: column; gap: 6px; }
.lab-feed-item {
  display: flex; align-items: baseline; gap: 10px;
  font-size: 13px; line-height: 1.5;
  padding: 4px 0;
  border-bottom: 1px dashed var(--border);
}
.lab-feed-item:last-child { border-bottom: none; }
.lab-feed-tag {
  flex: 0 0 auto; font-size: 11px; font-weight: 600;
  padding: 1px 8px; border-radius: 999px; white-space: nowrap;
}
.lab-feed-tag-news { background: var(--accent-light); color: var(--accent); }
.lab-feed-tag-notice { background: #eff6ff; color: #1d4ed8; }
.lab-feed-date {
  flex: 0 0 auto; font-family: var(--font-mono);
  font-size: 12px; color: var(--fg-muted);
}
.lab-feed-item-title { flex: 1 1 auto; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lab-feed-item-title a { color: var(--fg); }
.lab-feed-item-title a:hover { color: var(--accent); text-decoration: underline; }

@media (max-width: 640px) {
  .lab-feed-item { flex-wrap: wrap; gap: 4px 8px; }
  .lab-feed-item-title { flex: 1 1 100%; white-space: normal; }
}

.paper-card {
  background: var(--glass-bg-strong);
  border: 1px solid var(--glass-border-outer);
  border-radius: var(--radius); padding: 18px 22px;
  box-shadow: var(--glass-highlight), var(--glass-shadow);
}
.paper-card-header { margin-bottom: 6px; }
.paper-card-title-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.paper-card-title-row h2 {
  flex: 1 1 auto;
  min-width: 0;
  margin-bottom: 0;
}
.paper-card h2 {
  font-size: 17px; font-weight: 700; line-height: 1.4;
  margin-bottom: 6px;
}
.ia-btn.ia-share {
  flex: 0 0 auto;
  margin-top: 2px;
}
.ia-btn.ia-share-done {
  border-color: #0d9488;
  color: #0f766e;
  background: #ecfeff;
}
.paper-share-toolbar .paper-share-title {
  font-size: 18px;
  line-height: 1.45;
  font-family: var(--font-ui);
  font-weight: 700;
}
.paper-share-list {
  max-width: 920px;
}
.paper-card h2 a {
  border-bottom: 2px solid transparent;
  transition: border-color .15s;
}
.paper-card h2 a:hover { border-color: var(--accent); }
.paper-card-top {
  display: flex; gap: 8px; align-items: center; flex-wrap: wrap;
  margin-bottom: 8px;
}
.date-link {
  background: var(--fg); color: #fff !important;
  font-family: var(--font-mono); font-size: 12px;
  padding: 2px 10px; border-radius: 4px;
  text-decoration: none !important;
}
.cat-tag {
  display: inline-block; font-family: var(--font-mono);
  font-size: 11px; padding: 2px 8px; background: #f0f0ee;
  border-radius: 4px; color: var(--fg-muted);
}
.org-tag-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 8px;
}
.org-tag {
  display: inline-block;
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 999px;
  color: #0f766e;
  border: 1px solid #99f6e4;
  background: #ecfeff;
}
.badge {
  display: inline-block; font-size: 11px; padding: 2px 8px;
  border-radius: 4px; font-weight: 500;
}
.badge-cross { background: var(--cross-bg); color: var(--cross); }
.paper-meta-line {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
}
.arxiv-version-badge {
  display: inline-flex;
  align-items: center;
  font-size: 11px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 999px;
  line-height: 1.35;
  white-space: nowrap;
}
.arxiv-version-badge.is-pending {
  width: 52px;
  height: 18px;
  background: linear-gradient(90deg, #f3f4f6 25%, #e5e7eb 50%, #f3f4f6 75%);
  background-size: 200% 100%;
  animation: arxiv-ver-shimmer 1.1s ease-in-out infinite;
  border: 1px solid #e5e7eb;
}
.arxiv-version-badge.is-new {
  color: #0f766e;
  background: #ecfeff;
  border: 1px solid #99f6e4;
}
.arxiv-version-badge.is-update {
  color: #b45309;
  background: #fffbeb;
  border: 1px solid #fde68a;
}
.arxiv-version-badge.is-failed {
  display: none;
}
@keyframes arxiv-ver-shimmer {
  0% { background-position: 100% 0; }
  100% { background-position: -100% 0; }
}

.paper-authors { color: var(--fg-muted); font-size: 13px; margin-bottom: 4px; }
.paper-arxiv-comments {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px 10px;
  color: var(--fg-muted);
  font-size: 13px;
  line-height: 1.5;
  margin-bottom: 6px;
}
.paper-arxiv-comments .arxiv-meta-label {
  font-weight: 600;
  color: var(--fg);
  flex-shrink: 0;
}
.paper-arxiv-comments .arxiv-comment-text {
  flex: 1 1 12rem;
  min-width: 0;
  word-break: break-word;
}
.ccf-tag-row {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}
.ccf-tag {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 8px;
  border-radius: 6px;
  font-size: 11px;
  line-height: 1.3;
  border: 1px solid transparent;
  max-width: 100%;
}
.ccf-rank-pill {
  font-weight: 700;
  font-family: var(--font-mono);
  letter-spacing: 0.02em;
}
.ccf-abbr {
  font-weight: 600;
  color: var(--fg);
}
.ccf-type-pill {
  padding: 1px 6px;
  border-radius: 4px;
  font-size: 10px;
  font-weight: 500;
}
.ccf-area {
  color: var(--fg-muted);
  font-size: 10px;
  max-width: 8rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.ccf-rank-A {
  background: #FAECE7;
  color: #993C1D;
  border-color: #f0d4c8;
}
.ccf-rank-A .ccf-type-pill { background: rgba(153, 60, 29, 0.12); color: #993C1D; }
.ccf-rank-B {
  background: #E6F1FB;
  color: #185FA5;
  border-color: #c5ddf3;
}
.ccf-rank-B .ccf-type-pill { background: rgba(24, 95, 165, 0.12); color: #185FA5; }
.ccf-rank-C {
  background: #EAF3DE;
  color: #3B6D11;
  border-color: #c8e0b0;
}
.ccf-rank-C .ccf-type-pill { background: rgba(59, 109, 17, 0.12); color: #3B6D11; }
.paper-subjects { color: var(--fg-muted); font-size: 12px; font-family: var(--font-mono); margin-bottom: 8px; }
.paper-links { display: flex; gap: 14px; font-size: 13px; margin-top: 10px; }
.paper-links a { color: var(--accent); font-weight: 500; }

.abstract { margin-top: 10px; border: 1px solid var(--border); border-radius: 6px; overflow: hidden; }
.abstract summary {
  padding: 8px 14px; background: #f9f9f7; cursor: pointer;
  font-size: 13px; color: var(--fg-muted); font-weight: 500;
}
.abstract p { padding: 14px; font-size: 14px; color: var(--fg-muted); line-height: 1.7; }

/* ── 底栏 ── */
.site-footer {
  border-top: 1px solid var(--glass-border-outer);
  background: var(--glass-bg);
  padding: 20px 24px 22px;
  margin-top: 8px;
}
.site-footer-inner {
  max-width: 1180px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  text-align: center;
}
.footer-meta {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 6px 0;
  font-size: 13px;
  line-height: 1.5;
}
.footer-meta-item {
  display: inline-flex;
  align-items: center;
  color: var(--fg-muted);
}
.footer-meta-item:not(:last-child)::after {
  content: "";
  display: block;
  width: 1px;
  height: 12px;
  margin: 0 14px;
  background: var(--border);
}
.footer-meta-item:not(.footer-meta-muted):hover {
  color: var(--accent);
}
.footer-meta-muted {
  color: var(--fg-muted);
}
.footer-sub {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 8px 16px;
  font-size: 12px;
  color: var(--fg-muted);
  line-height: 1.5;
}
.footer-powered a {
  color: var(--fg-muted);
  font-weight: 500;
}
.footer-powered a:hover {
  color: var(--accent);
}
.footer-version {
  margin-left: 6px;
  font-variant-numeric: tabular-nums;
  opacity: 0.85;
}
.footer-beian {
  color: var(--fg-muted);
  font-size: 12px;
  padding: 2px 8px;
  border-radius: 4px;
  background: #f9f9f7;
  border: 1px solid var(--border);
  transition: color .15s, border-color .15s;
}
.footer-beian:hover {
  color: var(--fg);
  border-color: #d1d5db;
}
@media (max-width: 640px) {
  .site-footer { padding: 16px 16px 18px; }
  .footer-meta { font-size: 12px; }
  .footer-meta-item:not(:last-child)::after {
    margin: 0 10px;
    height: 10px;
  }
  .footer-sub {
    flex-direction: column;
    gap: 6px;
  }
}



/* visit pill (顶栏访问胶囊) */
.visit-pill {
  margin-left: auto;
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 14px;
  background: linear-gradient(135deg, #f0fdfa, #ecfeff);
  border: 1px solid #99f6e4;
  border-radius: 999px;
  font-size: 12px;
  color: #0f766e;
  font-weight: 500;
  white-space: nowrap;
  transition: transform .15s, box-shadow .15s, background .15s, border-color .15s;
  user-select: none;
}
.visit-pill:hover {
  background: linear-gradient(135deg, #ccfbf1, #cffafe);
  border-color: #5eead4;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(15, 118, 110, .18);
}
.visit-pill.is-active {
  background: linear-gradient(135deg, #14b8a6, #0d9488);
  border-color: #0d9488;
  color: #fff;
}
.visit-pill.is-active .visit-pill-num { color: #fff; }
.visit-pill-eye {
  font-size: 14px;
  display: inline-block;
  transform-origin: center;
  animation: visit-pulse 3.4s ease-in-out infinite;
}
@keyframes visit-pulse {
  0%, 88%, 100% { transform: scaleY(1); }
  92% { transform: scaleY(0.1); }
  96% { transform: scaleY(1); }
}
.visit-pill-num {
  font-family: var(--font-mono);
  font-weight: 700;
  color: #0d9488;
  font-size: 13px;
  letter-spacing: -.2px;
}
.visit-pill-label { opacity: .78; }
.visit-pill-sep { opacity: .35; margin: 0 1px; }

/* GitHub 链接按钮（替换访问统计） */
.github-link {
  margin-left: 4px;
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 14px;
  background: var(--fg);
  color: #fff;
  border-radius: 999px;
  font-size: 13px; font-weight: 600;
  white-space: nowrap;
  transition: transform .15s, box-shadow .15s, opacity .15s;
}
.github-link:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, .18);
  opacity: .92;
}
.github-icon { display: block; }

/* stats hero cards */
.stats-hero {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 16px;
  margin-bottom: 22px;
}
.stats-hero-card {
  background: var(--glass-bg-strong);
  border: 1px solid var(--glass-border-outer);
  border-radius: var(--radius);
  padding: 22px 24px;
  box-shadow: var(--glass-highlight), var(--glass-shadow);
  text-align: center;
  position: relative;
  overflow: hidden;
  transition: transform .15s, box-shadow .15s;
}
.stats-hero-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--glass-highlight), 0 12px 32px rgba(0, 0, 0, 0.1);
}
.stats-hero-card::before {
  content: "";
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--accent), #f59e0b);
}
.stats-hero--today::before { background: linear-gradient(90deg, #14b8a6, #06b6d4); }
.stats-hero--active::before { background: linear-gradient(90deg, #8b5cf6, #ec4899); }
.stats-hero--total::before { background: linear-gradient(90deg, #1f6feb, #7c3aed); }
.stats-hero--avg::before   { background: linear-gradient(90deg, #0f766e, #22c55e); }
.stats-hero--peak::before  { background: linear-gradient(90deg, #f97316, #dc2626); }

.stats-hero-icon {
  font-size: 20px; margin-bottom: 4px;
  opacity: .85;
}
.stats-hero-label {
  color: var(--fg-muted);
  font-size: 12px;
  letter-spacing: .5px;
  margin-bottom: 6px;
  text-transform: uppercase;
}
.stats-hero-num {
  font-family: var(--font-mono);
  font-size: 36px;
  font-weight: 700;
  color: var(--fg);
  line-height: 1.1;
  letter-spacing: -.5px;
}
.stats-hero-foot {
  color: var(--fg-muted);
  font-size: 12px;
  margin-top: 8px;
  font-family: var(--font-mono);
}

/* stats section + chart */
.stats-section {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border-outer);
  border-radius: var(--radius);
  padding: 20px 24px 22px;
  box-shadow: var(--glass-highlight), var(--glass-shadow);
  margin-bottom: 22px;
}
.stats-section-head {
  display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap;
  margin-bottom: 18px;
}
.stats-section-head h2 {
  font-size: 16px;
  font-weight: 700;
  display: inline-flex; align-items: center; gap: 8px;
}
.stats-section-icon { font-size: 18px; }
.stats-section-sub {
  font-size: 12px;
  color: var(--fg-muted);
}

.hour-chart, .day-chart {
  display: flex;
  align-items: flex-end;
  gap: 4px;
  height: 200px;
}
.hour-col, .day-col {
  flex: 1 1 0;
  min-width: 0;
  display: flex;
  flex-direction: column;
  height: 100%;
  position: relative;
  cursor: default;
}
.hour-bar-wrap, .day-bar-wrap {
  flex: 1;
  display: flex;
  align-items: flex-end;
  width: 100%;
}
.hour-bar, .day-bar {
  width: 100%;
  background: linear-gradient(180deg, #f59e0b 0%, var(--accent) 100%);
  border-radius: 4px 4px 0 0;
  min-height: 2px;
  transition: filter .15s, transform .15s;
}
.hour-bar.is-peak {
  background: linear-gradient(180deg, #fb923c 0%, #dc2626 100%);
  box-shadow: 0 0 0 2px rgba(220, 38, 38, .12);
}
.day-bar.is-today {
  background: linear-gradient(180deg, #06b6d4 0%, #0d9488 100%);
  box-shadow: 0 0 0 2px rgba(13, 148, 136, .18);
}
.hour-col:hover .hour-bar,
.day-col:hover .day-bar {
  filter: brightness(1.12);
  transform: scaleY(1.02);
  transform-origin: bottom;
}
.hour-label, .day-label {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-muted);
  text-align: center;
  margin-top: 6px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* tooltip on hover via data-tip */
.hour-col[data-tip]::after,
.day-col[data-tip]::after {
  content: attr(data-tip);
  position: absolute;
  bottom: calc(100% + 4px);
  left: 50%;
  transform: translateX(-50%) translateY(4px);
  background: #1a1a1a;
  color: #fff;
  font-family: var(--font-mono);
  font-size: 11px;
  padding: 4px 8px;
  border-radius: 6px;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity .15s, transform .15s;
  z-index: 5;
  box-shadow: 0 4px 12px rgba(0, 0, 0, .25);
}
.hour-col:hover::after,
.day-col:hover::after {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

.day-chart-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.day-chart {
  min-width: 100%;
}

.stats-table-wrap {
  margin-top: 18px;
  border: 1px solid var(--border);
  border-radius: 6px;
  overflow: hidden;
}
.stats-table-wrap summary {
  padding: 10px 14px;
  background: #f9f9f7;
  cursor: pointer;
  font-size: 13px;
  color: var(--fg-muted);
  font-weight: 500;
  list-style: none;
}
.stats-table-wrap summary::before { content: "▸ "; color: var(--accent); }
.stats-table-wrap[open] summary::before { content: "▾ "; }
.stats-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.stats-table th, .stats-table td {
  padding: 8px 14px;
  text-align: left;
  border-top: 1px solid var(--border);
}
.stats-table th {
  background: #fafaf8;
  font-weight: 600;
  color: var(--fg-muted);
  font-size: 12px;
  letter-spacing: .5px;
  text-transform: uppercase;
}
.stats-table td:nth-child(2),
.stats-table td:nth-child(3) {
  font-family: var(--font-mono);
  font-weight: 600;
}
.stats-table tr.is-today td {
  background: #ecfeff;
  color: #0f766e;
}

/* ── Auth area ── */
.auth-area {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-left: auto;
}
.auth-link {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 6px 12px; border-radius: 999px;
  font-size: 13px; font-weight: 500;
  color: var(--fg-muted);
  transition: background .15s, color .15s;
}
.auth-link svg { width: 13px; height: 13px; flex: none; }
.auth-link:hover { background: var(--accent-light); color: var(--accent); }
.auth-user {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 3px 12px 3px 3px; margin-left: 4px;
  background: #f3f3f0; border-radius: 999px;
}
.auth-avatar {
  width: 24px; height: 24px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--accent); color: #fff;
  font-size: 12px; font-weight: 700; line-height: 1;
}
.auth-name {
  font-size: 13px; font-weight: 600; color: var(--fg);
  max-width: 130px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.auth-logout {
  display: inline-flex; align-items: center; justify-content: center;
  width: 30px; height: 30px; border-radius: 50%;
  border: none; background: transparent; cursor: pointer;
  color: var(--fg-muted);
  transition: background .15s, color .15s;
}
.auth-logout svg { width: 15px; height: 15px; }
.auth-logout:hover { background: var(--accent-light); color: var(--accent); }
.auth-login-btn {
  display: inline-flex; align-items: center;
  padding: 7px 16px; border-radius: 999px;
  background: var(--accent); color: #fff;
  border: none; cursor: pointer;
  font-size: 13px; font-weight: 600;
  font-family: var(--font-ui);
  transition: transform .15s, box-shadow .15s, opacity .15s;
}
.auth-login-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(209, 77, 65, .28);
}
.nav-btn.small {
  padding: 4px 10px;
  font-size: 12px;
}

/* ── Auth modal ── */
.modal-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0, 0, 0, .45);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
}
.modal-card {
  background: var(--glass-bg-strong);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  padding: 28px 32px;
  width: 380px;
  max-width: 90vw;
  box-shadow: var(--glass-highlight), var(--glass-shadow-lg);
  position: relative;
}
.modal-tabs {
  display: flex;
  gap: 0;
  margin-bottom: 20px;
  border-bottom: 2px solid var(--border);
}
.modal-tab {
  flex: 1;
  padding: 10px;
  text-align: center;
  border: none;
  background: transparent;
  font-weight: 600;
  font-size: 14px;
  cursor: pointer;
  color: var(--fg-muted);
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
}
.modal-tab.active {
  color: var(--accent);
  border-bottom-color: var(--accent);
}
.modal-tab-content label {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 12px;
  color: var(--fg-muted);
  margin-bottom: 12px;
  font-weight: 500;
}
.modal-tab-content input {
  font-family: var(--font-ui);
  font-size: 14px;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 8px 10px;
  outline: none;
}
.modal-tab-content input:focus { border-color: var(--accent); }
.modal-submit {
  width: 100%;
  padding: 10px;
  border: none;
  background: var(--accent);
  color: #fff;
  font-weight: 600;
  border-radius: 6px;
  font-size: 14px;
  cursor: pointer;
}
.modal-submit:hover { opacity: .85; }
.modal-error {
  color: var(--accent);
  font-size: 13px;
  min-height: 20px;
  margin-bottom: 8px;
}
.auth-ldap-hint {
  font-size: 13px;
  color: var(--fg-muted);
  margin: 0 0 12px;
  padding: 8px 12px;
  background: #f3f3f0;
  border-radius: 6px;
  line-height: 1.5;
}
.auth-register-disabled {
  font-size: 14px;
  color: var(--fg-muted);
  text-align: center;
  padding: 32px 16px;
  line-height: 1.6;
}
.modal-close {
  position: absolute;
  top: 12px;
  right: 16px;
  border: none;
  background: transparent;
  font-size: 22px;
  cursor: pointer;
  color: var(--fg-muted);
  line-height: 1;
}

/* ── Dynamic paper cards ── */
.paper-list-dynamic {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.loading-indicator {
  text-align: center;
  color: var(--fg-muted);
  padding: 40px 20px;
  font-size: 14px;
}
.analysis-section {
  margin-top: 12px;
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
}
.analysis-section summary {
  padding: 10px 16px;
  background: #f9f9f7;
  cursor: pointer;
  font-size: 13px;
  color: var(--fg-muted);
  font-weight: 500;
  list-style: none;
}
.analysis-section summary::before { content: "▸ "; color: var(--accent); }
.analysis-section[open] summary::before { content: "▾ "; }
.analysis-content {
  padding: 22px 26px;
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.85;
  color: #2b2b29;
  letter-spacing: .1px;
  word-wrap: break-word;
}
.analysis-content > *:first-child { margin-top: 0; }
.analysis-content > *:last-child { margin-bottom: 0; }

/* 标题层级 */
.analysis-content h1,
.analysis-content h2,
.analysis-content h3,
.analysis-content h4,
.analysis-content h5,
.analysis-content h6 {
  font-family: var(--font-ui);
  font-weight: 700;
  line-height: 1.35;
  color: var(--fg);
  scroll-margin-top: 80px;
}
.analysis-content h1 {
  font-size: 22px;
  margin: 28px 0 14px;
  padding-bottom: 8px;
  border-bottom: 2px solid var(--border);
}
.analysis-content h2 {
  font-size: 18px;
  margin: 26px 0 12px;
  padding-left: 12px;
  border-left: 4px solid var(--accent);
}
.analysis-content h3 {
  font-size: 16px;
  margin: 22px 0 10px;
  color: var(--accent);
}
.analysis-content h4,
.analysis-content h5,
.analysis-content h6 {
  font-size: 14.5px;
  margin: 18px 0 8px;
  color: var(--fg-muted);
}

.analysis-content p { margin: 0 0 14px; }
.analysis-content strong { font-weight: 700; color: #1a1a1a; }
.analysis-content em { color: #4b5563; }

/* 链接 */
.analysis-content a {
  color: var(--accent);
  font-weight: 500;
  text-decoration: none;
  border-bottom: 1px solid rgba(209, 77, 65, .35);
  transition: border-color .15s, background .15s;
}
.analysis-content a:hover {
  border-bottom-color: var(--accent);
  background: var(--accent-light);
}

/* 列表 */
.analysis-content ul,
.analysis-content ol { margin: 0 0 14px; padding-left: 26px; }
.analysis-content li { margin-bottom: 6px; padding-left: 2px; }
.analysis-content li::marker { color: var(--accent); font-weight: 600; }
.analysis-content ul ul,
.analysis-content ol ol,
.analysis-content ul ol,
.analysis-content ol ul { margin: 6px 0; }

/* 表格 */
.analysis-content table {
  width: 100%;
  border-collapse: collapse;
  margin: 16px 0;
  font-family: var(--font-ui);
  font-size: 13.5px;
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
  box-shadow: var(--card-shadow);
}
.analysis-content thead th {
  background: linear-gradient(180deg, #fbfbf9, #f1f1ee);
  font-weight: 700;
  color: var(--fg);
}
.analysis-content th,
.analysis-content td {
  padding: 9px 14px;
  border-bottom: 1px solid var(--border);
  border-right: 1px solid var(--border);
  text-align: left;
  vertical-align: top;
}
.analysis-content th:last-child,
.analysis-content td:last-child { border-right: none; }
.analysis-content tbody tr:last-child td { border-bottom: none; }
.analysis-content tbody tr:nth-child(even) { background: #fafaf8; }
.analysis-content tbody tr:hover { background: var(--accent-light); }

/* 代码 */
.analysis-content code {
  font-family: var(--font-mono);
  font-size: .86em;
  background: #f3f3f0;
  color: #b91c4d;
  padding: 2px 6px;
  border-radius: 4px;
  word-break: break-word;
}
.analysis-content pre {
  background: #1e1e2e;
  color: #e4e4e7;
  padding: 16px 18px;
  border-radius: 10px;
  overflow-x: auto;
  margin: 16px 0;
  line-height: 1.6;
  box-shadow: var(--card-shadow);
}
.analysis-content pre code {
  background: transparent;
  color: inherit;
  padding: 0;
  font-size: 13px;
}

/* 引用块 */
.analysis-content blockquote {
  margin: 16px 0;
  padding: 10px 16px;
  border-left: 4px solid var(--accent);
  background: var(--accent-light);
  border-radius: 0 8px 8px 0;
  color: #4b5563;
}
.analysis-content blockquote p:last-child { margin-bottom: 0; }

/* 分隔线 / 图片 */
.analysis-content hr {
  border: none;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--border), transparent);
  margin: 24px 0;
}
.analysis-content img {
  max-width: 100%;
  height: auto;
  border-radius: 8px;
  margin: 10px 0;
}

/* ── Interaction bar ── */
.interaction-bar {
  display: flex;
  gap: 8px;
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid var(--border);
}
.ia-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: transparent;
  cursor: pointer;
  font-size: 13px;
  color: var(--fg-muted);
  transition: all .15s;
}
.ia-btn:hover { background: #f3f3f0; }
.ia-btn.active { border-color: var(--accent); color: var(--accent); background: var(--accent-light); }
.ia-icon { font-size: 14px; }
.ia-count { font-family: var(--font-mono); font-weight: 600; }
.ia-label { font-size: 12px; }
.ia-fav .ia-fav-label { max-width: 120px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ia-fav.active { border-color: #f59e0b; color: #b45309; background: #fffbeb; }
.ia-fav.active .ia-icon { color: #f59e0b; }

/* ── 收藏文件夹弹层 ── */
.fav-menu {
  position: absolute;
  z-index: 200;
  min-width: 200px;
  max-width: 280px;
  background: var(--glass-bg-strong);
  border: 1px solid var(--glass-border);
  border-radius: 10px;
  box-shadow: var(--glass-highlight), var(--glass-shadow-lg);
  padding: 10px;
}
.fav-menu-title { font-size: 12px; font-weight: 600; color: var(--fg-muted); margin-bottom: 8px; }
.fav-folder-list { display: flex; flex-direction: column; gap: 2px; max-height: 220px; overflow-y: auto; }
.fav-folder-item {
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
  width: 100%; text-align: left; cursor: pointer;
  padding: 7px 10px; border: none; background: transparent; border-radius: 6px;
  font-size: 13px; color: var(--fg);
}
.fav-folder-item:hover { background: #f3f3f0; }
.fav-folder-item.active { background: #fffbeb; color: #b45309; font-weight: 600; }
.fav-folder-name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.fav-check { color: #f59e0b; }
.fav-newfolder { display: flex; gap: 6px; margin-top: 8px; }
.fav-newfolder-input {
  flex: 1; min-width: 0; padding: 6px 9px; font-size: 13px;
  border: 1px solid var(--border); border-radius: 6px; font-family: inherit;
}
.fav-newfolder-btn {
  padding: 6px 12px; font-size: 13px; cursor: pointer; white-space: nowrap;
  border: 1px solid var(--border); border-radius: 6px; background: var(--fg); color: #fff;
}
.fav-newfolder-btn:hover { opacity: .85; }
.fav-remove {
  width: 100%; margin-top: 8px; padding: 7px; cursor: pointer;
  border: 1px solid #fecaca; border-radius: 6px; background: #fef2f2; color: var(--accent);
  font-size: 13px; font-weight: 500;
}
.fav-remove:hover { background: #fee2e2; }

/* ── Comments ── */
.comments-area {
  margin-top: 8px;
  padding: 12px 16px;
  background: var(--glass-bg-subtle);
  border: 1px solid var(--glass-border-outer);
  border-radius: 8px;
  box-shadow: var(--glass-highlight);
}
.comments-list { margin-bottom: 10px; }
.comments-empty {
  font-size: 13px;
  color: var(--fg-muted);
  padding: 2px 0 4px;
}
.comment-item {
  display: flex;
  align-items: baseline;
  gap: 8px;
  padding: 6px 0;
  border-bottom: 1px solid #f0f0ee;
  flex-wrap: wrap;
}
.comment-item:last-child { border-bottom: none; }
.comment-user {
  font-weight: 600;
  font-size: 13px;
  color: var(--accent);
}
.comment-text {
  font-size: 13px;
  flex: 1;
  min-width: 0;
  word-break: break-word;
}
.comment-time {
  font-size: 11px;
  color: var(--fg-muted);
  font-family: var(--font-mono);
}
.comment-delete {
  border: none;
  background: transparent;
  color: var(--fg-muted);
  cursor: pointer;
  font-size: 16px;
  padding: 0 4px;
}
.comment-delete:hover { color: var(--accent); }
.comment-form {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-top: 8px;
}
.comment-input {
  flex: 1;
  padding: 6px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 13px;
  font-family: var(--font-ui);
  outline: none;
}
.comment-input:focus { border-color: var(--accent); }
.comment-counter {
  font-size: 11px;
  color: var(--fg-muted);
  font-family: var(--font-mono);
  white-space: nowrap;
}
.comment-submit {
  padding: 6px 14px;
  border: none;
  background: var(--accent);
  color: #fff;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
}
.comment-submit:hover { opacity: .85; }
.comment-login-hint {
  font-size: 13px;
  color: var(--fg-muted);
  margin-top: 8px;
}
.comment-login-hint a { color: var(--accent); font-weight: 500; }

/* ── Highlights ── */
mark.paper-highlight {
  padding: 1px 2px;
  border-radius: 2px;
  cursor: pointer;
}
mark.paper-highlight:hover {
  opacity: .85;
}
.hl-community-mark {
  background: transparent;
  border-bottom: 2px dashed #86efac;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
  padding: 0 1px;
  cursor: default;
}
.hl-comment-display {
  display: inline-flex;
  align-items: flex-start;
  gap: 4px;
  margin: 2px 4px 4px 0;
  padding: 4px 8px;
  max-width: 100%;
  font-size: 12px;
  line-height: 1.45;
  color: #4b5563;
  background: #f8fafc;
  border: 1px solid #e5e7eb;
  border-radius: 6px;
  cursor: pointer;
  vertical-align: middle;
}
.hl-comment-display:active {
  background: #f3f4f6;
}
.hl-comment-icon {
  flex-shrink: 0;
  font-size: 11px;
  line-height: 1.4;
}
.hl-comment-text {
  word-break: break-word;
}
.hl-toolbar {
  position: absolute;
  transform: translateX(-50%);
  z-index: 100;
  background: var(--fg);
  color: #fff;
  border-radius: 8px;
  padding: 5px 6px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, .2);
  display: flex;
  gap: 5px;
}
.hl-toolbar-bottom {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  top: auto;
  transform: none;
  z-index: 1100;
  padding: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  display: block;
}
.hl-toolbar-sheet {
  background: var(--glass-bg-strong);
  color: var(--fg);
  border-top: 1px solid var(--glass-border-outer);
  box-shadow: var(--glass-highlight), var(--glass-shadow-lg);
  padding: 12px 16px calc(12px + env(safe-area-inset-bottom, 0px));
  border-radius: 14px 14px 0 0;
}
.hl-toolbar-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 8px;
}
.hl-toolbar-label {
  font-size: 14px;
  font-weight: 600;
  color: var(--fg);
}
.hl-toolbar-close {
  border: none;
  background: #f3f4f6;
  color: var(--fg-muted);
  width: 32px;
  height: 32px;
  border-radius: 8px;
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  touch-action: manipulation;
}
.hl-toolbar-close:active {
  background: #e5e7eb;
}
.hl-toolbar-preview {
  font-size: 13px;
  line-height: 1.5;
  color: var(--fg-muted);
  margin: 0 0 12px;
  padding: 8px 10px;
  background: #f9fafb;
  border: 1px solid var(--border);
  border-radius: 8px;
  max-height: 4.5em;
  overflow: hidden;
  word-break: break-word;
}
.hl-toolbar-colors {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
}
.hl-toolbar-bottom .hl-swatch {
  width: 36px;
  height: 36px;
  border-color: rgba(0, 0, 0, .12);
  box-shadow: 0 1px 3px rgba(0, 0, 0, .12);
}
body.hl-toolbar-open,
body.hl-mark-panel-open {
  overflow: hidden;
}

/* 点击标记：删除 / 评论 */
.hl-mark-panel {
  position: absolute;
  z-index: 1100;
  min-width: 260px;
  max-width: min(360px, calc(100vw - 24px));
}
.hl-mark-panel-bottom {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  top: auto;
  transform: none;
  min-width: 0;
  max-width: none;
}
.hl-mark-sheet {
  background: var(--glass-bg-strong);
  color: var(--fg);
  border: 1px solid var(--glass-border);
  border-radius: 10px;
  padding: 12px 14px;
  box-shadow: var(--glass-highlight), var(--glass-shadow-lg);
}
.hl-mark-panel-bottom .hl-mark-sheet {
  border-radius: 14px 14px 0 0;
  border-bottom: none;
  box-shadow: 0 -8px 32px rgba(0, 0, 0, .12);
  padding-bottom: calc(12px + env(safe-area-inset-bottom, 0px));
}
.hl-mark-preview {
  margin-bottom: 8px;
}
.hl-mark-comment-show {
  margin-bottom: 10px;
  padding: 8px 10px;
  background: #fffbeb;
  border: 1px solid #fde68a;
  border-radius: 8px;
}
.hl-mark-comment-show p {
  margin: 4px 0 0;
  font-size: 13px;
  line-height: 1.5;
  color: var(--fg);
  word-break: break-word;
}
.hl-mark-comment-label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: var(--fg-muted);
  margin-bottom: 6px;
}
.hl-mark-comment-edit {
  margin-bottom: 10px;
}
.hl-mark-input {
  width: 100%;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  font-size: 13px;
  font-family: var(--font-ui);
  line-height: 1.45;
  resize: vertical;
  min-height: 72px;
  outline: none;
}
.hl-mark-input:focus {
  border-color: var(--accent);
}
.hl-mark-counter {
  display: block;
  margin-top: 4px;
  font-size: 11px;
  color: var(--fg-muted);
  font-family: var(--font-mono);
  text-align: right;
}
.hl-mark-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}
.hl-mark-btn {
  padding: 7px 14px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--fg);
  touch-action: manipulation;
}
.hl-mark-btn-danger {
  color: #b91c1c;
  border-color: #fecaca;
  background: #fef2f2;
}
.hl-mark-btn-primary {
  color: var(--accent);
  border-color: #fecaca;
  background: var(--accent-light);
}
.hl-mark-btn-save {
  color: #fff;
  border-color: var(--accent);
  background: var(--accent);
}
.hl-btn {
  border: none;
  background: transparent;
  color: #fff;
  padding: 4px 12px;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  border-radius: 4px;
}
.hl-btn:hover { background: rgba(255, 255, 255, .15); }
.hl-swatch {
  width: 20px; height: 20px; padding: 0;
  border: 2px solid rgba(255, 255, 255, .65);
  border-radius: 50%;
  cursor: pointer;
  touch-action: manipulation;
  transition: transform .12s;
}
.hl-swatch:hover { transform: scale(1.18); border-color: #fff; }

/* 桌面浮动工具条在触屏上仍略放大色块 */
@media (hover: none) and (pointer: coarse) {
  .hl-toolbar:not(.hl-toolbar-bottom) { padding: 8px 10px; gap: 9px; }
  .hl-toolbar:not(.hl-toolbar-bottom) .hl-swatch { width: 28px; height: 28px; }
}

/* ── My Highlights page ── */
.highlights-date-group {
  margin-bottom: 24px;
}
.highlights-date-title {
  font-size: 18px;
  font-weight: 700;
  font-family: var(--font-mono);
  margin-bottom: 10px;
}
.highlights-date-title a { color: var(--fg); }
.highlight-item {
  background: var(--glass-bg-strong);
  border: 1px solid var(--glass-border-outer);
  border-radius: var(--radius);
  padding: 12px 16px;
  margin-bottom: 8px;
  box-shadow: var(--glass-highlight), var(--glass-shadow);
}
.highlight-item-meta {
  font-size: 12px;
  color: var(--fg-muted);
  margin-bottom: 6px;
}
.highlight-item-meta a { color: var(--accent); }
.highlight-item-text {
  font-size: 14px;
  line-height: 1.7;
  margin-bottom: 6px;
}
.highlight-item-note {
  font-size: 13px;
  line-height: 1.5;
  color: var(--fg-muted);
  margin: 4px 0 8px;
  padding: 6px 10px;
  background: #f8fafc;
  border-radius: 6px;
  border: 1px solid var(--border);
}
.highlight-item-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}
.highlight-item-time {
  font-size: 11px;
  color: var(--fg-muted);
  font-family: var(--font-mono);
}

/* ── 我的收藏 文件夹筛选 ── */
.fav-filter {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin-bottom: 20px;
}
.fav-tab {
  padding: 6px 14px; border-radius: 999px; cursor: pointer;
  border: 1px solid var(--border); background: var(--card);
  font-size: 13px; font-weight: 500; color: var(--fg);
  font-family: var(--font-ui); transition: all .15s;
}
.fav-tab:hover { background: #f3f3f0; }
.fav-tab.active { background: var(--accent); color: #fff; border-color: var(--accent); }

.fav-detail { margin: 8px 0 4px; }
.fav-detail > summary {
  cursor: pointer; font-size: 13px; color: var(--accent); font-weight: 500;
  list-style: none; user-select: none;
}
.fav-detail > summary::before { content: "▸ "; }
.fav-detail[open] > summary::before { content: "▾ "; }
.fav-detail-body { margin-top: 10px; }
.fav-detail-body .paper-meta-line { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 8px; }

/* ── 浮动操作按钮 (FAB) ── */
.fab-stack {
  position: fixed;
  right: 24px; bottom: 28px;
  z-index: 60;
  display: flex; flex-direction: column; gap: 10px;
}
.fab {
  width: 44px; height: 44px;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--glass-border-outer);
  background: var(--glass-bg-strong); color: var(--fg-muted);
  border-radius: 50%;
  cursor: pointer;
  box-shadow: var(--glass-highlight), 0 4px 16px rgba(0, 0, 0, 0.1);
  transition: transform .15s, color .15s, background .15s, box-shadow .15s;
}
.fab:hover {
  color: #fff; background: var(--accent);
  border-color: var(--accent);
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(209, 77, 65, .3);
}
.fab svg { display: block; }

/* ── 目录抽屉 ── */
.toc-backdrop {
  position: fixed; inset: 0;
  background: rgba(0, 0, 0, .28);
  opacity: 0; pointer-events: none;
  transition: opacity .2s;
  z-index: 70;
}
.toc-backdrop.open { opacity: 1; pointer-events: auto; }
.toc-drawer {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: 360px; max-width: 86vw;
  background: var(--glass-bg-strong);
  border-left: 1px solid var(--glass-border-outer);
  box-shadow: -8px 0 40px rgba(0, 0, 0, 0.1);
  z-index: 80;
  display: flex; flex-direction: column;
  transform: translateX(100%);
  transition: transform .25s ease;
}
.toc-drawer.open { transform: translateX(0); }
.toc-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--border);
}
.toc-head-title { font-weight: 700; font-size: 16px; }
.toc-close {
  border: none; background: transparent; cursor: pointer;
  font-size: 24px; line-height: 1; color: var(--fg-muted);
}
.toc-close:hover { color: var(--accent); }
.toc-list {
  list-style: none; margin: 0; padding: 8px 0;
  overflow-y: auto; flex: 1;
}
.toc-item {
  display: flex; align-items: baseline; gap: 8px;
  width: 100%; text-align: left;
  padding: 9px 20px;
  border: none; background: transparent; cursor: pointer;
  font-family: var(--font-ui); font-size: 13px; color: var(--fg);
  transition: background .12s;
}
.toc-item:hover { background: var(--accent-light); }
.toc-num {
  flex: none;
  min-width: 22px; height: 22px; padding: 0 5px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--accent); color: #fff;
  border-radius: 11px; font-size: 11px; font-weight: 700;
  font-family: var(--font-mono);
}
.toc-origin {
  flex: none; font-size: 11px; color: var(--fg-muted);
  font-family: var(--font-mono);
}
.toc-title {
  flex: 1; min-width: 0;
  line-height: 1.4;
  display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ── Mobile adjustments ── */
@media (max-width: 720px) {
  .site-header-inner { gap: 12px; padding: 10px 16px; }
  .fab-stack { right: 14px; bottom: 16px; gap: 8px; }
  .fab { width: 40px; height: 40px; }
  .visit-pill { margin-left: 0; order: 2; }
  .github-link { margin-left: 0; order: 2; }
  .site-search { flex: 1 1 100%; order: 3; }
  .auth-area { order: 4; margin-left: 0; }
  .site-main { padding: 16px; }
  .search-form-row { grid-template-columns: 1fr; }
  .rss-form { grid-template-columns: 1fr; }
  .report-frame { height: calc(100vh - 320px); }
  .hour-chart { gap: 2px; height: 160px; }
  .day-chart { gap: 2px; height: 160px; }
  .stats-hero-num { font-size: 28px; }
  .stats-hero-card { padding: 16px 14px; }
  .interaction-bar { flex-wrap: wrap; }
  .comment-form { flex-wrap: wrap; }
  .comment-input { flex: 1 1 100%; }
  .modal-card { padding: 20px; }
}

/* backdrop-filter：写在文件末尾，确保压过实心背景；不支持时浏览器自动忽略 */
.site-header,
.site-footer,
.date-toolbar,
.list-controls,
.lab-feed,
.page-header,
.search-form,
.stats-section,
.report-frame-wrap,
.paper-card,
.history-card,
.highlight-item,
.rss-card,
.stats-hero-card,
.stats-section,
.stats-table-wrap,
.plugin-hero,
.plugin-steps,
.plugin-config,
.plugin-menu,
.plugin-faq,
.comments-area,
.site-search,
.auth-user,
.fab,
.modal-card,
.toc-drawer,
.fav-menu,
.hl-toolbar-sheet,
.hl-mark-sheet {
  -webkit-backdrop-filter: var(--glass-blur-light);
  backdrop-filter: var(--glass-blur-light);
}
.modal-card,
.toc-drawer,
.fav-menu,
.hl-toolbar-sheet,
.hl-mark-sheet {
  -webkit-backdrop-filter: var(--glass-blur);
  backdrop-filter: var(--glass-blur);
}

/* ── 筛选模块：领域标签、创新方法、评分、黑名单 ── */

.domain-tag-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 8px;
}
.domain-tag {
  display: inline-block;
  font-size: 11px;
  padding: 2px 10px;
  border-radius: 999px;
  color: #6d28d9;
  border: 1px solid #ddd6fe;
  background: #f5f3ff;
  font-weight: 500;
}
.innovation-row {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  margin-bottom: 8px;
  font-size: 13px;
  line-height: 1.6;
}
.innovation-label {
  flex-shrink: 0;
  font-weight: 600;
  color: var(--fg-muted);
  white-space: nowrap;
}
.innovation-text {
  color: var(--fg);
}

/* 评分 badge */
.badge-score {
  font-weight: 600;
  font-family: var(--font-mono);
}
.badge-score.score-high {
  background: #fef3c7;
  color: #b45309;
  border: 1px solid #fcd34d;
}
.badge-score.score-mid {
  background: #f0f9ff;
  color: #0369a1;
  border: 1px solid #bae6fd;
}
.badge-score.score-low {
  background: #f3f4f6;
  color: #6b7280;
  border: 1px solid #e5e7eb;
}

/* 黑名单 badge */
.badge-blacklist {
  background: #fef2f2;
  color: #dc2626;
  border: 1px solid #fca5a5;
}

/* 黑名单论文样式（折叠到底部） */
.paper-blacklisted {
  opacity: 0.6;
}
.paper-blacklisted .paper-card-header h2 a {
  text-decoration: line-through;
  text-decoration-color: var(--fg-muted);
  text-decoration-thickness: 1px;
}

/* 领域筛选栏 */
.domain-filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 16px;
  padding: 8px 12px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border-outer);
  border-radius: var(--radius);
}
.df-btn {
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: 500;
  padding: 4px 10px;
  border-radius: 999px;
  cursor: pointer;
  background: transparent;
  color: var(--fg-muted);
  border: 1px solid var(--border);
  transition: all 0.15s;
  white-space: nowrap;
}
.df-btn:hover {
  background: #f3f3f0;
  color: var(--fg);
}
.df-btn.active {
  background: #6d28d9;
  color: #fff;
  border-color: #6d28d9;
}

/* 离线 HTML 报告中的筛选信息块 */
.filter-section {
  margin-top: 16px;
  padding: 12px 16px;
  background: #f9f9f7;
  border: 1px solid var(--border);
  border-radius: 8px;
}
.filter-row {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  margin-bottom: 8px;
  font-size: 13px;
  line-height: 1.6;
}
.filter-row:last-child {
  margin-bottom: 0;
}
.filter-label {
  flex-shrink: 0;
  font-weight: 600;
  color: var(--fg-muted);
  white-space: nowrap;
}
.filter-tag {
  display: inline-block;
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 999px;
  color: #6d28d9;
  border: 1px solid #ddd6fe;
  background: #f5f3ff;
}
.filter-innovation {
  color: var(--fg);
}
.filter-score {
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 15px;
}
.filter-score.score-high {
  color: #b45309;
}
.filter-score.score-mid {
  color: #0369a1;
}
.filter-score.score-low {
  color: #6b7280;
}

/* ── 状态横幅 ── */
.status-banner {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 18px;
  margin-bottom: 16px;
  border-radius: var(--radius);
  font-size: 14px;
  font-weight: 500;
  border: 1px solid transparent;
  animation: sb-fade-in 0.3s ease;
}
.sb-content {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1;
}
.sb-icon {
  font-size: 16px;
  flex-shrink: 0;
}
.sb-text {
  line-height: 1.5;
}
.sb-progress {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--fg-muted);
  margin-top: 4px;
  white-space: pre;
}
/* spinner */
.sb-spinner {
  display: inline-block;
  width: 16px;
  height: 16px;
  border: 2px solid currentColor;
  border-top-color: transparent;
  border-radius: 50%;
  animation: sb-spin 0.7s linear infinite;
  flex-shrink: 0;
}
@keyframes sb-spin { to { transform: rotate(360deg); } }
@keyframes sb-fade-in { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: translateY(0); } }

/* 各状态配色 */
.sb-fetching {
  background: #eff6ff;
  border-color: #93c5fd;
  color: #1d4ed8;
}
.sb-processing {
  background: #f5f3ff;
  border-color: #c4b5fd;
  color: #6d28d9;
}
.sb-complete {
  background: #f0fdf4;
  border-color: #86efac;
  color: #15803d;
}
.sb-partial {
  background: #fffbeb;
  border-color: #fcd34d;
  color: #b45309;
}
.sb-failed {
  background: #fef2f2;
  border-color: #fca5a5;
  color: #dc2626;
}
.sb-waiting {
  background: var(--glass-bg);
  border-color: var(--glass-border-outer);
  color: var(--fg-muted);
}

/* ── 额外论文（加餐）区域 ── */
.extra-papers-section {
  margin-top: 40px;
  padding-top: 20px;
  border-top: 2px dashed var(--border);
}
.extra-papers-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 20px;
}
.extra-papers-icon {
  font-size: 24px;
}
.extra-papers-title {
  font-size: 20px;
  font-weight: 700;
  color: var(--fg);
}
.extra-papers-count {
  font-size: 13px;
  color: var(--fg-muted);
  background: #fef3c7;
  border: 1px solid #fcd34d;
  padding: 2px 10px;
  border-radius: 999px;
}
.paper-index-extra {
  background: #fef3c7;
  color: #b45309;
  border: 1px solid #fcd34d;
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 4px;
  font-family: var(--font-ui);
}

/* ── 推荐等级 badge（🔥 必读 / 👀 值得看 / 💤 可跳过）── */
.badge-grade {
  display: inline-block;
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 4px;
  font-weight: 600;
  border: 1px solid transparent;
  font-family: var(--font-ui);
  white-space: nowrap;
}
.badge-grade.grade-must {
  background: #fef2f2;
  color: #b91c1c;
  border-color: #fca5a5;
}
.badge-grade.grade-worth {
  background: #eff6ff;
  color: #1d4ed8;
  border-color: #93c5fd;
}
.badge-grade.grade-skip {
  background: #f3f4f6;
  color: #6b7280;
  border-color: #e5e7eb;
}

/* 推荐等级卡片左侧色带（视觉强调，不破坏布局） */
.paper-card.grade-must {
  border-left: 3px solid #dc2626;
}
.paper-card.grade-worth {
  border-left: 3px solid #3b82f6;
}
.paper-card.grade-skip {
  border-left: 3px solid #d1d5db;
}

/* 目录里的等级标记 */
.toc-grade {
  flex: none;
  font-size: 14px;
  line-height: 1;
}

/* ── 推荐等级筛选栏 ── */
.grade-filter-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  margin-bottom: 16px;
  padding: 8px 12px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border-outer);
  border-radius: var(--radius);
}
.gf-label {
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: 600;
  color: var(--fg-muted);
  margin-right: 4px;
}
.gf-btn {
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: 500;
  padding: 4px 10px;
  border-radius: 999px;
  cursor: pointer;
  background: transparent;
  color: var(--fg-muted);
  border: 1px solid var(--border);
  transition: all 0.15s;
  white-space: nowrap;
}
.gf-btn:hover {
  background: #f3f3f0;
  color: var(--fg);
}
.gf-btn.active {
  color: #fff;
}
.gf-btn.active,
.gf-btn.gf-must.active {
  background: #dc2626;
  border-color: #dc2626;
}
.gf-btn.gf-worth.active {
  background: #2563eb;
  border-color: #2563eb;
}
.gf-btn.gf-skip.active {
  background: #6b7280;
  border-color: #6b7280;
}

/* ════════════════════════════════════════════════════════════════
   深色模式 (Dark Mode)
   策略：覆盖 :root 语义变量 + 玻璃层 + 背景渐变。
   - [data-theme="dark"]：用户显式选择深色
   - @media (prefers-color-scheme: dark) 且未显式设 light：跟随系统
   ════════════════════════════════════════════════════════════════ */

/* 深色 token 定义：显式选择时生效 */
:root[data-theme="dark"] {
  --bg: #15161a;
  --fg: #e7e7ea;
  --fg-muted: #9aa0ac;
  --accent: #f06a5e;
  --accent-light: #3a1d1b;
  --cross: #a78bfa;
  --cross-bg: #2a1f45;
  --border: #2c2e36;
  --card: #1c1e24;
  --card-shadow: 0 1px 3px rgba(0, 0, 0, .35), 0 1px 2px rgba(0, 0, 0, .25);
  /* 液态玻璃 — 深色版：半透明深底 + 微亮描边 */
  --glass-bg: rgba(34, 36, 44, 0.55);
  --glass-bg-strong: rgba(36, 38, 46, 0.72);
  --glass-bg-subtle: rgba(40, 42, 50, 0.38);
  --glass-border: rgba(255, 255, 255, 0.10);
  --glass-border-outer: rgba(255, 255, 255, 0.08);
  --glass-rim: rgba(0, 0, 0, 0.30);
  --glass-highlight: inset 0 1px 0 rgba(255, 255, 255, 0.06), inset 0 -1px 0 rgba(0, 0, 0, 0.20);
  --glass-shadow: 0 4px 6px rgba(0, 0, 0, 0.30), 0 16px 40px rgba(0, 0, 0, 0.45);
  --glass-shadow-lg: 0 8px 16px rgba(0, 0, 0, 0.35), 0 24px 56px rgba(0, 0, 0, 0.55);
  color-scheme: dark;
}

/* 显式深色下的背景渐变层（降饱和、提暗） */
:root[data-theme="dark"] body::before {
  background:
    radial-gradient(circle 520px at 12% 18%, rgba(209, 77, 65, 0.18), transparent 68%),
    radial-gradient(circle 480px at 88% 12%, rgba(124, 58, 237, 0.16), transparent 65%),
    radial-gradient(circle 560px at 78% 88%, rgba(46, 168, 229, 0.14), transparent 68%),
    radial-gradient(circle 420px at 22% 82%, rgba(245, 158, 11, 0.10), transparent 62%),
    linear-gradient(155deg, #1a1c22 0%, #14161c 45%, #1c1822 100%);
}
:root[data-theme="dark"] html { background: #0f1014; }
:root[data-theme="dark"] body::after { opacity: 0.25; }

/* 显式深色下的输入框、代码块等硬编码白色表面 */
:root[data-theme="dark"] input,
:root[data-theme="dark"] textarea,
:root[data-theme="dark"] select {
  background: #232530;
  color: var(--fg);
  border-color: var(--border);
}
:root[data-theme="dark"] input::placeholder,
:root[data-theme="dark"] textarea::placeholder { color: #6b7280; }

/* ── 跟随系统：未显式设 [data-theme] 时，按 prefers-color-scheme ──
   复制上面的深色规则，套在 media query 内且排除显式 light。 */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) {
    --bg: #15161a;
    --fg: #e7e7ea;
    --fg-muted: #9aa0ac;
    --accent: #f06a5e;
    --accent-light: #3a1d1b;
    --cross: #a78bfa;
    --cross-bg: #2a1f45;
    --border: #2c2e36;
    --card: #1c1e24;
    --card-shadow: 0 1px 3px rgba(0, 0, 0, .35), 0 1px 2px rgba(0, 0, 0, .25);
    --glass-bg: rgba(34, 36, 44, 0.55);
    --glass-bg-strong: rgba(36, 38, 46, 0.72);
    --glass-bg-subtle: rgba(40, 42, 50, 0.38);
    --glass-border: rgba(255, 255, 255, 0.10);
    --glass-border-outer: rgba(255, 255, 255, 0.08);
    --glass-rim: rgba(0, 0, 0, 0.30);
    --glass-highlight: inset 0 1px 0 rgba(255, 255, 255, 0.06), inset 0 -1px 0 rgba(0, 0, 0, 0.20);
    --glass-shadow: 0 4px 6px rgba(0, 0, 0, 0.30), 0 16px 40px rgba(0, 0, 0, 0.45);
    --glass-shadow-lg: 0 8px 16px rgba(0, 0, 0, 0.35), 0 24px 56px rgba(0, 0, 0, 0.55);
    color-scheme: dark;
  }
  :root:not([data-theme="light"]) body::before {
    background:
      radial-gradient(circle 520px at 12% 18%, rgba(209, 77, 65, 0.18), transparent 68%),
      radial-gradient(circle 480px at 88% 12%, rgba(124, 58, 237, 0.16), transparent 65%),
      radial-gradient(circle 560px at 78% 88%, rgba(46, 168, 229, 0.14), transparent 68%),
      radial-gradient(circle 420px at 22% 82%, rgba(245, 158, 11, 0.10), transparent 62%),
      linear-gradient(155deg, #1a1c22 0%, #14161c 45%, #1c1822 100%);
  }
  :root:not([data-theme="light"]) html { background: #0f1014; }
  :root:not([data-theme="light"]) body::after { opacity: 0.25; }
  :root:not([data-theme="light"]) input,
  :root:not([data-theme="light"]) textarea,
  :root:not([data-theme="light"]) select {
    background: #232530;
    color: var(--fg);
    border-color: var(--border);
  }
  :root:not([data-theme="light"]) input::placeholder,
  :root:not([data-theme="light"]) textarea::placeholder { color: #6b7280; }
}

/* 深色下的浅色卡片/代码/高亮区域通用收口（对两种触发方式都生效） */

/* ── 摘要 / 深度解读正文区（@supports 玻璃增强层里有硬编码白底，需覆盖）── */
:root[data-theme="dark"] .analysis-content {
  background: #1c1e24;
  color: #d8d8dc;
}
:root[data-theme="dark"] .analysis-content strong { color: #f0f0f2; }
:root[data-theme="dark"] .analysis-content em { color: #b8bec8; }
:root[data-theme="dark"] .analysis-section summary,
:root[data-theme="dark"] .abstract summary { background: #26282f; color: var(--fg-muted); }
:root[data-theme="dark"] .analysis-section,
:root[data-theme="dark"] .abstract { background: rgba(40, 42, 50, 0.55); border-color: var(--glass-border-outer); }
:root[data-theme="dark"] .abstract p { color: var(--fg-muted); }
:root[data-theme="dark"] .analysis-content thead th { background: linear-gradient(180deg, #2a2c34, #22242b); }
:root[data-theme="dark"] .analysis-content tbody tr:nth-child(even) { background: #21232a; }
:root[data-theme="dark"] .analysis-content code { background: #2c2e36; color: #f0a3a0; }

@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .analysis-content {
    background: #1c1e24;
    color: #d8d8dc;
  }
  :root:not([data-theme="light"]) .analysis-content strong { color: #f0f0f2; }
  :root:not([data-theme="light"]) .analysis-content em { color: #b8bec8; }
  :root:not([data-theme="light"]) .analysis-section summary,
  :root:not([data-theme="light"]) .abstract summary { background: #26282f; color: var(--fg-muted); }
  :root:not([data-theme="light"]) .analysis-section,
  :root:not([data-theme="light"]) .abstract { background: rgba(40, 42, 50, 0.55); border-color: var(--glass-border-outer); }
  :root:not([data-theme="light"]) .abstract p { color: var(--fg-muted); }
  :root:not([data-theme="light"]) .analysis-content thead th { background: linear-gradient(180deg, #2a2c34, #22242b); }
  :root:not([data-theme="light"]) .analysis-content tbody tr:nth-child(even) { background: #21232a; }
  :root:not([data-theme="light"]) .analysis-content code { background: #2c2e36; color: #f0a3a0; }
}

:root[data-theme="dark"] code,
:root[data-theme="dark"] pre {
  background: #232530;
}
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) code,
  :root:not([data-theme="light"]) pre {
    background: #232530;
  }
}

/* ── 主题切换按钮 ── */
.theme-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border: 1px solid var(--glass-border-outer);
  border-radius: 8px;
  background: var(--glass-bg-subtle);
  cursor: pointer;
  font-size: 17px;
  line-height: 1;
  color: var(--fg);
  transition: background .15s, transform .1s;
  flex-shrink: 0;
}
.theme-toggle:hover { background: var(--glass-bg-strong); }
.theme-toggle:active { transform: scale(0.92); }
.theme-toggle .theme-icon-sun { display: none; }
.theme-toggle .theme-icon-moon { display: inline; }
/* 当前是深色时，显示太阳图标（点击切回浅色） */
:root[data-theme="dark"] .theme-toggle .theme-icon-sun { display: inline; }
:root[data-theme="dark"] .theme-toggle .theme-icon-moon { display: none; }
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .theme-toggle .theme-icon-sun { display: inline; }
  :root:not([data-theme="light"]) .theme-toggle .theme-icon-moon { display: none; }
}

