:root{--noir:#f0ece6;--charbon:#ede5d8;--brun-sombre:#e2d8c8;--brun-chaud:#d4c8b0;--or:#b87333;--or-clair:#d4956a;--or-pale:#e8c49a;--creme:#2a1f12;--creme-sombre:#2e1f14;--rouille:#8b5e3c;--gris-chaud:#7a6552}
*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}
body{background:var(--noir);color:var(--creme);font-family:'Josefin Sans',sans-serif;font-weight:300;overflow-x:hidden;cursor:none}
.cursor{width:8px;height:8px;background:var(--or);border-radius:50%;position:fixed;pointer-events:none;z-index:9999;transition:transform .15s;transform:translate(-50%,-50%)}
.cursor-ring{width:30px;height:30px;border:1px solid var(--or);border-radius:50%;position:fixed;pointer-events:none;z-index:9998;transition:transform .4s,width .3s,height .3s,opacity .3s;transform:translate(-50%,-50%);opacity:.5}
/* NAV — sans logo */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:18px 50px;display:flex;justify-content:flex-end;align-items:center;background:linear-gradient(to bottom,rgba(245,237,224,.95),transparent);transition:background .3s,border-bottom .3s}
nav.scrolled{background:rgba(245,237,224,.97);border-bottom:1px solid rgba(184,115,51,.1)}
.nav-right{display:flex;align-items:center;gap:32px}
.nav-links{display:flex;gap:36px;list-style:none}
.nav-links a{text-decoration:none;color:var(--creme-sombre);font-size:.68rem;letter-spacing:.25em;text-transform:uppercase;transition:color .3s}
.nav-links a:hover{color:var(--or-clair)}
.lang-switcher{display:flex;gap:6px;align-items:center}
.lang-btn{background:none;border:none;cursor:pointer;font-size:1.3rem;opacity:.45;transition:opacity .2s,transform .2s;line-height:1;padding:2px}
.lang-btn:hover{opacity:.8;transform:scale(1.15)}
.lang-btn.active{opacity:1;transform:scale(1.15)}
.nav-toggle{display:none;background:none;border:none;color:var(--or-clair);font-size:1.4rem;cursor:pointer}
/* HERO + CANVAS LASER */
.hero{height:100vh;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 20% 50%,rgba(184,115,51,.08),transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(139,69,19,.12),transparent 50%),linear-gradient(160deg,#e8e0d5,#d4c8b0 60%,#b8a898)}
.laser-lines{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.laser-lines::before{content:'';position:absolute;top:0;right:15%;bottom:0;width:1px;background:linear-gradient(to bottom,transparent,var(--or) 30%,var(--or-clair) 50%,var(--or) 70%,transparent);opacity:.12}
.hero-center{position:relative;z-index:3;display:flex;flex-direction:column;align-items:center;gap:0}
.laser-canvas-inline{display:block;pointer-events:none;max-width:90vw}
.hero-content{position:relative;text-align:center;z-index:3;animation:fadeUp 1.2s 4.5s ease forwards;opacity:0;margin-top:-10px}

@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.hero-eyebrow{font-size:.85rem;letter-spacing:.5em;text-transform:uppercase;color:#8B4513;margin-bottom:16px;opacity:1;text-shadow:0 1px 2px rgba(255,255,255,.7),0 -1px 1px rgba(0,0,0,.2);font-weight:600}
.hero-subtitle{font-size:.7rem;letter-spacing:.4em;text-transform:uppercase;color:#1a110a;margin-top:16px;opacity:.7}
.hero-scroll{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--gris-chaud);font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;animation:pulse 2s 5s infinite}
.scroll-line{width:1px;height:50px;background:linear-gradient(to bottom,var(--or),transparent);animation:growLine 2s 5s ease-in-out infinite}
@keyframes growLine{0%,100%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}}
@keyframes pulse{0%,100%{opacity:.4}50%{opacity:.9}}
/* SECTIONS */
section{padding:110px 60px}
.section-label{font-size:.6rem;letter-spacing:.5em;text-transform:uppercase;color:var(--or);margin-bottom:16px;opacity:.7}
.section-title{font-family:'Cormorant Garamond',serif;font-size:clamp(2.5rem,5vw,4.5rem);font-weight:300;line-height:1.1;color:var(--creme);margin-bottom:40px}
.section-title em{font-style:italic;color:var(--or-clair)}
/* ABOUT */
.about{background:var(--charbon);display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-image-wrapper{position:relative}
.about-photo{width:100%;aspect-ratio:3/4;object-fit:cover;display:block;filter:sepia(20%)contrast(1.1)}
.about-image-wrapper::before{content:'';position:absolute;top:-15px;left:-15px;right:30px;bottom:30px;border:1px solid rgba(184,115,51,.25);pointer-events:none}
.about-image-wrapper::after{content:'';position:absolute;top:15px;left:15px;right:-15px;bottom:-15px;border:1px solid rgba(184,115,51,.1);pointer-events:none}
.about-bio{color:var(--creme-sombre);font-size:.95rem;line-height:1.9;margin-bottom:24px}
.about-bio strong{color:var(--or-clair);font-weight:400}
.about-divider{width:60px;height:1px;background:var(--or);margin:30px 0;opacity:.4}
.about-stats{display:flex;gap:40px;margin-top:40px}
.stat-number{font-family:'Cormorant Garamond',serif;font-size:3rem;font-weight:300;color:var(--or-clair);line-height:1}
.stat-label{font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gris-chaud);margin-top:6px}
/* GALERIE */
.gallery{background:var(--noir)}
.gallery-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:40px;flex-wrap:wrap;gap:20px}
.gallery-controls{display:flex;flex-direction:column;align-items:flex-end;gap:12px}
.gallery-filters{display:flex;gap:16px;flex-wrap:wrap;justify-content:flex-end}
.filter-btn{background:none;border:none;color:var(--gris-chaud);font-family:'Josefin Sans',sans-serif;font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;cursor:pointer;transition:color .3s;padding:8px 0;border-bottom:1px solid transparent}
.filter-btn.active,.filter-btn:hover{color:var(--or-clair);border-bottom-color:var(--or)}
/* MENU DEROULANT SOUS-CATEGORIES */
.subcat-wrap{position:relative}
.subcat-toggle{background:rgba(184,115,51,.08);border:1px solid rgba(184,115,51,.2);color:var(--or-clair);font-family:'Josefin Sans',sans-serif;font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;padding:9px 18px;cursor:pointer;transition:all .3s;display:flex;align-items:center;gap:8px}
.subcat-toggle:hover{background:rgba(184,115,51,.15);border-color:var(--or)}
.subcat-dropdown{position:absolute;right:0;top:calc(100% + 6px);background:#ede5d8;border:1px solid rgba(184,115,51,.2);min-width:220px;z-index:50;display:none;flex-direction:column;box-shadow:0 20px 60px rgba(42,31,20,.35)}
.subcat-dropdown.open{display:flex}
.subcat-dropdown button{background:none;border:none;border-bottom:1px solid rgba(184,115,51,.06);color:var(--creme-sombre);font-family:'Josefin Sans',sans-serif;font-size:.7rem;letter-spacing:.1em;padding:13px 18px;cursor:pointer;text-align:left;transition:background .2s,color .2s}
.subcat-dropdown button:hover,.subcat-dropdown button.active{background:rgba(184,115,51,.08);color:var(--or-clair)}
.subcat-dropdown button:last-child{border-bottom:none}
/* GRILLE */
.gallery-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:8px}
.gallery-item{position:relative;overflow:hidden;background:var(--brun-sombre);border:1px solid rgba(184,115,51,.05);cursor:pointer;transition:border-color .3s}
.gallery-item img{width:100%;height:100%;min-height:200px;object-fit:cover;display:block;transition:transform .6s,filter .4s;filter:brightness(.88)}
.gallery-item:hover{border-color:rgba(184,115,51,.25)}
.gallery-item:hover img{transform:scale(1.05);filter:brightness(1.02)}
.gallery-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(245,237,224,.92),transparent 65%);opacity:0;transition:opacity .4s;display:flex;align-items:flex-end;padding:18px}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-info{transform:translateY(8px);transition:transform .4s}
.gallery-item:hover .gallery-info{transform:translateY(0)}
.gallery-name{font-family:'Cormorant Garamond',serif;font-size:1rem;color:var(--creme);font-style:italic}
.gallery-ref{font-size:.52rem;letter-spacing:.25em;color:rgba(184,115,51,.5);margin-top:2px}
.gallery-cat{font-size:.55rem;letter-spacing:.3em;text-transform:uppercase;color:var(--or);margin-top:3px}
/* SHOP */
.shop{background:var(--brun-sombre);position:relative}
.shop::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 60px,rgba(184,115,51,.015) 60px,rgba(184,115,51,.015) 61px);pointer-events:none}
.shop-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:60px}
.product-card{background:var(--charbon);border:1px solid rgba(184,115,51,.08);position:relative;transition:border-color .3s,transform .3s}
.product-card:hover{border-color:rgba(184,115,51,.3);transform:translateY(-4px)}
.product-badge{position:absolute;top:16px;right:16px;background:var(--or);color:var(--noir);font-size:.55rem;letter-spacing:.2em;text-transform:uppercase;padding:4px 10px;z-index:1}
.product-img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;filter:sepia(10%)brightness(.9);transition:filter .4s}
.product-card:hover .product-img{filter:sepia(5%)brightness(1.05)}
.product-info{padding:22px}
.product-name{font-family:'Cormorant Garamond',serif;font-size:1.2rem;color:var(--creme);margin-bottom:6px;font-style:italic}
.product-desc{font-size:.7rem;color:var(--gris-chaud);line-height:1.6;margin-bottom:18px}
.product-footer{display:flex;justify-content:space-between;align-items:center}
.product-price{font-family:'Cormorant Garamond',serif;font-size:1.4rem;color:var(--or-clair)}
.product-price small{font-size:.6rem;color:var(--gris-chaud);font-family:'Josefin Sans',sans-serif;letter-spacing:.1em;margin-left:4px}
.btn-add{background:transparent;border:1px solid var(--or);color:var(--or-clair);font-family:'Josefin Sans',sans-serif;font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;padding:10px 18px;cursor:pointer;transition:background .3s,color .3s}
.btn-add:hover{background:var(--or);color:var(--noir)}
.shop-note{margin-top:50px;padding:28px 36px;border:1px solid rgba(184,115,51,.15);background:rgba(184,115,51,.03);display:flex;align-items:center;gap:18px}
.shop-note-icon{font-size:1.4rem;opacity:.6}
.shop-note-text{font-size:.75rem;color:var(--gris-chaud);line-height:1.7}
.shop-note-text strong{color:var(--creme-sombre)}
/* NEWSLETTER */
.newsletter{background:var(--charbon);text-align:center;position:relative;overflow:hidden}
.newsletter::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:600px;height:600px;border-radius:50%;border:1px solid rgba(184,115,51,.06)}
.newsletter::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:400px;height:400px;border-radius:50%;border:1px solid rgba(184,115,51,.1)}
.newsletter-content{position:relative;z-index:1;max-width:600px;margin:0 auto}
.newsletter-intro{color:var(--creme-sombre);font-size:.85rem;line-height:1.8;margin-top:20px}
.newsletter-form{display:flex;margin:40px auto 0;max-width:500px}
.newsletter-input{flex:1;background:rgba(255,255,255,.04);border:1px solid rgba(184,115,51,.2);border-right:none;color:var(--creme);font-family:'Josefin Sans',sans-serif;font-size:.75rem;padding:16px 20px;outline:none;transition:border-color .3s}
.newsletter-input::placeholder{color:var(--gris-chaud)}
.newsletter-input:focus{border-color:var(--or)}
.btn-newsletter{background:var(--or);border:1px solid var(--or);color:var(--noir);font-family:'Josefin Sans',sans-serif;font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;padding:16px 28px;cursor:pointer;transition:background .3s;white-space:nowrap}
.btn-newsletter:hover{background:var(--or-clair)}
.newsletter-note{margin-top:12px;font-size:.6rem;color:var(--gris-chaud);opacity:.6}
.captcha-wrap{max-width:500px;margin:14px auto 0;background:rgba(255,255,255,.03);border:1px solid rgba(184,115,51,.1);padding:12px 20px;display:flex;align-items:center;gap:14px}
.captcha-check{width:20px;height:20px;border:1px solid rgba(184,115,51,.4);background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s;color:transparent;font-size:.8rem}
.captcha-check.checked{background:var(--or);color:var(--noir);border-color:var(--or)}
.captcha-text{font-size:.65rem;color:var(--gris-chaud)}
.captcha-logo{margin-left:auto;font-size:.55rem;color:rgba(184,115,51,.3);text-align:right}
/* CONTACT */
.contact{background:var(--noir);display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.contact-form{display:flex;flex-direction:column;gap:16px}
.form-field{display:flex;flex-direction:column;gap:8px}
.form-label{font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:var(--or);opacity:.7}
.form-input,.form-textarea{background:rgba(255,255,255,.03);border:1px solid rgba(184,115,51,.15);color:var(--creme);font-family:'Josefin Sans',sans-serif;font-size:.85rem;padding:14px 18px;outline:none;transition:border-color .3s;resize:none}
.form-input:focus,.form-textarea:focus{border-color:var(--or)}
.form-textarea{min-height:130px}
.form-input::placeholder,.form-textarea::placeholder{color:var(--gris-chaud);opacity:.6}
.hcaptcha-wrap{margin:8px 0}
.btn-submit{align-self:flex-start;background:transparent;border:1px solid var(--or);color:var(--or-clair);font-family:'Josefin Sans',sans-serif;font-size:.65rem;letter-spacing:.35em;text-transform:uppercase;padding:16px 40px;cursor:pointer;transition:all .3s;margin-top:8px}
.btn-submit:hover{background:var(--or);color:var(--noir)}
.contact-info{padding-top:20px}
.contact-detail{display:flex;flex-direction:column;gap:6px;margin-bottom:32px}
.contact-detail-label{font-size:.6rem;letter-spacing:.35em;text-transform:uppercase;color:var(--or);opacity:.6}
.contact-detail-value{font-family:'Cormorant Garamond',serif;font-size:1.1rem;color:var(--creme-sombre);font-style:italic}
.social-links{display:flex;gap:20px;margin-top:40px}
.social-link{font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gris-chaud);text-decoration:none;border-bottom:1px solid transparent;padding-bottom:4px;transition:color .3s,border-color .3s}
.social-link:hover{color:var(--or-clair);border-color:var(--or)}
/* FOOTER */
footer{background:var(--brun-sombre);padding:36px 60px;display:flex;justify-content:space-between;align-items:center;border-top:1px solid rgba(184,115,51,.1)}
.footer-logo-img{height:38px;width:auto;filter:sepia(.3)saturate(2)hue-rotate(5deg)brightness(.7);opacity:.7}
.footer-copy{font-size:.6rem;color:var(--gris-chaud);letter-spacing:.15em;opacity:.5}
.footer-links{display:flex;gap:24px}
.footer-links a{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gris-chaud);text-decoration:none;opacity:.5;transition:opacity .3s}
.footer-links a:hover{opacity:1}
/* LIGHTBOX */
.modal{position:fixed;inset:0;background:rgba(245,237,224,.98);z-index:200;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .35s;padding:20px}
.modal.open{opacity:1;pointer-events:all}
.modal-close{position:absolute;top:20px;right:28px;background:none;border:none;color:#2a1f12 !important;font-size:1.3rem;cursor:pointer;font-family:'Josefin Sans',sans-serif;letter-spacing:.2em;z-index:10;transition:color .2s}
.modal-close:hover{color:var(--or-clair)}
.modal-layout{display:flex;gap:40px;max-width:1100px;width:100%;max-height:90vh;align-items:center}
.modal-img-wrap{flex:1;min-width:0;display:flex;align-items:center;justify-content:center}
.modal-img{max-width:100%;max-height:80vh;object-fit:contain;border:1px solid rgba(184,115,51,.15)}
.modal-sidebar{width:280px;flex-shrink:0;display:flex;flex-direction:column}
.modal-ref{font-size:.58rem;letter-spacing:.4em;color:var(--or);opacity:.6;margin-bottom:8px}
.modal-title {
  font-size: 1.4rem;
  font-weight: 800;
  color: #1a1a1a;
  letter-spacing: .06em;
  text-transform: uppercase;
  border: 2px solid var(--or-chaud);
  border-radius: 5px;
  padding: .35rem .8rem;
  background: rgba(198,145,40,.07);
  box-shadow: 0 0 12px rgba(198,145,40,.3), inset 0 0 6px rgba(198,145,40,.07);
  display: block;
  width: 100%;
  box-sizing: border-box;
  margin-bottom: .5rem;
}
.modal-cat{font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;color:#c69128 !important;font-weight:700 !important}
.modal-divider{width:40px;height:1px;background:var(--or);opacity:.5;margin:18px 0}
.modal-desc{font-size:.9rem;color:#2a1f12 !important;font-weight:600 !important;line-height:1.6}
.want-title{font-family:'Cormorant Garamond',serif;font-size:1rem;font-style:italic;color:var(--or-clair);margin-bottom:14px}
.want-fields{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.want-input,.want-textarea{background:rgba(255,255,255,.04);border:1px solid rgba(184,115,51,.2);color:var(--creme);font-family:'Josefin Sans',sans-serif;font-size:.75rem;padding:10px 14px;outline:none;transition:border-color .3s;resize:none}
.want-input::placeholder,.want-textarea::placeholder{color:var(--gris-chaud);opacity:.5}
.want-input:focus,.want-textarea:focus{border-color:var(--or)}
.want-textarea{min-height:70px}
.want-btns{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}
.btn-want-email{background:var(--or);border:none;color:var(--noir);font-family:'Josefin Sans',sans-serif;font-size:.62rem;letter-spacing:.25em;text-transform:uppercase;padding:13px;cursor:pointer;transition:background .3s;font-weight:bold}
.btn-want-email:hover{background:var(--or-clair)}
.btn-want-mailto{background:transparent;border:1px solid #c69128;color:#2a1f12 !important;font-family:'Josefin Sans',sans-serif;font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;padding:11px;cursor:pointer;transition:all .3s}
.btn-want-mailto:hover{border-color:var(--or);color:var(--or-clair)}
.want-note{font-size:.6rem;color:#7a6552 !important;opacity:.85;text-align:center}
.want-success{background:rgba(184,115,51,.1);border:1px solid rgba(184,115,51,.3);color:var(--or-clair);padding:12px;font-size:.75rem;text-align:center;margin-top:10px}
/* RESPONSIVE */
@media(max-width:900px){
  section{padding:80px 28px}nav{padding:16px 28px}
  .about,.contact{grid-template-columns:1fr;gap:40px}
  .shop-grid{grid-template-columns:1fr 1fr}
  .gallery-header{flex-direction:column;align-items:flex-start}
  .gallery-controls{align-items:flex-start}
  .gallery-filters{justify-content:flex-start}
  .nav-right{gap:16px}
  .nav-links{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(245,237,224,.97);flex-direction:column;align-items:center;justify-content:center;gap:32px}
  .nav-links.open{display:flex}
  .nav-toggle{display:block}
  footer{flex-direction:column;gap:16px;text-align:center}
  .modal-layout{flex-direction:column;overflow-y:auto}
  .modal-sidebar{width:100%}
}
@media(max-width:600px){.shop-grid{grid-template-columns:1fr}.about-stats{gap:20px}.newsletter-form{flex-direction:column}.newsletter-input{border-right:1px solid rgba(184,115,51,.2)}}

/* ============================================================
   GALERIE PAR THÈMES
   ============================================================ */
.gallery-themes-view { }
.gallery-header-simple { margin-bottom: 50px; }
.gallery-intro { color: var(--creme-sombre); font-size: .85rem; line-height: 1.8; margin-top: -20px; opacity: .7; }

/* Grille de tuiles thèmes */
.themes-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.theme-tile {
  position: relative;
  aspect-ratio: 4/3;
  overflow: hidden;
  cursor: pointer;
  border: 1px solid rgba(184,115,51,.08);
  transition: border-color .3s, transform .4s;
}
.theme-tile:hover {
  border-color: rgba(184,115,51,.4);
  transform: translateY(-4px);
}
.theme-cover {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  filter: brightness(.45) sepia(.2);
  transition: filter .5s, transform .5s;
}
.theme-tile:hover .theme-cover {
  filter: brightness(.3) sepia(.3);
  transform: scale(1.06);
}
.theme-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 24px;
  text-align: center;
  background: linear-gradient(to top, rgba(10,9,6,.7) 0%, rgba(10,9,6,.1) 100%);
  transition: background .3s;
}
.theme-tile:hover .theme-overlay {
  background: linear-gradient(to top, rgba(10,9,6,.85) 0%, rgba(10,9,6,.3) 100%);
}
.theme-emoji {
  font-size: 2rem;
  margin-bottom: 10px;
  filter: drop-shadow(0 0 12px rgba(184,115,51,.6));
  transition: transform .3s;
}
.theme-tile:hover .theme-emoji { transform: scale(1.2); }
.theme-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.5rem;
  font-style: italic;
  color: var(--creme);
  margin-bottom: 6px;
  text-shadow: 0 2px 12px rgba(0,0,0,.8);
}
.theme-desc {
  font-size: .6rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--or);
  opacity: .8;
  margin-bottom: 10px;
}
.theme-count {
  font-size: .6rem;
  letter-spacing: .25em;
  color: var(--creme-sombre);
  opacity: .6;
  border: 1px solid rgba(184,115,51,.2);
  padding: 4px 12px;
  transition: opacity .3s, border-color .3s;
}
.theme-tile:hover .theme-count {
  opacity: 1;
  border-color: rgba(184,115,51,.5);
}

/* Vue œuvres — après clic sur tuile */
.gallery-works-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 40px;
  flex-wrap: wrap;
  gap: 16px;
}
@keyframes blink-arrow{0%,100%{opacity:1;transform:translateX(0)}50%{opacity:.2;transform:translateX(-6px)}}
.back-btn{background:none;border:2px solid #1a1a1a;color:#1a1a1a;font-family:'Josefin Sans',sans-serif;font-size:.8rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;padding:12px 24px;cursor:pointer;transition:background .3s,border-color .3s;display:inline-flex;align-items:center;gap:10px;border-radius:0}
.back-btn::before{content:'←';font-size:1.1rem;font-weight:900;animation:blink-arrow 1s ease-in-out infinite;display:inline-block}
.back-btn:hover{background:rgba(26,26,26,.06);border-color:#000}
.back-btn:hover { background: rgba(184,115,51,.08); border-color: var(--or); }
.works-count {
  font-size: .6rem;
  letter-spacing: .3em;
  color: var(--gris-chaud);
  text-transform: uppercase;
  opacity: .6;
}

/* Grille masonnique des œuvres (inchangée) */
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.gallery-item {
  position: relative;
  overflow: hidden;
  background: var(--brun-sombre);
  border: 1px solid rgba(184,115,51,.05);
  cursor: pointer;
  aspect-ratio: 1;
  transition: border-color .3s;
}
.gallery-item img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .5s, filter .4s;
  filter: brightness(.88);
}
.gallery-item:hover { border-color: rgba(184,115,51,.3); }
.gallery-item:hover img { transform: scale(1.06); filter: brightness(1.02); }
.gallery-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(245,237,224,.95), transparent 60%);
  opacity: 0;
  transition: opacity .4s;
  display: flex;
  align-items: flex-end;
  padding: 16px;
}
.gallery-item:hover .gallery-overlay { opacity: 1; }
.gallery-name { font-family: 'Cormorant Garamond', serif; font-size: .95rem; color: var(--creme); font-style: italic; }
.gallery-ref { font-size: .52rem; letter-spacing: .2em; color: rgba(184,115,51,.5); margin-top: 2px; }
.gallery-cat { font-size: .52rem; letter-spacing: .25em; text-transform: uppercase; color: var(--or); margin-top: 2px; }

/* Responsive tuiles */
@media(max-width:900px){
  .themes-grid { grid-template-columns: repeat(2,1fr); }
  .gallery-grid { grid-template-columns: repeat(3,1fr); }
}
@media(max-width:600px){
  .themes-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
  .gallery-grid { grid-template-columns: repeat(2,1fr); }
  .theme-name { font-size: 1.1rem; }
}

/* Fix tuiles galerie */
.gallery-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 16px; }
.theme-tile { position: relative; overflow: hidden; border-radius: 8px; cursor: pointer; aspect-ratio: 4/3; }
.theme-tile img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .4s; }
.theme-tile:hover img { transform: scale(1.05); }
.tile-overlay { position: absolute; inset: 0; background: linear-gradient(to top, #000a 60%, transparent); display: flex; flex-direction: column; justify-content: flex-end; padding: 16px; }
.tile-emoji { font-size: 1.5rem; }
.tile-name { color: #fff; font-size: 1rem; font-weight: 600; margin: 4px 0 2px; }
.tile-count { color: #c8860a; font-size: .82rem; }
