/**
 * Landing Page Styles
 *
 * Styles for the Landing Page template (page-landing.php).
 * Uses only design tokens — no hardcoded colors, radii, or fonts.
 *
 * @package WPBlogsAndPages
 * @since 1.9.0
 */

/* ==========================================================================
   Layout
   ========================================================================== */

.lp {
	display: flex;
	flex-direction: column;
}

.lp-container {
	width: 100%;
	max-width: 48rem;
	margin-inline: auto;
	padding-inline: var(--spacing-4);
}

.lp-section {
	padding-block: var(--spacing-16);
}

/* Custom property overrides — set per-section via inline style */
.lp-section {
	background-color: var(--lp-bg, transparent);
}

/* Spacing modifiers */
.lp-section--pt-none { padding-top: 0; }
.lp-section--pt-xs   { padding-top: var(--spacing-4); }
.lp-section--pt-sm   { padding-top: var(--spacing-6); }
.lp-section--pt-lg   { padding-top: var(--spacing-16); }
.lp-section--pt-xl   { padding-top: var(--spacing-24); }

.lp-section--pb-none { padding-bottom: 0; }
.lp-section--pb-xs   { padding-bottom: var(--spacing-4); }
.lp-section--pb-sm   { padding-bottom: var(--spacing-6); }
.lp-section--pb-lg   { padding-bottom: var(--spacing-16); }
.lp-section--pb-xl   { padding-bottom: var(--spacing-24); }

/* Container width modifiers */
.lp-container--narrow { max-width: 36rem; }
.lp-container--wide   { max-width: 64rem; }
.lp-container--full   { max-width: 100%; }

/* Visibility modifiers */
.lp-section--desktop-only {
	display: none;
}

.lp-section--mobile-only {
	display: block;
}

@media (min-width: 768px) {
	.lp-section--desktop-only {
		display: block;
	}

	.lp-section--mobile-only {
		display: none;
	}
}

/* ==========================================================================
   Hero
   ========================================================================== */

.lp-hero {
	background-color: var(--lp-bg, var(--color-neutral-50));
	padding-block: var(--spacing-12);
}

.lp-hero__inner {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-8);
	align-items: center;
	text-align: center;
}

@media (min-width: 768px) {
	.lp-hero {
		padding-block: var(--spacing-16);
	}

	.lp-hero__inner {
		flex-direction: row;
		text-align: left;
		max-width: 64rem;
	}

	.lp-hero__content {
		flex: 1;
	}

	.lp-hero__image {
		flex: 0 0 45%;
	}
}

.lp-hero__label {
	display: inline-block;
	background-color: var(--color-primary);
	color: var(--color-white);
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	font-weight: 600;
	padding: var(--spacing-1) var(--spacing-3);
	border-radius: var(--radius-full);
	margin-bottom: var(--spacing-4);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.lp-hero__title {
	font-family: var(--lp-title-font, var(--font-serif));
	font-size: var(--lp-title-size, var(--text-3xl));
	font-weight: 700;
	line-height: 1.2;
	color: var(--lp-title-color, var(--color-neutral-900));
	margin: 0 0 var(--spacing-4);
}

@media (min-width: 768px) {
	.lp-hero__title {
		font-size: var(--lp-title-size, var(--text-4xl));
	}
}

.lp-hero__subtitle {
	font-family: var(--font-sans);
	font-size: var(--text-lg);
	color: var(--lp-subtitle-color, var(--color-neutral-600));
	line-height: 1.6;
	margin: 0;
}

/* Hero: CTA button */
.lp-hero__button {
	display: inline-block;
	font-family: var(--font-sans);
	font-size: var(--text-base);
	font-weight: 600;
	padding: var(--spacing-3) var(--spacing-8);
	border-radius: var(--radius-md);
	text-decoration: none;
	transition: opacity 0.2s ease;
	margin-top: var(--spacing-6);
}

.lp-hero__button:hover {
	opacity: 0.9;
}

.lp-hero__button--primary {
	background-color: var(--color-primary);
	color: var(--color-white);
}

.lp-hero__button--outline {
	background-color: transparent;
	color: var(--color-primary);
	border: 2px solid var(--color-primary);
}

.lp-hero__button--white {
	background-color: var(--color-white);
	color: var(--color-neutral-900);
}

/* Hero layout variants */
.lp-hero--image-left .lp-hero__inner {
	flex-direction: column;
}

@media (min-width: 768px) {
	.lp-hero--image-left .lp-hero__inner {
		flex-direction: row-reverse;
	}
}

.lp-hero--image-bg {
	position: relative;
	overflow: hidden;
}

.lp-hero--image-bg .lp-hero__image {
	position: absolute;
	inset: 0;
}

.lp-hero--image-bg .lp-hero__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 0;
}

.lp-hero--image-bg .lp-hero__inner {
	position: relative;
	z-index: 1;
	justify-content: center;
	min-height: 24rem;
}

.lp-hero--image-bg .lp-hero__content {
	text-align: center;
	max-width: 40rem;
}

.lp-hero--image-bg .lp-hero__overlay {
	position: absolute;
	inset: 0;
	background-color: var(--lp-overlay-color, var(--color-neutral-900));
	opacity: var(--lp-overlay-opacity, 0.5);
	z-index: 0;
}

.lp-hero--centered .lp-hero__inner {
	flex-direction: column;
	text-align: center;
	align-items: center;
	max-width: 40rem;
}

/* Hero title sizes */
.lp-hero--title-md .lp-hero__title { font-size: var(--lp-title-size, var(--text-2xl)); }
.lp-hero--title-xl .lp-hero__title { font-size: var(--lp-title-size, var(--text-4xl)); }
.lp-hero--title-2xl .lp-hero__title { font-size: var(--lp-title-size, var(--text-5xl)); }

@media (min-width: 768px) {
	.lp-hero--title-md .lp-hero__title { font-size: var(--lp-title-size, var(--text-3xl)); }
	.lp-hero--title-xl .lp-hero__title { font-size: var(--lp-title-size, var(--text-5xl)); }
	.lp-hero--title-2xl .lp-hero__title { font-size: var(--lp-title-size, var(--text-6xl)); }
}

.lp-hero__image img {
	width: 100%;
	height: auto;
	border-radius: var(--radius-lg);
	object-fit: cover;
}

/* ==========================================================================
   Content Blocks
   ========================================================================== */

.lp-content__inner {
	font-family: var(--font-sans);
	font-size: var(--text-base);
	line-height: 1.7;
	color: var(--lp-text-color, var(--color-neutral-700));
}

.lp-content--center .lp-content__inner {
	text-align: center;
}

.lp-content__inner h2,
.lp-content__inner h3,
.lp-content__inner h4 {
	font-family: var(--font-serif);
	color: var(--color-neutral-900);
	margin-top: var(--spacing-8);
	margin-bottom: var(--spacing-4);
}

.lp-content__inner p {
	margin-bottom: var(--spacing-4);
}

.lp-content__inner img {
	max-width: 100%;
	height: auto;
	border-radius: var(--radius-md);
}

.lp-content__inner ul,
.lp-content__inner ol {
	padding-left: var(--spacing-6);
	margin-bottom: var(--spacing-4);
}

.lp-content__inner a {
	color: var(--color-primary);
}

/* ==========================================================================
   Author
   ========================================================================== */

.lp-author {
	background-color: var(--lp-bg, var(--color-neutral-50));
}

.lp-author__inner {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-8);
	align-items: center;
}

@media (min-width: 768px) {
	.lp-author__inner {
		flex-direction: row;
	}

	.lp-author__image {
		flex: 0 0 14rem;
	}

	.lp-author__content {
		flex: 1;
	}
}

.lp-author__image img {
	width: var(--lp-author-img-size, 14rem);
	height: var(--lp-author-img-size, 14rem);
	border-radius: var(--lp-author-img-radius, var(--radius-full));
	object-fit: cover;
}

.lp-author__title {
	font-family: var(--lp-title-font, var(--font-serif));
	font-size: var(--text-2xl);
	color: var(--lp-title-color, var(--color-neutral-900));
	margin: 0 0 var(--spacing-4);
}

.lp-author__subtitle {
	font-family: var(--font-sans);
	font-size: var(--text-base);
	color: var(--lp-text-color, var(--color-neutral-500));
	margin: 0 0 var(--spacing-3);
}

.lp-author__text {
	font-family: var(--font-sans);
	font-size: var(--text-base);
	line-height: 1.7;
	color: var(--lp-text-color, var(--color-neutral-700));
}

.lp-author__text p {
	margin-bottom: var(--spacing-3);
}

/* Author: social links */
.lp-author__social {
	display: flex;
	gap: var(--spacing-3);
	margin-top: var(--spacing-4);
}

.lp-author__social-link {
	color: var(--lp-accent-color, var(--color-primary));
	transition: opacity 0.2s ease;
}

.lp-author__social-link:hover {
	opacity: 0.7;
}

.lp-author__social-link .ds-icon {
	width: 1.25rem;
	height: 1.25rem;
}

/* Author: signature */
.lp-author__signature {
	margin-top: var(--spacing-4);
}

.lp-author__signature img {
	height: 3rem;
	width: auto;
}

/* Author: image shape variants */
.lp-author--img-square .lp-author__image img {
	border-radius: 0;
}

.lp-author--img-rounded .lp-author__image img {
	border-radius: var(--radius-lg);
}

/* Author: image size variants */
.lp-author--img-sm .lp-author__image img {
	width: 8rem;
	height: 8rem;
}

.lp-author--img-lg .lp-author__image img {
	width: 20rem;
	height: 20rem;
}

@media (min-width: 768px) {
	.lp-author--img-sm .lp-author__image {
		flex: 0 0 8rem;
	}

	.lp-author--img-lg .lp-author__image {
		flex: 0 0 20rem;
	}
}

/* Author: layout variants */
.lp-author--centered .lp-author__inner {
	flex-direction: column;
	text-align: center;
	align-items: center;
}

.lp-author--centered .lp-author__social {
	justify-content: center;
}

.lp-author--card {
	background-color: transparent;
}

.lp-author--card .lp-author__inner {
	flex-direction: column;
	text-align: center;
	align-items: center;
	background-color: var(--lp-bg, var(--color-white));
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-md);
	padding: var(--spacing-8);
}

.lp-author--card .lp-author__social {
	justify-content: center;
}

/* ==========================================================================
   Product Preview
   ========================================================================== */

.lp-product__inner {
	text-align: center;
}

.lp-product__figure {
	margin: 0;
}

.lp-product__figure img {
	max-width: 100%;
	height: auto;
	border-radius: var(--radius-lg);
}

.lp-product__caption {
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	color: var(--color-neutral-500);
	margin-top: var(--spacing-3);
}

/* ==========================================================================
   Social Proof
   ========================================================================== */

.lp-social-proof {
	background-color: var(--lp-bg, var(--color-neutral-50));
}

.lp-social-proof__title {
	font-family: var(--lp-title-font, var(--font-serif));
	font-size: var(--text-2xl);
	color: var(--lp-title-color, var(--color-neutral-900));
	text-align: center;
	margin: 0 0 var(--spacing-4);
}

.lp-social-proof__subtitle {
	font-family: var(--font-sans);
	font-size: var(--text-base);
	color: var(--lp-text-color, var(--color-neutral-600));
	text-align: center;
	margin: 0 0 var(--spacing-10);
}

.lp-social-proof__title + .lp-social-proof__grid {
	margin-top: var(--spacing-10);
}

.lp-social-proof__grid {
	display: grid;
	gap: var(--spacing-6);
	grid-template-columns: repeat(var(--lp-grid-columns, 1), 1fr);
}

@media (min-width: 768px) {
	.lp-social-proof__grid {
		grid-template-columns: repeat(var(--lp-grid-columns, 3), 1fr);
	}
}

.lp-social-proof__item {
	background-color: var(--lp-card-bg, var(--color-white));
	border-radius: var(--radius-lg);
	padding: var(--spacing-6);
	margin: 0;
	box-shadow: var(--shadow-sm);
}

.lp-social-proof__rating {
	display: flex;
	gap: 0.125rem;
	margin-bottom: var(--spacing-3);
}

.lp-social-proof__star {
	width: 1rem;
	height: 1rem;
	color: var(--lp-accent-color, var(--color-warning-500));
}

.lp-social-proof__quote {
	font-family: var(--font-sans);
	font-size: var(--text-base);
	font-style: italic;
	line-height: 1.6;
	color: var(--lp-quote-color, var(--color-neutral-700));
	margin: 0 0 var(--spacing-4);
}

.lp-social-proof__footer {
	display: flex;
	align-items: center;
	gap: var(--spacing-3);
}

.lp-social-proof__avatar img {
	width: 2.5rem;
	height: 2.5rem;
	border-radius: var(--radius-full);
	object-fit: cover;
}

.lp-social-proof__author {
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	font-weight: 600;
	font-style: normal;
	color: var(--color-neutral-900);
}

.lp-social-proof__role {
	font-family: var(--font-sans);
	font-size: var(--text-xs);
	font-style: normal;
	color: var(--color-neutral-500);
}

/* ==========================================================================
   Form
   ========================================================================== */

.lp-form {
	background-color: var(--lp-bg, var(--color-primary));
	color: var(--lp-text-color, var(--color-white));
}

.lp-form__inner {
	text-align: center;
}

.lp-form__title {
	font-family: var(--lp-title-font, var(--font-serif));
	font-size: var(--text-2xl);
	color: var(--lp-title-color, var(--color-white));
	margin: 0 0 var(--spacing-4);
}

.lp-form__intro {
	font-family: var(--font-sans);
	font-size: var(--text-base);
	line-height: 1.6;
	margin: 0 0 var(--spacing-8);
	opacity: 0.9;
}

.lp-form__embed {
	max-width: 32rem;
	margin-inline: auto;
	text-align: left;
	background-color: var(--lp-container-bg, transparent);
	border-radius: var(--radius-md);
}

.lp-form__disclaimer {
	font-family: var(--font-sans);
	font-size: var(--text-xs);
	margin-top: var(--spacing-6);
	opacity: 0.75;
}

.lp-form__disclaimer p {
	margin: 0;
}

/* Form embed: input fields */
.lp-form__embed input[type="text"],
.lp-form__embed input[type="email"] {
	width: 100%;
	padding: var(--spacing-3) var(--spacing-4);
	border: 1px solid color-mix(in srgb, var(--color-white) 30%, transparent);
	border-radius: var(--radius-sm);
	font-family: var(--font-sans);
	font-size: var(--text-base);
	background: var(--color-white);
	color: var(--color-neutral-800);
	margin-bottom: var(--spacing-4);
	box-sizing: border-box;
}

.lp-form__embed label {
	display: block;
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	font-weight: 600;
	margin-bottom: var(--spacing-1);
	color: inherit;
}

.lp-form__embed button[type="submit"] {
	width: 100%;
	padding: var(--spacing-3) var(--spacing-6);
	border: none;
	border-radius: var(--radius-sm);
	font-family: var(--font-sans);
	font-size: var(--text-base);
	font-weight: 600;
	cursor: pointer;
	background: var(--color-neutral-800);
	color: var(--color-white);
	margin-top: var(--spacing-2);
	transition: var(--transition-fast);
}

.lp-form__embed button[type="submit"]:hover {
	opacity: 0.9;
	transform: var(--transform-hover-lift);
}

.lp-form__embed ._form-thank-you {
	font-family: var(--font-sans);
	font-size: var(--text-lg);
	color: inherit;
	padding: var(--spacing-8) 0;
}

.lp-form__disclaimer a {
	color: inherit;
	text-decoration: underline;
}

/* Form: two-column layout */
@media (min-width: 768px) {
	.lp-form--two-column .lp-form__inner {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: var(--spacing-8);
		text-align: left;
	}

	.lp-form--two-column .lp-form__text-col {
		display: flex;
		flex-direction: column;
		justify-content: center;
	}

	.lp-form--two-column .lp-form__embed {
		max-width: none;
	}
}

/* ==========================================================================
   CTA
   ========================================================================== */

/* CTA variants */
.lp-cta {
	background-color: var(--lp-bg, var(--color-neutral-900));
	color: var(--lp-text-color, var(--color-white));
}

.lp-cta--primary {
	background-color: var(--lp-bg, var(--color-primary));
}

.lp-cta--light {
	background-color: var(--lp-bg, var(--color-neutral-50));
	color: var(--lp-text-color, var(--color-neutral-700));
}

.lp-cta--gradient {
	background: linear-gradient(135deg, var(--color-primary), var(--color-neutral-900));
	color: var(--lp-text-color, var(--color-white));
}

.lp-cta__inner {
	text-align: center;
}

.lp-cta__title {
	font-family: var(--lp-title-font, var(--font-serif));
	font-size: var(--text-2xl);
	color: var(--lp-title-color, inherit);
	margin: 0 0 var(--spacing-4);
}

.lp-cta__text {
	font-family: var(--font-sans);
	font-size: var(--text-base);
	line-height: 1.6;
	margin: 0 0 var(--spacing-8);
	opacity: 0.85;
}

.lp-cta__buttons {
	display: flex;
	gap: var(--spacing-4);
	justify-content: center;
	flex-wrap: wrap;
}

.lp-cta__button {
	display: inline-block;
	font-family: var(--font-sans);
	font-size: var(--text-base);
	font-weight: 600;
	color: var(--lp-btn-text-color, var(--color-neutral-900));
	background-color: var(--lp-btn-color, var(--color-white));
	padding: var(--spacing-3) var(--spacing-8);
	border-radius: var(--radius-md);
	text-decoration: none;
	transition: opacity 0.2s ease;
}

.lp-cta__button:hover {
	opacity: 0.9;
}

.lp-cta__button--outline {
	background-color: transparent;
	color: inherit;
	border: 2px solid currentColor;
}

.lp-cta__button--ghost {
	background-color: transparent;
	color: inherit;
	text-decoration: underline;
}

/* ==========================================================================
   Product (enhanced)
   ========================================================================== */

.lp-product__title {
	font-family: var(--lp-title-font, var(--font-serif));
	font-size: var(--text-2xl);
	color: var(--lp-title-color, var(--color-neutral-900));
	text-align: center;
	margin: 0 0 var(--spacing-3);
}

.lp-product__description {
	font-family: var(--font-sans);
	font-size: var(--text-base);
	color: var(--color-neutral-600);
	text-align: center;
	margin: 0 0 var(--spacing-6);
	max-width: 36rem;
	margin-inline: auto;
}

.lp-product__figure--rounded img { border-radius: var(--radius-md); }
.lp-product__figure--shadow img  { box-shadow: var(--shadow-lg); }
.lp-product__figure--framed {
	padding: var(--spacing-4);
	background-color: var(--color-white);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-md);
}

.lp-product__link-button {
	display: inline-block;
	font-family: var(--font-sans);
	font-size: var(--text-base);
	font-weight: 600;
	color: var(--color-white);
	background-color: var(--color-primary);
	padding: var(--spacing-3) var(--spacing-8);
	border-radius: var(--radius-md);
	text-decoration: none;
	margin-top: var(--spacing-6);
	transition: opacity 0.2s ease;
}

.lp-product__link-button:hover {
	opacity: 0.9;
}

/* ==========================================================================
   Author Box (new section)
   ========================================================================== */

.lp-author-box {
	background-color: var(--lp-bg, transparent);
}

.lp-author-box__card {
	background-color: var(--lp-card-bg, var(--color-white));
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-md);
	overflow: hidden;
	text-align: center;
	max-width: 36rem;
	margin-inline: auto;
}

.lp-author-box__cover {
	height: 12rem;
	overflow: hidden;
}

.lp-author-box__cover img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.lp-author-box__avatar {
	margin-top: -3.5rem;
	margin-bottom: var(--spacing-4);
}

.lp-author-box__avatar img {
	width: 7rem;
	height: 7rem;
	border-radius: var(--radius-full);
	border: 4px solid var(--lp-card-bg, var(--color-white));
	object-fit: cover;
}

.lp-author-box--img-square .lp-author-box__avatar img {
	border-radius: 0;
}

.lp-author-box--img-rounded .lp-author-box__avatar img {
	border-radius: var(--radius-lg);
}

.lp-author-box__name {
	font-family: var(--lp-name-font, var(--font-serif));
	font-size: var(--lp-name-size, var(--text-2xl));
	color: var(--lp-name-color, var(--color-neutral-900));
	margin: 0 0 var(--spacing-2);
	padding-inline: var(--spacing-6);
}

.lp-author-box__subtitle {
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	color: var(--color-neutral-500);
	margin: 0 0 var(--spacing-4);
	padding-inline: var(--spacing-6);
}

.lp-author-box__bio {
	font-family: var(--font-sans);
	font-size: var(--text-base);
	line-height: 1.7;
	color: var(--lp-text-color, var(--color-neutral-700));
	padding-inline: var(--spacing-6);
	margin-bottom: var(--spacing-4);
}

.lp-author-box__bio p {
	margin-bottom: var(--spacing-3);
}

.lp-author-box__credentials {
	display: flex;
	flex-wrap: wrap;
	gap: var(--spacing-2);
	justify-content: center;
	padding-inline: var(--spacing-6);
	margin-bottom: var(--spacing-4);
}

.lp-author-box__credential {
	display: inline-block;
	font-family: var(--font-sans);
	font-size: var(--text-xs);
	font-weight: 600;
	color: var(--lp-accent-color, var(--color-primary));
	background-color: color-mix(in srgb, var(--lp-accent-color, var(--color-primary)) 10%, transparent);
	padding: var(--spacing-1) var(--spacing-3);
	border-radius: var(--radius-full);
}

.lp-author-box__quote {
	font-family: var(--font-serif);
	font-style: italic;
	font-size: var(--text-base);
	color: var(--color-neutral-600);
	padding-inline: var(--spacing-8);
	margin: 0 0 var(--spacing-4);
	border-left: 3px solid var(--lp-accent-color, var(--color-primary));
	text-align: left;
	margin-inline: var(--spacing-6);
}

.lp-author-box__signature {
	margin-bottom: var(--spacing-4);
}

.lp-author-box__signature img {
	height: 3rem;
	width: auto;
}

.lp-author-box__social {
	display: flex;
	gap: var(--spacing-3);
	justify-content: center;
	padding: var(--spacing-4) var(--spacing-6);
	border-top: 1px solid var(--color-neutral-100);
}

.lp-author-box__social-link {
	color: var(--lp-accent-color, var(--color-primary));
	transition: opacity 0.2s ease;
}

.lp-author-box__social-link:hover {
	opacity: 0.7;
}

.lp-author-box__social-link .ds-icon {
	width: 1.25rem;
	height: 1.25rem;
}

/* Author Box: magazine layout */
.lp-author-box--magazine .lp-author-box__card {
	max-width: 64rem;
	text-align: left;
}

@media (min-width: 768px) {
	.lp-author-box--magazine .lp-author-box__card {
		display: grid;
		grid-template-columns: 1fr 1fr;
	}

	.lp-author-box--magazine .lp-author-box__cover {
		height: auto;
		min-height: 20rem;
	}

	.lp-author-box--magazine .lp-author-box__avatar {
		margin-top: var(--spacing-6);
	}

	.lp-author-box--magazine .lp-author-box__social {
		justify-content: flex-start;
	}
}

/* Author Box: minimal layout */
.lp-author-box--minimal .lp-author-box__card {
	max-width: 64rem;
	box-shadow: none;
	border-radius: 0;
	background-color: transparent;
	display: flex;
	align-items: center;
	gap: var(--spacing-6);
	text-align: left;
	flex-wrap: wrap;
}

.lp-author-box--minimal .lp-author-box__cover {
	display: none;
}

.lp-author-box--minimal .lp-author-box__avatar {
	margin: 0;
	flex-shrink: 0;
}

.lp-author-box--minimal .lp-author-box__avatar img {
	width: 4rem;
	height: 4rem;
	border: 0;
}

.lp-author-box--minimal .lp-author-box__social {
	border-top: none;
	padding: 0;
}

/* ==========================================================================
   Image Grid (new section)
   ========================================================================== */

.lp-image-grid {
	background-color: var(--lp-bg, transparent);
}

.lp-image-grid__title {
	font-family: var(--lp-title-font, var(--font-serif));
	font-size: var(--text-2xl);
	color: var(--lp-title-color, var(--color-neutral-900));
	text-align: center;
	margin: 0 0 var(--spacing-3);
}

.lp-image-grid__subtitle {
	font-family: var(--font-sans);
	font-size: var(--text-base);
	color: var(--color-neutral-600);
	text-align: center;
	margin: 0 0 var(--spacing-8);
}

.lp-image-grid__grid {
	display: grid;
	grid-template-columns: repeat(var(--lp-grid-columns, 3), 1fr);
	gap: var(--lp-grid-gap, var(--spacing-4));
}

.lp-image-grid__item {
	margin: 0;
	overflow: hidden;
	border-radius: var(--lp-img-radius, 0);
}

.lp-image-grid__item a {
	display: block;
}

.lp-image-grid__item img {
	width: 100%;
	height: auto;
	display: block;
	object-fit: cover;
	transition: transform 0.3s ease;
}

/* Aspect ratio options */
.lp-image-grid--ratio-square .lp-image-grid__item img   { aspect-ratio: 1 / 1; }
.lp-image-grid--ratio-landscape .lp-image-grid__item img { aspect-ratio: 16 / 9; }
.lp-image-grid--ratio-portrait .lp-image-grid__item img  { aspect-ratio: 3 / 4; }

/* Hover effects */
.lp-image-grid--hover-zoom .lp-image-grid__item:hover img {
	transform: scale(1.05);
}

.lp-image-grid--hover-fade-caption .lp-image-grid__item {
	position: relative;
}

.lp-image-grid--hover-fade-caption .lp-image-grid__caption--overlay {
	position: absolute;
	inset: auto 0 0;
	padding: var(--spacing-3) var(--spacing-4);
	background: linear-gradient(transparent, var(--color-neutral-900));
	color: var(--color-white);
	opacity: 0;
	transition: opacity 0.3s ease;
}

.lp-image-grid--hover-fade-caption .lp-image-grid__item:hover .lp-image-grid__caption--overlay {
	opacity: 1;
}

.lp-image-grid__caption {
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	color: var(--lp-caption-color, var(--color-neutral-500));
	padding-top: var(--spacing-2);
}

/* Masonry layout (CSS multi-column) */
.lp-image-grid--masonry .lp-image-grid__grid {
	display: block;
	columns: var(--lp-grid-columns, 3);
	column-gap: var(--lp-grid-gap, var(--spacing-4));
}

.lp-image-grid--masonry .lp-image-grid__item {
	break-inside: avoid;
	margin-bottom: var(--lp-grid-gap, var(--spacing-4));
}

/* Collage layout: first item spans 2x2 */
.lp-image-grid--collage .lp-image-grid__item:first-child {
	grid-column: span 2;
	grid-row: span 2;
}

/* Responsive: fewer columns on mobile */
@media (max-width: 767px) {
	.lp-image-grid__grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.lp-image-grid--masonry .lp-image-grid__grid {
		columns: 2;
	}
}

/* Grid gap sizes */
.lp-image-grid--gap-none .lp-image-grid__grid { gap: 0; }
.lp-image-grid--gap-sm .lp-image-grid__grid   { gap: var(--spacing-2); }
.lp-image-grid--gap-lg .lp-image-grid__grid   { gap: var(--spacing-8); }

/* Image radius sizes */
.lp-image-grid--radius-sm .lp-image-grid__item  { border-radius: var(--radius-sm); }
.lp-image-grid--radius-md .lp-image-grid__item  { border-radius: var(--radius-md); }
.lp-image-grid--radius-lg .lp-image-grid__item  { border-radius: var(--radius-lg); }
.lp-image-grid--radius-full .lp-image-grid__item { border-radius: var(--radius-full); }

/* ==========================================================================
   Embed (new section)
   ========================================================================== */

.lp-embed {
	background-color: var(--lp-bg, transparent);
}

.lp-embed__title {
	font-family: var(--lp-title-font, var(--font-serif));
	font-size: var(--text-2xl);
	color: var(--lp-title-color, var(--color-neutral-900));
	text-align: center;
	margin: 0 0 var(--spacing-3);
}

.lp-embed__description {
	font-family: var(--font-sans);
	font-size: var(--text-base);
	color: var(--lp-text-color, var(--color-neutral-600));
	text-align: center;
	margin: 0 0 var(--spacing-8);
	max-width: 36rem;
	margin-inline: auto;
}

.lp-embed__container {
	max-width: var(--lp-embed-max-width, 48rem);
	margin-inline: auto;
}

.lp-embed__container > iframe,
.lp-embed__container > video,
.lp-embed__container > embed {
	width: 100%;
	aspect-ratio: var(--lp-embed-ratio, auto);
}
