
:root{
  --brand:#6AA585;      /* soft green */
  --brand-2:#4E876B;    /* darker green */
  --accent:#D6B56E;     /* warm gold accent (for small highlights) */
  --text:#1d1d1f;
  --muted:#6b7280;
  --bg:#ffffff;
  --bg-alt:#f7faf8;
  --radius:14px;
  --shadow:0 10px 25px rgba(0,0,0,.06);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0; font-family: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Arial; color:var(--text); background:var(--bg); line-height:1.6}
.container{width:min(1100px, 92%); margin-inline:auto}

/* Header */
header.site{position:sticky; top:0; background:#fff; border-bottom:1px solid #f1f3f2; z-index:50}
nav{display:flex; align-items:center; justify-content:space-between; gap:1rem; padding: .85rem 0}
.logo img{height:50px; width:auto}
.nav-links{display:flex; gap:.6rem; align-items:center}
.nav-links a{color:var(--text); text-decoration:none; padding:.5rem .7rem; border-radius:8px; font-weight:600}
.nav-links a:hover{background:#f0f6f2}
.menu-toggle{display:none; background:transparent; border:0; font-size:1.5rem}

/* Hero */
.hero{background:linear-gradient(180deg, #f7faf8 0%, #ffffff 60%); padding: clamp(2rem, 6vw, 4rem) 0 2rem}
.hero .grid{display:grid; gap:2rem; align-items:center; grid-template-columns: 1fr 1fr}
.hero h1{font-size: clamp(2.2rem, 4.2vw, 3rem); line-height:1.15; margin:.25rem 0 .4rem; text-align:left}
.hero p{color:var(--muted); font-size:1.1rem}
.hero .hero-big-logo img{max-width:360px}
.hero .cta{display:flex; gap:.75rem; flex-wrap:wrap; margin-top:1rem}

/* Buttons */
.btn{display:inline-block; padding:.9rem 1.15rem; border-radius:999px; text-decoration:none; background:var(--brand); color:#fff; font-weight:700; border:0; cursor:pointer; box-shadow:var(--shadow); transition:transform .08s ease, background .2s ease}
.btn:hover{transform:translateY(-1px); background:var(--brand-2)}
.btn.ghost{background:transparent; color:var(--brand); border:2px solid var(--brand); box-shadow:none}
.btn.block{display:block; width:100%; text-align:center}

/* Sections & Cards */
.section{padding: clamp(2rem, 6vw, 4rem) 0}
.section h2{font-size: clamp(1.8rem, 3.2vw, 2.2rem); margin:0 0 1rem; text-align:center}
.grid-3{display:grid; gap:1.25rem; grid-template-columns: repeat(3, 1fr)}
.grid-2{display:grid; gap:1.25rem; grid-template-columns: repeat(2, 1fr)}
.card{background:#fff; border-radius:18px; padding:1.25rem 1.4rem; box-shadow:var(--shadow)}

/* KPIs */
.kpis{display:grid; grid-template-columns: repeat(3, 1fr); gap:1rem; margin-top:1rem}
.kpi{background:#fff; padding:1rem; border-radius:14px; text-align:center; box-shadow:var(--shadow)}
.kpi strong{display:block; font-size:1.5rem}

/* Forms */
form label{display:block; font-weight:600; margin:.75rem 0 .35rem}
input, select, textarea{width:100%; padding:.85rem 1rem; border:1px solid #e5e7eb; border-radius:12px; font:inherit; outline:none}
input:focus, select:focus, textarea:focus{border-color:var(--brand); box-shadow:0 0 0 3px rgba(106,165,133,.16)}
.form-row{display:grid; grid-template-columns: repeat(2, 1fr); gap:1rem}
.help{color:var(--muted); font-size:.92rem}

/* Footer */
footer{border-top:1px solid #edf1ee; padding:2rem 0; margin-top:2rem; background:#fff}
footer .cols{display:grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap:1.5rem}
footer a{color:var(--text); text-decoration:none}
small.disclaimer{color:var(--muted); display:block; margin-top:1rem}
.badges{display:flex; gap:1.25rem; align-items:center; flex-wrap:wrap; margin-top:1rem}
.badge{padding:.35rem .6rem; border:1px solid #e6e9e7; border-radius:999px; font-size:.9rem; color:#4b5563; background:#f8fbf9}

/* Responsive */
@media (max-width: 980px){
  .hero .grid{grid-template-columns: 1fr}
  .nav-links{display:none; position:absolute; top:56px; right:4%; background:#fff; padding:.75rem; border-radius:12px; box-shadow:var(--shadow); flex-direction:column; min-width:240px}
  .menu-toggle{display:block}
  .nav-links.open{display:flex}
  .grid-3{grid-template-columns: 1fr}
  .grid-2{grid-template-columns: 1fr}
}


/* Horizontal gallery with fading edges */
.gallery-strip-wrap{position:relative}
.gallery-strip{
  position:relative;
  overflow-x:auto;
  display:flex;
  gap:14px;
  scroll-behavior:smooth;
  padding: 6px 30px; /* space for fades */
  scroll-snap-type:x proximity;
}
.gallery-strip img{
  height:200px;
  width:auto;
  border-radius:12px;
  flex-shrink:0;
  display:block;
  scroll-snap-align:center;
  box-shadow:0 8px 18px rgba(0,0,0,.06);
}
.gallery-strip-wrap::before,
.gallery-strip-wrap::after{
  content:"";
  position:absolute;
  top:0; bottom:0;
  width:60px;
  pointer-events:none;
  z-index:2;
}
.gallery-strip-wrap::before{
  left:0;
  background: linear-gradient(to right, var(--bg) 60%, transparent);
}
.gallery-strip-wrap::after{
  right:0;
  background: linear-gradient(to left, var(--bg) 60%, transparent);
}


/* Full width banner with fading sides */
.fade-sides-full{
  position:relative;
  overflow:hidden;
}
.fade-sides-full img{
  display:block;
  width:100%;
  height:auto;
}
.fade-sides-full::before,
.fade-sides-full::after{
  content:"";
  position:absolute;
  top:0; bottom:0;
  width:100px;
  pointer-events:none;
  z-index:2;
}
.fade-sides-full::before{
  left:0;
  background:linear-gradient(to right, white 60%, transparent);
}
.fade-sides-full::after{
  right:0;
  background:linear-gradient(to left, white 60%, transparent);
}


/* --- Hero banner with fixed background (parallax) --- */
.hero-banner{
  position:relative;
  min-height:72vh;
  background: url('assets/smile-banner-v3.jpg') center/cover no-repeat fixed;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
}
.hero-banner .overlay{
  position:absolute; inset:0;
  background:linear-gradient(to bottom, rgba(0,0,0,.35), rgba(0,0,0,.25));
}
.hero-banner .inner{
  position:relative; z-index:1;
  padding: clamp(1rem, 3vw, 2rem);
  color:#fff;
}
.hero-banner .inner img.logo-hero{
  width:min(300px, 60vw);
  height:auto;
  display:block;
  margin:0 auto .6rem;
  filter: drop-shadow(0 4px 18px rgba(0,0,0,.35));
}
.hero-banner .inner .slogan{
  font-size: clamp(1.3rem, 3.2vw, 2rem);
  font-weight: 800;
  letter-spacing:.2px;
  text-shadow: 0 2px 12px rgba(0,0,0,.45);
}

/* Small helper to separate hero from next section */
.section-after-hero{ margin-top: clamp(1.2rem, 3vw, 2rem); }


/* Footer affiliation logos (bottom-right) */
.affil-logos{display:flex; gap:10px; align-items:center; justify-content:flex-end}
.affil-logos img{height:50px; width:auto; display:block; filter: drop-shadow(0 1px 3px rgba(0,0,0,.08));}
@media (max-width: 700px){
  .footer-affiliations{ text-align:center !important; }
  .affil-logos{ justify-content:center }
}

.hero-banner.behandelingen{
  background: url('assets/behandelingen-banner.jpg') center/cover no-repeat fixed;
}

/* ===== Mobile-friendly tweaks ===== */
@media (max-width: 900px){
  .container{ padding-left:16px; padding-right:16px; }
  header nav{ gap:8px; }
  .nav-links{ flex-wrap:wrap; gap:8px; }
  .nav-links a{ padding:8px 10px; }
  .btn{ padding:10px 14px; }
  .grid-2{ display:block; }
  .grid-2 > *{ margin-bottom:16px; }
  .hero-banner.home,
  .hero-banner.behandelingen{
    background-attachment: scroll;
    min-height: 52vh;
  }
  .footer-affiliations{ text-align:center !important; margin-top:14px; }
  .affil-logos{ justify-content:center; }
}
@media (max-width: 480px){
  .nav-links a{ font-size:.95rem; }
  .logo{ font-size:1rem; }
  h1, .title{ font-size: clamp(1.6rem, 6vw, 2rem); }
  .btn{ padding:9px 12px; }
}

/* Prevent images from overflowing on narrow screens */
img{ max-width:100%; height:auto; }





/* Stijl voor de introductiesectie van Fadime */
.intro-fadime {
  background-color: #f7faf8;
  padding: 3rem 1rem;
  margin: 2rem 0;
  border-radius: 8px;
  text-align: center;
}

.intro-fadime h2 {
  color: #2a6c4f;
  margin-bottom: 1rem;
}


/* Specialismen sectie */
.specialismen {
  padding: 4rem 1rem;
  text-align: center;
}

.specialismen h2 {
  color: #2a6c4f;
  margin-bottom: 2rem;
}

.specialismen-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 2rem;
}

.specialisme-box {
  background: #fff;
  border: 1px solid #eee;
  padding: 2rem;
  border-radius: 8px;
  text-align: left;
}

.specialisme-box h3 {
  color: #b07b84;
  margin-bottom: 1rem;
}


.specialisme-box .icon {
  display: inline-block;
  margin-bottom: 0.5rem;
}
.specialisme-box {
  /* behoud bestaande styles uit eerdere stap */
}


/* Voor praktijken layout */
.vp-wrap{
  display:grid;
  grid-template-columns: 1.35fr .9fr;
  gap: clamp(1rem, 3vw, 2rem);
  align-items:center;
}
.vp-text h1 + p{margin-top:.5rem}
.vp-media{
  display:flex;
  justify-content:center;
}
.vp-media img{
  max-width: 420px;
  width: 100%;
  height: auto;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  object-fit: contain;
}
@media (max-width: 900px){
  .vp-wrap{grid-template-columns: 1fr;}
  .vp-media{order:-1}
}
