@import url('https://fonts.googleapis.com/css2?family=SF+Pro+Display:wght@300;400;500;600;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Share+Tech+Mono&family=Inter:wght@300;400;500;600;700&display=swap');

:root {
  /* Palette — teintes bleu nuit marines légèrement éclairées */
  --bg:        #1c2333;
  --surface:   #242d3e;
  --surface2:  #2a3449;
  --elevated:  #303d54;
  --border:    #3a4a65;
  --border-b:  #445578;

  /* Texte */
  --text:      #e8edf5;
  --text-dim:  #a0b0cc;
  --text-muted:#5e7296;

  /* Couleurs accent */
  --blue:      #1a6fc4;
  --blue-b:    #2080d8;
  --blue-glow: rgba(32,128,216,.18);
  --cyan:      #38bdf8;
  --gold:      #fbbf24;
  --green:     #34d399;
  --red:       #f87171;
  --orange:    #fb923c;
  --purple:    #c084fc;
  --amber:     #fbbf24;
  --teal:      #2dd4bf;

  --sidebar-w: 268px;
  --topbar-h:  52px;
  --r:         8px;
  --r-sm:      5px;

  /* Typographie Apple-like */
  --font:      'Inter', -apple-system, BlinkMacSystemFont, 'SF Pro Display', 'Segoe UI', sans-serif;
  --font-mono: 'Share Tech Mono', 'SF Mono', 'Fira Code', monospace;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;background:var(--bg);color:var(--text);font-family:var(--font);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border-b);border-radius:10px}
a{color:inherit;text-decoration:none}

/* ── TOPBAR ── */
.topbar{position:fixed;top:0;left:0;right:0;height:var(--topbar-h);z-index:300;
  background:linear-gradient(135deg,#162040 0%,#1a5fa0 100%);
  border-bottom:1px solid rgba(251,191,36,.35);
  display:flex;align-items:center;padding:0 18px;gap:14px;
  box-shadow:0 1px 20px rgba(0,0,0,.4),0 0 40px rgba(26,95,160,.15)}
.topbar-brand{font-size:17px;font-weight:700;letter-spacing:-.2px;color:#fff}
.topbar-sub{font-family:var(--font-mono);font-size:10px;color:rgba(251,191,36,.7);letter-spacing:.12em;margin-left:6px}
.topbar-badge{font-family:var(--font-mono);font-size:11px;color:var(--gold);background:rgba(251,191,36,.1);border:1px solid rgba(251,191,36,.25);padding:3px 10px;border-radius:20px;letter-spacing:.05em}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.topbar-unit{font-family:var(--font-mono);font-size:12px;color:var(--cyan);background:rgba(56,189,248,.08);border:1px solid rgba(56,189,248,.18);padding:4px 12px;border-radius:20px;letter-spacing:.05em}
.topbar-officer{text-align:right;line-height:1.3}
.topbar-officer strong{display:block;font-size:13px;font-weight:600;color:var(--text)}
.topbar-officer span{font-family:var(--font-mono);font-size:10px;color:var(--gold)}

/* ── SIDEBAR ── */
.sidebar{position:fixed;left:0;top:var(--topbar-h);bottom:0;width:var(--sidebar-w);
  background:var(--surface);border-right:1px solid var(--border);
  z-index:200;display:flex;flex-direction:column;overflow-y:auto}
.sidebar-unit-card{background:linear-gradient(135deg,var(--surface2),var(--elevated));
  border-bottom:1px solid var(--border);padding:16px;border-left:4px solid var(--gold)}
.unit-callsign{font-family:var(--font-mono);font-size:22px;font-weight:700;color:var(--gold);letter-spacing:.1em}
.unit-name{font-size:13px;color:var(--text);margin-top:4px;font-weight:500}
.unit-agency{font-family:var(--font-mono);font-size:10px;color:var(--cyan);letter-spacing:.06em;margin-top:5px}
.sidebar-nav{padding:10px;flex:1}
.nav-group{margin-bottom:8px}
.nav-group-title{font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted);padding:10px 8px 5px}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--r-sm);color:var(--text-dim);font-size:13px;font-weight:500;cursor:pointer;transition:all .12s;border:1px solid transparent;margin-bottom:2px;text-decoration:none}
.nav-item:hover{background:var(--elevated);color:var(--text)}
.nav-item.active{background:rgba(32,128,216,.18);color:var(--cyan);border-color:rgba(56,189,248,.2)}
.nav-item .ni{font-size:15px;width:22px;text-align:center;flex-shrink:0}
.nav-badge{margin-left:auto;background:var(--red);color:#fff;font-size:10px;font-family:var(--font-mono);padding:2px 7px;border-radius:10px;font-weight:700}
.sidebar-quickcodes{padding:12px 10px;border-top:1px solid var(--border);background:var(--surface2)}
.qc-title{font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);padding:0 4px 8px}
.qc-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.qc-btn{padding:7px 4px;background:var(--elevated);border:1px solid var(--border-b);border-radius:var(--r-sm);font-family:var(--font-mono);font-size:11px;letter-spacing:.05em;color:var(--text-dim);cursor:pointer;text-align:center;transition:all .12s;font-weight:600}
.qc-btn:hover{background:var(--border-b);color:var(--text);transform:translateY(-1px)}
.qc-btn.panic{background:rgba(248,113,113,.12);border-color:rgba(248,113,113,.35);color:var(--red);grid-column:1/-1;font-size:12px;padding:8px}
.qc-btn.panic:hover{background:var(--red);color:#fff}

/* ── MAIN ── */
.main{margin-left:var(--sidebar-w);margin-top:var(--topbar-h);min-height:calc(100vh - var(--topbar-h));padding:18px;background:var(--bg)}

/* ── PANEL ── */
.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-bottom:18px;box-shadow:0 2px 16px rgba(0,0,0,.18)}
.panel-header{background:var(--surface2);border-bottom:1px solid var(--border);padding:11px 16px;display:flex;align-items:center;gap:8px}
.panel-title{font-size:13px;font-weight:600;letter-spacing:-.1px;color:var(--text-dim);flex:1}
.panel-title.blue{color:var(--cyan)}
.panel-title.gold{color:var(--gold)}
.panel-title.green{color:var(--green)}
.panel-title.red{color:var(--red)}
.panel-body{padding:16px}
.panel-body.p0{padding:0}

/* ── CAD TABLE ── */
.cad-table{width:100%;border-collapse:collapse}
.cad-table th{padding:9px 14px;text-align:left;font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);background:var(--surface2);border-bottom:1px solid var(--border);white-space:nowrap}
.cad-table td{padding:10px 14px;border-bottom:1px solid var(--border);font-size:13px;color:var(--text-dim);vertical-align:middle}
.cad-table tr:last-child td{border-bottom:none}
.cad-table tbody tr{cursor:pointer;transition:background .1s}
.cad-table tbody tr:hover td{background:var(--elevated);color:var(--text)}

/* ── CLIGNOTEMENTS ── */
@keyframes blink-red{0%,100%{background:rgba(248,113,113,.06)}50%{background:rgba(248,113,113,.2)}}
@keyframes blink-yellow{0%,100%{background:rgba(251,191,36,.04)}50%{background:rgba(251,191,36,.14)}}
@keyframes blink-purple{0%,100%{background:rgba(192,132,252,.06)}50%{background:rgba(192,132,252,.16)}}
@keyframes blink-green{0%,100%{background:rgba(52,211,153,.06)}50%{background:rgba(52,211,153,.16)}}
.row-urgent td{animation:blink-red 1.1s infinite}
.row-yellow td{animation:blink-yellow 1.4s infinite}
.row-purple td{animation:blink-purple 1.2s infinite}
.row-green td{animation:blink-green 1.5s infinite}

/* ── BADGES ── */
.sbadge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:20px;font-size:10px;font-weight:600;letter-spacing:.03em;border:1px solid;white-space:nowrap}
.sb-green{background:rgba(52,211,153,.12);color:var(--green);border-color:rgba(52,211,153,.25)}
.sb-red{background:rgba(248,113,113,.12);color:var(--red);border-color:rgba(248,113,113,.25)}
.sb-blue{background:rgba(56,189,248,.1);color:var(--cyan);border-color:rgba(56,189,248,.2)}
.sb-amber{background:rgba(251,191,36,.1);color:var(--gold);border-color:rgba(251,191,36,.25)}
.sb-gray{background:rgba(148,163,184,.08);color:#94a3b8;border-color:rgba(148,163,184,.18)}
.sb-purple{background:rgba(192,132,252,.1);color:var(--purple);border-color:rgba(192,132,252,.25)}
.sb-orange{background:rgba(251,146,60,.1);color:var(--orange);border-color:rgba(251,146,60,.25)}
.sb-teal{background:rgba(45,212,191,.1);color:var(--teal);border-color:rgba(45,212,191,.25)}

/* ── FORMS ── */
.form-group{margin-bottom:13px}
.form-label{display:block;font-size:11px;font-weight:600;letter-spacing:.04em;color:var(--text-muted);margin-bottom:5px}
.form-control{width:100%;background:var(--elevated);border:1px solid var(--border-b);border-radius:var(--r-sm);padding:9px 13px;color:var(--text);font-family:var(--font);font-size:13px;outline:none;transition:border-color .15s,box-shadow .15s}
.form-control:focus{border-color:var(--cyan);box-shadow:0 0 0 3px rgba(56,189,248,.1)}
.form-control::placeholder{color:var(--text-muted)}
select.form-control option{background:var(--surface2)}
textarea.form-control{resize:vertical;min-height:80px;line-height:1.5}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 18px;font-family:var(--font);font-size:13px;font-weight:600;letter-spacing:-.1px;border:none;border-radius:var(--r-sm);cursor:pointer;text-decoration:none;transition:all .15s;white-space:nowrap}
.btn-blue{background:var(--blue);color:#fff;box-shadow:0 2px 10px rgba(26,111,196,.3)}.btn-blue:hover{background:var(--blue-b);box-shadow:0 4px 14px rgba(26,111,196,.45);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--text-dim);border:1px solid var(--border-b)}.btn-ghost:hover{background:var(--elevated);color:var(--text)}
.btn-green{background:rgba(52,211,153,.14);color:var(--green);border:1px solid rgba(52,211,153,.25)}.btn-green:hover{background:rgba(52,211,153,.25);transform:translateY(-1px)}
.btn-red{background:rgba(248,113,113,.14);color:var(--red);border:1px solid rgba(248,113,113,.25)}.btn-red:hover{background:var(--red);color:#fff;transform:translateY(-1px)}
.btn-gold{background:rgba(251,191,36,.12);color:var(--gold);border:1px solid rgba(251,191,36,.25)}.btn-gold:hover{background:rgba(251,191,36,.25)}
.btn-purple{background:rgba(192,132,252,.12);color:var(--purple);border:1px solid rgba(192,132,252,.25)}.btn-purple:hover{background:rgba(192,132,252,.25)}
.btn-sm{padding:6px 14px;font-size:12px}
.btn-xs{padding:3px 10px;font-size:11px}
.btn-full{width:100%;justify-content:center}

/* ── GRIDS ── */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}

/* ── ALERTS ── */
.alert{padding:11px 15px;border-radius:var(--r-sm);font-size:13px;margin-bottom:14px;border-left:3px solid;display:flex;align-items:flex-start;gap:9px}
.alert-error{background:rgba(248,113,113,.09);border-color:var(--red);color:#fca5a5}
.alert-success{background:rgba(52,211,153,.09);border-color:var(--green);color:#6ee7b7}
.alert-info{background:rgba(56,189,248,.09);border-color:var(--cyan);color:#7dd3fc}
.alert-warn{background:rgba(251,191,36,.09);border-color:var(--gold);color:var(--gold)}

/* ── TABS ── */
.tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:16px;gap:0}
.tab-btn{padding:9px 18px;font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;margin-bottom:-1px;text-decoration:none;transition:all .12s;white-space:nowrap}
.tab-btn:hover{color:var(--text)}
.tab-btn.active{color:var(--cyan);border-bottom-color:var(--cyan);font-weight:600}

/* ── SEARCH CARDS ── */
.search-result{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-bottom:18px;box-shadow:0 4px 20px rgba(0,0,0,.18);transition:border-color .15s,box-shadow .15s}
.search-result:hover{border-color:var(--border-b);box-shadow:0 8px 30px rgba(0,0,0,.25)}
.search-result.has-warrant{border-color:rgba(248,113,113,.4);box-shadow:0 4px 20px rgba(248,113,113,.08)}
.sr-header{background:linear-gradient(135deg,var(--surface2) 0%,var(--elevated) 100%);padding:16px 20px;display:flex;align-items:flex-start;gap:16px;border-bottom:1px solid var(--border)}
.sr-avatar{width:50px;height:50px;border-radius:12px;background:var(--blue-glow);border:2px solid var(--blue);display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:700;color:var(--cyan);flex-shrink:0}
.sr-name{font-size:18px;font-weight:700;letter-spacing:-.3px;color:var(--text);line-height:1.2}
.sr-sub{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);margin-top:4px}
.sr-badges{display:flex;gap:5px;flex-wrap:wrap;margin-top:7px}
.sr-body{padding:18px 20px}
.sr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:9px}
.sr-field{background:var(--elevated);border:1px solid var(--border);border-radius:6px;padding:9px 12px;position:relative}
.sr-field-label{font-size:9px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-bottom:4px}
.sr-field-value{font-family:var(--font-mono);font-size:12px;color:var(--text);word-break:break-all;line-height:1.4}
.sr-field-copy{position:absolute;top:7px;right:7px;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:12px;padding:2px 5px;border-radius:4px;transition:all .1s;opacity:0}
.sr-field:hover .sr-field-copy{opacity:1}
.sr-field-copy:hover{color:var(--cyan);background:rgba(56,189,248,.1)}
.sr-section-title{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin:16px 0 9px;padding-bottom:6px;border-bottom:1px solid var(--border)}
.sr-footer{background:var(--surface2);padding:11px 20px;display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--border)}
.sr-warrant{background:rgba(248,113,113,.08);border:1px solid rgba(248,113,113,.25);border-radius:var(--r-sm);padding:12px 15px;margin-top:14px}
.sr-warrant-title{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--red);margin-bottom:7px}
.sr-editable-section{background:var(--elevated);border:1px solid var(--border-b);border-radius:var(--r-sm);padding:14px;margin-top:14px}
.sr-editable-title{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin-bottom:10px;display:flex;align-items:center;justify-content:space-between}

/* ── WEAPON / VEHICLE CARDS ── */
.weapon-card,.vehicle-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-bottom:18px;box-shadow:0 4px 20px rgba(0,0,0,.18)}
.wc-header{background:linear-gradient(135deg,#1a2a1a,var(--surface2));padding:16px 20px;display:flex;align-items:center;gap:14px;border-bottom:1px solid var(--border)}
.wc-serial{font-family:var(--font-mono);font-size:20px;font-weight:700;color:var(--gold);letter-spacing:.1em}
.wc-name{font-size:15px;font-weight:600;color:var(--text)}
.wc-calibre{font-size:11px;color:var(--text-muted);margin-top:3px}
.vc-plate{font-family:var(--font-mono);padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:14px;background:linear-gradient(135deg,#1a2214,var(--surface2))}
.vc-plate-box{background:var(--surface);border:3px solid var(--gold);border-radius:6px;padding:7px 18px;text-align:center;min-width:150px}
.vc-plate-num{font-family:var(--font-mono);font-size:24px;font-weight:700;color:var(--gold);letter-spacing:.14em}
.vc-plate-state{font-family:var(--font-mono);font-size:8px;color:var(--text-muted);letter-spacing:.12em;margin-top:2px}

/* ── INCIDENT MODAL ── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.72);z-index:9999;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.modal-overlay.open{display:flex}
.modal{background:var(--surface);border:1px solid var(--border-b);border-radius:var(--r);width:680px;max-width:calc(100vw - 20px);max-height:calc(100vh - 40px);overflow-y:auto;box-shadow:0 30px 80px rgba(0,0,0,.7)}
.modal-header{background:linear-gradient(135deg,#162040,#1a5fa0);padding:13px 18px;display:flex;align-items:center;justify-content:space-between;border-bottom:2px solid rgba(251,191,36,.4)}
.modal-title{font-size:15px;font-weight:700;letter-spacing:-.2px;color:#fff}
.modal-close{background:none;border:none;color:rgba(255,255,255,.55);font-size:20px;cursor:pointer;padding:0 4px;transition:color .1s;line-height:1}
.modal-close:hover{color:#fff}
.modal-body{padding:20px}
.modal-footer{padding:12px 20px;border-top:1px solid var(--border);background:var(--surface2);display:flex;gap:8px;justify-content:flex-end}

/* ── LOG ENTRIES ── */
.log-entry{padding:9px 13px;border-left:3px solid var(--border-b);margin-bottom:6px;background:var(--elevated);border-radius:0 6px 6px 0;line-height:1.4}
.log-entry.attach{border-color:var(--green)}
.log-entry.detach{border-color:var(--text-muted)}
.log-entry.note{border-color:var(--cyan)}
.log-entry.report{border-color:var(--gold)}
.log-entry.reinforcement{border-color:var(--red)}
.log-entry.status{border-color:var(--purple)}
.log-time{font-family:var(--font-mono);font-size:10px;color:var(--text-muted);margin-right:8px}
.log-content{color:var(--text-dim);font-size:12px}

/* ── AUTH ── */
.auth-wrap{min-height:100vh;display:flex;flex-direction:column;background:radial-gradient(ellipse at top,#1a2a4e 0%,#141922 100%)}
.auth-topbar{height:54px;background:linear-gradient(135deg,#162040,#1a5fa0);border-bottom:1px solid rgba(251,191,36,.3);display:flex;align-items:center;padding:0 24px;gap:14px;box-shadow:0 2px 20px rgba(0,0,0,.4)}
.auth-main{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 16px}
.auth-card{background:var(--surface);border:1px solid var(--border-b);border-radius:16px;width:470px;max-width:100%;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.auth-card-header{background:linear-gradient(135deg,#162040,#1a5fa0);padding:22px 26px;border-bottom:1px solid rgba(251,191,36,.3);border-radius:16px 16px 0 0}
.auth-card-header h2{font-size:18px;font-weight:700;letter-spacing:-.3px;color:#fff;margin-bottom:4px}
.auth-card-header p{font-family:var(--font-mono);font-size:10px;color:rgba(255,255,255,.5);letter-spacing:.1em;text-transform:uppercase}
.auth-card-body{padding:26px}
.auth-steps{display:flex;margin-bottom:20px;border:1px solid var(--border);border-radius:var(--r-sm);overflow:hidden}
.auth-step{flex:1;padding:9px 6px;text-align:center;font-size:11px;font-weight:600;color:var(--text-muted);background:var(--surface2);border-right:1px solid var(--border)}
.auth-step:last-child{border-right:none}
.auth-step .sn{display:block;font-size:17px;margin-bottom:3px}
.auth-step.active{background:var(--blue);color:#fff}
.auth-step.done{background:rgba(52,211,153,.12);color:var(--green)}

/* ── INC MODAL FIELDS ── */
.inc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin-bottom:16px}
.inc-field{background:var(--elevated);border:1px solid var(--border);border-radius:6px;padding:9px 12px}
.inc-field.full{grid-column:1/-1}
.inc-field-label{font-size:9px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-bottom:4px}
.inc-field-value{font-size:13px;color:var(--text);font-weight:500}
.renfort-grid{display:flex;flex-wrap:wrap;gap:7px;margin:12px 0 4px}

/* ── PATROL CARD ── */
.patrol-card{background:var(--elevated);border:1px solid var(--border-b);border-radius:var(--r-sm);padding:12px 15px;margin-bottom:7px;display:flex;align-items:center;gap:14px;cursor:pointer;transition:all .13s}
.patrol-card:hover{border-color:var(--cyan);transform:translateX(2px)}
.patrol-callsign{font-family:var(--font-mono);font-size:17px;font-weight:700;color:var(--gold);letter-spacing:.1em;min-width:70px}

/* ── SCAN LINE ── */
.scan-line{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);letter-spacing:.06em;padding:7px 14px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--r-sm);margin-bottom:16px;display:flex;align-items:center;gap:12px}
.scan-dot{width:8px;height:8px;border-radius:50%;background:var(--green);flex-shrink:0;animation:pdot 2s infinite}
@keyframes pdot{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(52,211,153,.4)}50%{opacity:.7;box-shadow:0 0 0 5px rgba(52,211,153,0)}}

/* ── UTILS ── */
.flex{display:flex;align-items:center}
.flex-between{display:flex;align-items:center;justify-content:space-between;gap:8px}
.gap-8{gap:8px}
.gap-10{gap:10px}
.mb-14{margin-bottom:14px}
.mb-16{margin-bottom:16px}
.text-cyan{color:var(--cyan)}
.text-gold{color:var(--gold)}
.text-green{color:var(--green)}
.text-red{color:var(--red)}
.text-muted{color:var(--text-muted)}
.text-dim{color:var(--text-dim)}
.mono{font-family:var(--font-mono);font-size:12px}
.mono-sm{font-family:var(--font-mono);font-size:10px}
.empty-state{text-align:center;padding:50px 20px;color:var(--text-muted)}
.empty-icon{font-size:46px;margin-bottom:14px;opacity:.22;display:block}
.divider{height:1px;background:var(--border);margin:15px 0}
.blink-panic{animation:panic .5s infinite}
@keyframes panic{0%,100%{background:rgba(248,113,113,.12);border-color:rgba(248,113,113,.5)}50%{background:rgba(248,113,113,.38);border-color:var(--red)}}

@media(max-width:900px){
  :root{--sidebar-w:0px}
  .sidebar{width:268px;transform:translateX(-268px);transition:transform .3s}
  .sidebar.open{transform:translateX(0)}
  .main{margin-left:0}
  .grid-2,.grid-3{grid-template-columns:1fr}
}

/* ── CLIGNOTEMENTS RENFORCÉS ── */
@keyframes blink-red{
  0%,100%{background:rgba(248,113,113,.05);box-shadow:none}
  50%{background:rgba(248,113,113,.35);box-shadow:inset 0 0 12px rgba(248,113,113,.3)}
}
@keyframes blink-yellow{
  0%,100%{background:rgba(251,191,36,.04);box-shadow:none}
  50%{background:rgba(251,191,36,.28);box-shadow:inset 0 0 10px rgba(251,191,36,.25)}
}
@keyframes blink-purple{
  0%,100%{background:rgba(192,132,252,.05);box-shadow:none}
  50%{background:rgba(192,132,252,.32);box-shadow:inset 0 0 12px rgba(192,132,252,.28)}
}
@keyframes blink-green{
  0%,100%{background:rgba(52,211,153,.05);box-shadow:none}
  50%{background:rgba(52,211,153,.30);box-shadow:inset 0 0 10px rgba(52,211,153,.25)}
}
.row-urgent td{animation:blink-red 1s infinite}
.row-yellow td{animation:blink-yellow 1.3s infinite}
.row-purple td{animation:blink-purple 1.1s infinite}
.row-green td{animation:blink-green 1.4s infinite}

/* ── ALERT BANNER ── */
.alert-banner{background:linear-gradient(135deg,rgba(248,113,113,.18),rgba(248,113,113,.08));border:1px solid rgba(248,113,113,.4);border-left:4px solid var(--red);border-radius:var(--r-sm);padding:12px 16px;margin-bottom:14px;display:flex;align-items:flex-start;gap:12px;animation:alert-pulse 2s infinite}
@keyframes alert-pulse{0%,100%{box-shadow:0 0 0 0 rgba(248,113,113,.2)}50%{box-shadow:0 0 0 6px rgba(248,113,113,0)}}
.alert-banner.amber{background:linear-gradient(135deg,rgba(251,191,36,.15),rgba(251,191,36,.06));border-color:rgba(251,191,36,.4);border-left-color:var(--gold);animation:alert-pulse-amber 2s infinite}
@keyframes alert-pulse-amber{0%,100%{box-shadow:0 0 0 0 rgba(251,191,36,.2)}50%{box-shadow:0 0 0 6px rgba(251,191,36,0)}}
.alert-banner.blue{background:linear-gradient(135deg,rgba(56,189,248,.12),rgba(56,189,248,.05));border-color:rgba(56,189,248,.35);border-left-color:var(--cyan);animation:none}
.ab-icon{font-size:22px;flex-shrink:0;margin-top:1px}
.ab-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:3px}
.ab-body{font-size:12px;color:var(--text-dim);line-height:1.5}
.ab-meta{font-family:var(--font-mono);font-size:9px;color:var(--text-muted);margin-top:4px}

/* ── LOADING OVERLAY ── */
.search-loading{display:none;text-align:center;padding:50px 20px}
.search-loading.show{display:block}
.scan-animation{font-family:var(--font-mono);font-size:13px;color:var(--cyan);letter-spacing:.1em;margin-bottom:14px}
.scan-bar{width:260px;height:3px;background:var(--border);border-radius:10px;overflow:hidden;margin:0 auto}
.scan-bar-inner{height:100%;background:linear-gradient(90deg,transparent,var(--cyan),transparent);border-radius:10px;animation:scan-move 1.5s infinite}
@keyframes scan-move{0%{width:0;margin-left:0}50%{width:100%;margin-left:0}100%{width:0;margin-left:100%}}

/* ── CASIER JUDICIAIRE ── */
.casier-entry{background:var(--elevated);border:1px solid var(--border);border-radius:6px;padding:11px 14px;margin-bottom:8px;border-left:3px solid var(--border-b)}
.casier-entry.arrestation{border-left-color:var(--red)}
.casier-entry.ticket_citation{border-left-color:var(--amber)}
.casier-entry.ticket_fix{border-left-color:var(--orange)}
.casier-entry.signalement{border-left-color:var(--purple)}
.casier-type{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:4px}
.casier-charges{font-size:13px;color:var(--text);font-weight:500;margin-bottom:4px}
.casier-meta{font-family:var(--font-mono);font-size:10px;color:var(--text-muted)}

/* ── PDF VIEWER ── */
.pdf-frame{width:100%;border:none;border-radius:var(--r);background:#fff;min-height:500px}

/* ── REPORT STATUS ── */
.report-status-draft{color:var(--text-muted)}
.report-status-submitted{color:var(--amber)}
.report-status-reviewed{color:var(--cyan)}
.report-status-approved{color:var(--green)}
