:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#1d2a3f;background:#edf3ff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--app-height: 100vh;--bottom-nav-height: 74px}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:var(--app-height);background:#edf3ff;overscroll-behavior-y:none;touch-action:pan-y pinch-zoom;-webkit-tap-highlight-color:transparent;-webkit-text-size-adjust:100%}html,body,#root{width:100%;overflow-x:hidden}#root{min-height:var(--app-height)}button,input,select,textarea{font:inherit;-webkit-tap-highlight-color:transparent}button{border:0;cursor:pointer;touch-action:manipulation}button:disabled{cursor:not-allowed;opacity:.7}code{padding:2px 6px;background:#eef5ff;border-radius:6px}.appShell{display:flex;min-height:var(--app-height);background:#edf3ff}.sidebar{position:sticky;top:0;display:flex;flex-direction:column;width:280px;height:100vh;background:#fff;border-right:1px solid #e7eef9;box-shadow:0 0 0 1px #d7e2f366;z-index:5}.brand{display:flex;gap:16px;align-items:center;padding:31px 22px;border-bottom:1px solid #edf2fa}.brandIcon{display:grid;place-items:center;width:56px;height:56px;color:#fff;background:#e53946;border-radius:12px;box-shadow:0 12px 24px #2f73f640}.brand h1,.brand p,.topBar h1,.topBar p,.panel h2,.panel h3,.protocolForm h2,.protocolForm p{margin:0}.brand h1{font-size:24px;line-height:1.1}.brand p{margin-top:6px;color:#9aa9bf;font-size:16px;font-weight:650}.navList{display:grid;gap:16px;padding:24px 14px}.navItem{display:flex;align-items:center;gap:16px;width:100%;min-height:66px;padding:0 18px;color:#6b7d96;background:transparent;border-radius:8px;font-size:18px;font-weight:760;text-align:left}.navItem.active{color:#e53946;background:#eef5ff}.navIcon{display:grid;place-items:center;flex:0 0 42px;width:42px;height:42px;color:#8ea0b8;background:#f8fbff;border-radius:8px}.navItem.active .navIcon{color:#e53946;background:#deebff}.profile{display:flex;gap:14px;align-items:center;margin-top:auto;padding:22px;border-top:1px solid #edf2fa}.avatar{display:grid;place-items:center;width:44px;height:44px;color:#fff;background:#d84a55;border-radius:8px;font-weight:800}.profile strong,.profile span{display:block}.profile strong{max-width:178px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile span{margin-top:3px;color:#94a3b8;font-weight:650}.mainContent{flex:1;min-width:0;padding:40px clamp(22px,3vw,42px) 54px}.topBar{display:flex;gap:24px;align-items:center;justify-content:space-between;margin-bottom:34px}.topBar h1{color:#1c2840;font-size:32px;line-height:1.1}.topBar p{margin-top:11px;color:#74839a;font-size:18px;font-weight:720}.topActions{display:flex;gap:16px;align-items:center}.primaryButton,.secondaryButton,.dangerButton{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:58px;padding:0 25px;border-radius:8px;font-size:18px;font-weight:820;white-space:nowrap}.primaryButton{color:#fff;background:#e53946;box-shadow:0 12px 24px #2f73f638}.secondaryButton{color:#e53946;background:#eef5ff}.dangerButton{color:#d92d3d;background:#fff0f1}.signOutButton{min-height:50px;font-size:15px}.iconButton{display:grid;place-items:center;width:46px;height:46px;color:#e53946;background:#eef5ff;border-radius:8px}.iconButton.ghost{color:#708199;background:#f7faff}.mobileBrandMark{display:none}.searchBox{display:flex;align-items:center;gap:10px;width:250px;min-height:50px;padding:0 16px;color:#8fa0b8;background:#ffffffb8;border:1px solid #e5edf9;border-radius:8px}.searchBox input{width:100%;min-width:0;color:#1d2a3f;background:transparent;border:0;outline:0}.searchBox input::placeholder{color:#96a7be}.statsGrid{display:grid;grid-template-columns:repeat(4,minmax(170px,1fr));gap:20px}.statsGrid.compact{grid-template-columns:repeat(2,minmax(220px,1fr));max-width:700px}.statCard{min-width:0;min-height:172px;padding:28px;background:#fff;border-radius:8px;box-shadow:0 1px #d4dff1b3}.statIcon{display:grid;place-items:center;width:58px;height:58px;border-radius:8px}.statIcon.blue,.rowIcon.review{color:#e53946;background:#eef5ff}.statIcon.orange,.rowIcon.active{color:#fb9708;background:#fff8e8}.statIcon.red{color:#fb4c4f;background:#fff0ef}.statIcon.green,.rowIcon.completed{color:#18bf77;background:#ecfff7}.statValue{display:block;margin-top:26px;font-size:38px;line-height:1}.statValue.blue{color:#e53946}.statValue.orange{color:#f4950b}.statValue.red{color:#fb4c4f}.statValue.green{color:#18b973}.statCard span{display:block;margin-top:14px;color:#94a3b8;font-size:16px;font-weight:730}.contentGrid{display:grid;grid-template-columns:minmax(420px,1.35fr) minmax(330px,.95fr);gap:24px;margin-top:28px}.contentGrid.single{grid-template-columns:minmax(0,1fr)}.contentGrid.flush{margin-top:0}.panel{min-width:0;overflow:hidden;background:#fff;border-radius:8px;box-shadow:0 1px #d4dff1b3}.panelHeader{display:flex;align-items:center;justify-content:space-between;min-height:86px;padding:0 32px;border-bottom:1px solid #edf2fa}.panelHeader h2{color:#1c2840;font-size:22px}.panelHeader button{color:#e53946;background:transparent;font-weight:820}.emptyState{display:grid;justify-items:center;gap:14px;min-height:360px;padding:54px 28px;color:#8da0b8;text-align:center}.emptyIcon{display:grid;place-items:center;width:72px;height:72px;color:#e53946;background:#eef5ff;border-radius:8px}.emptyState h3{color:#1c2840;font-size:22px}.emptyState p{max-width:360px;margin:0 0 10px;font-size:16px;font-weight:680}.notice{margin-bottom:18px;padding:14px 16px;border-radius:8px;font-weight:720}.stockAlert{display:flex;gap:12px;align-items:flex-start;margin-bottom:18px;padding:14px 16px;color:#b4232e;background:#fff0f1;border:1px solid #ffd6db;border-radius:8px;font-weight:760}.stockAlert p{margin:3px 0 0;color:#8f5360;font-size:14px;font-weight:680}.errorNotice,.formError{color:#d92d3d;background:#fff0f1}.protocolRow{display:grid;grid-template-columns:58px 1fr;gap:22px;align-items:center;width:100%;min-height:100px;padding:18px 32px;color:inherit;background:#fff;border-bottom:1px solid #f1f4f9;text-align:left}.protocolRow:hover{background:#f8fbff}.rowIcon{display:grid;place-items:center;width:58px;height:58px;border-radius:8px}.protocolRow h3{color:#1c2840;font-size:20px}.protocolRow p{margin:8px 0 0;color:#94a3b8;font-size:16px;font-weight:680}.rowTitle{display:flex;gap:10px;align-items:center;min-width:0}.rowTitle h3{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.severityBadge{flex:0 0 auto;padding:5px 9px;border-radius:999px;font-size:12px;font-weight:850}.severityBadge.low{color:#16785a;background:#eafff5}.severityBadge.medium{color:#9a6400;background:#fff5d9}.severityBadge.high{color:#b4232e;background:#fff0f1}.severityBadge.emergency{color:#fff;background:#d92d3d}.protocolRow>div:last-child,.supplyTop h3{min-width:0}.summaryStrip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:18px}.summaryStrip div{min-width:0;padding:18px 20px;background:#fff;border:1px solid #e4edf9;border-radius:8px}.summaryStrip span{display:block;margin-bottom:8px;color:#8a9bb2;font-size:13px;font-weight:780}.summaryStrip strong{display:block;color:#1c2840;font-size:17px;overflow-wrap:anywhere}.supplyRow{padding:20px 32px;border-bottom:1px solid #f1f4f9}.supplyTop{display:flex;gap:16px;align-items:center;justify-content:space-between}.supplyTop h3{display:flex;gap:8px;align-items:center;color:#1c2840;font-size:18px}.supplyTop span{color:#95a5bc;font-size:16px;font-weight:790;white-space:nowrap}.warningText{color:#fb4c4f!important}.meter{height:8px;margin-top:13px;overflow:hidden;background:#edf2f8;border-radius:999px}.meter span{display:block;height:100%;background:#e53946;border-radius:inherit}.meter span.danger{background:#fb4c4f}.formDrawer{position:fixed;inset:0 0 0 auto;width:min(560px,100vw);height:var(--app-height);background:#fff;box-shadow:-24px 0 70px #202d4533;transform:translate(105%);transition:transform .24s ease;z-index:30}.formDrawer.open{transform:translate(0)}.scrim{position:fixed;inset:0;background:#1d2a3f52;z-index:20}.protocolForm,.protocolDetail{display:flex;flex-direction:column;gap:20px;height:100%;padding:28px;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.formHeader{display:flex;align-items:flex-start;justify-content:space-between;gap:20px}.eyebrow{display:block;margin-bottom:7px;color:#e53946;font-size:13px;font-weight:860;letter-spacing:0;text-transform:uppercase}.protocolForm h2{font-size:28px;line-height:1.1}.formGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.formGrid.small{margin-top:2px}.protocolForm label{display:grid;gap:8px;color:#66778e;font-size:14px;font-weight:780}.protocolForm input,.protocolForm select,.protocolForm textarea{width:100%;min-height:48px;color:#1d2a3f;font-size:16px;background:#f8fbff;border:1px solid #e4edf9;border-radius:8px;outline:0}.protocolForm input.invalid,.protocolForm select.invalid,.protocolForm textarea.invalid{border-color:#fb4c4f;box-shadow:0 0 0 3px #fb4c4f14}.fieldError{color:#d92d3d;font-size:12px;font-weight:760}.protocolForm input,.protocolForm select{padding:0 14px}.protocolForm textarea{min-height:102px;padding:13px 14px;resize:vertical}.checkSection{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding:14px;background:#f8fbff;border:1px solid #e4edf9;border-radius:8px}.checkSection label{display:flex;gap:10px;align-items:center;color:#1d2a3f;font-size:14px;font-weight:760}.checkSection input{width:18px;min-height:18px;accent-color:#e53946}.wideField{margin-top:2px}.formActions{position:sticky;bottom:0;display:flex;gap:12px;justify-content:flex-end;margin-top:auto;padding:12px 0 0;background:#fff}.formError{margin:0;padding:12px 14px;border-radius:8px;font-size:14px;font-weight:760}.detailGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.detailTabs{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;padding:6px;background:#fff5f6;border:1px solid #ffd6db;border-radius:8px}.detailTabs button{min-height:44px;color:#7f5260;background:transparent;border-radius:8px;font-weight:820}.detailTabs button.active{color:#fff;background:#e53946;box-shadow:0 10px 22px #e539462e}.detailItem,.detailBlock{display:grid;gap:7px;padding:16px;background:#f8fbff;border:1px solid #e4edf9;border-radius:8px}.detailItem span,.detailBlock span{color:#66778e;font-size:13px;font-weight:820}.detailItem strong{min-width:0;color:#1d2a3f;overflow-wrap:anywhere}.detailBlock p{margin:0;color:#1d2a3f;font-weight:680;line-height:1.5;white-space:pre-wrap}.managementPanel{padding-bottom:24px}.inlineForm,.materialForm{display:grid;gap:12px;padding:20px 32px;border-bottom:1px solid #edf2fa}.inlineForm{grid-template-columns:minmax(0,1fr) auto;align-items:end}.inlineForm label{display:grid;gap:8px;color:#66778e;font-size:14px;font-weight:780}.inlineForm input,.materialForm input,.usageRow input{width:100%;min-height:48px;padding:0 14px;color:#1d2a3f;background:#f8fbff;border:1px solid #e4edf9;border-radius:8px;outline:0}.inlineError{margin:12px 32px 0;color:#d92d3d;font-size:14px;font-weight:760}.bagGrid{display:grid;gap:18px;padding:24px 32px}.bagCard{display:grid;gap:16px;padding:18px;background:#f8fbff;border:1px solid #e4edf9;border-radius:8px}.bagHeader,.materialRow,.classRow,.usageBoxHeader{display:flex;gap:14px;align-items:center;justify-content:space-between}.bagHeader h3,.bagHeader span,.materialRow strong,.materialRow span,.classRow strong,.usageBoxHeader span,.usageBoxHeader strong{display:block}.bagHeader h3{margin:0;color:#1c2840;font-size:20px}.bagHeader span,.materialRow span,.mutedLine,.usageBox p,.usageRow small{color:#8a9bb2;font-weight:680}.materialForm{grid-template-columns:minmax(140px,1fr) 110px 100px auto;padding:0;border-bottom:0}.materialList,.classList,.usageList{display:grid;gap:10px}.materialRow,.classRow{min-height:56px;padding:12px 14px;background:#fff;border:1px solid #e8effa;border-radius:8px}.materialRow.lowStock{border-color:#ffd6db;background:#fff8f9}.classList{padding:24px 32px}.compactEmpty{min-height:240px}.usageBox{display:grid;gap:14px;padding:16px;background:#f8fbff;border:1px solid #e4edf9;border-radius:8px}.usageBoxHeader span{color:#66778e;font-size:14px;font-weight:820}.usageBoxHeader strong{color:#1d2a3f}.usageRow{display:grid;grid-template-columns:minmax(0,1fr) 94px;gap:12px;align-items:center;padding:12px;background:#fff;border:1px solid #e8effa;border-radius:8px}.usageRow>span{display:grid;gap:4px}.usageRow input{min-height:44px}.centerScreen{display:grid;place-items:center;min-height:var(--app-height);padding:24px;background:#edf3ff}.loginPanel,.setupPanel{display:grid;gap:18px;width:min(430px,100%);padding:32px;background:#fff;border-radius:8px;box-shadow:0 1px #d4dff1b3,0 24px 70px #202d451a}.loginPanel h1,.setupPanel h1,.loginPanel p,.setupPanel p{margin:0}.loginPanel h1,.setupPanel h1{color:#1c2840;font-size:30px}.loginPanel p,.setupPanel p{color:#71829a;font-weight:680}.loginPanel label{display:grid;gap:8px;color:#66778e;font-size:14px;font-weight:780}.loginPanel input{width:100%;min-height:50px;padding:0 14px;color:#1d2a3f;background:#f8fbff;border:1px solid #e4edf9;border-radius:8px;outline:0}.mobileNav{display:none}@media(max-width:1180px){.sidebar{width:230px}.statsGrid{grid-template-columns:repeat(2,minmax(180px,1fr))}.statsGrid.compact{max-width:none}.contentGrid{grid-template-columns:1fr}.searchBox{display:none}}@media(max-width:780px){.appShell{display:block;min-height:var(--app-height);padding-bottom:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom));overflow:visible}.sidebar{display:none}.mainContent{padding:calc(14px + env(safe-area-inset-top)) 14px calc(var(--bottom-nav-height) + 22px + env(safe-area-inset-bottom));overflow:visible}.topBar{display:grid;grid-template-columns:42px minmax(0,1fr) 48px;align-items:center;gap:11px;margin:0 0 16px}.mobileBrandMark{display:grid;place-items:center;width:42px;height:42px;color:#fff;background:#e53946;border-radius:8px;box-shadow:0 10px 24px #2f73f638}.topBar h1{font-size:23px}.topBar p{margin-top:4px;font-size:14px}.topActions{justify-self:end;margin-left:0}.topActions .primaryButton{width:48px;min-height:48px;padding:0;border-radius:12px}.topActions .secondaryButton{display:none}.topActions .primaryButton span,.topActions .primaryButton{font-size:0}.statsGrid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.summaryStrip{grid-template-columns:1fr;gap:10px;margin-top:12px}.summaryStrip div{padding:14px 16px}.statCard{min-height:112px;padding:14px}.statIcon{width:40px;height:40px}.statValue{margin-top:13px;font-size:28px}.statCard span{font-size:14px}.contentGrid{gap:16px;margin-top:14px}.panelHeader{min-height:60px;padding:0 16px}.panelHeader h2{font-size:19px}.emptyState{min-height:260px;padding:34px 18px}.emptyIcon{width:58px;height:58px}.emptyState h3{font-size:20px}.protocolRow{grid-template-columns:42px 1fr;gap:12px;min-height:78px;padding:14px 16px}.rowIcon{width:42px;height:42px}.protocolRow h3,.supplyTop h3{font-size:16px}.rowTitle{align-items:flex-start;flex-direction:column;gap:6px}.protocolRow p,.supplyTop span{font-size:14px}.supplyRow{padding:17px 18px}.formDrawer{width:100%;height:var(--app-height);padding-top:0;box-shadow:none;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.protocolForm,.protocolDetail{min-height:var(--app-height);height:auto;overflow:visible;padding:calc(16px + env(safe-area-inset-top)) 14px calc(22px + env(safe-area-inset-bottom))}.protocolForm .formHeader,.protocolDetail .formHeader{position:sticky;top:0;padding-bottom:10px;background:#fff;z-index:2}.formGrid,.detailGrid,.checkSection{grid-template-columns:1fr}.formActions{display:grid;grid-template-columns:1fr 1fr;position:static;bottom:auto;margin-right:-14px;margin-bottom:calc(-22px - env(safe-area-inset-bottom));margin-left:-14px;padding:12px 14px calc(12px + env(safe-area-inset-bottom));border-top:1px solid #edf2fa;box-shadow:none}.protocolDetail .formActions{grid-template-columns:repeat(3,minmax(0,1fr))}.primaryButton,.secondaryButton,.dangerButton{min-height:52px;padding:0 14px;font-size:15px}.mobileNav{position:fixed;right:0;bottom:0;left:0;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;padding:8px 10px calc(8px + env(safe-area-inset-bottom));background:#fff;border-top:1px solid #dfe8f5;box-shadow:0 -12px 34px #202d4524;z-index:15;transform:translateZ(0)}.mobileNav button{display:grid;grid-template-columns:1fr;place-items:center;justify-content:center;gap:3px;min-height:50px;color:#7f90a8;background:transparent;border-radius:10px;font-size:10px;font-weight:790}.mobileNav svg{width:21px;height:21px}.mobileNav span{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inlineForm{grid-template-columns:1fr;padding:18px 16px}.bagGrid,.classList{padding:18px 16px}.materialForm{grid-template-columns:1fr 88px 78px}.materialForm .secondaryButton{grid-column:1 / -1}.usageRow{grid-template-columns:1fr 82px}.mobileNav button.active{color:#e53946;background:#eef5ff}.centerScreen{width:100vw;max-width:100vw;min-height:var(--app-height);padding:calc(22px + env(safe-area-inset-top)) 16px calc(22px + env(safe-area-inset-bottom));overflow-y:auto;overscroll-behavior:contain}.loginPanel,.setupPanel{justify-self:center;width:calc(100vw - 32px);max-width:360px;padding:26px 22px}}@media(display-mode:standalone)and (max-width:780px){body{-webkit-user-select:none;user-select:none;background:#edf3ff}input,select,textarea{-webkit-user-select:text;user-select:text}.mainContent{padding-top:0}.topBar{position:sticky;top:0;z-index:12;margin:0 -14px 16px;padding:calc(12px + env(safe-area-inset-top)) 14px 12px;background:#edf3ff;border-bottom:1px solid #dfe8f5}.mobileNav{background:#fff}}@media(max-width:430px){.topActions{width:auto}.statsGrid{grid-template-columns:1fr 1fr}.statCard{padding:13px}.protocolForm h2{font-size:24px}.detailItem,.detailBlock{padding:14px}}
