/*
Theme Name: Bayou Bombastic
Theme URI: https://bayoubombastic.com
Author: Elijah Dixon & The Bayou Bombastic
Description: A cinematic Twenty Twenty-Five child theme for Elijah Dixon & The Bayou Bombastic, built for music storytelling, song catalogs, video promos, email capture, and WooCommerce digital downloads.
Requires at least: 6.7
Tested up to: 6.8
Requires PHP: 7.4
Version: 1.0.0
Template: twentytwentyfive
Text Domain: bayou-bombastic
Tags: block-patterns, block-styles, full-site-editing, entertainment, e-commerce
*/

:root {
	--bayou-blackwater: #070a08;
	--bayou-charcoal: #12110e;
	--bayou-panel: #18140f;
	--bayou-panel-soft: #211a12;
	--bayou-tobacco: #6f4528;
	--bayou-rust: #b9612e;
	--bayou-ember: #d18a4b;
	--bayou-gold: #b88d52;
	--bayou-smoke: #eadfcf;
	--bayou-muted: #b7a48e;
	--bayou-moon: #66707a;
	--bayou-line: rgba(184, 141, 82, 0.38);
	--bayou-shadow: 0 24px 70px rgba(0, 0, 0, 0.45);
	--bayou-radius: 6px;
}

html {
	scroll-behavior: smooth;
}

body {
	background: var(--bayou-blackwater);
	color: var(--bayou-smoke);
	font-family: Inter, Arial, sans-serif;
	letter-spacing: 0;
}

body::before {
	background-image:
		linear-gradient(rgba(255, 255, 255, 0.025) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255, 255, 255, 0.018) 1px, transparent 1px);
	background-size: 9px 9px, 11px 11px;
	bottom: 0;
	content: "";
	left: 0;
	opacity: 0.34;
	pointer-events: none;
	position: fixed;
	right: 0;
	top: 0;
	z-index: 999;
}

a {
	color: var(--bayou-ember);
	text-decoration-thickness: 1px;
	text-underline-offset: 0.18em;
}

.wp-site-blocks {
	background:
		linear-gradient(180deg, rgba(7, 10, 8, 0.86), rgba(7, 10, 8, 0.96) 46%, #070a08),
		linear-gradient(115deg, rgba(185, 97, 46, 0.12), transparent 34%),
		linear-gradient(245deg, rgba(111, 69, 40, 0.12), transparent 38%);
	overflow-x: clip;
}

.bayou-header {
	background: rgba(7, 10, 8, 0.64);
	border-bottom: 1px solid rgba(184, 141, 82, 0.22);
	backdrop-filter: blur(10px);
	position: sticky;
	top: 0;
	transition: background 180ms ease, box-shadow 180ms ease;
	z-index: 50;
}

.bayou-is-scrolled .bayou-header {
	background: rgba(7, 10, 8, 0.97);
	box-shadow: 0 12px 42px rgba(0, 0, 0, 0.45);
}

.bayou-header-inner {
	align-items: center;
	display: flex;
	gap: 1.5rem;
	justify-content: space-between;
	min-height: 74px;
}

.bayou-logo img {
	display: block;
	height: auto;
	max-width: 220px;
}

.bayou-main-nav .wp-block-navigation-item__content {
	color: var(--bayou-smoke);
	font-family: Georgia, "Times New Roman", serif;
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0;
	text-transform: uppercase;
}

.bayou-main-nav .wp-block-navigation-item__content:hover,
.bayou-main-nav .wp-block-navigation-item__content:focus {
	color: var(--bayou-ember);
}

.wp-block-navigation__responsive-container.is-menu-open {
	background: var(--bayou-blackwater);
	color: var(--bayou-smoke);
	padding: 1.25rem;
}

.wp-block-navigation__responsive-container-open,
.wp-block-navigation__responsive-container-close {
	color: var(--bayou-smoke);
}

.bayou-header-cta .wp-block-button__link,
.bayou-button-primary .wp-block-button__link,
.bayou-button-secondary .wp-block-button__link,
.bayou-button-small .wp-block-button__link {
	border-radius: 0;
	font-family: Inter, Arial, sans-serif;
	font-size: 0.78rem;
	font-weight: 800;
	letter-spacing: 0;
	padding: 0.82rem 1.1rem;
	text-transform: uppercase;
	transition: background 160ms ease, border-color 160ms ease, color 160ms ease, transform 160ms ease;
}

.bayou-header-cta .wp-block-button__link,
.bayou-button-secondary .wp-block-button__link,
.bayou-button-small.is-style-outline .wp-block-button__link {
	background: transparent;
	border: 1px solid var(--bayou-rust);
	color: var(--bayou-smoke);
}

.bayou-button-primary .wp-block-button__link {
	background: var(--bayou-rust);
	border: 1px solid var(--bayou-rust);
	color: #fff7ec;
}

.bayou-button-small .wp-block-button__link {
	background: rgba(185, 97, 46, 0.82);
	border: 1px solid rgba(209, 138, 75, 0.7);
	color: #fff7ec;
	padding: 0.64rem 0.86rem;
}

.bayou-header-cta .wp-block-button__link:hover,
.bayou-button-primary .wp-block-button__link:hover,
.bayou-button-secondary .wp-block-button__link:hover,
.bayou-button-small .wp-block-button__link:hover {
	background: var(--bayou-ember);
	border-color: var(--bayou-ember);
	color: #100c08;
	transform: translateY(-1px);
}

.bayou-section {
	border-top: 1px solid rgba(184, 141, 82, 0.15);
	padding-bottom: 4rem;
	padding-top: 4rem;
	position: relative;
}

.bayou-section-heading {
	color: var(--bayou-smoke);
	font-family: Georgia, "Times New Roman", serif;
	font-size: 2.15rem;
	font-weight: 800;
	line-height: 1.04;
	margin-bottom: 0.6rem;
	text-transform: uppercase;
}

.bayou-section-kicker,
.bayou-kicker {
	color: var(--bayou-ember);
	font-size: 0.82rem;
	font-weight: 800;
	letter-spacing: 0;
	margin: 0 0 0.55rem;
	text-transform: uppercase;
}

.bayou-muted {
	color: var(--bayou-muted);
}

.bayou-hero {
	min-height: 720px;
}

.bayou-hero::before {
	background:
		linear-gradient(90deg, rgba(7, 10, 8, 0.96) 0%, rgba(7, 10, 8, 0.78) 36%, rgba(7, 10, 8, 0.24) 67%, rgba(7, 10, 8, 0.55) 100%),
		linear-gradient(180deg, rgba(7, 10, 8, 0.1), rgba(7, 10, 8, 0.88));
	content: "";
	inset: 0;
	position: absolute;
	z-index: 1;
}

.bayou-hero .wp-block-cover__inner-container {
	position: relative;
	z-index: 2;
}

.bayou-hero-content {
	max-width: 640px;
	padding-top: 4rem;
}

.bayou-display-title {
	color: var(--bayou-smoke);
	font-family: Georgia, "Times New Roman", serif;
	font-size: 5.25rem;
	font-weight: 900;
	line-height: 0.92;
	margin: 0;
	text-transform: uppercase;
	text-wrap: balance;
}

.bayou-hero-subtitle {
	color: var(--bayou-ember);
	font-size: 1.12rem;
	font-weight: 800;
	line-height: 1.35;
	margin-top: 0.9rem;
	text-transform: uppercase;
}

.bayou-hero-copy {
	color: rgba(234, 223, 207, 0.88);
	font-size: 1.02rem;
	line-height: 1.75;
	max-width: 560px;
}

.bayou-panel {
	background:
		linear-gradient(180deg, rgba(33, 26, 18, 0.96), rgba(18, 17, 14, 0.98)),
		linear-gradient(90deg, rgba(184, 141, 82, 0.1), transparent);
	border: 1px solid var(--bayou-line);
	border-radius: var(--bayou-radius);
	box-shadow: var(--bayou-shadow);
	position: relative;
}

.bayou-panel::before {
	border: 1px solid rgba(234, 223, 207, 0.07);
	border-radius: var(--bayou-radius);
	content: "";
	inset: 8px;
	pointer-events: none;
	position: absolute;
}

.bayou-feature-grid {
	display: grid;
	gap: 2rem;
	grid-template-columns: minmax(220px, 340px) minmax(0, 1fr) minmax(180px, 230px);
	position: relative;
	z-index: 1;
}

.bayou-feature-cover img,
.bayou-track-card img,
.bayou-product-card img,
.bayou-video-card img {
	aspect-ratio: 1 / 1;
	border-radius: 3px;
	display: block;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.bayou-feature-title {
	font-family: Georgia, "Times New Roman", serif;
	font-size: 2rem;
	line-height: 1.08;
	margin: 0 0 0.8rem;
}

.bayou-audio-strip {
	align-items: center;
	background: rgba(234, 223, 207, 0.08);
	border: 1px solid rgba(184, 141, 82, 0.16);
	color: var(--bayou-smoke);
	display: grid;
	font-size: 0.82rem;
	gap: 0.72rem;
	grid-template-columns: auto auto 1fr auto;
	margin: 1.5rem 0 1rem;
	min-height: 44px;
	padding: 0.65rem 0.85rem;
}

.bayou-play-dot {
	background: var(--bayou-smoke);
	clip-path: polygon(0 0, 100% 50%, 0 100%);
	display: inline-block;
	height: 15px;
	width: 13px;
}

.bayou-progress {
	background: rgba(234, 223, 207, 0.18);
	display: block;
	height: 4px;
	position: relative;
}

.bayou-progress::after {
	background: var(--bayou-gold);
	content: "";
	height: 4px;
	left: 0;
	position: absolute;
	top: 0;
	width: 48%;
}

.bayou-meta-list {
	border-left: 1px solid rgba(184, 141, 82, 0.22);
	display: grid;
	gap: 1rem;
	padding-left: 1.2rem;
}

.bayou-meta-label {
	color: var(--bayou-gold);
	display: block;
	font-size: 0.72rem;
	font-weight: 800;
	text-transform: uppercase;
}

.bayou-meta-value {
	color: var(--bayou-smoke);
	font-size: 0.94rem;
	line-height: 1.5;
}

.bayou-track-grid,
.bayou-product-grid,
.bayou-video-grid {
	display: grid;
	gap: 1.2rem;
	grid-template-columns: repeat(5, minmax(0, 1fr));
}

.bayou-track-card,
.bayou-product-card,
.bayou-video-card {
	background: rgba(18, 17, 14, 0.88);
	border: 1px solid rgba(184, 141, 82, 0.28);
	border-radius: 5px;
	min-width: 0;
	padding: 0.75rem;
	position: relative;
}

.bayou-track-card h3,
.bayou-product-card h3,
.bayou-video-card h3 {
	color: var(--bayou-smoke);
	font-family: Georgia, "Times New Roman", serif;
	font-size: 1rem;
	line-height: 1.12;
	margin: 0.75rem 0 0.45rem;
	text-transform: uppercase;
}

.bayou-track-card p,
.bayou-product-card p,
.bayou-video-card p {
	color: rgba(234, 223, 207, 0.78);
	font-size: 0.83rem;
	line-height: 1.45;
	margin-bottom: 0.75rem;
}

.bayou-card-actions {
	align-items: center;
	display: flex;
	gap: 0.55rem;
	justify-content: space-between;
	margin-top: auto;
}

.bayou-icon-link {
	align-items: center;
	border: 1px solid rgba(184, 141, 82, 0.45);
	border-radius: 50%;
	color: var(--bayou-smoke);
	display: inline-flex;
	font-size: 0.85rem;
	height: 34px;
	justify-content: center;
	line-height: 1;
	text-decoration: none;
	width: 34px;
}

.bayou-icon-link:hover,
.bayou-icon-link:focus {
	background: var(--bayou-ember);
	border-color: var(--bayou-ember);
	color: #100c08;
}

.bayou-tag-row {
	display: flex;
	flex-wrap: wrap;
	gap: 0.65rem;
	margin-top: 1.4rem;
}

.bayou-tag {
	border: 1px solid rgba(184, 141, 82, 0.34);
	border-radius: 999px;
	color: var(--bayou-smoke);
	font-size: 0.76rem;
	font-weight: 700;
	padding: 0.5rem 0.72rem;
	text-transform: uppercase;
}

.bayou-about-band {
	background:
		linear-gradient(90deg, rgba(18, 17, 14, 0.96) 0%, rgba(18, 17, 14, 0.84) 48%, rgba(18, 17, 14, 0.4)),
		var(--bayou-panel);
	overflow: hidden;
}

.bayou-about-band figure img {
	min-height: 320px;
	object-fit: cover;
	width: 100%;
}

.bayou-product-card {
	align-content: start;
	display: grid;
	grid-template-columns: 78px minmax(0, 1fr) auto;
	gap: 0.75rem;
}

.bayou-product-card img {
	aspect-ratio: 1 / 1;
}

.bayou-product-card h3 {
	margin-top: 0;
}

.bayou-product-price {
	color: var(--bayou-smoke);
	font-size: 0.86rem;
	font-weight: 800;
}

.bayou-product-format {
	color: var(--bayou-muted);
	font-size: 0.72rem;
	text-transform: uppercase;
}

.bayou-video-card {
	padding: 0.55rem;
}

.bayou-video-thumb {
	position: relative;
}

.bayou-video-thumb::after {
	align-items: center;
	background: rgba(7, 10, 8, 0.7);
	border: 1px solid rgba(234, 223, 207, 0.7);
	border-radius: 50%;
	color: var(--bayou-smoke);
	content: "Play";
	display: flex;
	font-size: 0.68rem;
	font-weight: 800;
	height: 54px;
	justify-content: center;
	left: 50%;
	position: absolute;
	text-transform: uppercase;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 54px;
}

.bayou-signup {
	background-position: center;
	background-size: cover;
	border-top: 1px solid rgba(184, 141, 82, 0.24);
	position: relative;
}

.bayou-signup::before {
	background: linear-gradient(90deg, rgba(18, 17, 14, 0.98), rgba(18, 17, 14, 0.74), rgba(18, 17, 14, 0.6));
	content: "";
	inset: 0;
	position: absolute;
}

.bayou-signup > * {
	position: relative;
	z-index: 1;
}

.bayou-signup-form {
	display: grid;
	gap: 0.65rem;
	grid-template-columns: minmax(180px, 1fr) auto;
	max-width: 560px;
}

.bayou-signup-form input[type="email"],
.woocommerce input.input-text,
.woocommerce textarea,
.woocommerce select {
	background: rgba(234, 223, 207, 0.92);
	border: 1px solid rgba(184, 141, 82, 0.48);
	border-radius: 0;
	color: #110d09;
	min-height: 44px;
	padding: 0.78rem 0.9rem;
	width: 100%;
}

.bayou-signup-form button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.wc-block-components-button,
.wp-block-woocommerce-product-button .wp-block-button__link {
	background: var(--bayou-rust);
	border: 1px solid var(--bayou-rust);
	border-radius: 0;
	color: #fff7ec;
	cursor: pointer;
	font-size: 0.78rem;
	font-weight: 800;
	letter-spacing: 0;
	padding: 0.78rem 1rem;
	text-transform: uppercase;
}

.bayou-signup-form button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.wc-block-components-button:hover {
	background: var(--bayou-ember);
	border-color: var(--bayou-ember);
	color: #100c08;
}

.bayou-footer {
	background: #050705;
	border-top: 1px solid rgba(184, 141, 82, 0.24);
	color: var(--bayou-muted);
}

.bayou-footer a {
	color: var(--bayou-smoke);
	text-decoration: none;
}

.bayou-footer a:hover,
.bayou-footer a:focus {
	color: var(--bayou-ember);
}

.bayou-social-row {
	display: flex;
	flex-wrap: wrap;
	gap: 0.65rem;
}

.bayou-social-row a {
	align-items: center;
	border: 1px solid rgba(184, 141, 82, 0.35);
	border-radius: 50%;
	display: inline-flex;
	font-size: 0.76rem;
	height: 36px;
	justify-content: center;
	width: 36px;
}

.bayou-page-hero,
.bayou-archive-hero,
.bayou-song-hero {
	background:
		linear-gradient(90deg, rgba(7, 10, 8, 0.98), rgba(7, 10, 8, 0.78)),
		url("assets/images/hero-bayou.jpg") center / cover no-repeat;
	border-bottom: 1px solid rgba(184, 141, 82, 0.22);
	padding-bottom: 5rem;
	padding-top: 5rem;
}

.bayou-content-frame {
	background: rgba(18, 17, 14, 0.88);
	border: 1px solid rgba(184, 141, 82, 0.24);
	border-radius: var(--bayou-radius);
	padding: 2rem;
}

.bayou-content-frame > *:first-child {
	margin-top: 0;
}

.bayou-content-frame > *:last-child {
	margin-bottom: 0;
}

.woocommerce .woocommerce-breadcrumb {
	color: var(--bayou-muted);
	font-size: 0.85rem;
}

.woocommerce .woocommerce-breadcrumb a {
	color: var(--bayou-ember);
}

.woocommerce ul.products {
	display: grid;
	gap: 1.25rem;
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.woocommerce ul.products::before,
.woocommerce ul.products::after {
	display: none;
}

.woocommerce ul.products li.product,
.wc-block-grid__product {
	background: rgba(18, 17, 14, 0.9);
	border: 1px solid rgba(184, 141, 82, 0.28);
	border-radius: 5px;
	float: none;
	margin: 0;
	padding: 0.85rem;
	text-align: left;
	width: auto;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title,
.wc-block-grid__product-title {
	color: var(--bayou-smoke);
	font-family: Georgia, "Times New Roman", serif;
	font-size: 1rem;
	line-height: 1.18;
	text-transform: uppercase;
}

.woocommerce ul.products li.product .price,
.woocommerce div.product p.price,
.woocommerce div.product span.price,
.wc-block-grid__product-price {
	color: var(--bayou-ember);
	font-weight: 800;
}

.woocommerce span.onsale {
	background: var(--bayou-rust);
	border-radius: 0;
	color: #fff7ec;
	font-weight: 800;
	min-height: auto;
	min-width: auto;
	padding: 0.38rem 0.55rem;
	text-transform: uppercase;
}

.woocommerce div.product {
	color: var(--bayou-smoke);
}

.woocommerce div.product .woocommerce-tabs ul.tabs::before {
	border-bottom-color: rgba(184, 141, 82, 0.3);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
	background: rgba(18, 17, 14, 0.9);
	border-color: rgba(184, 141, 82, 0.34);
	border-radius: 3px 3px 0 0;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	color: var(--bayou-smoke);
}

.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	background: rgba(33, 26, 18, 0.98);
	border-top-color: var(--bayou-ember);
	color: var(--bayou-smoke);
}

@media (max-width: 1100px) {
	.bayou-display-title {
		font-size: 4rem;
	}

	.bayou-feature-grid {
		grid-template-columns: minmax(180px, 280px) minmax(0, 1fr);
	}

	.bayou-meta-list {
		border-left: 0;
		border-top: 1px solid rgba(184, 141, 82, 0.22);
		grid-column: 1 / -1;
		grid-template-columns: repeat(3, minmax(0, 1fr));
		padding-left: 0;
		padding-top: 1rem;
	}

	.bayou-track-grid,
	.bayou-product-grid,
	.bayou-video-grid,
	.woocommerce ul.products {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 760px) {
	.bayou-header-inner {
		align-items: center;
		min-height: 68px;
	}

	.bayou-logo img {
		max-width: 172px;
	}

	.bayou-header-cta {
		display: none;
	}

	.bayou-hero {
		min-height: 650px;
	}

	.bayou-hero-content {
		padding-top: 2.5rem;
	}

	.bayou-display-title {
		font-size: 3.15rem;
	}

	.bayou-section {
		padding-bottom: 3rem;
		padding-top: 3rem;
	}

	.bayou-section-heading {
		font-size: 1.72rem;
	}

	.bayou-feature-grid,
	.bayou-meta-list,
	.bayou-track-grid,
	.bayou-product-grid,
	.bayou-video-grid,
	.woocommerce ul.products {
		grid-template-columns: 1fr;
	}

	.bayou-audio-strip {
		grid-template-columns: auto auto 1fr;
	}

	.bayou-audio-strip span:last-child {
		display: none;
	}

	.bayou-product-card {
		grid-template-columns: 88px minmax(0, 1fr);
	}

	.bayou-product-card .bayou-icon-link {
		grid-column: 2;
		justify-self: start;
	}

	.bayou-signup-form {
		grid-template-columns: 1fr;
	}

	.bayou-content-frame {
		padding: 1.25rem;
	}
}
