/* ============================================================================
   sito/static/sito/sito.css — skin V4.1 "I Manifesti di Sicilia" (PR-S1a)
   Mobile-first. Palette/tema dalle CSS vars (--navy/--oro/--crema/--text dal record
   Sito; --blu/--terra/--fume fissi V4.1). Font: Alfa Slab One (titoli),
   Permanent Marker (battute), Inter (testo). Poster siciliano denso, niente minimal.
   ============================================================================ */

*{ margin:0; padding:0; box-sizing:border-box; }

/* Ancore nav (#camere/#servizi/#dove…) sotto la nav sticky → offset, niente salto secco
   coperto dall'header. Smooth solo se l'utente NON ha chiesto reduced-motion. */
.site section[id]{ scroll-margin-top:84px; }
@media (prefers-reduced-motion: no-preference){
  html{ scroll-behavior:smooth; }
}

body.oasi{
  background:var(--sand);
  color:var(--text);
  font-family:'Inter',system-ui,sans-serif;
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}

.alfa{ font-family:'Alfa Slab One',Georgia,serif; font-weight:400; letter-spacing:.01em; }
.mark{ font-family:'Permanent Marker',cursive; }

.site{ overflow-x:hidden; }

/* ---- ingredienti del kit ---------------------------------------------------- */

/* sticker/etichetta a blocco ruotata (V4.1 §2.5) */
.sticker{
  display:inline-block;
  background:var(--terra);
  color:var(--crema);
  font-family:'Alfa Slab One',serif;
  font-size:.82rem;
  letter-spacing:.04em;
  padding:5px 14px;
  transform:rotate(-2deg);
  box-shadow:0 6px 16px rgba(18,56,79,.18);
}

/* eyebrow Inter spaziato */
.eyebrow{
  display:inline-block;
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--terra);
  margin-bottom:14px;
}

/* scritte eco: UN solo nodo testo (fill) + contorno oro da pseudo-elemento (no doppione DOM).
   `data-text` porta lo stesso testo; ::before lo ricalca come outline perfettamente allineato. */
.eco{
  position:relative; display:inline-block; line-height:.92;
  font-family:'Alfa Slab One',serif; text-transform:uppercase; color:var(--navy);
}
.eco::before{
  content:attr(data-text);
  position:absolute; left:0; top:0; z-index:-1;
  -webkit-text-stroke:1.6px var(--oro); text-stroke:1.6px var(--oro);
  color:transparent; pointer-events:none;
}

/* fascia firma O·A·S·I (V4.1 §2.7) */
.firma{
  background:var(--navy);
  color:var(--crema);
  text-align:center;
  font-weight:700;
  font-size:.6rem;
  letter-spacing:.26em;
  padding:14px 16px;
}
.firma--page{ border-top:4px solid var(--terra); }

/* ---- HERO "LA BASE" --------------------------------------------------------- */

.hero{
  position:relative;
  min-height:92vh;
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:64px 24px 0;
  overflow:hidden;
  background:var(--sand);
}
/* halftone d'angolo (mezzitoni V4.1 §2.2) */
.hero__halftone{
  position:absolute; top:-40px; right:-40px;
  width:240px; height:240px;
  background-image:radial-gradient(var(--oro) 1.5px, transparent 1.6px);
  background-size:11px 11px;
  opacity:.5;
  -webkit-mask-image:radial-gradient(circle at 70% 30%, #000 40%, transparent 72%);
  mask-image:radial-gradient(circle at 70% 30%, #000 40%, transparent 72%);
  pointer-events:none;
}
.hero__inner{
  position:relative; z-index:2;
  max-width:920px; margin:0 auto; width:100%;
}
.hero__eyebrow{ margin-bottom:20px; }
.hero__title{ font-size:clamp(3.4rem,17vw,9rem); margin:6px 0 0; }
.hero__tagline{
  color:var(--blu);
  font-size:clamp(1.25rem,5vw,2rem);
  transform:rotate(-2deg);
  margin-top:26px;
  max-width:18ch;
}
/* sottotitolo descrittivo sotto la battuta marker (voce assertiva, non difensiva) */
.hero__sub{
  color:var(--text);
  font-size:clamp(1rem,2.6vw,1.12rem);
  line-height:1.5;
  max-width:42ch;
  margin-top:18px;
}
.hero__scene{
  position:relative; z-index:1;
  margin-top:40px;
  width:100%;
}
.hero__etna{
  display:block; width:100%; height:auto;
  max-height:42vh;
}
.hero__star{
  position:absolute; top:-6px; left:14%;
  width:26px; height:26px; z-index:3;
}

/* ---- HERO foto: immagine di sfondo + scrim scuro + overlay testo (go-live) ---- */
/* Contenuto CENTRATO verticalmente (non più ancorato in fondo): spazio top/bottom bilanciato
   dentro l'hero → la CTA non crowda la sezione "BENVENUTI" sotto. */
.hero--photo{ min-height:92vh; padding:72px 24px; justify-content:center; }
.hero__bg{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; z-index:0;
}
.hero__scrim{
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(18,56,79,.34) 0%, rgba(18,56,79,.46) 46%, rgba(18,56,79,.62) 100%);
}
.hero__inner--photo{ z-index:2; text-align:left; }
/* Leggibilità su immagine: oltre allo scrim, un'ombra leggera sul testo (NON sull'headline
   eco, che ha già profondità da outline+offset → l'ombra la incupirebbe). */
.hero__eyebrow-photo,.hero__corsivo,.hero__subline,.hero__introtext{ text-shadow:0 2px 14px rgba(18,56,79,.45); }
/* Occhiello NAVY su TAG CREMA: navy su crema = leggibile su qualsiasi immagine, stile "tag"
   coerente con la grafica social. Niente alone (ridondante sullo sfondo crema). */
.hero__eyebrow-photo{
  display:inline-block; font-family:'Inter',sans-serif; font-weight:700;
  font-size:.74rem; letter-spacing:.22em; text-transform:uppercase;
  color:var(--navy); margin-bottom:18px;
  background:var(--crema); padding:5px 12px; border-radius:5px; text-shadow:none;
}
/* "blu del mare" + "pietra lavica" (subline) NAVY con HIGHLIGHT INLINE crema (più leggero del
   tag pieno per non appesantire la subline). box-decoration-break:clone → su a capo ogni
   segmento mantiene padding/angoli. */
.hero__navy{
  color:var(--navy); background:var(--crema);
  padding:0 .22em; border-radius:4px; text-shadow:none;
  -webkit-box-decoration-break:clone; box-decoration-break:clone;
}
/* Headline col trattamento ECO (come le sezioni), su fondo scuro: outline ORO + fill CREMA
   (vedi .rev__eco). "SICILIA" nel layer fill → oro. Stesso font Alfa, niente testo piatto. */
/* letter-spacing per dare aria all'Alfa Slab (default troppo stretto → "SICILIA" schiacciata).
   Nessuna scale/compressione applicata; l'outline ::before eredita lo spacing → resta allineato. */
.hero__eco{ margin:0; font-size:clamp(2.6rem,11vw,6rem); line-height:1; letter-spacing:.05em; color:var(--crema); }
.hero__eco .hero__oro{ color:var(--oro); }
.hero__oro{ color:var(--oro); }
.hero__crema{ color:var(--crema); }
.hero__rule{ display:block; width:84px; height:4px; background:var(--oro); border-radius:2px; margin:24px 0 16px; }
/* Sottotitolo + subline in MARKER (handwritten), come gli accenti del sito. NON sans piatto. */
.hero__corsivo{
  font-family:'Permanent Marker',cursive; color:var(--crema);
  font-size:clamp(1.4rem,5vw,2.1rem); line-height:1.1; margin:0 0 10px; transform:rotate(-2deg);
}
.hero__subline{
  font-family:'Permanent Marker',cursive; color:var(--crema);
  font-size:clamp(1.2rem,3.4vw,1.7rem); line-height:1.25; margin:0 0 18px; max-width:24ch;
}
.hero__introtext{
  font-family:'Inter',sans-serif; color:rgba(251,247,240,.86);
  font-size:clamp(.98rem,2.4vw,1.08rem); line-height:1.5; max-width:42ch; margin:0;
}

/* ---- BLOCCHI DI CONTENUTO (intro / fallback) ------------------------------- */

.intro,
.block{
  padding:60px 24px;
}
.intro__inner,
.block__inner{
  max-width:760px; margin:0 auto;
}
.intro__title,
.block__title{
  font-size:clamp(1.8rem,7vw,3rem);
  color:var(--navy);
  line-height:1.05;
  margin:4px 0 22px;
  text-transform:uppercase;
}

/* prosa / markdown minimale */
.prose p{ margin:0 0 1.1em; color:var(--text); }
.prose p:last-child{ margin-bottom:0; }
.prose strong{ color:var(--navy); font-weight:700; }
.prose em{ font-style:italic; }
.prose ul{ list-style:none; margin:1.2em 0 0; padding:0; }
.prose li{
  position:relative;
  padding:12px 0 12px 30px;
  border-bottom:1.5px dashed rgba(18,56,79,.18);
  font-weight:600;
  color:var(--navy);
}
.prose li:before{
  content:"";
  position:absolute; left:2px; top:50%;
  width:12px; height:12px; margin-top:-6px;
  background:var(--terra);
  /* stellina 4 punte come bullet */
  clip-path:polygon(50% 0,61% 39%,100% 50%,61% 61%,50% 100%,39% 61%,0 50%,39% 39%);
}

/* Fondi-sezione: un'unica base sabbia calda (no alternanza, no bianco). Il ritmo
   lo danno le fasce firma navy, le recensioni navy e il footer navy. */

/* ---- CTA di conversione (terracotta = colore CTA V4.1) --------------------- */

.cta{
  display:inline-block;
  background:var(--terra);
  color:var(--crema);
  font-weight:700;
  font-size:1rem;
  letter-spacing:.03em;
  text-decoration:none;
  padding:15px 30px;
  border-radius:5px;            /* radius leggero V4.1 — NON pill */
  box-shadow:0 10px 26px rgba(201,106,59,.34);
  transition:transform .2s ease, background .2s ease;
}
.cta:hover{ background:#b35e34; transform:translateY(-2px); }   /* scurire terracotta */
.cta:active{ transform:translateY(0); }

/* CTA sticky: barra in fondo, SOLO mobile (si prenota da telefono). NAVY + testo chiaro
   (leggibile su qualsiasi sfondo/immagine); il cookie banner sta 72px sopra → non copre. */
.cta-sticky{
  position:fixed; left:0; right:0; bottom:0; z-index:50;
  display:block; text-align:center;
  background:var(--navy); color:var(--crema);
  border-top:2px solid var(--oro);
  font-weight:700; font-size:1.02rem; letter-spacing:.03em;
  text-decoration:none;
  padding:16px 20px calc(16px + env(safe-area-inset-bottom,0px));
  box-shadow:0 -8px 24px rgba(18,56,79,.3);
}
.cta-sticky:active{ background:#0c2a3c; }   /* navy più scuro */

/* ---- responsive ------------------------------------------------------------ */

@media (max-width:767px){
  body.oasi{ padding-bottom:66px; }   /* spazio per la CTA sticky */
}


@media (min-width:768px){
  .hero{ padding:88px 48px 0; }
  .intro, .block{ padding:84px 48px; }
  .hero__star{ width:34px; height:34px; left:10%; }
  .cta-sticky{ display:none; }   /* su desktop basta la CTA nel menu nav */
}

@media (prefers-reduced-motion: reduce){
  *{ transition:none !important; }
}

/* ============================================================================
   PR-S1 completo — header/nav, sezioni vetrina, blog, form, footer
   ============================================================================ */

.muted{ color:#7a8a93; }
.eyebrow{ display:inline-block; font-size:.72rem; font-weight:700; letter-spacing:.22em;
  text-transform:uppercase; color:var(--terra); }

/* ---- header / nav ---- */
/* nessun blur dietro la nav sticky: era un repaint a ogni frame di scroll (jank). Lo
   sfondo è 98% opaco → il blur era impercettibile; rimosso per scroll fluido. */
.nav{ position:sticky; top:0; z-index:60; display:flex; align-items:center; justify-content:space-between;
  gap:16px; padding:12px 22px; background:rgba(244,239,224,.98);
  box-shadow:0 0 0 rgba(94,64,38,0); transition:box-shadow .28s ease; }
/* E: niente linea navy dura — ombra morbida CALDA, invisibile in cima, accennata su scroll */
.nav--scrolled{ box-shadow:0 8px 24px rgba(94,64,38,.14); }
.nav__logo{ display:flex; flex-direction:column; line-height:1; text-decoration:none; color:var(--navy); }
.nav__wordmark{ font-size:1.5rem; letter-spacing:.06em; }
.nav__tag{ font-size:.6rem; letter-spacing:.18em; text-transform:uppercase; color:var(--terra); font-weight:700; }
.nav__menu{ display:flex; align-items:center; gap:22px; }
.nav__menu a{ color:var(--navy); text-decoration:none; font-weight:600; font-size:.92rem; }
.nav__menu a:hover{ color:var(--terra); }
.nav__cta{ background:var(--terra); color:var(--crema) !important; padding:9px 18px; font-weight:700; border-radius:5px; }
/* selettore lingua nell'head (oltre al footer) — sempre visibile desktop+mobile */
.nav__lang{ display:flex; align-items:center; gap:4px; font-size:.78rem; font-weight:700;
  letter-spacing:.04em; }
.nav__lang a{ color:var(--navy); text-decoration:none; padding:3px 5px; border-radius:3px; }
.nav__lang a:hover{ color:var(--terra); }
.nav__lang a.on{ color:var(--terra); }
.nav__lang span{ color:rgba(18,56,79,.32); }
.nav__logo{ padding:2px 0; margin-right:auto; }   /* logo a sx, resto (menu+lang+burger) a dx */
.nav__logoimg{ height:54px; width:auto; display:block; }
.nav__logoimg--sq{ height:58px; }
@media (min-width:768px){ .nav__logoimg{ height:62px; } .nav__logoimg--sq{ height:66px; } }
.foot__logoimg{ height:64px; width:auto; display:block; margin-bottom:6px; }
.nav__burger{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:6px; }
.nav__burger span{ width:24px; height:2.5px; background:var(--navy); }

/* ---- sezioni generiche ---- */
.sec{ padding-block:clamp(64px,8vw,120px); padding-inline:24px; }
/* Ritmo superfici — TUTTO CALDO (mai near-white clinico): si alterna solo tra due toni
   sabbia, --sand (chiaro) ↔ --sand3 (profondo), + bande navy. Regola: mai 3 uguali di fila. */
.sec--cream{ background:var(--sand3); }        /* sabbia profonda */
.sec--white{ background:var(--sand); }          /* sabbia chiara (warm, niente bianco) */
.sec--navy{ background:var(--navy); color:var(--crema); }
/* Divisore VISIBILE tra due sezioni CHIARE adiacenti (dove non c'è banda navy a staccarle).
   Le sezioni home sono <section> sorelle → selettore adiacente affidabile. Nastro oro sfumato. */
.sec--cream + .sec--cream, .sec--cream + .sec--white,
.sec--white + .sec--cream, .sec--white + .sec--white{ position:relative; }
.sec--cream + .sec--cream::before, .sec--cream + .sec--white::before,
.sec--white + .sec--cream::before, .sec--white + .sec--white::before{
  content:""; position:absolute; top:0; left:50%; transform:translateX(-50%);
  width:min(200px,46%); height:3px; border-radius:3px; pointer-events:none;
  background:linear-gradient(90deg, transparent, var(--oro) 50%, transparent);
}
.intro{ padding-block:clamp(64px,8vw,120px); }
.sec__head{ max-width:920px; margin:0 auto 30px; }
.sec__head--center{ text-align:center; }
.sec__title{ font-size:clamp(1.9rem,7vw,3rem); color:var(--navy); text-transform:uppercase; line-height:1.04; margin:4px 0 0; }
.sec__more{ text-align:center; margin-top:30px; }
.cards{ max-width:980px; margin:0 auto; display:grid; gap:22px; grid-template-columns:1fr; }

/* placeholder "cornice manifesto" */
.ph{ position:relative; width:100%; aspect-ratio:4/3; background:var(--navy);
  background-image:radial-gradient(rgba(200,164,106,.34) 1.4px, transparent 1.5px); background-size:12px 12px;
  display:flex; align-items:flex-end; }
.ph__label{ background:var(--terra); color:var(--crema); font-size:1rem; padding:6px 14px; margin:14px; transform:rotate(-2deg); }

/* ---- camere ---- */
.card-room{ background:var(--sand2); border:1.5px solid rgba(18,56,79,.14); overflow:hidden; display:flex; flex-direction:column; }
.card-room__photo{ position:relative; }
.card-room__photo img{ width:100%; aspect-ratio:4/3; object-fit:cover; display:block; }
/* Galleria camera (hero + UnitPhoto): carosello scroll-snap, niente JS. Swipe su mobile,
   scroll/drag su desktop; scrollbar nascosta. Ogni slide = larghezza piena della card.
   snap=proximity (non mandatory) + overscroll-x:contain → non cattura lo scroll VERTICALE
   della pagina passandoci sopra (era una causa del jank). */
.card-room__track{ display:flex; overflow-x:auto; scroll-snap-type:x proximity;
  overscroll-behavior-x:contain; -webkit-overflow-scrolling:touch; scrollbar-width:none; }
.card-room__track::-webkit-scrollbar{ display:none; }
.card-room__track > img{ flex:0 0 100%; scroll-snap-align:start; }
.card-room__count{ position:absolute; top:9px; right:9px; z-index:2; background:rgba(18,56,79,.74);
  color:#fff; font-family:'Inter',sans-serif; font-weight:700; font-size:.62rem; letter-spacing:.05em;
  text-transform:uppercase; padding:3px 9px; border-radius:20px; }
/* badge prezzo "da € XX" — prominente (terracotta = colore conversione, numero in display) */
.card-room__from{ position:absolute; bottom:0; left:0; background:var(--terra); color:var(--crema);
  font-family:'Alfa Slab One',serif; font-weight:400; font-size:1.12rem; letter-spacing:.01em;
  padding:9px 16px; box-shadow:0 10px 22px rgba(201,106,59,.36); }
.card-room__from small{ font-family:'Inter',sans-serif; font-weight:700; font-size:.62rem; opacity:.95;
  text-transform:uppercase; letter-spacing:.05em; }
.card-room__from small:first-child{ margin-right:1px; }
.card-room__body{ padding:18px 18px 20px; }
.card-room__name{ font-family:'Alfa Slab One',serif; font-weight:400; color:var(--navy); font-size:1.25rem; margin:0 0 8px; }
.card-room__desc{ color:var(--text); margin:0 0 14px; font-size:.95rem; }
.card-room__price-note{ color:var(--text); opacity:.62; margin:-6px 0 14px; font-size:.74rem; line-height:1.35; }

/* ---- servizi ---- */
/* Punto 5: servizi in due gruppi etichettati (Inclusi / Su richiesta), non lista piatta. */
.srv-groups{ max-width:920px; margin:0 auto; display:grid; gap:34px; }
.srv-group__t{ font-family:'Alfa Slab One',serif; text-transform:uppercase; color:var(--navy);
  font-size:1.05rem; letter-spacing:.02em; margin:0 0 16px; padding-bottom:7px;
  border-bottom:2.5px solid rgba(200,164,106,.55); display:inline-block; }
.srv-group--extra .srv-group__t{ color:var(--terra); border-bottom-color:rgba(201,106,59,.45); }
.srv-grid{ max-width:920px; margin:0 auto; display:grid; gap:14px; grid-template-columns:1fr; }
.srv{ display:flex; gap:14px; align-items:flex-start; padding:16px; background:var(--sand2); border:1.5px solid rgba(18,56,79,.12); }
.srv__star{ flex:none; width:16px; height:16px; margin-top:4px; background:var(--terra);
  clip-path:polygon(50% 0,61% 39%,100% 50%,61% 61%,50% 100%,39% 61%,0 50%,39% 39%); }
.srv__t{ font-size:1.04rem; font-weight:700; color:var(--navy); margin:0 0 3px; }
.srv__d{ font-size:.92rem; color:var(--text); margin:0; }
.badge{ font-size:.62rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--terra); border:1.5px solid var(--terra); padding:1px 7px; border-radius:3px; vertical-align:1px; }

/* ---- dove siamo ---- */
.dove{ max-width:980px; margin:0 auto; display:grid; gap:22px; grid-template-columns:1fr; }
.dove__addr{ font-size:1.1rem; }
.dove__map iframe{ width:100%; height:300px; border:0; border-radius:14px; }
/* Leaflet: angoli arrotondati come le card (overflow:hidden clippa i tile). */
.dove__mapcanvas{ width:100%; height:340px; border:2px solid var(--oro); border-radius:14px; overflow:hidden; z-index:0; }
.oasi-pin{ background:none; border:0; }   /* divIcon: niente sfondo/bordo default */
.leaflet-container{ font-family:'Inter',sans-serif; background:var(--sand2); }

/* ---- recensioni ---- */
/* §5.3: .sec:nth-of-type(even){#F3EAD9} (0,2,0) batteva .sec--rev (0,1,0) → la
   sezione restava crema e i testi crema/oro diventavano illeggibili. Alzo la
   specificità a (0,2,0) + source-order successivo → navy vince davvero. */
.sec.sec--rev{ background:var(--navy); color:var(--crema); }
.sec--rev .sec__title{ color:var(--crema); }
.rev{ display:flex; gap:20px; justify-content:center; flex-wrap:wrap; }
.rev__badge{ display:flex; flex-direction:column; align-items:center; gap:4px; text-decoration:none; background:rgba(251,247,240,.07); border:1.5px solid var(--oro); padding:20px 32px; color:var(--crema); }
.rev__score{ font-size:2.6rem; color:var(--oro); }
.rev__src{ font-size:.8rem; letter-spacing:.08em; text-transform:uppercase; }

/* ---- blog cards ---- */
.card-art{ display:block; text-decoration:none; color:var(--navy); background:var(--sand2); border:1.5px solid rgba(18,56,79,.14); overflow:hidden; }
.card-art__photo img{ width:100%; aspect-ratio:16/10; object-fit:cover; display:block; }
.card-art__photo .ph{ aspect-ratio:16/10; }
.card-art__body{ padding:16px 18px 20px; }
.card-art__t{ font-family:'Alfa Slab One',serif; font-weight:400; font-size:1.2rem; margin:6px 0 6px; }
.card-art__d{ font-size:.92rem; color:var(--text); margin:0; }

/* ---- CTA finale ---- */
.sec--final{ text-align:center; }   /* bg dalla classe superficie (.sec--white) */
.final{ max-width:760px; margin:0 auto; }
.final__eco{ margin:0 auto; font-size:clamp(2.6rem,12vw,5.5rem); }
.final__mark{ color:var(--blu); font-size:1.4rem; transform:rotate(-2deg); margin:18px 0 0; }
.final__cta{ margin-top:26px; }
.final__contacts{ margin-top:22px; display:flex; gap:18px; justify-content:center; flex-wrap:wrap; }
.final__contacts a{ color:var(--navy); font-weight:600; }

/* ---- pagehero (pagine interne) ---- */
.pagehero{ padding:70px 24px 30px; max-width:920px; margin:0 auto; }
.pagehero--center{ text-align:center; }
.pagehero--sm{ padding:54px 24px 20px; }
.pagehero__eco{ line-height:.9; margin-top:6px; font-size:clamp(3rem,15vw,7rem); }
.pagehero__h1{ font-size:clamp(2rem,8vw,3.4rem); color:var(--navy); text-transform:uppercase; }
.pagehero__mark{ font-family:'Permanent Marker',cursive; color:var(--blu); font-size:1.3rem; transform:rotate(-2deg); margin-top:18px; }

/* ---- form prenotazione ---- */
.formwrap{ max-width:720px; margin:0 auto; padding:10px 24px 70px; }
.bform{ position:relative; }
.bform .grid2{ display:grid; gap:14px; grid-template-columns:1fr; }
.bform label{ display:block; font-weight:600; font-size:.85rem; color:var(--navy); margin-bottom:14px; }
.bform label.full{ display:block; }
.gv-input, .bform input, .bform select, .bform textarea{ width:100%; margin-top:6px; min-height:46px; border:1.5px solid rgba(18,56,79,.25); border-radius:12px; background:#fff; color:var(--text); padding:10px 12px; font:inherit; font-size:.95rem; }
.bform textarea{ min-height:auto; }
.bform .errorlist{ list-style:none; margin:6px 0 0; padding:0; color:#a32d2d; font-size:.8rem; font-weight:600; }
.ferr{ background:#fcebeb; color:#a32d2d; padding:12px 14px; border-radius:10px; margin-bottom:16px; }
.consent{ font-size:.82rem; color:#7a8a93; margin:16px 0; }

/* ---- article / blog detail / legale ---- */
.article{ max-width:720px; margin:0 auto; padding:60px 24px 70px; }
.article__title{ font-size:clamp(2rem,7vw,3rem); color:var(--navy); text-transform:uppercase; line-height:1.05; margin:6px 0 0; }
.article__sub{ color:var(--blu); font-size:1.2rem; transform:rotate(-1deg); margin:14px 0 0; }
.article__cover{ width:100%; aspect-ratio:16/9; object-fit:cover; margin:26px 0; }
.article__back{ margin-top:34px; }
.grazie__lead{ font-size:1.15rem; max-width:30ch; margin:18px auto 0; }
.grazie__code{ margin-top:14px; color:#7a8a93; }

/* ---- footer ---- */
.foot{ background:var(--navy); color:var(--crema); padding:48px 24px 0; }
.foot__grid{ max-width:980px; margin:0 auto; display:grid; gap:30px; grid-template-columns:1fr; }
.foot__wordmark{ font-size:1.8rem; letter-spacing:.06em; }
.foot__tag{ font-size:.75rem; color:var(--oro); margin-top:4px; }
.foot__h{ font-size:.75rem; letter-spacing:.16em; text-transform:uppercase; color:var(--oro); margin:0 0 10px; font-weight:700; }
.foot p{ margin:0 0 7px; font-size:.92rem; }
.foot a{ color:var(--crema); text-decoration:none; }
.foot a:hover{ color:var(--oro); }
.foot__social{ display:flex; gap:14px; margin-top:12px; }
.foot__lang a.on{ color:var(--oro); font-weight:700; }
.foot__legal{ max-width:980px; margin:34px auto 0; border-top:1px solid rgba(251,247,240,.18); padding:16px 0 calc(20px + env(safe-area-inset-bottom,0px)); text-align:center; font-size:.68rem; letter-spacing:.12em; color:rgba(251,247,240,.7); }

/* ---- cookie banner ---- */
/* mobile: sopra la CTA sticky (bottom:0, ~56px) per non coprirla; desktop: in basso a SX
   (non sopra le CTA centrali/hero) — vedi override desktop. */
.cookie{ position:fixed; left:12px; right:12px; bottom:calc(72px + env(safe-area-inset-bottom,0px)); z-index:55; background:var(--navy); color:var(--crema); display:flex; gap:12px; align-items:center; justify-content:space-between; flex-wrap:wrap; padding:12px 16px; border:2px solid var(--oro); font-size:.84rem; box-shadow:0 12px 30px rgba(18,56,79,.3); }
/* `display:flex` vincerebbe sull'attributo HTML `hidden` → il banner restava sempre
   visibile e "Ho capito" non lo nascondeva mai. `[hidden]` (specificità più alta) lo onora. */
.cookie[hidden]{ display:none; }
.cookie a{ color:var(--oro); }
.cookie button{ background:var(--terra); color:var(--crema); border:0; font-weight:700; padding:9px 18px; cursor:pointer; }

/* ============================================================================
   §11 DENSITÀ V4.1 — manifesti pieni: stelline, eco di sezione, illustrazioni,
   fascia firma per blocco, scene illustrate. Niente spazi morti.
   ============================================================================ */

.sec{ position:relative; overflow:hidden; }
.sticker--b{ background:var(--navy); }
.eyebrow--oro{ color:var(--oro); }

/* stelline decorative sparse */
.sec__star{ position:absolute; width:22px; height:22px; background:var(--terra);
  clip-path:polygon(50% 0,61% 39%,100% 50%,61% 61%,50% 100%,39% 61%,0 50%,39% 39%); opacity:.85; pointer-events:none; }
.sec__star--a{ top:34px; right:8%; }
.sec__star--b{ bottom:60px; left:6%; background:var(--oro); width:16px; height:16px; }

/* titolo eco centrato di sezione + marker */
.sec__eco,.rev__eco,.terr__eco{ line-height:.9; font-size:clamp(2.4rem,9vw,4.4rem); }
/* sec/terr = fill navy (base); rev (su navy) = fill crema (sotto). Outline oro dal base ::before. */
.sec__mark{ font-family:'Permanent Marker',cursive; color:var(--blu); font-size:1.2rem; transform:rotate(-2deg); margin-top:14px; }

/* fascia firma per sezione */
.firma--sec{ margin:42px -24px -60px; }
@media (min-width:768px){ .firma--sec{ margin:54px -48px -84px; } }
.firma--rev{ margin-top:40px; background:var(--oro); color:var(--navy); }

/* ---- servizi: card illustrate ---- */
.srv-grid{ grid-template-columns:1fr 1fr; }
.srv{ flex-direction:column; align-items:flex-start; gap:8px; text-align:left; }
.srv__illus{ width:56px; height:56px; }
.illus{ width:100%; height:100%; display:block; }
.srv--extra{ border-style:dashed; border-color:var(--terra); }

/* ---- territorio: split testo + scena illustrata ---- */
.terr{ max-width:1000px; margin:0 auto; display:grid; gap:30px; grid-template-columns:1fr; align-items:center; }
.terr__mark{ font-family:'Permanent Marker',cursive; color:var(--blu); font-size:1.3rem; transform:rotate(-2deg); margin:14px 0; }
.terr__tags{ display:flex; flex-wrap:wrap; gap:10px; margin-top:18px; }
.terr__svg{ width:100%; max-width:380px; height:auto; display:block; margin:0 auto; filter:drop-shadow(0 16px 30px rgba(18,56,79,.22)); }

/* ---- recensioni dense ---- */
.sec--rev .eyebrow{ color:var(--oro); }
.rev__quote{ position:absolute; top:-10px; left:24px; font-family:'Alfa Slab One',serif; font-size:7rem; color:rgba(200,164,106,.3); line-height:1; }
.rev__eco{ color:var(--crema); }   /* recensioni su fondo navy → fill crema (outline oro dal base) */
.rev__mark{ font-family:'Permanent Marker',cursive; color:var(--oro); font-size:1.2rem; transform:rotate(-2deg); margin-top:12px; }
.rev__stars{ color:var(--oro); letter-spacing:2px; font-size:.9rem; }

/* ---- placeholder camera "cornice manifesto" tortora ---- */
.ph--tortora{ background:#BBA88F; display:flex; align-items:center; justify-content:center; }
.ph__halftone{ position:absolute; inset:0; width:100%; height:100%; }
.ph__bed{ width:46%; max-width:120px; opacity:.85; }
.ph__rot{ position:absolute; left:14px; bottom:44px; background:var(--terra); color:var(--crema); padding:5px 13px; font-size:1rem; transform:rotate(-2deg); box-shadow:0 6px 16px rgba(18,56,79,.2); }

/* ---- hero: sticker distanze ---- */
.hero__dist{ display:flex; flex-wrap:wrap; gap:10px; margin-top:26px; }
.hero__dist .sticker{ font-size:.72rem; padding:5px 12px; }

/* ---- galleria foto reali (cornice manifesto) ---- */
.sec--gall{ }   /* bg dalla classe superficie (.sec--cream) */
.gall{ max-width:1000px; margin:0 auto; display:grid; gap:12px; grid-template-columns:1fr 1fr; }
.gall__item{ position:relative; overflow:hidden; margin:0; border:3px solid var(--crema); box-shadow:0 10px 26px rgba(18,56,79,.18); }
.gall__item img{ width:100%; height:100%; object-fit:cover; display:block; aspect-ratio:4/3; }
.gall__cap{ position:absolute; left:10px; bottom:10px; background:var(--terra); color:var(--crema); font-size:.82rem; padding:4px 11px; transform:rotate(-2deg); }

/* ---- blog cover illustrata ---- */
.card-art__photo .ph{ background:var(--navy); }
.ph--art{ flex-direction:column; align-items:center; justify-content:center; gap:8px; }
.ph__illus{ width:64px; height:64px; }
.ph--art .ph__label{ position:static; margin:0; }

@media (min-width:768px){
  /* riga a 5 tile UNIFORMI (niente tile grande): tutte 4/3, object-fit:cover
     gestisce le verticali (es. Faraglioni 2268×4032) col crop coerente. */
  .gall{ grid-template-columns:repeat(5,1fr); }
  .gall__item--big{ grid-column:auto; grid-row:auto; }
  .gall__item--big img{ aspect-ratio:4/3; height:auto; }
}

@media (min-width:768px){
  .srv-grid{ grid-template-columns:repeat(3,1fr); }
  .terr{ grid-template-columns:1.1fr .9fr; }
}

/* ---- camere: meta + amenities + prezzo su richiesta ---- */
.card-room__meta{ list-style:none; display:flex; flex-wrap:wrap; gap:6px 14px; margin:0 0 10px; padding:0; font-size:.82rem; color:#7a8a93; font-weight:600; }
.card-room__meta li{ position:relative; }
.card-room__meta li+li:before{ content:"·"; position:absolute; left:-9px; }
.card-room__amen{ font-size:.8rem; color:var(--blu); font-weight:600; margin:0 0 14px; }
/* riga dotazioni L2 (data-driven): icona brand + nome, a chip morbidi */
.card-room__dotazioni{ list-style:none; margin:0 0 14px; padding:0; display:flex; flex-wrap:wrap; gap:7px 9px; }
.card-room__dotazioni li{ display:inline-flex; align-items:center; gap:5px; font-size:.78rem;
  font-weight:600; color:var(--navy); }
.dot-ico{ width:17px; height:17px; flex:none; color:var(--navy); }
.card-room__from--req{ background:var(--blu); }

/* S2: mini-calendario disponibilità (read-only). Collassabile via <details>, niente JS. */
.cal-disp{ margin:0 0 14px; border-top:1px solid rgba(18,56,79,.12); padding-top:10px; }
.cal-disp summary{ cursor:pointer; font-weight:700; font-size:.84rem; color:var(--navy);
  list-style:none; display:inline-flex; align-items:center; gap:6px; }
.cal-disp summary::-webkit-details-marker{ display:none; }
.cal-disp summary::before{ content:"📅"; }
.cal-disp[open] summary{ margin-bottom:8px; }
.cal-disp__legend{ font-size:.72rem; color:var(--text); margin:0 0 8px; display:flex; gap:12px; align-items:center; }
.cal-key{ display:inline-block; width:11px; height:11px; border-radius:3px; vertical-align:-1px; margin-right:4px; }
.cal-key--free{ background:var(--sand2); border:1px solid rgba(18,56,79,.25); }
.cal-key--occ{ background:var(--terra); }
.cal-disp__months{ display:flex; flex-wrap:wrap; gap:16px; }
.cal-month__name{ font-size:.78rem; font-weight:700; color:var(--navy); text-transform:uppercase; letter-spacing:.04em; margin-bottom:5px; }
.cal-grid{ display:grid; grid-template-columns:repeat(7,1fr); gap:2px; max-width:182px; }
.cal-wd{ font-size:.6rem; font-weight:700; color:rgba(18,56,79,.5); text-align:center; padding:1px 0; }
.cal-day{ font-size:.64rem; text-align:center; padding:3px 0; border-radius:3px; line-height:1.3; }
.cal-day--free{ background:var(--sand2); color:var(--navy); }
.cal-day--occ{ background:var(--terra); color:var(--crema); }
.cal-day--passato{ color:rgba(18,56,79,.3); }
.cal-day--pad{ visibility:hidden; }

/* S4-ter: contatto diretto (WhatsApp/Email) sotto la card camera. Token brand, mobile-friendly. */
.card-room__direct-q{ font-size:.8rem; color:var(--text); line-height:1.4; margin:14px 0 9px; }
.card-room__direct{ display:flex; gap:8px; flex-wrap:wrap; }
.dbtn{ flex:1 1 120px; display:inline-flex; align-items:center; justify-content:center; gap:7px;
  font-size:.84rem; font-weight:700; text-decoration:none; padding:9px 12px; border-radius:6px;
  border:1.6px solid; transition:background .18s ease, color .18s ease; }
.dbtn svg{ width:17px; height:17px; flex:none; }
.dbtn--wa{ border-color:var(--terra); color:var(--terra); }
.dbtn--wa:hover{ background:var(--terra); color:var(--crema); }
.dbtn--mail{ border-color:var(--navy); color:var(--navy); }
.dbtn--mail:hover{ background:var(--navy); color:var(--crema); }
/* ---- prenota: barra disponibilità + risultati ---- */
.availbar{ display:flex; gap:12px; flex-wrap:wrap; align-items:flex-end; background:var(--sand2); padding:18px; margin-bottom:24px; }
.availbar label{ display:flex; flex-direction:column; font-size:.78rem; font-weight:700; color:var(--navy); gap:6px; flex:1; min-width:120px; }
.availbar .cta{ flex:none; }
.availres__h{ font-size:1rem; margin:0 0 16px; }
.availres__list{ display:grid; gap:12px; }
.availcard{ display:flex; align-items:center; gap:16px; flex-wrap:wrap; background:var(--sand2); border:1.5px solid rgba(18,56,79,.14); padding:14px 18px; }
.availcard__name{ font-size:1.05rem; font-weight:700; color:var(--navy); margin:0; }
.availcard__meta{ font-size:.82rem; color:#7a8a93; margin:2px 0 0; }
.availcard__price{ margin-left:auto; text-align:right; }
.availcard__tot{ display:block; font-family:'Alfa Slab One',serif; font-size:1.3rem; color:var(--terra); }
.availcard__price small{ font-size:.7rem; color:#7a8a93; }
.availcard__req{ color:var(--blu); font-weight:700; }
.availres__none{ background:#fcebeb; color:#a32d2d; padding:14px; font-weight:600; }
.formwrap__h{ font-size:1.5rem; color:var(--navy); text-transform:uppercase; margin:0 0 18px; }
.regole{ font-size:.84rem; color:var(--text); background:var(--sand2); padding:14px 16px; margin:18px 0; line-height:1.5; }
.regole a{ color:var(--terra); font-weight:600; }

/* ---- legale ---- */
.prose--legal h2{ font-family:'Alfa Slab One',serif; font-weight:400; font-size:1.2rem; color:var(--navy); margin:1.6em 0 .5em; }
.prose--legal ul{ margin:.6em 0; padding-left:0; }

.cta--sm{ padding:11px 22px; font-size:.9rem; }
.cta--block{ display:block; width:100%; text-align:center; border:0; cursor:pointer; font-size:1.05rem; }
.cta--ghost{ background:transparent; color:var(--navy); border:2px solid var(--navy); box-shadow:none; }
.cta--ghost:hover{ background:var(--navy); color:var(--crema); }

/* ---- responsive desktop ---- */
@media (min-width:768px){
  .sec{ padding:84px 48px; }
  .cards{ grid-template-columns:repeat(3,1fr); }
  .srv-grid{ grid-template-columns:repeat(2,1fr); }
  .dove{ grid-template-columns:1fr 1fr; align-items:center; }
  .bform .grid2{ grid-template-columns:1fr 1fr; }
  .foot__grid{ grid-template-columns:1.4fr 1fr 1fr; }
  /* desktop: niente CTA sticky → cookie in basso a SINISTRA, compatto, lontano dalle CTA centrali */
  .cookie{ left:18px; right:auto; bottom:18px; max-width:360px; }
}
@media (max-width:767px){
  .nav__menu{ display:none; position:absolute; top:100%; left:0; right:0; flex-direction:column; align-items:stretch; gap:0; background:#F4EFE0; border-bottom:3px solid var(--navy); padding:8px 0; }
  .nav.open .nav__menu{ display:flex; }
  .nav__menu a{ padding:13px 22px; }
  .nav__cta{ margin:8px 22px; text-align:center; }
  .nav__burger{ display:flex; }
  .nav__lang{ margin-right:2px; }   /* piccolo gap dal burger (cluster già a dx via logo) */
}

/* ============================================================================
   DESIGN FINALE A→D (#270) — valori ESATTI Cowork. Solo CSS/markup.
   ============================================================================ */

/* A — STACCO CARD: sabbia più profondo (#EFE4CD) + bordo + radius 14 + ombra
   VISIBILE (il vero stacco). Hover: solleva. Tutte le card su fondo chiaro. */
.srv, .card-room, .card-art, .availcard, .regole, .availbar{
  background:#EFE4CD;
  border:1px solid rgba(18,56,79,.14);
  border-radius:14px;
  box-shadow:0 14px 30px -12px rgba(18,56,79,.28);
  transition:transform .25s ease, box-shadow .25s ease;
}
@media(hover:hover){
  .srv:hover, .card-room:hover, .card-art:hover, .availcard:hover{
    transform:translateY(-4px); box-shadow:0 24px 44px -14px rgba(18,56,79,.34); }
}
.card-room, .card-art{ overflow:hidden; }   /* la foto resta, clip al radius */
/* icone servizi: piene navy/oro, ~32px, non tagliate (set dedicato srv_icon) */
.srv__illus{ width:36px; height:36px; }

/* B — simboli del kit nei margini sabbia (decorativi, sotto i contenuti) */
.kit-star{ position:absolute; pointer-events:none; z-index:0; opacity:.85; background:var(--oro);
  width:24px; height:24px;   /* default; override con --18/--28/--40 */
  clip-path:polygon(50% 0,61% 39%,100% 50%,61% 61%,50% 100%,39% 61%,0 50%,39% 39%); }
.kit-star--terra{ background:var(--terra); }
.kit-star--oro{ background:var(--oro); }
.kit-star--18, .kit-star--sm{ width:18px; height:18px; }
.kit-star--28{ width:28px; height:28px; }
.kit-star--40{ width:40px; height:40px; }
.kit-dots{ position:absolute; pointer-events:none; z-index:0; width:120px; height:120px; opacity:.35;
  background-image:radial-gradient(#C8A574 1.6px, transparent 1.7px); background-size:12px 12px;
  -webkit-mask-image:radial-gradient(circle at 50% 50%, #000 45%, transparent 72%);
  mask-image:radial-gradient(circle at 50% 50%, #000 45%, transparent 72%); }
/* watermark: onda outline grande, navy .05, texture d'angolo */
.kit-wave{ position:absolute; pointer-events:none; z-index:0; width:220px; height:150px; opacity:.05;
  background-repeat:no-repeat; background-size:contain;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 120 80'%3E%3Cg fill='none' stroke='%2312384F' stroke-width='3' stroke-linecap='round'%3E%3Cpath d='M4 20 q15 -12 30 0 t30 0 t30 0 t22 0'/%3E%3Cpath d='M4 42 q15 -12 30 0 t30 0 t30 0 t22 0'/%3E%3Cpath d='M4 64 q15 -12 30 0 t30 0 t30 0 t22 0'/%3E%3C/g%3E%3C/svg%3E"); }
/* contenuti SEMPRE sopra i simboli */
.hero__inner, .intro__inner, .sec__head, .terr, .dove, .final, .cards, .srv-grid, .gall, .rev-quotes{ position:relative; z-index:1; }
.intro, .block, .sec{ position:relative; overflow:hidden; }

/* C — RECENSIONI: 2 testimonial card uguali (stessa altezza) + chip voti */
.rev-quotes{ max-width:940px; margin:0 auto 28px; display:grid; gap:28px; grid-template-columns:1fr; align-items:stretch; }
@media(min-width:768px){ .rev-quotes{ grid-template-columns:1fr 1fr; } }
.testi-card{ background:#F4EFE0; border-radius:16px; padding:30px 32px;
  box-shadow:0 18px 44px -18px rgba(0,0,0,.45); display:flex; flex-direction:column; }
.testi-stars{ color:var(--oro); font-size:18px; letter-spacing:2px; margin-bottom:14px; }
.testi-quote{ color:#12384F; font-size:1.05rem; line-height:1.6; flex:1; margin:0 0 16px; }
.testi-quote .q{ color:var(--oro); font-family:'Alfa Slab One',serif; font-size:1.6em; line-height:0; vertical-align:-.2em; margin-right:3px; }
.testi-by{ font-size:.92rem; }
.testi-by .name{ color:var(--terra); font-weight:700; }
.testi-by .meta{ color:rgba(18,56,79,.7); }
.testi-note{ text-align:center; color:rgba(251,247,240,.55); font-size:.78rem; margin:0 0 18px; }
.scores{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.score-chip{ display:inline-flex; align-items:center; gap:8px; border:1px solid rgba(200,165,116,.5);
  border-radius:999px; padding:8px 18px; color:#FBF7F0; font-weight:700; background:rgba(255,255,255,.04); text-decoration:none; }
.score-chip .num{ color:#C8A574; font-size:1.25rem; }

/* D — DINAMISMO */
/* will-change solo PRIMA dell'entrata (hint GPU per una transition fluida); rilasciato
   a fine animazione (.in) con will-change:auto → niente layer permanenti su ~10 sezioni. */
.js-reveal .reveal{ opacity:0; transform:translateY(28px); will-change:opacity, transform; }
.js-reveal .reveal.in{ opacity:1; transform:none; will-change:auto;
  transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
/* stagger: i figli delle griglie salgono in sequenza (80ms/card). backwards =
   nessun fill-forward → dopo l'entrata l'hover translateY resta libero. */
@keyframes kitRise{ from{ opacity:0; transform:translateY(24px); } to{ opacity:1; transform:none; } }
.js-reveal .reveal.in :is(.cards, .srv-grid, .gall, .rev-quotes) > *{ animation:kitRise .6s cubic-bezier(.2,.7,.2,1) backwards; }
.js-reveal .reveal.in :is(.cards, .srv-grid, .gall, .rev-quotes) > *:nth-child(2){ animation-delay:80ms; }
.js-reveal .reveal.in :is(.cards, .srv-grid, .gall, .rev-quotes) > *:nth-child(3){ animation-delay:160ms; }
.js-reveal .reveal.in :is(.cards, .srv-grid, .gall, .rev-quotes) > *:nth-child(4){ animation-delay:240ms; }
.js-reveal .reveal.in :is(.cards, .srv-grid, .gall, .rev-quotes) > *:nth-child(5){ animation-delay:320ms; }
.js-reveal .reveal.in :is(.cards, .srv-grid, .gall, .rev-quotes) > *:nth-child(6){ animation-delay:400ms; }
/* hover-zoom tile galleria */
.gall__item{ overflow:hidden; }
.gall__item img{ transition:transform .4s ease; }
@media(hover:hover){ .gall__item:hover img{ transform:scale(1.06); } }

/* prefers-reduced-motion: tutto statico e visibile */
@media (prefers-reduced-motion: reduce){
  *{ transition:none !important; animation:none !important; }
  .js-reveal .reveal{ opacity:1 !important; transform:none !important; }
}

/* ── Condivisione articolo blog (PR#19): WhatsApp / Facebook / copia link ── */
.blog-share{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin:1.75rem 0 .5rem;}
.blog-share__label{font-weight:700;font-size:.9rem;color:var(--navy);margin-right:.25rem;}
.blog-share__btn{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .9rem;
  border-radius:10px;font-weight:600;font-size:.85rem;line-height:1;
  border:1.5px solid var(--navy);color:var(--navy);background:transparent;cursor:pointer;
  text-decoration:none;transition:background .15s,color .15s,border-color .15s;}
.blog-share__btn svg{width:16px;height:16px;flex:none;}
.blog-share__btn--wa{border-color:var(--terra);color:var(--terra);}
.blog-share__btn:hover{background:var(--navy);color:#fff;}
.blog-share__btn--wa:hover{background:var(--terra);color:#fff;}
.blog-share__btn.is-copied{background:var(--terra);color:#fff;border-color:var(--terra);}
