/**
 * WDSB Wetter-Panel – Light/Dark automatisch (System + Darkmode-Widget).
 */

.wdsb-weather-panel[hidden],
.wdsb-weather-panel__card--loading[hidden] {
  display: none !important;
}

/* —— Helle Kachel (theme-light + theme-auto im Light-Mode) —— */
.wdsb-weather-panel--theme-light,
.wdsb-weather-panel--theme-auto {
  --wdsb-weather-panel-bg: color-mix(in srgb, var(--st-dunkel-light, #172033) 6%, var(--st-hell-light, #f4f6f8));
  --wdsb-weather-panel-border: color-mix(in srgb, var(--st-dunkel-light, #172033) 14%, var(--st-hell-light, #f4f6f8));
  --wdsb-weather-panel-text: #000;
  --wdsb-weather-panel-muted: rgb(0 0 0 / 65%);
  --wdsb-weather-panel-icon-fa: #000;
}

/* —— Dunkle Kachel (theme-dark / SaarRegional) —— */
.wdsb-weather-panel--theme-dark {
  --wdsb-weather-panel-bg: color-mix(in srgb, var(--st-dunkel-light, #172033) 72%, #3d5278);
  --wdsb-weather-panel-border: color-mix(in srgb, var(--st-hell-light, #f4f6f8) 18%, transparent);
  --wdsb-weather-panel-text: #fff;
  --wdsb-weather-panel-muted: color-mix(in srgb, #fff 72%, transparent);
  --wdsb-weather-panel-icon-fa: #fff;
}

@media (prefers-color-scheme: dark) {
  .wdsb-weather-panel--theme-auto {
    --wdsb-weather-panel-bg: color-mix(in srgb, var(--st-dunkel-light, #172033) 72%, #3d5278);
    --wdsb-weather-panel-border: color-mix(in srgb, var(--st-hell-light, #f4f6f8) 18%, transparent);
    --wdsb-weather-panel-text: #fff;
    --wdsb-weather-panel-muted: color-mix(in srgb, #fff 72%, transparent);
    --wdsb-weather-panel-icon-fa: #fff;
  }
}

body.darkmode--activated .wdsb-weather-panel--theme-auto {
  --wdsb-weather-panel-bg: color-mix(in srgb, var(--st-dunkel-light, #172033) 72%, #3d5278);
  --wdsb-weather-panel-border: color-mix(in srgb, var(--st-hell-light, #f4f6f8) 18%, transparent);
  --wdsb-weather-panel-text: #fff;
  --wdsb-weather-panel-muted: color-mix(in srgb, #fff 72%, transparent);
  --wdsb-weather-panel-icon-fa: #fff;
}

/* Geolocation: Ladezeile nur, wenn noch keine Karte da ist */
.wdsb-weather-panel--geolocate:has(.wdsb-weather-panel__geolocate-target .wdsb-weather-panel__card) .wdsb-weather-panel__card--loading {
  display: none !important;
}

.wdsb-weather-panel--geolocate .wdsb-weather-panel__geolocate-target > .wdsb-weather-panel--embedded {
  margin: 0;
}

.wdsb-weather-panel {
  box-sizing: border-box;
  width: 100%;
  color: var(--wdsb-weather-panel-text);
}

.wdsb-weather-panel__heading {
  margin: 0 0 10px;
  font-family: var(--font-heading, 'Manrope', sans-serif);
  font-size: clamp(1.125rem, 0.9rem + 0.45vw, 1.5rem);
  font-weight: 700;
  line-height: 1.25;
  color: var(--wdsb-weather-panel-text);
}

.wdsb-weather-panel__card {
  display: flex;
  flex-wrap: nowrap;
  align-items: stretch;
  gap: 0;
  min-height: 7.5rem;
  padding: 1rem 2rem;
  border: 1px solid var(--wdsb-weather-panel-border);
  border-radius: 10px;
  background: var(--wdsb-weather-panel-bg);
  box-sizing: border-box;
  color: var(--wdsb-weather-panel-text);
}

.wdsb-weather-panel--geolocate > .wdsb-weather-panel__card--loading {
  min-height: 3.5rem;
  margin-bottom: 0;
}

.wdsb-weather-panel__primary {
  display: flex;
  flex: 1 1 42%;
  align-items: center;
  gap: 1rem;
  min-width: 0;
  padding-right: 1rem;
}

.wdsb-weather-panel__icon {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: auto;
  height: auto;
  min-width: 2.5rem;
  min-height: 2.5rem;
  padding: 0;
  border-radius: 0;
  background: none !important;
  box-shadow: none !important;
}

.wdsb-weather-panel__icon-fa {
  font-size: 2rem;
  color: var(--wdsb-weather-panel-icon-fa, var(--wdsb-weather-panel-text));
  line-height: 1;
}

.wdsb-weather-panel__metric-icon {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  align-self: center;
  width: 1.1rem;
  height: 1.1rem;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: none !important;
  box-shadow: none !important;
  font-size: 0.95rem;
  line-height: 1;
  color: var(--wdsb-weather-panel-muted);
}

.wdsb-weather-panel__metric-icon::before,
.wdsb-weather-panel__metric-icon::after {
  line-height: 1;
  background: none !important;
  box-shadow: none !important;
}

.wdsb-weather-panel__temperature,
.wdsb-weather-panel__condition {
  display: flex;
  align-items: center;
  gap: 0.45rem;
}

.wdsb-weather-panel__temperature-value,
.wdsb-weather-panel__temperature-unit,
.wdsb-weather-panel__condition-text {
  line-height: 1;
}

.wdsb-weather-panel__stat-label {
  flex: 1;
  min-width: 0;
  line-height: 1.2;
}

.wdsb-weather-panel__summary {
  min-width: 0;
  color: var(--wdsb-weather-panel-text);
}

/* Startseite: Heute + 6 Tage Vorhersage im Primary-Bereich */
.wdsb-weather-panel__card:has(.wdsb-weather-panel__primary--forecast) {
  flex-direction: column;
  align-items: stretch;
  min-height: 0;
  padding-block: clamp(0.65rem, 0.5rem + 0.35vw, 1rem);
  padding-inline: clamp(1rem, 0.75rem + 1.25vw, 2rem);
  box-sizing: border-box;
}

.wdsb-weather-panel__primary--forecast {
  display: flex;
  flex-direction: column;
  flex: 0 0 auto;
  width: 100%;
  padding: 0;
  margin: 0;
  gap: 0;
}

/* Forecast-Scroller (wie st-menubar-scroller) */
.wdsb-weather-forecast-scroller {
  --wdsb-weather-forecast-scroller-mask-both: linear-gradient(
    to right,
    transparent 1.25rem,
    #000 3.5rem calc(100% - 3.5rem),
    transparent calc(100% - 1.25rem)
  );
  --wdsb-weather-forecast-scroller-mask-next: linear-gradient(
    to right,
    #000 calc(100% - 3.5rem),
    transparent calc(100% - 1.25rem)
  );
  --wdsb-weather-forecast-scroller-mask-previous: linear-gradient(
    to right,
    transparent 1.25rem,
    #000 3.5rem
  );
  display: grid;
  grid-template-columns: auto 1fr auto;
  grid-template-areas: "prev . next";
  align-items: center;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  position: relative;
  box-sizing: border-box;
}

.wdsb-weather-forecast-scroller__clip {
  grid-column: 1 / -1;
  grid-row: 1;
  width: 100%;
  min-width: 0;
  overflow: hidden;
  -webkit-mask-image: var(--wdsb-weather-forecast-scroller-mask, none);
  mask-image: var(--wdsb-weather-forecast-scroller-mask, none);
}

.wdsb-weather-forecast-scroller__track {
  display: flex;
  justify-content: center;
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
}

.wdsb-weather-panel__forecast {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: stretch;
  gap: 0.75rem;
  margin: 0;
  padding: 0;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.wdsb-weather-panel__forecast::-webkit-scrollbar {
  display: none;
  width: 0;
  height: 0;
}

.wdsb-weather-forecast-scroller:not(.wdsb-weather-forecast-scroller--scrollable) {
  grid-template-columns: minmax(0, 1fr);
}

.wdsb-weather-forecast-scroller:not(.wdsb-weather-forecast-scroller--scrollable) .wdsb-weather-forecast-scroller__btn {
  display: none;
}

.wdsb-weather-forecast-scroller:not(.wdsb-weather-forecast-scroller--scrollable) .wdsb-weather-forecast-scroller__track {
  display: flex;
  justify-content: center;
  width: 100%;
}

.wdsb-weather-forecast-scroller:not(.wdsb-weather-forecast-scroller--scrollable) .wdsb-weather-panel__forecast {
  justify-content: center;
  width: max-content;
  max-width: 100%;
  overflow: visible;
}

.wdsb-weather-forecast-scroller.wdsb-weather-forecast-scroller--scrollable .wdsb-weather-forecast-scroller__track {
  display: block;
}

.wdsb-weather-forecast-scroller.wdsb-weather-forecast-scroller--scrollable .wdsb-weather-panel__forecast {
  justify-content: flex-start;
  width: 100%;
  min-width: 0;
  overflow-x: auto !important;
  overflow-y: visible !important;
  -webkit-overflow-scrolling: touch;
  scroll-behavior: smooth;
}

.wdsb-weather-forecast-scroller__btn {
  align-items: center;
  align-self: center;
  background: transparent;
  border: 0;
  border-radius: 0.25rem;
  color: var(--wdsb-weather-panel-text);
  cursor: pointer;
  display: inline-flex;
  flex: 0 0 auto;
  font-size: 1rem;
  height: auto;
  max-height: none;
  justify-content: center;
  line-height: 1;
  padding: 0;
  width: 2.5rem;
  z-index: 2;
}

.wdsb-weather-forecast-scroller__btn::before,
.wdsb-weather-forecast-scroller__btn::after {
  content: none !important;
  display: none !important;
}

.wdsb-weather-forecast-scroller__btn .wdsb-weather-forecast-scroller__icon,
.wdsb-weather-forecast-scroller__btn i {
  display: block;
  font-family: var(--fa-family, var(--fa-style-family, 'Font Awesome 7 Pro')) !important;
  font-size: 1.25rem;
  font-style: normal;
  font-weight: var(--fa-style, 900);
  line-height: 1;
  -webkit-font-smoothing: antialiased;
}

.wdsb-weather-forecast-scroller__btn .wdsb-weather-forecast-scroller__icon::after,
.wdsb-weather-forecast-scroller__btn i::after {
  content: none !important;
  display: none !important;
}

.wdsb-weather-forecast-scroller__btn:hover,
.wdsb-weather-forecast-scroller__btn:focus-visible {
  background: color-mix(in srgb, var(--wdsb-weather-panel-text) 12%, transparent);
  outline: none;
}

.wdsb-weather-forecast-scroller__btn.is-hidden {
  display: none;
  pointer-events: none;
}

.wdsb-weather-forecast-scroller__btn--prev {
  grid-area: prev;
  grid-column: 1;
  grid-row: 1;
}

.wdsb-weather-forecast-scroller__btn--next {
  grid-area: next;
  grid-column: 3;
  grid-row: 1;
}

.wdsb-weather-panel__forecast-day {
  display: flex;
  flex: 0 0 auto;
  flex-shrink: 0;
  flex-direction: row;
  align-items: stretch;
  gap: 0.85rem;
  min-width: 11.5rem;
  padding: 0 0.85rem 0 0;
  box-sizing: border-box;
}

.wdsb-weather-panel__forecast-day:not(:last-child) {
  border-right: 1px solid var(--wdsb-weather-panel-border);
  padding-right: 0.85rem;
}

.wdsb-weather-panel__forecast-day-main {
  display: flex;
  flex: 0 0 auto;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 0.45rem;
  min-width: 3.5rem;
}

.wdsb-weather-panel__forecast-day-label {
  display: block;
  order: 1;
  margin: 0;
  font-family: var(--font-heading, 'Manrope', sans-serif);
  font-size: clamp(0.95rem, 0.8rem + 0.3vw, 1.2rem);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  white-space: nowrap;
  color: var(--wdsb-weather-panel-text);
}

.wdsb-weather-panel__forecast-day--today .wdsb-weather-panel__forecast-day-label {
  font-size: clamp(1.1rem, 0.95rem + 0.4vw, 1.45rem);
  letter-spacing: 0.02em;
  text-transform: none;
}

.wdsb-weather-panel__forecast-day-icon-wrap {
  position: relative;
  display: block;
  order: 2;
  flex-shrink: 0;
  line-height: 1;
  overflow: visible;
}

.wdsb-weather-panel__forecast-day:first-child,
.wdsb-weather-panel__forecast-day:first-child .wdsb-weather-panel__forecast-day-main {
  overflow: visible;
}

.wdsb-weather-panel__forecast-day-icon {
  display: block;
  font-size: 2rem;
  line-height: 1;
  color: var(--wdsb-weather-panel-icon-fa, var(--wdsb-weather-panel-text));
}

.wdsb-weather-panel__forecast-day-temps {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  justify-content: center;
  gap: 0;
  min-width: 0;
}

.wdsb-weather-panel__forecast-day-temp {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.2rem;
  padding: 0.2rem 0;
}

.wdsb-weather-panel__forecast-day-temp--min {
  padding-top: 0;
}

.wdsb-weather-panel__forecast-day-temp--max {
  padding-bottom: 0;
  border-top: 1px solid var(--wdsb-weather-panel-border);
}

.wdsb-weather-panel__forecast-day-temp-head {
  display: flex;
  align-items: center;
  gap: 0.35rem;
}

.wdsb-weather-panel__forecast-day-temp-icon {
  flex-shrink: 0;
  font-size: 0.85rem;
  line-height: 1;
  color: var(--wdsb-weather-panel-muted);
}

.wdsb-weather-panel__forecast-day-temp-label {
  font-size: 0.58rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  line-height: 1.2;
  text-transform: uppercase;
  color: var(--wdsb-weather-panel-muted);
}

.wdsb-weather-panel__forecast-day-temp-value {
  font-size: 0.95rem;
  font-weight: 600;
  line-height: 1.2;
  color: var(--wdsb-weather-panel-text);
  white-space: nowrap;
}

.wdsb-weather-panel__forecast-day--selectable {
  cursor: pointer;
  border-radius: 0.35rem;
  transition: background-color 0.15s ease, box-shadow 0.15s ease;
}

.wdsb-weather-panel__forecast-day--selectable:hover,
.wdsb-weather-panel__forecast-day--selectable:focus-visible {
  background: color-mix(in srgb, var(--wdsb-weather-panel-text) 8%, transparent);
  outline: none;
}

.wdsb-weather-panel__forecast-day--selected {
  background: color-mix(in srgb, var(--wdsb-weather-panel-text) 12%, transparent);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--wdsb-weather-panel-text) 28%, transparent);
}

/* Tages-Detail als Modal (Klick auf Forecast-Kachel) */
.wdsb-weather-forecast-detail {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  box-sizing: border-box;
}

.wdsb-weather-forecast-detail[hidden] {
  display: none !important;
}

body.wdsb-weather-forecast-detail-open {
  overflow: hidden;
}

.wdsb-weather-forecast-detail__backdrop {
  position: absolute;
  inset: 0;
  background: rgb(15 24 43 / 72%);
  cursor: pointer;
}

.wdsb-weather-forecast-detail__dialog {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  width: min(56rem, 100%);
  max-height: calc(100vh - 2rem);
  overflow: auto;
  padding: 1.2rem 1.35rem 1rem;
  border: 1px solid var(--wdsb-weather-panel-border);
  border-radius: 10px;
  background: var(--wdsb-weather-panel-bg);
  color: var(--wdsb-weather-panel-text);
  box-shadow: 0 18px 52px rgb(0 0 0 / 38%);
  box-sizing: border-box;
  -webkit-overflow-scrolling: touch;
}

.wdsb-weather-forecast-detail__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 0.85rem;
  padding-bottom: 0.65rem;
  padding-right: 2rem;
  border-bottom: 1px solid var(--wdsb-weather-panel-border);
}

.wdsb-weather-forecast-detail__close-icon {
  position: absolute;
  top: 0.85rem;
  right: 0.85rem;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  padding: 0;
  border: 0;
  border-radius: 0.35rem;
  background: transparent;
  color: var(--wdsb-weather-panel-text);
  font-size: 1.1rem;
  line-height: 1;
  cursor: pointer;
}

.wdsb-weather-forecast-detail__close-icon:hover,
.wdsb-weather-forecast-detail__close-icon:focus-visible {
  background: color-mix(in srgb, var(--wdsb-weather-panel-text) 12%, transparent);
  outline: none;
}

.wdsb-weather-forecast-detail__footer {
  display: flex;
  justify-content: flex-end;
  margin-top: 0.75rem;
  padding-top: 0.5rem;
}

.wdsb-weather-forecast-detail__title {
  margin: 0;
  flex: 1 1 auto;
  min-width: 0;
  font-family: var(--font-heading, 'Manrope', sans-serif);
  font-size: clamp(0.95rem, 0.85rem + 0.25vw, 1.15rem);
  font-weight: 700;
  line-height: 1.3;
  text-align: left;
  color: var(--wdsb-weather-panel-text);
}

.wdsb-weather-forecast-detail__weekday {
  margin: 0;
  flex: 0 0 auto;
  margin-left: auto;
  font-family: var(--font-heading, 'Manrope', sans-serif);
  font-size: clamp(1rem, 0.9rem + 0.3vw, 1.25rem);
  font-weight: 700;
  line-height: 1.2;
  text-align: right;
  color: var(--wdsb-weather-panel-text);
  white-space: nowrap;
}

.wdsb-weather-forecast-detail__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 0 1.25rem;
}

.wdsb-weather-forecast-detail__col--left {
  border-right: 1px solid var(--wdsb-weather-panel-border);
  padding-right: 1.25rem;
}

.wdsb-weather-forecast-detail__item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.2rem;
  padding: 0.4rem 0;
}

.wdsb-weather-forecast-detail__item:not(:last-child) {
  border-bottom: 1px solid color-mix(in srgb, var(--wdsb-weather-panel-border) 65%, transparent);
}

.wdsb-weather-forecast-detail__item-head {
  display: flex;
  align-items: center;
  gap: 0.35rem;
}

.wdsb-weather-forecast-detail__item-icon {
  flex-shrink: 0;
  font-size: 0.85rem;
  line-height: 1;
  color: var(--wdsb-weather-panel-muted);
}

.wdsb-weather-forecast-detail__item-label {
  font-size: 0.58rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  line-height: 1.2;
  text-transform: uppercase;
  color: var(--wdsb-weather-panel-muted);
}

.wdsb-weather-forecast-detail__item-value {
  font-size: 0.95rem;
  font-weight: 600;
  line-height: 1.25;
  color: var(--wdsb-weather-panel-text);
}

.wdsb-weather-forecast-detail__close {
  margin: 0;
  padding: 0.35rem 0.65rem;
  border: 1px solid var(--wdsb-weather-panel-border);
  border-radius: 0.35rem;
  background: transparent;
  color: var(--wdsb-weather-panel-text);
  font-size: 0.8rem;
  font-weight: 600;
  cursor: pointer;
}

.wdsb-weather-forecast-detail__close:hover,
.wdsb-weather-forecast-detail__close:focus-visible {
  background: color-mix(in srgb, var(--wdsb-weather-panel-text) 10%, transparent);
  outline: none;
}

@media (max-width: 720px) {
  .wdsb-weather-forecast-detail__grid {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .wdsb-weather-forecast-detail__col--left {
    border-right: 0;
    padding-right: 0;
    border-bottom: 1px solid var(--wdsb-weather-panel-border);
    margin-bottom: 0.35rem;
    padding-bottom: 0.35rem;
  }
}

.wdsb-weather-panel__card:has(.wdsb-weather-panel__primary--forecast) .wdsb-weather-panel__stats {
  flex: 1 1 auto;
  width: 100%;
  padding-left: 0;
  padding-top: 0.25rem;
}

.wdsb-weather-panel__card:has(.wdsb-weather-panel__primary--forecast) .wdsb-weather-panel__divider {
  width: 100%;
  height: 1px;
  margin: 0 0 0.75rem;
}

.wdsb-weather-panel__temperature {
  margin: 0;
  font-size: clamp(1.75rem, 1.35rem + 1vw, 2.35rem);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.02em;
}

.wdsb-weather-panel__temperature-unit {
  font-size: 0.95em;
  font-weight: 500;
}

.wdsb-weather-panel__condition {
  margin: 0.2rem 0 0;
  font-size: 1rem;
  line-height: 1.3;
  text-transform: capitalize;
}

.wdsb-weather-panel__divider {
  flex: 0 0 1px;
  align-self: stretch;
  margin: 0.15rem 0;
  background: var(--wdsb-weather-panel-border);
}

.wdsb-weather-panel__stats {
  display: grid;
  flex: 1 1 58%;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.65rem 1.25rem;
  align-content: center;
  margin: 0;
  padding-left: 1.25rem;
}

.wdsb-weather-panel__stat {
  margin: 0;
}

.wdsb-weather-panel__stat dt {
  margin: 0;
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.68rem;
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.wdsb-weather-panel__stat dd {
  margin: 0.15rem 0 0;
  font-size: 0.95rem;
  font-weight: 600;
  line-height: 1.25;
}

.wdsb-weather-panel--fallback .wdsb-weather-panel__card {
  min-height: auto;
  align-items: center;
}

.wdsb-weather-panel__fallback,
.wdsb-weather-panel__loading {
  margin: 0;
  font-size: 0.9rem;
}

.wdsb-weather-panel--geolocate .wdsb-weather-panel__card--loading {
  display: flex;
  align-items: center;
  justify-content: center;
}

.wdsb-weather-panel__stat--alerts dd {
  font-size: 0.85rem;
  font-weight: 500;
}

/* DWD-Warnungen (Button + Popover) */
.wdsb-weather-panel__card--has-alert {
  overflow: visible;
}

.wdsb-weather-panel__alert-slot {
  position: relative;
  flex: 0 0 auto;
  align-self: center;
  z-index: 4;
}

/* Startseite: Badge oben rechts am Wetter-Icon des ersten Tages */
.wdsb-weather-panel__alert-slot--on-icon {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 6;
  margin: 0;
  pointer-events: auto;
  transform: translate(15%, -15%);
}

.wdsb-weather-panel__alert-slot--on-icon .wdsb-weather-alert__btn {
  width: 1.85rem;
  height: 1.85rem;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.wdsb-weather-panel__alert-slot--on-icon .wdsb-weather-alert__icon {
  font-size: 1.15rem;
}

.wdsb-weather-panel__alert-slot--on-icon .wdsb-weather-alert__popover {
  top: calc(100% + 0.3rem);
  right: 0;
  left: auto;
}

/* Tages-Warnung in der 7-Tage-Vorschau (zeitliche Zuordnung) */
.wdsb-weather-panel__alert-slot--day {
  top: 0;
  right: 0;
  transform: translate(18%, -22%);
}

.wdsb-weather-panel__forecast-day-icon-wrap:has(.wdsb-weather-panel__alert-slot--summary) .wdsb-weather-panel__alert-slot--day {
  top: 0;
  left: 0;
  right: auto;
  transform: translate(-18%, -22%);
}

.wdsb-weather-day-alert__btn {
  width: 1.45rem;
  height: 1.45rem;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  cursor: pointer;
  line-height: 1;
}

.wdsb-weather-day-alert__btn:hover,
.wdsb-weather-day-alert__btn:active,
.wdsb-weather-day-alert__btn:focus {
  background: transparent;
  box-shadow: none;
}

.wdsb-weather-day-alert__btn:focus-visible {
  outline: 2px solid var(--wdsb-weather-panel-text);
  outline-offset: 2px;
}

.wdsb-weather-day-alert__icon {
  font-size: 0.95rem;
}

.st-weather-day-alert--level-1 .wdsb-weather-day-alert__icon,
.st-weather-day-alert--level-1.wdsb-weather-day-alert__btn {
  color: #e6c200;
}

.st-weather-day-alert--level-2 .wdsb-weather-day-alert__icon,
.st-weather-day-alert--level-2.wdsb-weather-day-alert__btn {
  color: #e67e22;
}

.st-weather-day-alert--level-3 .wdsb-weather-day-alert__icon,
.st-weather-day-alert--level-3.wdsb-weather-day-alert__btn {
  color: #e74c3c;
}

.st-weather-day-alert--level-4 .wdsb-weather-day-alert__icon,
.st-weather-day-alert--level-4.wdsb-weather-day-alert__btn {
  color: #9b59b6;
}

.st-weather-day-alert--advance .wdsb-weather-day-alert__icon,
.st-weather-day-alert--advance.wdsb-weather-day-alert__btn {
  color: var(--wdsb-weather-panel-muted, #6b7280);
}

.st-weather-day-alert--advance .wdsb-weather-day-alert__icon {
  -webkit-text-stroke: 1px currentColor;
  paint-order: stroke fill;
}

.wdsb-weather-day-alert__heading {
  margin: 0 0 0.65rem;
  font-size: 0.8rem;
  font-weight: 600;
  line-height: 1.35;
  color: var(--wdsb-weather-panel-text);
}

.wdsb-weather-alert__item--advance .wdsb-weather-alert__item-title {
  font-style: italic;
}

.wdsb-weather-alert__item--advance {
  border-left: 2px dashed var(--wdsb-weather-panel-muted, #9ca3af);
  padding-left: 0.5rem;
}

.wdsb-weather-panel__primary .wdsb-weather-panel__alert-slot--lead {
  margin-right: 0.35rem;
}

.wdsb-weather-alert-wrap {
  position: relative;
}

.st-weather-alert,
.wdsb-weather-alert__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  cursor: pointer;
  line-height: 1;
}

.wdsb-weather-alert__btn:hover,
.wdsb-weather-alert__btn:active,
.wdsb-weather-alert__btn:focus {
  background: transparent;
  box-shadow: none;
}

.wdsb-weather-alert__btn:focus-visible {
  outline: 2px solid var(--wdsb-weather-panel-text);
  outline-offset: 2px;
}

.wdsb-weather-alert__icon {
  font-size: 1.35rem;
}

.st-alert-level-1 .wdsb-weather-alert__icon,
.st-alert-level-1.wdsb-weather-alert__btn {
  color: #e6c200;
}

.st-alert-level-2 .wdsb-weather-alert__icon,
.st-alert-level-2.wdsb-weather-alert__btn {
  color: #e67e22;
}

.st-alert-level-3 .wdsb-weather-alert__icon,
.st-alert-level-3.wdsb-weather-alert__btn {
  color: #e74c3c;
}

.st-alert-level-4 .wdsb-weather-alert__icon,
.st-alert-level-4.wdsb-weather-alert__btn {
  color: #9b59b6;
}

.st-weather-alert-popover,
.wdsb-weather-alert__popover {
  position: absolute;
  top: calc(100% + 0.35rem);
  left: 0;
  right: auto;
  z-index: 20;
  width: min(22rem, calc(100vw - 2rem));
  max-height: min(24rem, 70vh);
  overflow: auto;
  margin: 0;
  padding: 0.75rem 0.9rem;
  border: 1px solid var(--wdsb-weather-panel-border);
  border-radius: 0.5rem;
  background: var(--wdsb-weather-panel-bg);
  color: var(--wdsb-weather-panel-text);
  box-shadow: 0 0.35rem 1.25rem rgb(0 0 0 / 18%);
  -webkit-overflow-scrolling: touch;
}

/* Beim Öffnen an body portiert – über Scroller/Headline-Container hinaus */
.wdsb-weather-alert__popover--portal {
  position: fixed;
  z-index: 10050;
  background: var(--wdsb-weather-panel-bg, #f4f6f8);
  color: var(--wdsb-weather-panel-text, #000);
  border: 1px solid var(--wdsb-weather-panel-border, #d0d5dc);
}

body.darkmode--activated .wdsb-weather-alert__popover--portal.wdsb-weather-panel--theme-auto,
.wdsb-weather-alert__popover--portal.wdsb-weather-panel--theme-dark {
  background: var(--wdsb-weather-panel-bg, #3d5278);
  color: var(--wdsb-weather-panel-text, #fff);
  border-color: var(--wdsb-weather-panel-border, rgb(255 255 255 / 18%));
}

.wdsb-weather-alert__popover[hidden] {
  display: none !important;
}

.wdsb-weather-alert-wrap--open .wdsb-weather-alert__btn {
  background: transparent;
  box-shadow: none;
}

.wdsb-weather-alert__overview {
  margin: 0 0 0.65rem;
  font-family: var(--font-heading, 'Manrope', sans-serif);
  font-size: 0.95rem;
  font-weight: 700;
}

.wdsb-weather-alert__list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.wdsb-weather-alert__item + .wdsb-weather-alert__item {
  margin-top: 0.85rem;
  padding-top: 0.85rem;
  border-top: 1px solid color-mix(in srgb, var(--wdsb-weather-panel-border) 70%, transparent);
}

.wdsb-weather-alert__item-title {
  margin: 0 0 0.35rem;
  font-weight: 700;
  font-size: 0.9rem;
  line-height: 1.3;
}

.wdsb-weather-alert__item-region,
.wdsb-weather-alert__item-level,
.wdsb-weather-alert__item-valid,
.wdsb-weather-alert__item-text,
.wdsb-weather-alert__item-source {
  margin: 0.2rem 0 0;
  font-size: 0.82rem;
  line-height: 1.4;
}

.wdsb-weather-alert__meta-label {
  color: var(--wdsb-weather-panel-muted);
}

.wdsb-weather-alert__item-text {
  margin-top: 0.45rem;
}

.wdsb-weather-alert__item-source {
  margin-top: 0.35rem;
  font-size: 0.75rem;
  color: var(--wdsb-weather-panel-muted);
}

/* SaarRegional: Infobox-Zeile nutzt weiterhin dunkle Kachel */
.st-category-weather-infobox-row__weather .wdsb-weather-panel--theme-auto,
.st-category-weather-infobox-row__weather .wdsb-weather-panel--theme-dark,
.st-category-page--saarregional .st-category-weather-infobox-row__weather .wdsb-weather-panel {
  --wdsb-weather-panel-bg: color-mix(in srgb, var(--st-dunkel-light, #172033) 72%, #3d5278);
  --wdsb-weather-panel-border: color-mix(in srgb, var(--st-hell-light, #f4f6f8) 18%, transparent);
  --wdsb-weather-panel-text: #fff;
  --wdsb-weather-panel-muted: rgb(255 255 255 / 72%);
  --wdsb-weather-panel-icon-fa: #fff;
}

/* —— Helle Kachel: feste Farben (inkl. summary) —— */
.wdsb-weather-panel--theme-light .wdsb-weather-panel__summary,
.wdsb-weather-panel--theme-light .wdsb-weather-panel__summary .wdsb-weather-panel__temperature,
.wdsb-weather-panel--theme-light .wdsb-weather-panel__summary .wdsb-weather-panel__temperature-value,
.wdsb-weather-panel--theme-light .wdsb-weather-panel__summary .wdsb-weather-panel__temperature-unit,
.wdsb-weather-panel--theme-light .wdsb-weather-panel__summary .wdsb-weather-panel__condition-text,
.wdsb-weather-panel--theme-light .wdsb-weather-panel__heading,
.wdsb-weather-panel--theme-light .wdsb-weather-panel__stat dd,
#st_body .wdsb-weather-panel--theme-light .wdsb-weather-panel__summary,
#st_body .wdsb-weather-panel--theme-light .wdsb-weather-panel__summary .wdsb-weather-panel__temperature-value,
#st_body .wdsb-weather-panel--theme-light .wdsb-weather-panel__summary .wdsb-weather-panel__temperature-unit {
  color: #000 !important;
}

.wdsb-weather-panel--theme-light .wdsb-weather-panel__summary .wdsb-weather-panel__condition,
.wdsb-weather-panel--theme-light .wdsb-weather-panel__summary .wdsb-weather-panel__metric-icon,
.wdsb-weather-panel--theme-light .wdsb-weather-panel__icon-fa,
.wdsb-weather-panel--theme-light .wdsb-weather-panel__stat dt,
.wdsb-weather-panel--theme-light .wdsb-weather-panel__stat-label,
#st_body .wdsb-weather-panel--theme-light .wdsb-weather-panel__summary .wdsb-weather-panel__condition-text,
#st_body .wdsb-weather-panel--theme-light .wdsb-weather-panel__summary .wdsb-weather-panel__metric-icon {
  color: rgb(0 0 0 / 65%) !important;
}

/* —— Dunkle Kachel: feste Farben (theme-dark + theme-auto im Dark-Mode) —— */
:is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__summary,
:is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__summary .wdsb-weather-panel__temperature,
:is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__summary .wdsb-weather-panel__temperature-value,
:is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__summary .wdsb-weather-panel__temperature-unit,
:is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__summary .wdsb-weather-panel__condition-text,
:is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__heading,
:is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__stat dd,
#st_body :is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__summary,
#st_body :is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__summary .wdsb-weather-panel__temperature-value,
#st_body :is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__summary .wdsb-weather-panel__temperature-unit,
:is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__forecast-day-label,
:is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__forecast-day-temp-value,
:is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__forecast-day-icon,
#st_body :is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__forecast-day-label,
#st_body :is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__forecast-day-temp-value,
#st_body :is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__forecast-day-icon {
  color: #fff !important;
}

:is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__forecast-day-temp-label,
:is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__forecast-day-temp-icon,
#st_body :is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__forecast-day-temp-label,
#st_body :is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__forecast-day-temp-icon {
  color: rgb(255 255 255 / 72%) !important;
}

.wdsb-weather-panel--theme-light .wdsb-weather-panel__forecast-day-label,
.wdsb-weather-panel--theme-light .wdsb-weather-panel__forecast-day-temp-value,
.wdsb-weather-panel--theme-light .wdsb-weather-panel__forecast-day-icon,
#st_body .wdsb-weather-panel--theme-light .wdsb-weather-panel__forecast-day-label,
#st_body .wdsb-weather-panel--theme-light .wdsb-weather-panel__forecast-day-temp-value,
#st_body .wdsb-weather-panel--theme-light .wdsb-weather-panel__forecast-day-icon {
  color: #000 !important;
}

.wdsb-weather-panel--theme-light .wdsb-weather-panel__forecast-day-temp-label,
.wdsb-weather-panel--theme-light .wdsb-weather-panel__forecast-day-temp-icon,
#st_body .wdsb-weather-panel--theme-light .wdsb-weather-panel__forecast-day-temp-label,
#st_body .wdsb-weather-panel--theme-light .wdsb-weather-panel__forecast-day-temp-icon {
  color: rgb(0 0 0 / 65%) !important;
}

.wdsb-weather-panel--theme-dark .wdsb-weather-forecast-scroller__btn,
body.darkmode--activated .wdsb-weather-panel--theme-auto .wdsb-weather-forecast-scroller__btn,
#st_body .wdsb-weather-panel--theme-dark .wdsb-weather-forecast-scroller__btn,
#st_body body.darkmode--activated .wdsb-weather-panel--theme-auto .wdsb-weather-forecast-scroller__btn {
  color: #fff !important;
}

.wdsb-weather-panel--theme-light .wdsb-weather-forecast-scroller__btn,
#st_body .wdsb-weather-panel--theme-light .wdsb-weather-forecast-scroller__btn {
  color: #000 !important;
}

:is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__summary .wdsb-weather-panel__condition,
:is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__summary .wdsb-weather-panel__metric-icon,
:is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__icon-fa,
:is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__stat dt,
:is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__stat-label,
#st_body :is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__summary .wdsb-weather-panel__condition-text,
#st_body :is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__summary .wdsb-weather-panel__metric-icon,
#st_body :is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__icon-fa {
  color: rgb(255 255 255 / 72%) !important;
}

:is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__metric-icon::before,
:is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__metric-icon::after,
:is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__icon-fa::before,
:is(
  .wdsb-weather-panel--theme-dark,
  body.darkmode--activated .wdsb-weather-panel--theme-auto,
  .st-category-weather-infobox-row__weather .wdsb-weather-panel
) .wdsb-weather-panel__icon-fa::after {
  color: inherit !important;
}

@media (prefers-color-scheme: dark) {
  .wdsb-weather-panel--theme-auto .wdsb-weather-panel__summary,
  .wdsb-weather-panel--theme-auto .wdsb-weather-panel__summary .wdsb-weather-panel__temperature,
  .wdsb-weather-panel--theme-auto .wdsb-weather-panel__summary .wdsb-weather-panel__temperature-value,
  .wdsb-weather-panel--theme-auto .wdsb-weather-panel__summary .wdsb-weather-panel__temperature-unit,
  .wdsb-weather-panel--theme-auto .wdsb-weather-panel__summary .wdsb-weather-panel__condition-text,
  #st_body .wdsb-weather-panel--theme-auto .wdsb-weather-panel__summary,
  #st_body .wdsb-weather-panel--theme-auto .wdsb-weather-panel__summary .wdsb-weather-panel__temperature-value,
  #st_body .wdsb-weather-panel--theme-auto .wdsb-weather-panel__summary .wdsb-weather-panel__temperature-unit {
    color: #fff !important;
  }

  .wdsb-weather-panel--theme-auto .wdsb-weather-panel__summary .wdsb-weather-panel__condition,
  .wdsb-weather-panel--theme-auto .wdsb-weather-panel__summary .wdsb-weather-panel__metric-icon,
  .wdsb-weather-panel--theme-auto .wdsb-weather-panel__icon-fa,
  #st_body .wdsb-weather-panel--theme-auto .wdsb-weather-panel__summary .wdsb-weather-panel__condition-text,
  #st_body .wdsb-weather-panel--theme-auto .wdsb-weather-panel__summary .wdsb-weather-panel__metric-icon,
  #st_body .wdsb-weather-panel--theme-auto .wdsb-weather-panel__icon-fa {
    color: rgb(255 255 255 / 72%) !important;
  }
}

@media (max-width: 720px) {
  .wdsb-weather-panel__forecast-day {
    min-width: 10rem;
    gap: 0.65rem;
  }

  .wdsb-weather-panel__card {
    flex-direction: column;
    min-height: 0;
  }

  .wdsb-weather-panel__primary:not(.wdsb-weather-panel__primary--forecast) {
    flex: 1 1 auto;
    padding-right: 0;
    padding-bottom: 0.85rem;
  }

  .wdsb-weather-panel__primary--forecast {
    padding-bottom: 0;
  }

  .wdsb-weather-panel__divider {
    width: 100%;
    height: 1px;
    margin: 0;
  }

  .wdsb-weather-panel__forecast-day-main {
    gap: 0.35rem;
  }

  .wdsb-weather-panel__forecast-day-icon {
    font-size: 1.75rem;
  }

  .wdsb-weather-panel__forecast-day--today .wdsb-weather-panel__forecast-day-label {
    font-size: 1.05rem;
  }

  .wdsb-weather-panel__forecast-day-label {
    font-size: 0.875rem;
    line-height: 1.1;
  }

  .wdsb-weather-panel__forecast-day-temp {
    padding: 0.15rem 0;
  }

  .wdsb-weather-forecast-scroller__btn {
    width: 2rem;
  }

  .wdsb-weather-panel__stats {
    padding-left: 0;
    padding-top: 0.85rem;
  }
}
