/* Glassmorphism компоненты */

/* Базовое стекло */
.glass {
  background: var(--glass-bg);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--glass-border);
  box-shadow: var(--glass-shadow), var(--glass-inner-glow);
  border-radius: var(--radius-lg);
}

/* Fallback для браузеров без backdrop-filter */
@supports not (backdrop-filter: blur(1px)) {
  .glass {
    background: rgba(235, 240, 250, 0.92);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }
}

/* Кнопка — стеклянная */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 44px;
  padding: 12px 20px;
  border-radius: var(--radius-md);
  font-size: 16px;
  font-weight: 500;
  color: var(--text-primary);
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  box-shadow: var(--glass-shadow), var(--glass-inner-glow);
  transition: background var(--duration-fast) var(--ease-ios),
              box-shadow var(--duration-fast) var(--ease-ios),
              transform var(--duration-fast) var(--ease-ios);
  cursor: pointer;
  user-select: none;
  -webkit-user-select: none;
  white-space: nowrap;
}

.btn:hover {
  background: var(--glass-bg-hover);
  box-shadow: var(--glass-shadow-hover), var(--glass-inner-glow);
}

.btn:active {
  background: var(--glass-bg-active);
  transform: scale(0.97);
}

/* Кнопка — акцент (синяя) */
.btn-primary {
  background: rgba(14, 110, 126, 0.85);
  border-color: rgba(14, 110, 126, 0.5);
  color: #fff;
  font-weight: 600;
}

.btn-primary:hover {
  background: rgba(14, 110, 126, 0.95);
}

.btn:focus-visible {
  outline: 3px solid var(--focus-ring);
  outline-offset: 2px;
  box-shadow: 0 0 0 5px rgba(14, 110, 126, 0.2);
}

/* Кнопка — успех (зелёная) */
.btn-success {
  background: rgba(0, 184, 148, 0.8);
  border-color: rgba(0, 184, 148, 0.45);
  color: #fff;
  font-weight: 600;
}

/* Кнопка — опасность (красная) */
.btn-danger {
  background: rgba(214, 48, 49, 0.8);
  border-color: rgba(214, 48, 49, 0.45);
  color: #fff;
}

/* Кнопка — золотая (Pro) */
.btn-pro {
  background: linear-gradient(135deg, rgba(217, 106, 138, 0.8), rgba(91, 63, 138, 0.8));
  border-color: rgba(91, 63, 138, 0.4);
  color: #fff;
  font-weight: 600;
}

.btn-pro:hover,
.btn-pro:focus-visible,
.btn-pro[disabled],
.btn-pro.is-loading {
  background: linear-gradient(135deg, rgba(217, 106, 138, 0.88), rgba(91, 63, 138, 0.88));
  border-color: rgba(91, 63, 138, 0.48);
  color: #fff;
}

.btn-pro:active {
  background: linear-gradient(135deg, rgba(195, 86, 124, 0.92), rgba(74, 49, 118, 0.92));
  border-color: rgba(91, 63, 138, 0.55);
  color: #fff;
  transform: scale(0.97);
}

.btn-pro .spinner {
  color: #fff;
}

/* Кнопка — маленькая (всё ещё ≥44px для touch) */
.btn-sm {
  min-height: 44px;
  padding: 10px 16px;
  font-size: 14px;
  border-radius: var(--radius-sm);
}

/* Кнопка — большая */
.btn-lg {
  padding: 16px 28px;
  font-size: 17px;
  border-radius: var(--radius-lg);
}

/* Кнопка — полная ширина */
.btn-block {
  width: 100%;
}

/* Иконка-кнопка */
.icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: var(--radius-sm);
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  color: var(--text-primary);
  transition: background var(--duration-fast) var(--ease-ios),
              transform var(--duration-fast) var(--ease-ios);
  cursor: pointer;
}

.icon-btn:hover {
  background: var(--glass-bg-hover);
}

.icon-btn:active {
  transform: scale(0.9);
}

.icon-btn:focus-visible {
  outline: 3px solid var(--focus-ring);
  outline-offset: 2px;
  box-shadow: 0 0 0 5px rgba(14, 110, 126, 0.2);
}

/* Состояние загрузки кнопки */
.btn[disabled],
.btn.is-loading {
  opacity: 0.5;
  pointer-events: none;
  cursor: not-allowed;
}

.btn.is-loading {
  position: relative;
  color: transparent;
}

.btn.is-loading::after {
  content: '';
  position: absolute;
  width: 18px;
  height: 18px;
  border: 2px solid currentColor;
  border-top-color: transparent;
  opacity: 0.9;
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
  color: var(--text-primary);
}

/* Поле ввода */
.input {
  display: block;
  width: 100%;
  padding: 12px 16px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-size: 16px;
  font-family: inherit;
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  outline: none;
  transition: border-color var(--duration-fast) var(--ease-ios),
              box-shadow var(--duration-fast) var(--ease-ios);
  -webkit-appearance: none;
}

.input::placeholder {
  color: var(--text-placeholder);
  opacity: 1;
}

.input:focus {
  border-color: var(--focus-ring);
  box-shadow: 0 0 0 3px rgba(14, 110, 126, 0.2);
}

.input.error {
  border-color: rgba(214, 48, 49, 0.7);
  box-shadow: 0 0 0 3px rgba(214, 48, 49, 0.15);
}

/* Разделитель */
.divider {
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
  color: var(--text-muted);
  font-size: 13px;
}

.divider::before,
.divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--glass-border);
}

/* Бейдж */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 600;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
}

.badge-pro {
  background: linear-gradient(135deg, rgba(217, 106, 138, 0.5), rgba(91, 63, 138, 0.5));
  border-color: rgba(91, 63, 138, 0.3);
  color: #fff;
}

.badge-success {
  background: rgba(0, 184, 148, 0.2);
  border-color: rgba(0, 184, 148, 0.35);
  color: var(--text-success);
}

/* Лейбл */
.label {
  display: block;
  font-size: 13px;
  font-weight: 500;
  color: var(--text-secondary);
  margin-bottom: 6px;
}

/* Спиннер загрузки */
.spinner {
  width: 20px;
  height: 20px;
  border: 2px solid currentColor;
  border-top-color: transparent;
  opacity: 0.85;
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
  color: var(--text-primary);
}
