/**
 * CSS stylesheet voor www.abc-energetics.com
 * Eigenaar         :   ABC-Energetics
 * Auteur           :   Jan Lont
 * Laatst gewijzigd :   24-04-2026
 */

/*--------------------------------------------------------------------------------------------*\
 * Instellingen gebruikt in CSS berekeningen
 * -slq is het aantal getuigenissen dat op de homepage wordt getoond (max 5, anders moet de css worden aangepast)
 * dit moet gelijk zijn aan het aantal keuzerondjes en getuigenissen in de html-code
*\--------------------------------------------------------------------------------------------*/

:root {
    /* Instellingen gebruikt in CSS berekeningen */
    --slq: 3;

    /* Randradius voor thema */
    --brd: 10px;

    /* Ondersteuning voor light/dark mode */
    color-scheme: light dark;

    /* Achtergrondkleuren */
    --cbg01: light-dark(#F8F8FF, #5A1A5A);
    --cbg02: light-dark(#FFFFFF, #450045);
    --cbg03: light-dark(#EFEFEF, #503050);

    /* Tekst-, schaduw- en randkleuren */
    --cfg01: light-dark(#444444, #DCDCDC);
    --cfg02: light-dark(#DDDDDD, #666666);
    --cfg03: light-dark(#000000, #343434);
    --cfg04: light-dark(#402040, #FFC12F);
    --cfg05: light-dark(#666666, #B3B3B3);

    /* Hoofdthema kleuren */
    --cmn01: light-dark(#800080, #FFFFFF);
    --cmn02: light-dark(#D8D8FF, #887788);

    /* Groene en rode tekst voor fouten of accenten */
    --cec01: light-dark(#FF0000, #FF0000);
    --cec02: light-dark(#228B22, #228B22);

    /* Tabblad accentkleur */
    --cth01: light-dark(rgba(50,0,50,0.1), rgba(255,255,255,0.1));
}

/* Forceer donkere modus (voor toggle) */
html.dark-mode {
    color-scheme: dark;
}

/* Forceer lichte modus (voor toggle) */
html.light-mode {
    color-scheme: light;
}

/*--------------------------------------------------------------------------------------------*\
# CSS reset:                             https://medium.com/swlh/css-reset-2b4831d4664e
#                                        https://piccalil.li/blog/a-modern-css-reset/
# Enkele verdere optimalisaties gevonden op: https://hankchizljaw.com/wrote/a-modern-css-reset/
*\--------------------------------------------------------------------------------------------*/

* {
    margin: 0;
    padding: 0;
    font-size: 1em;
    font-family: inherit;
}

*, *::before, *::after {
    box-sizing: border-box;
}

html {
    font-size: 100%;
    text-size-adjust: 100%;
}

html:focus-within {
    scroll-behavior: smooth;
}

body {
    min-height: 99vh;
    line-height: 1;
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

/*--------------------------------------------------------------------------------------------*\
# Lettertypen
*\--------------------------------------------------------------------------------------------*/

/* H1 */
@font-face {
    font-family: 'Basic';
    src: local('Basic'),
         url('/fonts/basic-v10-latin-regular.woff2') format('woff2');
    font-display: swap;
}

/* H2 */
@font-face {
    font-family: 'Courgette';
    src: local('Courgette'),
         url('/fonts/courgette-v8-latin-regular.woff2') format('woff2');
    font-display: swap;
}

/* Algemeen */
@font-face {
    font-family: 'Satoshi';
    src: local('Satoshi'),
         url('/fonts/Satoshi-Variable.woff2') format('woff2');
    font-weight: 300 900;
    font-display: swap;
}

/*--------------------------------------------------------------------------------------------*\
# Scroll behavior en margin voor anchor links
# Voorkomt dat elementen tegen de bovenrand plakken
*\--------------------------------------------------------------------------------------------*/

html {
    scroll-behavior: smooth;       /* vloeiend scrollen */
    scroll-padding-top: 20px;      /* algemene ruimte boven anchors */
}

#top {
    scroll-margin-top: 0;          /* geen extra ruimte voor top-anchor */
}

.footer [id] {
    scroll-margin-top: 30px;       /* extra ruimte voor footer-secties */
}

/*--------------------------------------------------------------------------------------------*\
# Structuur
*\--------------------------------------------------------------------------------------------*/

body {
    display:flex;
    flex-direction: column;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    color: var(--cfg01);
    background-color: var(--cbg01);
    margin: 0px;
    padding: 0px;
    font-family: Satoshi, system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
    /* Font correcties voor Satoshi */
    font-weight: 470;
    letter-spacing: 0;
    font-size: 1.025rem;
    /* Algemene Opentype font settings */
    text-rendering: optimizeLegibility;
    font-kerning: normal;
    font-variant-ligatures: common-ligatures contextual;
    font-variant-numeric: lining-nums tabular-nums;
}

html {
    -webkit-tap-highlight-color: var(--cth01);
}

header {
    padding: 6px 10px 10px 10px;
}

/*--------------------------------------------------------------------------------------------*\
# Flex grid opzet:                                                                             #
#  - flex-grid                          (index.php)                                            #
#    - col                              (pagina-inhoud)                                        #
#      - grid-1-col                     (aantal kolommen)                                      #
#      - grid-2-col                                                                            #
#      - grid-3-col                                                                            #
#      - grid-4-col                                                                            #
#        - grid-col                     (grid kolom)                                           #
#        - grid-col-box                 (grid kolom met rand)                                  #
#          - grid-content                                                                      #
#          - grid-content-center        (gecentreerde inhoud)                                  #
#          - grid-content-flex          (flex box voor afbeelding onderaan uitgelijnd)         #
#          - grid-content-center-flex   (als flex maar gecentreerd)                            #
#            - top-content              (eerste deel van de inhoud > titel + tekst)            #
#            - bottom-content           (afbeelding onderaan uitgelijnd)                       #
*\--------------------------------------------------------------------------------------------*/

/* BUITENSTE FLEX GRID */

.flex-grid {
    flex-grow: 1;
    display: flex;
    flex-direction: row;
    padding: 0;
    line-height: 1.45;
    margin: 10px;
    border-width: 1px;
    border-style: solid;
    border-radius: var(--brd);
    border-color: var(--cmn01);
    background-color: var(--cbg02);
    text-align: justify;
    overflow-wrap: break-word;
    hyphens: auto;
    hyphenate-limit-chars: auto 5 5;
    word-break: normal;
    text-wrap: pretty;
    text-wrap-mode: wrap;
}

.col {
    flex: 1;
    padding: 8px;
}

@media (max-width : 768px) {
    .flex-grid {
        display: flex;
        flex-wrap: wrap;
    }
    .col{
        font-size: 95%;

        word-spacing: -0.05em;
    }
}

@media (max-width : 600px) {
    .col{
        font-size:93%;

        word-spacing: -0.1em;
    }
}

.col ul {
    list-style-type: circle;
    padding-left: 15px;
    margin-left: 5px;
    text-align: left;
}

.col a:link, .col a:visited, .footer a:link, .footer a:visited {
    color: var(--cfg01);
    text-decoration: none;
}

.col a:hover, .col a:active, .footer a:hover, .footer a:active {
    color: var(--cfg01);
    text-decoration: none;
    text-shadow: var(--cfg01) 0px 0 1px;
}

/*--------------------------------------------------------------------------------------------*\
# BINNENSTE GRID
*\--------------------------------------------------------------------------------------------*/

/* Gemeenschappelijke grid eigenschappen voor alle grid-klassen */
.grid-1col,
.grid-2col,
.grid-3col,
.grid-4col,
.grid-6col {
    display: grid;
    column-gap: 12px;
    row-gap: 12px;
}

/* Aantal kolommen specifiek */
.grid-1col {
    grid-template-columns: repeat(1, 1fr);
}

.grid-2col {
    grid-template-columns: repeat(2, 1fr);
}

.grid-3col {
    grid-template-columns: repeat(3, 1fr);
}

.grid-4col {
    grid-template-columns: repeat(4, 1fr);
}

.grid-6col {
    grid-template-columns: repeat(6, 1fr);
    font-size: 90%; /* Specifiek voor webshop */
}

/* Responsive breakpoints - geoptimaliseerd en gebundeld */
@media (max-width: 1900px) {
    .grid-6col {
        grid-template-columns: repeat(5, 1fr);
    }
}

@media (max-width: 1600px) {
    .grid-6col {
        grid-template-columns: repeat(4, 1fr);
    }
}

@media (max-width: 1300px) {
    .grid-6col {
        grid-template-columns: repeat(3, 1fr);
    }

    .grid-4col {
        grid-template-columns: repeat(3, 1fr);
    }

    .grid-3col {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 992px) {
    .grid-4col {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 900px) {
    .grid-6col {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .grid-2col,
    .grid-3col,
    .grid-4col,
    .grid-6col {
        grid-template-columns: repeat(1, 1fr);
    }
}

/* Marge boven grid-1col wanneer deze direct na een andere grid komt */
.grid-2col + .grid-1col,
.grid-3col + .grid-1col,
.grid-4col + .grid-1col,
.grid-6col + .grid-1col {
    margin-top: 16px;
}


/* Grid kolommen */

.grid-col {
    display: flex;
    padding: 6px;
    margin: 0px;
    text-decoration: none !important;
    contain: layout style;
}

.grid-col-box {
    display: flex;
    padding: 6px;
    margin: 0px;
    border-width: 1px;
    border-style: solid;
    border-color: var(--cfg02);
    border-radius: var(--brd);
    contain: layout style;
}

.grid-content {
    width: 100%;
    padding: 0;
    margin: 0;
}

.grid-content-center {
    width: 100%;
    padding: 0;
    margin: 0;
    text-align: center;
}

.grid-content-flex {
    width: 100%;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

@media (max-width: 768px) {
    .grid-content,
    .grid-content-center,
    .grid-content-flex {
        word-spacing: -1px;
    }
}

.top-content {
    width: 100%;
    padding: 0;
    margin: 0;
}

.bottom-content {
    display: flex;
    justify-content: center;
    align-content: flex-end;
}

/* Prijzen in webpagina's rechts uitgelijnd */
.PR-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    grid-auto-rows: 1fr;
    column-gap: 16px;
    row-gap: 0px;
    grid-template-rows: auto;
    grid-auto-rows: auto;
}

.PR-col {
    display: flex;
    padding: 0 0 2px 0;
    margin: 0px;
    text-decoration: none !important;
    border-width: 0;
    font-size: 90%;
}

.PR-left {
    width: 100%;
    padding: 0;
    margin: 0;
    text-align: left;
    padding-top: 5px;
}

.PR-right {
    width: 100%;
    padding: 0;
    margin: 0;
    text-align: right;
    padding-top: 5px;
}

@media (max-width: 992px) {
    .PR-col {
        font-size: 95%;
    }
}

@media (max-width: 600px) {
    .PR-col {
        font-size: 90%;
    }
}

/* Webshop artikel uitlijning */
.WS-art-box {
    flex-direction: column;
}

.WS-art-cont-top {
    align-self: flex-start;
}

.WS-art-cont-dwn {
    align-self: flex-end;
    margin-top: auto;
}

/* Webshop winkelwagen grid */
.WS-grid {
    display: grid;
    grid-template-columns: min-content auto min-content min-content;
    grid-auto-rows: 1fr;
    column-gap: 16px;
    row-gap: 2px;
    grid-template-rows: auto;
    grid-auto-rows: auto;
}

.WS-grid-ttl {
    display: grid;
    grid-template-columns: min-content auto;
    grid-auto-rows: 1fr;
    column-gap: 16px;
    row-gap: 2px;
    grid-template-rows: auto;
    grid-auto-rows: auto;
}

.WS-grid-pers {
    display: grid;
    grid-template-columns: max-content auto;
    grid-auto-rows: 1fr;
    column-gap: 16px;
    row-gap: 2px;
    grid-template-rows: auto;
    grid-auto-rows: auto;
}

/* Webshop winkelwagen kolommen */
.WS-col {
    display: flex;
    padding: 0 0 2px 0;
    margin: 0px;
    text-decoration: none !important;
    border-width: 0;
    font-size: 90%;
    word-break: normal;
}

.WS-cnt-left {
    width: 100%;
    padding: 0;
    margin: 0;
    text-align: left;
    padding-top: 5px;
}

.WS-cnt-center {
    width: 100%;
    padding: 0;
    margin: 0;
    text-align: center;
    padding-top: 5px;
}

.WS-cnt-right {
    width: 100%;
    padding: 0;
    margin: 0;
    text-align: right;
    padding-top: 5px;
}

@media (max-width: 1000px) {
    .WS-col {
        font-size: 95%;
    }
}

@media (max-width: 600px) {
    .WS-col {
        font-size: 90%;
    }
}

/* Voorkom tekstafbreking in artikeloverzicht (eerste kolom) */
.WS-grid .WS-col:first-child .WS-cnt-center,
.WS-grid .WS-cnt-right {
    white-space: nowrap;
    word-break: keep-all;
    overflow-wrap: normal;
    hyphens: none;
    text-wrap: nowrap;
}

/* Voorkom tekstafbreking in betalingsoverzicht */
.WS-grid-ttl .WS-cnt-left,
.WS-grid-ttl .WS-cnt-right {
    white-space: nowrap;
    word-break: keep-all;
    overflow-wrap: normal;
    hyphens: none;
    text-wrap: nowrap;
}

.WS-action-row {
    padding: 0 0 2px 0;
    margin: 0px;
    font-size: 90%;
    font-style: italic;
    text-align: left;
}

@media (max-width: 768px) {
    .WS-action-row {
        font-size: 80%;
    }
}

/* Webshop Pop-up */
.overlay {
    position: fixed;
    z-index: 9993;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background: rgba(0, 0, 0, 0.7);
    transition: opacity 500ms;
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
}
.overlay:target {
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
}

.popup {
    margin: 15px auto;
    padding: 20px;
    color: var(--cfg01);
    background-color: var(--cbg01);
    border-width: 1px;
    border-style: solid;
    border-radius: var(--brd);
    border-color: var(--cmn01);
    width: 40%;
    position: relative;
    z-index: 9995;
    transition: all 0.5s ease-in-out;
    max-height: 95%;
    overflow: auto;
    letter-spacing: -0.01em;
    word-spacing: -1px;
    contain: layout style;
    content-visibility: auto;
    min-height: 400px;
}

.popup h2 {
    margin-top: 0;
}

.popup .close {
    position: absolute;
    top: 10px;
    right: 10px;
    padding: 10px;
    transition: all 400ms;
    font-size: 200%;
    font-weight: bold;
    text-decoration: none;
    color: var(--cfg01);
    cursor: pointer;
    background: transparent;
    border: none;
}
.popup .close:hover {
    font-size: 250%;
}

.popup ul {
    list-style-type: circle;
    padding-left: 10px;
    margin-left: 5px;
    text-align: left;
}

.popup img {
    z-index: 9996;
}

@media (max-width: 1200px){
    .popup{
        width: 70%;
        font-size: 95%;
    }
    .popup img {
        max-width: 75%;
        max-height: 75%;
    }
}

@media (max-width: 900px){
    .popup{
        margin: 10px auto;
        width: 85%;
        font-size: 90%;
    }
    .popup .close {
        top: 0px;
        right: 0px;
    }
}

@media (max-width: 768px) {
    .popup {
        margin: 5px auto;
        padding: 15px;
        letter-spacing: -0.02em;
        min-height: auto;
    }
}

/* Activiteitenkalender knop of tekst */
.cal-button, .cal-button:link, .cal-button:visited {
    display: block;
    width: 100%;
    padding: 0;
    margin: 0;
    text-align: left;
    line-height: 1.75;
}

@media (max-width: 1200px) {
    .cal-button, .cal-button:link, .cal-button:visited {
        font-size: 90%;
    }
}

@media (max-width: 992px) {
    .cal-button, .cal-button:link, .cal-button:visited {
        font-size: 80%;
        word-spacing: -1px;
    }
}

@media (max-width: 768px) {
    .cal-button, .cal-button:link, .cal-button:visited {
        display: block;
        width: 100%;
        margin-top: 5px;
        margin-bottom: 10px;
        overflow: hidden;
        padding: 5px;
        border-width: 2px;
        border-style: solid;
        border-color: var(--cmn01);
        border-radius: var(--brd);
        background-color: var(--cbg01);
        color: var(--cfg01);
        text-align: center;
        font-weight: 600;
        text-decoration: none !important;
        line-height: 1.45;
        font-size: 100%;
    }
}

@media (max-width: 600px) {
    .cal-button, .cal-button:link, .cal-button:visited {
        word-spacing: -2px;
    }
}

/* Voettekst */

.footer {
    font-size: 90%;
    padding: 0 var(--brd) 10px var(--brd);
    text-align: center;
    content-visibility: auto;
    min-height: 150px;
}

@media (max-width: 768px) {
    .footer {
        font-size: 80%;
    }
}

/*--------------------------------------------------------------------------------------------*\
# Screenreaders
*\--------------------------------------------------------------------------------------------*/

/* Alleen voor screenreaders, onzichtbaar voor visuele gebruikers */
.screen-reader-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* Voor als je de focus zichtbaar wilt maken voor toetsenbordgebruikers */
.screen-reader-only:focus {
    position: static;
    width: auto;
    height: auto;
    margin: 0;
    overflow: visible;
    clip: auto;
    white-space: normal;
}

/*--------------------------------------------------------------------------------------------*\
# Algemeen
*\--------------------------------------------------------------------------------------------*/

a {
	color: var(--cfg01);
    text-decoration: none;
}

b{
    font-weight: 600;
}

/* Ruimte tussen alinea's */
p {
    margin-bottom: 1em;
    margin-top: 0;
}

/* Geen marge onder een paragraaf die direct wordt gevolgd door een lijst */

p:has(+ ul) {
    margin-bottom: 6px;
}

/* Maar niet na de laatste alinea in een blok */
p:last-of-type {
    margin-bottom: 0;
}

/* Headers */
header {
    position: relative;
}

/*  de header_h1 en header_2 zijn de naam en ondertitel voor de website */
.header_h1, .header_h1 a:link, .header_h1 a:visited, .header_h1 a:hover, .header_h1 a:visited:hover, .header_h1 a:active {
    font-family: Basic, Georgia, Trebuchet MS, Arial, Helvetica Neue, Helvetica, sans-serif;
    font-size : 150%;
    text-decoration : none;
    font-weight : 700;
    color : var(--cmn01);
}

.header_h2 {
    font-family: Courgette, Georgia, Trebuchet MS, Arial, Helvetica Neue, Helvetica, sans-serif;
    font-size : 95%;
    font-weight: normal;
    color: var(--cfg04);
    padding: 10px 50px 0 0;
}

@media (min-width: 768px) {
    .header_h1 {
        margin-right: 10px;
        font-size : 175%;
    }
    .header_h2 {
        font-size: 120%;
    }
    .header_h1, .header_h2 {
        display: inline-block;
    }
}

h1 {
    font-size: 110%;
    font-weight: 650;
    color: var(--cmn01);
    padding-bottom: 10px;
    text-align: left;
}

h1::before {
    content: "";
    height: 4px;
    width: 4px;
    background-color: var(--cmn01);
    border-radius: 50%;
    display: inline-block;
    margin-bottom: 4px;
    margin-right: 4px;
}

h2, h3 {
    font-size: 105%;
    font-weight: 600;
    color: var(--cmn01);
    padding-bottom: 10px;
    text-align: left;
}

h4 {
    font-size: 100%;
    font-weight: 575;
    color: var(--cmn01);
    text-align: left;
}

/* Alle H2 in een col-box met meer dan 2 boxes worden gecentreerd */
.grid-3col .grid-col-box .grid-content h2,
.grid-4col .grid-col-box .grid-content h2,
.grid-5col .grid-col-box .grid-content h2,
.grid-6col .grid-col-box .grid-content h2,
.grid-content-center h2, .grid-content-center h3, .grid-content-center h4 {
    text-align: center;
    line-height: 1.3;
    padding-bottom: 0;
}



/* Alleen voor headings */
h1, h2, h3, h4 {
    text-wrap: balance;
}

/* de seo_ classes zijn buiten beeld geplaatst maar wel leesbaar door zoekmachines en AI */
.seo_header,
.seo_navigation {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.bigger {
    font-size: 110%;
    font-weight: 500;
}

.italic {
    font-style: italic;
}

input,
select {
    border: 1px solid var(--cfg02);
    border-radius: var(--brd);
    padding: 5px;
    background-color: var(--cbg02);
    color: var(--cfg01);
}

input:focus,
select:focus {
    border-style: inset;
    outline: none;
}

input:focus-visible,
select:focus-visible {
    border-style: inset;
    outline-style: auto;
    outline: 2px solid;
    outline-offset: -2px;
}

a:focus-visible,
.button:focus-visible,
.cal-button:focus-visible,
.but-dark-mode:focus-visible,
.button-inl:focus-visible,
.popup .close:focus-visible {
    outline: 2px solid var(--cmn01);
    outline-offset: 2px;
}

/* Verberg invoer pijltoetsen: Chrome, Safari, Edge, Opera */
input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* Verberg invoer pijltoetsen: Firefox */
input[type=number] {
  -moz-appearance: textfield;
}

/* Om informatie op schermen te verbergen */
@media (min-width: 768px) {
    .hide1 {
        display: none;
    }
}
@media (max-width: 768px) {
    .hide2 {
        display: none;
    }
}

.button, .button:link, .button:visited {
    display: block;
    max-width: 350px;
    margin-left: auto;
    margin-right: auto;
    margin-top: 20px;
    margin-bottom: 20px;
    overflow: hidden;
    padding: 10px;
    border-width: 2px;
    border-style: solid;
    border-color: var(--cmn01);
    border-radius: var(--brd);
    background-color: var(--cbg01);
    color: var(--cfg01);
    text-align: center;
    font-weight: 600;
    line-height: 125%;
    text-decoration: none !important;
}

.button-del, .button-del:link, .button-del:visited {
    display: inline-block;
    width: 20px;
    height: 20px;
    background: url(/images/delete-button.avif);
    background-repeat: no-repeat;
    background-size: contain;
    cursor: pointer;
    border: 0;
}

.button-inl, .button-inl:link, .button-inl:visited {
    display: inline-block;
    max-width: 350px;
    margin-left: auto;
    margin-right: auto;
    margin-top: 10px;
    margin-bottom: 10px;
    overflow: hidden;
    padding: 10px;
    border-width: 2px;
    border-style: solid;
    border-color: var(--cmn01);
    border-radius: var(--brd);
    background-color: var(--cbg01);
    color: var(--cfg01);
    text-align: center;
    font-weight: 600;
    line-height: 125%;
    text-decoration: none !important;
}

.button:hover, .button:visited:hover, .button:active,
.button-inl:hover, .button-inl:visited:hover, .button-inl:active {
    box-shadow: 5px 10px 18px var(--cfg02);
}

.button-del:hover, .button-del:visited:hover, .button-del:active {
    filter: brightness(1.25);
}

/* Header buttons (zoekicoon en dark-mode) */
.header-buttons {
    position: absolute;
    top: 10px;
    right: 10px;
    display: flex;
    gap: 10px;
    align-items: center;
    z-index: 10;
}

@media (max-width: 960px) {
    .header-buttons {
        top: 8px;
        right: 8px;
        gap: 8px;
    }
}

.but-dark-mode, .but-dark-mode:link, .but-dark-mode:visited {
    display: inline-block;
    overflow: auto;
    width: 20px;
    height: 20px;
    cursor: pointer;
    position: static;
    float: none;
    margin: 0;
    background: url(/images/dark-light-button.avif);
    background-repeat: no-repeat;
    background-position: 0px 0px;
    border-width: 1px;
    border-style: solid;
    border-color: var(--cfg05);
    border-radius: 4px;
}

.search-icon, .search-icon:link, .search-icon:visited {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    font-size: 1.1rem;
    text-decoration: none;
    color: var(--cmn01);
    background: transparent;
    border: 1px solid var(--cfg05);
    border-radius: 4px;
}

@media (max-width: 960px) {
    .but-dark-mode, .but-dark-mode:link, .but-dark-mode:visited, .search-icon, .search-icon:link, .search-icon:visited {
        border-radius: 8px;
        width: 16px;
        height: 16px;
        background-position: -3px -3px;
    }
    .search-icon, .search-icon:link, .search-icon:visited {
        border: 0px;
        margin-top: 3px;
        font-size: 1.2rem;
    }
}

.but-dark-mode:hover, .search-icon:hover {
    filter: brightness(1.2);
    transform: scale(1.2);
    transition: transform 0.2s ease;
}

/* .video             = gecentreerde video tag zonder rand        (kosmosofie-fragmenten) */
/* .center            = gecentreerde tekst of wat dan ook                                     */
/* .centerimg         = gecentreerde afbeelding zonder rand       (product foto's etc..)   */
/* .centerimgbordered = gecentreerde afbeelding met rand          (homepage etc..)         */

@keyframes fadeIn {
    0% { opacity: 0; }
    100% { opacity: 1; }
}

.video {
    display: block;
    margin-left: auto;
    margin-right: auto;
    margin-top: 10px;
    margin-bottom: 10px;
    text-align: center;
    border-radius: var(--brd);
    animation: fadeIn 1s;
    width: 100%;
    height: auto;
}

.center,
.centerimg,
.centerimgbordered {
    display: block;
    margin-left: auto;
    margin-right: auto;
    margin-top: 10px;
    margin-bottom: 10px;
    text-align: center;
    border-radius: var(--brd);
    animation: fadeIn 1s;
}

.centerimgbordered {
    box-shadow: 0px 0px 26px -20px var(--cfg05);
}

.centerimgbordered:hover {
    box-shadow: 5px 10px 18px var(--cfg02);
}

@media (min-width: 768px) {
    .centerimg,
    .centerimgbordered {
        transition: transform .2s;
        will-change: transform;
    }

    .centerimg:hover {
        transform: scale(1.5);
        transition-delay: 1.0s;
        box-shadow: 5px 10px 18px var(--cfg02);
    }
}

/* Grid afbeeldingen */
.centerimggrid {
    display: block;
    width: 100%;
    max-width: 350px;
    height: auto;
    aspect-ratio: 35 / 25;
    object-fit: cover;
    object-position: 50% 15%;
    margin-left: auto;
    margin-right: auto;
    margin-top: 10px;
    margin-bottom: 10px;
    border-radius: var(--brd);
    animation: fadeIn 1s;
    box-shadow: 0px 0px 26px -20px var(--cfg05);
}

.centerimggrid:hover {
    box-shadow: 5px 10px 18px var(--cfg02);
}

@media (min-width: 768px) {
    .centerimggrid {
        transition: transform .2s, box-shadow .2s;
        will-change: transform;
        aspect-ratio: 35 / 30;
        object-fit: cover;
        object-position: 50% 0%;  
    }

    .centerimggrid:hover {
        transform: scale(1.5);
        transition-delay: 1.0s;
        box-shadow: 5px 10px 18px var(--cfg02);
    }
}

.leftimg,
.align-left {
    float : left;
    margin : 5px 10px 5px 0;
    border-radius: var(--brd);
}

.rightimg,
.align-right {
    float : right;
    margin : 5px 0 5px 10px;
    border-radius: var(--brd);
}

/* Op kleine schermen zijn de linker en rechter afbeeldingen in het midden uitgelijnd */
@media (max-width: 900px) {
    .leftimg,
    .rightimg {
        float: none;
        display: block;
        margin-left: auto;
        margin-right: auto;
        margin-top: 15px;
        margin-bottom: 15px;
        text-align: center;
        border-radius: var(--brd);
    }
}

/* Winkelmand afbeelding in webshop knoppen */
.ws-basket-img {
    float: left;
    margin : 0 -1px 0 0;
    vertical-align: middle;
    height: 21px;
    width: 21px;
}

/* Groene en rode tekst voor fouten of accenten */
.green {
    color: var(--cec02);
    font-weight: 600;
}

.red {
    color: var(--cec01);
    font-weight: 600;
}

/* De punt gebruikt voor H3 */

.dot {
    height: 5px;
    width: 5px;
    background-color: var(--cmn01);
    border-radius: 50%;
    display: inline-block;
    margin-bottom: 4px;
    margin-right: 4px;
}

/* Externe link met pictogram */
.extlink {
    background: url('/images/icon-external-link.avif') no-repeat 100% 0;
    background-size: 16px 16px;
    padding-right: 18px;
}

/* Interne link met pictogram */
.intlink {
    background: url('/images/icon-internal-link.avif') no-repeat 100% 0;
    background-size: 16px 16px;
    padding-right: 18px;
}

/* De "lees meer" functionaliteit */

#readmore {
    display: none;
}

.readmore-button {
    display: none;
}

@media (max-width: 768px) {
    .hidden {
        display: none;
    }

    .readmore-button {
        margin-top: -10px;
        margin-bottom: 10px;
        margin-left: 6px;
        background-color: var(--cbg02);
        display: block;
    }

    #readmore ~ .readmore-button:before {
        font-weight: 800;
        content: 'Lees meer...';
    }

	#readmore:checked ~ .hidden {
        margin-top: 0px;
        margin-bottom: 0px;
        display: inline;
    }

    #readmore:checked ~ .readmore-button {
        display: none;
    }
}

/* Toon op mobiel of niet (social media knoppen) */
@media (max-width: 900px) {
    .mobile {
        display: block;
    }
    .desktop {
        display: none !important;
        margin: 0 !important;
        width: 0 !important;
        height: 0 !important;
        padding: 0 !important;
    }
}
@media (min-width: 900px) {
    .mobile {
        display: none !important;
        margin: 0 !important;
        width: 0 !important;
        height: 0 !important;
        padding: 0 !important;
    }
    .desktop {
        display: block;
    }
}

/* Horizontale scheiding tussen twee delen tekst */

.divider
{
	position: relative;
	margin-top: 25px;
    margin-bottom: 25px;
	height: 3px;
}

.div-transparent:before
{
	content: "";
	position: absolute;
	top: 0;
	left: 20%;
	right: 20%;
	width: 60%;
	height: 3px;
	background-image: linear-gradient(to right, transparent, var(--cfg02), transparent);
}

/*--------------------------------------------------------------------------------------------*\
# FAQ Styles
*\--------------------------------------------------------------------------------------------*/

/* FAQ Container voor productpagina's */
.faq-container {
    margin: -12px -6px 4px -6px;
    border: 0;
    background-color: var(--cbg02);
    padding: 10px 10px 0px 10px;
}

/* De gecentreerde button */
.faq-toggle-all {
    cursor: pointer;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    margin-top: 0;
    margin-bottom: 15px;
}

/* FAQ inhoud (standaard verborgen) */
.faq-content {
    margin-top: 15px;
    text-align: left;
}

/* Individueel FAQ item */
.faq-item {
    margin-bottom: 10px;
    border: 1px solid var(--cfg02);
    border-radius: var(--brd);
    background-color: var(--cbg01);
    overflow: hidden;
    contain: layout style;
}

/* Wrapper om het hele item klikbaar te maken */
.faq-item-wrapper {
    display: block;
    cursor: pointer;
    width: 100%;
}

/* De checkbox voor de toggle - verborgen */
.faq-item-toggle {
    display: none;
}

/* De vraag - geen border als standaard */
.faq-question {
    display: block;
    padding: 10px 20px;
    margin: 0;
    font-weight: 600;
    color: var(--cfg01);
    background-color: var(--cbg02);
    position: relative;
    transition: background-color 0.2s ease;
    width: 100%;
    box-sizing: border-box;
    border-bottom: none;  /* Geen border in dichtgeklapte staat */
}

/* Hover effect op hele wrapper */
.faq-item-wrapper:hover {
    background-color: var(--cbg03);
}
.faq-item-wrapper:hover .faq-question {
    background-color: var(--cbg03);
}

/* Het (+) icoontje voor de vraag */
.faq-question::before {
    content: '+';
    display: inline-block;
    font-size: 1.8rem;
    font-weight: 400;
    margin-right: 15px;
    line-height: 1;
    color: var(--cmn01);
    vertical-align: middle;
}

/* Het antwoord - standaard verborgen */
.faq-answer {
    max-height: 0;
    padding: 0 20px;
    margin: 0;
    overflow: hidden;
    background-color: var(--cbg01);
    color: var(--cfg01);
    line-height: 1.5;
    transition: max-height 0.2s ease-out, padding 0.2s ease-out;
}

/* Wanneer checkbox is aangevinkt - toon antwoord */
.faq-item-toggle:checked ~ .faq-item-wrapper .faq-answer {
    max-height: 500px; /* Genoeg voor lange antwoorden */
    padding: 10px 20px 20px 20px;
}

/* Wanneer checkbox is aangevinkt - toon border onder vraag */
.faq-item-toggle:checked ~ .faq-item-wrapper .faq-question {
    border-bottom: 1px solid var(--cfg02);  /* Alleen border bij uitgeklapt */
}

/* Wanneer checkbox is aangevinkt - verander icoon */
.faq-item-toggle:checked ~ .faq-item-wrapper .faq-question::before {
    content: '-';
}

/* Footer link naar FAQ pagina */
.faq-footer-link {
    text-align: center;
    margin: 10px 0 5px 0;
}
.faq-footer-link a {
    color: var(--cmn01);
    font-weight: 600;
    text-decoration: underline;
    text-decoration-color: var(--cfg02);
    text-underline-offset: 4px;
}
.faq-footer-link a:hover {
    text-decoration-color: var(--cmn01);
}

/* Specifiek voor de FAQ-pagina: categorie titels */
.faq-category {
    margin-bottom: 30px;
}
.faq-category h3 {
    font-size: 1.0rem;
    color: var(--cmn01);
    margin-bottom: 15px;
    padding-bottom: 0;
    border-bottom: none;
}
.faq-category .faq-item {
    margin-left: 0;
    margin-right: 0;
}

/* Zorg dat uitlijning gelijk is met rest van teksten */
.faq-question,
.faq-answer {
    text-align: left;
}

/* Voor donkere modus consistentie */
html.dark-mode .faq-container,
html.dark-mode .faq-item,
html.dark-mode .faq-item-wrapper,
html.dark-mode .faq-question,
html.dark-mode .faq-answer {
    background-color: var(--cbg02);
    border-color: var(--cfg02);
}

@media (prefers-color-scheme: dark) {
    .faq-container,
    .faq-item,
    .faq-item-wrapper,
    .faq-question,
    .faq-answer {
        background-color: var(--cbg02);
        border-color: var(--cfg02);
    }
}

/* Voor mobiel: button iets kleiner en beter klikbaar */
@media (max-width: 768px) {
    .faq-toggle-all.button {
        font-size: 0.95rem;
        padding: 8px;
    }

    .faq-question {
        padding: 10px 15px;  /* Iets groter klikgebied op mobiel */
        font-size: 0.9rem;   /* Iets kleinere tekst op mobiel */
    }

    .faq-question::before {
        font-size: 1.6rem;
        margin-right: 12px;
    }

    .faq-answer {
        font-size: 0.9rem;  /* Iets kleinere tekst op mobiel */
    }
}

/*--------------------------------------------------------------------------------------------*\
# Blog Pagina
*\--------------------------------------------------------------------------------------------*/

.blog {
    padding : 0;
    margin-top : -1em;
    margin-bottom : 0;
    margin-left : 0;
    margin-right : 0;
    width : 100%;
    float : left;
    border-radius: var(--brd);
}

.blog .story {
    margin: 20px 0px 0px 0px;
    padding : 0 4px 0 4px;
    border-width: 1px;
    border-style: solid;
    border-color: var(--cfg02);
    border-radius: var(--brd);
    background-color: var(--cbg01);
    contain: layout style;
}

.blog .story:hover,
.blog .story:active {
    background-color: var(--cbg03);
}

.blog b {
    font-weight : 500;
    color : var(--cmn01);
}

.blog a {
    color : var(--cfg01);
    text-decoration: none !important;
    border-radius: var(--brd);
}

/* Blog post metadata (datum en auteur) */
.post-meta {
    font-size: 85%;
    color: var(--cfg05);
    margin: -8px 0 16px 0;
    padding: 0;
    text-align: left;
    font-style: italic;
    letter-spacing: 0.3px;
    border-bottom: 1px solid var(--cfg02);
    display: inline-block;
    padding-bottom: 6px;
}

/* Icoon in post-meta niet cursief */
.post-meta .no-italic {
    font-style: normal;
}

/* Responsive aanpassingen */
@media (max-width: 768px) {
    .post-meta {
        font-size: 80%;
        margin: -5px 0 12px 0;
    }
}

/*--------------------------------------------------------------------------------------------*\
# Getuigenis Pagina
*\--------------------------------------------------------------------------------------------*/

.testimonial blockquote {
    margin: 10px 0 0 0;
    background: var(--cbg03);
    padding: 20px 35px;
    position: relative;
    border: none;
    border-radius: var(--brd);
    font-style: italic;
    contain: layout style;
}

.testimonial blockquote:before,
.testimonial blockquote:after {
    content: "\201C";
    position: absolute;
    font-size: 60px;
    line-height: 1;
    color: var(--cfg01);
    font-style: normal;
}

.testimonial blockquote:before {
    top: 0;
    left: 10px;
}

.testimonial blockquote:after {
    content: "\201D";
    right: 10px;
    bottom: -0.5em;
}

.testimonial div {
    width: 0;
    height: 0;
    border-left: 0 solid transparent;
    border-right: 20px solid transparent;
    border-top: 20px solid var(--cbg03);
    margin: 0 0 0 60px;
}

.testimonial p {
    margin: 4px 0 15px 20px;
    text-align: left;
    color: var(--cfg01);
}

.testimoniallink {
    text-align: left;
}

.testimonial a {
    text-align: center;
    display: block;
    margin: 0 auto;
}

/*--------------------------------------------------------------------------------------------*\
# ABC Kernkaarten
*\--------------------------------------------------------------------------------------------*/

/* "ABC Kernkaarten" afbeelding */
.kkimg {
    display: block;
    margin-left: auto;
    margin-right: auto;
    margin-top: 20px;
    margin-bottom: 20px;
    text-align: center;
    border-width: 4px;
    border-style: solid;
    border-color: var(--cfg02);
    border-radius: 40px;
    contain: layout style;
}

@media (min-width: 768px) {
    .kkimg {
        transition: transform .2s;
        will-change: transform;
    }

    .kkimg:hover {
        transform: scale(1.5);
        transition-delay:1.0s;
        border-color: var(--cfg02);
        box-shadow: 5px 10px 18px var(--cfg02);
    }
}

/* "ABC Kernkaarten" tekst */
.kktxt {
    display: block;
    margin-left: auto;
    margin-right: auto;
    max-width: 700px;
    margin-bottom: 20px;
    text-align: justify;
    hyphens: auto;
    font-style: italic;
}

/*--------------------------------------------------------------------------------------------*\
# Formulieren
*\--------------------------------------------------------------------------------------------*/

.contactform {
    box-sizing: border-box;
    width: 100%;
}

.WS-form {
    box-sizing: border-box;
    display:block;
}

.WS-form-artqty {
    width:4em;
    text-align: center;
    font-weight: 600;
    line-height: 125%;
    padding: 10px;
    text-decoration: none !important;
}

.WS-top-row {
    line-height: 150%;
    padding-top: 10px;
    padding-bottom: 10px;
    font-weight: 600;
}

.captcha {
    display: inline;
    width: 90px;
    height: 28px;
    margin-bottom: -8px;
}

.captchaform {
    text-align: center;
}

.fout {
    color : var(--cec01);
    font-weight : 500;
    font-size : 90%;
}

/*--------------------------------------------------------------------------------------------*\
# Navigatie
# ivm automatische menu opbouw .dd1 t/m .dd15 gedefinieerd,
# worden waarschijnlijk niet allemaal gebruikt ahv hoeveel menu items gegenereerd worden
*\--------------------------------------------------------------------------------------------*/

nav, nav ul {
    padding : 0;
    margin : 0;
    width : 100%;
    float : left;
    border-radius: var(--brd);
}

nav ul {
    margin: 0;
    padding: 0 10px 0 10px;
    background : var(--cbg01);
    list-style : none;
    border-radius: var(--brd);
}

nav ul li:first-child {
    margin-left: -5px;
}

nav li {
    float : left;
    text-align : left;
    border-radius: var(--brd);
}

nav a {
    cursor : pointer;
    display : block;
    outline : 0;
    text-decoration : none;
    margin : 0;
    padding : var(--brd);
    border : 0;
    text-decoration : none;
    border-radius: var(--brd);
}

@media (min-width : 1200px) {
    nav a{
        font-size:105%;
    }
}

nav a:link, nav a:visited {
    color : var(--cmn01);
    background : var(--cbg01);
    text-decoration : none;
    border-radius: 0px 0px var(--brd) var(--brd);
}

nav a:hover, nav a:visited:hover, nav a:active {
    color : var(--cmn01);
    background : var(--cmn02);
    text-decoration : none;
    border-radius: var(--brd);
}

nav [type="checkbox"], label {
    display : none;
    border-radius: 0px 0px calc(var(--brd)/2) calc(var(--brd)/2);
}

.dd1, .dd2, .dd3, .dd4, .dd5, .dd6, .dd7, .dd8, .dd9, .dd10, .dd11, .dd12, .dd13, .dd14, .dd15 {
    position: relative;
}

.dropdown {
    position: absolute;
    display: none;
    width: 200px;
    background : var(--cbg01);
    border-width: 1px;
    border-style: solid;
    border-color: var(--cmn02);
    border-radius: var(--brd);
    margin: 0 0 0 20px;
    padding: 0;
    z-index : 9999;
}

.dd1:hover .dropdown, .dd2:hover .dropdown, .dd3:hover .dropdown, .dd4:hover .dropdown, .dd5:hover .dropdown, .dd6:hover .dropdown, .dd7:hover .dropdown, .dd8:hover .dropdown, .dd9:hover .dropdown, .dd10:hover .dropdown, .dd11:hover .dropdown, .dd12:hover .dropdown, .dd13:hover .dropdown, .dd14:hover .dropdown, .dd15:hover .dropdown {
    display: block;
}

.dropdown li {
    padding: 0;
    margin: 2px !important;
    text-align: left;
    width: 194px;
}

/* kleine media */
@media (max-width: 960px) {
    nav ul, nav ul li {
        display : none;
    }
    nav label {
        display : block;
        background : var(--cbg01);
        width : 45px;
        height : 32px;
        cursor : pointer;
        z-index : 6666;
        float : right;
        position : relative;
        margin-right: 5px;
    }
    nav label:after {
        content : '';
        display : block;
        width : 40px;
        height : 6px;
        background : var(--cmn01);
        margin : 5px 2px 0 0px;
        box-shadow : 0 11px 0 var(--cmn01), 0 22px 0 var(--cmn01);
    }
    nav {
        margin-top : -30px;
    }
    nav [type="checkbox"]:checked ~ ul {
        display : block;
        z-index : 6666;
        float : right;
        padding-top: 5px;
    }
    nav [type="checkbox"]:checked ~ ul li {
        display : block;
        float : none;
        width : 100%;
        text-align : left;
        padding : 0;
        margin : 0;
        border-bottom : 1px solid var(--cfg02);
        border-radius: 0px;
    }
    nav a {
        padding : 10px 10px 10px 10px;
    }
    .dd1:hover .dropdown, .dd2:hover .dropdown, .dd3:hover .dropdown, .dd4:hover .dropdown, .dd5:hover .dropdown, .dd6:hover .dropdown, .dd7:hover .dropdown, .dd8:hover .dropdown, .dd9:hover .dropdown, .dd10:hover .dropdown, .dd11:hover .dropdown, .dd12:hover .dropdown, .dd13:hover .dropdown, .dd14:hover .dropdown, .dd15:hover .dropdown {
        display: none;
    }
}

/* wanneer de h2 onder de h1 staat kunnen we de navigatieknop iets naar boven verplaatsen */
@media (max-width: 768px) {
    nav {
        margin-top: -45px;
    }
    nav label {
        margin-bottom: 0px;
    }
    nav [type="checkbox"]:checked ~ ul {
        position: relative;
        top: 10px;
    }
}


/*--------------------------------------------------------------------------------------------*\
# Getuigenis slider op home pagina
*\--------------------------------------------------------------------------------------------*/

.grid-content-carrousel {
    width: 100%;
    padding: 0;
    margin: 0;
    text-align: center;
}
.carrousel {
    text-align: center;
    max-width: 100%;
    margin: auto;
    position: relative;
    overflow: hidden;
}
.carrousel .slides {
    width: calc(100% * var(--slq));
    padding: 0;
    margin: 0;
    overflow: hidden;
    list-style: none;
    position: relative;
    transition: transform 1s;
    will-change: transform;
}
.carrousel .slides li {
    width: calc(100% / var(--slq));
    position: relative;
    float: left;
    padding: 8px 18px 18px 18px;
    content-visibility: auto;
    min-height: 200px;
}

.carrousel li q {
    display: inline-block;
    max-width: 100%;
    margin: auto;
    padding: 0;
    color: var(--cfg05);
    text-align: justify;
    hyphens: auto;
    font-style: italic;
    text-shadow: none;
    text-decoration: none;
}

@media (min-width: 768px) {
    .carrousel .slides {
        width: calc(100% * var(--slq) / 2);
    }
}
@media (min-width: 1200px) {
    .carrousel .slides {
        width: calc(100% * var(--slq) / 3);
    }
}

/* Stijlen voor auteursnaam */
.carrousel li span.author {
    margin-top:0.5em;
    display: block;
}

/* Slide navigatie */
.carrousel .slidesNavigation {
    display: block;
    margin-top: 1em;
    list-style: none;
    text-align: center;
    bottom: 1em;
    position: absolute;
    width: calc(58px * var(--slq));
    left: 50%;
    margin-left: calc(-58px * var(--slq) / 2);
}
.carrousel input {
    display: none;
}
.carrousel .slidesNavigation label {
    float: left;
    margin-left: 18px;
    margin-right: 18px;
    margin-top: 0;
    margin-bottom: 0;
    display: block;
    height: 18px;
    width: 18px;
    border-radius: 50%;
    border: solid 2px var(--cfg02);
    font-size: 0;
}

/* Dit moet herhaald worden met elke slide. */
#radio-1:checked ~ .slides {
    transform: translateX(0%);
}
#radio-2:checked ~ .slides {
    transform: translateX(calc(-100% / var(--slq)));
}
#radio-3:checked ~ .slides {
    transform: translateX(calc(-100% / var(--slq) * 2));
}
#radio-4:checked ~ .slides {
    transform: translateX(calc(-100% / var(--slq) * 3));
}
#radio-5:checked ~ .slides {
    transform: translateX(calc(-100% / var(--slq) * 4));
}
.carrousel .slidesNavigation label:hover {
   cursor: pointer;
}

/* Dit moet herhaald worden met elke slide/punt */
.carrousel #radio-1:checked ~ .slidesNavigation label#dotForRadio-1,
.carrousel #radio-2:checked ~ .slidesNavigation label#dotForRadio-2,
.carrousel #radio-3:checked ~ .slidesNavigation label#dotForRadio-3,
.carrousel #radio-4:checked ~ .slidesNavigation label#dotForRadio-4,
.carrousel #radio-5:checked ~ .slidesNavigation label#dotForRadio-5 {
    background: var(--cmn01);
}

/* Verwijder de navigatie op grote schermen omdat alles getoond wordt */
@media (min-width: 1200px) {
    .carrousel .slidesNavigation {
        display: none;
    }
}

/*--------------------------------------------------------------------------------------------*\
# Lightbox afbeelding zoom
*\--------------------------------------------------------------------------------------------*/

/* (A) LIGHTBOX ACHTERGROND */
#lightbox {
    z-index: 9997;

    /* (A1) BEDEKT VOLLEDIG SCHERM */
    position: fixed;
    top: 0; left: 0;
    width: 100vw; height: 100vh;

    /* (A2) ACHTERGROND */
    background: rgba(0, 0, 0, 0.5);

    /* (A3) CENTREER AFBEELDING OP SCHERM */
    display: flex;
    align-items: center;

    /* (A4) STANDAARD VERBORGEN */
    visibility: hidden;
    opacity: 0;

    /* (A5) TOON/VERBERG ANIMATIE */
    transition: opacity 0.5s ease;
    will-change: opacity;
    content-visibility: auto;
    min-width: 100vw;
    min-height: 100vh;
}

/* Reduced motion voor lightbox */
@media (prefers-reduced-motion: reduce) {
    #lightbox {
        transition: none;
    }
}

/* (A6) ZICHTBAARHEID SCHAKELEN */
#lightbox.show {
    visibility: visible;
    opacity: 1;
}

/* (B) LIGHTBOX AFBEELDING */
#lightbox img {
    /* (B1) AFMETINGEN */
    width: 100%;
    height: 100%;
    z-index: 9998;

    /* (B2) AFBEELDING PASSEND MAKEN */
    /* contain | cover | fill | scale-down */
    object-fit: scale-down;
}

/*--------------------------------------------------------------------------------------------*\
# Terug naar boven knop
*\--------------------------------------------------------------------------------------------*/

#scrollToTop {
    visibility: hidden;
    position: fixed;
    bottom: 10px;
    right: 20px;
    z-index: 9992;
    font-size: 18px;
    border: none;
    outline: none;
    color: white;
    background-color: transparent;
    cursor: pointer;
    padding: 5px;
    border-radius: 27px;
    content-visibility: auto;
    width: 44px;
    height: 44px;
}

@media (hover: hover) and (pointer: fine) {
    #scrollToTop:hover {
        background-color: var(--cmn01);
        opacity: 0.7;
    }
}

#scrollToTop:active {
    background-color: var(--cmn01);
    opacity: 0.7;
}

.scrollToTop {
    width: 44px;
    height: 44px;
    margin: 0;
    padding: 0;
    opacity: 0.8;
}

/*--------------------------------------------------------------------------------------------*\
# Zoekpagina - Stijlen
*\--------------------------------------------------------------------------------------------*/

/* Zoekformulier - blijf horizontaal op alle schermen */
.search-form {
    margin: 20px 0;
    display: flex;
    flex-direction: row;
    gap: 10px;
    flex-wrap: nowrap;
    align-items: center;
}

.search-input {
    flex: 1;
    padding: 12px;
    font-size: 1rem;
    border: 1px solid var(--cfg02);
    border-radius: var(--brd);
    background: var(--cbg02);
    color: var(--cfg01);
    min-width: 0;
}

.search-button {
    margin: 0 !important;
    white-space: nowrap;
    flex-shrink: 0;
}

/* Filter container */
.filter-container {
    margin: 15px 0 20px 0;
    text-align: center;
}

.filter-form {
    display: inline-block;
    background: var(--cbg01);
    padding: 8px 15px;
    border-radius: var(--brd);
    border: 1px solid var(--cfg02);
}

.filter-label {
    font-weight: 600;
    margin-right: 10px;
    color: var(--cfg01);
}

.filter-select {
    padding: 6px 10px;
    border: 1px solid var(--cfg02);
    border-radius: var(--brd);
    background: var(--cbg02);
    color: var(--cfg01);
    cursor: pointer;
}

.filter-select:hover {
    background: var(--cbg03);
}

/* Zoeksecties */
.search-section {
    margin-top: 30px;
}

.search-section h4 {
    margin-bottom: 15px;
    padding-bottom: 5px;
    border-bottom: 1px solid var(--cfg02);
    color: var(--cmn01);
}

/* Clickable resultaten link */
.search-result-link {
    display: block;
    text-decoration: none;
    color: inherit;
    margin-bottom: 10px;
}

.search-result-link:hover {
    text-decoration: none;
}

/* Resultaat item styling */
.search-result-item {
    padding: 15px;
    border: 1px solid var(--cfg02);
    border-radius: var(--brd);
    background: var(--cbg01);
    transition: background 0.2s ease, transform 0.1s ease;
    cursor: pointer;
    text-align: left;
}

.search-result-link:hover .search-result-item {
    background: var(--cbg03);
    transform: translateX(4px);
}

/* Titels in resultaten */
.search-result-item h4 {
    margin-bottom: 8px;
    padding-bottom: 0;
    border-bottom: none;
    color: var(--cmn01);
    text-align: left;
}

/* Beschrijving in resultaten - responsive */
.search-result-desc {
    font-size: 0.9rem;
    line-height: 1.4;
    color: var(--cfg01);
    margin: 6px 0 0 0;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Desktop standaard (768px - 1600px) - 3 regels */
@media (min-width: 769px) and (max-width: 1599px) {
    .search-result-desc {
        -webkit-line-clamp: 3;
    }
}

/* Zeer brede schermen (≥1600px) - 4 regels */
@media (min-width: 1600px) {
    .search-result-desc {
        -webkit-line-clamp: 4;
        font-size: 0.95rem;
        line-height: 1.45;
    }
}

/* Prijs styling */
.search-result-price {
    color: var(--cmn01);
    font-weight: 600;
    margin-bottom: 4px;
    text-align: left;
}

/* Artikelnummer styling */
.search-result-artikel {
    font-size: 0.85rem;
    color: var(--cfg05);
    text-align: left;
}

/* Datum styling voor blogs */
.search-result-date {
    font-size: 0.85rem;
    color: var(--cfg05);
    margin-top: 5px;
    font-style: italic;
    text-align: left;
}

/* Toetsenbord focus styling */
.search-result-link:focus-visible {
    outline: none;
}

.search-result-link:focus-visible .search-result-item {
    outline: 2px solid var(--cmn01);
    outline-offset: 2px;
    background: var(--cbg03);
}

/*--------------------------------------------------------------------------------------------*\
# Zoekpagina - Mobiele optimalisaties
*\--------------------------------------------------------------------------------------------*/

@media (max-width: 768px) {
    /* Zoekformulier blijft horizontaal, alleen kleinere padding */
    .search-input {
        padding: 10px 8px;
        font-size: 0.9rem;
    }

    .search-button {
        padding: 10px 12px;
        font-size: 0.9rem;
    }

    /* Sectie titels */
    .search-section h4 {
        font-size: 1rem;
        margin-bottom: 10px;
        text-align: left;
    }

    /* Resultaat items */
    .search-result-item {
        padding: 12px;
    }

    .search-result-item h4 {
        font-size: 1rem;
        line-height: 1.3;
        margin-bottom: 6px;
    }

    /* Beschrijving op mobiel - 2 regels */
    .search-result-desc {
        font-size: 0.85rem;
        line-height: 1.3;
        -webkit-line-clamp: 2;
    }

    /* Prijs op mobiel */
    .search-result-price {
        font-size: 0.9rem;
    }

    /* Marge tussen resultaten */
    .search-result-link {
        margin-bottom: 8px;
    }

    /* Filter container op mobiel */
    .filter-container {
        display: flex;
        justify-content: center;
        align-items: center;
    }

    .filter-container form {
        width: auto;
        text-align: center;
    }

    .filter-select {
        width: auto;
        min-width: 180px;
    }
}

/* Hele kleine schermen (max 480px) */
@media (max-width: 480px) {
    .search-form {
        gap: 6px;
    }

    .search-input {
        padding: 8px 6px;
        font-size: 0.85rem;
    }

    .search-button {
        padding: 8px 10px;
        font-size: 0.85rem;
    }
}
