@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=Plus+Jakarta+Sans:wght@600;700;800&display=swap";:root{--teal:#1a9e8e;--teal-light:#e6f7f5;--teal-mid:#a8ddd7;--teal-dark:#0f6e62;--bg:#f2f7f9;--white:#fff;--text:#1a2e35;--muted:#6b8a94;--border:#d8eceb;--red:#e05252;--amber:#e09520;--green:#27ae7a;--blue:#2d7dd2}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-feature-settings:"cv02", "cv03", "cv04", "cv11";-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;overflow:hidden}nav{background:var(--white);border-bottom:1px solid var(--border);z-index:200;justify-content:space-between;align-items:center;height:60px;padding:0 36px;display:flex;position:sticky;top:0;box-shadow:0 1px 8px #00000008}.nav-logo{color:var(--teal);letter-spacing:-.02em;align-items:center;gap:8px;font-family:Plus Jakarta Sans,sans-serif;font-size:19px;font-weight:800;display:flex}.nav-logo-icon{background:var(--teal);border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.nav-logo-icon svg{fill:#fff;width:16px;height:16px}.nav-links{gap:6px;display:flex}.nav-link{color:var(--muted);cursor:pointer;letter-spacing:-.01em;background:0 0;border:none;border-radius:8px;padding:7px 16px;font-size:13.5px;font-weight:500;transition:all .18s}.nav-link:hover{background:var(--teal-light);color:var(--teal)}.nav-link.active{background:var(--teal-light);color:var(--teal);font-weight:600}.nav-right{align-items:center;gap:10px;display:flex}.nav-badge{background:var(--teal-light);color:var(--teal);letter-spacing:.01em;border-radius:20px;padding:5px 12px;font-family:Inter,sans-serif;font-size:11.5px;font-weight:600}.mobile-menu-btn{color:var(--teal);cursor:pointer;background:0 0;border:none;border-radius:6px;margin-right:12px;padding:4px 8px;font-size:24px;display:none}.mobile-menu-btn:hover{background:var(--teal-light)}.app-layout{width:100vw;height:calc(100vh - 60px);display:flex;overflow:hidden}.sidebar{background:var(--white);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:6px;width:250px;padding:24px 16px;display:flex;overflow-y:auto}.sidebar-label{letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:10px;padding:10px 12px 6px;font-size:11px;font-weight:700}.sidebar-item{cursor:pointer;color:var(--muted);letter-spacing:-.01em;border:1.5px solid #0000;border-radius:10px;align-items:center;gap:12px;padding:11px 14px;font-size:13.5px;font-weight:500;transition:all .18s;display:flex}.sidebar-item:hover{background:var(--teal-light);color:var(--teal)}.sidebar-item.active{background:var(--teal-light);color:var(--teal);border-color:var(--teal-mid);font-weight:600}.sidebar-icon{background:#f0f4f5;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;display:flex}.sidebar-item.active .sidebar-icon{background:var(--teal);color:#fff}.content{background:var(--bg);flex:1;padding:32px 40px;overflow-y:auto}.page{display:none}.page.active{animation:.3s cubic-bezier(.16,1,.3,1) fadeIn;display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-header{margin-bottom:28px}.page-title{color:var(--text);letter-spacing:-.03em;margin-bottom:6px;font-family:Plus Jakarta Sans,sans-serif;font-size:26px;font-weight:700}.page-sub{color:var(--muted);letter-spacing:-.01em;font-size:14.5px;font-weight:400;line-height:1.5}.stats-row{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.stat{background:var(--white);border:1px solid var(--border);border-radius:16px;padding:20px 22px;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 20px #00000004}.stat:hover{transform:translateY(-2px);box-shadow:0 6px 24px #00000008}.stat-val{letter-spacing:-.03em;font-family:Plus Jakarta Sans,sans-serif;font-size:30px;font-weight:800;line-height:1.2}.stat-label{color:var(--muted);margin-top:6px;font-size:12.5px;font-weight:500}.stat-change{align-items:center;gap:4px;margin-top:8px;font-size:12px;font-weight:600;display:flex}.up{color:var(--green)}.down{color:var(--red)}.card{background:var(--white);border:1px solid var(--border);border-radius:16px;margin-bottom:20px;padding:24px;box-shadow:0 4px 20px #00000004}.card-title{color:var(--text);letter-spacing:-.01em;justify-content:space-between;align-items:center;margin-bottom:18px;font-family:Plus Jakarta Sans,sans-serif;font-size:15px;font-weight:700;display:flex}.card-title-left{align-items:center;gap:10px;display:flex}.grid-2{grid-template-columns:1fr 1fr;gap:20px;display:grid}.grid-3{grid-template-columns:1fr 1fr 1fr;gap:16px;display:grid}.badge{white-space:nowrap;letter-spacing:.01em;border-radius:20px;padding:4px 10px;font-family:Inter,sans-serif;font-size:11px;font-weight:600}.badge-green{color:#15794c;background:#e6f7ef}.badge-red{color:#b32a1d;background:#fde8e8}.badge-amber{color:#a16000;background:#fef3e0}.badge-blue{color:#154c86;background:#e6f0fb}.badge-teal{background:var(--teal-light);color:var(--teal-dark)}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13.5px}thead th{color:var(--muted);text-align:left;border-bottom:2px solid var(--border);letter-spacing:.05em;text-transform:uppercase;padding:12px 14px;font-family:Inter,sans-serif;font-size:11.5px;font-weight:600}tbody td{vertical-align:middle;border-bottom:1px solid #f0f4f5;padding:14px}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:#fafcfd}.td-bold{color:var(--text);letter-spacing:-.01em;font-family:Plus Jakarta Sans,sans-serif;font-weight:700}.batch-timeline{flex-direction:column;gap:0;display:flex}.bt-step{align-items:flex-start;gap:18px;display:flex}.bt-left{flex-direction:column;flex-shrink:0;align-items:center;display:flex}.bt-dot{z-index:1;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:18px;display:flex}.bt-line{background:var(--border);width:2px;height:36px}.bt-content{flex:1;padding:6px 0 32px}.bt-title{color:var(--text);letter-spacing:-.01em;margin-bottom:4px;font-family:Inter,sans-serif;font-size:14px;font-weight:600}.bt-meta{color:var(--muted);font-size:12.5px;line-height:1.5}.bt-time{color:var(--muted);letter-spacing:.02em;margin-top:4px;font-family:Inter,sans-serif;font-size:11.5px;font-weight:500}.progress-row{flex-direction:column;gap:14px;display:flex}.prog-item{flex-direction:column;gap:6px;display:flex}.prog-header{justify-content:space-between;font-family:Inter,sans-serif;font-size:13px;display:flex}.prog-label{color:var(--text);font-weight:600}.prog-val{color:var(--teal);font-weight:700}.prog-bar{background:var(--border);border-radius:6px;height:8px;overflow:hidden}.prog-fill{background:var(--teal);border-radius:6px;height:100%;transition:width 1s cubic-bezier(.16,1,.3,1)}.alert-list{flex-direction:column;gap:10px;display:flex}.alert-item{border:1px solid;border-radius:12px;align-items:center;gap:14px;padding:14px 16px;display:flex}.alert-icon{flex-shrink:0;font-size:20px}.alert-body{flex:1}.alert-title{letter-spacing:-.01em;margin-bottom:2px;font-family:Inter,sans-serif;font-size:13.5px;font-weight:600}.alert-sub{color:var(--muted);font-size:12px;line-height:1.4}.alert-time{color:var(--muted);letter-spacing:.01em;flex-shrink:0;font-family:Inter,sans-serif;font-size:11.5px;font-weight:500}.alert-red{background:#fdf5f5;border-color:#f7d4d4}.alert-amber{background:#fefaf0;border-color:#f7e6b8}.alert-green{background:#f2fcf7;border-color:#bcebcf}.btn{cursor:pointer;letter-spacing:-.01em;border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-family:Inter,sans-serif;font-size:13.5px;font-weight:600;transition:all .2s cubic-bezier(.16,1,.3,1);display:inline-flex}.btn-primary{background:var(--teal);color:#fff;box-shadow:0 4px 12px #1a9e8e33}.btn-primary:hover{background:var(--teal-dark);transform:translateY(-1px);box-shadow:0 6px 16px #1a9e8e4d}.btn-outline{color:var(--teal);border:1.5px solid var(--teal-mid);background:0 0}.btn-outline:hover{background:var(--teal-light);border-color:var(--teal)}.btn-sm{border-radius:8px;padding:6px 14px;font-size:12px}.form-row{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;display:grid}.form-group{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.form-label{color:var(--text);letter-spacing:.02em;font-family:Inter,sans-serif;font-size:12px;font-weight:600}.form-input{border:1.5px solid var(--border);color:var(--text);background:#fafcfd;border-radius:10px;outline:none;padding:12px 14px;font-family:Inter,sans-serif;font-size:14px;transition:all .2s}.form-input:focus{border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-light);background:#fff}.form-select{border:1.5px solid var(--border);color:var(--text);cursor:pointer;background:#fafcfd;border-radius:10px;outline:none;padding:12px 14px;font-family:Inter,sans-serif;font-size:14px;transition:all .2s}.form-select:focus{border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-light);background:#fff}.qr-box{background:var(--teal-light);border:2px dashed var(--teal-mid);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:100px;height:100px;font-size:36px;display:flex}.molecule-card{border:1px solid var(--border);cursor:pointer;background:#fafcfd;border-radius:12px;align-items:center;gap:16px;margin-bottom:12px;padding:16px 18px;transition:all .2s;display:flex}.molecule-card:hover{border-color:var(--teal-mid);background:#fff;transform:translateY(-1px);box-shadow:0 4px 16px #00000005}.mol-icon{background:var(--teal-light);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:22px;display:flex}.mol-info{flex:1}.mol-name{color:var(--text);letter-spacing:-.01em;font-family:Inter,sans-serif;font-size:14px;font-weight:600}.mol-formula{color:var(--muted);margin-top:3px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:12px}.mol-status{align-items:center;gap:8px;margin-top:6px;display:flex}.map-placeholder{border:1px solid var(--teal-mid);background:linear-gradient(135deg,#e6f7f5 0%,#d0eee9 100%);border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:12px;height:240px;display:flex;position:relative;overflow:hidden}.map-dot{border-radius:50%;width:14px;height:14px;animation:2s cubic-bezier(0,0,.2,1) infinite ping;position:absolute}@keyframes ping{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.5)}}.scan-anim{border:3px solid var(--teal);border-radius:12px;flex-shrink:0;width:88px;height:88px;position:relative;overflow:hidden}.scan-line{background:var(--teal);height:2px;box-shadow:0 0 8px var(--teal);animation:2s ease-in-out infinite scanDown;position:absolute;left:0;right:0}@keyframes scanDown{0%{top:0}to{top:100%}}.scan-anim:before,.scan-anim:after{content:"";border-color:var(--teal-dark);border-style:solid;width:14px;height:14px;position:absolute}.scan-anim:before{border-width:3px 0 0 3px;top:6px;left:6px}.scan-anim:after{border-width:0 3px 3px 0;bottom:6px;right:6px}.search-bar{background:var(--white);border:1.5px solid var(--border);border-radius:12px;align-items:center;gap:12px;margin-bottom:20px;padding:12px 18px;transition:all .2s;display:flex;box-shadow:0 2px 10px #00000003}.search-bar:focus-within{border-color:var(--teal);box-shadow:0 4px 16px #1a9e8e1a}.search-bar input{color:var(--text);background:0 0;border:none;outline:none;flex:1;font-family:Inter,sans-serif;font-size:14px}.search-bar input::placeholder{color:var(--muted);font-weight:400}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--teal-mid);border-radius:6px}::-webkit-scrollbar-thumb:hover{background:var(--teal)}.notif-dot{background:var(--red);border-radius:50%;flex-shrink:0;width:8px;height:8px}.live-dot{background:var(--green);border-radius:50%;flex-shrink:0;width:8px;height:8px;animation:2s cubic-bezier(.4,0,.6,1) infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.live-label{color:var(--green);letter-spacing:.02em;align-items:center;gap:6px;font-family:Inter,sans-serif;font-size:11.5px;font-weight:600;display:flex}.indent-item{border-radius:10px;align-items:center;gap:12px;margin-bottom:8px;padding:12px;transition:all .2s;display:flex}.indent-item:hover{transform:translate(4px)}.patient-badge{background:var(--blue-light);color:var(--blue);border-radius:6px;padding:4px 8px;font-size:11px;font-weight:600}.supplier-badge{background:var(--amber-light);color:var(--amber);border-radius:6px;padding:4px 8px;font-size:11px;font-weight:600}@media (width<=1024px){.stats-row{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){body{overflow:auto}.app-layout{flex-direction:column;height:auto}nav{padding:0 16px}.nav-links{display:none}.mobile-menu-btn{display:block}.sidebar{z-index:1000;transition:left .3s cubic-bezier(.16,1,.3,1);position:fixed;top:60px;bottom:0;left:-250px;box-shadow:10px 0 30px #0000001a}.sidebar.mobile-open{left:0}.content{padding:20px 16px}.grid-2,.grid-3{grid-template-columns:1fr;gap:16px}.stats-row{grid-template-columns:1fr;gap:12px}.page-title{font-size:22px}.stat-val{font-size:24px}.card{padding:16px}.form-row{grid-template-columns:1fr;gap:0}.nav-right span{display:none}}.login-container{background:radial-gradient(circle at top left, #e6f7f5 0%, var(--bg) 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:var(--white);border:1px solid var(--border);border-radius:24px;width:100%;max-width:440px;padding:48px 40px;position:relative;overflow:hidden;box-shadow:0 20px 80px #0000000f,0 0 1px #00000005}.login-card:before{content:"";background:linear-gradient(to right, var(--teal), var(--teal-mid));height:6px;position:absolute;top:0;left:0;right:0}.login-header{text-align:center;margin-bottom:32px}.login-header h1{color:var(--teal);letter-spacing:-.04em;margin-bottom:8px;font-family:Plus Jakarta Sans,sans-serif;font-size:28px;font-weight:800}.login-header p{color:var(--muted);letter-spacing:-.01em;font-size:14.5px;font-weight:500}.login-footer{text-align:center;border-top:1px solid var(--border);margin-top:32px;padding-top:24px}.login-footer p{color:var(--muted);font-size:11.5px;font-weight:500}.map-container{background:var(--teal-light);border:1px solid var(--teal-mid);border-radius:16px;height:300px;margin-bottom:20px;position:relative;overflow:hidden}.map-node{background:var(--teal);cursor:pointer;z-index:5;border:2px solid #fff;border-radius:50%;width:12px;height:12px;transition:transform .2s;position:absolute;box-shadow:0 0 10px #1a9e8e66}.map-node:hover{transform:scale(1.3)}.map-node.active{background:var(--red);box-shadow:0 0 15px #e0525299}.map-node-label{color:var(--teal-dark);white-space:nowrap;font-size:10px;font-weight:700;position:absolute;top:-20px;left:50%;transform:translate(-50%)}.map-link{background:linear-gradient(90deg, var(--teal-mid), var(--teal));opacity:.4;transform-origin:0;z-index:1;height:2px;position:absolute}.fraud-alert{border-left:4px solid var(--red);background:#fef2f2;border-radius:8px;align-items:center;gap:12px;margin-bottom:12px;padding:12px 16px;display:flex}.fraud-alert-icon{font-size:20px}.fraud-alert-content{flex:1}.fraud-alert-title{color:#991b1b;font-size:13px;font-weight:700}.fraud-alert-sub{color:#b91c1c;font-size:12px}.animate-pulse-red{animation:2s infinite pulseRed}@keyframes pulseRed{0%{box-shadow:0 0 #e0525266}70%{box-shadow:0 0 0 10px #e0525200}to{box-shadow:0 0 #e0525200}}.animate-fade-in{animation:.4s cubic-bezier(.16,1,.3,1) fadeIn}.pipeline-track{justify-content:space-between;align-items:center;padding:20px 0;display:flex;position:relative}.pipeline-step-btn{z-index:2;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}.pipeline-step-icon{background:var(--bg);border:2px solid var(--border);border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;font-size:22px;transition:all .3s;display:flex;box-shadow:0 4px 12px #0000000d}.pipeline-step-btn.active .pipeline-step-icon{background:var(--teal);border-color:var(--teal);color:#fff;transform:scale(1.1);box-shadow:0 0 20px #38b2ac66}.pipeline-connector-line{background:var(--border);z-index:1;width:100%;height:2px;position:absolute;top:45px;left:0}.pipeline-connector-active{background:var(--teal);height:100%;transition:width .5s ease-in-out;position:absolute;top:0;left:0}.data-flow-dot{background:var(--teal);width:6px;height:6px;box-shadow:0 0 8px var(--teal);border-radius:50%;animation:3s linear infinite dataFlow;position:absolute;top:-2px}@keyframes dataFlow{0%{opacity:0;left:0}10%{opacity:1}90%{opacity:1}to{opacity:0;left:100%}}.stage-card-item{border-left:3px solid #0000;transition:all .2s}.stage-card-item:hover{border-left-color:var(--teal);transform:translate(4px);background:var(--bg)!important}
