:root { --kleur-achtergrond: #f5f5f5; --kleur-tekst: #2d2d2d; --kleur-primair: #f7941d; --kleur-primair-contrast: #ffffff; --kleur-zacht: #fff8f0; --font-koppen: Georgia, 'Times New Roman', serif; --font-tekst: Arial, Helvetica, sans-serif; --radius: 12px; } *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; } body { font-family: var(--font-tekst); background-color: var(--kleur-achtergrond); color: var(--kleur-tekst); font-size: 16px; line-height: 1.6; } img { max-width: 100%; height: auto; } a { color: var(--kleur-primair); text-decoration: none; } a:hover { text-decoration: underline; } h1, h2, h3 { font-family: var(--font-koppen); color: var(--kleur-primair); line-height: 1.3; } .container { max-width: 1100px; margin: 0 auto; padding: 0 1rem; } .site-header { background-color: var(--kleur-primair); padding: 0.75rem 1rem; position: sticky; top: 0; z-index: 100; } .header-inner { max-width: 1100px; margin: 0 auto; display: flex; flex-wrap: wrap; align-items: center; gap: 0.75rem 1.5rem; } .logo { display: inline-flex; flex-direction: column; background-color: var(--kleur-primair-contrast); border-radius: var(--radius); padding: 0.35rem 0.6rem; line-height: 1.15; text-decoration: none; min-width: 80px; } .logo-lekker { font-family: var(--font-koppen); font-size: 0.95rem; font-weight: bold; color: var(--kleur-primair); } .logo-makkelijk { font-family: var(--font-koppen); font-size: 0.95rem; font-weight: bold; color: var(--kleur-primair); } .logo-nl { font-family: var(--font-tekst); font-size: 0.8rem; font-weight: bold; color: var(--kleur-tekst); align-self: flex-end; } .main-nav { display: flex; flex-wrap: wrap; gap: 0.5rem 1rem; } .main-nav a { color: var(--kleur-primair-contrast); font-family: var(--font-tekst); font-size: 1rem; font-weight: bold; padding: 0.4rem 0.6rem; border-radius: var(--radius); text-decoration: none; min-height: 44px; display: flex; align-items: center; } .main-nav a:hover { background-color: rgba(255,255,255,0.2); text-decoration: none; } .btn { display: inline-flex; align-items: center; justify-content: center; background-color: var(--kleur-primair); color: var(--kleur-primair-contrast); font-family: var(--font-tekst); font-size: 1rem; font-weight: bold; padding: 0.75rem 1.5rem; border-radius: var(--radius); border: 2px solid var(--kleur-primair); cursor: pointer; text-decoration: none; min-height: 44px; transition: opacity 0.2s; } .btn:hover { opacity: 0.85; text-decoration: none; } .btn-outline { background-color: transparent; color: var(--kleur-primair-contrast); border-color: var(--kleur-primair-contrast); } .btn-outline:hover { background-color: rgba(255,255,255,0.15); } .btn-white { background-color: var(--kleur-primair-contrast); color: var(--kleur-primair); border-color: var(--kleur-primair-contrast); } .btn-white:hover { opacity: 0.9; } .btn-full { width: 100%; } .hero { background-color: var(--kleur-primair); color: var(--kleur-primair-contrast); padding: 4rem 1rem 3rem; text-align: center; } .hero-inner { max-width: 700px; margin: 0 auto; } .hero h1 { color: var(--kleur-primair-contrast); font-size: clamp(1.8rem, 5vw, 3rem); margin-bottom: 1rem; } .hero-sub { font-size: clamp(1rem, 2.5vw, 1.25rem); margin-bottom: 2rem; opacity: 0.95; } .hero-buttons { display: flex; flex-wrap: wrap; gap: 1rem; justify-content: center; } .page-hero { background-color: var(--kleur-primair); color: var(--kleur-primair-contrast); padding: 3rem 1rem 2.5rem; text-align: center; } .page-hero h1 { color: var(--kleur-primair-contrast); font-size: clamp(1.6rem, 4vw, 2.5rem); margin-bottom: 0.75rem; } .page-hero p { font-size: clamp(1rem, 2vw, 1.15rem); opacity: 0.95; max-width: 650px; margin: 0 auto; } .usps { padding: 3rem 1rem; background-color: var(--kleur-achtergrond); } .usps h2 { font-size: clamp(1.4rem, 3vw, 2rem); text-align: center; margin-bottom: 2rem; } .usp-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1.25rem; } .usp-card { background-color: var(--kleur-zacht); border-radius: var(--radius); padding: 1.5rem; text-align: center; border-top: 4px solid var(--kleur-primair); } .usp-icon { font-size: 2.5rem; display: block; margin-bottom: 0.75rem; } .usp-card h3 { font-family: var(--font-koppen); color: var(--kleur-primair); margin-bottom: 0.5rem; font-size: 1.1rem; } .usp-card p { font-size: 0.95rem; } .cta-strip { background-color: var(--kleur-primair); color: var(--kleur-primair-contrast); padding: 2.5rem 1rem; text-align: center; } .cta-strip p { font-size: clamp(1rem, 2vw, 1.15rem); margin-bottom: 1.25rem; } .cta-strip a { color: var(--kleur-primair-contrast); font-weight: bold; } .reviews { padding: 3rem 1rem; background-color: var(--kleur-zacht); } .reviews h2 { font-size: clamp(1.4rem, 3vw, 2rem); text-align: center; margin-bottom: 2rem; } .review-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1.25rem; } .review-card { background-color: var(--kleur-achtergrond); border-radius: var(--radius); padding: 1.5rem; border-left: 4px solid var(--kleur-primair); } .review-stars { color: var(--kleur-primair); font-size: 1.25rem; margin-bottom: 0.5rem; } .review-card p { font-size: 0.95rem; font-style: italic; margin-bottom: 0.75rem; } .review-author { font-size: 0.875rem; font-weight: bold; color: var(--kleur-primair); } .dienst-sectie { padding: 3rem 1rem; background-color: var(--kleur-achtergrond); } .dienst-sectie.alt { background-color: var(--kleur-zacht); } .dienst-grid { display: grid; grid-template-columns: 1fr; gap: 2rem; } .dienst-badge { display: inline-block; background-color: var(--kleur-primair); color: var(--kleur-primair-contrast); border-radius: var(--radius); padding: 0.3rem 0.8rem; font-size: 0.9rem; font-weight: bold; margin-bottom: 0.75rem; } .dienst-tekst h2 { font-size: clamp(1.3rem, 3vw, 1.8rem); margin-bottom: 1rem; } .dienst-tekst p { margin-bottom: 1rem; } .dienst-lijst { list-style: none; margin-bottom: 1.25rem; } .dienst-lijst li { padding: 0.3rem 0; font-size: 0.95rem; } .dienst-visual { display: flex; align-items: flex-start; justify-content: center; } .dienst-kaart { background-color: var(--kleur-zacht); border-radius: var(--radius); border: 3px solid var(--kleur-primair); padding: 2rem; text-align: center; max-width: 280px; width: 100%; } .dienst-kaart span { font-size: 3.5rem; display: block; margin-bottom: 1rem; } .dienst-kaart p { font-size: 1rem; font-weight: bold; color: var(--kleur-primair); } .bbq-kaart { border-color: var(--kleur-primair); } .tijden-sectie { padding: 3rem 1rem; } .tijden-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1.5rem; margin-bottom: 1.5rem; } .tijden-kaart { background-color: var(--kleur-zacht); border-radius: var(--radius); padding: 1.75rem; border-top: 5px solid var(--kleur-primair); } .tijden-kaart.highlight { background-color: var(--kleur-primair); color: var(--kleur-primair-contrast); } .tijden-kaart.highlight h2 { color: var(--kleur-primair-contrast); } .tijden-kaart h2 { font-size: 1.2rem; margin-bottom: 1rem; color: var(--kleur-primair); } .tijden-tabel { width: 100%; border-collapse: collapse; font-size: 0.95rem; } .tijden-tabel th, .tijden-tabel td { padding: 0.5rem 0.25rem; text-align: left; border-bottom: 1px solid rgba(0,0,0,0.1); } .tijden-kaart.highlight .tijden-tabel th, .tijden-kaart.highlight .tijden-tabel td { border-bottom-color: rgba(255,255,255,0.3); } .tijden-tabel th { font-weight: bold; } .zondag-kaart .zondag-lijst { list-style: none; margin: 0.75rem 0 1rem; } .zondag-kaart .zondag-lijst li { padding: 0.3rem 0; font-size: 0.95rem; font-weight: bold; } .gesloten-melding { background-color: var(--kleur-achtergrond); border-radius: var(--radius); padding: 0.5rem 0.75rem; font-size: 0.9rem; display: inline-block; } .bijgewerkt { font-size: 0.85rem; color: #777; text-align: right; margin-top: 0.5rem; } .over-sectie { padding: 3rem 1rem; } .over-grid { display: grid; grid-template-columns: 1fr; gap: 2.5rem; } .over-tekst h2 { font-size: clamp(1.3rem, 3vw, 1.8rem); margin-bottom: 0.75rem; margin-top: 1.5rem; } .over-tekst h2:first-child { margin-top: 0; } .over-tekst p { margin-bottom: 0.75rem; } .over-kaarten { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 1rem; } .over-kaart { background-color: var(--kleur-zacht); border-radius: var(--radius); padding: 1.25rem; text-align: center; border-top: 4px solid var(--kleur-primair); } .over-kaart span { font-size: 2rem; display: block; margin-bottom: 0.5rem; } .over-kaart h3 { font-family: var(--font-koppen); color: var(--kleur-primair); font-size: 1rem; margin-bottom: 0.4rem; } .over-kaart p { font-size: 0.9rem; } .adres-sectie { background-color: var(--kleur-zacht); padding: 3rem 1rem; } .adres-sectie h2 { font-size: clamp(1.3rem, 3vw, 1.8rem); margin-bottom: 1.5rem; } .adres-grid { display: grid; grid-template-columns: 1fr; gap: 1.5rem; } .adres-info p { margin-bottom: 1rem; line-height: 1.8; } .map-placeholder { background-color: var(--kleur-achtergrond); border: 3px dashed var(--kleur-primair); border-radius: var(--radius); padding: 2.5rem; text-align: center; } .map-placeholder span { font-size: 3rem; display: block; margin-bottom: 0.5rem; } .map-placeholder p { font-weight: bold; color: var(--kleur-primair); } .contact-sectie { padding: 3rem 1rem; } .contact-grid { display: grid; grid-template-columns: 1fr; gap: 2.5rem; } .contact-info h2, .contact-form-wrap h2 { font-size: clamp(1.2rem, 3vw, 1.6rem); margin-bottom: 1.25rem; } .contact-blok { display: flex; gap: 0.85rem; margin-bottom: 1.25rem; align-items: flex-start; } .contact-icon { font-size: 1.5rem; flex-shrink: 0; margin-top: 0.1rem; } .contact-blok strong { display: block; color: var(--kleur-primair); font-size: 0.95rem; } .contact-blok p { font-size: 0.95rem; margin-top: 0.2rem; } .form-groep { margin-bottom: 1.25rem; } .form-groep label { display: block; font-weight: bold; margin-bottom: 0.4rem; font-size: 0.95rem; } .form-groep input, .form-groep textarea { width: 100%; padding: 0.75rem; border: 2px solid #ddd; border-radius: var(--radius); font-family: var(--font-tekst); font-size: 1rem; background-color: var(--kleur-achtergrond); color: var(--kleur-tekst); transition: border-color 0.2s; } .form-groep input:focus, .form-groep textarea:focus { outline: none; border-color: var(--kleur-primair); } .form-groep textarea { resize: vertical; min-height: 130px; } .site-footer { background-color: var(--kleur-tekst); color: var(--kleur-primair-contrast); padding: 2.5rem 1rem 0; } .footer-inner { display: grid; grid-template-columns: 1fr; gap: 1.5rem; padding-bottom: 2rem; } .footer-col strong { display: block; color: var(--kleur-primair); font-family: var(--font-koppen); font-size: 1.05rem; margin-bottom: 0.5rem; } .footer-col p { font-size: 0.9rem; line-height: 1.8; } .footer-col a { color: var(--kleur-primair-contrast); font-size: 0.9rem; } .footer-col a:hover { color: var(--kleur-primair); } .footer-nav { display: flex; flex-direction: column; gap: 0.4rem; } .footer-bottom { border-top: 1px solid rgba(255,255,255,0.15); padding: 1rem 0; text-align: center; font-size: 0.85rem; opacity: 0.7; } @media (min-width: 640px) { .dienst-grid { grid-template-columns: 1fr 1fr; } .adres-grid { grid-template-columns: 1fr 1fr; } .contact-grid { grid-template-columns: 1fr 1fr; } .footer-inner { grid-template-columns: repeat(3, 1fr); } .over-grid { grid-template-columns: 1fr 1fr; } } @media (min-width: 768px) { .header-inner { flex-wrap: nowrap; justify-content: space-between; } }

/* stijlthema: speels_kleurrijk__oceaan */
:root {
  --kleur-achtergrond: #ffffff;
  --kleur-tekst: #0f2231;
  --kleur-primair: #0ea5e9;
  --kleur-primair-contrast: #ffffff;
  --kleur-zacht: #e0f2fe;
  --font-koppen: -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  --font-tekst: -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  --radius: 18px;
}
body { font-family: var(--font-tekst); }
h1, h2, h3, h4, h5, h6 { font-family: var(--font-koppen); }
button, input, select, textarea, .btn, [role="button"] { font-family: inherit; }
