/* ============================================================
   Verkeerscentrale Amsterdam — Casus-website (Cirkelstad)
   Volledig-scherm paginamodel · ← → + ☰-menu · clean
   Palet: warm wit / bijna-zwart / spaarzaam Amsterdam-rood
   Type:  Archivo (display/ui) · Newsreader (serif) · Space Mono (labels)
   ============================================================ */

:root{
  --paper:      #FAF8F4;
  --paper-2:    #F2EEE6;
  --ink:        #17150F;
  --ink-soft:   #3A362E;
  --muted:      #6E6A60;
  --faint:      #A19B8E;
  --line:       #E5E0D5;
  --line-2:     #D7D0C2;
  --accent:     #E4000F;   /* Amsterdam-rood — gedoseerd */
  --accent-ink: #C40010;

  --fs-display: clamp(40px, 6.2vw, 104px);
  --fs-cover:   clamp(44px, 7.2vw, 132px);
  --fs-h2:      clamp(30px, 4.0vw, 66px);
  --fs-lead:    clamp(19px, 1.85vw, 32px);
  --fs-body:    clamp(15px, 1.18vw, 21px);
  --fs-label:   clamp(11px, 0.82vw, 14px);
  --fs-stat:    clamp(56px, 9vw, 168px);

  --pad-x:      clamp(30px, 6.2vw, 128px);
  --pad-y:      clamp(30px, 6vh, 92px);
  --wrap:       1460px;
}

*{ box-sizing:border-box; }
html,body{ height:100%; margin:0; }
body{
  background:var(--ink);
  color:var(--ink);
  font-family:"Archivo",system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;
  overflow:hidden;
}

/* ---------- Deck / pages ---------- */
#deck{ position:relative; width:100vw; height:100vh; background:var(--paper); }

.page{
  position:absolute; inset:0;
  background:var(--paper);
  padding:var(--pad-y) var(--pad-x);
  display:flex; flex-direction:column; justify-content:center;
  opacity:0; visibility:hidden;
  transform:translateY(12px);
  transition:opacity .6s ease, transform .6s ease, visibility .6s;
  overflow:hidden;
}
.page.active{ opacity:1; visibility:visible; transform:none; z-index:2; }

.wrap{ width:100%; max-width:var(--wrap); margin:0 auto; }

/* running head / eyebrow */
.eyebrow{
  font-family:"Space Mono",monospace;
  font-size:var(--fs-label);
  letter-spacing:.14em; text-transform:uppercase;
  color:var(--muted);
  display:flex; align-items:center; gap:.75em;
  margin:0 0 clamp(14px,2.2vh,30px);
}
.eyebrow::before{ content:""; width:46px; height:15px; flex:none;
  background:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2058%2018'%3E%3Cg%20stroke='%23E4000F'%20stroke-width='3.4'%3E%3Cpath%20d='M2%203L12%2015M12%203L2%2015'/%3E%3Cpath%20d='M22%203L32%2015M32%203L22%2015'/%3E%3Cpath%20d='M42%203L52%2015M52%203L42%2015'/%3E%3C/g%3E%3C/svg%3E") no-repeat left center; background-size:contain; }

h2.head{
  font-size:var(--fs-h2); font-weight:700; line-height:1.02;
  letter-spacing:-.018em; margin:0 0 clamp(14px,2vh,28px); text-wrap:balance;
}

.lead{
  font-family:"Newsreader",Georgia,serif;
  font-size:var(--fs-lead); line-height:1.3; font-weight:400;
  color:var(--ink-soft); max-width:24em; margin:0;
}
.lead.wide{ max-width:32em; }

p.body{
  font-family:"Newsreader",Georgia,serif;
  font-size:var(--fs-body); line-height:1.5; color:var(--ink-soft); margin:0; max-width:34em;
}

.supplier{
  font-family:"Space Mono",monospace; font-size:var(--fs-label);
  letter-spacing:.06em; text-transform:uppercase; color:var(--muted);
  margin-top:clamp(14px,2vh,22px); display:flex; align-items:center; gap:.6em;
}
.supplier::before{ content:""; width:6px; height:6px; background:var(--accent); border-radius:50%; flex:none; }
.supplier b{ color:var(--ink); font-weight:700; }

/* ---------- Layout helpers ---------- */
.split{ display:grid; grid-template-columns:1.02fr .98fr; gap:clamp(34px,5vw,92px); align-items:center; }
.split.media-first{ grid-template-columns:.98fr 1.02fr; }
.split .media-first-el{ order:-1; }
.stack-gap > * + *{ margin-top:clamp(16px,2.2vh,28px); }
.duo{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,4vw,72px); align-items:start; }
.duo h4{ font-size:clamp(15px,1.1vw,20px); font-weight:700; letter-spacing:.02em; margin:0 0 12px; text-transform:uppercase; }
.duo h4 .rm{ color:var(--accent-ink); font-family:"Space Mono",monospace; font-size:.8em; margin-right:.6em; }

/* ---------- Placeholder image ---------- */
.ph, .shot{
  position:relative; width:100%; height:100%;
  background:repeating-linear-gradient(135deg,#ECE7DD 0 11px,#F4F0E8 11px 22px);
  border:1px solid var(--line-2); border-radius:3px; overflow:hidden;
  display:flex; align-items:flex-end;
}
.shot img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.ph.tall{ min-height:clamp(300px,54vh,640px); }
.ph.med{ min-height:clamp(220px,42vh,480px); }
.ph .cap{
  position:relative; z-index:1;
  font-family:"Space Mono",monospace; font-size:var(--fs-label);
  letter-spacing:.08em; text-transform:uppercase; color:#8B8578;
  padding:12px 15px; background:linear-gradient(transparent,rgba(250,248,244,.92) 55%);
  width:100%;
}
.ph .cap b{ color:var(--accent-ink); font-weight:700; }

/* ---------- Ticked list ---------- */
.ticks{ list-style:none; padding:0; margin:clamp(14px,2vh,24px) 0 0; display:grid; gap:clamp(10px,1.5vh,18px); max-width:32em; }
.ticks li{ position:relative; padding-left:24px;
  font-family:"Newsreader",serif; font-size:var(--fs-body); line-height:1.45; color:var(--ink-soft); }
.ticks li::before{ content:""; position:absolute; left:0; top:.6em; width:9px; height:9px; background:var(--accent); border-radius:50%; }
.ticks li b{ font-family:"Archivo",sans-serif; font-weight:700; color:var(--ink); }

/* ---------- Numbered index ---------- */
.index{ display:grid; gap:0; margin-top:clamp(26px,3.4vh,46px); border-top:1px solid var(--line); }
.index .row{
  display:grid; grid-template-columns:auto 1fr; gap:clamp(20px,2.6vw,44px);
  align-items:baseline; padding:clamp(16px,2.3vh,26px) 0; border-bottom:1px solid var(--line);
}
.index .num{ font-family:"Space Mono",monospace; font-size:clamp(14px,1.1vw,20px); color:var(--accent-ink); letter-spacing:.05em; }
.index .rt h3{ font-size:clamp(21px,2.2vw,36px); font-weight:600; margin:0 0 5px; letter-spacing:-.01em; }
.index .rt p{ font-family:"Newsreader",serif; font-size:var(--fs-body); color:var(--muted); margin:0; }

/* ---------- Kerngetallen strip ---------- */
.facts{ display:flex; flex-wrap:wrap; gap:clamp(22px,3.2vw,60px); margin-top:clamp(24px,3.2vh,42px); }
.facts .f b{ display:block; font-size:clamp(28px,2.8vw,48px); font-weight:700; letter-spacing:-.015em; line-height:1; }
.facts .f span{ font-family:"Space Mono",monospace; font-size:var(--fs-label); letter-spacing:.1em; text-transform:uppercase; color:var(--muted); display:block; margin-top:9px; }

/* ---------- Stats (energie) ---------- */
.stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(28px,4.5vw,88px);
  margin:clamp(12px,2vh,28px) 0 clamp(24px,3.2vh,42px); }
.stat b{ display:block; font-size:var(--fs-stat); font-weight:700; line-height:.86; letter-spacing:-.035em; color:var(--ink); }
.stat b sup{ font-size:.42em; font-weight:600; vertical-align:super; }
.stat .lb{ font-family:"Newsreader",serif; font-size:clamp(15px,1.15vw,21px); color:var(--ink-soft); margin-top:16px; display:block; line-height:1.32; }
.stat .lb u{ text-decoration:none; font-family:"Space Mono",monospace; font-size:var(--fs-label); letter-spacing:.08em; text-transform:uppercase; color:var(--muted); display:block; margin-top:7px; }
.note{ font-family:"Space Mono",monospace; font-size:var(--fs-label); letter-spacing:.1em; text-transform:uppercase; color:var(--muted); display:flex; align-items:center; gap:.6em; }
.note::before{ content:""; width:22px; height:2px; background:var(--accent); }

/* ---------- Locatie: luchtfoto + versleepbaar punt ---------- */
.intro-split{ grid-template-columns:1.06fr .94fr; }
.map-col{ display:flex; flex-direction:column; gap:clamp(10px,1.4vh,16px); }
.intro-split .vca-photo{ height:clamp(340px,66vh,640px); }
.vca-photo{ position:relative; width:100%; height:clamp(258px,46vh,486px);
  border:1px solid var(--line-2); border-radius:3px; overflow:hidden; background:var(--paper-2); }
.vca-photo.tall{ height:clamp(300px,56vh,620px); }
.vca-photo img{ width:100%; height:100%; object-fit:cover; display:block;
  user-select:none; -webkit-user-drag:none; }
.vca-dot{ position:absolute; left:50%; top:47%; width:22px; height:22px; transform:translate(-50%,-50%);
  border-radius:50%; background:var(--accent); border:3px solid #fff; box-shadow:0 2px 9px rgba(20,18,12,.55);
  cursor:grab; touch-action:none; z-index:5; }
.vca-dot::after{ content:""; position:absolute; inset:-7px; border-radius:50%; border:1px solid rgba(228,0,15,.55); }
.vca-dot:active{ cursor:grabbing; }
.vca-lbl{ position:absolute; bottom:calc(100% + 10px); left:50%; transform:translateX(-50%); white-space:nowrap;
  background:var(--ink); color:#fff; font-family:"Space Mono",monospace; font-size:10px; letter-spacing:.09em;
  text-transform:uppercase; font-weight:700; padding:3px 8px; border-radius:3px;
  box-shadow:0 2px 8px rgba(20,18,12,.3); pointer-events:none; }
.vca-lbl::after{ content:""; position:absolute; top:100%; left:50%; transform:translateX(-50%);
  border:5px solid transparent; border-top-color:var(--ink); }
.vca-dot.flip .vca-lbl{ bottom:auto; top:calc(100% + 10px); }
.vca-dot.flip .vca-lbl::after{ top:auto; bottom:100%; border-top-color:transparent; border-bottom-color:var(--ink); }
.map-cap{ font-family:"Newsreader",Georgia,serif; font-size:clamp(14px,1.05vw,18px); letter-spacing:0;
  color:var(--muted); margin:0; line-height:1.42; }

/* ---------- Gallery ---------- */
.gal{ display:grid; grid-template-columns:2fr 1fr; grid-template-rows:1fr 1fr;
  gap:clamp(12px,1.4vw,20px); height:clamp(340px,62vh,700px); margin-top:clamp(20px,2.6vh,34px); }
.gal .g1{ grid-row:1 / span 2; }
.gal .ph{ min-height:0; }

/* ---------- Cover (page 0) ---------- */
.page.cover{ padding:0; justify-content:flex-end; }
.page.cover .cover-img{ position:absolute; inset:0; }
.page.cover .cover-img img{ width:100%; height:100%; object-fit:cover; }
.page.cover .scrim{ position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(20,18,12,.28) 0%, rgba(20,18,12,0) 26%, rgba(20,18,12,0) 44%, rgba(20,18,12,.72) 100%); }
.page.cover .cover-body{ position:relative; z-index:2; padding:var(--pad-x); padding-bottom:clamp(46px,7vh,96px); width:100%; max-width:1500px; margin:0 auto; }
.cover-kicker{ font-family:"Space Mono",monospace; font-size:var(--fs-label); letter-spacing:.2em; text-transform:uppercase; color:rgba(255,255,255,.9); display:flex; align-items:center; gap:.8em; margin:0 0 clamp(18px,2.4vh,30px); }
.cover-kicker::before{ content:""; width:52px; height:16px; flex:none;
  background:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2058%2018'%3E%3Cg%20stroke='%23E4000F'%20stroke-width='3.4'%3E%3Cpath%20d='M2%203L12%2015M12%203L2%2015'/%3E%3Cpath%20d='M22%203L32%2015M32%203L22%2015'/%3E%3Cpath%20d='M42%203L52%2015M52%203L42%2015'/%3E%3C/g%3E%3C/svg%3E") no-repeat left center; background-size:contain; }
.page.cover h1{ font-size:var(--fs-cover); font-weight:700; line-height:.94; letter-spacing:-.025em; color:#fff; margin:0; text-wrap:balance; max-width:15em; }
.page.cover .cover-sub{ font-family:"Newsreader",serif; font-size:clamp(18px,1.7vw,29px); font-style:italic; color:rgba(255,255,255,.92); margin:clamp(18px,2.4vh,30px) 0 0; max-width:26em; line-height:1.32; }
.cover-corner{ position:absolute; top:clamp(24px,3.4vh,40px); right:clamp(28px,4vw,56px); z-index:2;
  font-family:"Space Mono",monospace; font-size:var(--fs-label); letter-spacing:.16em; text-transform:uppercase; color:rgba(255,255,255,.85); }

/* ---------- Full-bleed closing photo ---------- */
.page.bleed{ padding:0; }
.page.bleed .cover-img{ position:absolute; inset:0; }
.page.bleed .cover-img img{ width:100%; height:100%; object-fit:cover; }
.page.bleed .scrim{ position:absolute; inset:0; background:linear-gradient(180deg,rgba(20,18,12,0) 46%, rgba(20,18,12,.8) 100%); }
.colofon{ position:relative; z-index:2; margin-top:auto; padding:var(--pad-x); padding-bottom:clamp(28px,4.5vh,64px); width:100%; max-width:1500px; margin-left:auto; margin-right:auto; }
.colofon .cf-t{ font-family:"Space Mono",monospace; font-size:var(--fs-label); letter-spacing:.16em; text-transform:uppercase; color:rgba(255,255,255,.72); margin:0 0 12px; }
.colofon .cf-l{ font-family:"Space Mono",monospace; font-size:clamp(11px,.82vw,14px); letter-spacing:.04em; color:rgba(255,255,255,.9); line-height:1.65; margin:0; max-width:60em; }
.colofon .cf-l b{ color:#fff; }
.colofon .cf-l .sep{ color:var(--accent); padding:0 .5em; }

/* ============================================================
   Chrome — ☰-menu + ← → knoppen (verder niets)
   ============================================================ */
.page-footer{ position:fixed; left:0; right:0; bottom:clamp(22px,3.2vh,40px); z-index:55; padding:0 var(--pad-x); pointer-events:none; }
.page-footer .wrap{ max-width:var(--wrap); margin:0 auto; width:100%; }
.page-footer span{ font-family:"Space Mono",monospace; font-size:var(--fs-label); letter-spacing:.14em; text-transform:uppercase; color:var(--muted); }
body.chrome-light .page-footer{ display:none; }

.menu-btn{
  position:fixed; top:clamp(22px,3vh,36px); left:clamp(22px,3vw,42px); z-index:60;
  width:54px; height:54px; border:1px solid var(--line-2); border-radius:50%;
  background:rgba(250,248,244,.82); backdrop-filter:blur(7px);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:5px;
  cursor:pointer; transition:border-color .25s, background .25s;
}
.menu-btn:hover{ border-color:var(--accent); }
.menu-btn i{ display:block; width:20px; height:2px; background:var(--ink); transition:.3s; }

.controls{ position:fixed; right:clamp(22px,3vw,42px); bottom:clamp(22px,3vh,36px); z-index:60; display:flex; align-items:center; gap:13px; }
.controls button{
  width:54px; height:54px; border:1px solid var(--line-2); border-radius:50%;
  background:rgba(250,248,244,.82); backdrop-filter:blur(7px); cursor:pointer;
  display:flex; align-items:center; justify-content:center; color:var(--ink);
  transition:border-color .25s, color .25s, opacity .25s;
}
.controls button:hover:not(:disabled){ border-color:var(--accent); color:var(--accent); }
.controls button:disabled{ opacity:.32; cursor:default; }
.controls svg{ width:20px; height:20px; }

/* light chrome variant on photo pages */
body.chrome-light .menu-btn,
body.chrome-light .controls button{ background:rgba(30,26,18,.32); border-color:rgba(255,255,255,.45); }
body.chrome-light .menu-btn i{ background:#fff; }
body.chrome-light .controls button{ color:#fff; }
body.chrome-light .controls button:hover:not(:disabled){ border-color:#fff; color:#fff; }

/* ---------- Menu (Inhoud) ---------- */
.overlay{ position:fixed; inset:0; z-index:70; background:rgba(20,18,12,.34);
  opacity:0; visibility:hidden; transition:opacity .35s, visibility .35s; }
.overlay.open{ opacity:1; visibility:visible; }
.menu-panel{
  position:fixed; top:0; left:0; height:100%; width:min(470px,88vw); z-index:80;
  background:var(--paper); border-right:1px solid var(--line);
  padding:clamp(44px,7vh,92px) clamp(32px,4vw,62px);
  transform:translateX(-103%); transition:transform .44s cubic-bezier(.62,0,.2,1);
  display:flex; flex-direction:column;
}
.menu-panel.open{ transform:none; }
.menu-panel .mtitle{ font-family:"Space Mono",monospace; font-size:var(--fs-label); letter-spacing:.18em; text-transform:uppercase; color:var(--muted); margin:0 0 clamp(30px,4vh,50px); }
.menu-panel .close{ position:absolute; top:28px; right:30px; width:42px; height:42px; border:none; background:none; cursor:pointer; color:var(--muted); }
.menu-panel .close:hover{ color:var(--accent); }
.menu-panel .close svg{ width:22px; height:22px; }
.chapters{ list-style:none; margin:0; padding:0; }
.chapters button{
  width:100%; text-align:left; background:none; border:none; cursor:pointer;
  display:grid; grid-template-columns:auto 1fr; gap:22px; align-items:baseline;
  padding:clamp(14px,2vh,22px) 0; border-bottom:1px solid var(--line);
}
.chapters .cn{ font-family:"Space Mono",monospace; font-size:clamp(12px,.95vw,15px); color:var(--faint); }
.chapters .ct{ font-size:clamp(22px,2.2vw,34px); font-weight:600; color:var(--ink); letter-spacing:-.01em; transition:color .2s; }
.chapters button:hover .ct{ color:var(--accent); }
.chapters li.current .cn,
.chapters li.current .ct{ color:var(--accent); }
.menu-foot{ margin-top:auto; padding-top:34px; font-family:"Space Mono",monospace; font-size:var(--fs-label); letter-spacing:.08em; text-transform:uppercase; color:var(--faint); line-height:1.7; }

/* responsive */
@media (max-aspect-ratio:1/1), (max-width:860px){
  .split,.split.media-first{ grid-template-columns:1fr; gap:clamp(22px,3vh,38px); }
  .split .media-first-el{ order:0; }
  .stats,.duo{ grid-template-columns:1fr; gap:clamp(18px,2.4vh,30px); }
  .gal{ grid-template-columns:1fr 1fr; }
  .ph.tall{ min-height:clamp(220px,34vh,400px); }
}

/* ---------- Klikbare beeldframes + lightbox ---------- */
.shot-frame{ position:relative; display:block; width:100%; height:100%; padding:0;
  border:1px solid var(--line-2); border-radius:3px; overflow:hidden; cursor:pointer;
  background:var(--paper-2); font:inherit; }
.shot-frame img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .5s ease; }
.shot-frame.tall{ height:clamp(300px,54vh,600px); }
.photo-grid{ display:grid; grid-template-columns:repeat(6,1fr); grid-auto-rows:1fr;
  gap:clamp(6px,.7vw,12px); height:clamp(300px,64vh,760px); margin-top:clamp(16px,2.4vh,30px); }
.photo-grid .shot-frame{ height:100%; border-radius:2px; }
.photo-grid .shot-frame::after{ width:26px; height:26px; font-size:13px; top:8px; right:8px; }
.photo-grid .wide2{ grid-column:span 2; }
.mat-col{ display:grid; grid-template-columns:1fr 1fr; grid-template-rows:1fr 1fr; gap:clamp(9px,1.3vh,16px);
  height:clamp(320px,66vh,700px); }
.mat-col .shot-frame{ height:100%; }

/* ---------- Plattegronden + genummerde versleepbare punten ---------- */
.plans{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(10px,1.4vw,22px);
  margin-top:clamp(14px,2.2vh,28px); align-items:start; }
.plan{ display:flex; flex-direction:column; gap:clamp(7px,1vh,11px); }
.plan-img{ position:relative; width:100%; aspect-ratio:1/1; background:#fff;
  border:1px solid var(--line-2); border-radius:3px; overflow:hidden; }
.plan-img img{ width:100%; height:100%; object-fit:contain; display:block; padding:6px; }
.plan-cap{ font-family:"Newsreader",serif; font-size:clamp(14px,1.05vw,18px); letter-spacing:0;
  text-transform:none; color:var(--ink-soft); margin:0; text-align:left; }
.plan-cap b{ color:var(--ink); font-weight:600; }
.vca-dot.num{ width:26px; height:26px; display:flex; align-items:center; justify-content:center; }
.vca-dot.num::after{ display:none; }
.vca-dot.num b{ color:#fff; font-family:"Space Mono",monospace; font-weight:700; font-size:12px; line-height:1; }
.legend{ display:flex; flex-wrap:wrap; gap:clamp(10px,1.5vw,26px); margin-top:clamp(16px,2.4vh,32px); }
.legend .lg{ display:flex; align-items:center; gap:9px; font-family:"Newsreader",serif;
  font-size:clamp(14px,1.05vw,19px); color:var(--ink-soft); }
.legend .lg i{ flex:none; width:22px; height:22px; border-radius:50%; background:var(--accent); color:#fff;
  font-family:"Space Mono",monospace; font-style:normal; font-weight:700; font-size:11px;
  display:flex; align-items:center; justify-content:center; }
.plan-legend{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(10px,1.4vw,22px);
  margin-top:clamp(30px,6vh,80px); }
.plan-legend .lg-group{ display:flex; flex-direction:column; gap:clamp(5px,.85vh,10px); }
.plan-legend .lg-head{ font-family:"Space Mono",monospace; font-size:var(--fs-label);
  letter-spacing:.08em; text-transform:uppercase; color:var(--ink); margin:0 0 4px; }
.plan-legend .lg{ align-items:flex-start; }
.corner-render{ position:absolute; right:clamp(60px,14vw,320px); bottom:clamp(70px,16vh,190px);
  width:clamp(260px,32vw,520px); height:auto; aspect-ratio:1200/675; background:#fff; z-index:2; }
.corner-render img{ object-fit:contain; }
@media (max-aspect-ratio:1/1), (max-width:860px){
  .plans{ grid-template-columns:repeat(2,1fr); }
  .plan-legend{ grid-template-columns:repeat(2,1fr); }
}
.sec-layout{ display:grid; grid-template-columns:1.75fr 1fr; gap:clamp(16px,2vw,34px); align-items:start; }
.sec-main{ display:flex; flex-direction:column; gap:clamp(9px,1.5vh,18px); }
.sec-img{ height:calc(4 * clamp(56px,8.2vh,100px) + 3 * clamp(8px,1.1vh,15px)); }
.sec-legend{ margin-top:0; gap:clamp(8px,1vw,14px) clamp(14px,1.6vw,26px); }
.sec-legend .lg{ font-size:clamp(13px,.95vw,17px); }
.sec-renders{ display:grid; grid-template-rows:repeat(4,1fr); gap:clamp(8px,1.1vh,15px); height:calc(4 * clamp(56px,8.2vh,100px) + 3 * clamp(8px,1.1vh,15px)); }
.sec-renders .shot-frame{ height:100%; }
@media (max-aspect-ratio:1/1), (max-width:860px){
  .photo-grid{ grid-template-columns:repeat(3,1fr); height:auto; }
}
.shot-frame:hover img{ transform:scale(1.035); }
.shot-frame::after{ content:"\2922"; position:absolute; top:11px; right:12px; z-index:2; color:#fff; font-size:15px;
  width:30px; height:30px; border-radius:50%; background:rgba(20,18,12,.42); display:flex; align-items:center; justify-content:center;
  opacity:.9; transition:background .25s; }
.shot-frame:hover::after{ background:var(--accent); }
.shot-cap{ position:absolute; left:0; bottom:0; z-index:1; width:100%; padding:11px 14px; text-align:left;
  font-family:"Space Mono",monospace; font-size:var(--fs-label); letter-spacing:.08em; text-transform:uppercase; color:#EDEAE0;
  background:linear-gradient(transparent, rgba(20,18,12,.66) 72%); }
.shot-cap b{ color:#fff; font-weight:700; }

.lightbox{ position:fixed; inset:0; z-index:200; background:rgba(17,15,10,.95);
  display:none; align-items:center; justify-content:center; }
.lightbox.open{ display:flex; animation:lb-fade .28s ease; }
@keyframes lb-fade{ from{ opacity:0 } to{ opacity:1 } }
.lb-img{ max-width:90vw; max-height:86vh; object-fit:contain; box-shadow:0 24px 70px rgba(0,0,0,.55); background:#000; }
.lb-close{ position:fixed; top:24px; right:28px; width:50px; height:50px; z-index:210;
  border:1px solid rgba(255,255,255,.42); border-radius:50%; background:rgba(255,255,255,.07); color:#fff;
  cursor:pointer; display:flex; align-items:center; justify-content:center; transition:border-color .25s, color .25s; }
.lb-close:hover{ border-color:var(--accent); color:var(--accent); }
.lb-close svg{ width:22px; height:22px; }
.lb-nav{ position:fixed; top:50%; transform:translateY(-50%); width:56px; height:56px; z-index:210;
  border:1px solid rgba(255,255,255,.42); border-radius:50%; background:rgba(255,255,255,.07); color:#fff;
  cursor:pointer; display:flex; align-items:center; justify-content:center; transition:border-color .25s; }
.lb-nav:hover{ border-color:#fff; }
.lb-prev{ left:28px; } .lb-next{ right:28px; }
.lb-nav svg{ width:23px; height:23px; }
.lb-cap{ position:fixed; bottom:26px; left:50%; transform:translateX(-50%);
  font-family:"Space Mono",monospace; font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.82); }

/* ============================================================
   PRINT — PDF backup (liggend, één pagina per sectie)
   ============================================================ */
@media print{
  @page{ size:1600px 900px; margin:0; }
  html,body{ height:auto; overflow:visible; background:#fff; }
  .menu-btn,.overlay,.menu-panel,.controls,.lightbox,.page-footer{ display:none !important; }
  #deck{ height:auto; }
  .page{ position:relative; inset:auto; opacity:1 !important; visibility:visible !important;
    transform:none !important; height:900px; width:1600px; break-after:page; page-break-after:always; }
  *{ -webkit-print-color-adjust:exact !important; print-color-adjust:exact !important; }
}
