/*
Theme Name: ZanetTheme
Theme URI: https://evolutemedia.com
Author: Hannibal Smith
Author URI: https://lazona.biz
Version: 1.0.2
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 8.0
Text Domain: evotheme
*/

/* Slug directory tema: zanet-theme */

/* Base reset minimale */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* Evita scrollbar orizzontale da blocchi alignfull (100vw + scrollbar, margini negativi) */
html {
  overflow-x: hidden;
  /* Allinea meglio vw/client width quando la scrollbar è sempre presente */
  scrollbar-gutter: stable;
}

:root {
  --evotheme-font-family: "Avenir Next LT Pro", "Avenir Next", "Helvetica Neue", Helvetica, Arial, sans-serif;
  /* Allineamento contenuto (site-main e interno Copertina alignfull) */
  --evotheme-content-max-width: 1440px;
  --evotheme-content-padding-x: 1rem;
  /* Sidebar + marcatore Leaflet (.evotheme-leaflet-marker) */
  --evotheme-sidebar-bg: #423629;
}

body {
  margin: 0;
  font-family: var(--evotheme-font-family);
  color: #111;
  background: #fff;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  font-synthesis: none;
}

h1 {
  color: #252525;
  font-size: 3rem;
  font-weight: 500;
  letter-spacing: 10px;
  line-height: 65px;
}

h2 {
  font-size: 3rem;
  font-weight: 500;
  line-height: 65px;
}

/* Pagina Contattaci: mappa Google in scala di grigi */
.page-id-11 iframe[src*="google.com/maps"],
.page-id-11 iframe[src*="google.it/maps"] {
  filter: grayscale(85%);
}

.page-id-11 .leaflet-popup-content-wrapper,
.page-id-11 .leaflet-popup-content,
.page-id-11 .leaflet-popup-tip-container,
.page-id-11 .leaflet-popup-close-button {
  font-family: var(--evotheme-font-family), "Avenir Next LT Pro", "Avenir Next", "Helvetica Neue", Helvetica, Arial, sans-serif !important;
}

.page-id-11 .leaflet-popup-content {
  font-size: 1rem !important;
}

/*
 * Pagina Metodo: solo questo gruppo (non overlay/tab.processo) porta lo sfondo.
 * Il contenuto non deve aumentare l’altezza del box (altrimenti contain lascia bande ai lati): inner-container in absolute.
 * Immagine hero zanet_immagine_metodo_DEF-1-scaled.jpg: 1683×2560 — aspect-ratio = larghezza/altezza; con background-size 100% auto evita crop verticale.
 */
.page-id-39 .site-main .entry-content .metodo-hero-wrapper {
  display: flow-root;
  position: relative;
  isolation: isolate;
  box-sizing: border-box;
  overflow: hidden;
  --metodo-hero-bg-ratio: 1683 / 2560;
  aspect-ratio: var(--metodo-hero-bg-ratio);
  width: 100%;
  max-width: 100%;
  background-image: url("https://stage-zanet.lazona.biz/wp-content/uploads/2026/05/zanet_immagine_metodo_DEF-1-scaled.jpg");
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position: center top;
}

.page-id-39 .site-main .entry-content .metodo-hero-wrapper > .wp-block-group__inner-container {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  z-index: 1;
}

.page-id-39 .site-main .entry-content .metodo-hero-wrapper h1 {
  color: #423629 !important;
}

/*
 * Testo ponte tra hero e tabella processo:
 * - il blocco resta nel markup, ma non occupa altezza nel flusso
 * - il contenuto viene traslato sopra il bordo basso dell'immagine
 * In questo modo la tabella processo si "appoggia" all'immagine senza fascia bianca.
 */
.page-id-39 .site-main .entry-content .metodo-hero-overlay {
  background-color: transparent !important;
  padding-top: 0 !important;
  padding-right: 0 !important;
  padding-bottom: 0 !important;
  padding-left: 0 !important;
  height: 0;
  min-height: 0;
  overflow: visible;
  position: relative;
  z-index: 2;
}

.page-id-39 .site-main .entry-content .metodo-hero-overlay > .wp-block-group__inner-container {
  max-width: var(--evotheme-content-max-width);
  margin: 0 auto;
  padding: 0 1.5rem 2.1rem;
  transform: translateY(calc(-100% - 0.2rem));
  text-align: center;
}

.page-id-39 .site-main .entry-content .metodo-hero-overlay p {
  width: min(100%, 980px);
  margin: 0 auto !important;
  text-align: center !important;
}

.page-id-39 .site-main .entry-content p {
  font-style: normal !important;
  font-weight: 400 !important;
  font-size: 20px !important;
  line-height: 34px !important;
}

/* Pagina Metodo - sezione tabellare processi */
.page-id-39 .site-main .entry-content .metodo-process-table {
  background-color: #fff !important;
}

.page-id-39 .site-main .entry-content .metodo-process-table > .wp-block-group__inner-container {
  max-width: var(--evotheme-content-max-width);
  margin: 0 auto;
}

.page-id-39 .site-main .entry-content .metodo-process-table .wp-block-columns {
  margin: 0 !important;
  align-items: center !important;
  min-height: 132px;
  border-top-color: #e8ddc2 !important;
}

.page-id-39 .site-main .entry-content .metodo-process-table .wp-block-column {
  padding-top: 1.5rem !important;
  padding-bottom: 1.5rem !important;
}

.page-id-39 .site-main .entry-content .metodo-process-table .wp-block-column:first-child {
  flex-basis: 24% !important;
}

.page-id-39 .site-main .entry-content .metodo-process-table .wp-block-column:nth-child(2) {
  flex-basis: 61% !important;
}

.page-id-39 .site-main .entry-content .metodo-process-table .wp-block-column:last-child {
  flex-basis: 15% !important;
}

.page-id-39 .site-main .entry-content .metodo-process-table .wp-block-column:first-child p,
.page-id-39 .site-main .entry-content .metodo-process-table .wp-block-column:first-child strong {
  font-size: 26px !important;
  line-height: 1.22 !important;
  letter-spacing: 0.01em !important;
  font-weight: 500 !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
}

.page-id-39 .site-main .entry-content .metodo-process-table .wp-block-column:nth-child(2) p {
  font-size: 20px !important;
  line-height: 34px !important;
  letter-spacing: 0 !important;
  font-weight: 400 !important;
}

.page-id-39 .site-main .entry-content .metodo-process-table .wp-block-column:last-child p {
  margin: 0 !important;
  text-align: center !important;
}

.page-id-39 .site-main .entry-content .metodo-process-table .wp-block-column:last-child .emoji {
  width: 80px !important;
  height: 80px !important;
  max-width: none !important;
  vertical-align: middle;
  filter: grayscale(100%) contrast(0.85) brightness(0.72);
  opacity: 0.7;
}

@media (max-width: 1200px) {
  .page-id-39 .site-main .entry-content .metodo-hero-overlay > .wp-block-group__inner-container {
    padding-right: 1.2rem;
    padding-left: 1.2rem;
  }

  .page-id-39 .site-main .entry-content .metodo-hero-overlay p {
    width: min(100%, 820px);
    font-size: 18px !important;
    line-height: 1.5 !important;
  }

  .page-id-39 .site-main .entry-content .metodo-process-table .wp-block-column:first-child {
    flex-basis: 28% !important;
  }

  .page-id-39 .site-main .entry-content .metodo-process-table .wp-block-column:nth-child(2) {
    flex-basis: 56% !important;
  }

  .page-id-39 .site-main .entry-content .metodo-process-table .wp-block-column:last-child {
    flex-basis: 16% !important;
  }

  .page-id-39 .site-main .entry-content .metodo-process-table .wp-block-column:first-child p,
  .page-id-39 .site-main .entry-content .metodo-process-table .wp-block-column:first-child strong {
    font-size: 22px !important;
    line-height: 1.25 !important;
  }

  .page-id-39 .site-main .entry-content .metodo-process-table .wp-block-column:nth-child(2) p {
    font-size: 17px !important;
    line-height: 1.6 !important;
  }

  .page-id-39 .site-main .entry-content .metodo-process-table .wp-block-column:last-child .emoji {
    width: 64px !important;
    height: 64px !important;
  }
}

@media (max-width: 960px) {
  .page-id-39 .site-main .entry-content .metodo-hero-wrapper {
    margin: 0 !important;
    padding: 0 !important;
    background-size: cover;
    background-position: center top;
    aspect-ratio: auto;
    min-height: clamp(420px, 72vh, 620px);
  }

  .page-id-39 .site-main .entry-content .metodo-hero-wrapper > .wp-block-group__inner-container {
    position: relative;
    left: auto;
    right: auto;
    top: auto;
    padding: 0;
  }

  .page-id-39 .site-main .entry-content .metodo-hero-wrapper > .wp-block-group__inner-container > .wp-block-group {
    padding-top: 1.25rem !important;
    padding-right: 1rem !important;
    padding-bottom: 0.75rem !important;
    padding-left: 1rem !important;
    text-align: center !important;
  }

  /*
   * Titolo Metodo mobile: in editor il heading può avere .has-text-align-justify / justify nel markup:
   * forza il centro con specificità sul blocco heading e sugli h*.
   */
  .page-id-39 .site-main .entry-content .metodo-hero-wrapper .wp-block-heading,
  .page-id-39 .site-main .entry-content .metodo-hero-wrapper .wp-block-heading.has-text-align-justify,
  .page-id-39 .site-main .entry-content .metodo-hero-wrapper .wp-block-heading.has-text-align-left,
  .page-id-39 .site-main .entry-content .metodo-hero-wrapper .wp-block-heading.has-text-align-right,
  .page-id-39 .site-main .entry-content .metodo-hero-wrapper :where(h1, h2, h3) {
    text-align: center !important;
  }

  .page-id-39 .site-main .entry-content .metodo-hero-wrapper > .wp-block-group__inner-container > .wp-block-group > p {
    text-align: left !important;
  }

  .page-id-39 .site-main .entry-content .metodo-hero-wrapper h1 {
    font-size: clamp(2rem, 8.6vw, 2.7rem) !important;
    line-height: 1.08 !important;
    letter-spacing: 0.01em !important;
    margin: 0 0 0.55rem !important;
    text-align: center !important;
  }

  .page-id-39 .site-main .entry-content .metodo-hero-wrapper p {
    width: min(100%, 680px);
    margin: 0 auto !important;
    font-size: 15px !important;
    line-height: 1.45 !important;
    letter-spacing: 0.01em !important;
  }

  .page-id-39 .site-main .entry-content .metodo-hero-overlay {
    height: auto;
    min-height: 0;
    overflow: visible;
  }

  .page-id-39 .site-main .entry-content .metodo-hero-overlay > .wp-block-group__inner-container {
    padding: 0.55rem 1rem 2.25rem;
    transform: none;
  }

  .page-id-39 .site-main .entry-content .metodo-hero-overlay p,
  .page-id-39 .site-main .entry-content p {
    width: min(100%, 680px);
    font-size: 16px !important;
    line-height: 1.55 !important;
    letter-spacing: 0.01em !important;
  }

  .page-id-39 .site-main .entry-content .metodo-process-table .wp-block-columns {
    display: grid !important;
    grid-template-columns: 56px minmax(0, 1fr) !important;
    min-height: 0;
    gap: 0.15rem 2rem !important;
  }

  .page-id-39 .site-main .entry-content .metodo-process-table .wp-block-column {
    flex-basis: 100% !important;
    width: 100% !important;
    padding: 0.9rem 1rem !important;
  }

  .page-id-39 .site-main .entry-content .metodo-process-table .wp-block-column:first-child {
    grid-column: 2;
    grid-row: 1;
    padding-left: 0 !important;
  }

  .page-id-39 .site-main .entry-content .metodo-process-table .wp-block-column:nth-child(2) {
    grid-column: 1 / -1;
    grid-row: 2;
    border-left-width: 0 !important;
    padding-top: 0 !important;
  }

  .page-id-39 .site-main .entry-content .metodo-process-table .wp-block-column:first-child p,
  .page-id-39 .site-main .entry-content .metodo-process-table .wp-block-column:first-child strong {
    font-size: 22px !important;
    line-height: 1.25 !important;
  }

  .page-id-39 .site-main .entry-content .metodo-process-table .wp-block-column:nth-child(2) p {
    font-size: 16px !important;
    line-height: 1.55 !important;
  }

  .page-id-39 .site-main .entry-content .metodo-process-table .wp-block-column:last-child {
    grid-column: 1;
    grid-row: 1;
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    padding: 0.9rem 0 0.4rem 1rem !important;
  }

  .page-id-39 .site-main .entry-content .metodo-process-table .wp-block-column:last-child p {
    text-align: left !important;
  }

  .page-id-39 .site-main .entry-content .metodo-process-table .wp-block-column:last-child .emoji {
    width: 56px !important;
    height: 56px !important;
  }

  /*
   * Metodo mobile: stesso problema delle altre pagine con blocchi alignfull — 100vw + scrollbar
   * può lasciare una fascia chiara a destra; usa bleed sul padding di .site-main (1rem a ≤960px).
   */
  .page-id-39 .site-main {
    overflow-x: hidden;
    overflow-x: clip;
  }

  .page-id-39 .site-main .entry-content > .alignfull {
    width: calc(100% + 2rem);
    max-width: none;
    margin-left: -1rem;
    margin-right: -1rem;
  }

  /*
   * Metodo: il gruppo alignfull .metodo-hero-wrapper può duplicare/spostare il breakout (-50vw / left:50%
   * da Customizer o plugin): su mobile fascia bianca a sinistra. Solo questo blocco: neutralizza e allinea al bleed del main.
   */
  .page-id-39 .site-main .entry-content > .wp-block-group.alignfull.metodo-hero-wrapper,
  .page-id-39 .site-main .entry-content > .alignfull.metodo-hero-wrapper {
    position: relative !important;
    inset: auto !important;
    left: auto !important;
    right: auto !important;
    width: calc(100% + 2rem) !important;
    max-width: none !important;
    margin-left: -1rem !important;
    margin-right: -1rem !important;
    transform: none !important;
  }
}

@media (max-width: 600px) {
  .page-id-39 .site-main .entry-content > .alignfull {
    width: calc(100% + 1.7rem);
    margin-left: -0.85rem;
    margin-right: -0.85rem;
  }

  .page-id-39 .site-main .entry-content > .wp-block-group.alignfull.metodo-hero-wrapper,
  .page-id-39 .site-main .entry-content > .alignfull.metodo-hero-wrapper {
    width: calc(100% + 1.7rem) !important;
    margin-left: -0.85rem !important;
    margin-right: -0.85rem !important;
  }
}

button,
input,
select,
textarea {
  font-family: var(--evotheme-font-family);
}

.site-main {
  width: min(100%, var(--evotheme-content-max-width));
  margin: 0 auto;
  padding: 0 var(--evotheme-content-padding-x);
}

/*
 * Blocchi "Schermo intero" / "Ampio" (Gutenberg): escono dal max-width di .site-main.
 * Desktop: larghezza = area contenuto a destra della sidebar (260px).
 */
@media (min-width: 961px) {
  /*
   * Breakout simmetrico sul contenuto utile (viewport − sidebar). Non mischiare qui --evotheme-content-padding-x:
   * la vecchia formula (+P sulla width e −P solo su margin-left) spostava il riquadro di ~un padding e lasciava la fascia bianca a destra (simula ciò che succede portando la variabile a 0).
   */
  .site-main .entry-content > .alignfull {
    width: calc(100vw - 260px);
    max-width: calc(100vw - 260px);
    margin-left: calc((100vw - 260px - 100%) / -2);
    margin-right: calc((100vw - 260px - 100%) / -2);
  }

  @supports (width: 1dvw) {
    .site-main .entry-content > .alignfull {
      --evotheme-vw-scrollbar-fudge: max(0px, 100vw - 100dvw);
      width: calc(100vw - 260px + var(--evotheme-vw-scrollbar-fudge));
      max-width: calc(100vw - 260px + var(--evotheme-vw-scrollbar-fudge));
    }
  }

  .site-main .entry-content > .alignwide {
    max-width: min(100%, 1400px);
    width: min(100%, 1400px);
    margin-left: auto;
    margin-right: auto;
  }
}

@media (max-width: 960px) {
  .site-main .entry-content > .alignfull {
    width: 100vw;
    max-width: 100vw;
    margin-left: calc((100vw - 100%) / -2);
    margin-right: calc((100vw - 100%) / -2);
  }

  .site-main .entry-content > .alignwide {
    max-width: 100%;
    width: 100%;
    margin-left: 0;
    margin-right: 0;
  }
}

/*
 * Pagina Chi siamo — mobile: evita scrollbar orizzontale.
 * - alignfull generico usa 100vw + margini negativi ( scrollbar / subpixel ).
 * - colonne animate usano translateX(±4rem) fuori dal box finché l’animazione non termina.
 */
@media (max-width: 960px) {
  .evotheme-page-chi-siamo .site-main {
    overflow-x: hidden;
    overflow-x: clip;
  }

  .evotheme-page-chi-siamo .site-main .entry-content > .alignfull {
    width: calc(100% + 2rem);
    max-width: none;
    margin-left: -1rem;
    margin-right: -1rem;
  }

  .evotheme-page-chi-siamo .site-main .entry-content .wp-block-columns {
    overflow-x: hidden;
    overflow-x: clip;
  }
}

@media (max-width: 600px) {
  .evotheme-page-chi-siamo .site-main .entry-content > .alignfull {
    width: calc(100% + 1.7rem);
    margin-left: -0.85rem;
    margin-right: -0.85rem;
  }
}

/*
 * Pagina Contatti (post 11 / slug contatti, body .evotheme-page-contatti-mappa) — mobile:
 * alignfull con 100vw + scrollbar e colonne animate translateX(±4rem): stesso schema Chi siamo.
 */
@media (max-width: 960px) {
  .evotheme-page-contatti-mappa .page-contatti-main {
    overflow-x: hidden;
    overflow-x: clip;
  }

  .evotheme-page-contatti-mappa .page-contatti-main .entry-content > .alignfull {
    width: calc(100% + 2rem);
    max-width: none;
    margin-left: -1rem;
    margin-right: -1rem;
  }

  .evotheme-page-contatti-mappa .page-contatti-main .entry-content .wp-block-columns {
    overflow-x: hidden;
    overflow-x: clip;
  }
}

@media (max-width: 600px) {
  .evotheme-page-contatti-mappa .page-contatti-main .entry-content > .alignfull {
    width: calc(100% + 1.7rem);
    margin-left: -0.85rem;
    margin-right: -0.85rem;
  }
}

/*
 * Archivio progetti (/progetti/) — mobile: le card usano translateX(±4rem) all’ingresso
 * (chi-siamo-columns-animate.js): senza clip compare scrollbar orizzontale.
 */
@media (max-width: 960px) {
  .post-type-archive-portfolio main.site-main {
    overflow-x: hidden;
    overflow-x: clip;
  }

  .post-type-archive-portfolio .portfolio-grid {
    overflow-x: hidden;
    overflow-x: clip;
  }
}

/*
 * Copertina alignfull: immagine/sfondo a tutta larghezza colonna contenuto,
 * testo e colonne interne allineati al contenitore .site-main (come le sezioni sopra).
 */
.site-main .entry-content > .wp-block-cover.alignfull .wp-block-cover__inner-container {
  max-width: min(100%, var(--evotheme-content-max-width)) !important;
  width: 100%;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: var(--evotheme-content-padding-x) !important;
  padding-right: var(--evotheme-content-padding-x) !important;
  box-sizing: border-box !important;
}

/*
 * Pagina Chi siamo: copertina con colonne — padding verticale.
 * Usa .evotheme-page-chi-siamo (body): WordPress non aggiunge sempre page-{slug}.
 */
.evotheme-page-chi-siamo .site-main .entry-content .wp-block-cover:has(.wp-block-columns) {
  padding-top: 3.5rem !important;
  padding-bottom: 5.5rem !important;
}

.evotheme-page-chi-siamo .site-main .entry-content .wp-block-cover:has(.wp-block-columns) .wp-block-cover__inner-container {
  padding-top: 2.5rem !important;
  padding-bottom: 2.5rem !important;
}

/* Pagina Chi siamo: zoom immagini */
.evotheme-page-chi-siamo .site-main .entry-content .wp-block-image {
  overflow: hidden;
}

.evotheme-page-chi-siamo .site-main .entry-content .wp-block-image img,
.evotheme-page-chi-siamo .site-main .entry-content .wp-block-cover__image-background {
  display: block;
  transform: scale(1.08);
  transform-origin: center center;
  animation: evotheme-chi-siamo-image-zoom-out 6s ease-out both;
}

.evotheme-page-chi-siamo .site-main .entry-content .wp-block-image:hover img,
.evotheme-page-chi-siamo .site-main .entry-content .wp-block-image:focus-within img,
.evotheme-page-chi-siamo .site-main .entry-content .wp-block-cover:hover .wp-block-cover__image-background,
.evotheme-page-chi-siamo .site-main .entry-content .wp-block-cover:focus-within .wp-block-cover__image-background {
  transform: scale(1.08);
  animation-play-state: paused;
}

@keyframes evotheme-chi-siamo-image-zoom-out {
  from {
    transform: scale(1.08);
  }

  to {
    transform: scale(1);
  }
}

@media (prefers-reduced-motion: reduce) {
  .evotheme-page-chi-siamo .site-main .entry-content .wp-block-image img,
  .evotheme-page-chi-siamo .site-main .entry-content .wp-block-cover__image-background {
    animation: none;
    transform: none;
  }
}

/* Ingresso animato: colonne Gutenberg, hero e filtri archivio portfolio, card griglia */
@keyframes evotheme-chi-siamo-column-from-left {
  from {
    opacity: 0;
    transform: translateX(-4rem);
  }

  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes evotheme-chi-siamo-column-from-right {
  from {
    opacity: 0;
    transform: translateX(4rem);
  }

  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes evotheme-portfolio-hero-from-top {
  from {
    opacity: 0;
    transform: translateY(-2.75rem);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: no-preference) {
  .evotheme-page-chi-siamo .site-main .entry-content .wp-block-column.evotheme-column-enter-anim.evotheme-column-enter-from-left,
  .evotheme-page-contatti-mappa .page-contatti-main .entry-content .wp-block-column.evotheme-column-enter-anim.evotheme-column-enter-from-left,
  .home .site-main .front-page-content .wp-block-column.evotheme-column-enter-anim.evotheme-column-enter-from-left {
    animation: evotheme-chi-siamo-column-from-left 3.4s cubic-bezier(0.16, 1, 0.28, 1) both;
    animation-delay: calc(var(--evotheme-column-stagger, 0) * 420ms);
  }

  .evotheme-page-chi-siamo .site-main .entry-content .wp-block-column.evotheme-column-enter-anim.evotheme-column-enter-from-right,
  .evotheme-page-contatti-mappa .page-contatti-main .entry-content .wp-block-column.evotheme-column-enter-anim.evotheme-column-enter-from-right,
  .home .site-main .front-page-content .wp-block-column.evotheme-column-enter-anim.evotheme-column-enter-from-right {
    animation: evotheme-chi-siamo-column-from-right 3.4s cubic-bezier(0.16, 1, 0.28, 1) both;
    animation-delay: calc(var(--evotheme-column-stagger, 0) * 420ms);
  }

  .post-type-archive-portfolio .portfolio-archive-intro.evotheme-portfolio-hero-enter,
  .post-type-archive-portfolio #portfolio-filters.portfolio-filters.evotheme-portfolio-hero-enter {
    animation: evotheme-portfolio-hero-from-top 1.65s cubic-bezier(0.16, 1, 0.28, 1) both;
    animation-delay: calc(var(--evotheme-portfolio-hero-order, 0) * 160ms);
  }

  .post-type-archive-portfolio .portfolio-grid .portfolio-card.evotheme-portfolio-card-enter.evotheme-column-enter-anim.evotheme-column-enter-from-left {
    animation: evotheme-chi-siamo-column-from-left 2.75s cubic-bezier(0.16, 1, 0.28, 1) both;
    animation-delay: calc(var(--evotheme-portfolio-cards-base-delay, 0ms) + var(--evotheme-column-stagger, 0) * 88ms);
  }

  .post-type-archive-portfolio .portfolio-grid .portfolio-card.evotheme-portfolio-card-enter.evotheme-column-enter-anim.evotheme-column-enter-from-right {
    animation: evotheme-chi-siamo-column-from-right 2.75s cubic-bezier(0.16, 1, 0.28, 1) both;
    animation-delay: calc(var(--evotheme-portfolio-cards-base-delay, 0ms) + var(--evotheme-column-stagger, 0) * 88ms);
  }
}

@media (prefers-reduced-motion: reduce) {
  .evotheme-page-chi-siamo .site-main .entry-content .wp-block-column.evotheme-column-enter-anim,
  .evotheme-page-contatti-mappa .page-contatti-main .entry-content .wp-block-column.evotheme-column-enter-anim,
  .home .site-main .front-page-content .wp-block-column.evotheme-column-enter-anim {
    animation: none;
    opacity: 1;
    transform: none;
  }

  .post-type-archive-portfolio .evotheme-portfolio-hero-enter {
    animation: none;
    opacity: 1;
    transform: none;
  }

  .post-type-archive-portfolio .portfolio-grid .portfolio-card.evotheme-portfolio-card-enter {
    animation: none;
    opacity: 1;
    transform: none;
  }
}

/* Gutenberg is-layout-constrained imposta spesso max-width stretto sui figli */
.site-main .entry-content > .wp-block-cover.alignfull .wp-block-cover__inner-container > * {
  max-width: 100% !important;
}

@media (max-width: 960px) {
  .site-main .entry-content > .wp-block-cover.alignfull .wp-block-cover__inner-container {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
}

@media (max-width: 600px) {
  .site-main .entry-content > .wp-block-cover.alignfull .wp-block-cover__inner-container {
    padding-left: 0.85rem !important;
    padding-right: 0.85rem !important;
  }

  .evotheme-page-chi-siamo .site-main .entry-content .wp-block-cover:has(.wp-block-columns) {
    padding-top: 3.5rem !important;
    padding-bottom: 3.5rem !important;
  }

  .evotheme-page-chi-siamo .site-main .entry-content .wp-block-cover:has(.wp-block-columns) .wp-block-cover__inner-container {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
  }
}

/* Fascia bianca sotto ultima Copertina alignfull: compensa padding-bottom di .site-main */
.site-main .entry-content > .alignfull:last-child,
.site-main .entry-content > .alignfull:has(+ p:empty:last-child) {
  margin-bottom: -2.25rem;
}

/* Mobile: il margine negativo tira il footer sotto la Cover (sfondo/z-index) → footer “coperto” */
@media (max-width: 960px) {
  .site-main .entry-content > .alignfull:last-child,
  .site-main .entry-content > .alignfull:has(+ p:empty:last-child) {
    margin-bottom: 0;
  }
}

/* Paragrafi vuoti in coda (spesso lasciati da Gutenberg dopo la Copertina) */
.entry-content > p:empty {
  display: none;
  margin: 0 !important;
  padding: 0 !important;
  min-height: 0 !important;
}

/* Titoli lunghi (es. Chi siamo) + letter-spacing globale: evita overflow orizzontale */
.entry-content :where(h1, h2, h3, h4) {
  max-width: 100%;
  overflow-wrap: break-word;
  word-wrap: break-word;
}

/* Paragrafi: pagine (es. Chi siamo) e intro archivio portfolio */
.page .site-main .entry-content p,
.portfolio-archive-intro p {
  font-size: 20px;
  line-height: 1.7;
  letter-spacing: 1px;
}

.home .site-main {
  margin: 0;
  padding: 0;
}

/* Homepage desktop: larghezza colonna contenuto = alignfull (vw − sidebar) + bleed 2px; dopo la regola base .home .site-main per il cascade. */
@media (min-width: 961px) {
  .home .site-main {
    width: calc(100vw - 260px + 2px);
    max-width: none;
    box-sizing: border-box;
  }
}

@supports (width: 1dvw) {
  @media (min-width: 961px) {
    .home .site-main {
      --evotheme-vw-scrollbar-fudge: max(0px, 100vw - 100dvw);
      width: calc(100vw - 260px + var(--evotheme-vw-scrollbar-fudge) + 2px);
    }
  }
}

.home-slider {
  position: relative;
  width: 100%;
  height: 100vh;
  min-height: 100vh;
  overflow: hidden;
  background: #111;
}

/*
 * Canvas dietro l’hero: backup se qualcosa sfora sotto l’html overflow-x; la larghezza utile è su .home .site-main.
 */
html:has(.home-slider),
body:has(.home-slider) {
  background-color: #111;
}

.admin-bar .home-slider {
  height: calc(100vh - 32px);
  min-height: calc(100vh - 32px);
}

@media (max-width: 782px) {
  .admin-bar .home-slider {
    height: calc(100vh - 46px);
    min-height: calc(100vh - 46px);
  }
}

.home-slider-track {
  position: relative;
  width: 100%;
  height: 100%;
}

.home-slide {
  position: absolute;
  inset: 0;
  min-height: 100%;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding: 2rem 6rem;
  background-color: #101010;
  background-position: center center;
  background-size: cover;
  opacity: 0;
  pointer-events: none;
  transform: translateX(0);
  z-index: 1;
  overflow: hidden;
  transition: opacity 0.65s ease-in-out;
  will-change: opacity;
}

.home-slide.is-active {
  opacity: 1;
  pointer-events: auto;
  z-index: 2;
}

.home-slide::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: inherit;
  background-position: inherit;
  background-size: cover;
  background-repeat: no-repeat;
  transform: scale(1);
  transition: none;
  z-index: 0;
}

.home-slider.is-zoom-ready .home-slide::before {
  transition: transform 12s ease-out;
}

.home-slide.is-active::before {
  transform: scale(1.12);
}

/* Primo caricamento: stesso zoom 12s delle slide dopo cambio — finché manca .is-zoom-ready la slide attiva resta a scale(1). */
.home-slider:not(.is-zoom-ready) .home-slide.is-active::before {
  transform: scale(1);
}

.home-slide-overlay {
  position: absolute;
  inset: 0;
  background: none;
  z-index: 1;
}

.home-slide-content {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 1rem;
  color: #fff;
}

.home-slide-title {
  margin: 0;
  margin-top: 65px;
  color: #fff;
  font-size: clamp(2rem, 4vw, 3.25rem);
  letter-spacing: 0.08em;
  text-transform: capitalize;
  text-align: right;
}

/*
 * Slider home: link CTA sulle slide (testo/URL da ACF sul CPT home_slide).
 */
.home-slide-link {
  align-content: center;
  box-sizing: border-box;
  cursor: pointer;
  display: inline-block;
  height: auto;
  max-height: none;
  text-align: center;
  word-break: break-word;
  color: #fff;
  background: rgba(0, 0, 0, 0.15);
  border: 1px solid rgba(255, 255, 255, 0.45);
  border-radius: 9999px;
  box-shadow: none;
  text-decoration: none;
  padding: calc(0.667em + 2px) calc(1.333em + 2px);
  font-size: 1.125em;
  font-weight: inherit;
  line-height: inherit;
  letter-spacing: normal;
  text-transform: none;
}

.home-slide-link:hover,
.home-slide-link:focus {
  color: #fff;
  background: rgba(0, 0, 0, 0.15);
  border-color: rgba(255, 255, 255, 0.45);
  filter: brightness(1.08);
  text-decoration: none;
}

.home-slide-link:focus-visible {
  outline: 2px solid #fff;
  outline-offset: 3px;
}

/*
 * Pagina Chi siamo: blocco Pulsante in copertina — come Contatti (solo bordo + pillola),
 * colore #FFFFFF; URL/testo dall’editor Gutenberg.
 */
.evotheme-page-chi-siamo .site-main .entry-content .wp-block-cover:has(.wp-block-columns) .wp-block-button:not(.is-style-outline) .wp-block-button__link.wp-element-button {
  align-content: center;
  box-sizing: border-box;
  cursor: pointer;
  display: inline-block;
  height: auto;
  max-height: none;
  text-align: center;
  word-break: break-word;
  background: transparent;
  border: 1px solid #ffffff;
  border-radius: 9999px;
  color: #ffffff;
  box-shadow: none;
  text-decoration: none;
  padding: calc(0.667em + 2px) calc(1.333em + 2px);
  font-size: 1.125em;
  font-weight: inherit;
  line-height: inherit;
  letter-spacing: normal;
  text-transform: none;
}

.evotheme-page-chi-siamo .site-main .entry-content .wp-block-cover:has(.wp-block-columns) .wp-block-button:not(.is-style-outline) .wp-block-button__link.wp-element-button:hover,
.evotheme-page-chi-siamo .site-main .entry-content .wp-block-cover:has(.wp-block-columns) .wp-block-button:not(.is-style-outline) .wp-block-button__link.wp-element-button:focus {
  background: transparent;
  border-color: #ffffff;
  color: #ffffff;
  filter: brightness(1.08);
  text-decoration: none;
}

.evotheme-page-chi-siamo .site-main .entry-content .wp-block-cover:has(.wp-block-columns) .wp-block-button:not(.is-style-outline) .wp-block-button__link.wp-element-button:focus-visible {
  outline: 2px solid #ffffff;
  outline-offset: 3px;
}

/* Pagina Contatti: submit CF7 — bordo senza riempimento; padding e pillola come hero home / Chi siamo. */
.evotheme-page-contatti-mappa .page-contatti-entry .wpcf7 input.wpcf7-form-control.wpcf7-submit,
.evotheme-page-contatti-mappa .page-contatti-entry .wpcf7 button.wpcf7-form-control.wpcf7-submit {
  align-content: center;
  box-sizing: border-box;
  display: inline-block;
  height: auto;
  max-height: none;
  text-align: center;
  word-break: break-word;
  background: transparent;
  border: 1px solid #6e6e6e;
  border-radius: 9999px;
  color: #6e6e6e;
  box-shadow: none;
  padding: calc(0.667em + 2px) calc(1.333em + 2px);
  font-size: 1.125em;
  font-weight: inherit;
  line-height: inherit;
  letter-spacing: normal;
  text-transform: none;
}

.evotheme-page-contatti-mappa .page-contatti-entry .wpcf7 input.wpcf7-form-control.wpcf7-submit:hover,
.evotheme-page-contatti-mappa .page-contatti-entry .wpcf7 input.wpcf7-form-control.wpcf7-submit:focus,
.evotheme-page-contatti-mappa .page-contatti-entry .wpcf7 button.wpcf7-form-control.wpcf7-submit:hover,
.evotheme-page-contatti-mappa .page-contatti-entry .wpcf7 button.wpcf7-form-control.wpcf7-submit:focus {
  background: transparent;
  border-color: #252525;
  color: #252525;
}

.evotheme-page-contatti-mappa .page-contatti-entry .wpcf7 input.wpcf7-form-control.wpcf7-submit:focus-visible,
.evotheme-page-contatti-mappa .page-contatti-entry .wpcf7 button.wpcf7-form-control.wpcf7-submit:focus-visible {
  outline: 2px solid #252525;
  outline-offset: 3px;
}

.home-slider-arrow {
  position: absolute;
  top: 50%;
  bottom: auto;
  transform: translateY(-50%);
  width: 44px;
  height: 64px;
  border: 1px solid rgba(255, 255, 255, 0.45);
  background: rgba(0, 0, 0, 0.15);
  color: #fff;
  font-size: 1.9rem;
  line-height: 1;
  cursor: pointer;
  z-index: 3;
}

.home-slider-prev {
  left: 1rem;
}

.home-slider-next {
  right: 1rem;
}

@media (min-width: 961px) {
  .home-slide-content {
    position: absolute;
    top: 50%;
    right: 6rem;
    transform: translateY(-50%);
    margin: 0;
  }
}

.home-slider-dots {
  position: absolute;
  bottom: 1.1rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 0.5rem;
  z-index: 3;
}

.home-slider-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: 0;
  background: rgba(255, 255, 255, 0.55);
  cursor: pointer;
  padding: 0;
}

.home-slider-dot.is-active {
  background: #fff;
}

.site-branding {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  width: 100%;
  padding: 0;
}

.site-title {
  color: #fff;
  font-weight: 700;
  text-decoration: none;
}

.custom-logo-link img {
  height: 70px;
  width: auto;
  display: block;
}

.site-aside {
  position: fixed !important;
  top: 0 !important;
  bottom: 0 !important;
  left: 0 !important;
  z-index: 1000;
  width: 260px !important;
  height: auto !important;
  min-height: 100vh;
  min-height: 100dvh;
  background: var(--evotheme-sidebar-bg) !important;
  color: #fff;
  border-right: 1px solid rgba(255, 255, 255, 0.15);
}

/* Admin bar: sidebar sotto wpadminbar (32px desktop, 46px viewport stretti) */
.admin-bar .site-aside {
  top: 32px !important;
}

@media (max-width: 782px) {
  .admin-bar .site-aside {
    top: 46px !important;
  }
}

.site-aside-inner {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  width: 100%;
  height: 100%;
  padding: 1.4rem 1rem;
}

.site-aside-nav {
  width: 100%;
  margin-top: auto;
  margin-bottom: auto;
}

.site-aside-social {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.85rem;
  padding: 0.4rem 0 0.2rem;
}

.site-aside-social-link {
  display: inline-flex;
  width: 16px;
  height: 16px;
  align-items: center;
  justify-content: center;
  color: rgba(255, 255, 255, 0.62);
  text-decoration: none;
  text-transform: lowercase;
  font-size: 0.76rem;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.04em;
  transition: color 0.2s ease, opacity 0.2s ease;
}

.site-aside-social-link:hover,
.site-aside-social-link:focus-visible {
  color: #fff;
}

.site-aside-legal {
  width: 100%;
  text-align: center;
  color: rgba(255, 255, 255, 0.55);
  font-size: 11px;
  line-height: 1.45;
  letter-spacing: 0.04em;
  padding: 0.25rem 0 0;
}

.site-aside-nav > .menu {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 0.2rem;
}

.site-aside-nav ul.menu {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
}

.site-aside-nav > .menu > .menu-item {
  position: relative;
}

.site-aside-nav > .menu > .menu-item > a {
  width: auto;
  min-height: 0;
  padding: 0.6rem 0.4rem;
  display: flex !important;
  align-items: center;
  justify-content: center;
  line-height: 1.2;
  color: #a5a5a5;
  text-decoration: none;
  font-size: 13px;
  font-weight: 400;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  border-left: 0;
  transition: opacity 0.2s ease;
}

.site-aside-nav > .menu > .menu-item > a:hover,
.site-aside-nav > .menu > .menu-item > a:focus {
  color: #ffffff;
  opacity: 1;
}

.site-aside-nav > .menu > .current-menu-item > a,
.site-aside-nav > .menu > .current_page_item > a,
.site-aside-nav > .menu > .current-menu-ancestor > a {
  color: #ffffff;
}

.site-aside-nav .menu-item-has-children > a {
  position: relative;
  padding-right: 1.8rem;
}

.site-aside-nav .menu-item-has-children > a::after {
  content: "";
  position: absolute;
  right: 0.7rem;
  top: 50%;
  width: 0;
  height: 0;
  margin-top: -2px;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 5px solid rgba(255, 255, 255, 0.82);
}

.site-aside-nav .sub-menu {
  margin: 0.25rem 0 0.35rem;
  padding: 0 0 0 0.9rem;
  list-style: none;
  border-left: 1px solid rgba(255, 255, 255, 0.2);
}

.site-aside-nav .sub-menu .menu-item > a {
  display: block;
  padding: 0.45rem 0.75rem;
  color: rgba(255, 255, 255, 0.85);
  text-decoration: none;
  font-size: 0.85rem;
  font-weight: 400;
  white-space: nowrap;
  line-height: 1.5;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.site-aside-nav .sub-menu .menu-item > a:hover,
.site-aside-nav .sub-menu .menu-item > a:focus {
  color: #fff;
}

.site-aside-nav .sub-menu .menu-item-has-children > .sub-menu {
  left: 0;
  top: auto;
}

body {
  padding-left: 260px !important;
}

.site-footer {
  margin-left: 260px;
  text-align: center;
  padding: 16px;
}

.mobile-aside-toggle,
.mobile-aside-overlay {
  display: none;
}

/* Barra superiore logo + menu: solo mobile (vedi @media sotto) */
.site-mobile-header {
  display: none;
}

/* Fascia inferiore (solo mobile): stesso colore sidebar desktop */
.site-mobile-footer {
  display: none;
}

@media (max-width: 960px) {
  body {
    padding-left: 0 !important;
  }

  body.mobile-aside-open {
    overflow: hidden;
  }

  .site-mobile-header {
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1180;
    height: var(--site-mobile-header-height, 56px);
    background: #252525 !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
    box-sizing: border-box;
  }

  .admin-bar .site-mobile-header {
    top: 32px;
  }

  .site-mobile-header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    height: 100%;
    max-width: 100%;
    padding: 0 0.65rem 0 0.85rem;
    box-sizing: border-box;
  }

  .site-mobile-header-branding {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    flex: 1 1 auto;
    max-width: calc(100% - 52px);
    overflow: visible;
  }

  .site-mobile-header-branding .custom-logo-link {
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    flex-shrink: 0;
    max-height: calc(var(--site-mobile-header-height, 56px) - 10px);
    line-height: 0;
  }

  /* Logo raster / SVG: altezza esplicita (SVG senza dimensioni intrinseche collassano con height:auto) */
  .site-mobile-header-branding .custom-logo-link img,
  .site-mobile-header-branding img.custom-logo {
    display: block;
    width: auto;
    height: 38px;
    max-height: 38px;
    max-width: min(220px, 52vw);
    object-fit: contain;
    object-position: left center;
  }

  .site-mobile-header-title {
    display: block;
    font-size: 0.95rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    color: #fff;
    text-decoration: none;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .site-mobile-header-title:hover,
  .site-mobile-header-title:focus {
    color: #fff;
    text-decoration: underline;
  }

  .mobile-aside-toggle {
    display: inline-flex;
    position: relative;
    top: auto;
    left: auto;
    flex-shrink: 0;
    z-index: 1;
    width: 44px;
    height: 44px;
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: 4px;
    background: rgba(255, 255, 255, 0.06);
    color: #fff;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
    padding: 0;
  }

  .mobile-aside-toggle:hover,
  .mobile-aside-toggle:focus-visible {
    background: rgba(255, 255, 255, 0.12);
    border-color: rgba(255, 255, 255, 0.35);
    outline: none;
  }

  .mobile-aside-toggle-line {
    display: block;
    width: 20px;
    height: 2px;
    background: #fff;
  }

  .site-aside {
    position: fixed !important;
    top: 0 !important;
    bottom: 0 !important;
    left: 0 !important;
    width: min(84vw, 320px) !important;
    height: auto !important;
    min-height: 100vh;
    min-height: 100dvh;
    border-right: 0;
    border-bottom: 0;
    transform: translateX(-100%);
    transition: transform 0.25s ease;
    z-index: 1250;
    overflow-y: auto;
  }

  body.mobile-aside-open .site-aside {
    transform: translateX(0);
  }

  .mobile-aside-overlay {
    display: block;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.45);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.25s ease;
    z-index: 1100;
  }

  body.mobile-aside-open .mobile-aside-overlay {
    opacity: 1;
    pointer-events: auto;
  }

  .site-aside-inner {
    min-height: 100%;
    padding: 1.25rem 1rem;
    gap: 1rem;
    align-items: stretch;
  }

  .site-aside-inner .site-branding {
    justify-content: center;
  }

  .site-aside .custom-logo-link img,
  .site-aside img.custom-logo {
    display: block;
    width: auto;
    height: 56px;
    max-width: 100%;
    object-fit: contain;
  }

  .site-aside-nav > .menu {
    width: 100%;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 0.35rem;
  }

  .site-aside-nav {
    margin-top: auto;
    margin-bottom: auto;
  }

  .site-aside-social {
    margin-top: 0;
    margin-bottom: 0.35rem;
    justify-content: center;
    gap: 0.9rem;
  }

  .site-aside-legal {
    margin-top: 0;
    text-align: center;
    font-size: 10px;
    line-height: 1.45;
    letter-spacing: 0.03em;
    color: rgba(255, 255, 255, 0.55);
    padding-bottom: 0.2rem;
  }

  .site-aside-nav > .menu > .menu-item > a {
    width: 100%;
    padding: 0.7rem 0.2rem;
    font-size: 13px;
    border-left: 0;
    border-bottom: 0;
  }

  .site-aside-nav .sub-menu {
    padding: 0 0 0 0.65rem;
    margin: 0.1rem 0 0.35rem;
    border-left: 1px solid rgba(255, 255, 255, 0.2);
  }

  .site-aside-nav .sub-menu .menu-item > a {
    white-space: normal;
  }

  .site-main {
    width: 100%;
    padding-left: 1rem;
    padding-right: 1rem;
    padding-top: calc(var(--site-mobile-header-height, 56px) + 1rem);
  }

  .admin-bar .site-main,
  .admin-bar .portfolio-archive-page,
  .admin-bar .portfolio-single-page {
    padding-top: calc(32px + var(--site-mobile-header-height, 56px) + 0.85rem);
  }

  .home .site-main {
    padding: 0;
    width: calc(100vw + 2px);
    max-width: none;
    margin-left: calc((100vw + 2px - 100%) / -2);
    margin-right: calc((100vw + 2px - 100%) / -2);
    box-sizing: border-box;
  }

  @supports (width: 1dvw) {
    .home .site-main {
      width: calc(100dvw + 2px);
      margin-left: calc((100dvw + 2px - 100%) / -2);
      margin-right: calc((100dvw + 2px - 100%) / -2);
    }
  }

  .evotheme-page-venezia .site-main,
  .page-template-page-venezia-php .site-main,
  .page-venezia .site-main {
    padding: 0;
  }

  .home-slider {
    height: 100dvh;
    min-height: 100dvh;
    height: 100svh;
    min-height: 100svh;
    width: 100%;
    max-width: none;
    margin-left: 0;
    margin-right: 0;
  }

  .home-slide {
    justify-content: center;
    align-items: flex-end;
    padding: 1rem 1rem 4.2rem;
  }

  .home-slide-content {
    width: 100%;
    align-items: flex-start;
    gap: 0.75rem;
    margin-bottom: 8rem;
  }

  .home-slide-title {
    font-size: clamp(1.4rem, 8vw, 2rem);
    text-align: left;
  }

  .home-slider-arrow {
    width: 40px;
    height: 56px;
    top: 50%;
    bottom: auto;
    transform: translateY(-50%);
  }

  .page-id-11 iframe[src*="google.com/maps"],
  .page-id-11 iframe[src*="google.it/maps"] {
    height: 340px;
  }

  .page-id-11 .wp-block-columns {
    gap: 1.35rem;
  }

  .page-id-11 .wpcf7 input[type="submit"],
  .page-id-11 .wpcf7 button[type="submit"] {
    min-height: 40px;
    padding: 0.6rem 0.95rem;
  }

  .home-slider-prev {
    left: 0.5rem;
  }

  .home-slider-next {
    right: 0.5rem;
  }

  .site-footer {
    margin-left: 0;
  }

  .site-mobile-footer {
    display: block;
    width: 100%;
    min-height: 48px;
    margin: 0;
    padding: 0;
    padding-bottom: max(0.5rem, env(safe-area-inset-bottom, 0px));
    box-sizing: border-box;
    background: #252525;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    flex-shrink: 0;
  }

  .site-mobile-footer-legal {
    max-width: 100%;
    margin: 0;
    padding: 0.85rem 1rem 0.65rem;
    text-align: center;
    font-size: 10px;
    line-height: 1.5;
    letter-spacing: 0.03em;
    color: rgba(255, 255, 255, 0.55);
  }

  /* Legali solo nel footer mobile, non nel drawer */
  .site-aside-legal {
    display: none !important;
  }
}

@media (max-width: 782px) {
  .admin-bar .site-mobile-header {
    top: 46px;
  }

  .admin-bar .site-main,
  .admin-bar .portfolio-archive-page,
  .admin-bar .portfolio-single-page {
    padding-top: calc(46px + var(--site-mobile-header-height, 56px) + 0.85rem);
  }
}

@media (max-width: 600px) {
  :root {
    --site-mobile-header-height: 52px;
  }

  h1 {
    font-size: 2rem;
    font-weight: 500;
    letter-spacing: 4px;
    line-height: 1.2;
  }

  h2 {
    font-size: 2rem;
    font-weight: 500;
    line-height: 1.2;
  }

  .site-mobile-header-branding .custom-logo-link img,
  .site-mobile-header-branding img.custom-logo {
    height: 34px;
    max-height: 34px;
    max-width: min(180px, 52vw);
  }

  .mobile-aside-toggle {
    width: 40px;
    height: 40px;
  }

  .site-aside {
    width: 88vw !important;
  }

  .site-aside-nav > .menu > .menu-item > a {
    padding: 0.78rem 0.2rem;
  }

  .site-main {
    padding-left: 0.85rem;
    padding-right: 0.85rem;
    padding-top: calc(var(--site-mobile-header-height, 52px) + 0.9rem);
  }

  .admin-bar .site-main,
  .admin-bar .portfolio-archive-page,
  .admin-bar .portfolio-single-page {
    padding-top: calc(46px + var(--site-mobile-header-height, 52px) + 0.75rem);
  }

  .evotheme-page-venezia .site-main,
  .page-template-page-venezia-php .site-main,
  .page-venezia .site-main {
    padding: 0;
  }

  .page-id-11 iframe[src*="google.com/maps"],
  .page-id-11 iframe[src*="google.it/maps"] {
    height: 280px;
  }

  .page-id-11 .wpcf7 textarea {
    min-height: 128px;
  }

  .home-slide-content {
    margin-bottom: 8rem;
  }
}

/* Contact Form 7 - stile minimale pagina Contattaci */
.page-id-11 .wpcf7 form {
  color: #4a4a4a;
  font-size: 1rem;
}

.page-id-11 .wpcf7 form p {
  margin: 0 0 10px;
}

.page-id-11 .wpcf7 form label {
  display: block;
  margin: 0;
  font-size: inherit;
  line-height: inherit;
}

.page-id-11 .wpcf7 form label .wpcf7-form-control-wrap {
  display: block;
}

.page-id-11 .wpcf7 input[type="text"],
.page-id-11 .wpcf7 input[type="email"],
.page-id-11 .wpcf7 input[type="url"],
.page-id-11 .wpcf7 input[type="tel"],
.page-id-11 .wpcf7 input[type="number"],
.page-id-11 .wpcf7 input[type="date"],
.page-id-11 .wpcf7 select,
.page-id-11 .wpcf7 textarea {
  width: 100%;
  display: block;
  border: 1px solid #6e6e6e;
  border-radius: 0;
  background: #fff;
  color: #3d3d3d;
  box-shadow: none;
  padding: 10px 12px;
  font-size: 1rem;
  line-height: 1.35;
  transition: border-color 0.2s ease, background-color 0.2s ease;
}

.page-id-11 .wpcf7 textarea {
  min-height: 96px;
  resize: vertical;
}

.page-id-11 .wpcf7 input::placeholder,
.page-id-11 .wpcf7 textarea::placeholder {
  color: #767676;
  opacity: 1;
  font-size: 1rem;
}

.page-id-11 .wpcf7 input[type="text"]:focus,
.page-id-11 .wpcf7 input[type="email"]:focus,
.page-id-11 .wpcf7 input[type="url"]:focus,
.page-id-11 .wpcf7 input[type="tel"]:focus,
.page-id-11 .wpcf7 input[type="number"]:focus,
.page-id-11 .wpcf7 input[type="date"]:focus,
.page-id-11 .wpcf7 select:focus,
.page-id-11 .wpcf7 textarea:focus {
  outline: none;
  border-color: #252525;
}

.page-id-11 .wpcf7 input[type="submit"],
.page-id-11 .wpcf7 button[type="submit"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #6e6e6e;
  border-radius: 0;
  background: transparent;
  color: #4a4a4a;
  padding: 7px 12px;
  min-height: 34px;
  font-size: 1rem;
  line-height: 1;
  cursor: pointer;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.page-id-11 .wpcf7 input[type="submit"]:hover,
.page-id-11 .wpcf7 button[type="submit"]:hover {
  background: #252525;
  border-color: #252525;
  color: #fff;
}

.page-id-11 .wpcf7 .wpcf7-spinner {
  margin: 0.4rem 0 0;
}

/* Acceptance / checkbox: stessa scala tipografica di input e placeholder */
.page-id-11 .wpcf7 .wpcf7-acceptance,
.page-id-11 .wpcf7 .wpcf7-acceptance .wpcf7-list-item,
.page-id-11 .wpcf7 .wpcf7-acceptance label,
.page-id-11 .wpcf7 .wpcf7-list-item-label {
  font-size: 1rem;
  line-height: 1.35;
}

.evotheme-page-contatti-mappa .page-contatti-entry .wpcf7 .wpcf7-acceptance,
.evotheme-page-contatti-mappa .page-contatti-entry .wpcf7 .wpcf7-acceptance .wpcf7-list-item,
.evotheme-page-contatti-mappa .page-contatti-entry .wpcf7 .wpcf7-acceptance label,
.evotheme-page-contatti-mappa .page-contatti-entry .wpcf7 .wpcf7-list-item-label {
  font-size: 1rem;
  line-height: 1.35;
}

.wpcf7-list-item {
  margin-left: 0;
}

.spec-row {
  display: grid;
  grid-template-columns: 130px 1fr;
  gap: 0.75rem;
  padding: 0.65rem 0;
  border-bottom: 1px solid #f1f3f5;
}

.spec-row:last-child {
  border-bottom: 0;
}

.spec-row dt {
  margin: 0;
  font-weight: 700;
  color: #495057;
}

.spec-row dd {
  margin: 0;
  color: #212529;
}

@media (max-width: 900px) {
  .spec-row {
    grid-template-columns: 1fr;
    gap: 0.35rem;
  }
}

/* Pagina /venezia — mappa Leaflet (Leaflet aggiunge .leaflet-container con height: 180px di default) */
/* body.evotheme-page-venezia aggiunto da functions.php: il body WP non ha sempre page-{slug} */
/* Fascia bianca in basso: body era #fff; mappa usava calc(100vh - 24px) lasciando gap; su mobile 100vh ≠ altezza visibile. */
body.evotheme-page-venezia,
body.page-venezia {
  min-height: 100vh;
  min-height: 100dvh;
  background-color: #252525;
}

.evotheme-page-venezia .site-main,
.page-template-page-venezia-php .site-main,
.page-venezia .site-main {
  padding: 0;
}

.evotheme-page-venezia .page-venezia-main,
.page-template-page-venezia-php .page-venezia-main,
.page-venezia .page-venezia-main {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
  min-height: 100vh;
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
}

/* Stack mappa + overlay benvenuto: stesso riquadro di #venezia-map */
.evotheme-page-venezia .venezia-map-stack,
.page-template-page-venezia-php .venezia-map-stack,
.page-venezia .venezia-map-stack {
  position: relative;
  flex: 1 1 auto;
  min-height: 0;
  width: 100%;
  display: flex;
  flex-direction: column;
}

/* Overlay benvenuto: copre tutto il riquadro .venezia-map-stack (= area .venezia-map) */
.evotheme-page-venezia .evotheme-venezia-welcome-overlay,
.page-template-page-venezia-php .evotheme-venezia-welcome-overlay,
.page-venezia .evotheme-venezia-welcome-overlay {
  position: absolute;
  inset: 0;
  z-index: 400;
  display: flex;
  align-items: stretch;
  justify-content: stretch;
  padding: 0;
  box-sizing: border-box;
}

.evotheme-venezia-welcome-overlay[hidden] {
  display: none !important;
}

.evotheme-page-venezia .evotheme-venezia-welcome-backdrop,
.page-template-page-venezia-php .evotheme-venezia-welcome-backdrop,
.page-venezia .evotheme-venezia-welcome-backdrop {
  position: absolute;
  inset: 0;
  margin: 0;
  border: 0;
  padding: 0;
  background: rgba(37, 37, 37, 0.06);
  cursor: pointer;
}

.evotheme-page-venezia .evotheme-venezia-welcome-dialog,
.page-template-page-venezia-php .evotheme-venezia-welcome-dialog,
.page-venezia .evotheme-venezia-welcome-dialog {
  position: relative;
  z-index: 1;
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  justify-content: safe center;
  width: 100%;
  min-height: 0;
  max-width: none;
  height: 100%;
  max-height: none;
  overflow: auto;
  padding: 2.5rem 1.75rem;
  margin: 0;
  box-sizing: border-box;
  background: rgba(255, 255, 255, 0.12);
  backdrop-filter: blur(22px) saturate(1.3);
  -webkit-backdrop-filter: blur(22px) saturate(1.3);
  color: #111;
  border-radius: 0;
  box-shadow: none;
}

@media (prefers-reduced-motion: reduce) {
  .evotheme-page-venezia .evotheme-venezia-welcome-dialog,
  .page-template-page-venezia-php .evotheme-venezia-welcome-dialog,
  .page-venezia .evotheme-venezia-welcome-dialog {
    background: rgba(255, 255, 255, 0.82);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }
}

.evotheme-page-venezia .evotheme-venezia-welcome-close,
.page-template-page-venezia-php .evotheme-venezia-welcome-close,
.page-venezia .evotheme-venezia-welcome-close {
  position: absolute;
  top: 0.35rem;
  right: 0.35rem;
  width: 2.25rem;
  height: 2.25rem;
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 6px;
  font-size: 1.5rem;
  line-height: 1;
  color: #252525;
  background: transparent;
  cursor: pointer;
}

.evotheme-page-venezia .evotheme-venezia-welcome-close:hover,
.page-template-page-venezia-php .evotheme-venezia-welcome-close:hover,
.page-venezia .evotheme-venezia-welcome-close:hover,
.evotheme-page-venezia .evotheme-venezia-welcome-close:focus-visible,
.page-template-page-venezia-php .evotheme-venezia-welcome-close:focus-visible,
.page-venezia .evotheme-venezia-welcome-close:focus-visible {
  background: rgba(0, 0, 0, 0.06);
  outline: none;
}

.evotheme-page-venezia .evotheme-venezia-welcome-content.entry-content,
.page-template-page-venezia-php .evotheme-venezia-welcome-content.entry-content,
.page-venezia .evotheme-venezia-welcome-content.entry-content {
  flex: 0 1 auto;
  width: 100%;
  margin: 0;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
  box-sizing: border-box;
  text-align: center;
}

/* Titolo popup benvenuto Venezia (editor: heading H1/H2) */
.evotheme-page-venezia .evotheme-venezia-welcome-content.entry-content h1,
.page-template-page-venezia-php .evotheme-venezia-welcome-content.entry-content h1,
.page-venezia .evotheme-venezia-welcome-content.entry-content h1,
.evotheme-page-venezia .evotheme-venezia-welcome-content.entry-content h2,
.page-template-page-venezia-php .evotheme-venezia-welcome-content.entry-content h2,
.page-venezia .evotheme-venezia-welcome-content.entry-content h2,
.evotheme-page-venezia .evotheme-venezia-welcome-content.entry-content h3,
.page-template-page-venezia-php .evotheme-venezia-welcome-content.entry-content h3,
.page-venezia .evotheme-venezia-welcome-content.entry-content h3 {
  font-family: "Avenir Next LT Pro", "Avenir Next", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-style: normal;
  color: #252525;
  font-size: 3rem;
  font-weight: 500;
  letter-spacing: 10px;
  line-height: 65px;
  text-align: center;
}

/* Corpo testo popup benvenuto Venezia */
.evotheme-page-venezia .evotheme-venezia-welcome-content.entry-content p,
.page-template-page-venezia-php .evotheme-venezia-welcome-content.entry-content p,
.page-venezia .evotheme-venezia-welcome-content.entry-content p {
  font-family: "Avenir Next LT Pro", "Avenir Next", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-style: normal;
  color: #252525;
  font-size: 20px;
  line-height: 1.7;
  letter-spacing: 1px;
  text-align: center;
}

/* Link nel testo popup benvenuto Venezia */
.evotheme-page-venezia .evotheme-venezia-welcome-content.entry-content a,
.page-template-page-venezia-php .evotheme-venezia-welcome-content.entry-content a,
.page-venezia .evotheme-venezia-welcome-content.entry-content a {
  color: #111111;
}

.evotheme-page-venezia .evotheme-venezia-welcome-content.entry-content a:visited,
.page-template-page-venezia-php .evotheme-venezia-welcome-content.entry-content a:visited,
.page-venezia .evotheme-venezia-welcome-content.entry-content a:visited {
  color: #111111;
}

.evotheme-page-venezia .evotheme-venezia-welcome-content.entry-content a:hover,
.page-template-page-venezia-php .evotheme-venezia-welcome-content.entry-content a:hover,
.page-venezia .evotheme-venezia-welcome-content.entry-content a:hover,
.evotheme-page-venezia .evotheme-venezia-welcome-content.entry-content a:focus-visible,
.page-template-page-venezia-php .evotheme-venezia-welcome-content.entry-content a:focus-visible,
.page-venezia .evotheme-venezia-welcome-content.entry-content a:focus-visible {
  color: #111111;
}

/* Overlay Venezia: CTA con classi pulsante Gutenberg (filtro tema su pagina contenuto); pillola come Contatti su fondo chiaro. */
.evotheme-page-venezia .evotheme-venezia-welcome-content.entry-content a.wp-block-button__link.wp-element-button,
.page-template-page-venezia-php .evotheme-venezia-welcome-content.entry-content a.wp-block-button__link.wp-element-button,
.page-venezia .evotheme-venezia-welcome-content.entry-content a.wp-block-button__link.wp-element-button {
  align-content: center;
  box-sizing: border-box;
  cursor: pointer;
  display: inline-block;
  height: auto;
  max-height: none;
  text-align: center;
  word-break: break-word;
  background: transparent;
  border: 1px solid #6e6e6e;
  border-radius: 9999px;
  color: #6e6e6e;
  box-shadow: none;
  text-decoration: none;
  padding: calc(0.667em + 2px) calc(1.333em + 2px);
  font-size: 1.125em;
  font-weight: inherit;
  line-height: inherit;
  letter-spacing: normal;
  text-transform: none;
  margin-top: 1.5rem;
}

.evotheme-page-venezia .evotheme-venezia-welcome-content.entry-content a.wp-block-button__link.wp-element-button:visited,
.page-template-page-venezia-php .evotheme-venezia-welcome-content.entry-content a.wp-block-button__link.wp-element-button:visited,
.page-venezia .evotheme-venezia-welcome-content.entry-content a.wp-block-button__link.wp-element-button:visited {
  color: #6e6e6e;
}

.evotheme-page-venezia .evotheme-venezia-welcome-content.entry-content a.wp-block-button__link.wp-element-button:hover,
.page-template-page-venezia-php .evotheme-venezia-welcome-content.entry-content a.wp-block-button__link.wp-element-button:hover,
.page-venezia .evotheme-venezia-welcome-content.entry-content a.wp-block-button__link.wp-element-button:hover,
.evotheme-page-venezia .evotheme-venezia-welcome-content.entry-content a.wp-block-button__link.wp-element-button:focus,
.page-template-page-venezia-php .evotheme-venezia-welcome-content.entry-content a.wp-block-button__link.wp-element-button:focus,
.page-venezia .evotheme-venezia-welcome-content.entry-content a.wp-block-button__link.wp-element-button:focus {
  background: transparent;
  border-color: #252525;
  color: #252525;
  text-decoration: none;
}

.evotheme-page-venezia .evotheme-venezia-welcome-content.entry-content a.wp-block-button__link.wp-element-button:focus-visible,
.page-template-page-venezia-php .evotheme-venezia-welcome-content.entry-content a.wp-block-button__link.wp-element-button:focus-visible,
.page-venezia .evotheme-venezia-welcome-content.entry-content a.wp-block-button__link.wp-element-button:focus-visible {
  outline: 2px solid #252525;
  outline-offset: 3px;
}

.evotheme-page-venezia .evotheme-venezia-welcome-content.entry-content > *:first-child,
.page-template-page-venezia-php .evotheme-venezia-welcome-content.entry-content > *:first-child,
.page-venezia .evotheme-venezia-welcome-content.entry-content > *:first-child {
  margin-top: 0;
}

.evotheme-page-venezia .evotheme-venezia-welcome-content.entry-content > *:last-child,
.page-template-page-venezia-php .evotheme-venezia-welcome-content.entry-content > *:last-child,
.page-venezia .evotheme-venezia-welcome-content.entry-content > *:last-child {
  margin-bottom: 0;
}

/* Overlay benvenuto Venezia — solo mobile: tipografia più compatta (desktop invariato sopra). */
@media (max-width: 782px) {
  .evotheme-page-venezia .evotheme-venezia-welcome-dialog,
  .page-template-page-venezia-php .evotheme-venezia-welcome-dialog,
  .page-venezia .evotheme-venezia-welcome-dialog {
    justify-content: center;
    justify-content: safe center;
    padding: max(2.75rem, calc(env(safe-area-inset-top, 0px) + 1.25rem)) 1rem max(2rem, env(safe-area-inset-bottom, 0px));
    -webkit-overflow-scrolling: touch;
  }

  .evotheme-page-venezia .evotheme-venezia-welcome-content.entry-content,
  .page-template-page-venezia-php .evotheme-venezia-welcome-content.entry-content,
  .page-venezia .evotheme-venezia-welcome-content.entry-content {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
  }

  .evotheme-page-venezia .evotheme-venezia-welcome-content.entry-content h1,
  .page-template-page-venezia-php .evotheme-venezia-welcome-content.entry-content h1,
  .page-venezia .evotheme-venezia-welcome-content.entry-content h1,
  .evotheme-page-venezia .evotheme-venezia-welcome-content.entry-content h2,
  .page-template-page-venezia-php .evotheme-venezia-welcome-content.entry-content h2,
  .page-venezia .evotheme-venezia-welcome-content.entry-content h2,
  .evotheme-page-venezia .evotheme-venezia-welcome-content.entry-content h3,
  .page-template-page-venezia-php .evotheme-venezia-welcome-content.entry-content h3,
  .page-venezia .evotheme-venezia-welcome-content.entry-content h3 {
    font-size: clamp(1.375rem, 4.8vw + 0.35rem, 1.95rem);
    font-weight: 500;
    letter-spacing: 0.06em;
    line-height: 1.28;
    overflow-wrap: anywhere;
    hyphens: auto;
    max-width: 22rem;
    margin-left: auto;
    margin-right: auto;
  }

  .evotheme-page-venezia .evotheme-venezia-welcome-content.entry-content p,
  .page-template-page-venezia-php .evotheme-venezia-welcome-content.entry-content p,
  .page-venezia .evotheme-venezia-welcome-content.entry-content p {
    font-size: 1rem;
    line-height: 1.55;
    letter-spacing: 0.02em;
    max-width: 22rem;
    margin-left: auto;
    margin-right: auto;
  }

  .evotheme-page-venezia .evotheme-venezia-welcome-content.entry-content a.wp-block-button__link.wp-element-button,
  .page-template-page-venezia-php .evotheme-venezia-welcome-content.entry-content a.wp-block-button__link.wp-element-button,
  .page-venezia .evotheme-venezia-welcome-content.entry-content a.wp-block-button__link.wp-element-button {
    font-size: 1rem;
    margin-top: 1rem;
    max-width: min(22rem, 100%);
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .evotheme-page-venezia .evotheme-venezia-welcome-close,
  .page-template-page-venezia-php .evotheme-venezia-welcome-close,
  .page-venezia .evotheme-venezia-welcome-close {
    top: max(0.35rem, env(safe-area-inset-top, 0px));
    right: max(0.35rem, env(safe-area-inset-right, 0px));
    width: 2.75rem;
    height: 2.75rem;
    font-size: 1.625rem;
  }
}

body.evotheme-page-venezia.evotheme-venezia-welcome-open .venezia-map-stack,
body.page-venezia.evotheme-venezia-welcome-open .venezia-map-stack,
body.page-template-page-venezia-php.evotheme-venezia-welcome-open .venezia-map-stack {
  overflow: hidden;
}

.admin-bar.evotheme-page-venezia .page-venezia-main,
.admin-bar.page-template-page-venezia-php .page-venezia-main,
.admin-bar.page-venezia .page-venezia-main {
  min-height: calc(100vh - 32px);
  min-height: calc(100dvh - 32px);
}

@media (max-width: 782px) {
  .admin-bar.evotheme-page-venezia .page-venezia-main,
  .admin-bar.page-template-page-venezia-php .page-venezia-main,
  .admin-bar.page-venezia .page-venezia-main {
    min-height: calc(100vh - 46px);
    min-height: calc(100dvh - 46px);
  }
}

.evotheme-page-venezia .venezia-map,
.evotheme-page-venezia .venezia-map.leaflet-container,
.page-template-page-venezia-php .venezia-map,
.page-template-page-venezia-php .venezia-map.leaflet-container,
.page-venezia .venezia-map,
.page-venezia .venezia-map.leaflet-container {
  width: 100% !important;
  flex: 1 1 auto;
  height: 100vh !important;
  height: 100dvh !important;
  min-height: 420px !important;
  z-index: 1;
}

.admin-bar.evotheme-page-venezia .venezia-map,
.admin-bar.evotheme-page-venezia .venezia-map.leaflet-container,
.admin-bar.page-template-page-venezia-php .venezia-map,
.admin-bar.page-template-page-venezia-php .venezia-map.leaflet-container,
.admin-bar.page-venezia .venezia-map,
.admin-bar.page-venezia .venezia-map.leaflet-container {
  height: calc(100vh - 32px) !important;
  height: calc(100dvh - 32px) !important;
}

@media (max-width: 782px) {
  .admin-bar.evotheme-page-venezia .venezia-map,
  .admin-bar.evotheme-page-venezia .venezia-map.leaflet-container,
  .admin-bar.page-template-page-venezia-php .venezia-map,
  .admin-bar.page-template-page-venezia-php .venezia-map.leaflet-container,
  .admin-bar.page-venezia .venezia-map,
  .admin-bar.page-venezia .venezia-map.leaflet-container {
    height: calc(100vh - 46px) !important;
    height: calc(100dvh - 46px) !important;
  }
}

@media (max-width: 960px) {
  .evotheme-page-venezia .venezia-map,
  .evotheme-page-venezia .venezia-map.leaflet-container,
  .page-template-page-venezia-php .venezia-map,
  .page-template-page-venezia-php .venezia-map.leaflet-container,
  .page-venezia .venezia-map,
  .page-venezia .venezia-map.leaflet-container {
    height: calc(100vh - 130px) !important;
    height: calc(100dvh - 130px) !important;
    min-height: 300px !important;
  }

  .admin-bar.evotheme-page-venezia .venezia-map,
  .admin-bar.evotheme-page-venezia .venezia-map.leaflet-container,
  .admin-bar.page-template-page-venezia-php .venezia-map,
  .admin-bar.page-template-page-venezia-php .venezia-map.leaflet-container,
  .admin-bar.page-venezia .venezia-map,
  .admin-bar.page-venezia .venezia-map.leaflet-container {
    height: calc(100vh - 162px) !important;
    height: calc(100dvh - 162px) !important;
  }

  /*
   * Header mobile fixed sopra la mappa (z-index alto): i controlli zoom Leaflet default finirebbero sotto la barra (+ invisibile).
   * Abbassa il corner top-left sotto l’altezza header (+ safe area); admin-bar WP somma la sua fascia.
   */
  .evotheme-page-venezia .venezia-map.leaflet-container .leaflet-top.leaflet-left,
  .page-template-page-venezia-php .venezia-map.leaflet-container .leaflet-top.leaflet-left,
  .page-venezia .venezia-map.leaflet-container .leaflet-top.leaflet-left {
    top: calc(var(--site-mobile-header-height, 56px) + env(safe-area-inset-top, 0px) + 10px);
    left: max(10px, env(safe-area-inset-left, 0px));
  }

  body.admin-bar.evotheme-page-venezia .venezia-map.leaflet-container .leaflet-top.leaflet-left,
  body.admin-bar.page-template-page-venezia-php .venezia-map.leaflet-container .leaflet-top.leaflet-left,
  body.admin-bar.page-venezia .venezia-map.leaflet-container .leaflet-top.leaflet-left {
    top: calc(32px + var(--site-mobile-header-height, 56px) + env(safe-area-inset-top, 0px) + 10px);
  }
}

@media (max-width: 782px) {
  body.admin-bar.evotheme-page-venezia .venezia-map.leaflet-container .leaflet-top.leaflet-left,
  body.admin-bar.page-template-page-venezia-php .venezia-map.leaflet-container .leaflet-top.leaflet-left,
  body.admin-bar.page-venezia .venezia-map.leaflet-container .leaflet-top.leaflet-left {
    top: calc(46px + var(--site-mobile-header-height, 56px) + env(safe-area-inset-top, 0px) + 10px);
  }
}

@media (max-width: 600px) {
  .evotheme-page-venezia .venezia-map.leaflet-container .leaflet-top.leaflet-left,
  .page-template-page-venezia-php .venezia-map.leaflet-container .leaflet-top.leaflet-left,
  .page-venezia .venezia-map.leaflet-container .leaflet-top.leaflet-left {
    top: calc(var(--site-mobile-header-height, 52px) + env(safe-area-inset-top, 0px) + 10px);
  }

  body.admin-bar.evotheme-page-venezia .venezia-map.leaflet-container .leaflet-top.leaflet-left,
  body.admin-bar.page-template-page-venezia-php .venezia-map.leaflet-container .leaflet-top.leaflet-left,
  body.admin-bar.page-venezia .venezia-map.leaflet-container .leaflet-top.leaflet-left {
    top: calc(46px + var(--site-mobile-header-height, 52px) + env(safe-area-inset-top, 0px) + 10px);
  }
}

/*
 * Marcatore Leaflet (Venezia / Contatti): fill = sidebar.
 * Non usare solo currentColor sul path: dal div HTML il color spesso non eredita nel SVG → resta #111 del body.
 */
.leaflet-container .leaflet-div-icon.evotheme-leaflet-marker {
  width: 32px !important;
  height: 42px !important;
  background: transparent !important;
  border: none !important;
  color: var(--evotheme-sidebar-bg) !important;
}

.leaflet-container .evotheme-leaflet-marker svg {
  display: block;
  width: 32px;
  height: 42px;
  color: var(--evotheme-sidebar-bg) !important;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.28));
}

.leaflet-container .evotheme-leaflet-marker svg path {
  fill: var(--evotheme-sidebar-bg) !important;
}

/* Venezia: ingresso marker (animazione sul pin interno; Leaflet usa transform sul contenitore) */
.evotheme-page-venezia .evotheme-leaflet-marker .evotheme-venezia-marker-pin,
.page-venezia .evotheme-leaflet-marker .evotheme-venezia-marker-pin,
.page-template-page-venezia-php .evotheme-leaflet-marker .evotheme-venezia-marker-pin {
  display: block;
  width: 32px;
  height: 42px;
}

@media (prefers-reduced-motion: no-preference) {
  .evotheme-page-venezia .evotheme-leaflet-marker .evotheme-venezia-marker-pin.evotheme-venezia-marker-enter-anim.evotheme-venezia-marker-from-left,
  .page-venezia .evotheme-leaflet-marker .evotheme-venezia-marker-pin.evotheme-venezia-marker-enter-anim.evotheme-venezia-marker-from-left,
  .page-template-page-venezia-php .evotheme-leaflet-marker .evotheme-venezia-marker-pin.evotheme-venezia-marker-enter-anim.evotheme-venezia-marker-from-left {
    animation: evotheme-chi-siamo-column-from-left 3.4s cubic-bezier(0.16, 1, 0.28, 1) both;
    animation-delay: calc(var(--evotheme-marker-stagger, 0) * 420ms);
  }

  .evotheme-page-venezia .evotheme-leaflet-marker .evotheme-venezia-marker-pin.evotheme-venezia-marker-enter-anim.evotheme-venezia-marker-from-right,
  .page-venezia .evotheme-leaflet-marker .evotheme-venezia-marker-pin.evotheme-venezia-marker-enter-anim.evotheme-venezia-marker-from-right,
  .page-template-page-venezia-php .evotheme-leaflet-marker .evotheme-venezia-marker-pin.evotheme-venezia-marker-enter-anim.evotheme-venezia-marker-from-right {
    animation: evotheme-chi-siamo-column-from-right 3.4s cubic-bezier(0.16, 1, 0.28, 1) both;
    animation-delay: calc(var(--evotheme-marker-stagger, 0) * 420ms);
  }
}

@media (prefers-reduced-motion: reduce) {
  .evotheme-page-venezia .evotheme-leaflet-marker .evotheme-venezia-marker-pin.evotheme-venezia-marker-enter-anim,
  .page-venezia .evotheme-leaflet-marker .evotheme-venezia-marker-pin.evotheme-venezia-marker-enter-anim,
  .page-template-page-venezia-php .evotheme-leaflet-marker .evotheme-venezia-marker-pin.evotheme-venezia-marker-enter-anim {
    animation: none;
    opacity: 1;
    transform: none;
  }
}

/* Popup portfolio Venezia: header = sidebar, corpo bianco, testo da meta _evotheme_map_popup_text */
.evotheme-page-venezia .leaflet-popup.venezia-leaflet-popup .leaflet-popup-content-wrapper,
.page-venezia .leaflet-popup.venezia-leaflet-popup .leaflet-popup-content-wrapper,
.page-template-page-venezia-php .leaflet-popup.venezia-leaflet-popup .leaflet-popup-content-wrapper {
  padding: 0;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.2);
  border: 1px solid rgba(0, 0, 0, 0.08);
}

.evotheme-page-venezia .leaflet-popup.venezia-leaflet-popup .leaflet-popup-content,
.page-venezia .leaflet-popup.venezia-leaflet-popup .leaflet-popup-content,
.page-template-page-venezia-php .leaflet-popup.venezia-leaflet-popup .leaflet-popup-content {
  margin: 0;
  min-width: 240px;
  max-width: 320px;
  font-family: var(--evotheme-font-family);
}

.evotheme-page-venezia .venezia-popup-root,
.page-venezia .venezia-popup-root,
.page-template-page-venezia-php .venezia-popup-root {
  display: flex;
  flex-direction: column;
  text-align: left;
}

.evotheme-page-venezia .venezia-popup-header,
.page-venezia .venezia-popup-header,
.page-template-page-venezia-php .venezia-popup-header {
  margin: 0;
  padding: 0.85rem 1rem;
  background: var(--evotheme-sidebar-bg);
  color: #fff;
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.35;
  text-transform: uppercase;
  border: 0;
}

.evotheme-page-venezia .venezia-popup-body,
.page-venezia .venezia-popup-body,
.page-template-page-venezia-php .venezia-popup-body {
  background: #fff;
  color: #252525;
}

.evotheme-page-venezia .venezia-popup-media,
.page-venezia .venezia-popup-media,
.page-template-page-venezia-php .venezia-popup-media {
  display: block;
  overflow: hidden;
  background: #f0f0f0;
}

.evotheme-page-venezia .venezia-popup-media img,
.page-venezia .venezia-popup-media img,
.page-template-page-venezia-php .venezia-popup-media img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  display: block;
}

.evotheme-page-venezia .venezia-popup-media--empty,
.page-venezia .venezia-popup-media--empty,
.page-template-page-venezia-php .venezia-popup-media--empty {
  min-height: 120px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #6f6f6f;
  font-size: 0.75rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 400;
}

.evotheme-page-venezia .venezia-popup-text,
.page-venezia .venezia-popup-text,
.page-template-page-venezia-php .venezia-popup-text {
  padding: 1rem 1rem 0.65rem;
  font-size: 0.875rem;
  line-height: 1.6;
  color: #333;
}

.evotheme-page-venezia .venezia-popup-text p,
.page-venezia .venezia-popup-text p,
.page-template-page-venezia-php .venezia-popup-text p {
  margin: 0 0 0.65rem;
}

.evotheme-page-venezia .venezia-popup-text p:last-child,
.page-venezia .venezia-popup-text p:last-child,
.page-template-page-venezia-php .venezia-popup-text p:last-child {
  margin-bottom: 0;
}

.evotheme-page-venezia .venezia-popup-more,
.page-venezia .venezia-popup-more,
.page-template-page-venezia-php .venezia-popup-more {
  display: block;
  padding: 0.65rem 1rem 1rem;
  font-size: 0.875rem;
  font-weight: 400;
  color: #252525;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.evotheme-page-venezia .venezia-popup-more:hover,
.page-venezia .venezia-popup-more:hover,
.page-template-page-venezia-php .venezia-popup-more:hover,
.evotheme-page-venezia .venezia-popup-more:focus-visible,
.page-venezia .venezia-popup-more:focus-visible,
.page-template-page-venezia-php .venezia-popup-more:focus-visible {
  color: #111;
}

.evotheme-page-venezia .leaflet-popup.venezia-leaflet-popup .leaflet-popup-tip,
.page-venezia .leaflet-popup.venezia-leaflet-popup .leaflet-popup-tip,
.page-template-page-venezia-php .leaflet-popup.venezia-leaflet-popup .leaflet-popup-tip {
  background: #fff;
  box-shadow: none;
  border: 1px solid rgba(0, 0, 0, 0.06);
}

/* Pagina Contatti: mappa Leaflet (tiles Carto positron come Venezia) */
.evotheme-page-contatti-mappa .page-contatti-entry iframe[src*="google.com/maps"],
.evotheme-page-contatti-mappa .page-contatti-entry iframe[src*="google.it/maps"] {
  display: none !important;
}

/* Evita doppia mappa: il tema mostra già #contatti-map sopra; nascondi Leaflet nel contenuto editor */
.evotheme-page-contatti-mappa .page-contatti-entry .leaflet-container {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  min-height: 0 !important;
  max-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  overflow: hidden !important;
  pointer-events: none !important;
}

.evotheme-page-contatti-mappa .page-contatti-entry iframe[src*="openstreetmap.org"] {
  display: none !important;
}

.page-contatti-main {
  width: min(100%, var(--evotheme-content-max-width));
  margin: 0 auto;
}

.page-contatti-head {
  margin: 0 0 1.25rem;
}

.page-contatti-title {
  margin: 0;
  font-size: clamp(1.75rem, 4vw, 2.25rem);
  font-weight: 400;
  letter-spacing: 0.06em;
  color: #111;
}

@keyframes evotheme-contatti-map-from-top {
  from {
    opacity: 0;
    transform: translateY(-4rem);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: no-preference) {
  .evotheme-page-contatti-mappa .page-contatti-main #contatti-map.contatti-map {
    animation: evotheme-contatti-map-from-top 2.4s cubic-bezier(0.16, 1, 0.28, 1) both;
  }
}

@media (prefers-reduced-motion: reduce) {
  .evotheme-page-contatti-mappa .page-contatti-main #contatti-map.contatti-map {
    animation: none;
    opacity: 1;
    transform: none;
  }
}

.evotheme-page-contatti-mappa .contatti-map,
.evotheme-page-contatti-mappa .contatti-map.leaflet-container {
  width: 100% !important;
  height: 380px !important;
  min-height: 260px !important;
  max-width: 100%;
  margin: 0 auto 2rem;
  border-radius: 2px;
  overflow: hidden;
  border: none;
  box-shadow: none;
  z-index: 1;
}

.evotheme-page-contatti-mappa .leaflet-popup.contatti-leaflet-popup .leaflet-popup-content-wrapper {
  padding: 0;
  border-radius: 2px;
  overflow: hidden;
  box-shadow: 0 6px 24px rgba(0, 0, 0, 0.18);
  border: 1px solid rgba(0, 0, 0, 0.06);
}

.evotheme-page-contatti-mappa .leaflet-popup.contatti-leaflet-popup .leaflet-popup-content {
  margin: 0;
  min-width: 200px;
  max-width: 280px;
  padding: 0.85rem 1rem;
  font-family: var(--evotheme-font-family);
  font-size: 0.9rem;
  line-height: 1.45;
  color: #252525;
}

.evotheme-page-contatti-mappa .contatti-map-popup-text p {
  margin: 0 0 0.4em;
}

.evotheme-page-contatti-mappa .contatti-map-popup-text p:last-child {
  margin-bottom: 0;
}

.evotheme-page-contatti-mappa .leaflet-popup.contatti-leaflet-popup .leaflet-popup-tip {
  box-shadow: none;
  border: 1px solid rgba(0, 0, 0, 0.06);
}

@media (max-width: 960px) {
  .evotheme-page-contatti-mappa .contatti-map,
  .evotheme-page-contatti-mappa .contatti-map.leaflet-container {
    height: 280px !important;
    min-height: 220px !important;
    margin-bottom: 1.5rem;
  }
}

@media (max-width: 600px) {
  .evotheme-page-venezia .leaflet-popup.venezia-leaflet-popup .leaflet-popup-content,
  .page-venezia .leaflet-popup.venezia-leaflet-popup .leaflet-popup-content,
  .page-template-page-venezia-php .leaflet-popup.venezia-leaflet-popup .leaflet-popup-content {
    min-width: 0;
    width: min(86vw, 320px);
    max-width: 86vw;
  }

  .evotheme-page-contatti-mappa .leaflet-popup.contatti-leaflet-popup .leaflet-popup-content {
    min-width: 0;
    width: min(84vw, 280px);
    max-width: 84vw;
  }
}

/* Portfolio archive (hero + filtri come mockup) */
.portfolio-archive-page {
  width: min(100%, var(--evotheme-content-max-width));
  margin: 0 auto;
  padding: 3.25rem var(--evotheme-content-padding-x) 3.5rem;
  background: #fff;
}

.portfolio-archive-intro {
  margin: 0 auto 6.25rem;
  padding: 0 1rem;
  text-align: center;
  max-width: 920px;
}

/* Due righe nel titolo: stile tipografico = h1 globale (come pagine es. Chi siamo) */
.portfolio-archive-title-line {
  display: block;
}

.portfolio-filters {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 1.75rem 2.25rem;
  margin: 0 auto 2.75rem;
  padding: 0 1rem;
  max-width: 960px;
}

.portfolio-filter-link {
  display: inline-block;
  padding: 0;
  border: 0;
  background: transparent;
  color: #1a1a1a;
  text-decoration: none;
  font-family: inherit;
  font-size: 20px;
  line-height: 34px;
  font-style: normal;
  font-weight: 400;
  letter-spacing: 1px;
  text-transform: none;
  white-space: nowrap;
  border-bottom: 1px solid transparent;
  cursor: pointer;
  transition: color 0.2s ease, border-color 0.2s ease;
}

.portfolio-filter-link:hover,
.portfolio-filter-link:focus {
  color: #000;
  border-bottom-color: rgba(0, 0, 0, 0.35);
}

.portfolio-filter-link.is-active {
  font-weight: 500;
  border-bottom-color: #111;
  color: #000;
}

.portfolio-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.3rem 1.4rem;
}

/* Filtri archivio: dissolvenza sull’intera griglia (#portfolio-archive-grid) */
#portfolio-archive-grid.portfolio-grid {
  opacity: 1;
  transition: opacity 0.42s ease;
}

#portfolio-archive-grid.portfolio-grid.portfolio-grid--is-filtering {
  pointer-events: none;
}

#portfolio-archive-grid.portfolio-grid.portfolio-grid--filter-fade-out {
  opacity: 0;
}

.portfolio-grid .portfolio-card.portfolio-card--filter-gone {
  display: none !important;
}

@media (prefers-reduced-motion: reduce) {
  #portfolio-archive-grid.portfolio-grid {
    transition: none;
  }

  #portfolio-archive-grid.portfolio-grid.portfolio-grid--filter-fade-out {
    opacity: 1;
  }
}

.portfolio-archive-empty {
  grid-column: 1 / -1;
  margin: 2rem 0 0;
  text-align: center;
  color: #6e6e6e;
  font-size: 0.9rem;
  letter-spacing: 0.02em;
}

.portfolio-card {
  margin: 0;
}

.portfolio-card-media {
  position: relative;
  display: block;
  overflow: hidden;
  width: 100%;
  aspect-ratio: 1 / 1;
  background: #f5f5f5;
}

.portfolio-card-media::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: #fff;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.portfolio-card-media:hover::after,
.portfolio-card-media:focus-visible::after {
  opacity: 0.5;
}

.portfolio-card-media img {
  position: relative;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.3s ease;
}

.portfolio-card-media:hover img,
.portfolio-card-media:focus-visible img {
  transform: scale(1.03);
}

.portfolio-card-placeholder {
  position: relative;
  z-index: 0;
  min-height: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #6f6f6f;
  font-size: 0.9rem;
}

.portfolio-card-meta {
  text-align: center;
  padding: 2rem 0.25rem 2rem;
}

.portfolio-card-title {
  margin: 0;
  font-size: 20px;
  line-height: 34px;
  letter-spacing: 1px;
  font-style: normal;
  text-transform: capitalize;
  font-weight: 400;
}

.portfolio-card-title a {
  color: #252525;
  text-decoration: none;
}

.portfolio-card-title a:hover,
.portfolio-card-title a:focus {
  text-decoration: underline;
}

.portfolio-card-info {
  margin: 0.35rem 0 0;
  color: #737373;
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  text-transform: capitalize;
}

.portfolio-pagination {
  margin-top: 2rem;
  text-align: center;
}

.portfolio-pagination .page-numbers {
  display: inline-block;
  margin: 0 0.18rem;
  padding: 0.3rem 0.6rem;
  border: 1px solid #d8d8d8;
  color: #252525;
  text-decoration: none;
}

.portfolio-pagination .page-numbers.current,
.portfolio-pagination .page-numbers:hover,
.portfolio-pagination .page-numbers:focus {
  border-color: #252525;
  background: #252525;
  color: #fff;
}

/* Portfolio single */
.portfolio-single-page {
  width: min(100%, var(--evotheme-content-max-width));
  margin: 0 auto;
  padding: 1.6rem var(--evotheme-content-padding-x) 3rem;
}

.portfolio-single-head {
  margin-bottom: 1rem;
}

/* Galleria: copertina full width + masonry JS (max 2 colonne, colonna più bassa) */
.portfolio-single-gallery {
  width: 100%;
}

.portfolio-single-gallery .portfolio-single-image.is-cover {
  margin: 0 0 1.25rem;
  display: block;
  overflow: hidden;
  background: #f0f0f0;
}

.portfolio-single-gallery .portfolio-single-image.is-cover img {
  width: 100%;
  height: auto;
  display: block;
}

.portfolio-masonry {
  --portfolio-masonry-gap: 18px;
  position: relative;
  width: 100%;
}

.portfolio-masonry .portfolio-single-image,
.portfolio-single-gallery figure.portfolio-single-image {
  margin: 0;
  padding: 0;
  overflow: hidden;
  background: #f0f0f0;
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.06);
}

.portfolio-masonry .portfolio-single-image img {
  width: 100%;
  height: auto;
  display: block;
}

.portfolio-single-image img {
  width: 100%;
  height: auto;
  display: block;
}

.portfolio-single-meta {
  margin-top: 1.35rem;
  padding-top: 0.9rem;
  border-top: 1px solid #e5e5e5;
  color: #4f4f4f;
  font-size: 0.82rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.portfolio-single-meta p {
  margin: 0.35rem 0;
}

@media (max-width: 1200px) {
  .portfolio-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

}

@media (max-width: 960px) {
  /* Non usare padding shorthand: sovrascriverebbe il padding-top di .site-main per la header fissa */
  .portfolio-archive-page,
  .portfolio-single-page {
    width: 100%;
    padding-top: calc(var(--site-mobile-header-height, 56px) + 1rem);
    padding-left: 1rem;
    padding-right: 1rem;
    padding-bottom: 2rem;
  }

  .portfolio-archive-intro {
    margin-bottom: 1.75rem;
    padding: 0;
  }

  .portfolio-grid {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  .portfolio-filters {
    justify-content: center;
    gap: 1rem 1.35rem;
    margin-bottom: 2rem;
  }

  .portfolio-filter-link {
    font-size: 0.78rem;
  }

  .portfolio-masonry {
    --portfolio-masonry-gap: 14px;
  }
}

@media (max-width: 600px) {
  /* Allinea a .site-main stretto: --site-mobile-header-height 52px */
  .portfolio-archive-page,
  .portfolio-single-page {
    padding-top: calc(var(--site-mobile-header-height, 52px) + 0.9rem);
    padding-left: 0.85rem;
    padding-right: 0.85rem;
  }
}
