/* =====================================================================
   Marsili 2026 — Theme overrides
   Block theme: most styling lives in theme.json. This file adds:
   - Element-level tweaks not expressible in theme.json
   - Custom-class styles used by patterns and parts
   - Form (CF7) styling
   - Print
   ===================================================================== */

/* --- Reset light --- */
:root {
	--marsili-radius: 6px;
	--marsili-radius-lg: 12px;
	--marsili-shadow-soft: 0 1px 2px rgba(15, 27, 31, 0.06), 0 1px 3px rgba(15, 27, 31, 0.04);
	--marsili-shadow-medium: 0 4px 6px rgba(15, 27, 31, 0.05), 0 10px 15px rgba(15, 27, 31, 0.07);
	--marsili-transition: 200ms cubic-bezier(0.22, 1, 0.36, 1);
}

html { scroll-behavior: smooth; }

body {
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
	overflow-x: hidden; /* safety net against off-viewport submenus & fixed widgets */
}

/* --- Focus visible --- */
:focus-visible {
	outline: 2px solid var(--wp--preset--color--primary);
	outline-offset: 2px;
	border-radius: 3px;
}

/* --- Skip link --- */
.skip-link {
	position: absolute;
	top: -40px;
	left: 0;
	padding: 0.5rem 1rem;
	background: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--base);
	font-weight: 600;
	z-index: 1000;
	transition: top var(--marsili-transition);
}
.skip-link:focus { top: 0; }

/* --- Site header --- */
.site-header { backdrop-filter: saturate(180%) blur(8px); }
.site-header__inner {
	gap: clamp(1rem, 3vw, 2rem);
	align-items: center;
	/* Flex containers inside a constrained group don't auto-stretch to the
	   parent's max-width; force full width so logo + nav + tools span 1280px. */
	width: 100%;
}
.site-header__tools {
	display: inline-flex;
	gap: 1rem;
	align-items: center;
	font-size: var(--wp--preset--font-size--sm);
}
.site-header__tools .lang {
	text-transform: uppercase;
	font-weight: 600;
	letter-spacing: 0.05em;
	color: var(--wp--preset--color--body);
	text-decoration: none;
}
.site-header__tools .lang:hover { color: var(--wp--preset--color--primary); }
.site-header__lang { display: inline-flex; gap: 0.25rem; align-items: center; }
.site-header__search {
	color: var(--wp--preset--color--body);
	text-decoration: none;
	padding: 0.25rem 0.5rem;
	border-radius: var(--marsili-radius);
}
.site-header__search:hover { background: var(--wp--preset--color--bg-subtle); }

/* --- Navigation --- */
.wp-block-navigation .wp-block-navigation-item__content {
	font-weight: 500;
	transition: color var(--marsili-transition);
}
.wp-block-navigation .wp-block-navigation-item__content:hover {
	color: var(--wp--preset--color--primary);
}
.wp-block-navigation .current-menu-item > .wp-block-navigation-item__content,
.wp-block-navigation .current_page_item > .wp-block-navigation-item__content {
	color: var(--wp--preset--color--primary);
}

/* --- Buttons --- */
.wp-element-button, .wp-block-button__link {
	transition: background-color var(--marsili-transition), color var(--marsili-transition), transform var(--marsili-transition);
	font-weight: 600;
	letter-spacing: 0.01em;
}
.wp-block-button__link:hover { transform: translateY(-1px); }
.wp-block-button.is-style-outline .wp-block-button__link {
	border: 1px solid currentColor;
	background: transparent;
}
.wp-block-button.is-style-outline .wp-block-button__link:hover {
	background: var(--wp--preset--color--primary-light);
	color: var(--wp--preset--color--ink);
}
.front-hero .wp-block-button.is-style-outline .wp-block-button__link:hover {
	background: rgba(255, 255, 255, 0.08);
	color: var(--wp--preset--color--base);
}

/* --- Placeholder assets --- */
.ph {
	background-color: var(--wp--preset--color--primary-dark);
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	display: block;
	width: 100%;
	aspect-ratio: 4 / 3;
}
.ph--helm    { background-image: url("../images/placeholders/helm.svg"); }
.ph--boat    { background-image: url("../images/placeholders/boat.svg"); }
.ph--cyl     { background-image: url("../images/placeholders/cylinder.svg"); background-color: var(--wp--preset--color--bg-subtle); }
.ph--16x9    { aspect-ratio: 16 / 9; }
.ph--4x5     { aspect-ratio: 4 / 5; }
.ph--square  { aspect-ratio: 1 / 1; }
.ph--hero    { aspect-ratio: auto; height: 100%; min-height: 480px; }

/* --- Editorial utilities --- */
.eyebrow {
	font-family: var(--wp--preset--font-family--mono);
	font-size: var(--wp--preset--font-size--xs);
	text-transform: uppercase;
	letter-spacing: 0.14em;
	font-weight: 500;
}
.num {
	font-family: var(--wp--preset--font-family--mono);
	font-variant-numeric: tabular-nums;
	font-feature-settings: "tnum" 1;
}

/* --- Hero (split image + content) --- */
.front-hero {
	background: var(--wp--preset--color--primary-dark);
	color: var(--wp--preset--color--base);
	position: relative;
	overflow: hidden;
}
.front-hero h1 {
	max-width: 18ch;
	letter-spacing: -0.025em;
	color: var(--wp--preset--color--base);
}
.front-hero p { max-width: 48ch; color: var(--wp--preset--color--primary-light); }
.front-hero__inner {
	display: grid;
	grid-template-columns: 1.05fr 1fr;
	gap: var(--wp--preset--spacing--60);
	align-items: stretch;
	min-height: 540px;
}
.front-hero__media {
	position: relative;
	min-height: 420px;
}
.front-hero__media .ph {
	height: 100%;
	min-height: inherit;
}
.front-hero__media::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(90deg, transparent 60%, var(--wp--preset--color--primary-dark) 100%);
	pointer-events: none;
}
.front-hero__content {
	padding: var(--wp--preset--spacing--70) var(--wp--preset--spacing--40) var(--wp--preset--spacing--70) 0;
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: var(--wp--preset--spacing--30);
}
.front-hero__meta {
	display: flex;
	gap: 1.25rem;
	align-items: center;
	color: var(--wp--preset--color--primary-light);
	opacity: 0.7;
	margin-top: var(--wp--preset--spacing--60);
}
.front-hero__meta::before {
	content: "";
	display: inline-block;
	width: 2.5rem;
	height: 1px;
	background: currentColor;
}
@media (max-width: 900px) {
	.front-hero__inner {
		grid-template-columns: 1fr;
		gap: 0;
		min-height: auto;
	}
	.front-hero__media { min-height: 280px; }
	.front-hero__media::after {
		background: linear-gradient(180deg, transparent 50%, var(--wp--preset--color--primary-dark) 100%);
	}
	.front-hero__content {
		padding: var(--wp--preset--spacing--60) var(--wp--preset--spacing--40);
	}
}

/* --- Hex icon stat (USP) --- */
.hex-stat {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 1rem;
}
.hex-icon {
	width: 64px;
	height: 64px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--wp--preset--color--primary-dark);
	color: var(--wp--preset--color--brass);
	clip-path: polygon(25% 5%, 75% 5%, 100% 50%, 75% 95%, 25% 95%, 0% 50%);
	flex-shrink: 0;
}
.hex-icon svg { width: 30px; height: 30px; stroke: currentColor; fill: none; stroke-width: 1.5; stroke-linecap: round; stroke-linejoin: round; }
.front-hero .hex-icon,
.has-primary-dark-background-color .hex-icon,
.has-primary-background-color .hex-icon {
	background: rgba(255,255,255,0.06);
	color: var(--wp--preset--color--brass);
	border: 1px solid rgba(255,255,255,0.10);
}

/* --- Product tile with image --- */
.product-tile {
	display: block;
	color: inherit;
	text-decoration: none;
	background: var(--wp--preset--color--base);
	border: 1px solid var(--wp--preset--color--line);
	border-radius: 2px;
	overflow: hidden;
	transition: border-color var(--marsili-transition), transform var(--marsili-transition);
	position: relative;
	height: 100%;
}
.product-tile:hover { border-color: var(--wp--preset--color--primary); transform: translateY(-2px); }
.product-tile__media { aspect-ratio: 4 / 3; }
.product-tile__body {
	padding: var(--wp--preset--spacing--30) var(--wp--preset--spacing--40);
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
}
.product-tile__num { color: var(--wp--preset--color--muted); }
.product-tile:hover .product-tile__num { color: var(--wp--preset--color--primary); }
.product-tile__title {
	margin: 0;
	font-size: var(--wp--preset--font-size--lg);
	font-weight: 600;
	color: var(--wp--preset--color--ink);
	line-height: 1.25;
}
.product-tile__title::after { content: " →"; color: var(--wp--preset--color--primary); }

/* --- Application tile (boat type, dark) --- */
.app-tile {
	display: block;
	color: inherit;
	text-decoration: none;
	background: var(--wp--preset--color--ink);
	border-radius: 2px;
	overflow: hidden;
	position: relative;
	height: 100%;
	transition: transform var(--marsili-transition);
}
.app-tile:hover { transform: translateY(-2px); }
.app-tile__media { aspect-ratio: 16 / 10; position: relative; }
.app-tile__media::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 35%, rgba(15,27,31,0.85) 100%);
	pointer-events: none;
}
.app-tile__body {
	position: absolute;
	left: 0; right: 0; bottom: 0;
	padding: var(--wp--preset--spacing--40);
	color: var(--wp--preset--color--base);
	z-index: 1;
}
.app-tile__eyebrow {
	display: block;
	color: var(--wp--preset--color--brass);
	margin-bottom: 0.4rem;
}
.app-tile__title {
	margin: 0;
	font-size: var(--wp--preset--font-size--xl);
	font-weight: 600;
	color: var(--wp--preset--color--base);
	line-height: 1.2;
}
.app-tile__title::after { content: " →"; color: var(--wp--preset--color--brass); }

/* --- USP — hex icon stats on dark BG --- */
.front-usp h3 {
	color: var(--wp--preset--color--base);
	font-weight: 700;
	font-size: var(--wp--preset--font-size--lg);
	letter-spacing: -0.01em;
	margin: 0;
}
.front-usp p.eyebrow {
	color: var(--wp--preset--color--brass);
}
.front-usp .hex-stat p {
	color: var(--wp--preset--color--primary-light);
	opacity: 0.75;
	font-size: var(--wp--preset--font-size--sm);
	margin: 0;
}

/* --- Section heading editorial --- */
.front-products > .wp-block-heading,
.front-systems > .wp-block-heading,
.front-works > .wp-block-heading {
	letter-spacing: -0.02em;
	max-width: 28ch;
}
.section-eyebrow {
	display: block;
	margin-bottom: 1rem;
	color: var(--wp--preset--color--primary);
}

/* --- Product family card (editorial, hairline) --- */
.family-card {
	position: relative;
	transition: border-color var(--marsili-transition), background-color var(--marsili-transition);
	background: var(--wp--preset--color--base);
	border-radius: 2px !important;
	min-height: 180px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}
.family-card:hover {
	border-color: var(--wp--preset--color--primary) !important;
	background: var(--wp--preset--color--bg-subtle);
}
.family-card .family-card__num {
	color: var(--wp--preset--color--muted);
	margin-bottom: 0.75rem;
}
.family-card:hover .family-card__num { color: var(--wp--preset--color--primary); }
.family-card h3 a { text-decoration: none; color: inherit; }
.family-card h3 a::after { content: " →"; color: var(--wp--preset--color--primary); }
.family-card:hover h3 a { color: var(--wp--preset--color--primary); }

/* --- Product card (shop) --- */
.product-card {
	background: var(--wp--preset--color--base);
	transition: border-color var(--marsili-transition), background-color var(--marsili-transition);
	border-radius: 2px !important;
}
.product-card:hover {
	border-color: var(--wp--preset--color--primary) !important;
	background: var(--wp--preset--color--bg-subtle);
}
.product-card .wp-block-post-title a { text-decoration: none; color: var(--wp--preset--color--ink); }

/* --- Breadcrumbs --- */
.marsili-breadcrumbs, .woocommerce-breadcrumb {
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--muted);
	padding: 1rem 0;
}
.marsili-breadcrumbs .wrap, .woocommerce-breadcrumb {
	max-width: 1280px;
	margin-inline: auto;
	padding-inline: var(--wp--preset--spacing--40);
}
.marsili-breadcrumbs a, .woocommerce-breadcrumb a {
	color: var(--wp--preset--color--body);
	text-decoration: none;
}
.marsili-breadcrumbs a:hover, .woocommerce-breadcrumb a:hover { color: var(--wp--preset--color--primary); }
.marsili-breadcrumbs .sep, .woocommerce-breadcrumb .sep { color: var(--wp--preset--color--line); margin: 0 0.4em; }

/* --- WooCommerce product page --- */
.product-top .wp-block-woocommerce-product-image-gallery img {
	border-radius: 8px;
	background: var(--wp--preset--color--bg-subtle);
}
.product-top .wc-block-components-product-sku,
.is-style-mono { font-family: var(--wp--preset--font-family--mono); }

/* --- Shop sidebar --- */
.shop-sidebar .wp-block-search__input {
	border: 1px solid var(--wp--preset--color--line);
	border-radius: var(--marsili-radius);
}
.shop-sidebar .wc-block-product-categories-list a { color: var(--wp--preset--color--body); text-decoration: none; }
.shop-sidebar .wc-block-product-categories-list a:hover { color: var(--wp--preset--color--primary); }

/* --- Catalog browser (category + product grids on shop/archive) --- */
.marsili-cat-grid,
.marsili-product-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: var(--wp--preset--spacing--40);
}
.marsili-cat-card,
.marsili-product-card {
	display: flex;
	flex-direction: column;
	background: var(--wp--preset--color--base);
	border: 1px solid var(--wp--preset--color--line);
	border-radius: 2px;
	overflow: hidden;
	color: inherit;
	text-decoration: none;
	transition: border-color var(--marsili-transition), background-color var(--marsili-transition);
}
.marsili-cat-card:hover,
.marsili-product-card:hover {
	border-color: var(--wp--preset--color--primary);
	background: var(--wp--preset--color--bg-subtle);
}
.marsili-cat-card__media,
.marsili-product-card__media {
	aspect-ratio: 4 / 3;
	background: var(--wp--preset--color--bg-subtle);
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
}
.marsili-cat-card__img,
.marsili-product-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.marsili-cat-card__img--placeholder,
.marsili-product-card__img--placeholder {
	width: 100%;
	height: 100%;
	background:
		linear-gradient(135deg, transparent 47%, var(--wp--preset--color--line) 49%, var(--wp--preset--color--line) 51%, transparent 53%),
		var(--wp--preset--color--bg-subtle);
}
.marsili-cat-card__body,
.marsili-product-card__body {
	padding: var(--wp--preset--spacing--40);
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
}
.marsili-cat-card__title,
.marsili-product-card__title {
	margin: 0;
	font-size: var(--wp--preset--font-size--lg);
	font-weight: 600;
	color: var(--wp--preset--color--ink);
	line-height: 1.3;
}
.marsili-cat-card:hover .marsili-cat-card__title,
.marsili-product-card:hover .marsili-product-card__title {
	color: var(--wp--preset--color--primary);
}
.marsili-cat-card__title span { color: var(--wp--preset--color--primary); }
.marsili-cat-card__desc {
	margin: 0;
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--muted);
	line-height: 1.5;
}
.marsili-product-card__sku {
	font-family: var(--wp--preset--font-family--mono);
	font-size: var(--wp--preset--font-size--xs);
	color: var(--wp--preset--color--muted);
	text-transform: uppercase;
	letter-spacing: 0.04em;
}
.marsili-pagination {
	margin-top: var(--wp--preset--spacing--50);
}
.marsili-empty {
	color: var(--wp--preset--color--muted);
	font-style: italic;
}

/* --- Systems (light editorial section) --- */
.front-systems {
	border-top: 1px solid var(--wp--preset--color--line);
	border-bottom: 1px solid var(--wp--preset--color--line);
}
.front-systems .wp-block-columns { gap: 0 !important; }
.front-systems .wp-block-column {
	padding: var(--wp--preset--spacing--40) var(--wp--preset--spacing--40) var(--wp--preset--spacing--40) 0;
	border-right: 1px solid var(--wp--preset--color--line);
}
.front-systems .wp-block-column:last-child { border-right: 0; padding-right: 0; }
.front-systems .wp-block-column + .wp-block-column { padding-left: var(--wp--preset--spacing--40); }
.front-systems h3 {
	font-size: var(--wp--preset--font-size--lg);
	font-weight: 600;
	margin: 0;
}
.front-systems h3 a {
	text-decoration: none;
	color: var(--wp--preset--color--ink);
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
}
.front-systems h3 a::after {
	content: "→";
	color: var(--wp--preset--color--primary);
	transition: transform var(--marsili-transition);
	display: inline-block;
}
.front-systems h3 a:hover { color: var(--wp--preset--color--primary); }
.front-systems h3 a:hover::after { transform: translateX(4px); }
@media (max-width: 781px) {
	.front-systems .wp-block-column {
		border-right: 0;
		border-bottom: 1px solid var(--wp--preset--color--line);
		padding: var(--wp--preset--spacing--30) 0;
	}
	.front-systems .wp-block-column:last-child { border-bottom: 0; }
	.front-systems .wp-block-column + .wp-block-column { padding-left: 0; }
}

/* --- Works (project highlights) --- */
.work-card { border-radius: 2px !important; }
.work-card .wp-block-cover__inner-container { padding: var(--wp--preset--spacing--50); }

/* --- Footer --- */
.site-footer h4 { color: var(--wp--preset--color--base); }
/* Logo is teal — on a dark teal footer it would blend in. Invert it to white. */
.site-footer .wp-block-site-logo img,
.site-footer .custom-logo {
	filter: brightness(0) invert(1);
	opacity: 0.92;
}
.site-footer a { color: var(--wp--preset--color--primary-light); text-decoration: none; transition: color var(--marsili-transition); }
.site-footer a:hover { color: var(--wp--preset--color--brass); }
.site-footer__bottom { gap: 1rem; width: 100%; }
.site-footer__cols { width: 100%; }
.site-footer__legal a { margin: 0 0.25rem; }
.site-footer__list { list-style: none; margin: 0; padding: 0; }
.site-footer__list li { margin-bottom: 0.5rem; font-size: var(--wp--preset--font-size--sm); line-height: 1.5; }

/* --- Header navigation submenu polish --- */
.wp-block-navigation .wp-block-navigation-submenu > .wp-block-navigation__submenu-container {
	background: var(--wp--preset--color--base);
	border: 1px solid var(--wp--preset--color--line);
	border-radius: 6px;
	box-shadow: var(--marsili-shadow-medium);
	padding: 0.5rem;
	min-width: 240px;
}
.wp-block-navigation .wp-block-navigation-submenu .wp-block-navigation-item__content {
	padding: 0.4rem 0.75rem;
	border-radius: 4px;
	color: var(--wp--preset--color--ink);
	transition: background var(--marsili-transition), color var(--marsili-transition);
}
.wp-block-navigation .wp-block-navigation-submenu .wp-block-navigation-item__content:hover,
.wp-block-navigation .wp-block-navigation-submenu .wp-block-navigation-item__content:focus {
	background: var(--wp--preset--color--primary-light);
	color: var(--wp--preset--color--primary);
}
.wp-block-navigation .wp-block-navigation-submenu__toggle {
	color: inherit;
}

/* --- Forms (CF7) --- */
.wpcf7 {
	max-width: 720px;
}
.wpcf7 p { margin-bottom: 1rem; }
.wpcf7 label {
	display: block;
	font-size: var(--wp--preset--font-size--sm);
	font-weight: 600;
	margin-bottom: 0.4rem;
	color: var(--wp--preset--color--ink);
}
.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 input[type="url"],
.wpcf7 input[type="number"],
.wpcf7 select,
.wpcf7 textarea {
	width: 100%;
	min-height: 48px;
	padding: 0.65rem 0.9rem;
	font-size: var(--wp--preset--font-size--base);
	font-family: inherit;
	border: 1px solid var(--wp--preset--color--line);
	border-radius: var(--marsili-radius);
	background: var(--wp--preset--color--base);
	color: var(--wp--preset--color--ink);
	transition: border-color var(--marsili-transition), box-shadow var(--marsili-transition);
}
.wpcf7 textarea { min-height: 140px; resize: vertical; }
.wpcf7 input:focus, .wpcf7 select:focus, .wpcf7 textarea:focus {
	outline: none;
	border-color: var(--wp--preset--color--primary);
	box-shadow: 0 0 0 3px rgba(31, 101, 113, 0.12);
}
.wpcf7 input[type="submit"] {
	background: var(--wp--preset--color--brass);
	color: var(--wp--preset--color--ink);
	border: none;
	border-radius: var(--marsili-radius);
	font-weight: 600;
	font-size: var(--wp--preset--font-size--base);
	padding: 0.9rem 1.75rem;
	cursor: pointer;
	transition: background var(--marsili-transition), transform var(--marsili-transition);
}
.wpcf7 input[type="submit"]:hover {
	background: var(--wp--preset--color--brass-dark);
	color: var(--wp--preset--color--base);
	transform: translateY(-1px);
}
.wpcf7 .wpcf7-not-valid-tip { color: var(--wp--preset--color--alert); font-size: var(--wp--preset--font-size--sm); margin-top: 0.25rem; }
.wpcf7 .wpcf7-response-output {
	margin-top: 1.5rem;
	padding: 1rem 1.25rem;
	border-radius: var(--marsili-radius);
	border: 1px solid var(--wp--preset--color--line);
	font-size: var(--wp--preset--font-size--sm);
}
.wpcf7 .wpcf7-acceptance label { font-weight: 400; font-size: var(--wp--preset--font-size--sm); }

/* --- Language switcher --- */
.marsili-langswitch { display: inline-flex; gap: 0.5rem; align-items: center; }
.marsili-langswitch .lang { font-weight: 600; text-decoration: none; color: var(--wp--preset--color--body); padding: 0.25rem 0.5rem; border-radius: 4px; transition: background var(--marsili-transition); }
.marsili-langswitch .lang.is-current { background: var(--wp--preset--color--primary-light); color: var(--wp--preset--color--primary); }
.marsili-langswitch .lang:hover { background: var(--wp--preset--color--bg-subtle); }

/* --- Search block --- */
.wp-block-search .wp-block-search__input {
	border: 1px solid var(--wp--preset--color--line);
	border-radius: var(--marsili-radius);
	padding: 0.65rem 0.9rem;
	min-height: 48px;
}

/* --- Responsive content guards: kill horizontal overflow caused by legacy
   tables / iframes / wide images preserved inside wp:html blocks. --- */
.entry-content img,
.wp-block-html img,
main img { max-width: 100%; height: auto; }

.entry-content iframe,
.wp-block-html iframe,
.marsili-map iframe,
main iframe { max-width: 100%; }

/* Long product tables inside wp:html: allow horizontal scroll on small screens
   without breaking the layout. */
.entry-content table,
.wp-block-html table {
	max-width: 100%;
	border-collapse: collapse;
}
@media (max-width: 900px) {
	.entry-content table,
	.wp-block-html table {
		display: block;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		white-space: normal;
	}
}

/* Mobile tweaks */
@media (max-width: 781px) {
	.site-header__tools { gap: 0.5rem; }
	.site-header__cta { display: none; }     /* CTA already in mobile menu */
	.product-top .wp-block-column { flex-basis: 100% !important; }
	.shop-sidebar { position: static !important; }
	.product-quote { padding: var(--wp--preset--spacing--40) !important; }
	.site-footer .wp-block-columns { flex-wrap: wrap; gap: 2rem !important; }
	.site-footer .wp-block-column { flex-basis: calc(50% - 1rem) !important; min-width: 0; }
	.site-footer__bottom { flex-direction: column; align-items: flex-start; gap: 0.5rem; }
}

@media (max-width: 600px) {
	.site-footer .wp-block-column { flex-basis: 100% !important; }
}

/* ═══════════════════════════════════════════════════════════════
   LAVORI REALIZZATI (CPT "projects")
   - Archivio /lavori/ (page WP + shortcode [marsili_projects])
   - Single lavoro (templates/single-projects.html)
   - Block "Altri lavori realizzati" e CTA contatto
   Token: var(--wp--preset--color--*) e var(--wp--preset--font-size--*).
   ═══════════════════════════════════════════════════════════════ */

/* ─── Archivio (lavori page) ─────────────────────────────── */
.lavori-archive {
	background: var(--wp--preset--color--base);
	padding: clamp(2.5rem, 5vw, 4rem) 0 clamp(3rem, 6vw, 5rem);
}
.lavori-archive__wrap {
	max-width: var(--max, 1280px);
	margin: 0 auto;
	padding-inline: var(--gutter, 1.5rem);
}
.lavori-archive__intro > p:first-child {
	font-size: var(--wp--preset--font-size--lg);
	color: var(--wp--preset--color--muted);
	max-width: 60ch;
	margin: 0 0 clamp(2rem, 4vw, 3rem);
	line-height: 1.55;
}

/* ─── Grid editoriale (archivio + related) ──────────────── */
.lavori-grid {
	display: grid;
	grid-template-columns: repeat(var(--lavori-cols, 2), minmax(0, 1fr));
	gap: clamp(2rem, 4vw, 3.25rem);
	margin: 0;
	padding: 0;
	list-style: none;
}

/* ─── Card "lavoro" ─────────────────────────────────────── */
.lavoro-card {
	position: relative;
	margin: 0;
}
.lavoro-card__link {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
	color: inherit;
	text-decoration: none;
	height: 100%;
}
.lavoro-card__media {
	position: relative;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: var(--wp--preset--color--bg-subtle);
	border-radius: 4px;
	margin: 0;
}
.lavoro-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 600ms cubic-bezier(0.22, 1, 0.36, 1);
}
.lavoro-card__media::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(15, 27, 31, 0) 55%, rgba(15, 27, 31, 0.18) 100%);
	pointer-events: none;
	opacity: 0;
	transition: opacity 280ms ease;
}
.lavoro-card__placeholder {
	display: block;
	width: 100%;
	height: 100%;
	background: linear-gradient(135deg, var(--wp--preset--color--primary-light), var(--wp--preset--color--bg-subtle));
}
.lavoro-card__num {
	position: absolute;
	bottom: 1rem;
	left: 1.1rem;
	font-family: var(--wp--preset--font-family--mono, "IBM Plex Mono", monospace);
	font-size: 0.72rem;
	letter-spacing: 0.16em;
	color: rgba(255, 255, 255, 0.92);
	background: rgba(15, 27, 31, 0.55);
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	padding: 0.35rem 0.6rem;
	border-radius: 2px;
	line-height: 1;
}
.lavoro-card__body {
	display: flex;
	flex-direction: column;
	gap: 0.7rem;
	min-width: 0;
}
.lavoro-card__eyebrow {
	margin: 0;
	font-family: var(--wp--preset--font-family--mono, "IBM Plex Mono", monospace);
	font-size: 0.7rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--wp--preset--color--primary);
	font-weight: 600;
}
.lavoro-card__title {
	margin: 0;
	font-size: clamp(1.4rem, 2.4vw, 1.85rem);
	line-height: 1.18;
	color: var(--wp--preset--color--ink);
	font-weight: 700;
	letter-spacing: -0.01em;
	transition: color 200ms ease;
}
.lavoro-card__deck {
	margin: 0;
	color: var(--wp--preset--color--body);
	font-size: 0.97rem;
	line-height: 1.6;
	max-width: 52ch;
}
.lavoro-card__cta {
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
	margin-top: 0.25rem;
	font-size: 0.88rem;
	font-weight: 600;
	color: var(--wp--preset--color--primary);
	letter-spacing: 0.01em;
	border-bottom: 1px solid currentColor;
	padding-bottom: 0.15rem;
	width: fit-content;
	transition: color 200ms ease, gap 200ms ease;
}
.lavoro-card__cta svg { transition: transform 200ms ease; }

.lavoro-card__link:hover .lavoro-card__media img { transform: scale(1.045); }
.lavoro-card__link:hover .lavoro-card__media::after { opacity: 1; }
.lavoro-card__link:hover .lavoro-card__title { color: var(--wp--preset--color--primary-dark); }
.lavoro-card__link:hover .lavoro-card__cta { gap: 0.85rem; color: var(--wp--preset--color--primary-dark); }
.lavoro-card__link:hover .lavoro-card__cta svg { transform: translateX(3px); }
.lavoro-card__link:focus-visible {
	outline: 2px solid var(--wp--preset--color--primary);
	outline-offset: 6px;
	border-radius: 2px;
}

@media (max-width: 900px) {
	.lavori-grid { grid-template-columns: 1fr; gap: 2.5rem; }
}

/* ─── Single lavoro: body + prose ──────────────────────── */
.single-lavoro {
	background: var(--wp--preset--color--base);
}
.lavoro-single {
	padding: clamp(2.5rem, 5vw, 4.5rem) 0 clamp(3rem, 6vw, 5rem);
}
.lavoro-single__wrap {
	max-width: var(--max, 1280px);
	margin: 0 auto;
	padding-inline: var(--gutter, 1.5rem);
}
.lavoro-single__article {
	max-width: 760px;
	margin: 0 auto;
}
.lavoro-single__prose {
	color: var(--wp--preset--color--body);
	font-size: 1.05rem;
	line-height: 1.72;
}
.lavoro-single__prose > * + * { margin-top: 1.15rem; }
.lavoro-single__prose p { margin: 0; }
.lavoro-single__prose p:first-of-type:not([class]) {
	font-size: 1.18rem;
	line-height: 1.6;
	color: var(--wp--preset--color--ink);
}
.lavoro-single__prose strong {
	color: var(--wp--preset--color--ink);
	font-weight: 600;
}
.lavoro-single__prose em { font-style: italic; color: var(--wp--preset--color--primary-dark); }
.lavoro-single__prose a {
	color: var(--wp--preset--color--primary);
	text-decoration: underline;
	text-underline-offset: 3px;
	text-decoration-thickness: 1px;
}
.lavoro-single__prose a:hover { color: var(--wp--preset--color--primary-dark); }
.lavoro-single__prose h2,
.lavoro-single__prose h3,
.lavoro-single__prose h4 {
	color: var(--wp--preset--color--ink);
	font-weight: 700;
	letter-spacing: -0.01em;
	margin-top: 2.25rem;
}
.lavoro-single__prose h2 { font-size: clamp(1.45rem, 2.4vw, 1.75rem); line-height: 1.25; }
.lavoro-single__prose h3 { font-size: 1.25rem; line-height: 1.3; }
.lavoro-single__prose hr {
	border: 0;
	border-top: 1px solid var(--wp--preset--color--line);
	margin: 2.5rem 0;
}
.lavoro-single__prose ul,
.lavoro-single__prose ol { margin: 0; padding-left: 1.25rem; }
.lavoro-single__prose li + li { margin-top: 0.4rem; }

/* Immagini, gallery, figure dentro il post_content del progetto */
.lavoro-single__prose .wp-block-image,
.lavoro-single__prose figure.wp-block-image {
	margin: 2.25rem 0;
}
.lavoro-single__prose .wp-block-image img,
.lavoro-single__prose figure img {
	width: 100%;
	height: auto;
	border-radius: 4px;
	display: block;
}
.lavoro-single__prose .wp-block-gallery {
	margin: 2.5rem 0;
	gap: clamp(0.5rem, 1.2vw, 0.85rem);
}
.lavoro-single__prose .wp-block-gallery.is-cropped figure img {
	aspect-ratio: 4 / 3;
	object-fit: cover;
}
.lavoro-single__prose figcaption {
	font-family: var(--wp--preset--font-family--mono, "IBM Plex Mono", monospace);
	font-size: 0.75rem;
	letter-spacing: 0.08em;
	color: var(--wp--preset--color--muted);
	text-transform: uppercase;
	margin-top: 0.6rem;
}

/* Allinea il testo libero "justify" del legacy verso un look pulito */
.lavoro-single__prose p[style*="text-align: justify"] { text-align: left; }

/* ─── Related projects ─────────────────────────────────── */
.lavori-related {
	background: var(--wp--preset--color--bg-subtle);
	padding: clamp(3rem, 6vw, 5rem) 0;
	border-top: 1px solid var(--wp--preset--color--line);
}
.lavori-related__wrap {
	max-width: var(--max, 1280px);
	margin: 0 auto;
	padding-inline: var(--gutter, 1.5rem);
}
.lavori-related__head {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	margin-bottom: clamp(2rem, 4vw, 3rem);
	max-width: 60ch;
}
.lavori-related__title {
	margin: 0;
	font-size: clamp(1.8rem, 3.6vw, 2.4rem);
	font-weight: 700;
	letter-spacing: -0.015em;
	color: var(--wp--preset--color--ink);
	line-height: 1.15;
}
.lavori-related .hero__kicker {
	color: var(--wp--preset--color--primary);
	font-family: var(--wp--preset--font-family--mono, "IBM Plex Mono", monospace);
	font-size: 0.72rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	margin: 0;
}

/* ─── CTA contatto ─────────────────────────────────────── */
.lavori-cta {
	background: var(--wp--preset--color--primary-dark);
	color: var(--wp--preset--color--base);
	padding: clamp(3rem, 6vw, 5rem) 0;
}
.lavori-cta__wrap {
	max-width: var(--max, 1280px);
	margin: 0 auto;
	padding-inline: var(--gutter, 1.5rem);
	display: grid;
	grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
	gap: clamp(2rem, 5vw, 4rem);
	align-items: center;
}
.lavori-cta__copy { min-width: 0; }
.lavori-cta .hero__kicker {
	color: var(--wp--preset--color--brass);
	font-family: var(--wp--preset--font-family--mono, "IBM Plex Mono", monospace);
	font-size: 0.72rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	margin: 0 0 1rem;
}
.lavori-cta__title {
	margin: 0 0 1rem;
	font-size: clamp(1.9rem, 4vw, 2.8rem);
	font-weight: 700;
	letter-spacing: -0.02em;
	line-height: 1.1;
	color: var(--wp--preset--color--base);
}
.lavori-cta__lede {
	margin: 0;
	font-size: 1rem;
	line-height: 1.65;
	color: rgba(255, 255, 255, 0.78);
	max-width: 56ch;
}
.lavori-cta__actions {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
	align-items: flex-start;
}
.lavori-cta__actions .btn {
	display: inline-flex;
	align-items: center;
	gap: 0.6rem;
	padding: 0.95rem 1.6rem;
	font-weight: 600;
	font-size: 0.95rem;
	letter-spacing: 0.02em;
	border-radius: 3px;
	text-decoration: none;
	border: 1px solid transparent;
	transition: background 200ms ease, color 200ms ease, transform 200ms ease;
}
.lavori-cta__actions .btn--primary {
	background: var(--wp--preset--color--brass);
	color: var(--wp--preset--color--ink);
}
.lavori-cta__actions .btn--primary:hover {
	background: var(--wp--preset--color--brass-dark);
	transform: translateY(-1px);
}
.lavori-cta__phone {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
}
.lavori-cta__phone-label {
	font-family: var(--wp--preset--font-family--mono, "IBM Plex Mono", monospace);
	font-size: 0.7rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.55);
}
.lavori-cta__phone-num {
	color: var(--wp--preset--color--base);
	text-decoration: none;
	font-size: 1.15rem;
	font-weight: 600;
	letter-spacing: 0.01em;
	border-bottom: 1px solid rgba(255, 255, 255, 0.25);
	padding-bottom: 0.1rem;
	width: fit-content;
	transition: border-color 200ms ease, color 200ms ease;
}
.lavori-cta__phone-num:hover {
	border-bottom-color: var(--wp--preset--color--brass);
	color: var(--wp--preset--color--brass);
}

@media (max-width: 900px) {
	.lavori-cta__wrap { grid-template-columns: 1fr; gap: 2rem; align-items: start; }
	.lavori-cta__actions { align-items: stretch; }
	.lavori-cta__actions .btn { justify-content: space-between; }
}

/* --- Distributors map shortcode --- */
.marsili-distributors__intro { color: var(--wp--preset--color--muted); font-size: var(--wp--preset--font-size--lg); max-width: 70ch; }
.marsili-distributors__controls { display: grid; gap: 1rem; margin: 1.5rem 0 1rem; }
.marsili-distributors__search input {
	width: 100%; min-height: 48px;
	padding: 0.65rem 1rem;
	font: inherit;
	border: 1px solid var(--wp--preset--color--line);
	border-radius: var(--marsili-radius);
	background: var(--wp--preset--color--base);
}
.marsili-distributors__search input:focus {
	outline: none;
	border-color: var(--wp--preset--color--primary);
	box-shadow: 0 0 0 3px rgba(31,101,113,0.12);
}
.marsili-distributors__filter {
	display: flex; flex-wrap: wrap; gap: 0.5rem; align-items: center;
}
.marsili-distributors__filter-label {
	color: var(--wp--preset--color--muted);
	font-size: var(--wp--preset--font-size--sm);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	margin-right: 0.25rem;
}
/* wpautop inietta <br> dentro e tra i chip (button) → riga vuota extra che
   sbilancia il testo. Li nascondiamo: i chip vanno comunque a capo da soli. */
.marsili-distributors__filter br { display: none; }
.marsili-distributors__filter .chip {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--wp--preset--color--bg-subtle);
	border: 1px solid var(--wp--preset--color--line);
	color: var(--wp--preset--color--body);
	padding: 0.45rem 0.9rem;
	border-radius: 999px;
	font-size: var(--wp--preset--font-size--sm);
	cursor: pointer;
	transition: all var(--marsili-transition);
	font-weight: 500;
	line-height: 1;
}
.marsili-distributors__filter .chip:hover { border-color: var(--wp--preset--color--primary); color: var(--wp--preset--color--primary); }
.marsili-distributors__filter .chip.is-active {
	background: var(--wp--preset--color--primary);
	border-color: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--base);
}
.marsili-distributors__map {
	width: 100%; height: 520px;
	border-radius: 8px;
	background: var(--wp--preset--color--primary-light);
	border: 1px solid var(--wp--preset--color--line);
	margin: 1rem 0;
}
.marsili-distributors__meta {
	margin: 1rem 0 2rem;
	color: var(--wp--preset--color--muted);
	font-size: var(--wp--preset--font-size--sm);
}
.marsili-distributors__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 1.25rem;
	margin-top: 1.5rem;
}
.distributor-card {
	background: var(--wp--preset--color--base);
	border: 1px solid var(--wp--preset--color--line);
	border-radius: 8px;
	padding: 1.25rem;
	transition: border-color var(--marsili-transition), box-shadow var(--marsili-transition), transform var(--marsili-transition);
}
.distributor-card:hover {
	border-color: var(--wp--preset--color--primary);
	box-shadow: var(--marsili-shadow-soft);
	transform: translateY(-2px);
}
.distributor-card__title {
	font-size: var(--wp--preset--font-size--lg);
	font-weight: 600;
	color: var(--wp--preset--color--ink);
	margin: 0 0 0.25rem;
}
.distributor-card__sub {
	color: var(--wp--preset--color--muted);
	font-size: var(--wp--preset--font-size--sm);
	margin-bottom: 0.5rem;
}
.distributor-card__row {
	font-size: var(--wp--preset--font-size--sm);
	color: var(--wp--preset--color--body);
	line-height: 1.55;
	margin-top: 0.2rem;
	word-break: break-word;
}
.distributor-card__row a { color: var(--wp--preset--color--primary); text-decoration: none; }
.distributor-card__row a:hover { color: var(--wp--preset--color--primary-dark); text-decoration: underline; }
.marsili-distributors__noresults {
	text-align: center;
	color: var(--wp--preset--color--muted);
	padding: 2rem;
	font-style: italic;
}
.leaflet-popup-content { font-family: var(--wp--preset--font-family--sans); font-size: 0.9rem; line-height: 1.5; min-width: 220px; }
.leaflet-popup-content .ttl { font-weight: 600; color: var(--wp--preset--color--ink); margin-bottom: 0.25rem; }
.leaflet-popup-content .sub { color: var(--wp--preset--color--muted); font-size: 0.85em; margin-bottom: 0.35rem; }
.leaflet-popup-content a { color: var(--wp--preset--color--primary); }
@media (max-width: 600px) { .marsili-distributors__map { height: 380px; } }

/* --- Print --- */
@media print {
	.site-header, .site-footer, .product-cta, .product-quote, .marsili-breadcrumbs { display: none !important; }
	a { color: black !important; text-decoration: underline; }
	body { background: white !important; color: black !important; }
}
