:root{color:#111827;text-rendering:optimizelegibility;background-color:#f8fafc;font-family:Inter,system-ui,sans-serif;font-size:16px;line-height:1.5}*{box-sizing:border-box}body{margin:0;padding:0}h1,h2,h3,h4,p{margin:0}#root{min-height:100vh}:root{--color-primary:#1e5fd8;--color-primary-dark:#0b3c9b;--color-bg:#edf1f8;--color-surface:#fff;--color-text:#0f172a;--color-text-muted:#64748b;--radius-lg:24px;--radius-xl:28px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px}.app{background:var(--color-bg);flex-direction:column;min-height:100vh;display:flex}.teaser-page{background:radial-gradient(circle at 20% 20%,#3e71ff47,#0000 45%),radial-gradient(circle at 80% 0,#818cf833,#0000 40%),linear-gradient(150deg,#070b19,#11172c 55%,#0f1325);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.teaser-card{text-align:center;color:#e2e8f0;background:#0a0e1cb8;border:1px solid #94a3b84d;border-radius:28px;width:min(460px,100%);padding:42px 30px 32px;box-shadow:0 24px 60px #02061773}.logo-mark{justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 22px;display:flex}.logo-mark img{object-fit:contain;width:72px;height:72px}.logo-wordmark{width:min(300px,100%);height:auto;display:block}.teaser-wordmark{margin:0 auto 16px}.teaser-headline{color:#f8fafc;margin:0;font-size:clamp(28px,5.5vw,38px);font-weight:650;line-height:1.1}.teaser-subhead{color:#e2e8f0eb;margin:16px 0 26px;font-size:17px}.teaser-enter{color:#fff;cursor:pointer;background:linear-gradient(135deg,#4f46e5,#2563eb);border:none;border-radius:14px;padding:12px 26px;font-size:16px;font-weight:650;box-shadow:0 14px 28px #2563eb5c}.teaser-caption{letter-spacing:.16em;text-transform:uppercase;color:#e2e8f099;margin-top:14px;font-size:12px}.top-app-bar{color:var(--color-text);background:#f8fbff;border-bottom:1px solid #e2e8f0;padding:14px 20px 12px}.top-app-bar.home-banner{color:#fff;background:linear-gradient(#1f70ff 0%,#1a59cc 100%);border-bottom:none;padding:16px 20px 14px}.top-app-content{justify-content:center;align-items:center;gap:12px;display:flex}.top-app-bar.history-header{padding:10px 16px 8px}.top-app-bar.history-header .top-app-content{justify-content:flex-start;align-items:flex-start}.history-topbar-copy{text-align:left}.history-topbar-copy h1{font-size:19px;line-height:1.15}.topbar-subtitle{margin:3px 0 0}.topbar-copy h1{margin:0;font-size:20px}.home-banner-copy{flex-direction:column;justify-content:center;align-items:center;gap:6px;width:100%;min-height:104px;padding:6px 4px;display:flex;position:relative}.home-banner-copy h1{text-align:center;margin:0;font-size:20px;font-weight:700;line-height:1.1}.home-profile-avatar{background:#fff3;border:1px solid #ffffff73;border-radius:999px;justify-content:center;align-items:center;width:30px;height:30px;font-size:15px;display:inline-flex;position:absolute;top:4px;right:2px}.home-banner-main{text-align:center;color:#fff;margin:2px 0 0;font-size:16px;font-weight:650}.home-banner-divider{background:#ffffff59;width:100%;max-width:360px;height:1px}.home-banner-sub{text-align:center;color:#ffffffeb;margin:0;font-size:13px}.icon-button{color:#0f172a;cursor:pointer;background:#fff;border:1px solid #dbe4ef;border-radius:12px;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:inline-flex}.subtitle{color:#6c6c78;margin-top:8px}.toast-stack{z-index:40;flex-direction:column;gap:8px;width:min(360px,100vw - 24px);display:flex;position:fixed;top:16px;right:16px}.toast-item{border-radius:12px;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;display:flex;box-shadow:0 10px 24px #0f172a2e}.toast-item.info{color:#0c4a6e;background:#e0f2fe}.toast-item.success{color:#065f46;background:#ecfdf5}.toast-item.error{color:#991b1b;background:#fef2f2}.toast-item button{color:inherit;cursor:pointer;background:0 0;border:none;padding:0;font-size:16px}.auth-panel{flex-direction:column;gap:18px;display:flex}.auth-header h2{margin-bottom:4px}.content{flex-direction:column;flex:1;gap:8px;padding:10px 12px 110px;display:flex}.panel{background:var(--color-surface);box-shadow:none;border:1px solid #edf2f8;border-radius:14px;padding:10px}.home-panel{flex-direction:column;gap:14px;display:flex}.home-screen{flex-direction:column;gap:10px;display:flex}.home-block{background:#fff;border:1px solid #e9eef6;border-radius:10px;padding:8px}.home-redesign{gap:12px}.home-flat{box-shadow:none;border:1px solid #e5ebf3}.home-hero-compact h2{margin:0;font-size:38px;line-height:1}.home-summary-card{flex-direction:column;justify-content:center;align-items:center;gap:2px;min-height:96px;display:flex}.home-summary-number{color:#0f172a;font-size:40px;font-weight:800;line-height:1}.home-summary-label{color:#5b6b83;font-size:14px}.hero-top-row{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.hero-goal{color:#475569;font-size:12px}.hero-progress-wrap{background:#f1f5f9;border-radius:10px;margin-top:6px;padding:6px}.compact-progress{height:6px;margin-top:8px}.home-header{grid-template-columns:128px 1fr;align-items:center;gap:12px;display:grid}.ring{background:conic-gradient(#38bdf8 var(--progress), #ffffff4d 0);border-radius:50%;justify-content:center;align-items:center;width:128px;height:128px;padding:10px;display:flex;box-shadow:inset 0 0 0 12px #0c4a6e1f}.ring-inner{text-align:center;background:#fff;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;display:flex;box-shadow:0 10px 20px #0f172a14}.ring-value{font-size:26px;font-weight:700}.ring-sub{color:#64748b;font-size:12px}.home-summary h2{margin:4px 0;font-size:26px}.quick-actions-row{gap:8px;display:flex}.quick-action-card{text-align:center;background:#f8fbff;border:1px solid #e6eef9;border-radius:14px;flex-direction:row;flex:1;justify-content:center;align-items:center;gap:8px;min-height:42px;padding:9px 10px;display:flex}.quick-action-card.primary{color:#fff;background:linear-gradient(135deg,#1f70ff,#1a4bb8);border:none}.quick-action-card span{color:#64748b;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.quick-action-icon{flex:0 0 18px;width:18px;height:18px}.quick-action-label{font-size:13px;font-weight:600}.quick-action-card.primary span{color:#fffc}.home-footer-actions{margin-top:4px}.cta{color:#fff;cursor:pointer;background:linear-gradient(135deg,#1f70ff,#1a4bb8);border:none;border-radius:16px;width:100%;padding:14px 16px;font-size:16px;font-weight:600;box-shadow:0 12px 24px #1e70ff40}.cta.secondary{color:#1e3a8a;box-shadow:none;background:#f0f4ff;border:1px solid #dbe6ff}.macro-list{flex-direction:column;gap:8px;display:flex}.compact-macro-list{gap:8px}.compact-macro-list>h3{margin:0 0 2px}.macro-row{flex-direction:column;gap:5px;padding-bottom:1px;display:flex}.macro-label{color:#334155;justify-content:space-between;align-items:flex-start;font-size:14px;display:flex}.macro-values{flex-direction:column;align-items:flex-end;gap:1px;display:flex}.macro-current.warning{color:#c2410c;font-weight:600}.macro-current.critical{color:#b91c1c;font-weight:700}.overflow-callout{font-size:12px}.overflow-callout.warning{color:#b45309}.overflow-callout.critical{color:#b91c1c}.progress{background:#e2e8f0;border-radius:999px;width:100%;height:7px;overflow:hidden}.progress-fill{background:#38bdf8;border-radius:999px;height:100%}.progress-fill.warning{background:#f97316}.progress-fill.critical{background:#ef4444}.progress-fill.protein{background:#2563eb}.progress-fill.carbs{background:#22c55e}.progress-fill.sugar{background:#f97316}.progress-fill.sodium{background:#06b6d4}.grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-top:16px;display:grid}.card{background:#fff;border:1px solid #edf2f8;border-radius:14px;padding:12px;box-shadow:0 6px 14px #0f172a0d}.metric{margin:12px 0 4px;font-size:24px;font-weight:600}.caption{color:#56637a;font-size:14px}.actions{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}button{cursor:pointer;background:#fff;border:1px solid #dbe3ee;border-radius:12px;padding:9px 14px;font-size:14px}button:focus-visible,input:focus-visible,select:focus-visible,.tab:focus-visible,.chip:focus-visible,.quick-action-card:focus-visible,.recent-row:focus-visible,.compact-history-row:focus-visible,.more-item:focus-visible,.scan-tile:focus-visible,.sheet-action-grid button:focus-visible,.text-link:focus-visible{outline-offset:2px;outline:2px solid #1d4ed8}button.primary{color:#fff;background:linear-gradient(135deg,#1f70ff,#1a4bb8);border:none}button.danger{color:#b91c1c;background:#fee2e2;border-color:#fecaca}.result{flex-wrap:wrap;justify-content:space-between;gap:24px;display:flex}.result-grid{grid-template-columns:repeat(2,minmax(120px,1fr));gap:8px 16px;display:grid}.result-grid.compact{grid-template-columns:repeat(2,minmax(100px,1fr));font-size:13px}.scan-tiles{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:6px;display:grid}.scan-tile{color:#fff;background:linear-gradient(135deg,#1f70ff,#1a4bb8);border:none;border-radius:14px;flex-direction:column;align-items:flex-start;gap:8px;min-height:100px;padding:16px;display:flex;box-shadow:0 8px 18px #1e70ff38}.scan-tile .caption{color:#ffffffb3}.text-link{color:#1d4ed8;text-align:left;background:0 0;border:none;margin-top:6px;padding:0;font-weight:600}.text-link:focus-visible{border-radius:8px}.quick-action{align-self:flex-start;margin-top:0;font-size:15px}.scan-manual{flex-direction:column;gap:12px;margin-top:12px;display:flex}.scan-note{color:#9a5b1a;margin:0;font-size:14px}.callout{background:#eef2ff;border-radius:12px;margin-top:12px;padding:12px}.form-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;margin-top:8px;display:grid}.search-panel{flex-direction:column;gap:12px;display:flex}.search-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.search-results{flex-direction:column;gap:12px;display:flex}.search-card{background:#fff}.empty-state{background:#f8fafc;border:1px dashed #cbd5f5;border-radius:12px;flex-direction:column;gap:12px;padding:16px;display:flex}label{flex-direction:column;gap:6px;font-size:14px;display:flex}input{border:1px solid #dbe3ee;border-radius:10px;padding:9px 11px}select{background:#fff;border:1px solid #dbe3ee;border-radius:10px;padding:9px 11px}.trend-card{background:#fcfdff;border:1px solid #edf2f8;border-radius:10px;margin-bottom:4px;padding:6px}.history-redesign{flex-direction:column;gap:6px;display:flex}.history-flat{box-shadow:none;border:1px solid #eff3f8;padding:8px}.history-filter-row{flex-wrap:wrap;gap:6px;display:flex}.segmented-row{margin-bottom:2px}.segmented-control{background:#f7faff;border:1px solid #dde5f0;border-radius:10px;align-items:center;gap:0;max-width:100%;display:inline-flex;overflow:hidden}.segmented-control-scroll{scrollbar-width:none;overflow-x:auto}.segmented-control-scroll::-webkit-scrollbar{display:none}.segment{color:#475569;white-space:nowrap;background:0 0;border:0;border-right:1px solid #e3eaf4;border-radius:0;min-height:30px;padding:5px 10px;font-size:12px;font-weight:600}.segment:last-child{border-right:0}.segment.active{color:#fff;background:#1d4ed8}.chip{background:#f8fbff;border:1px solid #e4ebf4;border-radius:999px;min-height:30px;padding:4px 10px;font-size:11px}.chip.active{color:#fff;background:#1d4ed8;border-color:#1d4ed8}.summary-strip{background:#fbfdff;border:1px solid #edf2f8;border-radius:10px;grid-template-columns:minmax(0,1fr) auto;gap:6px;padding:6px 8px;display:grid}.summary-cell{background:#fff;border:1px solid #edf2f8;border-radius:8px;padding:4px 6px}.compact-history-summary .caption{font-size:11px}.summary-strip>div{min-width:0}.summary-strip strong{white-space:nowrap;display:block}.summary-date input{width:100%}.edit-log-redesign{flex-direction:column;gap:10px;display:flex}.section-heading{letter-spacing:0;text-transform:none;color:#475569;margin:2px 0 -2px;font-size:14px}.sticky-footer-actions{padding:8px 0 calc(6px + env(safe-area-inset-bottom));background:#fffffffa;border-top:1px solid #e2e8f0;margin-top:2px;position:sticky;bottom:0}.sticky-footer-actions .primary{width:100%}.sheet-backdrop{z-index:50;background:#0f172a73;justify-content:center;align-items:flex-end;padding:0 12px;display:flex;position:fixed;inset:0}.add-food-sheet{background:#fff;border-top-left-radius:20px;border-top-right-radius:20px;width:min(560px,100%);padding:12px 16px 18px;box-shadow:0 -10px 30px #0f172a33}.sheet-handle{background:#cbd5e1;border-radius:999px;width:44px;height:5px;margin:2px auto 12px}.sheet-action-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:12px;display:grid}.sheet-action-grid button{background:#f8fafc;border-radius:12px;padding:14px 10px}.sheet-close{width:100%;margin-top:12px}.trend-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:12px;margin-bottom:6px;display:flex}.trend-header h3{margin:0}.trend-chart-wrap{grid-template-columns:54px minmax(0,1fr);align-items:end;gap:5px;display:grid}.trend-y-axis{color:#64748b;text-align:right;flex-direction:column;justify-content:space-between;height:118px;padding-top:2px;padding-bottom:20px;font-size:11px;line-height:1.15;display:flex}.trend-y-axis span{white-space:nowrap}.trend-chart{grid-template-columns:repeat(var(--trend-columns,7), minmax(0, 1fr));gap:var(--trend-gap,8px);align-items:end;width:100%;max-width:100%;height:108px;display:grid;position:relative;overflow:hidden}.trend-line-chart{flex-direction:column;gap:4px;height:auto;min-height:116px;padding-bottom:2px;display:flex;overflow-x:auto}.trend-line-chart svg{width:100%;min-width:320px;height:114px;overflow:visible}.trend-line-path{fill:none;stroke:#2563eb;stroke-width:2.2px;stroke-linejoin:round;stroke-linecap:round}.trend-target-line-svg{stroke:#f43f5e;stroke-width:1px;stroke-dasharray:3 3;opacity:.75}.trend-point{fill:#fff;stroke:#2563eb;stroke-width:2px;cursor:pointer}.trend-point.selected{fill:#2563eb;stroke:#1e40af}.trend-tooltip-svg rect{fill:#0f172a;opacity:.95}.trend-tooltip-svg text{fill:#f8fafc;font-size:10px;font-weight:600}.trend-x-labels{grid-template-columns:repeat(var(--trend-columns,7), minmax(0, 1fr));gap:6px;min-width:320px;display:grid}.trend-x-labels span{color:#64748b;text-align:center;white-space:nowrap;font-size:11px}.trend-target-line{opacity:.75;z-index:3;pointer-events:none;border-top:1px dashed #ef4444;height:0;position:absolute;left:0;right:0}.trend-bar-group{z-index:2;cursor:default;flex-direction:column;align-items:center;gap:8px;min-width:0;display:flex;position:relative;overflow:hidden}.trend-bar-group:focus-visible{outline-offset:2px;border-radius:10px;outline:2px solid #2563eb}.trend-bar-group.selected .trend-bar-track{box-shadow:0 0 0 2px #2563eb59}.trend-tooltip{color:#f8fafc;text-align:center;z-index:5;pointer-events:none;background:#0f172a;border-radius:10px;min-width:92px;margin-bottom:8px;padding:6px 8px;font-size:11px;line-height:1.2;position:absolute;bottom:100%;left:50%;transform:translate(-50%);box-shadow:0 8px 20px #0f172a59}.trend-tooltip strong{font-size:11px;font-weight:700;display:block}.trend-tooltip span{color:#cbd5e1;margin-top:2px;display:block}.trend-tooltip:after{content:"";border:5px solid #0000;border-top-color:#0f172a;position:absolute;top:100%;left:50%;transform:translate(-50%)}.trend-bar-track{background:#f6f9fc;border-radius:6px;align-items:flex-end;width:100%;height:78px;display:flex;overflow:hidden}.trend-bar{background:#60a5fa;border-radius:2px 2px 1px 1px;width:100%;min-height:2px}.trend-bar.over-target{background:linear-gradient(#ef4444,#fb7185)}.trend-day{color:#64748b;text-align:center;white-space:nowrap;text-overflow:clip;width:100%;min-height:16px;font-size:12px;line-height:16px;display:block;overflow:hidden}.trend-empty{color:#64748b;margin:0 0 6px;font-size:12px}label.highlight{background:#38bdf814;border:1px dashed #38bdf8;border-radius:12px;padding:12px}.validation{color:#b91c1c;margin-top:12px}.validation.ok{color:#15803d}.summary{gap:24px;margin-bottom:16px;display:flex}.log-list{flex-direction:column;gap:8px;display:flex}.compact-history-list{margin-top:1px}.log-card{background:#fff;border-radius:16px;justify-content:space-between;gap:16px;padding:16px;display:flex;box-shadow:0 10px 18px #0f172a0f}.log-row{box-shadow:none;border:1px solid #e5eaf2;border-radius:12px;align-items:center;padding:10px}.compact-history-row{text-align:left;background:#fff;border:1px solid #edf2f8;border-radius:8px;flex-direction:column;align-items:flex-start;gap:2px;width:100%;padding:6px 8px;display:flex}.history-row-title{white-space:nowrap;text-overflow:ellipsis;width:100%;font-size:13px;font-weight:600;overflow:hidden}.history-row-meta{color:#64748b;white-space:nowrap;text-overflow:ellipsis;width:100%;font-size:11px;overflow:hidden}.log-row h3{margin:0 0 2px;font-size:14px}.log-row .caption{font-size:12px}.recent-list{flex-direction:column;gap:8px;display:flex}.recent-list>h3{margin:0 0 2px}.recent-row{text-align:left;background:#f8fafc;border:1px solid #e7edf5;flex-direction:column;align-items:flex-start;gap:2px;width:100%;padding:8px 26px 8px 10px;display:flex;position:relative}.recent-row:after{content:"›";color:#94a3b8;font-size:15px;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.recent-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;width:100%;font-weight:600;line-height:1.2;display:-webkit-box;overflow:hidden}.recent-meta{white-space:nowrap;color:#64748b;font-size:12px}.qty-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.nutrition-edit-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.log-actions{gap:8px;display:flex}.learn-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-bottom:16px;display:grid}.goal-card{flex-direction:column;gap:16px;display:flex}.goal-value{align-items:center;gap:12px;font-size:18px;display:flex}.goal-value input{width:120px;font-size:20px;font-weight:600}.more-list{flex-direction:column;gap:12px;display:flex}.more-item{text-align:left;background:#fafcff;border:none;border-radius:12px;width:100%;padding:12px;font-weight:600;box-shadow:inset 0 0 0 1px #e8edf5}.bottom-tabs{padding:12px 20px calc(20px + env(safe-area-inset-bottom));background:#fff;border-top-left-radius:24px;border-top-right-radius:24px;justify-content:space-around;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -8px 20px #0f172a14}.tab{color:#94a3b8;background:0 0;border:none;font-weight:600}.tab.active{color:#1d4ed8}.compact-summary-inline{align-items:center}.summary-inline-text{color:#334155;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.summary-date-picker{justify-self:end;align-items:center;gap:6px;display:inline-flex}.summary-date-picker .caption{color:#64748b;margin:0;font-size:11px}.summary-date-picker input{width:124px;min-height:28px;padding:4px 6px;font-size:11px}@media (width<=768px){.content{gap:6px;padding:8px 10px 104px}.panel{border-radius:12px;padding:8px}button{border-radius:10px;min-height:44px;padding:8px 12px}input,select{min-height:38px;padding:8px 10px}.home-block,.card{border-radius:10px;padding:8px}.actions{gap:6px;margin-top:10px}.result,.summary,.log-card{flex-direction:column}.home-header{grid-template-columns:110px 1fr;gap:10px}.quick-actions-row{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;display:grid}.quick-action-card{border-radius:10px;gap:6px;padding:7px 8px}.quick-action-icon{flex-basis:16px;width:16px;height:16px}.quick-action-label{font-size:12px}.home-summary-card{min-height:86px}.home-summary-number{font-size:34px}.home-banner-main{font-size:15px}.home-banner-sub{font-size:12px}.home-banner-copy{min-height:98px;padding:6px 2px}.home-profile-avatar{top:2px;right:0}.summary-strip{grid-template-columns:1fr;gap:4px}.summary-date-picker{justify-self:start}.summary-cell{padding:4px 5px}.nutrition-edit-list,.sheet-action-grid{grid-template-columns:1fr;gap:8px}.scan-tile{border-radius:12px;min-height:86px;padding:12px}.ring{width:110px;height:110px}.trend-chart-wrap{grid-template-columns:50px minmax(0,1fr);gap:6px}.trend-y-axis{padding-bottom:18px;font-size:10px}.bottom-tabs{padding:10px 16px calc(16px + env(safe-area-inset-bottom));border-top-left-radius:18px;border-top-right-radius:18px}}
