﻿:root {
    scroll-behavior: auto;
    --font-global: Prata, HK_Grotesk, arial, sans-serif;
    --font-global-alt: Prata, HK_Grotesk_alt, arial, sans-serif;
}

a {
	text-decoration:none !important;
}

.main-nav {
    width: 100%;
    height: 130px !important;
}
.nav-logo-wrap .logo{
    display: flex;
    align-items: center;
    max-width: 290px;
    height: 130px;
    -webkit-transition: all 0.2s cubic-bezier(0.000, 0.000, 0.580, 1.000);
    transition: all 0.2s cubic-bezier(0.000, 0.000, 0.580, 1.000);
}

.small-height {
    height: 90px !important;
}
.small-height .inner-nav ul li a, .mobile-cart.small-height {
    height: 90px !important;
    line-height: 87px !important;
}
.hs-line-1, .hs-line-2, .hs-line-3, .section-title, .lead-alt {
    font-weight: 400;
	text-transform:initial;
}
.hs-line-3 {
	font-size:2em;
}

.main-nav.dark {
    background-color: rgb(63 29 14);
}

.inner-nav ul {
    font-size: 24px;
}

.sfumabg {
	background: #000000;
	background: linear-gradient(180deg, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 0.5) 0%, rgba(0, 0, 0, 0) 25%);
	width:100%;
	height:100%;
	position:absolute;
	z-index:0;
}

.sfumabgheader {
	background: #000000;
	background: linear-gradient(180deg, rgba(0, 0, 0, .7) 0%, rgba(0, 0, 0, 0) 100%);
	width:100%;
	height:100%;
	position:absolute;
	z-index:0;
}

.sfumafooter {
	background: rgb(63 29 14);
	background: linear-gradient(0deg, rgba(63, 29, 14, 1) 0%, rgba(63, 29, 14, .95) 43%, rgba(63, 29, 14, 0.9) 100%);
	width:100%;
	height:100%;
	position:absolute;
	z-index:-1;
}

.sfumafooter5 {
	background: #1d3f2b;
	background: linear-gradient(0deg, rgba(29, 63, 43, 1) 0%, rgba(29, 63, 43, .95) 43%, rgba(29, 63, 43, 0.9) 100%);
	width:100%;
	height:100%;
	position:absolute;
	z-index:-1;
}

.mt-25vh {
	margin-top: -25vh;
}

.edge-bottom-figure {
	bottom:-1px;
}

.width90 {
    width: 90% !important;
    max-width: 90% !important;
    padding: 0 0 !important;
	margin:  0 auto;
}

.width80 {
    width: 80% !important;
    max-width: 80% !important;
    padding: 0 0 !important;
}

.bloccodistanziato20 {
	padding:5%;
}

.fondochiaro {
	background-color:#fffbee;
/*
	background-color:rgb(253,243,234);
*/
}

.section-text, .section-text .row {
	font-size:22px;
	font-weight:400;
	color:rgba(87, 52, 37, .95);
}

.local-scroll.scroll-down-wrap {
    visibility: visible;
    animation-name: fadeInUpShort;
    transform: scale(3) !important;
    opacity: 1 !important;
}

.lento {
    animation: scroll-down-anim 2.5s infinite;
}

.scroll-down:before, .scroll-down:hover {
    background: none;
    box-shadow: none;
    z-index: 1;
	color:initial;
    border-radius: 50%;
}

.firstcolor, .work-item a {
	color:#844f39;
}
.secondcolor {
	color:#748b4a !important;
}

.stile3 .firstcolor, .stile3 .work-item a, .stile3 .section-text {
/*
	color:#748b4a !important;
*/
	color:#3f1d0e !important;
}
.stile3 .secondcolor {
	color:#844f39 !important;
}


.secondcolorlight {
	color:#8fb153;
}
.thirdcolor {
	color:#f7dc82;
}
.banner-image-1, .banner-image-2 {
	width:50%;
}
.weightlight {
	font-weight:400;
}
.banner-image-1 {
    margin: 30px 0 0 0;
}

.ombratochiaro {
	-webkit-box-shadow: 0px 0px 18px 0px #000000; 
	box-shadow: 0px 0px 18px 0px #000000;
}

.ombrato {
	-webkit-box-shadow: 0px 0px 5px 0px #000000; 
	box-shadow: 0px 0px 5px 0px #000000;
}

.testoombrato {
	text-shadow: 0px 0px 5px #000000; 
}

.arrotondato {
	border-radius:100px;
}

.arrotondato2 {
	border-radius:50px;
}

.arrotondato3 {
	border-radius:25px;
}

.semiarrotondato {
	border-radius:100px 0 100px 0;
}

.main-nav.dark .inner-nav ul > li > a {
	opacity:1;
}
.main-nav.stile3, .main-nav.stile4, .main-nav.stile3, .main-nav.stile5 {
	background-color:#f5f0e2;
}
.main-nav.light.stile3 .inner-nav ul > li > a {
    font-family: "Google Sans", sans-serif;
}
.footer.stile3 {
    font-family: "Google Sans", sans-serif;
}
.main-nav.light.stile4 .inner-nav ul > li > a {
    font-family: "Ubuntu", sans-serif;
}
.footer.stile4 {
    font-family: "Ubuntu", sans-serif;
}
.main-nav.light.stile5 .inner-nav ul > li > a {
    font-family: "Roboto Slab", sans-serif;
	letter-spacing:0px;
}
.footer.stile5 {
    font-family: "Roboto Slab", sans-serif;
}




.main-nav.stile3 .nav-logo-wrap.local-scroll.scuro, .main-nav.stile4 .nav-logo-wrap.local-scroll.scuro, .main-nav.stile5 .nav-logo-wrap.local-scroll.scuro {
	display:none;
}
.main-nav.stile3 .nav-logo-wrap.local-scroll.chiaro, .main-nav.stile4 .nav-logo-wrap.local-scroll.chiaro, .main-nav.stile5 .nav-logo-wrap.local-scroll.chiaro {
	display:block;
}

.main-nav.body-scrolled.stile3 .nav-logo-wrap.local-scroll.chiaro, .main-nav.body-scrolled.stile4 .nav-logo-wrap.local-scroll.chiaro, .main-nav.body-scrolled.stile5 .nav-logo-wrap.local-scroll.chiaro {
	display: none;
}
.main-nav.body-scrolled.stile3 .nav-logo-wrap.local-scroll.scuro, .main-nav.body-scrolled.stile4 .nav-logo-wrap.local-scroll.scuro, .main-nav.body-scrolled.stile5 .nav-logo-wrap.local-scroll.scuro {
	display: block;
}



.main-nav.stile3 .inner-nav ul li a, .main-nav.stile4 .inner-nav ul li a, .main-nav.stile5 .inner-nav ul li a, .main-nav.stile3 .inner-nav ul li .mn-has-sub-icon, .main-nav.stile4 .inner-nav ul li .mn-has-sub-icon, .main-nav.stile5 .inner-nav ul li .mn-has-sub-icon {
	color:#fff;
}

.main-nav.body-scrolled.stile3 .inner-nav ul li a, .main-nav.body-scrolled.stile4 .inner-nav ul li a {
	color:#824e3a;
}

.main-nav.body-scrolled.stile5 .inner-nav ul li a {
	color:#35582a;
}




.main-nav.dark .inner-nav ul > li > a:hover {
	color:#f7dc82;
}

.main-nav.dark .inner-nav ul > li > a.giallo {
	color:#f7dc82;
}

.main-nav.dark .inner-nav ul > li > a.giallo:hover {
	color:#fff;
}

.sfumatostorto {
	background: #FFFBEE;
	background: linear-gradient(226deg, rgba(255, 251, 238, 1) 33%, rgba(255, 251, 238, 0) 100%);
}

.foto-clip {
  clip-path: polygon(
    20% 0%, 80% 0%, 100% 20%, 100% 80%, 
    80% 100%, 20% 100%, 0% 80%, 0% 20%
  );
}

.foto-irregolare {
  /* La magia avviene qui: 8 valori divisi da uno slash */
  border-radius: 34% 66% 61% 39% / 68% 42% 58% 32%;
}
.centrato {
	text-align:center !important;
}
.asinistra {
	text-align:left;
}
.adestra {
	text-align:right;
}
.firma {
  font-family: "Corinthia", cursive;
  font-weight: 400;
  font-style: normal;
  font-size:65px;
  line-height: 0.9;
 }
 
.scheda-item {
	padding:20px;
}
.scheda-item img {
	width:100%;
	aspect-ratio: 4 / 3;
}
 img.fotoservizi {
	width:100%;
	aspect-ratio: 16 / 9;
}
.scheda-item .post-prev-img, .work-img .post-prev-img, .work-img.scheda-item {
	background-size:cover;
	background-position:center center;
}
.scheda-item .post-prev-text {
	margin-bottom:0;
}

.pulsante_scheda a {
	background-color:#748b4a;
	padding:15px 16px 12px;
	text-decoration:none;
	color:#fff;
	float:right;
	line-height:1em;
	border-radius:10px;
	font-size:18px;
}
.pulsante_scheda a:hover {
    background-color: #844f39;
    text-decoration: none;
}

.post-prev-title a {
    color: #748b4a;
}

.scheda-item .post-prev-text {
	color:#573425;
	line-height: 1.5;
}
.light-content.footer a {
    color: #ffffff;
	transition: none;
}
.light-content.footer a:hover {
    color: #f7dc82;
    text-decoration: none;
}
.light-content.footer li {
    line-height: 1.5em;
}

.stripesbg {
	background:url(../images/stripes_bg.png);
	width:100%;
	height:100%;
	position:absolute;
	z-index:-1;
	opacity:.5;
}

nav.transparent .stripesbg {
	display:none;
}

.mn-sub {
    background: rgb(87 52 37);
    min-width: 260px;
    width: auto;
}

.inner-nav ul li .mn-sub li a {
    line-height: 1 !important;
    font-size: 20px;
    white-space: nowrap;
}

.intestazione {
	min-height:40vh;
}
.clearlist li {
	background-position:center center; 
	background-size:cover;
}
.schedaalloggio {
	font-size:1.2em;
}

.nav-tabs .nav-item .nav-link {
	color:#748b4a;
	font-size:1.6em;
	padding-top: 10px;
}

.nav-tabs .nav-item .nav-link.active {
	background-color:#748b4a !important;
	color:#fff !important;
	padding-top: 10px;
}
.tpl-minimal-tabs li a.active, .tpl-minimal-tabs li a.active:hover {
    border: 1px solid #748b4a !important;
	line-height:35px;
}
.tpl-minimal-tabs > li > a:hover {
    border-color: #748b4a !important;
}
.mobile-on .desktop-nav ul {
    background-color:#844f39;
}

.whatsappbutton {
	position:fixed; 
	left:20px; 
	bottom:20px; 
	z-index:300;
	height:auto;
	-webkit-transition:box-shadow .2s ease;
	transition:all .2s ease-in-out;
	color:#fff;
	background-color:#2c7423;
	border-radius:45px;
	border:2px solid rgba(255,255,255,0.8);
	padding:10px 20px 8px;
	text-decoration:none;
	box-shadow:0 0 7px rgba(0,0,0,0.7);
}
.whatsappbutton:hover {
	z-index:300;
	transform:scale(1.1);
	color:#fff;
	text-decoration:none;
}
.link_contatti {
	position:fixed;
	bottom:20px; 
	left:570px;
	height:auto;
	z-index:35;
	-webkit-transition:box-shadow .2s ease;
	transition:all .2s ease-in-out;
	color:#fff;
	background-color:#742a23;
	border-radius:45px;
	border:2px solid rgba(255,255,255,0.8);
	padding:10px 20px 8px;
	text-decoration:none;
	box-shadow:0 0 7px rgba(0,0,0,0.7);
}
.link_contatti:hover {
	transform:scale(1.1);
	color:#fff;
	text-decoration:none;
}
.telbutton {
	position:fixed; 
	left:300px; 
	bottom:20px; 
	z-index:300;
	height:auto;
	-webkit-transition:box-shadow .2s ease;
	transition:all .2s ease-in-out;
	color:#fff;
	background-color:#234c74;
	border-radius:45px;
	border:2px solid rgba(255,255,255,0.8);
	padding:10px 20px 8px;
	text-decoration:none;
	box-shadow:0 0 7px rgba(0,0,0,0.7);
}
.telbutton:hover {
	z-index:300;
	transform:scale(1.1);
	color:#fff;
	text-decoration:none;
}


.soluzioni .work-title {
	font-size:28px !important;
}

.scurente {
	position:absolute; 
	width:100%; 
	height:100%;
	background-color:rgba(0,0,0,0.5); 
	z-index:0;
}
.elenco_schede .row {
	padding:0 50px;
}
.elenco_schede .scheda {
	padding:3px;
}
.elenco_schede .titolo {
	position:relative; 
	padding:7px; 
	z-index:1;
}

.scheda .piepagina {
	position:absolute; 
	bottom:5px; 
	left:12px; 
	color:#fff;
}

.scheda .fotofondo {
	border-radius:7px; 
	overflow:hidden; 
	position:relative; 
	aspect-ratio: 1; 
	background-size:cover;
}

.scheda:hover .scurente {
	background-color:rgba(255,255,255,0.3);
	transition:all .2s ease-in-out;
}

.elenco_schede .titolo h4 {
	font-size:24px; font-weight:normal; color:#fff;
}

@media only screen and (max-width: 400px) {
    .nav-logo-wrap.local-scroll {
        width: calc(100% - 75px);
    }
}

@media only screen and (max-width: 480px) {
    .hs-line-2 {
        font-size: 48px;
    }
	.elenco_schede .row {
		padding: 0 10px;
	}
}
@media (max-width: 1040px) {
	.nomobile {
		display:none;
	}
}
@media (max-width: 1300px) {
	.section-text, .section-text .row {
		font-size: 18px;
	}
	.schedaalloggio {
		font-size: 1em;
	}
}


/* ========================================
   GALLERY CAROUSEL STYLES
   ======================================== */

.gallery-section {
	position: relative;
	overflow: hidden;
}

.gallery-title-bar {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 10;
	padding: 30px 50px;
	background: linear-gradient(0deg, rgba(0,0,0,0.6) 0%, rgba(0,0,0,0) 100%);
	pointer-events: none;
}

.gallery-section-title {
	font-family: Prata, serif;
	font-weight: 400;
	font-size: 2em;
	color: #fff;
	text-transform: none;
	letter-spacing: 0.02em;
	margin: 0;
	text-shadow: 0 2px 12px rgba(0,0,0,0.4);
}

.gallery-slide {
	height: 85vh;
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
}

/* Owl Carousel v1 overrides for gallery */
.gallery-carousel .owl-controls {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	pointer-events: none;
	z-index: 10;
}

.gallery-carousel .owl-buttons {
	position: absolute;
	top: 50%;
	left: 0;
	right: 0;
	transform: translateY(-50%);
	display: flex;
	justify-content: space-between;
	padding: 0 20px;
}

.gallery-carousel .owl-prev,
.gallery-carousel .owl-next {
	pointer-events: all;
	width: 50px;
	height: 50px;
	display: flex !important;
	align-items: center;
	justify-content: center;
	background: rgba(255,255,255,0.15) !important;
	border-radius: 50%;
	color: #fff !important;
	font-size: 18px !important;
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	transition: all 0.3s ease;
	opacity: 0.6;
}

.gallery-carousel .owl-prev:hover,
.gallery-carousel .owl-next:hover {
	background: rgba(255,255,255,0.35) !important;
	opacity: 1;
}

.gallery-carousel .owl-pagination {
	position: absolute;
	bottom: 20px;
	left: 50%;
	transform: translateX(-50%);
	pointer-events: all;
}

.gallery-carousel .owl-page span {
	display: inline-block;
	width: 10px;
	height: 10px;
	background: rgba(255,255,255,0.4);
	border-radius: 50%;
	margin: 0 5px;
	transition: all 0.3s ease;
}

.gallery-carousel .owl-page.active span {
	background: #fff;
	transform: scale(1.2);
}

/* Responsive gallery */
@media (max-width: 768px) {
	.gallery-slide {
		height: 60vh;
	}
	.gallery-title-bar {
		padding: 20px 25px;
	}
	.gallery-section-title {
		font-size: 1.5em;
	}
	.gallery-carousel .owl-prev,
	.gallery-carousel .owl-next {
		width: 40px;
		height: 40px;
		font-size: 14px !important;
	}
}


/* ========================================
   SCACCHIERA LAYOUT (index2)
   ======================================== */

.scacchiera-row {
	display: flex;
	width: 100%;
	min-height: 70vh;
}

.scacchiera-col {
	width: 50%;
	position: relative;
	overflow: hidden;
}

/* Slide dentro la scacchiera */
.scacchiera-slide {
	height: 70vh;
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
	position: relative;
	overflow: hidden;
}

/* Quando lo slide contiene <picture>/<img> invece del background-image.
   Vogliamo esattamente la stessa resa del vecchio background: cover + center. */
.scacchiera-slide > picture {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	display: block;
	width: 100%;
	height: 100%;
}
.scacchiera-slide > picture > img,
.scacchiera-slide > img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	margin: 0;
	padding: 0;
	border: 0;
	display: block;
	object-fit: cover;
	object-position: 50% 50%;
}

/* Label sovrapposta al carousel */
.scacchiera-label {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 10;
	padding: 20px 30px;
	background: linear-gradient(0deg, rgba(0,0,0,0.55) 0%, rgba(0,0,0,0) 100%);
	font-family: Prata, serif;
	font-weight: 400;
	font-size: 1.6em;
	color: #fff;
	text-transform: none;
	letter-spacing: 0.02em;
	text-shadow: 0 2px 10px rgba(0,0,0,0.4);
	pointer-events: none;
}

/* Colonna testo */
.scacchiera-testo {
	display: flex;
	align-items: center;
	justify-content: center;
}

.scacchiera-testo-inner {
	padding: 8% 10%;
	font-size: 20px;
	font-weight: 400;
	color: rgba(87, 52, 37, .95);
	line-height: 1.7;
}

.stile3 .scacchiera-testo-inner {
	color: #3f1d0e;
}

.scacchiera-testo-inner .section-title {
	text-transform: none;
}

.scacchiera-testo-inner p {
	margin-bottom: 15px;
}

.scacchiera-testo-inner .firma {
	margin-top: 10px;
}

/* Owl v1 nav per scacchiera */
.scacchiera-carousel .owl-controls {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	pointer-events: none;
	z-index: 10;
}

.scacchiera-carousel .owl-buttons {
	position: absolute;
	top: 50%;
	left: 0;
	right: 0;
	transform: translateY(-50%);
	display: flex;
	justify-content: space-between;
	padding: 0 12px;
}

.scacchiera-carousel .owl-prev,
.scacchiera-carousel .owl-next {
	pointer-events: all;
	width: 42px;
	height: 42px;
	display: flex !important;
	align-items: center;
	justify-content: center;
	background: rgba(255,255,255,0.15) !important;
	border-radius: 50%;
	color: #fff !important;
	font-size: 16px !important;
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	transition: all 0.3s ease;
	opacity: 0.5;
}

.scacchiera-carousel .owl-prev:hover,
.scacchiera-carousel .owl-next:hover {
	background: rgba(255,255,255,0.35) !important;
	opacity: 1;
}

.scacchiera-carousel .owl-pagination {
	position: absolute;
	bottom: 14px;
	left: 50%;
	transform: translateX(-50%);
	pointer-events: all;
}

.scacchiera-carousel .owl-page span {
	display: inline-block;
	width: 8px;
	height: 8px;
	background: rgba(255,255,255,0.4);
	border-radius: 50%;
	margin: 0 4px;
	transition: all 0.3s ease;
}

.scacchiera-carousel .owl-page.active span {
	background: #fff;
	transform: scale(1.2);
}

/* Mappa fullsize nel div scacchiera */
.scacchiera-mappa {
	min-height: 70vh;
}
.scacchiera-mappa iframe {
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
}

/* Responsive scacchiera */
@media (max-width: 991px) {
	.scacchiera-mappa {
		min-height: 45vh;
	}
	.scacchiera-row {
		flex-direction: column;
	}
	.scacchiera-col {
		width: 100%;
	}
	/* Forza sempre ordine: carousel prima, testo dopo */
	.scacchiera-col:not(.scacchiera-testo) {
		order: 1;
	}
	.scacchiera-col.scacchiera-testo {
		order: 2;
	}
	.scacchiera-slide {
		height: 55vh;
	}
	.scacchiera-testo-inner {
		padding: 10% 8%;
		font-size: 18px;
	}
}

@media (max-width: 576px) {
	.scacchiera-slide {
		height: 45vh;
	}
	.scacchiera-label {
		font-size: 1.3em;
		padding: 15px 20px;
	}
	.scacchiera-testo-inner {
		padding: 12% 7%;
		font-size: 16px;
	}
}


/* ========================================
   STILE GRIGIO (index3)
   ======================================== */

/* Sfondi alternati grigi */
.grigio-chiaro {
	background-color: #f2f2f2;
}
.grigio-scuro {
	background-color: #e0e0e0;
}

/* Testi nella palette grigia */
.stile-grigio .scacchiera-testo-inner {
	color: #333;
}
.stile-grigio .scacchiera-testo-inner strong {
	color: #111;
}
.stile-grigio .scacchiera-testo-inner .section-title {
	color: #222;
}
.stile-grigio .scacchiera-testo-inner a {
	color: #444;
	transition: color 0.2s ease;
}
.stile-grigio .scacchiera-testo-inner a:hover {
	color: #111;
}
.stile-grigio .scacchiera-testo-inner i.fa {
	color: #666;
}
.stile-grigio .scacchiera-testo-inner .firma {
	color: #555;
}

/* Navbar grigia */
.stile-grigio .main-nav.dark {
	background-color: #2a2a2a;
}
.stile-grigio .main-nav.dark .inner-nav ul > li > a:hover {
	color: #ccc;
}

/* Footer grigio */
.stile-grigio .sfumafooter {
	background: #2a2a2a;
	background: linear-gradient(0deg, rgba(42,42,42,1) 0%, rgba(42,42,42,.95) 43%, rgba(42,42,42,0.9) 100%);
}
.stile-grigio .footer .thirdcolor {
	color: #bbb !important;
}
.stile-grigio .footer a {
	color: #ddd;
}
.stile-grigio .footer a:hover {
	color: #fff;
}


/* ========================================
   STILE MOSSO (index4)
   Tocchi di irregolarità sulla scacchiera
   ======================================== */

/* --- Sfondi testo tutti bianchi --- */
.stile-mosso .scacchiera-testo.sfumatostorto,
.stile-mosso .scacchiera-testo.fondochiaro {
	background: #ffffff !important;
}

/* --- Piccolo gap verticale tra le colonne --- */
.stile-mosso .mosso-row {
	gap: 5px;
	position: relative;
}
.stile-mosso .mosso-row > .scacchiera-col {
	flex: 1 1 0;
	width: auto;
}

/* --- Clip-path leggermente irregolare sulle foto --- */
/* even = foto a SINISTRA (righe 1,3,5): bordo destro (interno) leggermente mosso */
.stile-mosso .mosso-row:nth-child(even) .mosso-foto {
	clip-path: polygon(0 0, 100% 1.2%, 99.3% 98.5%, 0 100%);
}
/* odd = foto a DESTRA (righe 2,4): bordo sinistro (interno) leggermente mosso */
.stile-mosso .mosso-row:nth-child(odd) .mosso-foto {
	clip-path: polygon(0.7% 1.5%, 100% 0, 100% 100%, 0 98.2%);
}

/* --- Nessuna ombra e nessun separatore orizzontale --- */

/* --- Nessuna lineetta decorativa sotto i titoli --- */

/* --- Sottile effetto rientro alternato sulla colonna foto --- */
.stile-mosso .mosso-row:nth-child(3n+1) .mosso-foto .scacchiera-slide {
	background-position: center 45%;
}
.stile-mosso .mosso-row:nth-child(3n+2) .mosso-foto .scacchiera-slide {
	background-position: center 55%;
}

/* --- Responsive: disabilita effetti su mobile --- */
@media (max-width: 991px) {
	.stile-mosso .mosso-row {
		gap: 0;
	}
	.stile-mosso .mosso-row .mosso-foto {
		clip-path: none;
	}
}


/* ========================================
   DIARIO DI BORDO - Blog listing & articolo
   ======================================== */

/* --- Griglia card nell'elenco --- */
.diario-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 35px;
}

.diario-vuoto {
	grid-column: 1 / -1;
	text-align: center;
	padding: 60px 20px;
	color: #999;
	font-size: 1.1em;
}

/* --- Card singola --- */
.diario-card {
	background: #fff;
	border-radius: 6px;
	overflow: hidden;
	box-shadow: 0 2px 15px rgba(0,0,0,0.06);
	transition: box-shadow 0.3s ease, transform 0.3s ease;
}
.diario-card:hover {
	box-shadow: 0 8px 30px rgba(0,0,0,0.1);
	transform: translateY(-3px);
}

.diario-card-link {
	display: block;
	text-decoration: none;
	color: inherit;
}

.diario-card-foto {
	position: relative;
	overflow: hidden;
	padding-bottom: 100%; /* rapporto 1:1 */
}
.diario-card-foto img {
	position: absolute;
	top: 0; left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	transition: transform 0.5s ease;
}
.diario-card:hover .diario-card-foto img {
	transform: scale(1.05);
}

.diario-card-corpo {
	padding: 22px 24px 26px;
}

.diario-card-data {
	display: block;
	font-size: 0.78em;
	color: #999;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin-bottom: 8px;
	font-family: Arial, Helvetica, sans-serif;
}

.diario-card-titolo {
	font-family: Prata, serif;
	font-size: 1.25em;
	font-weight: 400;
	color: #3f1d0e;
	line-height: 1.35;
	margin-bottom: 10px;
}

.diario-card-anteprima {
	font-size: 0.9em;
	color: #666;
	line-height: 1.6;
	margin-bottom: 14px;
	font-family: Arial, Helvetica, sans-serif;
}

.diario-card-leggi {
	display: inline-block;
	font-size: 0.85em;
	color: #3f1d0e;
	font-weight: 600;
	font-family: Arial, Helvetica, sans-serif;
	transition: color 0.3s;
}
.diario-card:hover .diario-card-leggi {
	color: #7f6043;
}

/* --- Responsive griglia --- */
@media (max-width: 991px) {
	.diario-grid {
		grid-template-columns: 1fr;
		gap: 28px;
	}
}
@media (max-width: 576px) {
	.diario-grid {
		gap: 20px;
	}
}


/* ========================================
   DIARIO ARTICOLO - Pagina dettaglio
   ======================================== */

/* --- Hero articolo --- */
.diario-art-hero {
	position: relative;
	background-size: cover;
	background-position: center center;
	display: flex;
	align-items: flex-end;
}
.diario-art-hero-overlay {
	position: absolute;
	top: 0; left: 0; right: 0; bottom: 0;
	background: rgba(63, 29, 14, 0.7);
}
.diario-art-hero-content {
	position: relative;
	z-index: 2;
	padding-bottom: 40px;
	padding-top: 170px;
}

/* Foto articolo nel corpo */
.diario-art-foto {
	margin-bottom: 35px;
	border-radius: 6px;
	overflow: hidden;
}
.diario-art-foto img {
	width: 100%;
	height: auto;
	display: block;
}
.diario-art-data {
	display: block;
	color: rgba(255,255,255,0.7);
	font-size: 0.85em;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	margin-bottom: 10px;
	font-family: Arial, Helvetica, sans-serif;
}
.diario-art-titolo {
	font-family: Prata, serif;
	font-size: 2.8em;
	font-weight: 400;
	color: #fff;
	line-height: 1.2;
	max-width: 800px;
}

/* --- Corpo articolo --- */
.diario-art-corpo {
	max-width: 780px;
	margin: 0 auto;
}

.diario-art-testo {
	font-size: 1.05em;
	line-height: 1.85;
	color: #444;
	font-family: Arial, Helvetica, sans-serif;
}
.diario-art-testo p {
	margin-bottom: 18px;
}
.diario-art-testo img {
	max-width: 100%;
	height: auto;
	border-radius: 4px;
	margin: 20px 0;
}

/* --- Video YouTube embed --- */
.diario-art-video {
	margin: 40px 0;
}
.diario-video-wrap {
	position: relative;
	padding-bottom: 56.25%;
	height: 0;
	overflow: hidden;
	border-radius: 6px;
	box-shadow: 0 4px 20px rgba(0,0,0,0.1);
}
.diario-video-wrap iframe {
	position: absolute;
	top: 0; left: 0;
	width: 100%; height: 100%;
}

/* --- Navigazione prev/next --- */
.diario-art-nav {
	display: flex;
	justify-content: space-between;
	gap: 20px;
	margin-top: 50px;
	padding-top: 30px;
	border-top: 1px solid #eee;
}
.diario-nav-prev,
.diario-nav-next {
	display: block;
	text-decoration: none;
	max-width: 48%;
	transition: color 0.3s;
}
.diario-nav-next {
	text-align: right;
}
.diario-nav-label {
	display: block;
	font-size: 0.78em;
	color: #999;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	margin-bottom: 4px;
	font-family: Arial, Helvetica, sans-serif;
}
.diario-nav-titolo {
	display: block;
	font-family: Prata, serif;
	font-size: 1.05em;
	color: #3f1d0e;
	line-height: 1.35;
}
.diario-nav-prev:hover .diario-nav-titolo,
.diario-nav-next:hover .diario-nav-titolo {
	color: #7f6043;
}

/* --- Link torna al diario --- */
.diario-art-indietro {
	margin-top: 30px;
	text-align: center;
}
.diario-art-indietro a {
	color: #999;
	font-size: 0.9em;
	text-decoration: none;
	font-family: Arial, Helvetica, sans-serif;
	transition: color 0.3s;
}
.diario-art-indietro a:hover {
	color: #3f1d0e;
}

/* --- Responsive articolo --- */
@media (max-width: 768px) {
	.diario-art-hero-content {
		padding-top: 140px;
		padding-bottom: 30px;
	}
	.diario-art-titolo {
		font-size: 1.8em;
	}
	.diario-art-hero {
		min-height: 40vh;
	}
	.diario-art-nav {
		flex-direction: column;
	}
	.diario-nav-prev,
	.diario-nav-next {
		max-width: 100%;
		text-align: left;
	}
}