:root {
  color-scheme: dark;
  --app-bg: radial-gradient(circle at top, #2b3038 0%, #1c1f23 55%, #14171b 100%);
  --app-panel: #2a2f35;
  --app-panel-soft: #313741;
  --app-text: #f5f5f5;
  --app-muted: #b6bcc6;
  --app-accent: #b0b0b0;
  --app-nav: #242830;
  --app-input-bg: #1f2328;
  --app-input-border: #3a3f46;
  --app-table-bg: #22262c;
  --app-table-striped: #2b3037;
  --app-table-border: #3a3f46;
  --app-link: #d0d3d8;
}

body.app-bg {
  background: var(--app-bg);
  color: var(--app-text);
  min-height: 100vh;
}

.app-navbar {
  background: var(--app-nav);
}

.app-brand-menu {
  border-radius: 999px;
}

.dropdown-menu-dark {
  background: #222831;
  border: 1px solid var(--app-panel-soft);
}

.dropdown-item {
  color: var(--app-text);
}

.dropdown-item:hover,
.dropdown-item:focus {
  background: rgba(255, 255, 255, 0.08);
  color: var(--app-text);
}

.app-card {
  background: var(--app-panel);
  border: 1px solid var(--app-panel-soft);
  color: var(--app-text);
}

.app-card .text-secondary {
  color: var(--app-muted) !important;
}

.btn-primary {
  background-color: #5f6369;
  border-color: #5f6369;
}

.btn-primary:hover,
.btn-primary:focus {
  background-color: #70757c;
  border-color: #70757c;
}

.btn-secondary {
  background-color: #3b4047;
  border-color: #3b4047;
}

.btn-secondary:hover,
.btn-secondary:focus {
  background-color: #4a5058;
  border-color: #4a5058;
}


.form-control,
.form-select {
  background-color: var(--app-input-bg);
  border-color: var(--app-input-border);
  color: var(--app-text);
}

.form-control:focus,
.form-select:focus {
  background-color: var(--app-input-bg);
  color: var(--app-text);
  border-color: #616770;
  box-shadow: 0 0 0 0.2rem rgba(97, 103, 112, 0.25);
}

.table-dark {
  --bs-table-bg: var(--app-table-bg);
  --bs-table-striped-bg: var(--app-table-striped);
  --bs-table-striped-color: var(--app-text);
  --bs-table-color: var(--app-text);
  --bs-table-border-color: var(--app-table-border);
}

.link-light-emphasis {
  color: var(--app-link);
}

.link-light-emphasis:hover {
  color: var(--app-text);
}

[v-cloak] {
  display: none;
}

.cabinet-builder-textarea {
  min-height: 180px;
  resize: vertical;
}

.cabinet-empty-state {
  border: 1px dashed var(--app-input-border);
  border-radius: 1rem;
  padding: 1.5rem;
  background: rgba(255, 255, 255, 0.02);
}

.cabinet-bot-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.cabinet-config-card {
  border: 1px solid var(--app-panel-soft);
  border-radius: 1rem;
  padding: 1rem 1.1rem;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.015));
}

.cabinet-config-preview {
  margin: 0;
  padding: 0.85rem 0.95rem;
  border-radius: 0.85rem;
  background: rgba(0, 0, 0, 0.24);
  color: #e9edf4;
  white-space: pre-wrap;
  word-break: break-word;
  font-size: 0.875rem;
  line-height: 1.45;
}

.app-info-row {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.85rem 1rem;
  border: 1px solid var(--app-panel-soft);
  border-radius: 0.85rem;
  background: rgba(255, 255, 255, 0.02);
}

.app-subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.tg-page-grid {
  display: grid;
  gap: 1rem;
}

.tg-flow-list {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}
