
:root{
  --bg:#f4f1ea;
  --paper:#fffaf1;
  --ink:#1e2525;
  --muted:#6f6a60;
  --line:#ded7c9;
  --accent:#ec6f35;
  --accent-dark:#a94d25;
  --blue:#1b5573;
  --green:#758b63;
  --shadow:0 20px 60px rgba(40,35,25,.11);
  --radius:30px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color:var(--ink);
  background:
    radial-gradient(circle at 12% 8%, rgba(236,111,53,.14), transparent 28%),
    radial-gradient(circle at 80% 10%, rgba(27,85,115,.10), transparent 26%),
    var(--bg);
  line-height:1.55;
}
a{color:inherit}
.container{width:min(1120px, calc(100% - 40px)); margin:0 auto}
.site-header{
  position:sticky; top:0; z-index:20;
  background:rgba(244,241,234,.86);
  backdrop-filter: blur(14px);
  border-bottom:1px solid rgba(222,215,201,.8);
}
.nav{display:flex; align-items:center; justify-content:space-between; min-height:76px; gap:24px}
.brand{font-weight:800; letter-spacing:-.04em; text-decoration:none; font-size:1.2rem}
.brand span{color:var(--accent)}
.nav-links{display:flex; align-items:center; gap:22px; font-size:.96rem}
.nav-links a{text-decoration:none; color:var(--muted)}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  border-radius:999px; padding:12px 18px;
  text-decoration:none; font-weight:750;
  border:1px solid var(--ink);
  background:var(--ink); color:#fff;
}
.btn.secondary{background:transparent;color:var(--ink)}
.btn.small{padding:9px 13px;font-size:.9rem}
.hero{
  padding:78px 0 68px;
}
.hero-grid{display:grid; grid-template-columns: 1.03fr .97fr; gap:54px; align-items:center}
.kicker{text-transform:uppercase; letter-spacing:.12em; color:var(--accent-dark); font-weight:800; font-size:.78rem}
h1,h2,h3{line-height:1.05; letter-spacing:-.055em; margin:0}
h1{font-size:clamp(3rem,7vw,6.8rem); max-width:860px}
h2{font-size:clamp(2.1rem,4vw,4.2rem)}
h3{font-size:1.35rem}
.lead{font-size:clamp(1.1rem,1.6vw,1.32rem); color:#3d403d; max-width:720px}
.text-muted{color:var(--muted)}
.hero-actions{display:flex; flex-wrap:wrap; gap:12px; margin-top:30px}
.blob-stack{position:relative; min-height:550px}
.blob-img{
  position:absolute; overflow:hidden; background:#ddd; box-shadow:var(--shadow);
}
.blob-img img{width:100%; height:100%; object-fit:cover; display:block}
.blob-main{inset:8% 5% auto auto; width:72%; aspect-ratio:1/1; border-radius:48% 52% 44% 56% / 58% 42% 55% 45%}
.blob-small{left:0; bottom:4%; width:43%; aspect-ratio:1/1; border-radius:54% 46% 58% 42% / 45% 60% 40% 55%}
.blob-wide{right:1%; bottom:0; width:52%; aspect-ratio:1.45/1; border-radius:38% 62% 43% 57% / 54% 39% 61% 46%}
.section{padding:70px 0}
.section-head{display:flex; align-items:end; justify-content:space-between; gap:28px; margin-bottom:28px}
.section-head p{max-width:560px}
.cards{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.card{
  background:rgba(255,250,241,.84); border:1px solid var(--line); border-radius:var(--radius);
  padding:24px; box-shadow:0 8px 30px rgba(40,35,25,.06);
}
.card h3{margin-bottom:10px}
.card p{color:var(--muted)}
.product-card{display:flex; flex-direction:column; min-height:330px}
.product-card .price{font-size:2rem; letter-spacing:-.04em; font-weight:850; margin:14px 0 4px}
.product-card .meta{font-size:.9rem; color:var(--muted)}
.product-card .btn{margin-top:auto; align-self:flex-start}
.split{display:grid; grid-template-columns:.92fr 1.08fr; gap:38px; align-items:center}
.round-photo{
  width:100%; aspect-ratio:1.1/1; border-radius:50% 42% 48% 52% / 48% 55% 45% 52%;
  object-fit:cover; box-shadow:var(--shadow);
}
.feature-list{display:grid; gap:14px; margin-top:22px}
.feature{padding:18px 20px; border:1px solid var(--line); background:rgba(255,250,241,.75); border-radius:22px}
.cta{
  margin:70px 0 30px; padding:42px; border-radius:40px;
  background:var(--ink); color:#fff;
  display:grid; grid-template-columns:1fr auto; gap:26px; align-items:center;
}
.cta p{color:rgba(255,255,255,.75); max-width:650px}
.footer{padding:42px 0; border-top:1px solid var(--line); color:var(--muted)}
.footer-inner{display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap}
.page-hero{padding:72px 0 38px}
.filters{
  display:flex; gap:12px; flex-wrap:wrap; align-items:center; margin:24px 0 24px
}
.filters input,.filters select{
  border:1px solid var(--line); border-radius:999px; padding:13px 16px;
  background:rgba(255,250,241,.9); font:inherit; min-width:220px;
}
.project-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-bottom:70px}
.project-card{min-height:270px; display:flex; flex-direction:column}
.project-card .nr{width:42px; height:42px; border-radius:50%; display:flex; align-items:center; justify-content:center; background:#ede6d7; color:var(--muted); font-weight:800}
.project-card header{display:flex; justify-content:space-between; gap:12px; align-items:flex-start; margin-bottom:16px}
.tags{display:flex; flex-wrap:wrap; gap:8px; margin:12px 0}
.tag{font-size:.78rem; border:1px solid var(--line); color:var(--muted); padding:4px 8px; border-radius:999px}
.project-card .links{margin-top:auto; display:flex; gap:10px; flex-wrap:wrap}
.gallery-strip{display:grid; grid-template-columns:1.2fr .8fr 1fr; gap:18px; margin-top:28px}
.gallery-strip img{width:100%; height:280px; object-fit:cover; box-shadow:var(--shadow)}
.gallery-strip img:nth-child(1){border-radius:48% 52% 44% 56% / 54% 46% 50% 50%}
.gallery-strip img:nth-child(2){border-radius:50%; height:280px}
.gallery-strip img:nth-child(3){border-radius:40% 60% 45% 55% / 55% 42% 58% 45%}
.mobile-toggle{display:none}
@media(max-width:900px){
  .hero-grid,.split,.cta{grid-template-columns:1fr}
  .blob-stack{min-height:430px}
  .cards,.project-grid{grid-template-columns:1fr 1fr}
  .gallery-strip{grid-template-columns:1fr}
  .gallery-strip img,.gallery-strip img:nth-child(2){height:310px}
}
@media(max-width:700px){
  .container{width:min(100% - 28px,1120px)}
  .nav{align-items:flex-start; padding:16px 0; min-height:auto}
  .nav-links{display:none; width:100%; flex-direction:column; align-items:flex-start; padding:12px 0}
  .nav.open{flex-wrap:wrap}
  .nav.open .nav-links{display:flex}
  .mobile-toggle{display:inline-flex; border:1px solid var(--line); border-radius:999px; padding:9px 12px; background:transparent}
  .cards,.project-grid{grid-template-columns:1fr}
  .hero{padding-top:44px}
  .blob-stack{min-height:360px}
  .cta{padding:28px}
}

.soft-section{
  background:rgba(255,250,241,.36);
  border-top:1px solid rgba(222,215,201,.65);
  border-bottom:1px solid rgba(222,215,201,.65);
}
.cv-hero{padding-bottom:64px}
.cv-grid{display:grid; grid-template-columns:1.45fr .75fr; gap:18px; align-items:stretch}
.cv-intro h2{font-size:clamp(2rem,3.2vw,3.25rem); margin-bottom:18px}
.cv-side{background:rgba(30,37,37,.04)}
.clean-list{list-style:none; padding:0; margin:18px 0 0; display:grid; gap:12px}
.clean-list li{padding-left:22px; position:relative; color:#3d403d}
.clean-list li::before{content:""; position:absolute; left:0; top:.62em; width:8px; height:8px; border-radius:50%; background:var(--accent)}
.timeline{
  --timeline-date-col:170px;
  --timeline-gap:54px;
  --timeline-marker-size:25px;
  display:grid; gap:18px; position:relative
}
.timeline::before{
  content:""; position:absolute;
  left:calc(var(--timeline-date-col) + (var(--timeline-gap) / 2));
  top:8px; bottom:8px; width:1px; background:var(--line)
}
.timeline-item{
  display:grid;
  grid-template-columns:var(--timeline-date-col) 1fr;
  gap:var(--timeline-gap);
  align-items:start; position:relative
}
.timeline-item .time{
  font-weight:850; color:var(--accent-dark); letter-spacing:.01em;
  padding-top:24px; padding-right:8px; text-align:right; white-space:nowrap
}
.timeline-item .card{position:relative}
.timeline-item .card::before{
  content:""; position:absolute;
  left:calc((var(--timeline-gap) / -2) - (var(--timeline-marker-size) / 2));
  top:30px; width:17px; height:17px; border-radius:50%;
  background:var(--bg); border:4px solid var(--accent); box-sizing:content-box
}
.portrait-focus{object-position:center 30%}
.four-cards{grid-template-columns:repeat(4,1fr)}
.reverse-mobile{ }
@media(max-width:900px){
  .cv-grid,.four-cards{grid-template-columns:1fr 1fr}
  .timeline{--timeline-date-col:0px; --timeline-gap:0px}
  .timeline::before{left:17px}
  .timeline-item{grid-template-columns:1fr; gap:8px; padding-left:48px}
  .timeline-item .time{text-align:left; padding-top:0; padding-right:0}
  .timeline-item .card::before{left:-40px; top:24px}
}
@media(max-width:700px){
  .cv-grid,.four-cards{grid-template-columns:1fr}
  .timeline-item{padding-left:42px}
}


/* Tools section */
.section-intro{color:var(--muted); max-width:520px; margin:0}
.tools-section{
  background:
    radial-gradient(circle at 94% 12%, rgba(117,139,99,.16), transparent 30%),
    rgba(255,250,241,.42);
  border-top:1px solid rgba(222,215,201,.65);
  border-bottom:1px solid rgba(222,215,201,.65);
}
.tools-head{align-items:start}
.tools-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:18px}
.tool-card{min-height:330px; display:flex; flex-direction:column; position:relative; overflow:hidden}
.tool-card-featured{
  grid-column:span 2;
  background:
    radial-gradient(circle at 100% 0%, rgba(27,85,115,.12), transparent 250px),
    rgba(255,250,241,.92);
}
.tool-label{
  width:fit-content;
  margin-bottom:18px;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(117,139,99,.16);
  color:var(--green);
  font-size:.74rem;
  font-weight:850;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.card-link{
  margin-top:auto;
  padding-top:22px;
  color:var(--accent-dark);
  font-weight:850;
  text-decoration:none;
}
.card-link span{display:inline-block; margin-left:4px; transition:transform 160ms ease}
.card-link:hover span{transform:translateX(4px)}
.muted-link{color:var(--muted)}
@media(max-width:900px){
  .tools-grid{grid-template-columns:1fr 1fr}
  .tool-card-featured{grid-column:span 2}
  .section-intro{max-width:720px}
}
@media(max-width:700px){
  .tools-grid{grid-template-columns:1fr}
  .tool-card-featured{grid-column:span 1}
  .tool-card{min-height:auto}
}


.project-card.has-visuals{overflow:hidden}
.project-visuals{margin:-24px -24px 22px; padding:18px 18px 10px; background:linear-gradient(180deg, rgba(27,85,115,.06), rgba(255,250,241,.2));}
.project-hero-media{
  width:100%;
  aspect-ratio:1.45/1;
  object-fit:cover;
  display:block;
  box-shadow:var(--shadow);
  border-radius:36% 64% 44% 56% / 48% 44% 56% 52%;
}
.project-thumb-row{display:grid; grid-template-columns:repeat(auto-fit, minmax(92px, 1fr)); gap:12px; margin-top:12px}
.project-thumb{
  width:100%;
  aspect-ratio:1/1;
  object-fit:cover;
  display:block;
  box-shadow:0 10px 24px rgba(40,35,25,.12);
}
.project-thumb.shape-1{border-radius:50%}
.project-thumb.shape-2{border-radius:42% 58% 48% 52% / 56% 40% 60% 44%}
.project-thumb.shape-3{border-radius:58% 42% 54% 46% / 44% 56% 48% 52%}
@media(max-width:700px){
  .project-visuals{margin:-24px -24px 18px; padding:16px 16px 10px}
  .project-thumb-row{gap:10px}
}



.logo-strip-grid {
  display: grid;
  grid-template-columns: minmax(220px, 300px) minmax(0, 1fr);
  gap: 28px;
  align-items: start;
}

.logo-strip-copy {
  padding-top: 8px;
}

.logo-strip-text {
  margin: 0;
  max-width: 28ch;
  color: rgba(0, 0, 0, 0.66);
  line-height: 1.7;
}

.logo-strip-panel {
  margin: 0;
  justify-self: end;
  max-width: 760px;
}

.logo-strip-panel img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 14px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.07);
  opacity: 0.96;
}

@media (max-width: 900px) {
  .logo-strip-grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .logo-strip-copy {
    padding-top: 0;
  }

  .logo-strip-text {
    max-width: 48ch;
  }

  .logo-strip-panel {
    justify-self: stretch;
    max-width: 100%;
  }
}

/* Schone, responsive logo-sectie */

.clients-section {
  padding: 64px 0 76px;
}

.clients-intro {
  max-width: 780px;
  margin-bottom: 30px;
}

.clients-intro h2 {
  margin: 0 0 14px;
  max-width: 720px;
}

.clients-intro p {
  margin: 0;
  max-width: 660px;
  color: rgba(0, 0, 0, 0.66);
  line-height: 1.7;
}

.clients-logo-block {
  margin: 0 auto;
  max-width: 980px;
  opacity: 0.92;
}

.clients-logo-block img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 22px;
}

@media (max-width: 900px) {
  .clients-section {
    padding: 48px 0 58px;
  }

  .clients-intro {
    margin-bottom: 22px;
  }

  .clients-logo-block {
    max-width: 680px;
  }

  .clients-logo-block img {
    border-radius: 18px;
  }
}

@media (max-width: 600px) {
  .clients-section {
    padding: 36px 0 46px;
  }

  .clients-intro h2 {
    font-size: clamp(2rem, 11vw, 3rem);
  }

  .clients-logo-block {
    max-width: 100%;
    opacity: 0.96;
  }

  .clients-logo-block img {
    border-radius: 14px;
  }
}

