/* 星弧引力 · 主样式表 · Day 8 统一打磨 */

/* ── CSS变量：纸墨主题（默认）──────────────────── */
:root, [data-theme="warm"] {
  --bg: #ede8db;
  --bg2: #f5f0e6;
  --bg-dot: rgba(24,18,10,.03);
  --card: rgba(255,255,255,.55);
  --card-solid: #fff;
  --card-hover: rgba(201,150,58,.08);
  --card-shadow: 0 2px 16px rgba(24,18,10,.06);
  --ink: #18120a;
  --ink2: #5c5347;
  --ink-secondary: #5c5347;
  --muted: #6b6050;
  --gold: #c9963a;
  --gold-light: #d4ab5e;
  --accent: #c9963a;
  --accent-light: #d4ab5e;
  --green: #5a8a6a;
  --red: #b05050;
  --line: rgba(24,18,10,.08);
  --line-hover: rgba(201,150,58,.3);
  --input-bg: rgba(255,255,255,.7);
  --nav-bg: rgba(24,18,10,.92);
  --nav-text: rgba(237,232,219,.5);
  --nav-text-hover: rgba(237,232,219,.85);
  --toast-success: #5a8a6a;
  --toast-error: #b05050;
  --toast-info: #c9963a;
  --font-serif: 'Playfair Display', 'Noto Serif SC', serif;
  --font-body: 'Noto Serif SC', serif;
  --font-cn: 'Noto Serif SC', serif;
  --font-en: 'Playfair Display', serif;
  --font-num: 'Playfair Display', serif;
  --radius: 10px;
  --radius-card: 12px;
  --radius-btn: 8px;
  --radius-input: 8px;
  --radius-note: 2px;
}

/* ── CSS变量：清冷主题 ────────────────────────── */
[data-theme="cool"] {
  --bg: #eef1f5;
  --bg2: #f4f6f9;
  --bg-dot: rgba(26,30,46,.03);
  --card: rgba(255,255,255,.55);
  --card-solid: #fff;
  --card-hover: rgba(107,138,170,.08);
  --card-shadow: 0 2px 16px rgba(26,30,46,.05);
  --ink: #1a1e2e;
  --ink2: #5a6474;
  --ink-secondary: #5a6474;
  --muted: #5a6474;
  --gold: #6b8aaa;
  --gold-light: #8aa4be;
  --accent: #6b8aaa;
  --accent-light: #8aa4be;
  --green: #5a8a7a;
  --red: #9a5060;
  --line: rgba(26,30,46,.08);
  --line-hover: rgba(107,138,170,.3);
  --input-bg: rgba(255,255,255,.7);
  --nav-bg: rgba(22,26,36,.92);
  --nav-text: rgba(220,228,238,.5);
  --nav-text-hover: rgba(220,228,238,.85);
}

/* ── 基础 ─────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

body {
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--ink);
  line-height: 1.7;
  font-size: 16px;
  min-height: 100vh;
  transition: background .5s, color .5s;
}

body::before {
  content: '';
  position: fixed; top:0; left:0; right:0; bottom:0;
  background-image: radial-gradient(circle, var(--bg-dot) 1px, transparent 1px);
  background-size: 28px 28px;
  pointer-events: none;
  z-index: 0;
}

a { color: var(--accent); text-decoration: none; }
a:hover { color: var(--accent-light); }

/* ── 全局导航 ─────────────────────────────────── */
.gn {
  position: fixed; top:0; left:0; right:0; z-index: 999;
  height: 48px; display:flex; align-items:center; justify-content:space-between;
  padding: 0 24px;
  background: var(--nav-bg);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.gn-left, .gn-right { display:flex; align-items:center; gap:16px; }
.gn-logo { font-size:16px; font-weight:700; color:#ede8db; letter-spacing:.03em; }
.gn-logo em { font-family:'Playfair Display',serif; font-style:italic; color:var(--accent); }
.gn-links { display:flex; gap:4px; }
.gn-link {
  padding:6px 14px; font-size:12.5px; color:var(--nav-text);
  border-radius:6px; transition:all .2s;
}
.gn-link:hover { color:var(--nav-text-hover); background:rgba(255,255,255,.06); }
.gn-link.active { color:var(--accent); background:rgba(201,150,58,.1); }
.gn-spacer { height:48px; }

/* 主题切换 */
.gn-theme { display:flex; background:rgba(255,255,255,.06); border-radius:5px; overflow:hidden; }
.gn-theme-btn {
  padding:5px 10px; font-size:10px; background:none; border:none; cursor:pointer;
  color:rgba(237,232,219,.4); font-family:var(--font-body); transition:all .2s;
  display:flex; align-items:center; gap:3px;
}
.gn-theme-btn.active { background:rgba(255,255,255,.12); color:rgba(237,232,219,.85); }

/* 搜索 */
.gn-search-link{display:flex;align-items:center;color:var(--nav-text);transition:color .2s}
.gn-search-link:hover{color:var(--accent)}

/* 写作按钮 */
.gn-write {
  padding:6px 16px; font-size:12px; background:var(--accent); color:#18120a;
  border:none; border-radius:6px; cursor:pointer; font-family:var(--font-body);
  font-weight:600; transition:all .2s; text-decoration:none;
}
.gn-write:hover { background:var(--accent-light); color:#18120a; }

/* 登录按钮 */
.gn-login {
  padding:6px 16px; font-size:12px; color:rgba(237,232,219,.7);
  border:1.5px solid rgba(237,232,219,.2); border-radius:6px; transition:all .2s;
}
.gn-login:hover { color:#ede8db; border-color:rgba(237,232,219,.4); }

/* 用户头像 */
.gn-user { position:relative; }
.gn-avatar {
  width:30px; height:30px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:12px; color:#fff; font-weight:700; cursor:pointer;
  border:2px solid transparent; transition:border-color .2s;
}
.gn-avatar:hover { border-color:rgba(201,150,58,.5); }

/* 下拉菜单 */
.gn-dropdown {
  display:none; position:absolute; top:40px; right:0; width:200px;
  background:#1e1a14; border:1px solid rgba(255,255,255,.08);
  border-radius:10px; padding:8px 0; box-shadow:0 8px 32px rgba(0,0,0,.3);
}
.gn-dropdown.show { display:block; animation:gnFade .2s ease-out; }
@keyframes gnFade { from{opacity:0;transform:translateY(-6px)} to{opacity:1;transform:translateY(0)} }
.gn-dd-label { padding:6px 16px; font-size:10px; color:rgba(255,255,255,.25); letter-spacing:.08em; }
.gn-dd-item {
  display:flex; align-items:center; gap:8px; padding:8px 16px;
  font-size:12.5px; color:rgba(237,232,219,.6); transition:all .15s;
}
.gn-dd-item:hover { background:rgba(255,255,255,.05); color:#ede8db; }
.gn-dd-gold { color:var(--accent) !important; }
.gn-dd-divider { height:1px; background:rgba(255,255,255,.06); margin:6px 0; }

/* 通知红点 */
.gn-notif-dot {
  position:absolute; top:8px; right:60px;
  min-width:16px; height:16px; padding:0 4px;
  background:var(--red); color:#fff; font-size:10px; font-weight:700;
  border-radius:8px; display:flex; align-items:center; justify-content:center;
}

/* ── 登录/注册页 ──────────────────────────────── */
.auth-page {
  display:flex; min-height:100vh; position:relative; z-index:1;
}
.auth-left {
  flex:1; display:flex; align-items:center; justify-content:center;
  padding:40px;
}
.auth-brand { text-align:center; }
.auth-logo { font-size:28px; font-weight:700; color:var(--ink); }
.auth-logo em { font-family:'Playfair Display',serif; font-style:italic; color:var(--accent); }
.auth-slogan { font-size:18px; color:var(--muted); margin-top:16px; font-family:var(--font-serif); }
.auth-sub { font-size:13px; color:var(--muted); margin-top:8px; opacity:.7; }

.auth-right {
  flex:1; display:flex; align-items:center; justify-content:center;
  padding:40px;
}
.auth-card {
  width:100%; max-width:400px;
  background:var(--card); border:1px solid var(--line);
  border-radius:var(--radius-card); padding:32px;
}
.auth-card-title { font-size:18px; font-weight:700; margin-bottom:24px; }

/* 登录/注册Tab */
.auth-tabs { display:flex; gap:4px; margin-bottom:28px; border-bottom:1px solid var(--line); }
.auth-tab {
  padding:10px 20px; font-size:14px; color:var(--muted); cursor:pointer;
  border-bottom:2px solid transparent; transition:all .2s;
}
.auth-tab.active { color:var(--ink); border-bottom-color:var(--accent); }

/* ── 表单 ─────────────────────────────────────── */
.form-group { margin-bottom:20px; }
.form-group label { display:block; font-size:13px; color:var(--muted); margin-bottom:6px; }
.form-group input[type="text"],
.form-group input[type="email"],
.form-group input[type="password"] {
  width:100%; padding:10px 14px; font-size:14px;
  background:var(--input-bg); border:1px solid var(--line);
  border-radius:var(--radius-input); color:var(--ink);
  font-family:var(--font-body); transition:border-color .2s;
}
.form-group input:focus {
  outline:none; border-color:var(--accent);
}
.field-hint { font-size:11px; color:var(--muted); margin-top:4px; opacity:.7; }

/* 输入框+按钮组合 */
.input-with-btn { display:flex; gap:8px; }
.input-with-btn input { flex:1; }
.btn-code {
  padding:10px 14px; font-size:12px; white-space:nowrap;
  background:transparent; border:1.5px solid var(--accent);
  color:var(--accent); border-radius:var(--radius-btn); cursor:pointer;
  font-family:var(--font-body); transition:all .2s;
}
.btn-code:hover { background:var(--accent); color:#fff; }
.btn-code:disabled { opacity:.5; cursor:not-allowed; }

/* 密码强度条 */
.pwd-strength { height:3px; background:var(--line); border-radius:2px; margin-top:6px; }
.pwd-bar { height:100%; width:0; border-radius:2px; transition:width .3s, background .3s; }

/* 复选框 */
.checkbox-label { display:flex; align-items:flex-start; gap:8px; cursor:pointer; font-size:13px; }
.checkbox-label input[type="checkbox"] { margin-top:3px; }
.checkbox-label a { color:var(--accent); }

/* ── 通用按钮 ─────────────────────────────────── */
.btn {
  padding:8px 20px; border-radius:var(--radius-btn); border:none; cursor:pointer;
  font-family:var(--font-body); font-size:13px; font-weight:600; transition:all .2s;
  text-decoration:none; display:inline-flex; align-items:center; gap:6px;
}
.btn-primary {
  padding:12px 24px; font-size:14px;
  background:var(--ink); color:var(--bg);
  border:none; border-radius:var(--radius-btn); cursor:pointer;
  font-family:var(--font-body); font-weight:600; transition:all .2s;
}
.btn-primary:hover { opacity:.85; }
.btn-full { width:100%; justify-content:center; }
.btn-gold { background:var(--gold); color:#fff; }
.btn-gold:hover { background:var(--gold-light); }
.btn-ghost { background:transparent; color:var(--ink2); border:1px solid var(--line); }
.btn-ghost:hover { background:var(--bg2); color:var(--ink); }
.btn-sm { padding:6px 14px; border-radius:6px; font-size:12px; }
.btn-danger { color:#dc2626; border-color:#fecaca; }
.btn-danger:hover { background:#fee2e2; }

.auth-links { text-align:center; margin-top:16px; font-size:13px; color:var(--muted); }
.auth-links a { color:var(--accent); }

/* ── 通用容器 ─────────────────────────────────── */
.container { max-width:960px; margin:0 auto; padding:40px 24px; }
.container-sm { max-width:720px; margin:0 auto; padding:40px 24px; }
.container-xs { max-width:560px; margin:0 auto; padding:40px 24px; }

/* ── 页头 ─────────────────────────────────────── */
.page-head {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:32px;
}
.page-head h1 { font-size:26px; font-weight:700; }

/* ── 面包屑 ───────────────────────────────────── */
.breadcrumb {
  font-size:13px; color:var(--ink2); margin-bottom:24px;
}
.breadcrumb a { color:var(--gold); text-decoration:none; }
.breadcrumb a:hover { text-decoration:underline; }

/* ── 通用Tabs ─────────────────────────────────── */
.tabs {
  display:flex; gap:4px; margin-bottom:28px;
  border-bottom:1px solid var(--line); padding-bottom:0;
}
.tabs a {
  padding:10px 18px; font-size:13px; color:var(--ink2);
  text-decoration:none; border-bottom:2px solid transparent;
  transition:all .2s; font-weight:600;
}
.tabs a:hover { color:var(--ink); }
.tabs a.active { color:var(--gold); border-bottom-color:var(--gold); }

/* ── 分类筛选 ─────────────────────────────────── */
.filters { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:12px; }
.filters a {
  padding:6px 16px; border-radius:20px; font-size:13px;
  text-decoration:none; color:var(--ink2); background:var(--card-solid);
  border:1px solid var(--line); transition:all .2s; font-weight:600;
}
.filters a:hover { color:var(--ink); border-color:var(--gold); }
.filters a.active { background:var(--gold); color:#fff; border-color:var(--gold); }

/* ── 排序栏 ───────────────────────────────────── */
.sort-bar { display:flex; gap:16px; margin-bottom:28px; font-size:13px; }
.sort-bar a { color:var(--ink2); text-decoration:none; }
.sort-bar a:hover { color:var(--ink); }
.sort-bar a.active { color:var(--gold); font-weight:700; }

/* ── 故事卡片：网格模式 ───────────────────────── */
.story-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
.story-card-grid {
  background:var(--card-solid); border-radius:var(--radius); padding:24px;
  box-shadow:var(--card-shadow); transition:transform .15s,box-shadow .15s;
  display:flex; flex-direction:column; text-decoration:none; color:var(--ink);
}
.story-card-grid:hover { transform:translateY(-3px); box-shadow:0 6px 28px rgba(24,18,10,.1); }
.story-card-grid h3 { font-size:17px; line-height:1.4; margin-bottom:8px; }
.story-card-grid h3 a { color:var(--ink); text-decoration:none; }
.story-card-grid h3 a:hover { color:var(--gold); }
.story-card-grid .summary {
  font-size:14px; color:var(--ink2); line-height:1.7; flex:1;
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden;
  margin-bottom:12px;
}
.story-card-grid .meta { font-size:12px; color:var(--ink2); display:flex; flex-wrap:wrap; gap:12px; }
.category-tag {
  display:inline-block; padding:2px 8px; border-radius:12px;
  background:var(--bg2); font-size:11px; color:var(--ink2); font-weight:600;
}

/* ── 故事卡片：列表模式 ───────────────────────── */
.story-list { display:flex; flex-direction:column; gap:16px; }
.story-card-list {
  background:var(--card-solid); border-radius:var(--radius);
  padding:24px 28px; box-shadow:var(--card-shadow);
  transition:transform .15s, box-shadow .15s;
}
.story-card-list:hover { transform:translateY(-2px); box-shadow:0 4px 24px rgba(24,18,10,.1); }
.story-card-list .card-top {
  display:flex; align-items:start; justify-content:space-between; gap:16px;
}
.story-card-list h3 { font-size:18px; font-weight:700; line-height:1.4; flex:1; }
.story-card-list h3 a { color:var(--ink); text-decoration:none; }
.story-card-list h3 a:hover { color:var(--gold); }
.story-card-list .meta {
  margin-top:10px; font-size:12px; color:var(--ink2);
  display:flex; flex-wrap:wrap; gap:14px;
}
.story-card-list .summary {
  margin-top:10px; font-size:14px; color:var(--ink2); line-height:1.7;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.story-card-list .card-actions { margin-top:14px; display:flex; gap:10px; }
.card-actions a, .card-actions button {
  padding:6px 14px; border-radius:6px; font-size:12px;
  font-family:var(--font-body); cursor:pointer; text-decoration:none;
  border:1px solid var(--line); background:transparent; color:var(--ink2);
  transition:all .2s;
}
.card-actions a:hover, .card-actions button:hover { background:var(--bg2); color:var(--ink); }
.card-actions .del { color:#dc2626; border-color:#fecaca; }
.card-actions .del:hover { background:#fee2e2; }

/* ── 状态徽章 ─────────────────────────────────── */
.badge {
  display:inline-block; padding:3px 10px; border-radius:20px;
  font-size:11px; font-weight:700; white-space:nowrap;
}
.badge-draft { background:#f3f4f6; color:#6b7280; }
.badge-pending { background:#fef3c7; color:#92400e; }
.badge-published { background:#d1fae5; color:#065f46; }
.badge-rejected { background:#fee2e2; color:#991b1b; }
.badge-admin { background:#ede9fe; color:#6d28d9; }
.badge-author { background:#d1fae5; color:#065f46; }
.badge-user { background:#f3f4f6; color:#6b7280; }
.badge-reviewer{background:#fef3c7;color:#92400e}
.badge-banned { background:#fee2e2; color:#991b1b; }

/* ── 分页 ─────────────────────────────────────── */
.pagination { display:flex; justify-content:center; gap:8px; margin-top:40px; }
.pagination a, .pagination span {
  padding:8px 14px; border-radius:6px; font-size:13px; text-decoration:none;
}
.pagination a { color:var(--ink2); background:var(--card-solid); border:1px solid var(--line); }
.pagination a:hover { color:var(--ink); border-color:var(--gold); }
.pagination .current { background:var(--gold); color:#fff; border:none; }

/* ── 空状态 ───────────────────────────────────── */
.empty { text-align:center; padding:80px 20px; color:var(--ink2); }
.empty .icon { font-size:48px; margin-bottom:16px; opacity:.3; }
.empty p { font-size:15px; margin-bottom:20px; }
.empty a { color:var(--gold); text-decoration:none; font-weight:600; }

/* ── 文章排版 ─────────────────────────────────── */
.article { max-width:720px; margin:0 auto; padding:60px 24px 40px; }
.article-header { text-align:center; margin-bottom:48px; padding-bottom:32px; border-bottom:1px solid var(--line); }
.article-header h1 { font-size:34px; font-weight:700; line-height:1.4; margin-bottom:16px; }
.article-header .meta { font-size:13px; color:var(--ink2); display:flex; justify-content:center; flex-wrap:wrap; gap:16px; }
.article-header .meta a { color:var(--gold); text-decoration:none; }

.article-body { font-size:17px; line-height:2; color:var(--ink); letter-spacing:.02em; }
.article-body p { margin:1em 0; }
.article-body h2 { font-size:22px; margin:2em 0 1em; font-weight:700; }
.article-body h3 { font-size:19px; margin:1.5em 0 .8em; font-weight:700; }
.article-body blockquote { border-left:3px solid var(--gold); padding:8px 20px; margin:1.5em 0; color:var(--ink2); font-style:italic; background:var(--bg2); border-radius:0 8px 8px 0; }
.article-body img { max-width:100%; border-radius:8px; margin:1em 0; }
.article-body a { color:var(--gold); }
.article-body hr { border:none; border-top:1px solid var(--line); margin:2em 0; }

/* 作者寄语 */
.author-note { margin-top:48px; padding:24px; background:var(--bg2); border-radius:var(--radius); border-left:3px solid var(--gold); }
.author-note .label { font-size:12px; color:var(--gold); font-weight:700; text-transform:uppercase; letter-spacing:.1em; margin-bottom:8px; }
.author-note p { font-size:15px; line-height:1.8; color:var(--ink2); }

/* ── 互动栏 ───────────────────────────────────── */
.interact-bar {
  margin-top:48px; padding:24px 0; border-top:1px solid var(--line);
  display:flex; align-items:center; gap:20px;
}
.interact-btn {
  display:flex; align-items:center; gap:6px; padding:8px 18px;
  border-radius:8px; border:1px solid var(--line); background:var(--card-solid);
  cursor:pointer; font-family:var(--font-body); font-size:13px; color:var(--ink2);
  transition:all .2s;
}
.interact-btn:hover { border-color:var(--gold); color:var(--gold); }
.interact-btn.active { background:var(--gold); color:#fff; border-color:var(--gold); }
.interact-btn .icon { font-size:16px; }
.interact-spacer { flex:1; }
.back-link { font-size:14px; color:var(--gold); text-decoration:none; font-weight:600; }
.back-link:hover { text-decoration:underline; }

/* ── 评论区 ───────────────────────────────────── */
.comments-section { max-width:720px; margin:0 auto; padding:0 24px 100px; }
.comments-section h2 { font-size:20px; margin-bottom:24px; padding-top:32px; border-top:1px solid var(--line); }
.comment-form { margin-bottom:32px; }
.comment-form textarea {
  width:100%; padding:14px; border:1px solid var(--line); border-radius:10px;
  background:var(--card-solid); font-family:var(--font-body); font-size:14px;
  line-height:1.7; resize:vertical; min-height:80px; outline:none; transition:border-color .2s;
}
.comment-form textarea:focus { border-color:var(--gold); }
.comment-form .form-bottom { display:flex; justify-content:space-between; align-items:center; margin-top:10px; }
.comment-form .hint { font-size:12px; color:var(--ink2); }
.comment-form .submit-btn {
  padding:8px 22px; background:var(--gold); color:#fff; border:none;
  border-radius:8px; cursor:pointer; font-family:var(--font-body); font-size:13px; font-weight:600;
  transition:background .2s;
}
.comment-form .submit-btn:hover { background:var(--gold-light); }
.comment-list { display:flex; flex-direction:column; gap:20px; }
.comment-item { padding:20px; background:var(--card-solid); border-radius:var(--radius); box-shadow:var(--card-shadow); }
.comment-item .comment-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:8px; }
.comment-item .comment-user { display:flex; align-items:center; gap:10px; }
.comment-item .avatar {
  width:32px; height:32px; border-radius:50%; background:var(--gold); color:#fff;
  display:flex; align-items:center; justify-content:center; font-size:14px; font-weight:700;
}
.comment-item .name { font-size:14px; font-weight:600; }
.comment-item .time { font-size:12px; color:var(--ink2); }
.comment-item .comment-body { font-size:14px; line-height:1.8; color:var(--ink); }
.comment-item .del-btn {
  font-size:12px; color:#dc2626; background:none; border:none;
  cursor:pointer; opacity:.6; transition:opacity .2s;
}
.comment-item .del-btn:hover { opacity:1; }
.no-comments { text-align:center; padding:40px; color:var(--ink2); font-size:14px; }
.login-hint { text-align:center; padding:20px; color:var(--ink2); font-size:14px; }
.login-hint a { color:var(--gold); text-decoration:none; font-weight:600; }

/* ── 通用弹窗 ─────────────────────────────────── */
.modal-overlay {
  display:none; position:fixed; inset:0; background:rgba(0,0,0,.4); z-index:200;
  align-items:center; justify-content:center;
}
.modal-overlay.show { display:flex; }
.modal {
  background:var(--card-solid); border-radius:12px; padding:32px;
  max-width:420px; width:90%; box-shadow:0 8px 32px rgba(0,0,0,.2);
}
.modal h3 { margin-bottom:16px; font-size:18px; }
.modal textarea, .modal input, .modal select {
  width:100%; padding:10px 14px; border:1px solid var(--line); border-radius:8px;
  font-family:var(--font-body); font-size:14px; outline:none; margin-bottom:12px;
  background:transparent; color:var(--ink);
}
.modal textarea { min-height:100px; resize:vertical; }
.modal textarea:focus, .modal input:focus { border-color:var(--gold); }
.modal .modal-actions { display:flex; gap:10px; justify-content:flex-end; }

/* ── 统计卡片 ─────────────────────────────────── */
.stat-cards { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:40px; }
.stat-card { background:var(--card-solid); border-radius:var(--radius); padding:24px; box-shadow:var(--card-shadow); text-align:center; }
.stat-card .num { font-size:32px; font-weight:700; color:var(--gold); }
.stat-card .label { font-size:12px; color:var(--ink2); margin-top:4px; }

/* ── 导航网格 ─────────────────────────────────── */
.nav-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:14px; }
.nav-grid a {
  display:block; padding:20px 24px; background:var(--card-solid);
  border-radius:var(--radius); box-shadow:var(--card-shadow);
  text-decoration:none; color:var(--ink); font-size:15px; font-weight:600;
  transition:all .2s;
}
.nav-grid a:hover { transform:translateY(-2px); box-shadow:0 4px 24px rgba(24,18,10,.1); }
.nav-grid a .desc { font-size:12px; color:var(--ink2); font-weight:400; margin-top:4px; }

/* ── 搜索栏 ───────────────────────────────────── */
.search-bar { display:flex; gap:10px; margin-bottom:24px; flex-wrap:wrap; }
.search-bar input {
  padding:8px 14px; border:1px solid var(--line); border-radius:8px;
  font-size:14px; font-family:var(--font-body); outline:none;
  background:var(--card-solid); color:var(--ink); flex:1; min-width:200px;
}
.search-bar input:focus { border-color:var(--gold); }
.search-bar select {
  padding:8px 14px; border:1px solid var(--line); border-radius:8px;
  font-size:13px; font-family:var(--font-body); background:var(--card-solid); color:var(--ink);
}
.search-bar button {
  padding:8px 18px; background:var(--ink); color:var(--bg); border:none;
  border-radius:8px; font-size:13px; font-family:var(--font-body); cursor:pointer; font-weight:600;
}

/* ── 数据表格 ─────────────────────────────────── */
.data-table { width:100%; border-collapse:collapse; background:var(--card-solid); border-radius:var(--radius); overflow:hidden; box-shadow:var(--card-shadow); }
.data-table th { text-align:left; padding:12px 16px; font-size:12px; color:var(--ink2); border-bottom:1px solid var(--line); font-weight:700; }
.data-table td { padding:12px 16px; font-size:14px; border-bottom:1px solid var(--line); }
.data-table tr:last-child td { border-bottom:none; }
.data-table tr:hover { background:var(--bg2); }
.avatar-sm { width:28px; height:28px; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; color:#fff; font-size:12px; font-weight:700; margin-right:8px; vertical-align:middle; }

/* ── 表单卡片 ─────────────────────────────────── */
.form-card { background:var(--card-solid); border-radius:12px; padding:32px; box-shadow:var(--card-shadow); }
.field { margin-bottom:20px; }
.field label { display:block; font-size:13px; font-weight:600; color:var(--ink2); margin-bottom:8px; }
.field input, .field textarea, .field select {
  width:100%; padding:10px 14px; border:1px solid var(--line); border-radius:8px;
  background:transparent; color:var(--ink); font-family:var(--font-body); font-size:14px; outline:none;
}
.field input:focus, .field textarea:focus { border-color:var(--gold); }
.field textarea { resize:vertical; min-height:120px; line-height:1.7; }
.field label.checkbox { display:flex; align-items:center; gap:8px; font-size:14px; cursor:pointer; color:var(--ink); }
.field label.checkbox input { width:auto; accent-color:var(--gold); }
.form-actions { display:flex; gap:12px; justify-content:flex-end; margin-top:24px; }

/* ── 预览横幅 ─────────────────────────────────── */
.preview-banner { background:#fef3c7; text-align:center; padding:10px; font-size:13px; color:#92400e; font-weight:600; }

/* ── 退回原因 ─────────────────────────────────── */
.reject-reason {
  margin-top:10px; padding:10px 14px;
  background:#fef2f2; border-radius:6px;
  font-size:13px; color:#991b1b; line-height:1.6;
}

/* ── 敏感词云 ─────────────────────────────────── */
.word-cloud { background:var(--card-solid); border-radius:var(--radius); padding:24px; box-shadow:var(--card-shadow); display:flex; flex-wrap:wrap; gap:8px; }
.word-tag {
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 14px; background:var(--bg2); border-radius:20px; font-size:13px; color:var(--ink);
}
.word-tag .del {
  width:16px; height:16px; border-radius:50%; border:none;
  background:transparent; color:var(--ink2); cursor:pointer;
  font-size:14px; line-height:1; display:flex; align-items:center; justify-content:center; transition:all .2s;
}
.word-tag .del:hover { background:#fee2e2; color:#dc2626; }

/* ── 审核卡片 ─────────────────────────────────── */
.review-card {
  background:var(--card-solid); border-radius:var(--radius); padding:24px 28px;
  box-shadow:var(--card-shadow); margin-bottom:16px;
}
.review-card h3 { font-size:18px; margin-bottom:8px; }
.review-card h3 a { color:var(--ink); text-decoration:none; }
.review-card h3 a:hover { color:var(--gold); }
.review-card .meta { font-size:12px; color:var(--ink2); display:flex; gap:14px; margin-bottom:10px; }
.review-card .summary { font-size:14px; color:var(--ink2); line-height:1.7; margin-bottom:14px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.review-card .actions { display:flex; gap:10px; align-items:center; }
.btn-approve { background:#22c55e; color:#fff; }
.btn-approve:hover { background:#16a34a; }
.btn-reject { background:transparent; color:#dc2626; border:1px solid #fecaca; }
.btn-reject:hover { background:#fee2e2; }

/* ── 公告卡片 ─────────────────────────────────── */
.ann-list { display:flex; flex-direction:column; gap:12px; }
.ann-card {
  background:var(--card-solid); border-radius:var(--radius); padding:20px 24px;
  box-shadow:var(--card-shadow); display:flex; align-items:start; gap:16px;
}
.ann-card.pinned { border-left:3px solid var(--gold); }
.ann-card .body { flex:1; }
.ann-card h3 { font-size:16px; margin-bottom:4px; }
.ann-card p { font-size:13px; color:var(--ink2); line-height:1.6; }
.ann-card .meta { font-size:11px; color:var(--ink2); margin-top:6px; }
.ann-card .actions { display:flex; gap:8px; flex-shrink:0; }

/* ── 审核详情 ─────────────────────────────────── */
.info-box {
  background:var(--card-solid); border-radius:var(--radius); padding:20px 24px;
  box-shadow:var(--card-shadow); margin-bottom:24px;
  display:flex; flex-wrap:wrap; gap:16px; font-size:13px; color:var(--ink2);
}
.info-box .label { color:var(--ink); font-weight:600; }
.action-bar {
  background:var(--card-solid); border-radius:var(--radius); padding:20px 24px;
  box-shadow:var(--card-shadow); display:flex; align-items:center; gap:12px;
}
.reject-form { flex:1; display:flex; gap:10px; }
.reject-form input {
  flex:1; padding:10px 14px; border:1px solid var(--line); border-radius:8px;
  font-family:var(--font-body); font-size:14px; outline:none;
}
.reject-form input:focus { border-color:var(--gold); }

/* ── 错误页面 ─────────────────────────────────── */
.error-page {
  text-align:center; padding:120px 24px;
}
.error-page h1 { font-size:72px; font-weight:700; color:var(--gold); margin-bottom:16px; font-family:var(--font-en); }
.error-page p { font-size:16px; color:var(--ink2); margin-bottom:24px; }
.error-page a { color:var(--gold); font-weight:600; }

/* ── Toast ────────────────────────────────────── */
.toast-container { position:fixed; bottom:24px; left:50%; transform:translateX(-50%); z-index:9999; display:flex; flex-direction:column; gap:8px; align-items:center; }
.toast {
  padding:12px 24px; border-radius:var(--radius-btn);
  font-size:13px; color:#fff; font-family:var(--font-body);
  animation:toastIn .3s ease-out;
  box-shadow:0 4px 16px rgba(0,0,0,.15);
}
.toast.success { background:var(--toast-success); }
.toast.error { background:var(--toast-error); }
.toast.info { background:var(--toast-info); }
.toast.out { animation:toastOut .3s ease-in forwards; }
@keyframes toastIn { from{opacity:0;transform:translateY(12px)} to{opacity:1;transform:translateY(0)} }
@keyframes toastOut { from{opacity:1;transform:translateY(0)} to{opacity:0;transform:translateY(12px)} }

/* ── 页脚 ─────────────────────────────────────── */
.site-footer {
  text-align:center; padding:40px 20px; font-size:12px; color:var(--muted);
  position:relative; z-index:1;
}
.site-footer span { color:var(--accent); }

/* ── 页面主体 ─────────────────────────────────── */
.page-main { position:relative; z-index:1; min-height:60vh; }

/* ── 通用过渡 ─────────────────────────────────── */
body, .gn-link, .btn-primary, .site-footer {
  transition: background .5s ease, color .5s ease, border-color .5s ease;
}

/* ── 响应式 ───────────────────────────────────── */
@media (max-width: 768px) {
  .auth-page { flex-direction:column; }
  .auth-left { padding:40px 20px 0; flex:none; }
  .auth-right { padding:20px; flex:none; }
  .auth-card { padding:24px; }
  .gn-links { display:none; }
  .gn { padding:0 16px; }
  .gn-theme { display:none; }
  .stat-cards { grid-template-columns:repeat(2,1fr); }
  .nav-grid { grid-template-columns:1fr; }
  .story-grid { grid-template-columns:1fr; }
  .container { padding:24px 16px; }
  .article { padding:32px 16px 24px; }
  .article-header h1 { font-size:26px; }
  .article-body { font-size:16px; line-height:1.9; }
  .comments-section { padding:0 16px 80px; }
}
