/* ═══════════════════════════════════════════════════════════════════════
   FEUILLE DE STYLE DU CATALOGUE — reprise fidèle de la maquette de référence.
   Les couleurs/typos sont centralisées ici (tokens :root) : pour changer
   l'identité visuelle, modifier ces variables.
   ═══════════════════════════════════════════════════════════════════════ */
:root {
  --ivory:#F8F6F1; --white:#FFFFFF; --anthracite:#1C1C1C;
  --bordeaux:#7A1F2E; --bordeaux-mid:#9E3347; --bordeaux-pale:#C8667A;
  --stone-dark:#6E6259; --stone:#9B8F84; --stone-light:#D6CFC8;
  --stone-xlight:#EDE8E3; --stone-xxlight:#F4F1ED; --tag-bg:#EFE9E3;
  --status-pub-bg:#E8F4EC; --status-pub-fg:#2E7D45;
  --status-draft-bg:#FFF8EC; --status-draft-fg:#B45300;
  --status-review-bg:#EEF2FF; --status-review-fg:#3949AB;
  --nav-h:54px; --sidebar-w:228px; --radius:2px;
  --shadow-card:0 2px 8px rgba(28,28,28,.07); --shadow-hover:0 6px 24px rgba(28,28,28,.13);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'Inter',sans-serif;background:var(--ivory);color:var(--anthracite);font-size:13px;line-height:1.5;-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;}
::-webkit-scrollbar{width:6px;height:6px;}
::-webkit-scrollbar-thumb{background:var(--stone-light);border-radius:4px;}

/* ── NAVIGATION ── */
.nav{position:fixed;top:0;left:0;right:0;height:var(--nav-h);background:var(--anthracite);display:flex;align-items:center;padding:0 24px;z-index:200;}
.nav-brand{font-family:'Cormorant Garamond',serif;font-size:17px;font-weight:300;letter-spacing:.14em;text-transform:uppercase;color:var(--ivory);white-space:nowrap;margin-right:36px;}
.nav-brand em{color:var(--bordeaux-pale);font-style:italic;}
.nav-links{display:flex;flex:1;}
.nav-link{padding:0 16px;height:var(--nav-h);display:flex;align-items:center;font-size:11.5px;letter-spacing:.09em;text-transform:uppercase;color:rgba(248,246,241,.5);cursor:pointer;border-bottom:2px solid transparent;transition:color .15s;}
.nav-link:hover{color:var(--ivory);}
.nav-link.active{color:var(--ivory);border-bottom-color:var(--bordeaux-pale);}
.nav-right{display:flex;align-items:center;gap:10px;}
.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;font-family:'Inter',sans-serif;font-size:11.5px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;border-radius:var(--radius);cursor:pointer;border:none;transition:background .15s;white-space:nowrap;}
.btn-primary{background:var(--bordeaux);color:var(--white);}
.btn-primary:hover{background:var(--bordeaux-mid);}
.btn-ghost{background:transparent;color:rgba(248,246,241,.6);border:1px solid rgba(255,255,255,.18);}
.btn-ghost:hover{color:var(--ivory);border-color:rgba(255,255,255,.4);}
.btn-sm{padding:5px 12px;font-size:11px;}

/* ── LAYOUT ── */
.app{display:flex;height:100vh;padding-top:var(--nav-h);}
.sidebar{width:var(--sidebar-w);background:var(--white);border-right:1px solid var(--stone-xlight);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;}
.sidebar-section{padding:18px 14px 8px;}
.sidebar-label{font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--stone);font-weight:600;margin-bottom:6px;padding:0 4px;}
.sidebar-item{display:flex;align-items:center;gap:8px;padding:7px 8px;border-radius:3px;cursor:pointer;font-size:12.5px;color:var(--anthracite);margin-bottom:1px;transition:background .12s;}
.sidebar-item:hover{background:var(--stone-xxlight);}
.sidebar-item.active{background:var(--tag-bg);color:var(--bordeaux);font-weight:500;}
.sidebar-icon{width:18px;text-align:center;font-size:13px;flex-shrink:0;}
.sidebar-count{margin-left:auto;background:var(--stone-xlight);color:var(--stone-dark);font-size:10px;font-weight:500;padding:1px 7px;border-radius:10px;}
.sidebar-item.active .sidebar-count{background:rgba(122,31,46,.12);color:var(--bordeaux);}
.sidebar-divider{height:1px;background:var(--stone-xlight);margin:6px 14px;}
/* Facette relationnelle : ligne « inclure » + bouton « − » (exclure). */
.facet{display:flex;align-items:stretch;gap:2px;}
.facet .facet-main{flex:1;min-width:0;margin-bottom:0;}
.facet .facet-label{flex:1;min-width:0;}
.facet.active .facet-main{background:var(--tag-bg);color:var(--bordeaux);font-weight:500;}
.facet.active .facet-main .sidebar-count{background:rgba(122,31,46,.12);color:var(--bordeaux);}
.facet-minus{display:flex;align-items:center;justify-content:center;width:22px;flex-shrink:0;color:var(--stone);font-size:15px;line-height:1;border-radius:4px;opacity:0;transition:opacity .12s,background .12s,color .12s;cursor:pointer;}
.facet:hover .facet-minus{opacity:.55;}
.facet-minus:hover{opacity:1;background:var(--bordeaux);color:#fff;}
.facet-minus.on{opacity:1;color:#fff;background:var(--bordeaux);}
.facet.excluded .facet-label{text-decoration:line-through;}
.facet.excluded .facet-main{color:var(--stone);}
/* Recherche par catégorie + liste défilante des options. */
.facet-search{width:100%;font-family:'Inter',sans-serif;font-size:12px;padding:5px 9px;margin:0 0 6px;border:1px solid var(--stone-light);border-radius:4px;background:var(--white);color:var(--anthracite);}
.facet-search::placeholder{color:var(--stone);}
.facet-search:focus{outline:none;border-color:var(--bordeaux-pale);box-shadow:0 0 0 2px rgba(122,31,46,.08);}
.facet-list{max-height:300px;overflow-y:auto;}
.facet-empty{display:none;font-size:11.5px;color:var(--stone);font-style:italic;padding:6px 8px;}

.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;}

/* ── TOOLBAR ── */
.toolbar{background:var(--white);border-bottom:1px solid var(--stone-xlight);padding:10px 18px;display:flex;align-items:center;gap:10px;flex-shrink:0;}
.search-wrap{display:flex;align-items:center;gap:7px;background:var(--ivory);border:1px solid var(--stone-light);border-radius:3px;padding:6px 10px;flex:1;max-width:340px;}
.search-wrap:focus-within{border-color:var(--bordeaux);}
.search-wrap input{border:none;background:transparent;font-family:'Inter',sans-serif;font-size:12.5px;outline:none;width:100%;color:var(--anthracite);}
.filter-pill{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border:1px solid var(--stone-light);border-radius:3px;background:var(--white);font-size:12px;cursor:pointer;color:var(--anthracite);}
.filter-pill:hover{background:var(--ivory);}
.filter-pill.active{border-color:var(--bordeaux);color:var(--bordeaux);background:rgba(122,31,46,.04);}
.toolbar-spacer{flex:1;}
.results-info{font-size:11.5px;color:var(--stone);white-space:nowrap;}

/* ── GRILLE ── */
.content{flex:1;overflow-y:auto;padding:18px;}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(var(--card-min,185px),1fr));gap:14px;}
/* Contrôle « taille des vignettes » (toolbar) */
.photo-size{display:inline-flex;align-items:center;gap:6px;margin-left:10px;}
.photo-size input[type=range]{width:90px;}
/* Filtre de période : « Entre [année] et [année] » (sidebar) */
.year-filter{display:flex;align-items:center;flex-wrap:wrap;gap:6px;font-size:12px;color:var(--anthracite);}
.year-box{width:62px;font-family:'Inter',sans-serif;font-size:12px;padding:5px 6px;border:1px solid var(--stone-light);border-radius:4px;background:var(--white);color:var(--anthracite);}
.year-box::placeholder{color:var(--stone-light);}
.year-box:focus{outline:none;border-color:var(--bordeaux-pale);box-shadow:0 0 0 2px rgba(122,31,46,.08);}
.year-go{padding:4px 10px;}
.card{background:var(--white);border:1px solid var(--stone-xlight);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:box-shadow .2s,transform .18s,border-color .18s;box-shadow:var(--shadow-card);display:block;}
.card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px);}
.card-visual{width:100%;background:var(--stone-xlight);display:flex;align-items:center;justify-content:center;font-size:40px;aspect-ratio:3/4;color:var(--stone-dark);}
.card-body{padding:10px 11px 11px;}
.card-cr{font-size:9.5px;letter-spacing:.1em;color:var(--stone);text-transform:uppercase;margin-bottom:3px;font-weight:500;}
/* Titre d'œuvre sur les cartes du catalogue : on conserve le serif Cormorant
   Garamond (style muséal), mais en graisse 600 et un peu plus grand pour qu'il
   reste lisible à petite taille. */
.card-title{font-family:'Cormorant Garamond',serif;font-size:15.5px;font-weight:600;line-height:1.28;margin-bottom:4px;color:var(--anthracite);}
.card-meta{font-size:11px;color:var(--stone);line-height:1.65;}
.card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:7px;}
.badge{display:inline-block;font-size:9.5px;font-weight:500;letter-spacing:.04em;padding:2px 8px;border-radius:10px;}
.badge-pub{background:var(--status-pub-bg);color:var(--status-pub-fg);}
.badge-draft{background:var(--status-draft-bg);color:var(--status-draft-fg);}
.badge-review{background:var(--status-review-bg);color:var(--status-review-fg);}
.badge-archived{background:var(--stone-xlight);color:var(--stone-dark);}

/* ── PAGINATION ── */
.pager{display:flex;align-items:center;justify-content:center;gap:6px;padding:20px;}
.pager a,.pager span{padding:5px 11px;border:1px solid var(--stone-light);border-radius:3px;font-size:12px;background:var(--white);color:var(--anthracite);}
.pager .current{background:var(--anthracite);color:var(--white);border-color:var(--anthracite);}
.pager .disabled{color:var(--stone-light);pointer-events:none;}

/* ── ÉTAT VIDE ── */
.empty{padding:60px 20px;text-align:center;color:var(--stone);}

/* ── PAGE DÉTAIL (simplifiée) ── */
.detail-page{flex:1;overflow-y:auto;padding:28px 36px;max-width:880px;}
.detail-cr{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--stone);font-weight:600;}
.detail-title{font-family:'Cormorant Garamond',serif;font-size:30px;font-weight:400;line-height:1.1;margin:2px 0 18px;}
.fields{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:8px;}
.field{display:flex;flex-direction:column;gap:2px;}
.field-full{grid-column:1 / -1;}
.f-label{font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--stone);font-weight:600;}
.f-value{font-size:13.5px;color:var(--anthracite);}
.f-null{color:var(--stone-light);font-style:italic;}
.d-section-title{font-size:9.5px;letter-spacing:.15em;text-transform:uppercase;color:var(--bordeaux);font-weight:600;margin:22px 0 6px;}
.back-link{font-size:12px;color:var(--bordeaux);}

/* ═══════════════════════════════════════════════════════════════════════
   FORMULAIRES, CONNEXION, ADMINISTRATION
   ═══════════════════════════════════════════════════════════════════════ */
/* Connexion : carte centrée */
.auth-wrap{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - var(--nav-h));padding:20px;}
.auth-card{background:var(--white);border:1px solid var(--stone-xlight);border-radius:var(--radius);box-shadow:var(--shadow-card);width:100%;max-width:360px;padding:30px 28px;}
.auth-title{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:400;margin-bottom:4px;}
.auth-sub{font-size:12px;color:var(--stone);margin-bottom:20px;}

/* Champs de formulaire génériques */
.form-row{margin-bottom:14px;display:flex;flex-direction:column;gap:4px;}
.form-label{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--stone-dark);font-weight:600;}
.form-input,.form-select{font-family:'Inter',sans-serif;font-size:13px;padding:8px 10px;border:1px solid var(--stone-light);border-radius:3px;background:var(--ivory);color:var(--anthracite);width:100%;}
.form-input:focus,.form-select:focus{outline:none;border-color:var(--bordeaux);}
.form-check{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--anthracite);}
.form-error{color:#C62828;font-size:11.5px;margin-top:2px;}
.form-validation{color:#C62828;font-size:12px;background:#FBE9E7;border-radius:3px;padding:8px 10px;margin-bottom:12px;}
.btn-block{width:100%;justify-content:center;padding:10px;}

/* Grille de formulaire (édition d'œuvre) */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.form-grid .span2{grid-column:1 / -1;}
.form-textarea{font-family:'Inter',sans-serif;font-size:13px;padding:8px 10px;border:1px solid var(--stone-light);border-radius:3px;background:var(--ivory);color:var(--anthracite);width:100%;min-height:70px;resize:vertical;}
.form-textarea:focus{outline:none;border-color:var(--bordeaux);}
.form-actions{display:flex;gap:10px;align-items:center;margin-top:20px;padding-top:16px;border-top:1px solid var(--stone-xlight);}

/* Médias (images) en édition */
.media-grid{display:flex;flex-wrap:wrap;gap:10px;margin:8px 0 14px;}
.media-item{width:130px;border:1px solid var(--stone-xlight);border-radius:3px;overflow:hidden;background:var(--white);}
.media-item.main{border-color:var(--bordeaux);box-shadow:0 0 0 1px var(--bordeaux);}
.media-item img{width:130px;height:130px;object-fit:cover;display:block;background:var(--stone-xlight);}
.media-cap{padding:5px 6px;font-size:10px;color:var(--stone-dark);line-height:1.4;}
.media-cap .tag{font-size:9px;}
.media-actions{display:flex;gap:8px;padding:5px 6px;border-top:1px solid var(--stone-xlight);}

/* Galerie d'images de la fiche publique */
.gallery{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:8px;}
.gallery-main{width:100%;max-width:420px;border:1px solid var(--stone-xlight);border-radius:2px;background:var(--stone-xlight);}
.gallery-main img{width:100%;display:block;border-radius:2px;}
.gallery-thumbs{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px;}
.gallery-thumbs img{width:64px;height:64px;object-fit:cover;border:1px solid var(--stone-xlight);border-radius:2px;cursor:pointer;}

/* ════════ FICHE D'ŒUVRE (détail) — mise en page muséale ════════ */
.aw-detail{flex:1;overflow-y:auto;width:100%;}
.aw-wrap{max-width:1180px;margin:0 auto;padding:22px 40px 64px;}
.aw-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px;}

/* Héros : image + cartel */
.aw-hero{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(320px,1fr);gap:52px;align-items:start;}
.aw-figure{background:linear-gradient(160deg,#fff,var(--stone-xxlight));border:1px solid var(--stone-xlight);border-radius:5px;padding:30px;box-shadow:var(--shadow-card);display:flex;align-items:center;justify-content:center;min-height:340px;}
.aw-figure img{max-width:100%;max-height:72vh;display:block;object-fit:contain;box-shadow:0 6px 26px rgba(28,28,28,.16);border-radius:2px;}
.aw-figure.empty{font-size:72px;color:var(--stone-light);}
.aw-thumbs{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px;}
.aw-thumbs img{width:74px;height:74px;object-fit:cover;border:1px solid var(--stone-light);border-radius:3px;cursor:pointer;transition:border-color .15s,transform .15s,box-shadow .15s;}
.aw-thumbs img:hover{transform:translateY(-2px);border-color:var(--bordeaux-pale);}
.aw-thumbs img.active{border-color:var(--bordeaux);box-shadow:0 0 0 1px var(--bordeaux);}

/* Cartel (étiquette muséale, collante) */
.aw-cartel{position:sticky;top:calc(var(--nav-h) + 20px);}
.aw-cr{font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--bordeaux);font-weight:600;}
.aw-title{font-family:'Cormorant Garamond',serif;font-size:40px;font-weight:500;line-height:1.04;margin:8px 0 4px;color:var(--anthracite);}
.aw-sub{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:18px;color:var(--stone-dark);margin-bottom:6px;}
.aw-badge-row{margin:14px 0 4px;}
.aw-facts{margin-top:16px;border-top:1px solid var(--stone-light);}
.aw-fact{display:grid;grid-template-columns:118px 1fr;gap:14px;padding:10px 0;border-bottom:1px solid var(--stone-xlight);}
.aw-fact dt{font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--stone);font-weight:600;padding-top:3px;}
.aw-fact dd{font-size:14px;color:var(--anthracite);line-height:1.5;}
.aw-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:20px;}

/* Sections secondaires sous le héros (deux colonnes) */
.aw-body{margin-top:52px;display:grid;grid-template-columns:1fr 1fr;gap:34px 52px;align-items:start;}
.aw-block.full{grid-column:1 / -1;}
.aw-h{font-family:'Cormorant Garamond',serif;font-size:21px;color:var(--anthracite);font-weight:500;margin-bottom:12px;padding-bottom:7px;border-bottom:1px solid var(--stone-light);position:relative;}
.aw-h::after{content:"";position:absolute;left:0;bottom:-1px;width:46px;height:2px;background:var(--bordeaux);}
.aw-prose{font-size:14px;line-height:1.75;color:var(--anthracite);white-space:pre-line;}
.aw-chips{display:flex;flex-wrap:wrap;gap:8px;}
.aw-chip{background:var(--tag-bg);border-radius:16px;padding:6px 13px;font-size:12.5px;color:var(--stone-dark);}
.aw-chip b{color:var(--anthracite);font-weight:600;}
.aw-ref{padding:10px 0;border-bottom:1px solid var(--stone-xlight);}
.aw-ref:last-child{border-bottom:none;}
.aw-ref .t{font-style:italic;color:var(--anthracite);font-size:14px;}
.aw-ref .m{display:block;font-size:12px;color:var(--stone);margin-top:2px;}
.aw-ref .tag{display:inline-block;background:var(--tag-bg);border-radius:10px;padding:1px 8px;font-size:10px;color:var(--stone-dark);margin-left:6px;}
/* Bloc exemplaire */
.aw-cast{background:var(--white);border:1px solid var(--stone-xlight);border-radius:5px;padding:16px 18px;margin-bottom:14px;box-shadow:var(--shadow-card);}
.aw-cast-h{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--bordeaux);font-weight:600;margin-bottom:8px;}
@media(max-width:900px){
  .aw-wrap{padding:18px 18px 48px;}
  .aw-hero{grid-template-columns:1fr;gap:26px;}
  .aw-cartel{position:static;}
  .aw-body{grid-template-columns:1fr;gap:26px;}
  .aw-title{font-size:32px;}
}
.card-visual img{width:100%;height:100%;object-fit:cover;}

/* ═══════════════════════════════════════════════════════════════════════
   PAGE ARTISTE (reprise de la maquette)
   ═══════════════════════════════════════════════════════════════════════ */
/* padding-top = hauteur de la barre de nav fixe (54px) + marge, sinon le contenu
   (notamment le bouton « Éditer ») passe sous le bandeau noir. */
.artist-page{flex:1;overflow-y:auto;padding:calc(var(--nav-h) + 28px) 48px 36px;max-width:960px;margin:0 auto;width:100%;}
.artist-hero{display:grid;grid-template-columns:160px 1fr;gap:32px;margin-bottom:36px;padding-bottom:32px;border-bottom:1px solid var(--stone-xlight);}
.artist-portrait{width:160px;height:200px;background:var(--stone-xlight);border-radius:2px;display:flex;align-items:center;justify-content:center;font-size:56px;overflow:hidden;}
.artist-portrait img{width:100%;height:100%;object-fit:cover;}
.artist-name{font-family:'Cormorant Garamond',serif;font-size:42px;font-weight:300;line-height:1;margin-bottom:6px;}
.artist-dates{font-size:16px;color:var(--stone);margin-bottom:16px;font-family:'Cormorant Garamond',serif;font-style:italic;}
.artist-stats{display:flex;gap:24px;flex-wrap:wrap;}
.artist-stat{text-align:center;}
.artist-stat-n{font-size:28px;font-family:'Cormorant Garamond',serif;color:var(--bordeaux);font-weight:300;}
.artist-stat-l{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--stone);margin-top:2px;}
.section-h{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:400;margin:26px 0 14px;color:var(--bordeaux);border-bottom:1px solid var(--stone-xlight);padding-bottom:6px;}
.bio-text{font-size:13.5px;line-height:1.75;color:var(--anthracite);white-space:pre-line;}
.chrono-item{display:flex;gap:16px;padding:8px 0;border-bottom:1px dashed var(--stone-xlight);}
.chrono-year{font-size:12px;font-weight:600;color:var(--bordeaux);min-width:44px;}
.chrono-text{font-size:13px;color:var(--anthracite);line-height:1.55;}

/* Page artiste : deux colonnes (contenu + panneau latéral de rubriques « infobox »). */
.artist-layout{display:grid;grid-template-columns:1fr 300px;gap:40px;align-items:start;}
.artist-main{min-width:0;}
.artist-aside{display:flex;flex-direction:column;gap:18px;position:sticky;top:calc(var(--nav-h) + 16px);}
.infobox{border:1px solid var(--stone-light);border-radius:6px;background:var(--white);overflow:hidden;box-shadow:var(--shadow-card);}
.infobox-h{background:var(--anthracite);color:var(--ivory);font-family:'Cormorant Garamond',serif;font-size:16px;font-weight:500;letter-spacing:.04em;padding:8px 13px;}
.infobox-list{list-style:none;margin:0;padding:6px 13px;}
.infobox-list li{font-size:12.5px;line-height:1.5;color:var(--anthracite);padding:5px 0;border-bottom:1px dashed var(--stone-xlight);}
.infobox-list li:last-child{border-bottom:none;}
.infobox-list a{color:var(--bordeaux);text-decoration:none;}
.infobox-list a:hover{text-decoration:underline;}
.infobox-src{font-size:10.5px;color:var(--stone);font-style:italic;padding:0 2px;}
.infobox-list.toc a{font-weight:500;}
/* Sections développées (texte enrichi + sources). Décalage d'ancre sous la nav fixe. */
.dev-section{scroll-margin-top:calc(var(--nav-h) + 14px);margin-top:18px;}
.dev-sources{margin-top:8px;border-left:2px solid var(--stone-light);padding:4px 0 4px 12px;}
.dev-sources-h{font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--stone);font-weight:600;}
.dev-sources ul{list-style:none;margin:4px 0 0;padding:0;}
.dev-sources li{font-size:12px;line-height:1.5;padding:2px 0;color:var(--stone-dark);}
.dev-sources a{color:var(--bordeaux);text-decoration:none;}
.dev-sources a:hover{text-decoration:underline;}
html{scroll-behavior:smooth;}
@media (max-width:860px){ .artist-layout{grid-template-columns:1fr;} .artist-aside{position:static;} }

/* Page d'administration : conteneur centré */
.admin-page{flex:1;overflow-y:auto;padding:28px 36px;max-width:980px;margin:0 auto;width:100%;}
.admin-h{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:400;margin-bottom:4px;}
.admin-sub{font-size:12px;color:var(--stone);margin-bottom:20px;}
.admin-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:16px;}

/* Cartes de gestion (style « tableau de bord » à la Amazon) :
   grille responsive, chaque carte = icône + titre + courte description, cliquable. */
.admin-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:16px;margin:14px 0 22px;}
.admin-card{display:flex;gap:16px;align-items:flex-start;background:var(--white);border:1px solid var(--stone-light);border-radius:6px;padding:18px 20px;text-decoration:none;transition:border-color .15s,box-shadow .15s,transform .15s;}
.admin-card:hover{border-color:var(--bordeaux);box-shadow:var(--shadow-card);transform:translateY(-1px);}
.admin-card .ac-icon{font-size:25px;line-height:1;flex-shrink:0;margin-top:1px;}
.admin-card .ac-title{display:block;font-family:'Cormorant Garamond',serif;font-size:19px;font-weight:500;color:var(--anthracite);margin-bottom:4px;}
.admin-card .ac-desc{display:block;font-size:12.5px;color:var(--stone);line-height:1.45;}
/* Carte mise en avant (action principale : nouvelle fiche). */
.admin-card.primary{border-color:var(--bordeaux);background:linear-gradient(0deg,rgba(122,30,45,.04),rgba(122,30,45,.04)),var(--white);}
.admin-card.primary .ac-title{color:var(--bordeaux);}

/* Tableau de données */
.table{width:100%;border-collapse:collapse;background:var(--white);border:1px solid var(--stone-xlight);border-radius:var(--radius);overflow:hidden;}
.table th{text-align:left;font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--stone);font-weight:600;padding:9px 12px;border-bottom:1px solid var(--stone-xlight);background:var(--stone-xxlight);}
.table td{font-size:12.5px;padding:9px 12px;border-bottom:1px solid var(--stone-xlight);}
.table tr:last-child td{border-bottom:none;}
.table tr:hover td{background:var(--stone-xxlight);}
.row-actions{display:flex;gap:6px;}
.link-action{font-size:11.5px;color:var(--bordeaux);cursor:pointer;background:none;border:none;padding:0;font-family:'Inter',sans-serif;}
.pill-ok{background:var(--status-pub-bg);color:var(--status-pub-fg);font-size:10px;padding:2px 8px;border-radius:10px;}
.pill-off{background:#FBE9E7;color:#C62828;font-size:10px;padding:2px 8px;border-radius:10px;}

/* Bandeau de message (succès) */
.flash{background:var(--status-pub-bg);color:var(--status-pub-fg);border-radius:3px;padding:10px 14px;font-size:12.5px;margin-bottom:16px;}

/* Liens d'auth dans la barre de navigation */
.nav-lang{display:inline-flex;align-items:center;gap:6px;font-size:11px;letter-spacing:.06em;margin-right:6px;}
.nav-lang a{color:rgba(248,246,241,.5);}
.nav-lang a:hover{color:var(--ivory);}
.nav-lang a.on{color:var(--bordeaux-pale);font-weight:600;}
.nav-user{font-size:11.5px;color:rgba(248,246,241,.7);display:flex;align-items:center;gap:10px;}
.nav-user a{color:var(--bordeaux-pale);}
.nav-logout{background:none;border:1px solid rgba(255,255,255,.18);color:rgba(248,246,241,.6);border-radius:var(--radius);padding:5px 12px;font-size:11px;font-family:'Inter',sans-serif;cursor:pointer;text-transform:uppercase;letter-spacing:.06em;}
.nav-logout:hover{color:var(--ivory);border-color:rgba(255,255,255,.4);}

/* ════════════════════════════════════════════════════════════════════════
   RESPONSIVE MOBILE (≤ 768px). N'affecte PAS l'affichage ordinateur.
   ════════════════════════════════════════════════════════════════════════ */
/* Bouton « Filtres » : masqué sur ordinateur, affiché en mobile. */
.filters-toggle, .filters-toggle-cb { display: none; }

@media (max-width: 768px) {
  /* ── Barre de navigation : ne plus déborder, rester en haut, passer à la ligne ── */
  .nav { position: sticky; height: auto; flex-wrap: wrap; padding: 8px 12px; row-gap: 4px; }
  .nav-brand { margin-right: auto; font-size: 15px; }
  .nav-links { order: 3; flex-basis: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .nav-link { height: auto; padding: 8px 12px; }
  .nav-right { gap: 8px; }

  /* ── Mise en page générale : flux vertical naturel (au lieu du 100vh à colonnes) ── */
  .app { display: block; height: auto; padding-top: 0; }
  .main { overflow: visible; display: block; }
  .content, .detail-page, .admin-page, .aw-detail, .aw-wrap, .artist-page { overflow: visible; height: auto; }
  .artist-page { padding: 16px; }
  .admin-page, .detail-page { padding: 16px; }

  /* ── Barre latérale de filtres : repliable via le bouton « Filtres » ── */
  .filters-toggle {
    display: block; margin: 10px 12px 0; padding: 9px 14px; border: 1px solid var(--stone-light);
    border-radius: var(--radius); background: var(--white); color: var(--anthracite);
    font-size: 13px; font-weight: 500; cursor: pointer; user-select: none;
  }
  .sidebar { display: none; width: 100%; border-right: none; border-bottom: 1px solid var(--stone-xlight); }
  #filtersToggle:checked ~ .sidebar { display: flex; }

  /* ── Barre d'outils : passe à la ligne proprement ── */
  .toolbar { flex-wrap: wrap; gap: 8px; height: auto; padding: 10px 12px; }
  .toolbar-spacer { display: none; }
  .search-wrap { flex: 1 1 100%; }

  /* ── Grille : vignettes plus petites par défaut pour 2 colonnes ── */
  .grid { grid-template-columns: repeat(auto-fill, minmax(var(--card-min, 150px), 1fr)); gap: 10px; }

  /* ── Fiche d'œuvre : déjà en 1 colonne (≤900px) ; on resserre encore ── */
  .aw-title { font-size: 28px; }
  .aw-figure { padding: 16px; min-height: 220px; }

  /* ── Pied de page / divers ── */
  .pager { flex-wrap: wrap; }
}
