:root{
  --paper:#f3ead9;
  --paper-2:#ece0c9;
  --ink:#1d1410;
  --ink-soft:#3c2c22;
  --oxblood:#6f1d1f;
  --oxblood-deep:#4f1213;
  --brass:#b1822f;
  --brass-light:#cda14c;
  --line:rgba(29,20,16,.18);
  --shadow:0 18px 40px -22px rgba(29,20,16,.55);
  --maxw:1180px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:"Spectral",Georgia,serif;
  font-size:18px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
/* paper grain overlay */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

h1,h2,h3,.display{font-family:"Fraunces",Georgia,serif}

a{color:inherit}
img{display:block;max-width:100%}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.eyebrow{
  font-family:"Fraunces",serif;font-weight:600;font-size:.74rem;letter-spacing:.32em;
  text-transform:uppercase;color:var(--oxblood);
}

/* ── Hero layout avec logo_big ── */
.hero-content{position:relative;display:flex;justify-content:center;align-items:center}
.hero-logo-big{
  position:absolute;left:0;top:50%;transform:translateY(-50%);
  height:clamp(120px,18vw,220px);width:auto;
  filter:drop-shadow(0 4px 24px rgba(0,0,0,.4));
  pointer-events:none;
}
.hero-text{text-align:center}

/* ── Saisons spectacles ── */
.saison-block{margin-bottom:56px}
.saison-block:last-child{margin-bottom:0}
.saison-titre{
  font-family:"Fraunces",serif;font-weight:900;
  font-size:clamp(1.1rem,2.5vw,1.5rem);
  color:var(--oxblood);
  display:flex;align-items:center;gap:16px;
  margin-bottom:24px;
}
.saison-titre::after{
  content:"";flex:1;height:2px;
  background:linear-gradient(90deg,var(--oxblood),transparent);
}

/* ============ NAV ============ */
header.nav{
  position:sticky;top:0;z-index:100;
  overflow:visible; /* permet au pseudo de déborder vers le bas */
  /* fond sombre pour lisibilité du texte de la barre */
  background:rgba(20,8,4,.6);
  border-bottom:none; /* la jonction est assurée par l'image */
}
/* Image header.png — hauteur FIXE, toujours identique */
header.nav::before{
  content:"";
  position:absolute;
  top:0;left:0;right:0;
  height:110px;
  background:url('../images/header.png') top center / auto 110px repeat-x;
  pointer-events:none;
  z-index:1;
}

/* quiche top-right fixe */
.quiche-admin{
  position:fixed;top:8px;right:16px;
  z-index:9999;
  opacity:.2;
  transition:opacity .3s, transform .3s;
  display:block;
  width:50px;height:50px;
}
.quiche-admin:hover{opacity:.85;transform:scale(1.5);transform-origin:top right}
.quiche-admin img{width:50px;height:50px;border-radius:50%;display:block}

/* Le contenu de la barre reste lisible par-dessus l'image */
header.nav .nav-inner{position:relative;z-index:2}
/* textes nav */
.brand,.brand-accent{color:var(--paper) !important}
.nav-links a{color:rgba(243,234,217,.8) !important}
.nav-links a:hover{color:var(--brass-light) !important}

.nav-inner{display:flex;align-items:center;justify-content:space-between;height:60px}
.brand{font-family:"Fraunces";font-weight:900;font-size:1.15rem;letter-spacing:.02em;text-decoration:none;display:flex;align-items:center;gap:8px}
.logo-img{height:36px;width:auto;display:block}
.brand-text{display:block}
.brand-accent{color:var(--oxblood)}
.nav-links{display:flex;gap:20px;list-style:none;align-items:center}
.nav-links li{position:relative}
.nav-links a{
  display:inline-block;
  text-decoration:none;font-size:.85rem;letter-spacing:.14em;text-transform:uppercase;
  font-family:"Fraunces";font-weight:600;
  padding:4px 0;
  white-space:nowrap;
  transition:color .2s;
  position:relative;
}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:-2px;
  width:0;height:1px;background:var(--brass-light);transition:width .25s;
}
.nav-links a:hover::after{width:100%}
.burger{display:none;background:none;border:none;cursor:pointer;font-size:1.5rem;color:var(--paper)}

/* ============ HERO ============ */
.hero{
  position:relative;overflow:hidden;
  background:url('../images/rideau.png') center center / cover no-repeat;
  color:var(--paper);padding:90px 0 100px;
  margin-top:-100px;
  padding-top:190px;
  z-index:1;
}
.hero::before{
   content:"";position:absolute;inset:0;z-index:0;
  background:rgba(0,0,0,0.35);
}
.hero::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:34px;z-index:2;
  background:repeating-linear-gradient(90deg,var(--oxblood) 0 38px,var(--oxblood-deep) 38px 76px);
  -webkit-mask:radial-gradient(28px 34px at 19px 0,transparent 0 28px,#000 29px) repeat-x;
  mask:radial-gradient(28px 34px at 19px 0,transparent 0 28px,#000 29px) repeat-x;
  -webkit-mask-size:38px 34px;mask-size:38px 34px;
}
.hero .wrap{position:relative;z-index:3;text-align:center}
.hero .eyebrow{color:var(--brass-light)}
.hero h1{
  font-weight:900;line-height:.92;letter-spacing:-.01em;margin:18px 0 10px;
  font-size:clamp(3rem,11vw,7.2rem);
  text-shadow:0 2px 0 rgba(0,0,0,.25);
}
.hero h1 em{font-style:italic;font-weight:500;color:var(--brass-light)}
.hero-titre-img{
  display:block;
  max-width:min(700px, 90vw);
  width:100%;
  height:auto;
  margin:18px auto 10px;
  filter:drop-shadow(0 2px 12px rgba(0,0,0,.4));
}
.hero .tagline{
  font-style:italic;font-size:clamp(1.1rem,2.4vw,1.5rem);max-width:620px;margin:0 auto;
  color:rgba(243,234,217,.92);
}
.hero .meta{
  margin-top:30px;display:inline-flex;gap:14px;align-items:center;flex-wrap:wrap;justify-content:center;
  font-family:"Fraunces";font-size:.8rem;letter-spacing:.22em;text-transform:uppercase;color:var(--brass-light);
}
.hero .meta span{opacity:.55}
.stars{letter-spacing:.4em;color:var(--brass-light);font-size:1rem;margin-bottom:6px}
.cta-row{margin-top:38px;display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.btn{
  display:inline-block;text-decoration:none;font-family:"Fraunces";font-weight:600;
  font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;padding:14px 28px;
  transition:transform .25s,background .25s,color .25s;
}
.btn-solid{background:var(--brass);color:var(--ink)}
.btn-solid:hover{background:var(--brass-light);transform:translateY(-2px)}
.btn-ghost{border:1px solid rgba(243,234,217,.5);color:var(--paper)}
.btn-ghost:hover{background:rgba(243,234,217,.12);transform:translateY(-2px)}

/* ============ SECTION FRAME ============ */
section{padding:88px 0}
.section-head{text-align:center;margin-bottom:54px}
.section-head h2{font-size:clamp(2rem,5vw,3.1rem);font-weight:900;line-height:1.04;margin-top:10px}
.rule{width:64px;height:3px;background:var(--oxblood);margin:18px auto 0;position:relative}
.rule::before,.rule::after{content:"";position:absolute;top:50%;width:7px;height:7px;background:var(--brass);transform:translateY(-50%) rotate(45deg)}
.rule::before{left:-16px}.rule::after{right:-16px}
.note{font-style:italic;color:var(--oxblood-deep);background:var(--paper-2);border-left:3px solid var(--brass);padding:10px 16px;font-size:.92rem;border-radius:0 6px 6px 0}
.ph{color:var(--oxblood);font-style:italic}

/* ============ À PROPOS ============ */
.about{background:var(--paper)}
.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
.about-grid p{margin-bottom:18px;color:var(--ink-soft)}
.dropcap::first-letter{font-family:"Fraunces";font-weight:900;font-size:3.4rem;float:left;line-height:.78;padding:6px 10px 0 0;color:var(--oxblood)}
.about-card{background:var(--oxblood-deep);color:var(--paper);padding:38px;box-shadow:var(--shadow);position:relative}
.about-card h3{font-size:1.5rem;color:var(--brass-light);margin-bottom:18px}
.factline{display:flex;justify-content:space-between;gap:18px;padding:16px 0;border-bottom:1px solid rgba(243,234,217,.2);font-size:.95rem}
.factline:last-child{border-bottom:none}
.factline strong{font-family:"Fraunces";color:var(--brass-light);font-weight:600;white-space:nowrap}

/* ============ SPECTACLES ============ */
.shows{background:var(--paper)}
.show-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:20px}
.show{display:flex;flex-direction:column;background:var(--paper-2);border:1px solid var(--line);box-shadow:var(--shadow);overflow:hidden;cursor:pointer;transition:transform .25s,box-shadow .25s}
.show:hover{transform:translateY(-6px);box-shadow:0 14px 36px rgba(29,20,16,.2)}
.show-poster-wrap{position:relative;overflow:hidden;aspect-ratio:2/3;background:repeating-linear-gradient(135deg,var(--oxblood) 0 10px,var(--oxblood-deep) 10px 20px);flex-shrink:0}
.show-poster-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s}
.show:hover .show-poster-img{transform:scale(1.04)}
.show-poster-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:12px;text-align:center}
.show-poster-ph span,.curtain-ph{width:100%;height:100%}
.curtain-ph{background:repeating-linear-gradient(90deg,#6f1d1f 0px,#8a2427 12px,#5e1419 24px,#7a2022 36px,#6f1d1f 48px);position:relative}
.curtain-ph::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.3) 0%,transparent 30%,rgba(0,0,0,.2) 100%)}
.show-ribbon{position:absolute;top:14px;right:-28px;width:120px;background:var(--oxblood-deep);color:var(--brass-light);text-align:center;padding:6px 0;font-family:"Fraunces",serif;font-weight:600;font-size:.87rem;letter-spacing:.1em;text-transform:uppercase;transform:rotate(45deg);box-shadow:0 2px 6px rgba(0,0,0,.35);white-space:nowrap}
.show-photo-badge{position:absolute;bottom:6px;left:6px;background:rgba(0,0,0,.55);color:rgba(243,234,217,.9);font-size:.68rem;padding:3px 7px;border-radius:10px;backdrop-filter:blur(4px)}
.show-caption{padding:10px 12px 12px;display:flex;flex-direction:column;gap:3px}
.show-caption-titre{font-family:"Fraunces",serif;font-weight:900;font-size:.9rem;line-height:1.2;color:var(--ink)}
.show-caption-auteur{font-size:.75rem;font-style:italic;color:var(--ink-soft)}

/* ============ AGENDA ============ */
.agenda{background:var(--oxblood-deep);color:var(--paper)}
.agenda .section-head h2{color:var(--paper)}
.agenda .rule{background:var(--brass-light)}
.dates{max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:24px}
.agenda-note{font-style:italic;opacity:.75}
.repr-card{background:rgba(243,234,217,.06);border:1px solid rgba(243,234,217,.15);display:grid;grid-template-columns:90px 1fr;gap:0;margin-bottom:16px;transition:background .25s}
.repr-card:hover{background:rgba(243,234,217,.11)}
.repr-when{background:var(--oxblood);padding:20px 14px;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;flex-shrink:0}
.repr-day{font-family:"Fraunces";font-weight:900;font-size:2rem;line-height:1;color:var(--paper)}
.repr-month{font-family:"Fraunces";font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--brass-light)}
.repr-year{font-size:.72rem;color:rgba(243,234,217,.6);letter-spacing:.08em}
.repr-heure{margin-top:8px;font-family:"Fraunces";font-size:1.1rem;color:var(--brass-light);border-top:1px solid rgba(243,234,217,.2);padding-top:8px;width:100%;text-align:center}
.repr-jours{margin-top:6px;font-size:.72rem;color:var(--brass-light);font-style:italic;border-top:1px solid rgba(243,234,217,.15);padding-top:6px;text-align:center;line-height:1.2}
.repr-body{padding:18px 22px;display:flex;flex-direction:column;gap:12px}
.repr-pieces{display:flex;flex-wrap:wrap;gap:12px}
.repr-content-row{display:flex;gap:16px;align-items:flex-start;flex-wrap:wrap}
.repr-affiche{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0}
.repr-affiche-img{max-width:100px;max-height:150px;width:auto;height:auto;object-fit:contain;border:2px solid var(--brass-light);box-shadow:0 4px 12px rgba(0,0,0,.3)}
.repr-affiche-label{font-family:"Fraunces",serif;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brass-light);opacity:.8}
.repr-pieces-col{display:flex;flex-wrap:wrap;gap:10px;flex:1;min-width:200px}
.agenda-piece-card{display:flex;align-items:flex-start;gap:14px;background:rgba(243,234,217,.08);padding:12px 16px;border:1px solid rgba(243,234,217,.15);flex:1;min-width:240px;cursor:pointer;transition:background .2s,transform .2s,box-shadow .2s}
.agenda-piece-card:hover{background:rgba(243,234,217,.16);transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.25)}
.agenda-piece-img{display:block;max-width:110px;max-height:160px;width:auto;height:auto;object-fit:contain;border:1px solid rgba(243,234,217,.2);flex-shrink:0;align-self:flex-start}
.agenda-piece-img-ph{width:90px;height:120px;background:var(--oxblood-deep);display:flex;align-items:center;justify-content:center;font-size:2.4rem;flex-shrink:0}
.agenda-piece-info{padding-top:4px}
.agenda-piece-info strong{font-family:"Fraunces";font-size:1.05rem;display:block;color:var(--paper);margin-bottom:4px}
.agenda-piece-info span{font-size:.82rem;font-style:italic;color:rgba(243,234,217,.75)}
.piece-card-hint{display:block;font-size:.72rem;margin-top:6px;color:var(--brass-light);font-style:italic;opacity:.85}
.agenda-asso{font-size:.88rem;color:var(--brass-light);font-style:italic;border-left:2px solid var(--brass-light);padding-left:10px}
.agenda-asso strong{font-style:normal}
.repr-lieu{font-size:.85rem;color:rgba(243,234,217,.8)}
.agenda-loading{text-align:center;font-style:italic;opacity:.7;color:var(--paper);padding:30px 0}

/* ============ GALERIE ============ */
.gallery{background:var(--paper-2)}
.grid-photos{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:130px;gap:14px}
.gphoto{background:linear-gradient(160deg,var(--oxblood),var(--oxblood-deep));display:flex;align-items:center;justify-content:center;color:rgba(243,234,217,.5);font-family:"Fraunces";font-size:.8rem;letter-spacing:.1em;border:1px solid rgba(0,0,0,.12)}
.gphoto.big{grid-column:span 3;grid-row:span 2}
.gphoto.tall{grid-row:span 2}
.gphoto.wide{grid-column:span 2}
#galerie-grid.grid-photos{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-auto-rows:180px}
#galerie-grid .gphoto{cursor:pointer;overflow:hidden;position:relative;background:var(--paper-2);transition:transform .25s,box-shadow .25s}
#galerie-grid .gphoto:hover{transform:scale(1.03);box-shadow:0 8px 24px rgba(0,0,0,.18);z-index:1}
#galerie-grid .gphoto img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s}
#galerie-grid .gphoto:hover img{transform:scale(1.06)}
.galerie-loading{grid-column:1/-1;text-align:center;font-style:italic;opacity:.7;color:var(--ink-soft);padding:40px 0}
.galerie-pagination{display:flex;align-items:center;justify-content:center;gap:20px;margin-top:32px}
.gal-btn{font-family:"Fraunces";font-weight:600;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;padding:10px 22px;background:var(--oxblood);color:var(--paper);border:none;cursor:pointer;transition:background .2s,opacity .2s}
.gal-btn:hover:not(:disabled){background:var(--oxblood-deep)}
.gal-btn:disabled{opacity:.35;cursor:default}
.gal-info{font-family:"Fraunces";font-size:.85rem;color:var(--ink-soft);font-style:italic}

/* barre de filtre galerie */
.galerie-filter-bar{display:flex;align-items:center;gap:12px;margin-bottom:22px;flex-wrap:wrap}
.gal-filter-label{font-size:.82rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);white-space:nowrap}
.gal-filter-select{padding:8px 14px;border:1px solid var(--line);background:var(--paper);color:var(--ink);font-family:inherit;font-size:.9rem;cursor:pointer;border-radius:4px;min-width:220px;transition:border-color .2s}
.gal-filter-select:focus{outline:none;border-color:var(--oxblood)}

/* ============ VISIONNEUSE ============ */
.galerie-viewer{position:fixed;inset:0;z-index:9500;background:rgba(10,5,3,.93);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s}
.galerie-viewer.open{opacity:1;pointer-events:all}
.viewer-img-wrap{max-width:90vw;max-height:88vh;display:flex;align-items:center;justify-content:center}
.viewer-img-wrap img{max-width:100%;max-height:88vh;object-fit:contain;display:block;box-shadow:0 20px 60px rgba(0,0,0,.6)}
.viewer-close{position:absolute;top:16px;right:16px;background:rgba(243,234,217,.15);color:#f3ead9;border:1px solid rgba(243,234,217,.25);width:38px;height:38px;border-radius:50%;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
.viewer-close:hover{background:rgba(243,234,217,.3)}
.viewer-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(243,234,217,.12);color:#f3ead9;border:1px solid rgba(243,234,217,.2);width:48px;height:72px;font-size:2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;user-select:none}
.viewer-nav:hover{background:rgba(243,234,217,.25)}
.viewer-prev{left:16px}.viewer-next{right:16px}
.viewer-counter{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);font-family:"Fraunces";font-size:.82rem;letter-spacing:.16em;color:rgba(243,234,217,.7);background:rgba(0,0,0,.4);padding:5px 14px;border-radius:20px}

/* ============ ASSOCIATIONS ============ */
.assos-section{background:var(--paper-2)}
.assos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:22px}
.asso-card{background:var(--paper);border:1px solid var(--line);display:flex;flex-direction:column;overflow:hidden;transition:transform .25s,box-shadow .25s}
.asso-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.1)}
.asso-card.highlighted{outline:3px solid var(--brass);animation:assoFlash .4s ease 3}
@keyframes assoFlash{0%,100%{outline-color:var(--brass)}50%{outline-color:var(--oxblood)}}
.asso-img-wrap{height:140px;overflow:hidden;background:var(--paper-2)}
.asso-img{width:100%;height:100%;object-fit:cover}
.asso-body{padding:16px 18px;display:flex;flex-direction:column;gap:8px;flex:1}
.asso-nom{font-family:inherit;font-size:1.05rem;font-weight:700}
.asso-desc{font-size:.88rem;opacity:.75;line-height:1.5}
.asso-link-ext{font-size:.8rem;color:var(--oxblood);text-decoration:none;font-weight:600;margin-top:auto}
.asso-link-ext:hover{text-decoration:underline}
.asso-link{color:var(--brass-light);text-decoration:none}
.asso-link:hover{text-decoration:underline}

/* ============ LIENS / PRESSE ============ */
.liens{background:var(--paper-2)}
.liens-carousel{position:relative;display:flex;align-items:center;gap:8px}
.liens-grid{flex:1;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.lien-card{background:var(--paper);border:1px solid var(--line);padding:22px 24px;text-decoration:none;color:inherit;display:flex;flex-direction:column;gap:8px;transition:transform .2s,box-shadow .2s;position:relative}
.lien-card::after{content:"↗";position:absolute;top:16px;right:18px;font-size:1.1rem;opacity:.3;transition:opacity .2s}
.lien-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.12)}
.lien-card:hover::after{opacity:.8}
.lien-date{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;opacity:.55;font-family:inherit}
.lien-titre{font-size:1.05rem;font-weight:600;line-height:1.3;color:var(--oxblood)}
.lien-url{font-size:.78rem;opacity:.5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-style:italic}
.liens-empty{font-style:italic;opacity:.6;text-align:center;padding:32px 0}
.liens-arrow{flex-shrink:0;width:40px;height:40px;border-radius:50%;border:none;cursor:pointer;font-size:1.6rem;line-height:1;background:var(--oxblood);color:#f3ead9;transition:background .2s,transform .15s;z-index:2}
.liens-arrow:hover:not(:disabled){background:var(--oxblood-deep);transform:scale(1.08)}
.liens-arrow:disabled{opacity:.3;cursor:default}
.liens-pager{display:flex;justify-content:center;gap:8px;margin-top:14px}
.liens-dot{width:8px;height:8px;border-radius:50%;background:var(--line);cursor:pointer;transition:background .2s,transform .2s;border:none;padding:0;display:inline-block}
.liens-dot.active{background:var(--oxblood);transform:scale(1.3)}

/* ============ REJOINDRE ============ */
.join{background:var(--paper)}
.join-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:10px}
.join-card{text-align:center;padding:34px 26px;border:1px solid var(--line);background:var(--paper-2)}
.join-card .num{font-family:"Fraunces";font-weight:900;font-size:2.4rem;color:var(--oxblood);line-height:1}
.join-card h4{font-family:"Fraunces";font-size:1.2rem;margin:14px 0 8px}
.join-card p{font-size:.95rem;color:var(--ink-soft)}

/* ============ CONTACT ============ */
.contact{background:var(--oxblood-deep);color:var(--paper)}
.contact .section-head h2{color:var(--paper)}
.contact .rule{background:var(--brass-light)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;max-width:920px;margin:0 auto}
.contact-block h4{font-family:"Fraunces";color:var(--brass-light);font-size:.8rem;letter-spacing:.22em;text-transform:uppercase;margin-bottom:10px}
.contact-block p{margin-bottom:20px;color:rgba(243,234,217,.9)}
.contact-block a{color:var(--brass-light)}
.social{display:flex;gap:14px;margin-top:6px}
.social a{width:42px;height:42px;border:1px solid rgba(243,234,217,.35);display:flex;align-items:center;justify-content:center;text-decoration:none;font-family:"Fraunces";font-weight:600;transition:background .25s,color .25s}
.social a:hover{background:var(--brass);color:var(--ink);border-color:var(--brass)}
.cform{display:flex;flex-direction:column;gap:14px}
.cform input,.cform textarea{background:rgba(243,234,217,.07);border:1px solid rgba(243,234,217,.3);color:var(--paper);padding:13px 15px;font-family:"Spectral";font-size:1rem;border-radius:4px}
.cform input::placeholder,.cform textarea::placeholder{color:rgba(243,234,217,.5)}
.cform button{align-self:flex-start;cursor:pointer;border:none}

/* ============ FOOTER ============ */
footer{background:var(--ink);color:rgba(243,234,217,.7);padding:40px 0;text-align:center;font-size:.85rem}
footer .brand-f{font-family:"Fraunces";font-weight:900;font-size:1.3rem;color:var(--paper);margin-bottom:6px}
footer a{color:var(--brass-light)}

/* thumbnails galerie modal */
.modal-gal-thumb{width:72px;height:72px;object-fit:cover;cursor:pointer;border:2px solid transparent;border-radius:3px;transition:border-color .2s,transform .2s}
.modal-gal-thumb:hover{border-color:var(--oxblood);transform:scale(1.06)}

/* bouton photos piece */
.btn-photos-piece{display:inline-flex;align-items:center;gap:5px;margin-top:12px;padding:6px 13px;background:transparent;border:1px solid var(--oxblood);color:var(--oxblood);font-family:inherit;font-size:.8rem;cursor:pointer;border-radius:3px;transition:background .2s,color .2s}
.btn-photos-piece:hover{background:var(--oxblood);color:#fff}

/* carousel pièces */
.shows-carousel{position:relative;display:flex;align-items:center;gap:8px}
.carousel-viewport{overflow-x:auto;scroll-behavior:smooth;flex:1;scrollbar-width:none}
.carousel-viewport::-webkit-scrollbar{display:none}
.show-grid{display:flex;gap:16px;min-width:0}
.show-grid .show{flex:0 0 160px;min-width:0}
.carousel-btn{flex-shrink:0;width:40px;height:40px;border-radius:50%;border:none;cursor:pointer;font-size:1.6rem;line-height:1;background:var(--oxblood);color:#f3ead9;transition:background .2s,transform .15s;z-index:2}
.carousel-btn:hover:not(:disabled){background:var(--oxblood-deep);transform:scale(1.08)}
.carousel-btn:disabled{opacity:.3;cursor:default}
.carousel-dots{display:flex;justify-content:center;gap:8px;margin-top:14px}
.carousel-dot{width:8px;height:8px;border-radius:50%;background:var(--line);cursor:pointer;transition:background .2s,transform .2s;border:none;padding:0}
.carousel-dot.active{background:var(--oxblood);transform:scale(1.3)}

/* rideau rouge */
.curtain-ph{background:repeating-linear-gradient(90deg,#6f1d1f 0px,#8a2427 12px,#5e1419 24px,#7a2022 36px,#6f1d1f 48px);position:relative}
.curtain-ph::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.3) 0%,transparent 30%,rgba(0,0,0,.2) 100%)}

/* jours avant représentation */
.repr-jours{margin-top:6px;font-size:.72rem;color:var(--brass-light);font-style:italic;border-top:1px solid rgba(243,234,217,.15);padding-top:6px;text-align:center;line-height:1.2}

/* reveal animation */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ============ MODAL PIÈCE ============ */
.piece-modal{position:fixed;inset:0;z-index:9000;background:rgba(15,8,5,.82);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .3s}
.piece-modal.open{opacity:1;pointer-events:all}
.modal-box{background:var(--paper);max-width:860px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 32px 80px rgba(0,0,0,.6);animation:modalIn .35s cubic-bezier(.22,1,.36,1) both}
@keyframes modalIn{from{transform:translateY(28px) scale(.97);opacity:0}to{transform:none;opacity:1}}
.piece-modal:not(.open) .modal-box{animation:none}
.modal-close{position:absolute;top:14px;right:14px;z-index:10;background:var(--oxblood-deep);color:var(--paper);border:none;width:34px;height:34px;border-radius:50%;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
.modal-close:hover{background:var(--oxblood)}
.modal-layout{display:grid;grid-template-columns:auto 1fr;gap:0}
.modal-image-col{background:var(--ink);display:flex;align-items:center;justify-content:center;min-width:200px;max-width:320px;align-self:stretch}
.modal-image-col img{display:block;width:100%;height:auto;max-height:90vh;object-fit:contain}
.modal-img-ph{width:220px;height:300px;display:flex;align-items:center;justify-content:center;font-size:4rem;color:rgba(243,234,217,.3);background:var(--oxblood-deep)}
.modal-info-col{padding:38px 36px;display:flex;flex-direction:column;gap:10px}
.modal-saison{font-family:"Fraunces";font-weight:600;font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--oxblood)}
.modal-titre{font-family:"Fraunces";font-weight:900;font-size:clamp(1.6rem,4vw,2.4rem);line-height:1.05;color:var(--ink);margin:0}
.modal-auteur{font-style:italic;color:var(--ink-soft);font-size:1rem}
.modal-auteur strong{font-style:normal;font-weight:600}
.modal-meta{font-size:.9rem;color:var(--ink-soft);font-style:italic}
.modal-genre-badge{display:inline-block;align-self:flex-start;background:var(--oxblood);color:var(--paper);font-style:normal;font-family:"Fraunces";font-weight:600;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;padding:4px 12px}
.modal-divider{height:1px;background:var(--line);margin:6px 0}
.modal-resume{font-size:1rem;line-height:1.75;color:var(--ink-soft);white-space:pre-line}

/* ============ RESPONSIVE ============ */
@media(max-width:900px){
  .nav-links{position:fixed;inset:60px 0 auto 0;background:var(--paper);flex-direction:column;gap:0;padding:10px 0;border-bottom:1px solid var(--line);display:none}
  .nav-links.open{display:flex}
  .nav-links li{padding:12px 28px;border-bottom:1px solid var(--line)}
  .nav-links a{transform:none;font-size:.85rem;letter-spacing:.1em;color:var(--ink-soft) !important}
  .burger{display:block}
  .about-grid{grid-template-columns:1fr;gap:36px}
  .show-grid{grid-template-columns:1fr}
  .join-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr;gap:36px}
  .grid-photos{grid-template-columns:repeat(2,1fr)}
  .gphoto.big{grid-column:span 2}
  .hero-content{flex-direction:column;gap:24px}
  .hero-logo-big{position:static;transform:none;height:clamp(80px,20vw,120px)}
  .liens-grid{grid-template-columns:1fr}
  .modal-layout{grid-template-columns:1fr}
  .modal-image-col{max-width:100%;min-width:0}
  .modal-image-col img{max-height:50vw}
  .modal-img-ph{width:100%;height:160px}
  .modal-info-col{padding:24px 20px}
}
@media(max-width:600px){
  .repr-card{grid-template-columns:70px 1fr}
  .repr-day{font-size:1.5rem}
  .repr-body{padding:14px}
  .agenda-piece-card{min-width:100%;flex-direction:row}
  .agenda-piece-img{max-width:80px;max-height:120px}
  .agenda-piece-img-ph{width:70px;height:94px}
  #galerie-grid.grid-photos{grid-template-columns:repeat(2,1fr);grid-auto-rows:130px}
  .viewer-nav{width:36px;height:52px;font-size:1.5rem}
}
