/*
Theme Name: AMDG Kampen
Theme URI: https://www.amdgkampen.nl
Author: AMDG Kampen
Author URI: https://www.amdgkampen.nl
Description: Officieel WordPress-thema voor Christelijke Muziekvereniging A.M.D.G. Kampen met WooCommerce-integratie.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: amdg-kampen
Tags: music, association, woocommerce, responsive, mobile-first
*/

/* ==========================================================================
   CUSTOM PROPERTIES - pixel-perfect match screenshots
   ========================================================================== */
:root {
    /* Page header: donker paars/navy tint (uit screenshots) */
    --amdg-purple: #2d2040;
    --amdg-purple-dark: #1e1530;
    /* Donkere achtergronden */
    --amdg-dark: #333333;
    --amdg-dark-bg: #2d2040;
    --amdg-darker: #1e1530;
    --amdg-darkest: #161020;
    /* Lichte kleuren */
    --amdg-white: #ffffff;
    --amdg-off-white: #f7f7f7;
    --amdg-gray-light: #e5e5e5;
    --amdg-gray: #999999;
    --amdg-gray-medium: #777777;
    /* Tekst */
    --amdg-text: #444444;
    --amdg-text-light: #666666;
    --amdg-text-dark: #333333;
    /* Accent / rood */
    --amdg-red: #c0392b;
    --amdg-red-dark: #a93226;
    --amdg-red-overlay: rgba(192, 57, 43, 0.80);
    /* Overlay hero */
    --amdg-overlay: rgba(30, 21, 48, 0.55);
    /* Links */
    --amdg-link: #c0392b;
    /* Schaduwen */
    --amdg-shadow: 0 2px 15px rgba(0,0,0,0.08);
    --amdg-shadow-lg: 0 5px 30px rgba(0,0,0,0.12);
    /* Typography */
    --font-heading: 'Open Sans', 'Helvetica Neue', Arial, sans-serif;
    --font-body: 'Open Sans', 'Helvetica Neue', Arial, sans-serif;
    /* Layout */
    --section-padding: 60px 0;
    --container-width: 1140px;
    --container-padding: 0 20px;
    --transition: all 0.3s ease;
    --radius: 3px;
}

/* ==========================================================================
   RESET & BASE - Mobile First
   ========================================================================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);font-size:.95rem;line-height:1.7;color:var(--amdg-text);background:var(--amdg-white);overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--amdg-link);text-decoration:none;transition:var(--transition)}
a:hover{color:var(--amdg-dark)}
ul,ol{list-style:none}
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:700;line-height:1.3;color:var(--amdg-text-dark)}
h1{font-size:1.6rem}h2{font-size:1.4rem}h3{font-size:1.2rem}h4{font-size:1.05rem}
p{margin-bottom:1rem}
.container{width:100%;max-width:var(--container-width);margin:0 auto;padding:var(--container-padding)}

/* ==========================================================================
   TOP BAR - donkere balk, e-mail links, "Lid worden?" rechts
   ========================================================================== */
.top-bar{background:var(--amdg-darkest);color:var(--amdg-white);padding:6px 0;font-size:.8rem;display:none}
.top-bar .container{display:flex;justify-content:space-between;align-items:center}
.top-bar a{color:rgba(255,255,255,.75)}
.top-bar a:hover{color:#fff}
.top-bar__email a{display:flex;align-items:center;gap:6px}
.top-bar__email i{font-size:.75rem}
.top-bar__cta a{font-weight:600}

/* ==========================================================================
   HEADER - Witte achtergrond, AMDG logo links, UPPERCASE nav rechts
   ========================================================================== */
.site-header{background:var(--amdg-white);position:sticky;top:0;z-index:1000;border-bottom:1px solid var(--amdg-gray-light)}
.site-header.scrolled{box-shadow:0 2px 10px rgba(0,0,0,.08)}
.site-header .container{display:flex;justify-content:space-between;align-items:center;min-height:60px}
.site-logo a{display:flex;align-items:center;padding:8px 0}
.site-logo img,.site-logo .custom-logo{height:55px;width:auto}

/* Mobile toggle */
.menu-toggle{display:flex;flex-direction:column;gap:5px;background:0 0;border:0;cursor:pointer;padding:10px;z-index:1001}
.menu-toggle span{display:block;width:24px;height:2px;background:var(--amdg-dark);transition:var(--transition)}
.menu-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.menu-toggle.active span:nth-child(2){opacity:0}
.menu-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Nav - Mobile */
.main-nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--amdg-white);box-shadow:var(--amdg-shadow-lg);z-index:999;border-top:1px solid var(--amdg-gray-light)}
.main-nav.active{display:block}
.main-nav ul{padding:8px 0}
.main-nav>ul>li{border-bottom:1px solid var(--amdg-gray-light)}
.main-nav>ul>li:last-child{border-bottom:0}
.main-nav a{color:var(--amdg-text-dark);display:block;padding:12px 20px;font-size:.88rem;font-weight:600;text-transform:uppercase;letter-spacing:.4px;transition:var(--transition)}
.main-nav a:hover,.main-nav .current-menu-item>a,.main-nav .current-page-ancestor>a{color:var(--amdg-purple)}

/* Submenu mobile */
.main-nav .sub-menu{background:var(--amdg-off-white);display:none}
.main-nav .sub-menu.active{display:block}
.main-nav .sub-menu a{padding-left:35px;font-size:.82rem;font-weight:400;text-transform:none}
.main-nav .menu-item-has-children>a::after{content:'\f107';font-family:'Font Awesome 6 Free';font-weight:900;float:right;transition:var(--transition);font-size:.75rem}
.main-nav .menu-item-has-children.open>a::after{transform:rotate(180deg)}

/* Cart icon */
.nav-cart{display:inline-flex;align-items:center;gap:4px;position:relative;color:var(--amdg-text-dark);padding:12px 20px;font-weight:600;text-transform:uppercase;font-size:.88rem}
.nav-cart .cart-count{background:var(--amdg-red);color:#fff;font-size:.6rem;font-weight:700;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;position:absolute;top:6px;right:8px}

/* ==========================================================================
   HERO - grote foto, donkere paarse overlay, italic witte titel
   ========================================================================== */
.hero{position:relative;min-height:45vh;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;overflow:hidden}
.hero__background{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.hero__background::after{content:'';position:absolute;inset:0;background:var(--amdg-overlay);z-index:1}
.hero__content{position:relative;z-index:2;padding:50px 20px;max-width:800px}
/* Titel is italic/cursief in de screenshot */
.hero__title{font-size:2rem;font-weight:700;font-style:italic;color:#fff;margin-bottom:25px;text-shadow:0 2px 15px rgba(0,0,0,.4)}
/* CTA: donkergrijze/semi-transparante rechthoek, uppercase, letter-spacing */
.hero__btn{display:inline-block;background:rgba(50,50,50,.82);color:#fff;padding:14px 35px;font-weight:600;font-size:.82rem;text-transform:uppercase;letter-spacing:2px;transition:var(--transition);border:0}
.hero__btn:hover{background:rgba(30,30,30,.95);color:#fff}

/* ==========================================================================
   PAGE HEADER - Donker paars (#2d2040) met witte UPPERCASE tekst
   Alle subpagina's hebben dit patroon
   ========================================================================== */
.page-header{background:var(--amdg-purple);color:#fff;padding:40px 0;text-align:center;position:relative;overflow:hidden}
/* Achtergrond patroon/foto met overlay zoals in screenshots */
.page-header::before{content:'';position:absolute;inset:0;background:url('') center/cover;opacity:.15}
.page-header h1,.page-header h2{color:#fff;font-size:1.8rem;margin-bottom:5px;text-transform:uppercase;letter-spacing:1px;position:relative;z-index:1;font-weight:800}
.breadcrumb{font-size:.82rem;opacity:.5;position:relative;z-index:1}
.breadcrumb a{color:#fff}
.breadcrumb a:hover{opacity:.8}

/* ==========================================================================
   INTRO OVERLAP SECTION
   Screenshot: split blok dat ~100px over de hero schuift
   ========================================================================== */
.intro-section{padding:0;position:relative;z-index:10}
.intro-overlap-grid{display:grid;grid-template-columns:1fr;background:var(--amdg-white);box-shadow:var(--amdg-shadow-lg);margin-top:-80px}
.intro-overlap__text{padding:35px 25px}
.intro-text__label{font-size:.82rem;color:var(--amdg-gray-medium);font-weight:600;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:8px;display:block}
.intro-text__title{font-size:1.4rem;color:var(--amdg-text-dark);margin-bottom:20px;text-transform:uppercase;font-weight:800;line-height:1.25}
.intro-text__content{color:var(--amdg-text-light);line-height:1.8;margin-bottom:20px;font-size:.92rem}
.intro-text__content p:last-child{margin-bottom:0}
.intro-overlap__media{position:relative;min-height:280px;background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center}
.intro-overlap__media-overlay{position:absolute;inset:0}
.intro-media__play{position:relative;z-index:2;width:65px;height:65px;border:3px solid #fff;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.4rem;transition:var(--transition);cursor:pointer;background:0 0;text-decoration:none}
.intro-media__play:hover{background:rgba(255,255,255,.15);transform:scale(1.08);color:#fff}

/* ==========================================================================
   BUTTONS - "Lees meer >" donker met chevron
   ========================================================================== */
.btn{display:inline-block;padding:10px 22px;border-radius:var(--radius);font-weight:600;font-size:.82rem;text-transform:uppercase;letter-spacing:.5px;transition:var(--transition);cursor:pointer;border:0}
.btn--primary{background:var(--amdg-purple);color:#fff}
.btn--primary:hover{background:var(--amdg-purple-dark);color:#fff}
.btn--red{background:var(--amdg-red);color:#fff}
.btn--red:hover{background:var(--amdg-red-dark);color:#fff}
.btn--outline{background:0 0;color:var(--amdg-text-dark);border:2px solid var(--amdg-text-dark)}
.btn--outline:hover{background:var(--amdg-text-dark);color:#fff}
/* Footer "Lees meer" button is outlined/bordered style */
.btn--outline-light{background:0 0;color:#fff;border:1px solid rgba(255,255,255,.5);font-size:.8rem;padding:8px 18px}
.btn--outline-light:hover{background:rgba(255,255,255,.1);color:#fff}
.btn i,.btn .fa,.btn .fas{margin-left:5px}

/* ==========================================================================
   NEWS / UITGELICHT
   ========================================================================== */
.news-section{padding:var(--section-padding);background:var(--amdg-white)}
.section-title{font-size:1.3rem;color:var(--amdg-text-dark);margin-bottom:30px;text-align:center;font-weight:400;font-style:italic}
.news-grid{display:grid;grid-template-columns:1fr;gap:25px;margin-bottom:30px}
.news-card{background:var(--amdg-white);overflow:hidden;box-shadow:var(--amdg-shadow);transition:var(--transition)}
.news-card:hover{box-shadow:var(--amdg-shadow-lg);transform:translateY(-2px)}
.news-card__image{width:100%;height:200px;overflow:hidden;display:block}
.news-card__image img{width:100%;height:100%;object-fit:cover;transition:var(--transition)}
.news-card:hover .news-card__image img{transform:scale(1.04)}
.news-card__content{padding:18px}
.news-card__date{font-size:.75rem;color:var(--amdg-gray);margin-bottom:8px;display:flex;align-items:center;gap:5px}
.news-card__date i{font-size:.65rem}
.news-card__title{font-size:.95rem;margin-bottom:14px;line-height:1.4;font-weight:600}
.news-card__title a{color:var(--amdg-text-dark)}
.news-card__title a:hover{color:var(--amdg-link)}
/* "Lees meer >" button op nieuws kaarten */
.news-card__link{display:inline-block;background:var(--amdg-purple);color:#fff;padding:7px 16px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px;border-radius:var(--radius);transition:var(--transition)}
.news-card__link:hover{background:var(--amdg-purple-dark);color:#fff}
/* Views counter */
.news-card__views{font-size:.75rem;color:var(--amdg-gray);margin-left:10px;display:inline-flex;align-items:center;gap:4px;float:right;margin-top:-28px}
.news-section__more{text-align:center;margin-top:10px}
.news-section__more a{color:var(--amdg-text-dark);font-size:.9rem;font-style:italic}
.news-section__more a:hover{color:var(--amdg-link)}

/* ==========================================================================
   NEWS PAGE - 2 kolommen + sidebar (screenshot Nieuws)
   ========================================================================== */
.news-page-grid{display:grid;grid-template-columns:1fr;gap:30px}
.news-page-main .news-grid{grid-template-columns:repeat(2,1fr)}
/* Sidebar op nieuwspagina */
.news-sidebar .sidebar-btn{display:inline-block;background:var(--amdg-red);color:#fff;padding:8px 16px;font-size:.78rem;font-weight:600;text-transform:uppercase;border-radius:var(--radius);margin-bottom:20px}
.news-sidebar .sidebar-btn:hover{background:var(--amdg-red-dark);color:#fff}
.news-sidebar h4{font-size:.9rem;font-weight:700;text-transform:uppercase;margin-bottom:12px;color:var(--amdg-text-dark)}
.news-sidebar ul li{padding:4px 0;font-size:.82rem;border-bottom:1px solid var(--amdg-gray-light)}
.news-sidebar ul li a{color:var(--amdg-text-light)}
.news-sidebar ul li a:hover{color:var(--amdg-link)}

/* ==========================================================================
   CONTENT SECTIONS (Vereniging)
   Afwisselende achtergrondkleur (wit/geel achtig voor jeugdorkest)
   ========================================================================== */
.content-section{padding:40px 0}
.content-section:nth-child(even){background:var(--amdg-off-white)}
/* Gele achtergrond sectie (jeugdorkest in Vereniging screenshot) */
.content-section--yellow{background:#f5c518 !important}
.content-section--yellow .content-block__text h3,
.content-section--yellow .content-block__text p{color:var(--amdg-text-dark)}
.content-block{display:grid;grid-template-columns:1fr;gap:25px;align-items:start;margin-bottom:30px}
.content-block__text h3{font-size:1.15rem;color:var(--amdg-text-dark);margin-bottom:12px;text-transform:uppercase;font-weight:700}
/* Verticale accent lijn voor h3 (zichtbaar bij Boekingen) */
.content-block__text h3.has-accent{padding-left:12px;border-left:4px solid var(--amdg-purple)}
.content-block__text p{color:var(--amdg-text-light);line-height:1.8;font-size:.92rem}
.content-block__image img{width:100%;box-shadow:var(--amdg-shadow)}

/* ==========================================================================
   FOTOBOEK - Album kaarten met overlay tekst onderaan
   ========================================================================== */
.album-grid{display:grid;grid-template-columns:1fr;gap:20px}
.album-card{position:relative;overflow:hidden;border-radius:var(--radius);min-height:250px;background-size:cover;background-position:center;display:flex;align-items:flex-end}
.album-card::after{content:'';position:absolute;inset:0;background:linear-gradient(transparent 40%,rgba(0,0,0,.65))}
.album-card__content{position:relative;z-index:2;padding:20px;color:#fff;width:100%}
.album-card__content h3{font-size:1.1rem;color:#fff;margin-bottom:3px;font-weight:600}
.album-card__content span{font-size:.8rem;opacity:.7}
.album-card:hover::after{background:linear-gradient(transparent 20%,rgba(0,0,0,.75))}

/* ==========================================================================
   STEUN AMDG - Rode formulier sectie
   ========================================================================== */
.red-form-section{background:var(--amdg-red);color:#fff;padding:40px 0}
.red-form-section h3{color:#fff;text-align:center;margin-bottom:25px;font-size:1.2rem;font-style:italic}
.red-form-section label{color:#fff;font-weight:600;font-size:.82rem}
.red-form-section input[type="text"],.red-form-section input[type="email"],.red-form-section textarea,.red-form-section select{background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:var(--radius);padding:10px 14px;width:100%;font-family:var(--font-body);font-size:.9rem}
.red-form-section input::placeholder,.red-form-section textarea::placeholder{color:rgba(255,255,255,.5)}
.red-form-section input:focus,.red-form-section textarea:focus{outline:0;border-color:rgba(255,255,255,.6);background:rgba(255,255,255,.2)}
.red-form-section .btn--red{background:var(--amdg-red-dark);border:1px solid rgba(255,255,255,.3)}
.red-form-section .form-consent{color:rgba(255,255,255,.8);font-size:.78rem}
/* Dankbaarheid tekst op rode achtergrond */
.red-section-thanks{background:var(--amdg-red);color:#fff;padding:30px 0;text-align:center}
.red-section-thanks h3{color:#fff;font-size:1.1rem;font-weight:600;font-style:italic}

/* ==========================================================================
   BESTUUR TABLE
   ========================================================================== */
.bestuur-table{width:100%;border-collapse:collapse;margin:20px 0;font-size:.88rem}
.bestuur-table thead{background:var(--amdg-purple);color:#fff}
.bestuur-table th,.bestuur-table td{padding:12px 15px;text-align:left;border-bottom:1px solid var(--amdg-gray-light)}
.bestuur-table tbody tr:nth-child(even){background:var(--amdg-off-white)}
.bestuur-table tbody tr:hover{background:rgba(0,0,0,.02)}
.bestuur-table a{color:var(--amdg-link)}
.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch}

/* ==========================================================================
   SPONSORS - Logo grid (2x3)
   ========================================================================== */
.sponsors-section{padding:var(--section-padding)}
.sponsors-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:15px;align-items:center}
.sponsors-grid a{display:flex;align-items:center;justify-content:center;padding:12px;background:var(--amdg-white);transition:var(--transition)}
.sponsors-grid a:hover{opacity:.8}
.sponsors-grid img{max-height:50px;width:auto}

/* ==========================================================================
   CONTACT - Split met kaart rechts
   ========================================================================== */
.contact-section{padding:var(--section-padding)}
.contact-grid{display:grid;grid-template-columns:1fr;gap:30px}
.contact-info h3{color:var(--amdg-text-dark);margin-bottom:12px;text-transform:uppercase;font-size:1rem}
.contact-info p{line-height:1.8;color:var(--amdg-text-light);font-size:.92rem}
.contact-map{min-height:300px;border-radius:0;overflow:hidden}
.contact-map iframe{width:100%;height:100%;min-height:300px;border:0}
/* Social icons */
.social-icons{display:flex;gap:10px;margin-top:15px}
.social-icons a{color:var(--amdg-gray);font-size:1rem;transition:var(--transition)}
.social-icons a:hover{color:var(--amdg-text-dark)}

/* ==========================================================================
   CONTACT FORM - Underline style inputs (uit screenshots)
   ========================================================================== */
.contact-form .form-row{display:grid;grid-template-columns:1fr;gap:15px;margin-bottom:15px}
.contact-form .form-group{margin-bottom:15px}
.contact-form label{display:block;font-weight:600;font-size:.82rem;margin-bottom:5px;color:var(--amdg-text-dark)}
.contact-form input[type="text"],.contact-form input[type="email"],.contact-form textarea,.contact-form select{width:100%;padding:10px 0;border:0;border-bottom:1px solid var(--amdg-gray-light);font-family:var(--font-body);font-size:.9rem;transition:var(--transition);background:transparent}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{outline:0;border-bottom-color:var(--amdg-purple)}
.contact-form textarea{min-height:120px;resize:vertical;border:1px solid var(--amdg-gray-light);padding:10px 14px}
.contact-form .form-consent{font-size:.78rem;color:var(--amdg-text-light);display:flex;align-items:flex-start;gap:8px}
.contact-form .form-consent input[type="checkbox"]{margin-top:3px;flex-shrink:0}

/* ==========================================================================
   FOOTER - 4 kolommen: Verenigingsgebouw, Vereniging, Snel naar, Lid worden?
   Donker paars/navy achtergrond. Social icons (fb + twitter)
   ========================================================================== */
.site-footer{background:var(--amdg-darker);color:#fff;padding:50px 0 0}
.footer-grid{display:grid;grid-template-columns:1fr;gap:30px;padding-bottom:30px}
.footer-col h4{color:#fff;font-size:.88rem;margin-bottom:14px;text-transform:uppercase;letter-spacing:.5px;font-weight:700}
.footer-col p,.footer-col address{font-style:normal;color:rgba(255,255,255,.55);font-size:.84rem;line-height:1.8}
.footer-col ul li{margin-bottom:5px}
.footer-col ul li a{color:rgba(255,255,255,.55);font-size:.84rem;transition:var(--transition)}
.footer-col ul li a:hover{color:#fff;padding-left:2px}
.footer-col .footer-contact-item{display:flex;align-items:center;gap:8px;margin-bottom:5px;color:rgba(255,255,255,.55);font-size:.84rem}
.footer-col .footer-contact-item i{color:rgba(255,255,255,.35);width:14px}
.footer-col .footer-contact-item a{color:rgba(255,255,255,.55)}
.footer-col .footer-contact-item a:hover{color:#fff}
.footer-privacy a{color:rgba(255,255,255,.35);font-size:.78rem}
/* Social icons in footer */
.footer-social{display:flex;gap:12px;margin-top:12px}
.footer-social a{color:rgba(255,255,255,.4);font-size:.95rem;transition:var(--transition)}
.footer-social a:hover{color:#fff}

/* Lid worden kolom (4e kolom) */
.footer-col--cta p{color:rgba(255,255,255,.55);font-size:.84rem;line-height:1.7;margin-bottom:12px}

/* Footer bottom */
.footer-bottom{background:rgba(0,0,0,.2);padding:14px 0;text-align:center;font-size:.78rem;color:rgba(255,255,255,.4)}
.footer-bottom a{color:rgba(255,255,255,.5)}
.footer-bottom a:hover{color:#fff}
.footer-bottom strong{font-weight:700;color:rgba(255,255,255,.5)}

/* ==========================================================================
   COOKIE NOTICE
   ========================================================================== */
.cookie-notice{position:fixed;bottom:0;left:0;right:0;background:var(--amdg-darkest);color:#fff;padding:14px 20px;z-index:9999;display:none;box-shadow:0 -2px 15px rgba(0,0,0,.2)}
.cookie-notice.show{display:block}
.cookie-notice .container{display:flex;flex-direction:column;gap:10px;align-items:center;text-align:center}
.cookie-notice p{font-size:.8rem;margin:0;line-height:1.5;color:rgba(255,255,255,.75)}
.cookie-notice .btn{font-size:.75rem;padding:7px 18px}

/* Scroll to top */
.scroll-top{position:fixed;bottom:25px;right:25px;width:38px;height:38px;background:var(--amdg-purple);color:#fff;border:0;border-radius:var(--radius);display:none;align-items:center;justify-content:center;cursor:pointer;z-index:99;transition:var(--transition);font-size:.85rem}
.scroll-top.visible{display:flex}
.scroll-top:hover{background:var(--amdg-purple-dark)}

.mobile-nav-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:998;opacity:0;visibility:hidden;transition:var(--transition)}
.mobile-nav-overlay.active{opacity:1;visibility:visible}

/* ==========================================================================
   WOOCOMMERCE
   ========================================================================== */
.woocommerce ul.products{display:grid;grid-template-columns:repeat(2,1fr);gap:15px;padding:0;margin:0}
.woocommerce ul.products li.product{background:var(--amdg-white);overflow:hidden;box-shadow:var(--amdg-shadow);transition:var(--transition);margin:0;padding:0;float:none;width:100%!important}
.woocommerce ul.products li.product:hover{box-shadow:var(--amdg-shadow-lg);transform:translateY(-2px)}
.woocommerce ul.products li.product a img{width:100%;height:200px;object-fit:cover;margin:0}
.woocommerce ul.products li.product .woocommerce-loop-product__title,.woocommerce ul.products li.product h2{padding:12px 15px 0;font-size:.88rem;color:var(--amdg-text-dark);font-weight:600}
.woocommerce ul.products li.product .price{padding:5px 15px;color:var(--amdg-red);font-weight:700;font-size:1rem}
.woocommerce ul.products li.product .button,.woocommerce ul.products li.product a.add_to_cart_button{display:block;margin:10px 15px 15px;background:var(--amdg-purple);color:#fff;text-align:center;padding:10px 15px;border-radius:var(--radius);font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;transition:var(--transition)}
.woocommerce ul.products li.product .button:hover,.woocommerce ul.products li.product a.add_to_cart_button:hover{background:var(--amdg-purple-dark);color:#fff}
.woocommerce span.onsale{background:var(--amdg-red);color:#fff;font-weight:700;border-radius:var(--radius);padding:4px 10px;min-width:auto;min-height:auto;line-height:1.4}
.woocommerce div.product .product_title{font-size:1.5rem;color:var(--amdg-text-dark);margin-bottom:10px;text-transform:uppercase}
.woocommerce div.product p.price{color:var(--amdg-red);font-size:1.4rem;font-weight:700;margin-bottom:15px}
.woocommerce div.product form.cart .button,.woocommerce .single_add_to_cart_button{background:var(--amdg-purple)!important;color:#fff!important;padding:12px 30px;border-radius:var(--radius);font-weight:700;text-transform:uppercase;letter-spacing:.5px;transition:var(--transition);border:0}
.woocommerce div.product form.cart .button:hover,.woocommerce .single_add_to_cart_button:hover{background:var(--amdg-purple-dark)!important}
.woocommerce div.product .woocommerce-tabs ul.tabs{padding:0;margin:0 0 20px;display:flex;border-bottom:2px solid var(--amdg-gray-light);overflow-x:auto}
.woocommerce div.product .woocommerce-tabs ul.tabs li{margin:0;border:0;background:0 0;border-radius:0;padding:0}
.woocommerce div.product .woocommerce-tabs ul.tabs li a{padding:12px 20px;color:var(--amdg-text-light);font-weight:600;font-size:.82rem;text-transform:uppercase;border-bottom:2px solid transparent;margin-bottom:-2px}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a{color:var(--amdg-text-dark);border-bottom-color:var(--amdg-purple)}
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button{background:var(--amdg-purple);color:#fff;font-weight:700;border-radius:var(--radius);font-size:1rem;padding:14px;text-transform:uppercase}
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover{background:var(--amdg-purple-dark)}
.woocommerce #place_order{background:var(--amdg-purple);color:#fff;font-weight:700;border-radius:var(--radius);font-size:1rem;padding:14px 30px;text-transform:uppercase;border:0;transition:var(--transition)}
.woocommerce #place_order:hover{background:var(--amdg-purple-dark)}
.woocommerce-message{border-top-color:var(--amdg-purple)}
.woocommerce-message::before{color:var(--amdg-purple)}
.woocommerce .star-rating{color:#f39c12}

/* ==========================================================================
   GALLERY / AGENDA / SIDEBAR / PAGINATION / SR
   ========================================================================== */
.gallery-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.gallery-grid__item{overflow:hidden}
.gallery-grid__item img{width:100%;height:150px;object-fit:cover;transition:var(--transition)}
.gallery-grid__item:hover img{transform:scale(1.05)}
.agenda-section{padding:var(--section-padding)}
.agenda-section iframe{width:100%;border:0;min-height:400px}
.sidebar .widget{margin-bottom:25px;padding:20px;background:var(--amdg-off-white)}
.sidebar .widget-title{font-size:.9rem;color:var(--amdg-text-dark);margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid var(--amdg-purple);text-transform:uppercase}
.pagination,.woocommerce-pagination{display:flex;justify-content:center;gap:5px;margin:30px 0}
.pagination a,.pagination span,.woocommerce-pagination a,.woocommerce-pagination span{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:var(--radius);font-weight:600;font-size:.85rem;transition:var(--transition)}
.pagination a,.woocommerce-pagination a{background:var(--amdg-white);color:var(--amdg-text-dark);border:1px solid var(--amdg-gray-light)}
.pagination a:hover,.woocommerce-pagination a:hover{background:var(--amdg-purple);color:#fff;border-color:var(--amdg-purple)}
.pagination .current,.woocommerce-pagination .current{background:var(--amdg-purple);color:#fff;border:1px solid var(--amdg-purple)}
.screen-reader-text{clip:rect(1px,1px,1px,1px);position:absolute!important;height:1px;width:1px;overflow:hidden;word-wrap:normal!important}
.screen-reader-text:focus{display:block;background:var(--amdg-purple);color:#fff;clip:auto!important;height:auto;width:auto;padding:15px 23px;z-index:100000}

/* ==========================================================================
   RESPONSIVE - 576px
   ========================================================================== */
@media(min-width:576px){
    .news-grid{grid-template-columns:repeat(2,1fr)}
    .gallery-grid{grid-template-columns:repeat(3,1fr)}
    .gallery-grid__item img{height:180px}
    .sponsors-grid{grid-template-columns:repeat(3,1fr)}
    .album-grid{grid-template-columns:repeat(2,1fr)}
    .contact-form .form-row{grid-template-columns:1fr 1fr}
}

/* ==========================================================================
   RESPONSIVE - 768px
   ========================================================================== */
@media(min-width:768px){
    h1{font-size:2rem}h2{font-size:1.75rem}h3{font-size:1.3rem}
    .top-bar{display:block}
    .hero{min-height:55vh}
    .hero__title{font-size:2.8rem}
    .intro-overlap-grid{grid-template-columns:1fr 1fr;margin-top:-100px}
    .intro-overlap__text{padding:50px 40px}
    .intro-text__title{font-size:1.7rem}
    .intro-overlap__media{min-height:auto}
    .news-grid{grid-template-columns:repeat(var(--news-cols,3),1fr)}
    .news-page-grid{grid-template-columns:2fr 1fr}
    .news-page-main .news-grid{grid-template-columns:repeat(2,1fr)}
    .content-block{grid-template-columns:1fr 1fr}
    .content-block--reverse .content-block__image{order:-1}
    .contact-grid{grid-template-columns:1fr 1fr}
    .footer-grid{grid-template-columns:repeat(2,1fr)}
    .page-header h1,.page-header h2{font-size:2.2rem}
    .woocommerce ul.products{grid-template-columns:repeat(3,1fr)}
    .woocommerce div.product div.images{float:left;width:48%;margin-right:4%}
    .woocommerce div.product div.summary{float:right;width:48%}
    .gallery-grid{grid-template-columns:repeat(4,1fr);gap:10px}
    .gallery-grid__item img{height:200px}
    .album-grid{grid-template-columns:repeat(3,1fr)}
}

/* ==========================================================================
   RESPONSIVE - 992px
   ========================================================================== */
@media(min-width:992px){
    .menu-toggle{display:none}
    .main-nav{display:flex!important;position:static;background:0 0;box-shadow:none;border-top:0}
    .main-nav>ul{display:flex;align-items:center;padding:0}
    .main-nav>ul>li{border:0;position:relative}
    .main-nav a{padding:25px 14px;font-size:.8rem;white-space:nowrap}
    .main-nav a:hover,.main-nav .current-menu-item>a,.main-nav .current-page-ancestor>a{background:0 0;color:var(--amdg-text-dark)}
    /* Actief: onderstreping (screenshot HOME) */
    .main-nav .current-menu-item>a{position:relative}
    .main-nav .current-menu-item>a::after{content:'';position:absolute;bottom:18px;left:14px;right:14px;height:2px;background:var(--amdg-text-dark)}
    /* Dropdown */
    .main-nav .sub-menu{position:absolute;top:100%;left:0;background:var(--amdg-white);min-width:240px;box-shadow:var(--amdg-shadow-lg);display:none;border-top:3px solid var(--amdg-purple);z-index:100}
    .main-nav>ul>li:hover>.sub-menu{display:block}
    .main-nav .sub-menu a{padding:10px 18px;font-size:.8rem;text-transform:none;font-weight:400;border-bottom:1px solid var(--amdg-gray-light)}
    .main-nav .sub-menu li:last-child a{border-bottom:0}
    .main-nav .sub-menu a:hover{background:var(--amdg-off-white)}
    .main-nav .menu-item-has-children>a::after{content:'\f107';font-family:'Font Awesome 6 Free';font-weight:900;margin-left:4px;float:none;font-size:.65rem}
    .site-logo img,.site-logo .custom-logo{height:65px}
    .site-header .container{min-height:85px}
    .hero{min-height:65vh}
    .hero__title{font-size:3.2rem}
    .intro-overlap__text{padding:60px 50px}
    .intro-text__title{font-size:2rem}
    .intro-overlap-grid{margin-top:-120px}
    .footer-grid{grid-template-columns:1fr 1fr 1fr 1.2fr}
    .cookie-notice .container{flex-direction:row;text-align:left}
    .woocommerce ul.products{grid-template-columns:repeat(3,1fr);gap:25px}
    .woocommerce ul.products li.product a img{height:250px}
    .nav-cart{padding:25px 14px}
}

/* ==========================================================================
   RESPONSIVE - 1200px
   ========================================================================== */
@media(min-width:1200px){
    .hero__title{font-size:3.8rem}
    .woocommerce ul.products{grid-template-columns:repeat(4,1fr)}
    .sponsors-grid{grid-template-columns:repeat(3,1fr)}
}

/* ==========================================================================
   UTILITIES
   ========================================================================== */
.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}
.mt-0{margin-top:0}.mt-1{margin-top:15px}.mt-2{margin-top:30px}.mt-3{margin-top:45px}
.mb-0{margin-bottom:0}.mb-1{margin-bottom:15px}.mb-2{margin-bottom:30px}.mb-3{margin-bottom:45px}
.py-1{padding-top:15px;padding-bottom:15px}.py-2{padding-top:30px;padding-bottom:30px}.py-3{padding-top:45px;padding-bottom:45px}
.hidden{display:none}
.alignleft{float:left;margin:0 20px 20px 0}.alignright{float:right;margin:0 0 20px 20px}
.aligncenter{display:block;margin:20px auto}
.wp-caption{max-width:100%}.wp-caption-text{font-size:.82rem;color:var(--amdg-text-light);text-align:center;padding:8px 0}
@media print{.site-header,.site-footer,.cookie-notice,.menu-toggle,.scroll-top{display:none}body{font-size:12pt;color:#000}}
