:root{--color-bg:#f5f5f0;--color-surface:#fff;--color-surface-2:#f0f0eb;--color-surface-3:#e8e8e4;--color-accent:#2d6a4f;--color-accent-hover:#245a42;--color-accent-light:#52b788;--color-accent-subtle:#d8f3dc;--color-danger:#d62828;--color-danger-subtle:#ffe5e5;--color-warning:#e9881b;--color-warning-subtle:#fff3e0;--color-success:#2d6a4f;--color-success-subtle:#d8f3dc;--color-text-primary:#1a1a1a;--color-text-secondary:#6b6b6b;--color-text-tertiary:#a0a0a0;--color-text-inverse:#fff;--color-border:#e8e8e4;--color-border-strong:#d0d0ca;--color-shadow:#0000000f;--color-shadow-md:#0000001a;--color-overlay:#00000073;--color-nav-active-bg:var(--color-accent-subtle);--color-section-label:var(--color-accent);--color-nav-bg:#f5f5f0eb;--color-breakfast:#f59e0b;--color-lunch:#3b82f6;--color-dinner:#2d6a4f;--color-snack:#f97316;--font-sans:-apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", sans-serif;--text-xs:11px;--text-sm:13px;--text-base:15px;--text-md:17px;--text-lg:20px;--text-xl:24px;--text-2xl:28px;--text-3xl:34px;--leading-tight:1.15;--leading-snug:1.3;--leading-normal:1.5;--weight-regular:400;--weight-medium:500;--weight-semibold:600;--weight-bold:700;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:20px;--radius-full:9999px;--shadow-sm:0 1px 3px var(--color-shadow), 0 1px 2px #0000000a;--shadow-md:0 4px 12px var(--color-shadow-md);--shadow-lg:0 8px 24px #0000001f;--bottom-nav-height:49px;--page-padding-x:16px;--page-padding-top:20px}*,:before,:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:16px}body{font-family:var(--font-sans);font-size:var(--text-base);font-weight:var(--weight-regular);line-height:var(--leading-normal);color:var(--color-text-primary);background-color:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100dvh;overflow:hidden}#root{flex-direction:column;height:100dvh;display:flex;overflow:hidden}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,textarea,select{font-family:inherit;font-size:inherit}.safe-top{padding-top:env(safe-area-inset-top)}.safe-bottom{padding-bottom:env(safe-area-inset-bottom)}.page-scroll{-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;padding:var(--page-padding-top) var(--page-padding-x) var(--space-8);flex:1;overflow-y:auto}.section-header{font-size:var(--text-xs);font-weight:var(--weight-semibold);letter-spacing:.06em;text-transform:uppercase;color:var(--color-section-label);padding:0 var(--page-padding-x) var(--space-2);margin-top:var(--space-6);margin-bottom:0}.list-divider{background:var(--color-border);height:1px;margin-left:var(--page-padding-x)}@keyframes shimmer{0%{background-position:-400% 0}to{background-position:400% 0}}.skeleton{background:linear-gradient(90deg, var(--color-surface-2) 25%, var(--color-surface-3) 50%, var(--color-surface-2) 75%);border-radius:var(--radius-sm);background-size:400% 100%;animation:1.5s linear infinite shimmer}.meal-breakfast{color:#92400e;background:#f59e0b26}.meal-lunch{color:#1e40af;background:#3b82f626}.meal-dinner{background:var(--color-accent-subtle);color:var(--color-accent)}.meal-snack{color:#9a3412;background:#f9731626}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.btn{justify-content:center;align-items:center;gap:var(--space-2);border-radius:var(--radius-md);font-weight:var(--weight-semibold);font-size:var(--text-base);cursor:pointer;white-space:nowrap;-webkit-tap-highlight-color:transparent;border:none;line-height:1;transition:opacity .1s,transform .1s;display:inline-flex}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--color-accent);color:var(--color-text-inverse)}.btn-primary:hover:not(:disabled){background:var(--color-accent-hover)}.btn-secondary{background:var(--color-surface-2);color:var(--color-text-primary)}.btn-secondary:hover:not(:disabled){background:var(--color-surface-3)}.btn-ghost{color:var(--color-accent);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--color-accent-subtle)}.btn-danger{background:var(--color-danger);color:var(--color-text-inverse)}.btn-sm{padding:var(--space-2) var(--space-3);font-size:var(--text-sm);border-radius:var(--radius-sm);height:32px}.btn-md{padding:var(--space-3) var(--space-5);height:44px}.btn-lg{padding:var(--space-4) var(--space-6);font-size:var(--text-md);border-radius:var(--radius-lg);height:52px}.btn-full{width:100%}.btn-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.badge{padding:2px var(--space-2);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--weight-semibold);white-space:nowrap;align-items:center;line-height:1.4;display:inline-flex}.badge-default{background:var(--color-surface-2);color:var(--color-text-secondary)}.badge-accent{background:var(--color-accent-subtle);color:var(--color-accent)}.badge-warning{background:var(--color-warning-subtle);color:var(--color-warning)}.badge-danger{background:var(--color-danger-subtle);color:var(--color-danger)}.badge-success{background:var(--color-success-subtle);color:var(--color-success)}.card{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--shadow-sm)}.chip{padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--weight-medium);background:var(--color-surface-2);color:var(--color-text-secondary);white-space:nowrap;align-items:center;gap:var(--space-1);display:inline-flex}.chip-active{background:var(--color-accent-subtle);color:var(--color-accent)}.toggle-track{border-radius:var(--radius-full);background:var(--color-border);cursor:pointer;flex-shrink:0;width:51px;height:31px;transition:background .2s;position:relative}.toggle-track.on{background:var(--color-accent)}.toggle-track.disabled{opacity:.5;cursor:not-allowed}.toggle-thumb{background:#fff;border-radius:50%;width:27px;height:27px;transition:transform .2s cubic-bezier(.34,1.56,.64,1);position:absolute;top:2px;left:2px;box-shadow:0 2px 4px #0003}.toggle-track.on .toggle-thumb{transform:translate(20px)}.input{width:100%;padding:var(--space-3) var(--space-4);border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--color-text-primary);background:var(--color-surface);-webkit-appearance:none;outline:none;transition:border-color .15s}.input:focus{border-color:var(--color-accent)}.input::placeholder{color:var(--color-text-tertiary)}.textarea{resize:vertical;min-height:120px;line-height:var(--leading-normal)}.skeleton-line{border-radius:var(--radius-sm);height:14px}.empty-state{justify-content:center;align-items:center;gap:var(--space-3);padding:var(--space-12) var(--space-8);text-align:center;flex-direction:column;display:flex}.empty-state-icon{opacity:.5;font-size:40px}.empty-state-title{font-size:var(--text-md);font-weight:var(--weight-semibold);color:var(--color-text-primary)}.empty-state-subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);max-width:240px}.bottom-sheet-overlay{background:var(--color-overlay);z-index:100;animation:.2s fadeIn;position:fixed;inset:0}.bottom-sheet{z-index:101;background:var(--color-surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:var(--space-4) var(--page-padding-x);padding-bottom:calc(var(--space-6) + env(safe-area-inset-bottom));box-shadow:var(--shadow-lg);-webkit-overflow-scrolling:touch;max-height:90dvh;position:fixed;bottom:0;left:0;right:0;overflow-y:auto}.bottom-sheet-handle{background:var(--color-border-strong);border-radius:var(--radius-full);width:36px;height:4px;margin:0 auto var(--space-4)}.sticky-footer{background:var(--color-surface);border-top:1px solid var(--color-border);padding:var(--space-3) var(--page-padding-x);padding-bottom:calc(var(--space-3) + env(safe-area-inset-bottom));z-index:10;position:sticky;bottom:0;left:0;right:0}.list-row{padding:var(--space-3) var(--page-padding-x);background:var(--color-surface);align-items:center;gap:var(--space-3);min-height:44px;display:flex}.section-title{font-size:var(--text-xl);font-weight:var(--weight-bold);color:var(--color-text-primary)}.page-title{font-size:var(--text-2xl);font-weight:var(--weight-bold);color:var(--color-text-primary);line-height:var(--leading-tight)}.fab{bottom:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom) + var(--space-4));right:var(--page-padding-x);background:var(--color-accent);color:#fff;width:52px;height:52px;font-size:24px;font-weight:var(--weight-regular);box-shadow:var(--shadow-md);cursor:pointer;z-index:20;border:none;border-radius:50%;justify-content:center;align-items:center;transition:transform .15s;display:flex;position:fixed}.fab:active{transform:scale(.94)}.tab-bar{background:var(--color-surface-2);border-radius:var(--radius-md);gap:2px;padding:3px;display:flex}.tab-bar-item{padding:var(--space-2) var(--space-3);border-radius:calc(var(--radius-md) - 2px);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text-secondary);text-align:center;cursor:pointer;background:0 0;border:none;flex:1;transition:all .15s}.tab-bar-item.active{background:var(--color-surface);color:var(--color-text-primary);font-weight:var(--weight-semibold);box-shadow:var(--shadow-sm)}.segment-control{background:var(--color-surface-2);border-radius:var(--radius-md);gap:2px;padding:3px;display:flex}.segment-control-item{padding:var(--space-2) var(--space-3);border-radius:calc(var(--radius-md) - 2px);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text-secondary);text-align:center;cursor:pointer;background:0 0;border:none;flex:1;transition:all .15s}.segment-control-item.active{background:var(--color-accent);color:var(--color-text-inverse);font-weight:var(--weight-semibold)}.status-banner{padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);line-height:var(--leading-snug)}.status-banner-info{background:var(--color-accent-subtle);color:var(--color-accent)}.status-banner-warning{background:var(--color-warning-subtle);color:var(--color-warning)}.status-banner-danger{background:var(--color-danger-subtle);color:var(--color-danger)}
