/* ==========================================================================
   dettaglio_annuncio.css
   Stili importati 1:1 dai blocchi <style> inline del template
   0vb_net_sito/dettaglio_annuncio_adv6971.html
   ========================================================================== */

/* ---------- Blocco 1 (template L6-42): dropdown e modale --------------- */
.modal-dialog { pointer-events: all; }

@media all and (min-width: 992px) {
  .dropdown-menu li { position: relative; }
  .dropdown-menu .submenu {
    display: none;
    position: absolute;
    left: 100%;
    top: -7px;
  }
  .dropdown-menu .submenu-left {
    right: 100%;
    left: auto;
  }
  .dropdown-menu > li:hover { background-color: #f1f1f1; }
  .dropdown-menu > li:hover > .submenu { display: block; }
}

@media (max-width: 991px) {
  .dropdown-menu .dropdown-menu {
    margin-left: 0.7rem;
    margin-bottom: 0.5rem;
  }
}

/* ---------- Blocco 2 (template L315-493): mappa, bottoni, gallery ------ */
.google-maps {
  position: relative;
  padding-bottom: 75%;
  overflow: hidden;
}
.google-maps iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100% !important;
  height: 100% !important;
}

.image_fade {
  margin-bottom: 10px;
  margin-right: 10px;
  margin-left: 10px;
}

textarea { margin-top: 20px; }

.btn-large {
  padding: .5rem 1rem !important;
  font-size: 1.25rem !important;
  line-height: 1.5 !important;
  border-radius: .3rem !important;
}

.btn-newdanger {
  color: #fff !important;
  background-color: #dc3545 !important;
  border-color: #dc3545 !important;
}
.btn-newdanger:hover {
  color: #fff !important;
  background-color: #c82333 !important;
  border-color: #bd2130 !important;
}

.btn-newprimary {
  color: #fff !important;
  background-color: #007bff !important;
  border-color: #007bff !important;
}
.btn-newprimary:hover {
  color: #fff !important;
  background-color: #0069d9 !important;
  border-color: #0062cc !important;
}

@media (max-width: 767px) {
  .portfolio-filter li {
    width: 50% !important;
    margin: 0 0 20px 0 !important;
  }
  .cell {
    border: 0;
    padding: 0;
  }
  #page-title.page-title-dark { padding: 0 0 5px !important; }
  #page-title.page-title-dark h1 { margin: 0; }
  #page-title.page-title-dark h3 { margin: 0; }
}

@media (max-width: 575px) {
  .portfolio-filter li {
    width: 50% !important;
    margin: 0 0 20px 0 !important;
  }
  #page-title.page-title-dark h3 a.return {
    font-size: 16px;
    color: #fff;
    font-weight: 300;
  }
  #page-title.page-title-dark {
    padding: 0 0 5px !important;
    padding-top: 20px !important;
    padding-right: 0 !important;
    padding-bottom: 5px !important;
    padding-left: 0 !important;
    margin-top: 0 !important;
  }
  #page-title.page-title-dark h1 { margin-bottom: 0 !important; }
}

.listaIternaScheda li { margin-left: 10px; }

.telH { display: none !important; }

#page-title.page-title-dark span.return { font-size: 16px; }
#page-title.page-title-dark h1 { font-weight: 500; }

img.img-fluid {
  border: solid 2px #c91c1c;
  border-radius: 10px;
}

/* Il logo dell'header non deve avere il bordo rosso */
#logo img.img-fluid,
header .standard-logo img.img-fluid,
#footer img.img-fluid {
  border: 0;
  border-radius: 0;
}

a.disabled img {
  filter: grayscale(100%) brightness(0.4);
  opacity: 0.3;
  pointer-events: none;
}
a.disabled {
  pointer-events: none;
  cursor: default;
}

.gallery-overlay-tile { position: relative; }
.gallery-overlay-tile .gallery-overlay-veil {
  position: absolute;
  inset: 0;
  background: rgba(128, 128, 128, 0.55);
}
.gallery-overlay-tile .gallery-overlay-label {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  color: #fff;
  font-weight: 700;
  padding: .6rem 1rem;
  border-radius: .5rem;
  background: rgba(0, 0, 0, .5);
  letter-spacing: .3px;
}

/* ---------- Blocco 3 (template L590-756): sticky mobile + nav contact -- */
.nav_contact {
  position: relative;
  top: 0;
  background: none;
  z-index: 7999;
}

#nav_contact {
  width: 100%;
  background: #fe0000;
  color: #fff;
  font-size: 1.4em;
  font-weight: 200;
  line-height: 20px;
}

.nav_contact a {
  color: #fff;
  font-weight: 500;
  line-height: 20px;
}
.nav_contact a:hover { color: #ddd; }

.nav_contact ul {
  width: 100%;
  height: 100%;
  background: none;
  line-height: 20px;
  text-align: center;
  list-style-type: none;
  padding-left: 0;
  margin-left: 0;
}

.nav_contact li {
  display: inline-block;
  text-align: center;
  background: none;
  padding: 10px 20px;
  list-style-type: none;
}

.sticky_mobile {
  position: fixed;
  top: 68px;
  background: none;
  width: 100%;
}
.sticky_mobile + .content {
  top: 92px;
  padding-top: 60px;
}

@media (min-width: 200px) {
  .nav_contact li { padding: 25px 5px; }
}
@media (min-width: 300px) {
  .nav_contact li { padding: 25px 5px; }
}
@media (min-width: 400px) {
  .sticky_mobile { top: 66px; }
  #nav_contact { font-size: 1.7em; }
  .nav_contact li { padding: 10px 10px; }
}
@media (min-width: 501px) {
  .sticky_mobile { top: 73px; }
  #nav_contact { font-size: 1.7em; }
}
@media (min-width: 558px) {
  .sticky_mobile { top: 77px; }
}
@media (min-width: 601px) {
  #nav_contact { font-size: 1.7em; }
  .nav_contact li { padding: 25px 20px; }
}
@media (min-width: 768px) {
  #nav_contact { font-size: 1.9em; }
}

.link-button-style {
  display: inline-block;
  background-color: #007bff;
  color: #fff;
  padding: 10px 20px;
  text-decoration: none;
  font-weight: bold;
  border-radius: 5px;
  transition: background-color 0.3s ease;
}
.link-button-style:hover {
  background-color: #0056b3;
  text-decoration: none;
}

.mobileButton {
  white-space: normal !important;
  word-break: break-word;
  line-height: 1.4 !important;
  height: auto !important;
  padding-top: 10px !important;
  padding-bottom: 10px !important;
}

/* ==========================================================================
   Aggiunte per il layout PHP rifatto sul template
   ========================================================================== */

/* Hero / Intro: SOLO wrapper additivo, NON sovrascrivo background o colori
   del contenitore .escort-dett-container che ha già il proprio dark theme + text-white. */
.annuncio-intro {
  padding: 0;
  background: transparent;
}
.annuncio-intro .copertina-wrap {
  position: relative;
  display: inline-block;
  width: 100%;
  max-width: 480px;
}
.annuncio-intro .copertina-wrap img {
  width: 100%;
  height: auto;
  border-radius: 10px;
  display: block;
}
.annuncio-intro .copertina-wrap .lente {
  position: absolute;
  right: 12px;
  bottom: 12px;
  background: rgba(0, 0, 0, .55);
  color: #fff;
  border-radius: 50%;
  width: 42px;
  height: 42px;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

/* Descrizione spostata nell'hero a fianco delle info */
.annuncio-intro .escort-dett-desc {
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,.15);
}
.annuncio-intro .escort-dett-desc #p_titolo {
  font-size: 1.1em;
  font-weight: 600;
  margin: 0 0 8px 0;
  color: inherit;
}
.annuncio-intro .escort-dett-desc #p_testo {
  margin: 0;
  line-height: 1.55;
  color: inherit;
  white-space: normal;
}
.annuncio-intro .escort-dett-desc #translate_btn {
  margin-top: 6px;
  font-size: .9em;
  opacity: .8;
}

/* Sezione dettaglio tabs - additiva, niente background overrides */
#tab-dettaglio {
  padding: 30px 0 10px 0;
  background: transparent;
}
#tab-dettaglio h2.section-title {
  color: #b9141d !important;
  font-weight: 600;
  line-height: 1.3;
  font-size: 1.4em;
  text-align: left;
}
#tab-dettaglio .tab-nav2 {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-start;
  list-style: none;
  padding: 0 0 14px 0;
  margin: 0 0 22px 0;
  border-bottom: 1px solid #d0d0d0;
}
#tab-dettaglio .tab-nav2 .nav-item { list-style: none; }
#tab-dettaglio .tab-nav2 .nav-link {
  background: #d9d9d9;
  color: #222;
  border: 1px solid #bdbdbd;
  padding: 0 22px;
  height: 40px;
  line-height: 40px;
  font-weight: 700;
  font-size: 0.95rem;
  cursor: pointer;
  transition: all .15s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}
#tab-dettaglio .tab-nav2 .nav-link span {
  display: inline-block;
  line-height: 1;
}
#tab-dettaglio .tab-nav2 .nav-link:hover {
  background: #c9c9c9;
  color: #111;
  border-color: #b9141d;
}
#tab-dettaglio .tab-nav2 .nav-link.active {
  background: #b9141d !important;
  color: #fff !important;
  border-color: #b9141d !important;
}
#tab-dettaglio .tab-pane h4 {
  color: #b9141d;
  font-weight: 400;
  font-size: 1.6em;
}

/* Gallery come sezione standalone, additiva al markup esistente */
#gallery-dettaglio {
  padding: 20px 0 30px 0;
  background: transparent;
}
#gallery-dettaglio h2.section-title {
  color: #fff;
  font-weight: 400;
  line-height: 1.5;
  margin: 0 0 20px 0;
  font-size: 2em;
  text-align: center;
}

/* Video */
#content_pnlVideo {
  background: #fff;
  padding: 40px 0;
}
#content_pnlVideo h2 {
  color: #b9141d;
  font-weight: 400;
  line-height: 1.5;
  font-size: 2.5em;
  text-align: center;
  margin: 0 0 30px 0;
}
#content_videoContainer video {
  width: 100%;
  height: auto;
  border-radius: 10px;
  display: block;
}

/* Commenti */
.annuncio-commenti,
.annuncio-commenti-mobile {
  padding: 40px 0;
  background: #fff;
}
.annuncio-commenti h2,
.annuncio-commenti-mobile h2 {
  color: #b9141d;
  font-weight: 400;
  line-height: 1.5;
  margin: 0 0 30px 0;
  font-size: 2.5em;
  text-align: center;
}
ol.commentlist {
  list-style: none;
  padding: 0;
  margin: 0;
}

/* Sezioni mobile dettaglio (accordion-like) */
.annuncio-dettaglio-mobile .section-mobile {
  padding: 30px 15px;
}
.annuncio-dettaglio-mobile .section-mobile.alt {
  background: #f5dedf;
}
.annuncio-dettaglio-mobile .section-mobile.gray {
  background: #f5f5f5;
}
.annuncio-dettaglio-mobile h2 {
  color: #b9141d;
  font-weight: 300;
  line-height: 1.5;
  margin: 0 0 20px 0;
  font-size: 2em;
  text-align: center;
}

/* Mappa mobile */
.annuncio-mappa-mobile {
  background: #f5f5f5;
  padding: 30px 0;
  text-align: center;
}
.annuncio-mappa-mobile iframe,
.annuncio-mappa-mobile #map {
  width: 100%;
  height: 400px;
  border: 0;
  border-radius: 10px;
}

/* CTA proprietario */
.annuncio-promo {
  background: #303030;
  color: #fff;
  text-align: center;
  text-transform: uppercase;
  padding: 30px 15px;
}
.annuncio-promo .button-rounded {
  display: inline-block;
  background: #b9141d;
  color: #fff;
  padding: 12px 28px;
  border-radius: 200px;
  margin-top: 12px;
  font-weight: 600;
  text-decoration: none;
}

/* Riga specifiche */
.dett-row { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.dett-col-int { display: inline-flex; gap: 6px; align-items: center; margin: 4px 8px 4px 0; }
.spec-value { background: #f1f1f1; padding: 4px 10px; border-radius: 6px; }

/* ==========================================================================
   OVERRIDE TEMA CHIARO sui contenitori del nuovo layout.
   Il markup originale usa .escort-dett-container.text-white (dark theme +
   testo bianco). Per il nuovo design vogliamo testo NERO su sfondo chiaro
   nei wrapper della pagina dettaglio.
   ========================================================================== */

/* Hero */
.annuncio-intro .escort-dett-container,
.annuncio-intro .escort-dett-container.text-white {
  background: #fff !important;
  color: #222 !important;
}
.annuncio-intro .escort-dett-container *,
.annuncio-intro .escort-dett-container.text-white * {
  color: inherit;
}
.annuncio-intro .escort-dett-container a,
.annuncio-intro .escort-dett-container.text-white a {
  color: #b9141d;
}

/* Tab dettaglio: contenitore GRIGIO (come da template) con tab grigie più chiare.
   Larghezza/margini gestiti dal blocco full-width più sotto: qui solo tema. */
#tab-dettaglio.escort-dett-container,
#tab-dettaglio.escort-dett-container.text-white {
  background: #ececec !important;
  color: #222 !important;
  box-sizing: border-box;
  padding: 30px 0 !important;
  border-radius: 0;
}
#tab-dettaglio.escort-dett-container *,
#tab-dettaglio.escort-dett-container.text-white * {
  color: inherit;
}
#tab-dettaglio h2.section-title {
  color: #b9141d;
  text-align: left;
}
#tab-dettaglio .tab-nav2 {
  background: transparent;
  /* border-radius: 10px; */
  padding: 0;
  gap: 6px;
}
#tab-dettaglio .tab-nav2 .nav-link {
  /* background: #fff; */
  color: #333;
  border: 1px solid #d0d0d0;
}
#tab-dettaglio .tab-nav2 .nav-link:hover {
  background: #f5f5f5;
  color: #111;
}
#tab-dettaglio .tab-nav2 .nav-link.active {
  background: #b9141d;
  color: #fff !important;
  border-color: #b9141d;
}
#tab-dettaglio .tabs_div {
  background: transparent;
}
#tab-dettaglio .tab-pane h4,
#tab-dettaglio h4.h4 {
  color: #b9141d;
}

/* Gallery: contenitore CHIARO + layout MASONRY (CSS columns) */
#gallery-dettaglio.escort-dett-container,
#gallery-dettaglio.escort-dett-container.text-white,
#video-dettaglio.escort-dett-container,
#video-dettaglio.escort-dett-container.text-white {
  background: #fff !important;
  color: #222 !important;
  width: auto !important;
  max-width: 1200px !important;
  margin: 24px auto !important;
  padding: 30px 20px !important;
  border-radius: 12px;
  box-sizing: border-box;
  display: block !important;
  flex-wrap: initial !important;
  gap: 0 !important;
}
#gallery-dettaglio h2.section-title,
#video-dettaglio h2.section-title {
  color: #b9141d;
  text-align: center;
  font-weight: 600;
  display: block;
  width: 100%;
  margin: 0 0 20px;
  float: none;
  clear: both;
}
#gallery-dettaglio .fv-titles,
#video-dettaglio .fv-titles {
  display: none;
}
/* Disattiva lo scroll orizzontale e i pulsanti freccia */
#gallery-dettaglio .scroll-btn,
#gallery-dettaglio #btn_scroll_left,
#gallery-dettaglio #btn_scroll_right,
#gallery-dettaglio .listing-rect-6,
#video-dettaglio .scroll-btn,
#video-dettaglio #btn_scroll_left,
#video-dettaglio #btn_scroll_right,
#video-dettaglio .listing-rect-6 {
  display: none !important;
}
#gallery-dettaglio .container-foto,
#video-dettaglio .container-foto {
  overflow: visible;
}
#gallery-dettaglio .listing-container.foto_div,
#gallery-dettaglio .foto_div,
#video-dettaglio .listing-container.foto_div,
#video-dettaglio .foto_div {
  max-width: none;
  width: 100%;
  overflow: visible;
}
#gallery-dettaglio .foto_escort.listing,
#gallery-dettaglio .foto_escort,
#video-dettaglio .foto_escort.listing,
#video-dettaglio .foto_escort {
  display: block;
  overflow: visible;
  column-gap: 10px;
  column-count: 3;
}
@media (max-width: 992px) {
  #gallery-dettaglio .foto_escort.listing,
  #gallery-dettaglio .foto_escort,
  #video-dettaglio .foto_escort.listing,
  #video-dettaglio .foto_escort { column-count: 2; }
}
@media (max-width: 600px) {
  #gallery-dettaglio .foto_escort.listing,
  #gallery-dettaglio .foto_escort,
  #video-dettaglio .foto_escort.listing,
  #video-dettaglio .foto_escort { column-count: 1; }
}
#gallery-dettaglio .foto_escort > article,
#gallery-dettaglio .foto_escort .escort,
#gallery-dettaglio .foto_escort .escort-small,
#gallery-dettaglio .foto_escort .escort-med,
#video-dettaglio .foto_escort > article,
#video-dettaglio .foto_escort .escort,
#video-dettaglio .foto_escort .escort-small,
#video-dettaglio .foto_escort .escort-med {
  display: inline-block;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  height: auto;
  margin: 0 0 10px 0;
  break-inside: avoid;
  -webkit-column-break-inside: avoid;
  page-break-inside: avoid;
  position: relative;
}
#gallery-dettaglio .foto_escort article img,
#gallery-dettaglio .foto_escort .escort img,
#video-dettaglio .foto_escort article img,
#video-dettaglio .foto_escort .escort img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 8px;
}
#video-dettaglio .video-big {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
}

/* ==========================================================================
   Layout HERO: article (foto) a fianco di .escort-dett-inside.
   La descrizione e le storie vanno su righe successive (full width).
   ========================================================================== */
.annuncio-intro {
  width: 100%;
  align-self: stretch;
  display: block;
}
.annuncio-intro .escort-dett-container {
  display: flex !important;
  flex-direction: row !important;
  width: 100% !important;
  max-width: 1200px !important;
  margin: 0 auto !important;
  align-items: flex-start !important;
  flex-wrap: wrap !important;
  gap: 30px !important;
}
.annuncio-intro .escort-dett-container > article.escort-post {
  flex: 0 0 480px !important;
  max-width: 480px !important;
  width: 480px !important;
  height: auto;
  position: relative;
}
@media (max-width: 900px) {
  .annuncio-intro .escort-dett-container > article.escort-post {
    flex: 0 0 360px !important;
    max-width: 100% !important;
    width: 360px !important;
  }
}
.annuncio-intro .escort-dett-container > article.escort-post img.photo-3 {
  width: 100% !important;
  height: auto !important;
  display: block;
  border-radius: 10px;
}
.annuncio-intro .escort-dett-inside {
  flex: 1 1 0 !important;
  min-width: 0 !important;
  width: auto !important;
  max-width: 100% !important;
}
.annuncio-intro .escort-dett-desc {
  flex: 1 0 100%;
  width: 100%;
}
.annuncio-intro #stories_container_out,
.annuncio-intro .listing-container {
  flex: 1 0 100%;
  width: 100%;
}

@media (max-width: 700px) {
  .annuncio-intro .escort-dett-container > article.escort-post {
    flex: 1 0 100%;
    max-width: 100%;
    width: 100%;
  }
  .annuncio-intro .escort-dett-inside {
    flex: 1 0 100%;
    width: 100% !important;
  }
}

/* Rinforzo dell'attivo sulle tab (vincere su eventuali rules dei tab legacy) */
#tab-dettaglio .tab-nav2 .nav-link.active,
#tab-dettaglio .tab-nav2 .nav-link.tab.active,
#tab-dettaglio .tab-nav2 a.nav-link.active {
  background: #b9141d !important;
  color: #fff !important;
  border-color: #b9141d !important;
}

/* ==========================================================================
   Mappa: deve stare dentro al contenitore tab (no overflow full-width)
   ========================================================================== */
#tab-dettaglio #div_mappa,
#tab-dettaglio #div_mappa > *,
#tab-dettaglio #mappa_dett,
#tab-dettaglio .mappa,
#tab-dettaglio .map,
#tab-dettaglio .leaflet-container {
  max-width: 100% !important;
  width: 100% !important;
  box-sizing: border-box;
  margin-left: 0 !important;
  margin-right: 0 !important;
  left: auto !important;
  right: auto !important;
}
#tab-dettaglio #div_mappa {
  overflow: hidden;
  border-radius: 8px;
}
#tab-dettaglio #mappa_dett,
#tab-dettaglio .leaflet-container {
  height: 420px;
}
@media (max-width: 700px) {
  #tab-dettaglio #mappa_dett,
  #tab-dettaglio .leaflet-container {
    height: 320px;
  }
}

/* ==========================================================================
   Tab "Su di me" (#div_tariffe): Tariffe e Servizi affiancati
   ========================================================================== */
#div_tariffe {
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
  align-items: flex-start;
}
#div_tariffe > .escort-col-tariffe,
#div_tariffe > .escort-col-servizi {
  flex: 1 1 300px;
  min-width: 0;
}
#div_tariffe h4.h4 {
  color: #b9141d;
  margin-bottom: 10px;
}
@media (max-width: 700px) {
  #div_tariffe > .escort-col-tariffe,
  #div_tariffe > .escort-col-servizi {
    flex: 1 0 100%;
  }
}

/* ==========================================================================
   HERO: adattamento dark→light per elementi figli (stelle, promo, storie)
   ========================================================================== */
.annuncio-intro .rece-stars-cont {
  color: #222;
}
.annuncio-intro .rece-stars {
  color: #f5b400; /* oro più visibile su bianco */
}
.annuncio-intro .dett-meta .badge,
.annuncio-intro .dett-row .item {
  background: #f5f5f5;
  color: #222;
  border: 1px solid #e0e0e0;
}
.annuncio-intro .escort-dett-desc {
  color: #222;
}
.annuncio-intro .escort-dett-desc #p_titolo,
.annuncio-intro .escort-dett-desc #p_testo {
  color: #222;
}
.annuncio-intro .footer-cta-dett,
.annuncio-intro .btn_segui {
  color: inherit;
}
.annuncio-intro h1,
.annuncio-intro h2,
.annuncio-intro h3 {
  color: #222;
}

/* Storie nell'hero: card su sfondo bianco */
.annuncio-intro #stories_container_out .listing-shadow,
.annuncio-intro #stories_container_out article {
  background: #fafafa;
  color: #222;
  border: 1px solid #ececec;
}

/* CTA proprietario (annuncio-promo): coordinato col tema chiaro */
.annuncio-promo {
  background: #ececec;
  color: #222;
  border-radius: 12px;
}
.annuncio-promo a,
.annuncio-promo .button,
.annuncio-promo .bg-red {
  color: #fff;
}

/* === Slideshow gallery: fullscreen overlay === */
#foto-show.d-none { display: none !important; }
#foto-show:not(.d-none) {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  z-index: 99999 !important;
  background: #000 !important;
  display: block !important;
}
#foto-show .pellicola {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  pointer-events: none;
}
#foto-show img,
#foto-show video {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  margin: auto !important;
  max-width: 100vw !important;
  max-height: 100vh !important;
  width: auto !important;
  height: auto !important;
  object-fit: contain !important;
}
#foto-show img.d-none,
#foto-show video.d-none { display: none !important; }

/* Frecce e chiudi dentro slideshow fullscreen */
#foto-show .chevron {
  position: absolute !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  z-index: 100000 !important;
  width: auto !important;
  height: auto !important;
  cursor: pointer;
  display: block !important;
}
#foto-show .chevron.d-none { display: none !important; }
#foto-show .chevron-prev { left: 20px !important; right: auto !important; }
#foto-show .chevron-next { right: 80px !important; left: auto !important; }
#foto-show .chevron svg,
#foto-show .chevron .svg {
  width: 60px !important;
  height: 60px !important;
  fill: #fff !important;
  color: #fff !important;
  display: block !important;
  filter: drop-shadow(0 1px 3px rgba(0,0,0,.6));
}
#foto-show .chevron-prev svg,
#foto-show .chevron-prev .svg { transform: rotate(90deg) !important; }
#foto-show .chevron-next svg,
#foto-show .chevron-next .svg { transform: rotate(-90deg) !important; }
#foto-show .close.close_media {
  position: absolute !important;
  top: 16px !important;
  right: 16px !important;
  left: auto !important;
  bottom: auto !important;
  width: 60px !important;
  height: auto !important;
  z-index: 100001 !important;
  cursor: pointer;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 4px !important;
  color: #fff !important;
  text-align: center !important;
  text-shadow: 0 1px 2px rgba(0,0,0,.6);
}
#foto-show .close.close_media svg,
#foto-show .close.close_media .svg {
  position: static !important;
  display: block !important;
  margin: 0 auto !important;
  width: 30px !important;
  height: 30px !important;
  float: none !important;
}
#foto-show .close.close_media p {
  margin: 0 !important;
  font-size: 0.85rem !important;
  line-height: 1 !important;
  width: 100% !important;
  text-align: center !important;
  color: #fff !important;
}
#foto-show #gallery_nfv {
  position: absolute !important;
  top: 20px !important;
  left: 20px !important;
  z-index: 100000 !important;
  color: #fff !important;
  font-size: 1rem !important;
  background: rgba(0,0,0,.4);
  padding: 4px 10px;
  border-radius: 4px;
}

/* Forza layout a blocco contro display:flex legacy di .escort-dett-container */
#tab-dettaglio.escort-dett-container,
#tab-dettaglio.escort-dett-container.text-white {
  display: block !important;
  flex-direction: initial !important;
  flex-wrap: initial !important;
  gap: 0 !important;
}

/* Sezione #tab-dettaglio a tutta larghezza: i contenuti interni restano centrati in max 1200px */
#tab-dettaglio.escort-dett-container {
  width: 100vw !important;
  max-width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  border-radius: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  box-sizing: border-box;
}
#tab-dettaglio.escort-dett-container > * {
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 20px;
  padding-right: 20px;
  box-sizing: border-box;
}

/* === Pulsante lente sulla foto hero === */
.annuncio-intro article.escort-post { position: relative; }
.annuncio-intro article.escort-post .hero-lens {
  position: absolute;
  bottom: 12px;
  right: 12px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: #b9141d;
  color: #fff;
  border: 2px solid #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  cursor: pointer;
  z-index: 5;
  transition: background .15s ease;
  padding: 0;
  box-shadow: 0 2px 6px rgba(0,0,0,.35);
}
.annuncio-intro article.escort-post .hero-lens:hover {
  background: #a01018;
}
#tab-dettaglio #tab-3 { width: 100%; }

/* === Gallery: griglia 3x3 uniforme con cornice rossa === */
#gallery-dettaglio .foto_escort.listing {
  column-count: initial !important;
  display: grid !important;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
@media (max-width: 900px) { #gallery-dettaglio .foto_escort.listing { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { #gallery-dettaglio .foto_escort.listing { grid-template-columns: 1fr; } }
#gallery-dettaglio .foto_escort.listing > article {
  width: 100% !important;
  display: block;
  break-inside: initial !important;
  margin: 0 !important;
  position: relative;
  border: 2px solid #b9141d;
  border-radius: 6px;
  overflow: hidden;
  aspect-ratio: 3/4;
  background: #000;
}
#gallery-dettaglio .foto_escort.listing > article img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
  border-radius: 0 !important;
  display: block;
}
#gallery-dettaglio .foto_escort.listing > article::after {
  content: "\f002"; /* fa-search */
  font-family: "FontAwesome";
  position: absolute;
  bottom: 8px;
  right: 8px;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: #b9141d;
  color: #fff;
  border: 2px solid #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  pointer-events: none;
  box-shadow: 0 2px 4px rgba(0,0,0,.3);
}

/* === Box "Sei tu il titolare?" === */
.owner-cta {
  background: #1a1a1a;
  color: #fff;
  text-align: center;
  padding: 24px 20px;
  margin: 24px auto;
  max-width: 1200px;
  border-radius: 8px;
}
.owner-cta p { margin: 0 0 14px 0; font-size: 1rem; color: #fff; }
.owner-cta .btn-entra {
  display: inline-block;
  background: #b9141d;
  color: #fff !important;
  padding: 10px 36px;
  border-radius: 4px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  text-decoration: none !important;
  border: none;
  cursor: pointer;
}
.owner-cta .btn-entra:hover { background: #a01018; }

/* === Lente sulla foto hero === */
.annuncio-intro article.escort-post .info-3 {
  position: absolute;
  bottom: 10px;
  right: 10px;
  background: rgba(255,255,255,0.9);
  color: #b9141d;
  padding: 6px 12px;
  border-radius: 20px;
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.85rem;
  cursor: pointer;
  z-index: 3;
}
.annuncio-intro article.escort-post .info-3 .p { color: #b9141d; }

/* === Generale: lista anagrafica leggibile === */
#div_info .anagrafica-list {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 8px 16px;
  margin: 10px 0 20px;
  max-width: 640px;
  font-size: 0.95rem;
}
#div_info .anagrafica-list dt { font-weight: 400; color: #444; margin: 0; }
#div_info .anagrafica-list dd { font-weight: 700; color: #111; margin: 0; }
#div_info .anagrafica-list dd.tel a { color: #b9141d; text-decoration: none !important; }
#div_info .anagrafica-list dd.tel a.tel-wa {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  margin-left: 8px;
  border-radius: 6px;
  background: #25D366;
  color: #fff !important;
  font-size: 1.05rem;
  vertical-align: middle;
}
#div_info .anagrafica-frase {
  margin: 8px 0 16px;
  font-size: 0.95rem;
  color: #333;
}
#div_info .anagrafica-frase strong { color: #b9141d; }

/* ==========================================================================
   MOBILE (max-width: 767px): tab tutte aperte + quick-nav icona + phone sticky
   ========================================================================== */

/* Default: nascondi gli elementi mobile-only su desktop */
.mobile-quick-nav { display: none; }
.mobile-phone-cta { display: none; }

@media (max-width: 767px) {
  /* Forza tutte le tab visibili (override su .d-none) */
  #tab-dettaglio .tabs_div,
  #tab-dettaglio .tabs_div.d-none {
    display: block !important;
    margin-bottom: 24px;
    padding-top: 8px;
  }
  /* Titolo della sezione preso da data-mobile-title */
  #tab-dettaglio .tabs_div[data-mobile-title]::before {
    content: attr(data-mobile-title);
    display: block;
    font-size: 1.3rem;
    font-weight: 700;
    color: #b9141d;
    text-align: center;
    margin: 8px 0 14px;
    padding-bottom: 8px;
    border-bottom: 1px solid #e0e0e0;
  }
  /* Nascondi tab-nav classico (sostituito da mobile-quick-nav) */
  #tab-dettaglio #tab-3 { display: none !important; }

  /* Titolo Scopri NOME al centro su mobile */
  #tab-dettaglio h2.section-title { text-align: center !important; }

  /* === Quick-nav icone (FIXED in basso al viewport, tiles rossi pieni) === */
  .mobile-quick-nav {
    display: flex !important;
    justify-content: stretch;
    align-items: stretch;
    background: #fff;
    padding: 6px;
    margin: 0;
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1030;
    border-top: 1px solid #c5c5c5;
    gap: 6px;
    overflow: hidden;
    box-shadow: 0 -2px 8px rgba(0,0,0,.15);
  }
  .mobile-quick-nav .mqn-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 1 1 0;
    min-width: 0;
    aspect-ratio: 1 / 1;
    height: auto;
    width: auto;
    border-radius: 6px;
    background: #b9141d;
    color: #fff;
    font-size: 1.5rem;
    text-decoration: none;
    border: 0;
    transition: background .15s ease;
  }
  .mobile-quick-nav .mqn-btn:hover,
  .mobile-quick-nav .mqn-btn:active { background: #a01018; color: #fff; }
  .mobile-quick-nav .mqn-btn i,
  .mobile-quick-nav .mqn-btn .fa { color: #fff !important; font-size: 1.5rem; line-height: 1; }
  .mobile-quick-nav .mqn-btn.mqn-tel { background: #b9141d; color: #fff; }
  .mobile-quick-nav .mqn-btn.mqn-tel:hover { background: #a01018; }

  /* === Phone CTA mobile (sticky sotto header) === */
  .mobile-phone-cta {
    display: flex !important;
    align-items: center;
    justify-content: center;
    gap: 8px;
    background: #b9141d;
    color: #fff !important;
    font-weight: 700;
    font-size: 1.15rem;
    text-decoration: none !important;
    padding: 14px 16px;
    position: sticky;
    top: 65px; /* sotto header-mobile (height 65px) */
    z-index: 1020; /* sotto offcanvas (1045) e quick-nav (1030) */
    box-shadow: 0 2px 8px rgba(0,0,0,.25);
  }
  .mobile-phone-cta i { font-size: 1.1rem; }

  /* === Phone CTA con WhatsApp: telefono a sinistra, pulsante WA a destra === */
  .mobile-phone-cta.has-wa {
    justify-content: space-between;
    gap: 0;
    padding: 0;
  }
  .mobile-phone-cta.has-wa .mpc-tel {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    flex: 1 1 auto;
    color: #fff !important;
    text-decoration: none !important;
    font-weight: 700;
    font-size: 1.15rem;
    padding: 14px 16px;
  }
  .mobile-phone-cta.has-wa .mpc-tel i { font-size: 1.1rem; }
  .mobile-phone-cta.has-wa .mpc-wa {
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    align-self: stretch;
    background: #25D366;
    color: #fff !important;
    text-decoration: none !important;
    padding: 0 22px;
    font-size: 1.7rem;
  }

  /* Spazio in fondo alla pagina per non far coprire il contenuto dalla quick-nav fixed */
  body { padding-bottom: 70px; }

  /* Anchor offset per scroll smooth sotto le barre sticky */
  #tab-dettaglio .tabs_div { scroll-margin-top: 130px; }
  #gallery-dettaglio,
  #video-dettaglio { scroll-margin-top: 130px; }

  /* Scroll smooth nativo */
  html { scroll-behavior: smooth; }

  /* === Navbar mobile: logo a sinistra, search + hamburger a destra (compatti) === */
  .header-mobile {
    justify-content: space-between !important;
    align-items: center !important;
    padding: 0 12px !important;
  }
  .header-mobile .logo {
    flex: 1 1 auto !important;
    width: auto !important;
    max-width: 60% !important;
    height: 45px !important;
    margin: 0 !important;
  }
  .header-mobile .logo img {
    height: 45px !important;
    width: auto !important;
    max-width: 100% !important;
    object-fit: contain !important;
    float: none !important;
  }
  .header-mobile .search {
    position: static !important;
    right: auto !important;
    flex: 0 0 50px !important;
    width: 50px !important;
    height: 65px !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-left: 1px solid rgba(255,255,255,.4) !important;
    border-right: 1px solid rgba(255,255,255,.4) !important;
    margin-left: auto !important;
  }
  .header-mobile .search a,
  .header-mobile .search i {
    font-size: 1.4rem !important;
    color: #fff !important;
    line-height: 1 !important;
  }
  .header-mobile .hamburger {
    flex: 0 0 35px !important;
    width: 35px !important;
    height: 40px !important;
    margin-left: 12px !important;
    position: relative !important;
  }
  .header-mobile .hamburger span {
    height: 3px !important;
    width: 100% !important;
    background: #fff !important;
    border-radius: 2px !important;
    position: absolute !important;
    left: 0 !important;
  }
  .header-mobile .hamburger span:nth-child(1) { top: 10px !important; bottom: auto !important; transform: none !important; }
  .header-mobile .hamburger span:nth-child(2) { top: 50% !important; bottom: auto !important; transform: translateY(-50%) !important; }
  .header-mobile .hamburger span:nth-child(3) { top: auto !important; bottom: 10px !important; transform: none !important; }
}

/* (Navbar mobile/tablet globale spostata in newstyle.css) */

/* === Mobile: titolo pagina rosso + breadcrumb compatto === */
@media (max-width: 767px) {

  /* Frecce gallery sempre visibili su mobile (override del d-none JS touch) */
  #foto-show .chevron.chevron-prev,
  #foto-show .chevron.chevron-next,
  #foto-show .chevron.chevron-prev.d-none,
  #foto-show .chevron.chevron-next.d-none { display: block !important; }
  #foto-show .chevron-next { right: 12px !important; }
  #foto-show .chevron-prev { left: 12px !important; }
  #foto-show .chevron svg,
  #foto-show .chevron .svg { width: 44px !important; height: 44px !important; }

  /* Hero-lens: più margine destro/bottom su mobile */
  .annuncio-intro article.escort-post .hero-lens { right: 24px !important; bottom: 24px !important; }

  /* Hero titolo: stesso rosso del header, testo bianco, compatto */
  #titolo-pagina { background: #b9141d !important; margin: 0 !important; }
  #page-title.page-title-dark {
    background: #b9141d !important;
    padding: 14px 16px 18px !important;
    margin: 0 !important;
  }
  #page-title.page-title-dark .container { padding: 0 !important; max-width: 100% !important; background: transparent !important; }
  #page-title.page-title-dark h1 {
    color: #fff !important;
    font-size: 1.5rem !important;
    line-height: 1.2 !important;
    font-weight: 700 !important;
    text-align: center !important;
    margin: 0 0 6px !important;
    text-transform: none !important;
    word-break: break-word;
  }
  #page-title.page-title-dark h2,
  #page-title.page-title-dark span {
    color: #fff !important;
    font-size: 1.05rem !important;
    font-weight: 600 !important;
    text-align: center !important;
    display: block !important;
    margin: 0 !important;
  }

  /* Breadcrumb compatto su sfondo bianco */
  #page-title.page-title-bread {
    background: #fff !important;
    padding: 10px 16px !important;
    margin: 0 !important;
  }
  #page-title.page-title-bread .container { padding: 0 !important; max-width: 100% !important; background: transparent !important; }
  #page-title.page-title-bread .breadcrumb {
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    font-size: .85rem !important;
    line-height: 1.4 !important;
    flex-wrap: wrap !important;
  }

  /* Phone CTA: sticky sotto la barra header mobile */
  .mobile-phone-cta {
    position: sticky !important;
    top: 65px !important;
    margin: 0 !important;
    border-radius: 0 !important;
    z-index: 1020 !important;
  }
}

/* ==========================================================================
   Commenti (#recensioni): tema chiaro tipo /recensioni.php
   dettaglio.css non viene caricato su questa pagina, quindi gli stili dei
   commenti vanno definiti qui dove vengono effettivamente applicati.
   ========================================================================== */
.rece-container {
  display: flex;
  width: 100%;
  padding: 0;
  flex-direction: column;
  align-items: flex-start;
  gap: 24px;
  background: transparent;
}
.rece-container > .h4 {
  padding: 16px 0;
}
#recensioni {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
#recensioni .rece {
  display: flex;
  width: 100%;
  padding: 24px;
  flex-direction: column;
  align-items: flex-start;
  gap: 14px;
  align-self: stretch;
  border: 1px solid #e5e5e5;
  border-radius: 8px;
  background: #f7f7f7;
  color: #000;
}
#recensioni .rece .h4,
#recensioni .rece .weight-400 {
  margin: 0;
}
#recensioni .rece-stars-cont {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
#recensioni .rece-stars {
  height: 18px;
}
#recensioni .rece-secondary-int {
  display: inline-flex;
  align-items: center;
  gap: 2px;
}
#recensioni .vedi_rece {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
#recensioni .rece-txt {
  padding: 4px 0;
  line-height: 1.55;
}
#recensioni .div_risposta_recensione {
  margin-top: 4px;
  background: #efefef;
  border: 1px solid #e0e0e0;
}
#recensioni .rece-reply-ut {
  display: flex;
  flex-direction: row;
  gap: 10px;
}
#recensioni .rece-reply-img {
  width: 35px;
  height: 35px;
}
#recensioni .rece-reply-img > img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 70px;
}
#recensioni .rece a { color: var(--red, #e1021e); }
#recensioni .rece .text-white { color: #000 !important; }
#recensioni .rece .text-secondary { color: rgba(0, 0, 0, 0.6); }
#recensioni .rece .button { text-shadow: none; }

/* ==========================================================================
   Commenti: pulsante "accedi come utente"
   ========================================================================== */
.btn-accedi-rece {
  display: inline-block;
  background-color: #0269E1;
  color: #fff !important;
  border: none;
  padding: 11px 26px;
  font-size: 14px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  border-radius: 6px;
  cursor: pointer;
  transition: background-color .2s;
}
.btn-accedi-rece:hover { background-color: #0257bd; }

/* ==========================================================================
   Commenti: form di inserimento / modifica commento
   (stili presi da dettaglio.css, non caricato su questa pagina)
   ========================================================================== */
#recensioni form {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 20px;
  margin-top: 12px;
  border: 1px solid #e5e5e5;
  border-radius: 8px;
  background: #fff;
}

/* selettore a stelle */
#recensioni #wrapper_stelle {
  text-align: center;
}
#recensioni .clasification {
  display: inline-flex;
  direction: rtl;
  gap: 4px;
  margin: 0;
  line-height: 1;
}
#recensioni .radio_stelle {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  pointer-events: none;
}
#recensioni .label_stelle {
  font-size: 34px;
  line-height: 1;
  color: #d8d8d8;
  cursor: pointer;
  transition: color .15s;
}
#recensioni .clasification .label_stelle:hover,
#recensioni .clasification .label_stelle:hover ~ .label_stelle,
#recensioni .clasification .radio_stelle:checked ~ .label_stelle {
  color: var(--oro, #F4911B);
}

/* input testo e textarea: tema chiaro al posto di bg-black */
#recensioni .input,
#recensioni input[type="text"],
#recensioni input[type="date"],
#recensioni textarea,
#recensioni select {
  width: 100%;
  background: #fff !important;
  color: #000 !important;
  border: 1px solid #cfcfcf;
  border-radius: 6px;
  padding: 10px 12px;
  font-size: 14px;
  font-family: inherit;
}
#recensioni textarea {
  min-height: 90px;
  resize: vertical;
}
#recensioni .input::placeholder,
#recensioni textarea::placeholder {
  color: #8a8a8a;
}
#recensioni .input:focus,
#recensioni textarea:focus,
#recensioni select:focus {
  outline: none;
  border-color: #0269E1;
  box-shadow: 0 0 0 2px rgba(2, 105, 225, .15);
}

/* pulsanti del form (scrivi/invia/modifica) */
#recensioni .button-small {
  display: inline-flex;
  align-self: flex-start;
  border-radius: 6px;
  overflow: hidden;
}
#recensioni .button-small.bg-white {
  border: 1px solid #cfcfcf;
}
#recensioni .button-small .button,
#recensioni .button-small button,
#recensioni .button-small span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 18px;
  font-weight: 700;
  cursor: pointer;
  border: none;
}
#recensioni .button-small.bg-red,
#recensioni .button-small.bg-red .button,
#recensioni .button-small.bg-red button {
  background: var(--red, #e1021e);
  color: #fff !important;
}
#recensioni .button-small.bg-white,
#recensioni .button-small.bg-white .button,
#recensioni .button-small.bg-white span {
  background: #fff;
  color: #000 !important;
}

/* box "Extra" (solo admin/punter speciali) */
#recensioni .rece-extra-box {
  padding: 12px;
  margin-top: 12px;
  border: 1px solid #e0e0e0;
  border-radius: 6px;
  background: #fafafa;
}
