/* Защита от горизонтального скролла */
  html, body { overflow-x: hidden; max-width: 100vw; }

  .bg-light {
    background-color: var(--c2) !important;
    color: var(--fg) !important;
  }

  .bg-dark {
    background-color: var(--c1) !important;
    color: var(--fg) !important;
  }

  .bonus-hero {
    background: var(--grad1);
    border-radius: var(--rad2);
    padding: var(--sp4) var(--sp3);
    margin-bottom: var(--sp4);
    border: 1px solid var(--c3);
  }

  .bonus-highlight {
    font-size: 2.2rem;
    font-weight: 800;
    color: var(--c4);
    display: block;
    line-height: 1.1;
  }

  .bonus-card {
    background: var(--c1);
    border: 1px solid var(--c3);
    border-radius: var(--rad2);
    padding: var(--sp3);
    transition: var(--trans);
    color: var(--fg);
  }

  .bonus-card:hover {
    box-shadow: var(--glow1);
    border-color: var(--c4);
    transform: translateY(-3px);
  }

  .bonus-card .bonus-icon {
    font-size: 2.2rem;
    margin-bottom: 0.75rem;
    color: var(--c4);
  }

  .bonus-card h3 {
    color: var(--fg);
    font-size: 1.15rem;
    font-weight: 700;
    margin-bottom: 0.5rem;
  }

  .bonus-card p {
    color: var(--fg2);
    font-size: 0.95rem;
  }

  .badge-promo {
    display: inline-block;
    background: var(--c4);
    color: var(--bg);
    font-weight: 700;
    font-size: 0.78rem;
    border-radius: var(--rad3);
    padding: 0.2rem 0.7rem;
    margin-bottom: 0.6rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
  }

  .table {
    color: var(--fg);
    border-color: var(--c3);
  }

  .table thead {
    background: var(--c1);
    border-bottom: 2px solid var(--c4);
    color: var(--fg);
  }

  .table tbody tr {
    border-color: var(--c3);
    background-color: transparent;
  }

  .table tbody tr:nth-of-type(odd) {
    background-color: color-mix(in srgb, var(--c1) 60%, transparent);
  }

  .table-dark {
    --bs-table-bg: var(--c1);
    --bs-table-striped-bg: var(--c2);
    --bs-table-border-color: var(--c3);
  }

  .tnc-box {
    background: var(--c2);
    border-left: 4px solid var(--c4);
    border-radius: 0 var(--rad) var(--rad) 0;
    padding: var(--sp2) var(--sp3);
    color: var(--fg2);
    font-size: 0.88rem;
  }

  .step-number {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--grad2);
    color: var(--bg);
    font-weight: 800;
    font-size: 1.1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
  }

  .step-row {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    margin-bottom: 1.25rem;
  }

  .step-content h4 {
    color: var(--fg);
    font-weight: 700;
    margin-bottom: 0.2rem;
  }

  .step-content p {
    color: var(--fg2);
    font-size: 0.93rem;
    margin: 0;
  }

  .section-divider {
    border: none;
    border-top: 1px solid var(--c3);
    margin: 2.5rem 0;
  }

  .loyalty-tier {
    background: var(--c1);
    border: 1px solid var(--c3);
    border-radius: var(--rad2);
    padding: var(--sp2) var(--sp3);
    color: var(--fg);
    transition: var(--trans);
  }

  .loyalty-tier:hover {
    border-color: var(--c5);
  }

  .loyalty-tier .tier-name {
    font-weight: 700;
    color: var(--c5);
    font-size: 1.05rem;
  }

  .loyalty-tier p {
    color: var(--fg2);
    margin: 0;
    font-size: 0.9rem;
  }

  .btnPrimary, .btn-primary {
    background: var(--grad2) !important;
    border: none !important;
    color: var(--bg) !important;
    font-weight: 700;
    border-radius: var(--rad) !important;
    padding: 0.55rem 1.4rem;
    transition: var(--trans);
  }

  .btnPrimary:hover, .btn-primary:hover {
    box-shadow: var(--glow2);
    opacity: 0.92;
  }

  .section-label {
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--c4);
    margin-bottom: 0.4rem;
  }