/**
 * Bookdragons Fan Art: CTA-Sektion, Off-Canvas-Formular, Drag&Drop-Upload,
 * Dashboard-Grid. Brand-Palette: Rose, Anthrazit, Gold, Cream.
 */
.bd-fanart-cta,
.bd-fanart-panel,
.bd-fanart-mine {
	--bd-rose: #C4707A;
	--bd-ink: #2D2926;
	--bd-gold: #D4A547;
	--bd-cream: #FAF7F2;
	--bd-line: rgba(45, 41, 38, 0.14);
	box-sizing: border-box;
}
.bd-fanart-cta *,
.bd-fanart-panel *,
.bd-fanart-mine * { box-sizing: border-box; }

/* ---------------- CTA-Sektion ---------------- */
.bd-fanart-cta {
	background: #f4d6da;
	border-radius: 18px;
	padding: 32px 36px;
	text-align: left;
}

/* Zwei-Spalten-Layout, wenn ein Bild gesetzt ist */
.bd-fanart-cta.has-media {
	display: grid;
	grid-template-columns: 1fr var(--bd-media-col, 320px);
	gap: 32px;
	align-items: center;
}
.bd-fanart-cta.has-media.media-left {
	grid-template-columns: var(--bd-media-col, 320px) 1fr;
}
.bd-fanart-cta.media-left .bd-fanart-cta-media {
	order: -1;
}
.bd-fanart-cta-media {
	min-width: 0;
}
.bd-fanart-cta-media img,
.bd-fanart-cta-img {
	display: block;
	width: 100%;
	height: auto;
}

@media (max-width: 768px) {
	.bd-fanart-cta.has-media,
	.bd-fanart-cta.has-media.media-left {
		grid-template-columns: 1fr;
	}
	.bd-fanart-cta.media-left .bd-fanart-cta-media {
		order: 0;
	}
}
.bd-fanart-cta-title {
	margin: 0 0 10px;
	color: var(--bd-ink);
	font-size: 1.6rem;
}
.bd-fanart-cta-text,
.bd-fanart-cta-guest {
	margin: 0 0 18px;
	color: var(--bd-ink);
	max-width: 46ch;
	line-height: 1.5;
}
.bd-fanart-cta-guest { font-size: 0.95rem; opacity: 0.85; }
.bd-fanart-cta-btn {
	display: inline-block;
	box-sizing: border-box;
	-webkit-appearance: none;
	appearance: none;
	background: var(--bd-rose);
	color: #fff;
	border: none;
	border-radius: 999px;
	padding: 12px 26px;
	font-family: inherit;
	font-size: 1rem;
	font-weight: 600;
	line-height: 1.4;
	text-align: center;
	vertical-align: middle;
	cursor: pointer;
	text-decoration: none;
	transition: filter 0.15s ease, transform 0.15s ease;
}
.bd-fanart-cta-btn:hover { filter: brightness(1.07); transform: translateY(-1px); }

/* ---------------- Off-Canvas-Panel ---------------- */
body.bd-fanart-noscroll { overflow: hidden; }
.bd-fanart-panel {
	position: fixed;
	inset: 0;
	z-index: 99990;
}
.bd-fanart-panel-overlay {
	position: absolute;
	inset: 0;
	background: rgba(45, 41, 38, 0.55);
	opacity: 0;
	transition: opacity 0.25s ease;
}
.bd-fanart-panel.is-open .bd-fanart-panel-overlay { opacity: 1; }
.bd-fanart-panel-inner {
	position: absolute;
	top: 0;
	right: 0;
	height: 100%;
	width: min(480px, 100%);
	background: var(--bd-cream);
	box-shadow: -8px 0 32px rgba(0, 0, 0, 0.18);
	padding: 28px 28px 40px;
	overflow-y: auto;
	transform: translateX(100%);
	transition: transform 0.28s cubic-bezier(0.4, 0, 0.2, 1);
}
.bd-fanart-panel.is-open .bd-fanart-panel-inner { transform: translateX(0); }
.bd-fanart-panel-x {
	position: absolute;
	top: 14px;
	right: 16px;
	background: none;
	border: none;
	font-size: 28px;
	line-height: 1;
	color: var(--bd-ink);
	cursor: pointer;
	opacity: 0.6;
}
.bd-fanart-panel-x:hover { opacity: 1; }
.bd-fanart-panel-title {
	margin: 0 0 18px;
	color: var(--bd-ink);
	font-size: 1.35rem;
}

/* ---------------- Formularfelder ---------------- */
.bd-fanart-field { margin-bottom: 16px; }
.bd-fanart-row { display: flex; gap: 14px; }
.bd-fanart-row .bd-fanart-field { flex: 1; }
.bd-fanart-field label,
.bd-fanart-grouplabel {
	display: block;
	margin-bottom: 6px;
	font-weight: 600;
	font-size: 0.9rem;
	color: var(--bd-ink);
}
.bd-fanart-field input[type="text"],
.bd-fanart-field textarea {
	width: 100%;
	padding: 10px 12px;
	border: 1px solid var(--bd-line);
	border-radius: 10px;
	font: inherit;
	background: #fff;
	color: var(--bd-ink);
}
.bd-fanart-field input:focus,
.bd-fanart-field textarea:focus {
	outline: none;
	border-color: var(--bd-rose);
	box-shadow: 0 0 0 3px rgba(196, 112, 122, 0.18);
}
.bd-req { color: var(--bd-rose); }
.bd-fanart-hint { display: block; margin-top: 6px; font-size: 0.78rem; opacity: 0.7; }

.bd-fanart-radio {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	font-weight: 400 !important;
	margin-bottom: 6px;
	cursor: pointer;
}
.bd-fanart-radio input { margin-top: 3px; }
.bd-fanart-ai-note { margin-top: 8px; }

.bd-fanart-checkbox label {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	font-weight: 400;
	cursor: pointer;
	line-height: 1.4;
}
.bd-fanart-checkbox input { margin-top: 3px; }
.bd-fanart-checkbox a { color: var(--bd-rose); }
.bd-fanart-invalid { border-color: #d6455f !important; box-shadow: 0 0 0 3px rgba(214, 69, 95, 0.15) !important; }

/* ---------------- Drag & Drop ---------------- */
.bd-fanart-drop {
	position: relative;
	border: 2px dashed var(--bd-rose);
	border-radius: 14px;
	background: rgba(196, 112, 122, 0.06);
	min-height: 180px;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	margin-bottom: 18px;
	overflow: hidden;
	transition: background 0.15s ease, border-color 0.15s ease;
}
.bd-fanart-drop.is-dragover { background: rgba(196, 112, 122, 0.16); border-color: var(--bd-gold); }
.bd-fanart-file {
	position: absolute;
	inset: 0;
	opacity: 0;
	cursor: pointer;
}
.bd-fanart-drop.has-file .bd-fanart-file { pointer-events: none; }
.bd-fanart-drop-empty {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 6px;
	padding: 20px;
	color: var(--bd-ink);
	pointer-events: none;
}
.bd-fanart-drop-icon { font-size: 32px; color: var(--bd-rose); }
.bd-fanart-drop-text { font-weight: 600; }
.bd-fanart-drop-empty small { opacity: 0.65; }
.bd-fanart-preview {
	position: relative;
	width: 100%;
	height: 100%;
}
.bd-fanart-preview img {
	display: block;
	width: 100%;
	max-height: 320px;
	object-fit: contain;
	background: #fff;
}
.bd-fanart-preview-remove {
	position: absolute;
	top: 8px;
	right: 8px;
	width: 30px;
	height: 30px;
	border-radius: 50%;
	border: none;
	background: rgba(45, 41, 38, 0.75);
	color: #fff;
	font-size: 18px;
	line-height: 1;
	cursor: pointer;
	z-index: 2;
}

/* ---------------- Submit-Button ---------------- */
.bd-fanart-submit {
	position: relative;
	width: 100%;
	background: var(--bd-rose);
	color: #fff;
	border: none;
	border-radius: 999px;
	padding: 13px 20px;
	font-weight: 600;
	font-size: 1rem;
	cursor: pointer;
	margin-top: 6px;
	transition: filter 0.15s ease;
}
.bd-fanart-submit:hover { filter: brightness(1.07); }
.bd-fanart-submit.is-loading { color: transparent; pointer-events: none; }
.bd-fanart-submit.is-loading .bd-fanart-spinner {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 20px;
	height: 20px;
	margin: -10px 0 0 -10px;
	border: 2px solid rgba(255, 255, 255, 0.4);
	border-top-color: #fff;
	border-radius: 50%;
	animation: bd-fanart-spin 0.7s linear infinite;
}
@keyframes bd-fanart-spin { to { transform: rotate(360deg); } }

.bd-fanart-message {
	margin-top: 14px;
	padding: 10px 14px;
	border-radius: 10px;
	background: rgba(214, 69, 95, 0.1);
	color: #a3203a;
	font-size: 0.9rem;
}

/* ---------------- Erfolg ---------------- */
.bd-fanart-success { text-align: center; padding: 40px 10px; }
.bd-fanart-success-icon {
	width: 56px;
	height: 56px;
	margin: 0 auto 14px;
	border-radius: 50%;
	background: var(--bd-gold);
	color: #fff;
	font-size: 28px;
	line-height: 56px;
}
.bd-fanart-success h4 { margin: 0 0 8px; color: var(--bd-ink); }
.bd-fanart-success p { color: var(--bd-ink); opacity: 0.85; line-height: 1.5; }

/* ---------------- Dashboard: Meine Fan Art ---------------- */
.bd-fanart-mine-title { margin: 0 0 18px; color: var(--bd-ink); }
.bd-fanart-mine-empty,
.bd-fanart-mine-guest { color: var(--bd-ink); opacity: 0.8; margin-bottom: 14px; }
.bd-fanart-mine-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: 18px;
}
.bd-fanart-mine-card {
	background: #fff;
	border: 1px solid var(--bd-line);
	border-radius: 14px;
	overflow: hidden;
	display: flex;
	flex-direction: column;
}
.bd-fanart-mine-thumb {
	position: relative;
	aspect-ratio: 4 / 3;
	background: var(--bd-cream);
}
.bd-fanart-mine-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.bd-fanart-badge {
	position: absolute;
	top: 10px;
	left: 10px;
	padding: 4px 10px;
	border-radius: 999px;
	font-size: 0.72rem;
	font-weight: 600;
	color: #fff;
	background: var(--bd-ink);
}
.bd-fanart-badge.is-pending { background: var(--bd-gold); }
.bd-fanart-badge.is-publish { background: var(--bd-rose); }
.bd-fanart-mine-body { padding: 12px 14px 14px; }
.bd-fanart-mine-cardtitle { margin: 0 0 8px; font-size: 1rem; color: var(--bd-ink); }
.bd-fanart-mine-meta {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
}
.bd-fanart-mine-votes { color: var(--bd-rose); font-weight: 600; font-size: 0.9rem; }
.bd-fanart-mine-share {
	background: none;
	border: none;
	color: var(--bd-rose);
	font-weight: 600;
	cursor: pointer;
	font-size: 0.88rem;
	padding: 4px 6px;
}
.bd-fanart-mine-share:hover { text-decoration: underline; }

/* ---------------- Responsive ---------------- */
@media (max-width: 600px) {
	.bd-fanart-row { flex-direction: column; gap: 0; }
	.bd-fanart-cta { padding: 24px 20px; }
}
