:root{
  /* Tema CALCE & MARE — fresco, luminoso, mediterraneo */
  --crema:#FCFAF3; --crema2:#FFFFFF; --antracite:#21302C; --ink:#18231F;
  --sage:#9FB4A6; --sage-d:#6C8779; --rovere:#D08C5B; --sun:#2F7C86; --sun-d:#245F67;
  --white:#fff; --muted:#6E756F;
  --serif:'DM Serif Display',Georgia,serif; --sans:'Mulish',system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--crema);line-height:1.65;font-weight:300;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:1240px;margin:0 auto;padding:0 28px}
.eyebrow{font-weight:600;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--sun)}
h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.08;letter-spacing:.01em}
h2.section-title{font-size:clamp(2.1rem,4.4vw,3.4rem);color:var(--antracite);margin:.4em 0 .3em}
.lead{font-size:1.12rem;color:var(--muted);max-width:62ch}
.btn{display:inline-block;font-weight:500;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;padding:15px 30px;border-radius:2px;transition:.25s;cursor:pointer;border:1px solid transparent}
.btn-sun{background:var(--sun);color:#fff}.btn-sun:hover{background:var(--sun-d)}
.btn-ghost{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.7)}.btn-ghost:hover{background:rgba(255,255,255,.18)}
.btn-dark{background:var(--antracite);color:#fff}.btn-dark:hover{background:#23252a}
.btn-outline{border-color:var(--antracite);color:var(--antracite)}.btn-outline:hover{background:var(--antracite);color:#fff}

/* HEADER */
header{position:fixed;top:0;left:0;right:0;z-index:100;transition:.35s}
header.solid{position:sticky;background:var(--crema2);box-shadow:0 1px 0 rgba(0,0,0,.06)}
header .bar{display:flex;align-items:center;justify-content:space-between;padding:14px 28px;max-width:1240px;margin:0 auto}
.brand img{height:50px;width:auto;display:block}
.brand .lw{display:block}.brand .ld{display:none}
header.scrolled,header.solid{background:var(--crema2);box-shadow:0 1px 0 rgba(0,0,0,.06)}
header.scrolled .brand .lw,header.solid .brand .lw{display:none}
header.scrolled .brand .ld,header.solid .brand .ld{display:block}
header.scrolled .brand img,header.solid .brand img{height:44px}
nav.main{display:flex;align-items:center;gap:30px}
nav.main a{color:#fff;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;transition:.25s;opacity:.95;text-shadow:0 1px 8px rgba(0,0,0,.3)}
nav.main a:hover{color:var(--rovere)}
header.scrolled nav.main a,header.solid nav.main a{color:var(--antracite);text-shadow:none}
.btn-nav{padding:11px 22px;font-size:.74rem;border:1px solid rgba(255,255,255,.7);color:#fff;border-radius:2px;letter-spacing:.12em;text-transform:uppercase;transition:.25s}
.btn-nav:hover{background:var(--sun);border-color:var(--sun)}
header.scrolled .btn-nav,header.solid .btn-nav{background:var(--sun);color:#fff;border-color:var(--sun)}
header.scrolled nav.main a.btn-nav,header.solid nav.main a.btn-nav{color:#fff}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:0}
.burger span{width:26px;height:2px;background:#fff;transition:.3s;box-shadow:0 1px 4px rgba(0,0,0,.3)}
header.scrolled .burger span,header.solid .burger span{background:var(--antracite);box-shadow:none}

/* HERO */
.hero{position:relative;height:100vh;min-height:620px;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;overflow:hidden}
.hero>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 35%}
.hero::after{content:"";position:absolute;inset:0;background:
  radial-gradient(ellipse 90% 65% at 50% 60%, rgba(0,0,0,.6), rgba(0,0,0,0) 72%),
  linear-gradient(180deg, rgba(20,20,18,.55) 0%, rgba(20,20,18,.22) 40%, rgba(20,20,18,.85) 100%)}
.hero .inner{position:relative;z-index:2;max-width:900px;padding:40px 24px}
.hero .eyebrow{color:#fff;opacity:.95}
.hero h1{font-size:clamp(2.8rem,7vw,5.4rem);margin:.16em 0 .34em;text-shadow:0 2px 40px rgba(0,0,0,.45)}
.hero p.sub{font-size:1.18rem;font-weight:300;max-width:58ch;margin:0 auto 2em;opacity:.97;text-shadow:0 1px 18px rgba(0,0,0,.5)}
.hero .cta-row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.scrollcue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:2;color:#fff;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;opacity:.85}
.scrollcue::before{content:"";display:block;width:1px;height:38px;background:rgba(255,255,255,.8);margin:0 auto 10px;animation:cue 2s infinite}
@keyframes cue{0%,100%{opacity:.2;transform:scaleY(.5)}50%{opacity:1;transform:scaleY(1)}}

/* page hero (interior) */
.phero{position:relative;min-height:62vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.phero>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.phero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,20,18,.45),rgba(20,20,18,.2) 45%,rgba(20,20,18,.8))}
.phero .inner{position:relative;z-index:2;width:100%;text-align:left;padding:0 28px 50px}
.phero h1{font-size:clamp(2.6rem,6vw,4.6rem);text-shadow:0 2px 30px rgba(0,0,0,.4)}
.phero .tema{font-size:1.1rem;opacity:.95;margin-top:6px;text-shadow:0 1px 12px rgba(0,0,0,.5)}
.crumbs{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;opacity:.9;margin-bottom:16px}
.crumbs a:hover{color:var(--rovere)}

.pad{padding:clamp(70px,9vw,130px) 0}
.pad-s{padding:clamp(48px,6vw,84px) 0}
.pad.wrap,.pad-s.wrap{padding-left:28px;padding-right:28px}
.center{text-align:center}
.intro .grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.payoff{font-family:var(--serif);font-style:italic;font-size:clamp(2.1rem,4.4vw,3.4rem);color:var(--antracite);line-height:1.2;margin:.2em 0 .15em}
.addr{margin-top:22px;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.addr b{color:var(--antracite);font-weight:600}

/* CASE */
.case-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;margin-top:48px}
.case{position:relative;overflow:hidden;border-radius:3px;aspect-ratio:4/3;cursor:pointer;display:block}
.case img{width:100%;height:100%;object-fit:cover;transition:transform .9s ease}
.case:hover img,.case:focus img{transform:scale(1.06)}
.case::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 38%,rgba(20,20,18,.8) 100%)}
.case .lab{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:28px;color:#fff}
.case .lab h3{font-size:2rem;margin-bottom:4px}
.case .lab .tema{font-size:.85rem;opacity:.92;font-weight:300}
.case .lab .meta{margin-top:12px;display:flex;align-items:center;gap:14px;font-size:.78rem;letter-spacing:.04em}
.case .lab .meta .g{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.16);backdrop-filter:blur(3px);padding:5px 11px;border-radius:30px}
.case .lab .go{color:var(--rovere);text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;opacity:0;transform:translateY(6px);transition:.3s}
.case:hover .lab .go,.case:focus .lab .go{opacity:1;transform:none}
.ico{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:1.6;flex:none}

/* SPAZI */
.spazi{background:var(--antracite);color:#fff}
.spazi .split{display:grid;grid-template-columns:1.05fr .95fr;align-items:stretch}
.spazi .ph{min-height:430px}.spazi .ph img{width:100%;height:100%;object-fit:cover}
.spazi .tx{padding:clamp(40px,6vw,84px);min-width:0}.spazi h2{color:#fff}.spazi .lead{color:rgba(255,255,255,.8)}
.spazi .mini{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:26px}
.spazi .mini img{height:150px;width:100%;object-fit:cover;border-radius:3px}

/* MAG */
.mag{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:200px;gap:18px;margin-top:48px}
.tile{position:relative;overflow:hidden;border-radius:3px}
.tile img{width:100%;height:100%;object-fit:cover;transition:transform .9s}
.tile:hover img{transform:scale(1.07)}
.tile .cap{position:absolute;left:0;bottom:0;right:0;padding:18px;color:#fff;z-index:2;font-family:var(--serif);font-size:1.5rem}
.tile::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 45%,rgba(0,0,0,.62))}
.t-big{grid-column:span 3;grid-row:span 2}.t-tall{grid-column:span 3;grid-row:span 2}.t-sm{grid-column:span 2}

/* BENEFITS */
.benefits{background:var(--sage)}
.ben-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;margin-top:46px}
.ben{text-align:center;color:#22302b}
.ben svg{width:42px;height:42px;margin:0 auto 16px;stroke:#22302b;fill:none;stroke-width:1.4}
.ben h3{font-size:1.35rem;margin-bottom:6px}.ben p{font-size:.92rem;color:#33433d;font-weight:300}

/* REVIEWS */
.rev{background:var(--crema2)}
.stars{color:var(--rovere);letter-spacing:4px;font-size:1.1rem}
.score{display:inline-flex;align-items:center;gap:12px;margin-top:8px;font-size:.95rem;color:var(--muted)}
.score b{font-family:var(--serif);font-style:normal;font-size:2rem;color:var(--sun);line-height:1}
.rev-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:42px}
.rev-card{background:#fff;border:1px solid #e6dfd0;border-radius:6px;padding:30px 28px;transition:.3s}
.rev-card:hover{transform:translateY(-3px);box-shadow:0 16px 36px rgba(0,0,0,.06)}
.rev-card .q{font-family:var(--serif);font-style:italic;font-size:1.16rem;line-height:1.42;color:var(--antracite);margin:12px 0 14px}
.rev-card .by{font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}

/* ITIN ACCORDION */
.acc{max-width:900px;margin:46px auto 0;text-align:left}
details.itm{border:1px solid #e0d9ca;border-radius:4px;background:#fff;margin-bottom:14px;transition:.3s}
details.itm[open]{box-shadow:0 16px 40px rgba(0,0,0,.07)}
details.itm summary{display:flex;align-items:center;gap:20px;padding:24px 26px;cursor:pointer;list-style:none}
details.itm summary::-webkit-details-marker{display:none}
.itm .num{font-family:var(--serif);font-size:2.6rem;color:var(--sage);line-height:1;flex:none;width:46px;text-align:center}
.itm .st{flex:1}.itm .st h3{font-size:1.55rem;color:var(--antracite)}.itm .st p{font-size:.92rem;color:var(--muted)}
.itm .plus{font-size:1.7rem;color:var(--sun);transition:.3s;flex:none;font-weight:300}
details.itm[open] .plus{transform:rotate(45deg)}
.itm .body{padding:4px 30px 30px;color:#3a3a36;border-top:1px solid #f0e9da}
.itm .body>p:first-child{margin-top:16px}
.itm .body h4{font-family:var(--sans);font-weight:600;font-size:.95rem;color:var(--antracite);margin:18px 0 4px;letter-spacing:.02em}
.itm .body p{font-size:.97rem;margin-bottom:8px;max-width:74ch}
.itm .body .cta{margin-top:20px}

/* FAQ */
.faq{max-width:840px;margin:40px auto 0;text-align:left}
details.q{border-bottom:1px solid #e0d9ca}
details.q summary{display:flex;justify-content:space-between;gap:18px;padding:22px 4px;cursor:pointer;list-style:none;font-family:var(--serif);font-size:1.35rem;color:var(--antracite)}
details.q summary::-webkit-details-marker{display:none}
details.q .plus{color:var(--sun);font-weight:300;transition:.3s}
details.q[open] .plus{transform:rotate(45deg)}
details.q .a{padding:0 4px 22px;color:var(--muted);max-width:74ch}

/* CTA banner */
.cta-banner{position:relative;color:#fff;text-align:center;overflow:hidden}
.cta-banner>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 30%}
.cta-banner::after{content:"";position:absolute;inset:0;background:rgba(20,20,18,.62)}
.cta-banner .inner{position:relative;z-index:2}
.cta-banner h2{color:#fff;font-size:clamp(2.2rem,4.6vw,3.6rem)}
.cta-banner p{max-width:54ch;margin:14px auto 30px;opacity:.94}

/* PRENOTA */
.prenota{background:var(--crema)}
.prenota .box{background:#fff;border:1px solid #e6dfd0;border-radius:4px;padding:clamp(34px,5vw,60px);text-align:center;max-width:820px;margin:40px auto 0}
.prenota .perks{display:flex;gap:28px;justify-content:center;flex-wrap:wrap;margin:24px 0 30px;font-size:.9rem;color:var(--muted)}
.prenota .perks b{color:var(--antracite);font-weight:600}
.note{font-size:.78rem;color:var(--muted);margin-top:18px}
#smoobu-booking{margin:6px 0 18px}
#smoobu-booking:empty{display:none}
#smoobu-booking iframe{width:100%;min-height:780px;border:0;border-radius:4px}
.smoobu-embed{margin:10px 0 4px;min-height:120px}
.smoobu-embed iframe{width:100%!important;border:0;border-radius:4px}
@media(max-width:600px){.smoobu-embed iframe{min-height:430px}.prenota .box{padding:22px 16px}}

/* GALLERY (apartment pages) */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:40px}
.gallery img{width:100%;height:260px;object-fit:cover;border-radius:3px;cursor:pointer;transition:.4s}
.gallery img:hover{filter:brightness(1.05);transform:scale(1.01)}
.amen-row{display:flex;flex-wrap:wrap;gap:12px;margin:26px 0 6px}
.chip{display:inline-flex;align-items:center;gap:8px;border:1px solid #e0d9ca;border-radius:30px;padding:9px 16px;font-size:.86rem;color:var(--antracite);background:#fff}
.chip svg{width:17px;height:17px;stroke:var(--sage-d);fill:none;stroke-width:1.6}
.guests-badge{display:inline-flex;align-items:center;gap:8px;background:var(--sage);color:#22302b;padding:8px 18px;border-radius:30px;font-weight:500;font-size:.92rem}
.apt-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:start}
.apt-grid .lead{margin-bottom:18px}
.apt-side{background:var(--crema2);border:1px solid #e6dfd0;border-radius:4px;padding:30px}
.apt-side h3{font-size:1.5rem;color:var(--antracite);margin-bottom:6px}
.other{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:40px}
.other a{position:relative;border-radius:3px;overflow:hidden;aspect-ratio:4/3;display:block}
.other img{width:100%;height:100%;object-fit:cover;transition:.6s}
.other a:hover img{transform:scale(1.06)}
.other span{position:absolute;left:0;bottom:0;right:0;padding:14px;color:#fff;z-index:2;font-family:var(--serif);font-size:1.3rem}
.other a::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 45%,rgba(0,0,0,.7))}

/* EXPERIENCE PAGES */
.exp-row{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;margin-top:46px}
.exp-row>div{text-align:left}
.exp-row h2,.exp-row p{text-align:left}
.exp-row img{width:100%;height:430px;object-fit:cover;border-radius:4px}
.exp-row h2{font-size:clamp(1.7rem,3vw,2.4rem);color:var(--antracite);margin-bottom:12px}
.exp-row p{font-size:1.05rem;color:#3a3a36;max-width:54ch}
.exp-text{max-width:74ch;margin:40px 0 0;text-align:left}
.exp-text h2{font-size:clamp(1.7rem,3vw,2.4rem);color:var(--antracite);margin-bottom:12px}
.exp-text p{font-size:1.08rem;color:#3a3a36}
.exp-intro{font-size:1.3rem;color:var(--antracite);max-width:72ch;text-align:left}
.seo-desc{margin-top:30px;max-width:78ch;text-align:left;color:#3a3a36;font-size:1rem}
.seo-desc h2{font-size:1.5rem;color:var(--antracite);margin-bottom:10px}
.exp-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:40px}
.exp-gallery img{width:100%;height:260px;object-fit:cover;border-radius:3px}
.tip{background:var(--sage);color:#22302b;border-radius:6px;padding:34px 38px;margin-top:50px;max-width:860px}
.dist{margin-top:24px;font-size:.95rem;color:var(--muted)}

/* FOOTER */
footer{background:var(--ink);color:rgba(255,255,255,.75);font-weight:300}
footer .grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding:70px 0 40px}
footer .flogo{height:60px;width:auto;margin-bottom:16px}
footer h4{font-weight:600;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:#fff;margin-bottom:16px}
footer a{display:block;color:rgba(255,255,255,.7);font-size:.92rem;padding:4px 0;transition:.2s}
footer a:hover{color:var(--rovere)}
footer .pay{font-family:var(--serif);font-style:italic;color:var(--sage);font-size:1.3rem;margin-top:6px}
footer .bottom{border-top:1px solid rgba(255,255,255,.12);padding:22px 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.78rem;color:rgba(255,255,255,.5)}

/* BOOKING BAR */
.bookbar{position:relative;z-index:20;margin:-48px auto 0;max-width:1040px;background:#fff;border-radius:14px;box-shadow:0 24px 60px rgba(0,0,0,.16);display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr auto;overflow:hidden}
.bookbar .f{padding:18px 24px;border-right:1px solid #ece4d6}
.bookbar .f label{display:block;font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:5px}
.bookbar .f{transition:background .2s}
.bookbar .f:focus-within{background:#f6f1e8}
.bookbar .f .v,.bookbar .f select.v,.bookbar .f input.v{font-family:var(--sans);font-weight:400;font-size:1rem;color:var(--antracite);line-height:1.3}
.bookbar .f select.v,.bookbar .f input.v{border:0;background:transparent;width:100%;outline:none;cursor:pointer;-webkit-appearance:none;appearance:none}
.bookbar .f select.v{padding-right:22px;background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" viewBox="0 0 24 24" fill="none" stroke="%232F7C86" stroke-width="2.5" stroke-linecap="round" stroke-linejoin="round"><path d="M6 9l6 6 6-6"/></svg>');background-repeat:no-repeat;background-position:right 0 center}
.bookbar .f input.v[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.75;filter:invert(36%) sepia(45%) saturate(560%) hue-rotate(140deg)}
.bookbar .f input.v::-webkit-datetime-edit{color:var(--antracite)}
.bookbar .go{display:flex;align-items:center;padding:0 16px}
.bookbar .go .btn{cursor:pointer;white-space:nowrap}
@media(max-width:860px){.bookbar{grid-template-columns:1fr 1fr;margin:-26px 16px 0}.bookbar .go{grid-column:1/-1;padding:14px}.bookbar .f:nth-child(2){border-right:0}}

/* VIDEO */
.videowrap{background:var(--ink)}
.video{display:block;position:relative;max-width:1040px;margin:34px 0 0;aspect-ratio:16/9;border-radius:6px;overflow:hidden;box-shadow:0 30px 70px rgba(0,0,0,.35)}
.video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-facade{display:block;cursor:pointer}
.video-facade img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.video-facade::after{content:"";position:absolute;inset:0;background:rgba(15,18,18,.32);transition:.3s}
.video-facade:hover::after{background:rgba(15,18,18,.18)}
.video-facade .playbtn{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:2;width:88px;height:88px;border-radius:50%;background:rgba(0,0,0,.45);border:2px solid #fff;color:#fff;display:grid;place-items:center;font-size:1.7rem;padding-left:6px;transition:.25s}
.video-facade:hover .playbtn{background:var(--sun);border-color:var(--sun);transform:translate(-50%,-50%) scale(1.08)}
.video-facade .vlabel{position:absolute;z-index:2;left:0;right:0;bottom:22px;text-align:center;color:#fff;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;text-shadow:0 1px 8px rgba(0,0,0,.5)}

.reveal{opacity:0;transform:translateY(26px);transition:.8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* MOBILE MENU */
.mnav{position:fixed;inset:0;background:var(--antracite);z-index:120;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:26px;transform:translateY(-100%);transition:.4s;opacity:0}
.mnav.open{transform:none;opacity:1}
.mnav a{color:#fff;font-family:var(--serif);font-size:1.8rem}
.mclose{position:absolute;top:24px;right:28px;font-size:2rem;color:#fff;background:none;border:0;cursor:pointer}

/* LIGHTBOX */
.lb{position:fixed;inset:0;z-index:200;background:rgba(18,18,16,.97);display:none;flex-direction:column}
.lb.open{display:flex}
.lb-top{display:flex;align-items:center;justify-content:space-between;padding:16px 22px;color:#fff;flex:none}
.lb-top h3{font-size:1.5rem}
.lb-close{background:none;border:0;color:#fff;font-size:2rem;cursor:pointer;line-height:1}
.lb-stage{position:relative;flex:1;display:flex;align-items:center;justify-content:center;background:#000;min-height:0;overflow:hidden}
.lb-stage img{max-width:100%;max-height:100%;object-fit:contain}
.lb-arrow{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.4);color:#fff;border:1px solid rgba(255,255,255,.4);width:48px;height:48px;border-radius:50%;font-size:1.5rem;cursor:pointer;transition:.2s;z-index:2}
.lb-arrow:hover{background:var(--sun);border-color:var(--sun)}
.lb-prev{left:18px}.lb-next{right:18px}
.lb-count{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);color:#fff;font-size:.78rem;background:rgba(0,0,0,.45);padding:4px 12px;border-radius:20px}

@media(max-width:900px){
  .intro .grid{grid-template-columns:1fr;gap:34px}
  .case-grid{grid-template-columns:1fr}
  .spazi .split{grid-template-columns:1fr}
  .spazi .ph{display:none}
  .mag{grid-template-columns:repeat(2,1fr);grid-auto-rows:170px}
  .t-big,.t-tall,.t-sm{grid-column:span 2;grid-row:span 1}.t-big,.t-tall{grid-row:span 2}
  .ben-grid{grid-template-columns:1fr 1fr;gap:30px 20px}
  .apt-grid{grid-template-columns:1fr;gap:30px}
  .rev-grid{grid-template-columns:1fr}
  .exp-row{grid-template-columns:1fr;gap:24px}
  .exp-row img{height:300px}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .other{grid-template-columns:1fr 1fr}
  footer .grid{grid-template-columns:1fr;gap:30px}
  nav.main,.btn-nav{display:none}.burger{display:flex}
}
/* ROUNDED BUTTONS (Calce) */
.btn,.btn-nav{border-radius:30px}

/* LAYOUT BOUTIQUE (homepage) */
.ribbon{background:var(--antracite);color:#fff;text-align:center;font-size:.76rem;letter-spacing:.12em;padding:9px;text-transform:uppercase}
.bhero{position:relative;height:66vh;min-height:460px;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;overflow:hidden}
.bhero>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.bhero::after{content:"";position:absolute;inset:0;background:
  radial-gradient(ellipse 85% 70% at 50% 52%, rgba(0,0,0,.5), rgba(0,0,0,0) 70%),
  linear-gradient(180deg, rgba(0,0,0,.3) 0%, rgba(0,0,0,.12) 42%, rgba(0,0,0,.68) 100%)}
/* carosello orizzontale */
.carousel{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;padding:8px 0 18px;margin-top:36px;scrollbar-width:thin}
.carousel::-webkit-scrollbar{height:6px}
.carousel::-webkit-scrollbar-thumb{background:#d8cdb9;border-radius:6px}
.carousel img{flex:0 0 auto;width:440px;max-width:82vw;height:300px;object-fit:cover;border-radius:8px;scroll-snap-align:center;cursor:pointer;transition:.3s}
.carousel img:hover{filter:brightness(1.04)}
.carousel-hint{margin-top:8px;color:var(--muted);font-size:.82rem;font-style:italic}
@media(max-width:560px){.carousel img{width:80vw;height:240px}}
/* carosello dentro il riquadro verde "Spazi da condividere" */
.spazi .carousel{margin-top:26px}
.spazi .carousel img{width:255px;height:185px;max-width:74vw}
.spazi .carousel::-webkit-scrollbar-thumb{background:rgba(255,255,255,.35)}
.spazi .carousel-hint{color:rgba(255,255,255,.65)}
.bhero .in{position:relative;z-index:2;padding:0 24px;max-width:920px}
.bhero h1{font-size:clamp(2.5rem,5.2vw,4.4rem);color:#fff;text-shadow:0 2px 30px rgba(0,0,0,.4);margin:.08em 0 .12em}
.bhero p{opacity:.96;font-size:1.12rem;margin-top:4px}
.scrollmouse{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:3;width:1px;height:50px;background:rgba(255,255,255,.28);overflow:hidden}
.scrollmouse::after{content:"";position:absolute;left:0;top:0;width:100%;height:45%;background:#fff;animation:lineDown 1.9s ease-in-out infinite}
@keyframes lineDown{0%{transform:translateY(-110%)}55%{transform:translateY(160%)}100%{transform:translateY(160%)}}
.facts{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin:62px 0 0;text-align:center}
.facts .n{font-family:var(--serif);font-size:2.4rem;color:var(--sun);line-height:1}
.facts .l{font-size:.84rem;color:var(--muted);margin-top:6px}
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:42px}
.card{background:#fff;border:1px solid #e9e1d2;border-radius:12px;overflow:hidden;transition:.3s}
.card:hover{transform:translateY(-4px);box-shadow:0 20px 44px rgba(0,0,0,.08)}
.card>img{width:100%;height:250px;object-fit:cover}
.card .cb{padding:20px 22px}
.card .cb h3{font-size:1.6rem;color:var(--antracite)}
.card .cb .tema{color:var(--muted);font-size:.92rem;margin:4px 0 14px}
.card .cb .ft{display:flex;justify-content:space-between;align-items:center;gap:10px}
.card .cb .g{font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;color:var(--sage-d)}
.exp3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:42px}
.exp3 a{position:relative;border-radius:10px;overflow:hidden;height:240px;display:block}
.exp3 img{width:100%;height:100%;object-fit:cover;transition:.7s}
.exp3 a:hover img{transform:scale(1.06)}
.exp3 span{position:absolute;left:0;right:0;bottom:0;padding:16px;color:#fff;z-index:2;font-family:var(--serif);font-size:1.4rem}
.exp3 a::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 48%,rgba(0,0,0,.66))}
@media(max-width:860px){.facts{grid-template-columns:1fr 1fr;gap:32px 18px}.cards{grid-template-columns:1fr}.exp3{grid-template-columns:1fr}}

/* LAYOUT RIVISTA — homepage editoriale */
.hsplit{display:grid;grid-template-columns:1fr 1fr;min-height:90vh}
.hsplit .tx{display:flex;flex-direction:column;justify-content:center;padding:7vw 5vw}
.hsplit .tx h1{font-size:clamp(2.6rem,4.6vw,4.6rem);margin:.16em 0 .34em;color:var(--antracite);line-height:1.05}
.hsplit .tx p.sub{font-size:1.15rem;color:var(--muted);max-width:46ch;margin-bottom:1.8em}
.hsplit .ph{position:relative;overflow:hidden;min-height:50vh}
.hsplit .ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.editorial-head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;border-bottom:1px solid #e6dfcf;padding-bottom:18px;margin-bottom:48px}
.editorial-head h2{font-size:clamp(2rem,3.6vw,3rem);color:var(--antracite);margin:0}
.rooms{display:flex;flex-direction:column;gap:64px}
.room{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.room:nth-child(even) .room-img{order:2}
.room-img{overflow:hidden;border-radius:6px}
.room-img img{width:100%;height:460px;object-fit:cover;transition:.9s}
.room:hover .room-img img{transform:scale(1.05)}
.room .num{font-family:var(--serif);font-size:3.2rem;color:var(--sage);line-height:1}
.room h3{font-size:2.4rem;color:var(--antracite);margin:4px 0 10px}
.room .tema{color:var(--muted);font-size:1.05rem;margin-bottom:10px}
.room .meta{display:inline-flex;align-items:center;gap:7px;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--sage-d);margin-bottom:22px}
@media(max-width:860px){
  .hsplit{grid-template-columns:1fr}.hsplit .ph{height:56vh;order:-1}
  .room{grid-template-columns:1fr;gap:18px}.room:nth-child(even) .room-img{order:0}.room-img img{height:300px}
  .editorial-head{flex-direction:column;align-items:flex-start;gap:8px}
}

@media(max-width:520px){
  .mag{grid-template-columns:1fr}.t-big,.t-tall,.t-sm{grid-column:span 1}
  .ben-grid{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr}.gallery img{height:230px}
  .other{grid-template-columns:1fr}
  .hero .cta-row{flex-direction:column}.hero .cta-row .btn{width:100%}
  .itm .num{font-size:2rem;width:34px}.itm .st h3{font-size:1.3rem}
}

/* ===== Language switcher ===== */
.langsw{display:inline-flex;gap:12px;align-items:center}
.langsw a,.langsw .on{font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;transition:.25s}
.langsw a{opacity:.95;font-weight:inherit}
.langsw a:hover{color:var(--rovere)}
.langsw .on{font-weight:800;color:var(--antracite);opacity:1}
.mnav .langsw{margin:22px 0 0;gap:20px;justify-content:center}
.mnav .langsw a,.mnav .langsw .on{font-size:1rem}
