/* ============================================================
   WEST ELIZABETH LAW ENFORCEMENT — MDT v5
   Meilleure lisibilité · Nouvelle palette · 1905
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;0,900;1,400&family=Lora:ital,wght@0,400;0,600;1,400&family=Special+Elite&display=swap');

:root {
  /* Palette principale — plus contrastée pour la lisibilité */
  --ink:        #12080A;
  --leather:    #4A1E0A;
  --sepia:      #7A5510;
  --gold:       #C8971A;
  --parchment:  #F5E6CC;
  --ivory:      #EDD8B8;
  --cream:      #FAF2E2;
  --bordeaux:   #7A1515;
  --border:     #9A7830;
  --green:      #245C18;
  --shadow:     rgba(18,8,10,0.35);

  /* Typographie — tailles augmentées */
  --font-display: 'Playfair Display', Georgia, serif;
  --font-body:    'Lora', 'Times New Roman', serif;
  --font-stamp:   'Special Elite', 'Courier New', monospace;

  /* Tailles de texte lisibles */
  --text-xs:   0.75rem;   /* 12px */
  --text-sm:   0.875rem;  /* 14px */
  --text-base: 1rem;      /* 16px */
  --text-lg:   1.125rem;  /* 18px */
  --text-xl:   1.25rem;   /* 20px */
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; -webkit-text-size-adjust: 100%; }

body {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.6;
  background-color: var(--ink);
  color: var(--ink);
  min-height: 100vh;
  background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none'%3E%3Cg fill='%23C8971A' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}

/* ── Loader ── */
#app-loader { position:fixed;inset:0;background:var(--ink);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999;gap:1.5rem; }
.loader-star { font-size:3rem;animation:pulse 1.5s ease-in-out infinite; }
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(.92)} }
.loader-text { font-family:var(--font-stamp);font-size:var(--text-sm);letter-spacing:.2em;text-transform:uppercase;color:var(--gold);opacity:.85; }
.page-loading { padding:3rem;text-align:center;font-family:var(--font-stamp);color:var(--sepia);font-size:var(--text-sm);letter-spacing:.12em; }

/* ── Login ── */
#login-screen { display:none;align-items:center;justify-content:center;min-height:100vh;padding:2rem;background:radial-gradient(ellipse at center,#2d1208 0%,#0e0804 100%); }
.login-card { background:var(--parchment);border:3px double var(--border);box-shadow:0 0 0 6px var(--leather),0 24px 64px rgba(0,0,0,.75);max-width:480px;width:100%;padding:3rem 2.5rem;position:relative;text-align:center; }
.login-card::before { content:'';position:absolute;inset:10px;border:1px solid var(--border);pointer-events:none; }
.login-star { font-size:3.5rem;line-height:1;margin-bottom:.5rem; }
.login-title { font-family:var(--font-display);font-size:1.7rem;font-weight:900;letter-spacing:.05em;color:var(--leather);text-transform:uppercase;line-height:1.2; }
.login-subtitle { font-family:var(--font-stamp);font-size:var(--text-xs);letter-spacing:.18em;color:var(--sepia);margin-top:.4rem;text-transform:uppercase; }
.login-divider { display:flex;align-items:center;gap:.75rem;margin:1.5rem 0;color:var(--border); }
.login-divider::before,.login-divider::after { content:'';flex:1;height:1px;background:var(--border); }
.login-btn { margin-top:.5rem;width:100%;padding:1rem 1rem;background:var(--leather);color:var(--gold);border:none;font-family:var(--font-display);font-size:var(--text-base);font-weight:700;letter-spacing:.15em;text-transform:uppercase;cursor:pointer;transition:background .2s,transform .1s;box-shadow:0 4px 12px var(--shadow); }
.login-btn:hover { background:var(--bordeaux); }
.login-btn:active { transform:translateY(1px); }
.login-btn:disabled { opacity:.6;cursor:not-allowed; }
.login-error { margin-top:.7rem;font-family:var(--font-stamp);font-size:var(--text-sm);color:var(--bordeaux);letter-spacing:.06em;min-height:1.4em; }
.login-footer { margin-top:1.5rem;font-family:var(--font-stamp);font-size:var(--text-xs);letter-spacing:.1em;color:var(--sepia);opacity:.75;text-transform:uppercase; }

/* ── Forms — lisibilité améliorée ── */
.form-group { display:flex;flex-direction:column;gap:.4rem; }
.form-group label { font-family:var(--font-stamp);font-size:var(--text-xs);letter-spacing:.13em;text-transform:uppercase;color:var(--leather);font-weight:normal; }
.form-group input,.form-group select,.form-group textarea {
  padding:.7rem 1rem;
  background:var(--cream);
  border:1px solid var(--border);
  border-bottom:2px solid var(--leather);
  font-family:var(--font-body);
  font-size:var(--text-base); /* 16px — important pour éviter le zoom mobile */
  color:var(--ink);
  outline:none;
  width:100%;
  transition:border-color .2s,background .2s;
  line-height:1.5;
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus { border-color:var(--sepia);background:#fff; }
.form-group textarea { resize:vertical;min-height:90px; }
.form-grid { display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:1rem; }
.form-group.full { grid-column:1/-1; }
.form-group.half { grid-column:span 1; }

/* ── App ── */
#app { display:none;min-height:100vh;background:var(--ivory); }

/* ── Header ── */
.app-header { background:linear-gradient(180deg,var(--leather) 0%,#2a1005 100%);border-bottom:3px solid var(--gold);padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;min-height:68px;position:sticky;top:0;z-index:100;box-shadow:0 4px 16px rgba(0,0,0,.5); }
.header-brand { display:flex;align-items:center;gap:.8rem; }
.header-star { font-size:2rem; }
.header-title { font-family:var(--font-display);font-size:1.05rem;font-weight:900;color:var(--gold);letter-spacing:.05em;text-transform:uppercase; }
.header-sub { font-family:var(--font-stamp);font-size:var(--text-xs);color:var(--ivory);letter-spacing:.15em;text-transform:uppercase;opacity:.75; }
.header-right { display:flex;align-items:center;gap:1.25rem; }
.header-agent { text-align:right;line-height:1.4; }
.header-agent-name { font-family:var(--font-display);font-size:.95rem;font-weight:700;color:var(--gold); }
.header-agent-rank { font-family:var(--font-stamp);font-size:var(--text-xs);color:var(--ivory);letter-spacing:.1em;text-transform:uppercase;opacity:.8; }
.header-badge { display:inline-flex;align-items:center;gap:.3rem;background:var(--bordeaux);border:1px solid var(--gold);color:var(--gold);font-family:var(--font-stamp);font-size:var(--text-xs);letter-spacing:.1em;text-transform:uppercase;padding:.3rem .7rem;cursor:pointer;transition:background .2s; }
.header-badge:hover { background:#8B0000; }

/* ── Layout ── */
.app-layout { display:flex;min-height:calc(100vh - 68px); }

/* ── Sidebar ── */
.sidebar { width:240px;min-width:240px;background:linear-gradient(180deg,#2d1208 0%,var(--ink) 100%);border-right:2px solid var(--border);padding:1rem 0;overflow-y:auto; }
.sidebar-section-label { font-family:var(--font-stamp);font-size:var(--text-xs);letter-spacing:.18em;text-transform:uppercase;color:var(--sepia);padding:.85rem .85rem .4rem;border-top:1px solid rgba(154,120,48,.25);margin-top:.5rem; }
.sidebar-section-label:first-child { border-top:none;margin-top:0; }
.nav-item { display:flex;align-items:center;gap:.65rem;padding:.65rem 1.1rem;color:var(--ivory);font-family:var(--font-body);font-size:var(--text-sm);cursor:pointer;border:none;background:none;width:100%;text-align:left;border-left:3px solid transparent;opacity:.88;transition:background .15s,color .15s; }
.nav-item:hover { background:rgba(200,151,26,.12);color:var(--gold);opacity:1; }
.nav-item.active { background:rgba(200,151,26,.2);color:var(--gold);border-left-color:var(--gold);opacity:1;font-weight:600; }
.nav-icon { font-size:1rem;width:20px;text-align:center;flex-shrink:0; }
.sidebar-dept-legend { margin:1.5rem .85rem .5rem;padding-top:1rem;border-top:1px solid rgba(154,120,48,.25);font-family:var(--font-stamp);font-size:var(--text-xs);color:var(--ivory);opacity:.65;line-height:2.1; }
.sidebar-dept-title { font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--sepia);margin-bottom:.4rem;opacity:1; }

/* ── Main ── */
.main-content { flex:1;padding:2rem;overflow-y:auto;background:var(--ivory); }

/* ── Page header ── */
.page-header { border-bottom:2px solid var(--border);padding-bottom:1rem;margin-bottom:1.75rem;display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;flex-wrap:wrap; }
.page-title { font-family:var(--font-display);font-size:1.8rem;font-weight:900;color:var(--leather);text-transform:uppercase;letter-spacing:.04em;line-height:1; }
.page-eyebrow { font-family:var(--font-stamp);font-size:var(--text-xs);letter-spacing:.18em;text-transform:uppercase;color:var(--sepia);margin-bottom:.3rem; }

/* ── Cards ── */
.card { background:var(--cream);border:1px solid var(--border);box-shadow:2px 4px 14px rgba(18,8,10,.1);padding:1.5rem;margin-bottom:1.25rem;position:relative; }
.card::before { content:'';position:absolute;top:5px;left:5px;right:5px;bottom:5px;border:1px solid rgba(154,120,48,.18);pointer-events:none; }
.card-title { font-family:var(--font-display);font-size:1.05rem;font-weight:700;color:var(--leather);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);padding-bottom:.65rem;margin-bottom:1rem; }

/* ── Stats ── */
.stats-grid { display:grid;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:1rem;margin-bottom:1.5rem; }
.stat-card { background:var(--cream);border:1px solid var(--border);border-top:4px solid var(--sepia);padding:1.25rem 1rem;text-align:center;box-shadow:2px 3px 8px rgba(18,8,10,.1); }
.stat-card.urgent { border-top-color:var(--bordeaux); }
.stat-card.gold   { border-top-color:var(--gold); }
.stat-value { font-family:var(--font-display);font-size:2.6rem;font-weight:900;color:var(--leather);line-height:1; }
.stat-label { font-family:var(--font-stamp);font-size:var(--text-xs);letter-spacing:.15em;text-transform:uppercase;color:var(--sepia);margin-top:.4rem; }

/* ── Table — texte plus lisible ── */
.table-wrap { overflow-x:auto; }
table { width:100%;border-collapse:collapse;font-size:var(--text-sm); }
thead tr { background:var(--leather);color:var(--gold); }
thead th { padding:.8rem 1rem;font-family:var(--font-stamp);font-size:var(--text-xs);letter-spacing:.13em;text-transform:uppercase;text-align:left;font-weight:normal;white-space:nowrap; }
tbody tr { border-bottom:1px solid var(--border);background:var(--cream);transition:background .15s; }
tbody tr:nth-child(even) { background:var(--parchment); }
tbody tr:hover { background:#f0e4c8; }
td { padding:.75rem 1rem;color:var(--ink);vertical-align:middle;line-height:1.5; }
.table-footer { display:flex;align-items:center;justify-content:space-between;padding:.8rem 1rem;font-family:var(--font-stamp);font-size:var(--text-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--sepia);flex-wrap:wrap;gap:.5rem; }
.fw-bold { font-weight:600; }
.empty-cell { text-align:center;padding:2rem;font-family:var(--font-stamp);font-size:var(--text-sm);color:var(--sepia); }

/* ── Badges — plus grands ── */
.badge { display:inline-block;padding:.2rem .65rem;font-family:var(--font-stamp);font-size:var(--text-xs);letter-spacing:.1em;text-transform:uppercase;border:1px solid currentColor; }
.badge-red   { color:var(--bordeaux);background:#f5e0e0; }
.badge-gold  { color:var(--sepia);   background:#f7eecc; }
.badge-green { color:#245C18;        background:#e2f4da; }
.badge-grey  { color:#5a5a5a;        background:#ededea; }
.badge-brown { color:var(--leather); background:#f0e2d0; }

/* ── Buttons — plus grands ── */
.btn { display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.2rem;font-family:var(--font-stamp);font-size:var(--text-sm);letter-spacing:.1em;text-transform:uppercase;cursor:pointer;border:1px solid;transition:all .15s;white-space:nowrap; }
.btn:disabled { opacity:.5;cursor:not-allowed; }
.btn-primary  { background:var(--leather);color:var(--gold);border-color:var(--leather); }
.btn-primary:hover:not(:disabled)  { background:var(--bordeaux);border-color:var(--bordeaux); }
.btn-secondary { background:transparent;color:var(--leather);border-color:var(--border); }
.btn-secondary:hover:not(:disabled) { background:var(--parchment); }
.btn-danger { background:transparent;color:var(--bordeaux);border-color:var(--bordeaux); }
.btn-danger:hover:not(:disabled) { background:var(--bordeaux);color:var(--ivory); }
.btn-sm { padding:.32rem .7rem;font-size:var(--text-xs); }
.btn-group { display:flex;gap:.4rem;flex-wrap:wrap; }

/* ── Search ── */
.search-bar { display:flex;gap:.75rem;align-items:flex-end;margin-bottom:1.25rem;flex-wrap:wrap; }
.search-bar .form-group { margin-bottom:0;flex:1;min-width:180px; }

/* ── Modal ── */
.modal-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.65);
  z-index: 500;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  /* Désactiver les clics sur le fond — la modale seule est cliquable */
  pointer-events: none;
}
.modal-overlay.open { display: flex; }
.modal {
  background: var(--parchment);
  border: 2px solid var(--border);
  box-shadow: 0 0 0 5px var(--leather), 0 24px 56px rgba(0,0,0,.65);
  width: 100%;
  max-width: 700px;
  max-height: 92vh;
  overflow-y: auto;
  position: relative;
  /* Réactiver les clics uniquement sur la modale */
  pointer-events: all;
}
.modal-header { background:var(--leather);color:var(--gold);padding:1.1rem 1.5rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10; }
.modal-title { font-family:var(--font-display);font-size:1.05rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase; }
.modal-close { background:none;border:none;color:var(--gold);font-size:1.4rem;cursor:pointer;opacity:.75;line-height:1; }
.modal-close:hover { opacity:1; }
.modal-body { padding:1.5rem; }
.modal-footer { padding:1rem 1.5rem;border-top:1px solid var(--border);display:flex;gap:.75rem;justify-content:flex-end;flex-wrap:wrap; }

/* ── Document fields ── */
.document-header { text-align:center;border-bottom:2px double var(--border);padding-bottom:1.25rem;margin-bottom:1.25rem; }
.document-title { font-family:var(--font-display);font-size:1.4rem;font-weight:900;text-transform:uppercase;letter-spacing:.08em;color:var(--leather); }
.document-ref { font-family:var(--font-stamp);font-size:var(--text-xs);letter-spacing:.14em;color:var(--sepia);margin-top:.3rem; }
.doc-field { display:flex;align-items:baseline;gap:.6rem;border-bottom:1px solid var(--border);padding:.4rem 0; }
.doc-field-label { font-family:var(--font-stamp);font-size:var(--text-xs);letter-spacing:.12em;text-transform:uppercase;color:var(--sepia);min-width:140px;flex-shrink:0; }
.doc-field-value { font-size:var(--text-sm);color:var(--ink);flex:1;line-height:1.5; }

/* ── Signature ── */
.signature-block { display:flex;gap:2rem;margin-top:2rem;padding-top:1.25rem;border-top:2px double var(--border);flex-wrap:wrap; }
.signature-field { flex:1;min-width:160px; }
.signature-line { border-bottom:1px solid var(--ink);height:44px;margin-bottom:.3rem;font-family:var(--font-display);font-style:italic;font-size:1.15rem;color:var(--ink);display:flex;align-items:flex-end;padding-bottom:3px; }
.signature-label { font-family:var(--font-stamp);font-size:var(--text-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--sepia); }

/* ── Warrant ── */
.warrant-card { background:var(--cream);border:1px solid var(--border);border-left:4px solid var(--bordeaux);padding:1rem 1.25rem;margin-bottom:.75rem;display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap; }
.warrant-card.inactive { border-left-color:var(--sepia);opacity:.72; }
.warrant-name { font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--leather); }
.warrant-details { font-family:var(--font-stamp);font-size:var(--text-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--sepia);margin-top:.25rem; }

/* ── Reports ── */
.report-list-title { font-family:var(--font-display);font-size:.95rem;font-weight:700;color:var(--leather); }

/* ── Log ── */
.log-entry { display:flex;gap:1rem;padding:.7rem 0;border-bottom:1px solid rgba(154,120,48,.2);font-size:var(--text-sm); }
.log-time { font-family:var(--font-stamp);font-size:var(--text-xs);letter-spacing:.06em;color:var(--sepia);min-width:155px;flex-shrink:0; }
.log-actor { font-weight:600;color:var(--leather); }

/* ── Officers ── */
.officers-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:.85rem; }
.officer-card { background:var(--cream);border:1px solid var(--border);padding:1.1rem 1.25rem;display:flex;align-items:center;gap:1rem;transition:box-shadow .15s; }
.officer-card:hover { box-shadow:0 4px 12px rgba(18,8,10,.15); }
.officer-avatar { width:50px;height:50px;background:var(--leather);border:2px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0; }
.officer-name { font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--leather); }
.officer-rank { font-family:var(--font-stamp);font-size:var(--text-xs);letter-spacing:.12em;text-transform:uppercase;color:var(--sepia);margin-top:.15rem; }

/* ── Tabs ── */
.tabs { display:flex;border-bottom:2px solid var(--border);margin-bottom:1.25rem;overflow-x:auto; }
.tab { padding:.65rem 1.35rem;font-family:var(--font-stamp);font-size:var(--text-xs);letter-spacing:.12em;text-transform:uppercase;color:var(--sepia);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;background:none;border-top:none;border-left:none;border-right:none;transition:color .15s;white-space:nowrap; }
.tab:hover { color:var(--leather); }
.tab.active { color:var(--leather);border-bottom-color:var(--leather);font-weight:600; }

/* ── Notices ── */
.notice { padding:.85rem 1.1rem;border-left:4px solid;font-family:var(--font-stamp);font-size:var(--text-sm);letter-spacing:.04em;margin-bottom:1rem;line-height:1.6; }
.notice-warn    { border-color:var(--gold);    background:#fdf5d0;color:#5a4800; }
.notice-error   { border-color:var(--bordeaux);background:#f9e0e0;color:var(--bordeaux); }
.notice-info    { border-color:var(--sepia);   background:#f5edd0;color:var(--ink); }
.notice-success { border-color:var(--green);   background:#e0f4d8;color:var(--green); }

/* ── Photos ── */
.photo-section { margin-top:1.5rem;padding-top:1.25rem;border-top:1px dashed var(--border); }
.photo-section-title { font-family:var(--font-stamp);font-size:var(--text-xs);letter-spacing:.14em;text-transform:uppercase;color:var(--leather);margin-bottom:.85rem;font-weight:600; }
.photo-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(115px,1fr));gap:.85rem;margin-bottom:1rem; }
.photo-thumb { position:relative;cursor:pointer;border:1px solid var(--border);background:var(--parchment);overflow:hidden;aspect-ratio:1;transition:transform .15s,box-shadow .15s; }
.photo-thumb:hover { transform:scale(1.03);box-shadow:0 4px 12px var(--shadow); }
.photo-thumb img { width:100%;height:100%;object-fit:cover;display:block; }
.photo-error { background:var(--parchment);display:flex;align-items:center;justify-content:center;font-size:1.5rem; }
.photo-name { position:absolute;bottom:0;left:0;right:0;background:rgba(18,8,10,.72);color:var(--ivory);font-family:var(--font-stamp);font-size:.6rem;letter-spacing:.06em;padding:.2rem .35rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
.photo-delete { position:absolute;top:.25rem;right:.25rem;background:var(--bordeaux);color:white;border:none;width:22px;height:22px;border-radius:50%;font-size:.68rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s; }
.photo-thumb:hover .photo-delete { opacity:1; }
.photo-upload-label { display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1.1rem;background:transparent;color:var(--leather);border:1px dashed var(--border);font-family:var(--font-stamp);font-size:var(--text-xs);letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:background .15s,border-color .15s; }
.photo-upload-label:hover { background:var(--parchment);border-color:var(--leather); }

/* ── Toast ── */
.toast {
  position:fixed;bottom:1.5rem;right:1.5rem;z-index:9999;
  background:var(--cream);border:1px solid var(--border);border-left:4px solid var(--sepia);
  padding:.85rem 1.35rem;font-family:var(--font-stamp);font-size:var(--text-sm);letter-spacing:.06em;
  box-shadow:0 4px 18px rgba(0,0,0,.25);max-width:340px;
  transition:opacity .4s;opacity:1;
}

/* ── Utility ── */
.hidden { display:none!important; }
.flex { display:flex; }
.items-center { align-items:center; }
.justify-between { justify-content:space-between; }
.flex-wrap { flex-wrap:wrap; }
.gap-sm { gap:.5rem; }
.mt-1 { margin-top:.5rem; }
.mt-2 { margin-top:1rem; }
.mt-3 { margin-top:1.5rem; }
.mb-1 { margin-bottom:.5rem; }
.mb-2 { margin-bottom:1rem; }
.text-muted { font-family:var(--font-stamp);font-size:var(--text-xs);color:var(--sepia);letter-spacing:.06em; }
.data-wrap { width:100%; }

/* ── Scrollbar ── */
::-webkit-scrollbar { width:8px;height:8px; }
::-webkit-scrollbar-track { background:var(--ink); }
::-webkit-scrollbar-thumb { background:var(--leather); }
::-webkit-scrollbar-thumb:hover { background:var(--sepia); }

/* ── Responsive ── */
@media (max-width:768px) {
  .sidebar { display:none; }
  .main-content { padding:1rem; }
  .stats-grid { grid-template-columns:repeat(2,1fr); }
  .form-grid { grid-template-columns:1fr; }
  .photo-grid { grid-template-columns:repeat(auto-fill,minmax(85px,1fr)); }
  .page-title { font-size:1.4rem; }
}
@media print {
  .app-header,.sidebar,.btn,.search-bar { display:none; }
  .main-content { padding:0; }
  .card { box-shadow:none; }
}

/* ── Quill éditeur de texte riche — style 1905 ── */
.quill-wrapper {
  border: 1px solid var(--border);
  border-bottom: 2px solid var(--leather);
  background: var(--cream);
}
.quill-wrapper .ql-toolbar {
  border: none;
  border-bottom: 1px solid var(--border);
  background: var(--parchment);
  padding: .4rem .5rem;
  flex-wrap: wrap;
}
.quill-wrapper .ql-toolbar button,
.quill-wrapper .ql-toolbar .ql-picker {
  color: var(--leather);
}
.quill-wrapper .ql-toolbar button:hover,
.quill-wrapper .ql-toolbar button.ql-active,
.quill-wrapper .ql-toolbar .ql-picker-label:hover {
  color: var(--bordeaux);
}
.quill-wrapper .ql-toolbar .ql-stroke { stroke: var(--leather); }
.quill-wrapper .ql-toolbar button:hover .ql-stroke,
.quill-wrapper .ql-toolbar button.ql-active .ql-stroke { stroke: var(--bordeaux); }
.quill-wrapper .ql-toolbar .ql-fill { fill: var(--leather); }
.quill-wrapper .ql-container {
  border: none;
  font-family: var(--font-body);
  font-size: .95rem;
}
.quill-wrapper .ql-editor {
  min-height: 160px;
  max-height: 340px;
  overflow-y: auto;
  color: var(--ink);
  line-height: 1.7;
}
.quill-wrapper .ql-editor.ql-blank::before {
  color: var(--sepia);
  font-style: italic;
  font-family: var(--font-body);
}
.quill-wrapper .ql-picker-options {
  background: var(--cream);
  border: 1px solid var(--border);
}

/* ── Zone narrative — préserve la mise en forme Quill ── */
.narrative-content p {
  margin-bottom: .85rem;
  line-height: 1.75;
}
.narrative-content p:last-child { margin-bottom: 0; }
.narrative-content p.ql-align-center { text-align: center; }
.narrative-content p.ql-align-right  { text-align: right; }
.narrative-content p.ql-align-justify { text-align: justify; }
.narrative-content h1, .narrative-content h2, .narrative-content h3 {
  font-family: var(--font-display);
  color: var(--leather);
  margin: .75rem 0 .4rem;
}
.narrative-content strong { font-weight: 700; }
.narrative-content em     { font-style: italic; }
.narrative-content u      { text-decoration: underline; }
.narrative-content s      { text-decoration: line-through; }
.narrative-content blockquote {
  border-left: 3px solid var(--border);
  margin: .5rem 0;
  padding-left: 1rem;
  color: var(--sepia);
  font-style: italic;
}
.narrative-content ol, .narrative-content ul {
  padding-left: 1.5rem;
  margin-bottom: .75rem;
}
.narrative-content li { margin-bottom: .25rem; }
.narrative-content .ql-indent-1 { padding-left: 2rem; }
.narrative-content .ql-indent-2 { padding-left: 4rem; }
