/* ============================================================
   Elmer × House of Deeprelax — matchsite
   "Warm maar nuchter" — editorial, ruim, feitelijke rust.
   Fallback-palet uit de handoff (leafy, warm-natuurlijk).
============================================================ */

:root{
  --paper:#F5EFE6;
  --surface:#FBF8F2;
  --ink:#23241F;
  --ink-soft:#4A4C43;
  --sage:#6E7B5E;
  --sage-deep:#46503B;
  --sage-tint:#E3E7D9;
  --clay:#C0784F;
  --line:#D9D2C4;

  --display:'Fraunces',Georgia,'Times New Roman',serif;
  --body:'Inter',system-ui,-apple-system,'Segoe UI',sans-serif;

  --maxw:1080px;
  --narrow:760px;
  --ease:cubic-bezier(.22,1,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.68;
  font-size:18px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:none}
ul{list-style:none;padding:0}
::selection{background:var(--sage-tint);color:var(--ink)}

.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:28px}
.wrap--narrow{max-width:var(--narrow)}
.center{text-align:center}

/* ---------- Skip & focus ---------- */
.skip{position:absolute;left:-9999px;top:0;z-index:400;background:var(--ink);color:var(--paper);padding:11px 18px;border-radius:0 0 10px 0;font-weight:600}
.skip:focus{left:0}
a:focus-visible,button:focus-visible,input:focus-visible{outline:2px solid var(--sage);outline-offset:3px;border-radius:6px}
#hero:focus{outline:none}

/* ---------- Progress ---------- */
.progress{position:fixed;top:0;left:0;height:2px;width:0;background:var(--sage);z-index:200;transition:width .1s linear}

/* ---------- Nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 28px;background:rgba(245,239,230,0);
  transition:background .3s var(--ease),box-shadow .3s var(--ease),padding .3s var(--ease);
}
.nav.scrolled{background:rgba(245,239,230,.9);backdrop-filter:blur(10px);box-shadow:0 1px 0 var(--line);padding:12px 28px}
.nav__name{font-family:var(--display);font-weight:600;font-size:18px;letter-spacing:-.01em}
.nav__links{display:flex;align-items:center;gap:28px}
.nav__links a{font-size:14.5px;font-weight:500;color:var(--ink-soft);transition:color .2s}
.nav__links a:hover{color:var(--ink)}
.nav__cta{color:var(--paper)!important;background:var(--sage-deep);padding:9px 18px;border-radius:100px}
.nav__cta:hover{background:var(--clay)!important;color:var(--paper)!important}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--body);font-size:15px;font-weight:600;padding:14px 26px;border-radius:100px;transition:background .25s,color .25s,border-color .25s,transform .2s}
.btn--solid{background:var(--sage-deep);color:var(--paper)}
.btn--solid:hover{background:var(--clay);transform:translateY(-2px)}
.btn--ghost{border:1.5px solid var(--ink);color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--paper);transform:translateY(-2px)}

/* ---------- Hero ---------- */
.hero{min-height:92svh;display:flex;align-items:center;padding:140px 0 90px;position:relative}
.hero__title{font-family:var(--display);font-weight:400;font-size:clamp(34px,6vw,68px);line-height:1.06;letter-spacing:-.02em;margin:22px 0 28px;max-width:15ch}
.hero__title em{color:var(--sage-deep);font-style:italic}
.hero__lead{font-size:clamp(18px,2.4vw,22px);color:var(--ink-soft);max-width:56ch;margin-bottom:26px}
.hero__by{font-family:var(--body);font-size:14.5px;color:var(--ink-soft);opacity:.85;margin-bottom:44px}
.hero__scroll{display:inline-flex;align-items:center;gap:10px;font-size:15px;font-weight:600;padding-bottom:4px;border-bottom:1.5px solid var(--ink);transition:gap .2s,color .2s,border-color .2s}
.hero__scroll:hover{gap:15px;color:var(--sage-deep);border-color:var(--sage-deep)}
.hero__scroll svg{animation:bob 1.9s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(3px)}}

/* Hero brand-visual: portret × woordmerk */
.hero__brand{display:flex;align-items:center;gap:20px;margin-bottom:40px}
.hero__portrait{width:88px;height:88px;border-radius:50%;overflow:hidden;flex:none;border:1px solid var(--line);box-shadow:0 10px 30px -12px rgba(35,36,31,.35);transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.hero__portrait img{width:100%;height:100%;object-fit:cover;object-position:50% 22%}
.hero__brand:hover .hero__portrait{transform:scale(1.04);box-shadow:0 16px 38px -12px rgba(35,36,31,.45)}
.hero__x{font-family:var(--display);font-size:26px;color:var(--clay);line-height:1}
.hero__wordmark{font-family:var(--display);font-weight:500;font-size:clamp(20px,3vw,27px);line-height:1.05;color:var(--sage-deep);letter-spacing:-.01em}

/* ---------- Sections ---------- */
.section{padding:clamp(64px,9vw,112px) 0;position:relative}
.section--tint{background:var(--sage-tint)}
.section--ink{background:var(--ink);color:var(--paper)}
.section--ink h2,.section--ink .prose strong{color:var(--paper)}
.section--cta{background:var(--surface);border-top:1px solid var(--line);text-align:center}

.label{font-family:var(--body);font-size:13px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--sage);margin-bottom:14px}
.label--light{color:#b8c3a6}
h2{font-family:var(--display);font-weight:400;font-size:clamp(26px,3.6vw,40px);line-height:1.14;letter-spacing:-.02em;margin-bottom:22px;color:var(--sage-deep)}
.section--ink h2{color:var(--paper)}

/* ---------- Prose ---------- */
.prose p{font-size:1.05rem;color:var(--ink-soft);margin-bottom:1.1em;max-width:68ch}
.section--ink .prose p{color:#d7dbcd}
.prose p:last-child{margin-bottom:0}
.prose strong{color:var(--ink);font-weight:600}
.prose em{font-style:italic}

/* Pull quote */
.pull{font-family:var(--display);font-weight:400;font-style:italic;font-size:clamp(22px,3.2vw,32px);line-height:1.3;color:var(--sage-deep);margin:34px 0;padding-left:22px;border-left:3px solid var(--clay);max-width:24ch}

/* Aside / kanttekening */
.aside{margin-top:26px;font-size:.95rem;color:var(--ink-soft);background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:20px 22px;max-width:70ch}

/* ---------- Stat blocks ---------- */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin:40px 0}
.stat{border-top:2px solid var(--line);padding-top:18px;transition:border-color .3s var(--ease)}
.stat:hover{border-top-color:var(--clay)}
.stat:hover .stat__num{color:var(--clay)}
.stat__num{transition:color .3s var(--ease)}
.stat__num{font-family:var(--display);font-weight:500;font-size:clamp(34px,4.4vw,52px);line-height:1;letter-spacing:-.02em;color:var(--sage-deep);margin-bottom:12px}
.stat__label{font-size:.95rem;color:var(--ink-soft);line-height:1.5}
.stat__src{font-size:.8rem;color:var(--sage);margin-top:10px;font-weight:500}

/* ---------- Routes (founders) ---------- */
.routes,.models{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin:32px 0}
.models--three{grid-template-columns:repeat(3,1fr)}
.route,.model{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:28px 26px;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease)}
.route:hover,.model:hover{transform:translateY(-4px);box-shadow:0 18px 40px -20px rgba(35,36,31,.4);border-color:var(--sage)}
.list li{transition:color .2s}
.list li:hover{color:var(--ink)}
.list li:hover::before{background:var(--clay)}
.route__name,.model h3{font-family:var(--display);font-weight:500;font-size:22px;color:var(--sage-deep);margin-bottom:4px}
.route__tag,.model__tag{font-family:var(--body);font-size:12.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--clay);margin-bottom:14px}
.model__tag{display:inline-block;margin-bottom:10px;padding:4px 12px;border-radius:100px}
.model__tag--live{color:var(--sage-deep);background:var(--sage-tint)}
.model__tag--dev{color:#7d4c2e;background:rgba(192,120,79,.14)}
.model__tag--new{color:var(--paper);background:var(--sage-deep)}
.route p,.model p{font-size:.98rem;color:var(--ink-soft)}

/* Subsectiekop */
.h3sub{font-family:var(--display);font-weight:500;font-size:clamp(20px,2.6vw,26px);letter-spacing:-.01em;color:var(--sage-deep);margin:44px 0 16px}

/* ---------- Lists ---------- */
.list{margin:26px 0;max-width:70ch;counter-reset:li}
.list li{position:relative;padding-left:26px;margin-bottom:16px;font-size:1.02rem;color:var(--ink-soft)}
.list li::before{content:"";position:absolute;left:0;top:12px;width:8px;height:8px;border-radius:50%;background:var(--sage)}
.list li strong{color:var(--ink)}
.list--numbered{counter-reset:li}
.list--numbered li{padding-left:38px}
.list--numbered li::before{counter-increment:li;content:counter(li);top:2px;width:24px;height:24px;border-radius:50%;background:var(--sage-tint);color:var(--sage-deep);font-family:var(--body);font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:center}
.muted{color:var(--sage);font-style:italic}

/* ---------- CTA ---------- */
.cta__lead{font-size:1.15rem;color:var(--ink-soft);max-width:52ch;margin:0 auto 30px}
.cta__actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---------- Draft note ---------- */
.draft-note{display:inline-block;font-family:var(--body);font-size:12px;font-weight:600;letter-spacing:.04em;color:var(--clay);background:rgba(192,120,79,.1);border:1px dashed var(--clay);border-radius:100px;padding:4px 12px;margin-bottom:18px}
[data-draft-inline]{border-bottom:1px dashed var(--clay)}

/* ---------- Footer ---------- */
.footer{padding:36px 0;border-top:1px solid var(--line);background:var(--paper)}
.footer p{font-size:13.5px;color:var(--sage);text-align:center}

/* ---------- Gate ---------- */
.gate{position:fixed;inset:0;z-index:500;display:none;align-items:center;justify-content:center;padding:24px;background:var(--paper)}
body.locked{overflow:hidden}
body.locked .gate{display:flex}
body.locked .nav,body.locked .progress,body.locked main,body.locked .footer{display:none!important}
.gate__card{max-width:460px;width:100%;text-align:center}
.gate__kicker{font-family:var(--body);font-size:13px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--sage);margin-bottom:18px}
.gate__card h1{font-family:var(--display);font-weight:400;font-size:clamp(26px,5vw,36px);line-height:1.15;letter-spacing:-.02em;color:var(--sage-deep);margin-bottom:12px}
.gate__lead{color:var(--ink-soft);margin-bottom:26px}
.gate__card form{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.gate__card input{flex:1;min-width:200px;padding:14px 18px;border:1.5px solid var(--line);border-radius:100px;background:var(--surface);color:var(--ink);font-size:16px;text-align:center}
.gate__card input:focus{outline:none;border-color:var(--sage)}
.gate__card .btn{justify-content:center}
.gate__error{color:var(--clay);font-size:.9rem;margin-top:16px}
.gate.shake .gate__card{animation:shake .42s var(--ease)}
@keyframes shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-8px)}40%,80%{transform:translateX(8px)}}

/* ---------- Reveal (fail-safe: alleen verbergen als JS draait) ---------- */
:where(html.js) .reveal{opacity:0;transform:translateY(20px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.visible{opacity:1;transform:none}

/* ---------- Vergelijkingsgrafiek ---------- */
.compare{margin-top:38px;border-top:1px solid var(--line);padding-top:28px}
.compare__cap{font-size:.95rem;color:var(--ink-soft);margin-bottom:24px;max-width:62ch}
.compare__row{margin-bottom:24px}
.compare__row:last-child{margin-bottom:0}
.compare__metric{display:block;font-family:var(--body);font-size:12.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--sage-deep);margin-bottom:12px}
.compare__unit{color:var(--sage);font-weight:500}
.compare__bars{display:flex;flex-direction:column;gap:10px}
.compare__bar{display:grid;grid-template-columns:150px 1fr auto;align-items:center;gap:14px}
.compare__name{font-family:var(--mono);font-size:12.5px;color:var(--ink-soft)}
.compare__track{height:12px;border-radius:100px;background:rgba(35,36,31,.06);overflow:hidden}
.compare__fill{display:block;height:100%;width:0;border-radius:100px;transition:width 1.1s var(--ease)}
.compare.visible .compare__fill{width:var(--w)}
.compare__fill--reach{background:var(--sage)}
.compare__fill--eng{background:var(--clay)}
.compare__val{font-family:var(--mono);font-size:13px;font-weight:700;color:var(--ink);min-width:52px;text-align:right}
.compare__bar:hover .compare__fill{filter:brightness(.93)}

/* ---------- Footer-teller (oogje) ---------- */
.footer__inner{display:flex;align-items:center;justify-content:center;gap:8px 18px;flex-wrap:wrap}
.views{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:12.5px;color:var(--sage)}
.views svg{opacity:.85}

/* ---------- Responsive ---------- */
@media(max-width:860px){
  .stats{grid-template-columns:1fr;gap:0}
  .stat{border-top:none;border-bottom:1px solid var(--line);padding:22px 0}
  .stat:first-child{border-top:2px solid var(--line)}
  .routes,.models{grid-template-columns:1fr}
}
@media(max-width:600px){
  body{font-size:17px}
  .nav__links a:not(.nav__cta){display:none}
  .wrap{padding-inline:22px}
  .hero{min-height:auto;padding:120px 0 72px}
  .compare__bar{grid-template-columns:1fr auto;grid-template-areas:"name val" "track track";row-gap:6px;column-gap:12px}
  .compare__name{grid-area:name}
  .compare__val{grid-area:val}
  .compare__track{grid-area:track}
}

@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition-duration:.001ms!important}
  .reveal{opacity:1;transform:none}
}
