/*
 * =============================================================================
 * 色彩与层级策略（补充需求 C2 — 供维护者与审阅对照）
 * =============================================================================
 * --color-accent / --color-accent-hover：主链路链接、主按钮、焦点环、首页主入口徽章
 * --color-danger / --color-danger-hover / --color-danger-bg：错误提示与对话框内「确认删除」等破坏性主按钮
 * --color-text / --color-text-muted：正文与辅助说明；次要入口标签（查阅者）弱化
 * --color-border / --color-bg / --color-surface：分区、卡片与面板底色；表单输入底同 surface
 * --color-on-accent：主按钮上的前景色
 * 派生色（accent-border / table 条纹等）：由主色与中性色推导，避免魔法数散落
 * --color-success-*：成功提示独立语义，避免与「可点击」蓝色混淆
 * =============================================================================
 */

/* 积分管理 — 设计令牌（单文件入口，业务页与壳层共用） */
:root {
  --font-sans: system-ui, -apple-system, "Segoe UI", Roboto, "PingFang SC", "Microsoft YaHei", sans-serif;
  --color-bg: #f8f9fb;
  --color-surface: #ffffff;
  --color-text: #1a1d26;
  --color-text-muted: #5c6370;
  --color-border: #e2e5eb;
  --color-accent: #2563eb;
  --color-accent-hover: #1d4ed8;
  --color-danger: #b91c1c;
  --color-danger-hover: #991b1b;
  --color-danger-bg: #fef2f2;
  --color-on-accent: #ffffff;
  --color-accent-border-soft: #bfdbfe;
  --color-accent-border-mid: #c7d2fe;
  --color-entry-primary-tint: #f8fafc;
  --shadow-entry-hover: 0 8px 28px rgba(37, 99, 235, 0.12);
  --color-table-header-bg: #f1f5f9;
  --color-table-row-alt: #fafbfc;
  --color-success-text: #166534;
  --color-success-bg: #f0fdf4;
  --color-success-border: #bbf7d0;
  --color-error-border: #fecaca;
  --color-viewer-nav-hover-bg: #eff6ff;
  --color-overlay: rgba(15, 23, 42, 0.35);
  --color-overlay-strong: rgba(15, 23, 42, 0.4);
  --space-xs: 0.25rem;
  --space-sm: 0.5rem;
  --space-md: 1rem;
  --space-lg: 1.5rem;
  --space-xl: 2rem;
  --space-2xl: 2.5rem;
  --radius: 10px;
  --shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.06);
  --shadow-md: 0 4px 24px rgba(15, 23, 42, 0.08);
  --max-content: 40rem;
  --max-content-wide: min(92rem, 100%);
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  font-size: 100%;
  -webkit-text-size-adjust: 100%;
}

body.shell {
  margin: 0;
  min-height: 100vh;
  font-family: var(--font-sans);
  font-size: 1rem;
  line-height: 1.55;
  color: var(--color-text);
  background: var(--color-bg);
  display: flex;
  flex-direction: column;
}

.site-header {
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  box-shadow: var(--shadow-sm);
}

.site-header__inner {
  max-width: 72rem;
  margin: 0 auto;
  padding: var(--space-md) var(--space-lg);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
}

.site-logo {
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--color-text);
  text-decoration: none;
  letter-spacing: -0.02em;
}

.site-logo:hover {
  color: var(--color-accent);
}

.site-logo:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 3px;
  border-radius: 4px;
}

.site-footer {
  margin-top: auto;
  padding: var(--space-lg);
  text-align: center;
  font-size: 0.875rem;
  color: var(--color-text-muted);
  border-top: 1px solid var(--color-border);
  background: var(--color-surface);
}

.site-footer a {
  color: var(--color-text-muted);
}

.site-footer a:hover {
  color: var(--color-accent);
}

.site-footer a:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
}

.container {
  width: 100%;
  max-width: var(--max-content);
  margin: 0 auto;
  padding: 0 var(--space-lg);
}

/* 表格/矩阵较多的业务页 */
.container--wide {
  max-width: var(--max-content-wide);
}

main.main {
  flex: 1;
  padding: var(--space-2xl) 0;
}

/* 登录页主区垂直略居中，减少「顶在壳层下」的空白失衡 */
main.main:has(.login-panel) {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-top: var(--space-xl);
  padding-bottom: var(--space-2xl);
}

/* 首页 */
.hero-title {
  font-size: clamp(1.5rem, 4vw, 1.875rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  margin: 0 0 var(--space-sm);
  line-height: 1.25;
}

.hero-lede {
  margin: 0 0 var(--space-xl);
  color: var(--color-text-muted);
  font-size: 1.05rem;
  max-width: 36rem;
}

/* 首页双入口：非等权网格 + 不同 DOM 骨架（主文档 R5 / 补充 C1） */
.entry-layout {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

@media (min-width: 640px) {
  .entry-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.65fr) minmax(0, 1fr);
    gap: var(--space-lg);
    align-items: start;
  }
}

.entry-featured {
  display: block;
  padding: var(--space-xl);
  background: var(--color-entry-primary-tint);
  border: 1px solid var(--color-accent-border-soft);
  border-radius: var(--radius);
  box-shadow: var(--shadow-md);
  text-decoration: none;
  color: inherit;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.entry-featured:hover {
  border-color: var(--color-accent-border-mid);
  box-shadow: var(--shadow-entry-hover);
}

.entry-featured:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 3px;
}

.entry-featured__badge {
  display: inline-block;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-accent);
  margin-bottom: var(--space-sm);
}

.entry-featured__title {
  font-size: clamp(1.2rem, 2.5vw, 1.35rem);
  font-weight: 700;
  margin: 0 0 var(--space-sm);
  letter-spacing: -0.02em;
  line-height: 1.25;
}

.entry-featured__desc {
  margin: 0;
  font-size: 0.95rem;
  color: var(--color-text-muted);
  line-height: 1.55;
  max-width: 28rem;
}

/* 查阅者：横向紧凑块，与主卡结构不同 */
.entry-sidebar {
  display: block;
  padding: var(--space-md) var(--space-lg);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  text-decoration: none;
  color: inherit;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.entry-sidebar:hover {
  border-color: var(--color-accent-border-soft);
  box-shadow: var(--shadow-md);
}

.entry-sidebar:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 3px;
}

.entry-sidebar__inner {
  display: flex;
  align-items: flex-start;
  gap: var(--space-md);
}

.entry-sidebar__tag {
  flex-shrink: 0;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-muted);
  padding: 0.2rem 0.45rem;
  border-radius: 4px;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
}

.entry-sidebar__body {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  min-width: 0;
}

.entry-sidebar__title {
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-text);
  line-height: 1.3;
}

.entry-sidebar__sub {
  font-size: 0.85rem;
  color: var(--color-text-muted);
  line-height: 1.45;
}

/* 登录页主区 */
.login-panel {
  max-width: 22rem;
  margin: 0 auto;
  padding: var(--space-xl);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-md);
}

.login-panel h1 {
  font-size: 1.35rem;
  font-weight: 700;
  margin: 0 0 var(--space-md);
  letter-spacing: -0.02em;
  line-height: 1.25;
  color: var(--color-text);
}

.login-question {
  margin: 0 0 var(--space-lg);
  color: var(--color-text-muted);
  font-size: 0.95rem;
}

/* 表单 */
.form-actions {
  margin-top: var(--space-lg);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-sm);
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.75rem;
  padding: 0 var(--space-lg);
  font-family: inherit;
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-on-accent);
  background: var(--color-accent);
  border: none;
  border-radius: 8px;
  cursor: pointer;
  width: 100%;
  transition: background 0.15s ease;
}

.btn:hover {
  background: var(--color-accent-hover);
}

.btn:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 3px;
}

.btn:disabled {
  opacity: 0.65;
  cursor: not-allowed;
}

a.btn {
  text-decoration: none;
  box-sizing: border-box;
}

a.btn:hover {
  color: var(--color-on-accent);
}

/* 次要操作：描边按钮，与主按钮区分 */
.btn--secondary {
  background: var(--color-surface);
  color: var(--color-accent);
  border: 1px solid var(--color-accent-border-soft);
  box-shadow: none;
}

.btn--secondary:hover {
  background: var(--color-viewer-nav-hover-bg);
  color: var(--color-accent-hover);
  border-color: var(--color-accent-border-mid);
}

.form-field {
  margin-bottom: var(--space-md);
}

.form-field label {
  display: block;
  font-size: 0.875rem;
  font-weight: 600;
  margin-bottom: var(--space-sm);
  color: var(--color-text);
}

.form-field input[type="text"],
.form-field input[type="password"],
.form-field input[type="date"],
.form-field input[type="file"] {
  width: 100%;
  padding: 0.65rem 0.75rem;
  font: inherit;
  border: 1px solid var(--color-border);
  border-radius: 8px;
  background: var(--color-surface);
}

.form-field input[type="file"] {
  padding: 0.5rem;
  font-size: 0.875rem;
}

.form-field input:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 1px;
  border-color: var(--color-accent);
}

/* 提示（阶段二可沿用） */
.alert {
  padding: var(--space-md);
  border-radius: 8px;
  margin-bottom: var(--space-lg);
  font-size: 0.9rem;
  border: 1px solid transparent;
}

.alert--error {
  color: var(--color-danger);
  background: var(--color-danger-bg);
  border-color: var(--color-error-border);
}

.alert__title {
  font-weight: 700;
  margin: 0 0 var(--space-xs);
}

.alert__text {
  margin: 0;
}

.alert--success {
  color: var(--color-success-text);
  background: var(--color-success-bg);
  border-color: var(--color-success-border);
}

.alert-list {
  margin: 0;
  padding-left: 1.25rem;
}

.alert-list li {
  margin-bottom: var(--space-xs);
}

.site-footer__sep {
  margin: 0 var(--space-sm);
  opacity: 0.5;
}

.page-title {
  font-size: clamp(1.35rem, 3vw, 1.6rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  margin: 0 0 var(--space-md);
  line-height: 1.3;
}

/* 业务页顶：站内短链接，与正文区隔开 */
.page-toolbar {
  margin: 0 0 var(--space-xl);
  padding: var(--space-sm) var(--space-md);
  background: var(--color-entry-primary-tint);
  border: 1px solid var(--color-accent-border-soft);
  border-radius: var(--radius);
  font-size: 0.9rem;
  line-height: 1.55;
  color: var(--color-text-muted);
}

.page-toolbar a {
  color: var(--color-accent);
  font-weight: 600;
  text-decoration: none;
}

.page-toolbar a:hover {
  text-decoration: underline;
}

.page-toolbar a:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
  border-radius: 2px;
}

/* 列表/表格空态 */
.empty-state {
  margin: 0 0 var(--space-lg);
  padding: var(--space-lg);
  text-align: center;
  color: var(--color-text-muted);
  font-size: 0.95rem;
  line-height: 1.55;
  background: var(--color-bg);
  border: 1px dashed var(--color-border);
  border-radius: var(--radius);
}

.empty-state a {
  color: var(--color-accent);
  font-weight: 600;
}

.panel {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  padding: var(--space-lg);
  margin-bottom: var(--space-lg);
}

.panel__title {
  font-size: 1.05rem;
  font-weight: 600;
  margin: 0 0 var(--space-md);
  padding-bottom: var(--space-sm);
  border-bottom: 1px solid var(--color-border);
}

.panel__hint {
  margin: 0 0 var(--space-md);
  font-size: 0.9rem;
  color: var(--color-text-muted);
  line-height: 1.5;
}

.panel__hint a {
  color: var(--color-accent);
  font-weight: 600;
  text-decoration: none;
}

.panel__hint a:hover {
  text-decoration: underline;
}

.form-field select,
.form-field textarea {
  width: 100%;
  max-width: 100%;
  padding: 0.65rem 0.75rem;
  font: inherit;
  border: 1px solid var(--color-border);
  border-radius: 8px;
  background: var(--color-surface);
}

.form-field select:focus-visible,
.form-field textarea:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 1px;
  border-color: var(--color-accent);
}

.form-field textarea {
  min-height: 6rem;
  resize: vertical;
}

.btn--narrow {
  width: auto;
  min-width: 8rem;
}

.table-wrap {
  width: 100%;
  overflow-x: auto;
  margin: var(--space-md) 0;
  -webkit-overflow-scrolling: touch;
}

.table-wrap--viewer-matrix {
  max-width: 100%;
}

.data-table--viewer-matrix {
  min-width: 72rem;
}

.data-table--viewer-matrix th:first-child,
.data-table--viewer-matrix td:first-child {
  position: sticky;
  left: 0;
  z-index: 1;
  background: var(--color-surface);
  box-shadow: 4px 0 8px -4px rgba(15, 23, 42, 0.12);
}

.data-table--viewer-matrix thead th:first-child {
  background: var(--color-table-header-bg);
}

.data-table--viewer-matrix tbody tr:nth-child(even) td:first-child {
  background: var(--color-table-row-alt);
}

.data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
  background: var(--color-surface);
}

.data-table th,
.data-table td {
  padding: 0.65rem 0.75rem;
  text-align: left;
  border: 1px solid var(--color-border);
  vertical-align: top;
}

.data-table thead th {
  background: var(--color-table-header-bg);
  font-weight: 600;
  color: var(--color-text);
}

.data-table tbody tr:nth-child(even) {
  background: var(--color-table-row-alt);
}

.data-table tbody tr {
  transition: background 0.12s ease;
}

.data-table tbody tr:hover {
  background: var(--color-viewer-nav-hover-bg);
}

/* 数值列（可选类） */
.data-table .cell-num {
  text-align: right;
  font-variant-numeric: tabular-nums;
}

.table-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-sm);
}

.form-inline-delete {
  display: inline-block;
  margin: 0;
  vertical-align: middle;
}

.viewer-nav-panel {
  margin-top: var(--space-xl);
  padding: var(--space-lg);
  background: var(--color-entry-primary-tint);
  border: 1px solid var(--color-accent-border-soft);
  border-radius: var(--radius);
}

.viewer-nav-panel__label {
  margin: 0 0 var(--space-md);
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-muted);
}

.viewer-nav {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}

.viewer-nav a {
  display: inline-block;
  padding: 0.5rem 0.9rem;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--color-accent);
  text-decoration: none;
  border: 1px solid var(--color-accent-border-soft);
  border-radius: 8px;
  background: var(--color-surface);
}

.viewer-nav a:hover {
  background: var(--color-viewer-nav-hover-bg);
}

.viewer-nav a:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
}

.viewer-saved__details {
  margin-top: var(--space-md);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: 0.35rem 0.75rem;
  background: var(--color-table-row-alt);
}

.viewer-saved__summary {
  cursor: pointer;
  font-weight: 600;
  color: var(--color-text);
  padding: 0.25rem 0;
}

.viewer-saved__summary:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
}

.viewer-saved__list {
  margin: var(--space-sm) 0 0.35rem;
  padding-left: 1.25rem;
  max-height: 16rem;
  overflow-y: auto;
  font-size: 0.9rem;
  line-height: 1.45;
}

.viewer-no-ledger__list {
  margin: var(--space-sm) 0 0;
  padding-left: 1.25rem;
  font-size: 0.9rem;
  line-height: 1.45;
}

.muted {
  color: var(--color-text-muted);
  font-size: 0.95rem;
  line-height: 1.55;
}

.muted a {
  color: var(--color-accent);
  font-weight: 600;
}

/* Excel 导入：提交后不确定进度遮罩 */
.excel-import-busy {
  position: fixed;
  inset: 0;
  z-index: 900;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-overlay);
}

.excel-import-busy--hidden {
  display: none;
}

.excel-import-busy__box {
  background: var(--color-surface);
  padding: var(--space-lg) var(--space-xl);
  border-radius: var(--radius);
  box-shadow: var(--shadow-md);
  border: 1px solid var(--color-border);
}

.excel-import-busy__text {
  margin: 0;
  font-weight: 600;
  color: var(--color-text);
}

/* Excel 导入结果：原生 dialog */
dialog.modal-dialog {
  position: fixed;
  inset: 0;
  margin: auto;
  max-width: min(32rem, calc(100vw - 2rem));
  max-height: min(85vh, 36rem);
  padding: var(--space-lg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-md);
  background: var(--color-surface);
  color: var(--color-text);
}

dialog.modal-dialog::backdrop {
  background: var(--color-overlay-strong);
}

.modal-dialog__title {
  margin: 0 0 var(--space-sm);
  font-size: 1.1rem;
  font-weight: 700;
  line-height: 1.35;
}

.modal-dialog__text,
.modal-dialog__lead {
  margin: 0 0 var(--space-md);
  line-height: 1.55;
}

.modal-dialog__errors {
  max-height: 40vh;
  overflow-y: auto;
  margin: 0 0 var(--space-md);
  padding-left: 1.25rem;
}

/* 手工提报确认：工号列表可滚动（与 Excel 错误列表高度策略相近） */
.modal-dialog__id-list {
  max-height: min(40vh, 16rem);
  overflow-y: auto;
  margin: 0 0 var(--space-md);
  padding-left: 1.25rem;
  list-style: disc;
}

.modal-dialog__summary {
  margin: 0 0 var(--space-md);
  font-size: 0.95rem;
  line-height: 1.55;
}

.modal-dialog__summary > div {
  margin-bottom: 0.25rem;
}

.modal-dialog__actions {
  display: flex;
  justify-content: flex-end;
  gap: var(--space-sm);
  margin-top: var(--space-md);
}

.btn--primary {
  background: var(--color-accent);
  color: var(--color-on-accent);
  border-color: var(--color-accent);
}

.btn--primary:hover {
  background: var(--color-accent-hover);
  border-color: var(--color-accent-hover);
  color: var(--color-on-accent);
}

.btn--danger {
  background: var(--color-danger);
  color: var(--color-on-accent);
  border: 1px solid var(--color-danger);
}

.btn--danger:hover {
  background: var(--color-danger-hover);
  border-color: var(--color-danger-hover);
  color: var(--color-on-accent);
}

.ledger-panel {
  margin-bottom: var(--space-xl);
}

.ledger-filter-form {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
  align-items: flex-end;
}

.ledger-filter-row {
  margin-bottom: 0;
}

.ledger-filter-row--grow {
  flex: 1 1 12rem;
  min-width: 10rem;
}

.ledger-filter-row--grow textarea {
  width: 100%;
  max-width: 28rem;
}

.ledger-table-toolbar {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-bottom: var(--space-sm);
}

.ledger-select-all {
  font-size: 0.9rem;
  color: var(--color-text-muted);
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
}

.ledger-col-check {
  width: 2.5rem;
}

.ledger-cats-cell {
  max-width: 20rem;
  word-break: break-word;
}

.ledger-pager {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-top: var(--space-md);
}

.ledger-pager__meta {
  font-size: 0.9rem;
  color: var(--color-text-muted);
}
