/**
 * Eventday – Frontend-Styles
 *
 * Bewusst themebar: Alle markenspezifischen Werte liegen in CSS-Variablen.
 * Boo-Crew oder Heide Park World überschreiben sie einfach im Template-CSS,
 * z. B.:  .eventday { --evt-accent: #c1121f; --evt-ink: #0b0b0f; }
 *
 * Keine externen Quellen: System-Font-Stack bzw. lokal eingebundene
 * Web-Font (Oswald, nur im dunklen Theme), kein CDN.
 */

/* Oswald nur lokal (OFL) – wird ausschließlich im dunklen Theme genutzt,
   lädt daher nur dort. Variable Schriftstärke 200–700. */
@font-face {
	font-family: "Oswald";
	font-style: normal;
	font-weight: 200 700;
	font-display: swap;
	src: url("../fonts/oswald-var-latin.woff2") format("woff2");
}

.eventday {
	/* Farbwelt – helles Theme = Heide Park World (Standard) */
	--evt-accent: #0057a8;          /* HPW-Primär (Links, aktive Elemente) */
	--evt-accent-ink: #ffffff;      /* Text auf Akzentfläche */
	--evt-accent-grad: linear-gradient(135deg, #0057a8 0%, #0077cc 100%); /* HPW-Verlauf */
	--evt-accent-soft: rgba(0, 87, 168, .4);  /* Hover-Rahmen */
	--evt-ring: rgba(0, 87, 168, .15);        /* Hover-Ring */
	--evt-ink: #212529;             /* Haupttext */
	--evt-muted: #6c757d;           /* Sekundärtext / Labels / Metadaten */
	--evt-line: #dee2e6;            /* Rahmen / Trennlinien */
	--evt-surface: #ffffff;         /* Kartenfläche */
	--evt-surface-2: #f0f4f8;       /* Hintergrund / Hover / Stempel */
	--evt-radius: 8px;
	--evt-shadow: 0 1px 4px rgba(0, 0, 0, .08);
	--evt-shadow-hover: 0 2px 10px rgba(0, 0, 0, .10), 0 14px 32px rgba(0, 0, 0, .08);

	/* Typo-Skala */
	--evt-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	--evt-font-head: var(--evt-font); /* Überschriften – im dunklen Theme Oswald */
	--evt-font-num: "SFMono-Regular", ui-monospace, "Cascadia Mono", Menlo, Consolas, monospace;

	color: var(--evt-ink);
	font-family: var(--evt-font);
	line-height: 1.55;
}

/* ---------- Listenkopf ---------- */
/* ---------- Monatsgruppen ---------- */
.eventday__monthblock { margin-bottom: 2.25rem; }
.eventday__monthblock:last-of-type { margin-bottom: 0; }
.eventday__month {
	font-family: var(--evt-font-head);
	font-size: 1rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .06em;
	color: var(--evt-ink);
	margin: 0 0 1rem;
	padding-bottom: .45rem;
	border-bottom: 1px solid var(--evt-line);
}
.eventday__empty {
	background: var(--evt-surface-2);
	border: 1px dashed var(--evt-line);
	border-radius: var(--evt-radius);
	color: var(--evt-muted);
	padding: 2rem;
	text-align: center;
}

/* ---------- Kartengrid ---------- */
.eventday__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 1.25rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.eventday-card {
	position: relative;
	background: var(--evt-surface);
	border: 1px solid var(--evt-line);
	border-radius: var(--evt-radius);
	overflow: hidden;
	transition: box-shadow .2s ease, transform .2s ease;
}
.eventday-card:hover {
	border-color: var(--evt-accent-soft);
	box-shadow: 0 0 0 1px var(--evt-ring), var(--evt-shadow-hover);
	transform: translateY(-2px);
}
.eventday-card__link {
	display: flex;
	flex-direction: column;
	height: 100%;
	color: inherit;
	text-decoration: none;
}

.eventday-card__media {
	aspect-ratio: 16 / 9;
	background: var(--evt-surface-2);
	overflow: hidden;
}
.eventday-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform .4s ease;
}
.eventday-card:hover .eventday-card__img { transform: scale(1.03); }

.eventday-card__body {
	display: flex;
	gap: 1rem;
	padding: 1.1rem 1.2rem 1.3rem;
}

/* Signaturelement: der Datums-„Stempel“ (Ticket-Anmutung) */
.eventday-stamp {
	flex: 0 0 auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 3.4rem;
	height: 3.4rem;
	border: 1px solid transparent;
	border-radius: var(--evt-radius);
	background: var(--evt-accent-grad);
	line-height: 1;
}
.eventday-stamp__day {
	font-family: var(--evt-font-num);
	font-size: 1.45rem;
	font-weight: 700;
	color: var(--evt-accent-ink);
}
.eventday-stamp__month {
	font-size: .7rem;
	text-transform: uppercase;
	letter-spacing: .08em;
	color: var(--evt-accent-ink);
	opacity: .8;
	margin-top: .15rem;
}

.eventday-card__text { min-width: 0; }
.eventday-card__title {
	font-family: var(--evt-font-head);
	font-size: 1.08rem;
	font-weight: 650;
	letter-spacing: -.01em;
	margin: 0 0 .35rem;
}
.eventday-card__meta,
.eventday-card__range,
.eventday-card__intro {
	margin: 0 0 .3rem;
	font-size: .88rem;
	color: var(--evt-muted);
}
.eventday-card__pin {
	display: inline-block;
	width: .6rem; height: .6rem;
	margin-right: .25rem;
	border: 2px solid currentColor;
	border-radius: 50% 50% 50% 0;
	transform: rotate(-45deg);
	vertical-align: middle;
}
.eventday-card__range { color: var(--evt-accent); font-weight: 600; }

.eventday-card__badge {
	position: absolute;
	top: .75rem; right: .75rem;
	background: rgba(22, 24, 29, .82);
	color: #fff;
	font-size: .7rem;
	font-weight: 600;
	letter-spacing: .04em;
	text-transform: uppercase;
	padding: .2rem .55rem;
	border-radius: 999px;
}
.eventday-card.is-past { opacity: .72; }
.eventday-card.is-past .eventday-stamp { filter: grayscale(.6); opacity: .9; }

/* ---------- Hero (Event mit mehr als 3 Eventtagen, volle Breite) ---------- */
.eventday-card--hero { grid-column: 1 / -1; }
.eventday-card--hero .eventday-card__link { display: block; }
.eventday-hero { display: grid; grid-template-columns: 1fr; }
.eventday-hero__media { overflow: hidden; background: var(--evt-surface-2); }
.eventday-hero__img {
	width: 100%; height: 100%; min-height: 200px;
	object-fit: cover; display: block;
	transition: transform .4s ease;
}
.eventday-card--hero:hover .eventday-hero__img { transform: scale(1.03); }
.eventday-hero__body {
	display: flex; flex-direction: column; justify-content: center;
	gap: .5rem; padding: clamp(1.25rem, .8rem + 2vw, 2rem);
}
.eventday-hero__range {
	align-self: flex-start;
	background: var(--evt-accent-grad);
	color: var(--evt-accent-ink);
	font-size: .78rem; font-weight: 700;
	text-transform: uppercase; letter-spacing: .05em;
	padding: .3rem .7rem; border-radius: 999px;
}
.eventday-hero__title {
	font-family: var(--evt-font-head);
	font-size: clamp(1.4rem, 1.1rem + 1.6vw, 2.1rem);
	font-weight: 700; line-height: 1.15; margin: 0;
	color: var(--evt-ink);
}
.eventday-hero__meta {
	display: flex; align-items: center; gap: .35rem;
	color: var(--evt-muted); font-size: .9rem; margin: 0;
}
.eventday-hero__intro { color: var(--evt-muted); margin: 0; max-width: 60ch; }

@media (min-width: 720px) {
	.eventday-hero { grid-template-columns: minmax(0, 42%) 1fr; align-items: stretch; }
}

/* ---------- Pagination ---------- */
.eventday__pagination { margin-top: 1.75rem; }
.eventday__pagination ul {
	display: flex; flex-wrap: wrap; gap: .35rem;
	list-style: none; margin: 0; padding: 0;
}
.eventday__pagination a,
.eventday__pagination span {
	display: inline-flex; align-items: center;
	min-width: 2.2rem; height: 2.2rem; padding: 0 .6rem;
	justify-content: center;
	border: 1px solid var(--evt-line);
	border-radius: 8px;
	text-decoration: none; color: var(--evt-ink);
}
.eventday__pagination .active span { background: var(--evt-accent-grad); color: var(--evt-accent-ink); border-color: transparent; }

/* ---------- Detailseite ---------- */
.eventday--single {
	max-width: 820px;
	margin: 0 auto;
	background: var(--evt-surface);
	color: var(--evt-ink);
	border: 1px solid var(--evt-line);
	border-radius: var(--evt-radius);
	box-shadow: var(--evt-shadow);
	padding: clamp(1.25rem, .8rem + 2vw, 2.5rem);
}
.eventday-single__back {
	display: inline-block; margin-bottom: 1rem;
	font-size: .9rem; color: var(--evt-accent); text-decoration: none;
}
.eventday-single__back::before { content: "← "; }

/* Keine Unterstreichung bei Hover/Fokus auf UI-Links (Template-Default überschreiben). */
.eventday-card__link:hover,
.eventday-card__link:focus,
.eventday-single__back:hover,
.eventday-single__back:focus,
.eventday__pagination a:hover,
.eventday__pagination a:focus {
	text-decoration: none;
}

.eventday-single__title {
	font-family: var(--evt-font-head);
	font-size: clamp(1.7rem, 1.2rem + 2.4vw, 2.6rem);
	font-weight: 700; letter-spacing: -.02em; line-height: 1.15;
	margin: 0 0 1rem;
}
.eventday-single__badge,
.eventday-single__title .eventday-single__badge {
	display: inline-block; vertical-align: middle;
	margin-left: .6rem;
	font-size: .7rem; font-weight: 600; letter-spacing: .04em;
	text-transform: uppercase;
	background: var(--evt-surface-2); color: var(--evt-muted);
	border: 1px solid var(--evt-line);
	padding: .2rem .55rem; border-radius: 999px;
}

.eventday-single__facts {
	display: flex; flex-wrap: wrap; gap: 1.5rem 2.5rem;
	margin: 0 0 1.75rem; padding: 1rem 0;
	border-top: 1px solid var(--evt-line);
	border-bottom: 1px solid var(--evt-line);
}
.eventday-fact dt {
	font-size: .72rem; text-transform: uppercase; letter-spacing: .08em;
	color: var(--evt-muted); margin-bottom: .2rem;
}
.eventday-fact dd { margin: 0; font-weight: 600; }

/* Galerie als horizontal scrollendes Carousel (Scroll-Snap). */
.eventday-gallery-wrap { position: relative; margin: 0 0 1.75rem; }
.eventday-gallery {
	display: flex;
	gap: .75rem;
	margin: 0;
	overflow-x: auto;
	overscroll-behavior-x: contain;
	-webkit-overflow-scrolling: touch;
	scroll-snap-type: x mandatory;
	scroll-padding-left: 0;
	padding-bottom: .25rem;
	scrollbar-width: thin;
}
.eventday-gallery__item {
	margin: 0;
	flex: 0 0 auto;
	width: clamp(220px, 62%, 320px);
	scroll-snap-align: start;
}
.eventday-gallery__item img {
	width: 100%; aspect-ratio: 4 / 3; object-fit: cover;
	border-radius: 10px; display: block; cursor: zoom-in;
	background: var(--evt-surface-2);
}
.eventday-gallery__item figcaption {
	font-size: .8rem; color: var(--evt-muted); margin-top: .35rem;
}
/* Vor/Zurück-Pfeile (nur mit JS, blenden sich am Rand aus). */
.eventday-gallery__nav {
	position: absolute; top: 38%; transform: translateY(-50%);
	z-index: 2;
	width: 2.4rem; height: 2.4rem;
	display: flex; align-items: center; justify-content: center;
	border: 1px solid var(--evt-line); border-radius: 50%;
	background: var(--evt-surface); color: var(--evt-ink);
	box-shadow: var(--evt-shadow); cursor: pointer;
	font-size: 1.5rem; line-height: 1; padding: 0;
}
.eventday-gallery__nav:hover { border-color: var(--evt-accent-soft); }
.eventday-gallery__nav--prev { left: -.5rem; }
.eventday-gallery__nav--next { right: -.5rem; }
.eventday-gallery__nav[hidden] { display: none; }

.eventday-single__body { font-size: 1.02rem; margin-bottom: 1.75rem; }
.eventday-single__body img { max-width: 100%; height: auto; border-radius: 10px; }

.eventday-days__title { font-family: var(--evt-font-head); font-size: 1.2rem; font-weight: 650; margin: 0 0 .75rem; }
.eventday-days__list { list-style: none; margin: 0; padding: 0; }
.eventday-day {
	display: flex; flex-wrap: wrap; align-items: baseline; gap: .25rem 1rem;
	padding: .7rem 0; border-bottom: 1px solid var(--evt-line);
}
.eventday-day__date { font-weight: 650; }
.eventday-day__time { color: var(--evt-accent); font-variant-numeric: tabular-nums; }
.eventday-day__note { color: var(--evt-muted); }

/* ---------- Leichtgewichtige Lightbox ---------- */
.eventday-lightbox {
	position: fixed; inset: 0; z-index: 9999;
	display: flex; align-items: center; justify-content: center;
	background: rgba(8, 10, 14, .9); padding: 1.5rem;
}
.eventday-lightbox[hidden] { display: none; }
.eventday-lightbox img { max-width: 100%; max-height: 90vh; border-radius: 8px; }
.eventday-lightbox__close {
	position: absolute; top: 1rem; right: 1rem;
	width: 2.6rem; height: 2.6rem;
	background: rgba(255, 255, 255, .12); color: #fff;
	border: 0; border-radius: 50%; font-size: 1.4rem; cursor: pointer;
}

/* ---------- Zugänglichkeit / Quality-Floor ---------- */
.eventday-card__link:focus-visible,
.eventday-single__back:focus-visible,
.eventday-gallery__item img:focus-visible,
.eventday__pagination a:focus-visible,
.eventday-lightbox__close:focus-visible {
	outline: 3px solid var(--evt-accent);
	outline-offset: 2px;
}
.visually-hidden {
	position: absolute !important; width: 1px; height: 1px;
	padding: 0; margin: -1px; overflow: hidden; clip: rect(0 0 0 0); border: 0;
}

@media (prefers-reduced-motion: reduce) {
	.eventday-card,
	.eventday-card__img { transition: none; }
	.eventday-card:hover { transform: none; }
	.eventday-card:hover .eventday-card__img { transform: none; }
}

/* ---------- Dunkles Theme (Boo-Crew) – explizit pro Menüpunkt wählbar ---------- */
.eventday--dark {
	--evt-accent: #fc9300;          /* Primärakzent / Orange */
	--evt-accent-ink: #111111;      /* Text auf Akzentfläche (dunkel) */
	--evt-accent-grad: linear-gradient(135deg, #fc9300, #e65c00); /* Orange → Rot */
	--evt-accent-soft: rgba(252, 147, 0, .4);  /* Hover-Rahmen */
	--evt-ring: rgba(252, 147, 0, .15);        /* Hover-Ring */
	--evt-ink: #e2e2e2;             /* Haupttext */
	--evt-muted: #8a8a8a;           /* Sekundärtext (etwas heller als #666 für Lesbarkeit) */
	--evt-line: #2a2a2a;            /* Standard-Rahmen */
	--evt-surface: #1a1a1a;         /* Karten / Panels */
	--evt-surface-2: #222222;       /* Eingabe / Hover */
	--evt-radius: 10px;
	--evt-shadow: 0 1px 2px rgba(0, 0, 0, .5), 0 10px 30px rgba(0, 0, 0, .45);
	--evt-shadow-hover: 0 2px 4px rgba(0, 0, 0, .6), 0 18px 44px rgba(0, 0, 0, .6);
	--evt-font-head: "Oswald", var(--evt-font);
}

/* Oswald wirkt kräftiger – minimale Laufweite an den großen Titeln. */
.eventday--dark .eventday-single__title {
	letter-spacing: .005em;
}

/* "Vorbei"-Badge an die dunkle Fläche anpassen. */
.eventday--dark .eventday-card__badge {
	background: rgba(0, 0, 0, .72);
	color: var(--evt-ink);
}
