/* ROADMAP LAYOUT */
/* [EN] Stage roadmap layout for the multi-step timeline (cards + progress bar) */

#stages-roadmap .timeline-inner {
  position: relative;
  padding-bottom: 10px; /* място за конекторите + бара */
}

#stages-roadmap .timeline-stages {
  position: relative;
  margin-bottom: 30px; /* разстояние между картите и бара */
  overflow: visible;
}

#stages-roadmap .timeline-stage {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  flex: 1 1 0;
  min-width: 0; /* важно: да може да се свива и да не бута Stage 4 навън */
}

/* Stage cards – леко разкрасени, с hover */
/* [EN] Individual stage cards with subtle styling and hover effect */

#stages-roadmap .stage-box {
  position: relative;
  border-radius: .9rem;
  border: 1px solid var(--bs-border-color, rgba(0,0,0,.08));
  padding: .75rem 1rem;
  background: linear-gradient(
    135deg,
    var(--bs-body-bg, #ffffff),
    var(--bs-secondary-bg, #f8f9fa)
  );
  box-shadow: 0 4px 12px rgba(15,23,42,0.06);
  transition:
    border-color .2s ease,
    background-color .2s ease,
    box-shadow .2s ease,
    transform .2s ease;
  cursor: pointer;
  text-align: center;
  min-width: 0; /* да не държи flex-а по-широк от контейнера */
}

html[data-bs-theme="dark"] #stages-roadmap .stage-box {
  background: linear-gradient(135deg, rgb(37 42 48), rgba(15, 23, 42, 0.92));
  box-shadow: 0 6px 16px rgba(0,0,0,0.5);
}

#stages-roadmap .stage-box:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(15,23,42,0.25);
}

/* Активен/кликнат бокс */
/* [EN] Active / selected state for the stage card */

#stages-roadmap .stage-box.selected {
  border-color: var(--bs-primary, #0d6efd);
  box-shadow:
    0 0 0 1px rgba(13,110,253,0.5),
    0 14px 32px rgba(15,23,42,0.3);
}

#stages-roadmap .stage-box.selected::before {
  content: "";
  position: absolute;
  left: 15%;
  right: 15%;
  top: 0;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(
    90deg,
    var(--bs-primary, #0d6efd),
    var(--bs-success, #198754)
  );
}

#stages-roadmap .stage-box.completed {
  border-color: var(--bs-success-border-subtle, rgba(25,135,84,.5));
  background-color: rgba(25,135,84,.03);
}

#stages-roadmap .stage-box.current {
  border-color: rgba(25,135,84,.9);
  background-color: rgba(25,135,84,.12);
}

#stages-roadmap .stage-box.upcoming {
  opacity: .95;
}

#stages-roadmap .stage-title,
#stages-roadmap .stage-date {
  color: var(--bs-body-color, #212529);
}

/* Вертикални конектори – център -> прогрес бар */
/* [EN] Vertical connectors from each card down to the progress bar */

#stages-roadmap .timeline-stage::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  width: 2px;
  height: 40px;
  background-color: var(--bs-border-color, rgba(0,0,0,.2));
  pointer-events: none;
}

#stages-roadmap .timeline-stage.completed::after,
#stages-roadmap .timeline-stage.current::after {
  background-color: var(--bs-success, #198754);
}

/* Progress bar долу – визуално като при Discord/Stream */
/* [EN] Bottom progress bar under the roadmap, styled like a stream/Discord bar */

#stages-roadmap .timeline-track {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
}

#stages-roadmap .timeline-track .progress {
  background-color: var(--bs-secondary-bg, rgba(0,0,0,.05));
  border-radius: 0;
}

#stagesProgressFill {
  background-color: var(--bs-success, #198754);
  border-radius: 0;
  transition: width .6s ease;
}

#stages-roadmap .marker-dot {
  background-color: var(--bs-success, #198754);
  box-shadow: 0 0 0 2px var(--bs-body-bg, #ffffff);
}

#stagesCenterLabel {
  max-width: 90%;
  text-align: center;
  white-space: normal !important; /* override на .text-nowrap */
  line-height: 1.2;
}

/* ===== INFO PANEL – чиста снимка + леко затъмняване в центъра ===== */
/* [EN] Info panel beside the roadmap – clean photo background + subtle center darkening */

#stageInfoPanel .stage-info-card {
  position: relative;
  border-radius: 1.25rem;
  overflow: hidden;
  border: 1px solid var(--bs-border-color, rgba(0,0,0,.12));
  background-color: #000;
  min-height: 210px;
}

/* Снимката – НИКАКЪВ BLUR, НИКАКВИ FILTER-и */
/* [EN] Background image – no blur, no filters */

#stageInfoPanel .stage-info-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: none !important;
  transform: none !important;
}

/* Централно леко затъмняване (без blur) за да изпъква текста */
/* [EN] Radial overlay to darken the center area (no blur) so text pops */

#stageInfoPanel .stage-info-gradient {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(
      circle at 50% 50%,
      rgba(0, 0, 0, 0.45) 0%,
      rgba(0, 0, 0, 0.45) 30%,
      rgba(0, 0, 0, 0.28) 55%,
      rgba(0, 0, 0, 0.12) 75%,
      rgba(0, 0, 0, 0.0) 100%
    );
  /* НЯМА backdrop-filter тук */
}

/* Foreground layout – текст + иконка */
/* [EN] Foreground layout with spinner graphic + text content */

#stageInfoPanel .stage-info-inner {
  position: relative;
  z-index: 1;
  padding: 1.5rem 1.75rem;
  display: flex;
  align-items: center;
  gap: 1.5rem;
  color: #ffffff;
}

/* Rotating circle + glow */
/* [EN] Circular animated “status” graphic with glow and icon */

#stageInfoPanel .stage-info-spinner-wrap {
  position: relative;
  width: 96px;
  height: 96px;
  flex-shrink: 0;
}

#stageInfoPanel .stage-info-spinner-glow {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(25,135,84,.55), transparent 60%);
  opacity: .9;
  animation: stage-pulse 2.2s ease-in-out infinite;
}

#stageInfoPanel .stage-info-spinner {
  position: absolute;
  inset: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
}

#stageInfoPanel .stage-info-spinner-ring {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 3px solid rgba(255,255,255,.16);
  border-top-color: var(--bs-success, #198754);
  border-right-color: rgba(13,110,253,.85);
  animation: stage-spin 1.1s linear infinite;
  box-shadow: 0 0 18px rgba(25,135,84,.55);
}

#stageInfoPanel .stage-info-spinner-center {
  position: relative;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 20%, rgba(255,255,255,.35), rgba(255,255,255,.08));
  border: 1px solid rgba(255,255,255,.4);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--bs-success, #198754);
  font-size: 1.35rem;
  backdrop-filter: blur(10px);
}

#stageInfoPanel .stage-info-meta {
  flex: 1 1 auto;
}

#stageInfoPanel #stageInfoBadge {
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  background: rgba(25,135,84,.22);
  color: #e9fdf3;
  border-radius: 999px;
  padding: .35rem .8rem;
  border: 1px solid rgba(25,135,84,.7);
}

#stageInfoPanel #stageInfoDate {
  display: block;
  margin-top: .35rem;
  color: rgba(255,255,255,.9);
  font-size: .78rem;
}

#stageInfoPanel #stageInfoTitle {
  margin-top: .75rem;
  margin-bottom: .25rem;
  font-size: 1.15rem;
  font-weight: 600;
  color: #ffffff;
}

#stageInfoPanel #stageInfoDesc {
  margin: 0;
  font-size: .88rem;
  color: rgba(255,255,255,.96);
}

/* Анимации за кръгчето */
/* [EN] Keyframe animations for the rotating circle and pulsing glow */

@keyframes stage-spin {
  0%   { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

@keyframes stage-pulse {
  0%, 100% { transform: scale(1); opacity: .7; }
  50%      { transform: scale(1.08); opacity: 1; }
}

/* Dark mode – снимката отново без blur, само малко по-силно затъмняване в центъра */
/* [EN] Dark theme tweaks – stronger center darkening, same sharp image */

html[data-bs-theme="dark"] #stageInfoPanel .stage-info-bg {
  filter: none !important;
}

html[data-bs-theme="dark"] #stageInfoPanel .stage-info-card {
  box-shadow: 0 16px 40px rgba(0,0,0,0.8);
}

html[data-bs-theme="dark"] #stageInfoPanel .stage-info-gradient {
  background:
    radial-gradient(
      circle at 50% 50%,
      rgba(0, 0, 0, 0.6) 0%,
      rgba(0, 0, 0, 0.6) 32%,
      rgba(0, 0, 0, 0.4) 55%,
      rgba(0, 0, 0, 0.18) 75%,
      rgba(0, 0, 0, 0.03) 100%
    );
}

/* Логото вътре в кръгчето (ако ползваш изображение) */
/* [EN] Optional logo image placed inside the spinner center */

#stageInfoPanel .stage-info-logo {
  width: 70%;
  height: 70%;
  object-fit: contain;
  display: block;
}

/* Server time badge като малък outline бутон */
/* [EN] Small pill-style badge for “server time / next stage” label */

#stagesNextLabel {
  font-size: 0.8rem;
  padding-inline: 0.75rem;
  padding-block: 0.25rem;
}

html[data-bs-theme="dark"] #stagesNextLabel {
  border-color: rgba(148, 163, 184, 0.7);
}

#stagesTimeIcon {
  font-size: 0.95rem;
}

/* ====== RESPONSIVE TWEAKS ====== */
/* [EN] Responsive behavior for roadmap and info panel across breakpoints */

@media (max-width: 992px) {
  #stages-roadmap .timeline-stages {
    gap: 1rem;
  }
}

@media (max-width: 768px) {
  #stageInfoPanel .stage-info-inner {
    flex-direction: column;
    text-align: center;
    padding: 1.25rem 1rem;
    gap: 1rem;
  }

  #stageInfoPanel .stage-info-spinner-wrap {
    width: 84px;
    height: 84px;
  }

  #stageInfoPanel #stageInfoTitle {
    font-size: 1.05rem;
  }

  #stageInfoPanel #stageInfoDesc {
    font-size: .84rem;
  }

  /* Timeline -> horizontal scroll (като carousel) */
  /* [EN] On mobile, the timeline becomes a horizontally scrollable carousel */

  #stages-roadmap .timeline-stages {
    overflow-x: auto;
    overflow-y: visible;
    padding-bottom: 1rem;
    gap: 1rem;
    scrollbar-width: thin;
  }

  #stages-roadmap .timeline-stage {
    min-width: 220px;
    flex: 0 0 auto;
  }

  /* Progress bar – под картите, full width */
  /* [EN] Move the progress bar under the cards on small screens */

  #stages-roadmap .timeline-track {
    position: relative;
    left: auto;
    right: auto;
    bottom: auto;
    margin-top: .25rem;
  }

  #stages-roadmap .timeline-track .progress {
    height: 24px !important;
  }

  #stages-roadmap .timeline-stage::after {
    height: 30px;
  }

  #stagesCenterLabel {
    font-size: .7rem;
    max-width: 95%;
    padding: 0 .25rem;
  }
}

@media (max-width: 576px) {
  #stageInfoPanel .stage-info-card {
    min-height: 190px;
    border-radius: 1rem;
  }
  #stageInfoPanel .stage-info-spinner-wrap {
    width: 78px;
    height: 78px;
  }
  #stageInfoPanel #stageInfoTitle {
    font-size: 1rem;
  }
  #stageInfoPanel #stageInfoDate {
    font-size: .75rem;
  }
}

/* ===== Ново: центриране и по-големи икони за стейджовете ===== */
/* [EN] Centered titles and larger stage icons in the roadmap cards */

#stages-roadmap .stage-box > .text-uppercase {
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

#stages-roadmap .stage-title {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  text-align: center;
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

#stages-roadmap .stage-title i.bi-1-circle,
#stages-roadmap .stage-title i.bi-2-circle,
#stages-roadmap .stage-title i.bi-3-circle,
#stages-roadmap .stage-title i.bi-4-circle {
  font-size: 1.7rem;
  line-height: 1;
  flex-shrink: 0;
}

#stages-roadmap .stage-title i.bi-bug-fill {
  font-size: 1.4rem;
  flex-shrink: 0;
}

@media (max-width: 576px) {
  #stages-roadmap .stage-title {
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
    flex-wrap: wrap;
  }
}

/* ===========================
   STAGE INFO TEXT GLOW
   =========================== */
/* [EN] Subtle text glow for readability on top of the image background */

/* Light режим – контрастен, но без цветен неон */
/* [EN] Light mode – strong contrast but no colored neon glow */

#stageInfoPanel #stageInfoTitle {
  color:#ffffff;
  text-shadow:
    0 2px 4px rgba(0,0,0,0.9),
    0 0 6px rgba(0,0,0,0.85);
}

#stageInfoPanel #stageInfoDesc,
#stageInfoPanel #stageInfoDate {
  color:rgba(255,255,255,0.96);
  text-shadow:
    0 1px 3px rgba(0,0,0,0.85),
    0 0 4px rgba(0,0,0,0.8);
}

#stageInfoPanel #stageInfoBadge {
  text-shadow:
    0 1px 3px rgba(0,0,0,0.9),
    0 0 6px rgba(0,0,0,0.85);
}

/* Dark режим – малко по-силен, леко цветен glow */
/* [EN] Dark mode – stronger, slightly colored glow for a more “neon” feel */

html[data-bs-theme="dark"] #stageInfoPanel #stageInfoTitle {
  color:#ffffff;
  text-shadow:
    0 2px 4px rgba(0,0,0,0.95),
    0 0 10px rgba(25,135,84,0.75),
    0 0 18px rgba(13,110,253,0.55);
}

html[data-bs-theme="dark"] #stageInfoPanel #stageInfoDesc,
html[data-bs-theme="dark"] #stageInfoPanel #stageInfoDate {
  color:rgba(255,255,255,0.96);
  text-shadow:
    0 1px 3px rgba(0,0,0,0.95),
    0 0 8px rgba(0,0,0,0.9),
    0 0 12px rgba(15,118,110,0.55);
}

html[data-bs-theme="dark"] #stageInfoPanel #stageInfoBadge {
  color:#e9fdf3;
  text-shadow:
    0 1px 3px rgba(0,0,0,1),
    0 0 8px rgba(25,135,84,0.9),
    0 0 18px rgba(13,110,253,0.75);
}



/* [EN] Base quick-payment tile hover/focus behavior and logo auto-invert */

.payment-quick { cursor:pointer; transition:transform .05s ease-in-out; }
.payment-quick:has(input:checked) { outline:2px solid var(--bs-primary); transform: translateY(-1px); }
.brand--autoInvert { filter: invert(0); }
[data-bs-theme="dark"] .brand--autoInvert { filter: invert(1) hue-rotate(180deg); }

.cred-card .copy-btn { white-space: nowrap; }
.cred-card code { user-select: all; }


/* ---------- Палитра / акценти ---------- */
/* [EN] Donation widget: palette variables and accent colors */

:root {
  --donate-radius: 1rem;
  --donate-shadow: 0 6px 24px rgba(0,0,0,.08);
  --donate-shadow-sm: 0 2px 12px rgba(0,0,0,.06);
  --donate-grad: linear-gradient(135deg, var(--bs-primary), #6ea8fe);
  --paypal-color: #003087;
  --crypto-color: #f7931a;
}

/* ---------- Контейнери ---------- */
/* [EN] Donation widget card containers */

#dash-donate .card.border-0.shadow-sm { border-radius: var(--donate-radius); box-shadow: var(--donate-shadow); }
#dash-donate .card-header { border-bottom: 0; padding-bottom: .25rem; }
#dash-donate .card-header h6 { letter-spacing: .04em; }

/* ---------- Заглавен бар ---------- */
/* [EN] Top header bar for the donate section */

#dash-donate .bg-body.border.rounded.p-3.mb-3 {
  border-radius: var(--donate-radius);
  box-shadow: var(--donate-shadow-sm);
  background:
    radial-gradient(1200px 1200px at 100% -10%, rgba(13,110,253,.08), transparent 60%),
    var(--bs-body-bg);
}

/* ---------- Нав табове (PayPal/Crypto) ---------- */
/* [EN] Nav tabs to switch between PayPal and Crypto methods */

#donateMethod .nav-link {
  border-radius: 999px;
  padding: .5rem .9rem;
  box-shadow: var(--donate-shadow-sm);
  transition: transform .15s ease, box-shadow .15s ease, background-color .15s ease;
}
#donateMethod .nav-link:hover { transform: translateY(-1px); }
#donateMethod #paypal_show i { color: var(--paypal-color); }
#donateMethod #crypto_show i { color: var(--crypto-color); }

/* Активно състояние (без JS; стилизираме общо) */
/* [EN] Generic active state styling for the selected donate tab */

#donateMethod .nav-link.active {
  color: #fff;
  background-image: var(--donate-grad);
  box-shadow: 0 8px 24px rgba(13,110,253,.25);
}

/* ---------- Формови блокове ---------- */
/* [EN] Form sections for PayPal and Crypto cards */

#paypal_form .card-header i { color: var(--paypal-color); }
#crypto_form .card-header i { color: var(--crypto-color); }

#dash-donate .form-select,
#dash-donate .form-control {
  border-radius: .75rem;
  padding-top: .6rem; padding-bottom: .6rem;
}

/* Малки помощни надписи */
/* [EN] Small uppercase helper labels */

#dash-donate .text-muted.text-uppercase { font-size: .75rem; }

/* ---------- Quick tiles (радио-карти) ---------- */
/* [EN] Quick amount tiles styled as radio-like cards */

label.payment-quick {
  cursor: pointer;
  border-radius: .85rem !important;
  transition: transform .1s ease, box-shadow .1s ease, outline-color .1s ease;
}
label.payment-quick .card-body {
  padding: .85rem .5rem !important;
}
label.payment-quick:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 24px rgba(0,0,0,.08) !important;
}

/* Активен тайл (без JS): label:has(input:checked) */
/* [EN] Visual highlight for the selected quick amount tile */

label.payment-quick:has(input:checked) {
  outline: 2px solid var(--bs-primary);
  box-shadow: 0 10px 28px rgba(13,110,253,.15) !important;
}
label.payment-quick .fw-bold { font-size: .95rem; }
label.payment-quick .small.text-secondary { font-size: .8rem; opacity: .9; }

/* Бейдж бонус */
/* [EN] Extra badge inside the quick tile (e.g., “Most popular”) */

label.payment-quick .badge {
  border-radius: 999px;
  padding: .3rem .6rem;
}

/* Подравняване на решетката при дребни екрани */
/* [EN] On very small screens, stack quick tiles in a single column */

@media (max-width: 420px) {
  .row.row-cols-2.g-2 .col { flex: 0 0 100%; max-width: 100%; }
}

/* ---------- Резюме на поръчката ---------- */
/* [EN] Order summary area on the right of the donation layout */

#dash-donate .summary-row { display:flex; justify-content:space-between; align-items:center; margin-bottom:.35rem; }
#dash-donate #summary_method.badge {
  font-weight: 600;
  letter-spacing:.02em;
  padding:.4rem .6rem;
  border-radius: 999px;
}
#dash-donate .summary-card { background: var(--bs-body-bg); }
#dash-donate .summary-card hr { opacity:.12; }

/* Подчертаване на метода визуално */
/* [EN] Color-coded summary badge depending on which method (PayPal/Crypto) is visible */

#paypal_form:where(:not([hidden])) ~ .col-lg-5 #summary_method { background: color-mix(in srgb, var(--paypal-color) 15%, transparent); color: var(--paypal-color); }
#crypto_form:where(:not([hidden])) ~ .col-lg-5 #summary_method { background: color-mix(in srgb, var(--crypto-color) 22%, transparent); color: var(--crypto-color); }

/* ---------- Чекбокс / бутон ---------- */
/* [EN] Checkbox focus ring and main “Donate” call-to-action button */

#dash-donate .form-check-input:focus { box-shadow: 0 0 0 .25rem rgba(13,110,253,.25); }
#donateBtn {
  border-radius: .8rem;
  padding:.7rem 1rem;
  box-shadow: 0 10px 28px rgba(13,110,253,.18);
}
#donateBtn:hover { transform: translateY(-1px); }

/* ---------- Достъпност / фокус ---------- */
/* [EN] Global focus-visible outline for keyboard accessibility */

:focus-visible { outline: 2px solid color-mix(in srgb, var(--bs-primary) 65%, #0000); outline-offset: 2px; border-radius: .5rem; }

/* ---------- Тъмен режим (ако ползваш data-bs-theme="dark") ---------- */
/* [EN] Dark mode tweaks for donate nav tabs and quick tiles */

[data-bs-theme="dark"] #donateMethod .nav-link { box-shadow: none; }
[data-bs-theme="dark"] label.payment-quick { background: rgba(255,255,255,.02); }
[data-bs-theme="dark"] label.payment-quick:hover { background: rgba(255,255,255,.04); }



/* ============================================================================
   L2Mid — Consolidated, Ordered, and Cleaned Stylesheet
   - Merges all blocks and key inline styles from the provided HTML
   - Theme-aware via [data-bs-theme]
   - Structured, deduplicated, with responsive and a11y considerations
   - Drop this as /css/style.css (or style.css) and remove inline styles
   ============================================================================ */




  /* Scope само в Lucky Wheel таба */
  #dash-luckywheel * { box-sizing: border-box; }

  /* ===== Wheel (НЕПРОМЕНЯН) ===== */
  #dash-luckywheel .wheel-container { position:relative; width:640px; height:832px; overflow:hidden; }
  #dash-luckywheel .wheel { position:absolute; top:50%; left:50%; width:100%; height:100%;
    transform:translate(-50%, calc(-50% + 200px)) scale(1.6) rotate(0deg);
    transform-origin:center center; will-change: transform; }
  @keyframes slow-spin {
    from { transform: translate(-50%, calc(-50% + 200px)) scale(1.6) rotate(0deg); }
    to   { transform: translate(-50%, calc(-50% + 200px)) scale(1.6) rotate(360deg); }
  }
  #dash-luckywheel .wheel.slow { animation: slow-spin 30s linear infinite; }

  #dash-luckywheel .gear { position:absolute; top:50%; left:50%; width:100%; height:100%;
    object-fit:contain; transform:translate(-50%,-50%); pointer-events:none; }

  #dash-luckywheel .reward { position:absolute; top:50%; left:50%; width:64px; height:64px;
    transform-origin:center center; pointer-events:none; transition:all .3s; }

  #dash-luckywheel .reward.highlight {
    outline: 4px solid gold; outline-offset: 4px; border-radius: 12px;
    box-shadow: 0 0 15px gold; z-index:200;
  }

  #dash-luckywheel .cover, #dash-luckywheel .border {
    position:absolute; inset:0; background-repeat:no-repeat; background-position:center; background-size:auto; pointer-events:none;
  }
  #dash-luckywheel .cover{background-image:url("/wheel/cover.png");}
  #dash-luckywheel .border{background-image:url("/wheel/border.png");}

  #dash-luckywheel .spin-btn { position:absolute; top:calc(69% + 40px); left:50%; transform:translate(-50%,-50%);
    width:259px; height:259px; background:url("/wheel/MAIN-BUTTON_click.png") no-repeat center/contain; border:none; cursor:pointer; z-index:100; }
  #dash-luckywheel .spin-btn:hover { background-image:url("/wheel/MAIN-BUTTON_mouseover.png"); }
  #dash-luckywheel .spin-btn:disabled { opacity:.6; cursor:not-allowed; }

  #dash-luckywheel .pointer {
    position:absolute; top:10px; left:50%; transform:translateX(-50%);
    width: 0; height: 0; border-left: 25px solid transparent; border-right: 25px solid transparent; border-bottom: 40px solid gold;
    z-index:150; filter: drop-shadow(0 0 5px #000);
  }

  /* ===== Панел вдясно (инфо + таблица с награди) ===== */
  #dash-luckywheel .lw-panel .lw-info {
    border-radius: .5rem;
    padding: .5rem .75rem;
    box-shadow: 0 2px 12px rgba(0,0,0,.06) inset;
  }

  /* Иконка + име на един ред (за двете таблици) */
  #dash-luckywheel .cell--reward{ display:flex; align-items:center; gap:8px; min-width:0; }
  #dash-luckywheel .cell--reward img{ width:28px; height:28px; flex:0 0 28px; border-radius:6px; object-fit:cover; }
  #dash-luckywheel .cell--reward .name{ overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

  /* Popup */
  #dash-luckywheel .popup{ position:fixed; inset:0; display:none; align-items:center; justify-content:center;
    background:rgba(0,0,0,.7); z-index:2000; }
  #dash-luckywheel .popup-content{ position:relative; width:400px; height:500px;
    display:flex; flex-direction:column; align-items:center; justify-content:flex-end; padding:20px; }
  #dash-luckywheel .popup-bg{ position:absolute; inset:0; width:100%; height:100%; object-fit:contain; pointer-events:none; }
  #dash-luckywheel .popup-effect{ position:absolute; top:-40px; left:50%; transform:translateX(-50%);
    width:320px; pointer-events:none; animation:pop-glow 1.2s ease-out both; }
  #dash-luckywheel .popup-win{ position:absolute; top:80px; left:50%; transform:translateX(-50%);
    width:220px; pointer-events:none; animation:pop-in .35s ease-out .1s both; }
  #dash-luckywheel .popup-reward{ position:relative; margin-top:auto; font-size:20px; color:#fff; text-align:center;
    text-shadow:0 0 10px rgba(255,215,0,.9), 0 0 20px rgba(255,215,0,.6); line-height:1.3; }
#dash-luckywheel .close-btn {
  margin-top:16px; 
  padding:10px 20px; 
  background:#222; 
  color:#fff;
  border:none; 
  border-radius:8px; 
  cursor:pointer;

  /* 🆕 За да е над картинките */
  position: relative;
  z-index: 10;
}
#dash-luckywheel .close-btn:hover { 
  background:#2b2b2b; 
}



  @keyframes pop-in{
    from{ transform:translateX(-50%) scale(.85); opacity:0; }
    to  { transform:translateX(-50%) scale(1);   opacity:1; }
  }
  @keyframes pop-glow{
    0%  { transform:translateX(-50%) scale(.9);  opacity:0;   filter:blur(2px); }
    60% { transform:translateX(-50%) scale(1.05);opacity:.95; filter:blur(0); }
    100%{ transform:translateX(-50%) scale(1);   opacity:1;   }
  }

  /* Toast винаги най-отгоре */
  #lw-toasts{ z-index:999999 !important; }







    .vote-card { transition: transform .15s ease, box-shadow .15s ease; border-radius: 1rem; }
    .vote-card:hover { transform: translateY(-2px); box-shadow: 0 .5rem 1.25rem rgba(0,0,0,.08); }
    .vote-logo { width: 44px; height: 44px; object-fit: cover; border-radius: .75rem; border: 1px solid var(--bs-border-color); }
    .vote-progress .progress-bar { transition: width .2s ease; }
	/* Claimed state for per-site claim button */
.btn-claimed {
  pointer-events: none;          /* да не се клика */
  opacity: 1;                    /* нека е четим, не избледнял */
}
.btn-claimed i {
  /* зелен check остава зелен върху бял фон */
}
    .cooldown.loading { display: inline-block; min-width: 60px; background: linear-gradient(90deg, rgba(0,0,0,.06), rgba(0,0,0,.12), rgba(0,0,0,.06)); background-size: 200% 100%; animation: shine 1.2s linear infinite; color: transparent; border-radius: .25rem; }
    @keyframes shine { from { background-position: 200% 0 } to { background-position: -200% 0 } }

  
  
/* ----------------------------------------------------------------------------
   0) ACCESSIBILITY / REDUCED MOTION
---------------------------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  * { animation-duration:.001ms!important; animation-iteration-count:1!important; transition-duration:.001ms!important; scroll-behavior:auto!important; }
  #discord .card{ transition: none; }
  #discord .blur-dot{ filter: none; }
  #discord .noise-layer{ display:none; }
}

/* ----------------------------------------------------------------------------
   1) DESIGN TOKENS (Light + Dark overrides)
---------------------------------------------------------------------------- */
:root, [data-bs-theme="light"] {
  /* Radii, shadows, motion */
  --ds-radius: .9rem;
  --ds-radius-sm: .6rem;
  --ds-shadow-soft: 0 8px 18px rgba(0,0,0,.08);
  --ds-shadow-strong: 0 12px 24px rgba(0,0,0,.12);
  --ds-inset-hairline: inset 0 0 0 1px rgba(0,0,0,.06);
  --ds-duration: .15s;

  /* Hero (discord section) */
  --ds-hero-start: #0d6efd;
  --ds-hero-end:   #6610f2;
  --ds-hero-radial: rgba(0,0,0,.05);
  --ds-hero-border: rgba(0,0,0,.10);
  --ds-hero-text:  #212529;

  /* Bubbles */
  --ds-bubble-bg:  #1f2937;
  --ds-bubble-text:#f8f9fa;

  /* Badges */
  --ds-badge-text: #212529;

  /* Tab indicator */
  --ds-tab-indicator: var(--bs-primary);

  /* Site palette */
  --bg: #eef2f6;
  --bg-soft: #ffffff;
  --text: #15181f;
  --text-soft: #333a46;
  --muted: #6c757d;
  --card-bg: #ffffff;
  --section-bg: #eef2f6;
  --border: #dfe3ea;
  --footer-bg: #e9edf2;
  --primary: #0d6efd;
  --primary-600: #0b5ed7;
  --secondary: #6f42c1;
  --info: #0dcaf0;
  --success: #198754;
  --warning: #ffca28;
  --danger: #dc3545;
  --shadow-soft: 0 8px 24px rgba(0,0,0,0.08);
  --shadow-strong: 0 12px 32px rgba(0,0,0,0.12);
  --hero-bg: #eef2f6;
  --hero-gradient: linear-gradient(
    rgba(255, 255, 255, 0.35),
    rgba(255, 255, 255, 0.35)
  );
  --announce-text: #15181f;
  --chip-bg: #f0f4f8;
  --overlay-80: rgba(0,0,0,.8);
  --progress-track: #e5e7eb;
  --progress-fill: linear-gradient(to right, #4caf50, #81c784);
  --stream-info-bg: #000;

  /* Buttons (light) */
  --btn-text: #ffffff;
  --btn-bg: var(--primary);
  --btn-border: var(--primary);
  --btn-bg-hover: var(--primary-600);
  --btn-border-hover: var(--primary-600);
  --btn-secondary-text: #ffffff;
  --btn-secondary-bg: #495057;
  --btn-secondary-border: #495057;
  --btn-secondary-bg-hover: #343a40;
  --btn-secondary-border-hover: #343a40;
  --btn-outline-text: var(--text);
  --btn-outline-border: var(--text);
  --btn-outline-hover-text: #ffffff;
  --btn-outline-hover-bg: var(--text);
  --btn-outline-hover-border: var(--text);
  --btn-light-text: #212529;
  --btn-light-bg: #f8f9fa;
  --btn-light-border: #dfe3e7;
  --btn-light-hover-text: #212529;
  --btn-light-hover-bg: #e9ecef;
  --btn-light-hover-border: #d1d5db;
  --btn-dark-text: #ffffff;
  --btn-dark-bg: #212529;
  --btn-dark-border: #212529;
  --btn-dark-hover-text: #ffffff;
  --btn-dark-hover-bg: #111315;
  --btn-dark-hover-border: #111315;
}

[data-bs-theme="dark"] {
  --ds-hero-start: #1a1a1a;
  --ds-hero-end:   #343a40;
  --ds-hero-radial: rgba(255,255,255,.12);
  --ds-hero-border: rgba(255,255,255,.15);
  --ds-hero-text:  #f8f9fa;
  --ds-bubble-bg:  #111827;
  --ds-bubble-text:#e9ecef;
  --ds-badge-text: #111;
  --ds-inset-hairline: inset 0 0 0 1px rgba(255,255,255,.06);

  --bg: #181a20;
  --bg-soft: #16191e;
  --text: #ffffff;
  --text-soft: #d1d7e0;
  --muted: #9aa3af;
  --card-bg: #20242b;
  --section-bg: #181a20;
  --border: #23262d;
  --footer-bg: #181a20;
  --primary: #5aa0ff;
  --primary-600: #8abfff;
  --secondary: #6610f2;
  --info: #31d2f2;
  --success: #00d38a;
  --warning: #ffca28;
  --danger: #ff5c7a;
  --shadow-soft: 0 8px 24px rgba(0,0,0,.35);
  --shadow-strong: 0 12px 32px rgba(0,0,0,.5);
  --hero-bg: #16191e;
  --hero-gradient: linear-gradient(
    rgba(16,16,23, 0.35),
    rgba(16,16,23, 0.35)
  );
  --announce-text: #f8f9fa;
  --chip-bg: #2a2f37;
  --overlay-80: rgba(0,0,0,.8);
  --progress-track: #222;
  --btn-text: #0b1220;
  --btn-bg: #a6c8ff;
  --btn-border: #a6c8ff;
  --btn-bg-hover: #c2d9ff;
  --btn-border-hover: #c2d9ff;
  --btn-secondary-text: #0b1220;
  --btn-secondary-bg: #aab2bf;
  --btn-secondary-border: #aab2bf;
  --btn-secondary-bg-hover: #c3c9d4;
  --btn-secondary-border-hover: #c3c9d4;
  --btn-outline-text: #e7ecf3;
  --btn-outline-border: #e7ecf3;
  --btn-outline-hover-text: #0b1220;
  --btn-outline-hover-bg: #e7ecf3;
  --btn-outline-hover-border: #e7ecf3;
  --btn-light-text: #0b1220;
  --btn-light-bg: #e7ecf3;
  --btn-light-border: #dbe3ee;
  --btn-light-hover-text: #0b1220;
  --btn-light-hover-bg: #f2f6fb;
  --btn-light-hover-border: #e8eef7;
  --btn-dark-text: #ffffff;
  --btn-dark-bg: #111315;
  --btn-dark-border: #111315;
  --btn-dark-hover-text: #ffffff;
  --btn-dark-hover-bg: #000;
  --btn-dark-hover-border: #000;
}

/* ----------------------------------------------------------------------------
   2) TYPOGRAPHY / GLOBAL
---------------------------------------------------------------------------- */
:root {
  --fs-h1: clamp(1.6rem, 1.05rem + 2.2vw, 2.4rem);
  --fs-h2: clamp(1.3rem, 1rem + 1.6vw, 1.8rem);
  --fs-h3: clamp(1.15rem, .95rem + 1.2vw, 1.4rem);
  --fs-base: clamp(.95rem, .9rem + .4vw, 1.05rem);
  --fs-small: clamp(.85rem, .8rem + .3vw, .95rem);
}

html, body { background: var(--section-bg); color: var(--text); min-height: 100%; }
body { display:flex; flex-direction:column; font-size: var(--fs-base); }

h1{ font-size: var(--fs-h1); }
h2{ font-size: var(--fs-h2); }
h3,h4{ font-size: var(--fs-h3); }
small,.small{ font-size: var(--fs-small)!important; }

a { color: var(--primary); }
a:hover { color: var(--primary-600); }

img, iframe { max-width: 100%; max-height: 100%; display:block; }

/* Avoid overflow clipping for rich sections */
p, li, .announcement-body, .discord-msg .bg-dark-subtle, .list-group-item, .tab-pane, .card, .section-header, .info-box, .stream-info {
  overflow-wrap:anywhere; word-break:break-word;
}

/* Container padding */
.container, .container-fluid { padding-left: clamp(12px, 3vw, 16px); padding-right: clamp(12px, 3vw, 16px); }

/* ----------------------------------------------------------------------------
   3) HELPERS / UTILITIES
---------------------------------------------------------------------------- */
.bg-dark-subtle{ background: rgba(255,255,255,.06)!important; border:1px solid var(--border); border-radius:.5rem; color:var(--text); }
.link-light{ color:var(--text)!important; opacity:.85; }
.link-light:hover{ opacity:1; }
.shadow-soft{ box-shadow: var(--shadow-soft); }
.shadow-strong{ box-shadow: var(--shadow-strong); }
.brand--autoInvert{ filter: invert(0); }
[data-bs-theme="dark"] .brand--autoInvert{ filter: invert(0); }

/* Map of inline-replacement helpers */
.card--fc{ border:1px solid var(--border); background:#fff; border-radius:1rem; }
.banner--rewards{ background: linear-gradient(to right, #b8860b, #8b7500); }
.card--rounded{ border-radius:1rem; }

/* ----------------------------------------------------------------------------
   4) NAVBAR
---------------------------------------------------------------------------- */
.navbar {
  position: sticky; top: 0; z-index: 1050; background: var(--card-bg) !important;
  border-bottom: 1px solid var(--border); min-height: 70px; display:flex; align-items:center;
}
.navbar .navbar-brand { font-size: 1.35rem; font-weight: 700; }
.navbar .navbar-brand img { max-height: 44px; }
.navbar .nav-link {
  position: relative; font-size: 1.15rem; padding: 1rem 1.25rem; border-radius: .6rem; color: var(--text) !important; transition: color 0.2s;
}
.navbar .nav-link:hover, .navbar .nav-link:focus { color: var(--primary) !important; }
.navbar .nav-link::after {
  content: ""; position: absolute; left: 25%; bottom: 6px; width: 50%; height: 2px; background-color: var(--primary);
  transform: scaleX(0); transform-origin: center; transition: transform 0.25s ease-in-out; border-radius: 2px;
}
.navbar .nav-link:hover::after, .navbar .nav-link:focus::after, .navbar .nav-link.active::after { transform: scaleX(1); }
.navbar .btn { font-size: 1rem; padding: .55rem 1.1rem; border-radius: .6rem; }

@media (max-width: 992px) {
  .navbar .navbar-brand img{ max-height: 40px; }
  .navbar .nav-link{ font-size: 1.05rem; padding: .75rem 1rem; display:block; }
  .navbar .navbar-collapse{ padding-top:.25rem; }
  .navbar .d-flex.align-items-center.gap-2{ gap:.5rem!important; }
  .navbar .btn{ width: 100%; font-size: .95rem; padding: .45rem .9rem; }
}

/* ----------------------------------------------------------------------------
   5) BUTTONS (theme-aware)
---------------------------------------------------------------------------- */
.btn { --bs-btn-border-width:1px; }
.btn-primary { color:var(--btn-text)!important; background:var(--btn-bg)!important; border-color:var(--btn-border)!important; }
.btn-primary:hover, .btn-primary:focus { color:var(--btn-text)!important; background:var(--btn-bg-hover)!important; border-color:var(--btn-border-hover)!important; }
.btn-secondary { color:var(--btn-secondary-text)!important; background:var(--btn-secondary-bg)!important; border-color:var(--btn-secondary-border)!important; }
.btn-secondary:hover, .btn-secondary:focus { color:var(--btn-secondary-text)!important; background:var(--btn-secondary-bg-hover)!important; border-color:var(--btn-secondary-border-hover)!important; }
.btn-outline-primary { color:var(--primary)!important; border-color:var(--primary)!important; }
.btn-outline-primary:hover, .btn-outline-primary:focus { background:var(--primary)!important; color:#fff!important; border-color:var(--primary)!important; }
.btn-outline-light { color:var(--btn-outline-text)!important; border-color:var(--btn-outline-border)!important; background:transparent!important; }
.btn-outline-light:hover, .btn-outline-light:focus { color:var(--btn-outline-hover-text)!important; background:var(--btn-outline-hover-bg)!important; border-color:var(--btn-outline-hover-border)!important; }
.btn-outline-dark { color:var(--text)!important; border-color:var(--text)!important; }
.btn-outline-dark:hover, .btn-outline-dark:focus { background:var(--text)!important; color:#fff!important; }
.btn-light { color:var(--btn-light-text)!important; background:var(--btn-light-bg)!important; border-color:var(--btn-light-border)!important; }
.btn-light:hover, .btn-light:focus { color:var(--btn-light-hover-text)!important; background:var(--btn-light-hover-bg)!important; border-color:var(--btn-light-hover-border)!important; }
.btn-dark { color:var(--btn-dark-text)!important; background:var(--btn-dark-bg)!important; border-color:var(--btn-dark-border)!important; }
.btn-dark:hover, .btn-dark:focus { color:var(--btn-dark-hover-text)!important; background:var(--btn-dark-hover-bg)!important; border-color:var(--btn-dark-hover-border)!important; }

@media (max-width: 576px){ .btn{ padding:.55rem .9rem; } .btn-lg{ padding:.75rem 1rem; font-size:1.05rem; } }

/* ----------------------------------------------------------------------------
   6) HERO
---------------------------------------------------------------------------- */
.main-hero { background: var(--hero-bg) url('../img/bg/forest-wall.png') no-repeat center/cover; position:relative; color:var(--text); min-height:420px; height: clamp(420px, 58vh, 560px); display:flex; align-items:center; }
.main-hero::before { content:""; position:absolute; inset:0; background:var(--hero-gradient); z-index:1; }
.hero-inner { position:relative; z-index:2; display:grid; grid-template-columns: 1fr auto; gap:2rem; align-items:start; padding-block:2rem; }
.hero-text { min-width:240px; padding-inline:1rem; }
.hero-title { font-size:clamp(1.8rem, 1rem + 2.5vw, 2.6rem); font-weight:700; line-height:1.1; letter-spacing:-.02em; text-shadow:0 2px 20px #0001; }
.hero-desc { font-size:1.05rem; color:var(--text-soft); text-shadow:0 2px 10px #0001; }

@media (max-width:992px){ .hero-inner { grid-template-columns:1fr; } }
@media (max-width: 992px){ .main-hero{ height:auto; min-height:420px; top:0; } .hero-inner{ gap:1.25rem; padding-block:1.25rem; } }

/* ----------------------------------------------------------------------------
   7) SERVER CARD
---------------------------------------------------------------------------- */
.server-card{ width:min(360px,100%); background:var(--card-bg); color:var(--text); border-left:5px solid var(--primary); border-radius:1rem; box-shadow:var(--shadow-soft); padding:1.25rem; border:1px solid var(--border); }
.server-card .logo{ width:48px; margin-right:.6rem; border-radius:8px; box-shadow:0 0 12px rgba(13,110,253,.15); }
.server-card h5{ font-size:1.25rem; font-weight:700; margin-bottom:.6rem; }
.server-card .badge{ font-size:.9em; padding:.3em .7em; letter-spacing:.4px; }
.server-stats-row span{ font-size:1rem; white-space:nowrap; }

.countdown-compact{ background:var(--bg-soft); border-radius:6px; border:1px solid var(--border); }
.countdown-compact small{ color:var(--text-soft); }
#countdown-timer{ color:var(--text); display:flex; gap:.4rem; justify-content:center; }
.countdown-compact span{ background:var(--chip-bg); padding:4px 6px; border-radius:4px; min-width:28px; display:inline-block; text-align:center; }

/* ----------------------------------------------------------------------------
   8) SECTION HEADER
---------------------------------------------------------------------------- */
.section-header{  background: url('/img/sections-head.png') center/cover no-repeat, var(--card-bg); border-radius:.7rem; border:1px solid var(--border); padding:1rem 1.25rem; margin:1.25rem 0; display:flex; align-items:center; justify-content:space-between; color:var(--text); box-shadow:var(--shadow-soft); gap:.6rem; flex-wrap:wrap; }
.section-header h4, .section-header .text-light{ color:var(--text)!important; }
@media (max-width: 768px){ .section-header{ gap:.5rem; padding:.75rem 1rem; flex-direction: column; align-items: flex-start; } .section-header .btn{ width:100%; } }

#server-stats .section-header {
  background: url('/img/sections-head.png') center/cover no-repeat, var(--card-bg) !important;
  color: var(--text) !important;
  border: 1px solid var(--border) !important;
}

/* ----------------------------------------------------------------------------
   10) INFO BOXES
---------------------------------------------------------------------------- */
.info-box{ background: linear-gradient(145deg, var(--card-bg), rgba(0,0,0,.02)); border-radius:16px; box-shadow:var(--shadow-strong); transition: transform .3s, box-shadow .3s; color:var(--text); border:1px solid var(--border); padding:1.25rem; }
@media (max-width: 768px){ .info-box{ padding:1rem; } }

/* ----------------------------------------------------------------------------
   11) ANNOUNCEMENTS
---------------------------------------------------------------------------- */
.announcement-card{ background:var(--card-bg); border:1px solid var(--border); border-radius:1rem; overflow:hidden; box-shadow:0 0 20px rgba(13,202,240,.08); }
.announcement-banner img{ width:100%; height:auto; display:block; }
.announcement-header{ background: linear-gradient(90deg, var(--info), var(--secondary)); padding:.75rem 1.25rem; display:flex; align-items:center; gap:.75rem; color:#fff; font-weight:700; font-size:1rem; }
.announcement-header img{ width:36px; height:36px; border-radius:50%; border:2px solid #fff; }
.announcement-header .time-info{ margin-left:10px; font-size:12px; color:#e9ecef; }
.announcement-body{ padding:1.25rem; font-size:1.05rem; line-height:1.6; font-weight:500; color:var(--announce-text); }
.announcement-meta{ font-size:.85rem; color:var(--muted); margin-top:.5rem; font-style:italic; }

/* ----------------------------------------------------------------------------
   12) SOCIAL TILES + FLAGCOUNTER
---------------------------------------------------------------------------- */
.social-tile{ display:flex; flex-direction:column; align-items:center; justify-content:center; gap:.35rem; height:100%; text-decoration:none; text-align:center; background:var(--card-bg); color:var(--text); border:1px solid var(--border); border-radius:.9rem; padding:14px 10px; box-shadow: var(--shadow-soft); transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease; }
.social-tile:hover, .social-tile:focus{ transform: translateY(-3px); box-shadow: var(--shadow-strong); border-color: color-mix(in srgb, var(--primary) 30%, var(--border)); color: var(--text); outline:none; }
.social-tile .label{ font-weight:700; font-size:.95rem; letter-spacing:.2px; }
.social-tile small{ color: var(--muted); font-size:.8rem; }

.social-icon{ width:44px; height:44px; border-radius:50%; display:grid; place-items:center; color:#fff; box-shadow: inset 0 0 8px rgba(0,0,0,.2), 0 4px 10px rgba(0,0,0,.12); border: 1px solid rgba(255,255,255,.18); }
.social-icon i{ font-size:18px; line-height:1; }
.bg-facebook{ background:#1877F2; }
.bg-fbgroup{ background:#1877F2; }
.bg-instagram{ background:linear-gradient(45deg,#F58529,#DD2A7B,#8134AF,#515BD4); }
.bg-tiktok{ background:#111; }
.bg-youtube{ background:#FF0000; }
.bg-discord{ background:#5865F2; }
.bg-vk{ background:#0077FF; }
.bg-telegram{ background:#46b1f1; }

.fc-image{ display:block; width:100%; height:auto; }
.fc-image-wrap{ display:inline-block; }

/* Card look for the Real Statistics (FlagCounter) container */
.realstats-card{ background:var(--card-bg); border:1px solid var(--border); border-radius:1rem; }




    .vote-card { transition: transform .15s ease, box-shadow .15s ease; border-radius: 1rem; }
    .vote-card:hover { transform: translateY(-2px); box-shadow: 0 .5rem 1.25rem rgba(0,0,0,.08); }
    .vote-logo { width: 44px; height: 44px; object-fit: cover; border-radius: .75rem; border: 1px solid var(--bs-border-color); }
    .vote-progress .progress-bar { transition: width .2s ease; }
	/* Claimed state for per-site claim button */
.btn-claimed {
  pointer-events: none;          /* да не се клика */
  opacity: 1;                    /* нека е четим, не избледнял */
}
.btn-claimed i {
  /* зелен check остава зелен върху бял фон */
}
    .cooldown.loading { display: inline-block; min-width: 60px; background: linear-gradient(90deg, rgba(0,0,0,.06), rgba(0,0,0,.12), rgba(0,0,0,.06)); background-size: 200% 100%; animation: shine 1.2s linear infinite; color: transparent; border-radius: .25rem; }
    @keyframes shine { from { background-position: 200% 0 } to { background-position: -200% 0 } }
  
  
  
/* ----------------------------------------------------------------------------
   13) DISCORD REWARDS + WIDGET
---------------------------------------------------------------------------- */
#discord .discord-hero{ position: relative; isolation: isolate; overflow: hidden; color: var(--ds-hero-text); background: radial-gradient(800px 400px at 20% -20%, var(--ds-hero-radial), transparent 60%), var(--bs-body-bg); border-radius: var(--ds-radius); box-shadow: var(--ds-shadow-soft); }
#discord .noise-layer{ position:absolute; inset:0; z-index:0; opacity:.08; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); mix-blend-mode: soft-light; pointer-events:none; will-change: opacity; }
#discord.is-reduced-noise .noise-layer{ display:none; }
#discord .blur-dot{ position:absolute; right:-40px; bottom:-40px; width:220px; height:220px; border-radius:50%; filter: blur(60px); background: rgba(255,255,255,.15); z-index: 1; }

#discord .discord-widget{ display:block; width:100%; height:780px; border:0; border-radius: 0 0 var(--ds-radius) var(--ds-radius); }
#discord .card{ transition: transform var(--ds-duration) ease, box-shadow var(--ds-duration) ease; border-radius: var(--ds-radius); box-shadow: var(--ds-inset-hairline); }

#discord .msg-bubble{ background: var(--ds-bubble-bg); color: var(--ds-bubble-text); border-radius: calc(var(--ds-radius) - .05rem); padding:.7rem .85rem; box-shadow: inset 0 0 0 1px rgba(255,255,255,.04); word-break: break-word; }

#discord .rank-badge{ display:inline-flex; align-items:center; justify-content:center; width:40px; height:28px; border-radius: var(--ds-radius-sm); font-weight:800; letter-spacing:.2px; font-variant-numeric: tabular-nums; background: var(--bs-body-tertiary); box-shadow: var(--ds-inset-hairline); color: #737885; }
#discord .rank-badge.rank-1{ background: linear-gradient(180deg,#fff3cd,#ffe08a); box-shadow: 0 2px 10px rgba(255,193,7,.25); }
#discord .rank-badge.rank-2{ background: linear-gradient(180deg,#e9ecef,#cfd4da); box-shadow: 0 2px 10px rgba(108,117,125,.25); }
#discord .rank-badge.rank-3{ background: linear-gradient(180deg,#fff1e6,#ffd6b3); box-shadow: 0 2px 10px rgba(255,159,67,.25); }
.bg-orange-subtle{ background:#fff1e6 !important; }
.text-orange-emphasis{ color:#a34d00 !important; }

#discord .nav-tabs{ border-bottom: 1px solid var(--ds-hero-border); }
#discord .nav-tabs .nav-link{ border:none; position:relative; border-radius: .5rem .5rem 0 0; color: inherit; }
#discord .nav-tabs .nav-link.active{ font-weight:700; background: transparent; }
#discord .nav-tabs .nav-link.active::after{ content:""; position:absolute; left:.8rem; right:.8rem; bottom:-6px; height:3px; background: var(--ds-tab-indicator); border-radius:999px; }

/* ----------------------------------------------------------------------------
   14) UNIFIED TABS (Social/Stats/Streamers)
---------------------------------------------------------------------------- */
.tabs-unified{ border-bottom: 1px solid var(--border); overflow-x: auto; white-space: nowrap; flex-wrap: nowrap; gap: .15rem; -ms-overflow-style: none; scrollbar-width: none; }
.tabs-unified::-webkit-scrollbar{ display: none; }
.tabs-unified .nav-link{ color: var(--text-soft) !important; border: 1px solid transparent !important; border-top-left-radius: .5rem; border-top-right-radius: .5rem; padding: .5rem .9rem; }
.tabs-unified .nav-link:hover{ color: var(--text) !important; }
.tabs-unified .nav-link.active{ color: var(--text) !important; background: var(--card-bg) !important; border: 1px solid var(--border) !important; border-bottom-color: transparent !important; font-weight: 600; }

/* Content frame under tabs (server stats & discord lists) */
#discord #discordTabsContent,
#server-stats #statsTabsContent{ background: var(--card-bg); color: var(--text); border: 1px solid var(--border); border-radius: .75rem; padding: 1rem; margin-top: .5rem; overflow-x:auto; }

/* ----------------------------------------------------------------------------
   15) SERVER STATISTICS
---------------------------------------------------------------------------- */
#server-stats .nav-tabs{ border-bottom:1px solid var(--border); overflow-x:auto; white-space:nowrap; -ms-overflow-style:none; scrollbar-width:none; }
#server-stats .nav-tabs::-webkit-scrollbar{ display:none; }
#server-stats .nav-tabs .nav-link{ color:var(--text-soft)!important; border-color:transparent!important; }
#server-stats .nav-tabs .nav-link:hover{ color:var(--text)!important; }
#server-stats .nav-tabs .nav-link.active{ color:var(--text)!important; background:var(--card-bg)!important; border:1px solid var(--border)!important; border-bottom-color:transparent!important; }
#server-stats .list-group-item{ background:transparent!important; color:var(--text)!important; border-color:var(--border)!important; }
#server-stats .text-success{ color:var(--success)!important; }
#server-stats .text-danger{ color:var(--danger)!important; }
#server-stats .text-primary{ color:var(--primary)!important; }
#server-stats .table thead th{ font-size:.85rem; text-transform:uppercase; letter-spacing:.05em; }
#server-stats .table td{ font-size:.95rem; vertical-align:middle; }
#server-stats .table-hover tbody tr:hover{ background-color: rgba(255,255,255,.06); }

@media (max-width: 768px){ #server-stats #statsTabsContent{ padding:.75rem; } #server-stats .table{ display:block; overflow-x:auto; width:100%; } #server-stats .list-group-item{ padding:.65rem .75rem; } }

/* ---------------------------------------------------------------------------
   16) VIDEOS & SCREENSHOTS
---------------------------------------------------------------------------- */
.video-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.1rem;margin-top:20px;}
.screenshot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.1rem;margin-bottom:2rem;}
.video-card{position:relative;display:block;width:100%;padding:0;border:1px solid var(--border);border-radius:.9rem;background:var(--card-bg);box-shadow:0 4px 16px rgba(0,0,0,.18);overflow:hidden;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease,background .15s ease;}
.video-card:hover{transform:translateY(-4px) scale(1.02);box-shadow:var(--shadow-strong);border-color:rgba(255,255,255,.06);background:var(--card-bg-elevated,var(--card-bg));}
.video-card:focus-visible{outline:2px solid #ff4b4b;outline-offset:3px;box-shadow:0 0 0 2px rgba(255,75,75,.4),var(--shadow-strong);}
.video-thumb-wrapper{position:relative;width:100%;padding-top:56.25%;overflow:hidden;border-radius:.9rem .9rem 0 0;background:#000;}
.video-thumb-wrapper img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scale(1);filter:brightness(.9);transition:transform .25s ease,filter .25s ease;}
.video-card:hover .video-thumb-wrapper img{transform:scale(1.05);filter:brightness(1);}
.video-thumb-wrapper::before{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.7),rgba(0,0,0,0));opacity:0;transition:opacity .25s ease;}
.video-card:hover .video-thumb-wrapper::before{opacity:1;}
.video-thumb-wrapper::after{content:'';position:absolute;top:50%;left:50%;border-style:solid;border-width:14px 0 14px 24px;border-color:transparent transparent transparent #fff;transform:translate(-50%,-50%) scale(.9);opacity:0;transition:opacity .25s ease,transform .25s ease;filter:drop-shadow(0 0 6px rgba(0,0,0,.8));}
.video-card:hover .video-thumb-wrapper::after,.video-card:focus-visible .video-thumb-wrapper::after{opacity:1;transform:translate(-50%,-50%) scale(1);}
.video-card .yt-label{position:absolute;left:10px;bottom:10px;padding:2px 8px;border-radius:999px;font-size:11px;text-transform:uppercase;letter-spacing:.06em;background:rgba(0,0,0,.75);color:#fff;}
.screenshot-card{background:var(--card-bg);border-radius:.7rem;border:1px solid var(--border);box-shadow:0 2px 16px rgba(0,0,0,.08);overflow:hidden;transition:transform .13s,box-shadow .13s;cursor:pointer;}
.screenshot-card:hover{transform:translateY(-5px) scale(1.03);box-shadow:var(--shadow-strong);}
.screenshot-card img{width:100%;height:190px;object-fit:cover;background:#000;min-height:140px;display:block;}
@media (max-width:576px){.video-grid{grid-template-columns:1fr;}.screenshot-grid{grid-template-columns:1fr;}.screenshot-card img{height:180px;}}

/* ----------------------------------------------------------------------------
   17) STREAMERS
---------------------------------------------------------------------------- */
.stream-card{ overflow:hidden; border-radius:8px; transition: transform .3s, box-shadow .3s; background:var(--bg-soft); flex-direction:column; box-shadow:0 2px 8px rgba(0,0,0,.15); }
.stream-card:hover{ transform:scale(1.03); box-shadow:var(--shadow-strong); }
.stream-card iframe, .stream-card img, .stream-card .pending-placeholder { width:100%; aspect-ratio:16/9; height:auto; border-radius:8px 8px 0 0; object-fit:cover; }
.discord-widget{ width:100%; height:100%; border-radius:8px; }
.stream-info{ padding:8px 10px; background:var(--stream-info-bg); color:#fff; display:flex; align-items:center; justify-content:space-between; }
.live-badge{ background:red; color:#fff; font-size:.75rem; padding:2px 6px; border-radius:4px; margin-left:6px; font-weight:bold; }
.char-name{ font-size:.85rem; color:#fff; }

@media (max-width: 576px){ .stream-card{ margin-bottom:.75rem; } .stream-info{ padding:6px 8px; } .stream-info h6{ font-size:1rem; } .char-name{ font-size:.85rem; } }

/* Rewards banner (was inline) */
.streamers-reward-banner{ background: linear-gradient(to right, #b8860b, #8b7500); }

/* ----------------------------------------------------------------------------
   18) MODALS (Gallery/Video)
---------------------------------------------------------------------------- */
#imageModal, #videoModal{ display:none; position:fixed; inset:0; z-index:9999; background:var(--overlay-80); justify-content:center; align-items:center; }
#imageModal .close, #videoModal .close{ position:absolute; top:10px; right:20px; color:#fff; font-size:30px; cursor:pointer; }
.modal-controls{ position:absolute; bottom:20px; width:100%; text-align:center; }
.modal-controls button{ margin:0 10px; padding:10px 15px; background:rgba(0,0,0,.7); color:#fff; border:none; border-radius:8px; cursor:pointer; }
.modal-content{ background: color-mix(in srgb, var(--card-bg) 88%, transparent); border:1px solid var(--border); backdrop-filter: blur(6px); }
#videoModal{ padding:24px; }
#videoModal iframe#modalVideo{ width:100%; max-width:960px; aspect-ratio:16/9; height:auto; border-radius:10px; display:block; border:0; }
@media (max-width: 992px){ #videoModal iframe#modalVideo{ max-width:90vw; } }
@media (max-height: 600px){ #videoModal iframe#modalVideo{ max-width:85vw; } }
#imageModal .modal-content{ max-width: 96vw; max-height: 80vh; }
#videoModal iframe#modalVideo{ max-width: 96vw; max-height: calc(80vh); }

/* Dev modal skin (from inline) */
#devModal .modal-content { border: none; background: linear-gradient(145deg, var(--card-bg, #fff), rgba(0,0,0,.03)); }

/* ----------------------------------------------------------------------------
   19) FORMS / TOASTS
---------------------------------------------------------------------------- */
.toast{ background:var(--card-bg)!important; color:var(--text)!important; border:1px solid var(--border)!important; }
.toast .btn-close{ filter: invert(0); opacity:.6; }
[data-bs-theme="dark"] .toast .btn-close{ filter: invert(1); }
.form-label{ color:var(--text); }
.form-select, .form-control{ background:var(--bg-soft); color:var(--text); border:1px solid var(--border); }
.input-group-text{ background:var(--bg-soft); color:var(--text); border:1px solid var(--border); }

/* ----------------------------------------------------------------------------
   20) FOOTER
---------------------------------------------------------------------------- */
footer{ background:var(--footer-bg); padding:2.3rem 0 1rem; color:var(--muted); border-top:1px solid var(--border); margin-top:auto; }
.footer-grid{ display:grid; grid-template-columns: repeat(3, minmax(180px,1fr)); gap:1.5rem; }
.footer-grid h5{ font-weight:600; color:var(--text); font-size:1.1rem; }
@media (max-width:768px){ footer{ padding:1.6rem 0 .8rem; } .footer-grid{ grid-template-columns:1fr!important; gap:1rem; } footer p, footer li{ line-height:1.5; } }

/* ----------------------------------------------------------------------------
   21) LIGHT THEME NEUTRALIZERS (for legacy dark classes)
---------------------------------------------------------------------------- */
[data-bs-theme="light"] .bg-dark,
[data-bs-theme="light"] .card-header.bg-dark,
[data-bs-theme="light"] .list-group-item.bg-dark,
[data-bs-theme="light"] .tab-content.bg-dark { background:var(--card-bg)!important; }
[data-bs-theme="light"] .text-light,
[data-bs-theme="light"] .list-group-item.text-light,
[data-bs-theme="light"] .tab-content.text-light { color:var(--text)!important; }
[data-bs-theme="light"] .social-section .text-light{ color:#fff!important; }

/* ----------------------------------------------------------------------------
   22) RESPONSIVE PATCHES / MISC
---------------------------------------------------------------------------- */
img{ height:auto; max-width:100%; }
.container, .container-fluid{ padding-left: clamp(12px, 4vw, 18px); padding-right: clamp(12px, 4vw, 18px); }

/* Hide horizontal scrollbars for certain tab bars on small screens */
#server-stats .nav-tabs, #streamers .nav-tabs{ -ms-overflow-style: none; scrollbar-width: none; }
#server-stats .nav-tabs::-webkit-scrollbar, #streamers .nav-tabs::-webkit-scrollbar{ display: none; }



/* --- Section Header helper (global) --- */
    .section-header { gap: .75rem; }
    .section-header h4 { line-height: 1.25; }
    .section-header .section-actions { display: flex; align-items: center; gap: .5rem; }
    @media (max-width: 576px){
      .section-header { flex-direction: column; align-items: stretch; }
      .section-header .section-actions { width: 100%; }
      .section-header .section-actions .btn { width: 100%; }
    }

    /* --- Page-specific polish (keeps it portable) --- */
    :root { --hero-h: clamp(340px, 60vh, 520px); }

    .sd-hero {
      position: relative; min-height: var(--hero-h);
      display: grid; place-items: center;
      background: center/cover no-repeat var(--bs-body-bg);
      border-bottom: 1px solid var(--bs-border-color); overflow: hidden;
    }
    .sd-hero::before { content: ""; position: absolute; inset: 0;
      background: radial-gradient(120% 80% at 50% 10%, rgba(0,0,0,.45) 0, rgba(0,0,0,.7) 60%, rgba(0,0,0,.85) 100%); }
    .sd-hero .content { position: relative; z-index: 1; }
    .sd-hero .brand { filter: drop-shadow(0 8px 24px rgba(0,0,0,.35)); max-width: 120px; }

    .sd-toc { position: sticky; top: 84px; }
    .sd-toc .list-group-item.active{
      background: var(--bs-primary-bg-subtle);
      color: var(--bs-primary-text);
      border-color: var(--bs-primary-border-subtle);
      font-weight: 600;
    }
    .sd-kpis .card { border-radius: 1rem; }
    .sd-section h2 .eyebrow { font-size: .8rem; letter-spacing: .08em; text-transform: uppercase; color: var(--bs-secondary-color); }
    .rates-table td, .rates-table th { vertical-align: middle; }
    .feature-icon { width: 48px; height: 48px; display: grid; place-items: center; border-radius: 12px; border: 1px solid var(--bs-border-color); }
    .callout { border-left: 4px solid var(--bs-warning); background: rgba(var(--bs-warning-rgb), .05); }
    .checklist i { color: var(--bs-success); }
    .sd-footer-cta { background: linear-gradient(180deg, rgba(255,193,7,.08), transparent 60%); border-top: 1px solid var(--bs-border-color); }
	
	
	

/* --- Calendar styling --- */
  .calendar-day {
    cursor: pointer;
  }

  .calendar-day-inner {
    margin: .25rem auto;
    width: 2.4rem;
    height: 2.4rem;
    border-radius: .6rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .9rem;
    font-weight: 600;
    border: 1px solid var(--bs-border-color);
    background-color: rgba(255, 255, 255, 0.02);
    transition: background-color .15s ease, transform .08s ease, box-shadow .15s ease, border-color .15s ease, color .15s ease;
  }

  .calendar-day-empty {
    cursor: default;
  }

  .calendar-day-empty .calendar-day-inner {
    visibility: hidden;
  }

  .calendar-day-has-events .calendar-day-inner {
    border-color: transparent;
  }

  .calendar-day-today .calendar-day-inner {
    box-shadow: 0 0 0 1px rgba(var(--bs-info-rgb), .8);
  }

  .calendar-day-selected .calendar-day-inner {
    box-shadow: 0 0 0 2px rgba(var(--bs-primary-rgb), .9);
    transform: scale(1.06);
  }

  .calendar-day:not(.calendar-day-empty):hover .calendar-day-inner {
    transform: scale(1.08);
    box-shadow: 0 0 0 2px rgba(var(--bs-primary-rgb), .6);
  }

  @media (min-width: 992px) {
    .calendar-day-inner {
      width: 2.8rem;
      height: 2.8rem;
    }
  }
  
  