/* =============================================================
   CASA MARÈA — Favignana · Design System
   Ispirato al template "The Stay" (Manrope + serif accent),
   ri-vestito con una palette mediterranea autentica.
   ============================================================= */

/* ---------- Design tokens ---------- */
:root {
  /* Colori */
  --ink:        #1e5e9e;   /* azzurro mediterraneo — testo / sezioni scure */
  --ink-soft:   #3576b8;
  --paper:      #ffffff;
  --cream:      #f7f2ea;   /* sezioni alternate, calde */
  --cream-2:    #efe7d9;
  --sea:        #0f7b8a;   /* accento principale (turchese Favignana) */
  --sea-deep:   #0a5a66;
  --sea-light:  #2aa7b0;
  --sand:       #c9a86b;   /* accento caldo (tufo) */
  --muted:      #6f7275;   /* testo secondario */
  --muted-2:    #9a9ea2;
  --line:       #e7e0d3;   /* bordi su crema */
  --line-dark:  rgba(255,255,255,.14);

  /* Tipografia */
  --sans: 'Manrope', system-ui, -apple-system, Segoe UI, sans-serif;
  --serif: 'Averia Serif Libre', Georgia, 'Times New Roman', serif;

  /* Raggi & ombre */
  --r-sm: 14px;
  --r-md: 24px;
  --r-lg: 32px;
  --r-pill: 100px;
  --shadow-sm: 0 4px 18px rgba(23,24,26,.06);
  --shadow-md: 0 18px 50px rgba(23,24,26,.10);
  --shadow-lg: 0 30px 80px rgba(10,90,102,.18);

  /* Layout */
  --container: 1200px;
  --gap: clamp(1rem, 3vw, 2rem);
  --nav-h: 76px;

  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--sans);
  color: var(--ink);
  background: var(--paper);
  line-height: 1.6;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img,svg,video { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button,input,textarea,select { font: inherit; color: inherit; }
ul { list-style: none; padding: 0; }
:focus-visible { outline: 3px solid var(--sea-light); outline-offset: 3px; border-radius: 4px; }

/* ---------- Tipografia ---------- */
h1,h2,h3,h4 { font-weight: 700; line-height: 1.08; letter-spacing: -.02em; }
h1 { font-size: clamp(2.7rem, 7.5vw, 6rem); font-weight: 700; }
h2 { font-size: clamp(2rem, 4.4vw, 3.1rem); }
h3 { font-size: clamp(1.3rem, 2.4vw, 1.7rem); }
.serif { font-family: var(--serif); font-weight: 400; font-style: italic; letter-spacing: -.01em; }
.eyebrow {
  font-size: .78rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase;
  color: var(--sea); display: inline-flex; align-items: center; gap: .55rem;
}
.eyebrow::before { content:""; width: 26px; height: 1.5px; background: var(--sea); display:inline-block; }
.lead { font-size: clamp(1.05rem, 1.6vw, 1.25rem); color: var(--muted); font-weight: 400; }
.muted { color: var(--muted); }

/* ---------- Layout ---------- */
.container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: clamp(1.15rem, 4vw, 2.5rem); }
.section { padding-block: clamp(4.5rem, 9vw, 8rem); }
.section--cream { background: var(--cream); }
.section--dark { background: var(--ink); color: var(--paper); }
.section--dark .lead,.section--dark .muted { color: rgba(255,255,255,.85); }
.section--tight { padding-block: clamp(3rem, 6vw, 5rem); }
.section-head { max-width: 640px; margin-bottom: clamp(2.2rem, 5vw, 3.6rem); }
.section-head.center { margin-inline: auto; text-align: center; }
.section-head .eyebrow { margin-bottom: 1.1rem; }
.section-head h2 { margin-bottom: 1rem; }

.grid { display: grid; gap: var(--gap); }
.grid-2 { grid-template-columns: repeat(2,1fr); }
.grid-3 { grid-template-columns: repeat(3,1fr); }
.grid-4 { grid-template-columns: repeat(4,1fr); }
@media (max-width: 900px){ .grid-3,.grid-4 { grid-template-columns: repeat(2,1fr);} }
@media (max-width: 620px){ .grid-2,.grid-3,.grid-4 { grid-template-columns: 1fr; } }

/* ---------- Bottoni ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .55rem;
  padding: .85rem 1.6rem; border-radius: var(--r-pill); font-weight: 600; font-size: .96rem;
  border: 1.5px solid transparent; cursor: pointer; transition: all .25s var(--ease);
  white-space: nowrap;
}
.btn svg { width: 18px; height: 18px; }
.btn--dark { background: var(--ink); color: #fff; }
.btn--dark:hover { background: var(--sea-deep); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.btn--sea { background: var(--sea); color: #fff; }
.btn--sea:hover { background: var(--sea-deep); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.btn--light { background: #fff; color: var(--ink); border-color: var(--line); }
.btn--light:hover { border-color: var(--ink); transform: translateY(-2px); }
.btn--ghost { background: transparent; color: var(--ink); border-color: currentColor; }
.btn--ghost:hover { background: var(--ink); color: #fff; }
.section--dark .btn--ghost { color: #fff; }
.section--dark .btn--ghost:hover { background: #fff; color: var(--ink); }
.btn--lg { padding: 1.05rem 2rem; font-size: 1.02rem; }
.btn--block { width: 100%; }

/* ---------- Navbar ---------- */
.nav {
  position: fixed; inset: 0 0 auto 0; z-index: 100; height: var(--nav-h);
  display: flex; align-items: center;
  transition: background .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease);
  border-bottom: 1px solid transparent;
}
.nav__inner { display: flex; align-items: center; justify-content: space-between; width: 100%;
  max-width: var(--container); margin-inline: auto; padding-inline: clamp(1.15rem, 4vw, 2.5rem); }
.brand { display: flex; align-items: center; gap: .6rem; font-weight: 800; font-size: 1.15rem; letter-spacing: -.02em; }
.brand__mark { width: 30px; height: 30px; flex: none; }
.brand small { display:block; font-size: .62rem; font-weight: 600; letter-spacing: .22em; text-transform: uppercase; color: var(--sea); margin-top: -3px; }
.nav__links { display: flex; align-items: center; gap: clamp(1rem, 2.2vw, 2rem); }
.nav__links a { font-weight: 500; font-size: .95rem; position: relative; padding: .2rem 0; transition: color .2s; }
.nav__links a::after { content:""; position:absolute; left:0; bottom:-2px; width:0; height:2px; background: var(--sea); transition: width .25s var(--ease); }
.nav__links a:hover::after,.nav__links a.active::after { width:100%; }
.nav__cta { display:flex; align-items:center; gap:.8rem; }

/* colore su hero (trasparente) vs scrolled (bianco) */
.nav[data-theme="light"] { color: #fff; text-shadow: 0 1px 14px rgba(10,20,40,.5); }
.nav[data-theme="light"].scrolled { text-shadow: none; }
.hero .eyebrow, .hero p { text-shadow: 0 1px 22px rgba(10,20,40,.45); }
.nav[data-theme="light"] .brand small { color: rgba(255,255,255,.85); }
.nav[data-theme="light"] .nav__links a::after { background:#fff; }
.nav.scrolled { background: rgba(255,255,255,.88); backdrop-filter: saturate(180%) blur(14px);
  -webkit-backdrop-filter: saturate(180%) blur(14px); color: var(--ink); border-bottom-color: var(--line); box-shadow: 0 4px 24px rgba(23,24,26,.05); }
.nav.scrolled .brand small { color: var(--sea); }
.nav.scrolled .nav__links a::after { background: var(--sea); }
.nav.scrolled .btn--light { border-color: var(--line); }

/* Hamburger */
.nav__toggle { display:none; width:44px; height:44px; border:none; background:transparent; cursor:pointer; position:relative; }
.nav__toggle span { position:absolute; left:11px; right:11px; height:2px; background: currentColor; transition: .3s var(--ease); }
.nav__toggle span:nth-child(1){ top:16px; } .nav__toggle span:nth-child(2){ top:22px; } .nav__toggle span:nth-child(3){ top:28px; }
body.menu-open .nav__toggle span:nth-child(1){ top:22px; transform: rotate(45deg); }
body.menu-open .nav__toggle span:nth-child(2){ opacity:0; }
body.menu-open .nav__toggle span:nth-child(3){ top:22px; transform: rotate(-45deg); }

@media (max-width: 860px){
  .nav__toggle { display:block; z-index:110; }

  .nav__links {
    position: fixed; inset: 0; z-index: 105;            /* sopra il nav, sotto la X (110) */
    flex-direction: column; justify-content: center; gap: 1.6rem;
    background: var(--ink); color:#fff;
    transform: translateX(100%);
    transition: transform .4s var(--ease);
    font-size: 1.4rem;
    overflow-y: auto;                                    /* schermi bassi/landscape: scroll interno */
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;                        /* non propaga lo scroll alla pagina dietro */
  }
  .nav__links a { color:#fff; font-size:1.5rem; }
  .nav__links .btn { font-size:1.1rem; }
  body.menu-open .nav__links { transform: translateX(0); }
  .nav__cta .btn:not(.nav__toggle){ display:none; }

  /* FIX BUG: .nav.scrolled applica backdrop-filter, che rende .nav il containing
     block dei figli position:fixed → il menu (inset:0) collassa alla barra da 76px
     e la pagina "sfonda". A menu aperto togliamo il filtro: .nav__links torna a
     coprire l'intero viewport, indipendentemente dallo scroll. */
  body.menu-open .nav,
  body.menu-open .nav.scrolled {
    background: transparent;
    -webkit-backdrop-filter: none;
    backdrop-filter: none;
    box-shadow: none;
    border-bottom-color: transparent;
  }
  /* hamburger/X sempre bianca e visibile sopra il menu scuro */
  body.menu-open .nav__toggle { color:#fff; }
}

/* ---------- WhatsApp floating button ---------- */
.wa-fab{
  position:fixed; right:clamp(1rem,4vw,1.75rem); bottom:clamp(1rem,4vw,1.75rem); z-index:90;
  width:56px; height:56px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background:#25D366; color:#fff;
  box-shadow:0 8px 24px rgba(37,211,102,.42), 0 2px 8px rgba(0,0,0,.18);
  transition:transform .2s var(--ease), box-shadow .2s var(--ease);
}
.wa-fab svg{ width:30px; height:30px; display:block; }
.wa-fab:hover{ transform:scale(1.08); box-shadow:0 12px 30px rgba(37,211,102,.55), 0 3px 10px rgba(0,0,0,.2); }
.wa-fab:active{ transform:scale(.98); }
body.menu-open .wa-fab{ opacity:0; visibility:hidden; pointer-events:none; }
@media (max-width:560px){ .wa-fab{ width:52px; height:52px; } .wa-fab svg{ width:27px; height:27px; } }
@media (prefers-reduced-motion:reduce){ .wa-fab{ transition:none; } }

/* ---------- Cookie consent banner ---------- */
.cookie-banner{
  position:fixed; left:0; right:0; bottom:0; z-index:100;
  display:none; align-items:center; justify-content:space-between; gap:1rem 1.5rem; flex-wrap:wrap;
  background:var(--ink); color:#fff;
  padding:1rem clamp(1rem,4vw,2.5rem);
  box-shadow:0 -6px 24px rgba(0,0,0,.2);
}
.cookie-banner.show{ display:flex; }
.cookie-banner__txt{ margin:0; font-size:.88rem; line-height:1.55; max-width:64ch; color:rgba(255,255,255,.9); }
.cookie-banner__txt a{ color:#fff; text-decoration:underline; }
.cookie-banner__btns{ display:flex; gap:.6rem; flex:none; }
.cookie-banner__btn{ padding:.6rem 1.3rem; font-size:.88rem; }
@media (max-width:560px){
  .cookie-banner{ flex-direction:column; align-items:stretch; }
  .cookie-banner__btns{ justify-content:flex-end; }
}

/* ---------- Hero ---------- */
.hero { position: relative; min-height: 100svh; display: flex; align-items: flex-end;
  color:#fff; padding-bottom: clamp(3rem, 8vh, 6rem); overflow: hidden; }
.hero__bg { position:absolute; inset:0; z-index:-2; }
.hero__bg img { width:100%; height:100%; object-fit: cover; }
.hero::after { content:""; position:absolute; inset:0; z-index:-1;
  background: linear-gradient(180deg, rgba(13,25,52,.26) 0%, rgba(13,25,52,0) 42%, rgba(10,20,42,.58) 100%); }
.hero__content { max-width: 900px; }
.hero h1 { margin-bottom: 1.4rem; text-shadow: 0 2px 40px rgba(0,0,0,.25); }
.hero p { font-size: clamp(1.05rem, 1.7vw, 1.35rem); max-width: 540px; color: rgba(255,255,255,.92); margin-bottom: 2rem; }
.hero__actions { display:flex; flex-wrap:wrap; gap: 1rem; align-items:center; }
.hero__scroll { position:absolute; left:50%; bottom:1.6rem; transform:translateX(-50%); z-index:1;
  font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; opacity:.8; display:flex; flex-direction:column; align-items:center; gap:.5rem; }
.hero__scroll span { width:1px; height:34px; background:#fff; animation: scrolldot 1.8s infinite; }
@keyframes scrolldot { 0%{transform:scaleY(0);transform-origin:top} 50%{transform:scaleY(1);transform-origin:top} 51%{transform-origin:bottom} 100%{transform:scaleY(0);transform-origin:bottom} }

/* mini booking bar sotto hero */
/* Glass scuro (frosted dark) — stessa forma, estetica da riferimento */
.bookingbar { background: rgba(16,24,36,.42); -webkit-backdrop-filter: blur(30px) saturate(150%); backdrop-filter: blur(30px) saturate(150%);
  color:#fff; border-radius: var(--r-md);
  box-shadow: 0 26px 60px rgba(0,0,0,.38), inset 0 1px 0 rgba(255,255,255,.2);
  display:grid; grid-template-columns: repeat(4,1fr) auto; gap:0; overflow:hidden; margin-top: 2.5rem; border:1px solid rgba(255,255,255,.24); }
.bookingbar label { display:flex; flex-direction:column; gap:.2rem; padding:1rem 1.3rem; border-right:1px solid rgba(255,255,255,.14);
  font-size:.72rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.62); }
.bookingbar input,.bookingbar select { border:none; background:transparent; font-size:.98rem; font-weight:700; color:#fff; padding:.15rem 0; color-scheme: dark; }
.bookingbar select option { color:#17294d; }
.bookingbar input::placeholder { color:rgba(255,255,255,.6); }
.bookingbar .btn { border-radius:0; margin:.55rem; background:#fff; color:var(--ink); border-color:transparent; }
.bookingbar .btn:hover { background:#eaf1f7; color:var(--ink); transform:none; box-shadow:none; }
@media (max-width: 820px){ .bookingbar { grid-template-columns: 1fr 1fr; } .bookingbar .btn{ grid-column:1/-1; } .bookingbar label:nth-child(2){border-right:none;} }
@media (max-width: 520px){ .bookingbar { grid-template-columns:1fr; } .bookingbar label{ border-right:none; border-bottom:1px solid rgba(255,255,255,.14);} }
/* Su mobile l'hero cresce con il contenuto e parte sotto la navbar (niente sovrapposizioni) */
@media (max-width: 720px){
  .hero { min-height: auto; align-items: flex-start;
    padding-top: calc(var(--nav-h) + 1.75rem); padding-bottom: 3rem; }
  .hero__scroll { display:none; }
  .hero__actions .btn { flex: 1 1 auto; }
}

/* ---------- Split (immagine + testo) ---------- */
.split { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 4.5rem); align-items:center; }
.split--rev .split__media { order: 2; }
.split__media { border-radius: var(--r-lg); overflow:hidden; box-shadow: var(--shadow-md); aspect-ratio: 4/5; }
.split__media img { width:100%; height:100%; object-fit:cover; transition: transform .8s var(--ease); }
.split__media:hover img { transform: scale(1.05); }
.split__body h2 { margin-bottom: 1.2rem; }
.split__body p + p { margin-top: 1rem; }
@media (max-width: 820px){ .split { grid-template-columns:1fr; } .split--rev .split__media{ order:0; } .split__media{ aspect-ratio:16/11; } }

/* ---------- Amenities / feature list ---------- */
.feature { padding: 1.8rem; border-radius: var(--r-md); background: rgba(255,255,255,.04); border:1px solid var(--line-dark);
  transition: transform .3s var(--ease), background .3s; }
.section--dark .feature:hover { transform: translateY(-6px); background: rgba(255,255,255,.08); }
.feature__ic { width:46px; height:46px; border-radius:12px; display:grid; place-items:center; margin-bottom:1.1rem;
  background: rgba(42,167,176,.16); color: var(--sea-light); }
.feature__ic svg { width:24px; height:24px; }
.feature h3 { font-size:1.15rem; margin-bottom:.5rem; }
.feature p { font-size:.94rem; }

/* light amenities (chips) */
.amen-list { display:grid; grid-template-columns: repeat(3,1fr); gap: .8rem 1.6rem; }
.amen-list li { display:flex; align-items:center; gap:.7rem; padding:.5rem 0; border-bottom:1px solid var(--line); font-weight:500; }
.amen-list svg { width:20px; height:20px; color: var(--sea); flex:none; }
@media (max-width:700px){ .amen-list{ grid-template-columns:1fr 1fr; } }
@media (max-width:460px){ .amen-list{ grid-template-columns:1fr; } }

/* ---------- Card (esperienze / blog) ---------- */
.card { background:#fff; border-radius: var(--r-lg); overflow:hidden; box-shadow: var(--shadow-sm);
  border:1px solid var(--line); transition: transform .35s var(--ease), box-shadow .35s; display:flex; flex-direction:column; }
.card:hover { transform: translateY(-8px); box-shadow: var(--shadow-md); }
.card__img { aspect-ratio: 3/2; overflow:hidden; }
.card__img img { width:100%; height:100%; object-fit:cover; transition: transform .7s var(--ease); }
.card:hover .card__img img { transform: scale(1.07); }
.card__body { padding: 1.5rem 1.5rem 1.7rem; flex:1; display:flex; flex-direction:column; }
.card__tag { font-size:.72rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--sea); margin-bottom:.6rem; }
.card h3 { font-size:1.25rem; margin-bottom:.5rem; }
.card p { font-size:.95rem; color:var(--muted); margin-bottom:1rem; }
.card__link { margin-top:auto; font-weight:600; color:var(--ink); display:inline-flex; align-items:center; gap:.4rem; }
.card__link svg { width:16px; height:16px; transition: transform .25s var(--ease); }
.card:hover .card__link svg { transform: translateX(4px); }

/* ---------- Stats / rating ---------- */
.stats { display:flex; flex-wrap:wrap; gap: clamp(1.5rem, 5vw, 4rem); }
.stat__num { font-family: var(--serif); font-size: clamp(2.4rem, 5vw, 3.4rem); font-style: italic; line-height:1; color: var(--sea); }
.stat__lbl { font-size:.9rem; color:var(--muted); margin-top:.4rem; }

/* ---------- Rates ---------- */
.ratecard { background:#fff; border:1px solid var(--line); border-radius: var(--r-lg); padding: 2.2rem; box-shadow: var(--shadow-sm); }
.ratecard.featured { background: var(--ink); color:#fff; border-color:var(--ink); box-shadow: var(--shadow-lg); }
.ratecard .price { font-size: 2.6rem; font-weight:800; letter-spacing:-.03em; }
.ratecard .price small { font-size:.95rem; font-weight:500; color: var(--muted); }
.ratecard.featured .price small { color: rgba(255,255,255,.6); }
.ratecard ul { margin:1.4rem 0; display:flex; flex-direction:column; gap:.7rem; }
.ratecard li { display:flex; gap:.6rem; align-items:flex-start; font-size:.95rem; }
.ratecard li svg { width:19px; height:19px; color:var(--sea-light); flex:none; margin-top:2px; }

/* ---------- Testimonianze ---------- */
.quote { background:#fff; border:1px solid var(--line); border-radius: var(--r-md); padding: 1.8rem; box-shadow: var(--shadow-sm); }
.quote__stars { color: var(--sand); letter-spacing:2px; margin-bottom:.9rem; }
.quote p { font-size:1.02rem; line-height:1.65; margin-bottom:1.2rem; }
.quote__who { display:flex; align-items:center; gap:.8rem; }
.quote__av { width:44px; height:44px; border-radius:50%; background: var(--cream-2); display:grid; place-items:center; font-weight:700; color:var(--sea-deep); }
.quote__who b { display:block; font-size:.95rem; }
.quote__who span { font-size:.82rem; color:var(--muted); }

/* ---------- CTA band ---------- */
.cta-band { position:relative; border-radius: var(--r-lg); overflow:hidden; color:#fff; padding: clamp(3rem,7vw,5.5rem); text-align:center; }
.cta-band__bg { position:absolute; inset:0; z-index:-2; }
.cta-band__bg img { width:100%; height:100%; object-fit:cover; }
.cta-band::after { content:""; position:absolute; inset:0; z-index:-1; background: linear-gradient(180deg, rgba(18,35,72,.44), rgba(11,21,44,.68)); }
.cta-band h2 { margin-bottom:1rem; }
.cta-band p { max-width:520px; margin:0 auto 2rem; color:rgba(255,255,255,.9); }

/* ---------- Gallery ---------- */
.gallery { columns: 3; column-gap: 1rem; }
@media (max-width:900px){ .gallery{ columns:2; } }
@media (max-width:560px){ .gallery{ columns:1; } }
.gallery figure { break-inside: avoid; margin:0 0 1rem; border-radius: var(--r-md); overflow:hidden; cursor:zoom-in; position:relative; box-shadow: var(--shadow-sm); }
.gallery img { width:100%; transition: transform .6s var(--ease); }
.gallery figure:hover img { transform: scale(1.06); }
.gallery figcaption { position:absolute; left:0; right:0; bottom:0; padding:1.4rem 1rem .9rem; color:#fff; font-size:.85rem; font-weight:600;
  background: linear-gradient(transparent, rgba(0,0,0,.6)); opacity:0; transition: opacity .3s; }
.gallery figure:hover figcaption { opacity:1; }

/* Lightbox */
.lightbox { position:fixed; inset:0; z-index:200; background:rgba(15,20,22,.94); display:none; place-items:center; padding:2rem; }
.lightbox.open { display:grid; }
.lightbox img { max-width:92vw; max-height:86vh; border-radius: var(--r-sm); box-shadow: var(--shadow-lg); }
.lightbox__close,.lightbox__nav { position:absolute; background:rgba(255,255,255,.12); border:none; color:#fff; cursor:pointer;
  width:52px; height:52px; border-radius:50%; display:grid; place-items:center; transition:background .2s; }
.lightbox__close:hover,.lightbox__nav:hover { background:rgba(255,255,255,.25); }
.lightbox__close { top:1.5rem; right:1.5rem; font-size:1.5rem; }
.lightbox__nav { top:50%; transform:translateY(-50%); font-size:1.6rem; }
.lightbox__nav.prev { left:1.5rem; } .lightbox__nav.next { right:1.5rem; }
.lightbox__cap { position:absolute; bottom:1.4rem; left:0; right:0; text-align:center; color:rgba(255,255,255,.8); font-size:.9rem; }

/* ---------- Form ---------- */
.form { display:grid; gap:1.15rem; }
.form .row { display:grid; grid-template-columns:1fr 1fr; gap:1.15rem; }
@media (max-width:560px){ .form .row{ grid-template-columns:1fr; } }
.field { display:flex; flex-direction:column; gap:.4rem; }
.field label { font-size:.82rem; font-weight:700; letter-spacing:.04em; color:var(--ink); }
.field label .req { color:var(--sea); }
.field label .opt { color:var(--muted); font-weight:400; font-size:.85em; }
.field input,.field select,.field textarea {
  border:1.5px solid var(--line); background:#fff; border-radius: var(--r-sm); padding:.85rem 1rem; font-size:1rem;
  transition: border-color .2s, box-shadow .2s; width:100%;
}
.field input:focus,.field select:focus,.field textarea:focus { outline:none; border-color:var(--sea); box-shadow:0 0 0 4px rgba(15,123,138,.12); }
.field textarea { resize:vertical; min-height:120px; }
.form__note { font-size:.82rem; color:var(--muted); }
.form__hp { position:absolute; left:-9999px; opacity:0; height:0; overflow:hidden; }
.form-status { padding:1rem 1.2rem; border-radius: var(--r-sm); font-weight:600; font-size:.95rem; display:none; }
.form-status.show { display:block; }
.form-status.ok { background:#e7f6f2; color:#0a5a53; border:1px solid #b9e3d8; }
.form-status.err { background:#fdecec; color:#a12525; border:1px solid #f3c9c9; }

/* ---------- Footer ---------- */
.footer { background: var(--ink); color: rgba(255,255,255,.7); padding-block: clamp(3rem,6vw,4.5rem) 2rem; }
.footer__grid { display:grid; grid-template-columns: 1.6fr 1fr 1fr 1.2fr; gap: 2.5rem; margin-bottom: 3rem; }
@media (max-width:820px){ .footer__grid{ grid-template-columns:1fr 1fr; gap:2rem; } }
@media (max-width:480px){ .footer__grid{ grid-template-columns:1fr; } }
.footer h4 { color:#fff; font-size:.8rem; letter-spacing:.14em; text-transform:uppercase; margin-bottom:1.1rem; }
.footer a { transition: color .2s; } .footer a:hover { color:#fff; }
.footer ul { display:flex; flex-direction:column; gap:.6rem; font-size:.95rem; }
.footer .brand { color:#fff; margin-bottom:1rem; }
.footer__about p { font-size:.95rem; max-width:32ch; }
.footer__social { display:flex; gap:.7rem; margin-top:1.2rem; }
.footer__social a { width:40px; height:40px; border-radius:50%; border:1px solid var(--line-dark); display:grid; place-items:center; }
.footer__social a:hover { background:var(--sea); border-color:var(--sea); color:#fff; }
.footer__social svg { width:18px; height:18px; }
.footer__bottom { border-top:1px solid var(--line-dark); padding-top:1.8rem; display:flex; justify-content:space-between; flex-wrap:wrap; gap:1rem; font-size:.85rem; }

/* ---------- Page header (pagine interne) ---------- */
.pagehead { position:relative; padding-top: calc(var(--nav-h) + clamp(3.5rem,8vw,6rem)); padding-bottom: clamp(3.5rem,8vw,6rem); color:#fff; overflow:hidden; }
.pagehead__bg { position:absolute; inset:0; z-index:-2; } .pagehead__bg img{ width:100%; height:100%; object-fit:cover; }
.pagehead::after { content:""; position:absolute; inset:0; z-index:-1; background: linear-gradient(180deg, rgba(13,25,52,.32) 20%, rgba(10,20,42,.6)); }
.pagehead .breadcrumb { font-size:.85rem; opacity:.85; margin-bottom:1rem; }
.pagehead .breadcrumb a:hover { text-decoration:underline; }
.pagehead h1 { font-size: clamp(2.4rem,6vw,4.2rem); margin-bottom:1rem; }
.pagehead p { max-width:560px; color:rgba(255,255,255,.9); font-size:clamp(1rem,1.5vw,1.2rem); }

/* ---------- Reveal on scroll ----------
   Nascosto solo se il JS è attivo (classe .js su <html>): senza JS
   tutto resta visibile. In questo modo il contenuto non sparisce mai. */
@media (prefers-reduced-motion: no-preference){
  .js .reveal { opacity:0; transform: translateY(28px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
  .js .reveal.in { opacity:1; transform:none; }
  .js .reveal[data-delay="1"]{ transition-delay:.08s; }
  .js .reveal[data-delay="2"]{ transition-delay:.16s; }
  .js .reveal[data-delay="3"]{ transition-delay:.24s; }
}

/* ---------- Utility ---------- */
.text-center { text-align:center; }
.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}
.mb-0{margin-bottom:0}
.divider { height:1px; background:var(--line); border:none; margin-block: clamp(3rem,6vw,5rem); }
.nav__links .only-mobile { display:none; }
@media (max-width:860px){ .nav__links .only-mobile { display:inline-flex; } }
.aspect-wide { aspect-ratio:16/10; object-fit:cover; width:100%; border-radius:var(--r-lg); }
.map-embed { border:0; width:100%; height:100%; min-height:360px; border-radius:var(--r-lg); filter:grayscale(.15); }
.placeholder-note { position:absolute; top:.7rem; left:.7rem; background:rgba(23,24,26,.78); color:#fff; font-size:.68rem;
  font-weight:600; letter-spacing:.03em; padding:.35rem .6rem; border-radius:8px; z-index:2; pointer-events:none; }
