@import "https://fonts.googleapis.com/css2?family=DM+Mono:wght@300;400;500&family=Inter:wght@400;600;700&display=swap";
:root{--bg:#0e0e10;--surface:#16161a;--surface2:#1e1e24;--surface3:#242430;--border:#2a2a35;--border-light:#353545;--accent:#5bc0be;--accent2:#6fd3cf;--accent-dim:#5bc0be14;--accent-glow:#5bc0be26;--text:#f0f0f4;--text-muted:#8888a0;--text-dim:#55556a;--danger:#ff6b6b;--danger-dim:#ff6b6b1a;--warning:#ffd166;--warning-dim:#ffd1661a;--info:#8af;--info-dim:#88aaff1a;--radius:10px;--radius-sm:6px;--radius-xs:4px}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:Inter,sans-serif;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;opacity:.4;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");position:fixed;inset:0}.app{z-index:1;min-height:100vh;display:flex;position:relative}.sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;width:230px;min-height:100vh;padding:28px 0 24px;display:flex;position:fixed;top:0;bottom:0;left:0;overflow-y:auto}.main{flex-direction:column;flex:1;min-height:100vh;margin-left:230px;display:flex}.sidebar-logo{border-bottom:1px solid var(--border);align-items:center;margin-bottom:16px;padding:12px 16px 16px;display:flex;overflow:hidden}.logo-mark{color:var(--accent);letter-spacing:-.5px;font-family:Inter,sans-serif;font-size:22px;font-weight:600;line-height:1;display:block}.logo-version{color:var(--text-dim);letter-spacing:2px;text-transform:uppercase;margin-top:4px;font-family:DM Mono,monospace;font-size:9px;display:block}.nav-group{margin-bottom:8px;padding:0 12px}.nav-group-label{letter-spacing:2px;text-transform:uppercase;color:var(--text-dim);margin-top:12px;margin-bottom:4px;padding:0 12px;font-family:DM Mono,monospace;font-size:9px}.nav-item{border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);border:1px solid #0000;align-items:center;gap:10px;margin-bottom:2px;padding:9px 12px;font-size:13px;font-weight:500;transition:all .15s;display:flex}.nav-item:hover{background:var(--accent-dim);color:var(--text)}.nav-item.active{background:var(--accent-dim);color:var(--accent);border-color:#5bc0be1f}.nav-icon{text-align:center;width:18px;font-size:14px}.sidebar-footer{border-top:1px solid var(--border);margin-top:auto;padding:16px 24px 0}.user-badge{align-items:center;gap:10px;display:flex}.user-avatar{background:var(--accent-dim);width:30px;height:30px;color:var(--accent);border:1px solid #5bc0be33;border-radius:50%;justify-content:center;align-items:center;font-family:DM Mono,monospace;font-size:11px;font-weight:500;display:flex}.user-name{color:#fff;font-size:12px;font-weight:700}.user-role{color:var(--text-muted);font-family:DM Mono,monospace;font-size:10px}.topbar{border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:10;background:#0e0e10d9;justify-content:space-between;align-items:center;padding:18px 36px;display:flex;position:sticky;top:0}.page-title{color:var(--text);letter-spacing:-.3px;font-family:Inter,sans-serif;font-size:21px;font-weight:700}.topbar-actions{align-items:center;gap:10px;display:flex}.badge-pill{background:var(--accent-dim);color:var(--accent2);letter-spacing:.5px;border:1px solid #5bc0be26;border-radius:20px;padding:4px 10px;font-family:DM Mono,monospace;font-size:10px}.content{flex:1;padding:28px 36px}.page{animation:.2s fadeIn;display:none}.page.active{display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.btn{border-radius:var(--radius-sm);cursor:pointer;border:none;align-items:center;gap:7px;padding:8px 16px;font-family:Inter,sans-serif;font-size:13px;font-weight:600;text-decoration:none;transition:all .15s;display:inline-flex}.btn-primary{background:var(--accent);color:#0e1a12}.btn-primary:hover{background:var(--accent2);transform:translateY(-1px)}.btn-ghost{color:var(--text-muted);border:1px solid var(--border);background:0 0}.btn-ghost:hover{border-color:var(--border-light);color:var(--text);background:var(--surface2)}.btn-danger{color:var(--danger);background:0 0;border:1px solid #ff6b6b40}.btn-danger:hover{background:var(--danger-dim)}.btn-warning{color:var(--warning);background:0 0;border:1px solid #ffd16640}.btn-warning:hover{background:var(--warning-dim)}.btn-sm{padding:5px 11px;font-size:12px}.btn-xs{padding:3px 8px;font-size:11px}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px}.card-sm{padding:16px 20px}.card-title{color:var(--text);align-items:center;gap:10px;margin-bottom:18px;font-family:Inter,sans-serif;font-size:17px;font-weight:600;display:flex}.card-title .badge{border-radius:var(--radius-xs);background:var(--accent-dim);color:var(--accent2);letter-spacing:1px;padding:3px 8px;font-family:DM Mono,monospace;font-size:9px}.stats-row{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;transition:border-color .2s;position:relative;overflow:hidden}.stat-card:hover{border-color:var(--border-light)}.stat-card:after{content:"";background:linear-gradient(90deg,var(--accent),transparent);opacity:.4;height:2px;position:absolute;top:0;left:0;right:0}.stat-label{letter-spacing:2px;text-transform:uppercase;color:var(--text-dim);margin-bottom:8px;font-family:DM Mono,monospace;font-size:9px}.stat-value{color:var(--text);font-family:Inter,sans-serif;font-size:30px;font-weight:700;line-height:1}.stat-sub{color:var(--text-muted);margin-top:5px;font-size:11px}.section-header{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.section-title{color:var(--text);font-family:Inter,sans-serif;font-size:18px;font-weight:700}.form-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.form-grid-3{grid-template-columns:1fr 1fr 1fr;gap:14px;display:grid}.form-grid-4{grid-template-columns:1fr 1fr 1fr 1fr;gap:14px;display:grid}.form-full{grid-column:1/-1}.field{flex-direction:column;gap:5px;display:flex}.field-label{letter-spacing:1.5px;text-transform:uppercase;color:var(--text-muted);font-family:DM Mono,monospace;font-size:10px}.field-label .req{color:var(--accent2);margin-left:2px}.field-hint{color:var(--text-dim);margin-top:2px;font-size:11px}input,select,textarea{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);outline:none;width:100%;padding:9px 12px;font-family:Inter,sans-serif;font-size:13.5px;transition:border-color .15s,box-shadow .15s}input:focus,select:focus,textarea:focus{border-color:#5bc0be4d;box-shadow:0 0 0 3px #5bc0be0f}input[readonly]{opacity:.5;cursor:default}select{cursor:pointer}select option{background:#1e1e24}.compound-blocks{flex-direction:column;gap:14px;display:flex}.compound-block{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:18px;transition:border-color .2s;animation:.15s fadeIn}.compound-block:hover{border-color:var(--border-light)}.compound-block-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.compound-block-num{letter-spacing:2px;text-transform:uppercase;color:var(--accent2);background:var(--accent-dim);border-radius:var(--radius-xs);padding:3px 9px;font-family:DM Mono,monospace;font-size:10px}.add-block-btn{border:1px dashed var(--border-light);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;background:0 0;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:14px;padding:10px 16px;font-family:Inter,sans-serif;font-size:13px;transition:all .15s;display:flex}.add-block-btn:hover{color:var(--accent);background:var(--accent-dim);border-color:#5bc0be40}.lot-info-panel{background:var(--surface3);border:1px solid var(--border);border-radius:var(--radius-sm);margin-top:8px;padding:10px 14px;display:none}.lot-info-panel.visible{flex-wrap:wrap;gap:20px;display:flex}.lot-info-panel.expired{background:#ff6b6b0d;border-color:#ff6b6b4d}.lot-info-item{flex-direction:column;gap:2px;display:flex}.lot-info-key{letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim);font-family:DM Mono,monospace;font-size:9px}.lot-info-val{color:var(--text);font-size:13px;font-weight:600}.lot-info-val.warn{color:var(--warning)}.lot-info-val.danger{color:var(--danger)}.lot-info-val.ok{color:var(--accent2)}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}#records-table-body table{min-width:1050px}#records-table-body{overflow-x:auto}#patients-table-body table{min-width:860px}#patients-table-body{overflow-x:auto}#users-table-body table{min-width:660px}#users-table-body{overflow-x:auto}.table-toolbar{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:10px;padding:14px 18px;display:flex}.table-toolbar input,.table-toolbar select{max-width:220px;padding:7px 11px;font-size:13px}table{border-collapse:collapse;width:100%}thead tr{border-bottom:1px solid var(--border)}th{letter-spacing:2px;text-transform:uppercase;color:var(--text-dim);text-align:left;white-space:nowrap;padding:10px 14px;font-family:DM Mono,monospace;font-size:9px;font-weight:400}td{color:var(--text);border-bottom:1px solid var(--border);vertical-align:middle;padding:11px 14px;font-size:13px}tr:last-child td{border-bottom:none}tbody tr{transition:background .1s}tbody tr:hover{background:var(--accent-dim)}.td-mono{color:var(--text-muted);font-family:DM Mono,monospace;font-size:11px}.td-bold{font-weight:600}.tag{border-radius:var(--radius-xs);white-space:nowrap;align-items:center;padding:2px 8px;font-family:DM Mono,monospace;font-size:11px;font-weight:500;display:inline-flex}.tag-green{color:var(--accent2);background:#6fd3cf1a;border:1px solid #6fd3cf26}.tag-blue{background:var(--info-dim);color:var(--info);border:1px solid #88aaff26}.tag-red{background:var(--danger-dim);color:var(--danger);border:1px solid #ff6b6b33}.tag-yellow{background:var(--warning-dim);color:var(--warning);border:1px solid #ffd16633}.tag-dim{background:var(--surface2);color:var(--text-dim);border:1px solid var(--border)}.empty-state{text-align:center;padding:50px 20px}.empty-icon{opacity:.4;margin-bottom:10px;font-size:32px}.empty-title{color:var(--text-muted);margin-bottom:5px;font-family:Inter,sans-serif;font-size:17px;font-weight:600}.empty-sub{color:var(--text-dim);font-size:13px}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#000000a6;justify-content:center;align-items:center;padding:20px;display:none;position:fixed;inset:0}.modal-overlay.open{display:flex}.modal{background:var(--surface);border:1px solid var(--border);border-radius:14px;width:100%;max-width:560px;max-height:90vh;padding:28px;overflow-y:auto;box-shadow:0 24px 64px #00000080}.modal-lg{max-width:720px}.modal-title{margin-bottom:6px;font-family:Inter,sans-serif;font-size:20px;font-weight:700}.modal-sub{color:var(--text-muted);margin-bottom:22px;font-size:13px;line-height:1.5}.modal-actions{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;margin-top:22px;padding-top:18px;display:flex}.alert{border-radius:var(--radius-sm);align-items:flex-start;gap:10px;margin-bottom:14px;padding:12px 16px;font-size:13px;display:flex}.alert-icon{flex-shrink:0;margin-top:1px;font-size:15px}.alert-warning{background:var(--warning-dim);color:var(--warning);border:1px solid #ffd16633}.alert-danger{background:var(--danger-dim);color:var(--danger);border:1px solid #ff6b6b33}.alert-info{background:var(--info-dim);color:var(--info);border:1px solid #8af3}.alert-success{background:var(--accent-dim);color:var(--accent2);border:1px solid #5bc0be33}.toast{background:var(--surface);border-radius:var(--radius);opacity:0;z-index:9999;border:1px solid #5bc0be33;align-items:center;gap:10px;min-width:260px;padding:12px 18px;transition:all .3s cubic-bezier(.34,1.56,.64,1);display:flex;position:fixed;bottom:24px;right:24px;transform:translateY(80px);box-shadow:0 8px 32px #0006}.toast.show{opacity:1;transform:translateY(0)}.toast-icon{font-size:16px}.toast-msg{color:var(--text);font-size:13px;font-weight:500}#login-page{background:var(--bg);z-index:1000;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:380px;padding:40px;box-shadow:0 32px 80px #00000080}.login-logo{justify-content:center;align-items:center;margin-bottom:28px;display:flex}.login-roles{flex-direction:column;gap:10px;display:flex}.role-btn{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface2);cursor:pointer;text-align:left;align-items:center;gap:14px;padding:13px 16px;transition:all .15s;display:flex}.role-btn:hover{background:var(--accent-dim);border-color:#5bc0be40}.role-icon{font-size:20px}.role-name{color:var(--text);font-size:13px;font-weight:600}.role-desc{color:var(--text-dim);margin-top:1px;font-size:11px}.divider{background:var(--border);height:1px;margin:20px 0}.tabs{border-bottom:1px solid var(--border);gap:4px;margin-bottom:22px;display:flex}.tab{color:var(--text-muted);cursor:pointer;border-bottom:2px solid #0000;margin-bottom:-1px;padding:9px 16px;font-size:13px;font-weight:600;transition:all .15s}.tab:hover{color:var(--text)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.autocomplete-wrap{position:relative}.autocomplete-dropdown{background:var(--surface2);border:1px solid var(--border-light);border-radius:var(--radius-sm);z-index:50;max-height:200px;margin-top:2px;display:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 8px 24px #0006}.autocomplete-item{cursor:pointer;border-bottom:1px solid var(--border);padding:9px 12px;font-size:13px;transition:background .1s}.autocomplete-item:last-child{border-bottom:none}.autocomplete-item:hover{background:var(--accent-dim)}.autocomplete-item-name{font-weight:600}.autocomplete-item-meta{color:var(--text-dim);margin-top:2px;font-family:DM Mono,monospace;font-size:10px}.audit-entry{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:8px;padding:12px 16px}.audit-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.audit-action{font-size:12px;font-weight:600}.audit-time{color:var(--text-dim);font-family:DM Mono,monospace;font-size:10px}.audit-diff{color:var(--text-muted);background:var(--surface3);border-radius:var(--radius-xs);white-space:pre-wrap;word-break:break-all;margin-top:6px;padding:8px 10px;font-family:DM Mono,monospace;font-size:11px}.inv-bar-wrap{background:var(--surface3);border-radius:3px;width:100px;height:6px;overflow:hidden}.inv-bar{border-radius:3px;height:100%;transition:width .3s}.inv-bar.ok{background:var(--accent2)}.inv-bar.low{background:var(--warning)}.inv-bar.critical{background:var(--danger)}.report-box{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;padding:20px}.report-box-title{letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);margin-bottom:14px;font-family:DM Mono,monospace;font-size:10px}.finalized-badge{color:var(--accent2);background:#5bc0be14;border:1px solid #5bc0be26;border-radius:20px;align-items:center;gap:5px;padding:3px 9px;font-family:DM Mono,monospace;font-size:10px;display:inline-flex}.amended-badge{color:var(--warning);background:#ffd1661a;border:1px solid #ffd16640;border-radius:20px;align-items:center;gap:5px;padding:3px 9px;font-family:DM Mono,monospace;font-size:10px;display:inline-flex}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.mobile-topbar-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:20px;display:none}.mobile-drawer-overlay{z-index:300;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;display:none;position:fixed;inset:0}.mobile-drawer-overlay.open{display:block}.mobile-drawer{background:var(--surface);z-index:301;width:260px;padding:24px 0;transition:transform .25s;position:fixed;top:0;bottom:0;left:0;overflow-y:auto;transform:translate(-100%)}.mobile-drawer.open{transform:translate(0)}.bottom-nav{background:var(--surface);border-top:1px solid var(--border);z-index:100;padding:0 8px;display:none;position:fixed;bottom:0;left:0;right:0}.bottom-nav-inner{justify-content:space-around;align-items:center;height:56px;display:flex}.bnav-item{border-radius:var(--radius-sm);cursor:pointer;color:var(--text-dim);background:0 0;border:none;flex-direction:column;align-items:center;gap:2px;padding:6px 10px;font-family:Inter,sans-serif;font-size:10px;font-weight:500;transition:all .15s;display:flex}.bnav-item:hover,.bnav-item.active{color:var(--accent)}.bnav-icon{font-size:18px}@media (max-width:900px){.sidebar{display:none}.main{margin-left:0}.stats-row,.form-grid-4{grid-template-columns:1fr 1fr}.mobile-topbar-btn,.bottom-nav{display:block}.content{padding:20px 16px 72px}}@media (max-width:480px){.form-grid{grid-template-columns:1fr}.compound-block{padding:12px}}.app-footer{background:var(--surface);border-top:1px solid var(--border);color:var(--text-dim);justify-content:space-between;align-items:center;margin-left:230px;padding:12px 36px;font-size:12px;display:flex}.app-footer-version{color:var(--text-dim);font-family:DM Mono,monospace;font-size:11px}.app-footer-link{color:var(--text-muted);font-weight:500;text-decoration:none}.app-footer-link:hover{color:var(--accent)}@media (max-width:900px){.app-footer{margin-left:0;padding:12px 20px}}.file-upload-zone{border:2px dashed var(--border-light);border-radius:var(--radius);text-align:center;cursor:pointer;background:var(--surface2);padding:32px 20px;transition:border-color .2s,background .2s}.file-upload-zone:hover,.file-upload-zone.dragover{border-color:var(--accent2);background:var(--accent-dim)}.file-upload-zone .upload-icon{opacity:.6;margin-bottom:10px;font-size:32px}.file-upload-zone .upload-title{color:var(--text);margin-bottom:4px;font-size:14px;font-weight:600}.file-upload-zone .upload-sub{color:var(--text-dim);font-size:12px}.file-upload-zone .upload-file-name{color:var(--accent2);background:var(--accent-dim);border-radius:var(--radius-xs);margin-top:10px;padding:4px 10px;font-family:DM Mono,monospace;font-size:11px;display:inline-block}.recv-autofill{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:14px;padding:14px;display:none}.recv-autofill.visible{display:block}.recv-autofill-label{letter-spacing:2px;text-transform:uppercase;color:var(--text-dim);margin-bottom:10px;font-family:DM Mono,monospace;font-size:9px}
