:root {
  --vert: #0F6E56; --vert-fonce: #085041; --vert-clair: #E1F5EE; --vert-mid: #5DCAA5;
  --bleu: #185FA5; --bleu-clair: #E6F1FB;
  --rouge: #A32D2D; --rouge-clair: #FCEBEB;
  --orange: #854F0B; --orange-clair: #FAEEDA;
  --vert-ok: #3B6D11; --vert-ok-clair: #EAF3DE;
  --violet: #3C3489; --violet-clair: #EEEDFE;
  --gris: #888780; --gris-clair: #F1EFE8;
  --bg: #ffffff; --bg-sec: #f5f5f3; --bg-ter: #eeede9;
  --text: #1a1a18; --text-sec: #6b6b66;
  --border: rgba(0,0,0,0.12); --border-med: rgba(0,0,0,0.22);
  --radius: 8px; --radius-lg: 12px;
}
@media (prefers-color-scheme: dark) {
  :root {
    --bg: #1a1a18; --bg-sec: #242422; --bg-ter: #2e2e2c;
    --text: #f0ede8; --text-sec: #a0a09a;
    --border: rgba(255,255,255,0.1); --border-med: rgba(255,255,255,0.2);
  }
}
* { box-sizing: border-box; margin: 0; padding: 0; }
body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  background: var(--bg-ter); color: var(--text);
  font-size: 16px; line-height: 1.5;
  max-width: 480px; margin: 0 auto; min-height: 100vh;
}
.topbar {
  padding: 12px 16px; display: flex; align-items: center; gap: 10px;
  position: sticky; top: 0; z-index: 100;
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
}
.topbar-agent { background: var(--vert); }
.topbar-superviseur { background: var(--vert-fonce); }
.topbar-logo { flex-shrink: 0; }
.topbar-info { flex: 1; min-width: 0; }
.topbar-title { color: #E1F5EE; font-size: 14px; font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.topbar-sub { color: #9FE1CB; font-size: 11px; margin-top: 1px; }
.topbar-right { flex-shrink: 0; }
.sync-pill { display: flex; align-items: center; gap: 4px; background: var(--vert-fonce); border-radius: 99px; padding: 3px 8px; }
.sync-dot { width: 7px; height: 7px; border-radius: 50%; }
.sync-dot.offline { background: #FAC775; }
.sync-dot.online { background: var(--vert-mid); }
.sync-label { font-size: 10px; color: #9FE1CB; }
.main-content { padding: 12px 16px; padding-bottom: 80px; }
.superviseur-main { padding-bottom: 24px; }
.section-label { font-size: 11px; font-weight: 500; color: var(--text-sec); text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 8px; margin-top: 16px; }
.card { background: var(--bg); border-radius: var(--radius-lg); border: 1px solid var(--border); padding: 14px 16px; margin-bottom: 10px; }
.card-row { display: flex; align-items: center; justify-content: space-between; }
.card-title { font-size: 15px; font-weight: 500; }
.card-sub { font-size: 12px; color: var(--text-sec); margin-top: 2px; }
.card-right { text-align: right; flex-shrink: 0; }
.badge { display: inline-block; font-size: 11px; font-weight: 600; padding: 2px 8px; border-radius: 99px; }
.badge-en_suivi { background: var(--bleu-clair); color: var(--bleu); }
.badge-transfere_cte { background: var(--orange-clair); color: var(--orange); }
.badge-cas_confirme { background: var(--rouge-clair); color: var(--rouge); }
.badge-non_cas { background: var(--gris-clair); color: var(--gris); }
.badge-sorti_sain { background: var(--vert-ok-clair); color: var(--vert-ok); }
.badge-decede { background: var(--violet-clair); color: var(--violet); }
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 6px; padding: 10px 18px; border-radius: var(--radius); font-size: 14px; font-weight: 500; border: none; cursor: pointer; text-decoration: none; transition: opacity 0.15s; }
.btn:active { opacity: 0.75; }
.btn-primary { background: var(--vert); color: #fff; }
.btn-secondary { background: var(--bg-sec); color: var(--text); border: 1px solid var(--border-med); }
.btn-danger { background: var(--rouge-clair); color: var(--rouge); }
.btn-full { width: 100%; }
.btn-icon { padding: 8px; border-radius: var(--radius); background: var(--bg-sec); border: 1px solid var(--border); color: var(--text-sec); }
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 6px; padding: 10px 18px; border-radius: var(--radius); font-size: 14px; font-weight: 500; border: none; cursor: pointer; text-decoration: none; }
.btn:active { opacity: 0.75; }
.btn-primary { background: var(--vert); color: #fff; }
.btn-secondary { background: var(--bg-sec); color: var(--text); border: 1px solid var(--border-med); }
.btn-danger { background: var(--rouge-clair); color: var(--rouge); }
.btn-full { width: 100%; }
.btn-icon { padding: 8px; border-radius: var(--radius); background: var(--bg-sec); border: 1px solid var(--border); color: var(--text-sec); }
.form-group { margin-bottom: 14px; }
.form-label { display: block; font-size: 13px; font-weight: 500; color: var(--text-sec); margin-bottom: 4px; }
.form-input { width: 100%; padding: 10px 12px; border-radius: var(--radius); border: 1px solid var(--border-med); background: var(--bg); color: var(--text); font-size: 15px; }
.form-input:focus { outline: none; border-color: var(--vert); }
.form-select { width: 100%; padding: 10px 12px; border-radius: var(--radius); border: 1px solid var(--border-med); background: var(--bg); color: var(--text); font-size: 15px; }
.form-textarea { width: 100%; padding: 10px 12px; border-radius: var(--radius); border: 1px solid var(--border-med); background: var(--bg); color: var(--text); font-size: 15px; resize: vertical; min-height: 80px; }
.form-hint { font-size: 11px; color: var(--text-sec); margin-top: 3px; }
.login-body { background: var(--vert-fonce); display: flex; align-items: center; justify-content: center; }
.login-wrap { width: 100%; max-width: 380px; padding: 24px 16px; }
.login-logo { display: flex; align-items: center; gap: 12px; margin-bottom: 24px; }
.login-icon { width: 48px; height: 48px; background: var(--vert); border-radius: 12px; display: flex; align-items: center; justify-content: center; }
.login-title { color: #E1F5EE; font-size: 20px; font-weight: 700; }
.login-sub { color: #9FE1CB; font-size: 12px; }
.login-card { background: var(--bg); border-radius: var(--radius-lg); padding: 20px; }
.login-card-title { font-size: 16px; font-weight: 600; margin-bottom: 16px; }
.login-footer { text-align: center; margin-top: 14px; }
.login-version { text-align: center; color: #9FE1CB; font-size: 11px; margin-top: 16px; }
.form-group { margin-bottom: 14px; }
.form-label { display: block; font-size: 13px; font-weight: 500; margin-bottom: 5px; color: var(--text-sec); }
.form-input { width: 100%; padding: 10px 12px; border-radius: var(--radius); border: 1px solid var(--border-med); background: var(--bg); color: var(--text); font-size: 15px; }
.form-input:focus { outline: 2px solid var(--vert); outline-offset: -1px; }
.form-select { width: 100%; padding: 10px 12px; border-radius: var(--radius); border: 1px solid var(--border-med); background: var(--bg); color: var(--text); font-size: 15px; }
.form-textarea { width: 100%; padding: 10px 12px; border-radius: var(--radius); border: 1px solid var(--border-med); background: var(--bg); color: var(--text); font-size: 15px; resize: vertical; min-height: 80px; }
.form-hint { font-size: 11px; color: var(--text-sec); margin-top: 3px; }
.form-check { display: flex; align-items: flex-start; gap: 10px; padding: 10px 0; border-bottom: 1px solid var(--border); }
.form-check:last-child { border-bottom: none; }
.form-check input[type=checkbox] { width: 18px; height: 18px; flex-shrink: 0; margin-top: 2px; accent-color: var(--vert); }
.login-body { background: var(--vert-fonce); display: flex; align-items: center; justify-content: center; min-height: 100vh; }
.login-wrap { width: 100%; max-width: 380px; padding: 24px 16px; }
.login-logo { display: flex; align-items: center; gap: 12px; margin-bottom: 24px; }
.login-icon { width: 48px; height: 48px; background: var(--vert); border-radius: 12px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.login-title { color: #E1F5EE; font-size: 20px; font-weight: 700; }
.login-sub { color: #9FE1CB; font-size: 12px; }
.login-card { background: var(--bg); border-radius: var(--radius-lg); padding: 20px; }
.login-card-title { font-size: 15px; font-weight: 600; margin-bottom: 16px; }
.login-footer { text-align: center; margin-top: 14px; }
.login-version { text-align: center; color: #9FE1CB; font-size: 11px; margin-top: 16px; }
.alert { padding: 10px 12px; border-radius: var(--radius); font-size: 13px; margin-bottom: 12px; }
.alert-danger { background: var(--rouge-clair); color: var(--rouge); }
.alert-success { background: var(--vert-ok-clair); color: var(--vert-ok); }
.alert-warning { background: var(--orange-clair); color: var(--orange); }
.link-muted { color: var(--text-sec); font-size: 13px; text-decoration: none; }
.bottom-nav { position: fixed; bottom: 0; left: 50%; transform: translateX(-50%); width: 100%; max-width: 480px; background: var(--bg); border-top: 1px solid var(--border); display: flex; z-index: 100; }
.bottom-nav-item { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 8px 4px; text-decoration: none; color: var(--text-sec); font-size: 10px; gap: 3px; }
.bottom-nav-item.active { color: var(--vert); }
.bottom-nav-icon { font-size: 20px; line-height: 1; }
.statut-banner { padding: 14px 16px; border-radius: var(--radius); margin-bottom: 16px; display: flex; align-items: center; gap: 10px; font-weight: 600; font-size: 15px; }
.statut-en_suivi { background: var(--bleu-clair); color: var(--bleu); }
.statut-transfere_cte { background: var(--orange-clair); color: var(--orange); }
.statut-cas_confirme { background: var(--rouge-clair); color: var(--rouge); }
.statut-non_cas { background: var(--gris-clair); color: var(--gris); border: 0.5px solid var(--border); }
.statut-sorti_sain { background: var(--vert-ok-clair); color: var(--vert-ok); }
.statut-decede { background: var(--violet-clair); color: var(--violet); }
.map-wrap { border-radius: var(--radius); overflow: hidden; border: 1px solid var(--border); margin-bottom: 12px; }
.info-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.info-table td { padding: 8px 4px; border-bottom: 1px solid var(--border); vertical-align: top; }
.info-table td:first-child { color: var(--text-sec); width: 42%; font-size: 13px; }
.page-title { font-size: 18px; font-weight: 700; margin-bottom: 4px; }
.page-sub { font-size: 13px; color: var(--text-sec); margin-bottom: 16px; }
.empty-state { text-align: center; padding: 40px 20px; color: var(--text-sec); }
.empty-state-icon { font-size: 36px; margin-bottom: 10px; }
.divider { height: 1px; background: var(--border); margin: 12px 0; }
.pill { display: inline-block; font-size: 11px; padding: 2px 8px; border-radius: 99px; background: var(--bg-sec); color: var(--text-sec); border: 1px solid var(--border); }
.text-danger { color: var(--rouge); }
.text-success { color: var(--vert-ok); }
.text-muted { color: var(--text-sec); font-size: 13px; }
.mt-8 { margin-top: 8px; } .mt-12 { margin-top: 12px; } .mt-16 { margin-top: 16px; }
.mb-8 { margin-bottom: 8px; } .mb-12 { margin-bottom: 12px; } .mb-16 { margin-bottom: 16px; }
