/*
Theme Name: DLKV
Theme URI: https://dlkv.nl
Author: DLKV
Description: Simpele one-page site voor korfbalvereniging DLKV uit Didam. Wit en grijs met DLKV-groen als accent.
Version: 1.2
Requires at least: 5.0
Requires PHP: 7.4
*/

/* =========================================================
   KLEUREN  -  zet --green op de echte DLKV-groen
   ========================================================= */
:root{
  --green:#1A7A4E;
  --green-dark:#14613E;
  --green-soft:#E9F4EE;
  --ink:#1F2A30;
  --grey:#667085;
  --line:#E6E8EB;
  --bg:#FFFFFF;
  --bg-soft:#F6F7F8;
  --font:'Figtree',-apple-system,BlinkMacSystemFont,sans-serif;
  --nav-h:68px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:calc(var(--nav-h) + 12px)}
body{font-family:var(--font);color:var(--ink);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{width:min(1120px,92vw);margin-inline:auto}
h1,h2,h3{line-height:1.15;font-weight:800;letter-spacing:-.02em}

/* NAV */
.nav{position:sticky;top:0;z-index:100;height:var(--nav-h);background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:100%}
.logo{display:flex;align-items:center;gap:9px;font-weight:800;font-size:22px;letter-spacing:-.02em}
.logo .dot{width:13px;height:13px;border-radius:50%;background:var(--green);flex:none}
.logo-img img{height:38px;width:auto;display:block}
.nav-links{display:flex;align-items:center;gap:28px;list-style:none}
.nav-links a{font-weight:600;font-size:15px;color:var(--ink);transition:color .15s}
.nav-links a:hover,.nav-links a.active{color:var(--green)}
.burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:42px;height:42px;background:none;border:0;cursor:pointer}
.burger span{display:block;width:24px;height:2.5px;background:var(--ink);border-radius:3px;transition:.3s}

/* HERO / FOTO */
.hero{background:var(--green);padding:clamp(22px,3.2vw,42px) 0}
.hero-card{border-radius:18px;overflow:hidden;aspect-ratio:1360/380;
  background:url('images/hero.jpg') center/cover no-repeat;background-color:var(--green-dark)}
@media(max-width:760px){.hero-card{aspect-ratio:auto;min-height:190px}}

/* SLOGAN-BLOK (groen, korven, volle breedte, slank) */
.welcome{position:relative;overflow:hidden;background:var(--green);color:#fff}
.welcome-inner{position:relative;z-index:1;padding:clamp(11px,1.5vw,19px) 0;max-width:820px}
.welcome h2{color:#fff;font-size:clamp(20px,2.3vw,27px)}
.welcome p{color:rgba(255,255,255,.92);font-size:clamp(14px,1.6vw,17px);margin-top:5px}
.welcome .ring{position:absolute;border-radius:50%;border:13px solid rgba(255,255,255,.14);pointer-events:none}
.welcome .ring.r1{width:150px;height:150px;right:-50px;top:-55px}
.welcome .ring.r2{width:90px;height:90px;right:95px;bottom:-50px}
.lead{color:var(--grey);font-size:clamp(17px,2vw,20px);line-height:1.6;margin-top:14px}

/* lichtgroene sectie */
.section-green{background:var(--green-soft)}

/* SECTIES */
section{padding:clamp(48px,7vw,84px) 0}
.section-soft{background:var(--bg-soft)}
.eyebrow{color:var(--green);font-weight:700;font-size:14px;letter-spacing:.06em;text-transform:uppercase;margin-bottom:10px}
h2{font-size:clamp(28px,4vw,40px)}

/* OVER (tekst links, adressen rechts, vult de breedte) */
.over-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:46px;align-items:start}
.over-text .prose{margin-top:18px}
.over-text .prose p{color:var(--grey);font-size:17px;margin-bottom:14px}
.over-text .prose p:last-child{margin-bottom:0}
.over-aside{display:flex;flex-direction:column;gap:16px}

/* KAARTEN (adressen) */
.card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px;transition:border-color .2s,transform .2s,box-shadow .2s}
.card:hover{border-color:var(--green);transform:translateY(-3px);box-shadow:0 12px 30px rgba(30,158,87,.10)}
.card .pin{color:var(--green);font-weight:700;font-size:13px;letter-spacing:.05em;text-transform:uppercase;margin-bottom:8px}
.card .name{font-weight:700;font-size:17px;margin-bottom:2px}
.card .addr{font-size:16px;line-height:1.65;color:var(--ink)}
.card .maps{display:inline-block;margin-top:12px;color:var(--green);font-weight:700;font-size:14px}
.card .maps:hover{color:var(--green-dark)}

/* TEAMS (met ruimte voor teamfoto) */
.team-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:30px}
.team-card{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:border-color .2s,transform .2s,box-shadow .2s}
.team-card:hover{border-color:var(--green);transform:translateY(-3px);box-shadow:0 12px 30px rgba(30,158,87,.10)}
.team-photo{aspect-ratio:1/1;background:var(--bg-soft);display:flex;align-items:center;justify-content:center;color:var(--grey);font-weight:600;font-size:15px;overflow:hidden}
.team-photo img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.team-body{padding:20px 24px}
.team-body h3{font-size:22px}
.team-body p{color:var(--grey);font-size:15px;margin-top:6px}

/* FOTO'S / SFEER */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:30px}
.shot{aspect-ratio:4/3;border-radius:12px;overflow:hidden;background:var(--green-soft);position:relative}
.shot img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}
.shot:hover img{transform:scale(1.05)}
.shot .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--green);font-weight:600;font-size:14px}
@media(max-width:760px){.gallery-grid{grid-template-columns:1fr 1fr}}

/* UITNODIGING / CTA-BALK */
.cta-band{position:relative;overflow:hidden;background:var(--green)}
.cta-band::before{content:"";position:absolute;width:240px;height:240px;border-radius:50%;border:18px solid rgba(255,255,255,.12);right:-70px;top:-90px;pointer-events:none}
.cta-inner{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:22px;padding:clamp(34px,5vw,52px) 0}
.cta-inner h2{color:#fff}
.cta-inner p{color:rgba(255,255,255,.92);font-size:17px;margin-top:8px;max-width:540px}
.btn{display:inline-block;background:var(--green);color:#fff;font-weight:700;font-size:16px;padding:13px 26px;border-radius:30px;border:0;cursor:pointer;transition:background .2s,transform .2s}
.btn:hover{background:var(--green-dark);transform:translateY(-2px)}
.btn-light{background:#fff;color:var(--green-dark)}
.btn-light:hover{background:#f1f1f1}

/* CONTACT (formulier links, info rechts) */
.contact-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:46px;align-items:start;margin-top:30px}
.contact-form{display:flex;flex-direction:column;gap:14px}
.contact-form label{display:flex;flex-direction:column;gap:6px;font-weight:600;font-size:14px;color:var(--ink)}
.contact-form input,.contact-form textarea{font-family:inherit;font-size:16px;padding:12px 14px;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--ink);width:100%}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px var(--green-soft)}
.contact-form .hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;overflow:hidden}
.contact-form .btn{align-self:flex-start;margin-top:4px}
.contact-aside{background:var(--bg-soft);border:1px solid var(--line);border-radius:14px;padding:26px}
.contact-aside h3{font-size:18px;margin-bottom:8px;margin-top:22px}
.contact-aside h3:first-child{margin-top:0}
.contact-aside p{color:var(--grey);font-size:15px;margin-bottom:14px}
.contact-aside a{color:var(--green);font-weight:700}
.contact-aside a:hover{color:var(--green-dark)}
.form-msg{padding:14px 16px;border-radius:10px;font-weight:600;margin-top:20px;max-width:560px}
.form-msg.ok{background:var(--green-soft);color:var(--green-dark)}
.form-msg.err{background:#FDECEC;color:#B42318}

/* FOOTER */
footer{background:var(--green);color:rgba(255,255,255,.82);padding:30px 0;font-size:14px}
.foot-inner{display:flex;flex-wrap:wrap;justify-content:space-between;gap:10px;align-items:center}
.foot-inner .logo{font-size:18px;color:#fff}
.foot-inner .logo .dot{background:#fff}

/* ANIMATIE */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* WORDPRESS ADMINBALK */
.admin-bar .nav{top:32px}
@media screen and (max-width:782px){.admin-bar .nav{top:46px}}

/* RESPONSIVE */
@media(max-width:860px){
  .over-grid,.contact-grid{grid-template-columns:1fr;gap:28px}
}
@media(max-width:760px){
  .team-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr;gap:20px 1px}
  .cta-inner{flex-direction:column;align-items:flex-start}
  .burger{display:flex}
  .nav-links{position:fixed;top:var(--nav-h);left:0;right:0;background:#fff;flex-direction:column;align-items:flex-start;gap:0;
    padding:8px 6vw 20px;border-bottom:1px solid var(--line);transform:translateY(-135%);transition:transform .3s ease;box-shadow:0 16px 30px rgba(0,0,0,.08)}
  .nav-links.open{transform:translateY(0)}
  .nav-links li{width:100%}
  .nav-links a{display:block;width:100%;padding:14px 0;font-size:17px;border-bottom:1px solid var(--line)}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}}
