/* ── GRAIN ── */
    body::before {
      content:'';
      position:fixed; inset:0; z-index:0; pointer-events:none;
      background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
      opacity:.45;
    }

    /* ── BACK LINK ── */

    /* ══════════════════════════
       LAYOUT
    ══════════════════════════ */
    /* ── Layout catalogue ── */
    .page {
      max-width: 900px;
      margin: 0 auto;
      padding: calc(var(--nav-h) + 3rem) 2.5rem 4rem;
    }

    .page--fiche {
      position: relative; z-index: 1;
      max-width: 1100px;
      margin: 0 auto;
      padding: calc(var(--nav-h) + 3rem) 2.5rem 6rem;
    }

    /* ── HERO GRID ── */
    .hero {
      display: grid;
      grid-template-columns: 340px 1fr;
      gap: 5rem;
      align-items: start;
      margin-bottom: 5rem;
    }

    /* Cover */
    .cover-wrap {
      position: sticky;
      top: 3rem;
    }
    .cover-img {
      width: 100%;
      height: auto;
      display: block;
      filter: brightness(.95);
    }
    .cover-img--square   { aspect-ratio: 300 / 268; }
    .cover-img--portrait { aspect-ratio: 300 / 425; }
    .cover-placeholder {
      width: 100%; aspect-ratio: 1;
      background: linear-gradient(135deg, #1a1a1a, #333);
      display: flex; align-items: center; justify-content: center;
    }
    .cover-credit {
      font-size: .52rem; letter-spacing: .18em;
      color: rgba(240,237,232,.2); text-transform: uppercase;
      margin-top: .8rem; text-align: right;
    }

    /* Info */
    .info-col { padding-top: .5rem; }

    .eyebrow {
      font-size: .56rem; letter-spacing: .38em; text-transform: uppercase;
      color: var(--accent); display: flex; align-items: center; gap: .7rem;
      margin-bottom: 1.2rem;
    }
    .eyebrow::before { content:''; width:2rem; height:1px; background:var(--accent); }

    .album-title {
      font-family: 'Cormorant Garamond', serif;
      font-size: clamp(1.4rem, 2vw, 2.8rem);
      font-weight: 300;
      line-height: 1.1;
      letter-spacing: .06em;
      margin-bottom: .6rem;
    }

    .album-artist {
      font-family: 'Cormorant SC', serif;
      font-size: 1rem; font-weight: 300;
      letter-spacing: .3em;
      color: rgba(240,237,232,.45);
      margin-bottom: 2.5rem;
    }

    .album-desc {
      font-size: .88rem; line-height: 1.95;
      color: var(--grey);
      border-left: 1px solid rgba(212,185,122,.3);
      padding-left: 1.5rem;
      margin-bottom: 2.5rem;
    }

    .album-meta-grid {
      display: grid; grid-template-columns: 1fr 1fr 1fr;
      gap: .6rem 2rem;
      margin-bottom: 3rem;
      font-size: .72rem;
    }
    .meta-item { display: flex; flex-direction: column; gap: .2rem; }
    .meta-label { font-size: .52rem; letter-spacing: .28em; text-transform: uppercase; color: var(--accent); opacity: .7; }
    .meta-val { color: rgba(240,237,232,.65); }

    /* Champs longs (musiciens, techniques) — pleine largeur sous la grille */
    .meta-item--full {
      margin-top: .8rem;
      padding-top: .8rem;
      border-top: 1px solid var(--border);
      margin-bottom: .5rem;
    }
    .meta-val--musicians {
      display: flex;
      flex-wrap: wrap;
      gap: .15rem 0;
      margin-top: .25rem;
    }
    .meta-musician {
      font-size: .72rem;
      line-height: 1.75;
      color: rgba(240,237,232,.65);
      width: 50%;
      padding-right: 1.5rem;
      box-sizing: border-box;
    }
    @media (max-width: 600px) {
      .meta-musician { width: 100%; }
    }

    /* ══════════════════════════════════════
    /* ══════════════════════════
       PURCHASE BUTTONS
    ══════════════════════════ */
    .purchase-section {
      margin-bottom: 3rem;
    }
    .purchase-title {
      font-size: .56rem; letter-spacing: .35em; text-transform: uppercase;
      color: var(--grey); margin-bottom: 1.2rem;
      display: flex; align-items: center; gap: .8rem;
    }
    .purchase-title::after { content:''; flex:1; height:1px; background:var(--border); }

    .purchase-grid {
      display: flex;
      flex-direction: column;
      gap: .8rem;
    }

    .buy-btn {
      display: flex;
      flex-direction: column;
      align-items: flex-start;
      gap: .3rem;
      padding: 1.1rem 1.4rem;
      border: 1px solid var(--border);
      background: rgba(255,255,255,.03);
      cursor: pointer;
      text-align: left;
      text-decoration: none;
      transition: border-color .25s, background .25s;
      width: 100%;
      box-sizing: border-box;
      overflow: hidden;
    }
    .buy-btn:hover {
      border-color: var(--accent);
      background: rgba(212,185,122,.05);
    }
    .buy-btn .btn-label {
      font-size: .6rem; letter-spacing: .22em; text-transform: uppercase;
      color: var(--accent);
    }
    .buy-btn .btn-desc {
      font-family: 'Cormorant Garamond', serif;
      font-size: 1.05rem; font-weight: 300;
      color: var(--white);
    }
    .buy-btn .btn-price {
      font-size: .75rem; letter-spacing: .1em;
      color: rgba(240,237,232,.5);
      margin-top: .2rem;
    }
    .buy-btn .pp-logo {
      margin-top: .5rem;
      display: flex; align-items: center; gap: .4rem;
      font-size: .5rem; letter-spacing: .15em; text-transform: uppercase;
      color: rgba(240,237,232,.2);
    }
    .buy-btn .pp-logo svg { width:40px; opacity:.35; }

    /* PayPal SVG logo */
    .buy-group {
      border: 1px solid var(--border);
      background: rgba(255,255,255,.03);
      padding: 1.1rem 1.4rem;
    }
    .buy-group-label {
      font-size: .52rem; letter-spacing: .28em; text-transform: uppercase;
      color: var(--grey); margin-bottom: .9rem;
      padding-bottom: .6rem;
      border-bottom: 1px solid var(--border);
    }
    .buy-group-row {
      display: flex;
      flex-direction: column;
      gap: .8rem;
    }
    .buy-group .buy-btn {
      border: 1px solid var(--border);
      background: rgba(255,255,255,.02);
      padding: .8rem 1rem;
    }
    .buy-group .buy-btn:hover {
      border-color: var(--accent);
      background: rgba(212,185,122,.05);
    }
    .pp-svg { fill: #009cde; }
    .pp-svg2 { fill: #012169; }

    /* Bouton PayPal submit (achat / téléchargement album) */
    .pp-submit {
      display: inline-flex; align-items: center; gap: .5rem;
      font-family: 'DM Sans', sans-serif;
      font-size: .78rem; letter-spacing: .1em; text-transform: uppercase;
      font-weight: 300; line-height: 1;
      color: var(--accent);
      background: transparent;
      border: 1px solid rgba(212,185,122,.35);
      border-radius: 6px;
      padding: .38rem .95rem;
      cursor: pointer;
      transition: border-color .2s, background .2s;
      white-space: nowrap;
      flex-shrink: 0;
    }
    .pp-submit:hover { border-color: var(--accent); background: rgba(212,185,122,.08); }
    .pp-submit .pp-sep { width: 1px; height: 10px; background: rgba(212,185,122,.35); flex-shrink: 0; }
    .pp-submit .pp-label { line-height: 1; font-weight: 300; white-space: nowrap; }

    /* Mise en ligne des boutons sur grand écran */
    .buy-btn-inner {
      display: flex;
      flex-direction: column;
      gap: .3rem;
      width: 100%;
    }
    .buy-btn-row {
      display: flex;
      flex-direction: column;
      gap: .45rem;
      width: 100%;
    }
    .buy-btn-row .buy-btn-action { width: 100%; }
    .buy-form-row {
      display: flex;
      flex-direction: column;
      gap: .45rem;
      width: 100%;
      box-sizing: border-box;
    }
    .buy-form-row select { width: 100%; max-width: 100%; box-sizing: border-box; }
    .buy-btn-action { max-width: 100%; box-sizing: border-box; }
    @media (min-width: 700px) {
      .buy-btn-row {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        gap: 1.2rem;
      }
      .buy-btn-row .buy-btn-info { flex: 1; }
      .buy-btn-row .buy-btn-action { flex-shrink: 0; width: auto; }
    }

    /* ══════════════════════════
       PLAYER + TRACKLIST
    ══════════════════════════ */
    .section-title {
      font-size: 1rem; letter-spacing: .35em; text-transform: uppercase;
      color: var(--grey); margin-bottom: 1.5rem;
      display: flex; align-items: center; gap: .8rem;
    }
    .section-title::after { content:''; flex:1; height:1px; background:var(--border); }

    .section-subtitle {
      font-family: 'DM Sans', sans-serif;
      font-size: .65rem; letter-spacing: .25em; text-transform: uppercase;
      color: rgba(240,237,232,.25); margin-bottom: 1.2rem;
      display: flex; align-items: center; gap: .8rem;
    }
    .section-subtitle::after { content:''; flex:1; height:1px; background:var(--border); }

    .tracklist { margin-bottom: 3rem; }

    .track-row {
      display: grid;
      grid-template-columns: 2rem 1fr auto auto;
      align-items: center;
      gap: .8rem;
      padding: .85rem 0;
      border-bottom: 1px solid var(--border);
    }
    .track-row--partition { grid-template-columns: 2rem 1fr auto; }
    .track-row:first-child { border-top: 1px solid var(--border); }

    .t-num {
      font-size: .6rem; letter-spacing: .1em;
      color: var(--grey); text-align: right;
    }
    .t-name {
      font-family: 'Cormorant Garamond', serif;
      font-weight: 300; letter-spacing: .04em;
      display: flex; flex-direction: column; gap: .1rem;
    }
    .t-name--cd {
      flex-direction: row; align-items: baseline; gap: 0;
      font-size: 1rem;
    }
    .t-name--cd:has(.t-author) {
      flex-direction: column; align-items: flex-start; gap: .1rem;
    }
    .t-name .t-author {
      font-size: 1rem; font-style: normal; color: var(--white);
    }
    .t-name .t-title-line {
      display: flex; align-items: baseline; gap: 0;
      font-size: .95rem; font-style: italic; color: var(--accent); letter-spacing: .03em;
    }
    .t-name--cd .t-title-line--own {
      font-size: 1rem; font-style: normal; color: var(--white); letter-spacing: .04em;
    }
    .t-name .t-dur {
      font-size: .75rem; letter-spacing: .08em;
      color: var(--grey); margin-left: .5rem; font-weight: 300;
      font-style: normal;
    }

    /* Play button */
    .t-play {
      width: 26px; height: 26px;
      border: 1px solid rgba(255,255,255,.15); border-radius: 50%;
      background: transparent; cursor: pointer;
      display: flex; align-items: center; justify-content: center;
      color: rgba(240,237,232,.45); flex-shrink:0;
      transition: border-color .2s, color .2s;
    }
    .t-play:hover  { border-color: var(--accent); color: var(--accent); }
    .t-play.playing { border-color: var(--accent); color: var(--accent); background: rgba(212,185,122,.08); }
    .t-play svg { width:8px; height:8px; fill:currentColor; }

    /* Download button per track */
    .t-buy {
      display: inline-flex; align-items: center; gap: .45rem;
      font-family: 'DM Sans', sans-serif;
      font-size: .78rem; letter-spacing: .06em;
      color: var(--accent);
      background: transparent;
      border: 1px solid rgba(212,185,122,.4);
      border-radius: 6px;
      padding: .38rem .95rem;
      cursor: pointer;
      transition: border-color .2s, background .2s;
      white-space: nowrap;
      flex-shrink: 0;
    }
    .t-buy { display:none; } /* masqué — plus utilisé directement */
    .t-buy--panier {
      display: inline-flex; align-items: center; gap: .5rem;
      font-family: 'DM Sans', sans-serif;
      font-size: .78rem; letter-spacing: .1em; text-transform: uppercase;
      font-weight: 300; line-height: 1;
      color: var(--accent);
      background: transparent;
      border: 1px solid rgba(212,185,122,.35);
      border-radius: 6px;
      padding: .38rem .95rem;
      cursor: pointer;
      transition: border-color .2s, background .2s;
      white-space: nowrap;
      flex-shrink: 0;
    }
    .t-buy--panier:hover { border-color: var(--accent); background: rgba(212,185,122,.08); }
    .t-buy--panier svg { width:13px; height:13px; stroke:var(--accent); fill:none; stroke-width:1.5; stroke-linecap:round; stroke-linejoin:round; flex-shrink:0; }
    .t-buy--panier .t-panier-sep { width:1px; height:10px; background:rgba(212,185,122,.35); flex-shrink:0; }
    .t-buy--panier .t-panier-prix { font-weight:300; line-height:1; white-space:nowrap; }

    /* ── STICKY MINI PLAYER ── */
    .mini-player {
      position: fixed;
      bottom: 0; left: 0; right: 0;
      z-index: 500;
      background: rgba(7,7,7,.97);
      border-top: 1px solid var(--border);
      padding: .9rem 2.5rem;
      display: flex; align-items: center; gap: 1.5rem;
      transform: translateY(100%);
      transition: transform .35s ease;
    }
    .mini-player.visible { transform: translateY(0); }

    .mp-cover {
      width: 40px; height: 40px; flex-shrink:0;
      object-fit: cover;
    }
    .mp-info { flex:1; min-width:0; }
    .mp-title {
      font-family: 'Cormorant Garamond', serif;
      font-size: .95rem; font-weight:300;
      white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
    }
    .mp-album { font-size: .58rem; letter-spacing:.1em; color:var(--grey); }

    .mp-controls { display:flex; align-items:center; gap:.8rem; flex-shrink:0; }
    .mp-btn {
      width:32px; height:32px; background:transparent; border:none; cursor:pointer;
      display:flex; align-items:center; justify-content:center;
      color:rgba(240,237,232,.55); transition:color .2s; padding:0;
    }
    .mp-btn:hover { color:var(--white); }
    .mp-btn.play-main {
      width:40px; height:40px; background:var(--white); border-radius:50%; color:var(--black);
    }
    .mp-btn.play-main:hover { background:var(--accent); }
    .mp-btn svg { width:13px; height:13px; fill:currentColor; }
    .mp-btn.play-main svg { width:12px; height:12px; }

    .mp-progress {
      flex:1; display:flex; align-items:center; gap:.8rem; min-width:0;
    }
    .mp-time { font-size:.57rem; letter-spacing:.08em; color:var(--grey); flex-shrink:0; }
    .mp-bar {
      flex:1; height:2px; background:rgba(255,255,255,.1);
      position:relative; cursor:pointer; border-radius:1px;
    }
    .mp-fill {
      height:100%; background:var(--accent); border-radius:1px;
      width:0%; transition:width .2s linear; pointer-events:none;
    }

    .mp-vol { display:flex; align-items:center; gap:.5rem; flex-shrink:0; }
    .mp-vol svg { width:11px; height:11px; fill:rgba(240,237,232,.3); }
    input[type=range].vol {
      -webkit-appearance:none; width:55px; height:2px;
      background:rgba(255,255,255,.1); outline:none; border-radius:1px; cursor:pointer;
    }
    input[type=range].vol::-webkit-slider-thumb {
      -webkit-appearance:none; width:9px; height:9px;
      border-radius:50%; background:var(--white); cursor:pointer;
    }

    /* ══════════════════════════
       PAYPAL FORMS (hidden)
    ══════════════════════════ */
    .paypal-forms { display:none; }

    /* ══════════════════════════
       RESPONSIVE
    ══════════════════════════ */
    @media(max-width:800px) {
      .hero { grid-template-columns:1fr; gap:2.5rem; }
      .cover-wrap { position:static; max-width:280px; }
      .purchase-grid { grid-template-columns:1fr; }
      .buy-btn { grid-column: auto !important; }
      .mini-player { padding:.8rem 1.2rem; gap:1rem; }
      .mp-progress { display:none; }
      .track-row {
        grid-template-columns: 1.5rem 1fr;
        grid-template-rows: auto auto;
        row-gap: .45rem;
        align-items: start;
      }
      .t-num        { grid-row: 1; grid-column: 1; padding-top: .15rem; }
      .t-name       { grid-row: 1; grid-column: 2; }
      .t-play       { grid-row: 2; grid-column: 2; justify-self: start; }
      .t-buy-form,
      .t-buy        { grid-row: 2; grid-column: 2; justify-self: start; margin-left: calc(26px + .5rem); }
      .t-name--cd   { flex-direction: row; align-items: baseline; flex-wrap: nowrap; overflow: hidden; }
      .t-name--cd .t-author     { font-size: .82rem; white-space: nowrap; flex-shrink: 0; }
      .t-name--cd .t-title-line { font-size: .85rem; font-style: normal; color: var(--white); display: flex; align-items: baseline; overflow: hidden; flex: 1; white-space: nowrap; }
      .t-name--cd .t-title-text { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
      .t-name--cd .t-dur        { font-size: .65rem; margin-left: .4rem; white-space: nowrap; flex-shrink: 0; }
    }

    /* ══════════════════════════
       VIDÉOS
    ══════════════════════════ */
    /* .videos-grid, .v-card, .video-thumb-wrap, .video-thumb,
       .v-play, .v-ring, .v-tri, .v-caption → common.css */

    /* ══════════════════════════
       REVUE DE PRESSE
    ══════════════════════════ */
    .press-list {
      margin-top: 1.5rem;
      display: flex;
      flex-direction: column;
      gap: 0;
    }
    .press-item {
      padding: 1.4rem 0;
      border-bottom: 1px solid var(--border);
    }
    .press-item:first-child { border-top: none; }
    .press-quote {
      font-family: 'Cormorant Garamond', serif;
      font-size: 1.05rem;
      font-weight: 300;
      font-style: italic;
      line-height: 1.75;
      color: var(--fg);
      margin-bottom: .7rem;
    }
    .press-meta {
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      gap: .4rem;
      font-family: 'DM Sans', sans-serif;
      font-size: .62rem;
      letter-spacing: .12em;
      text-transform: uppercase;
    }
    .press-author { color: var(--accent); }
    .press-sep { color: var(--border); }
    .press-source {
      color: rgba(240,237,232,.5);
      text-decoration: none;
      transition: color .2s;
    }
    .press-source:hover { color: var(--accent); }
    .press-date { color: rgba(240,237,232,.3); }


    /* ══════════════════════════
       FOOTER
    ══════════════════════════ */

    .photo-credit {
      position: fixed;
      bottom: 1rem;
      right: 1rem;
      z-index: 6;
      font-size: .5rem;
      letter-spacing: .15em;
      color: rgba(240,237,232,.2);
      pointer-events: none;
      writing-mode: vertical-rl;
    }

  /* ── Label de format dans les liens associés ── */
  .cat-type-label {
    font-family: 'DM Sans', sans-serif;
    font-size: .6rem;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--accent);
    opacity: .7;
    margin-bottom: .6rem;
  }

  /* .v-caption, .v-titl, .v-piv → common.css */
/* ══════════════════════════════════════════════════════════
   stal-additions.css
   Contenu à AJOUTER à la fin de css/stal.css

   Source : deux blocs <style> inline extraits de stal.php
   ══════════════════════════════════════════════════════════ */


/* ── BLOC A — Grille catalogue (était ~ligne 144 de stal.php) ── */

.catalogue-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 2rem;
  margin-top: 1.5rem;
}
.cat-item {
  display: block;
  text-decoration: none;
  color: inherit;
}
.cat-item:hover { text-decoration: none; }
.cat-cover-wrap {
  position: relative;
  border: 1px solid var(--border);
  overflow: hidden;
  transition: border-color .25s;
}
.cat-item:hover .cat-cover-wrap { border-color: var(--accent); }
.cat-cover {
  width: 100%;
  height: auto;
  display: block;
  transition: filter .3s, transform .3s;
  filter: brightness(.85);
}
.cat-item:hover .cat-cover { filter: brightness(1); transform: scale(1.03); }
.cat-overlay {
  position: absolute; inset: 0;
  display: flex; align-items: flex-end; justify-content: flex-end;
  padding: .6rem;
  opacity: 0;
  transition: opacity .25s;
}
.cat-item:hover .cat-overlay { opacity: 1; }
.cat-arrow {
  font-family: 'DM Sans', sans-serif;
  font-size: .7rem;
  letter-spacing: .15em;
  color: var(--accent);
}
.cat-titre {
  display: block;
  font-family: 'Cormorant Garamond', serif;
  font-size: 1rem;
  font-weight: 300;
  letter-spacing: .04em;
  margin-top: .5rem;
  color: var(--white);
}
.cat-artiste {
  display: block;
  font-size: .62rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--grey);
  margin-top: .2rem;
}

/* Liste (partitions / livres) */
.catalogue-list { display: flex; flex-direction: column; gap: .8rem; margin-top: 1.5rem; }
.cat-list-item {
  display: flex;
  align-items: center;
  gap: 1rem;
  text-decoration: none;
  color: inherit;
  padding: .6rem .8rem;
  border: 1px solid var(--border);
  transition: border-color .25s;
}
.cat-list-item:hover { border-color: var(--accent); text-decoration: none; }
.cat-list-cover { width: 36px; flex-shrink: 0; }
.cat-list-cover img { width: 100%; height: auto; display: block; }
.cat-list-info { flex: 1; display: flex; flex-direction: column; gap: .2rem; }
.section-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.5rem;
  font-weight: 300;
  letter-spacing: .08em;
  color: var(--white);
  padding: 0 2rem;
}
.section-subtitle {
  font-size: .62rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--grey);
  padding: 0 2rem;
}



/* ── BLOC B — Aperçus, sommaire, revue de presse (était ~ligne 942 de stal.php) ── */

.preview-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 1rem;
  margin-top: 1.5rem;
}
.preview-item {
  display: block;
  border: 1px solid var(--border);
  overflow: hidden;
  transition: border-color .25s;
}
.preview-item:hover { border-color: var(--accent); }
.preview-item img {
  width: 100%; height: auto; display: block;
  filter: brightness(.9);
  transition: filter .3s, transform .3s;
}
.preview-item:hover img { filter: brightness(1); transform: scale(1.02); }

.toc-list { display: flex; flex-direction: column; margin-top: 1.5rem; }
.toc-item {
  display: grid;
  grid-template-columns: 2rem 1fr;
  align-items: baseline;
  gap: .8rem;
  padding: .7rem 0;
  border-bottom: 1px solid var(--border);
}
.toc-item:first-child { border-top: 1px solid var(--border); }
.toc-item--highlight {
  background: rgba(212,185,122,.04);
  margin: 0 -.5rem;
  padding-left: .5rem;
  padding-right: .5rem;
}
.toc-num {
  font-size: .6rem;
  letter-spacing: .1em;
  color: var(--grey);
  text-align: right;
  font-family: 'DM Sans', sans-serif;
}
.toc-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1rem;
  font-weight: 300;
  letter-spacing: .04em;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: .4rem;
}
.toc-inst { font-size: .65rem; letter-spacing: .07em; color: var(--grey); font-family: 'DM Sans', sans-serif; }
.toc-article {
  width: 100%;
  font-size: .95rem;
  font-style: italic;
  color: var(--accent);
  letter-spacing: .03em;
  margin-top: .15rem;
}

