/* ===========================================================
   VENTURE : CLASSIC SAGA — gallery page (Toutes les cartes)
   relies on venture.css for tokens, fonts, bg, buttons, brand
   =========================================================== */

.gal-header{position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  gap:1.5rem;padding:1rem var(--gut);
  background:rgba(8,6,4,.82);backdrop-filter:blur(12px) saturate(1.2);
  border-bottom:1px solid var(--gold-line-soft)}
.gal-header .brand__mark{width:150px}
.gal-back{font-family:var(--display);font-size:.76rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--cream);display:inline-flex;align-items:center;gap:.6em;
  transition:color .25s}
.gal-back:hover{color:var(--gold-bright)}
.gal-back .arr{transition:transform .25s}
.gal-back:hover .arr{transform:translateX(-4px)}

.gal-hero{text-align:center;padding:clamp(120px,18vh,200px) var(--gut) clamp(30px,5vh,56px)}
.gal-hero .overline{padding-left:0}
.gal-hero h1{font-family:var(--display);font-weight:700;
  font-size:clamp(2.4rem,6vw,4.2rem);letter-spacing:.02em;margin:0;color:var(--cream)}
.gal-hero p{color:var(--cream-dim);font-size:1.12rem;margin:1.2rem auto 0;max-width:540px;text-wrap:pretty}

/* name search */
.gal-search{position:relative;display:flex;align-items:center;
  max-width:480px;margin:2.4rem auto 0}
.gal-search__ico{position:absolute;left:1.1rem;width:18px;height:18px;
  fill:none;stroke:var(--cream-faint);stroke-width:2;stroke-linecap:round;pointer-events:none}
.gal-search input{width:100%;font-family:var(--body);font-size:1rem;color:var(--cream);
  background:rgba(20,16,10,.55);border:1px solid var(--gold-line-soft);border-radius:3px;
  padding:.95em 3.2em .95em 3rem;transition:border-color .25s,box-shadow .25s;-webkit-appearance:none;appearance:none}
.gal-search input::placeholder{color:var(--cream-faint)}
.gal-search input:focus{outline:none;border-color:var(--gold);
  box-shadow:0 0 0 1px var(--gold-line),0 0 26px -10px rgba(200,164,92,.5)}
.gal-search input::-webkit-search-cancel-button{display:none}
#galClear{position:absolute;right:5.2rem;width:26px;height:26px;display:none;place-items:center;
  border:none;background:transparent;color:var(--cream-faint);font-size:1.4rem;line-height:1;
  cursor:pointer;border-radius:50%;transition:color .2s}
#galClear:hover{color:var(--gold-bright)}
.gal-count{position:absolute;right:1.1rem;font-family:var(--display);font-size:.72rem;
  letter-spacing:.1em;color:var(--cream-faint);pointer-events:none;white-space:nowrap}
.gal-empty{display:none;text-align:center;color:var(--cream-faint);font-style:italic;
  font-size:1.05rem;padding:clamp(40px,10vh,90px) var(--gut)}

/* grid */
.gal-grid{max-width:1450px;margin:clamp(40px,6vh,72px) auto 0;padding:0 var(--gut) clamp(80px,12vh,140px);
  display: grid;gap: clamp(26px, 3vw, 48px);grid-template-columns: repeat(2, 1fr);}
.gcard{cursor:pointer;text-align:center;perspective:1200px;
  opacity:0;transform:translateY(28px);transition:opacity .7s,transform .7s}
.gcard.in{opacity:1;transform:none}
.gcard__frame{position:relative;border-radius:13px;overflow:hidden;
  box-shadow:var(--shadow-deep);transition:transform .4s cubic-bezier(.2,.7,.3,1),box-shadow .4s;
  transform-style:preserve-3d}
.gcard__frame img{width:100%;display:block;aspect-ratio: 775 / 1081;object-fit:cover;background:#0c0a07}
.gcard.noart .gcard__frame img{object-fit:contain;padding:14% 14% 26%}
.gcard__num{position:absolute;top:9px;left:11px;z-index:2;font-family:var(--display);
  font-size:.62rem;letter-spacing:.14em;color:var(--cream);opacity:.62;
  text-shadow:0 1px 4px rgba(0,0,0,.9)}
.gcard__frame::after{content:"";position:absolute;inset:0;border-radius:13px;
  box-shadow:inset 0 0 0 1px rgba(200,164,92,.18);pointer-events:none}
.gcard:hover .gcard__frame{transform:translateY(-6px) scale(1.03);
  box-shadow:0 44px 90px -40px rgba(0,0,0,.95),0 0 34px -16px var(--accent,rgba(200,164,92,.45))}
/* "art à venir" placeholder ribbon */
.gcard__soon{position:absolute;inset:0;display:flex;align-items:flex-end;justify-content:center;
  padding-bottom:18%;background:linear-gradient(180deg,transparent 55%,rgba(6,5,3,.55));pointer-events:none}
.gcard__soon span{font-family:var(--display);font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--gold-bright);border:1px solid var(--gold-line);padding:.45em .9em;border-radius:2px;
  background:rgba(10,8,5,.6)}
.gcard__meta{margin-top:.85rem;display:flex;align-items:center;justify-content:flex-start;gap:.6em}
.gcard__name{font-family:var(--display);font-weight:600;font-size:.7rem;;color:var(--cream);
  letter-spacing:.01em;line-height:1.2;text-align:left}
.gcard__cost{flex:0 0 auto;min-width:1.95em;height:1.95em;padding:0 .35em;display:grid;place-items:center;
  border-radius:50%;border:1px solid var(--gold-line);background:rgba(20,16,10,.6);
  font-family:var(--display);font-weight:700;font-size:.82rem;color:var(--gold-bright)}

/* ===================== card detail overlay ===================== */
.cv{position:fixed;inset:0;z-index:300;display:flex;opacity:0;pointer-events:none;
  transition:opacity .4s}
.cv.open{opacity:1;pointer-events:auto}
.cv__backdrop{position:absolute;inset:0;background:rgba(5,4,3,.88);backdrop-filter:blur(12px)}
.cv__stage{position:relative;margin:auto;display:flex;align-items:center;
  gap:clamp(28px,5vw,80px);max-width:1160px;width:100%;
  padding:clamp(80px,10vh,110px) clamp(24px,6vw,64px) clamp(40px,6vh,64px)}
.cv__cardwrap{flex:0 0 auto;width:min(40vw,400px);position:relative}
.cv__card{width:100%;border-radius:16px;display:block;
  box-shadow:0 60px 120px -40px rgba(0,0,0,.95),0 0 60px -20px var(--accent,rgba(200,164,92,.4));
  will-change:transform}
.cv__info{flex:1 1 0;min-width:0;max-width:560px;max-height:calc(100vh - 160px);overflow-y:auto;
  opacity:0;transform:translateX(24px);
  transition:opacity .5s .12s,transform .5s .12s}
.cv.open .cv__info{opacity:1;transform:none}

.cv__topline{display:flex;align-items:center;gap:1em;margin-bottom:1rem}
.cv__type{font-family:var(--display);font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--accent,var(--gold));display:inline-flex;align-items:center;gap:.6em}
.cv__type::before{content:"";width:22px;height:1px;background:currentColor;opacity:.6}
.cv__rarity{margin-left:auto;font-family:var(--display);font-size:.68rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--cream-dim);border:1px solid var(--gold-line-soft);
  padding:.35em .8em;border-radius:2px}
.cv__head{display:flex;align-items:flex-start;gap:1.2rem;margin:0 0 1.5rem}
.cv__name{flex:1 1 auto;font-family:var(--display);font-weight:700;font-size:clamp(1.6rem,3vw,2.5rem);
  line-height:1.1;color:var(--cream);margin:0;text-wrap:balance}
.cv__cost{flex:0 0 auto;text-align:center;min-width:3.4rem;
  background:rgba(20,16,10,.55);border:1px solid var(--gold-line);border-radius:6px;
  padding:.5rem .55rem .45rem}
.cv__cost b{display:block;font-family:var(--display);font-weight:700;font-size:1.9rem;
  line-height:1;color:var(--gold-bright)}
.cv__cost span{display:block;font-family:var(--display);font-size:.56rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--cream-faint);margin-top:.45rem}
.cv__stats{display:flex;gap:.7rem;flex-wrap:wrap;margin-bottom:1.5rem}
.stat--wide{flex:1 1 100%}
.stat{flex:1 1 0;min-width:74px;background:rgba(20,16,10,.5);border:1px solid var(--gold-line-soft);
  border-radius:4px;padding:.7rem .6rem;text-align:center}
.stat b{display:block;font-family:var(--display);font-size:1.5rem;font-weight:600;color:var(--gold-bright);line-height:1;overflow-wrap:break-word}
.stat--wide b{font-size:1.15rem}
.stat span{display:block;font-family:var(--display);font-size:.6rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--cream-faint);margin-top:.5rem}
.cv__kw{display:flex;align-items:baseline;flex-wrap:wrap;gap:.3rem .8em;
  margin:0 0 1.4rem;padding:.7rem .9rem;border-radius:4px;
  background:rgba(20,16,10,.5);border:1px solid var(--gold-line-soft)}
.cv__kw b{flex:0 0 auto;font-family:var(--display);letter-spacing:.2em;text-transform:uppercase;
  font-size:.6rem;color:var(--cream-faint)}
.cv__kw span{flex:1 1 auto;min-width:0;font-family:var(--display);font-weight:600;
  letter-spacing:.04em;font-size:1.05rem;color:var(--accent,var(--gold-bright));
  filter:brightness(1.4);overflow-wrap:break-word}
.cv__sectionlabel{font-family:var(--display);font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--gold);margin:0 0 .6rem}
.cv__effect{color:var(--cream);font-size:1.02rem;line-height:1.65;margin:0 0 1.5rem;
  padding-left:1rem;border-left:2px solid var(--gold-line)}
.cv__lore{color:var(--cream-faint);font-style:italic;font-size:1rem;line-height:1.6;margin:0 0 1.6rem}
.cv__foot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem;
  padding-top:1.3rem;border-top:1px solid var(--gold-line-soft);
  font-size:.82rem;color:var(--cream-faint);letter-spacing:.04em}
.cv__foot b{color:var(--cream-dim);font-weight:500}
.cv__close{position:absolute;top:24px;right:28px;z-index:2;width:46px;height:46px;border-radius:50%;
  display:grid;place-items:center;
  background:rgba(20,16,10,.6);border:1px solid var(--gold-line-soft);color:var(--cream);
  font-size:1.5rem;line-height:1;cursor:pointer;transition:border-color .25s,color .25s,background .25s}
.cv__close:hover{border-color:var(--gold);color:var(--gold-bright);background:rgba(28,22,12,.8)}

@media(max-width:820px){
  .cv__stage{flex-direction:column;align-items:center;overflow-y:auto;margin:0;
    padding-top:84px;height:100%}
  .cv__cardwrap{width:min(62vw,280px)}
  .cv__info{max-width:560px;width:100%;max-height:none;overflow:visible}
}

@media (min-width: 768px) {
  .gal-grid {grid-template-columns: repeat(3, 1fr);}
}
@media (min-width: 1024px) {
  .gal-grid {grid-template-columns: repeat(5, 1fr);}
  .gcard__name {font-size: .92rem;}
}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001s!important}
  .cv__card{transition:none!important}
}
