/**
 * Homepage Styles
 *
 * Styles for all homepage components:
 * - Hero
 * - Search
 * - Featured Recipes
 * - Categories
 * - About
 * - Blog
 * - Newsletter CTA
 *
 * @package WPBlogsAndPages
 * @since 1.0.0
 */

/* @critical-start context: home */
.btn-white {
	background: var(--color-white);
	color: var(--color-neutral-900);
}

.btn-white:hover {
	background: var(--color-neutral-100);
}
/* @critical-end */

/* ==========================================================================
   Hero Slider
   ========================================================================== */

/* @critical-start context: home */
.hero-slider {
	position: relative;
	height: 70vh;
	min-height: 400px;
	max-height: 800px;
	overflow: hidden;
}

.hero-slider__slide {
	position: absolute;
	inset: 0;
	opacity: 0;
	z-index: 0;
	transition: opacity 0.8s ease;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--color-neutral-800) 0%, var(--color-neutral-600) 100%);
}

.hero-slider__slide--active {
	opacity: 1;
	z-index: 1;
}

.hero-slider__bg {
	position: absolute;
	inset: 0;
}

.hero-slider__bg-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.hero-slider__overlay {
	position: absolute;
	inset: 0;
	background: var(--hero-overlay, var(--color-neutral-900));
}

.hero-slider__content {
	position: relative;
	z-index: 1;
	text-align: center;
	color: var(--color-white);
	padding: var(--spacing-16) var(--spacing-4);
	max-width: 700px;
}

.hero-slider__title {
	color: var(--color-white);
	margin-bottom: var(--spacing-4);
}

.hero-slider__subtitle {
	font-size: var(--font-size-xl);
	color: var(--color-overlay-white-85);
	max-width: 600px;
	margin: 0 auto var(--spacing-6);
}

.hero-slider__link {
	display: inline-block;
}

.hero-slider__dots {
	position: absolute;
	bottom: var(--spacing-6);
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	gap: var(--spacing-3);
	z-index: 2;
	background: var(--color-overlay-black-50);
	padding: var(--spacing-2) var(--spacing-4);
	border-radius: var(--radius-full);
}

.hero-slider__dot {
	width: 14px;
	height: 14px;
	border-radius: 50%;
	background: var(--color-overlay-white-40);
	border: 2px solid var(--color-white);
	cursor: pointer;
	padding: 0;
	transition: background 0.3s ease, transform 0.2s ease;
}

.hero-slider__dot:hover {
	background: var(--color-overlay-white-80);
	transform: scale(1.15);
}

.hero-slider__dot--active {
	background: var(--color-white);
	border-color: var(--color-white);
	transform: scale(1.2);
}

.hero-slider__nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 2;
	width: 48px;
	height: 48px;
	border: none;
	border-radius: 50%;
	background: var(--color-overlay-black-30);
	color: var(--color-white);
	cursor: pointer;
	display: none;
	align-items: center;
	justify-content: center;
	transition: background 0.2s ease, opacity 0.2s ease;
}

.hero-slider__nav .icon {
	width: 24px;
	height: 24px;
}

.hero-slider__nav:hover {
	background: var(--color-overlay-black-60);
}

.hero-slider__nav--prev {
	left: var(--spacing-4);
}

.hero-slider__nav--next {
	right: var(--spacing-4);
}

@media (min-width: 769px) {
	.hero-slider__nav {
		display: flex;
	}
}

@media (max-width: 768px) {
	.hero-slider {
		height: 60vh;
		min-height: 300px;
		max-height: 500px;
	}

	.hero-slider__subtitle {
		font-size: var(--font-size-lg);
	}
}

@media (prefers-reduced-motion: reduce) {
	.hero-slider__slide {
		transition: none;
	}
}
/* @critical-end */


/* ==========================================================================
   Homepage Hero (legacy)
   ========================================================================== */

/* @critical-start context: home */
.homepage-hero {
	position: relative;
	min-height: 500px;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}

.homepage-hero-bg {
	position: absolute;
	inset: 0;
}

.homepage-hero-bg-picture {
	position: absolute;
	inset: 0;
	display: block;
}

.homepage-hero-bg-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: var(--bap-hero-pos-desktop, 50% 50%);
}

.homepage-hero-overlay {
	position: absolute;
	inset: 0;
	background: var(--hero-overlay, var(--color-neutral-900));
}

.homepage-hero-content {
	position: relative;
	z-index: 1;
	text-align: center;
	color: var(--color-white);
	padding: var(--spacing-16) var(--spacing-4);
}

.homepage-hero-title {
	color: var(--color-white);
	margin-bottom: var(--spacing-4);
}

.homepage-hero-tagline {
	font-size: var(--font-size-xl);
	color: var(--color-overlay-white-85);
	max-width: 600px;
	margin: 0 auto var(--spacing-8);
}

.homepage-hero-cta {
	display: flex;
	gap: var(--spacing-4);
	justify-content: center;
	flex-wrap: wrap;
}

@media (max-width: 768px) {
	.homepage-hero {
		min-height: 400px;
	}

	.homepage-hero-bg-image {
		object-position: var(--bap-hero-pos-mobile, 50% 50%);
	}

	.homepage-hero-tagline {
		font-size: var(--font-size-lg);
	}
}

.homepage-slider__nav svg{
	min-width: 20px;
	height: 20px;
}

/* ==========================================================================
   Homepage Sections (shared)
   ========================================================================== */

.homepage-section {
	padding: var(--spacing-section) 0;
}

/* Padding-top presets */
.homepage-section--pt-none { padding-top: 0; }
.homepage-section--pt-xs   { padding-top: var(--spacing-4); }
.homepage-section--pt-sm   { padding-top: var(--spacing-6); }
.homepage-section--pt-lg   { padding-top: var(--spacing-16); }
.homepage-section--pt-xl   { padding-top: var(--spacing-24); }

/* Padding-bottom presets */
.homepage-section--pb-none { padding-bottom: 0; }
.homepage-section--pb-xs   { padding-bottom: var(--spacing-4); }
.homepage-section--pb-sm   { padding-bottom: var(--spacing-6); }
.homepage-section--pb-lg   { padding-bottom: var(--spacing-16); }
.homepage-section--pb-xl   { padding-bottom: var(--spacing-24); }

/* Margin-top presets */
.homepage-section--mt-xs   { margin-top: var(--spacing-2); }
.homepage-section--mt-sm   { margin-top: var(--spacing-4); }
.homepage-section--mt-md   { margin-top: var(--spacing-8); }
.homepage-section--mt-lg   { margin-top: var(--spacing-12); }
.homepage-section--mt-xl   { margin-top: var(--spacing-16); }

/* Margin-bottom presets */
.homepage-section--mb-xs   { margin-bottom: var(--spacing-2); }
.homepage-section--mb-sm   { margin-bottom: var(--spacing-4); }
.homepage-section--mb-md   { margin-bottom: var(--spacing-8); }
.homepage-section--mb-lg   { margin-bottom: var(--spacing-12); }
.homepage-section--mb-xl   { margin-bottom: var(--spacing-16); }

/* Horizontal spacing presets */
.homepage-section--none { padding-left: 0; padding-right: 0; }
.homepage-section--wide { padding-left: var(--spacing-8); padding-right: var(--spacing-8); }
.homepage-section--full { padding-left: 0; padding-right: 0; }
.homepage-section--full > .container { max-width: none; padding-left: 0; padding-right: 0; }

.homepage-section:nth-child(even) {
	background: var(--color-neutral-50);
}

.section-title {
	color: var(--color-neutral-800);
	text-align: center;
	margin-bottom: var(--spacing-4);
}

.section-subtitle {
	font-size: var(--font-size-lg);
	color: var(--color-neutral-500);
	text-align: center;
	max-width: 600px;
	margin: 0 auto var(--spacing-8);
}

.section-title + .recipe-grid,
.section-title + .blog-grid {
	margin-top: var(--spacing-8);
}
/* @critical-end */


/* ==========================================================================
   Homepage Search
   ========================================================================== */

/* Search styles moved to components/homepage-search.css */


/* ==========================================================================
   Featured Recipes Grid
   ========================================================================== */

.homepage-featured .recipe-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--spacing-6);
}

@media (min-width: 600px) {
	.homepage-featured .recipe-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 992px) {
	.homepage-featured .recipe-grid {
		grid-template-columns: repeat(var(--grid-columns, 3), 1fr);
	}
}

/* ==========================================================================
   Categories Grid
   ========================================================================== */

.categories-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--spacing-4);
}

@media (min-width: 640px) {
	.categories-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (min-width: 992px) {
	.categories-grid {
		grid-template-columns: repeat(4, 1fr);
	}
}

.category-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-decoration: none;
	padding: var(--spacing-4);
	border-radius: var(--radius-xl);
	background: var(--color-white);
	border: 1px solid var(--color-neutral-200);
	transition: all 0.2s ease;
}

.category-card:hover {
	border-color: var(--color-brand-200);
	box-shadow: var(--shadow-lg);
	transform: translateY(-4px);
}

.category-card-image {
	width: 100%;
	max-width: 180px;
	aspect-ratio: var(--category-image-ratio, 1 / 1);
	border-radius: var(--category-image-radius, var(--radius-full));
	overflow: hidden;
	margin-bottom: var(--spacing-3);
}

.category-card-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.category-card-title {
	font-size: var(--font-size-lg);
	font-weight: var(--weight-semibold);
	color: var(--color-neutral-900);
	margin-bottom: var(--spacing-1);
}

.category-card-count {
	font-size: var(--font-size-sm);
	color: var(--color-neutral-500);
}

/* Square category images variant */
.homepage-categories--square {
	--category-image-radius: var(--radius-xl);
}

.homepage-categories--custom-bg {
	background: var(--homepage-categories-bg);
}

.homepage-categories--carousel .recipe-grid__slide {
	display: flex;
	justify-content: center;
}

.homepage-categories--carousel .category-card {
	width: 100%;
	max-width: 260px;
}


/* ==========================================================================
   About Box
   Note: Base styles moved to components/about-section.css (shared component)
   ========================================================================== */


/* ==========================================================================
   Blog Grid
   ========================================================================== */

.blog-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--spacing-6);
}

@media (min-width: 768px) {
	.blog-grid {
		grid-template-columns: repeat(var(--grid-columns, 3), 1fr);
	}
}

.blog-card {
	background: var(--color-white);
	border-radius: var(--radius-xl);
	overflow: hidden;
	border: 1px solid var(--color-neutral-200);
	transition: all 0.2s ease;
}

.blog-card:hover {
	border-color: var(--color-brand-200);
	box-shadow: var(--shadow-lg);
	transform: translateY(-4px);
}

.blog-card-link {
	display: block;
	text-decoration: none;
	color: inherit;
}

.blog-card-image {
	aspect-ratio: 16/9;
	overflow: hidden;
}

.blog-card-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.3s ease;
}

.blog-card:hover .blog-card-image img {
	transform: scale(1.05);
}

.blog-card-content {
	padding: var(--spacing-4);
}

.blog-card-date {
	font-size: var(--font-size-xs);
	color: var(--color-neutral-500);
	display: block;
	margin-bottom: var(--spacing-2);
}

.blog-card-title {
	font-size: var(--font-size-lg);
	font-weight: var(--weight-semibold);
	color: var(--color-neutral-900);
	margin-bottom: var(--spacing-2);
	line-height: 1.3;
}

.blog-card-excerpt {
	font-size: var(--font-size-sm);
	color: var(--color-neutral-500);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}


/* ==========================================================================
   Media + Text (core/media-text) on Homepage
   ========================================================================== */

.homepage-section .wp-block-media-text {
	max-width: 1100px;
	margin: 0 auto;
	gap: var(--spacing-8);
	align-items: center;
}

.homepage-section .wp-block-media-text .wp-block-media-text__media img {
	border-radius: var(--radius-xl);
}

.homepage-section .wp-block-media-text .wp-block-media-text__content {
	padding: var(--spacing-4) var(--spacing-6);
}

.homepage-section .wp-block-media-text .wp-block-media-text__content h2 {
	font-size: var(--font-size-6xl);
	color: var(--color-neutral-800);
	margin-bottom: var(--spacing-4);
}

.homepage-section .wp-block-media-text .wp-block-media-text__content p {
	font-size: var(--font-size-base);
	color: var(--color-neutral-600);
	line-height: 1.7;
}

@media (max-width: 600px) {
	.homepage-section .wp-block-media-text {
		grid-template-columns: 1fr !important;
	}

	.homepage-section .wp-block-media-text .wp-block-media-text__media {
		grid-column: 1;
		grid-row: 1;
	}

	.homepage-section .wp-block-media-text .wp-block-media-text__content {
		grid-column: 1;
		grid-row: 2;
		padding: var(--spacing-4) 0;
	}
}


/* ==========================================================================
   Books Section (core/columns with images)
   ========================================================================== */

.homepage-section .books-section .wp-block-columns {
	gap: var(--spacing-6);
	max-width: 900px;
	margin: 0 auto;
}

.homepage-section .books-section .wp-block-column {
	text-align: center;
}

.homepage-section .books-section .wp-block-image img {
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-md);
	max-width: 250px;
	margin: 0 auto var(--spacing-4);
}

.homepage-section .books-section .wp-block-column p {
	font-size: var(--font-size-sm);
	color: var(--color-neutral-600);
	text-align: center;
}


/* Newsletter CTA styles moved to components/newsletter-cta.css */
