.ct-section {
width:100%;
background-size:cover;
background-repeat:repeat;
}
.ct-section>.ct-section-inner-wrap {
display:flex;
flex-direction:column;
align-items:flex-start;
}
.ct-div-block {
display:flex;
flex-wrap:nowrap;
flex-direction:column;
align-items:flex-start;
}
.ct-new-columns {
display:flex;
width:100%;
flex-direction:row;
align-items:stretch;
justify-content:center;
flex-wrap:wrap;
}
.ct-link-text {
display:inline-block;
}
.ct-link {
display:flex;
flex-wrap:wrap;
text-align:center;
text-decoration:none;
flex-direction:column;
align-items:center;
justify-content:center;
}
.ct-link-button {
display:inline-block;
text-align:center;
text-decoration:none;
}
.ct-link-button {
background-color: #1e73be;
border: 1px solid #1e73be;
color: #ffffff;
padding: 10px 16px;
}
.ct-image {
max-width:100%;
}
.ct-fancy-icon>svg {
width:55px;height:55px;}
.ct-inner-content {
width:100%;
}
.ct-slide {
display:flex;
flex-wrap:wrap;
text-align:center;
flex-direction:column;
align-items:center;
justify-content:center;
}
.ct-nestable-shortcode {
display:flex;
flex-wrap:nowrap;
flex-direction:column;
align-items:flex-start;
}
.oxy-comments {
width:100%;
text-align:left;
}
.oxy-comment-form {
width:100%;
}
.oxy-login-form {
width:100%;
}
.oxy-search-form {
width:100%;
}
.oxy-tabs-contents {
display:flex;
width:100%;
flex-wrap:nowrap;
flex-direction:column;
align-items:flex-start;
}
.oxy-tab {
display:flex;
flex-wrap:nowrap;
flex-direction:column;
align-items:flex-start;
}
.oxy-tab-content {
display:flex;
width:100%;
flex-wrap:nowrap;
flex-direction:column;
align-items:flex-start;
}
.oxy-testimonial {
width:100%;
}
.oxy-icon-box {
width:100%;
}
.oxy-pricing-box {
width:100%;
}
.oxy-posts-grid {
width:100%;
}
.oxy-gallery {
width:100%;
}
.ct-slider {
width:100%;
}
.oxy-tabs {
display:flex;
flex-wrap:nowrap;
flex-direction:row;
align-items:stretch;
}
.ct-modal {
flex-direction:column;
align-items:flex-start;
}
.ct-span {
display:inline-block;
text-decoration:inherit;
}
.ct-widget {
width:100%;
}
.oxy-dynamic-list {
width:100%;
}
@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
			.ct-div-block,
			.oxy-post-content,
			.ct-text-block,
			.ct-headline,
			.oxy-rich-text,
			.ct-link-text { max-width: 100%; }
			img { flex-shrink: 0; }
			body * { min-height: 1px; }
		}            .oxy-testimonial {
                flex-direction: row;
                align-items: center;
            }
                        .oxy-testimonial .oxy-testimonial-photo-wrap {
                order: 1;
            }
            
                        .oxy-testimonial .oxy-testimonial-photo {
                width: 125px;                height: 125px;                margin-right: 20px;
            }
            
                        .oxy-testimonial .oxy-testimonial-photo-wrap, 
            .oxy-testimonial .oxy-testimonial-author-wrap, 
            .oxy-testimonial .oxy-testimonial-content-wrap {
                align-items: flex-start;                text-align: left;            }
            
                                                            .oxy-testimonial .oxy-testimonial-text {
                margin-bottom:8px;font-size: 21px;
line-height: 1.4;
-webkit-font-smoothing: subpixel-antialiased;
            }
            
                                    .oxy-testimonial .oxy-testimonial-author {
                font-size: 18px;
-webkit-font-smoothing: subpixel-antialiased;
            }
                            

                                                .oxy-testimonial .oxy-testimonial-author-info {
                font-size: 12px;
-webkit-font-smoothing: subpixel-antialiased;
            }
            
             
            
                        .oxy-icon-box {
                text-align: left;                flex-direction: column;            }
            
                        .oxy-icon-box .oxy-icon-box-icon {
                margin-bottom: 12px;
                align-self: flex-start;            }
            
                                                                        .oxy-icon-box .oxy-icon-box-heading {
                font-size: 21px;
margin-bottom: 12px;            }
            
                                                                                    .oxy-icon-box .oxy-icon-box-text {
                font-size: 16px;
margin-bottom: 12px;align-self: flex-start;            }
            
                        .oxy-icon-box .oxy-icon-box-link {
                margin-top: 20px;                            }
            
            
            /* GLOBALS */

                                                            .oxy-pricing-box .oxy-pricing-box-section {
                padding-top: 20px;
padding-left: 20px;
padding-right: 20px;
padding-bottom: 20px;
text-align: center;            }
                        
                        .oxy-pricing-box .oxy-pricing-box-section.oxy-pricing-box-price {
                justify-content: center;            }
            
            /* IMAGE */
                                                                                    .oxy-pricing-box .oxy-pricing-box-section.oxy-pricing-box-graphic {
                justify-content: center;            }
            
            /* TITLE */
                                                            
                                    .oxy-pricing-box .oxy-pricing-box-title-title {
                font-size: 48px;
            }
            
                                    .oxy-pricing-box .oxy-pricing-box-title-subtitle {
                font-size: 24px;
            }
            

            /* PRICE */
                                                .oxy-pricing-box .oxy-pricing-box-section.oxy-pricing-box-price {
                                                flex-direction: row;                                            }
            
                                    .oxy-pricing-box .oxy-pricing-box-currency {
                font-size: 28px;
            }
            
                                    .oxy-pricing-box .oxy-pricing-box-amount-main {
                font-size: 80px;
line-height: 0.7;
            }
            
                                    .oxy-pricing-box .oxy-pricing-box-amount-decimal {
                font-size: 13px;
            }
                        
                                    .oxy-pricing-box .oxy-pricing-box-term {
                font-size: 16px;
            }
            
                                    .oxy-pricing-box .oxy-pricing-box-sale-price {
                font-size: 12px;
color: rgba(0,0,0,0.5);
                margin-bottom: 20px;            }
            
            /* CONTENT */

                                                                        .oxy-pricing-box .oxy-pricing-box-section.oxy-pricing-box-content {
                font-size: 16px;
color: rgba(0,0,0,0.5);
            }
            
            /* CTA */

                                                                        .oxy-pricing-box .oxy-pricing-box-section.oxy-pricing-box-cta {
                justify-content: center;            }
            
        
                                .oxy-progress-bar .oxy-progress-bar-background {
            background-color: #000000;            background-image: linear-gradient(-45deg,rgba(255,255,255,.12) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.12) 50%,rgba(255,255,255,.12) 75%,transparent 75%,transparent);            animation: none 0s paused;        }
                
                .oxy-progress-bar .oxy-progress-bar-progress-wrap {
            width: 85%;        }
        
                                                        .oxy-progress-bar .oxy-progress-bar-progress {
            background-color: #66aaff;padding: 40px;animation: none 0s paused, none 0s paused;            background-image: linear-gradient(-45deg,rgba(255,255,255,.12) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.12) 50%,rgba(255,255,255,.12) 75%,transparent 75%,transparent);        
        }
                
                        .oxy-progress-bar .oxy-progress-bar-overlay-text {
            font-size: 30px;
font-weight: 900;
-webkit-font-smoothing: subpixel-antialiased;
        }
        
                        .oxy-progress-bar .oxy-progress-bar-overlay-percent {
            font-size: 12px;
        }
        
        .ct-slider .unslider-nav ol li {border-color: #ffffff; }.ct-slider .unslider-nav ol li.unslider-active {background-color: #ffffff; }.ct-slider .ct-slide {
				padding: 0px;			}
		
                        .oxy-superbox .oxy-superbox-secondary, 
            .oxy-superbox .oxy-superbox-primary {
                transition-duration: 0.5s;            }
            
            
            
            
            
        
        
        
        
            .oxy-shape-divider {
                width: 0px;
                height: 0px;
                
            }
            
            .oxy_shape_divider svg {
                width: 100%;
            }
            .oxy-pro-menu .oxy-pro-menu-container:not(.oxy-pro-menu-open-container):not(.oxy-pro-menu-off-canvas-container) .sub-menu{
box-shadow:px px px px ;}

.oxy-pro-menu .oxy-pro-menu-show-dropdown .oxy-pro-menu-list .menu-item-has-children > a svg{
transition-duration:0.4s;
}

.oxy-pro-menu .oxy-pro-menu-show-dropdown .oxy-pro-menu-list .menu-item-has-children > a div{
margin-left:0px;
}

.oxy-pro-menu .oxy-pro-menu-mobile-open-icon svg{
width:30px;
height:30px;
}

.oxy-pro-menu .oxy-pro-menu-mobile-open-icon{
padding-top:15px;
padding-right:15px;
padding-bottom:15px;
padding-left:15px;
}

.oxy-pro-menu .oxy-pro-menu-mobile-open-icon, .oxy-pro-menu .oxy-pro-menu-mobile-open-icon svg{
transition-duration:0.4s;
}

.oxy-pro-menu .oxy-pro-menu-mobile-close-icon{
top:20px;
left:20px;
}

.oxy-pro-menu .oxy-pro-menu-mobile-close-icon svg{
width:24px;
height:24px;
}

.oxy-pro-menu .oxy-pro-menu-mobile-close-icon, .oxy-pro-menu .oxy-pro-menu-mobile-close-icon svg{
transition-duration:0.4s;
}

.oxy-pro-menu .oxy-pro-menu-container.oxy-pro-menu-off-canvas-container, .oxy-pro-menu .oxy-pro-menu-container.oxy-pro-menu-open-container{
background-color:#ffffff;
}

.oxy-pro-menu .oxy-pro-menu-off-canvas-container, .oxy-pro-menu .oxy-pro-menu-open-container{
background-image:url();
}

.oxy-pro-menu .oxy-pro-menu-off-canvas-container .oxy-pro-menu-list .menu-item-has-children > a svg, .oxy-pro-menu .oxy-pro-menu-open-container .oxy-pro-menu-list .menu-item-has-children > a svg{
font-size:24px;
}

.oxy-pro-menu .oxy-pro-menu-dropdown-links-toggle.oxy-pro-menu-open-container .menu-item-has-children ul, .oxy-pro-menu .oxy-pro-menu-dropdown-links-toggle.oxy-pro-menu-off-canvas-container .menu-item-has-children ul{
background-color:rgba(0,0,0,0.2);
border-top-style:solid;
}

.oxy-pro-menu .oxy-pro-menu-container:not(.oxy-pro-menu-open-container):not(.oxy-pro-menu-off-canvas-container) .oxy-pro-menu-list{
                    flex-direction: row;
               }
.oxy-pro-menu .oxy-pro-menu-container .menu-item a{
                    text-align: left;
                    justify-content: flex-start;
                }
.oxy-pro-menu .oxy-pro-menu-container.oxy-pro-menu-open-container .menu-item, .oxy-pro-menu .oxy-pro-menu-container.oxy-pro-menu-off-canvas-container .menu-item{
                    align-items: flex-start;
                }

            .oxy-pro-menu .oxy-pro-menu-off-canvas-container{
                    top: 0;
                    bottom: 0;
                    right: auto;
                    left: 0;
               }
.oxy-pro-menu .oxy-pro-menu-container.oxy-pro-menu-open-container .oxy-pro-menu-list .menu-item a, .oxy-pro-menu .oxy-pro-menu-container.oxy-pro-menu-off-canvas-container .oxy-pro-menu-list .menu-item a{
                    text-align: left;
                    justify-content: flex-start;
                }

            .oxy-site-navigation {
--oxynav-brand-color:#4831B0;
--oxynav-neutral-color:#FFFFFF;
--oxynav-activehover-color:#EFEDF4;
--oxynav-background-color:#4831B0;
--oxynav-border-radius:0px;
--oxynav-other-spacing:8px;
--oxynav-transition-duration:0.3s;
--oxynav-transition-timing-function:cubic-bezier(.84,.05,.31,.93);
}

.oxy-site-navigation .oxy-site-navigation__mobile-close-wrapper{
text-align:left;
}

.oxy-site-navigation > ul{ left: 0; }
.oxy-site-navigation {
                        --oxynav-animation-name: none; 
                    }

                .oxy-site-navigation > ul:not(.open) > li[data-cta='true']:nth-last-child(1){ 
                    background-color: var(--oxynav-brand-color);
                    transition: var(--oxynav-transition-duration);
                    margin-left: var(--oxynav-other-spacing);
                    border: none;
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true']:nth-last-child(2){ 
                    background: transparent;
                    border: 1px solid currentColor;
                    transition: var(--oxynav-transition-duration);
                    margin-left: var(--oxynav-other-spacing);
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true']:nth-last-child(2):not(:hover) > img{
                    filter: invert(0) !important;
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true']:hover{
                    background-color: var(--oxynav-activehover-color);
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true']:nth-last-child(1) > a{
                    color: var(--oxynav-neutral-color);
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true']:nth-last-child(2) > a{
                    color: var(--oxynav-brand-color);
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true']:hover > a{
                    color: var(--oxynav-brand-color);
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true']:nth-last-child(1) > a::after{
                    color: var(--oxynav-neutral-color);   
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true']:nth-last-child(2) > a::after{
                    color: var(--oxynav-brand-color);   
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true']:hover > a::after{
                    color: var(--oxynav-brand-color);   
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true'] > ul{
                    display: none;
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true'] > button, .oxy-site-navigation > ul:not(.open) > li[data-cta='true'] > ul{
                    display: none;
                }

                .ct-section-inner-wrap, .oxy-header-container{
  max-width: 1120px;
}
body {font-family: 'Open Sans';}body {line-height: 1.6;font-size: 16px;font-weight: 400;color: #404040;}.oxy-nav-menu-hamburger-line {background-color: #404040;}h1, h2, h3, h4, h5, h6 {font-family: 'Source Sans 3';font-size: 36px;font-weight: 700;}h2, h3, h4, h5, h6{font-size: 30px;}h3, h4, h5, h6{font-size: 24px;}h4, h5, h6{font-size: 20px;}h5, h6{font-size: 18px;}h6{font-size: 16px;}a {color: #0074db;text-decoration: none;}a:hover {text-decoration: none;}.ct-link-text {text-decoration: ;}.ct-link {text-decoration: ;}.ct-link-button {border-radius: 3px;}.ct-section-inner-wrap {
padding-top: 75px;
padding-right: 20px;
padding-bottom: 75px;
padding-left: 20px;
}.ct-new-columns > .ct-div-block {
padding-top: 20px;
padding-right: 20px;
padding-bottom: 20px;
padding-left: 20px;
}.oxy-header-container {
padding-right: 20px;
padding-left: 20px;
}@media (max-width: 992px) {
				.ct-columns-inner-wrap {
					display: block !important;
				}
				.ct-columns-inner-wrap:after {
					display: table;
					clear: both;
					content: "";
				}
				.ct-column {
					width: 100% !important;
					margin: 0 !important;
				}
				.ct-columns-inner-wrap {
					margin: 0 !important;
				}
			}
/* =========================================================
   MADÌ — CSS UNICO GLOBALE OTTIMIZZATO
   Header + Footer + Home Premium + Cards + Territorio + Archive
   Versione: immobiliare / premium
   ========================================================= */

/* Font principale */
@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@300;400;500;600;700;800&display=swap');

/* =========================================================
   01. TOKENS
   ========================================================= */

:root{
  --madi-bg:#F4F0EA;
  --madi-sand:#E4DACD;
  --madi-sand-2:#EEE7DD;
  --madi-paper:#FFFFFF;

  --madi-accent:#6F858E;
  --madi-accent-dark:#39484D;

  --madi-text:#171717;
  --madi-muted:rgba(23,23,23,.66);
  --madi-muted-strong:rgba(23,23,23,.78);
  --madi-white:#FFFFFF;

  --madi-border:rgba(23,23,23,.12);
  --madi-border-soft:rgba(23,23,23,.08);
  --madi-border-strong:rgba(23,23,23,.18);

  --madi-shadow:0 24px 70px rgba(23,23,23,.10);
  --madi-shadow-soft:0 12px 34px rgba(23,23,23,.065);
  --madi-shadow-card:0 18px 44px rgba(23,23,23,.075);

  --madi-container:1540px;
  --madi-container-narrow:1280px;

  --madi-radius-xs:10px;
  --madi-radius-sm:14px;
  --madi-radius-md:18px;
  --madi-radius-lg:22px;
  --madi-radius-xl:28px;
  --madi-card-cut:22px;
  --madi-hero-radius:28px;

  --madi-ease:cubic-bezier(.22,.61,.36,1);

  --madi-display:"Manrope","Helvetica Neue",Arial,sans-serif;
  --madi-body:"Manrope","Helvetica Neue",Arial,sans-serif;

  --madi-sec:92px;
  --madi-sec-tight:68px;

  --madi-header-h:84px;
  --madi-header-h-mobile:76px;

  /*
    Shape SOLO hero:
    - lieve taglio/scanalatura in alto a sinistra
    - angoli arrotondati
    - il resto resta pulito e professionale
  */
  --madi-hero-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 400 300' preserveAspectRatio='none'%3E%3Cpath fill='white' d='M92 0H372C389 0 400 11 400 28V272C400 289 389 300 372 300H28C11 300 0 289 0 272V42H50C61 42 64 31 71 20L78 9C83 3 88 0 92 0Z'/%3E%3C/svg%3E");
}

/* =========================================================
   02. RESET / BASE
   ========================================================= */

html{
  scroll-behavior:smooth;
}

body{
  margin:0;
  background:var(--madi-bg);
  color:var(--madi-text);
  font-family:var(--madi-body);
  font-weight:400;
  letter-spacing:-.01em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

body.madi-mobile-open{
  overflow:hidden;
}

*,
*::before,
*::after{
  box-sizing:border-box;
}

img,
video,
svg{
  max-width:100%;
  height:auto;
  display:block;
}

a{
  color:inherit;
  text-decoration:none;
}

button,
input,
select,
textarea{
  font:inherit;
}

button{
  appearance:none;
  -webkit-appearance:none;
  border-radius:0;
}

.madi-home{
  overflow:hidden;
  background:var(--madi-bg);
}

.madi-home--real-estate{
  background:var(--madi-bg);
}

.madi-container{
  width:min(calc(100% - 64px), var(--madi-container));
  margin-inline:auto;
}

.madi-container--narrow{
  width:min(calc(100% - 64px), var(--madi-container-narrow));
  margin-inline:auto;
}

.madi-section{
  position:relative;
  padding:var(--madi-sec) 0;
}

.madi-section--tight{
  padding:var(--madi-sec-tight) 0;
}

.madi-center{
  text-align:center;
}

.madi-stack{
  display:grid;
  gap:18px;
}

.madi-copy{
  max-width:700px;
}

/* =========================================================
   03. TYPOGRAPHY / UI
   ========================================================= */

.madi-eyebrow{
  display:inline-block;
  margin:0 0 14px;
  font-size:10px;
  line-height:1;
  font-weight:800;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(23,23,23,.68);
}

.madi-title,
.madi-brand__title,
.madi-card__title,
.madi-map-card__body h4,
.madi-category-card__body h3,
.madi-destination__title,
.madi-service__title,
.madi-mobile-menu a,
.madi-destination-index-card__title,
.madi-archive-card__title{
  font-family:var(--madi-display);
  font-weight:400;
  letter-spacing:-.045em;
}

.madi-title{
  margin:0 0 16px;
  line-height:.98;
  color:var(--madi-text);
}

.madi-title--xl{
  font-size:clamp(48px, 6vw, 94px);
  font-weight:300;
  letter-spacing:-.07em;
}

.madi-title--lg{
  font-size:clamp(38px, 4.6vw, 68px);
  font-weight:320;
  letter-spacing:-.06em;
}

.madi-title--md{
  font-size:clamp(32px, 3vw, 50px);
  font-weight:350;
  letter-spacing:-.055em;
}

.madi-title--sm{
  font-size:clamp(22px, 2vw, 30px);
  font-weight:400;
  letter-spacing:-.04em;
}

.madi-text{
  margin:0;
  font-size:15px;
  line-height:1.85;
  color:rgba(23,23,23,.76);
}

.madi-btn,
.madi-btn:visited{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:50px;
  padding:0 24px;
  border:1px solid var(--madi-accent-dark);
  border-radius:999px;
  background:var(--madi-accent-dark);
  color:#fff;
  font-size:10px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
  line-height:1;
  cursor:pointer;
  white-space:nowrap;
  overflow:hidden;
  transition:
    transform .3s var(--madi-ease),
    background .3s var(--madi-ease),
    color .3s var(--madi-ease),
    border-color .3s var(--madi-ease),
    opacity .3s var(--madi-ease);
}

.madi-btn:hover{
  background:var(--madi-text);
  border-color:var(--madi-text);
  transform:translateY(-2px);
}

.madi-btn--ghost,
.madi-btn--ghost:visited{
  background:transparent !important;
  color:var(--madi-text) !important;
  border-color:rgba(23,23,23,.18) !important;
}

.madi-btn--ghost:hover{
  background:var(--madi-text) !important;
  color:#fff !important;
  border-color:var(--madi-text) !important;
}

.madi-btn--light,
.madi-btn--light:visited{
  background:#fff;
  color:var(--madi-text);
  border-color:#fff;
}

.madi-btn--light-ghost,
.madi-btn--light-ghost:visited{
  background:rgba(255,255,255,.08) !important;
  color:#fff !important;
  border-color:rgba(255,255,255,.34) !important;
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
}

.madi-btn--light-ghost:hover{
  background:#fff !important;
  color:#171717 !important;
  border-color:#fff !important;
}

.madi-link{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size:10px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--madi-accent-dark);
}

.madi-link::after{
  content:"→";
  transition:transform .3s var(--madi-ease);
}

.madi-link:hover::after{
  transform:translateX(4px);
}

/* =========================================================
   04. REVEAL
   ========================================================= */

.madi-reveal{
  opacity:0;
  transform:translate3d(0, 28px, 0);
  transition:
    opacity .9s var(--madi-ease),
    transform .9s var(--madi-ease);
}

.madi-reveal.is-visible{
  opacity:1;
  transform:translate3d(0, 0, 0);
}
/* =========================================================
   LOGO MADÌ
   ========================================================= */

.madi-brand--image{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  line-height:1;
}

.madi-brand__logo{
  display:block;
  width:125px;
  height:60px;
  object-fit:contain;
}

.madi-header .madi-brand__logo{
  width:125px;
  height:60px;
}

.madi-footer .madi-brand__logo{
  width:125px;
  height:60px;
}

.madi-mobile-logo{
  display:inline-flex;
  align-items:center;
  justify-content:flex-start;
  width:125px;
  margin-bottom:18px;
}

.madi-mobile-logo img{
  display:block;
  width:125px;
  height:60px;
  object-fit:contain;
}

@media (max-width:1024px){
  .madi-header .madi-brand__logo{
    width:112px;
    height:auto;
  }

  .madi-mobile-logo img{
    width:120px;
    height:auto;
  }
}

@media (max-width:767px){
  .madi-header .madi-brand__logo{
    width:104px;
    height:auto;
  }
}
/* =========================================================
   05. SHAPE SYSTEM
   ========================================================= */

/* Reset eventuali vecchie maschere applicate in override precedenti */
.madi-card,
.madi-category-card,
.madi-territory-property,
.madi-service,
.madi-sell,
.madi-sell__media,
.madi-territory-panel__image,
.madi-territory-panel__content,
.madi-story__mosaic img,
.madi-destination__media,
.madi-card__media,
.madi-category-card__media,
.madi-territory-property__media,
.madi-btn,
.madi-btn--ghost,
.madi-territory-tab,
.madi-slider__btn,
.madi-territory-tabs__nav{
  -webkit-mask-image:none !important;
  mask-image:none !important;
}

/* Shape vera solo sulla hero premium */
.madi-hero-premium__media{
  border-radius:var(--madi-hero-radius);
  overflow:hidden;
  -webkit-mask-image:var(--madi-hero-mask);
  mask-image:var(--madi-hero-mask);
  -webkit-mask-size:100% 100%;
  mask-size:100% 100%;
  -webkit-mask-repeat:no-repeat;
  mask-repeat:no-repeat;
  -webkit-mask-position:center;
  mask-position:center;
}

/* Card e pannelli: radius sobrio + piccolo taglio alto sinistro */
.madi-card,
.madi-category-card,
.madi-territory-property,
.madi-service,
.madi-territory-panel__content,
.madi-sell,
.madi-map-card,
.madi-map-results__panel,
.madi-press__item,
.madi-destination-index-card__media,
.madi-archive-card__media{
  border-radius:var(--madi-radius-lg);
  overflow:hidden;
  clip-path:polygon(
    var(--madi-card-cut) 0,
    100% 0,
    100% 100%,
    0 100%,
    0 var(--madi-card-cut)
  );
}

/* Media interni semplici */
.madi-card__media,
.madi-category-card__media,
.madi-territory-property__media,
.madi-destination__media,
.madi-sell__media,
.madi-map-card__media{
  border-radius:var(--madi-radius-md);
  overflow:hidden;
  clip-path:none;
}

/* Pill, tab e frecce semplici */
.madi-btn,
.madi-territory-tab,
.madi-map-tab,
.madi-slider__btn,
.madi-territory-tabs__nav,
.madi-burger,
.madi-social a,
.madi-archive-card__arrow,
.madi-archive-card__video-badge,
.madi-archive-pagination__item a,
.madi-archive-pagination__item span{
  border-radius:999px;
  clip-path:none;
}

/* =========================================================
   06. HEADER
   ========================================================= */

.madi-header{
  position:fixed;
  inset:0 0 auto 0;
  z-index:1000;
  height:var(--madi-header-h);
  background:rgba(255,255,255,.62);
  border-bottom:1px solid rgba(23,23,23,.10);
  backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);
  transition:
    background .28s var(--madi-ease),
    box-shadow .28s var(--madi-ease),
    border-color .28s var(--madi-ease),
    backdrop-filter .28s var(--madi-ease),
    -webkit-backdrop-filter .28s var(--madi-ease);
}

.madi-header.is-scrolled{
  background:rgba(255,255,255,.74);
  border-bottom-color:rgba(23,23,23,.12);
  box-shadow:0 8px 20px rgba(23,23,23,.05);
  backdrop-filter:blur(18px) saturate(145%);
  -webkit-backdrop-filter:blur(18px) saturate(145%);
}

.madi-header__row{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:28px;
  height:var(--madi-header-h);
}

.madi-header__left,
.madi-header__right{
  display:flex;
  align-items:center;
  min-width:0;
}

.madi-header__left{
  justify-content:flex-start;
}

.madi-header__center{
  display:flex;
  justify-content:center;
  align-items:center;
  min-width:0;
}

.madi-header__right{
  justify-content:flex-end;
}

.madi-nav{
  display:flex;
  align-items:center;
}

.madi-nav--right{
  justify-content:flex-end;
}

.madi-menu{
  display:flex;
  align-items:center;
  gap:34px;
  margin:0;
  padding:0;
  list-style:none;
}

.madi-menu li{
  margin:0;
  padding:0;
  line-height:1;
}

.madi-menu a{
  position:relative;
  display:inline-flex;
  align-items:center;
  min-height:20px;
  font-size:11px;
  line-height:1;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:#161616;
}

.madi-menu a::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-8px;
  height:1px;
  background:#161616;
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform .28s var(--madi-ease);
}

.madi-menu a:hover::after,
.madi-menu .current-menu-item > a::after,
.madi-menu .current_page_item > a::after{
  transform:scaleX(1);
}

.madi-brand{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  color:#161616;
  line-height:1;
}

.madi-brand__title{
  margin:0;
  font-size:30px;
  line-height:.92;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#161616;
}

.madi-brand__sub{
  display:block;
  margin-top:3px;
  font-size:9px;
  line-height:1;
  font-weight:700;
  letter-spacing:.26em;
  text-transform:uppercase;
  color:rgba(23,23,23,.58);
}

.madi-header__cta,
.madi-phone{
  display:none;
}

.madi-burger{
  display:none;
  width:42px;
  height:42px;
  border:1px solid rgba(23,23,23,.10);
  background:rgba(255,255,255,.52);
  color:#161616;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
}

.madi-burger span,
.madi-burger span::before,
.madi-burger span::after{
  display:block;
  width:18px;
  height:1px;
  background:currentColor;
  position:relative;
  transition:transform .3s var(--madi-ease), opacity .3s var(--madi-ease);
}

.madi-burger span::before,
.madi-burger span::after{
  content:"";
  position:absolute;
  left:0;
}

.madi-burger span::before{ top:-6px; }
.madi-burger span::after{ top:6px; }

.madi-mobile-panel{
  position:fixed;
  inset:0;
  z-index:999;
  background:rgba(255,255,255,.66);
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  transition:opacity .28s var(--madi-ease), visibility .28s var(--madi-ease);
}

.madi-mobile-panel.is-open{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}

.madi-mobile-panel__inner{
  width:min(92vw, 520px);
  height:100%;
  margin-left:auto;
  padding:96px 28px 28px;
  background:rgba(255,255,255,.82);
  box-shadow:-20px 0 50px rgba(23,23,23,.08);
  display:flex;
  flex-direction:column;
  gap:24px;
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
}

.madi-mobile-menu{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:16px;
}

.madi-mobile-menu a{
  font-size:30px;
  line-height:1;
  color:#161616;
}

.madi-mobile-meta{
  margin-top:auto;
  display:grid;
  gap:12px;
  font-size:14px;
}

.madi-mobile-meta a{
  color:#161616;
}

body.admin-bar .madi-header{
  top:32px;
}
.madi-property__icon-emoji{display:none!important}
/* =========================================================
   MENU HEADER — più sottile e premium
   ========================================================= */

.madi-menu{
  gap:38px;
}

.madi-menu a{
  font-size:10px;
  font-weight:500;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(23,23,23,.78);
}

.madi-menu a::after{
  bottom:-10px;
  height:1px;
  background:rgba(23,23,23,.55);
  opacity:.75;
}

.madi-menu a:hover,
.madi-menu .current-menu-item > a,
.madi-menu .current_page_item > a{
  color:rgba(23,23,23,1);
}

.madi-header.is-scrolled .madi-menu a{
  color:rgba(23,23,23,.82);
}

/* Mobile menu più elegante */
.madi-mobile-menu{
  gap:18px;
}

.madi-mobile-menu a{
  font-size:28px;
  font-weight:300;
  letter-spacing:-.045em;
  color:rgba(23,23,23,.88);
}

.madi-mobile-menu a:hover{
  color:var(--madi-text);
}

@media (max-width:1200px){
  .madi-menu{
    gap:28px;
  }

  .madi-menu a{
    font-size:9px;
    letter-spacing:.2em;
  }
}
/* =========================================================
   07. HERO LEGACY / REAL ESTATE
   ========================================================= */

.madi-hero{
  position:relative;
  min-height:100svh;
  display:flex;
  align-items:center;
  overflow:hidden;
  background:var(--madi-text);
}

.madi-hero__media{
  position:absolute;
  inset:0;
}

.madi-hero__media::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(to bottom, rgba(0,0,0,.18), rgba(0,0,0,.18) 24%, rgba(0,0,0,.38) 72%, rgba(0,0,0,.52)),
    linear-gradient(to right, rgba(0,0,0,.12), transparent 35%, transparent 65%, rgba(0,0,0,.12));
}

.madi-hero__media img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.madi-hero__inner{
  position:relative;
  z-index:2;
  width:100%;
  padding:160px 0 72px;
  color:#fff;
}

.madi-hero__content{
  max-width:820px;
  margin-inline:auto;
  text-align:center;
}

.madi-hero .madi-eyebrow,
.madi-hero .madi-text,
.madi-hero .madi-title{
  color:#fff;
}

.madi-hero--real-estate{
  align-items:flex-end;
  background:#171717;
}

.madi-hero--real-estate .madi-hero__media::after{
  background:
    linear-gradient(to bottom, rgba(0,0,0,.28), rgba(0,0,0,.22) 30%, rgba(0,0,0,.62)),
    linear-gradient(to right, rgba(0,0,0,.64), rgba(0,0,0,.24) 48%, rgba(0,0,0,.38));
}

.madi-hero--real-estate .madi-hero__inner{
  padding:170px 0 86px;
}

.madi-hero__grid{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(320px, 420px);
  gap:56px;
  align-items:end;
}

.madi-hero--real-estate .madi-hero__content{
  max-width:820px;
  margin:0;
  text-align:left;
}

.madi-hero--real-estate .madi-title{
  max-width:820px;
}

.madi-hero--real-estate .madi-text{
  max-width:660px;
  color:rgba(255,255,255,.82);
}

.madi-hero--real-estate .madi-eyebrow{
  color:rgba(255,255,255,.74);
}

.madi-hero__actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:30px;
}

.madi-hero-panel{
  padding:28px;
  background:rgba(255,255,255,.88);
  border:1px solid rgba(255,255,255,.34);
  box-shadow:0 24px 70px rgba(0,0,0,.18);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
}

.madi-hero-panel__label{
  display:block;
  margin-bottom:14px;
  font-size:10px;
  line-height:1;
  letter-spacing:.2em;
  text-transform:uppercase;
  font-weight:800;
  color:rgba(23,23,23,.58);
}

.madi-hero-panel__title{
  margin:0 0 22px;
  font-family:var(--madi-display);
  font-size:clamp(24px, 2vw, 34px);
  font-weight:350;
  line-height:1.05;
  letter-spacing:-.055em;
  color:#171717;
}

.madi-hero-panel__list{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:0;
  border-top:1px solid rgba(23,23,23,.10);
}

.madi-hero-panel__list li{
  position:relative;
  padding:14px 0 14px 28px;
  border-bottom:1px solid rgba(23,23,23,.10);
  font-size:13px;
  line-height:1.45;
  color:rgba(23,23,23,.76);
}

.madi-hero-panel__list li::before{
  content:"";
  position:absolute;
  left:0;
  top:20px;
  width:10px;
  height:10px;
  border:1px solid var(--madi-accent);
}

/* Vecchia ricerca nascosta nella nuova home */
.madi-search{
  display:none !important;
}

/* =========================================================
   08. HERO PREMIUM EDITORIALE
   ========================================================= */

.madi-hero-premium{
  position:relative;
  padding:148px 0 34px;
  background:#f5f1ea;
  overflow:hidden;
}

.madi-hero-premium::before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:42%;
  background:linear-gradient(to bottom, rgba(255,255,255,.58), rgba(255,255,255,0));
  pointer-events:none;
}

.madi-hero-premium .madi-container{
  position:relative;
  z-index:1;
}

.madi-hero-premium__top{
  display:grid;
  grid-template-columns:minmax(0, 1.45fr) minmax(320px, .8fr);
  gap:40px;
  align-items:start;
  margin-bottom:34px;
}

.madi-hero-premium__title{
  margin:0;
  max-width:880px;
  font-family:var(--madi-display);
  font-weight:320;
  font-size:clamp(52px, 6.15vw, 98px);
  line-height:.92;
  letter-spacing:-.072em;
  color:var(--madi-text);
}

.madi-hero-premium__side{
  display:grid;
  gap:22px;
  padding-top:12px;
  max-width:440px;
  margin-left:auto;
}

.madi-hero-premium__text{
  font-size:14px;
  line-height:1.78;
  color:rgba(23,23,23,.72);
}

.madi-hero-premium__actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}

.madi-hero-premium__media{
  position:relative;
  background:#ddd;
  box-shadow:0 26px 70px rgba(23,23,23,.10);
}

.madi-hero-premium__media::before{
  content:"";
  position:absolute;
  z-index:2;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(to bottom, rgba(0,0,0,0), rgba(0,0,0,.08)),
    linear-gradient(to right, rgba(0,0,0,.10), rgba(0,0,0,0) 42%, rgba(0,0,0,.08));
}

.madi-hero-premium__media img{
  width:100%;
  height:clamp(380px, 48vw, 640px);
  object-fit:cover;
  transform:scale(1.001);
}

/* =========================================================
   09. HEADLINE
   ========================================================= */

.madi-headline{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:20px;
  margin-bottom:28px;
}

/* =========================================================
   10. CARDS GLOBALI
   ========================================================= */

.madi-card,
.madi-card__anchor{
  display:block;
}

.madi-card{
  position:relative;
  background:#fff;
  border:1px solid var(--madi-border-soft);
  box-shadow:none;
  transition:
    transform .35s var(--madi-ease),
    box-shadow .35s var(--madi-ease);
}

.madi-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--madi-shadow-soft);
}

.madi-card__media{
  position:relative;
  background:#ddd;
  aspect-ratio:4 / 5.3;
}

.madi-card__media.is-wide,
.madi-card__media--wide,
.madi-card--wide .madi-card__media,
.madi-card.is-wide .madi-card__media{
  aspect-ratio:16 / 9;
}

.madi-card__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .7s var(--madi-ease);
}

.madi-card:hover .madi-card__media img{
  transform:scale(1.05);
}

.madi-card__badge{
  position:absolute;
  left:14px;
  top:14px;
  z-index:2;
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:0 12px;
  border-radius:999px;
  background:rgba(57,72,77,.92);
  color:#fff;
  font-size:10px;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
}

.madi-card__body{
  padding:16px 16px 15px;
}

.madi-card__top{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:14px;
  margin-bottom:8px;
}

.madi-card__title{
  margin:0;
  font-size:19px;
  line-height:1.08;
  text-transform:none;
}

.madi-card__price{
  flex:0 0 auto;
  font-size:11px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--madi-accent-dark);
  white-space:nowrap;
}

.madi-card__meta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  font-size:11px;
  color:rgba(23,23,23,.62);
}

.madi-card__meta span{
  position:relative;
}

.madi-card__meta span + span::before{
  content:"";
  display:inline-block;
  width:4px;
  height:4px;
  margin:0 9px 2px 0;
  background:rgba(23,23,23,.35);
}

/* =========================================================
   11. HOME — PROPOSTE
   ========================================================= */

.madi-proposals{
  display:grid;
  grid-template-columns:repeat(5, minmax(0, 1fr));
  gap:16px;
  align-items:start;
}

/* =========================================================
   12. TERRITORIO PREMIUM
   ========================================================= */

.madi-territory{
  padding-top:84px;
}

.madi-territory__head{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(320px, 470px);
  gap:28px;
  align-items:end;
  margin-bottom:24px;
}

.madi-territory__intro{
  max-width:460px;
  margin-left:auto;
}

.madi-territory-tabs-wrap{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:12px;
  align-items:center;
  margin-bottom:26px;
  padding:10px 12px;
  background:rgba(255,255,255,.62);
  border:1px solid var(--madi-border-soft);
  border-radius:999px;
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}

.madi-territory-tabs{
  display:flex;
  gap:12px;
  overflow-x:auto;
  overflow-y:hidden;
  scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
  scroll-behavior:smooth;
  padding:1px;
}

.madi-territory-tabs::-webkit-scrollbar{
  display:none;
}

.madi-territory-tabs__nav{
  width:42px;
  height:42px;
  border:1px solid var(--madi-border);
  background:#fff;
  color:var(--madi-text);
  cursor:pointer;
  transition:
    transform .3s var(--madi-ease),
    background .3s var(--madi-ease),
    border-color .3s var(--madi-ease);
}

.madi-territory-tabs__nav:hover{
  transform:translateY(-1px);
  background:#f0ebe4;
  border-color:rgba(23,23,23,.2);
}

.madi-territory-tab{
  flex:0 0 auto;
  min-height:44px;
  padding:0 18px;
  border:1px solid rgba(23,23,23,.10);
  background:rgba(255,255,255,.86);
  color:var(--madi-text);
  cursor:pointer;
  font-size:11px;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
  white-space:nowrap;
  transition:
    background .25s var(--madi-ease),
    color .25s var(--madi-ease),
    border-color .25s var(--madi-ease),
    transform .25s var(--madi-ease);
}

.madi-territory-tab:hover,
.madi-territory-tab.is-active{
  background:var(--madi-text);
  color:#fff;
  border-color:var(--madi-text);
}

.madi-territory-stage{
  position:relative;
}

.madi-territory-panel{
  display:none;
}

.madi-territory-panel.is-active{
  display:block;
}

.madi-territory-panel__grid{
  display:grid;
  grid-template-columns:minmax(0, 1.08fr) minmax(380px, .92fr);
  gap:24px;
  align-items:start;
}

.madi-territory-panel__visual{
  min-width:0;
}

.madi-territory-panel__image{
  position:relative;
  min-height:640px;
  background:#ddd;
  overflow:hidden;
  box-shadow:0 30px 70px rgba(23,23,23,.10);
}

.madi-territory-panel__image img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
}

.madi-territory-panel__overlay{
  position:absolute;
  inset:auto 0 0 0;
  z-index:2;
  padding:28px;
  background:linear-gradient(to top, rgba(0,0,0,.44), rgba(0,0,0,0));
  color:#fff;
}

.madi-territory-panel__overlay .madi-eyebrow{
  color:rgba(255,255,255,.8);
  margin-bottom:8px;
}

.madi-territory-panel__overlay h3{
  margin:0;
  font-family:var(--madi-display);
  font-size:38px;
  line-height:.95;
  font-weight:350;
  letter-spacing:-.05em;
  color:#fff;
}

.madi-territory-panel__content{
  min-height:640px;
  display:flex;
  flex-direction:column;
  padding:26px;
  background:rgba(255,255,255,.88);
  border:1px solid var(--madi-border-soft);
}

.madi-territory-panel__top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:20px;
  margin-bottom:12px;
}

.madi-territory-panel__top .madi-title{
  margin-bottom:0;
}

.madi-territory-properties{
  display:grid;
  gap:14px;
  margin-top:22px;
}

.madi-territory-property{
  display:grid;
  grid-template-columns:140px 1fr;
  gap:16px;
  align-items:stretch;
  background:#fff;
  border:1px solid var(--madi-border-soft);
  transition:
    transform .35s var(--madi-ease),
    box-shadow .35s var(--madi-ease);
}

.madi-territory-property:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 30px rgba(23,23,23,.06);
}

.madi-territory-property__media{
  min-height:128px;
  background:#ddd;
}

.madi-territory-property__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .7s var(--madi-ease);
}

.madi-territory-property:hover .madi-territory-property__media img{
  transform:scale(1.04);
}

.madi-territory-property__body{
  padding:14px 14px 14px 0;
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.madi-territory-property__body h4{
  margin:0 0 8px;
  font-family:var(--madi-display);
  font-size:22px;
  line-height:1.02;
  font-weight:400;
  letter-spacing:-.04em;
}

.madi-territory-property__meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  font-size:11px;
  color:rgba(23,23,23,.68);
}

.madi-territory-property__meta span + span::before{
  content:"";
  display:inline-block;
  width:4px;
  height:4px;
  margin:0 8px 2px 0;
  background:rgba(23,23,23,.32);
}

.madi-territory-property__price{
  margin-top:10px;
  font-size:11px;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--madi-text);
}

/* =========================================================
   13. LOCALITÀ A TAB — LEGACY COMPAT
   ========================================================= */

.madi-map-layout{
  display:grid;
  grid-template-columns:340px 1fr;
  gap:32px;
  align-items:start;
}

.madi-map-copy{
  position:sticky;
  top:120px;
}

.madi-map-tabs{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:22px;
}

.madi-map-tab{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:40px;
  padding:0 16px;
  border:1px solid var(--madi-border);
  background:rgba(255,255,255,.72);
  color:var(--madi-text);
  cursor:pointer;
  font-size:11px;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
  transition:
    background .25s var(--madi-ease),
    color .25s var(--madi-ease),
    border-color .25s var(--madi-ease),
    transform .25s var(--madi-ease);
}

.madi-map-tab:hover,
.madi-map-tab.is-active{
  background:var(--madi-accent-dark);
  color:#fff;
  border-color:var(--madi-accent-dark);
}

.madi-map-stage{
  display:grid;
  gap:18px;
}

.madi-map-visual{
  position:relative;
  min-height:560px;
  background:#ddd;
  overflow:hidden;
  box-shadow:var(--madi-shadow-soft);
}

.madi-map-visual__panel{
  position:absolute;
  inset:0;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:
    opacity .35s var(--madi-ease),
    visibility .35s var(--madi-ease);
}

.madi-map-visual__panel.is-active{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}

.madi-map-visual__panel img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.madi-map-visual__overlay{
  position:absolute;
  inset:0;
  display:flex;
  align-items:flex-end;
  padding:28px;
  background:linear-gradient(to top, rgba(0,0,0,.34), rgba(0,0,0,0));
}

.madi-map-visual__caption{
  color:#fff;
}

.madi-map-visual__caption .madi-eyebrow{
  color:rgba(255,255,255,.82);
  margin-bottom:8px;
}

.madi-map-visual__caption h3{
  margin:0;
  font-family:var(--madi-display);
  font-size:38px;
  font-weight:350;
  line-height:.95;
  color:#fff;
}

.madi-map-results{
  position:relative;
}

.madi-map-results__panel{
  display:none;
  background:rgba(255,255,255,.82);
  border:1px solid var(--madi-border-soft);
  padding:18px;
}

.madi-map-results__panel.is-active{
  display:block;
}

.madi-map-results__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  margin-bottom:16px;
}

.madi-map-results__grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:14px;
}

.madi-map-card{
  display:block;
  background:#fff;
  border:1px solid var(--madi-border-soft);
  transition:
    transform .35s var(--madi-ease),
    box-shadow .35s var(--madi-ease);
}

.madi-map-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--madi-shadow-soft);
}

.madi-map-card__media{
  aspect-ratio:16/10;
  background:#ddd;
}

.madi-map-card__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .7s var(--madi-ease);
}

.madi-map-card:hover .madi-map-card__media img{
  transform:scale(1.05);
}

.madi-map-card__body{
  padding:12px;
}

.madi-map-card__body h4{
  margin:0 0 6px;
  font-size:19px;
  line-height:1.1;
}

.madi-map-card__meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  font-size:11px;
  color:rgba(23,23,23,.7);
}

.madi-map-card__price{
  margin-top:8px;
  font-size:12px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--madi-accent-dark);
}

/* =========================================================
   14. CATEGORIE
   ========================================================= */

.madi-categories-intro{
  text-align:center;
  max-width:760px;
  margin:0 auto 28px;
}

.madi-category-cards{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:18px;
}

.madi-category-card{
  display:block;
  background:#fff;
  border:1px solid var(--madi-border-soft);
  box-shadow:var(--madi-shadow-soft);
  transition:
    transform .35s var(--madi-ease),
    box-shadow .35s var(--madi-ease);
}

.madi-category-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--madi-shadow);
}

.madi-category-card__media{
  aspect-ratio:16/10;
  background:#ddd;
}

.madi-category-card__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .7s var(--madi-ease);
}

.madi-category-card:hover .madi-category-card__media img{
  transform:scale(1.05);
}

.madi-category-card__body{
  padding:18px;
}

.madi-category-card__body h3{
  margin:0 0 10px;
  font-size:25px;
  line-height:1.08;
}

.madi-category-card__body p{
  margin:0;
  font-size:14px;
  line-height:1.8;
  color:rgba(23,23,23,.70);
}

/* =========================================================
   15. SLIDER
   ========================================================= */

.madi-slider{
  position:relative;
}

.madi-slider__nav{
  display:flex;
  gap:10px;
  justify-content:flex-end;
  margin-bottom:14px;
}

.madi-slider__btn{
  width:40px;
  height:40px;
  border:1px solid var(--madi-border);
  background:transparent;
  color:var(--madi-text);
  cursor:pointer;
  transition:
    transform .3s var(--madi-ease),
    background .3s var(--madi-ease);
}

.madi-slider__btn:hover{
  transform:translateY(-2px);
  background:rgba(111,133,142,.08);
}

.madi-slider__track{
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:minmax(420px, 34vw);
  gap:18px;
  overflow:auto;
  scroll-snap-type:x mandatory;
  padding-bottom:10px;
  scrollbar-width:none;
}

.madi-slider__track::-webkit-scrollbar{
  display:none;
}

.madi-slider__track > *{
  scroll-snap-align:start;
}

/* =========================================================
   16. SELL
   ========================================================= */

.madi-sell{
  display:grid;
  grid-template-columns:52% 48%;
  align-items:stretch;
  background:#DDD2C4;
  border:1px solid var(--madi-border-soft);
  box-shadow:var(--madi-shadow-soft);
}

.madi-sell__media{
  min-height:300px;
}

.madi-sell__media img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.madi-sell__content{
  padding:52px 56px;
  display:flex;
  align-items:center;
  text-align:left;
}

.madi-sell__content .madi-copy{
  max-width:520px;
  margin-inline:0;
}

.madi-sell .madi-title,
.madi-sell .madi-text{
  max-width:520px;
}

/* =========================================================
   17. STORY / AGENZIA
   ========================================================= */

.madi-story{
  display:grid;
  grid-template-columns:36% 64%;
  gap:44px;
  align-items:center;
}

.madi-story .madi-copy{
  max-width:430px;
}

.madi-story__mosaic{
  display:grid !important;
  grid-template-columns:repeat(3, minmax(0, 1fr)) !important;
  gap:18px !important;
  align-items:end;
  min-height:560px;
}

/*
  Immagini intere, affiancate, a quote diverse:
  - prima centrata
  - seconda margin-bottom 50
  - terza margin-bottom 25
*/
.madi-story__mosaic img{
  width:100%;
  height:420px;
  object-fit:contain;
  object-position:center center;
  background:#e9e1d6;
  padding:8px;
  border-radius:var(--madi-radius-lg);
  box-shadow:0 20px 50px rgba(23,23,23,.08);
  clip-path:polygon(
    var(--madi-card-cut) 0,
    100% 0,
    100% 100%,
    0 100%,
    0 var(--madi-card-cut)
  );
  filter:saturate(.94) contrast(1.02);
}

.madi-story__mosaic img:nth-child(1){
  align-self:center;
  margin-bottom:0;
  transform:none !important;
}

.madi-story__mosaic img:nth-child(2){
  align-self:end;
  margin-bottom:50px;
  transform:none !important;
}

.madi-story__mosaic img:nth-child(3){
  align-self:end;
  margin-bottom:25px;
  transform:none !important;
}

/* =========================================================
   18. DESTINAZIONI
   ========================================================= */

.madi-destinations{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:20px 22px;
}

.madi-destination{
  display:block;
}

.madi-destination__media{
  aspect-ratio:16 / 8;
  margin-bottom:10px;
  background:#ddd;
}

.madi-destination__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .8s var(--madi-ease);
}

.madi-destination:hover .madi-destination__media img{
  transform:scale(1.05);
}

.madi-destination__title{
  margin:0 0 4px;
  font-size:18px;
  line-height:1;
  letter-spacing:.04em;
  text-transform:uppercase;
}

.madi-destination__count{
  font-size:11px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(23,23,23,.58);
}

/* =========================================================
   19. PRESS
   ========================================================= */

.madi-press{
  display:grid !important;
  grid-auto-flow:column;
  grid-auto-columns:280px;
  gap:16px;
  width:100vw;
  max-width:100vw;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
  padding:0 24px 10px;
  overflow-x:auto;
  overflow-y:hidden;
  align-items:stretch;
  text-align:center;
  scrollbar-width:thin;
  -webkit-overflow-scrolling:touch;
}

.madi-press::-webkit-scrollbar{
  height:8px;
}

.madi-press::-webkit-scrollbar-thumb{
  background:rgba(23,23,23,.18);
  border-radius:999px;
}

.madi-press__item{
  min-height:116px;
  background:#fff;
  border:1px solid var(--madi-border-soft);
  box-shadow:var(--madi-shadow-soft);
  padding:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  font-size:20px;
  font-weight:700;
  opacity:1;
}

.madi-press__item a{
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
}

.madi-press__item img{
  display:block;
  width:auto;
  max-width:100%;
  max-height:64px;
  object-fit:contain;
  margin:0 auto;
}

/* =========================================================
   20. SERVIZI
   ========================================================= */

.madi-services{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:18px;
}

.madi-service{
  background:#fff;
  border:1px solid var(--madi-border-soft);
  box-shadow:var(--madi-shadow-soft);
  text-align:left;
  padding:26px 22px;
}

.madi-service__icon{
  width:auto;
  height:auto;
  border:none;
  border-radius:0;
  display:block;
  margin:0 0 22px;
  font-size:11px;
  font-weight:800;
  letter-spacing:.18em;
  color:var(--madi-accent-dark);
}

.madi-service__title{
  margin:0 0 10px;
  font-size:22px;
  line-height:1.08;
  text-transform:none;
}

.madi-service__text{
  margin:0;
  font-size:13px;
  line-height:1.75;
  color:rgba(23,23,23,.68);
}

/* =========================================================
   21. FOOTER
   ========================================================= */

.madi-footer{
  background:#f0ebe4;
  border-top:1px solid var(--madi-border-soft);
}

.madi-footer__grid{
  display:grid;
  grid-template-columns:1.1fr .8fr .8fr 1fr;
  gap:26px;
  padding:42px 0 22px;
}

.madi-footer__brand .madi-brand{
  align-items:flex-start;
  text-align:left;
}

.madi-footer__title{
  margin:0 0 14px;
  font-size:10px;
  font-weight:800;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:rgba(23,23,23,.6);
}

.madi-footer__menu{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:8px;
}

.madi-footer__menu a,
.madi-footer .madi-stack a,
.madi-footer .madi-stack span{
  font-size:13px;
  line-height:1.4;
}

.madi-footer__bottom{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:20px;
  padding:14px 0 24px;
  border-top:1px solid var(--madi-border-soft);
  font-size:11px;
  color:rgba(23,23,23,.66);
}

.madi-social{
  display:flex;
  gap:12px;
}

.madi-social a{
  width:34px;
  height:34px;
  border:1px solid rgba(23,23,23,.14);
  display:grid;
  place-items:center;
}

/* =========================================================
   22. ARCHIVE AJAX SHELL
   ========================================================= */

[data-madi-archive-results-shell]{
  transition:opacity .25s ease;
}

[data-madi-archive-results-shell].is-loading{
  opacity:.55;
  pointer-events:none;
}

/* =========================================================
   23. DESTINATION INDEX
   ========================================================= */

.madi-destination-index-hero{
  padding:56px 0 14px;
}

.madi-destination-index-hero__content{
  max-width:760px;
}

.madi-destination-index-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:24px;
}

.madi-destination-index-card__link{
  display:block;
}

.madi-destination-index-card__media{
  aspect-ratio:16/10;
  overflow:hidden;
  background:#ddd;
}

.madi-destination-index-card__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .7s var(--madi-ease);
}

.madi-destination-index-card:hover .madi-destination-index-card__media img{
  transform:scale(1.04);
}

.madi-destination-index-card__body{
  padding:14px 0 0;
}

.madi-destination-index-card__title{
  margin:0 0 8px;
  font-size:28px;
  line-height:1;
}

.madi-destination-index-card__text{
  margin:0 0 8px;
  font-size:14px;
  line-height:1.8;
  color:rgba(23,23,23,.76);
}

.madi-destination-index-card__meta{
  font-size:11px;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:rgba(23,23,23,.58);
}

/* =========================================================
   24. ARCHIVE IMMOBILI
   ========================================================= */

.madi-archive-cover{
  position:relative;
  min-height:420px;
  display:flex;
  align-items:flex-end;
  overflow:hidden;
  background:var(--madi-text);
}

.madi-archive-cover__media{
  position:absolute;
  inset:0;
}

.madi-archive-cover__media::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to bottom, rgba(0,0,0,.18), rgba(0,0,0,.52));
}

.madi-archive-cover__media img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.madi-archive-cover__content{
  position:relative;
  z-index:2;
  max-width:760px;
  padding:160px 0 52px;
  color:#fff;
}

.madi-archive-cover .madi-eyebrow,
.madi-archive-cover .madi-text,
.madi-archive-cover .madi-title{
  color:#fff;
}

.madi-archive-toolbar{
  position:relative;
  padding:26px 0 18px;
  background:var(--madi-bg);
  border-bottom:1px solid var(--madi-border-soft);
}

.madi-archive-filters{
  display:grid;
  gap:16px;
}

.madi-archive-filters__grid{
  display:grid;
  grid-template-columns:1.1fr 1.1fr .8fr .9fr auto;
  gap:14px;
  align-items:end;
}

.madi-archive-field{
  display:grid;
  gap:6px;
}

.madi-archive-field label{
  font-size:9px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(23,23,23,.72);
}

.madi-archive-field select{
  min-height:46px;
  width:100%;
  padding:0 12px;
  border:none;
  border-bottom:1px solid rgba(23,23,23,.18);
  background:transparent;
  color:var(--madi-text);
  outline:none;
}

.madi-archive-field select:disabled{
  opacity:.55;
}

.madi-archive-toolbar__bottom{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:20px;
}

.madi-archive-count{
  font-size:11px;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:rgba(23,23,23,.62);
}

.madi-archive-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:28px 24px;
}

.madi-archive-card{
  position:relative;
}

.madi-archive-card__media{
  position:relative;
  overflow:hidden;
  background:#ddd;
}

.madi-archive-card__media-link{
  display:block;
}

.madi-archive-card__track{
  position:relative;
  aspect-ratio:16/10.2;
}

.madi-archive-card__slide{
  position:absolute;
  inset:0;
  opacity:0;
  pointer-events:none;
  transition:opacity .35s ease;
}

.madi-archive-card__slide.is-active{
  opacity:1;
  pointer-events:auto;
}

.madi-archive-card__slide img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.madi-archive-card__video-badge{
  position:absolute;
  right:14px;
  bottom:14px;
  width:36px;
  height:36px;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,.9);
  color:var(--madi-text);
  font-size:14px;
}

.madi-archive-card__pill{
  position:absolute;
  left:14px;
  top:14px;
  z-index:3;
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:0 12px;
  border-radius:999px;
  background:rgba(57,72,77,.92);
  color:#fff;
  font-size:10px;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
}

.madi-archive-card__arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  z-index:4;
  width:34px;
  height:34px;
  border:none;
  background:rgba(255,255,255,.86);
  color:var(--madi-text);
  cursor:pointer;
  display:grid;
  place-items:center;
  font-size:20px;
  line-height:1;
}

.madi-archive-card__arrow.is-prev{
  left:12px;
}

.madi-archive-card__arrow.is-next{
  right:12px;
}

.madi-archive-card__body{
  padding:12px 0 10px;
  border-bottom:1px solid rgba(23,23,23,.16);
}

.madi-archive-card__topline{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:20px;
}

.madi-archive-card__title{
  margin:0;
  font-size:18px;
  line-height:1;
  text-transform:uppercase;
}

.madi-archive-card__title a{
  color:var(--madi-text);
}

.madi-archive-card__price{
  flex-shrink:0;
  font-size:11px;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:rgba(23,23,23,.72);
}

.madi-archive-card__meta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:8px;
  font-size:11px;
  color:rgba(23,23,23,.7);
}

.madi-archive-pagination{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:8px;
  margin-top:38px;
}

.madi-archive-pagination__item a,
.madi-archive-pagination__item span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:34px;
  height:34px;
  padding:0 10px;
  border:1px solid var(--madi-border);
  font-size:12px;
  color:var(--madi-text);
}

.madi-archive-pagination .current{
  background:var(--madi-accent-dark);
  color:#fff;
  border-color:var(--madi-accent-dark);
}

.madi-archive-empty{
  text-align:center;
  padding:80px 20px;
  font-size:15px;
  color:rgba(23,23,23,.72);
}

/* =========================================================
   25. FORM
   ========================================================= */

form.fluent_form_1 .ff-btn-submit:not(.ff_btn_no_style){
  background-color:var(--madi-accent-dark) !important;
  color:#ffffff !important;
  border-radius:999px !important;
}

/* =========================================================
   26. RESPONSIVE
   ========================================================= */

@media (max-width:1200px){
  .madi-menu{
    gap:24px;
  }

  .madi-proposals{
    grid-template-columns:repeat(3, minmax(0, 1fr));
  }

  .madi-slider__track{
    grid-auto-columns:minmax(360px, 52vw);
  }
}

@media (max-width:1199px){
  .madi-container,
  .madi-container--narrow{
    width:min(calc(100% - 36px), var(--madi-container));
  }

  .madi-hero-premium__top,
  .madi-territory__head,
  .madi-territory-panel__grid,
  .madi-map-layout{
    grid-template-columns:1fr;
  }

  .madi-hero-premium__side,
  .madi-territory__intro{
    max-width:none;
    margin-left:0;
  }

  .madi-map-copy{
    position:static;
  }

  .madi-territory-panel__image,
  .madi-territory-panel__content{
    min-height:auto;
  }

  .madi-territory-panel__image{
    aspect-ratio:16/10;
  }

  .madi-map-results__grid,
  .madi-category-cards{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  .madi-story{
    grid-template-columns:1fr;
    gap:30px;
  }

  .madi-story .madi-copy{
    max-width:100%;
  }

  .madi-story__mosaic{
    min-height:auto;
  }

  .madi-story__mosaic img{
    height:360px;
  }
}

@media (max-width:1024px){
  .madi-header{
    height:var(--madi-header-h-mobile);
  }

  .madi-header__row{
    grid-template-columns:auto 1fr auto;
    height:var(--madi-header-h-mobile);
    gap:18px;
  }

  .madi-header__left .madi-nav,
  .madi-header__right .madi-nav{
    display:none;
  }

  .madi-header__center{
    justify-content:flex-start;
  }

  .madi-brand{
    align-items:flex-start;
    text-align:left;
  }

  .madi-brand__title{
    font-size:24px;
  }

  .madi-brand__sub{
    font-size:8px;
    margin-top:3px;
  }

  .madi-burger{
    display:inline-flex;
    justify-self:end;
  }

  .madi-hero__grid{
    grid-template-columns:1fr;
    gap:32px;
  }

  .madi-hero-panel{
    max-width:560px;
  }

  .madi-hero--real-estate .madi-hero__inner{
    padding:142px 0 54px;
  }

  .madi-sell,
  .madi-story{
    grid-template-columns:1fr;
  }

  .madi-sell__content{
    padding:42px 32px;
  }

  .madi-proposals,
  .madi-categories,
  .madi-destinations,
  .madi-services,
  .madi-footer__grid,
  .madi-destination-index-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  .madi-services{
    gap:14px;
  }

  .madi-press{
    grid-auto-columns:220px;
    gap:14px;
    padding:0 18px 10px;
  }

  .madi-press__item{
    min-height:100px;
    padding:16px;
  }

  .madi-press__item img{
    max-height:54px;
  }

  .madi-archive-filters__grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  .madi-archive-grid{
    grid-template-columns:1fr;
  }
}

@media (max-width:767px){
  :root{
    --madi-sec:62px;
    --madi-sec-tight:52px;
    --madi-card-cut:16px;
    --madi-radius-lg:18px;
    --madi-radius-md:16px;
    --madi-hero-radius:20px;
  }

  .madi-container,
  .madi-container--narrow{
    width:min(calc(100% - 24px), var(--madi-container));
  }

  .madi-title--xl{
    font-size:clamp(42px, 13vw, 58px);
    letter-spacing:-.065em;
  }

  .madi-hero__inner{
    padding:132px 0 34px;
  }

  .madi-hero--real-estate{
    min-height:100svh;
  }

  .madi-hero--real-estate .madi-hero__inner{
    padding:126px 0 34px;
  }

  .madi-hero__grid{
    gap:24px;
  }

  .madi-hero__actions,
  .madi-hero-premium__actions{
    display:grid;
    grid-template-columns:1fr;
    gap:10px;
    margin-top:24px;
  }

  .madi-hero__actions .madi-btn,
  .madi-hero-premium__actions .madi-btn{
    width:100%;
  }

  .madi-hero-panel{
    padding:22px;
  }

  .madi-hero-panel__title{
    font-size:25px;
  }

  .madi-hero-panel__list li{
    font-size:12px;
  }

  .madi-hero-premium{
    padding:126px 0 22px;
  }

  .madi-hero-premium__top{
    gap:22px;
    margin-bottom:20px;
  }

  .madi-hero-premium__title{
    font-size:clamp(42px, 12vw, 58px);
    letter-spacing:-.065em;
  }

  .madi-hero-premium__media img{
    height:300px;
  }

  .madi-headline{
    flex-direction:column;
    align-items:flex-start;
  }

  .madi-proposals,
  .madi-category-cards,
  .madi-destinations,
  .madi-services,
  .madi-footer__grid,
  .madi-map-results__grid,
  .madi-destination-index-grid{
    grid-template-columns:1fr;
  }

  .madi-proposals{
    gap:14px;
  }

  .madi-card__media{
    aspect-ratio:4 / 4.9;
  }

  .madi-card__top,
  .madi-archive-card__topline{
    flex-direction:column;
    align-items:flex-start;
    gap:8px;
  }

  .madi-card__price{
    white-space:normal;
  }

  .madi-territory-tabs-wrap{
    grid-template-columns:1fr;
    border-radius:24px;
    padding:10px;
  }

  .madi-territory-tabs__nav{
    display:none;
  }

  .madi-territory-panel__image{
    min-height:340px;
    aspect-ratio:auto;
  }

  .madi-territory-panel__content{
    padding:18px;
  }

  .madi-territory-panel__top,
  .madi-map-results__head{
    flex-direction:column;
    align-items:flex-start;
  }

  .madi-territory-property,
  .madi-territory-property--empty{
    grid-template-columns:1fr;
  }

  .madi-territory-property__media{
    min-height:180px;
  }

  .madi-territory-property__body{
    padding:14px;
  }

  .madi-map-visual{
    min-height:340px;
  }

  .madi-sell__content,
  .madi-split__content{
    padding:32px 22px;
  }

  .madi-split__media,
  .madi-sell__media{
    min-height:260px;
  }

  .madi-slider__track{
    grid-auto-columns:84vw;
  }

  .madi-story{
    gap:24px;
  }

  .madi-story__mosaic{
    grid-template-columns:1fr !important;
    gap:14px !important;
  }

  .madi-story__mosaic img{
    height:300px;
    margin-bottom:0 !important;
    align-self:stretch !important;
  }

  .madi-category-card__body h3{
    font-size:24px;
  }

  .madi-map-card__body h4{
    font-size:20px;
  }

  .madi-press{
    grid-auto-columns:180px;
    gap:12px;
    padding:0 14px 10px;
  }

  .madi-press__item{
    min-height:86px;
    padding:14px;
  }

  .madi-press__item img{
    max-height:42px;
  }

  .madi-footer__bottom{
    flex-direction:column;
    align-items:flex-start;
  }

  .madi-mobile-menu a{
    font-size:26px;
  }

  .madi-archive-cover{
    min-height:320px;
  }

  .madi-archive-cover__content{
    padding:132px 0 34px;
  }

  .madi-archive-filters__grid{
    grid-template-columns:1fr;
  }

  .madi-archive-toolbar__bottom{
    flex-direction:column;
    align-items:flex-start;
  }

  .madi-archive-card__track{
    aspect-ratio:4/3.15;
  }

  body.admin-bar .madi-header{
    top:46px;
  }
}
.madi-story__mosaic img
 {
    width: 100%;
    height: 420px;
    object-fit: cover;
    object-position: center center;
    background: transparent;
    padding: 8px;
    border-radius: var(--madi-radius-lg);
    box-shadow: none;
    clip-path: polygon(var(--madi-card-cut) 0, 100% 0, 100% 100%, 0 100%, 0 var(--madi-card-cut));
    filter: none;
}
.madi-sell-page-split__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: left center;}

.madi-destinazioni-index__hero{padding-bottom:0}@font-face {
  font-family: 'Medio';
  src: url('https://offlinemilano.it/madi/wp-content/uploads/2026/04/medio.woff2') format('woff2'),
       url('https://offlinemilano.it/madi/wp-content/uploads/2026/04/medio.woff') format('woff');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
h1,
h2,
h3,
h4,
h5,
h6,
.wp-block-heading,
.entry-title,
.page-title,
.product_title {
  font-family: 'Medio', serif!important;
text-transform:uppercase;
}