/* ============================================================
   GALERIE 55 — BIRON
   Maquette e-commerce · antiquités d'Asie & artistes
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --ivory:#f4efe5;
  --ivory-deep:#ece5d6;
  --paper:#fbf8f1;
  --ink:#211d18;
  --ink-soft:#6f6557;
  --ink-faint:#9a8f7e;
  --lacquer:#d74a3b;
  --lacquer-deep:#bb3a2d;
  --gold:#b3873f;
  --line:rgba(33,29,24,.16);
  --line-soft:rgba(33,29,24,.09);

  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Jost","Helvetica Neue",Arial,sans-serif;

  --header-h:84px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --maxw:1320px;
  --gut:clamp(20px,5vw,72px);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  font-weight:300;
  background:var(--ivory);
  color:var(--ink);
  line-height:1.65;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body.no-scroll{overflow:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
ul{list-style:none}

::selection{background:var(--lacquer);color:#fff}

/* ---------- Typography helpers ---------- */
.eyebrow{
  font-size:.69rem;letter-spacing:.34em;text-transform:uppercase;
  font-weight:400;color:var(--lacquer);
}
.eyebrow--mute{color:var(--ink-faint)}
.serif{font-family:var(--serif)}

h1,h2,h3{font-family:var(--serif);font-weight:400;line-height:1.12;letter-spacing:.005em}

.section-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:2rem;flex-wrap:wrap;margin-bottom:clamp(2rem,5vw,3.6rem);
}
.section-head__title{
  font-size:clamp(2rem,4.4vw,3.3rem);font-weight:300;
}
.section-head .eyebrow{display:block;margin-bottom:1rem}
.section-link{
  font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink);padding-bottom:.4rem;border-bottom:1px solid var(--ink);
  transition:color .3s,border-color .3s;white-space:nowrap;
}
.section-link:hover{color:var(--lacquer);border-color:var(--lacquer)}

.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut)}
section{position:relative}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--sans);font-size:.76rem;font-weight:400;
  letter-spacing:.2em;text-transform:uppercase;
  padding:1.15em 2.4em;border:1px solid transparent;
  transition:background .35s var(--ease),color .35s var(--ease),border-color .35s;
  cursor:pointer;
}
.btn--solid{background:var(--lacquer);color:#fbf8f1}
.btn--solid:hover{background:var(--lacquer-deep)}
.btn--line{border-color:var(--ink);color:var(--ink)}
.btn--line:hover{background:var(--ink);color:var(--ivory)}
.btn--ghost-light{border-color:rgba(255,255,255,.55);color:#fff}
.btn--ghost-light:hover{background:#fff;color:var(--ink);border-color:#fff}
.btn--block{width:100%;justify-content:center}
.btn__arrow{transition:transform .35s var(--ease)}
.btn:hover .btn__arrow{transform:translateX(5px)}

/* ============================================================
   BANDEAU (topbar)
   ============================================================ */
.topbar{
  background:var(--lacquer);color:var(--ivory);
  text-align:center;padding:.66rem 1rem;
  font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;
  font-weight:400;
}
.topbar__short{display:none}

/* ============================================================
   HEADER
   ============================================================ */
.header{
  position:sticky;top:0;z-index:120;
  height:var(--header-h);
  display:flex;align-items:center;
  transition:background .4s var(--ease),box-shadow .4s,border-color .4s;
  border-bottom:1px solid transparent;
}
.header__inner{
  max-width:var(--maxw);margin:0 auto;width:100%;
  padding-inline:var(--gut);
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
  column-gap:clamp(2rem,5vw,4.2rem);
}
.header.is-solid{
  background:rgba(244,239,229,.96);
  backdrop-filter:blur(10px);
  border-bottom-color:var(--line-soft);
}

/* nav */
.nav{display:flex;gap:2.4rem}
.nav--left{justify-content:flex-end}
.nav--right{justify-content:flex-start}
.nav a{
  position:relative;font-size:.76rem;letter-spacing:.18em;
  text-transform:uppercase;font-weight:400;color:#fff;
  padding:.4em 0;transition:color .3s;
}
.header.is-solid .nav a{color:var(--ink)}
.nav a::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:0;
  background:var(--lacquer);transition:width .35s var(--ease);
}
.nav a:hover::after,.nav a.is-active::after{width:100%}
.nav a:hover,.nav a.is-active{color:var(--lacquer)}
.header.is-solid .nav a:hover,.header.is-solid .nav a.is-active{color:var(--lacquer)}

/* logo */
.logo{
  display:inline-flex;flex-direction:column;align-items:center;
  gap:.34rem;line-height:1;width:fit-content;justify-self:center;
}
.logo__name{
  font-family:var(--serif);font-weight:500;
  font-size:1.62rem;letter-spacing:.2em;text-transform:uppercase;
  color:#fff;transition:color .4s;padding-left:.2em;
}
.header.is-solid .logo__name{color:var(--ink)}
.logo__rule{
  display:block;width:75%;height:1.5px;background:var(--lacquer);
}
.logo__place{
  font-family:var(--sans);font-weight:400;
  font-size:.6rem;letter-spacing:.46em;text-transform:uppercase;
  color:rgba(255,255,255,.82);padding-left:.46em;transition:color .4s;
}
.header.is-solid .logo__place{color:var(--ink-soft)}

/* burger */
.burger{
  display:none;width:34px;height:34px;justify-self:end;
  flex-direction:column;justify-content:center;gap:6px;
}
.burger span{
  display:block;height:1.4px;width:24px;margin-left:auto;
  background:#fff;transition:.35s var(--ease);
}
.header.is-solid .burger span{background:var(--ink)}
.burger.is-open span:nth-child(1){transform:translateY(7.4px) rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0}
.burger.is-open span:nth-child(3){transform:translateY(-7.4px) rotate(-45deg)}

/* ============================================================
   VIEWS
   ============================================================ */
.view{display:none;animation:viewIn .6s var(--ease) both}
.view.is-active{display:block}
@keyframes viewIn{from{opacity:0}to{opacity:1}}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;min-height:100svh;
  display:flex;align-items:flex-end;
  color:#fff;overflow:hidden;
}
.hero__bg{position:absolute;inset:0}
.hero__bg img{width:100%;height:100%;object-fit:cover}
.hero__bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,17,14,.46) 0%,rgba(20,17,14,.05) 38%,rgba(20,17,14,.72) 100%);
}
.hero__inner{
  position:relative;z-index:2;width:100%;
  max-width:var(--maxw);margin:0 auto;
  padding:0 var(--gut) clamp(3.4rem,8vh,6rem);
}
.hero__eyebrow{color:#fff;opacity:.92;margin-bottom:1.7rem}
.hero h1{
  font-size:clamp(2.7rem,6.6vw,5.6rem);font-weight:300;
  max-width:16ch;letter-spacing:.004em;
}
.hero h1 em{font-style:italic;color:#f0d9b2}
.hero__sub{
  margin-top:1.7rem;max-width:46ch;font-size:1.02rem;
  font-weight:300;color:rgba(255,255,255,.9);line-height:1.7;
}
.hero__actions{margin-top:2.5rem;display:flex;gap:1rem;flex-wrap:wrap}
.hero__scroll{
  position:absolute;left:50%;bottom:1.6rem;transform:translateX(-50%);
  z-index:2;font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;
  color:rgba(255,255,255,.7);display:flex;flex-direction:column;
  align-items:center;gap:.6rem;
}
.hero__scroll::after{
  content:"";width:1px;height:46px;background:rgba(255,255,255,.5);
  animation:scrollPulse 2.4s var(--ease) infinite;
}
@keyframes scrollPulse{0%,100%{opacity:.2;transform:scaleY(.55)}50%{opacity:1;transform:scaleY(1)}}

/* ============================================================
   INTRO / MANIFESTO
   ============================================================ */
.intro{padding:clamp(5rem,11vw,9rem) 0}
.intro__grid{
  display:grid;grid-template-columns:1.05fr .95fr;
  gap:clamp(2.4rem,6vw,6rem);align-items:center;
}
.intro__text .eyebrow{display:block;margin-bottom:1.5rem}
.intro__text h2{
  font-size:clamp(1.9rem,3.4vw,2.9rem);font-weight:300;
  margin-bottom:1.5rem;
}
.intro__text p{
  color:var(--ink-soft);max-width:48ch;margin-bottom:1.1rem;
  font-size:1.02rem;
}
.intro__text .signature{
  margin-top:1.8rem;font-family:var(--serif);font-style:italic;
  font-size:1.25rem;color:var(--ink);
}
.intro__media{position:relative}
.intro__media .ph-a{
  width:80%;aspect-ratio:4/5;object-fit:cover;
}
.intro__media .ph-b{
  position:absolute;right:0;bottom:-3.4rem;
  width:48%;aspect-ratio:3/4;object-fit:cover;
  border:7px solid var(--ivory);
}
.intro__media .badge{
  position:absolute;left:-1.6rem;top:-1.6rem;z-index:2;
  width:118px;height:118px;border-radius:50%;
  background:var(--lacquer);color:#fbf8f1;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;line-height:1.25;
}
.intro__media .badge b{font-family:var(--serif);font-size:2rem;font-weight:500}
.intro__media .badge span{font-size:.56rem;letter-spacing:.2em;text-transform:uppercase}

/* ============================================================
   PRODUCT CARDS / GRID
   ============================================================ */
.section-pad{padding:clamp(4rem,9vw,7.5rem) 0}
.section-pad--tint{background:var(--paper)}

.grid-products{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(1.6rem,3vw,2.8rem) clamp(1.4rem,2.6vw,2.4rem);
}
.grid-products--4{grid-template-columns:repeat(4,1fr)}

.card{display:block;cursor:pointer;position:relative}
.card__media{
  position:relative;overflow:hidden;background:#fff;
  aspect-ratio:4/5;
}
.card__media img{
  width:100%;height:100%;object-fit:contain;
  transition:transform .9s var(--ease),opacity .8s;
}
.card:hover .card__media img{transform:scale(1.035)}
.card__tag{
  position:absolute;top:0;left:0;
  background:var(--ivory);color:var(--ink-soft);
  font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;
  padding:.62em 1.1em;
}
.card__tag--new{background:var(--lacquer);color:var(--ivory)}
.card__add{
  position:absolute;top:.7rem;right:.7rem;z-index:2;
  width:38px;height:38px;border-radius:50%;
  background:var(--ivory);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 12px rgba(33,29,24,.14);
  transition:background .25s,transform .2s var(--ease);
}
.card__add svg{
  width:17px;height:17px;stroke:var(--ink);fill:none;stroke-width:1.9;
  transition:stroke .2s;
}
.card__add:hover{background:var(--lacquer)}
.card__add:hover svg{stroke:var(--ivory)}
.card__add:active{transform:scale(.85)}
.card__body{padding-top:1.05rem}
.card__name{
  font-family:var(--serif);font-size:1.32rem;font-weight:500;
  line-height:1.2;transition:color .3s;
}
.card:hover .card__name{color:var(--lacquer)}
.card__origin{
  font-size:.74rem;color:var(--ink-faint);margin-top:.25rem;
  letter-spacing:.04em;
}
.card__price{
  margin-top:.7rem;font-size:.95rem;font-weight:400;
  letter-spacing:.03em;color:var(--ink);
}
.card__price .soldout{color:var(--ink-faint);font-style:italic}

/* ============================================================
   CATEGORIES STRIP
   ============================================================ */
.cats{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(1rem,2vw,1.8rem);
}
.cat{
  position:relative;display:block;overflow:hidden;
  aspect-ratio:1/1;color:#fff;cursor:pointer;
}
.cat img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.1s var(--ease);
}
.cat:hover img{transform:scale(1.07)}
.cat::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,17,14,.04),rgba(20,17,14,.66));
}
.cat__label{
  position:absolute;left:0;right:0;bottom:0;z-index:2;
  padding:clamp(1.4rem,2.6vw,2.2rem);
  display:flex;flex-direction:column;gap:.4rem;
}
.cat__label .n{
  font-size:.62rem;letter-spacing:.26em;text-transform:uppercase;
  color:rgba(255,255,255,.72);
}
.cat__label h3{font-size:clamp(1.5rem,2.5vw,2rem);font-weight:300}
.cat__label .go{
  font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;
  display:flex;align-items:center;gap:.5em;margin-top:.35rem;
  opacity:.85;transition:gap .3s;
}
.cat:hover .cat__label .go{gap:1em}

/* ============================================================
   ARTISTS TEASER
   ============================================================ */
.artists-teaser{
  background:var(--ink);color:var(--ivory);
  padding:clamp(4.5rem,9vw,8rem) 0;
}
.artists-teaser .eyebrow{color:var(--gold)}
.artists-teaser .section-head__title{color:var(--ivory)}
.artists-teaser .section-link{color:var(--ivory);border-color:var(--ivory)}
.artists-teaser .section-link:hover{color:var(--gold);border-color:var(--gold)}
.atease__grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(1.4rem,3vw,2.6rem);
}
.atease__item{cursor:pointer}
.atease__media{overflow:hidden;aspect-ratio:1/1;background:#2c2720}
.atease__media img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(.15);transition:transform 1s var(--ease),filter .6s;
}
.atease__item:hover .atease__media img{transform:scale(1.06);filter:grayscale(0)}
.atease__name{
  font-family:var(--serif);font-size:1.5rem;margin-top:1rem;
}
.atease__disc{
  font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold);margin-top:.2rem;
}

/* ============================================================
   AMBIANCE GALLERY (masonry)
   ============================================================ */
.ambiance-gallery{
  columns:3;column-gap:clamp(.9rem,2vw,1.5rem);
}
.ambiance-gallery figure{
  break-inside:avoid;margin-bottom:clamp(.9rem,2vw,1.5rem);
  overflow:hidden;background:var(--ivory-deep);cursor:pointer;
  position:relative;
}
.ambiance-gallery img{
  width:100%;transition:transform 1.1s var(--ease);
}
.ambiance-gallery figure:hover img{transform:scale(1.05)}
.ambiance-gallery figure::after{
  content:"";position:absolute;inset:0;
  background:rgba(33,29,24,0);transition:background .4s;
}
.ambiance-gallery figure:hover::after{background:rgba(33,29,24,.12)}

/* ============================================================
   VISIT BAND
   ============================================================ */
.visit{position:relative;color:#fff;overflow:hidden}
.visit__bg{position:absolute;inset:0}
.visit__bg img{width:100%;height:100%;object-fit:cover}
.visit__bg::after{content:"";position:absolute;inset:0;background:rgba(24,20,16,.62)}
.visit__inner{
  position:relative;z-index:2;
  padding:clamp(4.5rem,10vw,8rem) 0;
  display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:center;
}
.visit h2{font-size:clamp(2rem,4vw,3.2rem);font-weight:300;max-width:14ch}
.visit__eyebrow{color:#fff;opacity:.9;display:block;margin-bottom:1.3rem}
.visit p{color:rgba(255,255,255,.86);max-width:40ch;margin-top:1.2rem}
.visit__info{
  border-left:1px solid rgba(255,255,255,.28);
  padding-left:2.4rem;display:flex;flex-direction:column;gap:1.5rem;
}
.visit__info .row .k{
  font-size:.64rem;letter-spacing:.24em;text-transform:uppercase;
  color:rgba(255,255,255,.6);margin-bottom:.35rem;
}
.visit__info .row .v{font-family:var(--serif);font-size:1.3rem}
.visit__actions{margin-top:1.9rem}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--ink);color:var(--ivory)}
.footer__top{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;
  gap:2.6rem;padding:clamp(3.6rem,7vw,5.5rem) 0 3rem;
}
.footer .logo__name{color:var(--ivory)}
.footer .logo__place{color:rgba(244,239,229,.7)}
.footer__about{margin-top:1.5rem;color:rgba(244,239,229,.6);
  font-size:.92rem;max-width:32ch}
.footer__col h4{
  font-family:var(--sans);font-size:.66rem;font-weight:400;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);margin-bottom:1.3rem;
}
.footer__col li{margin-bottom:.7rem}
.footer__col a,.footer__col span{
  color:rgba(244,239,229,.72);font-size:.92rem;transition:color .3s;
}
.footer__col a:hover{color:var(--ivory)}
.footer__bottom{
  border-top:1px solid rgba(244,239,229,.13);
  padding:1.7rem 0;display:flex;justify-content:space-between;
  flex-wrap:wrap;gap:1rem;
}
.footer__bottom p,.footer__bottom a{
  font-size:.74rem;color:rgba(244,239,229,.5);letter-spacing:.04em;
}
.footer__credit a:hover{color:var(--gold)}

/* ============================================================
   BOUTIQUE (accueil + collection)
   ============================================================ */
/* --- Bandeau d'introduction : fin, pleine largeur --- */
.intro-banner{
  position:relative;overflow:hidden;background:var(--ink);
  min-height:clamp(190px,25vh,280px);
  display:flex;align-items:center;
}
.intro-banner__media{position:absolute;inset:0}
.intro-banner__media img{
  width:100%;height:100%;object-fit:cover;object-position:center 42%;
}
.intro-banner::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(26,22,18,.8) 0%,rgba(26,22,18,.46) 44%,rgba(26,22,18,.12) 80%);
}
.intro-banner__text{position:relative;z-index:2;width:100%}
.intro-banner__text .eyebrow{display:block;margin-bottom:.7rem}
.intro-banner__text h2{
  font-family:var(--serif);font-weight:300;color:#fff;
  font-size:clamp(1.7rem,3vw,2.5rem);line-height:1.12;margin-bottom:.7rem;
}
.intro-banner__text p{
  color:rgba(255,255,255,.88);font-size:.95rem;max-width:46ch;
}

.shop-head{
  text-align:center;
  padding:clamp(2.4rem,5vw,4rem) 0 clamp(1.4rem,3vw,2.4rem);
}
.shop-head .eyebrow{display:block;margin-bottom:1rem}
.shop-head h1{
  font-size:clamp(2.6rem,5.4vw,4.2rem);font-weight:300;letter-spacing:.01em;
}

.toolbar{
  display:flex;align-items:center;justify-content:space-between;
  gap:1.5rem;flex-wrap:wrap;padding:2rem 0;
  position:sticky;top:var(--header-h);z-index:40;
  background:var(--ivory);border-bottom:1px solid var(--line-soft);
}
.filters{display:flex;gap:.5rem;flex-wrap:wrap}
.filter{
  font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  padding:.7em 1.3em;border:1px solid var(--line);
  color:var(--ink-soft);transition:.3s var(--ease);
}
.filter:hover{border-color:var(--ink);color:var(--ink)}
.filter.is-active{background:var(--ink);border-color:var(--ink);color:var(--ivory)}
.toolbar__count{font-size:.8rem;color:var(--ink-faint);letter-spacing:.06em}
.collection-grid{padding:clamp(2.5rem,5vw,4rem) 0 clamp(3rem,6vw,5rem)}

/* --- Dernières arrivées --- */
.latest{padding:clamp(1.4rem,3vw,2.4rem) 0 clamp(1rem,2vw,1.6rem)}
.latest__head{
  display:flex;align-items:baseline;gap:1.1rem;
  margin-bottom:clamp(1.3rem,2.6vw,1.9rem);
}
.latest__head h2{font-size:clamp(1.6rem,3vw,2.3rem);font-weight:300}
.latest__head .tag{
  font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--lacquer);
}
.latest__row{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:clamp(1.6rem,3vw,2.8rem) clamp(1.4rem,2.6vw,2.4rem);
}

/* --- Formulaire de contact en bas de boutique --- */
.shop-contact{
  background:var(--paper);
  border-top:1px solid var(--line-soft);
  padding:clamp(3.5rem,7vw,6rem) 0;
  margin-top:clamp(2rem,5vw,4rem);
  scroll-margin-top:calc(var(--header-h) + 16px);
}
.contact-box{
  display:grid;grid-template-columns:.82fr 1.18fr;
  gap:clamp(2rem,5vw,4.5rem);
  max-width:1040px;margin:0 auto;align-items:start;
}
.contact-box__intro .eyebrow{display:block;margin-bottom:1rem}
.contact-box__intro h2{
  font-size:clamp(2rem,3.6vw,2.9rem);font-weight:300;
  margin-bottom:1.1rem;line-height:1.1;
}
.contact-box__intro p{color:var(--ink-soft);font-size:.99rem;max-width:34ch}
.contact-piece{
  display:flex;gap:1rem;align-items:center;
  background:var(--ivory-deep);padding:.8rem;margin-bottom:1.3rem;
}
.contact-piece img{width:62px;height:62px;object-fit:cover;flex:none}
.contact-piece .cp-name{font-family:var(--serif);font-size:1.16rem;line-height:1.2}
.contact-piece .cp-price{font-size:.82rem;color:var(--ink-soft);margin-top:.15rem}
.contact-flash{animation:flash 1.6s var(--ease)}
@keyframes flash{0%,100%{box-shadow:0 0 0 0 rgba(215,74,59,0)}
  25%{box-shadow:0 0 0 4px rgba(215,74,59,.30)}}

/* ============================================================
   PRODUCT DETAIL VIEW
   ============================================================ */
.crumb{
  padding:1.6rem 0;font-size:.74rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink-faint);
}
.crumb a{transition:color .3s}
.crumb a:hover{color:var(--lacquer)}
.crumb span{color:var(--ink)}

.product{
  display:grid;grid-template-columns:1.18fr .82fr;
  gap:clamp(2rem,4.5vw,4.5rem);
  padding-bottom:clamp(3.5rem,7vw,6rem);
}

/* gallery */
.pgal__main{
  position:relative;background:var(--ivory-deep);
  aspect-ratio:4/5;overflow:hidden;cursor:zoom-in;
}
.pgal__main img{width:100%;height:100%;object-fit:cover}
.pgal__zoom{
  position:absolute;right:1rem;bottom:1rem;
  width:42px;height:42px;border-radius:50%;
  background:rgba(251,248,241,.92);
  display:flex;align-items:center;justify-content:center;
}
.pgal__zoom svg{width:17px;height:17px;stroke:var(--ink);fill:none;stroke-width:1.5}
.pgal__count{
  position:absolute;left:1rem;top:1rem;
  background:rgba(33,29,24,.78);color:var(--ivory);
  font-size:.66rem;letter-spacing:.12em;padding:.5em 1em;
}
.pgal__thumbs{
  display:grid;grid-template-columns:repeat(5,1fr);
  gap:.6rem;margin-top:.7rem;
}
.pgal__thumb{
  aspect-ratio:1/1;overflow:hidden;background:var(--ivory-deep);
  cursor:pointer;opacity:.62;transition:opacity .3s;
  outline:1.5px solid transparent;outline-offset:-1.5px;
}
.pgal__thumb img{width:100%;height:100%;object-fit:cover}
.pgal__thumb:hover{opacity:.92}
.pgal__thumb.is-active{opacity:1;outline-color:var(--lacquer)}

/* info panel */
.pinfo{position:relative}
.pinfo__sticky{position:sticky;top:calc(var(--header-h) + 2rem)}
.pinfo__cat{
  font-size:.68rem;letter-spacing:.26em;text-transform:uppercase;
  color:var(--lacquer);
}
.pinfo h1{
  font-size:clamp(2rem,3.3vw,2.9rem);font-weight:300;
  margin:.85rem 0 .5rem;line-height:1.1;
}
.pinfo__origin{
  font-size:.92rem;color:var(--ink-faint);font-style:italic;
  font-family:var(--serif);font-size:1.08rem;
}
.pinfo__price{
  display:flex;align-items:baseline;gap:.8rem;
  margin:1.5rem 0;padding-bottom:1.5rem;
  border-bottom:1px solid var(--line-soft);
}
.pinfo__price .amount{
  font-family:var(--serif);font-size:2.1rem;font-weight:500;
}
.pinfo__price .unique{
  font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--lacquer);border:1px solid var(--lacquer);
  padding:.42em .9em;
}
.pinfo__desc{color:var(--ink-soft);margin-bottom:1.7rem;font-size:1.01rem}
.pinfo__cta{margin-bottom:1.1rem}
.pinfo__reassure{
  display:flex;flex-direction:column;gap:.65rem;
  margin-top:1.6rem;
}
.pinfo__reassure li{
  display:flex;gap:.7rem;align-items:center;
  font-size:.85rem;color:var(--ink-soft);
}
.pinfo__reassure svg{
  width:16px;height:16px;stroke:var(--lacquer);fill:none;
  stroke-width:1.5;flex:none;
}

/* specs */
.pdetails{
  border-top:1px solid var(--line-soft);
  padding:clamp(2.5rem,5vw,4rem) 0;
  display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,5rem);
}
.pdetails h3{font-size:1.6rem;font-weight:300;margin-bottom:1.3rem}
.pdetails__long p{color:var(--ink-soft);margin-bottom:1rem}
.specs__row{
  display:flex;justify-content:space-between;gap:1.5rem;
  padding:.95rem 0;border-bottom:1px solid var(--line-soft);
}
.specs__row .k{
  font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-faint);flex:none;
}
.specs__row .v{text-align:right;color:var(--ink);font-size:.95rem}

.related{
  border-top:1px solid var(--line-soft);
  padding:clamp(3rem,6vw,5rem) 0 clamp(4rem,8vw,7rem);
}

/* ============================================================
   ARTISTS VIEW
   ============================================================ */
.artist-block{
  padding:clamp(3rem,6vw,5.5rem) 0;
  border-bottom:1px solid var(--line-soft);
}
.artist-block:last-child{border-bottom:0}
.artist-head{
  display:grid;grid-template-columns:auto 1fr;gap:clamp(1.5rem,4vw,3.5rem);
  align-items:center;margin-bottom:clamp(1.8rem,3.5vw,2.6rem);
}
.artist-head__num{
  font-family:var(--serif);font-size:clamp(3rem,7vw,5.5rem);
  color:var(--ivory-deep);font-weight:500;line-height:.8;
}
.artist-head__txt h2{font-size:clamp(1.9rem,3.6vw,2.8rem);font-weight:300}
.artist-head__txt .disc{
  font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--lacquer);margin:.5rem 0 .9rem;
}
.artist-head__txt p{color:var(--ink-soft);max-width:62ch}
.artist-gallery{
  columns:4;column-gap:clamp(.8rem,1.8vw,1.3rem);
}
.artist-gallery figure{
  break-inside:avoid;margin-bottom:clamp(.8rem,1.8vw,1.3rem);
  overflow:hidden;background:var(--ivory-deep);cursor:pointer;
}
.artist-gallery img{width:100%;transition:transform 1s var(--ease)}
.artist-gallery figure:hover img{transform:scale(1.05)}

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lightbox{
  position:fixed;inset:0;z-index:300;
  background:rgba(20,17,14,.96);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .35s;
}
.lightbox.is-open{opacity:1;pointer-events:auto}
.lightbox__img{
  max-width:88vw;max-height:84vh;object-fit:contain;
  box-shadow:0 30px 80px rgba(0,0,0,.5);
}
.lb-btn{
  position:absolute;color:rgba(255,255,255,.8);
  width:54px;height:54px;display:flex;align-items:center;justify-content:center;
  transition:color .3s;
}
.lb-btn:hover{color:#fff}
.lb-btn svg{width:30px;height:30px;stroke:currentColor;fill:none;stroke-width:1.4}
.lb-close{top:1.4rem;right:1.4rem}
.lb-prev{left:1rem;top:50%;transform:translateY(-50%)}
.lb-next{right:1rem;top:50%;transform:translateY(-50%)}
.lb-count{
  position:absolute;bottom:1.6rem;left:50%;transform:translateX(-50%);
  color:rgba(255,255,255,.7);font-size:.75rem;letter-spacing:.2em;
}

/* ============================================================
   MODAL (enquiry form)
   ============================================================ */
.modal{
  position:fixed;inset:0;z-index:260;
  display:flex;align-items:center;justify-content:center;
  padding:1.2rem;opacity:0;pointer-events:none;transition:opacity .35s;
}
.modal.is-open{opacity:1;pointer-events:auto}
.modal__veil{position:absolute;inset:0;background:rgba(20,17,14,.6);backdrop-filter:blur(3px)}
.modal__box{
  position:relative;background:var(--paper);
  width:min(560px,100%);max-height:92vh;overflow-y:auto;
  padding:clamp(1.8rem,4vw,3rem);
  transform:translateY(20px) scale(.98);
  transition:transform .4s var(--ease);
}
.modal.is-open .modal__box{transform:translateY(0) scale(1)}
.modal__close{
  position:absolute;top:1rem;right:1rem;
  width:38px;height:38px;display:flex;align-items:center;justify-content:center;
  color:var(--ink-soft);transition:color .3s;
}
.modal__close:hover{color:var(--lacquer)}
.modal__close svg{width:20px;height:20px;stroke:currentColor;stroke-width:1.5}
.modal .eyebrow{display:block;margin-bottom:.7rem}
.modal h3{font-size:1.85rem;font-weight:300;margin-bottom:.4rem}
.modal__intro{color:var(--ink-soft);font-size:.94rem;margin-bottom:1.6rem}
.modal__piece{
  display:flex;gap:1rem;align-items:center;
  background:var(--ivory-deep);padding:.8rem;margin-bottom:1.5rem;
}
.modal__piece img{width:64px;height:64px;object-fit:cover;flex:none}
.modal__piece .mp-name{font-family:var(--serif);font-size:1.15rem}
.modal__piece .mp-price{font-size:.84rem;color:var(--ink-soft)}

.field{margin-bottom:1.1rem}
.field label{
  display:block;font-size:.68rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-soft);margin-bottom:.5rem;
}
.field input,.field textarea{
  width:100%;font-family:var(--sans);font-size:.95rem;font-weight:300;
  padding:.85em 1em;background:#fff;border:1px solid var(--line);
  color:var(--ink);transition:border-color .3s;
}
.field input:focus,.field textarea:focus{outline:0;border-color:var(--lacquer)}
.field textarea{resize:vertical;min-height:96px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.modal__note{font-size:.74rem;color:var(--ink-faint);margin-top:.9rem;text-align:center}
.form-success{text-align:center;padding:1.5rem 0}
.form-success svg{
  width:54px;height:54px;stroke:var(--lacquer);fill:none;stroke-width:1.2;
  margin:0 auto 1.2rem;
}
.form-success h3{margin-bottom:.6rem}
.form-success p{color:var(--ink-soft);margin-bottom:1.6rem}

/* ============================================================
   MOBILE NAV DRAWER
   ============================================================ */
.drawer{
  position:fixed;inset:0;z-index:115;
  background:var(--ink);color:var(--ivory);
  display:flex;flex-direction:column;justify-content:center;
  padding:var(--gut);
  transform:translateX(100%);transition:transform .5s var(--ease);
}
.drawer.is-open{transform:translateX(0)}
.drawer nav{display:flex;flex-direction:column}
.drawer a{
  display:block;
  font-family:var(--serif);font-size:2rem;font-weight:300;
  padding:.62rem 0;border-bottom:1px solid rgba(244,239,229,.12);
}
.drawer a .idx{
  font-family:var(--sans);font-size:.7rem;color:var(--gold);
  letter-spacing:.2em;margin-right:1rem;
}
.drawer__foot{margin-top:2.5rem;color:rgba(244,239,229,.55);font-size:.85rem}

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
.reveal{opacity:0;transform:translateY(26px);
  transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.is-in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}

.fade-img{opacity:0;transition:opacity .8s var(--ease)}
.fade-img.loaded{opacity:1}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1080px){
  .grid-products,.grid-products--4,.latest__row{grid-template-columns:repeat(2,1fr)}
  .artist-gallery{columns:3}
}
@media(max-width:900px){
  :root{--header-h:70px}
  .nav{display:none}
  .burger{display:flex}
  .header__inner{grid-template-columns:auto 1fr auto}
  .logo{justify-self:start}
  .logo__name{font-size:1.4rem}
  .intro__grid{grid-template-columns:1fr;gap:5rem}
  .intro__media{max-width:480px}
  .product{grid-template-columns:1fr;gap:1.6rem}
  .pinfo__sticky{position:static}
  .pdetails{grid-template-columns:1fr;gap:2rem}
  .visit__inner{grid-template-columns:1fr;gap:2.4rem}
  .visit__info{border-left:0;border-top:1px solid rgba(255,255,255,.28);
    padding-left:0;padding-top:2rem}
  .footer__top{grid-template-columns:1fr 1fr}
  .ambiance-gallery{columns:2}
  .contact-box{grid-template-columns:1fr;gap:2rem}
}
@media(max-width:768px){
  .topbar__full{display:none}
  .topbar__short{display:inline}
}
@media(max-width:620px){
  :root{--gut:16px}
  .topbar{font-size:.56rem;letter-spacing:.17em;padding:.6rem 1rem}
  .cats,.atease__grid{grid-template-columns:1fr}
  /* boutique : grille 2 colonnes sur mobile (Dernières arrivées comprises) */
  .grid-products,.grid-products--4,.latest__row{
    grid-template-columns:repeat(2,1fr);
    gap:1.7rem 1rem;
  }
  .card__tag{display:none}
  .card__body{padding-top:.7rem}
  .card__name{font-size:1.06rem}
  .card__origin{font-size:.68rem;margin-top:.15rem}
  .card__price{margin-top:.4rem;font-size:.92rem;font-weight:500}
  .card__add{width:32px;height:32px;top:.5rem;right:.5rem}
  .card__add svg{width:14px;height:14px}
  .latest__head{flex-direction:column;align-items:flex-start;gap:.3rem}
  .intro-banner{min-height:auto;padding:2.1rem 0}
  .intro-banner__text p{font-size:.86rem}
  .ambiance-gallery,.artist-gallery{columns:2}
  .pgal__thumbs{grid-template-columns:repeat(4,1fr)}
  .field-row{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr}
  .hero h1{font-size:clamp(2.4rem,9vw,3.2rem)}
  .section-head{gap:1rem}
  .toolbar{padding:1.1rem 0}
  .filter{padding:.6em 1em;font-size:.66rem}
  .shop-head{padding:1.6rem 0 1.2rem}
  .artist-head{grid-template-columns:1fr;gap:.5rem}
  .pinfo__price .amount{font-size:1.8rem}
}
@media(max-width:380px){
  .ambiance-gallery,.artist-gallery{columns:1}
}
