/* ===== WSG CLEAN SITE CSS ===== */

:root {
  --page-max: 1200px;
  --page-gutter: clamp(16px, 3vw, 36px);
  --section-gap: 28px;

  --theme-page-bg: #faf3e1;
  --theme-surface: rgba(255, 255, 255, 0.94);
  --theme-surface-muted: rgba(248, 251, 249, 0.82);
  --theme-border: rgba(202, 223, 214, 0.82);
  --theme-border-strong: rgba(154, 201, 228, 0.55);
  --theme-shadow: 0 14px 34px rgba(34, 82, 70, 0.08);
  --theme-ink: #1b3137;
  --theme-ink-soft: #2f4b52;
  --theme-note: #74858b;
  --theme-link: #164a86;
  --theme-link-strong: #0e3448;
  --theme-chart-bg: #f8fbf9;
  --theme-header-shell: rgba(250, 243, 225, 0.94);
  --theme-header-hover: rgba(255, 255, 255, 0.72);
  --theme-header-active: rgba(246, 210, 110, 0.34);
  --theme-header-status-bg: rgba(250, 243, 225, 0.92);
  --theme-switch-shell: rgba(255, 255, 255, 0.84);
  --theme-switch-track: rgba(243, 247, 251, 0.92);
  color-scheme: light;
}

html.wsg-night,
html.dark-mode,
body.wsg-night,
body.dark-mode {
  --theme-page-bg: #07142b;
  --theme-surface: rgba(10, 24, 48, 0.9);
  --theme-surface-muted: rgba(15, 31, 52, 0.86);
  --theme-border: rgba(119, 160, 221, 0.24);
  --theme-border-strong: rgba(119, 160, 221, 0.34);
  --theme-shadow: 0 18px 40px rgba(2, 10, 24, 0.34);
  --theme-ink: #eef5ff;
  --theme-ink-soft: #d7e6f7;
  --theme-note: #95aec7;
  --theme-link: #d7e9ff;
  --theme-link-strong: #ffffff;
  --theme-chart-bg: #102446;
  --theme-header-shell: rgba(7, 20, 43, 0.82);
  --theme-header-hover: rgba(255, 255, 255, 0.14);
  --theme-header-active: rgba(246, 210, 110, 0.22);
  --theme-header-status-bg: rgba(7, 20, 43, 0.9);
  --theme-switch-shell: rgba(8, 26, 48, 0.88);
  --theme-switch-track: rgba(15, 31, 52, 0.94);
  color-scheme: dark;
}

body.site-page {
  --fs-body: 1rem;
  --fs-h1: 2rem;
  --fs-h2: 1.5rem;
  --fs-h3: 1.1rem;
  --fs-small: 0.8rem;
  --fs-metric-value: clamp(26px, 1.8vw, 34px);
  --fs-metric-unit: clamp(18px, 1.1vw, 20px);
  --fs-ui-card-title: var(--fs-h3);
  --fs-ui-metric-value: var(--fs-metric-value);
  --fs-ui-metric-unit: var(--fs-metric-unit);
  --fs-ui-meta: var(--fs-small);
}

html,
body {
  margin: 0;
  min-height: 100%;
}

*, *::before, *::after {
  box-sizing: border-box;
}

body {
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background: var(--theme-page-bg);
  color: var(--theme-ink);
}

body.site-page,
body.site-page p,
body.site-page li,
body.site-page label,
body.site-page input,
body.site-page button,
body.site-page .lead,
body.site-page .note {
  font-size: var(--fs-body);
  line-height: 1.5;
}

body.site-page { overflow-x: hidden; }

h1, h2, h3, h4, p, ul, ol { margin-top: 0; }

body.site-page h1 { font-size: var(--fs-h1); line-height: 1.12; }

body.site-page h2,
body.site-page .section-head h2,
body.site-page .home-24h-card > .home-24h-title {
  font-size: var(--fs-h2);
  line-height: 1.16;
}

body.site-page h3,
body.site-page .home-mini-chart-title {
  font-size: var(--fs-h3);
  line-height: 1.25;
}

body.site-page .card-title {
  font-size: var(--fs-ui-card-title);
  line-height: 1.25;
}

body.site-page .note,
body.site-page .wx-time {
  font-size: var(--fs-ui-meta);
}

body.site-page .home-mini-chart label,
body.site-page .home-main-chart label,
body.site-page .button,
body.site-page button {
  font-size: var(--fs-small);
}

a { color: var(--theme-link); }
a:hover { color: var(--theme-link-strong); }
img, canvas { display: block; max-width: 100%; }

.site-header,
main,
.footer,
.page-hero {
  width: 100%;
  max-width: none;
}


.nav,
.hero-inner,
.section,
.section.alt > .section-inner,
.footer-inner {
  width: min(var(--page-max), calc(100% - (var(--page-gutter) * 2)));
  max-width: var(--page-max);
  margin-left: auto;
  margin-right: auto;
}

.site-header {
  position: absolute;
  inset: 0 0 auto;
  z-index: 20;
  min-height: 88px;
  pointer-events: auto;
}

.nav {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 16px;
  padding: 18px 0;
}

.brand,
.brand-title,
.brand-subtitle,
.brand-symbol { display: none; }

.nav-links {
  position: fixed;
  top: 2px;
  left: calc(50% - (min(var(--page-max), calc(100vw - (var(--page-gutter) * 2))) / 2));
  z-index: 90;
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  gap: 6px;
  max-width: calc(100vw - (var(--page-gutter) * 2));
  padding: 8px 10px;
  border-radius: 20px;
  background: var(--theme-header-shell);
  border: 1px solid var(--theme-border-strong);
  box-shadow: 0 12px 26px rgba(23, 82, 128, 0.1);
}

.nav-links a {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 8px 10px;
  border-radius: 12px;
  color: var(--theme-link);
  font-size: var(--fs-small);
  font-weight: 800;
  line-height: 1.1;
  text-decoration: none;
  white-space: nowrap;
}

.nav-links a[aria-current="page"] {
  color: var(--theme-link-strong);
  background: var(--theme-header-active);
}

.nav-links a:hover {
  color: var(--theme-link-strong);
  background: var(--theme-header-hover);
}

.nav-dropdown {
  position: relative;
}

.nav-dropdown summary {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 8px 10px;
  border-radius: 12px;
  color: var(--theme-link);
  font-size: var(--fs-small);
  font-weight: 800;
  line-height: 1.1;
  list-style: none;
  cursor: pointer;
  white-space: nowrap;
}

.nav-dropdown summary::-webkit-details-marker {
  display: none;
}

.nav-dropdown summary::after {
  content: "▾";
  margin-left: 6px;
  font-size: 0.72em;
}

.nav-dropdown[open] summary,
.nav-dropdown.is-current summary {
  color: var(--theme-link-strong);
  background: var(--theme-header-active);
}

.nav-dropdown summary:hover {
  color: var(--theme-link-strong);
  background: var(--theme-header-hover);
}

.nav-dropdown-menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  display: grid;
  gap: 4px;
  min-width: 180px;
  padding: 8px;
  border-radius: 16px;
  background: var(--theme-header-shell);
  border: 1px solid var(--theme-border-strong);
  box-shadow: 0 12px 26px rgba(23, 82, 128, 0.14);
  z-index: 40;
}

.nav-dropdown-menu a {
  width: 100%;
}

@media (max-width: 760px) {
  .nav-dropdown {
    width: 100%;
  }

  .nav-dropdown summary {
    width: 100%;
  }

  .nav-dropdown-menu {
    position: static;
    min-width: 0;
    margin-top: 6px;
  }
}


.wsg-header-controls {
  position: absolute;
  right: 0;
  top: calc(50% + 10px);
  display: flex;
  align-items: center;
  gap: 12px;
  margin-left: 0;
  transform: translateY(-50%);
}

.wsg-header-status {
  display: grid;
  gap: 2px;
  min-width: 132px;
  padding: 7px 9px;
  border-radius: 12px;
  background: var(--theme-header-status-bg);
  border: 1px solid var(--theme-border-strong);
  color: var(--theme-link);
  line-height: 1.15;
  white-space: nowrap;
}

.wsg-header-status-main {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: var(--fs-small);
  font-weight: 800;
}

.wsg-header-status-meta {
  padding-left: 19px;
  color: var(--theme-note);
  font-size: 0.65rem;
  font-weight: 700;
}

.wsg-header-status-dot {
  width: 12px;
  height: 12px;
  flex: 0 0 12px;
  align-self: center;
  border-radius: 50%;
  background: #8b9a95;
}

.wsg-header-status.is-ok .wsg-header-status-dot { background: #5f8f68; }
.wsg-header-status.is-late .wsg-header-status-dot { background: #a65f55; }

.wsg-moon-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: 154px;
  padding: 7px 10px;
  border-radius: 999px;
  background: var(--theme-header-status-bg);
  border: 1px solid var(--theme-border-strong);
  color: var(--theme-link);
  line-height: 1.1;
  white-space: nowrap;
}

.wsg-moon-icon {
  font-size: 1.05rem;
  line-height: 1;
}

.wsg-moon-copy {
  display: grid;
  gap: 2px;
}

.wsg-moon-phase {
  font-size: var(--fs-small);
  font-weight: 800;
}

.wsg-moon-next {
  color: var(--theme-note);
  font-size: 0.65rem;
  font-weight: 700;
}

.header-forecast-pin {
  position: absolute;
  left: 10px;
  top: 14px;
  z-index: 26;
  width: auto;
  pointer-events: auto;
  transform: translate(0, 65px);
}

.header-forecast-pin__link {
  display: grid;
  gap: 5px;
  width: fit-content;
  min-width: 0;
  min-height: 152px;
  padding: 10px 10px 11px;
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.26) 0%, rgba(255, 255, 255, 0.14) 100%);
  border: 1px solid rgba(255, 255, 255, 0.36);
  box-shadow: 0 10px 22px rgba(34, 82, 70, 0.08), inset 0 1px 0 rgba(255, 255, 255, 0.22);
  backdrop-filter: blur(12px) saturate(1.08);
  -webkit-backdrop-filter: blur(12px) saturate(1.08);
  color: #10242b;
  text-decoration: none;
  text-align: center;
}

.header-forecast-pin__top {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 0;
}

.header-forecast-pin__title,
.header-forecast-pin__date,
.header-forecast-pin__summary,
.header-forecast-pin__meta,
.header-forecast-pin__temps {
  font-variant-numeric: tabular-nums;
}

.header-forecast-pin__title {
  font-size: 1rem;
  font-weight: 900;
  color: #244654;
  text-align: center;
}

.header-forecast-pin__date {
  display: none;
}

.header-forecast-pin__meta {
  color: #36505b;
}

.header-forecast-pin__icon {
  display: grid;
  place-items: center;
  min-height: 32px;
  font-size: 2.3rem;
  line-height: 1;
}

.header-forecast-pin__summary {
  min-height: 1.1em;
  font-size: 0.95rem;
  line-height: 1.15;
  font-weight: 900;
  color: #164a86;
}

.header-forecast-pin__temps {
  display: grid;
  gap: 2px;
}

.header-forecast-pin__temps strong,
.header-forecast-pin__meta span {
  display: block;
}

.header-forecast-pin__temps strong {
  font-size: 0.84rem;
  font-weight: 900;
  color: #1f3e49;
}

.header-forecast-pin__temps span {
  font-size: 0.78rem;
  font-weight: 700;
  color: #244654;
}

.header-forecast-pin__meta {
  display: grid;
  gap: 1px;
  font-size: 0.76rem;
  line-height: 1.24;
  font-weight: 700;
}

html.wsg-night .header-forecast-pin__link,
html.dark-mode .header-forecast-pin__link,
body.wsg-night .header-forecast-pin__link,
body.dark-mode .header-forecast-pin__link {
  background: linear-gradient(180deg, rgba(18, 43, 84, 0.16) 0%, rgba(9, 28, 56, 0.08) 100%);
  border-color: rgba(230, 240, 255, 0.18);
  box-shadow: 0 8px 20px rgba(2, 10, 24, 0.08), inset 0 1px 0 rgba(236, 244, 255, 0.08);
  color: #eef5ff;
}

html.wsg-night .header-forecast-pin__title,
html.dark-mode .header-forecast-pin__title,
body.wsg-night .header-forecast-pin__title,
body.dark-mode .header-forecast-pin__title,
html.wsg-night .header-forecast-pin__temps strong,
html.dark-mode .header-forecast-pin__temps strong,
body.wsg-night .header-forecast-pin__temps strong,
body.dark-mode .header-forecast-pin__temps strong,
html.wsg-night .header-forecast-pin__temps span,
html.dark-mode .header-forecast-pin__temps span,
body.wsg-night .header-forecast-pin__temps span,
body.dark-mode .header-forecast-pin__temps span {
  color: #eef5ff;
}

html.wsg-night .header-forecast-pin__summary,
html.dark-mode .header-forecast-pin__summary,
body.wsg-night .header-forecast-pin__summary,
body.dark-mode .header-forecast-pin__summary {
  color: #d7e9ff;
}

html.wsg-night .header-forecast-pin__meta,
html.dark-mode .header-forecast-pin__meta,
body.wsg-night .header-forecast-pin__meta,
body.dark-mode .header-forecast-pin__meta {
  color: #eef5ff;
}

.header-spacex-pin {
  position: absolute;
  left: 50%;
  top: 14px;
  z-index: 26;
  width: clamp(297px, 29.7vw, 421px);
  pointer-events: auto;
  transform: translate(-50%, 65px);
}

.header-spacex-pin__link {
  position: relative;
  display: block;
  width: 100%;
  aspect-ratio: 1707 / 796;
  border-radius: 18px;
  overflow: hidden;
  background: #02060d;
  border: 1px solid rgba(0, 150, 255, 0.30);
  box-shadow: 0 18px 34px rgba(2, 10, 24, 0.26);
}

.header-spacex-pin__img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.header-spacex-pin__overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
  color: #f3fbff;
  font-family: Arial, system-ui, sans-serif;
  font-weight: 900;
  font-variant-numeric: tabular-nums;
  --spx-box-center-y: calc(401 / 796 * 100%);
  --spx-box-width: calc(228 / 1707 * 100%);
  --spx-box-height: calc(80 / 796 * 100%);
  --spx-hh-x: calc(372 / 1707 * 100%);
  --spx-mm-x: calc(631 / 1707 * 100%);
  --spx-ss-x: calc(891 / 1707 * 100%);
  --spx-sep-1-x: calc(501 / 1707 * 100%);
  --spx-sep-2-x: calc(761 / 1707 * 100%);
}

.header-spacex-pin__hh,
.header-spacex-pin__mm,
.header-spacex-pin__ss,
.header-spacex-pin__sep--1,
.header-spacex-pin__sep--2 {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  text-shadow: 0 0 12px rgba(13, 171, 255, 0.22), 0 2px 8px rgba(0, 0, 0, 0.85);
}

.header-spacex-pin__hh,
.header-spacex-pin__mm,
.header-spacex-pin__ss {
  top: var(--spx-box-center-y);
  width: var(--spx-box-width);
  height: var(--spx-box-height);
  transform: translate(-50%, -50%);
  font-size: clamp(0.97rem, 1.16vw, 1.34rem);
  letter-spacing: 0.05em;
}

.header-spacex-pin__hh { left: var(--spx-hh-x); }
.header-spacex-pin__mm { left: var(--spx-mm-x); }
.header-spacex-pin__ss { left: var(--spx-ss-x); }

.header-spacex-pin__sep--1,
.header-spacex-pin__sep--2 {
  top: calc(var(--spx-box-center-y) + 0.15%);
  width: calc(40 / 1707 * 100%);
  height: calc(68 / 796 * 100%);
  transform: translate(-50%, -50%);
  font-size: clamp(0.98rem, 1.18vw, 1.38rem);
  opacity: 0;
}

.header-spacex-pin__sep--1 { left: var(--spx-sep-1-x); }
.header-spacex-pin__sep--2 { left: var(--spx-sep-2-x); }

.site-header::before {
  content: attr(data-solstice-countdown);
  position: absolute;
  right: calc(clamp(12px, 3vw, 34px) + 264px);
  top: 116px;
  z-index: 28;
  width: clamp(260px, 33vw, 430px);
  text-align: center;
  color: #17324a;
  font-size: clamp(12px, 1.1vw, 16px);
  font-weight: 900;
  letter-spacing: .055em;
  text-shadow: 0 1px 0 rgba(255,255,255,.55), 0 0 8px rgba(255,255,255,.16), 0 0 1px rgba(23,50,74,.22);
  pointer-events: none;
  white-space: nowrap;
}

.site-header::after {
  content: "";
  position: absolute;
  right: calc(clamp(12px, 3vw, 34px) + 265px);
  top: -22px;
  z-index: 27;
  width: clamp(260px, 33vw, 430px);
  aspect-ratio: 1536 / 1024;
  background: url("/bilder/laengster_tag/laengster_tag.png") center / contain no-repeat;
  pointer-events: none;
  filter: drop-shadow(0 14px 28px rgba(34, 82, 70, 0.18));
  transform: translateY(-6px);
}

html.wsg-night .site-header::before,
html.dark-mode .site-header::before,
body.wsg-night .site-header::before,
body.dark-mode .site-header::before {
  color: #f6d97a;
  text-shadow: 0 0 10px rgba(0,0,0,.48);
}

.header-spacex-pin.is-live .header-spacex-pin__hh {
  top: var(--spx-box-center-y);
  left: calc(708 / 1707 * 100%);
  width: calc(704 / 1707 * 100%);
  font-size: clamp(0.93rem, 1.06vw, 1.22rem);
  letter-spacing: 0.04em;
  color: #baf2ff;
}

.header-spacex-pin.is-live .header-spacex-pin__mm,
.header-spacex-pin.is-live .header-spacex-pin__ss,
.header-spacex-pin.is-live .header-spacex-pin__sep--1,
.header-spacex-pin.is-live .header-spacex-pin__sep--2 {
  opacity: 0;
}

@media (max-width: 1320px) {
  .header-forecast-pin {
    transform: translate(0, 50px);
  }

  .header-spacex-pin {
    width: 342px;
    transform: translate(160px, 50px);
  }
}

@media (max-width: 1120px) {
  .header-forecast-pin {
    top: 18px;
    transform: translate(0, 50px);
  }

  .header-spacex-pin {
    width: 290px;
    top: 18px;
    transform: translate(118px, 50px);
  }
}

@media (max-width: 980px) {
  .header-forecast-pin,
  .header-spacex-pin {
    display: none;
  }
}

.wsg-theme-switch-wrap {
  display: flex;
  padding: 4px;
  border-radius: 999px;
  background: var(--theme-switch-shell);
  border: 1px solid var(--theme-border-strong);
}

.wsg-theme-switch {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  width: 76px;
  height: 36px;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: transparent;
  cursor: pointer;
}

.wsg-theme-switch-track {
  position: absolute;
  inset: 0;
  border-radius: 999px;
  background: var(--theme-switch-track);
}

.wsg-theme-switch-thumb {
  position: absolute;
  top: 3px;
  left: 3px;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: linear-gradient(180deg, #ffd56a 0%, #f4b63d 100%);
  transition: transform 0.18s ease;
}

.wsg-theme-switch[data-theme="night"] .wsg-theme-switch-thumb {
  transform: translateX(40px);
  background: linear-gradient(180deg, #c6d8ff 0%, #8fb0e6 100%);
}

.wsg-theme-switch-option {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 36px;
  color: var(--theme-note);
  font-size: 1rem;
}

.page-hero {
  position: relative;
  overflow: hidden;
  min-height: clamp(420px, 38vw, 760px);
  background-color: var(--theme-page-bg);
  background-image: none;
  background-position: center top;
  background-repeat: no-repeat;
  background-size: min(100%, 1300px) auto;
}

.page-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(250,243,225,0) 0,
    rgba(250,243,225,0) calc(100% - 140px),
    rgba(250,243,225,.08) calc(100% - 104px),
    rgba(250,243,225,.18) calc(100% - 68px),
    rgba(250,243,225,.30) calc(100% - 34px),
    rgba(7,18,35,.14) calc(100% - 8px),
    var(--theme-page-bg) 100%
  );
  pointer-events: none;
}

html.wsg-night .page-hero::before,
html.dark-mode .page-hero::before,
body.wsg-night .page-hero::before,
body.dark-mode .page-hero::before {
  background: linear-gradient(
    to bottom,
    rgba(7,20,43,0) 0,
    rgba(7,20,43,0) calc(100% - 140px),
    rgba(7,20,43,.06) calc(100% - 104px),
    rgba(7,20,43,.12) calc(100% - 68px),
    rgba(7,20,43,.22) calc(100% - 34px),
    rgba(7,20,43,.34) calc(100% - 8px),
    var(--theme-page-bg) 100%
  );
}

.hero-inner {
  position: relative;
  z-index: 1;
  display: grid;
  align-items: start;
  min-height: clamp(420px, 38vw, 760px);
  padding-top: clamp(92px, 9vw, 129px);
  padding-bottom: clamp(54px, 5vw, 82px);
}

.hero-inner > div:first-child {
  width: min(50%, 600px);
  max-width: 100%;
  margin: 0 auto;
  padding: clamp(18px, 3vw, 30px) clamp(24px, 4vw, 42px);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.18);
  border: 1px solid rgba(255, 255, 255, 0.42);
  box-shadow: 0 18px 42px rgba(34, 82, 70, 0.12);
  backdrop-filter: blur(14px) saturate(1.08);
  -webkit-backdrop-filter: blur(14px) saturate(1.08);
  transform: translateY(calc(clamp(140px, 12vw, 210px) - 50px));
}

.page-hero .eyebrow,
.page-hero .actions,
.page-hero .tag {
  display: none;
}

html.wsg-night .hero-inner > div:first-child,
html.dark-mode .hero-inner > div:first-child,
body.wsg-night .hero-inner > div:first-child,
body.dark-mode .hero-inner > div:first-child {
  background: rgba(7, 23, 45, 0.18);
  border-color: rgba(214, 230, 248, 0.30);
  box-shadow: 0 18px 42px rgba(2, 10, 24, 0.24);
  backdrop-filter: blur(14px) saturate(1.08);
  -webkit-backdrop-filter: blur(14px) saturate(1.08);
}

.page-hero .lead {
  color: var(--theme-ink-soft);
  font-size: 1.1rem;
  line-height: 1.65;
  max-width: 72ch;
}

.section,
.section.alt > .section-inner {
  padding-top: var(--section-gap);
  padding-bottom: var(--section-gap);
}

.section-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 10px;
}

body.site-page h1,
body.site-page h2,
body.site-page h3,
body.site-page .card-title,
body.site-page .home-24h-card > .home-24h-title,
body.site-page .home-mini-chart-title {
  margin-bottom: 4px;
}

.page-hero h1 {
  position: relative;
  top: -10px;
}

.grid { display: grid; gap: 24px; }
.grid.two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid.three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid.four { grid-template-columns: repeat(4, minmax(0, 1fr)); }

.card,
.chart-card,
.metric-card,
.combined-metrics-card,
.embed,
.map-stage,
.swiss-map-card {
  min-width: 0;
  padding: 24px;
  border-radius: 20px;
  background: var(--theme-surface);
  border: 1px solid var(--theme-border);
  box-shadow: var(--theme-shadow);
}

.note { color: var(--theme-note); }

.button,
button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 10px 14px;
  border-radius: 12px;
  border: 1px solid var(--theme-border);
  background: var(--theme-surface-muted);
  color: var(--theme-ink);
  font: inherit;
  font-weight: 700;
  text-decoration: none;
}

body.site-page .wx-stat,
body.site-page .home-summary-section [data-home-stat] {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 12px;
  gap: 8px;
  min-height: 95px;
  border-radius: 20px;
  background: var(--theme-surface);
  border: 1px solid var(--theme-border);
  box-shadow: var(--theme-shadow);
  text-align: center;
  overflow: hidden;
}

body.site-page .wx-value-wrap,
body.site-page .home-summary-section [data-home-stat-value] {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 2px;
  flex-wrap: nowrap;
  max-width: 100%;
}

body.site-page .wx-value,
body.site-page .home-summary-section [data-home-stat-value] {
  font-size: var(--fs-ui-metric-value);
  font-weight: 900;
  line-height: 1;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

body.site-page .wx-unit {
  font-size: var(--fs-ui-metric-unit);
  margin-left: 2px;
  opacity: 0.7;
  white-space: nowrap;
}

body.site-page .card-title { margin-bottom: 6px; text-align: center; }

body.site-page .wx-time,
body.site-page .home-summary-section [data-home-stat-meta] {
  font-size: var(--fs-ui-meta);
  margin-top: 10px;
  line-height: 1.8;
  text-align: center;
  opacity: 0.85;
}

body.site-page .grid.four { gap: 20px; }
body.site-page .grid.four > * { min-width: 0; }

body.site-page .home-24h-card > .home-24h-title { text-align: left; margin-bottom: 24px; }

body.site-page .home-main-chart,
body.site-page .home-mini-chart {
  min-width: 0;
  padding: 18px;
  border-radius: 18px;
  background: var(--theme-chart-bg);
  border: 1px solid var(--theme-border);
}

body.site-page .home-main-chart { margin-bottom: 22px; }

body.site-page .home-mini-chart-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

body.site-page .home-mini-chart-head {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: clamp(26px, 2.2vw, 38px);
  margin-bottom: 12px;
  flex-wrap: wrap;
}

body.site-page .home-mini-chart-title { margin: 0; font-weight: 900; }

body.site-page .home-mini-chart label,
body.site-page .home-main-chart label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  line-height: 1.2;
  font-weight: 500;
  letter-spacing: 0.01em;
  padding: 5px 8px;
  border-radius: 8px;
  background: rgba(120, 160, 210, 0.12);
  border: 1px solid var(--theme-note);
  white-space: nowrap;
}

body.site-page .home-mini-chart label input,
body.site-page .home-main-chart label input {
  width: 12px;
  height: 12px;
  margin: 0;
  flex: 0 0 auto;
}

body.site-page [data-home-temp-preview-message] { display: none; }
body.site-page [data-home-temp-preview-message].is-visible { display: block; }

.chart-canvas,
.metric-chart-canvas,
.combined-chart-canvas,
.swiss-map-frame {
  width: 100%;
  border-radius: 14px;
  background: var(--theme-chart-bg);
  border: 1px solid var(--theme-border);
}

body.site-page .home-main-chart canvas,
body.site-page .chart-canvas[data-home-temp-preview] {
  height: 360px;
  min-height: 360px;
}

body.site-page .home-mini-chart canvas { height: 220px; min-height: 220px; }

.footer {
  min-height: clamp(300px, 42vw, 620px);
  background-color: var(--theme-page-bg);
  background-image: url("/bilder/footer.png");
  background-position: center top;
  background-repeat: no-repeat;
  background-size: min(100%, 1600px) auto;
}

html.wsg-night .footer,
html.dark-mode .footer,
body.wsg-night .footer,
body.dark-mode .footer { background-image: url("/bilder/footer-nacht.png"); }

.footer-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: clamp(300px, 42vw, 620px);
}

.footer-fallback-note,
.footer-center-block {
  padding: 18px 20px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.74);
  border: 1px solid var(--theme-border);
  text-align: center;
  backdrop-filter: blur(3px);
}

html.wsg-night .footer-fallback-note,
html.dark-mode .footer-fallback-note,
body.wsg-night .footer-fallback-note,
body.dark-mode .footer-fallback-note { background: rgba(8, 26, 48, 0.62); }

.footer-glass-tile {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  max-width: 100%;
  padding: 16px 22px;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.32);
  border: 1px solid rgba(255, 255, 255, 0.46);
  box-shadow: 0 16px 36px rgba(8, 24, 42, 0.16);
  color: var(--theme-ink);
  backdrop-filter: blur(10px) saturate(1.15);
  -webkit-backdrop-filter: blur(10px) saturate(1.15);
}

html.wsg-night .footer-glass-tile,
html.dark-mode .footer-glass-tile,
body.wsg-night .footer-glass-tile,
body.dark-mode .footer-glass-tile {
  background: rgba(8, 26, 48, 0.46);
  border-color: rgba(119, 160, 221, 0.32);
}

.footer-copy-line { font-size: 0.8rem; line-height: 1.25; font-weight: 600; white-space: nowrap; }

.footer-visitor-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.34);
  border: 1px solid var(--theme-border);
  color: var(--theme-ink-soft);
  font-size: 0.75rem;
  line-height: 1.15;
  font-weight: 500;
  white-space: nowrap;
}

.footer-visitor-pill strong { font-size: 0.8rem; font-weight: 800; color: var(--theme-ink); }
.footer-pill-separator { width: 1px; height: 1.2em; background: var(--theme-border-strong); }

.metric-card-grid,
.combined-stats-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px;
}

.langzeit-intro {
  margin: 0 0 18px;
}

.langzeit-status {
  margin-top: 18px;
}

.langzeit-grid {
  display: grid;
  gap: 22px;
}

.langzeit-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px;
}

.langzeit-card {
  min-width: 0;
}

.langzeit-card .home-mini-chart {
  height: 100%;
}

.langzeit-card .home-mini-chart-head {
  align-items: flex-start;
  justify-content: flex-start;
}

.langzeit-card-meta {
  display: block;
  min-width: 0;
}

.langzeit-card-copy {
  margin: 0;
  font-size: 1rem;
  line-height: 1.28;
  color: var(--theme-ink-soft);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.langzeit-card-copy strong {
  font-size: 1em;
  font-weight: 900;
}

.langzeit-card-copy .langzeit-card-info {
  font-size: 0.74em;
}

.langzeit-card-meta .note {
  margin: 0;
}

.langzeit-card canvas {
  height: 260px;
  min-height: 260px;
}

@media (max-width: 760px) {
  .langzeit-row {
    grid-template-columns: 1fr;
  }

  .langzeit-card canvas {
    height: 220px;
    min-height: 220px;
  }
}

.embed iframe,
.warning,
.forecast,
.windy {
  width: 100%;
  min-height: 520px;
  border: 0;
  border-radius: 16px;
  background: var(--theme-chart-bg);
}

body.site-page section:has(.grid.three [data-extra-chart]) { display: none; }

@media (max-width: 1080px) {
  .grid.three,
  .grid.four,
  body.site-page .grid.four,
  .metric-card-grid,
  .combined-stats-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .nav {
    flex-wrap: wrap;
    justify-content: flex-start;
  }

  .nav-links {
    order: 2;
    width: 100%;
    justify-content: flex-start;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .wsg-header-controls {
    position: static;
    margin-left: auto;
    transform: none;
  }

  .section-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .grid.two,
  .grid.three,
  .grid.four,
  body.site-page .grid.four,
  .metric-card-grid,
  .combined-stats-grid,
  body.site-page .home-mini-chart-grid {
    grid-template-columns: 1fr;
  }

  .hero-inner {
    min-height: clamp(420px, 86vw, 560px);
    padding-top: 116px;
    padding-bottom: 24px;
  }

  .hero-inner > div:first-child,
  .card,
  .chart-card,
  .metric-card,
  .combined-metrics-card { padding: 20px; }

  body.site-page .home-mini-chart-head { gap: 14px; }

  body.site-page .chart-canvas[data-home-temp-preview],
  body.site-page .home-main-chart canvas {
    min-height: 280px;
    height: 280px;
  }

  .footer-glass-tile,
  .footer-copy-line,
  .footer-visitor-pill { white-space: normal; }
}

/* night-contrast-fix-20260505 */
html.wsg-night,
html.dark-mode,
body.wsg-night,
body.dark-mode {
  --theme-page-bg: #07172d;
  --theme-surface: rgba(7, 23, 45, 0.94);
  --theme-surface-muted: rgba(11, 29, 54, 0.94);
  --theme-border: rgba(108, 144, 188, 0.28);
  --theme-border-strong: rgba(136, 176, 221, 0.38);
  --theme-shadow: 0 18px 40px rgba(1, 8, 22, 0.46);
  --theme-ink: #cfe0f6;
  --theme-ink-soft: #b4c7df;
  --theme-note: #91a7c2;
  --theme-link: #b8d4f5;
  --theme-link-strong: #d6e6f8;
  --theme-chart-bg: #0c223f;
  --theme-header-shell: rgba(6, 18, 37, 0.88);
  --theme-header-hover: rgba(122, 157, 201, 0.14);
  --theme-header-active: rgba(120, 158, 206, 0.2);
  --theme-header-status-bg: rgba(8, 24, 45, 0.92);
  --theme-switch-shell: rgba(9, 27, 48, 0.92);
  --theme-switch-track: rgba(11, 29, 54, 0.98);
}

html.wsg-night body,
html.dark-mode body,
body.wsg-night,
body.dark-mode {
  color: var(--theme-ink);
  background: var(--theme-page-bg);
}

html.wsg-night body.site-page,
html.dark-mode body.site-page,
body.wsg-night.site-page,
body.dark-mode.site-page,
html.wsg-night body.site-page p,
html.dark-mode body.site-page p,
body.wsg-night.site-page p,
body.dark-mode.site-page p,
html.wsg-night body.site-page li,
html.dark-mode body.site-page li,
body.wsg-night.site-page li,
body.dark-mode.site-page li,
html.wsg-night body.site-page label,
html.dark-mode body.site-page label,
body.wsg-night.site-page label,
body.dark-mode.site-page label,
html.wsg-night body.site-page h1,
html.dark-mode body.site-page h1,
body.wsg-night.site-page h1,
body.dark-mode.site-page h1,
html.wsg-night body.site-page h2,
html.dark-mode body.site-page h2,
body.wsg-night.site-page h2,
body.dark-mode.site-page h2,
html.wsg-night body.site-page h3,
html.dark-mode body.site-page h3,
body.wsg-night.site-page h3,
body.dark-mode.site-page h3,
html.wsg-night body.site-page .note,
html.dark-mode body.site-page .note,
body.wsg-night.site-page .note,
body.dark-mode.site-page .note,
html.wsg-night body.site-page .wx-time,
html.dark-mode body.site-page .wx-time,
body.wsg-night.site-page .wx-time,
body.dark-mode.site-page .wx-time {
  color: var(--theme-ink);
}

html.wsg-night body.site-page .note,
html.dark-mode body.site-page .note,
body.wsg-night.site-page .note,
body.dark-mode.site-page .note,
html.wsg-night body.site-page .wx-time,
html.dark-mode body.site-page .wx-time,
body.wsg-night.site-page .wx-time,
body.dark-mode .wx-time {
  color: var(--theme-note);
}

html.wsg-night .hero-inner > div:first-child,
html.dark-mode .hero-inner > div:first-child,
body.wsg-night .hero-inner > div:first-child,
body.dark-mode .hero-inner > div:first-child,
html.wsg-night .card,
html.dark-mode .card,
body.wsg-night .card,
body.dark-mode .card,
html.wsg-night .chart-card,
html.dark-mode .chart-card,
body.wsg-night .chart-card,
body.dark-mode .chart-card,
html.wsg-night .metric-card,
html.dark-mode .metric-card,
body.wsg-night .metric-card,
body.dark-mode .metric-card,
html.wsg-night .combined-metrics-card,
html.dark-mode .combined-metrics-card,
body.wsg-night .combined-metrics-card,
body.dark-mode .combined-metrics-card,
html.wsg-night .embed,
html.dark-mode .embed,
body.wsg-night .embed,
body.dark-mode .embed,
html.wsg-night .map-stage,
html.dark-mode .map-stage,
body.wsg-night .map-stage,
body.dark-mode .map-stage,
html.wsg-night .swiss-map-card,
html.dark-mode .swiss-map-card,
body.wsg-night .swiss-map-card,
body.dark-mode .swiss-map-card,
html.wsg-night .footer-fallback-note,
html.dark-mode .footer-fallback-note,
body.wsg-night .footer-fallback-note,
body.dark-mode .footer-fallback-note,
html.wsg-night .footer-center-block,
html.dark-mode .footer-center-block,
body.wsg-night .footer-center-block,
body.dark-mode .footer-center-block,
html.wsg-night .footer-glass-tile,
html.dark-mode .footer-glass-tile,
body.wsg-night .footer-glass-tile,
body.dark-mode .footer-glass-tile,
html.wsg-night .footer-visitor-pill,
html.dark-mode .footer-visitor-pill,
body.wsg-night .footer-visitor-pill,
body.dark-mode .footer-visitor-pill {
  background: rgba(8, 24, 45, 0.92);
  border-color: rgba(108, 144, 188, 0.26);
  color: var(--theme-ink);
}

html.wsg-night .button,
html.dark-mode .button,
body.wsg-night .button,
body.dark-mode .button,
html.wsg-night button,
html.dark-mode button,
body.wsg-night button,
body.dark-mode button,
html.wsg-night input,
html.dark-mode input,
body.wsg-night input,
body.dark-mode input,
html.wsg-night textarea,
html.dark-mode textarea,
body.wsg-night textarea,
body.dark-mode textarea,
html.wsg-night select,
html.dark-mode select,
body.wsg-night select,
body.dark-mode select {
  background: rgba(10, 25, 48, 0.96);
  color: #cfe0f6;
  border-color: rgba(108, 144, 188, 0.28);
}

html.wsg-night .visitor-stat,
html.dark-mode .visitor-stat,
body.wsg-night .visitor-stat,
body.dark-mode .visitor-stat,
html.wsg-night .visitor-average,
html.dark-mode .visitor-average,
body.wsg-night .visitor-average,
body.dark-mode .visitor-average,
html.wsg-night .visitor-panel,
html.dark-mode .visitor-panel,
body.wsg-night .visitor-panel,
body.dark-mode .visitor-panel,
html.wsg-night .visitor-focus-card,
html.dark-mode .visitor-focus-card,
body.wsg-night .visitor-focus-card,
body.dark-mode .visitor-focus-card,
html.wsg-night .visitor-mini-card,
html.dark-mode .visitor-mini-card,
body.wsg-night .visitor-mini-card,
body.dark-mode .visitor-mini-card,
html.wsg-night .visitor-kpi-card,
html.dark-mode .visitor-kpi-card,
body.wsg-night .visitor-kpi-card,
body.dark-mode .visitor-kpi-card,
html.wsg-night .visitor-detail-box,
html.dark-mode .visitor-detail-box,
body.wsg-night .visitor-detail-box,
body.dark-mode .visitor-detail-box,
html.wsg-night .visitor-trend-frame,
html.dark-mode .visitor-trend-frame,
body.wsg-night .visitor-trend-frame,
body.dark-mode .visitor-trend-frame,
html.wsg-night .visitor-auth-dialog,
html.dark-mode .visitor-auth-dialog,
body.wsg-night .visitor-auth-dialog,
body.dark-mode .visitor-auth-dialog {
  background: rgba(8, 24, 45, 0.96) !important;
  border-color: rgba(108, 144, 188, 0.28) !important;
  color: #b7cbe2 !important;
}

html.wsg-night .visitor-stat-value,
html.dark-mode .visitor-stat-value,
body.wsg-night .visitor-stat-value,
body.dark-mode .visitor-stat-value,
html.wsg-night .visitor-focus-value,
html.dark-mode .visitor-focus-value,
body.wsg-night .visitor-focus-value,
body.dark-mode .visitor-focus-value,
html.wsg-night .visitor-mini-value,
html.dark-mode .visitor-mini-value,
body.wsg-night .visitor-mini-value,
body.dark-mode .visitor-mini-value,
html.wsg-night .visitor-table th,
html.dark-mode .visitor-table th,
body.wsg-night .visitor-table th,
body.dark-mode .visitor-table th,
html.wsg-night .visitor-table td,
html.dark-mode .visitor-table td,
body.wsg-night .visitor-table td,
body.dark-mode .visitor-table td,
html.wsg-night .visitor-detail-box strong,
html.dark-mode .visitor-detail-box strong,
body.wsg-night .visitor-detail-box strong,
body.dark-mode .visitor-detail-box strong,
html.wsg-night .visitor-kpi-card strong,
html.dark-mode .visitor-kpi-card strong,
body.wsg-night .visitor-kpi-card strong,
body.dark-mode .visitor-kpi-card strong {
  color: #cfe0f6 !important;
}

html.wsg-night .visitor-stat-label,
html.dark-mode .visitor-stat-label,
body.wsg-night .visitor-stat-label,
body.dark-mode .visitor-stat-label,
html.wsg-night .visitor-average-label,
html.dark-mode .visitor-average-label,
body.wsg-night .visitor-average-label,
body.dark-mode .visitor-average-label,
html.wsg-night .visitor-panel h3,
html.dark-mode .visitor-panel h3,
body.wsg-night .visitor-panel h3,
body.dark-mode .visitor-panel h3,
html.wsg-night .visitor-focus-label,
html.dark-mode .visitor-focus-label,
body.wsg-night .visitor-focus-label,
body.dark-mode .visitor-focus-label,
html.wsg-night .visitor-mini-label,
html.dark-mode .visitor-mini-label,
body.wsg-night .visitor-mini-label,
body.dark-mode .visitor-mini-label,
html.wsg-night .visitor-subhead,
html.dark-mode .visitor-subhead,
body.wsg-night .visitor-subhead,
body.dark-mode .visitor-subhead,
html.wsg-night .visitor-stat-meta,
html.dark-mode .visitor-stat-meta,
body.wsg-night .visitor-stat-meta,
body.dark-mode .visitor-stat-meta,
html.wsg-night .visitor-average-value,
html.dark-mode .visitor-average-value,
body.wsg-night .visitor-average-value,
body.dark-mode .visitor-average-value,
html.wsg-night .visitor-panel p,
html.dark-mode .visitor-panel p,
body.wsg-night .visitor-panel p,
body.dark-mode .visitor-panel p,
html.wsg-night .visitor-empty,
html.dark-mode .visitor-empty,
body.wsg-night .visitor-empty,
body.dark-mode .visitor-empty,
html.wsg-night .visitor-status,
html.dark-mode .visitor-status,
body.wsg-night .visitor-status,
body.dark-mode .visitor-status,
html.wsg-night .visitor-focus-meta,
html.dark-mode .visitor-focus-meta,
body.wsg-night .visitor-focus-meta,
body.dark-mode .visitor-focus-meta,
html.wsg-night .visitor-mini-meta,
html.dark-mode .visitor-mini-meta,
body.wsg-night .visitor-mini-meta,
body.dark-mode .visitor-mini-meta,
html.wsg-night .visitor-inline-note,
html.dark-mode .visitor-inline-note,
body.wsg-night .visitor-inline-note,
body.dark-mode .visitor-inline-note,
html.wsg-night .visitor-auth-note,
html.dark-mode .visitor-auth-note,
body.wsg-night .visitor-auth-note,
body.dark-mode .visitor-auth-note,
html.wsg-night .visitor-auth-status,
html.dark-mode .visitor-auth-status,
body.wsg-night .visitor-auth-status,
body.dark-mode .visitor-auth-status,
html.wsg-night .visitor-form-label,
html.dark-mode .visitor-form-label,
body.wsg-night .visitor-form-label,
body.dark-mode .visitor-form-label {
  color: #b7cbe2 !important;
}

html.wsg-night .visitor-chip,
html.dark-mode .visitor-chip,
body.wsg-night .visitor-chip,
body.dark-mode .visitor-chip,
html.wsg-night .back-to-top,
html.dark-mode .back-to-top,
body.wsg-night .back-to-top,
body.dark-mode .back-to-top {
  background: rgba(11, 29, 54, 0.94) !important;
  color: #cfe0f6 !important;
  border-color: rgba(108, 144, 188, 0.28) !important;
}

html.wsg-night .visitor-chip.is-active,
html.dark-mode .visitor-chip.is-active,
body.wsg-night .visitor-chip.is-active,
body.dark-mode .visitor-chip.is-active {
  background: rgba(34, 71, 113, 0.9) !important;
  color: #d6e6f8 !important;
  border-color: rgba(122, 160, 204, 0.4) !important;
}

html.wsg-night .visitor-table th,
html.dark-mode .visitor-table th,
body.wsg-night .visitor-table th,
body.dark-mode .visitor-table th,
html.wsg-night .visitor-table td,
html.dark-mode .visitor-table td,
body.wsg-night .visitor-table td,
body.dark-mode .visitor-table td {
  border-bottom-color: rgba(108, 144, 188, 0.18) !important;
}

html.wsg-night .combined-chart-shell,
html.dark-mode .combined-chart-shell,
body.wsg-night .combined-chart-shell,
body.dark-mode .combined-chart-shell,
html.wsg-night .combined-series-controls,
html.dark-mode .combined-series-controls,
body.wsg-night .combined-series-controls,
body.dark-mode .combined-series-controls,
html.wsg-night .combined-stat-card,
html.dark-mode .combined-stat-card,
body.wsg-night .combined-stat-card,
body.dark-mode .combined-stat-card {
  background: rgba(8, 24, 45, 0.96) !important;
  border-color: rgba(108, 144, 188, 0.28) !important;
  color: #b7cbe2 !important;
}

html.wsg-night .combined-metrics-card,
html.dark-mode .combined-metrics-card,
body.wsg-night .combined-metrics-card,
body.dark-mode .combined-metrics-card {
  background: rgba(7, 23, 45, 0.94) !important;
  border-color: rgba(108, 144, 188, 0.28) !important;
}

html.wsg-night .combined-loading,
html.dark-mode .combined-loading,
body.wsg-night .combined-loading,
body.dark-mode .combined-loading,
html.wsg-night .combined-notice,
html.dark-mode .combined-notice,
body.wsg-night .combined-notice,
body.dark-mode .combined-notice,
html.wsg-night .combined-field-note,
html.dark-mode .combined-field-note,
body.wsg-night .combined-field-note,
body.dark-mode .combined-field-note,
html.wsg-night .combined-stat-lines,
html.dark-mode .combined-stat-lines,
body.wsg-night .combined-stat-lines,
body.dark-mode .combined-stat-lines {
  color: #9db4cf !important;
}

html.wsg-night .combined-metrics-title h2,
html.dark-mode .combined-metrics-title h2,
body.wsg-night .combined-metrics-title h2,
body.dark-mode .combined-metrics-title h2,
html.wsg-night .combined-metrics-title p,
html.dark-mode .combined-metrics-title p,
body.wsg-night .combined-metrics-title p,
body.dark-mode .combined-metrics-title p,
html.wsg-night .combined-stat-head,
html.dark-mode .combined-stat-head,
body.wsg-night .combined-stat-head,
body.dark-mode .combined-stat-head,
html.wsg-night .combined-stat-lines strong,
html.dark-mode .combined-stat-lines strong,
body.wsg-night .combined-stat-lines strong,
body.dark-mode .combined-stat-lines strong,
html.wsg-night .combined-series-toggle,
html.dark-mode .combined-series-toggle,
body.wsg-night .combined-series-toggle,
body.dark-mode .combined-series-toggle,
html.wsg-night .combined-series-toggle small,
html.dark-mode .combined-series-toggle small,
body.wsg-night .combined-series-toggle small,
body.dark-mode .combined-series-toggle small {
  color: #cfe0f6 !important;
}

html.wsg-night .combined-range-tabs,
html.dark-mode .combined-range-tabs,
body.wsg-night .combined-range-tabs,
body.dark-mode .combined-range-tabs {
  background: rgba(8, 24, 45, 0.92) !important;
  border-color: rgba(108, 144, 188, 0.28) !important;
}

html.wsg-night .combined-range-tabs button,
html.dark-mode .combined-range-tabs button,
body.wsg-night .combined-range-tabs button,
body.dark-mode .combined-range-tabs button,
html.wsg-night .combined-series-toggle,
html.dark-mode .combined-series-toggle,
body.wsg-night .combined-series-toggle,
body.dark-mode .combined-series-toggle {
  background: rgba(10, 25, 48, 0.94) !important;
  border-color: rgba(108, 144, 188, 0.24) !important;
  color: #cfe0f6 !important;
}

html.wsg-night .combined-range-tabs button.is-active,
html.dark-mode .combined-range-tabs button.is-active,
body.wsg-night .combined-range-tabs button.is-active,
body.dark-mode .combined-range-tabs button.is-active {
  background: rgba(34, 71, 113, 0.9) !important;
  color: #d6e6f8 !important;
}

html.wsg-night .combined-stat-lines div,
html.dark-mode .combined-stat-lines div,
body.wsg-night .combined-stat-lines div,
body.dark-mode .combined-stat-lines div {
  border-top-color: rgba(108, 144, 188, 0.18) !important;
}

.combined-series-controls {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 14px 20px;
  margin: 24px auto 34px;
  width: min(100%, 1120px);
  max-width: 100%;
}

.combined-series-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 4px 2px;
}

.combined-stats-grid {
  grid-template-columns: repeat(4, minmax(220px, 1fr));
  gap: 26px 30px;
  align-items: start;
  justify-content: center;
  width: min(100%, 1180px);
  margin: 0 auto;
}

.combined-stat-card {
  height: 100%;
  text-align: left;
}

.combined-stat-head {
  color: var(--series-color) !important;
  margin: 0 0 16px;
}

.combined-stat-lines {
  display: grid;
  gap: 12px;
}

.combined-stat-lines div {
  display: grid;
  grid-template-columns: 11ch minmax(0, 1fr);
  align-items: baseline;
  justify-content: flex-start;
  column-gap: 14px;
  row-gap: 0;
  line-height: 1.55;
}

.combined-stat-label,
.combined-stat-value,
.combined-stat-lines strong {
  display: block;
  font-weight: 400 !important;
}

.combined-stat-label {
  white-space: nowrap;
}

.combined-stat-value {
  color: inherit;
  white-space: nowrap;
  text-align: left;
}

@media (max-width: 1080px) {
  .combined-series-controls {
    gap: 12px 18px;
  }

  .combined-stats-grid {
    grid-template-columns: repeat(2, minmax(220px, 1fr));
  }
}

@media (max-width: 760px) {
  .combined-series-controls {
    margin-top: 18px;
    margin-bottom: 24px;
    gap: 10px 14px;
  }

  .combined-stats-grid {
    grid-template-columns: 1fr;
  }

  .combined-stat-lines div {
    grid-template-columns: 10ch minmax(0, 1fr);
  }
}

/* central-contact-and-shared-ui-20260505 */
:root {
  --line: var(--theme-border);
  --ink: var(--theme-ink);
  --muted: var(--theme-note);
  --leaf: var(--theme-border-strong);
}

.eyebrow {
  display: inline-block;
  margin-bottom: 10px;
  color: var(--theme-link);
  font-size: var(--fs-small);
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 22px;
}

.button.primary {
  background: var(--theme-link);
  border-color: var(--theme-link);
  color: #fff;
}

.button.primary:hover {
  background: var(--theme-link-strong);
  border-color: var(--theme-link-strong);
  color: #fff;
}

.tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: 8px;
  padding: 2px 8px;
  border-radius: 999px;
  background: rgba(74,132,183,.12);
  border: 1px solid rgba(74,132,183,.22);
  color: var(--theme-link);
  font-size: .72em;
  font-weight: 800;
  line-height: 1.2;
  vertical-align: middle;
}

.tint-mint {
  background: linear-gradient(180deg, rgba(236,246,241,.96) 0%, rgba(247,251,249,.96) 100%);
}

.tint-sky {
  background: linear-gradient(180deg, rgba(237,245,252,.96) 0%, rgba(247,251,249,.96) 100%);
}

.tint-coral {
  background: linear-gradient(180deg, rgba(251,241,236,.96) 0%, rgba(247,251,249,.96) 100%);
}

.contact-form-shell {
  width: min(100%, 760px);
  margin-inline: auto;
  display: grid;
  gap: 18px;
}

.contact-intro {
  width: min(100%, 760px);
  margin-inline: auto;
}

.form-field {
  display: grid;
  gap: 8px;
}

.form-label {
  font-size: 14px;
  font-weight: 800;
  color: #35525b;
  letter-spacing: .01em;
}

.form-input,
.form-textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #fff;
  color: var(--ink);
  font: inherit;
  padding: 12px 14px;
  outline: none;
  box-shadow: none;
}

.form-input {
  min-height: 46px;
}

.form-textarea {
  min-height: 220px;
  resize: vertical;
  line-height: 1.5;
}

.form-input:focus,
.form-textarea:focus {
  border-color: var(--leaf);
}

.form-note {
  font-size: 14px;
  color: var(--muted);
  margin-top: -2px;
}

.contact-actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 4px;
}

.contact-status {
  min-height: 1.5em;
  font-size: 14px;
  color: var(--muted);
}

.contact-status.is-error {
  color: #a63d3d;
}

.contact-status.is-success {
  color: #2e6a43;
}

.contact-modal[hidden] {
  display: none;
}

.contact-modal {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: grid;
  place-items: center;
  padding: 20px;
}

.contact-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(21,29,27,.18);
  backdrop-filter: blur(10px);
}

.contact-modal-dialog {
  width: min(100%, 760px);
  padding: 30px 32px;
  border-radius: 20px;
  display: grid;
  gap: 22px;
  position: relative;
  z-index: 1;
  background: rgba(255,255,255,.97);
  color: var(--ink);
  border: 4px solid rgba(255,255,255,.88);
  box-shadow: 0 24px 56px rgba(21,29,27,.18);
}

.contact-modal-dialog h3 {
  margin: 0;
  color: var(--ink);
  line-height: 1.25;
}

.contact-modal-meta {
  display: grid;
  gap: 10px;
  color: var(--ink);
  line-height: 1.55;
}

.contact-modal-meta strong {
  color: var(--ink);
}

.contact-modal-preview {
  padding: 20px 22px;
  border-radius: 16px;
  border: 2px solid var(--line);
  background: #fff;
  color: var(--ink);
  white-space: pre-wrap;
  line-height: 1.75;
  min-height: 140px;
}

.contact-modal-status {
  display: none;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border-radius: 14px;
  border: 2px solid transparent;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.55;
}

.contact-modal-status.is-visible {
  display: flex;
}

.contact-modal-status.is-pending {
  color: #214c60;
  background: rgba(214, 238, 247, .84);
  border-color: rgba(116, 164, 185, .38);
}

.contact-modal-status.is-error {
  color: #8a2d2d;
  background: rgba(252, 232, 232, .9);
  border-color: rgba(204, 126, 126, .42);
}

.contact-modal-status.is-success {
  color: #14663e;
  background: rgba(225, 244, 232, .92);
  border-color: rgba(89, 159, 110, .4);
}

.contact-modal-status-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 30px;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  font-size: 16px;
  font-weight: 900;
  background: rgba(255,255,255,.88);
  border: 2px solid rgba(255,255,255,.72);
}

.contact-modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 14px;
  flex-wrap: wrap;
  padding-top: 4px;
}

.contact-modal-actions .button {
  border-width: 2px;
}

.contact-modal-actions [hidden] {
  display: none !important;
}

.contact-secondary-button {
  background: transparent;
}

body.contact-modal-open {
  overflow: hidden;
}

html.wsg-night .contact-modal-backdrop,
html.dark-mode .contact-modal-backdrop,
body.wsg-night .contact-modal-backdrop,
body.dark-mode .contact-modal-backdrop {
  background: rgba(3, 10, 22, .72);
  backdrop-filter: blur(10px);
}

html.wsg-night .contact-modal-dialog,
html.dark-mode .contact-modal-dialog,
body.wsg-night .contact-modal-dialog,
body.dark-mode .contact-modal-dialog {
  background: #07172d;
  color: #d7e6f8;
  border-color: rgba(108, 144, 188, .34);
  box-shadow: 0 24px 64px rgba(0, 0, 0, .42);
}

html.wsg-night .contact-modal-dialog h3,
html.dark-mode .contact-modal-dialog h3,
body.wsg-night .contact-modal-dialog h3,
body.dark-mode .contact-modal-dialog h3,
html.wsg-night .contact-modal-meta,
html.dark-mode .contact-modal-meta,
body.wsg-night .contact-modal-meta,
body.dark-mode .contact-modal-meta,
html.wsg-night .contact-modal-meta strong,
html.dark-mode .contact-modal-meta strong,
body.wsg-night .contact-modal-meta strong,
body.dark-mode .contact-modal-meta strong {
  color: #d7e6f8;
}

html.wsg-night .contact-modal-preview,
html.dark-mode .contact-modal-preview,
body.wsg-night .contact-modal-preview,
body.dark-mode .contact-modal-preview {
  background: #0b1d36;
  color: #d7e6f8;
  border-color: rgba(108, 144, 188, .42);
}

html.wsg-night .contact-modal-status.is-success,
html.dark-mode .contact-modal-status.is-success,
body.wsg-night .contact-modal-status.is-success,
body.dark-mode .contact-modal-status.is-success {
  color: #bff3d1;
  background: rgba(22, 97, 62, .22);
  border-color: rgba(115, 210, 147, .38);
}

html.wsg-night .contact-modal-status.is-error,
html.dark-mode .contact-modal-status.is-error,
body.wsg-night .contact-modal-status.is-error,
body.dark-mode .contact-modal-status.is-error {
  color: #ffd2d2;
  background: rgba(125, 43, 43, .24);
  border-color: rgba(220, 126, 126, .36);
}

html.wsg-night .contact-modal-status.is-pending,
html.dark-mode .contact-modal-status.is-pending,
body.wsg-night .contact-modal-status.is-pending,
body.dark-mode .contact-modal-status.is-pending {
  color: #d7e6f8;
  background: rgba(45, 84, 126, .28);
  border-color: rgba(108, 144, 188, .38);
}

html.wsg-night .contact-modal-status-icon,
html.dark-mode .contact-modal-status-icon,
body.wsg-night .contact-modal-status-icon,
body.dark-mode .contact-modal-status-icon {
  background: rgba(7, 23, 45, .96);
  border-color: rgba(108, 144, 188, .32);
}

html.wsg-night .nav-links,
html.dark-mode .nav-links,
body.wsg-night .nav-links,
body.dark-mode .nav-links {
  background: rgba(6, 18, 37, 0.46);
  border-color: rgba(136, 176, 221, 0.32);
  backdrop-filter: blur(8px) saturate(1.08);
  -webkit-backdrop-filter: blur(8px) saturate(1.08);
}

html.wsg-night .wsg-header-status,
html.dark-mode .wsg-header-status,
body.wsg-night .wsg-header-status,
body.dark-mode .wsg-header-status {
  background: rgba(8, 24, 45, 0.48);
  border-color: rgba(136, 176, 221, 0.32);
  backdrop-filter: blur(8px) saturate(1.08);
  -webkit-backdrop-filter: blur(8px) saturate(1.08);
}

html.wsg-night .wsg-theme-switch-wrap,
html.dark-mode .wsg-theme-switch-wrap,
body.wsg-night .wsg-theme-switch-wrap,
body.dark-mode .wsg-theme-switch-wrap {
  background: rgba(9, 27, 48, 0.50);
  border-color: rgba(136, 176, 221, 0.32);
  backdrop-filter: blur(8px) saturate(1.08);
  -webkit-backdrop-filter: blur(8px) saturate(1.08);
}

html.wsg-night .hero-inner > div:first-child,
html.dark-mode .hero-inner > div:first-child,
body.wsg-night .hero-inner > div:first-child,
body.dark-mode .hero-inner > div:first-child {
  background: rgba(7, 23, 45, 0.18);
  border-color: rgba(214, 230, 248, 0.30);
  box-shadow: 0 18px 42px rgba(2, 10, 24, 0.24);
  backdrop-filter: blur(14px) saturate(1.08);
  -webkit-backdrop-filter: blur(14px) saturate(1.08);
}

@media (max-width: 760px) {
  .actions {
    align-items: stretch;
  }

  .contact-modal-dialog {
    padding: 24px 20px;
  }

  .contact-modal-actions {
    justify-content: stretch;
  }
}

/* header-weather-live-20260506 */
.page-hero.wsg-hero-weather[data-weather-state] {
  background-position: center top;
  background-repeat: no-repeat;
  background-size: min(100%, 1300px) auto;
}

.page-hero.wsg-hero-weather[data-weather-state="fallback"] {
  background-image: url("/bilder/header.png");
}

.page-hero.wsg-hero-weather[data-weather-state="klar"] {
  background-image: url("/bilder/standard_tag-nacht_bilder/tag-wolkenlos-sonnig.png");
}

.page-hero.wsg-hero-weather[data-weather-state="leicht_bewoelkt"] {
  background-image: url("/bilder/standard_tag-nacht_bilder/tag-leicht-bewoelkt.png");
}

.page-hero.wsg-hero-weather[data-weather-state="bewoelkt"] {
  background-image: url("/bilder/standard_tag-nacht_bilder/tag-bewoelkt.png");
}

.page-hero.wsg-hero-weather[data-weather-state="stark_bewoelkt"] {
  background-image: url("/bilder/standard_tag-nacht_bilder/tag-stark-bewoelkt.png");
}

.page-hero.wsg-hero-weather[data-weather-state="nebel_leicht"] {
  background-image: url("/bilder/standard_tag-nacht_bilder/tag-nebel-leicht.png");
}

.page-hero.wsg-hero-weather[data-weather-state="nebel"] {
  background-image: url("/bilder/standard_tag-nacht_bilder/tag-nebel.png");
}

.page-hero.wsg-hero-weather[data-weather-state="regen"] {
  background-image: url("/bilder/standard_tag-nacht_bilder/tag-regen.png");
}

.page-hero.wsg-hero-weather[data-weather-state="gewitter"] {
  background-image: url("/bilder/standard_tag-nacht_bilder/tag-gewitter.png");
}

.page-hero.wsg-hero-weather[data-weather-state="sturm"] {
  background-image: url("/bilder/standard_tag-nacht_bilder/tag-sturm.png");
}

html.wsg-night .page-hero.wsg-hero-weather[data-weather-state="fallback"],
html.dark-mode .page-hero.wsg-hero-weather[data-weather-state="fallback"],
body.wsg-night .page-hero.wsg-hero-weather[data-weather-state="fallback"],
body.dark-mode .page-hero.wsg-hero-weather[data-weather-state="fallback"] {
  background-image: url("/bilder/header-nacht.png");
}

html.wsg-night .page-hero.wsg-hero-weather[data-weather-state="klar"],
html.dark-mode .page-hero.wsg-hero-weather[data-weather-state="klar"],
body.wsg-night .page-hero.wsg-hero-weather[data-weather-state="klar"],
body.dark-mode .page-hero.wsg-hero-weather[data-weather-state="klar"] {
  background-image: url("/bilder/standard_tag-nacht_bilder/nacht-klar-wolkenlos.png");
}

html.wsg-night .page-hero.wsg-hero-weather[data-weather-state="leicht_bewoelkt"],
html.dark-mode .page-hero.wsg-hero-weather[data-weather-state="leicht_bewoelkt"],
body.wsg-night .page-hero.wsg-hero-weather[data-weather-state="leicht_bewoelkt"],
body.dark-mode .page-hero.wsg-hero-weather[data-weather-state="leicht_bewoelkt"] {
  background-image: url("/bilder/standard_tag-nacht_bilder/nacht-leicht-bewoelkt.png");
}

html.wsg-night .page-hero.wsg-hero-weather[data-weather-state="bewoelkt"],
html.dark-mode .page-hero.wsg-hero-weather[data-weather-state="bewoelkt"],
body.wsg-night .page-hero.wsg-hero-weather[data-weather-state="bewoelkt"],
body.dark-mode .page-hero.wsg-hero-weather[data-weather-state="bewoelkt"] {
  background-image: url("/bilder/standard_tag-nacht_bilder/nacht-bewoelkt.png");
}

html.wsg-night .page-hero.wsg-hero-weather[data-weather-state="stark_bewoelkt"],
html.dark-mode .page-hero.wsg-hero-weather[data-weather-state="stark_bewoelkt"],
body.wsg-night .page-hero.wsg-hero-weather[data-weather-state="stark_bewoelkt"],
body.dark-mode .page-hero.wsg-hero-weather[data-weather-state="stark_bewoelkt"] {
  background-image: url("/bilder/standard_tag-nacht_bilder/nacht-stark-bewoelkt.png");
}

html.wsg-night .page-hero.wsg-hero-weather[data-weather-state="nebel_leicht"],
html.dark-mode .page-hero.wsg-hero-weather[data-weather-state="nebel_leicht"],
body.wsg-night .page-hero.wsg-hero-weather[data-weather-state="nebel_leicht"],
body.dark-mode .page-hero.wsg-hero-weather[data-weather-state="nebel_leicht"] {
  background-image: url("/bilder/standard_tag-nacht_bilder/nacht-nebel-leicht.png");
}

html.wsg-night .page-hero.wsg-hero-weather[data-weather-state="nebel"],
html.dark-mode .page-hero.wsg-hero-weather[data-weather-state="nebel"],
body.wsg-night .page-hero.wsg-hero-weather[data-weather-state="nebel"],
body.dark-mode .page-hero.wsg-hero-weather[data-weather-state="nebel"] {
  background-image: url("/bilder/standard_tag-nacht_bilder/nacht-nebel.png");
}

html.wsg-night .page-hero.wsg-hero-weather[data-weather-state="regen"],
html.dark-mode .page-hero.wsg-hero-weather[data-weather-state="regen"],
body.wsg-night .page-hero.wsg-hero-weather[data-weather-state="regen"],
body.dark-mode .page-hero.wsg-hero-weather[data-weather-state="regen"] {
  background-image: url("/bilder/standard_tag-nacht_bilder/nacht-regen.png");
}

html.wsg-night .page-hero.wsg-hero-weather[data-weather-state="gewitter"],
html.dark-mode .page-hero.wsg-hero-weather[data-weather-state="gewitter"],
body.wsg-night .page-hero.wsg-hero-weather[data-weather-state="gewitter"],
body.dark-mode .page-hero.wsg-hero-weather[data-weather-state="gewitter"] {
  background-image: url("/bilder/standard_tag-nacht_bilder/nacht-gewitter.png");
}

html.wsg-night .page-hero.wsg-hero-weather[data-weather-state="sturm"],
html.dark-mode .page-hero.wsg-hero-weather[data-weather-state="sturm"],
body.wsg-night .page-hero.wsg-hero-weather[data-weather-state="sturm"],
body.dark-mode .page-hero.wsg-hero-weather[data-weather-state="sturm"] {
  background-image: url("/bilder/standard_tag-nacht_bilder/nacht-sturm.png");
}

/* hero-layer-structure-fix-20260506-final */
.page-hero {
  isolation: isolate;
}

.page-hero::before,
.page-hero::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  pointer-events: none;
}

.page-hero::before {
  inset: 0;
  z-index: 0;
  background: rgba(255, 252, 245, 0.04);
}

html.wsg-night .page-hero::before,
html.dark-mode .page-hero::before,
body.wsg-night .page-hero::before,
body.dark-mode .page-hero::before {
  background: rgba(7, 20, 43, 0.14);
}

.page-hero::after {
  inset: auto 0 0 0;
  height: 96px;
  z-index: 1;
  background: linear-gradient(
    to bottom,
    rgba(250, 243, 225, 0) 0%,
    rgba(250, 243, 225, 0.05) 42%,
    rgba(250, 243, 225, 0.14) 72%,
    var(--theme-page-bg) 100%
  );
}

html.wsg-night .page-hero::after,
html.dark-mode .page-hero::after,
body.wsg-night .page-hero::after,
body.dark-mode .page-hero::after {
  background: linear-gradient(
    to bottom,
    rgba(7, 20, 43, 0) 0%,
    rgba(7, 20, 43, 0.05) 42%,
    rgba(7, 20, 43, 0.12) 72%,
    var(--theme-page-bg) 100%
  );
}

.hero-inner,
.page-hero > * {
  position: relative;
  z-index: 2;
}

main > .page-hero + .section,
main > .page-hero + .section::before,
main > .page-hero + .section::after,
main > .page-hero + .section > .card::before,
main > .page-hero + .section > .card::after {
  content: none !important;
  background: none !important;
}

main > .page-hero + .section {
  position: relative;
  z-index: 3;
  overflow: visible;
  margin-top: -205px;
  padding-top: 0;
  border-top: 0 !important;
  background-image: none !important;
}

main > .page-hero + .section > .card {
  position: relative;
  z-index: 4;
  margin-top: 8px;
  border-top: 1px solid var(--theme-glass-card-border, var(--theme-border)) !important;
  background-image: none !important;
  box-shadow: var(--theme-glass-card-shadow, var(--theme-shadow)) !important;
}

/* night-unified-blue-20260507 */
html.wsg-night,
html.dark-mode,
body.wsg-night,
body.dark-mode {
  --theme-page-bg: #07172d;
  --theme-surface: rgba(7, 23, 45, 0.94);
  --theme-surface-muted: rgba(7, 23, 45, 0.94);
  --theme-chart-bg: #07172d;
  --theme-header-shell: rgba(7, 23, 45, 0.88);
  --theme-header-status-bg: rgba(7, 23, 45, 0.92);
  --theme-switch-shell: rgba(7, 23, 45, 0.92);
  --theme-switch-track: rgba(7, 23, 45, 0.98);
}

html.wsg-night body,
html.dark-mode body,
body.wsg-night,
body.dark-mode,
html.wsg-night .page-hero,
html.dark-mode .page-hero,
body.wsg-night .page-hero,
body.dark-mode .page-hero,
html.wsg-night .footer,
html.dark-mode .footer,
body.wsg-night .footer,
body.dark-mode .footer {
  background-color: #07172d;
}

html.wsg-night .page-hero::before,
html.dark-mode .page-hero::before,
body.wsg-night .page-hero::before,
body.dark-mode .page-hero::before {
  background: rgba(7, 23, 45, 0.14);
}

html.wsg-night .page-hero::after,
html.dark-mode .page-hero::after,
body.wsg-night .page-hero::after,
body.dark-mode .page-hero::after {
  background: linear-gradient(
    to bottom,
    rgba(7, 23, 45, 0) 0%,
    rgba(7, 23, 45, 0.05) 42%,
    rgba(7, 23, 45, 0.12) 72%,
    #07172d 100%
  );
}

html.wsg-night .nav-links,
html.dark-mode .nav-links,
body.wsg-night .nav-links,
body.dark-mode .nav-links {
  background: rgba(7, 23, 45, 0.46);
}

html.wsg-night .wsg-header-status,
html.dark-mode .wsg-header-status,
body.wsg-night .wsg-header-status,
body.dark-mode .wsg-header-status {
  background: rgba(7, 23, 45, 0.48);
}

html.wsg-night .wsg-theme-switch-wrap,
html.dark-mode .wsg-theme-switch-wrap,
body.wsg-night .wsg-theme-switch-wrap,
body.dark-mode .wsg-theme-switch-wrap {
  background: rgba(7, 23, 45, 0.50);
}

html.wsg-night .footer-fallback-note,
html.dark-mode .footer-fallback-note,
body.wsg-night .footer-fallback-note,
body.dark-mode .footer-fallback-note,
html.wsg-night .footer-center-block,
html.dark-mode .footer-center-block,
body.wsg-night .footer-center-block,
body.dark-mode .footer-center-block,
html.wsg-night .footer-glass-tile,
html.dark-mode .footer-glass-tile,
body.wsg-night .footer-glass-tile,
body.dark-mode .footer-glass-tile,
html.wsg-night .footer-visitor-pill,
html.dark-mode .footer-visitor-pill,
body.wsg-night .footer-visitor-pill,
body.dark-mode .footer-visitor-pill {
  background: rgba(7, 23, 45, 0.92) !important;
}

/* night-unified-blue-final-20260507 */
html.wsg-night,
html.dark-mode,
body.wsg-night,
body.dark-mode {
  --theme-night-base: #07172d;
  --theme-page-bg: var(--theme-night-base);
  --theme-surface: var(--theme-night-base);
  --theme-surface-muted: var(--theme-night-base);
  --theme-chart-bg: var(--theme-night-base);
  --theme-header-shell: var(--theme-night-base);
  --theme-header-status-bg: var(--theme-night-base);
  --theme-switch-shell: var(--theme-night-base);
  --theme-switch-track: var(--theme-night-base);
}

html.wsg-night,
html.dark-mode,
body.wsg-night,
body.dark-mode,
html.wsg-night body,
html.dark-mode body,
body.wsg-night body,
body.dark-mode body,
html.wsg-night main,
html.dark-mode main,
body.wsg-night main,
body.dark-mode main,
html.wsg-night .page-hero,
html.dark-mode .page-hero,
body.wsg-night .page-hero,
body.dark-mode .page-hero,
html.wsg-night .footer,
html.dark-mode .footer,
body.wsg-night .footer,
body.dark-mode .footer {
  background-color: var(--theme-night-base) !important;
}

html.wsg-night .card,
html.dark-mode .card,
body.wsg-night .card,
body.dark-mode .card,
html.wsg-night .chart-card,
html.dark-mode .chart-card,
body.wsg-night .chart-card,
body.dark-mode .chart-card,
html.wsg-night .metric-card,
html.dark-mode .metric-card,
body.wsg-night .metric-card,
body.dark-mode .metric-card,
html.wsg-night .combined-metrics-card,
html.dark-mode .combined-metrics-card,
body.wsg-night .combined-metrics-card,
body.dark-mode .combined-metrics-card,
html.wsg-night .home-main-chart,
html.dark-mode .home-main-chart,
body.wsg-night .home-main-chart,
body.dark-mode .home-main-chart,
html.wsg-night .home-mini-chart,
html.dark-mode .home-mini-chart,
body.wsg-night .home-mini-chart,
body.dark-mode .home-mini-chart,
html.wsg-night .combined-chart-shell,
html.dark-mode .combined-chart-shell,
body.wsg-night .combined-chart-shell,
body.dark-mode .combined-chart-shell,
html.wsg-night .combined-series-controls,
html.dark-mode .combined-series-controls,
body.wsg-night .combined-series-controls,
body.dark-mode .combined-series-controls,
html.wsg-night .combined-stat-card,
html.dark-mode .combined-stat-card,
body.wsg-night .combined-stat-card,
body.dark-mode .combined-stat-card {
  background: var(--theme-night-base) !important;
}

html.wsg-night .page-hero::before,
html.dark-mode .page-hero::before,
body.wsg-night .page-hero::before,
body.dark-mode .page-hero::before {
  background: none !important;
}

html.wsg-night .page-hero::after,
html.dark-mode .page-hero::after,
body.wsg-night .page-hero::after,
body.dark-mode .page-hero::after {
  background: none !important;
}

html.wsg-night main > .page-hero + .section,
html.dark-mode main > .page-hero + .section,
body.wsg-night main > .page-hero + .section,
body.dark-mode main > .page-hero + .section {
  position: relative;
  z-index: 3;
  background-color: var(--theme-night-base) !important;
}

html.wsg-night,
html.dark-mode,
body.wsg-night,
body.dark-mode,
html.wsg-night body,
html.dark-mode body,
body.wsg-night,
body.dark-mode,
html.wsg-night main,
html.dark-mode main,
body.wsg-night main,
body.dark-mode main,
html.wsg-night .section,
html.dark-mode .section,
body.wsg-night .section,
body.dark-mode .section,
html.wsg-night .section.alt > .section-inner,
html.dark-mode .section.alt > .section-inner,
body.wsg-night .section.alt > .section-inner,
body.dark-mode .section.alt > .section-inner,
html.wsg-night .page-hero,
html.dark-mode .page-hero,
body.wsg-night .page-hero,
body.dark-mode .page-hero,
html.wsg-night .footer,
html.dark-mode .footer,
body.wsg-night .footer,
body.dark-mode .footer {
  background-color: var(--theme-night-base) !important;
}

/* night-no-transparency-20260507 */
html.wsg-night,
html.dark-mode,
body.wsg-night,
body.dark-mode {
  --theme-surface: var(--theme-night-base) !important;
  --theme-surface-muted: var(--theme-night-base) !important;
  --theme-header-shell: var(--theme-night-base) !important;
  --theme-header-hover: var(--theme-night-base) !important;
  --theme-header-active: var(--theme-night-base) !important;
  --theme-header-status-bg: var(--theme-night-base) !important;
  --theme-switch-shell: var(--theme-night-base) !important;
  --theme-switch-track: var(--theme-night-base) !important;
  --theme-chart-bg: var(--theme-night-base) !important;
}

html.wsg-night .nav-links,
html.dark-mode .nav-links,
body.wsg-night .nav-links,
body.dark-mode .nav-links,
html.wsg-night .wsg-header-status,
html.dark-mode .wsg-header-status,
body.wsg-night .wsg-header-status,
body.dark-mode .wsg-header-status,
html.wsg-night .wsg-theme-switch-wrap,
html.dark-mode .wsg-theme-switch-wrap,
body.wsg-night .wsg-theme-switch-wrap,
body.dark-mode .wsg-theme-switch-wrap,
html.wsg-night .hero-inner > div:first-child,
html.dark-mode .hero-inner > div:first-child,
body.wsg-night .hero-inner > div:first-child,
body.dark-mode .hero-inner > div:first-child,
html.wsg-night .footer-fallback-note,
html.dark-mode .footer-fallback-note,
body.wsg-night .footer-fallback-note,
body.dark-mode .footer-fallback-note,
html.wsg-night .footer-center-block,
html.dark-mode .footer-center-block,
body.wsg-night .footer-center-block,
body.dark-mode .footer-center-block,
html.wsg-night .footer-glass-tile,
html.dark-mode .footer-glass-tile,
body.wsg-night .footer-glass-tile,
body.dark-mode .footer-glass-tile,
html.wsg-night .footer-visitor-pill,
html.dark-mode .footer-visitor-pill,
body.wsg-night .footer-visitor-pill,
body.dark-mode .footer-visitor-pill,
html.wsg-night .button,
html.dark-mode .button,
body.wsg-night .button,
body.dark-mode .button,
html.wsg-night button,
html.dark-mode button,
body.wsg-night button,
body.dark-mode button,
html.wsg-night input,
html.dark-mode input,
body.wsg-night input,
body.dark-mode input,
html.wsg-night textarea,
html.dark-mode textarea,
body.wsg-night textarea,
body.dark-mode textarea,
html.wsg-night select,
html.dark-mode select,
body.wsg-night select,
body.dark-mode select,
html.wsg-night .combined-chart-shell,
html.dark-mode .combined-chart-shell,
body.wsg-night .combined-chart-shell,
body.dark-mode .combined-chart-shell,
html.wsg-night .combined-series-controls,
html.dark-mode .combined-series-controls,
body.wsg-night .combined-series-controls,
body.dark-mode .combined-series-controls,
html.wsg-night .combined-stat-card,
html.dark-mode .combined-stat-card,
body.wsg-night .combined-stat-card,
body.dark-mode .combined-stat-card,
html.wsg-night .combined-range-tabs,
html.dark-mode .combined-range-tabs,
body.wsg-night .combined-range-tabs,
body.dark-mode .combined-range-tabs,
html.wsg-night .combined-range-tabs button,
html.dark-mode .combined-range-tabs button,
body.wsg-night .combined-range-tabs button,
body.dark-mode .combined-range-tabs button,
html.wsg-night .combined-series-toggle,
html.dark-mode .combined-series-toggle,
body.wsg-night .combined-series-toggle,
body.dark-mode .combined-series-toggle,
html.wsg-night .visitor-chip,
html.dark-mode .visitor-chip,
body.wsg-night .visitor-chip,
body.dark-mode .visitor-chip,
html.wsg-night .back-to-top,
html.dark-mode .back-to-top,
body.wsg-night .back-to-top,
body.dark-mode .back-to-top {
  background: var(--theme-night-base) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  filter: none !important;
}

/* global-milch-card-unify-20260509 */
:root {
  --theme-glass-card-bg: linear-gradient(180deg, rgba(255, 255, 255, 0.62) 0%, rgba(255, 255, 255, 0.34) 100%);
  --theme-glass-card-border: rgba(219, 206, 176, 0.92);
  --theme-glass-card-shadow: 0 24px 58px rgba(34, 82, 70, 0.18), inset 0 1px 0 rgba(255, 255, 255, 0.46);
}

html.wsg-night,
html.dark-mode,
body.wsg-night,
body.dark-mode {
  --theme-glass-card-bg: linear-gradient(180deg, rgba(18, 43, 84, 0.72) 0%, rgba(9, 28, 56, 0.52) 100%);
  --theme-glass-card-border: rgba(140, 170, 210, 0.52);
  --theme-glass-card-shadow: 0 26px 60px rgba(2, 10, 24, 0.38), inset 0 1px 0 rgba(230, 240, 255, 0.16);
}

.card,
.chart-card,
.metric-card,
.combined-metrics-card,
.embed,
.map-stage,
.swiss-map-card,
.hero-inner > div:first-child {
  background: var(--theme-glass-card-bg) !important;
  border-color: var(--theme-glass-card-border) !important;
  box-shadow: var(--theme-glass-card-shadow) !important;
  backdrop-filter: blur(22px) saturate(1.24) !important;
  -webkit-backdrop-filter: blur(22px) saturate(1.24) !important;
}

main .card,
main .chart-card,
main .metric-card,
main .combined-metrics-card,
main .embed,
main .map-stage,
main .swiss-map-card,
main .home-main-chart,
main .home-mini-chart,
main .combined-chart-shell,
main .combined-series-controls,
main .combined-stat-card {
  background: #f9f5ee !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

html.wsg-night main .card,
html.dark-mode main .card,
body.wsg-night main .card,
body.dark-mode main .card,
html.wsg-night main .chart-card,
html.dark-mode main .chart-card,
body.wsg-night main .chart-card,
body.dark-mode main .chart-card,
html.wsg-night main .metric-card,
html.dark-mode main .metric-card,
body.wsg-night main .metric-card,
body.dark-mode main .metric-card,
html.wsg-night main .combined-metrics-card,
html.dark-mode main .combined-metrics-card,
body.wsg-night main .combined-metrics-card,
body.dark-mode main .combined-metrics-card,
html.wsg-night main .embed,
html.dark-mode main .embed,
body.wsg-night main .embed,
body.dark-mode main .embed,
html.wsg-night main .map-stage,
html.dark-mode main .map-stage,
body.wsg-night main .map-stage,
body.dark-mode main .map-stage,
html.wsg-night main .swiss-map-card,
html.dark-mode main .swiss-map-card,
body.wsg-night main .swiss-map-card,
body.dark-mode main .swiss-map-card,
html.wsg-night main .home-main-chart,
html.dark-mode main .home-main-chart,
body.wsg-night main .home-main-chart,
body.dark-mode main .home-main-chart,
html.wsg-night main .home-mini-chart,
html.dark-mode main .home-mini-chart,
body.wsg-night main .home-mini-chart,
body.dark-mode main .home-mini-chart,
html.wsg-night main .combined-chart-shell,
html.dark-mode main .combined-chart-shell,
body.wsg-night main .combined-chart-shell,
body.dark-mode main .combined-chart-shell,
html.wsg-night main .combined-series-controls,
html.dark-mode main .combined-series-controls,
body.wsg-night main .combined-series-controls,
body.dark-mode main .combined-series-controls,
html.wsg-night main .combined-stat-card,
html.dark-mode main .combined-stat-card,
body.wsg-night main .combined-stat-card,
body.dark-mode main .combined-stat-card {
  background: #0b1d36 !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

main .section-head h2,
main .home-24h-card > .home-24h-title,
main .card-title,
main h3 {
  color: #000000 !important;
  text-shadow: none !important;
}

main .note,
main .wx-time,
main p,
main li {
  color: #111111 !important;
  text-shadow: none !important;
}

html.wsg-night main .section-head h2,
html.dark-mode main .section-head h2,
body.wsg-night main .section-head h2,
body.dark-mode main .section-head h2,
html.wsg-night main .home-24h-card > .home-24h-title,
html.dark-mode main .home-24h-card > .home-24h-title,
body.wsg-night main .home-24h-card > .home-24h-title,
body.dark-mode main .home-24h-card > .home-24h-title,
html.wsg-night main .card-title,
html.dark-mode main .card-title,
body.wsg-night main .card-title,
body.dark-mode main .card-title,
html.wsg-night main h3,
html.dark-mode main h3,
body.wsg-night main h3,
body.dark-mode main h3 {
  color: #eef5ff !important;
  text-shadow: none !important;
}

html.wsg-night main .note,
html.dark-mode main .note,
body.wsg-night main .note,
body.dark-mode main .note,
html.wsg-night main .wx-time,
html.dark-mode main .wx-time,
body.wsg-night main .wx-time,
body.dark-mode main .wx-time,
html.wsg-night main p,
html.dark-mode main p,
body.wsg-night main p,
body.dark-mode main p,
html.wsg-night main li,
html.dark-mode main li,
body.wsg-night main li,
body.dark-mode main li {
  color: #d7e6f7;
  text-shadow: none !important;
}

.back-to-top {
  position: fixed !important;
  right: 18px !important;
  bottom: 18px !important;
  z-index: 120 !important;
  display: inline-flex !important;
  visibility: visible !important;
  opacity: 1 !important;
}

body.site-page :is(h1, h2, h3, p, li, label, .note, .wx-time, .card-title, .button, .nav-links a, .nav-dropdown summary, .wsg-header-status-main, .wsg-header-status-meta, .wsg-moon-phase, .wsg-moon-next) {
  color: #000000 !important;
}

html.wsg-night body.site-page :is(h1, h2, h3, p, li, label, .note, .wx-time, .card-title, .button, .nav-links a, .nav-dropdown summary, .wsg-header-status-main, .wsg-header-status-meta, .wsg-moon-phase, .wsg-moon-next),
html.dark-mode body.site-page :is(h1, h2, h3, p, li, label, .note, .wx-time, .card-title, .button, .nav-links a, .nav-dropdown summary, .wsg-header-status-main, .wsg-header-status-meta, .wsg-moon-phase, .wsg-moon-next),
body.wsg-night.site-page :is(h1, h2, h3, p, li, label, .note, .wx-time, .card-title, .button, .nav-links a, .nav-dropdown summary, .wsg-header-status-main, .wsg-header-status-meta, .wsg-moon-phase, .wsg-moon-next),
body.dark-mode.site-page :is(h1, h2, h3, p, li, label, .note, .wx-time, .card-title, .button, .nav-links a, .nav-dropdown summary, .wsg-header-status-main, .wsg-header-status-meta, .wsg-moon-phase, .wsg-moon-next) {
  color: #000000 !important;
}

body.site-page .wx-unit,
body.site-page .home-summary-section [data-home-stat-value] {
  color: #000000 !important;
}

/* speziell gefaerbte Messwerte bewusst nicht ueberschreiben */

html.wsg-night body.site-page :is(h1, h2, h3, p, li, label, .note, .wx-time, .card-title, .button, .nav-links a, .nav-dropdown summary, .wsg-header-status-main, .wsg-header-status-meta, .wsg-moon-phase, .wsg-moon-next, .wx-unit),
html.dark-mode body.site-page :is(h1, h2, h3, p, li, label, .note, .wx-time, .card-title, .button, .nav-links a, .nav-dropdown summary, .wsg-header-status-main, .wsg-header-status-meta, .wsg-moon-phase, .wsg-moon-next, .wx-unit),
body.wsg-night.site-page :is(h1, h2, h3, p, li, label, .note, .wx-time, .card-title, .button, .nav-links a, .nav-dropdown summary, .wsg-header-status-main, .wsg-header-status-meta, .wsg-moon-phase, .wsg-moon-next, .wx-unit),
body.dark-mode.site-page :is(h1, h2, h3, p, li, label, .note, .wx-time, .card-title, .button, .nav-links a, .nav-dropdown summary, .wsg-header-status-main, .wsg-header-status-meta, .wsg-moon-phase, .wsg-moon-next, .wx-unit) {
  color: #ffffff !important;
}

html.wsg-night body.site-page .wx-stat,
html.dark-mode body.site-page .wx-stat,
body.wsg-night.site-page .wx-stat,
body.dark-mode.site-page .wx-stat,
html.wsg-night body.site-page .home-summary-section [data-home-stat],
html.dark-mode body.site-page .home-summary-section [data-home-stat],
body.wsg-night.site-page .home-summary-section [data-home-stat],
body.dark-mode.site-page .home-summary-section [data-home-stat] {
  color: #ffffff !important;
}

html.wsg-night body.site-page .wx-stat .card-title,
html.dark-mode body.site-page .wx-stat .card-title,
body.wsg-night.site-page .wx-stat .card-title,
body.dark-mode.site-page .wx-stat .card-title,
html.wsg-night body.site-page .wx-stat .wx-value,
html.dark-mode body.site-page .wx-stat .wx-value,
body.wsg-night.site-page .wx-stat .wx-value,
body.dark-mode.site-page .wx-stat .wx-value,
html.wsg-night body.site-page .wx-stat .wx-unit,
html.dark-mode body.site-page .wx-stat .wx-unit,
body.wsg-night.site-page .wx-stat .wx-unit,
body.dark-mode.site-page .wx-stat .wx-unit,
html.wsg-night body.site-page .wx-stat .wx-time,
html.dark-mode body.site-page .wx-stat .wx-time,
body.wsg-night.site-page .wx-stat .wx-time,
body.dark-mode.site-page .wx-stat .wx-time,
html.wsg-night body.site-page .home-summary-section [data-home-stat] [data-home-stat-value],
html.dark-mode body.site-page .home-summary-section [data-home-stat] [data-home-stat-value],
body.wsg-night.site-page .home-summary-section [data-home-stat] [data-home-stat-value],
body.dark-mode.site-page .home-summary-section [data-home-stat] [data-home-stat-value],
html.wsg-night body.site-page .home-summary-section [data-home-stat] [data-home-stat-meta],
html.dark-mode body.site-page .home-summary-section [data-home-stat] [data-home-stat-meta],
body.wsg-night.site-page .home-summary-section [data-home-stat] [data-home-stat-meta],
body.dark-mode.site-page .home-summary-section [data-home-stat] [data-home-stat-meta] {
  color: #ffffff !important;
}

body.site-page .wx-stat .wx-unit,
body.site-page .wx-stat .wx-value-wrap > :not(.wx-value),
body.site-page .home-summary-section [data-home-stat] [data-home-stat-value] > :not(strong),
body.site-page .home-summary-section [data-home-stat] [data-home-stat-value] > :not(.wx-value) {
  font-size: clamp(18px, 1.1vw, 20px) !important;
  line-height: 1 !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
}

/* hero-glass-visibility-fix-20260510 */
.hero-inner > div:first-child {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.10) 0%, rgba(255, 255, 255, 0.02) 100%) !important;
  border: 1px solid rgba(255, 255, 255, 0.32) !important;
  box-shadow: 0 16px 36px rgba(24, 54, 88, 0.04), inset 0 1px 0 rgba(255, 255, 255, 0.14) !important;
  backdrop-filter: blur(8px) saturate(1.12) !important;
  -webkit-backdrop-filter: blur(8px) saturate(1.12) !important;
  transform: translateY(calc(clamp(140px, 12vw, 210px) - 150px)) !important;
}

html.wsg-night .hero-inner > div:first-child,
html.dark-mode .hero-inner > div:first-child,
body.wsg-night .hero-inner > div:first-child,
body.dark-mode .hero-inner > div:first-child {
  background: linear-gradient(180deg, rgba(160, 200, 255, 0.04) 0%, rgba(11, 31, 62, 0.01) 100%) !important;
  border: 1px solid rgba(255, 255, 255, 0.32) !important;
  box-shadow: 0 18px 42px rgba(2, 10, 24, 0.08), inset 0 1px 0 rgba(236, 244, 255, 0.05) !important;
  backdrop-filter: blur(6px) saturate(1.08) brightness(1.04) !important;
  -webkit-backdrop-filter: blur(6px) saturate(1.08) brightness(1.04) !important;
  transform: translateY(calc(clamp(140px, 12vw, 210px) - 150px)) !important;
}


.langzeit-radar-block {
  margin-top: 24px;
  padding-top: 10px;
  border-top: 1px solid var(--theme-border);
}

.langzeit-radar-panel {
  display: grid;
  gap: 18px;
}

.radar-stage-shell {
  width: 100%;
  overflow: hidden;
  border-radius: 22px;
  border: 1px solid rgba(148, 160, 176, 0.46);
  background: linear-gradient(180deg, rgba(247, 243, 234, 0.98) 0%, rgba(241, 235, 224, 0.98) 100%);
  box-shadow: none;
}

.radar-stage {
  position: relative;
  width: min(100%, var(--radar-stage-width, 349px));
  aspect-ratio: var(--radar-stage-ratio, 349 / 221);
  margin: 0 auto;
  background: transparent;
}

.radar-stage-time {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 8;
  display: grid;
  gap: 2px;
  padding: 8px 10px;
  border-radius: 12px;
  background: rgba(10, 24, 41, 0.82);
  border: 1px solid rgba(118, 138, 161, 0.65);
  color: #eef4fb;
  pointer-events: none;
}

.radar-stage-time strong {
  font-size: 0.82rem;
  line-height: 1.1;
}

.radar-stage-time span {
  font-size: 0.69rem;
  line-height: 1.1;
  color: #d4e3f6;
}

.radar-hydro-map,
.radar-overlay,
.radar-isobars-fill-map,
.radar-isobars-map,
.radar-outline-map,
.radar-city-dots-map,
.radar-city-labels-map {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.radar-hydro-map {
  z-index: 1;
}

.radar-overlay {
  z-index: 2;
  image-rendering: auto;
  opacity: 0.78;
}

.radar-isobars-fill-map {
  z-index: 3;
  display: none;
  pointer-events: none;
}

.radar-isobars-fill-map {
  opacity: 1;
}

.has-isobars-fill .radar-isobars-fill-map {
  display: block;
}

.radar-isobars-map {
  z-index: 4;
  display: none;
  pointer-events: none;
}

[data-radar-root].has-isobars .radar-isobars-map {
  display: block;
}

.radar-outline-map {
  z-index: 5;
  pointer-events: none;
}

.radar-city-dots-map {
  z-index: 6;
  pointer-events: none;
}

.radar-city-labels-map {
  z-index: 7;
  pointer-events: none;
}

[data-radar-root].radar-labels-hidden .radar-city-labels-map {
  display: none;
}

.radar-stage-legend {
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 12px;
  z-index: 8;
  display: flex;
  justify-content: center;
  pointer-events: none;
}

.radar-stage-legend-title {
  text-align: center;
  font-size: 0.74rem;
  font-weight: 800;
  line-height: 1.2;
  color: #e6eef7;
}

.radar-stage-legend-scale {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: center;
}

.radar-stage-legend-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-width: 58px;
  padding: 4px 7px;
  border-radius: 999px;
  background: rgba(13, 30, 51, 0.84);
  border: 1px solid rgba(121, 142, 166, 0.7);
  font-size: 0.73rem;
  font-weight: 800;
  line-height: 1;
  color: #eef4fb;
}

.radar-stage-legend-color {
  width: 11px;
  height: 11px;
  border-radius: 50%;
  border: 1px solid rgba(31, 41, 55, 0.2);
  flex: 0 0 auto;
}

.radar-toolbar {
  display: grid;
  grid-template-columns: auto minmax(220px, 1fr) minmax(220px, 320px) auto;
  gap: 14px;
  align-items: end;
}

.radar-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.radar-slider-wrap,
.radar-select-wrap {
  display: grid;
  gap: 8px;
}

.radar-slider-shell {
  position: relative;
}

.radar-slider-meta {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--theme-note);
}

.radar-now-marker {
  position: absolute;
  top: 0;
  bottom: 0;
  left: var(--radar-now-marker-pos, 0%);
  width: 0;
  pointer-events: none;
}

.radar-now-marker::before {
  content: "";
  position: absolute;
  top: -2px;
  bottom: -2px;
  left: -1px;
  width: 2px;
  border-radius: 999px;
  background: rgba(244, 208, 118, 0.96);
  box-shadow: 0 0 0 1px rgba(12, 27, 43, 0.34);
}

.radar-now-marker::after {
  content: "Jetzt";
  position: absolute;
  top: -18px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 0.64rem;
  font-weight: 800;
  line-height: 1;
  color: #d9b15f;
  white-space: nowrap;
}

.radar-slider-wrap span,
.radar-select-wrap span {
  font-size: var(--fs-small);
  font-weight: 800;
}

.radar-slider-wrap input,
.radar-select-wrap select {
  width: 100%;
}

.radar-layer-toggles {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  justify-content: flex-end;
}

.radar-toggle {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 40px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(11, 28, 47, 0.84);
  border: 1px solid rgba(118, 138, 161, 0.65);
  color: #eef4fb;
  font-size: 0.78rem;
  font-weight: 800;
}

.radar-toggle input {
  margin: 0;
  accent-color: #4aa2ff;
}

.radar-current {
  display: grid;
  gap: 4px;
  padding: 14px 16px;
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(247, 250, 252, 0.92) 0%, rgba(238, 244, 248, 0.9) 100%);
  border: 1px solid rgba(154, 177, 201, 0.34);
}

.radar-mode-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.radar-mode-badge.is-observed {
  background: rgba(74, 125, 184, 0.12);
  color: #315d8d;
}

.radar-mode-badge.is-forecast {
  background: rgba(189, 126, 49, 0.12);
  color: #8c5a19;
}

.radar-current strong {
  font-size: 1rem;
}

.radar-status[data-tone="ok"] {
  color: #244f3a !important;
}

.radar-status[data-tone="forecast"] {
  color: #9b4d0b !important;
}

.radar-status[data-tone="error"] {
  color: #8a2f2f !important;
}

.radar-meta {
  display: grid;
  gap: 8px;
}

.radar-meta-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px 16px;
}

.radar-attribution {
  margin: 0;
  color: var(--theme-note) !important;
  font-size: var(--fs-small);
}

.radar-legend {
  display: none;
  gap: 10px;
  padding: 16px;
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(247, 250, 252, 0.92) 0%, rgba(238, 244, 248, 0.9) 100%);
  border: 1px solid rgba(154, 177, 201, 0.34);
}

.radar-legend-title {
  font-size: var(--fs-small);
  font-weight: 800;
}

.radar-legend-scale {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.radar-legend-chip {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid rgba(177, 194, 214, 0.52);
  font-size: var(--fs-small);
  font-weight: 700;
}

.radar-legend-color {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 1px solid rgba(0, 0, 0, 0.12);
}

[data-radar-root][data-radar-mode="forecast"] .radar-stage-shell {
  border-color: rgba(193, 136, 67, 0.44);
  box-shadow: none;
}

[data-radar-root][data-radar-mode="forecast"] .radar-current,
[data-radar-root][data-radar-mode="forecast"] .radar-legend {
  background: linear-gradient(180deg, rgba(251, 248, 242, 0.94) 0%, rgba(245, 239, 230, 0.94) 100%);
  border-color: rgba(193, 136, 67, 0.28);
}

html.wsg-night .radar-stage-shell,
html.dark-mode .radar-stage-shell,
body.wsg-night .radar-stage-shell,
body.dark-mode .radar-stage-shell,
html.wsg-night .radar-stage,
html.dark-mode .radar-stage,
body.wsg-night .radar-stage,
body.dark-mode .radar-stage {
  background: transparent;
}

html.wsg-night .radar-stage-shell,
html.dark-mode .radar-stage-shell,
body.wsg-night .radar-stage-shell,
body.dark-mode .radar-stage-shell {
  background: linear-gradient(180deg, rgba(14, 31, 53, 0.98) 0%, rgba(13, 35, 61, 0.98) 100%);
}

html.wsg-night .radar-outline-map,
html.dark-mode .radar-outline-map,
body.wsg-night .radar-outline-map,
body.dark-mode .radar-outline-map {
  filter: brightness(0) invert(1);
  opacity: 0.98;
}

html.wsg-night .radar-hydro-map,
html.dark-mode .radar-hydro-map,
body.wsg-night .radar-hydro-map,
body.dark-mode .radar-hydro-map {
  opacity: 1;
}

html.wsg-night .radar-toggle,
html.dark-mode .radar-toggle,
body.wsg-night .radar-toggle,
body.dark-mode .radar-toggle {
  background: rgba(10, 24, 41, 0.86);
  border-color: rgba(110, 131, 154, 0.64);
  color: #f3f7fb;
}

html.wsg-night .radar-stage-legend-title,
html.dark-mode .radar-stage-legend-title,
body.wsg-night .radar-stage-legend-title,
body.dark-mode .radar-stage-legend-title {
  color: #e6edf5;
}

html.wsg-night .radar-stage-legend-chip,
html.dark-mode .radar-stage-legend-chip,
body.wsg-night .radar-stage-legend-chip,
body.dark-mode .radar-stage-legend-chip {
  background: rgba(18, 31, 45, 0.9);
  border-color: rgba(95, 115, 136, 0.7);
  color: #f3f7fb;
}

html.wsg-night .radar-legend-chip,
html.dark-mode .radar-legend-chip,
body.wsg-night .radar-legend-chip,
body.dark-mode .radar-legend-chip {
  background: rgba(15, 29, 48, 0.82);
  border-color: rgba(96, 124, 159, 0.34);
}

html.wsg-night [data-radar-root][data-radar-mode="forecast"] .radar-stage-shell,
html.dark-mode [data-radar-root][data-radar-mode="forecast"] .radar-stage-shell,
body.wsg-night [data-radar-root][data-radar-mode="forecast"] .radar-stage-shell,
body.dark-mode [data-radar-root][data-radar-mode="forecast"] .radar-stage-shell {
  border-color: rgba(201, 145, 79, 0.42);
  box-shadow: none;
}

html.wsg-night [data-radar-root][data-radar-mode="forecast"] .radar-current,
html.dark-mode [data-radar-root][data-radar-mode="forecast"] .radar-current,
body.wsg-night [data-radar-root][data-radar-mode="forecast"] .radar-current,
body.dark-mode [data-radar-root][data-radar-mode="forecast"] .radar-current,
html.wsg-night [data-radar-root][data-radar-mode="forecast"] .radar-legend,
html.dark-mode [data-radar-root][data-radar-mode="forecast"] .radar-legend,
body.wsg-night [data-radar-root][data-radar-mode="forecast"] .radar-legend,
body.dark-mode [data-radar-root][data-radar-mode="forecast"] .radar-legend {
  background: linear-gradient(180deg, rgba(28, 24, 19, 0.88) 0%, rgba(22, 19, 16, 0.9) 100%);
}

html.wsg-night .radar-current,
html.dark-mode .radar-current,
body.wsg-night .radar-current,
body.dark-mode .radar-current,
html.wsg-night .radar-legend,
html.dark-mode .radar-legend,
body.wsg-night .radar-legend,
body.dark-mode .radar-legend {
  background: linear-gradient(180deg, rgba(14, 24, 38, 0.86) 0%, rgba(10, 19, 31, 0.9) 100%);
  border-color: rgba(92, 121, 154, 0.28);
}

@media (max-width: 900px) {
  .radar-toolbar {
    grid-template-columns: 1fr;
  }

  .radar-meta-grid {
    grid-template-columns: 1fr;
  }

  .radar-stage-legend {
    left: 10px;
    right: 10px;
    bottom: 10px;
  }

  .radar-stage-legend-title {
    font-size: 0.68rem;
  }

  .radar-stage-legend-scale {
    gap: 4px;
  }

  .radar-stage-legend-chip {
    min-width: 50px;
    padding: 4px 6px;
    font-size: 0.67rem;
  }

  .radar-stage {
    aspect-ratio: var(--radar-stage-ratio, 349 / 221);
  }
}
