/*
 Theme Name: Twenty Twenty-Four Child
 Template: twentytwentyfour
 Version: 1.0.3
*/

/* ============================
   BASE / CARDS / MEDIA
============================ */
.wp-block-query .wp-block-post-template.is-layout-grid {
	gap: var(--wp--preset--spacing--m, 1.25rem);
}
.wp-block-post-template > li {
	list-style: none;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.wp-block-post-template > li:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(0, 0, 0, 0.08);
}
.wp-block-post-featured-image,
.wp-block-post .wp-block-post-featured-image {
	position: relative;
	overflow: hidden;
	border-radius: 16px;
}
.wp-block-post-featured-image img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: 16px;
}
.cards-16x9 .wp-block-post-featured-image img {
	aspect-ratio: 16/9;
	object-fit: cover;
}
.entry-content img,
.entry-content video {
	width: 100%;
	height: auto;
}

/* ============================
   FARMHOUSE BUILD GRID
   (Add class "farmhouse-grid" to that Query Loop)
============================ */
.farmhouse-grid .wp-block-post-template {
	--wp--style--block-gap: 0.22rem !important;
}
.farmhouse-grid .wp-block-post-featured-image,
.farmhouse-grid .wp-block-post-featured-image a {
	margin: 0 !important;
	display: block;
	border-radius: 16px;
	overflow: hidden;
}
.farmhouse-grid .wp-block-post-template h2.wp-block-post-title {
	font-size: clamp(0.95rem, 1.05vw, 1.15rem) !important;
	line-height: 1.18;
	margin: 0 0 0.25rem !important;
	text-align: center;
	padding: 0 0.25rem;
}
.farmhouse-grid .wp-block-post-template h2.wp-block-post-title a {
	color: inherit;
	text-decoration: none;
}
.farmhouse-grid .wp-block-post-template.is-layout-grid {
	gap: 1.1rem;
}

/* Hide accidental spacing when Post Content is empty */
.single .wp-block-post-content:empty {
	display: none;
}

/* ============================
   SINGLE — PHOTO (wrapper class on template)
============================ */
.single-photo-template {
	max-width: clamp(320px, 92vw, 1000px);
	margin-inline: auto;
}
.single-photo-template .wp-block-post-featured-image img {
	max-height: min(78vh, 1200px);
	object-fit: contain; /* show full portrait or landscape */
	border-radius: 16px;
}
.single-photo-template .wp-block-post-featured-image {
	margin-bottom: var(--wp--preset--spacing--30, 1.5rem);
}

/* Optional: center/narrow utility for sections */
.pics-narrow {
	max-width: clamp(320px, 92vw, 1100px);
	margin-inline: auto;
}

/* Video play badge on card-style posts (when post has tag "video") */
.wp-block-post .wp-block-post-featured-image a {
	position: relative;
	display: block;
}
.wp-block-post.tag-video .wp-block-post-featured-image a::after {
	content: "▶";
	position: absolute;
	right: 0.55rem;
	bottom: 0.55rem;
	width: 2.25rem;
	height: 2.25rem;
	display: grid;
	place-items: center;
	background: rgba(0, 0, 0, 0.6);
	color: #fff;
	border-radius: 50%;
	font-size: 1rem;
	line-height: 1;
	box-shadow: 0 3px 10px rgba(0, 0, 0, 0.25);
}

/* ============================
   PICTURES PAGE
============================ */
.gallery-cards .wp-block-cover {
	border-radius: 18px;
	overflow: hidden;
	min-height: clamp(220px, 28vw, 380px);
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}
.gallery-cards .wp-block-cover__inner-container {
	text-align: center;
}
.gallery-cards .wp-block-button .wp-block-button__link {
	border-radius: 999px;
	padding: 0.5rem 1rem;
}

/* Generic picture grids */
.pics-grid .wp-block-post-template.is-layout-grid {
	gap: clamp(0.75rem, 1.5vw, 1.25rem);
}
.pics-grid .wp-block-post-featured-image {
	margin: 0 0 0.4rem;
}
.pics-grid .wp-block-post-title {
	font-size: clamp(0.95rem, 1vw, 1.1rem);
	text-align: center;
	margin: 0.35rem 0 0;
}

/* ============================
   SINGLE — VIDEO template
============================ */
.wp-template-single-video .wp-block-post-featured-image {
	display: none !important;
}

/* ============================
   SINGLE MEDIA NAV (prev/next under image or video)
============================ */
.photo-nav {
	max-width: clamp(320px, 92vw, 1000px);
	margin: 0.75rem auto 1.5rem;
	display: flex;
	align-items: center;
	gap: var(--wp--style--block-gap, 1rem);
}
.photo-nav .nav-left {
	margin-right: auto;
}
.photo-nav .nav-right {
	margin-left: auto;
	text-align: right;
}
/* Neutralize any theme-provided arrows on nav links */
.wp-block-post-navigation-link a::before,
.wp-block-post-navigation-link a::after {
	content: none !important;
}
/* Our arrows */
.photo-nav .nav-left .wp-block-post-navigation-link a::before {
	content: "←";
	margin-inline-end: 0.4rem;
}
.photo-nav .nav-right .wp-block-post-navigation-link a::after {
	content: "→";
	margin-inline-start: 0.4rem;
}

/* ============================
   GALLERY — captions & video play badge (thumbnails)
============================ */
/* Keep captions BELOW the image (as you had) */
.wp-block-gallery .wp-block-image {
	position: relative;
	overflow: hidden;
}
.wp-block-gallery .wp-block-image figcaption {
	position: static !important;
	background: none !important;
	color: #111 !important;
	text-shadow: none !important;
	padding: 0.5rem 0 0;
}

/* Mark your three video thumbnails with class "is-video"
   (Block → Advanced → Additional CSS class(es)) */

/* White circular badge */
.wp-block-gallery .wp-block-image.is-video::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 56px;
	height: 56px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.92);
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.25);
	pointer-events: none;
	z-index: 50;
}

/* Dark triangle */
.wp-block-gallery .wp-block-image.is-video::before {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-35%, -50%);
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 12px 0 12px 18px; /* triangle size */
	border-color: transparent transparent transparent #111;
	pointer-events: none;
	z-index: 60;
}

/* 3-column grid for #lightgallery */
#lightgallery {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1rem;
}

#lightgallery {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1rem;
}
#lightgallery a {
	display: block;
}

/* Force toolbar & close button to be visible */
.lg-toolbar {
	display: flex !important;
	opacity: 1 !important;
}
.lg-toolbar .lg-close {
	display: inline-block !important;
}
