html,body,#root{height:100%}:root{--bg:#f5f7fb;--card:#fff;--border:#e4e8ef;--text:#1a1f2e;--muted:#6b7280;--primary:#0b3c8a;--primary-hover:#062a63;--danger:#c81e1e;--success:#1e7e34}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}button{cursor:pointer;border:1px solid var(--border);background:#fff;border-radius:8px;padding:10px 16px;font-size:14px;font-weight:500;transition:all .15s}button:hover:not(:disabled){background:#f9fafb}button:disabled{opacity:.5;cursor:not-allowed}button.primary{background:var(--primary);color:#fff;border-color:var(--primary);padding:12px 20px;font-weight:600}button.primary:hover:not(:disabled){background:var(--primary-hover)}button.ghost{color:var(--muted);background:0 0}input,textarea,select{border:1px solid var(--border);background:#fff;border-radius:8px;width:100%;padding:10px 12px;font-family:inherit;font-size:14px}input:focus,textarea:focus,select:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #0b3c8a26}label{color:var(--text);margin-bottom:12px;font-size:13px;font-weight:500;display:block}label input,label textarea,label select{margin-top:6px}.card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:20px;box-shadow:0 1px 2px #0000000a}.card h2{margin:0 0 16px;font-size:16px;font-weight:600}.muted{color:var(--muted)}.small{font-size:12px}.error{color:var(--danger);margin:4px 0 12px;font-size:13px}.auth-shell{justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-card{width:100%;max-width:400px}.auth-brand{align-items:center;gap:14px;margin-bottom:28px;display:flex}.auth-logo,.brand-dot{background:var(--primary);color:#fff;border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;font-weight:800;display:flex}.brand-dot{border-radius:10px;width:36px;height:36px;font-size:18px}.auth-brand h1{margin:0;font-size:20px}.auth-brand p{margin:0}.dashboard{max-width:1400px;min-height:100vh;margin:0 auto;padding:20px}.topbar{border:1px solid var(--border);background:#fff;border-radius:12px;justify-content:space-between;align-items:center;margin-bottom:20px;padding:12px 20px;display:flex}.topbar-left,.topbar-right{align-items:center;gap:16px;display:flex}.ws-indicator{border-radius:100px;padding:4px 10px;font-size:13px;font-weight:600}.ws-indicator.ok{color:var(--success);background:#e6f4ea}.ws-indicator.off{color:var(--danger);background:#fde7e7}.grid{grid-template-columns:1fr 1fr;gap:20px;display:grid}.span-2{grid-column:span 2}@media (width<=900px){.grid{grid-template-columns:1fr}.span-2{grid-column:span 1}}.alarm-status{letter-spacing:.5px;border-radius:100px;padding:4px 12px;font-size:12px;font-weight:700;display:inline-block}.alarm-status-active{color:var(--danger);background:#fde7e7}.alarm-status-closed{color:var(--muted);background:#eef0f3}.alarm-status-expired{color:#a36200;background:#fff4e0}.alarm-status-cancelled{color:var(--muted);background:#eef0f3}.responses-table{border-collapse:collapse;width:100%;font-size:14px}.responses-table th{text-align:left;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);padding:10px 12px;font-size:12px;font-weight:600}.responses-table td{border-bottom:1px solid var(--border);vertical-align:top;padding:12px}.responses-table tr:last-child td{border-bottom:none}.status-pill{color:#fff;border-radius:100px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-block}.timeline{padding-left:20px;position:relative}.timeline:before{content:"";background:var(--border);width:2px;position:absolute;top:6px;bottom:0;left:5px}.timeline-item{padding-bottom:16px;position:relative}.timeline-dot{width:12px;height:12px;box-shadow:0 0 0 2px var(--border);border:2px solid #fff;border-radius:50%;position:absolute;top:4px;left:-19px}.timeline-header{justify-content:space-between;align-items:center;display:flex}.timeline-time{color:var(--muted);font-size:12px}.timeline-payload{background:var(--bg);border-radius:6px;max-height:80px;margin:6px 0 0;padding:8px;font-size:11px;overflow:auto}.delivery-summary{background:var(--bg);border-radius:8px;margin-bottom:8px;padding:12px;font-size:13px}.toasts{z-index:1000;flex-direction:column;gap:8px;display:flex;position:fixed;top:20px;right:20px}.toast{color:#fff;border-radius:10px;min-width:280px;max-width:400px;padding:12px 20px;font-size:14px;font-weight:500;animation:.2s ease-out slideIn;box-shadow:0 4px 12px #00000026}.toast-success{background:var(--success)}.toast-error{background:var(--danger)}.toast-info{background:var(--primary)}@keyframes slideIn{0%{opacity:0;transform:translate(400px)}to{opacity:1;transform:translate(0)}}.at-risk-section{background:linear-gradient(135deg,#fdf2f2 0%,#fff5f5 100%);border:2px solid #f5c0c0;border-radius:12px;margin-bottom:16px;padding:18px 20px;box-shadow:0 2px 10px #c81e1e14}.at-risk-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.at-risk-title{color:var(--danger);font-size:16px;font-weight:700}.at-risk-subtitle{color:#7a5a5a;margin-top:2px;font-size:12px}.at-risk-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px;display:grid}.at-risk-card{cursor:pointer;text-align:left;background:#fff;border:1px solid #f0d4d4;border-radius:10px;align-items:center;gap:12px;padding:10px 12px;font-family:inherit;transition:all .15s;display:flex}.at-risk-card:hover{border-color:var(--danger);transform:translateY(-1px);box-shadow:0 4px 12px #c81e1e26}.at-risk-avatar{color:#fff;background:linear-gradient(135deg,#c81e1e,#e54545);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:15px;font-weight:700;display:flex}.at-risk-info{flex:1;min-width:0}.at-risk-name{white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.at-risk-meta{align-items:center;gap:6px;margin-top:4px;font-size:11px;display:flex}.at-risk-badge{white-space:nowrap;border-radius:10px;padding:2px 8px;font-size:10.5px;font-weight:600}.at-risk-since{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.at-risk-phone{color:var(--primary);font-variant-numeric:tabular-nums;margin-top:3px;font-size:12px}.profile-modal-backdrop{z-index:9000;background:#00000080;justify-content:center;align-items:center;padding:20px;animation:.2s ease-out sosBackdropFade;display:flex;position:fixed;inset:0}.profile-modal{background:#fff;border-radius:16px;width:100%;max-width:440px;padding:28px 24px 24px;position:relative;box-shadow:0 20px 60px #0000004d}.profile-modal-close{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:4px 10px;font-size:18px;position:absolute;top:12px;right:12px}.profile-modal-close:hover{color:var(--text)}.profile-modal-avatar{color:#fff;background:linear-gradient(135deg,#0b3c8a,#1e5ab8);border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 12px;font-size:28px;font-weight:700;display:flex;box-shadow:0 6px 18px #0b3c8a40}.profile-modal-name{text-align:center;margin:0 0 4px;font-size:20px;font-weight:700}.profile-modal-role{text-align:center;color:var(--primary);background:#e7f0fe;border-radius:14px;width:fit-content;margin:0 auto 20px;padding:4px 12px;font-size:12px;font-weight:600}.profile-modal-fields{flex-direction:column;gap:10px;display:flex}.profile-field{background:#f5f7fb;border-radius:8px;grid-template-columns:90px 1fr auto;align-items:center;gap:10px;padding:10px 12px;display:grid}.profile-field-label{color:var(--muted);font-size:12px;font-weight:600}.profile-field-value{font-size:14px;font-weight:500}.profile-field-action a{background:var(--primary);color:#fff;border-radius:6px;padding:6px 12px;font-size:12px;font-weight:600;text-decoration:none;display:inline-block}.profile-field-action a:hover{background:var(--primary-hover)}.siren-kill-btn{background:var(--danger);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:8px 14px;font-size:13px;font-weight:700;box-shadow:0 2px 8px #c81e1e40}.siren-kill-btn:hover{background:#a31717}.sos-modal-backdrop{z-index:9999;background:#0a0000bf;justify-content:center;align-items:center;padding:24px;animation:.25s ease-out sosBackdropFade;display:flex;position:fixed;inset:0}@keyframes sosBackdropFade{0%{opacity:0}to{opacity:1}}.sos-modal{border:3px solid var(--danger);background:#fff;border-radius:16px;width:100%;max-width:560px;padding:28px 28px 24px;animation:.3s cubic-bezier(.34,1.56,.64,1) sosPop;position:relative;box-shadow:0 20px 60px #c81e1e99}@keyframes sosPop{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}.sos-modal-pulse{border:3px solid var(--danger);pointer-events:none;border-radius:20px;animation:1.4s infinite sosPulse;position:absolute;inset:-6px}@keyframes sosPulse{0%{opacity:.9;transform:scale(1)}70%{opacity:0;transform:scale(1.04)}to{opacity:0;transform:scale(1)}}.sos-modal-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.sos-modal-badge{background:var(--danger);color:#fff;letter-spacing:1px;border-radius:20px;padding:6px 14px;font-size:13px;font-weight:800}.sos-modal-time{color:var(--muted);font-variant-numeric:tabular-nums;font-size:13px}.sos-modal-title{color:var(--danger);margin:0 0 14px;font-size:26px;font-weight:800;line-height:1.2}.sos-modal-body p{color:var(--text);margin:0;font-size:15px;line-height:1.5}.sos-modal-location{background:#fff6f6;border:1px solid #ffd5d5;border-radius:8px;margin-top:14px;padding:12px 14px;font-size:14px}.sos-modal-location a{color:var(--danger);font-weight:600}.sos-modal-actions{gap:10px;margin-top:20px;display:flex}.sos-modal-btn-primary{background:var(--danger);color:#fff;cursor:pointer;border:none;border-radius:10px;flex:1;padding:14px 18px;font-size:15px;font-weight:700}.sos-modal-btn-primary:hover{background:#a31717}.sos-modal-btn-ghost{color:var(--text);border:1px solid var(--border);background:0 0;border-radius:10px;padding:14px 18px;font-weight:500}.sos-modal-hint{color:var(--muted);text-align:center;margin-top:14px;font-size:12px;line-height:1.4}
