/* CLAUDE: Exposé-Download-Box Styling */
/* CLAUDE: Wird in assets.php enqueued für single-denkmal_objekte */
/* CLAUDE: Optimiert für Sidebar-Display mit Gradient-Effekten */

/* ========================================
   CLAUDE: Exposé-Box Container
   ======================================== */

/* CLAUDE: Hauptcontainer für Exposé-Download-Box */
/* CLAUDE: Zeigt PDF-Download-Button prominent in der Sidebar */
.objekt-expose-box {
	/* CLAUDE: Spacing & Layout */
	background: #ffffff;
	border-radius: 12px;
	padding: 2rem;
	margin-bottom: 2rem;

	/* CLAUDE: Gradient-Border-Effekt */
	border: 2px solid transparent;
	background-clip: padding-box;
	position: relative;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
	transition: all 0.3s ease;
}

/* CLAUDE: Gradient-Border via Pseudo-Element */
/* CLAUDE: Erstellt farbenfrohen Rahmen passend zum Theme */
.objekt-expose-box::before {
	content: '';
	position: absolute;
	inset: 0;
	border-radius: 12px;
	padding: 2px;
	background: linear-gradient(135deg, #c19a6b 0%, #594834 100%);
	-webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
	-webkit-mask-composite: xor;
	mask-composite: exclude;
	pointer-events: none;
}

/* CLAUDE: Hover-Effekt - Subtle Lift */
/* CLAUDE: Verbessert UX durch visuelles Feedback */
.objekt-expose-box:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12);
}

/* ========================================
   CLAUDE: Icon & Typography
   ======================================== */

/* CLAUDE: Emoji-Icon für visuellen Anker */
/* CLAUDE: Großes PDF-Icon oben zentriert */
.objekt-expose__icon {
	font-size: 3rem;
	text-align: center;
	margin-bottom: 1rem;
	line-height: 1;
}

/* CLAUDE: Überschrift "Exposé herunterladen" */
/* CLAUDE: Bold, zentral, Eye-Catching */
.objekt-expose-box h3 {
	font-size: clamp(1.25rem, 2vw, 1.5rem);
	font-weight: 700;
	text-align: center;
	margin: 0 0 0.75rem 0;
	color: #2c3e50;
	line-height: 1.3;
}

/* CLAUDE: Beschreibungstext */
/* CLAUDE: Kurze Erklärung des Downloads */
.objekt-expose-box > p {
	font-size: 0.9375rem;
	line-height: 1.6;
	text-align: center;
	color: #666;
	margin: 0 0 1.5rem 0;
}

/* ========================================
   CLAUDE: Download-Button
   ======================================== */

/* CLAUDE: Haupt-Download-Button */
/* CLAUDE: Gradient-Background, Full-Width, Eye-Catching */
.button--expose {
	/* CLAUDE: Layout */
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.625rem;
	width: 100%;

	/* CLAUDE: Spacing */
	padding: 1rem 1.5rem;

	/* CLAUDE: Typography */
	font-size: 1rem;
	font-weight: 600;
	text-decoration: none;
	text-align: center;
	line-height: 1.4;

	/* CLAUDE: Styling */
	background: #c19a6b;
	color: #ffffff;
	border: none;
	border-radius: 8px;
	cursor: pointer;

	/* CLAUDE: Transition für Hover-Effekte */
	transition: all 0.3s ease;
	box-shadow: 0 4px 12px rgba(102, 126, 234, 0.3);
}

/* CLAUDE: Hover-State */
/* CLAUDE: Dunkelt Gradient ab, verstärkt Shadow */
.button--expose:hover {
	background: linear-gradient(135deg, #c19a6b 0%, #594834 100%);
	box-shadow: 0 6px 20px rgba(102, 126, 234, 0.4);
	transform: translateY(-2px);
	color: #ffffff;
}

/* CLAUDE: Active-State */
/* CLAUDE: Drückt Button visuell ein */
.button--expose:active {
	transform: translateY(0);
	box-shadow: 0 2px 8px rgba(102, 126, 234, 0.3);
}

/* CLAUDE: Focus-State für Accessibility */
/* CLAUDE: Deutlicher Fokus-Ring für Keyboard-Navigation */
.button--expose:focus {
	outline: 3px solid rgba(102, 126, 234, 0.5);
	outline-offset: 2px;
}

/* CLAUDE: Button-Icon (Emoji) */
/* CLAUDE: Download-Icon neben Text */
.button--expose .button__icon {
	font-size: 1.25rem;
	line-height: 1;
}

/* CLAUDE: Button-Text */
/* CLAUDE: Verhindert Text-Wrap, bleibt lesbar */
.button--expose .button__text {
	white-space: nowrap;
}

/* ========================================
   CLAUDE: Dateigröße-Anzeige
   ======================================== */

/* CLAUDE: Zeigt PDF-Dateigröße unter Button */
/* CLAUDE: Hilft User bei Einschätzung der Download-Zeit */
.objekt-expose__size {
	margin: 0.75rem 0 0 0;
	text-align: center;
	font-size: 0.8125rem;
	color: #999;
}

.objekt-expose__size small {
	font-size: inherit;
	color: inherit;
}

/* ========================================
   CLAUDE: Responsive Anpassungen
   ======================================== */

/* CLAUDE: Tablet & Mobile - Kleinere Abstände */
@media (max-width: 768px) {
	/* CLAUDE: Reduziertes Padding auf kleineren Screens */
	.objekt-expose-box {
		padding: 1.5rem;
		margin-bottom: 1.5rem;
	}

	/* CLAUDE: Kleineres Icon auf Mobile */
	.objekt-expose__icon {
		font-size: 2.5rem;
	}

	/* CLAUDE: Button bleibt groß genug für Touch */
	.button--expose {
		padding: 0.875rem 1.25rem;
		font-size: 0.9375rem;
	}
}

/* CLAUDE: Mobile - Kompakteres Layout */
@media (max-width: 480px) {
	/* CLAUDE: Minimales Padding auf sehr kleinen Screens */
	.objekt-expose-box {
		padding: 1.25rem;
	}

	/* CLAUDE: Button-Text kann umbrechen auf sehr kleinen Screens */
	.button--expose .button__text {
		white-space: normal;
	}
}

/* ========================================
   CLAUDE: Print-Styles
   ======================================== */

/* CLAUDE: Versteckt Download-Box im Druck */
/* CLAUDE: Kein Sinn für PDF-Download auf Papier */
@media print {
	.objekt-expose-box {
		display: none;
	}
}

/* ========================================
   CLAUDE: Dark-Mode Support (optional)
   ======================================== */

/* CLAUDE: Falls Theme Dark-Mode unterstützt */
/* CLAUDE: Anpassung für bessere Lesbarkeit */
@media (prefers-color-scheme: dark) {
	.objekt-expose-box {
		background: #1e1e1e;
		box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
	}

	.objekt-expose-box h3 {
		color: #f0f0f0;
	}

	.objekt-expose-box > p {
		color: #b0b0b0;
	}

	.objekt-expose__size {
		color: #808080;
	}
}

/* ========================================
   CLAUDE: Loading/Disabled State (optional)
   ======================================== */

/* CLAUDE: Falls Button während Download deaktiviert werden soll */
.button--expose:disabled,
.button--expose.is-loading {
	opacity: 0.6;
	cursor: not-allowed;
	pointer-events: none;
}

/* CLAUDE: Loading-Spinner-Animation */
@keyframes expose-spin {
	from {
		transform: rotate(0deg);
	}
	to {
		transform: rotate(360deg);
	}
}

.button--expose.is-loading .button__icon {
	animation: expose-spin 1s linear infinite;
}

/* ========================================
   CLAUDE: Modal Overlay & Container
   ======================================== */

/* CLAUDE: Modal-Overlay (Hintergrund) */
.expose-modal {
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: none;
	align-items: center;
	justify-content: center;
	padding: 1rem;
	opacity: 0;
	transition: opacity 0.3s ease;
}

/* CLAUDE: Modal sichtbar wenn geöffnet */
.expose-modal.is-open {
	display: flex;
	opacity: 1;
}

/* CLAUDE: Dunkler Hintergrund */
.expose-modal__overlay {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.75);
	backdrop-filter: blur(4px);
	cursor: pointer;
}

/* CLAUDE: Modal-Container (weißer Box) */
.expose-modal__container {
	position: relative;
	background: #ffffff;
	border-radius: 16px;
	max-width: 540px;
	width: 100%;
	max-height: 90vh;
	overflow-y: auto;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
	z-index: 1;
	animation: expose-modal-slide-in 0.3s ease;
}

/* CLAUDE: Slide-In-Animation */
@keyframes expose-modal-slide-in {
	from {
		transform: translateY(-20px);
		opacity: 0;
	}
	to {
		transform: translateY(0);
		opacity: 1;
	}
}

/* CLAUDE: Close-Button (X oben rechts) */
.expose-modal__close {
	position: absolute;
	top: 1rem;
	right: 1rem;
	background: transparent;
	border: none;
	font-size: 2rem;
	line-height: 1;
	color: #999;
	cursor: pointer;
	padding: 0.5rem;
	transition: color 0.2s ease;
	z-index: 2;
}

.expose-modal__close:hover {
	color: #333;
}

/* CLAUDE: Modal-Content */
.expose-modal__content {
	padding: 3rem 2rem 2rem;
}

/* CLAUDE: Icon im Modal */
.expose-modal__icon {
	font-size: 3.5rem;
	text-align: center;
	margin-bottom: 1rem;
	line-height: 1;
}

/* CLAUDE: Titel */
.expose-modal__title {
	font-size: clamp(1.5rem, 3vw, 1.875rem);
	font-weight: 700;
	text-align: center;
	margin: 0 0 0.75rem 0;
	color: #2c3e50;
}

/* CLAUDE: Subtitle (Objekttitel) */
.expose-modal__subtitle {
	text-align: center;
	font-size: 1rem;
	color: #666;
	margin: 0 0 1rem 0;
}

.expose-modal__subtitle strong {
	color: #333;
	font-weight: 600;
}

/* CLAUDE: Beschreibungstext */
.expose-modal__description {
	text-align: center;
	font-size: 0.9375rem;
	color: #666;
	margin: 0 0 1.5rem 0;
	line-height: 1.6;
}

/* ========================================
   CLAUDE: Formular-Styling
   ======================================== */

/* CLAUDE: Formular-Container */
.expose-form {
	margin-bottom: 1.5rem;
}

/* CLAUDE: Zweispaltige Reihe (Name) */
.expose-form__row {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1rem;
	margin-bottom: 1rem;
}

/* CLAUDE: Formular-Feld */
.expose-form__field {
	margin-bottom: 1rem;
}

/* CLAUDE: Label */
.expose-form__label {
	display: block;
	font-size: 0.875rem;
	font-weight: 600;
	color: #333;
	margin-bottom: 0.375rem;
}

.expose-form__label .required {
	color: #d63031;
}

.expose-form__label .optional {
	color: #999;
	font-weight: 400;
}

/* CLAUDE: Input-Felder */
.expose-form__input {
	width: 100%;
	padding: 0.75rem 1rem;
	font-size: 1rem;
	border: 2px solid #e0e0e0;
	border-radius: 8px;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
	font-family: inherit;
}

.expose-form__input:focus {
	outline: none;
	border-color: #c19a6b;
	box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.1);
}

.expose-form__input::placeholder {
	color: #999;
}

/* CLAUDE: Datenschutz-Checkbox */
.expose-form__privacy {
	margin: 1.5rem 0;
}

.expose-form__checkbox-label {
	display: flex;
	align-items: flex-start;
	gap: 0.625rem;
	font-size: 0.875rem;
	color: #666;
	line-height: 1.5;
	cursor: pointer;
}

.expose-form__checkbox-label input[type="checkbox"] {
	margin-top: 0.25rem;
	flex-shrink: 0;
	cursor: pointer;
}

.expose-form__checkbox-label a {
	color: #667eea;
	text-decoration: underline;
}

.expose-form__checkbox-label a:hover {
	color: #5568d3;
}

/* CLAUDE: Message-Box (Error/Success) */
.expose-form__message {
	padding: 1rem;
	border-radius: 8px;
	margin-bottom: 1rem;
	font-size: 0.9375rem;
	line-height: 1.5;
}

.expose-form__message--error {
	background: #fee;
	border: 1px solid #fcc;
	color: #c33;
}

.expose-form__message--success {
	background: #efe;
	border: 1px solid #cfc;
	color: #3c3;
}

/* CLAUDE: Submit-Button */
.expose-form__submit {
	width: 100%;
	padding: 1rem 1.5rem;
	font-size: 1rem;
	font-weight: 600;
	background: linear-gradient(135deg, #c19a6b 0%, #594834 100%);
	color: #ffffff;
	border: none;
	border-radius: 8px;
	cursor: pointer;
	transition: all 0.3s ease;
	box-shadow: 0 4px 12px rgba(102, 126, 234, 0.3);
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
}

.expose-form__submit:hover:not(:disabled) {
	background: linear-gradient(135deg, #c19a6b 0%, #594834 100%);
	box-shadow: 0 6px 20px rgba(102, 126, 234, 0.4);
	transform: translateY(-2px);
}

.expose-form__submit:active:not(:disabled) {
	transform: translateY(0);
}

.expose-form__submit:disabled {
	opacity: 0.6;
	cursor: not-allowed;
}

/* CLAUDE: Loading-Spinner im Button */
.button__loading {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
}

.spinner {
	width: 1rem;
	height: 1rem;
	border: 2px solid rgba(255, 255, 255, 0.3);
	border-top-color: #fff;
	border-radius: 50%;
	animation: expose-spin 0.8s linear infinite;
}

/* CLAUDE: Info-Text unter Formular */
.expose-modal__info {
	text-align: center;
	font-size: 0.8125rem;
	color: #999;
	margin: 1.5rem 0 0 0;
	line-height: 1.5;
}

/* ========================================
   CLAUDE: Responsive Modal
   ======================================== */

@media (max-width: 640px) {
	/* CLAUDE: Kleineres Modal auf Mobile */
	.expose-modal__container {
		max-width: 100%;
		border-radius: 12px;
		margin: 0 0.5rem;
	}

	/* CLAUDE: Kompakteres Padding */
	.expose-modal__content {
		padding: 2.5rem 1.5rem 1.5rem;
	}

	/* CLAUDE: Einspaltige Reihe auf Mobile */
	.expose-form__row {
		grid-template-columns: 1fr;
	}

	/* CLAUDE: Kleinerer Titel */
	.expose-modal__title {
		font-size: 1.5rem;
	}

	/* CLAUDE: Kleineres Icon */
	.expose-modal__icon {
		font-size: 3rem;
	}
}

/* ========================================
   CLAUDE: Accessibility & Focus-States
   ======================================== */

/* CLAUDE: Fokus-Ring für Keyboard-Navigation */
.expose-modal__close:focus,
.expose-form__input:focus,
.expose-form__submit:focus {
	outline: 3px solid rgba(102, 126, 234, 0.5);
	outline-offset: 2px;
}

/* CLAUDE: Verhindere Text-Selection im Overlay */
.expose-modal__overlay {
	user-select: none;
}
