:root{--c-bg: #fbfdfa;--c-bg2: #f4f8f1;--c-bg3: #edf4ec;--c-card: rgba(255, 255, 255, .9);--c-border: rgba(22, 78, 52, .12);--c-text: #17211c;--c-muted: #6d776f;--c-hint: #a6ada7;--c-green: #1aa565;--c-green-deep: #063f25;--c-green-bg: #e8f7ec;--c-amber: #f08a3d;--c-amber-bg: #fff0e5;--c-red: #e24b4a;--c-red-bg: #fcebeb;--c-blue: #2876c9;--c-blue-bg: #e7f1ff;--shadow: 0 18px 48px rgba(31, 72, 47, .12);--shadow-soft: 0 10px 28px rgba(35, 79, 55, .08)}@media (prefers-color-scheme: dark){:root{--c-bg: #fbfdfa;--c-bg2: #f4f8f1;--c-bg3: #edf4ec;--c-card: rgba(255, 255, 255, .9);--c-border: rgba(22, 78, 52, .12);--c-text: #17211c;--c-muted: #6d776f;--c-hint: #a6ada7;--shadow: 0 18px 48px rgba(31, 72, 47, .12)}}*{box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Microsoft YaHei,sans-serif;font-size:16px;line-height:1.6;max-width:480px;min-height:100vh;margin:0 auto;padding:0;background:radial-gradient(circle at 14% 0%,rgba(196,230,198,.55),transparent 30%),radial-gradient(circle at 100% 12%,rgba(227,244,212,.75),transparent 34%),linear-gradient(180deg,#fbfdfa,#f7fbf4 48%,#fff);color:var(--c-text)}button,input{font:inherit}button{-webkit-tap-highlight-color:transparent}#root{display:block;min-height:100vh}.app-shell{min-height:100vh;background:radial-gradient(circle at 84% 4%,rgba(221,241,207,.9),transparent 26%),linear-gradient(180deg,#fbfdfafa,#fffffff5);border-left:.5px solid rgba(22,78,52,.08);border-right:.5px solid rgba(22,78,52,.08);position:relative;overflow-x:hidden}.top-nav{position:relative;top:0;z-index:20;display:flex;align-items:flex-start;justify-content:space-between;min-height:130px;padding:30px 24px 18px;background:transparent}.brand{display:flex;align-items:flex-start;gap:4px;color:var(--c-green-deep);font-size:31px;font-weight:800;line-height:1.14}.brand span{color:#64b660;font-size:22px;line-height:1}.brand-subtitle{margin-top:6px;color:var(--c-muted);font-size:16px;font-weight:500}.nav-actions{display:flex;gap:16px;align-items:center}.screen{display:block;min-height:calc(100vh - 130px);padding:0 22px 112px}#screen-camera,#screen-confirm{min-height:100vh;padding:0 16px 28px}.screen-header{display:flex;align-items:center;justify-content:space-between;height:58px}.screen-title{font-size:18px;font-weight:600}.text-xl{font-size:22px;font-weight:500}.text-lg{font-size:18px;font-weight:500}.text-base{font-size:16px}.text-sm{font-size:13px}.text-xs{font-size:11px}.card{background:var(--c-card);border:.5px solid rgba(18,71,45,.09);border-radius:18px;padding:1rem 1.25rem;margin-bottom:.75rem;box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.panel{background:var(--c-card);border:.5px solid rgba(18,71,45,.09);border-radius:18px;padding:14px;margin-bottom:14px;box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.btn-primary{width:100%;padding:12px;border-radius:12px;background:var(--c-blue-bg);color:var(--c-blue);border:none;font-size:15px;font-weight:500;cursor:pointer}.btn-solid{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:56px;padding:13px;border-radius:16px;background:linear-gradient(180deg,#2db86f,#119754);color:#fff;border:none;font-size:18px;font-weight:800;cursor:pointer;box-shadow:0 14px 24px #1aa56545}.btn-solid span{display:inline-grid;place-items:center;width:24px;height:24px;border-radius:50%;background:#ffffffeb;color:var(--c-green);font-weight:900}.btn-solid:disabled{opacity:.6;cursor:not-allowed}.btn-ghost{padding:7px 15px;border-radius:999px;background:#ffffffb8;border:.5px solid rgba(26,126,77,.18);color:color-mix(in srgb,var(--c-green) 68%,var(--c-text));font-size:13px;font-weight:600;cursor:pointer}.icon-btn{width:56px;height:56px;border-radius:22px;display:inline-grid;place-items:center;border:.5px solid rgba(20,72,45,.08);background:#ffffffd1;color:var(--c-green-deep);cursor:pointer;box-shadow:var(--shadow-soft);font-size:27px;line-height:1;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.hero-total{position:relative;display:grid;gap:18px;padding:24px 18px 20px;background:radial-gradient(circle at 72% 12%,rgba(216,241,190,.9),transparent 26%),radial-gradient(circle at 88% 18%,rgba(255,255,255,.96),transparent 24%),linear-gradient(135deg,#ecfae8f0,#ffffffe6);border:1px solid rgba(96,196,111,.32);border-radius:18px;margin-bottom:28px;box-shadow:var(--shadow);overflow:hidden;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.hero-total.hero-warn{background:linear-gradient(135deg,color-mix(in srgb,var(--c-amber-bg) 58%,var(--c-bg)),var(--c-bg))}.hero-total.hero-over{background:linear-gradient(135deg,color-mix(in srgb,var(--c-red-bg) 62%,var(--c-bg)),var(--c-bg))}.hero-plate{position:absolute;top:13px;right:34px;width:145px;height:94px;display:grid;place-items:center;pointer-events:none;opacity:.9;filter:drop-shadow(0 14px 16px rgba(71,118,70,.16))}.hero-plate:after{content:"";position:absolute;top:34px;right:4px;bottom:10px;left:4px;border-radius:50%;background:radial-gradient(ellipse,#ffffffd1,#e7f4db52);filter:blur(5px)}.hero-plate span{position:relative;z-index:1;font-size:72px;transform:rotate(-6deg)}.total-row{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;position:relative;z-index:1}.total-kcal{color:var(--c-green-deep);font-size:58px;line-height:1;font-weight:900;letter-spacing:0;text-shadow:0 5px 16px rgba(24,120,75,.14)}.goal-copy{color:var(--c-muted);font-size:14px}.goal-title{display:inline-flex;align-items:center;gap:8px;margin-bottom:6px;color:var(--c-green-deep);font-size:18px;font-weight:700}.goal-icon{color:var(--c-green);font-size:22px}.progress-track{position:relative;z-index:1;height:12px;overflow:hidden;background:#ffffffdb;border-radius:999px;box-shadow:inset 0 1px 2px #12502e14}.progress-fill{height:100%;width:0%;border-radius:inherit;background:linear-gradient(90deg,#20b56d,#1aa565);box-shadow:0 0 18px #1aa56547;transition:width .25s ease,background .25s ease}.stat-grid{position:relative;z-index:1;display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.stat-chip{min-width:0;display:grid;grid-template-columns:auto minmax(0,1fr);column-gap:6px;align-items:center;border-radius:14px;background:#fffc;border:.5px solid rgba(21,79,49,.06);padding:12px 8px;box-shadow:0 10px 24px #214a3212}.stat-label{color:var(--c-muted);font-size:12px;line-height:1.2;white-space:nowrap}.stat-value{grid-column:2;margin-top:1px;color:var(--c-text);font-size:19px;font-weight:800;line-height:1.15;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stat-icon{grid-row:1 / span 2;display:inline-grid;place-items:center;width:24px;height:24px;border-radius:50%;font-size:17px;font-weight:800}.stat-icon-goal{color:var(--c-green);background:var(--c-green-bg)}.stat-icon-limit{color:var(--c-amber);background:var(--c-amber-bg)}.stat-icon-left{color:var(--c-blue);background:var(--c-blue-bg)}.status-strip{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:10px;min-height:43px;padding:9px 14px;color:color-mix(in srgb,var(--c-green-deep) 84%,var(--c-muted));font-size:14px;font-weight:600;background:#f2faf2cc;border:.5px solid rgba(22,115,68,.14);border-radius:13px}.status-strip>span:last-child{color:var(--c-green);font-size:18px;font-weight:900}.status-copy{display:inline-flex;align-items:center;gap:8px}.section-heading{display:flex;align-items:center;justify-content:space-between;margin:22px 2px 12px}.section-heading .text-lg{color:#111614;font-size:22px;font-weight:800}.empty{padding:26px 18px;text-align:center;color:var(--c-muted);background:var(--c-card);border:.5px dashed rgba(26,126,77,.2);border-radius:18px;box-shadow:var(--shadow-soft)}.record-card{position:relative;display:grid;grid-template-columns:72px minmax(0,1fr) auto;gap:14px;align-items:center;touch-action:pan-y;transition:transform .18s ease;min-height:86px;padding:12px;border-radius:18px}.thumb{width:72px;height:72px;border-radius:14px;object-fit:cover;background:var(--c-bg2);border:.5px solid rgba(18,71,45,.08);display:grid;place-items:center;color:var(--c-hint);font-size:27px;overflow:hidden;box-shadow:0 10px 18px #19472d14}.record-title{display:flex;align-items:center;gap:8px;color:var(--c-muted);font-size:16px;font-weight:600;white-space:nowrap;margin-bottom:7px}.record-foods{color:color-mix(in srgb,var(--c-muted) 84%,var(--c-text));font-size:15px;line-height:1.32;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.record-cal{display:flex;align-items:baseline;gap:5px;font-size:0;color:var(--c-blue)}.record-cal span{font-size:28px;line-height:1;font-weight:900}.record-cal small{color:var(--c-muted);font-size:14px;font-weight:500}.trend-wrap svg{display:block;width:100%;height:164px}.bottom-bar{position:fixed;left:50%;bottom:calc(12px + env(safe-area-inset-bottom));z-index:25;width:min(436px,calc(100vw - 32px));transform:translate(-50%);display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:7px;background:#ffffffd1;border:.5px solid rgba(18,71,45,.09);border-radius:999px;box-shadow:0 16px 34px #1b452c21;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.bottom-bar.hidden{display:none}.bottom-tab{min-height:52px;border:0;border-radius:999px;background:transparent;color:#a0a4a5;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:10px;font-size:17px;font-weight:800}.bottom-tab span{font-size:24px;line-height:1}.bottom-tab.active{background:linear-gradient(90deg,#e5f7e8f5,#f7fcf7db);color:var(--c-green)}.camera-stage{display:grid;gap:18px;min-height:calc(100vh - 86px);align-content:center}.viewfinder{aspect-ratio:16 / 9;border-radius:16px;border:1px solid var(--c-border);background:linear-gradient(90deg,transparent 48%,color-mix(in srgb,var(--c-border) 60%,transparent) 49%,transparent 51%),linear-gradient(0deg,transparent 48%,color-mix(in srgb,var(--c-border) 60%,transparent) 49%,transparent 51%),var(--c-bg2);position:relative;overflow:hidden;display:grid;place-items:center}.hand-guide{width:42%;min-width:138px;aspect-ratio:1.55;border:1.5px dashed var(--c-green);border-radius:14px;display:grid;place-items:center;color:var(--c-green);font-size:13px;background:color-mix(in srgb,var(--c-green-bg) 42%,transparent)}.finder-copy{position:absolute;left:18px;right:18px;bottom:14px;color:var(--c-muted);text-align:center;font-size:13px}.camera-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px}.preview-image{width:100%;max-height:220px;object-fit:cover;border-radius:14px;border:.5px solid var(--c-border);margin-bottom:14px;background:var(--c-bg2)}.confirm-summary{position:sticky;top:0;z-index:18;margin:0 -16px 14px;padding:12px 16px;background:color-mix(in srgb,var(--c-bg) 94%,transparent);border-bottom:.5px solid var(--c-border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.confirm-summary .row{display:flex;align-items:center;justify-content:space-between;gap:12px}.food-card{padding:14px}.food-header{display:grid;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:8px;margin-bottom:12px}.food-name{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.calories{font-size:13px;color:var(--c-blue);font-weight:700}.food-meta{display:flex;flex-wrap:wrap;gap:6px;margin:-4px 0 12px}.meta-chip{border-radius:999px;background:var(--c-bg2);color:var(--c-muted);font-size:11px;line-height:1.2;padding:4px 8px}.meta-chip.source-boohee{background:var(--c-green-bg);color:var(--c-green)}.meta-chip.light-2{background:var(--c-amber-bg);color:var(--c-amber)}.meta-chip.light-3{background:var(--c-red-bg);color:var(--c-red)}.badge{font-size:10px;padding:2px 7px;border-radius:10px;white-space:nowrap}.badge-high{background:var(--c-green-bg);color:var(--c-green)}.badge-med{background:var(--c-amber-bg);color:var(--c-amber)}.badge-low{background:var(--c-red-bg);color:var(--c-red)}.adjust-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}.adjust-tab.active{color:var(--c-blue);background:var(--c-blue-bg);border-color:transparent}input[type=range]{width:100%;accent-color:var(--c-blue)}.slider-footer{display:flex;justify-content:space-between;align-items:center;color:var(--c-muted);font-size:12px;margin-top:2px}.weight-display,.step-weight-display{color:var(--c-text);font-weight:700;font-size:15px}.adjust-stepper{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;align-items:center}.step-weight-display{grid-column:1 / -1;text-align:center;padding:4px 0}.adjust-input{display:flex;align-items:center;gap:8px}.adjust-input input,.modal-card input,.goal-input{width:100%;min-height:42px;border-radius:10px;border:.5px solid var(--c-border);background:var(--c-bg);color:var(--c-text);padding:8px 10px;outline:none}.portion-presets{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:12px}.portion-presets .active{color:var(--c-green);background:var(--c-green-bg);border-color:transparent}.weight-adjuster{display:grid;gap:14px}.weight-stepper{display:grid;grid-template-columns:48px 1fr 48px;align-items:center;gap:12px}.stepper-btn{width:44px;height:44px;border-radius:50%;border:.5px solid var(--c-border);background:var(--c-bg);color:var(--c-text);font-size:22px;font-weight:400;line-height:1;cursor:pointer;display:grid;place-items:center;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.stepper-btn:active{background:var(--c-bg2);transform:scale(.97)}.weight-display{display:grid;justify-items:center;line-height:1}.weight-num{font-size:32px;font-weight:700;letter-spacing:0}.weight-unit{font-size:12px;color:var(--c-muted);margin-top:2px}.weight-slider{width:100%;accent-color:var(--c-blue);margin:0}.portion-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.portion-chip{padding:8px 4px;border-radius:8px;background:transparent;border:.5px solid var(--c-border);color:var(--c-muted);font-size:13px;cursor:pointer;-webkit-tap-highlight-color:transparent}.portion-chip.active{color:var(--c-green);background:var(--c-green-bg);border-color:transparent}.portion-chip:active{transform:scale(.98)}.diff-indicator{font-size:11px;margin-top:8px;padding:2px 8px;border-radius:8px;display:inline-block}.diff-same{background:var(--c-bg2);color:var(--c-hint)}.diff-up{background:var(--c-red-bg);color:var(--c-red)}.diff-down{background:var(--c-green-bg);color:var(--c-green)}.note-box{color:var(--c-muted);font-size:13px;background:var(--c-bg2);border-radius:10px;padding:10px 12px;margin-bottom:12px}.history-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:start}.history-date{color:var(--c-muted);font-size:12px}.modal,#loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;display:none;align-items:center;justify-content:center;padding:20px;background:#0000006b}.modal.show,#loading-overlay.show{display:flex}.modal-card,.loading-card{width:min(420px,100%);background:var(--c-bg);color:var(--c-text);border-radius:16px;box-shadow:var(--shadow);padding:20px;border:.5px solid var(--c-border)}.modal-card h2{margin:0 0 6px;font-size:20px}.modal-card p{margin:0 0 16px;color:var(--c-muted)}.modal-card label{display:block;margin:12px 0 6px;color:var(--c-muted);font-size:13px}.field-hint{margin-top:6px;color:var(--c-hint);font-size:11px;line-height:1.45}.modal-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(96px,1fr));gap:10px;margin-top:14px}.loading-card{display:grid;justify-items:center;text-align:center;gap:8px;width:min(300px,100%)}.loading-card p{margin:0}.spinner{width:32px;height:32px;border:2px solid var(--c-border);border-top-color:var(--c-blue);border-radius:50%;animation:spin .8s linear infinite}#toast-container{position:fixed;z-index:100;left:50%;bottom:calc(76px + env(safe-area-inset-bottom));width:min(448px,calc(100vw - 32px));transform:translate(-50%);display:grid;gap:8px;pointer-events:none}.toast{padding:11px 13px;border-radius:12px;color:var(--c-text);background:var(--c-bg);border:.5px solid var(--c-border);box-shadow:var(--shadow);font-size:13px}.toast-error{border-color:color-mix(in srgb,var(--c-red) 42%,var(--c-border))}.toast-undo{display:flex;align-items:center;justify-content:space-between;gap:12px;pointer-events:auto}.toast-undo-btn{background:transparent;border:.5px solid var(--c-green);color:var(--c-green);padding:4px 10px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer}.toast-undo-btn:hover{background:color-mix(in srgb,var(--c-green) 12%,transparent)}.thumb-letter{font-size:22px;font-weight:600;color:var(--c-green);background:var(--c-bg3)}.thumb-fallback-letter{color:var(--c-green);background:radial-gradient(circle at 50% 34%,rgba(255,255,255,.76),transparent 34%),var(--c-green-bg);font-weight:800}.demo-badge{display:inline-block;margin-left:6px;padding:2px 7px;font-size:10px;background:color-mix(in srgb,var(--c-amber) 18%,transparent);color:color-mix(in srgb,var(--c-amber) 70%,var(--c-text));border-radius:999px;font-weight:700}.meal-pill{display:inline-flex;align-items:center;justify-content:center;min-width:44px;padding:3px 10px;border-radius:999px;color:var(--c-green);background:var(--c-green-bg);font-weight:800}.record-actions{display:flex;flex-direction:column;align-items:flex-end;gap:15px}.record-btns{display:flex;gap:8px}.btn-sm{display:inline-flex;align-items:center;justify-content:center;gap:5px;min-height:30px;padding:4px 10px!important;font-size:13px!important;border-radius:8px!important;color:var(--c-muted);background:#ffffffc2;border-color:#132d211f}.record-main{min-width:0}.empty-cta{padding:36px 18px;display:flex;flex-direction:column;align-items:center;gap:10px;border-style:solid;background:var(--c-card)}.empty-emoji{font-size:40px;line-height:1}.empty-title{font-size:15px;font-weight:600;color:var(--c-text)}.empty-hint{font-size:12px;color:var(--c-muted);margin-bottom:6px}.trend-bar{cursor:pointer}.trend-bar:hover rect:nth-child(2),.trend-bar:focus-visible rect:nth-child(2){opacity:.36!important;filter:brightness(1.05)}.trend-bar:focus{outline:none}.trend-bar:focus-visible rect:nth-child(1){fill:color-mix(in srgb,var(--c-green) 12%,transparent)}.key-input-row{display:flex;gap:6px;align-items:center}.key-input-row input{flex:1}.key-input-row .key-toggle{padding:8px 10px;font-size:14px;line-height:1}.hidden{display:none!important}.boot-screen{min-height:60vh;display:grid;place-items:center;text-align:center;gap:14px;color:var(--c-muted)}.auth-screen{display:grid;place-items:center;padding:24px 16px}.auth-card{width:100%;max-width:360px;background:var(--c-card);border:.5px solid var(--c-border);border-radius:16px;padding:24px 20px 20px;display:grid;gap:12px;box-shadow:0 1px #0000000a}.auth-title{margin:0;font-size:22px;font-weight:600;color:var(--c-text)}.auth-sub{margin:0 0 4px;color:var(--c-muted);font-size:14px}.auth-card label{font-size:13px;color:var(--c-muted);margin-top:6px}.auth-card input{width:100%;padding:10px 12px;border-radius:10px;border:.5px solid var(--c-border);background:var(--c-bg);color:var(--c-text);font-size:15px;margin-top:4px}.auth-card input:focus{outline:2px solid var(--c-green);outline-offset:1px}.auth-error{background:#dc354514;color:var(--c-red);padding:8px 10px;border-radius:8px;font-size:14px;margin-top:4px}.auth-submit{width:100%;margin-top:10px}.auth-switch{width:100%;margin-top:4px}.edit-header{position:sticky;top:0;z-index:18;margin:0 -16px 14px;padding:12px 16px;background:color-mix(in srgb,var(--c-bg) 94%,transparent);border-bottom:.5px solid var(--c-border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.edit-header .row{display:flex;align-items:center;justify-content:space-between;gap:12px}.edit-info{display:flex;align-items:center;gap:8px;margin-top:8px}.edit-time{color:var(--c-muted);font-size:14px}.edit-foods{margin-bottom:16px}.image-viewer-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000;background:#000000e6;display:flex;align-items:center;justify-content:center;padding:20px}.image-viewer-content{position:relative;max-width:100%;max-height:100%;display:flex;align-items:center;justify-content:center}.image-viewer-close{position:fixed;top:20px;right:20px;z-index:1001;background:#fff3;border:none;color:#fff;font-size:24px;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.image-viewer-close:hover{background:#ffffff4d}.image-viewer-img{max-width:100%;max-height:90vh;object-fit:contain;border-radius:8px;cursor:pointer}.image-viewer-loading,.image-viewer-error{color:#fff;text-align:center;padding:40px}.image-viewer-loading .spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}@keyframes spin{to{transform:rotate(360deg)}}
