
/* Button Highlight Fix */
sl-button, sl-button::part(base), sl-icon-button, sl-icon-button::part(base) {
  -webkit-tap-highlight-color: transparent;
}

/* Input-Placeholder etwas dezenter */
sl-input::part(input)::placeholder {
  opacity:0.5;
}
sl-textarea::part(textarea)::placeholder {
  opacity:0.5;
}

/* Button Hover Fix */
@media (pointer: coarse) {

  /* Hängenden Hover auf Touch neutralisieren: zurück auf Grundzustand */

  sl-button[variant="default"]::part(base):hover:not(:active) {
    background: var(--sl-color-neutral-0);
    border-color: var(--sl-input-border-color);
    color: var(--sl-color-neutral-700);
  }

  sl-button[variant="primary"]::part(base):hover:not(:active) {
    background: var(--sl-color-primary-600);
    border-color: var(--sl-color-primary-600);
    color: var(--sl-color-neutral-0);
  }

  sl-button[variant="success"]::part(base):hover:not(:active) {
    background: var(--sl-color-success-600);
    border-color: var(--sl-color-success-600);
    color: var(--sl-color-neutral-0);
  }

  sl-button[variant="neutral"]::part(base):hover:not(:active) {
    background: var(--sl-color-neutral-600);
    border-color: var(--sl-color-neutral-600);
    color: var(--sl-color-neutral-0);
  }

  sl-button[variant="warning"]::part(base):hover:not(:active) {
    background: var(--sl-color-warning-600);
    border-color: var(--sl-color-warning-600);
    color: var(--sl-color-neutral-0);
  }

  sl-button[variant="danger"]::part(base):hover:not(:active) {
    background: var(--sl-color-danger-600);
    border-color: var(--sl-color-danger-600);
    color: var(--sl-color-neutral-0);
  }

  /* Beim Tap die jeweilige Shoelace-Hoverfarbe zeigen */

  sl-button[variant="default"]::part(base):active {
    transform: scale(0.98);
    background: var(--sl-color-primary-50);
    border-color: var(--sl-color-primary-300);
    color: var(--sl-color-primary-700);
  }

  sl-button[variant="primary"]::part(base):active {
    transform: scale(0.98);
    background: var(--sl-color-primary-500);
    border-color: var(--sl-color-primary-500);
    color: var(--sl-color-neutral-0);
  }

  sl-button[variant="success"]::part(base):active {
    transform: scale(0.98);
    background: var(--sl-color-success-500);
    border-color: var(--sl-color-success-500);
    color: var(--sl-color-neutral-0);
  }

  sl-button[variant="neutral"]::part(base):active {
    transform: scale(0.98);
    background: var(--sl-color-neutral-500);
    border-color: var(--sl-color-neutral-500);
    color: var(--sl-color-neutral-0);
  }

  sl-button[variant="warning"]::part(base):active {
    transform: scale(0.98);
    background: var(--sl-color-warning-500);
    border-color: var(--sl-color-warning-500);
    color: var(--sl-color-neutral-0);
  }

  sl-button[variant="danger"]::part(base):active {
    transform: scale(0.98);
    background: var(--sl-color-danger-500);
    border-color: var(--sl-color-danger-500);
    color: var(--sl-color-neutral-0);
  }

  /* Minimalfeedback durch Scale */

  sl-button::part(base):active {
    transform: scale(0.98);
  }
}
