:root {
  --color-primary: #22c55e;
  --color-primary-hover: #16a34a;
  --color-primary-soft: rgba(34, 197, 94, 0.15);
  --color-accent-text: #4ade80;
  --primary: #22c55e;
  --blue: #22c55e;
}

/* Buttons */
.btn-primary,
.badge-primary {
  background-color: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
}

.btn-primary:hover,
.btn-primary:focus {
  background-color: var(--color-primary-hover) !important;
  border-color: var(--color-primary-hover) !important;
}

.btn-secondary {
  background-color: transparent !important;
  border-color: var(--color-primary) !important;
}

.btn:not(.btn-selected):hover {
  background-color: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
  color: #fff !important;
}

/* Text colors */
.text-primary {
  color: var(--color-primary) !important;
}

/* Borders and accents */
.border-primary {
  border-color: var(--color-primary) !important;
}

.nav-tabs {
  border-bottom: 1px solid var(--color-primary) !important;
}

.nav-link.active {
  background: var(--color-primary) !important;
  color: #fff !important;
}

/* Tables */
.table thead th {
  border-bottom: 2px solid var(--color-primary) !important;
}

tr:hover {
  background: var(--color-primary-soft) !important;
}

/* Scrollbar */
::-webkit-scrollbar-thumb {
  background: var(--color-primary) !important;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--color-primary-hover) !important;
}

/* Progress bar */
#progress {
  background: var(--color-primary) !important;
}

#nprogress {
  pointer-events: none;
  position: relative;
  z-index: 9999999;
}

#nprogress .bar {
  background: var(--color-primary) !important;
  position: fixed;
  z-index: 9999999;
  top: 0;
  left: 0;
  width: 100%;
  height: 2px;
}

#nprogress .peg {
  display: block;
  position: absolute;
  right: 0px;
  width: 100px;
  height: 100%;
  box-shadow: 0 0 10px var(--color-primary), 0 0 5px var(--color-primary);
  opacity: 1.0;
  transform: rotate(3deg) translate(0px, -4px);
}

/* Form controls */
.form-check-input:checked {
  background-color: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
}

.form-switch .form-check-input:checked {
  background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnIHZpZXdCb3g9Jy00IC00IDggOCc+PGNpcmNsZSByPSczJyBmaWxsPScjZmZmZmZmJy8+PC9zdmc+) !important;
}

/* Dropdowns */
.dropdown-item.active,
.dropdown-item:active {
  color: var(--color-primary) !important;
  background: 0 0 !important;
}

.dropdown-item.active.filled,
.dropdown-item.filled:active {
  color: #fff !important;
  background: var(--color-primary) !important;
}

/* Alerts */
.embedded.alert.alert-primary {
  border-color: var(--color-primary) !important;
  background-color: rgba(34, 197, 94, 0.5) !important;
  color: var(--color-accent-text) !important;
}

/* Confirm dialogs */
.jconfirm.jconfirm-neplex .jconfirm-box .jconfirm-buttons button {
  background: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
}

.jconfirm.jconfirm-neplex .jconfirm-box .jconfirm-buttons button:hover {
  background: var(--color-primary-hover) !important;
  border-color: var(--color-primary-hover) !important;
}

/* Pagination */
.paginate_button.current {
  background: var(--color-primary) !important;
  border: none !important;
}

.page-item.active .page-link {
  background-color: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
  color: #fff !important;
}

.page-link:hover,
.page-link:focus {
  color: var(--color-primary) !important;
}

.page-link {
  color: var(--color-accent-text) !important;
}

/* Badges */
.badge-primary {
  background-color: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
}

/* Calculator */
.calculator {
  color: var(--color-primary) !important;
}

.result {
  color: var(--color-primary) !important;
}

/* Selection */
::selection {
  background: var(--color-primary) !important;
  color: #fff !important;
}

::-moz-selection {
  background: var(--color-primary) !important;
  color: #fff !important;
}

/* Sidebar */
#sidebar {
  border-right: 1px solid var(--color-primary) !important;
}

/* Top message */
.top-message {
  background: linear-gradient(90deg, #16151d, var(--color-primary)) !important;
}

/* Navbar auth */
.auth-dropdown-menu {
  background: #333 !important;
  border: 1px solid var(--color-primary) !important;
  /* display, opacity, visibility управляются через inline-стили в JS и top-message-fix.css */
}

.auth-dropdown-menu.show {
  /* Гарантируем, что меню видно при наличии класса .show */
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
}

.auth-dropdown-menu a:hover {
  background: var(--color-primary-soft) !important;
}

/* Toast */
.toast.success {
  border-left: 4px solid var(--color-primary) !important;
}

/* Row removing animation */
.row-removing {
  opacity: 0;
  height: 0;
  overflow: hidden;
  transition: opacity 0.3s, height 0.3s;
}

/* Override specific colors from general.css */
#progress {
  background: var(--color-primary) !important;
}

.nprogress .bar {
  background: var(--color-primary) !important;
}

.border-primary {
  border-color: var(--color-primary) !important;
}

.text-primary {
  color: var(--color-primary) !important;
}

.btn-primary {
  background-color: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
}

.btn-primary:hover {
  background-color: var(--color-primary-hover) !important;
  border-color: var(--color-primary-hover) !important;
}

.btn-secondary {
  background-color: transparent !important;
  border-color: var(--color-primary) !important;
}

.btn:not(.btn-selected):hover {
  background-color: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
  color: #fff !important;
}

.nav-tabs {
  border-bottom: 1px solid var(--color-primary) !important;
}

.nav-link.active {
  background: var(--color-primary) !important;
  color: #fff !important;
}

.table thead th {
  border-bottom: 2px solid var(--color-primary) !important;
}

tr:hover {
  background: var(--color-primary-soft) !important;
}

::-webkit-scrollbar-thumb {
  background: var(--color-primary) !important;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--color-primary-hover) !important;
}

.form-check-input:checked {
  background-color: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
}

.form-switch .form-check-input:checked {
  background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnIHZpZXdCb3g9Jy00IC00IDggOCc+PGNpcmNsZSByPSczJyBmaWxsPScjZmZmZmZmJy8+PC9zdmc+) !important;
}

.dropdown-item.active,
.dropdown-item:active {
  color: var(--color-primary) !important;
  background: 0 0 !important;
}

.dropdown-item.active.filled,
.dropdown-item.filled:active {
  color: #fff !important;
  background: var(--color-primary) !important;
}

.embedded.alert.alert-primary {
  border-color: var(--color-primary) !important;
  background-color: rgba(34, 197, 94, 0.5) !important;
  color: var(--color-accent-text) !important;
}

.jconfirm.jconfirm-neplex .jconfirm-box .jconfirm-buttons button {
  background: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
}

.jconfirm.jconfirm-neplex .jconfirm-box .jconfirm-buttons button:hover {
  background: var(--color-primary-hover) !important;
  border-color: var(--color-primary-hover) !important;
}

.paginate_button.current {
  background: var(--color-primary) !important;
  border: none !important;
}

.badge-primary {
  background-color: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
}

.calculator {
  color: var(--color-primary) !important;
}

.result {
  color: var(--color-primary) !important;
}

::selection {
  background: var(--color-primary) !important;
  color: #fff !important;
}

::-moz-selection {
  background: var(--color-primary) !important;
  color: #fff !important;
}

#sidebar {
  border-right: 1px solid var(--color-primary) !important;
}

.top-message {
  background: linear-gradient(90deg, #16151d, var(--color-primary)) !important;
}

.auth-dropdown-menu {
  background: #333 !important;
  border: 1px solid var(--color-primary) !important;
  /* display, opacity, visibility управляются через inline-стили в JS и top-message-fix.css */
}

.auth-dropdown-menu.show {
  /* Гарантируем, что меню видно при наличии класса .show */
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
}

.auth-dropdown-menu a:hover {
  background: var(--color-primary-soft) !important;
}

.toast.success {
  border-left: 4px solid var(--color-primary) !important;
}