/* =========================================================
   NRG THEME CORE
   ========================================================= */

:root {
  --nrg-bg-main: linear-gradient(180deg, rgba(18, 18, 14, 0.96) 0%, rgba(5, 5, 5, 0.96) 100%);
  --nrg-bg-card: linear-gradient(180deg, rgba(18, 18, 14, 0.97) 0%, rgba(5, 5, 5, 0.97) 100%);
  --nrg-bg-yellow: linear-gradient(180deg, #ffe766 0%, #ffd000 100%);
  --nrg-bg-yellow-hover: linear-gradient(180deg, #fff18a 0%, #ffd900 100%);

  --nrg-yellow: #ffd900;
  --nrg-yellow-soft: #f5d329;
  --nrg-yellow-hover: #ffe866;
  --nrg-black: #080808;
  --nrg-white: rgba(255, 255, 255, 0.88);
  --nrg-muted: rgba(255, 255, 255, 0.58);
  --nrg-red: #ff7070;

  --nrg-border: 1px solid rgba(255, 217, 0, 0.20);
  --nrg-border-strong: 1px solid rgba(255, 217, 0, 0.38);

  --nrg-radius-sm: 9px;
  --nrg-radius-md: 14px;
  --nrg-radius-lg: 16px;
  --nrg-radius-xl: 22px;

  --nrg-shadow-card:
    0 14px 34px rgba(0, 0, 0, 0.58),
    0 0 22px rgba(255, 217, 0, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);

  --nrg-shadow-btn:
    0 0 18px rgba(255, 217, 0, 0.24),
    inset 0 1px 0 rgba(255, 255, 255, 0.35);

  --nrg-transition:
    transform 0.16s ease,
    color 0.16s ease,
    background 0.16s ease,
    border-color 0.16s ease,
    box-shadow 0.16s ease;
}

/* =========================================================
   COMMON BUTTONS
   ========================================================= */

.app-button,
.navbar .nav-link,
.navbar .auth-btn,
.navbar .balance-btn,
.navbar .profile-btn,
.navbar .lang-label,
.navbar .navbar-toggler,
.profile-sidebar__link,
.modal-close-button,
.modal-primary-button {
  box-sizing: border-box;
}

.app-button.app-button--primary,
.navbar .nav-link,
.navbar .auth-btn,
.navbar .profile-btn,
.navbar .lang-label,
.navbar .navbar-toggler,
.profile-sidebar__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;

  min-height: 38px;
  padding: 0 14px;

  color: var(--nrg-yellow-soft) !important;
  background: var(--nrg-bg-main) !important;
  border: 1px solid rgba(255, 217, 0, 0.16) !important;
  border-radius: var(--nrg-radius-sm) !important;

  font-size: 12px;
  font-weight: 800;
  text-decoration: none !important;

  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.035);
  cursor: pointer;

  transition: var(--nrg-transition);
}

.app-button.app-button--primary:hover,
.navbar .nav-link:hover,
.navbar .auth-btn:hover,
.navbar .profile-btn:hover,
.navbar .lang-label:hover,
.navbar .navbar-toggler:hover,
.profile-sidebar__link:hover {
  transform: translateY(-1px);

  color: var(--nrg-black) !important;
  background: var(--nrg-bg-yellow) !important;
  border-color: rgba(255, 217, 0, 0.9) !important;

  box-shadow: var(--nrg-shadow-btn) !important;
}

.app-button.app-button--primary:active,
.navbar .nav-link:active,
.profile-sidebar__link:active {
  transform: translateY(0);
  background: #d7aa00 !important;
}

.app-button.app-button--primary:disabled,
.app-button.app-button--primary[disabled],
button:disabled {
  opacity: 0.45 !important;
  cursor: not-allowed !important;
}

.app-button__text,
.profile-sidebar__link span,
.profile-sidebar__link p {
  color: inherit !important;
  font: inherit !important;
  margin: 0 !important;
}

/* =========================================================
   NAVBAR
   ========================================================= */

.navbar {
  margin: 8px auto 0;
  max-width: 1180px;

  background: var(--nrg-bg-main);
  border: 1px solid rgba(255, 217, 0, 0.18);
  border-radius: 0 0 14px 14px;

  box-shadow:
    0 10px 28px rgba(0, 0, 0, 0.55),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);

  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);

  overflow: hidden;
}

.navbar-mobile {
  background: transparent;
}

.navbar .navbar-links {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;

  padding: 10px 12px;

  background: transparent;
  border: none;
  box-shadow: none;
}

.navbar .navbar-brand {
  padding: 9px 14px;

  color: var(--nrg-yellow) !important;
  font-weight: 900;
  letter-spacing: -0.3px;
  text-decoration: none;

  text-shadow: 0 0 12px rgba(255, 217, 0, 0.35);
}

.navbar .navbar-brand:hover {
  color: var(--nrg-yellow-hover) !important;
}

.navbar .navbar-nav,
.navbar .auth-btns {
  display: flex;
  align-items: center;
  gap: 8px;

  margin: 0;
  padding: 0;

  list-style: none;
}

.navbar .auth-btns {
  margin-left: auto;
}

.navbar .nav-item {
  margin: 0;
  padding: 0;
}

.navbar .nav-link,
.navbar .auth-btn,
.navbar .balance-btn,
.navbar .profile-btn,
.navbar .lang-label {
  min-height: 36px;
  text-transform: uppercase;
}

.navbar .balance-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;

  min-height: 36px;
  padding: 0 13px;

  color: var(--nrg-black) !important;
  background: var(--nrg-bg-yellow) !important;
  border: 1px solid rgba(255, 217, 0, 0.85) !important;
  border-radius: var(--nrg-radius-sm) !important;

  font-size: 12px;
  font-weight: 900;

  box-shadow:
    0 0 14px rgba(255, 217, 0, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.32);
}

.navbar .balance-btn:hover {
  transform: translateY(-1px);
  background: var(--nrg-bg-yellow-hover) !important;
  box-shadow:
    0 0 22px rgba(255, 217, 0, 0.34),
    inset 0 1px 0 rgba(255, 255, 255, 0.42);
}

.navbar .navbar-toggler,
.navbar .mobile-buttons {
  display: none;
}

@media (max-width: 768px) {
  .navbar {
    margin: 6px 8px 0;
    border-radius: 0 0 12px 12px;
  }

  .navbar .mobile-buttons {
    display: flex;
    align-items: center;
    gap: 8px;
  }

  .navbar .navbar-toggler {
    display: inline-flex;
  }

  .navbar .navbar-links {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }

  .navbar .navbar-nav,
  .navbar .auth-btns {
    flex-direction: column;
    align-items: stretch;
    width: 100%;
  }

  .navbar .nav-link,
  .navbar .auth-btn,
  .navbar .balance-btn,
  .navbar .profile-btn,
  .navbar .lang-label {
    width: 100%;
  }
}

/* =========================================================
   RIGHT COLUMN / MONITORING / BANNERS
   ========================================================= */

.right-column {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.right-column .monitoring,
.right-column .banner-elem {
  position: relative;

  background: var(--nrg-bg-card) !important;
  border: var(--nrg-border);
  border-radius: var(--nrg-radius-md);

  box-shadow:
    0 10px 24px rgba(0, 0, 0, 0.45),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);

  overflow: hidden;
}

.right-column .monitoring {
  margin-bottom: 10px;
  padding: 12px 14px;
}

.right-column .monitoring::before,
.right-column .banner-elem::before,
.profile-card::before,
.profile-page .left-column::before {
  content: "";
  position: absolute;
  inset: 0;

  background:
    radial-gradient(circle at top left, rgba(255, 217, 0, 0.16), transparent 42%),
    linear-gradient(90deg, rgba(255, 217, 0, 0.035), transparent 65%);

  pointer-events: none;
}

.right-column .monitoring-header,
.right-column .monitoring-progress,
.right-column .banner-item-link {
  position: relative;
  z-index: 1;
}

.right-column .monitoring-header {
  display: flex;
  align-items: center;
  justify-content: space-between;

  margin-bottom: 8px;
}

.right-column .monitoring-title {
  color: var(--nrg-yellow);
  font-size: 13px;
  font-weight: 900;
  line-height: 1.2;

  text-shadow: 0 0 10px rgba(255, 217, 0, 0.24);
}

.right-column .monitoring-title-span {
  margin-left: 4px;
  color: rgba(255, 255, 255, 0.55);
  font-size: 11px;
  font-weight: 700;
  text-transform: lowercase;
}

.right-column .monitoring-progress-bar {
  position: relative;

  height: 22px;

  background: linear-gradient(180deg, rgba(255,255,255,0.10), rgba(255,255,255,0.045));
  border: 1px solid rgba(255, 217, 0, 0.14);
  border-radius: 999px;

  overflow: hidden;

  box-shadow:
    inset 0 2px 6px rgba(0, 0, 0, 0.55),
    0 0 12px rgba(255, 217, 0, 0.08);
}

.right-column .monitoring-progress-fill {
  height: 100% !important;

  background: linear-gradient(90deg, #c99800 0%, #ffd900 55%, #fff06a 100%) !important;
  border-radius: 999px;

  box-shadow:
    0 0 14px rgba(255, 217, 0, 0.45),
    inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.right-column .monitoring-status-overlay {
  position: absolute;
  inset: 0;
  z-index: 2;

  display: flex;
  align-items: center;
  justify-content: center;
}

.right-column .monitoring-status-text {
  color: #fff;
  font-size: 12px;
  font-weight: 900;

  text-shadow:
    0 1px 2px rgba(0,0,0,0.9),
    0 0 8px rgba(0,0,0,0.75);
}

.right-column .banners-after-monitoring > div {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.right-column .banner-elem {
  min-height: unset;
  padding: 0 !important;
  color: #fff !important;
}

.right-column .banner-item-link {
  display: block;
  padding: 16px 14px;

  color: inherit !important;
  text-decoration: none;
}

.right-column .bunner-title {
  margin: 0 0 7px;

  color: var(--nrg-yellow) !important;
  font-size: 16px;
  font-weight: 900;
  line-height: 1.15;
  text-align: center;

  text-shadow: 0 0 12px rgba(255, 217, 0, 0.28);
}

.right-column .banner-content,
.right-column .banner-content p {
  margin: 0;

  color: rgba(255, 255, 255, 0.82) !important;
  font-size: 12px;
  font-weight: 600;
  line-height: 1.35;
  text-align: center;
}

/* =========================================================
   PRODUCTS
   ========================================================= */

.left-column {
  min-width: 0;
}

.left-column .products-container {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.left-column .servers-buttons,
.left-column .products-types-buttons {
  display: grid;
  gap: 8px;
}

.left-column .servers-buttons {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.left-column .products-types-buttons {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.left-column .products-types-buttons .app-button:last-child {
  grid-column: 1 / -1;
}

.left-column .app-button.app-button--primary.app-button--active,
.left-column .app-button.app-button--primary.app-button--bold {
  color: var(--nrg-black) !important;
  background: var(--nrg-bg-yellow) !important;
  border-color: rgba(255, 217, 0, 0.95) !important;

  box-shadow:
    0 0 20px rgba(255, 217, 0, 0.28),
    0 8px 18px rgba(0, 0, 0, 0.45),
    inset 0 1px 0 rgba(255, 255, 255, 0.38);
}

.left-column .search-input,
.text-input,
.recharge-panel-input {
  box-sizing: border-box;

  width: 100%;
  min-height: 44px;
  padding: 0 16px;

  color: #fff !important;
  background: var(--nrg-bg-main) !important;
  border: 1px solid rgba(255, 217, 0, 0.22) !important;
  border-radius: 10px !important;

  font-size: 13px;
  font-weight: 700;

  outline: none !important;

  box-shadow:
    0 8px 20px rgba(0,0,0,0.42),
    inset 0 1px 0 rgba(255,255,255,0.04);

  transition:
    border-color 0.18s ease,
    box-shadow 0.18s ease,
    background 0.18s ease;
}

.left-column .search-input::placeholder,
.text-input::placeholder,
.recharge-panel-input-raw::placeholder {
  color: rgba(255,255,255,0.42) !important;
}

.left-column .search-input:focus,
.text-input:focus,
.recharge-panel-input:focus-within {
  border-color: rgba(255, 217, 0, 0.62) !important;

  box-shadow:
    0 0 0 3px rgba(255,217,0,0.14),
    0 8px 20px rgba(0,0,0,0.46),
    inset 0 1px 0 rgba(255,255,255,0.05);
}

.left-column .product-cards {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.left-column .product-card {
  position: relative;

  background: var(--nrg-bg-card);
  border: 1px solid rgba(255, 217, 0, 0.18);
  border-radius: 13px;

  box-shadow:
    0 10px 24px rgba(0,0,0,0.48),
    inset 0 1px 0 rgba(255,255,255,0.04);

  overflow: hidden;

  transition:
    transform 0.18s ease,
    border-color 0.18s ease,
    box-shadow 0.18s ease;
}

.left-column .product-card:hover {
  transform: translateY(-3px);

  border-color: rgba(255,217,0,0.48);

  box-shadow:
    0 14px 30px rgba(0,0,0,0.58),
    0 0 22px rgba(255,217,0,0.16),
    inset 0 1px 0 rgba(255,255,255,0.05);
}

.left-column .product-card-image-container {
  position: relative;

  height: 170px;
  min-height: 170px;

  background-color: #050505;
  border-bottom: 1px solid rgba(255,217,0,0.14);

  overflow: hidden;
}

.left-column .product-card-image-container::after {
  content: "";
  position: absolute;
  inset: 0;

  background:
    radial-gradient(circle at top, rgba(255,217,0,0.12), transparent 48%),
    linear-gradient(180deg, transparent 62%, rgba(0,0,0,0.38) 100%);

  pointer-events: none;
}

.left-column .product-card-image-container img {
  position: relative;
  z-index: 1;

  display: block;
  width: 100%;
  height: 170px;

  object-fit: contain;

  filter:
    drop-shadow(0 8px 14px rgba(0,0,0,0.72))
    saturate(1.05);

  transition:
    transform 0.18s ease,
    filter 0.18s ease;
}

.left-column .product-card:hover .product-card-image-container img {
  transform: scale(1.035);
  filter:
    drop-shadow(0 10px 18px rgba(0,0,0,0.82))
    saturate(1.12);
}

.left-column .product-card-labels {
  position: absolute;
  top: 8px;
  left: 8px;
  z-index: 3;

  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.left-column .product-card-label {
  padding: 4px 7px;

  color: var(--nrg-black);
  background: var(--nrg-bg-yellow);
  border: 1px solid rgba(255,217,0,0.9);
  border-radius: 7px;

  font-size: 10px;
  font-weight: 900;
  line-height: 1;

  box-shadow:
    0 0 12px rgba(255,217,0,0.28),
    0 4px 10px rgba(0,0,0,0.45);
}

.left-column .product-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;

  min-height: 58px;
  padding: 10px;

  background: linear-gradient(180deg, rgba(13,13,10,0.98), rgba(5,5,5,0.98));
}

.left-column .product-card-name {
  margin: 0;

  color: rgba(255,255,255,0.92);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.25;
}

.left-column .product-card-price {
  margin: 0;

  color: var(--nrg-yellow);
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;

  text-shadow: 0 0 10px rgba(255,217,0,0.22);
}

@media (max-width: 1100px) {
  .left-column .product-cards {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 768px) {
  .left-column .servers-buttons {
    grid-template-columns: 1fr;
  }

  .left-column .products-types-buttons {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .left-column .product-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .left-column .product-card-image-container,
  .left-column .product-card-image-container img {
    height: 150px;
    min-height: 150px;
  }
}

@media (max-width: 480px) {
  .left-column .products-types-buttons,
  .left-column .product-cards {
    grid-template-columns: 1fr;
  }
}

/* =========================================================
   MODAL BASE
   ========================================================= */

.modal-overlay {
  background:
    radial-gradient(circle at center, rgba(255,217,0,0.10), transparent 38%),
    rgba(0,0,0,0.72) !important;

  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.modal-overlay .modal {
  position: relative !important;
  z-index: 1000 !important;

  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  overflow: visible !important;
}

.modal-overlay .modal-content {
  position: relative !important;
  z-index: 1001 !important;

  width: 100%;
  max-width: 430px;

  background: linear-gradient(180deg, rgba(20,18,8,0.98), rgba(5,5,5,0.98)) !important;
  border: 1px solid rgba(255,217,0,0.28) !important;
  border-radius: var(--nrg-radius-xl) !important;

  box-shadow:
    0 24px 60px rgba(0,0,0,0.75),
    0 0 34px rgba(255,217,0,0.16),
    inset 0 1px 0 rgba(255,255,255,0.05);

  overflow: visible !important;
}

.modal-overlay .modal-content::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;

  background:
    radial-gradient(circle at top left, rgba(255,217,0,0.20), transparent 42%),
    radial-gradient(circle at bottom right, rgba(255,217,0,0.10), transparent 38%),
    linear-gradient(90deg, rgba(255,217,0,0.035), transparent 60%);

  border-radius: inherit;
  pointer-events: none;
}

.modal-overlay .modal-content::after {
  content: "";
  position: absolute;
  left: 18px;
  right: 18px;
  top: 0;
  z-index: 1;

  height: 2px;

  background: linear-gradient(90deg, transparent, var(--nrg-yellow), transparent);
  opacity: 0.85;

  pointer-events: none;
}

.product-modal,
.recharge-panel {
  position: relative;
  z-index: 5;

  padding: 28px 30px 14px;

  color: #fff !important;
}

.product-modal-title,
.recharge-panel-header {
  margin: 0 0 18px;

  color: var(--nrg-yellow) !important;
  font-size: 22px;
  font-weight: 900;
  line-height: 1.15;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.4px;

  text-shadow:
    0 0 12px rgba(255,217,0,0.34),
    0 2px 8px rgba(0,0,0,0.8);
}

.product-modal-gallery {
  display: flex;
  align-items: center;
  justify-content: center;

  margin: 0 auto 18px;
  min-height: 185px;

  background:
    radial-gradient(circle at center, rgba(255,217,0,0.14), transparent 52%),
    linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.015));

  border: 1px solid rgba(255,217,0,0.14);
  border-radius: 16px;

  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.04),
    inset 0 -24px 40px rgba(0,0,0,0.26);
}

.product-modal-gallery .gallery-main-image {
  display: block;

  max-width: 100%;
  max-height: 195px;

  object-fit: contain;

  filter:
    drop-shadow(0 12px 18px rgba(0,0,0,0.78))
    saturate(1.08);
}

.product-modal-description,
.product-modal-description p {
  margin: 0 0 16px;

  color: rgba(255,255,255,0.78) !important;
  font-size: 13px;
  font-weight: 600;
  line-height: 1.45;
  text-align: center;
}

.product-modal-inputs {
  position: relative !important;
  z-index: 50 !important;

  display: flex;
  flex-direction: column;
  gap: 10px;

  overflow: visible !important;
}

.product-modal-inputs .select-container,
.product-modal-inputs .amount-control {
  width: 100%;
}

/* =========================================================
   SELECTS / DROPDOWNS
   ========================================================= */

.select-container {
  position: relative !important;
  z-index: 60 !important;
  overflow: visible !important;
}

.select-display {
  display: flex;
  align-items: center;
  justify-content: space-between;

  min-height: 42px;
  padding: 0 14px;

  color: #fff;
  background: linear-gradient(180deg, rgba(255,255,255,0.075), rgba(255,255,255,0.035)) !important;
  border: 1px solid rgba(255,217,0,0.22);
  border-radius: 10px;

  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.04),
    0 8px 18px rgba(0,0,0,0.35);

  transition:
    border-color 0.16s ease,
    box-shadow 0.16s ease;
}

.select-display:hover {
  border-color: rgba(255,217,0,0.52);
  box-shadow:
    0 0 0 3px rgba(255,217,0,0.10),
    0 8px 18px rgba(0,0,0,0.38);
}

.select-text {
  margin: 0;

  color: rgba(255,255,255,0.88) !important;
  font-size: 13px;
  font-weight: 700;
}

.select-arrow path {
  fill: var(--nrg-yellow) !important;
}

/* Жёсткий фикс: dropdown должен быть выше кнопок футера */
.modal-overlay .select-container > *:not(.select-display):not(svg),
.modal-overlay .select-options,
.modal-overlay .select-dropdown,
.modal-overlay .select-list,
.modal-overlay .select-menu {
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  top: calc(100% + 6px) !important;

  z-index: 99999 !important;

  max-height: 240px !important;
  overflow-y: auto !important;

  background: linear-gradient(180deg, rgba(18,18,14,0.99), rgba(5,5,5,0.99)) !important;
  border: 1px solid rgba(255,217,0,0.45) !important;
  border-radius: 10px !important;

  box-shadow:
    0 18px 34px rgba(0,0,0,0.85),
    0 0 22px rgba(255,217,0,0.22) !important;
}

.modal-overlay .select-option,
.modal-overlay .select-item,
.modal-overlay .select-options div,
.modal-overlay .select-dropdown div,
.modal-overlay .select-container > *:not(.select-display):not(svg) div {
  min-height: 38px !important;
  padding: 10px 12px !important;

  color: rgba(255,255,255,0.86) !important;
  background: transparent !important;

  font-size: 13px !important;
  font-weight: 800 !important;

  cursor: pointer !important;
}

.modal-overlay .select-option:hover,
.modal-overlay .select-item:hover,
.modal-overlay .select-options div:hover,
.modal-overlay .select-dropdown div:hover {
  color: var(--nrg-black) !important;
  background: var(--nrg-bg-yellow) !important;
}

/* =========================================================
   AMOUNT CONTROL
   ========================================================= */

.product-modal-inputs .amount-control {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 8px !important;
  align-items: stretch !important;
}

.product-modal-inputs .amount-control-counter {
  display: grid !important;
  grid-template-columns: 34px 1fr 34px !important;

  width: 100% !important;
  height: 46px !important;
  min-height: 46px !important;
  padding: 0 !important;

  background: linear-gradient(180deg, rgba(255,217,0,0.10), rgba(255,217,0,0.035)) !important;
  border: 1px solid rgba(255,217,0,0.38) !important;
  border-radius: 8px !important;

  overflow: hidden !important;
}

.product-modal-inputs .amount-control-counter-button {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;

  width: 34px !important;
  height: 44px !important;
  padding: 0 !important;
  margin: 0 !important;

  color: var(--nrg-yellow) !important;
  background: rgba(255,217,0,0.08) !important;

  border: none !important;
  border-radius: 0 !important;

  font-size: 14px !important;
  font-weight: 900 !important;
  line-height: 1 !important;

  box-shadow: none !important;
  cursor: pointer;
}

.product-modal-inputs .amount-control-counter-button:first-child {
  border-right: 1px solid rgba(255,217,0,0.24) !important;
}

.product-modal-inputs .amount-control-counter-button:last-child {
  border-left: 1px solid rgba(255,217,0,0.24) !important;
}

.product-modal-inputs .amount-control-counter-button:hover {
  color: var(--nrg-black) !important;
  background: var(--nrg-bg-yellow) !important;
}

.product-modal-inputs .amount-control-count {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;

  height: 44px !important;

  color: #fff !important;
  background: rgba(0,0,0,0.22) !important;

  font-size: 13px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
}

.product-modal-inputs .amount-control-total {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;

  height: 46px !important;
  min-height: 46px !important;
  padding: 0 10px !important;

  color: var(--nrg-yellow) !important;
  background: linear-gradient(180deg, rgba(255,217,0,0.14), rgba(255,217,0,0.045)) !important;
  border: 1px solid rgba(255,217,0,0.38) !important;
  border-radius: 8px !important;

  font-size: 13px !important;
  font-weight: 900 !important;
}

.product-modal-inputs .amount-control-total-rub {
  margin: 0 !important;

  color: rgba(255,255,255,0.58) !important;
  font-size: 10px !important;
  font-weight: 900 !important;
}

/* =========================================================
   MODAL FOOTER
   ========================================================= */

.modal-footer-buttons {
  position: relative !important;
  z-index: 2 !important;

  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;

  padding: 14px 30px 28px;
}

.modal-close-button,
.modal-primary-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;

  min-height: 42px;
  padding: 0 20px;

  border-radius: 12px;
  border: 1px solid transparent;

  cursor: pointer;

  transition: var(--nrg-transition);
}

.modal-close-button {
  color: rgba(255,255,255,0.62) !important;
  background: rgba(255,255,255,0.045) !important;
  border-color: rgba(255,255,255,0.08) !important;
}

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

  color: #fff !important;
  background: rgba(255,255,255,0.08) !important;
  border-color: rgba(255,255,255,0.16) !important;
}

.modal-primary-button {
  min-width: 140px;

  color: var(--nrg-black) !important;
  background: var(--nrg-bg-yellow) !important;
  border-color: rgba(255,217,0,0.9) !important;

  box-shadow:
    0 0 20px rgba(255,217,0,0.24),
    0 10px 22px rgba(0,0,0,0.42),
    inset 0 1px 0 rgba(255,255,255,0.35);
}

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

  background: var(--nrg-bg-yellow-hover) !important;

  box-shadow:
    0 0 26px rgba(255,217,0,0.38),
    0 12px 26px rgba(0,0,0,0.48),
    inset 0 1px 0 rgba(255,255,255,0.45);
}

.modal-close-button-text,
.modal-primary-button-text {
  margin: 0;

  color: inherit !important;
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
}

.modal-primary-button-text {
  text-transform: uppercase;
  letter-spacing: 0.2px;
}

/* =========================================================
   RECHARGE MODAL
   ========================================================= */

.modal-overlay .modal-content:has(.recharge-panel) {
  max-width: 720px !important;
}

.recharge-panel {
  background:
    radial-gradient(circle at top center, rgba(255,217,0,0.10), transparent 42%),
    linear-gradient(180deg, rgba(10,10,8,0.78), rgba(3,3,3,0.86)) !important;

  border-radius: 18px !important;
}

.recharge-panel-section {
  margin-bottom: 16px;
  background: transparent !important;
}

.recharge-panel-title,
.recharge-panel-label {
  margin: 0 0 8px;

  color: var(--nrg-yellow) !important;
  font-size: 12px;
  font-weight: 900;
  line-height: 1.25;
  text-transform: uppercase;

  text-shadow:
    0 1px 2px rgba(0,0,0,0.95),
    0 0 10px rgba(255,217,0,0.24);
}

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

.recharge-panel-provider {
  display: flex;
  align-items: center;
  justify-content: center;

  min-height: 52px;
  padding: 10px 12px;

  background: var(--nrg-bg-main) !important;
  border: 1px solid rgba(255,217,0,0.28) !important;
  border-radius: 12px;

  box-shadow:
    0 8px 18px rgba(0,0,0,0.38),
    inset 0 1px 0 rgba(255,255,255,0.04);

  cursor: pointer;

  transition: var(--nrg-transition);
}

.recharge-panel-provider:hover {
  transform: translateY(-1px);
  border-color: rgba(255,217,0,0.48) !important;
}

.recharge-panel-provider.selected {
  background: linear-gradient(180deg, rgba(255,217,0,0.24), rgba(35,30,6,0.96)) !important;
  border-color: rgba(255,217,0,0.85) !important;

  box-shadow:
    0 0 22px rgba(255,217,0,0.24),
    0 10px 22px rgba(0,0,0,0.46),
    inset 0 1px 0 rgba(255,255,255,0.06);
}

.recharge-panel-provider img {
  display: block;

  max-width: 130px;
  max-height: 28px;

  object-fit: contain;

  filter:
    drop-shadow(0 3px 8px rgba(0,0,0,0.7))
    brightness(1.08);
}

.recharge-panel-amount-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.recharge-panel-input {
  display: flex;
  align-items: center;

  padding: 0 14px !important;
}

.recharge-panel-input.readonly {
  justify-content: center;

  color: var(--nrg-yellow) !important;
  background: linear-gradient(180deg, rgba(255,217,0,0.18), rgba(20,18,6,0.96)) !important;
  border-color: rgba(255,217,0,0.55) !important;

  font-size: 14px;
  font-weight: 900;

  text-shadow:
    0 0 10px rgba(255,217,0,0.28),
    0 1px 2px rgba(0,0,0,0.9);
}

.recharge-panel-input-raw {
  width: 100%;
  min-height: 42px;

  color: #fff !important;
  -webkit-text-fill-color: #fff !important;

  background: transparent !important;
  border: none !important;
  outline: none !important;

  font-size: 13px;
  font-weight: 800;
}

.recharge-panel-bonuses {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;

  margin-top: 14px;
}

.recharge-panel-bonus-per-summ {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;

  min-height: 58px;
  padding: 8px 6px;

  color: rgba(255,255,255,0.78) !important;
  background: var(--nrg-bg-main) !important;
  border: 1px solid rgba(255,217,0,0.26);
  border-radius: 10px;

  font-size: 11px;
  font-weight: 800;
  text-align: center;
}

.recharge-panel-bonus {
  margin-bottom: 3px;
  padding: 3px 8px;

  color: var(--nrg-black) !important;
  background: var(--nrg-bg-yellow);
  border: 1px solid rgba(255,217,0,0.9);
  border-radius: 999px;

  font-size: 11px;
  font-weight: 900;
  line-height: 1;
}

.modal-overlay[isprimarydisabled="true"] .modal-primary-button {
  opacity: 0.65 !important;
  cursor: not-allowed !important;
  filter: grayscale(0.25);
}

@media (max-width: 760px) {
  .modal-overlay .modal-content:has(.recharge-panel) {
    max-width: calc(100vw - 28px) !important;
  }

  .product-modal,
  .recharge-panel {
    padding: 24px 18px 12px;
  }

  .recharge-panel-amount-row {
    grid-template-columns: 1fr !important;
  }

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

@media (max-width: 520px) {
  .modal-overlay .modal-content {
    max-width: calc(100vw - 28px);
    border-radius: 18px !important;
  }

  .modal-footer-buttons {
    padding: 12px 18px 24px;
    flex-direction: column-reverse;
  }

  .modal-close-button,
  .modal-primary-button {
    width: 100%;
  }

  .product-modal-title,
  .recharge-panel-header {
    font-size: 19px;
  }

  .product-modal-gallery {
    min-height: 165px;
  }

  .product-modal-gallery .gallery-main-image {
    max-height: 175px;
  }
}

@media (max-width: 420px) {
  .recharge-panel-providers,
  .recharge-panel-bonuses {
    grid-template-columns: 1fr;
  }
}

/* =========================================================
   PROFILE PAGES COMMON
   ========================================================= */

#profile-index-base-layout,
#profile-purchases-base-layout,
#profile-product-assignments-base-layout,
#profile-payments-base-layout,
#profile-promocodes-base-layout,
#profile-transfer-base-layout {
  max-width: 1180px !important;
  margin: 26px auto 0 !important;
  padding: 0 16px 40px !important;

  display: grid !important;
  grid-template-columns: minmax(640px, 1fr) 235px !important;
  gap: 20px !important;
  align-items: start !important;
}

#profile-index-base-layout .left-column,
#profile-purchases-base-layout .left-column,
#profile-product-assignments-base-layout .left-column,
#profile-payments-base-layout .left-column,
#profile-promocodes-base-layout .left-column,
#profile-transfer-base-layout .left-column {
  position: relative;

  width: 100% !important;
  min-width: 0 !important;
  padding: 20px !important;

  background: var(--nrg-bg-card) !important;
  border: 1px solid rgba(255,217,0,0.22) !important;
  border-radius: var(--nrg-radius-lg) !important;

  box-shadow: var(--nrg-shadow-card) !important;

  overflow: hidden !important;
}

#profile-index-base-layout .left-column {
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

#profile-index-base-layout .profile-info {
  position: relative;

  width: 100% !important;
  min-height: 210px;

  background: var(--nrg-bg-card) !important;
  border: 1px solid rgba(255,217,0,0.22) !important;
  border-radius: var(--nrg-radius-lg) !important;

  box-shadow: var(--nrg-shadow-card) !important;

  overflow: hidden;
}

#profile-index-base-layout .profile-info__body {
  position: relative;
  z-index: 1;

  padding: 22px 24px !important;
}

#profile-index-base-layout .profile-info__table {
  width: 100%;
  border-collapse: collapse;
}

#profile-index-base-layout .profile-info__row {
  border-bottom: 1px solid rgba(255,217,0,0.10);
}

#profile-index-base-layout .profile-info__row:last-child {
  border-bottom: none;
}

#profile-index-base-layout .profile-info__row--striped {
  background: transparent !important;
}

#profile-index-base-layout .profile-info__cell {
  padding: 14px 0 !important;

  color: rgba(255,255,255,0.88) !important;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.35;
}

#profile-index-base-layout .profile-info__cell--header {
  width: 34% !important;

  color: var(--nrg-yellow) !important;
  font-weight: 900;
  text-align: left;

  text-shadow: 0 0 10px rgba(255,217,0,0.18);
}

#profile-index-base-layout .profile-info__cell a {
  color: #ffe766 !important;
  text-decoration: none;
  font-weight: 800;
}

#profile-index-base-layout .profile-info__cell a:hover {
  color: #fff !important;
  text-shadow: 0 0 12px rgba(255,217,0,0.45);
}

#profile-purchases-base-layout .left-column h2,
#profile-product-assignments-base-layout .left-column h2,
#profile-payments-base-layout .left-column h2,
#profile-promocodes-base-layout .left-column h2,
#profile-transfer-base-layout .left-column h2 {
  position: relative;
  z-index: 1;

  margin: 0 0 16px !important;

  color: var(--nrg-yellow) !important;
  font-size: 18px !important;
  font-weight: 900 !important;
  line-height: 1.2 !important;
  text-transform: uppercase !important;

  text-shadow: 0 0 12px rgba(255,217,0,0.28) !important;
}

/* =========================================================
   PROFILE SIDEBAR COMMON
   ========================================================= */

.profile-sidebar {
  width: 235px !important;

  background: var(--nrg-bg-main) !important;
  border: 1px solid rgba(255,217,0,0.18) !important;
  border-radius: var(--nrg-radius-md) !important;

  box-shadow:
    0 10px 28px rgba(0,0,0,0.55),
    inset 0 1px 0 rgba(255,255,255,0.04) !important;

  overflow: hidden !important;
}

.profile-sidebar__header {
  padding: 14px 12px !important;

  background: var(--nrg-bg-main) !important;
  border-bottom: 1px solid rgba(255,217,0,0.18) !important;
}

.profile-sidebar__title {
  margin: 0 !important;

  color: var(--nrg-yellow) !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  text-align: center !important;
  text-transform: uppercase !important;

  text-shadow: 0 0 12px rgba(255,217,0,0.28) !important;
}

.profile-sidebar__nav {
  padding: 10px !important;
}

.profile-sidebar__list {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;

  margin: 0 !important;
  padding: 0 !important;

  list-style: none !important;
}

.profile-sidebar__item {
  margin: 0 !important;
  padding: 0 !important;
}

.profile-sidebar__link,
.profile-sidebar__link:link,
.profile-sidebar__link:visited {
  width: 100% !important;
  min-height: 38px !important;
}

.profile-sidebar__link--active {
  color: var(--nrg-black) !important;
  background: var(--nrg-bg-yellow) !important;
  border-color: rgba(255,217,0,0.9) !important;

  box-shadow: var(--nrg-shadow-btn) !important;
}

.profile-sidebar__footer {
  padding: 0 10px 10px !important;
  border-top: 1px solid rgba(255,217,0,0.12) !important;
}

.profile-sidebar__footer .profile-sidebar__link {
  color: var(--nrg-red) !important;
  background: var(--nrg-bg-main) !important;
  border-color: rgba(255,70,70,0.24) !important;
}

.profile-sidebar__footer .profile-sidebar__link:hover {
  color: #fff !important;
  background: linear-gradient(180deg, rgba(170,35,35,0.95), rgba(90,12,12,0.95)) !important;
  border-color: rgba(255,90,90,0.55) !important;

  box-shadow:
    0 0 18px rgba(255,70,70,0.22),
    inset 0 1px 0 rgba(255,255,255,0.10) !important;
}

/* =========================================================
   PROFILE TABLES COMMON
   ========================================================= */

#profile-purchases-base-layout table,
#profile-product-assignments-base-layout table,
#profile-payments-base-layout table,
#profile-transfer-base-layout table,
#profile-purchases-base-layout .table,
#profile-product-assignments-base-layout .table,
#profile-payments-base-layout .table,
#profile-transfer-base-layout .table,
#profile-purchases-base-layout thead,
#profile-product-assignments-base-layout thead,
#profile-payments-base-layout thead,
#profile-transfer-base-layout thead,
#profile-purchases-base-layout tbody,
#profile-product-assignments-base-layout tbody,
#profile-payments-base-layout tbody,
#profile-transfer-base-layout tbody,
#profile-purchases-base-layout tr,
#profile-product-assignments-base-layout tr,
#profile-payments-base-layout tr,
#profile-transfer-base-layout tr,
#profile-purchases-base-layout th,
#profile-product-assignments-base-layout th,
#profile-payments-base-layout th,
#profile-transfer-base-layout th,
#profile-purchases-base-layout td,
#profile-product-assignments-base-layout td,
#profile-payments-base-layout td,
#profile-transfer-base-layout td {
  background-color: transparent !important;
  color: rgba(255,255,255,0.86) !important;
}

#profile-purchases-base-layout .table,
#profile-product-assignments-base-layout .table,
#profile-payments-base-layout .table,
#profile-transfer-base-layout .table {
  position: relative;
  z-index: 1;

  width: 100% !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;

  background: var(--nrg-bg-card) !important;
  border: 1px solid rgba(255,217,0,0.22) !important;
  border-radius: 12px !important;

  overflow: hidden !important;

  box-shadow:
    0 10px 24px rgba(0,0,0,0.42),
    inset 0 1px 0 rgba(255,255,255,0.035) !important;
}

#profile-purchases-base-layout .table thead tr,
#profile-product-assignments-base-layout .table thead tr,
#profile-payments-base-layout .table thead tr,
#profile-transfer-base-layout .table thead tr {
  background: linear-gradient(180deg, rgba(255,217,0,0.18), rgba(255,217,0,0.06)) !important;
}

#profile-purchases-base-layout .table th,
#profile-product-assignments-base-layout .table th,
#profile-payments-base-layout .table th,
#profile-transfer-base-layout .table th {
  padding: 13px 12px !important;

  color: var(--nrg-yellow) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  line-height: 1.2 !important;
  text-align: left !important;
  white-space: nowrap !important;

  border-bottom: 1px solid rgba(255,217,0,0.22) !important;

  text-shadow: 0 0 10px rgba(255,217,0,0.18) !important;
}

#profile-purchases-base-layout .table td,
#profile-product-assignments-base-layout .table td,
#profile-payments-base-layout .table td,
#profile-transfer-base-layout .table td {
  padding: 13px 12px !important;

  color: rgba(255,255,255,0.86) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  line-height: 1.35 !important;

  border-top: 1px solid rgba(255,217,0,0.08) !important;
}

#profile-purchases-base-layout .table tbody tr,
#profile-product-assignments-base-layout .table tbody tr,
#profile-payments-base-layout .table tbody tr,
#profile-transfer-base-layout .table tbody tr {
  background: rgba(255,255,255,0.02) !important;
}

#profile-purchases-base-layout .table tbody tr:hover,
#profile-product-assignments-base-layout .table tbody tr:hover,
#profile-payments-base-layout .table tbody tr:hover,
#profile-transfer-base-layout .table tbody tr:hover {
  background: rgba(255,217,0,0.07) !important;
}

#empty-row td {
  padding: 28px 16px !important;

  color: rgba(255,255,255,0.58) !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  text-align: center !important;

  background: radial-gradient(circle at center, rgba(255,217,0,0.08), transparent 48%) !important;
}

/* =========================================================
   PAGINATION COMMON
   ========================================================= */

.mt-4.flex.justify-center.gap-2 {
  position: relative;
  z-index: 1;

  display: flex !important;
  justify-content: center !important;
  gap: 8px !important;

  margin-top: 16px !important;
}

.mt-4.flex.justify-center.gap-2 button,
button.rounded,
.rounded.border {
  min-height: 36px !important;
  padding: 0 14px !important;

  color: var(--nrg-yellow-soft) !important;
  background: var(--nrg-bg-main) !important;
  border: 1px solid rgba(255,217,0,0.18) !important;
  border-radius: 9px !important;

  font-size: 12px !important;
  font-weight: 900 !important;
  line-height: 1 !important;

  box-shadow: inset 0 1px 0 rgba(255,255,255,0.035) !important;
}

.mt-4.flex.justify-center.gap-2 button:hover:not(:disabled),
button.rounded:hover:not(:disabled),
.rounded.border:hover:not(:disabled) {
  transform: translateY(-1px) !important;

  color: var(--nrg-black) !important;
  background: var(--nrg-bg-yellow) !important;
  border-color: rgba(255,217,0,0.9) !important;

  box-shadow: var(--nrg-shadow-btn) !important;
}

/* =========================================================
   PROMOCODE / TRANSFER FORMS
   ========================================================= */

#profile-promocodes-base-layout form {
  position: relative;
  z-index: 1;

  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 150px !important;
  gap: 10px !important;
  width: 100% !important;
}

#profile-promocodes-base-layout .app-button.app-button--success,
#profile-transfer-base-layout .app-button.app-button--primary.w-full {
  width: 100% !important;
  min-height: 44px !important;
  padding: 0 16px !important;

  color: var(--nrg-black) !important;
  background: var(--nrg-bg-yellow) !important;
  border: 1px solid rgba(255,217,0,0.9) !important;
  border-radius: 10px !important;

  font-size: 12px !important;
  font-weight: 900 !important;

  box-shadow:
    0 0 18px rgba(255,217,0,0.24),
    0 8px 18px rgba(0,0,0,0.45),
    inset 0 1px 0 rgba(255,255,255,0.35) !important;
}

#profile-transfer-base-layout .form {
  margin-bottom: 26px !important;
  padding: 16px !important;

  background: linear-gradient(180deg, rgba(12,12,9,0.96), rgba(5,5,5,0.96)) !important;
  border: 1px solid rgba(255,217,0,0.18) !important;
  border-radius: 12px !important;

  box-shadow:
    0 10px 24px rgba(0,0,0,0.42),
    inset 0 1px 0 rgba(255,255,255,0.035) !important;
}

#profile-transfer-base-layout label,
#profile-transfer-base-layout #form-amount-inputs > div {
  color: rgba(255,255,255,0.82) !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  line-height: 1.35 !important;
}

#profile-transfer-base-layout #form-amount-inputs {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 12px !important;
}

#profile-transfer-base-layout .text-input.disabled,
#profile-transfer-base-layout .text-input[readonly] {
  color: rgba(255,217,0,0.82) !important;
  background: linear-gradient(180deg, rgba(255,217,0,0.10), rgba(255,217,0,0.035)) !important;
  border-color: rgba(255,217,0,0.28) !important;
  cursor: not-allowed !important;
}

#profile-transfer-base-layout input[type="checkbox"] {
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;

  accent-color: var(--nrg-yellow);
  cursor: pointer !important;
}

#profile-transfer-base-layout .flex.items-center {
  display: flex !important;
  align-items: flex-start !important;
  gap: 9px !important;

  padding: 12px !important;

  background: rgba(255,217,0,0.045) !important;
  border: 1px solid rgba(255,217,0,0.14) !important;
  border-radius: 10px !important;
}

#profile-transfer-base-layout .flex.items-center label {
  margin: 0 !important;

  color: rgba(255,255,255,0.68) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
}

/* =========================================================
   WHITE / TAILWIND FIXES
   ========================================================= */

.bg-white,
.bg-gray-50,
.bg-gray-100,
.hover\:bg-gray-200:hover {
  background: var(--nrg-bg-card) !important;
}

/* =========================================================
   RESPONSIVE PROFILE
   ========================================================= */

@media (max-width: 900px) {
  #profile-index-base-layout,
  #profile-purchases-base-layout,
  #profile-product-assignments-base-layout,
  #profile-payments-base-layout,
  #profile-promocodes-base-layout,
  #profile-transfer-base-layout {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
    margin-top: 18px !important;
  }

  #profile-index-base-layout .right-column,
  #profile-purchases-base-layout .right-column,
  #profile-product-assignments-base-layout .right-column,
  #profile-payments-base-layout .right-column,
  #profile-promocodes-base-layout .right-column,
  #profile-transfer-base-layout .right-column {
    order: -1;
  }

  .profile-sidebar {
    width: 100% !important;
  }

  .profile-sidebar__list {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .table {
    display: block !important;
    overflow-x: auto !important;
    white-space: nowrap !important;
  }
}

@media (max-width: 640px) {
  #profile-transfer-base-layout #form-amount-inputs {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 520px) {
  #profile-index-base-layout,
  #profile-purchases-base-layout,
  #profile-product-assignments-base-layout,
  #profile-payments-base-layout,
  #profile-promocodes-base-layout,
  #profile-transfer-base-layout {
    padding: 0 10px 30px !important;
  }

  #profile-purchases-base-layout .left-column,
  #profile-product-assignments-base-layout .left-column,
  #profile-payments-base-layout .left-column,
  #profile-promocodes-base-layout .left-column,
  #profile-transfer-base-layout .left-column {
    padding: 14px !important;
  }

  #profile-promocodes-base-layout form,
  #profile-transfer-base-layout #form-amount-inputs {
    grid-template-columns: 1fr !important;
  }

  .profile-sidebar__list {
    grid-template-columns: 1fr !important;
  }

  #profile-index-base-layout .profile-info__cell {
    display: block;
    width: 100%;
    padding: 6px 0 !important;
  }

  #profile-index-base-layout .profile-info__cell--header {
    padding-top: 12px !important;
  }
}

/* ===== FIX PRODUCT MODAL SELECT OVERLAP / TRANSPARENCY ===== */

/* Все селекты по умолчанию ниже */
.modal-overlay .product-modal-inputs .select-container {
  position: relative !important;
  z-index: 10 !important;
  overflow: visible !important;
}

/* Селект, который сейчас открыт, поднимаем выше остальных */
.modal-overlay .product-modal-inputs .select-container:focus-within,
.modal-overlay .product-modal-inputs .select-container:has(.select-options),
.modal-overlay .product-modal-inputs .select-container:has(.select-dropdown),
.modal-overlay .product-modal-inputs .select-container:has(.select-list),
.modal-overlay .product-modal-inputs .select-container:has(.select-menu) {
  z-index: 99999 !important;
}

/* Закрытая строка селекта */
.modal-overlay .product-modal-inputs .select-display {
  position: relative !important;
  z-index: 2 !important;
}

/* Сам выпадающий список */
.modal-overlay .product-modal-inputs .select-options,
.modal-overlay .product-modal-inputs .select-dropdown,
.modal-overlay .product-modal-inputs .select-list,
.modal-overlay .product-modal-inputs .select-menu {
  position: absolute !important;

  left: 0 !important;
  right: 0 !important;
  top: calc(100% + 6px) !important;

  z-index: 100000 !important;

  max-height: 230px !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;

  background: #050505 !important;
  background-image: linear-gradient(180deg, #11100b 0%, #050505 100%) !important;

  border: 1px solid rgba(255, 217, 0, 0.55) !important;
  border-radius: 10px !important;

  box-shadow:
    0 18px 34px rgba(0, 0, 0, 0.95),
    0 0 22px rgba(255, 217, 0, 0.24) !important;

  opacity: 1 !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

/* Жёсткая непрозрачная подложка внутри списка */
.modal-overlay .product-modal-inputs .select-options::before,
.modal-overlay .product-modal-inputs .select-dropdown::before,
.modal-overlay .product-modal-inputs .select-list::before,
.modal-overlay .product-modal-inputs .select-menu::before {
  content: "";
  position: absolute;
  inset: 0;

  z-index: -1;

  background: #050505 !important;
  border-radius: inherit;
}

/* Элементы списка тоже делаем непрозрачными */
.modal-overlay .product-modal-inputs .select-option,
.modal-overlay .product-modal-inputs .select-item,
.modal-overlay .product-modal-inputs .select-options > div,
.modal-overlay .product-modal-inputs .select-dropdown > div,
.modal-overlay .product-modal-inputs .select-list > div,
.modal-overlay .product-modal-inputs .select-menu > div {
  position: relative !important;
  z-index: 1 !important;

  min-height: 38px !important;
  padding: 10px 12px !important;

  color: rgba(255, 255, 255, 0.9) !important;
  background: #050505 !important;

  font-size: 13px !important;
  font-weight: 800 !important;
  line-height: 1.2 !important;

  cursor: pointer !important;
}

.modal-overlay .product-modal-inputs .select-option:hover,
.modal-overlay .product-modal-inputs .select-item:hover,
.modal-overlay .product-modal-inputs .select-options > div:hover,
.modal-overlay .product-modal-inputs .select-dropdown > div:hover,
.modal-overlay .product-modal-inputs .select-list > div:hover,
.modal-overlay .product-modal-inputs .select-menu > div:hover {
  color: #080808 !important;
  background: linear-gradient(180deg, #ffe766 0%, #ffd000 100%) !important;
}

/* Футер и кнопки ниже любого открытого селекта */
.modal-overlay .modal-footer-buttons,
.modal-overlay .modal-close-button,
.modal-overlay .modal-primary-button {
  position: relative !important;
  z-index: 1 !important;
}

/* Модалка не должна обрезать список */
.modal-overlay .modal,
.modal-overlay .modal-content,
.modal-overlay .product-modal,
.modal-overlay .product-modal-inputs {
  overflow: visible !important;
}

/* =========================================================
   ROULETTE MODAL
   ========================================================= */

/* Ширина окна именно для рулетки */
.modal-overlay .modal-content:has(.roulette-modal) {
  max-width: 860px !important;
  width: calc(100vw - 40px) !important;

  overflow: hidden !important;
}

/* Контейнер рулетки */
.modal-overlay .roulette-modal {
  position: relative;
  z-index: 5;

  padding: 28px 30px 14px;

  color: #ffffff !important;
}

/* Заголовок рулетки использует общий product-modal-title */
.modal-overlay .roulette-modal .product-modal-title {
  margin-bottom: 20px !important;
}

/* =========================================================
   ROULETTE WINDOW / TRACK
   ========================================================= */

.modal-overlay .roulette-wrapper {
  position: relative;

  width: 100%;
  height: 185px;
  margin: 0 0 22px;

  background:
    radial-gradient(circle at center, rgba(255, 217, 0, 0.13), transparent 55%),
    linear-gradient(180deg, rgba(18, 18, 14, 0.98), rgba(5, 5, 5, 0.98)) !important;

  border: 1px solid rgba(255, 217, 0, 0.32);
  border-radius: 16px;

  box-shadow:
    0 14px 32px rgba(0, 0, 0, 0.56),
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    inset 0 -30px 50px rgba(0, 0, 0, 0.42);

  overflow: hidden;
}

/* Затемнение краёв */
.modal-overlay .roulette-wrapper::before,
.modal-overlay .roulette-wrapper::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  z-index: 8;

  width: 110px;
  pointer-events: none;
}

.modal-overlay .roulette-wrapper::before {
  left: 0;
  background: linear-gradient(90deg, rgba(0, 0, 0, 0.92), transparent);
}

.modal-overlay .roulette-wrapper::after {
  right: 0;
  background: linear-gradient(270deg, rgba(0, 0, 0, 0.92), transparent);
}

/* Центральная линия выбора */
.modal-overlay .roulette-window {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  z-index: 12;

  width: 2px;

  background: linear-gradient(180deg, transparent, #ffd900 20%, #ffd900 80%, transparent);

  box-shadow:
    0 0 14px rgba(255, 217, 0, 0.75),
    0 0 28px rgba(255, 217, 0, 0.34);

  transform: translateX(-50%);
  pointer-events: none;
}

/* Маркер сверху */
.modal-overlay .roulette-window::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;

  width: 0;
  height: 0;

  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-top: 13px solid #ffd900;

  filter: drop-shadow(0 0 10px rgba(255, 217, 0, 0.75));

  transform: translateX(-50%);
}

/* Маркер снизу */
.modal-overlay .roulette-window::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;

  width: 0;
  height: 0;

  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-bottom: 13px solid #ffd900;

  filter: drop-shadow(0 0 10px rgba(255, 217, 0, 0.75));

  transform: translateX(-50%);
}

/* Лента рулетки */
.modal-overlay .roulette-track {
  position: relative;
  z-index: 4;

  display: flex;
  align-items: center;
  gap: 10px;

  height: 100%;
  padding: 16px;

  will-change: transform;
}

/* Карточка предмета в ленте */
.modal-overlay .roulette-item {
  flex: 0 0 132px;

  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;

  height: 148px;
  padding: 10px 8px;

  background:
    linear-gradient(180deg, rgba(255, 217, 0, 0.085), rgba(5, 5, 5, 0.98)) !important;

  border: 1px solid rgba(255, 217, 0, 0.22);
  border-radius: 12px;

  box-shadow:
    0 10px 20px rgba(0, 0, 0, 0.48),
    inset 0 1px 0 rgba(255, 255, 255, 0.035);

  overflow: hidden;
}

.modal-overlay .roulette-item img {
  display: block;

  width: 86px;
  height: 86px;

  object-fit: contain;

  filter:
    drop-shadow(0 8px 12px rgba(0, 0, 0, 0.75))
    saturate(1.08);
}

.modal-overlay .roulette-item-name {
  width: 100%;
  margin-top: 8px;

  color: rgba(255, 255, 255, 0.88) !important;

  font-size: 11px;
  font-weight: 800;
  line-height: 1.2;
  text-align: center;

  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

/* =========================================================
   POSSIBLE PRIZES
   ========================================================= */

.modal-overlay .roulette-prizes {
  margin: 0 0 16px;
}

.modal-overlay .roulette-prizes-title {
  margin: 0 0 10px;

  color: #ffd900 !important;

  font-size: 14px;
  font-weight: 900;
  line-height: 1.2;
  text-transform: uppercase;
  text-align: center;

  text-shadow: 0 0 12px rgba(255, 217, 0, 0.28);
}

.modal-overlay .roulette-prizes-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 8px;

  max-height: 260px;
  padding: 2px 4px 4px;

  overflow-y: auto;
  overflow-x: hidden;
}

/* Скролл призов */
.modal-overlay .roulette-prizes-grid::-webkit-scrollbar {
  width: 8px;
}

.modal-overlay .roulette-prizes-grid::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.05);
  border-radius: 999px;
}

.modal-overlay .roulette-prizes-grid::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, #ffe766 0%, #ffd000 100%);
  border-radius: 999px;
}

/* Карточка возможного приза */
.modal-overlay .roulette-prize-card {
  min-height: 116px;
  padding: 8px 6px;

  background:
    linear-gradient(180deg, rgba(18, 18, 14, 0.98), rgba(5, 5, 5, 0.98)) !important;

  border: 1px solid rgba(255, 217, 0, 0.18);
  border-radius: 10px;

  box-shadow:
    0 8px 18px rgba(0, 0, 0, 0.38),
    inset 0 1px 0 rgba(255, 255, 255, 0.035);

  transition:
    transform 0.16s ease,
    border-color 0.16s ease,
    box-shadow 0.16s ease;
}

.modal-overlay .roulette-prize-card:hover {
  transform: translateY(-2px);

  border-color: rgba(255, 217, 0, 0.44);

  box-shadow:
    0 12px 24px rgba(0, 0, 0, 0.5),
    0 0 16px rgba(255, 217, 0, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.modal-overlay .roulette-prize-image {
  display: flex;
  align-items: center;
  justify-content: center;

  height: 62px;
  margin-bottom: 7px;
}

.modal-overlay .roulette-prize-image img {
  display: block;

  max-width: 62px;
  max-height: 62px;

  object-fit: contain;

  filter:
    drop-shadow(0 6px 10px rgba(0, 0, 0, 0.72))
    saturate(1.08);
}

.modal-overlay .roulette-prize-name {
  color: rgba(255, 255, 255, 0.84) !important;

  font-size: 10.5px;
  font-weight: 800;
  line-height: 1.18;
  text-align: center;

  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

/* =========================================================
   ROULETTE BOTTOM INPUTS
   ========================================================= */

.modal-overlay .roulette-modal .product-modal-inputs {
  display: grid !important;
  grid-template-columns: 180px minmax(0, 1fr) !important;
  gap: 10px !important;
  align-items: center !important;

  margin-top: 14px;
}

/* Цена */
.modal-overlay .roulette-modal .amount-control {
  display: block !important;
  width: 100% !important;
}

.modal-overlay .roulette-modal .amount-control-total {
  width: 100% !important;
}

/* Селект сервера */
.modal-overlay .roulette-modal .select-container {
  width: 100% !important;
}

/* =========================================================
   ROULETTE MODAL FOOTER FIX
   ========================================================= */

.modal-overlay .modal-content:has(.roulette-modal) .modal-footer-buttons {
  padding-top: 4px !important;
}

/* =========================================================
   ROULETTE RESPONSIVE
   ========================================================= */

@media (max-width: 900px) {
  .modal-overlay .modal-content:has(.roulette-modal) {
    max-width: calc(100vw - 28px) !important;
  }

  .modal-overlay .roulette-prizes-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .modal-overlay .roulette-modal {
    padding: 24px 18px 12px;
  }

  .modal-overlay .roulette-wrapper {
    height: 165px;
  }

  .modal-overlay .roulette-item {
    flex-basis: 116px;
    height: 132px;
  }

  .modal-overlay .roulette-item img {
    width: 74px;
    height: 74px;
  }

  .modal-overlay .roulette-prizes-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    max-height: 230px;
  }

  .modal-overlay .roulette-modal .product-modal-inputs {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 420px) {
  .modal-overlay .roulette-prizes-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* =========================================================
   ROULETTE WIDTH / CLIPPING FIX
   ========================================================= */

/* модалка рулетки не должна выходить за экран */
.modal-overlay .modal-content:has(.roulette-modal) {
  width: min(96vw, 980px) !important;
  max-width: min(96vw, 980px) !important;
  box-sizing: border-box !important;

  overflow: visible !important;
}

/* сама модалка внутри */
.modal-overlay .roulette-modal {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
}

/* окно рулетки не должно вылезать вправо */
.modal-overlay .roulette-wrapper {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;

  overflow: hidden !important;
}

/* лента может быть длинной, но она должна обрезаться внутри окна рулетки */
.modal-overlay .roulette-track {
  width: max-content !important;
  min-width: max-content !important;
  max-width: none !important;
}

/* сетка призов должна укладываться в ширину модалки */
.modal-overlay .roulette-prizes {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
}

.modal-overlay .roulette-prizes-grid {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;

  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;

  overflow-y: auto !important;
  overflow-x: hidden !important;
}

/* карточки призов не должны растягивать сетку */
.modal-overlay .roulette-prize-card,
.modal-overlay .roulette-item {
  min-width: 0 !important;
  box-sizing: border-box !important;
}

.modal-overlay .roulette-prize-name,
.modal-overlay .roulette-item-name {
  max-width: 100% !important;
  word-break: normal !important;
  overflow-wrap: anywhere !important;
}

/* нижний блок цена + сервер */
.modal-overlay .roulette-modal .product-modal-inputs {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;

  grid-template-columns: 180px minmax(0, 1fr) !important;
}

.modal-overlay .roulette-modal .select-container,
.modal-overlay .roulette-modal .amount-control,
.modal-overlay .roulette-modal .amount-control-total {
  min-width: 0 !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

/* =========================================================
   ROULETTE SELECT DROPDOWN VISIBILITY FIX
   ========================================================= */

/* сама модалка рулетки не должна резать селект */
.modal-overlay .modal-content:has(.roulette-modal),
.modal-overlay .roulette-modal {
  overflow: visible !important;
}

/* обрезку оставляем только там, где она реально нужна */
.modal-overlay .roulette-wrapper {
  overflow: hidden !important;
}

.modal-overlay .roulette-prizes {
  overflow: hidden !important;
}

.modal-overlay .roulette-prizes-grid {
  overflow-y: auto !important;
  overflow-x: hidden !important;
}

/* нижний блок с ценой и выбором сервера поверх всего */
.modal-overlay .roulette-modal .product-modal-inputs {
  position: relative !important;
  z-index: 9999 !important;

  overflow: visible !important;
}

/* селект сервера */
.modal-overlay .roulette-modal .select-container {
  position: relative !important;
  z-index: 10000 !important;

  overflow: visible !important;
}

/* открытый список сервера */
.modal-overlay .roulette-modal .select-options,
.modal-overlay .roulette-modal .select-dropdown,
.modal-overlay .roulette-modal .select-list,
.modal-overlay .roulette-modal .select-menu {
  position: absolute !important;

  left: 0 !important;
  right: 0 !important;
  top: calc(100% + 6px) !important;

  z-index: 100000 !important;

  max-height: 220px !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;

  background: #050505 !important;
  background-image: linear-gradient(180deg, #11100b 0%, #050505 100%) !important;

  border: 1px solid rgba(255, 217, 0, 0.55) !important;
  border-radius: 10px !important;

  box-shadow:
    0 18px 34px rgba(0, 0, 0, 0.95),
    0 0 22px rgba(255, 217, 0, 0.24) !important;

  opacity: 1 !important;
}

/* пункты списка */
.modal-overlay .roulette-modal .select-option,
.modal-overlay .roulette-modal .select-item,
.modal-overlay .roulette-modal .select-options > div,
.modal-overlay .roulette-modal .select-dropdown > div,
.modal-overlay .roulette-modal .select-list > div,
.modal-overlay .roulette-modal .select-menu > div {
  min-height: 38px !important;
  padding: 10px 12px !important;

  color: rgba(255, 255, 255, 0.9) !important;
  background: #050505 !important;

  font-size: 13px !important;
  font-weight: 800 !important;
  line-height: 1.2 !important;

  cursor: pointer !important;
}

.modal-overlay .roulette-modal .select-option:hover,
.modal-overlay .roulette-modal .select-item:hover,
.modal-overlay .roulette-modal .select-options > div:hover,
.modal-overlay .roulette-modal .select-dropdown > div:hover,
.modal-overlay .roulette-modal .select-list > div:hover,
.modal-overlay .roulette-modal .select-menu > div:hover {
  color: #080808 !important;
  background: linear-gradient(180deg, #ffe766 0%, #ffd000 100%) !important;
}

/* кнопки футера ниже dropdown */
.modal-overlay .modal-content:has(.roulette-modal) .modal-footer-buttons,
.modal-overlay .modal-content:has(.roulette-modal) .modal-close-button,
.modal-overlay .modal-content:has(.roulette-modal) .modal-primary-button {
  position: relative !important;
  z-index: 1 !important;
}

/* ===== ROULETTE LOGIC SIZE SYNC FIX ===== */

.modal-overlay .roulette-track {
  gap: 12px !important;
}

.modal-overlay .roulette-item {
  flex: 0 0 100px !important;
  width: 100px !important;
  min-width: 100px !important;
  max-width: 100px !important;

  height: 124px !important;
  padding: 8px 6px !important;
}

.modal-overlay .roulette-item img {
  width: 62px !important;
  height: 62px !important;
}

.modal-overlay .roulette-item-name {
  font-size: 10px !important;
  line-height: 1.15 !important;
}

/* =========================================================
   PRODUCT MODAL SELECT SCROLLBAR STYLE
   ========================================================= */

/* сам список */
.modal-overlay .product-modal .select-options,
.modal-overlay .product-modal .select-dropdown,
.modal-overlay .product-modal .select-list,
.modal-overlay .product-modal .select-menu {
  scrollbar-width: thin !important;
  scrollbar-color: #ffd900 rgba(255, 255, 255, 0.06) !important;

  padding-right: 4px !important;
}

/* Chrome / Edge / Safari */
.modal-overlay .product-modal .select-options::-webkit-scrollbar,
.modal-overlay .product-modal .select-dropdown::-webkit-scrollbar,
.modal-overlay .product-modal .select-list::-webkit-scrollbar,
.modal-overlay .product-modal .select-menu::-webkit-scrollbar {
  width: 8px !important;
}

.modal-overlay .product-modal .select-options::-webkit-scrollbar-track,
.modal-overlay .product-modal .select-dropdown::-webkit-scrollbar-track,
.modal-overlay .product-modal .select-list::-webkit-scrollbar-track,
.modal-overlay .product-modal .select-menu::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.045) !important;
  border-radius: 999px !important;
}

.modal-overlay .product-modal .select-options::-webkit-scrollbar-thumb,
.modal-overlay .product-modal .select-dropdown::-webkit-scrollbar-thumb,
.modal-overlay .product-modal .select-list::-webkit-scrollbar-thumb,
.modal-overlay .product-modal .select-menu::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, #ffe766 0%, #ffd000 100%) !important;
  border-radius: 999px !important;

  box-shadow:
    0 0 10px rgba(255, 217, 0, 0.35),
    inset 0 1px 0 rgba(255, 255, 255, 0.35) !important;
}

.modal-overlay .product-modal .select-options::-webkit-scrollbar-thumb:hover,
.modal-overlay .product-modal .select-dropdown::-webkit-scrollbar-thumb:hover,
.modal-overlay .product-modal .select-list::-webkit-scrollbar-thumb:hover,
.modal-overlay .product-modal .select-menu::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, #fff18a 0%, #ffd900 100%) !important;
}

/* убираем белый стандартный scrollbar-угол */
.modal-overlay .product-modal .select-options::-webkit-scrollbar-corner,
.modal-overlay .product-modal .select-dropdown::-webkit-scrollbar-corner,
.modal-overlay .product-modal .select-list::-webkit-scrollbar-corner,
.modal-overlay .product-modal .select-menu::-webkit-scrollbar-corner {
  background: transparent !important;
}