:root {
  --gold: #C9A84C;
  --gold-light: #E8C96A;
  --gold-dim: #8B6E2E;
  --gold-glow: rgba(201,168,76,0.12);
  --khaki: #B5A882;
  --khaki-dim: #7A7055;
  --bg-deep: #080A06;
  --bg-dark: #0C0E09;
  --bg-panel: #171A10;
  --bg-card: #1C1F14;
  --border: rgba(201,168,76,0.11);
  --border-bright: rgba(201,168,76,0.38);
  --text: #CEC49A;
  --text-dim: #6A6550;
  --text-bright: #EDE3C0;
  --green: #4CAF72;
  --orange: #D4822A;
  --red: #C94C4C;
  --blue: #4C8BC9;
  --purple: #9B6ECA;
  --teal: #4CC9B0;
  --pink: #C94C8B;
  /* CAD actif : hauteur header + colonne latérale (rem = base html) */
  --cad-header-h: 72px;
  --cad-sidebar: minmax(300px, 24vw);
}
*{margin:0;padding:0;box-sizing:border-box;}
/* Densité type web-dispatch : texte et contrôles plus grands sur le board uniquement */
html:has(#screen-app.active){
  font-size:112.5%;
}
@media (min-width:1440px){
  html:has(#screen-app.active){
    font-size:118.75%;
  }
}
body{background:var(--bg-deep);color:var(--text);font-family:'Rajdhani',sans-serif;min-height:100vh;overflow-x:hidden;}
body::after{content:'';position:fixed;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(0,0,0,0.02) 3px,rgba(0,0,0,0.02) 4px);pointer-events:none;z-index:9998;}


/* Broadcast banner */
.broadcast-banner {
  display: none;
  align-items: center;
  gap: 1rem;
  padding: .65rem 1rem;
  background: rgba(201,168,76,.07);
  border: 1px solid rgba(201,168,76,.35);
  border-left: 3px solid var(--gold);
  margin-bottom: 1rem;
  animation: broadcastPulse 3s ease-in-out infinite;
}
.broadcast-banner.show { display: flex; }
@keyframes broadcastPulse {
  0%,100%{background:rgba(201,168,76,.07)}
  50%{background:rgba(201,168,76,.13)}
}
.bc-icon { font-size:1rem; }
.bc-sender { font-family:'Share Tech Mono',monospace;font-size:.6rem;color:var(--gold-dim);letter-spacing:.08em; }
.bc-msg { font-family:'Oswald',sans-serif;font-size:.95rem;font-weight:600;color:var(--text-bright);letter-spacing:.05em; }
.bc-close { margin-left:auto;cursor:pointer;color:var(--text-dim);font-size:.8rem;background:none;border:none;padding:.2rem .4rem; }
.bc-close:hover { color:var(--gold); }

/* Hot status buttons */
.sp-btn.sp-hot {
  border-color: rgba(201,168,76,0.35);
  position: relative;
}
.sp-btn.sp-hot::after {
  content: '★';
  position: absolute;
  top: 2px; right: 3px;
  font-size: .45rem;
  color: var(--gold-dim);
  opacity: .7;
}
.sp-btn.sp-hot span { color: var(--text) !important; }

#badge-login,
#badge-header { mix-blend-mode: lighten; }

/* ── SCREENS ── */
.screen{display:none;}
.screen.active{display:flex;flex-direction:column;min-height:100vh;}

/* ══════════════════════════════════
   LOGIN
══════════════════════════════════ */
#screen-login{
  align-items:center;justify-content:center;
  background:radial-gradient(ellipse at 50% 25%,rgba(201,168,76,0.07) 0%,transparent 65%);
  position:relative;overflow:hidden;
}
.login-grid{
  position:absolute;inset:0;
  background-image:linear-gradient(rgba(201,168,76,0.025) 1px,transparent 1px),linear-gradient(90deg,rgba(201,168,76,0.025) 1px,transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse at center,black 0%,transparent 68%);
}
.login-card{
  position:relative;z-index:10;width:440px;
  background:var(--bg-panel);border:1px solid var(--border-bright);padding:2.5rem;
}
.login-card::before{content:'';position:absolute;top:-1px;left:25px;right:25px;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);}

.login-header{display:flex;align-items:center;gap:1.25rem;margin-bottom:2rem;}
.login-badge svg{width:72px;height:72px;filter:drop-shadow(0 0 10px rgba(201,168,76,0.35));}
.login-titles h1{font-family:'Oswald',sans-serif;font-size:1.5rem;font-weight:700;color:var(--gold-light);letter-spacing:0.2em;text-transform:uppercase;line-height:1;}
.login-titles p{font-family:'Share Tech Mono',monospace;font-size:0.58rem;color:var(--khaki-dim);letter-spacing:0.22em;margin-top:5px;}
.login-titles small{font-family:'Share Tech Mono',monospace;font-size:0.55rem;color:var(--text-dim);letter-spacing:0.15em;}

.fl{margin-bottom:0.9rem;}
.fl label{display:block;font-family:'Share Tech Mono',monospace;font-size:0.58rem;color:var(--gold-dim);letter-spacing:0.2em;text-transform:uppercase;margin-bottom:0.35rem;}
.fi{width:100%;background:var(--bg-deep);border:1px solid var(--border);color:var(--text-bright);font-family:'Share Tech Mono',monospace;font-size:0.82rem;padding:0.6rem 0.8rem;outline:none;transition:border-color .2s,box-shadow .2s;}
.fi:focus{border-color:var(--gold);box-shadow:0 0 0 2px rgba(201,168,76,0.07);}
.fi::placeholder{color:var(--text-dim);}
.fs{width:100%;background:var(--bg-deep);border:1px solid var(--border);color:var(--text-bright);font-family:'Share Tech Mono',monospace;font-size:0.78rem;padding:0.6rem 0.8rem;outline:none;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%238B6E2E'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;}
.fs option{background:var(--bg-dark);}

.login-hint{font-family:'Share Tech Mono',monospace;font-size:0.6rem;color:var(--text-dim);background:var(--bg-deep);border:1px solid var(--border);padding:.5rem .75rem;margin-bottom:1rem;line-height:1.6;}
.login-hint strong{color:var(--gold);}

.btn-lg{width:100%;background:linear-gradient(135deg,#6B4F18,var(--gold));color:var(--bg-deep);border:none;font-family:'Oswald',sans-serif;font-size:.88rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;padding:.85rem;cursor:pointer;transition:all .2s;position:relative;overflow:hidden;}
.btn-lg::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.08),transparent);opacity:0;transition:opacity .2s;}
.btn-lg:hover::after{opacity:1;}
.btn-lg:hover{box-shadow:0 0 18px rgba(201,168,76,.28);}

.divider{display:flex;align-items:center;gap:.75rem;margin:1.1rem 0;}
.divider span{flex:1;height:1px;background:var(--border);}
.divider em{font-family:'Share Tech Mono',monospace;font-size:.58rem;color:var(--text-dim);font-style:normal;letter-spacing:.15em;}

/* ══════════════════════════════════
   APP LAYOUT
══════════════════════════════════ */
#screen-app{flex-direction:column;}

.app-header{
  background:linear-gradient(180deg,#090B07 0%,var(--bg-dark) 100%);
  border-bottom:1px solid var(--border-bright);
  padding:0 clamp(1rem, 2vw, 2rem);min-height:var(--cad-header-h);height:var(--cad-header-h);
  display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;z-index:200;flex-shrink:0;
}
.app-header::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);}

.hbrand{display:flex;align-items:center;gap:1rem;}
.hbrand svg{width:42px;height:42px;filter:drop-shadow(0 0 6px rgba(201,168,76,.3));}
.hbrand-text span:first-child{display:block;font-family:'Oswald',sans-serif;font-size:1.15rem;font-weight:600;color:var(--gold-light);letter-spacing:.12em;text-transform:uppercase;line-height:1;}
.hbrand-text span:last-child{display:block;font-family:'Share Tech Mono',monospace;font-size:.58rem;color:var(--khaki-dim);letter-spacing:.18em;margin-top:2px;}

.hnav{display:flex;gap:.25rem;}
.hnav-btn{font-family:'Oswald',sans-serif;font-size:.82rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);padding:.55rem 1rem;cursor:pointer;border:none;background:transparent;border-bottom:2px solid transparent;transition:all .2s;white-space:nowrap;}
.hnav-btn:hover{color:var(--khaki);}
.hnav-btn.active{color:var(--gold);border-bottom-color:var(--gold);}
.hnav-btn.disp-only{display:none;}
.hnav-btn.disp-only.show{display:block;}

.hright{display:flex;align-items:center;gap:1.1rem;}
.agent-pill{display:flex;align-items:center;gap:.55rem;padding:.4rem .85rem;background:rgba(201,168,76,.05);border:1px solid var(--border);}
.ap-discord{font-family:'Share Tech Mono',monospace;font-size:.8rem;color:var(--gold);letter-spacing:.03em;}
.ap-grade{font-family:'Share Tech Mono',monospace;font-size:.62rem;color:var(--text-dim);letter-spacing:.06em;}
.live-clock{font-family:'Share Tech Mono',monospace;font-size:1.2rem;color:var(--gold);letter-spacing:.06em;}
/* Indicateur flux temps réel (vert = OK, rouge = hors ligne / erreur) */
.live-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;animation:blink 1.5s ease-in-out infinite;}
.live-dot.live-ok{background:var(--green);box-shadow:0 0 8px rgba(76,175,114,.85);}
.live-dot.live-bad{background:var(--red);box-shadow:0 0 8px rgba(201,76,76,.75);}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

/* App body — sidebar plus large, zone centrale mieux remplie */
.app-body{display:grid;grid-template-columns:var(--cad-sidebar) minmax(0,1fr);flex:1;overflow:hidden;height:calc(100vh - var(--cad-header-h));}

/* ══════════════════════════════════
   SIDEBAR
══════════════════════════════════ */
.sidebar{background:var(--bg-panel);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;}
.sb-sec{border-bottom:1px solid var(--border);}
.sb-lbl{font-family:'Share Tech Mono',monospace;font-size:.62rem;color:var(--gold-dim);letter-spacing:.2em;text-transform:uppercase;padding:.65rem 1.1rem .4rem;}

/* Agent status block */
.sb-agent-block{padding:.85rem 1.1rem;}
.sb-unit-line{font-family:'Share Tech Mono',monospace;font-size:.8rem;color:var(--gold);letter-spacing:.03em;margin-bottom:.4rem;min-height:1.2rem;}
.sb-status-chip{display:inline-flex;align-items:center;gap:.4rem;font-family:'Share Tech Mono',monospace;font-size:.72rem;padding:.22rem .55rem;border:1px solid;}
.sb-status-chip .dot{width:5px;height:5px;border-radius:50%;background:currentColor;}

/* Patrol join */
.sb-patrol{padding:.55rem 1.1rem .85rem;display:flex;flex-direction:column;gap:.45rem;}
.sb-patrol-sub{font-family:'Share Tech Mono',monospace;font-size:.56rem;color:var(--gold-dim);letter-spacing:.12em;text-transform:uppercase;margin:.35rem 0 .15rem;}
.patrol-row{display:flex;gap:.35rem;}

/* Status pad */
.status-pad{padding:.55rem 1.1rem .9rem;display:grid;grid-template-columns:1fr 1fr;gap:.4rem;}
.status-pad.status-pad--locked{pointer-events:none;opacity:.42;filter:grayscale(.2);}
.status-pad.status-pad--locked .sp-btn{cursor:not-allowed;}
.sp-btn{background:var(--bg-deep);border:1px solid var(--border);color:var(--text-dim);font-family:'Share Tech Mono',monospace;font-size:.72rem;padding:.52rem .35rem;min-height:2.75rem;cursor:pointer;transition:all .15s;text-align:center;line-height:1.35;letter-spacing:.02em;}
.sp-btn:hover{border-color:var(--gold-dim);color:var(--text);}
.sp-btn.s-green{background:rgba(76,175,114,.1);border-color:var(--green);color:var(--green);}
.sp-btn.s-red{background:rgba(201,76,76,.1);border-color:var(--red);color:var(--red);}
.sp-btn.s-orange{background:rgba(212,130,42,.1);border-color:var(--orange);color:var(--orange);}
.sp-btn.s-blue{background:rgba(76,139,201,.1);border-color:var(--blue);color:var(--blue);}
.sp-btn.s-gold{background:rgba(201,168,76,.1);border-color:var(--gold);color:var(--gold);}

.sb-inputs{padding:.35rem 1.1rem .85rem;display:flex;flex-direction:column;gap:.5rem;}

/* Sidebar — actions bas de barre */
.sidebar-bottom{margin-top:auto;padding:.85rem 1.1rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.45rem;}

/* ══════════════════════════════════
   GENERIC BUTTONS
══════════════════════════════════ */
.btn-sm{background:transparent;border:1px solid var(--border);color:var(--text-dim);font-family:'Share Tech Mono',monospace;font-size:.68rem;padding:.38rem .6rem;min-height:2.25rem;cursor:pointer;transition:all .15s;letter-spacing:.05em;white-space:nowrap;}
.btn-sm:hover{border-color:var(--gold-dim);color:var(--gold);}
.btn-sm.danger:hover{border-color:var(--red);color:var(--red);}
.btn-sm.w100{width:100%;padding:.45rem;}
.btn-primary{background:linear-gradient(135deg,var(--gold-dim),var(--gold));color:var(--bg-deep);border:none;font-family:'Oswald',sans-serif;font-size:.88rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:.68rem 1.2rem;cursor:pointer;transition:all .2s;white-space:nowrap;}
.btn-primary:hover{box-shadow:0 0 14px rgba(201,168,76,.25);}
.btn-cancel{background:transparent;color:var(--text-dim);border:1px solid var(--border);font-family:'Share Tech Mono',monospace;font-size:.68rem;padding:.6rem .9rem;cursor:pointer;transition:all .2s;letter-spacing:.07em;}
.btn-cancel:hover{border-color:var(--gold-dim);color:var(--text);}

/* ══════════════════════════════════
   MAIN / PAGES
══════════════════════════════════ */
.main-content{overflow-y:auto;background:var(--bg-dark);width:100%;}
.page{display:none;padding:clamp(1.25rem,2vw,2rem) clamp(1rem,3vw,2.5rem);}
.page.active{display:block;}

/* ══════════════════════════════════
   DISPATCH BOARD
══════════════════════════════════ */

/* Stats bar */
.stats-bar{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1.5rem;}
.stat-card{background:var(--bg-card);border:1px solid var(--border);padding:1rem 1.15rem;position:relative;overflow:hidden;}
.stat-card::before{content:'';position:absolute;top:0;left:0;width:2px;height:100%;}
.sc-gold::before{background:var(--gold);}
.sc-green::before{background:var(--green);}
.sc-orange::before{background:var(--orange);}
.sc-red::before{background:var(--red);}
.stat-card-n{font-family:'Oswald',sans-serif;font-size:2.15rem;font-weight:700;line-height:1;color:var(--text-bright);}
.sc-red .stat-card-n{color:var(--red);}
.stat-card-l{font-family:'Share Tech Mono',monospace;font-size:.65rem;color:var(--text-dim);letter-spacing:.1em;margin-top:4px;text-transform:uppercase;}

/* Alert banner */
.alert-banner{display:none;align-items:center;gap:1rem;padding:.7rem 1rem;background:rgba(201,76,76,.07);border:1px solid rgba(201,76,76,.38);border-left:3px solid var(--red);margin-bottom:1.25rem;animation:alertPulse 1s ease-in-out infinite;}
.alert-banner.show{display:flex;}
@keyframes alertPulse{0%,100%{background:rgba(201,76,76,.07)}50%{background:rgba(201,76,76,.14)}}
.alert-icon{font-size:1.1rem;animation:shake .5s ease-in-out infinite;}
@keyframes shake{0%,100%{transform:rotate(0)}25%{transform:rotate(-5deg)}75%{transform:rotate(5deg)}}
.alert-text{font-family:'Share Tech Mono',monospace;font-size:.72rem;color:var(--red);letter-spacing:.07em;}
.alert-agents{font-family:'Oswald',sans-serif;font-size:.88rem;font-weight:600;color:var(--text-bright);}

/* Board section headers */
.board-sec{margin-bottom:1.5rem;}
.bsec-hdr{
  display:flex;align-items:center;gap:.85rem;
  padding:.55rem .9rem;margin-bottom:.55rem;
  border-left:2px solid var(--gold-dim);
  background:rgba(201,168,76,.03);
}
.bsec-hdr.s-patrol{border-left-color:var(--gold);}
.bsec-hdr.s-ert{border-left-color:var(--red);}
.bsec-hdr.s-cid{border-left-color:var(--purple);}
.bsec-hdr.s-troopers{border-left-color:var(--orange);}
.bsec-hdr.s-rangers{border-left-color:var(--green);}
.bsec-hdr.s-maritime{border-left-color:var(--teal);}
.bsec-hdr.s-mary{border-left-color:var(--blue);}
.bsec-hdr.s-k9{border-left-color:var(--pink);}
.bsec-hdr.s-asd{border-left-color:var(--blue);}
.bsec-hdr.s-sahp{border-left-color:var(--orange);}
.bsec-hdr.s-waiting{border-left-color:var(--gold-dim);}

.bsec-icon{font-size:1.05rem;flex-shrink:0;}
.bsec-title{font-family:'Oswald',sans-serif;font-size:.95rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;}
.bsec-sub{font-family:'Share Tech Mono',monospace;font-size:.65rem;color:var(--text-dim);letter-spacing:.06em;}
.bsec-count{font-family:'Share Tech Mono',monospace;font-size:.65rem;color:var(--text-dim);background:var(--bg-deep);border:1px solid var(--border);padding:.12rem .45rem;margin-left:auto;flex-shrink:0;}

/* Cartes patrouille déployables */
.patrol-card{
  margin-bottom:.9rem;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:12px;
  overflow:hidden;
  transition:border-color .2s, box-shadow .2s;
}
.patrol-card.drag-over{
  border-color:rgba(201,168,76,.45);
  box-shadow:0 0 0 1px rgba(201,168,76,.15);
}
.patrol-card__head{
  display:flex;
  align-items:center;
  gap:.5rem;
  flex-wrap:wrap;
  padding:.62rem .85rem;
  cursor:pointer;
  user-select:none;
  background:linear-gradient(180deg, rgba(255,255,255,.03), transparent);
}
.patrol-card__head:hover{background:rgba(201,168,76,.04);}
.patrol-card--open .patrol-card__head{border-bottom:1px solid var(--border);}
.patrol-card__chevron{
  font-size:.62rem;
  color:var(--gold-dim);
  transition:transform .2s ease;
  width:1rem;
  flex-shrink:0;
  text-align:center;
}
.patrol-card--open .patrol-card__chevron{transform:rotate(90deg);}
.patrol-card__icon{font-size:1.05rem;flex-shrink:0;line-height:1;}
.patrol-card__titlewrap{display:flex;flex-direction:column;gap:.1rem;min-width:0;}
.patrol-card__title{
  font-family:'Oswald',sans-serif;font-size:.92rem;font-weight:700;color:var(--text-bright);
  letter-spacing:.04em;
}
.patrol-card__sub{
  font-family:'Share Tech Mono',monospace;font-size:.52rem;color:var(--text-dim);letter-spacing:.08em;text-transform:uppercase;
}
.patrol-card__status{
  display:inline-flex;align-items:center;gap:.35rem;
  font-family:'Share Tech Mono',monospace;font-size:.58rem;padding:.22rem .5rem;border-radius:999px;border:1px solid;
  flex-shrink:0;
}
.patrol-card__status .dot{width:6px;height:6px;border-radius:50%;background:currentColor;}
.patrol-card__status--green{color:var(--green);border-color:rgba(76,175,114,.35);background:rgba(76,175,114,.08);}
.patrol-card__status--red{color:var(--red);border-color:rgba(201,76,76,.35);background:rgba(201,76,76,.1);}
.patrol-card__status--orange{color:var(--orange);border-color:rgba(212,130,42,.35);background:rgba(212,130,42,.1);}
.patrol-card__status--blue{color:var(--blue);border-color:rgba(76,139,201,.35);background:rgba(76,139,201,.1);}
.patrol-card__status--gold{color:var(--gold);border-color:rgba(201,168,76,.35);background:rgba(201,168,76,.08);}
.patrol-card__pills{
  display:flex;flex-wrap:wrap;gap:.35rem;align-items:center;
  margin-left:auto;
  flex:1 1 auto;
  justify-content:flex-end;
  min-width:8rem;
}
.pc-pill{
  font-family:'Share Tech Mono',monospace;font-size:.52rem;color:var(--text);
  padding:.18rem .42rem;border-radius:6px;background:rgba(0,0,0,.25);border:1px solid var(--border);
  white-space:nowrap;max-width:8rem;overflow:hidden;text-overflow:ellipsis;
}
.patrol-card__join{
  flex-shrink:0;
  font-family:'Oswald',sans-serif;font-size:.62rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  padding:.38rem .75rem;border-radius:8px;border:1px solid var(--border);
  background:rgba(255,255,255,.06);color:var(--text-bright);cursor:pointer;
  transition:background .15s,border-color .15s;
}
.patrol-card__join:hover{background:rgba(201,168,76,.12);border-color:rgba(201,168,76,.35);}
.patrol-card__mine{
  flex-shrink:0;font-family:'Share Tech Mono',monospace;font-size:.52rem;color:var(--gold-dim);
  padding:.25rem .5rem;border:1px dashed rgba(201,168,76,.25);border-radius:6px;
}
.patrol-drop-zone--bar{
  padding:.35rem .75rem;font-family:'Share Tech Mono',monospace;font-size:.54rem;
  color:var(--gold-dim);text-align:center;letter-spacing:.06em;
  background:rgba(155,110,202,.06);border-top:1px dashed rgba(155,110,202,.22);
}
.patrol-drop-zone--bar.drag-active{
  background:rgba(155,110,202,.14);color:var(--purple);border-top-color:var(--purple);
}
.patrol-card__body{display:none;padding:.85rem .9rem 1rem;background:rgba(0,0,0,.18);}
.patrol-card--open .patrol-card__body{display:block;}
.patrol-card__memtitle{
  font-family:'Oswald',sans-serif;font-size:.72rem;font-weight:600;color:var(--gold);letter-spacing:.12em;text-transform:uppercase;
  margin-bottom:.5rem;display:flex;align-items:center;gap:.4rem;
}
.patrol-card__memcount{
  font-family:'Share Tech Mono',monospace;font-size:.58rem;color:var(--text-dim);background:var(--bg-deep);padding:.1rem .4rem;border-radius:4px;
}
.patrol-card__agents .agent-row{
  margin-bottom:.4rem;
}
@media (max-width:960px){
  .patrol-card__pills{justify-content:flex-start;margin-left:0;width:100%;}
}

/* Agent row */
.agent-row{
  display:grid;
  grid-template-columns:minmax(11rem,1fr) minmax(8rem,1.4fr) minmax(10rem,1fr) 5rem 7.5rem;
  align-items:center;gap:.55rem;
  padding:.65rem .9rem;
  background:var(--bg-card);border:1px solid var(--border);border-left:3px solid transparent;
  margin-bottom:.35rem;transition:all .18s;
}
.agent-row:hover{border-color:rgba(201,168,76,.22);}
.agent-row.ow{background:rgba(201,168,76,.025);}
.ar-bc-green{border-left-color:var(--green)!important;}
.ar-bc-red{border-left-color:var(--red)!important;}
.ar-bc-orange{border-left-color:var(--orange)!important;}
.ar-bc-blue{border-left-color:var(--blue)!important;}
.ar-bc-gold{border-left-color:var(--gold)!important;}

.ar-unit{font-family:'Share Tech Mono',monospace;font-size:.85rem;color:var(--gold);letter-spacing:.03em;}
.ar-name{font-family:'Rajdhani',sans-serif;font-size:1.05rem;font-weight:600;color:var(--text-bright);}
.ar-discord{font-family:'Share Tech Mono',monospace;font-size:.65rem;color:var(--text-dim);letter-spacing:.03em;}
.ar-grade{font-family:'Share Tech Mono',monospace;font-size:.65rem;color:var(--khaki-dim);letter-spacing:.05em;}
.ar-status-badge{display:inline-flex;align-items:center;gap:.35rem;font-family:'Share Tech Mono',monospace;font-size:.72rem;padding:.25rem .55rem;border:1px solid;white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis;}
.ar-status-badge .dot{width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0;}
.asb-green{color:var(--green);border-color:rgba(76,175,114,.32);background:rgba(76,175,114,.07);}
.asb-red{color:var(--red);border-color:rgba(201,76,76,.32);background:rgba(201,76,76,.07);}
.asb-orange{color:var(--orange);border-color:rgba(212,130,42,.32);background:rgba(212,130,42,.07);}
.asb-blue{color:var(--blue);border-color:rgba(76,139,201,.32);background:rgba(76,139,201,.07);}
.asb-gold{color:var(--gold);border-color:rgba(201,168,76,.32);background:rgba(201,168,76,.07);}

.ar-time{font-family:'Share Tech Mono',monospace;font-size:.68rem;color:var(--text-dim);text-align:right;}

.tag-you{font-family:'Share Tech Mono',monospace;font-size:.48rem;color:var(--bg-deep);background:var(--gold-dim);padding:.08rem .28rem;letter-spacing:.05em;vertical-align:middle;margin-left:.3rem;}
.tag-disp{font-family:'Share Tech Mono',monospace;font-size:.48rem;color:var(--purple);background:rgba(155,110,202,.13);border:1px solid rgba(155,110,202,.28);padding:.08rem .28rem;margin-left:.3rem;}

/* Waiting row */
.waiting-row{
  display:grid;grid-template-columns:minmax(6.5rem,0.9fr) minmax(0,1fr) minmax(0,1fr) minmax(0,1fr) auto;
  align-items:center;gap:.55rem;
  padding:.65rem .9rem;
  background:rgba(201,168,76,.025);border:1px solid rgba(201,168,76,.1);border-left:3px solid var(--gold-dim);
  margin-bottom:.35rem;transition:all .15s;
}
.waiting-row:hover{border-color:rgba(201,168,76,.25);}

/* Empty */
.empty{text-align:center;padding:2rem 1rem;font-family:'Share Tech Mono',monospace;font-size:.68rem;color:var(--text-dim);letter-spacing:.15em;}
.empty::before{content:'[ AUCUNE UNITÉ ]';display:block;color:var(--gold-dim);font-size:.58rem;margin-bottom:.4rem;letter-spacing:.25em;}

/* ══════════════════════════════════
   DISPATCHER PAGE
══════════════════════════════════ */
.dp-panel{background:var(--bg-card);border:1px solid var(--border-bright);padding:1.25rem;margin-bottom:1.5rem;position:relative;}
.dp-panel::before{content:'';position:absolute;top:-1px;left:18px;right:18px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);}
.dp-title{font-family:'Oswald',sans-serif;font-size:.72rem;font-weight:600;color:var(--gold);letter-spacing:.2em;text-transform:uppercase;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem;}
.dp-badge{font-family:'Share Tech Mono',monospace;font-size:.52rem;padding:.08rem .38rem;background:rgba(155,110,202,.12);border:1px solid rgba(155,110,202,.28);color:var(--purple);letter-spacing:.1em;}
.dp-form{display:grid;grid-template-columns:1fr 1fr 1fr 1fr auto;gap:.65rem;align-items:end;}
.dp-fl{display:flex;flex-direction:column;gap:.28rem;}
.dp-lbl{font-family:'Share Tech Mono',monospace;font-size:.54rem;color:var(--gold-dim);letter-spacing:.15em;text-transform:uppercase;}

/* ══════════════════════════════════
   LOG PAGE
══════════════════════════════════ */
.log-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;}
.log-filters{display:flex;gap:.38rem;flex-wrap:wrap;}
.lf-btn{font-family:'Share Tech Mono',monospace;font-size:.62rem;padding:.32rem .7rem;background:var(--bg-card);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;transition:all .15s;letter-spacing:.07em;}
.lf-btn:hover,.lf-btn.active{border-color:var(--gold-dim);color:var(--gold);}

.log-entry{display:flex;align-items:flex-start;gap:.75rem;padding:.6rem .8rem;background:var(--bg-card);border:1px solid var(--border);border-left:2px solid var(--border);margin-bottom:.28rem;animation:logIn .25s ease;}
@keyframes logIn{from{opacity:0;transform:translateY(-3px)}to{opacity:1;transform:none}}
.ev-status{border-left-color:var(--blue)!important;}
.ev-dispatch{border-left-color:var(--gold)!important;}
.ev-login{border-left-color:var(--green)!important;}
.ev-logout{border-left-color:var(--red)!important;}
.ev-alert{border-left-color:var(--red)!important;background:rgba(201,76,76,.03)!important;}
.ev-patrol{border-left-color:var(--teal)!important;}
.log-time{font-family:'Share Tech Mono',monospace;font-size:.62rem;color:var(--text-dim);white-space:nowrap;min-width:52px;}
.log-icon{font-size:.85rem;flex-shrink:0;}
.log-body{flex:1;}
.log-main{font-family:'Rajdhani',sans-serif;font-size:.88rem;font-weight:600;color:var(--text-bright);line-height:1.3;}
.log-sub{font-family:'Share Tech Mono',monospace;font-size:.6rem;color:var(--text-dim);margin-top:2px;}

/* ══════════════════════════════════
   CODES PAGE
══════════════════════════════════ */
.codes-sec-hdr{font-family:'Oswald',sans-serif;font-size:.65rem;color:var(--gold-dim);letter-spacing:.25em;text-transform:uppercase;margin-bottom:.75rem;padding-bottom:.4rem;border-bottom:1px solid var(--border);margin-top:1.5rem;}
.codes-sec-hdr:first-child{margin-top:0;}
.codes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(255px,1fr));gap:.32rem;margin-bottom:.5rem;}
/* Intitulés d'unités : 4×2 (Mary / Motorisé sur la 2e ligne) */
#cg-units.codes-grid{grid-template-columns:repeat(4,minmax(0,1fr));}
/* Unités spécialisées : 3×3 */
#cg-spec.codes-grid{grid-template-columns:repeat(3,minmax(0,1fr));}
.code-card{display:flex;align-items:center;gap:.7rem;padding:.45rem .7rem;background:var(--bg-card);border:1px solid var(--border);transition:border-color .15s;}
.code-card:hover{border-color:rgba(201,168,76,.22);}
.code-num{font-family:'Share Tech Mono',monospace;font-size:.7rem;color:var(--gold);min-width:50px;letter-spacing:.04em;}
.code-desc{font-family:'Rajdhani',sans-serif;font-size:.88rem;color:var(--text);}

/* ══════════════════════════════════
   MODAL
══════════════════════════════════ */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.88);z-index:1000;align-items:center;justify-content:center;}
.modal-overlay.open{display:flex;}
.modal{background:var(--bg-panel);border:1px solid var(--border-bright);padding:1.75rem;width:390px;position:relative;animation:mIn .18s ease;}
@keyframes mIn{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
.modal::before{content:'';position:absolute;top:-1px;left:22px;right:22px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);}
.modal-title{font-family:'Oswald',sans-serif;font-size:.95rem;font-weight:600;color:var(--gold);letter-spacing:.15em;text-transform:uppercase;margin-bottom:1.2rem;}
.modal-body{display:flex;flex-direction:column;gap:.7rem;}
.modal-footer{display:flex;gap:.5rem;margin-top:1.2rem;}
.modal-footer .btn-primary{flex:1;}
.info-box{background:var(--bg-deep);border:1px solid var(--border);padding:.6rem .8rem;font-family:'Share Tech Mono',monospace;font-size:.72rem;color:var(--gold);letter-spacing:.06em;}

/* ══════════════════════════════════
   TOAST
══════════════════════════════════ */
.toast{position:fixed;bottom:1.5rem;right:1.5rem;background:var(--bg-panel);border:1px solid var(--gold-dim);border-left:3px solid var(--gold);padding:.7rem .95rem;font-family:'Share Tech Mono',monospace;font-size:.7rem;color:var(--text-bright);z-index:2000;transform:translateX(120%);transition:transform .3s ease;max-width:320px;letter-spacing:.04em;}
.toast.show{transform:translateX(0);}
.toast.t-error{border-color:var(--red);border-left-color:var(--red);}
.toast.t-alert{border-color:var(--red);border-left-color:var(--red);background:rgba(201,76,76,.08);}

/* Scrollbar */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--bg-deep)}
::-webkit-scrollbar-thumb{background:var(--gold-dim)}

.cdot {
  width:10px;height:10px;border-radius:50%;
  background:var(--border);border:1px solid var(--border-bright);
  transition:all .15s;
}
.cdot.filled { background:var(--gold);border-color:var(--gold);box-shadow:0 0 6px rgba(201,168,76,.5); }

/* ═══════════════════════════════════════════
   RESPONSIVE — Tablet, Mobile, Desktop
═══════════════════════════════════════════ */

/* ── TABLET 900px ── */
@media (max-width: 900px) {
  .app-body { grid-template-columns: minmax(240px, 32vw) minmax(0,1fr); }
  .stats-bar { grid-template-columns: repeat(2,1fr); gap:.55rem; }
  .agent-row { grid-template-columns: minmax(9rem,1fr) minmax(6rem,1fr) minmax(8rem,1fr) 4.5rem 6.5rem; }
  .dp-form { grid-template-columns: 1fr 1fr; gap:.5rem; }
  .dp-form .btn-primary { grid-column: span 2; width:100%; }
  .hnav-btn { padding:.5rem .65rem; font-size:.65rem; }
  .hbrand-text span:last-child { display:none; }
}

/* ── MOBILE 640px ── */
@media (max-width: 640px) {

  /* Header */
  .app-header { height:54px; padding:0 .875rem; }
  .hbrand img { width:30px; height:30px; }
  .hbrand-text span:first-child { font-size:.82rem; letter-spacing:.1em; }
  .hnav { display:none; }
  .agent-pill { display:none; }
  .live-clock { font-size:.92rem; }
  #mob-hamburger { display:flex !important; }

  /* Layout */
  .app-body {
    grid-template-columns: 1fr;
    height: calc(100vh - 54px - 58px);
  }

  /* Sidebar drawer */
  .sidebar {
    position: fixed;
    top: 54px;
    left: -100%;
    width: min(290px, 88vw);
    height: calc(100vh - 54px);
    z-index: 300;
    transition: left .28s cubic-bezier(.4,0,.2,1);
    box-shadow: 6px 0 32px rgba(0,0,0,.5);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  .sidebar.mob-open { left: 0; }

  #mob-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.65);
    z-index: 290;
    backdrop-filter: blur(1px);
  }
  #mob-overlay.show { display: block; }

  /* Main content */
  .main-content {
    height: calc(100vh - 54px - 58px);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  .page { padding: .875rem; }

  /* Stats — 4 colonnes compactes */
  .stats-bar { grid-template-columns: repeat(3,1fr); gap:.28rem; margin-bottom:.875rem; }
  .stat-card { padding:.5rem .35rem; }
  .stat-card-n { font-size:1.3rem; }
  .stat-card-l { font-size:.42rem; letter-spacing:.05em; }

  /* Agent rows — cards 2 lignes */
  .agent-row {
    display: flex;
    flex-direction: column;
    gap: .3rem;
    padding: .6rem .7rem;
  }
  .agent-row .desk { display: none !important; }
  .agent-row .mob-r1 {
    display: flex !important;
    align-items: flex-start;
    justify-content: space-between;
    gap: .5rem;
  }
  .agent-row .mob-r2 {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    gap: .4rem;
  }
  .ar-name { font-size:.88rem; }
  .ar-grade { font-size:.58rem; margin-top:1px; }
  .ar-status-badge { font-size:.62rem; }
  .btn-sm { min-height:32px; font-size:.55rem; }

  /* Patrol cards */
  .patrol-card__head { padding:.5rem .65rem; gap:.4rem; }
  .patrol-card__title { font-size:.82rem; }
  .patrol-card__join { padding:.34rem .6rem; font-size:.58rem; }
  .bsec-hdr { padding:.38rem .6rem; }
  .bsec-title { font-size:.78rem; }

  /* Dispatcher */
  .dp-panel { padding:1rem; }
  .dp-form { grid-template-columns:1fr; }
  .dp-form .btn-primary { width:100%; padding:.7rem; }
  .dp-title { font-size:.68rem; flex-wrap:wrap; }

  /* Log */
  .log-entry { padding:.5rem .65rem; gap:.5rem; }
  .log-main { font-size:.82rem; }
  .lf-btn { font-size:.58rem; padding:.28rem .5rem; }

  /* Codes */
  .codes-grid { grid-template-columns:1fr; }
  #cg-units.codes-grid { grid-template-columns:1fr; }
  #cg-spec.codes-grid { grid-template-columns:1fr; }

  /* Modal — slide up depuis le bas */
  .modal-overlay { align-items:flex-end; padding:0; }
  .modal {
    width:100%;
    max-width:100%;
    border-radius:0;
    padding:1.5rem 1.25rem 2rem;
    animation:mobUp .25s ease;
  }
  @keyframes mobUp {
    from { transform:translateY(20px); opacity:0; }
    to   { transform:translateY(0); opacity:1; }
  }

  /* Status pad — plus grands pour doigts */
  .status-pad { gap:.32rem; padding:.5rem .875rem .875rem; }
  .sp-btn { padding:.6rem .3rem; min-height:50px; font-size:.62rem; }
  .sb-patrol, .sb-inputs { padding:.5rem .875rem .875rem; }
  .sidebar-bottom { padding:.75rem .875rem; }

  /* Login */
  #screen-login { padding:.875rem; justify-content:flex-start; padding-top:1.5rem; }
  .login-card { width:100%; max-width:420px; padding:1.5rem 1.25rem; }
  .login-header { gap:1rem; }
  .login-header img { width:80px !important; height:80px !important; }
  .login-titles h1 { font-size:1.3rem; }

  /* Misc */
  #waiting-pill { flex-wrap:wrap; }
  .broadcast-banner { padding:.5rem .75rem; gap:.5rem; }
}

/* ── VERY SMALL 380px ── */
@media (max-width: 380px) {
  .stats-bar { grid-template-columns: repeat(2,1fr); }
  .stat-card-n { font-size:1.1rem; }
  .login-header { flex-direction:column; text-align:center; }
}

/* ── BOTTOM NAV (mobile only) ── */
.mob-bottom-nav {
  display: none;
  position: fixed;
  bottom:0; left:0; right:0;
  height: 58px;
  background: var(--bg-panel);
  border-top: 1px solid var(--border-bright);
  z-index: 280;
  align-items: stretch;
}
.mob-bottom-nav::before {
  content:'';
  position:absolute;
  top:-1px; left:15%; right:15%;
  height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}

.mob-btn {
  flex:1;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:2px;
  background:transparent; border:none;
  border-top:2px solid transparent;
  color:var(--text-dim);
  cursor:pointer;
  font-family:'Share Tech Mono',monospace;
  font-size:.46rem; letter-spacing:.06em; text-transform:uppercase;
  padding:0 .2rem;
  transition:color .15s, border-color .15s;
  -webkit-tap-highlight-color:transparent;
}
.mob-btn .mbi { font-size:1.1rem; line-height:1; }
.mob-btn.on { color:var(--gold); border-top-color:var(--gold); }
.mob-btn.disp-gated { display:none; }
.mob-btn.disp-gated.unlocked { display:flex; }

@media (max-width: 640px) {
  .mob-bottom-nav { display:flex; }
}

/* Hamburger */
#mob-hamburger {
  display:none;
  background:transparent;
  border:1px solid var(--border);
  color:var(--text-dim);
  width:34px; height:34px;
  cursor:pointer;
  align-items:center; justify-content:center;
  font-size:1rem; flex-shrink:0;
  -webkit-tap-highlight-color:transparent;
  transition:all .15s;
}
#mob-hamburger:hover { border-color:var(--gold-dim); color:var(--gold); }

/* PROCÉDURE button */
.sp-btn.sp-proc {
  background: rgba(201,168,76,.08) !important;
  border-color: rgba(201,168,76,.45) !important;
  color: var(--gold) !important;
  font-size:.82rem;
  font-weight:600;
  letter-spacing:.08em;
}
.sp-btn.sp-proc span { color: var(--gold-dim) !important; font-size:.65rem; }
.sp-btn.sp-proc:hover { background: rgba(201,168,76,.15) !important; }

