html {
  scroll-behavior: smooth;
}

q {
    display: block; 
    padding: 12px 20px;
    margin: 16px 0;
    background-color: #fafafa; 
    color: #444;
    font-style: italic; 
    font-size: 0.95em; 
    quotes: none;
}

q::before {
    content: '“'; 
    font-family: "Times New Roman", Times, serif;
    font-size: 1.2em;
    font-weight: bold;
    color: var(--primary-color); 
    margin-right: 5px;
}
q::after {
    content: '”'; 
    font-family: "Times New Roman", Times, serif;
    font-size: 1.2em; 
    font-weight: bold;
    color: var(--primary-color); 
    margin-left: 5px;
}

.h2, h2 {
  font-size: 1.8rem;
}
.h3, h3 {
  font-size: 1.6rem;
}

.fright{float:right;}
.fleft{float:left;}

.btn-primary {
  background-color: var(--primary-color);
  border-color: var(--primary-color);
}
.btn-primary:hover {
  background-color: var(--secondary-color);
  border-color: var(--secondary-color);
}
.card.colored .btn-primary:hover{background-color: white; border-color: white; color: var(--primary-color);}
.card.colored .btn-primary:hover i{color: var(--primary-color);}

.btn-outline-primary {
  color: var(--primary-color);
  border-color: var(--primary-color);
}
.btn-outline-primary:hover {
  background-color: var(--primary-color);
  border-color: var(--primary-color);
}
 .avatar {
  vertical-align: middle;
  width: 30px;
  height: 30px;
  border-radius: 50%;
}
.btn.tt {
  margin: 0;
  padding: 0;
  font-size: 80%;
  background: no-repeat;
  color: #666;
  font-weight: bold;
  position: relative;
  bottom: 10px;
}
.navbar-dark .navbar-nav .nav-link{color:white};

select#country-selector{
  background-color: white;
  border: solid 1px var(--primary-color);
  color: var(--primary-color);
  font-size: 20px;
  padding: 5px;
}

.language-selector{text-align: right; position: absolute; top: -25px; right: 15px;}

img{max-width: 100%;}
.clearer{clear:both;}
.oauth-signin{margin-bottom:30px}
.btn img{float: left;height: 20px;}
.btn img.icon{margin-right: 10px; margin-top: 4px;}
.btn-themed{background-color: var(--primary-color); color:white; border-radius:0;}
.btn-themed:hover{border: solid 1px var(--primary-color); color: var(--primary-color);  background-color: white;}
.btn-themed .badge {background-color: white !important;   color: var(--primary-color) !important;}
.short-description p{max-height: 100px; overflow: auto; text-align: justify;}
.product-detail .product-slider-single{text-align:center;}
.product-detail .product-slider-single img{width:auto;}
.alert {max-width: 600px; margin: 10px auto;}
.alert.alert-error {
  color: red;
  background-color: orange;
  border-color: red;
  font-weight: bold;
}
.material-icons{vertical-align:middle;}
.out-of-stock{font-weight: bold; text-align: center;}
/* Cookie Banner */
#cb-cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  z-index: 999;
  border-radius: 0;
  display: none;
  background-color: lightgray;
  padding:10px;
}

/** page **/
.cms-page h2{margin-top:60px;}

/* Footer */
.footer a{color:white;}
.footer-bottom {
  padding: 3px 0;
  background: var(--primary-color);
  font-size: 12px;
}
.footer-bottom p, .footer-bottom p a{color:white !important;}

/* Home page */
.home .slide .card{margin: 20px 0; height: 300px; border: 1px solid var(--primary-color); color: var(--primary-color);}
.home .slide .price{
  font-size: 25px;
  font-weight: 700;
  margin-bottom: 15px;
}
.home .slide .card-img { max-height: 280px; width: auto;}

.home .slide .control{color:gray;}
.home .slide .control i{font-weight: bold;font-size: 30px;}
.home .slide .product-photo{text-align:center; padding: 5px 30px;}
.home .slide .card-text {height: 2lh; overflow: hidden;}


.home .cards .card{margin-bottom:20px;  border: 1px solid var(--primary-color); }
.home .cards {text-align: center;}
.home .cards .card-title i{font-size:40px;  }
.home .cards .card-text {height: 2lh; overflow: hidden; border-bottom: solid 1px white;}
.home .cards .btn i{font-size:15px;}

.ext-news-widget{width: 100%; margin: 0; padding: 0;}
.ext-news-widget .cont{margin: 0; padding: 0;}
.news-widget .news-list li{float: left;}

.news-widget .wrapper {
  max-width: 100%;
  overflow: hidden;
  padding-top: 0.75rem;
}

.news-widget .title{
  padding: .75rem 1.25rem;
  margin-bottom: 0;
  background-color: rgba(0,0,0,.03);
  font-weight:bold;
}
.card-header{font-weight:bold;}
.news-widget .title .material-icons{margin-top: -3px;}
.news-widget .news-list {
  white-space: nowrap;
  overflow: hidden;
  display: inline-block;
  animation: marquee 10s linear infinite;
}

.news-widget .news-list p {
  display: inline-block;
  margin-bottom:7px;
  margin-right: 50px;
}

.card.colored{ background-color: var(--primary-color); color: white;}
.card.colored .material-icons{color:white;}
.card.colored a:hover .material-icons{color:var(--primary-color);}

@keyframes marquee {
  0% {
    transform: translate3d(0, 0, 0);
  }
  100% {
    transform: translate3d(-30%, 0, 0);
  }
}

.home .planet.list{margin:0}
.planet.list .post {
  border-right: solid 1px lightgray; 
  margin-bottom: 15px;
  margin-top: 15px;
}

.home .planet.list .post:last-child {border-right: none;}

/* product list */
.product-list .category-name{margin-top:20px;}
.product-list .product-item{border: 1px solid var(--primary-color); margin: 14px 0;}
.product-list .product-image{text-align: center;height: 290px;background-color: white;}
.product-list .product-image a{background-color:white; width:100%;}
.product-list .product-image img{max-height: 290px;width: auto; max-width: 290px;}
.product-list .product-content .title{height: 56px; overflow: clip;}
.product-list .price p.out-of-stock{font-size: 16px; margin: 13px 0;}

/* product-detail */
.product-detail .price{margin-bottom: 0 !important;}
.product-detail .delivery {color:green;}

.product-detail .delivery a{color:green;}
.product-detail .satisfied a{color:orange;}

.product-detail .product-content .actions{margin-top: 15px;}
.product-detail #offers .row {padding: 15px 0px; border-bottom: solid 1px var(--primary-color);}
.product-detail #offers .action {float:left; margin-top: 10px; margin-right: 10px;}

.product-detail #offers .offer-image{text-align:center;}
.product-detail #offers .offer-image img{max-height: 100px; max-width: 100px;}
.product-detail #offers .seller-name{font-weight: bold;}
.product-detail #offers .seller-name img{max-height: 20px;}
.product-detail #offers .price{color: var(--primary-color); font-size: 25px; font-weight: 700; padding: 0px; }
.product-detail h1{font-size: 2rem;}
.product-detail .product-brand{margin: 0; font-size: 18px; font-weight: bold;}
.product-detail .buybox .price{width: auto; float:left; margin-right:10px;}
.product-detail .buybox .seller-name{padding-top:10px;}
.product-detail .buybox .seller-icon{width: 16px;}
.product-detail .aff-text {font-size: 0.8rem;}
.product-detail .last-update {font-size: 0.8rem; position:relative; top:-8px;}
.product-detail .see-offers {margin-top: 10px;}

.product-detail .row.variation { margin-bottom: 10px;}

.product-detail .smaller-price{font-size:15px;}
.product-detail .product-content hr{margin-top:25px;}
.product-detail .smaller-price a{color:unset;}
.product-detail .smaller-price .price{font-size:18px}

.product-detail #description .description-title{text-align:center; text-transform: uppercase;font-size: 1.8rem;font-weight: bold;}
.product-detail #description p{text-align: justify;}
.product-detail #description h3{font-size: 1.8rem; margin-bottom:0; text-decoration:underline;}
.product-detail #description h4{font-size: 1.4rem; margin-bottom:0; text-decoration:underline;}
.product-detail #description table{width:100%};

.product-detail .condition {padding: 0px; border:0; font-size:16px; color:#666; float:left;}
/*.product-detail .action{padding-left:10px}*/

.shipping-price.free{color: green;}
.shipping-price{color: #959595; position: relative; top:-8px;}


/* cart-page */
.cart-page .image{text-align:center;}
.cart-page td{text-align:center !important;}
.cart-page .cart-btn{margin-top: 30px;}

/* checkout */
.checkout .policy {color: #ffffff; padding: 30px; background: var(--primary-color); margin-top:20px;}
.checkout .policy input{width: 1rem; height: 1.25rem;}
.checkout .policy a, .checkout .checkout-payment .payment-methods a{color:white; text-decoration: underline;}

.checkout .payment-method .custom-radio {padding-left:0; margin-bottom:0;}
.checkout .payment-method .custom-radio label {margin-bottom: 0;font-weight: bold;}
.checkout .payment-method .payment-content{font-size: 80%; font-style: italic;}

/* Pagination */
.page-item.active .page-link {
  background-color: var(--primary-color);
  border-color: var(--primary-color);
}
.page-link, .page-link:hover{
  color: var(--primary-color);
}

/* Planet */
.planet{margin-top: 12px;}

/* Stile principale del contenitore del pulsante */
.planet a.action {
  position: relative;
  display: inline-flex; 
  align-items: center; 
  padding: 12px 24px; 
  border-radius: 8px;
  background-color: var(--primary-color);
  color: white;
  text-decoration: none;
  font-family: 'Helvetica Neue', sans-serif;
  font-size: 16px;
  overflow: hidden; 
  border: none;
  cursor: pointer;
  transition: color 0.3s ease-in-out;
}
.planet a.action.best-price {
  padding: 0; 
  text-decoration: none;
}

/* Stile per la parte sinistra (testo "Miglior Prezzo:") */
.planet a.action.best-price span {
  padding: 12px 15px 12px 24px; 
  text-decoration: none;
}

/* Stile per la parte destra (il prezzo) */
.planet a.action.best-price b {
  font-weight: bold;
  margin-left: 0; 
  padding: 12px 24px 12px 15px; 
  background-color: rgba(0, 0, 0, 0.15);
  height: 100%;
  display: flex;
  align-items: center;
}

/* Effetto "Shine" al passaggio del mouse */
.planet a.action.best-price::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(120deg, transparent, rgba(255, 255, 255, 0.4), transparent);
  transition: left 0.5s cubic-bezier(0.23, 1, 0.32, 1);
}

.planet a.action.best-price:hover::before {
  left: 100%;
}

.planet.list .featured.post{
border: solid 1px var(--primary-color);
  padding: 20px;
  border-radius: .25rem;
    margin-bottom: 25px;
}
.planet.list .featured.post .actions{float:right;}

.planet.list .post{margin-bottom:50px;}
.planet.list .post .top{width: 100%; max-height: 457px; overflow: hidden;}
.planet.list .post .title{font-size: 20px; font-weight: 600; margin-bottom:0;}
.planet.list .post .tags{margin-bottom:15px; margin-top:4px;}
.planet.list .post-image { max-height: 250px; overflow: hidden; text-align:center; margin: auto;}
.planet.list .post-image img{ height: 100%; max-height: 220px;}
.planet.list .post-header ul{padding:0; font-size:13px;}
.planet.list .post-header li{
  float: left;
  list-style: none;
  margin: 0;
  padding: 0;
}
.planet.list .post-header li:last-child{float:right;}
.planet.list .post-excerpt{clear:both; padding-top:6px;}
.planet.list .post .actions{margin-top:10px;}

.planet.post .section-desc {
  background: var(--primary-color);
  color: white;
  text-transform: uppercase;
  padding: 10px;
  text-align: center;
}

.planet.post h2 {
  font-size: 1.8rem;
  text-align: center;
  text-decoration: underline;
  margin-top: 30px;
  font-weight: 600;
}
.planet.post .post-body{
  text-align:justify;
}
/* Stile generale del contenitore (invariato) */
.planet.post .pros-cons {
  border: solid 1px var(--primary-color);
  margin-bottom: 20px;
  padding: 20px;
  display: grid;
}

/* Stile degli header (invariato) */
.planet.post .pros-cons .pros-header, 
.planet.post .pros-cons .cons-header {
  text-align: center;
  font-size: 24px;
 /* margin-bottom: 15px;*/
}
.planet.post .pros-cons, 
 margin-bottom: 15px;
}



.planet.post .pros-cons ul {
  list-style: none;
  padding-left: 0;
  margin: 0;
}

.planet.post .pros-cons ul li {
  line-height: 1.5;
  display: flex;
}

.planet.post .pros-cons ul li::before {
  margin-right: 8px;
  font-size: 1.1em;
}

.planet.post .pros-cons .pros ul li::before {
  content: '✅';
}

.planet.post .pros-cons .cons ul li::before {
  content: '❌';
}




.planet.post .post-header{
  color: gray; 
  font-size: 80%; 
  border: solid 1px lightgray;
  margin-bottom:20px;
}
.planet.post .post-header ul{
  padding: 10px;
  margin-bottom: 0;
  overflow: auto;
}
.planet.post .post-header li{
  float: left;
  list-style: none;
  margin: 0;
  padding: 0;
  margin-right:30px
}
.planet.post .post-header li:last-child{float:right;}
.planet.post .sq{color: var(--primary-color); font-size: 20px; font-style: italic;}
.planet.post .post-excerpt{
  border-left: solid 3px var(--primary-color);
  margin: 20px 0;
  padding-left: 20px;
  font-style: italic;
  text-align: justify;
}
.planet.post .image-box, .planet.list .image-box{display: flex;align-items: center;flex-wrap: wrap;}

.planet.post .post-image{text-align:center; margin-bottom:20px; margin:auto;}
.planet.post .post-image img{max-height: 400px;}
.planet.post .rate-container {
    display: flex;
    justify-content: center;
    gap: 20px;
    flex-wrap: wrap;
    margin-bottom: 20px;
}

.planet.post .post-rate {
  border: solid 1px lightgray;
  padding: 20px;
  background-color: var(--primary-color);
  color: white;
  text-align: center;
  width: fit-content;
  margin-bottom: 20px;
}
.planet.post .post-rate .rate {font-size: 120%;}
.planet.post .post-rate .rate a{color:white;}
.planet.post .post-rate .rate strong{color:white; font-weight: 800;}

.post-rate li {list-style: none;}
.planet.post .post-rate .pros-cons{  border-top: solid 1px lightgray;}
.planet.post .post-rate .pros-header, .planet.post .post-rate .cons-header{
  font-weight: bold;
  margin-top: 20px;
  text-transform: uppercase;
}


.planet.post .community_feedback {
    background-color: #f9f9f9;
    padding: 30px;
    border-left: 3px solid var(--primary-color);
    margin: 20px 0;
    text-align: justify;
}

.planet.post .community_feedback .opinion-title {
    margin: 0;
    color: #333;
    font-weight: bold;
    text-align: center;
}

.planet.post .community_feedback .opinion-subtitle {
    font-style: italic;
    color: #666;
    margin-bottom: 20px;
    text-align: center;
    border-bottom: solid 1px var(--primary-color);
    font-weight: bold;
}
.planet.post .community_feedback h4 {
    font-size: 1.4rem;
  }


.planet.post section.specs{text-align: justify;}
.planet.post section.faqs{text-align: justify;}

.planet.post .products{margin-top: 20px;}
.planet.post .products .product{border:solid 1px lightgray; padding: 12px; margin: 15px 0;}
.planet.post .products .product .name a{font-size:15px; font-weight: 600; color: #666666;}
.planet.post .products .product .price{
  text-align: center; 
  font-size: 28px; 
  color: var(--primary-color);
  margin-top:10px;
}
.planet.post .buybox {
  border: solid 1px lightgray;
    padding: 20px;
    width: 300px;
    text-align: center;
    margin: auto;
    margin-top:100px;
}
.planet.post .buybox .price, .planet.post .buybox .actions{width:100%} 
.planet.post .products .product .actions{
  text-align: center; 
  margin-top:10px;
}

.planet.post .buybox .price{
  text-align: center; 
  font-size: 28px; 
  color: var(--primary-color);
  margin-top:10px;
}
.planet.post .buybox .actions{
  text-align: center; 
  margin-top:10px;
}


.fa-star.checked {
  color: orange;
}

.planet.post .search-buttons .btn{margin:10px;}
.planet.post .seller-offers {
  color: gray;
  border: solid 1px lightgray;
  background: var(--light-background);
  margin-bottom: 20px;
  margin-top:20px;
}
.planet.post .seller-offers .offers-header{
  background: var(--primary-color);
  color: white;
  text-transform: uppercase;
  padding: 10px;
  text-align: center;
}

.planet.post .seller-offers .offers-footer {
  text-align: center;
  margin: 20px;
}
.planet.post .seller-offers .offer{
  padding: 15px 0px;
  border-bottom: solid 1px var(--primary-color);
  margin:15px;
}

.planet.post .seller-offers .offer:last-child {
  border-bottom: 0;
}
.planet.post .seller-offers .seller-name{font-weight: bold;}
.planet.post .seller-offers .seller-name img {
  max-height: 20px;
}
.planet.post .aff-text {font-size: 0.8rem; font-size: 0.8rem; margin: 20px; text-align: center;}

.planet.post .seller-offers .offer .action{text-align:center;}
.planet.post .seller-offers .offer .from{color: var(--primary-color); font-style: italic;font-size: 13px;}
.planet.post .seller-offers .offer .price{color: var(--primary-color);font-size: 25px;font-weight: 700;}
.widget{margin-bottom:40px;}
.widget .widget-title{
  background-color: var(--primary-color);
  color: white;
  padding: 10px;
}

.planet.post .community_feedback img{float: right;  margin-left: 15px; margin-bottom: 10px; max-width:50%;}
.planet.post .post-body img{float: left;  margin-right: 15px; margin-bottom: 10px; max-width:50%;}
.planet.post .pros-cons-container img{max-height: 300px;}



.planet.post section.faqs img {float: right;margin-left: 15px; margin-bottom: 10px;max-width: 50%;}
.planet.post section.specs img {float: left;margin-right: 15px; margin-bottom: 10px;height: 120px;}




/** Menu articolo */

.article-toc {
  color: gray;
  border: solid 1px lightgray;
  background: var(--light-background);
  margin-bottom: 20px;
  margin-top:20px;
  padding:0;
}

.toc-title {
  background: var(--primary-color);
  color: white;
  text-transform: uppercase;
  padding: 10px;
  text-align: center;
}

.toc-icon { font-size: 1.5rem; }

.toc-title h3 {
    margin: 0;
    font-size: 1.25rem;
    color: #333;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.toc-list {
    list-style: none;
    padding: 0;
    margin: 15px;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); 
    gap: 15px;
}

.toc-list li a {
    display: flex;
    align-items: center;
    gap: 15px;
    text-decoration: none;
    padding: 12px;
    background: #fff;
    border: 1px solid #dee2e6;
    border-radius: 8px;
    transition: all 0.3s ease;
}

.toc-number {
    font-weight: 800;
    color: var(--primary-color);
    font-size: 0.9rem;
    opacity: 0.6;
}

.toc-text {
    font-weight: 600;
    color: #444;
}


.toc-list li a:hover {
    border-color: var(--primary-color);
    transform: translateY(-3px);
    box-shadow: 0 5px 15px rgba(0,74,153,0.1);
}

.toc-list li a:hover .toc-number {
    opacity: 1;
}

@media (max-width: 600px) {
    .toc-list {
        grid-template-columns: 1fr; 
    }
}

/********/


.widget .widget-content ul{
  list-style: disclosure-closed;
  padding-left: 15px;
}
.widget .widget-content li {
  border-bottom: solid 1px lightgray;
  padding: 7px 0;
}
.widget-product{
  border-bottom: solid 1px lightgray;
  padding: 10px 0;
}
.widget-product .widget-product-img{padding-right: 0px;}
.widget-product .widget-prduct-data{padding-left: 5px;}
.widget-product .widget-product-name{font-size:80%; margin-bottom:3px;}
.widget-product .widget-product-actions{text-align:center}
.widget-product .widget-product-actions a{
  border: solid 1px;
  padding: 3px;
  background-color: var(--primary-color);
  color: white;
  border-radius: 10px;

}

.widget .widget-button {
  margin: 10px 0;
  text-align: center;
}
.widget .widget-button:last-child {
  border-bottom: solid 1px lightgray;
  padding-bottom: 10px;
}
.widget .widget-content ul.no-list-style{
  list-style:none;
  padding-left:5px;
}


.condition .badge {
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-weight: 600;
}

/*** Galleria ***/
.gallery-container {
    position: relative;
    width: 100%;
    display: flex;
    align-items: center;
    margin-bottom: 25px;
}
.gallery-container .scrolling-wrapper {
    overflow-x: auto;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 15px;
    scrollbar-width: none; /* Per Firefox */
    -ms-overflow-style: none;  /* Per IE e Edge */
}
.gallery-container .scrolling-wrapper::-webkit-scrollbar {
    display: none;
}

.gallery-container .image-row {
    display: inline-block;
}
.gallery-container .thumbnail-item {
    display: inline-block !important;
    margin: 0 5px;
    transition: transform 0.2s ease-in-out;
    border-radius: 8px;
    overflow: hidden;
    vertical-align: middle;
}

.gallery-container .thumbnail-item:hover {
    transform: scale(1.05);
    cursor: pointer;
}
.gallery-container .thumbnail-item::after {
    display: none !important; 
}

.gallery-container .thumbnail-item img {
    height: 150px;
    width: auto;
    border: 2px solid #eee;
    border-radius: 8px;
    margin-bottom: 0 !important;
}

/* Stile per le frecce di navigazione */
.gallery-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background-color: rgba(0, 0, 0, 0.5);
    color: white;
    border: none;
    padding: 10px 15px;
    cursor: pointer;
    z-index: 10;
    font-size: 24px;
    font-weight: bold;
    line-height: 1;
    border-radius: 50%;
    user-select: none;
    margin-top: -15px;
}

.left-arrow {
    left: -10px;
}

.right-arrow {
    right: -10px;
}
#galleryModal .carousel-inner img {
    max-height: 80vh; 
    max-width: 100%; 
    margin: auto; 
    object-fit: contain; 
}


/* Tabelle */
.table-container {
    width: 100%;
    max-width: 100%;
    overflow-x: auto; 
    -webkit-overflow-scrolling: touch;
    display: block;
    box-sizing: border-box;
}
.table-container table{
    width: 100%;
    border-collapse: collapse;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    background-color: #fff;
    font-size: 15px;
    color: #333;
    table-layout: auto; 
}

.table-container {
    width: 100%;
    max-width: 100%;
    overflow-x: auto;
    display: block;
    box-sizing: border-box;
}
.table-container table {
    width: 100%;
    table-layout: auto;
    border-collapse: collapse;
    border: solid 1px lightgray;
}

/* 3. IL TUO CSS ESISTENTE CON LE CORREZIONI */
.table-container thead tr {
    background-color: var(--primary-color);
    color: white;
    text-transform: uppercase;
    padding: 10px;
    text-align: center;
    border: solid 1px lightgray;

  }

.table-container th, 
.table-container td {
    padding: 14px 18px;
    border-bottom: 1px solid #eee;

}

.table-container td {
    word-break: break-all; 
    overflow-wrap: anywhere;
    white-space: normal;
    min-width: 80px;
}

.table-container tbody td:first-child {
    background-color: #f9f9f9;
    font-weight: 600;
    color: #555;
    width: 30%;
    min-width: 90px;
}

/* Ottimizzazione Mobile */
@media screen and (max-width: 600px) {
    .table-container td {
        padding: 10px 8px; 
        font-size: 13px;
    }
    
    .table-container tbody td:first-child {
        width: 35%;
        min-width: 80px;
    }
}



/** FAQ **/
.faqs h4 {
    font-size: 1.2rem;
    color: #1a1a1a;
    margin: 35px 0 10px 0;
    padding-left: 35px;
    position: relative;
    cursor: default;
    display: flex;
    align-items: center;
}

.faqs h4::before {
    content: "?";
    position: absolute;
    left: 0;
    width: 24px;
    height: 24px;
    background: var(--primary-color);
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.8rem;
    font-weight: bold;
    box-shadow: 0 3px 6px rgba(0,74,153,0.2);
}
.faqs p:not(.faq-excerpt) {
    font-size: 1rem;
    line-height: 1.7;
    color: #555;
    margin-bottom: 25px;
    padding-left: 35px;
    border-bottom: 1px solid #f0f0f0;
    padding-bottom: 25px;
    transition: all 0.3s ease;
}
strong {
    color: var(--primary-color);
    font-weight: 600;
}

i {
    color: var(--primary-color);
    font-style: italic;
}
.faqs h4:hover + p {
    color: #000;
    border-bottom-color: #004a99;
}







/* Responsive */
@media (max-width: 600px) {
    .faqs {
        padding: 15px;
    }
    .faqs h2 {
        font-size: 1.5rem;
    }
    .faqs h4 {
        font-size: 1.1rem;
    }
    .faqs p:not(.faq-excerpt) {
        padding-left: 0;
    }
    .faqs h4::before {
        display: none; 
    }
    .faqs h4 {
        padding-left: 0;
    }
}


@media screen and (max-width: 768px) {  
  /* resposnive table */
  .responsive thead, .responsive tfoot {
    visibility: hidden;
    height: 0;
    position: absolute;
  }
  
  .responsive tr {
    display: contents;
    margin-bottom: .625em;
    /* width: 86vw;*/
  }
  
  .responsive td {
    border: 1px solid;
    border-bottom: none;
    display: block;
    font-size: .8em;
    text-align: right;
    min-height: 40px;
  }
  
  .responsive td::before {
    content: attr(data-label);
    float: left;
    font-weight: bold;
    text-transform: uppercase;
  }
  
  .responsive td:last-child {
    border-bottom: 1px solid;
  }

  /* product pagre */
  .product-detail h1{font-size: 1.5rem;}

  /* utility */
  .hide-on-smartphone{display: none !important;}
  .home .slide .card{margin: 20px 0; height: auto;}
  .product-detail #offers div.offer-image{display:none;}
  .product-detail #offers div.product-name{display:none;}

  .planet.list .post {
    border-right: 0;
    border-bottom: solid 1px lightgray;
    padding-bottom:15px; 
  }
  .planet.list .post:last-child {
    border-bottom: 0;
  }

  .planet.post .community_feedback {padding: 30px 10px;}
  .planet.post .community_feedback img{float: initial; max-width:100%;}
  .planet.post .post-body img{float: initial; max-width:100%;}
  .planet.post .pros-cons-container img{max-height: 100%;}


  .planet.post #buybox{
    position: fixed;
    bottom: 0;
    background-color: white;
    padding:0;
    z-index:10;
  }

  .planet.post #buybox .offers-header{display: none;}
  .planet.post #buybox .product-name{display: none;}
  .planet.post #buybox .offers-footer{display: none;}
  .planet.post #buybox .aff-text{margin:0; margin-bottom:5px; font-size:0.7rem;}
  .planet.post #buybox .offer{border:0; margin:0; padding:0;}
  .planet.post #buybox .offer .col-md-9{width:40%;}
  .planet.post #buybox .offer .col-md-3{width:60%;}
  .planet.post #buybox .offer .seller-name img{max-height: 30px;}
  .planet.post #buybox .seller-offers{margin:0; box-shadow: 0 0 10px;}
  .planet.post #buybox .seller-name{text-align: center;}
  .planet.post #buybox .btn{font-size:14px; padding:3px;}
  .footer{ padding-bottom: 50px;}

  body.review .cky-revisit-bottom-left, body.review .back-to-top{
    bottom: 120px !important;
  }


}



@media screen and (max-width: 992px) {  
  .language-selector {top: -120px;}
  .product-detail #offers .action {margin-right: 2px; margin-top:2px;}
  .product-detail #offers .price {font-size: 16px;}
  .product-detail #offers .shipping-price {font-size: 15px;}
  .product-detail .last-update{font-size: 0.7rem;}

  .planet.post .post-header li.date{float:right;}
  .planet.post .post-header li.tags{float:left;}
}

@media screen and (max-width: 350px) {  
  /* smartphone vecchissimi tipo iphone 5 */
  .language-selector {top: -145px;}

}
