.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:linear-gradient(135deg,#1e1b4b,#312e81);color:#fff;padding:20px 32px;box-shadow:0 2px 8px #0003}.header-inner{display:flex;align-items:center;gap:20px}.header-logo{height:52px;width:auto;filter:brightness(0) invert(1)}.header-title{font-size:1.6rem;font-weight:700;margin:0}.header-sub{font-size:.85rem;color:#c7d2fe;margin:4px 0 0}.header-user{display:flex;align-items:center;gap:10px;margin-left:12px;padding-left:16px;border-left:1px solid rgba(255,255,255,.2)}.header-user-avatar{width:34px;height:34px;border-radius:50%;background:#fff3;color:#fff;font-size:.9rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.header-user-info{display:flex;flex-direction:column;line-height:1.25}.header-user-name{font-size:.82rem;font-weight:600;color:#fff}.header-user-role{font-size:.7rem;color:#c7d2fe}.header-logout-btn{background:#ffffff1f;border:1px solid rgba(255,255,255,.25);color:#e0e7ff;font-size:.75rem;font-weight:600;padding:5px 12px;border-radius:6px;cursor:pointer;white-space:nowrap;transition:background .15s}.header-logout-btn:hover{background:#ffffff38}.main{flex:1;padding:24px 32px 48px;max-width:1440px;margin:0 auto;width:100%}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:28px}.stat-card{background:#fff;border-radius:12px;padding:20px 24px;box-shadow:0 1px 4px #00000014;border-left:4px solid #6366f1}.stat-label{font-size:.75rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.stat-value{font-size:1.7rem;font-weight:700;color:#1e1b4b;margin:4px 0 2px}.stat-sub{font-size:.78rem;color:#9ca3af}.chart-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.card{background:#fff;border-radius:12px;padding:20px 24px 16px;box-shadow:0 1px 4px #00000014}.span-2{grid-column:span 2}.span-3{grid-column:span 3}.card-title{font-size:.95rem;font-weight:600;color:#374151;margin-bottom:16px}.card-loading,.card-empty{padding:48px;text-align:center;color:#9ca3af;font-size:.9rem}@media (max-width: 900px){.chart-grid{grid-template-columns:1fr}.span-2,.span-3{grid-column:span 1}.main{padding:16px}}.monitor-open-btn{margin-left:auto;background:#ffffff26;border:1px solid rgba(255,255,255,.35);color:#fff;font-size:.875rem;font-weight:600;padding:8px 18px;border-radius:8px;cursor:pointer;transition:background .15s;white-space:nowrap}.monitor-open-btn:hover{background:#ffffff47}.monitor-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:100}.monitor-panel{position:fixed;top:0;right:0;height:100vh;width:440px;max-width:100vw;background:#f9fafb;box-shadow:-4px 0 24px #0000002e;display:flex;flex-direction:column;z-index:101;transform:translate(100%);transition:transform .25s cubic-bezier(.4,0,.2,1);overflow:hidden}.monitor-panel--open{transform:translate(0)}.monitor-panel-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;background:linear-gradient(135deg,#1e1b4b,#312e81);color:#fff;flex-shrink:0}.monitor-panel-title{font-size:1.1rem;font-weight:700}.monitor-panel-meta{font-size:.75rem;color:#c7d2fe;margin-left:10px}.monitor-close-btn{background:none;border:none;color:#fff;font-size:1.1rem;cursor:pointer;padding:4px 8px;border-radius:4px;opacity:.8}.monitor-close-btn:hover{opacity:1;background:#ffffff26}.monitor-panel-body{flex:1;overflow-y:auto;padding:0 0 32px}.monitor-section{padding:18px 22px;border-bottom:1px solid #e5e7eb}.monitor-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.monitor-section-label{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#6b7280;margin:0 0 10px}.monitor-section-header .monitor-section-label{margin-bottom:0}.monitor-no-alerts{font-size:.85rem;color:#6b7280;margin:0;padding:6px 0}.monitor-alert-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.monitor-alert-item{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:10px 12px;border-radius:8px;border-left:4px solid}.monitor-alert--high{background:#fef2f2;border-color:#ef4444}.monitor-alert--medium{background:#fffbeb;border-color:#f59e0b}.monitor-alert-content{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.monitor-severity-badge{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.monitor-alert-msg{font-size:.82rem;color:#374151;line-height:1.4}.monitor-notify-btn{background:#fff;border:1px solid #d1d5db;color:#374151;font-size:.75rem;font-weight:600;padding:5px 10px;border-radius:6px;cursor:pointer;white-space:nowrap;flex-shrink:0}.monitor-notify-btn:hover{background:#f3f4f6}.monitor-notify-all-btn{background:#4f46e5;color:#fff;border:none;font-size:.75rem;font-weight:600;padding:5px 12px;border-radius:6px;cursor:pointer}.monitor-notify-all-btn:hover{background:#4338ca}.monitor-rule-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.monitor-rule-item{display:flex;align-items:center;justify-content:space-between;gap:10px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:10px 12px;transition:opacity .15s}.monitor-rule--disabled{opacity:.45}.monitor-rule--triggered{border-color:#f59e0b;background:#fffbeb}.monitor-rule-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.monitor-rule-vendor{font-size:.85rem;font-weight:600;color:#1e1b4b}.monitor-rule-cond{font-size:.78rem;color:#6b7280}.monitor-rule-email{font-size:.72rem;color:#9ca3af;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.monitor-rule-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.monitor-toggle-btn{font-size:.72rem;font-weight:700;padding:4px 10px;border-radius:999px;border:1px solid #d1d5db;background:#f3f4f6;color:#6b7280;cursor:pointer}.monitor-toggle--on{background:#dcfce7;border-color:#86efac;color:#15803d}.monitor-delete-btn{background:none;border:none;font-size:.9rem;cursor:pointer;padding:4px 6px;border-radius:4px;opacity:.55}.monitor-delete-btn:hover{opacity:1;background:#fee2e2}.monitor-form-section{border-bottom:none}.monitor-form{display:flex;flex-direction:column;gap:10px}.monitor-field{display:flex;flex-direction:column;gap:4px}.monitor-label{font-size:.75rem;font-weight:600;color:#374151}.monitor-select,.monitor-input{width:100%;padding:8px 10px;border:1px solid #d1d5db;border-radius:7px;font-size:.85rem;color:#111827;background:#fff;outline:none;box-sizing:border-box}.monitor-select:focus,.monitor-input:focus{border-color:#6366f1;box-shadow:0 0 0 2px #6366f133}.monitor-form-error{font-size:.78rem;color:#dc2626;margin:0}.monitor-add-btn{background:#4f46e5;color:#fff;border:none;font-size:.875rem;font-weight:600;padding:10px 16px;border-radius:8px;cursor:pointer;transition:background .15s;margin-top:4px}.monitor-add-btn:hover{background:#4338ca}.monitor-toast-stack{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:8px;z-index:200;pointer-events:none;max-width:420px}.monitor-toast{background:#1e1b4b;color:#fff;font-size:.82rem;padding:12px 18px;border-radius:10px;box-shadow:0 4px 16px #00000040;animation:toast-in .2s ease;line-height:1.45}@keyframes toast-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.login-bg{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#0f0c29,#1e1b4b,#312e81);padding:24px}.login-card{background:#fff;border-radius:18px;padding:44px 40px 36px;width:100%;max-width:420px;box-shadow:0 24px 64px #0006}.login-logo-wrap{display:flex;justify-content:center;margin-bottom:22px}.login-logo{height:56px;width:auto}.login-title{text-align:center;font-size:1.5rem;font-weight:800;color:#1e1b4b;margin:0 0 6px}.login-subtitle{text-align:center;font-size:.875rem;color:#6b7280;margin:0 0 28px}.login-form{display:flex;flex-direction:column;gap:16px}.login-field{display:flex;flex-direction:column;gap:5px}.login-label{font-size:.78rem;font-weight:600;color:#374151;letter-spacing:.02em}.login-input{width:100%;padding:10px 12px;border:1.5px solid #d1d5db;border-radius:9px;font-size:.9rem;color:#111827;background:#f9fafb;outline:none;transition:border-color .15s,box-shadow .15s;box-sizing:border-box}.login-input:focus{border-color:#6366f1;background:#fff;box-shadow:0 0 0 3px #6366f12e}.login-input:disabled{opacity:.6;cursor:not-allowed}.login-pw-wrap{position:relative}.login-pw-wrap .login-input{padding-right:44px}.login-pw-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:1rem;padding:2px 4px;line-height:1;opacity:.6}.login-pw-toggle:hover{opacity:1}.login-error{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:.82rem;padding:9px 12px}.login-btn{margin-top:4px;background:linear-gradient(135deg,#4f46e5,#6366f1);color:#fff;border:none;border-radius:10px;padding:12px;font-size:.95rem;font-weight:700;cursor:pointer;transition:opacity .15s,box-shadow .15s;box-shadow:0 4px 12px #6366f166;display:flex;align-items:center;justify-content:center;min-height:44px}.login-btn:hover:not(:disabled){opacity:.92;box-shadow:0 6px 18px #6366f180}.login-btn:disabled{opacity:.65;cursor:not-allowed}.login-spinner{width:18px;height:18px;border:2.5px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.login-demo-hints{margin-top:28px;padding-top:20px;border-top:1px solid #f3f4f6}.login-demo-label{font-size:.72rem;color:#9ca3af;text-align:center;margin:0 0 10px;text-transform:uppercase;letter-spacing:.06em;font-weight:600}.login-demo-list{display:flex;flex-direction:column;gap:7px}.login-demo-chip{display:flex;align-items:center;justify-content:space-between;background:#f5f3ff;border:1px solid #e0e7ff;border-radius:8px;padding:8px 14px;cursor:pointer;transition:background .12s;width:100%;text-align:left}.login-demo-chip:hover:not(:disabled){background:#ede9fe;border-color:#c4b5fd}.login-demo-chip:disabled{opacity:.5;cursor:not-allowed}.login-demo-user{font-size:.82rem;font-weight:700;color:#4f46e5;font-family:monospace}.login-demo-role{font-size:.74rem;color:#7c3aed;background:#ede9fe;padding:2px 8px;border-radius:999px;font-weight:600}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f0f2f5;color:#1a1a2e}#root{min-height:100vh}
