/* =============================
   NEWS MODAL STYLES
   ============================= */
#news-modal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1000;
}

.modal-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.8);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

.modal-content {
  background: white;
  border-radius: var(--border-radius);
  box-shadow: var(--shadow-large);
  max-width: 90vw;
  max-height: 90vh;
  width: 100%;
  overflow: hidden;
}

.modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px;
  border-bottom: 1px solid var(--line);
  background: var(--soft);
}

.modal-header h3 {
  margin: 0;
  color: var(--ink);
  font-size: 1.2rem;
}

.modal-close {
  background: none;
  border: none;
  font-size: 24px;
  cursor: pointer;
  color: var(--ink-light);
  padding: 0;
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  transition: var(--transition-fast);
}

.modal-close:hover {
  background: var(--line);
  color: var(--ink);
}

.modal-body {
  padding: 0;
}

.modal-body iframe {
  border: none;
  width: 100%;
  height: 600px;
}

/* =============================
   BASIS / DESIGN TOKENS
   ============================= */
:root{
  --green:#0a7a3d;
  --green-light:#2d8f5a;
  --green-dark:#065a2c;
  --orange:#f58220;
  --orange-light:#ff9a4d;
  --orange-dark:#e06a0a;
  --ink:#0b1d14;
  --ink-light:#2d3d35;
  --line:#e6ece8;
  --soft:#f7f8f7;
  --bg:#ffffff;
  
  /* Modern gradients */
  --gradient-green: linear-gradient(135deg, var(--green) 0%, var(--green-light) 100%);
  --gradient-orange: linear-gradient(135deg, var(--orange) 0%, var(--orange-light) 100%);
  --gradient-hero: linear-gradient(135deg, rgba(10,122,61,0.9) 0%, rgba(245,130,32,0.8) 100%);
  --gradient-card: linear-gradient(145deg, #ffffff 0%, #f8f9fa 100%);
  
  /* Performance optimizations */
  --transition-fast: 0.2s ease;
  --transition-normal: 0.3s ease;
  --transition-slow: 0.5s ease;
  --border-radius: 12px;
  --border-radius-small: 8px;
  --border-radius-large: 16px;
  --shadow-light: 0 2px 6px rgba(0,0,0,0.04);
  --shadow-medium: 0 4px 12px rgba(0,0,0,0.08);
  --shadow-large: 0 8px 24px rgba(0,0,0,0.12);
  --shadow-colored: 0 8px 24px rgba(10,122,61,0.15);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.6;
  font-size:16px;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.wrap{max-width:1120px;margin:0 auto;padding:0 16px}

/* =============================
   HEADER / NAV
   ============================= */
header{
  position:sticky;
  top:0;
  z-index:20;
  background:rgba(255,255,255,0.95);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
  box-shadow:var(--shadow-light);
}
header .top{
  height:72px;
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.brand{
  display:flex;
  align-items:center;
  gap:12px;
  color:var(--green);
  font-weight:800;
  font-size:18px;
  transition:all var(--transition-fast);
}
.brand:hover{
  transform:scale(1.02);
}
.brand img{
  height:40px;
  transition:transform var(--transition-fast);
}
.brand:hover img{
  transform:rotate(5deg);
}
nav{
  display:flex;
  gap:24px;
  align-items:center;
}
nav a{
  color:var(--green);
  font-weight:600;
  padding:8px 16px;
  border-radius:var(--border-radius-small);
  transition:all var(--transition-fast);
  position:relative;
}
nav a::before{
  content:'';
  position:absolute;
  bottom:0;left:50%;right:50%;
  height:2px;
  background:var(--green);
  transition:all var(--transition-fast);
}
nav a:hover{
  color:var(--green-dark);
  background:rgba(10,122,61,0.1);
}
nav a:hover::before{
  left:0;right:0;
}
.lang-switch img{height:18px;width:auto}
/* hamburger */
.hamb{display:none;width:42px;height:42px;border:1px solid var(--line);border-radius:8px;background:transparent;align-items:center;justify-content:center;cursor:pointer}
.hamb span{display:block;width:22px;height:2px;background:var(--green);border-radius:2px;margin:4px 0}

/* mobiel nav */
@media (max-width:900px){
  .hamb{display:flex}
  header .top{position:relative}
  header nav{
    display:none;position:absolute;top:68px;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);
    padding:10px 16px;gap:14px;flex-wrap:wrap;z-index:50
  }
  header.open nav{display:flex}
}

/* =============================
   SECTIES / TITELS / BAND
   ============================= */
  .section{
    padding:40px 0;
    position:relative;
  }
  .section::before{
    content:'';
    position:absolute;
    top:0;left:0;right:0;bottom:0;
    background:linear-gradient(135deg,transparent 0%,rgba(10,122,61,0.02) 50%,transparent 100%);
    pointer-events:none;
  }
  .band{background:var(--soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
  .kicker{color:var(--green);font-weight:800;letter-spacing:.05em;text-transform:uppercase;font-size:12px;margin-bottom:6px}
  h1,h2,h3,h4{
    margin:8px 0 16px;
    font-weight:700;
    line-height:1.3;
    color:var(--ink);
  }
  h1{font-size:2.5rem;background:var(--gradient-green);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
  h2{font-size:2rem;color:var(--green)}
  h3{font-size:1.5rem;color:var(--ink-light)}
  h4{font-size:1.25rem;color:var(--ink)}
  .columns{display:grid;grid-template-columns:1fr 1fr;gap:18px;row-gap: 18px;}
  .card{
  background:var(--gradient-card);
  border:1px solid var(--line);
  border-radius:var(--border-radius-large);
  padding:24px;
  transition:all var(--transition-normal);
  position:relative;
  overflow:hidden;
  box-shadow:var(--shadow-light);
}
.card::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;height:4px;
  background:var(--gradient-green);
  transform:scaleX(0);
  transition:transform var(--transition-normal);
}
.card:hover::before{
  transform:scaleX(1);
}
.card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-large);
  border-color:var(--green-light);
}
  .list{margin:0;padding-left:18px} .list li{margin:6px 0}

/* =============================
   HERO / SLIDER   (laatste versie)
   ============================= */
.hero{position:relative;height:70vh;min-height:520px;overflow:hidden}
.slide{position:absolute;inset:0;display:none}
.slide.active{display:block}
.slide .bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
/* Overlay voor contrast – subtieler voor sponsoren */
.slide::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(0,0,0,.4),rgba(0,0,0,.2) 45%,rgba(0,0,0,.4))
}
.overlay{position:absolute;inset:0;z-index:2;display:flex;align-items:center;justify-content:center;padding:0 24px}
.lines{display:flex;flex-direction:column;gap:10px;align-items:flex-start}
.line{
  color:#fff;
  font-weight:800;
  font-size:30px;
  background:rgba(0,0,0,.3);
  border:1px solid rgba(255,255,255,.5);
  border-radius:12px;
  padding:12px 16px;
  text-shadow:0 2px 4px rgba(0,0,0,.6);
  transition:all var(--transition-fast);
}
.line:hover{
  transform:translateY(-1px);
  box-shadow:0 4px 12px rgba(0,0,0,.3);
}
.arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.6);
  color:#fff;font-size:24px;z-index:3
}
.prev{left:18px}.next{right:18px}
.bullets{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:3}
.bullets button{
  width:8px;height:8px;border-radius:50%;
  border:1px solid rgba(255,255,255,.7);
  background:rgba(255,255,255,.2);cursor:pointer
}
.bullets button.active{background:#fff}
.logo-mark{position:absolute;right:22px;bottom:22px;width:140px;z-index:3;filter:none;opacity:1;mix-blend-mode:normal}
@media (max-width:720px){
  .line{font-size:clamp(16px,5vw,22px);padding:8px 12px}
  .logo-mark{right:12px;bottom:12px;width:120px}
}

/* =============================
   BUTTONS
   ============================= */
.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  border-radius:var(--border-radius);
  padding:12px 20px;
  border:none;
  cursor:pointer;
  font-weight:600;
  font-size:15px;
  transition:all var(--transition-fast);
  text-decoration:none;
  box-shadow:var(--shadow-light);
}
.btn:hover{
  transform:translateY(-1px);
  box-shadow:var(--shadow-medium);
}
.btn:active{
  transform:translateY(0);
}
.btn-green{
  background:var(--green);
  color:#fff;
  border:1px solid var(--green-dark);
}
.btn-green:hover{
  background:var(--green-dark);
  box-shadow:var(--shadow-colored);
}
.btn-orange{
  background:var(--orange);
  color:#fff;
  border:1px solid var(--orange-dark);
}
.btn-orange:hover{
  background:var(--orange-dark);
  box-shadow:0 4px 12px rgba(245,130,32,0.3);
}
.btn-ghost{
  background:#fff;
  color:var(--green);
  border:2px solid var(--green);
  box-shadow:none;
}
.btn-ghost:hover{
  background:var(--green);
  color:#fff;
  box-shadow:var(--shadow-colored);
}

/* =============================
   QR CARD
   ============================= */
.qr-card{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px}
.qr-thumb{width:130px;height:auto;border:1px solid var(--line);border-radius:8px;padding:6px;background:#fff}

/* =============================
   BUSINESS CLUB – PAKKETTEN  (samengevoegd)
   ============================= */
.packages{padding:60px 20px;background:#f9f9f9}
.packages h2{text-align:center;color:var(--green);margin-bottom:20px}
.packages p{text-align:center;max-width:700px;margin:0 auto 40px auto}
.packages-grid{
  display:grid;gap:20px;
  grid-template-columns:repeat(3,1fr);
  max-width:960px;margin:0 auto;
  align-items:stretch;
}
@media (max-width:1024px){ .packages-grid{grid-template-columns:repeat(2,1fr)} }
@media (max-width:640px){ .packages-grid{grid-template-columns:1fr} }

.package-card{
  display:flex;flex-direction:column;justify-content:flex-start;height:100%;
  border:1px solid var(--line);border-radius:8px;padding:20px;background:#fff;transition:transform .2s
}
.package-card:hover{transform:translateY(-4px)}
.package-card h3{color:var(--orange);margin:0 0 10px}
.package-card .price{font-size:1.2em;font-weight:700;margin:0 0 12px}
.package-card ul{list-style:none;padding:0;margin:0}
.package-card ul li{margin:8px 0;color:#333}
.package-card.highlight{border:1px solid var(--line);box-shadow:0 0 0 2px var(--green)}

/* =============================
   HOOFDSPONSOR BLOCK
   ============================= */

.sponsor-highlight {
  display: flex;
  align-items: center;
  gap: 20px;
  background: #fff; /* witte achtergrond voor het kaartje */
  border: 1px solid #d6eadf; /* subtiel lichtgroen randje */
  border-radius: 12px;
  padding: 20px 24px;
  margin: 32px 0;
  box-shadow: 0 2px 6px rgba(0,0,0,0.04); /* heel subtiele schaduw */
}

.sponsor-highlight img {
  width: 100px;
  height: 100px;
  object-fit: contain;
  flex: 0 0 auto;
  border-radius: 8px;
  background: #fff; /* logo op wit */
}

.sponsor-highlight .content {
  flex: 1;
}

.sponsor-highlight h3 {
  font-size: 1.4rem;
  margin: 0 0 10px;
  color: #000; /* zwart */
}

.sponsor-highlight h3 .green {
  color: var(--green); /* alleen 'Van der Velden' groen */
}

.sponsor-highlight p {
  margin: 0 0 14px;
  color: var(--ink);
  line-height: 1.5;
}

.sponsor-highlight .btn {
  background: var(--green);
  color: #fff;
  border-radius: 8px;
  padding: 8px 16px;
  font-weight: 600;
  text-decoration: none;
  display: inline-block;
  box-shadow: 0 2px 0 rgba(0,0,0,0.15);
}

.sponsor-highlight .btn:hover {
  background: #085d2f;
}

@media (max-width: 700px) {
  .sponsor-highlight {
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
  }
  .sponsor-highlight img {
    width: 80px;
    height: auto;
  }
}

.sponsor-card-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

.sponsor-card-inner img {
  max-width: 96px;
  max-height: 96px;
  object-fit: contain;
}

.sponsor-name {
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--ink);
  text-align: center;
}

/* =============================
   FORMULIEREN
   ============================= */
.form{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:14px}
.field{display:flex;flex-direction:column;gap:8px}
.full{grid-column:1/-1}
.label{font-size:14px;font-weight:700;color:var(--ink)}
.input,textarea{
  width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:12px;font-size:15px;background:#fff
}
.input:focus,textarea:focus{outline:none;border-color:#cfe6d8;box-shadow:0 0 0 3px rgba(10,122,61,.12)}
textarea{resize:vertical;min-height:120px}
.agree{display:flex;align-items:center;gap:10px}
.submit-row{display:flex;gap:10px}
.btn-submit{background:var(--green);color:#fff;border:none;border-radius:12px;padding:14px 22px;font-size:16px;cursor:pointer;font-weight:700}
.btn-submit:hover{background:#085d2f}
@media (max-width:900px){ .form{grid-template-columns:1fr} }


/* =============================
   2-KOLOMS INFO (Waarom / Wat je mogelijk maakt)
   ============================= */
.columns{display:grid;grid-template-columns:1fr;gap:12px;align-items:start}
@media (min-width:860px){ 
  .columns{
    grid-template-columns:repeat(2,1fr);
    gap:12px;
  } 
}
.columns .card .kicker{margin-bottom:8px}
.columns .card h2{margin:0 0 12px}
.columns .card .list{margin:0}

/* Fallback zonder CSS Grid */
@supports not (display:grid){
  .columns{display:flex;flex-wrap:wrap;gap:12px}
  .columns .card{flex:1 1 320px}
}

/* =============================
   FLOATING CTA BUTTONS - v26
   ============================= */
.floating-cta{
  position:fixed;
  bottom:20px;
  right:20px;
  display:flex;
  flex-direction:column;
  gap:12px;
  z-index:100;
}

.floating-btn{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:12px 16px;
  border-radius:25px;
  text-decoration:none;
  font-weight:600;
  font-size:14px;
  box-shadow:0 4px 12px rgba(0,0,0,0.15);
  transition:all var(--transition-normal);
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,0.2);
  text-align:center;
}

.floating-btn-primary{
  background:var(--gradient-green);
  color:#fff;
}

.floating-btn-secondary{
  background:var(--gradient-orange);
  color:#fff;
}

.floating-btn:hover{
  transform:translateY(-2px);
  box-shadow:0 6px 20px rgba(0,0,0,0.2);
}

.floating-btn .btn-icon{
  font-size:16px;
  font-weight:400;
  line-height:1;
  color:white;
  opacity:0.9;
  transition:opacity var(--transition-fast);
  display:flex;
  align-items:center;
  justify-content:center;
  filter: brightness(0) invert(1);
}

.floating-btn .btn-icon svg{
  width:20px;
  height:20px;
}

.floating-btn:hover .btn-icon{
  opacity:1;
}

.floating-btn .btn-text{
  white-space:nowrap;
  text-align:center;
  flex:1;
}

/* Hide on mobile to avoid clutter */
@media (max-width:768px){
  .floating-cta{
    bottom:15px;
    right:15px;
  }
  
  .floating-btn .btn-text{
    display:none;
  }
  
  .floating-btn{
    padding:12px;
    border-radius:50%;
    width:48px;
    height:48px;
    justify-content:center;
  }
}

/* =============================
   NIEUWS SECTIE
   ============================= */
.news-container{
  margin:20px 0;
}

.news-item{
  border-bottom:1px solid var(--line);
  padding:16px 0;
  transition:background-color var(--transition-fast);
  display:flex;
  gap:16px;
  align-items:flex-start;
}

.news-item:last-child{
  border-bottom:none;
}

.news-item:hover{
  background-color:rgba(0,0,0,0.02);
  border-radius:8px;
  padding:16px;
  margin:0 -16px;
}

.news-image{
  flex-shrink:0;
  width:120px;
  height:80px;
  border-radius:8px;
  overflow:hidden;
  background:var(--line);
}

.news-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform var(--transition-normal);
}

.news-item:hover .news-image img{
  transform:scale(1.05);
}

.news-content{
  flex:1;
  min-width:0;
}

.news-title{
  font-weight:600;
  font-size:16px;
  line-height:1.4;
  margin:0 0 8px;
  color:var(--text);
}

.news-title a{
  color:inherit;
  text-decoration:none;
  transition:color var(--transition-fast);
}

.news-title a:hover{
  color:var(--green);
}

.news-date{
  font-size:14px;
  color:var(--muted);
  margin:0 0 8px;
}

.news-excerpt{
  font-size:14px;
  line-height:1.5;
  color:var(--muted);
  margin:0;
}

.news-loading{
  text-align:center;
  padding:20px;
  color:var(--muted);
  font-style:italic;
}

.news-footer{
  margin-top:20px;
  text-align:center;
}

.news-error{
  text-align:center;
  padding:20px;
  color:var(--orange);
  background:rgba(255,165,0,0.1);
  border-radius:8px;
  margin:10px 0;
}

/* Mobile responsive news */
@media (max-width:768px){
  .news-item{
    flex-direction:column;
    gap:12px;
  }
  
  .news-image{
    width:100%;
    height:160px;
  }
  
  .news-content{
    width:100%;
  }
}

/* =============================
   FOOTER
   ============================= */
footer{border-top:1px solid var(--line);padding:18px 0;margin-top:28px;background:#fff}
.foot-grid{display:grid;grid-template-columns:2fr 1fr;gap:18px}
.muted{color:#5f6b62}
.foot-title{font-weight:800;margin:0 0 6px}
@media (max-width:900px){ .foot-grid{grid-template-columns:1fr} }

/* =============================
   === UNIFIED GRID + CARD STYLE FOR PARTNERS & SPONSORS ===
   ============================= */

/* Ondersteun beide ids: #sponsor-grid én #sponsors-grid */
#partners-grid,
#sponsor-grid,
#sponsors-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:20px;
  margin-top:24px;
}

/* Sponsor kaartjes - professioneel voor bedrijven */
#partners-grid a,
#sponsor-grid a,
#sponsors-grid a{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  background:#fff;
  border:1px solid #d6eadf;
  border-radius:12px;
  padding:20px;
  box-shadow:0 2px 6px rgba(0,0,0,.04);
  text-decoration:none;
  color:var(--ink);
  transition:all var(--transition-fast);
  min-height:160px;
}

/* Maak elke tegel het positionerings‑anker */
#sponsors-grid a,
#sponsor-grid a{
  position: relative;
  display: block;     /* helpt bij kliks en maat */
  overflow: visible;  /* badge mag buiten de rand steken */
}

/* Badge + highlight voor hoofdsponsor */
#sponsor-grid a.featured,
#sponsors-grid a.featured{
  border:2px solid var(--green);
  background:linear-gradient(135deg,#f8fffe 0%,#ffffff 100%);
}

/* Hover effecten */
#partners-grid a:hover,
#sponsor-grid a:hover,
#sponsors-grid a:hover{
  transform:translateY(-2px);
  box-shadow:0 4px 12px rgba(0,0,0,.08);
  border-color:var(--green);
}

/* Badge gecentreerd bovenin de kaart */
#sponsors-grid a .badge,
#sponsor-grid a .badge{
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: var(--green);
  color: #fff;
  padding: 4px 12px;
  border-radius: 12px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .5px;
  z-index: 2;
  white-space: nowrap;
  text-align: center;
}

/* Inhoud van het kaartje (logo + naam) */
.sponsor-card-inner{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:10px;
}

.sponsor-card-inner img{
  max-width:96px;
  max-height:96px;
  object-fit:contain;
}

.sponsor-name{
  font-size:.9rem;
  font-weight:500;
  color:var(--ink);
}

/* Badge + highlight voor hoofdsponsor */
#sponsor-grid a.featured,
#sponsors-grid a.featured{
  border:2px solid var(--green);
  box-shadow:0 2px 10px rgba(0,128,0,.08);
}

#sponsor-grid a .badge,
#sponsors-grid a .badge{
  position: absolute;
  top: 0%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: var(--green);
  color: #fff;
  border-radius: 999px;
  padding: 6px 14px;
  font-size: 0.8rem;
  font-weight: 700;
  box-shadow: 0 2px 6px rgba(0,0,0,0.12);
  z-index: 2;
  text-transform: uppercase;
  white-space: nowrap;
}