:root {
  color-scheme: dark;
  --bg: #0b1020;
  --panel: rgba(16, 23, 42, 0.78);
  --panel-border: rgba(148, 163, 184, 0.16);
  --panel-strong: rgba(30, 41, 59, 0.92);
  --text: #e5edf7;
  --muted: #94a3b8;
  --accent: #22c55e;
  --accent-strong: #16a34a;
  --accent-soft: rgba(34, 197, 94, 0.14);
  --warning: #f59e0b;
  --danger: #ef4444;
  --neutral: #38bdf8;
  --shadow: 0 20px 60px rgba(0, 0, 0, 0.28);
}

:root[data-theme="light"] {
  color-scheme: light;
  --bg: #eef4ff;
  --panel: rgba(255, 255, 255, 0.84);
  --panel-border: rgba(71, 85, 105, 0.18);
  --panel-strong: rgba(248, 250, 252, 0.94);
  --text: #132036;
  --muted: #64748b;
  --accent: #0f9f6e;
  --accent-strong: #047857;
  --accent-soft: rgba(16, 185, 129, 0.16);
  --neutral: #0369a1;
  --shadow: 0 20px 48px rgba(15, 23, 42, 0.16);
}

:root[data-theme="contrast"] {
  color-scheme: dark;
  --bg: #020617;
  --panel: rgba(2, 6, 23, 0.92);
  --panel-border: rgba(250, 204, 21, 0.42);
  --panel-strong: rgba(15, 23, 42, 0.98);
  --text: #f8fafc;
  --muted: #d1d5db;
  --accent: #facc15;
  --accent-strong: #eab308;
  --accent-soft: rgba(250, 204, 21, 0.18);
  --neutral: #67e8f9;
  --shadow: 0 24px 70px rgba(0, 0, 0, 0.46);
}

* {
  box-sizing: border-box;
}

[hidden],
.advanced-field-hidden {
  display: none !important;
}

body {
  margin: 0;
  min-height: 100vh;
  font-family: "Microsoft YaHei UI", "HarmonyOS Sans SC", "Segoe UI", sans-serif;
  background:
    radial-gradient(circle at top left, rgba(34, 197, 94, 0.18), transparent 24%),
    radial-gradient(circle at top right, rgba(56, 189, 248, 0.14), transparent 26%),
    linear-gradient(135deg, #08111f 0%, #101b34 48%, #07111d 100%);
  color: var(--text);
}

:root[data-theme="light"] body {
  background:
    radial-gradient(circle at top left, rgba(16, 185, 129, 0.2), transparent 24%),
    radial-gradient(circle at top right, rgba(14, 165, 233, 0.16), transparent 26%),
    linear-gradient(135deg, #f8fbff 0%, #e7f0ff 48%, #eefdf6 100%);
}

:root[data-theme="contrast"] body {
  background:
    radial-gradient(circle at top left, rgba(250, 204, 21, 0.22), transparent 22%),
    radial-gradient(circle at top right, rgba(103, 232, 249, 0.18), transparent 24%),
    linear-gradient(135deg, #000 0%, #020617 52%, #050505 100%);
}

.shell {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 24px;
  padding: 24px;
}

.sidebar,
.workspace {
  display: grid;
  gap: 24px;
}

.brand,
.panel,
.hero {
  backdrop-filter: blur(18px);
  border: 1px solid var(--panel-border);
  box-shadow: var(--shadow);
}

.brand,
.panel {
  border-radius: 24px;
  background: var(--panel);
}

.brand {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 20px;
}

.brand-badge {
  display: grid;
  place-items: center;
  width: 52px;
  height: 52px;
  border-radius: 16px;
  background: linear-gradient(135deg, var(--accent), #0ea5e9);
  color: #041018;
  font-size: 24px;
  font-weight: 800;
}

.brand h1,
.hero h2,
.panel h2 {
  margin: 0;
}

.brand p,
.hero-copy,
.eyebrow,
.feature-list,
.status-list dt {
  color: var(--muted);
}

.panel,
.hero {
  padding: 20px;
}

.hero {
  border-radius: 28px;
  background:
    linear-gradient(135deg, rgba(34, 197, 94, 0.14), rgba(56, 189, 248, 0.08)),
    var(--panel-strong);
}

.eyebrow {
  margin: 0 0 8px;
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.hero-copy {
  max-width: 70ch;
  line-height: 1.7;
}

.hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(260px, 0.8fr);
  gap: 20px;
  align-items: stretch;
}

.hero-highlights {
  display: grid;
  gap: 12px;
}

.hero-stat {
  display: grid;
  gap: 8px;
  padding: 16px;
  border-radius: 18px;
  background: rgba(4, 11, 24, 0.42);
  border: 1px solid rgba(148, 163, 184, 0.12);
}

.hero-stat span {
  font-size: 12px;
  color: var(--muted);
}

.hero-stat strong {
  font-size: 18px;
}

.section-nav {
  position: sticky;
  top: 18px;
  z-index: 8;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  background:
    linear-gradient(135deg, rgba(34, 197, 94, 0.08), rgba(56, 189, 248, 0.06)),
    var(--panel);
}

.nav-chip {
  cursor: pointer;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(148, 163, 184, 0.1);
  border: 1px solid rgba(148, 163, 184, 0.14);
  color: var(--muted);
  font-size: 13px;
  font-weight: 600;
  transition:
    transform 0.18s ease,
    border-color 0.18s ease,
    background 0.18s ease,
    color 0.18s ease;
}

.nav-chip:hover {
  transform: translateY(-1px);
  border-color: rgba(56, 189, 248, 0.32);
  color: var(--text);
}

.nav-chip-active {
  background:
    linear-gradient(135deg, rgba(34, 197, 94, 0.28), rgba(56, 189, 248, 0.18)),
    rgba(34, 197, 94, 0.14);
  border-color: rgba(34, 197, 94, 0.38);
  color: #dcfce7;
  box-shadow: 0 10px 26px rgba(34, 197, 94, 0.12);
}

:root[data-theme="light"] .nav-chip-active {
  color: #064e3b;
}

.workspace-panel-hidden {
  display: none !important;
}

.workspace > .panel:not(.workspace-panel-hidden),
.workspace > .grid > .panel:not(.workspace-panel-hidden) {
  animation: panel-in 0.2s ease both;
}

@keyframes panel-in {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.grid {
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: 24px;
}

.panel-title-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
}

.compact-title-row {
  margin-bottom: 8px;
}

.pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 64px;
  height: 28px;
  padding: 0 12px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
}

.pill-idle {
  background: rgba(148, 163, 184, 0.14);
  color: #dbe7f6;
}

.pill-connected {
  background: var(--accent-soft);
  color: #bbf7d0;
}

.pill-error {
  background: rgba(239, 68, 68, 0.16);
  color: #fecaca;
}

.pill-neutral {
  background: rgba(56, 189, 248, 0.14);
  color: #bae6fd;
}

.status-list {
  display: grid;
  gap: 12px;
  margin: 0;
}

.status-list div {
  display: grid;
  grid-template-columns: 104px 1fr;
  gap: 8px;
}

.status-list dt,
.status-list dd {
  margin: 0;
}

.status-list dd {
  word-break: break-all;
}

.info-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin: 0;
}

.info-grid div {
  padding: 12px;
  border-radius: 16px;
  background: rgba(15, 23, 42, 0.72);
  border: 1px solid rgba(148, 163, 184, 0.1);
}

.info-grid dt {
  margin: 0 0 6px;
  font-size: 12px;
  color: var(--muted);
}

.info-grid dd {
  margin: 0;
  font-size: 14px;
  word-break: break-word;
}

.button-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 16px;
}

.button {
  min-height: 42px;
  padding: 0 16px;
  border: 1px solid transparent;
  border-radius: 14px;
  color: var(--text);
  font: inherit;
  cursor: pointer;
  transition:
    transform 120ms ease,
    background-color 120ms ease,
    border-color 120ms ease;
}

.button:hover {
  transform: translateY(-1px);
}

.button-primary {
  background: linear-gradient(135deg, var(--accent), var(--accent-strong));
  color: #041018;
  font-weight: 700;
}

.button-secondary {
  background: rgba(56, 189, 248, 0.14);
  border-color: rgba(56, 189, 248, 0.24);
}

.button-ghost {
  background: rgba(148, 163, 184, 0.08);
  border-color: rgba(148, 163, 184, 0.16);
}

.button-danger {
  background: linear-gradient(135deg, rgba(248, 113, 113, 0.9), rgba(251, 146, 60, 0.9));
  border-color: rgba(248, 113, 113, 0.35);
  color: #210706;
  font-weight: 700;
}

.feature-list {
  margin: 0;
  padding-left: 18px;
  line-height: 1.8;
}

.section-copy,
.small {
  color: var(--muted);
  line-height: 1.6;
}

.section-copy {
  margin: 0 0 16px;
}

.small {
  font-size: 13px;
}

.field {
  display: grid;
  gap: 8px;
  margin-bottom: 14px;
}

.field span {
  font-size: 13px;
  color: var(--muted);
}

.checkbox-field {
  align-content: center;
  grid-template-columns: auto 1fr;
  min-height: 64px;
}

.checkbox-field input {
  width: 18px;
  height: 18px;
}

input,
textarea,
select {
  width: 100%;
  border: 1px solid rgba(148, 163, 184, 0.18);
  border-radius: 14px;
  background: rgba(15, 23, 42, 0.85);
  color: var(--text);
  padding: 12px 14px;
  font: inherit;
}

textarea {
  resize: vertical;
  min-height: 132px;
}

select {
  appearance: none;
}

input[type="checkbox"] {
  width: 20px;
  height: 20px;
  accent-color: var(--accent);
}

.settings-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.setting-card {
  display: grid;
  gap: 14px;
  padding: 16px;
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(15, 23, 42, 0.88), rgba(7, 13, 24, 0.82));
  border: 1px solid rgba(148, 163, 184, 0.12);
}

.setting-copy strong {
  display: block;
  margin-bottom: 6px;
}

.setting-copy p {
  margin: 0;
  color: var(--muted);
  line-height: 1.5;
}

.feature-grid {
  align-items: start;
}

.keymap-feature-grid {
  grid-template-columns: minmax(0, 1fr);
}

.keymap-official-page {
  --official-keyboard-row-min: 0;
  display: grid;
  gap: 0;
  padding: 0;
  overflow: hidden;
  color: #111827;
  background: #f7f9fb;
  border-color: #d8dee6;
}

.keymap-official-header,
.keymap-official-page > .section-copy {
  display: none;
}

.keymap-official-stage {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 150px;
  gap: clamp(18px, 2.2vw, 34px);
  align-items: center;
  min-height: 430px;
  padding: 54px clamp(24px, 8vw, 150px) 48px clamp(24px, 10vw, 220px);
  background: #ffffff;
  border: 1px solid #d7dde5;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.75);
}

.keymap-keyboard-shell {
  position: relative;
  width: min(920px, 100%);
  max-width: none;
  min-width: 0;
  padding: 31px 18px 14px;
  background:
    linear-gradient(180deg, #f0f4f7 0 20px, transparent 20px),
    linear-gradient(90deg, #6d7478, #cfd4d3 10%, #f7faf9 50%, #9da4a3 90%, #5b6165);
  border-radius: 2px;
  box-shadow:
    0 16px 22px rgba(15, 23, 42, 0.17),
    inset 0 0 0 1px rgba(38, 49, 57, 0.22);
}

.keymap-keyboard-shell::before,
.keymap-keyboard-shell::after {
  position: absolute;
  top: 23px;
  bottom: -7px;
  width: 10px;
  content: "";
  background: linear-gradient(180deg, #4d5457, #8d9495);
  box-shadow: 0 3px 5px rgba(15, 23, 42, 0.2);
}

.keymap-keyboard-shell::before {
  left: -10px;
  border-radius: 5px 0 0 5px;
}

.keymap-keyboard-shell::after {
  right: -10px;
  border-radius: 0 5px 5px 0;
}

.keymap-official-matrix {
  gap: 5px;
  padding: 6px;
  overflow-x: hidden;
  background: linear-gradient(180deg, #f3fbfd, #c8edf4);
  border: 1px solid #9ba4a8;
}

.keymap-official-matrix .keyboard-row {
  min-width: var(--official-keyboard-row-min);
  grid-template-columns: repeat(64, minmax(0, 1fr));
  gap: 4px;
}

.keymap-official-matrix .key-button {
  min-height: 38px;
  padding: 4px 3px;
  color: #111827;
  text-align: center;
  background:
    linear-gradient(180deg, #ffffff, #e5e9ec 56%, #c7ced2);
  border: 1px solid #9aa6ac;
  border-radius: 4px;
  box-shadow:
    inset 0 2px 2px rgba(255, 255, 255, 0.85),
    0 2px 3px rgba(15, 23, 42, 0.2);
}

.keymap-official-matrix .key-button:hover {
  transform: translateY(-1px);
  border-color: #f59e0b;
}

.keymap-official-matrix .key-button.active {
  color: #111827;
  background: linear-gradient(180deg, #ffffff, #eff6ff 60%, #dbeafe);
  border-color: #f59e0b;
  box-shadow:
    inset 0 0 0 1px #f59e0b,
    0 0 0 2px rgba(245, 158, 11, 0.35),
    0 2px 3px rgba(15, 23, 42, 0.16);
}

.keymap-official-matrix .key-button.remapped:not(.active) {
  color: #111827;
  background: linear-gradient(180deg, #f0fdf4, #dcfce7);
  border-color: #10b981;
}

.keymap-official-matrix .key-button.remapped {
  position: relative;
  cursor: context-menu;
}

.keymap-official-matrix .key-button.remapped:hover {
  z-index: 8;
  overflow: visible;
}

.keymap-official-matrix .key-button.remapped:hover::after {
  position: absolute;
  bottom: calc(100% + 6px);
  left: 50%;
  z-index: 9;
  width: max-content;
  padding: 4px 8px;
  color: #ffffff;
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
  pointer-events: none;
  background: rgba(15, 23, 42, 0.92);
  border-radius: 999px;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.18);
  content: "右键恢复";
  transform: translateX(-50%);
}

.keymap-official-matrix .key-button.special-key:not(.active) {
  color: #111827;
  background: linear-gradient(180deg, #f8fafc, #e2e8f0);
  border-color: #94a3b8;
}

.keymap-official-matrix .key-button.device-advanced:not(.active) {
  color: #111827;
  background: linear-gradient(180deg, #fdf2f8, #fbcfe8);
  border-color: #f472b6;
}

.keymap-official-matrix .key-button.vendor {
  color: #111827;
  background: linear-gradient(180deg, #f8fafc, #e2e8f0);
  border-color: #94a3b8;
}

.keymap-official-matrix .key-button strong {
  display: block;
  font-size: 10px;
  font-weight: 500;
  line-height: 1.15;
}

.keymap-official-matrix .key-button span {
  display: none;
}

.keymap-layer-card {
  display: grid;
  gap: 18px;
  justify-items: start;
  align-content: center;
  min-height: 256px;
  padding: 48px 22px;
  background: #e3e8ec;
  border: 1px solid #c5ccd2;
  border-radius: 4px;
  box-shadow:
    0 4px 8px rgba(15, 23, 42, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.58);
}

.keymap-layer-radio {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: #111827;
  font-size: 15px;
  cursor: pointer;
}

.keymap-layer-radio input {
  width: 20px;
  height: 20px;
  accent-color: #1684e8;
}

.keymap-reset-layer-button {
  min-height: 36px;
  padding: 8px 15px;
  margin-top: 2px;
  color: #ffffff;
  font-weight: 700;
  background: #ff3b30;
  border: 0;
  border-radius: 3px;
  box-shadow: 0 3px 5px rgba(185, 28, 28, 0.28);
  cursor: pointer;
}

.keymap-reset-layer-button:disabled,
.keymap-output-button:disabled {
  cursor: not-allowed;
  opacity: 0.48;
}

.keymap-output-panel {
  background: #f6f8fa;
  border-top: 1px solid #d7dde5;
}

.keymap-output-tabs {
  display: grid;
  grid-template-columns: repeat(11, minmax(72px, 1fr));
  min-height: 41px;
  background: #f7f9fb;
  border-bottom: 1px solid #d7dde5;
}

.keymap-output-tabs button {
  color: #4b5563;
  font-size: 14px;
  background: transparent;
  border: 0;
  border-right: 1px solid #e3e7ec;
  cursor: pointer;
}

.keymap-output-tabs button:last-child {
  border-right: 0;
}

.keymap-output-tabs button.active {
  color: #1684e8;
  font-weight: 700;
  background: #ffffff;
}

.keymap-output-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-content: flex-start;
  min-height: 275px;
  padding: 18px 22px 28px;
}

.keymap-output-button {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 52px;
  min-height: 51px;
  padding: 0 10px;
  color: #020617;
  font-size: 14px;
  background: #d5dde5;
  border: 1px solid #cbd5df;
  border-radius: 8px;
  cursor: pointer;
  transition:
    transform 120ms ease,
    background-color 120ms ease,
    border-color 120ms ease;
}

.keymap-output-button small {
  margin-top: 3px;
  color: inherit;
  font-size: 11px;
  line-height: 1.2;
  opacity: 0.72;
}

.keymap-output-button:hover:not(:disabled) {
  transform: translateY(-1px);
  background: #c8d2db;
  border-color: #93a4b5;
}

.keymap-output-button.active {
  color: #ffffff;
  background: #1684e8;
  border-color: #0f6ec5;
}

.keymap-output-button.unsupported {
  color: #6b7280;
  background: #e8edf2;
}

.keymap-output-empty {
  width: 100%;
  margin: 0;
  padding: 28px;
  color: #64748b;
  text-align: center;
  background: #edf2f7;
  border: 1px dashed #cbd5e1;
  border-radius: 10px;
}

.keymap-hidden-plumbing {
  display: none !important;
}

.rt-overview {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}

.metric-card,
.workflow-card,
.callout-card,
.slider-card {
  border-radius: 18px;
  border: 1px solid rgba(148, 163, 184, 0.12);
}

.metric-card {
  display: grid;
  gap: 8px;
  padding: 14px;
  background: rgba(15, 23, 42, 0.72);
}

.metric-card span {
  font-size: 12px;
  color: var(--muted);
}

.metric-card strong {
  font-size: 20px;
}

.rt-control-grid,
.workflow-list {
  display: grid;
  gap: 12px;
}

.travel-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(320px, 0.8fr);
  gap: 14px;
  align-items: start;
  margin-bottom: 16px;
}

.travel-keyboard-panel,
.travel-controls-panel {
  min-width: 0;
}

.advanced-keyboard-panel {
  padding: 14px;
  margin: 16px 0;
  border: 1px solid rgba(148, 163, 184, 0.12);
  border-radius: 18px;
  background:
    radial-gradient(circle at 12% 0%, rgba(56, 189, 248, 0.12), transparent 30%),
    linear-gradient(180deg, rgba(15, 23, 42, 0.66), rgba(8, 13, 24, 0.54));
}

.advanced-keyboard-panel .section-copy {
  margin-bottom: 12px;
}

.advanced-keyboard-matrix {
  margin-top: 10px;
  overflow-x: hidden;
}

.advanced-keyboard-matrix .keyboard-row {
  min-width: var(--official-keyboard-row-min);
  grid-template-columns: repeat(64, minmax(0, 1fr));
}

.advanced-binding-slot-panel {
  display: grid;
  gap: 10px;
  padding: 14px;
  margin: 14px 0;
  border: 1px solid rgba(96, 165, 250, 0.18);
  border-radius: 18px;
  background:
    radial-gradient(circle at 16% 0%, rgba(96, 165, 250, 0.14), transparent 30%),
    rgba(15, 23, 42, 0.34);
}

.advanced-binding-slot-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 10px;
}

.advanced-binding-slot {
  display: grid;
  gap: 6px;
  min-height: 104px;
  padding: 12px;
  color: var(--text);
  text-align: left;
  border: 1px solid rgba(148, 163, 184, 0.16);
  border-radius: 16px;
  background: rgba(2, 6, 23, 0.28);
  cursor: pointer;
  transition:
    transform 120ms ease,
    border-color 120ms ease,
    background 120ms ease;
}

.advanced-binding-slot:hover {
  transform: translateY(-1px);
  border-color: rgba(96, 165, 250, 0.44);
  background: rgba(30, 41, 59, 0.54);
}

.advanced-binding-slot.active {
  border-color: rgba(37, 99, 235, 0.74);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.18);
  background:
    linear-gradient(135deg, rgba(37, 99, 235, 0.28), rgba(14, 165, 233, 0.12)),
    rgba(15, 23, 42, 0.62);
}

.advanced-binding-slot span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.04em;
}

.advanced-binding-slot strong {
  font-size: 18px;
  line-height: 1.15;
}

.advanced-binding-slot small {
  color: var(--muted);
  line-height: 1.35;
}

.field.advanced-slot-control-active {
  position: relative;
}

.field.advanced-slot-control-active select,
.field.advanced-slot-control-active input {
  border-color: rgba(37, 99, 235, 0.78);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.16);
}

.field.advanced-slot-control-active::after {
  content: "点上方键盘图绑定这里";
  justify-self: start;
  color: #2563eb;
  font-size: 12px;
  font-weight: 800;
}

.dks-quick-panel {
  display: grid;
  gap: 14px;
  padding: 16px;
  margin: 16px 0;
  border: 1px solid rgba(34, 197, 94, 0.18);
  border-radius: 20px;
  background:
    radial-gradient(circle at 8% 10%, rgba(34, 197, 94, 0.16), transparent 34%),
    linear-gradient(135deg, rgba(12, 30, 24, 0.82), rgba(8, 13, 24, 0.72));
}

.dks-quick-target {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 12px 14px;
  border: 1px solid rgba(148, 163, 184, 0.14);
  border-radius: 16px;
  background: rgba(2, 6, 23, 0.32);
}

.dks-quick-target span {
  color: var(--muted);
  font-size: 12px;
}

.dks-stage-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.dks-stage-field {
  grid-template-columns: 1fr;
}

.dks-stage-field select,
.dks-stage-field input {
  width: 100%;
}

.compact-info-banner {
  padding: 10px 12px;
}

.advanced-full-editor {
  margin-top: 16px;
  border: 1px solid rgba(148, 163, 184, 0.14);
  border-radius: 18px;
  background: rgba(2, 6, 23, 0.24);
}

.advanced-full-editor summary {
  padding: 14px 16px;
  color: var(--text);
  cursor: pointer;
  font-weight: 800;
}

.advanced-full-editor-body {
  padding: 0 16px 16px;
}

.advanced-mode-hidden,
.advanced-capture-panel[hidden],
.dks-quick-panel[hidden] {
  display: none !important;
}

.advanced-capture-panel {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid rgba(148, 163, 184, 0.12);
}

.advanced-device-panel {
  display: grid;
  gap: 12px;
  margin: 16px 0;
  padding: 16px;
  border: 1px solid rgba(56, 189, 248, 0.16);
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(14, 165, 233, 0.1), rgba(15, 23, 42, 0.34)),
    rgba(2, 6, 23, 0.2);
}

.advanced-device-current-card,
.advanced-device-list {
  display: grid;
  gap: 10px;
}

.advanced-device-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.advanced-device-stat-card {
  display: grid;
  gap: 4px;
  min-width: 0;
  padding: 12px;
  border: 1px solid rgba(56, 189, 248, 0.16);
  border-radius: 14px;
  background: rgba(15, 23, 42, 0.42);
}

.advanced-device-stat-card span,
.advanced-device-stat-card small {
  color: var(--muted);
  font-size: 12px;
}

.advanced-device-stat-card strong {
  color: var(--text);
  font-size: 22px;
  line-height: 1;
}

.advanced-device-filter-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.advanced-device-filter {
  display: inline-flex;
  gap: 8px;
  align-items: center;
  padding: 8px 12px;
  border: 1px solid rgba(148, 163, 184, 0.14);
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.36);
  color: var(--muted);
  cursor: pointer;
  font-weight: 800;
}

.advanced-device-filter strong {
  color: var(--text);
}

.advanced-device-filter.active {
  border-color: rgba(37, 99, 235, 0.44);
  background: rgba(37, 99, 235, 0.14);
  color: var(--text);
}

.advanced-device-current-title {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.06em;
}

.advanced-device-card,
.advanced-device-empty-current,
.advanced-device-empty-list {
  padding: 14px;
  border: 1px solid rgba(148, 163, 184, 0.14);
  border-radius: 16px;
  background: rgba(15, 23, 42, 0.5);
}

.advanced-device-card {
  display: grid;
  gap: 10px;
  cursor: pointer;
  transition:
    transform 120ms ease,
    border-color 120ms ease,
    background 120ms ease;
}

.advanced-device-card:hover {
  transform: translateY(-1px);
  border-color: rgba(56, 189, 248, 0.42);
  background: rgba(15, 23, 42, 0.64);
}

.advanced-device-card.current {
  border-color: rgba(34, 197, 94, 0.5);
  box-shadow: inset 4px 0 0 rgba(34, 197, 94, 0.72);
}

.advanced-device-card-head {
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: space-between;
}

.advanced-device-card-title {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  min-width: 0;
}

.advanced-device-index {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 30px;
  border-radius: 10px;
  background: rgba(148, 163, 184, 0.12);
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.advanced-device-card-head strong {
  font-size: 15px;
  overflow-wrap: anywhere;
}

.advanced-device-type {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(34, 197, 94, 0.12);
  color: #86efac;
  font-weight: 900;
  letter-spacing: 0.04em;
}

.advanced-device-edit-hint {
  flex: 0 0 auto;
  color: #93c5fd;
  font-size: 12px;
  font-weight: 900;
}

.advanced-device-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  color: var(--muted);
  font-size: 12px;
}

.advanced-device-summary-line {
  margin: 0;
  color: var(--text);
  font-size: 13px;
  font-weight: 750;
  line-height: 1.55;
}

.advanced-device-detail-list {
  display: grid;
  gap: 8px;
  margin: 0;
}

.advanced-device-detail-list div {
  display: grid;
  grid-template-columns: minmax(90px, 0.35fr) minmax(0, 1fr);
  gap: 10px;
  align-items: start;
}

.advanced-device-detail-list dt {
  color: var(--muted);
  font-size: 12px;
}

.advanced-device-detail-list dd {
  margin: 0;
  color: var(--text);
  font-weight: 750;
}

.advanced-device-empty-current,
.advanced-device-empty-list {
  display: grid;
  gap: 6px;
  color: var(--muted);
}

.advanced-device-empty-current strong,
.advanced-device-empty-list strong {
  color: var(--text);
}

.advanced-official-grid {
  display: grid;
  grid-template-columns: minmax(220px, 0.72fr) minmax(0, 1.58fr) minmax(260px, 0.9fr);
  gap: 16px;
  align-items: start;
}

.advanced-function-rail,
.advanced-binding-workspace,
.advanced-test-workspace {
  min-width: 0;
  padding: 16px;
  border: 1px solid rgba(148, 163, 184, 0.14);
  border-radius: 20px;
  background: rgba(2, 6, 23, 0.24);
}

.advanced-type-card-list {
  display: grid;
  gap: 10px;
}

.advanced-type-card {
  display: grid;
  gap: 5px;
  width: 100%;
  padding: 14px;
  border: 1px solid rgba(148, 163, 184, 0.16);
  border-radius: 16px;
  background:
    linear-gradient(180deg, rgba(19, 29, 51, 0.9), rgba(8, 13, 24, 0.72));
  color: var(--text);
  text-align: left;
  cursor: pointer;
  transition:
    transform 120ms ease,
    border-color 120ms ease,
    background 120ms ease;
}

.advanced-type-card:hover {
  transform: translateY(-1px);
  border-color: rgba(56, 189, 248, 0.34);
}

.advanced-type-card.active {
  border-color: rgba(34, 197, 94, 0.48);
  background:
    linear-gradient(180deg, rgba(22, 63, 47, 0.95), rgba(8, 22, 18, 0.86));
  box-shadow: inset 0 0 0 1px rgba(34, 197, 94, 0.14);
}

.advanced-type-name {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.advanced-type-card strong {
  font-size: 20px;
  letter-spacing: 0.04em;
}

.advanced-type-card small {
  color: var(--muted);
  line-height: 1.5;
}

.advanced-test-workspace {
  position: sticky;
  top: 18px;
}

.advanced-key-test-field {
  margin-bottom: 12px;
}

.advanced-key-live-output {
  display: grid;
  gap: 8px;
  margin-bottom: 12px;
  padding: 16px;
  border: 1px solid rgba(56, 189, 248, 0.22);
  border-radius: 18px;
  background:
    radial-gradient(circle at 12% 0%, rgba(56, 189, 248, 0.18), transparent 34%),
    linear-gradient(180deg, rgba(15, 23, 42, 0.72), rgba(8, 13, 24, 0.54));
}

.advanced-key-live-output span,
.advanced-key-live-output small {
  color: var(--muted);
  font-size: 12px;
}

.advanced-key-live-output strong {
  min-height: 40px;
  overflow-wrap: anywhere;
  color: var(--text);
  font-size: clamp(24px, 4vw, 42px);
  line-height: 1.1;
}

.advanced-key-test-input {
  width: 100%;
  min-height: 150px;
  display: flex;
  align-items: flex-start;
  padding: 14px 16px;
  border: 1px solid rgba(148, 163, 184, 0.42);
  border-radius: 14px;
  background: rgba(248, 250, 252, 0.86);
  color: var(--text);
  font-size: 20px;
  font-weight: 800;
  outline: none;
  user-select: none;
}

.advanced-key-test-input.has-active-key {
  border-color: rgba(37, 99, 235, 0.72);
  background: linear-gradient(180deg, #eff6ff, #ffffff);
  color: #1d4ed8;
}

.advanced-key-test-log {
  max-height: 280px;
  overflow: auto;
  white-space: pre-wrap;
}

.advanced-official-panel {
  background: #f6f8fb;
  color: #172033;
}

.advanced-official-panel > .panel-title-row,
.advanced-official-panel > .section-copy {
  display: none;
}

.advanced-official-panel .advanced-keyboard-panel {
  margin: 0 0 8px;
  padding: 34px 28px 24px;
  border-color: #d8dde6;
  border-radius: 6px;
  background: #ffffff;
}

.advanced-official-panel .advanced-keyboard-panel .compact-title-row,
.advanced-official-panel .advanced-keyboard-panel .section-copy {
  display: none;
}

.advanced-official-panel .advanced-keyboard-matrix {
  width: min(900px, 100%);
  margin: 0 auto;
}

.advanced-official-panel .advanced-device-panel {
  margin: 8px 0;
  border-color: #d8dde6;
  border-radius: 6px;
  background: #ffffff;
}

.advanced-official-panel .advanced-device-panel .section-copy,
.advanced-official-panel .advanced-device-summary,
.advanced-official-panel .advanced-device-current-card,
.advanced-official-panel .advanced-device-filter-list {
  display: none;
}

.advanced-official-panel .advanced-device-list {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.advanced-official-panel .advanced-device-card,
.advanced-official-panel .advanced-device-empty-list {
  color: #172033;
  border-color: #d8dde6;
  background: #f8fafc;
}

.advanced-official-grid {
  grid-template-columns: 300px minmax(420px, 1fr) 300px;
  gap: 8px;
}

.advanced-official-panel .advanced-function-rail,
.advanced-official-panel .advanced-binding-workspace,
.advanced-official-panel .advanced-test-workspace {
  border-color: #d8dde6;
  border-radius: 6px;
  background: #ffffff;
}

.advanced-official-panel .advanced-type-card {
  min-height: 86px;
  color: #172033;
  border-color: #d8dde6;
  background: #ffffff;
}

:root[data-theme="official"] .advanced-official-panel .advanced-type-card {
  color: #172033;
  border: 0;
  background: #dbe3eb;
  box-shadow: none;
}

.advanced-official-panel .advanced-type-card.active {
  color: #ffffff;
  border-color: #111827;
  background: #111827;
  box-shadow: none;
}

.advanced-official-panel .advanced-type-card.active .advanced-type-name,
.advanced-official-panel .advanced-type-card.active small {
  color: rgba(255, 255, 255, 0.78);
}

.advanced-official-panel .advanced-binding-slot-panel,
.advanced-official-panel .dks-quick-panel,
.advanced-official-panel .advanced-full-editor,
.advanced-official-panel #advanced-key-stage-preview,
.advanced-official-panel #advanced-key-preview {
  display: none !important;
}

.advanced-editor-shell {
  display: grid;
  gap: 16px;
  margin-top: 8px;
  padding: 18px;
  border: 1px solid #d8dde6;
  border-radius: 6px;
  background: #ffffff;
}

.advanced-editor-shell[hidden] {
  display: none !important;
}

.advanced-official-panel.editing .advanced-device-panel,
.advanced-official-panel.editing #advanced-overview-shell {
  display: none !important;
}

.advanced-editor-header {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  justify-content: space-between;
  padding-bottom: 12px;
  border-bottom: 1px solid #e5e7eb;
}

.advanced-editor-header h3,
.advanced-editor-section-title h4 {
  margin: 0;
  color: #172033;
}

.advanced-editor-actions {
  display: flex;
  gap: 10px;
  align-items: center;
}

.advanced-editor-layout {
  display: grid;
  grid-template-columns: 240px minmax(360px, 1fr) 330px;
  gap: 16px;
  align-items: stretch;
}

.advanced-editor-info,
.advanced-editor-controls,
.advanced-output-palette {
  min-width: 0;
  padding: 16px;
  border: 1px solid #d8dde6;
  border-radius: 10px;
  background: #f8fafc;
}

.advanced-editor-info {
  display: grid;
  align-content: start;
  gap: 12px;
}

.advanced-editor-kind-card {
  display: grid;
  gap: 8px;
  padding: 14px;
  border: 1px solid #d8dde6;
  border-radius: 10px;
  background: #ffffff;
}

.advanced-editor-kind-card span,
.advanced-output-box span,
.advanced-depth-field span,
.advanced-delay-field span,
.advanced-editor-section-title span {
  color: #64748b;
  font-size: 12px;
  font-weight: 800;
}

.advanced-editor-kind-card strong {
  color: #172033;
  font-size: 34px;
  letter-spacing: 0.05em;
}

.advanced-editor-kind-card small,
.advanced-editor-help,
.advanced-output-box small {
  color: #64748b;
  line-height: 1.45;
}

.advanced-editor-help {
  padding: 12px;
  border-radius: 10px;
  background: #eef5ff;
}

.advanced-editor-controls {
  display: grid;
}

.advanced-editor-type-panel {
  display: grid;
  align-content: start;
  gap: 14px;
}

.advanced-editor-type-panel[hidden] {
  display: none !important;
}

.advanced-editor-section-title {
  display: grid;
  gap: 4px;
}

.advanced-dks-stage-board {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.advanced-mt-board,
.advanced-socd-board {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.advanced-output-box {
  display: grid;
  gap: 8px;
  width: 100%;
  min-height: 92px;
  padding: 14px;
  color: #172033;
  text-align: left;
  border: 1px solid #d8dde6;
  border-radius: 12px;
  background: #ffffff;
  cursor: pointer;
}

.advanced-output-box.large {
  min-height: 132px;
}

.advanced-output-box:hover,
.advanced-output-box.active {
  border-color: #1677d2;
  box-shadow: 0 0 0 3px rgba(22, 119, 210, 0.14);
}

.advanced-output-box.target {
  cursor: default;
}

.advanced-output-box strong {
  color: #172033;
  font-size: 20px;
  line-height: 1.2;
  overflow-wrap: anywhere;
}

.advanced-depth-field,
.advanced-delay-field {
  display: grid;
  gap: 8px;
}

.advanced-depth-field input,
.advanced-delay-field input,
.advanced-delay-field select {
  width: 100%;
  min-height: 44px;
  padding: 0 12px;
  color: #172033;
  border: 1px solid #cbd5e1;
  border-radius: 10px;
  background: #ffffff;
}

.advanced-delay-field strong {
  color: #1677d2;
}

.advanced-output-palette {
  display: grid;
  align-content: start;
  gap: 12px;
}

.advanced-output-category-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.advanced-output-category,
.advanced-output-key {
  min-height: 38px;
  border: 1px solid #d8dde6;
  border-radius: 8px;
  background: #ffffff;
  color: #172033;
  cursor: pointer;
}

.advanced-output-category.active {
  color: #1677d2;
  border-color: #1677d2;
  background: #eef5ff;
}

.advanced-output-key-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  max-height: 420px;
  overflow: auto;
  padding-right: 4px;
}

.advanced-output-key:hover {
  color: #ffffff;
  border-color: #1677d2;
  background: #1677d2;
}

.advanced-output-palette-empty {
  padding: 14px;
  color: #64748b;
  border: 1px dashed #cbd5e1;
  border-radius: 10px;
  background: #ffffff;
}

.advanced-official-editor {
  gap: 0;
  margin-top: 0;
  padding: 0;
  border-color: #bcc8d5;
  border-radius: 2px;
  background: #eef2f6;
}

.advanced-official-editor-header {
  align-items: center;
  min-height: 52px;
  padding: 10px 18px;
  background: #f7f9fb;
  border-bottom-color: #bcc8d5;
}

.advanced-official-editor-header .section-copy {
  margin: 2px 0 0;
  color: #4b5563;
}

.advanced-official-editor-layout {
  grid-template-columns: minmax(250px, 0.95fr) minmax(390px, 1.3fr) minmax(280px, 0.9fr);
  gap: 0;
  align-items: stretch;
  min-height: 332px;
}

.advanced-official-editor.socd-mode .advanced-official-editor-layout {
  grid-template-columns: minmax(250px, 0.95fr) minmax(520px, 2.2fr);
}

.advanced-official-type-pane,
.advanced-official-control-pane,
.advanced-output-accordion {
  border: 0;
  border-radius: 0;
  background: #eef2f6;
}

.advanced-official-type-pane,
.advanced-official-control-pane {
  border-right: 1px solid #bcc8d5;
}

.advanced-official-type-pane {
  padding: 34px 28px;
  align-content: start;
}

.advanced-official-type-copy {
  border: 0;
  background: transparent;
  padding: 0 0 18px;
}

.advanced-official-bind-target {
  width: 92px;
  min-height: 92px;
  place-items: center;
  text-align: center;
  border-radius: 4px;
  background: #d8e1ea;
}

.advanced-official-bind-target span,
.advanced-official-bind-target small {
  display: none;
}

.advanced-official-bind-target strong {
  font-size: 14px;
  line-height: 1.35;
}

.advanced-official-control-pane {
  padding: 22px 26px;
}

.advanced-official-control-pane .advanced-editor-section-title {
  margin-bottom: 12px;
}

.advanced-official-dks-workspace {
  display: grid;
  grid-template-columns: 138px minmax(360px, 1fr);
  gap: 26px;
  align-items: center;
  min-height: 286px;
}

.advanced-official-dks-bind-column {
  display: grid;
  gap: 10px;
  justify-items: center;
}

.advanced-official-stage-box,
.advanced-official-square,
.advanced-official-mpt-output {
  width: 72px;
  min-height: 62px;
  padding: 6px 8px;
  place-items: center;
  text-align: center;
  border-radius: 5px;
  background: #dbe5ee;
}

.advanced-official-stage-box {
  width: 118px;
}

.advanced-official-stage-box span,
.advanced-official-stage-box small,
.advanced-official-square span,
.advanced-official-square small,
.advanced-official-mpt-output span,
.advanced-official-mpt-output small {
  color: #475569;
  font-size: 11px;
}

.advanced-official-stage-box strong,
.advanced-official-square strong,
.advanced-official-mpt-output strong {
  font-size: 13px;
}

.advanced-official-dks-matrix {
  display: grid;
  grid-template-rows: auto 1fr;
  gap: 16px;
}

.advanced-official-dks-depth-row,
.advanced-official-dks-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(78px, 1fr));
  gap: 12px;
}

.advanced-official-dks-depth-row label {
  display: grid;
  gap: 8px;
  justify-items: center;
  color: #334155;
  font-weight: 800;
}

.advanced-official-dks-depth-row input[type="range"] {
  width: 100%;
  accent-color: #94a3b8;
}

.advanced-official-dks-grid {
  grid-template-rows: repeat(4, 54px);
}

.advanced-official-dks-grid button {
  border: 1px solid #b8c6d4;
  border-radius: 10px;
  color: #64748b;
  background: #dbe5ee;
  font-size: 22px;
  font-weight: 900;
  cursor: pointer;
}

.advanced-official-dks-grid button:hover,
.advanced-official-dks-grid button.active {
  border-color: #1677d2;
  color: #ffffff;
  background: #1677d2;
}

.advanced-official-dks-grid button.active::before {
  content: "✓";
}

.advanced-official-dks-grid button.active {
  font-size: 0;
}

.advanced-official-mt-workspace,
.advanced-official-tgl-workspace,
.advanced-official-end-workspace {
  display: grid;
  gap: 24px;
  align-content: center;
  min-height: 240px;
}

.advanced-official-mt-squares,
.advanced-official-socd-targets {
  display: flex;
  gap: 22px;
  align-items: center;
}

.advanced-official-delay-field {
  max-width: 360px;
}

.advanced-official-delay-field input[type="range"] {
  accent-color: #1677d2;
}

.advanced-official-socd-workspace {
  display: grid;
  gap: 24px;
  align-content: start;
  min-height: 240px;
}

.advanced-official-socd-rules {
  display: grid;
  gap: 12px;
  margin: 0;
  padding: 14px 0 0;
  border: 0;
  border-top: 1px solid #cbd5e1;
}

.advanced-official-socd-rules legend {
  color: #172033;
  font-weight: 900;
}

.advanced-official-socd-rules label {
  display: flex;
  gap: 10px;
  align-items: center;
  color: #172033;
  font-weight: 800;
}

.advanced-official-mpt-workspace {
  display: grid;
  gap: 16px;
  align-content: center;
  min-height: 250px;
}

.advanced-official-mpt-row {
  display: grid;
  grid-template-columns: 82px minmax(220px, 1fr);
  gap: 22px;
  align-items: center;
}

.advanced-official-mpt-depth {
  display: grid;
  gap: 8px;
  color: #334155;
  font-weight: 800;
}

.advanced-official-mpt-depth input[type="range"] {
  width: 100%;
  accent-color: #94a3b8;
}

.advanced-output-accordion {
  padding: 18px;
}

.advanced-output-accordion .advanced-output-category-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
}

.advanced-output-accordion-section {
  border-bottom: 1px solid #cbd5e1;
}

.advanced-output-accordion .advanced-output-category {
  display: flex;
  justify-content: space-between;
  width: 100%;
  min-height: 44px;
  padding: 0 8px;
  color: #172033;
  text-align: left;
  border: 0;
  border-radius: 0;
  background: transparent;
}

.advanced-output-accordion .advanced-output-category.active {
  color: #172033;
  background: transparent;
}

.advanced-output-accordion-grid {
  display: none;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  max-height: 230px;
  overflow: auto;
  padding: 8px 0 12px;
}

.advanced-output-accordion-section.open .advanced-output-accordion-grid {
  display: grid;
}

.advanced-output-accordion .advanced-output-key {
  min-height: 36px;
  padding: 0 8px;
  border-radius: 6px;
  background: #ffffff;
}

@media (max-width: 1280px) {
  .advanced-editor-layout {
    grid-template-columns: 1fr;
  }

  .advanced-test-workspace {
    position: static;
  }
}

.travel-keyboard-matrix {
  margin-top: 12px;
}

.travel-tune-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.travel-action-row {
  margin-top: 4px;
}

.rt-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}

.lighting-official-panel {
  display: grid;
  gap: 10px;
  padding: 0;
  background: #ffffff;
  color: #111827;
}

.lighting-official-panel > .panel-title-row,
.lighting-official-panel > .section-copy,
.lighting-official-panel > .rt-overview {
  display: none;
}

.lighting-official-stage {
  min-height: 430px;
  padding: 52px 112px 26px;
  border: 1px solid #d8dde6;
  border-radius: 6px;
  background: #ffffff;
}

.lighting-keyboard-shell {
  display: grid;
  justify-items: center;
  gap: 24px;
  min-width: 0;
}

.lighting-keyboard-shell .keyboard-matrix {
  width: min(820px, 100%);
  padding: 0;
  overflow-x: hidden;
  border: 0;
  background: transparent;
}

.lighting-keyboard-shell .keyboard-row {
  min-width: var(--official-keyboard-row-min);
  grid-template-columns: repeat(64, minmax(0, 1fr));
}

.lighting-keyboard-matrix .key-button {
  min-height: 44px;
  color: #111827;
  background: linear-gradient(180deg, #ffffff, #f3f4f6 56%, #d5d8dc);
  border-color: #9aa6ac;
  border-radius: 3px;
}

.lighting-keyboard-matrix .key-button span {
  display: none;
}

.lighting-area-tabs {
  display: inline-flex;
  overflow: hidden;
  border: 1px solid #1676d2;
  border-radius: 999px;
}

.lighting-editor-layout {
  display: grid;
  grid-template-columns: minmax(540px, 1fr) minmax(360px, 0.58fr);
  gap: 6px;
}

.lighting-effect-panel,
.lighting-color-panel {
  min-height: 340px;
  padding: 44px 36px;
  border: 1px solid #d8dde6;
  border-radius: 6px;
  background: #f8fafc;
}

.lighting-effect-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(120px, 1fr));
  gap: 8px;
  align-content: start;
}

.lighting-effect-button {
  min-height: 52px;
  padding: 0 14px;
  border: 1px solid #cbd5df;
  border-radius: 8px;
  background: #d5dde5;
  color: #111827;
  font-weight: 850;
  cursor: pointer;
  transition:
    transform 120ms ease,
    border-color 120ms ease,
    background-color 120ms ease;
}

.lighting-effect-button:hover:not(:disabled) {
  transform: translateY(-1px);
  background: #c8d2db;
  border-color: #93a4b5;
}

.lighting-effect-button.active {
  color: #111827;
  background: #eef2f7;
  border-color: #f59e0b;
  box-shadow:
    inset 0 0 0 1px #f59e0b,
    0 0 0 2px rgba(245, 158, 11, 0.2);
}

.lighting-effect-button.custom.active {
  background: linear-gradient(135deg, #eff6ff, #fef3c7);
}

.lighting-hidden-controls {
  display: none;
}

.lighting-color-panel {
  display: grid;
  grid-template-columns: minmax(180px, 0.8fr) minmax(240px, 1fr);
  gap: 28px;
  align-items: center;
}

.lighting-color-picker-card,
.lighting-color-controls,
.lighting-custom-key-card {
  border: 1px solid #d7dde7;
  border-radius: 6px;
  background: #dfe3f1;
  box-shadow: 0 2px 7px rgba(15, 23, 42, 0.12);
}

.lighting-color-picker-card {
  display: grid;
  justify-items: center;
  gap: 14px;
  padding: 18px 12px;
}

.lighting-color-wheel {
  width: 148px;
  height: 148px;
  padding: 0;
  overflow: hidden;
  border: 0;
  border-radius: 50%;
  background: conic-gradient(red, yellow, lime, cyan, blue, magenta, red);
  cursor: pointer;
}

.lighting-rgb-readout {
  width: 100%;
  padding: 8px 10px;
  border-radius: 3px;
  background: #364252;
  color: #ffffff;
  font: 12px/1.4 ui-monospace, SFMono-Regular, Consolas, monospace;
}

.lighting-color-controls {
  display: grid;
  gap: 14px;
  padding: 16px;
}

.lighting-mode-switch,
.lighting-color-space-switch,
.lighting-swatch-row {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  align-items: center;
  justify-content: center;
}

.lighting-color-space-switch {
  justify-content: flex-start;
}

.lighting-color-mode-button,
.lighting-color-space-button {
  min-width: 80px;
  min-height: 36px;
  border: 1px solid #c7d2e5;
  border-radius: 4px;
  background: #eef2f7;
  color: #111827;
  font-weight: 850;
  cursor: pointer;
}

.lighting-color-mode-button.active,
.lighting-color-space-button.active {
  color: #ff1d1d;
  background: #fff7ed;
  border-color: #ff4d4f;
}

.lighting-color-channel-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(70px, 1fr));
  gap: 10px;
  align-items: end;
}

.lighting-color-channel {
  display: grid;
  gap: 5px;
  font-weight: 700;
  color: #1f2937;
}

.lighting-color-channel span {
  font-size: 12px;
}

.lighting-color-channel input {
  width: 100%;
  min-height: 34px;
  padding: 6px 8px;
  border: 1px solid #cbd5e1;
  border-radius: 4px;
  background: #fff;
  font-weight: 700;
  color: #111827;
}

.lighting-color-hex-channel {
  grid-column: 1 / -1;
}

.lighting-swatch-row {
  padding: 10px;
  border-radius: 4px;
  background: #cfd6ea;
}

.lighting-swatch {
  width: 20px;
  height: 20px;
  border: 0;
  border-radius: 999px;
  background: var(--swatch);
  cursor: pointer;
}

.lighting-slider-row {
  display: grid;
  grid-template-columns: 52px 1fr;
  gap: 12px;
  align-items: center;
  color: #111827;
  font-weight: 850;
}

.lighting-slider-row input {
  width: 100%;
  accent-color: #1676d2;
}

.lighting-custom-key-card {
  display: grid;
  gap: 8px;
  padding: 12px;
  background: #eef2ff;
}

.lighting-custom-key-card span {
  color: #64748b;
  font-size: 12px;
  font-weight: 850;
}

.lighting-custom-key-card strong {
  color: #111827;
  font-size: 15px;
}

.rhythm-official-panel {
  display: grid;
  gap: 10px;
  padding: 0;
  background: #ffffff;
  color: #111827;
}

.rhythm-official-panel > .panel-title-row,
.rhythm-official-panel > .section-copy {
  display: none;
}

.rhythm-official-stage {
  min-height: 430px;
  padding: 52px 112px 36px;
  border: 1px solid #d8dde6;
  border-radius: 6px;
  background: #ffffff;
}

.rhythm-keyboard-shell {
  display: grid;
  justify-items: center;
  min-width: 0;
}

.rhythm-keyboard-shell .keyboard-matrix {
  width: min(820px, 100%);
  padding: 0;
  overflow-x: hidden;
  border: 0;
  background: transparent;
}

.rhythm-keyboard-shell .keyboard-row {
  min-width: var(--official-keyboard-row-min);
  grid-template-columns: repeat(64, minmax(0, 1fr));
}

.rhythm-keyboard-matrix .key-button {
  min-height: 44px;
  color: #111827;
  background: linear-gradient(180deg, #ffffff, #f3f4f6 56%, #d5d8dc);
  border-color: #9aa6ac;
  border-radius: 3px;
}

.rhythm-keyboard-matrix .key-button span {
  display: none;
}

.rhythm-editor-layout {
  display: grid;
  grid-template-columns: minmax(520px, 1fr) minmax(360px, 0.65fr);
  gap: 6px;
}

.rhythm-mode-panel,
.rhythm-param-panel {
  min-height: 320px;
  padding: 44px 36px;
  border: 1px solid #d8dde6;
  border-radius: 6px;
  background: #f8fafc;
}

.rhythm-mode-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(150px, 1fr));
  gap: 12px;
  margin-top: 22px;
}

.rhythm-mode-button {
  min-height: 58px;
  border: 1px solid #cbd5df;
  border-radius: 8px;
  background: #d5dde5;
  color: #111827;
  font-size: 15px;
  font-weight: 850;
  cursor: pointer;
}

.rhythm-mode-button.active {
  color: #ffffff;
  background: #7c3aed;
  border-color: #7c3aed;
  box-shadow: 0 10px 24px rgba(124, 58, 237, 0.24);
}

.rhythm-param-panel {
  display: grid;
  gap: 18px;
}

.rhythm-param-grid {
  grid-template-columns: 1fr;
}

@media (max-width: 1480px) {
  .lighting-editor-layout,
  .rhythm-editor-layout {
    grid-template-columns: 1fr;
  }

  .lighting-color-panel {
    grid-template-columns: minmax(180px, 0.7fr) minmax(260px, 1fr);
  }
}

@media (max-width: 840px) {
  .lighting-official-stage,
  .lighting-effect-panel,
  .lighting-color-panel,
  .rhythm-official-stage,
  .rhythm-mode-panel,
  .rhythm-param-panel {
    padding: 24px;
  }

  .lighting-effect-grid,
  .rhythm-mode-grid {
    grid-template-columns: repeat(2, minmax(120px, 1fr));
  }

  .lighting-color-panel,
  .rhythm-editor-layout {
    grid-template-columns: 1fr;
  }
}

.keyboard-matrix {
  --keyboard-row-min: 860px;
  display: grid;
  gap: 10px;
  overflow-x: auto;
}

.keyboard-row {
  display: grid;
  grid-template-columns: repeat(64, minmax(0, 1fr));
  gap: 8px;
  min-width: var(--keyboard-row-min);
}

.keyboard-matrix.compact .keyboard-row {
  min-width: min(780px, var(--keyboard-row-min));
}

.keyboard-matrix.travel-keyboard-matrix .keyboard-row {
  min-width: min(800px, var(--keyboard-row-min));
}

.keyboard-matrix.compact .key-button {
  min-height: 48px;
  padding: 8px 7px;
}

.key-button {
  min-height: 58px;
  padding: 10px 8px;
  border: 1px solid rgba(148, 163, 184, 0.14);
  border-radius: 16px;
  background:
    linear-gradient(180deg, rgba(19, 29, 51, 0.95), rgba(8, 14, 27, 0.9));
  color: var(--text);
  text-align: left;
  cursor: pointer;
  transition:
    transform 120ms ease,
    border-color 120ms ease,
    background-color 120ms ease;
}

.key-button:hover {
  transform: translateY(-1px);
  border-color: rgba(56, 189, 248, 0.32);
}

.key-button.active {
  border-color: rgba(34, 197, 94, 0.42);
  background:
    linear-gradient(180deg, rgba(20, 46, 35, 0.95), rgba(9, 20, 16, 0.92));
  box-shadow: inset 0 0 0 1px rgba(34, 197, 94, 0.14);
}

.key-button.ready:not(.active) {
  border-color: rgba(56, 189, 248, 0.3);
  box-shadow: inset 0 0 0 1px rgba(56, 189, 248, 0.08);
}

.key-button.multi-selected:not(.active) {
  border-color: rgba(249, 115, 22, 0.72);
  background:
    linear-gradient(180deg, rgba(69, 38, 10, 0.95), rgba(28, 18, 6, 0.92));
  box-shadow:
    inset 0 0 0 2px rgba(249, 115, 22, 0.26),
    0 10px 22px rgba(249, 115, 22, 0.12);
}

.key-button.multi-selected span {
  color: rgba(254, 215, 170, 0.92);
}

.key-button.remapped:not(.active) {
  border-color: rgba(250, 204, 21, 0.38);
  background:
    linear-gradient(180deg, rgba(45, 36, 10, 0.94), rgba(18, 15, 7, 0.92));
  box-shadow: inset 0 0 0 1px rgba(250, 204, 21, 0.1);
}

.key-button.device-advanced:not(.active) {
  border-color: rgba(244, 114, 182, 0.46);
  background:
    linear-gradient(180deg, rgba(54, 18, 43, 0.94), rgba(22, 8, 20, 0.92));
  box-shadow: inset 0 0 0 1px rgba(244, 114, 182, 0.14);
}

.key-button.has-magnetic-readback {
  position: relative;
  overflow: hidden;
  border-color: rgba(251, 146, 60, 0.92);
  background:
    linear-gradient(180deg, rgba(255, 251, 235, 0.98), rgba(255, 237, 213, 0.94));
  color: #111827;
  box-shadow:
    inset 0 0 0 2px rgba(245, 158, 11, 0.35),
    0 10px 20px rgba(245, 158, 11, 0.14);
}

.key-button.has-magnetic-readback > span:not(.magnetic-key-readback) {
  opacity: 0.42;
}

.magnetic-key-readback {
  position: absolute;
  inset: 2px 3px auto 3px;
  z-index: 2;
  display: grid;
  gap: 0;
  pointer-events: none;
  font-size: 9px;
  line-height: 1.05;
  text-align: left;
}

.magnetic-key-readback i {
  display: block;
  overflow: hidden;
  font-style: normal;
  font-weight: 900;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.magnetic-readback-travel,
.magnetic-readback-press,
.magnetic-readback-top {
  color: #ef4444;
}

.magnetic-readback-release,
.magnetic-readback-bottom {
  color: #2563eb;
}

.key-button.remapped span {
  color: rgba(254, 240, 138, 0.86);
}

.key-button.device-advanced span {
  color: rgba(251, 207, 232, 0.9);
}

.key-button.vendor {
  border-color: rgba(245, 158, 11, 0.26);
  background:
    linear-gradient(180deg, rgba(52, 37, 12, 0.9), rgba(25, 19, 8, 0.9));
}

.key-button strong,
.key-button span {
  display: block;
}

.key-button strong {
  font-size: 13px;
}

.key-button span {
  margin-top: 6px;
  font-size: 11px;
  color: var(--muted);
}

.key-button.calibration-key {
  min-height: 58px;
}

.key-button.calibration-key.calibrated:not(.active) {
  border-color: rgba(34, 197, 94, 0.36);
  background:
    linear-gradient(180deg, rgba(22, 54, 45, 0.92), rgba(10, 28, 24, 0.9));
}

.key-button.calibration-key.calibration-hot:not(.active) {
  border-color: rgba(239, 68, 68, 0.58);
  background:
    linear-gradient(180deg, rgba(91, 25, 28, 0.95), rgba(42, 9, 14, 0.92));
}

.key-button.calibration-key.calibration-finished:not(.active) {
  border-color: rgba(220, 38, 38, 0.82);
  background:
    linear-gradient(180deg, rgba(153, 27, 27, 0.94), rgba(69, 10, 10, 0.92));
}

.calibration-value-pair {
  display: grid !important;
  grid-template-columns: 1fr 1fr;
  gap: 4px;
  margin-top: 4px !important;
  font-size: 10px !important;
  line-height: 1;
}

.calibration-value-pair i {
  font-style: normal;
  color: rgba(226, 232, 240, 0.86);
}

.keymap-info-grid {
  margin-bottom: 14px;
}

.keymap-layer-panel {
  display: grid;
  gap: 14px;
  margin-bottom: 14px;
}

.layer-tab-group {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.layer-tab {
  min-height: 44px;
  border-radius: 14px;
  border: 1px solid rgba(148, 163, 184, 0.16);
  background: rgba(10, 18, 33, 0.82);
  color: var(--muted);
  font-weight: 600;
  cursor: pointer;
  transition:
    border-color 120ms ease,
    background-color 120ms ease,
    color 120ms ease,
    transform 120ms ease;
}

.layer-tab:hover {
  transform: translateY(-1px);
  border-color: rgba(56, 189, 248, 0.32);
  color: var(--text);
}

.layer-tab.active {
  border-color: rgba(34, 197, 94, 0.4);
  background: linear-gradient(180deg, rgba(18, 55, 39, 0.95), rgba(9, 24, 18, 0.9));
  color: #f0fff4;
}

.layer-summary-card {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  padding: 14px 16px;
  border: 1px solid rgba(148, 163, 184, 0.12);
  border-radius: 18px;
  background: rgba(8, 15, 28, 0.78);
}

.layer-summary-card span,
.layer-summary-card strong {
  display: block;
}

.layer-summary-card span {
  color: var(--muted);
  font-size: 12px;
}

.layer-summary-card strong {
  margin-top: 6px;
  color: var(--text);
  font-size: 15px;
}

.keymap-callout {
  margin-top: 6px;
}

.keymap-command-preview {
  margin: 10px 0 0;
  white-space: pre-wrap;
  word-break: break-word;
  color: #dbe7f6;
  font-family: Consolas, "Courier New", monospace;
  font-size: 13px;
  line-height: 1.7;
}

.rt-span-2 {
  grid-column: 1 / -1;
}

.rt-toggle {
  align-self: end;
  min-height: 48px;
}

.slider-card,
.workflow-card,
.callout-card {
  padding: 16px;
  background: rgba(8, 15, 28, 0.82);
}

.slider-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}

.slider-card input[type="range"] {
  padding: 0;
  background: transparent;
  border: 0;
}

.workflow-card p,
.callout-card p {
  margin: 8px 0 0;
  color: var(--muted);
  line-height: 1.6;
}

.callout-card {
  margin-top: 16px;
  background:
    linear-gradient(135deg, rgba(34, 197, 94, 0.12), rgba(56, 189, 248, 0.08)),
    rgba(8, 15, 28, 0.82);
}

.info-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-top: 16px;
  padding: 16px;
  border-radius: 18px;
  background: rgba(34, 197, 94, 0.08);
  border: 1px solid rgba(34, 197, 94, 0.18);
}

.info-banner p {
  margin: 0;
  color: #d6f7df;
  line-height: 1.6;
}

.danger-banner {
  background: rgba(239, 68, 68, 0.1);
  border-color: rgba(248, 113, 113, 0.28);
}

.danger-banner p {
  color: #fecaca;
}

.manual-keyid-row {
  display: grid;
  gap: 10px;
  margin-top: 14px;
}

.button-row.compact {
  justify-content: flex-start;
}

.snapshot-preview {
  margin: 16px 0 0;
  padding: 16px;
  min-height: 140px;
  border-radius: 18px;
  border: 1px solid rgba(148, 163, 184, 0.16);
  background: rgba(4, 11, 24, 0.48);
  color: #dbe7f6;
  white-space: pre-wrap;
  word-break: break-word;
  line-height: 1.6;
}

.compact-preview {
  min-height: 92px;
  max-height: 260px;
  overflow: auto;
}

@media (max-width: 720px) {
  .layer-tab-group,
  .layer-summary-card,
  .advanced-device-summary,
  .dks-stage-grid,
  .dks-quick-target {
    grid-template-columns: 1fr;
  }
}

.setting-stack {
  display: grid;
  gap: 10px;
}

.toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(148, 163, 184, 0.14);
  background: rgba(15, 23, 42, 0.7);
  color: var(--text);
}

.toggle-row span {
  color: var(--muted);
  font-size: 13px;
}

.button:disabled,
input:disabled,
textarea:disabled,
select:disabled {
  cursor: not-allowed;
  opacity: 0.55;
}

.collections-view,
.ports-view,
.log-view {
  border-radius: 18px;
  background: rgba(2, 6, 23, 0.48);
  border: 1px solid rgba(148, 163, 184, 0.12);
}

.collections-view,
.ports-view {
  min-height: 320px;
  padding: 16px;
}

.collection-card,
.port-card {
  padding: 14px;
  border-radius: 16px;
  border: 1px solid rgba(148, 163, 184, 0.1);
  background: rgba(15, 23, 42, 0.8);
}

.collection-card + .collection-card,
.port-card + .port-card {
  margin-top: 12px;
}

.collection-card.selected,
.port-card.selected {
  border-color: rgba(34, 197, 94, 0.38);
  background: rgba(20, 36, 28, 0.86);
}

.port-card.auto {
  border-color: rgba(56, 189, 248, 0.36);
}

.port-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.port-copy p {
  margin: 6px 0 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.5;
}

.collection-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.tag {
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(148, 163, 184, 0.12);
  color: #dbe7f6;
  font-size: 12px;
}

.tag.ok {
  background: rgba(34, 197, 94, 0.16);
  color: #bbf7d0;
}

.tag.warn {
  background: rgba(245, 158, 11, 0.16);
  color: #fde68a;
}

.empty-state {
  display: grid;
  place-items: center;
  color: var(--muted);
}

.log-panel {
  min-height: 280px;
}

.log-view {
  min-height: 220px;
  max-height: 420px;
  overflow: auto;
  padding: 14px;
  font-family: Consolas, "Courier New", monospace;
  font-size: 13px;
  line-height: 1.6;
}

.log-line {
  padding: 6px 0;
  border-bottom: 1px solid rgba(148, 163, 184, 0.08);
  white-space: pre-wrap;
  word-break: break-word;
}

.log-line.info {
  color: #dbe7f6;
}

.log-line.success {
  color: #bbf7d0;
}

.log-line.warn {
  color: #fde68a;
}

.log-line.error {
  color: #fecaca;
}

.monitor-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin-top: 16px;
}

.travel-measure-modal,
.travel-calibration-modal {
  position: fixed;
  inset: 0;
  z-index: 80;
  display: grid;
  place-items: center;
  padding: 34px;
  background: rgba(15, 23, 42, 0.38);
  backdrop-filter: blur(4px);
}

.travel-measure-modal[hidden],
.travel-calibration-modal[hidden] {
  display: none !important;
}

.travel-measure-modal-card,
.travel-calibration-modal-card {
  width: min(900px, calc(100vw - 70px));
  max-height: calc(100vh - 70px);
  overflow: auto;
  border-radius: 18px;
  border: 1px solid rgba(148, 163, 184, 0.36);
  background: #e8eef4;
  box-shadow: 0 28px 80px rgba(15, 23, 42, 0.28);
}

.travel-measure-modal-card {
  padding: 26px 28px;
}

.travel-calibration-modal-card {
  display: grid;
  gap: 22px;
  padding: 28px 34px 30px;
}

.travel-measure-modal-head,
.travel-calibration-modal-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 18px;
}

.travel-measure-modal-head h3,
.travel-calibration-modal-head h3 {
  margin: 0;
  color: #1e293b;
  font-size: 24px;
  font-weight: 900;
}

.travel-measure-modal-head p,
.travel-calibration-modal-head p,
.travel-calibration-status {
  margin: 6px 0 0;
  color: #475569;
  font-size: 14px;
  font-weight: 700;
}

.travel-calibration-keyboard-shell {
  padding: 20px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.5);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

.travel-calibration-keyboard-shell .keyboard-matrix {
  overflow-x: hidden;
}

.travel-calibration-keyboard-shell .keyboard-row {
  min-width: var(--official-keyboard-row-min);
  grid-template-columns: repeat(64, minmax(0, 1fr));
}

.travel-calibration-actions {
  display: flex;
  justify-content: flex-end;
  gap: 12px;
}

.travel-monitor-grid {
  display: grid;
  gap: 14px;
  min-height: 300px;
}

.field:has(#travel-monitor-focus-input),
.button-row.compact:has(#travel-monitor-focus-clear-button) {
  display: none;
}

.travel-monitor-chart {
  display: grid;
  gap: 18px;
  padding: 18px;
  min-height: 300px;
  border-radius: 28px;
  border: 1px solid rgba(148, 163, 184, 0.18);
  background:
    linear-gradient(180deg, rgba(15, 23, 42, 0.92), rgba(2, 6, 23, 0.86)),
    radial-gradient(circle at 18% 20%, rgba(56, 189, 248, 0.18), transparent 36%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.travel-monitor-chart-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.travel-monitor-chart-toolbar div {
  display: grid;
  gap: 4px;
}

.travel-monitor-chart-toolbar strong {
  color: #f8fafc;
  font-size: 16px;
}

.travel-monitor-chart-toolbar span {
  color: #94a3b8;
  font-size: 12px;
}

.travel-monitor-chart-body {
  display: grid;
  grid-template-columns: minmax(300px, 0.92fr) minmax(260px, 1fr);
  gap: 28px;
  min-height: 360px;
  align-items: stretch;
}

.travel-monitor-chart.official-measure-mode {
  background:
    radial-gradient(circle at 50% 12%, rgba(226, 232, 240, 0.84), transparent 42%),
    linear-gradient(180deg, #edf2f7, #dfe7ef);
  border-color: rgba(148, 163, 184, 0.42);
}

.travel-monitor-chart.official-measure-mode .travel-monitor-chart-toolbar strong {
  color: #0f172a;
}

.travel-monitor-chart.official-measure-mode .travel-monitor-chart-toolbar span {
  color: #475569;
}

.official-measure-body {
  grid-template-columns: minmax(420px, 0.95fr) minmax(260px, 0.7fr);
  align-items: center;
}

.travel-measure-official-panel {
  display: grid;
  gap: 22px;
  min-height: 360px;
  padding: 22px 28px 26px;
  border-radius: 16px;
  background: #e8eef4;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.82),
    0 20px 45px rgba(15, 23, 42, 0.14);
}

.travel-measure-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.travel-measure-title-row strong {
  color: #1e293b;
  font-size: 22px;
  font-weight: 900;
}

.travel-measure-title-row span {
  padding: 5px 12px;
  border-radius: 999px;
  background: rgba(59, 130, 246, 0.1);
  color: #2563eb;
  font-size: 12px;
  font-weight: 800;
}

.travel-measure-body {
  display: grid;
  grid-template-columns: 1fr 210px;
  gap: 38px;
  align-items: center;
}

.travel-measure-gauge {
  display: grid;
  grid-template-columns: 96px 118px;
  justify-content: end;
  gap: 28px;
  min-height: 278px;
}

.travel-measure-track {
  position: relative;
  width: 96px;
  height: 258px;
  align-self: center;
  overflow: hidden;
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(203, 213, 225, 0.98), rgba(226, 232, 240, 0.98)),
    repeating-linear-gradient(180deg, transparent 0 18px, rgba(71, 85, 105, 0.18) 18px 19px);
  box-shadow:
    inset 0 0 0 1px rgba(100, 116, 139, 0.22),
    inset 0 14px 24px rgba(255, 255, 255, 0.32);
}

.travel-measure-track::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    repeating-linear-gradient(180deg, transparent 0 9px, rgba(15, 23, 42, 0.18) 9px 10px),
    linear-gradient(90deg, transparent 0 42%, rgba(15, 23, 42, 0.06) 42% 58%, transparent 58%);
  pointer-events: none;
}

.travel-measure-fill {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 100%;
  min-height: 2px;
  background: linear-gradient(180deg, rgba(239, 68, 68, 0.96), rgba(248, 113, 113, 0.78));
  transform: scaleY(var(--travel-measure-scale, 0));
  transform-origin: top;
  transition: transform 150ms cubic-bezier(0.4, 0, 0.2, 1);
  will-change: transform;
}

.travel-measure-thumb {
  position: absolute;
  left: calc(100% + 10px);
  width: 34px;
  height: 3px;
  border-radius: 999px;
  background: #111827;
  transform: translateY(-50%);
  transition: top 150ms cubic-bezier(0.4, 0, 0.2, 1);
  will-change: top;
}

.travel-measure-ruler {
  position: relative;
  height: 258px;
  align-self: center;
  color: #111827;
  font-size: 12px;
  font-weight: 900;
}

.travel-measure-ruler span {
  position: absolute;
  left: 0;
  display: flex;
  align-items: center;
  gap: 10px;
  transform: translateY(-50%);
}

.travel-measure-ruler i {
  width: 42px;
  height: 2px;
  border-radius: 999px;
  background: #111827;
}

.travel-measure-ruler b {
  min-width: 54px;
}

.travel-measure-readout {
  display: grid;
  gap: 8px;
  margin: 0;
  color: #1f2937;
  font-size: 13px;
}

.travel-measure-readout div {
  display: grid;
  grid-template-columns: 78px 1fr;
  gap: 10px;
  align-items: baseline;
}

.travel-measure-readout dt {
  color: #334155;
  font-weight: 800;
}

.travel-measure-readout dd {
  margin: 0;
  color: #0f172a;
  font-weight: 900;
}

.travel-measure-empty {
  padding: 18px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.58);
  color: #475569;
  font-weight: 700;
  text-align: center;
}

.travel-measure-modal .travel-monitor-chart {
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.travel-measure-modal .travel-monitor-chart-toolbar,
.travel-measure-modal .travel-monitor-live-list {
  display: none;
}

.travel-measure-modal .official-measure-body {
  display: block;
  min-height: auto;
}

.travel-measure-modal .travel-measure-official-panel {
  min-height: 0;
  box-shadow: none;
}

.travel-monitor-official-gauge {
  position: relative;
  display: grid;
  grid-template-columns: 130px 120px;
  justify-content: center;
  gap: 24px;
  min-height: 330px;
  padding: 12px 0 18px;
}

.travel-monitor-gauge-bar {
  position: relative;
  min-height: 310px;
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(226, 232, 240, 0.96), rgba(203, 213, 225, 0.95)),
    repeating-linear-gradient(180deg, transparent 0 18px, rgba(71, 85, 105, 0.18) 18px 19px);
  box-shadow:
    inset 0 0 0 1px rgba(148, 163, 184, 0.36),
    inset 0 10px 28px rgba(255, 255, 255, 0.45),
    0 18px 40px rgba(15, 23, 42, 0.16);
}

.travel-monitor-gauge-bar::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background:
    repeating-linear-gradient(180deg, transparent 0 9px, rgba(15, 23, 42, 0.16) 9px 10px),
    linear-gradient(90deg, transparent 0 42%, rgba(15, 23, 42, 0.08) 42% 58%, transparent 58%);
  pointer-events: none;
}

.travel-monitor-gauge-marker {
  position: absolute;
  left: 100%;
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 116px;
  transform: translate(12px, -50%);
  border: 0;
  background: transparent;
  color: var(--marker-color);
  font-weight: 900;
  cursor: pointer;
  z-index: 2;
}

.travel-monitor-gauge-marker::before {
  content: "";
  width: 22px;
  height: 4px;
  border-radius: 999px;
  background: var(--marker-color);
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.82);
}

.travel-monitor-gauge-marker span {
  padding: 3px 7px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.9);
  color: #0f172a;
  font-size: 11px;
  box-shadow: 0 6px 16px rgba(15, 23, 42, 0.12);
}

.travel-monitor-gauge-marker.pressed span {
  color: var(--marker-color);
}

.travel-monitor-ruler {
  position: relative;
  min-height: 310px;
  color: #0f172a;
}

.travel-monitor-ruler span {
  position: absolute;
  left: 0;
  display: flex;
  align-items: center;
  gap: 10px;
  transform: translateY(-50%);
  font-size: 12px;
  font-weight: 900;
}

.travel-monitor-ruler i {
  width: 44px;
  height: 2px;
  border-radius: 999px;
  background: #334155;
}

.travel-monitor-ruler b {
  min-width: 48px;
}

.travel-monitor-live-list {
  display: grid;
  align-content: start;
  gap: 10px;
  overflow: auto;
  padding-right: 2px;
}

.travel-monitor-row {
  display: grid;
  grid-template-columns: 86px minmax(90px, 1fr) 70px;
  gap: 10px;
  align-items: center;
  min-height: 48px;
  padding: 10px 12px;
  border: 1px solid rgba(148, 163, 184, 0.2);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.08);
  color: #e2e8f0;
  text-align: left;
  cursor: pointer;
}

.travel-monitor-row-key,
.travel-monitor-row-value {
  font-weight: 900;
}

.travel-monitor-row-value {
  text-align: right;
  color: #f8fafc;
}

.travel-monitor-row-meta {
  grid-column: 1 / -1;
  color: #94a3b8;
  font-size: 11px;
}

.travel-monitor-row-bar {
  position: relative;
  height: 10px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(148, 163, 184, 0.2);
}

.travel-monitor-row-bar i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #38bdf8, #22c55e);
  transition: width 150ms cubic-bezier(0.4, 0, 0.2, 1);
}

.travel-monitor-row.pressed {
  border-color: rgba(34, 197, 94, 0.45);
  background: rgba(34, 197, 94, 0.1);
}

.travel-monitor-row.stale {
  opacity: 0.58;
}

.travel-monitor-row.focused .travel-monitor-row-key {
  color: #7dd3fc;
}

.travel-monitor-row.pending {
  opacity: 0.58;
}

.travel-monitor-chart-scale {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 10px 0 44px;
  color: #64748b;
  font-size: 11px;
  text-align: right;
}

.travel-monitor-columns {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(54px, 1fr);
  align-items: end;
  gap: 10px;
  min-width: 100%;
  overflow-x: auto;
  padding: 6px 4px 2px;
}

.travel-monitor-column {
  display: grid;
  grid-template-rows: auto minmax(150px, 1fr) auto auto;
  gap: 8px;
  min-width: 54px;
  border: 0;
  background: transparent;
  color: #e2e8f0;
  cursor: pointer;
}

.travel-monitor-column:focus-visible {
  outline: 2px solid rgba(56, 189, 248, 0.85);
  outline-offset: 4px;
}

.travel-monitor-column-value,
.travel-monitor-column-meta {
  color: #94a3b8;
  font-size: 11px;
  text-align: center;
  white-space: nowrap;
}

.travel-monitor-column-key {
  color: #f8fafc;
  font-weight: 800;
  text-align: center;
}

.travel-monitor-column-track {
  position: relative;
  display: flex;
  align-items: end;
  justify-content: center;
  min-height: 150px;
  border-radius: 18px;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(148, 163, 184, 0.16) 0 1px, transparent 1px 50%, rgba(148, 163, 184, 0.12) 50% calc(50% + 1px), transparent calc(50% + 1px)),
    rgba(15, 23, 42, 0.74);
  box-shadow: inset 0 0 0 1px rgba(148, 163, 184, 0.14);
}

.travel-monitor-column-fill,
.travel-monitor-column-ad {
  position: absolute;
  bottom: 0;
  border-radius: 16px 16px 0 0;
  transition: height 150ms cubic-bezier(0.4, 0, 0.2, 1);
}

.travel-monitor-column-fill {
  left: 8px;
  right: 8px;
  min-height: 2px;
  background: linear-gradient(180deg, rgba(34, 197, 94, 0.95), rgba(56, 189, 248, 0.75));
  box-shadow: 0 -10px 28px rgba(56, 189, 248, 0.18);
}

.travel-monitor-column-ad {
  right: 5px;
  width: 4px;
  background: linear-gradient(180deg, rgba(251, 191, 36, 0.92), rgba(249, 115, 22, 0.7));
  opacity: 0.72;
}

.travel-monitor-column.pressed .travel-monitor-column-track {
  box-shadow:
    inset 0 0 0 1px rgba(34, 197, 94, 0.32),
    0 12px 32px rgba(34, 197, 94, 0.12);
}

.travel-monitor-column.focused .travel-monitor-column-key {
  color: #7dd3fc;
}

.travel-monitor-column.pending {
  opacity: 0.62;
}

@media (max-width: 980px) {
  .shell,
  .grid {
    grid-template-columns: 1fr;
  }

  .shell {
    padding: 16px;
  }

  .info-grid {
    grid-template-columns: 1fr;
  }

  .settings-grid {
    grid-template-columns: 1fr;
  }

  .hero-grid,
  .rt-overview,
  .travel-layout,
  .rt-form-grid,
  .advanced-official-grid,
  .monitor-summary {
    grid-template-columns: 1fr;
  }

  .advanced-test-workspace {
    position: static;
  }

  .info-banner {
    align-items: stretch;
    flex-direction: column;
  }
}

/* Official-style operation layout: left module rail, focused workspace, keyboard-first pages. */
:root[data-theme="official"] {
  color-scheme: light;
  --bg: #f3f5f8;
  --panel: rgba(255, 255, 255, 0.94);
  --panel-border: rgba(31, 41, 55, 0.1);
  --panel-strong: #ffffff;
  --text: #172033;
  --muted: #667085;
  --accent: #2563eb;
  --accent-strong: #1d4ed8;
  --accent-soft: rgba(37, 99, 235, 0.1);
  --warning: #f59e0b;
  --danger: #dc2626;
  --neutral: #0f766e;
  --shadow: 0 18px 42px rgba(15, 23, 42, 0.08);
}

:root[data-theme="official"] body {
  min-height: 100vh;
  background:
    radial-gradient(circle at 17% 8%, rgba(37, 99, 235, 0.08), transparent 24%),
    radial-gradient(circle at 88% 16%, rgba(245, 158, 11, 0.1), transparent 22%),
    linear-gradient(135deg, #f7f9fc 0%, #eef2f7 52%, #f8fafc 100%);
  color: var(--text);
}

:root[data-theme="official"] .shell {
  grid-template-columns: 278px minmax(0, 1fr);
  gap: 18px;
  width: min(100%, 1680px);
  margin: 0 auto;
  padding: 18px;
}

:root[data-theme="official"] .sidebar {
  position: sticky;
  top: 18px;
  align-self: start;
  max-height: calc(100vh - 36px);
  overflow: auto;
  gap: 14px;
  padding-right: 2px;
}

:root[data-theme="official"] .workspace {
  gap: 16px;
  min-width: 0;
}

:root[data-theme="official"] .brand,
:root[data-theme="official"] .panel,
:root[data-theme="official"] .hero {
  border-radius: 18px;
  border-color: var(--panel-border);
  background: var(--panel);
  box-shadow: var(--shadow);
  backdrop-filter: none;
}

:root[data-theme="official"] .brand {
  padding: 16px;
}

:root[data-theme="official"] .brand-badge {
  width: 46px;
  height: 46px;
  border-radius: 13px;
  background: linear-gradient(135deg, #111827, #374151);
  color: #fff;
  font-size: 18px;
  letter-spacing: 0.08em;
}

:root[data-theme="official"] .brand h1 {
  font-size: 18px;
  font-weight: 850;
}

:root[data-theme="official"] .brand p {
  margin-top: 4px;
  font-size: 12px;
}

:root[data-theme="official"] .section-nav {
  position: static;
  display: grid;
  gap: 8px;
  padding: 12px;
  background: #ffffff;
}

:root[data-theme="official"] .section-nav::before {
  content: "功能菜单";
  padding: 4px 8px 8px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.12em;
}

:root[data-theme="official"] .nav-chip {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  width: 100%;
  min-height: 46px;
  padding: 10px 12px 10px 48px;
  border-radius: 14px;
  background: transparent;
  border-color: transparent;
  color: #4b5563;
  font-size: 14px;
  text-align: left;
}

:root[data-theme="official"] .nav-chip::before {
  content: attr(data-icon);
  position: absolute;
  left: 10px;
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 10px;
  background: #eef2f7;
  color: #64748b;
  font-size: 11px;
  font-weight: 900;
}

:root[data-theme="official"] .nav-chip:hover {
  transform: none;
  background: #f6f8fb;
  border-color: #e5e7eb;
  color: #111827;
}

:root[data-theme="official"] .nav-chip-active {
  background: #111827;
  border-color: #111827;
  color: #ffffff;
  box-shadow: 0 10px 22px rgba(17, 24, 39, 0.18);
}

:root[data-theme="official"] .nav-chip-active::before {
  background: #f59e0b;
  color: #111827;
}

:root[data-theme="official"] .section-nav::before {
  content: "功能菜单";
}

:root[data-theme="official"] .status-card {
  order: 3;
}

:root[data-theme="official"] .sidebar > .panel:not(.status-card) {
  order: 4;
}

:root[data-theme="official"] .hero {
  padding: 18px 20px;
  background:
    linear-gradient(135deg, rgba(17, 24, 39, 0.96), rgba(30, 41, 59, 0.94)),
    #111827;
  color: #fff;
}

:root[data-theme="official"] .hero-copy,
:root[data-theme="official"] .eyebrow {
  color: #cbd5e1;
}

:root[data-theme="official"] .hero-grid {
  grid-template-columns: minmax(0, 1.15fr) minmax(260px, 0.85fr);
  gap: 16px;
}

:root[data-theme="official"] .hero h2 {
  font-size: clamp(24px, 2.4vw, 36px);
  line-height: 1.16;
  font-weight: 900;
}

:root[data-theme="official"] .hero-stat {
  border-color: rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.08);
}

:root[data-theme="official"] .hero-stat span {
  color: #cbd5e1;
}

:root[data-theme="official"] .panel {
  padding: 18px;
}

:root[data-theme="official"] .panel-title-row {
  padding-bottom: 12px;
  border-bottom: 1px solid #edf0f4;
}

:root[data-theme="official"] .panel-title-row h2,
:root[data-theme="official"] .panel-title-row h3 {
  color: #111827;
  font-weight: 900;
}

:root[data-theme="official"] .pill-neutral,
:root[data-theme="official"] .pill-idle {
  background: #eef2f7;
  color: #475569;
}

:root[data-theme="official"] .pill-connected {
  background: #dcfce7;
  color: #166534;
}

:root[data-theme="official"] .pill-error {
  background: #fee2e2;
  color: #b91c1c;
}

:root[data-theme="official"] .button {
  border-radius: 12px;
  min-height: 38px;
  font-weight: 800;
}

:root[data-theme="official"] .button-primary {
  background: #111827;
  color: #fff;
}

:root[data-theme="official"] .button-secondary {
  background: #eef5ff;
  border-color: #c7ddff;
  color: #1d4ed8;
}

:root[data-theme="official"] .button-ghost {
  background: #f8fafc;
  border-color: #e5e7eb;
  color: #475569;
}

:root[data-theme="official"] .button-danger {
  background: #dc2626;
  border-color: #dc2626;
  color: #fff;
}

:root[data-theme="official"] .status-list div,
:root[data-theme="official"] .info-grid div,
:root[data-theme="official"] .metric-card,
:root[data-theme="official"] .setting-card,
:root[data-theme="official"] .callout-card,
:root[data-theme="official"] .slider-card {
  background: #f8fafc;
  border-color: #e5e7eb;
}

:root[data-theme="official"] .settings-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

:root[data-theme="official"] .field input,
:root[data-theme="official"] .field select,
:root[data-theme="official"] .field textarea,
:root[data-theme="official"] textarea,
:root[data-theme="official"] select,
:root[data-theme="official"] input {
  background: #ffffff;
  border-color: #d7dde7;
  color: #111827;
}

:root[data-theme="official"] .field span,
:root[data-theme="official"] .small,
:root[data-theme="official"] .section-copy {
  color: var(--muted);
}

:root[data-theme="official"] .keyboard-matrix {
  --official-keyboard-row-min: 0;
  --keyboard-row-min: var(--official-keyboard-row-min);
  padding: 14px;
  overflow-x: hidden;
  border: 1px solid #e5e7eb;
  border-radius: 18px;
  background:
    radial-gradient(circle at 12% 10%, rgba(37, 99, 235, 0.08), transparent 28%),
    linear-gradient(180deg, #f8fafc, #eef2f7);
}

:root[data-theme="official"] .key-button {
  border-radius: 12px;
  border-color: #d1d5db;
  background: linear-gradient(180deg, #ffffff, #eef2f7);
  color: #111827;
  box-shadow:
    inset 0 -2px 0 rgba(15, 23, 42, 0.08),
    0 8px 18px rgba(15, 23, 42, 0.05);
}

:root[data-theme="official"] .key-button:hover {
  transform: translateY(-2px);
  border-color: #93c5fd;
}

:root[data-theme="official"] .key-button.active {
  background: linear-gradient(180deg, #111827, #1f2937);
  border-color: #111827;
  color: #ffffff;
  box-shadow: 0 12px 28px rgba(17, 24, 39, 0.22);
}

:root[data-theme="official"] .key-button.ready:not(.active) {
  border-color: #60a5fa;
}

:root[data-theme="official"] .key-button.multi-selected:not(.active) {
  border-color: #f59e0b;
  background: linear-gradient(180deg, #fff7ed, #fed7aa);
  box-shadow:
    inset 0 0 0 2px rgba(245, 158, 11, 0.32),
    0 10px 24px rgba(245, 158, 11, 0.14);
}

:root[data-theme="official"] .key-button.remapped:not(.active) {
  border-color: #10b981;
  background: linear-gradient(180deg, #f0fdf4, #dcfce7);
}

:root[data-theme="official"] .key-button.special-key:not(.active) {
  border-color: #94a3b8;
  background: linear-gradient(180deg, #ffffff, #eef2f7);
}

:root[data-theme="official"] .key-button.has-magnetic-readback:not(.active) {
  border-color: #f59e0b;
  background: linear-gradient(180deg, #ffffff, #fef3c7);
  box-shadow:
    inset 0 0 0 2px rgba(245, 158, 11, 0.34),
    0 10px 22px rgba(245, 158, 11, 0.12);
}

:root[data-theme="official"] .keymap-feature-grid {
  grid-template-columns: minmax(0, 1fr);
}

:root[data-theme="official"] .keymap-feature-grid > .panel:first-child {
  min-height: 420px;
}

:root[data-theme="official"] .keymap-info-grid,
:root[data-theme="official"] .rt-overview {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

:root[data-theme="official"] .travel-layout {
  grid-template-columns: minmax(0, 1.55fr) minmax(360px, 0.75fr);
}

:root[data-theme="official"] .advanced-keyboard-panel,
:root[data-theme="official"] .dks-quick-panel,
:root[data-theme="official"] .advanced-binding-slot-panel,
:root[data-theme="official"] .advanced-device-panel,
:root[data-theme="official"] .advanced-full-editor,
:root[data-theme="official"] .advanced-function-rail,
:root[data-theme="official"] .advanced-binding-workspace,
:root[data-theme="official"] .advanced-test-workspace {
  background: #f8fafc;
  border-color: #e5e7eb;
}

:root[data-theme="official"] .advanced-official-panel {
  background:
    linear-gradient(180deg, #ffffff, #f8fafc);
}

:root[data-theme="official"] .advanced-keyboard-panel {
  margin-top: 14px;
}

:root[data-theme="official"] .advanced-official-grid {
  grid-template-columns: minmax(230px, 0.74fr) minmax(0, 1.64fr) minmax(280px, 0.86fr);
}

:root[data-theme="official"] .advanced-function-rail,
:root[data-theme="official"] .advanced-device-panel,
:root[data-theme="official"] .advanced-binding-workspace,
:root[data-theme="official"] .advanced-test-workspace {
  box-shadow: none;
}

:root[data-theme="official"] .advanced-device-card,
:root[data-theme="official"] .advanced-device-stat-card,
:root[data-theme="official"] .advanced-device-filter,
:root[data-theme="official"] .advanced-binding-slot,
:root[data-theme="official"] .advanced-device-empty-current,
:root[data-theme="official"] .advanced-device-empty-list {
  background: #ffffff;
  border-color: #e5e7eb;
}

:root[data-theme="official"] .advanced-device-filter.active {
  border-color: #111827;
  background: #111827;
  color: #ffffff;
}

:root[data-theme="official"] .advanced-device-filter.active strong {
  color: #ffffff;
}

:root[data-theme="official"] .advanced-device-index {
  background: #eef2f7;
  color: #64748b;
}

:root[data-theme="official"] .advanced-device-edit-hint {
  color: #2563eb;
}

:root[data-theme="official"] .advanced-binding-slot:hover {
  border-color: #93c5fd;
  background: #f8fafc;
}

:root[data-theme="official"] .advanced-binding-slot.active {
  border-color: #2563eb;
  background: #eff6ff;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
}

:root[data-theme="official"] .field.advanced-slot-control-active select,
:root[data-theme="official"] .field.advanced-slot-control-active input {
  border-color: #2563eb;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
}

:root[data-theme="official"] .advanced-device-type {
  background: #ecfdf5;
  color: #047857;
}

:root[data-theme="official"] .advanced-type-card {
  border-color: #e5e7eb;
  background: #ffffff;
  color: #111827;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.04);
}

:root[data-theme="official"] .advanced-type-card:hover {
  transform: none;
  border-color: #cbd5e1;
  background: #f8fafc;
}

:root[data-theme="official"] .advanced-type-card.active {
  border-color: #111827;
  background: #111827;
  color: #ffffff;
  box-shadow: 0 12px 24px rgba(17, 24, 39, 0.18);
}

:root[data-theme="official"] .advanced-type-card.active .advanced-type-name,
:root[data-theme="official"] .advanced-type-card.active small {
  color: #cbd5e1;
}

:root[data-theme="official"] .advanced-type-card strong {
  font-weight: 950;
}

:root[data-theme="official"] .advanced-key-test-input {
  border-radius: 16px;
  background: #ffffff;
}

:root[data-theme="official"] .advanced-key-live-output {
  border-color: #c7ddff;
  background:
    radial-gradient(circle at 10% 0%, rgba(37, 99, 235, 0.1), transparent 34%),
    linear-gradient(180deg, #ffffff, #eff6ff);
}

:root[data-theme="official"] .advanced-key-live-output strong {
  color: #111827;
}

:root[data-theme="official"] .dks-quick-panel {
  border-left: 5px solid #111827;
}

:root[data-theme="official"] .dks-quick-target {
  background: #ffffff;
  border-color: #e5e7eb;
}

:root[data-theme="official"] .snapshot-preview,
:root[data-theme="official"] .keymap-command-preview {
  background: #0f172a;
  color: #dbeafe;
  border-color: #1e293b;
}

:root[data-theme="official"] .info-banner {
  background: #eff6ff;
  border-color: #bfdbfe;
}

:root[data-theme="official"] .info-banner p {
  color: #1e3a8a;
}

:root[data-theme="official"] .danger-banner {
  background: #fef2f2;
  border-color: #fecaca;
}

:root[data-theme="official"] .danger-banner p {
  color: #991b1b;
}

:root[data-theme="official"] .ports-view,
:root[data-theme="official"] .collections-view {
  max-height: 220px;
  overflow: auto;
}

:root[data-theme="official"] .port-card {
  background: #f8fafc;
  border-color: #e5e7eb;
}

:root[data-theme="official"] .port-card.selected {
  border-color: #111827;
  box-shadow: inset 4px 0 0 #111827;
}

:root[data-workspace-view="keymap"] .hero,
:root[data-workspace-view="magnetic"] .hero,
:root[data-workspace-view="performance"] .hero,
:root[data-workspace-view="lighting"] .hero,
:root[data-workspace-view="rhythm"] .hero,
:root[data-workspace-view="advanced"] .hero,
:root[data-workspace-view="macro"] .hero,
:root[data-workspace-view="device"] .hero {
  display: none;
}

.macro-title-row {
  align-items: flex-start;
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}

.macro-workspace {
  display: grid;
  grid-template-columns: minmax(220px, 0.8fr) minmax(460px, 1.8fr) minmax(220px, 0.9fr);
  gap: 16px;
  margin-top: 18px;
}

.macro-official-layout {
  grid-template-columns: minmax(280px, 0.92fr) minmax(560px, 1.95fr) minmax(220px, 0.78fr);
  align-items: stretch;
}

.macro-slot-panel,
.macro-editor-panel,
.macro-settings-panel {
  border: 1px solid rgba(148, 163, 184, 0.28);
  border-radius: 22px;
  background: rgba(248, 250, 252, 0.9);
  padding: 16px;
  box-shadow: 0 16px 40px rgba(15, 23, 42, 0.06);
}

.macro-list-toolbar {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 18px;
  margin-bottom: 18px;
}

.macro-import-link {
  appearance: none;
  border: 0;
  background: transparent;
  color: #111827;
  font-weight: 800;
  cursor: pointer;
}

.macro-import-link::before {
  content: "↓";
  display: inline-block;
  margin-right: 6px;
  font-weight: 900;
}

.macro-create-button::before {
  content: "+";
  display: inline-block;
  margin-right: 6px;
  font-weight: 900;
}

.macro-dialog-backdrop {
  position: fixed;
  inset: 0;
  z-index: 120;
  display: grid;
  place-items: center;
  background: rgba(0, 0, 0, 0.38);
}

.macro-dialog-backdrop[hidden] {
  display: none;
}

.macro-create-dialog {
  display: grid;
  gap: 18px;
  width: min(328px, calc(100vw - 40px));
  border-radius: 4px;
  background: #fff;
  padding: 20px;
  box-shadow: 0 14px 36px rgba(15, 23, 42, 0.28);
}

.macro-import-file-name {
  min-height: 18px;
  margin: 0;
  color: #4b5563;
  font-size: 13px;
  word-break: break-all;
}

.macro-create-name-field {
  display: grid;
  gap: 18px;
  margin: 0;
}

.macro-create-name-field > span {
  color: #111827;
  font-size: 16px;
  font-weight: 500;
}

.macro-create-name-field input {
  width: 100%;
  min-height: 68px;
  border: 1px solid #d1d5db;
  border-radius: 4px;
  background: #fff;
  padding: 10px 12px;
  color: #111827;
  font-size: 16px;
}

.macro-create-error {
  min-height: 18px;
  margin: -8px 0 0;
  color: #dc2626;
  font-size: 13px;
}

.macro-create-dialog-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 8px;
}

.macro-create-dialog-actions .button {
  min-width: 76px;
  min-height: 44px;
  border-radius: 4px;
}

.button-success {
  border: 0;
  background: #70c779;
  color: #fff;
  box-shadow: 0 8px 20px rgba(34, 197, 94, 0.24);
}

.macro-slot-select {
  width: 100%;
  margin-bottom: 12px;
}

.macro-slot-list {
  display: grid;
  gap: 10px;
  max-height: 460px;
  overflow: auto;
  padding-right: 4px;
}

.macro-official-layout .macro-slot-list {
  min-height: 560px;
  align-content: start;
  padding: 0 8px 8px 0;
}

.macro-list-card {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  min-height: 52px;
  padding: 12px 18px 12px 10px;
  border: 2px solid transparent;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 4px 10px rgba(15, 23, 42, 0.14);
  cursor: pointer;
}

.macro-list-card::before {
  content: none;
}

.macro-list-card.active {
  border-color: #ff9800;
}

.macro-list-card strong {
  grid-column: 1;
  margin-left: 14px;
  color: #111827;
  font-size: 14px;
}

.macro-list-card small {
  grid-column: 1 / -1;
  margin-left: 14px;
  color: #64748b;
}

.macro-list-card-progress {
  position: relative;
  grid-column: 1;
  height: 20px;
  margin-left: 0;
  overflow: hidden;
  border-radius: 4px;
  background: #e5e7eb;
}

.macro-list-card-progress span {
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  height: 100%;
  max-width: calc(100% - 12px);
  min-width: 44px;
  padding: 0 8px;
  border-radius: inherit;
  background: linear-gradient(90deg, #52c566, #8dde70);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  line-height: 20px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.macro-list-card-progress b {
  display: none;
}

.macro-list-edit-button {
  grid-column: 2;
  grid-row: 1;
  min-width: 60px;
  height: 36px;
  border: 1px solid #ff9800;
  border-radius: 4px;
  background: #fff;
  color: #f97316;
  font-weight: 800;
  cursor: pointer;
}

.macro-context-menu {
  position: fixed;
  inset: auto;
  z-index: 80;
  display: grid;
  min-width: 160px;
  transform: none;
  overflow: hidden;
  border: 1px solid rgba(148, 163, 184, 0.45);
  border-radius: 4px;
  background: #fff;
  box-shadow: 0 16px 38px rgba(15, 23, 42, 0.18);
}

.macro-context-menu[hidden] {
  display: none;
}

.macro-context-menu button {
  border: 0;
  background: #fff;
  padding: 12px 16px;
  color: #111827;
  text-align: left;
  cursor: pointer;
}

.macro-context-menu button:hover {
  background: #f3f4f6;
}

.macro-list-empty {
  min-height: 240px;
}

.macro-slot-card {
  display: grid;
  gap: 4px;
  width: 100%;
  text-align: left;
  border: 1px solid rgba(148, 163, 184, 0.28);
  border-radius: 16px;
  background: #fff;
  color: #111827;
  padding: 12px;
  cursor: pointer;
}

.macro-slot-card span,
.macro-slot-card small {
  color: #64748b;
}

.macro-slot-card strong {
  font-size: 16px;
}

.macro-slot-card.active {
  border-color: #111827;
  background: #111827;
  color: #fff;
}

.macro-slot-card.active span,
.macro-slot-card.active small {
  color: rgba(255, 255, 255, 0.72);
}

.macro-small-actions,
.macro-side-actions {
  margin-top: 14px;
}

.macro-editor-header {
  display: grid;
  grid-template-columns: minmax(240px, 1fr) auto;
  gap: 14px;
  align-items: end;
}

.macro-name-field {
  margin: 0;
}

.macro-record-card {
  min-width: 130px;
  border-radius: 18px;
  background: #111827;
  color: #fff;
  padding: 12px 16px;
}

.macro-record-card span {
  display: block;
  color: rgba(255, 255, 255, 0.68);
  font-size: 12px;
}

.macro-record-card strong {
  display: block;
  font-size: 24px;
  line-height: 1.1;
}

.macro-record-pad {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
  margin: 14px 0;
  border: 1px dashed rgba(37, 99, 235, 0.36);
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(219, 234, 254, 0.86), rgba(240, 249, 255, 0.9));
  padding: 14px;
}

.macro-record-pad p {
  margin: 4px 0 0;
  color: #475569;
}

.macro-action-toolbar {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  color: #475569;
  margin: 10px 0;
}

.macro-action-toolbar span {
  font-weight: 800;
  color: #111827;
}

.macro-action-list {
  display: grid;
  gap: 10px;
  max-height: 520px;
  overflow: auto;
  padding-right: 4px;
}

.macro-empty-state {
  display: grid;
  place-items: center;
  min-height: 180px;
  border: 1px dashed rgba(148, 163, 184, 0.6);
  border-radius: 18px;
  color: #64748b;
  text-align: center;
}

.macro-empty-state strong {
  color: #111827;
}

.macro-action-row {
  display: grid;
  grid-template-columns: 42px minmax(120px, 1.2fr) minmax(96px, 0.8fr) minmax(96px, 0.8fr) minmax(90px, 0.7fr) auto;
  gap: 10px;
  align-items: end;
  border: 1px solid rgba(148, 163, 184, 0.28);
  border-radius: 18px;
  background: #fff;
  padding: 10px;
}

.macro-action-number {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  background: #eef2ff;
  color: #1d4ed8;
  font-weight: 800;
}

.macro-action-row label {
  display: grid;
  gap: 4px;
  margin: 0;
}

.macro-action-row small {
  color: #64748b;
}

.macro-action-row select,
.macro-action-row input {
  width: 100%;
}

.macro-action-buttons {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.macro-help-card {
  border-radius: 18px;
  background: #eef2ff;
  color: #334155;
  padding: 14px;
  margin: 14px 0;
}

.macro-help-card p {
  margin: 6px 0 0;
}

.macro-bottom-actions {
  margin-top: 16px;
}

.macro-debug-preview {
  display: none;
}

.macro-action-stage {
  position: relative;
  display: flex;
  flex: 1;
  flex-direction: column;
  min-height: 600px;
}

.macro-action-stage-header {
  display: flex;
  justify-content: flex-end;
  min-height: 44px;
}

.macro-action-stage-header > span {
  align-self: center;
  margin-right: auto;
  color: #475569;
  font-weight: 800;
}

.macro-batch-delay-button {
  min-height: 34px;
  border-radius: 4px;
}

.macro-official-action-table {
  flex: 1;
  align-content: start;
}

.macro-action-row.selected {
  border-color: #d2a12a;
  box-shadow:
    0 0 0 1px rgba(210, 161, 42, 0.35),
    0 8px 18px rgba(15, 23, 42, 0.16);
}

.macro-action-key-cell select,
.macro-action-type-cell select,
.macro-action-device-cell select {
  min-height: 30px;
}

.macro-action-delay-cell {
  display: grid !important;
  grid-template-columns: 34px minmax(72px, 1fr) 34px;
  gap: 0 !important;
  align-items: center;
}

.macro-action-delay-cell button {
  min-height: 34px;
  border: 1px solid #d8dee8;
  background: #f8fafc;
  color: #111827;
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
}

.macro-action-delay-cell input {
  min-height: 34px;
  border-right: 0;
  border-left: 0;
  border-radius: 0;
  text-align: center;
}

.macro-toolbar-footer {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 6px;
  margin-top: auto;
  padding-top: 14px;
}

.macro-toolbar-footer .button {
  min-width: 72px;
  min-height: 38px;
  border-radius: 4px;
}

.macro-toolbar-footer .button:disabled,
.macro-batch-delay-button:disabled,
.macro-loop-stepper button:disabled {
  opacity: 0.42;
  cursor: not-allowed;
  transform: none;
}

.macro-loop-stepper {
  display: grid;
  grid-template-columns: 36px minmax(74px, 1fr) 36px;
  align-items: center;
  overflow: hidden;
  border: 1px solid #d8dee8;
  border-radius: 3px;
  background: #fff;
}

.macro-loop-stepper button {
  min-height: 36px;
  border: 0;
  background: #f4f6fa;
  color: #111827;
  font-size: 20px;
  cursor: pointer;
}

.macro-loop-stepper input {
  min-height: 36px;
  border: 0;
  border-right: 1px solid #d8dee8;
  border-left: 1px solid #d8dee8;
  border-radius: 0;
  text-align: center;
}

:root[data-theme="official"] .macro-overview {
  display: none !important;
}

:root[data-theme="official"] .macro-workspace {
  grid-template-columns: minmax(300px, 0.78fr) minmax(640px, 1.55fr) minmax(150px, 0.34fr);
  gap: 8px;
  min-height: calc(100vh - 240px);
  margin-top: 10px;
}

:root[data-theme="official"] .macro-slot-panel,
:root[data-theme="official"] .macro-editor-panel {
  border-color: #d5d8df;
  border-radius: 4px;
  background: #ffffff;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.14);
}

:root[data-theme="official"] .macro-slot-panel {
  padding: 22px 24px;
}

:root[data-theme="official"] .macro-editor-panel {
  display: flex;
  flex-direction: column;
  padding: 18px 48px 14px;
}

:root[data-theme="official"] .macro-settings-panel {
  align-self: center;
  overflow: hidden;
  min-width: 150px;
  padding: 0;
  border-color: #cfd6df;
  border-radius: 4px;
  background: #eef1f5;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.18);
}

:root[data-theme="official"] .macro-settings-panel .field {
  display: grid;
  gap: 0;
  margin: 0;
}

:root[data-theme="official"] .macro-settings-panel .field > span {
  display: block;
  padding: 9px 10px;
  color: #475569;
  font-weight: 800;
  text-align: center;
}

:root[data-theme="official"] .macro-loop-type-field select {
  min-height: 34px;
  border: 0;
  border-top: 1px solid #d8dee8;
  border-bottom: 1px solid #d8dee8;
  border-radius: 0;
  background: #fff;
  color: #9a5b16;
}

:root[data-theme="official"] .macro-loop-count-field > span,
:root[data-theme="official"] .macro-help-card {
  display: none;
}

:root[data-theme="official"] .macro-loop-stepper {
  margin: 14px 0 18px;
  border-right: 0;
  border-left: 0;
  border-radius: 0;
}

:root[data-theme="official"] .macro-action-stage {
  min-height: 640px;
}

:root[data-theme="official"] .macro-action-stage-header {
  justify-content: flex-end;
}

:root[data-theme="official"] .macro-action-stage-header > span,
:root[data-theme="official"] .macro-action-toolbar {
  display: none;
}

:root[data-theme="official"] .macro-batch-delay-button {
  margin-left: auto;
  background: #df2440;
  border-color: #df2440;
  color: #fff;
  font-size: 12px;
  box-shadow: 0 2px 5px rgba(223, 36, 64, 0.22);
}

:root[data-theme="official"] .macro-official-action-table {
  gap: 0;
  max-height: none;
  padding: 20px 0 10px;
  overflow: auto;
}

:root[data-theme="official"] .macro-action-row {
  grid-template-columns: minmax(108px, 0.85fr) minmax(112px, 0.72fr) minmax(68px, 0.42fr) minmax(150px, 0.66fr);
  gap: 18px;
  min-height: 54px;
  margin: 0 0 4px;
  padding: 10px 64px;
  border: 1px solid #d8dee8;
  border-radius: 4px;
  background: #fbfbfc;
  box-shadow: 0 2px 6px rgba(15, 23, 42, 0.16);
}

:root[data-theme="official"] .macro-action-number {
  display: none;
}

:root[data-theme="official"] .macro-action-row label {
  display: flex;
  align-items: center;
}

:root[data-theme="official"] .macro-action-key-cell select {
  width: 104px;
  border-color: #dbeef9;
  background: #edf8ff;
  color: #3b9bc8;
  text-align: center;
}

:root[data-theme="official"] .macro-action-type-cell select {
  width: 72px;
  border-radius: 999px;
  font-weight: 800;
  text-align: center;
}

:root[data-theme="official"] .macro-action-type-down select {
  border-color: #63bd79;
  color: #25863f;
}

:root[data-theme="official"] .macro-action-type-up select {
  border-color: #d65764;
  color: #af2f3f;
}

:root[data-theme="official"] .macro-action-type-click select {
  border-color: #7aa5de;
  color: #285f9e;
}

:root[data-theme="official"] .macro-action-device-cell select {
  width: 68px;
  border-color: transparent;
  background: transparent;
  color: #64748b;
}

:root[data-theme="official"] .macro-action-delay-cell {
  grid-template-columns: 34px 86px 34px;
}

:root[data-theme="official"] .macro-toolbar-footer {
  position: sticky;
  bottom: 0;
  z-index: 3;
  padding: 12px 0 0;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0), #fff 34%);
}

:root[data-theme="official"] .macro-toolbar-footer .button {
  border: 1px solid #d7dce5;
  background: #fff;
  color: #111827;
  box-shadow: 0 2px 5px rgba(15, 23, 42, 0.14);
}

:root[data-theme="official"] .macro-toolbar-footer .macro-record-start-button {
  background: #35bd58;
  border-color: #35bd58;
  color: #fff;
}

:root[data-theme="official"] .macro-toolbar-footer .macro-record-stop-button,
:root[data-theme="official"] .macro-toolbar-footer #macro-action-delete-button,
:root[data-theme="official"] .macro-toolbar-footer #macro-clear-button {
  background: #df2440;
  border-color: #df2440;
  color: #fff;
}

/* Clean settings mode: hide protocol/debug surfaces from the everyday driver UI. */
:root[data-theme="official"] .hero-copy,
:root[data-theme="official"] #settings-stability-note,
:root[data-theme="official"] #profile-copy,
:root[data-theme="official"] #single-key-copy,
:root[data-theme="official"] #performance-copy,
:root[data-theme="official"] #lighting-copy,
:root[data-theme="official"] #rhythm-copy,
:root[data-theme="official"] #rhythm-mode-note,
:root[data-theme="official"] #advanced-key-copy,
:root[data-theme="official"] #advanced-key-keyboard-copy,
:root[data-theme="official"] #advanced-device-copy,
:root[data-theme="official"] #advanced-type-rail-copy,
:root[data-theme="official"] #advanced-binding-copy,
:root[data-theme="official"] #advanced-binding-slot-copy,
:root[data-theme="official"] #dks-quick-copy,
:root[data-theme="official"] #advanced-key-test-copy,
:root[data-theme="official"] #macro-copy,
:root[data-theme="official"] #keymap-description,
:root[data-theme="official"] #rt-description,
:root[data-theme="official"] #rt-preset-description,
:root[data-theme="official"] #travel-monitor-description,
:root[data-theme="official"] .info-banner:has(#profile-status-note),
:root[data-theme="official"] .info-banner:has(#single-key-status-note),
:root[data-theme="official"] .info-banner:has(#performance-status-note),
:root[data-theme="official"] .info-banner:has(#lighting-status-note),
:root[data-theme="official"] .info-banner:has(#rhythm-status-note),
:root[data-theme="official"] .info-banner:has(#dks-quick-status-note),
:root[data-theme="official"] .info-banner:has(#advanced-key-status-note),
:root[data-theme="official"] .info-banner:has(#keymap-status-note),
:root[data-theme="official"] .info-banner:has(#rt-status-note),
:root[data-theme="official"] .info-banner:has(#rt-batch-status-note),
:root[data-theme="official"] .info-banner:has(#travel-monitor-status-note),
:root[data-theme="official"] .info-banner:has(#display-status-note),
:root[data-theme="official"] #report-id,
:root[data-theme="official"] #report-id,
:root[data-theme="official"] .status-details div:has(#report-id),
:root[data-theme="official"] .status-details div:has(#port-name),
:root[data-theme="official"] .panel:has(#ports-title),
:root[data-theme="official"] .panel:has(#collections-title),
:root[data-theme="official"] .panel:has(#progress-title),
:root[data-theme="official"] .panel:has(#display-title),
:root[data-theme="official"] .panel:has(#snapshot-title),
:root[data-theme="official"] .panel:has(#tools-title),
:root[data-theme="official"] .panel:has(#diagnostics-title),
:root[data-theme="official"] .panel:has(#workflow-title),
:root[data-theme="official"] .panel:has(#raw-title),
:root[data-theme="official"] .panel:has(#performance-title),
:root[data-theme="official"] .panel:has(#recovered-title),
:root[data-theme="official"] .panel:has(#log-title),
:root[data-theme="official"] #device-sync-preview,
:root[data-theme="official"] #lighting-preview,
:root[data-theme="official"] #advanced-key-stage-preview,
:root[data-theme="official"] #advanced-key-preview,
:root[data-theme="official"] #advanced-key-capture-panel,
:root[data-theme="official"] #macro-binding-preview,
:root[data-theme="official"] #display-preview,
:root[data-theme="official"] #snapshot-preview,
:root[data-theme="official"] #snapshot-diff-preview,
:root[data-theme="official"] #tools-preview,
:root[data-theme="official"] #diagnostics-preview,
:root[data-theme="official"] #travel-monitor-probe-preview,
:root[data-theme="official"] #keymap-command-preview,
:root[data-theme="official"] .callout-card:has(#keymap-command-title),
:root[data-theme="official"] .panel:has(#rt-batch-title),
:root[data-theme="official"] .metric-card:has(#single-key-route),
:root[data-theme="official"] .metric-card:has(#keymap-layer-route),
:root[data-theme="official"] .metric-card:has(#rt-current-port),
:root[data-theme="official"] .metric-card:has(#rt-current-report) {
  display: none !important;
}

:root[data-theme="official"] #device-info-grid > div:nth-child(1),
:root[data-theme="official"] #device-info-grid > div:nth-child(7),
:root[data-theme="official"] #device-info-grid > div:nth-child(8),
:root[data-theme="official"] #device-info-grid > div:nth-child(14) {
  display: none !important;
}

.setting-card.hidden-by-device {
  display: none !important;
}

:root[data-workspace-view="device"] .panel:has(#base-info-title) {
  display: none !important;
}

.panel:has(#performance-title) {
  display: none !important;
}

:root[data-theme="official"] #profile-panel {
  margin: 0;
  padding: 18px 16px;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

:root[data-theme="official"] #profile-panel .panel-title-row {
  display: block;
  margin: 0 0 16px;
}

:root[data-theme="official"] #profile-panel #profile-title {
  color: #ffffff;
  font-size: 20px;
  font-weight: 900;
}

:root[data-theme="official"] #profile-panel #profile-pill {
  display: none !important;
}

:root[data-theme="official"] #profile-panel .button-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

:root[data-theme="official"] #profile-panel .button {
  width: 100%;
  min-height: 48px;
  border: 0;
  border-radius: 4px;
  color: #ffffff;
  font-weight: 800;
  background: #383e46;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.24);
}

:root[data-theme="official"] #profile-panel .button-primary {
  background: #070b12;
}

:root[data-theme="official"] #profile-panel .button-secondary {
  background: #383e46;
}

:root[data-theme="official"] #profile-panel .button:hover {
  filter: brightness(1.08);
}

.profile-context-menu {
  position: fixed;
  z-index: 9999;
  min-width: 128px;
  padding: 8px;
  border: 1px solid #d7dde7;
  border-radius: 4px;
  background: #ffffff;
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.18);
}

.profile-context-menu button {
  display: block;
  width: 100%;
  padding: 10px 12px;
  border: 0;
  border-radius: 4px;
  background: transparent;
  color: #111827;
  font-weight: 700;
  text-align: left;
  cursor: pointer;
}

.profile-context-menu button:hover {
  background: #f1f5f9;
}

:root[data-theme="official"] #advanced-key-copy-button,
:root[data-theme="official"] #macro-copy-button,
:root[data-theme="official"] #macro-binding-copy-button,
:root[data-theme="official"] #display-copy-button,
:root[data-theme="official"] #display-import-json-button,
:root[data-theme="official"] #keymap-copy-button,
:root[data-theme="official"] #keymap-assign-rt-button {
  display: none !important;
}

:root[data-theme="official"] [data-workspace-view="tools"],
:root[data-theme="official"] [data-workspace-view="logs"],
:root[data-theme="official"] [data-workspace-view="official"] {
  display: none !important;
}

.magnetic-workbench-panel {
  overflow: hidden;
}

.magnetic-hidden-input {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip: rect(0 0 0 0) !important;
  clip-path: inset(50%) !important;
  white-space: nowrap !important;
  border: 0 !important;
  padding: 0 !important;
}

.magnetic-official-page {
  display: grid;
  gap: 8px;
  padding: 0;
  background: #ffffff;
}

.magnetic-page-heading,
.magnetic-state-strip {
  display: none;
}

.magnetic-official-stage {
  display: grid;
  grid-template-columns: minmax(680px, 1fr) 128px;
  gap: 28px;
  align-items: center;
  min-height: 430px;
  padding: 54px 112px 38px;
  border: 1px solid #d8dde6;
  border-radius: 6px;
  background: #ffffff;
}

.magnetic-keyboard-shell {
  display: grid;
  justify-items: center;
  gap: 12px;
  min-width: 0;
}

.magnetic-keyboard-shell .keyboard-matrix {
  width: min(820px, 100%);
  overflow-x: hidden;
  transform-origin: center;
}

.magnetic-keyboard-shell .keyboard-row {
  min-width: var(--official-keyboard-row-min);
  grid-template-columns: repeat(64, minmax(0, 1fr));
}

.magnetic-mode-tabs {
  display: inline-flex;
  align-items: center;
  overflow: hidden;
  border: 1px solid #1676d2;
  border-radius: 999px;
  background: #ffffff;
}

.magnetic-mode-tab {
  min-width: 86px;
  min-height: 34px;
  padding: 0 16px;
  border: 0;
  background: transparent;
  color: #1676d2;
  font-weight: 850;
  cursor: pointer;
}

.magnetic-mode-tab.active {
  background: #1676d2;
  color: #ffffff;
}

.magnetic-select-actions {
  display: grid;
  gap: 6px;
  align-content: center;
}

.magnetic-select-actions .button {
  width: 100%;
  min-height: 34px;
  border-radius: 4px;
  font-size: 14px;
}

.magnetic-select-actions .button-primary,
.magnetic-select-actions .button-secondary {
  background: #7e22ce;
  border-color: #7e22ce;
  color: #ffffff;
}

.magnetic-select-actions .button-danger {
  margin-top: 28px;
  background: #f10f0f;
  border-color: #f10f0f;
}

.magnetic-performance-columns {
  display: grid;
  grid-template-columns: minmax(620px, 1.16fr) minmax(330px, 0.78fr) minmax(330px, 0.82fr);
  min-height: 410px;
  overflow: hidden;
  border: 1px solid #d8dde6;
  border-radius: 6px;
  background: #edf1f6;
}

.magnetic-performance-column {
  display: grid;
  align-content: start;
  gap: 22px;
  min-width: 0;
  overflow: hidden;
  padding: clamp(20px, 1.45vw, 28px) clamp(22px, 1.7vw, 34px);
  border-right: 1px solid #cbd3df;
}

.magnetic-performance-column:last-child {
  border-right: 0;
}

.magnetic-column-head {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  justify-content: space-between;
  min-height: 54px;
}

.magnetic-column-head h3 {
  margin: 0;
  color: #111827;
  font-size: 20px;
  font-weight: 900;
}

.magnetic-column-head p {
  margin: 4px 0 0;
  color: #475569;
  font-size: 13px;
  line-height: 1.45;
}

.magnetic-axis-row {
  display: grid;
  grid-template-columns: auto minmax(130px, 1fr) repeat(2, minmax(104px, max-content));
  gap: 12px;
  align-items: center;
}

.magnetic-axis-row > span {
  color: #111827;
  font-weight: 850;
}

.magnetic-axis-row select {
  min-width: 0;
  width: 100%;
}

.magnetic-axis-row .button {
  white-space: nowrap;
  min-height: 38px;
  border-radius: 3px;
}

.magnetic-axis-row .button-primary {
  background: #7e22ce;
  border-color: #7e22ce;
}

.travel-depth-control {
  display: grid;
  grid-template-columns: minmax(160px, 0.72fr) minmax(126px, auto) minmax(136px, 0.58fr);
  grid-template-areas: "switch slider readout";
  gap: clamp(10px, 1vw, 18px);
  align-items: center;
  min-height: 300px;
}

.switch-cross-section {
  position: relative;
  grid-area: switch;
  width: min(168px, 100%);
  height: 210px;
  margin: 0 auto;
  opacity: 0.72;
}

.switch-housing {
  position: absolute;
  left: 15px;
  right: 15px;
  bottom: 18px;
  height: 104px;
  border: 2px solid #8d95a1;
  border-top: 0;
  background:
    linear-gradient(90deg, transparent 0 46%, #9aa2ad 46% 54%, transparent 54%),
    linear-gradient(180deg, rgba(255,255,255,0.5), rgba(226,232,240,0.12));
}

.switch-stem {
  position: absolute;
  left: calc(50% - 32px);
  top: 8px;
  width: 64px;
  height: 84px;
  border: 2px solid #6b7280;
  border-bottom: 0;
  background:
    repeating-linear-gradient(90deg, rgba(107,114,128,0.55) 0 2px, transparent 2px 19px),
    #f8fafc;
}

.switch-spring {
  position: absolute;
  left: calc(50% - 29px);
  bottom: 46px;
  width: 58px;
  height: 70px;
  border-left: 2px solid #9ca3af;
  border-right: 2px solid #9ca3af;
  background: repeating-linear-gradient(180deg, transparent 0 9px, #9ca3af 9px 11px);
}

.travel-depth-slider-wrap {
  grid-area: slider;
  display: grid;
  grid-template-columns: 34px 38px 64px;
  grid-template-rows: 34px 218px 34px;
  gap: 0 10px;
  align-items: center;
  justify-self: center;
  min-width: 120px;
  position: relative;
  z-index: 1;
}

.travel-depth-step {
  grid-column: 2;
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border: 0;
  border-radius: 50%;
  background: #d1d5db;
  color: #111827;
  font-size: 20px;
  font-weight: 900;
  cursor: pointer;
}

.travel-depth-step:first-child {
  grid-row: 1;
}

.travel-depth-step:last-child {
  grid-row: 3;
}

.travel-depth-slider {
  grid-column: 2;
  grid-row: 2;
  width: 32px;
  height: 218px;
  transform: none;
  writing-mode: vertical-lr;
  direction: rtl;
  accent-color: #1d70c9;
}

.travel-depth-ruler {
  position: relative;
  grid-column: 3;
  grid-row: 2;
  height: 218px;
  border-left: 2px solid #111827;
}

.travel-depth-ruler::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 -1px;
  width: 18px;
  background: repeating-linear-gradient(180deg, #111827 0 2px, transparent 2px 8px);
}

.travel-depth-ruler span {
  position: absolute;
  left: -34px;
  transform: translateY(-50%);
  color: #111827;
  font-size: 10px;
  font-weight: 800;
}

.travel-depth-readout {
  grid-area: readout;
  display: grid;
  gap: 10px;
  align-self: center;
  width: min(170px, 100%);
  max-width: 150px;
  justify-items: start;
  position: relative;
  z-index: 2;
}

.travel-depth-readout .button {
  width: 100%;
  white-space: nowrap;
}

.travel-depth-value {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 5px 12px;
  border-radius: 4px;
  background: #1676d2;
  color: #ffffff;
  font-size: 13px;
  white-space: nowrap;
}

#travel-depth-unit-value {
  color: #64748b;
  font-weight: 800;
}

.rt-tuning-body,
.deadzone-tuning-body {
  opacity: 0.42;
  transition: opacity 140ms ease;
}

.deadzone-tuning-body {
  pointer-events: none;
}

.rt-tuning-body.active,
.deadzone-tuning-body.active {
  opacity: 1;
  pointer-events: auto;
}

.rt-tuning-body {
  display: grid;
  grid-template-columns: repeat(2, minmax(118px, 160px));
  gap: 18px;
  align-items: start;
  justify-content: center;
  margin-top: 16px;
}

.rt-tuning-body.rt-independent {
  grid-template-columns: repeat(2, minmax(118px, 160px));
}

.rt-slider-card {
  display: grid;
  gap: 10px;
  min-height: 318px;
  justify-items: center;
  color: #475569;
  font-weight: 750;
}

.rt-slider-card > span {
  color: #475569;
  font-size: 13px;
  text-align: center;
}

.rt-slider-row {
  display: grid;
  grid-template-columns: 32px 30px 32px;
  grid-template-rows: 28px 220px 32px;
  grid-template-areas:
    "minus . plus"
    ". slider ."
    "value value value";
  gap: 8px;
  align-items: center;
  justify-items: center;
}

.rt-step {
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border: 0;
  border-radius: 50%;
  background: #d1d5db;
  color: #111827;
  font-size: 19px;
  font-weight: 900;
  cursor: pointer;
}

.rt-slider-row .rt-step:first-child {
  grid-area: minus;
}

.rt-slider-row .rt-step:nth-of-type(2) {
  grid-area: plus;
}

.rt-slider {
  grid-area: slider;
  width: 30px;
  height: 220px;
  min-width: 0;
  transform: none;
  writing-mode: vertical-lr;
  direction: rtl;
  accent-color: #1676d2;
}

.rt-value {
  grid-area: value;
  width: auto;
  min-width: 64px;
  padding: 4px 8px;
  border-radius: 4px;
  background: #1676d2;
  color: #ffffff;
  text-align: center;
  white-space: nowrap;
}

.rt-independent-row {
  grid-column: 1 / -1;
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: center;
  color: #475569;
  font-size: 13px;
  line-height: 1.35;
}

.rt-independent-row input {
  width: 40px;
  height: 22px;
  accent-color: #1676d2;
}

.deadzone-tuning-body {
  display: grid;
  grid-template-columns: repeat(2, minmax(120px, 1fr));
  gap: 42px;
  align-items: start;
  justify-items: center;
  margin-top: 8px;
}

.deadzone-slider-card {
  display: grid;
  grid-template-rows: auto 32px 220px 32px auto;
  gap: 10px;
  min-height: 330px;
  align-items: center;
  justify-items: center;
  color: #111827;
  font-weight: 850;
}

.deadzone-slider-card span {
  color: #111827;
  font-size: 14px;
}

.deadzone-slider {
  width: 28px;
  height: 220px;
  transform: none;
  writing-mode: vertical-lr;
  direction: rtl;
  accent-color: #7e22ce;
}

.deadzone-step {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border: 0;
  border-radius: 50%;
  background: #d1d5db;
  color: #111827;
  font-size: 19px;
  font-weight: 900;
  cursor: pointer;
}

.deadzone-slider-card strong {
  padding: 5px 10px;
  border-radius: 4px;
  background: #7e22ce;
  color: #ffffff;
}

.magnetic-official-switch {
  position: relative;
  display: inline-flex;
  flex: 0 0 auto;
  width: 44px;
  height: 24px;
  cursor: pointer;
}

.magnetic-official-switch input {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  opacity: 0;
  cursor: pointer;
  pointer-events: auto;
}

.magnetic-official-switch span {
  position: absolute;
  inset: 0;
  border-radius: 999px;
  background: #9ca3af;
  pointer-events: none;
  transition: background 140ms ease;
}

.magnetic-official-switch span::after {
  content: "";
  position: absolute;
  top: 3px;
  left: 3px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #ffffff;
  box-shadow: 0 2px 5px rgba(15, 23, 42, 0.24);
  transition: transform 140ms ease;
}

.magnetic-official-switch input:checked + span {
  background: #1676d2;
}

.magnetic-official-switch input:checked + span::after {
  transform: translateX(20px);
}

.magnetic-status-line {
  min-height: 36px;
  padding: 8px 18px 14px;
  color: #475569;
  font-size: 13px;
}

.magnetic-status-line p {
  margin: 0;
}

:root[data-theme="official"] .magnetic-workbench-panel + .keymap-feature-grid {
  margin-top: 20px;
}

:root[data-theme="official"] .keymap-official-page {
  border-radius: 4px;
  background: #f7f9fb;
  box-shadow: none;
}

:root[data-theme="official"] .keymap-official-stage {
  border-radius: 0;
}

:root[data-theme="official"] .keymap-official-matrix {
  padding: 6px;
  border: 1px solid #9ba4a8;
  border-radius: 0;
  background: linear-gradient(180deg, #f3fbfd, #c8edf4);
}

:root[data-theme="official"] .keymap-official-matrix .key-button {
  min-height: 38px;
  padding: 4px 3px;
  color: #111827;
  text-align: center;
  background: linear-gradient(180deg, #ffffff, #e5e9ec 56%, #c7ced2);
  border-color: #9aa6ac;
  border-radius: 4px;
  box-shadow:
    inset 0 2px 2px rgba(255, 255, 255, 0.85),
    0 2px 3px rgba(15, 23, 42, 0.2);
}

:root[data-theme="official"] .keymap-official-matrix .key-button.active {
  color: #111827;
  background: linear-gradient(180deg, #ffffff, #eff6ff 60%, #dbeafe);
  border-color: #f59e0b;
  box-shadow:
    inset 0 0 0 1px #f59e0b,
    0 0 0 2px rgba(245, 158, 11, 0.35),
    0 2px 3px rgba(15, 23, 42, 0.16);
}

:root[data-theme="official"] .keymap-official-matrix .key-button span {
  display: none;
}

:root[data-theme="official"] .keymap-keyboard-shell,
:root[data-theme="official"] .magnetic-keyboard-shell,
:root[data-theme="official"] .lighting-keyboard-shell,
:root[data-theme="official"] .rhythm-keyboard-shell,
:root[data-theme="official"] .travel-calibration-keyboard-shell,
:root[data-theme="official"] .advanced-keyboard-panel {
  --official-board-width: 1050px;
  display: grid;
  justify-items: center;
  min-width: 0;
  width: min(var(--official-board-width), 100%);
  margin-inline: auto;
  padding: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

:root[data-theme="official"] .advanced-keyboard-matrix {
  margin-inline: auto;
}

:root[data-theme="official"] .keyboard-matrix {
  --official-keyboard-row-min: 0;
  --keyboard-row-min: var(--official-keyboard-row-min);
  position: relative;
  width: min(var(--official-board-width, 1050px), 100%);
  max-width: 100%;
  gap: 4px;
  padding: 52px 22px 28px;
  overflow-x: hidden;
  border: 0;
  border-radius: 12px 12px 4px 4px;
  background:
    linear-gradient(180deg, rgba(77, 83, 86, 0.86), rgba(87, 94, 98, 0.95)) left 42px bottom 10px / 13px calc(100% - 46px) no-repeat,
    linear-gradient(180deg, rgba(245, 247, 245, 0.95), rgba(128, 137, 139, 0.92)) right 42px bottom 10px / 13px calc(100% - 46px) no-repeat,
    linear-gradient(180deg, #f7fbfc 0%, #dbeef2 62%, #b8d2d9 100%);
  box-shadow:
    0 16px 26px rgba(15, 23, 42, 0.18),
    inset 0 0 0 1px rgba(71, 85, 105, 0.2);
}

:root[data-theme="official"] .keyboard-matrix::before,
:root[data-theme="official"] .keyboard-matrix::after {
  position: absolute;
  right: 0;
  left: 0;
  z-index: 0;
  pointer-events: none;
  content: "";
}

:root[data-theme="official"] .keyboard-matrix::before {
  top: 0;
  height: 48px;
  border-radius: 10px 10px 0 0;
  background:
    linear-gradient(90deg, #5b6062 0%, #c7ccc8 13%, #f5f6f1 52%, #aeb5b2 87%, #5b6062 100%),
    repeating-linear-gradient(0deg, rgba(255, 255, 255, 0.16) 0 1px, transparent 1px 3px);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.58),
    inset 0 -3px 7px rgba(15, 23, 42, 0.25);
}

:root[data-theme="official"] .keyboard-matrix::after {
  bottom: 0;
  height: 22px;
  border-radius: 0 0 4px 4px;
  background:
    linear-gradient(90deg, #6a6f6f 0%, #d6d9d5 14%, #eff2ed 55%, #899290 100%);
  box-shadow:
    inset 0 2px 3px rgba(255, 255, 255, 0.32),
    inset 0 -4px 7px rgba(15, 23, 42, 0.2);
}

:root[data-theme="official"] .keyboard-matrix .keyboard-row {
  position: relative;
  z-index: 1;
  min-width: var(--official-keyboard-row-min);
  grid-template-columns: repeat(64, minmax(0, 1fr));
  gap: 4px;
}

:root[data-theme="official"] .keyboard-matrix.compact .keyboard-row,
:root[data-theme="official"] .keyboard-matrix.travel-keyboard-matrix .keyboard-row {
  min-width: var(--official-keyboard-row-min);
}

:root[data-theme="official"] .keyboard-matrix .key-button,
:root[data-theme="official"] .keyboard-matrix.compact .key-button {
  position: relative;
  min-height: 39px;
  padding: 4px 3px;
  overflow: hidden;
  color: #07111f;
  text-align: center;
  background:
    linear-gradient(180deg, rgba(249, 254, 255, 0.98) 0%, rgba(221, 248, 252, 0.98) 36%, rgba(185, 232, 241, 0.98) 72%, rgba(142, 197, 208, 0.98) 100%);
  border: 1px solid #5f95a5;
  border-radius: 5px;
  box-shadow:
    inset 0 2px 2px rgba(255, 255, 255, 0.9),
    inset 0 -4px 0 rgba(58, 106, 121, 0.18),
    0 2px 3px rgba(15, 23, 42, 0.22);
}

:root[data-theme="official"] .keyboard-matrix .key-button:hover {
  border-color: #f59e0b;
  transform: translateY(-1px);
}

:root[data-theme="official"] .keyboard-matrix .key-button strong {
  position: relative;
  z-index: 1;
  display: grid;
  min-height: 1em;
  place-items: center;
  font-size: 10px;
  font-weight: 650;
  line-height: 1;
  white-space: nowrap;
}

:root[data-theme="official"] .keyboard-matrix .key-button > span:not(.magnetic-key-readback):not(.calibration-value-pair) {
  display: none;
}

:root[data-theme="official"] .keyboard-matrix .key-button.active {
  color: #ffffff;
  background: linear-gradient(180deg, #111827, #1f2937);
  border-color: #111827;
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.18),
    0 8px 16px rgba(15, 23, 42, 0.24);
}

:root[data-theme="official"] .keyboard-matrix .key-button.special-key:not(.active),
:root[data-theme="official"] .keyboard-matrix .key-button.vendor:not(.active) {
  color: #07111f;
  background:
    linear-gradient(180deg, rgba(249, 254, 255, 0.98) 0%, rgba(221, 248, 252, 0.98) 36%, rgba(185, 232, 241, 0.98) 72%, rgba(142, 197, 208, 0.98) 100%);
  border-color: #5f95a5;
}

:root[data-theme="official"] .keyboard-matrix .key-button.remapped:not(.active) {
  background: linear-gradient(180deg, #ecfdf5, #bbf7d0);
  border-color: #10b981;
}

:root[data-theme="official"] .keymap-official-matrix .key-button.remapped {
  cursor: context-menu;
}

:root[data-theme="official"] .keymap-official-matrix .key-button.remapped:hover {
  z-index: 8;
  overflow: visible;
}

:root[data-theme="official"] .keyboard-matrix .key-button.multi-selected:not(.active) {
  color: #111827;
  background: linear-gradient(180deg, #fffdf7, #fef3c7 64%, #fde68a);
  border-color: #f59e0b;
  box-shadow:
    inset 0 0 0 2px rgba(245, 158, 11, 0.45),
    0 2px 3px rgba(15, 23, 42, 0.2);
}

:root[data-theme="official"] .keyboard-matrix .key-button.has-magnetic-readback:not(.active),
:root[data-theme="official"] .keyboard-matrix .key-button.has-magnetic-readback.special-key:not(.active),
:root[data-theme="official"] .keyboard-matrix .key-button.has-magnetic-readback.vendor:not(.active) {
  color: #07111f;
  background:
    linear-gradient(180deg, rgba(224, 251, 255, 0.98) 0%, rgba(190, 239, 247, 0.98) 100%);
  border-color: #f59e0b;
  box-shadow:
    inset 0 0 0 2px rgba(245, 158, 11, 0.78),
    0 2px 3px rgba(15, 23, 42, 0.18);
}

:root[data-theme="official"] .keyboard-matrix .key-button.has-magnetic-readback > strong {
  opacity: 0.92;
}

:root[data-theme="official"] .keyboard-matrix .key-button.has-magnetic-readback::after {
  position: absolute;
  bottom: 2px;
  left: 50%;
  z-index: 3;
  color: #8b5cf6;
  font-size: 9px;
  font-weight: 950;
  line-height: 1;
  text-shadow: 0 1px 1px rgba(255, 255, 255, 0.8);
  transform: translateX(-50%);
  content: "▲";
}

:root[data-theme="official"] .keyboard-matrix .magnetic-key-readback {
  inset: 2px auto auto 3px;
  z-index: 4;
  display: grid;
  max-width: calc(100% - 6px);
  gap: 0;
  margin: 0;
  color: #111827;
  font-size: 9px;
  line-height: 1.02;
  text-align: left;
}

:root[data-theme="official"] .keyboard-matrix .magnetic-key-readback i {
  display: block;
  font-weight: 900;
  letter-spacing: -0.03em;
}

:root[data-theme="official"] .keyboard-matrix .magnetic-readback-travel {
  color: #111827;
}

:root[data-theme="official"] .keyboard-matrix .magnetic-readback-press,
:root[data-theme="official"] .keyboard-matrix .magnetic-readback-top {
  color: #ef4444;
}

:root[data-theme="official"] .keyboard-matrix .magnetic-readback-release,
:root[data-theme="official"] .keyboard-matrix .magnetic-readback-bottom {
  color: #2563eb;
}

:root[data-theme="official"] .keyboard-matrix .calibration-value-pair {
  display: grid !important;
  font-size: 8px;
  line-height: 1;
}

@media (max-width: 1320px) {
  .magnetic-performance-columns {
    grid-template-columns: minmax(520px, 1fr) minmax(320px, 0.78fr);
  }

  .deadzone-column {
    grid-column: 1 / -1;
    border-top: 1px solid #cbd3df;
    border-right: 0;
  }

  .deadzone-tuning-body {
    max-width: 640px;
    margin-inline: auto;
  }
}

@media (max-width: 1280px) {
  .magnetic-official-stage,
  .magnetic-performance-columns {
    grid-template-columns: 1fr;
  }

  .travel-depth-control {
    grid-template-columns: minmax(150px, 0.75fr) minmax(126px, auto) minmax(136px, 0.58fr);
  }

  .magnetic-select-actions {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .magnetic-official-stage {
    padding: 28px;
  }

  .keymap-official-stage {
    grid-template-columns: 1fr;
    padding: 32px;
  }

  .keymap-keyboard-shell {
    max-width: 100%;
  }

  .keymap-layer-card {
    justify-self: center;
    grid-template-columns: repeat(3, auto);
    min-height: auto;
    padding: 18px;
  }

  .keymap-reset-layer-button {
    grid-column: 1 / -1;
    justify-self: center;
  }

  .keymap-output-tabs {
    grid-template-columns: repeat(auto-fit, minmax(88px, 1fr));
  }
}

@media (max-width: 760px) {
  .magnetic-axis-row {
    grid-template-columns: 1fr 1fr;
  }

  .travel-depth-control {
    grid-template-columns: minmax(0, 1fr);
    grid-template-areas:
      "switch"
      "slider"
      "readout";
    justify-items: center;
  }

  .travel-depth-readout {
    justify-items: stretch;
  }

  .deadzone-tuning-body {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 1280px) {
  .macro-workspace {
    grid-template-columns: 1fr;
  }

  :root[data-theme="official"] .macro-workspace {
    grid-template-columns: 1fr;
  }

  :root[data-theme="official"] .macro-editor-panel {
    padding: 18px 22px 14px;
  }

  :root[data-theme="official"] .macro-settings-panel {
    justify-self: stretch;
    align-self: stretch;
  }

  .macro-action-row {
    grid-template-columns: 36px 1fr 1fr;
  }

  :root[data-theme="official"] .macro-action-row {
    grid-template-columns: minmax(100px, 1fr) minmax(96px, 0.8fr) minmax(68px, 0.5fr) minmax(150px, 0.8fr);
    padding: 10px 16px;
  }

  .macro-action-buttons {
    grid-column: 2 / -1;
    justify-content: flex-start;
  }
}

@media (max-width: 1160px) {
  :root[data-theme="official"] .shell {
    grid-template-columns: 1fr;
  }

  :root[data-theme="official"] .sidebar {
    position: static;
    max-height: none;
  }

  :root[data-theme="official"] .section-nav {
    display: flex;
    overflow-x: auto;
  }

  :root[data-theme="official"] .section-nav::before {
    display: none;
  }

  :root[data-theme="official"] .nav-chip {
    min-width: 150px;
  }

  :root[data-theme="official"] .settings-grid,
  :root[data-theme="official"] .keymap-info-grid,
  :root[data-theme="official"] .rt-overview,
  :root[data-theme="official"] .travel-layout {
    grid-template-columns: 1fr;
  }

  :root[data-theme="official"] .advanced-test-workspace {
    position: static;
  }
}

/* Official-style advanced-key overview.  Keep the editors in the DOM for logic,
   but make the default page match the vendor driver's three-column workspace. */
.advanced-official-panel {
  display: grid;
  gap: 8px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: #f6f8fb;
  box-shadow: none;
}

.advanced-official-panel .advanced-device-panel {
  display: none !important;
}

.advanced-official-panel .advanced-keyboard-panel {
  display: grid;
  place-items: center;
  min-height: 325px;
  margin: 0;
  padding: 46px 28px 38px;
  border: 1px solid #cbd5e1;
  border-radius: 4px;
  background: #ffffff;
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.75),
    0 1px 2px rgba(15, 23, 42, 0.06);
}

.advanced-official-panel .advanced-keyboard-matrix {
  --official-board-width: 760px;
  width: min(var(--official-board-width), 92%);
  margin: 0 auto;
}

.advanced-official-panel:not(.editing) #advanced-overview-shell {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
  min-height: 305px;
  border: 1px solid #c4ccd8;
  border-radius: 0 0 4px 4px;
  background: #edf2f7;
  overflow: hidden;
}

.advanced-official-panel[data-advanced-mode="editor"] #advanced-overview-shell,
.advanced-official-panel[data-advanced-mode="editor"] .advanced-device-panel {
  display: none !important;
}

.advanced-official-panel[data-advanced-mode="overview"] #advanced-editor-shell {
  display: none !important;
}

.advanced-official-panel .advanced-function-rail,
.advanced-official-panel .advanced-binding-workspace,
.advanced-official-panel .advanced-test-workspace {
  position: static;
  min-height: 305px;
  padding: 18px 24px;
  border: 0;
  border-radius: 0;
  background: #edf2f7;
  box-shadow: none;
}

.advanced-official-panel .advanced-function-rail,
.advanced-official-panel .advanced-binding-workspace {
  border-right: 1px solid #c4ccd8;
}

.advanced-official-panel .compact-title-row {
  align-items: center;
  min-height: 28px;
  margin: 0 0 8px;
}

.advanced-official-panel .compact-title-row h3 {
  color: #172033;
  font-size: 16px;
  font-weight: 850;
}

.advanced-official-panel .compact-title-row .pill {
  margin-left: auto;
  color: #172033;
  background: transparent;
  border: 0;
}

.advanced-official-panel .advanced-function-rail .section-copy {
  margin: 0 0 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid #d8dde6;
  color: #475569;
  font-size: 12px;
  line-height: 1.7;
}

.advanced-official-panel .advanced-binding-workspace .section-copy,
.advanced-official-panel .advanced-test-workspace .section-copy,
.advanced-official-panel .advanced-function-rail .compact-title-row .pill,
.advanced-official-panel #advanced-key-test-pill,
.advanced-official-panel #advanced-key-test-input-label {
  display: none !important;
}

.advanced-official-binding-list {
  display: grid;
  gap: 8px;
  max-height: 238px;
  padding-right: 4px;
  overflow-y: auto;
}

.advanced-official-binding-card {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto auto;
  grid-template-areas:
    "index title type delete"
    "index pair type delete"
    "index summary summary delete";
  gap: 2px 8px;
  width: 100%;
  min-height: 62px;
  padding: 9px 11px;
  text-align: left;
  color: #172033;
  border: 1px solid #c9d3df;
  border-radius: 6px;
  background: #f8fafc;
  cursor: pointer;
}

.advanced-official-binding-delete {
  grid-area: delete;
  display: inline-grid;
  place-items: center;
  align-self: center;
  width: 24px;
  height: 24px;
  color: #64748b;
  font-size: 18px;
  font-weight: 900;
  line-height: 1;
  border: 1px solid transparent;
  border-radius: 999px;
  background: transparent;
  cursor: pointer;
}

.advanced-official-binding-delete:hover,
.advanced-official-binding-delete:focus-visible {
  color: #dc2626;
  border-color: #fecaca;
  background: #fff1f2;
  outline: none;
}

.advanced-official-binding-card:hover,
.advanced-official-binding-card:focus-visible {
  border-color: #94a3b8;
  background: #ffffff;
  outline: none;
}

.advanced-official-binding-card.active {
  border-color: #111827;
  background: #ffffff;
  box-shadow: inset 4px 0 0 #111827;
}

.advanced-official-binding-index {
  grid-area: index;
  display: inline-grid;
  place-items: center;
  align-self: stretch;
  color: #64748b;
  font-size: 12px;
  font-weight: 850;
  border-radius: 5px;
  background: #e2e8f0;
}

.advanced-official-binding-type {
  grid-area: type;
  align-self: start;
  padding: 2px 7px;
  color: #0f172a;
  font-size: 11px;
  font-weight: 850;
  border-radius: 999px;
  background: #dbeafe;
}

.advanced-official-binding-card strong {
  grid-area: title;
  overflow: hidden;
  font-size: 14px;
  font-weight: 850;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.advanced-official-binding-card small {
  grid-area: pair;
  overflow: hidden;
  color: #475569;
  font-size: 11px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.advanced-official-binding-card em {
  grid-area: summary;
  overflow: hidden;
  color: #64748b;
  font-size: 11px;
  font-style: normal;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.advanced-official-binding-empty {
  display: grid;
  place-items: center;
  min-height: 124px;
  padding: 16px;
  text-align: center;
  color: #64748b;
  border: 1px dashed #cbd5e1;
  border-radius: 6px;
  background: rgba(248, 250, 252, 0.72);
}

.advanced-official-binding-empty strong {
  color: #172033;
  font-size: 15px;
}

.advanced-official-panel .advanced-type-card-list {
  display: grid;
  gap: 10px;
  max-height: 220px;
  padding-right: 4px;
  overflow-y: auto;
}

.advanced-official-panel .advanced-type-card {
  display: grid;
  grid-template-columns: 46px minmax(0, 1fr);
  grid-template-areas:
    "abbr name"
    "abbr copy";
  gap: 2px 10px;
  align-items: center;
  min-height: 58px;
  padding: 8px 12px;
  color: #172033;
  border: 0;
  border-radius: 10px;
  background: #dbe3eb;
  box-shadow: none;
  transform: none;
}

.advanced-official-panel .advanced-type-card:hover {
  border: 0;
  background: #d2dce6;
  transform: none;
}

:root[data-theme="official"] .advanced-official-panel .advanced-type-card:hover {
  color: #172033;
  border: 0;
  background: #d2dce6;
  box-shadow: none;
  transform: none;
}

.advanced-official-panel .advanced-type-card.active {
  color: #172033;
  border: 0;
  background: #d2dce6;
  box-shadow: inset 4px 0 0 #94a3b8;
}

:root[data-theme="official"] .advanced-official-panel .advanced-type-card.active {
  color: #172033;
  border: 0;
  background: #d2dce6;
  box-shadow: inset 4px 0 0 #94a3b8;
}

.advanced-official-panel .advanced-type-card strong {
  grid-area: abbr;
  display: inline-grid;
  place-items: center;
  min-width: 38px;
  min-height: 38px;
  color: #64748b;
  font-size: 15px;
  font-weight: 950;
  letter-spacing: 0;
  border-radius: 8px;
  background: #c7d2dc;
}

:root[data-theme="official"] .advanced-official-panel .advanced-type-card strong {
  color: #64748b;
  background: #c7d2dc;
}

.advanced-official-panel .advanced-type-card .advanced-type-name {
  grid-area: name;
  color: #172033;
  font-size: 14px;
  font-weight: 750;
}

.advanced-official-panel .advanced-type-card small {
  grid-area: copy;
  color: #475569;
  font-size: 11px;
  line-height: 1.35;
}

.advanced-official-panel .advanced-type-card.active .advanced-type-name,
.advanced-official-panel .advanced-type-card.active small {
  color: #475569;
}

:root[data-theme="official"] .advanced-official-panel .advanced-type-card.active .advanced-type-name,
:root[data-theme="official"] .advanced-official-panel .advanced-type-card.active small {
  color: #475569;
}

.advanced-official-panel .advanced-binding-slot-panel,
.advanced-official-panel .dks-quick-panel,
.advanced-official-panel .advanced-full-editor,
.advanced-official-panel #advanced-key-stage-preview,
.advanced-official-panel #advanced-key-preview,
.advanced-official-panel #advanced-key-capture-panel,
.advanced-official-panel .advanced-key-live-output,
.advanced-official-panel .advanced-key-test-log,
.advanced-official-panel .advanced-test-workspace .button-row {
  display: none !important;
}

.advanced-official-panel .advanced-key-test-field {
  margin: 10px 0 0;
}

.advanced-official-panel .advanced-key-test-input {
  min-height: 124px;
  height: 124px;
  padding: 8px;
  color: #172033;
  border: 1px solid #9fb0c4;
  border-radius: 4px;
  background: #ffffff;
  align-items: flex-start;
  font-size: 14px;
  font-weight: 500;
  cursor: default;
}

.advanced-official-panel .advanced-key-test-input:focus {
  border-color: #9fb0c4;
  outline: none;
  box-shadow: inset 0 0 0 1px rgba(159, 176, 196, 0.35);
}

.advanced-official-panel .advanced-key-test-input.has-active-key {
  border-color: #60a5fa;
  background: #eff6ff;
  color: #1d4ed8;
  font-weight: 700;
}

@media (max-width: 960px) {
  .advanced-official-panel:not(.editing) #advanced-overview-shell {
    grid-template-columns: 1fr;
  }

  .advanced-official-panel .advanced-function-rail,
  .advanced-official-panel .advanced-binding-workspace {
    border-right: 0;
    border-bottom: 1px solid #c4ccd8;
  }
}

/* Official-style advanced key editor refinements. */
.advanced-official-dks-workspace {
  position: relative;
  display: block;
  min-height: 286px;
}

.advanced-official-dks-matrix,
.advanced-official-dks-matrix-shell {
  display: grid;
  grid-template-columns: minmax(86px, 112px) repeat(4, minmax(92px, 1fr));
  gap: 10px 12px;
  align-items: stretch;
}

.advanced-official-dks-corner,
.advanced-official-dks-stage-head {
  display: grid;
  gap: 8px;
  align-content: center;
  justify-items: center;
  color: #334155;
  font-weight: 800;
}

.advanced-official-dks-corner {
  min-height: 88px;
  color: #64748b;
}

.advanced-official-stage-box.advanced-official-dks-output-grid {
  width: 100%;
  min-height: 56px;
  justify-content: center;
}

.advanced-official-dks-direction {
  min-width: 70px;
  min-height: 32px;
  padding: 0 12px;
  border: 1px solid #94a3b8;
  border-radius: 8px;
  color: #172033;
  background: #ffffff;
  font-weight: 900;
  cursor: pointer;
}

.advanced-official-dks-direction[data-direction="press"] {
  border-color: #1677d2;
  color: #1677d2;
}

.advanced-official-dks-direction[data-direction="release"] {
  border-color: #ef4444;
  color: #ef4444;
}

.advanced-official-dks-stage-head label {
  display: grid;
  gap: 6px;
  width: 100%;
  text-align: center;
}

.advanced-official-dks-stage-head input[type="range"] {
  width: 100%;
  accent-color: #94a3b8;
}

.advanced-official-dks-grid-cell {
  min-height: 56px;
  border: 1px solid #b8c6d4;
  border-radius: 10px;
  color: #64748b;
  background: #dbe5ee;
  font-size: 22px;
  font-weight: 900;
  cursor: pointer;
}

.advanced-official-dks-grid-cell:hover,
.advanced-official-dks-grid-cell.active {
  border-color: #1677d2;
  color: #ffffff;
  background: #1677d2;
}

.advanced-dks-context-menu {
  position: fixed;
  z-index: 1000;
  min-width: 152px;
  padding: 6px;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  background: #ffffff;
  box-shadow: 0 18px 36px rgba(15, 23, 42, 0.16);
}

.advanced-dks-context-menu button {
  display: block;
  width: 100%;
  padding: 9px 10px;
  border: 0;
  border-radius: 6px;
  color: #172033;
  background: transparent;
  text-align: left;
  font-weight: 700;
  cursor: pointer;
}

.advanced-dks-context-menu button:hover {
  background: #e8f1ff;
}

.advanced-official-editor.socd-mode .advanced-official-editor-layout {
  grid-template-columns: minmax(0, 1fr);
}

.advanced-official-editor.socd-mode .advanced-official-type-pane {
  display: none;
}

.advanced-official-editor.socd-mode .advanced-official-control-pane {
  grid-column: 1 / -1;
  border-left: 0;
}

.advanced-official-socd-workspace {
  display: grid;
  grid-template-columns: minmax(320px, 0.95fr) minmax(420px, 1.05fr);
  gap: 0;
  min-height: 300px;
  border-top: 1px solid #bcc8d5;
}

.advanced-official-socd-bind-pane {
  display: grid;
  align-content: start;
  gap: 18px;
  padding: 22px 32px 26px;
  border-right: 1px solid #bcc8d5;
}

.advanced-official-socd-bind-title h4,
.advanced-official-socd-rules legend {
  margin: 0;
  color: #172033;
  font-size: 18px;
  font-weight: 900;
}

.advanced-official-socd-bind-title span,
.advanced-official-socd-rule-copy {
  color: #172033;
  font-size: 13px;
  line-height: 1.5;
}

.advanced-official-socd-key-row {
  display: flex;
  justify-content: center;
  gap: 30px;
  margin-top: 44px;
}

.advanced-official-socd-key-field {
  display: grid;
  justify-items: center;
  gap: 10px;
  color: #172033;
  font-size: 13px;
  font-weight: 800;
}

.advanced-official-socd-key-slot {
  width: 80px;
  min-height: 80px;
  height: 80px;
  padding: 8px;
  align-content: center;
  justify-items: center;
  border-color: #aebdca;
  border-radius: 4px;
  background: #dce6ef;
  text-align: center;
}

.advanced-official-socd-key-slot strong {
  font-size: 14px;
  line-height: 1.35;
}

.advanced-official-socd-key-slot.active {
  border-color: #1677d2;
  box-shadow: 0 0 0 2px rgba(22, 119, 210, 0.18);
}

.advanced-official-socd-bind-hint {
  margin: 0;
  color: #172033;
  font-size: 13px;
  text-align: center;
}

.advanced-official-socd-rules {
  display: grid;
  align-content: start;
  gap: 14px;
  margin: 0;
  padding: 22px 32px 26px;
  border: 0;
}

.advanced-official-socd-rules legend {
  padding: 0;
}

.advanced-official-socd-rule-copy {
  margin: -4px 0 44px;
}

.advanced-official-socd-rule-list {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 18px;
  max-width: 560px;
}

.advanced-official-socd-rule-option {
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  color: #172033;
}

.advanced-official-socd-rule-option input {
  width: 16px;
  height: 16px;
  accent-color: #15a36f;
}

.advanced-official-socd-rule-text {
  display: flex;
  gap: 16px;
  align-items: baseline;
  min-width: 0;
}

.advanced-official-socd-rule-text strong {
  min-width: 150px;
  color: #172033;
  font-size: 14px;
  font-weight: 900;
}

.advanced-official-socd-rule-text small {
  color: #172033;
  font-size: 13px;
  line-height: 1.45;
}

/* ==================================================================
   UI 视觉刷新 2026-06-11（纯外观覆盖层）
   只覆盖颜色 / 阴影 / 圆角 / 字体等视觉属性；
   不改变任何布局、尺寸、显示隐藏与交互行为。
   ================================================================== */

/* ---------- 全局基础（所有主题） ---------- */
body {
  font-family: "Segoe UI Variable Text", "MiSans", "HarmonyOS Sans SC",
    "Microsoft YaHei UI", "PingFang SC", "Segoe UI", sans-serif;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

::selection {
  background: rgba(59, 130, 246, 0.28);
}

*::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

*::-webkit-scrollbar-track {
  background: transparent;
}

*::-webkit-scrollbar-thumb {
  border: 3px solid transparent;
  border-radius: 8px;
  background-clip: padding-box;
  background-color: rgba(100, 116, 139, 0.45);
}

*::-webkit-scrollbar-thumb:hover {
  background-color: rgba(100, 116, 139, 0.72);
}

button:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

/* ---------- 官方式浅色主题：设计令牌 ---------- */
:root[data-theme="official"] {
  --bg: #f3f5fa;
  --panel: #ffffff;
  --panel-border: #e8ebf4;
  --panel-strong: #ffffff;
  --text: #1c2438;
  --muted: #69728a;
  --accent: #2563eb;
  --accent-strong: #1d4ed8;
  --accent-soft: rgba(37, 99, 235, 0.1);
  --danger: #e11d48;
  --neutral: #0e7490;
  --shadow: 0 1px 2px rgba(16, 24, 40, 0.05), 0 10px 28px rgba(16, 24, 40, 0.07);
}

:root[data-theme="official"] body {
  background:
    radial-gradient(900px 420px at 12% -4%, rgba(59, 130, 246, 0.1), transparent 60%),
    radial-gradient(820px 380px at 92% 0%, rgba(99, 102, 241, 0.09), transparent 60%),
    linear-gradient(180deg, #f7f8fc 0%, #f1f3f9 60%, #eef1f8 100%);
}

/* ---------- 面板与标题 ---------- */
:root[data-theme="official"] .brand,
:root[data-theme="official"] .panel,
:root[data-theme="official"] .hero {
  border-radius: 18px;
  border-color: var(--panel-border);
  box-shadow: var(--shadow);
}

:root[data-theme="official"] .panel-title-row {
  border-bottom: 1px solid #eef1f7;
}

:root[data-theme="official"] .panel-title-row h2,
:root[data-theme="official"] .panel-title-row h3 {
  color: #1c2438;
  font-weight: 800;
  letter-spacing: -0.01em;
}

:root[data-theme="official"] .section-copy,
:root[data-theme="official"] .small {
  color: var(--muted);
  line-height: 1.65;
}

/* ---------- 品牌区 ---------- */
:root[data-theme="official"] .brand-badge {
  background: linear-gradient(135deg, #2563eb 0%, #4f46e5 60%, #7c3aed 100%);
  color: #ffffff;
  box-shadow: 0 6px 16px rgba(67, 56, 202, 0.35);
}

:root[data-theme="official"] .brand h1 {
  font-weight: 800;
  letter-spacing: -0.01em;
}

/* ---------- 顶部 Hero ---------- */
:root[data-theme="official"] .hero {
  border-color: rgba(255, 255, 255, 0.06);
  background:
    radial-gradient(620px 300px at 86% -20%, rgba(96, 165, 250, 0.3), transparent 70%),
    radial-gradient(480px 260px at -10% 130%, rgba(129, 140, 248, 0.26), transparent 70%),
    linear-gradient(135deg, #111b34 0%, #162242 55%, #101a31 100%);
  box-shadow: 0 18px 40px rgba(16, 24, 40, 0.22);
}

:root[data-theme="official"] .hero h2 {
  font-weight: 800;
  letter-spacing: -0.015em;
}

:root[data-theme="official"] .eyebrow {
  color: #93c5fd;
  letter-spacing: 0.22em;
}

:root[data-theme="official"] .hero-copy {
  color: #aebad4;
}

:root[data-theme="official"] .hero-stat {
  border-color: rgba(255, 255, 255, 0.1);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.07);
}

:root[data-theme="official"] .hero-stat span {
  color: #9fb0d0;
}

:root[data-theme="official"] .hero-stat strong {
  color: #ffffff;
}

/* ---------- 侧边导航 ---------- */
:root[data-theme="official"] .section-nav {
  border-radius: 18px;
  background: #ffffff;
}

:root[data-theme="official"] .section-nav::before {
  color: #98a1b3;
  letter-spacing: 0.18em;
}

:root[data-theme="official"] .nav-chip {
  border-radius: 12px;
  color: #525c72;
  font-weight: 650;
  transition: background-color 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
}

:root[data-theme="official"] .nav-chip::before {
  border-radius: 9px;
  background: #eef1f8;
  color: #6b7689;
  font-size: 12px;
  font-weight: 700;
}

:root[data-theme="official"] .nav-chip:hover {
  background: #f3f6fc;
  border-color: transparent;
  color: #1c2438;
}

:root[data-theme="official"] .nav-chip:hover::before {
  background: #e3e9f6;
  color: #2563eb;
}

:root[data-theme="official"] .nav-chip-active,
:root[data-theme="official"] .nav-chip-active:hover {
  background: linear-gradient(135deg, #2563eb, #4338ca);
  border-color: transparent;
  color: #ffffff;
  box-shadow: 0 8px 18px rgba(37, 99, 235, 0.28);
}

:root[data-theme="official"] .nav-chip-active::before,
:root[data-theme="official"] .nav-chip-active:hover::before {
  background: rgba(255, 255, 255, 0.18);
  color: #ffffff;
}

:root[data-theme="official"] #nav-chip-keymap::before { content: "键"; }
:root[data-theme="official"] #nav-chip-lighting::before { content: "灯"; }
:root[data-theme="official"] #nav-chip-rhythm::before { content: "律"; }
:root[data-theme="official"] #nav-chip-macro::before { content: "宏"; }
:root[data-theme="official"] #nav-chip-performance::before { content: "能"; }
:root[data-theme="official"] #nav-chip-advanced::before { content: "高"; }
:root[data-theme="official"] #nav-chip-device::before { content: "设"; }
:root[data-theme="official"] .nav-chip[data-workspace-view="tools"]::before { content: "工"; }
:root[data-theme="official"] .nav-chip[data-workspace-view="logs"]::before { content: "记"; }
:root[data-theme="official"] .nav-chip[data-workspace-view="official"]::before { content: "维"; }

/* ---------- 按钮 ---------- */
:root[data-theme="official"] .button {
  border-radius: 11px;
  font-weight: 700;
  transition:
    transform 0.12s ease,
    box-shadow 0.15s ease,
    background-color 0.15s ease,
    border-color 0.15s ease,
    filter 0.15s ease;
}

:root[data-theme="official"] .button-primary {
  background: linear-gradient(135deg, #2563eb, #4f46e5);
  border-color: transparent;
  color: #ffffff;
  box-shadow: 0 1px 2px rgba(16, 24, 40, 0.1), 0 6px 16px rgba(67, 76, 234, 0.24);
}

:root[data-theme="official"] .button-primary:hover {
  filter: brightness(1.07);
  box-shadow: 0 10px 22px rgba(67, 76, 234, 0.32);
}

:root[data-theme="official"] .button-secondary {
  background: #eef3ff;
  border-color: #d7e3ff;
  color: #2050c8;
}

:root[data-theme="official"] .button-secondary:hover {
  background: #e2ebff;
  border-color: #bcd0fb;
}

:root[data-theme="official"] .button-ghost {
  background: #f7f8fb;
  border-color: #e6e9f2;
  color: #5a6478;
}

:root[data-theme="official"] .button-ghost:hover {
  background: #eef1f7;
  color: #1f2738;
}

:root[data-theme="official"] .button-danger {
  background: linear-gradient(135deg, #ef4444, #dc2626);
  border-color: transparent;
  color: #ffffff;
  box-shadow: 0 6px 16px rgba(220, 38, 38, 0.22);
}

:root[data-theme="official"] .button-danger:hover {
  filter: brightness(1.06);
}

/* ---------- 徽标 / 状态胶囊 ---------- */
:root[data-theme="official"] .pill {
  font-weight: 650;
}

:root[data-theme="official"] .pill-neutral,
:root[data-theme="official"] .pill-idle {
  background: #eef1f8;
  color: #5a6478;
}

:root[data-theme="official"] .pill-connected {
  background: #e3f8ec;
  color: #15803d;
}

:root[data-theme="official"] .pill-error {
  background: #feecee;
  color: #be123c;
}

/* ---------- 表单控件 ---------- */
:root[data-theme="official"] .field input,
:root[data-theme="official"] .field select,
:root[data-theme="official"] .field textarea,
:root[data-theme="official"] textarea,
:root[data-theme="official"] select,
:root[data-theme="official"] input {
  border-color: #dbe1ee;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

:root[data-theme="official"] .field input:focus,
:root[data-theme="official"] .field select:focus,
:root[data-theme="official"] .field textarea:focus,
:root[data-theme="official"] textarea:focus,
:root[data-theme="official"] select:focus,
:root[data-theme="official"] input[type="text"]:focus,
:root[data-theme="official"] input[type="number"]:focus {
  border-color: #93b4fd;
  outline: none;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.14);
}

:root[data-theme="official"] input[type="range"],
:root[data-theme="official"] input[type="checkbox"],
:root[data-theme="official"] input[type="radio"] {
  accent-color: #2563eb;
  box-shadow: none;
}

:root[data-theme="official"] .field span {
  color: #69728a;
  font-weight: 600;
}

/* ---------- 信息卡片 ---------- */
:root[data-theme="official"] .status-list div,
:root[data-theme="official"] .info-grid div,
:root[data-theme="official"] .metric-card,
:root[data-theme="official"] .setting-card,
:root[data-theme="official"] .callout-card,
:root[data-theme="official"] .slider-card {
  background: #f8f9fc;
  border-color: #e9edf5;
  border-radius: 14px;
}

:root[data-theme="official"] .setting-card {
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

:root[data-theme="official"] .setting-card:hover {
  border-color: #cdd9f0;
  box-shadow: 0 6px 18px rgba(16, 24, 40, 0.06);
}

:root[data-theme="official"] .metric-card strong {
  color: #1c2438;
}

:root[data-theme="official"] .empty-state {
  border-radius: 12px;
  color: #8a93a8;
}

:root[data-theme="official"] .info-banner {
  background: #eff4ff;
  border-color: #dbe6fd;
  border-radius: 12px;
}

:root[data-theme="official"] .info-banner p {
  color: #3a4a6b;
}

:root[data-theme="official"] .snapshot-preview {
  background: #0f172a;
  border: 1px solid #1e293b;
  border-radius: 12px;
  color: #c9d6ec;
}

:root[data-theme="official"] .port-card {
  border-radius: 14px;
  border-color: #e9edf5;
  background: #f8f9fc;
}

:root[data-theme="official"] .port-card.selected {
  border-color: #2563eb;
  background: #f3f7ff;
  box-shadow: 0 0 0 1px rgba(37, 99, 235, 0.35);
}

/* ---------- 键盘矩阵：石墨底座 + 浅色键帽 ---------- */
:root[data-theme="official"] .keyboard-matrix {
  border-radius: 16px 16px 10px 10px;
  background: linear-gradient(180deg, #313a4f 0%, #283146 58%, #232b3e 100%);
  box-shadow:
    0 24px 44px rgba(16, 24, 40, 0.28),
    0 2px 6px rgba(16, 24, 40, 0.22),
    inset 0 0 0 1px rgba(148, 163, 184, 0.18);
}

:root[data-theme="official"] .keyboard-matrix::before {
  border-radius: 14px 14px 0 0;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.12) 50%, rgba(255, 255, 255, 0.04)),
    linear-gradient(180deg, #3d4760, #2c3449);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.14),
    inset 0 -1px 0 rgba(0, 0, 0, 0.28);
}

:root[data-theme="official"] .keyboard-matrix::after {
  border-radius: 0 0 8px 8px;
  background: linear-gradient(180deg, #1d2435, #161c2a);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

:root[data-theme="official"] .keyboard-matrix .key-button,
:root[data-theme="official"] .keyboard-matrix.compact .key-button {
  color: #2a3550;
  background: linear-gradient(180deg, #ffffff 0%, #f2f5fa 58%, #e2e8f2 100%);
  border: 1px solid #aeb9cf;
  border-radius: 7px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.95),
    inset 0 -3px 0 rgba(148, 163, 184, 0.35),
    0 2px 3px rgba(10, 15, 30, 0.35);
  transition: transform 0.1s ease, border-color 0.12s ease, box-shadow 0.12s ease;
}

:root[data-theme="official"] .keyboard-matrix .key-button:hover {
  border-color: #60a5fa;
  transform: translateY(-1px);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.95),
    inset 0 -3px 0 rgba(148, 163, 184, 0.3),
    0 0 0 2px rgba(96, 165, 250, 0.35),
    0 4px 8px rgba(10, 15, 30, 0.35);
}

:root[data-theme="official"] .keyboard-matrix .key-button.active {
  color: #ffffff;
  background: linear-gradient(180deg, #3b82f6, #2563eb 60%, #1d4ed8);
  border-color: #1d4ed8;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.35),
    inset 0 -3px 0 rgba(13, 38, 110, 0.55),
    0 0 0 2px rgba(59, 130, 246, 0.4),
    0 6px 14px rgba(37, 99, 235, 0.45);
}

:root[data-theme="official"] .keyboard-matrix .key-button.special-key:not(.active),
:root[data-theme="official"] .keyboard-matrix .key-button.vendor:not(.active) {
  color: #1f2a44;
  background: linear-gradient(180deg, #e8edf6 0%, #d9e1ef 60%, #c8d3e6 100%);
  border-color: #9fadc8;
}

:root[data-theme="official"] .keyboard-matrix .key-button.remapped:not(.active) {
  background: linear-gradient(180deg, #e9fbf2, #ccf3de);
  border-color: #2fbf7f;
}

:root[data-theme="official"] .keyboard-matrix .key-button.multi-selected:not(.active) {
  color: #111827;
  background: linear-gradient(180deg, #fff8e6, #fdeebc);
  border-color: #f0a90c;
  box-shadow:
    inset 0 0 0 2px rgba(240, 169, 12, 0.42),
    0 2px 3px rgba(10, 15, 30, 0.3);
}

:root[data-theme="official"] .keyboard-matrix .key-button.has-magnetic-readback:not(.active),
:root[data-theme="official"] .keyboard-matrix .key-button.has-magnetic-readback.special-key:not(.active),
:root[data-theme="official"] .keyboard-matrix .key-button.has-magnetic-readback.vendor:not(.active) {
  color: #1f2a44;
  background: linear-gradient(180deg, #f0f6ff 0%, #dbe8fd 100%);
  border-color: #f59e0b;
  box-shadow:
    inset 0 0 0 2px rgba(245, 158, 11, 0.68),
    0 2px 3px rgba(10, 15, 30, 0.3);
}

/* ---------- 改键页键盘矩阵 ---------- */
:root[data-theme="official"] .keymap-official-page {
  border-radius: 14px;
  background: #f6f8fc;
}

:root[data-theme="official"] .keymap-official-matrix {
  border: 1px solid #d4dbe8;
  border-radius: 14px;
  background: linear-gradient(180deg, #f2f5fa, #e3e9f3);
}

:root[data-theme="official"] .keymap-official-matrix .key-button {
  color: #2a3550;
  background: linear-gradient(180deg, #ffffff 0%, #f2f5fa 56%, #e2e8f2 100%);
  border-color: #b6c1d6;
  border-radius: 7px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.95),
    inset 0 -3px 0 rgba(148, 163, 184, 0.3),
    0 2px 3px rgba(15, 23, 42, 0.12);
}

:root[data-theme="official"] .keymap-official-matrix .key-button.active {
  color: #173a8a;
  background: linear-gradient(180deg, #eff5ff, #dbe8ff);
  border-color: #2563eb;
  box-shadow:
    inset 0 0 0 1px #2563eb,
    0 0 0 2px rgba(37, 99, 235, 0.25),
    0 2px 3px rgba(15, 23, 42, 0.12);
}

/* ---------- 性能页滑条与数值 ---------- */
:root[data-theme="official"] .rt-step,
:root[data-theme="official"] .deadzone-step {
  background: #e6eaf3;
  color: #33415e;
  transition: background-color 0.15s ease;
}

:root[data-theme="official"] .rt-step:hover,
:root[data-theme="official"] .deadzone-step:hover {
  background: #d6ddec;
}

:root[data-theme="official"] .rt-slider,
:root[data-theme="official"] .rt-independent-row input,
:root[data-theme="official"] .deadzone-slider {
  accent-color: #2563eb;
}

:root[data-theme="official"] .rt-value,
:root[data-theme="official"] .deadzone-slider-card strong {
  border-radius: 8px;
  background: linear-gradient(135deg, #2563eb, #4f46e5);
  color: #ffffff;
  font-weight: 700;
  box-shadow: 0 4px 10px rgba(67, 76, 234, 0.25);
}

/* ---------- 开关与区域切换 ---------- */
:root[data-theme="official"] .magnetic-official-switch input:checked + span {
  background: linear-gradient(135deg, #2563eb, #4f46e5);
}

:root[data-theme="official"] .magnetic-mode-tab {
  border-radius: 999px;
  transition: background-color 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
}

:root[data-theme="official"] .magnetic-mode-tab.active {
  background: linear-gradient(135deg, #2563eb, #4338ca);
  color: #ffffff;
  box-shadow: 0 6px 14px rgba(37, 99, 235, 0.26);
}

/* ---------- 灯效页 ---------- */
:root[data-theme="official"] .lighting-effect-button {
  border-radius: 12px;
  transition: border-color 0.15s ease, background-color 0.15s ease, color 0.15s ease;
}

:root[data-theme="official"] .lighting-effect-button:hover:not(:disabled) {
  border-color: #bcd0fb;
  background: #f3f7ff;
}

:root[data-theme="official"] .lighting-effect-button.active {
  border-color: #2563eb;
  background: #eff4ff;
  color: #1d4ed8;
  box-shadow: 0 0 0 1px rgba(37, 99, 235, 0.35);
}

:root[data-theme="official"] .lighting-color-space-button.active,
:root[data-theme="official"] .lighting-color-mode-button.active {
  background: linear-gradient(135deg, #2563eb, #4338ca);
  color: #ffffff;
  border-color: transparent;
}

:root[data-theme="official"] .lighting-swatch {
  border-radius: 10px;
  box-shadow: inset 0 0 0 1px rgba(16, 24, 40, 0.1);
  transition: transform 0.12s ease, box-shadow 0.12s ease;
}

:root[data-theme="official"] .lighting-swatch:hover {
  transform: translateY(-1px) scale(1.05);
  box-shadow:
    inset 0 0 0 1px rgba(16, 24, 40, 0.12),
    0 4px 10px rgba(16, 24, 40, 0.18);
}

:root[data-theme="official"] .lighting-slider-row input {
  accent-color: #2563eb;
}

/* ---------- 律动页 ---------- */
:root[data-theme="official"] .rhythm-mode-button {
  border-radius: 12px;
  transition: border-color 0.15s ease, background-color 0.15s ease, color 0.15s ease;
}

:root[data-theme="official"] .rhythm-mode-button.active {
  background: linear-gradient(135deg, #2563eb, #4338ca);
  border-color: transparent;
  color: #ffffff;
  box-shadow: 0 6px 14px rgba(37, 99, 235, 0.24);
}

/* ---------- 高级键页 ---------- */
:root[data-theme="official"] .advanced-official-panel .advanced-type-card {
  background: #f8f9fc;
  border-color: #e8ebf4;
  border-radius: 14px;
  transition: border-color 0.15s ease, background-color 0.15s ease, box-shadow 0.15s ease;
}

:root[data-theme="official"] .advanced-official-panel .advanced-type-card:hover {
  background: #f3f7ff;
  border-color: #bcd0fb;
}

:root[data-theme="official"] .advanced-official-panel .advanced-type-card.active {
  background: linear-gradient(135deg, rgba(37, 99, 235, 0.1), rgba(79, 70, 229, 0.08));
  border-color: #2563eb;
  box-shadow: 0 0 0 1px rgba(37, 99, 235, 0.3);
}

:root[data-theme="official"] .advanced-official-panel .advanced-type-card strong {
  color: #1d4ed8;
}

:root[data-theme="official"] .advanced-official-binding-card {
  border-radius: 12px;
  border-color: #e8ebf4;
  background: #f8f9fc;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

:root[data-theme="official"] .advanced-official-binding-card:hover {
  border-color: #bcd0fb;
}

:root[data-theme="official"] .advanced-official-binding-card.active {
  border-color: #2563eb;
  background: #f3f7ff;
  box-shadow: 0 0 0 1px rgba(37, 99, 235, 0.3);
}

:root[data-theme="official"] .advanced-binding-slot {
  border-radius: 12px;
  transition: border-color 0.15s ease, background-color 0.15s ease;
}

:root[data-theme="official"] .advanced-binding-slot.active {
  border-color: #2563eb;
  background: #f3f7ff;
  box-shadow: 0 0 0 1px rgba(37, 99, 235, 0.3);
}

/* ---------- 宏页 ---------- */
:root[data-theme="official"] .macro-list-card {
  border-radius: 12px;
  border-color: #e8ebf4;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

:root[data-theme="official"] .macro-list-card:hover {
  border-color: #bcd0fb;
}

:root[data-theme="official"] .macro-list-card.active {
  border-color: #2563eb;
  box-shadow: 0 0 0 1px rgba(37, 99, 235, 0.3);
}

/* ---------- 配置文件按钮区 ---------- */
:root[data-theme="official"] #profile-panel #profile-title {
  color: #1c2438;
}

:root[data-theme="official"] #profile-panel .button {
  border-radius: 11px;
  box-shadow: 0 1px 2px rgba(16, 24, 40, 0.08);
}

:root[data-theme="official"] #profile-panel .button-primary {
  background: linear-gradient(135deg, #2563eb, #4f46e5);
  color: #ffffff;
  box-shadow: 0 6px 14px rgba(67, 76, 234, 0.24);
}

:root[data-theme="official"] #profile-panel .button-secondary {
  background: #eef1f8;
  color: #444f66;
}

:root[data-theme="official"] #profile-panel .button-secondary:hover {
  background: #e2e8f4;
  filter: none;
}

/* ==================================================================
   UI 布局升级 2026-06-11 第二轮（外观与信息密度）
   1) Hero 压缩为单行状态横幅；2) 侧栏顺序：功能菜单提前；
   3) 隐藏静态进度清单；4) 调试 JSON 块默认折叠（details）。
   不改变任何功能逻辑与协议交互。
   ================================================================== */

html {
  scroll-behavior: smooth;
}

/* ---------- 调试数据折叠块（全主题） ---------- */
.debug-details {
  margin-top: 14px;
}

.debug-details > summary {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(100, 116, 139, 0.12);
  color: var(--muted);
  font-size: 12px;
  font-weight: 650;
  cursor: pointer;
  user-select: none;
  transition: background-color 0.15s ease, color 0.15s ease;
}

.debug-details > summary:hover {
  background: rgba(100, 116, 139, 0.2);
  color: var(--text);
}

.debug-details[open] > summary {
  margin-bottom: 10px;
}

.debug-details > .snapshot-preview {
  margin-top: 0;
}

/* 收起时强制隐藏内容（不依赖各引擎的 details 内部实现） */
.debug-details:not([open]) > .snapshot-preview {
  display: none !important;
}

/* .macro-debug-preview 在基础层为 display:none，展开折叠框时恢复 */
.debug-details[open] > .macro-debug-preview {
  display: block;
}

:root[data-theme="official"] .debug-details > summary {
  background: #eef1f8;
  color: #69728a;
}

:root[data-theme="official"] .debug-details > summary:hover {
  background: #e2e8f4;
  color: #1c2438;
}

/* official 主题原本用 display:none!important 隐藏这些调试块；
   折叠框展开时恢复显示，让调试数据重新可达（默认仍收起）。 */
:root[data-theme="official"] .debug-details[open] > #device-sync-preview,
:root[data-theme="official"] .debug-details[open] > #lighting-preview,
:root[data-theme="official"] .debug-details[open] > #macro-binding-preview {
  display: block !important;
}

/* ---------- Hero 压缩为状态横幅 ---------- */
:root[data-theme="official"] .hero {
  padding: 14px 20px;
  border-radius: 16px;
}

:root[data-theme="official"] .hero-grid {
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
}

:root[data-theme="official"] .hero .eyebrow,
:root[data-theme="official"] .hero .hero-copy {
  display: none;
}

:root[data-theme="official"] .hero h2 {
  font-size: 15px;
  font-weight: 650;
  line-height: 1.5;
  letter-spacing: 0;
  color: #d7e1f5;
}

:root[data-theme="official"] .hero-highlights {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

:root[data-theme="official"] .hero-stat {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 13px;
  border-radius: 999px;
}

:root[data-theme="official"] .hero-stat span {
  font-size: 11px;
  white-space: nowrap;
}

:root[data-theme="official"] .hero-stat span::after {
  content: "·";
  margin-left: 8px;
  opacity: 0.5;
}

:root[data-theme="official"] .hero-stat strong {
  font-size: 12.5px;
  white-space: nowrap;
}

@media (max-width: 1280px) {
  :root[data-theme="official"] .hero-grid {
    grid-template-columns: minmax(0, 1fr);
  }
}

/* ---------- 侧栏顺序：品牌 → 功能菜单 → 配置档 → 连接状态 ---------- */
:root[data-theme="official"] .sidebar > .panel.official-sidebar-nav {
  order: 1;
}

:root[data-theme="official"] .sidebar > .panel.official-profile-card {
  order: 2;
}

/* ---------- 隐藏静态“当前已打通”进度清单 ---------- */
:root[data-theme="official"] .sidebar > .panel:has(#progress-title) {
  display: none;
}

/* ---------- 工作区密度微调 ---------- */
:root[data-theme="official"] .workspace {
  gap: 14px;
}

/* ==================================================================
   霓虹深空主题 2026-06-12（第三轮 · 纯外观覆盖层）
   将默认 official 主题改造为深色霓虹电竞风格：
   玻璃拟态 / 流动渐变 / 鼠标跟随光斑 / 悬浮动效。
   只覆盖视觉属性，不改变任何布局尺寸与交互逻辑。
   --mx / --my 由 ui-effects.js 写入（仅 CSS 变量，无 DOM 操作）。
   ================================================================== */

/* ---------- 动画定义 ---------- */
@keyframes fx-pan {
  to {
    background-position: 200% center;
  }
}

@keyframes fx-aurora {
  0% {
    transform: translate3d(-3%, -2%, 0) scale(1);
  }
  50% {
    transform: translate3d(3%, 2%, 0) scale(1.08);
  }
  100% {
    transform: translate3d(-2%, 3%, 0) scale(1.02);
  }
}

@keyframes fx-key-pulse {
  0%,
  100% {
    box-shadow:
      0 0 0 2px rgba(129, 140, 248, 0.55),
      0 0 18px rgba(129, 140, 248, 0.5);
  }
  50% {
    box-shadow:
      0 0 0 2px rgba(232, 121, 249, 0.6),
      0 0 26px rgba(232, 121, 249, 0.55);
  }
}

@keyframes fx-underglow {
  to {
    background-position: 300% center;
  }
}

/* ---------- 设计令牌 ---------- */
:root[data-theme="official"] {
  color-scheme: dark;
  --bg: #070a13;
  --panel: rgba(18, 23, 41, 0.72);
  --panel-border: rgba(124, 142, 230, 0.16);
  --panel-strong: rgba(24, 30, 52, 0.94);
  --text: #e9edfb;
  --muted: #93a0c2;
  --accent: #818cf8;
  --accent-strong: #6366f1;
  --accent-soft: rgba(99, 102, 241, 0.18);
  --warning: #fbbf24;
  --danger: #fb7185;
  --neutral: #22d3ee;
  --shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04), 0 16px 40px rgba(2, 6, 23, 0.5);
  --fx-grad: linear-gradient(120deg, #22d3ee, #818cf8 45%, #e879f9 90%);
  --fx-surface: rgba(10, 14, 27, 0.55);
  --fx-line: rgba(124, 142, 230, 0.22);
}

html {
  background: #070a13;
}

:root[data-theme="official"] body {
  background: transparent;
  color: var(--text);
}

:root[data-theme="official"] body::after {
  content: "";
  position: fixed;
  inset: -12%;
  z-index: -1;
  pointer-events: none;
  background:
    radial-gradient(640px 420px at 16% 6%, rgba(34, 211, 238, 0.13), transparent 62%),
    radial-gradient(720px 480px at 84% 12%, rgba(232, 121, 249, 0.11), transparent 64%),
    radial-gradient(820px 560px at 50% 110%, rgba(99, 102, 241, 0.14), transparent 60%),
    linear-gradient(160deg, #0a0e1d 0%, #070a13 50%, #0b0a18 100%);
  animation: fx-aurora 28s ease-in-out infinite alternate;
}

:root[data-theme="official"] ::selection {
  background: rgba(34, 211, 238, 0.32);
}

:root[data-theme="official"] *::-webkit-scrollbar-thumb {
  background-color: rgba(129, 140, 248, 0.36);
}

:root[data-theme="official"] *::-webkit-scrollbar-thumb:hover {
  background-color: rgba(129, 140, 248, 0.6);
}

/* ---------- 面板：玻璃 + 渐变描边 + 鼠标跟随光斑 ---------- */
:root[data-theme="official"] .brand,
:root[data-theme="official"] .panel {
  border: 1px solid var(--panel-border);
  border-radius: 18px;
  background:
    radial-gradient(560px circle at var(--mx, 50%) var(--my, -40%), rgba(129, 140, 248, 0.09), transparent 46%),
    linear-gradient(0deg, var(--panel), var(--panel));
  box-shadow: var(--shadow);
  backdrop-filter: blur(18px);
  color: var(--text);
  transition: border-color 0.25s ease, box-shadow 0.25s ease, transform 0.25s ease;
}

:root[data-theme="official"] .workspace > .panel:hover,
:root[data-theme="official"] .workspace > .grid > .panel:hover {
  border-color: rgba(129, 140, 248, 0.34);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.05),
    0 18px 44px rgba(2, 6, 23, 0.55),
    0 0 24px rgba(99, 102, 241, 0.12);
}

:root[data-theme="official"] .panel-title-row {
  border-bottom: 1px solid rgba(124, 142, 230, 0.14);
}

:root[data-theme="official"] .panel-title-row h2,
:root[data-theme="official"] .panel-title-row h3,
:root[data-theme="official"] .panel h2,
:root[data-theme="official"] .panel h3,
:root[data-theme="official"] .panel h4 {
  color: #f2f5ff;
  font-weight: 800;
  letter-spacing: 0.01em;
}

:root[data-theme="official"] .section-copy,
:root[data-theme="official"] .small,
:root[data-theme="official"] .field span,
:root[data-theme="official"] .setting-copy p {
  color: var(--muted);
}

:root[data-theme="official"] .setting-copy strong,
:root[data-theme="official"] .metric-card strong {
  color: #f2f5ff;
}

/* ---------- 品牌区 ---------- */
:root[data-theme="official"] .brand-badge {
  background: var(--fx-grad);
  background-size: 200% auto;
  color: #0b0e1a;
  box-shadow: 0 0 22px rgba(129, 140, 248, 0.45);
  animation: fx-pan 7s linear infinite;
}

:root[data-theme="official"] .brand h1 {
  background: var(--fx-grad);
  background-size: 200% auto;
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  font-weight: 850;
  animation: fx-pan 9s linear infinite;
}

:root[data-theme="official"] .brand p {
  color: var(--muted);
}

/* ---------- 侧边导航 ---------- */
:root[data-theme="official"] .section-nav {
  background:
    radial-gradient(560px circle at var(--mx, 50%) var(--my, -40%), rgba(129, 140, 248, 0.09), transparent 46%),
    linear-gradient(0deg, var(--panel), var(--panel));
}

:root[data-theme="official"] .section-nav::before {
  color: #6f7ba0;
  letter-spacing: 0.22em;
}

:root[data-theme="official"] .nav-chip {
  border-radius: 13px;
  color: #aab4d4;
  font-weight: 650;
  transition: background-color 0.18s ease, color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

:root[data-theme="official"] .nav-chip::before {
  border-radius: 9px;
  background: rgba(129, 140, 248, 0.12);
  color: #aab4d4;
  font-size: 12px;
  font-weight: 700;
  transition: background-color 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

:root[data-theme="official"] .nav-chip:hover {
  background: rgba(129, 140, 248, 0.1);
  border-color: transparent;
  color: #f2f5ff;
  transform: translateX(3px);
}

:root[data-theme="official"] .nav-chip:hover::before {
  background: rgba(129, 140, 248, 0.26);
  color: #c7d2fe;
  transform: scale(1.08);
}

:root[data-theme="official"] .nav-chip-active,
:root[data-theme="official"] .nav-chip-active:hover {
  background: var(--fx-grad);
  background-size: 220% auto;
  border-color: transparent;
  color: #0b0e1a;
  font-weight: 800;
  box-shadow: 0 8px 24px rgba(99, 102, 241, 0.4);
  animation: fx-pan 8s linear infinite;
  transform: none;
}

:root[data-theme="official"] .nav-chip-active::before,
:root[data-theme="official"] .nav-chip-active:hover::before {
  background: rgba(7, 10, 19, 0.28);
  color: #f2f5ff;
}

/* ---------- 按钮 ---------- */
:root[data-theme="official"] .button {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  border-radius: 12px;
  font-weight: 700;
  transition:
    transform 0.14s ease,
    box-shadow 0.2s ease,
    background-color 0.2s ease,
    border-color 0.2s ease,
    color 0.2s ease,
    filter 0.2s ease;
}

:root[data-theme="official"] .button::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: linear-gradient(115deg, transparent 30%, rgba(255, 255, 255, 0.22) 50%, transparent 70%);
  transform: translateX(-120%);
  transition: transform 0.5s ease;
  pointer-events: none;
}

:root[data-theme="official"] .button:hover::after {
  transform: translateX(120%);
}

:root[data-theme="official"] .button:hover {
  transform: translateY(-2px);
}

:root[data-theme="official"] .button:active {
  transform: translateY(0) scale(0.97);
}

:root[data-theme="official"] .button-primary {
  background: var(--fx-grad);
  background-size: 200% auto;
  border-color: transparent;
  color: #0b0e1a;
  box-shadow: 0 6px 20px rgba(99, 102, 241, 0.35);
}

:root[data-theme="official"] .button-primary:hover {
  background-position: 60% center;
  box-shadow: 0 10px 28px rgba(129, 140, 248, 0.5);
  filter: none;
}

:root[data-theme="official"] .button-secondary {
  background: rgba(99, 102, 241, 0.14);
  border-color: rgba(129, 140, 248, 0.34);
  color: #c7d2fe;
}

:root[data-theme="official"] .button-secondary:hover {
  background: rgba(99, 102, 241, 0.24);
  border-color: rgba(165, 180, 252, 0.55);
  color: #e0e7ff;
}

:root[data-theme="official"] .button-ghost {
  background: rgba(148, 163, 184, 0.08);
  border-color: rgba(148, 163, 184, 0.2);
  color: #aab4d4;
}

:root[data-theme="official"] .button-ghost:hover {
  background: rgba(148, 163, 184, 0.16);
  color: #f2f5ff;
}

:root[data-theme="official"] .button-danger {
  background: linear-gradient(120deg, #fb7185, #f43f5e 60%, #e11d48);
  background-size: 200% auto;
  border-color: transparent;
  color: #1a0509;
  box-shadow: 0 6px 18px rgba(244, 63, 94, 0.35);
}

:root[data-theme="official"] .button-danger:hover {
  background-position: 70% center;
  box-shadow: 0 10px 26px rgba(244, 63, 94, 0.48);
  filter: none;
}

:root[data-theme="official"] .button-success {
  background: linear-gradient(120deg, #34d399, #10b981);
  border-color: transparent;
  color: #04150d;
}

/* ---------- 状态胶囊 / 标签 ---------- */
:root[data-theme="official"] .pill {
  font-weight: 700;
  letter-spacing: 0.02em;
}

:root[data-theme="official"] .pill-neutral,
:root[data-theme="official"] .pill-idle {
  background: rgba(129, 140, 248, 0.14);
  color: #c7d2fe;
}

:root[data-theme="official"] .pill-connected {
  background: rgba(52, 211, 153, 0.16);
  color: #6ee7b7;
  box-shadow: 0 0 14px rgba(52, 211, 153, 0.22);
}

:root[data-theme="official"] .pill-error {
  background: rgba(251, 113, 133, 0.16);
  color: #fda4af;
  box-shadow: 0 0 14px rgba(251, 113, 133, 0.2);
}

:root[data-theme="official"] .tag {
  background: rgba(129, 140, 248, 0.14);
  color: #c7d2fe;
}

:root[data-theme="official"] .tag.ok {
  background: rgba(52, 211, 153, 0.16);
  color: #6ee7b7;
}

:root[data-theme="official"] .tag.warn {
  background: rgba(251, 191, 36, 0.16);
  color: #fcd34d;
}

/* ---------- 表单控件 ---------- */
:root[data-theme="official"] .field input,
:root[data-theme="official"] .field select,
:root[data-theme="official"] .field textarea,
:root[data-theme="official"] textarea,
:root[data-theme="official"] select,
:root[data-theme="official"] input {
  background: var(--fx-surface);
  border-color: var(--fx-line);
  color: var(--text);
  transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

:root[data-theme="official"] .field input:hover,
:root[data-theme="official"] .field select:hover,
:root[data-theme="official"] select:hover {
  border-color: rgba(165, 180, 252, 0.4);
}

:root[data-theme="official"] .field input:focus,
:root[data-theme="official"] .field select:focus,
:root[data-theme="official"] .field textarea:focus,
:root[data-theme="official"] textarea:focus,
:root[data-theme="official"] select:focus,
:root[data-theme="official"] input[type="text"]:focus,
:root[data-theme="official"] input[type="number"]:focus {
  border-color: rgba(34, 211, 238, 0.65);
  outline: none;
  box-shadow:
    0 0 0 3px rgba(34, 211, 238, 0.16),
    0 0 18px rgba(34, 211, 238, 0.14);
}

:root[data-theme="official"] select:disabled,
:root[data-theme="official"] input:disabled {
  color: #5d6788;
}

:root[data-theme="official"] input[type="range"],
:root[data-theme="official"] input[type="checkbox"],
:root[data-theme="official"] input[type="radio"] {
  accent-color: #818cf8;
  box-shadow: none;
}

:root[data-theme="official"] .toggle-row span {
  color: var(--muted);
}

/* ---------- 信息卡片 ---------- */
:root[data-theme="official"] .status-list div,
:root[data-theme="official"] .info-grid div,
:root[data-theme="official"] .metric-card,
:root[data-theme="official"] .setting-card,
:root[data-theme="official"] .callout-card,
:root[data-theme="official"] .slider-card {
  background: var(--fx-surface);
  border: 1px solid var(--fx-line);
  border-radius: 14px;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

:root[data-theme="official"] .setting-card:hover,
:root[data-theme="official"] .metric-card:hover {
  border-color: rgba(129, 140, 248, 0.4);
  box-shadow: 0 8px 24px rgba(2, 6, 23, 0.45), 0 0 18px rgba(99, 102, 241, 0.14);
  transform: translateY(-2px);
}

:root[data-theme="official"] .status-list dt,
:root[data-theme="official"] .info-grid dt {
  color: var(--muted);
}

:root[data-theme="official"] .status-list dd,
:root[data-theme="official"] .info-grid dd {
  color: #f2f5ff;
}

:root[data-theme="official"] .empty-state {
  border-radius: 12px;
  color: #6f7ba0;
}

:root[data-theme="official"] .info-banner {
  background: rgba(99, 102, 241, 0.1);
  border-color: rgba(129, 140, 248, 0.26);
  border-radius: 12px;
}

:root[data-theme="official"] .info-banner p {
  color: #c7d2fe;
}

:root[data-theme="official"] .danger-banner {
  background: rgba(244, 63, 94, 0.1);
  border-color: rgba(251, 113, 133, 0.3);
}

:root[data-theme="official"] .danger-banner p {
  color: #fda4af;
}

:root[data-theme="official"] .snapshot-preview {
  background: rgba(5, 8, 16, 0.8);
  border: 1px solid rgba(124, 142, 230, 0.18);
  border-radius: 12px;
  color: #b7c5e8;
}

:root[data-theme="official"] .debug-details > summary {
  background: rgba(129, 140, 248, 0.12);
  color: #93a0c2;
}

:root[data-theme="official"] .debug-details > summary:hover {
  background: rgba(129, 140, 248, 0.24);
  color: #e9edfb;
}

:root[data-theme="official"] .port-card {
  border-radius: 14px;
  border-color: var(--fx-line);
  background: var(--fx-surface);
}

:root[data-theme="official"] .port-card.selected {
  border-color: rgba(34, 211, 238, 0.6);
  background: rgba(34, 211, 238, 0.08);
  box-shadow: 0 0 18px rgba(34, 211, 238, 0.18);
}

:root[data-theme="official"] .collection-meta {
  color: var(--muted);
}

/* ---------- 配置档（侧栏） ---------- */
:root[data-theme="official"] #profile-panel #profile-title {
  color: #f2f5ff;
}

:root[data-theme="official"] #profile-panel .button {
  border-radius: 12px;
  box-shadow: none;
}

:root[data-theme="official"] #profile-panel .button-primary {
  background: var(--fx-grad);
  background-size: 200% auto;
  color: #0b0e1a;
  box-shadow: 0 6px 20px rgba(99, 102, 241, 0.38);
}

:root[data-theme="official"] #profile-panel .button-secondary {
  background: rgba(129, 140, 248, 0.1);
  border: 1px solid rgba(129, 140, 248, 0.22);
  color: #aab4d4;
}

:root[data-theme="official"] #profile-panel .button-secondary:hover {
  background: rgba(129, 140, 248, 0.2);
  color: #f2f5ff;
  filter: none;
}

/* ---------- 右键菜单（配置档 / 宏 / DKS） ---------- */
:root[data-theme="official"] .profile-context-menu,
:root[data-theme="official"] .macro-context-menu,
:root[data-theme="official"] .advanced-dks-context-menu {
  background: rgba(16, 21, 38, 0.96);
  border: 1px solid rgba(129, 140, 248, 0.3);
  border-radius: 12px;
  box-shadow: 0 18px 44px rgba(2, 6, 23, 0.6), 0 0 22px rgba(99, 102, 241, 0.16);
  backdrop-filter: blur(16px);
}

:root[data-theme="official"] .profile-context-menu button,
:root[data-theme="official"] .macro-context-menu button,
:root[data-theme="official"] .advanced-dks-context-menu button {
  color: #d6ddf5;
}

:root[data-theme="official"] .profile-context-menu button:hover,
:root[data-theme="official"] .macro-context-menu button:hover,
:root[data-theme="official"] .advanced-dks-context-menu button:hover {
  background: rgba(129, 140, 248, 0.18);
  color: #ffffff;
}

/* ---------- 键盘矩阵：暗夜底座 + RGB 底光灯带 ---------- */
:root[data-theme="official"] .keyboard-matrix {
  border-radius: 18px 18px 12px 12px;
  background:
    radial-gradient(520px circle at var(--mx, 50%) var(--my, 0%), rgba(34, 211, 238, 0.08), transparent 46%),
    linear-gradient(180deg, #161b2e 0%, #121729 58%, #0e1322 100%);
  box-shadow:
    0 26px 52px rgba(2, 6, 23, 0.6),
    0 4px 12px rgba(2, 6, 23, 0.5),
    inset 0 0 0 1px rgba(129, 140, 248, 0.2);
}

:root[data-theme="official"] .keyboard-matrix::before {
  border-radius: 16px 16px 0 0;
  background:
    linear-gradient(90deg, rgba(34, 211, 238, 0.1), rgba(129, 140, 248, 0.14) 50%, rgba(232, 121, 249, 0.1)),
    linear-gradient(180deg, #1c2238, #141a2d);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    inset 0 -1px 0 rgba(0, 0, 0, 0.4);
}

:root[data-theme="official"] .keyboard-matrix::after {
  border-radius: 0 0 10px 10px;
  background: var(--fx-grad);
  background-size: 300% auto;
  box-shadow:
    0 6px 22px rgba(129, 140, 248, 0.4),
    inset 0 2px 6px rgba(2, 6, 23, 0.55);
  animation: fx-underglow 9s linear infinite;
  opacity: 0.85;
}

:root[data-theme="official"] .keyboard-matrix .key-button,
:root[data-theme="official"] .keyboard-matrix.compact .key-button {
  color: #d6ddf5;
  background: linear-gradient(180deg, #2b3350 0%, #232a44 55%, #1c2238 100%);
  border: 1px solid rgba(148, 163, 200, 0.28);
  border-radius: 8px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    inset 0 -3px 0 rgba(2, 6, 23, 0.45),
    0 2px 4px rgba(2, 6, 23, 0.5);
  transition: transform 0.12s ease, border-color 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease;
}

:root[data-theme="official"] .keyboard-matrix .key-button:hover {
  border-color: rgba(34, 211, 238, 0.75);
  transform: translateY(-2px);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    inset 0 -3px 0 rgba(2, 6, 23, 0.4),
    0 0 0 2px rgba(34, 211, 238, 0.28),
    0 0 18px rgba(34, 211, 238, 0.35),
    0 6px 12px rgba(2, 6, 23, 0.5);
}

:root[data-theme="official"] .keyboard-matrix .key-button.active {
  color: #0b0e1a;
  background: var(--fx-grad);
  background-size: 220% auto;
  border-color: transparent;
  animation: fx-key-pulse 2.4s ease-in-out infinite, fx-pan 6s linear infinite;
}

:root[data-theme="official"] .keyboard-matrix .key-button.special-key:not(.active),
:root[data-theme="official"] .keyboard-matrix .key-button.vendor:not(.active) {
  color: #c7d2fe;
  background: linear-gradient(180deg, #2c2f55 0%, #252947 55%, #1d2138 100%);
  border-color: rgba(129, 140, 248, 0.4);
}

:root[data-theme="official"] .keyboard-matrix .key-button.remapped:not(.active) {
  color: #6ee7b7;
  background: linear-gradient(180deg, rgba(16, 185, 129, 0.24), rgba(6, 78, 59, 0.4));
  border-color: rgba(52, 211, 153, 0.6);
}

:root[data-theme="official"] .keyboard-matrix .key-button.multi-selected:not(.active) {
  color: #fcd34d;
  background: linear-gradient(180deg, rgba(251, 191, 36, 0.2), rgba(120, 53, 15, 0.4));
  border-color: rgba(251, 191, 36, 0.7);
  box-shadow:
    inset 0 0 0 2px rgba(251, 191, 36, 0.35),
    0 0 14px rgba(251, 191, 36, 0.25),
    0 2px 4px rgba(2, 6, 23, 0.5);
}

:root[data-theme="official"] .keyboard-matrix .key-button.has-magnetic-readback:not(.active),
:root[data-theme="official"] .keyboard-matrix .key-button.has-magnetic-readback.special-key:not(.active),
:root[data-theme="official"] .keyboard-matrix .key-button.has-magnetic-readback.vendor:not(.active) {
  color: #e9edfb;
  background: linear-gradient(180deg, rgba(99, 102, 241, 0.26), rgba(30, 27, 75, 0.55));
  border-color: rgba(251, 191, 36, 0.8);
  box-shadow:
    inset 0 0 0 2px rgba(251, 191, 36, 0.5),
    0 0 14px rgba(251, 191, 36, 0.2),
    0 2px 4px rgba(2, 6, 23, 0.5);
}

:root[data-theme="official"] .keyboard-matrix .key-button.ready:not(.active) {
  color: #d6ddf5;
}

:root[data-theme="official"] .keyboard-matrix .magnetic-key-readback {
  color: #e9edfb;
}

:root[data-theme="official"] .keyboard-matrix .magnetic-key-readback i {
  text-shadow: 0 1px 2px rgba(2, 6, 23, 0.8);
}

:root[data-theme="official"] .keyboard-matrix .magnetic-readback-travel {
  color: #e9edfb;
}

:root[data-theme="official"] .keyboard-matrix .magnetic-readback-press,
:root[data-theme="official"] .keyboard-matrix .magnetic-readback-top {
  color: #fda4af;
}

:root[data-theme="official"] .keyboard-matrix .magnetic-readback-release,
:root[data-theme="official"] .keyboard-matrix .magnetic-readback-bottom {
  color: #67e8f9;
}

:root[data-theme="official"] .keyboard-matrix .key-button.has-magnetic-readback::after {
  color: #e879f9;
  text-shadow: 0 1px 2px rgba(2, 6, 23, 0.8);
}

:root[data-theme="official"] .keyboard-matrix .calibration-value-pair {
  color: #e9edfb;
}

:root[data-theme="official"] .key-button.calibration-key.calibrated:not(.active) {
  color: #6ee7b7;
}

:root[data-theme="official"] .key-button.calibration-key.calibration-hot:not(.active) {
  color: #fcd34d;
}

/* ---------- 改键页键盘与输出选择区 ---------- */
:root[data-theme="official"] .keymap-official-page {
  border-radius: 16px;
  background: transparent;
}

:root[data-theme="official"] .keymap-official-matrix {
  border: 1px solid rgba(129, 140, 248, 0.22);
  border-radius: 16px;
  background:
    radial-gradient(520px circle at var(--mx, 50%) var(--my, 0%), rgba(34, 211, 238, 0.07), transparent 46%),
    linear-gradient(180deg, #161b2e 0%, #0f1424 100%);
}

:root[data-theme="official"] .keymap-official-matrix .key-button {
  color: #d6ddf5;
  background: linear-gradient(180deg, #2b3350 0%, #232a44 55%, #1c2238 100%);
  border-color: rgba(148, 163, 200, 0.28);
  border-radius: 8px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    inset 0 -3px 0 rgba(2, 6, 23, 0.45),
    0 2px 4px rgba(2, 6, 23, 0.5);
}

:root[data-theme="official"] .keymap-official-matrix .key-button.active {
  color: #0b0e1a;
  background: var(--fx-grad);
  background-size: 220% auto;
  border-color: transparent;
  box-shadow:
    0 0 0 2px rgba(129, 140, 248, 0.45),
    0 0 18px rgba(129, 140, 248, 0.45),
    0 2px 4px rgba(2, 6, 23, 0.5);
}

:root[data-theme="official"] .keymap-output-panel {
  background: transparent;
}

:root[data-theme="official"] .keymap-output-tabs button {
  background: transparent;
  border-color: transparent;
  color: #93a0c2;
  transition: color 0.18s ease, background-color 0.18s ease, box-shadow 0.18s ease;
}

:root[data-theme="official"] .keymap-output-tabs button:hover {
  color: #e9edfb;
  background: rgba(129, 140, 248, 0.1);
}

:root[data-theme="official"] .keymap-output-tabs button.active {
  color: #0b0e1a;
  background: var(--fx-grad);
  background-size: 220% auto;
  box-shadow: 0 6px 16px rgba(99, 102, 241, 0.35);
}

:root[data-theme="official"] .keymap-output-button {
  background: var(--fx-surface);
  border: 1px solid var(--fx-line);
  color: #d6ddf5;
  transition: transform 0.13s ease, border-color 0.16s ease, box-shadow 0.16s ease, background-color 0.16s ease;
}

:root[data-theme="official"] .keymap-output-button small {
  color: #6f7ba0;
}

:root[data-theme="official"] .keymap-output-button:hover:not(:disabled) {
  border-color: rgba(34, 211, 238, 0.6);
  transform: translateY(-2px);
  box-shadow:
    0 0 0 2px rgba(34, 211, 238, 0.2),
    0 0 16px rgba(34, 211, 238, 0.25);
}

:root[data-theme="official"] .keymap-output-button.active {
  color: #0b0e1a;
  background: var(--fx-grad);
  background-size: 220% auto;
  border-color: transparent;
  box-shadow: 0 0 18px rgba(129, 140, 248, 0.4);
}

:root[data-theme="official"] .keymap-output-button.active small {
  color: rgba(11, 14, 26, 0.7);
}

:root[data-theme="official"] .keymap-output-button.unsupported {
  opacity: 0.4;
}

:root[data-theme="official"] .keymap-output-empty {
  color: #6f7ba0;
  background: var(--fx-surface);
  border-color: var(--fx-line);
}

:root[data-theme="official"] .keymap-layer-card,
:root[data-theme="official"] .layer-summary-card {
  background: var(--fx-surface);
  border-color: var(--fx-line);
  color: var(--text);
}

:root[data-theme="official"] .layer-summary-card span {
  color: var(--muted);
}

:root[data-theme="official"] .layer-tab {
  background: rgba(129, 140, 248, 0.08);
  border-color: rgba(129, 140, 248, 0.18);
  color: #aab4d4;
  transition: background-color 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
}

:root[data-theme="official"] .layer-tab:hover {
  background: rgba(129, 140, 248, 0.18);
  color: #f2f5ff;
}

:root[data-theme="official"] .layer-tab.active {
  background: var(--fx-grad);
  background-size: 220% auto;
  border-color: transparent;
  color: #0b0e1a;
  box-shadow: 0 6px 16px rgba(99, 102, 241, 0.35);
}

:root[data-theme="official"] .keymap-reset-layer-button {
  background: rgba(251, 113, 133, 0.12);
  border-color: rgba(251, 113, 133, 0.32);
  color: #fda4af;
}

:root[data-theme="official"] .keymap-callout {
  color: var(--muted);
}

/* ---------- 性能页：模式切换 / 竖向滑条 / 死区 ---------- */
:root[data-theme="official"] .magnetic-mode-tab {
  border-radius: 999px;
  background: rgba(129, 140, 248, 0.1);
  color: #aab4d4;
  transition: background-color 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
}

:root[data-theme="official"] .magnetic-mode-tab:hover {
  color: #f2f5ff;
  background: rgba(129, 140, 248, 0.2);
}

:root[data-theme="official"] .magnetic-mode-tab.active {
  background: var(--fx-grad);
  background-size: 220% auto;
  color: #0b0e1a;
  box-shadow: 0 6px 18px rgba(99, 102, 241, 0.4);
}

:root[data-theme="official"] .magnetic-state-strip,
:root[data-theme="official"] .magnetic-status-line p {
  color: var(--muted);
}

:root[data-theme="official"] .magnetic-performance-column {
  background: var(--fx-surface);
  border: 1px solid var(--fx-line);
  border-radius: 16px;
}

:root[data-theme="official"] .magnetic-column-head h3 {
  color: #f2f5ff;
}

:root[data-theme="official"] .magnetic-column-head p {
  color: var(--muted);
}

:root[data-theme="official"] .magnetic-axis-row > span {
  color: var(--muted);
}

:root[data-theme="official"] .rt-slider-card,
:root[data-theme="official"] .rt-slider-card > span {
  color: #aab4d4;
}

:root[data-theme="official"] .rt-step,
:root[data-theme="official"] .deadzone-step {
  background: rgba(129, 140, 248, 0.16);
  color: #e9edfb;
  transition: background-color 0.15s ease, transform 0.15s ease;
}

:root[data-theme="official"] .rt-step:hover,
:root[data-theme="official"] .deadzone-step:hover {
  background: rgba(129, 140, 248, 0.32);
  transform: scale(1.1);
}

:root[data-theme="official"] .rt-slider,
:root[data-theme="official"] .rt-independent-row input,
:root[data-theme="official"] .deadzone-slider {
  accent-color: #818cf8;
}

:root[data-theme="official"] .rt-independent-row {
  color: #aab4d4;
}

:root[data-theme="official"] .rt-value,
:root[data-theme="official"] .deadzone-slider-card strong {
  border-radius: 9px;
  background: var(--fx-grad);
  background-size: 200% auto;
  color: #0b0e1a;
  font-weight: 800;
  box-shadow: 0 4px 14px rgba(99, 102, 241, 0.35);
}

:root[data-theme="official"] .deadzone-slider-card,
:root[data-theme="official"] .deadzone-slider-card span {
  color: #aab4d4;
}

:root[data-theme="official"] .magnetic-official-switch span {
  background: rgba(129, 140, 248, 0.18);
}

:root[data-theme="official"] .magnetic-official-switch input:checked + span {
  background: var(--fx-grad);
  background-size: 200% auto;
  box-shadow: 0 0 14px rgba(129, 140, 248, 0.45);
}

/* ---------- 行程深度可视化（轴体剖面） ---------- */
:root[data-theme="official"] .switch-housing {
  background: linear-gradient(180deg, #283052, #1a2036);
  border-color: rgba(148, 163, 200, 0.3);
}

:root[data-theme="official"] .switch-stem {
  background: linear-gradient(180deg, #22d3ee, #818cf8);
  border-color: rgba(34, 211, 238, 0.5);
}

:root[data-theme="official"] .travel-depth-step {
  background: rgba(129, 140, 248, 0.16);
  color: #e9edfb;
}

:root[data-theme="official"] .travel-depth-ruler span,
:root[data-theme="official"] .travel-depth-ruler b {
  color: #93a0c2;
}

:root[data-theme="official"] .travel-depth-readout,
:root[data-theme="official"] .travel-depth-value,
:root[data-theme="official"] #travel-depth-unit-value {
  color: #f2f5ff;
}

:root[data-theme="official"] .travel-depth-slider {
  accent-color: #22d3ee;
}

/* ---------- 行程监视 / 测量 / 校准弹窗 ---------- */
:root[data-theme="official"] .travel-calibration-modal-card,
:root[data-theme="official"] .travel-measure-modal-card {
  background: rgba(14, 18, 34, 0.97);
  border: 1px solid rgba(129, 140, 248, 0.3);
  color: var(--text);
  box-shadow: 0 30px 80px rgba(2, 6, 23, 0.7), 0 0 32px rgba(99, 102, 241, 0.18);
}

:root[data-theme="official"] .travel-calibration-modal-head h3 {
  color: #f2f5ff;
}

:root[data-theme="official"] .travel-calibration-status {
  color: var(--muted);
}

:root[data-theme="official"] .travel-monitor-chart {
  background: var(--fx-surface);
  border-color: var(--fx-line);
}

:root[data-theme="official"] .travel-monitor-chart-toolbar strong {
  color: #f2f5ff;
}

:root[data-theme="official"] .travel-monitor-chart-toolbar span {
  color: var(--muted);
}

:root[data-theme="official"] .travel-measure-official-panel {
  background: var(--fx-surface);
  border-color: var(--fx-line);
}

:root[data-theme="official"] .travel-measure-title-row strong {
  color: #f2f5ff;
}

:root[data-theme="official"] .travel-measure-title-row span {
  color: var(--muted);
}

:root[data-theme="official"] .travel-measure-track {
  background: rgba(129, 140, 248, 0.14);
}

:root[data-theme="official"] .travel-measure-fill {
  background: var(--fx-grad);
}

:root[data-theme="official"] .travel-measure-thumb {
  background: #e9edfb;
  box-shadow: 0 0 12px rgba(34, 211, 238, 0.6);
}

:root[data-theme="official"] .travel-measure-ruler span,
:root[data-theme="official"] .travel-measure-ruler b,
:root[data-theme="official"] .travel-monitor-ruler span,
:root[data-theme="official"] .travel-monitor-ruler b {
  color: #93a0c2;
}

:root[data-theme="official"] .travel-measure-readout dt {
  color: var(--muted);
}

:root[data-theme="official"] .travel-measure-readout dd {
  color: #f2f5ff;
}

:root[data-theme="official"] .travel-measure-empty {
  color: #6f7ba0;
}

:root[data-theme="official"] .travel-monitor-gauge-bar {
  background: rgba(129, 140, 248, 0.14);
}

:root[data-theme="official"] .travel-monitor-gauge-bar::before {
  background: var(--fx-grad);
}

:root[data-theme="official"] .travel-monitor-gauge-marker span {
  color: #e9edfb;
}

:root[data-theme="official"] .travel-monitor-row {
  background: var(--fx-surface);
  border-color: var(--fx-line);
  color: var(--text);
}

:root[data-theme="official"] .travel-monitor-row-meta {
  color: var(--muted);
}

:root[data-theme="official"] .travel-monitor-row-bar {
  background: rgba(129, 140, 248, 0.14);
}

:root[data-theme="official"] .travel-monitor-row-bar i {
  background: var(--fx-grad);
}

:root[data-theme="official"] .travel-monitor-row.pressed {
  border-color: rgba(34, 211, 238, 0.5);
  box-shadow: 0 0 14px rgba(34, 211, 238, 0.2);
}

:root[data-theme="official"] .travel-monitor-column-track {
  background: rgba(129, 140, 248, 0.12);
}

:root[data-theme="official"] .travel-monitor-column-fill {
  background: var(--fx-grad);
}

:root[data-theme="official"] .travel-monitor-column-key,
:root[data-theme="official"] .travel-monitor-column-ad {
  color: #aab4d4;
}

:root[data-theme="official"] .travel-monitor-column.pressed .travel-monitor-column-track {
  box-shadow: 0 0 14px rgba(34, 211, 238, 0.35);
}

/* ---------- 高级键页 ---------- */
:root[data-theme="official"] .keymap-feature-grid > .panel:first-child {
  background:
    radial-gradient(560px circle at var(--mx, 50%) var(--my, -40%), rgba(129, 140, 248, 0.09), transparent 46%),
    linear-gradient(0deg, var(--panel), var(--panel));
  border-color: var(--panel-border);
}

:root[data-theme="official"] .advanced-official-panel .advanced-keyboard-panel,
:root[data-theme="official"] .advanced-keyboard-panel {
  background: transparent;
  border-color: transparent;
}

:root[data-theme="official"] .advanced-official-panel .advanced-device-panel,
:root[data-theme="official"] .advanced-device-panel {
  background: var(--fx-surface);
  border: 1px solid var(--fx-line);
  border-radius: 16px;
}

:root[data-theme="official"] .advanced-device-stat-card {
  background: rgba(129, 140, 248, 0.08);
  border: 1px solid var(--fx-line);
  color: var(--text);
}

:root[data-theme="official"] .advanced-device-stat-card small {
  color: var(--muted);
}

:root[data-theme="official"] .advanced-device-stat-card strong {
  color: #f2f5ff;
}

:root[data-theme="official"] .advanced-device-filter {
  background: rgba(129, 140, 248, 0.08);
  border-color: var(--fx-line);
  color: #aab4d4;
  transition: background-color 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
}

:root[data-theme="official"] .advanced-device-filter:hover {
  background: rgba(129, 140, 248, 0.18);
  color: #f2f5ff;
}

:root[data-theme="official"] .advanced-device-filter.active {
  background: var(--fx-grad);
  background-size: 220% auto;
  border-color: transparent;
  color: #0b0e1a;
  box-shadow: 0 4px 14px rgba(99, 102, 241, 0.35);
}

:root[data-theme="official"] .advanced-device-filter.active strong {
  color: #0b0e1a;
}

:root[data-theme="official"] .advanced-device-card {
  background: rgba(129, 140, 248, 0.07);
  border: 1px solid var(--fx-line);
  color: var(--text);
  transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

:root[data-theme="official"] .advanced-device-card:hover {
  border-color: rgba(34, 211, 238, 0.5);
  box-shadow: 0 0 16px rgba(34, 211, 238, 0.16);
  transform: translateY(-2px);
}

:root[data-theme="official"] .advanced-device-card.current {
  border-color: rgba(129, 140, 248, 0.6);
  box-shadow: 0 0 0 1px rgba(129, 140, 248, 0.4), 0 0 18px rgba(99, 102, 241, 0.2);
}

:root[data-theme="official"] .advanced-device-card-head strong {
  color: #f2f5ff;
}

:root[data-theme="official"] .advanced-device-index {
  background: rgba(129, 140, 248, 0.18);
  color: #c7d2fe;
}

:root[data-theme="official"] .advanced-device-type {
  background: rgba(34, 211, 238, 0.14);
  color: #67e8f9;
}

:root[data-theme="official"] .advanced-device-edit-hint {
  color: var(--muted);
}

:root[data-theme="official"] .advanced-device-meta,
:root[data-theme="official"] .advanced-device-summary-line {
  color: var(--muted);
}

:root[data-theme="official"] .advanced-device-detail-list dt {
  color: var(--muted);
}

:root[data-theme="official"] .advanced-device-detail-list dd {
  color: #e9edfb;
}

:root[data-theme="official"] .advanced-device-empty-list,
:root[data-theme="official"] .advanced-official-panel .advanced-device-empty-list {
  background: rgba(129, 140, 248, 0.06);
  border: 1px dashed rgba(129, 140, 248, 0.3);
  color: var(--muted);
}

:root[data-theme="official"] .advanced-device-empty-list strong {
  color: #e9edfb;
}

/* 类型卡（含官方块的高优先级 active 变体） */
:root[data-theme="official"] .advanced-official-panel .advanced-type-card,
:root[data-theme="official"] .advanced-type-card {
  background: var(--fx-surface);
  border: 1px solid var(--fx-line);
  border-radius: 14px;
  color: var(--text);
  transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease, background-color 0.2s ease;
}

:root[data-theme="official"] .advanced-official-panel .advanced-type-card:hover,
:root[data-theme="official"] .advanced-type-card:hover {
  background: rgba(129, 140, 248, 0.1);
  border-color: rgba(34, 211, 238, 0.5);
  box-shadow: 0 0 18px rgba(34, 211, 238, 0.16);
  transform: translateY(-3px);
}

:root[data-theme="official"] .advanced-official-panel .advanced-type-card.active,
:root[data-theme="official"] .advanced-type-card.active {
  background: linear-gradient(135deg, rgba(34, 211, 238, 0.16), rgba(129, 140, 248, 0.18) 50%, rgba(232, 121, 249, 0.14));
  border-color: rgba(129, 140, 248, 0.65);
  box-shadow: 0 0 0 1px rgba(129, 140, 248, 0.4), 0 0 22px rgba(99, 102, 241, 0.22);
}

:root[data-theme="official"] .advanced-official-panel .advanced-type-card strong,
:root[data-theme="official"] .advanced-type-card strong {
  color: #c7d2fe;
}

:root[data-theme="official"] .advanced-official-panel .advanced-type-card .advanced-type-name,
:root[data-theme="official"] .advanced-type-name {
  color: #f2f5ff;
}

:root[data-theme="official"] .advanced-official-panel .advanced-type-card small,
:root[data-theme="official"] .advanced-type-card small {
  color: var(--muted);
}

:root[data-theme="official"] .advanced-official-panel .advanced-type-card.active small,
:root[data-theme="official"] .advanced-type-card.active small {
  color: #c7d2fe;
}

/* 绑定列表卡片 */
:root[data-theme="official"] .advanced-official-binding-card {
  background: var(--fx-surface);
  border: 1px solid var(--fx-line);
  border-radius: 12px;
  color: var(--text);
  transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

:root[data-theme="official"] .advanced-official-binding-card:hover {
  border-color: rgba(34, 211, 238, 0.5);
  box-shadow: 0 0 14px rgba(34, 211, 238, 0.15);
  transform: translateY(-2px);
}

:root[data-theme="official"] .advanced-official-binding-card.active {
  border-color: rgba(129, 140, 248, 0.65);
  background: rgba(99, 102, 241, 0.12);
  box-shadow: 0 0 0 1px rgba(129, 140, 248, 0.4), 0 0 18px rgba(99, 102, 241, 0.2);
}

:root[data-theme="official"] .advanced-official-binding-card strong {
  color: #f2f5ff;
}

:root[data-theme="official"] .advanced-official-binding-card small,
:root[data-theme="official"] .advanced-official-binding-card em {
  color: var(--muted);
}

:root[data-theme="official"] .advanced-official-binding-index {
  background: rgba(129, 140, 248, 0.18);
  color: #c7d2fe;
}

:root[data-theme="official"] .advanced-official-binding-type {
  background: rgba(34, 211, 238, 0.14);
  color: #67e8f9;
}

:root[data-theme="official"] .advanced-official-binding-delete {
  background: rgba(251, 113, 133, 0.14);
  color: #fda4af;
}

:root[data-theme="official"] .advanced-official-binding-delete:hover {
  background: rgba(251, 113, 133, 0.3);
  color: #ffe4e6;
}

:root[data-theme="official"] .advanced-official-binding-empty {
  background: rgba(129, 140, 248, 0.06);
  border: 1px dashed rgba(129, 140, 248, 0.3);
  color: var(--muted);
}

:root[data-theme="official"] .advanced-official-binding-empty strong {
  color: #e9edfb;
}

/* 绑定槽位 */
:root[data-theme="official"] .advanced-binding-slot {
  background: var(--fx-surface);
  border: 1px solid var(--fx-line);
  border-radius: 12px;
  transition: border-color 0.18s ease, background-color 0.18s ease, box-shadow 0.18s ease;
}

:root[data-theme="official"] .advanced-binding-slot:hover {
  border-color: rgba(34, 211, 238, 0.5);
  background: rgba(34, 211, 238, 0.06);
}

:root[data-theme="official"] .advanced-binding-slot.active {
  border-color: rgba(129, 140, 248, 0.65);
  background: rgba(99, 102, 241, 0.14);
  box-shadow: 0 0 0 1px rgba(129, 140, 248, 0.4), 0 0 16px rgba(99, 102, 241, 0.2);
}

:root[data-theme="official"] .advanced-binding-slot span {
  color: var(--muted);
}

:root[data-theme="official"] .advanced-binding-slot strong {
  color: #f2f5ff;
}

:root[data-theme="official"] .advanced-binding-slot small {
  color: var(--muted);
}

:root[data-theme="official"] .field.advanced-slot-control-active input {
  border-color: rgba(34, 211, 238, 0.65);
  box-shadow: 0 0 0 3px rgba(34, 211, 238, 0.16);
}

/* DKS 快速设置 */
:root[data-theme="official"] .dks-quick-panel {
  background: var(--fx-surface);
  border: 1px solid var(--fx-line);
  border-radius: 16px;
}

:root[data-theme="official"] .dks-quick-target {
  background: rgba(129, 140, 248, 0.1);
  border: 1px solid var(--fx-line);
  color: #f2f5ff;
}

:root[data-theme="official"] .dks-quick-target span {
  color: var(--muted);
}

:root[data-theme="official"] .advanced-full-editor {
  border-color: var(--fx-line);
}

:root[data-theme="official"] .advanced-full-editor summary {
  background: rgba(129, 140, 248, 0.1);
  color: #aab4d4;
}

:root[data-theme="official"] .advanced-full-editor summary:hover {
  color: #f2f5ff;
}

/* 测试绑定工作区 */
:root[data-theme="official"] .advanced-official-panel .advanced-test-workspace,
:root[data-theme="official"] .advanced-test-workspace {
  background: var(--fx-surface);
  border: 1px solid var(--fx-line);
  border-radius: 16px;
}

:root[data-theme="official"] .advanced-key-live-output {
  background: rgba(7, 10, 19, 0.6);
  border: 1px solid var(--fx-line);
  color: var(--muted);
}

:root[data-theme="official"] .advanced-key-live-output strong {
  background: var(--fx-grad);
  background-size: 200% auto;
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  animation: fx-pan 8s linear infinite;
}

:root[data-theme="official"] .advanced-key-live-output small {
  color: var(--muted);
}

:root[data-theme="official"] .advanced-official-panel .advanced-key-test-input,
:root[data-theme="official"] .advanced-key-test-input {
  background: rgba(7, 10, 19, 0.6);
  border: 1px dashed rgba(129, 140, 248, 0.35);
  color: #d6ddf5;
}

:root[data-theme="official"] .advanced-official-panel .advanced-key-test-input.has-active-key,
:root[data-theme="official"] .advanced-key-test-input.has-active-key {
  border-color: rgba(34, 211, 238, 0.65);
  box-shadow: 0 0 16px rgba(34, 211, 238, 0.2);
  color: #f2f5ff;
}

:root[data-theme="official"] .advanced-key-test-log {
  background: rgba(5, 8, 16, 0.8);
  color: #b7c5e8;
}

/* 高级键编辑器 */
:root[data-theme="official"] .advanced-editor-shell {
  background: var(--fx-surface);
  border-color: var(--fx-line);
}

:root[data-theme="official"] .advanced-editor-section-title h4 {
  color: #f2f5ff;
}

:root[data-theme="official"] .advanced-editor-section-title span {
  color: var(--muted);
}

:root[data-theme="official"] .advanced-editor-kind-card,
:root[data-theme="official"] .advanced-official-type-copy {
  background: rgba(99, 102, 241, 0.12);
  border: 1px solid rgba(129, 140, 248, 0.3);
  color: var(--text);
}

:root[data-theme="official"] .advanced-editor-kind-card strong {
  color: #c7d2fe;
}

:root[data-theme="official"] .advanced-editor-help {
  color: var(--muted);
}

:root[data-theme="official"] .advanced-output-box {
  background: var(--fx-surface);
  border: 1px solid var(--fx-line);
  color: var(--text);
  transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

:root[data-theme="official"] .advanced-output-box:hover {
  border-color: rgba(34, 211, 238, 0.5);
  box-shadow: 0 0 14px rgba(34, 211, 238, 0.16);
}

:root[data-theme="official"] .advanced-output-box.active {
  border-color: rgba(129, 140, 248, 0.7);
  background: rgba(99, 102, 241, 0.14);
  box-shadow: 0 0 0 1px rgba(129, 140, 248, 0.45), 0 0 18px rgba(99, 102, 241, 0.22);
}

:root[data-theme="official"] .advanced-output-box.target {
  border-color: rgba(232, 121, 249, 0.55);
}

:root[data-theme="official"] .advanced-output-box span {
  color: var(--muted);
}

:root[data-theme="official"] .advanced-output-box strong {
  color: #f2f5ff;
}

:root[data-theme="official"] .advanced-output-box small {
  color: var(--muted);
}

:root[data-theme="official"] .advanced-delay-field,
:root[data-theme="official"] .advanced-official-delay-field {
  color: var(--muted);
}

:root[data-theme="official"] .advanced-delay-field strong,
:root[data-theme="official"] .advanced-official-delay-field strong {
  background: var(--fx-grad);
  background-size: 200% auto;
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  font-weight: 800;
}

/* DKS 矩阵 */
:root[data-theme="official"] .advanced-official-dks-matrix-shell {
  background: rgba(7, 10, 19, 0.5);
  border: 1px solid var(--fx-line);
}

:root[data-theme="official"] .advanced-official-dks-corner {
  color: var(--muted);
}

:root[data-theme="official"] .advanced-official-dks-stage-head label span {
  color: #c7d2fe;
}

:root[data-theme="official"] .advanced-official-dks-direction {
  background: rgba(129, 140, 248, 0.12);
  border: 1px solid var(--fx-line);
  color: #d6ddf5;
  transition: background-color 0.18s ease, box-shadow 0.18s ease;
}

:root[data-theme="official"] .advanced-official-dks-direction[data-direction="press"] {
  background: rgba(34, 211, 238, 0.16);
  border-color: rgba(34, 211, 238, 0.45);
  color: #67e8f9;
}

:root[data-theme="official"] .advanced-official-dks-direction[data-direction="release"] {
  background: rgba(232, 121, 249, 0.14);
  border-color: rgba(232, 121, 249, 0.45);
  color: #f0abfc;
}

:root[data-theme="official"] .advanced-official-dks-grid-cell {
  background: rgba(129, 140, 248, 0.07);
  border: 1px solid var(--fx-line);
  color: #6f7ba0;
  transition: background-color 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease, color 0.15s ease;
}

:root[data-theme="official"] .advanced-official-dks-grid-cell:hover {
  border-color: rgba(34, 211, 238, 0.55);
  color: #67e8f9;
  box-shadow: 0 0 12px rgba(34, 211, 238, 0.2);
}

:root[data-theme="official"] .advanced-official-dks-grid-cell.active {
  background: var(--fx-grad);
  background-size: 220% auto;
  border-color: transparent;
  color: #0b0e1a;
  box-shadow: 0 0 14px rgba(129, 140, 248, 0.4);
}

/* SOCD */
:root[data-theme="official"] .advanced-official-socd-bind-pane {
  background: var(--fx-surface);
  border-color: var(--fx-line);
}

:root[data-theme="official"] .advanced-official-socd-key-field span {
  color: var(--muted);
}

:root[data-theme="official"] .advanced-official-socd-key-slot {
  background: rgba(129, 140, 248, 0.08);
  border-color: var(--fx-line);
}

:root[data-theme="official"] .advanced-official-socd-key-slot strong {
  color: #f2f5ff;
}

:root[data-theme="official"] .advanced-official-socd-key-slot.active {
  border-color: rgba(34, 211, 238, 0.6);
  box-shadow: 0 0 14px rgba(34, 211, 238, 0.2);
}

:root[data-theme="official"] .advanced-official-socd-bind-hint {
  color: var(--muted);
}

:root[data-theme="official"] .advanced-official-socd-rules {
  background: var(--fx-surface);
  border-color: var(--fx-line);
}

:root[data-theme="official"] .advanced-official-socd-rules legend {
  color: #f2f5ff;
}

:root[data-theme="official"] .advanced-official-socd-rule-copy {
  color: var(--muted);
}

:root[data-theme="official"] .advanced-official-socd-rule-option {
  border-color: var(--fx-line);
  background: rgba(129, 140, 248, 0.06);
  transition: border-color 0.18s ease, background-color 0.18s ease;
}

:root[data-theme="official"] .advanced-official-socd-rule-option:hover {
  border-color: rgba(129, 140, 248, 0.45);
  background: rgba(129, 140, 248, 0.12);
}

:root[data-theme="official"] .advanced-official-socd-rule-text strong {
  color: #f2f5ff;
}

:root[data-theme="official"] .advanced-official-socd-rule-text small {
  color: var(--muted);
}

/* MPT / 输出键选择 */
:root[data-theme="official"] .advanced-official-mpt-output strong {
  color: #f2f5ff;
}

:root[data-theme="official"] .advanced-official-mpt-output small {
  color: var(--muted);
}

:root[data-theme="official"] .advanced-output-accordion .advanced-output-category {
  background: rgba(129, 140, 248, 0.08);
  border-color: var(--fx-line);
  color: #aab4d4;
}

:root[data-theme="official"] .advanced-output-accordion .advanced-output-category.active {
  background: var(--fx-grad);
  background-size: 220% auto;
  border-color: transparent;
  color: #0b0e1a;
}

:root[data-theme="official"] .advanced-output-key {
  background: var(--fx-surface);
  border-color: var(--fx-line);
  color: #d6ddf5;
  transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
}

:root[data-theme="official"] .advanced-output-key:hover {
  border-color: rgba(34, 211, 238, 0.6);
  box-shadow: 0 0 12px rgba(34, 211, 238, 0.22);
  transform: translateY(-2px);
}

:root[data-theme="official"] .advanced-output-palette-empty {
  color: var(--muted);
}

/* ---------- 宏页 ---------- */
:root[data-theme="official"] .macro-workspace,
:root[data-theme="official"] .macro-official-layout {
  background: transparent;
}

:root[data-theme="official"] .macro-settings-panel,
:root[data-theme="official"] .macro-editor-panel,
:root[data-theme="official"] .macro-slot-panel {
  background: var(--fx-surface);
  border-color: var(--fx-line);
}

:root[data-theme="official"] .macro-settings-panel .field {
  background: transparent;
  border-color: var(--fx-line);
}

:root[data-theme="official"] .macro-settings-panel .field > span {
  color: var(--muted);
}

:root[data-theme="official"] .macro-list-toolbar {
  color: var(--muted);
}

:root[data-theme="official"] .macro-import-link {
  color: #67e8f9;
}

:root[data-theme="official"] .macro-import-link:hover {
  color: #a5f3fc;
}

:root[data-theme="official"] .macro-list-card {
  background: var(--fx-surface);
  border: 1px solid var(--fx-line);
  border-radius: 12px;
  color: var(--text);
  transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

:root[data-theme="official"] .macro-list-card:hover {
  border-color: rgba(34, 211, 238, 0.5);
  box-shadow: 0 0 14px rgba(34, 211, 238, 0.16);
  transform: translateY(-2px);
}

:root[data-theme="official"] .macro-list-card.active {
  border-color: rgba(129, 140, 248, 0.65);
  background: rgba(99, 102, 241, 0.12);
  box-shadow: 0 0 0 1px rgba(129, 140, 248, 0.4), 0 0 18px rgba(99, 102, 241, 0.2);
}

:root[data-theme="official"] .macro-list-card strong {
  color: #f2f5ff;
}

:root[data-theme="official"] .macro-list-card small {
  color: var(--muted);
}

:root[data-theme="official"] .macro-list-card-progress span {
  background: rgba(129, 140, 248, 0.16);
}

:root[data-theme="official"] .macro-list-card-progress b {
  background: var(--fx-grad);
}

:root[data-theme="official"] .macro-list-edit-button {
  background: rgba(129, 140, 248, 0.14);
  color: #c7d2fe;
}

:root[data-theme="official"] .macro-list-edit-button:hover {
  background: rgba(129, 140, 248, 0.3);
  color: #ffffff;
}

:root[data-theme="official"] .macro-list-empty {
  color: var(--muted);
}

:root[data-theme="official"] .macro-slot-card {
  background: var(--fx-surface);
  border-color: var(--fx-line);
  color: var(--text);
}

:root[data-theme="official"] .macro-slot-card small {
  color: var(--muted);
}

:root[data-theme="official"] .macro-slot-card strong {
  color: #f2f5ff;
}

:root[data-theme="official"] .macro-slot-card.active {
  border-color: rgba(129, 140, 248, 0.65);
  background: rgba(99, 102, 241, 0.12);
}

:root[data-theme="official"] .macro-create-dialog {
  background: rgba(14, 18, 34, 0.97);
  border: 1px solid rgba(129, 140, 248, 0.32);
  color: var(--text);
  box-shadow: 0 30px 80px rgba(2, 6, 23, 0.7), 0 0 32px rgba(99, 102, 241, 0.18);
  backdrop-filter: blur(18px);
}

:root[data-theme="official"] .macro-dialog-backdrop {
  background: rgba(4, 6, 14, 0.7);
  backdrop-filter: blur(6px);
}

:root[data-theme="official"] .macro-create-name-field > span {
  color: var(--muted);
}

:root[data-theme="official"] .macro-create-name-field input {
  background: var(--fx-surface);
  border-color: var(--fx-line);
  color: var(--text);
}

:root[data-theme="official"] .macro-create-error {
  color: #fda4af;
}

:root[data-theme="official"] .macro-import-file-name {
  color: var(--muted);
}

:root[data-theme="official"] .macro-record-card {
  background: var(--fx-surface);
  border-color: var(--fx-line);
}

:root[data-theme="official"] .macro-record-card span {
  color: var(--muted);
}

:root[data-theme="official"] .macro-record-card strong {
  color: #f2f5ff;
}

:root[data-theme="official"] .macro-record-pad {
  background: rgba(7, 10, 19, 0.6);
  border: 1px dashed rgba(129, 140, 248, 0.35);
}

:root[data-theme="official"] .macro-record-pad p {
  color: var(--muted);
}

:root[data-theme="official"] .macro-action-toolbar {
  color: var(--muted);
}

:root[data-theme="official"] .macro-action-stage {
  background: var(--fx-surface);
  border-color: var(--fx-line);
}

:root[data-theme="official"] .macro-action-stage-header {
  background: rgba(129, 140, 248, 0.08);
  color: var(--muted);
  border-color: var(--fx-line);
}

:root[data-theme="official"] .macro-batch-delay-button {
  background: rgba(129, 140, 248, 0.14);
  border-color: rgba(129, 140, 248, 0.3);
  color: #c7d2fe;
}

:root[data-theme="official"] .macro-batch-delay-button:hover {
  background: rgba(129, 140, 248, 0.26);
}

:root[data-theme="official"] .macro-official-action-table {
  background: transparent;
  border-color: var(--fx-line);
}

:root[data-theme="official"] .macro-action-row {
  background: rgba(129, 140, 248, 0.05);
  border-color: var(--fx-line);
  color: var(--text);
  transition: background-color 0.15s ease, border-color 0.15s ease;
}

:root[data-theme="official"] .macro-action-row:hover {
  background: rgba(129, 140, 248, 0.1);
}

:root[data-theme="official"] .macro-action-row.selected {
  background: rgba(99, 102, 241, 0.16);
  border-color: rgba(129, 140, 248, 0.5);
}

:root[data-theme="official"] .macro-action-number {
  background: rgba(129, 140, 248, 0.16);
  color: #c7d2fe;
}

:root[data-theme="official"] .macro-action-row label {
  color: var(--muted);
}

:root[data-theme="official"] .macro-action-row small {
  color: var(--muted);
}

:root[data-theme="official"] .macro-action-key-cell select,
:root[data-theme="official"] .macro-action-type-cell select,
:root[data-theme="official"] .macro-action-device-cell select {
  background: var(--fx-surface);
  border-color: var(--fx-line);
  color: var(--text);
}

:root[data-theme="official"] .macro-action-type-down select {
  background: rgba(52, 211, 153, 0.12);
  border-color: rgba(52, 211, 153, 0.4);
  color: #6ee7b7;
}

:root[data-theme="official"] .macro-action-type-up select {
  background: rgba(34, 211, 238, 0.12);
  border-color: rgba(34, 211, 238, 0.4);
  color: #67e8f9;
}

:root[data-theme="official"] .macro-action-type-click select {
  background: rgba(232, 121, 249, 0.12);
  border-color: rgba(232, 121, 249, 0.4);
  color: #f0abfc;
}

:root[data-theme="official"] .macro-action-delay-cell {
  color: var(--muted);
}

:root[data-theme="official"] .macro-action-delay-cell button {
  background: rgba(129, 140, 248, 0.14);
  color: #c7d2fe;
  border-color: transparent;
}

:root[data-theme="official"] .macro-action-delay-cell button:hover {
  background: rgba(129, 140, 248, 0.28);
}

:root[data-theme="official"] .macro-action-delay-cell input {
  background: var(--fx-surface);
  border-color: var(--fx-line);
  color: var(--text);
}

:root[data-theme="official"] .macro-empty-state {
  color: var(--muted);
  border-color: rgba(129, 140, 248, 0.3);
}

:root[data-theme="official"] .macro-empty-state strong {
  color: #e9edfb;
}

:root[data-theme="official"] .macro-help-card {
  background: rgba(99, 102, 241, 0.08);
  border-color: rgba(129, 140, 248, 0.24);
}

:root[data-theme="official"] .macro-help-card p {
  color: var(--muted);
}

:root[data-theme="official"] .macro-toolbar-footer {
  background: rgba(7, 10, 19, 0.55);
  border-color: var(--fx-line);
}

:root[data-theme="official"] .macro-toolbar-footer .button {
  border-radius: 11px;
}

:root[data-theme="official"] .macro-toolbar-footer .macro-record-start-button {
  background: linear-gradient(120deg, #34d399, #10b981);
  border-color: transparent;
  color: #04150d;
}

:root[data-theme="official"] .macro-toolbar-footer #macro-clear-button {
  background: rgba(251, 113, 133, 0.14);
  border-color: rgba(251, 113, 133, 0.34);
  color: #fda4af;
}

:root[data-theme="official"] .macro-loop-stepper {
  background: var(--fx-surface);
  border-color: var(--fx-line);
}

:root[data-theme="official"] .macro-loop-stepper button {
  background: rgba(129, 140, 248, 0.14);
  color: #c7d2fe;
  border-color: transparent;
}

:root[data-theme="official"] .macro-loop-stepper button:hover:not(:disabled) {
  background: rgba(129, 140, 248, 0.28);
}

:root[data-theme="official"] .macro-loop-stepper input {
  background: transparent;
  border-color: transparent;
  color: var(--text);
}

:root[data-theme="official"] .macro-loop-type-field select {
  background: var(--fx-surface);
  border-color: var(--fx-line);
  color: var(--text);
}

/* ---------- 灯效页 ---------- */
:root[data-theme="official"] .lighting-official-panel > .rt-overview {
  background: transparent;
}

:root[data-theme="official"] .lighting-effect-button {
  background: var(--fx-surface);
  border: 1px solid var(--fx-line);
  border-radius: 13px;
  color: #d6ddf5;
  transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease, background-color 0.18s ease;
}

:root[data-theme="official"] .lighting-effect-button:hover:not(:disabled) {
  background: rgba(129, 140, 248, 0.1);
  border-color: rgba(34, 211, 238, 0.55);
  box-shadow: 0 0 16px rgba(34, 211, 238, 0.2);
  transform: translateY(-2px);
}

:root[data-theme="official"] .lighting-effect-button.active {
  background: linear-gradient(135deg, rgba(34, 211, 238, 0.18), rgba(129, 140, 248, 0.2) 50%, rgba(232, 121, 249, 0.16));
  border-color: rgba(129, 140, 248, 0.7);
  color: #f2f5ff;
  box-shadow: 0 0 0 1px rgba(129, 140, 248, 0.45), 0 0 22px rgba(99, 102, 241, 0.25);
}

:root[data-theme="official"] .lighting-color-panel {
  background: var(--fx-surface);
  border-color: var(--fx-line);
}

:root[data-theme="official"] .lighting-color-picker-card {
  background: rgba(7, 10, 19, 0.55);
  border-color: var(--fx-line);
}

:root[data-theme="official"] .lighting-color-wheel {
  box-shadow: 0 0 24px rgba(129, 140, 248, 0.3);
}

:root[data-theme="official"] .lighting-rgb-readout {
  color: #67e8f9;
  background: rgba(34, 211, 238, 0.1);
  border-radius: 8px;
}

:root[data-theme="official"] .lighting-color-space-button,
:root[data-theme="official"] .lighting-color-mode-button {
  background: rgba(129, 140, 248, 0.1);
  border-color: var(--fx-line);
  color: #aab4d4;
  transition: background-color 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
}

:root[data-theme="official"] .lighting-color-space-button:hover,
:root[data-theme="official"] .lighting-color-mode-button:hover {
  color: #f2f5ff;
  background: rgba(129, 140, 248, 0.2);
}

:root[data-theme="official"] .lighting-color-space-button.active,
:root[data-theme="official"] .lighting-color-mode-button.active {
  background: var(--fx-grad);
  background-size: 220% auto;
  border-color: transparent;
  color: #0b0e1a;
  box-shadow: 0 4px 14px rgba(99, 102, 241, 0.35);
}

:root[data-theme="official"] .lighting-color-channel {
  color: var(--muted);
}

:root[data-theme="official"] .lighting-color-channel span {
  color: var(--muted);
}

:root[data-theme="official"] .lighting-color-channel input {
  background: var(--fx-surface);
  border-color: var(--fx-line);
  color: var(--text);
}

:root[data-theme="official"] .lighting-swatch {
  border-radius: 10px;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.14), 0 0 10px var(--swatch, transparent);
  transition: transform 0.14s ease, box-shadow 0.14s ease;
}

:root[data-theme="official"] .lighting-swatch:hover {
  transform: translateY(-2px) scale(1.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.2),
    0 0 18px var(--swatch, rgba(129, 140, 248, 0.5));
}

:root[data-theme="official"] .lighting-slider-row {
  color: var(--muted);
}

:root[data-theme="official"] .lighting-slider-row input {
  accent-color: #818cf8;
}

:root[data-theme="official"] .lighting-custom-key-card {
  background: rgba(7, 10, 19, 0.55);
  border: 1px solid var(--fx-line);
  border-radius: 12px;
}

:root[data-theme="official"] .lighting-custom-key-card span {
  color: var(--muted);
}

:root[data-theme="official"] .lighting-custom-key-card strong {
  color: #f2f5ff;
}

/* ---------- 律动页 ---------- */
:root[data-theme="official"] .rhythm-mode-button {
  background: var(--fx-surface);
  border: 1px solid var(--fx-line);
  border-radius: 13px;
  color: #d6ddf5;
  transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease, background-color 0.18s ease;
}

:root[data-theme="official"] .rhythm-mode-button:hover {
  background: rgba(129, 140, 248, 0.1);
  border-color: rgba(34, 211, 238, 0.55);
  transform: translateY(-2px);
}

:root[data-theme="official"] .rhythm-mode-button.active {
  background: var(--fx-grad);
  background-size: 220% auto;
  border-color: transparent;
  color: #0b0e1a;
  box-shadow: 0 6px 18px rgba(99, 102, 241, 0.38);
}

:root[data-theme="official"] .rhythm-param-panel,
:root[data-theme="official"] .rhythm-mode-panel {
  background: var(--fx-surface);
  border-color: var(--fx-line);
}

:root[data-theme="official"] .rhythm-mode-note,
:root[data-theme="official"] #rhythm-mode-note {
  color: var(--muted);
}

/* ---------- 减少动态效果时关闭动画 ---------- */
@media (prefers-reduced-motion: reduce) {
  :root[data-theme="official"] body::after,
  :root[data-theme="official"] .brand-badge,
  :root[data-theme="official"] .brand h1,
  :root[data-theme="official"] .nav-chip-active,
  :root[data-theme="official"] .keyboard-matrix::after,
  :root[data-theme="official"] .keyboard-matrix .key-button.active,
  :root[data-theme="official"] .advanced-key-live-output strong {
    animation: none !important;
  }

  :root[data-theme="official"] .button::after {
    display: none;
  }
}

/* ---------- 霓虹修正：改键页舞台与层卡 ---------- */
:root[data-theme="official"] .keymap-official-stage {
  background: transparent;
  border: 0;
  box-shadow: none;
}

:root[data-theme="official"] .keymap-keyboard-shell::before,
:root[data-theme="official"] .keymap-keyboard-shell::after {
  background: linear-gradient(180deg, #232a44, #141a2d);
  box-shadow: 0 3px 6px rgba(2, 6, 23, 0.5);
}

:root[data-theme="official"] .keymap-layer-radio {
  color: #d6ddf5;
}

:root[data-theme="official"] .keymap-layer-radio input {
  accent-color: #818cf8;
}

:root[data-theme="official"] .keymap-reset-layer-button {
  background: linear-gradient(120deg, #fb7185, #f43f5e);
  color: #1a0509;
  border-radius: 10px;
  box-shadow: 0 4px 14px rgba(244, 63, 94, 0.35);
  transition: transform 0.14s ease, box-shadow 0.18s ease;
}

:root[data-theme="official"] .keymap-reset-layer-button:hover:not(:disabled) {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(244, 63, 94, 0.45);
}

/* ---------- 霓虹修正：各页键盘舞台容器统一暗色 ---------- */
:root[data-theme="official"] .magnetic-official-page {
  background: transparent;
}

:root[data-theme="official"] .magnetic-official-stage,
:root[data-theme="official"] .lighting-official-stage,
:root[data-theme="official"] .rhythm-official-stage {
  background: rgba(7, 10, 19, 0.42);
  border: 1px solid rgba(124, 142, 230, 0.14);
  border-radius: 16px;
}

/* ---------- 霓虹修正：残余浅色容器与高优先级按钮 ---------- */
:root[data-theme="official"] .magnetic-performance-columns,
:root[data-theme="official"] .lighting-effect-panel,
:root[data-theme="official"] .lighting-color-controls,
:root[data-theme="official"] .lighting-swatch-row,
:root[data-theme="official"] .advanced-official-grid,
:root[data-theme="official"] #advanced-overview-shell {
  background: transparent;
  border-color: rgba(124, 142, 230, 0.14);
}

:root[data-theme="official"] .magnetic-mode-tabs,
:root[data-theme="official"] .keymap-output-tabs {
  background: rgba(7, 10, 19, 0.5);
  border: 1px solid rgba(124, 142, 230, 0.16);
  border-radius: 999px;
}

:root[data-theme="official"] .advanced-function-rail,
:root[data-theme="official"] .advanced-binding-workspace {
  background: rgba(7, 10, 19, 0.4);
  border: 1px solid rgba(124, 142, 230, 0.14);
  border-radius: 16px;
}

:root[data-theme="official"] .advanced-official-panel .advanced-type-card strong,
:root[data-theme="official"] .advanced-type-card strong {
  background: rgba(129, 140, 248, 0.16);
  color: #c7d2fe;
}

:root[data-theme="official"] .advanced-official-panel .advanced-type-card.active strong {
  background: rgba(34, 211, 238, 0.2);
  color: #a5f3fc;
}

/* 用更高优先级压住散落各处的官方按钮配色 */
:root[data-theme="official"] .button.button-primary {
  background: var(--fx-grad);
  background-size: 200% auto;
  border-color: transparent;
  color: #0b0e1a;
}

:root[data-theme="official"] .button.button-secondary {
  background: rgba(99, 102, 241, 0.14);
  border-color: rgba(129, 140, 248, 0.34);
  color: #c7d2fe;
}

:root[data-theme="official"] .button.button-secondary:hover {
  background: rgba(99, 102, 241, 0.24);
  color: #e0e7ff;
}

:root[data-theme="official"] .button.button-ghost {
  background: rgba(148, 163, 184, 0.08);
  border-color: rgba(148, 163, 184, 0.2);
  color: #aab4d4;
}

:root[data-theme="official"] .button.button-danger {
  background: linear-gradient(120deg, #fb7185, #f43f5e 60%, #e11d48);
  background-size: 200% auto;
  border-color: transparent;
  color: #1a0509;
}

:root[data-theme="official"] .macro-toolbar-footer .button.button-secondary {
  background: rgba(99, 102, 241, 0.14);
  border-color: rgba(129, 140, 248, 0.34);
  color: #c7d2fe;
}

/* ==================================================================
   操作方式与布局重设计 2026-06-12（第四轮）
   1) 连接状态升级为顶部常驻状态条；
   2) 全站滑块隐藏，由按钮操作（既有步进钮 + ui-redesign.js 注入的
      分段按钮 / 步进器 / 快捷预设）替代；
   3) 性能页三组竖向滑条卡片改为紧凑横向按钮卡。
   滑块仍保留在 DOM 中（仅视觉隐藏），main.js 逻辑不变。
   ================================================================== */

/* ---------- 顶部常驻连接状态条 ---------- */
:root[data-theme="official"] .status-card {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 20;
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 10px 20px;
  border-radius: 0 0 18px 18px;
  border-top: 0;
  background:
    linear-gradient(90deg, rgba(34, 211, 238, 0.06), rgba(129, 140, 248, 0.08) 50%, rgba(232, 121, 249, 0.06)),
    rgba(11, 15, 29, 0.92);
  backdrop-filter: blur(20px);
  box-shadow: 0 10px 34px rgba(2, 6, 23, 0.55);
}

:root[data-theme="official"] .status-card .panel-title-row {
  margin: 0;
  padding: 0;
  border: 0;
  gap: 10px;
}

:root[data-theme="official"] .status-card #status-title {
  font-size: 14px;
}

:root[data-theme="official"] .status-card .status-list {
  display: flex;
  gap: 14px;
  margin: 0;
  min-width: 0;
}

:root[data-theme="official"] .status-card .status-list > div {
  display: none;
}

:root[data-theme="official"] .status-card .status-list > div:first-child {
  display: flex;
  grid-template-columns: none;
  gap: 8px;
  align-items: center;
  white-space: nowrap;
}

:root[data-theme="official"] .status-card .status-list dd {
  max-width: 320px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  word-break: normal;
}

:root[data-theme="official"] .status-card .button-row {
  flex: 0 0 auto;
  margin: 0 0 0 auto;
}

:root[data-theme="official"] .status-card .button {
  min-height: 34px;
  padding: 0 14px;
  font-size: 13px;
}

:root[data-theme="official"] .shell {
  padding-top: 84px;
}

:root[data-theme="official"] .sidebar {
  top: 84px;
  max-height: calc(100vh - 100px);
}

@media (max-width: 900px) {
  :root[data-theme="official"] .status-card {
    position: static;
    flex-wrap: wrap;
    border-radius: 18px;
    border-top: 1px solid var(--panel-border);
  }

  :root[data-theme="official"] .shell {
    padding-top: 18px;
  }

  :root[data-theme="official"] .sidebar {
    top: 18px;
  }
}

/* ---------- 滑块按钮化：注入按钮组成功后才隐藏对应滑条 ---------- */
:root[data-theme="official"] input[type="range"][data-fxctl-ready="1"] {
  display: none !important;
}

:root[data-theme="official"] .travel-depth-ruler {
  display: none;
}

/* ---------- 注入按钮组（ui-redesign.js） ---------- */
.fxctl {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
  justify-content: center;
  max-width: 100%;
}

.fxctl-btn {
  min-width: 34px;
  min-height: 30px;
  padding: 4px 10px;
  border: 1px solid rgba(129, 140, 248, 0.32);
  border-radius: 10px;
  background: rgba(99, 102, 241, 0.12);
  color: #c7d2fe;
  font: inherit;
  font-size: 12.5px;
  font-weight: 700;
  cursor: pointer;
  transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease,
    transform 0.12s ease, box-shadow 0.15s ease;
}

.fxctl-btn:hover {
  background: rgba(99, 102, 241, 0.24);
  border-color: rgba(165, 180, 252, 0.6);
  color: #e0e7ff;
  transform: translateY(-1px);
  box-shadow: 0 0 12px rgba(99, 102, 241, 0.28);
}

.fxctl-btn:active {
  transform: translateY(0) scale(0.95);
}

.fxctl-btn.active {
  background: linear-gradient(120deg, #22d3ee, #818cf8 45%, #e879f9 90%);
  background-size: 200% auto;
  border-color: transparent;
  color: #0b0e1a;
  box-shadow: 0 0 14px rgba(129, 140, 248, 0.45);
}

.fxctl-minus,
.fxctl-plus {
  min-width: 38px;
  font-size: 17px;
  line-height: 1;
}

.fxctl-value {
  min-width: 64px;
  padding: 5px 10px;
  border-radius: 9px;
  background: linear-gradient(120deg, #22d3ee, #818cf8 45%, #e879f9 90%);
  background-size: 200% auto;
  color: #0b0e1a;
  font-weight: 800;
  text-align: center;
  box-shadow: 0 4px 14px rgba(99, 102, 241, 0.35);
}

.fxctl-disabled {
  opacity: 0.38;
  pointer-events: none;
}

/* 浅色 / 深色基础主题下的回退样式 */
:root:not([data-theme="official"]) .fxctl-btn {
  background: rgba(56, 189, 248, 0.14);
  border-color: rgba(56, 189, 248, 0.3);
  color: var(--text);
}

:root:not([data-theme="official"]) .fxctl-btn.active {
  background: var(--accent);
  color: #041018;
}

/* ---------- 性能页：竖向滑条卡 → 紧凑按钮卡 ---------- */
:root[data-theme="official"] .rt-tuning-body {
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 14px;
}

:root[data-theme="official"] .rt-slider-card {
  min-height: 0;
  gap: 8px;
}

:root[data-theme="official"] .rt-slider-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  justify-content: center;
}

:root[data-theme="official"] .rt-slider-row .rt-step[data-rt-step="-1"] {
  order: 1;
}

:root[data-theme="official"] .rt-slider-row .rt-value {
  order: 2;
}

:root[data-theme="official"] .rt-slider-row .rt-step[data-rt-step="1"] {
  order: 3;
}

:root[data-theme="official"] .rt-slider-row .fxctl {
  order: 4;
  flex-basis: 100%;
}

:root[data-theme="official"] .deadzone-tuning-body {
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 14px;
}

:root[data-theme="official"] .deadzone-slider-card {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  justify-content: center;
  grid-template-rows: none;
  min-height: 0;
}

:root[data-theme="official"] .deadzone-slider-card > span {
  order: 0;
  flex-basis: 100%;
  text-align: center;
}

:root[data-theme="official"] .deadzone-slider-card .deadzone-step[data-deadzone-step="-1"] {
  order: 1;
}

:root[data-theme="official"] .deadzone-slider-card > strong {
  order: 2;
}

:root[data-theme="official"] .deadzone-slider-card .deadzone-step[data-deadzone-step="1"] {
  order: 3;
}

:root[data-theme="official"] .deadzone-slider-card .fxctl {
  order: 4;
  flex-basis: 100%;
}

:root[data-theme="official"] .travel-depth-slider-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  justify-content: center;
}

:root[data-theme="official"] .rt-step,
:root[data-theme="official"] .deadzone-step,
:root[data-theme="official"] .travel-depth-step {
  width: 38px;
  height: 38px;
  font-size: 20px;
  border: 1px solid rgba(129, 140, 248, 0.32);
  transition: background-color 0.15s ease, transform 0.12s ease, box-shadow 0.15s ease;
}

:root[data-theme="official"] .rt-step:hover,
:root[data-theme="official"] .deadzone-step:hover,
:root[data-theme="official"] .travel-depth-step:hover {
  transform: scale(1.08);
  box-shadow: 0 0 12px rgba(99, 102, 241, 0.3);
}

:root[data-theme="official"] .lighting-slider-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

:root[data-theme="official"] .lighting-slider-row .fxctl {
  flex: 1 1 auto;
  justify-content: flex-start;
}

/* DKS 矩阵列头空间有限：按钮组紧凑排布 */
:root[data-theme="official"] .advanced-official-dks-stage-head .fxctl {
  gap: 4px;
}

:root[data-theme="official"] .advanced-official-dks-stage-head .fxctl-btn {
  min-width: 28px;
  min-height: 24px;
  padding: 2px 7px;
  font-size: 13px;
}

/* ==================================================================
   设置操作年轻化 2026-06-12（第五轮）
   1) 指定下拉框 → 分段按钮（原 select 注入成功后隐藏）；
   2) 复选框 → 拨动开关（纯 CSS，原生 input 不变）；
   3) 数字输入保留 + 快捷预设芯片；
   4) 设置卡片布局紧凑化。
   ================================================================== */

/* ---------- 下拉框分段化 ---------- */
select[data-fxsel-ready="1"] {
  display: none !important;
}

.fxctl-select .fxctl-btn {
  min-height: 34px;
  padding: 5px 14px;
}

.fxctl-number {
  margin-top: 8px;
  justify-content: flex-start;
}

/* ---------- 复选框 → 拨动开关 ---------- */
:root[data-theme="official"] input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  flex: 0 0 auto;
  width: 44px;
  height: 24px;
  margin: 0;
  border: 1px solid rgba(129, 140, 248, 0.35);
  border-radius: 999px;
  background-color: rgba(99, 102, 241, 0.14);
  background-image: radial-gradient(circle closest-side, #aab4d4 96%, transparent);
  background-repeat: no-repeat;
  background-position: 4px 50%;
  background-size: 16px 16px;
  cursor: pointer;
  transition:
    background-position 0.18s ease,
    background-color 0.18s ease,
    border-color 0.18s ease,
    box-shadow 0.18s ease;
}

:root[data-theme="official"] input[type="checkbox"]:hover:not(:disabled) {
  border-color: rgba(165, 180, 252, 0.6);
}

:root[data-theme="official"] input[type="checkbox"]:checked {
  background-color: #4f46e5;
  background-image: radial-gradient(circle closest-side, #ffffff 96%, transparent);
  background-position: calc(100% - 4px) 50%;
  border-color: transparent;
  box-shadow: 0 0 12px rgba(99, 102, 241, 0.45);
}

:root[data-theme="official"] input[type="checkbox"]:disabled {
  opacity: 0.38;
  cursor: default;
}

:root[data-theme="official"] input[type="checkbox"]:focus-visible {
  outline: 2px solid rgba(34, 211, 238, 0.6);
  outline-offset: 2px;
}

/* 性能页自带的官方开关保持原有覆盖实现 */
:root[data-theme="official"] .magnetic-official-switch input {
  width: 100%;
  height: 100%;
  border: 0;
  background: none;
  box-shadow: none;
}

/* ---------- 设置卡片紧凑化 ---------- */
:root[data-theme="official"] .settings-grid {
  gap: 14px;
}

:root[data-theme="official"] .setting-card {
  gap: 12px;
  padding: 16px;
}

:root[data-theme="official"] .setting-card .setting-copy strong {
  font-size: 15px;
}

:root[data-theme="official"] .setting-card > .button,
:root[data-theme="official"] .setting-card .button-row .button {
  width: auto;
  justify-self: end;
  align-self: end;
  height: 36px;
  min-height: 36px;
  padding: 0 20px;
  font-size: 13px;
}

:root[data-theme="official"] .setting-card .button-row {
  justify-content: flex-end;
  margin-top: 4px;
}

:root[data-theme="official"] .toggle-row {
  padding: 10px 14px;
  border: 1px solid rgba(124, 142, 230, 0.16);
  border-radius: 12px;
  background: rgba(7, 10, 19, 0.45);
}

:root[data-theme="official"] .toggle-row span {
  color: #d6ddf5;
  font-weight: 600;
}

:root[data-theme="official"] select:disabled,
:root[data-theme="official"] input:disabled {
  color: #8c97b8;
}

:root[data-theme="official"] .field {
  gap: 8px;
}

/* ==================================================================
   快捷设置列表化排版 2026-06-12（第六轮）
   大卡片 → 紧凑设置行：左列标题+说明，右列控件与操作按钮。
   仅布局属性，DOM 与逻辑不变。
   ================================================================== */
:root[data-theme="official"] .settings-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(560px, 1fr));
  gap: 10px;
}

:root[data-theme="official"] .setting-card {
  display: grid;
  grid-template-columns: minmax(200px, 280px) minmax(0, 1fr);
  column-gap: 24px;
  row-gap: 10px;
  align-items: center;
  padding: 14px 18px;
  border-radius: 14px;
  min-height: 0;
}

:root[data-theme="official"] .setting-card > * {
  grid-column: 2;
  margin: 0;
}

:root[data-theme="official"] .setting-card > .setting-copy {
  grid-column: 1;
  grid-row: 1;
  align-self: center;
}

:root[data-theme="official"] .setting-card .setting-copy strong {
  display: block;
  font-size: 14px;
}

:root[data-theme="official"] .setting-card .setting-copy p {
  margin: 4px 0 0;
  font-size: 12px;
  line-height: 1.5;
}

:root[data-theme="official"] .setting-card .field {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 10px;
}

:root[data-theme="official"] .setting-card .field > span {
  flex: 0 0 auto;
  font-size: 12px;
}

:root[data-theme="official"] .setting-card .field input[type="number"],
:root[data-theme="official"] .setting-card .field input[type="text"] {
  flex: 0 1 150px;
  min-width: 110px;
  min-height: 34px;
}

:root[data-theme="official"] .setting-card .field .fxctl {
  justify-content: flex-start;
}

:root[data-theme="official"] .setting-card .setting-stack {
  display: grid;
  gap: 10px;
}

:root[data-theme="official"] .setting-card .toggle-row {
  justify-content: space-between;
  width: 100%;
  padding: 8px 12px;
}

:root[data-theme="official"] .setting-card > .button,
:root[data-theme="official"] .setting-card .button-row {
  justify-self: end;
}

:root[data-theme="official"] .setting-card .button-row {
  margin-top: 0;
}

:root[data-theme="official"] .setting-card .small {
  font-size: 11.5px;
  text-align: right;
}

@media (max-width: 760px) {
  :root[data-theme="official"] .settings-grid {
    grid-template-columns: 1fr;
  }

  :root[data-theme="official"] .setting-card {
    grid-template-columns: 1fr;
  }

  :root[data-theme="official"] .setting-card > .setting-copy {
    grid-row: auto;
  }
}

/* ---------- 第六轮微调：单控件设置压成一行 ---------- */
:root[data-theme="official"] .setting-card {
  grid-template-columns: minmax(170px, 240px) minmax(0, 1fr) auto;
}

:root[data-theme="official"] .setting-card > .button,
:root[data-theme="official"] .setting-card > .button-row {
  grid-column: 3;
  grid-row: 1;
  align-self: center;
  justify-self: end;
}

:root[data-theme="official"] .setting-card > .button-row {
  display: grid;
  gap: 8px;
}

:root[data-theme="official"] .setting-card .fxctl-btn {
  min-height: 30px;
  padding: 4px 11px;
  font-size: 12px;
}

:root[data-theme="official"] .setting-card .toggle-row {
  background: transparent;
  border: 0;
  padding: 0;
}

@media (max-width: 760px) {
  :root[data-theme="official"] .setting-card {
    grid-template-columns: 1fr;
  }

  :root[data-theme="official"] .setting-card > .button,
  :root[data-theme="official"] .setting-card > .button-row {
    grid-column: 1;
    grid-row: auto;
  }
}

/* ==================================================================
   快捷设置无边框列表 2026-06-12（第七轮）
   1) 自动应用后隐藏「应用/重写」按钮（恢复出厂除外）；
   2) 取消每行边框，单列设置列表 + 细分隔线 + 悬浮高亮；
   3) 控件右对齐。
   ================================================================== */
:root[data-theme="official"] #apply-os-mode-button,
:root[data-theme="official"] #apply-polling-rate-button,
:root[data-theme="official"] #apply-sleep-time-button,
:root[data-theme="official"] #apply-debounce-time-button,
:root[data-theme="official"] #apply-debounce-mode-button,
:root[data-theme="official"] #apply-adaptive-calibration-button,
:root[data-theme="official"] #apply-combo-optimization-button,
:root[data-theme="official"] #apply-win-key-lock-button,
:root[data-theme="official"] #apply-low-power-mode-button {
  display: none !important;
}

:root[data-theme="official"] .settings-grid {
  grid-template-columns: 1fr;
  gap: 0;
  max-width: 980px;
}

:root[data-theme="official"] .setting-card {
  grid-template-columns: minmax(180px, 320px) minmax(0, 1fr);
  padding: 16px 14px;
  background: transparent;
  border: 0;
  border-radius: 12px;
  box-shadow: none;
}

:root[data-theme="official"] .setting-card:not(:first-child) {
  border-top: 1px solid rgba(124, 142, 230, 0.1);
  border-radius: 0;
}

:root[data-theme="official"] .setting-card:hover {
  background: rgba(129, 140, 248, 0.06);
  border-color: rgba(124, 142, 230, 0.1);
  box-shadow: none;
  transform: none;
}

:root[data-theme="official"] .setting-card .field,
:root[data-theme="official"] .setting-card .field .fxctl {
  justify-content: flex-end;
}

:root[data-theme="official"] .setting-card .toggle-row {
  display: flex;
  width: auto;
  justify-self: end;
  justify-content: flex-end;
  gap: 12px;
}

:root[data-theme="official"] .setting-card .fxctl-number {
  margin-top: 0;
  justify-content: flex-end;
}

:root[data-theme="official"] .setting-card .small {
  text-align: right;
}

/* 恢复出厂保持显式按钮与确认流程 */
:root[data-theme="official"] .setting-card #device-factory-reset-button {
  display: inline-flex;
  grid-column: 2;
  grid-row: auto;
  justify-self: end;
}

/* ==================================================================
   键盘条带取消 + 键帽色彩循环 2026-06-12（第八轮）
   1) 移除键盘底座的顶部金属条与底部 RGB 灯带（进度条观感）；
   2) 键帽颜色缓缓循环多色（hue-rotate 慢速转色，分三组相位成波浪）；
   3) 灯效/律动预览矩阵除外（颜色必须忠实反映设备真实灯效）；
      选中/改键/多选/回读/校准等状态键除外（保留状态识别色）。
   ================================================================== */
:root[data-theme="official"] .keyboard-matrix::before,
:root[data-theme="official"] .keyboard-matrix::after {
  display: none;
}

:root[data-theme="official"] .keyboard-matrix {
  padding: 20px 22px;
  border-radius: 18px;
}

:root[data-theme="official"] .keymap-keyboard-shell::before,
:root[data-theme="official"] .keymap-keyboard-shell::after {
  display: none;
}

@keyframes fx-key-cycle {
  from {
    filter: hue-rotate(0deg);
  }
  to {
    filter: hue-rotate(360deg);
  }
}

:root[data-theme="official"]
  .keyboard-matrix:not(.lighting-keyboard-matrix):not(.rhythm-keyboard-matrix)
  .key-button:not(.active):not(.remapped):not(.multi-selected):not(.has-magnetic-readback):not(.calibration-key) {
  background: linear-gradient(180deg, #253a68 0%, #1f2d55 55%, #192546 100%);
  border-color: rgba(102, 140, 255, 0.45);
  animation: fx-key-cycle 18s linear infinite;
}

:root[data-theme="official"] .keyboard-matrix .key-button:nth-child(3n + 2) {
  animation-delay: -6s;
}

:root[data-theme="official"] .keyboard-matrix .key-button:nth-child(3n) {
  animation-delay: -12s;
}

@media (prefers-reduced-motion: reduce) {
  :root[data-theme="official"] .keyboard-matrix .key-button {
    animation: none !important;
  }
}

/* ---------- 第八轮修正：键帽 = 暗色多色渐变，整体同相缓慢转色 ---------- */
:root[data-theme="official"]
  .keyboard-matrix:not(.lighting-keyboard-matrix):not(.rhythm-keyboard-matrix)
  .key-button:not(.active):not(.remapped):not(.multi-selected):not(.has-magnetic-readback):not(.calibration-key) {
  background:
    linear-gradient(180deg, rgba(12, 16, 31, 0.58), rgba(10, 14, 27, 0.72)),
    linear-gradient(120deg, #22d3ee, #818cf8 45%, #e879f9 90%);
  border-color: rgba(148, 163, 230, 0.42);
  animation: fx-key-cycle 30s linear infinite;
}

/* 取消相位分组：所有键同相，避免横向扫动观感 */
:root[data-theme="official"] .keyboard-matrix .key-button:nth-child(n) {
  animation-delay: 0s;
}

/* ==================================================================
   第九轮：键帽亮色多彩渐变 + 全站取消位移流动动画 2026-06-12
   所有键帽 = Q 键那样的明亮多色渐变（深色字），动画只做 hue 缓慢转色；
   fx-pan（背景位移产生的"从右向左刷新"观感）全部移除。
   ================================================================== */
:root[data-theme="official"]
  .keyboard-matrix:not(.lighting-keyboard-matrix):not(.rhythm-keyboard-matrix)
  .key-button:not(.active):not(.remapped):not(.multi-selected):not(.has-magnetic-readback):not(.calibration-key) {
  color: #0b0e1a;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.22) 0%, rgba(255, 255, 255, 0) 40%, rgba(8, 10, 20, 0.26) 100%),
    linear-gradient(120deg, #22d3ee, #818cf8 45%, #e879f9 90%);
  border-color: rgba(255, 255, 255, 0.3);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.4),
    inset 0 -3px 0 rgba(2, 6, 23, 0.35),
    0 2px 4px rgba(2, 6, 23, 0.5);
  animation: fx-key-cycle 24s linear infinite;
}

:root[data-theme="official"]
  .keyboard-matrix:not(.lighting-keyboard-matrix):not(.rhythm-keyboard-matrix)
  .key-button:not(.active):not(.remapped):not(.multi-selected):not(.has-magnetic-readback):not(.calibration-key):hover {
  border-color: rgba(255, 255, 255, 0.85);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.45),
    inset 0 -3px 0 rgba(2, 6, 23, 0.3),
    0 0 0 2px rgba(255, 255, 255, 0.4),
    0 0 16px rgba(255, 255, 255, 0.3),
    0 6px 12px rgba(2, 6, 23, 0.5);
}

/* 选中键：同样转色，但用白色描边 + 呼吸光环区分，不再位移 */
:root[data-theme="official"] .keyboard-matrix .key-button.active {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.32) 0%, rgba(255, 255, 255, 0.06) 45%, rgba(8, 10, 20, 0.18) 100%),
    linear-gradient(120deg, #22d3ee, #818cf8 45%, #e879f9 90%);
  border-color: #ffffff;
  animation: fx-key-pulse 2.4s ease-in-out infinite, fx-key-cycle 24s linear infinite;
}

/* 导航选中项 / 品牌标识：取消 fx-pan 位移，改为同款转色 */
:root[data-theme="official"] .nav-chip-active,
:root[data-theme="official"] .nav-chip-active:hover {
  animation: fx-key-cycle 24s linear infinite;
}

:root[data-theme="official"] .brand-badge,
:root[data-theme="official"] .brand h1 {
  animation: fx-key-cycle 24s linear infinite;
}

:root[data-theme="official"] .advanced-key-live-output strong {
  animation: fx-key-cycle 24s linear infinite;
}

@media (prefers-reduced-motion: reduce) {
  :root[data-theme="official"] .nav-chip-active,
  :root[data-theme="official"] .nav-chip-active:hover,
  :root[data-theme="official"] .brand-badge,
  :root[data-theme="official"] .brand h1,
  :root[data-theme="official"] .advanced-key-live-output strong {
    animation: none !important;
  }
}

/* ==================================================================
   第十轮：整块键盘同色平滑过渡 2026-06-12
   1) 放弃每键独立渐变/滤镜转色：键帽底色用多色关键帧直接过渡，
      所有键同相位 → 整块键盘作为整体在多个颜色间缓缓切换；
   2) 已改键（绿色）并入统一外观，键盘上不再有"不一样的按键"；
      （多选/磁轴回读为操作中的瞬时状态、校准键仅在校准弹窗内有意义，
       保留状态色；选中键以白描边+呼吸光环区分，颜色与整体同步。）
   ================================================================== */
@keyframes fx-board-cycle {
  0% {
    background-color: #22d3ee;
  }
  18% {
    background-color: #6366f1;
  }
  36% {
    background-color: #a855f7;
  }
  54% {
    background-color: #ec4899;
  }
  72% {
    background-color: #f59e0b;
  }
  88% {
    background-color: #34d399;
  }
  100% {
    background-color: #22d3ee;
  }
}

:root[data-theme="official"]
  .keyboard-matrix:not(.lighting-keyboard-matrix):not(.rhythm-keyboard-matrix)
  .key-button:not(.active):not(.remapped):not(.multi-selected):not(.has-magnetic-readback):not(.calibration-key),
:root[data-theme="official"]
  .keyboard-matrix:not(.lighting-keyboard-matrix):not(.rhythm-keyboard-matrix)
  .key-button.remapped:not(.active) {
  color: #0b0e1a;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.26) 0%, rgba(255, 255, 255, 0) 42%, rgba(8, 10, 20, 0.3) 100%)
    #22d3ee;
  border-color: rgba(255, 255, 255, 0.3);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.4),
    inset 0 -3px 0 rgba(2, 6, 23, 0.35),
    0 2px 4px rgba(2, 6, 23, 0.5);
  animation: fx-board-cycle 30s linear infinite;
}

:root[data-theme="official"]
  .keyboard-matrix:not(.lighting-keyboard-matrix):not(.rhythm-keyboard-matrix)
  .key-button:not(.active):not(.multi-selected):not(.has-magnetic-readback):not(.calibration-key):hover,
:root[data-theme="official"]
  .keyboard-matrix:not(.lighting-keyboard-matrix):not(.rhythm-keyboard-matrix)
  .key-button.remapped:not(.active):hover {
  border-color: rgba(255, 255, 255, 0.85);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.45),
    inset 0 -3px 0 rgba(2, 6, 23, 0.3),
    0 0 0 2px rgba(255, 255, 255, 0.4),
    0 0 16px rgba(255, 255, 255, 0.3),
    0 6px 12px rgba(2, 6, 23, 0.5);
}

:root[data-theme="official"] .keyboard-matrix .key-button.active {
  color: #0b0e1a;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.34) 0%, rgba(255, 255, 255, 0.08) 45%, rgba(8, 10, 20, 0.2) 100%)
    #22d3ee;
  border-color: #ffffff;
  animation: fx-key-pulse 2.4s ease-in-out infinite, fx-board-cycle 30s linear infinite;
}

/* ==================================================================
   第十一轮：键帽与导航选中项同款渐变转色 2026-06-12
   用户反馈第十轮的六色直线插值过渡生硬；改为与左侧导航选中项
   完全一致的方案：键帽 = 青→靛→粉渐变底，hue-rotate 连续平滑转色。
   全键同相位整体变化；已改键保持与普通键统一（沿用第十轮）。
   ================================================================== */
:root[data-theme="official"]
  .keyboard-matrix:not(.lighting-keyboard-matrix):not(.rhythm-keyboard-matrix)
  .key-button:not(.active):not(.remapped):not(.multi-selected):not(.has-magnetic-readback):not(.calibration-key),
:root[data-theme="official"]
  .keyboard-matrix:not(.lighting-keyboard-matrix):not(.rhythm-keyboard-matrix)
  .key-button.remapped:not(.active) {
  color: #0b0e1a;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.22) 0%, rgba(255, 255, 255, 0) 42%, rgba(8, 10, 20, 0.24) 100%),
    linear-gradient(120deg, #22d3ee, #818cf8 45%, #e879f9 90%);
  border-color: rgba(255, 255, 255, 0.3);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.4),
    inset 0 -3px 0 rgba(2, 6, 23, 0.35),
    0 2px 4px rgba(2, 6, 23, 0.5);
  animation: fx-key-cycle 24s linear infinite;
}

:root[data-theme="official"] .keyboard-matrix .key-button.active {
  color: #0b0e1a;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.34) 0%, rgba(255, 255, 255, 0.08) 45%, rgba(8, 10, 20, 0.16) 100%),
    linear-gradient(120deg, #22d3ee, #818cf8 45%, #e879f9 90%);
  border-color: #ffffff;
  animation: fx-key-pulse 2.4s ease-in-out infinite, fx-key-cycle 24s linear infinite;
}

/* ==================================================================
   Layout C：键盘为核心 + 控制浮层抽屉 2026-06-12（第十二轮）
   1) 左侧文字栏 → 收窄图标导航条（图标在上、小字在下）；
   2) 带键盘的功能页(keymap/performance/lighting/rhythm)重排为
      「键盘居中主角 + 控制区右侧玻璃抽屉」；
   3) 宏/设备/高级键页无干净两列结构，保持纵向流（键盘居中）。
   纯 CSS 重排，DOM 与 main.js 逻辑不变。
   ================================================================== */

/* ---------- 图标导航条 ---------- */
:root[data-theme="official"] .shell {
  grid-template-columns: 96px minmax(0, 1fr);
  gap: 16px;
}

:root[data-theme="official"] .sidebar {
  gap: 12px;
  padding-right: 0;
}

:root[data-theme="official"] .brand {
  flex-direction: column;
  gap: 6px;
  padding: 12px 6px;
  text-align: center;
}

:root[data-theme="official"] .brand > div {
  display: none;
}

:root[data-theme="official"] .brand-badge {
  width: 44px;
  height: 44px;
}

:root[data-theme="official"] .section-nav {
  padding: 8px 6px;
  gap: 4px;
}

:root[data-theme="official"] .section-nav::before {
  content: "菜单";
  text-align: center;
  padding: 2px 0 6px;
  letter-spacing: 0.1em;
}

:root[data-theme="official"] .nav-chip {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  width: 100%;
  min-height: 54px;
  padding: 8px 2px;
  font-size: 11px;
  text-align: center;
  white-space: nowrap;
}

:root[data-theme="official"] .nav-chip::before {
  position: static;
  margin: 0;
  width: 26px;
  height: 26px;
}

:root[data-theme="official"] .nav-chip:hover {
  transform: translateY(-1px);
}

/* 配置档：收窄成紧凑竖排 */
:root[data-theme="official"] #profile-panel {
  padding: 10px 6px;
}

:root[data-theme="official"] #profile-panel #profile-title {
  font-size: 13px;
  text-align: center;
}

:root[data-theme="official"] #profile-panel .button-row {
  gap: 6px;
}

:root[data-theme="official"] #profile-panel .button {
  min-height: 38px;
  padding: 0 4px;
  font-size: 12px;
}

/* ---------- 键盘为核心 + 控制抽屉（4 个带键盘的页） ---------- */
:root[data-theme="official"] .panel:has(> .keymap-official-stage),
:root[data-theme="official"] .panel:has(> .magnetic-official-stage),
:root[data-theme="official"] .lighting-official-panel,
:root[data-theme="official"] .rhythm-official-panel {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 16px 20px;
}

/* 整宽行：标题 / 说明 / 概览 / 底部按钮 / 提示 / 调试块 */
:root[data-theme="official"] .panel:has(> .keymap-official-stage) > .panel-title-row,
:root[data-theme="official"] .panel:has(> .keymap-official-stage) > .section-copy,
:root[data-theme="official"] .panel:has(> .keymap-official-stage) > .keymap-hidden-plumbing,
:root[data-theme="official"] .panel:has(> .magnetic-official-stage) > .magnetic-status-line,
:root[data-theme="official"] .lighting-official-panel > .panel-title-row,
:root[data-theme="official"] .lighting-official-panel > .section-copy,
:root[data-theme="official"] .lighting-official-panel > .rt-overview,
:root[data-theme="official"] .lighting-official-panel > .button-row,
:root[data-theme="official"] .lighting-official-panel > .info-banner,
:root[data-theme="official"] .lighting-official-panel > .debug-details,
:root[data-theme="official"] .rhythm-official-panel > .panel-title-row,
:root[data-theme="official"] .rhythm-official-panel > .section-copy {
  flex: 1 1 100%;
}

/* 键盘舞台：居中主角，占据左侧主要空间 */
:root[data-theme="official"] .panel:has(> .keymap-official-stage) > .keymap-official-stage,
:root[data-theme="official"] .panel:has(> .magnetic-official-stage) > .magnetic-official-stage,
:root[data-theme="official"] .lighting-official-panel > .lighting-official-stage,
:root[data-theme="official"] .rhythm-official-panel > .rhythm-official-stage {
  flex: 3 1 520px;
  min-width: 0;
  align-self: flex-start;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 28px clamp(16px, 3vw, 44px);
  border-radius: 18px;
  background:
    radial-gradient(620px circle at var(--mx, 50%) var(--my, 30%), rgba(129, 140, 248, 0.08), transparent 60%),
    rgba(7, 10, 19, 0.4);
  border: 1px solid rgba(124, 142, 230, 0.14);
}

/* 控制抽屉：右侧玻璃浮层，可独立滚动 */
:root[data-theme="official"] .panel:has(> .keymap-official-stage) > .keymap-output-panel,
:root[data-theme="official"] .panel:has(> .magnetic-official-stage) > .magnetic-performance-columns,
:root[data-theme="official"] .lighting-official-panel > .lighting-editor-layout,
:root[data-theme="official"] .rhythm-official-panel > .rhythm-editor-layout {
  flex: 1 1 320px;
  max-width: 440px;
  align-self: flex-start;
  padding: 16px;
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(24, 30, 52, 0.62), rgba(18, 23, 41, 0.72));
  border: 1px solid rgba(129, 140, 248, 0.2);
  box-shadow: 0 16px 40px rgba(2, 6, 23, 0.45);
  backdrop-filter: blur(16px);
  animation: panel-in 0.24s ease both;
}

/* 性能页控制列在抽屉内改为纵向堆叠 */
:root[data-theme="official"] .panel:has(> .magnetic-official-stage) > .magnetic-performance-columns {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

/* 灯效/律动编辑区在抽屉内纵向堆叠 */
:root[data-theme="official"] .lighting-official-panel > .lighting-editor-layout,
:root[data-theme="official"] .rhythm-official-panel > .rhythm-editor-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

/* 键盘舞台内部：去掉原本超大留白，让键盘自适应抽屉外的宽度 */
:root[data-theme="official"] .keymap-official-stage,
:root[data-theme="official"] .magnetic-official-stage,
:root[data-theme="official"] .lighting-official-stage,
:root[data-theme="official"] .rhythm-official-stage {
  grid-template-columns: 1fr;
  min-height: 0;
  padding: 0;
}

:root[data-theme="official"] .keymap-keyboard-shell,
:root[data-theme="official"] .magnetic-keyboard-shell,
:root[data-theme="official"] .lighting-keyboard-shell,
:root[data-theme="official"] .rhythm-keyboard-shell,
:root[data-theme="official"] .advanced-keyboard-panel {
  --official-board-width: 100%;
  width: 100%;
}

/* 性能页：模式切换、选择动作 居中显示在键盘下方 */
:root[data-theme="official"] .magnetic-select-actions {
  flex-flow: row wrap;
  justify-content: center;
}

/* ---------- 高级键页：键盘居中，控制区纵向（不强行抽屉，结构复杂） ---------- */
:root[data-theme="official"] .advanced-official-panel .advanced-keyboard-panel {
  display: flex;
  flex-direction: column;
  align-items: center;
}

:root[data-theme="official"] .advanced-official-panel .advanced-keyboard-matrix {
  width: 100%;
  max-width: 920px;
}

/* ---------- 窄屏：抽屉退回到键盘下方 ---------- */
@media (max-width: 1100px) {
  :root[data-theme="official"] .panel:has(> .keymap-official-stage) > .keymap-output-panel,
  :root[data-theme="official"] .panel:has(> .magnetic-official-stage) > .magnetic-performance-columns,
  :root[data-theme="official"] .lighting-official-panel > .lighting-editor-layout,
  :root[data-theme="official"] .rhythm-official-panel > .rhythm-editor-layout {
    flex-basis: 100%;
    max-width: none;
  }
}

@media (max-width: 900px) {
  :root[data-theme="official"] .shell {
    grid-template-columns: 1fr;
  }

  :root[data-theme="official"] .sidebar {
    position: static;
    flex-direction: row;
    flex-wrap: wrap;
    max-height: none;
  }

  :root[data-theme="official"] .section-nav {
    flex: 1 1 100%;
    display: flex;
    flex-flow: row wrap;
  }

  :root[data-theme="official"] .nav-chip {
    width: auto;
    flex: 0 0 auto;
  }
}

/* ---------- Layout C 收尾微调 ---------- */
:root[data-theme="official"] .keymap-layer-card {
  min-height: 0;
  padding: 16px 18px;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

:root[data-theme="official"] .magnetic-keyboard-shell,
:root[data-theme="official"] .lighting-keyboard-shell,
:root[data-theme="official"] .rhythm-keyboard-shell,
:root[data-theme="official"] .keymap-keyboard-shell {
  margin: 0 auto;
}

:root[data-theme="official"] .keymap-official-stage,
:root[data-theme="official"] .magnetic-official-stage {
  gap: 16px;
}

/* ==================================================================
   第十三轮：控制抽屉吸顶 + 内部滚动 2026-06-12
   抽屉内容再长，键盘也始终可见：抽屉 sticky 吸在顶部，
   超出视口高度时抽屉内部独立滚动（顶部状态条 ~56px + 余量）。
   ================================================================== */
@media (min-width: 1101px) {
  :root[data-theme="official"] .panel:has(> .keymap-official-stage) > .keymap-output-panel,
  :root[data-theme="official"] .panel:has(> .magnetic-official-stage) > .magnetic-performance-columns,
  :root[data-theme="official"] .lighting-official-panel > .lighting-editor-layout,
  :root[data-theme="official"] .rhythm-official-panel > .rhythm-editor-layout {
    position: sticky;
    top: 96px;
    max-height: calc(100vh - 120px);
    overflow-y: auto;
    overscroll-behavior: contain;
  }

  /* 键盘舞台同样吸顶，长抽屉滚动时键盘不被推走 */
  :root[data-theme="official"] .panel:has(> .keymap-official-stage) > .keymap-official-stage,
  :root[data-theme="official"] .panel:has(> .magnetic-official-stage) > .magnetic-official-stage,
  :root[data-theme="official"] .lighting-official-panel > .lighting-official-stage,
  :root[data-theme="official"] .rhythm-official-panel > .rhythm-official-stage {
    position: sticky;
    top: 96px;
  }

  /* 抽屉细滚动条配色 */
  :root[data-theme="official"] .keymap-output-panel::-webkit-scrollbar,
  :root[data-theme="official"] .magnetic-performance-columns::-webkit-scrollbar,
  :root[data-theme="official"] .lighting-editor-layout::-webkit-scrollbar,
  :root[data-theme="official"] .rhythm-editor-layout::-webkit-scrollbar {
    width: 8px;
  }

  :root[data-theme="official"] .keymap-output-panel::-webkit-scrollbar-thumb,
  :root[data-theme="official"] .magnetic-performance-columns::-webkit-scrollbar-thumb,
  :root[data-theme="official"] .lighting-editor-layout::-webkit-scrollbar-thumb,
  :root[data-theme="official"] .rhythm-editor-layout::-webkit-scrollbar-thumb {
    border-radius: 8px;
    background-color: rgba(129, 140, 248, 0.4);
  }
}

/* ==================================================================
   第十四轮：性能页专属布局重排 2026-06-12
   性能页内容多(行程/RT/死区三大组)，不适合"键盘+窄抽屉"。
   改为：键盘居中置顶 → 选择按钮横向工具条 → 三组控件下方一排平铺。
   覆盖第十二/十三轮对性能页的抽屉与吸顶规则。
   ================================================================== */

/* 性能页 panel 退出"键盘+抽屉"两列，恢复纵向整宽流 */
:root[data-theme="official"] .panel:has(> .magnetic-official-stage) {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

:root[data-theme="official"] .panel:has(> .magnetic-official-stage) > .magnetic-official-stage,
:root[data-theme="official"] .panel:has(> .magnetic-official-stage) > .magnetic-performance-columns {
  flex: 0 0 auto;
  width: 100%;
  max-width: none;
  position: static;
  max-height: none;
  overflow: visible;
}

/* 键盘舞台：键盘居中 + 模式/选择按钮横向工具条 */
:root[data-theme="official"] .magnetic-official-stage {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  padding: 24px clamp(16px, 3vw, 40px);
}

:root[data-theme="official"] .magnetic-keyboard-shell {
  width: 100%;
  max-width: 980px;
}

:root[data-theme="official"] .magnetic-select-actions {
  display: flex;
  flex-flow: row wrap;
  gap: 8px;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 980px;
}

:root[data-theme="official"] .magnetic-select-actions .button {
  flex: 0 0 auto;
  width: auto;
  min-height: 36px;
  padding: 0 16px;
}

/* 三组控件：下方一排平铺(行程 | RT | 死区) */
:root[data-theme="official"] .panel:has(> .magnetic-official-stage) > .magnetic-performance-columns {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 16px;
  align-items: start;
}

:root[data-theme="official"] .magnetic-performance-column {
  height: 100%;
  padding: 18px;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(24, 30, 52, 0.6), rgba(18, 23, 41, 0.7));
  border: 1px solid rgba(129, 140, 248, 0.2);
  box-shadow: 0 14px 34px rgba(2, 6, 23, 0.4);
}

/* 列内统一：标题行 + 控件居中 */
:root[data-theme="official"] .magnetic-column-head {
  margin-bottom: 14px;
}

/* 行程深度控件: 修正溢出, 适配列宽 */
:root[data-theme="official"] .travel-depth-control {
  width: 100%;
  max-width: 100%;
}

:root[data-theme="official"] .switch-cross-section {
  margin: 0 auto;
}

/* RT/死区: 两个子卡并排居中, 按钮组横排 */
:root[data-theme="official"] .rt-tuning-body,
:root[data-theme="official"] .deadzone-tuning-body {
  grid-template-columns: 1fr;
  gap: 14px;
}

:root[data-theme="official"] .rt-slider-card,
:root[data-theme="official"] .deadzone-slider-card {
  padding: 12px;
  border-radius: 14px;
  background: rgba(7, 10, 19, 0.4);
  border: 1px solid rgba(124, 142, 230, 0.14);
}

/* ==================================================================
   第十五轮：按键配置/灯效/律动页统一为"键盘置顶+控制整宽" 2026-06-12
   这三页控制区天生宽(键码11标签792px、灯效子面板834px)，窄抽屉会溢出。
   统一改为性能页同款：键盘居中置顶 + 控制区下方整宽平铺。
   覆盖第十二/十三轮对这三页的抽屉与吸顶规则。
   ================================================================== */
:root[data-theme="official"] .panel:has(> .keymap-official-stage),
:root[data-theme="official"] .lighting-official-panel,
:root[data-theme="official"] .rhythm-official-panel {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

:root[data-theme="official"] .panel:has(> .keymap-official-stage) > .keymap-official-stage,
:root[data-theme="official"] .panel:has(> .keymap-official-stage) > .keymap-output-panel,
:root[data-theme="official"] .lighting-official-panel > .lighting-official-stage,
:root[data-theme="official"] .lighting-official-panel > .lighting-editor-layout,
:root[data-theme="official"] .rhythm-official-panel > .rhythm-official-stage,
:root[data-theme="official"] .rhythm-official-panel > .rhythm-editor-layout {
  flex: 0 0 auto;
  width: 100%;
  max-width: none;
  position: static;
  max-height: none;
  overflow: visible;
}

/* 键码选择标签：换行平铺，不再横向溢出 */
:root[data-theme="official"] .keymap-output-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

/* 灯效编辑区：整宽单列堆叠(效果面板↑ / 颜色面板↓)。
   颜色面板 min-content 极宽，两栏 auto-fit 会把 1fr 撑爆，故用单列。 */
:root[data-theme="official"] .lighting-official-panel > .lighting-editor-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 16px;
  align-items: start;
}

:root[data-theme="official"] .lighting-official-panel > .lighting-editor-layout > * {
  min-width: 0;
}

/* 律动编辑区：整宽下两栏(模式 | 参数)并排 */
:root[data-theme="official"] .rhythm-official-panel > .rhythm-editor-layout {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 16px;
  align-items: start;
}

/* 控制区整宽时改用整宽玻璃卡片质感 */
:root[data-theme="official"] .panel:has(> .keymap-official-stage) > .keymap-output-panel {
  padding: 18px;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(24, 30, 52, 0.6), rgba(18, 23, 41, 0.7));
  border: 1px solid rgba(129, 140, 248, 0.2);
  box-shadow: 0 14px 34px rgba(2, 6, 23, 0.4);
}

/* 灯效效果网格：固定 6×120px 会溢出，改为自适应换行填满列宽 */
:root[data-theme="official"] .lighting-effect-grid {
  grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
}

/* 行程深度控件：三列横排在窄列里溢出，官方主题下改竖向堆叠 */
:root[data-theme="official"] .travel-depth-control {
  grid-template-columns: 1fr;
  grid-template-areas: "switch" "slider" "readout";
  justify-items: center;
  gap: 14px;
  min-height: 0;
}

/* ---------- 第十五轮修正：消除列向 flex 残留 flex-basis 造成的横向溢出 ----------
   第十二轮的 flex:1 1 100% 在 column 方向指高度，配合遗留 align-items:flex-start
   令底部按钮行/调试块被推出右边导致整页横滚。统一为整宽纵向堆叠。 */
:root[data-theme="official"] .panel:has(> .keymap-official-stage),
:root[data-theme="official"] .panel:has(> .magnetic-official-stage),
:root[data-theme="official"] .lighting-official-panel,
:root[data-theme="official"] .rhythm-official-panel {
  align-items: stretch;
  flex-wrap: nowrap;
}

:root[data-theme="official"] .panel:has(> .keymap-official-stage) > *,
:root[data-theme="official"] .panel:has(> .magnetic-official-stage) > *,
:root[data-theme="official"] .lighting-official-panel > *,
:root[data-theme="official"] .rhythm-official-panel > * {
  flex: 0 0 auto;
  width: 100%;
  max-width: 100%;
  min-width: 0;
}

/* 控制区两栏网格内部正常排布，不被上面的整宽规则破坏 */
:root[data-theme="official"] .lighting-official-panel > .lighting-editor-layout,
:root[data-theme="official"] .rhythm-official-panel > .rhythm-editor-layout,
:root[data-theme="official"] .panel:has(> .magnetic-official-stage) > .magnetic-performance-columns {
  box-sizing: border-box;
}
