*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #1a1a2e;--surface: #16213e;--surface-hover: #1a2744;--border: #2a3a5c;--text: #e0e0e0;--text-muted: #8892a4;--primary: #4f8cff;--primary-hover: #3a78f0;--danger: #ef4444;--danger-hover: #dc2626;--success: #4ade80;--warning: #facc15;--radius: 10px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);min-height:100dvh;-webkit-font-smoothing:antialiased}.app{max-width:640px;margin:0 auto;padding:20px 16px env(safe-area-inset-bottom,16px)}header{text-align:center;padding:24px 0 16px}header h1{font-size:1.8rem;font-weight:700;color:var(--primary)}.subtitle{color:var(--text-muted);font-size:.9rem;margin-top:4px}h2{font-size:1.1rem;font-weight:600;margin-bottom:12px;color:var(--text)}section{margin-bottom:24px}.alert-form .input-group{display:flex;gap:8px}.alert-form input{flex:1;padding:12px 14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:.95rem;outline:none;transition:border-color .2s}.alert-form input:focus{border-color:var(--primary)}.alert-form input::placeholder{color:var(--text-muted);font-size:.85rem}button{cursor:pointer;border:none;border-radius:var(--radius);font-size:.9rem;font-weight:600;padding:10px 18px;transition:background .2s,opacity .2s}button:disabled{opacity:.5;cursor:not-allowed}.btn-primary,.alert-form button[type=submit]{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled),.alert-form button[type=submit]:hover:not(:disabled){background:var(--primary-hover)}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--surface-hover)}.btn-danger{background:transparent;color:var(--danger);border:1px solid var(--danger)}.btn-danger:hover:not(:disabled){background:var(--danger);color:#fff}.alert-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px}.alert-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-label{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.alert-type{margin-left:auto;font-size:.75rem;color:var(--text-muted);background:var(--bg);padding:2px 8px;border-radius:4px}.alert-description{font-size:.95rem;margin-bottom:10px;line-height:1.4}.alert-meta{display:flex;flex-wrap:wrap;gap:8px 16px;font-size:.8rem;color:var(--text-muted);margin-bottom:8px}.alert-time{font-size:.8rem;color:var(--text-muted)}.alert-time.fired{color:var(--danger)}.alert-history{margin-top:10px;font-size:.8rem}.alert-history summary{cursor:pointer;color:var(--text-muted);margin-bottom:6px}.alert-history ul{list-style:none;padding:0}.alert-history li{display:flex;gap:8px;padding:4px 0;border-top:1px solid var(--border);color:var(--text-muted)}.event-type{font-weight:600;min-width:60px}.event-detail{color:var(--text)}.alert-actions{display:flex;gap:8px;margin-top:12px}.push-enrollment{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:20px;text-align:center}.push-enrollment p{font-size:.9rem;color:var(--text-muted);margin-bottom:12px}.push-status{text-align:center;padding:10px;border-radius:var(--radius);font-size:.85rem;margin-bottom:20px}.push-active{background:#4ade801a;color:var(--success);border:1px solid rgba(74,222,128,.2)}.push-denied{background:#ef44441a;color:var(--danger);border:1px solid rgba(239,68,68,.2)}.loading,.empty,.error{text-align:center;padding:32px 16px;color:var(--text-muted);font-size:.9rem}.error{color:var(--danger)}@media(max-width:480px){.alert-form .input-group{flex-direction:column}.alert-meta{flex-direction:column;gap:4px}}
