:root{color-scheme:light;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#eef5f1;color:#18231d}*{box-sizing:border-box}html,body,#root{width:100%;max-width:100%;overflow-x:hidden}body{margin:0;min-width:320px;background:radial-gradient(circle at 18% 0%,rgba(232,246,237,.96),transparent 34rem),linear-gradient(135deg,#f8fbf9,#eef5f1 54%,#f6f1ea)}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}.app-shell{width:min(1240px,calc(100% - 56px));min-height:100vh;margin:0 auto;padding:28px 0 36px}.topbar{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:18px;align-items:start;border-radius:8px;padding:14px 16px 16px;background:#fafcfaf0;box-shadow:0 10px 28px #22362b0f}.brand{display:flex;gap:13px;align-items:center;min-width:0}.brand-logo,.brand-mark{width:54px;height:54px;flex:0 0 auto;border-radius:8px}.brand-logo{object-fit:cover;box-shadow:0 8px 18px #1c3e3424}.brand-mark{display:grid;place-items:center;color:#2f6f72;background:#e6f2f1}.eyebrow,.header-email,.muted,.metric-label,.food-main span,.food-macros span,.compact-row span,.weight-labels span{color:#687970}.eyebrow{margin:0 0 2px;font-size:12px;font-weight:800;letter-spacing:0;text-transform:uppercase}h1,h2,p{margin:0;letter-spacing:0}.topbar h1{font-size:clamp(28px,4vw,42px);line-height:1.02}.header-email{margin-top:6px;font-size:16px}.header-actions{display:flex;gap:8px;align-items:center;justify-content:end;padding-top:3px}.header-action,.add-button,.edit-button,.icon-button,.primary-button,.secondary-button,.danger-button,.text-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:8px;font-weight:800}.header-action{width:38px;min-height:38px;border:0;color:#24352c;background:#ffffffb8}.header-action:hover{background:#edf5f3}.content{width:100%;min-width:0;margin-top:16px}.app-footer{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:22px;color:#687970;font-size:13px}.app-footer a{color:inherit;font-weight:750;text-decoration:none}.app-footer a:hover{color:#2f6f72;text-decoration:underline}.dashboard-grid{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(0,1fr) minmax(0,1fr);grid-template-areas:"summary summary summary" "daily protein weight" "food food food";gap:16px;align-items:stretch}.food-card{grid-area:food}.daily-calories-card{grid-area:daily}.protein-card{grid-area:protein}.weight-card{grid-area:weight}.card,.panel,.metric-card{min-width:0;border:0;border-radius:8px;background:#fffffff0;box-shadow:0 12px 30px #22362b0e}.panel{padding:18px}.daily-calories-card,.protein-card,.weight-card{height:100%}.panel-header{display:flex;align-items:start;justify-content:space-between;gap:14px;margin-bottom:16px}.panel-header h2{font-size:19px;line-height:1.15;white-space:nowrap}.panel-header p{margin-top:4px;color:#687970;font-size:13px}.macro-grid{grid-area:summary;display:grid;grid-template-columns:minmax(320px,1fr) minmax(360px,1.12fr);gap:10px;align-items:stretch}.macro-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.metric-card{display:grid;align-content:center;min-height:88px;padding:12px 13px}.metric-card.primary{color:#fff;background:linear-gradient(135deg,#2f6f72,#55989a)}.metric-card.primary .metric-label,.metric-card.primary .metric-unit,.metric-card.primary .metric-note,.metric-card.primary .metric-average{color:#ffffffd1}.metric-card.calorie-hero{min-height:92px;height:100%}.metric-card.compact-macro{min-height:72px;grid-template-rows:auto auto auto}.metric-label{display:block;font-size:14px;font-weight:800}.metric-value{display:block;margin-top:5px;font-size:clamp(24px,3vw,34px);line-height:.95;letter-spacing:0}.compact-macro .metric-value{display:flex;align-items:baseline;gap:4px}.calorie-hero .metric-value{text-align:right}.metric-value .metric-unit{margin-left:4px;font-size:.48em;font-weight:750;vertical-align:baseline}.calorie-topline{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:baseline}.calorie-subline{display:flex;justify-content:flex-end;margin-top:8px}.metric-note,.metric-average{color:#687970;font-size:12px;line-height:1.2}.metric-average{display:block;margin-top:7px}.compact-macro .metric-average{margin-top:8px}.calorie-subline .metric-average{margin-top:0;text-align:right}.metric-average strong{color:inherit;font-size:13px;white-space:nowrap}.chart-days{display:grid;grid-template-columns:repeat(var(--day-count, 6),minmax(0,1fr));gap:8px;align-items:end;overflow-x:visible;padding-bottom:2px}.day-bar{display:grid;grid-template-rows:116px 16px 18px;gap:6px;min-width:0;border:1px solid transparent;border-radius:8px;padding:8px;color:#18231d;background:#f7faf8}.day-bar.today{border-color:#4e888a8c;background:#f0f7f6}.day-bar.selected{background:#eef6f5;box-shadow:inset 0 0 0 2px #4e888a24}.bar-track{display:flex;align-items:end;justify-content:center;border-radius:6px;background:#edf3ef;overflow:hidden}.bar-fill{display:block;width:100%;min-height:12px;border-radius:4px 4px 0 0;background:#4e888a}.day-bar.empty .bar-track{align-items:center;border:1px dashed #d6e2dc;background:#fbfdfb}.bar-empty-dot{width:8px;height:8px;border-radius:999px;background:#c6d4cc}.day-bar span,.day-bar strong{min-width:0;font-size:11px;line-height:1.12;text-align:center;white-space:nowrap}.day-bar strong{font-size:12px;font-variant-numeric:tabular-nums}.day-bar.empty strong{visibility:hidden}.compact-chart{display:grid;gap:10px;border-radius:8px;padding:12px;background:#f7faf8}.protein-card .compact-chart{min-height:0}.compact-row{display:grid;grid-template-columns:54px minmax(0,1fr) 44px;gap:10px;align-items:center}.compact-row span,.compact-row strong{font-size:12px;line-height:1;white-space:nowrap}.compact-row strong{text-align:right}.compact-track{height:10px;border-radius:999px;background:#e8f0ec;overflow:hidden}.compact-fill{display:block;height:100%;border-radius:inherit;background:#4e888a}.compact-row.today{border-radius:8px;margin:-5px -6px;padding:5px 6px;background:#edf7f5}.weight-chart{position:relative;min-height:178px;border-radius:8px;padding:18px 14px 34px;background:#f7faf8}.weight-svg{display:block;width:100%;height:124px;overflow:visible}.weight-gridline{stroke:#dde8e2;stroke-width:1}.weight-path{fill:none;stroke:#4e888a;stroke-linecap:round;stroke-linejoin:round;stroke-width:3}.weight-dot{fill:#fff;stroke:#4e888a;stroke-width:3}.weight-labels{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:6px;margin-top:6px}.weight-labels span{font-size:12px;line-height:1.15;text-align:center}.weight-change{margin-top:10px;color:#2f7060;font-size:13px;font-weight:850}.weight-latest-card{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center}.weight-latest-card strong{font-size:26px}.food-list{display:grid}.food-row{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:12px;align-items:start;padding:13px 0;border-top:1px solid #edf2ef}.food-row:first-child{border-top:0;padding-top:0}.food-main{min-width:0}.food-title{display:block;width:100%;border:0;padding:0;color:#18231d;background:transparent;font-size:15px;font-weight:800;line-height:1.28;overflow-wrap:anywhere;text-align:left}.food-main span,.food-macros span{display:block;margin-top:5px;font-size:12px;line-height:1.25}.food-macros{text-align:right}.food-macros strong{display:block;color:#18231d;font-size:15px;font-weight:850;white-space:nowrap}.row-actions{display:flex;justify-content:flex-end}.edit-button,.add-button,.icon-button{width:38px;height:38px;border:0;color:#314138;background:#f7faf8}.add-button{color:#fff;background:#4e888a;box-shadow:0 10px 20px #4e888a2e}.primary-button,.secondary-button,.danger-button,.text-button{border:0;min-height:42px;padding:0 14px}.primary-button{color:#fff;background:#4e888a}.secondary-button{color:#24342b;background:#f7faf8}.danger-button{color:#fff;background:#a83e36}.danger-text{color:#a83e36}.full{width:100%}.sheet-actions{display:grid;gap:10px}.search-input,label input,label select,label textarea{width:100%;border:1px solid #d6e0da;border-radius:8px;padding:11px 12px;color:#17211c;background:#fbfdfb}label{display:grid;gap:6px;color:#52665b;font-size:13px;font-weight:700}label textarea{min-height:88px;resize:vertical}.form-grid{display:grid;gap:10px}.form-grid.two,.form-grid.four{grid-template-columns:repeat(2,minmax(0,1fr))}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;display:flex;align-items:flex-end;background:#0a120e61}.sheet{display:grid;gap:12px;width:100%;max-height:92vh;overflow:auto;border-radius:8px 8px 0 0;padding:16px;background:#fff}.login-screen{display:grid;min-height:100vh;align-content:center;gap:18px;place-items:center;padding:20px}.login-preview-screen{position:relative;display:grid;min-height:100vh;align-content:center;gap:20px;padding:28px}.login-preview-shell{width:min(1240px,100%);margin:0 auto;opacity:.42;filter:grayscale(.9);pointer-events:none;-webkit-user-select:none;user-select:none}.login-preview-shell:after{position:fixed;top:0;right:0;bottom:0;left:0;content:"";background:radial-gradient(circle at 50% 34%,rgba(248,251,249,.55),transparent 22rem),#eef5f129;pointer-events:none}.login-preview-topbar{margin-bottom:16px}.login-preview-grid{filter:blur(1.2px)}.login-preview-panel,.login-preview-panel *{color:#7c8982!important}.login-preview-panel .bar-fill,.login-preview-panel .compact-fill{background:#9aaba5}.login-unlock-card{position:fixed;top:50%;left:50%;z-index:2;display:grid;width:min(390px,calc(100% - 32px));gap:14px;justify-items:center;border-radius:8px;padding:22px;background:#fffffff0;box-shadow:0 24px 70px #1d332729;transform:translate(-50%,-50%);text-align:center}.login-unlock-card h1{margin-top:4px;font-size:28px;line-height:1.08}.login-unlock-card .brand-logo{width:58px;height:58px}.login-preview-screen>.app-footer{position:relative;z-index:2;margin-top:0}.login-panel,.legal-card{border:0;border-radius:8px;background:#fff;box-shadow:0 18px 45px #22382d17}.login-panel{width:min(420px,100%);padding:22px}.login-panel h1{margin:14px 0 0;font-size:30px}.login-panel p{color:#5b6e64;line-height:1.5}.legal-page{min-height:100vh;padding:28px 16px}.legal-card{width:min(820px,100%);margin:0 auto;padding:24px}.legal-card h1{margin:12px 0 4px;font-size:34px}.legal-card h2{margin:26px 0 8px;font-size:18px}.legal-card p{margin:0;color:#52665b;line-height:1.6}.legal-card a{color:#2f6f72;font-weight:750}.legal-date{font-size:14px}.legal-home{color:#2f6f72;font-weight:800;text-decoration:none}.error-banner{margin:14px 0;border:1px solid #f0c9c7;border-radius:8px;padding:10px 12px;color:#8d2e27;background:#fff3f2}.empty-state{border-radius:8px;padding:18px;color:#65786e;background:#f7faf8;text-align:center}.loading-dot{width:42px;height:42px;border:4px solid #d9e4de;border-top-color:#4e888a;border-radius:50%;animation:spin .8s linear infinite}.spin{animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 1080px){.app-shell{width:min(900px,calc(100% - 28px));padding-top:14px}.dashboard-grid{grid-template-columns:1fr}.dashboard-grid{grid-template-areas:"summary" "protein" "weight" "daily" "food"}.macro-grid{grid-template-columns:1fr}}@media (max-width: 720px){.login-preview-screen{padding:14px}.login-preview-shell{width:100%}.login-unlock-card{top:42%}.topbar{grid-template-columns:minmax(0,1fr) auto;gap:10px;padding:14px}.brand{gap:10px;align-items:start}.brand-logo{width:48px;height:48px}.topbar h1{font-size:clamp(28px,9vw,40px)}.header-email{font-size:15px}.macro-row{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.metric-card{padding:11px}.metric-label,.metric-average,.metric-average strong{font-size:12px}.metric-value{font-size:clamp(26px,8vw,34px)}.compact-macro .metric-value{font-size:clamp(24px,8vw,32px)}.chart-days{grid-template-columns:repeat(var(--day-count, 6),minmax(56px,1fr));overflow-x:auto;padding-bottom:2px}.day-bar{grid-template-rows:82px auto auto}.food-row{grid-template-columns:minmax(0,1fr) auto;gap:8px}.food-row .row-actions{grid-column:1 / -1;justify-content:flex-start}.food-macros{text-align:right}.panel{padding:14px}.form-grid.two,.form-grid.four{grid-template-columns:1fr}.legal-card,.login-panel{padding:18px}}@media (max-width: 430px){.macro-row{grid-template-columns:1fr}}
