/* ============================================================
   电丁丁知识库 · 设计系统
   字号阶梯 / 8px 间距 / 精炼色板 / 柔和阴影
   ============================================================ */
:root {
  /* 品牌色 */
  --blue: #1657a8;          /* 主色 */
  --blue2: #2b6fc7;         /* 主色-亮 */
  --blue-ink: #0f3f7d;      /* 主色-深（文字） */
  --blue-tint: #eef4fc;     /* 主色-淡底 */
  --accent: #f5781f;        /* 强调橙 */
  --accent-tint: #fff1e6;

  /* 中性 / 文字 */
  --ink: #1b2330;           /* 标题、强文字 */
  --ink-2: #4a5567;         /* 正文 */
  --ink-3: #6b7686;         /* 次要 */
  --ink-4: #98a1b0;         /* 提示、占位 */
  --tx: var(--ink); --tx2: var(--ink-3); --tx3: var(--ink-4);  /* 兼容旧变量 */

  /* 背景 / 边框 */
  --bg: #f4f6f9;
  --surface: #ffffff;
  --surface-2: #fafbfc;
  --card: var(--surface);
  --line: #e8ebf0;          /* 默认边框 */
  --line-2: #f0f2f5;        /* 极淡分隔 */
  --line2: var(--line-2);   /* 兼容旧变量 */

  /* 语义色 */
  --green: #14935f; --green-tint: #e6f5ee;
  --amber: #b9772a; --amber-tint: #fcf0dd;
  --red: #c8453c; --red-tint: #fdecea;

  /* 圆角 */
  --r-sm: 8px; --r: 10px; --r-lg: 14px; --r-xl: 18px;

  /* 阴影 */
  --sh-sm: 0 1px 2px rgba(20,30,50,.05), 0 1px 3px rgba(20,30,50,.05);
  --sh: 0 2px 8px rgba(20,30,50,.06), 0 1px 3px rgba(20,30,50,.05);
  --sh-md: 0 6px 20px rgba(20,30,50,.10);
  --sh-lg: 0 18px 44px rgba(20,30,50,.16);

  /* 字号阶梯 */
  --fz-xs: 12px; --fz-sm: 13px; --fz-base: 14px; --fz-md: 15px;
  --fz-lg: 16px; --fz-xl: 20px; --fz-2xl: 26px;

  --maxw: 1200px;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
body {
  font-family: -apple-system, "Segoe UI", "Microsoft YaHei", "PingFang SC", Roboto, sans-serif;
  font-size: var(--fz-base); line-height: 1.6; color: var(--ink-2);
  background: var(--bg); -moz-osx-font-smoothing: grayscale;
}
a { text-decoration: none; color: inherit; }
h1, h2, h3 { color: var(--ink); font-weight: 600; line-height: 1.3; }
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-thumb { background: #d2d7df; border-radius: 6px; border: 2px solid var(--bg); }
::-webkit-scrollbar-thumb:hover { background: #bcc3cd; }

.ico { display: inline-block; vertical-align: -0.16em; flex-shrink: 0; }
.side .it .ico { vertical-align: -0.2em; }
.tg-pill .ico { vertical-align: -0.1em; }
.topsearch button .ico, .back .ico, .dl-main .ico, .btn .ico { vertical-align: -0.18em; }

/* ============================ 顶栏 ============================ */
.topnav { height: 62px; background: var(--surface); border-bottom: 1px solid var(--line);
  position: sticky; top: 0; z-index: 50; display: flex; justify-content: center; }
.nav-inner { width: 100%; max-width: var(--maxw); padding: 0 24px; display: flex; align-items: center; gap: 20px; }
.logo { font-size: 19px; font-weight: 700; color: var(--blue); display: flex; align-items: center; gap: 8px; letter-spacing: .2px; }
.logo span { color: var(--accent); }
.logo .sep { margin: 0 3px; }
.logo-img { height: 30px; width: auto; display: block; }
.login-logo { width: 62px; height: auto; display: block; margin: 0 auto 14px; }
.topsearch { flex: 1; max-width: 460px; display: flex; align-items: center; background: var(--surface-2);
  border: 1px solid var(--line); border-radius: var(--r-sm); height: 40px; transition: .15s; }
.topsearch:focus-within { background: #fff; border-color: var(--blue2); box-shadow: 0 0 0 3px rgba(43,111,199,.12); }
.topsearch input { flex: 1; border: none; background: none; outline: none; padding: 0 14px; height: 100%;
  font-size: var(--fz-base); color: var(--ink); }
.topsearch input::placeholder { color: var(--ink-4); }
.topsearch button { background: none; border: none; padding: 0 14px; cursor: pointer; color: var(--ink-3);
  display: flex; align-items: center; }
.topsearch button:hover { color: var(--blue); }
.topnav-right { margin-left: auto; display: flex; align-items: center; gap: 18px; font-size: var(--fz-sm); color: var(--ink-3); }
.admin-entry { display: inline-flex; align-items: center; gap: 5px; color: var(--ink-2); font-weight: 500; padding: 7px 12px;
  border: 1px solid var(--line); border-radius: var(--r-sm); transition: .12s; }
.admin-entry:hover { color: var(--blue); border-color: var(--blue2); background: var(--blue-tint); }
.userbox { display: flex; align-items: center; gap: 10px; padding-left: 18px; border-left: 1px solid var(--line); }
.avatar { width: 36px; height: 36px; border-radius: 50%; background: var(--blue); color: #fff;
  display: flex; align-items: center; justify-content: center; font-weight: 600; font-size: var(--fz-base); flex-shrink: 0; }
.uinfo { display: flex; flex-direction: column; line-height: 1.25; }
.uname { font-size: var(--fz-sm); font-weight: 500; color: var(--ink); }
.urole { font-size: var(--fz-xs); color: var(--ink-4); }
.logout { display: inline-flex; align-items: center; justify-content: center; width: 32px; height: 32px;
  border-radius: var(--r-sm); color: var(--ink-4); margin-left: 2px; transition: .12s; }
.logout:hover { color: var(--red); background: var(--red-tint); }

/* ============================ flash ============================ */
.flash-wrap { max-width: var(--maxw); margin: 16px auto 0; padding: 0 24px; }
.flash { padding: 11px 16px; border-radius: var(--r-sm); font-size: var(--fz-base); margin-bottom: 8px;
  border: 1px solid transparent; }
.flash-success { background: var(--green-tint); color: var(--green); border-color: #c9ead8; }
.flash-danger { background: var(--red-tint); color: var(--red); border-color: #f5cfcb; }
.flash-info { background: var(--blue-tint); color: var(--blue-ink); border-color: #d6e6fa; }

/* ============================ 浏览页布局 ============================ */
.layout { display: flex; gap: 8px; max-width: var(--maxw); margin: 0 auto; padding: 0 24px; align-items: flex-start; }
.side { width: 236px; flex-shrink: 0; padding: 24px 8px 24px 0; position: sticky; top: 62px; }
.side .grp { margin-bottom: 26px; }
.side .gh { font-size: var(--fz-xs); color: var(--ink-4); font-weight: 600; letter-spacing: .08em;
  text-transform: uppercase; padding: 0 12px; margin-bottom: 10px; }
.side .it { display: flex; align-items: center; gap: 10px; padding: 9px 12px; border-radius: var(--r-sm);
  font-size: var(--fz-base); color: var(--ink-2); cursor: pointer; transition: .12s; }
.side a:hover .it { background: var(--surface-2); color: var(--ink); }
.side .it.on { background: var(--blue-tint); color: var(--blue-ink); font-weight: 500; }
.side .it.on .ico { color: var(--blue); }
.side .it .c { margin-left: auto; font-size: var(--fz-xs); color: var(--ink-4); font-variant-numeric: tabular-nums; }
.side .it.on .c { color: var(--blue); }

.main { flex: 1; padding: 24px 0 56px; min-width: 0; }
.crumb { font-size: var(--fz-sm); color: var(--ink-4); margin-bottom: 16px; }
.crumb b { color: var(--ink-2); font-weight: 500; }
.filters { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 18px; }
.filters .f { font-size: var(--fz-sm); padding: 6px 14px; background: var(--surface); border: 1px solid var(--line);
  border-radius: 20px; cursor: pointer; color: var(--ink-3); transition: .12s; }
.filters a:hover .f { border-color: var(--blue2); color: var(--blue); }
.filters .f.on { background: var(--blue); border-color: var(--blue); color: #fff; font-weight: 500; }
.subbar { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 16px;
  padding: 12px 14px; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); box-shadow: var(--sh-sm); }
.subbar-label { font-size: var(--fz-sm); color: var(--ink-4); margin-right: 4px; font-weight: 500; }
.chip { display: inline-flex; align-items: center; gap: 5px; font-size: var(--fz-sm); padding: 6px 12px;
  background: var(--surface-2); border: 1px solid var(--line); border-radius: 20px; cursor: pointer;
  color: var(--ink-2); transition: .12s; }
.subbar a:hover .chip { border-color: var(--blue2); color: var(--blue); }
.chip.on { background: var(--blue); border-color: var(--blue); color: #fff; font-weight: 500; }
.chip i { font-style: normal; font-size: var(--fz-xs); color: var(--ink-4); font-variant-numeric: tabular-nums; }
.chip.on i { color: rgba(255,255,255,.8); }
.chip .ico { color: inherit; }
.toolbar { display: flex; align-items: center; margin-bottom: 14px; font-size: var(--fz-sm); color: var(--ink-4); }
.toolbar .right { margin-left: auto; display: flex; gap: 16px; align-items: center; }
.toolbar a.tg { color: var(--ink-3); }
.toolbar a.tg:hover { color: var(--blue); }
.toolbar a.tg.on { color: var(--accent); font-weight: 500; }

/* 资料行 */
.row { position: relative; cursor: pointer; background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--r-lg); padding: 15px 18px; margin-bottom: 10px; display: flex; align-items: center;
  gap: 16px; transition: box-shadow .15s, border-color .15s, transform .15s; }
.row .tt::after { content: ""; position: absolute; inset: 0; }
.row .ic, .row .open { position: relative; z-index: 1; }
.row:hover { border-color: #cfdcef; box-shadow: var(--sh-md); transform: translateY(-1px); }
.row .ic { width: 44px; height: 44px; border-radius: var(--r); flex-shrink: 0; display: flex;
  align-items: center; justify-content: center; background: var(--blue-tint); color: var(--blue); overflow: hidden; }
.row .ic img { width: 100%; height: 100%; object-fit: cover; }
.row .info { flex: 1; min-width: 0; }
.row .tt { font-size: var(--fz-md); font-weight: 500; color: var(--ink); line-height: 1.45;
  display: block; overflow: hidden; text-overflow: ellipsis; }
.row:hover .tt { color: var(--blue); }
.row .tags { margin-top: 7px; display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.tg-pill { font-size: var(--fz-xs); background: #eff2f6; color: #54617a; padding: 2px 9px; border-radius: 6px; }
.tg-pill.ind { background: var(--green-tint); color: var(--green); }
.tg-pill.s { background: var(--red-tint); color: var(--red); }
.tg-pill.type { display: inline-flex; align-items: center; gap: 3px; background: var(--blue-tint);
  color: var(--blue-ink); font-weight: 500; }
.row .meta { text-align: right; flex-shrink: 0; font-size: var(--fz-xs); color: var(--ink-4);
  white-space: nowrap; line-height: 1.7; }
.badge { display: inline-block; font-size: 11px; font-weight: 500; padding: 2px 8px; border-radius: 6px; margin-bottom: 4px; }
.b-new { display: inline-block; font-size: 11px; font-weight: 500; padding: 2px 8px; border-radius: 6px;
  margin-bottom: 4px; background: var(--green-tint); color: var(--green); }
.b-old { display: inline-block; font-size: 11px; font-weight: 500; padding: 2px 8px; border-radius: 6px;
  margin-bottom: 4px; background: #eef0f3; color: var(--ink-3); }
.b-soon { display: inline-block; font-size: 11px; font-weight: 500; padding: 2px 8px; border-radius: 6px;
  margin-bottom: 4px; background: var(--amber-tint); color: var(--amber); }
.row.archived { opacity: .6; }
.row.archived .ic { background: #f0f1f3; color: var(--ink-4); }
.row .open { margin-left: 6px; padding: 7px 16px; border: 1px solid var(--line); color: var(--ink-3);
  border-radius: var(--r-sm); font-size: var(--fz-sm); font-weight: 500; transition: .12s; }
.row:hover .open { border-color: var(--blue); background: var(--blue); color: #fff; }
.row.archived .open, .row.archived:hover .open { background: var(--surface); border-color: var(--line); color: var(--ink-4); }
.empty { text-align: center; padding: 72px 0; color: var(--ink-4); }
.empty .ico { color: #c6cdd6; }

/* 分页 */
.pager { display: flex; justify-content: center; align-items: center; gap: 6px; flex-wrap: wrap; margin: 28px 0 8px; }
.pager .pg { min-width: 36px; height: 36px; padding: 0 10px; display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--line); border-radius: var(--r-sm); font-size: var(--fz-sm); color: var(--ink-2);
  background: var(--surface); transition: .12s; font-variant-numeric: tabular-nums; }
.pager .pg:hover { border-color: var(--blue2); color: var(--blue); }
.pager .pg.on { background: var(--blue); border-color: var(--blue); color: #fff; font-weight: 500; }

/* 交叉维度分组 */
.group { margin-bottom: 22px; }
.group-h { display: flex; align-items: center; gap: 8px; margin: 4px 2px 12px; color: var(--ink);
  font-size: var(--fz-md); font-weight: 600; }
.group-h .ico { color: var(--blue); }
.group-h .gname { letter-spacing: .01em; }
.group-h .gcount { font-size: var(--fz-xs); font-weight: 500; color: var(--ink-4); background: var(--surface-2);
  border: 1px solid var(--line); padding: 1px 9px; border-radius: 20px; }
.group-h::after { content: ""; flex: 1; height: 1px; background: var(--line); margin-left: 4px; }

/* ============================ 详情页 ============================ */
.detail { max-width: 980px; margin: 0 auto; padding: 28px 24px 56px; }
.back { font-size: var(--fz-sm); color: var(--ink-3); margin-bottom: 18px; display: inline-flex; align-items: center; gap: 5px; }
.back:hover { color: var(--blue); }
.detail .head { display: flex; gap: 20px; align-items: flex-start; margin-bottom: 20px; }
.detail h1 { font-size: var(--fz-2xl); font-weight: 600; letter-spacing: -.01em; }
.detail h1 .ver { color: var(--ink-4); font-size: var(--fz-lg); font-weight: 400; margin-left: 6px; }
.detail .sub { margin-top: 12px; color: var(--ink-2); font-size: var(--fz-base); line-height: 1.7; }
.detail .metaline { margin-top: 12px; font-size: var(--fz-sm); color: var(--ink-4); }
.dl-main { margin-left: auto; flex-shrink: 0; display: inline-flex; align-items: center; gap: 6px;
  padding: 10px 22px; background: var(--accent); color: #fff; border-radius: var(--r-sm); font-weight: 500; box-shadow: var(--sh-sm); }
.dl-main:hover { background: #e26b14; }
.preview-box { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg);
  overflow: hidden; margin-bottom: 18px; box-shadow: var(--sh-sm); }
.preview-box iframe { width: 100%; height: 700px; border: none; display: block; }
.preview-box img { width: 100%; display: block; }
.preview-none { padding: 56px; text-align: center; color: var(--ink-4); background: var(--surface);
  border: 1px dashed var(--line); border-radius: var(--r-lg); margin-bottom: 18px; }
.filelist { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 6px 18px; box-shadow: var(--sh-sm); }
.filelist .fr { display: flex; align-items: center; gap: 12px; padding: 13px 0; border-top: 1px solid var(--line-2); font-size: var(--fz-base); }
.filelist .fr:first-child { border-top: none; }
.filelist .fr .nm { flex: 1; color: var(--ink-2); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.filelist .fr .ftag { font-size: var(--fz-xs); background: var(--blue-tint); color: var(--blue-ink);
  padding: 2px 9px; border-radius: 6px; font-weight: 500; flex-shrink: 0; }
.ftag-pre { color: var(--blue); font-weight: 500; margin-right: 6px; }
.history .ftag-pre { color: var(--ink-3); }
.filelist .fr .sz { color: var(--ink-4); font-size: var(--fz-xs); flex-shrink: 0; min-width: 64px; text-align: right; }
.filelist .fr a { color: var(--blue); font-weight: 500; display: inline-flex; align-items: center; gap: 4px; flex-shrink: 0; }
.filelist .fr a:hover { color: var(--blue-ink); }
.notice { margin-top: 14px; padding: 11px 15px; border-radius: var(--r-sm); font-size: var(--fz-base); border: 1px solid transparent; }
.notice.warn { background: var(--amber-tint); color: var(--amber); border-color: #f0dcbf; }
.notice.danger { background: var(--red-tint); color: var(--red); border-color: #f5cfcb; }
.history { background: var(--surface-2); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 6px 18px; margin-top: 16px; }
.history-h { font-size: var(--fz-sm); color: var(--ink-3); font-weight: 600; padding: 12px 0 6px; display: flex; align-items: center; gap: 6px; }
.history .fr { display: flex; align-items: center; gap: 12px; padding: 11px 0; border-top: 1px solid var(--line-2); font-size: var(--fz-sm); }
.history .nm { flex: 1; color: var(--ink-3); }
.history .vlabel { font-size: 11px; background: #eef2f7; color: #51607a; padding: 1px 8px; border-radius: 6px; margin-left: 6px; }
.history .fr a { color: var(--blue); }

/* ============================ 登录 ============================ */
.login-page { min-height: 100vh; display: flex; align-items: center; justify-content: center;
  background: radial-gradient(1200px 600px at 50% -10%, #1d63bd, transparent), linear-gradient(160deg, #0e3a72, #15539c); padding: 24px; }
.login-card { width: 392px; background: var(--surface); border-radius: var(--r-xl); padding: 44px 40px; box-shadow: var(--sh-lg); }
.login-card .lg { text-align: center; font-size: 25px; font-weight: 700; color: var(--blue); margin-bottom: 6px; }
.login-card .lg span { color: var(--accent); }
.login-card .tip { text-align: center; color: var(--ink-4); font-size: var(--fz-sm); margin-bottom: 30px; }
.login-card label { display: block; font-size: var(--fz-sm); color: var(--ink-3); margin: 16px 0 7px; font-weight: 500; }
.login-card input { width: 100%; height: 46px; border: 1px solid var(--line); border-radius: var(--r-sm); padding: 0 14px; font-size: var(--fz-md); outline: none; transition: .15s; }
.login-card input:focus { border-color: var(--blue2); box-shadow: 0 0 0 3px rgba(43,111,199,.14); }
.login-card button { width: 100%; height: 48px; margin-top: 28px; background: var(--blue); color: #fff;
  border: none; border-radius: var(--r-sm); font-size: var(--fz-lg); font-weight: 500; cursor: pointer;
  letter-spacing: .3em; transition: .15s; box-shadow: var(--sh-sm); }
.login-card button:hover { background: var(--blue-ink); }
.login-card .err { background: var(--red-tint); color: var(--red); font-size: var(--fz-sm); padding: 9px 12px; border-radius: var(--r-sm); margin-top: 16px; text-align: center; }
.login-foot { text-align: center; color: rgba(255,255,255,.65); font-size: var(--fz-xs); margin-top: 20px; }

/* ============================ 后台 ============================ */
.admin-wrap { max-width: var(--maxw); margin: 0 auto; padding: 28px 24px 56px; }
.admin-tabs { display: flex; gap: 4px; border-bottom: 1px solid var(--line); margin-bottom: 24px; }
.admin-tabs a { padding: 12px 18px; font-size: var(--fz-base); color: var(--ink-3); border-bottom: 2px solid transparent; margin-bottom: -1px; transition: .12s; }
.admin-tabs a:hover { color: var(--ink); }
.admin-tabs a.on { color: var(--blue); border-color: var(--blue); font-weight: 500; }
.page-head { display: flex; align-items: center; margin-bottom: 18px; }
.page-head h2 { font-size: var(--fz-xl); }

/* 按钮系统 */
.btn { display: inline-flex; align-items: center; gap: 6px; height: 38px; padding: 0 16px; background: var(--blue);
  color: #fff; border: 1px solid var(--blue); border-radius: var(--r-sm); font-size: var(--fz-base); font-weight: 500;
  cursor: pointer; transition: .12s; white-space: nowrap; box-shadow: var(--sh-sm); }
.btn:hover { background: var(--blue-ink); border-color: var(--blue-ink); }
.btn.accent { background: var(--accent); border-color: var(--accent); }
.btn.accent:hover { background: #e26b14; border-color: #e26b14; }
.btn.ghost { background: var(--surface); color: var(--ink-2); border-color: var(--line); box-shadow: none; }
.btn.ghost:hover { background: var(--surface-2); border-color: var(--line); color: var(--ink); }
.btn.danger { background: var(--surface); color: var(--red); border-color: #f0cfcc; box-shadow: none; }
.btn.danger:hover { background: var(--red-tint); }
.btn.sm { height: 30px; padding: 0 11px; font-size: var(--fz-sm); }

/* 表格 */
table.tbl { width: 100%; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg);
  border-collapse: separate; border-spacing: 0; overflow: hidden; box-shadow: var(--sh-sm); }
table.tbl th { text-align: left; font-size: var(--fz-xs); color: var(--ink-4); font-weight: 600; letter-spacing: .03em;
  padding: 13px 16px; background: var(--surface-2); border-bottom: 1px solid var(--line); white-space: nowrap; }
table.tbl td { padding: 14px 16px; font-size: var(--fz-base); border-bottom: 1px solid var(--line-2); color: var(--ink-2); vertical-align: middle; }
table.tbl tr:last-child td { border-bottom: none; }
table.tbl tbody tr:hover td { background: var(--surface-2); }
.pill { display: inline-block; font-size: var(--fz-xs); font-weight: 500; padding: 3px 10px; border-radius: 20px; white-space: nowrap; }
.pill.active { background: var(--green-tint); color: var(--green); }
.pill.archived { background: #eef0f3; color: var(--ink-3); }
.actions { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.actions form { display: inline; }

/* 表单 */
.form-card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg);
  padding: 28px 30px; max-width: 780px; box-shadow: var(--sh-sm); }
.form-card h2 { font-size: var(--fz-xl); margin-bottom: 6px; }
.form-card > p { color: var(--ink-3); font-size: var(--fz-sm); margin-bottom: 18px; }
.fld { margin-bottom: 20px; }
.fld > label { display: block; font-size: var(--fz-base); font-weight: 500; color: var(--ink); margin-bottom: 8px; }
.fld input[type=text], .fld input[type=number], .fld input[type=date], .fld input[type=password],
.fld textarea, .fld select {
  width: 100%; border: 1px solid var(--line); border-radius: var(--r-sm); padding: 10px 13px;
  font-size: var(--fz-base); outline: none; font-family: inherit; color: var(--ink); transition: .15s; background: #fff; }
.fld input::placeholder, .fld textarea::placeholder { color: var(--ink-4); }
.fld input:focus, .fld textarea:focus, .fld select:focus { border-color: var(--blue2); box-shadow: 0 0 0 3px rgba(43,111,199,.12); }
.fld input[type=file] { width: 100%; font-size: var(--fz-sm); color: var(--ink-3); padding: 9px 12px;
  border: 1px dashed var(--line); border-radius: var(--r-sm); background: var(--surface-2); cursor: pointer; }
.fld .hint { font-size: var(--fz-xs); color: var(--ink-4); margin-top: 7px; line-height: 1.6; }
.tagbox { display: flex; flex-wrap: wrap; gap: 8px; }
.tagbox label { display: inline-flex; align-items: center; gap: 5px; font-weight: 400; font-size: var(--fz-sm);
  padding: 6px 13px; border: 1px solid var(--line); border-radius: 20px; cursor: pointer; color: var(--ink-2); transition: .12s; }
.tagbox label:hover { border-color: var(--blue2); }
.tagbox input { display: none; }
.tagbox label:has(input:checked) { border-color: var(--blue); background: var(--blue-tint); color: var(--blue-ink); font-weight: 500; }
.tag-cat { font-size: var(--fz-xs); color: var(--ink-4); margin: 14px 0 8px; font-weight: 600; letter-spacing: .03em; }
.row-2 { display: flex; gap: 16px; }
.row-2 > * { flex: 1; }
.matrix { width: 100%; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg);
  border-collapse: separate; border-spacing: 0; overflow: hidden; box-shadow: var(--sh-sm); }
.matrix th, .matrix td { padding: 12px 14px; border-bottom: 1px solid var(--line-2); font-size: var(--fz-base); text-align: center; }
.matrix th { background: var(--surface-2); color: var(--ink-3); font-weight: 600; font-size: var(--fz-sm); }
.matrix th:first-child, .matrix td:first-child { text-align: left; color: var(--ink); }
.matrix tr:last-child td { border-bottom: none; }
.matrix input { width: 17px; height: 17px; accent-color: var(--blue); }

/* ============================ 可访问性 / 焦点 ============================ */
a:focus-visible, button:focus-visible, input:focus-visible,
select:focus-visible, .row:focus-within { outline: 2px solid var(--blue2); outline-offset: 2px; border-radius: 6px; }

/* 排序 */
.sortbox { display: inline-flex; align-items: center; gap: 4px; }
.sortbox a { color: var(--ink-3); padding: 3px 9px; border-radius: 6px; }
.sortbox a:hover { color: var(--blue); background: var(--surface-2); }
.sortbox a.on { color: var(--blue); background: var(--blue-tint); font-weight: 500; }

/* ============================ 响应式 ============================ */
@media (max-width: 980px) {
  .layout, .admin-wrap, .detail, .nav-inner, .flash-wrap { padding-left: 16px; padding-right: 16px; }
  .side { width: 200px; }
  .topsearch { max-width: 320px; }
}
@media (max-width: 760px) {
  .nav-inner { gap: 12px; }
  .topsearch { max-width: none; }
  .urole, .who { display: none; }
  .admin-entry span:not(.ico) { display: none; }
  .userbox { padding-left: 12px; gap: 6px; }
  .layout { flex-direction: column; }
  .side { position: static; width: 100%; padding: 14px 0 0; display: flex; gap: 16px; overflow-x: auto; }
  .side .grp { margin-bottom: 0; flex-shrink: 0; }
  .side .it { white-space: nowrap; }
  .side .it .c { display: none; }
  .main { padding-top: 16px; }
  .row { gap: 12px; padding: 13px 14px; }
  .row .meta { display: none; }
  .detail .head { flex-direction: column; }
  .dl-main { margin-left: 0; }
  .preview-box iframe { height: 460px; }
  .row-2 { flex-direction: column; gap: 0; }
  table.tbl { display: block; overflow-x: auto; white-space: nowrap; }
}
@media (max-width: 760px) {
  .topnav { height: 56px; }
  .logo span { display: none; }
}
