/* ============================================================
   ANDRE RENY — andre-reny.com
   Refonte 2026 « Encre de Chine »
   ------------------------------------------------------------
   Palette :
     --encre    : fond bleu-noir profond (encre de Chine)
     --panneau  : surfaces légèrement éclaircies
     --papier   : crème papier (texte principal)
     --lavis    : gris lavis (texte secondaire)
     --or       : doré discret (cadres, accents)
     --rouge    : rouge basque (survols, touches fines)
   Typo :
     Cormorant Garamond (titres) + Karla (texte / interface)
   ============================================================ */

   :root{
    --encre:   #13161B;
    --panneau: #1B1F26;
    --papier:  #F1EAD9;
    --lavis:   #9AA3AD;
    --or:      #C8A567;
    --rouge:   #A8323A;
    --filet:   rgba(241,234,217,.16);
    --display: "Cormorant Garamond", Georgia, serif;
    --texte:   "Karla", "Helvetica Neue", Arial, sans-serif;
  }
  
  *{ margin:0; padding:0; box-sizing:border-box; }
  html{ scroll-behavior:smooth; }
  @media (prefers-reduced-motion: reduce){
    html{ scroll-behavior:auto; }
    *, *::before, *::after{ animation:none !important; transition:none !important; }
  }
  
  body{
    background:var(--encre);
    color:var(--papier);
    font-family:var(--texte);
    font-size:17px;
    line-height:1.75;
    -webkit-font-smoothing:antialiased;
    text-align:left;
  }
  
  img{ max-width:100%; height:auto; display:block; }
  a{ color:var(--or); text-decoration:none; outline:none; }
  a:hover{ color:var(--papier); }
  a:focus-visible, button:focus-visible{
    outline:2px solid var(--or); outline-offset:3px; border-radius:2px;
  }
  
  /* ------------------------------------------------------------
     NAVIGATION FIXE
     Transparente en haut de page, encre translucide au défilement
     (classe .est-defilee ajoutée par un petit script inline)
     ------------------------------------------------------------ */
  .rg-nav{
    position:fixed; top:0; left:0; right:0; z-index:100;
    display:flex; align-items:center; justify-content:space-between;
    gap:16px; padding:14px 28px;
    transition:background .35s ease, box-shadow .35s ease;
  }
  .rg-nav.est-defilee{
    background:rgba(19,22,27,.88);
    -webkit-backdrop-filter:blur(10px); backdrop-filter:blur(10px);
    box-shadow:0 1px 0 var(--filet);
  }
  .rg-nav__marque{
    font-family:var(--display); font-size:22px; font-weight:600;
    letter-spacing:.04em; color:var(--papier); white-space:nowrap;
  }
  .rg-nav__marque em{ color:var(--or); font-style:normal; }
  .rg-nav__liens{ display:flex; flex-wrap:wrap; gap:4px 22px; align-items:center; }
  .rg-nav__liens a{
    font-size:12px; letter-spacing:.22em; text-transform:uppercase;
    color:var(--lavis); padding:6px 0; position:relative;
  }
  .rg-nav__liens a:hover{ color:var(--papier); }
  .rg-nav__liens a.actif{ color:var(--or); }
  .rg-nav__liens a.actif::after{
    content:""; position:absolute; left:0; right:0; bottom:0;
    height:1px; background:var(--or);
  }
  .rg-nav__liens a.rg-lang{
    border:1px solid var(--filet); border-radius:3px;
    padding:4px 9px; letter-spacing:.14em;
  }
  
  /* ------------------------------------------------------------
     HERO — pleine page sur l'accueil, réduit sur les autres pages
     ------------------------------------------------------------ */
  .rg-hero{
    position:relative; overflow:hidden;
    min-height:92vh;
    display:flex; flex-direction:column;
    align-items:center; justify-content:center;
    text-align:center; padding:120px 24px 80px;
  }
  .rg-hero--court{ min-height:58vh; }
  .rg-hero__fond{
    position:absolute; inset:0; z-index:-2;
    background-size:cover; background-position:center 22%;
    filter:grayscale(72%) contrast(1.05);
    opacity:.38;
  }
  /* Voile « lavis » : dégradé d'encre qui fond l'image dans la page */
  .rg-hero__voile{
    position:absolute; inset:0; z-index:-1;
    background:
      radial-gradient(ellipse at 50% 30%, rgba(19,22,27,0) 0%, rgba(19,22,27,.55) 62%, rgba(19,22,27,.92) 100%),
      linear-gradient(to bottom, rgba(19,22,27,.55) 0%, rgba(19,22,27,.15) 35%, var(--encre) 96%);
  }
  .rg-hero__sur-titre{
    font-size:12px; letter-spacing:.38em; text-transform:uppercase;
    color:var(--lavis); margin-bottom:22px;
  }
  .rg-hero h1{
    font-family:var(--display); font-weight:500;
    font-size:clamp(54px, 9.5vw, 118px);
    line-height:1.02; letter-spacing:.015em;
    text-transform:uppercase;
  }
  .rg-hero__dates{
    display:flex; align-items:center; gap:18px;
    margin:26px 0 14px;
    font-family:var(--display); font-style:italic;
    font-size:clamp(19px, 2.4vw, 26px); color:var(--or);
  }
  .rg-hero__dates::before, .rg-hero__dates::after{
    content:""; width:64px; height:1px; background:var(--or); opacity:.65;
  }
  .rg-hero__sous-titre{
    font-size:14px; letter-spacing:.26em; text-transform:uppercase;
    color:var(--papier); opacity:.85;
  }
  .rg-hero__indice{
    position:absolute; bottom:26px; left:50%; transform:translateX(-50%);
    color:var(--lavis); font-size:20px; line-height:1;
    animation:rg-flotte 2.6s ease-in-out infinite;
  }
  @keyframes rg-flotte{
    0%,100%{ transform:translate(-50%,0); opacity:.55; }
    50%{ transform:translate(-50%,8px); opacity:1; }
  }
  
  /* ------------------------------------------------------------
     STRUCTURE DES SECTIONS
     ------------------------------------------------------------ */
  .rg-section{ max-width:1180px; margin:0 auto; padding:56px 24px; }
  .rg-section--etroite{ max-width:760px; }
  
  /* Titre de section avec « trait de plume » doré */
  .rg-titre{
    font-family:var(--display); font-weight:500;
    font-size:clamp(30px, 4.2vw, 44px);
    letter-spacing:.02em; text-align:center; margin-bottom:10px;
  }
  .rg-titre--gauche{ text-align:left; }
  .rg-trait{
    width:70px; height:14px; margin:0 auto 36px; display:block;
  }
  .rg-trait--gauche{ margin-left:0; }
  .rg-sous-texte{
    text-align:center; color:var(--lavis); max-width:680px;
    margin:-22px auto 40px;
  }
  
  /* ------------------------------------------------------------
     FILTRE DE GALERIE (select PHP existant, simplement re-stylé)
     ------------------------------------------------------------ */
  .rg-filtre{ display:flex; justify-content:center; margin:6px 0 34px; }
  .form_select{
    -webkit-appearance:none; appearance:none;
    background:var(--panneau) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23C8A567' fill='none' stroke-width='1.5'/%3E%3C/svg%3E") no-repeat right 16px center;
    border:1px solid var(--filet); border-radius:999px;
    color:var(--papier); font-family:var(--texte); font-size:14px;
    letter-spacing:.06em; padding:11px 46px 11px 22px;
    max-width:92vw; cursor:pointer;
    transition:border-color .25s;
  }
  .form_select:hover, .form_select:focus{ border-color:var(--or); outline:none; }
  .form_select option{ background:var(--panneau); color:var(--papier); }
  
  /* ------------------------------------------------------------
     CARTES DES GALERIES (couvertures de chaque série de tableaux)
     ------------------------------------------------------------ */
  .rg-galeries{
    display:grid; gap:26px;
    grid-template-columns:repeat(auto-fill, minmax(260px, 1fr));
    margin-top:14px;
  }
  .rg-carte{
    display:block; position:relative;
    background:var(--panneau);
    border:1px solid var(--filet);
    padding:10px;                       /* marie-louise du cadre */
    transition:transform .3s ease, border-color .3s ease;
  }
  .rg-carte:hover{ transform:translateY(-4px); border-color:var(--or); }
  .rg-carte img{
    width:100%; aspect-ratio:4/3; object-fit:cover;
    filter:saturate(.96);
  }
  .rg-carte__nom{
    display:block; text-align:center;
    font-family:var(--display); font-size:20px; font-style:italic;
    color:var(--papier); padding:14px 6px 8px;
  }
  .rg-carte:hover .rg-carte__nom{ color:var(--or); }
  
  /* ------------------------------------------------------------
     TABLEAU SEUL (vue ?tableau=XXX)
     ------------------------------------------------------------ */
  .rg-oeuvre{ text-align:center; }
  .rg-oeuvre__cadre{
    display:inline-block; background:var(--panneau);
    border:1px solid var(--filet); padding:16px;
    box-shadow:0 24px 60px rgba(0,0,0,.5);
  }
  .rg-oeuvre__cadre img{ margin:0 auto; max-height:78vh; width:auto; max-width:100%; }
  .rg-oeuvre__titre{
    font-family:var(--display); font-style:italic;
    font-size:26px; margin:22px 0 4px;
  }
  .rg-oeuvre__infos{ color:var(--lavis); font-size:14px; }
  .rg-retour{
    display:inline-block; margin-top:26px;
    font-size:12px; letter-spacing:.22em; text-transform:uppercase;
    border-bottom:1px solid var(--or); padding-bottom:3px;
  }
  
  /* ------------------------------------------------------------
     NANOGALLERY2 — harmonisation avec le thème
     ------------------------------------------------------------ */
  .nGY2 .nGY2Gallery{ text-align:center; }
  .nGY2 .nGY2GThumbnailImage{ background:var(--panneau); }
  .nGY2 .nGY2GThumbnail{ border:1px solid rgba(241,234,217,.10); background:var(--panneau); }
  .nGY2 .nGY2GThumbnailLabel{ font-family:var(--display) !important; font-style:italic; }
  .nGY2 .nGY2GalleryMoreButton .nGY2GalleryMoreButtonAnnotation{
    background:transparent; border:1px solid var(--or); border-radius:999px;
    color:var(--or); font-family:var(--texte); font-size:12px;
    letter-spacing:.2em; text-transform:uppercase; padding:10px 26px;
  }
  .nGY2 .nGY2GalleryMoreButton .nGY2GalleryMoreButtonAnnotation:hover{
    background:var(--or); color:var(--encre);
  }
  
  /* ------------------------------------------------------------
     PAGE BIOGRAPHIE
     ------------------------------------------------------------ */
  .rg-bio p{ margin-bottom:1.6em; color:var(--papier); }
  .rg-bio p:first-of-type::first-letter{
    font-family:var(--display); float:left;
    font-size:74px; line-height:.82;
    padding:8px 12px 0 0; color:var(--or);
  }
  .rg-figure{ margin:48px 0; }
  .rg-figure img{ margin:0 auto; border:1px solid var(--filet); }
  .rg-figure figcaption{
    text-align:center; margin-top:12px;
    font-family:var(--display); font-style:italic;
    font-size:16px; color:var(--lavis);
  }
  .rg-signature{
    font-family:var(--display); font-style:italic; font-size:20px;
    color:var(--or); text-align:right; margin-top:8px;
  }
  
  /* Grille d'archives photographiques */
  .rg-archives{
    display:grid; gap:18px;
    grid-template-columns:repeat(auto-fill, minmax(220px, 1fr));
  }
  .rg-archives a{
    display:block; background:var(--panneau);
    border:1px solid var(--filet); padding:8px;
    transition:border-color .3s, transform .3s;
  }
  .rg-archives a:hover{ border-color:var(--or); transform:translateY(-3px); }
  .rg-archives img{ width:100%; aspect-ratio:4/3; object-fit:cover; filter:grayscale(18%); }
  .rg-archives figcaption{
    font-size:12.5px; color:var(--lavis); text-align:center; padding:9px 4px 3px;
  }
  
  /* ------------------------------------------------------------
     PAGE MUSIQUE — listes de pistes + lecteur fixe en bas
     ------------------------------------------------------------ */
  .rg-pistes{ list-style:none; counter-reset:piste; }
  .rg-pistes li{ border-bottom:1px solid var(--filet); }
  .rg-pistes li:first-child{ border-top:1px solid var(--filet); }
  .rg-piste{
    width:100%; display:flex; align-items:center; gap:16px;
    background:none; border:none; cursor:pointer;
    font-family:var(--texte); color:var(--papier); text-align:left;
    padding:15px 10px; transition:background .2s;
  }
  .rg-piste:hover{ background:rgba(241,234,217,.05); }
  .rg-piste::before{
    counter-increment:piste; content:counter(piste, decimal-leading-zero);
    font-family:var(--display); font-style:italic;
    color:var(--lavis); font-size:15px; min-width:30px;
  }
  .rg-piste__txt{ flex:1; min-width:0; }
  .rg-piste__titre{ display:block; font-size:16px; letter-spacing:.01em; }
  .rg-piste__sous{ display:block; font-size:12.5px; color:var(--lavis); margin-top:2px; }
  .rg-piste__icone{
    width:30px; height:30px; flex:none; border-radius:50%;
    border:1px solid var(--filet);
    display:flex; align-items:center; justify-content:center;
    color:var(--or); font-size:10px;
    transition:border-color .2s, background .2s;
  }
  .rg-piste:hover .rg-piste__icone{ border-color:var(--or); }
  /* Piste en cours de lecture */
  .rg-pistes li.en-lecture .rg-piste__titre{ color:var(--or); }
  .rg-pistes li.en-lecture .rg-piste__icone{ background:var(--or); color:var(--encre); border-color:var(--or); }
  
  /* Lecteur fixe en bas d'écran */
  .rg-lecteur{
    position:fixed; left:0; right:0; bottom:0; z-index:90;
    background:rgba(27,31,38,.96);
    -webkit-backdrop-filter:blur(10px); backdrop-filter:blur(10px);
    border-top:1px solid var(--filet);
    padding:12px 20px calc(12px + env(safe-area-inset-bottom));
    display:flex; align-items:center; gap:16px;
    transform:translateY(110%); transition:transform .4s ease;
  }
  .rg-lecteur.visible{ transform:translateY(0); }
  .rg-lecteur__btn{
    background:none; border:1px solid var(--filet); border-radius:50%;
    width:38px; height:38px; flex:none; cursor:pointer;
    color:var(--papier); font-size:13px; line-height:1;
    display:flex; align-items:center; justify-content:center;
    transition:border-color .2s, background .2s;
  }
  .rg-lecteur__btn:hover{ border-color:var(--or); color:var(--or); }
  .rg-lecteur__btn--lecture{
    width:48px; height:48px; background:var(--or);
    color:var(--encre); border-color:var(--or); font-size:16px;
  }
  .rg-lecteur__btn--lecture:hover{ background:var(--papier); color:var(--encre); }
  .rg-lecteur__infos{ flex:1; min-width:0; }
  .rg-lecteur__titre{
    font-family:var(--display); font-style:italic; font-size:17px;
    white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
  }
  .rg-lecteur__barre-zone{ display:flex; align-items:center; gap:10px; margin-top:5px; }
  .rg-lecteur__temps{
    font-size:11px; color:var(--lavis); min-width:38px;
    font-variant-numeric:tabular-nums;
  }
  .rg-lecteur__barre{
    flex:1; height:14px; display:flex; align-items:center; cursor:pointer;
  }
  .rg-lecteur__rail{
    width:100%; height:3px; background:rgba(241,234,217,.18);
    border-radius:2px; overflow:hidden;
  }
  .rg-lecteur__avancement{
    height:100%; width:0%; background:var(--or); border-radius:2px;
  }
  
  /* ------------------------------------------------------------
     PIED DE PAGE
     ------------------------------------------------------------ */
  .rg-pied{
    border-top:1px solid var(--filet);
    margin-top:70px; padding:46px 24px 60px;
    text-align:center;
  }
  .rg-pied__liens{
    display:flex; flex-wrap:wrap; justify-content:center;
    gap:8px 26px; margin-bottom:26px;
  }
  .rg-pied__liens a{
    font-size:12px; letter-spacing:.22em; text-transform:uppercase;
    color:var(--lavis);
  }
  .rg-pied__liens a:hover{ color:var(--or); }
  .rg-pied__mention{ color:var(--lavis); font-size:13px; }
  .rg-pied__mention a{ color:var(--lavis); border-bottom:1px solid var(--filet); }
  .rg-pied__mention a:hover{ color:var(--or); border-color:var(--or); }
  .rg-pied__fleur{
    font-family:var(--display); font-style:italic;
    color:var(--or); font-size:18px; margin-bottom:14px;
  }
  
  /* ------------------------------------------------------------
     RESPONSIVE
     ------------------------------------------------------------ */
  @media (max-width:720px){
    .rg-nav{ flex-direction:column; padding:12px 16px; gap:8px; }
    .rg-nav__liens{ justify-content:center; gap:4px 16px; }
    .rg-hero{ min-height:86vh; padding-top:150px; }
    .rg-section{ padding:40px 18px; }
    .rg-lecteur{ gap:10px; padding-left:12px; padding-right:12px; }
    .rg-lecteur__btn{ width:34px; height:34px; }
    .rg-lecteur__btn--lecture{ width:44px; height:44px; }
  }
  
  /* ------------------------------------------------------------
     LIVRE D'OR — onglets, messages, pagination
     ------------------------------------------------------------ */
  .rg-onglets{
    display:flex; justify-content:center; flex-wrap:wrap;
    gap:14px; margin-bottom:40px;
  }
  .rg-onglets a{
    font-size:12px; letter-spacing:.2em; text-transform:uppercase;
    border:1px solid var(--filet); border-radius:999px;
    padding:11px 26px; color:var(--lavis);
    transition:border-color .25s, color .25s, background .25s;
  }
  .rg-onglets a:hover{ border-color:var(--or); color:var(--or); }
  .rg-onglets a.actif{
    border-color:var(--or); background:var(--or); color:var(--encre);
  }
  
  /* Carte d'un message du livre d'or */
  .rg-message{
    background:var(--panneau); border:1px solid var(--filet);
    border-left:3px solid var(--or);
    padding:22px 26px; margin-bottom:18px;
  }
  .rg-message__nom{
    font-family:var(--display); font-style:italic;
    font-size:19px; color:var(--or); margin-bottom:8px;
  }
  .rg-message__texte{ color:var(--papier); }
  
  .rg-vide{
    text-align:center; color:var(--lavis);
    font-family:var(--display); font-style:italic; font-size:20px;
    padding:30px 0;
  }
  
  .rg-pagination{
    text-align:center; margin-top:26px;
    font-size:13px; color:var(--lavis);
  }
  .rg-pagination a{
    display:inline-block; margin:0 4px;
    border:1px solid var(--filet); border-radius:3px;
    padding:5px 10px; color:var(--lavis);
  }
  .rg-pagination a:hover{ border-color:var(--or); color:var(--or); }
  .rg-pagination .courant{
    display:inline-block; margin:0 4px;
    border:1px solid var(--or); border-radius:3px;
    padding:5px 10px; color:var(--or);
  }
  
  /* ------------------------------------------------------------
     FORMULAIRES (livre d'or, contact)
     ------------------------------------------------------------ */
  .rg-form{ max-width:560px; margin:0 auto; text-align:left; }
  .rg-form__champ{ margin-bottom:24px; }
  .rg-form label, .rg-form__etiquette{
    display:block; font-size:12px; letter-spacing:.18em;
    text-transform:uppercase; color:var(--lavis); margin-bottom:8px;
  }
  .rg-form__aide{ font-size:12.5px; color:var(--lavis); margin-top:6px; }
  .rg-form input[type=text], .rg-form textarea, .inputtext{
    width:100%; box-sizing:border-box;
    background:var(--panneau); border:1px solid var(--filet);
    border-radius:4px; color:var(--papier);
    font-family:var(--texte); font-size:15px;
    padding:12px 14px; transition:border-color .25s;
  }
  .rg-form input[type=text]:focus, .rg-form textarea:focus{
    border-color:var(--or); outline:none;
  }
  .rg-form textarea{ min-height:170px; resize:vertical; }
  /* Le captcha cryptographp est une image sombre : on le pose sur fond papier */
  .rg-captcha{
    display:inline-block; background:#FFF; border-radius:4px;
    padding:8px; margin-bottom:12px;
  }
  .rg-form input[name=code]{ width:120px; }
  .rg-bouton, .rg-form input[type=submit]{
    display:inline-block; cursor:pointer;
    background:var(--or); color:var(--encre);
    border:1px solid var(--or); border-radius:999px;
    font-family:var(--texte); font-size:13px; font-weight:700;
    letter-spacing:.18em; text-transform:uppercase;
    padding:13px 34px; transition:background .25s, color .25s;
  }
  .rg-bouton:hover, .rg-form input[type=submit]:hover{
    background:var(--papier); border-color:var(--papier);
  }
  .rg-alerte{
    text-align:center; padding:16px 20px; margin:0 auto 30px;
    max-width:560px; border-radius:4px; font-size:15px;
  }
  .rg-alerte--ok{
    background:rgba(200,165,103,.12); border:1px solid var(--or); color:var(--papier);
  }
  .rg-alerte--erreur{
    background:rgba(168,50,58,.14); border:1px solid var(--rouge); color:var(--papier);
  }
  
  /* ------------------------------------------------------------
     PAGE CONTACT — carte d'adresse
     ------------------------------------------------------------ */
  .rg-contact{
    max-width:480px; margin:0 auto; text-align:center;
    background:var(--panneau); border:1px solid var(--filet);
    padding:40px 34px;
  }
  .rg-contact__nom{
    font-family:var(--display); font-size:28px; font-weight:500;
    margin-bottom:4px;
  }
  .rg-contact__role{
    font-size:12px; letter-spacing:.22em; text-transform:uppercase;
    color:var(--lavis); margin-bottom:24px;
  }
  .rg-contact__adresse{ color:var(--papier); line-height:1.9; margin-bottom:22px; }
  .rg-contact__note{ color:var(--lavis); font-size:14px; margin:22px 0; }
  .rg-contact__photo{ margin:0 auto 36px; max-width:480px; }
  .rg-contact__photo img{ border:1px solid var(--filet); margin:0 auto; }
  
  /* ------------------------------------------------------------
     GRILLE DES TABLEAUX — rangées justifiées façon nanogallery2
     Le JS (reny-galerie.js) fixe width/height de chaque vignette
     pour que chaque rangée remplisse exactement la largeur,
     sans recadrer les images. Le CSS ci-dessous sert d'état
     d'attente avant le premier calage.
     IMPORTANT : gap = 14px, en phase avec la constante GAP du JS.
     ------------------------------------------------------------ */
  .rg-grille{
    display:flex; flex-wrap:wrap; justify-content:center;
    gap:14px;
  }
  .rg-vignette{
    position:relative; display:block; overflow:hidden;
    height:230px;                         /* avant calage JS */
    background:var(--panneau);
    border:1px solid rgba(241,234,217,.10);
    padding:7px;                          /* marie-louise du cadre */
    transition:border-color .3s ease;
  }
  .rg-vignette:hover{ border-color:var(--or); }
  .rg-vignette img{
    height:100%; width:auto; max-width:none; display:block;
    transition:transform .45s ease;
  }
  /* Une fois la grille calée par le JS, l'image épouse son cadre */
  .rg-grille.est-calee .rg-vignette img{ width:100%; height:100%; }
  .rg-vignette:hover img{ transform:scale(1.045); }
  .rg-vignette.est-cachee{ display:none; }
  .rg-vignette__titre{
    position:absolute; left:7px; right:7px; bottom:7px;
    padding:26px 12px 9px;
    background:linear-gradient(to top, rgba(19,22,27,.85), rgba(19,22,27,0));
    font-family:var(--display); font-style:italic; font-size:16px;
    color:var(--papier); text-align:left;
    white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
    opacity:0; transition:opacity .3s ease;
  }
  .rg-vignette:hover .rg-vignette__titre{ opacity:1; }
  @media (hover:none){ .rg-vignette__titre{ opacity:1; } } /* tactile : titre toujours visible */
  @media (max-width:720px){ .rg-vignette{ height:150px; } } /* avant calage JS ; ensuite hauteurCible() prend le relais */
  
  .rg-grille__plus{ display:block; margin:38px auto 0; }
  
  /* ------------------------------------------------------------
     VISIONNEUSE DE TABLEAUX (lightbox maison)
     ------------------------------------------------------------ */
  body.rg-noscroll{ overflow:hidden; }
  
  .rg-visionneuse{
    position:fixed; inset:0; z-index:200;
    background:rgba(15,17,21,.96);
    -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px);
    opacity:0; visibility:hidden;
    transition:opacity .3s ease, visibility .3s;
  }
  .rg-visionneuse.est-ouverte{ opacity:1; visibility:visible; }
  
  /* Scène : zone centrale qui accueille le cadre */
  .rg-visionneuse__scene{
    position:absolute; inset:0;
    display:flex; align-items:center; justify-content:center;
    padding:56px 64px 120px;
  }
  .rg-visionneuse__cadre{
    background:var(--panneau);
    border:1px solid var(--filet);
    padding:12px;
    box-shadow:0 30px 80px rgba(0,0,0,.65);
    opacity:0; transform:scale(.985);
    transition:opacity .35s ease, transform .35s ease;
  }
  .rg-visionneuse__cadre.est-chargee{ opacity:1; transform:scale(1); }
  .rg-visionneuse__cadre img{
    display:block; cursor:zoom-in;
    max-width:calc(100vw - 152px);
    max-height:calc(100vh - 200px);
    width:auto; height:auto;
  }
  
  /* Mode loupe : image en taille réelle, exploration par glisser */
  .rg-visionneuse.est-zoome .rg-visionneuse__scene{
    display:block; overflow:auto; padding:0;
    cursor:grab; -webkit-overflow-scrolling:touch;
  }
  .rg-visionneuse.est-zoome .rg-visionneuse__scene:active{ cursor:grabbing; }
  .rg-visionneuse.est-zoome .rg-visionneuse__cadre{
    display:inline-block; margin:40px; padding:0; border:none; box-shadow:none;
  }
  .rg-visionneuse.est-zoome .rg-visionneuse__cadre img{
    max-width:none; max-height:none; cursor:zoom-out;
  }
  .rg-visionneuse.est-zoome .rg-visionneuse__legende{ display:none; }
  
  /* Boutons de la visionneuse */
  .rg-visionneuse__btn{
    position:absolute; z-index:5;
    width:46px; height:46px; border-radius:50%;
    background:rgba(27,31,38,.85); color:var(--papier);
    border:1px solid var(--filet); cursor:pointer;
    font-size:22px; line-height:1;
    display:flex; align-items:center; justify-content:center;
    transition:border-color .25s, color .25s;
  }
  .rg-visionneuse__btn:hover{ border-color:var(--or); color:var(--or); }
  .rg-visionneuse__fermer{ top:18px; right:18px; font-size:16px; }
  .rg-visionneuse__loupe{ top:18px; right:76px; }
  .rg-visionneuse__prec{ left:14px; top:50%; transform:translateY(-50%); }
  .rg-visionneuse__suiv{ right:14px; top:50%; transform:translateY(-50%); }
  
  /* Légende sous le tableau */
  .rg-visionneuse__legende{
    position:absolute; left:0; right:0; bottom:0; z-index:4;
    text-align:center; padding:18px 70px 24px;
    background:linear-gradient(to top, rgba(15,17,21,.92), rgba(15,17,21,0));
    pointer-events:none;
  }
  .rg-visionneuse__legende a{ pointer-events:auto; }
  .rg-visionneuse__titre{
    font-family:var(--display); font-style:italic;
    font-size:clamp(19px, 2.6vw, 26px); color:var(--papier);
  }
  .rg-visionneuse__infos{ color:var(--lavis); font-size:14px; margin-top:3px; }
  .rg-visionneuse__meta{
    margin-top:10px; font-size:12px; letter-spacing:.16em;
    text-transform:uppercase; color:var(--lavis);
  }
  .rg-visionneuse__compteur{ margin-right:22px; }
  .rg-visionneuse__lien{
    color:var(--or); border-bottom:1px solid var(--or); padding-bottom:2px;
  }
  .rg-visionneuse__lien:hover{ color:var(--papier); border-color:var(--papier); }
  
  @media (max-width:720px){
    .rg-visionneuse__scene{ padding:64px 12px 110px; }
    .rg-visionneuse__cadre img{
      max-width:calc(100vw - 48px);
      max-height:calc(100vh - 190px);
    }
    .rg-visionneuse__prec, .rg-visionneuse__suiv{ display:none; } /* tactile : on navigue au swipe */
    .rg-visionneuse__legende{ padding:14px 16px 18px; }
  }