:root {
  --accent: #238f4a;
  --accent-rgb: 35, 143, 74;
  --bg-gradient-start: #0b2a1d;
  --active: rgba(35, 143, 74, 0.25);
  --preview-scale: 0.75;
}

html,
body {
  height: 100%;
  user-select: none;
}

body {
  margin: 0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Microsoft YaHei", sans-serif;
  background: radial-gradient(900px 520px at 50% -200px, var(--bg-gradient-start), var(--bg));
  color: var(--fg);
  overflow-y: hidden;
}

/* 插件页面主体容器（示例插件窗口等） */
.wrap {
  padding: 20px;
  height: calc(100vh - 35px);
  overflow-y: auto;
  box-sizing: border-box;
}

/* 全局滚动条样式（统一定义） */
.wrap::-webkit-scrollbar,
#content::-webkit-scrollbar,
.modal-body::-webkit-scrollbar,
.auto-list::-webkit-scrollbar,
.auto-editor::-webkit-scrollbar,
.profiles-table-wrap::-webkit-scrollbar,
textarea::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

.wrap::-webkit-scrollbar-track,
#content::-webkit-scrollbar-track,
.modal-body::-webkit-scrollbar-track,
.auto-list::-webkit-scrollbar-track,
.auto-editor::-webkit-scrollbar-track,
.profiles-table-wrap::-webkit-scrollbar-track,
textarea::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.04);
  border-left: 1px solid var(--border);
}

.wrap::-webkit-scrollbar-thumb,
#content::-webkit-scrollbar-thumb,
.modal-body::-webkit-scrollbar-thumb,
.auto-list::-webkit-scrollbar-thumb,
.auto-editor::-webkit-scrollbar-thumb,
.profiles-table-wrap::-webkit-scrollbar-thumb,
textarea::-webkit-scrollbar-thumb {
  background: rgba(64, 75, 88, 0.685);
  border: 1px solid rgba(72, 87, 107, 0.45);
  border-radius: 999px;
}

.wrap::-webkit-scrollbar-thumb:hover,
#content::-webkit-scrollbar-thumb:hover,
.modal-body::-webkit-scrollbar-thumb:hover,
.auto-list::-webkit-scrollbar-thumb:hover,
.auto-editor::-webkit-scrollbar-thumb:hover,
.profiles-table-wrap::-webkit-scrollbar-thumb:hover,
textarea::-webkit-scrollbar-thumb:hover {
  background: rgba(69, 83, 90, 0.5);
}
body::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}
body::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.04);
  border-left: 1px solid var(--border);
}
body::-webkit-scrollbar-thumb {
  background: rgba(64, 75, 88, 0.685);
  border: 1px solid rgba(72, 87, 107, 0.45);
  border-radius: 999px;
}
body::-webkit-scrollbar-thumb:hover {
  background: rgba(69, 83, 90, 0.5);
}

/* 布局 */
.layout {
  display: grid;
  grid-template-columns: 240px 1fr;
  height: 100vh;
}

.sidebar {
  border-right: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.06);
}

.logo {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 16px;
}

.logo img {
  width: 36px;
  height: 36px;
}

.logo span {
  font-weight: 600;
}

.sidebar nav {
  display: grid;
  gap: 6px;
  padding: 10px;
}

.nav-item {
  display: flex;
  align-items: center;
  gap: 8px;
  text-align: left;
  background: transparent;
  color: var(--fg);
  border: 1px solid transparent;
  border-radius: 8px;
  padding: 10px 12px;
  cursor: pointer;
}

.nav-item:hover {
  background: rgba(255, 255, 255, 0.04);
  border-color: var(--border);
}

.nav-item.active {
  background: rgba(34, 197, 94, 0.15);
  border-color: rgba(34, 197, 94, 0.35);
}

#content {
  position: relative;
  height: calc(100vh - 34px);
  /* 标题栏高度：34px */
  overflow-y: auto;
}

/* 滚动条样式统一至全局规则（见上方全局滚动条样式） */


/* 拖拽安装区域 */
.drop-install {
  margin: 12px 20px;
  border: 1px dashed var(--border);
  background: rgba(255, 255, 255, 0.04);
  border-radius: 10px;
  padding: 20px;
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--muted);
}

.drop-install i {
  color: var(--accent);
}

.drop-install.dragover {
  border-color: rgba(34, 197, 94, 0.45);
  background: rgba(34, 197, 94, 0.12);
  color: var(--fg);
}

/* 模态框 */
.modal {
  position: fixed;
  inset: 0;
  z-index: 10;
}

.modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.75);
}

.modal-dialog {
  position: relative;
  width: 560px;
  margin: 10vh auto;
  border: 1px solid var(--border);
  background: #1b1f2a;
  border-radius: 10px;
  overflow: hidden;
  color: var(--fg);
}

.modal-title {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.06);
}

.modal-body {
  padding: 12px 16px;
  color: var(--fg);
  max-height: 50vh;
  overflow-y: auto;
}

/* 滚动条样式统一至全局规则（见上方全局滚动条样式） */

.modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  padding: 12px 16px;
  border-top: 1px dashed var(--border);
}

/* 调试：后端日志列表 */
.log-list {
  margin: 12px 20px;
  padding: 12px 16px;
  border: 1px solid var(--border);
  background: var(--panel);
  border-radius: 10px;
  max-height: 50vh;
  overflow-y: auto;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Courier New", monospace;
  font-size: 12px;
  line-height: 1.6;
  white-space: pre-wrap;
}

.btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: none;
  border-radius: 6px;
  padding: 8px 12px;
  cursor: pointer;
  background: rgba(255, 255, 255, 0.06);
  border-color: transparent;
  color: var(--fg);
}
a.btn { text-decoration: none; }

.btn.primary {
  background: #15803d;
  color: #fff;
}

.btn.secondary {
  background: #14532d;
  color: #fff;
}

.btn.danger {
  background: #dc2626;
  color: #fff;
}

#content section {
  padding: 0 20px
}

/* 启动页内嵌预览样式 */
.splash-preview-container {
  margin-top: 8px;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.04);
  border-radius: 8px;
  overflow: hidden;
  height: 280px;
}
.splash-preview-frame {
  display: block;
  width: calc(100% / var(--preview-scale));
  height: calc(280px / var(--preview-scale));
  border: none;
  transform: scale(var(--preview-scale));
  transform-origin: top left;
}

/* 紧凑选项组（用于背景样式选择） */
.options.compact label {
  font-size: 12px;
  padding: 4px 10px;
}

/* 合并卡片布局：左预览 / 右设置 */
.setting-card {
  border: 1px solid var(--border);
  background: var(--panel);
  border-radius: 10px;
  padding: 12px;
  margin: 10px 0;
}
.splash-card {
  display: grid;
  grid-template-columns: 420px 1fr;
  gap: 12px;
  align-items: start;
}
.splash-card-left { display: flex; flex-direction: column; }
.splash-card-right { display: flex; flex-direction: column; }

/* 右侧分组卡片（美化名言相关设置） */
.field-group {
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.04);
  border-radius: 10px;
  padding: 12px;
  margin-top: 10px;
}
.field-header { display: grid; gap: 4px; margin-bottom: 8px; }
.field-title { font-weight: 600; }
.field-desc { color: var(--muted); font-size: 13px; }

/* 名言来源按钮组优化 */
.field-group .options {
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.03);
}
.field-group .options label {
  padding: 8px 12px;
}
.field-group .options input[type=radio]:checked+label {
  background: rgba(34, 197, 94, 0.16);
}
.field-group .inline { margin-top: 6px; }

/* API示例文本样式 */
#api-sample {
  margin-top: 6px;
  padding: 6px 8px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.03);
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size: 12px;
}

/* Toast 通知（全局） */
.toast-container {
  position: fixed;
  right: 16px;
  bottom: 16px;
  z-index: 1000;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.toast {
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid var(--border);
  color: var(--fg);
  padding: 10px 12px;
  border-radius: 8px;
  box-shadow: 0 6px 24px rgba(0,0,0,0.3);
  transform: translateY(10px);
  opacity: 0;
  transition: opacity 0.25s ease, transform 0.25s ease;
  max-width: 360px;
}
.toast.show {
  opacity: 1;
  transform: translateY(0);
}
.toast-info { border-left: 4px solid #22c55e; }
.toast-success { border-left: 4px solid #16a34a; }
.toast-warning { border-left: 4px solid #f59e0b; }
.toast-error { border-left: 4px solid #ef4444; }

header {
  margin: 20px;
}

/* 插件页标题区域：左文案 + 右视图切换器 */
#page-plugins > .plugins-header {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
}
#page-plugins > .plugins-header .header-left { display: grid; gap: 4px; }
#page-plugins > .plugins-header .header-right { justify-self: end; }

header h1 {
  margin: 0 0 6px 0;
}

header p {
  margin: 0;
  color: var(--muted);
}

main {
  padding: 0;
}

.plugins {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 12px;
  padding: 10px 20px 20px;
}

/* 图标视图 */
.plugins.icons-view {
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 16px;
}
.plugin-tile {
  display: grid;
  grid-template-rows: 1fr auto;
  place-items: center;
  border: 1px solid var(--border);
  background: var(--panel);
  border-radius: 10px;
  padding: 16px 10px;
  cursor: default;
  transition: border-color .2s ease, background .2s ease, box-shadow .2s ease;
  position: relative;
}
.plugin-tile:hover {
  border-color: rgba(34, 197, 94, 0.45);
  background: rgba(34, 197, 94, 0.08);
  box-shadow: 0 8px 24px rgba(0,0,0,0.35);
}
.plugin-tile .tile-icon i {
  font-size: 34px;
  color: #ffffff;
}
.plugin-tile .tile-label {
  margin-top: 8px;
  font-size: 13px;
  text-align: center;
  color: var(--fg);
}
.plugin-tile.disabled .tile-icon i { color: #94a3b8; opacity: 0.6; }
.plugin-tile.disabled .tile-label { color: #94a3b8; }
.plugin-tile .tile-status { position: absolute; top: 8px; right: 8px; font-size: 11px; color: #ffffff; border: 1px solid var(--border); border-radius: 999px; padding: 2px 6px; background: rgba(220, 38, 38, 0.35); }

/* 通用设置表单 */
.form {
  display: grid;
  gap: 8px;
}

.field {
  display: grid;
  gap: 6px;
}

.field label {
  color: var(--muted);
}

.options {
  display: inline-flex;
  gap: 0;
  flex-wrap: nowrap;
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
}

.options input[type=radio] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.options label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border: none;
  border-radius: 0;
  background: rgba(255, 255, 255, 0.06);
  color: var(--fg);
  cursor: pointer;
  user-select: none;
}

.options label:not(:last-of-type) {
  border-right: 1px solid var(--border);
}

.options label:hover {
  background: rgba(255, 255, 255, 0.09);
}

.options input[type=radio]:focus+label {
  outline: 2px solid rgba(34, 197, 94, 0.6);
  outline-offset: -2px;
}

.options input[type=radio]:checked+label {
  background: rgba(34, 197, 94, 0.18);
}

.inline {
  display: flex;
  gap: 8px;
  align-items: center;
}

.inline input {
  flex: 1;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.04);
  color: var(--fg);
  padding: 8px;
}

.muted {
  color: var(--muted);
  font-size: 12px;
}

.array-list {
  display: grid;
  gap: 8px;
}

.array-item {
  display: grid;
  grid-template-columns: 1fr 1fr auto;
  gap: 8px;
  align-items: center;
}

/* 动作选择列表（满宽、固定高度区域滚动） */
.action-list {
  display: grid;
  gap: 8px;
}

.action-item {
  display: grid;
  grid-template-columns: auto auto 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.04);
  border-radius: 8px;
}

.action-item i {
  font-size: 18px;
}

.action-item:hover {
  border-color: rgba(34, 197, 94, 0.45);
  background: rgba(34, 197, 94, 0.12);
}

.array-item input {
  border-radius: 8px;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.04);
  color: var(--fg);
  padding: 8px;
}

/* 参数编辑对话框下拉框优化 */
.array-item select {
  border-radius: 8px;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.04);
  color: var(--fg);
  padding: 8px;
  min-width: 140px;
}

/* 参数编辑对话框内容区域统一内边距 */
.modal-box .modal-body,
.modal-box .muted,
.modal-box .array-actions,
.modal-box .modal-desc,
.modal-box .array-list {
  padding-left: 16px;
  padding-right: 16px;
}

.modal-desc {
  margin-top: 15px;
}

.array-item button {
  background: rgba(220, 38, 38, 0.25);
  color: #fff;
  border: none;
  border-radius: 6px;
  padding: 6px 10px;
  cursor: pointer;
}

.array-actions {
  display: flex;
  gap: 8px;
  margin-top: 8px;
}

.plugin-card {
  border: 1px solid var(--border);
  background: var(--panel);
  border-radius: 10px;
  display: flex;
  flex-direction: column;
  overflow: visible;
}

.card-header {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 12px;
}

.card-header i {
  font-size: 20px;
  color: var(--accent);
}

.card-title {
  font-weight: 400;
}

.card-desc {
  color: var(--muted);
  font-size: 13px;
}

.card-body {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 12px 12px;
}

/* 插件卡片操作区：左侧为操作提示或按钮，右侧为卸载按钮 */
.card-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 0 12px 12px;
}

.card-actions .muted {
  color: var(--muted);
}

/* 自动执行页面 */
.automation {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 12px;
  padding: 12px 0 20px;
  height: 90%;
  overflow: hidden;
  /* 避免触发页面滚动，由内部区域滚动 */
}

.auto-left {
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.04);
  border-radius: 10px;
  overflow: hidden;
  /* 由列表区域滚动 */
  display: flex;
  flex-direction: column;
  height: 100%;
}

.auto-topbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  padding: 10px;
  border-bottom: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.06);
}

.auto-list {
  display: block;
  padding: 10px;
  overflow-y: auto;
  /* 左侧列表独立滚动 */
  flex: 1;
  min-height: 0;
  /* 允许在 flex 容器中收缩以产生滚动 */
}

.auto-item {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  margin-bottom: 5px;
  align-items: center;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.03);
  padding: 8px 10px;
  cursor: pointer;
}

.auto-item:hover {
  background: rgba(255, 255, 255, 0.06);
}

/* 已移除全局安装进度展示（global-progress）相关样式 */

.auto-item .title {
  font-weight: 600;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.auto-item .desc {
  color: var(--muted);
  font-size: 12px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.auto-item .actions {
  display: flex;
  align-items: center;
  gap: 6px;
}

.auto-item .toggle {
  margin-left: 6px;
}

/* 允许左侧文本容器在网格中收缩以启用省略号 */
.auto-item>div:first-child {
  min-width: 0;
}

.auto-right {
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.04);
  border-radius: 10px;
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
  /* 由编辑器区域滚动 */
}

.auto-editor-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
  position: sticky;
  /* 右侧顶栏固定，以下区域滚动 */
  top: 0;
  z-index: 2;
  background: rgba(255, 255, 255, 0.06);
  backdrop-filter: blur(2px);
  border-bottom: 1px solid var(--border);
  padding-bottom: 8px;
}

.auto-editor>.section {
  padding: 16px;
  margin: 10px;
}

.auto-editor .field-row {
  display: grid;
  gap: 6px;
  margin: 8px 0;
}

.auto-editor .field-row label {
  color: var(--muted);
}

.auto-editor input[type="text"],
.auto-editor input[type="number"],
.auto-editor input[type="time"],
.auto-editor select,
.auto-editor textarea {
  border-radius: 8px;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.04);
  color: var(--fg);
  padding: 6px 8px;
}

.auto-editor input[type="time"] {
  padding: 0px 8px;
}

.auto-editor select:focus-visible,
.auto-editor input:focus-visible {
  outline: 2px solid #0f1318;
  /* 自定义键盘焦点样式 */
}

.auto-editor textarea {
  min-height: 80px;
}

/* 右侧编辑器为可滚动区域（除顶栏） */
.auto-editor {
  overflow-y: auto;
  flex: 1;
  min-height: 0;
}
/* 右侧空状态容器：应用内边距与弱化颜色 */
.auto-editor-empty {
  margin: 10px;
  padding: 12px 16px;
  color: var(--muted);
}

/* 自动化页面占满内容区高度，禁用全局滚动影响 */
#page-automation {
  display: flex;
  flex-direction: column;
  height: calc(100vh - 34px);
  /* 与 #content 高度一致，避免页面滚动 */
  overflow: hidden;
}

#page-automation .automation.panel {
  flex: 1;
  overflow: hidden;
  margin: 0 20px 20px 20px;
}

/* 滚动条样式统一至全局规则（见上方全局滚动条样式） */

/* --- 修复自动化页面隐藏与高度布局、优化样式（覆盖前面规则） --- */

/* 当存在 hidden 属性时强制隐藏（避免被 display 覆盖） */
#page-automation[hidden] {
  display: none !important;
}

/* 仅在可见时参与布局：采用两行网格，header 自适应，高度精确填充 */
#page-automation:not([hidden]) {
  display: grid;
  grid-template-rows: auto 1fr;
  height: calc(100vh - 34px);
  overflow: hidden;
}

/* 面板作为第二行填满，并允许内部滚动区正确收缩 */
#page-automation .automation.panel {
  min-height: 0;
  overflow: hidden;
}

/* 自动执行筛选条外观优化 */
.auto-filters {
  padding: 8px 10px;
  background: rgba(255, 255, 255, 0.06);
  border: none;
  border-radius: 0;
}

/* 左侧列表：统一每项高度，避免视觉错乱 */
.auto-list {
  grid-auto-rows: minmax(56px, auto);
}

/* 右侧编辑器顶栏：优化间距与输入扩展，保持粘性顶部 */
.auto-editor-header {
  gap: 10px;
  margin-bottom: 10px;
  padding: 10px 12px;
}

.auto-editor-header input[type="text"] {
  flex: 1;
  min-width: 0;
}

/* 下拉框（Select）深色样式与选中项颜色 */
select,
.auto-editor select {
  background: #2f3137;
  color: var(--fg);
  border: 1px solid var(--border);
  border-radius: 8px;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.04);
  color: var(--fg);
  padding: 6px 8px;
}

select:focus {
  outline: none;
  border-color: var(--border);
  box-shadow: none;
}

select option {
  background: #121621;
  color: var(--fg);
}

select option:hover {
  background: rgba(34, 197, 94, 0.15);
}

select option:checked,
select option:selected {
  background: rgba(34, 197, 94, 0.25);
  color: var(--fg);
}

/* 自绘提示框（Alert/Confirm） */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  backdrop-filter: blur(2px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
}

.modal-box {
  width: 480px;
  max-width: 92vw;
  max-height: 85vh;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: #1b1f2a;
  color: #e5e7eb;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.5);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.modal-title {
  font-weight: 600;
  margin-bottom: 8px;
  border-radius: 12px 12px 0 0;
}

.modal-message {
  color: #cbd5e1;
  white-space: pre-wrap;
  padding: 20px;
}
.modal-message.compact { padding: 0; }
.modal-box.config-wide-modal { width: 900px; max-width: 94vw; }

/* 统一模态内容区域为可滚动，避免内容溢出容器 */
.modal-body {
  padding: 16px;
  overflow: auto;
}

.modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 12px;
  padding: 16px;
}

.theme-dark body,
:root.theme-dark body {
  background: #0f1115;
  color: #e5e7eb;
}

.theme-dark .layout,
:root.theme-dark .layout {
  background: transparent;
}

.theme-dark .sidebar,
:root.theme-dark .sidebar {
  background: #121621;
  border-color: #2a2f3a;
}

.theme-dark .panel,
:root.theme-dark .panel {
  background: rgba(255, 255, 255, 0.04);
  border-color: #2a2f3a;
}

.theme-dark .titlebar,
:root.theme-dark .titlebar {
  background: #121621;
  border-bottom-color: #2a2f3a;
}

.theme-light body,
:root.theme-light body {
  background: #f3f4f6;
  color: #1f2937;
}

.theme-light .layout,
:root.theme-light .layout {
  background: transparent;
}

.theme-light .sidebar,
:root.theme-light .sidebar {
  background: #ffffff;
  border-color: #e5e7eb;
}

.theme-light .panel,
:root.theme-light .panel {
  background: #ffffff;
  border-color: #e5e7eb;
}

.theme-light .titlebar,
:root.theme-light .titlebar {
  background: #ffffff;
  border-bottom-color: #e5e7eb;
}

.theme-light .btn.primary,
:root.theme-light .btn.primary {
  background: var(--accent);
  border-color: transparent;
  color: #fff;
}

.theme-light .btn.secondary,
:root.theme-light .btn.secondary {
  background: rgba(0, 0, 0, 0.05);
  border-color: #e5e7eb;
  color: #1f2937;
}

.theme-light .btn.danger,
:root.theme-light .btn.danger {
  background: #dc2626;
  border-color: transparent;
  color: #fff;
}

.theme-light header h1,
.theme-light .setting-title,
.theme-light .card-title,
.theme-light .section-title,
.theme-light .auto-item .title,
:root.theme-light header h1,
:root.theme-light .setting-title,
:root.theme-light .card-title,
:root.theme-light .section-title,
:root.theme-light .auto-item .title {
  color: #1f2937;
}

.theme-light .setting-desc,
.theme-light .card-desc,
.theme-light .auto-item .desc,
.theme-light label,
:root.theme-light .setting-desc,
:root.theme-light .card-desc,
:root.theme-light .auto-item .desc,
:root.theme-light label {
  color: #6b7280;
}

.theme-light .muted,
:root.theme-light .muted {
  color: #6b7280;
}

.theme-light .site-topbar,
:root.theme-light .site-topbar {
  background: #ffffff;
  border-bottom-color: #e5e7eb;
}

.theme-light .modal-box,
.theme-light .modal-dialog,
:root.theme-light .modal-box,
:root.theme-light .modal-dialog {
  background: #ffffff;
  color: #1f2937;
}

.theme-light select option,
:root.theme-light select option {
  background: #ffffff;
  color: #1f2937;
}

.theme-light .auto-editor input[type="text"],
.theme-light .auto-editor input[type="number"],
.theme-light .auto-editor input[type="time"],
.theme-light .auto-editor select,
.theme-light .auto-editor textarea,
:root.theme-light .auto-editor input[type="text"],
:root.theme-light .auto-editor input[type="number"],
:root.theme-light .auto-editor input[type="time"],
:root.theme-light .auto-editor select,
:root.theme-light .auto-editor textarea {
  background: rgba(0, 0, 0, 0.05);
  color: #1f2937;
  border-color: #e5e7eb;
}

.theme-light .overflow-menu,
:root.theme-light .overflow-menu {
  background: #ffffff;
}

.theme-light .app-menu,
:root.theme-light .app-menu {
  background: #ffffff;
}

.theme-light .editor-textarea,
:root.theme-light .editor-textarea {
  background: #f3f4f6;
  color: #1f2937;
}

.theme-light .docs-sidebar,
:root.theme-light .docs-sidebar {
  background: #ffffff;
  border-color: #e5e7eb;
}

.theme-light .docs-toolbar,
:root.theme-light .docs-toolbar {
  background: #ffffff;
  border-color: #e5e7eb;
}

.theme-light .res-item,
:root.theme-light .res-item {
  background: #f3f4f6;
  border-color: #e5e7eb;
}

.theme-light .admin-tabs,
:root.theme-light .admin-tabs {
  border-bottom-color: #e5e7eb;
}

.theme-light .admin-tab,
:root.theme-light .admin-tab {
  color: #6b7280;
}

.theme-light .admin-tab:hover,
:root.theme-light .admin-tab:hover {
  background: rgba(0, 0, 0, 0.05);
}

.theme-light .admin-tab.active,
:root.theme-light .admin-tab.active {
  color: var(--accent);
}

.theme-light .upload-card,
.theme-light .form-group input,
.theme-light .form-group select,
:root.theme-light .upload-card,
:root.theme-light .form-group input,
:root.theme-light .form-group select {
  background: #ffffff;
  border-color: #e5e7eb;
  color: #1f2937;
}

.theme-light .file-drop-zone,
:root.theme-light .file-drop-zone {
  background: #f3f4f6;
  border-color: #e5e7eb;
}

.btn.primary {
  background: var(--accent);
  border-color: transparent;
  color: #fff;
}

.btn.secondary {
  background: rgba(255, 255, 255, 0.06);
  border-color: #2a2f3a;
  color: #e5e7eb;
}

.btn.danger {
  background: #dc2626;
  border-color: transparent;
  color: #fff;
}



header h1,
.setting-title,
.card-title,
.section-title,
.auto-item .title {
  color: #e5e7eb;
}

.setting-desc,
.card-desc,
.auto-item .desc,
label {
  color: #cbd5e1;
}

.muted {
  color: #94a3b8;
}

.section {
  margin-top: 10px;
  padding-top: 8px;
  /* border-top: 1px dashed var(--border); */
  border-radius: 12px;
  background: var(--panel);
  border: 1px solid var(--border);
  padding: 16px;
}

.section .section-title {
  font-weight: 600;
  margin-bottom: 6px;
  display: flex;
  align-items: center;
  gap: 6px;
}

/* 模态框内的辅文不加左侧缩进，保持紧凑排版 */
.modal-body .muted {
  margin-left: 0 !important;
  padding-left: 0 !important;
}

/* hidden 属性应强制隐藏，即使后续有 display 覆盖 */
[hidden], .chips[hidden], .auto-filters[hidden] {
  display: none !important;
}

.chips {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
/* 两组筛选换行后的间距 */
.auto-filters .chips + .chips {
  margin-top: 6px;
}

.chip {
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 4px 8px;
  font-size: 12px;
  color: var(--muted);
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}
.chips .chip:hover {
  background: rgba(255, 255, 255, 0.06);
  color: var(--fg);
}
.chips .chip.selected {
  background: rgba(34, 197, 94, 0.18);
  border-color: rgba(34, 197, 94, 0.45);
  color: var(--fg);
}

.group {
  border: 1px dashed var(--border);
  border-radius: 8px;
  padding: 8px;
  margin: 6px 0;
}

.group-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}

.cond-row {
  display: grid;
  grid-template-columns: 160px 1fr auto auto;
  gap: 6px;
  align-items: center;
  margin: 4px 0;
}

.cond-row .negate {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.cond-row .del {
  color: #fca5a5;
  cursor: pointer;
}

.action-row {
  display: grid;
  grid-template-columns: 160px 1fr auto;
  gap: 6px;
  align-items: center;
  margin: 6px 0;
}

.action-row .del {
  color: #fca5a5;
  cursor: pointer;
}

.card-actions {
  border-top: 1px dashed var(--border);
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 8px;
}

.action-btn {
  background: #15803d;
  color: white;
  border: none;
  border-radius: 6px;
  padding: 6px 10px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.action-btn:hover {
  background: #1a8f46;
}

/* 滑块开关 */
.toggle {
  position: relative;
  width: 42px;
  height: 24px;
  display: inline-block;
}

.toggle input {
  display: none;
}

.toggle .slider {
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid var(--border);
  border-radius: 999px;
  transition: .2s;
}

.toggle .slider:before {
  content: '';
  position: absolute;
  left: 2px;
  top: 2px;
  width: 18px;
  height: 18px;
  background: var(--fg);
  border-radius: 50%;
  transition: .2s;
}

.toggle input:checked+.slider {
  background: rgba(34, 197, 94, 0.25);
  border-color: rgba(34, 197, 94, 0.45);
}

.toggle input:checked+.slider:before {
  transform: translateX(18px);
  background: #22c55e;
}

/* 通用设置项布局 */
.setting-item {
  display: grid;
  grid-template-columns: 32px 1fr auto;
  align-items: center;
  gap: 12px;
  border: 1px solid var(--border);
  background: var(--panel);
  border-radius: 10px;
  padding: 10px 12px;
}

.setting-icon {
  margin-left: 5px
}

.setting-icon i {
  color: var(--accent);
  font-size: 20px;
}

.setting-title {
  font-weight: 200;
}

.setting-desc {
  color: var(--muted);
  font-size: 13px;
}

.setting-main {
  display: grid;
  gap: 6px;
}

.setting-action {
  display: flex;
  align-items: center;
  gap: 8px;
}

/* 新版开关控件（与.toggle一致的外观） */
.switch {
  position: relative;
  width: 42px;
  height: 24px;
  display: inline-block;
}

.switch input {
  display: none;
}

.switch .slider {
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid var(--border);
  border-radius: 999px;
  transition: .2s;
}

.switch .slider:before {
  content: '';
  position: absolute;
  left: 2px;
  top: 2px;
  width: 18px;
  height: 18px;
  background: var(--fg);
  border-radius: 50%;
  transition: .2s;
}

.switch input:checked+.slider {
  background: rgba(34, 197, 94, 0.25);
  border-color: rgba(34, 197, 94, 0.45);
}

.switch input:checked+.slider:before {
  transform: translateX(18px);
  background: #22c55e;
}

.panel {
  border: 1px solid var(--border);
  background: var(--panel);
  border-radius: 10px;
  padding: 12px;
  margin: 20px;
}

/* 自定义标题栏 */
.titlebar {
  position: sticky;
  top: 0;
  height: 34px;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  padding: 0 0 0 8px;
  border-bottom: 1px solid var(--border);
  /* 不显示后方文字，使用不透明背景 */
  z-index: 5;
}

.titlebar .drag {
  -webkit-app-region: drag;
  height: 100%;
  line-height: 34px;
}

.window-actions {
  display: flex;
  gap: 0;
  height: 100%;
}

.win-btn {
  -webkit-app-region: no-drag;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  color: var(--fg);
  border: none;
  border-radius: 0;
  width: 38px;
  height: 100%;
  cursor: pointer;
}

.win-btn:hover,
.win-btn:active {
  background: rgba(255, 255, 255, 0.08);
}

.win-btn.close:hover,
.win-btn.close:active {
  background: #E81123;
  color: #fff;
}

.win-btn {
  font-size: 18px;
}

.win-btn.max {
  font-size: 13px;
}

/* NPM 页面 */
.npm-search {
  display: flex;
  gap: 8px;
}

.npm-search input {
  flex: 1;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.04);
  color: var(--fg);
  padding: 8px;
}

.npm-versions {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}

.npm-installed {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 16px;
}

.pkg {
  border: 1px solid var(--border);
  background: var(--panel);
  border-radius: 8px;
  padding: 8px;
}

.pkg-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 6px;
}

.pkg-name i {
  color: var(--accent);
  margin-right: 6px;
}

.versions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.pill {
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 4px 8px;
  font-size: 12px;
  margin-top: 5px;
}

/* 版本徽标：更紧凑并与标题对齐 */
.pill.small {
  font-size: 11px;
  padding: 2px 6px;
}

/* 依赖满足/不满足标签样式 */
.pill.ok {
  background: rgba(46, 204, 113, 0.25);
  border-color: rgba(46, 204, 113, 0.6);
}
.pill.danger {
  background: rgba(231, 76, 60, 0.25);
  border-color: rgba(231, 76, 60, 0.6);
}

.card-title .plugin-version {
  margin-left: 0px;
  vertical-align: middle;
  opacity: 0.85;
  font-size: 8px;
}

.version-item {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 8px;
  align-items: center;
  border: 1px solid var(--border);
  background: var(--panel);
  border-radius: 8px;
  padding: 8px;
}

.version-actions button {
  background: #15803d;
  color: white;
  border: none;
  border-radius: 6px;
  padding: 6px 10px;
  cursor: pointer;
}

/* 通用设置子夹导航 */
.subnav {
  display: flex;
  gap: 8px;
  padding: 0 20px;
}

.sub-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(255, 255, 255, 0.04);
  color: var(--fg);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 8px 12px;
  cursor: pointer;
}

.sub-item.active {
  background: rgba(34, 197, 94, 0.15);
  border-color: rgba(34, 197, 94, 0.35);
}

/* 条件行与状态指示 */
.cond-row {
  display: flex;
  align-items: center;
  gap: 8px;
}

.cond-row select,
.cond-row input {
  height: 28px;
}

.cond-status {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--muted);
  display: inline-block;
}

.cond-status.ok {
  background: #22c55e;
}

.cond-status.fail {
  background: #ef4444;
}

/* 条件编辑器容器与多选样式 */
.cond-editor {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  align-items: center;
}

.cond-editor .chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.cond-editor .chip.selected {
  background: rgba(34, 197, 94, 0.18);
  border-color: rgba(34, 197, 94, 0.45);
  color: var(--fg);
}

.editor-summary {
  color: var(--muted);
  font-size: 12px;
  margin-left: 8px;
  max-width: 280px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}


/* 全局移除输入框选中后的黄色边框（不影响键盘 focus-visible 样式） */
input:focus,
textarea:focus,
select:focus {
  outline: none;
  box-shadow: none;
  border-color: var(--border);
}

/* 覆盖插件卡片操作区：固定在卡片底部并左右分布 */
.plugin-card {
  display: flex;
  flex-direction: column;
}

.plugin-card .card-actions {
  margin-top: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px;
  border-top: 1px dashed var(--border);
}

.plugin-card .card-actions .muted {
  color: var(--muted);
}

/* 右侧小图标按钮，无文字无背景，仅图标 */
.icon-btn {
  background: transparent;
  border: none;
  color: var(--muted);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 6px;
}

.icon-btn i {
  font-size: 18px;
}

.icon-btn:hover {
  color: var(--accent);
}

/* 激活态为绿色（点击按下时） */
.icon-btn:active {
  color: #22c55e;
  background: rgba(34, 197, 94, 0.15);
}

/* 快捷方式预览对话框样式 */
.form-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 8px 0;
}

.form-row input[type="text"] {
  flex: 1;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.04);
  color: var(--fg);
  padding: 6px 8px;
}

.color-input {
  width: 40px;
  height: 28px;
  padding: 0;
  border-radius: 6px;
  border: 1px solid var(--border);
  background: transparent;
}

.shortcut-preview-grid {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 12px;
  align-items: start;
  margin-top: 8px;
  grid-auto-flow: dense;
}

.shortcut-preview-grid .preview-meta {
  overflow-x: hidden;
}

.preview-square {
  width: 160px;
  height: 160px;
  border-radius: 20px;
  background: #0b1221;
  display: grid;
  place-items: center;
  border: 1px solid var(--border);
  display: none;
}

.preview-square i {
  font-size: 72px;
  color: #fff;
}

.preview-meta {
  word-break: break-all;
}

.preview-meta .muted {
  margin-bottom: 8px;
}

.preview-canvas {
  width: min(200px, 100%);
  height: auto;
  aspect-ratio: 1 / 1;
  background: transparent;
  display: block;
  grid-column: 1;
  justify-self: center;
}

/* 响应式：窄屏下栅格改为单列，并保证宽度适配 */
@media (max-width: 560px) {
  .modal-box {
    width: 95vw;
  }

  .shortcut-preview-grid {
    grid-template-columns: 1fr;
  }

  .preview-square {
    margin: 0 auto;
  }
}

/* 关于页面样式 */
.about-hero {
  display: grid;
  grid-template-columns: 64px 1fr auto;
  align-items: center;
  gap: 12px;
}

.about-logo {
  width: 64px;
  height: 64px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid var(--border);
}

.about-title .name {
  font-weight: 600;
  font-size: 18px;
}

.about-title .tagline {
  color: var(--muted);
  font-size: 13px;
}

.about-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: flex-end;
}

.about-links {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 10px;
}

.about-links .spacer {
  flex: 1;
}

.about-links a {
  color: var(--fg);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.about-links a:not(.btn):hover {
  color: var(--accent);
}

.contributors-list {
  list-style: none;
  padding: 0;
  margin: 6px 0;
  display: grid;
  gap: 6px;
}

.contributors-list li {
  border: 1px solid var(--border);
  background: var(--panel);
  border-radius: 8px;
  padding: 8px 10px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.contributors-list .name {
  font-weight: 600;
}

/* 横向卡片布局（头像-名字-角色） */
.contributors-list.horizontal {
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 10px;
}

.contributors-list.horizontal li {
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  text-align: center;
  padding: 12px;
  gap: 6px;
}

.contributors-list.horizontal .avatar {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
}

.contributors-list.horizontal .avatar i {
  font-size: 28px;
}

.contributors-list.horizontal .name {
  font-weight: 600;
  margin-top: 6px;
}

.contributors-list.horizontal .role {
  color: var(--muted);
  font-size: 12px;
}

/* ===== Market modal and filters tweaks ===== */
.modal-box.market-plugin { width: 760px; max-width: 85vw; }
.modal-readme { overflow-x: hidden; word-break: break-word; white-space: normal; }
.modal-readme img { max-width: 100%; height: auto; }
#page-market .store-left .section-title { margin-bottom: 14px; }
#page-market #store-subnav .sub-item { background: transparent; border: 1px solid transparent; }
#page-market #store-subnav .sub-item:hover { background: rgba(255,255,255,0.06); border-color: var(--border); }
#page-market #store-subnav .sub-item.active { background: rgba(34,197,94,0.18); border-color: rgba(34,197,94,0.45); }
/* 市场页：左侧隐藏时让右侧占满 */
#page-market .store-panel.compact {
  grid-template-columns: 1fr !important;
}

/* 市场卡片按钮使用白色，不影响全局 */
#page-market .store-card .btn,
#page-market .store-card .btn.primary,
#page-market .store-card .btn.secondary,
#page-market .store-card .btn i {
  color: white !important
}

/* ---- 追加规则：满宽设置项与插件操作区溢出菜单 ---- */

/* 满宽设置项：无图标/动作列，主体占满整行 */
.setting-item.full {
  grid-template-columns: 1fr;
}
.setting-item.full .setting-icon,
.setting-item.full .setting-action {
  display: none;
}

/* 插件卡片操作区左右两侧容器与溢出处理 */
.card-actions .actions-left {
  display: flex;
  align-items: center;
  gap: 8px;
  overflow: visible;
  flex: 1;
  min-width: 0;
  position: relative;
}
.card-actions .actions-right {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

/* 溢出菜单（更多操作） */
.overflow-menu {
  position: absolute;
  z-index: 50;
  min-width: 160px;
  border: 1px solid var(--border);
  background: #1b1f2a; /* 使用不透明背景，避免透出卡片内容 */
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.45);
  padding: 8px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  right: 0;
  top: calc(100% + 6px);
  display: none;
}
.overflow-menu.overflow-open { display: flex; }

/* 溢出菜单中的按钮使用同样的按钮样式，并占满宽度 */
.overflow-menu .action-btn { width: 100%; background: #1f2937; }

/* 插件动作按钮统一高度与不换行，避免缩窄时增高 */
.plugin-card .card-actions .action-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
  height: 28px;
  line-height: 28px;
  padding: 0 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.06);
  color: var(--fg);
}
.plugin-card .card-actions .action-btn i { font-size: 16px; }

/* 展开按钮使用文字提示“展开操作”，在窄宽度更友好 */
.plugin-card .card-actions .icon-btn.more-btn.text {
  width: auto;
  padding: 0 10px;
  gap: 6px;
  color: var(--fg);
  background: #1f2937;
  border: 1px solid var(--border);
}
.plugin-card .card-actions .icon-btn.more-btn.text i { font-size: 16px; }
.site-topbar {
  position: sticky;
  top: 0;
  height: 44px;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 12px;
  background: #121621;
  border-bottom: 1px solid #2a2f3a;
  z-index: 10;
}
.site-logo img { width: 28px; height: 28px; }
.site-title { font-weight: 600; display: flex; align-items: center; gap: 6px; }
.site-nav { display: flex; gap: 12px; margin-left: 12px; }
.topnav-item { background: transparent; border: none; color: var(--fg); padding: 6px 8px; border-radius: 6px; cursor: pointer; display: inline-flex; align-items: center; gap: 6px; }
.topnav-item i { color: var(--fg); font-size: 16px; }
.topnav-item.active { color: var(--accent); }
.topnav-item.active i { color: var(--accent); }
a.topnav-item { text-decoration: none; }
.site-actions { margin-left: auto; display: flex; gap: 8px; }
.status { color: var(--muted); font-size: 12px; }
.about-logo { width: 36px; height: 36px; }
.store-tabs .sub-item { background: transparent; border: 1px solid var(--border); color: var(--fg); }
.store-tabs .sub-item.active { background: rgba(34, 197, 94, 0.18); color: var(--accent); border-color: rgba(34, 197, 94, 0.45); }
.store-tabs .sub-item.active:hover { background: rgba(34, 197, 94, 0.18); }
.store-tabs .sub-item:hover { background: rgba(255,255,255,0.06); }
.plugin-card { border: 1px solid var(--border); background: var(--panel); border-radius: 10px; transition: border-color .2s ease, background .2s ease, box-shadow .2s ease; }
.plugin-card:hover { border-color: rgba(34, 197, 94, 0.45); background: rgba(34, 197, 94, 0.08); box-shadow: 0 8px 24px rgba(0,0,0,0.35); }
.entry-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 8px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.06);
  color: var(--fg);
  text-decoration: none;
  word-break: break-all;
}
.entry-link i { color: var(--accent); }
.entry-link:hover { background: rgba(255, 255, 255, 0.09); }

/* 自绘应用菜单 */
.app-menu-overlay { position: fixed; inset: 0; z-index: 2000; background: transparent; }
.app-menu { position: absolute; min-width: 200px; background: #1b1f2a; border: 1px solid var(--border); border-radius: 8px; box-shadow: 0 8px 24px rgba(0,0,0,0.45); padding: 6px 4px; max-height: 70vh; overflow-y: auto; overflow-x: hidden; }
.app-menu-item { display: flex; align-items: center; gap: 8px; padding: 8px 12px; color: var(--fg); cursor: pointer; border-radius: 6px; }
.app-menu-item i { font-size: 18px; }
.app-menu-item:hover { background: rgba(255, 255, 255, 0.06); }
.app-menu-sep { height: 1px; margin: 4px; background: var(--border); }
.config-editor input[type="text"],
.config-editor input[type="number"],
.config-editor select,
.config-editor textarea {
  border-radius: 8px;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.04);
  color: var(--fg);
  padding: 6px 8px;
}

.config-editor textarea { min-height: 80px; }

.config-editor select:focus-visible,
.config-editor input:focus-visible,
.config-editor textarea:focus-visible {
  outline: 2px solid #0f1318;
}
.config-editor {
  max-height: 60vh;
  overflow-y: auto;
  overflow-x: hidden;
}
.config-editor .setting-item {
  grid-template-columns: 32px 1fr minmax(180px, 40%);
}
.config-editor .setting-action {
  min-width: 0;
  margin-left: auto;
}
.config-editor .setting-action input,
.config-editor .setting-action select,
.config-editor .setting-action textarea { width: 100%; }
.config-editor textarea { resize: vertical; }
.json-editor { display: grid; gap: 6px; }
.json-node { border: 1px solid var(--border); background: rgba(255,255,255,0.04); border-radius: 8px; padding: 8px; }
.json-header { display: flex; align-items: center; gap: 8px; }
.json-key { font-weight: 600; }
.json-children { margin-top: 6px; padding-left: 12px; }
.json-toggle { width: 24px; height: 24px; }

/* 可选择文本区域 */
#page-about, #page-about * { user-select: text !important; -webkit-user-select: text !important; }
.modal-box.plugin-about .modal-body,
.modal-box.component-about .modal-body,
.config-editor,
.config-editor *,
.json-editor,
.json-editor * { user-select: text !important; -webkit-user-select: text !important; }
