/* ============================================================
   style.css v3 — TOMHP Jazz Quartet
   ============================================================ */
/* NOTE: Google Fonts loaded via PHP head for dynamic fonts */

/* ── Design Tokens ──────────────────────────────────────────── */
:root {
  --gold:          #c9a84c;
  --gold-light:    #e8c97a;
  --gold-dim:      rgba(201,168,76,.12);
  --dark:          #0a0804;
  --dark2:         #111009;
  --dark3:         #1a1710;
  --dark4:         #222018;
  --cream:         #f0e8d5;
  --cream-dim:     rgba(240,232,213,.78);
  --warm-gray:     #8c8070;
  --font-title:    'Playfair Display', Georgia, serif;
  --font-display:  'Bebas Neue', sans-serif;
  --font-body:     'DM Sans', system-ui, sans-serif;
  --font-accent:   'Cormorant Garamond', Georgia, serif;
  --fs-body:       16px;
  --fs-title:      clamp(1.9rem, 4vw, 3rem);
  --fw-body:       400;
  --radius:        4px;
  --radius-lg:     10px;
  --transition:    0.26s ease;
  --shadow-gold:   0 4px 40px rgba(201,168,76,.18);
  --nav-height:    68px;
  --container-max: 1160px;
  --site-bg-color: var(--dark);
  --site-bg-image: none;
  --site-bg-repeat:no-repeat;
  --site-bg-size:  cover;
  --site-bg-pos:   center center;
  --site-bg-attach:scroll;
}

/* ── Reset ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:calc(var(--p, 16) * 1px); -webkit-text-size-adjust:100%; }
body {
  background-color:var(--site-bg-color); color:var(--cream);
  background-image:var(--site-bg-image);
  background-repeat:var(--site-bg-repeat);
  background-size:var(--site-bg-size);
  background-position:var(--site-bg-pos);
  background-attachment:var(--site-bg-attach);
  font-family:var(--font-body); font-weight:var(--fw-body);
  font-size:1rem; line-height:1.65; overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img,video { display:block; max-width:100%; height:auto; }
a { color:inherit; text-decoration:none; }
button { font-family:inherit; cursor:pointer; border:none; background:none; }
ul { list-style:none; }
input,textarea,select { font-family:inherit; }

/* ── Layout ── */
.container { max-width:var(--container-max); margin:0 auto; padding:0 clamp(1rem,4vw,2.5rem); width:100%; }
.section { padding:clamp(4rem,8vw,7rem) 0; box-shadow:var(--section-shadow, none); font-family:var(--font-body); font-weight:var(--fw-body); font-size:calc(var(--p, 16) * 1px); }
.section-dark   { background:var(--section-bg, var(--dark)); }
.section-dark2  { background:var(--section-bg2, var(--dark2)); }
.section-dark3  { background:var(--section-bg3, var(--dark3)); }

h1, h2, h3, h4, h5, h6 { font-family:var(--font-title); font-weight:700; color:var(--cream); line-height:1.15; }
h1 { font-size:clamp(calc(var(--h1, 96) * 0.55px), 10vw, calc(var(--h1, 96) * 1px)); }
h2 { font-size:clamp(calc(var(--h2, 42) * 0.62px), 6vw, calc(var(--h2, 42) * 1px)); }
h3 { font-size:clamp(calc(var(--h3, 32) * 0.72px), 4.2vw, calc(var(--h3, 32) * 1px)); }
h4 { font-size:clamp(calc(var(--h4, 24) * 0.78px), 3.2vw, calc(var(--h4, 24) * 1px)); }
h5 { font-size:clamp(calc(var(--h5, 18) * 0.85px), 2.6vw, calc(var(--h5, 18) * 1px)); }
h6 { font-size:clamp(calc(var(--h6, 14) * 0.9px), 2.2vw, calc(var(--h6, 14) * 1px)); }
.section-contact{ background:linear-gradient(180deg,var(--dark2),var(--dark)); }
.divider { width:100%; height:1px; background:linear-gradient(90deg,transparent,rgba(201,168,76,.2),transparent); }
.mb-3 { margin-bottom:1.5rem; }

/* ── Typography ── */
.section-label {
  font-family:var(--font-accent); font-style:italic; color:var(--gold);
  font-size:clamp(.72rem,1.4vw,.88rem); letter-spacing:.35em; text-transform:uppercase;
  margin-bottom:.8rem; display:block;
}
.section-title {
  font-family:var(--font-title); font-size:var(--section-title-size, var(--fs-title));
  font-weight:700; line-height:1.15; margin-bottom:1.6rem; color:var(--cream);
}
.section-title em { font-style:italic; color:var(--gold); }
.gold-line { width:56px; height:2px; background:linear-gradient(90deg,var(--gold),transparent); margin-bottom:2.5rem; }
.body-text { font-size:var(--section-body-size, clamp(1rem,1.5vw,1.1rem)); line-height:1.85; color:var(--cream-dim); margin-bottom:1.4rem; }

/* ── Buttons ── */
.btn-outline {
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.78rem 2.1rem; border:1px solid var(--gold); color:var(--gold);
  font-family:var(--font-body); font-size:.85rem; font-weight:500;
  letter-spacing:.12em; text-transform:uppercase; border-radius:var(--radius);
  transition:background var(--transition),color var(--transition);
}
.btn-outline:hover { background:var(--gold); color:var(--dark); }
.btn-gold {
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.78rem 2.1rem; background:var(--gold); color:var(--dark);
  font-family:var(--font-body); font-size:.85rem; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase; border-radius:var(--radius);
  transition:background var(--transition),transform .15s;
}
.btn-gold:hover { background:var(--gold-light); transform:translateY(-2px); }

/* ── Animations ── */
@keyframes fadeUp { from{opacity:0;transform:translateY(26px)} to{opacity:1;transform:translateY(0)} }
@keyframes heroZoom { from{transform:scale(1.04)} to{transform:scale(1.1)} }
@keyframes scrollPulse { 0%,100%{opacity:1;transform:scaleY(1)} 50%{opacity:.3;transform:scaleY(.6)} }
@keyframes spin { to{transform:rotate(360deg)} }
@keyframes barBounce { 0%,100%{transform:scaleY(.5)} 50%{transform:scaleY(1)} }
.reveal { opacity:0; transform:translateY(22px); transition:opacity .6s ease,transform .6s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }
.animate-fadeup { animation:fadeUp .85s ease both; }

/* ════ NAVIGATION ════ */
#navbar {
  position:fixed; inset:0 0 auto 0; z-index:900;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 clamp(1.2rem,4vw,3rem); height:var(--nav-height);
  transition:background var(--transition),box-shadow var(--transition),height var(--transition);
}
#navbar.scrolled {
  background:rgba(10,8,4,.97); height:58px;
  box-shadow:0 1px 30px rgba(0,0,0,.6);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
}
.nav-logo img { height:var(--logo-size); filter:brightness(1.15); }
.nav-links { display:flex; align-items:center; gap:clamp(1.2rem,2.2vw,2rem); }
.nav-links a {
  font-family:var(--font-body); font-size:clamp(.72rem,1.1vw,.8rem);
  font-weight:500; letter-spacing:.18em; text-transform:uppercase;
  color:rgba(240,232,213,.82); position:relative;
  transition:color var(--transition); padding:.3rem 0; white-space:nowrap;
}
.nav-links a::after {
  content:''; position:absolute; bottom:-2px; left:0; right:100%;
  height:1px; background:var(--gold); transition:right var(--transition);
}
.nav-links a:hover { color:var(--cream); }
.nav-links a:hover::after,.nav-links a.active::after { right:0; }
.nav-links a.active { color:var(--gold); }
.nav-burger {
  display:none; flex-direction:column; justify-content:center; gap:5px;
  width:40px; height:40px; padding:8px; border-radius:var(--radius);
  transition:background var(--transition);
}
.nav-burger:hover { background:rgba(255,255,255,.06); }
.nav-burger span { display:block; height:2px; background:var(--cream); border-radius:2px; transition:transform .3s,opacity .3s,width .3s; }
.nav-burger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.nav-burger.open span:nth-child(2) { opacity:0; width:0; }
.nav-burger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* ════ HERO ════ */
.hero {
  position:relative; height:100svh; min-height:560px;
  display:flex; align-items:center; justify-content:center; overflow:hidden;
}
.hero-bg {
  position:absolute; inset:0; background-size:cover; background-position:center 30%;
  filter:brightness(.38) blur(var(--hp-bg-blur, 0px)) saturate(var(--hp-bg-sat, 1));
  transition:filter calc(var(--hp-trans-ms, 320) * 1ms) ease;
  transform:scale(1.04);
  animation:heroZoom 22s ease-in-out infinite alternate; will-change:transform;
}
.hero-overlay {
  position:absolute; inset:0;
  background:linear-gradient(180deg,rgba(10,8,4,.18) 0%,rgba(10,8,4,.04) 30%,rgba(10,8,4,.6) 72%,rgba(10,8,4,1) 100%);
}
.hero-player-tint{
  position:absolute;
  inset:0;
  z-index:1;
  opacity:0;
  pointer-events:none;
  background:rgba(var(--hp-tint-rgb, 201,168,76), var(--hp-tint-opacity, .22));
  filter:saturate(var(--hp-tint-sat, 1.15)) hue-rotate(var(--hp-tint-hue, 0deg));
  mix-blend-mode:soft-light;
  transition:opacity calc(var(--hp-trans-ms, 320) * 1ms) ease;
}
.hero[data-home-player-active="1"] .hero-player-tint{ opacity:1; }
.hero-content {
  position:relative; z-index:2; text-align:center;
  padding:0 clamp(1.2rem,5vw,3rem); max-width:860px; width:100%;
}
.hero-sub {
  font-family:var(--font-accent); font-style:italic; font-size:clamp(.88rem,1.5vw,1.05rem);
  letter-spacing:.38em; color:var(--gold); margin-bottom:.9rem;
  animation:fadeUp .9s .18s ease both;
}
.hero-title {
  font-family:var(--font-display);
  font-size:clamp(calc(var(--h1, 96) * 0.55px), 12vw, calc(var(--h1, 96) * 1px));
  line-height:.9; letter-spacing:.04em; color:var(--cream);
  text-shadow:0 0 80px rgba(201,168,76,.22);
  animation:fadeUp .9s .32s ease both;
}
.hero-tagline {
  font-family:var(--font-body); font-size:clamp(.72rem,1.2vw,.88rem);
  letter-spacing:.38em; text-transform:uppercase; color:var(--warm-gray); margin-top:1.4rem;
  animation:fadeUp .9s .48s ease both;
}
.hero-cta {
  display:inline-flex; align-items:center; gap:.6rem; margin-top:2.4rem;
  padding:.82rem 2.3rem; border:1px solid rgba(201,168,76,.55); color:var(--gold);
  font-family:var(--font-body); font-size:.83rem; font-weight:500; letter-spacing:.18em; text-transform:uppercase;
  border-radius:var(--radius); transition:background .3s,border-color .3s;
  animation:fadeUp .9s .62s ease both;
}
.hero-cta:hover { background:rgba(201,168,76,.12); border-color:var(--gold); }
.scroll-hint {
  position:absolute; bottom:2rem; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:.6rem;
  color:var(--warm-gray); font-family:var(--font-body); font-size:.66rem;
  letter-spacing:.3em; text-transform:uppercase; animation:fadeUp 1.2s 1s ease both;
}
.scroll-line { width:1px; height:48px; background:linear-gradient(to bottom,var(--gold),transparent); animation:scrollPulse 2.4s ease-in-out infinite; }

.hero-player-btn{
  position:absolute; z-index:3;
  right:clamp(.9rem, 3vw, 1.6rem);
  bottom:clamp(1.2rem, 4vw, 1.9rem);
  display:inline-flex; align-items:center; gap:.6rem;
  padding:.66rem .95rem;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(15, 14, 10, .28);
  color:rgba(240,232,213,.92);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  cursor:pointer;
  transition:transform calc(var(--hp-trans-ms, 320) * 1ms) ease, background calc(var(--hp-trans-ms, 320) * 1ms) ease, border-color calc(var(--hp-trans-ms, 320) * 1ms) ease, color calc(var(--hp-trans-ms, 320) * 1ms) ease, opacity calc(var(--hp-trans-ms, 320) * 1ms) ease;
}
.hero-player-btn:hover{
  transform:translateY(-2px);
  background:rgba(15, 14, 10, .36);
  border-color:rgba(201,168,76,.32);
  color:#fff;
}
.hero-player-btn:active{ transform:translateY(0) scale(.98); }
.hero-player-btn:focus-visible{ outline:2px solid rgba(201,168,76,.85); outline-offset:3px; }
.hero-player-btn-icon{
  width:34px; height:34px; border-radius:999px;
  display:flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg, rgba(201,168,76,.95), rgba(201,168,76,.55));
  color:rgba(10,8,4,.96);
  box-shadow:0 10px 30px rgba(0,0,0,.26);
}
.hero-player-btn[data-active="1"] .hero-player-btn-icon{
  background:linear-gradient(135deg, rgba(255,255,255,.92), rgba(201,168,76,.72));
}
.hero-player-btn-text{
  font-family:var(--font-body);
  font-size:.78rem;
  letter-spacing:.16em;
  text-transform:uppercase;
}

.hero-player-v2{
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  padding:clamp(1rem, 4vw, 2rem);
  opacity:0; transform:translateY(14px);
  pointer-events:none;
  transition:opacity calc(var(--hp-trans-ms, 320) * 1ms) ease, transform calc(var(--hp-trans-ms, 320) * 1ms) ease;
  z-index:3;
}
.hero[data-home-player-active="1"] .hero-player-v2{
  opacity:1; transform:translateY(0);
  pointer-events:auto;
}
.hero[data-home-player-active="1"]{
  height:100svh;
  min-height:100svh;
  overflow:hidden;
  flex-direction:column;
  align-items:flex-start;
  justify-content:flex-start;
  padding-top:calc(var(--hp-nav-h, 72px) + 14px);
  padding-bottom:calc(16px + env(safe-area-inset-bottom, 0px));
}
.hero[data-home-player-active="1"] .hero-content{ display:none; }
.hero[data-home-player-active="1"] .hero-player-v2{
  position:relative;
  inset:auto;
  padding:0 clamp(1rem, 4vw, 2rem);
  flex:1 1 auto;
  min-height:0;
  width:100%;
  align-items:stretch;
  justify-content:center;
}
.hero[data-home-player-active="1"] .hero-player-v2 .hp2{
  height:100%;
  min-height:0;
  grid-template-rows:1fr auto;
  align-content:stretch;
}
.hero[data-home-player-active="1"] .hero-player-v2 .hp2-art{ align-self:center; }
.hero[data-home-player-active="1"] .hero-player-v2 .hp2-card{ align-self:end; }
.hero[data-home-player-active="1"] .hero-content{
  opacity:0; transform:translateY(-10px) scale(.985);
  transition:opacity calc(var(--hp-trans-ms, 320) * 1ms) ease, transform calc(var(--hp-trans-ms, 320) * 1ms) ease;
  pointer-events:none;
}
.hero[data-home-player-active="1"] .hero-content,
.hero[data-home-player-active="1"] .hero-sub,
.hero[data-home-player-active="1"] .hero-title,
.hero[data-home-player-active="1"] .hero-tagline{
  animation:none !important;
}
.hero[data-home-player-active="1"] .hero-player-btn{
  opacity:0;
  transform:translateY(6px);
  pointer-events:none;
}

@media (max-width:560px){
  .hero-player-btn{ left:50%; right:auto; transform:translateX(-50%); bottom:1.2rem; }
  .hero-player-btn:hover{ transform:translateX(-50%) translateY(-2px); }
  .hero-player-btn:active{ transform:translateX(-50%) scale(.98); }
  .hero:not([data-home-player-active="1"]) .hero-player-v2{ align-items:flex-end; }
}

@media (min-width:900px){
  .hero-player-v2{
    align-items:stretch;
    padding-top:calc(var(--hp-nav-h, 72px) + 18px);
    padding-bottom:24px;
  }
}

@media (prefers-reduced-motion: reduce){
  .hero-player-btn,
  .hero-player-v2,
  .hero-player-tint,
  .hero-bg,
  .hero[data-home-player-active="1"] .hero-content{
    transition:none;
  }
}

/* ════ LAYOUT ════ */
.two-col { display:grid; grid-template-columns:1fr 1fr; gap:clamp(2.5rem,5vw,5rem); align-items:center; }
.frame-img { position:relative; border-radius:var(--radius); overflow:hidden; }
.frame-img::before { content:''; position:absolute; inset:-10px; border:1px solid rgba(201,168,76,.2); border-radius:var(--radius); pointer-events:none; z-index:1; }
.frame-img img { width:100%; border-radius:var(--radius); filter:brightness(.86); transition:filter .5s,transform .5s; }
.frame-img:hover img { filter:brightness(1); transform:scale(1.02); }

body.light-mode #navbar { background:transparent; }
body.light-mode #navbar.scrolled {
  background:rgba(10,8,4,.88);
  box-shadow:0 1px 30px rgba(0,0,0,.4);
}
body.light-mode .nav-links a { color:rgba(240,232,213,.84); }
body.light-mode .nav-links a:hover { color:#ffffff; }
body.light-mode .nav-links a.active { color:var(--gold); }
body.light-mode .nav-burger:hover { background:rgba(255,255,255,.06); }
body.light-mode .nav-burger span { background:rgba(240,232,213,.92); }
body.light-mode .hero-tagline { color:rgba(240,232,213,.72); }
body.light-mode .hero-bg { filter:brightness(.38) blur(var(--hp-bg-blur, 0px)) saturate(var(--hp-bg-sat, 1)); }
body.light-mode .hero-overlay { background:linear-gradient(180deg,rgba(10,8,4,.18) 0%,rgba(10,8,4,.04) 30%,rgba(10,8,4,.6) 72%,rgba(10,8,4,1) 100%); }

body.light-mode .section-label { color:var(--gold-contrast); }
body.light-mode .gold-line { background:linear-gradient(90deg,var(--gold-contrast),transparent); }
body.light-mode .event-day { color:var(--gold-contrast); }
body.light-mode .event-artist { color:var(--gold-contrast); }
body.light-mode .event-prix { color:var(--gold-contrast); }
body.light-mode .membre-instrument { color:var(--gold-contrast); }
body.light-mode .avis-stars { color:var(--gold-contrast); }
body.light-mode .avis-author { color:var(--gold-contrast); }
body.light-mode .contact-email { color:var(--gold-contrast); border-bottom-color:rgba(122,90,16,.35); }

body.light-mode { --card-shadow: 0 14px 50px rgba(0,0,0,.08); }
body.light-mode .membre-card,
body.light-mode .event-card,
body.light-mode .avis-card { box-shadow:var(--card-shadow); }
body.light-mode .event-card { background:var(--card-bg, rgba(0,0,0,.02)); border-color:var(--card-border, rgba(0,0,0,.10)); }
body.light-mode .membre-card { background:var(--card-bg, rgba(0,0,0,.02)); border-color:var(--card-border, rgba(0,0,0,.10)); }
body.light-mode .avis-card { background:var(--card-bg, rgba(0,0,0,.02)); border-color:var(--card-border, rgba(0,0,0,.10)); }

body.light-mode .btn-outline { color:var(--gold-contrast); border-color:var(--gold-contrast); }
body.light-mode .btn-outline:hover { background:var(--gold-contrast); color:#ffffff; }
body.light-mode .btn-gold { color:#111111; }
body.light-mode .btn-gold:hover { filter:brightness(.98); transform:translateY(-2px); }

body.light-mode .events-filter-btn { border-color:rgba(0,0,0,.12); color:rgba(17,17,17,.72); }
body.light-mode .events-filter-btn:hover { border-color:var(--gold-contrast); color:#111111; }
body.light-mode .events-filter-btn.active { background:var(--gold-contrast); border-color:var(--gold-contrast); color:#ffffff; }
body.light-mode .events-viewall { background:rgba(122,90,16,.10); border-color:rgba(122,90,16,.35); color:var(--gold-contrast); }
body.light-mode .events-viewall:hover { background:rgba(122,90,16,.14); border-color:var(--gold-contrast); }

body.light-mode .events-browser-panel { background:#ffffff; }
body.light-mode .events-browser-top { background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.84) 60%, rgba(255,255,255,0)); }
body.light-mode .events-browser-title { color:#111111; }
body.light-mode .events-searchbox { background:rgba(0,0,0,.03); border:1px solid rgba(0,0,0,.10); }
body.light-mode .events-searchbox:focus-within { box-shadow:0 0 0 3px rgba(122,90,16,.22); background:rgba(0,0,0,.04); }
body.light-mode .events-search-icon { color:rgba(0,0,0,.45); }
body.light-mode .events-search { color:#111111; }
body.light-mode .events-browser-close,
body.light-mode .events-browser-back { color:rgba(17,17,17,.82); background:rgba(255,255,255,.86); border:1px solid rgba(0,0,0,.10); }

body.light-mode .divider { background:linear-gradient(90deg,transparent,rgba(201,168,76,.2),transparent); }
body.light-mode .site-footer { background:#0a0804; border-top:1px solid rgba(201,168,76,.12); }
body.light-mode .footer-nav a { color:rgba(240,232,213,.72); }
body.light-mode .footer-nav a:hover { color:rgba(240,232,213,.92); }
body.light-mode .footer-copy p { color:rgba(240,232,213,.62); }

.event-card:focus-visible,
.membre-card:focus-visible,
.avis-card:focus-visible,
.events-viewall:focus-visible,
.events-filter-btn:focus-visible,
.btn-outline:focus-visible,
.btn-gold:focus-visible {
  outline:2px solid var(--gold-contrast, var(--gold));
  outline-offset:3px;
}

/* ════ MEMBRES ════ */
.membres-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:1.5rem; margin-top:2rem; }
.membre-card {
  background:var(--card-bg, rgba(255,255,255,.025)); border:1px solid var(--card-border, rgba(201,168,76,.1));
  border-radius:var(--radius-lg); padding:1.8rem; position:relative; overflow:hidden;
  transition:border-color .28s,background .28s,transform .22s;
}
.membre-card::before { content:''; position:absolute; top:0; left:0; width:3px; height:0; background:var(--gold); transition:height .38s; }
.membre-card:hover { border-color:rgba(201,168,76,.3); background:rgba(201,168,76,.05); transform:translateY(-3px); }
.membre-card:hover::before { height:100%; }
.membre-photo { width:70px; height:70px; border-radius:50%; overflow:hidden; margin-bottom:1rem; border:2px solid rgba(201,168,76,.28); background:var(--dark3); }
.membre-photo img { width:100%; height:100%; object-fit:cover; }
.membre-instrument { font-family:var(--font-accent); font-style:italic; color:var(--gold); font-size:.8rem; letter-spacing:.2em; margin-bottom:.3rem; }
.membre-name { font-family:var(--font-title); font-size:1.28rem; font-weight:700; margin-bottom:.8rem; }
.membre-bio { font-size:.95rem; line-height:1.75; color:var(--cream-dim); }

/* ════ EVENTS ════ */
.events-grid { display:grid; grid-template-columns:repeat(var(--events-cols, 3), minmax(0, 1fr)); gap:1.5rem; margin-top:2rem; }
.events-grid.is-masonry { grid-auto-rows:10px; grid-auto-flow:dense; }
.event-card {
  background:var(--card-bg, var(--dark3)); border:1px solid var(--card-border, rgba(201,168,76,.1));
  border-radius:var(--radius-lg); overflow:hidden; cursor:pointer;
  transition:transform .26s,border-color .26s,box-shadow .26s;
}
.event-card:hover { transform:translateY(-5px); border-color:rgba(201,168,76,.35); box-shadow:var(--shadow-gold); }
.event-img { position:relative; overflow:hidden; background:var(--dark2); }
.event-img.has-poster img { width:100%; height:auto; display:block; background:linear-gradient(135deg,var(--dark2),var(--dark3)); }
.event-badges { display:flex; flex-wrap:wrap; gap:.4rem; margin:0 0 .45rem; }
.event-card:hover .event-img img { transform:scale(1.05); }
.event-img-placeholder { width:100%; height:100%; display:flex; align-items:center; justify-content:center; background:linear-gradient(135deg,var(--dark2),var(--dark3)); }
.event-img-icon { font-size:2.6rem; opacity:.35; }
.event-badge { position:absolute; top:.75rem; left:.75rem; background:var(--gold); color:var(--dark); font-family:var(--font-body); font-size:.68rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; padding:.2rem .62rem; border-radius:3px; }
.event-badges .event-badge { position:static; }
.badge-complet { background:#ef4444; color:#fff; }
.event-body { display:flex; gap:.9rem; align-items:flex-start; padding:var(--card-padding, 1.1rem); }
.event-date { display:flex; flex-direction:column; align-items:center; min-width:44px; padding-top:.1rem; }
.event-day { font-family:var(--font-display); font-size:1.9rem; line-height:1; color:var(--gold); }
.event-month { font-family:var(--font-body); font-size:.66rem; letter-spacing:.12em; text-transform:uppercase; color:var(--warm-gray); }
.event-info { flex:1; min-width:0; }
.event-title { font-family:var(--font-title); font-size:.98rem; font-weight:700; margin-bottom:.35rem; line-height:1.3; }
.event-artist { font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); margin:0 0 .35rem; font-weight:700; }
.event-lieu { font-family:var(--font-body); font-size:.78rem; color:var(--warm-gray); display:flex; align-items:center; gap:.3rem; margin-bottom:.4rem; }
.event-desc { font-size:.86rem; color:var(--cream-dim); line-height:1.55; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
.event-prix { display:inline-block; margin-top:.5rem; font-size:.76rem; color:var(--gold); }
.event-arrow { color:var(--gold); opacity:.45; flex-shrink:0; align-self:center; transition:opacity .24s,transform .24s; }
.event-card:hover .event-arrow { opacity:1; transform:translateX(4px); }
.no-events { text-align:center; padding:4rem 2rem; color:var(--warm-gray); font-style:italic; }

/* ════ EVENTS FILTERS + BROWSER ════ */
.events-toolbar { display:flex; align-items:center; justify-content:space-between; gap:1rem; flex-wrap:wrap; margin-top:1.6rem; }
.events-filters { display:flex; gap:.5rem; flex-wrap:wrap; }
.events-filter-btn {
  padding:.45rem 1.1rem; border:1px solid rgba(201,168,76,.2); border-radius:999px;
  background:transparent; color:var(--warm-gray);
  font-family:var(--font-body); font-size:.78rem; font-weight:600; letter-spacing:.08em;
  cursor:pointer; transition:all .22s;
}
.events-filter-btn:hover { border-color:var(--gold); color:var(--cream); }
.events-filter-btn.active { background:var(--gold); border-color:var(--gold); color:var(--dark); }
.events-viewall {
  padding:.48rem 1.1rem; border-radius:999px;
  background:rgba(201,168,76,.12); border:1px solid rgba(201,168,76,.35);
  color:var(--gold); font-family:var(--font-body); font-size:.78rem; font-weight:700; letter-spacing:.08em;
  cursor:pointer; transition:background .2s,border-color .2s,transform .15s;
}
.events-viewall:hover { background:rgba(201,168,76,.18); border-color:var(--gold); transform:translateY(-1px); }

.events-browser { display:none; position:fixed; inset:0; z-index:1200; }
.events-browser.open { display:block; }
.events-browser-overlay { position:absolute; inset:0; background:rgba(0,0,0,.92); }
.events-browser-panel {
  position:relative; z-index:1;
  width:100%; height:100%;
  background:var(--dark);
  overflow:auto;
  padding:clamp(1.2rem,3vw,2rem);
}
.events-browser-top {
  position:sticky; top:0; z-index:3;
  padding-bottom:1rem;
  background:linear-gradient(180deg, rgba(10,8,4,.96), rgba(10,8,4,.84) 60%, rgba(10,8,4,0));
  backdrop-filter: blur(10px);
}
.events-browser-title { font-family:var(--font-title); font-size:clamp(1.4rem,3vw,2rem); margin-bottom:1rem; letter-spacing:.02em; text-align:center; }
.events-browser-close { position:fixed; top:1rem; right:1rem; z-index:20; color:rgba(240,232,213,.85); background:rgba(0,0,0,.35); border-radius:50%; padding:.55rem; cursor:pointer; border:none; }
.events-browser-back { position:fixed; top:1rem; left:1rem; z-index:20; color:rgba(240,232,213,.85); background:rgba(0,0,0,.35); border-radius:999px; padding:.6rem 1rem; font-family:var(--font-body); font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; cursor:pointer; border:none; }
.events-browser-bar { display:flex; align-items:center; justify-content:center; gap:.75rem; max-width:900px; margin:0 auto; }
.events-searchbox { flex:1; width:auto; }
.events-browser-bar #eventsFiltersToggle { flex:0 0 auto; }
.events-searchbox {
  flex:1;
  display:flex; align-items:center; gap:.7rem;
  padding:.72rem .95rem;
  border-radius:999px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.10);
  transition:border-color .2s, background .2s, box-shadow .2s;
}
.events-searchbox:focus-within { border-color:rgba(201,168,76,.35); box-shadow:0 0 0 3px rgba(201,168,76,.12); background:rgba(255,255,255,.06); }
.events-search-icon { color:rgba(240,232,213,.65); display:flex; align-items:center; }
.events-search {
  width:100%;
  border:none; outline:none;
  background:transparent;
  color:var(--cream);
  font-family:var(--font-body);
  font-size:.95rem;
}
.events-browser-actions { align-items:center; gap:.5rem; }
.events-ico-btn {
  position:relative;
  width:42px; height:42px;
  display:inline-flex; align-items:center; justify-content:center;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
  color:rgba(240,232,213,.82);
  cursor:pointer;
  transition:transform .15s, background .2s, border-color .2s, color .2s;
}
.events-filter-reset {
  height:38px;
  padding:0 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
  color:rgba(240,232,213,.85);
  font-family:var(--font-body);
  font-size:.72rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  cursor:pointer;
  transition:background .2s, border-color .2s, transform .15s;
}
.events-filter-reset:hover { background:rgba(255,255,255,.06); border-color:rgba(201,168,76,.28); transform:translateY(-1px); }
.events-ico-btn:hover { background:rgba(255,255,255,.06); border-color:rgba(201,168,76,.28); color:var(--cream); transform:translateY(-1px); }
.events-ico-btn:focus-visible { outline:3px solid rgba(201,168,76,.25); outline-offset:2px; }
.events-ico-btn-sm { width:38px; height:38px; }
.events-ico-btn[aria-expanded="true"] { background:rgba(201,168,76,.10); border-color:rgba(201,168,76,.35); color:var(--gold); }
.events-ico-badge {
  position:absolute; top:-6px; right:-6px;
  min-width:18px; height:18px;
  padding:0 5px;
  border-radius:999px;
  background:var(--gold);
  color:var(--dark);
  font-size:.68rem;
  font-weight:800;
  display:inline-flex; align-items:center; justify-content:center;
}
.events-filters-panel {
  max-width: 900px;
  margin: 1rem auto 0;
  background: rgba(10,8,4,.94);
  border: 1px solid rgba(201,168,76,.16);
  border-radius: var(--radius-lg);
  box-shadow: 0 18px 60px rgba(0,0,0,.65);
  max-height: 0;
  opacity: 0;
  transform: translateY(-6px);
  overflow: hidden;
  transition: max-height .35s ease, opacity .25s ease, transform .25s ease, padding .25s ease;
  padding: 0 1.5rem;
}
.events-filters-panel.open {
  max-height: 800px;
  opacity: 1;
  transform: translateY(0);
  padding: 1.5rem;
}
.events-filters-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1.2rem;
  margin-bottom: 1.5rem;
}
.events-filters-actions {
  display: flex;
  justify-content: center;
  border-top: 1px solid rgba(255,255,255,.08);
  padding-top: 1.2rem;
}
.events-menu-field label { display:block; font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:rgba(240,232,213,.65); margin-bottom:.35rem; }
.events-menu-field input,.events-menu-field select {
  width:100%; padding:.62rem .75rem; border-radius:var(--radius);
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);
  color:var(--cream);
  font-family:var(--font-body); font-size:.9rem;
}
.events-browser-grid { display:grid; grid-template-columns:repeat(var(--events-cols, 5), minmax(0, 1fr)); gap:1.2rem; }
.events-browser-grid.is-masonry { grid-auto-rows:10px; grid-auto-flow:dense; }
.events-browser-empty { text-align:center; padding:2rem; color:var(--warm-gray); font-style:italic; }
.events-browser-sentinel { height:1px; }
.events-browser-grid .event-card { background:var(--card-bg, rgba(255,255,255,.02)); border:1px solid var(--card-border, rgba(255,255,255,.08)); }
.events-browser-grid .event-card:hover { transform:translateY(-4px); border-color:rgba(201,168,76,.4); box-shadow:0 18px 55px rgba(0,0,0,.55); }
.events-browser-grid .event-body { padding:1rem; }
.events-browser-grid .event-desc { display:none; }
.events-browser-grid .event-date { min-width:42px; }
.events-browser-grid .event-day { font-size:1.75rem; }
.events-browser-grid .event-title { font-size:1.02rem; }
.events-browser-grid .event-lieu { font-size:.8rem; }
.events-browser-grid .event-card-compact .event-arrow { display:none; }
.events-browser-grid .event-card-compact .event-body { gap:.68rem; padding:.9rem; }
.events-browser-grid .event-card-compact .event-date { min-width:38px; }
.events-browser-grid .event-card-compact .event-day { font-size:1.48rem; }
.events-browser-grid .event-card-compact .event-month { font-size:.6rem; }
.events-browser-grid .event-card-compact .event-title { font-size:.9rem; margin-bottom:.25rem; }
.events-browser-grid .event-card-compact .event-artist { font-size:.62rem; margin-bottom:.24rem; }
.events-browser-grid .event-card-compact .event-lieu { font-size:.73rem; margin-bottom:.25rem; }
.events-browser-grid .event-card-compact .event-prix { margin-top:.35rem; font-size:.7rem; }

/* Pixel Perfect cible 1366px */
@media (max-width:1366px) {
  .events-grid { gap:1.35rem; }
  .events-browser-grid { gap:1rem; }
  .event-body { padding:1rem; gap:.8rem; }
  .event-title { font-size:.94rem; }
  .event-desc { font-size:.83rem; }
}

@media (max-width:1024px) {
  .events-filters-grid { grid-template-columns:repeat(2, minmax(0, 1fr)); }
  .events-grid { grid-template-columns:repeat(2, minmax(0, 1fr)); }
  .events-browser-grid { grid-template-columns:repeat(2, minmax(0, 1fr)); }
  .events-grid { gap:1.12rem; }
  .events-browser-grid { gap:.92rem; }
  .events-toolbar { gap:.8rem; }
  .events-viewall { padding:.44rem .9rem; font-size:.74rem; }
  .event-body { padding:.92rem; }
  .event-title { font-size:.9rem; }
  .event-lieu { font-size:.74rem; }
}
@media (max-width:640px) {
  .events-browser-back { left:.8rem; top:.8rem; }
  .events-browser-close { right:.8rem; top:.8rem; }
  .events-browser-panel { padding:1rem; }
  .events-browser-title { margin-bottom:.8rem; }
  .events-filters-panel { padding:0 1rem; }
  .events-filters-panel.open { padding:1rem; }
  .events-filters-grid { grid-template-columns:1fr; }
  .events-ico-btn { width:40px; height:40px; }
  .events-searchbox { padding:.65rem .85rem; }
  .events-browser-bar { flex-direction:column; }
  .events-searchbox { width:100%; }
}

/* ════ GALERIE ════ */
.gallery-filters { display:flex; align-items:center; gap:.6rem; flex-wrap:wrap; margin-bottom:1.6rem; }
.gallery-filter-btn {
  padding:.4rem 1.1rem; border:1px solid rgba(201,168,76,.2); border-radius:20px;
  color:var(--warm-gray); font-family:var(--font-body); font-size:.78rem; font-weight:500;
  cursor:pointer; transition:all .22s; background:transparent;
}
.gallery-filter-btn:hover { border-color:var(--gold); color:var(--cream); }
.gallery-filter-btn.active { background:var(--gold); border-color:var(--gold); color:var(--dark); }
.gallery-masonry { display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:205px; gap:5px; }
.gallery-item { position:relative; overflow:hidden; cursor:pointer; border-radius:var(--radius); background:var(--dark3); }
.gallery-item:nth-child(5n+1) { grid-row:span 2; }
.gallery-item.hidden { display:none; }
.gallery-item img,.gallery-item video { width:100%; height:100%; object-fit:cover; transition:transform .5s,filter .32s; filter:brightness(.78) saturate(.85); }
.gallery-item:hover img,.gallery-item:hover video { transform:scale(1.07); filter:brightness(1) saturate(1.05); }
.gallery-overlay { position:absolute; inset:0; background:rgba(10,8,4,.42); display:flex; align-items:center; justify-content:center; opacity:0; transition:opacity .28s; color:var(--cream); }
.gallery-item:hover .gallery-overlay { opacity:1; }

body.light-mode .gallery-item img,
body.light-mode .gallery-item video { filter:brightness(.72) saturate(.86) contrast(1.04); }
body.light-mode .gallery-item:hover img,
body.light-mode .gallery-item:hover video { filter:brightness(.86) saturate(.95) contrast(1.06); }
body.light-mode .gallery-overlay {
  background:linear-gradient(180deg,rgba(0,0,0,.18) 0%,rgba(0,0,0,.55) 70%,rgba(0,0,0,.68) 100%);
  color:#ffffff;
  text-shadow:0 2px 10px rgba(0,0,0,.62);
}
body.light-mode .gallery-item:focus-visible {
  outline:2px solid var(--gold-contrast, var(--gold));
  outline-offset:3px;
}
.video-badge { position:absolute; bottom:.55rem; left:.55rem; background:rgba(0,0,0,.72); color:var(--cream); font-family:var(--font-body); font-size:.66rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; padding:.18rem .52rem; border-radius:3px; display:flex; align-items:center; gap:.3rem; }
.video-badge svg { color:#ef4444; }
.video-thumb-placeholder { width:100%; height:100%; background:linear-gradient(135deg,#0d0c0a,#1c1812); display:flex; align-items:center; justify-content:center; }

/* ════ PRO ════ */
.pro-services { display:flex; flex-direction:column; gap:.85rem; margin:1.8rem 0; }
.pro-service { display:flex; align-items:flex-start; gap:1.1rem; padding:1.05rem 1.25rem; border-left:2px solid rgba(201,168,76,.2); background:rgba(201,168,76,.03); border-radius:0 var(--radius) var(--radius) 0; transition:border-color .26s,background .26s; }
.pro-service:hover { border-color:var(--gold); background:rgba(201,168,76,.07); }
.pro-icon { font-size:1.3rem; flex-shrink:0; margin-top:.1rem; }
.pro-service-title { font-family:var(--font-title); font-size:1rem; margin-bottom:.2rem; }
.pro-service-desc { font-size:.9rem; color:var(--cream-dim); line-height:1.55; }

/* ════ AVIS ════ */
.avis-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(275px,1fr)); gap:1.8rem; margin-top:2rem; }
.avis-card { background:var(--card-bg, transparent); border-top:1px solid var(--card-border, rgba(201,168,76,.2)); padding-top:1.8rem; border-radius:var(--radius-lg); padding:1.6rem; }
.avis-stars { color:var(--gold); letter-spacing:.18em; margin-bottom:.85rem; font-size:.88rem; }
.avis-text { font-family:var(--font-accent); font-size:1.1rem; line-height:1.75; font-style:italic; color:var(--cream-dim); margin-bottom:1.1rem; }
.avis-author { font-family:var(--font-body); font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); opacity:.85; }

/* ════ CONTACT ════ */
.contact-inner { max-width:640px; margin:0 auto; text-align:center; }
.contact-email { display:inline-block; margin-top:2rem; font-family:var(--font-display); font-size:clamp(1.3rem,3.5vw,1.75rem); letter-spacing:.1em; color:var(--gold); border-bottom:1px solid rgba(201,168,76,.38); padding-bottom:.2rem; transition:color .26s,border-color .26s; }
.contact-email:hover { color:var(--gold-light); border-color:var(--gold-light); }
.social-links { display:flex; justify-content:center; gap:1.4rem; margin-top:2rem; }
.social-links a { color:var(--warm-gray); transition:color .26s; }
.social-links a:hover { color:var(--gold); }

/* ════ FOOTER ════ */
.site-footer { background:var(--dark); border-top:1px solid rgba(201,168,76,.08); padding:2rem 0; }
.footer-inner { display:flex; align-items:center; justify-content:space-between; gap:2rem; flex-wrap:wrap; }
.footer-logo img { height:calc(var(--logo-size) * 0.7); opacity:.5; filter:grayscale(1); }
.footer-nav { display:flex; gap:1.3rem; flex-wrap:wrap; }
.footer-nav a { font-family:var(--font-body); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--warm-gray); transition:color .24s; }
.footer-nav a:hover { color:var(--gold); }
.footer-copy { text-align:right; }
.footer-copy p { font-size:.74rem; color:rgba(140,128,112,.65); line-height:1.65; }

/* ════ MODAL ════ */
.modal { display:none; position:fixed; inset:0; z-index:1300; align-items:center; justify-content:center; padding:1rem; }
.modal.open { display:flex; animation:fadeUp .28s ease; }
.modal-overlay { position:absolute; inset:0; background:rgba(0,0,0,.88); }
.modal-panel { position:relative; z-index:1; width:min(95vw,780px); max-height:90svh; overflow-y:auto; background:var(--dark3); border:1px solid rgba(201,168,76,.18); border-radius:var(--radius-lg); box-shadow:0 20px 80px rgba(0,0,0,.8); scrollbar-width:thin; scrollbar-color:var(--gold) transparent; }
.modal-close { position:absolute; top:1rem; right:1rem; z-index:2; color:var(--warm-gray); padding:.4rem; transition:color .2s,transform .2s; background:rgba(0,0,0,.3); border-radius:50%; }
.modal-close:hover { color:var(--cream); transform:rotate(90deg); }
.modal-content { display:block; }
.modal-content .modal-img img { width:100%; max-height:320px; object-fit:contain; border-radius:var(--radius-lg) var(--radius-lg) 0 0; background:var(--dark2); }
.modal-content.modal-has-poster { display:grid; grid-template-columns:minmax(240px, var(--poster-col, 44%)) 1fr; height:100%; }
.modal-content.modal-has-poster .modal-body { overflow:auto; }
.modal-poster { height:100%; background:var(--dark2); border-right:1px solid rgba(201,168,76,.12); overflow:hidden; display:flex; align-items:center; justify-content:center; }
.modal-poster img { width:100%; height:100%; object-fit:contain; display:block; padding:clamp(.75rem,1.8vw,1.2rem); }
.modal-content.poster-cover .modal-poster img { object-fit:cover; padding:0; }

#eventModal .modal-panel.has-poster { width:min(96vw, var(--modal-max-w, 1100px)); height:min(90svh, var(--modal-max-h, 760px)); max-height:none; overflow:hidden; }
.modal-body { padding:calc(var(--card-padding, 18px) + 10px); }
.modal-label { font-family:var(--font-accent); font-style:italic; color:var(--gold); font-size:.8rem; letter-spacing:.25em; text-transform:uppercase; }
.modal-title { font-family:var(--font-title); font-size:clamp(1.35rem,3.5vw,1.85rem); font-weight:700; margin:.6rem 0 1.4rem; }
.modal-meta { display:flex; flex-wrap:wrap; gap:.8rem 1.8rem; padding:1rem; background:rgba(0,0,0,.35); border-radius:var(--radius); margin-bottom:1.6rem; border:1px solid rgba(255,255,255,.06); }
.modal-meta-item { display:flex; align-items:center; gap:.45rem; font-size:.88rem; color:var(--warm-gray); }
.modal-meta-item svg { color:var(--gold); flex-shrink:0; }
.modal-meta-item strong { color:var(--cream); }
.modal-desc { font-size:1rem; line-height:1.85; color:var(--cream-dim); margin-bottom:2rem; }
.modal-actions { display:flex; gap:.85rem; flex-wrap:wrap; }

/* ════ LIGHTBOX ════ */
.lightbox { display:none; position:fixed; inset:0; z-index:1400; align-items:center; justify-content:center; flex-direction:column; gap:1rem; padding:1rem; }
.lightbox.open { display:flex; animation:fadeUp .26s ease; }
.lightbox-overlay { position:absolute; inset:0; background:rgba(0,0,0,.94); }
.lightbox img { position:relative; z-index:1; max-width:92vw; max-height:82svh; object-fit:contain; border-radius:var(--radius); }
.lightbox iframe { position:relative; z-index:1; width:min(92vw,900px); height:min(82svh,510px); border:none; border-radius:var(--radius); }
.lightbox-close { position:absolute; top:1.2rem; right:1.5rem; z-index:2; color:rgba(240,232,213,.7); transition:color .2s,transform .2s; background:rgba(0,0,0,.4); border-radius:50%; padding:.5rem; }
.lightbox-close:hover { color:var(--cream); transform:rotate(90deg); }
.lightbox-caption { position:relative; z-index:1; font-size:.84rem; color:var(--warm-gray); letter-spacing:.1em; text-align:center; }

/* ════ RESPONSIVE ════ */
@media (max-width:1024px) {
  .events-grid { grid-template-columns:repeat(2, minmax(0, 1fr)); }
  .events-browser-grid { grid-template-columns:repeat(2, minmax(0, 1fr)); }
  .gallery-masonry { grid-template-columns:repeat(3,1fr); }
}
@media (max-width:900px) {
  :root { --nav-height:56px; }
  .nav-burger { display:flex; z-index:10; }
  #navbar.menu-open { background:rgba(10,8,4,.97); box-shadow:0 1px 30px rgba(0,0,0,.6); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); }
  .nav-links {
    display:none;
    position:absolute;
    top:0; left:0; right:0;
    height:100vh;
    height:100dvh;
    padding:calc(var(--nav-height) + 1.5rem) 1.25rem max(2rem, env(safe-area-inset-bottom));
    background:rgba(10,8,4,.97);
    flex-direction:column;
    align-items:center;
    justify-content:flex-start;
    gap:clamp(1.2rem,4vh,2.2rem);
    z-index:880;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    backdrop-filter:blur(14px);
    -webkit-backdrop-filter:blur(14px);
  }
  .nav-links > li:first-child { margin-top: auto; }
  .nav-links > li:last-child { margin-bottom: auto; }
  .nav-links.open { display:flex; animation:fadeUp .3s ease; }
  .nav-links a { font-size:1.05rem; letter-spacing:.24em; padding:.7rem 1rem; }
}
@media (max-width:720px) {
  #eventModal .modal-panel.has-poster { height:auto; max-height:90svh; overflow:auto; }
  .modal-content.modal-has-poster { display:block; height:auto; }
  .modal-poster { height:auto; border-right:none; border-bottom:1px solid rgba(201,168,76,.12); }
  .modal-poster img { height:auto; max-height:340px; width:100%; object-fit:contain; }
}

@media (max-width:768px) {
  .section { padding:clamp(3rem,6vw,5rem) 0; }
  .two-col { grid-template-columns:1fr; gap:2.2rem; }
  .reverse-mobile .col-img { order:-1; }
  .gallery-masonry { grid-template-columns:repeat(2,1fr); grid-auto-rows:155px; }
  .gallery-item:nth-child(5n+1) { grid-row:span 1; }
  .footer-inner { flex-direction:column; text-align:center; }
  .footer-nav { justify-content:center; }
  .footer-copy { text-align:center; }
  .modal-actions { flex-direction:column; }
  .avis-grid { grid-template-columns:1fr; }
}
@media (max-width:480px) {
  .gallery-masonry { grid-template-columns:repeat(2,1fr); grid-auto-rows:130px; }
  .events-grid { grid-template-columns:1fr; }
  .events-browser-grid { grid-template-columns:1fr; }
  .events-grid { gap:.95rem; }
  .events-browser-grid { gap:.78rem; }
  .event-body { padding:.84rem; gap:.62rem; }
  .event-date { min-width:36px; }
  .event-day { font-size:1.42rem; }
  .event-month { font-size:.58rem; }
  .event-title { font-size:.87rem; margin-bottom:.2rem; }
  .event-artist { font-size:.62rem; letter-spacing:.1em; margin-bottom:.2rem; }
  .event-lieu { font-size:.7rem; margin-bottom:.22rem; }
  .event-prix { font-size:.69rem; }
  .membres-grid { grid-template-columns:1fr; }
}

/* Pixel Perfect cible 390px */
@media (max-width:390px) {
  .events-toolbar { gap:.68rem; }
  .events-filters { width:100%; justify-content:space-between; }
  .events-filter-btn { flex:1 1 auto; min-width:0; text-align:center; padding:.4rem .44rem; font-size:.69rem; letter-spacing:.05em; }
  .events-viewall { width:100%; text-align:center; }
  .events-browser-panel { padding:.82rem; }
  .events-browser-title { font-size:1.15rem; }
  .events-browser-back { padding:.42rem .65rem; font-size:.64rem; }
}
@media (min-width:1400px) {
  :root { --container-max:1320px; }
  .gallery-masonry { grid-template-columns:repeat(5,1fr); }
}
