/* =========================================================
   RESET (léger, moderne)
========================================================= */
*,*::before,*::after{box-sizing:border-box}
html:focus-within{scroll-behavior:smooth}
body,h1,h2,h3,h4,p,figure,blockquote,dl,dd{margin:0}
ul[role="list"],ol[role="list"]{list-style:none;padding:0;margin:0}
img,video,canvas,svg{max-width:100%;height:auto;display:block}
button,input,select,textarea{font:inherit}
a{text-decoration:none;color:inherit}

/* =========================================================
   VARIABLES
========================================================= */
:root{
  /* Couleurs thème */
  --claret-600: rgb(156,0,33);
  --claret-700: rgb(189,0,24);
  --text-900: #333;
  --text-800: #444;
  --bg-50: #fdfdfd;
  --border: #e8e8e8;

  /* Ombres & rayons */
  --shadow-1: 0 1px 6px rgba(0,0,0,.08);
  --shadow-2: 0 2px 10px rgba(0,0,0,.12);
  --radius-6: 6px; --radius-8: 8px; --radius-10: 10px;

  /* Layout */
  --container-760: 760px;
  --container-1200: 1200px;

  /* Rythme */
  --sp-8:.5rem; --sp-12:.75rem; --sp-16:1rem; --sp-20:1.25rem;
}

/* =========================================================
   BASE
========================================================= */
body{
  font-family: system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,'Open Sans',sans-serif;
  color: var(--text-900);
  background: var(--bg-50);
  line-height: 1.5;
}
.main-content,.page-intro{max-width:var(--container-760);margin:0 auto;padding:1.2em 1em}
.container{max-width:var(--container-1200);margin:0 auto;padding:1.4em 1em}
.text-muted{opacity:.8}
.small-text{font-size:.85em;opacity:.8}
.hidden{display:none !important}
a:hover {text-decoration:underline}

/* =========================================================
   HEADER (Grid : .date | .logo | .socials)
   - Logo toujours centré
   - Réseaux à droite en desktop, tout centré en mobile
========================================================= */
.header-top{
  display:grid;
  grid-template-columns: 1fr auto 1fr; /* gauche | LOGO | droite */
  align-items:center;
  gap:.6rem;
  background:var(--claret-600);
  color:#fff;
  padding:1rem;
}
.header-top .date{ grid-column:1; justify-self:start; line-height:1.3 }
.header-top .logo{ grid-column:2; justify-self:center }
.header-top .socials{ grid-column:3; justify-self:end }

/* Logo (div .logo contenant img.logo) */
.header-top .logo img.logo{
  display:block;
  max-height:60px;
  height:auto; width:auto;
  margin:0 auto;
}

/* Réseaux header en ligne */
.header-top .socials,
.header-top .socials ul{
  display:flex; flex-wrap:wrap; align-items:center; gap:.6rem;
  list-style:none; margin:0; padding:0;
}
.header-top .socials li{ margin:0 }
.header-top .socials a{ display:inline-flex; align-items:center }
.header-top .socials img{ width:28px; height:auto; display:block; filter:invert(1); }

/* MOBILE : tout au centre (texte + logo + réseaux) */
@media (max-width:768px){
  .header-top{
	/* grid-template-columns: 1fr; */
	row-gap: .5rem;
	text-align: center;
	flex-direction: column;
	display: flex;
  }
  .header-top > *{
    grid-column:1;
    justify-self:center;
  }
  .header-top .socials{ justify-content:center }
}

/* =========================================================
   NAV (burger)
========================================================= */
.main-nav{
  background:var(--claret-600);
  position:sticky;top:0;z-index:50;
}
.main-nav .burger{
  display:none;background:none;color:#fff;font-size:1.2em;border:0;padding:1em;cursor:pointer
}
.main-nav .burger .burger-label{display:none;margin-left:.4em;font-weight:700}
.main-nav .nav-menu{
  list-style:none;margin:0;padding:.6em 1em;
  display:flex;gap:1em;justify-content:center;
}
.main-nav .nav-menu a{color:#fff;font-weight:700}
.main-nav .nav-menu a:hover{opacity:.85}
@media (max-width:768px){
  .main-nav .burger{display:inline-block}
  .main-nav .burger .burger-label{display:inline}
  .main-nav .nav-menu{display:none;flex-direction:column}
  .main-nav .nav-menu.open{display:flex}
}

/* =========================================================
   HERO
========================================================= */
.hero{
  min-height:20vh; display:flex; align-items:center; justify-content:center;
  color:#fff; text-align:center; background:#b30018;
}
.hero-title{
  font-size:3rem; font-weight:700; text-shadow:2px 2px 4px rgba(0,0,0,.7);
}
@media (max-width:1049px){ .hero-title{font-size:2rem;padding:0 1rem} }

/* =========================================================
   BOUTONS
========================================================= */
.btn,.btn-ticket{
  display:inline-block;padding:.6em 1em;border-radius:var(--radius-6);
  text-decoration:none;font-weight:700;border:1px solid transparent;
}
.btn-ticket,.btn--primary{background:var(--claret-700);color:#fff}
.btn-ticket:hover,.btn--primary:hover{opacity:.9}
a.btn-ticket:hover {text-decoration:none}
.btn--ghost{background:#fff;color:var(--claret-700);border-color:var(--claret-700)}
.btn--ghost:hover{background:var(--claret-700);color:#fff}
.btn-row{display:flex;gap:.6rem;flex-wrap:wrap}
.btn-row a:hover {text-decoration:none}

/* =========================================================
   FOOTER
========================================================= */
footer{background:var(--claret-700);color:#fff;margin-top:2em}
.footer-content{
  display:flex;flex-wrap:wrap;gap:1.2em;
  max-width:var(--container-1200);margin:0 auto;padding:1.4em 1em
}
.footer-content>div{flex:1 1 280px}

/* Réseaux footer en ligne */
footer .socials,
footer .socials ul{
  display:flex; flex-direction:row; align-items:center; justify-content:flex-start;
  gap:.6rem; flex-wrap:wrap; list-style:none; margin:0; padding:0;
}
footer .socials li{ margin:0 }
footer .socials a{ display:inline-flex; align-items:center }
footer .socials a img{ max-width:28px; height:auto; display:block; filter:invert(1); }

.footer-bottom{background:var(--claret-600);text-align:center;padding:.8em}

/* Bande logos partenaires (home éventuel) */
.partner-logos{
  display:flex;justify-content:center;gap:1.2em;background:#fff;padding:1em;flex-wrap:wrap;border-top:1px solid var(--border)
}
.partner-logos img{max-height:84px}

/* =========================================================
   SCROLL TO TOP
========================================================= */
.scroll-top{
  position:fixed;bottom:1em;right:1em;background:var(--claret-600);color:#fff;
  border:0;border-radius:var(--radius-6);padding:.5em .8em;display:none;z-index:1000
}

/* =========================================================
   TABS + EVENTS
========================================================= */
.tabs{display:flex;gap:8px;justify-content:center;margin:0 0 14px}
@media (max-width:720px){.tabs{flex-direction:column}}
.tab-link{
  border:1px solid var(--claret-600);background:#fff;color:var(--claret-600);
  padding:8px 12px;border-radius:20px;cursor:pointer;font-weight:700
}
.tab-link.active,.tab-link:hover{background:var(--claret-600);color:#fff}

.event-day{max-width:var(--container-760);margin:0 auto 2em}
.events-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
@media (max-width:720px){.events-grid{grid-template-columns:1fr}}
.event-card{
  background:#fff;border-radius:var(--radius-10);overflow:hidden;
  box-shadow:var(--shadow-1);display:flex;flex-direction:column
}
.event-card img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block;border-radius:4px;box-shadow:var(--shadow-1)}
.event-info{padding:.9em 1em}
.event-info h4{margin:0 0 .4em;color:var(--claret-600);font-size:1.05em}

/* =========================================================
   GALLERY
========================================================= */
.gallery-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px;
  max-width:var(--container-760);margin:0 auto 2em
}
@media (max-width:900px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.gallery-grid{grid-template-columns:1fr}}
.gallery-item{
  background:#fff;border-radius:var(--radius-8);overflow:hidden;box-shadow:var(--shadow-1)
}
.gallery-item img{width:100%;aspect-ratio:3/2;object-fit:cover;display:block;border-radius:4px;box-shadow:var(--shadow-1)}
.gallery-item figcaption{padding:.6em .8em;font-size:.95em}
.gallery-filters{
  background:#fff;padding:8px 10px;border-radius:10px;max-width:var(--container-760);
  margin:0 auto 14px;box-shadow:var(--shadow-1);display:flex;flex-wrap:wrap;gap:8px;justify-content:center
}
.gallery-filters .gf-link{
  border:1px solid var(--claret-600);color:var(--claret-600);
  padding:6px 10px;border-radius:20px;font-weight:700;background:#fff
}
.gallery-filters .gf-link.active,.gallery-filters .gf-link:hover{background:var(--claret-600);color:#fff}

/* =========================================================
   LIGHTBOX
========================================================= */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.85);display:none;align-items:center;justify-content:center;z-index:9999}
.lightbox.open{display:flex}
.lb-content{position:relative;max-width:92vw;max-height:86vh}
.lb-img{max-width:92vw;max-height:76vh;margin:0 auto}
.lb-caption{color:#fff;text-align:center;margin-top:8px;font-size:.95em}
.lb-close,.lb-prev,.lb-next{
  position:absolute;top:50%;transform:translateY(-50%);
  background:rgba(255,255,255,.15);color:#fff;border:0;padding:10px 14px;border-radius:6px;cursor:pointer;font-size:18px
}
.lb-close{top:12px;right:12px;transform:none}
.lb-prev{left:-56px}.lb-next{right:-56px}
@media (max-width:560px){.lb-prev{left:-12px}.lb-next{right:-12px}}

/* =========================================================
   BLOG / ARTICLE
========================================================= */
.blog-list .post-filters{display:flex;gap:8px;justify-content:center;margin:0 0 16px}
.blog-list .pf-btn{
  border:1px solid var(--claret-600);background:#fff;color:var(--claret-600);
  padding:6px 10px;border-radius:20px;font-weight:700;cursor:pointer
}
.blog-list .pf-btn.active,.blog-list .pf-btn:hover{background:var(--claret-600);color:#fff}

.blog-list .posts-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:16px;max-width:var(--container-760);margin:0 auto
}
.post-card{
  background:#fff;border-radius:var(--radius-10);overflow:hidden;box-shadow:var(--shadow-1);display:flex;flex-direction:column
}
.post-card img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block;border-radius:4px;box-shadow:var(--shadow-1)}
.post-card h3{margin:.6em 0 .3em;color:var(--claret-600);padding:0 12px}
.post-card p{padding:0 12px 12px;margin:0}
.post-card .meta{font-size:.9em;opacity:.8}

.article-page{max-width:var(--container-760);margin:0 auto;padding:1.5em 1em}
.article-page h1{color:var(--claret-600);margin-bottom:.2em}
.article-page .meta{opacity:.8;margin-bottom:1em}
.article-page img{width:100%;height:auto;border-radius:8px;margin:12px 0 16px}
.article-page .content{line-height:1.6}
.article-page blockquote{
  margin:1em;padding:.8em 1em;background:#fff;border-left:4px solid var(--claret-600);
  border-radius:6px;box-shadow:0 1px 4px rgba(0,0,0,.05)
}
.article-cta{display:flex;gap:12px;align-items:center;margin-top:16px}

/* =========================================================
   FORMULAIRES / CONTACT
========================================================= */
.contact-form .form{display:flex;flex-direction:column;gap:.8em;max-width:600px;margin:0 auto}
.contact-form input,.contact-form textarea{border:1px solid #ccc;border-radius:4px;padding:.6em;font-size:1em}
.contact-form label{font-weight:600;color:var(--claret-600)}
.contact-form button{align-self:flex-start}

/* =========================================================
   MENTIONS LÉGALES
========================================================= */
.legal-section{margin-bottom:1.8em}
.legal-section h3{color:var(--claret-600);margin-bottom:.4em}

/* =========================================================
   HOME — STRUCTURE, COLONNES, NEWS 3 COL
========================================================= */
.lead{max-width:860px;margin:.4rem auto .8rem;text-align:center;color:var(--text-800); font-size:1.2rem;}
.columns--intro{display:grid;grid-template-columns:2fr 1fr;gap:1rem;align-items:start;margin-top:1rem}
@media (max-width:1049px){.columns--intro{grid-template-columns:1fr}}

.hero-illustration{
  width:100%;aspect-ratio:16/9;object-fit:cover;display:block;border-radius:6px;box-shadow:var(--shadow-2)
}
.visuel-caption{font-size:.85rem;opacity:.75;margin-top:.3rem}
.highlights{margin:.6rem 0 1rem 1.1rem}
.highlights li{margin:.25rem 0}
.countdown{margin:.8rem 0}
.countdown-label{display:block;font-weight:700;color:#333;margin-bottom:.25rem}

.quick-links{margin-top:1.4rem}
.quick-links h2{text-align:center;margin-bottom:.6rem}
.quick-grid{display:grid;gap:.8rem;grid-template-columns:repeat(3,1fr)}
@media (max-width:1049px){.quick-grid{grid-template-columns:1fr}}
.quick-card{
  display:block;background:#fff;border-radius:8px;padding:1rem;box-shadow:var(--shadow-2);
  color:#333;border:1px solid #eee
}
.quick-card:hover{border-color:#e52c3d;box-shadow:0 3px 10px rgba(0,0,0,.12)}
.quick-card h3{color:#e52c3d;margin:0 0 .2rem}
a.quick-card:hover {text-decoration:none}

.home-main{max-width:var(--container-1200);margin:0 auto}

/* Actus: grille 3 → 2 → 1 */
.home-news{margin-top:1.4rem}
.home-news .news-intro{text-align:left;margin:.1rem 0 .6rem}
.home-news .news-more{text-align:right;margin-top:.6rem}
.home-news .cards{
  display:grid !important;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px
}
@media (max-width:1024px){.home-news .cards{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:640px){.home-news .cards{grid-template-columns:1fr}}

.home-news .filmcards{
  display:grid !important;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px
}
@media (max-width:1024px){.home-news .filmcards{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:640px){.home-news .filmcards{grid-template-columns:1fr}}

.home-news .card{
  background:#fff;border-radius:8px;box-shadow:var(--shadow-2);overflow:hidden;display:flex;flex-direction:column
}
.home-news .card img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block}
.home-news .card h3{margin:.6rem 1rem .25rem;color:var(--claret-600)}
.home-news .card time{margin:0 1rem .25rem;opacity:.75;font-size:.95rem}
.home-news .card p{margin:0 1rem 1rem}
.home-news .card .read-more{margin:auto 1rem 1rem;color:var(--claret-600);font-weight:700}
.home-news .card .read-more:hover{text-decoration:underline}

.home-news .cardvip{
  background:#fff;border-radius:8px;box-shadow:var(--shadow-2);overflow:hidden;display:flex;flex-direction:column
}
.home-news .cardvip img{max-width:100%;max-height:260px;aspect-ratio:9/16;object-fit:cover;display:block}
.home-news .cardvip h3{margin:.6rem 1rem .25rem;color:var(--claret-600)}
.home-news .cardvip time{margin:0 1rem .25rem;opacity:.75;font-size:.95rem}
.home-news .cardvip p{margin:0 1rem 1rem}
.home-news .cardvip .read-more{margin:auto 1rem 1rem;color:var(--claret-600);font-weight:700}
.home-news .cardvip .read-more:hover{text-decoration:underline}

/* =========================================================
   PAGE PARTENAIRES (grilles par niveau)
========================================================= */
.partners-hero h1{ color: var(--claret-600); margin-bottom:.2rem }
.partners-hero .lead{ max-width:860px }

.partners-tier{ margin: 1.6rem auto; max-width: var(--container-1200); padding: 0 1rem }
.tier-header{ display:flex; align-items:baseline; gap:.8rem; margin: .4rem 0 .8rem }
.tier-title{ margin:0; color:#222; font-size: clamp(1.2rem, 2.2vw, 1.6rem) }
.tier-badge{
  display:inline-block; font-weight:800; letter-spacing:.2px;
  padding:.2rem .6rem; border-radius:999px; margin-right:.4rem
}

/* Badges */
.tier-premium .tier-badge{ background:#111; color:#fff }
.tier-gold    .tier-badge{ background:#D4AF37; color:#111 }
.tier-silver  .tier-badge{ background:#C0C0C0; color:#111 }
.tier-bronze  .tier-badge{ background:#CD7F32; color:#111 }
.tier-supporters .tier-badge{ background:#eee; color:#111; border:1px solid #ddd }

/* Grilles de logos */
.partner-grid{
  list-style:none; margin:0; padding:0;
  display:grid; gap:16px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
@media (max-width:1024px){ .partner-grid{ grid-template-columns: repeat(3, 1fr) } }
@media (max-width:680px){  .partner-grid{ grid-template-columns: repeat(2, 1fr) } }
@media (max-width:420px){  .partner-grid{ grid-template-columns: 1fr } }

/* Variante dense pour supporters */
.partner-grid--small{ gap:12px }
@media (min-width:1025px){ .partner-grid--small{ grid-template-columns: repeat(6, 1fr) } }
@media (min-width:681px) and (max-width:1024px){ .partner-grid--small{ grid-template-columns: repeat(4, 1fr) } }

.partner-card{
  background:#fff; border:1px solid var(--border); border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  padding:16px; box-shadow: var(--shadow-1);
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.partner-card:hover{
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(0,0,0,.12);
  border-color:#e1e1e1;
}

/* Hauteurs par niveau */
.partner-card img{ max-height:64px; width:auto; height:auto; object-fit:contain; display:block }
.tier-premium .partner-card img{ max-height:80px }
.tier-gold    .partner-card img{ max-height:72px }
.tier-silver  .partner-card img{ max-height:64px }
.tier-bronze  .partner-card img{ max-height:56px }
.partner-grid--small .partner-card img{ max-height:48px }

/* Synopsis pliable */
details.synopsis {
  margin-top:.4rem;
  background:#fff;
  /* border:1px solid var(--border, #e8e8e8); */
  /* border-radius:8px; */
  padding:.2rem .6rem .6rem;
}

details.synopsis > summary {
  list-style:none;          /* supprime la puce par défaut */
  cursor:pointer;
  padding:.4rem 0;
  user-select:none;
}

/* Chevron custom */
details.synopsis > summary::before {
  content:"▸";
  display:inline-block;
  margin-right:.4rem;
  transform:translateY(-1px);
  transition:transform .15s ease;
}
details.synopsis[open] > summary::before { transform:rotate(90deg) translateY(0) }

/* Contenu */
details.synopsis p { margin:.2rem 0 0 }

/* ===== Programme en un coup d’œil ===== */
.prog-controls{
  display:flex;flex-wrap:wrap;gap:.8rem;align-items:center;justify-content:space-between;margin:.4rem 0 1rem
}
.prog-filters{display:flex;gap:.6rem;align-items:center}
.prog-filters label{display:flex;gap:.4rem;align-items:center}
.prog-legend{display:flex;gap:.6rem;margin:.2rem 0 1rem}
.leg{display:inline-block;padding:.15rem .5rem;border-radius:999px;border:1px solid var(--border,#e8e8e8);background:#fff}
.leg-proj{border-color:#2e7d32;color:#2e7d32}
.leg-conc{border-color:#ad1457;color:#ad1457}
.leg-renc{border-color:#1565c0;color:#1565c0}
.leg-vip{border-color:#6d4c41;color:#6d4c41}

/* Grille temporelle */
.prog-grid{
  --row-min: 24px;             /* hauteur d’un slot (15 min) */
  --slot: 15;                  /* pas en minutes */
  display:grid;
  grid-template-columns: 80px repeat(2, 1fr); /* Heures + 2 lieux (adapté à data-cols via JS au besoin) */
  align-items:start;
  gap:6px;
  background:transparent;
}

/* entêtes colonnes */
.prog-colhead{
  position:sticky;top:0;z-index:2;
  background:#fff;border:1px solid var(--border);border-radius:6px;padding:.5rem .6rem;font-weight:700;
}

/* Rail heures à gauche (col 1) */
.prog-grid::before{
  content:"";
  grid-column:1; grid-row:2 / -1;
}

/* Items */
.prog-item{
  position:relative;
  border-radius:8px;
  padding:.4rem .5rem;
  font-size:.95rem;
  color:#111;
  box-shadow:var(--shadow-1);
  border:1px solid #ddd;
  background:#fff;
  overflow:hidden;
}
.prog-item strong{color:var(--claret-600)}

/* Couleurs par type */
.prog-item.type-proj{border-color:#2e7d32;box-shadow:0 1px 6px rgba(46,125,50,.15)}
.prog-item.type-conc{border-color:#ad1457;box-shadow:0 1px 6px rgba(173,20,87,.15)}
.prog-item.type-renc{border-color:#1565c0;box-shadow:0 1px 6px rgba(21,101,192,.15)}
.prog-item.type-vip{border-color:#6d4c41;box-shadow:0 1px 6px rgba(109,76,65,.15)}

/* Rail horaire (affichage des heures) */
.prog-time{
  grid-column:1;
  border:1px dashed #e6e6e6;
  border-radius:6px;
  padding:.2rem .4rem;
  font-size:.9rem; color:#666;
  align-self:stretch;
}

/* Ligne “maintenant” optionnelle */
.prog-now{
  position:relative; grid-column:1 / -1; height:0;
}
.prog-now::after{
  content:""; position:absolute; left:0; right:0; height:2px; background:rgba(220,0,0,.6);
}

/* VUE LISTE */
.prog-list{display:none}
.prog-ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.prog-li{
  display:flex; gap:.8rem; align-items:flex-start;
  background:#fff;border:1px solid var(--border);border-radius:8px;padding:.5rem .6rem;box-shadow:var(--shadow-1)
}
.prog-li time{min-width:110px;font-weight:700}
.prog-li strong{color:var(--claret-600)}
.prog-li.type-proj{border-color:#2e7d32}
.prog-li.type-conc{border-color:#ad1457}
.prog-li.type-renc{border-color:#1565c0}
.prog-li.type-vip{border-color:#6d4c41}

/* RESPONSIVE */
@media (max-width:920px){
  .prog-grid{grid-template-columns: 60px repeat(2,1fr)}
}
@media (max-width:780px){
  /* Par défaut sur mobile : vue liste */
  .prog-grid{display:none}
  .prog-list{display:block}
}

/* filtre compétitions */
.films-filters{display:flex;gap:.5rem;flex-wrap:wrap;margin:.5rem 0 1rem}
.films-filters .pf-btn{border:1px solid var(--claret-600);background:#fff;color:var(--claret-600);padding:.4rem .7rem;border-radius:20px;font-weight:700;cursor:pointer}
.films-filters .pf-btn.active,.films-filters .pf-btn:hover{background:var(--claret-600);color:#fff}

/* Événements simultanés dans la même colonne (split 50/50) */
.prog-item[data-stack="1"]{ width:calc(50% - 4px); justify-self:start }
.prog-item[data-stack="2"]{ width:calc(50% - 4px); justify-self:end }
@media (max-width:780px){ .prog-item[data-stack] { width:auto; justify-self:stretch } } /* sur mobile (vue liste), on annule */

/* ===== Programme — vue liste ===== */
.prog-ul{list-style:none;margin:0 0 1rem;padding:0;display:flex;flex-direction:column;gap:10px}
.prog-li{
  display:flex;gap:.8rem;align-items:flex-start;
  background:#fff;border:1px solid var(--border,#e8e8e8);
  border-left:4px solid #ddd; /* rehaussé par type ci-dessous */
  border-radius:10px;padding:.6rem .8rem;box-shadow:var(--shadow-1);
}
.prog-li time{min-width:120px;font-weight:700}
.prog-li strong{color:var(--claret-600)} 

/* Codes couleur par type */
.prog-li.type-proj{ border-left-color:#2e7d32 }   /* vert */
.prog-li.type-conc{ border-left-color:#ad1457 }   /* rose */
.prog-li.type-renc{ border-left-color:#1565c0 }   /* bleu */

/* Accent Pathé (jaune) quand tag-pathe est présent */
.prog-li.tag-pathe{ border-left-color:#f9a825; background:linear-gradient(90deg, rgba(249,168,37,.08), transparent 60%) }
.films-filters .pf-btn--pathe{ border-color:#f9a825; color:#8a6b00 }
.films-filters .pf-btn--pathe.active,
.films-filters .pf-btn--pathe:hover{ background:#f9a825; color:#111 }
