/* ===========================================================
   Studio Bongers — stylesheet
   Lokale fonts (geen externe verbinding), donker met koper accent
   =========================================================== */

@font-face{font-family:"Cormorant Garamond";src:url("fonts/cormorant-garamond-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Cormorant Garamond";src:url("fonts/cormorant-garamond-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Cormorant Garamond";src:url("fonts/cormorant-garamond-500-italic.woff2") format("woff2");font-weight:500;font-style:italic;font-display:swap}
@font-face{font-family:"DM Sans";src:url("fonts/dm-sans-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"DM Sans";src:url("fonts/dm-sans-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"DM Mono";src:url("fonts/dm-mono-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"DM Mono";src:url("fonts/dm-mono-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}

:root{
  --ink:#0E0D0C; --ink-soft:#191715;
  --paper:#F2EDE4; --paper-dim:#E4DCCE;
  --copper:#C7763D; --copper-deep:#A85A2A;
  --muted:#8C8378; --muted-dark:#6E665C;
  --line-dark:rgba(242,237,228,.14); --line-light:rgba(14,13,12,.12);
  --maxw:1180px; --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--ink);color:var(--paper);
  font-family:"DM Sans",system-ui,sans-serif;
  font-size:clamp(16px,1.05vw,18px);line-height:1.65;letter-spacing:.01em;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
body.is-locked{overflow:hidden}
a{color:inherit}
img{max-width:100%;display:block}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,64px)}

.display{font-family:"Cormorant Garamond",Georgia,serif;font-weight:500;line-height:1.02;letter-spacing:-.01em}
.eyebrow{font-family:"DM Mono",ui-monospace,monospace;font-size:.72rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--copper)}
.lede{font-size:clamp(1.1rem,1.6vw,1.32rem);color:var(--paper);opacity:.9}

/* ===================== SPLASH ===================== */
.splash{
  position:fixed;inset:0;z-index:1000;
  background:radial-gradient(120% 120% at 50% 40%, #1a1714 0%, var(--ink) 60%);
  display:grid;place-items:center;
  transition:opacity .9s var(--ease), transform 1s var(--ease), visibility .9s;
}
.no-js .splash{display:none}
.splash.is-hidden{opacity:0;transform:scale(1.04) translateY(-1.5%);visibility:hidden;pointer-events:none}
.splash-stage{position:relative;display:grid;place-items:center;width:min(86vw,640px);aspect-ratio:1/1}
.splash-ring{position:absolute;inset:0;margin:auto;width:min(64vw,420px);height:min(64vw,420px)}
.splash-ring circle{--circ:578;fill:none;stroke:var(--copper);stroke-width:1.4;opacity:.85;stroke-dasharray:var(--circ);stroke-dashoffset:var(--circ);transform:rotate(-90deg);transform-origin:center}
.splash-blades{position:absolute;inset:0;margin:auto;width:min(64vw,420px);height:min(64vw,420px);opacity:0}
.splash-blades line{stroke:var(--copper);stroke-width:1;opacity:.35}
.splash-mark{position:relative;text-align:center;padding:0 6vw}
.splash-mark .top{font-family:"DM Mono",monospace;font-size:.7rem;letter-spacing:.5em;text-transform:uppercase;color:var(--copper);opacity:0;margin-bottom:.9rem;padding-left:.5em}
.splash-mark .word{font-family:"Cormorant Garamond",serif;font-weight:500;font-size:clamp(2.6rem,9vw,5.4rem);line-height:.96;color:var(--paper);filter:blur(14px);opacity:.25;transform:scale(1.06)}
.splash-skip{position:absolute;bottom:clamp(20px,5vh,40px);left:50%;transform:translateX(-50%);background:none;border:0;cursor:pointer;font-family:"DM Mono",monospace;font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);opacity:0;transition:opacity .4s}
.splash-skip:hover,.splash-skip:focus-visible{color:var(--paper);opacity:1 !important;outline:none}
.splash.run .splash-ring circle{animation:draw 1.9s var(--ease) .25s forwards}
.splash.run .splash-blades{animation:fadeIn .8s ease 1.6s forwards}
.splash.run .splash-mark .top{animation:fadeIn .7s ease 1.5s forwards}
.splash.run .splash-mark .word{animation:focusPull 1.5s var(--ease) .55s forwards}
.splash.run .splash-skip{animation:fadeIn .6s ease 2.1s forwards}
@keyframes draw{to{stroke-dashoffset:0}}
@keyframes focusPull{0%{filter:blur(14px);opacity:.25;transform:scale(1.06);letter-spacing:.06em}100%{filter:blur(0);opacity:1;transform:scale(1);letter-spacing:0}}
@keyframes fadeIn{to{opacity:1}}

/* ===================== HERO ===================== */
.hero{position:relative;overflow:hidden;min-height:100svh;display:flex;align-items:center;padding:clamp(90px,14vh,150px) 0 clamp(60px,10vh,110px)}
.hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--line-dark);max-width:var(--maxw);margin:0 auto}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.55fr .85fr;gap:clamp(32px,5vw,72px);align-items:end;width:100%}
.hero h1{font-size:clamp(2.6rem,6.4vw,5.4rem);margin:.5em 0 .55em;max-width:14ch}
.hero h1 em{font-style:italic;color:var(--copper)}
.hero-meta{padding-bottom:.6rem}
.hero-meta p{margin:0 0 1.6rem;color:var(--paper);opacity:.82}
/* interactieve lens */
.hero-lens{position:absolute;z-index:0;top:50%;right:clamp(-90px,-3vw,-30px);transform:translateY(-50%);width:clamp(300px,46vw,600px);aspect-ratio:1;opacity:.17;pointer-events:none}
.hero-lens svg{width:100%;height:100%;display:block;overflow:visible}
.hero-lens .ring{fill:none;stroke:var(--copper);stroke-width:1}
.hero-lens line{stroke:var(--copper);stroke-width:1}
.hero-lens .core{fill:var(--copper);stroke:none}
.hero-lens .iris{transform-origin:100px 100px;will-change:transform}
.hero-flash{position:absolute;inset:0;z-index:2;background:var(--paper);opacity:0;pointer-events:none;mix-blend-mode:screen}
.hero-flash.snap{animation:flash .5s ease}
@keyframes flash{0%{opacity:0}9%{opacity:.45}100%{opacity:0}}
.cta-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.btn{display:inline-flex;align-items:center;gap:.6em;font-family:"DM Mono",monospace;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;padding:.95em 1.4em;border-radius:2px;text-decoration:none;transition:transform .25s var(--ease),background .25s,color .25s,border-color .25s}
.btn-primary{background:var(--copper);color:#1a1310;border:1px solid var(--copper)}
.btn-primary:hover{background:var(--paper);border-color:var(--paper);transform:translateY(-2px)}
.btn-ghost{background:none;border:1px solid var(--line-dark);color:var(--paper)}
.btn-ghost:hover{border-color:var(--copper);color:var(--copper);transform:translateY(-2px)}

/* ===================== sections ===================== */
section{padding:clamp(72px,11vh,150px) 0}
.sec-head{max-width:62ch;margin-bottom:clamp(40px,6vh,72px)}
.sec-head h2{font-size:clamp(2rem,4.4vw,3.6rem);margin:.45em 0 .35em}
.sec-head p{color:var(--paper);opacity:.8;margin:0}

.about{background:var(--paper);color:var(--ink)}
.about .eyebrow{color:var(--copper-deep)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,80px);align-items:start}
.about-portrait{aspect-ratio:4/5;background:linear-gradient(135deg,#d8cdbb,#c2b39c);border:1px solid var(--line-light);display:grid;place-items:center;position:relative;overflow:hidden}
.about-portrait img{width:100%;height:100%;object-fit:cover}
.about-portrait.reveal img{filter:blur(13px) saturate(.85);transform:scale(1.05);transition:filter 1.3s var(--ease),transform 1.3s var(--ease)}
.about-portrait.reveal.in img{filter:none;transform:none}
.about-portrait span{font-family:"DM Mono",monospace;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted-dark);text-align:center;padding:1.5em}
.about-text h2{font-family:"Cormorant Garamond",serif;font-weight:500;font-size:clamp(1.9rem,3.6vw,3rem);line-height:1.05;margin:.3em 0 .7em}
.about-text p{margin:0 0 1.15em}
.about-text p:last-of-type{margin-bottom:0}
.signature{width:clamp(170px,18vw,224px);height:auto;margin-top:1.7rem;opacity:.92}

.work{background:var(--ink-soft)}
.work-list{border-top:1px solid var(--line-dark)}
.work-item{display:grid;grid-template-columns:auto 1fr;gap:clamp(20px,4vw,60px);padding:clamp(30px,5vh,52px) 0;border-bottom:1px solid var(--line-dark);transition:padding-left .35s var(--ease)}
.work-item:hover{padding-left:clamp(8px,1.5vw,20px)}
.work-no{font-family:"DM Mono",monospace;font-size:.8rem;color:var(--copper);padding-top:.5em;letter-spacing:.1em}
.work-item h3{font-family:"Cormorant Garamond",serif;font-weight:500;font-size:clamp(1.5rem,3.2vw,2.4rem);margin:0 0 .35em;line-height:1.04}
.work-item .what{color:var(--paper);opacity:.84;margin:0 0 1.2em;max-width:60ch}
.work-tags{display:flex;flex-wrap:wrap;gap:8px 10px}
.tag{font-family:"DM Mono",monospace;font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);border:1px solid var(--line-dark);border-radius:2px;padding:.45em .8em}

.process .steps{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3vw,40px)}
.step{border-top:1px solid var(--copper);padding-top:1.1rem}
.step .n{font-family:"DM Mono",monospace;font-size:.72rem;color:var(--copper);letter-spacing:.14em}
.step h4{font-family:"Cormorant Garamond",serif;font-weight:500;font-size:clamp(1.3rem,2.4vw,1.8rem);margin:.5rem 0 .4rem}
.step p{margin:0;color:var(--paper);opacity:.78;font-size:.96rem}

.case{background:var(--paper);color:var(--ink)}
.case .eyebrow{color:var(--copper-deep)}
.case-card{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(28px,4vw,64px);align-items:center;border:1px solid var(--line-light);background:#fff;border-radius:3px;overflow:hidden}
.case-visual{align-self:stretch;min-height:340px;position:relative;background:linear-gradient(160deg,#16201b 0%,#0d1410 55%,#111a17 100%);display:grid;place-items:center;gap:1.2rem;color:var(--paper);padding:2.5rem}
.case-visual .oho-logo{width:clamp(92px,12vw,128px);height:auto;border-radius:20px;box-shadow:0 12px 34px rgba(0,0,0,.45)}
.case-visual .ohomark{text-align:center}
.case-visual .ohomark s{font-family:"DM Mono",monospace;text-decoration:none;font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:#d9f55f;display:block}
.case-body{padding:clamp(24px,3vw,44px) clamp(24px,3vw,44px) clamp(24px,3vw,44px) 0}
.case-body h3{font-family:"Cormorant Garamond",serif;font-weight:500;font-size:clamp(1.7rem,3.2vw,2.6rem);margin:.2em 0 .5em;line-height:1.04}
.case-body p{margin:0 0 1.1em;color:var(--ink)}
.case-chips{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 1.6rem}
.chip{font-family:"DM Mono",monospace;font-size:.64rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-dark);border:1px solid var(--line-light);padding:.4em .7em;border-radius:2px}
.case-link{font-family:"DM Mono",monospace;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--copper-deep);text-decoration:none;border-bottom:1px solid currentColor;padding-bottom:.2em}
.case-link:hover{color:var(--ink)}
.next-cases{margin-top:clamp(28px,4vh,48px);display:flex;align-items:center;gap:1rem;color:var(--muted-dark)}
.next-cases .dot{width:7px;height:7px;border-radius:50%;background:var(--copper);flex:none}
.next-cases p{margin:0;font-size:.95rem}

.contact{text-align:center}
.contact h2{font-size:clamp(2.2rem,5.5vw,4.4rem);max-width:18ch;margin:.3em auto .5em}
.contact .lede{max-width:52ch;margin:0 auto 2.4rem}
.mailto{font-family:"Cormorant Garamond",serif;font-weight:500;font-style:italic;font-size:clamp(1.4rem,3.4vw,2.4rem);color:var(--copper);text-decoration:none;border-bottom:1px solid var(--line-dark);padding-bottom:.1em;transition:border-color .3s,color .3s}
.mailto:hover{color:var(--paper);border-color:var(--copper)}

footer{border-top:1px solid var(--line-dark);padding:clamp(48px,7vh,80px) 0 clamp(36px,5vh,56px)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:clamp(28px,4vw,56px)}
footer h5{font-family:"DM Mono",monospace;font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--copper);margin:0 0 1rem;font-weight:500}
footer p,footer a{font-size:.92rem;color:var(--muted);margin:0 0 .55rem;text-decoration:none;line-height:1.6}
footer a:hover{color:var(--paper)}
footer .linkbtn{background:none;border:0;padding:0;cursor:pointer;font-family:inherit}
.foot-mark{font-family:"Cormorant Garamond",serif;font-size:1.8rem;color:var(--paper);margin-bottom:.6rem}
.foot-bottom{margin-top:clamp(36px,5vh,56px);padding-top:1.6rem;border-top:1px solid var(--line-dark);display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;color:var(--muted-dark);font-size:.82rem}
.foot-bottom span{display:block}

.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.no-js .reveal{opacity:1;transform:none}
.no-js .about-portrait img{filter:none;transform:none}
:focus-visible{outline:2px solid var(--copper);outline-offset:3px;border-radius:1px}

/* ===================== CONSENT ===================== */
.consent{position:fixed;left:50%;bottom:clamp(14px,3vh,28px);transform:translateX(-50%) translateY(140%);z-index:900;width:min(640px,calc(100% - 28px));background:var(--ink-soft);border:1px solid var(--line-dark);border-radius:4px;padding:clamp(18px,2.5vw,26px);box-shadow:0 18px 50px rgba(0,0,0,.5);opacity:0;transition:transform .55s var(--ease),opacity .55s var(--ease)}
.consent.show{transform:translateX(-50%) translateY(0);opacity:1}
.consent p{margin:0 0 1rem;font-size:.92rem;color:var(--paper);opacity:.86;line-height:1.6}
.consent a{color:var(--copper);text-decoration:underline;text-underline-offset:2px}
.consent-row{display:flex;flex-wrap:wrap;gap:10px}
.consent-row button{font-family:"DM Mono",monospace;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;padding:.8em 1.2em;border-radius:2px;cursor:pointer;transition:transform .2s var(--ease),background .2s,color .2s,border-color .2s}
.c-accept{background:var(--copper);color:#1a1310;border:1px solid var(--copper)}
.c-accept:hover{background:var(--paper);border-color:var(--paper);transform:translateY(-2px)}
.c-deny{background:none;border:1px solid var(--line-dark);color:var(--paper)}
.c-deny:hover{border-color:var(--copper);color:var(--copper)}

/* ===================== 404 ===================== */
.error-page{min-height:100svh;display:grid;place-items:center;text-align:center;padding:6vh 5vw}
.error-page .code{font-family:"DM Mono",monospace;font-size:.74rem;letter-spacing:.3em;text-transform:uppercase;color:var(--copper);margin-bottom:1.4rem}
.error-page h1{font-family:"Cormorant Garamond",serif;font-weight:500;font-size:clamp(2.4rem,7vw,4.6rem);line-height:1.02;margin:0 0 .5em;max-width:16ch}
.error-page p{max-width:46ch;margin:0 auto 2.2rem;color:var(--paper);opacity:.82}
.error-ap{width:120px;margin:0 auto 2.4rem;opacity:.85}
.error-ap circle{fill:none;stroke:var(--copper);stroke-width:1.4}
.error-ap line{stroke:var(--copper);stroke-width:.9;opacity:.5}

/* ===================== GALERIJ ===================== */
.gallery-sec{background:var(--ink)}
.gallery{columns:1;column-gap:14px}
@media(min-width:620px){.gallery{columns:2}}
@media(min-width:980px){.gallery{columns:3}}
.shot{break-inside:avoid;margin:0 0 14px}
.shot-btn{display:block;width:100%;padding:0;border:0;background:none;cursor:pointer;position:relative;overflow:hidden;border-radius:3px}
.shot-btn img{width:100%;height:auto;display:block;transition:transform .6s var(--ease)}
.shot-btn:hover img,.shot-btn:focus-visible img{transform:scale(1.04)}
.shot-btn figcaption{position:absolute;left:0;right:0;bottom:0;padding:1.6rem .9rem .7rem;font-family:"DM Mono",monospace;font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--paper);text-align:left;background:linear-gradient(to top,rgba(14,13,12,.82),transparent);opacity:0;transform:translateY(6px);transition:opacity .3s,transform .3s}
.shot-btn:hover figcaption,.shot-btn:focus-visible figcaption{opacity:1;transform:none}
.shot-btn::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 0 1px var(--line-dark);border-radius:3px;pointer-events:none}

/* filmische band */
.band{position:relative;width:100%;height:clamp(300px,55vh,560px);overflow:hidden;padding:0}
.band-img{width:100%;height:100%;object-fit:cover;display:block}
.band-overlay{position:absolute;inset:0;display:flex;align-items:flex-end;padding:clamp(20px,4vw,48px);background:linear-gradient(to top,rgba(14,13,12,.55),rgba(14,13,12,.05) 42%,transparent)}
.band-overlay .eyebrow{color:var(--paper);opacity:.92}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:1100;background:rgba(8,7,6,.95);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s var(--ease)}
.lightbox.show{opacity:1}
.lightbox[hidden]{display:none}
.lb-fig{margin:0;display:flex;flex-direction:column;align-items:center;gap:.9rem}
.lb-fig img{max-width:92vw;max-height:80vh;width:auto;height:auto;object-fit:contain;border-radius:2px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.lb-fig figcaption{font-family:"DM Mono",monospace;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--paper);opacity:.85}
.lb-btn{position:absolute;background:none;border:0;color:var(--paper);cursor:pointer;line-height:1;transition:color .2s,transform .2s}
.lb-btn:hover,.lb-btn:focus-visible{color:var(--copper);outline:none}
.lb-close{top:clamp(10px,2vw,22px);right:clamp(12px,2.5vw,28px);font-size:2.4rem}
.lb-nav{top:50%;transform:translateY(-50%);font-size:3rem;padding:.2em .35em}
.lb-prev{left:clamp(4px,2vw,24px)}
.lb-next{right:clamp(4px,2vw,24px)}
@media(max-width:560px){.lb-nav{font-size:2.2rem}.lb-fig img{max-height:72vh}}

/* ===================== responsive ===================== */
@media (max-width:860px){
  .hero-grid{grid-template-columns:1fr;align-items:start;gap:2.2rem}
  .hero-aperture{display:none}
  .about-grid{grid-template-columns:1fr;gap:2rem}
  .about-portrait{aspect-ratio:16/10;order:-1}
  .process .steps{grid-template-columns:1fr}
  .case-card{grid-template-columns:1fr}
  .case-visual{min-height:220px}
  .case-body{padding:clamp(22px,5vw,34px)}
  .foot-grid{grid-template-columns:1fr;gap:2rem}
}
@media (max-width:560px){
  .work-item{grid-template-columns:1fr;gap:.5rem}
  .work-no{padding-top:0}
}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
  .splash-mark .word{filter:none;opacity:1;transform:none}
  .splash-mark .top,.splash-skip,.splash-blades{opacity:1}
  .splash-ring circle{stroke-dashoffset:0}
  .reveal{opacity:1;transform:none}
  .about-portrait img{filter:none !important;transform:none !important}
  .shot-btn img{transform:none !important}
}
