/*
Theme Name: BuitenOpMaatwerk Next Level
Theme URI: https://buitenopmaatwerk.nl
Author: OpenAI
Description: Luxe landelijke WordPress theme voor BuitenOpMaatwerk met homepage, afspraakpagina en Calendly-integratie.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
Text Domain: buitenopmaatwerk
*/

:root{
  --bom-bg:#f5f1ea;
  --bom-bg-soft:#efe7db;
  --bom-paper:#fcfaf7;
  --bom-text:#2d312b;
  --bom-muted:#6c7268;
  --bom-accent:#6b7b57;
  --bom-accent-dark:#44503a;
  --bom-wood:#8d7258;
  --bom-border:#ddd3c6;
  --bom-white:#ffffff;
  --bom-shadow:0 12px 40px rgba(40,32,22,.10);
  --bom-radius:22px;
  --bom-radius-sm:14px;
  --bom-max:1200px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bom-bg);
  color:var(--bom-text);
  font-family: Georgia, "Times New Roman", serif;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
.screen-reader-text{position:absolute;left:-9999px}

.bom-wrap{width:min(calc(100% - 32px), var(--bom-max));margin:0 auto}
.bom-section{padding:84px 0;position:relative}
.bom-section--tight{padding:56px 0}
.bom-paper{
  background:var(--bom-paper);
  border:1px solid rgba(0,0,0,.04);
  border-radius:var(--bom-radius);
  box-shadow:var(--bom-shadow);
}

.bom-topbar{
  position:sticky;top:0;z-index:50;
  backdrop-filter: blur(10px);
  background:rgba(252,250,247,.85);
  border-bottom:1px solid rgba(0,0,0,.05);
}
.bom-topbar__inner{
  min-height:78px;display:flex;align-items:center;justify-content:space-between;gap:18px;
}
.bom-brand{display:flex;align-items:center;gap:14px;font-size:14px}
.bom-brand__mark{width:52px;height:52px;border-radius:16px;background:linear-gradient(135deg,var(--bom-accent-dark),var(--bom-wood));display:grid;place-items:center;box-shadow:var(--bom-shadow)}
.bom-brand__mark img{width:36px;height:36px}
.bom-brand__title{font-size:24px;letter-spacing:.05em;font-weight:700}
.bom-brand__subtitle{font-size:12px;color:var(--bom-muted);text-transform:uppercase;letter-spacing:.16em}
.bom-nav{display:flex;align-items:center;gap:22px;font-size:15px;color:var(--bom-muted)}
.bom-nav a:hover{color:var(--bom-text)}
.bom-nav__cta{display:none}

.bom-btn{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:52px;padding:0 24px;border-radius:999px;
  background:var(--bom-accent-dark);color:#fff;font-size:15px;font-weight:700;
  letter-spacing:.02em;box-shadow:var(--bom-shadow);
  border:1px solid rgba(255,255,255,.08); transition:.22s ease;
}
.bom-btn:hover{transform:translateY(-1px);background:#394433}
.bom-btn--light{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.18)}
.bom-btn--secondary{background:transparent;color:var(--bom-accent-dark);border:1px solid var(--bom-border);box-shadow:none}

.bom-hero{
  padding:46px 0 56px;
  background:
    linear-gradient(180deg, rgba(39,45,36,.55), rgba(39,45,36,.42)),
    var(--bom-hero-image, linear-gradient(135deg,#6e7b63,#8d7258));
  background-size:cover;background-position:center;
  color:#fff;
}
.bom-hero__shell{padding:56px;border-radius:30px;min-height:640px;display:flex;align-items:flex-end;background:linear-gradient(180deg, rgba(255,255,255,0) 15%, rgba(0,0,0,.16) 100%)}
.bom-hero__grid{display:grid;grid-template-columns:1.2fr .8fr;gap:28px;align-items:end;width:100%}
.bom-kicker{
  display:inline-flex;align-items:center;gap:10px;
  padding:10px 16px;border-radius:999px;background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.15);font-size:13px;letter-spacing:.08em;text-transform:uppercase;
}
.bom-hero h1{
  font-size:clamp(38px,6vw,72px);line-height:1.02;margin:18px 0 16px;
  max-width:12ch;font-weight:700;
}
.bom-hero__lead{max-width:650px;font-size:clamp(18px,2.2vw,24px);color:rgba(255,255,255,.93);margin:0 0 26px}
.bom-hero__actions{display:flex;flex-wrap:wrap;gap:14px}
.bom-hero__card{
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.14);
  border-radius:28px;padding:26px;backdrop-filter:blur(6px)
}
.bom-hero__list{display:grid;gap:14px;margin:0;padding:0;list-style:none}
.bom-hero__list li{display:flex;gap:12px}
.bom-hero__list span:first-child{width:26px;height:26px;border-radius:50%;background:rgba(255,255,255,.14);display:grid;place-items:center;flex:0 0 auto}
.bom-hero__small{font-size:13px;color:rgba(255,255,255,.85);margin-top:16px}

.bom-intro{margin-top:-58px;z-index:3}
.bom-intro__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding:24px}
.bom-stat{padding:16px 18px;border-radius:20px;background:#fff;border:1px solid rgba(0,0,0,.04)}
.bom-stat strong{display:block;font-size:15px}
.bom-stat span{font-size:14px;color:var(--bom-muted)}

.bom-heading{max-width:760px;margin-bottom:28px}
.bom-heading__eyebrow{font-size:13px;color:var(--bom-accent-dark);text-transform:uppercase;letter-spacing:.15em;margin-bottom:10px}
.bom-heading h2{font-size:clamp(30px,4vw,48px);line-height:1.08;margin:0 0 14px}
.bom-heading p{font-size:18px;color:var(--bom-muted);margin:0}

.bom-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.bom-card{
  background:var(--bom-paper);padding:26px;border-radius:24px;border:1px solid rgba(0,0,0,.05);
  box-shadow:var(--bom-shadow)
}
.bom-card__num{width:44px;height:44px;border-radius:14px;background:var(--bom-bg-soft);display:grid;place-items:center;color:var(--bom-accent-dark);font-weight:700;margin-bottom:16px}
.bom-card h3{margin:0 0 8px;font-size:24px}
.bom-card p{margin:0;color:var(--bom-muted)}

.bom-split{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:center}
.bom-photo{
  min-height:620px;border-radius:30px;overflow:hidden;position:relative;
  background:linear-gradient(180deg, rgba(0,0,0,.12), rgba(0,0,0,.28)), var(--bom-photo-image, linear-gradient(135deg,#d7c3ad,#7e6651));
  background-size:cover;background-position:center;
  box-shadow:var(--bom-shadow);
}
.bom-photo__badge{
  position:absolute;left:24px;bottom:24px;background:rgba(255,255,255,.88);
  color:var(--bom-text);padding:14px 16px;border-radius:18px;max-width:310px;font-size:15px;
  box-shadow:var(--bom-shadow)
}

.bom-featurelist{display:grid;gap:14px;margin-top:24px}
.bom-feature{
  display:grid;grid-template-columns:58px 1fr;gap:16px;align-items:start;
  padding:18px;border-radius:20px;background:#fff;border:1px solid rgba(0,0,0,.05)
}
.bom-feature__icon{
  width:58px;height:58px;border-radius:18px;background:var(--bom-bg-soft);
  display:grid;place-items:center;color:var(--bom-accent-dark);font-size:26px
}
.bom-feature strong{display:block;font-size:20px;margin-bottom:4px}
.bom-feature span{color:var(--bom-muted)}

.bom-gallery{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.bom-gallery__item{
  min-height:240px;border-radius:26px;overflow:hidden;position:relative;
  background:linear-gradient(180deg, rgba(24,26,22,.06), rgba(24,26,22,.22)), var(--bom-gallery-image, linear-gradient(135deg,#b7a18e,#d8ccb9));
  background-size:cover;background-position:center;
  box-shadow:var(--bom-shadow)
}
.bom-gallery__item:nth-child(1){grid-column:span 5}
.bom-gallery__item:nth-child(2){grid-column:span 3}
.bom-gallery__item:nth-child(3){grid-column:span 4}
.bom-gallery__item:nth-child(4){grid-column:span 4}
.bom-gallery__item:nth-child(5){grid-column:span 4}
.bom-gallery__item:nth-child(6){grid-column:span 4}
.bom-gallery__caption{
  position:absolute;left:18px;right:18px;bottom:18px;
  background:rgba(255,255,255,.88);padding:14px 16px;border-radius:18px;font-size:15px
}

.bom-trust{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.bom-quote{padding:24px;border-radius:24px;background:#fff;border:1px solid rgba(0,0,0,.05);box-shadow:var(--bom-shadow)}
.bom-quote p{margin:0 0 14px;font-size:18px}
.bom-quote strong{display:block;font-size:15px}
.bom-quote span{font-size:14px;color:var(--bom-muted)}

.bom-cta-band{
  padding:34px;border-radius:30px;background:linear-gradient(135deg,var(--bom-accent-dark),#5d694e 60%, var(--bom-wood));color:#fff;
  box-shadow:var(--bom-shadow)
}
.bom-cta-band__grid{display:grid;grid-template-columns:1.2fr .8fr;gap:24px;align-items:center}
.bom-cta-band h2{margin:0 0 12px;font-size:clamp(32px,4vw,52px);line-height:1.04}
.bom-cta-band p{margin:0;color:rgba(255,255,255,.92);font-size:18px}

.bom-pagehero{
  padding:88px 0 36px;
  background:linear-gradient(180deg,#ede6da,#f8f4ee);
  border-bottom:1px solid rgba(0,0,0,.05)
}
.bom-pagehero h1{font-size:clamp(34px,5vw,64px);line-height:1.05;margin:0 0 12px}
.bom-pagehero p{font-size:20px;color:var(--bom-muted);max-width:820px;margin:0}
.bom-bullets{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:22px}
.bom-bullet{
  padding:16px 18px;border-radius:18px;background:#fff;border:1px solid rgba(0,0,0,.05);
  font-size:16px;box-shadow:var(--bom-shadow)
}

.bom-calendly{
  min-height:860px;border-radius:28px;overflow:hidden;border:1px solid rgba(0,0,0,.05);
  box-shadow:var(--bom-shadow);background:#fff
}

.bom-footer{
  padding:34px 0 46px;border-top:1px solid rgba(0,0,0,.05);background:#f0ebe3
}
.bom-footer__grid{display:grid;grid-template-columns:1fr auto;gap:20px;align-items:center}
.bom-footer p{margin:0;color:var(--bom-muted);font-size:14px}
.bom-footer__links{display:flex;gap:18px;font-size:14px;color:var(--bom-muted)}

.bom-page-content{padding:70px 0}
.bom-content-box{padding:34px}

@media (max-width: 1080px){
  .bom-hero__grid,.bom-cta-band__grid,.bom-split,.bom-footer__grid{grid-template-columns:1fr}
  .bom-intro__grid,.bom-cards,.bom-trust,.bom-bullets{grid-template-columns:repeat(2,1fr)}
  .bom-gallery__item:nth-child(n){grid-column:span 6}
  .bom-photo{min-height:440px}
}
@media (max-width: 760px){
  .bom-nav{display:none}
  .bom-nav__cta{display:inline-flex}
  .bom-topbar__inner{min-height:72px}
  .bom-brand__title{font-size:21px}
  .bom-hero__shell{padding:28px;min-height:unset}
  .bom-intro__grid,.bom-cards,.bom-trust,.bom-bullets{grid-template-columns:1fr}
  .bom-gallery__item:nth-child(n){grid-column:span 12}
  .bom-section{padding:64px 0}
  .bom-pagehero{padding-top:64px}
  .bom-hero h1{max-width:unset}
  .bom-hero__actions{flex-direction:column;align-items:stretch}
  .bom-btn{width:100%}
}
