/*
Theme Name: Recond Child
Theme URI: https://recond.com
Description: Child theme for Recond
Author: Overbeat Studio
Author URI: https://overbeatstudio.com
Template: recond
Version: 1.0.0
Text Domain: recond-child
*/

/* Aumenta la dimensione del logo nell'header */
nav.navbar .navbar-logo .logo img {
  max-height: 45px !important;
  width: auto;
  max-width: 200px;
}

/* Stile per il logo quando è solo testo (fallback) */
nav.navbar .navbar-logo .logo {
  font-size: 20px;
  font-weight: 700;
  color: inherit;
  text-decoration: none;
  display: inline-block;
}

/* Ottimizzazione per tablet */
@media (max-width: 991px) {
  nav.navbar .navbar-logo .logo img {
    max-height: 40px !important;
    max-width: 180px;
  }

  nav.navbar .navbar-logo .logo {
    font-size: 18px;
  }
}

/* Ottimizzazione per mobile */
@media (max-width: 768px) {
  nav.navbar .navbar-logo .logo img {
    max-height: 35px !important;
    max-width: 150px;
  }

  nav.navbar .navbar-logo .logo {
    font-size: 16px;
  }

  /* Assicura che il navbar non si rompa su mobile */
  nav.navbar .container {
    padding-left: 15px !important;
    padding-right: 15px !important;
  }

  /* Fix per il menu mobile */
  #navbar.navbar-mobile {
    width: 100% !important;
  }

  /* Assicura che le immagini siano responsive */
  img {
    max-width: 100%;
    height: auto;
  }
}

/* Stili per Ghost Track - Pulsante carrello stesso colore del prezzo scontato */
body.tax-product_cat.term-ghost-track .woocommerce table tr td .button,
body.tax-product_cat.term-ghost-track
  .woocommerce
  table
  tr
  td
  .add_to_cart_button,
body.tax-product_cat.term-ghost-track
  .woocommerce
  table
  tr
  td
  .ajax_add_to_cart {
  background-color: #e91e63 !important;
  background: linear-gradient(135deg, #e91e63 0%, #c2185b 100%) !important;
  border-color: #e91e63 !important;
  color: #ffffff !important;
}

/* Assicura che il prezzo scontato sia dello stesso colore */
body.tax-product_cat.term-ghost-track table ins .woocommerce-Price-amount,
body.tax-product_cat.term-ghost-track table .price > .woocommerce-Price-amount {
  color: #dc2751 !important;
  font-weight: bold;
}

/* Fix per Ghost Track - Layout prezzi in colonna */
body.tax-product_cat.term-ghost-track table .price {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 5px !important;
}

body.tax-product_cat.term-ghost-track table .price del {
  display: block !important;
  width: 100% !important;
  order: 1 !important;
}

body.tax-product_cat.term-ghost-track table .price ins {
  display: block !important;
  width: 100% !important;
  text-decoration: none !important;
  order: 2 !important;
}

/* Fix sovrapposizione SOLD e Esaurito */
body.tax-product_cat.term-ghost-track table tr.outofstock td:first-child {
  position: relative !important;
}

/* Nascondi il badge SOLD duplicato se presente */
body.tax-product_cat.term-ghost-track table tr.outofstock td .onsale-badge,
body.tax-product_cat.term-ghost-track table tr.outofstock td .badge {
  display: none !important;
}

/* ========================================
   OBS PROFESSIONAL BUY BUTTON & SOLD STATUS
   ======================================== */

/* Pulsante SOLD */
.obs-table-sold,
body.custom-ghost-track-page .obs-table-sold {
  background-color: #e02d4f !important;
  background: linear-gradient(135deg, #e02d4f 0%, #c2185b 100%) !important;
  color: #ffffff !important;
  padding: 8px 16px !important;
  border-radius: 4px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  display: inline-block !important;
  border: none !important;
  font-size: 13px !important;
  line-height: 1 !important;
  text-decoration: none !important;
  box-shadow: 0 4px 12px rgba(224, 45, 79, 0.4) !important;
}

/* ========================================
   OBS PROFESSIONAL ROUND CART BUTTON (GLOBAL)
   ======================================== */

.add_to_cart_button,
.single_add_to_cart_button,
.ajax_add_to_cart,
a.button.add_to_cart_button,
button.single_add_to_cart_button,
.wc-product-table .add_to_cart_button,
.wcpt-table .add_to_cart_button,
.ltx-cart.cart {
  font-size: 0 !important;
  line-height: 0 !important;
  padding: 0 !important;
  width: 44px !important; /* Slightly smaller for header compatibility */
  height: 44px !important;
  min-width: 44px !important;
  text-indent: -9999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, #e91e63 0%, #d81b60 100%) !important;
  border: none !important;
  box-shadow: 0 5px 15px rgba(233, 30, 99, 0.4) !important;
  transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275) !important;
  position: relative !important;
  overflow: visible !important;
  color: transparent !important;
}

.add_to_cart_button::before,
.single_add_to_cart_button::before,
.ajax_add_to_cart::before,
.wc-product-table .add_to_cart_button::before,
.wcpt-table .add_to_cart_button::before,
.ltx-cart.cart::before {
  content: "\f174" !important; /* Dashicons Cart */
  font-family: "dashicons" !important;
  font-size: 22px !important;
  color: #fff !important;
  text-indent: 0 !important;
  display: block !important;
  line-height: 1 !important;
  visibility: visible !important;
  position: static !important;
}

/* Hide original icon inside ltx-cart */
.ltx-cart.cart i,
.ltx-cart.cart span:not(.count) {
  display: none !important;
}

/* Adjust counter position for the round button */
.ltx-cart.cart .count {
  position: absolute !important;
  top: -5px !important;
  right: -5px !important;
  background: #fff !important;
  color: #e91e63 !important;
  width: 20px !important;
  height: 20px !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 11px !important;
  font-weight: bold !important;
  text-indent: 0 !important;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2) !important;
}

.add_to_cart_button:hover,
.single_add_to_cart_button:hover,
.ajax_add_to_cart:hover,
.ltx-cart.cart:hover {
  transform: scale(1.1) rotate(5deg) !important;
  box-shadow: 0 8px 25px rgba(233, 30, 99, 0.5) !important;
}

/* Forza visibilità colonna Acquista (col-buy) */
table.wc-product-table td.col-buy,
table.wc-product-table th.col-buy,
table.wcpt-table td.col-acquista,
table.wcpt-table th.col-acquista,
.col-buy,
.col-acquista {
  display: table-cell !important;
  visibility: visible !important;
  opacity: 1 !important;
  text-align: center !important;
  vertical-align: middle !important;
}

/* ========================================
   GHOST TRACK PRODUCT TABLE - PC ENLARGEMENT
   ======================================== */
@media (min-width: 992px) {
  table.wc-product-table th.col-image,
  table.wc-product-table td.col-image,
  table.wcpt-table th.col-image,
  table.wcpt-table td.col-image,
  .col-image {
    width: 170px !important;
    min-width: 170px !important;
    max-width: 170px !important;
  }

  .custom-ghost-track-page table.wc-product-table td.col-image img,
  .custom-ghost-track-page table.wcpt-table td.col-image img,
  body.tax-product_cat.term-ghost-track table .obs-img-wrap img {
    width: 150px !important;
    height: 150px !important;
    max-width: 150px !important;
    object-fit: cover !important;
    border-radius: 10px !important;
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.5) !important;
    display: block !important;
    margin: 0 auto !important;
  }

  body.tax-product_cat.term-ghost-track table .obs-img-wrap {
    width: 150px !important;
    height: 150px !important;
    display: inline-block !important;
    position: relative !important;
    overflow: hidden !important;
    border-radius: 10px !important;
  }
}

/* OBS PROFESSIONAL PLAY BUTTON OVERLAY */
.obs-play-overlay {
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) !important;
  width: 44px !important;
  height: 44px !important;
  background: rgba(10, 24, 45, 0.75) !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  opacity: 0 !important;
  transition: all 0.3s ease !important;
  cursor: pointer !important;
  z-index: 20 !important;
  backdrop-filter: blur(2px) !important;
  border: 1px solid rgba(255, 255, 255, 0.2) !important;
}

.obs-img-wrap:hover .obs-play-overlay,
.obs-play-overlay:hover,
.obs-play-overlay.playing {
  opacity: 1 !important;
}

.obs-play-overlay:hover {
  background: #e91e63 !important;
  transform: translate(-50%, -50%) scale(1.1) !important;
}

.obs-play-icon {
  width: 0 !important;
  height: 0 !important;
  border-style: solid !important;
  border-width: 7px 0 7px 12px !important;
  border-color: transparent transparent transparent #ffffff !important;
  margin-left: 4px !important;
}

.obs-play-overlay.playing .obs-play-icon {
  width: 12px !important;
  height: 14px !important;
  border: none !important;
  border-left: 4px solid #fff !important;
  border-right: 4px solid #fff !important;
  background: transparent !important;
  margin-left: 0 !important;
}

/* MOBILE UI OPTIMIZATION */
@media only screen and (max-width: 768px) {
  html,
  body {
    overflow-x: hidden !important;
    width: 100% !important;
  }

  /* Change BPM text color to black on mobile */
  .obs-bpm-label {
    color: #000 !important;
  }

  /* Reduce large headers on mobile */
  h1.header,
  .ltx-h1,
  .page-header h1 {
    font-size: 26px !important;
    line-height: 1.1 !important;
  }

  /* Fix sidebar and content overlap */
  .sidebar-container,
  .ltx-sidebar,
  .ltx-sidebar-wrapper {
    width: 100% !important;
    float: none !important;
    margin-bottom: 30px !important;
    display: block !important;
  }

  #primary,
  .content-area {
    width: 100% !important;
    float: none !important;
    display: block !important;
  }

  /* Fix overlapping columns in services/consulenza category */
  .ltx-item-col-1,
  .ltx-item-col-2,
  .wcpt-col {
    width: 100% !important;
    min-width: 100% !important;
    display: block !important;
    padding: 10px 0 !important;
    float: none !important;
  }

  table.wc-product-table thead {
    display: none !important;
  }

  table.wc-product-table,
  table.wc-product-table tr {
    display: block !important;
    width: 100% !important;
  }

  table.wc-product-table tr {
    padding: 10px !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
  }

  table.wc-product-table td {
    display: flex !important;
    padding: 5px !important;
    align-items: center !important;
    flex-wrap: wrap !important;
  }

  /* Fix per i titoli dei caroselli che traboccano su mobile */
  .ltx-item h3.ltx-header,
  .ltx-item h3,
  .services-carousel .ltx-item .ltx-header {
    font-size: 20px !important;
    line-height: 1.2 !important;
    word-wrap: break-word !important;
    overflow-wrap: break-word !important;
    hyphens: auto !important;
    margin-bottom: 10px !important;
  }

  .ltx-item .ltx-text {
    font-size: 14px !important;
    line-height: 1.4 !important;
  }
}

/* --- RESTORED GHOST TRACK TABLE FORMATTING --- */
body.custom-ghost-track-page table.wc-product-table,
body.custom-ghost-track-page table.wcpt-table,
body.custom-ghost-track-page .dataTable {
  table-layout: auto !important;
  width: 100% !important;
}

body.custom-ghost-track-page table.wcpt-table td.col-image,
body.custom-ghost-track-page table.wcpt-table th.col-image,
body.custom-ghost-track-page table.wc-product-table td.col-image,
body.custom-ghost-track-page table.wc-product-table th.col-image,
body.custom-ghost-track-page .wcpt-table th.col-image,
body.custom-ghost-track-page .wcpt-table td.col-image,
body.custom-ghost-track-page .dataTable td.col-image,
body.custom-ghost-track-page .dataTable th.col-image {
  width: 165px !important;
  min-width: 165px !important;
  max-width: 165px !important;
  padding: 15px 10px 15px 5px !important;
  vertical-align: middle !important;
  border-right: none !important;
}

/* ========================================
   WOOCOMMERCE CHECKOUT RESPONSIVE FIXES
   ======================================== */
@media (max-width: 768px) {
  /* Prevent horizontal scroll */
  .woocommerce-checkout,
  .woocommerce-page {
    overflow-x: hidden !important;
  }

  /* Order Review Table Fix */
  .woocommerce-checkout-review-order-table {
    display: table !important;
    width: 100% !important;
    border: none !important;
    background: #fff !important;
    border-collapse: collapse !important;
  }

  .woocommerce-checkout-review-order-table thead {
    display: none !important;
  }

  .woocommerce-checkout-review-order-table tbody tr {
    display: block !important;
    width: 100% !important;
    border-bottom: 1px solid #eee !important;
    padding: 10px 0 !important;
  }

  .woocommerce-checkout-review-order-table td.product-name {
    display: block !important;
    width: 100% !important;
    font-weight: 800 !important;
    font-size: 15px !important;
    color: #111 !important;
    padding: 5px 0 !important;
    text-align: left !important;
  }

  .woocommerce-checkout-review-order-table td.product-total {
    display: block !important;
    width: 100% !important;
    text-align: left !important;
    color: #e91e63 !important;
    font-weight: 700 !important;
    font-size: 14px !important;
    padding: 2px 0 10px 0 !important;
  }

  /* Footer rows (Subtotal, Total, etc) */
  .woocommerce-checkout-review-order-table tfoot tr {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 15px 0 !important;
    border-bottom: 1px solid #eee !important;
    width: 100% !important;
  }

  .woocommerce-checkout-review-order-table tfoot th {
    flex: 1 !important;
    text-align: left !important;
    font-size: 14px !important;
    color: #333 !important;
    text-transform: uppercase !important;
    padding: 0 !important;
    border: none !important;
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
  }

  .woocommerce-checkout-review-order-table tfoot td {
    flex: 1 !important;
    text-align: right !important;
    font-weight: 800 !important;
    font-size: 16px !important;
    color: #e91e63 !important;
    padding: 0 !important;
    border: none !important;
    display: block !important;
  }

  .woocommerce-checkout-review-order-table tr.order-total td {
    font-size: 20px !important;
  }

  /* Coupon section alignment */
  .woocommerce-checkout-review-order-table .cart-discount {
    flex-direction: column !important;
    align-items: flex-start !important;
  }

  .woocommerce-checkout-review-order-table .cart-discount th {
    width: 100% !important;
    margin-bottom: 5px !important;
  }

  .woocommerce-checkout-review-order-table .cart-discount td {
    width: 100% !important;
    text-align: left !important;
    color: #4caf50 !important;
  }

  /* Payment Section Fixes */
  #payment {
    background: #f8f8f8 !important;
    border: 1px solid #e5e5e5 !important;
    border-radius: 12px !important;
    padding: 20px !important;
    margin-top: 30px !important;
  }

  #payment ul.payment_methods li label {
    font-size: 15px !important;
    font-weight: 700 !important;
    color: #111 !important;
    display: inline-block !important;
    margin-left: 10px !important;
  }

  /* FORCE ALL labels to stay ABOVE inputs and be visible */
  #payment label,
  #payment .payment_box label,
  .woocommerce-checkout #payment label {
    display: block !important;
    position: static !important;
    margin-bottom: 10px !important;
    padding: 0 !important;
    font-size: 14px !important;
    color: #222 !important;
    font-weight: 700 !important;
    text-align: left !important;
    visibility: visible !important;
    opacity: 1 !important;
    transform: none !important;
    clear: both !important;
    height: auto !important;
    clip: auto !important;
    width: 100% !important;
  }

  #payment .payment_box .form-row {
    padding: 0 !important;
    margin-bottom: 25px !important;
    display: block !important;
    clear: both !important;
  }

  #payment .payment_box input.input-text,
  #payment .payment_box .wc-stripe-elements-field {
    padding: 12px 15px !important;
    height: 50px !important;
    background: #fff !important;
    border: 1px solid #ccc !important;
    border-radius: 8px !important;
    color: #111 !important;
    width: 100% !important;
    box-sizing: border-box !important;
    display: block !important;
  }

  /* Form Fields Overlap Fix */
  .woocommerce-checkout .form-row {
    width: 100% !important;
    margin-right: 0 !important;
    float: none !important;
    display: block !important;
  }

  #payment .wc-credit-card-form .form-row-first,
  #payment .wc-credit-card-form .form-row-last {
    width: 100% !important;
    float: none !important;
  }
}

/* Optimize for landscape on mobile */
@media screen and (max-width: 991px) and (orientation: landscape) {
  .woocommerce-checkout-review-order-table tfoot tr {
    padding: 5px 0 !important;
  }

  h3#order_review_heading {
    font-size: 20px !important;
    margin-top: 20px !important;
  }
}

/* ========================================
   PERSUASIVE SERVICE OVERLAYS
   ======================================== */
.services-sc .ltx-inner .photo {
  position: relative !important;
  overflow: hidden !important;
  display: block !important;
}

.ltx-overlay-persuasive {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  background: rgba(0, 0, 0, 0.85) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  opacity: 0 !important;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
  padding: 25px !important;
  text-align: center !important;
  z-index: 50 !important;
  backdrop-filter: blur(4px) !important;
}

.services-sc .ltx-inner:hover .photo .ltx-overlay-persuasive {
  opacity: 1 !important;
}

.ltx-overlay-persuasive .ltx-overlay-inner {
  transform: translateY(20px) !important;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
  width: 100% !important;
}

.services-sc
  .ltx-inner:hover
  .photo
  .ltx-overlay-persuasive
  .ltx-overlay-inner {
  transform: translateY(0) !important;
}

.ltx-overlay-persuasive h4.title {
  color: #fff !important;
  font-size: 22px !important;
  margin-bottom: 12px !important;
  font-weight: 900 !important;
  text-transform: uppercase !important;
  letter-spacing: 1.5px !important;
  line-height: 1.2 !important;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5) !important;
}

.ltx-overlay-persuasive p.subtitle {
  color: #dfdfdf !important;
  font-size: 13px !important;
  line-height: 1.5 !important;
  margin-bottom: 20px !important;
  font-family: inherit !important;
}

.ltx-overlay-persuasive .cta {
  display: inline-block !important;
  background: #dc2751 !important;
  background: linear-gradient(135deg, #dc2751 0%, #a01c3b 100%) !important;
  color: #fff !important;
  padding: 10px 20px !important;
  border-radius: 50px !important;
  font-weight: 800 !important;
  font-size: 12px !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  box-shadow: 0 4px 15px rgba(220, 39, 81, 0.4) !important;
  transition: all 0.3s ease !important;
}

.ltx-overlay-persuasive .cta:hover {
  transform: scale(1.05) !important;
  box-shadow: 0 6px 20px rgba(220, 39, 81, 0.6) !important;
  background: #dc2751 !important;
}

/* Nascondi il più originale quando l'overlay è attivo */
.services-sc .ltx-inner:hover .photo .ltx-plus {
  opacity: 0 !important;
  visibility: hidden !important;
}

/* Responsività Overlay */
@media (max-width: 1200px) {
  .ltx-overlay-persuasive h4.title {
    font-size: 18px !important;
  }
  .ltx-overlay-persuasive p.subtitle {
    font-size: 12px !important;
  }
}

@media (max-width: 768px) {
  .ltx-overlay-persuasive {
    opacity: 0.9 !important;
    background: rgba(0, 0, 0, 0.7) !important;
  }
  .ltx-overlay-persuasive .ltx-overlay-inner {
    transform: translateY(0) !important;
  }
}

/* ========================================
   UNIFY SERVICE CARDS HEIGHT
   ======================================== */
.services-sc.layout-product .swiper-wrapper {
  display: flex !important;
  align-items: stretch !important;
}

.services-sc.layout-product .swiper-slide {
  height: auto !important;
}

.services-sc.layout-product .ltx-inner {
  height: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  background: #fff !important;
  box-shadow: 0 5px 20px rgba(0, 0, 0, 0.05) !important;
}

.services-sc.layout-product .ltx-inner .description {
  flex-grow: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  padding: 25px !important;
  text-align: center !important;
}

.services-sc.layout-product .ltx-inner .description p {
  flex-grow: 1 !important;
  margin: 0 !important;
}

/* ========================================
   FIX VISIBILITA' TESTO OUTLINE NELLO SLIDER (es. "Audio")
   ======================================== */
/* Rimuovi il bordo e riempi il testo di bianco pieno (Desktop - SVG) */
.heading.header-outline-subheader text {
  stroke: none !important;
  stroke-width: 0 !important;
  fill: #ffffff !important;
  animation: none !important;
  filter: drop-shadow(0px 4px 10px rgba(0, 0, 0, 0.5));
}

/* Rimuovi animazione e resetta i path SVG in caso siano rimasti attivi */
.zs-enabled
  .ltx-zs-slider-inner.visible
  .heading.header-outline-subheader
  text {
  animation: none !important;
  stroke-dasharray: none !important;
  stroke-dashoffset: 0 !important;
}

/* Rimuovi il bordo e riempi il testo per la versione Mobile */
.heading.header-outline-subheader .ltx-mobile span,
.heading.header-outline-subheader .ltx-mobile {
  -webkit-text-stroke: 0 !important;
  color: #ffffff !important;
  text-shadow: 0px 4px 10px rgba(0, 0, 0, 0.5);
}

/* Nascondi lo spazio vuoto/sfondo ripetuto inutile presente in homepage */
.ltx-background-animation {
  display: none !important;
}

/* 
 * Overbeat Studio - Modern Design System 2026
 * A comprehensive aesthetic upgrade for a premium music studio look.
 */

:root {
  --primary-color: #dc2751; /* Colore base / bottoni (Fucsia) */
  --primary-glow: rgba(220, 39, 81, 0.4);
  --secondary-color: #1a1a1a;
  --dark-bg: #ffffff; /* Sfondo del sito normale */
  --glass-bg: rgba(255, 255, 255, 0.02);
  --glass-border: rgba(220, 39, 81, 0.15);
  --neon-blue: #00f2ff;
  --neon-pink: #ff00ff;
  --text-main: #666666; /* Testo normale grigio su sfondo bianco */
  --text-muted: #a3a3a3;
  --font-heading:
    "Outfit", "Inter", -apple-system, BlinkMacSystemFont, sans-serif;
}

/* --- Global Tipography Update --- */
body {
  font-family: "Inter", sans-serif;
  -webkit-font-smoothing: antialiased;
}

h1,
h2,
h3,
h4,
h5,
h6,
.ltx-h1,
.ltx-h2,
.ltx-h3,
h1.header,
h2.header,
h3.header,
h4.header,
h5.header,
h6.header {
  font-family: var(--font-heading) !important;
  letter-spacing: -0.02em !important;
}

/* Lasciamo la gestione globale dei colori al tema nativo 
   in modo da non rompere sfondi neri e form con testo scuro illeggibile.
   Forniamo l'accento colore (Fucsia) solo alle entità .color-main come da standard WPBakery */
.color-main,
.color-main * {
  color: var(--primary-color) !important;
}

/* --- Glassmorphism Cards --- */
.ltx-inner,
.services-sc .ltx-inner,
.wcpt-item,
.post-item {
  background: var(--glass-bg) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: 16px !important;
  transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1) !important;
  overflow: hidden;
}

.ltx-inner:hover {
  transform: translateY(-8px) !important;
  background: rgba(255, 255, 255, 0.05) !important;
  border-color: var(--primary-color) !important;
  box-shadow:
    0 20px 40px rgba(0, 0, 0, 0.4),
    0 0 20px var(--primary-glow) !important;
}

/* --- Neon Buttons --- */
.ltx-btn,
.button,
.btn,
.cta,
.add_to_cart_button,
.single_add_to_cart_button {
  border-radius: 50px !important;
  padding: 14px 28px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  transition: all 0.3s ease !important;
  position: relative !important;
  overflow: hidden !important;
}

.ltx-btn:not(.ltx-btn-white),
.button:not(.ltx-btn-white),
.cta,
.add_to_cart_button {
  background: linear-gradient(
    135deg,
    var(--primary-color) 0%,
    #a01c3b 100%
  ) !important;
  border: none !important;
  box-shadow: 0 4px 15px var(--primary-glow) !important;
}

.ltx-btn:hover,
.button:hover,
.cta:hover {
  box-shadow:
    0 8px 25px var(--primary-glow),
    0 0 15px var(--primary-color) !important;
  transform: scale(1.02) !important;
}

/* --- Hero Section Polish --- */
.ltx-h1.header {
  font-size: clamp(40px, 8vw, 80px) !important;
  background: linear-gradient(to bottom, #fff 0%, #a3a3a3 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-bottom: 20px !important;
}

/* --- Fix Foto ripetuta + The Experience Error Fix --- */
.vc_section,
.vc_row {
  overflow: hidden !important; /* Questo blocca l'immagine se esce dai bordi della sua sezione! */
}

.vc_column_container > .vc_column-inner {
  box-sizing: border-box;
  padding-left: 15px;
  padding-right: 15px;
  width: 100%;
  background-repeat: no-repeat !important; /* Evita foto in loop */
  background-size: cover !important;
  background-position: center !important;
}

/* --- Mobile Responsiveness --- */
@media (max-width: 768px) {
  .ltx-h1,
  h1 {
    font-size: 32px !important;
    line-height: 1.1 !important;
  }
  .ltx-h2,
  h2 {
    font-size: 26px !important;
  }
  .ltx-inner {
    margin-bottom: 20px !important;
  }
  ul,
  ol {
    padding-left: 20px !important;
  }
  li {
    margin-bottom: 10px !important;
  }
}

/* --- Social Proof Section Styling --- */
.ob-social-proof {
  padding: 80px 0;
  background: #080808;
  position: relative;
  overflow: hidden;
}

.ob-social-proof::before {
  content: "";
  position: absolute;
  top: -100px;
  right: -100px;
  width: 300px;
  height: 300px;
  background: radial-gradient(circle, var(--primary-glow) 0%, transparent 70%);
  z-index: 0;
}

.ob-testimonials {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 30px;
  margin-top: 50px;
}

.ob-testimonial-card {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--glass-border);
  padding: 30px;
  border-radius: 20px;
  position: relative;
}

.ob-testimonial-card i.quote {
  color: var(--primary-color);
  font-size: 24px;
  margin-bottom: 15px;
  display: block;
}

.ob-testimonial-content {
  font-style: italic;
  color: var(--text-muted);
  line-height: 1.6;
  margin-bottom: 20px;
}

.ob-testimonial-author {
  display: flex;
  align-items: center;
  gap: 15px;
}

.ob-testimonial-author img {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  object-fit: cover;
}

.ob-testimonial-info h4 {
  margin: 0 !important;
  font-size: 16px !important;
}

.ob-testimonial-info span {
  font-size: 12px;
  color: var(--primary-color);
  text-transform: uppercase;
  font-weight: 700;
}

.ob-logos-row {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 40px;
  margin-top: 60px;
  opacity: 0.6;
  filter: grayscale(1);
  transition: all 0.5s ease;
}

.ob-logos-row:hover {
  opacity: 1;
  filter: grayscale(0);
}

.ob-logos-row img {
  height: 30px;
  width: auto;
}

.ob-stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 20px;
  margin-top: 60px;
  text-align: center;
}

.ob-stat-item h3 {
  font-size: 36px !important;
  color: var(--primary-color) !important;
  margin: 0 !important;
}

.ob-stat-item p {
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text-muted);
}

/* --- Service Page Enhancements --- */
.ltx-check-list li {
  list-style: none !important;
  position: relative !important;
  padding-left: 30px !important;
  margin-bottom: 12px !important;
}

.ltx-check-list li::before {
  content: "→";
  position: absolute;
  left: 0;
  color: var(--primary-color);
  font-weight: 900;
}

/* --- Animated Accents --- */
@keyframes pulse-glow {
  0% {
    box-shadow: 0 0 5px var(--primary-glow);
  }
  50% {
    box-shadow: 0 0 20px var(--primary-glow);
  }
  100% {
    box-shadow: 0 0 5px var(--primary-glow);
  }
}

.pulse-accent {
  animation: pulse-glow 3s infinite;
}

/* ========================================
   FIX CONTRASTE TESTO E TITOLI (SITO/SERVIZI)
   ======================================== */
/* Forza i colori del testo per renderli leggibili sulle pagine con sfondo bianco (Ghost Production, ecc.) */
body.single-services .inner-page p,
body.single-services .inner-page li,
body.single-services .inner-page .note,
body.single-services .inner-page strong,
body.single-services
  .inner-page
  span:not(.color-main):not(.fa):not(.wpcf7-form-control-wrap),
body.single-services .inner-page summary,
body.single-services .inner-page .faq details {
  color: #1a1a1a !important;
}

body.single-services .inner-page h1,
body.single-services .inner-page h2,
body.single-services .inner-page h3,
body.single-services .inner-page h4,
body.single-services .inner-page h5,
body.single-services .inner-page h6 {
  color: #000000 !important;
}

/* Fix per i placeholder e campi del modulo di contatto sulle pagine a sfondo chiaro */
body.single-services .wpcf7-form-control::placeholder {
  color: #666666 !important;
}
body.single-services .wpcf7-form-control:not(.wpcf7-submit) {
  color: #1a1a1a !important;
  border-color: #cccccc !important;
  background-color: #fafafa !important;
}

/* ========================================
   HOMEPAGE: GESTIONE SEZIONE CASSE E PULSANTE STUDIO
   ======================================== */
/* Centra e sposta verso il basso l'immagine delle casse nella Home */
.home img[src*="about-monitors.png"] {
  margin-top: 50px !important;
  display: block !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Nascondi il pulsante "Il nostro studio" sotto la sezione dei servizi nella Home */
.home a.btn.btn-main[href*="/il-nostro-studio/"] {
  display: none !important;
}

/* ========================================
   HOMEPAGE: WORKING ROOMS
   ======================================== */
/* Nascondi l'intera sezione "The Experience / Working Rooms" come richiesto */
body.home .wpb-content-wrapper > section.vc_section:nth-of-type(3) {
  display: none !important;
}

/* Rendi i titoli visibili (Control Room, etc.) all'interno della box bianca */
.home .ltx-portfolio-item .header .ltx-title,
.home .ltx-portfolio-item .ltx-description h3.ltx-title,
.home .ltx-portfolio-item .ltx-portfolio-content .ltx-title-tag,
.home .ltx-portfolio-item .ltx-portfolio-content h3.ltx-header {
  color: #111111 !important;
  font-weight: 900 !important;
  margin-top: 0 !important;
  margin-bottom: 25px !important;
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* Rendi il testo descrittivo visibile (La Control Room...) */
.home .ltx-portfolio-item .ltx-description,
.home .ltx-portfolio-item .ltx-description p,
.home .ltx-portfolio-item .ltx-portfolio-content p,
.home .ltx-portfolio-item p,
.home .ltx-portfolio-item .text {
  color: #333333 !important;
  font-size: 16px !important;
  line-height: 1.6 !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* Rendi il prezzo più grande e professionale */
.home .ltx-portfolio-item .ltx-price,
.home .ltx-portfolio-item .ltx-price .ltx-value,
.home .ltx-portfolio-item .ltx-description .ltx-price,
.home .ltx-portfolio-item .ltx-portfolio-content .ltx-price {
  font-size: 72px !important;
  font-weight: 900 !important;
  color: #c31e39 !important;
  display: block !important;
  margin: 30px 0 !important;
  letter-spacing: -2px !important;
  line-height: 1 !important;
}

/* Simbolo dell'euro e periodo */
.home .ltx-portfolio-item .ltx-price span.symbol,
.home .ltx-portfolio-item .ltx-price span.period,
.home .ltx-portfolio-item .ltx-price .ltx-currency,
.home .ltx-portfolio-item .ltx-price .ltx-type {
  font-size: 36px !important;
  font-weight: 700 !important;
  color: #c31e39 !important;
  display: inline-block !important;
  vertical-align: top !important;
  margin-top: 10px !important;
}

/* ========================================
   SINGLE PORTFOLIO PAGE: WORKING ROOMS
   (E.g. La pagina Control Room diretta)
   ======================================== */
.single-portfolio .heading-large h4.header,
.single-portfolio .heading h4.header {
  color: #1a1a1a !important;
}

.single-portfolio .wpb_text_column p {
  color: #333333 !important;
  font-size: 16px !important;
  line-height: 1.6 !important;
}

.single-portfolio .heading.header-price h5.subheader {
  font-size: 72px !important;
  font-weight: 900 !important;
  color: #c31e39 !important;
  line-height: 1 !important;
  margin-bottom: 0 !important;
  letter-spacing: -2px !important;
  display: inline-block !important;
}

.single-portfolio .heading.header-price h5.subheader span {
  font-size: 36px !important;
  vertical-align: super !important;
}

.single-portfolio .heading.header-price h6.header {
  font-size: 30px !important;
  font-weight: 700 !important;
  color: #c31e39 !important;
  display: inline-block !important;
  text-transform: lowercase !important;
  margin-top: 0 !important;
  margin-left: 5px !important;
}

/* Fix per l'immagine di sfondo che sporge in basso */
.home .ltx-portfolio-section,
.home section.vc_custom_1610640693510,
.home .ltx-portfolio-tabs {
  padding-bottom: 0px !important;
  margin-bottom: 0px !important;
  overflow: hidden !important;
}

/* Rimuovi eventuali margini negativi o padding che spingono lo sfondo fuori */
.home .ltx-portfolio-item .ltx-portfolio-content {
  margin-bottom: 0 !important;
  padding-bottom: 50px !important;
}

/* ========================================
   GLOBAL FIXES (Feb 2026 Home Graphic Fix)
   ======================================== */

/* 1. Header e Sezione Hero */
/* Spaziatura Eccessiva e rimosso spazio vuoto sopra Hero */
.home .entry-content .wpb-content-wrapper > .vc_row:nth-of-type(1),
.home .entry-content .wpb-content-wrapper > br,
.home .entry-content .wpb-content-wrapper > .vc_row:nth-of-type(2) {
  display: none !important;
  margin: 0 !important;
  padding: 0 !important;
  height: 0 !important;
}
.home .entry-content .wpb-content-wrapper > .vc_row.bg-color-black {
  margin-top: 0 !important;
}

/* Sovrapposizione Sticky Header */
html {
  scroll-padding-top: 110px !important;
}
.vc_section,
.vc_row {
  scroll-margin-top: 110px !important;
}

/* 2. Sezione Servizi Professionali (Carousel) */
/* Unificazione Stile Card, dark per tutte con testo chiaro e bottoni premium */
.services-sc.layout-product .ltx-inner {
  background: #1a1a1a !important;
  border-color: rgba(255, 255, 255, 0.05) !important;
}
.services-sc.layout-product .description,
.services-sc.layout-product .description * {
  color: #ffffff !important;
}
.services-sc.layout-product .btn {
  background: var(--primary-color) !important;
  color: #ffffff !important;
  border: none !important;
  font-size: 11px !important;
  padding: 10px 20px !important;
  opacity: 1 !important;
}
/* Allineamento Frecce Carousel */
.services-sc .arrows {
  position: absolute !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 100% !important;
  z-index: 100 !important;
  pointer-events: none !important;
  margin: 0 !important;
}
.services-sc .arrows a {
  pointer-events: auto !important;
  position: absolute !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  background: rgba(0, 0, 0, 0.5) !important;
}
.services-sc .arrows .arrow-left {
  left: 10px !important;
}
.services-sc .arrows .arrow-right {
  right: 10px !important;
}

/* 3. Artisti Partner (Orientamento Testo e Margini) */
/* Reset rotazione nomi */
.ltx-team .header,
.ltx-clients .header,
.ltx-team.layout-side .header {
  transform: none !important;
  writing-mode: unset !important;
  position: relative !important;
  left: auto !important;
  right: auto !important;
  bottom: auto !important;
  padding: 15px 0 0 0 !important;
  white-space: normal !important;
  display: block !important;
  text-align: center !important;
  width: 100% !important;
}
.ltx-team .ltx-item,
.ltx-clients .ltx-item {
  overflow: hidden !important;
  padding-bottom: 20px !important;
}
.ltx-team .ltx-photo,
.ltx-clients .ltx-photo {
  width: 100% !important;
  height: auto !important;
}

/* 4. Footer e Newsletter */
/* Fix Bottone Subscribe Troncato e Sovrapposto all'input */
.footer-widget form,
.footer-widget .wpcf7-form,
.footer-widget .mc4wp-form {
  display: flex !important;
  flex-wrap: wrap !important;
  position: relative !important;
  overflow: hidden !important;
}
.footer-widget form *,
.footer-widget .wpcf7-form *,
.footer-widget .mc4wp-form * {
  position: static !important; /* Force no absolute overlap */
}
.footer-widget input[type="email"],
.footer-widget .wpcf7-text {
  width: 100% !important;
  margin-bottom: 10px !important;
  padding: 10px !important;
  border-radius: 4px !important;
  box-sizing: border-box !important;
}
.footer-widget input[type="submit"],
.footer-widget button[type="submit"],
.footer-widget .btn {
  width: 100% !important;
  padding: 15px !important;
  border-radius: 4px !important;
  white-space: normal !important;
  height: auto !important;
  line-height: normal !important;
  text-indent: 0 !important;
  font-size: 14px !important;
  background: var(--primary-color) !important;
  color: #fff !important;
  box-sizing: border-box !important;
}

/* Contatti Footer Spaziatura Icone */
.footer-widget ul.ltx-contact-list li {
  display: flex !important;
  flex-direction: row !important;
  align-items: flex-start !important;
  margin-bottom: 15px !important;
  padding-left: 0 !important;
}
.footer-widget ul.ltx-contact-list li span.fa,
.footer-widget ul.ltx-contact-list li i {
  position: relative !important;
  margin-right: 15px !important;
  margin-top: 4px !important;
  width: 16px !important;
  text-align: center !important;
}
/* Go Top Button Glitch */
.go-top,
#go-top,
.ltx-go-top {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 55px !important;
  height: 55px !important;
  background: linear-gradient(135deg, #e91e63, #880e4f) !important;
  border-radius: 50% !important;
  box-shadow:
    0 10px 25px rgba(233, 30, 99, 0.4),
    inset 0 2px 5px rgba(255, 255, 255, 0.3) !important;
  backdrop-filter: blur(5px) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
}
.go-top::before,
.go-top::after,
#go-top::before,
#go-top::after,
.ltx-go-top::before,
.ltx-go-top::after {
  display: none !important;
}
.go-top span,
.go-top i,
#go-top span,
#go-top i,
.ltx-go-top span,
.ltx-go-top i {
  opacity: 1 !important;
  transform: none !important;
  color: #fff !important;
}

/* 5. Sezione Galleria / Instagram */
.ltx-instagram,
.sbi_custom_gallery,
#sbi_images {
  margin-top: 60px !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 5px !important;
}
.ltx-instagram .item,
#sbi_images .sbi_item {
  margin: 0 !important;
  padding: 0 !important;
  width: calc(25% - 5px) !important;
}
.ltx-instagram .item img,
.ltx-gallery .item img,
#sbi_images .sbi_item img,
.sbi_item img {
  aspect-ratio: 1/1 !important;
  object-fit: cover !important;
  height: 100% !important;
  width: 100% !important;
}
@media (max-width: 768px) {
  .ltx-instagram .item,
  #sbi_images .sbi_item {
    width: calc(50% - 5px) !important;
  }
}

/* ========================================
   GHOST TRACK: FIX LEGGIBILITA' TESTO SU SFONDO CHIARO
   ======================================== */
/* Forza colore nero/scuro per titoli e testo nella sidebar (carrello, categorie) */
body.custom-ghost-track-page .widget-area .header-widget,
body.custom-ghost-track-page .widget-area .widget-title,
body.custom-ghost-track-page .widget-area h1,
body.custom-ghost-track-page .widget-area h2,
body.custom-ghost-track-page .widget-area h3,
body.custom-ghost-track-page .widget-area h4,
body.custom-ghost-track-page .widget-area h5,
body.custom-ghost-track-page .widget-area h6 {
  color: #111111 !important;
}

body.custom-ghost-track-page .widget-area p,
body.custom-ghost-track-page .widget-area span,
body.custom-ghost-track-page .widget-area strong,
body.custom-ghost-track-page .widget-area li,
body.custom-ghost-track-page .widget-area a {
  color: #333333 !important;
}

/* Eccezione: mantenere i bottoni della sidebar scritti in bianco */
body.custom-ghost-track-page .widget-area a.button,
body.custom-ghost-track-page .widget-area button.button,
body.custom-ghost-track-page .widget-area .btn {
  color: #ffffff !important;
}

/* Colore scuro per il prezzo barrato (invece che bianco/grigio troppo chiaro) */
body.custom-ghost-track-page table del .amount,
body.custom-ghost-track-page table del {
  color: #777777 !important;
}

/* Colore bianco per i controlli di paginazione WooCommerce / DataTables come richiesto */
body.custom-ghost-track-page
  .wc-product-table-wrapper
  .dataTables_paginate
  .paginate_button,
body.custom-ghost-track-page
  .wcpt-table-wrapper
  .dataTables_paginate
  .paginate_button {
  color: #ffffff !important;
}

body.custom-ghost-track-page
  .wc-product-table-wrapper
  .dataTables_paginate
  .paginate_button.current,
body.custom-ghost-track-page
  .wcpt-table-wrapper
  .dataTables_paginate
  .paginate_button:hover {
  color: #ffffff !important;
}

/* Colore scuro per le colonne BPM e Tonalità nella tabella */
body.custom-ghost-track-page table.wc-product-table td.col-col_bpm,
body.custom-ghost-track-page table.wc-product-table td.col-col_tonalita {
  color: #333333 !important;
  font-weight: 600 !important;
}

/* ========================================
   CONTATTI: FIX LEGGIBILITA' E ASPETTO PREMIUM
   ======================================== */
/* Contenitore principale: rimuove testo giustificato inline e dà respiro */
.page-id-25 .wpb_text_column > .wpb_wrapper > div {
  text-align: center !important;
  max-width: 900px !important;
  padding: 10px 0 !important;
}

/* Titoli Eleganti e d'Impatto (solo contenuto, non testata) */
.page-id-25 .entry-content h1,
.page-id-25 .wpb_text_column h1 {
  color: #111111 !important;
  font-size: 48px !important;
  font-weight: 900 !important;
  letter-spacing: -2px !important;
  line-height: 1.1 !important;
  margin-bottom: 25px !important;
  text-transform: uppercase !important;
}

.page-id-25 .entry-content h2,
.page-id-25 .entry-content h3,
.page-id-25 .wpb_text_column h2,
.page-id-25 .wpb_text_column h3 {
  color: #111111 !important;
  font-size: 32px !important;
  font-weight: 800 !important;
  letter-spacing: -1px !important;
  line-height: 1.2 !important;
  margin-top: 55px !important;
  margin-bottom: 20px !important;
}

/* Supporto per titoli minori, form e sidebar */
.page-id-25 h4,
.page-id-25 h5,
.page-id-25 h6 {
  color: #111111 !important;
}

/* Paragrafi Ariosi e Leggibili (Premium Look) */
.page-id-25 p,
.page-template-default.page-id-25 .entry-content p,
.page-template-default.page-id-25 .wpb_text_column p {
  color: #444444 !important;
  font-size: 19px !important; /* Testo più grande e comodo da leggere */
  line-height: 1.8 !important; /* Interlinea distesa */
  letter-spacing: 0.2px !important;
  margin-bottom: 24px !important;
}

/* Dettagli Premium su Grassetto e Link */
.page-id-25 .wpb_text_column p strong {
  color: #111111 !important;
  font-weight: 700 !important;
}

.page-id-25 .wpb_text_column p a {
  color: var(--main, #dc2751) !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  border-bottom: 2px solid transparent !important;
  transition: all 0.3s ease !important;
}

.page-id-25 .wpb_text_column p a:hover {
  color: #111111 !important;
  border-bottom: 2px solid var(--main, #dc2751) !important;
}

/* Rimozione spazi eccessivi (Empty space) tra i blocchi in modo sicuro */
.page-id-25 .es-resp,
.page-id-25 .vc_section > .vc_row:nth-of-type(2),
.page-id-25 .vc_section > .vc_row:nth-of-type(3) {
  display: none !important;
}

/* Aggiungi un margine morbido alla prima riga di testi per dare aria dopo la testata */
.page-id-25 .vc_section > .vc_row:nth-of-type(1) {
  margin-bottom: 50px !important;
}

/* Form dei Contatti - Testo Inserito e Menu Tendina */
.page-id-25 .wpcf7-form-control,
.page-id-25 input[type="text"],
.page-id-25 input[type="email"],
.page-id-25 textarea,
.page-id-25 select {
  color: #111111 !important;
}

/* Placeholder scuro per il form dei contatti */
.page-id-25 .wpcf7-form-control::placeholder,
.page-id-25 input[type="text"]::placeholder,
.page-id-25 input[type="email"]::placeholder,
.page-id-25 textarea::placeholder {
  color: #555555 !important;
  opacity: 1 !important;
}

/* Orari di lavoro (labels) */
.page-id-25 .ltx-working-hours ul li .label,
.page-id-25 ul li strong,
.page-id-25 dt,
.page-id-25 dd {
  color: #222222 !important;
}

/* ========================================
   FIX VISIBILITA' TESTO SU SFONDO CHIARO O SCURO
   Ripristino per rendere operativo il sito:
   ======================================== */
.ltx-records .heading.header-subheader .header,
.ltx-records .heading.header-subheader .subheader,
.ltx-records .heading.header-subheader h3 {
  color: #1a1a1a !important;
}
.ltx-records p,
.ltx-records .text-md,
.ltx-records .text-lg,
.ltx-records .text-sm {
  color: #333333 !important;
}

.services-sc .item .in {
  background: #111 !important; /* Make service cards dark to show white text */
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.5) !important;
  border-radius: 12px;
}
.services-sc .item h5.header {
  color: #fff !important;
}
.services-sc .item .text {
  color: #ccc !important;
}

/* Fix "Working Rooms" o sezioni con classe simile diventsndo scure per contrasto */
/* .vc_section[data-vc-full-width="true"] { 
    Se l'utente voleva sfondo scuro sui Servizi Professionali per test...
} */

/* ========================================
   EMERGENCY FIX: VISIBILITA' TESTI E COLORI GLOBALI
   Ripristino leggibilita' dopo downgrade del 21 Febbraio
   ======================================== */

/* 1. Hero Slogan (sotto il Menu principale) */
.header-wrapper .header h1,
.header-wrapper .header h2,
.header-wrapper .header h3,
.header-wrapper .header p,
.header-wrapper .header span,
.top-slider .slide-content h1,
.top-slider .slide-content p {
  color: #1a1a1a !important;
  text-shadow: none !important;
}

/* 2. Testi standard su sfondo chiaro */
body,
.entry-content p,
.wpb_wrapper p,
.wpb_text_column p,
.vc_column-inner p,
.text-md,
.text-lg,
.text-sm {
  color: #333333 !important;
}

/* 3. Titoli standard su sfondo chiaro (Servizi, Working Rooms, Testi descrittivi) */
h1,
h2,
h3,
h4,
h5,
h6,
.wpb_wrapper h1,
.wpb_wrapper h2,
.wpb_wrapper h3,
.wpb_wrapper h4,
.wpb_wrapper h5,
.wpb_wrapper h6,
.vc_column-inner h1,
.vc_column-inner h2,
.vc_column-inner h3,
.vc_column-inner h4,
.vc_column-inner h5,
.vc_column-inner h6,
.heading.header-subheader .header,
.heading.header-subheader .subheader {
  color: #111111 !important;
}

/* 4. Link Generici */
a {
  color: #d93b65 !important; /* Colore brand pink/red */
}
a:hover {
  color: #111111 !important;
}

/* 5. Eccezioni per sezioni scure (es. Footer, Counter, Sezione Nera Video Premium se presente) */
.ltx-footer-wrapper *,
.ltx-footer-wrapper p,
.ltx-footer-wrapper h1,
.ltx-footer-wrapper h2,
.ltx-footer-wrapper h3,
.ltx-footer-wrapper h4,
.ltx-footer-wrapper a,
.ltx-footer-wrapper strong,
.ltx-footer-wrapper em,
.ltx-footer-wrapper em strong,
.ltx-footer-wrapper .wpb_wrapper p em strong,
footer.copyright-block,
footer.copyright-block p,
footer.copyright-block strong,
footer.copyright-block *,
body .copyright-block p,
body .copyright-block strong {
  color: #ffffff !important;
}
.ltx-footer-wrapper a:hover {
  color: #d93b65 !important;
}

/* Cofanetti Info scuri (se presenti) */
.bg-color-black p,
.bg-color-black h1,
.bg-color-black h2,
.bg-color-black h3,
.bg-color-black h4,
.bg-color-second p,
.bg-color-second h1,
.bg-color-second h2,
.bg-color-second h3,
.bg-color-second h4,
.obs-premium-section p,
.obs-premium-section h1,
.obs-premium-section h2,
.obs-premium-section h3,
.obs-premium-section h4 {
  color: #ffffff !important;
}

/* 6. Servizi Professionali (Mix & Mastering, Ghost) - Box testo */
.services-sc .item .text,
.services-sc .item p {
  color: #444444 !important;
}
.services-sc .item h5.header,
.services-sc .item .header h5 {
  color: #111111 !important;
}

/* Rendi lo sfondo grigio chiaro ai box dei servizi per staccarli dallo sfondo bianco */
.services-sc .item .in {
  background-color: #f8f9fa !important;
  border: 1px solid #eeeeee !important;
}

/* IMPORTANT: FORZA Colore scuro sui testi per la Home Page e i Servizi */

/* Slogan in Home e Testi in generale */
.page-id-7925 .wpb_text_column .wpb_wrapper p,
.page-id-7925 .wpb_text_column .wpb_wrapper span,
.page-id-7925 .wpb_text_column .wpb_wrapper h1,
.page-id-7925 .wpb_text_column .wpb_wrapper h2,
.page-id-7925 .wpb_text_column .wpb_wrapper h3,
.page-id-7925 .wpb_text_column .wpb_wrapper h4,
.page-id-7925 .wpb_text_column .wpb_wrapper h5,
.page-id-7925 .wpb_text_column .wpb_wrapper h6,
.page-id-7925 .wpb_text_column p,
.page-id-7925 p,
.page-id-7925 span,
.page-id-7925 .vc_column-inner p,
.page-id-7925 .text-md,
.page-id-7925 .text-lg,
.page-id-7925 .text-sm,
.page-id-7925 .ltx-icon-text,
.page-id-7925 .ltx-icon-text p,
.page-id-7925 .ltx-icon-text .text,
.page-id-7925 .wpb_wrapper .text,
.page-id-7925 .services-sc p,
.page-id-7925 .services-sc .text,
.page-id-7925 .obs-premium-section p,
.page-id-7925 .vc_row .wpb_wrapper p {
  color: #444444 !important;
}

/* Titoli Generali, per renderli leggibili (nero su bianco) */
.page-id-7925 h1,
.page-id-7925 h2,
.page-id-7925 h3,
.page-id-7925 h4,
.page-id-7925 h5,
.page-id-7925 h6,
.page-id-7925 .heading .header,
.page-id-7925 .heading .subheader,
.page-id-7925 .ltx-icon-text h4,
.page-id-7925 .ltx-icon-text h5,
.page-id-7925 .ltx-icon-text .header {
  color: #111111 !important;
}

/* Fix Colore HEADER pagina singola / Breadcrumbs su Sfondo Scuro */
.page-header h1,
.page-header h2,
.page-header h3,
.page-header h4,
.page-header h5,
.page-header h6,
.page-header .breadcrumbs,
.page-header .breadcrumbs *,
.page-header span {
  color: #ffffff !important;
}

/* ECCEZIONI PER AREE SCURE: menu & popup */
.header-wrapper *,
.header-wrapper a,
.nav-menu *,
.vc_row.bg-color-black *,
.vc_row.bg-color-black p,
.vc_row.bg-color-black h1,
.vc_row.bg-color-black h2,
.vc_row.bg-color-black h3,
.vc_row.bg-color-black h4,
.vc_row.bg-color-black span,
.vc_row.bg-color-second *,
.vc_row.bg-color-second p,
.vc_row.bg-color-second h1,
.vc_row.bg-color-second h2,
.vc_row.bg-color-second h3,
.vc_row.bg-color-second h4,
.vc_row.bg-color-second span,
.services-sc .item .in *,
#obsPopup,
#obsPopup *,
#obsPopup p,
#obsPopup h2,
#obsPopup span {
  color: inherit; /* Reset exceptions */
}

/* Colore Fucsia per i titoli nel Footer (Newsletter, Contatti, ecc.) */
.ltx-footer-wrapper h1,
.ltx-footer-wrapper h2,
.ltx-footer-wrapper h3,
.ltx-footer-wrapper h4,
.ltx-footer-wrapper h5,
.ltx-footer-wrapper h6,
.ltx-footer-wrapper .wpb_wrapper h1,
.ltx-footer-wrapper .wpb_wrapper h2,
.ltx-footer-wrapper .wpb_wrapper h3,
.ltx-footer-wrapper .wpb_wrapper h4,
.ltx-footer-wrapper .wpb_wrapper h5,
.ltx-footer-wrapper .wpb_wrapper h6,
.ltx-footer-wrapper .widget-title {
  color: #d93b65 !important;
}

/* Fix specifico per Cards dei Servizi Professionali Scuri (se li vogliamo con sfondo scuro e testo chiaro) */
.services-sc .item .in {
  background-color: #1a1a1a !important; /* Sfondo Scuro */
}
.services-sc .item .in h5,
.services-sc .item .in .header {
  color: #ffffff !important;
}
.services-sc .item .in p,
.services-sc .item .in .text {
  color: #cccccc !important;
}

/* Tasto rosso/pink globale */
.btn,
.button,
input[type="submit"],
.wpcf7-submit,
a.button {
  color: #ffffff !important;
}

/* ========================================================
   ROBUST FIX: COLORI TESTI, TITOLI E LINK (Working Rooms, ecc.)
   Richiesta dell'utente: Mantenere leggibili testi su sfondo chiaro.
======================================================== */

/* Fix aggressivo per testi (paragrafi, span, div di testo) all'interno delle sezioni chiare */
.wpb_wrapper .wpb_text_column p,
.wpb_wrapper .wpb_text_column span,
.wpb_text_column p,
.wpb_content_element p,
.icon-box p,
.ltx-icon-text p,
.ltx-icon-text .text,
.wpb_wrapper p,
.vc_column-inner p {
  color: #3f3f3f !important; /* Grigio scuro ben leggibile */
}

/* Fix per i Titoli in quelle sezioni */
.wpb_wrapper .wpb_text_column h1,
.wpb_wrapper .wpb_text_column h2,
.wpb_wrapper .wpb_text_column h3,
.wpb_wrapper .wpb_text_column h4,
.wpb_wrapper .wpb_text_column h5,
.wpb_wrapper .wpb_text_column h6,
.icon-box h4,
.icon-box h5,
.icon-box h6,
.ltx-icon-text h4,
.ltx-icon-text h5,
.ltx-icon-text h6,
.ltx-icon-text .header,
.wpb_wrapper h1,
.wpb_wrapper h2,
.wpb_wrapper h3,
.wpb_wrapper h4,
.wpb_wrapper h5,
.wpb_wrapper h6 {
  color: #111111 !important; /* Nero acceso per i titoli */
}

/* Link in linea nel testo visibili */
.wpb_wrapper p a,
.wpb_text_column a,
.entry-content a {
  color: #d93b65 !important;
  text-decoration: underline !important;
  font-weight: bold;
}
.wpb_wrapper p a:hover,
.wpb_text_column a:hover,
.entry-content a:hover {
  color: #111111 !important;
}

/* Reset per sezioni nativamente oscure per non rompere il testo bianco */
.bg-color-black .wpb_wrapper p,
.bg-color-black .wpb_text_column p,
.bg-color-black .wpb_wrapper h1,
.bg-color-black .wpb_wrapper h2,
.bg-color-black .wpb_wrapper h3,
.bg-color-black .wpb_wrapper h4,
.bg-color-black .wpb_wrapper h5,
.bg-color-black .wpb_wrapper h6,
.bg-color-second .wpb_wrapper p,
.bg-color-second .wpb_text_column p,
.bg-color-second .wpb_wrapper h1,
.bg-color-second .wpb_wrapper h2,
.bg-color-second .wpb_wrapper h3,
.bg-color-second .wpb_wrapper h4,
.bg-color-second .wpb_wrapper h5,
.bg-color-second .wpb_wrapper h6,
.ltx-footer-wrapper .wpb_wrapper p,
.ltx-footer-wrapper .wpb_wrapper h1,
.ltx-footer-wrapper .wpb_wrapper h2,
.ltx-footer-wrapper .wpb_wrapper h3,
.ltx-footer-wrapper .wpb_wrapper h4,
.ltx-footer-wrapper .wpb_wrapper h5,
.ltx-footer-wrapper .wpb_wrapper h6,
.services-sc .item .in p,
.services-sc .item .in .text,
.services-sc .item .in h5,
.services-sc .item .in .header,
.header-wrapper * {
  color: #ffffff !important;
}

/* ========================================================
   1. GO TOP BUTTON - ULTRA MODERNO (SQUARE & SHARP ICON)
======================================================== */
.go-top,
#go-top,
.ltx-go-top {
  position: fixed !important;
  bottom: 30px !important;
  right: 30px !important;
  width: 48px !important;
  height: 48px !important;
  background: #dc2751 !important;
  color: #ffffff !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 0px !important; /* Tasto quadrato moderno */
  border: none !important;
  box-shadow: 0 5px 15px rgba(220, 39, 81, 0.4) !important;
  z-index: 9999 !important;
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1) !important;
}

.go-top:hover,
#go-top:hover,
.ltx-go-top:hover {
  background: #111111 !important;
  color: #ffffff !important;
  transform: translateY(-6px) !important;
  box-shadow: 0 15px 25px rgba(17, 17, 17, 0.4) !important;
}

/* Elimino i testi e vecchia icona costringendo lo stile icona freccia - FontAwesome */
.go-top span::before,
.go-top i::before,
#go-top span::before,
#go-top i::before,
.ltx-go-top span::before,
.ltx-go-top i::before,
.go-top::before,
#go-top::before,
.ltx-go-top::before {
  content: "\f062" !important; /* fa-arrow-up */
  font-family: "FontAwesome" !important;
  font-weight: 400 !important;
  font-size: 20px !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: thin !important;
  text-align: center !important;
  display: inline-block !important;
  font-style: normal !important;
}

/* Nascondo il testo originale del pulsante (es. "Go top") e i livelli a forma di barrette del tema originale */
.go-top .txt,
#go-top .txt,
.ltx-go-top .txt,
.go-top #ltx-go-top-levels,
#go-top #ltx-go-top-levels,
.ltx-go-top #ltx-go-top-levels {
  display: none !important;
}

.go-top:hover span::before,
.go-top:hover i::before,
#go-top:hover span::before,
#go-top:hover i::before,
.ltx-go-top:hover span::before,
.ltx-go-top:hover i::before {
  transform: translateY(-2px) !important;
  display: block !important;
}

/* ========================================================
   2. LOGHI SOCIAL DEL FOOTER BIANCHI
======================================================== */
.ltx-footer-wrapper .social-icons-list li a .ltx-ic,
.ltx-footer-wrapper .ltx-social ul li a,
.ltx-footer-wrapper .ltx-social ul li a span,
.ltx-footer-wrapper .ltx-social ul li a i,
.ltx-footer-wrapper .widget_nav_menu ul li a {
  color: #ffffff !important;
}

.ltx-footer-wrapper .ltx-social ul li a {
  border-color: rgba(255, 255, 255, 0.3) !important;
  background: rgba(255, 255, 255, 0.05) !important;
}

.ltx-footer-wrapper .ltx-social ul li a:hover {
  background: #ffffff !important;
  color: #111111 !important;
  border-color: #ffffff !important;
}

.ltx-footer-wrapper .ltx-social ul li a:hover span,
.ltx-footer-wrapper .ltx-social ul li a:hover i {
  color: #111111 !important;
}

/* ========================================================
   3. CASELLA SOTTOSCRIZIONE NEWSLETTER FOOTER (MODERNA)
======================================================== */
.ltx-footer-wrapper .mc4wp-form {
  background: linear-gradient(
    135deg,
    rgba(20, 20, 20, 0.8) 0%,
    rgba(10, 10, 10, 0.9) 100%
  ) !important;
  padding: 25px !important;
  border-radius: 15px !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  box-shadow:
    0 15px 35px rgba(233, 30, 99, 0.2),
    inset 0 2px 10px rgba(255, 255, 255, 0.05) !important;
  transition: all 0.4s ease !important;
}
.ltx-footer-wrapper .mc4wp-form:hover {
  box-shadow:
    0 20px 40px rgba(233, 30, 99, 0.35),
    inset 0 2px 10px rgba(255, 255, 255, 0.08) !important;
}

.ltx-footer-wrapper .mc4wp-form-fields p {
  margin-bottom: 15px !important;
}

.ltx-footer-wrapper .mc4wp-form input[type="email"] {
  width: 100% !important;
  background: rgba(0, 0, 0, 0.4) !important;
  border: 1px solid rgba(255, 255, 255, 0.2) !important;
  color: #ffffff !important;
  padding: 15px 20px !important;
  border-radius: 50px !important;
  font-size: 15px !important;
  transition: all 0.3s ease !important;
  box-sizing: border-box !important;
}

.ltx-footer-wrapper .mc4wp-form input[type="email"]:focus {
  border-color: #d93b65 !important;
  background: rgba(0, 0, 0, 0.8) !important;
  box-shadow: 0 0 15px rgba(217, 59, 101, 0.3) !important;
  outline: none !important;
}

.ltx-footer-wrapper .mc4wp-form input[type="submit"],
.ltx-footer-wrapper .mc4wp-form .btn,
.ltx-footer-wrapper .mc4wp-form button {
  width: 100% !important;
  background: #d93b65 !important;
  color: #ffffff !important;
  border: none !important;
  padding: 15px 20px !important;
  border-radius: 50px !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  cursor: pointer !important;
  transition: all 0.3s ease !important;
  margin-top: 10px !important;
  box-sizing: border-box !important;
}

.ltx-footer-wrapper .mc4wp-form input[type="submit"]:hover,
.ltx-footer-wrapper .mc4wp-form .btn:hover,
.ltx-footer-wrapper .mc4wp-form button:hover {
  background: #c2185b !important;
  color: #ffffff !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 10px 25px rgba(233, 30, 99, 0.5) !important;
}

/* ========================================================
   4. MENU BIANCO
======================================================== */
nav.navbar ul.nav > li > a,
nav.navbar ul.nav > li > a > span,
.header-wrapper .nav-menu > li > a,
.header-wrapper .nav-menu > li > a > span {
  color: #ffffff !important;
  font-weight: 600 !important;
}

/* ========================================================
   5. FONT MODERNO OVUNQUE
======================================================== */
@import url("https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700;800;900&display=swap");

body,
p,
a:not(.fa):not(.ltx-icon):not([class*="icon"]),
span:not(.fa):not(.ltx-icon):not([class*="icon"]),
div:not(.fa):not(.ltx-icon):not([class*="icon"]),
input,
button,
textarea,
select {
  font-family: "Montserrat", sans-serif !important;
}

h1,
h2,
h3,
h4,
h5,
h6,
.header,
.title {
  font-family: "Montserrat", sans-serif !important;
  font-weight: 800 !important;
  letter-spacing: -1px !important;
}

/* ========================================================
   6. ALLINEAMENTO ICONE FOOTER (Email, Posizione, Telefono)
======================================================== */
.ltx-footer-wrapper .ltx-icon-text {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
  justify-content: center !important;
}

.ltx-footer-wrapper .ltx-icon-text .ltx-icon,
.ltx-footer-wrapper .ltx-icon-text i {
  float: none !important;
  margin: 0 auto 15px auto !important;
  display: inline-block !important;
  font-size: 32px !important;
  color: #d93b65 !important;
}

.ltx-footer-wrapper .ltx-icon-text .text,
.ltx-footer-wrapper .ltx-icon-text .header {
  text-align: center !important;
  margin-left: 0 !important;
}

/* ========================================================
   7. FRECCE TAGLIATE - SPOSTATO NEL BLOCCO 10
======================================================== */

/* ========================================================
   8. TESTO BIANCO DEI PULSANTI (es: Saperne di più)
======================================================== */
.btn-black,
.btn-main,
.btn:not(.btn-white),
a.btn:not(.btn-white),
button.btn,
button.btn-black {
  color: #ffffff !important;
}

/* ========================================================
   9. TITOLO OVERBEAT ARTISTI PARTNER IN BIANCO/FUCSIA
======================================================== */
.ltx-clients-sc h3.header,
.ltx-team-sc h3.header,
.page-id-7925 .ltx-team h3.header {
  color: #ffffff !important;
}

.ltx-clients-sc h3.header span,
.ltx-team-sc h3.header span,
.page-id-7925 .ltx-team h3.header span {
  color: #d93b65 !important;
}

/* ========================================================
   10. FIX DEFINITIVO FRECCE (TESTIMONIAL E PARTNER) - ALTEZZA 50 E FIX OVERFLOW
======================================================== */
.ltx-testimonials .arrows,
.ltx-team .arrows,
.ltx-clients .arrows,
.ltx-testimonials-sc .arrows,
.ltx-team-sc .arrows,
.ltx-clients-sc .arrows {
  position: absolute !important;
  top: 50% !important;
  left: 0 !important;
  width: 100% !important;
  margin-top: -22px !important; /* height/2 to perfectly center them */
  z-index: 9999 !important;
  pointer-events: none !important; /* let clicks pass through to slider if not on arrows */
}

.ltx-testimonials .arrows a,
.ltx-team .arrows a,
.ltx-clients .arrows a,
.ltx-testimonials-sc .arrows a,
.ltx-team-sc .arrows a,
.ltx-clients-sc .arrows a {
  pointer-events: auto !important;
  background-color: rgba(0, 0, 0, 0.4) !important;
  color: rgb(204, 51, 102) !important;
  border-radius: 50% !important;
  width: 45px !important;
  height: 45px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  opacity: 1 !important;
  position: absolute !important;
  box-shadow: none !important;
  margin: 0 !important;
  font-size: 16px !important;
  border: 2px solid rgb(255, 255, 255) !important;
  transition: all 0.3s ease !important;
}

.ltx-testimonials .arrows a:before,
.ltx-team .arrows a:before,
.ltx-clients .arrows a:before {
  font-size: 16px !important;
}

.ltx-testimonials .arrows a.arrow-left,
.ltx-team .arrows a.arrow-left,
.ltx-clients .arrows a.arrow-left {
  left: 0px !important;
  right: auto !important;
}

.ltx-testimonials .arrows a.arrow-right,
.ltx-team .arrows a.arrow-right,
.ltx-clients .arrows a.arrow-right {
  right: 0px !important;
  left: auto !important;
}

.ltx-testimonials .arrows a:hover,
.ltx-team .arrows a:hover,
.ltx-clients .arrows a:hover {
  background: #d93b65 !important;
  color: #ffffff !important;
}

/* Overflow visible for not cutting the arrows */
.swiper-container.ltx-slider-container,
.ltx-clients .swiper-container,
.ltx-team .swiper-container,
.ltx-testimonials .swiper-container,
.clients-sc .swiper-container {
  overflow: visible !important;
}

/* ========================================================
   11. FIX OVERBEAT ARTISTI PARTNER (TESTO)
======================================================== */
.vc_section.bg-color-black h3.header,
.vc_section.bg-color-second h3.header,
.vc_row.bg-color-black h3.header,
.vc_row.bg-color-second h3.header,
.ltx-team .heading h3.header,
.ltx-clients .heading h3.header,
.ltx-testimonials .heading h3.header {
  color: #ffffff !important;
}

.vc_section.bg-color-black h5.subheader,
.vc_section.bg-color-second h5.subheader,
.ltx-team .heading h5.subheader,
.ltx-clients .heading h5.subheader,
.ltx-testimonials .heading h5.subheader {
  color: #d93b65 !important;
}

.ltx-team .heading,
.ltx-clients .heading,
.ltx-testimonials .heading {
  text-align: center !important;
  margin-bottom: 30px !important;
}

/* ========================================================
   12. FIX TESTI DESCRITTIVI "SERVIZI PROFESSIONALI" E SIMILI
======================================================== */
.ltx-block-icon .descr,
.ltx-block-icon .descr p,
.ltx-block-icon .text,
.ltx-block-icon .text p {
  color: #444444 !important; /* Grigio scuro per alta leggibilità su chiari */
}

.bg-color-black .ltx-block-icon .descr,
.bg-color-black .ltx-block-icon .descr p,
.bg-color-black .ltx-block-icon .text,
.bg-color-black .ltx-block-icon .text p,
.bg-color-second .ltx-block-icon .descr,
.bg-color-second .ltx-block-icon .descr p,
.bg-color-second .ltx-block-icon .text,
.bg-color-second .ltx-block-icon .text p {
  color: #ffffff !important; /* Bianco per massima leggibilità su scuri */
}

/* ========================================================
   13. MENU SCURO NON TRASPARENTE (PREVISTO)
======================================================== */
nav.navbar,
.header-wrapper.wrapper-navbar-layout-transparent nav.navbar.affix {
  background-color: rgba(17, 17, 17, 0.95) !important;
}
.header-wrapper.wrapper-navbar-layout-transparent nav.navbar {
  background-color: rgba(17, 17, 17, 0.8) !important;
}

/* ========================================================
   14. CONTACT FORM 7 UNIFORM MODERN STYLING
======================================================== */
.wpcf7-form {
  background: rgba(17, 17, 17, 0.6) !important;
  padding: 30px !important;
  border-radius: 15px !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5) !important;
  margin-bottom: 30px !important;
}
.wpcf7-form .wpcf7-form-control:not(.wpcf7-submit) {
  background: rgba(255, 255, 255, 0.05) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  color: #ffffff !important;
  padding: 15px 20px !important;
  border-radius: 8px !important;
  font-size: 15px !important;
  transition: all 0.3s ease !important;
  width: 100% !important;
  margin-bottom: 10px !important;
}
.wpcf7-form .wpcf7-form-control:not(.wpcf7-submit):focus {
  border-color: #d93b65 !important;
  background: rgba(0, 0, 0, 0.8) !important;
  box-shadow: 0 0 15px rgba(217, 59, 101, 0.3) !important;
  outline: none !important;
}
.wpcf7-form .wpcf7-submit {
  background: #d93b65 !important;
  color: #ffffff !important;
  border: none !important;
  padding: 15px 30px !important;
  border-radius: 50px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  cursor: pointer !important;
  transition: all 0.3s ease !important;
  display: block !important;
  width: 100% !important;
}
.wpcf7-form .wpcf7-submit:hover {
  background: #ffffff !important;
  color: #111111 !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 5px 15px rgba(255, 255, 255, 0.2) !important;
}

/* Rimuovi spazio extra tra La tua visione e portfolio (Richiesta utente) */

/* Hide the large empty padding between sections */
.home section.vc_section:nth-of-type(3),
.home section.vc_section:nth-of-type(4),
.home section.vc_section:nth-of-type(5) {
  display: none !important;
}

/* Hide empty spaces inside the section that contains "La tua visione" after the text */
.home .ltx-scroll-section .vc_row:nth-of-type(1) .like_sc_empty_space,
.home .ltx-scroll-section > .vc_row:last-child .like_sc_empty_space {
  display: none !important;
}

/* Riduzione margine inferiore per avvicinare la sezione superiore al portfolio */
.home .ltx-scroll-section {
  padding-bottom: 20px !important;
  margin-bottom: 0 !important;
}

/* Hide empty spaces before "Portfolio" / "Alcune nostre Hit" */
.home
  section.ltx-records
  > .vc_row:first-child
  > .vc_column
  > .like_sc_empty_space {
  display: none !important;
  height: 0 !important;
}

/* Remove 80px space within the record section */
.home section.ltx-records {
  padding-top: 20px !important;
}

/* ========================================
   WOOCOMMERCE SINGLE PRODUCT - FIX TESTI BIANCHI
   ======================================== */
.woocommerce div.product p,
.woocommerce div.product span,
.woocommerce div.product h1,
.woocommerce div.product h2,
.woocommerce div.product h3,
.woocommerce div.product h4,
.woocommerce div.product h5,
.woocommerce div.product h6,
.woocommerce div.product li,
.woocommerce
  div.product
  div:not(.button):not(.onsale):not(.badge):not(.obs-popup-success):not(
    .obs-popup-title
  ),
.single-services .inner-page p,
.single-services .inner-page span,
.single-services .inner-page h1,
.single-services .inner-page h2,
.single-services .inner-page h3,
.single-services .inner-page h4,
.single-services .inner-page h5,
.single-services .inner-page h6,
.single-services .inner-page li,
.post-type-archive-services .inner-page p,
.post-type-archive-services .inner-page span {
  color: #333333 !important;
}
.woocommerce div.product .price,
.woocommerce div.product .price span,
.woocommerce div.product .price ins {
  color: #dc2751 !important;
}
.woocommerce div.product h1.product_title,
.single-services h1.entry-title {
  color: #111111 !important;
}

/* ========================================
   FIX ALLINEAMENTO ICONE CONTATTI FOOTER
   ======================================== */
.ltx-footer-wrapper .widget_ltx_icons ul.social-icons-list li a {
  display: flex !important;
  align-items: flex-start !important;
  gap: 15px !important;
  margin-bottom: 15px !important;
}

.ltx-footer-wrapper .widget_ltx_icons ul.social-icons-list li a .ltx-ic {
  position: relative !important;
  left: auto !important;
  top: auto !important;
  flex: 0 0 20px !important;
  text-align: center !important;
  margin: 4px 0 0 0 !important;
  display: block !important;
  font-size: 18px !important;
  transition: none !important;
  transform: none !important;
}

.ltx-footer-wrapper .widget_ltx_icons ul.social-icons-list li a .txt {
  flex: 1 1 auto !important;
  display: block !important;
  line-height: 1.5 !important;
  transition: none !important;
  transform: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Neutralizza effetti di spostamento / espansione hover nativi del tema */
.ltx-footer-wrapper .widget_ltx_icons ul.social-icons-list li a:hover,
.ltx-footer-wrapper .widget_ltx_icons ul.social-icons-list li a:hover .ltx-ic,
.ltx-footer-wrapper .widget_ltx_icons ul.social-icons-list li a:hover .txt,
.ltx-footer-wrapper .widget_ltx_icons ul.social-icons-list li:hover,
.ltx-footer-wrapper .widget_ltx_icons ul.social-icons-list li:hover a {
  transform: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  margin-left: 0 !important;
  background: transparent !important;
}

.ltx-footer-wrapper .widget_ltx_icons ul.social-icons-list li a:hover .ltx-ic {
  margin: 4px 0 0 0 !important;
}

/* Fix Icona Soundcloud invisibile */
.ltx-social ul li a span.entypo-soundcloud:before,
.entypo.entypo-soundcloud:before {
  content: "\f1be" !important;
  font-family: "FontAwesome", "Font Awesome 5 Brands", sans-serif !important;
}

/* ========================================================
   ENHANCED ARTISTI PARTNER SECTION (PROFESSIONAL LOOK)
   ======================================================== */

/* Section Padding */
.ltx-testimonials-sc,
.ltx-testimonials-slider {
  padding: 80px 0 !important;
}

/* Heading Typography refinement */
.ltx-testimonials-sc .heading h3.header {
  font-size: 52px !important;
  font-weight: 900 !important;
  text-transform: uppercase !important;
  letter-spacing: -1px !important;
  margin-bottom: 12px !important;
  background: linear-gradient(to bottom, #ffffff 60%, #aaaaaa 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 5px 15px rgba(0, 0, 0, 0.5));
}

.ltx-testimonials-sc .heading h5.subheader {
  font-size: 15px !important;
  font-weight: 800 !important;
  letter-spacing: 5px !important;
  text-transform: uppercase !important;
  color: #d93b65 !important;
  opacity: 0.95;
  margin-bottom: 5px !important;
}

/* Artist Item Card */
.ltx-testimonials-sc .swiper-slide a.photo {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-decoration: none !important;
  transition: all 0.6s cubic-bezier(0.23, 1, 0.32, 1) !important;
  position: relative !important;
  padding: 15px !important;
  background: transparent !important;
}

.ltx-testimonials-sc .swiper-slide a.photo img {
  border-radius: 24px !important;
  box-shadow: 0 25px 50px rgba(0, 0, 0, 0.7) !important;
  transition: all 0.8s cubic-bezier(0.23, 1, 0.32, 1) !important;
  transform: scale(0.96) !important;
  filter: brightness(0.85) grayscale(15%) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  width: 100% !important;
  height: auto !important;
}

.ltx-testimonials-sc .swiper-slide a.photo h5 {
  margin-top: 25px !important;
  font-size: 19px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: 2.5px !important;
  color: #bbbbbb !important;
  transition: all 0.4s ease !important;
  position: relative !important;
  text-align: center !important;
}

/* Modern underline indicator on name */
.ltx-testimonials-sc .swiper-slide a.photo h5::after {
  content: "" !important;
  position: absolute !important;
  bottom: -10px !important;
  left: 50% !important;
  width: 0 !important;
  height: 3px !important;
  background: #d93b65 !important;
  transition: all 0.4s cubic-bezier(0.23, 1, 0.32, 1) !important;
  transform: translateX(-50%) !important;
  border-radius: 2px !important;
}

/* Professional Hover State */
.ltx-testimonials-sc .swiper-slide a.photo:hover {
  transform: translateY(-12px) !important;
}

.ltx-testimonials-sc .swiper-slide a.photo:hover img {
  transform: scale(1.02) !important;
  box-shadow: 0 40px 80px rgba(217, 59, 101, 0.25) !important;
  filter: brightness(1.1) grayscale(0%) !important;
  border-color: rgba(217, 59, 101, 0.5) !important;
}

.ltx-testimonials-sc .swiper-slide a.photo:hover h5 {
  color: #ffffff !important;
  transform: translateY(2px) !important;
}

.ltx-testimonials-sc .swiper-slide a.photo:hover h5::after {
  width: 50px !important;
}

/* Glassmorphism Navigation Arrows Fix */
.ltx-testimonials-slider .arrows a {
  background: rgba(15, 15, 15, 0.7) !important;
  border: 1px solid rgba(255, 255, 255, 0.15) !important;
  backdrop-filter: blur(12px) !important;
  width: 54px !important;
  height: 54px !important;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5) !important;
  transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275) !important;
}

.ltx-testimonials-slider .arrows a:hover {
  background: #d93b65 !important;
  border-color: #ffffff !important;
  color: #ffffff !important;
  transform: scale(1.15) !important;
  box-shadow: 0 0 25px rgba(217, 59, 101, 0.7) !important;
}

/* Hide some default theme shadows/borders if they interfere */

/* Aumenta lo spazio tra il menu e la sezione Servizi Professionali in home */
.home .ltx-heading.ltx-heading-center:first-of-type {
  margin-top: 80px !important;
}

@media (max-width: 1200px) {
  .home .ltx-heading.ltx-heading-center:first-of-type {
    margin-top: 60px !important;
  }
}

@media (max-width: 768px) {
  .home .ltx-heading.ltx-heading-center:first-of-type {
    margin-top: 40px !important;
  }
}
