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

  .bg-light {
    background-color: var(--color-surface-card) !important;
    color: var(--color-text-primary) !important;
  }

  .bg-dark {
    background-color: var(--color-neutral-800) !important;
    color: var(--color-text-primary) !important;
  }

  .table {
    color: var(--color-text-primary);
    border-color: var(--color-neutral-600);
  }

  .table thead {
    background: var(--color-neutral-800);
    border-bottom: 2px solid var(--color-brand-primary);
  }

  .table-striped > tbody > tr:nth-of-type(odd) > * {
    background-color: rgba(255,255,255,0.04);
    color: var(--color-text-primary);
  }

  .table > :not(caption) > * > * {
    background-color: transparent;
    color: var(--color-text-primary);
    border-color: var(--color-neutral-600);
  }

  .reg-step-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border-radius: var(--radius-full);
    background: var(--color-brand-primary);
    color: #fff;
    font-weight: 700;
    font-size: 1.2rem;
    margin-bottom: var(--spacing-sm);
    flex-shrink: 0;
  }

  .step-card {
    border: 1px solid var(--color-neutral-700);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    background: var(--color-surface-card);
    color: var(--color-text-primary);
    transition: var(--transition-smooth);
    display: flex;
    gap: var(--spacing-md);
    align-items: flex-start;
    margin-bottom: var(--spacing-md);
  }

  .step-card:hover {
    box-shadow: var(--shadow-card-hover);
    border-color: var(--color-brand-primary);
  }

  .step-content h3 {
    margin-bottom: var(--spacing-xs);
    font-size: 1.1rem;
    color: var(--color-brand-primary);
  }

  .step-content p {
    margin-bottom: 0;
    font-size: 0.95rem;
    color: var(--color-text-secondary);
  }

  .highlight-box {
    border-left: 4px solid var(--color-brand-primary);
    background: var(--color-surface-card);
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    padding: var(--spacing-md) var(--spacing-lg);
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-lg);
  }

  .highlight-box strong {
    color: var(--color-brand-primary);
  }

  .req-card {
    background: var(--color-neutral-800);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    border: 1px solid var(--color-neutral-700);
    color: var(--color-text-primary);
  }

  .req-card h3 {
    color: var(--color-accent-cyan);
    font-size: 1rem;
    margin-bottom: var(--spacing-sm);
  }

  .req-card ul {
    margin-bottom: 0;
    padding-left: 1.2rem;
    color: var(--color-text-secondary);
    font-size: 0.92rem;
  }

  .tip-block {
    background: linear-gradient(135deg, var(--color-brand-primary) 0%, var(--color-brand-secondary) 100%);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg) var(--spacing-xl);
    color: #fff;
    margin-bottom: var(--spacing-xl);
  }

  .tip-block h2 {
    color: #fff;
    margin-bottom: var(--spacing-sm);
  }

  .tip-block p, .tip-block li {
    color: rgba(255,255,255,0.9);
  }

  .cta-reg-btn {
    display: inline-block;
    background: var(--color-brand-primary);
    color: #fff;
    border-radius: var(--radius-full);
    padding: 0.75rem 2.25rem;
    font-weight: 700;
    font-size: 1.05rem;
    text-decoration: none;
    transition: var(--transition-smooth);
    border: none;
    box-shadow: var(--shadow-glow-primary);
    letter-spacing: 0.02em;
  }

  .cta-reg-btn:hover {
    opacity: 0.88;
    color: #fff;
    box-shadow: var(--shadow-card-hover);
    transform: translateY(-2px);
  }

  .section-divider {
    border: none;
    border-top: 1px solid var(--color-neutral-700);
    margin: var(--spacing-2xl) 0;
  }

  .faq-item {
    background: var(--color-surface-card);
    border: 1px solid var(--color-neutral-700);
    border-radius: var(--radius-md);
    padding: var(--spacing-md) var(--spacing-lg);
    margin-bottom: var(--spacing-sm);
    color: var(--color-text-primary);
  }

  .faq-item h3 {
    font-size: 1rem;
    color: var(--color-brand-primary);
    margin-bottom: var(--spacing-xs);
  }

  .faq-item p {
    margin-bottom: 0;
    font-size: 0.93rem;
    color: var(--color-text-secondary);
  }

  @media (max-width: 767px) {
    .step-card { flex-direction: column; }
    .reg-step-badge { width: 38px; height: 38px; font-size: 1rem; }
  }