:root{
  --bg:#ECEAE1; --card:#fff; --ink:#161514; --muted:#8a857c;
  --line:#dcd8cd; --accent:#cf4d33; --accent2:#e2a23c; --ok:#2f9e54;
  --mono:ui-monospace,"SF Mono",Menlo,Consolas,monospace;
  --sans:"Helvetica Neue",Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
[hidden]{display:none!important}   /* anders overschrijft .overlay/.viewer de hidden-status */
html,body{margin:0;height:100%}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);
  -webkit-font-smoothing:antialiased;overflow:hidden}
.dots{position:fixed;width:220px;height:220px;pointer-events:none;opacity:.5;z-index:0;
  background-image:radial-gradient(var(--line) 1.4px,transparent 1.4px);
  background-size:13px 13px}
.dots-tl{top:0;left:0;-webkit-mask:linear-gradient(135deg,#000,transparent 70%);
  mask:linear-gradient(135deg,#000,transparent 70%)}
.dots-br{bottom:0;right:0;-webkit-mask:linear-gradient(-45deg,#000,transparent 70%);
  mask:linear-gradient(-45deg,#000,transparent 70%)}

header{display:flex;align-items:center;gap:16px;padding:14px 26px;
  border-bottom:1px solid var(--line);position:relative;z-index:2}
.brand{display:flex;align-items:center;gap:11px}
.logo-img{width:34px;height:34px;border-radius:9px;object-fit:cover;
  border:1px solid var(--line);background:#fff}
.brand-name{font-weight:800;letter-spacing:.01em;font-size:19px}
.brand-tag{font-family:var(--mono);font-size:11.5px;color:var(--muted);letter-spacing:.02em;
  padding-left:16px;border-left:1px solid var(--line)}
.nav{margin-left:auto;display:flex;gap:22px;align-items:center}
.nav a{font-family:var(--mono);font-size:12px;letter-spacing:.06em;color:var(--muted);cursor:pointer;
  text-decoration:none;text-transform:uppercase;display:flex;align-items:center}
.nav a.active,.nav a:hover{color:var(--ink)}
.nav-count{display:inline-grid;place-items:center;min-width:18px;height:18px;padding:0 5px;margin-left:5px;
  border-radius:999px;background:var(--line);color:var(--muted);font-size:10.5px;font-weight:700}
.nav a.active .nav-count{background:var(--ink);color:#fff}
/* account-knop (magic-link login) */
.nav-auth{text-transform:none!important;border:1px solid var(--line);border-radius:999px;
  padding:5px 13px;color:var(--ink);background:#fff;transition:.15s;max-width:160px;overflow:hidden;
  text-overflow:ellipsis;white-space:nowrap}
.nav-auth:hover{border-color:var(--ink)}
.nav-auth.is-pro{background:var(--accent,#cf4d33);border-color:var(--accent,#cf4d33);color:#fff;font-weight:700}
.auth-msg{margin-top:12px;font-size:12.5px;line-height:1.5}
.auth-msg.ok{color:var(--ok,#2f9e54)}
.auth-msg.err{color:var(--accent,#cf4d33)}
.auth-msg a{color:var(--accent,#cf4d33);font-weight:700}
.auth-plan{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
.auth-plan.is-pro{color:var(--accent,#cf4d33);font-weight:700}
.auth-credits{color:var(--accent,#cf4d33);font-weight:700;font-size:12.5px}
/* billing (upgrade/credits/portal) in de account-modal */
.bill-block{margin:14px 0 4px;display:flex;flex-direction:column;gap:10px}
.bill-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.bill-grid-3{grid-template-columns:1fr 1fr 1fr}
.bill-btn{display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer;
  border:1px solid var(--line);background:#fff;border-radius:11px;padding:11px 8px;transition:.15s}
.bill-btn:hover{border-color:var(--ink);transform:translateY(-1px)}
.bill-btn b{font-size:13.5px;color:var(--ink)}
.bill-btn span{font-family:var(--mono);font-size:12px;color:var(--muted)}
.bill-btn.sm{padding:9px 6px}
.bill-cred-h{font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-top:4px;font-weight:800}
.bill-pro-note{font-size:13px;color:var(--muted);margin:0 0 2px;line-height:1.5}
.auth-logout{margin-top:14px;border:1px solid var(--line);background:#fff;color:var(--muted);
  border-radius:9px;padding:9px 14px;cursor:pointer;font-family:inherit;font-size:12.5px;width:100%;transition:.15s}
.auth-logout:hover{color:var(--ink);border-color:var(--ink)}
/* taalkiezer (auto-gevuld door i18n.js) — width:auto overschrijft de globale select-regel */
.lang-switch{display:inline-flex;align-items:center;gap:6px;color:var(--muted)}
.lang-switch svg{width:15px;height:15px}
.lang-select{width:auto;margin:0;font-family:var(--mono);font-size:12px;letter-spacing:.04em;
  color:var(--muted);background:#fff;border:1px solid var(--line);border-radius:9px;padding:5px 8px;cursor:pointer;transition:.15s}
.lang-select:hover{color:var(--ink);border-color:var(--ink)}
@media(max-width:820px){.brand-tag{display:none}}

/* tabs */
.tabs{display:inline-flex;background:#fff;border:1px solid var(--line);border-radius:999px;padding:3px;margin-bottom:12px}
.tab{border:none;background:none;font-family:inherit;font-size:13px;font-weight:600;color:var(--muted);
  padding:6px 16px;border-radius:999px;cursor:pointer}
.tab.active{background:var(--ink);color:#fff}

/* sketch */
#sketch{width:100%;height:auto;aspect-ratio:380/450;background:#fff;border:1px solid var(--line);
  border-radius:12px;touch-action:none;cursor:crosshair;display:block}
.sketch-tools{display:flex;align-items:center;gap:8px;margin:9px 0}
.sketch-tools input[type=range]{flex:1}
.mini{border:1px solid var(--line);background:#fff;border-radius:8px;padding:5px 9px;font-size:12px;cursor:pointer;font-family:inherit}
.mini.active{background:var(--ink);color:#fff;border-color:var(--ink)}

main{display:grid;grid-template-columns:430px 1fr;height:calc(100% - 61px);position:relative;z-index:1}
/* Modellen = aparte, volle-breedte pagina zonder de linker sidebar */
body.view-models main{grid-template-columns:1fr}
body.view-models .panel{display:none}

/* ---------- panel ---------- */
.panel{padding:24px 22px;overflow-y:auto;border-right:1px solid var(--line);display:flex;flex-direction:column;gap:26px}
.step-h{font-weight:700;font-size:13px;letter-spacing:.02em;display:flex;align-items:center;gap:10px;margin-bottom:14px;
  text-transform:uppercase}
.num{display:grid;place-items:center;width:20px;height:20px;border-radius:6px;
  background:var(--ink);color:#fff;font-family:var(--mono);font-size:11px;font-weight:600}
.opt{font-family:var(--mono);font-size:10.5px;color:var(--muted);font-weight:400;margin-left:auto;
  text-transform:none;letter-spacing:.04em}
.hint{font-size:12.5px;color:var(--muted);margin:0 0 12px;line-height:1.55}

.drop{display:grid;place-items:center;min-height:120px;border:2px dashed var(--line);
  border-radius:14px;background:#fff;cursor:pointer;text-align:center;color:var(--muted);
  font-size:13px;line-height:1.5;transition:.15s;overflow:hidden;padding:8px}
.drop:hover,.drop.over{border-color:var(--accent);color:var(--ink);background:#fffdf8}
.drop img{max-width:100%;max-height:200px;border-radius:8px}

textarea,select{width:100%;font-family:inherit;font-size:13px;border:1px solid var(--line);
  border-radius:9px;padding:10px 12px;background:#fff;resize:vertical;margin-bottom:10px;color:var(--ink)}
textarea:focus,select:focus{outline:none;border-color:var(--ink)}
textarea::placeholder{color:var(--muted)}
.choice{display:flex;gap:8px;font-size:12.5px;margin-top:10px}
.choice label{flex:1;display:flex;gap:7px;align-items:center;justify-content:center;cursor:pointer;
  border:1px solid var(--line);border-radius:8px;padding:8px 10px;background:#fff;color:var(--muted);transition:.15s}
.choice label:hover{border-color:var(--ink);color:var(--ink)}
.choice label:has(input:checked){border-color:var(--ink);color:var(--ink);font-weight:600;background:#faf9f5}

.sliders{display:flex;flex-direction:column;gap:14px}
.sl label{display:flex;justify-content:space-between;font-size:12.5px;margin-bottom:5px}
.sl label b{font-family:var(--mono);font-weight:600}
.sl .lab{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-size:11px}
input[type=range]{width:100%;-webkit-appearance:none;height:4px;border-radius:3px;
  background:var(--line);outline:none}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;
  border-radius:50%;background:var(--ink);cursor:pointer;border:3px solid #fff;box-shadow:0 0 0 1px var(--line)}
.adv{margin-top:14px}
.adv summary{font-family:var(--mono);font-size:11px;color:var(--muted);cursor:pointer;
  text-transform:uppercase;letter-spacing:.06em}
.adv .sliders{margin-top:14px}

.btn{display:block;width:100%;text-align:center;border:none;border-radius:9px;padding:12px;
  font-family:inherit;font-weight:600;font-size:13.5px;letter-spacing:.01em;cursor:pointer;
  transition:.15s;text-decoration:none}
.btn:disabled{opacity:.35;cursor:not-allowed}
.btn.primary{background:var(--ink);color:#fff;letter-spacing:.02em}
.btn.primary:not(:disabled):hover{background:var(--accent)}
.btn.ghost{background:#fff;border:1px solid var(--line);color:var(--ink);font-weight:500}
.btn.ghost:not(:disabled):hover{border-color:var(--ink)}

/* ---------- stage ---------- */
.stage{position:relative;display:flex;flex-direction:column;padding:16px;overflow:hidden}
.status{margin:auto;font-family:var(--mono);font-size:13px;color:var(--muted);text-align:center;max-width:340px;line-height:1.6}

/* ---------- onboarding (lege editor) ---------- */
.onboard{margin:auto;display:grid;place-items:center;width:100%;padding:18px;overflow:auto}
.ob-card{width:100%;max-width:640px;background:var(--card);border:1px solid var(--line);border-radius:20px;
  padding:30px 32px;box-shadow:0 18px 50px rgba(0,0,0,.06);text-align:center}
.ob-tag{display:inline-block;font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);border:1px solid var(--line);border-radius:999px;padding:5px 13px;margin-bottom:16px}
.ob-title{font-size:27px;font-weight:800;letter-spacing:-.01em;margin:0 0 8px}
.ob-sub{font-size:13.5px;color:var(--muted);line-height:1.55;margin:0 auto 22px;max-width:450px}
.ob-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;text-align:left}
.ob-tile{display:flex;gap:13px;align-items:flex-start;background:#fff;border:1px solid var(--line);
  border-radius:14px;padding:15px 16px;cursor:pointer;font-family:inherit;transition:.15s}
.ob-tile:hover{border-color:var(--accent);background:#fffdf8;transform:translateY(-2px);box-shadow:0 8px 22px rgba(0,0,0,.06)}
.ob-ic{flex:none;width:40px;height:40px;border-radius:11px;display:grid;place-items:center;background:#f3f0e8;color:var(--ink);transition:.15s}
.ob-ic svg{width:21px;height:21px}
.ob-tile:hover .ob-ic{background:var(--accent);color:#fff}
.ob-tx{display:flex;flex-direction:column;gap:3px;min-width:0}
.ob-tx b{font-size:14px;font-weight:700;display:flex;align-items:center;gap:7px}
.ob-tx i{font-style:normal;font-size:12px;color:var(--muted);line-height:1.45}
.ob-tx em{font-style:normal;font-family:var(--mono);font-size:10.5px;font-weight:600;color:var(--accent);
  background:#fbe9e4;border-radius:6px;padding:1px 7px}
.ob-desc{margin-top:22px;border-top:1px solid var(--line);padding-top:20px;text-align:left}
.ob-lbl{display:block;font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:9px}
.ob-row{display:flex;gap:9px}
.ob-row input{flex:1;font-family:inherit;font-size:13.5px;border:1px solid var(--line);border-radius:10px;padding:11px 13px;background:#fff;color:var(--ink)}
.ob-row input:focus{outline:none;border-color:var(--ink)}
.ob-gen{flex:none;border:none;border-radius:10px;padding:0 22px;font-family:inherit;font-weight:700;font-size:13.5px;background:var(--ink);color:#fff;cursor:pointer;transition:.15s}
.ob-gen:hover{background:var(--accent)}
.ob-note{font-size:12px;color:var(--muted);margin:10px 0 0;line-height:1.5}
@media(max-width:560px){.ob-grid{grid-template-columns:1fr}}
#workspace{flex:1;display:flex;flex-direction:column;min-height:0}
.viewer{flex:1;display:flex;flex-direction:column;min-height:0;width:100%;gap:10px}
.ed-head{display:flex;align-items:center;gap:10px}
.ed-title{font-weight:800;font-size:16px;display:flex;align-items:center;gap:9px}
#modelName{outline:none;border-radius:7px;padding:2px 7px;margin:0 -3px;cursor:text;transition:.15s;min-width:24px}
#modelName:hover{background:#f3f0e8}
#modelName:focus{background:#fff;box-shadow:0 0 0 2px var(--accent)}
.okdot{width:9px;height:9px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 3px rgba(47,158,84,.15)}
.ed-right{margin-left:auto;display:flex;align-items:center;gap:12px}
.actions{position:relative;display:flex;align-items:center;gap:8px}
.act-btn{font-family:var(--mono);font-size:12px;border:1px solid var(--line);background:#fff;border-radius:9px;padding:7px 13px;cursor:pointer;color:var(--ink)}
.act-btn:hover{border-color:var(--ink)}
/* Download STL — in de viewer-kop, naast Acties */
.dl-head{font-family:var(--mono);font-size:12px;border:1px solid var(--ok);background:var(--ok);
  color:#fff;border-radius:9px;padding:7px 14px;cursor:pointer;text-decoration:none;
  display:inline-flex;align-items:center;gap:6px;letter-spacing:.02em;white-space:nowrap}
.dl-head:hover{filter:brightness(1.06)}
/* gegenereerde previews (deeg / hoogtekaart / render) — klikbaar om te heropenen */
.results{display:flex;align-items:center;gap:6px}
.res-thumb{width:34px;height:34px;border-radius:8px;overflow:hidden;border:1px solid var(--line);
  background:#fff;cursor:pointer;padding:0;transition:.15s}
.res-thumb:hover{border-color:var(--accent);transform:translateY(-1px);box-shadow:0 3px 10px rgba(0,0,0,.1)}
.res-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.act-menu{position:absolute;right:0;top:calc(100% + 6px);background:#fff;border:1px solid var(--line);
  border-radius:12px;box-shadow:0 12px 34px rgba(0,0,0,.16);padding:6px;z-index:30;min-width:250px}
.act-menu button{display:flex;align-items:center;gap:11px;width:100%;text-align:left;border:none;background:none;
  font-family:inherit;font-size:13px;padding:9px 11px;border-radius:8px;cursor:pointer;color:var(--ink)}
.act-menu button:hover{background:#f3f0e8}
.act-menu button svg{flex:none;width:17px;height:17px;color:var(--muted);transition:.15s}
.act-menu button:hover svg{color:var(--ink)}
.act-menu button span{flex:1;display:flex;align-items:center}
.act-menu em{font-style:normal;font-family:var(--mono);font-size:9.5px;letter-spacing:.06em;color:var(--muted);
  border:1px solid var(--line);border-radius:5px;padding:1px 5px;margin-left:8px;text-transform:uppercase}
.act-sep{height:1px;background:var(--line);margin:5px 8px}

/* ===== werkruimtes-modal (instellingen-presets bewaren/inladen) ===== */
.wsmodal{position:fixed;inset:0;z-index:60;background:rgba(22,21,20,.55);
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:grid;place-items:center;padding:24px}
.wsm-card{width:100%;max-width:460px;background:var(--card);border:1px solid var(--line);border-radius:18px;
  box-shadow:0 22px 60px rgba(0,0,0,.28);padding:22px;max-height:80vh;display:flex;flex-direction:column}
.wsm-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.wsm-title{font-weight:700;font-size:16px}
.wsm-x{border:none;background:none;font-size:17px;line-height:1;color:var(--muted);cursor:pointer;
  width:30px;height:30px;border-radius:8px;transition:.15s}
.wsm-x:hover{background:#f3f0e8;color:var(--ink)}
.wsm-sub{color:var(--muted);font-size:12.5px;line-height:1.5;margin:0 0 16px}
.wsm-save{display:flex;gap:8px;margin-bottom:16px}
.wsm-save input{flex:1;font-family:inherit;font-size:13px;border:1px solid var(--line);border-radius:9px;
  padding:9px 12px;background:#fff;color:var(--ink)}
.wsm-save input:focus{outline:none;border-color:var(--ink)}
.wsm-savebtn{flex:none;border:none;background:var(--ink);color:#fff;font-family:inherit;font-size:13px;
  font-weight:600;border-radius:9px;padding:9px 14px;cursor:pointer;transition:.15s;white-space:nowrap}
.wsm-savebtn:hover{background:var(--accent)}
.wsm-list{overflow-y:auto;display:flex;flex-direction:column;gap:8px}
.wsm-empty{color:var(--muted);font-size:12.5px;line-height:1.5;text-align:center;padding:18px 8px;
  border:1px dashed var(--line);border-radius:10px}
.wsm-row{display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:11px;padding:10px 12px}
.wsm-row:hover{border-color:var(--ink)}
.wsm-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.wsm-info b{font-size:13.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wsm-info span{font-family:var(--mono);font-size:10.5px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wsm-acts{flex:none;display:flex;align-items:center;gap:6px}
.wsm-load{border:1px solid var(--line);background:#fff;color:var(--ink);font-family:inherit;font-size:12px;
  font-weight:600;border-radius:8px;padding:6px 12px;cursor:pointer;transition:.15s}
.wsm-load:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.wsm-del{border:1px solid var(--line);background:#fff;color:var(--muted);font-size:13px;line-height:1;
  width:30px;height:30px;border-radius:8px;cursor:pointer;transition:.15s}
.wsm-del:hover{border-color:var(--accent);color:var(--accent)}

/* gallery — premium overzicht: collecties-rail + raster + bulk-acties */
.gallery{align-self:stretch;width:100%;height:100%;display:flex;flex-direction:column;min-height:0;position:relative}
.gal-head{display:flex;align-items:center;gap:16px;flex-wrap:wrap;padding:2px 4px 18px;
  border-bottom:1px solid var(--line);margin-bottom:18px}
.gal-h{margin:0;font-size:20px;font-weight:800;letter-spacing:-.01em;display:flex;align-items:center;gap:9px}
.gal-count{font-family:var(--mono);font-size:12px;font-weight:600;color:var(--muted)}
.gal-tools{margin-left:auto;display:flex;align-items:center;gap:10px}
.gal-search{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:0 12px;height:38px;transition:.15s}
.gal-search:focus-within{border-color:var(--ink);box-shadow:0 0 0 3px rgba(207,77,51,.08)}
.gal-search svg{width:16px;height:16px;color:var(--muted);flex:none}
.gal-search input{border:none;background:none;outline:none;font-family:inherit;font-size:13px;color:var(--ink);width:210px;height:100%}
.gal-search input::placeholder{color:var(--muted)}
#galSort{width:auto;min-width:150px;height:38px;margin:0;font-size:12.5px;cursor:pointer}

/* layout: rail links, raster rechts */
.gal-body{flex:1;min-height:0;display:grid;grid-template-columns:236px 1fr;gap:26px;padding-bottom:4px}

/* ---- collecties-rail ---- */
.gal-side{display:flex;flex-direction:column;gap:4px;min-height:0;overflow-y:auto;padding-right:6px;
  border-right:1px solid var(--line)}
.gal-side-h{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);font-weight:700;padding:4px 10px 10px}
.col-list{display:flex;flex-direction:column;gap:3px}
.col-item{display:flex;align-items:center;gap:9px;padding:9px 11px;border-radius:10px;cursor:pointer;
  border:1px solid transparent;transition:.13s;position:relative}
.col-item:hover{background:#fff;border-color:var(--line)}
.col-item.on{background:var(--ink);border-color:var(--ink)}
.col-item.on .col-ic,.col-item.on .col-nm{color:#fff}
.col-item.on .col-ct{background:rgba(255,255,255,.22);color:#fff}
.col-item.drop{border-color:var(--accent);background:#fff;box-shadow:inset 0 0 0 1px var(--accent)}
.col-ic{width:17px;height:17px;flex:none;color:var(--muted)}
.col-ic svg{width:100%;height:100%;display:block}
.col-nm{flex:1;font-size:13px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.col-ct{font-family:var(--mono);font-size:10.5px;font-weight:700;color:var(--muted);background:var(--line);
  min-width:20px;height:18px;padding:0 6px;border-radius:999px;display:grid;place-items:center}
.col-menu-btn{flex:none;width:22px;height:22px;border:none;background:none;border-radius:6px;cursor:pointer;
  color:var(--muted);opacity:0;display:grid;place-items:center;font-size:15px;line-height:1}
.col-item:hover .col-menu-btn{opacity:1}
.col-item.on .col-menu-btn{color:#fff}
.col-menu-btn:hover{background:rgba(0,0,0,.08)}
.col-sep{height:1px;background:var(--line);margin:7px 10px}
.col-new{display:flex;align-items:center;gap:8px;margin-top:8px;padding:10px 11px;border:1px dashed var(--line);
  background:none;border-radius:10px;cursor:pointer;font-family:inherit;font-size:12.5px;font-weight:600;
  color:var(--muted);transition:.13s}
.col-new:hover{border-color:var(--ink);color:var(--ink);background:#fff}
.col-new svg{width:15px;height:15px;flex:none}

/* ---- raster ---- */
.gal-main{min-height:0;display:flex;flex-direction:column}
.gal-main-h{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:0 4px 14px}
.col-title{margin:0;font-size:15px;font-weight:700}
.sel-all{display:flex;align-items:center;gap:7px;font-family:var(--mono);font-size:11.5px;color:var(--muted);
  cursor:pointer;user-select:none}
.sel-all input{width:15px;height:15px;accent-color:var(--accent);cursor:pointer}
.gal-grid{flex:1;min-height:0;overflow-y:auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(186px,1fr));
  grid-auto-rows:max-content;gap:16px;padding:12px 6px 90px;align-content:start}
.gal-grid .empty{grid-column:1/-1;text-align:center;color:var(--muted);font-family:var(--mono);font-size:13px;margin-top:50px}
.card{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;cursor:pointer;
  transition:transform .15s,box-shadow .15s,border-color .15s;position:relative}
.card:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 10px 26px rgba(0,0,0,.09)}
.card.sel{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent)}
.card-img{position:relative;width:100%;aspect-ratio:4/3;background:#faf9f5;display:grid;place-items:center;overflow:hidden}
.card-img img{width:100%;height:100%;object-fit:cover;display:block}
.card-img.is-empty{background:linear-gradient(135deg,#f4f1ea,#e8e3d8)}
.card-ph{display:grid;place-items:center;color:#bdb4a3}
.card-ph svg{width:42px;height:42px;display:block}
.card-photos{position:absolute;top:8px;right:8px;display:flex;align-items:center;gap:4px;
  background:rgba(22,21,20,.72);color:#fff;font-family:var(--mono);font-size:11px;font-weight:600;
  padding:3px 7px;border-radius:999px;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}
.card-photos svg{width:12px;height:12px}
/* selectievakje linksboven (verschijnt bij hover of selectie) */
.card-check{position:absolute;top:8px;left:8px;width:24px;height:24px;border-radius:7px;cursor:pointer;
  display:grid;place-items:center;background:rgba(255,255,255,.9);border:1px solid var(--line);
  -webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);opacity:0;transition:.13s;z-index:2;color:transparent}
.card:hover .card-check,.card.sel .card-check{opacity:1}
.card-check svg{width:15px;height:15px;display:block}
.card.sel .card-check{background:var(--accent);border-color:var(--accent);color:#fff}
.card-b{padding:11px 12px;display:flex;flex-direction:column;gap:2px}
.card-b b{font-size:13.5px;font-weight:700}
.card-b span{font-family:var(--mono);font-size:11px;color:var(--ink)}
.card-b .muted{color:var(--muted)}

/* ---- bulk-actiebalk (zwevend onderaan) ---- */
.bulk-bar{position:absolute;left:50%;bottom:20px;transform:translateX(-50%);z-index:30;
  display:flex;align-items:center;gap:10px;background:var(--ink);color:#fff;
  padding:9px 12px 9px 14px;border-radius:14px;box-shadow:0 18px 50px rgba(0,0,0,.35);
  animation:bulkUp .18s ease}
@keyframes bulkUp{from{opacity:0;transform:translate(-50%,12px)}to{opacity:1;transform:translate(-50%,0)}}
.bulk-x{border:none;background:rgba(255,255,255,.14);color:#fff;width:28px;height:28px;border-radius:8px;
  cursor:pointer;font-size:14px;line-height:1;flex:none}
.bulk-x:hover{background:rgba(255,255,255,.26)}
.bulk-count{font-family:var(--mono);font-size:12px;font-weight:600;white-space:nowrap;padding:0 4px}
.bulk-sep{width:1px;height:24px;background:rgba(255,255,255,.2)}
.bulk-act{display:flex;align-items:center;gap:7px;border:none;background:rgba(255,255,255,.12);color:#fff;
  font-family:inherit;font-size:12.5px;font-weight:600;padding:8px 13px;border-radius:9px;cursor:pointer;transition:.13s}
.bulk-act:hover{background:rgba(255,255,255,.24)}
.bulk-act svg{width:15px;height:15px;flex:none}
.bulk-act.danger:hover{background:var(--accent)}
.bulk-move-wrap{position:relative}
.bulk-menu{position:absolute;left:0;bottom:calc(100% + 8px);min-width:200px;background:#fff;color:var(--ink);
  border:1px solid var(--line);border-radius:12px;box-shadow:0 16px 44px rgba(0,0,0,.22);padding:6px;
  max-height:320px;overflow-y:auto}
.bulk-menu button{display:flex;align-items:center;gap:9px;width:100%;text-align:left;border:none;background:none;
  font-family:inherit;font-size:13px;color:var(--ink);padding:9px 10px;border-radius:8px;cursor:pointer}
.bulk-menu button:hover{background:#f3f0e8}
.bulk-menu button svg{width:15px;height:15px;flex:none;color:var(--muted)}
.bulk-menu .bm-sep{height:1px;background:var(--line);margin:5px 4px}
.bulk-menu .bm-new{color:var(--accent);font-weight:600}
.bulk-menu .bm-new svg{color:var(--accent)}

/* ---- kleine tekst-invoer modal (collectie maken/hernoemen) ---- */
.mini-modal .modal-card{max-width:380px}
.mini-modal label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:7px}
.mini-modal input{width:100%;height:42px;border:1px solid var(--line);border-radius:10px;padding:0 13px;
  font-family:inherit;font-size:14px;color:var(--ink);outline:none;transition:.15s}
.mini-modal input:focus{border-color:var(--ink);box-shadow:0 0 0 3px rgba(207,77,51,.08)}
.mini-modal .mm-row{display:flex;gap:10px;justify-content:flex-end;margin-top:18px}
.mini-modal .mm-btn{border:1px solid var(--line);background:#fff;border-radius:10px;padding:10px 18px;
  font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;color:var(--ink)}
.mini-modal .mm-btn:hover{border-color:var(--ink)}
.mini-modal .mm-btn.primary{background:var(--ink);color:#fff;border-color:var(--ink)}
.mini-modal .mm-btn.primary:hover{background:#000}
.mini-modal .mm-btn.danger{background:var(--accent);color:#fff;border-color:var(--accent)}

@media(max-width:760px){
  .gal-body{grid-template-columns:1fr}
  .gal-side{border-right:none;border-bottom:1px solid var(--line);padding-bottom:10px;max-height:30vh}
}
.viewport{position:relative;flex:1;min-height:0;width:100%}
.three{width:100%;height:100%;background:
  radial-gradient(circle at 50% 32%,#eef1f5,#d2d8e0);border-radius:16px;border:1px solid var(--line);overflow:hidden}
.three canvas{display:block;border-radius:16px}
iframe.three{border:1px solid var(--line);border-radius:16px;background:#0b0f14;display:block}
.vtoolbar{position:absolute;top:10px;right:10px;z-index:8;display:flex;gap:3px;background:rgba(255,255,255,.92);
  backdrop-filter:blur(4px);border:1px solid var(--line);border-radius:11px;padding:4px;box-shadow:0 3px 12px rgba(0,0,0,.06)}
.vtoolbar button{border:none;background:none;font-family:var(--mono);font-size:11px;color:var(--muted);
  padding:5px 9px;border-radius:7px;cursor:pointer;letter-spacing:.02em}
.vtoolbar button:hover{color:var(--ink);background:#f0ede4}
.vtoolbar button.on{background:var(--ink);color:#fff}
.vsep{width:1px;background:var(--line);margin:3px 2px}
.vdims{position:absolute;left:12px;bottom:12px;z-index:8;display:flex;gap:8px;font-family:var(--mono);
  font-size:11px;color:var(--muted);background:rgba(255,255,255,.7);padding:3px 8px;border-radius:8px}
.vdims b{color:var(--ink)}

/* maatvoering op de grid (breedte × diepte + oppervlak) — tekstlabels volgen het 3D-model */
.dim-overlay{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:1}
.dim-label{position:absolute;left:0;top:0;display:inline-flex;align-items:center;gap:6px;
  padding:3px 10px 3px 4px;border-radius:999px;
  background:rgba(255,255,255,.82);backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px);
  border:1px solid var(--line);
  box-shadow:0 2px 9px rgba(22,21,20,.12),inset 0 0 0 1px rgba(255,255,255,.7);
  font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:.01em;
  color:var(--ink);white-space:nowrap;will-change:transform}
.dim-axis{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;
  width:17px;height:17px;border-radius:50%;background:var(--ink);color:#fff;
  font-family:var(--sans);font-size:10px;font-weight:800;letter-spacing:0;line-height:1}
.dim-val{padding-right:2px}
.dim-label.dim-w .dim-axis{background:var(--accent)}
.dim-label.dim-d .dim-axis{background:var(--ok)}
.dim-label.dim-h .dim-axis{background:var(--accent2)}
.dim-label.dim-a{padding:2px 10px;font-weight:600;font-style:italic;color:var(--muted);
  font-size:11px;background:rgba(255,255,255,.72)}

/* ── sidebar-modus-switch (Aanpassen ↔ Nieuwe vorm) ── */
.side-pane{display:flex;flex-direction:column;gap:26px}
.side-tabs{display:flex;gap:4px;background:#fff;border:1px solid var(--line);
  border-radius:11px;padding:4px;box-shadow:0 1px 3px rgba(0,0,0,.03)}
.side-tabs button{flex:1;border:none;background:none;font-family:inherit;font-weight:700;
  font-size:12.5px;color:var(--muted);padding:8px 10px;border-radius:8px;cursor:pointer;
  transition:background .15s,color .15s;letter-spacing:.01em}
.side-tabs button:hover:not(.on){color:var(--ink);background:#f3f0e8}
.side-tabs button.on{background:var(--ink);color:#fff}

/* laaghoogte-toolbar — verhuisd van de viewport naar de left sidebar */
.hpanel{display:flex;flex-direction:column}
.hp-body{display:flex;flex-direction:column;flex-wrap:nowrap;gap:3px;padding:0}
/* in de smalle sidebar: alles full-width gestapeld (geen flex-basis:100%-hoogtes) */
#sideEdit .hp-body>*{flex:0 0 auto;width:100%;min-width:0}
#sideEdit .hp-settings{grid-template-columns:auto 1fr;justify-content:stretch;
  column-gap:14px;padding:15px 18px}
#sideEdit .hp-row-ctl{justify-self:end}
#sideEdit .hl{min-width:0;padding:1px 0}
#sideEdit .hp-sec:first-child{margin-top:2px}

/* connector-paneel (links boven in de viewport) */
.cpanel{position:absolute;left:10px;top:10px;width:205px;background:rgba(255,255,255,.95);
  backdrop-filter:blur(6px);border:1px solid var(--line);border-radius:12px;
  box-shadow:0 8px 24px rgba(0,0,0,.14);padding:11px;display:flex;flex-direction:column;
  gap:9px;font-family:var(--mono);font-size:11px;z-index:6}
.cpanel[hidden]{display:none}
.cp-h{font-weight:800;color:var(--ink);font-size:12px;letter-spacing:.3px}
.cp-row{display:flex;gap:5px}
.cbtn{flex:1;border:1px solid var(--line);background:#faf8f2;color:var(--ink);border-radius:7px;
  padding:7px 4px;cursor:pointer;font-family:var(--mono);font-size:11px;white-space:nowrap}
.cbtn:hover:not(:disabled){background:#f0ede4}
.cbtn.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.cbtn:disabled{opacity:.4;cursor:default}
.cbtn.danger{color:var(--accent);border-color:#e3b7b0}
.cbtn.danger:hover:not(:disabled){background:#fbe9e6}
.cp-lbl{display:flex;flex-direction:column;gap:4px;color:var(--muted)}
.cp-lbl select,.cp-lbl input[type=range]{font-family:var(--mono);font-size:11px;width:100%}
.cp-check{display:flex;align-items:center;gap:7px;color:var(--muted);font-size:11px;cursor:pointer}
.cp-check input{margin:0;cursor:pointer}
.cp-hint{color:var(--muted);line-height:1.45;font-size:10px}

/* sectie-koppen (Laaghoogte / Wanddikte) — label + hairline-rule = premium */
.hp-sec{flex-basis:100%;width:100%;display:flex;align-items:center;gap:10px;
  font-size:10px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;
  color:var(--muted);margin:9px 0 1px}
.hp-sec::after{content:"";flex:1;height:1px;background:var(--line)}
.hl{flex:1;min-width:130px;padding:1px 2px}
.hl-top{display:flex;align-items:center;gap:7px;margin-bottom:6px}
.hl-sw{width:11px;height:11px;border-radius:4px;border:1px solid rgba(0,0,0,.15);flex:0 0 auto}
.hl-name{font-size:11.5px;font-weight:700;color:var(--ink)}
.hl-val{margin-left:auto;font-family:var(--mono);font-size:11px;font-weight:600;color:var(--muted)}
.hl input[type=range]{width:100%}

/* Totale grootte — premium hero-control (groot bewerkbaar getal + slider) */
.size-row{flex-basis:100%;width:100%;padding:2px 2px 2px}
.size-top{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.size-name{font-size:11.5px;font-weight:700;color:var(--ink)}
.size-field{margin-left:auto;display:inline-flex;align-items:center;background:#fff;
  border:1px solid var(--line);border-radius:10px;overflow:hidden;
  transition:border-color .15s,box-shadow .15s}
.size-field:focus-within{border-color:var(--ink);box-shadow:0 0 0 3px rgba(207,77,51,.12)}
.size-num{width:78px;border:none;background:none;text-align:right;margin:0;padding:7px 3px 7px 12px;
  font-family:var(--mono);font-size:15px;font-weight:700;color:var(--ink);
  -moz-appearance:textfield}
.size-num:focus{outline:none}
.size-num::-webkit-outer-spin-button,.size-num::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.size-unit{font-family:var(--mono);font-size:11px;font-weight:600;color:var(--muted);padding:0 11px 0 3px}
.size-range{width:100%}
.size-foot{display:flex;align-items:center;gap:8px;margin-top:8px;
  font-family:var(--mono);font-size:10.5px;color:var(--muted)}
.size-dims b{color:var(--ink);font-weight:700}
.size-reset{margin-left:auto;border:1px solid var(--line);background:#fff;cursor:pointer;
  font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  color:var(--muted);padding:4px 10px;border-radius:7px;transition:.15s}
.size-reset:hover{color:var(--accent);border-color:var(--accent)}

/* globale instellingen: nette uitgelijnde kaart (label-kolom | control-kolom) */
.hp-settings{flex-basis:100%;width:100%;display:grid;
  grid-template-columns:max-content max-content;justify-content:center;
  align-items:center;column-gap:18px;row-gap:10px;
  background:rgba(120,132,156,.06);border:1px solid var(--line);
  border-radius:12px;padding:13px 18px;margin:2px 0 2px}
.hp-row{display:contents}
.hp-row-lab{font-size:10.5px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;
  color:var(--muted);white-space:nowrap}
.hp-row-ctl{display:inline-flex;align-items:center;gap:10px;justify-self:start}
/* alle controls in de instellingen-kaart even hoog -> netjes uitgelijnd */
.hp-row-ctl .seg,.hp-row-ctl .hp-select,.hp-row-ctl .hp-prof-dots{height:30px}
/* segmented control (mm/inch · Aan/Uit) */
.seg{display:inline-flex;border:1px solid var(--line);border-radius:9px;overflow:hidden;background:#fff}
.seg button{border:none;background:transparent;padding:0 16px;font-size:11.5px;font-weight:700;
  cursor:pointer;color:var(--muted);transition:background .15s,color .15s}
.seg button:hover:not(.on){background:rgba(0,0,0,.04)}
.seg button.on{background:var(--accent,#E8612A);color:#fff}
/* wand-uitlijning: drie even brede knoppen op volle breedte + uitleg-hint */
.align-row{width:100%;padding:2px 2px 0}
.align-row .seg.seg-3{display:flex;width:100%}
.align-row .seg.seg-3 button{flex:1;padding:0;height:32px;font-size:11.5px;
  border-left:1px solid var(--line)}
.align-row .seg.seg-3 button:first-child{border-left:none}
.hp-hint{width:100%;font-size:10px;line-height:1.45;color:var(--muted);padding:5px 3px 2px}
/* merknaam-tekst op de zijwand */
.brand-row{width:100%;display:flex;flex-direction:column;gap:9px;padding:2px 2px 0}
.brand-input{width:100%;box-sizing:border-box;border:1px solid var(--line);border-radius:9px;
  padding:8px 11px;font-family:var(--mono);font-size:12.5px;font-weight:600;color:var(--ink);
  background:#fff;transition:border-color .15s,box-shadow .15s}
.brand-input:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 3px rgba(207,77,51,.12)}
.brand-sub{display:flex;align-items:center;gap:10px}
.brand-lab{font-size:10.5px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:var(--muted)}
.seg.seg-4{display:flex;flex:1}
.seg.seg-4 button{flex:1;padding:0;height:30px;font-size:11px;border-left:1px solid var(--line)}
.seg.seg-4 button:first-child{border-left:none}
.seg.seg-2{display:flex;flex:1}
.seg.seg-2 button{flex:1;padding:0;height:30px;font-size:11px;border-left:1px solid var(--line)}
.seg.seg-2 button:first-child{border-left:none}
.brand-sub .seg.seg-3{display:flex;flex:1}
.brand-sub .seg.seg-3 button{flex:1;padding:0;height:30px;font-size:11px;border-left:1px solid var(--line)}
.brand-sub .seg.seg-3 button:first-child{border-left:none}
/* dropdown kleurprofiel + aaneengesloten swatch-strip (zelfde hoogte, verticaal gecentreerd) */
.hp-select{font-size:11.5px;font-weight:700;color:var(--ink);cursor:pointer;background:#fff;
  border:1px solid var(--line);border-radius:9px;padding:0 11px;min-width:132px;margin:0}
.hp-prof-dots{display:inline-flex}
.hp-prof-dots i{width:16px;height:100%;border:1px solid rgba(0,0,0,.12);border-right:none}
.hp-prof-dots i:first-child{border-radius:6px 0 0 6px}
.hp-prof-dots i:last-child{border-radius:0 6px 6px 0;border-right:1px solid rgba(0,0,0,.12)}

/* ondergrond-kiezer (werkblad-thumbnails) */
.bg-row{display:inline-flex;gap:6px}
.bg-thumb{width:30px;height:30px;border-radius:7px;border:1px solid var(--line);cursor:pointer;padding:0;
  background-size:cover;background-position:center;transition:.15s}
.bg-thumb.bg-studio{background:radial-gradient(circle at 50% 32%,#eef1f5,#d2d8e0)}
.bg-thumb:hover{border-color:var(--ink)}
.bg-thumb.on{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent)}

/* Productfoto-studio (premium modal) */
.shoot-card{max-width:520px}
.shoot-head{text-align:center;margin-bottom:18px}
.shoot-head h2{margin:11px 0 6px}
.shoot-head .help-intro{margin:0}
.shoot-lbl{display:block;font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin:0 0 10px}
.shoot-styles{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:18px}
.shoot-style{display:flex;gap:11px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:12px;
  padding:11px 13px;cursor:pointer;font-family:inherit;transition:.15s}
.shoot-style:hover{border-color:var(--ink)}
.shoot-style.on{border-color:var(--accent);background:#fffdf8;box-shadow:0 0 0 2px rgba(207,77,51,.15)}
.shoot-style .si{flex:none;width:34px;height:34px;border-radius:9px;display:grid;place-items:center;background:#f3f0e8;color:var(--ink);transition:.15s}
.shoot-style .si svg{width:18px;height:18px}
.shoot-style.on .si{background:var(--accent);color:#fff}
.shoot-style b{font-size:13px;font-weight:700}
.shoot-rows{display:flex;flex-direction:column;gap:11px;margin-bottom:20px}
.shoot-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.shoot-row>span:first-child{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.shoot-row .seg{height:30px}
.shoot-note{font-size:12px;color:var(--muted);text-align:center;margin:10px 0 0}

/* ---------- Etsy Listing Studio (premium) ---------- */
.etsy-card{max-width:880px}
.etsy-head{text-align:center;margin-bottom:18px}
.etsy-head h2{margin:11px 0 6px}
.etsy-head .help-intro{margin:0}
.etsy-grid{display:grid;grid-template-columns:300px 1fr;gap:24px;align-items:start}
.etsy-sec-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.etsy-count{background:var(--ink);color:#fff;border-radius:999px;padding:2px 8px;font-size:10px}
.etsy-thumbs{display:grid;grid-template-columns:1fr 1fr;gap:8px;min-height:60px}
.etsy-empty{grid-column:1/-1;font-size:12.5px;color:var(--muted);line-height:1.5;margin:0;
  border:1px dashed var(--line);border-radius:10px;padding:14px;text-align:center}
.etsy-thumb{position:relative;padding:0;border:1px solid var(--line);border-radius:10px;overflow:hidden;
  cursor:pointer;background:#fff;aspect-ratio:1/1;transition:.15s}
.etsy-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.etsy-thumb:hover{border-color:var(--ink)}
.etsy-thumb .tick{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:50%;
  background:#fff;border:1px solid var(--line);color:transparent;display:grid;place-items:center;
  font-size:13px;font-weight:800;transition:.15s}
.etsy-thumb.on{border-color:var(--accent);box-shadow:0 0 0 2px rgba(207,77,51,.18)}
.etsy-thumb.on .tick{background:var(--accent);border-color:var(--accent);color:#fff}
.etsy-mk{display:flex;gap:8px;margin-top:10px}
.btn.sm{padding:8px 10px;font-size:12px;width:auto;flex:1}
.etsy-fields{display:flex;flex-direction:column;gap:13px}
.etsy-f{display:flex;flex-direction:column;gap:5px}
.etsy-f>span{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.etsy-f>span em{font-style:normal;float:right;opacity:.8}
.etsy-f input,.etsy-f textarea{width:100%;font-family:inherit;font-size:13px;border:1px solid var(--line);
  border-radius:9px;padding:10px 12px;background:#fff;color:var(--ink);margin:0;resize:vertical}
.etsy-f input:focus,.etsy-f textarea:focus{outline:none;border-color:var(--ink)}
.etsy-chips{display:flex;flex-wrap:wrap;gap:6px}
.etsy-chips:empty{display:none}
.etsy-chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;background:#faf9f5;
  border:1px solid var(--line);border-radius:999px;padding:4px 10px}
.etsy-chip i{font-style:normal;cursor:pointer;color:var(--muted);font-weight:800}
.etsy-chip i:hover{color:var(--accent)}
.etsy-row2{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.etsy-note{font-size:12px;color:var(--muted);margin:0;line-height:1.5}
.etsy-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}
.etsy-actions .btn{width:auto;flex:1 1 160px;margin:0}
@media(max-width:760px){.etsy-grid{grid-template-columns:1fr}}

/* inklapbare 'Weergave'-sectie boven de sliders */
.hp-setwrap{flex-basis:100%;width:100%}
.hp-setbar{width:100%;display:flex;align-items:center;gap:10px;border:none;background:none;cursor:pointer;
  padding:0;margin:6px 0 10px;font-size:10px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;
  color:var(--muted);font-family:inherit}
.hp-setbar:hover{color:var(--ink)}
.hp-setbar .hp-rule{flex:1;height:1px;background:var(--line)}
.hp-setbar .chev{font-size:11px;transition:.2s}
.hp-setwrap.collapsed .hp-setbar{margin-bottom:2px}
.hp-setwrap.collapsed .hp-setbar .chev{transform:rotate(-90deg)}
.hp-setwrap.collapsed .hp-settings{display:none}

/* ── inklapbare secties met alternerende achtergrond (overzicht in de sidebar) ── */
#sideEdit .hp-body{gap:7px}
.hp-group{width:100%;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--card)}
.hp-group:nth-of-type(even){background:#f1efe7}          /* alternerende tint */
.hp-group-bar{width:100%;display:flex;align-items:center;gap:10px;border:none;background:transparent;
  cursor:pointer;padding:11px 14px;color:var(--muted);font-family:inherit;
  font-size:10.5px;font-weight:800;letter-spacing:.6px;text-transform:uppercase}
.hp-group-bar:hover{color:var(--ink)}
.hp-group-bar .hp-rule{flex:1;height:1px;background:var(--line)}
.hp-group-bar .chev{font-size:11px;transition:transform .2s}
.hp-group-body{display:flex;flex-direction:column;gap:6px;padding:2px 14px 13px}
/* DISPLAY-grid binnen een sectie: strip de oude binnen-box (de groep is al de kaart);
   hogere specificiteit dan '#sideEdit .hp-settings' zodat padding/rand/bg echt wegvallen */
#sideEdit .hp-group-body .hp-settings{background:none;border:none;padding:0;margin:0;column-gap:12px}
.hp-group.collapsed .chev{transform:rotate(-90deg)}
.hp-group.collapsed .hp-group-body{display:none}

@media(max-width:820px){.hp-body{flex-direction:column;gap:8px}.hl{min-width:0}}
.thumbs{display:flex;gap:14px}
.thumbs figure{margin:0;background:#fff;border:1px solid var(--line);border-radius:12px;padding:8px;text-align:center}
.thumbs img{height:150px;display:block}
.thumbs figcaption{font-family:var(--mono);font-size:10.5px;color:var(--muted);margin-top:6px;letter-spacing:.04em}

.info{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px;justify-content:center}
.chip{font-family:var(--mono);font-size:12px;background:#fff;border:1px solid var(--line);
  border-radius:999px;padding:6px 12px}
.chip b{color:var(--ink)}
.chip.good{border-color:var(--ok);color:var(--ok)}
.chip.bad{border-color:var(--accent);color:var(--accent)}

/* info-knop + dialog */
.info-btn{margin-left:auto;width:20px;height:20px;border-radius:50%;border:1px solid var(--line);
  background:#fff;color:var(--muted);font-family:Georgia,serif;font-style:italic;font-size:13px;
  font-weight:700;cursor:pointer;display:grid;place-items:center;line-height:1}
.info-btn:hover{border-color:var(--accent);color:var(--accent)}
.modal{position:fixed;inset:0;background:rgba(22,21,20,.45);display:flex;align-items:center;
  justify-content:center;z-index:60;padding:24px}
.modal-card{background:#fff;border-radius:18px;max-width:560px;width:100%;max-height:86vh;
  overflow:auto;padding:26px 30px;position:relative;box-shadow:0 24px 70px rgba(0,0,0,.28)}
.modal-card h2{margin:0 0 12px;font-size:20px}
.modal-x{position:absolute;top:12px;right:16px;border:none;background:none;font-size:26px;
  cursor:pointer;color:var(--muted);line-height:1}
.modal-x:hover{color:var(--ink)}
.help-intro{font-size:13.5px;line-height:1.6;color:#534f48;margin:0 0 10px}
.help-row{display:grid;grid-template-columns:128px 1fr;gap:12px;padding:10px 0;
  border-top:1px solid var(--line);font-size:13px;line-height:1.5}
.help-row b{font-weight:700}.help-row span{color:#534f48}
.help-tip{margin-top:14px;background:#fbf7ee;border:1px solid var(--line);border-radius:10px;
  padding:11px 13px;font-size:12.5px;line-height:1.55}

/* lightbox + deeg */
.thumbs img{cursor:zoom-in}
/* premium foto-viewer */
.lightbox{position:fixed;inset:0;background:rgba(22,21,20,.9);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  z-index:60;display:flex;flex-direction:column;padding:18px;gap:14px}
.lb-top{display:flex;align-items:center;gap:12px}
.lb-meta{font-family:var(--mono);font-size:12px;color:#e9e6df;letter-spacing:.03em}
.lb-tools{margin-left:auto;display:flex;gap:8px}
.lb-tools button{font-family:var(--mono);font-size:12px;color:#e9e6df;background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.18);border-radius:9px;padding:8px 13px;cursor:pointer;transition:.15s}
.lb-tools button:hover{background:rgba(255,255,255,.18);color:#fff}
.lb-tools button.danger:hover{background:var(--accent);border-color:transparent;color:#fff}
.lb-stage{flex:1;min-height:0;display:flex;align-items:center;justify-content:center;gap:14px}
.lb-stage img{max-width:84vw;max-height:70vh;border-radius:12px;background:#fff;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.lb-nav{flex:none;width:46px;height:46px;border-radius:50%;border:1px solid rgba(255,255,255,.2);
  background:rgba(255,255,255,.1);color:#fff;font-size:24px;line-height:1;cursor:pointer;transition:.15s}
.lb-nav:hover:not(:disabled){background:rgba(255,255,255,.22)}
.lb-nav:disabled{opacity:.22;cursor:default}
.lb-thumbs{display:flex;gap:9px;justify-content:center;flex-wrap:wrap;max-height:84px;overflow:auto;padding:2px}
.lb-thumb{width:60px;height:60px;border-radius:9px;overflow:hidden;border:2px solid transparent;background:#fff;
  cursor:pointer;padding:0;opacity:.55;transition:.15s}
.lb-thumb:hover{opacity:1}
.lb-thumb.on{opacity:1;border-color:var(--accent)}
.lb-thumb img{width:100%;height:100%;object-fit:cover;display:block}
/* "+N" chip in de mini-strip naast Acties */
.res-more{display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:12px;
  font-weight:700;color:var(--muted);background:#f3f0e8}
.res-more:hover{color:var(--ink)}
.dough-btn{max-width:320px;margin-top:6px}

/* premium 3D-showroom: fullscreen, schone studio-gradient, model centraal */
.showroom{position:fixed;inset:0;z-index:70;display:flex;flex-direction:column;
  background:radial-gradient(120% 100% at 50% 42%, #f5f7fa 0%, #e3e8ef 55%, #d3d9e2 100%)}
.sr-top{position:absolute;top:0;left:0;right:0;z-index:2;display:flex;align-items:center;
  justify-content:space-between;padding:14px 18px;
  background:linear-gradient(to bottom, rgba(255,255,255,.7), rgba(255,255,255,0))}
.sr-title{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.sr-tools{display:flex;gap:8px}
.sr-tools button{font-family:var(--mono);font-size:12px;color:var(--ink);background:rgba(255,255,255,.72);
  border:1px solid var(--line);border-radius:9px;padding:7px 12px;cursor:pointer;transition:.15s;
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
.sr-tools button:hover{background:#fff}
.sr-tools button.on{border-color:var(--accent);color:var(--accent);box-shadow:0 0 0 2px rgba(207,77,51,.12)}
.sr-stage{position:relative;flex:1;min-height:0}
.sr-canvas{position:absolute;inset:0;width:100%;height:100%;display:block;touch-action:none}
.sr-bottom{position:absolute;left:0;right:0;bottom:0;z-index:2;display:flex;flex-direction:column;
  align-items:center;gap:9px;padding:0 18px 24px;pointer-events:none}
.sr-shot{pointer-events:auto;font-family:var(--mono);font-size:14px;font-weight:700;color:#fff;
  background:var(--accent);border:none;border-radius:999px;padding:13px 26px;cursor:pointer;transition:.15s;
  box-shadow:0 8px 24px rgba(207,77,51,.35)}
.sr-shot:hover{transform:translateY(-1px);box-shadow:0 11px 30px rgba(207,77,51,.42)}
.sr-shot:active{transform:translateY(0)}
.sr-hint{font-family:var(--mono);font-size:11px;color:var(--muted);text-align:center;
  background:rgba(255,255,255,.55);padding:3px 10px;border-radius:999px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
/* kleurprofiel-rail: schaalt mee, horizontaal scrollbaar bij veel profielen */
.sr-palette{pointer-events:auto;display:flex;align-items:center;gap:10px;max-width:100%;
  background:rgba(255,255,255,.62);border:1px solid var(--line);border-radius:999px;
  padding:7px 12px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
.sr-pal-lbl{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);flex:none}
.sr-swatches{display:flex;gap:7px;overflow-x:auto;overflow-y:hidden;padding:4px 2px;scrollbar-width:thin}
.sr-swatch{flex:none;width:26px;height:26px;border-radius:50%;cursor:pointer;padding:0;
  border:2px solid #fff;box-shadow:0 0 0 1px var(--line);transition:.15s}
.sr-swatch:hover{transform:scale(1.12)}
.sr-swatch.on{box-shadow:0 0 0 2px var(--accent);transform:scale(1.12)}

.overlay{position:fixed;inset:0;background:rgba(236,234,225,.82);backdrop-filter:blur(2px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;z-index:50;
  font-family:var(--mono);font-size:13px;color:var(--ink)}
.spinner{width:42px;height:42px;border:4px solid var(--line);border-top-color:var(--accent);
  border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

@media(max-width:820px){main{grid-template-columns:1fr;height:auto;overflow:auto}
  body{overflow:auto}.panel{border-right:none;border-bottom:1px solid var(--line)}}
