/* ============================================================
   Dimora Tauro — B&B Fasano (BR), Puglia
   Stylesheet · editorial Mediterranean
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --terracotta:#C2714F;
  --terracotta-deep:#A85B3C;
  --olive:#6B7C4E;
  --olive-deep:#56653E;
  --cream:#F5EFE0;
  --cream-deep:#ECE3CF;
  --graphite:#2E2E2B;
  --graphite-soft:#4d4d47;
  --adriatic:#5B8FA8;
  --adriatic-deep:#4A7A92;
  --line:#e3dccb;
  --paper:#FBF8F0;
  --white:#ffffff;

  /* swappable accent (Tweaks) */
  --accent:var(--terracotta);
  --accent-deep:var(--terracotta-deep);

  --serif:"Cormorant Garamond", Georgia, serif;
  --sans:"DM Sans", system-ui, -apple-system, sans-serif;

  --maxw:1240px;
  --gut:clamp(20px,5vw,64px);
  --r:3px;

  --shadow-s:0 2px 14px rgba(46,46,43,.07);
  --shadow-m:0 16px 50px -18px rgba(46,46,43,.28);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--graphite);
  background:var(--paper);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.04;margin:0;letter-spacing:.002em}

/* ---------- Helpers ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut)}
.eyebrow{
  font-family:var(--sans);font-size:12.5px;font-weight:600;
  letter-spacing:.28em;text-transform:uppercase;color:var(--accent);
  display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--accent);opacity:.7}
.eyebrow.center::after{content:"";width:26px;height:1px;background:var(--accent);opacity:.7}
.eyebrow.olive{color:var(--olive)}
.eyebrow.olive::before,.eyebrow.olive.center::after{background:var(--olive)}
.sec{padding-block:clamp(64px,9vw,128px)}
.sec--cream{background:var(--cream)}
.sec--paper{background:var(--paper)}
.sec-head{max-width:720px}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head h2{font-size:clamp(34px,5.4vw,62px);margin-top:18px;letter-spacing:-.01em}
.sec-head p{margin:18px 0 0;color:var(--graphite-soft);font-size:clamp(16px,1.5vw,18.5px);max-width:60ch}
.sec-head.center p{margin-inline:auto}
.serif-i{font-family:var(--serif);font-style:italic}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  padding:15px 28px;border-radius:var(--r);font-weight:600;font-size:14.5px;
  letter-spacing:.02em;border:1px solid transparent;transition:.4s var(--ease);
  white-space:nowrap;
}
.btn svg{width:16px;height:16px}
.btn--fill{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn--fill:hover{background:var(--accent-deep);border-color:var(--accent-deep);transform:translateY(-2px);box-shadow:var(--shadow-m)}
.btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn--ghost:hover{background:rgba(255,255,255,.12);border-color:#fff}
.btn--ink{background:transparent;color:var(--graphite);border-color:var(--line)}
.btn--ink:hover{border-color:var(--accent);color:var(--accent)}
.btn--lg{padding:17px 34px;font-size:15px}
.btn--wide{width:100%}

.link-arrow{
  display:inline-flex;align-items:center;gap:.5em;font-weight:600;font-size:14px;
  letter-spacing:.04em;color:var(--accent);text-transform:uppercase;
}
.link-arrow svg{width:15px;height:15px;transition:transform .4s var(--ease)}
.link-arrow:hover svg{transform:translateX(5px)}

/* ============================================================
   HEADER
   ============================================================ */
.head{
  position:fixed;inset:0 0 auto 0;z-index:60;
  transition:background .5s var(--ease),box-shadow .5s var(--ease),border-color .5s;
  border-bottom:1px solid transparent;
}
.head__in{display:flex;align-items:center;gap:28px;height:78px}
.brand{display:flex;align-items:center;gap:13px;color:#fff;transition:color .5s}
.brand__mark{
  position:relative;width:42px;height:42px;border:1.5px solid currentColor;border-radius:50%;
  display:grid;place-items:center;font-family:var(--serif);font-size:17px;
  letter-spacing:.04em;flex:none;transition:.5s;
}
.brand__mark--logo{
  width:48px;height:48px;border:0;background:#fff;overflow:hidden;color:#b9973c;
  box-shadow:0 3px 14px rgba(0,0,0,.12);
}
.brand__mark--logo img{width:100%;height:100%;object-fit:contain;display:block}
.brand__mark--logo:has(img) span{display:none}
.brand__mark--logo::before{content:"";position:absolute;width:36px;height:36px;border:1px solid #b9973c;border-radius:50%;opacity:.85;display:none}
.brand__mark--logo span{position:relative;display:grid;place-items:center;font-family:var(--serif);font-size:18px;font-weight:600;color:#b9973c}
.brand__name{font-family:var(--serif);font-size:23px;line-height:1;letter-spacing:.01em}
.brand__sub{display:block;font-family:var(--sans);font-size:9.5px;font-weight:600;
  letter-spacing:.34em;text-transform:uppercase;opacity:.72;margin-top:4px}
.nav{display:flex;align-items:center;gap:30px;margin-left:auto}
.nav__link{
  position:relative;color:#fff;font-size:14.5px;font-weight:500;letter-spacing:.015em;
  transition:color .5s,opacity .3s;opacity:.92;
}
.nav__link::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1.5px;
  background:var(--accent);transition:width .4s var(--ease)}
.nav__link:hover{opacity:1}
.nav__link:hover::after{width:100%}

.head__right{display:flex;align-items:center;gap:18px;margin-left:6px}
/* language switcher */
.lang{position:relative}
.lang__btn{display:flex;align-items:center;gap:7px;background:none;border:none;color:#fff;
  font-weight:600;font-size:13px;letter-spacing:.08em;padding:8px 4px;transition:color .5s}
.lang__btn svg{width:12px;height:12px;transition:transform .3s}
.lang[data-open="true"] .lang__btn svg{transform:rotate(180deg)}
.lang__menu{
  position:absolute;top:calc(100% + 12px);right:0;background:#fff;border:1px solid var(--line);
  border-radius:var(--r);box-shadow:var(--shadow-m);padding:6px;min-width:148px;
  opacity:0;visibility:hidden;transform:translateY(-8px);transition:.32s var(--ease);
}
.lang[data-open="true"] .lang__menu{opacity:1;visibility:visible;transform:none}
.lang__opt{display:flex;align-items:center;gap:11px;width:100%;background:none;border:none;
  padding:10px 12px;border-radius:2px;color:var(--graphite);font-size:14px;font-weight:500;text-align:left}
.lang__opt:hover{background:var(--cream)}
.lang__opt[aria-current="true"]{color:var(--accent);font-weight:700}
.lang__flag{font-size:16px;line-height:1}

/* header scrolled / solid (also used on inner anchored states) */
.head.is-solid{background:rgba(251,248,240,.92);backdrop-filter:blur(14px);
  border-color:var(--line);box-shadow:0 4px 30px -22px rgba(46,46,43,.5)}
.head.is-solid .brand,.head.is-solid .nav__link,.head.is-solid .lang__btn{color:var(--graphite)}
.head.is-solid .nav__link{opacity:.85}
.head.is-solid .btn--ghost{color:var(--graphite);border-color:var(--line)}
.head.is-solid .btn--ghost:hover{background:var(--graphite);color:#fff;border-color:var(--graphite)}

/* burger */
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:8px;margin-left:4px}
.burger span{width:24px;height:2px;background:#fff;transition:.4s var(--ease)}
.head.is-solid .burger span{background:var(--graphite)}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;background:var(--graphite)}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__slide{position:absolute;inset:0;opacity:0;transition:opacity 1.5s var(--ease)}
.hero__slide.is-active{opacity:1}
.hero__slide img{width:100%;height:100%;object-fit:cover}
.hero__scrim{position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(46,46,43,.52) 0%,rgba(46,46,43,.26) 36%,rgba(46,46,43,.36) 62%,rgba(46,46,43,.82) 100%)}
.hero__grain{position:absolute;inset:0;z-index:1;opacity:.05;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* slideshow / video modes */
[data-hero="photo"] .hero__slide:not(:first-child){display:none}
[data-hero="photo"] .hero__slide:first-child{opacity:1}
[data-hero="video"] .hero__slide.is-active img{animation:kenburns 22s ease-in-out infinite alternate}
@keyframes kenburns{from{transform:scale(1.02) translate(0,0)}to{transform:scale(1.16) translate(-2%,-2%)}}
@media (prefers-reduced-motion:reduce){[data-hero="video"] .hero__slide img{animation:none}}

.hero__in{position:relative;z-index:2;width:100%;padding-bottom:clamp(54px,9vh,104px);padding-top:120px}
.hero__eyebrow{color:#fff;font-size:12.5px;font-weight:600;letter-spacing:.3em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:.8em;opacity:.92}
.hero__eyebrow::before{content:"";width:34px;height:1px;background:#fff;opacity:.7}
.hero h1{color:#fff;font-size:clamp(46px,8.4vw,116px);margin:22px 0 0;max-width:14ch;letter-spacing:-.012em;
  text-shadow:0 2px 40px rgba(0,0,0,.25)}
.hero h1 em{font-style:italic;color:var(--cream)}
.hero__sub{color:rgba(255,255,255,.92);font-size:clamp(16px,1.9vw,21px);margin:22px 0 0;max-width:46ch;
  text-shadow:0 1px 20px rgba(0,0,0,.35)}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:36px}
.hero__dots{position:absolute;right:var(--gut);bottom:clamp(54px,9vh,104px);z-index:2;display:flex;gap:10px}
[data-hero="photo"] .hero__dots,[data-hero="video"] .hero__dots{display:none}
.hero__dot{width:34px;height:3px;background:rgba(255,255,255,.35);border:none;padding:0;border-radius:2px;transition:.4s}
.hero__dot.is-active{background:#fff;width:48px}
.scrollcue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:2;color:#fff;
  font-size:11px;letter-spacing:.25em;text-transform:uppercase;opacity:.8;display:flex;flex-direction:column;
  align-items:center;gap:9px}
.scrollcue span{width:1px;height:38px;background:linear-gradient(#fff,transparent);animation:cue 2.2s ease-in-out infinite}
@keyframes cue{0%,100%{opacity:.2;transform:scaleY(.5);transform-origin:top}50%{opacity:1;transform:scaleY(1)}}

/* ============================================================
   TRUST STRIP
   ============================================================ */
.trust{background:var(--graphite);color:var(--cream)}
.trust__in{display:flex;flex-wrap:wrap;justify-content:space-between;gap:18px;padding-block:22px}
.trust__item{display:flex;align-items:center;gap:13px;flex:1;min-width:210px}
.trust__ic{width:34px;height:34px;flex:none;color:var(--accent)}
.trust__ic svg{width:100%;height:100%}
.trust__t{display:block;font-family:var(--serif);font-size:20px;line-height:1}
.trust__d{display:block;font-size:12px;letter-spacing:.05em;opacity:.7;margin-top:3px}

/* ============================================================
   ROOMS
   ============================================================ */
.rooms__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,2.4vw,34px);margin-top:56px}
.room{position:relative;background:var(--white);border:1px solid var(--line);border-radius:var(--r);
  overflow:hidden;display:flex;flex-direction:column;transition:.5s var(--ease)}
.room:hover{box-shadow:var(--shadow-m);transform:translateY(-4px)}
.room__media{position:relative;aspect-ratio:4/3;overflow:hidden}
.room__media img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.room:hover .room__media img{transform:scale(1.06)}
.room__badge{position:absolute;top:16px;left:16px;background:rgba(251,248,240,.94);backdrop-filter:blur(4px);
  color:var(--graphite);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  padding:7px 13px;border-radius:2px}
.room__fruit{position:absolute;top:16px;right:16px;width:34px;height:34px;border-radius:50%;
  display:grid;place-items:center;font-size:16px;background:rgba(251,248,240,.94);backdrop-filter:blur(4px);
  border:2px solid var(--rc,var(--terracotta))}
.room__body{padding:26px 28px 28px;display:flex;flex-direction:column;flex:1}
.room__name{font-size:30px;display:flex;align-items:baseline;gap:12px}
.room__dot{width:9px;height:9px;border-radius:50%;background:var(--rc,var(--terracotta));flex:none;transform:translateY(-3px)}
.room__type{font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--graphite-soft);margin-top:6px}
.room__desc{color:var(--graphite-soft);font-size:15.5px;margin:14px 0 18px;flex:1}
.room__meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:22px}
.chip{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:500;letter-spacing:.02em;
  background:var(--cream);color:var(--graphite-soft);padding:7px 12px;border-radius:2px}
.chip svg{width:14px;height:14px;color:var(--accent)}
.room__foot{display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding-top:18px;border-top:1px solid var(--line)}
.room__foot .link-arrow{color:var(--rc,var(--accent))}
.room__cta{font-size:13px;font-weight:600;letter-spacing:.04em;color:var(--graphite);
  border:1px solid var(--line);padding:11px 18px;border-radius:2px;transition:.35s}
.room__cta:hover{background:var(--rc,var(--accent));border-color:var(--rc,var(--accent));color:#fff}

/* ============================================================
   SERVICES
   ============================================================ */
.feat{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(20px,2.4vw,34px);margin-top:56px}
.feat__row{display:grid;grid-template-columns:1.05fr 1fr;align-items:center;gap:clamp(28px,5vw,84px)}
.feat__row:nth-child(even){grid-template-columns:1fr 1.05fr}
.feat__row:nth-child(even) .feat__media{order:2}
.feat__media{position:relative;aspect-ratio:5/4;border-radius:var(--r);overflow:hidden}
.feat__media img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.feat__row:hover .feat__media img{transform:scale(1.05)}
.feat__tag{position:absolute;bottom:16px;left:16px;background:rgba(251,248,240,.94);backdrop-filter:blur(4px);
  font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);padding:8px 14px;border-radius:2px}
.feat__txt h3{font-size:clamp(28px,3.6vw,44px);margin-top:14px}
.feat__txt p{color:var(--graphite-soft);margin:16px 0 24px;font-size:16.5px}
.feat__num{font-family:var(--serif);font-size:15px;color:var(--accent);font-style:italic}
.feat-stack{display:flex;flex-direction:column;gap:clamp(54px,8vw,104px);margin-top:60px}
.host-card{display:grid;grid-template-columns:96px 1fr;align-items:center;gap:22px;max-width:720px;margin:-12px auto 0;
  padding:16px 18px;background:rgba(251,248,240,.78);border:1px solid var(--line);border-radius:var(--r)}
.host-card img{width:96px;height:96px;object-fit:cover;border-radius:50%;border:3px solid #fff;box-shadow:0 10px 30px -18px rgba(46,46,43,.45)}
.host-card__eyebrow{display:block;font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--olive)}
.host-card h3{font-size:30px;margin-top:3px}
.host-card p{margin:7px 0 0;color:var(--graphite-soft);font-size:14.5px;line-height:1.55}
.host-card a{display:inline-flex;margin-top:10px;color:var(--accent);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.host-card a:hover{text-decoration:underline;text-underline-offset:3px}

/* ============================================================
   ESPERIENZE
   ============================================================ */
.exp__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,1.6vw,22px);margin-top:52px}
.exp{position:relative;aspect-ratio:3/4;border-radius:var(--r);overflow:hidden;display:flex;align-items:flex-end;
  color:#fff;isolation:isolate;background:var(--xc,var(--olive));transition:.5s var(--ease)}
.exp:hover{transform:translateY(-5px);box-shadow:var(--shadow-m)}
.exp::before{content:attr(data-init);position:absolute;right:-.18em;top:-.12em;z-index:0;
  font-family:var(--serif);font-size:clamp(120px,15vw,210px);line-height:.8;color:#fff;opacity:.1;font-style:italic}
.exp::after{content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(180deg,rgba(0,0,0,0) 35%,rgba(0,0,0,.34) 100%)}
.exp__b{padding:22px;position:relative;z-index:1;width:100%}
.exp__dist{font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#fff;opacity:.92;
  display:flex;align-items:center;gap:6px}
.exp__dist svg{width:13px;height:13px}
.exp__name{font-family:var(--serif);font-size:26px;margin-top:6px}
.exp__line{width:30px;height:1px;background:rgba(255,255,255,.5);margin-bottom:14px}
.exp__soon{margin-top:46px;border:1px solid var(--line);border-radius:var(--r);background:var(--paper);
  display:grid;grid-template-columns:40px 1fr auto;align-items:start;gap:18px 28px;padding:28px 30px;box-shadow:var(--shadow-s)}
.exp__soon .lock{width:40px;height:40px;border-radius:50%;background:var(--cream);display:grid;place-items:center;color:var(--olive);flex:none}
.exp__soon .lock svg{width:19px;height:19px}
.exp__soon h4{font-size:22px}
.exp__soon p{margin:3px 0 0;color:var(--graphite-soft);font-size:14.5px}
.exp__soon .badge{background:var(--olive);color:#fff;font-size:11px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;padding:8px 14px;border-radius:2px}
.exp__service-grid{grid-column:1/-1;display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:28px}
.exp__service{background:var(--cream);border:none;border-radius:var(--r);padding:32px 26px 28px;display:flex;
  flex-direction:column;gap:0;box-shadow:0 2px 12px rgba(46,46,43,.06);transition:.3s var(--ease);position:relative;overflow:hidden}
.exp__service::after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--olive);
  transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.exp__service--link:hover{box-shadow:0 12px 40px rgba(46,46,43,.13);transform:translateY(-4px)}
.exp__service--link:hover::after{transform:scaleX(1)}
.exp__service-ic{width:52px;height:52px;border-radius:14px;background:var(--olive);display:grid;place-items:center;
  color:#fff;flex:none;margin-bottom:22px}
.exp__service-ic svg{width:22px;height:22px}
.exp__service h5{font-family:var(--serif);font-size:19px;font-style:italic;font-weight:400;letter-spacing:0;
  text-transform:none;color:var(--graphite);margin:0 0 10px;line-height:1.25}
.exp__service p{font-size:13.5px;line-height:1.7;margin:0 0 20px;color:var(--graphite-soft);flex:1}
.exp__service-cta{color:var(--accent);font-size:11.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-top:auto}

/* ============================================================
   REVIEWS
   ============================================================ */
.rev{position:relative;overflow:hidden}
.rev__track{position:relative;min-height:390px;max-width:760px;margin-inline:auto}
.rev__item{position:absolute;inset:0;margin:0;padding:34px 38px 32px;background:rgba(251,248,240,.72);border:1px solid var(--line);
  border-radius:var(--r);display:flex;flex-direction:column;text-align:left;opacity:0;transform:translateY(16px) scale(.985);
  pointer-events:none;transition:.55s var(--ease);box-shadow:var(--shadow-s)}
.rev__item.is-active{opacity:1;transform:none;pointer-events:auto}
.rev__top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}
.rev__source{font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--graphite-soft)}
.rev__score{background:#003b95;color:#fff;font-size:12px;font-weight:800;line-height:1;padding:8px 9px;border-radius:3px;white-space:nowrap}
.rev__quote{font-family:var(--serif);font-style:italic;font-size:clamp(25px,2.65vw,35px);line-height:1.28;
  color:var(--graphite);margin:0;letter-spacing:.004em;flex:1}
.rev__by{margin-top:24px;font-size:13px;letter-spacing:.04em}
.rev__by b{font-weight:700}
.rev__by span{display:block;color:var(--graphite-soft);margin-top:2px}
.rev__link{margin-top:20px;display:inline-flex;align-items:center;justify-content:center;align-self:flex-start;border:1px solid var(--line);
  color:var(--accent);font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:10px 16px;border-radius:2px;
  transition:.3s}
.rev__link:hover{border-color:var(--accent);background:var(--accent);color:#fff}
.rev__nav{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:26px}
.rev__dots{display:flex;align-items:center;justify-content:center;gap:11px}
.rev__arrow{width:38px;height:38px;border-radius:50%;border:1px solid var(--line);background:var(--paper);color:var(--graphite);
  display:grid;place-items:center;font-family:var(--serif);font-size:27px;line-height:1;transition:.25s}
.rev__arrow:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}
.rev__dot{width:9px;height:9px;border-radius:50%;background:var(--cream-deep);border:none;padding:0;transition:.35s}
.rev__dot.is-active{background:var(--accent);transform:scale(1.25)}
.rev__src{margin-top:24px;text-align:center;font-size:12.5px;letter-spacing:.06em;color:var(--graphite-soft)}
.rev__src b{color:var(--graphite)}
.rev__src a{text-decoration:underline;text-underline-offset:3px}
.rev__src a:hover b{color:var(--accent)}

/* ============================================================
   GALLERY
   ============================================================ */
.gal{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:12px;margin-top:52px}
.gal__cell{position:relative;overflow:hidden;border-radius:var(--r);cursor:pointer}
.gal__cell img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.gal__cell:hover img{transform:scale(1.07)}
.gal__cell::after{content:"";position:absolute;inset:0;background:rgba(46,46,43,0);transition:.4s}
.gal__cell:hover::after{background:rgba(46,46,43,.18)}
.gal__plus{position:absolute;inset:0;display:grid;place-items:center;opacity:0;transition:.4s;color:#fff;z-index:2}
.gal__plus svg{width:30px;height:30px}
.gal__cell:hover .gal__plus{opacity:1}
.gal .tall{grid-row:span 2}
.gal .wide{grid-column:span 2}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:120;background:rgba(28,28,25,.94);display:none;
  align-items:center;justify-content:center;padding:32px}
.lightbox.is-open{display:flex}
.lightbox img{max-width:92vw;max-height:86vh;object-fit:contain;border-radius:2px;box-shadow:0 30px 90px rgba(0,0,0,.5)}
.lb-btn{position:absolute;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25);color:#fff;
  width:52px;height:52px;border-radius:50%;display:grid;place-items:center;transition:.3s}
.lb-btn:hover{background:rgba(255,255,255,.22)}
.lb-btn svg{width:20px;height:20px}
.lb-close{top:26px;right:26px}
.lb-prev{left:26px;top:50%;transform:translateY(-50%)}
.lb-next{right:26px;top:50%;transform:translateY(-50%)}
.lb-count{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);color:#fff;font-size:13px;letter-spacing:.1em}

/* ============================================================
   CTA BAND
   ============================================================ */
.band{position:relative;color:#fff;text-align:center;overflow:hidden;isolation:isolate}
.band img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}
.band::after{content:"";position:absolute;inset:0;z-index:-1;background:rgba(46,46,43,.58)}
.band__in{padding-block:clamp(80px,12vw,150px)}
.band h2{font-size:clamp(36px,6vw,76px);color:#fff;max-width:18ch;margin-inline:auto}
.band p{color:rgba(255,255,255,.9);max-width:50ch;margin:20px auto 34px;font-size:18px}

/* ============================================================
   FOOTER
   ============================================================ */
.foot{background:var(--graphite);color:#cfcdc4}
.foot__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:44px;padding-block:78px}
.foot__brand .brand{color:var(--cream)}
.foot__brand p{margin:20px 0 0;font-size:14.5px;line-height:1.7;color:#a3a199;max-width:30ch}
.foot h5{font-family:var(--sans);font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:#fff;margin:0 0 20px}
.foot ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}
.foot a{color:#a3a199;font-size:14.5px;transition:.3s}
.foot a:hover{color:var(--cream)}
.foot__contact a{display:flex;align-items:center;gap:11px}
.foot__contact svg{width:16px;height:16px;color:var(--accent);flex:none}
.foot__social{display:flex;gap:12px;margin-top:22px}
.foot__social a{width:42px;height:42px;border:1px solid #44443e;border-radius:50%;display:grid;place-items:center;color:#cfcdc4}
.foot__social a:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.foot__social svg{width:18px;height:18px}
.foot__lang{display:flex;gap:8px;margin-top:24px;flex-wrap:wrap}
.foot__lang button{background:none;border:1px solid #44443e;color:#a3a199;font-size:12px;font-weight:600;
  letter-spacing:.08em;padding:7px 12px;border-radius:2px;transition:.3s}
.foot__lang button[aria-current="true"]{border-color:var(--accent);color:var(--accent)}
.foot__lang button:hover{color:var(--cream)}
.foot__bot{border-top:1px solid #3a3a35;padding-block:28px;display:flex;flex-direction:column;gap:16px}
.foot__bot-row{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.foot__bot-links{display:flex;gap:20px;align-items:center;flex-wrap:wrap}
.foot__bot a,.foot__bot-links a{color:#86847c;font-size:13px;transition:.3s}
.foot__bot a:hover,.foot__bot-links a:hover{color:var(--cream)}
.foot__powered{font-size:12.5px;color:#5e5e59;letter-spacing:.03em}
.foot__powered a{color:#86847c;font-size:12.5px}
.foot__powered a:hover{color:var(--cream)}
.foot__legal{margin:0;font-size:11.5px;color:#5e5e59;letter-spacing:.02em;text-align:center;padding-top:16px;border-top:1px solid #2e2e2a}
.foot__cookie-btn{background:none;border:0;color:#86847c;font:inherit;padding:0;cursor:pointer;transition:.3s}
.foot__cookie-btn:hover{color:var(--cream)}

/* ============================================================
   COOKIE CONSENT
   ============================================================ */
.cookie{position:fixed;right:18px;bottom:18px;z-index:180;width:min(520px,calc(100vw - 36px));display:none}
.cookie.is-open{display:block}
.cookie__panel{background:var(--paper);border:1px solid var(--line);border-radius:6px;box-shadow:var(--shadow-m);padding:22px}
.cookie__eyebrow{font-size:10.5px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.cookie h3{font-size:27px;margin:7px 0 0;color:var(--graphite)}
.cookie p{font-size:13.5px;line-height:1.6;color:var(--graphite-soft);margin:10px 0 0}
.cookie__copy a{display:inline-flex;margin-top:10px;color:var(--accent);font-size:12px;font-weight:800;
  letter-spacing:.08em;text-transform:uppercase;text-decoration:underline;text-underline-offset:3px}
.cookie__prefs{margin-top:16px;display:grid;gap:10px}
.cookie__toggle{display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:start;border:1px solid var(--line);
  background:#fff;padding:12px;border-radius:4px}
.cookie__toggle input{margin-top:4px;accent-color:var(--accent)}
.cookie__toggle b{display:block;font-size:13px;color:var(--graphite)}
.cookie__toggle small{display:block;font-size:12px;line-height:1.45;color:var(--graphite-soft);margin-top:2px}
.cookie__actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end;margin-top:18px}
.cookie__actions .btn{padding:11px 16px;font-size:12.5px}

/* ============================================================
   MOBILE BOTTOM BAR + WHATSAPP FAB
   ============================================================ */
.botbar{position:fixed;left:0;right:0;bottom:0;z-index:55;display:none;gap:10px;padding:11px 14px;
  background:rgba(251,248,240,.96);backdrop-filter:blur(12px);border-top:1px solid var(--line)}
.botbar .btn{flex:1}
.wfab{position:fixed;z-index:54;right:18px;bottom:18px;width:58px;height:58px;border-radius:50%;
  background:#25D366;color:#fff;display:grid;place-items:center;box-shadow:0 10px 30px -8px rgba(37,211,102,.6);
  border:none;transition:.35s}
.wfab:hover{transform:scale(1.07)}
.wfab svg{width:30px;height:30px}

/* ============================================================
   BOOKING MODAL (AvaiBook handoff)
   ============================================================ */
.modal{position:fixed;inset:0;z-index:130;display:none;align-items:flex-start;justify-content:center;
  padding:40px 18px;overflow-y:auto}
.modal.is-open{display:flex}
.modal__scrim{position:fixed;inset:0;background:rgba(28,28,25,.6);backdrop-filter:blur(3px)}
.modal__card{position:relative;background:var(--paper);width:100%;max-width:560px;border-radius:6px;
  box-shadow:var(--shadow-m);overflow:hidden;margin:auto}
.modal.is-open .modal__card{animation:pop .4s var(--ease)}
@keyframes pop{from{opacity:0;transform:translateY(18px) scale(.98)}to{opacity:1;transform:none}}
.modal__head{background:var(--graphite);color:#fff;padding:26px 30px;position:relative}
.modal__head .eyebrow{color:var(--accent)}
.modal__head h3{font-size:30px;margin-top:8px;color:#fff}
.modal__head p{margin:8px 0 0;font-size:13.5px;color:#bdbbb2}
.modal__x{position:absolute;top:20px;right:20px;width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,.1);border:none;color:#fff;display:grid;place-items:center;transition:.3s}
.modal__x:hover{background:rgba(255,255,255,.22)}
.modal__x svg{width:18px;height:18px}
.modal__body{padding:28px 30px 32px}
.bk-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.bk-field{display:flex;flex-direction:column;gap:7px}
.bk-field.full{grid-column:1/-1}
.bk-field label{font-size:11.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--graphite-soft)}
.bk-field input,.bk-field select{font-family:inherit;font-size:15px;color:var(--graphite);background:#fff;
  border:1px solid var(--line);border-radius:3px;padding:13px 14px;transition:.3s}
.bk-field input:focus,.bk-field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(194,113,79,.12)}
.bk-date input{cursor:pointer;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' fill='none' stroke='%23C2714F' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='12' height='12' rx='2'/%3E%3Cpath d='M6 2v4M12 2v4M3 8h12'/%3E%3C/svg%3E") no-repeat right 13px center;padding-right:42px}
.bk-cal{position:absolute;z-index:150;width:min(320px,calc(100vw - 28px));background:var(--paper);border:1px solid var(--line);
  border-radius:6px;box-shadow:0 22px 70px -26px rgba(46,46,43,.45);padding:14px;display:none}
.bk-cal.is-open{display:block;animation:pop .24s var(--ease)}
.bk-cal__head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.bk-cal__jump{display:grid;grid-template-columns:1fr 82px;gap:7px;flex:1}
.bk-cal__jump select{min-width:0;font-family:var(--sans);font-size:13px;font-weight:700;color:var(--graphite);
  background:#fff;border:1px solid var(--line);border-radius:3px;padding:9px 28px 9px 10px;text-transform:capitalize;
  appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--accent) 50%),linear-gradient(135deg,var(--accent) 50%,transparent 50%);
  background-position:calc(100% - 13px) 50%,calc(100% - 8px) 50%;background-size:5px 5px,5px 5px;background-repeat:no-repeat}
.bk-cal__jump select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(194,113,79,.12)}
.bk-cal__head button{width:34px;height:34px;border:1px solid var(--line);border-radius:50%;background:#fff;color:var(--graphite);
  display:grid;place-items:center;font-size:23px;line-height:1;transition:.25s}
.bk-cal__head button:hover{border-color:var(--accent);color:var(--accent)}
.bk-cal__yearnav{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-bottom:13px}
.bk-cal__yearnav button{background:var(--cream);border:1px solid var(--line);border-radius:3px;color:var(--graphite-soft);
  font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:8px 6px;transition:.25s}
.bk-cal__yearnav button:hover{border-color:var(--accent);color:var(--accent);background:#fff}
.bk-cal__yearnav button:disabled{opacity:.45;cursor:not-allowed}
.bk-cal__yearnav button:disabled:hover{background:var(--cream);border-color:var(--line);color:var(--graphite-soft)}
.bk-cal__week,.bk-cal__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.bk-cal__week{margin-bottom:7px}
.bk-cal__week span{text-align:center;font-size:10.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--graphite-soft)}
.bk-cal__day{height:36px;border:1px solid transparent;border-radius:50%;background:transparent;color:var(--graphite);
  font-size:13.5px;font-weight:600;transition:.2s}
.bk-cal__day:hover{background:var(--cream);border-color:var(--line)}
.bk-cal__day.is-muted{color:#aaa79d}
.bk-cal__day.is-range{background:var(--cream);border-radius:3px}
.bk-cal__day.is-selected{background:var(--accent);border-color:var(--accent);color:#fff}
.bk-cal__day:disabled{color:#c7c2b5;cursor:not-allowed;text-decoration:line-through;background:transparent}
.bk-note{font-size:12px;color:var(--graphite-soft);margin:16px 0 0;display:flex;align-items:center;gap:8px}
.bk-note svg{width:15px;height:15px;color:var(--olive);flex:none}
.bk-results{margin-top:22px;display:flex;flex-direction:column;gap:12px}
.bk-card{display:flex;gap:14px;align-items:center;border:1px solid var(--line);border-radius:4px;padding:12px;background:#fff}
.bk-card img{width:74px;height:64px;object-fit:cover;border-radius:3px;flex:none}
.bk-card__info{flex:1}
.bk-card__info b{font-family:var(--serif);font-size:19px;font-weight:500}
.bk-card__info span{display:block;font-size:12.5px;color:var(--graphite-soft);margin-top:2px}
.bk-card__status{text-align:right;flex:none;max-width:130px}
.bk-card__status small{display:block;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)}
.bk-action{margin-top:6px}
.bk-action .btn[disabled]{cursor:not-allowed;opacity:.7}
.bk-powered{margin-top:22px;text-align:center;font-size:11.5px;letter-spacing:.06em;color:var(--graphite-soft)}
.bk-powered b{color:var(--graphite);letter-spacing:.02em}
.bk-summary{background:var(--cream);border-radius:4px;padding:14px 16px;font-size:13.5px;color:var(--graphite-soft);
  margin-top:4px;display:none}
.bk-summary.show{display:block}

/* ============================================================
   LEGAL PAGES
   ============================================================ */
.legal-page{min-height:100vh;background:var(--paper)}
.legal{max-width:860px}
.legal__brand{display:inline-flex;margin-bottom:46px}
.legal h1{font-size:clamp(48px,7vw,78px);margin:12px 0 12px;color:var(--graphite)}
.legal__lead{font-size:19px;line-height:1.7;color:var(--graphite-soft);max-width:720px}
.legal__updated{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin:20px 0 38px}
.legal h2{font-family:var(--serif);font-size:30px;font-weight:500;color:var(--graphite);margin:34px 0 10px}
.legal p,.legal li{font-size:15.5px;line-height:1.75;color:var(--graphite-soft)}
.legal a:not(.btn){color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.legal ul{padding-left:20px}
.legal__note{border-left:3px solid var(--accent);padding-left:16px;margin-top:34px}

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .foot__top{grid-template-columns:1fr 1fr;gap:40px}
  .exp__grid{grid-template-columns:repeat(2,1fr)}
  .exp__service-grid{grid-template-columns:repeat(2,1fr);gap:16px}
}
@media (max-width:860px){
  body{font-size:16px}
  .nav{display:none}
  .head__right .btn{display:none}
  .burger{display:flex}
  /* Garantisce che il testo non risalga nell'area dell'header fisso */
  .hero{padding-top:78px}
  .feat__row,.feat__row:nth-child(even){grid-template-columns:1fr;gap:24px}
  .feat__row:nth-child(even) .feat__media{order:0}
  .rooms__grid{grid-template-columns:1fr}
  .gal{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}
  .gal .wide{grid-column:span 2}
  .botbar{display:flex}
  .wfab{bottom:84px}
  body{padding-bottom:0}
}
@media (max-width:560px){
  :root{--gut:20px}
  .head__in{height:66px;gap:12px}
  .brand{gap:10px;min-width:0}
  .brand__mark--logo{width:42px;height:42px}
  .brand__mark--logo::before{width:31px;height:31px}
  .brand__mark--logo span{font-size:16px}
  .brand__name{font-size:20px}
  .brand__sub{font-size:8px;letter-spacing:.22em;white-space:nowrap}
  .head__right{gap:8px;margin-left:auto}
  .lang{display:none}
  .burger{padding:8px 0 8px 8px}
  .hero{min-height:92svh;align-items:flex-end;padding-top:66px}
  .hero__in{padding-top:72px;padding-bottom:74px}
  .hero__eyebrow{font-size:10.5px;letter-spacing:.18em;gap:.55em}
  .hero__eyebrow::before{width:22px}
  .hero h1{font-size:clamp(42px,15vw,58px);max-width:9ch;margin-top:16px}
  .hero__sub{font-size:15.5px;line-height:1.55;max-width:31ch;margin-top:16px}
  .hero__cta{gap:10px;margin-top:26px}
  .hero__cta .btn{width:100%;padding-inline:18px}
  .scrollcue{display:none}
  .sec{padding-block:58px}
  .sec-head h2{font-size:34px}
  .sec-head p{font-size:15.5px}
  .trust__in{gap:14px}
  .trust__item{min-width:100%;gap:12px}
  .trust__t{font-size:18px}
  .rooms__grid{gap:18px;margin-top:34px}
  .room__body{padding:22px}
  .room__name{font-size:28px}
  .room__foot{align-items:stretch;flex-direction:column}
  .room__cta{width:100%}
  .feat-stack{margin-top:38px;gap:48px}
  .feat__media{aspect-ratio:4/3}
  .host-card{grid-template-columns:72px 1fr;gap:14px;margin-top:-4px;padding:14px}
  .host-card img{width:72px;height:72px;border-width:2px}
  .host-card h3{font-size:25px}
  .host-card p{font-size:13.5px}
  .host-card a{font-size:10.5px;line-height:1.35}
  .exp__grid{grid-template-columns:1fr;gap:10px;margin-top:34px}
  .exp{aspect-ratio:auto;min-height:112px;align-items:center}
  .exp:hover{transform:none}
  .exp::before{right:18px;top:50%;transform:translateY(-50%);font-size:112px;opacity:.08}
  .exp::after{background:linear-gradient(90deg,rgba(0,0,0,.24),rgba(0,0,0,.04))}
  .exp__b{padding:18px 20px;display:grid;gap:8px}
  .exp__line{display:none}
  .exp__name{font-size:28px;line-height:1.05;margin-top:0;max-width:11ch}
  .exp__dist{font-size:10.5px;line-height:1.35;letter-spacing:.1em;max-width:none}
  .exp__dist span{overflow-wrap:normal}
  .exp__dist svg{width:12px;height:12px}
  .exp__soon{grid-template-columns:40px 1fr;padding:22px;align-items:flex-start}
  .exp__soon .badge{grid-column:2;justify-self:start;margin-left:0;white-space:nowrap}
  .exp__soon-copy{min-width:0}
  .exp__service-grid{grid-template-columns:1fr;gap:14px}
  .exp__service{padding:22px 20px}
  .rev__track{min-height:430px}
  .rev__item{padding:22px}
  .rev__quote{font-size:24px;line-height:1.3}
  .rev__by{font-size:12.5px}
  .rev__link{width:100%;padding-block:11px}
  .rev__nav{margin-top:18px}
  .rev__src{font-size:11.5px;line-height:1.55}
  .gal{grid-template-columns:1fr 1fr;grid-auto-rows:132px;gap:8px;margin-top:34px}
  .gal .wide,.gal .tall{grid-column:auto;grid-row:auto}
  .band__in{padding-block:76px 92px}
  .foot__top{grid-template-columns:1fr;gap:34px;padding-block:56px}
  .foot__bot{padding-bottom:92px}
  .foot__bot-row{flex-direction:column;align-items:flex-start}
  .foot__legal{text-align:left}
  .modal{padding:12px}
  .cookie{left:12px;right:12px;bottom:88px;width:auto}
  .cookie__panel{padding:18px}
  .cookie__actions{display:grid;grid-template-columns:1fr}
  .cookie__actions .btn{width:100%}
  .modal__card{max-width:none;margin:auto 0;border-radius:5px}
  .modal__head{padding:22px 54px 22px 22px}
  .modal__head h3{font-size:28px}
  .modal__body{padding:22px}
  .bk-grid{grid-template-columns:1fr}
  .bk-card{align-items:flex-start}
  .bk-card img{width:64px;height:58px}
  .bk-card__status{max-width:94px}
  .bk-cal{position:fixed;width:calc(100vw - 24px);left:12px!important;right:12px;top:auto!important;bottom:88px;padding:12px}
  .bk-cal__jump{grid-template-columns:1fr 76px}
  .bk-cal__jump select{font-size:12px;padding-block:9px}
  .bk-cal__yearnav button{font-size:9.5px}
  .bk-cal__week,.bk-cal__grid{gap:4px}
  .bk-cal__day{height:34px;font-size:13px}
  .hero__dots{display:none}
  .drawer__panel{width:min(88vw,360px);padding:76px 24px 28px}
  .drawer__panel a{font-size:24px}
  .botbar{padding:10px 12px}
  .wfab{width:52px;height:52px;right:14px;bottom:78px}
  .wfab svg{width:27px;height:27px}
}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:80;display:none}
.drawer.is-open{display:block}
.drawer__scrim{position:absolute;inset:0;background:rgba(28,28,25,.5)}
.drawer__panel{position:absolute;top:0;right:0;bottom:0;width:min(82vw,360px);background:var(--paper);
  padding:84px 30px 30px;display:flex;flex-direction:column;gap:6px;transform:translateX(100%);
  transition:transform .45s var(--ease);box-shadow:var(--shadow-m)}
.drawer.is-open .drawer__panel{transform:none}
.drawer__panel a{font-family:var(--serif);font-size:26px;padding:12px 0;border-bottom:1px solid var(--line);color:var(--graphite)}
.drawer__panel a:last-of-type{border-bottom:none}
.drawer__panel .btn{margin-top:18px}
.drawer__lang{display:flex;gap:8px;margin-top:24px}
.drawer__lang button{flex:1;background:none;border:1px solid var(--line);color:var(--graphite-soft);font-size:13px;
  font-weight:600;padding:10px;border-radius:2px}
.drawer__lang button[aria-current="true"]{border-color:var(--accent);color:var(--accent)}
.drawer__x{position:absolute;top:24px;right:24px;width:42px;height:42px;border-radius:50%;border:1px solid var(--line);
  background:none;display:grid;place-items:center}
.drawer__x svg{width:20px;height:20px}
