/* ============================================================
   JPR DOCS — Gestionnaire de documents en ligne
   Feuille de style principale
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700;800&family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

/* ---------- Tokens ---------- */
:root{
  /* Bleus de marque */
  --navy-950:#061428;
  --navy-900:#0b1e3d;
  --navy-800:#14335c;
  --navy-700:#1c4478;
  --blue-600:#2563eb;
  --blue-500:#3b82f6;
  --cyan-400:#38bdf8;

  /* Neutres */
  --surface:#f7f9fc;
  --surface-alt:#eef2f8;
  --surface-card:#ffffff;
  --border:#e2e8f0;
  --border-strong:#cbd5e1;

  /* Texte */
  --ink-900:#0f172a;
  --ink-700:#334155;
  --ink-600:#475569;
  --ink-400:#94a3b8;
  --ink-inverse:#f1f5f9;

  /* États */
  --success:#16a34a;
  --success-bg:#dcfce7;
  --warning:#d97706;
  --warning-bg:#fef3c7;
  --danger:#dc2626;
  --danger-bg:#fee2e2;
  --info-bg:#dbeafe;

  /* Dégradés signature */
  --grad-hero: linear-gradient(155deg, var(--navy-950) 0%, var(--navy-900) 38%, var(--navy-700) 68%, var(--blue-600) 92%, var(--cyan-400) 130%);
  --grad-cta: linear-gradient(115deg, var(--blue-600), var(--cyan-400));
  --grad-line: linear-gradient(90deg, var(--blue-600), var(--cyan-400));

  /* Typo */
  --font-display:'Sora', sans-serif;
  --font-body:'Inter', sans-serif;
  --font-mono:'JetBrains Mono', monospace;

  /* Ombres */
  --shadow-sm: 0 1px 2px rgba(11,30,61,0.06);
  --shadow-md: 0 8px 24px rgba(11,30,61,0.10);
  --shadow-lg: 0 20px 48px rgba(11,30,61,0.18);
  --shadow-focus: 0 0 0 3px rgba(37,99,235,0.25);

  --radius-sm:8px;
  --radius-md:14px;
  --radius-lg:22px;
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink-900);
  background:var(--surface);
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{ font-family:var(--font-display); margin:0; letter-spacing:-0.01em; }
p{ margin:0; }
a{ color:inherit; text-decoration:none; }
button{ font-family:var(--font-body); cursor:pointer; }
ul{ list-style:none; margin:0; padding:0; }
::selection{ background:var(--cyan-400); color:var(--navy-950); }

/* Focus visible clavier */
a:focus-visible, button:focus-visible, input:focus-visible, [tabindex]:focus-visible{
  outline:none;
  box-shadow:var(--shadow-focus);
  border-radius:6px;
}

.mono{ font-family:var(--font-mono); }

/* ============================================================
   PAGE DE CONNEXION (index.html)
   ============================================================ */
.login-shell{
  min-height:100vh;
  display:grid;
  grid-template-columns: 1.05fr 1fr;
}

/* --- Panneau de marque (gauche) --- */
.brand-panel{
  position:relative;
  background:var(--grad-hero);
  color:var(--ink-inverse);
  padding:56px 64px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  overflow:hidden;
}
.brand-panel::before{
  /* Grain / texture subtile pour éviter l'aplat de dégradé générique */
  content:"";
  position:absolute; inset:0;
  background-image: radial-gradient(circle at 18% 20%, rgba(255,255,255,0.09), transparent 40%),
                     radial-gradient(circle at 82% 78%, rgba(56,189,248,0.20), transparent 45%);
  pointer-events:none;
}
.brand-top{ position:relative; z-index:1; display:flex; align-items:center; gap:12px; }
.brand-mark{ width:38px; height:38px; flex:none; }
.brand-name{ font-size:19px; font-weight:700; letter-spacing:0.01em; }
.brand-name span{ color:var(--cyan-400); }

.brand-mid{ position:relative; z-index:1; max-width:440px; }
.brand-eyebrow{
  font-family:var(--font-mono); font-size:12px; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--cyan-400); margin-bottom:18px; display:block;
}
.brand-title{ font-size:38px; line-height:1.18; font-weight:700; margin-bottom:18px; }
.brand-desc{ font-size:15.5px; line-height:1.6; color:#c9d6ea; }

/* Signature : empilement de dossiers animé */
.stack-scene{
  position:relative; z-index:1;
  height:170px; margin-top:34px;
  display:flex; align-items:flex-end; gap:0;
}
.doc-card{
  position:relative;
  width:150px; height:98px;
  border-radius:10px;
  background:rgba(255,255,255,0.07);
  border:1px solid rgba(255,255,255,0.16);
  backdrop-filter:blur(2px);
  margin-left:-58px;
  padding:12px 14px;
  display:flex; flex-direction:column; justify-content:space-between;
  animation:float 6s ease-in-out infinite;
  box-shadow:0 12px 30px rgba(3,10,25,0.35);
}
.doc-card:first-child{ margin-left:0; }
.doc-card:nth-child(1){ transform:rotate(-9deg); animation-delay:0s; z-index:1; background:rgba(255,255,255,0.05);}
.doc-card:nth-child(2){ transform:rotate(-2deg) translateY(-10px); animation-delay:0.6s; z-index:2; background:rgba(255,255,255,0.09);}
.doc-card:nth-child(3){ transform:rotate(6deg) translateY(-4px); animation-delay:1.2s; z-index:3; background:linear-gradient(145deg, rgba(56,189,248,0.24), rgba(37,99,235,0.12)); border-color:rgba(56,189,248,0.4); }
.doc-card .tag{ width:26px; height:5px; border-radius:3px; background:var(--cyan-400); opacity:0.85; }
.doc-card .lines{ display:flex; flex-direction:column; gap:5px; }
.doc-card .lines i{ display:block; height:3px; border-radius:2px; background:rgba(255,255,255,0.35); }
.doc-card .lines i:nth-child(2){ width:70%; }
.doc-card .lines i:nth-child(3){ width:45%; }
@keyframes float{
  0%,100%{ transform:translateY(0) rotate(var(--r,0deg)); }
  50%{ transform:translateY(-7px) rotate(var(--r,0deg)); }
}
@media (prefers-reduced-motion: reduce){ .doc-card{ animation:none; } }

.brand-bottom{ position:relative; z-index:1; display:flex; gap:34px; }
.brand-stat b{ display:block; font-size:22px; font-family:var(--font-display); }
.brand-stat span{ font-size:12.5px; color:#9fb3d1; }

/* --- Panneau formulaire (droite) --- */
.form-panel{
  display:flex; align-items:center; justify-content:center;
  padding:40px;
  background:
    radial-gradient(circle at 100% 0%, rgba(37,99,235,0.05), transparent 40%),
    var(--surface-card);
}
.login-box{ width:100%; max-width:380px; }
.login-box h1{ font-size:25px; margin-bottom:6px; }
.login-sub{ color:var(--ink-600); font-size:14.5px; margin-bottom:32px; }

.field{ margin-bottom:18px; }
.field label{ display:block; font-size:13px; font-weight:600; color:var(--ink-700); margin-bottom:7px; }
.input-wrap{ position:relative; }
.input-wrap svg{ position:absolute; left:13px; top:50%; transform:translateY(-50%); color:var(--ink-400); }
.field input{
  width:100%; padding:12px 14px 12px 40px;
  border:1.5px solid var(--border); border-radius:10px;
  font-size:14.5px; color:var(--ink-900); background:#fff;
  transition:border-color .15s, box-shadow .15s;
}
.field input:focus{ outline:none; border-color:var(--blue-500); box-shadow:0 0 0 4px rgba(37,99,235,0.12); }
.toggle-pass{
  position:absolute; right:10px; top:50%; transform:translateY(-50%);
  background:none; border:none; color:var(--ink-400); padding:6px; display:flex;
}
.toggle-pass:hover{ color:var(--ink-600); }

.row-between{ display:flex; align-items:center; justify-content:space-between; margin:2px 0 24px; font-size:13.5px; }
.remember{ display:flex; align-items:center; gap:8px; color:var(--ink-600); }
.remember input{ accent-color:var(--blue-600); width:15px; height:15px; }
.link-muted{ color:var(--blue-600); font-weight:600; }
.link-muted:hover{ text-decoration:underline; }

.btn-primary{
  width:100%; padding:13px 16px; border:none; border-radius:10px;
  background:var(--grad-cta); color:#fff; font-weight:700; font-size:14.5px;
  box-shadow:0 10px 24px rgba(37,99,235,0.28);
  display:flex; align-items:center; justify-content:center; gap:8px;
  transition:transform .12s, box-shadow .12s;
}
.btn-primary:hover{ transform:translateY(-1px); box-shadow:0 14px 30px rgba(37,99,235,0.36); }
.btn-primary:active{ transform:translateY(0); }
.btn-primary:disabled{ opacity:.7; cursor:progress; }

.form-error{
  display:none;
  align-items:center; gap:8px;
  background:var(--danger-bg); color:#991b1b;
  border:1px solid #fecaca; border-radius:10px;
  padding:10px 12px; font-size:13.5px; margin-bottom:18px;
}
.form-error.show{ display:flex; }

.hint-box{
  margin-top:26px; padding:12px 14px; border-radius:10px;
  background:var(--surface-alt); border:1px dashed var(--border-strong);
  font-size:12.5px; color:var(--ink-600); line-height:1.6;
}
.hint-box b{ color:var(--ink-900); }
.hint-box code{ font-family:var(--font-mono); background:#fff; padding:1px 6px; border-radius:5px; border:1px solid var(--border); }

.login-footer{ margin-top:28px; font-size:12.5px; color:var(--ink-400); text-align:center; }
.login-footer a{ color:var(--ink-600); font-weight:600; }

@media (max-width: 900px){
  .login-shell{ grid-template-columns:1fr; }
  .brand-panel{ display:none; }
  .form-panel{ padding:24px; }
}

/* ============================================================
   INTERFACE DE GESTION (dashboard.html)
   ============================================================ */
.app-shell{
  display:grid;
  grid-template-columns: 264px 1fr;
  min-height:100vh;
}

/* ---------- Sidebar ---------- */
.sidebar{
  background:var(--grad-hero);
  color:var(--ink-inverse);
  padding:22px 18px;
  display:flex; flex-direction:column;
  position:relative;
}
.sidebar::before{
  content:"";
  position:absolute; inset:0;
  background:radial-gradient(circle at 90% 100%, rgba(56,189,248,0.16), transparent 45%);
  pointer-events:none;
}
.sidebar > *{ position:relative; z-index:1; }

.side-brand{ display:flex; align-items:center; gap:10px; padding:6px 8px 22px; }
.side-brand .brand-mark{ width:30px; height:30px; }
.side-brand span{ font-family:var(--font-display); font-weight:700; font-size:16.5px; }
.side-brand span em{ font-style:normal; color:var(--cyan-400); }

.btn-import{
  width:100%; padding:11px 14px; border:none; border-radius:10px;
  background:var(--grad-cta); color:#fff; font-weight:700; font-size:13.5px;
  display:flex; align-items:center; justify-content:center; gap:8px;
  box-shadow:0 8px 20px rgba(37,99,235,0.3);
  margin-bottom:22px;
}
.btn-import:hover{ filter:brightness(1.06); }

.nav-label{
  font-family:var(--font-mono); font-size:10.5px; letter-spacing:0.12em; text-transform:uppercase;
  color:#8ea6cc; margin:16px 8px 8px;
}
.nav-item{
  display:flex; align-items:center; gap:10px;
  padding:9px 10px; border-radius:9px; font-size:14px; color:#dbe6f6;
  margin-bottom:2px; transition:background .12s, color .12s;
}
.nav-item svg{ flex:none; opacity:.85; }
.nav-item .count{
  margin-left:auto; font-family:var(--font-mono); font-size:11px; color:#9fb3d1;
  background:rgba(255,255,255,0.08); padding:1px 7px; border-radius:20px;
}
.nav-item:hover{ background:rgba(255,255,255,0.06); color:#fff; }
.nav-item.active{ background:rgba(56,189,248,0.16); color:#fff; box-shadow:inset 0 0 0 1px rgba(56,189,248,0.3); }
.nav-item.active .count{ background:rgba(56,189,248,0.25); color:#fff; }

.folder-dot{ width:8px; height:8px; border-radius:2px; flex:none; }

.sidebar-spacer{ flex:1; }

/* Jauge de stockage — encode la répartition réelle par dossier */
.storage-box{
  margin-top:18px; padding:14px; border-radius:12px;
  background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.1);
}
.storage-box .st-top{ display:flex; justify-content:space-between; font-size:12px; color:#c9d6ea; margin-bottom:9px; }
.storage-box .st-top b{ color:#fff; font-family:var(--font-mono); font-weight:500; }
.storage-bar{ height:7px; border-radius:6px; overflow:hidden; display:flex; background:rgba(255,255,255,0.08); }
.storage-bar i{ display:block; height:100%; }
.storage-legend{ display:flex; flex-wrap:wrap; gap:8px; margin-top:9px; }
.storage-legend span{ font-size:10.5px; color:#a9bcda; display:flex; align-items:center; gap:5px; }
.storage-legend i{ width:7px; height:7px; border-radius:2px; }

.side-user{
  margin-top:16px; padding-top:16px; border-top:1px solid rgba(255,255,255,0.1);
  display:flex; align-items:center; gap:10px;
}
.avatar{
  width:34px; height:34px; border-radius:9px; flex:none;
  background:var(--grad-cta); color:#fff; font-family:var(--font-display); font-weight:700; font-size:13px;
  display:flex; align-items:center; justify-content:center;
}
.side-user .u-name{ font-size:13.5px; font-weight:600; color:#fff; }
.side-user .u-role{ font-size:11.5px; color:#9fb3d1; }
.logout-btn{ margin-left:auto; background:none; border:none; color:#9fb3d1; padding:6px; border-radius:7px; }
.logout-btn:hover{ color:#fff; background:rgba(255,255,255,0.08); }

/* ---------- Zone principale ---------- */
.main{ display:flex; flex-direction:column; min-width:0; }

.topbar{
  height:68px; flex:none; padding:0 28px;
  display:flex; align-items:center; gap:18px;
  background:#fff; border-bottom:1px solid var(--border);
  position:sticky; top:0; z-index:5;
}
.search-wrap{ position:relative; flex:1; max-width:440px; }
.search-wrap svg{ position:absolute; left:13px; top:50%; transform:translateY(-50%); color:var(--ink-400); }
.search-wrap input{
  width:100%; padding:10px 14px 10px 38px; border-radius:10px;
  border:1.5px solid var(--border); background:var(--surface-alt); font-size:13.8px;
}
.search-wrap input:focus{ outline:none; border-color:var(--blue-500); background:#fff; box-shadow:0 0 0 4px rgba(37,99,235,0.1); }
.topbar-spacer{ flex:1; }
.icon-btn{
  width:38px; height:38px; border-radius:10px; border:1.5px solid var(--border); background:#fff;
  color:var(--ink-600); display:flex; align-items:center; justify-content:center; position:relative;
}
.icon-btn:hover{ border-color:var(--border-strong); color:var(--ink-900); }
.icon-btn .dot{
  position:absolute; top:6px; right:6px; width:7px; height:7px; border-radius:50%;
  background:var(--cyan-400); border:2px solid #fff;
}

.content{ padding:26px 28px 60px; flex:1; }

.breadcrumb{ display:flex; align-items:center; gap:8px; font-size:13px; color:var(--ink-600); margin-bottom:6px; }
.breadcrumb b{ color:var(--ink-900); }

.content-head{ display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:22px; flex-wrap:wrap; gap:14px; }
.content-head h2{ font-size:22px; }
.content-head .muted{ color:var(--ink-600); font-size:13.5px; margin-top:4px; }

.toolbar{ display:flex; align-items:center; gap:10px; }
.chip-select{
  padding:8px 12px; border-radius:9px; border:1.5px solid var(--border); background:#fff;
  font-size:13px; color:var(--ink-700); font-weight:600;
}
.view-toggle{ display:flex; border:1.5px solid var(--border); border-radius:9px; overflow:hidden; }
.view-toggle button{ width:36px; height:34px; background:#fff; border:none; color:var(--ink-400); display:flex; align-items:center; justify-content:center; }
.view-toggle button.active{ background:var(--surface-alt); color:var(--blue-600); }

/* KPI de synthèse */
.kpi-row{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:24px; }
.kpi-card{ background:#fff; border:1px solid var(--border); border-radius:14px; padding:16px 18px; }
.kpi-card .k-top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
.kpi-card .k-icon{ width:32px; height:32px; border-radius:9px; display:flex; align-items:center; justify-content:center; }
.kpi-card .k-val{ font-family:var(--font-display); font-size:23px; font-weight:700; }
.kpi-card .k-label{ font-size:12.5px; color:var(--ink-600); margin-top:2px; }

/* ---------- Tableau documents ---------- */
.doc-table-wrap{ background:#fff; border:1px solid var(--border); border-radius:16px; overflow:hidden; }
table.doc-table{ width:100%; border-collapse:collapse; }
.doc-table thead th{
  text-align:left; font-size:11.5px; text-transform:uppercase; letter-spacing:0.06em;
  color:var(--ink-400); font-weight:600; padding:13px 16px; background:var(--surface-alt);
  border-bottom:1px solid var(--border);
}
.doc-table tbody td{ padding:13px 16px; border-bottom:1px solid var(--border); font-size:13.8px; vertical-align:middle; }
.doc-table tbody tr:last-child td{ border-bottom:none; }
.doc-table tbody tr:hover{ background:#fbfcfe; }
.doc-table tbody tr.selected{ background:var(--info-bg); }

.file-cell{ display:flex; align-items:center; gap:12px; }
.file-icon{
  width:36px; height:36px; border-radius:9px; flex:none;
  display:flex; align-items:center; justify-content:center; color:#fff; position:relative;
}
.file-icon::after{
  content:""; position:absolute; top:-1px; right:-1px; width:11px; height:11px;
  border-radius:3px; background:inherit; filter:brightness(0.75);
}
.file-name{ font-weight:600; color:var(--ink-900); }
.file-sub{ font-size:12px; color:var(--ink-400); margin-top:1px; }

.badge{
  display:inline-flex; align-items:center; gap:6px; padding:4px 10px; border-radius:20px;
  font-size:11.5px; font-weight:700;
}
.badge.valide{ background:var(--success-bg); color:#166534; }
.badge.attente{ background:var(--warning-bg); color:#92400e; }
.badge.archive{ background:var(--surface-alt); color:var(--ink-600); }
.badge i{ width:6px; height:6px; border-radius:50%; background:currentColor; }

.star-btn{ background:none; border:none; color:var(--ink-400); padding:4px; }
.star-btn.on{ color:var(--warning); }

.row-actions{ display:flex; gap:4px; justify-content:flex-end; }
.row-actions button{
  width:30px; height:30px; border-radius:8px; border:1px solid transparent; background:none; color:var(--ink-400);
  display:flex; align-items:center; justify-content:center;
}
.row-actions button:hover{ background:var(--surface-alt); color:var(--ink-700); }
.row-actions button.danger:hover{ background:var(--danger-bg); color:var(--danger); }

.empty-state{ padding:70px 30px; text-align:center; }
.empty-state svg{ margin-bottom:16px; color:var(--ink-400); }
.empty-state h3{ font-size:16.5px; margin-bottom:6px; }
.empty-state p{ color:var(--ink-600); font-size:13.8px; max-width:340px; margin:0 auto; }

/* ---------- Modale d'import ---------- */
.modal-overlay{
  position:fixed; inset:0; background:rgba(6,20,40,0.55); backdrop-filter:blur(2px);
  display:none; align-items:center; justify-content:center; z-index:50; padding:20px;
}
.modal-overlay.open{ display:flex; }
.modal-box{
  background:#fff; border-radius:18px; width:100%; max-width:460px; padding:26px;
  box-shadow:var(--shadow-lg);
}
.modal-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; }
.modal-head h3{ font-size:17px; }
.modal-close{ background:none; border:none; color:var(--ink-400); padding:4px; }
.modal-close:hover{ color:var(--ink-900); }

.dropzone{
  border:2px dashed var(--border-strong); border-radius:14px; padding:28px 16px; text-align:center;
  color:var(--ink-600); font-size:13.5px; margin-bottom:16px; transition:border-color .15s, background .15s;
}
.dropzone.drag{ border-color:var(--blue-500); background:var(--info-bg); }
.dropzone svg{ color:var(--blue-500); margin-bottom:8px; }
.dropzone b{ color:var(--ink-900); }

.field-inline{ margin-bottom:14px; }
.field-inline label{ display:block; font-size:12.5px; font-weight:600; color:var(--ink-700); margin-bottom:6px; }
.field-inline select, .field-inline input{
  width:100%; padding:10px 12px; border-radius:9px; border:1.5px solid var(--border); font-size:13.5px;
}
.modal-actions{ display:flex; gap:10px; margin-top:20px; }
.btn-secondary{
  flex:1; padding:11px; border-radius:10px; border:1.5px solid var(--border); background:#fff;
  color:var(--ink-700); font-weight:600; font-size:13.5px;
}
.btn-secondary:hover{ background:var(--surface-alt); }
.modal-actions .btn-primary{ flex:1.4; }

/* Toast */
.toast{
  position:fixed; bottom:24px; right:24px; z-index:60;
  background:var(--navy-900); color:#fff; padding:13px 18px; border-radius:12px;
  font-size:13.5px; display:flex; align-items:center; gap:10px; box-shadow:var(--shadow-lg);
  transform:translateY(20px); opacity:0; pointer-events:none; transition:transform .25s, opacity .25s;
}
.toast.show{ transform:translateY(0); opacity:1; }
.toast svg{ color:var(--cyan-400); flex:none; }

@media (max-width: 1080px){
  .kpi-row{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width: 860px){
  .app-shell{ grid-template-columns:1fr; }
  .sidebar{ display:none; }
}

/* ---------- Aperçu document ---------- */
.modal-preview{ max-width:900px; width:95vw; }
.modal-wide{ max-width:780px; }
.modal-head-actions{ display:flex; align-items:center; gap:10px; }
.preview-body{
  min-height:400px; max-height:75vh; overflow:auto;
  background:var(--surface-alt); border-radius:12px; border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
}
.preview-body iframe{ width:100%; height:70vh; border:none; border-radius:12px; }
.preview-body img{ max-width:100%; max-height:70vh; object-fit:contain; }
.preview-body video, .preview-body audio{ max-width:100%; }
.preview-body pre{
  width:100%; padding:16px; margin:0; font-family:var(--font-mono); font-size:12.5px;
  white-space:pre-wrap; word-break:break-word; text-align:left; align-self:flex-start;
}
.preview-fallback{ text-align:center; padding:40px 20px; }
.preview-fallback .file-icon.large{ width:64px; height:64px; margin:0 auto 16px; font-size:14px; }
.preview-fallback .muted{ color:var(--ink-600); font-size:13.5px; margin:8px 0 20px; }
.preview-fallback .btn-primary{ width:auto; display:inline-flex; padding:10px 20px; }

.clickable{ cursor:pointer; }
.doc-row.dragging{ opacity:0.5; }
.doc-row[draggable]{ cursor:grab; }

/* ---------- Drag global ---------- */
.global-drop-overlay{
  position:fixed; inset:0; z-index:40;
  background:rgba(6,20,40,0.65); backdrop-filter:blur(4px);
  display:none; align-items:center; justify-content:center;
  pointer-events:none;
}
.global-drop-overlay.show{ display:flex; pointer-events:all; }
.global-drop-inner{
  border:3px dashed var(--cyan-400); border-radius:24px; padding:48px 60px;
  text-align:center; color:#fff;
}
.global-drop-inner svg{ color:var(--cyan-400); margin-bottom:12px; }
.global-drop-inner b{ display:block; font-size:20px; margin-bottom:6px; }
.global-drop-inner span{ font-size:14px; color:#c9d6ea; }

/* ---------- Admin ---------- */
.admin-grid{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.admin-grid h4{ font-size:14px; margin-bottom:12px; color:var(--ink-700); }
.admin-users-list{ display:flex; flex-direction:column; gap:8px; max-height:200px; overflow-y:auto; }
.admin-user-row{
  display:flex; align-items:center; gap:10px; padding:10px 12px;
  background:var(--surface-alt); border-radius:10px; font-size:13px;
}
.admin-user-row b{ display:block; }
.admin-user-row .muted{ font-size:12px; color:var(--ink-400); }
.admin-user-row .badge{ margin-left:auto; }
.admin-form{ display:flex; flex-direction:column; gap:8px; }
.admin-form input, .admin-form select{
  padding:10px 12px; border-radius:9px; border:1.5px solid var(--border); font-size:13.5px;
}
.admin-form .btn-primary{ width:auto; margin-top:4px; }
.perm-list{ margin-top:12px; display:flex; flex-direction:column; gap:8px; }
.perm-row{
  display:flex; align-items:center; gap:10px; flex-wrap:wrap;
  padding:10px 12px; background:var(--surface-alt); border-radius:10px; font-size:12.5px;
}
.perm-row label{ display:flex; align-items:center; gap:4px; color:var(--ink-600); }
.perm-row button.danger{
  margin-left:auto; width:28px; height:28px; border-radius:6px; border:none;
  background:var(--danger-bg); color:var(--danger); font-size:16px; font-weight:700;
}
.perm-add-row{ display:flex; gap:8px; margin-top:8px; }
.perm-add-row select{ flex:1; padding:8px 10px; border-radius:9px; border:1.5px solid var(--border); }
.btn-secondary.sm{ padding:7px 14px; font-size:12.5px; border-radius:8px; border:1.5px solid var(--border); background:#fff; font-weight:600; }
.muted{ color:var(--ink-600); }

@media (max-width: 700px){
  .admin-grid{ grid-template-columns:1fr; }
  .modal-preview{ max-width:100%; }
}

/* ---------- Recherche autocomplétion ---------- */
.search-wrap{ position:relative; }
.search-suggestions{
  position:absolute; top:calc(100% + 6px); left:0; right:0; z-index:20;
  background:#fff; border:1px solid var(--border); border-radius:12px;
  box-shadow:var(--shadow-lg); max-height:420px; overflow-y:auto;
  display:none;
}
.search-suggestions.open{ display:block; }
.suggest-item{
  width:100%; display:flex; align-items:flex-start; gap:12px; padding:12px 14px;
  border:none; background:none; text-align:left; cursor:pointer; border-bottom:1px solid var(--border);
}
.suggest-item:last-child{ border-bottom:none; }
.suggest-item:hover{ background:var(--surface-alt); }
.suggest-item mark{ background:#fef08a; color:inherit; padding:0 2px; border-radius:2px; }
.file-icon.sm{ width:32px; height:32px; font-size:8px; }
.suggest-body{ flex:1; min-width:0; }
.suggest-title{ font-weight:600; font-size:13.5px; color:var(--ink-900); }
.suggest-meta{ font-size:12px; color:var(--ink-600); margin-top:2px; }
.suggest-sub{ font-size:11.5px; color:var(--ink-400); margin-top:3px; }
.suggest-empty{ padding:16px; font-size:13px; color:var(--ink-600); }

/* ---------- Import ---------- */
.import-preview{
  background:var(--surface-alt); border:1px solid var(--border); border-radius:10px;
  padding:12px 14px; font-size:13px; margin-bottom:14px;
}
.import-file-list{ display:flex; flex-direction:column; gap:3px; margin-top:8px; max-height:160px; overflow-y:auto; }
.import-file-list span{
  font-size:12px; color:var(--ink-600); font-family:var(--font-mono);
  display:flex; align-items:center; justify-content:space-between; gap:8px;
}
.import-file-list .file-size{ color:var(--ink-400); flex-shrink:0; }
.import-file-list .remove-file{
  border:none; background:none; color:var(--ink-400); cursor:pointer; padding:0 4px; font-size:14px; line-height:1;
}
.import-file-list .remove-file:hover{ color:#dc2626; }
.check-row{ display:flex; align-items:center; gap:8px; font-size:13px; color:var(--ink-700); margin-bottom:14px; }
.check-row input{ accent-color:var(--blue-600); }

/* ---------- Dossiers sidebar ---------- */
.btn-new-folder{
  width:100%; padding:8px 10px; margin-bottom:8px; border-radius:8px;
  border:1px dashed rgba(255,255,255,0.25); background:rgba(255,255,255,0.05);
  color:#dbe6f6; font-size:12.5px; font-weight:600; display:flex; align-items:center; justify-content:center; gap:6px;
}
.btn-new-folder:hover{ background:rgba(255,255,255,0.1); color:#fff; }
.folder-drop-target.drop-hover{ background:rgba(56,189,248,0.25) !important; outline:2px dashed var(--cyan-400); }

/* ---------- Admin amélioré ---------- */
.admin-tabs{ display:flex; gap:6px; margin-bottom:18px; border-bottom:1px solid var(--border); padding-bottom:10px; }
.admin-tab{
  padding:8px 14px; border:none; background:none; font-size:13px; font-weight:600;
  color:var(--ink-600); border-radius:8px; cursor:pointer;
}
.admin-tab.active{ background:var(--info-bg); color:var(--blue-600); }
.admin-panel{ display:none; }
.admin-panel.active{ display:block; }
.admin-panel h4{ font-size:14px; margin:16px 0 10px; color:var(--ink-700); }
.admin-form.grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.admin-form .span-2{ grid-column:span 2; }
.admin-user-card{
  display:grid; grid-template-columns:1fr auto; gap:8px 12px; align-items:center;
  padding:12px 14px; background:var(--surface-alt); border-radius:12px; margin-bottom:8px;
}
.admin-user-main b{ display:block; font-size:14px; }
.admin-user-badges{ display:flex; gap:6px; flex-wrap:wrap; }
.admin-user-actions{ grid-column:1 / -1; display:flex; gap:6px; flex-wrap:wrap; }
.admin-folder-card{
  display:flex; align-items:center; gap:10px; padding:10px 12px;
  background:var(--surface-alt); border-radius:10px; margin-bottom:8px;
}
.admin-folder-card b{ display:block; }
.admin-folder-card .muted{ font-size:12px; }
.btn-danger.sm, .btn-danger{
  padding:7px 12px; font-size:12px; border-radius:8px; border:none;
  background:var(--danger-bg); color:var(--danger); font-weight:600; cursor:pointer;
}
.btn-danger.sm:disabled{ opacity:0.45; cursor:not-allowed; }
.perm-name{ min-width:100px; font-weight:600; }

.import-server-info{
  background:var(--info-bg); border:1px solid #bfdbfe; border-radius:12px;
  padding:14px 16px; font-size:13px; margin-bottom:16px; line-height:1.6;
}
.import-server-info ol{ margin:8px 0 0 18px; padding:0; }
.import-server-info code{ background:#fff; padding:2px 6px; border-radius:4px; font-size:12px; }
.server-import-list{ display:flex; flex-direction:column; gap:8px; }
.server-import-card{
  padding:12px 14px; background:var(--surface-alt); border-radius:10px;
  display:flex; flex-direction:column; gap:8px;
}
.server-import-actions{ display:flex; flex-wrap:wrap; align-items:center; gap:8px; }
.cli-hint{ font-size:11px; color:var(--ink-600); background:#fff; padding:4px 8px; border-radius:6px; word-break:break-all; }

.large-zip-panel{ background:var(--info-bg); border:1px solid #bfdbfe; border-radius:10px; padding:12px 14px; margin-bottom:14px; }
.progress-wrap{ height:10px; background:var(--border); border-radius:6px; overflow:hidden; margin:10px 0 6px; }
.progress-bar{ height:100%; width:0%; background:var(--grad-cta); transition:width .25s; border-radius:6px; }
.progress-label{ font-size:12.5px; color:var(--ink-600); font-family:var(--font-mono); }
