
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Jost',sans-serif;background:var(--cream);color:var(--ink);font-size:14px;line-height:1.6;min-height:100vh;display:flex;flex-direction:column}
.nav-bar{background:var(--ink);border-bottom:.5px solid rgba(192,144,96,0.3);padding:.75rem 2rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}
.nav-logo{font-family:'Cormorant Garamond',serif;font-size:1.05rem;color:var(--cream);text-decoration:none}
.nav-logo em{font-style:italic;color:var(--gold-l)}
.nav-links{display:flex;gap:1.5rem;align-items:center}
.nav-links a{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(232,224,213,.6);text-decoration:none;transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:var(--gold-l)}
.hero{background:var(--ink-l);padding:4rem 2rem 3.5rem;text-align:center;position:relative;overflow:hidden;border-bottom:1px solid rgba(192,144,96,0.2)}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 100%,rgba(192,144,96,0.1) 0%,transparent 70%)}
.hero-eyebrow{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-l);margin-bottom:.75rem;position:relative;opacity:.8}
.hero h1{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(2rem,5vw,3rem);color:var(--cream);line-height:1.1;position:relative}
.hero h1 em{font-style:italic;color:var(--gold-l)}
.hero-sep{width:50px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);margin:1.25rem auto 0;position:relative}
.main{max-width:860px;margin:0 auto;padding:3rem 2rem;flex:1}
.section-block{margin-bottom:3.5rem}
.section-label{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}
.section-label h2{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:1.5rem;color:var(--ink)}
.section-label h2 em{font-style:italic;color:var(--gold)}
.section-label::after{content:'';flex:1;height:.5px;background:var(--bd)}
.badge-avenir{background:var(--sage);color:white;font-size:9px;letter-spacing:.15em;text-transform:uppercase;padding:.25rem .7rem;border-radius:10px;font-weight:500}
.badge-passee{background:var(--cream-dd);color:var(--ink-f);font-size:9px;letter-spacing:.15em;text-transform:uppercase;padding:.25rem .7rem;border-radius:10px}
/* Expo cards */
.expo-list{display:flex;flex-direction:column;gap:1.25rem}
.expo-card{background:white;border:.5px solid var(--bd);border-radius:var(--r2);box-shadow:var(--sh);overflow:hidden;display:grid;grid-template-columns:auto 1fr;transition:transform .2s,box-shadow .2s}
.expo-card:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(15,13,11,0.18)}
.expo-card.avenir{border-left:4px solid var(--sage)}
.expo-card.passee{border-left:4px solid var(--cream-dd);opacity:.85}
.expo-card.has-affiche{grid-template-columns:140px 1fr}
/* Affiche */
.expo-affiche{width:140px;overflow:hidden;flex-shrink:0}
.expo-affiche img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s}
.expo-card:hover .expo-affiche img{transform:scale(1.03)}
/* Date block */
.expo-date-block{padding:1.5rem 1.25rem;background:var(--cream-d);display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:90px;border-right:.5px solid var(--bd)}
.expo-date-day{font-family:'Cormorant Garamond',serif;font-size:1.8rem;font-weight:300;color:var(--ink);line-height:1}
.expo-date-month{font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);font-weight:500;margin-top:.2rem}
.expo-date-year{font-size:11px;color:var(--ink-f);margin-top:.1rem}
.expo-date-fin{font-size:10px;color:var(--ink-f);margin-top:.4rem;font-style:italic;text-align:center}
/* Infos */
.expo-info{padding:1.25rem 1.5rem;display:flex;flex-direction:column;justify-content:center}
.expo-nom{font-family:'Cormorant Garamond',serif;font-size:1.25rem;color:var(--ink);margin-bottom:.4rem;line-height:1.2;font-weight:400}
.expo-lieu-wrap{display:flex;align-items:center;gap:.4rem;font-size:12px;color:var(--ink-l);margin-bottom:.2rem}
.expo-lieu-wrap::before{content:'📍';font-size:11px}
.expo-ville{font-size:11px;color:var(--ink-f);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.5rem}
.expo-dates-full{font-size:12px;color:var(--gold);font-style:italic;font-family:'Cormorant Garamond',serif;font-size:1rem}
.empty-expos{text-align:center;padding:3rem;color:var(--ink-f);font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.1rem;background:white;border:.5px solid var(--bd);border-radius:var(--r2)}
footer{background:var(--ink);color:var(--cream);padding:2rem;text-align:center;margin-top:auto;border-top:1px solid rgba(192,144,96,0.2)}
.ft{font-family:'Cormorant Garamond',serif;font-size:1rem;margin-bottom:.4rem}
.ft em{font-style:italic;color:var(--gold-l)}
.ft-links{display:flex;gap:1.25rem;justify-content:center;flex-wrap:wrap;margin-top:.5rem}
.ft-links a{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-l);text-decoration:none}
.ft-links a:hover{color:white}
@media(max-width:768px){
  .main{padding:2rem 1.25rem}
  .expo-list{gap:1rem}
}
@media(max-width:480px){
  .nav-bar{padding:.6rem 1rem}
  .nav-links{gap:.5rem}
  .nav-links a{font-size:10px}
  .hero{padding:2.5rem 1rem 2rem}
  .hero h1{font-size:1.7rem}
  .main{padding:1.5rem 1rem}
  .section-label h2{font-size:1.2rem}
  .expo-card,.expo-card.has-affiche{grid-template-columns:1fr}
  .expo-affiche{width:100%;height:160px}
  .expo-date-block{flex-direction:row;gap:1rem;justify-content:flex-start;padding:.85rem 1rem;border-right:none;border-bottom:.5px solid var(--bd);min-width:auto}
  .expo-date-day{font-size:1.4rem}
  .expo-info{padding:1rem 1.1rem}
  .expo-nom{font-size:1.05rem}
}
