*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{font-family:DM Sans,-apple-system,BlinkMacSystemFont,sans-serif;background:#f8fafc;min-height:100vh;color:#0f172a;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:2px}.mono{font-family:JetBrains Mono,monospace}.btn{display:inline-flex;align-items:center;gap:6px;background:#2563eb;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;line-height:1.5;font-family:DM Sans,sans-serif;transition:background .2s,box-shadow .2s;white-space:nowrap}.btn:hover{background:#1d4ed8;box-shadow:0 0 0 3px #2563eb26}.btn-ghost{background:transparent;color:#64748b;border:1px solid #E2E8F0}.btn-ghost:hover{background:#f1f5f9;color:#0f172a;border-color:#cbd5e1;box-shadow:none}.btn-danger{background:#ef4444}.btn-danger:hover{background:#dc2626;box-shadow:0 0 0 3px #ef444426}.input-dark{width:100%;padding:10px 14px;background:#fff;border:1px solid #E2E8F0;border-radius:6px;font-size:14px;color:#0f172a;outline:none;font-family:DM Sans,sans-serif;transition:border-color .2s,box-shadow .2s}.input-dark::placeholder{color:#94a3b8}.input-dark:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1f}.option-dark{width:100%;padding:11px 16px;background:#fff;border:1px solid #E2E8F0;border-radius:6px;text-align:left;cursor:pointer;font-size:13px;color:#64748b;font-family:DM Sans,sans-serif;transition:border-color .2s,background .2s,color .2s}.option-dark:hover{border-color:#2563eb;background:#2563eb0d;color:#0f172a}.alert-row{padding:18px 20px;border-left:4px solid transparent;border-bottom:1px solid #E2E8F0;cursor:pointer;transition:background .2s}.alert-row:last-child{border-bottom:none}.alert-row.urgent{border-left-color:#ef4444;background:#fef2f2}.alert-row.urgent:hover{background:#fee2e2}.alert-row.medium{border-left-color:#f59e0b;background:#fff7ed}.alert-row.medium:hover{background:#ffedd5}.alert-row.low{border-left-color:#3b82f6;background:#eff6ff}.alert-row.low:hover{background:#dbeafe}.fade-up{animation:fadeUp .25s ease both}@keyframes fadeUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.glow-dot{width:6px;height:6px;border-radius:50%;background:#10b981;box-shadow:0 0 6px #10b981;animation:pulse 2s ease infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes blink{0%,49%{opacity:1}50%,to{opacity:0}}@keyframes spin{to{transform:rotate(360deg)}}.ai-spinner{width:36px;height:36px;border-radius:50%;border:3px solid #E2E8F0;border-top-color:#2563eb;animation:spin .8s linear infinite;margin:0 auto 16px}@keyframes msgFade{0%{opacity:0;transform:translateY(4px)}15%{opacity:1;transform:translateY(0)}85%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-4px)}}.ai-msg{animation:msgFade 3s ease forwards}.ai-spinner-sm{width:14px;height:14px;border-radius:50%;border:2px solid #BFDBFE;border-top-color:#2563eb;animation:spin .8s linear infinite;flex-shrink:0}@keyframes skelShimmer{0%{background-position:-480px 0}to{background-position:480px 0}}.skel{background-color:#e9eef3;background-image:linear-gradient(90deg,#e9eef3,#f3f6f9,#e9eef3 180px);background-size:480px 100%;background-repeat:no-repeat;border-radius:6px;animation:skelShimmer 1.3s ease-in-out infinite}@media (prefers-reduced-motion: reduce){.skel{animation:none}}.mobile-header{display:none;align-items:center;gap:12px;height:44px;background:#fff;border-bottom:1px solid #E2E8F0;padding:0 16px;position:sticky;top:0;z-index:20;flex-shrink:0}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:99;animation:backdropFade .18s ease}@keyframes backdropFade{0%{opacity:0}to{opacity:1}}.navbar-logo{height:75px;width:auto;display:block}@media (max-width: 767px){.mobile-header{display:flex}.sidebar-backdrop{display:block}.navbar-logo{height:48px}.app-content>*{min-height:0!important}}
