:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;--font-sans:"DengXian", Arial, "Microsoft YaHei UI", "PingFang SC", "Noto Sans SC", sans-serif;--font-cn:"DengXian", "Microsoft YaHei UI", "PingFang SC", "Noto Sans SC", sans-serif;--font-en:"Times New Roman", Arial, serif;--font-number:Arial, "DengXian", sans-serif;font-family:var(--font-sans);background:var(--bg);color:var(--text);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;--bg:#f8faf9;--surface:#fff;--surface-soft:#f6faf9;--surface-muted:#edf8f7;--text:#17201f;--muted:#5f6f6d;--subtle:#93a09d;--line:#dbe7e5;--line-strong:#b8cfcb;--green:#0a8f91;--green-strong:#057173;--green-soft:#e4f7f7;--green-faint:#f2fbfa;--amber:#07839a;--amber-soft:#e8f7fa;--blue:#65777b;--blue-strong:#4e6064;--blue-soft:#eef4f4;--red:#b85a4f;--red-soft:#fae9e6;--danger:#9b4f48;--danger-soft:#f8eeee;--danger-line:#ead2cf;--on-accent:#fff;--control-bg:#fbfefd;--control-shadow:0 1px 0 #ffffffe6 inset;--button-shadow:0 10px 24px #0874761f;--shadow-sm:0 1px 3px #1229270d;--shadow-md:0 8px 28px #12292712;--shadow-lg:0 20px 56px #1229271a;--shadow:var(--shadow-md);--radius:10px;--radius-lg:14px}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}.dark-mode{--bg:#0d100f;--surface:#151917;--surface-soft:#1b211e;--surface-muted:#202922;--text:#e6ece8;--muted:#9ca8a1;--subtle:#6d7872;--line:#29312c;--line-strong:#3b4a40;--green:#3e7657;--green-strong:#2f5c43;--green-soft:#3e765733;--green-faint:#3e76571a;--amber:#326f64;--amber-soft:#326f642e;--blue:#6e7b74;--blue-strong:#59665f;--blue-soft:#6e7b7421;--red:#b86b62;--red-soft:#b86b621f;--danger:#a4635d;--danger-soft:#a4635d24;--danger-line:#a4635d57;--on-accent:#f4faf6;--control-bg:#171d1a;--control-shadow:0 1px 0 #ffffff09 inset;--button-shadow:0 12px 28px #0000003d;--shadow-sm:0 1px 3px #0003;--shadow-md:0 8px 28px #00000047;--shadow-lg:0 20px 56px #0000005c;--shadow:var(--shadow-md)}@media (prefers-color-scheme:dark){:root:not(.light-mode){--bg:#0d100f;--surface:#151917;--surface-soft:#1b211e;--surface-muted:#202922;--text:#e6ece8;--muted:#9ca8a1;--subtle:#6d7872;--line:#29312c;--line-strong:#3b4a40;--green:#3e7657;--green-strong:#2f5c43;--green-soft:#3e765733;--green-faint:#3e76571a;--amber:#326f64;--amber-soft:#326f642e;--blue:#6e7b74;--blue-strong:#59665f;--blue-soft:#6e7b7421;--red:#b86b62;--red-soft:#b86b621f;--danger:#a4635d;--danger-soft:#a4635d24;--danger-line:#a4635d57;--on-accent:#f4faf6;--control-bg:#171d1a;--control-shadow:0 1px 0 #ffffff09 inset;--button-shadow:0 12px 28px #0000003d;--shadow-sm:0 1px 3px #0003;--shadow-md:0 8px 28px #00000047;--shadow-lg:0 20px 56px #0000005c;--shadow:var(--shadow-md)}}html.light-mode{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}html.dark-mode{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}*{box-sizing:border-box}body{min-width:320px;font-family:var(--font-sans);background:linear-gradient(180deg, color-mix(in srgb, var(--green) 3%, transparent), transparent 260px), var(--bg);margin:0;transition:background-color .3s,color .3s}::selection{color:var(--on-accent);background:color-mix(in srgb, var(--green) 76%, var(--green-strong))}button,input,select,textarea{font:inherit}button{letter-spacing:0;touch-action:manipulation;-webkit-user-select:none;user-select:none;border:0}button *,[role=button],[role=button] *{cursor:inherit;-webkit-user-select:none;user-select:none}button:not(:disabled){cursor:pointer}button:disabled{cursor:not-allowed;opacity:.64}button:disabled *{cursor:not-allowed}input,select,textarea{color:var(--text);caret-color:var(--green);letter-spacing:0;transition:border-color .18s,box-shadow .18s,background-color .18s}input::placeholder,textarea::placeholder{color:color-mix(in srgb, var(--muted) 68%, transparent);opacity:1}textarea{resize:vertical}.app-shell{min-height:100vh}.app-shell :where(.brand,.mode-chip,.sync-state,.section-label,.stat-tile,.calorie-hero,.daily-goal-card,.review-strip,.confidence-pill,.meal-chip,.tag-row span,.library-filter-summary,.library-category-tabs,.library-category-row,.library-row-side,.library-detail-metrics,.component-head,.component-group-pills,.profile-metrics,.segmented-control,.record-table-head,.trend-day,.distribution-row strong,.ranked-row strong,.profile-file-tab,.profile-account-chip,.profile-action-row,.profile-privacy-block summary,.danger-zone-head){-webkit-user-select:none;user-select:none}.topbar{z-index:10;background:linear-gradient(180deg, #fffffff5, #ffffffe6), var(--surface);border-bottom:1px solid var(--line);-webkit-backdrop-filter:saturate(160%)blur(18px);align-items:center;min-height:68px;padding:0 28px;display:flex;position:sticky;top:0;box-shadow:inset 0 1px #ffffffb8}.dark-mode .topbar{background:linear-gradient(180deg, #121513f5, #0f1210e6), var(--surface);box-shadow:inset 0 1px #ffffff09}@media (prefers-color-scheme:dark){:root:not(.light-mode) .topbar{background:linear-gradient(180deg, #121513f5, #0f1210e6), var(--surface);box-shadow:inset 0 1px #ffffff09}}.brand{align-items:center;gap:11px;min-width:270px;display:flex}.brand-mark{width:40px;height:40px;color:var(--on-accent);background:linear-gradient(145deg, color-mix(in srgb, var(--green) 88%, #fff), var(--green-strong)), var(--green);border:1px solid color-mix(in srgb, var(--green-strong) 68%, var(--surface));box-shadow:var(--button-shadow), 0 1px 0 #ffffff42 inset;border-radius:12px;place-items:center;transition:transform .3s,box-shadow .3s;display:grid;position:relative}.brand-mark:after{content:"";pointer-events:none;border:1px solid #ffffff38;border-radius:8px;position:absolute;inset:6px}.brand-mark:hover{transform:scale(1.06);box-shadow:0 12px 28px #05717333}.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:82px;height:38px;color:var(--muted);white-space:nowrap;background:0 0;border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;gap:7px;padding:0 10px;font-size:14px;font-weight:750;display:inline-flex}.nav-item.active{color:var(--green);background:var(--green-faint);border-color:color-mix(in srgb, var(--green) 22%, var(--line));box-shadow:0 8px 18px color-mix(in srgb, var(--green) 8%, transparent)}.nav-item:disabled,.theme-toggle: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:36px;color:var(--amber);white-space:nowrap;background:color-mix(in srgb, var(--amber-soft) 82%, var(--surface));border:1px solid color-mix(in srgb, var(--amber) 34%, var(--line));box-shadow:var(--control-shadow);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(--blue);background:var(--blue-soft);border-color:color-mix(in srgb, var(--blue) 36%, var(--line))}.mode-chip.cloud{color:var(--green);background:var(--green-soft);border-color:color-mix(in srgb, var(--green) 34%, var(--line))}.mode-chip.localdb{color:var(--green-strong);background:var(--green-soft);border-color:color-mix(in srgb, var(--green) 26%, var(--line))}.mode-chip.error{color:var(--red);background:var(--red-soft);border-color:color-mix(in srgb, var(--red) 34%, var(--line))}.theme-toggle,.plain-icon,.profile-button{width:40px;height:40px;color:var(--muted);background:linear-gradient(145deg, color-mix(in srgb, var(--green) 4%, transparent), transparent), var(--control-bg);border:1px solid var(--line);box-shadow:var(--control-shadow);border-radius:12px;place-items:center;display:inline-grid;position:relative;overflow:hidden}.theme-toggle:before,.plain-icon:before,.profile-button:before{content:"";background:color-mix(in srgb, var(--green) 7%, transparent);opacity:0;border-radius:9px;transition:opacity .18s;position:absolute;inset:4px}.profile-button{color:var(--green);background:linear-gradient(145deg, color-mix(in srgb, var(--green) 12%, transparent), transparent), var(--control-bg);font-weight:850;overflow:hidden}.profile-button span,.profile-button img{border-radius:inherit;place-items:center;width:100%;height:100%;display:grid}.profile-button img{object-fit:cover}.profile-button.has-avatar{padding:0}.profile-button>svg,.plain-icon>svg,.theme-toggle>svg{z-index:1;width:20px;height:20px;position:relative}button:focus-visible{box-shadow:0 0 0 3px color-mix(in srgb, var(--green) 16%, transparent), var(--control-shadow);outline:0}.theme-toggle{color:var(--amber)}.dark-mode .theme-toggle{color:var(--green)}@media (prefers-color-scheme:dark){:root:not(.light-mode) .theme-toggle{color:var(--green)}}.theme-toggle:hover,.plain-icon:hover,.profile-button:hover{color:var(--text);border-color:var(--line-strong);background:var(--surface-muted)}.theme-toggle:hover:before,.plain-icon:hover:before,.profile-button:hover:before{opacity:1}.theme-toggle:hover{color:var(--amber);background:var(--surface-muted)}.dark-mode .theme-toggle:hover{color:var(--green)}@media (prefers-color-scheme:dark){:root:not(.light-mode) .theme-toggle:hover{color:var(--green)}}.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, color-mix(in srgb, var(--green) 8%, transparent), transparent 42%), linear-gradient(180deg, var(--surface), var(--surface-soft));border:1px solid color-mix(in srgb, var(--green) 20%, var(--line));width:100%;min-height:218px;box-shadow:var(--control-shadow);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:14px;place-items:center;display:grid;position:relative;overflow:hidden}.dropzone:before{content:"";border:1px solid color-mix(in srgb, var(--green) 18%, var(--line));pointer-events:none;border-radius:11px;position:absolute;inset:13px}.dropzone:after{display:none}.dropzone input{opacity:0;cursor:pointer;position:absolute;inset:0}.dropzone img{object-fit:cover;width:100%;height:100%;min-height:218px}.label-dropzone img{object-fit:contain;background:#fff}.dropzone-empty{z-index:1;text-align:center;justify-items:center;gap:9px;padding:22px;display:grid;position:relative}.dropzone-empty strong{max-width:240px;color:var(--text);font-size:16px;font-weight:860;line-height:1.35}.dropzone-empty span{color:var(--muted);font-size:12px}.upload-mark{width:62px;height:62px;color:var(--green);background:radial-gradient(circle at 50% 42%, color-mix(in srgb, var(--green) 10%, transparent), transparent 52%), var(--surface);border:1px solid color-mix(in srgb, var(--green) 26%, var(--line));box-shadow:0 14px 30px color-mix(in srgb, var(--green) 12%, transparent), var(--control-shadow);border-radius:17px;place-items:center;display:grid;position:relative}.upload-mark:before,.upload-mark:after{content:"";border-color:color-mix(in srgb, var(--green) 58%, var(--line));pointer-events:none;width:18px;height:18px;position:absolute}.upload-mark:before{border-top:2px solid;border-left:2px solid;border-radius:5px 0 0;top:10px;left:10px}.upload-mark:after{border-bottom:2px solid;border-right:2px solid;border-radius:0 0 5px;bottom:10px;right:10px}.capture-mode-switch{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-bottom:14px;display:grid}.capture-mode-switch button{min-width:0;min-height:42px;color:var(--muted);white-space:nowrap;background:var(--control-bg);border:1px solid var(--line);box-shadow:var(--control-shadow);border-radius:12px;justify-content:center;align-items:center;gap:7px;font-size:13px;font-weight:850;display:inline-flex}.capture-mode-switch button.active{color:var(--on-accent);background:linear-gradient(145deg, var(--green), var(--green-strong));box-shadow:var(--button-shadow);border-color:#0000}.thumb-row{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;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:12px;height:76px;overflow:hidden}.thumb img{object-fit:cover;width:100%;height:100%}.thumb.placeholder{color:var(--subtle);background:linear-gradient(135deg, color-mix(in srgb, var(--green) 5%, transparent), transparent), var(--surface-soft);border-style:solid;place-items:center;gap:4px;font-size:12px;font-weight:800;display:grid}.thumb.placeholder span{line-height:1}.thumb.sample{position:relative}.thumb.sample span{color:#fff;background:#17211fc7;border-radius:5px;padding:4px 8px;font-size:12px;font-weight:850;position:absolute;bottom:10px;left:10px}.thumb-action{color:var(--muted);background:var(--control-bg);box-shadow:var(--control-shadow);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:7px;margin-top:12px;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(--control-bg);border:1px solid var(--line);box-shadow:var(--control-shadow);border-radius:12px;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:color-mix(in srgb, var(--green) 50%, var(--line));box-shadow:0 0 0 3px color-mix(in srgb, var(--green) 16%, transparent)}.primary-button,.secondary-button,.ghost-button{isolation:isolate;white-space:nowrap;min-height:42px;box-shadow:var(--control-shadow);border:1px solid #0000;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:0 17px;font-size:14px;font-weight:850;display:inline-flex;position:relative;overflow:hidden}.primary-button:after,.secondary-button:after{z-index:-1;content:"";border-radius:inherit;opacity:0;background:linear-gradient(90deg,#0000,#ffffff2e,#0000);transition:opacity .18s,transform .32s;position:absolute;inset:1px;transform:translate(-44%)}.primary-button:hover:after,.secondary-button:hover:after{opacity:1;transform:translate(44%)}.primary-button>svg,.secondary-button>svg,.ghost-button>svg{box-sizing:content-box;border-radius:9px;flex:none;width:16px;height:16px;padding:4px}.primary-button{width:100%;color:var(--on-accent);background:linear-gradient(145deg, var(--green), var(--green-strong));box-shadow:var(--button-shadow), 0 1px 0 #ffffff3d inset;margin-top:12px}.primary-button:hover{background:linear-gradient(145deg, color-mix(in srgb, var(--green) 78%, var(--green-strong)), var(--green-strong))}.secondary-button{color:var(--on-accent);background:linear-gradient(145deg, var(--green-strong), color-mix(in srgb, var(--green) 68%, var(--amber)));box-shadow:var(--button-shadow), 0 1px 0 #fff3 inset}.ghost-button{color:var(--text);background:var(--control-bg);border:1px solid var(--line)}.primary-button>svg,.secondary-button>svg{background:#ffffff29}.ghost-button>svg{color:var(--green);background:var(--green-faint)}.ghost-button.danger>svg{color:var(--danger);background:var(--danger-soft)}.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:760;display:inline-flex}.template-row{flex-wrap:wrap;gap:8px;display:flex}.template-row button{min-height:28px;color:var(--muted);background:var(--surface);border:1px solid var(--line);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);background:var(--surface);box-shadow:var(--control-shadow);border-radius:14px;overflow-x:auto}.food-table{min-width:0}.food-row{border-top:1px solid var(--line);grid-template-columns:minmax(164px,1.28fr) 152px 58px 76px 28px;align-items:center;gap:8px;min-height:68px;padding:10px 12px;display:grid}.food-row:first-child{border-top:0}.food-empty{min-height:190px;color:var(--muted);text-align:center;border-top:1px solid var(--line);place-items:center;gap:8px;padding:32px 18px;display:grid;position:relative}.food-empty svg,.empty-state svg,.library-detail-panel.empty svg{width:42px;height:42px;color:var(--green);background:linear-gradient(145deg, var(--green-faint), transparent), var(--control-bg);border:1px solid color-mix(in srgb, var(--green) 22%, var(--line));box-sizing:content-box;box-shadow:var(--control-shadow);border-radius:14px;padding:9px}.food-empty strong{color:var(--text);font-size:16px}.food-empty span{max-width:280px;font-size:13px;line-height:1.5}.table-head{min-height:40px;color:var(--muted);background:color-mix(in srgb, var(--green-faint) 58%, var(--surface-soft));font-size:12px;font-weight:850}.food-name-cell{min-width:0;display:block}.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:8px;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);background:var(--surface);box-shadow:var(--control-shadow);border-radius:11px;grid-template-columns:28px minmax(34px,1fr) 28px 52px;align-items:center;display:grid;overflow:hidden}.grams-control button{height:32px;color:var(--muted);background:var(--control-bg);place-items:center;display:grid}.grams-control input{width:100%;height:32px;color:var(--text);text-align:center;background:var(--green-faint);border:0;border-right:1px solid var(--line);border-left:1px solid var(--line);outline:none;font-size:14px;font-weight:700}.grams-control select{width:100%;height:32px;color:var(--text);text-align:center;background:var(--control-bg);border:0;border-left:1px solid var(--line);outline:none;padding:0 4px;font-size:12px;font-weight:700}.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:5px;display:grid}.confidence-pill{max-width:100%;color:var(--green);text-overflow:ellipsis;white-space:nowrap;background:var(--green-soft);border:1px solid #c7ddcc;border-radius:999px;justify-self:start;padding:3px 6px;font-size:11px;line-height:1;overflow:hidden}.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.warn .confidence-pill{color:var(--amber);background:var(--amber-soft);border-color:color-mix(in srgb, var(--amber) 34%, var(--line))}.confidence-cell.warn .confidence-bar i{background:var(--amber)}.confidence-cell.alert .confidence-pill{color:var(--danger);background:var(--danger-soft);border-color:var(--danger-line)}.confidence-cell.alert .confidence-bar i{background:var(--danger)}.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:var(--control-bg);border:1px solid #0000;border-radius:10px;place-items:center;display:grid}.row-delete:hover{color:var(--danger);background:var(--danger-soft);border-color:var(--danger-line)}.table-actions,.summary-actions{gap:10px;margin-top:14px;display:flex}.review-strip{color:var(--amber);background:var(--amber-soft);border:1px solid color-mix(in srgb, var(--amber) 30%, var(--line));border-radius:var(--radius);grid-template-columns:auto 1fr auto;align-items:center;gap:10px;margin-top:16px;padding:12px;display:grid}.review-strip strong{color:var(--green-strong);font-size:13px;line-height:1.35;display:block}.review-strip span{color:var(--muted);margin-top:2px;font-size:12px;line-height:1.35;display:block}.review-strip button{height:32px;color:var(--amber);background:var(--surface);border:1px solid color-mix(in srgb, var(--amber) 34%, var(--line));border-radius:6px;align-items:center;gap:4px;padding:0 10px;font-size:12px;font-weight:700;display:inline-flex}.calorie-hero{color:var(--text);background:linear-gradient(135deg, var(--surface) 0%, var(--surface-soft) 72%, var(--green-soft) 100%);border:1px solid color-mix(in srgb, var(--green) 20%, var(--line));border-radius:var(--radius);grid-template-columns:auto 1fr auto;align-items:end;gap:8px;padding:18px;display:grid;position:relative;overflow:hidden}.calorie-hero:before{content:"";background:linear-gradient(180deg, var(--green), var(--amber));width:5px;position:absolute;inset:0 auto 0 0}.calorie-hero span{color:var(--green);grid-column:1/-1;font-size:13px;font-weight:820}.calorie-hero strong{color:var(--green-strong);letter-spacing:0;font-size:clamp(44px,5vw,64px);line-height:.95}.calorie-hero em{color:var(--muted);align-self:end;padding-bottom:7px;font-size:15px;font-style:normal;font-weight:850}.daily-goal-card{background:var(--blue-soft);border:1px solid color-mix(in srgb, var(--blue) 28%, var(--line));border-radius:var(--radius);gap:9px;margin-top:12px;padding:12px;display:grid}.daily-goal-card.over{background:var(--amber-soft);border-color:color-mix(in srgb, var(--amber) 30%, var(--line))}.daily-goal-topline,.daily-goal-metrics{justify-content:space-between;align-items:center;gap:8px;display:flex}.daily-goal-topline span,.daily-goal-metrics span{color:var(--muted);font-size:12px;font-weight:820}.daily-goal-topline strong{color:var(--blue);font-size:14px}.daily-goal-card.over .daily-goal-topline strong{color:var(--amber)}.goal-meter{background:color-mix(in srgb, var(--surface) 78%, var(--line));border:1px solid color-mix(in srgb, var(--blue) 16%, var(--line));border-radius:999px;height:9px;overflow:hidden}.goal-meter i{background:linear-gradient(90deg, var(--blue), var(--green));border-radius:inherit;height:100%;transition:width .3s;display:block}.daily-goal-card.over .goal-meter i{background:linear-gradient(90deg, var(--amber), var(--danger))}.daily-goal-metrics strong{color:var(--text);white-space:nowrap;font-size:12px}.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:center;gap:8px;min-height:0;padding:8px 10px 9px}.brand{gap:8px;min-width:auto}.brand-mark{border-radius:11px;width:34px;height:34px}.top-actions{justify-content:flex-end;gap:6px;width:auto;margin-left:auto}.mode-chip{justify-content:center;width:36px;height:34px;padding:0;font-size:0;overflow:hidden}.mode-chip svg{width:16px;height:16px}.nav-item{min-width:0;height:38px;padding:0 8px}.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}.toast-container{z-index:80;pointer-events:none;gap:8px;width:min(320px,100vw - 32px);display:grid;position:fixed;bottom:18px;right:18px}.toast-card{min-height:44px;color:var(--text);background:color-mix(in srgb, var(--surface) 96%, transparent);border:1px solid color-mix(in srgb, var(--green) 24%, var(--line));border-radius:var(--radius);pointer-events:auto;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px 10px 10px 13px;animation:.22s both toast-in;display:grid;box-shadow:0 14px 34px #1e2f3024}.toast-card span{text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:840;overflow:hidden}.toast-card button{width:26px;height:26px;color:var(--muted);background:var(--surface-soft);border:1px solid var(--line);border-radius:6px;place-items:center;display:grid}.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:3px solid color-mix(in srgb, var(--green) 22%, transparent);outline-offset:2px}@media (width>=1241px){.topbar{min-height:72px}.workspace{grid-template-columns:minmax(270px,.72fr) minmax(560px,1.52fr) minmax(300px,.82fr);align-items:stretch;height:min(820px,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:150px}.compact-mode .thumb,.compact-mode .thumb-action{height:58px}.compact-mode .thumb-action{height:34px;min-height:34px}.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 .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}.library-view-panel{flex-direction:column;height:calc(100vh - 120px);max-height:calc(100vh - 120px);display:flex;overflow:hidden}.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}.library-card strong{-webkit-line-clamp:2;white-space:normal;-webkit-box-orient:vertical;line-height:1.25;display:-webkit-box}.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(4,minmax(0,1fr))}.stat-tile{background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius);gap:8px;padding:14px;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(--blue), var(--green));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-workbench{flex:auto;grid-template-rows:auto minmax(0,1fr);gap:14px;min-height:0;display:grid}.library-filter-bar{background:color-mix(in srgb, var(--surface-soft) 76%, var(--surface) 24%);border:1px solid var(--line);border-radius:var(--radius);gap:10px;min-width:0;min-height:118px;padding:10px;display:grid}.library-search-field{background:var(--surface);min-height:42px}.library-filter-summary{min-width:0;display:block}.library-all-button{min-width:0;min-height:42px;color:var(--muted);text-align:left;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);grid-template-columns:auto minmax(0,1fr);grid-template-areas:"icon label""icon meta";align-items:center;gap:2px 8px;padding:8px 10px;display:grid}.library-all-button svg{grid-area:icon}.library-all-button span,.library-all-button em{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.library-all-button span{color:var(--text);grid-area:label;font-size:13px;font-weight:760}.library-all-button em{color:var(--muted);grid-area:meta;font-size:11px;font-style:normal;font-weight:760}.library-all-button.active{color:var(--green);background:var(--green-soft);border-color:color-mix(in srgb, var(--green) 34%, var(--line));box-shadow:inset 3px 0 0 var(--green)}.library-category-tabs,.library-category-row{-webkit-mask-image:linear-gradient(90deg,#000 calc(100% - 28px),#0000);mask-image:linear-gradient(90deg,#000 calc(100% - 28px),#0000)}.library-category-tabs{overscroll-behavior-x:contain;scrollbar-width:none;gap:8px;min-width:0;padding:2px 2px 4px;display:flex;overflow:auto hidden}.library-category-tabs::-webkit-scrollbar{display:none}.library-category-tabs button{min-width:72px;min-height:36px;color:var(--muted);background:var(--surface);border:1px solid var(--line);border-radius:7px;flex:none;padding:0 12px;font-size:13px;font-weight:700}.library-category-tabs button.active{color:var(--on-accent);background:var(--green);border-color:var(--green);box-shadow:0 5px 12px color-mix(in srgb, var(--green) 14%, transparent)}.library-subfilter{grid-template-columns:auto minmax(0,1fr);align-items:center;gap:10px;min-width:0;min-height:36px;display:grid}.library-subfilter>span{color:var(--muted);font-size:12px;font-weight:840}.library-category-row{overscroll-behavior-x:contain;scrollbar-width:none;gap:8px;padding-bottom:2px;display:flex;overflow-x:auto}.library-category-row::-webkit-scrollbar{display:none}.library-category-row button{min-height:34px;color:var(--muted);background:var(--surface-soft);border:1px solid var(--line);border-radius:999px;flex:none;padding:0 12px;font-size:13px;font-weight:820}.library-category-row button.active{color:var(--on-accent);background:linear-gradient(135deg, var(--green-strong), var(--amber));border-color:#0000}.library-category-row.sub{margin-top:0}.library-category-row.sub button{background:var(--surface);min-height:30px;padding:0 10px;font-size:12px}.library-category-row.sub button.active{color:var(--on-accent);background:var(--green);border-color:var(--green);box-shadow:0 5px 12px color-mix(in srgb, var(--green) 16%, transparent)}.library-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));margin-top:14px}.library-meta{color:var(--muted);flex-wrap:wrap;gap:8px 14px;margin-top:10px;font-size:12px;font-weight:760;display:flex}.library-layout{grid-template-rows:minmax(0,1fr);grid-template-columns:minmax(0,1.18fr) minmax(280px,.82fr);align-items:stretch;gap:14px;height:100%;min-height:0;margin-top:0;display:grid;overflow:hidden}.library-list-panel,.library-list{min-width:0;display:grid}.library-list-panel{grid-template-rows:auto minmax(0,1fr);gap:10px;min-height:0;overflow:hidden}.library-list{overscroll-behavior:contain;scrollbar-gutter:stable;scrollbar-width:thin;scrollbar-color:var(--line-strong) transparent;grid-auto-rows:max-content;align-content:start;gap:8px;min-height:0;padding-right:4px;overflow-y:auto}.library-row{background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius);min-width:0;min-height:52px;animation:.24s both library-row-in;animation-delay:calc(min(var(--row-index,0), 12) * 18ms);grid-template-columns:minmax(0,1fr) minmax(124px,max-content);align-items:center;gap:8px;padding:8px 10px;display:grid}.library-row.active{background:var(--green-soft);border-color:color-mix(in srgb, var(--green) 38%, var(--line));box-shadow:inset 3px 0 0 var(--green)}.library-row.active:hover{background:var(--green-soft)}html.dark-mode .library-row,.dark-mode .library-row{background:color-mix(in srgb, var(--surface) 86%, #203229);border-color:color-mix(in srgb, var(--line) 72%, #6fb58c)}html.dark-mode .library-row.active,.dark-mode .library-row.active{background:color-mix(in srgb, var(--green) 18%, var(--surface));border-color:color-mix(in srgb, var(--green) 44%, var(--line))}html.dark-mode .library-row-title strong,.dark-mode .library-row-title strong{color:#eef5f0}html.dark-mode .library-row-title small,.dark-mode .library-row-title small,html.dark-mode .library-row-facts,.dark-mode .library-row-facts{color:#aab8af}html.dark-mode .library-row-side b,.dark-mode .library-row-side b{color:#6cc79d}html.dark-mode .row-add-button,.dark-mode .row-add-button{color:#7fd4a8;border-color:color-mix(in srgb, #7fd4a8 44%, var(--line));background:#111a15}.library-row-title,.library-row-title strong,.library-row-title small,.library-row-facts,.library-row-facts em,.library-row-facts span,.library-row-side b,.library-detail-head span,.library-detail-head p,.library-detail-head em{cursor:default;-webkit-user-select:none;user-select:none}.library-row-main{min-width:0;color:var(--text);text-align:left;background:0 0;border:0;flex-direction:column;gap:3px;padding:0;display:flex}.library-row-title{flex-wrap:nowrap;align-items:baseline;gap:7px;min-width:0;display:flex}.library-row-title strong{min-width:0;max-width:min(64%,340px);font-family:var(--font-cn);text-overflow:ellipsis;white-space:nowrap;flex:auto;font-size:15px;font-weight:760;line-height:1.25;overflow:hidden}.library-row-title small{color:#8a9991;min-width:0;max-width:38%;font-family:var(--font-en);text-overflow:ellipsis;white-space:nowrap;flex:0 auto;font-size:11px;font-weight:500;line-height:1.2;overflow:hidden}.library-row-facts{min-width:0;color:var(--muted);white-space:nowrap;align-items:center;gap:5px;font-size:11px;font-weight:640;display:flex;overflow:hidden}.library-row-facts em,.library-row-facts span{flex:none;font-style:normal}.library-row-facts em{max-width:72px;color:var(--green);text-overflow:ellipsis;overflow:hidden}.library-row-side{justify-content:end;align-items:center;gap:7px;min-width:124px;display:flex}.library-row-side b{width:76px;color:var(--green);font-family:var(--font-number);text-align:right;white-space:nowrap;font-size:11px;font-weight:700;line-height:1}.row-add-button{min-width:48px;height:30px;color:var(--green);background:var(--green-faint);border:1px solid color-mix(in srgb, var(--green) 36%, var(--line));box-shadow:var(--control-shadow);border-radius:999px;flex:none;padding:0 10px;font-size:12px;font-weight:850}.library-detail-panel{overscroll-behavior:contain;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);scrollbar-width:thin;scrollbar-color:var(--line-strong) transparent;align-content:start;align-self:stretch;gap:12px;min-width:0;height:100%;max-height:100%;padding:14px;animation:.2s both detail-panel-in;display:grid;position:relative;top:auto;overflow-y:auto;box-shadow:0 12px 34px #1e2f300f}.library-detail-panel.empty{min-height:180px;color:var(--muted);text-align:center;place-items:center}.library-mobile-detail-backdrop{display:none}.library-detail-head{grid-template-columns:1fr auto;align-items:center;gap:6px 10px;display:grid}.library-detail-head>span{color:var(--green);font-size:12px;font-weight:850}.library-detail-status{color:var(--green);justify-self:end;align-items:center;gap:7px;display:inline-flex}.library-detail-close{width:30px;height:30px;color:var(--muted);background:var(--surface-soft);border:1px solid var(--line);border-radius:8px;place-items:center;display:inline-grid}.library-detail-close:hover{color:var(--text);background:var(--surface-muted)}.library-detail-head h3{color:var(--text);letter-spacing:0;grid-column:1/-1;margin:0;font-size:22px;line-height:1.18}.library-detail-head p,.library-detail-head em{color:var(--muted);text-overflow:ellipsis;grid-column:1/-1;margin:0;font-size:12px;font-style:normal;font-weight:720;line-height:1.4;overflow:hidden}.tag-row span{color:var(--green);background:var(--green-soft);border-radius:999px;padding:5px 8px;font-size:12px;font-weight:820}.library-detail-metrics{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.library-detail-metrics div{background:var(--surface-soft);border:1px solid var(--line);border-radius:7px;gap:5px;padding:10px;display:grid}.library-detail-metrics span,.component-head strong{color:var(--muted);font-size:12px;font-weight:820}.library-detail-metrics strong{color:var(--text);font-size:15px}.component-list{gap:6px;display:grid}.component-head{justify-content:space-between;align-items:center;gap:10px;display:flex}.component-head span{color:var(--muted);font-size:12px;font-weight:820}.component-group-pills{flex-wrap:wrap;gap:6px;display:flex}.component-group-pills span{background:var(--surface-soft);border:1px solid var(--line);border-radius:999px;align-items:center;gap:5px;padding:5px 8px;display:inline-flex}.component-group-pills b{color:var(--text);font-size:12px;font-weight:820}.component-group-pills em{color:var(--muted);font-size:11px;font-style:normal;font-weight:760}.component-sections{gap:8px;display:grid}.component-group{border-top:1px solid var(--line);gap:6px;padding-top:8px;display:grid}.component-group strong{color:var(--text);font-size:13px;font-weight:820}.component-group div{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;min-width:0;padding:5px 0;display:grid}.component-group span{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:760;overflow:hidden}.component-group b{color:var(--muted);font-size:12px}.modal-panel .library-detail-panel{position:static}.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}.library-card small{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;margin-top:5px;font-size:11px;font-weight:680;line-height:1.35;display:block;overflow:hidden}.modal-backdrop{z-index:50;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);overscroll-behavior:contain;background:#121b1661;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.modal-panel{overscroll-behavior:contain;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-panel.modal-wide{width:min(920px,100%)}.modal-panel.modal-profile{width:min(920px,100vw - 48px)}.modal-panel.modal-library{flex-direction:column;width:min(1180px,100vw - 48px);height:min(860px,100vh - 48px);display:flex;overflow:hidden}.modal-library .modal-heading{flex:none}.modal-library .library-workbench{flex:auto;min-height:0}.modal-library .library-layout{min-height:0}.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}.settings-stack{grid-template-columns:minmax(0,1fr) minmax(280px,.82fr);align-items:start;gap:12px;display:grid}.settings-section,.cloud-data-panel{background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius);gap:10px;padding:14px;display:grid}.settings-section-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.settings-section-head strong{color:var(--text);font-size:15px;font-weight:820}.settings-section-head span{color:var(--muted);white-space:nowrap;font-size:12px;font-weight:760}.data-action-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.data-action-grid button:first-child:last-child,.data-action-grid button:nth-child(3){grid-column:1/-1}.image-store-meta{min-height:38px;color:var(--muted);background:var(--surface);border:1px solid var(--line);border-radius:8px;justify-content:space-between;align-items:center;gap:10px;padding:9px 12px;display:flex}.image-store-meta span,.image-store-meta strong{font-size:12px;font-weight:780}.image-store-meta strong{color:var(--text)}.ghost-button.danger{color:var(--danger);background:var(--danger-soft);border-color:var(--danger-line)}.cloud-data-panel .secondary-button,.settings-section>.secondary-button{width:100%}.profile-modal-grid{grid-template-columns:minmax(260px,.8fr) minmax(0,1.2fr);align-items:start;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}.account-panel{background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius);gap:10px;padding:14px;display:grid}.account-status{color:var(--muted);font-size:12px;font-weight:760;line-height:1.4}.account-heading{align-items:center;gap:10px;display:flex}.account-heading span{gap:2px;display:grid}.account-heading strong,.account-panel small{color:var(--text)}.account-heading em,.auth-field span{color:var(--muted);font-size:12px;font-style:normal;font-weight:780}.profile-panel{gap:0;display:grid;position:relative}.profile-dossier{background:0 0;border:0}.profile-file-tab{min-width:164px;color:var(--green-strong);letter-spacing:0;background:linear-gradient(135deg, var(--green-soft), var(--surface-soft));border:1px solid var(--line);border-bottom:0;border-radius:10px 10px 0 0;justify-self:start;margin-left:14px;padding:9px 18px 10px;font-size:13px;font-weight:850}.profile-file-card{background:linear-gradient(90deg, color-mix(in srgb, var(--green) 8%, transparent), transparent 34%), var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-md);border-radius:10px;gap:14px;padding:18px;display:grid}.profile-head-row{grid-template-columns:84px minmax(0,1fr) max-content;align-items:center;gap:14px;display:grid}.avatar-editor{width:84px;height:84px;color:var(--green);background:radial-gradient(circle at 42% 28%, color-mix(in srgb, var(--green) 16%, transparent), transparent 52%), linear-gradient(145deg, var(--surface), var(--green-faint));border:1px solid color-mix(in srgb, var(--green) 30%, var(--line));border-radius:22px;place-items:center;font-size:30px;font-weight:900;display:grid;position:relative;overflow:hidden}.avatar-editor>svg{color:var(--green);filter:drop-shadow(0 8px 16px color-mix(in srgb, var(--green) 16%, transparent))}.avatar-editor img{object-fit:cover;width:100%;height:100%}.avatar-editor i{width:28px;height:28px;color:var(--on-accent);background:var(--green);border:2px solid var(--surface);border-radius:50%;place-items:center;display:grid;position:absolute;bottom:7px;right:7px}.profile-identity{gap:8px;min-width:0;display:grid}.profile-name-field{gap:6px;display:grid}.profile-name-field span,.profile-subline span,.profile-account-chip,.danger-zone-head span,.delete-confirm-row>span{color:var(--muted);font-size:12px;font-weight:780}.profile-name-field input{width:min(360px,100%);min-height:42px;color:var(--text);background:var(--surface-soft);border:1px solid var(--line);border-radius:9px;padding:0 12px;font-size:18px;font-weight:850}.profile-name-field input:focus,.profile-field input:focus,.delete-confirm-row input:focus{border-color:color-mix(in srgb, var(--green) 46%, var(--line));box-shadow:0 0 0 3px color-mix(in srgb, var(--green) 14%, transparent)}.profile-subline{flex-wrap:wrap;align-items:center;gap:8px 12px;min-width:0;display:flex}.profile-subline strong{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:15px;font-weight:850;overflow:hidden}.profile-account-chip{min-height:34px;color:var(--green);background:var(--green-soft);border:1px solid color-mix(in srgb, var(--green) 30%, var(--line));white-space:nowrap;border-radius:999px;align-items:center;gap:6px;padding:0 11px;display:inline-flex}.profile-metrics{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;display:grid}.profile-metrics div{background:var(--surface-soft);border:1px solid var(--line);border-radius:8px;gap:4px;min-width:0;padding:11px;display:grid}.profile-metrics span,.profile-control>span,.profile-field>span{color:var(--muted);font-size:12px;font-weight:820}.profile-metrics strong{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:17px;line-height:1;overflow:hidden}.profile-metrics em{color:var(--muted);font-size:11px;font-style:normal;font-weight:760}.profile-form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.profile-dossier-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.profile-control,.profile-field{gap:6px;min-width:0;display:grid}.profile-control.wide{grid-column:span 2}.profile-field input{width:100%;min-height:40px;color:var(--text);background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);outline:none;padding:0 12px;font-weight:820}.profile-segment{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);grid-auto-columns:minmax(0,1fr);grid-auto-flow:column;padding:3px;display:grid}.profile-segment button{min-height:32px;color:var(--muted);background:0 0;border:0;border-radius:6px;padding:0 8px;font-weight:820}.profile-segment button.active{color:var(--green);background:var(--green-soft)}.profile-action-row{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.profile-action-row button{white-space:nowrap;width:100%;min-width:0}.danger-zone .profile-action-row{grid-template-columns:repeat(2,minmax(0,1fr))}.profile-privacy-block,.danger-zone{background:var(--surface-soft);border:1px solid var(--line);border-radius:9px;gap:10px;padding:13px;display:grid}.profile-privacy-block summary{color:var(--text);cursor:pointer;align-items:center;gap:7px;font-size:14px;font-weight:850;display:inline-flex}.profile-privacy-block ol{color:var(--muted);gap:6px;margin:8px 0 0;padding-left:20px;font-size:13px;line-height:1.55;display:grid}.danger-zone{background:color-mix(in srgb, var(--danger-soft) 42%, var(--surface-soft));border-color:var(--danger-line)}.danger-zone-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.danger-zone-head strong{color:var(--danger);font-size:14px}.delete-confirm-row{gap:8px;display:grid}.delete-confirm-row div{grid-template-columns:minmax(0,1fr) max-content;gap:8px;display:grid}.delete-confirm-row input{min-height:40px;color:var(--text);background:var(--surface);border:1px solid var(--danger-line);border-radius:8px;padding:0 11px}.danger-button{color:#fff;background:var(--danger);border-radius:8px;justify-content:center;align-items:center;gap:7px;min-height:40px;padding:0 12px;font-weight:850;display:inline-flex}.danger-button:disabled{opacity:.58}.sync-row{color:var(--text);background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius);justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;display:flex}.sync-row span,.sync-row strong{font-size:12px;font-weight:820}.sync-row span{color:var(--green)}.sync-row strong{color:var(--muted)}.account-mode-switch{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);grid-template-columns:1fr 1fr;gap:6px;padding:4px;display:grid}.account-mode-switch button{min-height:34px;color:var(--muted);background:0 0;border:0;border-radius:6px;font-weight:820}.account-mode-switch button.active{color:var(--green);background:var(--green-soft)}.model-settings-section{align-self:stretch}.model-provider-tabs{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;display:grid}.model-provider-tabs button{min-height:34px;color:var(--muted);text-overflow:ellipsis;white-space:nowrap;background:var(--surface);border:1px solid var(--line);border-radius:7px;padding:0 8px;font-size:12px;font-weight:820;overflow:hidden}.model-provider-tabs button.active{color:var(--green);background:var(--green-soft);border-color:color-mix(in srgb, var(--green) 36%, var(--line))}.auth-field{gap:6px;display:grid}.auth-field input{width:100%;min-height:42px;color:var(--text);background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:0 12px}.toggle-row{background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius);cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;gap:16px;min-height:48px;padding:12px 14px;display:flex}.toggle-row>span:first-child{color:var(--text);font-size:14px;font-weight:760}.toggle-row input{clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap;width:1px;height:1px;position:absolute;overflow:hidden}.toggle-switch{background:color-mix(in srgb, var(--muted) 14%, var(--surface));border:1px solid var(--line);width:46px;height:26px;box-shadow:var(--control-shadow);border-radius:999px;flex:none;padding:3px;transition:background-color .18s,border-color .18s,box-shadow .18s;position:relative}.toggle-switch span{background:var(--surface);border:1px solid color-mix(in srgb, var(--line-strong) 76%, var(--surface));border-radius:50%;width:18px;height:18px;transition:transform .18s,background-color .18s;display:block;box-shadow:0 3px 8px #1229271f}.toggle-row input:checked+.toggle-switch{background:linear-gradient(135deg, var(--green), var(--green-strong));box-shadow:var(--button-shadow);border-color:#0000}.toggle-row input:checked+.toggle-switch span{background:var(--on-accent);transform:translate(20px)}.toggle-row:focus-within{border-color:color-mix(in srgb, var(--green) 42%, var(--line));box-shadow:0 0 0 3px color-mix(in srgb, var(--green) 12%, transparent)}.toggle-row input:disabled+.toggle-switch{cursor:not-allowed;opacity:.64}.number-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:50px;padding:12px 14px;display:flex}.number-row span{color:var(--text);-webkit-user-select:none;user-select:none;font-size:14px;font-weight:760}.number-row div{background:var(--surface);border:1px solid var(--line);border-radius:7px;grid-template-columns:92px auto;align-items:center;display:inline-grid;overflow:hidden}.number-row input{width:92px;height:34px;color:var(--text);text-align:right;background:0 0;border:0;outline:none;padding:0 8px;font-size:14px;font-weight:700}.number-row em{color:var(--muted);-webkit-user-select:none;user-select:none;padding:0 9px 0 2px;font-size:12px;font-style:normal;font-weight:620}.summary-detail{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.backup-actions{grid-template-columns:1fr 1fr;gap:10px;display:grid}.backup-actions button:first-child,.backup-actions button:last-of-type{grid-column:1/-1}.primary-summary-actions{grid-template-columns:1fr auto;display:grid}.summary-task-switch{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-top:14px;display:grid}.summary-task-switch button{min-width:0;min-height:52px;color:var(--muted);text-align:left;background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius);gap:3px;padding:8px;display:grid}.summary-task-switch button.active{color:var(--green);background:var(--green-soft);border-color:#bfd9c5}.summary-task-switch span{color:inherit;font-size:13px;font-weight:880}.summary-task-switch em{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:11px;font-style:normal;font-weight:760;overflow:hidden}.summary-brief{background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius);grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:14px;padding:12px;display:grid}.summary-brief div{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);gap:4px;padding:10px;display:grid}.summary-brief span{color:var(--muted);font-size:12px;font-weight:780}.summary-brief strong{color:var(--text);font-size:14px}.summary-brief p{color:var(--muted);grid-column:1/-1;margin:0;font-size:12px;line-height:1.45}.meal-tip-list{gap:8px;margin-top:10px;display:grid}.meal-tip{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);border-left-width:4px;gap:4px;padding:10px 11px;display:grid}.meal-tip.good{border-left-color:var(--green)}.meal-tip.warn{border-left-color:var(--amber)}.meal-tip.alert{border-left-color:var(--red)}.meal-tip strong{color:var(--text);font-size:13px}.meal-tip span{color:var(--muted);font-size:12px;line-height:1.42}.leftover-panel{background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius);gap:12px;margin-top:16px;padding:14px;display:grid}.leftover-heading{justify-content:space-between;align-items:center;gap:10px;display:flex}.leftover-heading span,.leftover-meta,.leftover-summary span,.leftover-item em{color:var(--muted);font-size:12px;font-weight:780}.leftover-heading strong{color:var(--text);margin-top:3px;font-size:14px;line-height:1.25;display:block}.leftover-upload{min-height:96px;color:var(--green);background:var(--green-soft);border:1px dashed color-mix(in srgb, var(--green) 36%, var(--line));border-radius:var(--radius);cursor:pointer;-webkit-user-select:none;user-select:none;place-items:center;display:grid;position:relative;overflow:hidden}.leftover-upload input{opacity:0;cursor:pointer;position:absolute;inset:0}.leftover-upload img{object-fit:cover;width:100%;height:120px}.leftover-upload span{align-items:center;gap:8px;font-size:13px;font-weight:700;display:inline-flex}.leftover-meta{justify-content:space-between;gap:8px;display:flex}.leftover-meta strong{color:var(--amber);text-align:right;font-size:12px}.leftover-summary{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.leftover-summary div{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);gap:4px;padding:10px;display:grid}.leftover-summary strong{color:var(--text);font-size:16px;line-height:1}.leftover-item-list{gap:10px;display:grid}.leftover-item{gap:7px;display:grid}.leftover-item>span{justify-content:space-between;gap:8px;display:flex}.leftover-item strong{min-width:0;color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:820;overflow:hidden}.leftover-item input{width:100%;accent-color:var(--green)}.leftover-item-control{grid-template-columns:minmax(0,1fr) 58px;align-items:center;gap:9px;display:grid}.leftover-percent-field{height:32px;color:var(--muted);background:var(--surface);border:1px solid var(--line);border-radius:6px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:3px;padding:0 7px;font-size:12px;font-weight:700;display:grid}.leftover-percent-field input{min-width:0;color:var(--text);text-align:right;background:0 0;border:0;outline:none;font-size:13px;font-weight:850}.leftover-actions{grid-template-columns:1fr;gap:8px;display:grid}.records-view,.stats-view{align-content:start;gap:18px;display:grid}.record-toolbar{grid-template-columns:minmax(240px,1fr) auto auto auto auto;align-items:center;gap:10px;display:grid}.record-search{min-width:0}.segmented-control{background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius);grid-auto-flow:column;display:inline-grid;overflow:hidden}.segmented-control button{min-height:42px;color:var(--muted);white-space:nowrap;border-left:1px solid var(--line);background:0 0;padding:0 12px;font-size:13px;font-weight:850}.segmented-control button:first-child{border-left:0}.segmented-control button.active{color:var(--on-accent);background:var(--green)}.select-filter{min-height:42px;color:var(--muted);background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;align-items:center;gap:8px;padding:0 10px;display:inline-flex}.select-filter.full{width:100%}.select-filter select{appearance:none;width:100%;min-width:0;color:var(--text);background:linear-gradient(45deg,#0000 50%,currentColor 50%) right 7px center/6px 6px no-repeat,linear-gradient(135deg,currentColor 50%,#0000 50%) right 3px center/6px 6px no-repeat;border:0;outline:none;padding-right:18px;font-size:13px;font-weight:820}.select-filter option{color:var(--text);background:var(--surface)}html.dark-mode .select-filter,.dark-mode .select-filter{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;background:var(--surface-muted)}html.dark-mode .select-filter select,.dark-mode .select-filter select{color:var(--text)}html.dark-mode .select-filter option,.dark-mode .select-filter option{color:var(--text);background:var(--surface)}.records-kpis{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.records-layout{grid-template-columns:minmax(0,1.55fr) minmax(320px,.9fr);align-items:start;gap:14px;display:grid}.record-table-card,.record-detail,.analytics-panel{background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius);min-width:0}.record-table-card{overflow:hidden}.record-table-head{color:var(--muted);border-bottom:1px solid var(--line);grid-template-columns:minmax(0,1fr) 90px 96px 84px;gap:10px;padding:12px 14px;font-size:12px;font-weight:850;display:grid}.record-list{overscroll-behavior:contain;max-height:min(58vh,640px);display:grid;overflow-y:auto}.record-row{border-top:1px solid var(--line);grid-template-columns:minmax(0,1fr) 90px 96px 84px;align-items:center;gap:10px;min-height:72px;padding:10px 14px;display:grid}.record-row:first-child{border-top:0}.record-row.active{background:var(--green-soft)}.record-main{min-width:0;color:inherit;text-align:left;background:0 0}.record-main strong{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:850;display:block;overflow:hidden}.record-main em{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;margin-top:4px;font-size:12px;font-style:normal;font-weight:760;display:block;overflow:hidden}.meal-chip{color:var(--green);background:var(--surface);border:1px solid #cce0d0;border-radius:999px;justify-self:start;padding:5px 8px;font-size:12px;font-weight:700}.record-row b{color:var(--text);font-size:14px}.record-row-actions{gap:6px;display:flex}.record-row-actions button{width:32px;height:32px;color:var(--muted);background:var(--surface);border:1px solid var(--line);border-radius:6px;place-items:center;display:grid}.record-row-actions button:hover{color:var(--text);border-color:var(--line-strong)}.record-detail{gap:12px;padding:14px;display:grid}.record-detail-heading span,.analytics-heading,.trend-extremes span,.distribution-row span{color:var(--muted);font-size:12px;font-weight:820}.record-detail-heading strong{color:var(--text);margin-top:4px;font-size:18px;line-height:1.25;display:block}.detail-edit-field{gap:7px;display:grid}.detail-edit-field span{color:var(--muted);font-size:12px;font-weight:820}.detail-edit-field input,.detail-edit-field textarea{width:100%;color:var(--text);background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);outline:none;padding:10px 11px;font-size:13px;font-weight:780;line-height:1.45}.detail-edit-field input:focus,.detail-edit-field textarea:focus{border-color:color-mix(in srgb, var(--green) 50%, var(--line));box-shadow:0 0 0 3px color-mix(in srgb, var(--green) 16%, transparent)}.detail-status-switch{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.detail-status-switch button{min-height:38px;color:var(--muted);background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);font-size:13px;font-weight:700}.detail-status-switch button.active{color:var(--on-accent);background:var(--blue);border-color:var(--blue)}.detail-metrics{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.detail-metrics .stat-tile{padding:12px}.detail-metrics .stat-tile strong{font-size:17px}.tag-row{flex-wrap:wrap;gap:7px;display:flex}.tag-row span{color:var(--muted);background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:5px 8px;font-size:12px;font-weight:700}.difference-note{color:var(--green);background:var(--green-soft);border:1px solid color-mix(in srgb, var(--green) 28%, var(--line));border-radius:var(--radius);align-items:flex-start;gap:8px;padding:11px;display:flex}.difference-note span{color:var(--green);font-size:13px;font-weight:780;line-height:1.45}.detail-foods{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);max-height:230px;display:grid;overflow-y:auto}.detail-foods div{border-top:1px solid var(--line);justify-content:space-between;gap:12px;padding:10px 12px;display:flex}.detail-foods div:first-child{border-top:0}.detail-foods span,.detail-foods strong{font-size:13px;font-weight:820}.detail-foods span{min-width:0;color:var(--text);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.detail-actions{grid-template-columns:1fr auto;gap:8px;display:grid}.empty-state{color:var(--muted);text-align:center;justify-items:center;gap:7px;padding:28px 16px;display:grid}.empty-state strong{color:var(--text);font-size:15px}.empty-state span{max-width:280px;font-size:13px;line-height:1.45}.analytics-layout{grid-template-columns:minmax(0,1.4fr) minmax(280px,.8fr);align-items:start;gap:14px;display:grid}.analysis-toolbar{background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius);grid-template-columns:minmax(260px,1fr) minmax(140px,auto) auto;align-items:center;gap:14px;margin-bottom:14px;padding:10px;display:grid}.analysis-toolbar .segmented-control{width:100%}.analysis-toolbar>span{color:var(--muted);white-space:nowrap;font-size:12px;font-weight:820}.analysis-select{background:var(--surface);min-height:38px}.trend-panel{grid-row:span 2;min-width:0}.analytics-panel{gap:14px;min-width:0;padding:16px;display:grid}.analytics-heading{align-items:center;gap:8px;display:flex}.analytics-heading strong{color:var(--text);font-size:15px}.trend-chart{grid-template-columns:repeat(var(--trend-count,14), minmax(36px, 1fr));background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);scrollbar-width:thin;scrollbar-color:var(--line-strong) transparent;align-items:end;gap:8px;width:100%;min-width:0;max-width:100%;min-height:190px;padding:12px;display:grid;overflow:auto hidden}.timeline-chart{position:relative}.timeline-chart:before{content:"";background:color-mix(in srgb, var(--green) 26%, var(--line));opacity:.72;height:1px;position:absolute;bottom:40px;left:12px;right:12px}.trend-day{text-align:center;grid-template-rows:24px 1fr 18px;align-items:end;gap:6px;min-width:36px;min-height:160px;display:grid}.timeline-day{z-index:1;position:relative}.timeline-bar-shell{justify-content:center;align-items:end;min-height:108px;display:flex}.trend-chart .empty-state{grid-column:1/-1;align-self:center}.trend-day span,.trend-day em{color:var(--muted);font-size:11px;font-style:normal;font-weight:800}.trend-day i,.timeline-stack{background:linear-gradient(180deg, var(--blue), var(--green));border-radius:6px 6px 2px 2px;width:100%;min-height:8px;display:block}.timeline-stack{border:1px solid color-mix(in srgb, var(--line) 80%, transparent);background:0 0;flex-direction:column-reverse;display:flex;overflow:hidden}.timeline-stack b{min-height:3px;display:block}.timeline-stack .protein{background:var(--green)}.timeline-stack .carbs{background:var(--blue)}.timeline-stack .fat{background:var(--amber)}.trend-day.over i{background:linear-gradient(180deg, var(--amber), var(--danger))}.trend-day.empty i,.trend-day.empty .timeline-stack{background:var(--line-strong);opacity:.38;min-height:2px}.trend-day.empty .timeline-stack b{display:none}.trend-extremes{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.trend-extremes div{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);gap:5px;padding:12px;display:grid}.trend-extremes strong{color:var(--text);font-size:14px}.macro-daily-strip{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.macro-daily-strip div{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);gap:4px;padding:11px 12px;display:grid}.macro-daily-strip span{color:var(--muted);font-size:11px;font-weight:820}.macro-daily-strip strong{color:var(--text);font-size:15px}.meal-distribution{gap:12px;display:grid}.distribution-row{grid-template-columns:54px minmax(0,1fr) 74px;align-items:center;gap:10px;display:grid}.distribution-row i{background:linear-gradient(90deg, var(--blue), var(--green));border-radius:999px;height:12px;display:block}.distribution-row strong{color:var(--text);text-align:right;font-size:12px}.ranked-bars{gap:12px;display:grid}.ranked-row{grid-template-columns:minmax(72px,.85fr) minmax(0,1.4fr) 78px;align-items:center;gap:10px;display:grid}.ranked-row span{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:820;overflow:hidden}.ranked-row i{background:linear-gradient(90deg, var(--blue), var(--green));border-radius:999px;height:12px;display:block}.ranked-row strong{color:var(--muted);text-align:right;font-size:12px;font-weight:820}.nutrition-split .macro-bar{grid-template-columns:64px minmax(0,1fr) 44px;gap:9px}.nutrition-split .macro-bar em{color:var(--muted);grid-column:2/-1;margin-top:-8px;font-size:11px;font-style:normal;font-weight:760}.empty-state.compact{padding:18px 12px}.panel{animation:.34s cubic-bezier(.2,.8,.2,1) both panel-reveal}.capture-panel{animation-delay:20ms}.recognition-panel{animation-delay:60ms}.summary-panel{animation-delay:.1s}.primary-button,.secondary-button,.ghost-button,.theme-toggle,.plain-icon,.profile-button,.mode-chip,.nav-item,.capture-mode-switch button,.summary-task-switch button,.detail-status-switch button,.template-row button,.record-row,.library-card,.library-row,.row-add-button,.profile-segment button,.record-card,.food-row:not(.table-head),.history-item,.leftover-upload,.dropzone,.thumb-action{transition:transform .18s,box-shadow .18s,border-color .18s,background-color .18s,color .18s,opacity .18s}.primary-button:hover,.secondary-button:hover,.ghost-button:hover,.theme-toggle:hover,.plain-icon:hover,.profile-button:hover,.mode-chip:hover,.capture-mode-switch button:hover,.summary-task-switch button:hover,.detail-status-switch button:hover,.template-row button:hover,.record-card:hover,.library-card:hover,.library-row:hover,.history-item:hover,.thumb-action:hover{transform:translateY(-1px)}.primary-button:hover,.secondary-button:hover{box-shadow:0 14px 30px color-mix(in srgb, var(--green) 22%, transparent)}.primary-button:active,.secondary-button:active,.ghost-button:active,.theme-toggle:active,.plain-icon:active,.profile-button:active,.mode-chip:active,.nav-item:active,.capture-mode-switch button:active,.summary-task-switch button:active,.detail-status-switch button:active,.template-row button:active,.row-add-button:active,.thumb-action:active{transform:translateY(0)scale(.985)}.nav-item:hover:not(.active){color:var(--text);background:color-mix(in srgb, var(--green) 9%, transparent)}.dropzone:hover,.leftover-upload:hover{border-color:color-mix(in srgb, var(--green) 48%, var(--line));box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--green) 16%, transparent)}.food-row:not(.table-head):hover,.record-row:hover,.library-row:hover{background:var(--surface-muted)}.calorie-hero{background:linear-gradient(135deg, var(--surface) 0%, var(--surface-soft) 72%, var(--green-soft) 100%);box-shadow:0 12px 28px color-mix(in srgb, var(--green) 12%, transparent)}.calorie-hero strong{text-shadow:none}.summary-brief,.leftover-panel,.factor-list,.history-block,.manual-box{animation:.24s both content-rise}.trend-day i,.distribution-row i,.macro-bar i,.confidence-bar i{transition:width .28s,height .34s}.modal-panel{animation:.22s both modal-in}@keyframes panel-reveal{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes content-rise{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes library-row-in{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}@keyframes detail-panel-in{0%{opacity:0;transform:translate(6px)}to{opacity:1;transform:translate(0)}}@keyframes mobile-sheet-in{0%{opacity:0;transform:translateY(18px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes sheet-backdrop-in{0%{opacity:0}to{opacity:1}}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes modal-in{0%{opacity:0;transform:translateY(10px)scale(.99)}to{opacity:1;transform:translateY(0)scale(1)}}.macro-chart.compact{background:0 0;border:0;margin-top:0;padding:0}@media (width<=1240px){.panel-scroll{overflow:visible}}@media (width<=980px){.stats-grid,.trend-extremes{grid-template-columns:repeat(2,minmax(0,1fr))}.analysis-toolbar{grid-template-columns:1fr;align-items:stretch}.analysis-toolbar .segmented-control{width:100%}.macro-daily-strip{grid-template-columns:1fr}}@media (width<=760px){.view-shell{width:min(100% - 24px,680px);margin:12px auto 24px}.view-panel{min-height:auto;padding:16px}.library-view-panel{flex-direction:column;height:calc(100dvh - 196px);min-height:0;max-height:calc(100dvh - 196px);display:flex;overflow:hidden}.view-heading,.record-card{grid-template-columns:1fr}.view-heading{display:grid}.library-view-panel .view-heading{align-items:center;margin-bottom:12px;display:flex}.library-view-panel .view-heading h1{font-size:24px}.library-view-panel .view-heading .ghost-button{min-height:38px;padding:0 12px}.stats-grid,.summary-detail{grid-template-columns:1fr}.macro-bar{grid-template-columns:64px minmax(0,1fr) 58px}.leftover-summary,.leftover-actions,.primary-summary-actions,.records-kpis,.records-layout,.detail-metrics,.detail-actions,.settings-stack,.library-filter-summary,.library-layout,.profile-head-row,.profile-modal-grid,.profile-form-grid,.profile-dossier-grid,.profile-action-row,.analytics-layout,.trend-extremes{grid-template-columns:1fr}.avatar-editor{border-radius:18px;width:76px;height:76px}.profile-account-chip{justify-self:start}.profile-control.wide{grid-column:1/-1}.delete-confirm-row div{grid-template-columns:1fr}.settings-section:first-child{grid-row:auto}.data-action-grid{grid-template-columns:1fr}.library-workbench{flex:auto;min-height:0;display:grid}.library-filter-bar{min-height:112px;padding:10px}.library-category-tabs{gap:7px;padding-bottom:4px}.library-category-tabs button{text-align:center;min-width:68px;min-height:36px;padding:0 10px}.library-subfilter{grid-template-columns:auto minmax(0,1fr);gap:8px;min-height:34px;overflow:hidden}.library-category-row.sub{flex-wrap:nowrap;overflow-x:auto}.library-list{overscroll-behavior:contain;padding-right:4px;overflow-y:auto}.library-row{grid-template-columns:minmax(0,1fr) minmax(108px,max-content)}.library-row-title strong{max-width:100%}.library-row-title small{display:none}.library-row-side{gap:5px;min-width:108px}.library-row-side b{width:66px}.row-add-button{min-width:40px;padding:0 8px}.view-panel .library-workbench{height:auto;min-height:0;max-height:none}.modal-panel.modal-library{width:min(640px,100%);height:calc(100dvh - 24px);max-height:calc(100dvh - 24px);padding:14px}.modal-library .library-workbench,.modal-library .library-layout,.modal-library .library-list-panel{min-height:0}.modal-library .library-list{overscroll-behavior:contain;padding-right:4px;overflow-y:auto}.library-layout>.library-detail-panel{display:none}.library-mobile-detail-backdrop{z-index:80;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#14201d57;align-items:end;padding:14px 10px;animation:.18s both sheet-backdrop-in;display:grid;position:fixed;inset:0}.library-mobile-detail-card{width:min(100%,520px);max-height:min(82vh,680px);margin:0 auto;display:grid}.library-mobile-detail-card .library-detail-panel{border-radius:16px 16px 12px 12px;height:auto;max-height:min(82vh,680px);padding:16px;animation:.22s cubic-bezier(.2,.8,.2,1) both mobile-sheet-in;overflow-y:auto;box-shadow:0 22px 60px #14201d3d}.library-mobile-detail-card .library-detail-panel:before{content:"";background:var(--line-strong);border-radius:999px;justify-self:center;width:38px;height:4px;margin:0 0 2px}.library-mobile-detail-card .library-detail-head h3{font-size:20px}.profile-metrics,.summary-task-switch,.summary-brief{grid-template-columns:repeat(2,minmax(0,1fr))}.record-toolbar{grid-template-columns:1fr}.segmented-control{grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-flow:row}.segmented-control button{border-top:1px solid var(--line);border-left:0}.segmented-control button:nth-child(-n+2){border-top:0}.record-table-head{display:none}.record-row{grid-template-columns:1fr auto;grid-template-areas:"main actions""meal kcal";gap:8px}.record-main{grid-area:main}.meal-chip{grid-area:meal}.record-row b{grid-area:kcal;justify-self:end}.record-row-actions{grid-area:actions}.trend-chart{grid-template-columns:repeat(var(--trend-count,7), minmax(38px, 1fr));min-height:220px}.trend-day{min-width:34px}.distribution-row{grid-template-columns:48px minmax(0,1fr) 72px}.ranked-row{grid-template-columns:minmax(66px,.9fr) minmax(0,1fr) 72px}.library-row{grid-template-columns:minmax(0,1fr) 104px;gap:6px;min-height:50px}.library-row-side{justify-content:end;align-items:center;gap:4px;min-width:104px;display:flex}.library-row-side b{align-self:center;width:62px;font-size:10px}.library-row-title strong{flex:0 auto;max-width:min(150px,64%)}.library-row-title small{min-width:0}.row-add-button{min-width:40px;height:28px;padding:0 8px}.library-row-facts{gap:4px;font-size:10px}}@media (width<=640px){.panel-scroll{padding:14px}.topbar{min-height:0}.main-nav{grid-template-columns:repeat(4,minmax(0,1fr));gap:0;min-height:40px;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:0 0 36px;justify-content:center;width:36px;font-size:0}.plain-icon,.profile-button{border-radius:11px;width:34px;height:34px}.profile-file-card{padding:14px}.profile-name-field input{font-size:16px}.modal-backdrop{align-items:end;padding:12px}.modal-profile-backdrop{align-items:stretch;padding:8px}.modal-panel{max-height:calc(100vh - 24px);padding:16px}.modal-panel.modal-profile{border-radius:18px;width:100%;max-height:calc(100dvh - 16px);padding:13px}.modal-heading{margin-bottom:10px}.modal-heading h2{font-size:22px}.modal-profile .modal-heading{z-index:3;background:color-mix(in srgb, var(--surface) 94%, transparent);border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);margin:-13px -13px 10px;padding:12px 13px 9px;position:sticky;top:-13px}.modal-profile .modal-heading h2{font-size:19px}.profile-file-tab{min-width:136px;margin-left:10px;padding:8px 14px 9px}.modal-profile .profile-file-tab{display:none}.modal-profile .profile-file-card{background:linear-gradient(90deg, color-mix(in srgb, var(--green) 5%, transparent), transparent 42%), var(--surface);box-shadow:none;border-radius:14px;gap:10px;padding:12px}.modal-profile .profile-head-row{grid-template-columns:58px minmax(0,1fr);align-items:center;gap:10px}.modal-profile .avatar-editor{border-radius:16px;width:58px;height:58px}.modal-profile .avatar-editor>svg{width:34px;height:34px}.modal-profile .avatar-editor i{border-width:2px;width:23px;height:23px;bottom:3px;right:3px}.modal-profile .profile-name-field{gap:4px}.modal-profile .profile-name-field input{border-radius:8px;min-height:36px;padding:0 10px;font-size:15px}.modal-profile .profile-subline{gap:4px 8px}.modal-profile .profile-subline strong{max-width:180px;font-size:13px}.modal-profile .profile-subline span,.modal-profile .profile-name-field span{font-size:11px}.modal-profile .profile-account-chip{grid-column:2;justify-self:start;min-height:28px;padding:0 9px;font-size:11px}.modal-profile .profile-metrics{grid-template-columns:repeat(2,minmax(0,1fr));gap:7px}.modal-profile .profile-metrics div{gap:2px;padding:9px}.modal-profile .profile-metrics strong{font-size:15px}.modal-profile .profile-metrics em{font-size:10px}.modal-profile .profile-dossier-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.modal-profile .profile-control.wide{grid-column:1/-1}.modal-profile .profile-segment{border-radius:9px;padding:2px}.modal-profile .profile-segment button{border-radius:7px;min-height:30px;padding:0 5px;font-size:13px}.modal-profile .profile-field{gap:5px}.modal-profile .profile-field input{border-radius:9px;min-height:36px;padding:0 10px}.modal-profile .profile-action-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.modal-profile .profile-action-row button{min-height:38px;padding:0 10px;font-size:13px}.modal-profile .profile-privacy-block,.modal-profile .danger-zone{gap:8px;padding:10px}.modal-profile .profile-privacy-block ol{font-size:12px}.grams-control input{min-width:0}}@media (width<=420px){.modal-panel.modal-profile{padding:11px}.modal-profile .modal-heading{margin:-11px -11px 9px;padding:11px;top:-11px}.modal-profile .profile-file-card{padding:10px}.modal-profile .profile-metrics strong{font-size:14px}.modal-profile .profile-action-row button{gap:6px;font-size:12px}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
