/*
Theme Name: Posidonia Rizoma
Theme URI: 
Author: Mike Goodstadt
Author URI: 
Description: A Block theme for JuanCarlosNadal.com
Requires at least: 6.9
Tested up to: 6.9
Requires PHP: 8.0
Version: 0.8.1
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: posidonia-rizoma
Tags: 
*/

/* Site-wide fixed header */
.wp-site-blocks > .wp-block-template-part.site-header {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 10001;
	background: rgba(255, 255, 255, 0.3);
}

.admin-bar {
	--wp-admin-offset: 32px;
}

@media (max-width: 782px) {
	.admin-bar {
		--wp-admin-offset: 46px;
	}
}

.admin-bar .wp-site-blocks > .wp-block-template-part.site-header {
	top: var(--wp-admin-offset);
}

/* Non-home templates: leave some headspace below the fixed transparent header */
.wp-site-blocks > .main-content,
.wp-site-blocks > main.wp-block-group {
	width: min(calc(100% - 3.75rem), var(--wp--style--global--wide-size));
	max-width: var(--wp--style--global--wide-size);
	margin-right: auto;
	margin-left: auto;
	padding-top: 50px; /* matches fixed header height — keep px */
	padding-right: 0;
	padding-left: 0;
	box-sizing: border-box;
}

@media (max-width: 767.98px) {
	.wp-site-blocks > .main-content,
	.wp-site-blocks > main.wp-block-group {
		padding-top: 50px;
	}
}

/* Front page hero slider */
.home .wp-site-blocks > .wp-block-blablablocks-slider.alignfull {
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	margin-top: 0 !important;
	margin-bottom: 0 !important;
	padding: 0 !important;
}

.home .wp-site-blocks > .wp-block-blablablocks-slider.alignfull,
.home .wp-site-blocks > .wp-block-blablablocks-slider.alignfull .swiper,
.home .wp-site-blocks > .wp-block-blablablocks-slider.alignfull .swiper-wrapper,
.home .wp-site-blocks > .wp-block-blablablocks-slider.alignfull .swiper-slide {
	height: 100vh;
	min-height: 100vh;
}

@supports (height: 100svh) {
	.home .wp-site-blocks > .wp-block-blablablocks-slider.alignfull,
	.home .wp-site-blocks > .wp-block-blablablocks-slider.alignfull .swiper,
	.home .wp-site-blocks > .wp-block-blablablocks-slider.alignfull .swiper-wrapper,
	.home .wp-site-blocks > .wp-block-blablablocks-slider.alignfull .swiper-slide {
		height: 100svh;
		min-height: 100svh;
	}
}

@supports (height: 100dvh) {
	.home .wp-site-blocks > .wp-block-blablablocks-slider.alignfull,
	.home .wp-site-blocks > .wp-block-blablablocks-slider.alignfull .swiper,
	.home .wp-site-blocks > .wp-block-blablablocks-slider.alignfull .swiper-wrapper,
	.home .wp-site-blocks > .wp-block-blablablocks-slider.alignfull .swiper-slide {
		height: 100dvh;
		min-height: 100dvh;
	}
}

.home .wp-site-blocks > .wp-block-blablablocks-slider.alignfull .swiper-slide .wp-block-image,
.home .wp-site-blocks > .wp-block-blablablocks-slider.alignfull .swiper-slide .wp-block-image figure {
	height: 100%;
	margin: 0;
}

.home .wp-site-blocks > .wp-block-blablablocks-slider.alignfull .swiper-slide .wp-block-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.admin-bar.home .wp-site-blocks > .wp-block-blablablocks-slider.alignfull,
.admin-bar.home .wp-site-blocks > .wp-block-blablablocks-slider.alignfull .swiper,
.admin-bar.home .wp-site-blocks > .wp-block-blablablocks-slider.alignfull .swiper-wrapper,
.admin-bar.home .wp-site-blocks > .wp-block-blablablocks-slider.alignfull .swiper-slide {
	height: calc(100vh - var(--wp-admin-offset));
	min-height: calc(100vh - var(--wp-admin-offset));
}

@supports (height: 100svh) {
	.admin-bar.home .wp-site-blocks > .wp-block-blablablocks-slider.alignfull,
	.admin-bar.home .wp-site-blocks > .wp-block-blablablocks-slider.alignfull .swiper,
	.admin-bar.home .wp-site-blocks > .wp-block-blablablocks-slider.alignfull .swiper-wrapper,
	.admin-bar.home .wp-site-blocks > .wp-block-blablablocks-slider.alignfull .swiper-slide {
		height: calc(100svh - var(--wp-admin-offset));
		min-height: calc(100svh - var(--wp-admin-offset));
	}
}

@supports (height: 100dvh) {
	.admin-bar.home .wp-site-blocks > .wp-block-blablablocks-slider.alignfull,
	.admin-bar.home .wp-site-blocks > .wp-block-blablablocks-slider.alignfull .swiper,
	.admin-bar.home .wp-site-blocks > .wp-block-blablablocks-slider.alignfull .swiper-wrapper,
	.admin-bar.home .wp-site-blocks > .wp-block-blablablocks-slider.alignfull .swiper-slide {
		height: calc(100dvh - var(--wp-admin-offset));
		min-height: calc(100dvh - var(--wp-admin-offset));
	}
}

/* Home hero header contrast */
.home .wp-site-blocks > .wp-block-template-part.site-header {
	background: transparent;
}

.home .wp-site-blocks > .wp-block-template-part.site-header,
.home .wp-site-blocks > .wp-block-template-part.site-header a,
.home .wp-site-blocks > .wp-block-template-part.site-header .wp-block-navigation-item__content {
	color: #888;
	text-shadow: none;
}

/* Header text spacing for file-based template part and Site Editor-rendered fallback */
.header-main .wp-block-site-title {
	margin: 0 0 0.25rem;
}

.home .wp-site-blocks > .wp-block-template-part.site-header .wp-block-navigation-item__content:hover,
.home .wp-site-blocks > .wp-block-template-part.site-header .wp-block-navigation-item__content:focus-visible {
	opacity: 0.9;
}

/* ============================================================
   Header width alignment
   ============================================================ */


.wp-block-group.alignfull.header-main {
	width: min(calc(100% - 3.75rem), var(--wp--style--global--wide-size));
	max-width: var(--wp--style--global--wide-size);
	margin-right: auto;
	margin-left: auto;
	padding-right: 0;
	padding-left: 0;
	box-sizing: border-box;
}

@media (min-width: 768px) {
	.header-main {
		flex-wrap: nowrap;
	}
}

/* Override core nav animation: fade only, no slide */
@keyframes overlay-menu__fade-in-animation {
	0%   { opacity: 0; }
	to   { opacity: 1; }
}

@media (max-width: 767.98px) {
	.header-main {
		flex-wrap: nowrap !important;
		align-items: center !important;
	}

	.header-main .wp-block-navigation__responsive-container-open {
		display: flex !important;
		align-items: center;
		justify-content: center;
		padding: 0;
		line-height: 0;
	}

	/* Replace 2-line WP core hamburger with a 3-line icon via CSS */
	.header-main .wp-block-navigation__responsive-container-open svg {
		display: none;
	}

	.header-main .wp-block-navigation__responsive-container-open::before {
		content: '';
		display: block;
		width: 20px;
		height: 2px;
		background: currentColor;
		box-shadow: 0 -6px 0 currentColor, 0 6px 0 currentColor;
	}

	.header-main .wp-block-navigation {
		position: relative;
		flex: 0 0 auto;
		margin-left: auto;
	}

	.header-main .wp-block-navigation > .wp-block-navigation__container {
		display: none !important;
	}

	.header-main .wp-block-navigation__responsive-container:not(.is-menu-open) .wp-block-navigation__responsive-container-content {
		display: none !important;
	}

	/* Hide hamburger when menu is open */
	.header-main .wp-block-navigation:has(.wp-block-navigation__responsive-container.is-menu-open) .wp-block-navigation__responsive-container-open {
		display: none !important;
	}

	/* Menu card */
	.header-main .wp-block-navigation__responsive-container.is-menu-open {
		position: absolute !important;
		top: -1.2rem;
		right: -0.95rem;
		left: auto;
		bottom: auto;
		width: min(280px, calc(100vw - 60px));
		height: auto;
		min-height: 0;
		overflow: visible !important;
		padding: 0 !important;
		background: rgba(255, 255, 255, 0.75) !important;
		backdrop-filter: blur(6px);
		-webkit-backdrop-filter: blur(6px);
		border: 1px solid rgba(0, 0, 0, 0.08);
		border-radius: 6px;
		box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
		z-index: 10020;
	}

	/* Dialog: relative so X button can be positioned inside */
	.header-main .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-dialog {
		position: relative;
		background: transparent !important;
		padding: 2.25rem 1.25rem 1.25rem;
	}

	.header-main .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-close,
	.header-main .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
		background: transparent !important;
	}

	/* X close button: top-right corner inside the card */
	.header-main .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-close {
		position: absolute;
		top: 0.4rem;
		right: 0.75rem;
		left: auto;
		bottom: auto;
	}

	.header-main .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
		padding-top: 0 !important;
	}

	.header-main .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container {
		display: block !important;
	}

	/* Adequate touch targets for mobile nav items (min 44px height) */
	.header-main .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content {
		display: block;
		padding: 0.75rem 0;
		font-size: 1rem;
		line-height: 1.4;
	}
}

@media (min-width: 600px) and (max-width: 767.98px) {
	.header-main .wp-block-navigation__responsive-container:not(.is-menu-open) {
		display: none !important;
	}
}

/* ============================================================
   Footer horizontal padding
   ============================================================ */

/* Footer */
.footer-bar {
	background-color: #fff;
	color: #757575;
	text-decoration: none;
	padding: 1rem 2rem;
	margin-top: 2rem;
	justify-content: center;
}

@media (min-width: 1024px) {
	.footer-bar {
		padding-right: 4rem;
		padding-left: 4rem;
	}
}

@media (min-width: 1280px) {
	.footer-bar {
		padding-right: 7.5rem;
		padding-left: 7.5rem;
	}
}

@media (min-width: 1920px) {
	.footer-bar {
		padding-right: 10rem;
		padding-left: 10rem;
	}
}

.footer-legal {
	justify-content: center;
	gap: 0.75rem;
}

.footer-copyright {
	margin: 0;
	font-size: 0.875rem;
}

.footer-legal .wp-block-navigation {
	margin: 0;
}

.footer-legal .footer-legal-menu .wp-block-navigation__container,
.footer-legal .footer-legal-menu ul {
	gap: 0.75rem;
}

.footer-legal .wp-block-navigation-item {
	margin: 0;
}

/* Works page grid — matches juancarlosnadal.com breakpoints + padding system */

.site-content > .archive-header {
	padding: 0;
}

.category-works .wp-block-post-template {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
	margin: 0 auto;
	padding: 0;
	list-style: none;
	max-width: 100%;
	box-sizing: border-box;
}

@media (min-width: 640px) {
	.category-works .wp-block-post-template {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (min-width: 768px) {
	.category-works .wp-block-post-template {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (min-width: 1024px) {
	.site-content > .archive-header,
	.category-works .wp-block-post-template {
		padding-right: 2rem;
		padding-left: 2rem;
	}
}

@media (min-width: 1536px) {
	.category-works .wp-block-post-template {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

.category-works .wp-block-post-template li {
	min-width: 0;
	width: 100%;
	display: flex;
	flex-direction: column;
	margin-top: 0 !important;
	margin-block-start: 0 !important;
}

.category-works .wp-block-post-template li .gallery-item {
	display: flex;
	flex-direction: column;
	flex: 1;
	position: relative;
}

.category-works .wp-block-post-template li .gallery-item > figure,
.category-works .wp-block-post-template li .gallery-item > a {
	aspect-ratio: 3 / 2;
	overflow: hidden;
	margin: 0;
}

.category-works .wp-block-post-template li img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.category-works .wp-block-post-template li h3 {
	margin: 0.5rem 0 0;
	padding: 0;
}

.category-works .wp-block-post-template li .gallery-item .wp-block-post-title a {
	position: static;
}

.category-works .wp-block-post-template li .gallery-item .wp-block-post-title a::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 2;
	cursor: pointer;
}

/* Index + single templates: prevent post content media from overflowing constrained width */
.index-main .wp-block-post-content,
.single-main .wp-block-post-content {
	min-width: 0;
	overflow-wrap: anywhere;
}

.index-main .wp-block-post-content img,
.index-main .wp-block-post-content video,
.index-main .wp-block-post-content iframe,
.index-main .wp-block-post-content embed,
.index-main .wp-block-post-content object,
.single-main .wp-block-post-content img,
.single-main .wp-block-post-content video,
.single-main .wp-block-post-content iframe,
.single-main .wp-block-post-content embed,
.single-main .wp-block-post-content object {
	max-width: 100%;
	height: auto;
}

.index-main .wp-block-post-content .alignwide,
.index-main .wp-block-post-content .alignfull,
.single-main .wp-block-post-content .alignwide,
.single-main .wp-block-post-content .alignfull {
	width: 100%;
	max-width: 100%;
	margin-left: 0;
	margin-right: 0;
}

/* Fallback table reset (main config now in theme.json) */
.wp-block-table thead,
.wp-block-table tfoot,
.wp-block-table tr,
.wp-block-table th,
.wp-block-table td,
.wp-block-table table {
	border: none !important;
}

/* ============================================================
   Block compatibility — core block normalization
   ============================================================ */

/* Captions — base typography. Also defined in theme.json elements.caption for editor control. */
body .wp-element-caption,
body figcaption {
	color: #121212;
	font-size: 1rem;
	line-height: 1.5;
	font-style: normal;
	text-align: left;
	margin-top: 0.75rem;
	margin-bottom: 2.25rem;
}

body .wp-element-caption cite,
body figcaption cite {
	font-style: italic;
}

/* Image block: remove default bottom margin */
.wp-block-image figure {
	margin: 0;
}

/* Blockquote */
.wp-block-quote {
	border-left: 1px solid #ccc;
	margin: 1.5em 0;
	padding: 0.25em 1.5em;
	font-style: italic;
}

.wp-block-quote cite,
.wp-block-quote footer,
.wp-block-quote .wp-block-quote__citation {
	font-style: normal;
	font-size: 0.75rem;
	color: #aaa;
	display: block;
	margin-top: 0.5em;
}

/* Large / plain style quote: no border */
.wp-block-quote.is-style-large,
.wp-block-quote.is-style-plain {
	border-left: none;
	padding-left: 0;
	font-size: 1.1em;
}

/* Pullquote */
.wp-block-pullquote {
	border-top: 1px solid #ccc;
	border-bottom: 1px solid #ccc;
	text-align: center;
	padding: 1.5em 0;
	margin: 2em 0;
}

.wp-block-pullquote blockquote {
	border: none;
	padding: 0;
	margin: 0;
	font-style: italic;
}

.wp-block-pullquote cite,
.wp-block-pullquote .wp-block-pullquote__citation {
	font-style: normal;
	font-size: 0.6875rem;
	color: #aaa;
	display: block;
	margin-top: 0.5em;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

/* Separator */
.wp-block-separator {
	border: none;
	border-top: 1px solid #ddd;
	margin: 2em auto;
	max-width: 40px;
}

.wp-block-separator.is-style-wide {
	max-width: 100%;
}

.wp-block-separator.is-style-dots {
	max-width: none;
	border: none;
	text-align: center;
	color: #ccc;
	font-size: 0.875rem;
	line-height: 1;
}

/* Core gallery block */
.wp-block-gallery {
	gap: 0.5rem;
}

/* Allow figcaption to sit outside the natural image boundary */
.wp-block-gallery figure.wp-block-image {
	overflow: visible;
}

/* Natural image sizing — override is-cropped height:100% / flex:1 behavior */
.wp-block-gallery figure.wp-block-image img {
	flex: none !important;
	height: auto !important;
	width: 100%;
	object-fit: initial;
}

/* Remove WP core's blur-gradient ::before backdrop (only appears with figcaption) */
.wp-block-gallery figure.wp-block-image:has(figcaption)::before,
.wp-block-gallery figure.wp-block-image:has(.wp-element-caption)::before {
	content: none !important;
}

/* Figcaption below image, not as overlay.
   Typography (color, font-size) inherited from theme.json elements.caption. */
.wp-block-gallery.has-nested-images figure.wp-block-image figcaption,
.wp-block-gallery.has-nested-images figure.wp-block-image .wp-element-caption {
	position: static !important;
	max-height: none !important;
	background: none !important;
	color: var(--wp--elements--caption--color--text, #121212);
	font-size: var(--wp--elements--caption--typography--font-size, 1rem);
	line-height: var(--wp--elements--caption--typography--line-height, 1.5);
	font-style: normal;
	text-align: left;
	text-shadow: none !important;
	padding: 0;
	margin: 0.75rem 0;
	overflow: visible !important;
}

.wp-block-gallery.has-nested-images figure.wp-block-image figcaption small.obra-description {
	display: block;
	margin-top: 0.25rem;
}

/* Responsive embed */
.wp-block-embed__wrapper {
	position: relative;
	width: 100%;
	overflow: hidden;
}

.wp-block-embed.wp-embed-aspect-16-9 .wp-block-embed__wrapper { aspect-ratio: 16 / 9; }
.wp-block-embed.wp-embed-aspect-4-3  .wp-block-embed__wrapper { aspect-ratio: 4 / 3; }
.wp-block-embed.wp-embed-aspect-21-9 .wp-block-embed__wrapper { aspect-ratio: 21 / 9; }

.wp-block-embed.wp-embed-aspect-16-9 .wp-block-embed__wrapper iframe,
.wp-block-embed.wp-embed-aspect-4-3  .wp-block-embed__wrapper iframe,
.wp-block-embed.wp-embed-aspect-21-9 .wp-block-embed__wrapper iframe {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border: none;
}

/* Code / preformatted */
.wp-block-code,
.wp-block-preformatted {
	font-size: 0.8125rem;
	background: #f5f5f5;
	padding: 1em 1.25em;
	overflow-x: auto;
	border-radius: 2px;
	line-height: 1.6;
}

/* Buttons: flatten radius, honour theme weight */
.wp-block-button__link {
	border-radius: 0 !important;
	font-weight: 300;
	letter-spacing: 0.03em;
}

/* ============================================================
   Content & gallery spacing
   ============================================================ */

/* Breathing room between post-title and content */
.single-main .wp-block-post-title,
.index-main  .wp-block-post-title {
	margin-bottom: 1.25rem;
}

/* Vertical rhythm inside constrained post content */
.wp-block-post-content > * + * {
	margin-top: 1.25rem;
}

.wp-block-post-content > .wp-block-heading + *,
.wp-block-post-content > h1 + *,
.wp-block-post-content > h2 + *,
.wp-block-post-content > h3 + * {
	margin-top: 0.5rem;
}

/* Category-works grid: wider row gap for visual breathing room */
.category-works .wp-block-post-template {
	row-gap: 2rem;
	column-gap: 2rem;
}
