/* =====================================================================
   GCWW Platzstatus & News – Frontend
   Farben zentral als CSS-Variablen, einfach anpassbar.
   ===================================================================== */

.gcww-status {
	--gcww-green: #1f7a44;
	--gcww-red:   #cc2b2b;
	--gcww-gold:  #c8912f;
	--gcww-title: #1c5230;

	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	align-items: stretch;
}

.gcww-card {
	flex: 1 1 220px;
	display: flex;
	align-items: center;
	gap: 14px;
	background: #fff;
	border-radius: 12px;
	padding: 16px 18px;
	box-shadow: 0 10px 25px rgba(0, 0, 0, .12);
}

.gcww-card__iconbox {
	flex: 0 0 auto;
	width: 52px;
	height: 52px;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 2px solid var(--gcww-gold);
	border-radius: 8px;
}

/* Icon = einfarbige Silhouette via Mask. Farbe steuert offen/geschlossen. */
.gcww-card__icon {
	width: 30px;
	height: 30px;
	display: block;
	background-color: var(--gcww-green);
	-webkit-mask: var(--gcww-icon) no-repeat center / contain;
	        mask: var(--gcww-icon) no-repeat center / contain;
	transition: background-color .2s ease;
}

.gcww-card.is-closed .gcww-card__icon {
	background-color: var(--gcww-red);
}

.gcww-card__body {
	display: flex;
	flex-direction: column;
	line-height: 1.2;
}

.gcww-card__title {
	font-weight: 700;
	color: var(--gcww-title);
	font-size: 1rem;
}

.gcww-card__status {
	font-size: .9rem;
	font-weight: 600;
	margin-top: 2px;
	color: var(--gcww-green);
}

.gcww-card.is-closed .gcww-card__status {
	color: var(--gcww-red);
}

/* ---------------------------------------------------------------------
   News-Ticker (kontinuierlicher Lauf, nahtlose Schleife)
   ------------------------------------------------------------------- */

.gcww-ticker {
	--gcww-gold:  #c8912f;
	--gcww-green: #1a5632;

	display: flex;
	align-items: stretch;
	min-height: 52px;
	background: var(--gcww-gold);
	color: #fff;
	overflow: hidden;
}

/* feststehendes Label links */
.gcww-ticker__label {
	position: relative;
	z-index: 2;
	flex: 0 0 auto;
	display: flex;
	align-items: center;
	background: var(--gcww-green);
	color: #fff;
	font-weight: 800;
	letter-spacing: .06em;
	padding: 0 22px;
	font-size: 1rem;
}

/* Ausschnitt, in dem gescrollt wird */
.gcww-ticker__viewport {
	flex: 1 1 auto;
	min-width: 0;
	overflow: hidden;
	display: flex;
	align-items: center;
}

/* der laufende Streifen; Dauer + Shift setzt das JS, Werte hier sind Fallback */
.gcww-ticker__track {
	display: flex;
	flex-wrap: nowrap;
	align-items: center;
	width: max-content;
	will-change: transform;
	animation: gcww-ticker-scroll 20s linear infinite;
}

.gcww-ticker:hover .gcww-ticker__track,
.gcww-ticker:focus-within .gcww-ticker__track {
	animation-play-state: paused;
}

.gcww-ticker__set {
	display: flex;
	flex: 0 0 auto;
	align-items: center;
}

.gcww-ticker__item {
	flex: 0 0 auto;
	color: #fff;
	font-weight: 700;
	font-size: 1.05rem;
	text-decoration: none;
	white-space: nowrap;
	padding: 0 2px;
}

a.gcww-ticker__item:hover {
	text-decoration: underline;
}

.gcww-ticker__sep {
	flex: 0 0 auto;
	margin: 0 20px;
	color: var(--gcww-green);
	font-size: .6rem;
	line-height: 1;
}

@keyframes gcww-ticker-scroll {
	from { transform: translateX(0); }
	to   { transform: translateX(calc(-1 * var(--gcww-shift, 50%))); }
}

/* Bewegungsreduzierung respektieren: kein Lauf */
@media (prefers-reduced-motion: reduce) {
	.gcww-ticker__track {
		animation: none;
	}
}

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

@media (max-width: 600px) {
	.gcww-card {
		flex: 1 1 100%;
	}

	.gcww-ticker__label {
		padding: 0 16px;
	}

	.gcww-ticker__item {
		font-size: 1rem;
	}

	.gcww-ticker__sep {
		margin: 0 14px;
	}
}
