:root {
	--font-primary: 'Fagun', sans-serif;

	--fs-h1: clamp(2.5rem, 5vw, 4rem);
	--fs-h2: clamp(2rem, 4vw, 3rem);
	--fs-h3: clamp(1.5rem, 3vw, 2rem);
	--fs-h4: clamp(1.25rem, 2.5vw, 1.5rem);
	--fs-body: clamp(1.1rem, 1.2vw, 1.125rem);
}

/* Basis */
body,
body input,
body textarea,
body select,
p.elementor-heading-title,
span.elementor-heading-title,
div.elementor-heading-title {
	font-family: var(--font-primary);
	font-size: var(--fs-body);
	font-weight: 300;
	line-height: 1.8;
}

/* Headings */
/* H1 */
body h1,
body .elementor-widget-heading h1.elementor-heading-title {
	font-family: var(--font-primary);
	font-size: var(--fs-h1);
	font-weight: 900;
	line-height: 1.2;
}

/* H2 */
body h2,
body .elementor-widget-heading h2.elementor-heading-title {
	font-family: var(--font-primary);
	font-size: var(--fs-h2);
	font-weight: 900;
	line-height: 1.25;
}

/* H3 */
body h3,
body .elementor-widget-heading h3.elementor-heading-title {
	font-family: var(--font-primary);
	font-size: var(--fs-h3);
	font-weight: 500;
	line-height: 1.3;
}

/* H4 */
body h4,
body .elementor-widget-heading h4.elementor-heading-title {
	font-family: var(--font-primary);
	font-size: var(--fs-h4);
	font-weight: 500;
	line-height: 1.35;
}

/* H5 */
body h5,
body .elementor-widget-heading h5.elementor-heading-title {
	font-family: var(--font-primary);
	font-size: var(--fs-h5);
	font-weight: 300;
	line-height: 1.4;
}

/* H6 */
body h6,
body .elementor-widget-heading h6.elementor-heading-title {
	font-family: var(--font-primary);
	font-size: var(--fs-h6);
	font-weight: 300;
	line-height: 1.45;
}

/* Tekst */
body p,
body li,
body a,
body span,
body .elementor-widget-text-editor,
body .elementor-icon-list-text,
body .elementor-image-box-description,
body .elementor-post__excerpt {
	font-family: var(--font-primary);
}
/* Links */
/* Underline alleen voor links in tekst */
.elementor-widget-text-editor p a,
.elementor-widget-text-editor li a,
.elementor-widget-theme-post-content p a,
.elementor-widget-theme-post-content li a {
    text-decoration: underline;
}
/* Voor de zekerheid: geen underline op buttons */
.elementor-button,
.elementor-button:hover {
    text-decoration: none !important;
}
/* Geen underline op menu-items */
.elementor-nav-menu a,
.elementor-nav-menu a:hover {
    text-decoration: none !important;
}
/* Geen underline op links in footer */
footer a,
footer a:hover {
    text-decoration: none !important;
}
/* Buttons */
body .elementor-button,
body button,
body input[type="button"],
body input[type="submit"] {
	font-family: var(--font-primary);
	font-size: var(--fs-body);
	line-height: 1.1em!important;
}

/*** Breadcrumbs ***/
.rank-math-breadcrumb p,
.rank-math-breadcrumb a,
.rank-math-breadcrumb span {
	font-size: var(--e-global-typography-text-font-size);
	color: var(--e-global-color-bdbd2f0);
	transition: 0.2s ease-in;
}
.rank-math-breadcrumb a:hover {
	color: var(--e-global-color-a5a3a40);
}

/*** Custom scrollbar ***/
::-webkit-scrollbar {
	width: 10px;
}

::-webkit-scrollbar-track {
	background: var(--e-global-color-secondary);
}

::-webkit-scrollbar-thumb {
	background: var(--e-global-color-bdbd2f0);
	border-radius: 10px;
}

/*** Custom selection ***/
::selection {
	color: var(--e-global-color-text);
	background-color: color-mix(in srgb, var(--e-global-color-primary), transparent 80%);
}

::-moz-selection {
	color: var(--e-global-color-text);
	background-color: color-mix(in srgb, var(--e-global-color-primary), transparent 80%);
}

/*** Lightbox background color for images ***/
.elementor-lightbox .elementor-lightbox-image {
	background-color: var(--e-global-color-5148d3c);
}
/*** Hover lift on containers ***/
.hover-lift {
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.hover-lift:hover,
.hover-lift:focus-within {
  transform: translateY(-6px);
}
/*** Hide ReCaptcha badge ***/
.grecaptcha-badge { 
  visibility: hidden; 
}
/* Tabel FastFit */

/* Elke 2de td (Torix FastFit kolom) achtergrondkleur */
.elementor-element-3e6e7bb .jet-table__body-row .jet-table__body-cell:nth-child(2),
.elementor-element-3e6e7bb .jet-table__head .jet-table__head-cell:nth-child(2) {
    background-color: #ffffff7d;
	padding: 0rem 2rem;
}
/* Eerste td links uitlijnen */
.elementor-element-3e6e7bb .jet-table__body-row .jet-table__body-cell:nth-child(1) .jet-table__cell-content {
    text-align: left !important;
    margin-left: 0 !important;
    margin-right: auto !important;
}
.elementor-element-3e6e7bb .jet-table {
    border-collapse: collapse !important;
}
.elementor-element-3e6e7bb .jet-table__body-row {
    border-bottom: 1px solid var(--e-global-color-373b23c);
}
.elementor-element-3e6e7bb .jet-table__body-row:last-child {
    border-bottom: none;
}
.elementor-repeater-item-770174c .jet-table__cell-text {
	color: var(--e-global-color-bdbd2f0);
}
/*** FORMS ***/

/* Acceptance text small */
.elementor-field-type-acceptance .elementor-field-subgroup .elementor-field-option label {
	font-size: 75%!important;
}
.button-password {
	background-color: transparent!important;
	padding: 0!important;
	border-radius: 0px!important;
	color: var(--e-global-color-bdbd2f0)!important;
	font-size: 80%!important;
}

/*** Styling van radio buttons ***/
.elementor-field-type-radio input[type="radio"] {
  appearance: none;
  -webkit-appearance: none;
  display: inline-block!important;
  width: 18px;
  height: 18px;
  min-width: 18px;
  background-clip: content-box;
  border: 2px solid var(--e-global-color-373b23c);
  border-radius: 50%;
  padding: 3px;
  margin-right: 0.5rem!important;
  cursor: pointer;
  vertical-align: middle;
  box-sizing: border-box;
}
.elementor-field-type-radio input[type="radio"]:checked {
  background-color: var(--e-global-color-primary);
  border-color: var(--e-global-color-primary);
}

.elementor-field-type-radio input[type="radio"]:focus-visible {
  outline: 2px solid var(--e-global-color-primary);
  outline-offset: 2px;
}

/*** Styling van JetEngine Grid Slider pagination ***/
.jet-engine-swiper-pagination-wrapper {
    margin: 2rem 0 0;
}