@import url('https://fonts.googleapis.com/css2?family=ABeeZee:ital@0;1&family=Dancing+Script:wght@400..700&family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap');
/* Effetto Sidebar Fissa solo su Desktop */

.itemid-101 h1, .itemid-119 h1 {position: absolute; top:-999999999999999px}



@media (min-width: 992px) {
    #sp-left {
        position: fixed;
        top: 0;
        left: 0;
        width: 20%; /* Regola in base alla colonna scelta */
        height: 100vh;
        background-color: #ffffff; /* Colore di sfondo della sidebar */
        border-right: 1px solid #eee;
        z-index: 1000;
        overflow-y: auto;
    }

    /* Sposta il contenuto principale a destra per non sovrapporlo */
    #sp-main-body, #sp-footer, #sp-bottom {
        margin-left: 20%; 
        width: 80%;
    }
    
    #sp-header, #sp-top-bar{display: none!important;}
}
#sp-footer{background: #0abdba; text-align: center;     color: #eee; padding: 15px 0px}


#sp-footer img {
    filter: brightness(0) invert(1);
}

#sp-footer #sp-footer2 {
     text-align:center;
}

#sp-footer a, #sp-bottom a {
    color: azure;
    opacity: .6;
    font-size: xx-small; 
}

img {
    display: inherit;
    max-width: 100%;
    height: auto;
}

#sp-bottom {
    background:#e0eede;
   color: #000;
}

#sp-bottom {
    padding: 0px 0 0px;
    font-size: 17px;
    line-height: 1.6;
}
#sp-main-body {
    padding: 0px 0px 60px 0px;
}

.sp-hero-dark{background-image: url('../../../images/asilo-cani-malpemsa-lago-maggiore.jpg');
background-position: bottom center; background-size: cover;     min-height: 350px;  }
.article-info {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-bottom: 1rem;
    justify-content: center;
}

.article-details [itemprop="articleBody"] {
        max-width: 1320px; margin: 0 auto; padding: 50px 15px;}
body {
     font-family: "Inter", sans-serif;
         font-size: 17px;
    line-height: 1.6;
    font-weight: 400;
}

#sp-top-bar {
    background: #068B89;
    color: #fff;
    position: relative;
    z-index: 99;
}

#sp-top-bar a {
    color: #fff!important;
}
.sp-btn-fill-light.content-links-b a{  border-color: #FF5F4E!important;
    background-color: #FF5F4E!important;      font-family: "ABeeZee", sans-serif!important;
    font-size: 15px!important;
    color: #fff !important;
    font-weight: 600!important;
    padding-top: 1rem!important;
    padding-bottom: 1rem!important;
    transition: all 0.6s ease-in-out!important;
    letter-spacing: 0.5px!important;
    text-transform: uppercase!important;
    border-radius: 30% 70% 70% 30% / 30% 45% 55% 70%!important;
    padding-right: 1rem!important;
    padding-left: 1rem!important;}
.btn-primary,.sppb-btn-primary, .sp-btn-fill-light.content-links-a a,  .sp-btn-fill-light.content-links-c a {
    border-color: #EDA04D!important;
    background-color: #EDA04D!important;
          font-family: "ABeeZee", sans-serif!important;
    font-size: 15px!important;
    color: #fff !important;
    font-weight: 600!important;
    padding-top: 1rem!important;
    padding-bottom: 1rem!important;
    transition: all 0.6s ease-in-out!important;
    letter-spacing: 0.5px!important;
    text-transform: uppercase!important;
    border-radius: 30% 70% 70% 30% / 30% 45% 55% 70%!important;
    padding-right: 1rem!important;
    padding-left: 1rem!important;
}

.btn-primary:hover,.sppb-btn-primary:hover,  .sp-btn-fill-light.content-links-a a:hover,  .sp-btn-fill-light.content-links-b a:hover,  .sp-btn-fill-light.content-links-c a:hover {
    border-color: #068B89!important;
    background-color: #068B89!important;
        
           border-radius: 62% 38% 82% 18% / 54% 61% 39% 46%!important;
               color: #fff !important!important;
}

#sp-left .sp-module, #sp-right .sp-module {
    margin-top: 50px;
     border: 0px solid #f3f3f3; 
    padding: 0px; 
    border-radius: 0px;
    text-align: center;
}


#sp-left .sp-module ul.menu, #sp-right .sp-module ul {
    list-style: none;
    padding: 0;
    margin: 0;
    margin-top: 50px;
}
#sp-left{background:linear-gradient(to bottom, #068B89, #0ABFBC); border-right: 1px solid #fff; }

  #sp-left .sp-module ul.menu>li a:hover {
       background-color:#FF5F4E;
           border-radius: 62% 38% 82% 18% / 54% 61% 39% 46%;
               color: #fff !important;
       
}


#sp-left .sp-module ul.menu>li{border:0px!important;     padding: .5rem 1rem;}
#sp-left .sp-module ul>li, #sp-right .sp-module ul>li {
    
    border-bottom: 0px solid #f3f3f3;
}


#sp-left .sp-module ul.menu>li>a {
  font-family: "ABeeZee", sans-serif;
    font-size: 15px;
    color: #fff !important;
    font-weight: 600;
    display: inline-block;
    text-decoration: none;
    transition: all 0.6s ease-in-out;
    letter-spacing: 0.5px;

    text-transform: uppercase;
    border-radius: 30% 70% 70% 30% / 30% 45% 55% 70%;
            padding-right: .8rem;
        padding-left: .8rem;
     
}

.section-label {
    font-size: 0.7rem;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    color: var(--green);
    margin-bottom: 1rem;
}

.section-label:before {
    transform: rotate(30deg);
    content: "\f1b0";
       font-family: "Font Awesome 5 Free";
    font-weight: 900;
    opacity: 0.5;
    font-size: 26px;
    display: inline-block;
    vertical-align: middle;
    margin-right: 5px;
}



.titolo .sppb-addon-title {
    color: #fff;
    font-size: clamp(4rem, 7vw, 5.2rem);
    line-height: 1.15;
    margin-bottom: 2rem;
    font-family: "Dancing Script", cursive;
    font-weight: 700;
    line-height: 1.1;
    
    letter-spacing: -0.5px;
}

h1 {
    color: #fff;
    font-size: clamp(2rem, 3vw, 3.2rem);
    line-height: 1.15;
    margin-bottom: 0rem;
    padding-top: 20px;
    font-family: "ABeeZee", sans-serif;
    font-weight: 700;
    line-height: 1.1;
    
    letter-spacing: -0.5px;
}

.article-details figcaption.caption {
    font-size: 14px;
    color: #fff;
    margin: 5px 0px;
    opacity: .9;
}

.nav-tabs {
    --bs-nav-tabs-border-width: 0px;
    margin-top: 30px;
}

h2 {
    color: #068B89;
    font-size: clamp(1.5rem, 2vw, 1.3rem);
    line-height: 1.15;
    margin-bottom: 0rem;
    font-weight: 400;
    letter-spacing: 2px;
    text-transform: uppercase;
}

h3 {
   color: #068B89;
    font-size: clamp(2rem, 5vw, 3.2rem);
    line-height: 1.15;
    margin-bottom: 2rem;
    font-family: "ABeeZee", sans-serif;
      font-weight: 700;
    line-height: 1.1;
    
    letter-spacing: -0.5px;
}

h3 em {
    font-style: italic;
    color: #FF5F4E;
}


/* ── Social Icons ── */

  /* ── Transizioni ── */
  :root {
  --transition-base:   0.3s ease;
  --transition-smooth: 0.45s cubic-bezier(0.76, 0.08, 0.24, 0.94);
  --t:                 0.3s ease;
}

#sp-left .sp-module ul.social-icons>li{
    display: inline-flex;
    padding: 0px;
}

#section-id-858c7a2c-c673-49d9-9aee-08d5799c9829 {position: absolute!important; z-index: -1; top:0px; left:0px!important;     align-items: flex-start!important;  width: 100%;   height: 100vh;}

.sezione{
    padding: 7rem 0rem;
  
    margin: 0 auto;
}

/* ── VANTAGGI ── */
  .vantaggi-section {
    border-top: 1px solid rgba(90,158,111,0.15);
  }
 
  .vantaggi-grid .sppb-nested-row .sppb-row-column   {
    
    gap: 1.5px;
   border: 1px solid rgba(90,158,111,0.1);
  }
 
  .vantaggio-card {
   padding: 2.5rem 2rem;
    position: relative;
   
    transition: background 0.4s;
  }
 
  .vantaggio-card::before {
    content: '';
    position: absolute;
    bottom: 0; left: 0;
    width: 100%;
    height: 2px;
    background: linear-gradient(90deg, #3d7a52, #7ec492);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.4s ease;
  }
 
  .vantaggio-card:hover::before { transform: scaleX(1); }
  .vantaggio-card:hover {  background: rgba(90,158,111,0.1); }
 
  .vantaggio-icon {
    font-size: 2.2rem;
    margin-bottom: 1.2rem;
    display: block;
    max-width: 120px;
    height: 120px;
    text-align: center;
    height: 120px;
    padding: 30px;
    transition: all ease-in-out 0.3s;
    border-radius: 30% 70% 70% 30% / 30% 45% 55% 70%;
    margin: 0px auto 20px auto;
    background: #e0eede;
  }
 
  .vantaggio-title {
  text-align: center;
    font-size: 1.3rem;
    color: #068B89 ;
    margin-bottom: 0.8rem;
    font-weight: 700;
  }
 
  .vantaggio-text {
   text-align: center;
    max-width: none;
  }
 
  .location-map {
    background: linear-gradient(135deg, rgba(90, 158, 111, 0.08), rgba(122, 58, 30, 0.05));
    border: 1px solid rgba(90, 158, 111, 0.2);
    border-radius: 4px;
    padding: 3rem 2rem;
    text-align: center;
}
.map-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #068B89;
    margin-top: 0.5rem;
    flex-shrink: 0;
}

.map-detail {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    padding: 1rem 0;
    border-bottom: 1px solid rgba(90, 158, 111, 0.1);
    text-align: left;
}
.map-detail:last-child {
    border-bottom: none;
}
 
.qual-list {
    list-style: none;
    margin-top: 1.5rem;
        padding-left: 0rem;
}

.qual-list li::before {
    content: '—';
    color: #EDA04D;
    flex-shrink: 0;
    font-weight: 300;
}


.qual-list li {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    padding: 0.75rem 0;
    border-bottom: 1px solid rgba(90, 158, 111, 0.18);
  
    line-height: 1.5;
}

.quote-block {
    background: linear-gradient(135deg, rgba(90, 158, 111, 0.1), transparent);
    border-left: 2px solid #068B89;
    padding: 2rem 2rem 2rem 2.5rem;
    border-radius: 0 4px 4px 0;
}

.quote-text {
    font-family: 'Cormorant Garamond', serif;
    font-style: italic;
    font-size: 1.25rem;
    line-height: 1.75;

    max-width: none;
}

.quote-attr {
    margin-top: 1rem;
    font-size: 0.75rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: #068B89;
}
.card-stat {
    background: linear-gradient(135deg, rgba(90,158,111,0.15), rgba(90,158,111,0.05));
    border: 1px solid rgba(90,158,111,0.2);
    border-radius: 4px;
    padding: 2rem;
    text-align: center;
    transition: border-color 0.3s, transform 0.3s;
  }
 
  .card-stat:hover {
    border-color: rgba(90,158,111,0.5);
    transform: translateY(-4px);
  }
 
  .stat-num {
 
    font-size: 3.5rem;
    color: #068B89;
    line-height: 1;
    display: block;
  }
 
  .stat-label {
    font-size: 0.75rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--cream-dim);
    margin-top: 0.5rem;
    display: block;
  }
  
  /* blob shape 1 */
 .blob1 img.sppb-img-responsive {
     border-radius: 30% 70% 70% 30% / 30% 45% 55% 70%!important;
     transition: all 0.7s ease-in-out;
}
 .blob1 img.sppb-img-responsive:hover {
     border-radius: 57% 43% 31% 69% / 54% 61% 39% 46%!important;
}

.social-icons {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  gap: 10px;
  align-items: center;
}
.social-icons li a {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 36px !important;
  height: 36px !important;
  border-radius: 50% !important;
  border: none !important;
  transition: transform var(--transition-base), filter var(--transition-base) !important;
  text-decoration: none !important;
}
.social-icons li a:hover {
  transform: translateY(-3px) !important;
  filter: brightness(1.1) !important;
}
.social-icons li a span {
  font-size: 1rem !important;
  color: #fff !important;
}

/* Facebook */
.social-icon-facebook a {
  background: #1877F2 !important;
}

/* Instagram */
.social-icon-instagram a {
  background: radial-gradient(circle at 30% 107%, #fdf497 0%, #fdf497 5%, #fd5949 45%, #d6249f 60%, #285AEB 90%) !important;
}

/* WhatsApp */
.social-icon-whatsapp a, .social-icon-whatsapp a:hover{
  background: #25D366!important;
}



/* Stile Generale del Form A Casa di Pluto */
.bfPage {
    background-color: #ffffff;
    padding: 30px;
    border-radius: 15px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.05);
    font-family: 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
    max-width: 900px;
    margin: 20px auto;
}

/* Titoli delle sezioni (Legend) */
legend {
    color: #00a4a6; /* Colore Tiffany */
    font-weight: 700;
    font-size: 1.4rem;
    border-bottom: 2px solid #e0f7f7;
    padding-bottom: 10px;
    margin-bottom: 25px;
    margin-top: 20px;
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* Campi di input e Textarea */
.ff_elem.inputbox, 
.form-select,
.bfCalendar {
    border: 2px solid #e0e0e0 !important;
    border-radius: 8px !important;
    transition: all 0.3s ease;
    background-color: #fcfcfc !important;
    color: #444;
}

.bfQuickMode input[type=text], .bfQuickMode textarea, .bfQuickMode select, .bfQuickMode .uneditable-input, #ff_elem35 {
 min-height: 50px!important; 
}

/* Effetto Focus sui campi (quando l'utente clicca) */
.ff_elem:focus, 
.form-select:focus {
    border-color: #00a4a6 !important; /* Tiffany */
    box-shadow: 0 0 8px rgba(0, 164, 166, 0.2) !important;
    background-color: #fff !important;
    outline: none;
}

/* Etichette (Labels) */
.form-label {
    font-weight: 600;
    color: #555;
    margin-bottom: 8px;
    display: block;
}

/* Asterisco dei campi obbligatori */
.fa-asterisk {
    color: #ff6b6b;
    font-size: 0.7rem;
    vertical-align: super;
}

/* Layout Spaziatura Righe */
.bfElemWrap {
    margin-bottom: 20px !important;
}

/* Stile speciale per il Bottone "Fai felice il tuo cane" */
#bfSubmitButton {
    background-color: #00a4a6 !important; /* Base Tiffany */
    border: none !important;
    padding: 15px 40px !important;
    font-size: 1.2rem !important;
    font-weight: 700 !important;
    color: white !important;
    border-radius: 50px !important;
    transition: all 0.4s ease !important;
    cursor: pointer;
    box-shadow: 0 4px 15px rgba(0, 164, 166, 0.3) !important;
    margin-top: 20px;
}

.bfQuickMode .bfElemWrap .form-inline input[type="text"], .bfQuickMode .bfElemWrap .form-inline input[type="number"], .bfQuickMode .bfElemWrap .form-inline textarea, .bfQuickMode .bfElemWrap .form-inline select {
    display: inline;
    max-width: 100%!important;
}

#bfSubmitButton:hover {
    background-color: #008a8c !important; /* Tiffany più scuro al passaggio */
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(0, 164, 166, 0.4) !important;
}

/* Checkbox Privacy */
#ff_elem18 {
    width: 18px;
    height: 18px;
    cursor: pointer;
    accent-color: #00a4a6;
}

/* Bottone Calendario */
.field-calendar .btn-secondary {
    background-color: #00a4a6 !important;
    border: none !important;
}

#bfElemWrap43 > div > div > span > div > div.input-group > span {
    background-color: #00a4a6 !important;
   
}
#ff_elem43{border-radius: 8px 0px 0px 8px!important;     border-right: 0px solid #00a4a6;
}


/* Adattamento Mobile */
@media (max-width: 768px) {
    .bfPage {
        padding: 15px;
    }
    #bfSubmitButton {
        width: 100%;
    }
}


/* Su Mobile torna tutto normale automaticamente grazie alle media queries */
@media (max-width: 991px) {
  
      .logo-image {
        height: 56px;
    }
  
      #sp-header {
        height: 60px;
    }
    
  
  .sp-contact-info li {
    display: inline-block;
    margin: 0px 10px 0px 0px;
    font-size: 90%;
     white-space: normal;
}


    #sp-left {
       display:none!important;
    }
    
    .sezione {
    padding: 4rem 0rem;
    margin: 0 auto;
}

}

.paw-print {
    position: absolute;
    width: 60px; /* Dimensione zampina */
    height: 68px;
    background-image: url('../../../images/zampe.png'); /* Usa un'icona SVG o PNG */
    background-size: contain;
    background-repeat: no-repeat;
    opacity: 0;
    transition: opacity 0.5s ease;
    pointer-events: none; /* Evita che disturbino i click sul sito */
    z-index: 1; /* Restano sullo sfondo */
}

.paw-visible {
  
    opacity: 0.2 !important; /* Abbassata l'opacità per un effetto più "impronta sul terreno" */
    filter: blur(0.5px); /* Un leggero sfocato le rende meno "finte" */

}

/* Box Recensioni Google - Stile Pulito */
.google-reviews-box {
    position: fixed;
    right: 20px;
    bottom: 20px;
    z-index: 9999;
}

.reviews-box-link {
    display: flex;
    align-items: center;
    gap: 12px;
    background: white;
    border-radius: 50px;
    padding: 12px 20px 12px 16px;
    box-shadow: 0 4px 16px rgba(0,0,0,0.12);
    cursor: pointer;
    transition: all 0.3s ease;
    text-decoration: none;
    border: 1px solid #e8eaed;
}

.reviews-box-link:hover {
    box-shadow: 0 8px 24px rgba(0,0,0,0.18);
    transform: translateY(-3px);
}

/* Logo Google */
.google-logo-box {
    width: 32px;
    height: 32px;
    flex-shrink: 0;
}

/* Contenuto a destra del logo */
.reviews-content {
    display: flex;
    align-items: center;
    gap: 8px;
}

/* Rating Number */
.rating-number {
    font-size: 24px;
    font-weight: 700;
    color: #202124;
    line-height: 1;
}

/* Stelle */
.stars-display {
    color: #fbbc04;
    font-size: 16px;
    letter-spacing: 1px;
}

/* Testo Recensioni */
.reviews-text {
    font-size: 13px;
    color: #5f6368;
    font-weight: 500;
    margin: 0;
    white-space: nowrap;
}

.reviews-label {
    display: none;
}

/* Responsive */
@media (max-width: 768px) {
  
  .article-details .article-full-image img {
  max-height: 250px;
  width: auto;
  text-align: center;
}

    .google-reviews-box {
        right: 15px;
        bottom: 15px;
    }
    
    .reviews-box-link {
        padding: 10px 16px 10px 12px;
        gap: 10px;
    }
    
    .google-logo-box {
        width: 28px;
        height: 28px;
    }
    
    .rating-number {
        font-size: 20px;
    }
    
    .stars-display {
        font-size: 14px;
    }
    
    .reviews-text {
        font-size: 12px;
    }
}

/* Animazione pulse leggera */
@keyframes pulse-soft {
    0%, 100% {
        box-shadow: 0 4px 16px rgba(0,0,0,0.12);
    }
    50% {
        box-shadow: 0 6px 20px rgba(0,0,0,0.15);
    }
}

.reviews-box-link {
    animation: pulse-soft 3s ease-in-out infinite;
}

.reviews-box-link:hover {
    animation: none;
}
.google-reviews-box {
    position: fixed;
    right: 20px;
    bottom: 20px;
    z-index: 9999;
}

a.asilo-cani, a.dog-sitting, a.centro-diurno-cani{color:#000!important}