@font-face{font-family:'Bodoni Moda';font-style:normal;font-weight:400 800;font-display:swap;src:url('fonts/bodoni.woff2') format('woff2')}
@font-face{font-family:'Bodoni Moda';font-style:italic;font-weight:400 700;font-display:swap;src:url('fonts/bodoni-italic.woff2') format('woff2')}
@font-face{font-family:'Archivo';font-style:normal;font-weight:400 900;font-stretch:62.5% 125%;font-display:swap;src:url('fonts/archivo.woff2') format('woff2')}
@font-face{font-family:'Newsreader';font-style:normal;font-weight:300 600;font-display:swap;src:url('fonts/newsreader.woff2') format('woff2')}
@font-face{font-family:'Newsreader';font-style:italic;font-weight:300 600;font-display:swap;src:url('fonts/newsreader-italic.woff2') format('woff2')}
@font-face{font-family:'Pinyon Script';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/pinyon.woff2') format('woff2')}
:root{
  --paper:#FBF7EF;--paper-2:#F4EDE0;--kraft:#E9DEC9;
  --ink:#231C17;--ink-2:#4A3E35;--ink-3:#8A7868;--ink-4:#B5A492;
  --coral:#D6532F;--coral-2:#E8856A;--coral-soft:#F6DCCE;--gold:#B98A3E;--dark:#1E1511;
  --disp:'Bodoni Moda',serif;--sans:'Archivo',system-ui,sans-serif;
  --serif:'Newsreader',Georgia,serif;--script:'Pinyon Script',cursive;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
html{background:#1b120d;-webkit-text-size-adjust:100%}
body{font-family:var(--serif);color:var(--ink-2)}
img{display:block;max-width:100%}

/* ============ READER CHROME ============ */
body.reader{overflow:hidden;background:radial-gradient(120% 100% at 50% 0%,#2a1d15 0%,#160f0a 70%)}
.topbar{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  padding:11px 18px;background:rgba(20,13,9,.6);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.tb-l{font:800 15px var(--disp);color:#F6DCCE;letter-spacing:.14em}
.tb-l span{font:400 11px var(--serif);font-style:italic;color:rgba(246,220,206,.6);margin-left:7px}
.tb-r{display:flex;gap:9px;align-items:center}
.chap-pill{font:700 9px var(--sans);letter-spacing:.24em;text-transform:uppercase;color:rgba(246,220,206,.65)}
.btn{font:600 10px var(--sans);letter-spacing:.14em;text-transform:uppercase;cursor:pointer;color:#F6DCCE;
  background:transparent;border:1px solid rgba(246,220,206,.4);padding:8px 14px;border-radius:2px;transition:.18s;text-decoration:none}
.btn:hover{background:rgba(246,220,206,.14)}
.btn-p{background:var(--coral);border-color:var(--coral);color:#fff}.btn-p:hover{background:#C2451F}

.stage{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;overflow:hidden}
.scaler{transform-origin:center center}
.book{position:relative;width:840px;height:1080px;perspective:2600px}
.pg{position:absolute;inset:0;width:840px;height:1080px;overflow:hidden;background:var(--paper);
  box-shadow:0 30px 80px rgba(0,0,0,.5);backface-visibility:hidden;-webkit-backface-visibility:hidden;
  transform-style:preserve-3d;display:none}

.navbar{position:fixed;bottom:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:center;gap:22px;
  padding:14px;background:linear-gradient(0deg,rgba(20,13,9,.66),transparent)}
.nav-btn{width:48px;height:48px;border-radius:50%;border:1px solid rgba(246,220,206,.35);background:rgba(20,13,9,.5);
  color:#F6DCCE;font:300 26px/1 var(--sans);cursor:pointer;transition:.18s}
.nav-btn:hover{background:rgba(246,220,206,.18)}
.nav-btn:disabled{opacity:.3;cursor:default}
.folio-ind{font:600 11px var(--sans);letter-spacing:.26em;text-transform:uppercase;color:rgba(246,220,206,.8);min-width:74px;text-align:center}
.hint{position:fixed;left:0;right:0;bottom:74px;text-align:center;z-index:49;
  font:400 13px var(--serif);font-style:italic;color:rgba(246,220,206,.66);transition:opacity .6s;pointer-events:none}
.hint.hide{opacity:0}

/* ============ PAGE INTERIORS (840x1080) ============ */
.p-paper{background:var(--paper)}.p-kraft{background:var(--kraft)}
.p-dark{background:var(--dark);color:#EDE3D4}.p-cover,.p-photo{background:var(--dark)}
.inner{position:absolute;inset:62px 64px 74px;display:flex;flex-direction:column}
.rh{position:absolute;top:30px;left:64px;right:64px;display:flex;justify-content:space-between;
  font:600 9px var(--sans);letter-spacing:.34em;text-transform:uppercase;color:var(--ink-4);z-index:5}
.p-dark .rh{color:rgba(237,227,212,.4)}
.folio{position:absolute;bottom:28px;left:0;right:0;text-align:center;font:500 11px var(--disp);letter-spacing:.42em;color:var(--ink-3);z-index:5}
.p-dark .folio{color:rgba(237,227,212,.45)}
.kick{font:700 10.5px var(--sans);letter-spacing:.34em;text-transform:uppercase;color:var(--coral);margin-bottom:12px}
.h2{font:600 50px/1.0 var(--disp);color:var(--ink);margin-bottom:16px}
.pg-head{display:flex;align-items:baseline;gap:14px;margin-bottom:14px;border-bottom:1px solid rgba(35,28,23,.16);padding-bottom:10px}
.pg-head .pk{font:700 10px var(--sans);letter-spacing:.3em;text-transform:uppercase;color:var(--coral)}
.pg-head .pt{font:400 13px var(--serif);font-style:italic;color:var(--ink-3);margin-left:auto}

/* foto rijen/kolommen */
.prow{display:flex;gap:14px;flex:1;min-height:0}
.pcol{display:flex;flex-direction:column;gap:14px;flex:1;min-height:0}
.ph{position:relative;overflow:hidden;background:#E5DBC9;box-shadow:0 2px 14px rgba(30,18,10,.14);flex:1;min-height:0;min-width:0}
.ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.zoom{cursor:zoom-in}
.zoom::after{content:"\2922";position:absolute;right:9px;bottom:7px;color:#fff;font-size:14px;opacity:0;text-shadow:0 1px 4px rgba(0,0,0,.6);transition:.2s}
.zoom:hover::after{opacity:.85}

.capline{display:flex;gap:10px;align-items:baseline;margin-top:13px;border-top:1px solid rgba(35,28,23,.16);padding-top:8px}
.capmark{color:var(--coral);font:700 12px var(--sans)}
.capline-t{font:400 13px var(--serif);font-style:italic;color:var(--ink-3);flex:1}

.ed{outline:none;border-radius:2px;transition:background .15s;cursor:text;min-height:1em}
.ed:hover{background:rgba(214,83,47,.06)}
.ed:focus{background:rgba(214,83,47,.09);box-shadow:0 0 0 1px rgba(214,83,47,.25)}
.ed:empty::before{content:attr(data-hint);color:var(--ink-4);font-style:italic;pointer-events:none}
.p-cover .ed:empty::before{color:rgba(255,255,255,.6)}.p-dark .ed:empty::before{color:rgba(237,227,212,.4)}

.wjd{margin-top:16px;background:#fff;border-top:3px solid var(--coral);padding:14px 16px 16px;box-shadow:0 2px 14px rgba(30,18,10,.09);max-width:320px}
.wjd-k{font:700 9.5px var(--sans);letter-spacing:.3em;text-transform:uppercase;color:var(--coral)}
.wjd-n{font:600 24px var(--disp);color:var(--ink);margin:4px 0 6px}
.wjd-b{font:400 14px/1.5 var(--serif);font-style:italic;color:var(--ink-2);min-height:1.4em}

.quote-band{margin-top:18px;text-align:center;font:400 27px/1.4 var(--disp);font-style:italic;color:var(--ink);
  padding:18px 28px;border-top:1px solid rgba(35,28,23,.2);border-bottom:1px solid rgba(35,28,23,.2)}

/* opener */
.op-grid{display:grid;grid-template-columns:7fr 5fr;gap:34px;align-items:start;flex:1;min-height:0}
.op-body{font:400 16.5px/1.85 var(--serif);color:var(--ink-2)}
.op-sign{margin-top:20px;font:400 16px var(--serif);font-style:italic;color:var(--ink-3);text-align:right}
.op-side{display:flex;flex-direction:column}.op-side .ph{box-shadow:0 2px 14px rgba(30,18,10,.14)}

/* full-bleed */
.cov-bleed{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.p-photo .cov-bleed{cursor:zoom-in}
.full-grad{position:absolute;inset:0;background:linear-gradient(0deg,rgba(20,10,6,.7) 0%,rgba(20,10,6,0) 34%)}
.full-cap{position:absolute;left:64px;right:64px;bottom:54px;display:flex;gap:10px;align-items:baseline;color:#fff;z-index:4}
.full-cap .capmark{color:var(--coral-2)}
.full-cap .ed{font:400 16px var(--serif);font-style:italic;color:rgba(255,255,255,.92);flex:1}
.full-cap .ed:empty::before{color:rgba(255,255,255,.6)}
.p-photo .folio{color:rgba(255,255,255,.7)}

/* cover */
.cov-grad{position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,10,6,.5) 0%,rgba(20,10,6,.05) 36%,rgba(20,10,6,0) 52%,rgba(20,10,6,.8) 100%)}
.cov-top{position:absolute;top:40px;left:56px;right:56px;text-align:center;color:#fff}
.cov-issue{font:600 9.5px var(--sans);letter-spacing:.36em;text-transform:uppercase;color:rgba(255,255,255,.85)}
.cov-bottom{position:absolute;left:56px;right:56px;bottom:60px;display:flex;gap:24px;align-items:flex-end;color:#fff}
.cov-roman{font:400 26px var(--disp);color:#FFD9C4;border:1px solid rgba(255,217,196,.6);width:60px;height:60px;flex:0 0 60px;
  display:flex;align-items:center;justify-content:center;border-radius:50%}
.cov-kick{font:700 10.5px var(--sans);letter-spacing:.4em;text-transform:uppercase;color:rgba(255,255,255,.82);margin-bottom:8px}
.cov-title{font:600 88px/0.92 var(--disp);text-shadow:0 2px 30px rgba(20,10,6,.45);margin-bottom:12px}
.cov-sub{font:400 19px/1.5 var(--serif);font-style:italic;color:rgba(255,255,255,.93);max-width:34ch}
.cov-meta{margin-top:14px;font:600 9.5px var(--sans);letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.72)}

/* polaroids */
.pol-stage{position:absolute;inset:150px 40px 60px}
.pol{position:absolute;width:300px;background:#fff;padding:12px 12px 8px;box-shadow:0 12px 30px rgba(40,24,12,.32),0 2px 6px rgba(40,24,12,.2)}
.pol .ph{position:relative;width:100%;box-shadow:none}
.pol .tape{position:absolute;top:-11px;left:50%;width:88px;height:26px;margin-left:-44px;background:rgba(214,83,47,.5);transform:rotate(-2deg);z-index:3}
.polcap{font:400 22px/1.15 var(--script);color:var(--ink-2);padding:8px 4px 4px;text-align:center;min-height:30px}

/* closing */
.close-in{justify-content:center;align-items:center;text-align:center}
.close-roman{font:400 26px var(--disp);color:#FFD9C4;border:1px solid rgba(255,217,196,.5);width:58px;height:58px;
  display:flex;align-items:center;justify-content:center;border-radius:50%;margin-bottom:24px}
.kick-c{color:var(--coral-2)}
.close-h{font:600 58px/1.02 var(--disp);color:#FFD9C4;margin-bottom:18px}
.close-s{font:400 19px/1.6 var(--serif);font-style:italic;color:rgba(237,227,212,.86);max-width:32ch}
.close-ch{margin-top:24px;font:700 9px var(--sans);letter-spacing:.3em;text-transform:uppercase;color:rgba(237,227,212,.55)}

/* guestbook */
.gsub{font:400 16px var(--serif);font-style:italic;color:var(--ink-3);margin-bottom:18px}
.gform{display:flex;flex-direction:column;gap:11px;background:var(--paper-2);border-top:3px solid var(--coral);padding:18px;box-shadow:0 2px 14px rgba(30,18,10,.08)}
.gform input,.gform textarea{font:400 16px var(--serif);color:var(--ink);background:#fff;border:1px solid rgba(35,28,23,.18);border-radius:3px;padding:11px 13px;outline:none;width:100%}
.gform textarea{min-height:84px;resize:none}
.gform input:focus,.gform textarea:focus{border-color:var(--coral)}
.gform .grow{display:flex;justify-content:flex-end}
.gform button{font:600 11px var(--sans);letter-spacing:.16em;text-transform:uppercase;cursor:pointer;color:#fff;background:var(--coral);border:none;padding:11px 22px;border-radius:2px}
.gform button:hover{background:#C2451F}
.gentries{margin-top:18px;display:flex;flex-direction:column;gap:10px;overflow:auto;flex:1;min-height:0}
.gentry{background:#fff;border-left:3px solid var(--coral-2);padding:12px 14px;box-shadow:0 2px 10px rgba(30,18,10,.07)}
.gentry .gm{font:400 16px/1.5 var(--serif);color:var(--ink-2)}
.gentry .gmeta{margin-top:6px;font:600 9.5px var(--sans);letter-spacing:.16em;text-transform:uppercase;color:var(--ink-4)}
.gentry .gmeta b{color:var(--coral)}
.gempty{font:400 15px var(--serif);font-style:italic;color:var(--ink-4)}

/* lightbox */
.lb{position:fixed;inset:0;z-index:95;background:rgba(14,9,6,.97);display:none;align-items:center;justify-content:center;touch-action:none}
.lb.open{display:flex}
.lb img{max-width:94vw;max-height:88vh;object-fit:contain;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.lb-close,.lb-prev,.lb-next{position:absolute;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%}
.lb-close{top:18px;right:18px;width:46px;height:46px;font:300 26px/1 var(--sans)}
.lb-prev,.lb-next{top:50%;transform:translateY(-50%);width:54px;height:54px;font:300 30px/1 var(--sans)}
.lb-prev{left:16px}.lb-next{right:16px}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{background:rgba(255,255,255,.26)}
.lb-count{position:absolute;bottom:20px;left:0;right:0;text-align:center;font:600 10px var(--sans);letter-spacing:.24em;text-transform:uppercase;color:rgba(255,255,255,.7)}
@media (max-width:540px){.lb-prev,.lb-next{width:44px;height:44px;font-size:24px}}

/* ============ INDEX / CONTROL ============ */
body.idx{background:#B9AC99;overflow:auto}
.idx-bar{position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;padding:13px 20px;background:rgba(30,21,17,.92);backdrop-filter:blur(14px)}
.idx-hero{padding:60px 24px 26px;text-align:center;background:var(--paper)}
.idx-hero .kick{font:700 11px var(--sans);letter-spacing:.4em;text-transform:uppercase;color:var(--coral);margin-bottom:14px}
.idx-hero h1{font:600 clamp(42px,7vw,76px)/0.98 var(--disp);color:var(--ink);margin-bottom:14px}
.idx-hero p{font:400 17px/1.65 var(--serif);color:var(--ink-2);max-width:56ch;margin:0 auto}
.idx-note{max-width:740px;margin:24px auto 0;background:var(--paper-2);border-top:3px solid var(--coral);padding:16px 20px;font:400 14.5px/1.6 var(--serif);color:var(--ink-2);text-align:left}
.idx-note b{font-weight:600;color:var(--ink)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:22px;padding:40px 24px 80px;max-width:1100px;margin:0 auto;background:var(--paper)}
.card{display:block;text-decoration:none;color:inherit;background:#fff;box-shadow:0 4px 20px rgba(30,18,10,.16);overflow:hidden;transition:transform .2s,box-shadow .2s}
.card:hover{transform:translateY(-4px);box-shadow:0 14px 38px rgba(30,18,10,.26)}
.card-img{position:relative;aspect-ratio:1.4;overflow:hidden;background:#E5DBC9}
.card-img img{width:100%;height:100%;object-fit:cover}
.card-ch{position:absolute;top:12px;left:12px;font:700 9px var(--sans);letter-spacing:.2em;text-transform:uppercase;color:#fff;background:var(--coral);padding:6px 10px;border-radius:2px}
.card-b{padding:18px 20px 22px}
.card-t{font:600 28px/1 var(--disp);color:var(--ink);margin-bottom:7px}
.card-s{font:400 14.5px var(--serif);font-style:italic;color:var(--ink-3);margin-bottom:12px}
.card-m{font:600 9.5px var(--sans);letter-spacing:.2em;text-transform:uppercase;color:var(--ink-4)}
.idx-foot{padding:0 24px 60px;text-align:center;font:400 13px var(--serif);font-style:italic;color:var(--ink-3);background:var(--paper)}

/* ============ FOTO-LAYOUTS (v3, weinig tekst) ============ */
.lay{position:absolute;inset:0;display:flex;gap:7px;padding:7px;background:var(--paper)}
.lay.bleed{padding:0;gap:0}
.lay.frame{padding:62px;background:var(--paper)}
.lay.dark{padding:62px;background:var(--dark)}
.lay.kraft{background:var(--kraft);padding:9px;gap:9px}
.lay .prow{display:flex;gap:7px;flex:1;min-width:0;min-height:0}
.lay .pcol{display:flex;flex-direction:column;gap:7px;flex:1;min-width:0;min-height:0}
.lay .ph{box-shadow:none;flex:1;min-width:0;min-height:0}
.lay.frame .ph,.lay.dark .ph{box-shadow:0 12px 38px rgba(20,12,6,.42)}
/* polaroid scatter */
.pg .pol-stage{position:absolute;inset:0}
.pol{position:absolute;width:300px;background:#fff;padding:12px 12px 30px;box-shadow:0 14px 32px rgba(40,24,12,.34),0 2px 6px rgba(40,24,12,.2)}
.pol .ph{position:relative;width:100%;aspect-ratio:1;box-shadow:none;flex:none}
.pol .ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.pol .tape{position:absolute;top:-11px;left:50%;width:90px;height:26px;margin-left:-45px;background:rgba(214,83,47,.5);transform:rotate(-2deg);z-index:3}

/* ============ FULL-PAGE FLIPBOOK (v4): 1 foto per pagina, niets afsnijden ============ */
.photopage{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:var(--paper);padding:30px}
.photopage.dark{background:#211812}
.photopage img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;
  box-shadow:0 16px 44px rgba(20,12,6,.34);cursor:zoom-in;background:#E5DBC9}
