/* ============================================================
   OASI DEL BENESSERE — Catania
   Design: "Oasi botanica siciliana"
   Palette: eucalipto / basalto Etna / ottone brunito / marmo
   Type:    Fraunces (display) + Hanken Grotesk (testo)
   ============================================================ */

:root{
  /* colore */
  --ink:#1c211b;
  --bosco:#2b3528;
  --bosco-deep:#212a1f;
  --salvia:#6f7d63;
  --oro:#b08d57;
  --oro-deep:#876636;     /* testo oro su chiaro (AA) */
  --oro-soft:#d6b67e;     /* oro su scuro */
  --avorio:#f1ece1;
  --avorio-2:#e9e2d3;
  --marmo:#fcfbf7;
  --crema:#f3eee4;
  --crema-dim:#cdc8ba;
  --line:#ddd5c4;
  --line-dark:rgba(243,238,228,.15);

  /* tipografia */
  --font-display:"Fraunces", Georgia, "Times New Roman", serif;
  --font-body:"Hanken Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;

  /* layout */
  --container:1220px;
  --gutter:clamp(1.25rem, 5vw, 4rem);
  --section-y:clamp(4.5rem, 9vw, 8.5rem);
  --radius:9px;
  --header-h:74px;

  /* effetti */
  --shadow-soft:0 18px 50px -28px rgba(28,33,26,.5);
  --shadow-card:0 30px 70px -34px rgba(28,33,26,.55);
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- reset / base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.65;
  color:var(--ink);
  background:var(--avorio);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit}
button{font-family:inherit}
h1,h2,h3,h4,p,figure,blockquote,ul{margin:0}
ul{list-style:none;padding:0}
section[id], #top{scroll-margin-top:calc(var(--header-h) + 12px)}

::selection{background:var(--oro);color:#fff}
:focus-visible{outline:2px solid var(--oro);outline-offset:3px;border-radius:3px}

.skip-link{
  position:fixed;top:-100px;left:1rem;z-index:200;
  background:var(--bosco);color:var(--crema);
  padding:.7rem 1.2rem;border-radius:6px;text-decoration:none;font-weight:600;
  transition:top .25s var(--ease);
}
.skip-link:focus{top:1rem}

/* ---------- utility ---------- */
.container{width:min(100%, var(--container));margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:var(--section-y)}
.section--tint{background:var(--avorio-2)}
.section--marble{background:var(--marmo)}
.section--dark{background:var(--bosco);color:var(--crema)}

.eyebrow{
  display:inline-flex;align-items:center;gap:.75em;
  font-size:.76rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase;
  color:var(--oro-deep);margin:0 0 1.1rem;
}
.eyebrow::before{content:"";width:30px;height:1px;background:currentColor;opacity:.7}
.section--dark .eyebrow,.hero .eyebrow,.feature .eyebrow{color:var(--oro-soft)}

.title{
  font-family:var(--font-display);
  font-optical-sizing:auto;
  font-weight:380;
  line-height:1.06;
  letter-spacing:-.012em;
  color:var(--ink);
  font-size:clamp(1.9rem, 4vw, 3.15rem);
}
.section--dark .title,.feature .title{color:var(--crema)}

.lead{
  font-size:clamp(1.05rem,1.5vw,1.22rem);
  color:color-mix(in srgb, var(--ink) 78%, transparent);
  max-width:56ch;margin-top:1.1rem;
}

.ico-sprig{display:block}

/* divisore con rametto d'oro */
.divider{
  display:flex;align-items:center;justify-content:center;gap:1.4rem;
  color:var(--oro);margin-block:clamp(2.5rem,5vw,4rem) 0;
}
.divider::before,.divider::after{
  content:"";height:1px;width:min(140px,20vw);
}
.divider::before{background:linear-gradient(90deg,transparent,currentColor)}
.divider::after{background:linear-gradient(90deg,currentColor,transparent)}
.divider .ico-sprig{width:36px;height:36px;flex:none}

/* ---------- bottoni ---------- */
.btn{
  --btn-pad:1em 1.7em;
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  padding:var(--btn-pad);
  font-weight:600;font-size:.96rem;letter-spacing:.01em;
  border-radius:999px;border:1.5px solid transparent;
  text-decoration:none;cursor:pointer;white-space:nowrap;
  transition:transform .25s var(--ease), background .25s, color .25s, border-color .25s, box-shadow .25s;
}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn .ico{width:1.15em;height:1.15em;flex:none}
.btn--gold{background:var(--oro);color:#20251c;box-shadow:0 14px 30px -16px rgba(176,141,87,.9)}
.btn--gold:hover{background:var(--oro-soft)}
.btn--ghost{background:rgba(243,238,228,.06);border-color:rgba(243,238,228,.45);color:var(--crema)}
.btn--ghost:hover{border-color:var(--crema);background:rgba(243,238,228,.12)}
.btn--sm{padding:.62em 1.15em;font-size:.88rem}
.btn--block{width:100%}

/* link con freccia */
.link-arrow{
  display:inline-flex;align-items:center;gap:.5em;margin-top:1.6rem;
  font-weight:600;color:var(--oro-deep);text-decoration:none;
}
.link-arrow svg{width:1.2em;height:1.2em;transition:transform .3s var(--ease)}
.link-arrow:hover svg{transform:translateX(5px)}

/* reveal on scroll — gated behind .js so content is ALWAYS visible if JS doesn't run */
.js [data-reveal]{opacity:0;transform:translateY(24px);transition:opacity .85s var(--ease), transform .85s var(--ease)}
.js [data-reveal].is-visible{opacity:1;transform:none}
[data-reveal-delay="1"]{transition-delay:.09s}
[data-reveal-delay="2"]{transition-delay:.18s}
[data-reveal-delay="3"]{transition-delay:.27s}

/* ============================================================
   HEADER / NAV
   ============================================================ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:80;
  padding-block:.85rem;
  transition:background .4s var(--ease), padding .4s var(--ease), box-shadow .4s var(--ease);
}
.site-header.is-scrolled{
  background:color-mix(in srgb, var(--avorio) 88%, transparent);
  -webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);
  box-shadow:0 1px 0 rgba(28,33,26,.08), 0 16px 40px -30px rgba(28,33,26,.5);
  padding-block:.55rem;
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:2rem}

.brand{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--font-display);font-weight:430;font-size:1.32rem;letter-spacing:.005em;
  color:var(--crema);text-decoration:none;transition:color .4s;
}
.brand .ico-sprig{width:24px;height:24px;color:var(--oro-soft);transition:color .4s}
.is-scrolled .brand{color:var(--ink)}
.is-scrolled .brand .ico-sprig{color:var(--oro)}

.nav-links{display:flex;align-items:center;gap:1.9rem}
.nav-links a{
  position:relative;font-weight:500;font-size:.97rem;text-decoration:none;
  color:var(--crema);opacity:.92;padding-block:.35rem;transition:color .4s, opacity .25s;
}
.is-scrolled .nav-links a{color:var(--ink)}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:-1px;height:1.5px;width:0;background:var(--oro);
  transition:width .3s var(--ease);
}
.nav-links a:hover{opacity:1}
.nav-links a:hover::after,.nav-links a[aria-current="true"]::after{width:100%}

.nav-actions{display:flex;align-items:center;gap:.9rem}

.nav-toggle{
  display:none;width:44px;height:44px;border:0;background:transparent;cursor:pointer;
  padding:10px;border-radius:8px;
}
.nav-toggle span{display:block;height:2px;border-radius:2px;background:var(--crema);margin:4px 0;transition:.3s var(--ease)}
.is-scrolled .nav-toggle span{background:var(--ink)}
.nav-toggle[aria-expanded="true"] span{background:var(--crema)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* menu mobile a tutto schermo */
.mobile-menu{
  position:fixed;inset:0;z-index:75;background:var(--bosco);
  display:grid;place-items:center;
  opacity:0;visibility:hidden;transition:opacity .35s var(--ease), visibility .35s;
}
.mobile-menu.is-open{opacity:1;visibility:visible}
.mobile-menu__inner{display:flex;flex-direction:column;align-items:center;gap:1.6rem;text-align:center;padding:2rem}
.mobile-menu__inner a:not(.btn){
  font-family:var(--font-display);font-size:1.9rem;color:var(--crema);text-decoration:none;
  opacity:0;transform:translateY(14px);transition:opacity .4s var(--ease), transform .4s var(--ease), color .25s;
}
.mobile-menu.is-open .mobile-menu__inner a:not(.btn){opacity:1;transform:none}
.mobile-menu__inner a:not(.btn):hover{color:var(--oro-soft)}
.mobile-menu.is-open .mobile-menu__inner a:nth-child(1){transition-delay:.06s}
.mobile-menu.is-open .mobile-menu__inner a:nth-child(2){transition-delay:.12s}
.mobile-menu.is-open .mobile-menu__inner a:nth-child(3){transition-delay:.18s}
.mobile-menu.is-open .mobile-menu__inner a:nth-child(4){transition-delay:.24s}
.mobile-menu.is-open .mobile-menu__inner a:nth-child(5){transition-delay:.30s}
.mobile-menu__inner .btn{margin-top:1rem}
body.menu-open{overflow:hidden}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;min-height:100svh;display:flex;align-items:flex-end;
  color:var(--crema);overflow:hidden;isolation:isolate;
}
.hero__media{position:absolute;inset:0;z-index:-2}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:center 60%;
  animation:kenburns 26s var(--ease) infinite alternate;will-change:transform}
@keyframes kenburns{from{transform:scale(1.04)}to{transform:scale(1.12) translateY(-1.5%)}}
.hero__overlay{
  position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(180deg, rgba(21,28,19,.62) 0%, rgba(21,28,19,.30) 32%, rgba(21,28,19,.55) 70%, rgba(21,28,19,.86) 100%),
    radial-gradient(130% 90% at 15% 95%, rgba(21,28,19,.6), transparent 60%);
}
.hero__inner{
  width:min(100%, var(--container));margin-inline:auto;
  padding-inline:var(--gutter);
  padding-block:clamp(7rem,16vh,11rem) clamp(4.5rem,11vh,7rem);
}
.hero__title{
  font-family:var(--font-display);font-optical-sizing:auto;font-weight:340;
  font-size:clamp(2.7rem,6.6vw,5.6rem);line-height:1.01;letter-spacing:-.018em;
  margin:.45em 0 .5em;text-wrap:balance;
}
.hero__title em{font-style:italic;font-weight:380;color:var(--oro-soft)}
.hero__sub{font-size:clamp(1.06rem,1.5vw,1.32rem);max-width:48ch;color:rgba(243,238,228,.92)}
.hero__actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2.2rem}

.hero__loc{
  position:absolute;right:calc(var(--gutter) - .2rem);top:50%;z-index:1;
  transform:rotate(90deg);transform-origin:right center;
  font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;color:rgba(243,238,228,.75);
  display:flex;align-items:center;gap:1rem;
}
.hero__loc::after{content:"";width:70px;height:1px;background:var(--oro-soft)}

.hero__scroll{
  position:absolute;left:50%;bottom:1.6rem;transform:translateX(-50%);z-index:1;
  display:flex;flex-direction:column;align-items:center;gap:.4rem;
  color:rgba(243,238,228,.8);text-decoration:none;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
}
.hero__scroll svg{width:22px;height:22px;animation:bob 2s var(--ease) infinite}
@keyframes bob{0%,100%{transform:translateY(0);opacity:.7}50%{transform:translateY(6px);opacity:1}}

/* ============================================================
   MANIFESTO
   ============================================================ */
.manifesto__grid{
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,6vw,5rem);
  align-items:start;margin-top:.5rem;
}
.manifesto__title{font-size:clamp(2rem,3.6vw,3.2rem);max-width:18ch}
.manifesto__body p{margin-bottom:1.1rem;color:color-mix(in srgb, var(--ink) 80%, transparent)}
.manifesto__body p:last-of-type{margin-bottom:0}

/* ============================================================
   TRATTAMENTI (menu)
   ============================================================ */
.menu-head{max-width:60ch;margin-bottom:clamp(2.5rem,5vw,4rem)}
.menu-head--center{margin-inline:auto;text-align:center}
.menu-head--center .eyebrow{justify-content:center}
.menu-head--center .eyebrow::before{display:none}

.menu{display:flex;flex-direction:column;gap:clamp(2.5rem,5vw,4rem)}
.menu-cat{
  display:grid;grid-template-columns:minmax(180px,230px) 1fr;gap:clamp(1.2rem,4vw,3.5rem);
  padding-top:clamp(2rem,4vw,3rem);border-top:1px solid var(--line);
}
.menu:first-child{}
.menu-cat:first-child{border-top:0;padding-top:0}
.menu-cat__label h3{
  font-family:var(--font-display);font-weight:420;font-size:1.5rem;color:var(--ink);
  letter-spacing:-.01em;
}
.menu-cat__label p{margin-top:.4rem;font-size:.93rem;color:var(--salvia);max-width:24ch}

.menu-item{padding-block:1.15rem;border-bottom:1px solid var(--line)}
.menu-item:last-child{border-bottom:0}
.menu-item__head{display:flex;align-items:baseline;gap:.7rem}
.menu-item__name{
  font-family:var(--font-display);font-weight:440;font-size:clamp(1.16rem,1.7vw,1.4rem);
  color:var(--ink);transition:color .25s;
}
.menu-item__leader{flex:1 1 auto;min-width:20px;border-bottom:2px dotted var(--oro);transform:translateY(-.28em);opacity:.65}
.menu-item__meta{font-size:.84rem;font-weight:600;letter-spacing:.02em;color:var(--oro-deep);white-space:nowrap}
.menu-item__desc{margin-top:.45rem;font-size:.99rem;color:color-mix(in srgb, var(--ink) 70%, transparent);max-width:64ch}
.menu-item__desc a{color:var(--oro-deep);text-underline-offset:3px}
.menu-item:hover .menu-item__name{color:var(--oro-deep)}

/* ============================================================
   DOCCIA EMOZIONALE (feature)
   ============================================================ */
.feature{position:relative;background:var(--bosco);color:var(--crema);overflow:hidden;isolation:isolate}
.feature__grid{display:grid;grid-template-columns:1.05fr .95fr;min-height:min(88vh,760px)}
.feature__media{position:relative;overflow:hidden}
.feature__media img{width:100%;height:100%;object-fit:cover}
.feature__media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg, transparent 60%, rgba(43,53,40,.7) 100%);
}
.feature__body{
  display:flex;flex-direction:column;justify-content:center;align-items:flex-start;
  padding:clamp(3rem,7vw,6rem) clamp(1.5rem,6vw,5.5rem);
}
.feature__body p{max-width:46ch;color:rgba(243,238,228,.86);margin-top:1.2rem}
.feature__title{font-size:clamp(2.2rem,4.4vw,3.6rem)}
.feature__tags{display:flex;flex-wrap:wrap;gap:.6rem;margin:1.8rem 0 2.2rem}
.feature__tags li{
  font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600;
  padding:.5em 1em;border:1px solid var(--line-dark);border-radius:999px;color:var(--oro-soft);
}

/* ============================================================
   GALLERY
   ============================================================ */
/* card stile Airbnb: immagine quadrata ad angoli tondi uguali, griglia simmetrica, didascalia sotto */
.gallery-grid{
  display:grid;gap:clamp(1.4rem,2.6vw,2rem) clamp(1.1rem,2vw,1.6rem);
  grid-template-columns:repeat(3, 1fr);
}
.gallery-item{
  display:flex;flex-direction:column;gap:.85rem;
  border:0;padding:0;background:transparent;cursor:zoom-in;text-align:left;color:inherit;font:inherit;
}
.gallery-item__media{
  position:relative;overflow:hidden;border-radius:22px;aspect-ratio:1/1;
  background:var(--avorio-2);box-shadow:0 1px 3px rgba(28,33,26,.12);
  transition:box-shadow .35s var(--ease), transform .35s var(--ease);
}
.gallery-item__media img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.gallery-item:hover .gallery-item__media,.gallery-item:focus-visible .gallery-item__media{
  transform:translateY(-4px);box-shadow:var(--shadow-card);
}
.gallery-item:hover .gallery-item__media img,.gallery-item:focus-visible .gallery-item__media img{transform:scale(1.05)}
.gallery-item__cap{display:flex;flex-direction:column;gap:.12rem;padding-inline:.2rem}
.gallery-item__cap strong{font-weight:600;font-size:1.02rem;color:var(--ink);letter-spacing:.005em}
.gallery-item__cap small{font-size:.86rem;color:var(--salvia)}
/* puntini dello slider (solo mobile) */
.gallery-dots{display:none}
.gallery-dot{width:8px;height:8px;padding:0;border:0;border-radius:50%;background:var(--line);cursor:pointer;transition:transform .25s var(--ease), background .25s}
.gallery-dot.is-active{background:var(--oro);transform:scale(1.35)}

/* ============================================================
   CERTIFICAZIONI
   ============================================================ */
.certs{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.certs__media{position:relative}
.certs__media img{
  width:100%;aspect-ratio:4/5;object-fit:cover;object-position:left center;
  border-radius:var(--radius);box-shadow:var(--shadow-card);
}
.certs__badge{
  position:absolute;left:-1.2rem;bottom:1.6rem;
  display:inline-flex;align-items:center;gap:.5rem;
  background:var(--bosco);color:var(--crema);
  padding:.7rem 1.1rem;border-radius:999px;font-size:.82rem;font-weight:600;letter-spacing:.04em;
  box-shadow:var(--shadow-card);
}
.certs__badge .ico-sprig{width:20px;height:20px;color:var(--oro-soft)}

.certs__list{display:flex;flex-direction:column;gap:1.6rem;margin-top:2rem}
.cert-point{display:flex;gap:1.1rem;align-items:flex-start}
.cert-point__ico{
  flex:none;width:38px;height:38px;border-radius:50%;
  display:grid;place-items:center;background:color-mix(in srgb,var(--oro) 16%, transparent);color:var(--oro-deep);
}
.cert-point__ico svg{width:20px;height:20px}
.cert-point h3{font-family:var(--font-display);font-weight:480;font-size:1.18rem;color:var(--ink)}
.cert-point p{margin-top:.25rem;font-size:.98rem;color:color-mix(in srgb,var(--ink) 70%, transparent);max-width:46ch}

/* ============================================================
   TESTIMONIANZE
   ============================================================ */
.quotes{
  display:flex;gap:1.5rem;overflow-x:auto;scroll-snap-type:x mandatory;
  padding:.5rem .2rem 1.4rem;margin-top:.5rem;
  scrollbar-width:none;-ms-overflow-style:none;
}
.quotes::-webkit-scrollbar{display:none}
.quote-card{
  flex:0 0 min(100%, 430px);scroll-snap-align:center;
  background:var(--marmo);border:1px solid var(--line);border-radius:var(--radius);
  padding:clamp(1.8rem,3vw,2.6rem);box-shadow:var(--shadow-soft);position:relative;
}
.quote-card__mark{
  font-family:var(--font-display);font-size:4.5rem;line-height:.6;color:var(--oro);opacity:.55;
  display:block;height:2rem;
}
.quote-card__text{
  font-family:var(--font-display);font-weight:400;font-size:clamp(1.18rem,1.7vw,1.35rem);
  line-height:1.4;color:var(--ink);margin-bottom:1.4rem;
}
.quote-card__by{font-size:.86rem;color:var(--salvia)}
.quote-card__by span{display:block;font-weight:700;letter-spacing:.04em;color:var(--oro-deep);text-transform:uppercase;font-size:.8rem;margin-bottom:.15rem}

.quotes-nav{display:flex;gap:.7rem;justify-content:center;margin-top:.5rem}
.quotes-btn{
  width:48px;height:48px;border-radius:50%;border:1.5px solid var(--line);
  background:var(--marmo);color:var(--ink);cursor:pointer;display:grid;place-items:center;
  transition:background .25s, border-color .25s, transform .25s var(--ease);
}
.quotes-btn:hover{background:var(--oro);border-color:var(--oro);color:#20251c;transform:translateY(-2px)}
.quotes-btn svg{width:22px;height:22px}

/* ============================================================
   CONTATTI
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:start}
.contact-lead{color:rgba(243,238,228,.84);max-width:42ch;margin-top:1.1rem}

.contact-info{display:flex;flex-direction:column;gap:1.3rem;margin-top:2.2rem}
.contact-info li{display:flex;gap:1rem;align-items:flex-start}
.contact-info__ico{
  flex:none;width:42px;height:42px;border-radius:50%;display:grid;place-items:center;
  border:1px solid var(--line-dark);color:var(--oro-soft);
}
.contact-info__ico svg{width:21px;height:21px}
.contact-info__k{display:block;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--crema-dim);margin-bottom:.15rem}
.contact-info a{color:var(--crema);text-decoration:none;text-underline-offset:3px}
.contact-info a:hover{text-decoration:underline}
.contact-info em{color:var(--crema-dim);font-size:.85em}

/* card prenotazione */
.contact-side{display:flex;flex-direction:column;gap:1.4rem}
.booking{background:var(--marmo);color:var(--ink);border-radius:var(--radius);padding:clamp(1.5rem,3vw,2.2rem);box-shadow:var(--shadow-card)}
.booking__title{font-family:var(--font-display);font-weight:480;font-size:1.4rem}
.booking__hint{font-size:.92rem;color:var(--salvia);margin:.3rem 0 1.3rem}
.field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field label{font-size:.82rem;font-weight:600;letter-spacing:.02em;color:var(--ink)}
.field label span{color:var(--salvia);font-weight:400}
.field input,.field select{
  font-family:inherit;font-size:1rem;color:var(--ink);
  padding:.7rem .85rem;border:1.5px solid var(--line);border-radius:7px;background:var(--avorio);
  transition:border-color .25s, box-shadow .25s;
}
.field input:focus,.field select:focus{outline:none;border-color:var(--oro);box-shadow:0 0 0 3px color-mix(in srgb,var(--oro) 22%, transparent)}
#bk-send{margin-top:.4rem}

/* mappa */
.map{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card);background:var(--bosco-deep)}
.map iframe{width:100%;height:230px;border:0;display:block;filter:grayscale(.25) contrast(.95)}
.map__note{font-size:.82rem;color:var(--crema-dim);padding:.7rem 1rem;background:var(--bosco-deep)}
.map__note em{color:var(--oro-soft)}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--bosco-deep);color:var(--crema)}
.footer-grid{
  display:grid;grid-template-columns:1.6fr 1fr 1.2fr;gap:clamp(2rem,5vw,4rem);
  padding-block:clamp(3rem,6vw,5rem) 2.5rem;
}
.brand--footer{color:var(--crema);font-size:1.4rem;margin-bottom:1rem}
.brand--footer .ico-sprig{color:var(--oro-soft)}
.footer-brand p{color:var(--crema-dim);max-width:36ch;font-size:.96rem}
.footer-nav,.footer-contact{display:flex;flex-direction:column;gap:.6rem}
.footer-nav h4,.footer-contact h4{
  font-size:.76rem;letter-spacing:.2em;text-transform:uppercase;color:var(--oro-soft);
  margin-bottom:.5rem;font-weight:600;
}
.footer-nav a,.footer-contact a{color:var(--crema-dim);text-decoration:none;transition:color .25s}
.footer-nav a:hover,.footer-contact a:hover{color:var(--crema)}
.footer-contact p{color:var(--crema-dim);font-size:.96rem}
.footer-social{display:flex;gap:.7rem;margin-top:.6rem}
.footer-social a{
  width:42px;height:42px;border-radius:50%;border:1px solid var(--line-dark);
  display:grid;place-items:center;color:var(--crema);transition:background .25s, border-color .25s, color .25s, transform .25s var(--ease);
}
.footer-social a:hover{background:var(--oro);border-color:var(--oro);color:#20251c;transform:translateY(-2px)}
.footer-social svg{width:20px;height:20px}
.footer-bottom{
  display:flex;flex-wrap:wrap;gap:.6rem;justify-content:space-between;
  padding-block:1.4rem 2rem;border-top:1px solid var(--line-dark);
  font-size:.84rem;color:var(--crema-dim);
}
.footer-bottom a{color:var(--crema-dim);text-decoration:none}
.footer-bottom a:hover{color:var(--oro-soft)}

/* ============================================================
   FLOATING WHATSAPP
   ============================================================ */
.wa-float{
  position:fixed;right:clamp(1rem,3vw,2rem);bottom:clamp(1rem,3vw,2rem);z-index:70;
  width:58px;height:58px;border-radius:50%;background:#25D366;color:#fff;
  display:grid;place-items:center;text-decoration:none;
  box-shadow:0 14px 34px -10px rgba(37,211,102,.7);
  transform:translateY(130%) scale(.7);opacity:0;
  transition:transform .45s var(--ease), opacity .45s, box-shadow .25s;
}
.wa-float.is-visible{transform:none;opacity:1}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:30px;height:30px}

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lightbox{
  position:fixed;inset:0;z-index:120;display:grid;place-items:center;
  padding:clamp(1rem,4vw,3rem);
  background:rgba(18,22,17,.93);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
  opacity:0;visibility:hidden;transition:opacity .3s var(--ease), visibility .3s;
}
.lightbox.is-open{opacity:1;visibility:visible}
.lightbox__figure{margin:0;max-width:min(1100px,92vw);text-align:center}
.lightbox__figure img{max-width:100%;max-height:84vh;object-fit:contain;border-radius:6px;box-shadow:0 40px 90px -20px #000}
.lightbox__figure figcaption{color:var(--crema-dim);margin-top:.9rem;font-size:.9rem;letter-spacing:.04em}
.lightbox button{
  position:absolute;background:rgba(243,238,228,.1);border:1px solid rgba(243,238,228,.25);
  color:var(--crema);width:50px;height:50px;border-radius:50%;cursor:pointer;
  display:grid;place-items:center;transition:background .25s, transform .25s var(--ease);
}
.lightbox button:hover{background:rgba(243,238,228,.22)}
.lightbox button svg{width:24px;height:24px}
.lightbox__close{top:clamp(1rem,3vw,2rem);right:clamp(1rem,3vw,2rem)}
.lightbox__nav{top:50%;transform:translateY(-50%)}
.lightbox__nav:hover{transform:translateY(-50%) scale(1.06)}
.lightbox__nav--prev{left:clamp(.6rem,3vw,2rem)}
.lightbox__nav--next{right:clamp(.6rem,3vw,2rem)}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1000px){
  .manifesto__grid{grid-template-columns:1fr}
  .feature__grid{grid-template-columns:1fr}
  .feature__media{min-height:54vh}
  .feature__media::after{background:linear-gradient(0deg, rgba(43,53,40,.7), transparent 40%)}
  .certs{grid-template-columns:1fr}
  .certs__media{max-width:460px}
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:repeat(2, 1fr)}
}

@media (max-width:760px){
  .nav-links{display:none}
  .nav-toggle{display:block}
  .menu-cat{grid-template-columns:1fr;gap:1.2rem}
  .menu-cat__label p{max-width:none}
  .hero__loc{display:none}
  .footer-grid{grid-template-columns:1fr;gap:2.2rem}
}

@media (max-width:520px){
  body{font-size:16px}

  /* HERO: più arioso e meno gigante su telefono */
  .hero__inner{padding-block:5rem 3.2rem}
  .hero .eyebrow{font-size:.66rem;letter-spacing:.16em;margin-bottom:.85rem}
  .hero__title{font-size:1.95rem;line-height:1.12;margin:.25em 0 .55em}
  .hero__sub{font-size:1rem;max-width:42ch}
  .hero__actions{flex-direction:column;align-items:stretch;gap:.65rem;margin-top:1.6rem}
  .hero__actions .btn{width:100%;padding:.82em 1.3em;font-size:.92rem}
  .hero__scroll{display:none}

  /* titoli di sezione leggermente più piccoli */
  .title{font-size:1.7rem}
  .manifesto__title{font-size:1.7rem}
  .feature__title{font-size:1.95rem}

  .field-row{grid-template-columns:1fr}
  .nav-actions .btn--sm{display:none} /* sul mobile resta il FAB + menu */

  /* GALLERIA: da colonna lunghissima a slider orizzontale */
  .gallery-grid{
    display:flex;grid-template-columns:none;gap:1rem;
    overflow-x:auto;scroll-snap-type:x mandatory;
    margin-inline:calc(var(--gutter) * -1);padding-inline:var(--gutter);
    scroll-padding-inline:var(--gutter);scrollbar-width:none;
  }
  .gallery-grid::-webkit-scrollbar{display:none}
  .gallery-item{flex:0 0 82%;scroll-snap-align:center}
  .gallery-dots{display:flex;justify-content:center;gap:.55rem;margin-top:1.2rem}
}

/* ============================================================
   MOTION OFF
   ============================================================ */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
  [data-reveal],.js [data-reveal]{opacity:1;transform:none}
  .hero__media img{animation:none}
}
