/*
Theme Name: Nouriri
Theme URI: https://nouriri.com
Description: Block theme child of Twenty Twenty-Five for nouriri.com — a nutrition brand helping people eat well without stress.
Author: Gridnimbus
Author URI: https://gridnimbus.com
Template: twentytwentyfive
Version: 1.0.2
Text Domain: nouriri
Requires at least: 6.5
Requires PHP: 8.0
*/

/*
 * Button style variation: is-style-inverted
 * Light background, primary-colour text. Used on dark hero + CTA sections.
 */
.wp-block-button.is-style-inverted > .wp-block-button__link {
	background-color: var(--wp--preset--color--surface);
	color: var(--wp--preset--color--primary);
	border: none;
	font-weight: 600;
}

.wp-block-button.is-style-inverted > .wp-block-button__link:hover,
.wp-block-button.is-style-inverted > .wp-block-button__link:focus {
	background-color: var(--wp--preset--color--background);
	color: var(--wp--preset--color--primary);
}

/*
 * Outlined button tuning for dark-background sections.
 */
.has-primary-background-color .wp-block-button.is-style-outline > .wp-block-button__link {
	color: var(--wp--preset--color--surface);
	border-color: var(--wp--preset--color--surface);
	border-width: 2px;
}

.has-primary-background-color .wp-block-button.is-style-outline > .wp-block-button__link:hover {
	background-color: var(--wp--preset--color--surface);
	color: var(--wp--preset--color--primary);
}

/*
 * Value-prop icons — centered SVG icons in sage green.
 */
.nouriri-icon {
	text-align: center;
	color: var(--wp--preset--color--primary);
	margin-bottom: 0.5rem;
}

/* --------------------------------------------------------
 * Hero v2 — asymmetric split layout
 * -------------------------------------------------------- */
.nouriri-hero-v2 {
	min-height: 85vh;
	gap: 0 !important;
	padding: 0 !important;
	margin-top: 0 !important;
	margin-bottom: 0 !important;
}

.nouriri-hero-text {
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: clamp(3rem, 6vw, 6rem) clamp(1.5rem, 4vw, 5rem);
}

.nouriri-hero-image-col {
	display: flex;
	overflow: hidden;
}

.nouriri-hero-image-col .nouriri-hero-photo {
	flex: 1;
	margin: 0;
}

.nouriri-hero-image-col .nouriri-hero-photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Eyebrow label — reusable across sections */
.nouriri-eyebrow {
	font-family: var(--wp--preset--font-family--body);
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	margin-bottom: 1rem;
}

/* Hero display heading — bigger, tighter than default h1 */
.nouriri-hero-heading {
	font-size: clamp(2.75rem, 6vw, 5.5rem) !important;
	line-height: 1.05 !important;
	letter-spacing: -0.02em;
	margin-bottom: 1.5rem;
}

@media (max-width: 781px) {
	.nouriri-hero-v2 {
		min-height: auto;
		flex-direction: column-reverse !important;
		flex-wrap: nowrap !important;
	}

	.nouriri-hero-v2 > .wp-block-column {
		flex-basis: auto !important;
	}

	.nouriri-hero-image-col {
		min-height: 50vh;
	}

	.nouriri-hero-text {
		padding: 3rem 1.5rem;
	}
}

/* --------------------------------------------------------
 * Recipe section — featured + stacked layout
 * -------------------------------------------------------- */
.nouriri-recipes-top {
	gap: var(--wp--preset--spacing--30) !important;
	align-items: stretch !important;
}

/* Featured column: card fills column height, image grows to absorb slack */
.nouriri-recipes-featured,
.nouriri-recipes-featured > .wp-block-query,
.nouriri-recipes-featured .wp-block-post-template,
.nouriri-recipes-featured .wp-block-post {
	display: flex !important;
	flex-direction: column;
	flex: 1;
}

.nouriri-recipes-featured .wp-block-post > .wp-block-group {
	flex: 1;
	display: flex;
	flex-direction: column;
}

.nouriri-recipes-featured .wp-block-post-featured-image {
	flex: 1;
	overflow: hidden;
	aspect-ratio: auto !important;
	min-height: 220px;
}

.nouriri-recipes-featured .wp-block-post-featured-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Stacked column: cards split height evenly */
.nouriri-recipes-stack,
.nouriri-recipes-stack > .wp-block-query {
	display: flex !important;
	flex-direction: column;
	flex: 1;
}

.nouriri-recipes-stack .wp-block-post-template {
	flex: 1;
	grid-template-rows: 1fr 1fr !important;
}

.nouriri-recipes-stack .wp-block-post > .wp-block-group {
	height: 100%;
	display: flex;
	flex-direction: column;
}

.nouriri-recipes-stack .wp-block-post-featured-image {
	flex: 1;
	overflow: hidden;
	min-height: 0;
}

.nouriri-recipes-stack .wp-block-post-featured-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* --------------------------------------------------------
 * Meal plans section — hero + 2 companions
 * -------------------------------------------------------- */
.nouriri-mealplans-featured {
	margin-top: var(--wp--preset--spacing--40) !important;
	margin-bottom: var(--wp--preset--spacing--40) !important;
}

/* Featured meal-plan card: image left / text right, no gap */
.nouriri-mealplan-hero {
	overflow: hidden;
	align-items: stretch !important;
	gap: 0 !important;
	border-radius: 8px;
}

.nouriri-mealplan-hero-image {
	display: flex !important;
	overflow: hidden;
	padding: 0 !important;
}

.nouriri-mealplan-hero-image .wp-block-post-featured-image {
	flex: 1;
	margin: 0;
	aspect-ratio: auto !important;
}

.nouriri-mealplan-hero-image .wp-block-post-featured-image a,
.nouriri-mealplan-hero-image .wp-block-post-featured-image img {
	width: 100%;
	height: 100%;
	display: block;
}

.nouriri-mealplan-hero-image .wp-block-post-featured-image img {
	object-fit: cover;
	border-radius: 0 !important;
}

.nouriri-mealplan-hero-text {
	display: flex !important;
	flex-direction: column;
	justify-content: center;
}

.nouriri-mealplan-hero-text .wp-block-post-title {
	font-size: clamp(1.5rem, 2.25vw, 2rem);
	line-height: 1.2;
	margin-bottom: 1rem;
}

.nouriri-mealplan-hero-text .wp-block-post-excerpt p {
	font-size: 1rem;
	line-height: 1.65;
	margin-bottom: 1.5rem;
}

/* Mobile: stack image above text */
@media (max-width: 781px) {
	.nouriri-mealplan-hero {
		flex-wrap: wrap !important;
	}
	.nouriri-mealplan-hero > .wp-block-column {
		flex-basis: 100% !important;
	}
	.nouriri-mealplan-hero-image {
		min-height: 280px;
	}
}

/* Companion meal-plan cards: 2-col grid */
.nouriri-mealplans-companions .wp-block-post-template {
	gap: var(--wp--preset--spacing--30) !important;
}

.nouriri-mealplans-companions .wp-block-post-featured-image {
	margin: 0;
}

.nouriri-mealplans-companions .wp-block-post-featured-image img {
	width: 100%;
	display: block;
}

/* --------------------------------------------------------
 * Value propositions section — 3 horizontal rows
 * -------------------------------------------------------- */
.nouriri-valueprops-row {
	margin-bottom: var(--wp--preset--spacing--40) !important;
	gap: var(--wp--preset--spacing--30) !important;
}

.nouriri-valueprops-row:last-of-type {
	margin-bottom: 0 !important;
}

.nouriri-valueprops-icon {
	text-align: center;
}

.nouriri-valueprops-icon .nouriri-icon {
	text-align: center;
	margin-bottom: 0;
	display: flex;
	justify-content: center;
	align-items: center;
}

.nouriri-valueprops-icon svg {
	width: 64px;
	height: 64px;
	flex-shrink: 0;
}

.nouriri-valueprops-row .wp-block-column h3 {
	margin-top: 0;
	margin-bottom: 0.5rem;
}

.nouriri-valueprops-row .wp-block-column p:last-child {
	margin-bottom: 0;
}

/* Mobile: keep rows horizontal but shrink icon */
@media (max-width: 600px) {
	.nouriri-valueprops-row {
		flex-wrap: nowrap !important;
		gap: var(--wp--preset--spacing--20) !important;
	}
	.nouriri-valueprops-icon {
		flex-basis: 56px !important;
	}
	.nouriri-valueprops-icon svg {
		width: 48px;
		height: 48px;
	}
}

/* --------------------------------------------------------
 * Testimonial section — single big pull-quote
 * -------------------------------------------------------- */
.nouriri-testimonial-mark {
	font-family: var(--wp--preset--font-family--heading);
	font-size: clamp(5rem, 10vw, 8rem);
	line-height: 0.8;
	color: var(--wp--preset--color--primary);
	text-align: center;
	margin: var(--wp--preset--spacing--30) 0 0;
	opacity: 0.4;
	user-select: none;
}

.nouriri-testimonial-body {
	font-size: clamp(1.5rem, 2.4vw, 2.25rem) !important;
	line-height: 1.4 !important;
	font-style: italic;
	font-weight: 400;
	letter-spacing: -0.01em;
	max-width: 780px;
	margin: 0 auto var(--wp--preset--spacing--30) !important;
}

.nouriri-testimonial-attribution {
	margin-top: var(--wp--preset--spacing--30);
	margin-bottom: var(--wp--preset--spacing--30);
}

.nouriri-testimonial-name {
	font-size: 1rem !important;
	font-weight: 600;
	letter-spacing: 0.02em;
	margin-bottom: 0.25rem !important;
}

.nouriri-testimonial-role {
	font-size: 0.875rem !important;
	font-weight: 400;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	margin-top: 0 !important;
}

.nouriri-testimonial-more {
	font-size: 0.875rem !important;
	margin-top: var(--wp--preset--spacing--30) !important;
}

.nouriri-testimonial-more a {
	text-decoration: underline;
	text-underline-offset: 4px;
	color: inherit;
}

.nouriri-testimonial-more a:hover {
	color: var(--wp--preset--color--primary);
}
