/* ========================================
   MARIO VAN SOELEN — SHARED STYLESHEET
   ======================================== */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700;800&display=swap');

:root{--accent:#2563EB;--accent-light:#EFF6FF;--accent-dark:#1D4ED8;--bg:#fff;--dark:#0F172A;--text:#475569;--grey:#F8FAFC;--border:#E2E8F0;--radius:12px}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:'Poppins',sans-serif;font-weight:300;overflow-x:hidden}
a{color:inherit}
img{max-width:100%;display:block}

/* ── NAV ─────────────────────────────── */
nav{position:fixed;top:0;width:100%;z-index:100;background:#fff;box-shadow:0 1px 20px rgba(0,0,0,.06)}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center;height:72px}
.nav-logo{text-decoration:none;cursor:pointer}
.nav-logo span{font-weight:700;font-size:1.1rem;color:var(--dark)}
.nav-links{display:flex;gap:2rem;list-style:none;align-items:center}
.nav-links a{color:var(--text);text-decoration:none;font-size:.85rem;font-weight:500;transition:.3s}
.nav-links a:hover{color:var(--accent)}
.nav-cta{background:var(--accent);color:#fff!important;padding:.65rem 1.8rem;border-radius:50px;text-decoration:none;font-size:.85rem;font-weight:600;transition:.3s;box-shadow:0 4px 15px rgba(37,99,235,.25)}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 8px 25px rgba(37,99,235,.35)}
.dropdown{position:relative}
.dropdown-menu{display:none;position:absolute;top:100%;left:0;background:#fff;box-shadow:0 10px 40px rgba(0,0,0,.1);border-radius:var(--radius);padding:.5rem 0;min-width:200px;z-index:200;list-style:none}
.dropdown:hover .dropdown-menu{display:block}
.dropdown-menu a{display:block;padding:.6rem 1.5rem;font-size:.85rem;white-space:nowrap}
.dropdown-menu a:hover{background:var(--accent-light);color:var(--accent)}
.hamburger{display:none;background:none;border:none;cursor:pointer;padding:.5rem;flex-direction:column;gap:5px}
.hamburger span{display:block;width:24px;height:2px;background:var(--dark);transition:.3s}

/* ── HERO (home) ─────────────────────── */
.hero{position:relative;min-height:85vh;display:flex;align-items:center;padding-top:72px;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(15,23,42,.8) 0%,rgba(15,23,42,.35) 60%,rgba(37,99,235,.15) 100%)}
.hero-content{position:relative;z-index:2;max-width:580px;padding:4rem;color:#fff;background:rgba(15,23,42,.55);backdrop-filter:blur(4px);border-radius:var(--radius);margin:2rem}
.hero-eyebrow{font-size:.8rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:1.2rem;font-weight:500}
.hero-content h1{font-size:clamp(2.2rem,4.5vw,3.2rem);font-weight:800;line-height:1.15;margin-bottom:1.2rem}
.hero-content h1 span{color:#60A5FA}
.hero-content p{font-size:.95rem;opacity:.7;line-height:1.9;margin-bottom:2rem}
.btn-hero{display:inline-block;padding:1rem 2.5rem;background:var(--accent);color:#fff;text-decoration:none;border-radius:50px;font-weight:700;font-size:.9rem;transition:.3s;box-shadow:0 8px 30px rgba(37,99,235,.4)}
.btn-hero:hover{transform:translateY(-2px);box-shadow:0 12px 35px rgba(37,99,235,.5)}

/* ── HERO FULL + FLOATING TEXT ────────── */
.hero-full-wrap{margin-top:72px}
.hero-full{position:relative;height:calc(100vh - 72px - 70px);overflow:hidden}
.hero-full-img{width:100%;height:100%;object-fit:cover;object-position:center center;display:block}
.hero-full-text{position:absolute;top:50%;left:2rem;transform:translateY(-50%);width:40%;max-width:500px;background:rgba(0,0,0,.55);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);padding:2.5rem;color:#fff;border-radius:var(--radius)}
.hero-full-text h1{font-size:clamp(1.5rem,2.5vw,2.2rem);font-weight:800;line-height:1.2;margin-bottom:.3rem;white-space:nowrap}
.hero-full-eyebrow{font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:1.8rem}
.hero-full-text h2{font-size:clamp(1.1rem,2vw,1.5rem);font-weight:600;color:#60A5FA;margin-bottom:.7rem}
.hero-full-body{font-size:.88rem;opacity:.65;line-height:1.9;margin-bottom:1.8rem}
.hero-stats-bar{display:grid;grid-template-columns:repeat(4,1fr);background:var(--dark);height:70px}
.hero-stat-item{display:flex;align-items:center;gap:.8rem;color:#fff;padding:0 1.5rem;border-right:1px solid rgba(255,255,255,.06)}
.hero-stat-item:last-child{border-right:none}
.hero-stat-icon{font-size:1.2rem;flex-shrink:0}
.hero-stat-item strong{display:block;font-size:.75rem;font-weight:600}
.hero-stat-item span{font-size:.65rem;opacity:.4}

/* ── PAGE HERO (subpages) ────────────── */
.page-hero{padding:8rem 2rem 4rem;text-align:center;background:linear-gradient(135deg,var(--accent-light) 0%,#fff 100%)}
.page-hero h1{font-size:clamp(2rem,4vw,3rem);color:var(--dark);font-weight:800;margin-bottom:1rem}
.page-hero p{font-size:1rem;max-width:600px;margin:0 auto;line-height:1.8}

/* ── CONTENT SECTIONS ────────────────── */
.content-section{padding:5rem 2rem;max-width:1200px;margin:0 auto}
.content-narrow{max-width:800px;margin:0 auto}
.sect-header{text-align:center;margin-bottom:4rem}
.sect-eyebrow{font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:.5rem;font-weight:600}
.sect-title{font-size:clamp(1.8rem,3vw,2.5rem);color:var(--dark);font-weight:700}

/* ── USP BAR ─────────────────────────── */
.usp-bar{background:var(--dark);padding:3.5rem 2rem}
.usp-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}
.usp-item{display:flex;align-items:center;gap:1rem;color:#fff}
.usp-icon{width:48px;height:48px;background:rgba(37,99,235,.2);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}
.usp-item strong{display:block;font-size:.9rem;font-weight:600;margin-bottom:.2rem}
.usp-item span{font-size:.75rem;opacity:.5}

/* ── ABOUT SPLIT ─────────────────────── */
.about-split{display:grid;grid-template-columns:1fr 1.2fr;gap:4rem;align-items:center;padding:5rem 2rem;max-width:1200px;margin:0 auto}
.about-image{position:relative}
.about-image img{width:100%;border-radius:var(--radius);height:420px;object-fit:cover}
.about-accent{position:absolute;top:-1rem;right:-1rem;width:100%;height:100%;border:3px solid var(--accent);border-radius:var(--radius);z-index:-1;opacity:.15}
.about-text h2{font-size:clamp(1.8rem,2.5vw,2.2rem);color:var(--dark);font-weight:700;margin-bottom:1.5rem}
.about-text p{font-size:.95rem;line-height:2;margin-bottom:1rem}

/* ── PRICING CARDS ───────────────────── */
.pkg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-bottom:3rem}
.pkg-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;max-width:800px;margin:0 auto 3rem}
.pkg-card{background:#fff;border:2px solid var(--border);border-radius:var(--radius);padding:2.5rem;text-align:center;transition:.4s;position:relative}
.pkg-card:hover{border-color:var(--accent);transform:translateY(-5px);box-shadow:0 20px 60px rgba(0,0,0,.08)}
.pkg-card.featured{border-color:var(--accent);background:var(--accent-light)}
.pkg-card.featured::before{content:'Meest gekozen';position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;padding:.3rem 1.2rem;border-radius:50px;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase}
.pkg-icon{font-size:2.5rem;margin-bottom:1.5rem}
.pkg-name{font-size:1.2rem;font-weight:700;color:var(--dark);margin-bottom:.5rem}
.pkg-price{font-size:2rem;font-weight:800;color:var(--accent);margin-bottom:1.5rem}
.pkg-price small{font-size:.85rem;font-weight:400;color:var(--text)}
.pkg-price s{font-size:1rem;opacity:.5;font-weight:400}
.pkg-features{list-style:none;text-align:left;margin-bottom:2rem}
.pkg-features li{padding:.5rem 0;border-bottom:1px solid rgba(0,0,0,.04);font-size:.85rem;display:flex;align-items:center;gap:.6rem}
.pkg-features li::before{content:'✓';color:var(--accent);font-weight:700}
.pkg-cta{display:inline-block;width:100%;padding:.9rem;background:var(--dark);color:#fff;text-decoration:none;border-radius:50px;font-weight:600;font-size:.85rem;transition:.3s;border:none;cursor:pointer;text-align:center}
.pkg-card.featured .pkg-cta{background:var(--accent)}
.pkg-cta:hover{opacity:.9;transform:translateY(-1px)}

/* ── PRICE TABLE ─────────────────────── */
.price-table{margin:2rem 0}
.price-table table{width:100%;border-collapse:collapse}
.price-table th{text-align:left;padding:.8rem 1rem;background:var(--dark);color:#fff;font-size:.8rem;font-weight:600;letter-spacing:.05em}
.price-table td{padding:.8rem 1rem;border-bottom:1px solid var(--border);font-size:.9rem}
.price-table tr:hover td{background:var(--accent-light)}
.price-table td:last-child{font-weight:600;color:var(--accent);white-space:nowrap}

/* ── INFO BOX ────────────────────────── */
.info-box{background:var(--accent-light);border-left:4px solid var(--accent);padding:2rem;border-radius:0 var(--radius) var(--radius) 0;margin:2rem 0}
.info-box h3{color:var(--dark);font-weight:700;margin-bottom:.5rem;font-size:1rem}
.info-box p,.info-box ul{font-size:.9rem;line-height:1.8}
.info-box ul{padding-left:1.2rem;margin-top:.5rem}

/* ── LEARN GRID ──────────────────────── */
.learn-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin:2rem 0}
.learn-item{display:flex;flex-direction:column;padding:1.5rem;background:var(--grey);border-radius:var(--radius);text-align:center}
.learn-icon{font-size:1.5rem;margin-bottom:.8rem}
.learn-item h4{color:var(--dark);font-weight:600;font-size:.85rem;margin-bottom:.4rem}

/* ── OVERVIEW GRID ───────────────────── */
.overview-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}
.overview-card{background:#fff;border:2px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:.4s}
.overview-card:hover{border-color:var(--accent);transform:translateY(-5px);box-shadow:0 20px 60px rgba(0,0,0,.08)}
.overview-card-icon{height:160px;background:var(--accent-light);display:flex;align-items:center;justify-content:center;font-size:3.5rem}
.overview-card-body{padding:2rem}
.overview-card-body h3{font-size:1.2rem;color:var(--dark);font-weight:700;margin-bottom:.5rem}
.overview-card-body p{font-size:.85rem;line-height:1.8;margin-bottom:1rem}
.overview-price{font-size:1.1rem;font-weight:700;color:var(--accent);margin-bottom:1.5rem}
.overview-btn{display:inline-block;padding:.7rem 2rem;background:var(--dark);color:#fff;text-decoration:none;border-radius:50px;font-size:.8rem;font-weight:600;transition:.3s}
.overview-card:hover .overview-btn{background:var(--accent)}

/* ── CTA BAND ────────────────────────── */
.cta-band{background:var(--accent);padding:5rem 2rem;text-align:center;color:#fff}
.cta-band h2{font-size:clamp(1.8rem,3vw,2.5rem);font-weight:700;margin-bottom:1rem}
.cta-band p{opacity:.8;max-width:500px;margin:0 auto 2rem;line-height:1.8}
.cta-band a{display:inline-block;padding:1rem 3rem;background:#fff;color:var(--accent);text-decoration:none;border-radius:50px;font-weight:700;font-size:.9rem;transition:.3s}
.cta-band a:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(0,0,0,.15)}

/* ── CAROUSEL ────────────────────────── */
.carousel-wrap{position:relative;overflow:hidden;margin-top:3rem}
.carousel-track{display:flex;transition:transform .5s ease}
.carousel-slide{min-width:33.333%;padding:0 .75rem;flex-shrink:0}
.rev-card{background:#fff;border-radius:var(--radius);padding:2rem;border:1px solid var(--border);height:100%}
.rev-stars{color:#FBBF24;font-size:1rem;margin-bottom:1rem}
.rev-text{font-size:.9rem;line-height:1.9;font-style:italic;margin-bottom:1.5rem}
.rev-author{font-weight:600;color:var(--dark);font-size:.85rem}
.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:50%;background:#fff;border:1px solid var(--border);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2rem;transition:.3s;z-index:5;box-shadow:0 4px 15px rgba(0,0,0,.08)}
.carousel-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.carousel-prev{left:.5rem}
.carousel-next{right:.5rem}
.carousel-dots{display:flex;justify-content:center;gap:.5rem;margin-top:2rem}
.carousel-dot{width:10px;height:10px;border-radius:50%;background:var(--border);cursor:pointer;transition:.3s;border:none}
.carousel-dot.active{background:var(--accent);transform:scale(1.2)}

/* ── PHOTO GRID ──────────────────────── */
.photo-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;border-radius:var(--radius);overflow:hidden}
.photo-grid-item{height:220px;overflow:hidden}
.photo-grid-item img{width:100%;height:100%;object-fit:cover;transition:.4s;filter:brightness(.9)}
.photo-grid-item:hover img{filter:brightness(1);transform:scale(1.05)}

/* ── CONTACT FORM ────────────────────── */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:4rem;align-items:start}
.contact-sidebar{padding:2rem;background:var(--grey);border-radius:var(--radius)}
.ct-item{display:flex;gap:1rem;margin-bottom:2rem;align-items:flex-start}
.ct-icon{width:44px;height:44px;background:var(--accent-light);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.ct-item strong{display:block;color:var(--dark);font-weight:600;margin-bottom:.2rem;font-size:.9rem}
.ct-item span,.ct-item a{font-size:.85rem;color:var(--text);text-decoration:none}
.ct-item a:hover{color:var(--accent)}
.contact-map{border-radius:var(--radius);overflow:hidden;height:250px;margin-top:1rem}
.contact-map iframe{width:100%;height:100%;border:none}
.form-group{margin-bottom:1.5rem}
.form-group label{display:block;font-size:.8rem;font-weight:600;color:var(--dark);margin-bottom:.5rem}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:.9rem 1.2rem;border:2px solid var(--border);border-radius:var(--radius);font-family:inherit;font-size:.9rem;transition:.3s;background:#fff}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.toggle-group{display:flex;border:2px solid var(--border);border-radius:50px;overflow:hidden;margin-bottom:1.5rem}
.toggle-btn{flex:1;padding:.9rem;text-align:center;font-size:.85rem;font-weight:600;cursor:pointer;border:none;background:#fff;color:var(--text);transition:.3s;font-family:inherit}
.toggle-btn.active{background:var(--accent);color:#fff}
.toggle-btn:hover:not(.active){background:var(--accent-light)}
.radio-group{display:flex;flex-wrap:wrap;gap:.8rem;margin-bottom:1.5rem}
.radio-group label{display:flex;align-items:center;gap:.5rem;padding:.7rem 1.2rem;border:2px solid var(--border);border-radius:50px;cursor:pointer;font-size:.85rem;font-weight:500;transition:.3s}
.radio-group input{display:none}
.radio-group label:has(input:checked){border-color:var(--accent);background:var(--accent-light);color:var(--accent)}
.submit-btn{width:100%;padding:1.1rem;background:var(--accent);color:#fff;border:none;border-radius:50px;font-size:1rem;font-weight:700;cursor:pointer;transition:.3s;font-family:inherit}
.submit-btn:hover{background:var(--accent-dark);transform:translateY(-1px);box-shadow:0 8px 25px rgba(37,99,235,.3)}
.form-success{display:none;text-align:center;padding:3rem;background:var(--accent-light);border-radius:var(--radius);margin-top:2rem}
.form-success h3{color:var(--accent);font-size:1.3rem;margin-bottom:.5rem}

/* ── FOOTER ──────────────────────────── */
footer{background:var(--dark);color:rgba(255,255,255,.5);padding:4rem 2rem 0}
.footer-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:3rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-brand{font-weight:700;font-size:1.2rem;color:#fff;margin-bottom:.5rem}
.footer-col strong{display:block;color:#fff;font-weight:600;font-size:.9rem;margin-bottom:1rem}
.footer-col p{font-size:.85rem;margin-bottom:.5rem;line-height:1.6}
.footer-col a{color:rgba(255,255,255,.4);text-decoration:none;transition:.3s}
.footer-col a:hover{color:var(--accent)}
.footer-bottom{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;padding:1.5rem 0;font-size:.75rem;opacity:.4}
.footer-bottom a{color:inherit}


/* ── ANIMATIONS ──────────────────────── */
.reveal{opacity:0;transform:translateY(25px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ── RESPONSIVE ──────────────────────── */
@media(max-width:768px){

/* Nav */
.hamburger{display:flex}
.nav-links{display:none;position:fixed;top:72px;left:0;right:0;background:#fff;flex-direction:column;padding:2rem;gap:1rem;box-shadow:0 10px 40px rgba(0,0,0,.1);z-index:200}
.nav-links.open{display:flex}
.nav-cta{display:none}

/* 4. Mobile dropdown — tap to toggle, not hover */
.dropdown-menu{position:static;box-shadow:none;padding-left:1.5rem;display:none;flex-direction:column;gap:0}
.dropdown:hover .dropdown-menu{display:none}
.dropdown.open .dropdown-menu{display:flex}
.dropdown-menu a{padding:.5rem 0;font-size:.9rem;opacity:.8}

/* 1. Hero text — centered vertically */
.hero-full{height:75vh;position:relative}
.hero-full-text{width:90%;max-width:none;left:5%;right:5%;top:50%;bottom:auto;transform:translateY(-50%);padding:2rem;border-radius:var(--radius)}
.hero-full-text h1{white-space:normal;font-size:1.4rem}
.hero-stats-bar{grid-template-columns:1fr 1fr;height:auto;padding:.5rem 0}
.hero-stat-item{padding:.8rem 1rem}

/* 2. Carousel arrows hidden */
.carousel-btn{display:none}
.rev-set{grid-template-columns:1fr!important}

/* 3. Photo grid — 2x2, hide 5th+ */
.photo-grid{grid-template-columns:1fr 1fr}
.photo-grid-item:nth-child(n+5){display:none}

/* 5. Contact — form above info */
.contact-grid{grid-template-columns:1fr;display:flex;flex-direction:column-reverse}
.form-group input,.form-group textarea,.form-group select{width:100%;min-height:48px;font-size:1rem}
.toggle-group{flex-direction:column}
.toggle-btn{min-height:48px}
.radio-group label{padding:.8rem 1.2rem;min-height:48px}
.submit-btn{min-height:52px;font-size:1.05rem}

/* General */
.about-split{grid-template-columns:1fr;padding:3rem 1.5rem;gap:2rem}
.about-accent{display:none}
.pkg-grid,.pkg-grid-2{grid-template-columns:1fr}
.carousel-slide{min-width:100%}
.overview-grid{grid-template-columns:1fr}
.footer-inner{grid-template-columns:1fr 1fr;gap:2rem}
.footer-bottom{flex-direction:column;gap:.5rem;text-align:center}
.form-row{grid-template-columns:1fr}
.learn-grid{grid-template-columns:1fr}
}
