:root{--red-50:#fff1f0;--red-100:#ffe0de;--red-200:#ffb8b3;--red-400:#f05a52;--red-500:#e63946;--red-600:#c0392b;--red-700:#96261b;--red-900:#4a0f0a;--gray-50:#f8f9fa;--gray-100:#f1f3f5;--gray-200:#e9ecef;--gray-300:#dee2e6;--gray-400:#ced4da;--gray-500:#adb5bd;--gray-600:#6c757d;--gray-700:#495057;--gray-800:#343a40;--gray-900:#212529;--green-500:#2ecc71;--green-600:#27ae60;--amber-500:#f39c12;--amber-600:#e67e22;--blue-500:#3498db;--bg:#0f0f10;--bg-card:#1a1a1d;--bg-elevated:#222226;--border:#2e2e33;--border-light:#3a3a40;--text-primary:#f0f0f2;--text-secondary:#9999a8;--text-muted:#6b6b7a;--font-display:"Sora",sans-serif;--font-body:"DM Sans",sans-serif;--radius-sm:6px;--radius:10px;--radius-lg:16px;--radius-xl:24px;--shadow-sm:0 1px 3px #0006;--shadow:0 4px 16px #00000080;--shadow-lg:0 12px 40px #0009;--shadow-red:0 4px 20px #e6394640;--transition:0.18s ease}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;background:#0f0f10;background:var(--bg);font-family:DM Sans,sans-serif;font-family:var(--font-body);line-height:1.6}body,h1,h2,h3,h4,h5,h6{color:#f0f0f2;color:var(--text-primary)}h1,h2,h3,h4,h5,h6{font-family:Sora,sans-serif;font-family:var(--font-display);font-weight:700;line-height:1.2}a{color:#e63946;color:var(--red-500);text-decoration:none}a:hover{color:#f05a52;color:var(--red-400)}button{cursor:pointer}button,input,select,textarea{font-family:DM Sans,sans-serif;font-family:var(--font-body)}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:#1a1a1d;background:var(--bg-card)}::-webkit-scrollbar-thumb{background:#3a3a40;background:var(--border-light);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#6c757d;background:var(--gray-600)}.app-layout{display:flex;min-height:100vh}.sidebar{background:#1a1a1d;background:var(--bg-card);border-right:1px solid #2e2e33;border-right:1px solid var(--border);bottom:0;display:flex;flex-direction:column;flex-shrink:0;left:0;overflow-y:auto;position:fixed;top:0;transition:transform .18s ease;transition:transform var(--transition);width:240px;z-index:100}.main-content{display:flex;flex:1 1;flex-direction:column;margin-left:240px;min-height:100vh}.page-content{flex:1 1;max-width:1200px;padding:28px 32px;width:100%}.topbar{background:#1a1a1d;background:var(--bg-card);height:64px;justify-content:space-between;padding:0 32px;position:sticky;top:0;z-index:50}.logo,.topbar{align-items:center;border-bottom:1px solid #2e2e33;border-bottom:1px solid var(--border);display:flex}.logo{gap:10px;padding:20px 20px 16px}.logo-icon{align-items:center;background:linear-gradient(135deg,#c0392b,#e63946);background:linear-gradient(135deg,var(--red-600),var(--red-500));border-radius:6px;border-radius:var(--radius-sm);box-shadow:0 4px 20px #e6394640;box-shadow:var(--shadow-red);display:flex;font-size:20px;height:36px;justify-content:center;width:36px}.logo-text{color:#f0f0f2;color:var(--text-primary);font-family:Sora,sans-serif;font-family:var(--font-display);font-size:18px;font-weight:800}.logo-sub{color:#6b6b7a;color:var(--text-muted);font-size:10px;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.nav{flex:1 1;padding:12px 0}.nav-section-label{color:#6b6b7a;color:var(--text-muted);font-size:10px;font-weight:600;letter-spacing:.08em;padding:12px 20px 6px;text-transform:uppercase}.nav-item{align-items:center;background:none;border:none;border-radius:0;color:#9999a8;color:var(--text-secondary);cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:10px;padding:10px 20px;position:relative;text-align:left;text-decoration:none;transition:all .18s ease;transition:all var(--transition);width:100%}.nav-item:hover{background:#ffffff0a;color:#f0f0f2;color:var(--text-primary)}.nav-item.active{background:#e639461a;color:#f05a52;color:var(--red-400)}.nav-item.active:before{background:#e63946;background:var(--red-500);border-radius:0 2px 2px 0;bottom:6px;content:"";left:0;position:absolute;top:6px;width:3px}.nav-item .icon{font-size:18px;text-align:center;width:22px}.btn{align-items:center;border:1px solid #0000;border-radius:6px;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;font-family:DM Sans,sans-serif;font-family:var(--font-body);font-size:14px;font-weight:600;gap:6px;justify-content:center;padding:9px 18px;text-decoration:none;transition:all .18s ease;transition:all var(--transition);white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-primary{background:#c0392b;background:var(--red-600);border-color:#c0392b;border-color:var(--red-600);color:#fff}.btn-primary:hover:not(:disabled){background:#96261b;background:var(--red-700);box-shadow:0 4px 20px #e6394640;box-shadow:var(--shadow-red)}.btn-secondary{background:#222226;background:var(--bg-elevated);border-color:#3a3a40;border-color:var(--border-light);color:#f0f0f2;color:var(--text-primary)}.btn-secondary:hover:not(:disabled){background:#2e2e33;background:var(--border)}.btn-ghost{background:#0000;border-color:#0000;color:#9999a8;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:#222226;background:var(--bg-elevated);color:#f0f0f2;color:var(--text-primary)}.btn-danger{background:#0000;border-color:#c0392b;border-color:var(--red-600);color:#e63946;color:var(--red-500)}.btn-danger:hover:not(:disabled){background:#e639461a}.btn-success{background:#27ae60;background:var(--green-600);border-color:#27ae60;border-color:var(--green-600);color:#fff}.btn-success:hover:not(:disabled){background:#219a52}.btn-sm{font-size:12px;padding:5px 12px}.btn-lg{font-size:16px;padding:13px 28px}.btn-icon{border-radius:6px;border-radius:var(--radius-sm);height:36px;padding:0;width:36px}.card{background:#1a1a1d;background:var(--bg-card);border:1px solid #2e2e33;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius-lg);padding:24px}.card-sm{padding:16px}.card-header{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-bottom:20px}.card-title{color:#f0f0f2;color:var(--text-primary);font-size:16px;font-weight:700}.stat-card{align-items:center;background:#1a1a1d;background:var(--bg-card);border:1px solid #2e2e33;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius-lg);display:flex;gap:16px;padding:20px 24px;transition:border-color .18s ease,box-shadow .18s ease;transition:border-color var(--transition),box-shadow var(--transition)}.stat-card:hover{border-color:#3a3a40;border-color:var(--border-light);box-shadow:0 4px 16px #00000080;box-shadow:var(--shadow)}.stat-icon{align-items:center;border-radius:10px;border-radius:var(--radius);display:flex;flex-shrink:0;font-size:22px;height:48px;justify-content:center;width:48px}.stat-icon.red{background:#e6394626}.stat-icon.green{background:#2ecc7126}.stat-icon.amber{background:#f39c1226}.stat-icon.blue{background:#3498db26}.stat-label{color:#6b6b7a;color:var(--text-muted);font-size:12px;font-weight:500;letter-spacing:.05em;margin-bottom:4px;text-transform:uppercase}.stat-value{color:#f0f0f2;color:var(--text-primary);font-family:Sora,sans-serif;font-family:var(--font-display);font-size:28px;font-weight:800}.stat-sub{color:#6b6b7a;color:var(--text-muted);font-size:12px;margin-top:2px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{color:#9999a8;color:var(--text-secondary);font-size:13px;font-weight:600}.form-control{background:#222226;background:var(--bg-elevated);border:1px solid #2e2e33;border:1px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);color:#f0f0f2;color:var(--text-primary);font-size:14px;outline:none;padding:10px 14px;transition:border-color .18s ease;transition:border-color var(--transition);width:100%}.form-control:focus{border-color:#e63946;border-color:var(--red-500);box-shadow:0 0 0 3px #e639461f}.form-control::placeholder{color:#6b6b7a;color:var(--text-muted)}.form-control option{background:#222226;background:var(--bg-elevated);color:#f0f0f2;color:var(--text-primary)}.form-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.form-grid-3{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr 1fr}.table-wrap{overflow-x:auto}table{border-collapse:collapse;font-size:14px;width:100%}thead tr{border-bottom:1px solid #2e2e33;border-bottom:1px solid var(--border)}th{color:#6b6b7a;color:var(--text-muted);font-size:11px;font-weight:600;letter-spacing:.06em;padding:10px 14px;text-align:left;text-transform:uppercase}td{border-bottom:1px solid #ffffff0a;color:#9999a8;color:var(--text-secondary);padding:12px 14px;vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:#ffffff05;color:#f0f0f2;color:var(--text-primary)}.badge{align-items:center;border-radius:20px;display:inline-flex;font-size:11px;font-weight:700;letter-spacing:.03em;padding:3px 10px;text-transform:uppercase;white-space:nowrap}.badge-red{background:#e6394626;color:#f07070}.badge-green{background:#2ecc7126;color:#5dd08a}.badge-amber{background:#f39c1226;color:#f5b754}.badge-blue{background:#3498db26;color:#6ab7e8}.badge-gray{background:#6c757d33;color:#9999a8}.badge-purple{background:#9b59b626;color:#c39bd3}.blood-chip{align-items:center;background:linear-gradient(135deg,#96261b,#c0392b);background:linear-gradient(135deg,var(--red-700),var(--red-600));border:2px solid #e63946;border:2px solid var(--red-500);border-radius:50%;color:#fff;display:inline-flex;flex-shrink:0;font-family:Sora,sans-serif;font-family:var(--font-display);font-size:12px;font-weight:800;height:40px;justify-content:center;width:40px}.blood-chip-sm{font-size:10px;height:30px;width:30px}.modal-overlay{align-items:center;animation:fadeIn .15s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.modal{animation:slideUp .2s ease;background:#1a1a1d;background:var(--bg-card);border:1px solid #3a3a40;border:1px solid var(--border-light);border-radius:24px;border-radius:var(--radius-xl);box-shadow:0 12px 40px #0009;box-shadow:var(--shadow-lg);max-height:90vh;max-width:520px;overflow-y:auto;width:100%}.modal-header{align-items:center;display:flex;justify-content:space-between;padding:24px 28px 0}.modal-title{font-size:20px;font-weight:700}.modal-body{display:flex;flex-direction:column;gap:16px;padding:20px 28px}.modal-footer{display:flex;gap:10px;justify-content:flex-end;padding:0 28px 24px}.page-header{align-items:flex-start;display:flex;gap:16px;justify-content:space-between;margin-bottom:28px}.page-header-left h1{font-size:26px;font-weight:800}.page-header-left p{font-size:14px;margin-top:4px}.empty-state,.page-header-left p{color:#6b6b7a;color:var(--text-muted)}.empty-state{padding:60px 20px;text-align:center}.empty-state .icon{font-size:48px;margin-bottom:12px}.empty-state h3{color:#9999a8;color:var(--text-secondary);font-size:18px;margin-bottom:6px}.empty-state p{font-size:14px}.urgency-critical{color:#f07070}.urgency-urgent{color:#f5b754}.urgency-normal{color:#6ab7e8}.spinner-wrap{align-items:center;display:flex;justify-content:center;padding:60px}.spinner{animation:spin .7s linear infinite;border:3px solid #2e2e33;border-top-color:#e63946;border:3px solid var(--border);border-radius:50%;border-top-color:var(--red-500);height:36px;width:36px}.tabs{border-bottom:1px solid #2e2e33;border-bottom:1px solid var(--border);display:flex;gap:4px;margin-bottom:24px}.tab{background:none;border:none;border-bottom:2px solid #0000;color:#6b6b7a;color:var(--text-muted);cursor:pointer;font-size:14px;font-weight:600;padding:10px 16px;transition:all .18s ease;transition:all var(--transition)}.tab:hover{color:#f0f0f2;color:var(--text-primary)}.tab.active{border-bottom-color:#e63946;border-bottom-color:var(--red-500);color:#f05a52;color:var(--red-400)}.grid-2{grid-gap:16px;grid-template-columns:1fr 1fr}.grid-2,.grid-3{display:grid;gap:16px}.grid-3{grid-gap:16px;grid-template-columns:1fr 1fr 1fr}.grid-4{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr)}.flex{display:flex}.flex-center{justify-content:center}.flex-between,.flex-center{align-items:center;display:flex}.flex-between{justify-content:space-between}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-24{gap:24px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.text-sm{font-size:13px}.text-xs{font-size:12px}.text-muted{color:#6b6b7a;color:var(--text-muted)}.text-secondary{color:#9999a8;color:var(--text-secondary)}.text-red{color:#f05a52;color:var(--red-400)}.text-green{color:#2ecc71;color:var(--green-500)}.text-amber{color:#f39c12;color:var(--amber-500)}.font-bold{font-weight:700}.divider{border:none;border-top:1px solid #2e2e33;border-top:1px solid var(--border);margin:20px 0}.search-bar{align-items:center;background:#222226;background:var(--bg-elevated);border:1px solid #2e2e33;border:1px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);display:flex;gap:8px;padding:0 12px;transition:border-color .18s ease;transition:border-color var(--transition);width:260px}.search-bar:focus-within{border-color:#e63946;border-color:var(--red-500)}.search-bar input{background:none;border:none;color:#f0f0f2;color:var(--text-primary);flex:1 1;font-size:14px;outline:none;padding:9px 0}.search-bar .search-icon{color:#6b6b7a;color:var(--text-muted);font-size:16px}.notif-badge{align-items:center;background:#e63946;background:var(--red-500);border:2px solid #1a1a1d;border:2px solid var(--bg-card);border-radius:50%;color:#fff;display:flex;font-size:10px;font-weight:700;height:16px;justify-content:center;position:absolute;right:-4px;top:-4px;width:16px}.landing{background:#0f0f10;background:var(--bg);min-height:100vh}.landing-hero{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:100vh;overflow:hidden;padding:80px 24px;position:relative;text-align:center}.landing-hero:before{background:radial-gradient(circle,#c0392b1f 0,#0000 70%);content:"";height:800px;left:50%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);width:800px}.hero-eyebrow{align-items:center;background:#e639461f;border:1px solid #e6394640;border-radius:20px;color:#f05a52;color:var(--red-400);display:inline-flex;font-size:12px;font-weight:700;gap:6px;letter-spacing:.08em;margin-bottom:24px;padding:6px 14px;text-transform:uppercase}.hero-title{font-size:clamp(40px,6vw,80px);font-weight:800;line-height:1.05;margin-bottom:24px;max-width:760px}.hero-title .accent{color:#e63946;color:var(--red-500)}.hero-sub{color:#9999a8;color:var(--text-secondary);font-size:18px;line-height:1.7;margin-bottom:40px;max-width:560px}.hero-cta{gap:14px}.hero-cta,.hero-stats{display:flex;flex-wrap:wrap;justify-content:center}.hero-stats{gap:48px;margin-top:80px}.hero-stat-num{color:#f0f0f2;color:var(--text-primary);font-family:Sora,sans-serif;font-family:var(--font-display);font-size:36px;font-weight:800}.hero-stat-label{color:#6b6b7a;color:var(--text-muted);font-size:13px;margin-top:2px}.features-section{margin:0 auto;max-width:1100px;padding:100px 24px}.section-label{color:#e63946;color:var(--red-500);font-size:12px;font-weight:700;letter-spacing:.1em;margin-bottom:12px;text-transform:uppercase}.section-title{font-size:clamp(28px,4vw,44px);font-weight:800;margin-bottom:48px;max-width:500px}.feature-card{background:#1a1a1d;background:var(--bg-card);border:1px solid #2e2e33;border:1px solid var(--border);border-radius:24px;border-radius:var(--radius-xl);padding:28px;transition:border-color .18s ease,transform .18s ease;transition:border-color var(--transition),transform var(--transition)}.feature-card:hover{border-color:#c0392b;border-color:var(--red-600);transform:translateY(-2px)}.feature-icon{font-size:32px;margin-bottom:14px}.feature-title{font-size:18px;font-weight:700;margin-bottom:8px}.feature-desc{color:#6b6b7a;color:var(--text-muted);font-size:14px;line-height:1.6}.auth-page{align-items:center;background:#0f0f10;background:var(--bg);display:flex;justify-content:center;min-height:100vh;padding:24px;position:relative}.auth-page:before{background:radial-gradient(circle,#c0392b14 0,#0000 70%);content:"";height:600px;pointer-events:none;position:absolute;right:0;top:0;width:600px}.auth-card{background:#1a1a1d;background:var(--bg-card);border:1px solid #2e2e33;border:1px solid var(--border);border-radius:24px;border-radius:var(--radius-xl);box-shadow:0 12px 40px #0009;box-shadow:var(--shadow-lg);max-width:460px;padding:40px;position:relative;width:100%;z-index:1}.auth-logo{margin-bottom:32px;text-align:center}.auth-logo .icon{font-size:40px}.auth-title{font-size:24px;font-weight:800;margin-bottom:6px;text-align:center}.auth-sub{color:#6b6b7a;color:var(--text-muted);font-size:14px;margin-bottom:28px;text-align:center}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-divider{align-items:center;color:#6b6b7a;color:var(--text-muted);display:flex;font-size:13px;gap:12px;margin:4px 0}.auth-divider:after,.auth-divider:before{border-top:1px solid #2e2e33;border-top:1px solid var(--border);content:"";flex:1 1}.auth-switch{color:#6b6b7a;color:var(--text-muted);font-size:14px;margin-top:20px;text-align:center}.demo-creds{background:#e639460f;border:1px solid #e639462e;border-radius:10px;border-radius:var(--radius);margin-top:4px;padding:14px 16px}.demo-creds-title{color:#f05a52;color:var(--red-400);font-size:11px;font-weight:700;letter-spacing:.06em;margin-bottom:8px;text-transform:uppercase}.demo-cred-row{align-items:center;color:#9999a8;color:var(--text-secondary);display:flex;font-size:12px;justify-content:space-between;padding:4px 0}.sidebar-footer{border-top:1px solid #2e2e33;border-top:1px solid var(--border);padding:16px 20px}.user-pill{align-items:center;border-radius:10px;border-radius:var(--radius);cursor:pointer;display:flex;gap:10px;padding:8px 10px;transition:background .18s ease;transition:background var(--transition)}.user-pill:hover{background:#222226;background:var(--bg-elevated)}.avatar{align-items:center;background:linear-gradient(135deg,#96261b,#e63946);background:linear-gradient(135deg,var(--red-700),var(--red-500));border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:13px;font-weight:700;height:32px;justify-content:center;width:32px}.user-pill-name{color:#f0f0f2;color:var(--text-primary);font-size:13px;font-weight:600}.user-pill-role{color:#6b6b7a;color:var(--text-muted);font-size:11px}@keyframes spin{to{transform:rotate(1turn)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.fade-in{animation:fadeIn .25s ease}.slide-up{animation:slideUp .25s ease}@media (max-width:900px){.sidebar{transform:translateX(-240px)}.sidebar.open{box-shadow:0 12px 40px #0009;box-shadow:var(--shadow-lg);transform:translateX(0)}.main-content{margin-left:0}.grid-3,.grid-4{grid-template-columns:1fr 1fr}}@media (max-width:600px){.page-content{padding:20px 16px}.form-grid,.form-grid-3,.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.auth-card{padding:28px 20px}}
/*# sourceMappingURL=main.70db0448.css.map*/