/*
Theme Name: Aarnoudse Base
Theme URI: https://elementor.com/hello-theme/?utm_source=wp-themes&utm_campaign=theme-uri&utm_medium=wp-dash
Template: hello-elementor
Author: Tim Barendregt
Author URI: https://elementor.com/?utm_source=wp-themes&utm_campaign=author-uri&utm_medium=wp-dash
Description: Custom styling voor de multisite
Tags: accessibility-ready,flexible-header,custom-colors,custom-menu,custom-logo,featured-images,rtl-language-support,threaded-comments,translation-ready
Version: 3.4.8
Updated: 2026-06-01 16:04
*/

/* === FONTS === */

@font-face {
  font-family: 'Barlow';
  src: url('assets/fonts/barlow/barlow-400.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Barlow';
  src: url('assets/fonts/barlow/barlow-500.woff2') format('woff2');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Barlow';
  src: url('assets/fonts/barlow/barlow-600.woff2') format('woff2');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Barlow';
  src: url('assets/fonts/barlow/barlow-700.woff2') format('woff2');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Space Mono';
  src: url('assets/fonts/monospace/SpaceMono-Regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Space Mono';
  src: url('assets/fonts/monospace/SpaceMono-Bold.woff2') format('woff2');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

/* === ROOT VARIABLES === */

:root {
  /* Colors */
  --color-white: #ffffff;
  --color-lightblue: #f7faff;
  --color-lightbluedarker: #e2e9f4;
  --color-blue: #154281;
  --color-orange: #eb7412;
  --color-black: #292929;
  --color-green: #18bd31;
  --color-gradient: linear-gradient(180deg, #f7faff 0%, #ffffff 100%) !important;

  /* Typography */
  --font-primary: 'Barlow', sans-serif;
  --font-mono: 'Space Mono', monospace;

  --text-body: 1rem;
  --text-small: 0.875rem;

  --h1-size: clamp(2rem, 4.4vw, 3.5rem);
  --h2-size: clamp(1.7rem, 3.2vw, 2.2rem);
  --h3-size: clamp(1.2rem, 1.4vw, 1.5rem);

  --subtitle-large: clamp(0.8rem, 1.4vw, 1rem);
  --subtitle-small: 0.8rem;
  --faq-title: 1.2rem;

  /* Icons */
  --icon-large: 1rem;
  --icon-small: 1rem;

  /* Layout */
  --container-max: 1280px;
  --container-padding: 5%;
  --section-spacing: clamp(4rem, 8vw, 7rem);
  --footer-spacing: clamp(0.3rem, 4vw, 0.6rem);
  --gap-md: 24px;

  /* Spacing */
  --faq-title-padding: 6px 20px;

  /* Radius */
  --radius-image: 12px;
  --radius-card: 16px;
  --radius-button: 50px;

  /* Shadows */
  --shadow-sm: 0 4px 12px rgba(0, 0, 0, 0.08);
  --shadow-md: 0 8px 24px rgba(0, 0, 0, 0.12);
  --shadow-neu: 14px 14px 26px #d8dbe1, -14px -14px 26px #ffffff;

  /* Transitions */
  --transition: 0.25s ease;
  --transition-slow: 1.3s ease;

  /* Animations */
  --fade-in-duration: 0.8s;
  --fade-in-delay-step: 300ms;
}

/* === GLOBAL === */

html {
  scroll-behavior: smooth;
}

#header, #specs, #opties, #faq, #offerte {
  scroll-margin-top: 120px;
}

body {
  font-family: var(--font-primary);
  font-size: var(--text-body);
  line-height: 1.5;
  font-weight: 400;
  color: var(--color-black);
  background: var(--color-white);
  overflow-x: clip;
}

.e-con {
  --container-max-width: var(--container-max);
}

section {
  padding-block: var(--section-spacing);
}

img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-image);
}

a {
  color: var(--color-orange);
  text-decoration: none;
  transition: var(--transition);
}

a:hover {
  color: var(--color-blue);
}

p {
  margin-bottom: 1.25rem;
}

/* === CONTAINER === */

.elementor-element.container.e-parent {
  width: 100% !important;
  max-width: none !important;
  margin-inline: auto;
  padding-inline: var(--container-padding) !important;
  padding-block: var(--section-spacing) !important;
}

.elementor-element.container.e-child {
  width: 100% !important;
  max-width: none !important;
}

.elementor-element.container.e-parent.no-top {
  padding-top: 0 !important;
}

.elementor-element.e-con.bg-gradient {
  background: var(--color-gradient) !important;
  background-image: var(--color-gradient) !important;
}

.elementor-lightbox .elementor-lightbox-image {
	background: #fff;
}

/* === HEADINGS === */

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--font-primary);
  margin-top: 0;
  line-height: 1.4;
}

h1 {
  font-size: var(--h1-size);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--color-blue);
}

h2 {
  font-size: var(--h2-size);
  font-weight: 700;
  color: var(--color-blue);
}

h3 {
  font-size: var(--h3-size);
  font-weight: 600;
  color: var(--color-blue);
  margin-bottom: 6px;
}

/* === SUBTITLES === */

.h2-subtitle h2,
.h3-subtitle h3 {
  line-height: 1.5;
  color: var(--color-orange) !important;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 600;
}

.h2-subtitle h2 {
  font-size: var(--subtitle-large) !important;
  margin-inline: auto;
}

.h3-subtitle h3 {
  font-size: var(--subtitle-small);
}

/* === TEXT HELPERS === */

.small-text {
  font-size: var(--text-small);
  line-height: 1.5;
}

.mono {
  font-family: var(--font-mono);
  font-weight: 700;
}

.text-center {
  text-align: center;
}

.text-white {
  color: var(--color-white);
}

.text-blue {
  color: var(--color-blue);
}

.text-orange {
  color: var(--color-orange);
}

.text-black {
  color: var(--color-black);
}

/* === BACKGROUNDS === */

.bg-white {
  background: var(--color-white);
}

.bg-lightblue {
  background: var(--color-lightblue);
}

.bg-blue {
  background: var(--color-blue);
}

.bg-orange {
  background: var(--color-orange);
}

/* === UTILITIES === */

.mt-lg {
  margin-top: 64px;
}

.mb-lg {
  margin-bottom: 64px;
}

.shadow {
  box-shadow: var(--shadow-sm);
}

.glass {
  background: rgba(237, 241, 247, 0.9);
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
  border: 1px solid rgba(237, 241, 247, 0.3);
}

.neu {
  background: #edf1f7;
  box-shadow: var(--shadow-neu) !important;
}


/* === ANIMATIONS === */

@keyframes FadeIn {
  0% {
    opacity: 0;
    transform: var(--fade-in-start-position);
  }

  100% {
    opacity: 1;
    transform: none;
  }
}

.fade-in-up {
  --fade-in-start-position: translate3d(0, 100%, 0);
}

.fade-in-left {
  --fade-in-start-position: translate3d(100%, 0, 0);
}

html.motion-ready .fade-in {
  opacity: 0;
}

html.motion-ready .fade-in.is-visible {
  animation-name: FadeIn;
  animation-duration: var(--fade-in-duration);
  animation-timing-function: ease-out;
  animation-fill-mode: both;
}

.fade-in.delay-1 {
  animation-delay: calc(var(--fade-in-delay-step) * 1);
}

.fade-in.delay-2 {
  animation-delay: calc(var(--fade-in-delay-step) * 2);
}

.fade-in.delay-3 {
  animation-delay: calc(var(--fade-in-delay-step) * 3);
}

.fade-in.delay-4 {
  animation-delay: calc(var(--fade-in-delay-step) * 4);
}

.fade-in.delay-5 {
  animation-delay: calc(var(--fade-in-delay-step) * 5);
}

@media (prefers-reduced-motion: reduce) {
  html.motion-ready .fade-in {
    opacity: 1;
    transform: none;
    animation: none;
  }
}

/* === MENU === */

.header-menu a {
  font-family: var(--font-primary);
  font-size: var(--text-body);
  line-height: 1.7;
  font-weight: 500 !important;
  color: var(--color-black);
}

li.mobiel {
  display: none !important;
}

.menu-bar {
  height: 100px !important;
  z-index: 999 !important;
}

/* === BUTTONS === */

.btn-primary .elementor-button,
.btn-secondary .elementor-button,
.btn-cta .elementor-button,
.form-block button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px 28px;
  border-radius: var(--radius-button);
  font-family: var(--font-primary);
  font-weight: 600 !important;
  text-decoration: none;
  transition: var(--transition);
}

.btn-primary .elementor-button {
  background: var(--color-blue);
  color: var(--color-white);
}

.btn-primary .elementor-button:hover {
  background: var(--color-orange);
  color: var(--color-black);
}

.btn-secondary .elementor-button {
  padding: 12px 28px;
  background: var(--color-white);
  color: var(--color-blue) !important;
  border: 2px solid var(--color-blue);
}

.btn-secondary .elementor-button:hover {
  background: var(--color-blue);
  color: var(--color-white) !important;
}

.btn-cta .elementor-button,
.form-block button {
  background: var(--color-orange);
  color: var(--color-black);
}

.btn-cta .elementor-button:hover,
.form-block button:hover {
  background: var(--color-blue);
  color: var(--color-white);
}

.form-block button {
  width: 30% !important;
}

/* === CARDS & BLOCKS === */

.card,
.block,
.form-block {
  background: var(--color-lightblue);
  border-radius: var(--radius-card) !important;
  padding: 20px !important;
}

.card {
  transition: var(--transition);
}

.card-white {
  background: var(--color-white);
  border-radius: var(--radius-card) !important;
  box-shadow: var(--shadow-sm);
  padding: 20px !important;
  transition: var(--transition) !important;
}

.block {
  box-shadow: var(--shadow-sm) !important;
  padding: 32px !important;
}

.form-block {
  box-shadow: var(--shadow-sm) !important;
  background: var(--color-white);
  border-radius: 0 !important;
}

.card-white img,
.block img {
  border-radius: var(--radius-image) !important;
  aspect-ratio: 1 / 1;
  object-fit: cover;
}

.card-white img {
  background: #f9f9f9 !important;
}

/* === IMAGES === */

.main-image img {
  height: 480px !important;
  object-fit: contain;
  aspect-ratio: 1 / 1;
  transition: var(--transition-slow);
}

.main-image:hover img {
  transform: scale(1.2);
}

/* === HEADER SPECS === */

.header-specs-banner {
  margin-top: 40px !important;
}

.header-specs {
  width: 25%;
  border-right: 1px solid var(--color-lightbluedarker);
}

.header-specs:last-child {
  border-right: none !important;
}

.header-specs p.elementor-icon-box-title {
  font-family: var(--font-mono);
  font-weight: 400;
  font-size: 14px;
  margin-bottom: 0;
  line-height: 1;
  color: var(--color-blue);
}

div#specs img {
	height: 300px !important;
    object-fit: contain !important;
}

div#specs .image.one {
    border-right-color: var(--color-lightbluedarker);
    border-right-style: solid;
    border-right-width: 1px;
    border-bottom-color: var(--color-lightbluedarker);
    border-bottom-style: solid;
    border-bottom-width: 1px;
}
div#specs .image.four {
    border-left-color: var(--color-lightbluedarker);
    border-left-style: solid;
    border-left-width: 1px;
    border-top-color: var(--color-lightbluedarker);
    border-top-style: solid;
    border-top-width: 1px;
}


/* === TOEPASSINGEN === */

.elementor-element.toep-box {
    background: var(--color-white) !important;
    padding: 0 !important;
    border-radius: 12px !important;
    overflow: hidden;
    box-shadow: var(--shadow-sm);
}

.toep-box .text-box {
    padding: 24px !important;
}

.toep-box .elementor-shape-circle .elementor-icon {
    border-radius: 8px;
}

.toep-box .elementor-view-stacked .elementor-icon {
    background-color: var(--color-lightbluedarker);
    color: var(--color-blue);
    fill: var(--color-blue);
    padding: 8px;
}

.toep-box .elementor-icon-wrapper {
    margin-top: -40px;
}

.toep-box .elementor-icon svg {
	width: 20px;
    height: 20px;
}

.toep-box img {
    height: 240px;
    object-fit: cover;
}

/* === USP / ICON BOXES === */

.card .elementor-icon {
  font-size: 24px;
  color: var(--color-blue);
}

.usp-banner {
  display: flex;
  gap: var(--gap-md);
  align-items: stretch;
}

.usp-banner .card {
  flex: 1;
}



.usp-box {
  position: relative;
  padding: 40px !important;
  background: var(--color-lightblue);
}

.usp-box .mono {
  position: absolute !important;
  top: 20px;
  right: 40px;
  color: var(--color-lightbluedarker);
  font-size: 30px;
}

.usp-box span.elementor-icon, .toep-box span.elementor-icon {
  background: var(--color-lightbluedarker) !important;
  font-size: var(--icon-large);
  border-radius: 8px;
}

.usp-box span.elementor-icon svg, .toep-box span.elementor-icon svg {
  fill: var(--color-blue) !important;
}

.usp-box:hover {
  transform: translateY(-6px);
}

.usp-box::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 1px;
  background-color: var(--color-blue);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 700ms ease;
}

.usp-box:hover::after {
  transform: scaleX(1);
}

/* === CHECKLIST === */

.checkbox {
  border-bottom: 1px solid var(--color-lightbluedarker);
  padding: 10px 10px 0 !important;
}

.checkbox:first-child {
  padding-top: 0 !important;
}

.checkbox .mono {
  color: var(--color-lightbluedarker);
  font-weight: 400;
}

.checklist svg {
  fill: var(--color-green) !important;
}

/* === OPTIES BLOKKEN === */

.opties-box {
    background: var(--color-lightblue);
    padding: 0 !important;
}

.opties-box img {
    height: 220px !important;
    object-fit: cover;
    background: var(--color-white);
}

.opties-box .text-box {
    padding: 16px 24px;
}

.category {
    margin-top: -32px;
    margin-bottom: 12px !important;
}

.category span {
    background: var(--color-blue);
    color: var(--color-white);
    padding: 3px 16px;
    border-radius: 8px;
    font-family: 'Space Mono';
    font-size: 12px;
}


/* === FAQ ACCORDION === */

.faq-accordion summary.e-n-accordion-item-title {
  border: none !important;
  background: var(--color-lightblue);
  border-radius: 0 !important;
  margin-bottom: 20px;
  padding: var(--faq-title-padding);
}

.faq-accordion .e-child {
  border: none;
  background: var(--color-lightblue);
  margin-bottom: 20px;
  padding: var(--faq-title-padding);
}

.faq-accordion .e-n-accordion-item-title-text {
  font-size: var(--faq-title) !important;
  line-height: 1.5;
  font-weight: 600;
  color: var(--color-blue);
}

/* === FORMS === */

input,
textarea,
select {
  width: 100%;
  padding: 14px 18px !important;
  border-radius: 12px !important;
  border: 1px solid #dcdcdc !important;
  font-family: inherit;
  font-size: 1rem !important;
  transition: var(--transition) !important;
}

input:focus,
textarea:focus,
select:focus {
  outline: none;
  border-color: var(--color-blue) !important;
}

.form-block label {
  display: block;
  font-weight: 600;
  margin-bottom: 6px;
  margin-top: 12px;
}

/* === FOOTER === */

.footer {
  padding-block: var(--footer-spacing);
  background: var(--color-blue);
}

.footer p a {
  color: var(--color-white) !important;
  text-decoration: underline;
}

/* === RESPONSIVE === */

@media (max-width: 767px) {
	.main-image img {
  height: 220px !important;
}

  .card {
    padding: 24px !important;
  }

  .btn-primary .elementor-button,
  .btn-cta .elementor-button,
  .form-block button {
    width: 100% !important;
  }

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

  .usp-banner .card {
    width: 100% !important;
  }

  li.mobiel {
    display: block !important;
  }
  
  .header-specs-banner {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0;
  }

  .header-specs {
    width: auto !important;
    border-right: none;
    border-bottom: none;
    margin: 0;
    padding: 16px 12px;
    text-align: center;
  }

  /* verticale lijn tussen kolom 1 en 2 */
  .header-specs:nth-child(odd) {
    border-right: 1px solid var(--color-lightbluedarker);
  }

  /* horizontale lijn tussen rij 1 en 2 */
  .header-specs:nth-child(-n + 2) {
    border-bottom: 1px solid var(--color-lightbluedarker);
  }
}