/* ============================================================
   WEST ELIZABETH LAW ENFORCEMENT — MDT v3
   Firebase Edition · Anno Domini 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 {
  --ink:       #1A1008;
  --leather:   #3D1F0D;
  --sepia:     #8B6914;
  --gold:      #C9A227;
  --parchment: #F2E8D0;
  --ivory:     #EDE0C4;
  --cream:     #FBF5E6;
  --bordeaux:  #6B1A1A;
  --border:    #A08040;
  --shadow:    rgba(26,16,8,0.35);
  --font-display: 'Playfair Display', Georgia, serif;
  --font-body:    'Lora', 'Times New Roman', serif;
  --font-stamp:   'Special Elite', 'Courier New', monospace;
}

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

body {
  font-family: var(--font-body);
  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' fill-rule='evenodd'%3E%3Cg fill='%23C9A227' fill-opacity='0.04'%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:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);opacity:.8; }

/* ── Login ── */
#login-screen { display:none;align-items:center;justify-content:center;min-height:100vh;padding:2rem;background:radial-gradient(ellipse at center,#2a1005 0%,#0e0804 100%); }
.login-card { background:var(--parchment);border:3px double var(--border);box-shadow:0 0 0 6px var(--leather),0 20px 60px rgba(0,0,0,.7);max-width:460px;width:100%;padding:3rem 2.5rem;position:relative;text-align:center; }
.login-card::before { content:'';position:absolute;inset:8px;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.5rem;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:.72rem;letter-spacing:.16em;color:var(--sepia);margin-top:.35rem;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:.9rem 1rem;background:var(--leather);color:var(--gold);border:none;font-family:var(--font-display);font-size:1rem;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:.6rem;font-family:var(--font-stamp);font-size:.78rem;color:var(--bordeaux);letter-spacing:.06em;min-height:1.2em; }
.login-footer { margin-top:1.5rem;font-family:var(--font-stamp);font-size:.62rem;letter-spacing:.1em;color:var(--sepia);opacity:.7;text-transform:uppercase; }
.login-hint { font-family:var(--font-stamp);font-size:.62rem;color:var(--sepia);margin-top:.25rem;text-align:left;opacity:.8; }

/* ── Forms ── */
.form-group { display:flex;flex-direction:column;gap:.35rem; }
.form-group label { font-family:var(--font-stamp);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--leather); }
.form-group input,.form-group select,.form-group textarea { padding:.65rem .9rem;background:var(--cream);border:1px solid var(--border);border-bottom:2px solid var(--leather);font-family:var(--font-body);font-size:.9rem;color:var(--ink);outline:none;width:100%;transition:border-color .2s; }
.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(200px,1fr));gap:1rem; }
.form-group.full { grid-column:1/-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:64px;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:.75rem; }
.header-star { font-size:1.8rem; }
.header-title { font-family:var(--font-display);font-size:1rem;font-weight:900;color:var(--gold);letter-spacing:.05em;text-transform:uppercase; }
.header-sub { font-family:var(--font-stamp);font-size:.58rem;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.3; }
.header-agent-name { font-family:var(--font-display);font-size:.85rem;font-weight:700;color:var(--gold); }
.header-agent-rank { font-family:var(--font-stamp);font-size:.58rem;color:var(--ivory);letter-spacing:.12em;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:.6rem;letter-spacing:.1em;text-transform:uppercase;padding:.25rem .6rem;cursor:pointer;transition:background .2s; }
.header-badge:hover { background:#8B0000; }

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

/* ── Sidebar ── */
.sidebar { width:230px;min-width:230px;background:linear-gradient(180deg,#2a1005 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:.58rem;letter-spacing:.18em;text-transform:uppercase;color:var(--sepia);padding:.75rem .75rem .35rem;border-top:1px solid rgba(139,105,20,.25);margin-top:.5rem; }
.sidebar-section-label:first-child { border-top:none;margin-top:0; }
.nav-item { display:flex;align-items:center;gap:.6rem;padding:.55rem 1rem;color:var(--ivory);font-family:var(--font-body);font-size:.82rem;cursor:pointer;border:none;background:none;width:100%;text-align:left;border-left:3px solid transparent;opacity:.85;transition:background .15s,color .15s; }
.nav-item:hover { background:rgba(201,162,39,.12);color:var(--gold);opacity:1; }
.nav-item.active { background:rgba(201,162,39,.18);color:var(--gold);border-left-color:var(--gold);opacity:1;font-weight:600; }
.nav-icon { font-size:.95rem;width:18px;text-align:center;flex-shrink:0; }
.sidebar-dept-legend { margin:1.5rem .75rem .5rem;padding-top:1rem;border-top:1px solid rgba(139,105,20,.25);font-family:var(--font-stamp);font-size:.6rem;color:var(--ivory);opacity:.65;line-height:2; }
.sidebar-dept-title { font-size:.57rem;letter-spacing:.18em;text-transform:uppercase;color:var(--sepia);margin-bottom:.4rem; }

/* ── 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.6rem;font-weight:900;color:var(--leather);text-transform:uppercase;letter-spacing:.04em;line-height:1; }
.page-eyebrow { font-family:var(--font-stamp);font-size:.63rem;letter-spacing:.18em;text-transform:uppercase;color:var(--sepia);margin-bottom:.25rem; }

/* ── Cards ── */
.card { background:var(--cream);border:1px solid var(--border);box-shadow:2px 3px 12px rgba(26,16,8,.12);padding:1.5rem;margin-bottom:1.25rem;position:relative; }
.card::before { content:'';position:absolute;top:4px;left:4px;right:4px;bottom:4px;border:1px solid rgba(160,128,64,.2);pointer-events:none; }
.card-title { font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--leather);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);padding-bottom:.6rem;margin-bottom:1rem; }

/* ── Stats ── */
.stats-grid { display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1.5rem; }
.stat-card { background:var(--cream);border:1px solid var(--border);border-top:3px solid var(--sepia);padding:1.25rem 1rem;text-align:center;box-shadow:2px 3px 8px rgba(26,16,8,.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.4rem;font-weight:900;color:var(--leather);line-height:1; }
.stat-label { font-family:var(--font-stamp);font-size:.63rem;letter-spacing:.15em;text-transform:uppercase;color:var(--sepia);margin-top:.4rem; }

/* ── Table ── */
.table-wrap { overflow-x:auto; }
table { width:100%;border-collapse:collapse;font-size:.87rem; }
thead tr { background:var(--leather);color:var(--gold); }
thead th { padding:.7rem 1rem;font-family:var(--font-stamp);font-size:.63rem;letter-spacing:.14em;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:#f5edda; }
td { padding:.65rem 1rem;color:var(--ink);vertical-align:middle; }
.table-footer { display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;font-family:var(--font-stamp);font-size:.63rem;letter-spacing:.08em;text-transform:uppercase;color:var(--sepia);flex-wrap:wrap;gap:.5rem; }

/* ── Badges ── */
.badge { display:inline-block;padding:.15rem .55rem;font-family:var(--font-stamp);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;border:1px solid currentColor; }
.badge-red   { color:var(--bordeaux);background:#f5e5e5; }
.badge-gold  { color:var(--sepia);   background:#f7f0d5; }
.badge-green { color:#2d5a1b;        background:#e8f5e0; }
.badge-grey  { color:#666;           background:#f0ece0; }
.badge-brown { color:var(--leather); background:#f0e8d5; }

/* ── Buttons ── */
.btn { display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1.1rem;font-family:var(--font-stamp);font-size:.7rem;letter-spacing:.12em;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:.28rem .65rem;font-size:.6rem; }
.btn-group { display:flex;gap:.4rem;flex-wrap:wrap; }

/* ── Search bar ── */
.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; }
.modal-overlay.open { display:flex; }
.modal { background:var(--parchment);border:2px solid var(--border);box-shadow:0 0 0 4px var(--leather),0 20px 50px rgba(0,0,0,.6);width:100%;max-width:680px;max-height:90vh;overflow-y:auto;position:relative; }
.modal-header { background:var(--leather);color:var(--gold);padding: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:1rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase; }
.modal-close { background:none;border:none;color:var(--gold);font-size:1.3rem;cursor:pointer;opacity:.75; }
.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 ── */
.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.3rem;font-weight:900;text-transform:uppercase;letter-spacing:.08em;color:var(--leather); }
.document-ref { font-family:var(--font-stamp);font-size:.66rem;letter-spacing:.14em;color:var(--sepia);margin-top:.3rem; }
.doc-field { display:flex;align-items:baseline;gap:.5rem;border-bottom:1px solid var(--border);padding:.35rem 0; }
.doc-field-label { font-family:var(--font-stamp);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--sepia);min-width:130px;flex-shrink:0; }
.doc-field-value { font-size:.9rem;color:var(--ink);flex:1; }

/* ── 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:42px;margin-bottom:.25rem;font-family:var(--font-display);font-style:italic;font-size:1.1rem;color:var(--ink);display:flex;align-items:flex-end;padding-bottom:3px; }
.signature-label { font-family:var(--font-stamp);font-size:.58rem;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:.7; }
.warrant-name { font-family:var(--font-display);font-size:1.05rem;font-weight:700;color:var(--leather); }
.warrant-details { font-family:var(--font-stamp);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--sepia);margin-top:.2rem; }

/* ── Log ── */
.log-entry { display:flex;gap:1rem;padding:.65rem 0;border-bottom:1px solid rgba(160,128,64,.2);font-size:.85rem; }
.log-time { font-family:var(--font-stamp);font-size:.62rem;letter-spacing:.06em;color:var(--sepia);min-width:150px;flex-shrink:0; }
.log-actor { font-weight:600;color:var(--leather); }

/* ── Officers ── */
.officers-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.75rem; }
.officer-card { background:var(--cream);border:1px solid var(--border);padding:1rem 1.25rem;display:flex;align-items:center;gap:1rem; }
.officer-avatar { width:48px;height:48px;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:.95rem;font-weight:700;color:var(--leather); }
.officer-rank { font-family:var(--font-stamp);font-size:.6rem;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:.6rem 1.25rem;font-family:var(--font-stamp);font-size:.66rem;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:.75rem 1rem;border-left:3px solid;font-family:var(--font-stamp);font-size:.73rem;letter-spacing:.05em;margin-bottom:1rem;line-height:1.5; }
.notice-warn    { border-color:var(--gold);    background:#fdf5d5;color:#6b5800; }
.notice-error   { border-color:var(--bordeaux);background:#f9e5e5;color:var(--bordeaux); }
.notice-info    { border-color:var(--sepia);   background:#f5eed5;color:var(--ink); }
.notice-success { border-color:#2d5a1b;        background:#e8f5e0;color:#2d5a1b; }

/* ═══════════════════════════════════════════════════════════
   PHOTOS — Galerie & Upload
   ═══════════════════════════════════════════════════════════ */
.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: .7rem;
  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(110px, 1fr));
  gap: .75rem;
  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-name {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  background: rgba(26,16,8,.7);
  color: var(--ivory);
  font-family: var(--font-stamp);
  font-size: .52rem;
  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: 20px; height: 20px;
  border-radius: 50%;
  font-size: .65rem;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  opacity: 0;
  transition: opacity .15s;
}

.photo-thumb:hover .photo-delete { opacity: 1; }

.photo-upload-zone {
  display: flex;
  align-items: center;
  margin-top: .5rem;
}

.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: .7rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .15s, border-color .15s;
  /* fonctionne aussi bien sur <button> que <label> */
  font-weight: normal;
  text-align: left;
}

.photo-upload-label:hover {
  background: var(--parchment);
  border-color: var(--leather);
}

/* ── Utility ── */
.hidden { display:none!important; }
.flex { display:flex; }
.flex-wrap { flex-wrap:wrap; }
.items-center { align-items:center; }
.justify-between { justify-content:space-between; }
.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:.7rem;color:var(--sepia);letter-spacing:.06em; }

/* ── 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(80px,1fr)); }
}
