/* Admin custom styles
   High-contrast, consistent spacing, and improved modal.
*/
#admin-users-table.table-sm > :not(caption) > * > * {
  padding-top: .4rem;
  padding-bottom: .4rem;
}

/* Keep actions column always visible */
.table-sticky-right {
  position: relative;
}
.table-sticky-right th:last-child,
.table-sticky-right td:last-child {
  position: sticky;
  right: 0;
  z-index: 2;
  background: var(--pp-card);
  backdrop-filter: saturate(120%) blur(2px);
}
.table-sticky-right th:last-child {
  z-index: 3;
}
.table-sticky-right td:last-child::before {
  content: '';
  position: absolute;
  left: -10px; top: 0; bottom: 0; width: 10px;
  background: linear-gradient(90deg, rgba(0,0,0,0), rgba(0,0,0,.22));
  pointer-events: none;
}

/* Compact badges in users list */
.admin-user-compact-badge {
  font-size: .72rem;
  padding: .2rem .45rem;
  border-radius: 999px;
}

/* Minimize icon-only columns */
.col-min {
  width: 1%;
  white-space: nowrap;
}

/* Clickable balance chip */
.admin-balance-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(61, 220, 151, 0.12);
  border: 1px solid rgba(61, 220, 151, 0.35);
  color: #d0f7e6;
  text-decoration: none;
  transition: all .15s ease-in-out;
}
.admin-balance-chip:hover {
  background: rgba(61, 220, 151, 0.2);
  box-shadow: 0 0 0 2px rgba(61, 220, 151, 0.12) inset;
  color: #e9fff6;
}
/* Keep balance value on one line and align numbers */
.admin-balance-chip span{white-space:nowrap;display:inline-block;min-width:5.2rem;text-align:right;font-variant-numeric:tabular-nums}
#admin-users-table td[data-col="balance"]{white-space:nowrap;width:1%}

/* Activity truncation */
.admin-activity { max-width: 260px; }
.admin-activity .small { line-height: 1.1; }
.admin-activity-line2{min-width:0}
.admin-activity-line2 .text-muted{white-space:nowrap}
.admin-activity-ip{min-width:0;max-width:130px;display:inline-block;vertical-align:bottom}

:root {
  --pp-bg: #0e0f13;
  --pp-card: #161822;
  --pp-text: #e6e9ef;
  --pp-muted: #9aa4b2;
  --pp-primary: #4da3ff;
  --pp-accent: #7c4dff;
  --pp-border: #2a2f3a;
  --pp-success: #3ddc97;
  --pp-warning: #ffb020;
  --pp-danger: #ff6b6b;
}

#overview-section {
  color: var(--pp-text);
}

#overview-section .overview-hero {
  position: relative;
  background: linear-gradient(160deg, rgba(19, 22, 32, 0.95), rgba(12, 14, 22, 0.92));
  border-radius: 28px;
  border: 1px solid rgba(96, 122, 184, 0.28);
  padding: 24px 28px;
  box-shadow: 0 24px 42px rgba(6, 10, 20, 0.52);
  overflow: hidden;
}

#overview-section .overview-hero::after {
  content: '';
  position: absolute;
  inset: -45% 42% auto auto;
  width: 320px;
  height: 320px;
  background: radial-gradient(circle at center, rgba(77, 163, 255, 0.28), transparent 70%);
  filter: blur(6px);
  pointer-events: none;
}

#overview-section .overview-hero__title {
  font-size: clamp(1.6rem, 2.8vw, 2rem);
  color: var(--pp-text);
}

#overview-section .overview-hero__subtitle {
  color: rgba(203, 214, 236, 0.78);
}

#overview-section .overview-hero__amount {
  font-size: clamp(2.1rem, 3vw, 2.6rem);
  font-weight: 600;
  color: #f4f6ff;
}

#overview-section .overview-hero__hint {
  color: rgba(194, 206, 232, 0.7) !important;
}

#overview-section .overview-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  border-radius: 999px;
  background: rgba(77, 163, 255, 0.12);
  border: 1px solid rgba(124, 167, 255, 0.25);
  color: rgba(222, 233, 255, 0.86);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

#overview-section .overview-metric-card {
  position: relative;
  border-radius: 22px;
  padding: 22px 24px;
  background: linear-gradient(200deg, rgba(20, 23, 33, 0.96), rgba(11, 12, 20, 0.94));
  border: 1px solid rgba(92, 116, 178, 0.28);
  box-shadow: 0 18px 32px rgba(7, 10, 20, 0.45);
  overflow: hidden;
  transition: transform .2s ease, box-shadow .2s ease;
}

#overview-section .overview-metric-card::before,
#overview-section .overview-metric-card::after {
  content: '';
  position: absolute;
  pointer-events: none;
  border-radius: 32px;
  opacity: 0.6;
}

#overview-section .overview-metric-card::before {
  inset: 10px auto auto 14px;
  width: 120px;
  height: 120px;
  background: radial-gradient(circle, rgba(77, 163, 255, 0.28), transparent 70%);
}

#overview-section .overview-metric-card::after {
  inset: auto -50px -60px auto;
  width: 180px;
  height: 180px;
  background: radial-gradient(circle, rgba(77, 163, 255, 0.22), transparent 65%);
  filter: blur(4px);
}

#overview-section .overview-metric-card--projects::before,
#overview-section .overview-metric-card--projects::after {
  background: radial-gradient(circle, rgba(124, 77, 255, 0.28), transparent 70%);
}

#overview-section .overview-metric-card--spend::before,
#overview-section .overview-metric-card--spend::after {
  background: radial-gradient(circle, rgba(255, 176, 32, 0.3), transparent 70%);
}

#overview-section .overview-metric-card--topups::before,
#overview-section .overview-metric-card--topups::after {
  background: radial-gradient(circle, rgba(61, 220, 151, 0.28), transparent 70%);
}

#overview-section .overview-metric-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 24px 40px rgba(9, 12, 24, 0.55);
}

#overview-section .overview-metric-card .metric-label {
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.72rem;
  color: rgba(206, 216, 236, 0.75);
}

#overview-section .overview-metric-card .metric-value {
  font-size: clamp(2rem, 2.6vw, 2.4rem);
  font-weight: 600;
  color: #f5f8ff;
  margin-top: 4px;
}

#overview-section .overview-metric-card .metric-change {
  margin-top: 10px;
  color: rgba(203, 214, 236, 0.74) !important;
}

#overview-section .overview-card {
  background: linear-gradient(165deg, rgba(18, 21, 31, 0.95), rgba(10, 12, 19, 0.96));
  border-radius: 22px;
  border: 1px solid rgba(96, 122, 184, 0.25);
  box-shadow: 0 22px 38px rgba(6, 9, 20, 0.5);
  color: var(--pp-text);
}

#overview-section .overview-card .card-title {
  color: var(--pp-text);
}

#overview-section .chart-wrapper {
  min-height: 220px;
}

#overview-section canvas {
  width: 100% !important;
}

#overview-section .overview-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

#overview-section .overview-list > li {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid rgba(120, 140, 190, 0.18);
}

#overview-section .overview-list > li:last-child {
  border-bottom: none;
  padding-bottom: 4px;
}

#overview-section .overview-list__item {
  display: flex;
  align-items: center;
  gap: 12px;
}

#overview-section .overview-list__index {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: rgba(77, 163, 255, 0.18);
  border: 1px solid rgba(96, 122, 184, 0.35);
  color: rgba(224, 233, 252, 0.9);
  font-weight: 600;
}

#overview-section .overview-list__title {
  font-weight: 600;
  color: #f1f4ff;
}

#overview-section .overview-list__meta {
  color: rgba(198, 209, 232, 0.65) !important;
}

#overview-section .overview-list__value {
  font-variant-numeric: tabular-nums;
  color: #f1f5ff;
}

#overview-section .overview-list--plain > li {
  padding: 10px 0;
}

@media (max-width: 767.98px) {
  #overview-section .overview-hero {
    padding: 20px;
  }
  #overview-section .overview-metric-card {
    padding: 20px;
  }
  #overview-section .overview-list__value {
    text-align: right;
  }
}

/* Crowd marketing status widget */
.crowd-stats-row .card {
  border: 0;
}

.crowd-stat-card {
  --crowd-accent: rgba(77, 163, 255, 0.45);
  --crowd-accent-strong: rgba(77, 163, 255, 0.85);
  position: relative;
  background: linear-gradient(195deg, rgba(21, 25, 37, 0.96) 0%, rgba(12, 13, 21, 0.97) 65%, rgba(11, 12, 20, 0.98) 100%);
  border: 1px solid rgba(102, 126, 186, 0.28);
  color: var(--pp-text);
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 20px 32px rgba(7, 11, 20, 0.42);
  transition: transform .18s ease, box-shadow .18s ease;
}

.crowd-stat-card::before,
.crowd-stat-card::after {
  content: '';
  position: absolute;
  border-radius: 32px;
  pointer-events: none;
  mix-blend-mode: screen;
}

.crowd-stat-card::before {
  inset: 14px auto auto 14px;
  width: 120px;
  height: 120px;
  background: radial-gradient(circle, var(--crowd-accent) 0%, transparent 70%);
  opacity: 0.65;
  filter: blur(4px);
}

.crowd-stat-card::after {
  inset: -50px -60px auto auto;
  width: 190px;
  height: 190px;
  background: radial-gradient(circle, var(--crowd-accent-strong) 0%, transparent 65%);
  opacity: 0.55;
  filter: blur(8px);
}

.crowd-stat-card__label {
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: 0.75rem;
  color: rgba(203, 212, 233, 0.7);
  position: relative;
  z-index: 1;
}

.crowd-stat-card__value {
  font-size: clamp(2.1rem, 2.6vw, 2.8rem);
  font-weight: 600;
  line-height: 1.1;
  position: relative;
  z-index: 1;
  color: #f4f6ff;
}

.crowd-stat-card--ok {
  --crowd-accent: rgba(61, 220, 151, 0.35);
  --crowd-accent-strong: rgba(61, 220, 151, 0.85);
  color: #c9f7e0;
}
.crowd-stat-card--pending {
  --crowd-accent: rgba(255, 176, 32, 0.4);
  --crowd-accent-strong: rgba(255, 176, 32, 0.9);
  color: #ffe7b5;
}
.crowd-stat-card--errors {
  --crowd-accent: rgba(255, 107, 107, 0.35);
  --crowd-accent-strong: rgba(255, 107, 107, 0.9);
  color: #ffd5d5;
}

.crowd-stat-card--ok .crowd-stat-card__value { color: #dafae8; }
.crowd-stat-card--pending .crowd-stat-card__value { color: #ffe9c6; }
.crowd-stat-card--errors .crowd-stat-card__value { color: #ffc9c9; }

.crowd-stat-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 24px 36px rgba(10, 14, 28, 0.46);
}

.crowd-header {
  position: relative;
}

.crowd-title {
  font-size: clamp(1.45rem, 2vw, 1.8rem);
  color: var(--pp-text);
}

.crowd-header-progress {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 14px 18px;
  background: linear-gradient(165deg, rgba(17, 21, 31, 0.92), rgba(12, 14, 22, 0.88));
  border-radius: 18px;
  border: 1px solid rgba(96, 122, 184, 0.32);
  box-shadow: 0 18px 32px rgba(7, 10, 18, 0.38);
  min-width: min(320px, 100%);
}

.crowd-header-progress__status {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}

.crowd-header-progress__label {
  text-transform: uppercase;
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  color: rgba(201, 212, 234, 0.72);
}

.crowd-header-progress__percent {
  font-size: 1.35rem;
  font-weight: 600;
  color: #f2f6ff;
}

.crowd-header-progress__bar {
  position: relative;
  height: 8px;
  background: rgba(255, 255, 255, 0.08);
  border-radius: 999px;
  overflow: hidden;
}

.crowd-header-progress__bar-fill {
  position: absolute;
  inset: 0;
  display: block;
  background: linear-gradient(135deg, rgba(77, 163, 255, 0.95), rgba(61, 220, 151, 0.9));
  box-shadow: 0 8px 16px rgba(38, 130, 220, 0.35);
  transition: width .25s ease;
}

.crowd-header-progress__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 0.78rem;
  color: rgba(204, 214, 235, 0.75);
}

.crowd-header-progress__status-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(77, 163, 255, 0.16);
  border: 1px solid rgba(98, 132, 194, 0.4);
  color: rgba(224, 233, 252, 0.88);
  font-weight: 500;
}

.crowd-header-progress__count {
  font-variant-numeric: tabular-nums;
}

.crowd-panel {
  position: relative;
  background: linear-gradient(150deg, rgba(18, 22, 32, 0.96), rgba(11, 13, 21, 0.98));
  border: 1px solid rgba(92, 118, 176, 0.25);
  color: var(--pp-text);
  border-radius: 20px;
  box-shadow: 0 22px 40px rgba(5, 9, 20, 0.55);
  overflow: hidden;
}

.crowd-panel::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(140% 110% at 90% -20%, rgba(77, 163, 255, 0.18), transparent 55%);
  opacity: 0.85;
}

.crowd-panel--upload::before {
  background: radial-gradient(135% 105% at 95% -15%, rgba(124, 77, 255, 0.2), transparent 60%);
}

.crowd-panel--status::before {
  background: radial-gradient(130% 100% at 90% -15%, rgba(61, 220, 151, 0.2), transparent 60%);
}

.crowd-panel .card-body {
  position: relative;
  z-index: 1;
}

.crowd-panel .form-label,
.crowd-panel .text-muted,
.crowd-panel .form-text {
  color: rgba(214, 223, 241, 0.78) !important;
}

.crowd-panel .form-control,
.crowd-panel .form-select,
.crowd-panel .form-control:focus,
.crowd-panel .form-select:focus {
  background: rgba(15, 18, 28, 0.85);
  border-color: rgba(112, 134, 192, 0.45);
  color: var(--pp-text);
  box-shadow: 0 0 0 0.2rem rgba(77, 163, 255, 0.18);
}

.crowd-panel .form-control::placeholder,
.crowd-panel .form-select option {
  color: rgba(160, 173, 203, 0.65);
}

.crowd-panel--upload .btn-primary {
  box-shadow: 0 12px 20px rgba(29, 94, 206, 0.32);
}

.crowd-panel--status .btn-success {
  box-shadow: 0 14px 24px rgba(42, 161, 110, 0.32);
}

.crowd-check-message {
  color: rgba(206, 216, 236, 0.75) !important;
}

.crowd-status-card {
  background: linear-gradient(175deg, rgba(13, 16, 26, 0.92), rgba(17, 20, 31, 0.78));
  border: 1px solid rgba(104, 134, 190, 0.28);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.015), 0 16px 28px rgba(8, 12, 22, 0.42);
  backdrop-filter: blur(10px);
}

.crowd-pagination-wrapper {
  display: flex;
  justify-content: center;
}

.crowd-pagination {
  display: flex;
  gap: 4px;
  padding: 6px 10px;
  border-radius: 16px;
  border: 1px solid rgba(90, 118, 176, 0.35);
  background: linear-gradient(165deg, rgba(17, 21, 31, 0.92), rgba(11, 14, 22, 0.9));
  box-shadow: 0 16px 28px rgba(6, 10, 18, 0.38);
}

.crowd-pagination .page-link {
  border: 0;
  border-radius: 12px;
  background: transparent;
  color: rgba(212, 223, 247, 0.8);
  min-width: 34px;
  text-align: center;
  transition: background .18s ease, color .18s ease, transform .18s ease;
}

.crowd-pagination .page-link:hover {
  background: rgba(77, 163, 255, 0.14);
  color: #f4f7ff;
  transform: translateY(-1px);
}

.crowd-pagination .page-item.active .page-link {
  background: linear-gradient(135deg, rgba(77, 163, 255, 0.9), rgba(61, 220, 151, 0.85));
  color: #0c1120;
  box-shadow: 0 8px 16px rgba(32, 84, 156, 0.32);
  font-weight: 600;
}

.crowd-pagination .page-item.disabled .page-link {
  color: rgba(156, 169, 197, 0.45);
  cursor: not-allowed;
  background: transparent;
  transform: none;
}

.crowd-pagination__ellipsis .page-link {
  cursor: default;
  color: rgba(156, 169, 197, 0.55);
  pointer-events: none;
}

#crowdCheckCard {
  background: radial-gradient(120% 160% at 90% -20%, rgba(77, 163, 255, 0.18), transparent 60%),
              linear-gradient(160deg, rgba(18, 22, 34, 0.96), rgba(9, 11, 18, 0.98));
  border: 1px solid rgba(90, 116, 168, 0.35);
  color: var(--pp-text);
  box-shadow: 0 22px 40px rgba(5, 9, 20, 0.55);
  backdrop-filter: blur(8px);
}

#crowdCheckCard .card-body {
  background: transparent;
}

#crowdCheckStatusCard {
  background: rgba(18, 22, 32, 0.85);
  border: 1px solid rgba(98, 126, 178, 0.35);
  border-radius: 14px;
  color: var(--pp-text);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02);
}

#crowdCheckStatusCard .text-muted {
  color: rgba(200, 209, 229, 0.78) !important;
}

#crowdCheckStatusCard .fw-semibold,
#crowdCheckStatusCard .text-success,
#crowdCheckStatusCard .text-danger {
  color: var(--pp-text);
}

#crowdCheckStatusCard .text-success i { color: var(--pp-success); }
#crowdCheckStatusCard .text-danger i { color: var(--pp-danger); }

#crowdCheckStatusCard .progress {
  background: rgba(255, 255, 255, 0.08);
  border-radius: 999px;
  height: 12px;
  overflow: hidden;
}

#crowdCheckStatusCard .progress-bar {
  background: linear-gradient(135deg, rgba(77, 163, 255, 0.95), rgba(61, 220, 151, 0.92));
  box-shadow: 0 6px 16px rgba(46, 155, 255, 0.35);
  transition: width .25s ease, background .3s ease;
}

#crowdCheckStatusCard hr {
  border-color: rgba(142, 160, 200, 0.25);
}

#crowdCheckCard .btn {
  box-shadow: 0 6px 18px rgba(32, 54, 96, 0.35);
}

#crowdCheckCard .btn.btn-outline-secondary {
  box-shadow: none;
  border-color: rgba(132, 148, 182, 0.45);
  color: rgba(222, 231, 248, 0.85);
}

#crowdCheckCard .btn.btn-outline-secondary:hover {
  background: rgba(28, 35, 52, 0.85);
  border-color: rgba(77, 163, 255, 0.45);
  color: var(--pp-text);
}

/* Settings layout polish */
.settings-card {
  background: var(--pp-card);
  border: 1px solid var(--pp-border);
  color: var(--pp-text);
}
.settings-card .form-label,
.settings-card .form-text,
.settings-card .card-title,
.settings-card .card-header,
.settings-card label {
  color: var(--pp-text);
}
.settings-card .form-text { color: var(--pp-muted); }
.settings-card .form-control,
.settings-card .form-select {
  background-color: #0f1117;
  border-color: var(--pp-border);
  color: var(--pp-text);
}
.settings-card .form-control::placeholder { color: #60697a; }
.settings-card .form-control:focus,
.settings-card .form-select:focus {
  border-color: var(--pp-primary);
  box-shadow: 0 0 0 .2rem rgba(77,163,255,.15);
}

/* Admin-wide dark form readability (scoped to pages with sidebar layout) */
.layout-has-sidebar .card {
  background: var(--pp-card);
  border: 1px solid var(--pp-border);
  color: var(--pp-text);
}
.layout-has-sidebar .card .card-header {
  background: transparent;
  border-bottom: 1px solid var(--pp-border);
  color: var(--pp-text);
}
.layout-has-sidebar .form-label,
.layout-has-sidebar .form-check-label,
.layout-has-sidebar label {
  color: var(--pp-text);
}
.layout-has-sidebar .form-text,
.layout-has-sidebar .text-muted {
  color: rgba(198, 209, 232, 0.82) !important; /* higher contrast on dark */
}
.layout-has-sidebar .form-text a { color: var(--pp-primary); text-decoration: underline; }
.layout-has-sidebar .form-text a:hover { text-decoration: none; }

.layout-has-sidebar .form-control,
.layout-has-sidebar .form-select {
  background-color: #0f1117;
  border-color: var(--pp-border);
  color: var(--pp-text);
}
.layout-has-sidebar .form-control::placeholder { color: #8c97ad; }
.layout-has-sidebar .form-control:focus,
.layout-has-sidebar .form-select:focus {
  border-color: var(--pp-primary);
  box-shadow: 0 0 0 .2rem rgba(77,163,255,.12);
}
.layout-has-sidebar .form-check-input {
  background-color: #0f1117;
  border-color: var(--pp-border);
}
.layout-has-sidebar .form-check-input:checked {
  background-color: var(--pp-primary);
  border-color: var(--pp-primary);
}

.settings-group {
  margin-bottom: 32px;
}
.settings-group:last-of-type {
  margin-bottom: 0;
}
.settings-group__header {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 18px;
}
@media (min-width: 768px) {
  .settings-group__header {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }
}
.settings-group__title {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--pp-text);
  margin: 0;
}
.settings-group__meta {
  margin: 0;
  color: var(--pp-muted);
  font-size: 0.9rem;
}

.settings-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 24px;
}
.settings-grid--single {
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
}

.settings-field {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 18px 18px 16px;
  background: linear-gradient(165deg, rgba(18, 22, 34, 0.82), rgba(11, 13, 22, 0.94));
  border: 1px solid rgba(90, 116, 168, 0.35);
  border-radius: 16px;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02), 0 12px 26px rgba(5, 9, 20, 0.38);
  backdrop-filter: blur(6px);
}
.settings-field--wide {
  grid-column: span 2;
}
@media (max-width: 991.98px) {
  .settings-field--wide {
    grid-column: span 1;
  }
}
.settings-field__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.settings-field__title {
  font-weight: 600;
  color: var(--pp-text);
  font-size: 1rem;
}
.settings-field__body {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.settings-field .form-text {
  margin: 0;
}

.pp-switch__label {
  color: var(--pp-text);
  font-weight: 500;
  cursor: pointer;
}

.promotion-levels-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 24px;
}
.promotion-level-card {
  background: linear-gradient(185deg, rgba(21, 25, 37, 0.96), rgba(11, 13, 22, 0.94));
  border: 1px solid rgba(98, 126, 178, 0.38);
  border-radius: 18px;
  padding: 20px 18px;
  box-shadow: 0 16px 32px rgba(5, 9, 20, 0.42);
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.promotion-level-card__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
}
.promotion-level-card__title {
  font-weight: 600;
  font-size: 1.05rem;
  color: #f4f6ff;
}
.promotion-level-card__hint {
  font-size: 0.85rem;
  color: rgba(203, 212, 233, 0.75);
  margin-top: 4px;
  max-width: 240px;
}
.promotion-level-card__body {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.promotion-level-card__body .form-text {
  color: rgba(203, 212, 233, 0.72) !important;
}
.promotion-level-card__note {
  color: rgba(203, 212, 233, 0.72);
  margin: 0;
}

.cascade-summary {
  background: rgba(17, 20, 32, 0.9);
  border: 1px solid rgba(82, 109, 173, 0.45);
  border-radius: 18px;
  box-shadow: 0 18px 38px rgba(2, 6, 18, 0.42);
  color: #f1f4ff;
}
.cascade-summary__title .bi {
  font-size: 1.4rem;
  color: #7aa5ff;
}
.cascade-summary__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
}
.cascade-summary__item {
  background: rgba(28, 33, 52, 0.65);
  border-radius: 14px;
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-height: 96px;
}
.cascade-summary__label {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  font-size: 0.92rem;
  color: rgba(214, 223, 245, 0.85);
}
.cascade-summary__hint {
  border: 0;
  background: transparent;
  color: rgba(214, 223, 245, 0.6);
  padding: 0;
  display: inline-flex;
  align-items: center;
  cursor: help;
}
.cascade-summary__hint:focus-visible {
  outline: 2px solid rgba(128, 168, 255, 0.8);
  outline-offset: 2px;
  border-radius: 50%;
}
.cascade-summary__value {
  font-size: 1.35rem;
  font-weight: 600;
  color: #ffffff;
}
.cascade-summary__footer-label {
  letter-spacing: 0.02em;
}
.cascade-summary__footer-value {
  font-size: 1.2rem;
}
.cascade-summary__footer {
  border-top: 1px solid rgba(82, 109, 173, 0.35);
  padding-top: 14px;
  margin-top: 10px;
}

.pp-switch--disabled {
  opacity: 0.5;
  pointer-events: none;
}
.pp-switch--disabled .track,
.pp-switch--disabled .thumb {
  pointer-events: none;
}
.pp-switch--disabled .pp-switch__label {
  cursor: not-allowed;
  opacity: 0.7;
}

.form-control.disabled,
.form-control.is-readonly {
  background: rgba(255, 255, 255, 0.05);
  opacity: 0.65;
  cursor: not-allowed;
}
/* Segmented control for provider */
.pp-segmented {
  display: inline-flex;
  border: 1px solid var(--pp-border);
  border-radius: 8px;
  overflow: hidden;
  background: #0f1117;
}
.pp-segmented input { display: none; }
.pp-segmented label {
  margin: 0;
  padding: 8px 14px;
  color: var(--pp-muted);
  cursor: pointer;
  user-select: none;
  transition: all .15s ease;
}
.pp-segmented label + label { border-left: 1px solid var(--pp-border); }
.pp-segmented input:checked + label {
  color: var(--pp-text);
  background: #121521;
}

.table tbody tr.table-active>td,
.table tbody tr.table-active>th {
  background: rgba(77, 163, 255, 0.18) !important;
  border-color: rgba(77, 163, 255, 0.25) !important;
}

#networksTable .network-select-head .form-check,
#networksTable .network-select-cell .form-check {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
}

#networksTable tr.network-row-saving td,
#networksTable tr.network-row-saved td,
#networksTable tr.network-row-error td {
  transition: background-color .3s ease, box-shadow .3s ease;
}

#networksTable tr.network-row-saving td {
  background-color: rgba(37, 99, 235, 0.08);
  box-shadow: inset 3px 0 0 rgba(37, 99, 235, 0.55);
}

#networksTable tr.network-row-saved td {
  background-color: rgba(34, 197, 94, 0.1);
  box-shadow: inset 3px 0 0 rgba(34, 197, 94, 0.6);
}

#networksTable tr.network-row-error td {
  background-color: rgba(248, 113, 113, 0.14);
  box-shadow: inset 3px 0 0 rgba(248, 113, 113, 0.8);
}

#networksTable .network-select-cell {
  width: 48px;
  text-align: center;
  vertical-align: middle;
}

#networksTable .network-select-cell .form-check-input,
#networkSelectAll {
  cursor: pointer;
  width: 1.15rem;
  height: 1.15rem;
  border-radius: 6px;
  border: 1.5px solid rgba(138, 152, 174, 0.45);
  background-color: #0e111b;
  transition: border-color .15s ease, box-shadow .15s ease, background-color .15s ease, transform .12s ease;
}

#networksTable .network-select-cell .form-check-input:hover:not(:disabled),
#networkSelectAll:hover:not(:disabled) {
  border-color: rgba(77, 163, 255, 0.55);
  box-shadow: 0 0 0 2px rgba(77, 163, 255, 0.12);
  transform: scale(1.05);
}

#networksTable .network-select-cell .form-check-input:active:not(:disabled),
#networkSelectAll:active:not(:disabled) {
  transform: scale(0.92);
}

#networksTable .network-select-cell .form-check-input:focus-visible,
#networkSelectAll:focus-visible {
  outline: none;
  border-color: rgba(77, 163, 255, 0.75);
  box-shadow: 0 0 0 3px rgba(77, 163, 255, 0.2);
}

#networksTable .network-select-cell .form-check-input:checked,
#networkSelectAll:checked {
  background-color: var(--pp-primary);
  border-color: var(--pp-primary);
  box-shadow: 0 0 0 3px rgba(77, 163, 255, 0.18);
}

#networksTable .network-select-cell .form-check-input:disabled,
#networkSelectAll:disabled {
  background-color: rgba(24, 28, 42, 0.5);
  border-color: rgba(134, 146, 170, 0.25);
  cursor: not-allowed;
  opacity: 0.65;
  transform: none;
}

#networksTable .network-info-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  cursor: help;
  transition: transform .15s ease, color .15s ease, background-color .15s ease;
}

#networksTable .network-info-icon:hover {
  color: var(--pp-primary);
  transform: translateY(-1px);
}
/* Pretty switch */
.pp-switch {
  --h: 24px;
  --w: 46px;
  --thumb-offset: 3px;
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.pp-switch-sm {
  --h: 20px;
  --w: 38px;
}
.pp-switch input { display:none; }
.pp-switch .track {
  width: var(--w);
  height: var(--h);
  background: rgba(36, 42, 60, 0.85);
  border-radius: calc(var(--h) / 2);
  position: relative;
  transition: background .2s ease, box-shadow .2s ease, opacity .2s ease;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.04);
  cursor: pointer;
}
.pp-switch .thumb {
  width: calc(var(--h) - (var(--thumb-offset) * 2));
  height: calc(var(--h) - (var(--thumb-offset) * 2));
  background: #f1f5ff;
  border-radius: 50%;
  position: absolute;
  top: var(--thumb-offset);
  left: var(--thumb-offset);
  transition: transform .2s ease, background .2s ease, box-shadow .2s ease;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.35);
}
.pp-switch:hover .track {
  box-shadow: inset 0 0 0 1px rgba(77, 163, 255, 0.25);
}
.pp-switch input:checked + .track {
  background: linear-gradient(135deg, rgba(77, 163, 255, 0.95), rgba(46, 146, 255, 0.85));
  box-shadow: 0 6px 16px rgba(32, 84, 140, 0.35);
}
.pp-switch input:checked + .track .thumb {
  transform: translateX(calc(var(--w) - var(--h)));
  background: #ffffff;
  box-shadow: 0 4px 12px rgba(19, 33, 54, 0.45);
}
.pp-switch input:focus-visible + .track {
  box-shadow: 0 0 0 3px rgba(77, 163, 255, 0.35);
}
.pp-switch input:disabled + .track {
  background: rgba(32, 36, 48, 0.7);
  cursor: not-allowed;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.03);
  opacity: 0.75;
}
.pp-switch input:disabled + .track .thumb {
  background: rgba(209, 214, 224, 0.65);
  box-shadow: none;
}

/* Modal (scrollable, high-contrast) */
.pp-modal {
  position: fixed;
  inset: 0;
  background: rgba(6,7,10,.7);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 1060; /* above Bootstrap's backdrop and modal to ensure visibility */
}
.modal-backdrop { z-index: 1040; }
.modal { z-index: 1055; }
.modal.show { display: block; }
.pp-modal.show { display: flex; }
.pp-modal .pp-modal-dialog {
  width: min(800px, 92vw);
  max-height: 90vh;
  background: #0f1117;
  border: 1px solid var(--pp-border);
  border-radius: 12px;
  color: var(--pp-text);
  box-shadow: 0 10px 40px rgba(0,0,0,.6);
  display: flex; flex-direction: column;
  pointer-events: auto;
}
.pp-modal { padding: 24px; box-sizing: border-box; }
.pp-modal[aria-hidden="true"] { pointer-events: none; }
.pp-modal .pp-modal-header {
  padding: 14px 18px;
  border-bottom: 1px solid var(--pp-border);
  display: flex; align-items: center; justify-content: space-between;
}
.pp-modal .pp-modal-title { font-size: 1.05rem; font-weight: 600; }
.pp-modal .pp-modal-body {
  padding: 16px 18px;
  overflow: auto;
}
.pp-modal .pp-modal-footer {
  padding: 12px 18px;
  border-top: 1px solid var(--pp-border);
  display: flex; justify-content: flex-end; gap: 8px;
}
.pp-modal .pp-close {
  background: transparent; color: var(--pp-muted); border: 0; font-size: 20px; line-height: 1; cursor: pointer;
}
.pp-modal code { color: #b0d4ff; background: #0b0d12; border: 1px solid #1e2530; padding: 2px 6px; border-radius: 6px; }
.pp-modal a { color: var(--pp-primary); }

/* Diagnostics pills */
.diagnostics-pill {
  font-size: .85rem;
  background: #121521; color: var(--pp-text);
  border: 1px solid var(--pp-border);
  padding: 4px 8px; border-radius: 999px;
}

/* Buttons */
.btn-primary { background-color: var(--pp-primary); border-color: var(--pp-primary); }
.btn-outline-primary { color: var(--pp-primary); border-color: var(--pp-primary); }
.btn-outline-primary:hover { background: rgba(77,163,255,.1); }

/* Alerts */
.alert-info { background: #0c1a2b; color: #d9ecff; border-color: #15314e; }
.alert-warning { background: #2b2410; color: #ffe6a3; border-color: #4a3f1a; }
.alert-success { background: #0f231c; color: #cef2e3; border-color: #194635; }

/* Tables */
.table { color: var(--pp-text); }
.table thead { color: #c9d3df; }
.table-striped>tbody>tr:nth-of-type(odd)>* { background: #121521; }
.table-striped>tbody>tr:nth-of-type(even)>* { background: #0f1117; }
.table > :not(caption) > * > * { border-bottom-color: var(--pp-border); }

.table tbody tr.table-active>td,
.table tbody tr.table-active>th {
  background: rgba(77, 163, 255, 0.18) !important;
  border-color: rgba(77, 163, 255, 0.25) !important;
}

#networksTable .network-select-head .form-check,
#networksTable .network-select-cell .form-check {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
}

#networksTable .network-select-cell {
  width: 48px;
  text-align: center;
  vertical-align: middle;
}

/* Networks filters bar */
#networkFiltersBar {
  position: relative;
  z-index: 0;
  background: linear-gradient(135deg, rgba(18, 24, 38, 0.95), rgba(10, 12, 20, 0.98));
  border: 1px solid rgba(82, 110, 156, 0.35);
  border-radius: 14px;
  box-shadow: 0 18px 36px rgba(6, 8, 20, 0.35);
  color: var(--pp-text);
  padding: 20px 22px;
  overflow: hidden;
}

#networkFiltersBar::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(160% 120% at 95% -20%, rgba(77, 163, 255, 0.18), transparent 55%);
  z-index: -1;
}

#networkFiltersBar .row {
  row-gap: 18px;
}

#networkFiltersBar .form-label {
  color: rgba(197, 205, 224, 0.85);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: .05em;
  text-transform: uppercase;
  margin-bottom: 6px;
}

#networkFiltersBar .form-select,
#networkFiltersBar .form-control {
  background: rgba(12, 16, 29, 0.95);
  border: 1px solid rgba(120, 138, 170, 0.35);
  color: var(--pp-text);
  border-radius: 12px;
  padding: 8px 14px;
  min-height: 40px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
  transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
  backdrop-filter: blur(6px);
}

#networkFiltersBar .form-select:hover,
#networkFiltersBar .form-control:hover {
  border-color: rgba(77, 163, 255, 0.5);
}

#networkFiltersBar .form-select:focus,
#networkFiltersBar .form-control:focus {
  border-color: var(--pp-primary);
  box-shadow: 0 0 0 .2rem rgba(77, 163, 255, 0.18);
  background: rgba(14, 20, 34, 0.98);
}

#networkFiltersBar .form-select-sm,
#networkFiltersBar .form-control-sm {
  padding: 8px 14px;
  font-size: .85rem;
}

#networkFiltersBar .form-select option {
  color: #0c0f18;
}

#networkFiltersBar .btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border-radius: 999px;
  font-weight: 600;
  padding: 7px 15px;
  font-size: .85rem;
  transition: transform .15s ease, box-shadow .15s ease, color .15s ease, background .15s ease, border-color .15s ease;
  background: rgba(18, 24, 38, 0.6);
  border: 1px solid rgba(118, 138, 170, 0.35);
  color: rgba(214, 226, 249, 0.85);
}

#networkFiltersBar .btn .bi {
  font-size: 1rem;
  opacity: 0.75;
}

#networkFiltersBar .btn:hover {
  transform: translateY(-1px);
  background: rgba(26, 34, 52, 0.95);
  border-color: rgba(77, 163, 255, 0.55);
  color: var(--pp-text);
}

#networkFiltersBar .btn:active {
  transform: translateY(0);
}

#networkFiltersBar .btn:hover .bi {
  opacity: 1;
}

#networkFiltersBar .btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(77, 163, 255, 0.2);
}

#networkFiltersBar .btn-outline-primary {
  color: var(--pp-primary);
  border-color: rgba(77, 163, 255, 0.55);
  background: rgba(26, 36, 58, 0.45);
}

#networkFiltersBar .btn-outline-primary:hover {
  background: rgba(77, 163, 255, 0.16);
  color: var(--pp-text);
}

#networkFiltersBar .btn-outline-secondary {
  color: rgba(214, 226, 249, 0.8);
  border-color: rgba(154, 164, 178, 0.4);
  background: rgba(20, 26, 40, 0.45);
}

#networkFiltersBar .btn-outline-secondary:hover {
  background: rgba(154, 164, 178, 0.16);
  color: var(--pp-text);
}

#networkFiltersBar .btn-outline-success,
#networkFiltersBar .btn-outline-warning,
#networkFiltersBar .btn-outline-info,
#networkFiltersBar .btn-outline-light {
  border-color: rgba(255, 255, 255, 0.16);
  background: rgba(18, 24, 38, 0.35);
  color: rgba(214, 226, 249, 0.85);
}

#networkFiltersBar .btn-outline-success:hover {
  color: var(--pp-success);
  border-color: rgba(61, 220, 151, 0.45);
  background: rgba(61, 220, 151, 0.18);
}

#networkFiltersBar .btn-outline-warning:hover {
  color: var(--pp-warning);
  border-color: rgba(255, 176, 32, 0.45);
  background: rgba(255, 176, 32, 0.18);
}

#networkFiltersBar .btn-outline-info:hover {
  color: var(--pp-primary);
  border-color: rgba(77, 163, 255, 0.45);
  background: rgba(77, 163, 255, 0.2);
}

#networkFiltersBar .btn-outline-light {
  border-color: rgba(255, 255, 255, 0.12);
  color: rgba(222, 230, 245, 0.85);
}

#networkFiltersBar .btn-outline-light:hover {
  color: var(--pp-text);
  border-color: rgba(255, 255, 255, 0.22);
  background: rgba(255, 255, 255, 0.08);
}

#networkFiltersBar .filters-actions {
  padding-top: 14px;
  margin-top: 4px;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}

#networkFiltersBar .filters-actions-primary {
  margin-top: 18px;
}

#networkFiltersBar .filters-actions-selection {
  margin-top: 10px;
  border-color: rgba(255, 255, 255, 0.05);
}

#networkFiltersBar .filters-info {
  border-left: 3px solid rgba(77, 163, 255, 0.4);
  border-radius: 11px;
  padding: 10px 14px;
  background: rgba(12, 17, 29, 0.65);
  min-height: 38px;
  color: var(--pp-muted);
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
}

#networkFiltersBar #networkFiltersInfo {
  color: inherit;
}

#networkFiltersBar .text-muted { color: var(--pp-muted) !important; }

@media (prefers-reduced-motion: reduce) {
  #networkFiltersBar .btn,
  #networkFiltersBar .form-select,
  #networkFiltersBar .form-control,
  .pp-switch .track,
  .pp-switch .thumb,
  #networksTable .network-select-cell .form-check-input,
  #networkSelectAll {
    transition: none !important;
  }
}

/* Network diagnostics */
.network-check-summary-card {
  background: #10131d;
  border: 1px solid var(--pp-border);
  color: var(--pp-text);
}

.network-check-summary-card .card-body {
  padding: 14px 18px;
}

.network-check-progress {
  background: rgba(255, 255, 255, 0.06);
  border-radius: 999px;
  height: 16px;
  overflow: hidden;
}

.network-check-progress .progress-bar {
  background: var(--pp-primary);
  font-size: 0.75rem;
  line-height: 16px;
  font-weight: 600;
  color: #05070b;
  transition: width .3s ease;
}

.network-check-progress .progress-bar.bg-success { background: var(--pp-success); color: #04170d; }
.network-check-progress .progress-bar.bg-warning { background: var(--pp-warning); color: #241d08; }
.network-check-progress .progress-bar.bg-danger { background: var(--pp-danger); color: #fff5f5; }

.network-check-results {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.network-check-item {
  border: 1px solid var(--pp-border);
  background: #0f1117;
  border-radius: 10px;
  padding: 12px 14px;
  transition: border-color .2s ease, box-shadow .2s ease;
}

.network-check-item.running {
  border-color: var(--pp-primary);
  box-shadow: 0 0 0 1px rgba(77, 163, 255, 0.25);
}

.network-check-item.cancelled {
  border-color: rgba(108, 117, 125, 0.45);
  opacity: 0.9;
}

.network-check-item.cancelled .network-check-error {
  color: var(--pp-muted);
}

.network-check-item-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.network-check-item-title {
  font-weight: 600;
  font-size: 0.95rem;
}

.network-check-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 3px 12px;
  font-size: 0.75rem;
  letter-spacing: .03em;
  text-transform: uppercase;
  font-weight: 600;
}

.network-check-badge.success { background: rgba(61, 220, 151, 0.14); color: var(--pp-success); }
.network-check-badge.failed { background: rgba(255, 107, 107, 0.18); color: var(--pp-danger); }
.network-check-badge.running { background: rgba(77, 163, 255, 0.18); color: var(--pp-primary); }
.network-check-badge.queued { background: rgba(122, 128, 140, 0.18); color: var(--pp-muted); }
.network-check-badge.cancelled { background: rgba(108, 117, 125, 0.18); color: var(--pp-muted); }

.network-check-item-body {
  margin-top: 8px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 0.85rem;
  color: var(--pp-muted);
}

.network-check-link {
  color: var(--pp-primary);
  font-weight: 600;
}

.network-check-link:hover {
  text-decoration: underline;
}

.network-check-error {
  color: var(--pp-danger);
  word-break: break-word;
}

.network-check-times {
  font-size: 0.78rem;
  color: var(--pp-muted);
}

.network-check-current {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--pp-primary);
}

.network-check-note {
  font-size: 0.85rem;
  color: var(--pp-muted);
}
