/* ============================================================
   Le Viseur — prototype vanilla · Kim B Lucas · v6
   HUD qui s'efface pour contempler · acquérir bas-centre ·
   menu LCD (+ Instagram valorisé) · descriptions série + image (Info).
   ============================================================ */

:root {
  --noir:#050505; --surface:#171715; --surface-2:#1c1c1a; --line:#2a2a28;
  --gris:#7a7a76; --gris-2:#a6a39d; --ambre:#e8c79a; --vert:#7cc08a;
  --rouge:#e4483b; --blanc:#f5f4f1;
  --ease:cubic-bezier(0.65,0.05,0,1); --focus-dur:0.9s;
  --hud-pad:clamp(0.9rem,2.2vw,1.75rem);
  --mono:"Spline Sans Mono",ui-monospace,"SFMono-Regular",Menlo,monospace;
  --serif:"Libre Caslon Display",Georgia,"Times New Roman",serif;
  --sans:"Instrument Sans",system-ui,-apple-system,"Segoe UI",sans-serif;
}
* { box-sizing:border-box; margin:0; padding:0; }
html,body { background:var(--noir); color:var(--blanc); font-family:var(--sans); }
body { min-height:100vh; display:flex; flex-direction:column; }
img { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
[hidden] { display:none !important; }

/* ---------- Viseur ---------- */
.viewfinder { position:relative; flex:1 1 auto; min-height:80vh; overflow:hidden; background:var(--noir); }
.stage { position:absolute; inset:0; }
.stage__img { width:100%; height:100%; object-fit:cover; filter:saturate(1.02) contrast(1.02); transition:filter var(--focus-dur) var(--ease); will-change:filter; }
.viewfinder.is-focusing .stage__img { filter:blur(24px) saturate(0.25) brightness(1.12) contrast(0.96); transition:none; }
.stage__vignette { position:absolute; inset:0; pointer-events:none; transition:opacity 0.8s var(--ease);
  background:linear-gradient(to bottom,rgba(0,0,0,0.42),transparent 20% 62%,rgba(0,0,0,0.62)),
             radial-gradient(130% 100% at 50% 40%,transparent 58%,rgba(0,0,0,0.4) 100%); }

/* ---------- Chrome qui s'efface (contemplation) ---------- */
.hud,.cartel,.acquire,.ctl--cart,.ctl--fit,.dial { transition:opacity 0.7s var(--ease); }
body.idle .hud,
body.idle .cartel,
body.idle .acquire,
body.idle .ctl--cart,
body.idle .ctl--fit,
body.idle .dial { opacity:0; pointer-events:none; }
body.idle .stage__vignette { opacity:0.35; }

/* ---------- Cadre viseur ---------- */
.hud { position:absolute; inset:0; padding:var(--hud-pad); font-family:var(--mono);
  font-size:clamp(0.62rem,1.15vw,0.8rem); letter-spacing:0.08em; color:var(--gris-2);
  text-transform:uppercase; pointer-events:none; }
.dim { color:var(--gris); }
.hud__grid { position:absolute; inset:var(--hud-pad); pointer-events:none; opacity:0.4;
  background:linear-gradient(var(--line),var(--line)) 33.33% 0 / 1px 100% no-repeat,
            linear-gradient(var(--line),var(--line)) 66.66% 0 / 1px 100% no-repeat,
            linear-gradient(var(--line),var(--line)) 0 33.33% / 100% 1px no-repeat,
            linear-gradient(var(--line),var(--line)) 0 66.66% / 100% 1px no-repeat; }
.hud__corner { position:absolute; width:22px; height:22px; border:1.5px solid var(--blanc); opacity:0.8; }
.hud__corner.tl { top:var(--hud-pad); left:var(--hud-pad); border-right:0; border-bottom:0; }
.hud__corner.tr { top:var(--hud-pad); right:var(--hud-pad); border-left:0; border-bottom:0; }
.hud__corner.bl { bottom:var(--hud-pad); left:var(--hud-pad); border-right:0; border-top:0; }
.hud__corner.br { bottom:var(--hud-pad); right:var(--hud-pad); border-left:0; border-top:0; }
.hud__top { position:relative; display:flex; justify-content:space-between; align-items:center; gap:1rem; padding:0 clamp(1.3rem,3vw,2rem); }
.wordmark { font-family:var(--serif); text-transform:none; letter-spacing:0.22em; font-size:clamp(0.85rem,1.7vw,1.15rem); color:var(--blanc); opacity:0.92; }
.reticle { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); display:grid; place-items:center; color:var(--vert); }
.reticle__mark { font-size:clamp(1.4rem,3vw,2rem); line-height:1; }
.reticle__label { position:absolute; top:calc(50% + 1.4rem); font-size:0.7rem; letter-spacing:0.2em; }
.reticle[data-state="focus"] { color:var(--ambre); }
.reticle[data-state="focus"] .reticle__mark { animation:hintpulse 0.5s ease-in-out infinite; }
.af { position:absolute; border:1.5px solid currentColor; opacity:0.9; }
.af--l { left:-34px; width:2px; height:18px; border-right:0; border-top:0; border-bottom:0; }
.af--r { right:-34px; width:2px; height:18px; border-left:0; border-top:0; border-bottom:0; }
.af--t { top:-30px; height:2px; width:18px; border-bottom:0; border-left:0; border-right:0; }
.af--b { bottom:-30px; height:2px; width:18px; border-top:0; border-left:0; border-right:0; }
@keyframes hintpulse { 0%,100%{opacity:0.5;} 50%{opacity:0.95;} }

/* ---------- Cartel (bas-gauche) ---------- */
.cartel { position:absolute; left:calc(var(--hud-pad) + 1.4rem); bottom:calc(var(--hud-pad) + 1.2rem); max-width:min(52ch,56%); z-index:3; }
.cartel__story { font-family:var(--serif); font-style:italic; font-size:clamp(0.95rem,1.6vw,1.15rem); color:var(--blanc); max-width:40ch; margin-bottom:0.7rem; opacity:0; max-height:0; overflow:hidden; transform:translateY(6px); transition:opacity 0.4s var(--ease),transform 0.4s var(--ease),max-height 0.4s var(--ease); text-shadow:0 2px 20px rgba(0,0,0,0.7); }
.cartel.story .cartel__story { opacity:1; max-height:6rem; transform:none; }
.cartel__idx { font-family:var(--mono); color:var(--ambre); font-size:0.72rem; letter-spacing:0.16em; margin-bottom:0.35rem; text-transform:uppercase; }
.cartel__title { font-family:var(--serif); font-weight:400; font-size:clamp(1.8rem,5vw,3.4rem); line-height:1.02; color:var(--blanc); text-shadow:0 2px 30px rgba(0,0,0,0.6); }
.cartel__meta { display:flex; align-items:center; gap:1rem; margin-top:0.7rem; flex-wrap:wrap; }
.exif { font-family:var(--mono); display:inline-flex; flex-wrap:wrap; gap:0.7rem; color:var(--blanc); font-size:clamp(0.62rem,1.1vw,0.76rem); letter-spacing:0.08em; text-transform:uppercase; }
.info-ctl { font-family:var(--mono); font-size:0.64rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--gris-2); background:transparent; border:1px solid var(--line); border-radius:2px; padding:0.28rem 0.55rem; cursor:help; transition:color 0.3s var(--ease),border-color 0.3s var(--ease); }
.info-ctl:hover,.info-ctl:focus-visible { color:var(--ambre); border-color:rgba(232,199,154,0.6); outline:none; }

/* ---------- Acquérir (bas-centre) ---------- */
.acquire { position:absolute; left:50%; bottom:calc(var(--hud-pad) + 0.4rem); transform:translateX(-50%); z-index:3;
  display:inline-flex; align-items:center; gap:0.5rem; cursor:pointer;
  font-family:var(--mono); font-size:0.74rem; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--blanc); background:rgba(10,10,9,0.5); border:1px solid rgba(232,199,154,0.55);
  padding:0.7rem 1.3rem; border-radius:2px; backdrop-filter:blur(6px);
  transition:border-color 0.4s var(--ease),background 0.4s var(--ease),opacity 0.7s var(--ease); }
.acquire:hover { border-color:var(--ambre); background:rgba(232,199,154,0.14); }
.acquire__plus { color:var(--ambre); font-size:0.95rem; line-height:0; }
.viewfinder__hit { position:absolute; inset:0; background:transparent; border:0; cursor:grab; z-index:1; touch-action:none; }
.viewfinder.panning .viewfinder__hit { cursor:grabbing; }
.viewfinder.fitmode .viewfinder__hit { cursor:pointer; }
/* Vue « image entière » : on voit toute la photo, bandes noires (letterbox) */
.viewfinder.fitmode .stage__img { object-fit:contain; }
.viewfinder.fitmode .stage__vignette { opacity:0.25; }

/* ---------- Panier (déclencheur) ---------- */
.ctl { position:absolute; z-index:4; font-family:var(--mono); font-size:0.72rem; letter-spacing:0.12em;
  text-transform:uppercase; color:var(--gris-2); background:transparent; border:0; cursor:pointer;
  padding:0.3rem; display:inline-flex; align-items:center; gap:0.4rem; opacity:0.85; transition:color 0.3s var(--ease),opacity 0.7s var(--ease); }
.ctl:hover,.ctl:focus-visible { color:var(--blanc); opacity:1; outline:none; }
.ctl--cart { right:var(--hud-pad); top:calc(var(--hud-pad) + 2.4rem); }
.ctl--cart.has-items { color:var(--ambre); opacity:1; }
.ctl--fit { right:var(--hud-pad); top:calc(var(--hud-pad) + 4.6rem); }
.ctl--fit[aria-pressed="true"] { color:var(--ambre); opacity:1; }
.ctl__ic { font-size:0.95rem; }

/* ---------- Molette ---------- */
.dial { position:absolute; z-index:5; right:var(--hud-pad); bottom:var(--hud-pad);
  width:96px; height:96px; border-radius:50%; border:0; cursor:pointer; background:rgba(8,8,7,0.42);
  backdrop-filter:blur(8px); display:grid; place-items:center; color:var(--blanc); box-shadow:0 8px 30px rgba(0,0,0,0.5); }
.dial__ring { position:absolute; inset:0; border-radius:50%; border:1.5px solid var(--gris-2); opacity:0.95; }
.dial__ticks { position:absolute; inset:4px; border-radius:50%; opacity:0.75; transition:transform 0.6s var(--ease);
  background:repeating-conic-gradient(from 0deg,var(--gris-2) 0 1.4deg,transparent 1.4deg 12deg);
  -webkit-mask:radial-gradient(circle,transparent 60%,#000 62%,#000 74%,transparent 76%);
          mask:radial-gradient(circle,transparent 60%,#000 62%,#000 74%,transparent 76%); }
.dial__pointer { position:absolute; top:4px; left:50%; transform:translateX(-50%); width:0; height:0; border-left:5px solid transparent; border-right:5px solid transparent; border-bottom:8px solid var(--ambre); }
.dial__label { font-family:var(--mono); font-size:0.66rem; letter-spacing:0.16em; text-transform:uppercase; color:var(--blanc); }
.dial:hover,.dial:focus-visible { outline:none; transform:scale(1.05); }
.dial:hover .dial__ring,.dial:focus-visible .dial__ring { border-color:var(--ambre); }
.dial:hover .dial__ticks,.dial:focus-visible .dial__ticks { transform:rotate(20deg); }
.dial.call { animation:dialcall 2.4s var(--ease) 3; }
@keyframes dialcall { 0%,100%{box-shadow:0 8px 30px rgba(0,0,0,0.5);} 50%{box-shadow:0 0 0 6px rgba(232,199,154,0.16),0 8px 30px rgba(0,0,0,0.5);} }

/* ---------- Navigation des séries (en bas) ---------- */
.seriesbar { flex:0 0 auto; display:flex; gap:8px; padding:8px clamp(8px,2vw,14px); background:#0a0a09; border-top:1px solid var(--line); overflow-x:auto; scrollbar-width:thin; }
.seriechip { display:flex; align-items:center; gap:0.6rem; flex:0 0 auto; padding:0.35rem 0.85rem 0.35rem 0.35rem; background:transparent; border:1px solid var(--line); border-radius:4px; cursor:pointer; transition:border-color 0.3s var(--ease),background 0.3s var(--ease); }
.seriechip img { width:40px; height:40px; object-fit:cover; border-radius:2px; flex:0 0 auto; }
.seriechip__name { font-family:var(--serif); font-size:1.05rem; color:var(--gris-2); white-space:nowrap; transition:color 0.3s var(--ease); }
.seriechip__n { font-family:var(--mono); font-size:0.58rem; letter-spacing:0.08em; text-transform:uppercase; color:var(--gris); display:block; }
.seriechip:hover { border-color:var(--gris); }
.seriechip:hover .seriechip__name { color:var(--blanc); }
.seriechip[aria-current="true"] { border-color:var(--ambre); background:rgba(232,199,154,0.08); }
.seriechip[aria-current="true"] .seriechip__name { color:var(--ambre); }
.seriechip:focus-visible { outline:2px solid var(--ambre); outline-offset:2px; }

/* ---------- Pellicule ---------- */
.filmstrip { flex:0 0 auto; display:flex; gap:6px; padding:6px; background:var(--noir); overflow-x:auto; }
.frame { position:relative; flex:0 0 auto; width:clamp(88px,12vw,150px); aspect-ratio:3/2; border:0; padding:0; cursor:pointer; background:none; opacity:0.5; transition:opacity 0.4s var(--ease); }
.frame img { width:100%; height:100%; object-fit:cover; }
.frame::after { content:""; position:absolute; inset:0; border:1px solid transparent; }
.frame[aria-current="true"] { opacity:1; }
.frame[aria-current="true"]::after { border-color:var(--ambre); }
.frame:hover { opacity:0.85; }
.frame:focus-visible { outline:2px solid var(--ambre); outline-offset:2px; }

/* ---------- Overlays ---------- */
.scrim { position:fixed; inset:0; background:rgba(3,3,3,0.72); backdrop-filter:blur(4px); z-index:20; animation:fade 0.4s var(--ease); }
.ov { position:fixed; z-index:21; color:var(--blanc); animation:fade 0.45s var(--ease); }
@keyframes fade { from{opacity:0;} to{opacity:1;} }
.ov__close { position:absolute; top:clamp(1rem,3vw,2rem); right:clamp(1rem,3vw,2rem); background:transparent; border:0; color:var(--gris-2); font-family:var(--mono); font-size:0.72rem; letter-spacing:0.12em; text-transform:uppercase; cursor:pointer; z-index:2; }
.ov__close:hover { color:var(--blanc); }

/* Menu LCD (agrandi) */
.ov--lcd { right:var(--hud-pad); bottom:calc(var(--hud-pad) + 122px); z-index:22; }
.lcd { position:relative; width:min(540px,93vw); background:radial-gradient(120% 120% at 50% 0%,#0c0f0c,#070907);
  border:9px solid #17170f; border-radius:16px; padding:1.1rem 1.4rem 1.3rem;
  box-shadow:0 24px 70px rgba(0,0,0,0.65), inset 0 0 30px rgba(0,0,0,0.5); overflow:hidden; animation:lcdrise 0.35s var(--ease); }
@keyframes lcdrise { from{opacity:0; transform:translateY(14px) scale(0.98);} to{opacity:1; transform:none;} }
.lcd::after { content:""; position:absolute; inset:0; pointer-events:none; opacity:0.5; background:repeating-linear-gradient(to bottom,rgba(255,255,255,0.025) 0 1px,transparent 1px 3px); }
.lcd__bar { display:flex; justify-content:space-between; align-items:center; padding-bottom:0.6rem; margin-bottom:0.4rem; border-bottom:1px solid rgba(232,199,154,0.18); }
.lcd__title { font-family:var(--mono); font-size:0.68rem; letter-spacing:0.16em; text-transform:uppercase; color:var(--ambre); }
.lcd__nav { display:flex; flex-direction:column; }
.lcd__row { display:flex; align-items:center; gap:0.9rem; padding:0.82rem 0.4rem; border-bottom:1px solid rgba(255,255,255,0.05); transition:background 0.25s var(--ease); }
.lcd__row:hover,.lcd__row:focus-visible { background:rgba(232,199,154,0.1); outline:none; }
.lcd__no { font-family:var(--mono); font-size:0.68rem; color:var(--ambre); letter-spacing:0.08em; }
.lcd__lbl { font-family:var(--serif); font-size:1.65rem; color:var(--blanc); flex:1 1 auto; }
.lcd__ar { font-family:var(--mono); color:var(--ambre); opacity:0; transform:translateX(-4px); transition:opacity 0.25s var(--ease),transform 0.25s var(--ease); }
.lcd__row:hover .lcd__ar,.lcd__row:focus-visible .lcd__ar { opacity:1; transform:none; }
/* Instagram valorisé */
.lcd__ig { display:flex; align-items:center; gap:0.7rem; margin-top:0.8rem; padding:0.7rem 0.8rem; border:1px solid rgba(232,199,154,0.35); border-radius:4px; color:var(--blanc); transition:background 0.3s var(--ease),border-color 0.3s var(--ease); }
.lcd__ig:hover { background:rgba(232,199,154,0.12); border-color:var(--ambre); }
.lcd__ig svg { color:var(--ambre); flex:0 0 auto; }
.lcd__ig-h { font-family:var(--serif); font-size:1.05rem; flex:1 1 auto; }
.lcd__ig-n { font-family:var(--mono); font-size:0.62rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--ambre); }
.lcd__foot { display:flex; gap:1rem; padding-top:0.7rem; margin-top:0.7rem; border-top:1px solid rgba(255,255,255,0.06); font-family:var(--mono); font-size:0.64rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--gris); }
.lcd__foot a { cursor:pointer; }
.lcd__foot a:hover { color:var(--gris-2); }
.lcd__close { top:0.6rem; right:0.7rem; font-size:1rem; }
.lcd__back { display:inline-flex; align-items:center; gap:0.4rem; background:transparent; border:0; color:var(--gris-2); font-family:var(--mono); font-size:0.66rem; letter-spacing:0.12em; text-transform:uppercase; cursor:pointer; padding:0.2rem 0 0.6rem; }
.lcd__back:hover,.lcd__back:focus-visible { color:var(--ambre); outline:none; }
.lcd__row--sm { padding:0.62rem 0.4rem; }
.lcd__row--sm .lcd__lbl { font-size:1.15rem; }

/* Séries (grille) */
.ov--menu { inset:0; background:linear-gradient(160deg,#0b0b0a,#050505); display:flex; flex-direction:column; justify-content:center; padding:clamp(1.5rem,6vw,5rem); }
.ov__wordmark { position:absolute; top:clamp(1.2rem,3vw,2rem); left:clamp(1.2rem,4vw,3rem); font-family:var(--serif); letter-spacing:0.2em; color:var(--blanc); opacity:0.9; }
.series { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:1rem; max-width:940px; }
.serie { position:relative; border:0; padding:0; cursor:pointer; background:none; text-align:left; overflow:hidden; border-radius:3px; display:block; }
.serie__img { position:relative; aspect-ratio:4/3; overflow:hidden; }
.serie__img img { width:100%; height:100%; object-fit:cover; transition:transform 0.5s var(--ease),filter 0.4s var(--ease); filter:brightness(0.72); }
.serie:hover .serie__img img { transform:scale(1.04); filter:brightness(0.9); }
.serie__cap { position:absolute; left:0; right:0; bottom:0; padding:1rem; background:linear-gradient(transparent,rgba(0,0,0,0.8)); }
.serie__name { font-family:var(--serif); font-size:1.6rem; }
.serie__n { font-family:var(--mono); font-size:0.64rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--ambre); }
.serie__desc { color:var(--gris-2); font-size:0.86rem; line-height:1.45; margin-top:0.5rem; }
.serie[aria-current="true"] .serie__img { outline:2px solid var(--ambre); outline-offset:-2px; }

/* Documents */
.ov--doc { top:0; right:0; height:100%; width:min(560px,100%); background:linear-gradient(180deg,#0c0c0b,#080807); padding:clamp(2rem,5vw,3.5rem); overflow-y:auto; box-shadow:-30px 0 60px rgba(0,0,0,0.5); }
.doc { max-width:46ch; }
.doc__kicker { font-family:var(--mono); font-size:0.7rem; letter-spacing:0.18em; text-transform:uppercase; color:var(--ambre); margin-bottom:0.8rem; }
.doc__title { font-family:var(--serif); font-weight:400; font-size:clamp(2rem,5vw,3rem); line-height:1.05; margin-bottom:1rem; }
.doc__lede { color:var(--gris-2); font-size:1.05rem; margin-bottom:1.5rem; }
.doc p { color:#d8d6d1; line-height:1.65; margin-bottom:1rem; }
.doc__sign { font-family:var(--serif); font-style:italic; color:var(--blanc); }
.doc__note { color:var(--gris); font-size:0.9rem; }
.doc__link { color:var(--ambre); border-bottom:1px solid rgba(232,199,154,0.4); }
.doc__list { list-style:none; margin:0 0 1.2rem; }
.doc__list li { color:#d8d6d1; padding:0.55rem 0; border-bottom:1px solid var(--line); }
/* Index légal */
.legalnav { display:flex; flex-direction:column; margin:0.5rem 0 1.2rem; }
.legalnav__row { display:flex; justify-content:space-between; align-items:center; gap:1rem; width:100%; text-align:left; background:transparent; border:0; border-bottom:1px solid var(--line); color:#d8d6d1; font-family:var(--sans); font-size:1.02rem; padding:0.85rem 0.2rem; cursor:pointer; transition:color 0.25s var(--ease),padding 0.25s var(--ease); }
.legalnav__row span { font-family:var(--mono); color:var(--ambre); opacity:0; transition:opacity 0.25s var(--ease); }
.legalnav__row:hover,.legalnav__row:focus-visible { color:var(--blanc); padding-left:0.5rem; outline:none; }
.legalnav__row:hover span,.legalnav__row:focus-visible span { opacity:1; }
/* Lecteur légal */
#legalBody h3 { font-family:var(--serif); font-weight:400; font-size:1.15rem; color:var(--blanc); margin:1.4rem 0 0.5rem; }
#legalBody p { color:#cfcdc8; line-height:1.6; margin-bottom:0.8rem; font-size:0.95rem; }
#legalBody .maj { font-family:var(--mono); font-size:0.7rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--gris); }

/* Formulaire */
.form { display:flex; flex-direction:column; gap:1rem; margin-top:1.2rem; }
.field { display:flex; flex-direction:column; gap:0.35rem; }
.field span { font-family:var(--mono); font-size:0.66rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--gris-2); }
.field input,.field textarea { background:var(--surface); border:1px solid var(--line); color:var(--blanc); font-family:var(--sans); font-size:0.95rem; padding:0.7rem 0.8rem; border-radius:2px; resize:vertical; }
.field input:focus,.field textarea:focus { outline:none; border-color:var(--ambre); }
.form__ok { color:var(--vert); font-size:0.95rem; }

/* Boutons */
.btn-primary { width:100%; padding:0.9rem; background:var(--ambre); color:#1a1508; border:0; border-radius:2px; font-family:var(--mono); text-transform:uppercase; letter-spacing:0.12em; font-size:0.75rem; cursor:pointer; transition:filter 0.3s var(--ease); }
.btn-primary:hover { filter:brightness(1.08); }
.btn-primary:disabled { background:var(--surface); color:var(--gris); cursor:not-allowed; }
.btn-ghost { padding:0.9rem 1.4rem; background:transparent; color:var(--blanc); border:1px solid var(--line); border-radius:2px; font-family:var(--mono); text-transform:uppercase; letter-spacing:0.12em; font-size:0.75rem; cursor:pointer; }
.btn-ghost:hover { border-color:var(--gris-2); }

/* Configurateur */
.ov--acquire { inset:0; display:grid; place-items:center; padding:clamp(1rem,4vw,3rem); }
.config { width:min(780px,100%); max-height:90vh; overflow-y:auto; background:linear-gradient(180deg,#111110,#0a0a09); border:1px solid var(--line); border-radius:4px; display:grid; grid-template-columns:0.85fr 1fr; }
.config__preview { position:relative; }
.config__preview img { width:100%; height:100%; object-fit:cover; min-height:220px; }
.config__preview figcaption { position:absolute; left:0; right:0; bottom:0; padding:0.8rem 1rem; font-family:var(--serif); font-size:1.1rem; background:linear-gradient(transparent,rgba(0,0,0,0.7)); }
.config__form { padding:clamp(1.4rem,3vw,2.2rem); display:flex; flex-direction:column; gap:1.4rem; }
.opt { border:0; }
.opt legend { font-family:var(--mono); font-size:0.66rem; letter-spacing:0.16em; text-transform:uppercase; color:var(--gris-2); margin-bottom:0.7rem; }
.opt__row { display:flex; flex-wrap:wrap; gap:0.5rem; }
.chip { font-family:var(--mono); font-size:0.72rem; letter-spacing:0.04em; color:var(--gris-2); background:transparent; border:1px solid var(--line); border-radius:2px; padding:0.5rem 0.7rem; cursor:pointer; transition:border-color 0.3s var(--ease),color 0.3s var(--ease),background 0.3s var(--ease); }
.chip:hover { color:var(--blanc); border-color:var(--gris); }
.chip[aria-pressed="true"] { color:var(--noir); background:var(--ambre); border-color:var(--ambre); }
.chip small { opacity:0.7; }
.config__foot { margin-top:auto; }
.config__price { font-family:var(--mono); text-transform:uppercase; letter-spacing:0.1em; display:flex; justify-content:space-between; margin-bottom:1rem; font-size:1rem; color:var(--blanc); }

/* Panier */
.ov--cart { inset:0; background:linear-gradient(160deg,#0b0b0a,#050505); overflow-y:auto; padding:clamp(1.5rem,5vw,4rem); }
.cartpage { max-width:760px; margin:0 auto; }
.cartpage__title { font-family:var(--serif); font-weight:400; font-size:clamp(2.2rem,6vw,3.6rem); margin-bottom:2rem; }
.cartpage__list { list-style:none; }
.cartpage__item { display:flex; gap:1.2rem; align-items:center; padding:1.1rem 0; border-top:1px solid var(--line); }
.cartpage__item img { width:96px; height:68px; object-fit:cover; flex:0 0 auto; }
.cartpage__meta { flex:1 1 auto; }
.cartpage__meta .t { font-family:var(--serif); font-size:1.3rem; }
.cartpage__meta .o { font-family:var(--mono); font-size:0.72rem; letter-spacing:0.06em; color:var(--gris-2); text-transform:uppercase; margin-top:0.3rem; }
.cartpage__price { font-family:var(--mono); color:var(--blanc); white-space:nowrap; }
.cartpage__rm { background:0; border:0; color:var(--gris); cursor:pointer; font-family:var(--mono); font-size:1.1rem; padding:0.3rem; }
.cartpage__rm:hover { color:var(--rouge); }
.cartpage__empty { color:var(--gris); font-size:1rem; }
.cartpage__foot { margin-top:2rem; border-top:1px solid var(--line); padding-top:1.5rem; max-width:340px; margin-left:auto; }
.cartpage__total { display:flex; justify-content:space-between; font-family:var(--mono); text-transform:uppercase; letter-spacing:0.1em; color:var(--blanc); margin-bottom:1rem; font-size:1.05rem; }

/* Cookies */
.cookiebar { position:fixed; left:0; right:0; bottom:0; z-index:30; display:flex; flex-wrap:wrap; gap:0.5rem 1.4rem; align-items:center; justify-content:space-between;
  padding:0.6rem clamp(1rem,4vw,2.4rem); background:rgba(9,9,8,0.9); backdrop-filter:blur(10px); border-top:1px solid var(--line); animation:slideup 0.45s var(--ease); }
@keyframes slideup { from{transform:translateY(100%);} to{transform:translateY(0);} }
.cookiebar__txt { font-size:0.8rem; color:var(--gris-2); line-height:1.4; }
.cookiebar__txt strong { font-family:var(--sans); font-weight:600; font-size:0.82rem; color:var(--blanc); margin-right:0.5rem; }
.cookiebar__txt p { display:inline; }
.cookiebar__txt a { color:var(--ambre); border-bottom:1px solid rgba(232,199,154,0.4); cursor:pointer; }
.cookiebar__act { display:flex; gap:0.6rem; flex:0 0 auto; }
.cookiebar__act .btn-primary,.cookiebar__act .btn-ghost { width:auto; padding:0.5rem 1.1rem; }

.ov--cookies { inset:0; display:grid; place-items:center; padding:clamp(1rem,4vw,3rem); }
.cookies { position:relative; width:min(620px,100%); max-height:90vh; overflow-y:auto; background:linear-gradient(180deg,#111110,#0a0a09); border:1px solid var(--line); border-radius:6px; padding:clamp(1.6rem,4vw,2.6rem); }
.cookies .doc__title { font-size:clamp(1.6rem,4vw,2.2rem); }
.ck { border:1px solid var(--line); border-radius:4px; padding:1rem 1.2rem; margin-top:1rem; }
.ck__head { display:flex; align-items:center; justify-content:space-between; gap:1rem; }
.ck__name { font-weight:600; }
.ck__desc { color:var(--gris-2); font-size:0.88rem; margin-top:0.4rem; }
.cookies__foot { display:flex; gap:0.7rem; justify-content:flex-end; margin-top:1.5rem; }
.cookies__foot .btn-primary,.cookies__foot .btn-ghost { width:auto; }
.switch { position:relative; display:inline-block; width:46px; height:24px; flex:0 0 auto; }
.switch input { opacity:0; width:0; height:0; }
.slider { position:absolute; inset:0; background:var(--surface); border:1px solid var(--line); border-radius:24px; cursor:pointer; transition:background 0.3s var(--ease); }
.slider::before { content:""; position:absolute; left:2px; top:2px; width:18px; height:18px; background:var(--gris-2); border-radius:50%; transition:transform 0.3s var(--ease),background 0.3s var(--ease); }
.switch input:checked + .slider { background:var(--ambre); border-color:var(--ambre); }
.switch input:checked + .slider::before { transform:translateX(22px); background:#1a1508; }
.switch input:disabled + .slider { opacity:0.6; cursor:not-allowed; }

/* ---------- Mouvement réduit ---------- */
@media (prefers-reduced-motion: reduce) {
  .stage__img,.frame,.dial,.dial__ticks,.serie__img img { transition:none; }
  .viewfinder.is-focusing .stage__img { filter:saturate(1) brightness(1); }
  .reticle[data-state="focus"] .reticle__mark,.scrim,.ov,.dial.call,.cookiebar { animation:none; }
  body.idle .hud,body.idle .cartel,body.idle .acquire,body.idle .ctl--cart,body.idle .dial { opacity:1; }  /* pas d'auto-effacement */
}

/* ---------- Mobile ---------- */
@media (max-width: 680px) {
  .hud__topC { display:none; }
  .reticle .af { display:none; }
  .hud__top { padding:0 1.4rem; }
  .cartel { left:calc(var(--hud-pad) + 1rem); bottom:calc(var(--hud-pad) + 5rem); max-width:calc(100% - 2*var(--hud-pad) - 2rem); }
  .acquire { bottom:calc(var(--hud-pad) + 0.6rem); }
  .dial { width:78px; height:78px; }
  .ov--lcd { left:var(--hud-pad); right:var(--hud-pad); bottom:calc(var(--hud-pad) + 96px); }
  .lcd { width:auto; }
  .config { grid-template-columns:1fr; }
  .config__preview img { max-height:200px; }
  .seriechip img { width:34px; height:34px; }
  .seriechip__name { font-size:0.95rem; }
}

/* Écrans courts (mobile paysage) : éviter l'entassement */
@media (max-height: 560px) {
  .viewfinder { min-height:66vh; }
  .cartel__title { font-size:clamp(1.4rem,4vw,2rem); }
  .seriesbar { padding-top:5px; padding-bottom:5px; }
  .seriechip img { width:30px; height:30px; }
}
