/* button */
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  min-height: var(--touch-min);
  padding: 0 var(--space-4);
  border-radius: var(--radius-md);
  font-weight: var(--font-weight-medium);
  font-size: var(--font-size-base);
  transition: background var(--transition-fast),
              box-shadow var(--transition-fast),
              transform var(--transition-fast);
  white-space: nowrap;
  user-select: none;
}
.button:active { transform: translateY(1px); }
.button[disabled],
.button[aria-disabled="true"] { opacity: 0.5; cursor: not-allowed; pointer-events: none; }

.button--primary { background: var(--profil-aktiv-strong); color: var(--text-on-color); box-shadow: var(--shadow-sm); }
.button--primary:hover { background: var(--profil-aktiv); }

.button--ghost { background: transparent; color: var(--text-primary); border: 1px solid var(--border-strong); }
.button--ghost:hover { background: var(--bg-tertiary); }

.button--danger { background: var(--negative); color: var(--text-on-color); }

.button--icon {
  width: var(--touch-min);
  min-width: var(--touch-min);
  padding: 0;
  border-radius: var(--radius-full);
  background: var(--bg-tertiary);
  color: var(--text-primary);
}
.button--icon:hover { background: var(--border); }

.button--block { width: 100%; }
.button--sm { min-height: 36px; padding: 0 var(--space-3); font-size: var(--font-size-sm); }
.button--lg { min-height: var(--touch-comfort); padding: 0 var(--space-5); font-size: var(--font-size-lg); }
