/* ===== Übungsfinder – fester Look, scoping ===== */
.uf-scope {
  /* Brand kommt inline als CSS-Var; Fallback s.u. */
  --uf-brand: var(--uf-brand, #0d6efd);
}

/* Überschrift + Unterzeile exakt setzen */
.uf-scope h2 {
  margin: 0 0 .25rem 0 !important;
  font-weight: 700 !important;
  font-size: 2rem !important; /* wirkt wie im Screenshot */
  line-height: 1.2 !important;
}
.uf-scope p.text-muted {
  margin: 0 0 1rem 0 !important;
  color: #6c757d !important;
}

/* Akkordeon-Kopf in Brand-Farbe (geschlossen + offen) – volle Breite, weißer Text */
.uf-scope .uf-accordion-brand .accordion-button {
  background-color: var(--uf-brand, #0d6efd) !important;
  color: #fff !important;
  border-radius: .5rem !important;
}
.uf-scope .uf-accordion-brand .accordion-button.collapsed {
  background-color: var(--uf-brand, #0d6efd) !important;
  color: #fff !important;
}
.uf-scope .uf-accordion-brand .accordion-button::after {
  filter: invert(1) brightness(2);
}

/* Formkarten wie im Screenshot: Card-Rahmen, großzügiges Padding */
.uf-scope .border.rounded.p-3 {
  border-color: #e9ecef !important;
  border-radius: .5rem !important;
  padding: 1rem !important;
}

/* Selects wie Bootstrap, nicht vom Theme verfärben lassen */
.uf-scope .form-select {
  background-color: #fff !important;
  color: #212529 !important;
  border-color: #dee2e6 !important;
  border-radius: .5rem !important;
}


/* Partner-Badge (Gold) – bereits vorhanden */
.uf-badge-partner {
  margin-left: .5rem;
  background-color: #FFD700 !important;
  color: #000 !important;
  border: 1px solid #d4af37;
}

/* Brand-Farbe für Buttons */
.uf-btn-brand {
  background-color: var(--uf-brand, #0d6efd) !important;
  border-color: var(--uf-brand, #0d6efd) !important;
  color: #fff !important;
  box-shadow: none !important;
}
.uf-btn-brand:hover,
.uf-btn-brand:focus {
  filter: brightness(0.9);
  color: #fff !important;
}
.uf-btn-brand:focus-visible {
  outline: 2px solid #0b5ed7 !important; /* A11y Fokus sichtbar */
  outline-offset: 2px;
}

/* Brand-Farbe für die Partner-Zeile (Accordion-Header) */
.uf-accordion-brand .accordion-button {
  background-color: var(--uf-brand, #0d6efd);
  color: #fff;
}
.uf-accordion-brand .accordion-button.collapsed {
  /* auch im geschlossenen Zustand eingefärbt */
  background-color: var(--uf-brand, #0d6efd);
  color: #fff;
}
.uf-accordion-brand .accordion-button::after {
  filter: invert(1) brightness(2);
}

/* Ergebnisliste */
.uf-item:last-child { border-bottom: 0; }
.uf-item img {
  width: 72px;
  height: 72px;
  object-fit: cover;
  border-radius: .25rem;
  background-color: #f8f9fa;
}
.uf-title {
  font-weight: 700;
  font-size: 1.1rem;
  margin: 0 0 .25rem 0;
}
.uf-desc {
  font-size: .9rem;
  color: #555;
  margin-bottom: .5rem;
}

/* ===== Optional: Hardening gegen sehr aggressive Themes ===== */
.uf-scope.uf-hard .form-select,
.uf-scope.uf-hard .btn,
.uf-scope.uf-hard .accordion-button,
.uf-scope.uf-hard .uf-title,
.uf-scope.uf-hard .uf-desc {
  font-family: inherit !important;
  letter-spacing: normal !important;
  text-transform: none !important;
}


/* --- Fix: Text & Button neben dem Bild ----------------------------------- */
.uf-scope .uf-item{
  display: flex !important;         /* erzwingt Flex, falls Theme überschreibt */
  align-items: flex-start !important;
  gap: 1rem !important;
  margin: 0 0 2rem 0;
}

.uf-scope .uf-thumb{
  flex: 0 0 72px !important;        /* feste Spalte für das Vorschaubild */
  max-width: 72px !important;
}

.uf-scope .uf-body{
  flex: 1 1 auto !important;        /* Restbreite für Text/Buttons */
  min-width: 0;                      /* verhindert unnötige Umbrüche */
}

.uf-scope .uf-btn-brand{
  display: inline-block;             /* sicher nicht full-width */
}

/* Falls ein Theme floatet: Floats neutralisieren */
.uf-scope .uf-thumb, .uf-scope .uf-body{
  float: none !important;
}

/* Nur zur Sicherheit: keine Listeneffekte durch .list-unstyled */
.uf-scope .list-unstyled{
  padding-left: 0 !important;
}

/* Banner unter der Liste (Kauf-Hinweis) */
.uf-scope .uf-banner {
  background-color: var(--uf-brand, #0d6efd) !important;
  color: #fff !important;
  border: none !important;           /* kein grauer Rand mehr */
  border-radius: .5rem;
}
.uf-scope .uf-banner strong {
  font-weight: 700;
  font-size: 1.5rem;;
}

.uf-scope .uf-banner .uf-banner-text {
  color: #fff !important;
}

.uf-scope .uf-banner .uf-btn-brand {
  /* Button bleibt in Brand-Farbe – wirkt hier wie „solid“ auf gleichfarbigem Grund */
  background-color: #fff !important;     /* invertieren für bessere Lesbarkeit */
  border-color: #fff !important;
  color: #000 !important;
}
.uf-scope .uf-banner .uf-btn-brand:hover,
.uf-scope .uf-banner .uf-btn-brand:focus {
  filter: none;
  background-color: #f8f9fa !important;
  border-color: #f8f9fa !important;
  color: #000 !important;
}

.uf-scope .uf-intro p { margin-bottom: .75rem; }