:root{--bg: #E7DDCF;--bg2: #DCCFBE;--card: #F7F0E5;--card2: #EEE4D6;--card3: #D8C8B4;--text: #191713;--text-soft: #312D24;--muted: #6B6155;--muted2: #8F8374;--accent: #2F6B45;--accent-hover: #285C3B;--accent-active: #214D32;--accent-dim: #8AAE95;--accent-bg: #DCE8DE;--accent-bg2: #CFE0D3;--gold: #B8872F;--gold-soft: #E5D0A8;--border: #CFC0AC;--border2: #D8CBB9;--border-strong: #B9A891;--shadow: 0 10px 24px rgba(44, 38, 28, .08);--shadow-soft: 0 6px 16px rgba(44, 38, 28, .06);--green: #2F6B45;--orange: #B87524;--red: #B84A3A;--blue: #3B6F8C;--purple: #7A5A9E;--cal-colour: #3B6F8C;--protein-colour: #2F6B45;--carbs-colour: #B8872F;--fat-colour: #B84A3A;--fibre-colour: #7A5A9E;--warning-bg: #EEDCC4;--warning-border: rgba(184, 117, 36, .28);--warning-text: #9A5C16;--font-display: "Barlow Condensed", system-ui, sans-serif;--font-body: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;--radius: 12px;--radius-lg: 18px;--radius-sm: 10px;--radius-pill: 999px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px)}*{box-sizing:border-box;margin:0;padding:0}html{background:var(--bg);min-height:100%}body{background:radial-gradient(circle at top left,rgba(47,107,69,.06),transparent 34%),linear-gradient(180deg,#EDE3D5 0%,var(--bg) 46%,#DCD0C0 100%);color:var(--text);font-family:var(--font-body);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;max-width:480px;margin:0 auto;min-height:100vh;overscroll-behavior:none}::-moz-selection{background:var(--accent-bg2);color:var(--text)}::selection{background:var(--accent-bg2);color:var(--text)}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--radius-pill)}h1,h2,h3,h4,h5,h6{color:var(--text);font-family:var(--font-display);font-weight:700;letter-spacing:.2px;line-height:.95}p{color:var(--text-soft);line-height:1.5}small{color:var(--muted)}input,textarea,select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--card2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font-body);font-size:14px;line-height:1.35;outline:none;padding:11px 12px;width:100%;transition:border-color .18s ease,background .18s ease,box-shadow .18s ease}input:focus,textarea:focus,select:focus{background:var(--card);border-color:var(--accent);box-shadow:0 0 0 3px #2f6b451f}input::-moz-placeholder,textarea::-moz-placeholder{color:var(--muted2)}input::placeholder,textarea::placeholder{color:var(--muted2)}textarea{min-height:96px;resize:vertical}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:none;box-shadow:none;padding:0}input[type=range]::-webkit-slider-runnable-track{background:var(--border);border-radius:var(--radius-pill);height:5px}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--accent);border:2px solid var(--card);border-radius:50%;box-shadow:0 2px 8px #2f6b4542;height:20px;margin-top:-7.5px;width:20px}button{border:none;cursor:pointer;font-family:var(--font-body);font-weight:700;letter-spacing:.1px;text-transform:none;transition:transform .12s ease,opacity .12s ease,background .18s ease,border-color .18s ease,box-shadow .18s ease}button:active{opacity:.9;transform:scale(.985)}button:disabled{cursor:not-allowed;opacity:.45}.card{background:var(--card);border:1px solid var(--border2);border-radius:var(--radius-lg);box-shadow:var(--shadow);margin-bottom:12px;padding:16px}.card-subtle{background:var(--card2);border:1px solid var(--border);border-radius:var(--radius);padding:13px}.card-flat{background:color-mix(in srgb,var(--card) 72%,transparent);border:1px solid var(--border2);border-radius:var(--radius);padding:14px}.btn-accent{background:var(--accent);border:1px solid var(--accent);border-radius:var(--radius);box-shadow:0 8px 18px #2f6b4533;color:var(--card);font-size:15px;font-weight:800;padding:13px 14px;width:100%}.btn-accent:hover{background:var(--accent-hover);border-color:var(--accent-hover);box-shadow:0 10px 22px #2f6b453d}.btn-accent:active{background:var(--accent-active);border-color:var(--accent-active)}.btn-ghost{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-soft);color:var(--text);font-size:14px;padding:11px 14px;width:100%}.btn-ghost:hover{background:var(--card);border-color:var(--border-strong)}.btn-danger{background:color-mix(in srgb,var(--red) 10%,var(--card));border:1px solid rgba(184,74,58,.26);border-radius:var(--radius);color:var(--red);font-size:14px;font-weight:800;padding:11px 14px;width:100%}.chip{align-items:center;border-radius:var(--radius-pill);display:inline-flex;font-family:var(--font-body);font-size:12px;font-weight:700;gap:6px;letter-spacing:.1px;line-height:1;padding:8px 12px;text-transform:none;transition:background .16s ease,border-color .16s ease,color .16s ease,box-shadow .16s ease}.chip-off{background:var(--card);border:1px solid var(--border);color:var(--muted)}.chip-on{background:var(--accent-bg);border:1px solid rgba(47,107,69,.34);box-shadow:inset 0 1px #ffffff70;color:var(--accent)}.tab-bar{background:color-mix(in srgb,var(--card) 94%,transparent);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-top:1px solid var(--border);bottom:0;box-shadow:0 -10px 24px #2c261c14;display:flex;left:0;padding-bottom:var(--safe-bottom);position:fixed;right:0;z-index:100}.tab-bar button,.tab-bar a{align-items:center;background:transparent;border:none;color:var(--muted);display:flex;flex:1;font-size:12px;font-weight:700;justify-content:center;min-height:56px;text-decoration:none}.tab-bar button.active,.tab-bar a.active{color:var(--accent)}.progress-track{background:var(--border2);border-radius:var(--radius-pill);height:8px;overflow:hidden;width:100%}.progress-fill{background:var(--accent);border-radius:var(--radius-pill);height:100%;transition:width .28s ease;width:var(--target-width, 0%)}.cal-fill{background:var(--cal-colour)}.protein-fill{background:var(--protein-colour)}.carbs-fill{background:var(--carbs-colour)}.fat-fill{background:var(--fat-colour)}.fibre-fill{background:var(--fibre-colour)}.warning{background:var(--warning-bg);border:1px solid var(--warning-border);border-radius:var(--radius);color:var(--warning-text);padding:12px 14px}.mono{font-family:var(--font-mono)}.display{font-family:var(--font-display)}.accent{color:var(--accent)}.gold{color:var(--gold)}.muted{color:var(--muted)}.green{color:var(--green)}.orange{color:var(--orange)}.red{color:var(--red)}.blue{color:var(--blue)}.surface{background:var(--card)}.surface-soft{background:var(--card2)}.border-soft{border:1px solid var(--border2)}.shadow-soft{box-shadow:var(--shadow-soft)}@keyframes barGrow{0%{width:0}to{width:var(--target-width)}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}html{background:var(--bg)}body{min-width:320px;max-width:none;overflow-x:hidden}button,input,textarea{font:inherit}button{min-height:44px}input,textarea{font-family:var(--font-mono)}textarea{font-family:var(--font-body)}.loading,.app-shell{width:min(100%,480px);min-height:100svh;margin:0 auto}.loading{display:grid;place-items:center;color:var(--accent);font-family:var(--font-mono)}.app-shell{padding-bottom:calc(76px + var(--safe-bottom))}.sync-pill{position:sticky;top:calc(88px + var(--safe-top));z-index:4;margin:10px 16px 0;padding:9px 12px;border:1px solid var(--warning-border);border-radius:var(--radius);background:var(--warning-bg);color:var(--warning-text);font-family:var(--font-mono);font-size:11px;text-align:center}.app-header{position:sticky;top:0;z-index:5;padding:calc(16px + var(--safe-top)) 16px 14px;border-bottom:1px solid var(--border);background:var(--card);box-shadow:var(--shadow-soft)}.app-header p,.eyebrow,.field-stack span,.slider-card span,.input-grid span,.number-input span{color:var(--muted);font-family:var(--font-mono);font-size:10px}.app-header h1{margin-top:4px;color:var(--text);font-family:var(--font-display);font-size:34px;font-weight:800;letter-spacing:0}.app-header h1 span{color:var(--accent)}.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:14px}.stat-pill{min-width:0;padding:10px 9px;border:1px solid var(--border2);border-radius:var(--radius);background:var(--card2)}.stat-pill span{display:block;color:var(--muted);font-family:var(--font-mono);font-size:9px}.stat-pill strong{display:block;margin-top:4px;overflow-wrap:anywhere;color:var(--text);font-family:var(--font-mono);font-size:13px}.stat-pill[data-status=ok] strong{color:var(--green)}.stat-pill[data-status=near] strong{color:var(--orange)}.stat-pill[data-status=low] strong{color:var(--red)}.today-widget{display:grid;gap:12px;margin:14px 16px 0;padding:15px;border:1px solid var(--border2);border-radius:var(--radius-lg);background:linear-gradient(180deg,var(--card) 0%,var(--card2) 100%);box-shadow:var(--shadow-soft)}.today-widget__top{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.today-widget__top div:last-child{grid-column:1 / -1;padding-top:10px;border-top:1px solid var(--border2)}.today-widget__top div,.today-widget__metric{min-width:0}.today-widget span{display:block;color:var(--muted);font-family:var(--font-mono);font-size:10px}.today-widget__top strong{display:block;margin-top:4px;overflow-wrap:anywhere;color:var(--text);font-family:var(--font-mono);font-size:14px;line-height:1.25}.today-widget__macros{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:7px}.today-widget__metric{padding:9px 7px;border:1px solid var(--border);border-radius:var(--radius);background:color-mix(in srgb,var(--card) 62%,var(--card2))}.today-widget__metric strong{display:block;margin-top:4px;color:var(--accent);font-family:var(--font-mono);font-size:13px}.today-widget__metric small{display:block;margin-top:3px;color:var(--muted);font-family:var(--font-mono);font-size:8px;line-height:1.2}.screen{padding:18px 16px 0;animation:fadeIn .15s ease}.tab-stack{display:grid;gap:14px}.pill-row{display:flex;flex-wrap:wrap;gap:9px}.toggle,.outline-button,.save-button{border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--card);color:var(--muted);box-shadow:var(--shadow-soft);font-weight:700}.toggle{min-width:62px;padding:0 14px}.toggle--accent{border-color:var(--accent-dim);background:var(--accent-bg);color:var(--accent)}.toggle--danger{border-color:var(--warning-border);background:var(--warning-bg);color:var(--warning-text)}.panel,.exercise-card,.warning-card,.danger-card,.macro-card,.slider-card,.snapshot,.history-card,.photo-card{border:1px solid var(--border2);border-radius:var(--radius-lg);background:var(--card);box-shadow:var(--shadow-soft)}.panel,.warning-card,.danger-card,.exercise-card,.history-card,.photo-card{padding:16px}.panel h2,.warning-card h2,.history-card h2{margin-bottom:6px;color:var(--text);font-size:clamp(20px,5.5vw,24px);font-weight:800;line-height:1.06}.panel p,.exercise-note,.history-card p{margin:0;color:var(--muted);line-height:1.45}.warning-card{border-color:var(--warning-border);background:var(--warning-bg);color:var(--warning-text)}.danger-card{border-color:color-mix(in srgb,var(--red) 32%,var(--border));background:color-mix(in srgb,var(--red) 9%,var(--card));color:var(--red);font-family:var(--font-mono);font-size:12px}.swap-list{display:grid;gap:5px;margin-top:12px;font-family:var(--font-mono);font-size:11px}.swap-list p{margin:0}.exercise-card{border-left:4px solid transparent}.exercise-card.complete{border-left-color:var(--green)}.exercise-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.exercise-head h3{margin:0;color:var(--text);font-size:clamp(19px,5vw,23px);font-weight:800;line-height:1.08}.exercise-head p,.exercise-head small,.exercise-head strong{font-family:var(--font-mono)}.exercise-head p,.exercise-head small{display:block;margin-top:6px;color:var(--muted);font-size:11px}.exercise-head strong{flex:0 0 auto;color:var(--green);font-size:12px}.exercise-note{margin-top:12px;font-size:14px}.set-list{display:grid;gap:9px;margin-top:14px}.set-row{display:grid;grid-template-columns:28px 1fr 1fr 44px;align-items:end;gap:8px;animation:slideIn .16s ease}.set-row>span{padding-bottom:12px;color:var(--accent);font-family:var(--font-mono);font-size:12px;font-weight:700}.set-row button,.food-log button{border:1px solid var(--border);border-radius:var(--radius);background:var(--card2);color:var(--muted);font-family:var(--font-mono)}.number-input{display:grid;gap:5px}.outline-button,.save-button,.coach-button{width:100%;margin-top:2px;font-size:15px}.outline-button{background:var(--card);color:var(--accent)}.coach-button{border:1px solid var(--accent);border-radius:var(--radius);background:var(--accent);color:var(--card);box-shadow:0 8px 18px color-mix(in srgb,var(--accent) 20%,transparent);font-weight:800}.save-button{background:var(--card2);color:var(--text)}.field-stack{display:grid;gap:7px}.verdict-card{margin:0;padding:15px;border:1px solid var(--accent-dim);border-radius:var(--radius);background:var(--accent-bg);color:var(--text);font-family:var(--font-mono);font-size:12px;white-space:pre-wrap}.macro-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.macro-card{padding:14px}.macro-card strong{display:block;margin-top:7px;font-family:var(--font-mono);font-size:23px;font-weight:700}.macro-card small,.panel small,.food-grid span,.food-log span,.history-card span,.history-card strong{color:var(--muted);font-family:var(--font-mono);font-size:10px}.macro-bar{height:7px;margin-top:12px;overflow:hidden;border-radius:var(--radius-pill);background:var(--border2)}.macro-bar span{display:block;height:100%;max-width:100%;border-radius:inherit;background:var(--tone, var(--accent));transition:width .3s ease}.macro-bar[data-status=under] span{background:var(--orange)}.macro-bar[data-status=over] span{background:var(--red)}.fibre-head{display:flex;justify-content:space-between;gap:10px;font-family:var(--font-mono)}.fibre-head span{color:var(--muted);font-size:11px}.fibre-head strong{color:var(--accent);font-size:12px}.food-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:9px}.food-grid button{display:grid;gap:5px;min-width:0;padding:12px;border:1px solid var(--border2);border-radius:var(--radius);background:var(--card);color:var(--text);text-align:left;box-shadow:var(--shadow-soft)}.food-grid strong,.food-log strong{overflow-wrap:anywhere;color:var(--text);font-size:14px;line-height:1.12}.food-log em{display:block;margin-top:3px;color:var(--gold);font-family:var(--font-mono);font-size:10px;font-style:normal}.camera-button{display:grid;place-items:center;width:72px;height:72px;border:1px solid var(--accent-dim);border-radius:var(--radius-pill);background:var(--accent-bg);color:var(--accent);font-size:12px;font-weight:800}.camera-button input{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.photo-loading{margin:0;color:var(--accent);font-family:var(--font-mono);font-size:11px;animation:pulse 1.2s ease-in-out infinite}.photo-error{margin:0;color:var(--red);font-family:var(--font-mono);font-size:11px}.photo-review{display:grid;gap:10px}.photo-review small{color:var(--muted);font-family:var(--font-mono);font-size:10px}.photo-item{display:grid;grid-template-columns:24px 1fr;align-items:start;gap:8px;color:var(--text);font-family:var(--font-mono);font-size:10px}.photo-item input{width:18px;min-height:18px;accent-color:var(--accent)}.photo-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.custom-food,.input-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.full{grid-column:1 / -1}.food-log{display:grid;gap:9px;max-height:420px;overflow:auto}.food-log article{display:grid;grid-template-columns:1fr auto 44px;align-items:center;gap:8px;padding:12px;border:1px solid var(--border2);border-radius:var(--radius);background:var(--card);box-shadow:var(--shadow-soft)}.slider-card{display:grid;gap:12px;padding:16px}.slider-card div{display:flex;align-items:center;justify-content:space-between}.slider-card strong{color:var(--accent);font-family:var(--font-mono);font-size:30px}.slider-card input{accent-color:var(--accent)}.input-grid label{display:grid;gap:6px}.snapshot{overflow:hidden}.snapshot div{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 15px;border-bottom:1px solid var(--border2);font-family:var(--font-mono)}.snapshot div:last-child{border-bottom:0}.snapshot span{color:var(--muted);font-size:11px}.snapshot strong{color:var(--text);font-size:12px}.reminder-card{display:grid;gap:14px;padding:16px;border:1px solid var(--border2);border-radius:var(--radius-lg);background:var(--card);box-shadow:var(--shadow-soft)}.reminder-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.reminder-head h2{margin:0 0 5px;color:var(--text);font-size:24px;font-weight:800}.reminder-head p{margin:0;color:var(--muted);font-size:14px}.reminder-head span{flex:0 0 auto;padding:6px 10px;border:1px solid var(--accent-dim);border-radius:var(--radius-pill);background:var(--accent-bg);color:var(--accent);font-family:var(--font-mono);font-size:11px}.reminder-list{display:grid;gap:9px}.reminder-row{display:grid;grid-template-columns:42px minmax(0,1fr) 92px 36px;align-items:center;gap:8px}@media (max-width: 380px){.stat-row{grid-template-columns:repeat(2,1fr)}.today-widget__macros{grid-template-columns:repeat(2,minmax(0,1fr))}.food-grid,.custom-food,.input-grid{grid-template-columns:1fr}.reminder-row{grid-template-columns:42px minmax(0,1fr)}.reminder-row input[type=time],.reminder-row>button{grid-column:2}}.reminder-row input[type=text],.reminder-row input:not([type]){min-width:0}.reminder-row input[type=time]{min-width:0;font-family:var(--font-mono)}.reminder-row>button{min-height:40px;border:1px solid var(--border);border-radius:var(--radius);background:var(--card2);color:var(--muted);font-family:var(--font-mono)}.reminder-switch{position:relative;display:block;width:42px;height:26px}.reminder-switch input{position:absolute;width:1px;height:1px;opacity:0}.reminder-switch span{position:absolute;top:0;right:0;bottom:0;left:0;border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--card2);transition:background .18s ease,border-color .18s ease}.reminder-switch span:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:var(--muted2);transition:transform .18s ease,background .18s ease}.reminder-switch input:checked+span{border-color:var(--accent-dim);background:var(--accent-bg)}.reminder-switch input:checked+span:after{transform:translate(16px);background:var(--accent)}.reminder-actions{display:grid;grid-template-columns:1fr 92px;gap:8px}.reminder-card small{color:var(--muted);font-size:12px;line-height:1.45}.history-card strong{display:block;margin-top:8px;color:var(--accent)}.empty{margin:28px 0;color:var(--muted);font-family:var(--font-mono);text-align:center}.tab-bar{position:fixed;right:0;bottom:0;left:0;z-index:10;display:grid;grid-template-columns:repeat(4,1fr);width:min(100%,480px);min-height:calc(64px + var(--safe-bottom));margin:0 auto;padding:8px 10px calc(8px + var(--safe-bottom));border-top:1px solid var(--border);background:var(--card);box-shadow:0 -10px 24px color-mix(in srgb,var(--text) 8%,transparent)}.tab-bar button{border:0;border-radius:var(--radius-pill);background:transparent;color:var(--muted);font-size:13px;font-weight:700}.tab-bar button.active{background:var(--accent-bg);color:var(--accent)}@keyframes pulse{0%,to{opacity:.55}50%{opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translate(18px)}to{opacity:1;transform:translate(0)}}
