/**
 * Spurghi Piacenza — palette originale collina/salvia (verde bosco + terra)
 * Caricare sempre dopo assets/css/style.css
 */

/* WOW.js disattivato: contenuto sempre visibile, senza animazioni allo scroll */
.wow {
	visibility: visible !important;
	animation: none !important;
	animation-delay: 0s !important;
	opacity: 1 !important;
	transform: none !important;
}

:root,
[data-bs-theme="light"] {
	--bs-primary: #287a5c;
	--bs-primary-rgb: 40, 122, 92;
	--bs-secondary: #3d3329;
	--bs-secondary-rgb: 61, 51, 41;
	--bs-heading-color-style-1: #2e4a3f;
	--bs-heading-color-style-1-rgb: 46, 74, 63;
	--bs-bg-custom-light: #f1f7f4;
	--bs-bg-custom-light-rgb: 241, 247, 244;
	--bs-bg-custom-light-style-2: #e5ece8;
	--bs-bg-custom-light-style-2-rgb: 229, 236, 232;
	--bs-body-color-style-3: #dde8e2;
	--bs-body-color-style-3-rgb: 221, 232, 226;
	--bs-primary-text-emphasis: #1a4536;
	--bs-primary-bg-subtle: #d4e8df;
	--bs-primary-border-subtle: #8fbfaa;
}

[data-bs-theme="light"] {
	--bs-border-color: rgba(40, 122, 92, 0.35);
}

[data-bs-theme="dark"] .btn-primary {
	--bs-btn-hover-color: var(--bs-secondary);
	--bs-btn-active-color: var(--bs-secondary);
}

[data-bs-theme="dark"] .btn-primary:hover .arrow-icon-2 {
	--bs-arrow-icon-2-stroke-color: var(--bs-secondary);
}

body {
	background-color: #dce6e0;
	--bs-body-bg: #dce6e0;
}

.page {
	background-color: #dce6e0;
}

/* ========= Header chiaro tinta salvia (coerente con primario verde) ========= */
.site-header-piacenza.section-header.header-1 {
	--bs-header-bg: #eaf1ed;
	background-color: #eaf1ed !important;
	background-image: linear-gradient(180deg, #f2f8f5 0%, #dce8e1 100%);
	border-bottom: 1px solid rgba(40, 90, 70, 0.12);
	box-shadow: 0 2px 12px rgba(22, 45, 35, 0.08);
}

.site-header-piacenza.section-header.sticky {
	background-color: #e3ebe5 !important;
	background-image: linear-gradient(180deg, #eaf1ed, #d2dfd7);
	box-shadow: 0 3px 16px rgba(22, 45, 35, 0.12);
}

/* Navbar: testo sul verde grafite leggibile */
.site-header-piacenza .logistics-navbar.navbar-light {
	--bs-navbar-color: rgba(46, 74, 63, 0.92);
	--bs-navbar-hover-color: var(--bs-primary);
	--bs-navbar-active-color: var(--bs-primary);
}

/* Logo PNG: scala in altezza alla barra, non tocchiamo struttura/gap del tema */
.site-header-piacenza .navbar-brand .site-logo-img {
	display: block;
	width: auto;
	height: auto;
	max-height: 72px;
}

@media (min-width: 1200px) {
	.site-header-piacenza .navbar-brand .site-logo-img {
		max-height: 88px;
	}
}

@media (min-width: 1400px) {
	.site-header-piacenza .navbar-brand .site-logo-img {
		max-height: 100px;
	}
}

/* Il tema imposta width ~220px sotto i 992px: forziamo proporzioni dall’altezza */
@media (max-width: 991.98px) {
	.site-header-piacenza .navbar-brand .site-logo-img {
		width: auto !important;
		max-height: 68px;
	}
}

@media (max-width: 767.98px) {
	.site-header-piacenza .navbar-brand .site-logo-img {
		max-height: 78px;
	}
}

.site-header-piacenza .navbar-toggler {
	border-color: rgba(40, 122, 92, 0.22);
	box-shadow: none;
}

/* Menu principale: maiuscole tema, spaziatura leggibile (desktop + drawer mobile) */
.site-header-piacenza .nav-piacenza-main .nav-link {
	font-size: 0.875rem;
	letter-spacing: 0.065em;
	line-height: 1.35;
}

@media (min-width: 1200px) {
	.site-header-piacenza .nav-piacenza-main .nav-link {
		font-size: 0.9375rem;
		letter-spacing: 0.075em;
	}

	/*
	 * Il collapse cresce tra logo e bordo: senza justify-end le voci restano
	 * attaccate a sinistra. w-100 sul wrapper interno annullava anche ms-auto.
	 */
	.site-header-piacenza .logistics-navbar.navbar-expand-xl .nav-piacenza-collapse.navbar-collapse {
		justify-content: flex-end;
		flex-wrap: nowrap;
	}

	.site-header-piacenza .nav-piacenza-inner.nav-piacenza-inner {
		width: auto !important;
		max-width: 100%;
		flex: 0 0 auto;
	}
}

/* Drawer mobile/tablet (<xl): colonna a tutta larghezza (no fascia vuota a destra) */
@media (max-width: 1199.98px) {
	.site-header-piacenza .nav-piacenza-collapse.navbar-collapse.show,
	.site-header-piacenza .nav-piacenza-collapse.navbar-collapse.collapsing {
		display: flex !important;
		flex-direction: column;
		align-items: stretch;
		width: 100%;
		flex-basis: 100%;
		padding-top: 0.35rem;
		padding-bottom: 0.85rem;
		margin-top: 0.35rem;
		border-top: 1px solid rgba(40, 90, 70, 0.14);
	}

	.site-header-piacenza .nav-piacenza-collapse .navbar-nav.nav-piacenza-main {
		width: 100% !important;
		max-width: 100%;
		margin-left: 0 !important;
		margin-right: 0 !important;
		margin-bottom: 0 !important;
		row-gap: 0;
	}

	.site-header-piacenza .nav-piacenza-collapse .nav-item {
		width: 100%;
		border-bottom: 1px solid rgba(40, 90, 70, 0.1);
	}

	.site-header-piacenza .nav-piacenza-collapse .nav-item:last-of-type {
		border-bottom: none;
	}

	.site-header-piacenza .nav-piacenza-collapse .nav-link {
		width: 100%;
		text-align: start;
	}

	.site-header-piacenza .nav-piacenza-cta.btn {
		width: 100%;
		margin-left: 0 !important;
		margin-right: 0 !important;
		align-self: stretch;
		padding-top: 0.7rem;
		padding-bottom: 0.7rem;
		font-size: 0.8rem;
		letter-spacing: 0.08em;
	}
}

/* ========= Footer (tipografia e layout) ========= */
.footer-piacenza {
	background: linear-gradient(180deg, #2a3832 0%, #171d1b 100%);
	color: #e2ebe6;
	--bs-link-color: #e8f2ed;
	--bs-link-hover-color: #fff;
	font-size: 1.0625rem;
	line-height: 1.55;
}

.footer-piacenza a {
	color: var(--bs-link-color);
}

.footer-piacenza a:hover {
	color: var(--bs-link-hover-color);
}

.footer-piacenza .footer-piacenza-col-title,
.footer-piacenza h5.footer-piacenza-col-title {
	color: #f4f7f5;
	font-size: 1.2rem;
	font-weight: 700;
	letter-spacing: -0.02em;
	margin-bottom: 1.15rem;
}

.footer-piacenza-brand {
	font-family: Lexend, system-ui, sans-serif;
}

.footer-piacenza-brand-line1 {
	letter-spacing: 0.1em;
	color: #f2f8f5;
	font-size: 1.35rem;
}

.footer-piacenza-brand-line2 {
	letter-spacing: 0.16em;
	font-size: 0.9rem;
	font-weight: 700;
	color: #8fd9b8;
	margin-top: 0.2rem;
}

.footer-piacenza-lead {
	max-width: 22rem;
	font-size: 1.02rem;
	line-height: 1.6;
	color: rgba(226, 235, 230, 0.92);
}

.footer-piacenza-links {
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
}

.footer-piacenza-links a {
	font-size: 1.05rem;
	font-weight: 500;
}

.footer-piacenza-contact-grid {
	display: grid;
	gap: 1.35rem;
	max-width: 22rem;
}

@media (min-width: 768px) and (max-width: 991.98px) {
	.footer-piacenza-contact-grid {
		grid-template-columns: 1fr 1fr;
		max-width: none;
		gap: 1.25rem 2rem;
	}

	.footer-piacenza-contact-cta {
		grid-column: 1 / -1;
	}
}

.footer-piacenza-contact-block {
	display: flex;
	flex-direction: column;
	gap: 0.3rem;
}

.footer-piacenza-label {
	font-size: 0.8125rem;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: rgba(244, 247, 245, 0.78);
}

.footer-piacenza-value {
	font-size: 1.125rem;
	font-weight: 600;
	color: #f4faf7;
}

a.footer-piacenza-phone {
	font-size: 1.375rem;
	font-weight: 700;
	letter-spacing: 0.02em;
}

.footer-piacenza-contact-cta .btn-primary {
	font-size: 0.95rem;
	font-weight: 600;
	padding-top: 0.55rem;
	padding-bottom: 0.55rem;
}

.footer-piacenza .footer-separator {
	border-top: 1px solid rgba(255, 255, 255, 0.2);
	margin-left: auto;
	margin-right: auto;
	opacity: 1;
}

.footer-piacenza-bar,
.footer-piacenza-domain {
	font-size: 0.9375rem;
	color: rgba(200, 214, 206, 0.95);
}

.footer-piacenza-bar a {
	color: rgba(220, 232, 225, 0.98);
}

.footer-piacenza-bar a:hover {
	color: #fff;
}

.footer-piacenza-bar-sep {
	opacity: 0.55;
	padding: 0 0.35rem;
}

.footer-piacenza-domain {
	font-weight: 600;
	letter-spacing: 0.04em;
}

.footer-piacenza-domain:hover {
	color: #fff;
}

.footer-piacenza .mobile-call-fab {
	box-shadow: 0 10px 28px rgba(10, 24, 18, 0.45);
}

@media (max-width: 991.98px) {
	.footer-piacenza .mobile-call-fab {
		display: flex !important;
		position: fixed;
		right: 16px;
		bottom: max(42px, calc(18px + env(safe-area-inset-bottom, 0px)));
		width: 82px;
		height: 82px;
		border-radius: 50%;
		background: var(--bs-primary);
		color: #fff !important;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		gap: 2px;
		z-index: 9999;
		text-decoration: none !important;
		font-size: 10px;
		font-weight: 700;
		letter-spacing: 0.5px;
		text-transform: uppercase;
	}
}

@media (min-width: 992px) {
	.footer-piacenza .mobile-call-fab {
		display: none !important;
	}
}

/*
 * Home: margin-top tema = fascia vuota; l’overlay header copre dall’alto,
 * si compensa solo con il padding dell’hero.
 */
.section-hero.hero-margin-top-style-2 {
	margin-top: 0 !important;
}

@media screen and (min-width: 1400px) and (max-width: 1650px) {
	.section-hero.hero-margin-top-style-2 .hero-components-style-6 {
		--bs-hero-inner-text-padding: 150px 0 130px 0;
	}
}

/* Hero home: foto 1920×910 (allineata al tema), messa a fuoco verso destra + velatura a sinistra per il testo. Foto: Dave Meckler / Unsplash. */
.hero-2 .hero-wrapper.parallax::after {
	background-image: linear-gradient(
			90deg,
			rgba(23, 35, 32, 0.78) 0%,
			rgba(23, 35, 32, 0.28) 42%,
			transparent 68%
		),
		var(--bg-parallax-image);
	background-size: cover;
	background-position: center, 82% center;
	background-repeat: no-repeat;
}

/* Tablet: resta enfasi a destra (testo allineato a sinistra da md). */
@media (max-width: 991.98px) and (min-width: 768px) {
	.hero-2 .hero-wrapper.parallax::after {
		background-position: center, 70% center;
		background-image: linear-gradient(
				180deg,
				rgba(23, 35, 32, 0.82) 0%,
				rgba(23, 35, 32, 0.35) 38%,
				transparent 70%
			),
			var(--bg-parallax-image);
		background-size: cover;
		background-repeat: no-repeat;
	}
}

/* Hero home — smartphone: sfondo inquadratura/velatura; testo come il tema + solo più aria sopra al titolo */
@media (max-width: 767.98px) {
	.hero-2 .hero-wrapper.parallax::after {
		background-image: linear-gradient(
				180deg,
				rgba(23, 35, 32, 0.85) 0%,
				rgba(23, 35, 32, 0.42) 42%,
				transparent 72%
			),
			var(--bg-parallax-image);
		background-size: cover;
		background-repeat: no-repeat;
		background-position: center, 64% 36%;
	}

	.section-hero.hero-margin-top-style-2 .hero-components-style-6 .hero-inner {
		padding-top: max(9rem, calc(6.25rem + env(safe-area-inset-top, 0px)));
	}
}

/* ========= Home — “Le nostre soluzioni”: look editoriale / lista tecnica ========= */
/*
 * La section ha padding-bottom (pb-60…) fuori da .service-wrapper: senza sfondo qui
 * si vede il body (#dce6e0) e resta la “fascia” verde chiaro tra soluzioni e servizi.
 */
.section-service.service-1 {
	background-color: #f3f8f6;
	background-image: repeating-linear-gradient(
		90deg,
		transparent,
		transparent 7px,
		rgba(40, 122, 92, 0.04) 7px,
		rgba(40, 122, 92, 0.04) 8px
	);
}

.section-service.service-1 .service-wrapper.bg-custom-light {
	background-color: #f3f8f6;
	background-image: repeating-linear-gradient(
		90deg,
		transparent,
		transparent 7px,
		rgba(40, 122, 92, 0.04) 7px,
		rgba(40, 122, 92, 0.04) 8px
	);
}

.section-service.service-1 .col-lg-5 .subtitle {
	display: inline-flex;
	align-items: center;
	gap: 0.65rem;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	margin-bottom: 0.75rem !important;
	color: var(--bs-primary);
}

.section-service.service-1 .col-lg-5 .subtitle::before {
	content: "";
	width: 4px;
	align-self: stretch;
	min-height: 1rem;
	background: var(--bs-primary);
	border-radius: 1px;
	flex-shrink: 0;
}

.section-service.service-1 .col-lg-5 .subtitle::after {
	display: none;
}

.section-service.service-1 .col-lg-5 .title {
	font-weight: 700;
	letter-spacing: -0.03em;
	line-height: 1.18;
	color: var(--bs-secondary);
}

.section-service.service-1 .col-lg-5 .descriptions-width {
	line-height: 1.7;
	color: rgba(61, 51, 41, 0.78);
	font-size: 0.98rem;
}

.section-service.service-1 .card-custom-lists {
	counter-reset: sp-soluzioni;
	gap: 0 !important;
}

.section-service.service-1 .card-custom-lists li {
	border-bottom: none;
	padding-bottom: 0;
	margin-bottom: 0;
}

.section-service.service-1 .card-custom-lists li + li {
	margin-top: 1.05rem;
	padding-top: 1.15rem;
	border-top: 1px dashed rgba(40, 122, 92, 0.22);
}

@media (max-width: 991.98px) {
	.section-service.service-1 .card-custom-lists li {
		margin-bottom: 0;
	}
}

.section-service.service-1 .card-style-2 {
	counter-increment: sp-soluzioni;
	--bs-card-bg: transparent;
	position: relative;
	border: none;
	border-left: 4px solid var(--bs-primary);
	border-radius: 0;
	box-shadow: none;
	overflow: visible;
	padding: 0.85rem 0.5rem 0.85rem 1rem;
	background: rgba(255, 255, 255, 0.55);
	transition: background 0.2s ease;
}

.section-service.service-1 .card-style-2::before {
	content: counter(sp-soluzioni, decimal-leading-zero);
	position: absolute;
	right: 0.35rem;
	top: 0.5rem;
	font-size: clamp(2.5rem, 6vw, 3.25rem);
	font-weight: 800;
	line-height: 1;
	color: rgba(40, 122, 92, 0.07);
	pointer-events: none;
	user-select: none;
	letter-spacing: -0.04em;
}

.section-service.service-1 .card-style-2:hover {
	background: rgba(255, 255, 255, 0.98);
	transform: none;
}

.section-service.service-1 .card-style-2 .card-image-wrapper {
	border-radius: 3px !important;
	box-shadow: none;
	border: 1px solid rgba(40, 122, 92, 0.12);
}

.section-service.service-1 .card-style-2 .card-body {
	padding-top: 0.35rem;
	padding-bottom: 0.35rem;
}

@media (min-width: 992px) {
	.section-service.service-1 .card-style-2 .card-body {
		padding-right: 0.25rem;
	}
}

.section-service.service-1 .card-style-2 .arrow-icon-3.arrow-style-1 {
	--bs-arrow-style-1-size: 42px;
	--bs-arrow-style-1-bg: transparent;
	--bs-arrow-icon-3-stroke-color: var(--bs-primary);
	border: 2px solid rgba(40, 122, 92, 0.4);
	box-shadow: none;
}

.section-service.service-1 .card-style-2:hover .arrow-icon-3.arrow-style-1 {
	--bs-arrow-style-1-bg: var(--bs-primary);
	--bs-arrow-icon-3-stroke-color: #fff;
	border-color: var(--bs-primary);
}

.section-service.service-1 .card-style-2 .card-title a {
	color: var(--bs-secondary);
	font-weight: 700;
	transition: color 0.2s ease;
}

.section-service.service-1 .card-style-2:hover .card-title a {
	color: var(--bs-primary);
}

.section-service.service-1 .card-style-2 .card-text {
	color: rgba(61, 51, 41, 0.72);
}

/* ========= Home — “Servizi offerti”: fascia intro scura + schede foto (stile diverso) ========= */
/* Stesso fondo della sezione soluzioni: evita fascia “vuota” verde chiaro (.body-bg) tra le due blocchi */
.section-portfolio.portfolio-1 {
	background-color: #f3f8f6;
	background-image: repeating-linear-gradient(
		90deg,
		transparent,
		transparent 7px,
		rgba(40, 122, 92, 0.04) 7px,
		rgba(40, 122, 92, 0.04) 8px
	);
	overflow-x: clip;
	padding-top: 0;
}

.section-portfolio.portfolio-1 .contents-width {
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	margin-bottom: 2.75rem !important;
	padding: 2.6rem clamp(1.15rem, 4vw, 2.5rem) 2.85rem;
	text-align: center;
	background: linear-gradient(145deg, #14221c 0%, #1e352b 42%, #163028 100%);
	border-bottom: 3px solid var(--bs-primary);
	box-shadow: 0 18px 40px rgba(10, 24, 18, 0.28);
}

.section-portfolio.portfolio-1 .contents-width h6 {
	color: rgba(186, 230, 206, 0.95) !important;
	font-size: 0.74rem !important;
	font-weight: 600 !important;
	letter-spacing: 0.2em !important;
	text-transform: uppercase;
	margin-bottom: 0.7rem !important;
}

.section-portfolio.portfolio-1 .contents-width h6::after {
	content: "";
	display: block;
	width: 3rem;
	height: 2px;
	margin: 0.75rem auto 0;
	background: var(--bs-primary);
	border-radius: 1px;
	opacity: 0.95;
}

.section-portfolio.portfolio-1 .contents-width h2,
.section-portfolio.portfolio-1 .contents-width .portfolio-section-intro {
	font-weight: 700;
	font-size: clamp(1.35rem, 2.8vw, 2rem);
	letter-spacing: -0.02em;
	line-height: 1.25;
	color: #f3faf7 !important;
}

.section-portfolio.portfolio-1 .contents-width .portfolio-intro-line {
	color: rgba(231, 244, 237, 0.88);
	font-size: clamp(0.95rem, 2vw, 1.06rem);
	letter-spacing: 0.01em;
}

.section-portfolio.portfolio-1 .portfolio-image.border-10,
.section-portfolio.portfolio-1 .portfolio-image.border-10 img {
	border-radius: 6px;
}

.section-portfolio.portfolio-1 .portfolio-image {
	transition: box-shadow 0.35s ease, filter 0.35s ease;
	box-shadow: 0 20px 40px rgba(10, 24, 18, 0.18);
	border: none;
	outline: 1px solid rgba(255, 255, 255, 0.12);
	outline-offset: -1px;
}

.section-portfolio.portfolio-1 .portfolio-image:hover,
.section-portfolio.portfolio-1 .portfolio-image.active {
	box-shadow: 0 24px 52px rgba(10, 24, 18, 0.28), 0 0 0 2px rgba(125, 217, 168, 0.35);
	filter: saturate(1.08) contrast(1.02);
	transform: none;
	outline-color: rgba(125, 217, 168, 0.45);
}

.section-portfolio.portfolio-1 .portfolio-image:hover img,
.section-portfolio.portfolio-1 .portfolio-image.active img {
	transform: scale(1.06);
}

.section-portfolio.portfolio-1 .portfolio-image-hover {
	--bs-portfolio-image-hover-width: 100%;
	--bs-portfolio-image-hover-bg: transparent;
	--bs-portfolio-hover-heading-color: #f8fffb;
	left: 0 !important;
	width: 100% !important;
	bottom: -100px;
	padding: 1.1rem 1.15rem 1.15rem;
	border-radius: 0 0 6px 6px;
	border: none;
	border-top: 1px solid rgba(255, 255, 255, 0.1);
	backdrop-filter: none;
	-webkit-backdrop-filter: none;
	box-shadow: none;
	background-color: transparent !important;
	background-image: linear-gradient(
		180deg,
		rgba(20, 34, 28, 0.15) 0%,
		rgba(14, 28, 22, 0.96) 55%,
		rgba(10, 22, 18, 0.99) 100%
	);
}

.section-portfolio.portfolio-1 .portfolio-image:hover .portfolio-image-hover,
.section-portfolio.portfolio-1 .portfolio-image.active .portfolio-image-hover {
	bottom: 0;
}

.section-portfolio.portfolio-1 .portfolio-image-hover .arrow-icon-3.arrow-style-1 {
	--bs-arrow-style-1-size: 42px;
	--bs-arrow-style-1-bg: var(--bs-primary);
	--bs-arrow-icon-3-stroke-color: #0e1c17;
	flex-shrink: 0;
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.35);
}

.section-portfolio.portfolio-1 .portfolio-image-hover:hover .arrow-icon-3 {
	--bs-arrow-style-1-bg: #f3faf7;
}

.section-portfolio.portfolio-1 .portfolio-subtitle-style-2:empty {
	display: none !important;
}

.section-portfolio.portfolio-1 .portfolio-subtitle-style-2:not(:empty) {
	display: inline-block;
	font-size: 0.62rem;
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: #b8efd1 !important;
	background: rgba(255, 255, 255, 0.12);
	border: 1px solid rgba(255, 255, 255, 0.35) !important;
	border-radius: 2px;
	padding: 0.2rem 0.55rem !important;
	margin-bottom: 0.35rem !important;
}

.section-portfolio.portfolio-1 .portfolio-hover-heading {
	font-weight: 700;
	letter-spacing: -0.02em;
	text-shadow: 0 1px 12px rgba(0, 0, 0, 0.45);
}

.section-portfolio.portfolio-1 > .container > .text-lg-center .btn.btn-primary {
	padding-left: 2rem;
	padding-right: 2rem;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	font-size: 0.82rem;
	border-radius: 2px;
	box-shadow: 0 8px 28px rgba(40, 122, 92, 0.35);
	transition: box-shadow 0.25s ease, transform 0.25s ease;
}

.section-portfolio.portfolio-1 > .container > .text-lg-center .btn.btn-primary:hover {
	box-shadow: 0 12px 36px rgba(40, 122, 92, 0.45);
	transform: translateY(-2px);
}

@media (prefers-reduced-motion: reduce) {
	.section-service.service-1 .card-style-2 {
		transition: border-color 0.2s ease, box-shadow 0.2s ease;
	}

	.section-service.service-1 .card-style-2:hover {
		transform: none;
	}

	.section-service.service-1 .card-style-2 .arrow-icon-3.arrow-style-1 {
		transition: box-shadow 0.2s ease;
	}

	.section-portfolio.portfolio-1 .portfolio-image {
		transition: box-shadow 0.2s ease, border-color 0.2s ease;
	}

	.section-portfolio.portfolio-1 .portfolio-image:hover,
	.section-portfolio.portfolio-1 .portfolio-image.active {
		filter: none !important;
	}

	.section-portfolio.portfolio-1 .portfolio-image:hover img,
	.section-portfolio.portfolio-1 .portfolio-image.active img {
		transform: none !important;
	}

	.section-portfolio.portfolio-1 > .container > .text-lg-center .btn.btn-primary,
	.section-portfolio.portfolio-1 > .container > .text-lg-center .btn.btn-primary:hover {
		transform: none;
	}
}

/* ========= Home — modulo richiesta (no foto, fascia + griglia leggibile) ========= */
.call-request-piacenza-shell {
	border-radius: 14px;
	overflow: hidden;
	border: 1px solid rgba(40, 122, 92, 0.18);
	box-shadow:
		0 6px 34px rgba(14, 28, 22, 0.08),
		0 1px 0 rgba(255, 255, 255, 0.75) inset;
	background: #fff;
}

@media (max-width: 991.98px) {
	.call-request-piacenza-shell {
		border-radius: 12px;
	}
}

.call-request-piacenza-aside {
	background: linear-gradient(155deg, #121c18 0%, #1a3028 46%, #15261f 100%);
	border-bottom: 1px solid rgba(255, 255, 255, 0.09);
}

@media (min-width: 992px) {
	.call-request-piacenza-aside {
		border-bottom: none;
		border-right: 1px solid rgba(255, 255, 255, 0.1);
	}
}

.call-request-piacenza-aside-inner {
	padding: clamp(1.85rem, 4.5vw, 2.9rem);
	padding-bottom: clamp(2rem, 4.5vw, 3rem);
	color: rgba(247, 252, 249, 0.96);
}

.call-request-piacenza-eyebrow {
	font-size: 0.68rem;
	font-weight: 700;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: rgba(176, 230, 204, 0.95);
}

.call-request-piacenza-title {
	font-weight: 700;
	letter-spacing: -0.028em;
	line-height: 1.17;
	color: #f6fbf8;
	font-size: clamp(1.32rem, 2.9vw, 1.92rem);
	margin-bottom: 0.85rem;
}

.call-request-piacenza-lead {
	font-size: 0.96rem;
	line-height: 1.62;
	color: rgba(225, 240, 233, 0.86);
	max-width: 22rem;
}

.call-request-piacenza-points {
	margin-top: 0.75rem;
}

.call-request-piacenza-points li {
	position: relative;
	padding-left: 1.42rem;
	margin-bottom: 0.62rem;
	font-size: 0.93rem;
	color: rgba(235, 245, 239, 0.92);
	line-height: 1.45;
}

.call-request-piacenza-points li:last-child {
	margin-bottom: 0;
}

.call-request-piacenza-points li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.44rem;
	width: 8px;
	height: 8px;
	border-radius: 2px;
	background: var(--bs-primary);
	box-shadow: 0 0 0 3px rgba(40, 122, 92, 0.32);
}

.call-request-piacenza-phone {
	padding: 0.75rem 0;
	border-top: 1px solid rgba(255, 255, 255, 0.14);
	border-bottom: 1px solid rgba(255, 255, 255, 0.14);
}

.call-request-piacenza-phone:hover .fw-semibold {
	color: #bfe9d5 !important;
}

.call-request-piacenza-phone:hover {
	opacity: 0.94;
}

.call-request-phone-label {
	letter-spacing: 0.12em;
}

.call-request-piacenza-main {
	background: linear-gradient(180deg, #fcfdfc 0%, #f5faf7 52%, #f0f4f2 100%);
}

.call-request-piacenza-form-inner {
	padding: clamp(1.5rem, 4vw, 2.75rem);
}

.call-request-piacenza-form-hint {
	max-width: 38rem;
	line-height: 1.52;
	margin-bottom: 0;
}

.call-request-piacenza-form .form-label {
	font-size: 0.71rem;
	font-weight: 600;
	letter-spacing: 0.09em;
	text-transform: uppercase;
	color: var(--bs-secondary);
	margin-bottom: 0.38rem;
}

.call-request-piacenza-form .form-control,
.call-request-piacenza-form .form-select {
	border-color: rgba(40, 122, 92, 0.24);
	border-radius: 6px;
	background-color: #fff;
}

.call-request-piacenza-form .form-control:focus,
.call-request-piacenza-form .form-select:focus {
	border-color: rgba(40, 122, 92, 0.55);
	box-shadow: 0 0 0 0.2rem rgba(40, 122, 92, 0.11);
}

.call-request-piacenza-form textarea.form-control {
	min-height: 7rem;
	resize: vertical;
}

.call-request-piacenza-form .btn-lg {
	padding-top: 0.88rem;
	padding-bottom: 0.88rem;
	border-radius: 6px;
	letter-spacing: 0.05em;
}

.call-request-piacenza-form .response .alert-success,
.call-request-piacenza-form .response .alert-error {
	width: 100%;
	margin-bottom: 0;
}

/* ========= Home — recensioni (griglia nel container: niente caroselli tagliati) ========= */
.section-testimonial.testimonial-piacenza {
	position: relative;
	padding-top: clamp(2rem, 4.5vw, 3rem);
	background: linear-gradient(180deg, #f7faf8 0%, #eaf1ee 52%, var(--bs-body-bg) 100%);
}

.section-testimonial.testimonial-piacenza .testimonial-piacenza-header {
	position: relative;
	z-index: 1;
	max-width: 44rem;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: clamp(3rem, 7vw, 4.5rem);
	padding-bottom: 0.5rem;
}

.section-testimonial.testimonial-piacenza .testimonial-piacenza-eyebrow {
	letter-spacing: 0.2em;
	font-size: 0.71rem !important;
}

.section-testimonial.testimonial-piacenza .testimonial-piacenza-heading {
	font-weight: 700;
	letter-spacing: -0.02em;
	color: var(--bs-secondary);
	line-height: 1.28;
	font-size: clamp(1.4rem, 3vw, 2rem);
}

.section-testimonial.testimonial-piacenza .testimonial-header-sub {
	max-width: 28rem;
	font-size: 0.95rem;
	line-height: 1.55;
	color: rgba(61, 51, 41, 0.72);
}

.section-testimonial.testimonial-piacenza .testimonial-piacenza-grid-wrap {
	width: 100%;
	max-width: 100%;
}

.section-testimonial.testimonial-piacenza .testimonial-piacenza-grid {
	display: grid;
	gap: clamp(1.35rem, 3.2vw, 2rem);
	grid-template-columns: minmax(0, 1fr);
	width: 100%;
}

@media (min-width: 576px) {
	.section-testimonial.testimonial-piacenza .testimonial-piacenza-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (min-width: 992px) {
	.section-testimonial.testimonial-piacenza .testimonial-piacenza-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (min-width: 1400px) {
	.section-testimonial.testimonial-piacenza .testimonial-piacenza-grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
		gap: clamp(1.35rem, 2.2vw, 1.95rem);
	}
}

.section-testimonial.testimonial-piacenza .testimonial-piacenza-grid-cell {
	min-width: 0;
}

.section-testimonial.testimonial-piacenza .testimonial-piacenza-card {
	--bs-testimonial-author-name-color: var(--bs-secondary);
	--bs-testimonial-3-wrapper-bg: #fafdfc;

	display: flex;
	flex-direction: column;
	gap: 1rem;
	min-height: 100%;
	height: auto;
	max-width: 100%;
	padding: clamp(1.15rem, 3vw, 1.65rem);
	border-radius: 12px;
	border: 1px solid rgba(40, 122, 92, 0.13);
	box-shadow:
		0 4px 22px rgba(22, 45, 35, 0.05),
		0 1px 0 rgba(255, 255, 255, 0.9) inset;
	transition: box-shadow 0.25s ease, border-color 0.25s ease;
}

.section-testimonial.testimonial-piacenza .testimonial-piacenza-card:hover {
	border-color: rgba(40, 122, 92, 0.28);
	box-shadow:
		0 10px 32px rgba(22, 45, 35, 0.1),
		0 0 0 1px rgba(40, 122, 92, 0.08),
		0 1px 0 rgba(255, 255, 255, 0.92) inset;
}

.section-testimonial.testimonial-piacenza .testimonial-piacenza-google-logo {
	width: 46px;
	height: 46px;
	object-fit: contain;
	border-radius: 10px;
	background: #fff;
	border: 1px solid rgba(0, 0, 0, 0.06);
	padding: 3px;
}

.section-testimonial.testimonial-piacenza .testimonial-piacenza-source {
	color: rgba(61, 51, 41, 0.55);
	letter-spacing: 0.04em;
}

.section-testimonial.testimonial-piacenza .testimonial-piacenza-quote {
	font-family: Georgia, ui-serif, serif;
	font-size: 2.15rem;
	line-height: 1;
	font-weight: 700;
	color: rgba(40, 122, 92, 0.16);
	transform: translateY(-2px);
}

.section-testimonial.testimonial-piacenza .testimonial-piacenza-card .testimonial-details {
	font-size: 0.955rem;
	line-height: 1.58;
	color: rgba(61, 51, 41, 0.82);
}

.section-testimonial.testimonial-piacenza .testimonial-piacenza-card-foot {
	border-top-color: rgba(40, 122, 92, 0.12) !important;
	padding-top: 0.95rem !important;
}

.section-testimonial.testimonial-piacenza .testimonial-piacenza-score {
	color: rgba(61, 51, 41, 0.55);
	letter-spacing: 0.02em;
	font-size: 0.73rem !important;
}

.section-testimonial.testimonial-piacenza .testimonial-piacenza-stars .star-rating-icon {
	--bs-star-rating-icon-color: #e2b728;
}

@media (prefers-reduced-motion: reduce) {
	.section-testimonial.testimonial-piacenza .testimonial-piacenza-card {
		transition: none;
	}

	.section-testimonial.testimonial-piacenza .testimonial-piacenza-card:hover {
		box-shadow:
			0 4px 22px rgba(22, 45, 35, 0.05),
			0 1px 0 rgba(255, 255, 255, 0.9) inset;
	}
}

/* ========= Pagina Cosa facciamo (servizi) ========= */
.page-servizi-piacenza .servizi-macrocategoria {
	letter-spacing: 0.07em;
}

.page-servizi-piacenza .servizi-scheda-card {
	transition: box-shadow 0.28s ease, transform 0.28s ease;
	border: 1px solid rgba(var(--bs-primary-rgb), 0.08);
}

.page-servizi-piacenza .servizi-scheda-card-link:focus-visible {
	outline: 2px solid rgba(var(--bs-primary-rgb), 0.45);
	outline-offset: 3px;
}

.page-servizi-piacenza .servizi-scheda-card:hover {
	box-shadow:
		0 16px 48px rgba(22, 45, 35, 0.09),
		0 1px 0 rgba(255, 255, 255, 0.65) inset;
	transform: translateY(-4px);
}

.page-servizi-piacenza .servizi-foot-cta-panel {
	border: 1px solid rgba(var(--bs-primary-rgb), 0.09);
}

@media (prefers-reduced-motion: reduce) {
	.page-servizi-piacenza .servizi-scheda-card {
		transition: none;
	}

	.page-servizi-piacenza .servizi-scheda-card:hover {
		transform: none;
	}
}

/* ========= Banner con foto operativo (Area servita, Conoscici, Cosa facciamo) ========= */
.section-banner.banner-page-area-servita.parallax,
.section-banner.banner-page-conoscici.parallax,
.section-banner.banner-page-servizi.parallax {
	--bg-parallax-image: url(/upload/foto/spurghi-piacenza-soluzioni-complete.jpg);
}

.section-banner.banner-page-area-servita.parallax::after,
.section-banner.banner-page-conoscici.parallax::after,
.section-banner.banner-page-servizi.parallax::after {
	background-position: center 40%;
}

/* ========= Banner consenso cookie (footer include) ========= */
.cookie-banner-piacenza {
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 10050;
	background: linear-gradient(180deg, rgba(30, 48, 38, 0.97) 0%, #1a2e24 100%);
	color: #e4ede8;
	border-top: 1px solid rgba(255, 255, 255, 0.12);
	box-shadow: 0 -12px 40px rgba(10, 22, 16, 0.35);
	padding: 1rem 0 max(1rem, env(safe-area-inset-bottom, 0px));
}

.cookie-banner-piacenza[hidden] {
	display: none !important;
}

.cookie-banner-piacenza.is-visible {
	display: block;
}

.cookie-banner-piacenza-inner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 1rem 1.5rem;
}

.cookie-banner-piacenza-copy {
	flex: 1 1 220px;
	min-width: min(100%, 280px);
	max-width: 52rem;
}

.cookie-banner-piacenza-heading {
	font-weight: 700;
	font-size: 1rem;
	letter-spacing: 0.02em;
	color: #fff;
}

.cookie-banner-piacenza-msg {
	font-size: 0.875rem;
	line-height: 1.5;
	color: rgba(228, 237, 232, 0.92);
}

.cookie-banner-piacenza-actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.75rem 1rem;
	flex-shrink: 0;
}

.cookie-banner-piacenza-link {
	font-size: 0.875rem;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.88);
	text-decoration: underline;
	text-underline-offset: 3px;
}

.cookie-banner-piacenza-link:hover {
	color: #fff;
}

.cookie-banner-piacenza-btn {
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	padding-inline: 1.5rem;
	min-width: 8rem;
}

@media (max-width: 991.98px) {
	body.cookie-banner-visible .footer-piacenza .mobile-call-fab {
		bottom: max(42px, calc(18px + env(safe-area-inset-bottom, 0px) + 7.5rem));
	}

	/* Pulsante “torna su” con freccia — nascosto su tablet/smartphone */
	.progressCounter.progressScroll {
		display: none !important;
	}
}
