:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:#19211d;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;--bg:#f4f6f3;--surface:#fff;--surface-soft:#f7f9f6;--surface-muted:#eef2ed;--text:#19211d;--muted:#6b746d;--subtle:#8b948c;--line:#dde4dc;--line-strong:#c9d3c8;--green:#2d6b43;--green-strong:#1f5735;--green-soft:#e7f2ea;--amber:#b86b19;--amber-soft:#fff5e8;--red:#b63d3d;--shadow:0 18px 50px #252f2714;--radius:8px;background:#f4f6f3;font-family:Inter,PingFang SC,Microsoft YaHei,Noto Sans SC,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{background:var(--bg);min-width:320px;margin:0}button,input,textarea{font:inherit}button{border:0}button:not(:disabled){cursor:pointer}button:disabled{cursor:not-allowed;opacity:.64}input,textarea{color:var(--text)}textarea{resize:vertical}.app-shell{min-height:100vh}.topbar{z-index:10;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#fffffff0;align-items:center;min-height:72px;padding:0 28px;display:flex;position:sticky;top:0}.brand{align-items:center;gap:11px;min-width:270px;display:flex}.brand-mark{color:#fff;background:var(--green);border-radius:var(--radius);place-items:center;width:38px;height:38px;display:grid;box-shadow:0 10px 20px #2d6b432e}.brand strong{font-size:18px;font-weight:800;line-height:1.1;display:block}.brand span{color:var(--muted);margin-top:2px;font-size:12px;font-weight:650;display:block}.main-nav{background:0 0;border:0;border-radius:0;align-self:stretch;align-items:center;gap:26px;padding:0 6px;display:flex}.nav-item{min-width:86px;height:100%;color:var(--muted);white-space:nowrap;background:0 0;border-bottom:3px solid #0000;border-radius:0;justify-content:center;align-items:center;gap:7px;padding:0 4px;font-size:14px;font-weight:750;display:inline-flex}.nav-item.active{color:var(--green);box-shadow:none;border-bottom-color:var(--green);background:0 0}.nav-item:disabled,.plain-icon:disabled,.profile-button:disabled,.ghost-button:disabled,.review-strip button:disabled{cursor:default}.top-actions{align-items:center;gap:10px;margin-left:auto;display:flex}.mode-chip{height:34px;color:var(--amber);white-space:nowrap;background:var(--amber-soft);border:1px solid #f4d7b2;border-radius:999px;align-items:center;gap:6px;padding:0 12px;font-size:13px;font-weight:800;display:inline-flex}.mode-chip.online{color:var(--green);background:var(--green-soft);border-color:#c5dec8}.plain-icon,.profile-button{width:38px;height:38px;color:var(--muted);background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);place-items:center;display:inline-grid}.plain-icon:hover,.profile-button:hover{color:var(--text);border-color:var(--line-strong)}.workspace{grid-template-columns:minmax(292px,.82fr) minmax(500px,1.36fr) minmax(330px,.92fr);align-items:start;gap:18px;width:min(1480px,100% - 36px);margin:18px auto 30px;display:grid}.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);min-width:0;box-shadow:var(--shadow)}.panel-heading{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;display:flex}.panel-heading h1,.panel-heading h2{color:var(--text);letter-spacing:0;margin:0;line-height:1.1}.panel-heading h1{max-width:310px;font-size:26px;font-weight:850}.panel-heading h2{font-size:22px;font-weight:820}.compact-heading{align-items:center}.section-label{color:var(--green);margin-bottom:8px;font-size:12px;font-weight:850;display:block}.dropzone{background:linear-gradient(135deg, #2d6b430d, #ffffff8c), var(--surface-soft);border:1px dashed var(--line-strong);border-radius:var(--radius);place-items:center;width:100%;min-height:258px;display:grid;position:relative;overflow:hidden}.dropzone input{opacity:0;position:absolute;inset:0}.dropzone img{object-fit:cover;width:100%;height:100%;min-height:258px}.dropzone-empty{text-align:center;justify-items:center;gap:9px;padding:24px;display:grid}.dropzone-empty strong{max-width:240px;font-size:16px;line-height:1.35}.dropzone-empty span{color:var(--muted);font-size:13px}.upload-mark{width:58px;height:58px;color:var(--green);border:1px solid var(--line);border-radius:var(--radius);background:#fff;place-items:center;display:grid}.thumb-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:12px;display:grid}.upload-count{color:var(--muted);justify-content:space-between;align-items:center;gap:8px;margin-top:12px;font-size:13px;font-weight:800;display:flex}.upload-count strong{color:var(--amber);text-align:right;font-size:12px;font-weight:850}.thumb,.thumb-action{border:1px solid var(--line);border-radius:var(--radius);height:118px;overflow:hidden}.thumb img{object-fit:cover;width:100%;height:100%}.thumb.placeholder{color:var(--subtle);background:var(--surface-soft);border-style:dashed;place-items:center;display:grid}.thumb.sample{position:relative}.thumb.sample span{color:#fff;background:#2d6b43eb;border-radius:5px;padding:4px 8px;font-size:12px;font-weight:850;position:absolute;bottom:10px;left:10px}.thumb-action{color:var(--muted);background:#fff;grid-column:1/-1;justify-content:center;align-items:center;gap:5px;padding:0 11px;font-size:12px;font-weight:760;display:inline-flex}.field-block{gap:8px;margin-top:16px;display:grid}.field-block label,.factor-topline strong{color:var(--text);font-size:13px;font-weight:820}.field-block textarea,.manual-box textarea{width:100%;color:var(--text);background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius);outline:none;padding:12px;line-height:1.45}.field-block textarea:focus,.manual-box textarea:focus,.food-name-cell input:focus,.grams-control input:focus{border-color:#8fb99b;box-shadow:0 0 0 3px #2d6b431f}.primary-button,.secondary-button,.ghost-button{white-space:nowrap;border-radius:var(--radius);justify-content:center;align-items:center;gap:8px;min-height:42px;padding:0 16px;font-size:14px;font-weight:850;display:inline-flex}.primary-button{color:#fff;background:var(--green);width:100%;margin-top:14px;box-shadow:0 12px 24px #2d6b4333}.primary-button:hover{background:var(--green-strong)}.secondary-button{color:#fff;background:var(--green)}.ghost-button{color:var(--text);background:var(--surface-soft);border:1px solid var(--line)}.manual-box{background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius);gap:10px;margin-top:16px;padding:14px;display:grid}.manual-heading{color:var(--text);align-items:center;gap:8px;font-size:14px;font-weight:850;display:inline-flex}.template-row{flex-wrap:wrap;gap:8px;display:flex}.template-row button{min-height:28px;color:var(--muted);border:1px solid var(--line);background:#fff;border-radius:999px;padding:0 9px;font-size:12px;font-weight:760}.status-message{color:var(--green);background:var(--green-soft);border-radius:var(--radius);border:1px solid #c8ddcc;align-items:flex-start;gap:8px;margin-top:14px;padding:10px;font-size:13px;line-height:1.42;display:flex}.sync-state{height:32px;color:var(--green);background:var(--green-soft);border-radius:999px;align-items:center;gap:6px;padding:0 10px;font-size:12px;font-weight:850;display:inline-flex}.table-shell{border:1px solid var(--line);border-radius:var(--radius);overflow-x:auto}.food-table{min-width:0}.food-row{border-top:1px solid var(--line);grid-template-columns:minmax(176px,1.25fr) 158px 60px 62px 30px;align-items:center;gap:8px;min-height:78px;padding:10px 12px;display:grid}.food-row:first-child{border-top:0}.table-head{min-height:40px;color:var(--muted);background:var(--surface-soft);font-size:12px;font-weight:850}.food-name-cell{grid-template-columns:50px minmax(0,1fr);align-items:center;gap:8px;min-width:0;display:grid}.food-name-cell>img{object-fit:cover;border:1px solid var(--line);border-radius:7px;width:50px;height:50px}.food-name-cell>div{gap:5px;min-width:0;display:grid}.food-name-cell input{width:100%;min-width:0;color:var(--text);text-overflow:ellipsis;background:0 0;border:1px solid #0000;border-radius:5px;outline:none;padding:0;font-size:15px;font-weight:850;overflow:hidden}.food-name-cell span{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:700;overflow:hidden}.grams-control{border:1px solid var(--line);border-radius:var(--radius);grid-template-columns:30px minmax(36px,1fr) 30px 58px;align-items:center;display:grid;overflow:hidden}.grams-control button{height:32px;color:var(--muted);background:#fff;place-items:center;display:grid}.grams-control input{width:100%;height:32px;color:var(--text);text-align:center;background:var(--surface-soft);border:0;border-right:1px solid var(--line);border-left:1px solid var(--line);outline:none;font-size:14px;font-weight:850}.grams-control select{width:100%;height:32px;color:var(--text);text-align:center;border:0;border-left:1px solid var(--line);background:#fff;outline:none;padding:0 4px;font-size:12px;font-weight:820}.kcal-cell{gap:1px;display:grid}.kcal-cell strong{font-size:17px;line-height:1}.kcal-cell span{color:var(--muted);font-size:12px;font-weight:760}.confidence-cell{gap:6px;display:grid}.confidence-bar{background:#e9eee8;border-radius:999px;width:100%;height:6px;display:block;overflow:hidden}.confidence-bar i{background:var(--green);border-radius:inherit;height:100%;display:block}.confidence-cell em{color:var(--muted);font-size:12px;font-style:normal;font-weight:800}@media (width<=760px){.table-shell{overflow-x:visible}.food-table{gap:10px;min-width:0;display:grid}.food-row{border:1px solid var(--line);border-radius:var(--radius);grid-template-columns:1fr auto;grid-template-areas:"food delete""grams grams""kcal confidence";gap:10px;min-height:0;padding:12px}.food-row.table-head{display:none}.food-name-cell{grid-area:food}.grams-control{grid-area:grams;grid-template-columns:40px minmax(72px,1fr) 40px 72px;width:100%}.grams-control button,.grams-control input,.grams-control select{height:38px}.kcal-cell{background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius);grid-area:kcal;padding:9px 10px}.confidence-cell{background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius);grid-area:confidence;justify-content:center;align-self:stretch;min-width:118px;padding:9px 10px}.row-delete{grid-area:delete}}.row-delete{width:34px;height:34px;color:var(--subtle);background:0 0;border-radius:6px;place-items:center;display:grid}.row-delete:hover{color:var(--red);background:#fff0f0}.table-actions,.summary-actions{gap:10px;margin-top:14px;display:flex}.review-strip{color:var(--amber);background:var(--amber-soft);border-radius:var(--radius);border:1px solid #f3d4aa;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;margin-top:16px;padding:12px;display:grid}.review-strip strong{color:#77430f;font-size:13px;line-height:1.35;display:block}.review-strip span{color:#986221;margin-top:2px;font-size:12px;line-height:1.35;display:block}.review-strip button{color:#794711;background:#fff;border:1px solid #f0cc9d;border-radius:6px;align-items:center;gap:4px;height:32px;padding:0 10px;font-size:12px;font-weight:850;display:inline-flex}.calorie-hero{color:#fff;border-radius:var(--radius);background:#22382a;grid-template-columns:auto 1fr auto;align-items:end;gap:8px;padding:18px;display:grid}.calorie-hero span{color:#b9d0be;grid-column:1/-1;font-size:13px;font-weight:820}.calorie-hero strong{letter-spacing:0;font-size:clamp(44px,5vw,64px);line-height:.95}.calorie-hero em{color:#dfe9e1;align-self:end;padding-bottom:7px;font-size:15px;font-style:normal;font-weight:850}.range-row{grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px;display:grid}.range-row div,.macro-item{background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius);gap:6px;padding:12px;display:grid}.range-row span,.macro-item span{color:var(--muted);font-size:12px;font-weight:780}.range-row strong,.macro-item strong{font-size:14px;line-height:1.2}.delta-box{color:var(--green);background:var(--green-soft);border-radius:var(--radius);border:1px solid #c6dccb;align-items:center;gap:10px;margin-top:12px;padding:13px;display:flex}.delta-box span{color:var(--muted);font-size:12px;font-weight:780;display:block}.delta-box strong{color:var(--green);margin-top:2px;font-size:15px;display:block}.macro-grid{grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px;display:grid}.factor-list{gap:14px;margin-top:18px;display:grid}.factor-item{gap:8px;display:grid}.factor-topline{justify-content:space-between;align-items:center;gap:12px;display:flex}.factor-topline em{color:var(--text);font-size:13px;font-style:normal;font-weight:850}.factor-item input{width:100%;accent-color:var(--green)}.factor-item small{color:var(--muted);font-size:12px;line-height:1.4}.assumption-list{gap:8px;margin-top:16px;display:grid}.assumption-list div{color:var(--muted);align-items:flex-start;gap:7px;font-size:12px;line-height:1.42;display:flex}.assumption-list svg{color:var(--green);flex:none;margin-top:1px}.history-block{border-top:1px solid var(--line);gap:8px;margin-top:18px;padding-top:16px;display:grid}.history-heading{color:var(--text);justify-content:space-between;align-items:center;font-size:14px;font-weight:850;display:flex}.history-heading button{color:var(--green);background:0 0;font-size:12px;font-weight:850}.history-item{text-align:left;background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius);grid-template-columns:1fr auto;align-items:center;gap:10px;width:100%;padding:10px;display:grid}.history-item.active{background:var(--green-soft);border-color:#bdd8c2}.history-item strong{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:13px;line-height:1.35;display:block;overflow:hidden}.history-item em{color:var(--muted);margin-top:2px;font-size:12px;font-style:normal;display:block}.history-item b{color:var(--text);font-size:16px}.spin{animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=1240px){.topbar{flex-wrap:wrap;gap:12px;padding:14px 18px}.main-nav{border:1px solid var(--line);border-radius:var(--radius);order:3;align-self:auto;width:100%;min-height:46px;padding:0;overflow-x:auto}.workspace{grid-template-columns:minmax(300px,.9fr) minmax(500px,1.1fr)}.summary-panel{grid-column:1/-1}}@media (width<=920px){.workspace{grid-template-columns:1fr;width:min(100% - 24px,680px)}.summary-panel{grid-column:auto}}@media (width<=640px){.topbar{align-items:flex-start}.brand{min-width:auto}.top-actions{justify-content:space-between;width:100%;margin-left:0}.nav-item{min-width:max-content;height:44px;padding:0 14px}.capture-panel,.recognition-panel,.summary-panel{padding:14px}.panel-heading{gap:10px}.panel-heading h1{font-size:22px}.panel-heading h2{font-size:19px}.dropzone,.dropzone img{min-height:210px}.thumb-row{grid-template-columns:repeat(2,minmax(0,1fr))}.thumb-action{grid-column:1/-1;justify-content:center}.table-actions,.summary-actions{flex-direction:column}.review-strip{grid-template-columns:auto 1fr}.review-strip button{grid-column:1/-1;justify-content:center}.range-row,.macro-grid{grid-template-columns:1fr}.calorie-hero strong{font-size:46px}}html{overflow-x:hidden}.app-shell{flex-direction:column;display:flex;overflow-x:hidden}.brand{color:inherit;text-align:left;background:0 0}.capture-panel,.recognition-panel,.summary-panel{padding:0}.panel{min-height:0}.panel-scroll{min-height:0;padding:18px}button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline-offset:2px;outline:3px solid #2d6b432e}@media (width>=1241px){.topbar{min-height:72px}.workspace{grid-template-columns:minmax(290px,.78fr) minmax(520px,1.42fr) minmax(330px,.9fr);align-items:stretch;height:calc(100vh - 104px);min-height:0;margin:16px auto}.panel{flex-direction:column;height:100%;display:flex;overflow:hidden}.panel-scroll{overscroll-behavior:contain;scrollbar-gutter:stable;flex:auto;height:100%;overflow-y:auto}.compact-mode .dropzone,.compact-mode .dropzone img{min-height:184px}.compact-mode .thumb,.compact-mode .thumb-action{height:82px}.compact-mode .thumb-action{min-height:42px}.compact-mode .field-block,.compact-mode .manual-box,.compact-mode .factor-list,.compact-mode .history-block{margin-top:12px}.compact-mode .food-row{min-height:66px;padding:8px 10px}.compact-mode .food-name-cell>img{width:44px;height:44px}.compact-mode .calorie-hero{padding:16px}.compact-mode .calorie-hero strong{font-size:52px}.compact-mode .range-row div,.compact-mode .macro-item{padding:10px}}.view-shell{width:min(1180px,100% - 36px);margin:18px auto 30px}.view-panel{min-height:calc(100vh - 120px);padding:24px}.view-heading{justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:18px;display:flex}.view-heading h1{color:var(--text);letter-spacing:0;margin:0;font-size:28px;line-height:1.1}.record-grid,.stats-grid,.library-grid{gap:12px;display:grid}.record-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.record-card,.library-card{width:100%;min-width:0;color:var(--text);text-align:left;background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius);display:grid}.record-card{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:14px;min-height:86px;padding:14px}.record-card:hover,.library-card:hover,.history-item:hover,.ghost-button:hover,.secondary-button:hover{border-color:var(--line-strong);filter:brightness(.995)}.record-card.active{background:var(--green-soft);border-color:#b8d4bf}.record-card strong,.library-card strong{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.record-card em,.library-card em{color:var(--muted);margin-top:4px;font-size:12px;font-style:normal;font-weight:760;display:block}.record-card b{color:var(--green);font-size:18px}.view-actions{justify-content:flex-end;margin-top:18px;display:flex}.stats-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.stat-tile{background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius);gap:8px;padding:16px;display:grid}.stat-tile span{color:var(--muted);font-size:13px;font-weight:780}.stat-tile strong{color:var(--text);font-size:24px;line-height:1.1}.macro-chart{background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius);gap:14px;margin-top:18px;padding:18px;display:grid}.macro-bar{grid-template-columns:78px minmax(0,1fr) 68px;align-items:center;gap:12px;display:grid}.macro-bar span,.macro-bar strong{font-size:13px;font-weight:820}.macro-bar i{background:linear-gradient(90deg, var(--green), #77a86b);border-radius:999px;height:12px;display:block}.search-field{min-height:44px;color:var(--muted);background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius);align-items:center;gap:10px;padding:0 12px;display:flex}.search-field input{background:0 0;border:0;outline:none;width:100%;min-width:0}.library-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));margin-top:14px}.library-card{grid-template-columns:52px minmax(0,1fr);align-items:center;gap:12px;min-height:88px;padding:12px}.library-card img{object-fit:cover;border:1px solid var(--line);border-radius:7px;grid-row:span 2;width:52px;height:52px}.library-card b{color:var(--green);grid-column:2;font-size:12px}.modal-backdrop{z-index:50;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#121b1661;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.modal-panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);width:min(640px,100%);max-height:calc(100vh - 48px);padding:20px;overflow-y:auto;box-shadow:0 28px 80px #121b163d}.modal-heading{justify-content:space-between;align-items:center;gap:14px;margin-bottom:14px;display:flex}.modal-heading h2{letter-spacing:0;margin:0;font-size:21px;line-height:1.15}.modal-stack{gap:12px;display:grid}.info-box{background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius);gap:6px;padding:14px;display:grid}.info-box strong{color:var(--text);font-size:14px}.info-box span{color:var(--muted);font-size:13px;line-height:1.5}.toggle-row{background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius);justify-content:space-between;align-items:center;gap:16px;min-height:48px;padding:12px 14px;display:flex}.toggle-row span{color:var(--text);font-size:14px;font-weight:820}.toggle-row input{width:42px;height:24px;accent-color:var(--green)}.summary-detail{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}@media (width<=1240px){.panel-scroll{overflow:visible}}@media (width<=760px){.view-shell{width:min(100% - 24px,680px);margin:12px auto 24px}.view-panel{min-height:auto;padding:16px}.view-heading,.record-card{grid-template-columns:1fr}.view-heading{display:grid}.stats-grid,.summary-detail{grid-template-columns:1fr}.macro-bar{grid-template-columns:64px minmax(0,1fr) 58px}}@media (width<=640px){.panel-scroll{padding:14px}.topbar{min-height:0}.main-nav{grid-template-columns:repeat(4,minmax(0,1fr));gap:0;display:grid;overflow:visible}.nav-item{gap:4px;width:100%;min-width:0;padding:0 4px;font-size:12px}.nav-item svg{width:15px;height:15px}.brand strong{font-size:16px}.mode-chip{flex:auto;justify-content:center}.plain-icon,.profile-button{width:36px;height:36px}.modal-backdrop{align-items:end;padding:12px}.modal-panel{max-height:calc(100vh - 24px);padding:16px}.grams-control input{min-width:0}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
