:root{color-scheme:light;--theme-dark-grey: #111111;--theme-deep-orange: #d1d1d1;--theme-light-orange: #7a7a7a;--theme-orange-yellow: #4f4f4f;--theme-page-bg: #f3f3f3;--theme-surface: #ffffff;--theme-surface-alt: #ededed;--theme-text: #334155;--theme-text-muted: #64748b;--theme-text-soft: #7c8ea3;--theme-border: #cccccc;--theme-shadow: rgba(0, 0, 0, .16);--theme-control-bg: #ffffff;--theme-control-bg-hover: #f5f5f5;--theme-primary-bg: #111111;--theme-primary-text: #ffffff;--theme-danger: #9f1d1d;--theme-danger-bg: #f5dddd;font-family:Aptos,Segoe UI,sans-serif;background:var(--theme-page-bg);color:var(--theme-text);font-synthesis:none;line-height:1.5}html{scrollbar-gutter:stable}*{box-sizing:border-box}body{margin:0}button,input{font:inherit}.page{min-height:100vh;padding:36px 20px;background:radial-gradient(circle at 18% 4%,rgba(17,17,17,.12),transparent 34%),radial-gradient(circle at 92% 14%,rgba(122,122,122,.14),transparent 28%),linear-gradient(180deg,#f3f3f3,#fff)}.daily-board,.weekly-board{width:min(1240px,100%);margin:0 auto}.daily-board--state{display:grid;min-height:calc(100vh - 72px);place-items:center}.state-card{width:min(480px,100%);padding:28px;border:1px solid var(--theme-border);border-radius:8px;background:var(--theme-surface);box-shadow:0 20px 50px var(--theme-shadow)}.state-card h1,.board-header h1{margin:0;color:var(--theme-text);font-size:clamp(1.65rem,2.8vw,2.55rem);font-weight:780;line-height:1.05;letter-spacing:.01em}.auth-card>p:not(.state-date){margin:18px 0 0;color:var(--theme-text-muted);font-weight:700}.auth-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}.auth-primary-button,.auth-secondary-button,.account-bar button{min-height:36px;padding:0 14px;border:1px solid var(--theme-primary-bg);border-radius:8px;background:var(--theme-primary-bg);color:var(--theme-primary-text);font-size:.8rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;cursor:pointer}.auth-secondary-button{border-color:var(--theme-border);background:var(--theme-control-bg);color:var(--theme-text)}.auth-primary-button:hover,.account-bar button:hover{background:var(--theme-orange-yellow)}.auth-secondary-button:hover{background:var(--theme-control-bg-hover)}.account-bar{display:flex;width:min(1240px,100%);align-items:center;justify-content:flex-end;gap:10px;margin:0 auto 14px;color:var(--theme-text-soft);font-size:.82rem;font-weight:800}.account-bar span{min-width:0;overflow-wrap:anywhere}.state-date,.eyebrow{margin:0 0 10px;color:var(--theme-text-soft);font-size:.78rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.error-text{margin:18px 0 0;color:var(--theme-text);font-weight:700}.board-header{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:stretch;gap:24px;margin-bottom:24px}.header-title{display:grid;align-content:space-between;min-width:0}.header-actions{display:grid;align-content:space-between;justify-items:end;gap:10px}.view-switch{display:inline-grid;grid-template-columns:repeat(2,minmax(86px,1fr));padding:4px;border:1px solid var(--theme-border);border-radius:8px;background:var(--theme-surface-alt)}.view-switch__button{min-height:34px;border:0;border-radius:6px;background:transparent;color:var(--theme-text-soft);cursor:pointer;font-size:.78rem;font-weight:800;text-transform:uppercase}.view-switch__button--active{background:var(--theme-dark-grey);color:var(--theme-surface);box-shadow:inset 0 0 0 1px #11111147}.view-switch__button:focus-visible{outline:3px solid rgba(17,17,17,.35);outline-offset:2px}.day-navigation{display:grid;grid-template-columns:42px minmax(76px,auto) 42px;align-items:stretch;gap:8px}.day-navigation button{display:grid;width:42px;min-height:64px;place-items:center;border:1px solid var(--theme-border);border-radius:8px;background:var(--theme-surface);color:var(--theme-text);cursor:pointer}.day-navigation button:hover{border-color:var(--theme-light-orange);background:#7a7a7a38}.day-navigation button:disabled{border-color:#7a7a7a59;background:#7a7a7a2e;color:#7a7a7ab3;cursor:default}.day-navigation button:disabled:hover{border-color:#7a7a7a59;background:#7a7a7a2e}.day-navigation button:focus-visible{outline:3px solid rgba(17,17,17,.35);outline-offset:2px}.day-navigation button span{display:block;font-size:2rem;font-weight:700;line-height:1;transform:translateY(-1px)}.today-button{min-width:76px;padding:0 14px;color:var(--theme-text);font-size:.82rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.add-meal-button{min-height:38px;padding:0 16px;border:1px solid var(--theme-deep-orange);border-radius:8px;background:var(--theme-deep-orange);color:var(--theme-dark-grey);font-size:.8rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;cursor:pointer}.add-meal-button:hover{border-color:var(--theme-light-orange);background:var(--theme-light-orange)}.add-meal-button:focus-visible{outline:3px solid rgba(17,17,17,.35);outline-offset:2px}.summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:14px}.weekly-summary{margin-bottom:18px}.metric-card{min-height:126px;padding:18px;border:1px solid var(--theme-border);border-radius:8px;background:var(--theme-surface)}.metric-card span,.footer-summary span,.progress-copy span{color:var(--theme-text-soft);font-size:.78rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase}.metric-card strong{display:block;margin-top:16px;color:var(--theme-text);font-size:clamp(1.55rem,3vw,2.35rem);line-height:1}.metric-card p{margin:10px 0 0;color:var(--theme-text-muted);font-size:.95rem}.metric-card--good{border-color:var(--theme-light-orange);background:#7a7a7a3d}.metric-card--warning{border-color:var(--theme-orange-yellow);background:#11111124}.progress-panel{margin-bottom:20px;padding:16px 18px;border:1px solid var(--theme-border);border-radius:8px;background:var(--theme-surface)}.add-meal-panel{margin-bottom:20px;padding:14px;border:1px solid var(--theme-border);border-radius:8px;background:var(--theme-surface)}.add-meal-title{margin:0 0 10px;color:var(--theme-text);font-size:.96rem;font-weight:900;letter-spacing:.05em;text-transform:uppercase}.add-meal-form{display:grid;gap:10px}.add-meal-form label{display:grid;gap:6px;color:var(--theme-text-soft);font-size:.78rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase}.add-meal-form input{width:100%;min-height:38px;padding:0 10px;border:1px solid var(--theme-border);border-radius:8px;background:var(--theme-control-bg);color:var(--theme-text);font-size:.95rem;text-transform:none;letter-spacing:0}.add-meal-form input::placeholder{color:var(--theme-text-soft);opacity:1}.add-meal-form input:focus-visible{outline:3px solid rgba(17,17,17,.35);outline-offset:1px}.category-presets{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px}.category-preset{min-height:34px;border:1px solid var(--theme-border);border-radius:8px;background:var(--theme-control-bg);color:var(--theme-text);font-size:.74rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;cursor:pointer}.category-preset:hover{background:var(--theme-control-bg-hover)}.category-preset--active{border-color:var(--theme-primary-bg);background:var(--theme-primary-bg);color:var(--theme-primary-text)}.category-preset--active:hover{background:var(--theme-primary-bg);color:var(--theme-primary-text)}.meal-form-summary{margin:0;color:var(--theme-text-muted);font-size:.85rem;font-weight:700}.meal-form-warning,.meal-form-error{margin:0;font-size:.85rem;font-weight:700}.meal-form-warning{color:var(--theme-light-orange)}.meal-form-error{color:var(--theme-danger)}.add-meal-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.add-meal-actions button{min-height:34px;min-width:88px;padding:0 12px;border:1px solid var(--theme-border);border-radius:8px;background:var(--theme-control-bg);color:var(--theme-text);font-weight:700;cursor:pointer}.add-meal-actions button:hover:not(:disabled){background:var(--theme-control-bg-hover)}.add-meal-actions button[type=submit]{border-color:var(--theme-primary-bg);background:var(--theme-primary-bg);color:var(--theme-primary-text)}.add-meal-actions button[type=submit]:hover:not(:disabled){background:var(--theme-orange-yellow);color:var(--theme-primary-text)}.add-meal-actions button:disabled{cursor:default;opacity:.7}.progress-copy{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:12px}.progress-copy strong{color:var(--theme-light-orange);font-size:1.1rem}.progress-track{height:12px;overflow:hidden;border-radius:999px;background:var(--theme-dark-grey)}.progress-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--theme-deep-orange),var(--theme-light-orange) 70%,var(--theme-orange-yellow))}.meal-actions-bar{position:sticky;top:10px;z-index:5;display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:14px;padding:9px 11px;border:1px solid var(--theme-border);border-radius:8px;background:#fffffff2;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.add-meal-shortcut-hint{color:var(--theme-text-soft);font-size:.76rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase}.meal-timeline{display:grid;gap:18px}.meal-empty-state{display:grid;justify-items:start;gap:10px;padding:16px;border:1px dashed var(--theme-border);border-radius:8px;background:var(--theme-surface-alt)}.meal-empty-state>p{margin:0;color:var(--theme-text-muted);font-weight:700}.meal-empty-state__button{min-height:34px;padding:0 12px;border:1px solid var(--theme-deep-orange);border-radius:8px;background:var(--theme-deep-orange);color:var(--theme-dark-grey);font-size:.78rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;cursor:pointer}.meal-empty-state__button:hover{background:var(--theme-light-orange)}.meal-category-group{display:grid;gap:10px}.meal-category-header{display:flex;align-items:center;justify-content:space-between;gap:10px}.meal-category-header>h2{margin:0;color:var(--theme-text-soft);font-size:.82rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.category-toggle{display:inline-flex;width:24px;height:24px;align-items:center;justify-content:center;border:1px solid var(--theme-border);border-radius:6px;background:var(--theme-surface);color:var(--theme-light-orange);font-size:1rem;font-weight:800;line-height:1;cursor:pointer}.category-toggle:hover{border-color:var(--theme-light-orange);background:#7a7a7a3d}.category-toggle:focus-visible{outline:3px solid rgba(17,17,17,.35);outline-offset:2px}.meal-category-list{display:grid;gap:10px}.meal-row{display:grid;grid-template-columns:88px minmax(0,1fr) auto 52px;align-items:center;gap:12px;min-height:68px;padding:10px 12px;border:1px solid var(--theme-border);border-left:5px solid var(--theme-orange-yellow);border-radius:8px;background:#fffffff0}.meal-row--done{border-left-color:var(--theme-deep-orange);background:#7a7a7a3d}.meal-row--highlighted{box-shadow:0 0 0 2px #11111159}.meal-row--no-time{grid-template-columns:minmax(0,1fr) auto 52px}.time-chip{display:inline-flex;align-items:center;justify-content:center;height:34px;border:1px solid var(--theme-border);border-radius:999px;background:var(--theme-dark-grey);color:var(--theme-light-orange);font-weight:800;font-variant-numeric:tabular-nums}.meal-main{position:relative;min-width:0}.meal-title-row{display:flex;align-items:center;gap:8px;position:relative}.meal-title-row h2{margin:0;overflow-wrap:anywhere;color:var(--theme-text);font-size:1.08rem;line-height:1.2}.status-dot{width:8px;height:8px;flex:0 0 auto;border-radius:999px;background:var(--theme-orange-yellow)}.meal-row--done .status-dot{background:var(--theme-deep-orange)}.meal-numbers{display:grid;min-width:132px;gap:4px;text-align:right;white-space:nowrap}.meal-numbers span{color:var(--theme-text-soft);font-size:.92rem}.meal-numbers strong{color:var(--theme-text);font-size:1.08rem}.meal-check{position:relative;display:grid;width:32px;height:32px;place-items:center}.meal-check input{position:absolute;opacity:0}.meal-check span{width:26px;height:26px;border:2px solid var(--theme-text-muted);border-radius:7px;background:var(--theme-control-bg)}.meal-check input:checked+span{border-color:var(--theme-primary-bg);background:linear-gradient(135deg,transparent 55%,var(--theme-primary-text) 56%),linear-gradient(45deg,transparent 43%,var(--theme-primary-text) 44%),var(--theme-primary-bg)}.meal-check input:focus-visible+span{outline:3px solid rgba(17,17,17,.35);outline-offset:2px}.meal-actions{display:grid;gap:0;justify-items:center}.meal-more{width:24px;height:24px;padding:0;border:1px solid var(--theme-border);border-radius:6px;background:var(--theme-control-bg);color:var(--theme-text);font-size:1rem;font-weight:700;line-height:1;cursor:pointer}.meal-more:hover{border-color:var(--theme-light-orange);background:var(--theme-control-bg-hover);color:var(--theme-text)}.meal-more:focus-visible{outline:3px solid rgba(17,17,17,.35);outline-offset:1px}.meal-more:disabled{opacity:.55;cursor:default}.meal-menu{position:absolute;top:30px;left:0;z-index:6;min-width:124px;padding:4px;border:1px solid var(--theme-border);border-radius:8px;background:var(--theme-control-bg);box-shadow:0 10px 22px var(--theme-shadow)}.meal-menu__edit,.meal-menu__delete{width:100%;min-height:30px;padding:0 8px;border:0;border-radius:6px;background:transparent;color:var(--theme-danger);font-size:.8rem;font-weight:800;text-align:left;cursor:pointer}.meal-menu__edit{color:var(--theme-text)}.meal-menu__edit:hover{background:var(--theme-control-bg-hover)}.meal-menu__delete:hover{background:var(--theme-danger-bg)}.meal-menu__edit:disabled,.meal-menu__delete:disabled{opacity:.55;cursor:default}.undo-stack{position:fixed;right:16px;bottom:16px;z-index:40;display:grid;gap:8px;width:min(340px,calc(100vw - 24px))}.undo-toast{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 12px;border:1px solid var(--theme-border);border-radius:8px;background:var(--theme-surface);color:var(--theme-text);box-shadow:0 10px 24px var(--theme-shadow)}.undo-toast button{min-height:28px;min-width:58px;padding:0 10px;border:1px solid var(--theme-deep-orange);border-radius:7px;background:var(--theme-deep-orange);color:var(--theme-dark-grey);font-size:.78rem;font-weight:800;cursor:pointer}.undo-toast button:hover{background:var(--theme-light-orange)}.undo-toast--error{border-color:var(--theme-border);background:var(--theme-surface);color:var(--theme-text)}.footer-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:18px;padding:14px;border:1px solid var(--theme-border);border-radius:8px;background:var(--theme-surface)}.footer-summary div{display:grid;gap:4px;padding:4px}.footer-summary strong{color:var(--theme-text);font-size:1.15rem}.week-state-panel{padding:28px;border:1px solid var(--theme-border);border-radius:8px;background:var(--theme-surface);color:var(--theme-text-muted);font-weight:700}.week-grid{display:grid;grid-template-columns:repeat(7,minmax(160px,1fr));gap:10px;align-items:start}.week-day{min-width:0;overflow:hidden;border:1px solid var(--theme-border);border-radius:8px;background:#fffffff2}.week-day--today{border-color:var(--theme-deep-orange);box-shadow:inset 0 0 0 1px var(--theme-deep-orange)}.week-day-header{display:grid;width:100%;min-height:78px;gap:8px;padding:14px;border:0;border-bottom:1px solid var(--theme-border);background:var(--theme-surface);color:inherit;cursor:pointer;text-align:left}.week-day-header:hover{background:#7a7a7a3d}.week-day-header:focus-visible{outline:3px solid rgba(17,17,17,.35);outline-offset:-3px}.week-day-header span{color:var(--theme-text-soft);font-size:.76rem;font-weight:800;text-transform:uppercase}.week-day-header strong{color:var(--theme-text);font-size:1.18rem;line-height:1}.week-day-progress{height:7px;background:var(--theme-dark-grey)}.week-day-progress div{height:100%;max-width:100%;background:linear-gradient(90deg,var(--theme-deep-orange),var(--theme-light-orange),var(--theme-orange-yellow))}.week-meals{display:grid;gap:1px;padding:8px}.week-empty{margin:0;padding:12px 8px;color:var(--theme-text-soft);font-size:.9rem;font-weight:700}.week-meal{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:start;min-height:36px;padding:8px;border-radius:6px;color:var(--theme-text)}.week-meal:nth-child(odd){background:#7a7a7a33}.week-meal--done{background:#11111124}.week-meal span{min-width:0;overflow-wrap:anywhere;font-size:.88rem;line-height:1.2}.week-meal strong{color:var(--theme-text-soft);font-size:.84rem;font-variant-numeric:tabular-nums;white-space:nowrap}@media(max-width:760px){.page{padding:22px 12px}.board-header{grid-template-columns:1fr}.header-actions{justify-items:stretch}.view-switch{width:100%}.day-navigation{grid-template-columns:42px minmax(0,1fr) 42px}.today-button{min-height:42px;width:100%}.summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.category-presets{grid-template-columns:repeat(3,minmax(0,1fr))}.meal-actions-bar{position:static;flex-direction:column;align-items:stretch}.add-meal-shortcut-hint{text-align:right}.week-grid{grid-template-columns:1fr}.meal-row{grid-template-columns:72px minmax(0,1fr) 34px}.meal-row--no-time{grid-template-columns:minmax(0,1fr) 34px}.meal-numbers{grid-column:2 / 3;min-width:0;text-align:left}.meal-actions{grid-column:3;grid-row:1 / 3}}@media(max-width:520px){.state-card h1,.board-header h1{font-size:1.85rem}.summary-grid,.footer-summary{grid-template-columns:1fr}.category-presets{grid-template-columns:repeat(2,minmax(0,1fr))}.meal-row,.meal-row--no-time{grid-template-columns:1fr 34px}.time-chip{justify-content:flex-start;width:fit-content;padding:0 14px}.meal-main,.meal-numbers{grid-column:1 / 2}.undo-stack{left:12px;right:12px;width:auto}}
