/* ==========================================================================
   SML - Buttons
   Файл: /wp-content/themes/sml/src/css/components/buttons.css
   Версия: 1.0.0
   Author: NUVREN (https://nuvren.com)

   Назначение:
   - Единая система кнопок: primary / secondary / ghost;
   - Размеры, состояния (hover/focus/disabled);
   - Важно: ссылки-кнопки не должны ломать цвет из-за :visited/:active.
   ========================================================================== */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 11px 16px;
  min-height: 44px;
  border-radius: 999px;
  border: 1px solid transparent;
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-sm);
  line-height: 1.1;
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
  text-decoration: none;
  -webkit-tap-highlight-color: transparent;
  transition:
    background var(--dur-2) var(--ease),
    border-color var(--dur-2) var(--ease),
    color var(--dur-2) var(--ease),
    box-shadow var(--dur-2) var(--ease),
    opacity var(--dur-2) var(--ease),
    transform var(--dur-2) var(--ease);
}

/* Ссылки-кнопки: запрещаем браузеру "играть" цветами */
a.btn,
a.btn:visited,
a.btn:hover,
a.btn:active,
a.btn:focus,
a.btn:focus-visible {
  color: inherit;
  text-decoration: none;
  -webkit-text-fill-color: currentColor;
}

.btn:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring);
}

.btn > .icon,
.btn svg {
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
}

/* Ряд кнопок */
.btn-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  align-items: center;
}

/* Размеры */
.btn--sm {
  padding: 9px 14px;
  min-height: 40px;
  font-size: var(--font-size-xs);
}

.btn--sm > .icon,
.btn--sm svg {
  width: 16px;
  height: 16px;
}

.btn--md {
  padding: 11px 16px;
  min-height: 44px;
}

.btn--lg {
  padding: 13px 18px;
  min-height: 48px;
  font-size: var(--font-size-md);
}

.btn--lg > .icon,
.btn--lg svg {
  width: 20px;
  height: 20px;
}

/* Поведение */
.btn--block {
  width: 100%;
}

.btn--icon {
  width: 44px;
  padding: 0;
}

.btn--icon.btn--sm {
  width: 40px;
}

.btn--icon.btn--lg {
  width: 48px;
}

/* Primary */
.btn--primary {
  background: var(--color-primary);
  color: var(--color-primary-contrast);
  box-shadow: var(--shadow-xs);
}

a.btn--primary,
a.btn--primary:visited,
a.btn--primary:hover,
a.btn--primary:active,
a.btn--primary:focus,
a.btn--primary:focus-visible {
  color: var(--color-primary-contrast);
  -webkit-text-fill-color: var(--color-primary-contrast);
}

.btn--primary:hover {
  background: var(--color-primary-2);
  transform: translateY(-1px);
}

.btn--primary:active {
  background: var(--color-primary-2);
  color: var(--color-primary-contrast);
  -webkit-text-fill-color: var(--color-primary-contrast);
  transform: translateY(0);
  opacity: 1;
  box-shadow: none;
}

/* Secondary */
.btn--secondary {
  background: var(--color-surface);
  color: var(--color-text);
  border-color: var(--color-border-strong);
  box-shadow: var(--shadow-xs);
}

a.btn--secondary,
a.btn--secondary:visited,
a.btn--secondary:hover,
a.btn--secondary:active,
a.btn--secondary:focus,
a.btn--secondary:focus-visible {
  color: var(--color-text);
  -webkit-text-fill-color: var(--color-text);
}

.btn--secondary:hover {
  border-color: rgba(31, 122, 58, 0.30);
  box-shadow: var(--shadow-sm);
  transform: translateY(-1px);
}

.btn--secondary:active {
  transform: translateY(0);
  opacity: 1;
  box-shadow: none;
}

/* Ghost */
.btn--ghost {
  background: transparent;
  color: var(--color-text);
  border-color: var(--color-border);
  box-shadow: none;
}

a.btn--ghost,
a.btn--ghost:visited,
a.btn--ghost:hover,
a.btn--ghost:active,
a.btn--ghost:focus,
a.btn--ghost:focus-visible {
  color: var(--color-text);
  -webkit-text-fill-color: var(--color-text);
}

.btn--ghost:hover {
  border-color: var(--color-border-strong);
  background: var(--color-surface-2);
  color: var(--color-link);
  transform: translateY(-1px);
}

.btn--ghost:hover,
a.btn--ghost:hover {
  -webkit-text-fill-color: var(--color-link);
}

.btn--ghost:active {
  transform: translateY(0);
  opacity: 1;
}

/* Disabled */
.btn:disabled,
.btn[aria-disabled="true"] {
  cursor: not-allowed;
  opacity: 0.6;
  box-shadow: none !important;
  transform: none !important;
}

a.btn[aria-disabled="true"] {
  pointer-events: none;
}
