/* ==========================================================================
   spreen-plugins.css — Versie 2.2.6 
   Auteur: Rik Spreen
   Laatste update: 10 oktober 2025
   ========================================================================== */
   
 /* === Spreen lightbox === */
 
 /* Gallery en video */
 .spreen-lightbox {
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0.85);
	z-index: 9999;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 2rem;
}

/* Alleen video */

.spreen-video-lightbox-inner {
	position: relative;
	display: inline-block;
	border: 2px solid #b2788e;
	border-radius: .5rem;
	background: #000;
}

.spreen-lightbox-video {
	width: 80vw;
	height: 45vw;
	max-width: 960px;
	max-height: 540px;
	border-bottom-left-radius: .3rem;
	border-bottom-right-radius: .3rem;
}

.positie-sluitknop {
	position: absolute;
	top: -1rem;
	right: -1rem;
	z-index: 10000;
}

.spreen-video-titel {
	margin-bottom: 0;
	text-align: center;
	background: #8f4e66;
	width: 100%;
	position: relative;
	padding: 0 1rem .2rem;
	z-index: 1000;
	border-top-left-radius: .25rem;
	font-size: clamp(0.9rem, 2vw + 0.5rem, 1.2rem);
	color: #f1d1e0;
	border-bottom: 2px solid #b2788e;
	text-shadow: 0.06rem 0.06rem 0 rgba(0, 0, 0, 0.7);
}

.wp-block-spreen-video {
	max-width: 350px !important;
}

/* Alleen gallery */



.spreen-lightbox-inner.gallery-inner {
	border: none;
}
.spreen-gallery-wrapper {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}


@media (max-width: 768px) {
	.spreen-gallery-wrapper {
		display: block;
		width: 100%;
		max-width: none;
		margin: 0 auto;
		box-sizing: border-box;
	}
}


.spreen-thumbs {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0.3rem;
}

@media (max-width: 768px) {
	.spreen-thumbs {
		grid-template-columns: repeat(3, 1fr);
		gap: 0.2rem;
		margin: 0.3rem 0 1.5rem;
	}
}


.spreen-lightbox-inner {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1rem;
	background: transparent;
	visibility: hidden;
	opacity: 0;
	transition: opacity 0.3s ease, visibility 0s linear 0.3s;
}

.spreen-lightbox-inner.visible {
	visibility: visible;
	opacity: 1;
	transition-delay: 0s;
}


.spreen-lightbox-img {
	width: auto;
	height: auto;
	max-width: 100vw;
	max-height: 100vh;
	display: block;
	margin: 0 auto;
}

.spreen-lightbox-close {
	top: 0;
	right: 0;
}

.spreen-lightbox-close,
.spreen-lightbox-prev,
.spreen-lightbox-next {
	position: absolute;
}

.spreen-lightbox-prev,
.spreen-lightbox-next {
	top: 50%;
	transform: translateY(-50%);
	box-sizing: content-box;
	cursor: pointer;
}

.spreen-lightbox-prev {
	padding: clamp(4rem, 10vw, 15rem) clamp(2rem, 10vw, 20rem) clamp(4rem, 10vw, 15rem) 2rem;
	left: 1.5rem;
}

.spreen-lightbox-next {
	padding: clamp(4rem, 10vw, 15rem) 2rem clamp(4rem, 10vw, 15rem) clamp(2rem, 10vw, 20rem);
	right: 1.5rem;
}

.button-lightbox-next::before,
.button-lightbox-prev::before {
	font: var(--fa-font-solid);
	font-size: 1.5rem;
	width: 1.5rem;
	height: 1.5rem;
	border: 3px solid #b2788e;
	border-radius: 50%;
	color: #f1d1e0;
	background-color: #a31351;
	display: block;
	cursor: pointer;
	transition: 1s;
	margin: 0 0 .1rem;
}

.button-lightbox-next::before {
	content: "\f0da";
	
}

.button-lightbox-prev::before {
	content: "\f0d9";
}

.spreen-lightbox-prev:hover::before,
.spreen-lightbox-next:hover::before {
	color: #dd7ca1 !important;
	border-color: #f1d1e0 !important;
	transition: 1s;
}


@media (max-width: 768px) {
	.spreen-lightbox-prev {
		top: 50%;
		transform: translateY(-50%);
		left: 0;
	}

	.spreen-lightbox-next {
		top: 50%;
		transform: translateY(-50%);
		right: 0;
	}

	.button-lightbox-prev::before,
	.button-lightbox-next::before {
		font-size: 1.1rem;
		width: 1.1rem;
		height: 1.1rem;
		border-width: 2px;
		margin: 0;
	}
}
 
 
 /* === Servies database === */
 
 
 @media (max-width: 768px) {
    .sidebar.inhoud .servies-serie-info {
        float: none;
        clear: none;
        margin: 0 auto;
        display: block;
        position: relative;
        top: 0;
    }
}
 
.toggle-wrapper {
    display: flex;
    flex-direction: column;
}

.toggle-content {
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    transition: max-height 0.6s ease, opacity 0.4s ease;
    margin-bottom: 1rem;
}

.toggle-button {
    padding: 0;
    cursor: pointer;
    display: inline-block;
    text-align: left;
    width: fit-content;
    font-size: larger;
    transition: color 0.3s ease;
}

.toggle-button i {
    margin-right: .5rem;
    transition: color 0.3s ease;
}

.toggle-button:hover {
    color: #dd7ca1 !important;
}

.toggle-button:hover i {
    color: #dd7ca1;
}

.galerij-lijst,
.backstamp-lijst,
.sfeerbeeld-lijst {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    padding: 0;
    list-style: none;
    margin-top: 10px;
}

.galerij-lijst li,
.backstamp-lijst li,
.sfeerbeeld-lijst li {
    flex: 1 1 100%;
    max-width: 100%;
    box-sizing: border-box;
}

.image-wrapper {
    position: relative;
    overflow: hidden;
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.25);
    border: .15rem solid #b2788e;
    border-radius: .5rem;
}

.image-wrapper img {
    display: block;
    width: 100%;
    height: auto;
}

.image-wrapper .caption {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: .15rem .5rem;
    background: rgb(116 48 71 / 50%);
    color: #e6c4d1;
    text-align: center;
    box-sizing: border-box;
}

@media (min-width: 600px) {
    .galerij-lijst li,
    .backstamp-lijst li,
    .sfeerbeeld-lijst li {
        flex: 1 1 calc(50% - 16px);
        max-width: calc(50% - 16px);
    }
}

@media (min-width: 900px) {
    .galerij-lijst li,
    .backstamp-lijst li,
    .sfeerbeeld-lijst li {
        flex: 1 1 calc(33.333% - 16px);
        max-width: calc(33.333% - 16px);
    }		
}

@media (max-width: 768px) {
  .servies-fallback-widget {
    display: none;
  }
}

.toelichting {
    margin-top: 1rem;
}


.servies-serie-info dl {
  display: grid !important;
  grid-template-columns: max-content 1fr;
  gap: 0.5em;
  font-size: larger;
}

.servies-serie-info dt,
.servies-serie-info dd {
  margin: 0;
}

.meta-lijst{
	font-size: large !important;
}
 
 
 /* === Begin Spreen Ajax zoeken === */

/* === Spreen Ajax zoeken === */

body.zoeken-open {
  position: fixed;
  width: 100%;
  top: 0;
  left: 0;
  overflow: hidden;
  touch-action: none;
}

input, textarea {
  touch-action: manipulation;
}


#spreen-overlay {
    position: fixed;
    top: .3rem;
    left: .4rem;
    right: .4rem;
    height: 100dvh;
    background: rgba(0, 0, 0, 0.65);
    z-index: 1100;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s;
    display: flex;
    /*align-items: flex-start;*/
	align-items: center;
    justify-content: center;
    /*padding-top: 8vh;*/
    overflow: hidden;
}

#spreen-overlay.visible {
  opacity: 1;
  visibility: visible;
}

#spreen-resultaten {
  width: 95%;
  max-width: 960px;
  max-height: 70vh;
  box-sizing: border-box;
  z-index: 1200;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s;
  background: url(../afbeeldingen/achtergronden/roos3.jpg) top left repeat;
  padding: 0;
  border: 2px solid #b2788e;
  border-radius: .5rem;
  overflow: hidden;
}

#spreen-resultaten.visible {
  opacity: 1;
  visibility: visible;
}

@media (max-height: 700px) {
  #spreen-overlay {

  }
}

.popup-header-zoeken {
  display: flex;
  line-height: 1;
  gap: .5rem;
  position: sticky;
  z-index: 120;
  top: 0;
  padding: .3rem 0 .2rem .5rem;
  border-bottom: 3px solid #b2788e;
  background: url(../afbeeldingen/achtergronden/achtergrond3.jpg) top left repeat;
  box-shadow: 0px 1px 5px 2px #826a6b;
  align-items: center;
}

.popup-header-zoeken h1,
.popup-header-zoeken .fa-magnifying-glass {
  color: #e6c4d1;
}

.popup-header-zoeken h1 {
  padding: .2rem 0;
  margin: 0;
}

.popup-header-zoeken .fa-magnifying-glass {
  font-size: larger;
}

.sub-header-zoeken h3 {
  font-size: large;
  padding: .3rem;
  background: #e6c4d1;
  border-bottom: 2px solid #b2788e;
  box-shadow: 0px 1px 5px 2px #826a6b;
  z-index: 110;
  top: 0;
  margin: 0;
  border-top: none;
  position: sticky;
  display: flex;
  justify-content: center;
  gap: .3rem;
}

.popup-header-zoeken::after {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: 1rem;
  height: 100%;
  background: url(../afbeeldingen/achtergronden/achtergrond3.jpg) top left repeat;
  z-index: 121;
}

.popup-header-zoeken h3 {
  color: #e6c4d1;
  line-height: 1rem;
}

#spreen-close {
  z-index: 200;
  position: absolute;
  right: 0;
}

/* ✅ Scrollbare inhoud onder sticky header */
.popup-content-wrapper {
  max-height: calc(70vh - 3rem);
  overflow-y: auto;
  padding: 2rem 1rem;
  margin: -1rem 0;
  background-color: #f8f8f845;
  scrollbar-width: thin;
  scrollbar-color: #a35d75 #cfb3bc;
}

/* WebKit (Chrome, Safari, Edge) */
.popup-content-wrapper::-webkit-scrollbar {
  width: 6px;
}

.popup-content-wrapper::-webkit-scrollbar-track {
  background: #cfb3bc;
}

.popup-content-wrapper::-webkit-scrollbar-thumb {
  background-color: #a35d75;
  border-radius: 3px;
}


.zoekresultaten-header {
  border-bottom: 2px solid #b2788e;
  margin: -1rem -2rem 1rem;
  padding: 0 2rem 1rem;
}

/* Zoekresultaten grid */
.zoekresultaten {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  padding: 10px;
}

/* De tegels */

.zoekresultaat-serie,
.zoekresultaat{
	display: flex;
	border: 1px solid #a35d75;
    padding: 1rem;
    border-radius: .5rem;
    margin: 0;
    box-shadow: 0 2px 6px rgba(0, 0, 0, .35);
    width: 100%;
    box-sizing: border-box;
    justify-content: flex-start;
}


.zoekresultaat-serie{  
	flex-direction: column;

}

.zoekresultaat{	
    flex-direction: row;
    gap: 1rem;   
}

.zoekresultaat-serie-body {
  border-radius: .5rem;
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 12px;
}

.zoekresultaat-thumb {
  width: 200px;
  height: auto;
  object-fit: cover;
  flex-shrink: 0;
  border: 2px solid #a35d75;
  border-radius: .5rem;
}

.suggestie-container{
	margin-top: 1rem;
}

.suggestie-extra{
	padding: 2rem 0;
}




.productlink-zoeken{
	margin-top: 3rem;
}

.item-meta {
  flex: 1;
}

.wiki-excerpt {
	line-height: 1.1;
}

/* ✅ Toggle en extra wiki-items */

.extra-wiki-item {
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transition: max-height 0.5s ease, opacity 0.5s ease;
}

.extra-wiki-item.expanded {
  max-height: 1000px; /* ruim genoeg voor content */
  opacity: 1;
}

.toggle-button-wiki {
  background: none;
  border: none;
  font-size: larger;
  cursor: pointer;
  color: inherit;
  display: inline-flex;
  align-items: center;
}

.toggle-button-wiki i {
  margin-right: 6px;
}

.wiki-toggle-wrapper {
    margin: 1rem 0 3rem;
    display: flex;
    justify-content: center;
}


/* ✅ Responsive */
@media (max-width: 768px) {
  .zoekresultaten {
    grid-template-columns: 1fr;
    padding: 0;
  }
  
  .zoekresultaat{
	 flex-direction: column;
	 padding: 1rem 1rem 0;
	 text-align: center;
	 margin: 0;
  }

  .popup-content-wrapper {
    padding: 2rem .5rem;
  }

  .zoekresultaat-serie-body {
    flex-direction: column;
    align-items: flex-start;
  }

  .zoekresultaat-thumb {
    width: 100%;
    max-width: 400px;
    height: auto;
    margin-bottom: 1rem;
  }

  .item-meta {
    width: 100%;
  }
  
  .productlink-zoeken{
	margin-top: 0;
	justify-content: center;
}
  
}

/* ✅ Overige */
span.tags,
span.cats,
span.type-label {
  display: none;
}

a.suggestie-link,
a.wiki-link {
	margin: 1rem 0 !important;
	font-size: larger !important;
}

input#spreen-zoekveld {
  width: 101%;
  margin: -2rem -2rem 0 -.2rem;
  border: none;
  height: 2.65rem;
  padding: 2.7rem 1.8rem;
  background: #e6c4d1;
  font-weight: 700;
}





  

/* === Begin Snelle Productweergave Popup === */

/* Snelle weergave knop styling */
button.button.spw-view-product-button {
    display: flex;
    font-size: larger;
    padding: .3rem;
	color: #a31351 !important;
    background: none;
    align-items: flex-end;
}

button.button.spw-view-product-button:hover,
button.button.spw-add-to-cart-button {
	background:none;
}

/* Container voor winkelwagenactie */
.in-winkelwagen-sw {
	position: relative;
	display: flex;
	justify-content: center;
}

/* Toevoegen aan winkelwagen-knop */
button.button.spw-add-to-cart-button {
	justify-content: center;
	margin: 0 !important;
	font-size: larger;
	background: none;
}

/* Centraal geladen spinner */
.spw-loading-spinner {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
}

/* Fout- en bevestigingsberichten */
.spw-error-message,
.spw-confirmation-message,
.spw-custom-outofstock-message {
	background: #d4b5bf;
	margin-top: -1rem;
	position: relative;
	min-height: 5rem;
}

/* Uitverkocht melding aangepast */
.spw-custom-outofstock-message {
	margin-top: 0 !important;
	min-height: unset !important;
}

/* Container voor actieblokken */
.sw-actie-blok {
	min-height: 4rem;
}

/* Algemene notificaties */
.sw-mededelingen {
	margin-top: 10px;
	color: #740027;
	border: 0.1rem solid #b2788e;
	border-radius: 0.5rem;
	padding: 0.5rem;
	background: #d4b5bf;
}

/* Laadanimatie (spinner) */
@keyframes spin {
	0% {
		transform: rotate(0deg);
	}

	100% {
		transform: rotate(360deg);
	}
}


/* Inputveld styling voor hoeveelheid */
.spw-quantity-input {
	appearance: none;
	line-height: 1.2;
	border: 1px solid #a31351;
	border-radius: 0.3rem;
	background-color: #e6c4d1;
	color: #333;
	text-align: center;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

/* Focus-state inputveld */
.spw-quantity-input:focus {
	border-color: #b2788e;
	box-shadow: 0 0 0 2px rgba(178, 120, 142, 0.3);
	outline: none;
}

/* Verwijder spinner-knoppen in input */
.spw-quantity-input::-webkit-inner-spin-button,
.spw-quantity-input::-webkit-outer-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

.spw-quantity-input[type=number] {
	-moz-appearance: textfield;
}

/* Knop na toevoegen overlay */
.spw-added-overlay .button {
	display: inline-block;
	margin-bottom: 0.5rem;
}

/* === Einde Snelle Productweergave Popup === */


/* === Begin Verlanglijst === */



.wishlist-already,
.servies-wishlist-knop-button{
    gap: .5rem;
    display: flex;
    padding: 0 .1rem;
    font-size: larger;
    cursor: pointer;
    width: 100%;
    align-items: flex-start;
    text-align: left;
	line-height: 1;
}

.wishlist-already:hover{
	cursor: not-allowed;
}
.servies-wishlist-knop-button:hover{
	color: #dd7ca1 !important;
	transition: 1s;
}


.servies-wishlist-knopservies-wishlist-knop.servies-wishlist-knop-button.button-hartje-toevoegen,
.servies-wishlist-knop.servies-wishlist-knop-button.button-hartje-toevoegen{
    display: flex;
    gap: .5rem;
    align-items: baseline;
    padding-left: .2rem;
    cursor: pointer;
}

/* Harticoon met teller */
.servies-wishlist-icon {
	position: relative;
	display: inline-block;
	font-size: 24px;
	color: #cc2b5e;
}

/* Harticoon met teller */
.servies-wishlist-icon {
	position: relative;
	display: inline-block;
	font-size: 24px;
	color: #cc2b5e;
}

.wishlist-count-badge {
	position: absolute;
	top: 7px;
	margin-left: 5px;
	color: #a31351;
	font-size: 12px;
	padding: 2px 6px;
	font-weight: bold;
}

/* Header boven wishlist popup */
.popup-header-verlanglijst {
	position: sticky;
	z-index: 120;
	top: 0;
	padding: 0.6rem 0.8rem 0;
	border-bottom: 3px solid #b2788e;
	background: url(../afbeeldingen/achtergronden/achtergrond3.jpg) top left repeat;
	box-shadow: 0px 1px 5px 2px #826a6b;
}

.popup-header-verlanglijst h1 {
	display: flex;
	color: #e6c4d1;
	align-items: center;
	max-width: 90%;
	margin: 0 0 .4rem 0;
}

/* Container voor harticoon */
.wishlist-icon-wrap {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.wishlist-icon-wrap i.fa-heart::before {
	/* color: #e6c4d1;
	font-size: 1.2rem!important;*/
}

/* Teller in harticoon */
.wishlist-counter-badge {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: .7rem;
    font-weight: 700;
    color: #7a2647;
    pointer-events: none;
    z-index: 2;
}

/* Wishlist-grid met flexibele kolommen */
.wishlist-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 1rem;
    padding: 0;
    margin: 0;
    list-style: none !important;
    color: #a31351;
}

/* Wishlist-tegel styling */
/* Algemene tegelstijl – gedeeld door popup en pagina */
.wishlist-item {
    position: relative;
    background: rgba(255, 255, 255, 0.2);
    border: 1px solid #b2788e;
    border-radius: 8px;
    padding: 0.6rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    overflow: hidden;
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.25);
}

/* Responsieve grid – alleen op pagina-verlanglijst */
.gedeelde-verlanglijst .wishlist-grid {
  display: grid;
  gap: 1.5rem;
  list-style: none;
  padding: 0;
  margin: 2rem 0;
  grid-template-columns: 1fr;
}

@media (min-width: 600px) {
  .gedeelde-verlanglijst .wishlist-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 900px) {
  .gedeelde-verlanglijst .wishlist-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}


/* Verwijderknop in hoek */
.wishlist-remove,
.delen-sluitknop {
	position: absolute;
	top: 0.4rem;
	right: 0.4rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: .6rem;
	width: 1.2rem;
	height: 1.2rem;
	font-size: 1rem;
	line-height: 1;
	color: #a31351;
	background-color: #e6c4d1;
	border: 2px solid #b2788e;
	border-radius: 50%;
	cursor: pointer;
	transition: all 0.8s ease;
}

.wishlist-remove:hover,
.delen-sluitknop:hover {
	background-color: #dd7ca1;
	color: #fee9ef;
}

/* Rij met thumbnail en prijs */
.wishlist-item-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.6rem;
}

.wishlist-item-row img {
    width: 60px;
    height: auto;
    border-radius: 4px;
    flex-shrink: 0;
    border: 2px solid #b2788e;
	box-shadow: 0 12px 24px rgba(0, 0, 0, 0.25);
}

/* Prijsweergave */
.wishlist-item .price {
	margin-top: 1rem;
	font-weight: 600;
	font-size: 0.95rem;
	color: #a31351;
}

/* Producttitel en knop onderin */
.wishlist-item-info {
	margin-top: auto;
	margin-bottom: .5rem;
}

.wishlist-item-info a,
button.wishlist-add-to-cart.button {
    font-size: large;
    text-align: left;
    line-height: 1.1;
    align-items: flex-end;
    display: flex;
    gap: .2rem;
}


/* Statusregel onder wishlist */
.wishlist-status-tekst {
	min-height: 2rem;
}

/* Feedback-overlay */
#wishlist-feedback {
	display: none;
	background: #fcecf1;
	color: #9b4d68;
	padding: 3rem 1rem;
	border-radius: 0.5rem;
	margin-bottom: 1rem;
	font-weight: 700;
	font-size: large;
	transition: opacity 0.3s ease;
	position: absolute;
	top: 50%;
	left: 50%;
	width: 80%;
	text-align: center;
	z-index: 2;
	transform: translate(-50%, -50%);
	box-shadow: 0px 1px 5px 2px #826a6b;
	border: 2px solid;
}

#wishlist-feedback.show {
	display: block;
	opacity: 1;
}

@keyframes slideInLogin {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.login-verlanglijst-blok {
  display: none;
}

.login-verlanglijst-blok.visible {
  display: block;
  animation: slideInLogin 0.4s ease forwards;
}

.wishlist-delen-trigger a {

}

#wishlist-delen-slide {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 90%;
  border: .5rem solid #a31351;
  max-width: 500px;
  background: #fff8fa;
  z-index: 9999;
  box-shadow: 0 6px 34px rgba(0,0,0,1.3);
  padding: 2rem;
  display: none;
  border-radius: .5rem;
}

@keyframes zoomInPopup {
  from {
    transform: translate(-50%, -50%) scale(0.8);
    opacity: 0;
  }
  to {
    transform: translate(-50%, -50%) scale(1);
    opacity: 1;
  }
}

#wishlist-delen-slide.open {
  display: block;
  animation: zoomInPopup 0.3s ease-out forwards;
}

.wishlist-hidden {
  display: none !important;
}

@keyframes zoomInContent {
  from {
    transform: translateY(20px) scale(0.95);
    opacity: 0;
  }
  to {
    transform: translateY(0) scale(1);
    opacity: 1;
  }
}

/* Verberg initieel de extra tekst tot de wishlist is geladen */
.wishlist-hidden {
  display: none !important;
}

/* Subtiele zoom-in voor de wishlist content */
@keyframes zoomInContent {
  from {
    transform: translateY(20px) scale(0.95);
    opacity: 0;
  }
  to {
    transform: translateY(0) scale(1);
    opacity: 1;
  }
}

.wishlist-content-animated {
  animation: zoomInContent 0.4s ease-out forwards;
}

/* Verberg de deelknop standaard */
.wishlist-delen-trigger {
  display: none;
}


.wishlist-content-animated {
  animation: zoomInContent 0.4s ease-out forwards;
}

#wishlist-share-form label{
	color: #a9225c;
    font-weight: 600;
}

input#share_name,
#share_message{   
	margin-top: .2rem;
    border-radius: .2rem;
}

/* Responsive wishlist weergave op mobiel */
@media (max-width: 500px) {
	.wishlist-list {
		grid-template-columns: 1fr;
		gap: 0.75rem;
	}

	.wishlist-item {
		padding: 0.5rem;
	}

	.wishlist-item .price,
	.wishlist-item-info a {
		font-size: 0.92rem;
	}
}

/* === Einde Verlanglijst === */


/* === Begin (FAQ) Accordeon === */


.spreen-accordeon-titel{
	display: flex;
    gap: .3rem;
    flex-direction: row;
	padding: 10px;
	position: relative;
	cursor: pointer;
}

.spreen-accordeon-titel:hover{
	color: #dd7ca1;
}

.spreen-accordeon-titel::before {
	content: "\f0da";
	font: var(--fa-font-solid);
	line-height: 1.1;
}

.spreen-accordeon-titel.active{	
    margin: 2rem 0 -1.3rem;
    border: 1px solid #b2788e;
    border-radius: .5rem;
    width: fit-content;
    background: #faf0f5;
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.25);
}

.spreen-accordeon-titel.active:hover{
	color: #a31351;
	cursor: unset;
}

.spreen-accordeon-titel.active::before {
	content: "\f05a";
	font: var(--fa-font-solid);
	line-height: 1.1;
}

/* ▪️ Inhoudsstructuur */


.spreen-accordeon-inhoud{
    margin: 0 0 2rem 1rem;
	border: 1px solid #b2788e;
    border-radius: .5rem;
    padding: 1rem;
    background: #f1d1e042;
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.25);
}


@media only screen and (max-width: 768px) {
  .spreen-accordeon-inhoud{
    margin: 0 .5rem 2rem;
    padding: .5rem;

}

.spreen-accordeon-titel.active{
	margin: 2rem 0 -1.3rem -.5rem;
}
}



/* ▪️ Gesloten inhoudsblok — verborgen + subtiele blur op paragrafen */
.spreen-accordeon.accordeon .spreen-accordeon-inhoud {
	max-height: 0;
	overflow: hidden;
	/* border-bottom-width: 0; */
	padding-top: 0;
	padding-bottom: 0;
}

/* ▪️ Geopende inhoudsblok — zichtbaar + scherpe paragrafen */
.spreen-accordeon .accordeon-open .spreen-accordeon-inhoud {
	max-height: 9999px;
	padding-top: 2rem;
	padding-bottom: 1rem;
	transition:
		padding-top 0.2s ease-in,
		max-height 0.3s 0.2s linear,
		padding-bottom 0.4s 0.2s ease;
}

ul.faqlijst,
.woocommerce-product-details__short-description ul{
	padding-left: 1rem;
    margin: 1rem 0;
    font-size: large;
}

ul.faqlijst li,
.woocommerce-product-details__short-description ul li {
    list-style-type: none;
    margin-bottom: 1rem;
    display: flex;
    gap: .3rem;
    align-items: flex-start;
}
ul.faqlijst li::before,
.woocommerce-product-details__short-description ul li::before {
    font: var(--fa-font-solid);
    content: "\f111";
    color: #cb789c;
    font-size: .5rem;
	line-height: 1;
    transform: translateY(0.35rem);
    flex-shrink: 0;
}


/* === Einde (FAQ) Accordeon === */


/* === Begin Theepot Spinner === */

.blockUI.blockSpinner,
.blockUI.blockOverlay {
	display: none !important;
	opacity: 0 !important;
	pointer-events: none !important;
	visibility: hidden !important;
}

.global-spinner.spinner-container {
	position: fixed;
	top: 50%;
	left: 50%;
	width: 80px;
	height: 80px;
	transform: translate(-50%, -50%) scale(2);
	background-color: #e6c4d1;
	border: 2px solid #b2788e;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.4s ease, transform 0.8s ease;
	overflow: visible;
	z-index: 9100;
}

.global-spinner.spinner-container.show {
	opacity: 1;
	pointer-events: auto;
}

.spinner-inner {
	position: relative;
	width: 76px;
	height: 76px;
}

.steam-puffs {
	position: absolute;
	top: 65%;
	left: 78%;
	transform: translate(-50%, -50%);
	z-index: 4;
	pointer-events: none;
}

.steam {
	position: absolute;
	bottom: 0;
	left: 50%;
	width: 6px;
	height: 12px;
	background: radial-gradient(circle, rgba(150, 69, 97, 0.75), transparent);
	border-radius: 50%;
	transform: translateX(-50%);
	opacity: 0;
	animation: steamFloat 6s ease-in-out infinite;
	filter: blur(2px);
}

.puff1 {
	animation-delay: 0s;
}

.puff2 {
	animation-delay: 2s;
	left: 40%;
}

.puff3 {
	animation-delay: 4s;
	left: 60%;
}

@keyframes steamFloat {
	0% {
		transform: translateX(-50%) translateY(0) scale(0.7) rotate(0deg);
		opacity: 0;
	}

	20% {
		transform: translateX(-58%) translateY(-10px) scale(0.9) rotate(-3deg);
		opacity: 0.6;
	}

	50% {
		transform: translateX(-42%) translateY(-30px) scale(1.1) rotate(4deg);
		opacity: 0.4;
	}

	80% {
		transform: translateX(-55%) translateY(-45px) scale(1.3) rotate(-2deg);
		opacity: 0.2;
	}

	100% {
		transform: translateX(-50%) translateY(-60px) scale(1.5) rotate(0deg);
		opacity: 0;
	}
}

.spinner-teapot {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 50px;
	height: auto;
	transform: translate(-50%, -50%);
	z-index: 2;
}

.spinner-ring {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
}

.spinner-rotate {
	animation: spinRing 2s linear infinite;
	transform-origin: center;
	transform-box: fill-box;
	transform: rotate(0deg);
}

@keyframes spinRing {
	from {
		transform: rotate(0deg);
	}

	to {
		transform: rotate(360deg);
	}
}

/* === Einde Theepot Spinner === */

/* === Begin toegankelijkheid === */


body.grayscale-mode #popup_toegankelijkheid {
  left: 0 !important;
  right: 0 !important;
}

.dyslexic-mode * {
  font-family: 'Lexend', Arial, sans-serif !important;
}

.dyslexic-mode {
  letter-spacing: 0.02rem;
  word-spacing: 0.15rem;
  line-height: 1.8;
}

.dyslexic-mode h2.titel,
.dyslexic-mode #delen-huidige-pagina,
.dyslexic-mode #delen-home-pagina{
	line-height: 1 !important;
	padding: .5rem 1rem;
}

.dyslexic-mode .sidebar.inhoud p{
  text-align: left !important;
}

.dyslexic-mode i,
.dyslexic-mode .fa,
.dyslexic-mode .fas,
.dyslexic-mode .far,
.dyslexic-mode .fab,
.dyslexic-mode .fa-solid,
.dyslexic-mode .fa-regular,
.dyslexic-mode .fa-brands {
  font-family: "Font Awesome 6 Free", "Font Awesome 5 Free", "FontAwesome", sans-serif !important;
}


.toggle-titel {
  cursor: pointer;
  outline: none;
  font-size: larger;
  margin-bottom: 2rem;
}

.toggle-titel:focus {

}

.arrow {
  display: inline-block;
  transition: transform 0.3s ease;
  margin-right: 8px;
}

.arrow.open {
  transform: rotate(180deg);
}


#toegankelijkheidsverklaring li,
#toegankelijkheidsverklaring-simpel li {
    list-style: disc;
    font-size: large;
    margin: 0 0 .5rem 1.2rem;
}

#toegankelijkheidsbeleid,
#toegankelijkheidsbeleid-simpel{
	margin: 0 -1rem;
    padding: 0 1rem;
}

#accessibility-menu{
	font-size: larger;
}

#accessibility-title{
	font-weight: 800;
    margin-bottom: 1rem;
}

ul.accessibility-list li{
	margin-bottom: .8rem;
}




.grayscale-mode body::before,
.grayscale-mode #wrapper,
.grayscale-mode #inner,
.grayscale-mode #content {
  filter: grayscale(100%) !important;  
}

 html.grayscale-mode{
  scrollbar-color: #aaaaaa #3b3b3b !important;
  background-color: #3b3b3b !important;
  scrollbar-gutter: stable !important;
}




.dark-mode #inner,
.dark-mode #content,
.dark-mode .inhoud,
.dark-mode h1,
.dark-mode h2,
.dark-mode h3,
.dark-mode p,
.dark-mode .sticky-titel,
.dark-mode ::before,
.dark-mode #header-menu,
.dark-mode .navigatie
{
	
	
  /*background-color: #121212 !important;
  color: #ffd5e5 !important;
  background-image: none !important;*/
}

.dark-mode a {
  color: #ff99cc !important;
}
.dark-mode button,
.dark-mode input,
.dark-mode textarea,
.dark-mode select {
  background-color: ;
  color:;
  border-color:;
}

.dark-mode .inhoud{
	
}

.soft-contrast-mode #inner,
.soft-contrast-mode #content,
.soft-contrast-mode .inhoud,


.high-contrast-mode #inner,
.high-contrast-mode #content,
.high-contrast-mode .inhoud 


{
  background-color: #121212 !important;
  color: #f5f5f5 !important;
}



.high-contrast-mode a {
  color: #0ff !important;
}
.high-contrast-mode {
  background-color: #000 !important;
  color: #ff0 !important;
}

/* Menu mag NIET meeveranderen met modi */
.dark-mode #accessibility-menu,
.soft-contrast-mode #accessibility-menu,
.high-contrast-mode #accessibility-menu,
.dark-mode #accessibility-menu *,
.soft-contrast-mode #accessibility-menu *,
.high-contrast-mode #accessibility-menu * {

  color: #000 !important;

}



.spreen-flyer-box img{
    border: 2px solid #b2788e;
    border-radius: .5rem;
}

.widget_media_image img,
.spreen-flyer-box img{
	box-shadow: 0 12px 24px rgba(0, 0, 0, 0.25);
}

.spreen-flyer-box{
	margin-bottom: 1rem;
}


