/* =========================================================
   Admin panel — dark header + light content
   ========================================================= */
html { scrollbar-gutter: stable; overflow-y: scroll; }
body.admin-page { background: #e8e6df; overflow-x: clip; overflow-y: visible; }

.admin-nav {
  background: var(--ink);
  color: #fff;
  padding: 18px 0;
  position: sticky;
  top: 0;
  z-index: 100;
}
.admin-nav .wrap {
  display: flex; align-items: center; justify-content: space-between; gap: 20px;
  max-width: 1200px; margin: 0 auto; padding: 0 var(--gutter);
}
.admin-brand { display: inline-flex; align-items: center; gap: 8px; transition: opacity .2s var(--ease-out); }
.admin-brand:hover { opacity: 0.75; }
.admin-brand .mark { display: none; }
.admin-brand .name {
  font-family: "Oswald", "Helvetica Neue", Arial, sans-serif;
  font-weight: 400;
  font-size: 1.05rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  line-height: 1;
}
.admin-brand .badge {
  display: inline-block; padding: 2px 7px;
  background: var(--accent);
  font-size: 9px; font-weight: 700; letter-spacing: 0.2em;
  margin-left: 4px;
}
/* Plan badge (in admin header next to ADMIN badge) */
.admin-brand .badge.plan-badge {
  background: transparent;
  border: 1px solid currentColor;
  letter-spacing: 0.15em;
}
.admin-brand .badge.plan-badge--lite       { color: #c7d2fe; border-color: #818cf8; }
.admin-brand .badge.plan-badge--standard   { color: #a7f3d0; border-color: #34d399; }
.admin-brand .badge.plan-badge--business   { color: #fde68a; border-color: #fbbf24; }
.admin-brand .badge.plan-badge--enterprise { color: #fbcfe8; border-color: #f472b6; }

/* Plan pill (used in dashboard meta line) */
.plan-pill {
  display: inline-block;
  padding: 2px 8px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.1em;
  border: 1px solid currentColor;
  background: transparent;
  white-space: nowrap;
  vertical-align: middle;
}
.plan-pill--lite       { color: #6366f1; border-color: #818cf8; }
.plan-pill--standard   { color: #059669; border-color: #34d399; }
.plan-pill--business   { color: #d97706; border-color: #fbbf24; }
.plan-pill--enterprise { color: #be185d; border-color: #f472b6; }
body.admin-page .plan-pill--lite       { color: #c7d2fe; }
body.admin-page .plan-pill--standard   { color: #a7f3d0; }
body.admin-page .plan-pill--business   { color: #fde68a; }
body.admin-page .plan-pill--enterprise { color: #fbcfe8; }
.admin-nav-links { display: flex; flex-wrap: wrap; gap: 12px 18px; font-size: var(--fs-xs); }
.admin-nav-links a {
  padding: 5px 0; color: rgba(255,255,255,0.7);
  transition: color .2s var(--ease-out);
  position: relative;
}
.admin-nav-links a:hover { color: #fff; }
.admin-nav-links a.active { color: #fff; font-weight: 700; }

/* グループ（ドロップダウン）メニュー */
.admin-nav-links .nav-group { position: relative; display: inline-flex; }
.nav-group-btn {
  font: inherit; font-size: var(--fs-xs); line-height: 1;
  color: rgba(255,255,255,0.7); background: none; border: none; cursor: pointer;
  padding: 5px 0; display: inline-flex; align-items: center; gap: 5px;
  transition: color .2s var(--ease-out);
}
.nav-group-btn:hover,
.nav-group:focus-within > .nav-group-btn { color: #fff; }
.nav-group.is-active > .nav-group-btn { color: #fff; font-weight: 700; }
.nav-group-btn .caret { font-size: 9px; opacity: .75; transition: transform .15s var(--ease-out); }
.nav-group:hover > .nav-group-btn .caret,
.nav-group.open > .nav-group-btn .caret { transform: rotate(180deg); }
/* ボタンとメニューの間の隙間を埋め、ホバーが切れないように */
.nav-group::after { content: ''; position: absolute; top: 100%; left: -8px; right: -8px; height: 10px; }
.nav-group-menu {
  position: absolute; top: calc(100% + 9px); left: 0; z-index: 60;
  min-width: 176px; display: none; flex-direction: column;
  background: var(--dash-surface-2); border: 1px solid var(--dash-border);
  box-shadow: 0 10px 28px rgba(0,0,0,0.45);
}
.nav-group:hover > .nav-group-menu,
.nav-group:focus-within > .nav-group-menu,
.nav-group.open > .nav-group-menu { display: flex; }
.nav-group-menu a {
  padding: 9px 14px; white-space: nowrap; color: rgba(255,255,255,0.78);
  border-bottom: 1px solid var(--dash-border-soft);
}
.nav-group-menu a:last-child { border-bottom: none; }
.nav-group-menu a:hover { background: var(--dash-surface-3); color: #fff; }
.nav-group-menu a.active { color: #fff; font-weight: 700; background: var(--dash-surface-3); }
.admin-user {
  display: flex; align-items: center; gap: 10px;
  font-size: 10px; color: rgba(255,255,255,0.7);
}
.admin-user .sep { color: rgba(255,255,255,0.3); }
.admin-user a:hover { color: #fff; }
.admin-user-name { white-space: nowrap; }
.admin-icon-sep { width: 1px; height: 18px; background: rgba(255,255,255,0.18); margin: 0 2px; }

/* ハンバーガー（モバイルメニュー開閉）— PC では非表示 */
.admin-nav-toggle {
  display: none;
  flex-direction: column; justify-content: center; gap: 5px;
  width: 40px; height: 40px; margin-left: auto; padding: 0;
  background: transparent; border: 1px solid rgba(255,255,255,0.28); cursor: pointer;
}
.admin-nav-toggle-bar { display: block; width: 20px; height: 1.5px; background: #fff; margin: 0 auto; transition: transform .2s var(--ease-out), opacity .2s var(--ease-out); }
.admin-nav.is-open .admin-nav-toggle-bar:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.admin-nav.is-open .admin-nav-toggle-bar:nth-child(2) { opacity: 0; }
.admin-nav.is-open .admin-nav-toggle-bar:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* 管理ナビ：狭い画面ではハンバーガー開閉＋縦アコーディオン */
@media (max-width: 820px) {
  .admin-nav .wrap { flex-wrap: wrap; row-gap: 12px; }
  .admin-nav-toggle { display: inline-flex; }
  .admin-nav-links, .admin-user { display: none; width: 100%; }
  .admin-nav.is-open .admin-nav-links {
    display: flex; flex-direction: column; flex-wrap: nowrap;
    gap: 2px; align-items: stretch;
  }
  .admin-nav.is-open .admin-user {
    display: flex; flex-direction: row; flex-wrap: wrap; align-items: center;
    gap: 10px 16px; margin-top: 6px; padding-top: 12px;
    border-top: 1px solid rgba(255,255,255,0.15);
  }
  .admin-nav-links > a { padding: 12px 2px; }
  .admin-nav-links .nav-group { position: static; display: block; width: 100%; }
  .nav-group-btn { display: flex; width: 100%; justify-content: space-between; padding: 12px 2px; }
  /* モバイルではタップ＝.open のみで開く（hover/focus追従を無効化） */
  .nav-group:hover > .nav-group-menu,
  .nav-group:focus-within > .nav-group-menu { display: none; }
  .nav-group.open > .nav-group-menu { display: flex; }
  .nav-group-menu {
    position: static; min-width: 0; margin: 0; padding: 2px 0 6px;
    border: none; box-shadow: none; background: rgba(255,255,255,0.04);
  }
  .nav-group-menu a { padding: 11px 16px; }
  .nav-group::after { content: none; }
}
.admin-icon-link {
  position: relative;
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px; border-radius: 6px;
  color: rgba(255,255,255,0.7);
  background: none; border: none; cursor: pointer; font: inherit; padding: 0;
  transition: background .15s var(--ease-out), color .15s var(--ease-out);
}
.admin-icon-link:hover { color: #fff; background: rgba(255,255,255,0.10); }
.admin-icon-link.is-current { color: #fff; background: rgba(255,255,255,0.14); }

/* ホバー/フォーカスで吹き出し（ツールチップ）表示 */
.admin-icon-link[data-tooltip]::after {
  content: attr(data-tooltip);
  position: absolute; top: calc(100% + 9px); left: 50%; transform: translateX(-50%) translateY(2px);
  padding: 4px 9px; white-space: nowrap;
  background: var(--dash-surface-3); color: #fff; font-size: 10px; font-weight: 400; line-height: 1.4;
  letter-spacing: 0.02em; border: 1px solid var(--dash-border); border-radius: 5px;
  box-shadow: 0 6px 18px rgba(0,0,0,0.45);
  opacity: 0; pointer-events: none; z-index: 200;
  transition: opacity .15s var(--ease-out), transform .15s var(--ease-out);
}
.admin-icon-link[data-tooltip]::before {
  content: ''; position: absolute; top: calc(100% + 4px); left: 50%; transform: translateX(-50%) translateY(2px);
  border: 5px solid transparent; border-bottom-color: var(--dash-surface-3);
  opacity: 0; pointer-events: none; z-index: 200;
  transition: opacity .15s var(--ease-out), transform .15s var(--ease-out);
}
.admin-icon-link[data-tooltip]:hover::after,
.admin-icon-link[data-tooltip]:hover::before,
.admin-icon-link[data-tooltip]:focus-visible::after,
.admin-icon-link[data-tooltip]:focus-visible::before {
  opacity: 1; transform: translateX(-50%) translateY(0);
}
/* 右端のアイコンは吹き出しが画面外に出ないよう右寄せ */
.admin-user > :last-child .admin-icon-link[data-tooltip]::after,
.admin-user > .admin-icon-link:last-child[data-tooltip]::after { left: auto; right: 0; transform: translateY(2px); }
.admin-user > :last-child .admin-icon-link[data-tooltip]:hover::after { transform: translateY(0); }

.admin-wrap { max-width: 1200px; margin: 0 auto; padding: 24px var(--gutter) 40px; }

.admin-foot {
  padding: 16px 0;
  text-align: center;
  font-size: var(--fs-2xs);
  color: var(--ink-faint);
  border-top: 1px solid var(--line-hair);
  background: #fff;
}

/* Page header */
.page-head {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 14px;
  gap: 16px; flex-wrap: wrap;
}
.page-head h1 { font-size: var(--fs-xl); font-weight: 700; letter-spacing: -0.01em; }
.page-head .sub { font-size: var(--fs-xs); color: var(--ink-faint); }
.page-head .sub b { color: var(--ink); font-weight: 700; font-variant-numeric: tabular-nums; }
.page-lead { font-size: var(--fs-xs); color: var(--ink-mid); line-height: 1.75; margin-bottom: 22px; max-width: 820px; }

/* Dashboard */
.dash-head {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 22px; gap: 16px; flex-wrap: wrap;
}
.dash-head h1 { font-size: var(--fs-xl); font-weight: 700; letter-spacing: -0.01em; }
.dash-head .meta { font-size: var(--fs-xs); color: var(--ink-faint); }
.dash-head .meta b { color: var(--ink); font-weight: 700; font-variant-numeric: tabular-nums; }

.stat-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 28px; }
.stat-card {
  background: #fff;
  border: 1px solid var(--line-soft);
  padding: 16px 18px;
  position: relative;
  overflow: hidden;
}
.stat-card .label {
  font-size: var(--fs-2xs); letter-spacing: 0.15em;
  color: var(--ink-faint); text-transform: uppercase;
  margin-bottom: 10px;
}
.stat-card .value {
  font-size: 30px; font-weight: 800;
  letter-spacing: -0.02em; line-height: 1;
  font-variant-numeric: tabular-nums;
  margin-bottom: 6px;
}
.stat-card .value .unit {
  font-size: var(--fs-sm); font-weight: 400;
  color: var(--ink-faint); margin-left: 4px;
}
.stat-card .trend { font-size: var(--fs-2xs); color: var(--ink-faint); line-height: 1.5; }
.stat-card.warn .value { color: var(--warn); }
.stat-card.accent .value { color: var(--accent); }
.stat-card.ok .value { color: var(--ok); }
.stat-card::after {
  content: ""; position: absolute;
  top: 0; left: 0; width: 40px; height: 3px;
  background: var(--ink);
}
.stat-card.warn::after { background: var(--warn); }
.stat-card.accent::after { background: var(--accent); }
.stat-card.ok::after { background: var(--ok); }

.quick-actions { margin-bottom: 28px; }
.quick-actions h2 {
  font-size: var(--fs-2xs); letter-spacing: 0.2em;
  text-transform: uppercase; font-weight: 700;
  margin-bottom: 12px;
}
.action-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.action-card {
  background: #fff; border: 1px solid var(--line-soft);
  padding: 14px 16px;
  display: flex; gap: 12px; align-items: center;
  transition: all .2s var(--ease-out);
}
.action-card:hover { border-color: var(--ink); transform: translateY(-2px); box-shadow: 0 4px 0 -2px rgba(0,0,0,0.06); }
.action-card .ico {
  width: 38px; height: 38px;
  background: var(--ink); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; font-weight: 700; flex-shrink: 0;
}
.action-card.primary .ico { background: var(--accent); }
.action-card .info { flex: 1; }
.action-card .nm { font-size: var(--fs-sm); font-weight: 700; margin-bottom: 2px; }
.action-card .dsc { font-size: var(--fs-2xs); color: var(--ink-faint); line-height: 1.5; }
.action-card .arw { color: var(--ink-faint); font-size: var(--fs-md); transition: all .2s var(--ease-out); }
.action-card:hover .arw { color: var(--accent); transform: translateX(3px); }

/* Activity log */
.activity-section { margin-bottom: 28px; }
.activity-section h2 {
  font-size: var(--fs-2xs); letter-spacing: 0.2em;
  text-transform: uppercase; font-weight: 700;
  margin-bottom: 12px;
}
.activity-list { background: #fff; border: 1px solid var(--line-soft); }
.activity-row {
  display: grid;
  grid-template-columns: 160px 1fr 120px 80px;
  gap: 12px;
  padding: 10px 16px;
  align-items: center;
  border-bottom: 1px solid var(--line-hair);
  font-size: var(--fs-xs);
}
.activity-row:last-child { border-bottom: none; }
.activity-row--note { grid-template-columns: 110px 1fr; align-items: start; }
.activity-row--note .activity-desc { line-height: 1.7; }
.activity-time { font-variant-numeric: tabular-nums; color: var(--ink-faint); font-size: var(--fs-xs); }
.activity-desc b { font-weight: 700; }
.activity-user { font-size: var(--fs-xs); color: var(--ink-faint); }
.activity-status {
  padding: 3px 10px; font-size: var(--fs-2xs);
  letter-spacing: 0.1em; font-weight: 700;
  color: #fff; display: inline-block; text-align: center;
  white-space: nowrap;
}
.activity-status.ok { background: var(--ok); }
.activity-status.warn { background: var(--warn); }
.activity-status.err { background: var(--accent); }

/* Inline alerts (save / error / empty state) */
.alert-box {
  padding: 12px 16px;
  background: #fff;
  border: 1px solid var(--line-soft);
  border-left: 3px solid var(--ink-faint);
  margin-bottom: 16px;
  display: flex; gap: 10px; align-items: start;
  font-size: var(--fs-xs); line-height: 1.7;
}
.alert-box.err { border-left-color: var(--accent); }
.alert-box.ok  { border-left-color: var(--ok); }
.alert-box .icn { font-size: var(--fs-md); color: var(--ink-faint); flex-shrink: 0; line-height: 1.5; }
.alert-box.err .icn { color: var(--accent); }
.alert-box.ok  .icn { color: var(--ok); }
.alert-box b { font-weight: 700; color: var(--ink); }
.alert-box ul { margin: 4px 0 0 18px; list-style: disc; }

/* Notifications (dashboard alert list) */
.notice-list {
  background: #fff;
  border: 1px solid var(--line-soft);
  margin-bottom: 22px;
}
.notice-row {
  display: flex; align-items: center; gap: 14px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--line-hair);
  font-size: var(--fs-xs);
}
.notice-row:last-child { border-bottom: none; }
.notice-tag {
  display: inline-block;
  padding: 3px 10px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.15em;
  color: #fff;
  background: var(--ink);
  flex-shrink: 0;
  min-width: 64px;
  text-align: center;
}
.notice-tag.err  { background: var(--accent); }
.notice-tag.warn { background: var(--warn); }
.notice-tag.ok   { background: var(--ok); }
.notice-msg { flex: 1; color: var(--ink-mid); line-height: 1.6; }
.notice-msg b { color: var(--ink); font-weight: 700; font-variant-numeric: tabular-nums; }
.notice-action {
  font-size: var(--fs-xs);
  color: var(--ink);
  font-weight: 600;
  flex-shrink: 0;
  text-decoration: none;
  border-bottom: 1px solid var(--ink);
  padding-bottom: 1px;
}
.notice-action:hover { color: var(--accent); border-bottom-color: var(--accent); }

/* Upload page */
.upload-steps {
  display: flex; gap: 0; margin-bottom: 32px;
  background: #fff; border: 1px solid var(--line-soft);
}
.upl-step {
  flex: 1; display: flex; align-items: center; gap: 14px;
  padding: 18px 24px;
  border-right: 1px solid var(--line-hair);
}
.upl-step:last-child { border-right: none; }
.upl-step .nm {
  width: 34px; height: 34px; border-radius: 50%;
  background: var(--line-soft); color: var(--ink-faint);
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: var(--fs-md);
  font-variant-numeric: tabular-nums;
  flex-shrink: 0;
}
.upl-step.done .nm { background: var(--ok); color: #fff; }
.upl-step.active .nm { background: var(--accent); color: #fff; }
.upl-step .label { font-size: var(--fs-xs); color: var(--ink-faint); letter-spacing: 0.1em; }
.upl-step .title { font-size: var(--fs-sm); font-weight: 700; margin-top: 2px; }

.upload-zone {
  padding: 48px 32px;
  background: #fff;
  border: 2px dashed var(--line-soft);
  text-align: center;
  margin-bottom: 24px;
  transition: all .2s var(--ease-out);
}
.upload-zone:hover { border-color: var(--ink); background: #fbfbf9; }
.upload-zone .icn {
  width: 64px; height: 64px; margin: 0 auto 20px;
  border: 2px solid var(--ink);
  display: flex; align-items: center; justify-content: center;
  font-size: 28px; color: var(--ink);
}
.upload-zone h3 { font-size: var(--fs-lg); font-weight: 700; margin-bottom: 8px; }
.upload-zone p { font-size: var(--fs-sm); color: var(--ink-faint); margin-bottom: 18px; line-height: 1.8; }
.upload-zone .accept {
  font-size: var(--fs-xs); padding: 3px 8px;
  background: var(--fill-light); color: var(--ink-mid);
  letter-spacing: 0.04em;
}
.upload-zone input[type=file] { margin-top: 10px; }

.file-card {
  padding: 20px; background: var(--ok-soft);
  border: 1px solid var(--ok); margin-bottom: 24px;
  display: flex; gap: 16px; align-items: center;
}
.file-card .check {
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--ok); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; font-weight: 800; flex-shrink: 0;
}
.file-card .info { flex: 1; }
.file-card .nm { font-weight: 700; font-size: var(--fs-md); }
.file-card .meta { font-size: var(--fs-xs); color: var(--ink-faint); margin-top: 4px; font-variant-numeric: tabular-nums; }

.validation-card { margin-bottom: 28px; border: 1px solid var(--line-soft); background: #fff; }
.validation-head {
  padding: 14px 20px; background: var(--ok-soft);
  border-bottom: 1px solid var(--ok);
  display: flex; justify-content: space-between;
  font-size: var(--fs-sm); flex-wrap: wrap; gap: 12px;
}
.validation-head b { font-weight: 700; color: var(--ok); }
.validation-card.err .validation-head { background: var(--accent-soft); border-bottom-color: var(--accent); }
.validation-card.err .validation-head b { color: var(--accent); }
.validation-body { padding: 20px; }
.validation-body h4 {
  font-size: var(--fs-2xs); letter-spacing: 0.15em;
  font-weight: 700; color: var(--ink-faint);
  text-transform: uppercase; margin-bottom: 12px;
}
.diff-list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-bottom: 20px; }
.diff-card {
  padding: 14px; background: #fbfbf9;
  border: 1px solid var(--line-hair);
  font-size: var(--fs-xs); line-height: 1.7;
}
.diff-card .label {
  font-size: var(--fs-2xs); letter-spacing: 0.15em;
  color: var(--ink-faint); text-transform: uppercase; margin-bottom: 6px;
}
.diff-card .value {
  font-size: var(--fs-md); font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.diff-card.add .value    { color: var(--ok); }
.diff-card.change .value { color: var(--warn); }
.diff-card.remove .value { color: var(--accent); }

.preview-table-wrap {
  overflow-x: auto;
  border: 1px solid var(--line-soft);
  background: #fff;
}
.preview-table { width: 100%; border-collapse: collapse; font-size: var(--fs-xs); }
.preview-table th, .preview-table td {
  padding: 10px 12px; text-align: left;
  border-bottom: 1px solid var(--line-hair);
  white-space: nowrap;
}
.preview-table th {
  background: #fbfbf9; font-weight: 700;
  letter-spacing: 0.1em; color: var(--ink-faint);
  text-transform: uppercase; font-size: var(--fs-2xs);
}
.preview-table td.num { font-variant-numeric: tabular-nums; }
.preview-table .diff-add { background: var(--ok-soft); }
.preview-table .diff-change { background: var(--warn-soft); }
.preview-table .diff-remove { background: var(--accent-soft); }
.preview-table .diff-badge {
  display: inline-block; padding: 1px 6px;
  font-size: 9px; font-weight: 700;
  letter-spacing: 0.1em; color: #fff;
}
.preview-table .diff-badge.add    { background: var(--ok); }
.preview-table .diff-badge.change { background: var(--warn); }
.preview-table .diff-badge.remove { background: var(--accent); }

.backup-notice {
  margin-top: 20px; padding: 14px 18px;
  background: #fbfbf9;
  border-left: 3px solid var(--ink);
  font-size: var(--fs-xs);
  color: var(--ink-mid);
  line-height: 1.85;
}
.backup-notice b { color: var(--ink); font-weight: 700; }

.form-footer {
  display: flex; justify-content: space-between; gap: 14px;
  padding-top: 28px; margin-top: 32px;
  border-top: 1px solid var(--line);
  flex-wrap: wrap;
}
.form-footer .btn {
  padding: 8px 18px;
  font-size: 11px;
  letter-spacing: 0.06em;
  gap: 8px;
}

/* History table */
.history-table {
  width: 100%; border-collapse: collapse; background: #fff;
  border: 1px solid var(--line-soft); font-size: var(--fs-xs);
}
.history-table th, .history-table td {
  padding: 10px 14px; text-align: left;
  border-bottom: 1px solid var(--line-hair);
}
.history-table .btn--sm {
  padding: 2px 12px;
  font-size: 10px;
  letter-spacing: 0.06em;
  line-height: 1.4;
  min-width: 84px;
  justify-content: center;
  white-space: nowrap;
  box-sizing: border-box;
}
.history-table th {
  font-size: var(--fs-2xs); font-weight: 700;
  letter-spacing: 0.15em; color: var(--ink-faint);
  background: #fbfbf9;
}
.history-table tr:last-child td { border-bottom: none; }
.history-table .rollback-form {
  display: inline-block; margin: 0;
}

/* =========================================================
   Pagination
   ========================================================= */
.pagination {
  display: flex; align-items: center; justify-content: flex-end;
  gap: 16px; flex-wrap: wrap;
}
.pagination--top    { margin-bottom: 12px; padding-bottom: 12px; border-bottom: 1px solid var(--line-hair); }
.pagination--bottom { margin-top: 20px;    padding-top: 16px;    border-top: 1px solid var(--line-hair); }
.pagination__info {
  font-size: 11px;
  color: var(--ink-faint);
  letter-spacing: 0.04em;
  margin-right: 6px;
  white-space: nowrap;
}
.pagination__pages {
  display: flex; align-items: center; gap: 4px; flex-wrap: wrap;
}
.pagination__btn {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 30px;
  height: 30px;
  padding: 0 10px;
  border: 1px solid var(--line-soft);
  background: #fff;
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--ink);
  text-decoration: none;
  cursor: pointer;
  transition: all .15s var(--ease-out);
}
.pagination__btn:hover { border-color: var(--ink); }
.pagination__btn--num { font-variant-numeric: tabular-nums; }
.pagination__btn.is-current {
  background: var(--ink);
  color: #fff;
  border-color: var(--ink);
  cursor: default;
}
.pagination__btn.is-disabled {
  color: var(--ink-trace);
  cursor: not-allowed;
  pointer-events: none;
}
.pagination__ellipsis {
  padding: 0 4px;
  color: var(--ink-faint);
  font-size: 11px;
}

/* Per-page selector (lives inside .pagination__pages) */
.per-page-selector {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  color: var(--ink-faint);
  letter-spacing: 0.04em;
  margin-right: 8px;
}
.per-page-selector select {
  height: 30px;
  padding: 0 24px 0 10px;
  border: 1px solid var(--line-soft);
  background: #fff;
  font: inherit;
  font-size: 11px;
  letter-spacing: 0.04em;
  line-height: 28px;
  color: var(--ink);
  outline: none;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' fill='none' stroke='%23999' stroke-width='1.4' stroke-linecap='round'/></svg>");
  background-repeat: no-repeat;
  background-position: right 9px center;
  background-size: 9px 6px;
  box-sizing: border-box;
}
body.admin-page .per-page-selector { color: var(--dash-ink-faint); }
body.admin-page .per-page-selector select {
  background-color: var(--dash-surface);
  border-color: var(--dash-border);
  color: var(--dash-ink);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' fill='none' stroke='%23a8aab2' stroke-width='1.4' stroke-linecap='round'/></svg>");
}

/* Dark mode */
body.admin-page .pagination--top    { border-bottom-color: var(--dash-border); }
body.admin-page .pagination--bottom { border-top-color: var(--dash-border); }
body.admin-page .pagination__info { color: var(--dash-ink-faint); }
body.admin-page .pagination__btn {
  background: var(--dash-surface);
  border-color: var(--dash-border);
  color: var(--dash-ink);
}
body.admin-page .pagination__btn:hover { border-color: var(--dash-ink-faint); }
body.admin-page .pagination__btn.is-current {
  background: var(--dash-ink);
  color: var(--dash-bg);
  border-color: var(--dash-ink);
}
body.admin-page .pagination__btn.is-disabled {
  background: var(--dash-surface);
  color: var(--dash-ink-faint);
  opacity: 0.5;
}
body.admin-page .pagination__ellipsis { color: var(--dash-ink-faint); }

/* =========================================================
   Confirm modal (used by destructive actions like rollback)
   ========================================================= */
.confirm-modal {
  position: fixed; inset: 0;
  background: rgba(0, 0, 0, 0.7);
  z-index: 1000;
  display: none;
  align-items: center; justify-content: center;
  padding: 20px;
}
.confirm-modal.is-open { display: flex; }
.confirm-modal__box {
  background: #fff;
  border: 1px solid var(--line-soft);
  width: 100%; max-width: 460px;
  padding: 24px 28px 22px;
}
.confirm-modal__title {
  font-size: var(--fs-md);
  font-weight: 700;
  margin-bottom: 12px;
  color: var(--ink);
}
.confirm-modal__body {
  font-size: var(--fs-xs);
  line-height: 1.75;
  color: var(--ink-mid);
  margin-bottom: 20px;
  white-space: pre-line;
}
.confirm-modal__actions {
  display: flex; justify-content: flex-end; gap: 8px;
}
.confirm-modal__btn {
  height: 32px;
  padding: 0 16px;
  font-size: 11px;
  letter-spacing: 0.06em;
  font-weight: 600;
  border: 1px solid var(--line-soft);
  background: #fff;
  color: var(--ink);
  cursor: pointer;
  transition: all .15s var(--ease-out);
  box-sizing: border-box;
}
.confirm-modal__btn:hover { border-color: var(--ink); }
.confirm-modal__btn--danger {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}
.confirm-modal__btn--danger:hover {
  background: var(--accent-deep);
  border-color: var(--accent-deep);
  color: #fff;
}

/* Dark mode override */
body.admin-page .confirm-modal__box {
  background: var(--dash-surface);
  border-color: var(--dash-border);
}
body.admin-page .confirm-modal__title { color: var(--dash-ink); }
body.admin-page .confirm-modal__body { color: var(--dash-ink-mid); }
body.admin-page .confirm-modal__btn {
  background: var(--dash-surface-2);
  border-color: var(--dash-border);
  color: var(--dash-ink);
}
body.admin-page .confirm-modal__btn:hover {
  border-color: var(--dash-ink-faint);
}
body.admin-page .confirm-modal__btn--danger {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

/* Inquiries */
.inq-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; flex-wrap: wrap;
  margin-bottom: 12px;
}
.inq-toolbar .inq-status-bar { margin-bottom: 0; }
.inq-toolbar .pagination--top { margin-bottom: 0; padding-bottom: 0; border-bottom: none; }
.inq-status-bar {
  display: flex; gap: 6px; flex-wrap: wrap; align-items: center;
  margin-bottom: 12px;
}
.inq-pill {
  display: inline-flex; align-items: center; gap: 6px;
  height: 30px;
  padding: 0 12px;
  background: #fff;
  border: 1px solid var(--line-soft);
  font-size: 11px;
  letter-spacing: 0.04em;
  line-height: 28px;
  box-sizing: border-box;
  transition: all .2s var(--ease-out);
}
.inq-pill:hover { border-color: var(--ink); }
.inq-pill.active {
  background: var(--ink); color: #fff; border-color: var(--ink);
}
.inq-pill span {
  font-size: 10px;
  padding: 1px 7px;
  background: var(--fill-light);
  color: var(--ink);
  line-height: 1.4;
}
.inq-pill.active span { background: var(--accent); color: #fff; }

.inq-search-form {
  display: flex; gap: 6px; align-items: center;
  margin-bottom: 16px; flex-wrap: wrap;
}
.inq-search-form input[type=search] {
  flex: 1; min-width: 260px;
  height: 30px;
  padding: 0 12px;
  border: 1px solid var(--line-soft);
  font: inherit;
  font-size: 11px;
  line-height: 28px;
  outline: none;
  box-sizing: border-box;
}
.inq-search-form input[type=search]:focus { border-color: var(--ink); }
.inq-search-form .btn {
  height: 30px;
  padding: 0 14px;
  font-size: 11px;
  letter-spacing: 0.04em;
  gap: 6px;
  line-height: 28px;
  box-sizing: border-box;
}
.inq-clear { font-size: 11px; color: var(--accent); text-decoration: underline; }

.inq-list { display: flex; flex-direction: column; gap: 10px; }

.inq-card {
  background: #fff;
  border: 1px solid var(--line-soft);
  border-left: 4px solid var(--ink-faint);
  transition: border-color .2s var(--ease-out);
}
.inq-card.st-new         { border-left-color: var(--accent); }
.inq-card.st-in_progress { border-left-color: var(--warn); }
.inq-card.st-waiting     { border-left-color: var(--ink); }
.inq-card.st-completed   { border-left-color: var(--ok); }
.inq-card.st-archived    { border-left-color: var(--ink-faint); opacity: 0.7; }
.inq-card.is-focus { box-shadow: 0 0 0 3px var(--accent-soft); }

.inq-head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 10px 16px;
  border-bottom: 1px dotted var(--line-hair);
  gap: 14px; flex-wrap: wrap;
}
.inq-meta { display: flex; gap: 16px; align-items: baseline; flex-wrap: wrap; font-size: var(--fs-2xs); color: var(--ink-faint); }
.inq-id { letter-spacing: 0.05em; }
.inq-id code { font-size: 10px; color: var(--ink-mid); }
.inq-received { font-size: var(--fs-xs); color: var(--ink); font-weight: 600; }
.inq-status-label {
  padding: 3px 10px;
  font-size: var(--fs-2xs);
  letter-spacing: 0.15em;
  font-weight: 700;
  color: #fff;
}
.inq-status-label.st-new         { background: var(--accent); }
.inq-status-label.st-in_progress { background: var(--warn); }
.inq-status-label.st-waiting     { background: var(--ink); }
.inq-status-label.st-completed   { background: var(--ok); }
.inq-status-label.st-archived    { background: var(--ink-faint); }

.inq-body {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 22px;
  padding: 14px 16px;
}

.inq-dl { display: grid; grid-template-columns: 80px 1fr; gap: 4px 12px; font-size: var(--fs-xs); margin-bottom: 12px; }
.inq-dl dt { color: var(--ink-faint); font-size: var(--fs-2xs); padding-top: 2px; letter-spacing: 0.06em; }
.inq-dl dd { color: var(--ink); line-height: 1.5; word-break: break-all; }
.inq-dl a { color: var(--accent); text-decoration: underline; }

.inq-summary-label {
  font-size: var(--fs-2xs);
  letter-spacing: 0.15em;
  color: var(--ink-faint);
  text-transform: uppercase;
  font-weight: 700;
  margin-bottom: 6px;
}
.inq-summary-body {
  padding: 10px 12px;
  background: #fbfbf9;
  border: 1px solid var(--line-hair);
  font-size: var(--fs-xs);
  line-height: 1.75;
  max-height: 160px;
  overflow: auto;
  white-space: pre-wrap;
  word-break: break-word;
}

.inq-form { display: flex; flex-direction: column; gap: 12px; }
.inq-field { display: flex; flex-direction: column; gap: 6px; }
.inq-label {
  font-size: var(--fs-2xs);
  letter-spacing: 0.15em;
  color: var(--ink-faint);
  text-transform: uppercase;
  font-weight: 700;
}
.inq-status-select {
  padding: 7px 28px 7px 10px;
  font: inherit;
  font-size: var(--fs-xs);
  border: 1.5px solid var(--line-soft);
  background: #fff;
  outline: none;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' fill='none' stroke='%23999' stroke-width='1.4' stroke-linecap='round'/></svg>");
  background-repeat: no-repeat;
  background-position: right 10px center;
  background-size: 9px 6px;
}
.inq-status-select:focus { border-color: var(--ink); }
.inq-field textarea {
  font: inherit;
  font-size: var(--fs-xs);
  padding: 8px 12px;
  border: 1.5px solid var(--line-soft);
  background: #fff;
  outline: none;
  resize: vertical;
  min-height: 80px;
  line-height: 1.7;
}
.inq-field textarea:focus { border-color: var(--ink); }

.inq-form-foot {
  display: flex; justify-content: space-between; align-items: center;
  gap: 14px; flex-wrap: wrap;
}
.inq-updated { font-size: var(--fs-xs); color: var(--ink-faint); }

/* =========================================================
   CRUD — product admin
   ========================================================= */
.crud-toolbar {
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-areas:
    "lead   button"
    "filter pagination";
  gap: 10px 12px;
  margin-bottom: 14px;
}
.crud-toolbar > .btn,
.crud-toolbar > a.btn       { grid-area: button; justify-self: end; align-self: center; }
.crud-toolbar > .crud-toolbar__lead { grid-area: lead; align-self: center; margin: 0; }
.crud-toolbar > .crud-filter { grid-area: filter; align-self: center; }
.crud-toolbar > .pagination  { grid-area: pagination; align-self: center; justify-self: end; margin: 0; padding: 0; border: none; }
.crud-toolbar__lead {
  font-size: var(--fs-xs);
  color: var(--ink-mid);
  line-height: 1.6;
  max-width: 720px;
}
body.admin-page .crud-toolbar__lead { color: var(--dash-ink-mid); }
body.admin-page .crud-toolbar__lead a { color: var(--dash-ink); border-bottom: 1px solid var(--dash-ink-faint); }
@media (max-width: 768px) {
  .crud-toolbar {
    grid-template-columns: 1fr;
    grid-template-areas:
      "lead"
      "button"
      "filter"
      "pagination";
  }
  .crud-toolbar > .pagination { justify-self: stretch; }
}
.crud-toolbar .btn {
  padding: 8px 16px;
  font-size: var(--fs-xs);
  letter-spacing: 0.06em;
  gap: 8px;
}
.crud-filter {
  display: flex; gap: 6px; flex-wrap: wrap; align-items: center;
  flex: 1;
}
.crud-filter select,
.crud-filter input[type="search"],
.crud-filter .btn {
  height: 30px;
  padding: 0 10px;
  border: 1px solid var(--line-soft);
  background: #fff;
  font: inherit;
  font-size: 11px;
  letter-spacing: 0.04em;
  line-height: 28px;
  outline: none;
  box-sizing: border-box;
}
.crud-filter select {
  appearance: none;
  -webkit-appearance: none;
  padding-right: 26px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' fill='none' stroke='%23999' stroke-width='1.4' stroke-linecap='round'/></svg>");
  background-repeat: no-repeat;
  background-position: right 9px center;
  background-size: 9px 6px;
}
.crud-filter .btn { padding: 0 14px; gap: 6px; }
.crud-filter input[type="search"] { width: 160px; min-width: 0; flex: 1 1 160px; max-width: 220px; }
.crud-filter select:focus,
.crud-filter input[type="search"]:focus { border-color: var(--ink); }
.crud-clear { font-size: 11px; color: var(--accent); text-decoration: underline; }

.crud-table { width: 100%; border-collapse: collapse; background: #fff; font-size: var(--fs-xs); }
.crud-table th, .crud-table td {
  padding: 8px 12px;
  text-align: left;
  border-bottom: 1px solid var(--line-hair);
  vertical-align: middle;
}
.crud-table th {
  background: #fbfbf9;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: var(--ink-faint);
  text-transform: uppercase;
  font-size: var(--fs-2xs);
  white-space: nowrap;
}
.crud-table tr:last-child td { border-bottom: none; }
.crud-id-cell code { font-size: 11px; color: var(--ink-mid); }
.crud-name-cell { font-weight: 700; letter-spacing: -0.01em; margin-top: 2px; }
.crud-spec-cell { font-size: var(--fs-xs); color: var(--ink-faint); margin-top: 2px; }
.crud-thumb {
  width: 44px; height: 44px;
  background: var(--fill-light);
  border: 1px solid var(--line-hair);
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
}
.crud-thumb img { width: 100%; height: 100%; object-fit: cover; }
.crud-thumb-empty { color: var(--ink-trace); font-size: var(--fs-lg); }
.crud-table .stock { font-size: var(--fs-sm); font-weight: 700; }
.crud-table .stock small { font-size: var(--fs-2xs); font-weight: 400; color: var(--ink-faint); margin-left: 2px; }
.crud-table td:last-child { white-space: nowrap; }

/* Drag-to-reorder handle */
.crud-table .drag-cell {
  width: 28px;
  padding-left: 8px !important;
  padding-right: 0 !important;
}
.drag-handle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px; height: 22px;
  color: var(--ink-trace);
  cursor: grab;
  font-size: 14px;
  line-height: 1;
  user-select: none;
  transition: color .15s var(--ease-out);
}
.drag-handle:hover { color: var(--ink); }
.drag-handle:active { cursor: grabbing; }
body.admin-page .drag-handle { color: var(--dash-ink-faint); }
body.admin-page .drag-handle:hover { color: var(--dash-ink); }
.crud-table tr.is-dragging { opacity: 0.4; }
.crud-table tr.is-drag-ghost {
  background: var(--accent-soft) !important;
}
body.admin-page .crud-table tr.is-drag-ghost {
  background: var(--dash-surface-2) !important;
  outline: 1px dashed var(--admin-primary);
  outline-offset: -1px;
}
.reorder-toast {
  position: fixed;
  right: 20px; bottom: 20px;
  padding: 10px 16px;
  background: var(--ink);
  color: #fff;
  font-size: 11px;
  letter-spacing: 0.06em;
  z-index: 200;
  opacity: 0;
  transform: translateY(8px);
  pointer-events: none;
  transition: opacity .2s var(--ease-out), transform .2s var(--ease-out);
}
.reorder-toast.is-visible {
  opacity: 1;
  transform: translateY(0);
}
.reorder-toast.is-error { background: var(--accent); }
body.admin-page .reorder-toast { background: var(--admin-primary); }
body.admin-page .reorder-toast.is-error { background: var(--accent); }
.crud-table .btn--sm,
.crud-table .activity-status {
  padding: 2px 10px;
  font-size: 10px;
  letter-spacing: 0.06em;
  line-height: 1.4;
  min-width: 64px;
  text-align: center;
  justify-content: center;
  white-space: nowrap;
  box-sizing: border-box;
}
.crud-table .btn--sm { margin-left: 8px; gap: 4px; }
.crud-table .activity-status { display: inline-block; vertical-align: middle; }

/* Form */
.crud-form { margin-top: 8px; }
.crud-fieldset {
  border: 1px solid var(--line-soft);
  background: #fff;
  padding: 16px 18px 14px;
  margin-bottom: 14px;
}
.crud-fieldset legend {
  padding: 0 10px;
  font-size: var(--fs-2xs);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--ink);
}
.crud-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px 18px;
}
.crud-field { display: flex; flex-direction: column; gap: 4px; }
.crud-field--wide { grid-column: 1 / -1; }
.crud-label {
  font-size: var(--fs-2xs);
  letter-spacing: 0.15em;
  color: var(--ink-faint);
  text-transform: uppercase;
  font-weight: 700;
}
.crud-label em {
  color: var(--accent);
  font-style: normal;
  font-weight: 800;
  margin-left: 4px;
}
.crud-field input,
.crud-field select,
.crud-field textarea {
  padding: 7px 10px;
  border: 1.5px solid var(--line-soft);
  background: #fff;
  font: inherit;
  font-size: var(--fs-xs);
  outline: none;
}
.crud-field select {
  appearance: none;
  -webkit-appearance: none;
  padding-right: 28px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' fill='none' stroke='%23999' stroke-width='1.4' stroke-linecap='round'/></svg>");
  background-repeat: no-repeat;
  background-position: right 10px center;
  background-size: 9px 6px;
}
.crud-field input[type="file"] {
  background: transparent;
  border: none;
  padding: 4px 0;
  font-size: var(--fs-xs);
  color: inherit;
}
.crud-field input[disabled] { background: var(--fill-light); color: var(--ink-faint); }
.crud-field input:focus,
.crud-field select:focus,
.crud-field textarea:focus { border-color: var(--ink); }
.crud-field textarea { resize: vertical; min-height: 70px; line-height: 1.7; }
.crud-hint { font-size: 10px; color: var(--ink-faint); line-height: 1.5; }

/* Dynamic rows (tags, specs, faqs) */
.crud-rows {
  display: flex; flex-direction: column;
  gap: 6px;
  margin-bottom: 8px;
}
.crud-row {
  display: grid;
  grid-template-columns: 1fr 32px;
  gap: 8px;
  align-items: start;
}
.crud-row--kv  { grid-template-columns: 200px 1fr 32px; }
.crud-row--faq { grid-template-columns: 1fr 2fr 32px; }
.crud-row input[type="text"],
.crud-row textarea {
  padding: 8px 10px;
  border: 1.5px solid var(--line-soft);
  background: #fff;
  font: inherit;
  font-size: var(--fs-xs);
  outline: none;
  min-height: 32px;
}
.crud-row input:focus, .crud-row textarea:focus { border-color: var(--ink); }
.crud-row textarea { line-height: 1.6; }
.crud-row-remove {
  width: 32px; height: 36px;
  background: var(--fill-light);
  border: 1px solid var(--line-soft);
  color: var(--ink-faint);
  font-weight: 700;
  font-size: var(--fs-lg);
  cursor: pointer;
  line-height: 1;
  transition: all .15s var(--ease-out);
}
.crud-row-remove:hover {
  color: #fff;
  background: var(--accent);
  border-color: var(--accent);
}
.crud-row-add {
  align-self: flex-start;
  padding: 6px 12px;
  background: transparent;
  border: 1.5px dashed var(--line-soft);
  color: var(--ink-mid);
  font-size: var(--fs-xs);
  cursor: pointer;
  transition: all .15s var(--ease-out);
}
.crud-row-add:hover { border-color: var(--ink); color: var(--ink); }

/* Image grid */
.crud-img-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 10px;
  margin-bottom: 10px;
}
.crud-img-item {
  position: relative;
  border: 1px solid var(--line-soft);
  background: #fff;
  overflow: hidden;
}
.crud-img-item img {
  width: 100%; aspect-ratio: 4 / 3;
  object-fit: cover;
  display: block;
}
.crud-img-item--new img { outline: 3px solid var(--ok-soft); outline-offset: -3px; }
.crud-img-keep {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 10px;
  font-size: var(--fs-xs);
  background: #fbfbf9;
  border-top: 1px solid var(--line-hair);
  cursor: pointer;
}
.crud-img-keep input[type="checkbox"] { width: 14px; height: 14px; }

.crud-actions {
  display: flex; justify-content: space-between; gap: 12px;
  padding-top: 16px; margin-top: 16px;
  border-top: 1px solid var(--line);
  flex-wrap: wrap;
}
.crud-actions .btn {
  padding: 8px 18px;
  font-size: 11px;
  letter-spacing: 0.06em;
  gap: 8px;
}
.crud-actions > div { display: flex; gap: 10px; flex-wrap: wrap; }

@media (max-width: 1024px) {
  .stat-grid { grid-template-columns: 1fr 1fr; }
  .action-grid { grid-template-columns: 1fr; }
  .activity-row { grid-template-columns: 1fr; gap: 6px; padding: 14px 16px; }
  .upload-steps { flex-direction: column; }
  .upl-step { border-right: none; border-bottom: 1px solid var(--line-hair); }
  .upl-step:last-child { border-bottom: none; }
  .diff-list { grid-template-columns: 1fr; }
  .inq-body { grid-template-columns: 1fr; }
  .crud-grid { grid-template-columns: 1fr; }
  .crud-row--kv { grid-template-columns: 1fr 32px; }
  .crud-row--kv input[type="text"]:first-child { grid-column: 1 / -1; }
  .crud-row--faq { grid-template-columns: 1fr 32px; }
  .crud-row--faq textarea { grid-column: 1 / -1; }
}

/* =========================================================
   Admin — dark mode (scoped to all admin pages)
   ========================================================= */
body.admin-page {
  /* Restore red accent for admin (frontend uses green via common.css) */
  --accent:      #c63c2c;
  --accent-deep: #9a2918;
  --accent-soft: #f4e3df;

  /* Restore original border tokens for admin (frontend uses pure gray) */
  --line:      #2b2b2b;
  --line-soft: #d5d4ce;
  --line-hair: #e3e2db;

  --dash-bg:        #0e1117;
  --dash-surface:   #181b22;
  --dash-surface-2: #21252e;
  --dash-surface-3: #2a2e38;
  --dash-border:    #2a2e38;
  --dash-border-soft: #1f232b;
  --dash-ink:       #e8e8e8;
  --dash-ink-mid:   #a8aab2;
  --dash-ink-faint: #8b9099; /* WCAG AA: ~4.6:1 on --dash-bg（旧 #6c7079 は 3.8:1 で不足） */

  --admin-primary:      #3b82f6;
  --admin-primary-hov:  #60a5fa;

  /* Status pill gradients (top: light → bottom: dark) */
  --grad-info:    linear-gradient(180deg, #60a5fa 0%, #3b82f6 100%);
  --grad-err:     linear-gradient(180deg, #e85a48 0%, #c63c2c 100%);
  --grad-warn:    linear-gradient(180deg, #d99a2c 0%, #b47a18 100%);
  --grad-ok:      linear-gradient(180deg, #4ca06a 0%, #2d7a4b 100%);
  --grad-neutral: linear-gradient(180deg, #8a8d95 0%, #5c6068 100%);
  --grad-mute:    linear-gradient(180deg, #6c7079 0%, #4a4d54 100%);

  background: var(--dash-bg);
  color: var(--dash-ink);
}

/* Status badges — gradient fills */
body.admin-page .notice-tag.info,
body.admin-page .inq-status-label.st-new {
  background: var(--grad-info);
}
body.admin-page .notice-tag.err,
body.admin-page .activity-status.err,
body.admin-page .preview-table .diff-badge.remove {
  background: var(--grad-err);
}
body.admin-page .notice-tag.warn,
body.admin-page .inq-status-label.st-in_progress,
body.admin-page .activity-status.warn,
body.admin-page .preview-table .diff-badge.change {
  background: var(--grad-warn);
}
body.admin-page .notice-tag.ok,
body.admin-page .inq-status-label.st-completed,
body.admin-page .activity-status.ok,
body.admin-page .preview-table .diff-badge.add {
  background: var(--grad-ok);
}
body.admin-page .inq-status-label.st-waiting {
  background: var(--grad-neutral);
  color: #fff;
}
body.admin-page .inq-status-label.st-archived {
  background: var(--grad-mute);
}

/* Header matches body bg with subtle bottom hairline */
body.admin-page .admin-nav {
  background: var(--dash-bg);
  border-bottom: 1px solid var(--dash-border);
}

/* Primary action buttons (新規登録 / 保存 など) → blue gradient */
body.admin-page .btn--accent {
  background: var(--grad-info);
  border-color: var(--admin-primary);
  color: #fff;
}
body.admin-page .btn--accent:hover {
  background: linear-gradient(180deg, #7eb6fb 0%, #4f8ff8 100%);
  color: #fff;
  border-color: var(--admin-primary-hov);
}

/* Danger button in confirm modal → red gradient */
body.admin-page .confirm-modal__btn--danger {
  background: var(--grad-err);
  border-color: var(--accent);
  color: #fff;
}
body.admin-page .confirm-modal__btn--danger:hover {
  background: linear-gradient(180deg, #f07564 0%, #b53524 100%);
  border-color: var(--accent-deep);
  color: #fff;
}

/* Pagination current page indicator → subtle neutral gradient */
body.admin-page .pagination__btn.is-current {
  background: var(--grad-neutral);
  border-color: var(--dash-surface-3);
  color: #fff;
}

/* "New" indicators (新規お問い合わせ通知 / inquiry 新規ステータス) → blue */
body.admin-page .notice-tag.info { background: var(--admin-primary); }
body.admin-page .inq-card.st-new      { border-left-color: var(--admin-primary); }
body.admin-page .inq-card.st-waiting  { border-left-color: var(--dash-ink-mid); }
body.admin-page .inq-card.st-archived { border-left-color: var(--dash-ink-faint); opacity: 0.6; }
body.admin-page .inq-pill span { background: var(--dash-surface-2); color: var(--dash-ink); }

/* Dashboard quick-action icons — outlined gray squares */
body.admin-page .action-card .ico,
body.admin-page .action-card.primary .ico {
  background: transparent;
  border: 1px solid var(--dash-border);
  color: var(--dash-ink-faint);
}

/* Headings */
body.admin-page .dash-head h1,
body.admin-page .page-head h1 { color: var(--dash-ink); }
body.admin-page .dash-head .meta,
body.admin-page .page-head .sub { color: var(--dash-ink-faint); }
body.admin-page .dash-head .meta b,
body.admin-page .page-head .sub b { color: var(--dash-ink); }
body.admin-page .page-lead { color: var(--dash-ink-mid); }
body.admin-page .page-lead a { color: var(--dash-ink); border-bottom: 1px solid var(--dash-ink-faint); }
body.admin-page .quick-actions h2,
body.admin-page .activity-section h2 { color: var(--dash-ink-mid); }

/* Notifications */
body.admin-page .notice-list {
  background: var(--dash-surface);
  border-color: var(--dash-border);
}
body.admin-page .notice-row { border-bottom-color: var(--dash-border); }
body.admin-page .notice-msg { color: var(--dash-ink-mid); }
body.admin-page .notice-msg b { color: var(--dash-ink); }
body.admin-page .notice-action {
  color: var(--dash-ink);
  border-bottom-color: var(--dash-ink-faint);
}
body.admin-page .notice-action:hover {
  color: var(--accent);
  border-bottom-color: var(--accent);
}

/* Stat cards */
body.admin-page .stat-card {
  background: var(--dash-surface);
  border-color: var(--dash-border);
}
body.admin-page .stat-card .label { color: var(--dash-ink-faint); }
body.admin-page .stat-card .value { color: var(--dash-ink); }
body.admin-page .stat-card .value .unit { color: var(--dash-ink-faint); }
body.admin-page .stat-card .trend { color: var(--dash-ink-faint); }
body.admin-page .stat-card::after { background: var(--dash-ink-faint); }
body.admin-page .stat-card.warn::after   { background: var(--warn); }
body.admin-page .stat-card.accent::after { background: var(--accent); }
body.admin-page .stat-card.ok::after     { background: var(--ok); }

/* Action cards */
body.admin-page .action-card {
  background: var(--dash-surface);
  border-color: var(--dash-border);
}
body.admin-page .action-card:hover {
  background: var(--dash-surface-2);
  border-color: var(--dash-ink-faint);
  box-shadow: none;
}
body.admin-page .action-card .nm  { color: var(--dash-ink); }
body.admin-page .action-card .dsc { color: var(--dash-ink-faint); }
body.admin-page .action-card .arw { color: var(--dash-ink-faint); }

/* Activity list */
body.admin-page .activity-list {
  background: var(--dash-surface);
  border-color: var(--dash-border);
}
body.admin-page .activity-row { border-bottom-color: var(--dash-border); color: var(--dash-ink-mid); }
body.admin-page .activity-time { color: var(--dash-ink-faint); }
body.admin-page .activity-desc { color: var(--dash-ink); }
body.admin-page .activity-desc b { color: var(--dash-ink); }
body.admin-page .activity-user { color: var(--dash-ink-faint); }

/* Inline alerts (save / error / empty state) */
body.admin-page .alert-box {
  background: var(--dash-surface);
  border-color: var(--dash-border);
}
body.admin-page .alert-box b { color: var(--dash-ink); }

/* CRUD tables (商品 / セット商品 / 事例 一覧) */
body.admin-page .crud-table {
  background: var(--dash-surface);
}
body.admin-page .crud-table th,
body.admin-page .crud-table td { border-bottom-color: var(--dash-border); }
body.admin-page .crud-table th { background: var(--dash-surface-2); color: var(--dash-ink-faint); }
body.admin-page .crud-table { color: var(--dash-ink-mid); }
body.admin-page .crud-name-cell { color: var(--dash-ink); }
body.admin-page .crud-id-cell code { color: var(--dash-ink-faint); }
body.admin-page .crud-spec-cell { color: var(--dash-ink-faint); }
body.admin-page .crud-thumb { background: var(--dash-surface-2); border-color: var(--dash-border); }
body.admin-page .crud-thumb-empty { color: var(--dash-ink-faint); }
body.admin-page .crud-table .stock { color: var(--dash-ink); }
body.admin-page .crud-filter select,
body.admin-page .crud-filter input[type="search"],
body.admin-page .crud-filter .btn {
  background-color: var(--dash-surface);
  border-color: var(--dash-border);
  color: var(--dash-ink);
}
body.admin-page .crud-filter select,
body.admin-page .crud-field select,
body.admin-page .inq-status-select {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' fill='none' stroke='%23a8aab2' stroke-width='1.4' stroke-linecap='round'/></svg>");
  background-repeat: no-repeat;
}
body.admin-page .crud-filter select   { background-position: right 9px center;  background-size: 9px 6px; }
body.admin-page .crud-field select    { background-position: right 10px center; background-size: 9px 6px; }
body.admin-page .inq-status-select    { background-position: right 10px center; background-size: 9px 6px; }
body.admin-page .crud-filter .btn:hover {
  background: var(--dash-surface-2);
  border-color: var(--dash-ink-faint);
  color: var(--dash-ink);
}
body.admin-page .crud-filter input[type="search"]::placeholder { color: var(--dash-ink-faint); }
body.admin-page .crud-filter select:focus,
body.admin-page .crud-filter input[type="search"]:focus { border-color: var(--dash-ink-faint); }

/* CRUD edit forms */
body.admin-page .crud-fieldset {
  background: var(--dash-surface);
  border-color: var(--dash-border);
}
body.admin-page .crud-fieldset legend { color: var(--dash-ink); }
body.admin-page .crud-label { color: var(--dash-ink-faint); }
body.admin-page .crud-field input:not([type="file"]),
body.admin-page .crud-field select,
body.admin-page .crud-field textarea {
  background-color: var(--dash-bg);
  border-color: var(--dash-border);
  color: var(--dash-ink);
}
body.admin-page .crud-field input[type="file"] {
  background: transparent;
  border: none;
  color: var(--dash-ink-mid);
}
body.admin-page .crud-field input::placeholder,
body.admin-page .crud-field textarea::placeholder { color: var(--dash-ink-faint); }
body.admin-page .crud-field input:focus,
body.admin-page .crud-field select:focus,
body.admin-page .crud-field textarea:focus { border-color: var(--dash-ink-faint); }
body.admin-page .crud-field input[disabled] { background: var(--dash-surface-2); color: var(--dash-ink-faint); }
body.admin-page .crud-hint { color: var(--dash-ink-faint); }

/* すべての admin プルダウンを統一（暗色・矢印・高さ）。
   個別の .crud-field / .crud-filter / .per-page-selector はより詳細度が高い既存規則で微調整される。 */
body.admin-page select {
  appearance: none;
  -webkit-appearance: none;
  padding: 7px 30px 7px 10px;
  border: 1.5px solid var(--dash-border);
  border-radius: 0;
  background-color: var(--dash-bg);
  color: var(--dash-ink);
  font: inherit;
  font-size: var(--fs-xs);
  outline: none;
  box-sizing: border-box;
  cursor: pointer;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' fill='none' stroke='%23a8aab2' stroke-width='1.4' stroke-linecap='round'/></svg>");
  background-repeat: no-repeat;
  background-position: right 11px center;
  background-size: 9px 6px;
}
body.admin-page select:focus { border-color: var(--dash-ink-faint); }
body.admin-page select option { background: var(--dash-surface); color: var(--dash-ink); }
/* 検索バー内のプルダウンは同行のフォーム要素（高さ30px）に揃える */
body.admin-page .inq-search-form select { height: 30px; padding-top: 0; padding-bottom: 0; }

/* すべてのテキスト系入力・テキストエリアを暗色で統一（白フィールド残存を一掃）。
   チェックボックス/ラジオ/ファイルは対象外。 */
body.admin-page input[type="text"],
body.admin-page input[type="number"],
body.admin-page input[type="search"],
body.admin-page input[type="email"],
body.admin-page input[type="tel"],
body.admin-page input[type="url"],
body.admin-page input[type="date"],
body.admin-page input[type="password"],
body.admin-page textarea {
  border: 1.5px solid var(--dash-border);
  border-radius: 0;
  background-color: var(--dash-bg);
  color: var(--dash-ink);
  font: inherit;
  font-size: var(--fs-xs);
  box-sizing: border-box;
}
body.admin-page input::placeholder,
body.admin-page textarea::placeholder { color: var(--dash-ink-faint); }
/* キーボード操作時のフォーカスリング（outline:none の置き換え不足を補う） */
body.admin-page input:focus-visible,
body.admin-page select:focus-visible,
body.admin-page textarea:focus-visible,
body.admin-page .btn:focus-visible,
body.admin-page a:focus-visible {
  outline: 2px solid var(--admin-primary);
  outline-offset: 1px;
}
body.admin-page .crud-row input[type="text"],
body.admin-page .crud-row textarea {
  background: var(--dash-bg);
  border-color: var(--dash-border);
  color: var(--dash-ink);
}
body.admin-page .crud-row-remove {
  background: var(--dash-surface-2);
  border-color: var(--dash-border);
  color: var(--dash-ink-faint);
}
body.admin-page .crud-row-add {
  border-color: var(--dash-border);
  color: var(--dash-ink-mid);
}
body.admin-page .crud-row-add:hover { border-color: var(--dash-ink-faint); color: var(--dash-ink); }
body.admin-page .crud-img-item {
  background: var(--dash-surface);
  border-color: var(--dash-border);
}
body.admin-page .crud-img-keep {
  background: var(--dash-surface-2);
  border-top-color: var(--dash-border);
  color: var(--dash-ink-mid);
}
body.admin-page .crud-actions { border-top-color: var(--dash-border); }

/* Inquiries (問い合わせ管理) */
body.admin-page .inq-pill {
  background: var(--dash-surface);
  border-color: var(--dash-border);
  color: var(--dash-ink-mid);
}
body.admin-page .inq-pill:hover { border-color: var(--dash-ink-faint); color: var(--dash-ink); }
body.admin-page .inq-pill.active {
  background: #5c6068;
  color: #fff;
  border-color: #5c6068;
}
body.admin-page .inq-pill span { background: var(--dash-surface-2); color: var(--dash-ink); }
body.admin-page .inq-pill.active span { background: #2a2e38; color: #fff; }
body.admin-page .inq-search-form input[type=search],
body.admin-page .inq-search-form .btn {
  background: var(--dash-surface);
  border-color: var(--dash-border);
  color: var(--dash-ink);
}
body.admin-page .inq-search-form input[type=search]::placeholder { color: var(--dash-ink-faint); }
body.admin-page .inq-search-form .btn:hover {
  background: var(--dash-surface-2);
  border-color: var(--dash-ink-faint);
  color: var(--dash-ink);
}
body.admin-page .inq-card {
  background: var(--dash-surface);
  border-top-color: var(--dash-border);
  border-right-color: var(--dash-border);
  border-bottom-color: var(--dash-border);
}
body.admin-page .inq-head { border-bottom-color: var(--dash-border); }
body.admin-page .inq-meta { color: var(--dash-ink-faint); }
body.admin-page .inq-id code { color: var(--dash-ink-mid); }
body.admin-page .inq-received { color: var(--dash-ink); }
body.admin-page .inq-dl dt { color: var(--dash-ink-faint); }
body.admin-page .inq-dl dd { color: var(--dash-ink); }
body.admin-page .inq-dl a { color: var(--dash-ink); text-decoration: underline; }
body.admin-page .inq-summary-label,
body.admin-page .inq-label { color: var(--dash-ink-faint); }
body.admin-page .inq-summary-body {
  background: var(--dash-bg);
  border-color: var(--dash-border);
  color: var(--dash-ink);
}
body.admin-page .inq-status-select,
body.admin-page .inq-field textarea {
  background-color: var(--dash-bg);
  border-color: var(--dash-border);
  color: var(--dash-ink);
}
body.admin-page .inq-updated { color: var(--dash-ink-faint); }

/* History */
body.admin-page .history-table {
  background: var(--dash-surface);
  border-color: var(--dash-border);
  color: var(--dash-ink-mid);
}
body.admin-page .history-table th { background: var(--dash-surface-2); color: var(--dash-ink-faint); border-bottom-color: var(--dash-border); }
body.admin-page .history-table td { border-bottom-color: var(--dash-border); color: var(--dash-ink-mid); }

/* Upload page */
body.admin-page .upload-steps {
  background: var(--dash-surface);
  border-color: var(--dash-border);
}
body.admin-page .upl-step { border-right-color: var(--dash-border); }
body.admin-page .upl-step .nm { background: var(--dash-surface-2); color: var(--dash-ink-faint); }
body.admin-page .upl-step .label { color: var(--dash-ink-faint); }
body.admin-page .upl-step .title { color: var(--dash-ink); }
body.admin-page .upload-zone {
  background: var(--dash-surface);
  border-color: var(--dash-border);
  color: var(--dash-ink-mid);
}
body.admin-page .upload-zone:hover { background: var(--dash-surface-2); border-color: var(--dash-ink-faint); }
body.admin-page .upload-zone .icn { color: var(--dash-ink); border-color: var(--dash-ink); }
body.admin-page .upload-zone h3 { color: var(--dash-ink); }
body.admin-page .upload-zone p { color: var(--dash-ink-faint); }
body.admin-page .upload-zone .accept { background: var(--dash-surface-2); color: var(--dash-ink-mid); }
body.admin-page .file-card {
  background: var(--dash-surface);
  border-color: var(--ok);
}
body.admin-page .file-card .nm { color: var(--dash-ink); }
body.admin-page .file-card .meta { color: var(--dash-ink-faint); }
body.admin-page .validation-card {
  background: var(--dash-surface);
  border-color: var(--dash-border);
}
body.admin-page .validation-head { background: var(--dash-surface-2); border-bottom-color: var(--dash-border); color: var(--dash-ink); }
body.admin-page .validation-body h4 { color: var(--dash-ink-faint); }
body.admin-page .diff-card {
  background: var(--dash-surface-2);
  border-color: var(--dash-border);
  color: var(--dash-ink-mid);
}
body.admin-page .diff-card .label { color: var(--dash-ink-faint); }
body.admin-page .preview-table-wrap {
  background: var(--dash-surface);
  border-color: var(--dash-border);
}
body.admin-page .preview-table th { background: var(--dash-surface-2); color: var(--dash-ink-faint); }
body.admin-page .preview-table td { color: var(--dash-ink-mid); border-bottom-color: var(--dash-border); }
body.admin-page .backup-notice {
  background: var(--dash-surface-2);
  color: var(--dash-ink-mid);
}
body.admin-page .backup-notice b { color: var(--dash-ink); }
body.admin-page .form-footer { border-top-color: var(--dash-border); }

/* Buttons need a touch of dark-mode contrast */
body.admin-page .btn--outline {
  border-color: var(--dash-ink-faint);
  color: var(--dash-ink);
}
body.admin-page .btn--outline:hover {
  background: var(--dash-ink);
  color: var(--dash-bg);
  border-color: var(--dash-ink);
}

/* Footer */
body.admin-page .admin-foot {
  background: var(--dash-bg);
  color: var(--dash-ink-faint);
  border-top-color: var(--dash-border);
}
