@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Montserrat:wght@300;400;500&display=swap');
:root{
  --noir:#16140F; --blanc:#FBFAF7; --ivoire:#F2EEE6; --sable:#C2A56B; --sable-f:#A9894E;
  --brun:#8A7B66; --pierre:#E6E0D5; --pierre-f:#D7CFC0;
  --serif:'Cormorant Garamond',Georgia,serif; --sans:'Montserrat',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--sans);color:var(--noir);background:var(--blanc);-webkit-font-smoothing:antialiased;line-height:1.55}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input{font-family:inherit}
img{display:block;max-width:100%}
a{color:inherit}
.hidden{display:none!important}
.eyebrow{font-size:10px;letter-spacing:4px;text-transform:uppercase;color:var(--sable-f)}

.topbar{position:fixed;top:0;left:0;right:0;z-index:40;display:flex;align-items:center;justify-content:center;
  padding:16px 30px;background:rgba(251,250,247,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--pierre)}
.logo-h{height:40px;width:auto;display:block}

/* PAGE CLIENT (entrée code) */
.gate{min-height:100vh;display:flex;flex-direction:column;padding:96px 24px 0}
.gate-body{flex:1;display:grid;place-items:center}
.gate-card{max-width:440px;width:100%;text-align:center}
.gate h2{font-family:var(--serif);font-weight:300;font-size:36px}
.gate p{color:var(--brun);font-size:14px;margin-top:10px}
.code-input{width:100%;text-align:center;font-family:var(--serif);font-size:25px;letter-spacing:6px;padding:17px 16px;margin-top:30px;
  border:1px solid var(--pierre-f);border-radius:3px;background:#fff;text-transform:uppercase;color:var(--noir);transition:.25s}
.code-input:focus{outline:none;border-color:var(--sable);box-shadow:0 0 0 4px rgba(194,168,107,.14)}
.code-input::placeholder{letter-spacing:3px;color:var(--pierre-f);text-transform:none;font-size:17px}
.btn{display:inline-block;font-family:var(--sans);font-size:10.5px;letter-spacing:2.5px;text-transform:uppercase;padding:15px 32px;
  background:var(--noir);color:var(--blanc);border-radius:2px;transition:.25s;text-align:center}
.btn:hover{background:var(--sable-f)}
.btn.full{width:100%;margin-top:14px;border:none;cursor:pointer}
.btn.ghost{background:transparent;color:var(--noir);border:1px solid var(--pierre-f)}
.btn.ghost:hover{border-color:var(--sable);color:var(--sable-f)}
.err{color:#9b3b2e;font-size:12.5px;margin-top:13px;min-height:18px}

.site-footer{text-align:center;padding:30px 20px 26px;font-size:11px;letter-spacing:1px;color:var(--brun)}
.site-footer .sep{margin:0 12px;color:var(--pierre-f)}
.site-footer a{color:var(--brun);text-decoration:none;border-bottom:1px solid transparent;transition:.2s;padding-bottom:2px}
.site-footer a:hover{color:var(--sable-f);border-color:var(--sable)}

/* GALERIE CLIENT */
.cover{position:relative;height:100vh;overflow:hidden;display:grid;place-items:center;text-align:center;color:#fff}
.cover .bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.04);animation:kb 18s ease-in-out infinite alternate}
@keyframes kb{to{transform:scale(1.12)}}
.cover::after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(22,20,15,.32),rgba(22,20,15,.18) 40%,rgba(22,20,15,.55))}
.cover-inner{position:relative;z-index:2;padding:24px}
.logo-cover{width:250px;max-width:64%;height:auto;margin:0 auto 22px;display:block;filter:drop-shadow(0 3px 22px rgba(0,0,0,.28))}
.cover .eyebrow{color:rgba(255,255,255,.85)}
.cover h1{font-family:var(--serif);font-weight:300;font-size:clamp(44px,8vw,96px);line-height:1.02;margin:18px 0 14px;text-shadow:0 2px 30px rgba(0,0,0,.25)}
.cover .date{font-size:12px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.9)}
.cover .scroll{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);z-index:2;color:#fff;display:flex;flex-direction:column;align-items:center;gap:10px;font-size:10px;letter-spacing:2.5px;text-transform:uppercase;cursor:pointer;opacity:.9}
.cover .scroll .chev{font-size:22px;animation:bob 2s ease-in-out infinite}
@keyframes bob{50%{transform:translateY(7px)}}

.galbar{position:fixed;top:0;left:0;right:0;z-index:45;display:flex;align-items:center;justify-content:space-between;padding:15px 30px;color:#fff;transition:.3s;pointer-events:none}
.galbar>*{pointer-events:auto}
.galbar.solid{background:rgba(251,250,247,.94);backdrop-filter:blur(10px);border-bottom:1px solid var(--pierre);color:var(--noir)}
.galbar .gname{font-family:var(--serif);font-size:18px;letter-spacing:.4px}
.galbar .acts{display:flex;gap:6px;align-items:center}
.tbtn{display:inline-flex;align-items:center;gap:7px;font-size:10px;letter-spacing:1.5px;text-transform:uppercase;padding:9px 14px;border-radius:2px;transition:.25s;color:inherit;border:1px solid transparent}
.tbtn:hover{background:rgba(255,255,255,.16)}
.galbar.solid .tbtn:hover{background:var(--ivoire)}
.tbtn .badge{background:var(--sable);color:#fff;border-radius:10px;padding:1px 7px;font-size:10px;letter-spacing:0}
.tbtn.exit{border-color:rgba(255,255,255,.4)}
.galbar.solid .tbtn.exit{border-color:var(--pierre-f)}

.gwrap{background:var(--blanc);padding:70px 26px 40px}
.gwrap .lead{max-width:560px;margin:0 auto 50px;text-align:center}
.gwrap .lead .eyebrow{display:block;margin-bottom:12px}
.gwrap .lead p{font-family:var(--serif);font-style:italic;font-size:21px;color:var(--brun);font-weight:300}
.masonry{max-width:1320px;margin:0 auto;column-gap:16px;columns:3}
@media(max-width:1000px){.masonry{columns:2}}
@media(max-width:600px){.masonry{columns:1}}
.ph{position:relative;break-inside:avoid;margin-bottom:16px;border-radius:2px;overflow:hidden;background:var(--pierre);cursor:zoom-in}
.ph img{width:100%;height:auto;transition:.7s ease}
.ph:hover img{transform:scale(1.04)}
.ph .veil{position:absolute;inset:0;background:linear-gradient(to top,rgba(22,20,15,.4),transparent 42%);opacity:0;transition:.3s}
.ph:hover .veil{opacity:1}
.heart{position:absolute;top:12px;right:12px;width:38px;height:38px;border-radius:50%;background:rgba(251,250,247,.85);display:grid;place-items:center;transition:.25s;z-index:2;opacity:0}
.ph:hover .heart,.heart.on{opacity:1}
.heart svg{width:18px;height:18px;stroke:var(--noir);fill:none;stroke-width:1.6;transition:.2s}
.heart.on{background:#fff}.heart.on svg{fill:var(--sable);stroke:var(--sable)}
.ph .dl{position:absolute;left:12px;bottom:12px;font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:#fff;background:rgba(22,20,15,.55);padding:7px 11px;border-radius:2px;opacity:0;transition:.3s;z-index:2;text-decoration:none}
.ph:hover .dl{opacity:1}.ph .dl:hover{background:var(--sable-f)}

#view-gallery.no-dl .dl,#view-gallery.no-dl #tDl{display:none!important}
#view-gallery.protected{user-select:none;-webkit-user-select:none}
#view-gallery.protected .ph img{-webkit-user-drag:none}

.lightbox{position:fixed;inset:0;z-index:60;background:rgba(14,13,10,.97);display:none;place-items:center}
.lightbox.show{display:grid}
.lightbox.no-dl #lbDl{display:none!important}
.lb-stage{position:relative;display:grid;place-items:center}
.lb-img{max-width:88vw;max-height:84vh;object-fit:contain;border-radius:2px;box-shadow:0 40px 90px -20px #000}
.lb-top{position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:22px 28px;color:rgba(251,250,247,.9)}
.lb-counter{font-family:var(--serif);font-size:17px;letter-spacing:2px}
.lb-close{font-size:11px;letter-spacing:2px;text-transform:uppercase;opacity:.85;background:none;border:none;color:inherit;cursor:pointer}.lb-close:hover{opacity:1}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);color:#fff;font-family:var(--serif);font-size:46px;padding:0 24px;opacity:.55;transition:.2s;user-select:none;background:none;border:none;cursor:pointer}
.lb-nav:hover{opacity:1}.lb-prev{left:4px}.lb-next{right:4px}
.lb-bar{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);display:flex;gap:12px}
.lb-bar button,.lb-bar a{display:inline-flex;align-items:center;gap:8px;font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:#fff;border:1px solid rgba(255,255,255,.4);padding:11px 18px;border-radius:2px;transition:.2s;text-decoration:none;background:none;cursor:pointer}
.lb-bar button:hover,.lb-bar a:hover{border-color:var(--sable);color:var(--sable)}
.lb-bar button.on{background:var(--sable);color:var(--noir);border-color:var(--sable)}

/* ATELIER */
.admin{max-width:1140px;margin:0 auto;padding:96px 30px 40px}
.admin-head{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:30px}
.admin-head h2{font-family:var(--serif);font-weight:300;font-size:40px}
.admin-head p{color:var(--brun);font-size:13px;margin-top:4px}
.login-card{max-width:380px;margin:0 auto;text-align:center;padding-top:6vh}
.login-card .logo-stack{width:240px;max-width:74%;margin:0 auto 22px;display:block}
.login-card h2{font-family:var(--serif);font-weight:300;font-size:30px}
.field{text-align:left;margin-top:16px}
.field label{display:block;font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--brun);margin-bottom:6px}
.field input{width:100%;padding:13px 14px;border:1px solid var(--pierre-f);border-radius:3px;background:#fff;font-size:14px}
.field input:focus{outline:none;border-color:var(--sable);box-shadow:0 0 0 4px rgba(194,168,107,.12)}
.gal-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}
.gcard{background:#fff;border:1px solid var(--pierre);border-radius:4px;overflow:hidden;transition:.25s}
.gcard:hover{border-color:var(--sable);box-shadow:0 18px 44px -30px rgba(22,20,15,.5)}
.gcard .cv{aspect-ratio:16/10;background:var(--pierre);overflow:hidden;position:relative;display:block}
.gcard .cv img{width:100%;height:100%;object-fit:cover}
.gcard .cv .empty{position:absolute;inset:0;display:grid;place-items:center;color:var(--brun);font-size:12px;letter-spacing:1px}
.gcard .body{padding:17px 19px}
.gcard h3{font-family:var(--serif);font-weight:400;font-size:22px}
.gcard .row{display:flex;justify-content:space-between;align-items:center;margin-top:9px;font-size:12px;color:var(--brun)}
.gcard .codepill{font-family:var(--sans);letter-spacing:2px;background:var(--ivoire);color:var(--noir);padding:3px 10px;border-radius:3px}
.gcard .flags{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}
.flag{font-size:9px;letter-spacing:1px;text-transform:uppercase;padding:3px 8px;border-radius:3px;background:var(--ivoire);color:var(--brun)}
.flag.warn{background:#f3e6df;color:#9b5b3b}
.flag.fav{background:#efe6d3;color:#8a6d2f}
.gcard .acts{display:flex;gap:8px;margin-top:12px}
.gcard .acts a,.gcard .acts button{flex:1;font-size:9px;letter-spacing:1.5px;text-transform:uppercase;padding:10px;border:1px solid var(--pierre-f);border-radius:2px;transition:.2s;text-align:center;text-decoration:none;color:var(--noir);background:none;cursor:pointer}
.gcard .acts a:hover,.gcard .acts button:hover{border-color:var(--sable);color:var(--sable-f)}
.gcard .acts .primary{background:var(--noir);color:var(--blanc);border-color:var(--noir)}
.gcard .acts .primary:hover{background:var(--sable-f);color:#fff}
.new-card{display:grid;place-items:center;border:1px dashed var(--pierre-f);background:transparent;min-height:200px;color:var(--brun);transition:.25s;text-decoration:none}
.new-card:hover{border-color:var(--sable);color:var(--sable-f)}
.new-card .plus{font-family:var(--serif);font-size:40px;line-height:1}
.new-card span{font-size:10px;letter-spacing:2px;text-transform:uppercase;margin-top:6px}

.panel{max-width:680px;margin:0 auto;background:#fff;border:1px solid var(--pierre);border-radius:6px;padding:34px}
.panel h2{font-family:var(--serif);font-weight:300;font-size:32px;margin-bottom:4px}
.panel .sub{color:var(--brun);font-size:13px;margin-bottom:18px}
.row2{display:flex;gap:12px;flex-wrap:wrap}.row2 .field{flex:1;min-width:180px}
.switch-row{display:flex;align-items:center;justify-content:space-between;margin-top:14px;padding:12px 14px;border:1px solid var(--pierre-f);border-radius:4px;background:#fff}
.switch-row .lbl{font-size:12.5px}.switch-row .lbl b{font-weight:500}.switch-row .lbl small{display:block;color:var(--brun);font-size:10.5px;margin-top:2px}
.switch{position:relative;width:46px;height:26px;border-radius:14px;background:var(--pierre-f);transition:.25s;flex:none;cursor:pointer;border:none}
.switch.on{background:var(--sable)}
.switch::after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:.25s}
.switch.on::after{transform:translateX(20px)}
.drop{margin-top:18px;border:1px dashed var(--pierre-f);border-radius:4px;padding:32px;text-align:center;color:var(--brun);transition:.25s;cursor:pointer;background:#fff}
.drop:hover,.drop.over{border-color:var(--sable);background:#fffdf8;color:var(--sable-f)}
.drop .ico{font-family:var(--serif);font-size:32px}
.drop small{display:block;margin-top:5px;font-size:11px;letter-spacing:1px}
.thumbs{display:grid;grid-template-columns:repeat(auto-fill,minmax(86px,1fr));gap:8px;margin-top:14px}
.thumbs .t{aspect-ratio:1;border-radius:3px;overflow:hidden;background:var(--pierre);position:relative;border:2px solid transparent}
.thumbs .t img{width:100%;height:100%;object-fit:cover}
.thumbs .t.cover{border-color:var(--sable)}
.thumbs .t .setcover{position:absolute;inset:auto 0 0 0;font-size:8px;letter-spacing:1px;text-transform:uppercase;background:rgba(22,20,15,.6);color:#fff;padding:3px;text-align:center;border:none;cursor:pointer;width:100%}
.thumbs .t.cover .setcover{background:var(--sable)}
.thumbs .t .del{position:absolute;top:3px;right:3px;width:20px;height:20px;border-radius:50%;background:rgba(22,20,15,.7);color:#fff;font-size:11px;display:grid;place-items:center;border:none;cursor:pointer;text-decoration:none}
.muted{font-size:11.5px;color:var(--brun);margin-top:10px;line-height:1.6}
.muted code{background:var(--ivoire);padding:2px 7px;border-radius:3px}
.notice{background:#f3ede1;border:1px solid var(--pierre-f);border-radius:4px;padding:12px 16px;font-size:12.5px;color:var(--brun);margin-bottom:18px}
.notice.warn{background:#f3e6df;color:#8a4a32;border-color:#e3c8bc}

#shield{position:fixed;inset:0;z-index:90;background:#0e0d0a;display:none;place-items:center;text-align:center;color:rgba(251,250,247,.7)}
#shield.on{display:grid}
#shield .s-inner{max-width:340px;padding:24px}
#shield .s-mono{font-family:var(--serif);font-size:46px;color:var(--sable);margin-bottom:14px}
#shield h4{font-family:var(--serif);font-weight:300;font-size:24px;color:var(--blanc);margin-bottom:8px}
#shield p{font-size:12px;letter-spacing:.4px;line-height:1.6}

/* ---------- Panneau de commande de tirages (charte studio) ---------- */
.cmd-overlay{position:fixed;inset:0;z-index:75;background:rgba(14,13,10,.55);display:none;align-items:stretch;justify-content:flex-end}
.cmd-overlay.open{display:flex}
.cmd-panel{background:var(--blanc);width:100%;max-width:540px;display:flex;flex-direction:column;box-shadow:-30px 0 80px -30px rgba(22,20,15,.6)}
@media(max-width:560px){.cmd-panel{max-width:100%}}
.cmd-head{display:flex;align-items:flex-start;justify-content:space-between;padding:24px 28px 16px;border-bottom:1px solid var(--pierre)}
.cmd-head h3{font-family:var(--serif);font-weight:300;font-size:28px;margin-top:2px}
.cmd-close{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--brun)}
.cmd-close:hover{color:var(--noir)}
.cmd-body{flex:1;overflow:auto;padding:20px 28px}
.cmd-intro{font-size:13px;color:var(--brun);line-height:1.6;margin-bottom:18px}
.cmd-filters{display:flex;gap:8px;margin-bottom:16px}
.cmd-pill{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;padding:9px 16px;border:1px solid var(--pierre-f);border-radius:2px;color:var(--brun);transition:.2s}
.cmd-pill.on{background:var(--noir);color:var(--blanc);border-color:var(--noir)}
.cmd-list{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}
.cmd-item{display:flex;gap:14px;align-items:center;padding:10px;border:1px solid var(--pierre);border-radius:4px;background:#fff}
.cmd-item img{width:62px;height:62px;object-fit:cover;border-radius:3px;flex:none;background:var(--pierre)}
.cmd-item-ctrl{flex:1;display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.cmd-fmt{flex:1;min-width:130px;font-family:var(--sans);font-size:13px;color:var(--noir);background:#fff;border:1px solid var(--pierre-f);border-radius:3px;padding:9px 10px}
.cmd-fmt:focus{outline:none;border-color:var(--sable)}
.cmd-qty{display:inline-flex;align-items:center;border:1px solid var(--pierre-f);border-radius:3px;overflow:hidden;background:#fff}
.cmd-qty button{width:30px;height:34px;font-size:16px;color:var(--noir)}
.cmd-qty button:hover{background:var(--ivoire)}
.cmd-qty span{min-width:26px;text-align:center;font-size:14px;font-weight:500}
.cmd-coords h4{font-family:var(--serif);font-weight:400;font-size:20px;margin:6px 0 12px;padding-top:18px;border-top:1px solid var(--pierre)}
.cmd-coords .field{margin-bottom:12px}
.cmd-retrait{display:flex;gap:10px;margin:6px 0 14px}
.cmd-retrait .rad{flex:1;border:1px solid var(--pierre-f);border-radius:4px;padding:11px 12px;background:#fff;cursor:pointer;font-size:13px;display:flex;gap:8px;align-items:center}
.cmd-retrait .rad.sel{border-color:var(--sable);background:#fffdf8}
.cmd-retrait .rad input{accent-color:var(--sable)}
.cmd-adresse{border:1px solid var(--pierre);border-radius:4px;padding:14px;background:#fff;margin-bottom:14px}
.cmd-err{color:#9b3b2e;font-size:13px;min-height:18px;margin-top:6px}
.cmd-foot{display:flex;align-items:center;gap:16px;padding:16px 28px;border-top:1px solid var(--pierre);background:var(--blanc)}
.cmd-total{flex:1}
.cmd-total .t-lbl{display:block;font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--brun)}
.cmd-total .t-val{font-family:var(--serif);font-size:24px}
.cmd-total .t-sub{display:block;font-size:11px;color:var(--brun)}
.cmd-foot .btn{white-space:nowrap}
.cmd-foot .btn:disabled{background:var(--pierre-f);cursor:not-allowed}
