/* Buttons and CTA Elements */
/* Переиспользуемые стили для кнопок с различными вариантами и состояниями */

/* ===== БАЗОВЫЙ КЛАСС .button ===== */

.button {
  /* Layout */
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  
  /* Sizing */
  min-height: 44px;
  padding: var(--space-3) var(--space-6);
  
  /* Typography */
  font-family: var(--font-family-base);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  line-height: 1;
  text-align: center;
  text-decoration: none;
  white-space: nowrap;
  
  /* Visual */
  border-radius: var(--border-radius-md);
  border: var(--border-width-medium) solid transparent;
  background-color: transparent;
  
  /* Interaction */
  cursor: pointer;
  user-select: none;
  transition: 
    background-color var(--transition-base) var(--ease-in-out),
    border-color var(--transition-base) var(--ease-in-out),
    color var(--transition-base) var(--ease-in-out),
    transform var(--transition-fast) var(--ease-out),
    box-shadow var(--transition-base) var(--ease-in-out);
  
  /* Accessibility */
  -webkit-tap-highlight-color: transparent;
}

/* Focus state для keyboard navigation */
.button:focus-visible {
  outline: 2px solid var(--color-primary-500);
  outline-offset: 2px;
}

/* Удаление дефолтного outline (используем focus-visible) */
.button:focus {
  outline: none;
}

/* ===== PRIMARY BUTTON ===== */

.button--primary {
  background-color: var(--color-primary-600);
  color: white;
  border-color: var(--color-primary-600);
}

.button--primary:hover {
  background-color: var(--color-primary-700);
  border-color: var(--color-primary-700);
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

.button--primary:active {
  background-color: var(--color-primary-800);
  border-color: var(--color-primary-800);
  transform: translateY(0);
  box-shadow: var(--shadow-sm);
}

.button--primary:disabled,
.button--primary[disabled] {
  background-color: var(--color-neutral-300);
  border-color: var(--color-neutral-300);
  color: var(--color-neutral-500);
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
  pointer-events: none;
}

/* ===== SECONDARY BUTTON ===== */

.button--secondary {
  background-color: var(--color-neutral-100);
  color: var(--color-neutral-900);
  border-color: var(--color-neutral-300);
}

.button--secondary:hover {
  background-color: var(--color-neutral-200);
  border-color: var(--color-neutral-400);
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}

.button--secondary:active {
  background-color: var(--color-neutral-300);
  border-color: var(--color-neutral-500);
  transform: translateY(0);
  box-shadow: none;
}

.button--secondary:disabled,
.button--secondary[disabled] {
  background-color: var(--color-neutral-100);
  border-color: var(--color-neutral-200);
  color: var(--color-neutral-400);
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
  pointer-events: none;
}

/* ===== OUTLINE BUTTON ===== */

.button--outline {
  background-color: transparent;
  color: var(--color-primary-700); /* Изменено с primary-600 для лучшей контрастности (7.90:1 WCAG AA) */
  border-color: var(--color-primary-700);
}

.button--outline:hover {
  background-color: var(--color-primary-50);
  color: var(--color-primary-800);
  border-color: var(--color-primary-800);
}

.button--outline:active {
  background-color: var(--color-primary-100);
  color: var(--color-primary-900);
  border-color: var(--color-primary-900);
}

.button--outline:disabled,
.button--outline[disabled] {
  background-color: transparent;
  border-color: var(--color-neutral-300);
  color: var(--color-neutral-400);
  cursor: not-allowed;
  pointer-events: none;
}

/* ===== GHOST BUTTON ===== */

.button--ghost {
  background-color: transparent;
  color: var(--color-primary-700); /* Изменено с primary-600 для лучшей контрастности (7.90:1 WCAG AA) */
  border-color: transparent;
  padding: var(--space-2) var(--space-4);
  min-height: 36px;
}

.button--ghost:hover {
  background-color: var(--color-primary-50);
  color: var(--color-primary-800);
}

.button--ghost:active {
  background-color: var(--color-primary-100);
  color: var(--color-primary-900);
}

.button--ghost:disabled,
.button--ghost[disabled] {
  background-color: transparent;
  color: var(--color-neutral-400);
  cursor: not-allowed;
  pointer-events: none;
}

/* ===== РАЗМЕРЫ КНОПОК ===== */

/* Small button */
.button--small {
  min-height: 36px;
  padding: var(--space-2) var(--space-4);
  font-size: var(--font-size-sm);
}

/* Default size уже определен в .button */

/* Large button */
.button--large {
  min-height: 56px;
  padding: var(--space-4) var(--space-8);
  font-size: var(--font-size-lg);
}

/* ===== FULL-WIDTH BUTTON ===== */

.button--full {
  width: 100%;
}

/* Full-width только на mobile */
@media (max-width: 640px) {
  .button--full-mobile {
    width: 100%;
  }
}

/* ===== ГРУППЫ КНОПОК ===== */

.button-group {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  align-items: center;
}

.button-group--center {
  justify-content: center;
}

.button-group--left {
  justify-content: flex-start;
}

.button-group--right {
  justify-content: flex-end;
}

.button-group--vertical {
  flex-direction: column;
  align-items: stretch;
}

.button-group--vertical .button {
  width: 100%;
}

/* Уменьшенный gap для компактных групп */
.button-group--compact {
  gap: var(--space-2);
}

/* ===== LOADING STATE ===== */

.button[data-loading="true"] {
  position: relative;
  color: transparent;
  pointer-events: none;
}

.button[data-loading="true"]::after {
  content: "";
  position: absolute;
  width: 16px;
  height: 16px;
  top: 50%;
  left: 50%;
  margin-left: -8px;
  margin-top: -8px;
  border: 2px solid currentColor;
  border-radius: 50%;
  border-top-color: transparent;
  animation: button-loading-spin 0.6s linear infinite;
}

@keyframes button-loading-spin {
  to {
    transform: rotate(360deg);
  }
}

/* Цвет спиннера для primary кнопки */
.button--primary[data-loading="true"]::after {
  border-color: white;
  border-top-color: transparent;
}

/* ===== КНОПКИ С ИКОНКАМИ ===== */

.button--icon-left {
  flex-direction: row;
}

.button--icon-right {
  flex-direction: row-reverse;
}

/* Иконка в кнопке */
.button__icon {
  display: inline-flex;
  width: 1.25em;
  height: 1.25em;
  flex-shrink: 0;
}

/* Только иконка (квадратная кнопка) */
.button--icon-only {
  padding: var(--space-3);
  min-width: 44px;
  aspect-ratio: 1;
}

.button--icon-only.button--small {
  min-width: 36px;
  padding: var(--space-2);
}

.button--icon-only.button--large {
  min-width: 56px;
  padding: var(--space-4);
}

/* ===== АДАПТИВНОСТЬ ===== */

@media (max-width: 640px) {
  /* На mobile кнопки могут быть чуть меньше */
  .button {
    font-size: var(--font-size-sm);
    padding: var(--space-3) var(--space-5);
  }
  
  .button--large {
    font-size: var(--font-size-base);
  }
  
  /* Вертикальные группы на mobile */
  .button-group--mobile-vertical {
    flex-direction: column;
    align-items: stretch;
  }
  
  .button-group--mobile-vertical .button {
    width: 100%;
  }
}

/* ===== ACCESSIBILITY ===== */

/* Отключение анимаций для prefers-reduced-motion */
@media (prefers-reduced-motion: reduce) {
  .button {
    transition: none;
  }
  
  .button:hover,
  .button:active {
    transform: none;
  }
  
  .button[data-loading="true"]::after {
    animation: none;
    border-top-color: currentColor;
    opacity: 0.5;
  }
}

/* ===== УТИЛИТЫ ===== */

/* Кнопка как ссылка (для навигации) */
a.button {
  text-decoration: none;
}

/* Внешние ссылки */
a.button[target="_blank"]:not(.button--no-icon)::after {
  display: none;
}

/* Print styles */
@media print {
  .button {
    border: 1px solid var(--color-neutral-400);
    box-shadow: none;
    transform: none;
  }
  
  .button--primary {
    background-color: var(--color-neutral-200);
    color: var(--color-neutral-900);
  }
}
