    /* Font Card */
    @font-face{
        font-family:'Lato';
        src:url('../olive_green/Lato-Regular.ttf') format('truetype');
        font-weight:400; font-style:normal;
    }

    @font-face{
        font-family:'Cormorant Italic';
        src:url('../olive_green/cormorant-garamond-italic.ttf') format('truetype');
        font-weight:400; font-style:italic;
    }

    @font-face{
        font-family:'Cormorant';
        src:url('../olive_green/cormorant-garamond-regular.ttf') format('truetype');
        font-weight:400; font-style:normal;
    }
    
    
    :root {
        --color-primary: #46503E;
        --color-text: #3A4135;
        --color-background: #E5E7E2;
        --font-lato: 'Lato', sans-serif;
        --font-cormorant-italic: 'Cormorant Italic', serif;
        --font-cormorant: 'Cormorant', serif;

        --pw-accent: var(--color-primary);
        --pw-ink: var(--color-text);
        --pw-bg: var(--color-background);

        --pw-display: var(--font-cormorant);
        --pw-display-italic: var(--font-cormorant-italic);
        --pw-text: var(--font-lato);
    }

    /* Body Card */
    body {
        margin: 0;
        padding: 0;
        background: white;
        scroll-behavior: smooth;
    }

    /* Multipage: elk kaartblok in <main> */
    main > div[data-card-id] {
        border-top: 1px solid var(--color-primary);
    }

    /* Onepage: kaartblokken binnen sections */
    .section .section-content > div[data-card-id] {
        border-top: 1px solid var(--color-primary);
    }

    /* Geen rand vóór het eerste blok per container */
    main > div[data-card-id]:first-of-type,
    .section .section-content > div[data-card-id]:first-of-type {
        border-top: none;
    }


    /* Header & Navigatie Card */
    nav{
        display: grid;
        grid-template-columns: 1fr auto 1fr; /* links – midden – rechts */
        align-items: center;
    }

    header {
        background: var(--color-background);        
        position: relative;
        z-index: 50;
        padding: 20px;
        border-bottom: 1px solid var(--color-primary);
    }

    .header-container {
        grid-column: 1;
        display: flex;
        align-items: center;
        justify-content: flex-start; /* namen links */
        gap: 12px;
    
    }

    .header-namen {
        position: relative;
        display: inline-block;
        font-size: 50px;
        color: var(--color-primary);
        font-weight: 400;
        font-family: var(--font-cormorant-italic);
        text-align: center;
        text-transform: uppercase;
        background-image: url('../olive_green/header-namen.png');
        background-repeat: no-repeat;
        background-size: 66px 84px;
        background-position: right 0 top 10%;
    }

    .en-teken{
        display: none;
    }

    .nav-toggle {
        font-size: 1.5rem;
        background: none;
        border: none;
        cursor: pointer;
        display: none;
        color: var(--color-primary);
    }

    .nav-toggle {
        --size: 40px;          /* totale klikdoelgrootte */
        --line-w: 40px;        /* breedte van de lijnen */
        --line-h: 2px;         /* dikte van de lijnen (dun) */
        --gap: 6px;            /* tussenruimte tussen de 2 lijnen */
        --color: var(--color-primary);
        position: relative;
        display: none;
        width: var(--size);
        height: var(--size);
        padding: 0;
        border: 0;
        background: transparent;
        cursor: pointer;
        outline-offset: 4px;
    }

    /* Lijnen worden getekend met ::before en ::after */
    .nav-toggle::before,
    .nav-toggle::after {
        content: "";
        position: absolute;
        left: 50%;
        width: var(--line-w);
        height: var(--line-h);
        background: var(--color);
        border-radius: 999px;
        transform-origin: center;
        transform: translateX(-50%);
        transition:
            transform 220ms ease,
            opacity 180ms ease,
            top 220ms ease,
            background-color 220ms ease;
        display: none;
    }

    /* Bovenste lijntje */
    .nav-toggle::before {
        top: calc(50% - (var(--gap) / 2) - var(--line-h));
    }

    /* Onderste lijntje */
    .nav-toggle::after {
        top: calc(50% + (var(--gap) / 2));
    }

    /* Hover/focus: subtiel meer ruimte (niet verplicht) */
    .nav-toggle:hover::before { top: calc(50% - (var(--gap) * 0.7) - var(--line-h)); }
    .nav-toggle:hover::after  { top: calc(50% + (var(--gap) * 0.7)); }

    /* GEOPEND = X (2 lijnen kruisen) */
    .nav-toggle.is-open::before {
        top: 50%;
        transform: translateX(-50%) rotate(45deg);
    }
    .nav-toggle.is-open::after {
        top: 50%;
        transform: translateX(-50%) rotate(-45deg);
    }

    /* Optioneel: verander kleur in open staat */
    .nav-toggle.is-open::before,
    .nav-toggle.is-open::after {
        background-color: var(--color-primary);
    }

    /* Respecteer reduced motion */
    @media (prefers-reduced-motion: reduce) {
        .nav-toggle::before,
        .nav-toggle::after {
            transition: none;
        }
    }

    .nav-menu {
        display: flex;
        justify-content: center;
        list-style: none;
    }
    .nav-menu li {
        margin: 0 10px;
    }
    nav ul li a {
        color: var(--color-text);
        font-size: 15px;
        text-decoration: none;
        padding: 8px 12px;
        border-radius: 4px;
        font-family: var(--font-lato);
        line-height: 28px;
    }

    /* Hero Card */
    .hero-card {
        margin: 0;
        padding: 0;
        background-color: var(--color-background);
        display: flex;
        flex-direction: row-reverse;
        align-items: center;
        justify-content: center;
        
    }

    .hero-overlay{
        width: 50%;
    }

    .hero-card img {
        width: 50%;
        height: 83vh !important;
    }

    .couple-names {
        font-family: var(--font-cormorant-italic, serif);
        font-weight: 400 !important;
        font-size: clamp(40px, 6vw, 72px);
        color: var(--color-primary);
        letter-spacing: 0px !important;
        line-height: 0.9 !important;
        font-size: 75px !important;
    }

    /* Subtitel iets lichter en smaller */
    .hero-title {
        font-family: var(--font-lato, sans-serif);
        font-size: 16px !important;
        color: var(--color-text);
        font-weight: 400;
        max-width: 46ch;
        margin: 10px auto 0;
        line-height: 1.6;
        position: relative;
        padding-bottom: 20px;
    }

    .hero-title::after {
        content: "";
        display: block;
        height: 95px;
        margin: 14px auto 0;
        background: url('../olive_green/hero-decor.png') no-repeat center / contain;
        opacity: 0.95;
    }


    /* Title Card */
    .title-blok-h1{
        color: var(--color-primary);
        font-family: var(--font-cormorant);
        font-size: 50px;
        line-height: 60px;
        font-style: normal;
        font-weight: 400;
        text-align: center;
    }
    .title-blok-h2{
        color: var(--color-primary);
        font-family: var(--font-cormorant);
        font-size: 35px;
        line-height: 45px;
        
        font-style: normal;
        font-weight: 400;
        text-align: center;
    }
    .title-blok-h3{
        color: var(--color-primary);
        font-family: var(--font-cormorant);
        font-size: 24px;
        line-height: 30px;
        
        font-style: normal;
        font-weight: 400;
        text-align: center;
    }

    /* Tekst Card */
    .text-card {
        display: flex;
        justify-content: center;
    }
    .text-card .text-content {
        max-width: 860px;
        font-family: var(--font-lato);
        color: var(--color-text);
        font-size: 17px;
        line-height: 28px;
        letter-spacing: 0%;
        font-weight: 300;
        text-align: center;
        padding: 0;
    }

    /* Titel + tekst blok Card */
    .title-text-section {
        padding-top: 3rem;
        padding-bottom: 3rem;
        text-align: center;
    }
    .title-text-grid {
        display: flex;
        flex-direction: column;
        gap: 1.5rem;
        align-items: center;
        text-align: center;
    }
    
    .title-text-grid h2 {
        color: var(--color-primary);
        font-family: var(--font-cormorant);
        font-size: 35px;
        line-height: 45px;
        font-weight: 400;
        text-align: left;
        margin: 0;
    }
    .title-text-grid .text-content {
        font-family: var(--font-lato);
        color: var(--color-text);
        font-size: 17px;
        line-height: 28px;
        font-weight: 300;
        text-align: left;
        max-width: 100%;
    }

    /* Quote Card */

    [data-card-id].py-6:has(> .quote-card) {
        padding-top: 0;
        padding-bottom: 0;
    }

    .quote-card {
        margin-top: -24px;
        margin-bottom: -24px;
    }
    
    .quote-card {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 24px;
        padding: 125px 0;
        background: var(--color-background);
        margin: 0 !important;
    }

    .quote-img{
        width:100px;
        height:99px;
        background-color: var(--color-primary); /* ← kleur hier aanpassen */
        -webkit-mask: url('../olive_green/quote.svg') no-repeat center / contain;
                mask: url('../olive_green/quote.svg') no-repeat center / contain;
    }

    .quote-text{
        border-left: 1px solid var(--color-primary);
        padding-left: 24px;
        margin-left: 8px;
        max-width: 560px;

    }

    .quote-text blockquote{
        font-size: 27px;
        line-height: 35px !important;
        letter-spacing: 0 !important;
        margin: 0 0 10px 0;
        color: var(--color-primary);
        font-family: var(--font-cormorant);
    }

    .quote-text h2{
        font-family: var(--font-lato);
        font-size: 13px;
        text-transform: uppercase;
        color: var(--color-primary);
        margin: 0;
    }

    /* Grote foto Card */
    .grote-foto {
        width: 100%;
        height: auto;
        padding: 1.5rem 0;
    }

    .grote-foto h2 {
        color: var(--color-primary);
        font-family: var(--font-cormorant);
        font-size: 35px;
        font-style: normal;
        font-weight: 400;
        text-align: center;
    }

    .grote-foto img {
        margin-top: 35px;
        max-width: 1440px;
        margin: 35px auto 0 auto;
    }

    /* Foto tekst Card */

    .image-card {
        margin: 0px !important;
    }

    [data-card-id].py-6:has(> .image-card) {
        padding-top: 0;
        padding-bottom: 0;
    }

    .image-card {
        margin-top: -24px;
        margin-bottom: -24px;
    }

    .foto-tekst{
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 0 !important;
        text-align: center;
        background-color: var(--color-background);
    }
    
    .foto-tekst .image-side img{
        width: 100%;
        height: 550px;
        border-right: 1px solid var(--color-primary);
    }
    .foto-tekst .text-side{
        display: flex;
        flex-direction: column;
        align-self: center;
        justify-content: center;
        gap: 20px;
        padding: 50px 70px;
    }
    .foto-tekst .text-side h2{
        color: var(--color-primary);
        font-family: var(--font-cormorant);
        font-weight: 400;
        font-size: 35px;
        line-height: 38px;
        
        text-align: left;
        max-width: 500px;
    }
    .foto-tekst .text-side .description{
        color: var(--color-text);
        font-family: var(--font-lato);
        font-size: 17px;
        line-height: 28px;
        letter-spacing: 0%;
        font-weight: 300;
        text-align: left;
        max-width: 500px;
    }

    /* Collage Card */

    .collage-layout{
        background-color: var(--color-background);
        padding: 50px 0;
    }

    .collage-grid{
        --tile-ratio: 4 / 5;
        display: grid;
        gap: 16px;
        max-width: 1440px;
        margin: 0 auto;
    }

    .collage-grid{
        grid-template-columns: repeat(3, 1fr);
    }

    .collage-grid .tile{
        position: relative;
        aspect-ratio: var(--tile-ratio);
        overflow: hidden;
       
    }

    .collage-layout h2{
        font-family: var(--font-cormorant);
        color: var(--color-primary);
        font-size: 50px;
        font-weight: 400;
        text-align: center;
        margin-bottom: 40px;
    }

    .collage-grid .tile img{
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center;
        display: block;
    }


    /* Schedule Card */
    .schedule-wrapper {
        position: relative;
        overflow: hidden;
        background-color: var(--color-background);
        margin: 0 !important;
        padding: 25px 0;
    }

    [data-card-id].py-6:has(> .schedule-wrapper) {
        padding-top: 0;
        padding-bottom: 0;
    }

    .schedule-wrapper {
        margin-top: -24px;
        margin-bottom: -24px;
    }

    .schedule-wrapper::before {
        content: '';
        position: absolute;
        top: 0;
        width: 300px;
        height: 300px;
        background: url('../olive_green/side1.png') no-repeat top left;
        background-size: contain;
        z-index: 0;
        pointer-events: none;
    }
    .schedule-wrapper::after {
        content: '';
        position: absolute;
        right: -50px;
        bottom: 0;
        width: 400px;
        height: 500px;
        background: url('../olive_green/side2.png') no-repeat bottom right;
        background-size: contain;
        z-index: 0;
        pointer-events: none;
        transform: rotate(-12deg);
    }
    .schedule-container {
        position: relative;
        z-index: 1;
    }
    .schedule-container {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        max-width: 1440px;
        margin: 0 auto;
        gap: 60px;
    }
    .schedule-heading {
        font-family: var(--font-cormorant);
        font-weight: 400;
        font-size: 50px;
        color: var(--color-primary);
        margin: 0 auto;
        text-transform: capitalize;
    }
    .timeline {
        position: relative;
        width: 100%;
        max-width: 900px;
        margin: 0 auto;
        padding: 0;
        list-style: none;
    }
    .timeline-item {
        position: relative;
        width: 100%;
        display: flex;
        justify-content: flex-start;
        margin: 40px 0;
    }
    .timeline-item:first-child {
        margin-top: 0;
    }
    .timeline-item:last-child {
        margin-bottom: 0;
    }
    .timeline-item::before {
        content: '';
        position: absolute;
        top: 0;
        bottom: -40px;
        left: 50%;
        width: 1px;
        background-color: var(--color-primary);
        transform: translateX(-50%);
        z-index: 0;
    }
    .timeline-item:last-child::before {
        content: none;
    }
    .timeline-item:nth-child(odd) {
        justify-content: flex-end;
    }
    .timeline-dot {
        width: 14px;
        height: 14px;
        background-color: var(--color-primary);
        border-radius: 50%;
        position: absolute;
        left: 50%;
        top: 0;
        transform: translate(-50%, 0);
        z-index: 2;
    }

    .timeline-item::after {
        content: '';
        position: absolute;
        top: 7px;
        height: 1px;
        background-color: var(--color-primary);
        opacity: 0.9;
        z-index: 1;
    }

    .timeline-item:nth-child(even)::after {
        left: calc(50% - 50px);
        width: 50px;
        transform: translateX(0);
    }

    .timeline-item .timeline-dot::after {
        content: '';
        position: absolute;
        top: 3px;
        width: 8px;
        height: 8px;
        background-color: var(--color-primary);
        border-radius: 50%;
    }

    .timeline-item:nth-child(even) .timeline-dot::after { right: 50px; }
    .timeline-item:nth-child(odd)  .timeline-dot::after { left: 50px; }

    .timeline-item:nth-child(odd)::after {
        left: 50%; 
        width: 50px;
    }
    .timeline-content {
        width: 45%;
        padding: 0 20px;
        text-align: left;
        top: -10px;
        position: relative;
    }
    .timeline-item:nth-child(even) .timeline-content {
        text-align: right;
    }
    .timeline-title {
        font-family: var(--font-cormorant);
        font-weight: 400;
        font-size: 30px;
      
        color: var(--color-text);
        text-transform: capitalize;
    }
    .timeline-description {
        font-family: var(--font-lato);
        font-size: 17px;
        color: var(--color-text);
        line-height: 28px;
        font-weight: 300;
        letter-spacing: 0%;
    }
    .timeline-time {
        font-family: var(--font-lato);
        font-size: 14px;
        font-weight: 400;
        color: var(--color-text);
        opacity: 0.8;
        margin-bottom: 10px;
    }

    /* Person Card */
    .grid:has(> .person-card-wrapper){
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 0 !important;
    }

    .grid:has(> .person-card-wrapper) > .person-card-wrapper{
        border-left: 1px solid #e5e7eb;
        border-top: 1px solid #e5e7eb;
    }

    .grid:has(> .person-card-wrapper) > .person-card-wrapper:nth-child(3n + 1){
        border-left: none;
    }

    .grid:has(> .person-card-wrapper) > .person-card-wrapper:nth-child(-n + 3){
        border-top: none;
    }

    @media (max-width: 640px){
        .grid:has(> .person-card-wrapper){
            grid-template-columns: 1fr;
        }
        .grid:has(> .person-card-wrapper) > .person-card-wrapper{
            border-left: none;
        }
        .grid:has(> .person-card-wrapper) > .person-card-wrapper:nth-child(n + 2){
            border-top: 1px solid #e5e7eb;
        }
    }

    @media (min-width: 1024px){
        .people-grid > .person-card-wrapper:nth-last-child(-n + 3):nth-child(n + 4){
            border-bottom: none;
        }
    }

    @media (min-width: 640px) and (max-width: 1023.98px){
        .people-grid > .person-card-wrapper:nth-last-child(-n + 2):nth-child(n + 3){
            border-bottom: none;
        }
    }

    @media (max-width: 639.98px){
        .people-grid > .person-card-wrapper:last-child{
            border-bottom: none;
        }
    }

    .person-card-wrapper {
        border: 1px solid var(--color-primary);
        border-top: none;
        padding: 50px 0
    }

    .person-card img{
        width: 287px;
        height: 317px;
        object-fit: cover;
        object-position: top;
    }

    .people-grid > .person-card-wrapper:nth-child(even) > img{
        border-radius: 175px 175px 0 0 !important;
    }

    .person-card h3{
        font-family: var(--font-cormorant);
        font-weight: 400;
        font-size: 24px;
      
        text-align: center;
        text-transform: capitalize;
        color: var(--color-text);
    }

    .person-card p{
        font-family: var(--font-cormorant-italic);
        font-size: 21px;
        color: var(--color-text);
        font-weight: 400;
        letter-spacing: 0%;
        text-align: center;
        opacity: 0.8;
    }

    @media (min-width: 1024px) {
        .people-grid {
            grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
            max-width: none !important;
            margin: 0 !important;
            background-color: var(--color-background);
        }
    }

    [data-card-id].py-6:has(> .people-grid) {
        padding-top: 0;
        padding-bottom: 0;
    }

    /* Google Maps Card */

    [data-card-id].py-6:has(> .googlemaps-card) {
        padding-top: 0;
        padding-bottom: 0;
    }


    /* Countdown Card */

    [data-card-id].py-6:has(> .card-countdown) {
        padding-top: 0;
        padding-bottom: 0;
    }
    .card-countdown {
        text-align: center;
        display: flex;
        flex-direction: column;
        align-items: center;
        background-color: var(--color-background);
        margin: 0 !important;
        padding: 75px 0;
    }

    .card-countdown h2{
        font-family: var(--font-cormorant);
        font-weight: 400;
        font-size: 35px;
        text-align: center;
        text-transform: capitalize;
        color: var(--color-primary);
    }

    .countdown-timers {
        display: flex;
        gap: 2rem;
        justify-content: center;
        flex-wrap: wrap;
    }

    .countdown-value{
        font-family: var(--font-cormorant);
        font-weight: 400;
        font-size: 120px;
        line-height: 1;
        color: var(--color-text);
        margin-bottom: 12px;
    }
    
    .countdown-label{
        font-family: var(--font-lato);
        font-size: 12px;
        color: var(--color-text);
        text-transform: uppercase;
      
    }

    .countdown-unit {
        position: relative;
        padding: 0 2rem;
    }

    /* Countdown Map Card */

    [data-card-id].py-6:has(> .countdown-map) {
        padding-top: 0;
        padding-bottom: 0;
    }
    .countdown-map {
        height: 600px;
        margin: 0 !important;
    }
    .countdown-map .countdown{
        background-color: var(--color-background);
        text-align: center;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        width: 50%;
    }

    .countdown-map .map{
        width: 50%;
    }

    .map-link-wrapper {
        margin-top: 12px;
        text-align: center;
    }

    .map-link {
        font-family: var(--font-lato);
        font-size: 14px;
        text-decoration: underline;
        color: var(--color-primary);
    }

    .countdown-map .countdown h2{
        font-family: var(--font-cormorant);
        width: 70%;
        font-weight: 400;
        font-size: 51px;
        
        text-align: center;
        text-transform: capitalize;
        color: var(--color-primary);
    }

    .countdown-days{
        font-family: var(--font-lato);
        font-weight: 400;
        font-size: 18px;
        line-height: 25px;
        color: var(--color-text);
        letter-spacing: 0em;
        width: 70%;
        margin-bottom: 25px;
    }
    
    .countdown-map .live-countdown .countdown-wrapper{
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
        margin-top: 20px;
    }

    .countdown-map .live-countdown .countdown-item{
        border: 1px solid var(--color-primary);
        width: 125px;
        height: 125px;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
    }

    .countdown-map .live-countdown .countdown-item{
        border: 1px solid var(--color-primary);
    }

    @media (min-width: 769px){
        .countdown-map .live-countdown .countdown-wrapper{
            display: flex;
            flex-wrap: nowrap;
        }

        .countdown-map .live-countdown .countdown-item{
            border: 1px solid var(--color-primary);
        }

        .countdown-map .live-countdown .countdown-item:nth-child(2){
            border-left: none;
        }
        .countdown-map .live-countdown .countdown-item:nth-child(3){
            border-left: none;
            border-right: none;
        }
    }

    .countdown-map .live-countdown .countdown-item .countdown-number{
        font-family: var(--font-cormorant);
        font-weight: 400;
        font-size: 60px;
        
        line-height: 1;
        color: var(--color-text);
        margin-bottom: 12px;
    }

    .countdown-map .live-countdown .countdown-item .countdown-text{
        font-family: var(--font-lato);
        font-size: 12px;
        color: var(--color-primary);
        text-transform: uppercase;
      
    }

    /* Form Card */

    .card-form{
        width: 70%;
        margin: 0 auto;
        text-align: center;
        display: flex;
        flex-direction: column;
        align-items: center;
    }

    .form-container{
        width: 100%;
        position: relative;
    }

    .form-container::before {
        content: '';
        position: absolute;
        top: 100px;
        left: 0;
        width: 300px;
        height: 300px;
        background: url('../olive_green/form_side1.png') no-repeat top left;
        background-size: contain;
        z-index: 0;
        pointer-events: none;
    }
    .form-container::after {
        content: '';
        position: absolute;
        top: 0;
        right: 50px;
        width: 80px;
        height: 160px;
        background: url('../olive_green/form_side2.png') no-repeat bottom right;
        background-size: contain;
        z-index: 0;
        pointer-events: none;
    }

    .form-title{
        font-family: var(--font-cormorant);
        font-weight: 400;
        font-size: 35px;
        
        text-align: center;
        text-transform: uppercase;
        color: var(--color-primary);
    }

    .form-intro{
        font-family: var(--font-cormorant-italic);
        font-size: 21px;
        line-height: 25px;
        color: var(--color-text);
        letter-spacing: 0em;
        margin-bottom: 50px;
    }

    .form-fields{
        display: flex;
        flex-wrap: wrap;
        width: 70%;
        justify-content: space-between;
    }

    .form-label {
        display: block;
        font-size: 12px;
      
        text-transform: uppercase;
        color: var(--color-primary);
    }

    .form-input,
    .form-textarea,
    .form-select {
        width: 100%;
        border: none;
        border-bottom: 1px solid var(--color-primary);
        background: transparent;
        font-size: 15px;
        font-family: var(--font-cormorant);
        color: var(--color-text);
    }

    .form-input:focus,
    .form-textarea:focus,
    .form-select:focus {
        outline: none;
    }

    .form-required {
        color: var(--color-text);
        margin-left: 2px;
    }


    .form-group{
        width: 45%;
        margin-bottom: 25px;
    }

    .form-group.full-width{
        width: 100%;
        flex: 0 0 100%;
    }

    .form-submit{
        background-color: var(--color-primary);
        color: white;
        font-family: var(--font-lato);
        padding: 12px 50px;
        border-radius: 0px;
        font-size: 17px;
        font-weight: 500;
        cursor: pointer;
        margin-top: 20px;
    }

    .card-form{
        position: relative;
        overflow: visible;   /* laat de illustratie naar buiten steken */
        z-index: 0;
    }

    /* inhoud blijft boven alles */
    .card-form > *{
        position: relative;
        z-index: 1;
    }

    .card-form > *{
        position: relative;
        z-index: 2; /* was 1 */
    }

    .form-success{
        color: var(--color-text);
        font-family: var(--font-lato);
        width: 70%;
        background-color: var(--color-background);
        padding: 7px 0;
    }

    /* Foutmelding Card */
    .error-text {
        color: #ef4444;
    }

    /* Footer Card */
    footer {
        background-color: var(--color-primary);
        font-family: var(--font-cormorant-italic);
        text-align: center;
        padding: 15px;
        font-size: 0.9rem;
        color: #ffff;
        margin-top: 0 !important;
    }

    /* Password Card */
    .password-wrapper{
    min-height: 100vh;
    display:flex;
    align-items:center;
    justify-content:center;
    padding: 2rem;
    background:
        linear-gradient(135deg, color-mix(in srgb, var(--pw-bg) 80%, #ffffff), #ffffff);
    position: relative;
    overflow: hidden;
    animation: fadeIn .6s ease;
    }

    /* Subtiele botanische hoeken met bestaande assets */
    .password-wrapper::before,
    .password-wrapper::after{
    content:"";
    position:absolute;
    background-repeat:no-repeat;
    background-size:contain;
    pointer-events:none;
    opacity:.10;
    }
    .password-wrapper::before{
    top:-30px; left:-40px;
    width:320px; height:320px;
    background-image:url('../olive_green/side1.png');
    transform: rotate(8deg);
    }
    .password-wrapper::after{
    right:-40px; bottom:-50px;
    width:380px; height:460px;
    background-image:url('../olive_green/side2.png');
    transform: rotate(-10deg);
    }

    /* 3) Kaart */
    .password-card{
    background:#fff;
    width:100%;
    max-width:520px;
    padding: 2.25rem 2rem;
    border-radius:18px;
    box-shadow: 0 14px 40px rgba(0,0,0,.08);
    text-align:center;
    border: 1px solid color-mix(in srgb, var(--pw-accent) 18%, #ffffff);
    }

    /* 4) Typografie */
    .couple-names{
    font-family: var(--pw-display);
    font-weight:400;
    font-size: clamp(2.2rem, 5vw, 3.3rem);
    color: var(--pw-accent);
    line-height:1.05;
    margin: 0 0 .35rem;
    }
    .subtitle{
    font-family: var(--pw-display-italic);
    font-size: 1.05rem;
    color: var(--pw-ink);
    opacity:.85;
    margin: 0 0 .75rem;
    letter-spacing:.02em;
    }
    .info-text{
    font-family: var(--pw-text);
    font-size:.95rem;
    color: var(--pw-ink);
    opacity:.75;
    margin: 0 0 1.25rem;
    font-style: normal;
    }

    /* 5) Form */
    .password-card form{
    display:flex;
    flex-direction:column;
    gap:.85rem;
    width:100%;
    }

    .password-card input[type="password"]{
    width:100%;
    padding:.9rem 1rem;
    border:1px solid color-mix(in srgb, var(--pw-accent) 40%, #ffffff);
    border-radius:12px;
    background:#fff;
    font-family: var(--pw-text);
    font-size:1rem;
    color: var(--pw-ink);
    outline:none;
    transition: border-color .2s ease, box-shadow .2s ease;
    box-sizing:border-box;
    }
    .password-card input[type="password"]::placeholder{
    color: color-mix(in srgb, var(--pw-ink) 55%, #ffffff);
    }
    .password-card input[type="password"]:hover{
    border-color: color-mix(in srgb, var(--pw-accent) 60%, #ffffff);
    }
    .password-card input[type="password"]:focus{
    border-color: var(--pw-accent);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--pw-accent) 18%, transparent);
    }

    .password-card button[type="submit"]{
    width:100%;
    padding:.9rem 1rem;
    border:none;
    border-radius:12px;
    background: var(--pw-accent);
    color:#fff;
    font-family: var(--pw-text);
    font-weight:600;
    letter-spacing:.04em;
    font-size:1rem;
    cursor:pointer;
    transition: transform .06s ease, filter .2s ease, box-shadow .2s ease;
    box-shadow: 0 10px 24px rgba(70,80,62,.28);
    }
    .password-card button[type="submit"]:hover{ filter: brightness(1.02); }
    .password-card button[type="submit"]:active{ transform: translateY(1px); }

    /* 6) Foutmelding */
    .error-text{
    color:#e63946;
    font-family: var(--pw-text);
    font-size:.95rem;
    margin: 0 0 .6rem;
    }

    /* 7) Animatie util (je HTML gebruikt al animate-fade-in) */
    @keyframes fadeIn{
    from{ opacity:0; transform: translateY(10px); }
    to{ opacity:1; transform: translateY(0); }
    }
    .animate-fade-in{ animation: fadeIn .6s ease; }

    /* 8) Mobile tweaks */
    @media (max-width:640px){
    .password-wrapper{ padding: 1.25rem; }
    .password-card{ padding: 1.6rem 1.1rem; border-radius:14px; }
    }

    @media (max-width: 768px) {

        body{
            overflow-x: hidden;
        }

        nav{
            display: block;
        }

        .nav-toggle::before,
        .nav-toggle::after {
            display: block;
        }
        .header-namen {
            font-size: 30px;
        }

        .header-namen::after {
            width: 45px;
            height: 57px;
        }

        .header-container {
            justify-content: space-between;
        }
        nav ul li a {
            font-size: 1rem;
        }
        .nav-toggle {
            display: block;
        }
        .nav-menu {
            position: absolute;
            top: 100%;
            left: 0;
            right: 0;
            z-index: 100;
            background: var(--color-background);
            display: none;
            flex-direction: column;
            text-align: left;
            padding: 10px 0;
        }
        .nav-menu.active {
            display: flex;
        }
        .nav-menu li {
            margin: 10px 0;
        }
        main {
            min-height: 100vh;
        }

        .container {
            background-position: center top;
            background-size: cover;
        }

        .hero-card{
            flex-direction: column-reverse;
        }

        .hero-card img {
            height: 50% !important;
            width: 100%;
            border-top: var(--color-primary) 1px solid;
        }

        .hero-card  .hero-overlay{
            height: 50%;
            padding: 40px 0;
        }
       
        .hero-card .couple-names {
            font-size: 50px !important;
        }

        .hero-card .hero-title{
            font-size: 30px;
            padding: 0;
        }

        .grote-foto img{
            aspect-ratio: 1/1;
            height: auto;
        }

        .foto-tekst{
            flex-direction: column;
        }

        .foto-tekst .image-side img{
            width: 100%;
            aspect-ratio: 1/1;
            height: auto;
            border-bottom: 1px solid var(--color-primary);
        }

        .foto-tekst .text-side{
            padding: 50px 20px;
            align-items: center;
            text-align: center;
        }

        .foto-tekst .text-side h2{
            font-size: 43px;
        }

        .collage-grid{
            grid-template-columns: repeat(2, 1fr);
            padding: 0 16px;
        }

        .quote-card{
            gap: 16px;
            padding: 40px 0;
            flex-direction: column;
        }
        .qoute-img{
            width: 56px;
            height: 56px;
        }

        .quote-text{
            padding-left: 16px;
            border-top: none;
            border-left: none;
            position: relative;
            text-align: center;
            padding-top: 15px;
        }

        .quote-text::before{
            content: "";
            position: absolute;
            top: 0;
            left: 0;
            width: 50%;
            height: 1px;
            background-color: var(--color-primary);
            left: 50%;
            transform: translateX(-50%);
        }

        .quote-text blockquote{
            font-size: 28px;
        }

        .schedule-wrapper::before{
            display: none;
        }
        .schedule-wrapper::after{
            width: 200px;
            height: 250px;
        }

        .timeline-dot{
            display: none;
        }

        .timeline-item::before {
            display: none;
        }

        .timeline-item::after {
            display: none;
        }

        .timeline-item:nth-child(odd), .timeline-item {
            justify-content: center;
        }

        .timeline-content {
            width: 100%;
            text-align: left !important;
        }

        .countdown-map {
            flex-direction: column;
        }

        .countdown-map .countdown{
            width: 100%;
        }

        .countdown-map .map{
            width: 100%;
        }

        .countdown-value{
            font-size: 80px;
        }

        .countdown-unit:not(:last-child)::after {
            display: none;
        }

        .card-countdown h2{
            font-size: 28px;
        }
        
        /* Columns: Countdown + Map (mobile) */
        .countdown-map {
            display: flex;
            flex-direction: column;
            align-items: stretch;
            height: unset !important; 
        }

        .countdown-map .countdown,
        .countdown-map .map {
            width: 100%;
        }

        .countdown-map .map{
            height: 400px;
        }

        .countdown-map .countdown {
            padding: 24px 16px;
        }

        .countdown-map .countdown h2 {
            width: 100%;
            font-size: 28px;
            line-height: 1.25;
            margin: 0 auto 8px;
            text-align: center;
        }

        .countdown-days {
            width: 100%;
            font-size: 16px;
            line-height: 22px;
            text-align: center;
            margin: 4px auto 0;
        }

        .countdown-map .live-countdown .countdown-wrapper {
            display: grid;
            grid-template-columns: repeat(2, minmax(0, 1fr));
            justify-content: center;
            margin-top: 16px;
        }

        .countdown-map .live-countdown .countdown-item {
            width: 125px;
            height: 125px;
        }

        .countdown-map .live-countdown .countdown-item .countdown-number {
            font-size: 44px;
        }

        .countdown-map .live-countdown .countdown-item .countdown-text {
            font-size: 11px;
        }

        .countdown-map .live-countdown .countdown-item:nth-child(1){
            border-right: none;
            border-bottom: none;
        }

        /* 2: geen onder */
        .countdown-map .live-countdown .countdown-item:nth-child(2){
            border-bottom: none;
        }

        /* 3: geen rechts */
        .countdown-map .live-countdown .countdown-item:nth-child(3){
            border-right: none;
        }

        /* Map iframe hoogte op mobiel */
        .countdown-map .map iframe {
            width: 100%;
            height: 280px; /* pas aan naar 240-320 als nodig */
            border: 0;
            display: block;
        }

        .form-fields{
            display: flex;
            flex-direction: column;
        }

        .card-form::after {
            display: none;
        }

        .card-form {
            width: 90%;
        }

        .form-group {
            width: 100%;
        }

        .form-label{
            text-align: left;
        }

        .form-container::before, .form-container::after{
            display: none;
        }
    }
