/**
 * ITX Popup Module - Frontend Styles
 *
 * Mobile-first. Anpassbar ueber CSS-Variablen am Selektor .itx-pop-popup.
 *
 * @package   ITX_Pop_Module
 * @author    FURRER ITX, Reto Furrer
 * @copyright 2026 FURRER ITX, Reto Furrer
 * @license   Proprietaer - Alle Rechte vorbehalten
 */

/* Scroll der Seite sperren, solange ein Popup offen ist. */
.itx-pop-locked {
	overflow: hidden;
}

.itx-pop-popup {
	--itx-pop-accent: #1d2327;
	--itx-pop-accent-contrast: #ffffff;
	--itx-pop-bg: #ffffff;
	--itx-pop-text: #1d2327;
	--itx-pop-radius: 10px;
	--itx-pop-transition: 200ms ease;
	--itx-pop-arrow-size: 1em;
	--itx-pop-arrow-gap: 0.5em;
	--itx-pop-button-font-size: 1rem;

	position: fixed;
	inset: 0;
	z-index: 99999;
	display: flex;
	align-items: safe center;
	justify-content: center;
	padding: 1rem;
	color: var(--itx-pop-text);
	overflow-y: auto;
	overscroll-behavior: contain;
}

.itx-pop-popup[hidden] {
	display: none;
}

.itx-pop-popup__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.55);
	opacity: 0;
	transition: opacity var(--itx-pop-transition);
}

.itx-pop-popup__dialog {
	position: relative;
	width: 100%;
	max-width: 600px;
	background: var(--itx-pop-bg);
	border-radius: var(--itx-pop-radius);
	padding: 1.75rem;
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.25);
	transform: translateY(8px);
	opacity: 0;
	transition: transform var(--itx-pop-transition), opacity var(--itx-pop-transition);
}

/* Container erhaelt programmatisch den Fokus beim Oeffnen (tabindex=-1) -
   kein sichtbarer Ring. Echte interaktive Elemente innerhalb behalten ihren
   :focus-visible-Stil. */
.itx-pop-popup__dialog:focus {
	outline: none;
}

/* Maximale Breite pro Meldung (Klein / Mittel / Gross). */
.itx-pop-popup--size-small .itx-pop-popup__dialog {
	max-width: 400px;
}

.itx-pop-popup--size-medium .itx-pop-popup__dialog {
	max-width: 600px;
}

.itx-pop-popup--size-large .itx-pop-popup__dialog {
	max-width: 800px;
}

/* Hauptbild im Popup. */
.itx-pop-popup__media {
	margin: 0 0 1rem;
}

.itx-pop-popup__image {
	display: block;
	width: 100%;
	height: auto;
	border-radius: var(--itx-pop-radius);
}

/* Offen-Zustand. */
.itx-pop-popup.is-open .itx-pop-popup__backdrop {
	opacity: 1;
}

.itx-pop-popup.is-open .itx-pop-popup__dialog {
	transform: translateY(0);
	opacity: 1;
}

.itx-pop-popup__close {
	position: absolute;
	top: 0.5rem;
	right: 0.5rem;
	width: 2.25rem;
	height: 2.25rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 1.5rem;
	line-height: 1;
	color: inherit;
	background: transparent;
	border: 0;
	border-radius: 50%;
	cursor: pointer;
	transition: background var(--itx-pop-transition);
}

.itx-pop-popup__close:hover,
.itx-pop-popup__close:focus-visible {
	background: rgba(0, 0, 0, 0.08);
}

.itx-pop-popup__close:focus-visible {
	outline: 2px solid var(--itx-pop-accent);
	outline-offset: 2px;
}

.itx-pop-popup__close-icon {
	width: 1.25rem;
	height: 1.25rem;
}

/* Vorschau-Badge: nur bei Aktiv-Zustand "Vorschau" sichtbar (nur Redakteure
   sehen das Popup ueberhaupt). Hilft beim Testen vor Veroeffentlichung. */
.itx-pop-popup__preview-badge {
	position: absolute;
	top: 0.75rem;
	left: 0.75rem;
	padding: 0.2em 0.6em;
	background: #f0b849;
	color: #1d2327;
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	border-radius: 4px;
	pointer-events: none;
}

.itx-pop-popup__title {
	margin: 0 0 0.5rem;
	padding-right: 2rem;
	font-size: 1.35rem;
	line-height: 1.25;
}

/* Titel-Anzeige (pro Meldung waehlbar). "medium" entspricht dem
   Default oben; die anderen ueberschreiben Schriftgroesse oder
   blenden den Titel visuell aus (bleibt fuer Screenreader erhalten,
   damit aria-labelledby weiterhin greift). */
.itx-pop-popup__title--large {
	font-size: 1.75rem;
}

.itx-pop-popup__title--small {
	font-size: 1.05rem;
}

.itx-pop-popup__title--hidden {
	position: absolute;
	width: 1px;
	height: 1px;
	margin: -1px;
	padding: 0;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.itx-pop-popup__text {
	margin-bottom: 0.75rem;
}

.itx-pop-popup__text > :first-child {
	margin-top: 0;
}

.itx-pop-popup__text > :last-child {
	margin-bottom: 0;
}

.itx-pop-popup__buttons {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	margin-top: 0.75rem;
}

.itx-pop-popup__button {
	display: inline-flex;
	align-items: center;
	padding: 0.6rem 1.1rem;
	background: var(--itx-pop-accent);
	color: var(--itx-pop-accent-contrast);
	text-decoration: none;
	border: 0;
	border-radius: 6px;
	font: inherit;
	font-size: var(--itx-pop-button-font-size);
	line-height: 1.2;
	cursor: pointer;
	transition: opacity var(--itx-pop-transition);
}

.itx-pop-popup__button--close {
	background: transparent;
	color: var(--itx-pop-text);
	border: 1px solid currentColor;
}

.itx-pop-popup__button--arrow {
	gap: var(--itx-pop-arrow-gap);
}

.itx-pop-popup__button-arrow {
	display: inline-block;
	flex: 0 0 auto;
	width: var(--itx-pop-arrow-size);
	height: var(--itx-pop-arrow-size);
	background-color: currentColor;
	-webkit-mask: var(--itx-pop-arrow-url) no-repeat center / contain;
	mask: var(--itx-pop-arrow-url) no-repeat center / contain;
}

.itx-pop-popup__image-link {
	display: block;
}

/* Media-Container mit gesetzter Bildhoehe (pro Meldung).
   Das Bild fuellt die Hoehe und wird gemaess Fokus zugeschnitten. */
.itx-pop-popup__media--constrained,
.itx-pop-popup__media--constrained .itx-pop-popup__image-link {
	height: var(--itx-pop-img-h);
}

.itx-pop-popup__media--constrained .itx-pop-popup__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: var(--itx-pop-img-focus);
	display: block;
}

/* Wer Hover sagt, sagt auch Focus: gleicher Stil fuer beide. */
.itx-pop-popup__button:hover,
.itx-pop-popup__button:focus-visible {
	opacity: 0.9;
}

.itx-pop-popup__button:focus-visible {
	outline: 2px solid var(--itx-pop-accent);
	outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
	.itx-pop-popup__backdrop,
	.itx-pop-popup__dialog {
		transition: none;
	}
}

/* Mobile: kompaktere Button-Textgroesse. Via CSS-Variable, damit Themes
   den Wert pro Projekt anpassen oder den Breakpoint ueberschreiben koennen. */
@media (max-width: 600px) {
	.itx-pop-popup {
		--itx-pop-button-font-size: 0.875rem;
	}
}
