/* ============================================================
   Backoffice Mirtillo — interface admin
   ============================================================ */
:root{
  --paper:#faf6ef; --ink:#1a1d36; --ink-soft:#3b3f5c; --muted:#6b6f8c;
  --green:#1f9d6b; --pink:#ee4d8f; --violet:#7b5bd6; --violet-d:#5f43b8;
  --lav:#ece4fa; --mint:#e9f6ef; --line:#e6e2ee; --card:#ffffff;
  --grad:linear-gradient(120deg,#ee4d8f,#7b5bd6);
  --sans:'Hanken Grotesk',system-ui,sans-serif; --serif:'Fraunces',serif; --mono:'JetBrains Mono',monospace;
}
*{box-sizing:border-box}
body{margin:0;font-family:var(--sans);background:#f3f0fa;color:var(--ink);-webkit-font-smoothing:antialiased}
a{color:var(--violet)}
.layout{display:flex;min-height:100vh}

/* sidebar */
.side{width:248px;background:var(--ink);color:#cdd0e8;flex:none;display:flex;flex-direction:column;padding:22px 16px;position:sticky;top:0;height:100vh}
.side-brand{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-weight:600;font-size:20px;color:#fff;padding:6px 8px 22px}
.side-brand .dot{width:26px;height:26px;border-radius:8px;background:var(--grad);display:inline-block}
.side nav{display:flex;flex-direction:column;gap:3px}
.side nav a{display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:11px;color:#cdd0e8;text-decoration:none;font-weight:600;font-size:14.5px;transition:.15s}
.side nav a svg{width:18px;height:18px;opacity:.85}
.side nav a:hover{background:rgba(255,255,255,.07);color:#fff}
.side nav a.active{background:var(--grad);color:#fff}
.side-foot{margin-top:auto;padding:14px 10px 4px;border-top:1px solid rgba(255,255,255,.1);font-size:13px;color:#9aa0c4}
.side-foot a{color:#cdd0e8}

/* main */
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:18px 30px;background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}
.topbar h1{font-family:var(--serif);font-weight:600;font-size:23px;margin:0}
.topbar .who{font-size:13.5px;color:var(--muted)}
.content{padding:30px;max-width:1080px;width:100%}

/* cartes stats */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:30px}
@media(max-width:840px){.stat-grid{grid-template-columns:repeat(2,1fr)}}
.stat{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:22px 20px}
.stat .n{font-family:var(--serif);font-weight:600;font-size:34px;line-height:1;color:var(--ink)}
.stat .l{font-size:13.5px;color:var(--muted);margin-top:8px}
.stat.accent{background:var(--grad);border:none;color:#fff}
.stat.accent .n,.stat.accent .l{color:#fff}

/* panneau / table */
.panel{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:24px;margin-bottom:24px}
.panel h2{font-family:var(--serif);font-weight:600;font-size:19px;margin:0 0 16px}
table{width:100%;border-collapse:collapse;font-size:14.5px}
th,td{text-align:left;padding:12px 12px;border-bottom:1px solid var(--line);vertical-align:middle}
th{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}
tr:last-child td{border-bottom:none}
.badge{display:inline-block;font-size:11.5px;font-weight:700;padding:3px 10px;border-radius:999px}
.badge.published{background:var(--mint);color:#177a52}
.badge.draft{background:#fdeef4;color:#c23b6f}
.badge.lang{background:var(--lav);color:var(--violet-d);font-family:var(--mono)}
.badge.mode{background:#eef1ff;color:#2b4ddb;font-family:var(--mono)}

/* boutons */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-weight:700;font-size:14.5px;padding:11px 18px;border-radius:11px;border:none;cursor:pointer;text-decoration:none;transition:.15s;line-height:1}
.btn-primary{background:var(--grad);color:#fff}
.btn-primary:hover{filter:brightness(1.06)}
.btn-ghost{background:#fff;color:var(--ink);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--violet);color:var(--violet)}
.btn-danger{background:#fff;color:#c23b6f;border:1px solid #f3cad9}
.btn-danger:hover{background:#fdeef4}
.btn-sm{padding:7px 13px;font-size:13px;border-radius:9px}
.row-actions{display:flex;gap:8px;justify-content:flex-end}
.toolbar{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:20px}
.toolbar .spacer{flex:1}

/* formulaires */
.form-grid{display:grid;gap:18px}
.form-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:720px){.form-2{grid-template-columns:1fr}}
label{display:block;font-weight:600;font-size:13.5px;margin-bottom:7px;color:var(--ink)}
.hint{font-weight:400;color:var(--muted);font-size:12.5px}
input[type=text],input[type=email],input[type=password],input[type=url],textarea,select{
  width:100%;font-family:var(--sans);font-size:15px;color:var(--ink);background:#fff;
  border:1px solid var(--line);border-radius:11px;padding:11px 13px;transition:.15s}
textarea{min-height:120px;resize:vertical;line-height:1.5}
textarea.code{font-family:var(--mono);font-size:13.5px;min-height:300px}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--violet);box-shadow:0 0 0 3px rgba(123,91,214,.16)}
.field{margin:0}
.seg{display:flex;gap:10px;flex-wrap:wrap}
.seg label{display:flex;align-items:center;gap:9px;border:1px solid var(--line);border-radius:11px;padding:12px 15px;cursor:pointer;font-weight:600;margin:0;flex:1;min-width:200px}
.seg label:hover{border-color:var(--violet)}
.seg input{width:auto;margin:0}
.seg .desc{display:block;font-weight:400;font-size:12.5px;color:var(--muted);margin-top:2px}
.thumbs{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}
.thumbs img{width:84px;height:64px;object-fit:cover;border-radius:9px;border:1px solid var(--line)}
.cover-prev{margin-top:10px}
.cover-prev img{max-width:240px;border-radius:11px;border:1px solid var(--line)}
.form-actions{display:flex;gap:12px;align-items:center;margin-top:8px}

/* flash + alertes */
.flash{padding:13px 16px;border-radius:12px;margin-bottom:20px;font-weight:600;font-size:14.5px}
.flash.success{background:var(--mint);color:#177a52}
.flash.error{background:#fdeef4;color:#c23b6f}
.alert-error{background:#fdeef4;color:#c23b6f;padding:12px 15px;border-radius:11px;margin-bottom:18px;font-weight:600;font-size:14px}

/* écran de connexion centré */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(900px 500px at 70% -10%,#efe7ff,transparent),#f3f0fa}
.auth-card{width:100%;max-width:412px;background:#fff;border:1px solid var(--line);border-radius:20px;padding:38px 34px;box-shadow:0 30px 70px -40px rgba(27,31,59,.45)}
.auth-card .brand{display:flex;align-items:center;gap:11px;font-family:var(--serif);font-weight:600;font-size:23px;margin-bottom:6px}
.auth-card .brand .dot{width:30px;height:30px;border-radius:9px;background:var(--grad)}
.auth-card .sub{color:var(--muted);font-size:14px;margin:0 0 26px}
.auth-card .field{margin-bottom:16px}
.auth-card .btn{width:100%;justify-content:center;margin-top:6px}
.auth-links{display:flex;justify-content:space-between;margin-top:18px;font-size:13.5px}
.muted-note{color:var(--muted);font-size:13px;margin-top:18px;text-align:center}
.empty{color:var(--muted);text-align:center;padding:30px}
.msg-body{white-space:pre-wrap;color:var(--ink-soft);font-size:14px;line-height:1.5;max-width:560px}

/* ----- Réglages : grille 3 colonnes ----- */
.form-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px}
@media(max-width:720px){.form-3{grid-template-columns:1fr}}

/* ----- Éditeur de code colorisé (CodeMirror) ----- */
.CodeMirror{
  height:auto;border:1px solid var(--line,#e6e2ef);border-radius:12px;
  font-family:var(--mono);font-size:13.5px;line-height:1.55;
  background:#fbfaff;color:#2a2540;
}
.CodeMirror-focused{border-color:var(--violet);box-shadow:0 0 0 3px rgba(123,91,214,.16)}
.CodeMirror-gutters{background:#f1eef9;border-right:1px solid var(--line,#e6e2ef)}
.CodeMirror-linenumber{color:#a99fc4}
.cm-s-default .cm-tag{color:#7b5bd6}
.cm-s-default .cm-attribute{color:#c0398a}
.cm-s-default .cm-string{color:#2e8b6f}
.cm-s-default .cm-comment{color:#9a93ad;font-style:italic}
.cm-s-default .cm-property,.cm-s-default .cm-keyword{color:#c0398a}

/* ===================== SEO / UX : en-tête de champ, case, compteur, médiathèque ===================== */

/* En-tête de champ (label + bouton aligné à droite, ex. « + Insérer une image ») */
.field-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:6px}
.field-head label{margin:0}

/* Case à cocher (noindex) */
.check{display:flex;align-items:flex-start;gap:9px;margin-top:14px;font-family:var(--sans);
  font-size:14px;color:var(--ink-soft);cursor:pointer;line-height:1.4}
.check input{margin-top:2px;width:16px;height:16px;accent-color:var(--violet);flex:none}
.check .hint{font-size:12.5px}

/* Compteur de caractères */
.charcount{display:block;margin-top:6px;font-family:var(--mono);font-size:11.5px;color:var(--muted);text-align:right}
.charcount.near{color:#c98a1a}
.charcount.over{color:#d4453b;font-weight:600}
/* Quand le champ est un éditeur CodeMirror, le compteur suit l'éditeur */
.CodeMirror + .charcount{margin-top:8px}

/* Médiathèque (modale du sélecteur d'images) */
.media-ov{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;
  padding:24px;background:rgba(20,22,40,.55);backdrop-filter:blur(3px)}
.media-ov[hidden]{display:none}
.media-modal{width:100%;max-width:760px;max-height:82vh;display:flex;flex-direction:column;
  background:var(--card);border-radius:18px;box-shadow:0 40px 90px -40px rgba(20,22,40,.6);overflow:hidden}
.media-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line)}
.media-head strong{font-family:var(--serif);font-size:18px;color:var(--ink)}
.media-close{border:none;background:none;cursor:pointer;font-size:26px;line-height:1;color:var(--muted);padding:0 4px}
.media-close:hover{color:var(--ink)}
.media-body{padding:18px 20px;overflow:auto}
.media-empty{text-align:center;color:var(--muted);font-family:var(--sans);font-size:14px;padding:30px 10px}
.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px}
.media-thumb{display:flex;flex-direction:column;gap:6px;padding:6px;border:1px solid var(--line);border-radius:12px;
  background:var(--paper);cursor:pointer;text-align:left;transition:.15s}
.media-thumb:hover{border-color:var(--violet);box-shadow:0 8px 20px -12px rgba(123,91,214,.5)}
.media-thumb img{width:100%;height:90px;object-fit:cover;border-radius:8px;display:block;background:#fff}
.media-thumb span{font-family:var(--mono);font-size:10.5px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* Badges indicateur sitemap */
.badge.ok{background:var(--mint);color:#177a52}
.badge.muted{background:#eef0f4;color:#7a7f95;font-family:var(--mono)}
