.mod-divinggallerymenu {
  --dgm-height: 620px;
  --dgm-max-width: 1240px;
  --dgm-feature: 64%;
  --dgm-line: 12px;
  --dgm-radius: 0px;
  --dgm-content-x: 6%;
  --dgm-content-y: 17%;
  --dgm-accent: #c5b27d;
  --dgm-line-color: #fff;
  --dgm-text: #fff;
  --dgm-button-bg: #c5b27d;
  --dgm-button-text: #fff;
  --dgm-overlay: .55;
  --dgm-tile-overlay: .35;
  --dgm-slant: 64px;
  --dgm-tile-title-max: 54px;
  --dgm-tile-letter: .055em;
  --dgm-button-gap: 56px;
  --dgm-secondary-gap: 26px;
  --dgm-margin-top: 0px;
  --dgm-margin-right: 0px;
  --dgm-margin-bottom: 0px;
  --dgm-margin-left: 0px;
  position: relative;
  color: var(--dgm-text);
  font-family: inherit;
  width: 100%;
  overflow: visible;
  margin-top: var(--dgm-margin-top);
  margin-bottom: var(--dgm-margin-bottom);
}

.mod-divinggallerymenu,
.mod-divinggallerymenu * {
  box-sizing: border-box;
}

.mod-divinggallerymenu .dgm-shell {
  position: relative;
  margin-inline: auto;
  width: 100%;
}

.mod-divinggallerymenu.dgm-boxed .dgm-shell {
  width: calc(100% - var(--dgm-margin-left) - var(--dgm-margin-right));
  max-width: var(--dgm-max-width);
  padding-inline: 0;
}

.mod-divinggallerymenu.dgm-fullwidth .dgm-shell {
  width: calc(100vw - var(--dgm-margin-left) - var(--dgm-margin-right));
  max-width: calc(100vw - var(--dgm-margin-left) - var(--dgm-margin-right));
  margin-left: calc(50% - 50vw + var(--dgm-margin-left));
  margin-right: calc(50% - 50vw + var(--dgm-margin-right));
}

.mod-divinggallerymenu .dgm-stage {
  position: relative;
  min-height: var(--dgm-height);
  height: var(--dgm-height);
  overflow: hidden;
  border-radius: var(--dgm-radius);
  background: #061923;
  isolation: isolate;
}

.mod-divinggallerymenu .dgm-feature {
  position: absolute;
  inset: 0;
  min-width: 0;
  min-height: 0;
  overflow: hidden;
  background: #061923;
  z-index: 1;
}

.mod-divinggallerymenu.dgm-pos-left .dgm-feature {
  grid-column: auto;
}

/* v1.1.7: viewport visivo separato dal link.
   L'immagine grande viene centrata solo dentro la porzione realmente visibile,
   mentre overlay, link e z-index restano indipendenti dai box piccoli. */
.mod-divinggallerymenu .dgm-feature-visual {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: auto;
  width: min(100%, calc(var(--dgm-feature) + var(--dgm-slant) + var(--dgm-line)));
  height: 100%;
  overflow: hidden;
  z-index: 0;
  background: #061923;
}

.mod-divinggallerymenu.dgm-pos-left .dgm-feature-visual {
  left: auto;
  right: 0;
}

.mod-divinggallerymenu.dgm-pos-right.dgm-variant-diagonal .dgm-feature-visual,
.mod-divinggallerymenu.dgm-pos-right.dgm-variant-compact .dgm-feature-visual {
  clip-path: polygon(0 0, 100% 0, calc(100% - var(--dgm-slant) - var(--dgm-line)) 100%, 0 100%);
}

.mod-divinggallerymenu.dgm-pos-left.dgm-variant-diagonal .dgm-feature-visual,
.mod-divinggallerymenu.dgm-pos-left.dgm-variant-compact .dgm-feature-visual {
  clip-path: polygon(var(--dgm-line) 0, 100% 0, 100% 100%, calc(var(--dgm-slant) + var(--dgm-line)) 100%);
}

.mod-divinggallerymenu .dgm-feature-bg,
.mod-divinggallerymenu .dgm-feature-video,
.mod-divinggallerymenu .dgm-feature-shade {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.mod-divinggallerymenu .dgm-feature-bg {
  background-image: var(--dgm-bg-image);
  background-size: cover;
  background-position: center;
  z-index: 0;
  transform: scale(1.01);
  transition: background-image .35s ease, filter .35s ease, transform .45s ease;
}

.mod-divinggallerymenu .dgm-feature-video {
  object-fit: cover;
  z-index: 1;
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s ease;
}

.mod-divinggallerymenu .dgm-feature-video.is-visible {
  opacity: 1;
}

.mod-divinggallerymenu .dgm-feature-shade {
  z-index: 2;
  background:
    linear-gradient(90deg, rgba(0,0,0,var(--dgm-overlay)) 0%, rgba(0,0,0,calc(var(--dgm-overlay) * .72)) 52%, rgba(0,0,0,.20) 100%),
    radial-gradient(circle at 65% 35%, rgba(255,255,255,.10), transparent 25%);
}

.mod-divinggallerymenu .dgm-content {
  position: absolute;
  top: var(--dgm-content-y);
  left: var(--dgm-content-x);
  z-index: 4;
  width: min(620px, calc(var(--dgm-feature) - var(--dgm-content-x) - 2rem));
  margin: 0;
  padding: 0 0 4rem;
}

.mod-divinggallerymenu.dgm-pos-left .dgm-content {
  left: auto;
  right: var(--dgm-content-x);
  margin: 0;
}

.mod-divinggallerymenu .dgm-kicker {
  margin: 0 0 1.4rem;
  color: var(--dgm-text);
  opacity: .82;
  font-size: clamp(.76rem, .95vw, 1rem);
  font-weight: 700;
  letter-spacing: .42em;
  line-height: 1.2;
  text-transform: uppercase;
}

.mod-divinggallerymenu .dgm-title {
  margin: 0;
  color: var(--dgm-text);
  font-size: clamp(3rem, 5.4vw, 6.4rem);
  font-weight: 900;
  line-height: .92;
  letter-spacing: .08em;
  text-shadow: 0 16px 38px rgba(0,0,0,.42);
}

.mod-divinggallerymenu .dgm-title span {
  display: block;
}

.mod-divinggallerymenu .dgm-accent-line {
  display: block;
  width: clamp(42px, 5vw, 72px);
  height: 3px;
  margin: clamp(1.15rem, 2vw, 2rem) 0 clamp(1.5rem, 2.4vw, 2.4rem);
  background: var(--dgm-accent);
}

.mod-divinggallerymenu .dgm-copy {
  max-width: 560px;
}

.mod-divinggallerymenu .dgm-small-title,
.mod-divinggallerymenu .dgm-subtitle,
.mod-divinggallerymenu .dgm-description {
  display: block;
  margin: 0;
  color: var(--dgm-text);
}

.mod-divinggallerymenu .dgm-small-title,
.mod-divinggallerymenu .dgm-subtitle {
  font-size: clamp(1.6rem, 2.55vw, 3.25rem);
  line-height: 1.08;
  font-weight: 400;
  text-shadow: 0 12px 30px rgba(0,0,0,.36);
}

.mod-divinggallerymenu .dgm-subtitle {
  margin-bottom: 1.2rem;
}

.mod-divinggallerymenu .dgm-description {
  max-width: 560px;
  color: color-mix(in srgb, var(--dgm-text) 84%, transparent);
  font-size: clamp(.98rem, 1.1vw, 1.12rem);
  line-height: 1.65;
}

.mod-divinggallerymenu .dgm-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 1.2rem;
  min-width: clamp(180px, 18vw, 300px);
  min-height: clamp(54px, 5.5vw, 82px);
  margin-top: var(--dgm-button-gap);
  padding: 1rem 2.5rem;
  background: var(--dgm-button-bg);
  color: var(--dgm-button-text);
  text-decoration: none;
  font-size: clamp(1.15rem, 1.7vw, 1.8rem);
  font-weight: 800;
  line-height: 1;
  letter-spacing: .01em;
  box-shadow: 0 18px 46px rgba(0,0,0,.26);
  transition: transform .22s ease, filter .22s ease;
}

.mod-divinggallerymenu .dgm-primary:hover,
.mod-divinggallerymenu .dgm-primary:focus-visible {
  color: var(--dgm-button-text);
  filter: brightness(1.05);
  transform: translateY(-3px);
  outline: none;
}

.mod-divinggallerymenu .dgm-secondary {
  display: table;
  margin-top: var(--dgm-secondary-gap);
  color: var(--dgm-text);
  text-decoration: none;
  font-size: clamp(.96rem, 1vw, 1.1rem);
  font-weight: 500;
  border-bottom: 2px solid var(--dgm-accent);
  padding-bottom: .25rem;
  transition: opacity .2s ease, transform .2s ease;
}

.mod-divinggallerymenu .dgm-secondary:hover,
.mod-divinggallerymenu .dgm-secondary:focus-visible {
  color: var(--dgm-text);
  opacity: .82;
  transform: translateX(3px);
  outline: none;
}

.mod-divinggallerymenu .dgm-tiles {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: calc(100% - var(--dgm-feature));
  height: 100%;
  display: grid;
  grid-template-rows: repeat(var(--dgm-small-count), minmax(0, 1fr));
  gap: var(--dgm-line);
  background: var(--dgm-line-color);
  min-width: 0;
  min-height: 0;
  overflow: hidden;
  z-index: 5;
}

.mod-divinggallerymenu.dgm-pos-left .dgm-tiles {
  left: 0;
  right: auto;
}

.mod-divinggallerymenu.dgm-variant-diagonal.dgm-pos-right .dgm-tiles,
.mod-divinggallerymenu.dgm-variant-compact.dgm-pos-right .dgm-tiles {
  clip-path: polygon(var(--dgm-slant) 0, 100% 0, 100% 100%, 0 100%);
}

.mod-divinggallerymenu.dgm-variant-diagonal.dgm-pos-left .dgm-tiles,
.mod-divinggallerymenu.dgm-variant-compact.dgm-pos-left .dgm-tiles {
  clip-path: polygon(0 0, calc(100% - var(--dgm-slant)) 0, 100% 100%, 0 100%);
}

.mod-divinggallerymenu.dgm-variant-compact {
  --dgm-tile-title-max: min(50px, var(--dgm-tile-title-max));
}

.mod-divinggallerymenu.dgm-variant-straight {
  --dgm-slant: 0px;
}

.mod-divinggallerymenu.dgm-variant-straight .dgm-tiles {
  clip-path: none;
}

.mod-divinggallerymenu .dgm-stage::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: calc(var(--dgm-slant) + var(--dgm-line));
  background: var(--dgm-line-color);
  z-index: 8;
  pointer-events: none;
}

.mod-divinggallerymenu.dgm-pos-right.dgm-variant-diagonal .dgm-stage::after,
.mod-divinggallerymenu.dgm-pos-right.dgm-variant-compact .dgm-stage::after {
  left: calc(var(--dgm-feature) - var(--dgm-line) / 2);
  clip-path: polygon(var(--dgm-slant) 0, calc(var(--dgm-slant) + var(--dgm-line)) 0, var(--dgm-line) 100%, 0 100%);
}

.mod-divinggallerymenu.dgm-pos-left.dgm-variant-diagonal .dgm-stage::after,
.mod-divinggallerymenu.dgm-pos-left.dgm-variant-compact .dgm-stage::after {
  right: calc(var(--dgm-feature) - var(--dgm-line) / 2);
  clip-path: polygon(0 0, var(--dgm-line) 0, calc(var(--dgm-slant) + var(--dgm-line)) 100%, var(--dgm-slant) 100%);
}

.mod-divinggallerymenu.dgm-variant-straight .dgm-stage::after {
  width: var(--dgm-line);
  clip-path: none;
}

.mod-divinggallerymenu.dgm-pos-right.dgm-variant-straight .dgm-stage::after {
  left: calc(var(--dgm-feature) - var(--dgm-line) / 2);
}

.mod-divinggallerymenu.dgm-pos-left.dgm-variant-straight .dgm-stage::after {
  right: calc(var(--dgm-feature) - var(--dgm-line) / 2);
}

.mod-divinggallerymenu .dgm-tile {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  width: 100%;
  height: 100%;
  min-width: 0;
  min-height: 0;
  padding: clamp(1.2rem, 3vw, 3.5rem) clamp(1.4rem, 4vw, 5.4rem);
  border: 0;
  color: var(--dgm-text);
  text-align: left;
  cursor: pointer;
  background-color: #07141d;
  background-image: var(--dgm-tile-image);
  background-size: cover;
  background-position: center;
  overflow: hidden;
}

.mod-divinggallerymenu.dgm-pos-right.dgm-variant-diagonal .dgm-tile,
.mod-divinggallerymenu.dgm-pos-right.dgm-variant-compact .dgm-tile {
  padding-left: calc(var(--dgm-slant) + clamp(1.4rem, 3vw, 4rem));
}

.mod-divinggallerymenu.dgm-pos-left .dgm-tile {
  text-align: right;
  justify-content: flex-end;
}

.mod-divinggallerymenu.dgm-pos-left.dgm-variant-diagonal .dgm-tile,
.mod-divinggallerymenu.dgm-pos-left.dgm-variant-compact .dgm-tile {
  padding-right: calc(var(--dgm-slant) + clamp(1.4rem, 3vw, 4rem));
}

.mod-divinggallerymenu .dgm-tile > * {
  pointer-events: none;
}

.mod-divinggallerymenu .dgm-tile[aria-selected="true"] {
  cursor: pointer;
}

.mod-divinggallerymenu .dgm-tile::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,var(--dgm-tile-overlay));
  z-index: 1;
  transition: background .22s ease;
}

.mod-divinggallerymenu .dgm-tile-shade {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(0,0,0,.45), rgba(0,0,0,.08));
  z-index: 2;
}

.mod-divinggallerymenu.dgm-pos-left .dgm-tile-shade {
  background: linear-gradient(270deg, rgba(0,0,0,.45), rgba(0,0,0,.08));
}

.mod-divinggallerymenu .dgm-tile-content {
  position: relative;
  z-index: 3;
  display: block;
  max-width: calc(100% - clamp(55px, 8vw, 115px));
  min-width: 0;
  text-shadow: 0 12px 28px rgba(0,0,0,.5);
  transition: transform .22s ease;
}

.mod-divinggallerymenu .dgm-tile strong {
  display: block;
  color: var(--dgm-text);
  font-size: clamp(1.65rem, 2.9vw, var(--dgm-tile-title-max));
  font-weight: 900;
  letter-spacing: var(--dgm-tile-letter);
  line-height: .98;
  white-space: nowrap;
  overflow-wrap: normal;
  word-break: keep-all;
  hyphens: none;
}

.mod-divinggallerymenu .dgm-tile em {
  display: block;
  margin-top: .65rem;
  color: color-mix(in srgb, var(--dgm-text) 82%, transparent);
  font-size: clamp(.82rem, 1vw, 1.05rem);
  font-style: normal;
  font-weight: 500;
  letter-spacing: .03em;
  line-height: 1.25;
}

.mod-divinggallerymenu .dgm-tile:hover::before,
.mod-divinggallerymenu .dgm-tile:focus-visible::before,
.mod-divinggallerymenu .dgm-tile.is-active::before {
  background: rgba(0,0,0,calc(var(--dgm-tile-overlay) * .65));
}

.mod-divinggallerymenu .dgm-tile:hover .dgm-tile-content,
.mod-divinggallerymenu .dgm-tile:focus-visible .dgm-tile-content,
.mod-divinggallerymenu .dgm-tile.is-active .dgm-tile-content {
  transform: translateX(8px);
}

.mod-divinggallerymenu.dgm-pos-left .dgm-tile:hover .dgm-tile-content,
.mod-divinggallerymenu.dgm-pos-left .dgm-tile:focus-visible .dgm-tile-content,
.mod-divinggallerymenu.dgm-pos-left .dgm-tile.is-active .dgm-tile-content {
  transform: translateX(-8px);
}

.mod-divinggallerymenu .dgm-tile:focus-visible {
  outline: 3px solid var(--dgm-accent);
  outline-offset: -6px;
}

.mod-divinggallerymenu .dgm-play {
  position: absolute;
  right: clamp(1rem, 3vw, 3rem);
  top: 50%;
  z-index: 4;
  width: clamp(38px, 4.4vw, 68px);
  height: clamp(38px, 4.4vw, 68px);
  border: 3px solid var(--dgm-text);
  border-radius: 999px;
  transform: translateY(-50%);
  background: rgba(0,0,0,.12);
}

.mod-divinggallerymenu.dgm-pos-left .dgm-play {
  right: auto;
  left: clamp(1rem, 3vw, 3rem);
}

.mod-divinggallerymenu .dgm-play::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 0;
  height: 0;
  border-top: .55em solid transparent;
  border-bottom: .55em solid transparent;
  border-left: .82em solid var(--dgm-text);
  transform: translate(-38%, -50%);
  font-size: clamp(14px, 1.6vw, 22px);
}


/* v1.2.2: possibilità di nascondere il box grande su desktop e usare i box piccoli come menu completo. */
@media (min-width: 992px) {
  .mod-divinggallerymenu.dgm-hide-feature-desktop .dgm-feature,
  .mod-divinggallerymenu.dgm-hide-feature-desktop .dgm-stage::after {
    display: none;
  }

  .mod-divinggallerymenu.dgm-hide-feature-desktop .dgm-tiles,
  .mod-divinggallerymenu.dgm-hide-feature-desktop.dgm-pos-left .dgm-tiles,
  .mod-divinggallerymenu.dgm-hide-feature-desktop.dgm-variant-diagonal .dgm-tiles,
  .mod-divinggallerymenu.dgm-hide-feature-desktop.dgm-variant-compact .dgm-tiles,
  .mod-divinggallerymenu.dgm-hide-feature-desktop.dgm-variant-straight .dgm-tiles {
    left: 0;
    right: auto;
    width: 100%;
    clip-path: none !important;
  }

  .mod-divinggallerymenu.dgm-hide-feature-desktop .dgm-tile,
  .mod-divinggallerymenu.dgm-hide-feature-desktop.dgm-pos-left .dgm-tile,
  .mod-divinggallerymenu.dgm-hide-feature-desktop.dgm-pos-right.dgm-variant-diagonal .dgm-tile,
  .mod-divinggallerymenu.dgm-hide-feature-desktop.dgm-pos-right.dgm-variant-compact .dgm-tile,
  .mod-divinggallerymenu.dgm-hide-feature-desktop.dgm-pos-left.dgm-variant-diagonal .dgm-tile,
  .mod-divinggallerymenu.dgm-hide-feature-desktop.dgm-pos-left.dgm-variant-compact .dgm-tile {
    justify-content: flex-start;
    text-align: left;
    padding-left: clamp(1.4rem, 4vw, 5.4rem);
    padding-right: clamp(1.4rem, 4vw, 5.4rem);
  }
}

@media (max-width: 991.98px) {
  .mod-divinggallerymenu .dgm-stage,
  .mod-divinggallerymenu.dgm-pos-left .dgm-stage {
    height: auto;
    min-height: 0;
    display: grid;
    grid-template-columns: 1fr;
    background: var(--dgm-line-color);
  }

  .mod-divinggallerymenu .dgm-stage::after {
    display: none;
  }

  .mod-divinggallerymenu .dgm-feature-visual,
  .mod-divinggallerymenu.dgm-pos-left .dgm-feature-visual,
  .mod-divinggallerymenu.dgm-pos-right.dgm-variant-diagonal .dgm-feature-visual,
  .mod-divinggallerymenu.dgm-pos-right.dgm-variant-compact .dgm-feature-visual,
  .mod-divinggallerymenu.dgm-pos-left.dgm-variant-diagonal .dgm-feature-visual,
  .mod-divinggallerymenu.dgm-pos-left.dgm-variant-compact .dgm-feature-visual {
    left: 0;
    right: auto;
    width: 100%;
    clip-path: none;
  }


  .mod-divinggallerymenu .dgm-feature,
  .mod-divinggallerymenu.dgm-pos-left .dgm-feature {
    position: relative;
    inset: auto;
    grid-column: 1;
    min-height: min(76vh, var(--dgm-height));
  }

  .mod-divinggallerymenu .dgm-content,
  .mod-divinggallerymenu.dgm-pos-left .dgm-content {
    position: relative;
    top: auto;
    left: auto;
    right: auto;
    width: min(650px, 88%);
    margin-left: 6%;
    margin-right: auto;
    padding-top: 4rem;
    padding-bottom: 4rem;
  }

  .mod-divinggallerymenu .dgm-tiles,
  .mod-divinggallerymenu.dgm-pos-left .dgm-tiles {
    position: relative;
    top: auto;
    right: auto;
    bottom: auto;
    left: auto;
    width: 100%;
    height: auto;
    grid-column: 1;
    clip-path: none !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    grid-template-rows: minmax(170px, 1fr);
    gap: var(--dgm-line);
  }

  .mod-divinggallerymenu .dgm-tile,
  .mod-divinggallerymenu.dgm-pos-left .dgm-tile,
  .mod-divinggallerymenu.dgm-pos-right.dgm-variant-diagonal .dgm-tile,
  .mod-divinggallerymenu.dgm-pos-right.dgm-variant-compact .dgm-tile,
  .mod-divinggallerymenu.dgm-pos-left.dgm-variant-diagonal .dgm-tile,
  .mod-divinggallerymenu.dgm-pos-left.dgm-variant-compact .dgm-tile {
    justify-content: flex-start;
    text-align: left;
    padding: 1.35rem;
  }

  .mod-divinggallerymenu .dgm-tile-content {
    max-width: calc(100% - 60px);
  }

  .mod-divinggallerymenu .dgm-tile strong {
    font-size: clamp(1.35rem, 5vw, 2.6rem);
    white-space: normal;
    letter-spacing: min(var(--dgm-tile-letter), .04em);
  }

  .mod-divinggallerymenu .dgm-play,
  .mod-divinggallerymenu.dgm-pos-left .dgm-play {
    left: auto;
    right: 1rem;
  }

  .mod-divinggallerymenu .dgm-feature,
  .mod-divinggallerymenu.dgm-pos-left .dgm-feature {
    order: 1;
  }

  .mod-divinggallerymenu .dgm-tiles,
  .mod-divinggallerymenu.dgm-pos-left .dgm-tiles {
    order: 2;
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-above .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-above.dgm-pos-left .dgm-tiles {
    order: 0;
  }

  .mod-divinggallerymenu.dgm-hide-feature-mobile .dgm-feature,
  .mod-divinggallerymenu.dgm-hide-feature-mobile.dgm-pos-left .dgm-feature {
    display: none;
  }

  .mod-divinggallerymenu.dgm-hide-feature-mobile .dgm-tiles,
  .mod-divinggallerymenu.dgm-hide-feature-mobile.dgm-pos-left .dgm-tiles {
    order: 1;
    grid-column: 1 / -1;
    width: 100%;
  }
}

@media (min-width: 641px) and (max-width: 991.98px) {
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto .dgm-stage,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto .dgm-stage {
    grid-template-rows: auto;
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto .dgm-stage {
    grid-template-columns: minmax(0, 1fr) minmax(220px, 32%);
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto .dgm-stage {
    grid-template-columns: minmax(220px, 32%) minmax(0, 1fr);
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto .dgm-feature,
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-pos-left .dgm-feature {
    grid-column: 1;
    grid-row: 1;
    min-height: min(76vh, var(--dgm-height));
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-pos-left .dgm-tiles {
    grid-column: 2;
    grid-row: 1;
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto .dgm-feature,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-pos-left .dgm-feature {
    grid-column: 2;
    grid-row: 1;
    min-height: min(76vh, var(--dgm-height));
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-pos-left .dgm-tiles {
    grid-column: 1;
    grid-row: 1;
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-pos-left .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-pos-left .dgm-tiles {
    height: auto;
    grid-template-columns: 1fr;
    grid-template-rows: repeat(var(--dgm-small-count), minmax(0, 1fr));
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-hide-feature-mobile .dgm-stage,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-hide-feature-mobile .dgm-stage {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .mod-divinggallerymenu .dgm-feature,
  .mod-divinggallerymenu.dgm-pos-left .dgm-feature {
    min-height: 620px;
  }

  .mod-divinggallerymenu .dgm-content,
  .mod-divinggallerymenu.dgm-pos-left .dgm-content {
    width: min(88%, 520px);
    margin-left: 6%;
    padding-top: 3rem;
  }

  .mod-divinggallerymenu .dgm-title {
    font-size: clamp(2.55rem, 15vw, 4.4rem);
  }

  .mod-divinggallerymenu .dgm-small-title,
  .mod-divinggallerymenu .dgm-subtitle {
    font-size: clamp(1.45rem, 7vw, 2.3rem);
  }

  .mod-divinggallerymenu .dgm-primary {
    width: min(100%, 270px);
  }

  .mod-divinggallerymenu .dgm-tiles,
  .mod-divinggallerymenu.dgm-pos-left .dgm-tiles {
    grid-template-columns: 1fr;
    grid-template-rows: repeat(var(--dgm-small-count), minmax(150px, auto));
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-above .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-above.dgm-pos-left .dgm-tiles {
    order: 0;
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-pos-left .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-pos-left .dgm-tiles {
    order: 2;
  }
}

/* v1.1.5: intero box grande cliccabile con un solo link */
.mod-divinggallerymenu .dgm-feature-link {
  position: absolute;
  inset: 0;
  z-index: 3;
  display: block;
  cursor: pointer;
  text-decoration: none;
}

.mod-divinggallerymenu .dgm-content {
  pointer-events: none;
}

.mod-divinggallerymenu .dgm-tile {
  text-decoration: none;
}

.mod-divinggallerymenu .dgm-tile:hover,
.mod-divinggallerymenu .dgm-tile:focus-visible {
  color: var(--dgm-text);
  text-decoration: none;
}

.mod-divinggallerymenu .dgm-feature:hover .dgm-primary,
.mod-divinggallerymenu .dgm-feature:focus-within .dgm-primary {
  color: var(--dgm-button-text);
  filter: brightness(1.05);
  transform: translateY(-3px);
}

/* v1.2.6: sottotitolo box su righe separate gestite da backend e icona play opzionale da modulo. */
.mod-divinggallerymenu .dgm-tile-content {
  width: auto;
  max-width: none;
}

.mod-divinggallerymenu.dgm-show-play-icons .dgm-tile-content {
  max-width: calc(100% - clamp(55px, 8vw, 115px));
}

.mod-divinggallerymenu .dgm-tile-content em {
  display: block;
  white-space: nowrap;
  margin-top: .18rem;
}

.mod-divinggallerymenu .dgm-tile-content em + em {
  margin-top: .04rem;
}

/* v1.2.10: layout desktop sicuro quando si usa la posizione mobile "box a lato".
   Replica la logica mobile/tablet anche su PC: box piccoli rettangolari, niente taglio diagonale,
   testo non spezzato a una parola per riga, icona play gestita dal flag del modulo. */
.mod-divinggallerymenu:not(.dgm-show-play-icons) .dgm-play {
  display: none !important;
}

.mod-divinggallerymenu .dgm-tile-content em {
  display: block;
  white-space: nowrap;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: none;
}

@media (min-width: 992px) {
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto .dgm-stage,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto .dgm-stage {
    height: var(--dgm-height);
    min-height: var(--dgm-height);
    display: grid;
    grid-template-rows: auto;
    background: var(--dgm-line-color);
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto .dgm-stage {
    grid-template-columns: minmax(0, 1fr) minmax(260px, 36%);
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto .dgm-stage {
    grid-template-columns: minmax(260px, 36%) minmax(0, 1fr);
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto .dgm-stage::after,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto .dgm-stage::after {
    display: none !important;
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto .dgm-feature,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto .dgm-feature,
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-pos-left .dgm-feature,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-pos-left .dgm-feature {
    position: relative;
    inset: auto;
    min-height: var(--dgm-height);
    height: 100%;
    overflow: hidden;
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto .dgm-feature,
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-pos-left .dgm-feature {
    grid-column: 1;
    grid-row: 1;
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto .dgm-feature,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-pos-left .dgm-feature {
    grid-column: 2;
    grid-row: 1;
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto .dgm-feature-visual,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto .dgm-feature-visual,
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-pos-left .dgm-feature-visual,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-pos-left .dgm-feature-visual,
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-variant-diagonal .dgm-feature-visual,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-variant-diagonal .dgm-feature-visual,
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-variant-compact .dgm-feature-visual,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-variant-compact .dgm-feature-visual {
    left: 0 !important;
    right: auto !important;
    width: 100% !important;
    clip-path: none !important;
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto .dgm-content,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto .dgm-content,
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-pos-left .dgm-content,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-pos-left .dgm-content {
    left: var(--dgm-content-x);
    right: auto;
    width: min(650px, 88%);
    max-width: 88%;
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-pos-left .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-pos-left .dgm-tiles {
    position: relative;
    top: auto;
    bottom: auto;
    left: auto;
    right: auto;
    width: 100%;
    height: 100%;
    clip-path: none !important;
    grid-template-columns: 1fr;
    grid-template-rows: repeat(var(--dgm-small-count), minmax(0, 1fr));
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-pos-left .dgm-tiles {
    grid-column: 2;
    grid-row: 1;
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-pos-left .dgm-tiles {
    grid-column: 1;
    grid-row: 1;
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto .dgm-tile,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto .dgm-tile,
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-pos-left .dgm-tile,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-pos-left .dgm-tile,
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-variant-diagonal .dgm-tile,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-variant-diagonal .dgm-tile,
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-variant-compact .dgm-tile,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-variant-compact .dgm-tile {
    justify-content: flex-start;
    text-align: left;
    padding: 1.35rem !important;
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto .dgm-tile-content,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto .dgm-tile-content {
    width: 100%;
    min-width: 0;
    max-width: 100% !important;
  }

  .mod-divinggallerymenu.dgm-show-play-icons.dgm-mobile-tiles-right-auto .dgm-tile-content,
  .mod-divinggallerymenu.dgm-show-play-icons.dgm-mobile-tiles-left-auto .dgm-tile-content {
    max-width: calc(100% - 60px) !important;
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto .dgm-tile strong,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto .dgm-tile strong {
    white-space: nowrap;
    overflow-wrap: normal;
    word-break: normal;
    hyphens: none;
    font-size: clamp(1.35rem, 2.1vw, 2.8rem);
    letter-spacing: min(var(--dgm-tile-letter), .04em);
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto .dgm-tile-content em,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto .dgm-tile-content em {
    font-size: clamp(.72rem, .85vw, 1rem);
    line-height: 1.18;
    letter-spacing: .01em;
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto .dgm-play,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto .dgm-play,
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-pos-left .dgm-play,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-pos-left .dgm-play {
    left: auto;
    right: 1rem;
  }
}

/* v1.2.14: box piccoli dinamici.
   La colonna laterale si divide automaticamente in base al numero reale di voci pubblicate:
   2 voci = 50/50, 3 = terzi, 6 = sesti. Nessun terzo box vuoto. */
.mod-divinggallerymenu .dgm-tiles {
  grid-template-rows: repeat(var(--dgm-small-count), minmax(0, 1fr));
}

@media (min-width: 992px) {
  .mod-divinggallerymenu .dgm-tile {
    padding-top: clamp(.55rem, calc(2.2rem / var(--dgm-small-count)), 1.4rem);
    padding-bottom: clamp(.55rem, calc(2.2rem / var(--dgm-small-count)), 1.4rem);
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-pos-left .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-pos-left .dgm-tiles {
    grid-template-rows: repeat(var(--dgm-small-count), minmax(0, 1fr)) !important;
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto .dgm-tile,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto .dgm-tile,
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-pos-left .dgm-tile,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-pos-left .dgm-tile,
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-variant-diagonal .dgm-tile,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-variant-diagonal .dgm-tile,
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-variant-compact .dgm-tile,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-variant-compact .dgm-tile {
    padding: clamp(.55rem, calc(2.4rem / var(--dgm-small-count)), 1.25rem) clamp(.75rem, 2vw, 1.35rem) !important;
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto .dgm-tile strong,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto .dgm-tile strong {
    font-size: clamp(1.05rem, calc(5.9vw / var(--dgm-small-count)), 2.65rem);
    line-height: .98;
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto .dgm-tile-content em,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto .dgm-tile-content em {
    font-size: clamp(.62rem, calc(2.35vw / var(--dgm-small-count)), .98rem);
    line-height: 1.08;
  }
}

@media (max-width: 640px) {
  .mod-divinggallerymenu .dgm-tiles,
  .mod-divinggallerymenu.dgm-pos-left .dgm-tiles {
    grid-template-rows: repeat(var(--dgm-small-count), minmax(150px, auto));
  }
}


/* v1.3.5: posizione configurabile icona play/video nei box piccoli. */
.mod-divinggallerymenu.dgm-play-pos-bottom-left .dgm-play,
.mod-divinggallerymenu.dgm-play-pos-bottom-left.dgm-pos-left .dgm-play {
  left: .85rem;
  right: auto;
  top: auto;
  bottom: .85rem;
  transform: none;
  width: clamp(34px, 3.2vw, 54px);
  height: clamp(34px, 3.2vw, 54px);
}

.mod-divinggallerymenu.dgm-play-pos-top-right .dgm-play,
.mod-divinggallerymenu.dgm-play-pos-top-right.dgm-pos-left .dgm-play {
  left: auto;
  right: .85rem;
  top: .85rem;
  bottom: auto;
  transform: none;
}

.mod-divinggallerymenu.dgm-play-pos-center-right .dgm-play {
  left: auto;
  right: clamp(1rem, 3vw, 3rem);
  top: 50%;
  bottom: auto;
  transform: translateY(-50%);
}

.mod-divinggallerymenu.dgm-play-pos-center-right.dgm-pos-left .dgm-play {
  right: auto;
  left: clamp(1rem, 3vw, 3rem);
}

@media (min-width: 992px) {
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-play-pos-bottom-left .dgm-play,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-play-pos-bottom-left .dgm-play,
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-pos-left.dgm-play-pos-bottom-left .dgm-play,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-pos-left.dgm-play-pos-bottom-left .dgm-play {
    left: .85rem;
    right: auto;
    top: auto;
    bottom: .85rem;
    transform: none;
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-play-pos-top-right .dgm-play,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-play-pos-top-right .dgm-play,
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-pos-left.dgm-play-pos-top-right .dgm-play,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-pos-left.dgm-play-pos-top-right .dgm-play {
    left: auto;
    right: .85rem;
    top: .85rem;
    bottom: auto;
    transform: none;
  }
}


/* v1.3.6: padding laterale icona play/video nei box piccoli.
   Evita che l'icona resti attaccata al bordo/diagonale quando è in basso a sinistra. */
.mod-divinggallerymenu {
  --dgm-play-edge-x: clamp(1.35rem, 2.6vw, 2.4rem);
  --dgm-play-edge-y: clamp(1rem, 1.8vw, 1.55rem);
}

.mod-divinggallerymenu.dgm-play-pos-bottom-left .dgm-play,
.mod-divinggallerymenu.dgm-play-pos-bottom-left.dgm-pos-left .dgm-play {
  left: var(--dgm-play-edge-x) !important;
  right: auto !important;
  top: auto !important;
  bottom: var(--dgm-play-edge-y) !important;
  transform: none !important;
}

.mod-divinggallerymenu.dgm-play-pos-top-right .dgm-play,
.mod-divinggallerymenu.dgm-play-pos-top-right.dgm-pos-left .dgm-play {
  left: auto !important;
  right: var(--dgm-play-edge-x) !important;
  top: var(--dgm-play-edge-y) !important;
  bottom: auto !important;
  transform: none !important;
}

.mod-divinggallerymenu.dgm-play-pos-center-right .dgm-play {
  left: auto !important;
  right: var(--dgm-play-edge-x) !important;
}

.mod-divinggallerymenu.dgm-play-pos-center-right.dgm-pos-left .dgm-play {
  right: auto !important;
  left: var(--dgm-play-edge-x) !important;
}

@media (min-width: 992px) {
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-play-pos-bottom-left .dgm-play,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-play-pos-bottom-left .dgm-play,
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-pos-left.dgm-play-pos-bottom-left .dgm-play,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-pos-left.dgm-play-pos-bottom-left .dgm-play {
    left: var(--dgm-play-edge-x) !important;
    right: auto !important;
    top: auto !important;
    bottom: var(--dgm-play-edge-y) !important;
    transform: none !important;
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-play-pos-top-right .dgm-play,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-play-pos-top-right .dgm-play,
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-pos-left.dgm-play-pos-top-right .dgm-play,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-pos-left.dgm-play-pos-top-right .dgm-play {
    left: auto !important;
    right: var(--dgm-play-edge-x) !important;
    top: var(--dgm-play-edge-y) !important;
    bottom: auto !important;
    transform: none !important;
  }
}

/* v1.3.7: icona fotocamera nei box piccoli, stessa dimensione/posizione del play. */
.mod-divinggallerymenu .dgm-icon-camera::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 53%;
  width: 1.42em;
  height: .92em;
  border: .18em solid var(--dgm-text);
  border-radius: .14em;
  background: transparent;
  transform: translate(-50%, -50%);
  font-size: clamp(14px, 1.6vw, 22px);
}

.mod-divinggallerymenu .dgm-icon-camera::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 56%;
  width: .48em;
  height: .48em;
  border: .17em solid var(--dgm-text);
  border-radius: 999px;
  transform: translate(-50%, -50%);
  z-index: 1;
  font-size: clamp(14px, 1.6vw, 22px);
}

.mod-divinggallerymenu .dgm-icon-camera {
  /* tettuccio della macchina fotografica */
  box-shadow: inset 0 0 0 999px rgba(0,0,0,.02);
}

.mod-divinggallerymenu .dgm-icon-camera > span {
  display: none;
}


/* v1.3.9: fix griglia mobile/tablet: niente righe/celle vuote.
   Quando i box piccoli sono sopra/sotto, la griglia crea solo le righe necessarie.
   Quando sono a lato in mobile, resta una colonna verticale dinamica. */
@media (max-width: 991.98px) {
  .mod-divinggallerymenu:not(.dgm-mobile-tiles-right-auto):not(.dgm-mobile-tiles-left-auto) .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-above .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-below .dgm-tiles,
  .mod-divinggallerymenu.dgm-hide-feature-mobile .dgm-tiles {
    height: auto !important;
    min-height: 0 !important;
    grid-template-rows: minmax(118px, auto) !important;
    grid-auto-rows: minmax(118px, auto) !important;
    align-content: stretch !important;
  }

  .mod-divinggallerymenu.dgm-small-count-1:not(.dgm-mobile-tiles-right-auto):not(.dgm-mobile-tiles-left-auto) .dgm-tiles,
  .mod-divinggallerymenu.dgm-small-count-1.dgm-mobile-tiles-above .dgm-tiles,
  .mod-divinggallerymenu.dgm-small-count-1.dgm-mobile-tiles-below .dgm-tiles,
  .mod-divinggallerymenu.dgm-small-count-1.dgm-hide-feature-mobile .dgm-tiles {
    grid-template-columns: 1fr !important;
  }

  .mod-divinggallerymenu.dgm-small-count-2:not(.dgm-mobile-tiles-right-auto):not(.dgm-mobile-tiles-left-auto) .dgm-tiles,
  .mod-divinggallerymenu.dgm-small-count-2.dgm-mobile-tiles-above .dgm-tiles,
  .mod-divinggallerymenu.dgm-small-count-2.dgm-mobile-tiles-below .dgm-tiles,
  .mod-divinggallerymenu.dgm-small-count-2.dgm-hide-feature-mobile .dgm-tiles {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .mod-divinggallerymenu.dgm-small-count-3:not(.dgm-mobile-tiles-right-auto):not(.dgm-mobile-tiles-left-auto) .dgm-tiles,
  .mod-divinggallerymenu.dgm-small-count-3.dgm-mobile-tiles-above .dgm-tiles,
  .mod-divinggallerymenu.dgm-small-count-3.dgm-mobile-tiles-below .dgm-tiles,
  .mod-divinggallerymenu.dgm-small-count-3.dgm-hide-feature-mobile .dgm-tiles {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }

  .mod-divinggallerymenu.dgm-small-count-4:not(.dgm-mobile-tiles-right-auto):not(.dgm-mobile-tiles-left-auto) .dgm-tiles,
  .mod-divinggallerymenu.dgm-small-count-4.dgm-mobile-tiles-above .dgm-tiles,
  .mod-divinggallerymenu.dgm-small-count-4.dgm-mobile-tiles-below .dgm-tiles,
  .mod-divinggallerymenu.dgm-small-count-4.dgm-hide-feature-mobile .dgm-tiles {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .mod-divinggallerymenu.dgm-small-count-5:not(.dgm-mobile-tiles-right-auto):not(.dgm-mobile-tiles-left-auto) .dgm-tiles,
  .mod-divinggallerymenu.dgm-small-count-5.dgm-mobile-tiles-above .dgm-tiles,
  .mod-divinggallerymenu.dgm-small-count-5.dgm-mobile-tiles-below .dgm-tiles,
  .mod-divinggallerymenu.dgm-small-count-5.dgm-hide-feature-mobile .dgm-tiles,
  .mod-divinggallerymenu.dgm-small-count-6:not(.dgm-mobile-tiles-right-auto):not(.dgm-mobile-tiles-left-auto) .dgm-tiles,
  .mod-divinggallerymenu.dgm-small-count-6.dgm-mobile-tiles-above .dgm-tiles,
  .mod-divinggallerymenu.dgm-small-count-6.dgm-mobile-tiles-below .dgm-tiles,
  .mod-divinggallerymenu.dgm-small-count-6.dgm-hide-feature-mobile .dgm-tiles {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-pos-left .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-pos-left .dgm-tiles {
    grid-template-columns: 1fr !important;
    grid-template-rows: repeat(var(--dgm-small-count), minmax(0, 1fr)) !important;
    grid-auto-rows: auto !important;
    min-height: 0 !important;
  }
}

@media (max-width: 640px) {
  .mod-divinggallerymenu:not(.dgm-mobile-tiles-right-auto):not(.dgm-mobile-tiles-left-auto) .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-above .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-below .dgm-tiles,
  .mod-divinggallerymenu.dgm-hide-feature-mobile .dgm-tiles {
    grid-template-rows: minmax(104px, auto) !important;
    grid-auto-rows: minmax(104px, auto) !important;
  }
}


/* v1.3.11: fix definitivo griglia mobile senza celle vuote.
   Per i box piccoli sopra/sotto o quando il box grande mobile è nascosto,
   non usiamo più CSS Grid: usiamo flex-wrap, così esistono solo i box reali stampati da Joomla.
   Risultato: 3 voci = 3 box, 2 voci = 2 box, 6 voci = 6 box, zero celle vuote. */
@media (max-width: 991.98px) {
  .mod-divinggallerymenu.dgm-mobile-tiles-above .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-below .dgm-tiles,
  .mod-divinggallerymenu.dgm-hide-feature-mobile .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-above.dgm-pos-left .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-below.dgm-pos-left .dgm-tiles,
  .mod-divinggallerymenu.dgm-hide-feature-mobile.dgm-pos-left .dgm-tiles {
    position: relative !important;
    top: auto !important;
    right: auto !important;
    bottom: auto !important;
    left: auto !important;
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: stretch !important;
    align-content: flex-start !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    overflow: visible !important;
    clip-path: none !important;
    gap: var(--dgm-line) !important;
    background: var(--dgm-line-color) !important;
    grid-template-columns: none !important;
    grid-template-rows: none !important;
    grid-auto-rows: auto !important;
  }

  .mod-divinggallerymenu.dgm-mobile-tiles-above .dgm-tile,
  .mod-divinggallerymenu.dgm-mobile-tiles-below .dgm-tile,
  .mod-divinggallerymenu.dgm-hide-feature-mobile .dgm-tile,
  .mod-divinggallerymenu.dgm-mobile-tiles-above.dgm-pos-left .dgm-tile,
  .mod-divinggallerymenu.dgm-mobile-tiles-below.dgm-pos-left .dgm-tile,
  .mod-divinggallerymenu.dgm-hide-feature-mobile.dgm-pos-left .dgm-tile {
    flex: 1 1 calc(33.333% - var(--dgm-line)) !important;
    min-width: 0 !important;
    min-height: 118px !important;
    height: auto !important;
  }

  .mod-divinggallerymenu.dgm-small-count-1.dgm-mobile-tiles-above .dgm-tile,
  .mod-divinggallerymenu.dgm-small-count-1.dgm-mobile-tiles-below .dgm-tile,
  .mod-divinggallerymenu.dgm-small-count-1.dgm-hide-feature-mobile .dgm-tile {
    flex-basis: 100% !important;
  }

  .mod-divinggallerymenu.dgm-small-count-2.dgm-mobile-tiles-above .dgm-tile,
  .mod-divinggallerymenu.dgm-small-count-2.dgm-mobile-tiles-below .dgm-tile,
  .mod-divinggallerymenu.dgm-small-count-2.dgm-hide-feature-mobile .dgm-tile {
    flex-basis: calc(50% - var(--dgm-line)) !important;
  }

  .mod-divinggallerymenu.dgm-small-count-3.dgm-mobile-tiles-above .dgm-tile,
  .mod-divinggallerymenu.dgm-small-count-3.dgm-mobile-tiles-below .dgm-tile,
  .mod-divinggallerymenu.dgm-small-count-3.dgm-hide-feature-mobile .dgm-tile {
    flex-basis: calc(33.333% - var(--dgm-line)) !important;
  }

  .mod-divinggallerymenu.dgm-small-count-4.dgm-mobile-tiles-above .dgm-tile,
  .mod-divinggallerymenu.dgm-small-count-4.dgm-mobile-tiles-below .dgm-tile,
  .mod-divinggallerymenu.dgm-small-count-4.dgm-hide-feature-mobile .dgm-tile {
    flex-basis: calc(50% - var(--dgm-line)) !important;
  }

  .mod-divinggallerymenu.dgm-small-count-5.dgm-mobile-tiles-above .dgm-tile,
  .mod-divinggallerymenu.dgm-small-count-5.dgm-mobile-tiles-below .dgm-tile,
  .mod-divinggallerymenu.dgm-small-count-5.dgm-hide-feature-mobile .dgm-tile,
  .mod-divinggallerymenu.dgm-small-count-6.dgm-mobile-tiles-above .dgm-tile,
  .mod-divinggallerymenu.dgm-small-count-6.dgm-mobile-tiles-below .dgm-tile,
  .mod-divinggallerymenu.dgm-small-count-6.dgm-hide-feature-mobile .dgm-tile {
    flex-basis: calc(33.333% - var(--dgm-line)) !important;
  }

  /* Se i box piccoli sono veramente a lato e il box grande è visibile, resta la colonna verticale. */
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto:not(.dgm-hide-feature-mobile) .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto:not(.dgm-hide-feature-mobile) .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-right-auto.dgm-pos-left:not(.dgm-hide-feature-mobile) .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-left-auto.dgm-pos-left:not(.dgm-hide-feature-mobile) .dgm-tiles {
    display: grid !important;
    overflow: hidden !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: repeat(var(--dgm-small-count), minmax(0, 1fr)) !important;
    grid-auto-rows: auto !important;
  }
}

@media (max-width: 640px) {
  .mod-divinggallerymenu.dgm-mobile-tiles-above .dgm-tile,
  .mod-divinggallerymenu.dgm-mobile-tiles-below .dgm-tile,
  .mod-divinggallerymenu.dgm-hide-feature-mobile .dgm-tile {
    min-height: 104px !important;
  }
}


/* v1.3.11 extra guard: se in backend il box grande mobile è spento, i box piccoli non devono mai mantenere la griglia 3x3. */
@media (max-width: 991.98px) {
  .mod-divinggallerymenu.dgm-hide-feature-mobile .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-above .dgm-tiles,
  .mod-divinggallerymenu.dgm-mobile-tiles-below .dgm-tiles {
    position: relative !important;
    top: auto !important;
    right: auto !important;
    bottom: auto !important;
    left: auto !important;
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: stretch !important;
    align-content: flex-start !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    overflow: visible !important;
    clip-path: none !important;
    grid-template-columns: none !important;
    grid-template-rows: none !important;
    grid-auto-rows: auto !important;
  }

  .mod-divinggallerymenu.dgm-hide-feature-mobile .dgm-tile,
  .mod-divinggallerymenu.dgm-mobile-tiles-above .dgm-tile,
  .mod-divinggallerymenu.dgm-mobile-tiles-below .dgm-tile {
    min-height: 104px !important;
    height: auto !important;
    min-width: 0 !important;
  }

  .mod-divinggallerymenu.dgm-small-count-1 .dgm-tile {
    flex: 1 1 100% !important;
  }

  .mod-divinggallerymenu.dgm-small-count-2 .dgm-tile {
    flex: 1 1 calc(50% - var(--dgm-line)) !important;
  }

  .mod-divinggallerymenu.dgm-small-count-3 .dgm-tile {
    flex: 1 1 calc(33.333% - var(--dgm-line)) !important;
  }

  .mod-divinggallerymenu.dgm-small-count-4 .dgm-tile {
    flex: 1 1 calc(50% - var(--dgm-line)) !important;
  }

  .mod-divinggallerymenu.dgm-small-count-5 .dgm-tile,
  .mod-divinggallerymenu.dgm-small-count-6 .dgm-tile {
    flex: 1 1 calc(33.333% - var(--dgm-line)) !important;
  }
}

/* v1.3.12: fix reale celle vuote quando il box grande è nascosto.
   Il problema non era il numero di voci: Joomla stampa solo i link reali.
   Il vuoto era causato da stage/tiles ancora alti e da grid-template-rows dinamico.
   Qui, quando il box grande è nascosto, stage e tiles diventano auto-height e i box usano flex-wrap. */
@media (max-width: 991.98px) {
  .mod-divinggallerymenu.dgm-hide-feature-mobile .dgm-stage,
  .mod-divinggallerymenu.dgm-hide-feature-mobile.dgm-pos-left .dgm-stage {
    display: block !important;
    height: auto !important;
    min-height: 0 !important;
    background: transparent !important;
  }

  .mod-divinggallerymenu.dgm-hide-feature-mobile .dgm-tiles,
  .mod-divinggallerymenu.dgm-hide-feature-mobile.dgm-pos-left .dgm-tiles {
    position: relative !important;
    inset: auto !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    bottom: auto !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: stretch !important;
    align-content: flex-start !important;
    gap: var(--dgm-line) !important;
    overflow: visible !important;
    clip-path: none !important;
    background: var(--dgm-line-color) !important;
    grid-template-columns: none !important;
    grid-template-rows: none !important;
    grid-auto-rows: auto !important;
  }

  .mod-divinggallerymenu.dgm-hide-feature-mobile .dgm-tile,
  .mod-divinggallerymenu.dgm-hide-feature-mobile.dgm-pos-left .dgm-tile {
    position: relative !important;
    height: auto !important;
    min-height: 104px !important;
    min-width: 0 !important;
    clip-path: none !important;
  }

  .mod-divinggallerymenu.dgm-hide-feature-mobile.dgm-small-count-1 .dgm-tile {
    flex: 1 1 100% !important;
  }

  .mod-divinggallerymenu.dgm-hide-feature-mobile.dgm-small-count-2 .dgm-tile {
    flex: 1 1 calc(50% - var(--dgm-line)) !important;
  }

  .mod-divinggallerymenu.dgm-hide-feature-mobile.dgm-small-count-3 .dgm-tile {
    flex: 1 1 calc(33.333% - var(--dgm-line)) !important;
  }

  .mod-divinggallerymenu.dgm-hide-feature-mobile.dgm-small-count-4 .dgm-tile {
    flex: 1 1 calc(50% - var(--dgm-line)) !important;
  }

  .mod-divinggallerymenu.dgm-hide-feature-mobile.dgm-small-count-5 .dgm-tile,
  .mod-divinggallerymenu.dgm-hide-feature-mobile.dgm-small-count-6 .dgm-tile {
    flex: 1 1 calc(33.333% - var(--dgm-line)) !important;
  }
}

/* Stessa correzione per PC/tablet larghi quando è spento il box grande desktop. */
@media (min-width: 992px) {
  .mod-divinggallerymenu.dgm-hide-feature-desktop .dgm-stage,
  .mod-divinggallerymenu.dgm-hide-feature-desktop.dgm-pos-left .dgm-stage {
    display: block !important;
    height: auto !important;
    min-height: 0 !important;
    background: transparent !important;
  }

  .mod-divinggallerymenu.dgm-hide-feature-desktop .dgm-tiles,
  .mod-divinggallerymenu.dgm-hide-feature-desktop.dgm-pos-left .dgm-tiles {
    position: relative !important;
    inset: auto !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    bottom: auto !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: stretch !important;
    align-content: flex-start !important;
    gap: var(--dgm-line) !important;
    overflow: visible !important;
    clip-path: none !important;
    background: var(--dgm-line-color) !important;
    grid-template-columns: none !important;
    grid-template-rows: none !important;
    grid-auto-rows: auto !important;
  }

  .mod-divinggallerymenu.dgm-hide-feature-desktop .dgm-tile,
  .mod-divinggallerymenu.dgm-hide-feature-desktop.dgm-pos-left .dgm-tile {
    position: relative !important;
    height: auto !important;
    min-height: 128px !important;
    min-width: 0 !important;
    clip-path: none !important;
  }

  .mod-divinggallerymenu.dgm-hide-feature-desktop.dgm-small-count-1 .dgm-tile {
    flex: 1 1 100% !important;
  }

  .mod-divinggallerymenu.dgm-hide-feature-desktop.dgm-small-count-2 .dgm-tile {
    flex: 1 1 calc(50% - var(--dgm-line)) !important;
  }

  .mod-divinggallerymenu.dgm-hide-feature-desktop.dgm-small-count-3 .dgm-tile {
    flex: 1 1 calc(33.333% - var(--dgm-line)) !important;
  }

  .mod-divinggallerymenu.dgm-hide-feature-desktop.dgm-small-count-4 .dgm-tile {
    flex: 1 1 calc(50% - var(--dgm-line)) !important;
  }

  .mod-divinggallerymenu.dgm-hide-feature-desktop.dgm-small-count-5 .dgm-tile,
  .mod-divinggallerymenu.dgm-hide-feature-desktop.dgm-small-count-6 .dgm-tile {
    flex: 1 1 calc(33.333% - var(--dgm-line)) !important;
  }
}
