:root {
  --accent: #E57373;
  --accent-strong: #D65A5A;
  --accent-hover: #FFA4A2;
  --accent-soft: rgba(229, 115, 115, 0.12);
  --accent-ring: rgba(229, 115, 115, 0.28);
  --surface: rgba(255, 255, 255, 0.9);
  --surface-strong: #fffefe;
  --surface-subtle: rgba(255, 248, 248, 0.95);
  --border: #e7d4d4;
  --border-strong: #d9c1c1;
  --text: #18212b;
  --muted: #5f6f82;
  --shadow: 0 10px 26px rgba(23, 33, 43, 0.07);
  --danger: #c74c4c;
  --success: #388267;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  scrollbar-gutter: stable;
}

body {
  margin: 0;
  font-family: "Segoe UI", "PingFang SC", sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at top left, rgba(255, 164, 162, 0.28), transparent 28%),
    linear-gradient(180deg, #fff2f1 0%, #f6ecec 48%, #eceef1 100%);
}

body.picker-open {
  overflow: hidden;
}

body.config-refresh-open {
  overflow: hidden;
}

body.config-preview-open {
  overflow: hidden;
}

button,
input,
select,
textarea {
  font: inherit;
}

button,
.button-link {
  border: 1px solid var(--accent);
  background: var(--accent);
  color: #fff;
  border-radius: 12px;
  padding: 10px 16px;
  cursor: pointer;
  transition: transform 120ms ease, box-shadow 120ms ease, background 120ms ease, border-color 120ms ease;
}

button:hover:not(:disabled),
.button-link:hover {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
  box-shadow: 0 10px 22px rgba(229, 115, 115, 0.2);
  transform: translateY(-1px);
}

button:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.button-link.is-disabled,
.button-link[aria-disabled="true"] {
  opacity: 0.45;
  cursor: not-allowed;
  pointer-events: none;
  transform: none;
  box-shadow: none;
}

:is(button, .button-link)[data-action-icon]:not([hidden]) {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
}

:is(button, .button-link)[data-action-icon]::before {
  content: "";
  width: 15px;
  height: 15px;
  flex: 0 0 15px;
  display: block;
  background: currentColor;
  opacity: 0.78;
  -webkit-mask: var(--button-action-mask) center / contain no-repeat;
  mask: var(--button-action-mask) center / contain no-repeat;
}

#keymap-sync-current-btn {
  display: none !important;
}

button[data-action-icon]:disabled::before {
  opacity: 0.48;
}

button[data-action-icon="refresh"] {
  --button-action-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 12a9 9 0 0 1-15.5 6.2'/%3E%3Cpath d='M3 12a9 9 0 0 1 15.5-6.2'/%3E%3Cpath d='M18 3v5h-5'/%3E%3Cpath d='M6 21v-5h5'/%3E%3C/svg%3E");
}

button[data-action-icon="save"] {
  --button-action-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 3h12l2 2v16H5z'/%3E%3Cpath d='M8 3v6h8V3'/%3E%3Cpath d='M8 21v-7h8v7'/%3E%3C/svg%3E");
}

button[data-action-icon="reset"] {
  --button-action-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 12a9 9 0 1 0 3-6.7'/%3E%3Cpath d='M3 4v5h5'/%3E%3C/svg%3E");
}

button[data-action-icon="import"] {
  --button-action-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3v10'/%3E%3Cpath d='M8 9l4 4 4-4'/%3E%3Cpath d='M5 17h14'/%3E%3Cpath d='M5 17v3h14v-3'/%3E%3C/svg%3E");
}

button[data-action-icon="export"] {
  --button-action-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 13V3'/%3E%3Cpath d='M8 7l4-4 4 4'/%3E%3Cpath d='M5 17h14'/%3E%3Cpath d='M5 17v3h14v-3'/%3E%3C/svg%3E");
}

button[data-action-icon="upload"] {
  --button-action-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M17.5 18H17a4.5 4.5 0 0 0 .4-9.7A5.4 5.4 0 0 0 7.2 10 4 4 0 0 0 8 18h.5'/%3E%3Cpath d='M12 20v-8'/%3E%3Cpath d='M9 15l3-3 3 3'/%3E%3C/svg%3E");
}

button[data-action-icon="check"] {
  --button-action-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");
}

button[data-action-icon="cancel"],
button[data-action-icon="clear"] {
  --button-action-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 6l12 12'/%3E%3Cpath d='M18 6L6 18'/%3E%3C/svg%3E");
}

button[data-action-icon="repair"] {
  --button-action-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14.7 6.3a4 4 0 0 0 4.9 4.9L11 19.8a2.5 2.5 0 0 1-3.5-3.5z'/%3E%3Cpath d='M18 5l1 1'/%3E%3C/svg%3E");
}

button[data-action-icon="power"] {
  --button-action-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 2v10'/%3E%3Cpath d='M18.4 6.6a9 9 0 1 1-12.8 0'/%3E%3C/svg%3E");
}

button[data-action-icon="sync"] {
  --button-action-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M16 3h5v5'/%3E%3Cpath d='M21 3l-7 7'/%3E%3Cpath d='M8 21H3v-5'/%3E%3Cpath d='M3 21l7-7'/%3E%3C/svg%3E");
}

button[data-action-icon="send"] {
  --button-action-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 2L11 13'/%3E%3Cpath d='M22 2l-7 20-4-9-9-4z'/%3E%3C/svg%3E");
}

button[data-action-icon="spark"] {
  --button-action-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3l1.7 4.3L18 9l-4.3 1.7L12 15l-1.7-4.3L6 9l4.3-1.7z'/%3E%3Cpath d='M19 15l.9 2.1L22 18l-2.1.9L19 21l-.9-2.1L16 18l2.1-.9z'/%3E%3C/svg%3E");
}

button[data-action-icon="connect"] {
  --button-action-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M8.5 15.5a5 5 0 0 1 0-7l1.5-1.5a5 5 0 0 1 7 7l-1.2 1.2'/%3E%3Cpath d='M15.5 8.5a5 5 0 0 1 0 7L14 17a5 5 0 0 1-7-7l1.2-1.2'/%3E%3C/svg%3E");
}

:is(button, .button-link)[data-action-icon="download"] {
  --button-action-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3v12'/%3E%3Cpath d='M7 10l5 5 5-5'/%3E%3Cpath d='M5 21h14'/%3E%3C/svg%3E");
}

button[data-action-icon="preview"] {
  --button-action-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M2 12s3.5-6 10-6 10 6 10 6-3.5 6-10 6S2 12 2 12z'/%3E%3Ccircle cx='12' cy='12' r='3'/%3E%3C/svg%3E");
}

button[data-action-icon="history"] {
  --button-action-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 12a9 9 0 1 0 3-6.7'/%3E%3Cpath d='M3 4v5h5'/%3E%3Cpath d='M12 7v5l3 2'/%3E%3C/svg%3E");
}

.button-link {
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

input,
select,
textarea {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--border-strong);
  border-radius: 12px;
  background: #fff;
  color: var(--text);
}

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

input:focus,
select:focus,
textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 4px var(--accent-ring);
}

.input-error {
  border-color: var(--danger);
  box-shadow: 0 0 0 3px rgba(199, 76, 76, 0.14);
}

label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 14px;
}

label > span {
  color: var(--muted);
  font-weight: 600;
}

.shell {
  max-width: 1680px;
  margin: 0 auto;
  padding: 28px 24px 40px;
  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
  gap: 20px;
  align-items: start;
}

.shell-main {
  min-width: 0;
}

.project-sidebar {
  position: sticky;
  top: 24px;
  align-self: start;
}

.project-sidebar-inner {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto auto;
  gap: 16px;
  padding: 18px;
  align-content: stretch;
  background: linear-gradient(180deg, var(--surface-strong) 0%, var(--surface-subtle) 100%);
  border: 1px solid var(--border);
  border-radius: 22px;
  box-shadow: var(--shadow);
  min-height: calc(100vh - 48px);
  max-height: calc(100vh - 48px);
  overflow: visible;
}

.project-sidebar-brand {
  display: grid;
  grid-template-columns: 60px minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}

.project-sidebar-brand-compact {
  grid-template-columns: 1fr;
  justify-items: center;
}

.project-sidebar-logo {
  width: 60px;
  height: 60px;
  object-fit: contain;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
  padding: 8px;
  border: 1px solid rgba(229, 115, 115, 0.18);
}

.project-nav {
  display: grid;
  gap: 10px;
  min-height: 0;
  align-content: start;
  overflow-y: auto;
  overscroll-behavior: contain;
  padding: 5px 8px 5px 4px;
  margin: -5px -6px -5px -4px;
  scrollbar-width: thin;
}

.project-nav::-webkit-scrollbar {
  width: 6px;
}

.project-nav::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: rgba(229, 115, 115, 0.22);
}

.project-sidebar-language {
  display: grid;
  gap: 8px;
  padding: 12px 0 0;
  border-top: 1px solid rgba(229, 115, 115, 0.12);
  position: relative;
  z-index: 20;
}

.project-sidebar-config-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-top: -4px;
  padding: 0;
  position: relative;
  z-index: 1;
}

.config-library-file-actions {
  position: relative;
  display: inline-flex;
  flex: none;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}

.project-language-select {
  width: 100%;
  min-height: 42px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(229, 115, 115, 0.16);
  background: rgba(255, 255, 255, 0.92);
}

.project-sidebar-status {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-top: -4px;
  padding-top: 0;
  position: relative;
  z-index: 1;
}

.project-status-tile {
  position: relative;
  display: grid;
  place-items: center;
  gap: 6px;
  min-width: 0;
  min-height: 58px;
  padding: 8px 6px;
  border-radius: 12px;
  border: 1px solid rgba(229, 115, 115, 0.16);
  background: rgba(255, 255, 255, 0.9);
  color: var(--muted);
  text-align: center;
}

.project-transport-tile,
.project-config-tile {
  width: 100%;
  appearance: none;
  font: inherit;
  cursor: pointer;
}

.project-transport-tile[data-active="true"] {
  border-color: rgba(229, 115, 115, 0.42);
  background: rgba(255, 248, 248, 0.98);
  color: var(--text);
}

.project-transport-tile[data-state="connected"]::after {
  content: "";
  position: absolute;
  top: 7px;
  right: 7px;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 3px rgba(229, 115, 115, 0.14);
}

.project-transport-tile:disabled,
.project-config-tile:disabled {
  cursor: not-allowed;
  opacity: 0.48;
}

.project-transport-tile:not(:disabled):hover,
.project-transport-tile:focus-visible,
.project-config-tile:not(:disabled):hover,
.project-config-tile:focus-visible {
  border-color: rgba(229, 115, 115, 0.44);
  color: var(--text);
  box-shadow: 0 0 0 4px var(--accent-soft);
  outline: none;
}

.project-status-icon {
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.project-status-text {
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.2;
  white-space: nowrap;
}

button.project-config-tile {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 38px;
  padding: 8px 9px;
}

button.project-config-tile .project-status-icon {
  width: 15px;
  height: 15px;
  flex: 0 0 15px;
}

.config-library-file-actions .project-config-tile {
  width: auto;
}

.config-library-file-actions .project-config-message {
  flex: 1 0 100%;
  max-width: 260px;
  margin: -2px 0 0;
  text-align: right;
}

.project-status-battery {
  cursor: default;
}

.battery-icon {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  color: var(--muted);
}

.battery-body {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px;
  width: 22px;
  height: 12px;
  padding: 2px;
  border: 1.6px solid currentColor;
  border-radius: 3px;
  box-sizing: border-box;
}

.battery-cap {
  width: 3px;
  height: 7px;
  border-radius: 1px;
  background: currentColor;
}

.battery-segment {
  border-radius: 1px;
  background: rgba(99, 115, 139, 0.18);
}

.project-status-battery[data-level="1"] .battery-segment:nth-child(-n+1),
.project-status-battery[data-level="2"] .battery-segment:nth-child(-n+2),
.project-status-battery[data-level="3"] .battery-segment:nth-child(-n+3),
.project-status-battery[data-level="4"] .battery-segment:nth-child(-n+4) {
  background: currentColor;
}

.project-status-battery[data-state="good"] {
  color: var(--text);
}

.project-status-battery[data-state="low"] {
  color: var(--text);
}

.project-status-battery[data-state="critical"] {
  color: var(--text);
}

.project-status-battery[data-state="unknown"] {
  color: var(--muted);
}

.project-config-message {
  grid-column: 1 / -1;
  min-height: 0;
  font-size: 12px;
}

.project-config-message:empty {
  display: none;
}

.project-nav-link {
  position: relative;
  display: flex;
  align-items: center;
  gap: 13px;
  min-height: 50px;
  padding: 12px 13px;
  border-radius: 10px;
  border: 1px solid rgba(229, 115, 115, 0.14);
  background: rgba(255, 255, 255, 0.9);
  color: var(--text);
  font-size: 15px;
  font-weight: 600;
  line-height: 1.35;
  text-decoration: none;
  transition: transform 120ms ease, box-shadow 120ms ease, background 120ms ease, border-color 120ms ease, color 120ms ease;
}

.project-nav-icon {
  width: 19px;
  height: 19px;
  flex: 0 0 19px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.project-nav-text {
  min-width: 0;
}

.project-nav-link:hover {
  border-color: var(--accent);
  background: rgba(255, 164, 162, 0.1);
  box-shadow: 0 0 0 4px var(--accent-ring);
  transform: translateX(2px);
}

.project-nav-link[data-active="true"] {
  background: var(--accent-soft);
  border-color: var(--accent);
  color: #7b3f3f;
  box-shadow: inset 0 0 0 1px rgba(229, 115, 115, 0.16);
}

.hero,
.summary-grid,
.panel {
  scroll-margin-top: 24px;
}

.anchor-target {
  display: block;
  height: 0;
  scroll-margin-top: 24px;
}

.hero,
.panel,
.summary-card {
  background: linear-gradient(180deg, var(--surface-strong) 0%, var(--surface-subtle) 100%);
  border: 1px solid var(--border);
  border-radius: 18px;
  box-shadow: var(--shadow);
}

.hero {
  padding: 20px;
  display: grid;
  gap: 14px;
}

.hero-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 12px;
  align-items: start;
}

.hero-main {
  display: grid;
  gap: 10px;
  min-width: 0;
}

.hero-side {
  display: grid;
  align-content: start;
}

.hero-actions-panel {
  display: grid;
  gap: 10px;
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.74);
  border: 1px solid rgba(229, 115, 115, 0.16);
}

.hero-access-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.hero-access-header h2 {
  font-size: 18px;
}

.hero-side-copy {
  margin: 8px 0 0;
  color: var(--muted);
  line-height: 1.55;
}

.hero-brand {
  display: flex;
  gap: 14px;
  align-items: center;
}

.hero-brand-copy {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.hero-logo {
  width: 68px;
  height: 68px;
  object-fit: contain;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.7);
  padding: 8px;
  border: 1px solid rgba(229, 115, 115, 0.18);
}

.eyebrow {
  color: var(--accent);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

h1,
h2,
h3 {
  margin: 0;
}

.hero-copy,
.panel-header p,
.notes,
.summary-note,
.section-message:empty::before {
  color: var(--muted);
}

.hero-copy,
.panel-header p {
  margin: 0;
  line-height: 1.55;
}

.hero-copy {
  max-width: 1120px;
}

.hero-actions,
.section-actions,
.editor-toolbar,
.subpanel-header {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

.hero-meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 180px));
  gap: 10px;
}

.hero-meta-inline {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.hero-sync-row {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(540px, 1fr);
  gap: 12px;
  align-items: end;
}

.hero-actions-panel .hero-actions {
  display: flex;
  flex-wrap: nowrap;
  gap: 10px;
  align-items: end;
  justify-content: flex-end;
}

.hero-actions-panel .hero-transport {
  max-width: none;
  flex: 0 0 180px;
}

.hero-actions-panel .hero-actions button {
  min-width: 92px;
  min-height: 46px;
  padding-inline: 14px;
  white-space: nowrap;
}

.hero-file-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.hero-file-actions button {
  min-height: 42px;
  padding-inline: 14px;
  white-space: nowrap;
}

.form-message {
  min-height: 20px;
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.form-message[data-state="success"] {
  color: #237a4f;
}

.form-message[data-state="error"] {
  color: #b33a35;
}

.meta-pill {
  display: inline-flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(229, 115, 115, 0.16);
}

.meta-pill strong {
  line-height: 1.2;
}

.meta-label {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

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

#context-system > .summary-grid {
  margin-bottom: 18px;
}

.hero-summary-grid {
  margin-top: 0;
}

.summary-card {
  display: grid;
  gap: 10px;
  align-content: start;
  padding: 16px;
}

.summary-card h2 {
  margin-bottom: 0;
  font-size: 17px;
}

.meta-list {
  margin: 0;
  display: grid;
  gap: 10px;
}

.meta-list > div {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: baseline;
}

.meta-list dt {
  color: var(--muted);
  font-size: 14px;
}

.meta-list dd {
  margin: 0;
  font-weight: 600;
  text-align: right;
}

.summary-card .meta-list {
  gap: 8px;
}

.summary-card .meta-list > div {
  padding: 8px 10px;
  border-radius: 14px;
  border: 1px solid rgba(229, 115, 115, 0.12);
  background: rgba(255, 255, 255, 0.78);
  gap: 10px;
}

.summary-card .meta-list dt {
  font-size: 13px;
}

.summary-card .meta-list dd {
  font-size: 14px;
}

.summary-card .chip-list {
  gap: 6px;
}

.summary-card .chip {
  padding: 6px 10px;
  font-size: 12px;
}

.summary-card .summary-note {
  margin-top: 0;
  display: grid;
  gap: 8px;
}

.summary-card .summary-note span {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 14px;
  border: 1px solid rgba(229, 115, 115, 0.12);
  background: rgba(255, 255, 255, 0.78);
}

.chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  background: var(--accent-soft);
  color: #7b3f3f;
  font-size: 13px;
  font-weight: 600;
}

.panel {
  margin-top: 18px;
  padding: 20px;
}

.panel-header {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
  margin-bottom: 18px;
}

.panel-header > .section-actions > button {
  min-width: 92px;
  min-height: 46px;
  padding-inline: 14px;
  white-space: nowrap;
}

#macro-panel > .panel-header {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) minmax(480px, 640px);
  gap: 18px;
  align-items: start;
}

#macro-panel > .panel-header > div:first-child {
  min-width: 0;
  max-width: 460px;
}

#macro-panel .macro-panel-actions {
  display: grid;
  grid-template-columns: repeat(4, max-content);
  gap: 8px;
  width: auto;
  justify-self: end;
  align-items: stretch;
}

#macro-panel .macro-panel-actions button {
  width: auto;
  min-width: 92px;
  min-height: 38px;
  padding: 8px 14px;
  white-space: nowrap;
}

#macro-save-btn,
#macro-import-btn,
#macro-export-selected-btn,
#macro-repair-btn {
  display: none !important;
}

@media (max-width: 1180px) {
  #macro-panel > .panel-header {
    grid-template-columns: 1fr;
  }

  #macro-panel > .panel-header > div:first-child {
    max-width: none;
  }

  #macro-panel .macro-panel-actions {
    width: auto;
    grid-template-columns: repeat(4, max-content);
    justify-self: end;
  }
}

@media (max-width: 720px) {
  #macro-panel .macro-panel-actions {
    width: 100%;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    justify-self: stretch;
  }

  #macro-panel .macro-panel-actions button {
    width: 100%;
  }
}

.panel-grid {
  display: grid;
  gap: 16px;
}

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

.panel-grid-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.context-system-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 12px;
  align-items: start;
}

.context-system-column {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 12px;
  align-content: start;
  min-width: 0;
}

.context-system-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 10px;
  align-content: start;
  padding: 12px 14px;
}

.context-system-card > h3,
.context-system-card > .subpanel-header,
.context-system-card > .notes,
.context-system-card > .compact-grid,
.context-system-card > .action-grid,
.context-system-card > .section-message {
  grid-column: 1 / -1;
}

.context-system-card-header {
  justify-content: space-between;
  align-items: center;
  gap: 8px 12px;
  margin-bottom: 0;
}

.context-system-card-header .section-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 6px;
  margin-top: 0;
  width: auto;
  flex: 0 0 auto;
}

.context-system-card-header .section-actions button {
  width: auto;
  min-width: 112px;
  min-height: 34px;
  padding: 8px 12px;
  white-space: nowrap;
}

.context-system-card .compact-grid {
  justify-content: start;
  gap: 8px 10px;
}

.context-system-card .compact-grid > label {
  display: grid;
  gap: 6px;
  padding: 8px 10px;
  border-radius: 14px;
  border: 1px solid rgba(229, 115, 115, 0.12);
  background: rgba(255, 255, 255, 0.78);
}

.context-system-card .compact-grid > label > span {
  font-size: 13px;
}

.context-system-card-current .compact-grid {
  grid-template-columns: repeat(2, minmax(180px, 240px));
}

.context-system-card-defaults .compact-grid {
  grid-template-columns: repeat(4, minmax(170px, 220px));
}

.context-system-card-runtime .compact-grid {
  grid-template-columns: repeat(2, minmax(180px, 240px));
}

.context-system-actions {
  margin-top: 0;
  gap: 10px;
}

.context-system-actions .subpanel-header {
  margin-bottom: 0;
  align-items: flex-start;
}

.context-system-actions .action-grid {
  grid-template-columns: repeat(2, minmax(180px, 260px));
  justify-content: start;
  gap: 8px;
  margin-top: 0;
}

.context-system-actions .action-grid button {
  min-height: 38px;
}

.context-system-actions .section-message {
  grid-column: 1 / -1;
  margin-top: 0;
  min-height: 0;
}

.context-system-actions .section-message:empty {
  display: none;
}

@media (min-width: 1180px) {
  .context-system-layout {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
    align-items: start;
    overflow: visible;
  }

  .context-system-card {
    min-width: 0;
    overflow: hidden;
    margin: 0;
  }

  .context-system-card .compact-grid {
    grid-template-columns: 1fr;
  }

  .context-system-card-current .compact-grid,
  .context-system-card-defaults .compact-grid,
  .context-system-card-runtime .compact-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .context-system-card-defaults .compact-grid {
    gap: 8px;
  }

  .context-system-card-indicator-colors .indicator-setting-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    justify-content: stretch;
  }

  .context-system-card-header .section-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    width: auto;
    min-width: 0;
    margin-top: 0;
  }

  .context-system-card-header .section-actions button {
    width: auto;
    min-width: 92px;
  }

  .context-system-actions .action-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .context-system-actions .action-grid button {
    min-width: 0;
  }

  .context-system-card input,
  .context-system-card select {
    min-width: 0;
  }
}

.context-system-card-ble-names,
.context-system-card-indicator-colors {
  gap: 12px;
}

.context-system-card-ble-names .section-message,
.context-system-card-indicator-colors .section-message {
  margin-top: 0;
  min-height: 0;
}

.context-system-card-ble-names .section-message:empty,
.context-system-card-indicator-colors .section-message:empty {
  display: none;
}

.compact-setting-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 8px;
}

.indicator-setting-grid {
  grid-template-columns: repeat(5, minmax(108px, 136px));
  justify-content: start;
  gap: 8px;
}

.ble-name-setting-grid {
  grid-template-columns: repeat(3, minmax(220px, 320px));
  justify-content: start;
  gap: 10px;
}

@media (min-width: 1180px) {
  .ble-name-setting-grid {
    grid-template-columns: 1fr;
  }
}

.ble-name-setting-grid > .setting-card,
.indicator-setting-grid > .setting-card {
  height: auto;
  padding: 12px;
}

.ble-name-setting-grid > .setting-card {
  display: grid;
  grid-template-columns: 82px minmax(0, 1fr);
  align-items: center;
  gap: 8px;
}

.ble-name-setting-grid .setting-card-header,
.indicator-setting-grid .setting-card-header {
  margin-bottom: 0;
}

.ble-name-setting-grid .setting-card-header {
  min-width: 0;
}

.ble-name-setting-grid .setting-title {
  white-space: nowrap;
}

.ble-name-setting-grid > .setting-card label {
  min-width: 0;
  margin: 0;
}

.indicator-setting-grid .setting-title {
  font-size: 15px;
  white-space: nowrap;
}

.indicator-color-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-height: 42px;
}

.indicator-color-card .indicator-color-row {
  flex: 0 0 auto;
  min-width: 0;
  gap: 0;
}

.indicator-color-card .indicator-color-controls {
  min-width: 0;
  justify-content: end;
}

.indicator-color-card .indicator-color-input {
  width: 42px;
  min-width: 42px;
  height: 30px;
  padding: 3px;
  border-radius: 9px;
}

.compact-setting-grid > .setting-card {
  height: 100%;
  padding: 12px;
}

.compact-setting-grid > .setting-card .setting-card-header {
  margin-bottom: 8px;
}

.ble-name-setting-grid > .setting-card,
.indicator-setting-grid > .setting-card {
  height: auto;
}

.ble-name-setting-grid > .setting-card .setting-card-header,
.indicator-setting-grid > .setting-card .setting-card-header {
  margin-bottom: 0;
}

.subpanel,
.setting-card,
.key-editor-card {
  border-radius: 16px;
  border: 1px solid rgba(229, 115, 115, 0.12);
  background: rgba(255, 255, 255, 0.7);
}

.subpanel,
.setting-card,
.key-editor-card {
  padding: 16px;
}

.subpanel h3,
.setting-title,
.key-editor-name {
  font-size: 16px;
}


.compact-grid {
  display: grid;
  gap: 12px;
}

.field-stack {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.field-stack > span {
  color: var(--muted);
  font-size: 14px;
  font-weight: 600;
}

.toggle-list {
  display: grid;
  gap: 12px;
}

.toggle-row {
  flex-direction: row;
  align-items: center;
  gap: 10px;
}

.toggle-row input {
  width: auto;
  margin: 0;
}

.notes {
  margin-top: 14px;
  display: grid;
  gap: 6px;
  line-height: 1.5;
  font-size: 13px;
}

.section-message {
  margin-top: 14px;
  min-height: 20px;
  font-size: 14px;
  font-weight: 600;
}

#keymap-message:empty {
  display: none;
}

.section-message[data-state="success"] {
  color: var(--success);
}

.section-message[data-state="error"] {
  color: var(--danger);
}

.config-library-panel {
  scroll-margin-top: 24px;
  padding: 22px 24px 26px;
}

.config-library-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 18px;
  margin-bottom: 14px;
}

.config-library-heading {
  display: grid;
  gap: 5px;
  min-width: 0;
}

.config-library-header h2 {
  margin: 0;
}

.config-library-header p {
  max-width: 560px;
  font-size: 14px;
}

.config-library-header-actions {
  position: relative;
  display: inline-flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 2px;
}

.config-library-header-actions :is(.project-config-tile, summary),
.hero-actions-panel .hero-actions > button[data-action-icon],
.panel-header > .section-actions > button[data-action-icon],
.subpanel-header > .section-actions > button[data-action-icon],
.context-system-actions .action-grid > button[data-action-icon],
.app .upgrade-action-card :is(button, .button-link)[data-action-icon],
.ai-agent-actions > button[data-action-icon],
.ai-agent-cli-link[data-action-icon],
.macro-title-group :is(.macro-clear-btn, .macro-card-save-btn, .macro-card-import-btn, .macro-export-btn)[data-action-icon],
.config-library-device-row > button[data-action-icon],
.config-library-upload-popover .section-actions > button[data-action-icon] {
  width: auto;
  min-width: 92px;
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  padding: 8px 14px;
  border: 1px solid rgba(229, 115, 115, 0.24);
  border-radius: 12px;
  background: rgba(229, 115, 115, 0.07);
  color: var(--accent-strong);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.2;
  box-shadow: 0 1px 0 rgba(229, 115, 115, 0.06);
  white-space: nowrap;
  transition: border-color 140ms ease, background 140ms ease, color 140ms ease, box-shadow 140ms ease, transform 140ms ease;
}

.config-library-header-actions :is(.project-status-icon, .config-library-action-icon) {
  width: 15px;
  height: 15px;
  flex: 0 0 15px;
  display: block;
  color: currentColor;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  opacity: 0.76;
}

.config-library-header-actions :is(.project-status-text, summary span) {
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
}

.config-library-header-actions .project-config-tile:disabled,
.hero-actions-panel .hero-actions > button[data-action-icon]:disabled,
.panel-header > .section-actions > button[data-action-icon]:disabled,
.subpanel-header > .section-actions > button[data-action-icon]:disabled,
.context-system-actions .action-grid > button[data-action-icon]:disabled,
.app .upgrade-action-card :is(button, .button-link)[data-action-icon]:disabled,
.ai-agent-actions > button[data-action-icon]:disabled,
.macro-title-group :is(.macro-clear-btn, .macro-card-save-btn, .macro-card-import-btn, .macro-export-btn)[data-action-icon]:disabled,
.config-library-device-row > button[data-action-icon]:disabled,
.config-library-upload-popover .section-actions > button[data-action-icon]:disabled {
  border-color: rgba(229, 115, 115, 0.14);
  background: rgba(229, 115, 115, 0.08);
  color: rgba(214, 90, 90, 0.48);
  opacity: 1;
}

.config-library-header-actions :is(.project-config-tile:not(:disabled):hover, .project-config-tile:focus-visible, summary:hover),
.hero-actions-panel .hero-actions > button[data-action-icon]:not(:disabled):hover,
.hero-actions-panel .hero-actions > button[data-action-icon]:focus-visible,
.panel-header > .section-actions > button[data-action-icon]:not(:disabled):hover,
.panel-header > .section-actions > button[data-action-icon]:focus-visible,
.subpanel-header > .section-actions > button[data-action-icon]:not(:disabled):hover,
.subpanel-header > .section-actions > button[data-action-icon]:focus-visible,
.context-system-actions .action-grid > button[data-action-icon]:not(:disabled):hover,
.context-system-actions .action-grid > button[data-action-icon]:focus-visible,
.app .upgrade-action-card :is(button, .button-link)[data-action-icon]:not(:disabled):hover,
.app .upgrade-action-card :is(button, .button-link)[data-action-icon]:focus-visible,
.ai-agent-actions > button[data-action-icon]:not(:disabled):hover,
.ai-agent-actions > button[data-action-icon]:focus-visible,
.ai-agent-cli-link[data-action-icon]:hover,
.ai-agent-cli-link[data-action-icon]:focus-visible,
.macro-title-group :is(.macro-clear-btn, .macro-card-save-btn, .macro-card-import-btn, .macro-export-btn)[data-action-icon]:not(:disabled):hover,
.macro-title-group :is(.macro-clear-btn, .macro-card-save-btn, .macro-card-import-btn, .macro-export-btn)[data-action-icon]:focus-visible,
.config-library-device-row > button[data-action-icon]:not(:disabled):hover,
.config-library-device-row > button[data-action-icon]:focus-visible,
.config-library-upload-popover .section-actions > button[data-action-icon]:not(:disabled):hover,
.config-library-upload-popover .section-actions > button[data-action-icon]:focus-visible {
  border-color: rgba(229, 115, 115, 0.42);
  background: var(--accent-soft);
  color: var(--accent-strong);
  box-shadow: 0 8px 18px rgba(229, 115, 115, 0.12);
  transform: translateY(-1px);
  outline: none;
}

.config-library-device-menu {
  position: relative;
  flex: none;
}

.config-library-device-menu summary,
.config-library-tool-panel summary {
  cursor: pointer;
  user-select: none;
  list-style: none;
}

.config-library-device-menu summary::-webkit-details-marker,
.config-library-tool-panel summary::-webkit-details-marker {
  display: none;
}

.config-library-device-menu[open] summary,
.config-library-tool-panel[open] summary {
  border-color: rgba(229, 115, 115, 0.46);
  background: rgba(255, 241, 241, 0.96);
  color: var(--accent-strong);
}

.config-library-list {
  --config-library-row-height: 150px;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 12px;
  align-items: stretch;
  max-height: calc(var(--config-library-row-height) * 3 + 24px);
  overflow-y: auto;
  padding: 2px 4px 0 2px;
  scrollbar-gutter: stable;
}

.config-library-actions {
  align-items: center;
}

.config-library-actions .secondary-action.active,
.config-library-card-actions .secondary-action.active {
  background: rgba(229, 115, 115, 0.12);
  border-color: var(--accent);
  color: var(--accent-strong);
}

.config-library-tools {
  display: grid;
  gap: 10px;
  margin-bottom: 14px;
}

.config-library-toolbar {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 12px;
}

.config-library-device-row {
  position: absolute;
  z-index: 40;
  top: calc(100% + 8px);
  right: 0;
  width: min(340px, calc(100vw - 64px));
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: end;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 16px 32px rgba(23, 33, 43, 0.12);
}

.config-library-device-row label {
  display: grid;
  gap: 5px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}

.config-library-device-row input {
  min-height: 38px;
  min-width: 0;
}

.config-library-device-row button {
  width: auto;
  min-width: 64px;
  min-height: 36px;
  padding: 7px 12px;
}

.config-library-mode-row {
  display: inline-flex;
  flex: none;
  flex-wrap: nowrap;
  gap: 8px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
}

.config-library-mode {
  min-height: 34px;
  padding: 6px 14px;
  border: 1px solid rgba(229, 115, 115, 0.2);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.68);
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
  box-shadow: none;
}

.config-library-mode.active {
  border-color: var(--accent);
  background: rgba(229, 115, 115, 0.1);
  color: var(--accent-strong);
  box-shadow: none;
}

.config-library-mode:hover:not(:disabled) {
  background: rgba(255, 246, 245, 0.88);
  color: var(--accent-strong);
  box-shadow: none;
}

.config-library-mode.is-unavailable:not(.active) {
  opacity: 0.62;
}

.config-library-share-row {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) auto;
  gap: 10px;
  align-items: center;
}

.config-library-share-row input {
  min-width: 0;
}

.config-library-filter-row {
  display: grid;
  grid-template-columns: minmax(220px, 1fr);
  gap: 10px;
}

.config-library-search-row {
  display: grid;
}

.config-library-search-row input {
  min-height: 46px;
  padding-inline: 16px;
  border-color: rgba(217, 193, 193, 0.8);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.9);
  font-size: 14px;
}

.config-library-filter-row label {
  display: grid;
  gap: 5px;
  color: var(--muted);
  font-size: 13px;
}

.config-library-filter-row select,
.config-library-filter-row input {
  width: 100%;
  min-width: 0;
}

.config-library-tag-filter-list {
  display: flex;
  flex-wrap: nowrap;
  gap: 6px;
  max-width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  padding: 2px 0 3px;
  scrollbar-gutter: stable;
  -webkit-overflow-scrolling: touch;
}

.config-library-tag-filter {
  flex: 0 0 auto;
  min-height: 26px;
  padding: 4px 9px;
  border: 1px solid rgba(229, 115, 115, 0.16);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.64);
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}

.config-library-tag-filter.active {
  border-color: var(--accent);
  background: rgba(229, 115, 115, 0.12);
  color: var(--accent-strong);
}

.config-library-tag-filter:hover:not(:disabled),
.config-library-tag-filter:focus-visible {
  transform: none;
}

.config-library-tool-panel {
  position: relative;
  flex: none;
}

.config-library-upload-popover {
  position: absolute;
  z-index: 45;
  top: calc(100% + 8px);
  right: 0;
  width: min(540px, calc(100vw - 64px));
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 18px 36px rgba(23, 33, 43, 0.14);
}

.config-library-form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
  margin: 4px 0 12px;
}

.config-library-form-grid label {
  display: grid;
  gap: 5px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}

.config-library-form-grid input,
.config-library-form-grid select {
  width: 100%;
  min-height: 38px;
}

.config-library-form-grid textarea {
  width: 100%;
  min-height: 88px;
}

.config-library-tags-field {
  align-content: start;
  grid-template-columns: minmax(180px, 1fr);
}

.config-library-tags-field > span,
.config-library-tags-field > input {
  max-width: calc((100% - 10px) / 2);
}

.config-library-upload-tag-list {
  min-height: 32px;
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  align-items: center;
}

.config-library-upload-tag-chip {
  min-height: 26px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  max-width: 100%;
  padding: 4px 6px 4px 10px;
  border: 1px solid rgba(229, 115, 115, 0.18);
  border-radius: 999px;
  background: rgba(229, 115, 115, 0.08);
  color: var(--accent-strong);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.2;
}

.config-library-upload-tag-chip span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.config-library-upload-tag-remove {
  width: 18px;
  height: 18px;
  min-width: 18px;
  min-height: 18px;
  display: inline-grid;
  place-items: center;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--accent-strong);
  font-size: 16px;
  font-weight: 700;
  line-height: 1;
  box-shadow: none;
}

.config-library-upload-tag-remove:hover:not(:disabled),
.config-library-upload-tag-remove:focus-visible {
  background: rgba(229, 115, 115, 0.14);
  color: var(--accent-strong);
  box-shadow: none;
  transform: none;
}

.config-library-upload-popover .section-actions {
  justify-content: flex-end;
  margin-top: 2px;
}

.config-library-upload-popover .section-actions button {
  width: auto;
}

.config-library-admin-grid {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) minmax(130px, 160px) minmax(180px, 1fr) auto;
  gap: 10px;
  align-items: center;
  margin: 4px 0 10px;
}

.config-library-admin-grid input,
.config-library-admin-grid select {
  min-width: 0;
}

.config-library-review-pager {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin: 0 0 10px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.config-library-review-pager button {
  min-height: 32px;
  padding: 7px 10px;
}

.config-library-wide-field {
  grid-column: 1 / -1;
}

.config-library-empty {
  min-height: 92px;
  display: grid;
  place-items: center;
  padding: 18px;
  border: 1px dashed var(--border);
  border-radius: 12px;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.56);
  font-size: 14px;
  text-align: center;
}

.config-library-card {
  position: relative;
  min-width: 0;
  width: 100%;
  max-width: none;
  min-height: var(--config-library-row-height);
  display: grid;
  gap: 10px;
  align-content: start;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--surface-strong);
  box-shadow: 0 8px 18px rgba(23, 33, 43, 0.05);
  cursor: pointer;
  transition: border-color 140ms ease, box-shadow 140ms ease, transform 140ms ease, background 140ms ease;
}

.config-library-card:hover,
.config-library-card:focus-visible,
.config-library-card.is-active {
  z-index: 1;
  border-color: rgba(229, 115, 115, 0.38);
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 12px 24px rgba(23, 33, 43, 0.08);
}

.config-library-card:hover {
  transform: translateY(-1px);
}

.config-library-card[aria-disabled="true"] {
  cursor: default;
  opacity: 0.72;
  transform: none;
}

.config-library-card-header {
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.config-library-card-title {
  flex: 1 1 auto;
  min-width: 0;
  margin: 0;
  font-size: 17px;
  line-height: 1.3;
}

.config-library-card-code-group {
  flex: none;
  display: flex;
  flex-wrap: nowrap;
  justify-content: flex-end;
  gap: 5px;
  max-width: min(100%, 220px);
}

.config-library-card-favorite {
  flex: none;
  width: 34px;
  height: 34px;
  display: inline-grid;
  place-items: center;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--accent);
  -webkit-text-fill-color: currentColor;
  line-height: 1;
  box-shadow: none;
}

.config-library-card-favorite svg {
  width: 24px;
  height: 24px;
  display: block;
  overflow: visible;
}

.config-library-card-favorite svg path {
  fill: transparent;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linejoin: round;
}

.config-library-card-favorite:hover:not(:disabled),
.config-library-card-favorite:focus-visible {
  background: rgba(229, 115, 115, 0.08);
  color: var(--accent);
  box-shadow: none;
  transform: none;
}

.config-library-card-favorite.active {
  color: var(--accent);
}

.config-library-card-favorite.active svg path {
  fill: currentColor;
  stroke: currentColor;
}

.config-library-card-favorite-count {
  flex: none;
  min-width: 10px;
  margin-left: -8px;
  color: var(--accent);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
}

.config-library-card-code {
  flex: none;
  padding: 3px 7px;
  border: 1px solid rgba(229, 115, 115, 0.2);
  border-radius: 999px;
  background: rgba(229, 115, 115, 0.08);
  color: var(--accent-strong);
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0;
}

.config-library-card-author {
  border-color: rgba(117, 86, 86, 0.18);
  background: rgba(117, 86, 86, 0.04);
  color: var(--muted);
}

.config-library-card-meta,
.config-library-card-description {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.config-library-card-footer {
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
}

.config-library-chip-list {
  min-width: 0;
  display: flex;
  flex: 1 1 auto;
  flex-wrap: wrap;
  gap: 6px;
}

.config-library-card-metrics {
  flex: none;
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  margin-left: auto;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
}

.config-library-card-metric {
  display: inline-flex;
  align-items: center;
  gap: 3px;
}

.config-library-card-metric-icon {
  width: 14px;
  height: 14px;
  display: block;
  color: rgba(91, 104, 121, 0.82);
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.config-library-chip {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 3px 8px;
  border-radius: 999px;
  border: 1px solid rgba(229, 115, 115, 0.22);
  background: rgba(229, 115, 115, 0.08);
  color: var(--muted);
  font-size: 12px;
  font-weight: 600;
}

.config-library-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 2px;
}

.config-library-card-actions button {
  min-height: 34px;
  padding: 8px 12px;
}

.config-library-card-actions .secondary-action {
  background: var(--surface);
  color: var(--text);
  border-color: var(--border-strong);
}

.config-library-card-actions .secondary-action:hover:not(:disabled) {
  background: var(--surface-strong);
  color: var(--text);
  border-color: var(--accent);
}

.config-library-pending-list {
  display: grid;
  gap: 10px;
}

.config-library-pending-card {
  display: grid;
  gap: 8px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--surface);
}

.config-library-pending-card h4 {
  margin: 0;
  font-size: 15px;
  line-height: 1.35;
}

.config-library-pending-card[data-status="approved"] {
  border-color: rgba(56, 130, 103, 0.22);
  background: rgba(246, 255, 251, 0.74);
}

.config-library-pending-card[data-status="rejected"] {
  border-color: rgba(199, 76, 76, 0.22);
  background: rgba(255, 246, 246, 0.74);
}

.config-library-review-history {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}

.config-library-review-history:empty {
  display: none;
}

.config-library-review-history-card {
  display: grid;
  gap: 8px;
  padding: 12px;
  border: 1px solid rgba(229, 115, 115, 0.16);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.7);
}

.config-library-review-history-card h4,
.config-library-review-history-card p {
  margin: 0;
}

.config-library-review-history-list {
  display: grid;
  gap: 6px;
}

.config-library-review-history-item {
  display: grid;
  gap: 3px;
  padding: 8px 10px;
  border-radius: 10px;
  background: rgba(255, 248, 248, 0.72);
  color: var(--muted);
  font-size: 13px;
}

.config-library-review-history-item strong {
  color: var(--text);
}

.config-review-page {
  min-height: 100vh;
}

.config-review-shell {
  width: calc(100% - 48px);
  max-width: 1320px;
  margin: 0 auto;
  padding: 32px 0 56px;
}

.config-review-panel {
  display: grid;
  gap: 16px;
  padding: 26px 28px;
}

.config-review-panel h1 {
  margin: 0;
  font-size: 30px;
  line-height: 1.2;
}

.admin-page-header {
  align-items: flex-start;
  gap: 18px;
}

.admin-page-header .eyebrow {
  margin-bottom: 6px;
}

.admin-page-topbar {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
}

.admin-page-nav {
  position: relative;
  z-index: 5;
  flex: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 4px;
  border: 1px solid rgba(229, 115, 115, 0.16);
  border-radius: 16px;
  background: rgba(255, 247, 247, 0.76);
}

.admin-page-nav a,
.admin-nav-more summary {
  min-height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 7px 14px;
  border-radius: 12px;
  color: var(--muted);
  font-size: 14px;
  font-weight: 850;
  text-decoration: none;
  white-space: nowrap;
  cursor: pointer;
  pointer-events: auto;
}

.admin-page-nav a:hover,
.admin-page-nav a:focus-visible,
.admin-nav-more summary:hover,
.admin-nav-more summary:focus-visible {
  color: var(--accent-strong);
  background: rgba(229, 115, 115, 0.08);
  outline: none;
}

.admin-page-nav a.active,
.admin-nav-more summary.active {
  color: var(--accent-strong);
  background: #fff;
  box-shadow: 0 6px 16px rgba(229, 115, 115, 0.12);
}

.admin-nav-more {
  position: relative;
}

.admin-nav-more summary {
  list-style: none;
}

.admin-nav-more summary::-webkit-details-marker {
  display: none;
}

.admin-nav-more-menu {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  z-index: 12;
  display: grid;
  gap: 6px;
  min-width: 132px;
  padding: 8px;
  border: 1px solid rgba(229, 115, 115, 0.2);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 18px 42px rgba(102, 62, 62, 0.16);
}

.admin-nav-more:not([open]) .admin-nav-more-menu {
  display: none;
}

.admin-nav-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  margin-left: 6px;
  padding: 0 6px;
  border-radius: 999px;
  background: var(--accent);
  color: #fff;
  font-size: 11px;
  font-weight: 900;
}

.admin-logout-btn {
  min-height: 46px;
  padding: 10px 18px;
  border: 1px solid rgba(229, 115, 115, 0.24);
  border-radius: 16px;
  background: #fff2f2;
  color: var(--muted);
  font-size: 14px;
  font-weight: 850;
  box-shadow: none;
}

.admin-logout-btn:hover:not(:disabled),
.admin-logout-btn:focus-visible {
  border-color: rgba(229, 115, 115, 0.44);
  color: var(--accent-strong);
  outline: none;
}

.admin-page-actions {
  justify-content: flex-end;
  margin-top: -6px;
}

.admin-dashboard-panel {
  min-height: auto;
}

.admin-dashboard-login {
  display: grid;
  grid-template-columns: minmax(260px, 420px) auto;
  gap: 12px;
  align-items: center;
}

.admin-dashboard-login input {
  width: 100%;
}

.admin-dashboard-login button {
  min-height: 48px;
  padding: 10px 20px;
  border: 1px solid rgba(229, 115, 115, 0.26);
  border-radius: 16px;
  background: #fff2f2;
  color: var(--accent-strong);
  font-weight: 900;
  box-shadow: none;
}

.admin-dashboard-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 14px;
}

.admin-dashboard-card {
  min-width: 0;
  display: grid;
  gap: 12px;
  padding: 18px;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 16px 40px rgba(102, 62, 62, 0.08);
}

.admin-dashboard-card span {
  color: var(--muted);
  font-size: 14px;
  font-weight: 850;
}

.admin-dashboard-card strong {
  color: var(--text);
  font-size: 34px;
  line-height: 1;
}

.admin-dashboard-card small {
  min-height: 18px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 750;
  line-height: 1.4;
}

.admin-dashboard-card a {
  justify-self: start;
  color: var(--accent-strong);
  font-size: 14px;
  font-weight: 900;
  text-decoration: none;
}

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

.admin-dashboard-section {
  min-width: 0;
  display: grid;
  align-content: start;
  gap: 18px;
  padding: 22px;
  border: 1px solid var(--border);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 18px 44px rgba(102, 62, 62, 0.08);
}

.admin-dashboard-section-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.admin-dashboard-section-head span {
  color: var(--text);
  font-size: 20px;
  font-weight: 950;
}

.admin-dashboard-section-head strong {
  color: var(--accent-strong);
  font-size: 42px;
  line-height: 0.95;
}

.admin-dashboard-section p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  font-weight: 750;
  line-height: 1.55;
}

.admin-dashboard-metric-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(132px, 1fr));
  gap: 10px;
}

.admin-dashboard-metric-row > div,
.admin-dashboard-detail-grid small {
  min-width: 0;
  display: grid;
  gap: 5px;
  padding: 12px;
  border: 1px solid rgba(229, 115, 115, 0.14);
  border-radius: 14px;
  background: rgba(255, 247, 247, 0.66);
}

.admin-dashboard-metric-row span,
.admin-dashboard-detail-grid small {
  color: var(--muted);
  font-size: 13px;
  font-weight: 850;
}

.admin-dashboard-metric-row strong,
.admin-dashboard-detail-grid b {
  color: var(--text);
  font-size: 24px;
  line-height: 1;
}

.admin-dashboard-metric-row small,
.admin-dashboard-detail-grid span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 750;
  line-height: 1.35;
}

.admin-dashboard-detail-grid {
  display: grid;
  gap: 10px;
}

.admin-dashboard-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.admin-dashboard-actions a {
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 14px;
  border: 1px solid rgba(229, 115, 115, 0.22);
  border-radius: 14px;
  background: #fff2f2;
  color: var(--accent-strong);
  font-size: 14px;
  font-weight: 900;
  text-decoration: none;
  box-shadow: none;
}

.admin-dashboard-actions a:hover,
.admin-dashboard-actions a:focus-visible {
  border-color: rgba(229, 115, 115, 0.44);
  outline: none;
}

.resource-admin-panel {
  min-height: auto;
}

.resource-admin-token-row {
  display: grid;
  grid-template-columns: minmax(240px, 420px) auto;
  gap: 12px;
  align-items: center;
}

.resource-admin-token-row input {
  width: 100%;
}

.resource-admin-token-row button,
.resource-admin-card-head button,
.resource-admin-item-actions button {
  min-height: 42px;
  padding: 8px 16px;
  border: 1px solid rgba(229, 115, 115, 0.24);
  border-radius: 14px;
  background: #fff2f2;
  color: var(--accent-strong);
  font-weight: 850;
  box-shadow: none;
}

.resource-admin-card {
  display: grid;
  gap: 16px;
  padding: 20px;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 16px 40px rgba(102, 62, 62, 0.08);
}

.resource-admin-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.resource-admin-card h2 {
  margin: 0;
  font-size: 22px;
}

.resource-admin-form {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.resource-admin-form label {
  min-width: 0;
  display: grid;
  gap: 8px;
}

.resource-admin-form label > span,
.resource-admin-list-filter {
  color: var(--muted);
  font-size: 13px;
  font-weight: 850;
}

.resource-admin-form :is(input, select, textarea) {
  width: 100%;
}

.resource-admin-wide {
  grid-column: 1 / -1;
}

.resource-admin-check {
  grid-column: 1 / -1;
  display: inline-flex !important;
  grid-auto-flow: column;
  justify-content: start;
  align-items: center;
}

.resource-admin-check input {
  width: auto;
}

.resource-admin-list-filter {
  display: flex;
  gap: 10px;
}

.resource-admin-list-filter select {
  min-width: 130px;
}

.resource-admin-list {
  display: grid;
  gap: 12px;
}

.resource-admin-item {
  display: grid;
  gap: 12px;
  padding: 16px;
  border: 1px solid rgba(229, 115, 115, 0.18);
  border-radius: 16px;
  background: #fff;
}

.resource-admin-item.is-inactive {
  opacity: 0.66;
}

.resource-admin-item-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.resource-admin-item-head strong {
  display: block;
  color: var(--text);
  font-size: 18px;
  font-weight: 900;
}

.resource-admin-item-head span,
.resource-admin-item-summary {
  color: var(--muted);
  font-size: 13px;
  font-weight: 750;
}

.resource-admin-item-actions {
  display: flex;
  gap: 8px;
}

.resource-admin-files {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.resource-admin-files a {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 6px 10px;
  border: 1px solid rgba(229, 115, 115, 0.18);
  border-radius: 999px;
  color: var(--muted);
  background: #fff7f7;
  font-size: 12px;
  font-weight: 850;
  text-decoration: none;
}

.resource-admin-empty {
  padding: 28px;
  border: 1px dashed rgba(229, 115, 115, 0.28);
  border-radius: 16px;
  color: var(--muted);
  text-align: center;
  font-weight: 800;
}

.backup-admin-panel {
  min-height: auto;
}

.backup-admin-toolbar {
  display: grid;
  grid-template-columns: minmax(220px, 360px) auto auto;
  gap: 10px;
  align-items: center;
}

.backup-admin-toolbar input,
.backup-admin-card input[type="file"] {
  min-width: 0;
  width: 100%;
}

.backup-admin-toolbar button,
.backup-admin-card button {
  min-height: 42px;
  padding: 8px 16px;
  border: 1px solid rgba(229, 115, 115, 0.24);
  border-radius: 14px;
  background: #fff2f2;
  color: var(--accent-strong);
  font-weight: 850;
  box-shadow: none;
}

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

.backup-admin-card {
  min-width: 0;
  display: grid;
  gap: 12px;
  padding: 18px;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 16px 40px rgba(102, 62, 62, 0.08);
}

.backup-admin-card h2 {
  margin: 0;
  font-size: 19px;
}

.backup-admin-counts {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.backup-admin-counts span,
.backup-admin-diffs span,
.backup-admin-scope-grid label {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-height: 38px;
  padding: 8px 10px;
  border: 1px solid rgba(229, 205, 205, 0.72);
  border-radius: 12px;
  background: rgba(255, 250, 250, 0.78);
  color: var(--muted);
  font-weight: 800;
}

.backup-admin-counts strong {
  color: var(--text);
}

.backup-admin-diffs {
  display: grid;
  gap: 8px;
  max-height: 220px;
  overflow: auto;
}

.backup-admin-scope-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
}

.backup-admin-scope-grid label {
  justify-content: center;
  cursor: pointer;
}

.backup-admin-scope-grid input {
  accent-color: var(--accent);
}

.knowledge-admin-toolbar {
  display: grid;
  grid-template-columns: minmax(180px, 280px) minmax(260px, 1fr) auto auto;
  gap: 10px;
  align-items: center;
}

.rule-admin-toolbar {
  grid-template-columns: minmax(160px, 240px) minmax(170px, 220px) minmax(220px, 1fr) auto auto;
}

.knowledge-admin-toolbar input {
  min-width: 0;
  width: 100%;
}

.knowledge-admin-toolbar select {
  min-width: 0;
  width: 100%;
}

.knowledge-admin-toolbar button,
.knowledge-admin-list-head button,
.knowledge-admin-editor-head button {
  min-height: 40px;
  padding: 8px 14px;
  border: 1px solid rgba(229, 115, 115, 0.24);
  border-radius: 14px;
  background: #fff2f2;
  color: var(--accent-strong);
  font-weight: 850;
  box-shadow: none;
}

.knowledge-admin-toolbar button:hover:not(:disabled),
.knowledge-admin-list-head button:hover:not(:disabled),
.knowledge-admin-editor-head button:hover:not(:disabled) {
  border-color: rgba(229, 115, 115, 0.5);
}

.knowledge-admin-layout {
  display: grid;
  grid-template-columns: minmax(260px, 340px) minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}

.knowledge-admin-list-panel,
.knowledge-admin-editor {
  min-width: 0;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.82);
}

.knowledge-admin-list-panel {
  overflow: hidden;
}

.knowledge-admin-list-head,
.knowledge-admin-editor-head {
  min-height: 62px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  border-bottom: 1px solid rgba(229, 205, 205, 0.72);
}

.knowledge-admin-list-head strong,
.knowledge-admin-editor-head strong {
  font-size: 18px;
}

.knowledge-admin-list {
  max-height: 650px;
  overflow: auto;
  padding: 10px;
}

.knowledge-admin-list-item {
  width: 100%;
  display: grid;
  gap: 4px;
  min-height: 58px;
  margin: 0 0 8px;
  padding: 10px 12px;
  border: 1px solid rgba(229, 205, 205, 0.76);
  border-radius: 14px;
  background: #fff;
  color: var(--text);
  text-align: left;
  box-shadow: none;
}

.knowledge-admin-list-item strong,
.knowledge-admin-list-item span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.knowledge-admin-list-item span {
  color: var(--muted);
  font-size: 13px;
}

.knowledge-admin-list-item.active {
  border-color: var(--accent);
  background: #fff2f2;
  color: var(--accent-strong);
}

.knowledge-admin-editor {
  display: grid;
  gap: 14px;
  padding-bottom: 16px;
}

.knowledge-admin-form-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  padding: 16px 16px 0;
}

.rule-admin-form-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  padding: 16px 16px 0;
}

.knowledge-admin-gate.rule-admin-global {
  margin: 0;
}

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

.knowledge-admin-field {
  display: grid;
  gap: 8px;
  padding: 0 16px;
}

.knowledge-admin-form-grid label,
.rule-admin-form-grid label,
.knowledge-admin-check {
  display: grid;
  gap: 8px;
  min-width: 0;
}

.knowledge-admin-form-grid label > span,
.rule-admin-form-grid label > span,
.knowledge-admin-field > span,
.knowledge-admin-gate summary {
  color: var(--muted);
  font-size: 13px;
  font-weight: 850;
}

.knowledge-admin-check {
  align-content: end;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  min-height: 76px;
}

.knowledge-admin-check input {
  width: 18px;
  height: 18px;
}

.knowledge-admin-field textarea {
  width: 100%;
  min-width: 0;
  resize: vertical;
  font-family: inherit;
  line-height: 1.55;
}

.knowledge-admin-gate {
  margin: 2px 16px 0;
  padding: 12px;
  border: 1px solid rgba(229, 205, 205, 0.72);
  border-radius: 14px;
  background: #fffafa;
}

.knowledge-admin-gate summary {
  cursor: pointer;
}

.knowledge-admin-gate .knowledge-admin-field {
  padding: 12px 0 0;
}

.admin-tool-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(260px, 0.8fr);
  gap: 12px;
}

.rule-admin-test-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  margin-top: 12px;
}

.rule-admin-test-grid input {
  min-width: 0;
  width: 100%;
}

.rule-admin-test-grid button,
.rule-admin-keyword-actions button,
.admin-history-item button {
  min-height: 38px;
  padding: 7px 13px;
  border: 1px solid rgba(229, 115, 115, 0.24);
  border-radius: 13px;
  background: #fff2f2;
  color: var(--accent-strong);
  font-weight: 850;
  box-shadow: none;
}

.admin-json-preview {
  overflow: auto;
  max-height: 260px;
  margin: 12px 0 0;
  padding: 12px;
  border: 1px solid rgba(229, 205, 205, 0.72);
  border-radius: 12px;
  background: #fff;
  color: var(--text);
  font-size: 12px;
  line-height: 1.55;
  white-space: pre-wrap;
}

.admin-history-list {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}

.admin-history-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 9px 10px;
  border: 1px solid rgba(229, 205, 205, 0.72);
  border-radius: 12px;
  background: #fff;
}

.admin-history-item div {
  min-width: 0;
  display: grid;
  gap: 3px;
}

.admin-history-item strong,
.admin-history-item span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.admin-history-item span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 750;
}

.rule-admin-keyword-actions {
  display: flex;
  justify-content: flex-end;
  padding: 0 16px;
}

.config-review-toolbar {
  display: grid;
  grid-template-columns: minmax(190px, 260px) 140px 150px 150px minmax(240px, 1fr) auto auto;
  gap: 10px;
  align-items: center;
}

.config-review-toolbar-main {
  grid-template-columns: minmax(190px, 260px) minmax(240px, 1fr) auto;
}

.config-review-toolbar input,
.config-review-toolbar select {
  min-width: 0;
  width: 100%;
}

.config-review-maintenance,
.automation-admin-filter-panel {
  border: 1px solid rgba(229, 205, 205, 0.72);
  border-radius: 14px;
  background: rgba(255, 246, 246, 0.6);
}

.config-review-maintenance summary,
.automation-admin-filter-panel summary {
  cursor: pointer;
  padding: 10px 14px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 900;
}

.config-review-maintenance-grid,
.automation-admin-filter-grid {
  display: grid;
  gap: 10px;
  padding: 0 14px 14px;
}

.config-review-maintenance-grid {
  grid-template-columns: 140px 150px 150px auto;
}

.config-review-maintenance-grid select,
.automation-admin-filter-grid select {
  min-width: 0;
  width: 100%;
}

.config-review-pager {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.config-review-pager button {
  min-height: 36px;
  padding: 8px 12px;
  border-radius: 12px;
  background: rgba(229, 115, 115, 0.07);
  border-color: rgba(229, 115, 115, 0.2);
  color: var(--accent-strong);
  font-weight: 800;
}

.config-review-panel .config-library-pending-list {
  grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
  gap: 12px;
  align-items: stretch;
}

.config-review-panel .config-library-empty {
  min-height: 120px;
}

.config-review-panel .config-library-pending-card {
  min-width: 0;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 12px;
  min-height: 186px;
  padding: 18px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 16px 34px rgba(141, 73, 73, 0.08);
}

.config-review-card-head {
  min-width: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: start;
}

.config-review-card-title {
  min-width: 0;
  display: grid;
  gap: 6px;
}

.config-review-card-title h4 {
  font-size: 19px;
  line-height: 1.25;
}

.config-review-card-badges {
  min-width: 0;
  display: inline-flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 7px;
}

.config-review-status-chip[data-status="pending"] {
  color: var(--accent-strong);
  border-color: rgba(229, 115, 115, 0.32);
  background: rgba(229, 115, 115, 0.08);
}

.config-review-status-chip[data-status="approved"] {
  color: #2b7a62;
  border-color: rgba(56, 130, 103, 0.24);
  background: rgba(56, 130, 103, 0.08);
}

.config-review-status-chip[data-status="rejected"] {
  color: var(--danger);
  border-color: rgba(199, 76, 76, 0.24);
  background: rgba(199, 76, 76, 0.08);
}

.config-review-visibility-chip[data-visibility="private"] {
  color: #6b7584;
  background: rgba(139, 152, 170, 0.08);
}

.config-review-visibility-chip[data-visibility="unlisted"] {
  color: #8a5a28;
  background: rgba(196, 139, 68, 0.08);
}

.config-review-deleted-chip[data-deleted="deleted"] {
  color: var(--danger);
  border-color: rgba(199, 76, 76, 0.24);
  background: rgba(199, 76, 76, 0.08);
}

.config-audit-card {
  display: grid;
  gap: 10px;
  padding: 16px;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.78);
}

.config-audit-card h4 {
  margin: 0;
  font-size: 18px;
}

.config-audit-summary,
.config-audit-issues {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.config-audit-summary span,
.config-audit-issue {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 4px 10px;
  border: 1px solid rgba(229, 205, 205, 0.72);
  border-radius: 999px;
  background: #fffafa;
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
}

.config-audit-summary span[data-severity="error"],
.config-audit-issue[data-severity="error"] {
  color: var(--danger);
  border-color: rgba(199, 76, 76, 0.28);
  background: rgba(199, 76, 76, 0.08);
}

.config-audit-summary span[data-severity="warning"],
.config-audit-issue[data-severity="warning"] {
  color: #a56825;
  border-color: rgba(196, 139, 68, 0.28);
  background: rgba(196, 139, 68, 0.08);
}

.config-audit-list {
  display: grid;
  gap: 8px;
  max-height: 320px;
  overflow: auto;
}

.config-audit-item {
  display: grid;
  gap: 7px;
  padding: 10px;
  border: 1px solid rgba(229, 205, 205, 0.6);
  border-radius: 12px;
  background: rgba(255, 250, 250, 0.78);
}

.config-audit-item strong {
  font-size: 13px;
}

.config-review-card-footer {
  min-width: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-end;
}

.config-review-panel .config-library-card-actions {
  flex: none;
  justify-content: flex-end;
  margin: 0;
}

.config-review-panel .config-library-card-actions button {
  min-width: 78px;
  min-height: 36px;
  padding: 8px 12px;
  border-radius: 12px;
  background: rgba(229, 115, 115, 0.07);
  border-color: rgba(229, 115, 115, 0.24);
  color: var(--accent-strong);
  font-size: 13px;
  font-weight: 800;
  box-shadow: none;
}

.config-review-panel .config-library-card-actions button:not(:disabled):hover,
.config-review-panel .config-library-card-actions button:focus-visible {
  background: rgba(229, 115, 115, 0.12);
  border-color: rgba(229, 115, 115, 0.42);
  color: var(--accent-strong);
  box-shadow: 0 8px 18px rgba(229, 115, 115, 0.12);
}

.config-review-panel .config-library-card-actions button:disabled {
  opacity: 1;
  color: rgba(214, 90, 90, 0.42);
  border-color: rgba(229, 115, 115, 0.12);
  background: rgba(229, 115, 115, 0.05);
}

.config-review-panel .config-preview-dialog {
  width: min(960px, calc(100vw - 36px));
  height: min(860px, calc(100vh - 36px));
}

@media (max-width: 760px) {
  .config-review-shell {
    width: calc(100% - 24px);
    padding: 18px 0 36px;
  }

  .config-review-panel {
    padding: 18px;
    border-radius: 18px;
  }

  .config-review-toolbar {
    grid-template-columns: 1fr;
  }

  .config-review-maintenance-grid,
  .automation-admin-filter-grid {
    grid-template-columns: 1fr;
  }

  .admin-page-header {
    display: grid;
  }

  .admin-page-nav {
    width: 100%;
  }

  .admin-page-nav a {
    flex: 1 1 0;
  }

  .admin-page-actions {
    justify-content: stretch;
    margin-top: 0;
  }

  .admin-page-actions button {
    flex: 1 1 0;
  }

  .config-review-card-head {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .config-review-card-badges {
    justify-content: flex-start;
  }

  .config-review-panel .config-library-pending-list {
    grid-template-columns: minmax(0, 1fr);
  }

  .config-review-card-footer {
    align-items: stretch;
  }

  .config-review-panel .config-library-chip-list,
  .config-review-panel .config-library-card-actions {
    width: 100%;
  }

  .config-review-panel .config-library-card-actions button {
    flex: 1 1 calc(50% - 6px);
  }
}

.ai-interactions-panel {
  gap: 16px;
}

.ai-interactions-header {
  align-items: flex-start;
  gap: 16px;
}

.ai-interactions-header-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
}

.ai-interactions-header-actions button,
.ai-interactions-toolbar button,
.ai-interactions-pager button {
  min-height: 40px;
  border-radius: 14px;
  background: #fff2f2;
  border-color: rgba(237, 112, 116, 0.36);
  color: var(--text);
  box-shadow: none;
}

.ai-interactions-header-actions button:hover:not(:disabled),
.ai-interactions-toolbar button:hover:not(:disabled),
.ai-interactions-pager button:hover:not(:disabled) {
  border-color: rgba(237, 112, 116, 0.72);
  color: #d65358;
}

.ai-interactions-toolbar {
  display: grid;
  grid-template-columns: 210px minmax(240px, 1fr) 130px 110px 132px 124px 86px;
  gap: 10px;
  align-items: center;
}

.ai-interactions-toolbar input,
.ai-interactions-toolbar select {
  min-width: 0;
  width: 100%;
}

.ai-interactions-stats {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 10px;
}

.ai-interactions-stat-card,
.ai-interactions-group,
.ai-interactions-item {
  border: 1px solid var(--border);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 16px 34px rgba(141, 73, 73, 0.08);
}

.ai-interactions-stat-card {
  padding: 14px 16px;
}

.ai-interactions-stat-card span {
  display: block;
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.ai-interactions-stat-card strong {
  display: block;
  margin-top: 6px;
  font-size: 24px;
  line-height: 1.1;
}

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

.ai-interactions-group {
  padding: 14px;
}

.ai-interactions-group h2 {
  margin: 0 0 10px;
  font-size: 16px;
}

.ai-interactions-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.ai-interactions-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-height: 28px;
  padding: 4px 10px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: #fffafa;
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.ai-interactions-chip b {
  color: #d65358;
}

.ai-interactions-muted {
  color: var(--muted);
  font-size: 13px;
}

.ai-interactions-top-requests ol {
  display: grid;
  gap: 7px;
  margin: 0;
  padding-left: 20px;
}

.ai-interactions-top-requests li {
  color: var(--muted);
}

.ai-interactions-top-requests li span {
  color: var(--text);
}

.ai-interactions-top-requests li b {
  margin-left: 8px;
  color: #d65358;
}

.automation-admin-panel {
  gap: 16px;
}

.automation-admin-toolbar {
  display: grid;
  grid-template-columns: minmax(220px, 360px) 120px 130px 92px;
  gap: 10px;
  align-items: center;
}

.automation-admin-toolbar-main {
  grid-template-columns: minmax(220px, 360px) auto;
  justify-content: start;
}

.automation-admin-toolbar input,
.automation-admin-toolbar select {
  min-width: 0;
  width: 100%;
}

.automation-admin-filter-grid {
  grid-template-columns: 140px 150px;
  justify-content: start;
}

.automation-admin-toolbar button,
.automation-admin-pager button {
  min-height: 40px;
  border-radius: 14px;
  background: #fff2f2;
  border-color: rgba(237, 112, 116, 0.36);
  color: var(--text);
  box-shadow: none;
}

.automation-admin-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.automation-admin-summary-card,
.automation-admin-item {
  border: 1px solid var(--border);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 16px 34px rgba(141, 73, 73, 0.08);
}

.automation-admin-summary-card {
  padding: 14px 16px;
}

.automation-admin-summary-card span {
  display: block;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.automation-admin-summary-card strong {
  display: block;
  margin-top: 6px;
  color: var(--text);
  font-size: 24px;
  line-height: 1.1;
}

.automation-admin-list {
  display: grid;
  gap: 12px;
}

.automation-admin-item {
  display: grid;
  gap: 12px;
  padding: 16px;
}

.automation-admin-item.is-error {
  background: #fff7f5;
}

.automation-admin-item-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
}

.automation-admin-item-head strong,
.automation-admin-item-head span {
  display: block;
}

.automation-admin-item-head span {
  margin-top: 4px;
  color: var(--muted);
  font-size: 13px;
}

.automation-admin-badges {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 6px;
}

.automation-admin-badges span {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  padding: 3px 9px;
  border-radius: 999px;
  border: 1px solid var(--border);
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.automation-admin-badges .ok {
  color: #267a4a;
  border-color: rgba(39, 164, 92, 0.28);
  background: rgba(39, 164, 92, 0.08);
}

.automation-admin-badges .bad {
  color: #d65358;
  border-color: rgba(237, 112, 116, 0.36);
  background: #fff2f2;
}

.automation-admin-run-summary {
  margin: 0;
  color: var(--muted);
  font-weight: 800;
}

.automation-admin-metric-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.automation-admin-metric-list span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 28px;
  padding: 4px 10px;
  border: 1px solid rgba(229, 115, 115, 0.18);
  border-radius: 999px;
  background: rgba(229, 115, 115, 0.06);
  color: var(--accent-strong);
  font-size: 12px;
  font-weight: 900;
}

.automation-admin-metric-list b {
  color: var(--muted);
}

.automation-admin-human.is-empty {
  border-style: dashed;
  background: rgba(255, 255, 255, 0.55);
}

.automation-admin-human p {
  margin: 0;
  color: var(--muted);
  font-weight: 800;
}

.automation-admin-item section {
  padding: 12px;
  border: 1px solid rgba(229, 205, 205, 0.72);
  border-radius: 12px;
  background: #fff;
}

.automation-admin-item h3 {
  margin: 0 0 8px;
  color: var(--muted);
  font-size: 13px;
}

.automation-admin-item ul {
  display: grid;
  gap: 6px;
  margin: 0;
  padding-left: 20px;
}

.automation-admin-details {
  border: 1px solid rgba(229, 205, 205, 0.72);
  border-radius: 12px;
  background: #fff;
}

.automation-admin-details summary {
  cursor: pointer;
  padding: 10px 12px;
  color: var(--accent-strong);
  font-weight: 900;
}

.automation-admin-details pre {
  max-height: 420px;
  margin: 0;
  padding: 12px;
  overflow: auto;
  border-top: 1px solid rgba(229, 205, 205, 0.72);
  color: #233142;
  font-size: 12px;
  line-height: 1.45;
  white-space: pre-wrap;
}

.ai-interactions-list {
  display: grid;
  gap: 12px;
}

.ai-interactions-review-guide {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 12px;
  margin: 12px 0 14px;
  padding: 12px 14px;
  border: 1px solid rgba(229, 205, 205, 0.72);
  border-radius: 14px;
  background: rgba(255, 247, 247, 0.72);
  color: var(--muted);
  font-size: 13px;
  line-height: 1.55;
}

.ai-interactions-review-guide strong {
  color: var(--text);
  font-size: 14px;
}

.ai-interactions-review-guide span {
  display: inline-flex;
  align-items: center;
}

.ai-interactions-item {
  padding: 16px;
}

.ai-interactions-item.is-error {
  background: #fff7f5;
}

.ai-interactions-item-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
}

.ai-interactions-item-head strong,
.ai-interactions-item-head span {
  display: block;
}

.ai-interactions-item-head span {
  margin-top: 4px;
  color: var(--muted);
  font-size: 13px;
}

.ai-interactions-badges {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 6px;
}

.ai-interactions-badges span {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  padding: 3px 9px;
  border-radius: 999px;
  border: 1px solid var(--border);
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.ai-interactions-badges .ok {
  color: #267a4a;
  border-color: rgba(39, 164, 92, 0.28);
  background: rgba(39, 164, 92, 0.08);
}

.ai-interactions-badges .bad {
  color: #d65358;
  border-color: rgba(237, 112, 116, 0.36);
  background: #fff2f2;
}

.ai-interactions-badges .admin-status {
  color: var(--accent-strong);
  border-color: rgba(237, 112, 116, 0.3);
  background: rgba(229, 115, 115, 0.08);
}

.ai-interactions-qa {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 14px;
}

.ai-interactions-qa section {
  min-width: 0;
  padding: 12px;
  border: 1px solid rgba(229, 205, 205, 0.72);
  border-radius: 12px;
  background: #fff;
}

.ai-interactions-qa h3 {
  margin: 0 0 8px;
  color: var(--muted);
  font-size: 13px;
}

.ai-interactions-qa p {
  margin: 0;
  white-space: pre-wrap;
}

.ai-interactions-details {
  margin-top: 12px;
}

.ai-interactions-details summary {
  cursor: pointer;
  color: var(--muted);
  font-weight: 800;
}

.ai-interactions-history {
  margin-top: 12px;
  padding: 12px;
  border: 1px solid rgba(229, 205, 205, 0.72);
  border-radius: 12px;
  background: rgba(255, 247, 247, 0.72);
}

.ai-interactions-history h3 {
  margin: 0 0 8px;
  font-size: 13px;
  color: var(--muted);
}

.ai-interactions-history ol {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.ai-interactions-history li {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  gap: 8px;
  align-items: start;
}

.ai-interactions-history b {
  color: var(--muted);
  font-size: 12px;
}

.ai-interactions-history span {
  overflow-wrap: anywhere;
}

.ai-interactions-details dl {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin: 10px 0;
}

.ai-interactions-details dl div {
  min-width: 0;
  padding: 8px;
  border: 1px solid rgba(229, 205, 205, 0.72);
  border-radius: 10px;
}

.ai-interactions-details dt {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.ai-interactions-details dd {
  margin: 3px 0 0;
  overflow-wrap: anywhere;
}

.ai-interactions-details pre {
  overflow: auto;
  max-height: 240px;
  margin: 0;
  padding: 12px;
  border-radius: 12px;
  background: #101820;
  color: #ecf3f8;
  font-size: 12px;
}

.ai-interactions-status-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px 14px;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid rgba(229, 205, 205, 0.5);
}

.ai-interactions-action-group {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
}

.ai-interactions-action-group > span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
}

.ai-interactions-status-action {
  min-height: 34px;
  padding: 7px 12px;
  border: 1px solid rgba(229, 115, 115, 0.22);
  border-radius: 12px;
  background: #fff2f2;
  color: var(--accent-strong);
  font-size: 13px;
  font-weight: 850;
  box-shadow: none;
}

.ai-interactions-status-action.is-primary {
  border-color: rgba(229, 115, 115, 0.54);
  background: rgba(229, 115, 115, 0.14);
  color: var(--accent-strong);
}

.ai-interactions-status-action:hover:not(:disabled),
.ai-interactions-status-action:focus-visible {
  border-color: rgba(229, 115, 115, 0.5);
  outline: none;
}

.ai-interactions-status-action.active,
.ai-interactions-status-action:disabled {
  opacity: 1;
  color: rgba(105, 118, 136, 0.76);
  border-color: rgba(229, 205, 205, 0.64);
  background: rgba(255, 255, 255, 0.74);
}

@media (max-width: 760px) {
  .config-review-shell {
    width: calc(100% - 20px);
    padding-top: 18px;
  }

  .config-review-panel {
    padding: 16px;
  }

  .config-review-toolbar {
    grid-template-columns: 1fr;
  }

  .admin-page-topbar,
  .admin-page-nav,
  .admin-dashboard-login {
    width: 100%;
  }

  .admin-page-nav {
    overflow-x: auto;
  }

  .admin-nav-more {
    flex: none;
  }

  .admin-nav-more-menu {
    position: fixed;
    top: auto;
    right: 14px;
    left: 14px;
    width: auto;
  }

  .admin-logout-btn,
  .admin-dashboard-login button {
    width: 100%;
  }

  .admin-dashboard-login,
  .admin-dashboard-cards,
  .admin-dashboard-sections,
  .knowledge-admin-toolbar,
  .knowledge-admin-layout,
  .knowledge-admin-form-grid,
  .rule-admin-toolbar,
  .rule-admin-form-grid,
  .rule-admin-global-grid {
    grid-template-columns: 1fr;
  }

  .knowledge-admin-list {
    max-height: 360px;
  }

  .ai-interactions-header {
    display: grid;
  }

  .ai-interactions-header-actions,
  .ai-interactions-toolbar {
    grid-template-columns: 1fr;
    justify-content: stretch;
  }

  .ai-interactions-header-actions button {
    width: 100%;
  }

  .ai-interactions-stats,
  .ai-interactions-groups,
  .ai-interactions-qa,
  .ai-interactions-details dl {
    grid-template-columns: 1fr;
  }

  .ai-interactions-status-row,
  .ai-interactions-action-group {
    justify-content: flex-start;
  }
}

@media (max-width: 720px) {
  .config-library-header {
    grid-template-columns: 1fr;
  }

  .config-library-header-actions {
    width: 100%;
    justify-content: stretch;
  }

  .config-library-share-row,
  .config-library-filter-row {
    grid-template-columns: 1fr;
  }

  .config-library-toolbar {
    align-items: stretch;
    flex-direction: column;
  }

  .config-library-file-actions,
  .config-library-device-menu,
  .config-library-tool-panel {
    width: 100%;
  }

  .config-library-file-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .config-library-file-actions .project-config-tile {
    width: 100%;
  }

  .config-library-file-actions .project-config-message {
    grid-column: 1 / -1;
    max-width: none;
    text-align: left;
  }

  .config-library-device-menu summary,
  .config-library-tool-panel summary {
    width: 100%;
  }

  .config-library-device-row,
  .config-library-upload-popover {
    position: static;
    width: 100%;
    margin-top: 8px;
  }

  .config-library-mode-row {
    display: flex;
    width: 100%;
  }

  .config-library-mode {
    flex: 1 1 0;
  }

  .config-library-admin-grid {
    grid-template-columns: 1fr;
  }
}

.stack-list,
.key-editor-grid,
.tap-dance-grid,
.macro-grid {
  display: grid;
  gap: 14px;
}

.setting-card-header,
.key-editor-top {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
  margin-bottom: 12px;
}

.setting-caption,
.key-editor-caption,
.key-editor-code,
.td-preview,
.macro-preview {
  color: var(--muted);
  font-size: 13px;
}

.macro-storage-summary {
  margin-bottom: 14px;
}

.macro-import-preview {
  margin-bottom: 14px;
  padding: 16px;
  border-radius: 16px;
  border: 1px solid rgba(229, 115, 115, 0.12);
  background: rgba(255, 255, 255, 0.72);
}

.macro-import-preview[hidden] {
  display: none;
}

.macro-import-summary {
  display: grid;
  gap: 6px;
}

.macro-import-card {
  display: grid;
  gap: 12px;
}

.macro-import-card .chip-list {
  margin-top: 4px;
}

.macro-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: flex-end;
  margin-bottom: 12px;
}

#macro-slot-menu {
  grid-template-columns: repeat(2, 64px);
  justify-content: start;
  gap: 8px;
  padding: 5px;
  box-sizing: border-box;
  max-height: none;
  overflow: visible;
  align-content: start;
}

#macro-slot-menu .slot-menu-button {
  min-height: 34px;
  padding: 6px 8px;
  gap: 0;
  align-content: center;
  justify-items: center;
  border-radius: 12px;
}

#macro-slot-menu .slot-menu-title {
  font-size: 12px;
  text-align: center;
  white-space: nowrap;
}

#macro-slot-menu .slot-menu-meta {
  display: none;
}

.editor-split {
  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
  gap: 16px;
  align-items: start;
}

.slot-sidebar {
  padding: 16px;
  border-radius: 16px;
  border: 1px solid rgba(229, 115, 115, 0.12);
  background: rgba(255, 255, 255, 0.7);
}

.slot-sidebar-header {
  display: grid;
  gap: 6px;
  margin-bottom: 12px;
}

.slot-sidebar-header h3 {
  font-size: 15px;
}

.slot-sidebar-copy {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.5;
}

.slot-menu {
  display: grid;
  gap: 8px;
  max-height: 560px;
  overflow: auto;
}

#tap-dance-slot-menu {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  padding: 6px;
  box-sizing: border-box;
  max-height: 404px;
  align-content: start;
}

#tap-dance-slot-menu .slot-menu-button {
  min-height: 42px;
  padding: 8px 10px;
  gap: 0;
  align-content: center;
  justify-items: center;
}

#tap-dance-slot-menu .slot-menu-title {
  font-size: 13px;
  text-align: center;
  white-space: nowrap;
}

#tap-dance-slot-menu .slot-menu-meta {
  display: none;
}

.slot-menu-button {
  position: relative;
  width: 100%;
  padding: 10px 12px;
  display: grid;
  gap: 4px;
  text-align: left;
  border: 1px solid rgba(229, 115, 115, 0.16);
  background: rgba(255, 255, 255, 0.92);
  color: var(--text);
  border-radius: 12px;
  box-shadow: none;
  transform: none;
}

.slot-menu-button:hover:not(:disabled) {
  background: rgba(255, 164, 162, 0.12);
  border-color: var(--accent);
  box-shadow: 0 0 0 4px var(--accent-ring);
  transform: none;
}

.slot-menu-button[data-selected="true"] {
  background: var(--accent-soft);
  border-color: rgba(229, 115, 115, 0.24);
  box-shadow: inset 0 0 0 2px var(--accent);
  color: var(--accent);
  z-index: 1;
}

.slot-menu-button[data-selected="true"] .slot-menu-title,
.slot-menu-button[data-selected="true"] .slot-menu-meta {
  color: inherit;
}

.slot-menu-title {
  font-weight: 700;
  color: var(--text);
  white-space: normal;
  overflow-wrap: anywhere;
}

.slot-menu-meta {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
  white-space: normal;
  overflow-wrap: anywhere;
}

.slot-detail {
  min-width: 0;
  display: grid;
  gap: 14px;
}

.slot-detail-summary {
  display: grid;
  gap: 4px;
  padding: 10px 14px;
  border-radius: 14px;
  border: 1px solid rgba(229, 115, 115, 0.14);
  background: rgba(255, 255, 255, 0.68);
  color: var(--muted);
  font-size: 13px;
  line-height: 1.5;
}

.slot-detail-summary[hidden] {
  display: none !important;
}

.slot-detail-summary strong {
  color: var(--text);
  font-size: 14px;
}

.macro-toolbar label {
  min-width: 180px;
  flex: 1 1 180px;
}

.macro-top-grid {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) auto auto;
  gap: 10px;
  align-items: end;
  margin-bottom: 0;
}

.macro-top-grid .macro-name-field {
  min-width: 0;
}

.macro-mode-field {
  display: none !important;
}

.macro-top-grid .macro-export-toggle {
  min-height: 42px;
  align-self: end;
  padding: 0 2px 10px 0;
}

.macro-quick-actions {
  display: flex;
  gap: 8px;
  align-items: end;
}

.macro-quick-actions button {
  min-width: 76px;
}

.macro-builder-toolbar {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) 64px minmax(220px, 1fr) 64px;
  gap: 10px;
  align-items: end;
}

.macro-builder-toolbar label {
  min-width: 0;
}

.macro-structured-editor {
  display: grid;
  gap: 12px;
  align-content: start;
  min-width: 0;
}

.macro-template-editor {
  margin-bottom: 0;
  padding: 12px;
  border-radius: 14px;
  border: 1px dashed rgba(229, 115, 115, 0.26);
  background: rgba(255, 255, 255, 0.58);
}

.macro-header-editor {
  display: grid;
  min-width: 0;
}

.macro-playback-editor {
  display: grid;
  min-width: 0;
}

.macro-playback-editor .macro-step-detail-fields {
  padding: 0;
}

.macro-playback-note {
  margin: 0;
}

.macro-playback-grid {
  display: grid;
  gap: 10px;
}

.macro-raw-field {
  display: none !important;
}

.macro-template-editor {
  display: grid;
  min-width: 0;
}

.macro-template-panel {
  display: grid;
  gap: 10px;
}

.macro-template-note {
  margin: 0 0 10px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.macro-disclosure {
  min-width: 0;
  border: 1px solid rgba(229, 115, 115, 0.12);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.62);
}

.macro-disclosure summary {
  min-height: 38px;
  padding: 9px 12px;
  cursor: pointer;
  color: var(--text);
  font-size: 13px;
  font-weight: 750;
  list-style-position: inside;
}

.macro-disclosure[open] summary {
  border-bottom: 1px solid rgba(229, 115, 115, 0.1);
}

.macro-disclosure-body {
  padding: 10px 12px 12px;
}

.macro-empty {
  padding: 14px 16px;
  border-radius: 14px;
  border: 1px dashed var(--border-strong);
  background: rgba(255, 255, 255, 0.56);
  color: var(--muted);
  font-size: 13px;
}

.macro-step-workbench {
  display: grid;
  grid-template-columns: minmax(300px, 0.95fr) minmax(320px, 1.05fr);
  gap: 12px;
  align-items: start;
  min-width: 0;
}

.macro-step-flow-pane,
.macro-step-detail-pane {
  min-width: 0;
}

.macro-step-detail-pane {
  position: sticky;
  top: 12px;
}

.macro-step-card {
  width: 156px;
  min-width: 156px;
  padding: 5px;
  border-radius: 12px;
  border: 1px solid rgba(229, 115, 115, 0.14);
  background: rgba(255, 255, 255, 0.76);
  transition: border-color 140ms ease, background-color 140ms ease, box-shadow 140ms ease;
}

.macro-step-card:hover {
  border-color: rgba(229, 115, 115, 0.46);
  background: rgba(255, 164, 162, 0.12);
  box-shadow: 0 10px 20px rgba(229, 115, 115, 0.1);
}

.macro-step-card[data-selected="true"] {
  border-color: rgba(229, 115, 115, 0.76);
  background: var(--accent);
  box-shadow: 0 12px 24px rgba(229, 115, 115, 0.18);
}

.macro-step-flow {
  display: grid;
  gap: 8px;
  align-content: start;
  max-height: 520px;
  overflow: auto;
  padding: 4px;
  border: 1px solid rgba(229, 115, 115, 0.1);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.46);
}

.macro-step-header {
  display: flex;
  gap: 8px;
  align-items: center;
}

.macro-step-row {
  display: flex;
  align-items: stretch;
  gap: 8px;
}

.macro-step-toggle {
  display: flex;
  flex: 1 1 auto;
  min-width: 0;
  min-height: 48px;
  align-items: center;
  padding: 6px 8px;
  border: none;
  background: transparent;
  color: inherit;
  text-align: left;
  cursor: pointer;
  border-radius: 10px;
}

.macro-step-card:hover .macro-step-summary {
  color: var(--text);
}

.macro-step-card:hover .macro-step-toggle {
  background: transparent;
}

.macro-step-card[data-selected="true"] .macro-step-toggle {
  background: transparent;
  color: #fff;
}

.macro-step-summary {
  width: 100%;
  color: var(--text);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.25;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.macro-step-card[data-selected="true"] .macro-step-summary {
  color: #fff;
}

.macro-step-actions {
  display: flex;
  gap: 8px;
  flex: 0 0 auto;
  justify-content: flex-end;
}

.macro-step-actions button,
.macro-toolbar button {
  padding: 8px 12px;
}

.macro-step-action-icon {
  width: 40px;
  min-width: 40px;
  height: 40px;
  padding: 0;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  line-height: 1;
}

.macro-step-arrow,
.macro-step-turn {
  color: rgba(229, 115, 115, 0.72);
  font-size: 18px;
  line-height: 1;
  user-select: none;
}

.macro-step-arrow {
  flex: 0 0 16px;
  align-self: center;
  text-align: center;
}

.macro-step-turn {
  min-height: 16px;
  display: flex;
  align-items: center;
}

.macro-step-turn[data-side="end"] {
  justify-content: flex-end;
  padding-right: 72px;
}

.macro-step-turn[data-side="start"] {
  justify-content: flex-start;
  padding-left: 72px;
}

.macro-step-detail {
  display: grid;
  gap: 10px;
  padding: 10px;
  border-radius: 16px;
  border: 1px solid rgba(229, 115, 115, 0.18);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 18px 44px rgba(85, 42, 42, 0.08);
  min-width: 0;
}

.macro-step-detail-header {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  min-height: 54px;
  padding: 8px 10px;
  border: 1px solid rgba(229, 115, 115, 0.18);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.78);
}

.macro-step-detail-badge {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 9px;
  background: rgba(229, 115, 115, 0.1);
  color: var(--accent-hover);
  font-size: 11px;
  font-weight: 850;
  line-height: 1;
  letter-spacing: 0;
}

.macro-step-detail-copy {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.macro-step-detail-copy strong {
  overflow: hidden;
  color: var(--text);
  font-size: 13px;
  font-weight: 900;
  line-height: 1.2;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.macro-step-detail-summary {
  overflow: hidden;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.25;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.macro-step-detail-fields {
  display: grid;
  gap: 7px;
  padding: 1px 2px 1px 0;
}

.macro-step-detail-fields > label,
.macro-step-detail-fields > .field-stack,
.macro-step-detail-fields > .macro-empty {
  min-width: 0;
  padding: 8px;
  border: 1px solid rgba(176, 91, 91, 0.14);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.74);
  transition: border-color 140ms ease, background-color 140ms ease, box-shadow 140ms ease;
}

.macro-step-detail-fields > label,
.macro-step-detail-fields > .field-stack {
  display: grid;
  grid-template-columns: minmax(76px, 0.36fr) minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  min-height: 46px;
}

.macro-step-detail-fields > label:hover,
.macro-step-detail-fields > .field-stack:hover {
  border-color: rgba(229, 115, 115, 0.42);
  background: rgba(255, 246, 245, 0.94);
  box-shadow: 0 10px 22px rgba(158, 66, 66, 0.08);
}

.macro-step-detail-fields > label > span,
.macro-step-detail-fields > .field-stack > span {
  display: grid;
  place-items: center;
  align-self: center;
  min-width: 0;
  min-height: 30px;
  padding: 4px 8px;
  border-radius: 9px;
  background: rgba(229, 115, 115, 0.1);
  overflow: hidden;
  color: var(--accent-hover);
  font-size: 11px;
  font-weight: 850;
  line-height: 1.15;
  text-align: center;
  overflow-wrap: anywhere;
}

.macro-step-detail-fields input:not([type="checkbox"]),
.macro-step-detail-fields select,
.macro-step-detail-fields textarea,
.macro-step-detail-fields .keycode-picker-trigger,
.macro-step-detail-fields .macro-custom-select-trigger,
.config-custom-select .macro-custom-select-trigger,
.macro-template-inline-fields .macro-custom-select-trigger {
  min-width: 0;
  width: 100%;
  min-height: 34px;
  padding: 7px 10px;
  border: 1px solid rgba(176, 91, 91, 0.16);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.9);
}

.macro-custom-select {
  position: relative;
  min-width: 0;
}

.macro-custom-select[open] {
  z-index: 220;
}

.macro-section:has(.macro-custom-select[open]),
.setting-card:has(.macro-custom-select[open]),
.context-system-card:has(.macro-custom-select[open]),
.protocol-output-group:has(.macro-custom-select[open]),
.tap-dance-card:has(.macro-custom-select[open]),
label:has(.macro-custom-select[open]) {
  position: relative;
  z-index: 210;
}

.config-native-select {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.config-custom-select {
  width: 100%;
}

.setting-card,
.context-system-card,
.protocol-output-group,
.macro-card,
.macro-section,
.macro-builder-column,
.macro-editor-workbench,
.tap-dance-card,
.tap-dance-editor,
.tap-dance-settings-grid {
  overflow: visible;
}

.macro-custom-select summary {
  list-style: none;
}

.macro-custom-select summary::-webkit-details-marker {
  display: none;
}

.macro-custom-select-trigger {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 18px;
  gap: 8px;
  align-items: center;
  cursor: pointer;
  color: var(--text);
  font-weight: 750;
}

.macro-custom-select-trigger::after {
  content: "";
  width: 8px;
  height: 8px;
  justify-self: center;
  border-right: 2px solid var(--accent-hover);
  border-bottom: 2px solid var(--accent-hover);
  transform: translateY(-2px) rotate(45deg);
  transition: transform 140ms ease;
}

.macro-custom-select[open] .macro-custom-select-trigger {
  border-color: rgba(229, 115, 115, 0.48);
  background: rgba(255, 246, 245, 0.96);
  box-shadow: 0 0 0 3px rgba(229, 115, 115, 0.1);
}

.macro-custom-select[open] .macro-custom-select-trigger::after {
  transform: translateY(2px) rotate(225deg);
}

.macro-custom-select[data-disabled="true"] .macro-custom-select-trigger {
  cursor: not-allowed;
  opacity: 0.62;
}

.macro-custom-select-value {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.macro-custom-select-menu {
  position: absolute;
  z-index: 230;
  left: 0;
  right: 0;
  top: calc(100% + 6px);
  display: grid;
  gap: 4px;
  padding: 6px;
  border: 1px solid rgba(229, 115, 115, 0.26);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 18px 34px rgba(85, 42, 42, 0.14);
}

.project-language-custom-select .macro-custom-select-menu {
  top: auto;
  bottom: calc(100% + 6px);
}

.macro-custom-select-option {
  position: relative;
  min-height: 34px;
  padding: 7px 10px 7px 16px;
  border: 1px solid transparent;
  border-radius: 10px;
  background: transparent;
  color: var(--text);
  font-size: 13px;
  font-weight: 750;
  text-align: left;
}

.macro-custom-select-option:hover,
.macro-custom-select-option:focus-visible {
  border-color: rgba(229, 115, 115, 0.42);
  background: rgba(255, 246, 245, 0.94);
  box-shadow: 0 10px 22px rgba(158, 66, 66, 0.08);
}

.macro-step-detail-fields .keycode-picker-trigger {
  gap: 0;
}

.macro-step-kind-picker {
  z-index: 26;
}

.macro-step-kind-picker .macro-action-popover {
  right: 0;
  left: auto;
  grid-template-columns: minmax(190px, 0.9fr) minmax(250px, 1.1fr);
  width: min(600px, calc(100vw - 48px));
}

.macro-step-kind-picker .macro-action-group-btn {
  grid-template-columns: 30px minmax(0, 1fr) 24px;
}

.macro-step-kind-picker .macro-action-group-count {
  min-width: 24px;
  padding: 0;
}

.macro-step-detail-fields .macro-empty {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.macro-step-detail-fields .macro-flags {
  gap: 6px;
}

.macro-step-detail-fields .macro-flags label {
  display: inline-flex;
  min-height: 30px;
  padding: 5px 8px;
  border: 1px solid rgba(176, 91, 91, 0.12);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  font-size: 12px;
  font-weight: 700;
  line-height: 1.1;
}

.macro-step-detail-fields .macro-flags label:hover {
  border-color: rgba(229, 115, 115, 0.32);
  background: rgba(255, 246, 245, 0.86);
}

.macro-flags {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.macro-flags label {
  flex-direction: row;
  align-items: center;
  gap: 8px;
}

.macro-flags input {
  width: auto;
  margin: 0;
}

.macro-hex-details {
  margin-top: 0;
}

.macro-hex-preview {
  margin: 12px 0 0;
  padding: 12px;
  border-radius: 12px;
  background: #fff;
  border: 1px solid var(--border);
  color: var(--muted);
  font-size: 12px;
  line-height: 1.6;
  white-space: pre-wrap;
  word-break: break-word;
}

.protocol-output-groups {
  margin-top: 14px;
  display: grid;
  gap: 12px;
}

.protocol-output-layout {
  grid-template-columns: minmax(0, 1.28fr) minmax(360px, 0.88fr);
  align-items: start;
}

.ai-agent-layout {
  grid-template-columns: minmax(0, 1.16fr) minmax(360px, 0.76fr);
  align-items: stretch;
}

.ai-agent-planner-card,
.ai-agent-preview-card {
  display: grid;
  gap: 12px;
  align-content: start;
  align-self: stretch;
  height: 100%;
  min-width: 0;
}

.ai-agent-preview-card {
  width: min(100%, 520px);
  justify-self: end;
}

.ai-agent-actions {
  gap: 8px;
  justify-content: flex-start;
}

.ai-agent-actions button {
  min-height: 36px;
  white-space: nowrap;
}

.ai-agent-top-grid {
  grid-template-columns: minmax(0, 1.35fr) minmax(0, 1.15fr) minmax(0, 0.9fr);
  gap: 10px 12px;
}

.ai-agent-top-grid > label {
  min-width: 0;
}

.ai-agent-text-grid {
  display: grid;
  gap: 12px;
}

.ai-agent-text-grid > .field-stack,
.ai-agent-conversation-block,
.ai-agent-request-block {
  min-width: 0;
  width: 100%;
}

.ai-agent-conversation {
  min-height: 472px;
  max-height: 472px;
  overflow: auto;
  padding: 12px;
  border-radius: 18px;
  border: 1px solid rgba(229, 115, 115, 0.18);
  background: rgba(255, 255, 255, 0.78);
  display: grid;
  align-content: start;
  gap: 10px;
}

#ai-agent-request {
  min-height: 104px;
  max-height: 104px;
}

.ai-agent-conversation-empty {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.6;
}

.ai-agent-chat-item {
  max-width: 92%;
  display: grid;
  gap: 4px;
  padding: 10px 12px;
  border-radius: 16px;
  border: 1px solid rgba(229, 115, 115, 0.16);
  background: rgba(255, 255, 255, 0.96);
}

.ai-agent-chat-item.is-user {
  justify-self: end;
  background: rgba(229, 115, 115, 0.1);
  border-color: rgba(229, 115, 115, 0.3);
}

.ai-agent-chat-item.is-assistant {
  justify-self: start;
}

.ai-agent-chat-text {
  white-space: pre-wrap;
  word-break: break-word;
  line-height: 1.55;
}

.ai-agent-status-list {
  margin-bottom: 0;
  grid-template-columns: minmax(0, 0.78fr) minmax(0, 1.22fr);
  gap: 8px 10px;
}

.ai-agent-status-list > div {
  min-width: 0;
  align-items: flex-start;
}

.ai-agent-status-list dd {
  max-width: 100%;
  text-align: left;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.ai-agent-notes {
  margin-top: 0;
  gap: 4px;
}

.ai-agent-cli-card {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px 16px;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid rgba(229, 115, 115, 0.16);
  background: rgba(255, 164, 162, 0.08);
}

.ai-agent-cli-copy {
  display: grid;
  gap: 4px;
  min-width: 0;
  flex: 1 1 280px;
}

.ai-agent-cli-copy h4 {
  margin: 0;
  font-size: 14px;
}

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

.ai-agent-cli-meta {
  font-size: 12px;
  color: var(--muted);
}

.ai-agent-cli-link {
  flex: 0 0 auto;
  min-width: 148px;
  white-space: nowrap;
}

.ai-agent-output-block {
  gap: 8px;
}

.ai-agent-planner-card .section-message {
  margin-top: 0;
  min-height: 0;
}

.ai-agent-planner-card .section-message:empty {
  display: none;
}

.ai-agent-log {
  min-height: 140px;
  max-height: 200px;
}

.ai-agent-dev-details {
  display: grid;
  gap: 12px;
  margin-top: 4px;
  padding-top: 10px;
  border-top: 1px solid rgba(229, 115, 115, 0.16);
}

.ai-agent-dev-title {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  font-weight: 800;
}

.protocol-output-panel-actions {
  gap: 10px;
}

.protocol-output-panel-actions button {
  white-space: nowrap;
}

.protocol-output-frame-card,
.protocol-output-status-card {
  display: grid;
  gap: 14px;
  align-content: start;
}

.protocol-output-status-card {
  gap: 10px;
}

.protocol-output-top-grid {
  grid-template-columns: repeat(3, minmax(150px, 1fr));
  gap: 10px 12px;
}

.protocol-output-auto-picker {
  margin-top: 12px;
}

.protocol-output-group .compact-grid {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px 12px;
}

.protocol-output-preset-panel {
  gap: 8px;
  margin-bottom: 12px;
}

.protocol-output-preset-grid {
  display: grid;
  gap: 8px;
}

.protocol-output-mouse-preset-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.protocol-output-touch-preset-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.protocol-output-preset-button {
  min-height: 38px;
  padding: 8px 12px;
  border-radius: 12px;
  border: 1px solid rgba(229, 115, 115, 0.2);
  background: rgba(255, 255, 255, 0.88);
  color: var(--text);
  font-size: 13px;
  font-weight: 600;
  line-height: 1.2;
  transition: border-color 120ms ease, background-color 120ms ease, color 120ms ease, transform 120ms ease;
}

.protocol-output-preset-button:hover:not(:disabled) {
  border-color: rgba(229, 115, 115, 0.42);
  transform: translateY(-1px);
}

.protocol-output-preset-button.is-active {
  border-color: rgba(229, 115, 115, 0.66);
  background: rgba(229, 115, 115, 0.12);
  color: #a34545;
}

.protocol-output-preset-button:disabled {
  opacity: 0.58;
  transform: none;
}

.protocol-output-group {
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(229, 115, 115, 0.14);
  background: rgba(255, 255, 255, 0.72);
}

.protocol-output-group[hidden] {
  display: none;
}

.protocol-output-group h4 {
  margin: 0 0 10px;
  font-size: 15px;
}

.realtime-primary-note {
  margin-top: 10px;
  gap: 4px;
  font-size: 12px;
}

.realtime-advanced {
  margin-top: 12px;
  border-top: 1px solid rgba(229, 115, 115, 0.12);
  padding-top: 12px;
}

.realtime-advanced summary {
  cursor: pointer;
  color: var(--text);
  font-size: 13px;
  font-weight: 700;
  line-height: 1.35;
}

.realtime-advanced[open] summary {
  margin-bottom: 12px;
}

.realtime-advanced-body {
  display: grid;
  gap: 12px;
}

.realtime-advanced-actions {
  justify-content: end;
}

.realtime-advanced-actions button {
  min-height: 40px;
}

.protocol-output-capture {
  margin-top: 12px;
  display: grid;
  gap: 10px;
}

.protocol-output-capture-status {
  color: var(--text);
  font-size: 13px;
  font-weight: 600;
  line-height: 1.45;
}

.protocol-output-capture-input {
  width: 100%;
  min-height: 40px;
  padding: 0 12px;
  border: 1px solid var(--border-strong);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.94);
  color: var(--text);
  font-size: 12px;
  line-height: 40px;
  transition: border-color 120ms ease, box-shadow 120ms ease, background-color 120ms ease;
}

.protocol-output-capture-input:focus {
  outline: none;
  border-color: rgba(229, 115, 115, 0.58);
  box-shadow: 0 0 0 4px rgba(229, 115, 115, 0.14);
}

.protocol-output-capture-input[data-capturing="true"] {
  border-color: rgba(229, 115, 115, 0.58);
  box-shadow: 0 0 0 4px rgba(229, 115, 115, 0.14);
  background: rgba(255, 255, 255, 0.98);
}

.protocol-output-capture-input:disabled {
  opacity: 0.72;
  cursor: not-allowed;
}

.protocol-output-capture-events {
  display: flex;
  flex-wrap: nowrap;
  gap: 6px;
  overflow: hidden;
  min-height: 30px;
}

.protocol-output-capture-event {
  flex: 0 0 auto;
  width: auto;
  max-width: 84px;
  min-height: 34px;
  padding: 4px 7px;
  gap: 2px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.96);
}

.protocol-output-capture-event .keycode-picker-value {
  font-size: 11px;
  line-height: 1.05;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.protocol-output-capture-event .keycode-picker-meta {
  display: block;
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.04em;
  line-height: 1;
  text-transform: lowercase;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.protocol-output-capture-event.is-warning {
  border-color: rgba(245, 158, 11, 0.34);
  background: rgba(255, 248, 235, 0.96);
}

.protocol-output-capture-empty {
  flex: 0 0 auto;
  font-size: 12px;
  color: var(--muted);
  line-height: 1.5;
}

.protocol-output-status-list {
  margin-bottom: 0;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px 10px;
}

.protocol-output-status-list > div {
  padding: 8px 10px;
  border-radius: 14px;
  border: 1px solid rgba(229, 115, 115, 0.12);
  background: rgba(255, 255, 255, 0.78);
  flex-direction: row;
  justify-content: space-between;
  align-items: baseline;
  gap: 10px;
}

.protocol-output-status-list dt {
  font-size: 13px;
}

.protocol-output-status-list dd {
  text-align: right;
  font-size: 14px;
}

.protocol-output-status-card .field-stack {
  gap: 8px;
  padding: 8px 10px;
  border-radius: 14px;
  border: 1px solid rgba(229, 115, 115, 0.12);
  background: rgba(255, 255, 255, 0.78);
}

.protocol-output-status-card .chip-list {
  gap: 6px;
}

.protocol-output-notes {
  margin-top: 0;
  gap: 3px;
  font-size: 12px;
}

.protocol-output-status-notes {
  padding-top: 2px;
  border-top: 1px solid rgba(229, 115, 115, 0.1);
}

.indicator-color-row {
  gap: 10px;
}

.indicator-color-controls {
  display: flex;
  align-items: center;
  gap: 12px;
}

.indicator-color-input {
  width: 72px;
  min-width: 72px;
  height: 44px;
  padding: 4px;
  border-radius: 12px;
}

.range-field {
  gap: 10px;
}

.range-row {
  display: flex;
  align-items: center;
  gap: 12px;
}

.range-row input[type="range"] {
  -webkit-appearance: none;
  appearance: none;
  flex: 1 1 auto;
  height: 14px;
  padding: 0;
  border: 1px solid rgba(95, 111, 130, 0.22);
  border-radius: 999px;
  box-shadow: none;
  background: var(--range-track, linear-gradient(90deg, #edf1f6 0%, #d8dde6 100%));
  outline: none;
}

.range-row input[type="range"]::-webkit-slider-runnable-track {
  height: 14px;
  border-radius: 999px;
  background: transparent;
}

.range-row input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 20px;
  height: 20px;
  margin-top: -4px;
  border-radius: 50%;
  border: 2px solid #ffffff;
  background: var(--accent);
  box-shadow: 0 2px 8px rgba(24, 33, 43, 0.2);
}

.range-row input[type="range"]::-moz-range-track {
  height: 14px;
  border: none;
  border-radius: 999px;
  background: transparent;
}

.range-row input[type="range"]::-moz-range-thumb {
  width: 20px;
  height: 20px;
  border: 2px solid #ffffff;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 2px 8px rgba(24, 33, 43, 0.2);
}

.range-row input[type="range"]:focus-visible {
  box-shadow: 0 0 0 4px var(--accent-ring);
}

.range-value {
  min-width: 72px;
  text-align: right;
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.backlight-layout {
  display: grid;
}

.backlight-panel-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 12px;
  align-items: end;
}

.backlight-header-field {
  display: grid;
  gap: 6px;
  min-width: 260px;
}

.backlight-header-field[hidden] {
  display: none !important;
}

.backlight-header-field span {
  font-size: 12px;
  font-weight: 700;
  color: var(--muted);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.backlight-unified-card {
  display: grid;
  gap: 14px;
}

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

.backlight-footer {
  display: grid;
  gap: 12px;
  padding-top: 6px;
  border-top: 1px solid rgba(229, 115, 115, 0.12);
}

.backlight-effects-block {
  display: grid;
  gap: 10px;
}

.backlight-effect-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.backlight-effect-button {
  --backlight-preview-color: #f05f5f;
  --backlight-preview-alpha: 1;
  --backlight-preview-speed: 1.2s;
  min-height: 38px;
  padding: 8px 12px;
  border-radius: 10px;
  border: 1px solid rgba(95, 111, 130, 0.18);
  background: rgba(255, 255, 255, 0.82);
  color: var(--text);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 700;
  white-space: nowrap;
  cursor: pointer;
  transition: border-color 0.16s ease, background 0.16s ease, color 0.16s ease, box-shadow 0.16s ease;
}

.backlight-effect-button:hover:not(:disabled),
.backlight-effect-button[data-active="true"] {
  border-color: rgba(229, 115, 115, 0.46);
  background: var(--accent-soft);
  color: #7b3f3f;
  box-shadow: 0 8px 18px rgba(229, 115, 115, 0.12);
}

.backlight-effect-button:disabled {
  cursor: not-allowed;
  opacity: 0.55;
}

.backlight-effect-dot {
  width: 14px;
  height: 14px;
  flex: 0 0 14px;
  border-radius: 999px;
  background: var(--backlight-preview-color);
  opacity: var(--backlight-preview-alpha);
  box-shadow: inset 0 0 0 1px rgba(24, 33, 43, 0.18), 0 0 12px rgba(229, 115, 115, 0.22);
}

.backlight-effect-dot-off {
  background: #cfd7e2;
  opacity: 0.72;
  box-shadow: inset 0 0 0 1px rgba(24, 33, 43, 0.16);
}

.backlight-effect-dot-random {
  background: conic-gradient(from 30deg, var(--backlight-preview-color), #43d3c8, #ffd166, #ef476f, var(--backlight-preview-color));
  animation: backlight-dot-spin var(--backlight-preview-speed) linear infinite;
}

.backlight-effect-dot-reactive {
  animation: backlight-dot-pulse var(--backlight-preview-speed) ease-out infinite;
}

.backlight-effect-dot-breathing {
  animation: backlight-dot-breathe var(--backlight-preview-speed) ease-in-out infinite;
}

.backlight-effect-dot-cycle {
  background: conic-gradient(from 0deg, #ff4d4d, #ffd166, #3ddc97, #44b8ff, #b56cff, #ff4d4d);
  animation: backlight-dot-spin var(--backlight-preview-speed) linear infinite;
}

@keyframes backlight-dot-pulse {
  0% {
    transform: scale(0.78);
    opacity: 0.5;
  }
  35% {
    transform: scale(1.16);
    opacity: 1;
  }
  100% {
    transform: scale(0.82);
    opacity: 0.62;
  }
}

@keyframes backlight-dot-breathe {
  0%,
  100% {
    transform: scale(0.82);
    opacity: 0.42;
  }
  50% {
    transform: scale(1.12);
    opacity: 1;
  }
}

@keyframes backlight-dot-spin {
  to {
    transform: rotate(360deg);
  }
}

@media (prefers-reduced-motion: reduce) {
  .backlight-effect-dot {
    animation: none !important;
  }
}

.keymap-layout {
  display: block;
}

.keymap-panel-actions {
  display: flex;
  flex-wrap: nowrap;
  gap: 8px;
  align-items: end;
  justify-content: end;
  flex: 0 0 auto;
  min-width: 0;
}

.keymap-layer-select {
  display: none !important;
}

.keymap-layer-stack {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.keymap-layer-panel {
  display: grid;
  gap: 10px;
}

.keymap-layer-header {
  justify-content: space-between;
  align-items: center;
  gap: 8px 12px;
}

.keymap-panel-actions .action-select {
  display: grid;
  gap: 6px;
  min-width: 172px;
  flex: 0 0 172px;
}

.keymap-panel-actions .action-select span {
  font-size: 12px;
  font-weight: 700;
  color: var(--muted);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.keymap-panel-actions button {
  white-space: nowrap;
  min-width: 92px;
  padding-inline: 14px;
}

.keymap-panel-actions > [hidden] {
  display: none !important;
}

.keymap-layer-stack .key-editor-grid {
  grid-template-columns: repeat(auto-fit, minmax(148px, 1fr));
}

.keymap-model {
  position: relative;
  display: grid;
  grid-template-columns: minmax(96px, 0.82fr) 18px minmax(96px, 0.82fr);
  grid-template-rows: auto auto;
  gap: 12px 10px;
  align-items: center;
  justify-items: center;
  min-height: 184px;
  padding: 28px 16px 18px;
  border: 1px solid var(--line);
  border-radius: 22px;
  background:
    radial-gradient(circle at 50% 28%, rgba(255, 255, 255, 0.9), transparent 22%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(255, 248, 248, 0.72));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.keymap-model-key {
  position: relative;
  z-index: 1;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 2px;
  padding: 4px 6px;
  border: 1px solid rgba(24, 33, 43, 0.1);
  background: linear-gradient(180deg, #fff, #f8f5f5);
  color: var(--text);
  box-shadow:
    inset 0 1px 0 #fff,
    0 10px 18px rgba(23, 33, 43, 0.08);
  cursor: pointer;
  transition: border-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.keymap-model-key:hover,
.keymap-model-key:focus-visible {
  z-index: 8;
  border-color: var(--accent);
  box-shadow:
    inset 0 1px 0 #fff,
    0 0 0 4px var(--accent-soft),
    0 14px 24px rgba(23, 33, 43, 0.11);
  transform: translateY(-1px);
  outline: none;
}

.keymap-model-key:disabled {
  cursor: not-allowed;
  opacity: 0.62;
  transform: none;
}

.keymap-model-key-main {
  grid-column: 1 / -1;
  width: min(54%, 142px);
  aspect-ratio: 1 / 0.94;
  border-radius: 12px;
}

.keymap-model-key-left {
  grid-column: 1;
  grid-row: 2;
  justify-self: end;
}

.keymap-model-key-right {
  grid-column: 3;
  grid-row: 2;
  justify-self: start;
}

.keymap-model-key-left,
.keymap-model-key-right,
.keymap-model-key-extra {
  width: min(100%, 118px);
  min-height: 52px;
  border-radius: 15px;
}

.keymap-model-key-extra-1 {
  grid-column: 1;
  grid-row: 3;
}

.keymap-model-key-extra-2 {
  grid-column: 3;
  grid-row: 3;
}

.keymap-model-key-name {
  display: none;
}

.keymap-model-keycode {
  max-width: 100%;
  padding: 0 2px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 700;
  line-height: 1.12;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.keymap-td-popover {
  position: absolute;
  left: 50%;
  bottom: calc(100% + 10px);
  z-index: 20;
  width: max-content;
  min-width: 190px;
  max-width: 240px;
  display: grid;
  gap: 8px;
  padding: 11px 12px;
  border: 1px solid rgba(229, 115, 115, 0.18);
  border-radius: 16px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(255, 247, 247, 0.94)),
    radial-gradient(circle at 12% 0%, rgba(229, 115, 115, 0.14), transparent 38%);
  box-shadow:
    0 18px 44px rgba(63, 35, 35, 0.16),
    0 6px 16px rgba(229, 115, 115, 0.12);
  color: var(--text);
  opacity: 0;
  pointer-events: none;
  transform: translate(-50%, 6px) scale(0.98);
  transition: opacity 140ms ease, transform 140ms ease;
}

.keymap-td-popover::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -6px;
  width: 10px;
  height: 10px;
  border-right: 1px solid rgba(229, 115, 115, 0.18);
  border-bottom: 1px solid rgba(229, 115, 115, 0.18);
  background: rgba(255, 247, 247, 0.98);
  transform: translateX(-50%) rotate(45deg);
}

.keymap-model-key:hover .keymap-td-popover,
.keymap-model-key:focus-visible .keymap-td-popover {
  opacity: 1;
  pointer-events: auto;
  transform: translate(-50%, 0) scale(1);
}

.keymap-td-popover-title {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--accent);
  font-size: 12px;
  font-weight: 850;
  line-height: 1.2;
}

.keymap-td-popover-title::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: var(--accent);
  box-shadow: 0 0 0 4px rgba(229, 115, 115, 0.12);
}

.keymap-td-popover-rows {
  display: grid;
  gap: 5px;
}

.keymap-td-popover-row {
  position: relative;
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 8px;
  align-items: baseline;
  font-size: 12px;
  line-height: 1.28;
}

.keymap-td-popover-row.has-nested {
  cursor: default;
}

.keymap-td-popover-row.has-nested .keymap-td-popover-value {
  color: var(--accent);
}

.keymap-td-popover-row.has-nested::after {
  content: ">";
  position: absolute;
  right: -2px;
  top: 50%;
  color: var(--accent);
  font-size: 11px;
  font-weight: 850;
  transform: translateY(-50%);
}

.keymap-td-popover-label {
  color: var(--muted);
  font-weight: 750;
}

.keymap-td-popover-value {
  min-width: 0;
  color: var(--text);
  font-weight: 800;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.keymap-td-cascade-popover {
  position: absolute;
  left: calc(100% + 12px);
  top: 0;
  z-index: 24;
  width: max-content;
  min-width: 190px;
  max-width: 260px;
  display: grid;
  gap: 8px;
  padding: 11px 12px;
  border: 1px solid rgba(229, 115, 115, 0.18);
  border-radius: 16px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(255, 247, 247, 0.94)),
    radial-gradient(circle at 12% 0%, rgba(229, 115, 115, 0.14), transparent 38%);
  box-shadow:
    0 18px 44px rgba(63, 35, 35, 0.16),
    0 6px 16px rgba(229, 115, 115, 0.12);
  color: var(--text);
  opacity: 0;
  pointer-events: none;
  transform: translate(-6px, 0) scale(0.98);
  transition: opacity 140ms ease, transform 140ms ease;
}

.keymap-td-cascade-popover::before {
  content: "";
  position: absolute;
  left: -7px;
  top: 50%;
  width: 12px;
  height: 12px;
  border-left: 1px solid rgba(229, 115, 115, 0.18);
  border-bottom: 1px solid rgba(229, 115, 115, 0.18);
  background: rgba(255, 247, 247, 0.98);
  transform: translateY(-50%) rotate(45deg);
}

.keymap-model-key:hover .keymap-td-cascade-popover,
.keymap-model-key:focus-visible .keymap-td-cascade-popover {
  opacity: 1;
  pointer-events: auto;
  transform: translate(0, 0) scale(1);
}

.keymap-td-cascade-section {
  display: grid;
  gap: 8px;
}

.keymap-td-cascade-section + .keymap-td-cascade-section {
  padding-top: 8px;
  border-top: 1px solid rgba(229, 115, 115, 0.12);
}

.keymap-model-hint {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.5;
  text-align: center;
}

.keymap-compact-card {
  gap: 8px;
  padding: 12px;
}

.keymap-compact-card .key-editor-top {
  align-items: center;
}

.keymap-compact-card .key-editor-name {
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.keymap-compact-card .key-editor-caption,
.keymap-compact-card .field-stack > span,
.keymap-compact-card .keycode-picker-meta {
  display: none;
}

.keymap-compact-card .field-stack {
  gap: 0;
}

.keymap-compact-card .keycode-picker-trigger {
  min-height: 48px;
  padding: 8px 10px;
  gap: 0;
}

.keymap-compact-card .keycode-picker-value {
  font-size: 14px;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.key-editor-grid {
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
}

.key-editor-card {
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.keycode-picker-trigger {
  width: 100%;
  min-height: 62px;
  padding: 10px 12px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 4px;
  text-align: left;
  border: 1px solid var(--border-strong);
  background: #fff;
  color: var(--text);
  border-radius: 14px;
  box-shadow: none;
  transform: none;
  min-width: 0;
  white-space: normal;
}

.keycode-picker-trigger:hover:not(:disabled) {
  background: rgba(255, 164, 162, 0.12);
  border-color: var(--accent);
  box-shadow: 0 0 0 4px var(--accent-ring);
  transform: none;
}

.keycode-picker-trigger:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.keycode-picker-value {
  font-weight: 700;
  color: var(--text);
  width: 100%;
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.keycode-picker-meta {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
  width: 100%;
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.key-editor-caption {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.keycode-notes {
  margin-top: 8px;
  padding: 10px 12px;
}

.keycode-notes summary {
  cursor: pointer;
  font-weight: 700;
  color: var(--text);
  line-height: 1.3;
}

.keycode-notes[open] summary {
  margin-bottom: 8px;
}

.keycode-notes-body {
  display: grid;
  gap: 4px;
  font-size: 13px;
}

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

.tap-dance-editor {
  display: grid;
  gap: 16px;
}

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

.tap-dance-grid.single-editor-grid,
.macro-grid.single-editor-grid {
  grid-template-columns: minmax(0, 1fr);
}

.tap-dance-grid.single-editor-grid .tap-dance-card {
  width: 100%;
  max-width: none;
}

#tap-dance-panel .editor-split {
  grid-template-columns: 240px minmax(0, 1fr);
  gap: 16px;
  align-items: stretch;
  padding: 14px;
  border: 1px solid rgba(229, 115, 115, 0.1);
  border-radius: 22px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.82), rgba(255, 248, 248, 0.68)),
    radial-gradient(circle at 6% 12%, rgba(229, 115, 115, 0.08), transparent 34%);
}

#tap-dance-panel .slot-sidebar {
  padding: 14px;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  align-self: stretch;
  box-sizing: border-box;
  min-height: 100%;
  background: rgba(255, 255, 255, 0.68);
}

#tap-dance-panel .slot-sidebar-header {
  margin-bottom: 12px;
}

#tap-dance-panel .slot-detail {
  display: grid;
  gap: 14px;
  min-width: 0;
  min-height: 100%;
}

#macro-panel .editor-split {
  grid-template-columns: 170px minmax(0, 1fr);
  gap: 14px;
  align-items: stretch;
  padding: 12px;
  border: 1px solid rgba(229, 115, 115, 0.1);
  border-radius: 22px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.82), rgba(255, 248, 248, 0.68)),
    radial-gradient(circle at 6% 12%, rgba(229, 115, 115, 0.08), transparent 34%);
}

#macro-panel .slot-sidebar {
  padding: 12px;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  align-self: stretch;
  box-sizing: border-box;
  min-height: 100%;
  background: rgba(255, 255, 255, 0.68);
}

#macro-panel .slot-sidebar-header {
  margin-bottom: 10px;
}

#macro-panel .slot-detail {
  display: grid;
  gap: 0;
  min-width: 0;
  min-height: 100%;
}

#tap-dance-panel.is-unavailable .editor-split {
  grid-template-columns: minmax(0, 1fr);
}

#tap-dance-panel.is-unavailable .panel-header .section-actions {
  display: none;
}

#tap-dance-panel.is-unavailable .slot-sidebar {
  display: none;
}

#tap-dance-panel.is-unavailable .slot-detail {
  min-height: auto;
}

#tap-dance-slot-summary,
#macro-slot-summary {
  display: grid;
  gap: 4px;
  padding: 12px 14px;
  border: 1px solid rgba(229, 115, 115, 0.12);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.72);
}

#tap-dance-slot-summary strong,
#macro-slot-summary strong {
  font-size: 14px;
}

#tap-dance-slot-summary span,
#macro-slot-summary span {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.slot-summary-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 6px;
}

.summary-chip {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 5px 9px;
  border: 1px solid rgba(229, 115, 115, 0.12);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.68);
  color: var(--text);
  font-size: 12px;
  font-weight: 750;
}

.summary-chip[data-state="error"] {
  border-color: rgba(184, 35, 35, 0.24);
  background: rgba(255, 235, 235, 0.82);
  color: #9b2b2b;
}

.tap-dance-summary-steps {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
}

.tap-dance-summary-steps span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 7px 10px;
  border: 1px solid rgba(229, 115, 115, 0.12);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.64);
  color: var(--text);
  font-size: 12px;
  font-weight: 750;
}

.tap-dance-summary-steps span::before {
  content: attr(data-step);
  width: 18px;
  height: 18px;
  display: inline-grid;
  place-items: center;
  border-radius: 999px;
  background: rgba(229, 115, 115, 0.12);
  color: var(--accent-hover);
  font-size: 11px;
  font-weight: 850;
}

#tap-dance-list {
  display: grid;
}

.tap-dance-card {
  display: grid;
  gap: 16px;
  min-height: 100%;
  padding: 18px;
  border-radius: 20px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.78)),
    radial-gradient(circle at 94% 0%, rgba(229, 115, 115, 0.08), transparent 30%);
}

.tap-dance-card .setting-card-header {
  align-items: center;
  margin-bottom: 0;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(229, 115, 115, 0.1);
}

.tap-dance-card .setting-title {
  font-size: 20px;
  letter-spacing: -0.02em;
}

.tap-dance-card .setting-caption {
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(229, 115, 115, 0.08);
  color: var(--muted);
  font-size: 12px;
  font-weight: 750;
}

.tap-dance-card.is-preview .td-keycode-button,
.tap-dance-card.is-preview .td-tapping-term-input,
.tap-dance-card.is-preview .td-hold-term-input,
.tap-dance-card.is-preview .td-hold-mode-select,
.tap-dance-card.is-preview .td-switch-mode-select {
  border-style: dashed;
  background: rgba(255, 255, 255, 0.54);
}

.tap-dance-card.is-preview .td-preview {
  color: var(--muted);
}

.tap-dance-editor {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.tap-dance-editor .field-stack,
.tap-dance-settings-grid label {
  width: 100%;
  max-width: none;
}

.tap-dance-editor .field-stack {
  position: relative;
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid rgba(229, 115, 115, 0.12);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.62);
}

.tap-dance-editor .field-stack > span {
  display: inline-flex;
  gap: 7px;
  align-items: center;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.tap-dance-editor .field-stack > span::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: var(--accent);
  box-shadow: 0 0 0 4px rgba(229, 115, 115, 0.1);
}

.tap-dance-editor .td-keycode-button {
  min-height: 76px;
  border-radius: 16px;
}

.tap-dance-settings-grid {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  align-items: end;
  padding: 12px;
  border: 1px solid rgba(229, 115, 115, 0.1);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.5);
}

.tap-dance-settings-grid label {
  display: grid;
  gap: 8px;
}

.tap-dance-settings-grid label > span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 750;
}

.tap-dance-card .td-preview {
  margin: 0;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.55);
}

#tap-dance-panel.is-compact .editor-split {
  grid-template-columns: 320px minmax(0, 1fr);
  gap: 14px;
  align-items: stretch;
  padding: 12px;
}

#tap-dance-panel.is-compact .slot-sidebar {
  align-self: stretch;
  min-height: 100%;
  padding: 12px;
}

#tap-dance-panel.is-compact .slot-sidebar-header {
  margin-bottom: 10px;
}

#tap-dance-panel.is-compact #tap-dance-slot-menu {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  padding: 5px;
  max-height: none;
}

#tap-dance-panel.is-compact #tap-dance-slot-menu .slot-menu-button {
  min-height: 34px;
  padding: 6px 8px;
  border-radius: 12px;
}

#tap-dance-panel.is-compact #tap-dance-slot-menu .slot-menu-title {
  font-size: 12px;
}

#tap-dance-panel.is-compact .slot-detail {
  gap: 0;
  min-height: 100%;
}

#tap-dance-panel.is-compact .tap-dance-card {
  gap: 12px;
  min-height: 100%;
  padding: 14px;
}

#tap-dance-panel.is-compact .tap-dance-card .setting-card-header {
  padding-bottom: 10px;
}

#tap-dance-panel.is-compact .tap-dance-card .setting-title {
  font-size: 19px;
}

#tap-dance-panel.is-compact .tap-dance-card .setting-caption {
  padding: 5px 9px;
  font-size: 12px;
}

#tap-dance-panel.is-compact .tap-dance-editor {
  gap: 10px;
}

#tap-dance-panel.is-compact .tap-dance-editor .field-stack {
  gap: 8px;
  padding: 10px;
  border-radius: 16px;
}

#tap-dance-panel.is-compact .tap-dance-editor .field-stack > span {
  font-size: 12px;
}

#tap-dance-panel.is-compact .tap-dance-editor .td-keycode-button {
  min-height: 54px;
  border-radius: 14px;
}

#tap-dance-panel.is-compact .tap-dance-settings-grid {
  gap: 10px;
  padding: 10px;
  border-radius: 16px;
}

#tap-dance-panel.is-compact .tap-dance-settings-grid label {
  gap: 6px;
}

#tap-dance-panel.is-compact .tap-dance-settings-grid label > span {
  font-size: 12px;
}

#tap-dance-panel.is-compact .td-tapping-term-input,
#tap-dance-panel.is-compact .td-hold-term-input,
#tap-dance-panel.is-compact .td-hold-mode-select,
#tap-dance-panel.is-compact .td-switch-mode-select {
  min-height: 38px;
  padding: 7px 10px;
}

.macro-card {
  display: grid;
  gap: 10px;
  min-height: 100%;
  padding: 12px;
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.78)),
    radial-gradient(circle at 94% 0%, rgba(229, 115, 115, 0.08), transparent 30%);
}

.macro-card-body {
  display: grid;
  gap: 10px;
  min-width: 0;
}

.macro-section {
  display: grid;
  gap: 8px;
  min-width: 0;
  padding: 10px;
  border: 1px solid rgba(229, 115, 115, 0.09);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.48);
}

.macro-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 20px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
  text-transform: uppercase;
  letter-spacing: 0;
}

.macro-section--identity,
.macro-section--playback,
.macro-section--builder {
  padding-bottom: 10px;
}

.macro-section--playback {
  background: rgba(255, 255, 255, 0.62);
}

.macro-section--program {
  background: rgba(255, 255, 255, 0.62);
}

.macro-section--output {
  display: none !important;
}

.macro-card .setting-card-header {
  align-items: center;
  margin-bottom: 0;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(229, 115, 115, 0.1);
}

.macro-card .setting-title {
  font-size: 19px;
  letter-spacing: 0;
}

.macro-card .setting-caption {
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(229, 115, 115, 0.08);
  color: var(--muted);
  font-size: 12px;
  font-weight: 750;
}

.macro-card.is-preview input,
.macro-card.is-preview select,
.macro-card.is-preview textarea,
.macro-card.is-preview button {
  border-style: dashed;
  background: rgba(255, 255, 255, 0.54);
}

.macro-card.is-preview .macro-preview {
  color: var(--muted);
}

.macro-card.is-preview .macro-export-toggle,
.macro-card.is-preview .macro-quick-actions,
.macro-card.is-preview .macro-header-editor,
.macro-card.is-preview .macro-template-picker,
.macro-card.is-preview .macro-template-editor,
.macro-card.is-preview .macro-structured-editor,
.macro-card.is-preview .macro-raw-field,
.macro-card.is-preview .macro-hex-details,
.macro-card.is-preview .macro-section--builder,
.macro-card.is-preview .macro-builder-toolbar button {
  display: none;
}

.macro-card.is-preview .macro-top-grid {
  grid-template-columns: minmax(0, 1fr) minmax(160px, 220px);
}

.macro-card.is-preview .macro-builder-toolbar {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

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

.picker-copy {
  margin: 8px 0 0;
  color: var(--muted);
  line-height: 1.5;
}

.keycode-picker-modal[hidden] {
  display: none;
}

.config-preview-modal[hidden] {
  display: none;
}

.config-refresh-modal[hidden] {
  display: none;
}

.config-preview-modal {
  position: fixed;
  inset: 0;
  z-index: 1980;
  display: grid;
  place-items: center;
  padding: 16px;
}

.config-preview-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 32, 0.48);
  backdrop-filter: blur(4px);
}

.config-preview-dialog {
  position: relative;
  width: min(720px, calc(100vw - 28px));
  height: min(860px, calc(100vh - 28px));
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 18px 18px 20px;
  border: 1px solid rgba(229, 115, 115, 0.2);
  border-radius: 22px;
  background: #fff;
  box-shadow: 0 28px 70px rgba(15, 23, 32, 0.28);
  overflow: hidden;
}

.config-preview-header {
  min-width: 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.config-preview-header h2 {
  margin: 0;
  font-size: 22px;
  line-height: 1.2;
}

.config-preview-subtitle {
  margin: 0;
  color: var(--muted);
  font-weight: 600;
  line-height: 1.5;
}

#config-preview-close-btn,
.config-preview-close-btn {
  width: 38px;
  height: 38px;
  min-width: 38px;
  min-height: 38px;
  display: inline-grid;
  place-items: center;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: #7b8794;
  font-size: 30px;
  font-weight: 400;
  line-height: 1;
  box-shadow: none;
}

#config-preview-close-btn:hover:not(:disabled),
#config-preview-close-btn:focus-visible,
.config-preview-close-btn:hover:not(:disabled),
.config-preview-close-btn:focus-visible {
  background: rgba(229, 115, 115, 0.08);
  color: var(--text);
  box-shadow: none;
  transform: none;
}

.config-preview-meta-grid {
  display: none;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.config-preview-meta-card {
  min-width: 0;
  display: grid;
  gap: 4px;
  padding: 12px 14px;
  border: 1px solid rgba(229, 115, 115, 0.14);
  border-radius: 14px;
  background: var(--surface-subtle);
}

.config-preview-meta-card span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}

.config-preview-meta-card strong {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 15px;
}

.config-preview-warning {
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(199, 76, 76, 0.25);
  background: rgba(199, 76, 76, 0.08);
  color: var(--danger);
  font-size: 13px;
  font-weight: 700;
  line-height: 1.5;
}

.config-preview-body {
  flex: 1 1 0;
  min-height: 0;
  display: grid;
  gap: 14px;
  align-content: start;
  overflow: auto;
  padding-right: 2px;
}

.config-preview-message {
  flex: 0 0 auto;
  margin: 0;
  min-height: 0;
  padding: 0 4px;
  text-align: center;
}

.config-preview-message:empty {
  display: none;
}

.config-preview-device-card {
  min-width: 0;
}

.config-preview-layer-table {
  overflow: hidden;
  border: 1px solid #f3e1e1;
  border-radius: 12px;
  background: #fff;
}

.config-preview-device-summary {
  min-height: 40px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 0 14px;
  border-bottom: 1px solid #f3e1e1;
  background: #fffafa;
  color: #526171;
  font-size: 13px;
  line-height: 1.25;
}

.config-preview-device-summary-name {
  min-width: 0;
  color: #202b36;
  font-size: 16px;
  font-weight: 800;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.config-preview-device-summary-color {
  flex: none;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: #7b8794;
  font-size: 13px;
  font-weight: 700;
}

.config-preview-device-summary-swatch {
  width: 15px;
  height: 15px;
  flex: 0 0 15px;
  border-radius: 999px;
  box-shadow: inset 0 0 0 1px rgba(32, 43, 54, 0.14), 0 2px 6px rgba(197, 79, 79, 0.12);
}

.config-preview-layer-head-row,
.config-preview-layer-row {
  display: grid;
  grid-template-columns: 88px repeat(3, minmax(0, 1fr));
}

.config-preview-layer-head,
.config-preview-key-head {
  min-height: 42px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff8f8;
  color: #526171;
  font-size: 14px;
  font-weight: 800;
  line-height: 1.2;
  text-align: center;
}

.config-preview-layer-head {
  border-left: 1px solid #f3e1e1;
}

.config-preview-key-head {
  padding: 4px;
  color: #202b36;
  font-size: 13px;
  overflow-wrap: anywhere;
}

.config-preview-layer-key,
.config-preview-layer-cell {
  border-top: 1px solid #f3e1e1;
}

.config-preview-layer-key {
  min-height: 96px;
  display: grid;
  grid-template-columns: 42px 30px;
  gap: 4px;
  align-items: center;
  justify-content: center;
  padding: 6px 4px;
  color: #18212b;
  font-size: 15px;
  font-weight: 800;
  line-height: 1.1;
}

.config-preview-key-name {
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.config-preview-key-name span {
  writing-mode: vertical-rl;
  text-orientation: upright;
  letter-spacing: 0;
}

.config-preview-key-actions {
  display: grid;
  gap: 4px;
  align-content: center;
}

.config-preview-key-action-box {
  width: 26px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #f0dddd;
  border-radius: 6px;
  background: #fff8f8;
  color: #8b98a7;
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
}

.config-preview-layer-cell {
  min-height: 96px;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 4px;
  padding: 8px;
  border-left: 1px solid #f3e1e1;
  text-align: center;
}

.config-preview-layer-cell.selectable {
  cursor: pointer;
  background: #fffafa;
}

.config-preview-layer-cell.selectable:hover,
.config-preview-layer-cell.selectable:focus-visible {
  outline: none;
  background: #fff1f1;
  box-shadow: inset 0 0 0 1px rgba(229, 115, 115, 0.25);
}

.config-preview-cell-value-row {
  width: 100%;
  min-height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #607083;
  font-size: 13px;
  line-height: 1.25;
  overflow-wrap: anywhere;
}

.config-preview-cell-value-row.empty {
  color: transparent;
}

.config-preview-empty {
  padding: 24px;
  border: 1px dashed rgba(229, 115, 115, 0.24);
  border-radius: 14px;
  color: var(--muted);
  text-align: center;
  font-weight: 700;
}

.config-preview-actions {
  flex: 0 0 auto;
  margin-top: 0;
  padding-top: 6px;
  justify-content: center;
  gap: 10px;
}

.config-preview-actions[hidden] {
  display: none;
}

.config-preview-partial-panel {
  flex: 0 0 auto;
  max-height: min(320px, 38vh);
  min-height: 0;
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 1px solid #f0dddd;
  border-radius: 16px;
  background: #fffafa;
  overflow: auto;
}

.config-preview-partial-title {
  color: #18212b;
  font-size: 16px;
  font-weight: 900;
  line-height: 1.2;
}

.config-preview-partial-summary {
  color: #6b7788;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.35;
}

.config-preview-partial-group {
  display: grid;
  gap: 7px;
}

.config-preview-partial-label {
  color: #6b7788;
  font-size: 12px;
  font-weight: 800;
}

.config-preview-partial-options,
.config-preview-partial-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.config-preview-partial-chip,
.config-preview-partial-actions button {
  min-height: 36px;
  padding: 0 14px;
  border: 1px solid #f0dddd;
  border-radius: 12px;
  background: #fff;
  color: #526171;
  font-size: 13px;
  font-weight: 800;
}

.config-preview-partial-chip.active {
  border-color: var(--accent);
  background: #fff1f1;
  color: var(--danger);
}

.config-preview-partial-actions {
  justify-content: flex-end;
  padding-top: 2px;
}

.config-preview-partial-actions button:last-child {
  border-color: var(--accent);
  background: var(--accent);
  color: #fff;
}

.config-preview-actions button {
  min-width: 220px;
  min-height: 48px;
  border-radius: 999px;
  font-size: 16px;
  font-weight: 800;
}

.config-preview-actions #config-preview-write-btn:disabled {
  cursor: not-allowed;
  opacity: 0.55;
  transform: none;
}

.config-preview-actions #config-preview-cancel-btn {
  background: var(--surface);
  color: var(--text);
  border-color: var(--border-strong);
}

.config-preview-actions #config-preview-cancel-btn:hover:not(:disabled) {
  background: var(--surface-strong);
  color: var(--text);
  border-color: var(--accent);
}

.config-refresh-modal {
  position: fixed;
  inset: 0;
  z-index: 1900;
  display: grid;
  place-items: center;
  padding: 24px;
}

.config-refresh-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 32, 0.36);
  backdrop-filter: blur(5px);
}

.config-refresh-dialog {
  position: relative;
  width: min(430px, calc(100vw - 32px));
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 16px;
  align-items: center;
  padding: 22px;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: linear-gradient(180deg, var(--surface-strong) 0%, var(--surface-subtle) 100%);
  box-shadow: 0 24px 44px rgba(15, 23, 32, 0.2);
}

.config-refresh-spinner {
  width: 40px;
  height: 40px;
  border: 3px solid rgba(229, 115, 115, 0.2);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: config-refresh-spin 0.85s linear infinite;
}

.config-refresh-copy-block {
  min-width: 0;
}

.config-refresh-copy-block h2 {
  margin: 2px 0 6px;
  font-size: 22px;
}

.config-refresh-copy-block p {
  margin: 0;
  color: var(--muted);
  font-weight: 600;
  line-height: 1.5;
}

@keyframes config-refresh-spin {
  to {
    transform: rotate(360deg);
  }
}

.keycode-picker-modal {
  position: fixed;
  inset: 0;
  z-index: 2000;
}

.keycode-picker-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 32, 0.48);
  backdrop-filter: blur(6px);
}

.keycode-picker-dialog {
  position: relative;
  width: min(1620px, calc(100vw - 12px));
  height: min(920px, calc(100vh - 20px));
  max-height: calc(100vh - 20px);
  margin: 8px auto;
  padding: 20px 20px 18px;
  overflow: hidden;
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr) auto;
  gap: 16px;
  background: linear-gradient(180deg, var(--surface-strong) 0%, var(--surface-subtle) 100%);
  border: 1px solid var(--border);
  border-radius: 20px;
  box-shadow: 0 24px 44px rgba(15, 23, 32, 0.24);
}

.keycode-picker-header {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
}

.picker-close-btn {
  white-space: nowrap;
}

.keycode-picker-toolbar {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.keycode-picker-layout {
  min-height: 0;
  height: 100%;
  display: grid;
  grid-template-columns: 146px minmax(0, 1fr);
  gap: 18px;
}

.keycode-picker-categories,
.keycode-picker-main {
  min-height: 0;
}

.keycode-picker-categories {
  display: grid;
  gap: 8px;
  align-content: start;
  min-height: 0;
  overflow: auto;
  padding: 6px 8px 6px 4px;
}

.keycode-picker-category {
  display: inline-flex;
  justify-content: flex-start;
  align-items: center;
  min-height: 44px;
  padding: 0 12px;
  font-size: 15px;
  gap: 10px;
  background: rgba(255, 255, 255, 0.7);
  color: var(--text);
  border-color: var(--border-strong);
  box-shadow: none;
  transform: none;
}

.keycode-picker-category-icon {
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
  stroke: currentColor;
  stroke-width: 1.8;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.keycode-picker-category-text {
  min-width: 0;
}

.keycode-picker-category:hover:not(:disabled) {
  background: rgba(255, 164, 162, 0.12);
  color: var(--text);
  border-color: var(--accent);
  box-shadow: 0 0 0 4px var(--accent-ring);
  transform: none;
}

.keycode-picker-category.is-active {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}

.keycode-picker-category.is-active:hover:not(:disabled) {
  background: var(--accent-hover);
  color: #fff;
  border-color: var(--accent-hover);
}

.keycode-picker-main {
  display: grid;
  grid-template-rows: auto minmax(360px, 1fr) auto;
  gap: 12px;
  min-height: 0;
}

.keycode-picker-preview {
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(229, 115, 115, 0.16);
  background: rgba(255, 255, 255, 0.78);
  color: var(--muted);
  line-height: 1.5;
}

.keycode-picker-preview[data-state="error"] {
  border-color: rgba(199, 76, 76, 0.28);
  color: var(--danger);
}

.keycode-picker-stage {
  min-height: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

.keycode-picker-composer,
.keycode-picker-results-block,
.keycode-picker-keyboard-section {
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(229, 115, 115, 0.16);
  background: rgba(255, 255, 255, 0.78);
}

.keycode-picker-composer {
  display: grid;
  align-content: start;
  gap: 12px;
}

.keycode-picker-modifiers {
  display: grid;
  gap: 12px;
}

.keycode-picker-modifier-note {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.5;
}

.keycode-picker-modifier-group {
  display: grid;
  gap: 8px;
}

.keycode-picker-modifier-group-title,
.keycode-picker-keyboard-section-title {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.keycode-picker-keyboard-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.keycode-picker-modifier-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.keycode-picker-modifier {
  justify-content: center;
  min-height: 40px;
  padding: 0 10px;
  background: rgba(255, 255, 255, 0.88);
  color: var(--text);
  border-color: rgba(229, 115, 115, 0.22);
  box-shadow: none;
  transform: none;
  white-space: nowrap;
}

.keycode-picker-modifier:hover:not(:disabled),
.keycode-picker-virtual-key:hover:not(:disabled),
.keycode-picker-result.is-active,
.keycode-picker-modifier.is-active {
  background: rgba(255, 164, 162, 0.14);
  border-color: var(--accent);
  box-shadow: 0 0 0 4px var(--accent-ring);
  color: var(--text);
}

.keycode-picker-modifier.is-active,
.keycode-picker-virtual-key.is-active {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

.keycode-picker-modifier.is-active:hover:not(:disabled),
.keycode-picker-virtual-key.is-active:hover:not(:disabled) {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
  color: #fff;
}

.keycode-picker-keyboard {
  min-height: 0;
  overflow: auto;
  display: grid;
  gap: 12px;
  align-content: start;
  padding-right: 4px;
  overscroll-behavior: contain;
}

.keycode-picker-keyboard[data-category="keyboard"] {
  --picker-key-step: 22px;
  --picker-key-gap: 8px;
  --picker-section-gap: 26px;
  --picker-key-size: calc(var(--picker-key-step) * 2 + var(--picker-key-gap));
  grid-template-columns: max-content max-content max-content;
  grid-template-areas:
    "function function function"
    "main nav numpad";
  padding: 18px;
  border-radius: 20px;
  border: 1px solid rgba(229, 115, 115, 0.16);
  background: rgba(255, 255, 255, 0.78);
  gap: 16px var(--picker-section-gap);
  justify-content: start;
}

.keycode-picker-keyboard[data-category="functions"] {
  grid-template-columns: 1.06fr 1.18fr 0.98fr;
  align-items: start;
  gap: 12px;
}

.keycode-picker-keyboard[data-category="tapDance"],
.keycode-picker-keyboard[data-category="macro"] {
  grid-template-columns: 1fr;
  gap: 12px;
}

.keycode-picker-keyboard[data-category="custom"] {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: start;
  gap: 12px;
}

.keycode-picker-keyboard[data-category="bindings"] {
  grid-template-columns: 1fr;
  gap: 12px;
}

.keycode-picker-keyboard-section {
  display: grid;
  gap: 10px;
}

.keycode-picker-keyboard[data-category="keyboard"] .keycode-picker-keyboard-section {
  padding: 0;
  border: none;
  border-radius: 0;
  background: transparent;
}

.keycode-picker-keyboard[data-category="functions"] .keycode-picker-keyboard-section {
  grid-area: auto;
  min-width: 0;
  gap: 10px;
  padding: 12px;
}

.keycode-picker-keyboard[data-category="custom"] .keycode-picker-keyboard-section {
  grid-area: auto;
  min-width: 0;
  gap: 10px;
  padding: 12px;
}

.keycode-picker-keyboard[data-category="tapDance"] .keycode-picker-keyboard-section,
.keycode-picker-keyboard[data-category="macro"] .keycode-picker-keyboard-section {
  min-width: 0;
  gap: 10px;
  padding: 12px;
}

.keycode-picker-keyboard[data-category="bindings"] .keycode-picker-keyboard-section {
  min-width: 0;
  gap: 10px;
  padding: 12px;
}

.keycode-picker-keyboard[data-category="keyboard"] .keycode-picker-keyboard-section-title {
  display: none;
}

.keycode-picker-keyboard[data-category="functions"] .keycode-picker-keyboard-section-title {
  padding-bottom: 6px;
  border-bottom: 1px solid rgba(229, 115, 115, 0.14);
  font-size: 13px;
}

.keycode-picker-keyboard[data-category="custom"] .keycode-picker-keyboard-section-title {
  padding-bottom: 6px;
  border-bottom: 1px solid rgba(229, 115, 115, 0.14);
  font-size: 13px;
}

.keycode-picker-keyboard[data-category="tapDance"] .keycode-picker-keyboard-section-title,
.keycode-picker-keyboard[data-category="macro"] .keycode-picker-keyboard-section-title {
  padding-bottom: 6px;
  border-bottom: 1px solid rgba(229, 115, 115, 0.14);
  font-size: 13px;
}

.keycode-picker-keyboard[data-category="tapDance"] .keycode-picker-keyboard-section.has-header-action .keycode-picker-keyboard-section-header {
  padding-bottom: 6px;
  border-bottom: 1px solid rgba(229, 115, 115, 0.14);
  display: grid;
  grid-template-columns: repeat(10, minmax(0, 1fr));
  align-items: center;
  gap: 8px;
}

.keycode-picker-keyboard[data-category="tapDance"] .keycode-picker-keyboard-section.has-header-action .keycode-picker-keyboard-section-title {
  padding-bottom: 0;
  border-bottom: none;
  grid-column: 1 / span 2;
}

.keycode-picker-keyboard-section-action {
  width: auto;
  min-width: 108px;
  padding: 0 12px;
  flex: 0 0 auto;
}

.keycode-picker-keyboard[data-category="tapDance"] .keycode-picker-keyboard-section.has-header-action .keycode-picker-keyboard-section-action {
  grid-column: 3 / span 2;
  width: 100%;
  min-width: 0;
}

.keycode-picker-keyboard[data-category="bindings"] .keycode-picker-keyboard-section-title {
  padding-bottom: 6px;
  border-bottom: 1px solid rgba(229, 115, 115, 0.14);
  font-size: 13px;
}

.keycode-picker-keyboard-section--function {
  grid-area: function;
}

.keycode-picker-keyboard-section--main {
  grid-area: main;
}

.keycode-picker-keyboard-section--nav {
  grid-area: nav;
}

.keycode-picker-keyboard-section--numpad {
  grid-area: numpad;
}

.keycode-picker-keyboard-section--main,
.keycode-picker-keyboard-section--function {
  min-width: 0;
}

.keycode-picker-keyboard-section--functions-consumer {
  grid-area: functions-consumer;
}

.keycode-picker-keyboard-section--functions-mouse {
  grid-area: functions-mouse;
}

.keycode-picker-keyboard-section--functions-system {
  grid-area: functions-system;
}

.keycode-picker-keyboard-section--functions-touch {
  grid-area: functions-touch;
}

.keycode-picker-keyboard-section--functions-xteink {
  grid-area: functions-xteink;
}

.keycode-picker-keyboard-rows {
  display: grid;
  gap: 8px;
}

.keycode-picker-keyboard[data-category="keyboard"] .keycode-picker-keyboard-rows {
  gap: 12px;
}

.keycode-picker-keyboard[data-category="functions"] .keycode-picker-keyboard-rows {
  gap: 8px;
}

.keycode-picker-keyboard[data-category="custom"] .keycode-picker-keyboard-rows {
  gap: 8px;
}

.keycode-picker-keyboard[data-category="tapDance"] .keycode-picker-keyboard-rows,
.keycode-picker-keyboard[data-category="macro"] .keycode-picker-keyboard-rows {
  gap: 8px;
}

.keycode-picker-keyboard[data-category="bindings"] .keycode-picker-keyboard-rows {
  gap: 8px;
}

.keycode-picker-keyboard-row {
  display: grid;
  gap: 8px;
}

.keycode-picker-keyboard[data-category="functions"] .keycode-picker-keyboard-row {
  gap: 8px;
  grid-auto-rows: 46px;
}

.keycode-picker-keyboard[data-category="custom"] .keycode-picker-keyboard-row {
  gap: 8px;
  grid-auto-rows: 46px;
}

.keycode-picker-keyboard[data-category="tapDance"] .keycode-picker-keyboard-row,
.keycode-picker-keyboard[data-category="macro"] .keycode-picker-keyboard-row {
  gap: 8px;
  grid-auto-rows: 46px;
}

.keycode-picker-keyboard[data-category="bindings"] .keycode-picker-keyboard-row {
  gap: 8px;
  grid-auto-rows: 46px;
}

.keycode-picker-keyboard[data-category="keyboard"] .keycode-picker-keyboard-row {
  gap: var(--picker-key-gap);
  grid-auto-rows: var(--picker-key-size);
}

.keycode-picker-keyboard-spacer {
  min-height: 1px;
}

.keycode-picker-keyboard-matrix {
  display: grid;
  gap: 8px;
}

.keycode-picker-keyboard[data-category="keyboard"] .keycode-picker-keyboard-matrix {
  gap: var(--picker-key-gap);
  grid-auto-rows: var(--picker-key-size);
}

.keycode-picker-virtual-key {
  min-height: 42px;
  padding: 0 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  border: 1.5px solid rgba(229, 115, 115, 0.42);
  background: rgba(255, 255, 255, 0.9);
  color: var(--text);
  font-size: 13px;
  font-weight: 700;
  line-height: 1.1;
  text-align: center;
  box-shadow: none;
  transform: none;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.keycode-picker-virtual-key.has-icon {
  justify-content: flex-start;
  gap: 10px;
  padding-left: 12px;
  padding-right: 12px;
}

.keycode-picker-button-icon {
  flex: 0 0 16px;
  width: 16px;
  height: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: 12px;
  line-height: 1;
  opacity: 0.8;
}

.keycode-picker-button-icon--svg {
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.keycode-picker-button-icon--battery {
  position: relative;
  display: inline-block;
  width: 14px;
  height: 9px;
  flex: 0 0 14px;
  border: 1.5px solid currentColor;
  border-radius: 2px;
  opacity: 0.9;
}

.keycode-picker-button-icon--battery::after {
  content: "";
  position: absolute;
  top: 2px;
  right: -3px;
  width: 2px;
  height: 3px;
  border-radius: 0 1px 1px 0;
  background: currentColor;
}

.keycode-picker-button-icon--battery::before {
  content: "";
  position: absolute;
  left: 2px;
  top: 1.5px;
  width: 3px;
  height: 4px;
  border-radius: 1px;
  background: currentColor;
  box-shadow: 4px 0 0 currentColor;
}

.keycode-picker-button-label {
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.keycode-picker-key-label-stack {
  display: grid;
  justify-items: center;
  align-content: center;
  gap: 2px;
  width: 100%;
  line-height: 1;
}

.keycode-picker-key-label-secondary {
  font-size: 10px;
  font-weight: 700;
  color: var(--muted);
}

.keycode-picker-key-label-primary {
  font-size: inherit;
  font-weight: 700;
  color: inherit;
}

.keycode-picker-key-label-hint {
  font-size: 10px;
  font-weight: 600;
  color: var(--muted);
}

.keycode-picker-virtual-key.is-active .keycode-picker-key-label-secondary,
.keycode-picker-virtual-key.is-active .keycode-picker-key-label-hint,
.keycode-picker-virtual-key.is-active:hover:not(:disabled) .keycode-picker-key-label-secondary,
.keycode-picker-virtual-key.is-active:hover:not(:disabled) .keycode-picker-key-label-hint {
  color: rgba(255, 255, 255, 0.84);
}

.keycode-picker-keyboard-section--main .keycode-picker-virtual-key {
  min-height: 46px;
}

.keycode-picker-keyboard[data-category="keyboard"] .keycode-picker-virtual-key {
  min-height: 0;
  height: auto;
  aspect-ratio: auto;
  border-radius: 14px;
  font-size: 14px;
  font-weight: 700;
}

.keycode-picker-keyboard[data-category="keyboard"] .keycode-picker-virtual-key.has-secondary {
  padding-top: 6px;
  padding-bottom: 6px;
}

.keycode-picker-keyboard[data-category="keyboard"] .keycode-picker-virtual-key.has-hint {
  padding-top: 6px;
  padding-bottom: 6px;
}

.keycode-picker-keyboard[data-category="keyboard"] .keycode-picker-keyboard-section--function .keycode-picker-virtual-key {
  min-height: 0;
}

.keycode-picker-keyboard-function-grid {
  display: grid;
  grid-template-columns: max-content max-content max-content;
  gap: var(--picker-section-gap);
  align-items: start;
  justify-content: start;
}

.keycode-picker-keyboard-function-placeholder {
  min-height: 1px;
}

.keycode-picker-keyboard[data-category="keyboard"] .keycode-picker-keyboard-section--main .keycode-picker-virtual-key {
  min-height: 0;
}

.keycode-picker-keyboard-section--nav .keycode-picker-virtual-key,
.keycode-picker-keyboard-section--numpad .keycode-picker-virtual-key,
.keycode-picker-keyboard-section--functions-mouse .keycode-picker-virtual-key,
.keycode-picker-keyboard-section--functions-system .keycode-picker-virtual-key,
.keycode-picker-keyboard-section--functions-touch .keycode-picker-virtual-key,
.keycode-picker-keyboard-section--functions-xteink .keycode-picker-virtual-key {
  min-height: 40px;
  padding: 0 6px;
  font-size: 12px;
}

.keycode-picker-keyboard[data-category="functions"] .keycode-picker-virtual-key {
  min-height: 46px;
  padding: 0 10px;
  font-size: 13px;
  border-radius: 12px;
}

.keycode-picker-keyboard[data-category="custom"] .keycode-picker-virtual-key {
  min-height: 46px;
  padding: 0 10px;
  font-size: 13px;
  border-radius: 12px;
}

.keycode-picker-keyboard[data-category="tapDance"] .keycode-picker-virtual-key,
.keycode-picker-keyboard[data-category="macro"] .keycode-picker-virtual-key {
  min-height: 46px;
  padding: 0 10px;
  font-size: 13px;
  border-radius: 12px;
}

.keycode-picker-keyboard[data-category="bindings"] .keycode-picker-virtual-key {
  min-height: 46px;
  padding: 0 10px;
  font-size: 13px;
  border-radius: 12px;
}

.keycode-picker-keyboard[data-category="functions"] .keycode-picker-keyboard-matrix {
  gap: 8px;
  grid-auto-rows: 46px;
}

.keycode-picker-keyboard[data-category="custom"] .keycode-picker-keyboard-matrix {
  gap: 8px;
  grid-auto-rows: 46px;
}

.keycode-picker-keyboard-function-column {
  display: grid;
  gap: 12px;
  align-content: start;
}

.keycode-picker-keyboard[data-category="functions"] .keycode-picker-keyboard-section--functions-mouse,
.keycode-picker-keyboard[data-category="functions"] .keycode-picker-keyboard-section--functions-touch {
  align-content: start;
}

.keycode-picker-keyboard[data-category="functions"] .keycode-picker-keyboard-section--functions-system .keycode-picker-keyboard-row {
  justify-content: start;
}

.keycode-picker-keyboard[data-category="functions"] .keycode-picker-keyboard-section--functions-system .keycode-picker-keyboard-row .keycode-picker-virtual-key {
  width: 100%;
}

.keycode-picker-keyboard[data-category="keyboard"] .keycode-picker-keyboard-section--nav .keycode-picker-virtual-key,
.keycode-picker-keyboard[data-category="keyboard"] .keycode-picker-keyboard-section--numpad .keycode-picker-virtual-key {
  min-height: 0;
  height: auto;
  aspect-ratio: auto;
  font-size: 14px;
}

.keycode-picker-keyboard[data-category="keyboard"] .keycode-picker-keyboard-matrix .keycode-picker-virtual-key {
  align-self: stretch;
}

.keycode-picker-results-block {
  min-height: 0;
  display: grid;
  gap: 10px;
}

.keycode-picker-results-block[hidden] {
  display: none;
}

.keycode-picker-results {
  min-height: 0;
  height: 100%;
  overflow: auto;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  align-content: start;
  padding-right: 4px;
  overscroll-behavior: contain;
}

.keycode-picker-result {
  width: 100%;
  min-height: 82px;
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  align-items: flex-start;
  justify-content: center;
  text-align: left;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.8);
  color: var(--text);
  border: 1.5px solid rgba(229, 115, 115, 0.28);
  box-shadow: none;
  transform: none;
  min-width: 0;
  white-space: normal;
}

.keycode-picker-result:hover:not(:disabled) {
  background: rgba(255, 164, 162, 0.14);
  border-color: var(--accent);
  box-shadow: 0 0 0 4px var(--accent-ring);
  transform: none;
}

.keycode-picker-result.is-active:hover:not(:disabled) {
  background: rgba(255, 164, 162, 0.14);
  color: var(--text);
}

.keycode-picker-result-name {
  font-weight: 700;
  width: 100%;
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.keycode-picker-result-meta {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
  width: 100%;
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.keycode-picker-empty {
  padding: 18px;
  border-radius: 14px;
  border: 1px dashed rgba(229, 115, 115, 0.24);
  color: var(--muted);
  background: rgba(255, 255, 255, 0.54);
}

.log-view {
  margin: 0;
  min-height: 280px;
  max-height: 420px;
  overflow: auto;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid #d6dfe8;
  background: #0f1720;
  color: #dce6ef;
  white-space: pre-wrap;
  word-break: break-word;
  font-family: "Consolas", "SFMono-Regular", monospace;
  font-size: 13px;
  line-height: 1.55;
}

@media (max-width: 1280px) {
  .hero-sync-row {
    grid-template-columns: 1fr;
  }

  .hero-actions-panel .hero-actions {
    justify-content: flex-start;
  }

  .hero-actions-panel .hero-transport {
    flex-basis: 220px;
  }

  .hero-meta-inline {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .shell {
    grid-template-columns: 244px minmax(0, 1fr);
    gap: 16px;
  }

  .project-sidebar-inner {
    padding: 16px;
  }

  .summary-grid,
  .panel-grid-3,
  .panel-grid-2,
  .tap-dance-grid,
  .macro-grid,
  .action-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .keymap-layout {
    grid-template-columns: 1fr;
  }

  .keymap-layer-stack {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  #tap-dance-panel .editor-split {
    grid-template-columns: 224px minmax(0, 1fr);
  }

  #macro-panel .editor-split {
    grid-template-columns: 170px minmax(0, 1fr);
  }

  #tap-dance-panel .slot-sidebar {
    min-height: auto;
  }

  #macro-panel .slot-sidebar {
    min-height: auto;
  }

  #macro-slot-menu {
    grid-template-columns: repeat(2, 64px);
    justify-content: start;
    gap: 8px;
    padding: 5px;
    max-height: none;
  }

  #macro-slot-menu .slot-menu-button {
    min-height: 34px;
    padding: 6px 8px;
    border-radius: 12px;
  }

  #macro-slot-menu .slot-menu-title {
    font-size: 12px;
  }

  .tap-dance-editor {
    gap: 14px;
  }

  .tap-dance-settings-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .tap-dance-editor {
    grid-template-columns: 1fr;
  }

  .macro-top-grid {
    grid-template-columns: minmax(220px, 1fr) auto auto;
  }

  .macro-builder-toolbar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .macro-step-workbench {
    grid-template-columns: 1fr;
  }

  .macro-step-detail-pane {
    position: static;
  }

  .backlight-panel-actions {
    justify-content: flex-start;
    width: 100%;
  }

  .backlight-header-field {
    min-width: 220px;
  }

  .protocol-output-layout {
    grid-template-columns: minmax(0, 1.14fr) minmax(320px, 0.86fr);
  }

  .protocol-output-top-grid {
    grid-template-columns: repeat(3, minmax(140px, 1fr));
  }

  .protocol-output-mouse-preset-grid,
  .protocol-output-touch-preset-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .protocol-output-status-list {
    grid-template-columns: 1fr;
  }

  .protocol-output-capture-status {
    text-align: left;
  }

  .ai-agent-top-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .ai-agent-text-grid {
    grid-template-columns: 1fr;
  }

  .editor-split {
    grid-template-columns: 220px minmax(0, 1fr);
  }

  .key-editor-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  #tap-dance-panel .editor-split {
    grid-template-columns: 224px minmax(0, 1fr);
  }

  #macro-panel .editor-split {
    grid-template-columns: 170px minmax(0, 1fr);
  }

  #tap-dance-slot-menu {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .keycode-picker-layout {
    grid-template-columns: 1fr;
  }

  .keycode-picker-categories {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .keycode-picker-stage {
    grid-template-columns: 1fr;
  }

  .keycode-picker-keyboard[data-category="keyboard"] {
    --picker-key-step: 20px;
    --picker-section-gap: 22px;
    grid-template-columns: max-content max-content;
    grid-template-areas:
      "function function"
      "main main"
      "nav numpad";
  }

  .keycode-picker-keyboard-function-grid {
    grid-template-columns: max-content max-content;
  }

  .keycode-picker-keyboard-function-placeholder {
    display: none;
  }

  .keycode-picker-results {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .keycode-picker-keyboard[data-category="functions"] {
    grid-template-columns: 1fr;
    grid-template-areas:
      "functions-consumer"
      "functions-mouse"
      "functions-system"
      "functions-touch"
      "functions-xteink";
  }

  .keycode-picker-keyboard[data-category="custom"] {
    grid-template-columns: 1fr;
  }

  .keycode-picker-keyboard[data-category="tapDance"],
  .keycode-picker-keyboard[data-category="macro"] {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 1600px), (max-height: 820px) {
  .keycode-picker-dialog {
    width: min(1500px, calc(100vw - 16px));
    height: min(900px, calc(100vh - 16px));
    max-height: calc(100vh - 16px);
    margin: 8px auto;
    padding: 16px;
    gap: 12px;
  }

  .keycode-picker-layout {
    grid-template-columns: 132px minmax(0, 1fr);
    gap: 14px;
  }

  .keycode-picker-main {
    grid-template-rows: auto minmax(0, 1fr) auto;
    gap: 10px;
  }

  .keycode-picker-preview {
    padding: 10px 12px;
  }

  .keycode-picker-category {
    min-height: 38px;
    padding: 0 10px;
    font-size: 14px;
  }

  .keycode-picker-keyboard[data-category="keyboard"] {
    --picker-key-step: 18px;
    --picker-key-gap: 6px;
    --picker-section-gap: 18px;
    gap: 12px var(--picker-section-gap);
    padding: 12px;
  }

  .keycode-picker-keyboard[data-category="keyboard"] .keycode-picker-keyboard-rows {
    gap: 8px;
  }

  .keycode-picker-keyboard[data-category="keyboard"] .keycode-picker-virtual-key {
    border-radius: 11px;
    font-size: 12px;
  }

  .keycode-picker-key-label-secondary,
  .keycode-picker-key-label-hint {
    font-size: 9px;
  }
}

@media (max-width: 1280px) and (min-width: 901px) {
  .config-preview-dialog {
    width: min(720px, calc(100vw - 18px));
    height: min(860px, calc(100vh - 18px));
  }

  .keycode-picker-dialog {
    width: min(100vw - 16px, 1220px);
    height: min(100vh - 16px, 900px);
    max-height: calc(100vh - 16px);
    margin: 8px auto;
    padding: 14px;
    gap: 10px;
  }

  .keycode-picker-toolbar {
    gap: 10px;
  }

  .keycode-picker-layout {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .keycode-picker-categories {
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 6px;
    padding: 0 4px 4px;
  }

  .keycode-picker-category {
    min-height: 34px;
    padding: 0 8px;
    font-size: 13px;
  }

  .keycode-picker-category-icon {
    width: 16px;
    height: 16px;
    flex-basis: 16px;
  }

  .keycode-picker-keyboard[data-category="keyboard"] {
    --picker-key-step: 16px;
    --picker-key-gap: 5px;
    --picker-section-gap: 14px;
    grid-template-columns: max-content max-content max-content;
    grid-template-areas:
      "function function function"
      "main nav numpad";
    gap: 10px var(--picker-section-gap);
    padding: 10px;
  }

  .keycode-picker-keyboard-function-grid {
    grid-template-columns: max-content max-content max-content;
  }

  .keycode-picker-keyboard-function-placeholder {
    display: grid;
  }

  .keycode-picker-keyboard[data-category="keyboard"] .keycode-picker-keyboard-rows {
    gap: 7px;
  }

  .keycode-picker-keyboard[data-category="keyboard"] .keycode-picker-virtual-key {
    border-radius: 10px;
    font-size: 11px;
  }
}

@media (max-width: 900px) {
  .config-preview-dialog {
    width: min(100vw - 18px, 720px);
    height: min(100vh - 18px, 880px);
    padding: 14px;
    border-radius: 18px;
  }

  .config-preview-header,
  .config-preview-actions {
    gap: 10px;
  }

  .config-preview-meta-grid {
    grid-template-columns: 1fr;
  }

  .config-preview-layer-head-row,
  .config-preview-layer-row {
    grid-template-columns: 78px repeat(3, minmax(0, 1fr));
  }

  .config-preview-layer-key {
    grid-template-columns: 36px 28px;
    min-height: 92px;
    font-size: 13px;
  }

  .config-preview-layer-cell {
    min-height: 92px;
    padding: 7px 5px;
  }

  .config-preview-cell-value-row {
    font-size: 12px;
  }

  .config-preview-actions button {
    width: 100%;
    min-width: 0;
  }

  .shell {
    grid-template-columns: 1fr;
    padding: 20px 16px 32px;
  }

  .project-sidebar {
    position: static;
  }

  .project-sidebar-inner {
    max-height: none;
    min-height: 0;
    align-content: start;
    overflow: visible;
  }

  .project-nav {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-content: start;
    overflow: visible;
    padding: 0;
    margin: 0;
  }

  .project-sidebar-status {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .hero-brand {
    align-items: flex-start;
  }

  .hero-actions-panel {
    padding: 16px;
  }

  .summary-grid,
  .panel-grid-3,
  .panel-grid-2,
  .key-editor-grid,
  .keymap-layer-stack,
  .tap-dance-grid,
  .macro-grid,
  .action-grid {
    grid-template-columns: 1fr;
  }

  .panel-header,
  .subpanel-header {
    flex-direction: column;
    align-items: flex-start;
  }

  .ai-agent-layout,
  .ai-agent-top-grid {
    grid-template-columns: 1fr;
  }

  .keymap-panel-actions {
    width: 100%;
    flex-wrap: nowrap;
    justify-content: flex-end;
  }

  .context-system-card .compact-grid {
    grid-template-columns: 1fr;
  }

  .context-system-card,
  .context-system-actions {
    grid-template-columns: 1fr;
    justify-content: stretch;
  }

  .context-system-actions .action-grid {
    grid-template-columns: 1fr;
  }

  .context-system-card-current .compact-grid,
  .context-system-card-defaults .compact-grid,
  .context-system-card-runtime .compact-grid {
    grid-template-columns: 1fr;
    max-width: none;
  }

  .context-system-card-header .section-actions {
    display: grid;
    width: 100%;
    min-width: 0;
  }

  .context-system-card-header .section-actions button {
    width: 100%;
    min-width: 0;
  }

  .editor-split {
    display: grid;
    grid-template-columns: 1fr;
  }

  .slot-menu {
    max-height: none;
  }

  #tap-dance-slot-menu {
    grid-template-columns: 1fr;
    max-height: none;
  }

  #macro-slot-menu {
    grid-template-columns: 1fr;
    max-height: none;
  }

  #tap-dance-panel .editor-split {
    grid-template-columns: 1fr;
  }

  #macro-panel .editor-split {
    grid-template-columns: 1fr;
  }

  .macro-top-grid,
  .macro-builder-toolbar {
    grid-template-columns: 1fr;
  }

  .macro-section {
    padding: 10px;
    border-radius: 14px;
  }

  .macro-step-workbench {
    grid-template-columns: 1fr;
  }

  .macro-step-detail-pane {
    position: static;
  }

  .macro-step-flow {
    max-height: 360px;
  }

  .backlight-sliders {
    grid-template-columns: 1fr;
  }

  .protocol-output-status-list,
  .protocol-output-top-grid {
    grid-template-columns: 1fr;
  }

  .protocol-output-mouse-preset-grid,
  .protocol-output-touch-preset-grid {
    grid-template-columns: 1fr;
  }

  .keycode-picker-keyboard[data-category="keyboard"],
  .keycode-picker-keyboard[data-category="functions"],
  .keycode-picker-keyboard[data-category="custom"],
  .keycode-picker-keyboard[data-category="tapDance"],
  .keycode-picker-keyboard[data-category="macro"] {
    grid-template-columns: 1fr;
  }

  .keycode-picker-keyboard[data-category="keyboard"] {
    grid-template-areas:
      "function"
      "main"
      "nav"
      "numpad";
  }

  .backlight-panel-actions {
    align-items: stretch;
  }

  .backlight-header-field {
    width: 100%;
    min-width: 0;
  }

  .macro-quick-actions {
    width: 100%;
  }

  .macro-quick-actions button {
    flex: 1 1 0;
  }

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

  .keycode-picker-toolbar,
  .keycode-picker-results,
  .keycode-picker-categories {
    grid-template-columns: 1fr;
  }

  .keycode-picker-modifier-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .keycode-picker-keyboard-row {
    grid-template-columns: repeat(12, minmax(0, 1fr));
  }

  .keycode-picker-dialog {
    width: min(100vw - 20px, 1220px);
    height: min(100vh - 20px, 960px);
    max-height: calc(100vh - 20px);
    margin: 10px auto;
    padding: 16px;
  }
}

@media (max-height: 760px) and (min-width: 901px) {
  .project-sidebar-inner {
    gap: 12px;
    padding: 16px;
  }

  .project-sidebar-logo {
    width: 52px;
    height: 52px;
    border-radius: 16px;
  }

  .project-nav {
    gap: 8px;
  }

  .project-nav-link {
    min-height: 46px;
    padding: 11px 12px;
  }
}

/* IAP page compatibility layer.
   The config page was rebuilt, but iap.html still uses the previous shared class names. */
.app {
  max-width: 1400px;
  margin: 0 auto;
  padding: 24px;
}

.app.app-narrow {
  max-width: 1360px;
  padding: 20px;
}

.app.iap-embedded,
.app.iap-embedded.app-narrow {
  max-width: none;
  margin: 0;
  padding: 0;
}

.app.iap-embedded .card:first-child,
.app.iap-embedded .dashboard-grid + .card {
  margin-top: 0;
}

.app.iap-embedded .dashboard-grid + .card.log-card {
  margin-top: 24px;
}

.app .page-header,
.app .toolbar,
.app .grid,
.app .stack {
  display: flex;
  gap: 12px;
}

.app .page-header,
.app .toolbar.wide {
  justify-content: space-between;
  align-items: center;
}

.app .toolbar {
  align-items: center;
  flex-wrap: wrap;
}

.app .stack {
  flex-direction: column;
}

.app .grid {
  flex-wrap: wrap;
}

.app .dashboard-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-top: 16px;
  align-items: stretch;
}

.app .upgrade-layout {
  grid-template-columns: minmax(0, 55fr) minmax(380px, 45fr);
  grid-template-areas:
    "upgrade release";
  align-items: start;
  gap: 12px;
}

.app .upgrade-action-card {
  grid-area: upgrade;
  align-self: start;
}

.app .upgrade-card {
  grid-area: upgrade;
  display: grid;
  align-content: start;
  gap: 8px;
}

.app .upgrade-release-card {
  grid-area: release;
  display: grid;
  align-content: start;
  gap: 8px;
}

.app .upgrade-card.compact-card,
.app .upgrade-release-card.compact-card {
  padding: 10px;
}

.app .upgrade-connect-grid {
  flex-direction: column;
  gap: 10px;
}

.app .upgrade-connect-grid > * {
  width: 100%;
}

.app .grid.cols-2 > * {
  width: calc(50% - 6px);
}

.app .grid.cols-3 > * {
  width: calc(33.333% - 8px);
}

.app .grid.cols-4 > * {
  width: calc(25% - 9px);
}

.app .upgrade-connect-grid.cols-2 > * {
  width: 100%;
}

.app .upgrade-advanced-controls {
  display: none;
}

.app .card {
  background: linear-gradient(180deg, #fffefe 0%, #fff8f8 100%);
  border: 1px solid #e7d4d4;
  border-radius: 12px;
  padding: 16px;
  margin-top: 16px;
  box-shadow: 0 8px 20px rgba(23, 33, 43, 0.05);
}

.app .dashboard-grid .card {
  margin-top: 0;
  height: 100%;
}

.app .compact-card {
  padding: 12px;
}

.app .top-row-card {
  padding: 12px;
}

.app .log-card {
  margin-top: 48px;
}

.app .top-row-card h2 {
  margin-bottom: 6px;
}

.app .muted {
  color: #5f6f82;
}

.app .upgrade-connection-summary {
  display: grid;
  grid-template-columns: 1fr;
  gap: 6px;
}

.app .upgrade-hidden-state {
  display: none !important;
}

.app .upgrade-device-state-item {
  align-items: flex-start;
}

.app .upgrade-summary-item {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 10px;
  padding: 6px 8px;
  border: 1px solid #e7d4d4;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.75);
}

.app .upgrade-summary-item .label {
  min-width: 0;
  font-size: 13px;
  font-weight: 700;
}

.app .upgrade-summary-item .muted {
  line-height: 1.4;
  text-align: right;
  font-size: 14px;
  font-weight: 600;
}

.app .upgrade-device-state-item .muted {
  overflow-wrap: anywhere;
}

.app .card .muted {
  line-height: 1.55;
}

.app .top-row-card .stack.muted {
  gap: 6px;
  line-height: 1.45;
}

.app .upgrade-hints {
  padding-top: 4px;
  border-top: 1px dashed rgba(231, 212, 212, 0.9);
  gap: 3px;
  font-size: 12px;
}

.app .upgrade-hints > div {
  line-height: 1.4;
}

.app .upgrade-inline-note {
  padding-top: 4px;
  border-top: 1px dashed rgba(231, 212, 212, 0.9);
  font-size: 12px;
  line-height: 1.45;
}

.app .top-gap {
  margin-top: 10px;
}

.app .top-row-card .top-gap {
  margin-top: 8px;
}

.app .top-row-card .connection-actions {
  margin-top: 12px !important;
  padding-top: 0;
}

.app .upgrade-secondary-actions {
  justify-content: flex-start;
}

.app .upgrade-secondary-actions[hidden],
.app .upgrade-secondary-actions [hidden] {
  display: none !important;
}

.app .upgrade-secondary-actions #connectButton {
  display: none !important;
}

.app .connection-actions .button-primary {
  min-width: 128px;
}

.app .section-title {
  margin-top: 4px;
  font-size: 14px;
  font-weight: 700;
  color: #4e5d70;
}

.app .upgrade-card h2,
.app .upgrade-release-card h2 {
  margin-bottom: 2px;
}

.app .upgrade-release-info {
  display: grid;
  grid-template-columns: minmax(110px, 0.8fr) minmax(190px, 1.2fr);
  gap: 6px;
  margin: 0 0 2px;
}

.app .upgrade-release-item {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 8px;
  min-width: 0;
  padding: 6px 8px;
  border: 1px solid rgba(231, 212, 212, 0.9);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.6);
}

.app .upgrade-release-note {
  grid-column: 1 / -1;
}

.app .upgrade-release-item .label {
  min-width: auto;
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
}

.app .upgrade-release-item strong {
  min-width: 0;
  color: #34465a;
  font-size: 13px;
  font-weight: 700;
  text-align: right;
  white-space: nowrap;
  overflow-wrap: anywhere;
}

.app .upgrade-history-section {
  margin: -2px 0 6px;
}

.app .upgrade-history-section > summary {
  cursor: pointer;
  list-style: none;
  user-select: none;
  color: #4e5d70;
  font-size: 13px;
  font-weight: 700;
}

.app .upgrade-history-section > summary::-webkit-details-marker {
  display: none;
}

.app .upgrade-history-section > summary::after {
  content: "";
  display: inline-block;
  width: 7px;
  height: 7px;
  margin-left: 8px;
  border-right: 2px solid #8b6d6d;
  border-bottom: 2px solid #8b6d6d;
  transform: rotate(45deg) translateY(-2px);
}

.app .upgrade-history-section[open] > summary::after {
  transform: rotate(225deg) translate(-2px, -2px);
}

.app .upgrade-history-list {
  display: grid;
  gap: 6px;
  margin-top: 6px;
  max-height: 180px;
  overflow-y: auto;
}

.app .upgrade-history-entry {
  padding: 6px 8px;
  border: 1px solid rgba(231, 212, 212, 0.9);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.62);
}

.app .upgrade-history-entry-head {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  color: #34465a;
  font-size: 13px;
  font-weight: 800;
}

.app .upgrade-history-date {
  color: #5f6f82;
  font-weight: 700;
  white-space: nowrap;
}

.app .upgrade-history-summary {
  margin-top: 4px;
  color: #4e5d70;
  font-size: 13px;
  line-height: 1.35;
}

@media (max-width: 720px) {
  .app .upgrade-release-info {
    grid-template-columns: 1fr;
  }

  .app .upgrade-release-item {
    align-items: flex-start;
  }
}

.app .upgrade-section {
  display: grid;
  gap: 6px;
}

.app .upgrade-auto-section {
  padding: 10px;
  border: 1px solid #e7d4d4;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.72);
}

.app .upgrade-section + .upgrade-section {
  padding-top: 8px;
  border-top: 1px dashed rgba(231, 212, 212, 0.9);
}

.app .upgrade-section-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.app .upgrade-action-row {
  justify-content: flex-start;
  flex-wrap: wrap;
}

.app .upgrade-action-row .muted {
  flex: 1 1 auto;
  text-align: right;
}

.app .upgrade-auto-status {
  min-width: 160px;
  overflow-wrap: anywhere;
}

.app .upgrade-section-head .button-primary {
  min-width: 150px;
  white-space: nowrap;
}

.app .upgrade-card .muted {
  line-height: 1.45;
}

.app .upgrade-card .top-gap {
  margin-top: 8px;
}

.app .upgrade-card .section-title.top-gap {
  margin-top: 6px;
}

.app .upgrade-card .grid.cols-2,
.app .upgrade-card .toolbar {
  gap: 10px;
}

.app .upgrade-card .progress-status-row {
  margin-top: 6px;
}

.app .upgrade-manual-grid {
  gap: 10px;
  align-items: end;
}

.app .upgrade-advanced-section {
  display: block;
  margin-top: 4px;
}

.app .upgrade-advanced-section > summary {
  cursor: pointer;
  list-style: none;
  user-select: none;
}

.app .upgrade-advanced-section > summary::-webkit-details-marker {
  display: none;
}

.app .upgrade-advanced-section > summary::after {
  content: "";
  display: inline-block;
  width: 7px;
  height: 7px;
  margin-left: 8px;
  border-right: 2px solid #8b6d6d;
  border-bottom: 2px solid #8b6d6d;
  transform: rotate(45deg) translateY(-2px);
  transition: transform 0.18s ease;
}

.app .upgrade-advanced-section[open] > summary::after {
  transform: rotate(225deg) translate(-2px, -2px);
}

.app .upgrade-manual-body {
  display: grid;
  gap: 10px;
  margin-top: 10px;
}

.app .upgrade-log-section {
  display: block;
}

.app .upgrade-log-summary {
  cursor: pointer;
  list-style: none;
  user-select: none;
  font-size: 22px;
  font-weight: 800;
  color: #0f1f2f;
}

.app .upgrade-log-summary::-webkit-details-marker {
  display: none;
}

.app .upgrade-log-summary::after {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  margin-left: 10px;
  border-right: 2px solid #8b6d6d;
  border-bottom: 2px solid #8b6d6d;
  transform: rotate(45deg) translateY(-3px);
  transition: transform 0.18s ease;
}

.app .upgrade-log-section[open] .upgrade-log-summary::after {
  transform: rotate(225deg) translate(-2px, -2px);
}

.app .upgrade-log-section .log-view {
  margin-top: 12px;
}

.app .upgrade-info-item {
  align-items: flex-start;
}

.app .upgrade-info-item .muted {
  text-align: left;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.main-log-section {
  display: block;
}

.main-log-summary {
  cursor: pointer;
  list-style: none;
  user-select: none;
  font-size: 22px;
  font-weight: 800;
  color: #0f1f2f;
}

.main-log-summary::-webkit-details-marker {
  display: none;
}

.main-log-summary::after {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  margin-left: 10px;
  border-right: 2px solid #8b6d6d;
  border-bottom: 2px solid #8b6d6d;
  transform: rotate(45deg) translateY(-3px);
  transition: transform 0.18s ease;
}

.main-log-section[open] .main-log-summary::after {
  transform: rotate(225deg) translate(-2px, -2px);
}

.main-log-copy {
  margin: 10px 0 14px;
  color: var(--muted);
  line-height: 1.55;
}

.keycode-picker-trigger.is-meta-only {
  min-height: 38px;
  padding: 8px 12px;
  justify-content: center;
  gap: 0;
}

.keycode-picker-trigger.is-meta-only .keycode-picker-value {
  display: none;
}

.keycode-picker-trigger.is-meta-only .keycode-picker-meta {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  line-height: 1.3;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.app .upgrade-card .progress-block {
  margin-top: 6px;
}

.app .label {
  display: inline-block;
  min-width: 110px;
  color: #4e5d70;
}

.app .button-primary,
.app .button-secondary {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}

.app .button-primary:hover:not([disabled]),
.app .button-secondary:hover:not([disabled]) {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
  color: #fff;
}

.app .upgrade-action-card :is(button, .button-link)[data-action-icon] {
  background: rgba(229, 115, 115, 0.07);
  border-color: rgba(229, 115, 115, 0.24);
  color: var(--accent-strong);
  box-shadow: 0 1px 0 rgba(229, 115, 115, 0.06);
}

.app .upgrade-action-card :is(button, .button-link)[data-action-icon]:disabled {
  background: rgba(229, 115, 115, 0.08);
  border-color: rgba(229, 115, 115, 0.14);
  color: rgba(214, 90, 90, 0.48);
  opacity: 1;
}

.app .upgrade-action-card :is(button, .button-link)[data-action-icon]:not(:disabled):hover,
.app .upgrade-action-card :is(button, .button-link)[data-action-icon]:focus-visible {
  background: var(--accent-soft);
  border-color: rgba(229, 115, 115, 0.42);
  color: var(--accent-strong);
  box-shadow: 0 8px 18px rgba(229, 115, 115, 0.12);
}

.app .json-view,
.app .log-view {
  margin: 0;
  min-height: 120px;
  padding: 12px;
  border-radius: 10px;
  border: 1px solid #d6dfe8;
  background: #0f1720;
  color: #dce6ef;
  overflow: auto;
  white-space: pre-wrap;
  word-break: break-word;
}

.app .log-view {
  height: 220px;
  min-height: 220px;
  max-height: 220px;
  overflow-y: auto;
}

.app .progress-block {
  margin-top: 24px;
}

.app .progress-status-row {
  justify-content: flex-end;
  align-items: center;
  margin-top: 4px;
}

.app .progress-inline-label {
  margin-left: auto;
  white-space: nowrap;
  text-align: right;
}

.app .upgrade-actions {
  margin-top: 4px;
  display: flex;
  flex-wrap: nowrap;
  gap: 10px;
  width: 100%;
}

.app .upgrade-actions > * {
  width: auto;
  min-width: 118px;
  padding: 10px 12px;
  font-size: inherit;
  white-space: nowrap;
}

.app .upgrade-download-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}

.app #progressBar {
  width: 100%;
  height: 10px;
  display: block;
  margin-top: 8px;
  margin-bottom: 8px;
  border: none;
  border-radius: 999px;
  overflow: hidden;
  background: #f6cccc;
  appearance: none;
  -webkit-appearance: none;
}

.app #progressBar::-webkit-progress-bar {
  background: #f6cccc;
  border-radius: 999px;
}

.app #progressBar::-webkit-progress-value {
  background: linear-gradient(90deg, #e57373 0%, #ffa4a2 100%);
  border-radius: 999px;
}

.app #progressBar::-moz-progress-bar {
  background: linear-gradient(90deg, #e57373 0%, #ffa4a2 100%);
  border-radius: 999px;
}

.app .explain-card .stack.muted {
  gap: 6px;
}

.app .explain-card code {
  color: #a84b4b;
}

@media (max-width: 1100px) {
  .app .grid.cols-3 > *,
  .app .grid.cols-4 > * {
    width: calc(50% - 6px);
  }
}

@media (max-width: 900px) {
  .app .dashboard-grid,
  .app .upgrade-layout {
    grid-template-columns: 1fr;
    grid-template-areas:
      "upgrade"
      "release";
  }

  .app .upgrade-connection-summary {
    grid-template-columns: 1fr;
  }

  .app .upgrade-section-head {
    flex-direction: column;
  }

  .app .upgrade-actions {
    flex-wrap: wrap;
  }
}

@media (max-width: 720px) {
  .hero-brand {
    flex-direction: column;
  }

  .hero-logo {
    width: 56px;
    height: 56px;
  }

  .hero-actions-panel .hero-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .hero-actions-panel .hero-transport,
  .hero-actions-panel .hero-actions button {
    width: 100%;
    flex: 0 0 auto;
  }

  .hero-meta-inline {
    grid-template-columns: 1fr;
  }

  .project-sidebar-brand {
    grid-template-columns: 1fr;
  }

  .project-nav {
    grid-template-columns: 1fr;
  }

  .project-sidebar-status {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .compact-setting-grid,
  .indicator-setting-grid {
    grid-template-columns: 1fr;
  }

  .app .grid.cols-2 > *,
  .app .grid.cols-3 > *,
  .app .grid.cols-4 > * {
    width: 100%;
  }

  .app .page-header {
    flex-direction: column;
    align-items: flex-start;
  }

.app.app-narrow {
    padding: 16px;
  }
}

/* Keep one-key multi-use on the same compact layout after responsive overrides. */
@media (min-width: 721px) {
  #tap-dance-panel.is-compact .editor-split {
    grid-template-columns: 320px minmax(0, 1fr);
    align-items: stretch;
  }

  #tap-dance-panel.is-compact .slot-sidebar,
  #tap-dance-panel.is-compact .slot-detail,
  #tap-dance-panel.is-compact .tap-dance-card {
    min-height: 100%;
  }
}

#tap-dance-panel.is-compact #tap-dance-slot-menu {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

/* Macro editor: keep the path linear for beginner use. */
#macro-slot-summary {
  display: none !important;
}

#macro-panel #macro-slot-menu {
  grid-template-columns: repeat(2, minmax(0, 64px));
  max-height: clamp(220px, calc(100vh - 360px), 430px);
  min-height: 0;
  overflow-x: hidden;
  overflow-y: auto;
  overscroll-behavior: contain;
  box-sizing: border-box;
}

#macro-panel #macro-slot-menu .slot-menu-button {
  min-width: 0;
}

#macro-panel .slot-detail {
  gap: 0;
}

.macro-card {
  gap: 12px;
  padding: 14px;
  grid-template-rows: auto minmax(0, 1fr);
  align-content: start;
  border: 1px solid rgba(229, 115, 115, 0.1);
  background: rgba(255, 255, 255, 0.78);
}

.macro-card .setting-card-header {
  padding-bottom: 10px;
  align-items: end;
  justify-content: flex-start;
  min-height: 56px;
}

.macro-card-body {
  gap: 12px;
}

.macro-title-group {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 28px;
  align-items: end;
  width: 100%;
  min-width: 0;
}

.macro-title-group .setting-title {
  padding-bottom: 9px;
  white-space: nowrap;
}

.macro-title-group .macro-name-field {
  display: grid;
  grid-template-columns: minmax(180px, 232px) minmax(12px, 1fr) auto;
  gap: 8px;
  min-width: 0;
  align-items: end;
}

.macro-title-group .macro-name-input {
  grid-column: 1;
  min-width: 0;
}

.macro-title-group .macro-title-actions {
  grid-column: 3;
  display: grid;
  grid-template-columns: repeat(4, 92px);
  gap: 8px;
  justify-self: end;
  min-width: 0;
}

.macro-title-group .macro-clear-btn,
.macro-title-group .macro-card-save-btn,
.macro-title-group .macro-card-import-btn,
.macro-title-group .macro-export-btn {
  width: 100%;
  min-width: 92px;
  min-height: 38px;
  padding: 8px 14px;
  white-space: nowrap;
}

.macro-header-actions {
  display: none;
}

.macro-section {
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.54);
}

.macro-section-header {
  min-height: 22px;
  color: var(--text);
  text-transform: none;
}

.macro-section--identity {
  display: none;
}

.macro-top-grid {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
}

.macro-export-toggle {
  display: none !important;
}

.macro-quick-actions {
  align-items: end;
}

.macro-quick-actions .macro-clear-btn {
  min-width: 82px;
}

.macro-editor-workbench {
  display: grid;
  grid-template-columns: minmax(240px, 300px) minmax(0, 1fr);
  gap: 12px;
  align-items: stretch;
  min-width: 0;
}

.macro-builder-column {
  display: grid;
  gap: 10px;
  align-content: start;
  min-width: 0;
}

.macro-section--builder,
.macro-section--program {
  align-content: start;
  min-width: 0;
}

.macro-section--builder {
  gap: 10px;
}

.macro-section--program {
  min-height: 260px;
  background: rgba(255, 255, 255, 0.72);
  container-type: inline-size;
}

.macro-section--program > .macro-section-header {
  display: grid;
  grid-template-columns: minmax(220px, 300px) minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  justify-content: stretch;
  min-width: 0;
}

.macro-section--program .macro-section-title-program,
.macro-section--program .macro-section-title-step-details {
  min-width: 0;
  justify-self: start;
}

.macro-builder-toolbar {
  grid-template-columns: minmax(0, 1fr) 76px;
  gap: 10px;
}

.macro-builder-toolbar label {
  display: grid;
  gap: 7px;
}

.macro-builder-toolbar button {
  min-width: 76px;
}

.macro-action-picker[hidden],
.macro-template-picker[hidden],
.macro-recorder[hidden] {
  display: none !important;
}

.macro-action-picker,
.macro-template-picker,
.macro-recorder {
  display: grid;
  position: relative;
  min-width: 0;
  z-index: 24;
}

.macro-action-picker[data-open="true"],
.macro-template-picker[data-open="true"] {
  z-index: 52;
}

.macro-action-trigger {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  width: 100%;
  min-height: 54px;
  padding: 8px 10px;
  border: 1px solid rgba(229, 115, 115, 0.18);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.78);
  color: var(--text);
  text-align: left;
}

.macro-action-trigger:hover:not(:disabled),
.macro-action-trigger[data-open="true"] {
  border-color: rgba(229, 115, 115, 0.52);
  background: #fff7f6;
  box-shadow: 0 10px 24px rgba(158, 66, 66, 0.09);
}

.macro-action-trigger-badge,
.macro-action-group-badge,
.macro-action-card-badge {
  display: grid;
  place-items: center;
  border-radius: 9px;
  background: rgba(229, 115, 115, 0.1);
  color: var(--accent-hover);
  font-size: 11px;
  font-weight: 850;
  line-height: 1;
  letter-spacing: 0;
}

.macro-action-trigger-badge {
  width: 34px;
  height: 34px;
}

.macro-action-trigger-copy {
  display: grid;
  min-width: 0;
  gap: 2px;
}

.macro-action-trigger-copy strong {
  color: var(--text);
  font-size: 13px;
  font-weight: 900;
  line-height: 1.2;
}

.macro-action-trigger-copy span {
  overflow: hidden;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.25;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.macro-action-trigger-chevron {
  display: grid;
  place-items: center;
  width: 26px;
  height: 26px;
  border-radius: 999px;
  background: rgba(229, 115, 115, 0.1);
  color: var(--accent-hover);
  font-size: 13px;
  font-weight: 900;
}

.macro-action-popover {
  position: absolute;
  z-index: 1;
  left: 0;
  top: calc(100% + 8px);
  display: grid;
  grid-template-columns: minmax(160px, 0.88fr) minmax(220px, 1.12fr);
  gap: 10px;
  width: min(560px, calc(100vw - 48px));
  max-width: calc(100vw - 48px);
  padding: 10px;
  border: 1px solid rgba(229, 115, 115, 0.18);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 18px 44px rgba(85, 42, 42, 0.16);
}

.macro-action-column {
  display: grid;
  min-width: 0;
  gap: 8px;
  align-content: start;
}

.macro-action-column-title {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  line-height: 1.2;
}

.macro-action-groups {
  display: grid;
  gap: 6px;
  min-width: 0;
  max-height: 292px;
  overflow: auto;
  padding-right: 2px;
}

.macro-action-group-btn,
.macro-action-card {
  min-width: 0;
  border: 1px solid rgba(176, 91, 91, 0.14);
  background: rgba(255, 255, 255, 0.74);
  color: var(--text);
  text-align: left;
  transition: border-color 140ms ease, background-color 140ms ease, box-shadow 140ms ease, transform 140ms ease;
}

.macro-action-group-btn {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr) auto;
  gap: 7px;
  align-items: center;
  min-height: 40px;
  padding: 6px 7px;
  border-radius: 12px;
}

.macro-action-group-btn:hover,
.macro-action-card:hover {
  border-color: rgba(229, 115, 115, 0.42);
  background: rgba(255, 246, 245, 0.94);
  box-shadow: 0 10px 22px rgba(158, 66, 66, 0.08);
}

.macro-action-group-btn:disabled,
.macro-action-card:disabled {
  opacity: 0.72;
}

.macro-action-group-btn[data-selected="true"] {
  border-color: rgba(229, 115, 115, 0.72);
  background: #fff5f3;
  box-shadow: 0 10px 24px rgba(229, 115, 115, 0.12);
}

.macro-action-card[data-selected="true"] {
  border-color: rgba(229, 115, 115, 0.62);
  background: #fff5f3;
  box-shadow: 0 10px 22px rgba(229, 115, 115, 0.1);
}

.macro-action-card[data-selected="true"] .macro-action-add-hint {
  background: rgba(28, 30, 35, 0.06);
  color: var(--muted);
}

.macro-action-group-badge {
  width: 28px;
  height: 28px;
}

.macro-action-group-copy,
.macro-action-card-copy {
  display: grid;
  min-width: 0;
  gap: 2px;
}

.macro-action-group-copy strong,
.macro-action-card-copy strong {
  min-width: 0;
  overflow: hidden;
  color: var(--text);
  font-size: 12px;
  font-weight: 850;
  line-height: 1.2;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.macro-action-group-copy span,
.macro-action-card-copy span,
.macro-action-stage-copy {
  color: var(--muted);
  font-size: 11px;
  line-height: 1.25;
}

.macro-action-group-count {
  display: grid;
  place-items: center;
  min-width: 22px;
  height: 22px;
  padding: 0 6px;
  border-radius: 999px;
  background: rgba(28, 30, 35, 0.06);
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.macro-action-stage {
  display: grid;
  min-width: 0;
  gap: 7px;
  align-content: start;
}

.macro-action-stage-header {
  display: grid;
  gap: 2px;
  min-height: 34px;
  align-content: center;
  padding: 0 2px;
}

.macro-action-stage-title {
  color: var(--text);
  font-size: 13px;
  font-weight: 900;
  line-height: 1.2;
}

.macro-action-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 6px;
  min-width: 0;
  max-height: 232px;
  overflow: auto;
  padding: 1px 2px 1px 0;
}

.macro-action-card {
  display: grid;
  grid-template-columns: 30px minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  min-height: 48px;
  padding: 8px;
  border-radius: 12px;
}

.macro-action-card:active {
  transform: translateY(1px);
}

.macro-action-card-badge {
  width: 30px;
  height: 30px;
}

.macro-action-card-copy span {
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.macro-action-add-hint {
  width: fit-content;
  max-width: 100%;
  padding: 3px 8px;
  border-radius: 999px;
  background: rgba(229, 115, 115, 0.1);
  color: var(--accent-hover);
  font-size: 11px;
  font-weight: 850;
  line-height: 1;
}

.macro-action-empty {
  padding: 12px;
  color: var(--muted);
  font-size: 12px;
}

.macro-template-picker {
  z-index: 23;
}

.macro-template-popover {
  grid-template-columns: minmax(170px, 0.78fr) minmax(280px, 1.22fr);
  width: min(640px, calc(100vw - 48px));
}

.macro-template-list {
  max-height: 264px;
}

.macro-template-option-btn {
  grid-template-columns: 28px minmax(0, 1fr) 22px;
}

.macro-template-option-mark {
  color: transparent;
}

.macro-template-option-btn[data-selected="true"] .macro-template-option-mark {
  color: var(--accent-hover);
}

.macro-template-stage {
  gap: 8px;
  min-width: 0;
  padding: 8px;
  border: 1px solid rgba(229, 115, 115, 0.12);
  border-radius: 14px;
  background: rgba(255, 250, 249, 0.54);
}

.macro-template-inline-fields {
  display: grid;
  gap: 7px;
  max-height: 260px;
  overflow: auto;
  padding: 1px 2px 1px 0;
  scroll-padding: 8px;
}

.macro-template-inline-fields > label,
.macro-template-inline-fields > .field-stack,
.macro-template-inline-fields > .macro-empty {
  min-width: 0;
  padding: 8px;
  border: 1px solid rgba(176, 91, 91, 0.14);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.74);
  transition: border-color 140ms ease, background-color 140ms ease, box-shadow 140ms ease;
}

.macro-template-inline-fields > label,
.macro-template-inline-fields > .field-stack {
  display: grid;
  grid-template-columns: minmax(76px, 0.36fr) minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  min-height: 46px;
}

.macro-template-inline-fields > label:hover,
.macro-template-inline-fields > .field-stack:hover {
  border-color: rgba(229, 115, 115, 0.42);
  background: rgba(255, 246, 245, 0.94);
  box-shadow: 0 10px 22px rgba(158, 66, 66, 0.08);
}

.macro-template-inline-fields > label > span,
.macro-template-inline-fields > .field-stack > span {
  display: grid;
  place-items: center;
  align-self: center;
  min-width: 0;
  min-height: 30px;
  padding: 4px 8px;
  border-radius: 9px;
  background: rgba(229, 115, 115, 0.1);
  overflow: hidden;
  color: var(--accent-hover);
  font-size: 11px;
  font-weight: 850;
  line-height: 1.15;
  text-align: center;
  overflow-wrap: anywhere;
}

.macro-template-inline-fields input:not([type="checkbox"]),
.macro-template-inline-fields select,
.macro-template-inline-fields textarea,
.macro-template-inline-fields .keycode-picker-trigger,
.macro-template-inline-fields .macro-custom-select-trigger {
  min-width: 0;
  width: 100%;
  min-height: 34px;
  padding: 7px 10px;
  border-color: rgba(176, 91, 91, 0.16);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.9);
}

.macro-template-inline-fields textarea {
  min-height: 78px;
}

.macro-template-inline-fields .keycode-picker-trigger {
  gap: 0;
}

.macro-template-inline-fields .macro-empty {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.macro-template-inline-fields .macro-flags {
  gap: 6px;
}

.macro-template-inline-fields .macro-flags label {
  display: inline-flex;
  min-height: 30px;
  padding: 5px 8px;
  border: 1px solid rgba(176, 91, 91, 0.12);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  font-size: 12px;
  font-weight: 700;
  line-height: 1.1;
}

.macro-template-inline-fields .macro-flags label:hover {
  border-color: rgba(229, 115, 115, 0.32);
  background: rgba(255, 246, 245, 0.86);
}

.macro-template-picker-actions {
  display: grid;
  padding-top: 2px;
}

.macro-template-picker-insert {
  width: 100%;
  min-height: 40px;
  border-radius: 12px;
}

.macro-recorder {
  z-index: 22;
}

.macro-recorder-trigger-badge {
  font-size: 10px;
}

.macro-recorder-trigger {
  outline: none;
}

.macro-recorder-trigger:focus-visible,
.macro-recorder-trigger[data-recording="true"] {
  border-color: rgba(229, 115, 115, 0.72);
  background: #fff6f4;
  box-shadow: 0 0 0 3px rgba(229, 115, 115, 0.12);
}

.macro-template-toolbar {
  display: none;
}

.macro-template-editor {
  padding: 0;
  border: 0;
  background: transparent;
}

.macro-template-editor:empty {
  display: none;
}

.macro-step-workbench {
  grid-template-columns: minmax(220px, 300px) minmax(0, 1fr);
  align-items: start;
}

.macro-step-flow {
  gap: 6px;
  max-height: 430px;
  padding: 6px;
  background: rgba(255, 255, 255, 0.5);
}

.macro-step-row {
  display: grid;
  gap: 8px;
}

.macro-step-arrow,
.macro-step-turn {
  display: none;
}

.macro-step-card {
  position: relative;
  width: auto;
  min-width: 0;
  padding: 6px 8px 6px 38px;
}

.macro-step-card::before {
  content: counter(macro-step);
  counter-increment: macro-step;
  position: absolute;
  left: 10px;
  top: 50%;
  width: 20px;
  height: 20px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: rgba(229, 115, 115, 0.12);
  color: var(--accent-hover);
  font-size: 12px;
  font-weight: 850;
  transform: translateY(-50%);
}

.macro-step-card[data-selected="true"]::before {
  background: rgba(255, 255, 255, 0.22);
  color: #fff;
}

.macro-step-flow {
  counter-reset: macro-step;
}

.macro-step-card {
  cursor: grab;
  padding: 2px 8px 2px 32px;
}

.macro-step-card:active {
  cursor: grabbing;
}

.macro-step-card.is-dragging {
  opacity: 0.45;
}

.macro-step-card[data-drop-position] {
  box-shadow: none;
}

.macro-step-card[data-drop-position]::after {
  content: "";
  position: absolute;
  left: 8px;
  right: 8px;
  height: 2px;
  border-radius: 999px;
  background: var(--accent);
}

.macro-step-card[data-drop-position="before"]::after {
  top: -5px;
}

.macro-step-card[data-drop-position="after"]::after {
  bottom: -5px;
}

.macro-step-actions {
  display: none !important;
}

body.is-macro-step-drag-outside .macro-step-flow {
  position: relative;
  border-color: rgba(184, 35, 35, 0.32);
  background: rgba(255, 238, 238, 0.68);
}

body.is-macro-step-drag-outside .macro-step-flow::after {
  content: "松开删除";
  position: sticky;
  bottom: 0;
  display: grid;
  place-items: center;
  min-height: 34px;
  margin-top: 6px;
  border-radius: 10px;
  background: rgba(184, 35, 35, 0.1);
  color: #9b2b2b;
  font-size: 12px;
  font-weight: 850;
}

.macro-step-toggle {
  min-height: 28px;
  padding: 2px 6px;
}

.macro-step-card::before {
  left: 8px;
  width: 17px;
  height: 17px;
  font-size: 11px;
}

.macro-step-summary {
  font-size: 12px;
  line-height: 1.15;
}

.macro-step-detail {
  min-height: 100%;
}

@media (max-width: 1280px) {
  .macro-editor-workbench,
  .macro-step-workbench {
    grid-template-columns: 1fr;
  }

  .macro-section--program > .macro-section-header {
    grid-template-columns: 1fr;
  }

  .macro-section--program {
    min-height: auto;
  }
}

@container (max-width: 620px) {
  .macro-section--program > .macro-section-header,
  .macro-section--program .macro-step-workbench {
    grid-template-columns: 1fr;
  }

  .macro-section--program .macro-step-detail-pane {
    position: static;
  }
}

@media (max-width: 900px) {
  .macro-top-grid,
  .macro-builder-toolbar {
    grid-template-columns: 1fr;
  }

  .macro-action-popover {
    position: static;
    width: 100%;
    max-width: 100%;
    margin-top: 8px;
    grid-template-columns: 1fr;
  }

  .macro-action-groups {
    max-height: 190px;
    overflow: auto;
    padding: 0;
  }

  .macro-action-group-btn {
    grid-template-columns: 28px minmax(0, 1fr) auto;
  }

  .macro-action-group-count {
    display: grid;
  }

  .macro-action-list {
    max-height: 210px;
  }

  .macro-card .setting-card-header,
  .macro-title-group,
  .macro-header-actions {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .macro-card .setting-card-header,
  .macro-header-actions {
    flex-direction: column;
  }

  .macro-title-group .setting-title {
    padding-bottom: 0;
  }

  .macro-title-group .macro-name-field {
    grid-template-columns: 1fr;
  }

  .macro-title-group .macro-name-input {
    grid-column: auto;
  }

  .macro-title-group .macro-title-actions {
    grid-column: auto;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    justify-self: stretch;
  }

  .macro-title-group .macro-clear-btn,
  .macro-title-group .macro-card-save-btn,
  .macro-title-group .macro-card-import-btn,
  .macro-title-group .macro-export-btn {
    width: 100%;
    min-width: 0;
  }

  .macro-quick-actions {
    justify-content: stretch;
  }

  .macro-quick-actions .macro-clear-btn,
  .macro-builder-toolbar button {
    width: 100%;
  }
}
