:root {
    --v20-neon: #00ff88;
    /* AANGEPAST: Niet meer inktzwart, maar 'Gunmetal' grijs */
    --v20-dark: #16181d; 
    /* AANGEPAST: Cards lichter voor contrast */
    --v20-card-bg: #212429; 
    --v20-text: #e0e0e0;
    /* NIEUW: Een randkleur variabele voor definitie */
    --v20-border: rgba(255,255,255,0.08);
    --bs-body-bg: var(--v20-dark);
    --bs-body-color: var(--v20-text);
 --bg-dark-1:#0e1116;
--bg-dark-2:#131824;
--card-bg:#161c2d;
--card-border:rgba(255,255,255,.06);
--text-main:#e6e8ee;
--text-soft:#a9b0c2;
--accent:#4da3ff;   
    
}

/* --- 1. DE TRUC VOOR DE FOOTER (Sticky Footer) --- */
html, body {
    height: 100%; 
    margin: 0;
    padding: 0;
    font-family: 'Inter', sans-serif;
    background-color: var(--v20-dark);
    color: var(--v20-text);
}

body {
    display: flex;       
    flex-direction: column; 
    min-height: 100vh;   
    overflow-x: hidden;
}
/* Zorg dat het middenstuk alle beschikbare ruimte opslokt */
main.content {
  flex: 1; 
  /* Of: flex-grow: 1; */
}
/* --- NAVBAR --- */
.navbar {
    /* AANGEPAST: Semi-transparant met Blur voor diepte */
    background-color: rgba(22, 24, 29, 0.9) !important; 
    backdrop-filter: blur(10px);
    border-bottom: 1px solid var(--v20-border); /* Subtiele rand */
    flex-shrink: 0; 
    z-index: 9999999;
}
.navbar-brand img { height: 35px; width: auto; }
.navbar-brand { font-weight: 800; font-size: 1.5rem; color: white !important; }
.nav-link { color: rgba(255,255,255,0.7) !important; text-transform: uppercase; font-size: 0.85rem; letter-spacing: 1px; }
.nav-link:hover { color: var(--v20-neon) !important; }

/* --- HERO SPLIT WRAPPER (Het Middenstuk) --- */
.hero-split-wrapper {
    position: relative;
    width: 100%;
    flex: 1 0 auto; 
    display: flex;      
    flex-direction: column; 
    background-color: var(--v20-dark);
}

/* Linker Kant (Afbeelding) */
.hero-left-container {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
    min-height: 400px; 
}

.hero-img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.hero-overlay {
    position: absolute;
    inset: 0;
    /* AANGEPAST: Gradient past nu bij de nieuwe grijze achtergrond */
    background: linear-gradient(to top, rgba(22,24,29,0.95), rgba(22,24,29,0.3));
    z-index: 1;
}

.hero-content {
    position: relative;
    z-index: 2;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 3rem;
}

/* Rechter Kant (Content) */
.hero-right {
    padding: 3rem 2rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 100%;
    /* AANGEPAST: Subtiele gradient zodat het niet plat is */
    background: linear-gradient(180deg, var(--v20-dark) 0%, #0e1013 100%);
}

/* --- CARDS & UI --- */
.v20-side-card {
    background: var(--v20-card-bg);
    border: 1px solid var(--v20-border); /* Rand toegevoegd */
    transition: transform 0.2s;
    margin-bottom: 1rem;
    box-shadow: 0 4px 10px rgba(0,0,0,0.15); /* Schaduw voor diepte */
}
.v20-side-card:hover {
    border-color: var(--v20-neon);
    transform: translateX(-5px);
    background: #2a2e35; /* Lichter bij hover */
}
.price-tag { color: var(--v20-neon); font-family: monospace; font-weight: 700; font-size: 1.1rem; }
.btn-neon { background-color: var(--v20-neon)!important; color: #000!important; font-weight: 700; text-transform: uppercase; border: none; padding: 12px 30px; }

/* --- FOOTER --- */
footer {
    flex-shrink: 0; 
    /* AANGEPAST: Niet #000, maar heel donker grijs */
    background-color: #08090b !important; 
    border-top: 1px solid var(--v20-border);
    width: 100%;
    position: relative;
    z-index: 10;    padding-bottom: 0px !important;
}

.noborder
{
 padding-bottom:0px!important;
    margin-bottom: 0px!important;
}
/* =========================================
   DESKTOP LOGICA (> 1024px)
   ========================================= */
@media (min-width: 1024px) {
    .hero-split-wrapper {
        flex-direction: row; 
    }

    /* Links: 60% Breedte */
    .hero-left {
        width: 60%;
        position: relative; 
        display: block;
    }

    /* Rechts: 40% Breedte */
    .hero-right {
        width: 40%;
        position: relative;
    }
    
    /* Zorg dat de afbeelding container meegroeit met de flexbox */
    .hero-left-container {
        height: 100%;
        position: absolute; 
        min-height: auto; 
    }
}

/* =========================================
   MOBIEL LOGICA (< 1024px)
   ========================================= */

@media screen and (max-width: 768px) {
    /* Target specifiek het article met het schema type */
    article[itemtype="https://schema.org/Article"] {
        padding: 12px;
    }
    .artiekel
    {
        padding:16px;
    }
}
@media (max-width: 1023.98px) {
    /* Plaatje WEG op mobiel */
    .hero-left {
        display: none !important;
    }

    .hero-right {
        width: 100%;
        padding: 2rem 1rem;
    }
    
    /* Navbar logo kleiner */
    .navbar-brand img { height: 30px; }
    
    .offcanvas-body
    {
       border-bottom: 1px solid;
    }
 
  
}

/* Offcanvas Menu */
.offcanvas { background-color: var(--v20-dark); border-right: 1px solid #333; }
.btn-close { filter: invert(1); }
.offcanvas .nav-link { color: white !important; font-size: 1.1rem; margin-bottom: 5px; }

/* --- FOOTER STYLING (Aangepast) --- */
footer {
    background-color: #08090b !important; /* Consistent donkergrijs */
    border-top: 1px solid var(--v20-border) !important;
}

/* De Titels */
.footer-title {
    color: var(--v20-neon); 
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-size: 1.1rem;
    margin-bottom: 1.2rem;
    text-shadow: 0 0 10px rgba(0, 255, 136, 0.3); 
}

/* De Links */
.footer-link {
    color: #9ca3af; /* Iets lichter grijs voor leesbaarheid */
    transition: all 0.3s ease;
    display: inline-block;
    font-size: 0.9rem;
}

.footer-link:hover {
    color: #fff; 
    transform: translateX(5px); 
    text-shadow: 0 0 5px rgba(255,255,255,0.5);
}

/* Het Input Veld */
.input-v20 {
    background-color: #212429 !important; /* Lichter dan achtergrond */
    border: 1px solid var(--v20-border);
    color: #fff !important;
    border-radius: 0; 
    padding: 10px 15px;
}

.input-v20:focus {
    background-color: #2a2e35 !important;
    border-color: var(--v20-neon);
    box-shadow: 0 0 15px rgba(0, 255, 136, 0.2);
}

/* De Knop */
.btn-v20-footer {
    background-color: var(--v20-neon);
    color: #000;
    font-weight: 700;
    text-transform: uppercase;
    border: none;
    border-radius: 0;
    padding: 0 20px;
    transition: 0.3s;
}

.btn-v20-footer:hover {
    background-color: #fff;
    box-shadow: 0 0 15px var(--v20-neon);
}

/* Social Icons */
.social-link i {
    font-size: 1.2rem;
    color: #666;
    transition: 0.3s;
}

.social-link:hover i {
    color: var(--v20-neon);
    transform: scale(1.2);
}

/* --- NIEUWE SECTIE: V20 EXPLAINER --- */

/* De sectie zelf */
.v20-explainer-section {
    position: relative;
    /* AANGEPAST: Contrastkleur, iets donkerder dan body om te breken */
    background-color: #121316; 
    padding: 5rem 0;
    z-index: 5; 
    
    border-top: 2px solid var(--v20-neon);
    box-shadow: 0 -10px 30px rgba(0, 255, 136, 0.15); 
}

/* Helper class voor neon tekst */
.text-neon {
    color: var(--v20-neon) !important;
}
.ls-2 { letter-spacing: 2px; }


/* De kaarten binnen de sectie */
.explainer-card {
    /* AANGEPAST: Lichter grijs ipv transparant */
    background: var(--v20-card-bg); 
    border: 1px solid var(--v20-border); 
    transition: all 0.3s ease;
}

/* Hover effect op de kaarten */
.explainer-card:hover {
    background: #2a2e35;
    border-color: var(--v20-neon); 
    transform: translateY(-10px); 
    box-shadow: 0 10px 30px rgba(0, 255, 136, 0.1); 
}

/* De iconen */
.icon-wrapper {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 80px;
    height: 80px;
    background: rgba(0, 255, 136, 0.1);
    border-radius: 50%; /* Cirkel */
    border: 2px solid rgba(0, 255, 136, 0.3);
    transition: 0.3s;
}

.icon-wrapper i {
    font-size: 2.5rem;
    color: var(--v20-neon);
}

/* Icoon effect bij hover op de kaart */
.explainer-card:hover .icon-wrapper {
    background: var(--v20-neon);
    box-shadow: 0 0 20px var(--v20-neon);
}

.explainer-card:hover .icon-wrapper i {
    color: #000; /* Icoon wordt zwart op neon achtergrond */
}

/* --- NIEUWSTE MODELLEN STYLING --- */
.bg-card-light {
    background-color: #16181d; /* Donkere basis voor foto */
    height: 200px; 
    transition: 0.3s;
}

.model-card {
    background: var(--v20-card-bg); /* Lichter grijs */
    border: 1px solid var(--v20-border);
    transition: all 0.3s ease;
}

.model-card:hover {
    border-color: var(--v20-neon);
    transform: translateY(-5px);
    background: #2a2e35;
}

.model-card:hover .bg-card-light {
    background-color: #000; 
}

.bg-neon {
    background-color: var(--v20-neon) !important;
}

.hover-white:hover {
    color: #fff !important;
}


/* --- BLOG CARDS STYLING --- */
.blog-card {
    background: var(--v20-card-bg);
    border: 1px solid var(--v20-border);
    overflow: hidden; 
    transition: all 0.3s ease;
    position: relative;
    box-shadow: 0 4px 15px rgba(0,0,0,0.2);
}

.blog-img-container {
    height: 240px;
    width: 100%;
    position: relative;
    overflow: hidden;
}

.blog-img-container img {
    transition: transform 0.5s ease;
}

/* Zoom effect op plaatje bij hover */
.blog-card:hover .blog-img-container img {
    transform: scale(1.1);
}

/* Datum blokje */
.blog-date {
    position: absolute;
    top: 15px;
    left: 15px;
    background: rgba(0,0,0,0.8);
    backdrop-filter: blur(5px);
    padding: 8px 12px;
    text-align: center;
    border: 1px solid rgba(255,255,255,0.1);
    border-bottom: 2px solid var(--v20-neon);
}

/* Read more link animatie */
.read-more i {
    transition: 0.3s;
}
.blog-card:hover .read-more i {
    transform: translateX(5px);
}

/* Glow effect om de hele kaart */
.blog-card:hover {
    border-color: rgba(255,255,255,0.2);
    box-shadow: 0 10px 40px rgba(0,0,0,0.5);
}

/* --- GLOBAL RADIUS UPDATE --- */

/* Pas de ronding toe op ALLE kaarten op de site */
.v20-side-card,      
.explainer-card,     
.model-card,         
.blog-card,          
.card {              
    border-radius: 12px !important; 
    overflow: hidden; 
}

.blog-img-container {
    border-radius: 12px 12px 0 0; 
}

.btn, .form-control, .input-v20 {
    border-radius: 8px !important; 
}

.input-v20 {
    border-radius: 8px 0 0 8px !important; 
}
.btn-v20-footer {
    border-radius: 0 8px 8px 0 !important; 
}

.offcanvas-body
{
    overflow: visible!important;
    background: #16181d !important;
}
body{
background: radial-gradient(1200px 600px at 20% -10%, #1b2240 0%, var(--bg-dark-1) 45%),
linear-gradient(180deg, var(--bg-dark-2), var(--bg-dark-1));
color:var(--text-main);
}


.blog-detail{
 max-width: 1400px;
    margin: 0 auto;
    padding: 0 24px;
}


/* Artikel card */
article{    color: #1f2937;background: #f9fafb;border:1px solid var(--card-border);border-radius:20px;padding: 2.5rem 3rem; /* iets minder padding */box-shadow:0 20px 40px rgba(0,0,0,.45);}


/* Titel */
article h1{
letter-spacing:-0.02em;
    color:#000;
}


/* Meta info */
article header .text-muted{
color:var(--text-soft)!important;
}


/* Featured image */
article header img{
border-radius:16px;
box-shadow:0 18px 36px rgba(0,0,0,.5);
}


/* Tekst */
article [itemprop="articleBody"]{color: #565555;}
article [itemprop="articleBody"] p{
margin-bottom:1.4rem;
}

@media (min-width: 1400px) {
    /* Verhoog de standaard container breedte */
    .container, .container-lg, .container-md, .container-sm, .container-xl, .container-xxl {
        max-width: 1400px !important;
    }

    /* Zorg dat de Hero wrapper ook begrensd wordt en gecentreerd blijft */
    .hero-split-wrapper {
        max-width: 1400px;
        margin-left: auto;
        margin-right: auto;
        width: 100%;
    }
}
/* Links in artikel */
article a{
color:var(--accent);
text-decoration:none;
}
.blog-sidebar {
  position: sticky;
  top: 100px;
  background: #212429;
  border-radius: 18px;
  padding: 1.75rem;
  border: 1px solid var(--card-border);
}

.blog-sidebar h6 {
    letter-spacing: 0.05em;
}

.blog-sidebar .v20-side-card {
    background: rgba(255,255,255,0.02);
    transition: transform .15s ease, box-shadow .15s ease;
}

.blog-sidebar .v20-side-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 25px rgba(0,0,0,.3);
}

/* Zorg dat de pointer een handje is */
.filter-color {
    cursor: pointer;
    transition: transform 0.2s, outline 0.2s;
}

/* Als de knop de class 'active' heeft */
.filter-color.active {
    transform: scale(1.1);
    outline: 2px solid #00ff00; /* Fel groen randje */
    outline-offset: 2px;
    box-shadow: 0 0 5px rgba(0,255,0,0.5);
}

.filter-box {
    /* Moderne donkere achtergrond met lichte doorzichtigheid */
    background: rgba(25, 25, 25, 0.7);
    
    /* Het 'Blur' effect voor de glas-look */
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    
    /* Een subtiele rand die niet te hard is */
    border: 1px solid rgba(255, 255, 255, 0.1);
    
    /* Moderne ronde hoeken */
    border-radius: 16px;
    
    /* De padding die je vroeg (iets ruimer voor modernere look) */
    padding: 20px;
    
    /* Diepte creëren */
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.5);
    
    /* Animatie voor de hover */
    transition: all 0.3s ease;
}

/* Hover effect: Maak het 'cool' met een V20-groene gloed */
.filter-box:hover {
    border-color: rgba(40, 167, 69, 0.4); /* Groene rand */
    box-shadow: 0 0 25px rgba(40, 167, 69, 0.15); /* Groene gloed achter de box */
    transform: translateY(-2px); /* Komt ietsje naar voren */
}

/* Zorg dat de titel er strak uitspringt */
.filter-box h4 {
    font-weight: 700;
    letter-spacing: 0.5px;
    border-bottom: 1px solid rgba(255,255,255,0.1);
    padding-bottom: 10px;
}

.form-check-input:checked
{
    background-color: var(--v20-neon) !important;
}

@media screen and (max-width: 768px) {
    /* Side cards layout fix */
    .v20-side-card {
        flex-direction: column !important;
        align-items: flex-start !important;
        height: auto !important;
    }
    .v20-side-card > div:first-child {
        width: 100% !important;
        height: auto !important;
        margin-bottom: 1rem;
    }
    .v20-side-card .ms-3 {
        margin-left: 0 !important;
        width: 100%;
    }
    .v20-side-card .text-end {
        text-align: left !important;
        margin-left: 0 !important;
        margin-top: 0.5rem;
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: 100%;
    }
    .v20-side-card .opacity-50 {
        display: none; 
    }
}

/* --- DE STICKY BUTTON ALLEEN VOOR MOBIEL --- */
@media screen and (max-width: 768px) {
    .btn-checkout {
       /* position: fixed;*/
        position: relative;
        /* bottom: 20px; */
        /* left: 50%; */
        /* transform: translateX(-50%); */
        width: 100% !important;
        z-index: 9999;
        box-shadow: 0 5px 20px rgba(0, 0, 0, 0.5);
    }
    
    /* Ruimte maken onderaan de pagina zodat de knop niet over tekst valt */
    .cart-card {
        margin-bottom: 80px; 
    }
}

/* --- VEILIGHEIDSNET VOOR DESKTOP --- */
/* Dit dwingt de knop terug in de normale flow op schermen breder dan 768px */
@media (min-width: 769px) {
    .btn-checkout {
        position: static !important; /* Reset positie */
        transform: none !important;
        width: 100% !important;
        box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.05) !important; /* De originele shadow */
        bottom: auto !important;
        left: auto !important;
    }
}

#cartToast {
    min-width: auto !important;
    width: calc(100vw - 2rem);
    max-width: 420px;
}

/* Neon Validatie Stijlen */
.newsletter-success {
    color: #00ff88;
    text-shadow: 0 0 10px rgba(0, 255, 136, 0.5);
    border: 1px solid rgba(0, 255, 136, 0.3);
    background: rgba(0, 255, 136, 0.05);
    padding: 8px;
    border-radius: 8px;
    animation: neonPulse 1.5s infinite alternate;
}

.newsletter-error {
    color: #ff4444;
    text-shadow: 0 0 10px rgba(255, 68, 68, 0.5);
    border: 1px solid rgba(255, 68, 68, 0.3);
    background: rgba(255, 68, 68, 0.05);
    padding: 8px;
    border-radius: 8px;
}

@keyframes neonPulse {
    from { box-shadow: 0 0 5px rgba(0, 255, 136, 0.2); }
    to { box-shadow: 0 0 15px rgba(0, 255, 136, 0.4); }
}

/* Zorg dat de input-v20 er ook strak uitziet */
.input-v20 {
    background-color: #1a1a1a !important;
    border: 1px solid #333 !important;
    color: white !important;
}
.input-v20:focus {
    border-color: #00ff88 !important;
    box-shadow: 0 0 10px rgba(0, 255, 136, 0.2) !important;
}