/**
 * gw-webcams — Dashboard-Styles ([gw_webcams_dashboard]).
 *
 * Eigenes Stylesheet für das server-gerenderte „Seenland-Dashboard". Baut auf
 * gw-webcams.css auf (geteilte Tile-/Badge-/Credit-/Status-Styles). Marken-Werte
 * als `var(--awb-…, #hex)` (Avada-Erbe, Fallback = meinSeenland-CI).
 *
 * Mobile-first; Touch-Ziele ≥ 44px; eckige Cards (radius 0), Pills/Buttons 2px,
 * Formfelder 6px, fast schattenlos.
 */

.gw-webcams-dashboard {
	--gw-board-max-width: 1248px;
	box-sizing: border-box;
	max-width: var(--gw-board-max-width, 1248px);
	margin: 1.5em auto;
	padding-inline: 1rem;
}

/* Avada-H1 auf Dashboard-Seiten zähmen (sonst ~64px, frisst mobil die Seite). */
.post-content:has(.gw-webcams-dashboard) > h1 {
	overflow-wrap: break-word;
	line-height: 1.15;
}

/* --- Hero „Live im Fränkischen Seenland" ---------------------------------- */

.gw-hero {
	display: grid;
	grid-template-columns: minmax(0, 1.75fr) minmax(300px, 1fr);
	gap: 1.75rem;
	margin: 0 0 2.25rem;
	padding: 1.75rem;
	color: #fff;
	background:
		radial-gradient(130% 150% at 100% 0%, rgba(1, 112, 142, 0.6) 0%, rgba(1, 112, 142, 0) 55%),
		radial-gradient(90% 120% at 0% 100%, rgba(54, 209, 122, 0.16) 0%, rgba(54, 209, 122, 0) 50%),
		linear-gradient(145deg, var(--gw-brand) 0%, #102e44 58%, #0a1f2f 100%);
	border-radius: 18px;
	box-shadow: 0 30px 60px -34px rgba(12, 35, 52, 0.78);
	overflow: hidden;
}

.gw-hero--night {
	grid-template-columns: 1fr;
	gap: 1.25rem;
}

/* Eyebrow + Live-Dot. */
.gw-hero-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	margin: 0 0 0.85rem;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.86);
}

.gw-hero-live-dot {
	width: 0.55rem;
	height: 0.55rem;
	border-radius: 50%;
	background: #36d17a;
	box-shadow: 0 0 0 0 rgba(54, 209, 122, 0.7);
	animation: gw-webcam-livepulse 1.8s ease-in-out infinite;
}

@media (prefers-reduced-motion: reduce) {
	.gw-hero-live-dot {
		animation: none;
	}
}

/* „Bild des Augenblicks" (großes, kinematisches Live-Bild). */
.gw-hero-featured {
	margin: 0;
	display: flex;
	flex-direction: column;
	border-radius: 14px;
	overflow: hidden;
	background: rgba(0, 0, 0, 0.28);
	box-shadow: 0 22px 44px -24px rgba(0, 0, 0, 0.8);
}

.gw-hero-figure {
	position: relative;
	display: block;
	aspect-ratio: 16 / 9;
	overflow: hidden;
}

.gw-hero-img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.6s cubic-bezier(0.22, 0.61, 0.36, 1);
	will-change: transform;
}

.gw-hero-figure:hover .gw-hero-img,
.gw-hero-figure:focus-visible .gw-hero-img {
	transform: scale(1.04);
}

.gw-hero-figure::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(8, 20, 28, 0.55) 0%, rgba(8, 20, 28, 0) 40%);
	pointer-events: none;
}

.gw-hero-badge {
	position: absolute;
	top: 0.85rem;
	left: 0.85rem;
	z-index: 2;
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.3rem 0.75rem;
	font-size: 0.66rem;
	font-weight: 800;
	letter-spacing: 0.09em;
	text-transform: uppercase;
	color: #0c2334;
	background: #fff;
	border-radius: 999px;
	box-shadow: 0 6px 16px -8px rgba(0, 0, 0, 0.6);
}

.gw-hero-badge::before {
	content: "";
	width: 0.5rem;
	height: 0.5rem;
	border-radius: 50%;
	background: #ff4d4d;
	box-shadow: 0 0 0 0 rgba(255, 77, 77, 0.6);
	animation: gw-webcam-livepulse 1.8s ease-in-out infinite;
}

@media (prefers-reduced-motion: reduce) {
	.gw-hero-img {
		transition: none;
	}
	.gw-hero-badge::before {
		animation: none;
	}
}

.gw-hero-chip-row {
	position: absolute;
	top: 0.85rem;
	right: 0.85rem;
	z-index: 2;
}

.gw-hero-chip-weather {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.34rem 0.75rem;
	font-size: 0.9rem;
	font-weight: 700;
	color: #fff;
	background: var(--gw-glass-strong, rgba(8, 20, 28, 0.7));
	backdrop-filter: blur(7px) saturate(1.2);
	-webkit-backdrop-filter: blur(7px) saturate(1.2);
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: 999px;
	box-shadow: 0 4px 14px -8px rgba(0, 0, 0, 0.7);
}

.gw-hero-caption {
	display: flex;
	flex-wrap: wrap;
	gap: 0.2rem 0.85rem;
	align-items: baseline;
	padding: 0.85rem 1.05rem 1rem;
}

.gw-hero-kicker {
	flex: 0 0 100%;
	font-size: 0.68rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--awb-color6, #5fd0e8);
	color: color-mix(in srgb, var(--gw-cta, #01708e) 40%, #bfe9f3);
}

.gw-hero-place {
	font-size: 1.45rem;
	font-weight: 700;
	color: #fff;
}

.gw-hero-credit {
	margin-left: auto;
	font-size: 0.7rem;
	color: rgba(255, 255, 255, 0.72);
	text-decoration: none;
}

a.gw-hero-credit:hover,
a.gw-hero-credit:focus {
	color: #fff;
	text-decoration: underline;
}

/* Antwort-Chip-Spalte. */
.gw-hero-aside {
	display: flex;
	flex-direction: column;
	justify-content: center;
	min-width: 0;
}

.gw-hero-chips {
	display: flex;
	flex-direction: column;
	gap: 0.55rem;
}

.gw-hero-chip {
	display: flex;
	align-items: center;
	gap: 0.7rem;
	min-height: 44px;
	padding: 0.55rem 0.85rem;
	color: #fff;
	text-decoration: none;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.14);
	border-left: 3px solid var(--gw-cta, #01708e);
	border-radius: 6px;
	transition: background 0.16s ease, transform 0.16s ease;
}

a.gw-hero-chip:hover,
a.gw-hero-chip:focus {
	background: rgba(255, 255, 255, 0.16);
	transform: translateX(2px);
}

.gw-hero-chip--sun {
	border-left-color: #f0b54b;
}

.gw-hero-chip-icon {
	font-size: 1.3rem;
	line-height: 1;
}

.gw-hero-chip-body {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.gw-hero-chip-label {
	font-size: 0.66rem;
	font-weight: 700;
	letter-spacing: 0.07em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.72);
}

.gw-hero-chip-value {
	font-size: 0.98rem;
	font-weight: 600;
	color: #fff;
	overflow-wrap: anywhere;
}

.gw-hero-chip-num {
	font-variant-numeric: tabular-nums;
	color: var(--gw-cta, #01708e);
	color: color-mix(in srgb, var(--gw-cta, #01708e) 35%, #cfeef6);
}

/* Nacht-Panel. */
.gw-hero-night {
	margin: 0 0 1.1rem;
}

.gw-hero-moon {
	font-size: 2rem;
	line-height: 1;
}

.gw-hero-night-title {
	margin: 0.35rem 0 0.5rem !important;
	font-size: 1.6rem !important;
	font-weight: 600 !important;
	line-height: 1.15 !important;
	color: #fff !important;
}

.gw-hero-night-line {
	margin: 0.15rem 0;
	font-size: 0.95rem;
	color: rgba(255, 255, 255, 0.82);
}

.gw-hero-night-sunrise {
	font-weight: 700;
	color: #fff;
}

@media (max-width: 760px) {
	.gw-hero {
		grid-template-columns: 1fr;
		padding: 1.1rem;
	}
}

/* --- Filterleiste --------------------------------------------------------- */

.gw-webcams-filter {
	margin: 0 0 1.5rem;
	padding: 1.5rem 1.75rem;
	background: var(--gw-panel);
	border: 1px solid var(--gw-border);
	border-radius: 0;
}

.gw-webcams-filter-details {
	margin: 0;
}

.gw-webcams-filter-toggle {
	display: none;
}

@media (min-width: 641px) {
	.gw-webcams-filter-details > .gw-webcams-filter-inner {
		display: block !important;
	}

	.gw-webcams-filter-details::details-content {
		content-visibility: visible !important;
	}
}

.gw-webcams-filter-row {
	display: flex;
	flex-wrap: wrap;
	gap: 1.25rem 2rem;
	align-items: flex-start;
}

.gw-webcams-field {
	min-width: 12rem;
	margin: 0;
	padding: 0;
	border: 0;
}

.gw-webcams-field--toggles {
	flex: 1 1 18rem;
}

.gw-webcams-label {
	display: block;
	margin: 0 0 0.5rem;
	padding: 0;
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--gw-brand);
}

.gw-webcams-field select {
	width: 100%;
	min-height: 44px;
	padding: 0.55rem 0.7rem;
	font: inherit;
	color: var(--gw-ink);
	background: var(--gw-card);
	border: 1px solid var(--gw-border);
	border-radius: var(--gw-form-radius);
}

.gw-webcams-checks {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 1.25rem;
}

.gw-webcams-check {
	display: inline-flex;
	gap: 0.45rem;
	align-items: center;
	min-height: 44px;
	font-size: 0.95rem;
	color: var(--gw-ink);
	cursor: pointer;
}

.gw-webcams-check input[type="checkbox"] {
	width: 1.1rem;
	height: 1.1rem;
	margin: 0;
	accent-color: var(--gw-cta);
}

.gw-webcams-searchrow {
	display: flex;
	margin-top: 1.25rem;
}

.gw-webcams-submit {
	min-height: 44px;
	padding: 0.6rem 1.8rem;
	font: inherit;
	font-weight: 600;
	letter-spacing: 0.02em;
	color: #fff;
	background: var(--gw-cta);
	border: 0;
	border-radius: 2px;
	cursor: pointer;
	transition: background 0.16s ease;
}

.gw-webcams-submit:hover,
.gw-webcams-submit:focus {
	background: var(--gw-cta-hover);
}

/* --- Meta-Zeile: Umschalter + Trefferzähler ------------------------------- */

.gw-webcams-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem 1.5rem;
	align-items: center;
	justify-content: space-between;
	margin: 0 0 1.25rem;
	padding: 0 0 1rem;
	border-bottom: 1px solid var(--gw-border);
}

.gw-webcams-count {
	margin: 0;
	font-size: 0.9rem;
	color: var(--gw-ink-soft);
}

/* Ansicht-Umschalter Liste | Karte (echte <a>-Links). */
.gw-webcams-viewtoggle {
	display: inline-flex;
	border: 1px solid var(--gw-border);
	border-radius: 2px;
	overflow: hidden;
}

.gw-webcams-viewtoggle-link {
	min-height: 44px;
	display: inline-flex;
	align-items: center;
	padding: 0.45rem 1.1rem;
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--gw-cta);
	text-decoration: none;
	background: var(--gw-card);
	transition: background 0.16s ease, color 0.16s ease;
}

.gw-webcams-viewtoggle-link + .gw-webcams-viewtoggle-link {
	border-left: 1px solid var(--gw-border);
}

.gw-webcams-viewtoggle-link:hover,
.gw-webcams-viewtoggle-link:focus {
	color: #fff;
	background: var(--gw-cta-hover);
}

.gw-webcams-viewtoggle-link.is-active,
.gw-webcams-viewtoggle-link[aria-current="true"] {
	color: #fff;
	background: var(--gw-cta);
}

/* --- Karten-Ansicht (Leaflet, lazy) --------------------------------------- */

.gw-webcams-map {
	margin: 0 0 1.5rem;
	border: 1px solid var(--gw-border);
	border-radius: 0;
	background: var(--gw-panel);
}

.gw-webcams-map-canvas {
	width: 100%;
	height: 460px;
}

.gw-webcams-map-notice {
	margin: 0;
	padding: 1.1rem 1.25rem;
	font-size: 0.9rem;
	color: var(--gw-ink-soft);
}

.gw-webcams-map-popup-thumb {
	display: block;
	width: 100%;
	height: 96px;
	margin: 0 0 0.45rem;
	object-fit: cover;
	border-radius: 4px;
}

.gw-webcams-map-popup-title {
	display: block;
	margin-bottom: 0.2rem;
	font-weight: 700;
	color: var(--gw-cta);
	text-decoration: none;
}

.gw-webcams-map-popup-title:hover,
.gw-webcams-map-popup-title:focus {
	text-decoration: underline;
}

.gw-webcams-map-popup-see {
	margin: 0 0 0.25rem;
	font-size: 0.8rem;
	color: var(--gw-ink-soft);
}

.gw-webcams-map-popup-data {
	margin: 0;
	font-size: 0.82rem;
	color: var(--gw-ink);
}

/* aria-busy: dezentes Ausgrauen während des fetch()-Austauschs. */
.gw-webcams-results[aria-busy="true"] {
	opacity: 0.55;
	transition: opacity 0.12s ease;
}

/* --- Ort-Sektionen -------------------------------------------------------- */

.gw-webcams-ort {
	margin: 0 0 3rem;
	scroll-margin-top: 1rem;
}

/* Eleganter Sektions-Kopf: Titelzeile (Ort + See) über kompaktem Daten-Streifen
 * + deterministischem Einzeiler. */
.gw-webcams-ort-head {
	margin: 0 0 1.25rem;
	padding: 0 0 0.85rem;
	border-bottom: 2px solid color-mix(in srgb, var(--gw-brand) 30%, transparent);
}

.gw-webcams-ort-headline {
	display: flex;
	flex-wrap: wrap;
	gap: 0.2rem 0.85rem;
	align-items: baseline;
	min-width: 0;
}

.gw-webcams-ort-title {
	margin: 0;
	/* !important: gegen Avadas h2-Typo. */
	font-size: 1.7rem !important;
	font-weight: 500 !important;
	line-height: 1.15 !important;
	color: var(--gw-brand) !important;
}

.gw-webcams-ort-icon {
	font-size: 1.25rem;
}

.gw-webcams-ort-see {
	font-size: 0.82rem;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--gw-cta);
}

/* Kompakter Daten-Streifen unter dem Titel (temp/gefühlt/Wasser/Bade-Badge). */
.gw-webcams-ort-data {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 1.1rem;
	align-items: center;
	margin: 0.7rem 0 0;
}

.gw-webcams-ort-data .gw-webcam-data {
	margin: 0;
	padding: 0.28rem 0.7rem;
	background: var(--gw-panel);
	border: 1px solid var(--gw-border);
	border-radius: 999px;
	font-size: 0.86rem;
}

.gw-webcams-ort-data .gw-webcam-data--missing {
	background: transparent;
	border-color: transparent;
	padding-inline: 0;
}

/* Deterministischer Ort-Einzeiler (Contract A). */
.gw-webcams-ort-summary {
	margin: 0.85rem 0 0;
	font-size: 1.05rem;
	line-height: 1.5;
	color: var(--gw-ink);
}

.gw-webcams-ort-freshness {
	margin: 0.5rem 0 0;
}

/* Cam-lose Daten-Card: geschmackvoll, ohne leere Bildfläche. */
.gw-webcams-ort--dataonly {
	padding: 1.4rem 1.6rem 1.5rem;
	margin-bottom: 2rem;
	background:
		linear-gradient(135deg, color-mix(in srgb, var(--gw-cta) 5%, var(--gw-panel)) 0%, var(--gw-panel) 60%);
	border: 1px solid var(--gw-border);
	border-left: 4px solid var(--gw-cta);
	border-radius: var(--gw-card-radius);
	box-shadow: var(--gw-shadow-soft);
}

.gw-webcams-ort--dataonly .gw-webcams-ort-head {
	margin-bottom: 0;
	padding-bottom: 0;
	border-bottom: 0;
}

.gw-webcams-ort--dataonly .gw-webcams-ort-summary {
	color: var(--gw-ink-soft);
}

/* --- Cam-Kachelgrid (große Feature-Cards) --------------------------------- */

/* Füllt die Desktop-Breite mit großen, bild-zentrierten Cards:
 * auto-fit minmax(380px,1fr) → 2–3 pro Reihe auf breitem Desktop. Bei genau einer
 * Cam würde auto-fit zwar ohnehin eine volle Spalte ergeben; die :has-Single-Regel
 * unten macht das robust explizit (keine schmale, einsame Kachel). */
.gw-webcams-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(380px, 1fr));
	gap: 1.75rem;
}

/* Genau EINE Cam im Ort: volle Feature-Card statt einer schmalen Spalte. */
.gw-webcams-grid:has(> .gw-webcam-tile:only-child) {
	grid-template-columns: 1fr;
}

.gw-webcam-tile {
	position: relative;
	display: flex;
	flex-direction: column;
	overflow: hidden;
	background: var(--gw-card);
	border: 1px solid var(--gw-border);
	border-radius: var(--gw-card-radius);
	box-shadow: var(--gw-shadow-soft);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

/* „Stretched-Link"-Muster: der Titel-Link spannt sich unsichtbar über die ganze
 * Card (::after), sodass die GESAMTE Card ein CTA zur Detailseite ist — ohne
 * verschachtelte <a> (der Pflicht-Credit im Bild bleibt eigenständig klickbar). */
.gw-webcam-tile-link {
	color: inherit;
	text-decoration: none;
	outline: none;
}

.gw-webcam-tile--image .gw-webcam-tile-link::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 4;
	border-radius: var(--gw-card-radius);
}

/* Anbieter-Credit (Pflicht, ADR-011) liegt ÜBER dem Stretched-Link, bleibt klickbar. */
.gw-webcam-tile--image .gw-webcam-overlay-credit {
	z-index: 5;
}

/* Image-forward Card: hebt sich beim Hover/Fokus ab + Bild zoomt sanft. */
.gw-webcam-tile--image:hover,
.gw-webcam-tile--image:focus-within {
	transform: translateY(-3px);
	box-shadow: var(--gw-shadow-lift);
	border-color: color-mix(in srgb, var(--gw-cta) 35%, var(--gw-border));
}

.gw-webcam-tile--image:hover .gw-webcam-img,
.gw-webcam-tile--image:focus-within .gw-webcam-img {
	transform: scale(1.045);
}

/* Sichtbarer Fokus-Ring für Tastatur-Navigation (a11y): am Card-Rahmen. */
.gw-webcam-tile--image:focus-within {
	outline: 3px solid var(--gw-cta);
	outline-offset: 2px;
}

.gw-webcam-tile-link:focus-visible {
	outline: none;
}

@media (prefers-reduced-motion: reduce) {
	.gw-webcam-tile,
	.gw-webcam-tile--image:hover .gw-webcam-img,
	.gw-webcam-tile--image:focus-within .gw-webcam-img {
		transform: none;
	}
}

.gw-webcam-tile .gw-webcam-media {
	margin: 0;
	border-radius: 0;
}

/* Das Live-Bild ist der Card-Held: deutlich größer als zuvor. */
.gw-webcam-tile--image .gw-webcam-media--image {
	min-height: 240px;
}

.gw-webcam-tile-body {
	display: flex;
	flex: 1 1 auto;
	flex-direction: column;
	gap: 0.35rem;
	padding: 0.85rem 1.05rem 1rem;
	min-width: 0;
}

.gw-webcam-tile-heading {
	display: flex;
	flex-wrap: wrap;
	gap: 0.3rem 0.7rem;
	align-items: baseline;
	justify-content: space-between;
}

.gw-webcam-tile-title {
	margin: 0;
	/* !important: gegen Avadas h3-Typo. */
	font-size: 1.18rem !important;
	font-weight: 600 !important;
	line-height: 1.3 !important;
	color: var(--gw-ink);
}

.gw-webcam-tile-title a {
	color: var(--gw-ink);
	text-decoration: none;
}

.gw-webcam-tile-title a:hover,
.gw-webcam-tile-title a:focus {
	color: var(--gw-cta);
}

.gw-webcam-tile-cat {
	display: inline-flex;
	align-items: center;
	padding: 0.18rem 0.6rem;
	font-size: 0.66rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--gw-cta);
	background: color-mix(in srgb, var(--gw-cta) 10%, transparent);
	border-radius: 999px;
}

/* „Zeitraffer & Details →"-Affordanz: ruhend dezent, beim Hover/Fokus betont. */
.gw-webcam-tile-cta {
	margin-top: 0.15rem;
	font-size: 0.82rem;
	font-weight: 700;
	letter-spacing: 0.01em;
	color: var(--gw-cta);
	opacity: 0.7;
	transform: translateX(0);
	transition: transform 0.2s ease, opacity 0.2s ease;
}

.gw-webcam-tile--image:hover .gw-webcam-tile-cta,
.gw-webcam-tile--image:focus-within .gw-webcam-tile-cta {
	opacity: 1;
	transform: translateX(3px);
}

.gw-webcam-tile-see {
	margin: 0;
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--gw-cta);
}

/* Nicht-Bild-Cards (Consent/Link-out) behalten den Inline-Credit. */
.gw-webcam-tile .gw-webcam-credit {
	margin-top: auto;
	padding-top: 0.5rem;
}

@media (prefers-reduced-motion: reduce) {
	.gw-webcam-tile-cta {
		transition: none;
	}
}

/* --- Skeleton / Lade-Zustand ---------------------------------------------- */

/* Vor dem Lazy-Load (data-src noch nicht geladen) UND während des Ladens. */
.gw-webcam-tile--skeleton .gw-webcam-media,
.gw-webcam-img[data-src][data-gw-loading="1"],
.gw-webcam-img[data-src]:not([src*="://"]):not([data-gw-loading]) {
	background:
		linear-gradient(
			90deg,
			var(--gw-badge) 25%,
			#e9eaee 37%,
			var(--gw-badge) 63%
		);
	background-size: 400% 100%;
	animation: gw-webcam-shimmer 1.4s ease infinite;
}

@keyframes gw-webcam-shimmer {
	0% {
		background-position: 100% 0;
	}
	100% {
		background-position: -100% 0;
	}
}

@media (prefers-reduced-motion: reduce) {
	.gw-webcam-tile--skeleton .gw-webcam-media,
	.gw-webcam-img[data-src][data-gw-loading="1"],
	.gw-webcam-img[data-src]:not([src*="://"]):not([data-gw-loading]) {
		animation: none;
	}
}

/* Stale-/Offline-Kacheln dezent kennzeichnen. */
.gw-webcam-tile--stale .gw-webcam-img {
	filter: saturate(0.85);
}

.gw-webcam-tile--offline .gw-webcam-media--image::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 2;
	pointer-events: none;
	background: rgba(20, 22, 23, 0.35);
}

.gw-webcams-empty {
	margin: 2rem 0;
	font-style: italic;
	color: var(--gw-ink-soft);
}

/* --- Responsive ----------------------------------------------------------- */

@media (max-width: 640px) {
	.gw-webcams-dashboard {
		padding-inline: 0.85rem;
	}

	.post-content:has(.gw-webcams-dashboard) > h1 {
		font-size: 2rem !important;
		margin-bottom: 0.5rem;
	}

	/* Filter eingeklappt als Toggle-Button (Cams sofort sichtbar). */
	.gw-webcams-filter {
		padding: 0.55rem 0.6rem;
		margin-bottom: 1.25rem;
	}

	.gw-webcams-filter-toggle {
		display: flex;
		align-items: center;
		justify-content: space-between;
		gap: 0.5rem;
		min-height: 44px;
		list-style: none;
		cursor: pointer;
		padding: 0.8rem 0.95rem;
		font-weight: 600;
		letter-spacing: 0.02em;
		color: #fff;
		background: var(--gw-cta);
		border-radius: 2px;
	}

	.gw-webcams-filter-toggle::-webkit-details-marker {
		display: none;
	}

	.gw-webcams-filter-toggle::after {
		content: "▾";
		font-size: 0.9em;
		transition: transform 0.15s ease;
	}

	.gw-webcams-filter-details[open] .gw-webcams-filter-toggle::after {
		transform: rotate(180deg);
	}

	.gw-webcams-filter-inner {
		padding-top: 1rem;
	}

	.gw-webcams-field,
	.gw-webcams-field--toggles {
		flex: 1 1 100%;
		min-width: 0;
	}

	.gw-webcams-submit {
		width: 100%;
		padding-block: 0.85rem;
	}

	/* Meta-Zeile: Zähler oben, Umschalter volle Breite darunter. */
	.gw-webcams-meta {
		flex-direction: column-reverse;
		align-items: stretch;
		gap: 0.75rem;
	}

	.gw-webcams-viewtoggle {
		width: 100%;
	}

	.gw-webcams-viewtoggle-link {
		flex: 1 1 0;
		justify-content: center;
		text-align: center;
	}

	.gw-webcams-ort-title {
		font-size: 1.4rem !important;
	}

	/* Kacheln einspaltig — das große Bild bleibt der Held. */
	.gw-webcams-grid,
	.gw-webcams-grid:has(> .gw-webcam-tile:only-child) {
		grid-template-columns: 1fr;
		gap: 1.25rem;
	}

	.gw-webcam-tile--image .gw-webcam-media--image {
		min-height: 0;
	}

	/* Auf Mobil ist die CTA-Affordanz immer sichtbar (kein Hover). */
	.gw-webcam-tile-cta {
		opacity: 1;
	}

	.gw-webcams-map-canvas {
		height: 340px;
	}
}
