/* Studio Logogoedkoop — minimalist creative-agency one-pager
   Geïnspireerd op de typografische rust en het editorial-grid van laurentiwebdesign.it,
   webdorks.com en ux-india.org. Eén warm accent, zwaar leunend op typografie en witruimte. */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
 --paper:#f5f1ea;
 --paper-2:#ece6dc;
 --ink:#161311;
 --ink-soft:#5b524a;
 --line:rgba(22,19,17,.14);
 --accent:#ff4e2c;
 --accent-soft:#ff7e5f;
 --radius:2px;
 --pad-x:clamp(20px,5vw,80px);
 --max:1320px;
 --hd:'Fraunces',Georgia,serif;
 --bd:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}
html{scroll-behavior:smooth}
body{font-family:var(--bd);color:var(--ink);background:var(--paper);line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
::selection{background:var(--accent);color:var(--paper)}

.skip{position:absolute;left:-9999px;top:0;background:var(--ink);color:var(--paper);padding:8px 14px;z-index:200}
.skip:focus{left:12px;top:12px}

:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:var(--radius)}

/* ---------- NAV ---------- */
.nav{position:fixed;inset:0 0 auto 0;z-index:100;padding:18px var(--pad-x);transition:background .35s ease,box-shadow .35s ease,padding .35s ease;backdrop-filter:saturate(140%) blur(0)}
.nav.scrolled{background:rgba(245,241,234,.82);backdrop-filter:saturate(140%) blur(12px);box-shadow:0 1px 0 var(--line);padding:12px var(--pad-x)}
.nav-inner{max-width:var(--max);margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:24px}
.brand{display:inline-flex;align-items:center;gap:10px;font-family:var(--hd);font-weight:500;font-size:18px;letter-spacing:-.01em;color:var(--ink)}
.brand-mark{width:22px;height:22px;color:var(--accent);transition:transform .4s cubic-bezier(.16,1,.3,1)}
.brand:hover .brand-mark{transform:rotate(90deg)}
.nav nav{display:flex;align-items:center;gap:24px;font-size:14px}
.nav nav a{color:var(--ink-soft);position:relative;padding:6px 0;transition:color .2s}
.nav nav a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--ink);transition:width .35s cubic-bezier(.16,1,.3,1)}
.nav nav a:hover,.nav nav a.active{color:var(--ink)}
.nav nav a:hover::after,.nav nav a.active::after{width:100%}
.nav-cta{padding:8px 14px!important;border:1px solid var(--ink);border-radius:980px;color:var(--ink)!important}
.nav-cta::after{display:none!important}
.nav-cta:hover{background:var(--ink);color:var(--paper)!important}
@media (max-width:760px){.nav nav{display:none}}

/* ---------- HERO ---------- */
.hero{padding:160px var(--pad-x) 90px;position:relative;overflow:hidden}
.hero-inner{max-width:var(--max);margin:0 auto}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:36px}
.dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px rgba(255,78,44,.18);animation:pulse 2.4s ease-in-out infinite}
@keyframes pulse{50%{box-shadow:0 0 0 8px rgba(255,78,44,0)}}
.hero h1{font-family:var(--hd);font-weight:400;font-size:clamp(56px,11vw,180px);line-height:.92;letter-spacing:-.04em;margin-bottom:36px}
.hero h1 br{display:block}
.lead{font-size:clamp(18px,1.6vw,22px);max-width:54ch;color:var(--ink-soft);line-height:1.6;margin-bottom:44px}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:80px}
.btn-primary,.btn-ghost{display:inline-flex;align-items:center;gap:12px;padding:16px 26px;border-radius:980px;font-size:15px;font-weight:500;transition:transform .25s cubic-bezier(.16,1,.3,1),background .2s,color .2s,border-color .2s}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary svg{width:18px;height:18px}
.btn-primary:hover{background:var(--accent);transform:translateY(-2px)}
.btn-ghost{border:1px solid var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper);transform:translateY(-2px)}
.hero-meta{list-style:none;display:flex;gap:64px;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:30px}
.hero-meta li{display:flex;flex-direction:column;gap:6px}
.hero-meta strong{font-family:var(--hd);font-weight:500;font-size:42px;letter-spacing:-.02em;line-height:1}
.hero-meta span{font-size:13px;color:var(--ink-soft)}

/* ---------- MARQUEE ---------- */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:24px 0;overflow:hidden;background:var(--paper)}
.marquee-track{display:flex;gap:48px;white-space:nowrap;font-family:var(--hd);font-weight:400;font-size:clamp(28px,4vw,52px);letter-spacing:-.02em;animation:scroll 38s linear infinite;width:max-content}
.marquee-track span{flex:0 0 auto}
.marquee-track span[aria-hidden="true"]{color:var(--accent)}
@keyframes scroll{to{transform:translateX(-50%)}}
.marquee:hover .marquee-track{animation-play-state:paused}

/* ---------- SECTIONS ---------- */
.section{padding:140px var(--pad-x);max-width:var(--max);margin:0 auto;position:relative}
.section-dark{background:var(--ink);color:var(--paper);max-width:none;margin:0}
.section-dark .kicker,.section-dark .section-sub{color:rgba(245,241,234,.55)}
.section-tone{background:var(--paper-2);max-width:none;margin:0}
.section-head{margin-bottom:80px;max-width:760px}
.kicker{font-size:12px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:18px}
h2{font-family:var(--hd);font-weight:400;font-size:clamp(36px,5.5vw,72px);letter-spacing:-.025em;line-height:1.02}
.section-sub{margin-top:20px;font-size:18px;color:var(--ink-soft);line-height:1.6;max-width:62ch}
.section-dark .section{max-width:var(--max);margin:0 auto}
.section-dark > .section-head,.section-tone > .section-head{max-width:var(--max);margin-left:auto;margin-right:auto;padding:0}
/* Verzeker dat dark/tone secties dezelfde container hebben */
.section-dark,.section-tone{padding:140px var(--pad-x)}
.section-dark > *,.section-tone > *{max-width:var(--max);margin-left:auto;margin-right:auto}

/* ---------- WERK ---------- */
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.work{background:var(--paper);padding:46px 38px;display:flex;flex-direction:column;gap:32px;transition:background .3s ease}
.work:hover{background:var(--paper-2)}
.work-art{aspect-ratio:1;display:grid;place-items:center;padding:20px;color:var(--ink);transition:color .3s ease,transform .5s cubic-bezier(.16,1,.3,1)}
.work:hover .work-art{color:var(--accent);transform:scale(1.04)}
.work-art svg{width:100%;height:auto;max-width:240px}
.work-meta{display:flex;justify-content:space-between;align-items:baseline;gap:16px;border-top:1px solid var(--line);padding-top:16px}
.work-meta h3{font-family:var(--hd);font-weight:500;font-size:20px;letter-spacing:-.01em}
.work-meta p{font-size:13px;color:var(--ink-soft)}
@media (max-width:980px){.work-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:620px){.work-grid{grid-template-columns:1fr}}

/* ---------- DIENSTEN ---------- */
.services{list-style:none;border-top:1px solid rgba(245,241,234,.18)}
.services li{display:grid;grid-template-columns:80px 1fr auto;gap:32px;align-items:start;padding:36px 0;border-bottom:1px solid rgba(245,241,234,.18);transition:padding .3s ease,background .3s ease}
.services li:hover{padding-left:18px}
.srv-no{font-family:var(--hd);font-weight:400;font-size:18px;color:rgba(245,241,234,.5)}
.services h3{font-family:var(--hd);font-weight:500;font-size:clamp(28px,3.4vw,44px);letter-spacing:-.02em;margin-bottom:10px;transition:color .3s ease}
.services li:hover h3{color:var(--accent-soft)}
.services p{color:rgba(245,241,234,.7);font-size:16px;max-width:62ch}
.srv-tag{font-size:13px;color:rgba(245,241,234,.65);white-space:nowrap;font-variant-numeric:tabular-nums}
@media (max-width:760px){.services li{grid-template-columns:1fr;gap:8px}.srv-tag{margin-top:6px}}

/* ---------- WERKWIJZE ---------- */
.steps{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.steps li{background:var(--paper);padding:42px 30px;display:flex;flex-direction:column;gap:14px;position:relative}
.step-no{font-family:var(--hd);font-size:14px;color:var(--accent);font-weight:500;letter-spacing:.06em}
.steps h3{font-family:var(--hd);font-weight:500;font-size:24px;letter-spacing:-.01em}
.steps p{font-size:15.5px;color:var(--ink-soft);line-height:1.6}
@media (max-width:980px){.steps{grid-template-columns:repeat(2,1fr)}}
@media (max-width:620px){.steps{grid-template-columns:1fr}}

/* ---------- TARIEVEN ---------- */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.plan{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:40px 32px;display:flex;flex-direction:column;gap:24px;transition:transform .35s cubic-bezier(.16,1,.3,1),box-shadow .35s ease,border-color .3s ease}
.plan:hover{transform:translateY(-4px);box-shadow:0 14px 40px rgba(22,19,17,.07);border-color:var(--ink)}
.plan header{display:flex;flex-direction:column;gap:6px;border-bottom:1px solid var(--line);padding-bottom:22px;position:relative}
.plan h3{font-family:var(--hd);font-weight:500;font-size:24px;letter-spacing:-.01em}
.plan-price{font-family:var(--hd);font-size:64px;font-weight:400;letter-spacing:-.04em;line-height:1;display:inline-flex;align-items:baseline;gap:6px}
.plan-price span{font-size:24px;color:var(--ink-soft);font-weight:400}
.plan-note{font-size:13px;color:var(--ink-soft)}
.plan-flag{position:absolute;top:-8px;right:0;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-weight:600}
.plan-featured{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.plan-featured .plan-note,.plan-featured .plan-price span{color:rgba(245,241,234,.6)}
.plan-featured header{border-color:rgba(245,241,234,.18)}
.plan-featured ul{color:rgba(245,241,234,.85)}
.plan-featured .plan-cta{background:var(--accent);color:var(--paper);border-color:var(--accent)}
.plan-featured .plan-cta:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.plan ul{list-style:none;display:flex;flex-direction:column;gap:10px;font-size:14.5px;color:var(--ink-soft);flex:1}
.plan ul li{padding-left:18px;position:relative;line-height:1.5}
.plan ul li::before{content:"";position:absolute;left:0;top:.7em;width:8px;height:1px;background:currentColor;opacity:.6}
.plan-cta{display:inline-flex;align-items:center;justify-content:center;padding:14px 22px;border:1px solid var(--ink);border-radius:980px;font-size:14px;font-weight:500;transition:background .2s,color .2s}
.plan-cta:hover{background:var(--ink);color:var(--paper)}
@media (max-width:980px){.plans{grid-template-columns:1fr;gap:18px}}

/* ---------- FAQ ---------- */
.faq{max-width:880px;margin:0 auto}
.faq details{border-bottom:1px solid var(--line);padding:22px 0;transition:padding .3s ease}
.faq details:first-child{border-top:1px solid var(--line)}
.faq summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:24px;font-family:var(--hd);font-weight:500;font-size:clamp(20px,2.2vw,26px);letter-spacing:-.01em;color:var(--ink);transition:color .2s}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--bd);font-size:28px;color:var(--accent);font-weight:300;line-height:1;transition:transform .3s cubic-bezier(.16,1,.3,1)}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq summary:hover{color:var(--accent)}
.faq details p{margin-top:18px;font-size:16.5px;color:var(--ink-soft);line-height:1.7;max-width:74ch}

/* ---------- CONTACT ---------- */
.section-contact{text-align:center;padding-bottom:160px}
.section-contact .section-head{margin-left:auto;margin-right:auto}
.section-contact .section-sub{margin-left:auto;margin-right:auto}
.mail-cta{display:inline-flex;align-items:center;gap:24px;font-family:var(--hd);font-weight:400;font-size:clamp(34px,6vw,72px);letter-spacing:-.03em;color:var(--ink);padding:24px 8px;border-bottom:2px solid var(--ink);transition:color .3s ease,border-color .3s ease,transform .3s ease}
.mail-cta svg{width:.7em;height:.7em;transition:transform .3s cubic-bezier(.16,1,.3,1)}
.mail-cta:hover{color:var(--accent);border-color:var(--accent)}
.mail-cta:hover svg{transform:translateX(8px)}

/* ---------- FOOTER ---------- */
.foot{border-top:1px solid var(--line);padding:36px var(--pad-x);background:var(--paper)}
.foot-inner{max-width:var(--max);margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;font-size:13.5px;color:var(--ink-soft)}
.foot-sale a{color:var(--accent);border-bottom:1px solid currentColor;transition:opacity .2s}
.foot-sale a:hover{opacity:.7}

/* ---------- REVEAL ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
.reveal-stagger > *{opacity:0;transform:translateY(20px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.reveal-stagger.in > *{opacity:1;transform:none}
.reveal-stagger.in > *:nth-child(1){transition-delay:.05s}
.reveal-stagger.in > *:nth-child(2){transition-delay:.12s}
.reveal-stagger.in > *:nth-child(3){transition-delay:.19s}
.reveal-stagger.in > *:nth-child(4){transition-delay:.26s}
.reveal-stagger.in > *:nth-child(5){transition-delay:.33s}
.reveal-stagger.in > *:nth-child(6){transition-delay:.40s}

/* Hero entrance */
.eyebrow,.hero h1,.lead,.hero-cta,.hero-meta{opacity:0;animation:rise .95s cubic-bezier(.16,1,.3,1) forwards}
.eyebrow{animation-delay:.05s}
.hero h1{animation-delay:.18s}
.lead{animation-delay:.36s}
.hero-cta{animation-delay:.5s}
.hero-meta{animation-delay:.62s}
@keyframes rise{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}

/* ---------- REDUCED MOTION ---------- */
@media (prefers-reduced-motion: reduce){
 *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
 html{scroll-behavior:auto!important}
 .marquee-track{animation:none!important}
 .reveal,.reveal-stagger > *{opacity:1!important;transform:none!important}
 .eyebrow,.hero h1,.lead,.hero-cta,.hero-meta{opacity:1!important}
}

/* Anker-offset onder sticky nav */
section[id],h2{scroll-margin-top:96px}
