.driver-home,
.driver-console {
  padding-bottom: 32px;
}
.driver-hero {
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: 18px;
  align-items: center;
  overflow: hidden;
}
.driver-hero h2 {
  font-size: 34px;
  margin: 0 0 10px;
}
.driver-hero .hero-actions {
  margin-top: 18px;
}
.hero-visual {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 240px;
}
.hero-visual img {
  max-width: 100%;
  width: 320px;
  filter: drop-shadow(0 24px 36px rgba(0, 0, 0, 0.28));
}
.lang-select-wrap select {
  min-width: 156px;
  padding-left: 18px;
}
.device-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 14px;
}
.device-card {
  background: var(--panel-2);
  border: 1px solid var(--line);
  border-radius: 18px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.device-card__media {
  padding: 20px 20px 0;
  display: flex;
  justify-content: center;
}
.device-card__media img {
  width: 180px;
}
.device-card__body {
  padding: 18px;
}
.device-card__body h4 {
  margin: 0 0 6px;
  font-size: 18px;
}
.console-grid {
  grid-template-columns: 310px minmax(0, 1fr);
}
.panel-tabs {
  padding: 10px 14px;
}
.tabbar {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.tab-btn {
  border: 1px solid var(--line);
  background: var(--panel-2);
  color: var(--muted);
  padding: 10px 16px;
  border-radius: 14px;
  cursor: pointer;
  font-weight: 700;
}
.tab-btn.active {
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #fff;
  border-color: transparent;
}
.tab-panel {
  display: none;
}
.tab-panel.active {
  display: block;
}
.compact-select {
  max-width: 160px;
}
.form-inline {
  margin-bottom: 14px;
}
.console-split {
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 16px;
}
.mouse-diagram {
  position: relative;
  min-height: 320px;
  border-radius: 18px;
  background: var(--panel-2);
  border: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.mouse-diagram img {
  width: 280px;
}
#mouse-hotspots {
  position: absolute;
  inset: 0;
}
.hotspot {
  position: absolute;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  background: rgba(99, 102, 241, 0.18);
  border: 1px solid rgba(129, 140, 248, 0.5);
  color: var(--text);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 12px;
  font-weight: 800;
}
.hotspot.active {
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #fff;
}
.macro-editor-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.action-list {
  display: grid;
  gap: 8px;
}
.action-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 14px;
  background: var(--panel-2);
  border: 1px solid var(--line);
}
.hidden {
  display: none !important;
}
[data-theme="dark"] body.app-shell {
  background:
    radial-gradient(
      circle at top right,
      rgba(99, 102, 241, 0.2),
      transparent 30%
    ),
    var(--bg);
}
@media (max-width: 1080px) {
  .driver-hero,
  .console-split,
  .macro-editor-grid,
  .console-grid {
    grid-template-columns: 1fr;
  }
}

.hid-overlay-toolbar {
  position: fixed;
  top: 18px;
  right: 18px;
  z-index: 9999;
  display: flex;
  align-items: center;
  gap: 12px;
}

.hid-overlay-toolbar .lang-select-wrap select {
  min-width: 150px;
  padding-left: 16px;
  height: 40px;
  border-radius: 12px;
  border: 1px solid var(--line, rgba(255, 255, 255, 0.16));
  background: rgba(15, 23, 42, 0.72);
  color: #fff;
  backdrop-filter: blur(12px);
}

[data-theme="light"] .hid-overlay-toolbar .lang-select-wrap select {
  background: rgba(255, 255, 255, 0.92);
  color: #111827;
}

.hid-overlay-toolbar .theme-switch {
  height: 40px;
  width: 40px;
  border-radius: 999px;
  border: 1px solid var(--line, rgba(255, 255, 255, 0.16));
  background: rgba(15, 23, 42, 0.72);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
  cursor: pointer;
  backdrop-filter: blur(12px);
}

[data-theme="light"] .hid-overlay-toolbar .theme-switch {
  background: rgba(255, 255, 255, 0.92);
  color: #111827;
}

.hid-overlay-toolbar .theme-switch svg {
  position: absolute;
  transition:
    transform 0.3s ease,
    opacity 0.3s ease;
}

.hid-overlay-toolbar .theme-switch .icon-sun {
  opacity: 0;
  transform: scale(0.75) rotate(-30deg);
}

[data-theme="light"] .hid-overlay-toolbar .theme-switch .icon-moon {
  opacity: 0;
  transform: scale(0.75) rotate(30deg);
}

[data-theme="light"] .hid-overlay-toolbar .theme-switch .icon-sun {
  opacity: 1;
  transform: scale(1) rotate(0deg);
}

.hid-demo-badge {
  position: fixed;
  left: 18px;
  bottom: 18px;
  z-index: 9999;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 88px;
  height: 40px;
  border-radius: 999px;
  padding: 0 16px;
  background: linear-gradient(
    135deg,
    var(--accent, #ff5019),
    var(--accent-2, #0052cc)
  );
  color: #fff;
  text-decoration: none;
  font-weight: 700;
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.18);
}

.vendor-like-home {
  min-height: calc(100vh - 40px);
  display: flex;
  flex-direction: column;
}

.topbar-compact {
  padding-top: 20px;
  padding-bottom: 20px;
}

.brand-driver .brand-mark {
  width: 44px;
  height: 44px;
  border-radius: 16px;
}

.vendor-home-stage {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px 0 40px;
}

.vendor-home-panel {
  width: min(980px, 100%);
  min-height: 520px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 16px;
  padding: 40px 28px;
}

.vendor-home-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
}

.primary-lg {
  min-width: 190px;
  min-height: 46px;
}

.vendor-browser-tip {
  color: var(--muted);
  font-size: 14px;
}

.vendor-count-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-size: 15px;
  font-weight: 700;
}

.vendor-device-grid {
  width: 100%;
  margin-top: 12px;
}

.console-banner {
  margin-bottom: 18px;
}

.console-banner-title {
  margin: 0 0 6px;
  font-size: 24px;
}

.vendor-console-grid {
  align-items: start;
}

.console-sidebar {
  position: sticky;
  top: 20px;
}

.device-summary-card {
  margin: 12px 0 16px;
  padding: 16px;
  border-radius: 18px;
  background: var(--panel-2);
  border: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: center;
}

.device-summary-image {
  width: 220px;
  max-width: 100%;
  filter: drop-shadow(0 20px 28px rgba(0, 0, 0, 0.18));
}

.tabbar-vertical {
  flex-direction: column;
}

.tabbar-vertical .tab-btn {
  width: 100%;
  justify-content: flex-start;
}

.section-head {
  margin-bottom: 14px;
}

.section-head h3 {
  margin-bottom: 0;
}

.console-inline-selects {
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.macro-import-bar {
  margin-bottom: 16px;
}

@media (max-width: 1080px) {
  .console-sidebar {
    position: static;
  }

  .vendor-home-panel {
    min-height: auto;
    padding: 28px 18px;
  }
}

.vendor-bg-canvas {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg, #000428 0%, #004e92 100%);
  z-index: -1;
}

.vendor-home-shell,
.vendor-console-shell {
  min-height: 100vh;
}

.vendor-topbar,
.vendor-console-topbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  padding: 12px 0 28px;
}

.vendor-console-topbar {
  align-items: center;
}

.vendor-logo-slot {
  width: 120px;
  height: 40px;
}

.toolbar-overlay {
  margin-left: auto;
}

.vendor-home-main {
  min-height: calc(100vh - 120px);
  display: flex;
  align-items: center;
  justify-content: center;
}

.vendor-home-center {
  width: min(760px, 100%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  text-align: center;
}

.primary-xl {
  min-width: 160px;
  min-height: 46px;
  border-radius: 10px;
  font-size: 16px;
}

.vendor-home-hint,
.vendor-browser-tip,
.vendor-count-row {
  color: #fff;
}

.vendor-count-row {
  font-size: 14px;
}

.vendor-home-secondary-actions {
  display: flex;
  gap: 10px;
  margin: 4px 0 10px;
}

.vendor-device-grid {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 16px;
  min-height: 260px;
}

.vendor-device-grid .device-card {
  width: 240px;
}

.vendor-console-topbar {
  padding: 8px 0 18px;
}

.vendor-back {
  width: 38px;
  height: 38px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--panel);
  border: 1px solid var(--line);
}

.vendor-back img {
  width: 18px;
  height: 18px;
}

.vendor-console-titlebox {
  flex: 1;
}

.vendor-console-titlebox h1 {
  margin: 0 0 2px;
  font-size: 24px;
}

.vendor-console-titlebox p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
}

.vendor-console-frame {
  display: grid;
  grid-template-columns: 300px minmax(0, 1fr);
  gap: 18px;
}

.vendor-left-column,
.vendor-right-column {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.vendor-status-card,
.vendor-nav-card {
  border-radius: 18px;
}

.vendor-device-hero {
  min-height: 180px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.vendor-device-hero img {
  width: 200px;
  filter: drop-shadow(0 18px 28px rgba(0, 0, 0, 0.26));
}

.vendor-badges {
  display: flex;
  gap: 8px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}

.vendor-side-actions,
.vendor-footer-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
  margin-top: 14px;
}

.vendor-nav-card {
  padding: 10px;
}

.vendor-nav-card .tab-btn {
  width: 100%;
  justify-content: flex-start;
}

.vendor-nav-card {
  display: grid;
  gap: 10px;
}

.vendor-section-head {
  margin-bottom: 12px;
}

.vendor-button-layout {
  display: grid;
  grid-template-columns: 360px minmax(0, 1fr);
  gap: 16px;
}

.vendor-import-bar {
  margin-bottom: 16px;
}

.vendor-macro-grid {
  gap: 16px;
}

.vendor-card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}

.vendor-card-header h4 {
  margin: 0;
}

.vendor-inline-selects {
  gap: 10px;
  flex-wrap: wrap;
}

#record-status.notice {
  margin-bottom: 12px;
}

@media (max-width: 1100px) {
  .vendor-console-frame,
  .vendor-button-layout,
  .macro-editor-grid {
    grid-template-columns: 1fr;
  }
}

.console-main-grid {
  display: grid;
  grid-template-columns: 320px minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}
.console-sidebar,
.console-content {
  min-height: 760px;
}
.console-sidebar {
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.console-sidebar-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.console-sidebar-head h3 {
  margin: 0 0 4px;
  font-size: 20px;
}
.console-config-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.button.small,
.ghost-btn.small {
  min-height: 38px;
  padding: 10px 12px;
  font-size: 13px;
}
.profile-list {
  display: grid;
  gap: 10px;
}
.profile-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: var(--panel-2);
}
.profile-item.active {
  border-color: var(--accent);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 30%, transparent);
}
.profile-name {
  text-align: left;
  font-weight: 700;
  color: var(--text);
}
.profile-actions {
  display: inline-flex;
  gap: 6px;
}
.ghost-icon {
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--panel);
  color: var(--muted);
  cursor: pointer;
}
.console-device-card {
  margin-top: auto;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--panel-2);
  display: grid;
  gap: 10px;
}
.console-device-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  font-size: 14px;
}
.console-content {
  padding: 18px;
}
.console-tabs-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
}
.tabbar-wide {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.console-top-actions {
  display: inline-flex;
  gap: 10px;
}
.key-settings-grid {
  display: grid;
  grid-template-columns: 390px minmax(0, 1fr);
  gap: 18px;
}
.key-library-panel,
.key-binding-panel {
  display: grid;
  gap: 14px;
}
.library-tabs {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
}
.library-tab {
  min-height: 42px;
  padding: 0 12px;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: var(--panel-2);
  color: var(--muted);
  font-weight: 700;
  cursor: pointer;
}
.library-tab.active {
  color: #fff;
  border-color: transparent;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
}
.notice.soft {
  border-style: dashed;
  background: color-mix(in srgb, var(--panel-2) 90%, transparent);
}
.library-panel {
  display: none;
}
.library-panel.active {
  display: grid;
  gap: 12px;
}
.assign-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.assign-grid-compact {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.assign-item {
  min-height: 42px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: var(--panel-2);
  color: var(--text);
  text-align: center;
  font-weight: 600;
  cursor: grab;
}
.macro-library-actions,
.macro-import-toolbar,
.macro-custom-toolbar,
.macro-slot-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}
.macro-json-box {
  min-height: 220px;
}
.binding-stage,
.binding-detail {
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--panel-2);
}
.vendor-mouse-diagram.large {
  min-height: 420px;
}
.vendor-mouse-diagram.large img {
  width: 320px;
}
.binding-detail-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 12px;
}
.button-grid-detailed {
  display: grid;
  gap: 10px;
}
.binding-card {
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--panel);
  cursor: pointer;
}
.binding-card.active,
.binding-card.drag-over {
  border-color: var(--accent);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 30%, transparent);
}
.binding-card-head {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 6px;
}
.binding-card-body {
  font-weight: 600;
}
.hotspot.drag-over {
  transform: scale(1.08);
  border-color: var(--accent);
}
.console-footer-actions {
  display: flex;
  justify-content: flex-end;
  margin-top: 12px;
}
.section-heading-block {
  margin-bottom: 14px;
}
.section-heading-block h3 {
  margin: 0 0 6px;
}
.settings-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.settings-form-grid .card-mini {
  padding: 14px;
}
.settings-form-grid label {
  display: flex;
  align-items: center;
  gap: 8px;
}
@media (max-width: 1280px) {
  .console-main-grid,
  .key-settings-grid {
    grid-template-columns: 1fr;
  }
}


.vendor-home-main {
  min-height: calc(100vh - 84px);
  display: flex;
  align-items: center;
  justify-content: center;
}

.vendor-home-center {
  width: min(920px, 92vw);
  text-align: center;
}

.vendor-home-actions {
  display: flex;
  justify-content: center;
  margin-bottom: 16px;
}

.vendor-home-secondary-actions {
  display: flex;
  justify-content: center;
  margin: 14px 0 22px;
}

.vendor-count-row {
  margin: 10px 0 16px;
  color: var(--muted);
}

.vendor-device-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 240px));
  justify-content: center;
  gap: 18px;
  margin-top: 18px;
}

.device-card {
  border-radius: 20px;
  overflow: hidden;
  text-align: center;
}

.device-card__media {
  padding-top: 18px;
}

.device-card__media img {
  width: 170px;
}

.device-card__body {
  padding: 14px 18px 20px;
}

.console-main-grid {
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: 18px;
}

.console-sidebar,
.console-content {
  border-radius: 20px;
}

.console-device-card {
  margin-top: 18px;
}

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

.key-settings-grid {
  display: grid;
  grid-template-columns: 360px minmax(0, 1fr);
  gap: 18px;
}

.key-library-panel,
.key-binding-panel {
  border: 1px solid var(--line);
  background: var(--panel-2);
  border-radius: 18px;
  padding: 16px;
}

.library-tabs {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-bottom: 12px;
}

.library-tab {
  border: 1px solid var(--line);
  background: transparent;
  border-radius: 12px;
  padding: 10px 12px;
  font-weight: 700;
  cursor: pointer;
}

.library-tab.active {
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #fff;
  border-color: transparent;
}

.assign-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(112px, 1fr));
  gap: 10px;
}

.assign-btn {
  min-height: 46px;
  border: 1px solid var(--line);
  background: var(--panel);
  color: var(--text);
  border-radius: 12px;
  padding: 10px 12px;
  font-weight: 700;
  cursor: grab;
}

.binding-detail-head.compact-head {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-bottom: 14px;
}

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

.binding-pill {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  border: 1px solid var(--line);
  background: var(--panel);
  border-radius: 14px;
  padding: 10px 12px;
}

.macro-import-toolbar.compact-toolbar {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 14px;
}

.macro-json-box.hidden,
#macro-slot.hidden,
#macro-profile-list.hidden {
  display: none !important;
}

@media (max-width: 1080px) {
  .console-main-grid,
  .key-settings-grid,
  .console-tabs-header {
    grid-template-columns: 1fr;
  }
  .console-tabs-header {
    display: grid;
  }
}


.vendor-home-header { height: 60px; position: relative; z-index: 10; }
.vendor-home-main.mimic-home-main { min-height: calc(100vh - 60px); display:flex; align-items:center; justify-content:center; padding: 12px 24px 48px; }
.vendor-home-card { display:flex; flex-direction:column; align-items:center; gap:16px; min-height:520px; justify-content:center; width:100%; }
.mimic-connect-btn { min-width: 176px; min-height: 42px; font-size: 16px; border-radius: 8px; }
.vendor-home-count { color:#fff; font-size:14px; }
.mimic-device-grid { display:flex; flex-wrap:wrap; justify-content:center; gap:24px; min-height:240px; width:100%; }
.vendor-device-card { width:240px; padding:24px; border-radius:18px; border:1px solid rgba(255,255,255,.18); background:#211a31; cursor:pointer; }
.vendor-device-card:hover { border-color:#006BEE; }
.vendor-device-card img { width:160px; margin:0 auto 16px; display:block; }
.vendor-device-card__name { color:#fff; font-size:20px; text-align:center; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.small-demo { margin-top: 4px; }

.mimic-console-header { height:60px; display:flex; justify-content:space-between; align-items:center; padding:0 24px; background:#211a31; border-bottom:1px solid #aaaaaa; }
.mimic-back-link { display:flex; align-items:center; gap:12px; color:#fff; font-size:16px; font-weight:700; }
.mimic-back-link img { width:22px; height:22px; }
.mimic-console-shell { display:flex; min-height: calc(100vh - 60px); }
.mimic-sidebar { width:250px; min-height:calc(100vh - 60px); background:#211a31; border-right:1px solid #aaaaaa; padding-bottom:18px; }
.mimic-device-title { height:60px; display:flex; align-items:center; padding:0 25px; gap:8px; color:#fff; font-size:20px; font-weight:700; }
.mimic-status-dot { width:8px; height:8px; border-radius:999px; background:#33c169; }
.mimic-divider { width:200px; margin:0 auto; border-top:1px solid #aaaaaa; }
.mimic-device-row-group { display:flex; justify-content:space-between; padding:14px 24px; color:#fff; font-size:14px; }
.mimic-device-row { display:flex; align-items:center; gap:8px; }
.mimic-config-actions { display:flex; justify-content:space-between; gap:8px; padding:0 24px 12px; }
.small-btn { width:96px; height:40px; border-radius:8px; font-size:14px; }
.mimic-sidebar .configs { padding-top: 4px; }
.mimic-sidebar .configs > div:first-child > div { padding: 0 24px !important; height: 64px; }
.mimic-console-content { flex:1; padding:24px 32px; background:transparent; }
.mimic-content-tabs { display:flex; gap:16px; margin-bottom:24px; }
.mimic-content-tabs .tab-btn { min-height:56px; min-width:160px; border-radius:12px; background:#211a31; border:1px solid rgba(255,255,255,.18); color:#fff; font-weight:700; }
.mimic-content-tabs .tab-btn.active { border:2px solid #006BEE; color:#006BEE; background:#211a31; }
.mimic-key-grid { display:grid; grid-template-columns:360px 1fr; gap:24px; }
.mimic-key-library { width:360px; border-radius:12px; background:#2b2d31; overflow:hidden; }
.mimic-subtabs { display:flex; padding-left:16px; border-bottom:1px solid rgba(255,255,255,.12); }
.mimic-subtabs .library-tab { padding:16px 8px; margin-right:12px; background:none; color:#fff; font-size:14px; font-weight:600; border-bottom:2px solid transparent; }
.mimic-subtabs .library-tab.active { color:#FF5019; border-bottom-color:#FF5019; }
.mimic-scroll-panel { padding:16px 16px 24px; height: calc(100vh - 230px); overflow:auto; }
.mimic-key-stage { min-height: calc(100vh - 180px); display:flex; align-items:flex-start; justify-content:center; }
.mimic-mouse-box { width:100%; min-height: 620px; display:flex; justify-content:center; align-items:flex-start; }
.mimic-mouse-box .mouse-diagram { width: 620px; min-height:620px; background:transparent; border:none; }
.mimic-mouse-box .mouse-diagram img { width:420px; margin-top:42px; }
.mimic-tip { color:#eeeeee; font-size:13px; margin-bottom:16px; }
.mimic-section-card { background:transparent; color:#fff; }
.mimic-section-card h3 { margin:0 0 20px; color:#fff; font-size:18px; font-weight:700; }
.inside-header { position: static; }
.checkbox-pill { display:flex; align-items:center; gap:8px; color:#fff; padding:12px 16px; border:1px solid rgba(255,255,255,.18); border-radius:12px; background:#211a31; }
.toggle-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:16px; }
.form-grid.two { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:16px; }
.field > span { display:block; margin-bottom:8px; color:#ddd; }
.dpi-stage-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:12px; margin-bottom:18px; }
.dpi-stage-item { padding:16px; border-radius:12px; background:#211a31; border:1px solid rgba(255,255,255,.18); color:#fff; }
@media (max-width: 1200px) { .mimic-key-grid { grid-template-columns:1fr; } .mimic-key-library { width:100%; } }


/* v13 incremental refinements */
.vendor-home-header__left {
  display: flex;
  align-items: center;
  min-width: 180px;
}
.home-return-link {
  font-size: 14px;
  color: var(--text);
  opacity: 0.95;
}
.vendor-home-tip {
  color: var(--muted);
  font-size: 14px;
  margin-top: -6px;
}
/* full-page theme coverage for hid */
[data-theme="light"] .mimic-console-header {
  background: #ffffff;
  border-bottom: 1px solid var(--line);
}
[data-theme="light"] .mimic-sidebar {
  background: #ffffff;
  border-right: 1px solid var(--line);
}
[data-theme="light"] .mimic-device-title,
[data-theme="light"] .mimic-device-row-group,
[data-theme="light"] .mimic-content-tabs .tab-btn,
[data-theme="light"] .mimic-back-link,
[data-theme="light"] .mimic-subtabs .library-tab,
[data-theme="light"] .mimic-section-card h3,
[data-theme="light"] .mimic-tip,
[data-theme="light"] .hotspot-label {
  color: var(--text);
}
[data-theme="light"] .mimic-divider { border-top-color: var(--line); }
[data-theme="light"] .mimic-content-tabs .tab-btn {
  background: #fff;
  border-color: var(--line);
}
[data-theme="light"] .mimic-content-tabs .tab-btn.active {
  background: #fff;
  border-color: var(--accent);
  color: var(--accent);
}
[data-theme="light"] .mimic-key-library {
  background: #fff;
  border: 1px solid var(--line);
}
[data-theme="light"] .mimic-subtabs { border-bottom-color: var(--line); }
[data-theme="light"] .mimic-subtabs .library-tab.active {
  color: var(--accent);
  border-bottom-color: var(--accent);
}
[data-theme="light"] .mimic-scroll-panel,
[data-theme="light"] .mimic-section-card,
[data-theme="light"] .mimic-console-content {
  background: transparent;
}
[data-theme="light"] .mimic-mouse-box .mouse-diagram {
  background: #fff;
  border: 1px solid var(--line);
}
[data-theme="light"] .assign-item,
[data-theme="light"] .profile-item,
[data-theme="light"] .action-row,
[data-theme="light"] .checkbox-pill,
[data-theme="light"] .field .input,
[data-theme="light"] .macro-import-toolbar .input,
[data-theme="light"] .macro-custom-toolbar .input {
  background: #f8fafc;
  color: var(--text);
  border-color: var(--line);
}
[data-theme="light"] .profile-item.active { background: #eef4ff; border-color: var(--accent); }
[data-theme="light"] .vendor-home-count { color: var(--text); }
[data-theme="light"] .vendor-browser-tip { color: var(--muted); }
#mouse-hotspots .hotspot-wrap { position: absolute; inset: 0; pointer-events: none; }
.hotspot-line {
  position: absolute;
  height: 1px;
  background: rgba(255,255,255,.45);
  transform-origin: left center;
}
[data-theme="light"] .hotspot-line { background: rgba(15, 23, 42, .35); }
.hotspot { pointer-events: auto; }
.hotspot-label {
  position: absolute;
  min-width: 72px;
  max-width: 132px;
  padding: 4px 8px;
  border-radius: 999px;
  font-size: 12px;
  line-height: 1.2;
  color: #fff;
  background: rgba(33, 26, 49, .88);
  border: 1px solid rgba(255,255,255,.15);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
[data-theme="light"] .hotspot-label {
  background: rgba(255,255,255,.96);
  border-color: var(--line);
}
.hotspot-label.active {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 20%, transparent);
}

/* v14 closer vendor match */
.vendor-console-body {
  background: var(--bg, #111827);
}

.vendor-console-header {
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 28px;
}

.vendor-back-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: inherit;
  text-decoration: none;
  font-size: 14px;
}

.vendor-console-shell {
  display: grid;
  grid-template-columns: 252px 1fr;
  min-height: calc(100vh - 64px);
}

.vendor-console-sidebar {
  border-right: 1px solid rgba(255,255,255,.14);
  background: #1b1730;
  padding: 8px 0 20px;
}

.vendor-device-panel {
  padding: 0 22px 12px;
}
.vendor-device-name-row { display:flex; align-items:center; gap:10px; font-size: 18px; }
.vendor-status-dot { width:8px; height:8px; border-radius:50%; background:#34d399; display:inline-block; }
.vendor-device-meta { margin-top: 12px; font-size: 14px; }
.vendor-device-meta .meta-row { display:flex; justify-content:space-between; padding: 8px 0; }
.vendor-profile-panel { padding-top: 8px; }
.vendor-profile-actions {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0;
  border-top:1px solid rgba(255,255,255,.12);
  border-bottom:1px solid rgba(255,255,255,.12);
}
.vendor-link-action {
  display:flex; align-items:center; justify-content:center; gap:8px;
  height: 48px; background: transparent; color: inherit; border: 0; cursor: pointer;
  font-size: 14px;
}
.vendor-link-action + .vendor-link-action { border-left:1px solid rgba(255,255,255,.12); }
.vendor-link-action__icon { font-size: 16px; line-height: 1; }
.vendor-profile-list { padding-top: 8px; }
.vendor-profile-item {
  position: relative;
  display:grid;
  grid-template-columns: 1fr auto;
  align-items:center;
  min-height: 64px;
  padding: 8px 18px 8px 24px;
  border-left: 3px solid transparent;
}
.vendor-profile-item.active { background: rgba(255,255,255,.06); border-left-color: var(--accent); }
.vendor-profile-name {
  background:none; border:0; color:inherit; text-align:left; font-size:15px; font-weight:600; cursor:pointer;
}
.vendor-profile-meta { font-size: 12px; color: var(--muted); margin-top: 4px; grid-column: 1 / span 1; }
.vendor-profile-menu-wrap { position:absolute; right: 16px; top: 14px; }
.vendor-profile-menu-btn { background:none; border:0; color:inherit; font-size:18px; width:28px; height:28px; border-radius:50%; }
.vendor-profile-menu { position:absolute; right:0; top:28px; min-width:120px; background: var(--panel, #211a31); border:1px solid var(--line); border-radius:12px; padding: 6px; z-index:20; }
.vendor-profile-menu button { width:100%; text-align:left; background:none; border:0; color:inherit; padding: 8px 10px; border-radius:8px; }
.vendor-profile-menu button:hover { background: rgba(255,255,255,.08); }
.vendor-console-main { padding: 18px 26px 28px; }
.vendor-main-tabs, .vendor-subtabs { display:flex; align-items:center; gap:24px; border-bottom:1px solid rgba(255,255,255,.10); }
.vendor-main-tabs { margin-bottom: 22px; }
.vendor-subtabs { margin-bottom: 14px; }
.vendor-main-tabs .tab-btn,
.vendor-subtabs .library-tab {
  position:relative;
  appearance:none; background:none; border:0; color:inherit; padding: 0 0 14px; font-size:15px; font-weight:600;
}
.vendor-main-tabs .tab-btn.active,
.vendor-subtabs .library-tab.active { color: var(--accent); }
.vendor-main-tabs .tab-btn.active::after,
.vendor-subtabs .library-tab.active::after {
  content:''; position:absolute; left:0; right:0; bottom:-1px; height:2px; background: var(--accent); border-radius:999px;
}
.tab-panel { display:none; }
.tab-panel.active { display:block; }
.vendor-key-layout { display:grid; grid-template-columns: 360px 1fr; gap: 28px; }
.vendor-library-body { min-height: 520px; }
.library-panel { display:none; }
.library-panel.active { display:block; }
.vertical-scroll { max-height: 520px; overflow: auto; padding-right: 6px; }
.vendor-key-list { display:flex; flex-direction:column; gap: 4px; }
.vendor-key-item {
  height: 42px; padding: 0 14px; display:flex; align-items:center; justify-content:flex-start;
  background:none; border:0; color:inherit; text-align:left; border-radius:8px; cursor:pointer; font-size:14px;
}
.vendor-key-item:hover { background: rgba(255,255,255,.06); }
.vendor-help-line { font-size: 13px; color: var(--muted); margin-bottom: 12px; min-height: 18px; }
.vendor-mouse-stage { min-height: 580px; display:flex; align-items:flex-start; justify-content:center; }
.vendor-mouse-diagram.exact { position:relative; width: 560px; max-width: 100%; margin: 20px auto 0; }
.vendor-mouse-diagram.exact img { width: 320px; margin: 0 auto; display:block; }
#mouse-hotspots { position:absolute; inset:0; }
.vendor-hotspot-wrap { position:absolute; }
.vendor-hotspot-dot {
  width: 12px; height: 12px; border-radius:50%; border:2px solid #fff; background: var(--accent); box-shadow: 0 0 0 4px rgba(255,80,25,.18);
}
.vendor-hotspot-wrap.active .vendor-hotspot-dot { transform: scale(1.12); }
.vendor-hotspot-line { position:absolute; height:1px; background: rgba(255,255,255,.6); transform-origin:left center; }
.vendor-hotspot-label {
  position:absolute; min-width: 118px; font-size: 13px; line-height:1.35; color: inherit;
}
.vendor-hotspot-label .name { display:block; color: var(--muted); }
.vendor-hotspot-label .binding { display:block; font-weight:600; }
.vendor-section-wrap { display:flex; flex-direction:column; gap: 24px; }
.vendor-dpi-grid { display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.vendor-dpi-card { padding: 14px; border-radius: 14px; border:1px solid var(--line); background: var(--panel); display:flex; flex-direction:column; gap:10px; text-align:left; }
.vendor-dpi-card.active { border-color: var(--accent); box-shadow: 0 0 0 1px rgba(255,80,25,.35); }
.vendor-dpi-card .stage { font-size: 13px; color: var(--muted); }
.vendor-dpi-card input { background:none; border:0; color:inherit; font-size: 24px; font-weight:700; outline:none; }
.vendor-dpi-card .unit { font-size: 12px; color: var(--muted); }
.vendor-field-title { font-size: 14px; font-weight: 600; margin-bottom: 10px; }
.vendor-chip-row { display:flex; flex-wrap:wrap; gap: 10px; }
.vendor-chip-row.stacked { flex-direction: column; align-items: stretch; }
.vendor-chip {
  min-height: 38px; padding: 0 14px; border-radius: 999px; border:1px solid var(--line); background: var(--panel); color:inherit;
}
.vendor-chip.active { border-color: var(--accent); color: var(--accent); }
.vendor-switch-list { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 14px; }
.vendor-switch-row { min-height: 50px; border:1px solid var(--line); border-radius: 14px; padding: 0 16px; display:flex; align-items:center; justify-content:space-between; background: var(--panel); }
.vendor-macro-toolbar { display:flex; gap: 16px; align-items:center; margin-bottom: 10px; }
.vendor-text-action { background:none; border:0; color: var(--accent); padding:0; font-size:14px; font-weight:600; }
.vendor-drawer { position:fixed; inset:0; z-index:60; }
.vendor-drawer.hidden { display:none; }
.vendor-drawer__backdrop { position:absolute; inset:0; background: rgba(0,0,0,.48); }
.vendor-drawer__panel {
  position:absolute; right:0; top:0; height:100%; width:min(520px, 100%); background: var(--bg); border-left:1px solid var(--line);
  display:flex; flex-direction:column; box-shadow:-20px 0 40px rgba(0,0,0,.24);
}
.vendor-drawer__header, .vendor-drawer__footer { padding: 18px 20px; border-bottom:1px solid var(--line); display:flex; align-items:center; justify-content:space-between; }
.vendor-drawer__footer { border-top:1px solid var(--line); border-bottom:0; margin-top:auto; }
.vendor-drawer__body { padding: 18px 20px; overflow:auto; display:flex; flex-direction:column; gap: 18px; }
.vendor-icon-close { background:none; border:0; color:inherit; font-size:24px; line-height:1; }
.vendor-recorder-actions, .vendor-custom-inline { display:flex; gap: 10px; align-items:center; }
.vendor-action-list { display:flex; flex-direction:column; gap: 8px; min-height: 160px; }
.vendor-action-row { display:flex; align-items:center; justify-content:space-between; gap: 12px; padding: 10px 12px; border:1px solid var(--line); border-radius: 12px; background: var(--panel); }

[data-theme="light"] .vendor-console-sidebar { background: #fff; border-right-color:#dde3ef; }
[data-theme="light"] .vendor-profile-item.active { background:#eef4ff; }
[data-theme="light"] .vendor-key-item:hover { background:#f5f8ff; }
[data-theme="light"] .vendor-hotspot-line { background: rgba(31,41,55,.35); }
[data-theme="light"] .vendor-console-body { background:#f5f7fb; }

@media (max-width: 1200px) {
  .vendor-console-shell { grid-template-columns: 1fr; }
  .vendor-key-layout { grid-template-columns: 1fr; }
}
