/* ==========================================================================
   Boogie Kathi Shop – Frontend-Layout
   Ergänzung zum Theme (dark maroon / gold accent).
   ========================================================================== */

/* ---------- Gemeinsame Komponenten ---------- */
.bk-shop-msg {
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid rgba(255, 255, 255, 0.1);
	color: var(--bk-white-70);
	padding: 1.25rem 1.5rem;
	border-radius: var(--bk-radius);
	margin: 1.5rem auto;
	max-width: 640px;
	text-align: center;
}
.bk-shop-msg--info {
	border-color: rgba(212, 168, 83, 0.35);
	background: rgba(212, 168, 83, 0.08);
}
.bk-shop-msg a { color: var(--bk-gold-400); text-decoration: underline; }
.bk-shop-msg a:hover { color: var(--bk-gold-300); }

/* ---------- Warenkorb ---------- */
.bk-shop-cart {
	max-width: 960px;
	margin: 0 auto;
	background: rgba(255, 255, 255, 0.03);
	padding: 1.5rem;
	border-radius: var(--bk-radius-lg);
	border: 1px solid rgba(255, 255, 255, 0.08);
}

.bk-shop-table {
	width: 100%;
	border-collapse: collapse;
	color: var(--bk-white);
}
.bk-shop-table th {
	text-align: left;
	font-size: 0.8rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--bk-gold-400);
	padding: 0.75rem;
	border-bottom: 1px solid rgba(255, 255, 255, 0.15);
}
.bk-shop-table td {
	padding: 1rem 0.75rem;
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
	vertical-align: middle;
}
.bk-shop-table tr:last-child td { border-bottom: 0; }

.bk-shop-qty {
	width: 4rem;
	padding: 0.4rem 0.6rem;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: var(--bk-radius);
	color: var(--bk-white);
	font-size: 1rem;
	margin-right: 0.5rem;
}

.bk-shop-cart .button,
.bk-shop-form .button {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.5rem 1rem;
	background: rgba(255, 255, 255, 0.08);
	color: var(--bk-white);
	border: 1px solid rgba(255, 255, 255, 0.25);
	border-radius: var(--bk-radius);
	cursor: pointer;
	font-family: var(--bk-font-body);
	font-size: 0.85rem;
	font-weight: 500;
	text-transform: none;
	letter-spacing: 0;
	transition: all var(--bk-transition);
	text-decoration: none;
}
.bk-shop-cart .button:hover,
.bk-shop-form .button:hover {
	background: rgba(212, 168, 83, 0.15);
	border-color: var(--bk-gold-400);
	color: var(--bk-gold-400);
}

.bk-shop-cart .button-primary,
.bk-shop-form .button-primary {
	background: var(--bk-gold-500);
	border-color: var(--bk-gold-500);
	color: var(--bk-maroon-900);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	padding: 0.75rem 1.5rem;
}
.bk-shop-cart .button-primary:hover,
.bk-shop-form .button-primary:hover {
	background: var(--bk-gold-300);
	border-color: var(--bk-gold-300);
	color: var(--bk-maroon-900);
}

.bk-shop-cart button.link {
	background: none;
	border: 0;
	padding: 0.25rem 0;
	margin-top: 0.35rem;
	color: var(--bk-white-50);
	font-size: 0.8rem;
	cursor: pointer;
	text-decoration: underline;
}
.bk-shop-cart button.link:hover { color: var(--bk-red); }

.bk-shop-total {
	font-size: 1.15rem;
	color: var(--bk-gold-400);
	text-align: right;
	margin: 1.25rem 0;
}
.bk-shop-total strong { color: var(--bk-white); margin-right: 0.5rem; }

/* ---------- Checkout-Formular ---------- */
.bk-shop-checkout {
	max-width: 780px;
	margin: 0 auto;
}

.bk-shop-errors {
	background: rgba(192, 57, 43, 0.12);
	border: 1px solid var(--bk-red);
	color: #ffb2a6;
	padding: 1rem 1.25rem;
	border-radius: var(--bk-radius);
	margin-bottom: 1.5rem;
}
.bk-shop-errors ul { margin: 0; padding-left: 1.25rem; }

.bk-shop-form fieldset {
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: var(--bk-radius-lg);
	padding: 1.5rem;
	margin: 0 0 1.5rem;
	background: rgba(0, 0, 0, 0.12);
}
.bk-shop-form legend {
	padding: 0 0.75rem;
	color: var(--bk-gold-400);
	font-family: var(--bk-font-heading);
	font-size: 1.1rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

.bk-shop-form p { margin: 0 0 1rem; }
.bk-shop-form label {
	display: block;
	color: var(--bk-white-70);
	font-size: 0.85rem;
	letter-spacing: 0.04em;
	margin-bottom: 0.35rem;
}

.bk-shop-form input[type="text"],
.bk-shop-form input[type="email"],
.bk-shop-form input[type="number"],
.bk-shop-form input[type="tel"],
.bk-shop-form textarea {
	width: 100%;
	max-width: 100%;
	padding: 0.7rem 0.9rem;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: var(--bk-radius);
	color: var(--bk-white);
	font-family: var(--bk-font-body);
	font-size: 1rem;
	transition: border-color var(--bk-transition), background var(--bk-transition);
}
.bk-shop-form input:focus,
.bk-shop-form textarea:focus {
	outline: none;
	border-color: var(--bk-gold-400);
	background: rgba(255, 255, 255, 0.1);
}
.bk-shop-form textarea { min-height: 96px; resize: vertical; }

.bk-shop-form .description {
	font-size: 0.82rem;
	color: var(--bk-white-50);
	margin-top: -0.5rem;
}

.bk-shop-form input[type="checkbox"] {
	accent-color: var(--bk-gold-400);
	margin-right: 0.4rem;
	vertical-align: middle;
}

/* ---------- Danke-Seite ---------- */
.bk-shop-thankyou {
	max-width: 640px;
	margin: 0 auto;
	background: rgba(212, 168, 83, 0.08);
	border: 1px solid rgba(212, 168, 83, 0.35);
	padding: 2rem;
	border-radius: var(--bk-radius-lg);
	text-align: center;
	color: var(--bk-white);
}
.bk-shop-thankyou p { margin-bottom: 1rem; color: var(--bk-white-70); }
.bk-shop-thankyou p strong { color: var(--bk-gold-400); }

/* ---------- Produkt-Grid ---------- */
.bk-product-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: 1.5rem;
	margin-top: 2rem;
}

.bk-product-card--lg { background: var(--bk-maroon-700); border-radius: var(--bk-radius-lg); overflow: hidden; text-align: left; padding: 0; }
.bk-product-card--lg .bk-product-card__image { aspect-ratio: 4 / 3; margin-bottom: 0; display: block; }
.bk-product-card--lg .bk-product-card__body { padding: 1rem 1.25rem 1.25rem; }
.bk-product-card--lg .bk-product-card__title { font-size: 1rem; margin: 0.5rem 0 0.35rem; text-align: left; }
.bk-product-card--lg .bk-product-card__price { font-size: 1.05rem; color: var(--bk-gold-400); margin-bottom: 0.75rem; text-align: left; }
.bk-product-card--lg .bk-product-card__title a { color: var(--bk-white); }
.bk-product-card--lg .bk-product-card__title a:hover { color: var(--bk-gold-400); }

.bk-product-card__placeholder {
	width: 100%;
	height: 100%;
	min-height: 140px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--bk-maroon-600), var(--bk-maroon-800));
	color: var(--bk-gold-400);
	font-size: 3rem;
	font-family: var(--bk-font-heading);
}

/* ---------- Einzelner Shop-Artikel ---------- */
.bk-product-single { padding: 4rem 0; background: var(--bk-maroon-900); }

.bk-product-single__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2.5rem;
	max-width: 1040px;
	margin: 0 auto 3rem;
}

.bk-product-single__media {
	background: var(--bk-maroon-800);
	border-radius: var(--bk-radius-lg);
	overflow: hidden;
	box-shadow: var(--bk-shadow);
}
.bk-product-single__image { width: 100%; height: auto; display: block; }
.bk-product-single__placeholder {
	aspect-ratio: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 6rem;
	color: var(--bk-gold-400);
	font-family: var(--bk-font-heading);
	background: linear-gradient(135deg, var(--bk-maroon-700), var(--bk-maroon-900));
}

.bk-product-single__info {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.bk-product-single__price-row {
	display: flex;
	align-items: center;
	gap: 1rem;
	flex-wrap: wrap;
}
.bk-product-single__price {
	font-family: var(--bk-font-heading);
	font-size: clamp(1.75rem, 4vw, 2.5rem);
	color: var(--bk-gold-400);
	font-weight: 700;
}

.bk-product-single__sku {
	color: var(--bk-white-50);
	font-size: 0.85rem;
	letter-spacing: 0.03em;
}

.bk-product-single__excerpt { color: var(--bk-white-70); font-size: 1rem; line-height: 1.7; }

.bk-product-single__features {
	list-style: none;
	padding: 0;
	margin: 0.5rem 0 0;
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
}
.bk-product-single__features li {
	position: relative;
	padding-left: 1.25rem;
	color: var(--bk-white-70);
	font-size: 0.95rem;
}
.bk-product-single__features li::before {
	content: '♪';
	position: absolute;
	left: 0;
	color: var(--bk-gold-400);
}

.bk-product-single__desc {
	max-width: 800px;
	margin: 0 auto 3rem;
}
.bk-product-single__desc-title {
	color: var(--bk-gold-400);
	font-size: 1.5rem;
	border-bottom: 1px solid rgba(255, 255, 255, 0.1);
	padding-bottom: 0.75rem;
	margin-bottom: 1.5rem;
}

.bk-product-single__related { max-width: 1040px; margin: 0 auto; }
.bk-product-single__related .bk-section-title { color: var(--bk-gold-400); margin-bottom: 1.5rem; }

/* ---------- Produkt-Badge (digital / versand) ---------- */
.bk-product-meta__badge {
	display: inline-block;
	padding: 0.25rem 0.75rem;
	border-radius: 20px;
	background: rgba(255, 255, 255, 0.1);
	color: var(--bk-white-70);
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-weight: 600;
}
.bk-product-meta__badge--digital {
	background: rgba(212, 168, 83, 0.2);
	color: var(--bk-gold-400);
}

/* ---------- Shop-Archive ---------- */
.bk-shop-archive {
	padding: 4rem 0 5rem;
	background: var(--bk-maroon-900);
}

/* ---------- Page-Hero-Lead / Eyebrow ---------- */
.bk-page-hero__lead {
	color: var(--bk-white-70);
	margin: 1rem auto 0;
	font-size: 1.1rem;
	max-width: 600px;
}
.bk-page-hero__eyebrow {
	color: var(--bk-gold-400);
	text-transform: uppercase;
	letter-spacing: 0.15em;
	font-size: 0.82rem;
	font-weight: 600;
	margin-bottom: 0.75rem;
}

/* ---------- Kontakt-Fallback (Ninja-Form-Ersatz) ---------- */
.bk-contact-fallback {
	max-width: 560px;
	margin: 2rem auto;
	padding: 2rem;
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: var(--bk-radius-lg);
	text-align: center;
}
.bk-contact-fallback p { color: var(--bk-white-70); margin-bottom: 1rem; }
.bk-contact-fallback__lines {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	justify-content: center;
}

/* ---------- Legacy-Event-Block (Ersatz für event_calendar / performance_archive) ---------- */
.bk-legacy-events {
	margin: 2rem 0;
	color: var(--bk-white);
}
.bk-legacy-events__month {
	font-family: var(--bk-font-heading);
	font-size: 1.05rem;
	color: var(--bk-gold-400);
	text-transform: uppercase;
	letter-spacing: 0.12em;
	padding: 0.6rem 0;
	border-bottom: 1px solid rgba(212, 168, 83, 0.35);
	margin: 1.75rem 0 1rem;
}
.bk-legacy-events .bk-event-row {
	background: rgba(255, 255, 255, 0.04);
	border-radius: var(--bk-radius);
	border-bottom: 0;
	margin-bottom: 0.75rem;
	padding: 1rem 1.25rem;
	color: var(--bk-white);
}
.bk-legacy-events .bk-event-row__title a,
.bk-legacy-events .bk-event-row__title { color: var(--bk-white); }
.bk-legacy-events .bk-event-row__title a:hover { color: var(--bk-gold-400); }
.bk-legacy-events .bk-event-row__meta { color: var(--bk-gold-400); }
.bk-legacy-events .bk-event-row__venue,
.bk-legacy-events .bk-event-row__doors,
.bk-legacy-events .bk-event-row__ensemble { color: var(--bk-white-70); }
.bk-legacy-events .bk-event-row__price { color: var(--bk-gold-400); }

/* ---------- Legacy-Bild-Galerie (aus Elementor-Content gruppiert) ---------- */
.bk-legacy-gallery {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
	gap: 1rem;
	margin: 1.5rem 0;
}
.bk-legacy-gallery img {
	width: 100%;
	height: 100%;
	max-height: 260px;
	object-fit: cover;
	border-radius: var(--bk-radius);
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.35);
	transition: transform var(--bk-transition);
	background: var(--bk-maroon-700);
}
.bk-legacy-gallery img:hover { transform: translateY(-2px); }
.bk-legacy-gallery p { margin: 0; } /* falls wpautop einzelne <p><img></p> hinterlässt */

/* ---------- Sicherstellen: Standard-Pages haben dunklen Grund ---------- */
.bk-page-content { background: var(--bk-maroon-900); color: var(--bk-white-70); }
.bk-page-content .bk-prose { color: var(--bk-white-70); }

/* ---------- Responsive ---------- */
@media (min-width: 768px) {
	.bk-product-single__grid {
		grid-template-columns: 1fr 1fr;
		align-items: start;
		gap: 3rem;
	}
}

@media (min-width: 1024px) {
	.bk-product-single__grid { grid-template-columns: 1.1fr 1fr; }
	.bk-product-grid { grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); }
}
