/* ============================================================
   zum eibach — Component interaction states
   Hover / active / focus styling for class-hooked primitives.
   Shipped with the design system so consumers get live states.
   ============================================================ */

/* ---- Button ---- */
.eibach-btn:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--eibach-blue) 55%, transparent);
  outline-offset: 2px;
}
.eibach-btn:not(:disabled):active { transform: translateY(1px) scale(0.99); }

.eibach-btn[data-variant="primary"]:not(:disabled):hover { background: var(--color-primary-hover); }
.eibach-btn[data-variant="accent"]:not(:disabled):hover  { background: var(--color-accent-hover); }
.eibach-btn[data-variant="secondary"]:not(:disabled):hover {
  background: var(--warm-700); color: var(--cream);
}
.eibach-btn[data-variant="outline-light"]:not(:disabled):hover {
  background: var(--cream); color: var(--warm-900);
}
.eibach-btn[data-variant="ghost"]:not(:disabled):hover { color: var(--color-primary-hover); }

/* ---- Link with arrow ---- */
.eibach-link { text-decoration: none; }
.eibach-link .eibach-link__arrow {
  transition: transform var(--dur-base) var(--ease-out);
}
.eibach-link:hover .eibach-link__arrow { transform: translateX(4px); }
.eibach-link:hover { color: var(--color-accent); }

/* ---- Cards & tiles ---- */
.eibach-card--interactive {
  transition: box-shadow var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out);
  cursor: pointer;
}
.eibach-card--interactive:hover {
  box-shadow: var(--shadow-card);
  transform: translateY(-3px);
}
.eibach-tile { transition: transform var(--dur-slow) var(--ease-out); }
.eibach-tile:hover .eibach-tile__img { transform: scale(1.05); }

/* ---- Chip ---- */
.eibach-chip { transition: color var(--dur-base) var(--ease-out); cursor: pointer; }
.eibach-chip:hover { color: var(--text-accent); }
.eibach-chip:hover .eibach-chip__well { background: var(--eibach-magenta-tint); color: var(--eibach-magenta); }

/* ---- Inputs ---- */
.eibach-input:focus-visible {
  outline: none;
  border-color: var(--eibach-blue);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--eibach-blue) 22%, transparent);
}

@media (prefers-reduced-motion: reduce) {
  .eibach-btn, .eibach-link__arrow, .eibach-card--interactive, .eibach-tile, .eibach-tile__img, .eibach-chip {
    transition: none !important;
  }
}
