/*
Theme Name: The Party Package Thema
Theme URI: www.thepartypackage.nl
Description: The Party Package Thema
Author: JM Products
Author URI: www.thepartypackage.nl
Version: 1.0
Template: Divi
*/

/* styling colors */

p, a, span, li, label {
font-family: "bahnschrift", sans-serif !important;
font-weight: 400;
font-style: normal;
}

h1, h2, h3, h4, h5, h6 {
font-family: "bahnschrift", sans-serif !important;
font-weight: 700 !important;
font-style: normal;
}

.et-db #et-boc .et-l .et-menu a, .et-db #et-boc .et-l .et_pb_menu_0_tb_header.et_pb_menu ul li.current-menu-item a {
    color: #203e70 !important;
}

h2 span {
  font-weight: 700 !important;
}

#main-content {
  background-color: transparent !important;
}

#main-footer {
  background-image: url('https://thepartypackage.nl/wp-content/uploads/2025/11/background-footer-scaled.png') !important;
  background-position: center !important;
  background-size: cover !important;
  background-color: transparent !important;
}

.link-btn{
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: inherit;
  font-weight: 600;
  text-decoration: none;
  padding-bottom: 2px;
}

.et_pb_text_inner a {
  text-decoration: underline !important;
}

/* doorlopende underline */
.link-btn::before{
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  background: currentColor;
}

/* pijl rechts */
.link-btn::after{
  content: "→";
  display: inline-block;
  font-size: 16px;
  line-height: 1;
  margin-left: 8px;
}

/* hover subtiel */
.link-btn:hover{
  opacity: 0.85;
}

.et_pb_row {
  width: 87% !important;
}

.et_pb_menu__logo {
  margin-right: 0 !important;
}

.et_pb_menu .et-menu>li a{
  color: #203E70;
}
.et_pb_menu .et-menu>li {
  padding: 0px 22px;
}

.wc-forward {
  border-radius: 30px !important;
  padding: 7px 30px 7px 15px !important;
}

.wc-forward:hover {
  background-color: #CF5B6A !important;
}

.dnwoo_woocarousel_container .dnwoo_product_carousel .dnwoo_product_content .dnwoo_product_categories {
  background-color: white !important;
}
.dnwoo_woocarousel_container .dnwoo_product_carousel .dnwoo_product_content .dnwoo_product_title {
  color: #203E70 !important;
  font-family: 'Poppins',Helvetica,Arial,Lucida,sans-serif;
  font-weight: normal !important;
}

.dnwoo_woocarousel_container .dnwoo_product_carousel .dnwoo_single_price .woocommerce-Price-amount{
  color: #203E70 !important;
  font-family: 'Poppins',Helvetica,Arial,Lucida,sans-serif;
  font-weight: bold !important;
  font-size: 18px !important;
}

.swiper-button-next, .swiper-button-prev {
  background-color: #21B3A1 !important;
  border-radius: 30px;
}

.swiper-button-next.dnwoo_woocarousel_arrows_default_right, .dnwoo_cat_carousel_container .dnwoo_cat_carousel_arrows_default_right{
  right: -15px !important;
}
.swiper-button-prev.dnwoo_woocarousel_arrows_default_left, .dnwoo_cat_carousel_container .dnwoo_cat_carousel_arrows_default_left{
  left: -15px !important;
}

.dnwoo_cat_carousel_container .swiper-button-next:after, .dnwoo_cat_carousel_container .swiper-button-prev:after {
  font-size: 15px !important;
}

.dnwoo_minicart_wrapper .dnwoo_minicart_icon {
  background-color: #21B3A1 !important;
}

.pink {
  color: #E71A64;
}

h1 .pink, h1 .blue {
  font-weight: 700 !important;
}

.blue {
  color: #21B3A1;
}

.usp-sub-tekst {
	font-size:14px !important;
}

.leesmeer-blog::after {
  font-family: 'ETMODULES';
content: '\e03c';
font-size: 32px;
color: #21b3a1;
margin-right: 7px;
vertical-align: top;
float: right;
}

.homepage-header-sectie .et_pb_slide_title {
  font-size: 48px !important;
  font-weight: bold !important;
}

.homepage-header-sectie .et_pb_slide_content {
  font-size: 20px !important;
  font-weight: bold !important;
}

.homepage-header-sectie .et_pb_promo {
  border-radius: 30px;
  box-shadow: 0px 3px 6px #0000003d;
}
.homepage-header-sectie .et_pb_promo h1 {
  color: #203e70 !important;
}

.homepage-header-sectie .et_pb_promo .et_pb_promo_description img {
  padding-top: 15px !important;
}

.dnwoo_product_carousel_layout_six .dnwoo_carousel_social_icon_wrap li a:hover {
  background-color: #E71A64 !important;
}

.sectie-blauw, .sectie-blauw h2, .sectie-blauw, .sectie-blauw h1 {
  color: white !important;
}

.header-categorie {
  padding: 20px !important;
  color: white;
}

.top_usp_balk .et_pb_row .et_pb_column{
  padding: 2px 0px !important;
}

.top_usp_balk {
  display: none !important;
}

.header-categorie a {
  color: white !important;
}

.homepage-header-slider {
  border-radius: 10px;
  box-shadow: 0px 3px 6px #0000003d;
}

.homepage-header-slider .et_pb_slide_description {
  text-align: left !important;
  font-family: 'Poppins',Helvetica,Arial,Lucida,sans-serif;
  font-weight: bold !important;
}

.homepage-header-slider .et_pb_slide_description .et_pb_button {
width: 140px !important;
text-align: center;
}

.et_pb_section .thema-lijst .et_pb_button:after {
  right: 15px !important;
}

.homepage-header-sectie {
  padding: 0px !important;
}

.papier-lint {
  margin-top: -100px !important;
  padding: 0px !important;
}

.dnwoo_product_cate_grid_wrapper_layout_one .dnwoo_product_cate_grid_content_inner {
  margin: 0px !important;
  border-radius: 0px 0px 10px 10px !important;
}
.dnwoo_cat_carousel .dnwoo_product_cate_grid_content_inner {
  background-color: transparent !important;
}

.dnwoo_product_cate_grid_item {
  box-shadow: 0px 3px 6px #0000003d;
  border-radius: 10px;
}

.dnwoo_product_cate_grid_thumbnail img{
  border-top-left-radius: 10px !important;
  border-top-right-radius: 10px !important;
  background-color: white !important;
}

#top-menu .current-menu-item a {
  border-bottom: 0px !important;
}

.top-menu #menu-main-menu {
  margin-top: 15px !important;
}

.top-menu-sectie {
  background-color: transparent !important;
}


.et-db #et-boc .et-l .et_pb_menu .top-menu-sectie .et_pb_menu__wrap {
  justify-content: flex-end !important;
  -webkit-box-pack: end !important;
  -ms-flex-pack: inherit !important;
}

.dnwoo_product_carousel_layout_six .dnwoo_product_image {
  border-radius: 10px 10px 0px 0px !important;
}

.dnwoo_product_imgwrap .dnwoo_product_image_container::before{
  border-radius: 10px 10px 0px 0px !important;
}

.dnwoo_carousel .dnwoo_product_content {
  border-radius: 0px 0px 10px 10px !important;
  background-color: white !important
}

.dnwoo_carousel .dnwoo_product_categories {
  border-radius: 0px 0px 10px 10px !important;
  background-color: white !important
}

body .et_pb_button {
  padding: 10px 30px 10px 20px !important;
  border-radius: 30px !important;
  background-color: #f46275 !important;
}

.et_button_icon_visible .et_pb_button:after {
margin-top: 2px !important;
}

body .et_pb_button.blue {
  background-color: #21b3a1 !important;
}

body .et_pb_button:hover{
  filter: brightness(85%) !important;
}

body .styling-btn{
  display: inline-flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  width: auto !important;
  padding: 14px 30px !important;
  white-space: nowrap !important;
  font-size: 14px !important;
  text-decoration: none !important;
}

/* zorgt dat de after netjes naast de tekst staat */
.styling-btn::after{
  display: inline-block !important;
  margin-left: 8px !important;
  position: relative !important;
}

.thema-lijst .et_pb_button {
  width: 100% !important;
  background-color: transparent !important;
}

.thema-lijst .et_pb_button.all-btn {
  width: 100% !important;
  background-color: #203e70 !important;
}

.btn-right .et_pb_button_module_wrapper {
  text-align: right !important;
}

.categorie-bladeren .et_pb_image img {
  border-radius: 10px;
}

.blogs .et_pb_blurb_container{
  background-color: white;
  padding: 20px 30px !important;
  color: #203E70;
  margin-top: -10px;
  border-radius: 0px 0px 10px 10px;
  box-shadow: 0px 3px 6px #0000003d;
}

.blogs .et_pb_main_blurb_image{
  margin-bottom: 0px;
}

.blogs .et_pb_main_blurb_image img {
  border-radius: 10px 10px 0px 0px;
}

.blogs .et_pb_column_12 {
  border-radius: 10px;
}

.blog-artikelen .et_pb_promo_description p:last-of-type {
  padding-bottom: 10px !important;
}

.blog-artikelen .et_pb_promo_button {
    width: 200px !important;
    float: left !important;
  }

.nieuwsbrief-sectie .et_pb_column{
  padding: 5px 10px 5px 10px;
}

.usp-section img{
  border-radius: 10px;
}

#footer-bottom {
  display: none;
}

.faq-sectie .et_pb_accordion_item {
  background-color: transparent !important;
  border-top-width: 0px !important;
  border-right-width: 0px !important;
  border-left-width: 0px !important;
  border-bottom: 3px solid #7e7e7e !important;
}

.faq-sectie h2, .faq-sectie h5 {
  color: #203e70 !important;
}

.faq-sectie .et_pb_toggle_title:before {
  color: #203e70 !important;
}

.faq-sectie .categorie-button {
  color: white !important;
}

.faq-sectie .et_pb_toggle {
  padding-left: 0px !important;
}

.faq-sectie .et_pb_toggle {
  border-bottom: 1px solid #203e70 !important;
}

/* FAQ sectie centreren */
body .faq-sectie{
  display: flex !important;
  justify-content: center !important;
}

/* Accordion wrapper max breedte */
body .faq-sectie .et_pb_accordion{
  width: 100% !important;
  max-width: 860px !important;
  margin: auto !important;
}

/* Toggle kaarten */
body .faq-sectie .et_pb_accordion .et_pb_toggle{
  width: 100% !important;
  border: 1px solid #d4d9e6 !important;
  border-radius: 16px !important;
  background: #ffffff !important;
  box-shadow: 0 10px 26px rgba(0,0,0,0.06) !important;
  overflow: hidden !important;
}

/* Titel */
body .faq-sectie .et_pb_toggle_title{
  position: relative !important;
  padding: 18px 56px 18px 20px !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  color: #0B2046 !important;
  cursor: pointer !important;
}

/* Plus / min icoon */
body .faq-sectie .et_pb_toggle_title::after{
  content: "+" !important;
  position: absolute !important;
  right: 20px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 28px !important;
  height: 28px !important;
  border-radius: 999px !important;
  border: 1px solid #d4d9e6 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 18px !important;
  color: #0B2046 !important;
  background: #ffffff !important;
}

/* Open state */
body .faq-sectie .et_pb_toggle_open .et_pb_toggle_title::after{
  content: "–" !important;
}

/* Content */
body .faq-sectie .et_pb_toggle_content{
  padding: 0 20px 18px 20px !important;
  font-size: 15px !important;
  color: #4e5670 !important;
  line-height: 1.6 !important;
}

/* Hover */
body .faq-sectie .et_pb_toggle:hover{
  border-color: #0B2046 !important;
}

/* Mobiel */
@media (max-width: 980px){
  body .faq-sectie .et_pb_accordion{
    max-width: 100% !important;
  }
}

/* Toggle container */
body .questions .et_pb_toggle{
  border: 1px solid #d4d9e6;
  border-radius: 16px;
  background: #ffffff;
  box-shadow: 0 10px 26px rgba(0,0,0,0.06);
  padding: 0;
  overflow: hidden;
  margin-bottom: 10px !important;
}

/* Titel */
body .questions .et_pb_toggle_title{
  position: relative;
  padding: 18px 56px 18px 20px !important;
  font-size: 16px;
  font-weight: 600;
  color: #0B2046 !important;
  cursor: pointer;
}

/* Plus min icoon rechts */
body .questions .et_pb_toggle_title::after{
  content: "+";
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  width: 28px;
  height: 28px;
  border-radius: 999px;
  border: 1px solid #d4d9e6;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  line-height: 1;
  color: #0B2046;
  background: #ffffff;
}

body .questions .et_pb_toggle_open .et_pb_toggle_title {
  color: #0B2046 !important;
}

/* Open state, min teken */
body .questions .et_pb_toggle_open .et_pb_toggle_title::after{
  content: "–";
}

.questions .et_pb_toggle .et_pb_toggle_title:before {
  display: none !important;
}

/* Content */
body .questions .et_pb_toggle_content{
  padding: 0 20px 18px 20px;
  font-size: 15px;
  color: #4e5670;
  line-height: 1.6;
}

/* Hover */
body .et_pb_toggle:hover{
  border-color: #0B2046;
}

.nieuwsbrief-sectie {
  color: white !important;
}

.nieuwsbrief-sectie h2{
  color: white !important;
}

.woocommerce-page div.product p.price{
  color: #203e70 !important;
}

.breadcrumb-sectie {
  padding: 0px !important;
}

.breadcrumb-sectie .woocommerce-breadcrumb {
  margin-bottom: 0px;
}

.breadcrumb-sectie .et_pb_row {
    padding: 0px !important;
}

.row-price-button {
    display: -webkit-flex; /* Safari */
   display: flex; /* Standard syntax */
}
@media (max-width: 767px){

.column-price {
  -webkit-flex: 1; /* Safari */
    -ms-flex: 1; /* IE 10 */
    flex: 1; /* Standard syntax */
  margin-right: 5% !important;
  display: flex !important;
}
}

.column-price .et_pb_wc_price {
  margin: auto !important;
  margin-left: 0px !important;
}

.column-add-to-cart {
  -webkit-flex: 4; /* Safari */
    -ms-flex: 4; /* IE 10 */
    flex: 4; /* Standard syntax */
}

.column-add-to-cart .single_add_to_cart_button {
  padding: 10px 30px 10px 15px !important;
  border-radius: 30px !important;
}

.column-add-to-cart .ring-container {
    position: relative;
}

.column-add-to-cart .circle {
    width: 15px;
    height: 15px;
    background-color: #62bd19;
    border-radius: 50%;
    position: absolute;
    top: 5px;
left: 10px;
}

.column-add-to-cart .ringring {
    border: 3px solid #62bd19;
    -webkit-border-radius: 30px;
    height: 25px;
    width: 25px;
    position: absolute;
    left: 5px;
    top: 0;
    -webkit-animation: pulsate 1s ease-out;
    -webkit-animation-iteration-count: infinite;
    opacity: 0.0
}
@-webkit-keyframes pulsate {
    0% {-webkit-transform: scale(0.1, 0.1); opacity: 0.0;}
    50% {opacity: 1.0;}
    100% {-webkit-transform: scale(1.2, 1.2); opacity: 0.0;}
}

.ring-container {
  display: -webkit-flex; /* Safari */
 display: flex; /* Standard syntax */
 margin-bottom: 10px;
}

.ring {
  -webkit-flex: 1; /* Safari */
    -ms-flex: 1; /* IE 10 */
    flex: 1; /* Standard syntax */
}

.voorraad-text {
  -webkit-flex: 8; /* Safari */
    -ms-flex: 8; /* IE 10 */
    flex: 8; /* Standard syntax */
    font-size: 12px;
}

.woocommerce .quantity input.qty{
  padding: 8px !important;
}

.product .et_pb_row_inner {
  padding-bottom: 0px !important;
}
.woocommerce div.product form.cart .button:hover {
  background-color: #CF5B6A !important;
}

.woocommerce-notices-wrapper {
  background-color: #203e70 !important;
}
.woocommerce-notices-wrapper .woocommerce-message,.woocommerce .woocommerce-error, .woocommerce .woocommerce-info, .woocommerce .woocommerce-message {
  background-color: #203e70 !important;
  margin-bottom: 20px !important;
  width: 80% !important;
  margin-left: auto !important;
  margin-right: auto !important;

}

.dnwoo_carousel .dnwoo_product_carousel_frontend .swiper-slide {
  padding: 0px 5px !important;
}

.above-header {
  height: 30px !important;
  display: block !important;
  background-color: #21B3A1 !important;
}

.above-header .usp_column_1_3{
  width: 22% !important;
  display: inline-block;
  margin-right: 2% !important;
  text-align: left;
}

.above-header .usp_column_1_3 h4{
  color: white!important;
  font-size: 12px !important;
}

.above-header .usp_column_1_3:last-child {
  margin-right: 0px !important
}

.header-cta .et_pb_promo_description h2{
  padding-bottom: 25px !important;
}

.header-cta .et_pb_promo_description {
  padding-bottom: 0px !important;
}

.rechter-banner {
  display: flex !important;
  flex-direction: column !important;
}

.rechter-banner .inspo {
  flex: 1 !important;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.sectie-blauw .et_pb_row {
  padding: 0px 0px 10px 0px;
}

.sectie-blauw .swiper-container {
  margin-bottom: 0px;
}

.swiper-container .dnwoo_product_carousel_container {
  border-radius: 10px !important;
  box-shadow: 0px 3px 6px #0000003d;
}

.et_pb_section .dnwoo_product_cate_grid_wrapper_layout_one .dnwoo_product_cate_grid_thumbnail img {
  object-fit: contain !important;
}

.et_pb_section .dnwoo_product_cate_grid_wrapper_layout_one .dnwoo_product_cate_grid_content_inner, .et_pb_section .dnwoo_product_cate_grid_carousel_layout_one .dnwoo_product_cate_grid_content {
  position: relative !important;
}

.dnwoo_product_cate_grid_title {
    height: 30px !important;
}


.et_pb_section .dnwoo_cat_carousel_container .dnwoo_product_cate_grid_thumbnail img {
  object-fit: contain !important;
}

.et_pb_section .dnwoo_cat_carousel_container .dnwoo_product_cate_grid_item_inner .dnwoo_product_cate_grid_content {
  position: relative !important;
}

.dnwoo_product_cate_grid_title {
    height: 30px !important;
}

.dnwoo_product_cate_grid_carousel_layout_one .dnwoo_product_cate_grid_item_inner {
  background-color: white !important;
}

.thema-lijst.et_pb_row {
    display: flex !important;
    gap: 5px !important;
}

.thema-lijst.et_pb_row .et_pb_column_1_4 {
  flex: 1 !important;
  margin-right: 0px !important;
}

.thema-lijst .et_pb_column_1_4 .et_pb_module {
  margin-bottom: 7% !important;
}

body #page-container .et_pb_section .et_pb_row.thema-lijst .et_pb_button:hover{
  background-color: #203e70 !important;
  color: white !important;
}

body #page-container .et_pb_section .et_pb_row.thema-lijst .et_pb_button:hover::after  {
  color: white !important;
}

.title-with-button .et_pb_text_inner {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between;
}

.title-with-button .et_pb_text_inner h2, .title-with-button .et_pb_text_inner h3 {
  padding-bottom: 0px !important;
}

body .categorie-button {
  float: right;
  background-color: #21B3A1;
  padding: 13px 45px !important;
  border-radius: 30px;
  color: white;
  margin-left: 20px;
  text-decoration: none !important;
}

.inspo .et_pb_button_wrapper {
  bottom: 17px !important;
  position: absolute !important;
  right: 17px !important;
}

.inspo .et_pb_button_wrapper .et_pb_button {
  padding-right: 30px !important;
}

.inspo .et_pb_promo_description div {
  width: 45% !important;
}

.blue-cta {
  background-color: #21B3A1 !important;
  color: white !important;
  border-color: #21B3A1 !important;
}

.woocommerce-Price-amount {
  font-size: 24px;
  font-weight: 400 !important;
}

.dnwoo_product_grid_title a{
  font-weight: 400;
  font-size: 18px !important;
}

.dnwoo_product_grid_wrapper_layout_one .dnwoo_product_addtocart {
  text-transform: inherit !important;
}

.dnwoo-show-product-text {
  background-color: transparent !important;
}

/* basis */
.acc { position: relative; }

/* het paneel is standaard dicht */
.acc-panel {
  display: grid;
  grid-template-rows: 0fr;       /* moderne, soepelere truc ipv max-height */
  overflow: hidden;
  transition: grid-template-rows .35s ease;
  padding-top: 0px;
  padding-bottom: 0px;
  border-bottom: 2px solid #203e70 !important;
}

/* inhoud mag zijn eigen hoogte bepalen */
.acc-panel > * {
  min-height: 0;                 /* noodzakelijk bij 0fr/1fr patroon */
}

/* open staat */
.acc.is-open .acc-panel {
  grid-template-rows: 1fr;
}

/* trigger styling voorbeeld */
.acc-trigger {
  cursor: pointer;
  user-select: none;
}

/* toegankelijkheid/visuele cues (optioneel) */
.acc-trigger[aria-expanded="true"]::after {
  content: "–";
  float: right;
  margin-top: 9px;
font-size: 40px;
}
.acc-trigger[aria-expanded="false"]::after {
  content: "+";
  float: right;
  margin-top: 9px;
font-size: 40px;
}

.trigger-title .et_pb_text_inner {
  display: inline-block !important;
}

.et_pb_row.acc-panel .et_pb_column .et_pb_module:last-child {
  margin-bottom: 15px !important;
}

.dnwoo-show-product-text {
  box-shadow: unset !important;
}

/* Container netjes naar links of rechts */
.woocommerce-ordering{
  margin: 0 0 20px 0 !important;
}

/* Select wrapper */
.woocommerce-ordering select{
  appearance: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;

  background: #fff !important;
  border: 1px solid #dcdfe4 !important;
  padding: 10px 36px 10px 14px !important;
  font-size: 16px !important;
  line-height: 1.2 !important;
  color: #0f3b6e !important; /* jouw blauw */
  border-radius: 8px !important;
  cursor: pointer !important;
  outline: none !important;
  transition: all .2s ease !important;
  position: relative !important;
}

/* Hover */
.woocommerce-ordering select:hover{
  border-color: #bfc4cc !important;
  box-shadow: 0 2px 6px rgba(0,0,0,0.06) !important;
}

/* Focus */
.woocommerce-ordering select:focus{
  border-color: #0B2046 !important; /* roze */
  box-shadow:
    0 0 0 2px rgba(11, 32, 70, 0.20),   /* subtiele buitenring */
    0 2px 6px rgba(11, 32, 70, 0.15) !important; /* zachte schaduw naar beneden */
}

/* Pijltje toevoegen */
.woocommerce-ordering{
  position: relative !important;
}

.woocommerce-ordering:after{
  content: "▾";
  position: absolute;
  right: 14px;
  top: 50%;
  font-size: 16px;
  color: #0f3b6e;
  pointer-events: none;
  transform: translateY(-50%);
}


/* ============================
   SINGLE PRODUCT → TOGGLE STYLING
============================ */
.single-product .et_pb_toggle {
  border: none !important;
  background: transparent !important;
  padding: 0 !important;
  margin-bottom: 24px !important;
}

/* Header wrapper */
.single-product .et_pb_toggle_title {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  padding: 10px 0 !important;
  position: relative !important;
  cursor: pointer;
  padding-left: 48px !important;
  padding-right: 23px !important;
  height: 75px;
}

/* Nummer-icoon cirkel */
.single-product .et_pb_toggle_title:after {
  content: attr(data-step);
      font-family: "Poppins", sans-serif !important;
      display: flex;
      align-items: center;
      justify-content: center;
      width: 28px;
      height: 28px;
      border: 2px solid #0B2046;
      border-radius: 50%;
      font-size: 13px;
      font-weight: 600;
      color: #0B2046;
      flex-shrink: 0;
      left: 0 !important;
      position: absolute;
      font-weight: 500 !important;
      font-size: 16px;
}

/* Titel tekst */
.single-product .et_pb_toggle_title h5,
.single-product .et_pb_toggle_title {
  font-size: 17px !important;
  font-weight: 600 !important;
  color: #0B2046 !important;
  margin: 0 !important;
}

/* Rechter icoon (minus teken) */
.single-product .et_pb_toggle .et_pb_toggle_title:before {
  font-size: 20px;
  color: #0B2046;
  margin-left: auto;
}

/* Content */
.single-product .et_pb_toggle_content {
  padding: 10px 0 16px 0 !important;
  color: #0B2046 !important;
  font-size: 15px !important;
  line-height: 1.55 !important;
}

/* Onderste lijn */
.single-product .et_pb_toggle::after {
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  background: #0B2046;
  margin-top: 14px;
}

/* Center alle kolommen binnen deze toggle-rij */
.single-product .pakket-steps .et_pb_row {
  display: flex !important;
  align-items: center !important; /* verticaal centreren */
}

/* Zorg dat elke kolom zelf ook de toggle in het midden zet */
.single-product .pakket-steps .et_pb_column {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important; /* centreren binnen de kolom */
}

/* Alleen product detail pagina */
body.single-product #stappen-rij {
  position: relative;
}

/* Mobile slider */
@media (max-width: 767px) {
  body.single-product #stappen-rij {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: visible;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    gap: 14px;
    padding-left: 14px;
    padding-right: 14px;
    margin-left: 0;
    margin-right: 0;
    width: 100% !important;
  }

  .et-db #et-boc .et-l .et_pb_section.pakket-steps{
    padding: 0 33px !important;
  }

  body.single-product #stappen-rij::-webkit-scrollbar {
    display: none;
  }
  body.single-product #stappen-rij {
    scrollbar-width: none;
  }

  body.single-product #stappen-rij > .et_pb_column {
    flex: 0 0 86%;
    max-width: 86%;
    scroll-snap-align: start;
    scroll-snap-stop: always;
  }

  /* Knoppen */
  body.single-product #stappen-rij .stappen-nav{
  position: sticky;
  top: 50%;
  transform: translateY(-50%);
  z-index: 50;
  width: 44px;
  padding: 0px 12px !important;
  height: 44px;
  border-radius: 999px;
  background: #20B3A1;
  border: 1px solid #d4d9e6;
  color: white;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
  box-shadow: 0 10px 26px rgba(0,0,0,0.12);
  transition: background 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease;
  }

  /* hover */
  body.single-product #stappen-rij .stappen-nav:hover{
  background: #20B3A1;
  box-shadow: 0 12px 30px rgba(0,0,0,0.16);
  }

  /* disabled state */
  body.single-product #stappen-rij .stappen-nav.is-disabled{
  opacity: 0.35;
  cursor: default;
  pointer-events: none;
  box-shadow: 0 6px 16px rgba(0,0,0,0.08);
  }

  /* pijl styling als je ::before gebruikt */
  body.single-product #stappen-rij .stappen-nav::before{
  content: “”;
  width: 10px;
  height: 10px;
  border-right: 2px solid #0B2046;
  border-bottom: 2px solid #0B2046;
  transform: rotate(-45deg);
  }

  /* linker pijl */
  body.single-product #stappen-rij .stappen-nav–prev::before{
  transform: rotate(135deg);
  }

  body.single-product #stappen-rij .stappen-nav.stappen-prev {
    left: -10px;
    margin-left: -14px;
  }

  body.single-product #stappen-rij .stappen-nav.stappen-next {
    right: -10px;
    margin-right: -14px;
  }

  body.single-product #stappen-rij .stappen-nav.is-disabled {
    opacity: 0.28;
    pointer-events: none;
  }

  body.single-product #stappen-rij .stappen-nav:focus {
    outline: none;
  }

  body.single-product #stappen-rij .stappen-nav svg {
    width: 18px;
    height: 18px;
    display: block;
  }
}
/* ------- product grid -------- */

.et-db #et-boc .et-l .et_pb_section.no_padding {
  padding: 0px !important;
}

.dnwoo_grid .dnwoo_product_grid_item {
  border-radius: 10px !important;
  padding: 0px !important;
  background-color: white !important;
}

.dnwoo_grid .dnwoo_product_grid_img {
  padding: 15px !important;
  background-color: white !important;
  border-radius: 10px 10px 0px 0px !important;
}

.dnwoo_grid .dnwoo_product_grid_title, .dnwoo_grid .dnwoo_product_grid_price, .dnwoo_grid .dnwoo_product_grid_buttons {
  padding-left: 15px !important;
  padding-right: 15px !important;
  color: #203E70 !important;
}

.dnwoo_grid .dnwoo_product_grid_title, .dnwoo_grid .dnwoo_product_grid_buttons {
  padding-top: 15px !important;
  padding-bottom: 15px !important;
}

.dnwoo_grid .dnwoo_product_grid_buttons a{
  width: 100%;
  background-color: #F46275;
  color: white !important;
  font-weight: bold;
}
.dnwoo_grid .dnwoo_product_grid_buttons a:hover{
  background-color:#c45261;
}

.dnwoo_product_cate_grid_carousel_layout_one .dnwoo_product_cate_grid_content_inner {
  margin: 0px !important;
  padding: 15px !important;
  font-size: 16px !important;
}

.add-menu {
  width: auto !important;
  float: right !important;
}

.add-menu .mini-cart {
  display: inline-block;
  float: left;
  width: 45px !important;
  top: 5px;
}

.add-menu .mini-account {
  display: inline-block;
  float: left;
  width: 27px !important;
  margin-top: 30px !important;
  text-align: left !important;
  top: 5px;
}

.add-menu .mini-zoek {
  display: inline-block;
  float: left;
  width: 45px !important;
  margin-top: 32px !important;
  text-align: left !important;
  top: 5px;
}

.et_pb_cta_1.et_pb_promo {
  padding-top: 90px !important;
}

@media (max-width: 479px) {
    .et-db #et-boc .et-l .top-menu-sectie .et_pb_column {
        width: 11% !important;
    }
}


/* -------- Mobile -------- */
@media only screen and (max-width: 980px) {
  html, body {
  overflow-x: hidden;
  overscroll-behavior-x: none; /* voorkomt ‘bounce’/doorschieten */
}
.tax-product_cat.et-db #et-boc .et-l .et_pb_row {
  padding: 0px !important
}
.et-db #et-boc .et-l .dnwoo_cat_carousel_0_tb_body .dnwoo_product_cate_grid_carousel_layout_one .dnwoo_product_cate_grid_thumbnail img, .et-db #et-boc .et-l .dnwoo_cat_carousel_0_tb_body .dnwoo_product_cate_grid_carousel_layout_one .dnwoo_cat_no_image {
  margin: auto !important;
}

.et-db #et-boc .et-l .dnwoo_cat_carousel_0_tb_body .dnwoo_product_cate_grid_title {
  text-align: center !important;
}

  .desktop-aan {
    display: none;
  }
  #page-container .dnwoo_cat_grid_0 .dnwoo_product_cate_grid_wrapper_layout_one .dnwoo_product_cate_grid_thumbnail img, #page-container .dnwoo_cat_grid_0 .dnwoo_product_cate_grid_wrapper_layout_one .dnwoo_cat_no_image {
    height: 150px !important;
  }

  .dnwoo_product_cate_grid_thumbnail{
      display: flex !important;
      align-items: center !important;
      gap: 12px !important;
      background-color: white !important;

    }

    .dnwoo_product_cate_grid_thumbnail > a:first-child img, body .dnwoo_cat_grid .dnwoo_product_cate_grid_wrapper_layout_one .dnwoo_product_cate_grid_thumbnail img{
      width: 150px !important;
      height: auto !important;
      display: block !important;
      flex-shrink: 0 !important;
      padding: 10px !important;
    }

    .dnwoo_product_cate_grid_thumbnail > a:last-child{
      flex: 1 !important;
      display: block !important;
    }

    .dnwoo_product_cate_grid_title{
      margin: 0 !important;
      text-align: left !important;
      font-size: 1.1rem !important;
    }

  /*changing the Divi hamburger menu to X*/
.mobile_nav.opened .mobile_menu_bar:before {
    content: '\4d';
}
/*rotating the Divi Menu icon*/
.mobile_menu_bar:before {
    transition: all .4s ease;
    transform: rotate(0deg);
    display: block;
}
/*rotate the Divi Menu icon on click*/
.mobile_nav.opened .mobile_menu_bar::before {
    transition: all .4s ease;
    transform: rotate(90deg);
    display: block;
}
/* Remove the top line in the mobile menu*/
.et_mobile_menu {
border-top:0;
}
/*making the Divi Menu full width*/
.et_pb_menu .et_mobile_menu{
  min-width: 100vw;
padding-top: 9% !important;
margin-left: -10vw;
padding-bottom: 100vh !important;
margin-top: 20px;
padding-left: 40px;
}
/*removing the line from the menu items and adding line height*/
.et_mobile_menu li a {
padding:10px 10px!important;
border-bottom: none!important;
}
/*removing padding of the social media icons*/
.et_mobile_menu li li {
    padding-left:0%!important;
}

  .top_usp_balk .usp-horizontal .et-pb-icon, .top_usp_balk .usp-horizontal #cbwrap {
    color: white !important;
  }

  .top-menu-sectie .hoofd-menu {
    margin-bottom: 10px !important;
  }

  .top-menu-sectie .add-menu {
    width: 11% !important;
  }

  .top-menu-sectie .add-menu .mini-cart {
    padding-top: 0px !important;
  }

  .top-menu-sectie .add-menu .mini-cart .et-pb-icon::before{
    font-size: 16px !important;
  }

  .top-menu-sectie .add-menu .mini-cart .et-pb-icon{
    width: 30px;
    height: 30px;
  }

  .top-menu-sectie .add-menu .mini-cart .dnwoo_mmini_cart_count_number {
    width: 15px;
    height: 15px;
    top: -13px !important;
    font-size: 10px;
  }

  .top-menu-sectie .mini-account {
    display: none;
  }

  .header-cta.inspo .et_pb_button {
    margin-top: 85px !important;
  }

  .hoofd-menu .et_pb_menu .et_pb_menu__wrap {
    margin-top: 10px !important;
  }

  .blogs .et_pb_blurb_container {
    padding: 10px 19px !important;
  }

  .et-db #et-boc .et-l .et_pb_section {
    padding: 5px !important;
  }

  #home-header .et_pb_column_0 {
    background-color: #E0B0A2;
    border-radius: 30px 30px 0px 0px;
    padding: 20px;
    margin-bottom: 0px !important;
  }

  .title-with-button .et_pb_text_inner {
    flex-direction: column !important;
  }

  .title-with-button-row {
    padding: 0px !important;
  }

  .categorie-button {
    margin-top: 20px !important;
    margin-left: 0px !important;
  }

  .categorie-button-mobile {
    background-color: #21B3A1;
    padding: 10px 15px;
    border-radius: 30px;
    color: white;
    margin-top: 15px;
    display: inline-block;
  }

  .usp-row {
    padding:0px !important;
  }

  .thema-lijst.et_pb_row {
    flex-direction: column;
  }

  .thema-lijst.et_pb_row .et_pb_column_1_4 {
    width: 100% !important;
  }

  .thema-lijst.et_pb_row .et_pb_column_1_4 .et_pb_button {
    text-align: center !important;
  }

  .thema-lijst .et_pb_column_1_4 .et_pb_module {
    margin-bottom: 15px !important;
  }

  .thema-lijst .et_pb_column_1_4 {
    margin-bottom: 0px !important;
  }

  .usp-row .et_pb_column.et_pb_column_1_4{
    width: 21.25%;
    margin-right: 2.5%;
    margin-left: 2.5%;
  }

  .usp-row .et_pb_blurb_position_left .et_pb_blurb_container {
    padding-left: 5px;
  }

  .categorie-bladeren .et_pb_column.et_pb_column_1_4 {
    width: 23.125%;
    margin-right: 2.5% !important;
  }
  .categorie-bladeren .et_pb_column.et_pb_column_1_4.et-last-child {
    margin-right: 0% !important;
  }

  /* ====== HEADER ROW BASIS ====== */
.et_pb_row_1_tb_header {
  position: relative;                /* referentie voor absolute centrering logo */
  display: flex;
  align-items: center;
  justify-content: space-between;    /* linker kolom links, rechter kolom rechts */
}

/* ====== KOLommen ====== */
.et_pb_column_2_tb_header.hoofd-menu {
  display: flex;
  align-items: center;
  flex: 1 1 auto;                    /* neemt resterende ruimte */
  min-width: 0;
}

.et_pb_column_3_tb_header.add-menu {
  display: flex;
  align-items: center;
  justify-content: flex-end;         /* iconen helemaal rechts */
  gap: 0px;                         /* ruimte tussen iconen */
  flex: 0 0 auto;
}

/* ====== MENU LINKS ====== */
.et_pb_menu_1_tb_header {
  flex: 1 1 auto;                    /* menu mag meeschalen */
  min-width: 0;
}

/* Zorg dat menu-wrapper horizontaal is en menu zelf naar links duwt */
.et_pb_menu_1_tb_header .et_pb_menu__wrap {
  display: flex;
  align-items: center;
  gap: 0;
}

.et_pb_menu_1_tb_header .et_pb_menu__menu {
  margin-right: auto;                /* menu helemaal links */
}

/* ====== LOGO PERFECT GECENTREERD ====== */
/* Haal logo uit de flow en centreer t.o.v. de GEHELE header-rij */
.et_pb_menu_1_tb_header .et_pb_menu__logo-wrap {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);  /* exact midden */
  z-index: 2;                        /* boven andere items indien nodig */
  width: auto;
  display: block;
}

/* Optioneel: max-hoogte voor nette uitlijning */
.et_pb_menu_1_tb_header .et_pb_menu__logo img {
  height: 48px;                      /* pas aan jouw design */
  width: auto;
}

/* Verwijder mogelijke margins/padding die Divi toevoegt */
.et_pb_menu_1_tb_header .et_pb_menu__logo {
  margin: 0;
  padding: 0;
}

/* ====== RECHTER KOLOM ICONEN ====== */
.add-menu .mini-zoek,
.add-menu .mini-cart,
.add-menu .mini-account {
  display: inline-flex;
  align-items: center;
  line-height: 1;
}

/* Maak iconen klikbaar zonder extra spacing-glitches */
.add-menu .et_pb_icon .et_pb_icon_wrap,
.add-menu .dnwoo_mminicart_icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* Mini-cart badge netjes uitlijnen */
.add-menu .dnwoo_mmini_cart_count_number {
  position: relative;
  top: -2px;
  font-size: 12px;
  line-height: 1;
}

/* ====== RESET standaard p/margins in header ====== */
.top-menu-sectie p { margin: 0; }
.top-menu-sectie .et_pb_menu__wrap {
    justify-content: flex-start !important;
    -webkit-box-pack: start !important;

}
.dnwoo_mminicart.dnwoo_mminicart_cart_bag_position_left.dnwoo_mminicart_slide_down.dnwoo_mminicart_alignment_center .dnwoo_mminicart_wrapper .dnwoo_mminicart_cart_bag {
-webkit-transform: translateX(-79%) !important;
transform: translateX(-79%) !important;
}
}
/* -------- Desktop -------- */
@media only screen and (min-width: 981px) {

  .et-divi-dynamic .et_pb_section, .et_pb_section {
        padding: 0px !important;
    }

  .et_pb_gutters3 .et_pb_column_3_4.hoofd-menu {
    width: 86% !important;
    margin-right: 0px !important;
  }

  .tax-product_cat.et-db #et-boc .et-l .et_pb_row {
    padding: 15px !important
  }
.tax-product_cat.et-db #et-boc .et-l .et_pb_section {
    padding: 2% 0;
  }

  .tax-product_cat.et-db #et-boc .mb-30 {
    margin-bottom: 0px !important;
  }

  .mobiel-aan {
    display: none;
  }

  .top-menu-sectie .dnwoo_mminicart_wrapper .dnwoo_mmini_cart_count_number {
    position: relative!important;
    top: -15px !important;
    left: -10px!important;
    right: 0
}

  #home-header {
    height: 400px;
  }
  #home-header .et_pb_row {
    border-radius: 30px 30px 30px 30px;
    padding: 0px;
    box-shadow: 0px 3px 6px #0000003d;
  }

  #home-header .et_pb_column_0 {
    background-color: #E0B0A2;
    margin-right: 0px;
    border-radius: 30px 0px 0px 30px;
  }
  #home-header .et_pb_column_0 .et_pb_text_inner {
    margin: 30px 20px 30px 20px;
  }
  #home-header .et_pb_column_3_5 {
    width: 63.3%;
    border-radius: 0px 30px 30px 0px;
  }

  .categorie-button-mobile {
    display: none;
  }

  .usp-section .et_pb_column_1_5 {
    width: 19.6% !important;
    margin-right: 1.5% !important;
  }

  .top-menu-sectie .et_pb_menu__wrap {
    justify-content: flex-end !important;
    -webkit-box-pack: end !important;
    -ms-flex-pack: inherit !important;

  }
}

.usp-sectie-met-shortcode, .usp-sectie-met-shortcode .et_pb_row {
  padding: 0px !important;
}

.usp-horizontal{
  width: 80% !important;
  margin: auto !important;
}

.product .usp-horizontal{
  width: 100% !important;
  margin: auto !important;
}

.usp-horizontal h4{
  font-size: 15px !important;
  font-weight: normal !important;
}

.usp-horizontal .et-pb-icon, #cbwrap .et-pb-icon {
  font-size: 15px !important;
  font-weight: bold !important;
}

.usp-menu-horizontal .et-pb-icon {
  font-size: 13px !important;
  font-weight: bold !important;
}

.usp-menu-horizontal {
  color: white !important;
  font-size: 13px !important;
}

.header-cta .et-pb-icon {
  font-size: 16px !important;
}

@media (min-width: 981px) {

  /* Submenu: container over de volle page-container breedte */
  .top-menu-sectie .et-menu li.mega-menu > ul.sub-menu {
    position: fixed !important;
     left: 50% !important;
     transform: translateX(-50%);
     top: var(--menu-top, 90px); /* stel je headerhoogte in */
     width: min(100vw, 1400px);
     z-index: 1000;
box-sizing: border-box;
display: grid !important;
grid-template-columns: repeat(5, minmax(0, 1fr));
column-gap: clamp(12px, 1.6vw, 24px);
row-gap: clamp(8px, 1.2vw, 16px);
border-radius: 10px !important;
  }

  .et-menu-nav, .et_menu_container, .et_header_container{ overflow: visible !important; }


  /* Kritiek: Divi forceert soms vaste kolombreedtes/max-widths → uitzetten */
  .top-menu-sectie .et-menu .mega-menu > .sub-menu > li {
    float: none !important;
    width: auto !important;            /* voorkom 25%/vaste breedte */
    max-width: none !important;
    min-width: 0;                      /* laat afbreken in grid */
    clear: none !important;

    /* laat kolom-inhoud netjes stapelen en meerekken */
    display: flex;
    flex-direction: column;
    gap: 8px;
    box-sizing: border-box;
  }

  /* Binnenste UL/LI niet laten “duwen” met eigen breedtes/padding */
  .top-menu-sectie .et-menu .mega-menu > .sub-menu > li > ul,
  .top-menu-sectie .et_menu .mega-menu > .sub-menu > li > ul { /* tweede selector failsafe */
    margin: 0;
    padding: 0;
    list-style: none;
  }

  .top-menu-sectie .et-menu .mega-menu > .sub-menu > li > ul > li {
    float: none !important;
    width: auto !important;
    max-width: none !important;
  }

  /* Kop in elke kolom: breek lange woorden en hou het compact */
  .top-menu-sectie .et-menu .mega-menu > .sub-menu > li > a {
    font-weight: 600;
    white-space: normal;
    word-wrap: break-word;
    margin-bottom: 6px;
    width: auto !important;
  }

  /* (Optioneel) als je nog steeds “ruimte verliest”, maak gaps/padding kleiner op small desktops */
  @media (max-width: 1200px) {
    .top-menu-sectie .et-menu li.mega-menu > ul.sub-menu {
      column-gap: clamp(8px, 1.2vw, 16px);
      padding-left: clamp(8px, 1.6vw, 20px);
      padding-right: clamp(8px, 1.6vw, 20px);
    }
  }

}

.et-l--header{
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 91px;               /* jouw headerhoogte */
  transform: translateY(-100%);
  transition: transform .25s ease;
  z-index: 9999;
}

/* Witte gradient-overlay */
.et-l--header::before{
content:"";
position:absolute;
inset:0;
background: white !important;
border-bottom: 1px solid #F0F0F0;
opacity:0;
pointer-events:none;
transition: opacity .25s ease;
}

/* Wanneer header zichtbaar wordt (bij scroll omhoog) */
.header-show::before{
opacity:1;
}

/* Header zichtbaar */
.header-show{
  transform: translateY(0);
}

/* Zorg dat content niet onder de header valt */
#et-boc, #et-main-area{
  padding-top: 40px;
}



/* ------ Slider ------- */

/* (A1) FORCE ALL SLIDES INTO SINGLE ROW */
.hmove { display: flex; }
.hslide { width: 100%; flex-shrink: 0; }
.hwrap { overflow: hidden; }

 /* eigen styling */
.hwrap {
  width: 100%;
  text-align: center;
}

/* (A2) SLIDES POSITION */
.hmove { position: relative; top: 0; right: 0; }
@keyframes slideh {
  0% { right: 0; } 24% { right: 0; }
  25% { right: 100%; } 49% { right: 100%; }
  50% { right: 200%; } 74% { right: 200%; }
  75% { right: 300%; } 99% { right: 300%; }
  100% { right: 0; }
}

/* (A3) MOVE SLIDES */
.hmove { animation: slideh 15s infinite; }
.hmove:hover { animation-play-state: paused; }

.wc-forward {
  padding: 10px 30px 10px 20px !important;
  background-color: #21B3A1 !important;
  text-transform: none !important;
}

.wc-forward::after {
  margin-top: 2px !important;
}

.wc-forward:hover {
  background-color: #229e8f !important;

}
/* WooCommerce Cart – CRO vriendelijke styling voor thepartypackage.nl */

/* Basis layout alleen op winkelwagen */
body.woocommerce-cart .woocommerce{
  margin: 0 auto;
  padding: 24px 0px !important;
}

/* Achtergrond en typografie */
body.woocommerce-cart{
  background: #f7f8f9;
}
body.woocommerce-cart .woocommerce,
body.woocommerce-cart .woocommerce table,
body.woocommerce-cart .woocommerce th,
body.woocommerce-cart .woocommerce td{
  font-family: "Poppins", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: #0B2046;
}

/* Titel winkelwagen */
body.woocommerce-cart h1,
body.woocommerce-cart h2,
body.woocommerce-cart .cart_totals h2{
  font-size: 26px;
  font-weight: 700;
  margin-bottom: 16px;
}

/* Notificaties netter */
body.woocommerce-cart .woocommerce-message,
body.woocommerce-cart .woocommerce-info,
body.woocommerce-cart .woocommerce-error{
  border-radius: 10px;
  border-width: 1px;
  box-shadow: 0 4px 14px rgba(0,0,0,0.06);
}

/* Cart layout: items links, samenvatting rechts (desktop) */
body.woocommerce-cart .woocommerce-cart-form,
body.woocommerce-cart .cart-collaterals{
  margin-top: 16px;
}

@media (min-width: 900px){
  body.woocommerce-cart .woocommerce{
    display: grid;
    grid-template-columns: minmax(0, 1.8fr) minmax(0, 0.9fr);
    column-gap: 32px;
    align-items: flex-start;
  }

  body.woocommerce-cart .woocommerce-cart-form{
    grid-column: 1;
  }

  body.woocommerce-cart .cart-collaterals{
    grid-column: 2;
  }

  /* Samenvatting sticky op desktop voor minder frictie */
  body.woocommerce-cart .cart-collaterals{
    position: sticky;
    top: 24px;
  }
}

/* Tabel netjes opschonen */
body.woocommerce-cart table.shop_table.cart{
  border-radius: 16px;
  overflow: hidden;
  border: none;
  background: #ffffff;
  box-shadow: 0 10px 30px rgba(0,0,0,0.06);
}

body.woocommerce-cart table.shop_table thead{
  background: #eef1f7;
}

body.WooCommerce-cart table.shop_table .cart-subtotal td {
  text-align: center;
}

body.woocommerce-cart .woocommerce-Price-amount, body.woocommerce-checkout .woocommerce-Price-amount  {
  font-size: 21px !important;
}

body.woocommerce-cart table.shop_table th{
  font-weight: 600;
  text-transform: none;
  letter-spacing: 0;
  padding: 14px 16px;
}

body.woocommerce-cart table.shop_table td{
  padding: 14px 16px;
  vertical-align: middle;
}

/* Lijnen subtieler maken */
body.woocommerce-cart table.shop_table tbody tr{
  border-bottom: 1px solid #e0e4ee;
}

body.woocommerce-cart table.shop_table tbody tr:last-child{
  border-bottom: none;
}

/* Product kolom: thumbnail en naam netjes */
body.woocommerce-cart td.product-thumbnail{
  width: 72px;
}

body.woocommerce-cart td.product-thumbnail img{
  width: 64px;
  height: 64px;
  border-radius: 10px;
  object-fit: cover;
}

/* Coupon knop subtiel maken */
body.woocommerce-cart .coupon .button {
  background: #ffffff !important;
  color: #0B2046 !important;
  border: 1.5px solid #0B2046 !important;
  border-radius: 999px !important;
  padding: 8px 18px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  text-transform: none !important;
  box-shadow: none !important;
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  transition: all .2s ease !important;
}

/* Hover: heel licht blauw */
body.woocommerce-cart .coupon .button:hover {
  background: rgba(11, 32, 70, 0.07) !important;
  border-color: #0B2046 !important;
  color: #0B2046 !important;
}

/* Eventuele iconen weg */
body.woocommerce-cart .coupon .button::after {
  display: none !important;
}

body.woocommerce-cart button[name="update_cart"]::after {
  display: none !important;
}

/* Subtiele update cart knop */
body.woocommerce-cart button[name="update_cart"] {
  background: #ffffff !important;
  color: #0B2046 !important;
  border: 1.5px solid #0B2046 !important;
  border-radius: 999px !important;
  padding: 8px 18px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  text-transform: none !important;
  box-shadow: none !important;
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  cursor: pointer !important;
  transition: all .2s ease !important;
  margin-top: 7px !important;
}

/* Hover */
body.woocommerce-cart button[name="update_cart"]:hover {
  background: rgba(11, 32, 70, 0.07) !important;
  border-color: #0B2046 !important;
  color: #0B2046 !important;
}

/* WooCommerce disabled state overschrijven */
body.woocommerce-cart button[name="update_cart"]:disabled,
body.woocommerce-cart button[name="update_cart"]:disabled:hover {
  opacity: .4 !important;
  cursor: default !important;
  background: #ffffff !important;
  color: #0B2046 !important;
  border: 1.5px solid #0B2046 !important;
}

body.woocommerce-cart td.product-name a{
  color: #0B2046;
  font-weight: 600;
  text-decoration: none;
}

body.woocommerce-cart td.product-name a:hover{
  text-decoration: underline;
}

/* Prijs en subtotalen beter leesbaar */
body.woocommerce-cart td.product-price,
body.woocommerce-cart td.product-subtotal{
  font-weight: 600;
}

/* Hoeveelheid input */
body.woocommerce-cart .quantity .qty{
  max-width: 72px;
  border-radius: 999px;
  border: 1px solid #d4d9e6;
  padding: 6px 10px;
}

/* Verwijder icoontje subtieler maken */
body.woocommerce-cart a.remove{
  color: #f92b73 !important;
  font-size: 20px;
}

body.woocommerce-cart a.remove:hover{
  background: #f92b73;
  color: #ffffff !important;
}

/* Coupon blok compacter en minder afleidend */
body.woocommerce-cart .coupon{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

body.woocommerce-cart .coupon label{
  font-size: 13px;
  opacity: 0.8;
}

body.woocommerce-cart .coupon .input-text{
  border-radius: 999px;
  border: 1px solid #d4d9e6;
  padding: 6px 12px;
}

/* Update cart knop rustiger als secundaire actie */
body.woocommerce-cart button[name="update_cart"]{
  background: #0B2046 !important;
  color: white !important;
  border-radius: 999px !important;
  border: 1px solid #d4d9e6 !important;
  padding: 6px 16px !important;
  font-weight: 500 !important;
}

body.woocommerce-cart button[name="update_cart"]:hover{
  background: #eef1f7 !important;
}

/* Cart totals blok als CRO card */
body.woocommerce-cart .cart-collaterals .cart_totals{
  background: #ffffff;
  border-radius: 16px;
  padding: 20px 18px 22px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.06);
  width: 100% !important;
}

body.woocommerce-cart .cart-collaterals .cart_totals table{
  border: none;
  margin: 0 0 12px;
}

body.woocommerce-cart .cart-collaterals .cart_totals tr th,
body.woocommerce-cart .cart-collaterals .cart_totals tr td{
  border: 0;
  padding: 6px 0;
}

body.woocommerce-cart .cart-collaterals .cart_totals tr.order-total th,
body.woocommerce-cart .cart-collaterals .cart_totals tr.order-total td{
  font-size: 18px;
  font-weight: 700;
}

body.woocommerce-cart .cart-collaterals .cart_totals tr.order-total td, body.woocommerce-cart .cart-collaterals .cart_totals tr.cart-subtotal td{
  text-align: right !important;
}

/* Primaire CTA: Naar afrekenen */
body.woocommerce-cart .cart-collaterals .checkout-button{
  display: block;
  width: 100%;
  text-align: center;
  background: #5fbead !important;
  border-radius: 999px !important;
  padding: 12px 18px !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  text-transform: none !important;
  box-shadow: 0 10px 25px rgba(95,190,173,0.45);
}

body.woocommerce-cart .cart-collaterals .checkout-button:hover{
  background: #4aa99a !important;
}

/* Secundaire link terug naar shop als rustige tekstknop */
body.woocommerce-cart .return-to-shop .button{
  background: transparent !important;
  color: #0B2046 !important;
  border-radius: 999px !important;
  border: 1px solid #d4d9e6 !important;
  padding: 8px 18px !important;
  font-weight: 500 !important;
}

body.woocommerce-cart .return-to-shop .button:hover{
  background: #eef1f7 !important;
}

/* Responsieve verbeteringen voor mobiel */
@media (max-width: 768px){
  body.woocommerce-cart .woocommerce{
    padding: 16px 10px 32px;
  }

  body.woocommerce-cart table.shop_table{
    box-shadow: none;
    border-radius: 0;
  }

  body.woocommerce-cart .cart-collaterals .cart_totals{
    margin-top: 16px;
  }
}

/* CHECKOUT – menu weg, logo blijft staan */
body.woocommerce-checkout #main-header {
  height: auto !important;
  background: transparent !important;
  border-bottom: none !important;
}

/* Verberg alles binnen de header behalve het logo */
body.woocommerce-checkout #main-header .et_menu_container,
body.woocommerce-checkout #main-header .mobile_menu_bar,
body.woocommerce-checkout #main-header nav,
body.woocommerce-checkout #main-header .et_pb_menu__menu,
body.woocommerce-checkout #main-header .et_pb_menu__wrap {
  display: none !important;
}

/* Alleen logo tonen */
body.woocommerce-checkout #main-header .logo_container,
body.woocommerce-checkout #main-header .logo_container img {
  display: block !important;
}

/* Logo centreren voor nette uitstraling */
body.woocommerce-checkout #main-header .logo_container {
  text-align: center !important;
  padding: 12px 0 !important;
}

/* Footer volledig weg (CRO) */
body.woocommerce-checkout footer,
body.woocommerce-checkout #main-footer {
  display: none !important;
}

body.woocommerce-checkout .et-l--header{
position: static !important;
box-shadow: none !important;
background: transparent !important;
border-bottom: none !important;
padding: 0 !important;
}

body.woocommerce-checkout .et-boc {
  padding-top: 0px !important;
}

/* Toon alleen je logo-module en inhoud daarvan */
body.woocommerce-checkout .et-l--header .checkout-logo,
body.woocommerce-checkout .et-l--header .checkout-logo *{
display: block !important;
}

/* Logo netjes centreren */
body.woocommerce-checkout .et-l--header .checkout-logo{
text-align: center !important;
padding: 16px 0 !important;
}

/* Footer volledig weg op checkout */
body.woocommerce-checkout footer,
body.woocommerce-checkout #main-footer{
display: none !important;
}

/* WooCommerce Checkout – CRO vriendelijke styling in lijn met cart */


body.woocommerce-checkout .woocommerce{
  margin: 0 auto;
  padding: 24px 16px 48px;
  font-family: "Poppins", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: #0B2046;
}

body.woocommerce-checkout h1,
body.woocommerce-checkout h2,
body.woocommerce-checkout h3{
  color: #0B2046;
}


/* Notificaties netter */
body.woocommerce-checkout .woocommerce-message,
body.woocommerce-checkout .woocommerce-info,
body.woocommerce-checkout .woocommerce-error{
  border-radius: 10px;
  border-width: 1px;
  box-shadow: 0 4px 14px rgba(0,0,0,0.06);
}

/* Form blokken als kaarten */
body.woocommerce-checkout #customer_details .col-1,
body.woocommerce-checkout #customer_details .col-2{
  background: #ffffff;
  border-radius: 16px;
  padding: 20px 18px 18px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.06);
  margin-bottom: 18px;
}

body.woocommerce-checkout #customer_details h3{
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 12px;
}

/* Labels en velden */
body.woocommerce-checkout .woocommerce-billing-fields__field-wrapper p,
body.woocommerce-checkout .woocommerce-shipping-fields__field-wrapper p,
body.woocommerce-checkout .woocommerce-additional-fields__field-wrapper p{
  margin-bottom: 12px;
}

body.woocommerce-checkout .woocommerce form .form-row label,
body.woocommerce-checkout .woocommerce form .form-row .woocommerce-input-wrapper label{
  font-size: 13px;
  font-weight: 500;
  margin-bottom: 4px;
}

body.woocommerce-checkout .woocommerce form .form-row input.input-text,
body.woocommerce-checkout .woocommerce form .form-row select,
body.woocommerce-checkout .woocommerce form .form-row textarea{
  width: 100%;
  border-radius: 999px;
  border: 1px solid #d4d9e6;
  padding: 8px 12px;
  font-size: 14px;
  color: #0B2046;
  box-shadow: none;
}

body.woocommerce-checkout .woocommerce form .form-row textarea{
  border-radius: 12px;
  min-height: 80px;
}

body.woocommerce-checkout .woocommerce form .form-row input.input-text:focus,
body.woocommerce-checkout .woocommerce form .form-row select:focus,
body.woocommerce-checkout .woocommerce form .form-row textarea:focus{
  border-color: #0B2046;
  box-shadow: 0 0 0 1px rgba(11,32,70,0.12);
  outline: none;
}

/* Placeholders iets lichter */
body.woocommerce-checkout ::placeholder{
  color: #a0a6b8;
}

/* Order review blok als kaart */
body.woocommerce-checkout #order_review{
  background: #ffffff;
  border-radius: 16px;
  padding: 20px 18px 18px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.06);
}

body.woocommerce-checkout #order_review_heading{
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 12px;
}

/* Order table opschonen */
body.woocommerce-checkout #order_review table.shop_table{
  border: none;
  margin: 0 0 12px;
}

body.woocommerce-checkout #order_review table.shop_table th,
body.woocommerce-checkout #order_review table.shop_table td{
  border: 0;
  padding: 6px 0;
}

body.woocommerce-checkout #order_review table.shop_table thead{
  border-bottom: 1px solid #e0e4ee;
}

body.woocommerce-checkout #order_review table.shop_table tfoot tr.order-total th,
body.woocommerce-checkout #order_review table.shop_table tfoot tr.order-total td{
  font-size: 18px;
  font-weight: 700;
}

body.woocommerce-checkout #order_review table.shop_table tfoot tr.order-total td, body.woocommerce-checkout #order_review table.shop_table td.product-total, .woocommerce-checkout #main-content .cart-subtotal td {
  text-align: right;
}

.showcoupon {
  text-decoration: underline;
}

.checkout_coupon .button {
  padding: 10px 40px 10px 20px !important;
    border-radius: 20px !important;
}

.checkout_coupon .button::after {
  font-size: 24px !important;
}

/* Betalingsmethoden blok */
body.woocommerce-checkout #payment{
  background: #f5f6fb;
  border-radius: 12px;
  padding: 14px 12px 10px;
}

body.woocommerce-checkout #payment ul.payment_methods{
  padding: 0;
  margin: 0 0 10px;
}

body.woocommerce-checkout #payment ul.payment_methods li{
  list-style: none;
  padding: 6px 0;
}

body.woocommerce-checkout #payment .payment_box{
  background: transparent;
  padding: 4px 0 0;
}

/* Primaire CTA: bestelling plaatsen */
body.woocommerce-checkout #place_order{
  display: block;
  width: 100%;
  text-align: center;
  background: #5fbead !important;
  border-radius: 999px !important;
  padding: 12px 18px !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  text-transform: none !important;
  border: none !important;
  box-shadow: 0 10px 25px rgba(95,190,173,0.45) !important;
}

body.woocommerce-checkout #place_order:hover{
  background: #4aa99a !important;
}

/* Terms & conditions tekst kleiner en rustig */
body.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper{
  margin-top: 10px;
  font-size: 12px;
  color: #4a5270;
}

body.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper a{
  color: #0B2046;
}

/* Mobiel tweaks */
@media (max-width: 768px){
  body.woocommerce-checkout .woocommerce{
    padding: 16px 10px 32px;
    display: block;
  }

  body.woocommerce-checkout #order_review{
    margin-top: 16px;
  }
}

/* WooCommerce checkout layout – formulier links, order review rechts
   Additional fields onder shipping
*/

/* Alleen op checkout */
body.woocommerce-checkout{
  background: #f7f8f9;
}

body.woocommerce-checkout .col-1, body.woocommerce-checkout .col-2 {
  width: 100% !important;
  float: none !important;
}


/* Alleen checkout layout, desktop */
@media (min-width: 900px){

  /* Maak van het checkout formulier een 2 koloms grid */
  body.woocommerce-checkout form.checkout{
    display: grid;
    grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
    column-gap: 32px;
    align-items: flex-start;
  }

  /* Linkerzijde: klantgegevens */
  body.woocommerce-checkout #customer_details,
  body.woocommerce-checkout #customer-details{
    grid-column: 1;
  }

  /* Additional fields ook links, onder shipping */
  body.woocommerce-checkout .woocommerce-additional-fields{
    grid-column: 1;
    margin-top: 16px;
  }

  /* Rechterzijde: order review blok */
  body.woocommerce-checkout #order_review{
    grid-column: 2;
    align-self: flex-start;
    position: sticky;
    top: 24px;
    margin-top: 0;
  }

  /* Originele heading verbergen op desktop */
  body.woocommerce-checkout #order_review_heading{
    display: none;
  }

  /* Nieuwe heading binnen het order review blok */
  body.woocommerce-checkout #order_review::before{
    content: "Je bestelling";
    display: block;
    font-size: 20px;
    font-weight: 700;
    margin: 0 0 12px 0;
    color: #0B2046;
  }
}

/* Mobiel: alles onder elkaar */
@media (max-width: 899px){
  body.woocommerce-checkout form.checkout{
    display: block;
  }

  /* Op mobiel mag de originele heading gewoon zichtbaar zijn */
  body.woocommerce-checkout #order_review_heading{
    display: block;
  }

  body.woocommerce-checkout #order_review::before{
    content: none;
  }
}

/* MOBIEL OVERLAY MENU CSS – thepartypackage.nl */

/* Verberg standaard Divi mobiele UL in deze header */
@media (max-width: 980px){
  .et_pb_menu_1_tb_header .et_mobile_menu{
    display: none !important;
  }
}

/* Body lock wanneer overlay open is */
.tp-mobile-overlay-open{
  overflow: hidden;
}

/* Volledige overlay achtergrond */
@media (max-width: 980px){

  #tp-mobile-overlay.tp-mobile-overlay{
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: rgba(11, 32, 70, 0.16); /* zachte blauwe gloed */
    display: none;
  }

  /* zichtbaar state, aangestuurd door JS */
  #tp-mobile-overlay.tp-mobile-overlay.tp-mobile-overlay--visible{
    display: block;
  }

  /* binnenpaneel, wit vlak met content */
  #tp-mobile-overlay .tp-mobile-overlay__inner{
    position: absolute;
    top: 80px;              /* ruimte voor je bestaande headerbalk */
    left: 0;
    right: 0;
    bottom: 0;
    background: #ffffff;
    padding: 24px 24px 28px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.12);
    border-radius: 24px;
    overflow-y: auto;
    height: calc(100vh - 80px);
  }



  /* hoofditems en themalinks (paneel 1 én 2) */
  #tp-mobile-overlay .tp-mobile-overlay__item{
    display: flex;
    align-items: center;
    justify-content: flex-start;
    width: 100%;
    padding: 12px 4px;
    border: none;
    background: transparent;
    text-align: left;
    font-family: "Poppins", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-size: 17px;
    font-weight: 600;
    color: #0B2046;
    text-decoration: none;
    cursor: pointer;
  }

  #tp-mobile-overlay .tp-mobile-overlay__item span{
    margin-right: auto;
  }

  #tp-mobile-overlay .tp-mobile-overlay__item:hover{
    color: #31456b;
  }

  /* subtiel lijntje tussen groepen */
  #tp-mobile-overlay .tp-mobile-overlay__group-separator{
    margin: 6px 0;
    border-bottom: 1px solid #d4d9e6;
  }

  /* Terug knop in themapaneel */
  #tp-mobile-overlay .tp-mobile-overlay__back{
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 12px;
    padding: 4px 0;
    border: none;
    background: transparent;
    font-family: "Poppins", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-size: 15px;
    font-weight: 600;
    color: #0B2046;
    cursor: pointer;
  }

  #tp-mobile-overlay .tp-mobile-overlay__back:hover{
    color: #31456b;
  }

  #tp-mobile-overlay .tp-mobile-overlay__back::before{
    content: "\f104"; /* Font Awesome angle-left */
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: 16px;
  }

  /* extra label boven sublijst */
  #tp-mobile-overlay .tp-mobile-overlay__heading{
    font-family: "Poppins", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #7c8496;
    margin-bottom: 10px;
  }

  /* Font Awesome arrow-right op Thema's knop in hoofdpanel */
  #tp-mobile-overlay .tp-mobile-overlay__item[data-target="themas"]::after{
    content: "\f105"; /* fa-angle-right */
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: 16px;
    color: #0B2046;
  }

  /* sublinks in themapaneel iets lichter */
  #tp-mobile-overlay .tp-mobile-overlay__panel--themas .tp-mobile-overlay__item{
    font-size: 16px;
    font-weight: 500;
  }

  /* geen bullets in themapaneel, alles strak links */
  #tp-mobile-overlay .tp-mobile-overlay__panel--themas .tp-mobile-overlay__item::before{
    display: none !important;
  }
  /* Hele item klikbaar + pijl negeren */
  #tp-mobile-overlay .tp-mobile-overlay__item{
    position: relative;
    pointer-events: auto !important;
  }

  #tp-mobile-overlay .tp-mobile-overlay__panel--cat-gelegenheden .tp-mobile-overlay__item:last-child{
    padding-bottom: 150px !important;
  }

  /* Maak alleen de pijl niet-klikbaar */
  #tp-mobile-overlay .tp-mobile-overlay__item[data-target="themas"]::after{
    pointer-events: none !important;
  }

  /* Pijl rechts naast Gelegenheden in paneel 2 */
#tp-mobile-overlay .tp-mobile-overlay__panel--themas
.tp-mobile-overlay__item[data-target="cat-gelegenheden"]{
  position: relative;
  padding-right: 26px;
}

#tp-mobile-overlay .tp-mobile-overlay__panel--themas
.tp-mobile-overlay__item[data-target="cat-gelegenheden"]::after{
  content: "\f105"; /* Font Awesome angle-right */
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  font-size: 16px;
  color: #0B2046;
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none; /* zodat de hele rij klikbaar is */
}
/* Geen horizontale scroll in overlay */
 #tp-mobile-overlay .tp-mobile-overlay__inner{
   overflow-x: hidden !important;
 }

 #tp-mobile-overlay .tp-mobile-overlay__panel{
   max-width: 100% !important;
   box-sizing: border-box !important;
   overflow-x: hidden !important;
 }

 /* Alle directe content in panelen mag nooit breder zijn dan 100% */
 #tp-mobile-overlay .tp-mobile-overlay__panel{
   box-sizing: border-box;
   max-width: 100%;
 }

/* HEADER NOOIT VERDWIJNEN ALS OVERLAY OPEN IS */
  body.tp-mobile-overlay-open .et-l.et-l--header{
    transform: translateY(0) !important;
    opacity: 1 !important;
    pointer-events: auto !important;
  }

  /* WITTE ACHTERGROND (DIVI SECTIE & MENU-WRAPPER) OOK FIXEREN */
  body.tp-mobile-overlay-open .et_pb_section.et_pb_section--with-menu,
  body.tp-mobile-overlay-open .top-menu-sectie,
  body.tp-mobile-overlay-open .et_pb_menu_1_tb_header,
  body.tp-mobile-overlay-open .et_builder_inner_content{
    transform: translateY(0) !important;
    opacity: 1 !important;
    pointer-events: auto !important;
  }

  /* voorkom dat een “header-hide” class het alsnog kapotmaakt */
  body.tp-mobile-overlay-open .header-hide{
    transform: translateY(0) !important;
    opacity: 1 !important;
  }
}


@media (max-width: 980px){

  /* Basis: alle panelen buiten beeld, onklikbaar */
  #tp-mobile-overlay .tp-mobile-overlay__panel{
    position: absolute;
    top: 24px;
    left: 24px;
    right: 24px;
    bottom: 24px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    box-sizing: border-box;
    transition: transform 0.28s ease, opacity 0.28s ease;
    transform: translateX(100%);
    opacity: 0;
    pointer-events: none;
  }

  /* STATE: hoofdmenu actief */
  #tp-mobile-overlay.tp-mobile-overlay--main .tp-mobile-overlay__panel--main{
    transform: translateX(0);
    opacity: 1;
    pointer-events: auto;
  }

  /* STATE: thema-overzicht actief */
  #tp-mobile-overlay.tp-mobile-overlay--themas .tp-mobile-overlay__panel--main{
    transform: translateX(-40%);
    opacity: 0;
    pointer-events: none;
  }

  #tp-mobile-overlay.tp-mobile-overlay--themas .tp-mobile-overlay__panel--themas{
    transform: translateX(0);
    opacity: 1;
    pointer-events: auto;
  }

  /* STATE: Gelegenheden actief */
  #tp-mobile-overlay.tp-mobile-overlay--cat-gelegenheden .tp-mobile-overlay__panel--main,
  #tp-mobile-overlay.tp-mobile-overlay--cat-gelegenheden .tp-mobile-overlay__panel--themas{
    transform: translateX(-40%);
    opacity: 0;
    pointer-events: none;
  }

  #tp-mobile-overlay.tp-mobile-overlay--cat-gelegenheden .tp-mobile-overlay__panel--cat-gelegenheden{
    transform: translateX(0);
    opacity: 1;
    pointer-events: auto;
  }

  /* STATE: Magische actief */
  #tp-mobile-overlay.tp-mobile-overlay--cat-magische .tp-mobile-overlay__panel--main,
  #tp-mobile-overlay.tp-mobile-overlay--cat-magische .tp-mobile-overlay__panel--themas{
    transform: translateX(-40%);
    opacity: 0;
    pointer-events: none;
  }

  #tp-mobile-overlay.tp-mobile-overlay--cat-magische .tp-mobile-overlay__panel--cat-magische{
    transform: translateX(0);
    opacity: 1;
    pointer-events: auto;
  }

  /* STATE: Stoere actief */
  #tp-mobile-overlay.tp-mobile-overlay--cat-stoere .tp-mobile-overlay__panel--main,
  #tp-mobile-overlay.tp-mobile-overlay--cat-stoere .tp-mobile-overlay__panel--themas{
    transform: translateX(-40%);
    opacity: 0;
    pointer-events: none;
  }

  #tp-mobile-overlay.tp-mobile-overlay--cat-stoere .tp-mobile-overlay__panel--cat-stoere{
    transform: translateX(0);
    opacity: 1;
    pointer-events: auto;
  }

  /* STATE: Dieren actief */
  #tp-mobile-overlay.tp-mobile-overlay--cat-dieren .tp-mobile-overlay__panel--main,
  #tp-mobile-overlay.tp-mobile-overlay--cat-dieren .tp-mobile-overlay__panel--themas{
    transform: translateX(-40%);
    opacity: 0;
    pointer-events: none;
  }

  #tp-mobile-overlay.tp-mobile-overlay--cat-dieren .tp-mobile-overlay__panel--cat-dieren{
    transform: translateX(0);
    opacity: 1;
    pointer-events: auto;
  }

  /* STATE: Overig actief */
  #tp-mobile-overlay.tp-mobile-overlay--cat-overig .tp-mobile-overlay__panel--main,
  #tp-mobile-overlay.tp-mobile-overlay--cat-overig .tp-mobile-overlay__panel--themas{
    transform: translateX(-40%);
    opacity: 0;
    pointer-events: none;
  }

  #tp-mobile-overlay.tp-mobile-overlay--cat-overig .tp-mobile-overlay__panel--cat-overig{
    transform: translateX(0);
    opacity: 1;
    pointer-events: auto;
  }

  /* Pijltjes op alle items die doorsturen (data-target) */
  #tp-mobile-overlay .tp-mobile-overlay__item[data-target]{
    position: relative;
    padding-right: 26px;
  }

  #tp-mobile-overlay .tp-mobile-overlay__item[data-target]::after{
    content: "\f105"; /* Font Awesome angle-right */
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: 16px;
    color: #0B2046;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none; /* hele rij blijft klikbaar */
  }
}

/* animatie binnenpaneel (open overlay van boven naar beneden) */
@keyframes tp-overlay-slide-in{
  0%{
    transform: translateY(-24px);
    opacity: 0;
  }
  100%{
    transform: translateY(0);
    opacity: 1;
  }
}


/* ALGOLIA SEARCH SECTIE UITKLAPBAAR + STYLING */

@media (min-width: 0px){

  /* Sectie zelf: standaard dicht */
  #algolia-search-bar{
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    visibility: hidden;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    background: transparent !important;
    transition:
      max-height 0.25s ease,
      opacity 0.25s ease,
      visibility 0.25s ease;
  }



  /* als open: sectie zichtbaar + ruimte onder header */
  body.tp-header-search-open #algolia-search-bar{
    max-height: calc(100vh - 80px); /* 80px = ongeveer jouw headerhoogte */
    opacity: 1;
    visibility: visible;
    padding-top: 10px !important;   /* ruimte tussen menu en balk */
    padding-bottom: 10px !important;
    background: transparent !important;
  }

  /* Divi rij centreren en full width houden */
  #algolia-search-bar .et_pb_row{
    max-width: 1200px;
    margin-left: auto !important;
    margin-right: auto !important;
    padding: 0 !important;
  }

  #algolia-search-bar .et_pb_column,
  #algolia-search-bar .et_pb_code,
  #algolia-search-bar .et_pb_code_inner{
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
  }

  /* Onze eigen container: echte balk */
  #algolia-search-bar .tp-header-search{
    width: 100%;
    background: #ffffff;
    border-radius: 10px;
    border: 1px solid #d4d9e6;
    box-shadow: 0 12px 30px rgba(0,0,0,0.08);
  }

  .tp-header-search__form{
    display: flex;
    align-items: center;
    gap: 5px;
    padding: 10px 14px;
    box-sizing: border-box;
  }

  .tp-header-search__input{
    flex: 1;
    border-radius: 999px;
    border: 1px solid #d4d9e6;
    padding: 10px 14px;
    font-family: "Poppins", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-size: 15px;
    color: #0B2046;
    outline: none;
    background: #f7f8fb;
  }

  .tp-header-search__input::placeholder{
    color: #9aa1b3;
  }

  .tp-header-search__input:focus{
    border-color: #0B2046;
    box-shadow: 0 0 0 2px rgba(11, 32, 70, 0.12);
    background: #ffffff;
  }

  .tp-header-search__submit{
    border-radius: 999px;
    border: none;
    padding: 13px 12px;
    background: #0B2046;
    color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    flex-shrink: 0;
  }

  .tp-header-search__submit .et-pb-icon{
    font-size: 16px;
    line-height: 1;
  }

  .tp-header-search__submit:hover{
    filter: brightness(1.05);
  }

  /* Close knop met kruisje */
  .tp-header-search__close{
    border: none;
    background: transparent;
    color: #8189a0;
    font-size: 20px;
    line-height: 1;
    padding: 0 4px;
    cursor: pointer;
    flex-shrink: 0;
  }

  .tp-header-search__close:hover{
    color: #0B2046;
  }

  /* Resultaten */
  .tp-header-search__results{
    padding: 0 10px 10px;
    box-sizing: border-box;
    max-height: calc(80vh - 140px); /* header + zoekbalk zelf + beetje marge */
    overflow-y: auto;
    padding: 0 10px 10px;
    box-sizing: border-box;
  }

    .tp-header-search__results-item::marker {
      display: none !important;
    }

  .tp-header-search__results-list{
    margin: 0;
    padding: 8px 0 !important;
    list-style: none;
    background: #ffffff;
    border-radius: 12px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.08);
    border: 1px solid #d4d9e6;
  }

  .tp-header-search__results-item{
    border-bottom: 1px solid #edf0f7;
    list-style-type: none !important;
  }

  .tp-header-search__results-item:last-child{
    border-bottom: none;
  }

  .tp-header-search__results-link:hover{
    background: #f7f8fb;
  }

  .tp-header-search__results-title{
    font-size: 15px;
    font-weight: 600;
  }

  .tp-header-search__results-meta{
    font-size: 12px;
    font-weight: 500;
    color: #8189a0;
  }

  .tp-header-search__results-empty{
    padding: 8px 12px;
    font-size: 14px;
    color: #8189a0;
  }
}

@media (max-width: 980px){
  .tp-header-search__form{
    padding: 8px 10px;
  }
  .tp-header-search__results{
    padding: 0 8px 8px;
  }
}


@media (max-width: 980px){

  #fold-menu.et_pb_row_2_tb_header {
    padding: 0px !important;
  }

  /* zorg dat de menu-wrap niet boven alles hangt */
  .et_pb_menu_1_tb_header .et_pb_menu__wrap{
    position: relative;
    z-index: 22 !important;
  }

  /* zoek-icoon boven de menu-wrap leggen */
  #header-zoek-icon.et_pb_icon_2_tb_header{
    position: relative;
    z-index: 9999 !important;
  }
}

/* MOBIEL: zoekicoon klikbaar maken, menu-wrap mag niet eroverheen liggen */
@media (max-width: 980px){

  /* Row met mobiel menu en iconen netjes als flex naast elkaar */
  .et_pb_row_1_tb_header{
    display: flex !important;
    align-items: center;
    justify-content: space-between;
  }

  /* Kolom met menu */
  .et_pb_column_2_tb_header.hoofd-menu{
    flex: 1 1 auto !important;
    min-width: 0;
  }

  /* Kolom met zoekicoon + cart */
  .et_pb_column_3_tb_header.add-menu{
    flex: 0 0 auto !important;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    position: relative !important;
    z-index: 50 !important;
  }

  /* Belangrijk: menu-wrap mag niet full-width over de iconen hangen */
  .et_pb_menu_1_tb_header .et_pb_menu__wrap{
    position: relative !important;
    z-index: 1 !important;
    max-width: calc(100% - 80px) !important; /* ruimte rechts voor iconen */
    margin-right: auto !important;
  }

  /* Zorg dat mobiele nav zelf ook niet over de iconen heen hangt */
  .et_pb_menu_1_tb_header .et_mobile_nav_menu{
    position: relative !important;
    z-index: 1 !important;
  }

  /* Jouw mobiele zoekicoon altijd boven alles */
  #header-zoek-icon.et_pb_icon_2_tb_header{
    position: relative !important;
    z-index: 9999 !important;
    pointer-events: auto !important;
  }

  /* Het clickable gebied van de iconen niet “afgepakt” laten worden */
  .et_pb_column_3_tb_header.add-menu .et_pb_icon,
  .et_pb_column_3_tb_header.add-menu .mini-zoek{
    pointer-events: auto !important;
  }

  /* Zoekknop in de Algolia zoekbalk → Font Awesome f002 */
.tp-header-search__submit .et-pb-icon{
  font-family: "Font Awesome 6 Free" !important;
  font-weight: 900 !important;
  font-size: 16px !important;
}
}

/* extra styling voor categorie, snippet, badge en prijs */

/* De container van elke zoekresultaatkaart */
.tp-header-search__results-link{
  display: flex;
  align-items: flex-start;
  gap: 12px;
  text-decoration: none;
  padding: 10px 12px;
  color: #0B2046;
}

/* Linker kolom: thumbnail */
.tp-header-search__thumb{
  flex: 0 0 60px;
  width: 60px;
  height: 60px;
  border-radius: 12px;
  overflow: hidden;
  background: #f1f3f9;
  display: flex;
  align-items: center;
  justify-content: center;
}

.tp-header-search__thumb img{
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Rechter kolom: alles naast de thumbnail */
.tp-header-search__body{
  display: flex;
  flex-direction: column;
  gap: 3px;
  flex: 1;
  min-width: 0; /* voorkomt overflow */
}

/* Titel */
.tp-header-search__title{
  font-size: 15px;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Categorie */
.tp-header-search__category{
  font-size: 12px;
  color: #7c8496;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Snippet */
.tp-header-search__snippet{
  font-size: 13px;
  color: #4e5670;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Onderste regel: prijs + badge */
.tp-header-search__bottom{
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 4px;
}

/* Prijs */
.tp-header-search__price{
  display: flex;
  align-items: baseline;
  gap: 6px;
}

.tp-header-search__price-old{
  font-size: 13px;
  color: #9aa1b3;
  text-decoration: line-through;
}

.tp-header-search__price-new,
.tp-header-search__price-single{
  font-size: 14px;
  font-weight: 600;
  color: #0B2046;
}

/* Badge */
.tp-header-search__results-badge{
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 999px;
  background: #ffeaf2;
  color: #b0205a;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

/* Sold out badge */
.tp-header-search__results-badge--soldout{
  background: #ffe5e5;
  color: #c62828;
}

/* Mobiel compact */
@media (max-width: 980px){
  .tp-header-search__thumb{
    flex: 0 0 50px;
    width: 50px;
    height: 50px;
  }
}

/* Algolia zoekpagina, product kaarten, thumbnail links, tekst rechts */

/* Layout container van de hits, maakt er een nette grid van */
#algolia-hits .ais-Hits-list,
#algolia-hits .ais-hits,
#algolia-hits .ais-InfiniteHits-list{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin: 0;
  padding: 0;
  list-style: none;
}

/* Tablet */
@media (max-width: 980px){
  #algolia-hits .ais-Hits-list,
  #algolia-hits .ais-hits,
  #algolia-hits .ais-InfiniteHits-list{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
  }
}

/* Mobiel */
@media (max-width: 640px){
  #algolia-hits .ais-Hits-list,
  #algolia-hits .ais-hits,
  #algolia-hits .ais-InfiniteHits-list{
    grid-template-columns: 1fr;
    gap: 12px;
  }
}

/* Kaart */
.tp-ais-card{
  margin: 0;
}

.tp-ais-card__link{
  display: flex;
  gap: 12px;
  padding: 12px;
  border-radius: 16px;
  border: 1px solid #d4d9e6;
  background: #ffffff;
  box-shadow: 0 10px 26px rgba(0,0,0,0.06);
  text-decoration: none;
  color: #0B2046;
  min-height: 94px;
}

.tp-ais-card__link:hover{
  background: #f7f8fb;
}

/* Thumbnail links */
.tp-ais-card__thumb{
  flex: 0 0 76px;
  width: 76px;
  height: 76px;
  border-radius: 14px;
  overflow: hidden;
  background: #f1f3f9;
  display: flex;
  align-items: center;
  justify-content: center;
}

.tp-ais-card__thumb img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Tekst kolom rechts */
.tp-ais-card__body{
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1;
  min-width: 0;
}

/* Titel */
.tp-ais-card__title{
  font-family: "Poppins", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: 15px;
  font-weight: 600;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Categorie */
.tp-ais-card__cat{
  font-size: 12px;
  font-weight: 500;
  color: #7c8496;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Snippet */
.tp-ais-card__snippet{
  font-size: 13px;
  color: #4e5670;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Onderste regel */
.tp-ais-card__bottom{
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 4px;
}

/* Prijs */
.tp-ais-card__price{
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
}

.tp-ais-card__price-old{
  font-size: 13px;
  color: #9aa1b3;
  text-decoration: line-through;
}

.tp-ais-card__price-new,
.tp-ais-card__price-single{
  font-size: 14px;
  font-weight: 600;
  color: #0B2046;
}

/* Badge */
.tp-ais-card__badge{
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 999px;
  background: #ffeaf2;
  color: #b0205a;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.tp-ais-card__badge--soldout{
  background: #ffe5e5;
  color: #c62828;
}

/* Highlight van Algolia iets netter */
.tp-ais-card em,
.algolia-search-highlight{
  background-color: #fffbcc;
  border-radius: 3px;
  padding: 0 2px;
  font-style: normal;
}

/* Mobiel iets compacter */
@media (max-width: 980px){
  .tp-ais-card__link{
    padding: 10px;
    border-radius: 14px;
  }

  .tp-ais-card__thumb{
    flex: 0 0 64px;
    width: 64px;
    height: 64px;
    border-radius: 12px;
  }
}

/* ==============================
   ALGOLIA SEARCH PAGINA LAYOUT
   ============================== */

/* Hoofd layout: sidebar links, resultaten rechts */
#ais-wrapper{
  width: 80%;
  max-width: 1080px;
  margin: 0 auto;
  padding: 40px 0;
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 24px;
}

/* Main */
#ais-main{
  min-width: 0;
}

/* Sidebar */
#ais-facets{
  position: sticky;
  top: 120px;
  align-self: start;
}

/* Mobiel */
@media (max-width: 980px){
  #ais-wrapper{
    width: 90%;
    grid-template-columns: 1fr;
    gap: 18px;
    padding: 24px 0;
  }

  #ais-facets{
    position: static;
  }
}

/* ==============================
   ZOEKVELD
   ============================== */

.algolia-search-box-wrapper{
  display: grid;
  gap: 10px;
  margin-bottom: 18px;
}

#algolia-search-box input[type="search"]{
  width: 100%;
  border: 1px solid #d4d9e6;
  border-radius: 14px;
  padding: 12px;
  font-size: 16px;
  outline: none;
}

#algolia-search-box input[type="search"]:focus{
  border-color: #0B2046;
}

#algolia-powered-by{
  display: none;
}

/* ==============================
   SIDEBAR OPSCHONEN
   ============================== */

/* Post types en users verbergen */
#ais-facets > div:nth-child(1),
#facet-users,
#ais-facets > div:has(#facet-users){
  display: none;
}

/* ==============================
   RESULTATEN LIJST
   ============================== */

/* 1 resultaat per rij */
#algolia-hits .ais-Hits-list,
#algolia-hits .ais-hits,
#algolia-hits .ais-InfiniteHits-list{
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin: 0;
  padding: 0;
  list-style: none;
}

/* Reset items */
#algolia-hits .ais-Hits-item,
#algolia-hits .ais-InfiniteHits-item{
  padding: 0;
  margin: 0;
  border: 0;
  background: transparent;
  display: flex;
}

/* ==============================
   PRODUCT KAART
   ============================== */

.tp-ais-card{
  width: 100%;
  max-width: 760px;
  margin: 0 auto;
  height: 100%;
}

.tp-ais-card__link{
  display: flex;
  gap: 12px;
  padding: 12px;
  border-radius: 16px;
  border: 1px solid #d4d9e6;
  background: #ffffff;
  box-shadow: 0 10px 26px rgba(0,0,0,0.06);
  text-decoration: none;
  color: #0B2046;
  height: 100%;
}

.tp-ais-card__link:hover{
  background: #f7f8fb;
}

/* Thumbnail */
.tp-ais-card__thumb{
  flex: 0 0 76px;
  width: 76px;
  height: 76px;
  border-radius: 14px;
  overflow: hidden;
  background: #f1f3f9;
  display: flex;
  align-items: center;
  justify-content: center;
}

.tp-ais-card__thumb img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Tekst kolom */
.tp-ais-card__body{
  display: flex;
  flex-direction: column;
  flex: 1;
  min-width: 0;
}

/* Titel */
.tp-ais-card__title{
  font-family: "Poppins", system-ui, sans-serif;
  font-size: 15px;
  font-weight: 600;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Categorie */
.tp-ais-card__cat{
  font-size: 12px;
  font-weight: 500;
  color: #7c8496;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Snippet */
.tp-ais-card__snippet{
  font-size: 13px;
  color: #4e5670;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Onderregel */
.tp-ais-card__bottom{
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: auto;
}

/* Prijs */
.tp-ais-card__price{
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
}

.tp-ais-card__price-old{
  font-size: 13px;
  color: #9aa1b3;
  text-decoration: line-through;
}

.tp-ais-card__price-new,
.tp-ais-card__price-single{
  font-size: 14px;
  font-weight: 600;
  color: #0B2046;
}

/* Badge */
.tp-ais-card__badge{
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 999px;
  background: #ffeaf2;
  color: #b0205a;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
}

.tp-ais-card__badge--soldout{
  background: #ffe5e5;
  color: #c62828;
}

/* Highlight */
.tp-ais-card em,
.algolia-search-highlight{
  background-color: #fffbcc;
  border-radius: 3px;
  padding: 0 2px;
  font-style: normal;
}

/* Sidebar rechts, resultaten links */
#ais-wrapper{
  grid-template-columns: 1fr 280px;
}

#ais-main{
  order: 1;
}

#ais-facets{
  order: 2;
}

.algolia-search-box-wrapper .search-icon{
  right: 40px !important;
  left: unset !important;
}

/* Mobiel, alles onder elkaar */
@media (max-width: 980px){
  #ais-wrapper{
    grid-template-columns: 1fr;
  }

  #ais-main,
  #ais-facets{
    order: initial;
  }
}

/* ==============================
   MOBIEL
   ============================== */

@media (max-width: 980px){
  .tp-ais-card__link{
    padding: 10px;
    border-radius: 14px;
  }

  .tp-ais-card__thumb{
    flex: 0 0 64px;
    width: 64px;
    height: 64px;
    border-radius: 12px;
  }
}

.tp-search-header {
  background-color: transparent !important;
}

.tp-search-header h1 {
  text-align: center !important;
}


/* Gravity Forms – Contactformulier styling */

/* Gravity Forms, centered blok, huisstijl knop donkerblauw, geen kleur variabelen */

/* Pagina breedte, centreer het hele formulier blok */
.gform_wrapper{
  max-width: 680px;
  margin: 0 auto;
}

/* Als je Divi of theme extra wrappers gebruikt */
.et_pb_gforms_wrapper .gform_wrapper,
.et_pb_module .gform_wrapper{
  max-width: 680px;
  margin: 0 auto;
}

/* Form card */
.gform_wrapper form{
  background: #ffffff;
  border: 1px solid #d4d9e6;
  border-radius: 18px;
  padding: 22px;
  box-shadow: 0 12px 28px rgba(0,0,0,0.06);
}

/* Spacing */
.gform_wrapper .gform_fields{
  row-gap: 14px;
}

/* Labels, links uitlijnen links, geen center */
.gform_wrapper .gfield_label,
.gform_wrapper legend,
.gform_wrapper .gfield_description{
  text-align: left;
}

.gform_wrapper .gfield_label{
  font-family: "Poppins", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: #0B2046;
  margin-bottom: 6px;
}

/* Inputs */
.gform_wrapper input[type="text"],
.gform_wrapper input[type="email"],
.gform_wrapper input[type="tel"],
.gform_wrapper input[type="url"],
.gform_wrapper input[type="number"],
.gform_wrapper input[type="password"],
.gform_wrapper input[type="search"],
.gform_wrapper select,
.gform_wrapper textarea{
  width: 100%;
  border: 1px solid #d4d9e6;
  border-radius: 14px;
  padding: 12px 12px;
  font-size: 15px;
  color: #0B2046;
  background: #ffffff;
  outline: none;
  transition: border-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

/* Textarea */
.gform_wrapper textarea{
  min-height: 140px;
  resize: vertical;
}

/* Focus state */
.gform_wrapper input[type="text"]:focus,
.gform_wrapper input[type="email"]:focus,
.gform_wrapper input[type="tel"]:focus,
.gform_wrapper input[type="url"]:focus,
.gform_wrapper input[type="number"]:focus,
.gform_wrapper input[type="password"]:focus,
.gform_wrapper input[type="search"]:focus,
.gform_wrapper select:focus,
.gform_wrapper textarea:focus{
  border-color: #0B2046;
  box-shadow: 0 0 0 4px rgba(11,32,70,0.12);
}

/* Placeholder */
.gform_wrapper ::placeholder{
  color: #7c8496;
}

/* Descriptions, errors */
.gform_wrapper .gfield_description{
  font-size: 12px;
  color: #7c8496;
  margin-top: 6px;
}

.gform_wrapper .validation_message,
.gform_wrapper .gfield_validation_message{
  font-size: 12px;
  color: #c62828;
  margin-top: 6px;
}

.gform_wrapper .validation_error{
  border: 1px solid #f2b8b8;
  background: #fff5f5;
  color: #7a1b1b;
  padding: 12px;
  border-radius: 14px;
  margin-bottom: 14px;
}

/* Checkboxes en radios */
.gform_wrapper .gfield_checkbox label,
.gform_wrapper .gfield_radio label{
  font-size: 14px;
  color: #0B2046;
}

.gform_wrapper input[type="checkbox"],
.gform_wrapper input[type="radio"]{
  transform: translateY(1px);
}

/* Footer area met knop */
.gform_wrapper .gform_footer,
.gform_wrapper .gform_page_footer{
  margin-top: 14px;
  padding-top: 6px;
  display: flex;
  justify-content: flex-end;
  gap: 10px;
}

/* Submit knop, volledig rond, donkerblauw */
.gform_wrapper .gform_button,
.gform_wrapper input[type="submit"].gform_button,
.gform_wrapper button.gform_button{
  appearance: none;
  border: 0 !important;
  background: #0B2046 !important;
  color: #ffffff !important;
  border-radius: 999px !important;
  padding: 14px 18px !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  line-height: 1;
  cursor: pointer !important;
  min-height: 46px !important;
  min-width: 160px !important;
  box-shadow: 0 14px 30px rgba(11,32,70,0.22) !important;
  transition: transform 140ms ease, box-shadow 140ms ease, background 140ms ease, opacity 140ms ease !important;
}

/* Hover, focus */
.gform_wrapper .gform_button:hover,
.gform_wrapper input[type="submit"].gform_button:hover,
.gform_wrapper button.gform_button:hover{
  transform: translateY(-1px);
  box-shadow: 0 18px 36px rgba(11,32,70,0.26);
}

.gform_wrapper .gform_button:focus,
.gform_wrapper input[type="submit"].gform_button:focus,
.gform_wrapper button.gform_button:focus{
  outline: none;
  box-shadow: 0 0 0 4px rgba(11,32,70,0.18), 0 14px 30px rgba(11,32,70,0.22);
}

/* Disabled */
.gform_wrapper .gform_button:disabled,
.gform_wrapper input[type="submit"].gform_button:disabled,
.gform_wrapper button.gform_button:disabled{
  opacity: 0.65;
  cursor: not-allowed;
  transform: none;
}

/* Kleine schermen */
@media (max-width: 640px){
  .gform_wrapper{
    max-width: 92%;
  }

  .gform_wrapper form{
    padding: 18px;
    border-radius: 16px;
  }

  .gform_wrapper .gform_footer,
  .gform_wrapper .gform_page_footer{
    justify-content: stretch;
  }

  .gform_wrapper .gform_button,
  .gform_wrapper input[type="submit"].gform_button,
  .gform_wrapper button.gform_button{
    width: 100%;
    min-width: 0;
  }
}


/* Klantenservice kaarten – alleen kaart styling, geen grid */
#klantenservice-kaarten .et_pb_column{
  background: #ffffff;
  border: 1px solid #d4d9e6;
  border-radius: 18px;
  padding: 18px;
  box-shadow: 0 12px 28px rgba(0,0,0,0.06);
  display: flex;
  flex-direction: column;
}

/* Afbeelding */
#klantenservice-kaarten .et_pb_image img{
  width: 100%;
  height: 160px;
  object-fit: cover;
  border-radius: 14px;
  display: block;
  background: #f1f3f9;
}

/* Tekst */
#klantenservice-kaarten p{
  margin: 0;
  font-size: 14px;
  line-height: 1.5;
  color: #4e5670;
}

/* Knop altijd onderaan */
#klantenservice-kaarten .et_pb_button_module_wrapper{
  margin-top: auto;
  padding-top: 8px;
}

/* Alle content boven de link normaal */
#klantenservice-kaarten .et_pb_module{
  flex-shrink: 0;
}

/* Link onderaan vastplakken */
#klantenservice-kaarten .link-btn{
  margin-top: auto;
  align-self: flex-start;
}

/* Knop in huisstijl */
#klantenservice-kaarten .et_pb_button{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  background: #0B2046;
  color: #ffffff;
  border-radius: 999px;
  padding: 12px 16px;
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
  box-shadow: 0 14px 30px rgba(11,32,70,0.22);
  transition: transform 140ms ease, box-shadow 140ms ease, opacity 140ms ease;
}

/* Divi after icoon uit */
#klantenservice-kaarten .et_pb_button:after{
  display: none;
}

#klantenservice-kaarten .et_pb_button:hover{
  transform: translateY(-1px);
  box-shadow: 0 18px 36px rgba(11,32,70,0.26);
}

/* Mobiel compacter */
@media (max-width: 640px){
  #klantenservice-kaarten .et_pb_column{
    padding: 16px;
    border-radius: 16px;
  }

  #klantenservice-kaarten .et_pb_image img{
    height: 150px;
    border-radius: 12px;
  }

  #klantenservice-kaarten .et_pb_button{
    width: 100%;
  }
}

/* Blog kaarten, huisstijl, Divi */

@media (min-width: 981px){
  .et_pb_posts .et_pb_post,
  .et_pb_blog_grid .et_pb_post,
  .et_pb_blog_grid_wrapper .et_pb_post,
  .et_pb_blog_0 .et_pb_post{
    height: 100%;
  }
}

/* Kaart basis */
.et_pb_posts .et_pb_post,
.et_pb_blog_grid .et_pb_post,
.et_pb_blog_grid_wrapper .et_pb_post,
.et_pb_blog_0 .et_pb_post{
  background: #ffffff;
  border: 1px solid #d4d9e6;
  border-radius: 18px;
  box-shadow: 0 10px 26px rgba(0,0,0,0.06);
  overflow: hidden;
  margin: 0;
}

/* Binnenruimte */
.et_pb_posts .et_pb_post .entry-featured-image-url,
.et_pb_blog_grid .et_pb_post .entry-featured-image-url{
  margin: 0;
}

/* Afbeelding */
.et_pb_posts .et_pb_post .entry-featured-image-url img,
.et_pb_blog_grid .et_pb_post .entry-featured-image-url img{
  width: 100%;
  display: block;
  aspect-ratio: 16 / 10;
  object-fit: cover;
}

/* Titel */
.et_pb_posts .et_pb_post h2.entry-title,
.et_pb_blog_grid .et_pb_post h2.entry-title{
  font-family: "Poppins", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: 18px;
  line-height: 1.2;
  font-weight: 650;
  margin: 0 0 8px 0;
  color: #0B2046;
  min-height: 54px !important;
}

/* Titel link */
.et_pb_posts .et_pb_post h2.entry-title a,
.et_pb_blog_grid .et_pb_post h2.entry-title a{
  color: #0B2046;
  text-decoration: none;
}

.et_pb_posts .et_pb_post h2.entry-title a:hover,
.et_pb_blog_grid .et_pb_post h2.entry-title a:hover{
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* Meta */
.et_pb_posts .et_pb_post .post-meta,
.et_pb_blog_grid .et_pb_post .post-meta{
  font-size: 12px;
  color: #7c8496;
  margin: 0 0 10px 0;
}

/* Excerpt */
.et_pb_posts .et_pb_post .post-content p,
.et_pb_blog_grid .et_pb_post .post-content p{
  font-size: 14px;
  line-height: 1.5;
  color: #4e5670;
  margin: 0 0 12px 0;
  min-height: 113px !important;
}

/* Lees meer als link-btn stijl */
.et_pb_posts .et_pb_post a.more-link,
.et_pb_blog_grid .et_pb_post a.more-link{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: #0B2046;
  text-decoration: underline;
  text-underline-offset: 3px;
  font-weight: 600;
  font-size: 14px;
  white-space: nowrap;
}

.et_pb_posts .et_pb_post a.more-link:after,
.et_pb_blog_grid .et_pb_post a.more-link:after{
  content: "→";
  font-size: 16px;
  line-height: 1;
  display: inline-block;
  transform: translateY(1px);
}

.et_pb_posts .et_pb_post a.more-link:hover,
.et_pb_blog_grid .et_pb_post a.more-link:hover{
  opacity: 0.9;
}

/* Hover kaart */
.et_pb_posts .et_pb_post:hover,
.et_pb_blog_grid .et_pb_post:hover{
  background: #f7f8fb;
}

.et_pb_blog_grid .et_pb_salvattore_content[data-columns] .et_pb_post {
  opacity: 1 !important;
}

/* Gelijke hoogte gedrag, knop onderaan */
@media (min-width: 981px){
  .et_pb_posts .et_pb_post,
  .et_pb_blog_grid .et_pb_post{
    display: flex;
    flex-direction: column;
  }

  .et_pb_posts .et_pb_post .post-content,
  .et_pb_blog_grid .et_pb_post .post-content{
    display: flex;
    flex-direction: column;
    flex: 1;
  }

  .et_pb_posts .et_pb_post a.more-link,
  .et_pb_blog_grid .et_pb_post a.more-link{
    margin-top: auto;
  }
}

/* Mobiel iets compacter */
@media (max-width: 980px){
  .et_pb_posts .et_pb_post,
  .et_pb_blog_grid .et_pb_post{
    border-radius: 16px;
  }

  .et_pb_posts .et_pb_post h2.entry-title,
  .et_pb_blog_grid .et_pb_post h2.entry-title, .et_pb_posts .et_pb_post .post-content p, .et_pb_blog_grid .et_pb_post .post-content p{
    min-height: unset !important;
  }

  .et_pb_posts .et_pb_post h2.entry-title,
  .et_pb_blog_grid .et_pb_post h2.entry-title{
    font-size: 17px;
  }
}
@media (max-width: 767px){
.et_pb_posts .et_pb_post h2.entry-title,
.et_pb_blog_grid .et_pb_post h2.entry-title, .et_pb_posts .et_pb_post .post-content p, .et_pb_blog_grid .et_pb_post .post-content p{
  min-height: unset !important;
}
}

/* Optioneel, max breedte per kaart in grid */
.et_pb_blog_grid .et_pb_post{
  max-width: 520px;
  width: 100%;
}


/* ===============================
   Filter Everything – Blog filters
   Zoekveld bovenaan, full width
   Checkboxen eronder
   Font +1px
   =============================== */

/* Wrapper boven content */
.widget_wpc_filters_widget{
  max-width: 1080px;
  margin: 0 auto 24px;
  padding: 0 16px;
}

/* Hoofdcontainer */
.widget_wpc_filters_widget .wpc-filters-main-wrap{
  background: #ffffff;
  border: 1px solid #d4d9e6;
  border-radius: 18px;
  box-shadow: 0 10px 26px rgba(0,0,0,0.06);
  padding: 18px;
}

/* Open/close knop weg */
.widget_wpc_filters_widget .wpc-filters-open-button-container,
.widget_wpc_filters_widget .wpc-widget-close-container,
.widget_wpc_filters_widget .wpc-filters-widget-controls-container{
  display: none;
}

/* Content altijd zichtbaar */
.widget_wpc_filters_widget .wpc-filters-widget-content{
  display: block;
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}

/* Layout: eerst zoekveld, dan filters */
.widget_wpc_filters_widget .wpc-filters-widget-wrapper{
  display: flex;
  flex-direction: column;
  gap: 16px;
}

@media (max-width: 980px){

.widget_wpc_filters_widget .wpc-filters-widget-wrapper{
  gap: 0px;
}
}
/* ===============================
   ZOEKVELD BOVENAAN
   =============================== */

.widget_wpc_filters_widget
.wpc-filters-section.wpc-filter-layout-search-field{
  width: 80%;
  margin: auto;
}

@media (max-width: 980px){
body .wpc-filters-main-wrap li.wpc-term-item {
  margin-bottom: 3px !important;
}

.widget_wpc_filters_widget .wpc-filters-section.wpc-filter-layout-search-field {
  margin-top: 5px !important;
}
}

/* Titel boven zoekveld */
.widget_wpc_filters_widget
.wpc-filter-layout-search-field .wpc-filter-title{
  font-size: 14px;
  font-weight: 600;
  color: #0B2046;
  margin-bottom: 6px;
  text-align: center !important;
}

/* Zoekveld container */
.widget_wpc_filters_widget .wpc-search-field-wrapper{
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid #d4d9e6;
  background: #ffffff;
}

/* Input */
.widget_wpc_filters_widget .wpc-search-field{
  flex: 1;
  border: 0;
  outline: none;
  font-size: 16px; /* +1px */
  color: #0B2046;
  background: transparent;
}

.wpc-counter-length-1 .wpc-term-count {
  width: auto !important;
}



/* Placeholder */
.widget_wpc_filters_widget .wpc-search-field::placeholder{
  color: #7c8496;
}

/* Clear knop */
.widget_wpc_filters_widget .wpc-search-clear-icon{
  display: inline-flex;
  width: 30px;
  height: 30px;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid #d4d9e6;
  color: #0B2046;
  text-decoration: none;
}

/* ===============================
   CHECKBOX FILTERS (CHIPS)
   =============================== */

.widget_wpc_filters_widget
.wpc-filters-section.wpc-filter-taxonomy{
  margin: 0;
}

/* Lijst met chips */
.widget_wpc_filters_widget .wpc-filters-ul-list{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

/* Verberg checkbox input */
.widget_wpc_filters_widget input[type="checkbox"]{
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

/* Chip */
.widget_wpc_filters_widget .wpc-term-item label{
  display: inline-flex;
  align-items: center;
  padding: 11px 15px;
  border-radius: 999px;
  border: 1px solid #d4d9e6;
  background: #ffffff;
  cursor: pointer;
  line-height: 1;
}

/* Tekst */
.widget_wpc_filters_widget .wpc-filter-link{
  font-size: 15px; /* +1px */
  font-weight: 600;
  color: #0B2046;
  text-decoration: none;
}

/* Teller */
.widget_wpc_filters_widget .wpc-term-count{
  font-size: 13px;
  font-weight: 600;
  color: #7c8496;
}

/* Hover */
.widget_wpc_filters_widget .wpc-term-item label:hover{
  background: #f7f8fb;
}

/* Actief */
.widget_wpc_filters_widget input[type="checkbox"]:checked + label{
  background: #0B2046;
  border-color: #0B2046;
}

.widget_wpc_filters_widget
input[type="checkbox"]:checked + label .wpc-filter-link{
  color: #ffffff;
}

.widget_wpc_filters_widget
input[type="checkbox"]:checked + label .wpc-term-count{
  color: rgba(255,255,255,0.8);
}

/* ===============================
   OVERIG
   =============================== */

.widget_wpc_filters_widget .wpc-spinner{
  margin: 10px auto 0;
}

.wpc-filters-widget-content input[type=text] {
  border: unset !important;
}

/* Mobiel */
@media (max-width: 640px){
  .widget_wpc_filters_widget{
    padding: 0 12px;
  }

  .widget_wpc_filters_widget .wpc-filters-main-wrap{
    padding: 14px;
    border-radius: 16px;
  }

  .widget_wpc_filters_widget .wpc-filters-ul-list{
    justify-content: flex-start;
  }
}

/* ===============================
   Divi Blog Grid fix bij AJAX
   Forceer grid, ook na reload
   =============================== */

/* 1. Zet Salvattore uit, dat breekt je grid bij AJAX */
.et_pb_blog_grid_wrapper .et_pb_salvattore_content{
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
  align-items: stretch;
}

/* 2. Artikelen vullen de grid-cel en krijgen gelijke hoogte */
.et_pb_blog_grid_wrapper .et_pb_salvattore_content > article.et_pb_post{
  width: 100%;
  height: 100%;
  margin: 0 !important;
  float: none !important;
}

/* 3. Kaart inhoud netjes laten mee-rekken */
.et_pb_blog_grid_wrapper .et_pb_salvattore_content > article.et_pb_post{
  display: flex;
  flex-direction: column;
}

/* 4. Afbeelding blok consistent */
.et_pb_blog_grid_wrapper .et_pb_post .et_pb_image_container{
  margin-bottom: 14px;
}

.et_pb_blog_grid_wrapper .et_pb_post .et_pb_image_container img{
  display: block;
  width: 100%;
  height: auto;
}

/* 5. Lees meer knop onderaan plakken, voor gelijke rust */
.et_pb_blog_grid_wrapper .et_pb_post .post-content{
  display: flex;
  flex-direction: column;
  height: 100%;
}

.et_pb_blog_grid_wrapper .et_pb_post .post-content .more-link{
  margin-top: auto;
}

/* 6. Tablet */
@media (max-width: 980px){
  .et_pb_blog_grid_wrapper .et_pb_salvattore_content{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
  }
}

/* 7. Mobiel */
@media (max-width: 640px){
  .et_pb_blog_grid_wrapper .et_pb_salvattore_content{
    grid-template-columns: 1fr;
    gap: 14px;
  }
}

/* 8. Extra zekerheid, Divi zet soms nog floats */
.et_pb_blog_grid_wrapper .et_pb_blog_grid .et_pb_post{
  float: none !important;
}

/* ===============================
   Divi blog, grid goed bij load en bij AJAX filters
   Oplossing, alleen ingrijpen als Salvattore kolommen ontbreken
   =============================== */

/* Basis, laat Divi zijn eigen Salvattore layout gebruiken bij eerste load */
.et_pb_blog_grid_wrapper .et_pb_salvattore_content{
  display: block !important;
}

/* Alleen als filters actief zijn, of als de kolommen weg zijn na AJAX */
.wpc-filter-request .et_pb_blog_grid_wrapper .et_pb_salvattore_content,
.et_pb_blog_grid_wrapper .et_pb_salvattore_content[data-columns=""]{
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
  align-items: stretch;
}

/* Artikelen in grid modus */
.wpc-filter-request .et_pb_blog_grid_wrapper .et_pb_salvattore_content > article.et_pb_post,
.et_pb_blog_grid_wrapper .et_pb_salvattore_content[data-columns=""] > article.et_pb_post{
  width: 100%;
  height: 100%;
  margin: 0 !important;
  float: none !important;
  display: flex;
  flex-direction: column;
}

/* Lees meer onderaan, alleen in grid modus */
.wpc-filter-request .et_pb_blog_grid_wrapper .et_pb_post .post-content,
.et_pb_blog_grid_wrapper .et_pb_salvattore_content[data-columns=""] .et_pb_post .post-content{
  display: flex;
  flex-direction: column;
  height: 100%;
}

.wpc-filter-request .et_pb_blog_grid_wrapper .et_pb_post .post-content .more-link,
.et_pb_blog_grid_wrapper .et_pb_salvattore_content[data-columns=""] .et_pb_post .post-content .more-link{
  margin-top: auto;
}

/* Tablet, alleen in grid modus */
@media (max-width: 980px){
  .wpc-filter-request .et_pb_blog_grid_wrapper .et_pb_salvattore_content,
  .et_pb_blog_grid_wrapper .et_pb_salvattore_content[data-columns=""]{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
  }
}

/* Mobiel, alleen in grid modus */
@media (max-width: 640px){
  .wpc-filter-request .et_pb_blog_grid_wrapper .et_pb_salvattore_content,
  .et_pb_blog_grid_wrapper .et_pb_salvattore_content[data-columns=""]{
    grid-template-columns: 1fr;
    gap: 14px;
  }
}

/* Extra zekerheid, alleen in grid modus */
.wpc-filter-request .et_pb_blog_grid_wrapper .et_pb_blog_grid .et_pb_post,
.et_pb_blog_grid_wrapper .et_pb_salvattore_content[data-columns=""] .et_pb_post{
  float: none !important;
}

/* Lees meer link – doorlopende underline + pijltje netjes op lijn */

.et_pb_post .more-link{
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  position: relative !important;
  font-family: Poppins, sans-serif !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: #0B2046 !important;
  text-decoration: none !important;
  padding-bottom: 2px !important;
  width: 150px !important;
}

/* doorlopende underline */
.et_pb_post .more-link::before{
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  height: 1px !important;
  background: currentColor !important;
}

/* pijltje */
.et_pb_post .more-link::after{
  content: "→" !important;
  font-size: 16px !important;
  line-height: 1 !important;
  margin-top: 1px !important;
  margin-left: 60px !important;
}

/* hover */
.et_pb_post .more-link:hover{
  opacity: 0.85 !important;
}

/* Categorie tag als pil op single blogpost */
.single-post .et_pb_title_meta_container a[rel="category tag"]{
  display: inline-flex !important;
  align-items: center !important;
  padding: 6px 14px !important;
  border: 1px solid #d4d9e6 !important;
  background: #ffffff !important;
  border-radius: 999px !important;
  text-decoration: none !important;
  color: #0B2046 !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}

/* Hover subtiel */
.single-post .et_pb_title_meta_container a[rel="category tag"]:hover{
  background: #f7f8fb !important;
  border-color: #c7cede !important;
}

/* Container netjes uitlijnen */
.single-post .et_pb_title_meta_container{
  margin-top: 12px !important;
}

/* Verwijder eventuele standaard tekstopmaak */
.single-post .et_pb_title_meta_container p,
.single-post .et_pb_title_meta_container{
  font-size: 0 !important;
}

/* Herstel font voor de link zelf */
.single-post .et_pb_title_meta_container a{
  font-size: 13px !important;
}

/* Blog button in huisstijl */
.blog-button{
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 12px 22px !important;
  background: #21B3A1 !important;
  color: #ffffff !important;
  border-radius: 999px !important;
  text-decoration: none !important;
  font-family: Poppins, sans-serif !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  line-height: 1 !important;
  border: none !important;
  cursor: pointer !important;
  transition: background-color 0.2s ease, transform 0.15s ease !important;
}

/* Hover */
.blog-button:hover{
  background: #1aa091 !important;
  transform: translateY(-1px) !important;
}

/* Focus */
.blog-button:focus{
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(33,179,161,0.25) !important;
}

/* Blog tip blok */
.blog-tip{
  position: relative !important;
  padding: 22px 24px 22px 82px !important; /* ruimte links voor icoon */
  margin: 28px 0 !important;

  background: #ffffff !important;
  border-radius: 16px !important;
  box-shadow: 0 10px 26px rgba(0,0,0,0.08) !important;

  font-family: Poppins, sans-serif !important;
  color: #0B2046 !important;
}

/* Icoon links, verticaal gecentreerd over het blok */
.blog-tip::before{
  content: "\f0eb";
  font-family: "Font Awesome 6 Free" !important;
  font-weight: 400 !important;
  position: absolute !important;
  left: 24px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  font-size: 33px !important;
  color: #E71A64 !important;
}

/* Titel in tipblok */
.blog-tip h2{
  margin: 0 0 8px 0 !important;
}

/* Paragraaf */
.blog-tip p{
  margin: 0 0 12px 0 !important;
  line-height: 1.5 !important;
}

/* Lijst */
.blog-tip ul{
  margin: 0 !important;
  padding-left: 18px !important;
}

/* Lijstitems */
.blog-tip li{
  margin-bottom: 6px !important;
  line-height: 1.4 !important;
}

/* Blog terug knop */
.blog-back-btn{
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;

  font-family: Poppins, sans-serif !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: #0B2046 !important;

  text-decoration: none !important;
  position: relative !important;
}

.et_pb_text_inner a.blog-back-btn {
  text-decoration: none !important;
}

/* Pijl links */
.blog-back-btn::before{
  content: "\f060"; /* Font Awesome arrow-left */
  font-family: "Font Awesome 6 Free" !important;
  font-weight: 900 !important;
  font-size: 14px !important;
  line-height: 1 !important;
}

/* Doorlopende underline */
.blog-back-btn::after{
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  bottom: -3px !important;
  width: 100% !important;
  height: 1px !important;
  background: currentColor !important;
}

/* Hover subtiel */
.blog-back-btn:hover{
  opacity: 0.8 !important;
}

@media (min-width: 981px) {
    .et_pb_gutters3 .et_pb_column_4_4 .et_pb_blog_grid .column.size-1of3 {
        width: 29.657% !important;
    }
  }



  /* Variations: nieuwe opbouw in single_variation_wrap
     Volgorde:
     1. add to cart
     2. price
     3. availability
     4. description
     Geen blauw vlak meer, rustige card in jouw stijl
  */
  .woocommerce div.product .et_pb_wc_add_to_cart {
    width: 100% !important;
  }

  /* Wrapper als card */
  .woocommerce div.product form.variations_form .single_variation_wrap{
    background: #ffffff !important;
    border: 1px solid #d4d9e6 !important;
    border-radius: 18px !important;
    box-shadow: 0 10px 26px rgba(0,0,0,0.06) !important;
    overflow: hidden !important;
    margin-top: 14px !important;
  }

  /* Maak de wrap een flex kolom zodat we kunnen reorder-en */
  .woocommerce div.product form.variations_form .single_variation_wrap{
    display: flex !important;
    flex-direction: column !important;
  }

  /* Reorder: add-to-cart bovenaan */
  .woocommerce div.product form.variations_form .single_variation_wrap .woocommerce-variation-add-to-cart{
    order: 1 !important;

    background: #ffffff !important;
    border-bottom: 1px solid #e7eaf2 !important;

    padding: 16px 18px !important;

    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    flex-wrap: wrap !important;
  }

  /* Quantity */
  .woocommerce div.product form.variations_form .single_variation_wrap .woocommerce-variation-add-to-cart .quantity input.qty{
    width: 92px !important;
    height: 46px !important;
    border-radius: 999px !important;
    border: 1px solid #d4d9e6 !important;
    text-align: center !important;
  }

  .woocommerce div.product form.variations_form .single_variation_wrap .single_add_to_cart_button.button:hover{
    transform: translateY(-1px) !important;
    box-shadow: 0 18px 36px rgba(11,32,70,0.26) !important;
    filter: brightness(1.02) !important;
  }

  .woocommerce div.product form.variations_form .single_variation_wrap .single_add_to_cart_button.button:active{
    transform: translateY(0) !important;
    box-shadow: 0 12px 24px rgba(11,32,70,0.18) !important;
  }

  /* Reorder: single_variation blok met price, availability, description */
  .woocommerce div.product form.variations_form .single_variation_wrap .woocommerce-variation.single_variation{
    order: 2 !important;
    background: transparent !important;
    color: #0B2046 !important;
    padding: 16px 18px 18px !important;
  }

  /* Forceer volgorde binnen single_variation */
  .woocommerce div.product form.variations_form .single_variation_wrap .woocommerce-variation.single_variation{
    display: flex !important;
    flex-direction: column !important;
  }

  /* Price eerst */
  .woocommerce div.product form.variations_form .single_variation_wrap .woocommerce-variation-price{
    order: 1 !important;
    margin: 0 0 10px 0 !important;
  }

  .woocommerce div.product form.variations_form .single_variation_wrap .woocommerce-variation-price .price{
    color: #0B2046 !important;
    font-weight: 800 !important;
    font-size: 22px !important;
  }

  .woocommerce div.product form.variations_form .single_variation_wrap .woocommerce-variation-price .woocommerce-price-suffix{
    color: rgba(11,32,70,0.75) !important;
    font-weight: 600 !important;
    font-size: 12px !important;
  }

  /* Availability daarna */
  .woocommerce div.product form.variations_form .single_variation_wrap .woocommerce-variation-availability{
    order: 2 !important;
    margin: 0 0 12px 0 !important;
    color: #0B2046 !important;
  }

  .woocommerce div.product form.variations_form .single_variation_wrap .woocommerce-variation-availability .voorraad-text{
    font-weight: 600 !important;
    color: rgba(11,32,70,0.9) !important;
  }

  /* Description als laatste */
  .woocommerce div.product form.variations_form .single_variation_wrap .woocommerce-variation-description{
    order: 3 !important;
    margin: 0 !important;
    padding-top: 12px !important;
    border-top: 1px solid #e7eaf2 !important;
  }

  .woocommerce div.product form.variations_form .single_variation_wrap .woocommerce-variation-description p{
    margin: 0 0 8px 0 !important;
    color: rgba(11,32,70,0.92) !important;
  }

  /* Mobiel: knop full width */
  @media (max-width: 640px){
    .woocommerce div.product form.variations_form .single_variation_wrap .single_add_to_cart_button.button{
      width: 100% !important;
      justify-content: center !important;
    }
  }

  /* Variations label + select in huisstijl */

/* Label (bijv. Samenstelling) */
.woocommerce div.product form.variations_form table.variations th.label{
  font-size: 16px !important;
  font-weight: 700 !important;
  color: #0B2046 !important;
  padding: 12px 16px !important;
  vertical-align: middle !important;
}

/* Value cel */
.woocommerce div.product form.variations_form table.variations td.value{
  padding: 12px 16px !important;
}

/* Select wrapper */
.woocommerce div.product form.variations_form table.variations td.value span{
  display: block !important;
}

/* Select zelf */
.woocommerce div.product form.variations_form table.variations td.value select{
  width: 100% !important;
  height: 46px !important;

  padding: 10px 14px !important;
  border-radius: 14px !important;
  border: 1px solid #d4d9e6 !important;

  background: #ffffff !important;
  color: #0B2046 !important;

  font-size: 14px !important;
  font-weight: 600 !important;

  cursor: pointer !important;
  appearance: none !important;
}

/* Focus state */
.woocommerce div.product form.variations_form table.variations td.value select:focus{
  outline: none !important;
  border-color: rgba(11,32,70,0.45) !important;
  box-shadow: 0 0 0 4px rgba(11,32,70,0.14) !important;
}

/* Reset link */
.woocommerce div.product form.variations_form table.variations td.value a.reset_variations{
  display: none !important;
  margin-top: 8px !important;

  font-size: 13px !important;
  font-weight: 600 !important;
  color: #0B2046 !important;
  text-decoration: underline !important;
  opacity: 0.85 !important;
}

.et_pb_wc_add_to_cart form.cart .variations td.value span:after {
    border: 6px solid transparent;
    border-top-color: #666;
    content: "";
    display: block;
    height: 0;
    margin-top: -7px;
    pointer-events: none;
    position: absolute;
    right: 30px;
    -webkit-transform: translateY(-145%);
    transform: translateY(-145%);
    width: 0;
}

.woocommerce div.product form.variations_form table.variations td.value a.reset_variations:hover{
  opacity: 0.7 !important;
}

/* Mobiel: label boven select */
@media (max-width: 640px){
  .woocommerce div.product form.variations_form table.variations th.label,
  .woocommerce div.product form.variations_form table.variations td.value{
    display: block !important;
    width: 100% !important;
  }

  .woocommerce div.product form.variations_form table.variations th.label{
    padding: 10px 0px 7px 0px !important;

  }

  .woocommerce div.product form.variations_form table.variations td.value{
    padding: 0 !important;
  }
}

@keyframes tp-select-pulse-strong {
  0% {
    box-shadow: 0 0 0 0 rgba(95,190,173,0.55);
    transform: scale(1);
  }
  60% {
    box-shadow: 0 0 0 8px rgba(95,190,173,0);
    transform: scale(1.015);
  }
  100% {
    box-shadow: 0 0 0 0 rgba(95,190,173,0);
    transform: scale(1);
  }
}

.tp-select-attention{
  border-color: #5fbead !important;
  animation: tp-select-pulse-strong 1.4s ease-out infinite;
}




/* Product prijs styling – zelfde lijn als variation prijs */

.et_pb_wc_price .price{
  font-size: 22px !important;
  font-weight: 400 !important;
  line-height: 1.2 !important;
  margin: 0 !important;
}

/* Bedragen zelf */
.et_pb_wc_price .woocommerce-Price-amount{
  font-weight: 400 !important;
}

/* Het streepje tussen van–tot prijs */
.et_pb_wc_price .price > span[aria-hidden="true"]{
  font-weight: 400 !important;
}

/* incl. BTW veel subtieler */
.et_pb_wc_price .woocommerce-price-suffix, .wpsp-slider-section .wpsp-product-section .wpsp-product-price .woocommerce-price-suffix{
  font-size: 12px !important;
  font-weight: 600 !important;
  color: rgba(11,32,70,0.65) !important;
  line-height: 1 !important;
}




  /* Knop full width binnen het blok, naast quantity */
  .single-product form.cart .single_add_to_cart_button,
  .single-product form.cart button.single_add_to_cart_button,
  .single-product form.cart .button.single_add_to_cart_button{
    width: 100% !important;
    padding: 16px 18px !important;
    border-radius: 999px !important;
    color: #ffffff !important;
    border: 0 !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    line-height: 1 !important;

    box-shadow: 0 14px 30px rgba(231,26,100,0.25) !important;
    transition: transform 0.15s ease, box-shadow 0.15s ease, filter 0.15s ease !important;
  }

  /* Hover, active */
  .single-product form.cart .single_add_to_cart_button:hover{
    filter: brightness(1.02) !important;
    box-shadow: 0 18px 36px rgba(231,26,100,0.30) !important;
    transform: translateY(-1px) !important;
  }
  .single-product form.cart .single_add_to_cart_button:active{
    transform: translateY(0) !important;
    box-shadow: 0 12px 24px rgba(231,26,100,0.22) !important;
  }

  /* Focus zichtbaar */
  .single-product form.cart .single_add_to_cart_button:focus{
    outline: none !important;
    box-shadow: 0 0 0 4px rgba(33,179,161,0.25), 0 14px 30px rgba(231,26,100,0.25) !important;
  }

  /* Pijltje mooi mee in de regel, niet los ernaast */
  .single-product form.cart .single_add_to_cart_button:after{
    content: "\2794" !important;
    margin-left: 10px !important;
    font-size: 18px !important;
    line-height: 1 !important;
    display: inline-block !important;
  }

  /* Knop: tekst gecentreerd, pijl rechts */
.single-product form.cart .single_add_to_cart_button{
  position: relative !important;
  justify-content: center !important;
  padding-right: 52px !important; /* ruimte voor pijl */
}

/* Pijl vast rechts in de knop */
.single-product form.cart .single_add_to_cart_button:after{
  content: "\2794" !important;
  position: absolute !important;
  right: 22px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;

  font-size: 18px !important;
  line-height: 1 !important;
}

  /* Mobiel, quantity boven, knop eronder full width */
  @media (max-width: 640px){
    .single-product form.cart{
      flex-wrap: wrap !important;
    }
    .single-product form.cart .quantity{
      width: 100% !important;
    }
    .single-product form.cart .single_add_to_cart_button{
      width: 100% !important;
    }
  }

.woocommerce:where(body:not(.woocommerce-uses-block-theme)) .woocommerce-breadcrumb,.woocommerce:where(body:not(.woocommerce-uses-block-theme)) .woocommerce-breadcrumb a {
      font-size: 13px !important;
      font-family: 'Poppins', Helvetica, Arial, Lucida, sans-serif !important;
      font-weight: 500 !important;
}

/* ===============================
   Woo Product Slider Pro, huisstijl
   Wrapper: #wpsp-slider-section-wrapper
   =============================== */

/* Algemene wrapper spacing */
#wpsp-slider-section-wrapper{
  width: 100% !important;
}

/* Slide kaart */
#wpsp-slider-section-wrapper .wpsp-product .wpspro-product-data{
  background: #ffffff !important;
  border: 1px solid #d4d9e6 !important;
  border-radius: 18px !important;
  box-shadow: 0 10px 26px rgba(0,0,0,0.08) !important;
  overflow: hidden !important;
  height: 100% !important;
  display: flex !important;
  flex-direction: column !important;
}

/* Afbeelding blok */
#wpsp-slider-section-wrapper .wpsp-product a.wpsp-product-image{
  border-bottom: 1px solid #eef1f7 !important;
  overflow: hidden !important;
  border-top-left-radius: 18px !important;
  border-top-right-radius: 18px !important;
}

/* Afbeeldingen */
#wpsp-slider-section-wrapper .wpsp-product-img{
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

/* Title, price, button blok */
#wpsp-slider-section-wrapper .product-details{
  padding: 14px 14px 16px 14px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  flex: 1 !important;
}

/* Titel */
#wpsp-slider-section-wrapper .wpsp-product-title h3{
  margin: 0 !important;
  padding: 0 !important;
  font-size: 18px !important;
  line-height: 1.25 !important;
}

/* Link titel */
#wpsp-slider-section-wrapper .wpsp-product-title a{
  color: #0B2046 !important;
  text-decoration: none !important;
}

/* Prijs */
#wpsp-slider-section-wrapper .wpsp-product-price{
  font-size: 16px !important;
  font-weight: 700 !important;
  color: #0B2046 !important;
}

/* Cart area naar onder plakken */
#wpsp-slider-section-wrapper .wpsp-cart-button{
  margin-top: auto !important;
}

/* Verwijder inline rand en padding van plugin */
#wpsp-slider-section-wrapper .wpsp-cart-button p.add_to_cart_inline{
  border: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Button zelf */
#wpsp-slider-section-wrapper .wpsp-cart-button a.button{
  background-color: #F46275 !important;
  color: white !important;
  border-radius: 999px !important;
  padding: 12px 30px !important;
  text-decoration: none !important;
}

/* Hover en focus zonder kleur wijziging, alleen klein effect */
#wpsp-slider-section-wrapper .wpsp-cart-button a.button:hover{
  filter: brightness(85%) !important;
}

#wpsp-slider-section-wrapper .wpsp-cart-button a.button::after{
  display: none !important;
}
#wpsp-slider-section-wrapper .wpsp-cart-button a.button:focus{
  outline: none !important;
}

/* Nav pijlen */
#wpsp-slider-section-wrapper .wpsp-nav{
  width: 44px !important;
  height: 44px !important;
  border-radius: 999px !important;
  border: 1px solid #d4d9e6 !important;
  background: #ffffff !important;
  box-shadow: 0 10px 26px rgba(0,0,0,0.12) !important;
}

#wpsp-slider-section-wrapper .wpsp-nav i{
  font-size: 18px !important;
  line-height: 1 !important;
}

/* Swiper pijlen, verticaal midden + jouw groen */
#wpsp-slider-section-wrapper .swiper-button-prev,
#wpsp-slider-section-wrapper .swiper-button-next{
  top: 50% !important;
  transform: translateY(-50%) !important;
}

#wpsp-slider-section-wrapper .swiper-button-prev {
left: 5px !important;
}
#wpsp-slider-section-wrapper .swiper-button-next{
right: 5px !important;
}
#wpsp-slider-section-wrapper .wpsp-nav.swiper-button-prev,
#wpsp-slider-section-wrapper .wpsp-nav.swiper-button-next{
  background: #5fbead !important;
  border-color: #5fbead !important;
}

/* Icoon wit zodat het goed leesbaar is */
#wpsp-slider-section-wrapper .wpsp-nav i{
  color: #ffffff !important;
}

/* Dots */
#wpsp-slider-section-wrapper .swiper-pagination{
  bottom: 8px !important;
}

#wpsp-slider-section-wrapper .swiper-pagination-bullet{
  width: 8px !important;
  height: 8px !important;
  border-radius: 999px !important;
  background: #d4d9e6 !important;
  opacity: 1 !important;
}

#wpsp-slider-section-wrapper .swiper-pagination-bullet-active{
  background: #0B2046 !important;
}

/* Gelijke hoogte per slide, jouw wrapper heeft al sp_wpsp_item_same_height maar dit helpt extra */
#wpsp-slider-section-wrapper .swiper-slide{
  height: auto !important;
}

#wpsp-slider-section-wrapper .wpsp-product{
  height: 100% !important;
}

/* Kleine responsive polish */
@media (max-width: 980px){
  #wpsp-slider-section-wrapper .product-details{
    padding: 12px !important;
  }
  #wpsp-slider-section-wrapper .wpsp-product-title h3{
    font-size: 14px !important;
  }
  #wpsp-slider-section-wrapper .wpsp-product-price{
    font-size: 15px !important;
  }
}
.upsell #wpsp-slider-section-wrapper .wpsp-cart-button a.add_to_cart_button  {
  padding: 7px 10px !important;
  font-size: 12px !important;
}

.upsell .wpsp-product-title h3{
  font-size: 15px !important;
}

.upsell .wpsp-product-price .woocommerce-Price-amount{
  font-size: 15px !important;
}

.upsell #wpsp-slider-section-wrapper .product-details {
  gap: 0px !important;
}

.footer-custom .et_pb_blurb{
  overflow: visible !important;
  margin-top: 66px !important;
}

.footer-custom .et_pb_main_blurb_image {
    margin-top: -66px !important;
}

/* ===============================
   Cart cross-sells styling
   Scope: alleen winkelwagen
   =============================== */

body.woocommerce-cart .cart-collaterals{
  display: flex !important;
  flex-direction: column-reverse !important;
}

/* Cross-sells blok */
body.woocommerce-cart .cart-collaterals .cross-sells{
  background: #ffffff !important;
  border: 1px solid #d4d9e6 !important;
  border-radius: 18px !important;
  box-shadow: 0 10px 26px rgba(0,0,0,0.06) !important;
  padding: 18px !important;
  overflow: hidden !important;
  margin-top: 10px !important;
}

.woocommerce .cart-collaterals .cross-sells,
.woocommerce-page .cart-collaterals .cross-sells{
  width: 100% !important;
}

body.woocommerce-cart .cart-collaterals .cross-sells > h2{
  margin: 0 0 14px 0 !important;
  font-size: 18px !important;
  line-height: 1.25 !important;
}

/* Product lijst */
body.woocommerce-cart .cart-collaterals .cross-sells ul.products{
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
  display: grid !important;
  gap: 14px !important;
}

@media (max-width: 640px){
  body.woocommerce-cart .cart-collaterals .cross-sells ul.products{
    grid-template-columns: 1fr !important;
  }
}

/* Woo floats uit */
body.woocommerce-cart .cart-collaterals .cross-sells ul.products li.product{
  float: none !important;
  width: auto !important;
  margin: 0 !important;
}

/* Kaart */
body.woocommerce-cart .cart-collaterals .cross-sells ul.products li.product{
  background: #ffffff !important;
  border: 1px solid #d4d9e6 !important;
  border-radius: 16px !important;
  box-shadow: 0 10px 26px rgba(0,0,0,0.06) !important;
  overflow: hidden !important;
  transition: transform .15s ease, box-shadow .15s ease !important;
  display: flex !important;
  flex-direction: row !important;
}

/* Link wordt horizontale kaart */
body.woocommerce-cart .cart-collaterals .cross-sells ul.products li.product a.woocommerce-LoopProduct-link{
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 14px !important;
  padding: 12px !important;
  text-decoration: none !important;
}

/* Afbeelding links, vaste breedte */
body.woocommerce-cart .cart-collaterals .cross-sells ul.products li.product .et_shop_image{
  flex: 0 0 92px !important;
  width: 92px !important;
  max-width: 92px !important;
  display: block !important;
  position: relative !important;
  background: #f1f3f9 !important;
  border-radius: 12px !important;
  overflow: hidden !important;
}

body.woocommerce-cart .cart-collaterals .cross-sells ul.products li.product .et_shop_image img{
  width: 100% !important;
  height: 92px !important;
  object-fit: cover !important;
  display: block !important;
}

/* Content rechts, geen oude padding */
body.woocommerce-cart .cart-collaterals .cross-sells ul.products li.product .woocommerce-loop-product__title{
  padding: 0 !important;
  margin: 0 0 6px 0 !important;
  font-size: 15px !important;
  line-height: 1.25 !important;
}

body.woocommerce-cart .cart-collaterals .cross-sells ul.products li.product .price{
  padding: 0 !important;
  margin: 0 !important;
  font-size: 15px !important;
  font-weight: 600 !important;
}

/* Zorg dat titel en prijs links uitlijnen */
body.woocommerce-cart .cart-collaterals .cross-sells ul.products li.product a.woocommerce-LoopProduct-link{
  text-align: left !important;
}

/* Hover */
body.woocommerce-cart .cart-collaterals .cross-sells ul.products li.product:hover{
  transform: translateY(-2px) !important;
  box-shadow: 0 14px 34px rgba(0,0,0,0.10) !important;
}

body.woocommerce-cart .cart-collaterals .cross-sells ul.products li.product a.woocommerce-LoopProduct-link:focus{
  outline: 2px solid rgba(11,32,70,0.25) !important;
  outline-offset: 2px !important;
}

body.woocommerce-cart .cart-collaterals .cross-sells ul.products::before {
  display: none !important;
}

body.woocommerce-cart .cart-collaterals .cross-sells ul.products .add_to_cart_button{
    height: 32px;
    border-radius: 30px;
    margin: auto !important;
    padding: 5px 15px !important;
}

body.woocommerce-cart .cart-collaterals .cross-sells ul.products .add_to_cart_button::after {
  display: none !important;
}

/* Cart totals laat je zoals je had */
body.woocommerce-cart .cart-collaterals .cart_totals{
  background: #ffffff !important;
  border: 1px solid #d4d9e6 !important;
  border-radius: 18px !important;
  box-shadow: 0 10px 26px rgba(0,0,0,0.06) !important;
  padding: 18px !important;
}

body.woocommerce-cart .cart-collaterals .cart_totals > h2{
  margin: 0 0 14px 0 !important;
  font-size: 18px !important;
  line-height: 1.25 !important;
}

/* Cross-sell kaart: afbeelding links, tekstkolom rechts */
body.woocommerce-cart .cart-collaterals .cross-sells ul.products li.product a.woocommerce-LoopProduct-link{
  display: grid !important;
  grid-template-columns: 92px 1fr !important;
  grid-template-rows: auto auto !important;
  column-gap: 14px !important;
  row-gap: 4px !important;
  align-items: center !important;
}

/* Afbeelding links, over 2 regels */
body.woocommerce-cart .cart-collaterals .cross-sells ul.products li.product a.woocommerce-LoopProduct-link .et_shop_image{
  grid-column: 1 !important;
  grid-row: 1 / span 2 !important;
  width: 92px !important;
}

/* Titel rechtsboven */
body.woocommerce-cart .cart-collaterals .cross-sells ul.products li.product a.woocommerce-LoopProduct-link .woocommerce-loop-product__title{
  grid-column: 2 !important;
  grid-row: 1 !important;
  margin: 0 !important;
}

/* Prijs rechtsonder, onder titel */
body.woocommerce-cart .cart-collaterals .cross-sells ul.products li.product a.woocommerce-LoopProduct-link .price{
  grid-column: 2 !important;
  grid-row: 2 !important;
  margin: 0 !important;
}

/* Cross-sell kaart strak uitlijnen */
body.woocommerce-cart .cart-collaterals .cross-sells ul.products li.product{
  display: grid !important;
  grid-template-columns: 92px 1fr auto !important;
  align-items: center !important;
}

/* Link vult het middengebied */
body.woocommerce-cart .cart-collaterals .cross-sells ul.products li.product a.woocommerce-LoopProduct-link{
  display: grid !important;
  grid-template-columns: 92px 1fr !important;
  grid-template-rows: auto auto !important;
  column-gap: 14px !important;
  row-gap: 6px !important;
  align-items: center !important;
  grid-column: 1 / span 2 !important;
}

/* Afbeelding links, altijd gecentreerd */
body.woocommerce-cart .cart-collaterals .cross-sells ul.products li.product .et_shop_image{
  align-self: center !important;
}

/* Titel altijd boven */
body.woocommerce-cart .cart-collaterals .cross-sells ul.products li.product .woocommerce-loop-product__title{
  grid-column: 2 !important;
  grid-row: 1 !important;
  min-height: 2.5em;
}

/* Prijs altijd onder titel */
body.woocommerce-cart .cart-collaterals .cross-sells ul.products li.product .price{
  grid-column: 2 !important;
  grid-row: 2 !important;
}

/* Knop altijd rechts gecentreerd */
body.woocommerce-cart .cart-collaterals .cross-sells ul.products li.product .add_to_cart_button{
  grid-column: 3 !important;
  align-self: center !important;
  margin: 0 14px 0 0 !important;
}

/* Zorg dat kaarten gelijke hoogte houden */
body.woocommerce-cart .cart-collaterals .cross-sells ul.products li.product{
  min-height: 120px;
}

a.restore-item {
  text-decoration: underline !important;
}

/* Cart: thumbnail terug op mobiel en netjes in de lijst */
@media (max-width: 768px){

  /* Thumbnail niet verbergen */
  body.woocommerce-cart table.shop_table_responsive tr td.product-thumbnail,
  body.woocommerce-cart table.shop_table_responsive tr td.product-thumbnail::before{
    display: block !important;
  }

  body.woocommerce-cart table.shop_table_responsive tr td.product-thumbnail{
    text-align: left !important;
    padding: 10px 0 6px 0 !important;
  }

  body.woocommerce-cart table.shop_table_responsive tr td.product-thumbnail a{
    display: inline-flex !important;
    align-items: center !important;
    gap: 10px !important;
    text-decoration: none !important;
  }

  body.woocommerce-cart table.shop_table_responsive tr td.product-thumbnail img{
    width: 58px !important;
    height: 58px !important;
    object-fit: cover !important;
    border-radius: 12px !important;
    background: #f1f3f9 !important;
  }

  /* Label “Thumbnail” weg, Woo zet die via ::before */
  body.woocommerce-cart table.shop_table_responsive tr td.product-thumbnail::before{
    content: "" !important;
  }
}

@media (max-width: 768px){

  body.woocommerce-cart .container, body.woocommerce-checkout .et-et_pb_row {
    width: 90% !important;
  }
}

@media (max-width: 768px){

  /* Basis: maak elke cart item een nette card */
  body.woocommerce-cart table.shop_table_responsive tr.cart_item{
    display: grid !important;
    grid-template-columns: 72px 1fr 32px !important;
    grid-template-rows: auto auto auto auto!important;
    gap: 10px 12px !important;

    padding: 14px !important;
    border: 1px solid #d4d9e6 !important;
    border-radius: 18px !important;
    box-shadow: 0 10px 26px rgba(0,0,0,0.06) !important;
    background: #ffffff !important;

    margin: 0 0 14px 0 !important;
  }

  /* Reset: geen Woo responsive labels, we zetten ze zelf terug waar nodig */
  body.woocommerce-cart table.shop_table_responsive tr.cart_item td::before{
    display: none !important;
  }

  body.woocommerce-cart table.shop_table_responsive tr.cart_item td{
    display: block !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
  }

  /* Thumbnail */
  body.woocommerce-cart table.shop_table_responsive tr.cart_item td.product-thumbnail{
    grid-column: 1 !important;
    grid-row: 1 / span 3 !important;
    align-self: start !important;
  }

  body.woocommerce-cart table.shop_table_responsive tr.cart_item td.product-thumbnail img{
    width: 72px !important;
    height: 72px !important;
    object-fit: cover !important;
    border-radius: 14px !important;
    display: block !important;
  }

  /* Remove knop rechtsboven, compacter */
  body.woocommerce-cart table.shop_table_responsive tr.cart_item td.product-remove{
    grid-column: 3 !important;
    grid-row: 1 !important;
    justify-self: end !important;
    align-self: start !important;
    width: 32px !important;
  }

  body.woocommerce-cart table.shop_table_responsive tr.cart_item td.product-remove a.remove{
    display: inline-flex !important;
    width: 28px !important;
    height: 28px !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 999px !important;
    line-height: 1 !important;
    font-size: 18px !important;
  }

  /* Naam */
  body.woocommerce-cart table.shop_table_responsive tr.cart_item td.product-name{
    grid-column: 2 !important;
    grid-row: 1 !important;
    align-self: start !important;
  }

  body.woocommerce-cart table.shop_table_responsive tr.cart_item td.product-name a{
    font-weight: 700 !important;
    line-height: 1.25 !important;
    text-decoration: none !important;
    display: inline-block !important;
  }

  /* Prijs kleiner onder naam */
  body.woocommerce-cart table.shop_table_responsive tr.cart_item td.product-price{
    grid-column: 2 !important;
    grid-row: 2 !important;
    align-self: center !important;
    opacity: 0.85 !important;
    font-weight: 600 !important;
  }

  /* Aantal links onder prijs, met label */
  body.woocommerce-cart table.shop_table_responsive tr.cart_item td.product-quantity{
    grid-column: 2 !important;
    grid-row: 3 !important;
    align-self: start !important;
  }

  body.woocommerce-cart table.shop_table_responsive tr.cart_item td.product-quantity::before{
    display: block !important;
    content: "Aantal" !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    opacity: 0.6 !important;
    margin-bottom: 4px !important;
  }

  body.woocommerce-cart table.shop_table_responsive tr.cart_item td.product-quantity .quantity{
    display: inline-flex !important;
    align-items: center !important;
    gap: 10px !important;
  }

  body.woocommerce-cart table.shop_table_responsive tr.cart_item td.product-quantity input.qty{
    width: 50px !important;
    min-width: 50px !important;
    height: 37px !important;
    border-radius: 999px !important;
    text-align: center !important;
}

  /* Subtotaal rechts onder, met label */
  body.woocommerce-cart table.shop_table_responsive tr.cart_item td.product-subtotal{
    grid-column: 2 !important;
    grid-row: 4 !important;
    align-self: start !important;
    text-align: right !important;
    white-space: nowrap !important;
    font-weight: 700 !important;
    font-size: 18px !important;
    line-height: 1.1 !important;
  }

  body.woocommerce-cart table.shop_table_responsive tr.cart_item td.product-subtotal::before{
    display: block !important;
    content: "Subtotaal" !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    opacity: 0.6 !important;
    margin-bottom: 6px !important;
    text-align: right !important;
  }

  body.woocommerce-cart table.shop_table_responsive tr.cart_item td.product-subtotal{
    font-weight: 700 !important;
    font-size: 18px !important;
    line-height: 1.1 !important;
  }

  /* Zorg dat er niet stiekem een 2e subtotal ergens zichtbaar blijft */
  body.woocommerce-cart table.shop_table_responsive tr.cart_item .product-subtotal *{
    float: none !important;
  }

  /* Extra rommel die sommige themes toevoegen verbergen als het dubbel is */
  body.woocommerce-cart table.shop_table_responsive tr.cart_item td.product-subtotal .includes_tax,
  body.woocommerce-cart table.shop_table_responsive tr.cart_item td.product-subtotal small{
    display: none !important;
  }
  .woocommerce-page table.cart td.actions .coupon .button {
    width: 100% !important;
  }
}

.woocommerce table.shop_table_responsive tr:nth-child(2n) td, .woocommerce-page table.shop_table_responsive tr:nth-child(2n) td {
  background-color: unset !important;
}

.thema-lijst-mobile .et_pb_button:not(.blue-cta){
  background-color: transparent !important;
}

.thema-lijst-mobile .et_pb_button {
  width: 100% !important;
}
.thema-lijst-mobile .et_pb_button::after {
  right: 20px !important;
}

.et-db .faq-sectie .et_pb_toggle .et_pb_toggle_title:before {
  display: none !important;
}

/* Breadcrumb styling – nieuwe structuur */

.woo-breadcrumb .et_pb_text_inner{
  margin: 10px 0 18px 0 !important;
  font-size: 13px !important;
  line-height: 1.4 !important;
  color: rgba(11,32,70,0.55) !important;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

/* Links */
.woo-breadcrumb .et_pb_text_inner a{
  color: rgba(11,32,70,0.75) !important;
  text-decoration: none !important;
  font-weight: 500 !important;
  transition: color 120ms ease, opacity 120ms ease !important;
}

.woo-breadcrumb .et_pb_text_inner a:hover{
  color: #0B2046 !important;
  opacity: 0.85 !important;
  text-decoration: underline !important;
}

/* Scheidingsteken > subtieler maken */
.woo-breadcrumb .et_pb_text_inner{
  letter-spacing: 0.2px;
}

/* Huidige pagina */
.woo-breadcrumb .et_pb_text_inner .breadcrumb_last{
  color: #0B2046 !important;
  font-weight: 700 !important;
}

/* Mobiel iets compacter */
@media (max-width: 640px){
  .woo-breadcrumb .et_pb_text_inner{
    font-size: 12px !important;
  }
}

/* Maak > pijltjes lichter */
.woo-breadcrumb .et_pb_text_inner{
  color: rgba(11,32,70,0.55) !important;
}

/* Alleen het > teken lichter */
.woo-breadcrumb .et_pb_text_inner span > span + span::before{
  color: rgba(11,32,70,0.35);
}


#wpsp-slider-section-wrapper.wpsp-slider-section .sale_text, .woocommerce span.onsale, .woocommerce-page span.onsale {
  color: #ffffff !important;
    font-size: 17px !important;
    line-height: 17px !important;
    text-transform: none !important;
    letter-spacing: 1px !important;
    text-align: center !important;
    background-color: #c02020 !important;
    position: absolute !important;
   -webkit-transform:rotate(0deg) !important;
   -moz-transform: rotate(0deg) !important;
   -ms-transform: rotate(0deg) !important;
   -o-transform: rotate(0deg) !important;
   transform:rotate(0deg) !important;
   top: 10px !important;
   left: 10px !important;
   padding: 10px 20px !important;
   width: unset !important;
   z-index: 2;
   border-radius: 106px !important;
   font-weight: bold !important;
}
