:root{font-synthesis:none;letter-spacing:0;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Aptos,Segoe UI,Noto Sans TC,sans-serif;font-size:16px;line-height:1.5}*{box-sizing:border-box}body{min-width:320px;margin:0;overflow:hidden}#root{height:100svh}:root{color:#1d1b20;font-synthesis:none;text-rendering:geometricprecision}button,input,textarea{letter-spacing:0}.login-shell{color:#1d1b20;background:linear-gradient(90deg,#536dfe0f 1px,#0000 1px) 0 0/32px 32px,linear-gradient(#fffbff 0%,#f6f7ff 100%);align-items:center;min-height:100svh;padding:24px;display:grid}.login-card{background:#fffbff;border:1px solid #d7d3e0;border-radius:20px;justify-self:center;gap:16px;width:min(100%,400px);max-width:400px;padding:28px;display:grid;box-shadow:0 20px 44px #211f2624}.login-heading{gap:4px;padding-bottom:8px;display:grid}.login-heading h1{font-size:24px;font-weight:800;line-height:1.15}.workspace,.md3-workspace{color:#1d1b20;background:#fffbfe;grid-template-columns:72px minmax(0,1fr);align-items:stretch;gap:0;height:100svh;min-height:0;display:grid;overflow:hidden}.app-navigation-rail{background:#f7f2fa;border-right:1px solid #cac4d0b8;grid-template-rows:auto minmax(0,1fr) auto;align-items:center;gap:10px;height:100%;min-height:0;padding:10px 4px;display:grid}.rail-nav-group{gap:8px;width:100%;display:grid}.nav-rail-item,.account-button{color:#49454f;cursor:pointer;font:inherit;background:0 0;border:0;align-self:end;place-items:center;width:100%;min-width:0;padding:0;display:grid}.nav-rail-item{border-radius:18px;gap:3px;min-height:62px;padding:7px 2px;transition:background-color .14s,color .14s,transform .14s}.nav-rail-item svg{box-sizing:content-box;border-radius:999px;width:20px;height:20px;padding:6px 12px}.nav-rail-item span{text-align:center;font-size:11px;font-weight:800;line-height:1.15;display:block}.nav-rail-item:hover{background:#6750a414}.nav-rail-item.active{color:#21005d}.nav-rail-item.active svg{color:#536dfe;background:#eaddff}.rail-spacer{min-height:0}.account-button:hover{background:#ece6f4}.account-avatar{color:#fff;background:linear-gradient(135deg,#536dfe 0%,#6a3de8 100%);width:42px;height:42px;font-size:14px;font-weight:900}.account-menu-header{align-items:center;gap:12px;min-width:220px;padding:10px 14px;display:flex}.MuiMenuItem-root{gap:10px}.password-dialog-content{gap:14px;padding-top:8px;display:grid}.visually-hidden{clip:rect(0 0 0 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.workspace-page,.md3-pane{background:#fffbfe;min-width:0;height:100%;min-height:0;margin:0;padding:14px 18px 18px;overflow:auto}.md3-pane{box-shadow:none;border:0;border-radius:0}.workspace-page .MuiFilledInput-root{background:#f5f6fb;border-radius:16px 16px 6px 6px;min-height:50px}.workspace-page .MuiFilledInput-root:hover{background:#eef1f8}.workspace-page .MuiFilledInput-root.Mui-focused{background:#f7f4ff;box-shadow:inset 0 0 0 1px #536dfe33}.workspace-page .MuiFilledInput-root:before{border-bottom-color:#49454f57}.workspace-page .MuiFilledInput-root:after{border-bottom-color:#536dfe}.workspace-page .MuiInputLabel-root.Mui-focused{color:#536dfe}.record-page{grid-template-rows:auto auto;gap:12px;height:auto;min-height:0;display:grid}.history-page{grid-template-rows:auto minmax(0,1fr);gap:16px;height:100%;min-height:0;display:grid}.page-heading,.record-heading,.editor-panel-heading,.list-item-header{justify-content:space-between;align-items:center;gap:12px;min-width:0;display:flex}.page-header h2{font-size:20px;font-weight:900;line-height:1.2}.record-layout{grid-template-rows:auto auto;grid-template-columns:minmax(0,1fr);gap:12px;height:auto;min-height:0;display:grid}.record-meta-panel,.record-editor-panel{background:#f5f2fa;border:1px solid #cac4d0c7;border-radius:16px;gap:10px;min-width:0;padding:10px;display:grid}.record-meta-panel{grid-template-columns:minmax(180px,1fr) minmax(180px,1fr) minmax(260px,auto);align-items:center}.record-editor-panel{background:0 0;border:0;border-radius:0;grid-template-rows:auto auto;min-height:auto;padding:0}.editor-panel-heading{border-bottom:0;padding:0 2px}.group-list{align-content:start;gap:0;min-height:auto;padding:0;display:grid;overflow:visible}.capture-area{background:0 0;border:0;border-radius:0;align-items:center;gap:10px;min-width:0;padding:0;display:flex}.capture-meta{gap:2px;min-width:0;display:grid}.capture-meta strong{color:#1d1b20;font-size:15px;font-weight:900}.capture-meta span,.page-header p,.list-item-header span,.line-count{color:#625b71;font-size:12px}.photo-strip{flex:auto;gap:8px;min-width:0;padding-bottom:2px;display:flex;overflow-x:auto}.photo-tile{background:0 0;border:1px solid #cac4d0;border-radius:20px;flex:none;justify-content:stretch;align-items:stretch;width:76px;height:56px;display:flex;position:relative;overflow:hidden}.photo-preview-trigger{color:inherit;cursor:zoom-in;font:inherit;background:0 0;border:0;width:100%;height:100%;margin:0;padding:0;display:block}.photo-preview-trigger:focus-visible{outline-offset:-2px;outline:2px solid #536dfe}.photo-preview-trigger img{object-fit:cover;width:100%;height:100%;display:block}.photo-remove{color:#fff;background:#1d192bb8;width:22px;min-width:22px;height:22px;padding:0;position:absolute;top:6px;right:6px}.photo-preview-dialog .MuiDialog-paper{max-height:calc(100svh - 48px)}.photo-preview-body{background:#f7f2fa;border-radius:24px;place-items:center;min-height:280px;max-height:min(72svh,720px);padding:12px;display:grid;overflow:auto}.photo-preview-body img{object-fit:contain;border-radius:18px;max-width:100%;max-height:calc(72svh - 24px);display:block}.group-editor,.line-editor{background:#faf8ff;border:1px solid #cac4d0ad;border-radius:16px;gap:8px;min-width:0;padding:10px 12px;display:grid}.line-editor{background:#fffbfe;border-radius:14px}.group-heading-row .MuiTextField-root,.line-editor .MuiTextField-root{flex:180px;min-width:0}.group-heading-row .MuiIconButton-root,.line-editor .MuiIconButton-root{flex:none}.nutrition-grid{grid-template-columns:repeat(4,minmax(96px,1fr));gap:6px;display:grid}.nutrition-grid .MuiFilledInput-root{border-radius:14px 14px 4px 4px;align-items:flex-end;min-height:44px;padding-right:6px;overflow:visible}.nutrition-grid .MuiFilledInput-input{min-width:0;padding-top:18px;padding-bottom:5px;padding-right:4px;line-height:1.35}.nutrition-grid .MuiInputAdornment-root{white-space:nowrap;flex-shrink:0;align-self:flex-end;margin-left:2px;margin-right:2px;padding-bottom:6px}.nutrition-grid .MuiInputAdornment-root p{font-size:14px;line-height:1.35}.nutrition-grid .MuiInputLabel-root{transform:translate(12px,13px)scale(1)}.nutrition-grid .MuiInputLabel-root.MuiInputLabel-shrink{transform:translate(12px,5px)scale(.75)}.list-panel{background:#fffbff;border:1px solid #cac4d0;border-radius:20px;grid-template-rows:auto minmax(0,1fr);gap:12px;height:100%;min-height:0;padding:16px;display:grid;overflow:hidden}.staff-panel{grid-template-rows:auto auto minmax(0,1fr)}.page-header{border-bottom:1px solid #e7e0ec;align-items:start;gap:4px;padding-bottom:12px;display:grid}.staff-form{background:#f7f2fa;border:1px solid #e7e0ec;border-radius:18px;grid-template-columns:repeat(6,minmax(0,1fr));align-items:center;gap:10px;padding:12px;display:grid}.record-list{align-content:start;gap:10px;min-height:0;padding-right:2px;display:grid;overflow:auto}.list-item{color:inherit;text-align:left;background:#fffbff;border:1px solid #e1d9e8;border-radius:18px;gap:8px;width:100%;min-width:0;padding:12px;display:grid}.metric-row{color:#49454f;flex-wrap:wrap;gap:6px 12px;font-size:12px;line-height:1.35;display:flex}.empty-state,.detail-empty{color:#625b71;text-align:center;background:#f7f2fa;border:1px dashed #cac4d0;border-radius:18px;align-items:center;min-height:96px;padding:18px;display:grid}.history-page-grid{grid-template-columns:minmax(280px,340px) minmax(0,1fr);gap:18px;height:100%;min-height:0;display:grid}.history-list{align-content:start;gap:8px;min-height:0;padding-right:2px;display:grid;overflow:auto}.history-row{color:#1d1b20;cursor:pointer;font:inherit;text-align:left;background:#f7f2fa;border:1px solid #0000;border-radius:20px;justify-content:space-between;align-items:center;gap:12px;width:100%;padding:12px;transition:background-color .14s,border-color .14s;display:flex}.history-row:hover{background:#f1ebf5}.history-row.active,.history-row[aria-current=true]{background:#eaddff;border-color:#536dfe}.history-row span:first-child{gap:3px;min-width:0;display:grid}.history-row strong,.history-detail-header h3{color:#1d1b20;text-overflow:ellipsis;white-space:nowrap;font-weight:900;overflow:hidden}.history-row small{color:#625b71}.history-detail{background:0 0;border:0;border-radius:0;grid-template-rows:auto minmax(0,1fr);gap:10px;min-height:0;display:grid;overflow:hidden}.history-detail-header{background:#f7f2fa;border:1px solid #cac4d0b8;border-radius:18px;grid-template-columns:minmax(150px,.28fr) minmax(88px,auto) minmax(360px,1fr);align-items:center;gap:10px;min-width:0;padding:10px 12px;display:grid}.history-title-block{gap:3px;min-width:0;display:grid}.history-title-block h3{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.history-photo-grid{gap:6px;min-width:0;display:flex;overflow-x:auto}.history-photo-tile,.history-photo-placeholder{text-align:center;background:#fffbff;border:1px solid #d7cfe2;border-radius:20px;place-items:center;width:76px;height:56px;display:grid;overflow:hidden}.history-photo-tile img{object-fit:cover;width:100%;height:100%}.history-photo-placeholder{color:#625b71;background:#f7f2fa;padding:8px;font-size:12px}.history-dish-list{align-content:start;gap:8px;min-height:0;padding-right:4px;display:grid;overflow:auto}.history-dish{background:#f7f2fabd;border:1px solid #cac4d0a3;border-radius:16px;grid-template-columns:minmax(92px,.16fr) minmax(0,1fr);align-items:start;gap:8px 12px;padding:9px 12px;display:grid}.history-dish-heading{align-content:start;min-width:0;padding-top:2px;display:grid}.history-dish-heading strong{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.history-nutrition-metrics{grid-template-columns:repeat(4,minmax(86px,1fr));gap:6px;min-width:0;display:grid}.history-detail-header .history-nutrition-metrics{grid-template-columns:repeat(4,minmax(68px,1fr))}.history-dish>.history-nutrition-metrics{grid-template-columns:repeat(8,minmax(54px,1fr))}.history-nutrition-metrics span{background:#fffbffbd;border-radius:12px;gap:2px;min-width:0;padding:5px 8px;display:grid}.history-nutrition-metrics small{color:#625b71;font-size:11px;font-weight:800;line-height:1}.history-nutrition-metrics strong{color:#1d1b20;white-space:nowrap;font-size:13px;font-weight:800;line-height:1.4;overflow:visible}.history-nutrition-metrics.compact{grid-template-columns:repeat(4,minmax(64px,1fr))}.history-nutrition-metrics.compact span{background:#f7f2fac2;border-radius:10px;padding:4px 7px}.ingredient-list{grid-column:2;gap:5px;display:grid}.ingredient-row{background:#fffbff;border:1px solid #cac4d070;border-radius:12px;grid-template-columns:minmax(110px,.2fr) minmax(0,1fr);gap:8px 10px;padding:6px 8px;display:grid}.ingredient-row>strong{color:#1d1b20;text-overflow:ellipsis;align-self:center;min-width:0;overflow:hidden}.camera-modal-body{gap:12px;display:grid}.camera-video{aspect-ratio:4/3;object-fit:cover;background:#111;border-radius:18px;width:100%;display:block}.camera-actions{justify-content:flex-end;gap:8px;display:flex}.MuiButton-root{letter-spacing:0;text-transform:none;border-radius:18px;min-height:40px;font-weight:900}.MuiSelect-root{background:#f7f2fa;border-radius:16px}.MuiTextField-root .MuiInputLabel-root{color:#625b71}.MuiTextField-root .MuiInputBase-input{min-height:24px}@media (width<=1180px){.record-layout{grid-template-columns:minmax(0,1fr)}.history-page-grid{grid-template-columns:minmax(220px,300px) minmax(0,1fr)}}@media (width<=860px){.workspace,.md3-workspace{grid-template-columns:72px minmax(0,1fr)}.workspace-page,.md3-pane{padding:16px}.record-meta-panel,.history-page-grid,.history-detail-header,.staff-form{grid-template-columns:minmax(0,1fr)}.nutrition-grid,.history-nutrition-metrics,.history-detail-header .history-nutrition-metrics,.history-dish>.history-nutrition-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}.page-heading,.record-heading{align-items:stretch;display:grid}}@media (width<=560px){.workspace,.md3-workspace{grid-template-rows:auto minmax(0,1fr);grid-template-columns:1fr}.app-navigation-rail{border-bottom:1px solid #e7e0ec;border-right:0;grid-row:1;grid-template-rows:auto;grid-template-columns:1fr minmax(44px,auto);align-items:center;padding:8px 12px}.rail-nav-group{flex:auto;gap:8px;display:flex;overflow-x:auto}.nav-rail-item{width:72px;min-height:52px}.rail-spacer{display:none}.account-button{width:58px}.account-avatar{width:34px;height:34px}.workspace-page,.md3-pane{grid-row:2;padding:12px}.record-editor-panel,.record-meta-panel,.group-editor,.list-panel{border-radius:16px}.capture-area,.history-dish,.ingredient-row{grid-template-columns:minmax(0,1fr);align-items:stretch;display:grid}.ingredient-list{grid-column:1}}
