/* Concert-Hommage.fr — thème national hommage/tribute (PLAN B). Standalone. */
:root{
  --brand:#6d28d9; --brand-d:#4c1d95; --ink:#1a1330; --muted:#6b6480;
  --bg:#faf8ff; --card:#fff; --line:#e7e1f5; --accent:#f59e0b;
}
*{box-sizing:border-box}
body.hommage{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.55}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:1080px;margin:0 auto;padding:0 20px}
.skip{position:absolute;left:-9999px}

/* Header */
.site-header{background:linear-gradient(100deg,var(--brand-d),var(--brand));color:#fff}
.site-header__in{display:flex;align-items:center;justify-content:space-between;padding:14px 20px}
.brand{display:inline-flex;align-items:center;gap:10px;color:#fff;font-size:1.35rem;letter-spacing:-.02em}
.brand:hover{text-decoration:none}
.brand__mark{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:50%;
  background:rgba(255,255,255,.16);font-size:1.1rem}
.brand__txt strong{font-weight:800}
.brand__tld{opacity:.7;font-weight:400}
.site-nav{display:flex;gap:22px}
.site-nav a{color:#fff;opacity:.9;font-weight:600;font-size:.95rem}
.site-nav a.current,.site-nav a:hover{opacity:1;text-decoration:none;border-bottom:2px solid var(--accent);padding-bottom:2px}

/* Hero */
.hero{padding:44px 0 8px}
.hero h1{font-size:2.1rem;margin:0 0 .4em;letter-spacing:-.02em}
.hero__intro{font-size:1.1rem;color:var(--muted);max-width:760px}

/* Blocks */
main.wrap{padding-bottom:56px}
.block{margin:38px 0}
.block h2{font-size:1.35rem;margin:0 0 16px;padding-bottom:8px;border-bottom:2px solid var(--line)}

/* Grid of artist cards */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:16px}
.card{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);
  border-radius:14px;overflow:hidden;transition:.15s;color:var(--ink)}
.card:hover{text-decoration:none;transform:translateY(-2px);box-shadow:0 10px 28px rgba(76,29,149,.15);border-color:var(--brand)}
.card__img{position:relative;display:block;aspect-ratio:4/5;overflow:hidden;
  background:linear-gradient(135deg,var(--brand),var(--brand-d))}
.card__img img{position:relative;z-index:1;width:100%;height:100%;object-fit:cover;display:block}

/* Fallback stylisé (mini « poster texte ») quand aucune image du flux n'est dispo. */
.hn-ph{position:absolute;inset:0;z-index:0;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:9px;padding:18px;text-align:center;color:#fff;
  background:linear-gradient(135deg,var(--brand),var(--brand-d))}
.hn-ph::before{content:"";position:absolute;inset:0;opacity:.13;
  background:radial-gradient(circle at 30% 20%,#fff 0,transparent 42%),radial-gradient(circle at 78% 82%,#fff 0,transparent 40%)}
.hn-ph__mark{font-size:1.5rem;opacity:.55}
.hn-ph__name{position:relative;font-weight:800;font-size:1.18rem;line-height:1.18;letter-spacing:-.01em;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.hn-ph__sub{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;opacity:.62}
.card__body{display:flex;flex-direction:column;gap:5px;padding:13px 15px 15px}
.card__name{font-weight:700;font-size:1.06rem;color:var(--brand-d);line-height:1.25}
.card__meta{font-size:.83rem;color:var(--muted)}

/* Date list (home) */
.datelist{list-style:none;margin:0;padding:0}
.datelist li{display:flex;align-items:baseline;gap:12px;padding:10px 0;border-bottom:1px solid var(--line);flex-wrap:wrap}
.datelist time{flex:0 0 116px;font-variant-numeric:tabular-nums;color:var(--muted);font-size:.9rem}
.datelist a{font-weight:600}
.datelist__where{color:var(--muted);font-size:.9rem}
.more{margin-top:16px}

/* Breadcrumb */
.breadcrumb{font-size:.85rem;color:var(--muted);padding:18px 0 0}
.breadcrumb a{color:var(--muted)}
.breadcrumb span{color:var(--ink)}

/* Artist / spectacle */
.tag{display:inline-block;background:var(--brand);color:#fff;font-size:.72rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.04em;padding:4px 10px;border-radius:999px}
.artiste__head,.spectacle header{margin:14px 0 22px}
.artiste h1,.spectacle h1{font-size:1.9rem;margin:.3em 0 .2em;letter-spacing:-.02em}
.artiste__count,.spectacle__count{color:var(--muted)}
.intro{max-width:760px;margin:0 0 26px}
.intro--edito{max-width:820px;font-size:1.02rem}
.intro--edito p{margin:0 0 .9em}
.intro--edito p:last-child{margin-bottom:0}

.shows{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}
.show{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.show__img{position:relative;display:block;aspect-ratio:4/5;overflow:hidden;
  background:linear-gradient(135deg,var(--brand),var(--brand-d))}
.show__img img{position:relative;z-index:1;width:100%;height:100%;object-fit:cover;display:block}
.show__body{padding:16px 18px 18px}
.show h3{margin:0 0 6px;font-size:1.1rem}
.show__meta{color:var(--muted);font-size:.9rem;margin:0 0 14px}

/* Fiche spectacle : héro image + titre */
.spectacle__hero{display:flex;gap:22px;align-items:flex-start;margin:14px 0 24px}
.spectacle__poster{flex:0 0 260px;aspect-ratio:3/4;border-radius:14px;overflow:hidden;position:relative;
  background:linear-gradient(135deg,var(--brand),var(--brand-d))}
.spectacle__poster img{position:relative;z-index:1;width:100%;height:100%;object-fit:cover;display:block}
.spectacle__poster .hn-ph__name{font-size:1.35rem}
.spectacle__headtxt{flex:1;min-width:0}
.tag a{color:#fff;text-decoration:underline}
@media(max-width:640px){.spectacle__hero{flex-direction:column}.spectacle__poster{flex-basis:auto;width:100%}}

.btn{display:inline-flex;align-items:center;height:40px;padding:0 18px;background:var(--brand);color:#fff;
  border-radius:8px;font-weight:600;font-size:.92rem}
.btn:hover{text-decoration:none;background:var(--brand-d)}
.btn--sm{height:32px;padding:0 12px;font-size:.85rem}

/* Dates table */
.dates{width:100%;border-collapse:collapse;margin:8px 0 22px;background:var(--card);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.dates th,.dates td{text-align:left;padding:11px 14px;border-bottom:1px solid var(--line);font-size:.94rem}
.dates thead th{background:#f3eefe;font-size:.78rem;text-transform:uppercase;letter-spacing:.03em;color:var(--muted)}
.dates tr:last-child td{border-bottom:0}
.dates time{font-variant-numeric:tabular-nums}
.ta-r{text-align:right}

/* Index A-Z */
.index-list{list-style:none;margin:0;padding:0;columns:2;column-gap:32px}
.index-list li{break-inside:avoid;padding:7px 0;border-bottom:1px solid var(--line)}
.index-list__n{color:var(--muted);font-size:.82rem}

/* Misc */
.empty{background:#fff;border:1px dashed var(--line);border-radius:12px;padding:22px;color:var(--muted)}
.pad,.block{scroll-margin-top:20px}
.back{margin:20px 0}
.disclaimer{color:var(--muted);font-size:.82rem}
.disclaimer--inline{margin-top:30px;padding-top:16px;border-top:1px solid var(--line)}

/* Footer */
.site-footer{background:#f3eefe;border-top:1px solid var(--line);padding:28px 0;margin-top:40px}
.site-footer p{margin:.4em 0;font-size:.86rem;color:var(--muted)}
.footer-net a{color:var(--brand)}

@media(max-width:640px){
  .hero h1{font-size:1.6rem}
  .index-list{columns:1}
  .datelist time{flex-basis:100%}
  .site-header__in{flex-direction:column;gap:10px}
}
