/* ================================================================
   Palazzo Nobiliare Scarciglia v3 — Global Stylesheet
   FIXES: Contrasto testo, accessibilità, leggibilità mobile, SEO UI
   ================================================================ */
:root {
  --nero: #09070D; --pietra: #1C1520; --pietra2: #241C2B;
  --oro: #C9A84C; --oro-luce: #E8C97A; --oro-pale: #F5E4B8;
  --crema: #F2EBD9; --crema2: #E8DFC8; --terra: #7C2D12; --wa: #25D366;
  --fd: 'Cormorant Garamond', serif; --fb: 'DM Sans', sans-serif;
  --ease: cubic-bezier(0.16,1,0.3,1);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit} ul{list-style:none}
html.has-cursor,html.has-cursor *,html.has-cursor *::before,html.has-cursor *::after{cursor:none!important}
.cur-dot{position:fixed;top:0;left:0;width:8px;height:8px;background:var(--oro-luce);border-radius:50%;pointer-events:none;z-index:99999;transform:translate(-50%,-50%);transition:width .2s,height .2s,background .2s,opacity .3s;opacity:0;}
.cur-dot.visible{opacity:1} .cur-dot.hovering{width:13px;height:13px;background:var(--oro)}
html{height:-webkit-fill-available}
body{font-family:var(--fb);background:var(--nero);color:var(--crema);min-height:100vh;min-height:-webkit-fill-available;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;}
.site{overflow-x:clip;position:relative;width:100%}
#p-canvas,.wa-float,#nav,.cur-dot,.mob-menu,.progress-bar{-webkit-transform:translateZ(0);transform:translateZ(0);-webkit-backface-visibility:hidden;backface-visibility:hidden;}
::-webkit-scrollbar{width:4px} ::-webkit-scrollbar-track{background:var(--nero)} ::-webkit-scrollbar-thumb{background:var(--oro);border-radius:2px}
.progress-bar{position:fixed;top:0;left:0;right:0;height:2px;z-index:701;pointer-events:none}
.progress-fill{height:100%;width:0%;background:linear-gradient(90deg,var(--oro),var(--oro-luce))}
#p-canvas{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;opacity:.15}
#nav{position:fixed;inset:0 0 auto;z-index:700;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:20px 24px;transition:background .6s var(--ease),padding .5s var(--ease),border-color .5s;}
#nav.scrolled{background:rgba(9,7,13,.95);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);padding:12px 24px;border-bottom:1px solid rgba(201,168,76,.15);}
.nav-logo{flex:0 0 auto}.nav-logo img{height:44px;width:auto;max-width:none;filter:brightness(0) invert(1);transition:height .4s var(--ease);display:block;object-fit:contain}
@media(min-width:768px){.nav-logo img{height:52px}} #nav.scrolled .nav-logo img{height:38px}
.nav-links{display:none;align-items:center;gap:clamp(18px,2.1vw,34px);list-style:none;margin:0;padding:0;white-space:nowrap;flex:0 1 auto;min-width:0} @media(min-width:1220px){.nav-links{display:flex}}.nav-links li{flex:0 0 auto}
.nav-links a{font-size:10px;font-weight:500;letter-spacing:2.2px;text-transform:uppercase;color:rgba(242,235,217,.85);position:relative;padding-bottom:4px;transition:color .3s;}
.nav-links a::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--oro);transform:scaleX(0);transform-origin:right;transition:transform .45s var(--ease);}
.nav-links a:hover,.nav-links a.active{color:var(--oro-luce)} .nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1);transform-origin:left}
.nav-right{display:flex;align-items:center;gap:18px;flex:0 0 auto}.lang-wrap{display:flex;align-items:center;gap:6px}
.lang-btn{font-family:var(--fb);font-size:10px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:rgba(242,235,217,.5);background:none;border:none;padding:5px 7px;transition:color .3s;}
.lang-btn.on{color:var(--oro-luce)} .lang-sep{color:rgba(242,235,217,.3);font-size:11px}
.burger{display:flex;flex-direction:column;gap:5px;background:none;border:none;padding:4px} @media(min-width:900px){.burger{display:none}}
.burger span{display:block;width:24px;height:2px;background:var(--crema);transition:all .35s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)} .burger.open span:nth-child(2){opacity:0} .burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mob-menu{position:fixed;inset:0;z-index:699;background:rgba(9,7,13,.98);backdrop-filter:blur(10px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;opacity:0;pointer-events:none;transition:opacity .4s var(--ease);}
.mob-menu.open{opacity:1;pointer-events:all}
.mob-menu a{font-family:var(--fd);font-size:clamp(38px,10vw,56px);font-weight:400;color:var(--crema);opacity:0;transform:translateY(18px);transition:color .3s,opacity .4s var(--ease),transform .4s var(--ease);}
.mob-menu.open a{opacity:1;transform:translateY(0)} .mob-menu.open a:nth-child(1){transition-delay:.05s}.mob-menu.open a:nth-child(2){transition-delay:.1s}.mob-menu.open a:nth-child(3){transition-delay:.15s}.mob-menu.open a:nth-child(4){transition-delay:.2s}.mob-menu.open a:nth-child(5){transition-delay:.25s}
.mob-menu a:hover{color:var(--oro-luce)} .mob-lang{display:flex;gap:18px;margin-top:8px}
.mob-lang button{font-family:var(--fb);font-size:12px;font-weight:500;letter-spacing:3px;text-transform:uppercase;color:rgba(242,235,217,.5);background:none;border:none;transition:color .3s;} .mob-lang button.on{color:var(--oro-luce)}
.wa-float{position:fixed;bottom:24px;right:24px;z-index:5000;display:flex;align-items:center;gap:10px;background:var(--wa);color:#fff;padding:14px 22px;border-radius:100px;font-family:var(--fb);font-size:14px;font-weight:600;box-shadow:0 4px 28px rgba(37,211,102,.4);transition:box-shadow .3s,transform .3s;text-decoration:none;}
.wa-float:hover{transform:translateY(-2px) scale(1.03);box-shadow:0 6px 48px rgba(37,211,102,.65)} .wa-float i{font-size:24px;flex-shrink:0}
.wa-float,.wa-cta,.btn-oro,.btn-ghost,.btn-dark{touch-action:manipulation}
@media(max-width:400px){.wa-float .wa-label{display:none}.wa-float{padding:16px}}
.container{max-width:1200px;margin:0 auto;padding:0 24px} @media(min-width:768px){.container{padding:0 48px}}
/* Typography Fixes: Increased Opacity and weights */
.sec-label{display:block;font-family:var(--fb);font-size:10px;font-weight:600;letter-spacing:5px;text-transform:uppercase;color:var(--oro);margin-bottom:18px;opacity:1;}
.sec-label.light{color:var(--oro-luce)}
.sec-title{font-family:var(--fd);font-size:clamp(40px,8vw,88px);font-weight:400;line-height:1;color:var(--crema);letter-spacing:-0.5px;}
.sec-title em{font-style:italic;color:var(--oro-pale)}
.sec-body{font-size:16px;line-height:1.8;color:rgba(242,235,217,.9);max-width:600px;margin-top:24px;font-weight:400;letter-spacing:0;}
.gold-line{width:50px;height:2px;background:var(--oro);margin:28px 0;opacity:1}
.btn-oro{display:inline-flex;align-items:center;gap:12px;background:var(--oro);color:var(--nero);padding:18px 44px;border:none;font-family:var(--fb);font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;position:relative;overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s;}
.btn-oro::before{content:'';position:absolute;inset:0;background:var(--oro-luce);transform:scaleX(0);transform-origin:right;transition:transform .55s var(--ease);} .btn-oro:hover::before{transform:scaleX(1);transform-origin:left} .btn-oro:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(201,168,76,.35)} .btn-oro>*{position:relative;z-index:1}
.btn-ghost{display:inline-flex;align-items:center;gap:12px;border:1px solid rgba(201,168,76,.5);color:rgba(242,235,217,.95);padding:17px 42px;font-family:var(--fb);font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;transition:border-color .4s,color .4s,transform .3s,box-shadow .3s;}
.btn-ghost:hover{border-color:var(--oro-luce);color:var(--oro-luce);transform:translateY(-3px);box-shadow:0 12px 40px rgba(201,168,76,.15)}
.btn-dark{display:inline-flex;align-items:center;gap:12px;background:var(--nero);color:var(--oro-luce);padding:18px 44px;font-family:var(--fb);font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;border:none;transition:background .35s,transform .3s;} .btn-dark:hover{background:var(--pietra);transform:translateY(-2px)}
.magnetic{display:inline-block}
/* Hero Fixes: Text Shadows for readability */
.hero{position:relative;height:100svh;min-height:600px;display:flex;align-items:center;justify-content:center;overflow:hidden;}
.hero-slides,.hero-slide{position:absolute;inset:0} .hero-slide{opacity:0;transition:opacity 2s cubic-bezier(.4,0,.2,1)} .hero-slide.on{opacity:1}
.hero-slide img{width:100%;height:100%;object-fit:cover;transform:scale(1.06);transition:transform 10s cubic-bezier(.25,.46,.45,.94);background:var(--pietra2);} .hero-slide.on img{transform:scale(1)}
.hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(170deg,rgba(9,7,13,.7) 0%,rgba(9,7,13,.3) 45%,rgba(9,7,13,.85) 100%);}
.hero-content{position:relative;z-index:3;text-align:center;padding:0 24px;max-width:1080px; text-shadow: 0 4px 24px rgba(0,0,0,0.6);}
.hero-eyebrow{font-family:var(--fb);font-size:11px;font-weight:600;letter-spacing:5px;text-transform:uppercase;color:var(--oro-luce);margin-bottom:28px;display:block;animation:fadeUp .9s .3s both;}
.hero-title{font-family:var(--fd);font-size:clamp(52px,16vw,170px);font-weight:400;color:#fff;line-height:.9;letter-spacing:-1px;margin-bottom:20px;text-shadow: 0 8px 32px rgba(0,0,0,0.7);}
.hero-accent{font-family:var(--fd);font-size:clamp(16px,2.5vw,22px);font-weight:400;font-style:italic;color:rgba(242,235,217,.9);letter-spacing:.03em;margin-bottom:12px;display:block;animation:fadeUp .9s .55s both;}
.hero-sub{font-family:var(--fb);font-size:clamp(15px,2.2vw,20px);font-weight:400;color:rgba(255,255,255,.95);margin-bottom:36px;display:block;line-height:1.6;animation:fadeUp .9s .75s both;}
.hero-btns{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;animation:fadeUp .9s 1.05s both}
.hero-dots{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:4;}
.hero-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.4);border:none;transition:width .45s var(--ease),background .4s,border-radius .4s;} .hero-dot.on{width:32px;border-radius:3px;background:var(--oro)}
.scroll-cue{position:absolute;bottom:36px;right:32px;z-index:4;display:flex;flex-direction:column;align-items:center;gap:10px;animation:fadeUp .9s 2s both;}
.scroll-cue span{font-size:10px;font-weight:600;letter-spacing:4px;text-transform:uppercase;color:rgba(255,255,255,.6);writing-mode:vertical-rl;}
.scroll-line{width:2px;height:60px;background:rgba(255,255,255,.2);overflow:hidden;position:relative} .scroll-line::after{content:'';position:absolute;top:-100%;left:0;width:100%;height:100%;background:linear-gradient(to bottom,transparent,var(--oro));animation:scrollDrop 2.2s 2s infinite;}
@media(max-width:768px){.scroll-cue{display:none}}
.sub-hero{position:relative;height:clamp(400px,65svh,720px);display:flex;align-items:flex-end;overflow:hidden;padding-bottom:80px;padding-top:110px;}
.sub-hero>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;background:var(--pietra2)}
.sub-hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(9,7,13,.95) 0%,rgba(9,7,13,.3) 60%)}
.sub-hero-content{position:relative;z-index:2; text-shadow: 0 4px 20px rgba(0,0,0,0.6);}
.sub-hero-label{display:block;font-size:10px;font-weight:600;letter-spacing:4px;text-transform:uppercase;color:var(--oro-luce);margin-bottom:16px;animation:fadeUp .8s .2s both}
.sub-hero-title{font-family:var(--fd);font-size:clamp(50px,11vw,110px);font-weight:400;color:#fff;line-height:1;animation:fadeUp .9s .35s both}
.sub-hero-sub{font-family:var(--fb);font-size:clamp(16px,2.2vw,22px);font-weight:400;color:rgba(255,255,255,.9);margin-top:22px;max-width:700px;line-height:1.6;animation:fadeUp .9s .5s both}
.breadcrumb{display:flex;align-items:center;gap:10px;margin-bottom:20px;animation:fadeUp .7s .1s both} .breadcrumb a{font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:rgba(242,235,217,.6);transition:color .3s} .breadcrumb a:hover{color:var(--oro-luce)} .breadcrumb-sep{color:var(--oro);font-size:10px}
.marquee{background:var(--pietra);padding:20px 0;overflow:hidden;position:relative;z-index:2;border-top:1px solid rgba(201,168,76,.2);border-bottom:1px solid rgba(201,168,76,.2);contain:layout;}
.marquee-track{display:flex;width:max-content;animation:marqueeScroll 35s linear infinite} .marquee:hover .marquee-track{animation-play-state:paused}
.marquee-item{font-family:var(--fd);font-size:clamp(13px,1.8vw,16px);font-weight:400;letter-spacing:5px;text-transform:uppercase;color:var(--oro);white-space:nowrap;padding:0 36px;opacity:.9;}
.marquee-sep{color:rgba(201,168,76,.5);margin:0 8px;}
#palazzo{background:var(--pietra);padding:140px 0;position:relative;z-index:2}
.palazzo-grid{display:grid;gap:80px} @media(min-width:900px){.palazzo-grid{grid-template-columns:1fr 1fr;align-items:center}}
.palazzo-stats{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-top:52px} .stat{border-top:1px solid rgba(201,168,76,.3);padding-top:20px}
.stat-n{font-family:var(--fd);font-size:56px;font-weight:400;color:var(--oro);line-height:1} .stat-l{font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:rgba(242,235,217,.6);margin-top:12px;line-height:1.4;}
.palazzo-imgs{display:grid;grid-template-columns:1fr 1fr;gap:12px} .p-img{overflow:hidden;position:relative} .p-img img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)} .p-img:hover img{transform:scale(1.06)}
.p-img-main{grid-column:1/-1;height:360px} .p-img-sm{height:220px} @media(min-width:768px){.p-img-main{height:500px}.p-img-sm{height:260px}}
.journey-section{position:relative;z-index:2;background:var(--nero)} .journey-sticky{position:sticky;top:0;height:100svh;overflow:hidden;display:flex;align-items:center;contain:layout}
.journey-track{display:flex;gap:0;height:100%;width:max-content;will-change:transform} .journey-panel{width:100svw;height:100%;flex-shrink:0;position:relative;overflow:hidden;display:flex;align-items:flex-end;padding:80px 32px;} @media(min-width:768px){.journey-panel{width:88svw;padding:90px}}
.journey-panel>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;background:var(--pietra2)} .journey-panel-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(9,7,13,.95) 0%,rgba(9,7,13,.15) 65%)}
.journey-panel-content{position:relative;z-index:2;max-width:600px; text-shadow: 0 4px 16px rgba(0,0,0,0.8);}
.journey-panel-num{font-family:var(--fd);font-size:130px;font-weight:400;color:rgba(201,168,76,.15);line-height:1;position:absolute;top:-70px;right:0;pointer-events:none;letter-spacing:-4px;} @media(max-width:768px){.journey-panel-num{font-size:90px;top:-50px}}
.journey-panel-label{font-size:10px;font-weight:600;letter-spacing:4px;text-transform:uppercase;color:var(--oro);margin-bottom:16px;display:block} .journey-panel-title{font-family:var(--fd);font-size:clamp(36px,5vw,68px);font-weight:400;color:#fff;line-height:1.05;margin-bottom:24px;} .journey-panel-body{font-size:16px;line-height:1.8;color:rgba(255,255,255,.9);font-weight:400}
.journey-progress{position:absolute;bottom:36px;right:48px;z-index:5;display:flex;gap:10px;align-items:center} .j-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.3);transition:all .4s var(--ease)} .j-dot.on{width:26px;border-radius:3px;background:var(--oro)}
.journey-hint{position:absolute;bottom:36px;left:48px;z-index:5;font-size:10px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:rgba(242,235,217,.6);display:flex;align-items:center;gap:10px;} .journey-hint i{color:var(--oro);font-size:14px}
#eventi{background:var(--nero);padding:140px 0;position:relative;z-index:2} .eventi-grid{display:grid;gap:24px} @media(min-width:600px){.eventi-grid{grid-template-columns:repeat(2,1fr)}} @media(min-width:1100px){.eventi-grid{grid-template-columns:repeat(4,1fr)}}
.ev-card{position:relative;overflow:hidden;border:1px solid rgba(201,168,76,.15);background:var(--pietra);transition:border-color .45s,box-shadow .45s,transform .45s var(--ease);} .ev-card:hover{border-color:rgba(201,168,76,.5);box-shadow:0 32px 80px rgba(0,0,0,.7);transform:translateY(-6px)}
.ev-img{overflow:hidden;aspect-ratio:3/4;position:relative;background:var(--pietra2)} .ev-img img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease);} .ev-card:hover .ev-img img{transform:scale(1.1)} .ev-img::after{content:'';position:absolute;inset:0;background:rgba(9,7,13,.35);transition:opacity .6s ease;pointer-events:none;} .ev-card:hover .ev-img::after{opacity:0}
.ev-num{position:absolute;top:12px;right:16px;z-index:1;font-family:var(--fd);font-size:80px;font-weight:400;color:rgba(201,168,76,.15);line-height:1;pointer-events:none;} .ev-body{padding:32px 24px;position:relative;z-index:3}
.ev-tag{font-size:9px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--oro);margin-bottom:14px;display:block;} .ev-title{font-family:var(--fd);font-size:32px;font-weight:400;color:var(--crema);margin-bottom:16px;line-height:1.1} .ev-desc{font-size:15px;line-height:1.7;color:rgba(242,235,217,.8);font-weight:400}
.ev-link{display:inline-flex;align-items:center;gap:10px;margin-top:24px;font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--oro-luce);transition:gap .4s var(--ease);} .ev-card:hover .ev-link{gap:16px}
#galleria{background:var(--pietra);padding:140px 0;position:relative;z-index:2} .gallery-hd{margin-bottom:60px} .gallery-grid{display:grid;gap:8px;grid-template-columns:repeat(2,1fr)} @media(min-width:640px){.gallery-grid{grid-template-columns:repeat(3,1fr)}} @media(min-width:1024px){.gallery-grid{grid-template-columns:repeat(4,1fr)}}
.g-item{overflow:hidden;aspect-ratio:1;background:var(--pietra2);position:relative} .g-item.tall{aspect-ratio:unset;grid-row:span 2} .g-item.wide{grid-column:span 2} @media(max-width:639px){.g-item.tall{aspect-ratio:1;grid-row:auto} .g-item.wide{grid-column:auto}}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease);} .g-item:hover img{transform:scale(1.08)} .g-item::before{content:'';position:absolute;inset:0;z-index:1;background:rgba(9,7,13,.4);transition:opacity .55s ease;pointer-events:none;} .g-item:hover::before{opacity:0}
.g-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;transition:background .35s; z-index:2;} .g-item:hover .g-overlay{background:rgba(9,7,13,.1)} .g-overlay i{color:#fff;font-size:24px;opacity:0;transform:scale(.5);transition:opacity .3s,transform .35s var(--ease)} .g-item:hover .g-overlay i{opacity:1;transform:scale(1)}
.cta-band{background:var(--oro);padding:110px 24px;text-align:center;position:relative;z-index:2;overflow:hidden} .cta-band::before{content:'SCARCIGLIA';font-family:var(--fd);font-size:clamp(80px,20vw,240px);font-weight:400;color:rgba(9,7,13,.08);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;white-space:nowrap;letter-spacing:-6px;}
.cta-band-title{font-family:var(--fd);font-size:clamp(38px,6vw,76px);font-weight:400;color:var(--nero);margin-bottom:20px;position:relative;line-height:1.1;} .cta-band-sub{font-size:16px;color:rgba(9,7,13,.8);font-weight:500;margin-bottom:48px;max-width:560px;margin-left:auto;margin-right:auto;position:relative;line-height:1.7} .cta-urgency{font-size:11px;font-weight:600;letter-spacing:2px;color:rgba(9,7,13,.85);margin-top:24px;position:relative;text-transform:uppercase}
#experience{background:var(--pietra2);padding:140px 0;position:relative;z-index:2} .exp-grid{display:grid;gap:48px;margin-top:80px} @media(min-width:768px){.exp-grid{grid-template-columns:repeat(3,1fr)}}
.exp-item{border-top:1px solid rgba(201,168,76,.25);padding-top:32px} .exp-icon{font-size:32px;color:var(--oro);margin-bottom:24px} .exp-title{font-family:var(--fd);font-size:32px;font-weight:400;color:var(--crema);margin-bottom:16px} .exp-text{font-size:15px;line-height:1.8;color:rgba(242,235,217,.85);font-weight:400}
#contatti{background:var(--nero);padding:140px 0;position:relative;z-index:2} .contatti-grid{display:grid;gap:90px} @media(min-width:900px){.contatti-grid{grid-template-columns:1fr 1fr}}
.cform{display:flex;flex-direction:column;gap:22px} .flabel{font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:rgba(242,235,217,.6);display:block;margin-bottom:10px}
.finput,.fselect,.ftextarea{width:100%;background:rgba(242,235,217,.05);border:1px solid rgba(242,235,217,.15);padding:18px 20px;color:var(--crema);font-family:var(--fb);font-size:15px;outline:none;transition:border-color .35s,background .35s;-webkit-appearance:none;border-radius:0;}
.finput::placeholder,.ftextarea::placeholder{color:rgba(242,235,217,.3)} .finput:focus,.fselect:focus,.ftextarea:focus{border-color:rgba(201,168,76,.8);background:rgba(201,168,76,.08)} .fselect{cursor:pointer;background:rgba(9,7,13,.9)} .fselect option{background:var(--pietra)} .ftextarea{height:150px;resize:none}
.fsubmit{background:var(--oro);color:var(--nero);padding:20px 36px;border:none;font-family:var(--fb);font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;width:100%;transition:background .35s,transform .25s;position:relative;overflow:hidden;} .fsubmit::before{content:'';position:absolute;inset:0;background:var(--oro-luce);transform:scaleX(0);transform-origin:right;transition:transform .5s var(--ease)} .fsubmit:hover::before{transform:scaleX(1);transform-origin:left} .fsubmit:hover{transform:translateY(-2px)} .fsubmit span{position:relative;z-index:1}
.cinfo-title{font-family:var(--fd);font-size:clamp(38px,5vw,62px);font-weight:400;color:var(--crema);line-height:1.1;margin-bottom:56px}
.cdetail{display:flex;align-items:flex-start;gap:20px;padding-bottom:30px;margin-bottom:30px;border-bottom:1px solid rgba(242,235,217,.1)} .cdetail:last-of-type{border-bottom:none} .cdetail i{color:var(--oro);font-size:18px;margin-top:4px;width:20px;flex-shrink:0} .cdetail-inner{display:flex;flex-direction:column;gap:6px} .cdetail-label{font-size:9px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:rgba(242,235,217,.4)} .cdetail-val{font-size:16px;color:rgba(242,235,217,.9);line-height:1.6;font-weight:400;transition:color .3s} a.cdetail-val:hover{color:var(--oro-luce)}
.wa-cta{display:flex;align-items:center;gap:16px;background:var(--wa);color:#fff;padding:18px 28px;margin-top:36px;font-family:var(--fb);font-size:15px;font-weight:600;transition:background .3s,transform .3s;text-decoration:none; justify-content: center;} .wa-cta:hover{background:#1eb84e;transform:translateY(-3px)} .wa-cta i{font-size:24px}
.socials{display:flex;gap:12px;margin-top:32px} .soc-btn{width:48px;height:48px;border:1px solid rgba(201,168,76,.3);display:flex;align-items:center;justify-content:center;color:var(--oro);font-size:18px;text-decoration:none;transition:background .3s,border-color .3s,color .3s,transform .3s} .soc-btn:hover{background:var(--oro);border-color:var(--oro);color:var(--nero);transform:translateY(-3px)}
.map-wrap{height:350px;overflow:hidden;filter:grayscale(40%) contrast(1.1) brightness(.9)} .map-wrap iframe{width:100%;height:100%;border:none}
.footer{background:#030103;padding:64px 24px;text-align:center;position:relative;z-index:2;border-top:1px solid rgba(201,168,76,.15)} .footer-logo img{height:52px;width:auto;max-width:none;filter:brightness(0) invert(1);opacity:.4;margin:0 auto 36px;display:block;object-fit:contain} .footer-nav{display:flex;flex-wrap:wrap;justify-content:center;gap:16px 32px;margin-bottom:36px} .footer-nav a,.footer-nav button{font-family:var(--fb);font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:rgba(242,235,217,.65);background:none;border:none;transition:color .3s} .footer-nav a:hover,.footer-nav button:hover{color:var(--oro-luce)}
.footer-contacts{display:flex;flex-wrap:wrap;justify-content:center;gap:10px 22px;margin:-14px auto 28px;max-width:980px;font-size:12px;line-height:1.8;color:rgba(242,235,217,.55)}.footer-contacts a{color:rgba(232,201,122,.82);text-decoration:none}.footer-contacts a:hover{color:var(--oro-luce)}
.footer-copy{font-size:12px;letter-spacing:1px;color:rgba(242,235,217,.3);line-height:1.8} .footer-credit{font-size:11px;color:rgba(242,235,217,.2);margin-top:16px} .footer-credit a{color:rgba(201,168,76,.6);transition:color .3s} .footer-credit a:hover{color:var(--oro-luce)}
/* Modals / Privacy / Booking (keeping base layout but better fonts) */
#priv-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:9500;display:flex;justify-content:center;opacity:0;pointer-events:none;transition:opacity .45s var(--ease),transform .45s var(--ease);transform:translateY(12px)} #priv-banner.show{opacity:1;transform:translateY(0)} .priv-box{position:relative;background:rgba(28,21,32,.96);border:1px solid rgba(201,168,76,.28);box-shadow:0 22px 70px rgba(0,0,0,.45);backdrop-filter:blur(18px);max-width:980px;width:100%;padding:24px;display:flex;flex-direction:column;gap:18px;pointer-events:auto} @media(min-width:768px){.priv-box{flex-direction:row;align-items:center;padding:24px 28px;gap:28px}}
.priv-close-mini{position:absolute;top:10px;right:12px;width:32px;height:32px;border:none;background:transparent;color:rgba(242,235,217,.55);font-size:24px;line-height:1;transition:color .25s}.priv-close-mini:hover{color:var(--crema)}.priv-text{font-size:14px;line-height:1.8;color:rgba(242,235,217,.8);flex:1;font-weight:400;padding-right:28px} .priv-text a{color:var(--oro-luce);text-decoration:underline;text-underline-offset:3px} .priv-btns{display:flex;gap:12px;flex-shrink:0;flex-wrap:wrap} .priv-accept{background:var(--oro);color:var(--nero);padding:14px 32px;font-family:var(--fb);font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;border:none;} .priv-reject{border:1px solid rgba(242,235,217,.3);color:rgba(242,235,217,.8);padding:14px 24px;font-family:var(--fb);font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;background:none;transition:border-color .3s,color .3s} .priv-reject:hover{border-color:rgba(242,235,217,.8);color:var(--crema)}
#priv-modal{position:fixed;inset:0;z-index:9600;background:rgba(9,7,13,.95);backdrop-filter:blur(20px);display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;pointer-events:none;transition:opacity .4s} #priv-modal.show{opacity:1;pointer-events:all} .priv-modal-inner{background:var(--pietra);max-width:760px;width:100%;max-height:85svh;overflow-y:auto;padding:56px 40px;position:relative} .priv-modal-inner h2{font-family:var(--fd);font-size:48px;font-weight:400;color:var(--crema);margin-bottom:12px} .priv-modal-inner h3{font-family:var(--fd);font-size:26px;color:var(--oro-luce);margin:32px 0 12px;font-weight:400} .priv-modal-inner p{font-size:15px;line-height:1.8;color:rgba(242,235,217,.85);margin-bottom:12px;font-weight:400} .priv-close{position:absolute;top:24px;right:24px;font-size:24px;color:rgba(242,235,217,.5);background:none;border:none;transition:color .3s} .priv-close:hover{color:var(--crema)}
#booking-modal{position:fixed;inset:0;z-index:9400;background:rgba(9,7,13,.95);backdrop-filter:blur(22px);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .45s var(--ease);overflow-y:auto;} #booking-modal.show{opacity:1;pointer-events:all} .booking-inner{background:var(--pietra);max-width:880px;width:100%;position:relative;margin:auto;} .booking-header{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;padding:40px 40px 28px;border-bottom:1px solid rgba(201,168,76,.2);} .booking-header-text h2{font-family:var(--fd);font-size:40px;font-weight:400;color:var(--crema);margin-bottom:10px;letter-spacing:0;} .booking-header-text p{font-size:14px;color:rgba(242,235,217,.7);line-height:1.7;max-width:560px} .booking-close{flex-shrink:0;background:none;border:none;font-size:24px;color:rgba(242,235,217,.5);transition:color .3s;padding:6px;margin-top:-6px;} .booking-close:hover{color:var(--crema)}
.booking-legend{display:flex;gap:28px;flex-wrap:wrap;padding:20px 40px;border-bottom:1px solid rgba(201,168,76,.15);} .legend-item{display:flex;align-items:center;gap:10px;font-size:13px;color:rgba(242,235,217,.7);font-weight:500;} .legend-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0} .legend-dot.available{background:rgba(201,168,76,.8)} .legend-dot.limited{background:#d97706} .legend-dot.booked{background:var(--terra)}
.booking-months{display:grid;grid-template-columns:repeat(2,1fr);gap:0;} @media(max-width:600px){.booking-months{grid-template-columns:1fr}} .booking-month{padding:32px 32px 28px;border-right:1px solid rgba(201,168,76,.15)} .booking-month:nth-child(even){border-right:none} .booking-month:nth-child(n+3){border-top:1px solid rgba(201,168,76,.15)} @media(max-width:600px){.booking-month{border-right:none!important} .booking-month:nth-child(n+2){border-top:1px solid rgba(201,168,76,.15)}}
.booking-month-title{font-family:var(--fd);font-size:26px;font-weight:400;color:var(--crema);display:inline;margin-right:10px;} .booking-month-year{font-size:13px;color:rgba(242,235,217,.5);font-weight:600;letter-spacing:2px;display:inline;}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-top:18px;} .cal-day-head{text-align:center;font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:rgba(242,235,217,.5);padding:8px 0;font-family:var(--fb);} .cal-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-family:var(--fb);font-size:16px;font-weight:500;border:1px solid transparent;position:relative;transition:background .2s,border-color .2s,color .2s;cursor:default;} .cal-day.empty,.cal-day.past{color:rgba(242,235,217,.15);pointer-events:none} .cal-day.available{color:var(--crema);border-color:rgba(201,168,76,.3)} .cal-day.available:hover{background:rgba(201,168,76,.2);border-color:var(--oro)} .cal-day.limited{color:#fbbf24;border-color:rgba(217,119,6,.4)} .cal-day.limited:hover{background:rgba(217,119,6,.2);border-color:#d97706} .cal-day.booked{color:rgba(242,235,217,.3);pointer-events:none;background:rgba(124,45,18,.2)} .cal-day.booked::after{content:'';position:absolute;bottom:6px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--terra);opacity:.8;} .cal-day.today{border-color:rgba(201,168,76,.7)!important;color:var(--oro-luce);font-weight:700;}
.booking-cta{padding:32px 40px 40px;border-top:1px solid rgba(201,168,76,.2);text-align:center;} .booking-cta>p{font-size:15px;color:rgba(242,235,217,.75);line-height:1.7;margin-bottom:24px;font-weight:400} .booking-cta-row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

.social-sidebar{position:fixed;left:24px;top:50%;transform:translateY(-50%);z-index:200;display:flex;flex-direction:column;align-items:center;gap:0;} @media(max-width:900px){.social-sidebar{display:none}} .social-sidebar::before,.social-sidebar::after{content:'';display:block;width:2px;height:60px;background:linear-gradient(to bottom,transparent,rgba(201,168,76,.5));margin:0 auto;} .social-sidebar::after{background:linear-gradient(to top,transparent,rgba(201,168,76,.5));} .social-sidebar-links{display:flex;flex-direction:column;gap:6px;padding:16px 0} .social-sidebar a{width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:rgba(201,168,76,.7);font-size:18px;text-decoration:none;position:relative;transition:color .35s,transform .35s var(--ease);} .social-sidebar a::before{content:'';position:absolute;inset:0;border-radius:50%;background:rgba(201,168,76,.0);transition:background .35s,transform .35s var(--ease);transform:scale(.5);} .social-sidebar a:hover{color:var(--oro-luce);transform:translateX(4px)} .social-sidebar a:hover::before{background:rgba(201,168,76,.2);transform:scale(1)}
.rev{opacity:0;transition:opacity 1.1s var(--ease),transform 1.1s var(--ease)} .rev.up{transform:translateY(56px)} .rev.left{transform:translateX(-56px)} .rev.right{transform:translateX(56px)} .rev.zoom{transform:scale(.94)} .rev.in{opacity:1;transform:translate(0) scale(1)} .curtain{overflow:hidden} .curtain-inner{clip-path:inset(100% 0 0 0);transition:clip-path 1.4s var(--ease)} .curtain.in .curtain-inner{clip-path:inset(0% 0 0 0)} .img-lazy{opacity:0;transition:opacity .8s ease} .img-lazy.loaded{opacity:1}
.page-section{padding:130px 0;position:relative;z-index:2} .page-section.dark{background:var(--nero)} .page-section.stone{background:var(--pietra)} .page-section.stone2{background:var(--pietra2)}
.legal-main{background:var(--nero);min-height:100vh;padding-top:120px}.legal-hero{padding:84px 0 44px;background:linear-gradient(180deg,rgba(201,168,76,.08),rgba(9,7,13,0))}.legal-doc{max-width:960px;margin:0 auto 90px;padding:44px;background:rgba(28,21,32,.72);border:1px solid rgba(201,168,76,.18)}.legal-doc h1{font-family:var(--fd);font-size:clamp(44px,7vw,82px);font-weight:400;color:var(--crema);line-height:1;margin-bottom:18px}.legal-doc h2{font-family:var(--fd);font-size:32px;font-weight:400;color:var(--oro-luce);margin:38px 0 14px}.legal-doc h3{font-family:var(--fb);font-size:12px;letter-spacing:2px;text-transform:uppercase;color:rgba(201,168,76,.78);margin:28px 0 10px}.legal-doc p,.legal-doc li{font-size:15px;line-height:1.9;color:rgba(242,235,217,.78);font-weight:400}.legal-doc ul{padding-left:20px;margin:10px 0 18px}.legal-doc a{color:var(--oro-luce);text-decoration:underline;text-underline-offset:3px}.legal-updated{font-family:var(--fb);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:rgba(242,235,217,.42);margin-bottom:28px}.legal-note{border-left:2px solid var(--oro);padding:16px 20px;margin:28px 0;background:rgba(201,168,76,.06);color:rgba(242,235,217,.82)}@media(max-width:767px){.legal-main{padding-top:96px}.legal-doc{padding:30px 22px;margin-bottom:64px}.legal-hero{padding-top:48px}}
.info-grid{display:grid;gap:24px;margin-top:60px} @media(min-width:640px){.info-grid{grid-template-columns:repeat(2,1fr)}} @media(min-width:900px){.info-grid{grid-template-columns:repeat(3,1fr)}}
.info-box{border:1px solid rgba(201,168,76,.2);padding:36px 32px;transition:border-color .45s,background .45s,transform .45s var(--ease)} .info-box:hover{border-color:rgba(201,168,76,.6);background:rgba(201,168,76,.06);transform:translateY(-4px)} .info-box-icon{font-size:32px;color:var(--oro);margin-bottom:24px} .info-box-title{font-family:var(--fd);font-size:28px;font-weight:400;color:var(--crema);margin-bottom:14px} .info-box-text{font-size:15px;line-height:1.8;color:rgba(242,235,217,.8);font-weight:400}
.steps{display:flex;flex-direction:column;gap:48px;margin-top:60px} @media(min-width:768px){.steps{flex-direction:row}} .step{flex:1;padding-top:28px;border-top:1px solid rgba(201,168,76,.3)} .step-num{font-family:var(--fd);font-size:60px;font-weight:400;color:rgba(201,168,76,.4);line-height:1;margin-bottom:20px} .step-title{font-family:var(--fd);font-size:28px;font-weight:400;color:var(--crema);margin-bottom:14px} .step-text{font-size:15px;line-height:1.8;color:rgba(242,235,217,.8);font-weight:400}
.faq-list{display:flex;flex-direction:column;gap:0;margin-top:60px} .faq-item{border-bottom:1px solid rgba(201,168,76,.2)} .faq-q{width:100%;text-align:left;padding:26px 0;font-family:var(--fd);font-size:24px;font-weight:400;color:var(--crema);background:none;border:none;display:flex;justify-content:space-between;align-items:center;gap:20px;transition:color .3s;} .faq-q:hover{color:var(--oro-luce)} .faq-q i{color:var(--oro);font-size:14px;transition:transform .45s var(--ease);flex-shrink:0} .faq-item.open .faq-q i{transform:rotate(180deg)} .faq-a{max-height:0;overflow:hidden;transition:max-height .55s var(--ease)} .faq-a-inner{padding:0 0 28px;font-size:16px;line-height:1.8;color:rgba(242,235,217,.85);font-weight:400} .faq-item.open .faq-a{max-height:450px}
.wedding-quote{font-family:var(--fd);font-size:clamp(26px,4.5vw,44px);font-weight:400;font-style:italic;color:var(--oro-luce);text-align:center;max-width:800px;margin:0 auto;line-height:1.5; text-shadow: 0 2px 10px rgba(0,0,0,0.5);} .wedding-quote::before{content:'❝\00a0';color:rgba(201,168,76,.8)} .wedding-quote::after{content:'\00a0❞';color:rgba(201,168,76,.8)}

@media(max-width:767px){
  .page-section{padding:80px 0} #palazzo,#eventi,#galleria,#experience,#contatti{padding:90px 0} .journey-panel{padding:60px 24px}
  .hero-btns{flex-direction:column;align-items:center;gap:14px;padding:0 24px} .hero-btns .btn-oro,.hero-btns .btn-ghost,.hero-btns a,.hero-btns button{width:100%;max-width:380px;justify-content:center;padding:18px 24px}
  .hero-eyebrow{font-size:9px;letter-spacing:3px;margin-bottom:20px} .hero-accent{font-size:14px;margin-bottom:10px}
  .stat-l{font-size:9px;letter-spacing:1px;line-height:1.4} .stat-n{font-size:46px} .palazzo-stats{gap:24px;margin-top:40px}
  .btn-oro,.btn-ghost,.btn-dark{padding:18px 32px;font-size:10px;}
  .palazzo-grid{gap:48px} .palazzo-imgs{gap:8px} .p-img-main{height:280px} .p-img-sm{height:180px}
  .sec-title{font-size:clamp(38px,10vw,62px)} .sec-body{font-size:15px;line-height:1.7;margin-top:20px} .gold-line{margin:24px 0}
  .journey-hint{display:none} .contatti-grid{gap:60px} .cta-band{padding:80px 24px} .cta-band-title{font-size:clamp(32px,8vw,54px)}
  .exp-grid{gap:36px;margin-top:48px} .sub-hero{padding-bottom:56px;padding-top:100px} .sub-hero-title{font-size:clamp(44px,11vw,80px)}
  .gallery-grid{grid-template-columns:repeat(2,1fr);gap:6px} .eventi-grid{grid-template-columns:1fr} .info-grid{grid-template-columns:1fr} .steps{flex-direction:column;gap:36px}
  .booking-inner{margin:12px} .booking-header{padding:28px 24px 20px} .booking-header-text h2{font-size:30px} .booking-months{grid-template-columns:1fr} .booking-month{padding:24px 20px} .booking-cta{padding:24px 24px 32px}
  .cform > div[style*="grid-template-columns"]{grid-template-columns:1fr!important}
}
@media(max-width:480px){.hero-title{font-size:clamp(48px,15vw,80px);letter-spacing:-1px} .eventi-grid{grid-template-columns:1fr} .ev-img{aspect-ratio:16/9}}
@keyframes fadeUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:translateY(0)}}
@keyframes marqueeScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes scrollDrop{0%{top:-100%;opacity:0}20%{opacity:1}100%{top:100%;opacity:0}}
@keyframes waPulse{0%,100%{box-shadow:0 4px 28px rgba(37,211,102,.4)}50%{box-shadow:0 4px 52px rgba(37,211,102,.8),0 0 0 12px rgba(37,211,102,.1)}}
.hero-video {position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; opacity: 0; display:block; background:var(--pietra2); transition:opacity 1.15s cubic-bezier(.4,0,.2,1); animation: videoZoom 18s ease-in-out infinite alternate; will-change:opacity,transform;}
.hero-video.is-loaded{opacity:1;}
.hero.video-ready .hero-slides--fallback{opacity:0;pointer-events:none;transition:opacity 1.15s cubic-bezier(.4,0,.2,1);}
@keyframes videoZoom {from { transform: scale(1); } to { transform: scale(1.04); }} @keyframes videoReveal {from { opacity: 0; } to { opacity: 1; }}
@media (min-width: 768px) and (hover: hover) {.hero-slides--fallback { display: block; }}
@media (max-width: 767px) {.hero-video { display: block; } .hero-slides--fallback { display: block; }}
@media (prefers-reduced-motion: reduce) {.hero-video { display: none; } .hero-slides--fallback { display: block; } .hero-video { animation: none; }}

/* ================================================================
   MOBILE-FIRST OVERRIDES — Android & iOS
   ================================================================ */
@media(max-width:767px){
  body{overscroll-behavior-y:none}
  .site{overflow-x:hidden}
  
  /* Sezioni */
  .page-section{padding:64px 0}
  #palazzo,#eventi,#galleria,#experience,#contatti{padding:72px 0}
  
  /* Hero */
  .hero{touch-action:pan-y}
  .hero-btns{flex-direction:column;align-items:center;gap:10px;padding:0 20px}
  .hero-btns .btn-oro,.hero-btns .btn-ghost,.hero-btns button,.hero-btns a{
    width:100%;max-width:320px;justify-content:center;padding:15px 20px
  }
  .hero-eyebrow{font-size:7px;letter-spacing:3.5px;margin-bottom:14px}
  .hero-accent{font-size:11px}
  .hero-sub{font-size:15px;margin-bottom:28px}
  
  /* Typography */
  .sec-title{font-size:clamp(32px,8.5vw,52px)}
  .sec-body{font-size:13px;line-height:1.85;margin-top:14px}
  .gold-line{margin:18px 0}
  
  /* Palazzo grid */
  .palazzo-grid{gap:36px}
  .palazzo-imgs{gap:5px}
  .p-img-main{height:220px}
  .p-img-sm{height:138px}
  .palazzo-stats{gap:16px;margin-top:28px}
  .stat-n{font-size:38px}
  .stat-l{font-size:7.5px;letter-spacing:1px;line-height:1.4}
  
  /* Buttons */
  .btn-oro,.btn-ghost,.btn-dark{padding:14px 24px;font-size:8px;letter-spacing:2.5px}
  
  /* Events */
  .eventi-grid{grid-template-columns:1fr}
  .ev-img{aspect-ratio:16/9}
  
  /* Gallery */
  .gallery-grid{grid-template-columns:repeat(2,1fr);gap:3px}
  .g-item.tall{aspect-ratio:1;grid-row:auto}
  .g-item.wide{grid-column:auto}
  
  /* Journey panels stacked */
  .journey-section{height:auto!important}
  .journey-sticky{position:relative!important;height:auto!important;overflow:visible!important;display:block!important}
  .journey-track{display:block!important;width:100%!important;transform:none!important}
  .journey-panel{width:100%!important;height:68svh;display:flex;align-items:flex-end;padding:36px 20px!important}
  .journey-hint{display:none}
  
  /* Contatti */
  .contatti-grid{gap:40px}
  
  /* CTA Band */
  .cta-band{padding:56px 20px}
  .cta-band-title{font-size:clamp(26px,7vw,44px)}
  
  /* Experience */
  .exp-grid{gap:24px;margin-top:36px}
  
  /* Sub hero */
  .sub-hero{padding-bottom:44px;padding-top:88px}
  .sub-hero-title{font-size:clamp(36px,10vw,64px)}
  
  /* Info & Steps */
  .info-grid{grid-template-columns:1fr}
  .steps{flex-direction:column;gap:24px}
  
  /* Booking modal */
  .booking-inner{margin:0}
  .booking-header{padding:20px 18px 16px}
  .booking-header-text h2{font-size:24px}
  .booking-months{grid-template-columns:1fr}
  .booking-month{padding:18px 14px}
  .cal-day{font-size:13px}
  .booking-cta{padding:18px 18px 24px}
  .booking-cta-row{flex-direction:column}
  
  /* Forms */  
  .cform>div[style*="grid-template-columns"]{grid-template-columns:1fr!important}
  
  /* Social sidebar nascosta su mobile */
  .social-sidebar{display:none}
  
  /* FAQ */
  .faq-q{font-size:17px}
}

@media(max-width:480px){
  .hero-title{font-size:clamp(42px,13vw,64px);letter-spacing:-1px}
  .container{padding:0 18px}
}

/* Smooth scroll Android */
html{scroll-behavior:smooth}
@media(max-width:767px){
  html{-webkit-text-size-adjust:100%}
}

/* ═══════════════════════════════════════════════════════════════
   GALLERY V2 — Layout cinematografico 3 righe
   ═══════════════════════════════════════════════════════════════ */
/* ── TAP TARGETS: min 44x44px su tutti gli elementi interattivi ─ */
.hero-dot {
  min-width: 44px !important;
  min-height: 44px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.j-dot {
  min-width: 44px !important;
  min-height: 44px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.faq-q {
  min-height: 48px !important;
}
.lang-btn, .mob-lang button {
  min-width: 44px !important;
  min-height: 44px !important;
  padding: 8px 12px !important;
}
/* footer nav links: tap area */
.footer-nav a, .footer-nav button {
  padding: 8px 6px !important;
  min-height: 44px !important;
  display: inline-flex !important;
  align-items: center !important;
}

/* ── COLOR CONTRAST: gallery hint e altri testi leggeri ────────── */
#galleria p[style*="letter-spacing:3px"],
.gallery-hint p {
  color: rgba(201,168,76,0.65) !important;
}
.gv2-tag {
  color: var(--oro) !important;
  opacity: 1 !important;
}

/* ── UNSIZED IMAGES: aspect-ratio per prevenire layout shift ───── */
.gallery-v2 .gv2-item img,
.gallery-cinematic .gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.gv2-feat img { aspect-ratio: 16/9; }
.gv2-tall img { aspect-ratio: 9/16; }
.gv2-med  img { aspect-ratio: 4/3; }
.hero-slide img { aspect-ratio: 16/9; }
/* ═══════════════════════════════════════════════════════════════
   GLIGHTBOX — override premium
   ═══════════════════════════════════════════════════════════════ */
.glightbox-open { overflow: hidden; }

.glightbox-container .gbtn-close {
  background: rgba(9,7,13,0.8) !important;
  border-radius: 50% !important;
  width: 48px !important;
  height: 48px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border: 1px solid rgba(201,168,76,0.3) !important;
  top: 20px !important;
  right: 20px !important;
}

.glightbox-container .gbtn-prev,
.glightbox-container .gbtn-next {
  background: rgba(9,7,13,0.7) !important;
  border-radius: 50% !important;
  width: 52px !important;
  height: 52px !important;
  border: 1px solid rgba(201,168,76,0.25) !important;
}

.glightbox-container .gbtn-prev:hover,
.glightbox-container .gbtn-next:hover,
.glightbox-container .gbtn-close:hover {
  background: rgba(201,168,76,0.15) !important;
  border-color: rgba(201,168,76,0.6) !important;
}

.glightbox-container .goverlay {
  background: rgba(9,7,13,0.95) !important;
  cursor: zoom-out !important;
}

.glightbox-container .gcurrent img {
  border-radius: 4px;
  box-shadow: 0 20px 80px rgba(0,0,0,0.8) !important;
}

/* Cursore pointer sulle gv2-item */
.gv2-item { cursor: zoom-in !important; }

/* ── RESPONSIVE IMAGES: ottimizzazione immagini mobile ─────────── */
.ev-img img,
.p-img img {
  content-visibility: auto;
  contain-intrinsic-size: 400px 300px;
}

/* Aspect ratio stabili per prevenire CLS */
.ev-img { aspect-ratio: 4/3; overflow: hidden; }
.ev-img img { width: 100%; height: 100%; object-fit: cover; }

/* Hero eyebrow mobile: mai su due righe */
@media (max-width: 480px) {
  .hero-eyebrow {
    font-size: 8px !important;
    letter-spacing: 1.5px !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   BENTO GALLERY — Nuovo layout dinamico
   ═══════════════════════════════════════════════════════════════ */

.bento-gallery {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  grid-auto-rows: 280px;
  grid-auto-flow: dense;
  max-width: 1400px;
  margin: 0 auto;
}

.bento-item {
  position: relative;
  overflow: hidden;
  border-radius: 12px;
  cursor: zoom-in;
  transition: transform .5s cubic-bezier(.23,1,.32,1);
  background: rgba(9,7,13,.6);
}

.bento-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .6s cubic-bezier(.23,1,.32,1);
}

.bento-item:hover {
  transform: scale(1.02);
  z-index: 10;
}

.bento-item:hover img {
  transform: scale(1.08);
}

.bento-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(9,7,13,.95) 0%, transparent 60%);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 24px;
  opacity: 0;
  transform: translateY(12px);
  transition: opacity .4s ease, transform .4s cubic-bezier(.23,1,.32,1);
}

.bento-item:hover .bento-overlay {
  opacity: 1;
  transform: translateY(0);
}

.bento-tag {
  font-family: var(--fb);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--oro);
  margin-bottom: 8px;
  display: inline-block;
}

.bento-cap {
  font-family: var(--ft);
  font-size: 18px;
  font-weight: 400;
  color: var(--bianco);
  margin: 0;
  line-height: 1.3;
}

/* Mobile: Swipe carousel */
@media (max-width: 767px) {
  .bento-gallery {
    grid-template-columns: 1fr;
    grid-auto-rows: 320px;
    gap: 12px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding: 0 20px;
  }
  
  .bento-item {
    scroll-snap-align: center;
    border-radius: 8px;
  }
  
  .bento-hero,
  .bento-wide,
  .bento-tall {
    grid-column: span 1 !important;
    grid-row: span 1 !important;
  }
  
  .bento-overlay {
    opacity: 1;
    transform: translateY(0);
  }
  
  .bento-cap {
    font-size: 16px;
  }
}

/* Tablet */
@media (min-width: 768px) and (max-width: 1023px) {
  .bento-gallery {
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
    grid-auto-rows: 240px;
  }
  
  .bento-hero {
    grid-column: span 2 !important;
    grid-row: span 2 !important;
  }
  
  .bento-wide {
    grid-column: span 2 !important;
  }
  
  .bento-tall {
    grid-row: span 2 !important;
  }
}


/* ═══════════════════════════════════════════════════════════════
   SLIDER GALLERIA — Layout orizzontale full-width
   ═══════════════════════════════════════════════════════════════ */

.palazzo-slider {
  position: relative;
  width: 100%;
  max-width: 1400px;
  height: 600px;
  margin: 0 auto;
  overflow: hidden;
  border-radius: 12px;
}

.slider-track {
  display: flex;
  height: 100%;
  transition: transform 0.6s cubic-bezier(0.23, 1, 0.32, 1);
}

.slide {
  min-width: 100%;
  height: 100%;
  position: relative;
  flex-shrink: 0;
}

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

.slide-info {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 40px;
  background: linear-gradient(to top, rgba(9,7,13,0.95) 0%, transparent 100%);
  color: var(--bianco);
}

.slide-tag {
  display: inline-block;
  font-family: var(--fb);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--oro);
  margin-bottom: 8px;
}

.slide-title {
  font-family: var(--ft);
  font-size: 32px;
  font-weight: 300;
  margin: 0 0 16px 0;
  color: var(--bianco);
}

.slide-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 24px;
  background: rgba(201,168,76,0.15);
  border: 1px solid var(--oro);
  color: var(--oro);
  font-family: var(--fb);
  font-size: 11px;
  letter-spacing: 1px;
  text-transform: uppercase;
  border-radius: 4px;
  cursor: pointer;
  transition: all 0.3s ease;
  text-decoration: none;
}

.slide-btn:hover {
  background: var(--oro);
  color: var(--nero);
}

.slider-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  background: rgba(9,7,13,0.8);
  border: 1px solid rgba(201,168,76,0.3);
  color: var(--oro);
  font-size: 18px;
  border-radius: 50%;
  cursor: pointer;
  transition: all 0.3s ease;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
}

.slider-nav:hover {
  background: rgba(201,168,76,0.2);
  border-color: var(--oro);
}

.slider-prev {
  left: 20px;
}

.slider-next {
  right: 20px;
}

.slider-dots {
  position: absolute;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
  z-index: 10;
}

.slider-dots button {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: 1px solid var(--oro);
  background: transparent;
  cursor: pointer;
  transition: all 0.3s ease;
  padding: 0;
}

.slider-dots button.active {
  background: var(--oro);
  width: 24px;
  border-radius: 5px;
}

/* Mobile */
@media (max-width: 767px) {
  .palazzo-slider {
    height: 500px;
  }
  
  .slide-title {
    font-size: 24px;
  }
  
  .slide-info {
    padding: 24px;
  }
  
  .slider-nav {
    width: 40px;
    height: 40px;
    font-size: 14px;
  }
  
  .slider-prev {
    left: 10px;
  }
  
  .slider-next {
    right: 10px;
  }
}



/* Surgical menu fix: prevent desktop nav overlap/ghost rows after adding La Terrazza */
@media (max-width: 1219px){
  .nav-links{display:none!important;}
  .burger{display:flex;}
}
@media (min-width: 1220px){
  .burger{display:none;}
}
@media (max-height: 760px){
  .mob-menu{gap:22px;}
  .mob-menu a{font-size:clamp(30px,7vh,46px);}
}


/* ================================================================
   MOBILE REFINEMENT + PWA PERF PATCH — 2026-05-19
   Solo mobile: layout, immagini, scroll fluido. Desktop invariato.
   ================================================================ */
@media (max-width: 767px) {
  html, body { width: 100%; max-width: 100%; overflow-x: hidden; }
  body { -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
  .site { overflow-x: clip; }

  /* Menu mobile più stabile: niente overflow verticale o voci schiacciate */
  #nav { padding: 12px 16px; min-height: 64px; background: linear-gradient(to bottom, rgba(9,7,13,.72), rgba(9,7,13,.22)); }
  #nav.scrolled { padding: 9px 16px; background: rgba(9,7,13,.96); }
  .nav-logo img { height: 34px !important; }
  #nav.scrolled .nav-logo img { height: 32px !important; }
  .nav-right { gap: 8px; }
  .lang-wrap { gap: 0; }
  .lang-btn { font-size: 10px; letter-spacing: 1.5px; min-width: 36px !important; min-height: 36px !important; padding: 6px 8px !important; }
  .burger { min-width: 44px; min-height: 44px; align-items: center; justify-content: center; }
  .mob-menu { justify-content: flex-start; gap: 14px; padding: max(92px, calc(env(safe-area-inset-top) + 86px)) 22px 32px; overflow-y: auto; -webkit-overflow-scrolling: touch; }
  .mob-menu a { font-size: clamp(28px, 8.2vw, 42px); line-height: 1.02; text-align: center; }
  .mob-lang { margin-top: 4px; }

  /* Hero mobile: foto precaricata subito, poi video mobile leggero */
  .hero { min-height: 640px; height: 100svh; }
  .hero-video { display: block !important; opacity: 0; }
  .hero-video.is-loaded { opacity: 1 !important; }
  .hero-slides--fallback { display: block !important; opacity: 1; transition: opacity 1.15s cubic-bezier(.4,0,.2,1); }
  .hero.video-ready .hero-slides--fallback { opacity: 0 !important; pointer-events: none; }
  .hero-slide img { transform: scale(1.02); object-position: center center; }
  .hero-content { padding-inline: 18px; max-width: 100%; }
  .hero-title { font-size: clamp(48px, 17vw, 76px) !important; line-height: .96; overflow-wrap: normal; }
  .hero-eyebrow { max-width: 92vw; margin-inline: auto; line-height: 1.55; white-space: normal !important; }
  .hero-sub { max-width: 88vw; margin-left: auto; margin-right: auto; }
  .hero-dots { bottom: 18px; gap: 2px; }
  .hero-dot { min-width: 30px !important; min-height: 30px !important; width: 30px; height: 30px; padding: 0; }
  .hero-dot::before { content: ''; display:block; width: 6px; height: 6px; border-radius: 99px; background: rgba(255,255,255,.45); }
  .hero-dot.on::before { width: 20px; background: var(--oro); }

  /* Griglie e immagini: rapporti stabili per evitare salti di layout */
  .container { padding-inline: 18px; }
  img { height: auto; }
  .palazzo-imgs, .eventi-grid, .exp-grid, .info-grid, .contatti-grid { min-width: 0; }
  .p-img, .ev-img, .g-item, .gallery-masonry-mobile a { content-visibility: auto; contain-intrinsic-size: 320px 240px; }
  .p-img-main { height: auto !important; aspect-ratio: 4 / 3; }
  .p-img-sm { height: auto !important; aspect-ratio: 4 / 3; }
  .ev-img { aspect-ratio: 4 / 3 !important; }

  /* Galleria homepage: da masonry a card verticali leggibili su smartphone */
  #galleria { padding: 72px 0 !important; }
  #galleria .sec-body { max-width: 92vw !important; }
  .gallery-masonry-mobile { columns: auto !important; column-count: auto !important; display: grid !important; grid-template-columns: 1fr !important; gap: 14px !important; padding-inline: 0 !important; }
  .gallery-masonry-mobile a { margin: 0 !important; border-radius: 10px !important; aspect-ratio: 4 / 3; min-height: 0; box-shadow: 0 18px 44px rgba(0,0,0,.28); }
  .gallery-masonry-mobile a img { width: 100% !important; height: 100% !important; object-fit: cover !important; }
  .gallery-masonry-mobile a div { padding: 16px !important; }
  .gallery-masonry-mobile a p { font-size: 17px !important; line-height: 1.2 !important; }
  .gallery-masonry-mobile a span { font-size: 8px !important; letter-spacing: 1.7px !important; }

  /* Terrazza: stessa grafica, ma proporzioni più sane su mobile */
  #terrazza .container { padding: 72px 18px !important; }
  .terrazza-split { display: block !important; }
  .terrazza-title { font-size: clamp(38px, 11vw, 56px) !important; }
  .terrazza-subtitle { font-size: 15px !important; line-height: 1.75 !important; }
  .terrazza-images { margin-bottom: 68px; }
  .terrazza-img-main { transform: none !important; border-radius: 10px !important; }
  .terrazza-img-main img { aspect-ratio: 4 / 5; object-fit: cover; }
  .terrazza-img-secondary { width: 42% !important; right: 8px !important; bottom: -34px !important; border-width: 3px !important; transform: rotate(2deg) !important; }
  .terrazza-img-secondary img { aspect-ratio: 4 / 5; object-fit: cover; }
  .terrazza-content { transform: none !important; }
  .terrazza-feature > div { gap: 12px !important; }
  .terrazza-feature h3 { font-size: 19px !important; line-height: 1.16; }
  .terrazza-feature p { font-size: 13.5px !important; line-height: 1.75 !important; }
  .terrazza-stats { margin-top: 52px !important; padding-top: 36px !important; grid-template-columns: 1fr !important; gap: 24px !important; }

  /* Journey verticale meno pesante e senza scroll orizzontale fantasma */
  .journey-panel { height: 62svh !important; min-height: 440px; }
  .journey-panel > img { object-position: center center; }
  .journey-panel-body { font-size: 14px; line-height: 1.72; }

  /* CTA e floating WA con safe-area */
  .wa-float { right: 14px; bottom: max(14px, env(safe-area-inset-bottom)); padding: 13px 15px; border-radius: 999px; }
  .wa-float .wa-label { display: none; }
  #priv-banner { left: 12px; right: 12px; bottom: calc(78px + env(safe-area-inset-bottom)); }
  .priv-box { padding: 16px; gap: 12px; }
  .priv-text { font-size: 13px; line-height: 1.55; padding-right: 26px; }
  .priv-btns { gap: 8px; }
  .priv-accept, .priv-reject { flex: 1 1 130px; min-height: 44px; padding: 12px 14px; }
  .cta-urgency { font-size: 11px; line-height: 1.45; }

  /* Lightbox meno invasiva su mobile */
  .glightbox-container .gbtn-prev, .glightbox-container .gbtn-next { width: 42px !important; height: 42px !important; }
  .glightbox-container .gbtn-close { width: 44px !important; height: 44px !important; top: max(12px, env(safe-area-inset-top)) !important; right: 12px !important; }

  /* Evita animazioni costose e repaint continui su mobile */
  #p-canvas, .cur-dot { display: none !important; }
  .magnetic { transform: none !important; }
}

@media (max-width: 380px) {
  .hero-title { font-size: clamp(42px, 15vw, 60px) !important; }
  .mob-menu a { font-size: clamp(25px, 7.6vw, 34px); }
  .hero-btns .btn-oro, .hero-btns .btn-ghost, .hero-btns button, .hero-btns a { max-width: 292px; }
}
