:root{--bg:#fff4fb;--panel:#fff;--ink:#201823;--muted:#746a78;--line:#e8cfe0;--soft:#fff8fc;--pink:#cf5aa5;--pink-strong:#bd3d92;--violet:#6d5d9b;--violet-dark:#4f447f;--mint:#2f9d88;--yellow:#e6a83d;--shadow:0 18px 44px #7c4c7026;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html{background:radial-gradient(circle at 14% 4%, #cf5aa521, transparent 28rem), linear-gradient(180deg, #fff7fd 0%, var(--bg) 48%, #fff 100%);min-height:100%;overflow-x:hidden}body{min-height:100%;color:var(--ink);background:0 0;margin:0;overflow-x:hidden}body.menu-open{overflow:hidden}.topbar-actions{justify-content:flex-end;align-items:center;gap:10px;min-width:0;display:flex}.auth-strip{align-items:center;gap:8px;min-width:0;display:flex}.auth-strip input{border:1px solid var(--line);background:#ffffffd1;border-radius:999px;width:min(210px,42vw);min-height:38px;padding:0 12px}.auth-button{white-space:nowrap;justify-content:center;align-items:center;gap:6px;min-height:38px;display:inline-flex}.user-strip span{max-width:190px;color:var(--muted);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.error-state{color:#a52d4f}.empty-list{border:1px dashed var(--line);color:var(--muted);text-align:center;border-radius:18px;margin:0;padding:14px}.entry-form-inner{gap:16px;display:grid}.item-actions{align-items:center;gap:6px;display:flex}.entry-remove svg,.icon-button svg,.action-button svg,.ghost-button svg{pointer-events:none}@media (width<=760px){.topbar-actions{flex-direction:column-reverse;align-items:flex-end}.auth-strip{flex-wrap:wrap;justify-content:flex-end;width:100%}.auth-strip input{width:min(100%,260px)}}button,input,select,textarea{font:inherit}button{cursor:pointer;border:0}h1,h2,p{margin:0}.menu-backdrop{z-index:20;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#20182357;position:fixed;inset:0}.side-menu{z-index:30;width:min(82vw,330px);padding:max(22px, env(safe-area-inset-top)) 18px max(22px, env(safe-area-inset-bottom));color:var(--ink);background:#fffffffa;transition:transform .18s;position:fixed;inset:0 auto 0 0;transform:translate(-104%);box-shadow:22px 0 44px #3c20362e}body.menu-open .side-menu{transform:translate(0)}.drawer-brand{align-items:center;gap:12px;padding:8px 6px 22px;display:flex}.drawer-brand img{flex:none;width:44px;height:44px}.drawer-brand strong,.drawer-brand span{display:block}.drawer-brand strong{font-size:1.18rem;line-height:1.05}.drawer-brand span{color:var(--muted);margin-top:3px;font-size:.88rem;font-weight:650}.drawer-nav{gap:8px;display:grid}.drawer-link{min-height:58px;color:var(--ink);text-align:left;background:0 0;border-radius:18px;align-items:center;gap:12px;padding:0 14px;font-size:1.1rem;font-weight:820;display:flex}.drawer-link.is-active{color:#fff;background:linear-gradient(135deg, var(--pink), var(--violet))}.nav-mark{width:34px;height:34px;color:var(--pink-strong);background:#fff2fa;border-radius:12px;place-items:center;font-size:.78rem;font-weight:900;display:inline-grid}.drawer-link.is-active .nav-mark{color:var(--violet-dark);background:#fff}.app-shell{width:min(100%,980px);max-width:100%;min-height:100svh;padding:max(2px, env(safe-area-inset-top)) 16px calc(max(32px, env(safe-area-inset-bottom)) + 92px);margin:0 auto}.topbar{z-index:16;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#fff4fbe0;grid-template-columns:48px minmax(0,1fr) auto auto;align-items:center;gap:10px;min-height:68px;margin:-2px -6px 10px;padding:8px 6px;display:grid;position:relative;top:auto}.topbar.is-docked{width:min(100%,980px);padding:max(8px, env(safe-area-inset-top)) 16px 8px;align-items:start;margin:0;position:fixed;top:0;left:50%;transform:translate(-50%);box-shadow:0 12px 24px #7c4c701f}.icon-button{width:48px;height:48px;color:var(--ink);background:#fff;border:1px solid #e8cfe0e6;border-radius:18px;place-items:center;display:inline-grid;box-shadow:0 10px 24px #7c4c701f}.hamburger,.hamburger:before,.hamburger:after{background:currentColor;border-radius:999px;width:21px;height:2px;display:block}.hamburger{position:relative}.hamburger:before,.hamburger:after{content:"";position:absolute;left:0}.hamburger:before{top:-7px}.hamburger:after{top:7px}.topbar-title{opacity:0;text-align:left;visibility:hidden;min-width:0;transition:opacity .16s,transform .16s,visibility .16s;transform:translateY(-4px)}.topbar.is-docked .topbar-title{opacity:1;visibility:visible;transform:translateY(0)}.topbar.is-docked .topbar-title h1,.topbar.is-docked .topbar-title span{text-overflow:clip;white-space:normal;overflow:visible}.topbar.is-docked .topbar-title h1{line-height:1.12}.topbar.is-docked .topbar-title span{line-height:1.18}.topbar-title span{color:var(--violet-dark);letter-spacing:0;text-overflow:ellipsis;white-space:nowrap;margin-top:2px;font-size:.78rem;font-weight:850;line-height:1.1;display:block;overflow:hidden}h1{letter-spacing:0;text-overflow:ellipsis;white-space:nowrap;font-size:clamp(1.08rem,4.8vw,1.55rem);font-weight:850;line-height:1.05;overflow:hidden}.topbar-logo{justify-self:end;width:42px;height:42px}.topbar.is-docked .topbar-logo{display:none}.topbar-day-controls{background:#ffffffd1;border:1px solid #e8cfe0eb;border-radius:16px;align-items:center;gap:4px;min-width:max-content;padding:4px;display:none}.topbar.is-docked .topbar-day-controls{display:inline-flex}.topbar-day-controls span{min-width:72px;color:var(--violet-dark);text-align:center;white-space:nowrap;font-size:.82rem;font-weight:900}.topbar-day-button{width:34px;height:34px;color:var(--violet-dark);background:#fff;border:1px solid #ebd6e5;border-radius:12px;place-items:center;display:inline-grid}.topbar.is-docked .install-state{display:none}.topbar.is-docked .topbar-actions{flex-direction:row;align-items:center}.bottom-action-bar{bottom:max(10px, env(safe-area-inset-bottom));z-index:14;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#fffffff5;border:1px solid #e8cfe0f2;border-radius:24px;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;width:min(100% - 24px,360px);min-height:70px;padding:8px;display:grid;position:fixed;left:50%;transform:translate(-50%);box-shadow:0 18px 40px #5b30522e}.bottom-action-button{min-width:0;min-height:54px;color:var(--violet-dark);background:var(--soft);border:1px solid #efd9e8;border-radius:18px;place-items:center;transition:transform .14s,filter .14s;display:inline-grid;box-shadow:inset 0 0 0 1px #ffffffbd}.bottom-action-button.is-active{color:#fff;background:linear-gradient(135deg, var(--pink), var(--violet))}.bottom-action-button:active{transform:translateY(1px)}.bottom-action-button svg{pointer-events:none}.bottom-icon-stack{place-items:center;width:38px;height:38px;display:inline-grid;position:relative}.bottom-plus{color:#fff;background:var(--mint);box-sizing:content-box;border:2px solid #fff;border-radius:999px;padding:2px;position:absolute;bottom:-3px;right:-4px}.view{padding-bottom:10px;display:none}.view.is-active{display:block}.view-hero{padding:18px 2px 8px}.day-nav{background:#ffffffc7;border:1px solid #e8cfe0e6;border-radius:20px;grid-template-columns:52px minmax(0,1fr) 52px;align-items:center;gap:10px;min-height:62px;margin-top:10px;padding:8px;display:grid;box-shadow:0 10px 24px #7c4c701a}.day-nav-button{width:48px;height:48px;color:var(--violet-dark);background:#fff;border:1px solid #ebd6e5;border-radius:16px;place-items:center;display:inline-grid}.day-nav-current{text-align:center;grid-template-columns:auto minmax(0,1fr);justify-content:center;align-items:center;gap:2px 8px;min-width:0;display:grid}.day-nav-current svg{color:var(--violet-dark)}.day-nav-current span,.day-nav-current strong{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.day-nav-current span{color:var(--pink-strong);text-transform:uppercase;font-size:.76rem;font-weight:850}.day-nav-current strong{color:var(--violet-dark);text-overflow:clip;white-space:normal;font-size:clamp(.95rem,3.9vw,1.18rem);font-weight:850;line-height:1.1;overflow:visible}.eyebrow{color:var(--pink-strong);letter-spacing:.08em;text-transform:uppercase;margin-bottom:4px;font-size:.82rem;font-weight:850}h2{letter-spacing:0;font-size:clamp(1.72rem,7vw,2.55rem);font-weight:850;line-height:1.04}.panel{width:100%;max-width:100%;box-shadow:var(--shadow);background:#fffffff7;border:1px solid #fffc;border-radius:28px;margin-top:16px;padding:clamp(20px,5.4vw,32px)}.field-grid{grid-template-columns:1fr;gap:18px;display:grid}.field-grid.compact{gap:14px}.goals-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.goals-grid .field-wide{grid-column:1/-1}.field{gap:9px;display:grid}.field span{font-size:clamp(1.03rem,4.6vw,1.45rem);font-weight:820;line-height:1.1}input,select,textarea{color:#120d16;border:2px solid var(--line);background:#fff;border-radius:20px;outline:0;width:100%;min-height:64px;padding:12px 18px;font-size:clamp(1.34rem,6.2vw,2.15rem);line-height:1;box-shadow:inset 0 0 0 1px #dbadcc47}textarea{resize:vertical;min-height:104px;font-size:clamp(1rem,4.2vw,1.2rem);line-height:1.35}input[type=date],input[type=time],select{min-height:64px;font-size:clamp(1.1rem,4.8vw,1.42rem);font-weight:760}input[type=text]{font-size:clamp(1.2rem,5vw,1.7rem)}input[type=range]{min-height:auto;accent-color:var(--pink);box-shadow:none;border:0;padding:0}input::placeholder{color:#847f86}input:focus,select:focus,textarea:focus{border-color:var(--pink);box-shadow:0 0 0 5px #cf5aa529}.activity-panel{display:none}.activity-panel.is-active{display:block}.entry-form{gap:16px;display:grid}.form-panel-heading{margin-bottom:2px}.form-panel-heading h2{font-size:clamp(1.55rem,6.4vw,2.28rem)}.activity-panel>.field+.section-heading{margin-top:18px}.form-section-title{color:var(--ink);margin:2px 0 -4px;font-size:clamp(1.12rem,4.8vw,1.45rem);font-weight:900;line-height:1.1}.entry-form+.entry-form,.quick-grid{margin-top:18px}.duration-control,.kcal-control{background:var(--soft);border:1px solid #f0d8e8;border-radius:18px;gap:14px;padding:16px;display:grid}.kcal-input-field{margin-top:2px}.grade-builder{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.grade-builder select{flex:64px;min-width:64px;min-height:52px;padding-inline:12px;font-size:clamp(1rem,4.4vw,1.28rem)}.grade-builder span{color:var(--muted);font-size:1.25rem;font-weight:900}.duration-heading,.range-field{grid-template-columns:1fr auto;align-items:center;gap:12px;display:grid}.duration-heading span,.range-field span{color:var(--ink);font-size:1rem;font-weight:850}.duration-heading output,.range-field output{color:var(--violet-dark);white-space:nowrap;font-weight:850}.range-field input{grid-column:1/-1}.stepper-row{grid-column:1/-1;grid-template-columns:44px minmax(0,1fr) 44px;align-items:center;gap:10px;display:grid}.stepper-row input{grid-column:auto}.stepper-button{width:44px;height:44px;color:var(--pink-strong);background:#fff;border:1px solid #efcfe3;border-radius:14px;place-items:center;font-size:1.25rem;font-weight:900;line-height:1;display:inline-grid}.stepper-button:active{transform:translateY(1px)}.quick-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.quick-button,.ghost-button{min-height:46px;color:var(--pink-strong);background:#fff2fa;border:1px solid #efcfe3;border-radius:14px;padding:0 12px;font-weight:850}.quick-button{min-width:0;font-size:clamp(.86rem,3.6vw,1rem)}.wide-button{justify-content:center;align-items:center;gap:8px;width:100%;display:inline-flex}.action-button{color:#fff;text-align:center;border-radius:21px;justify-content:center;align-items:center;gap:10px;min-height:74px;padding:13px 16px;font-size:clamp(1.25rem,5.4vw,1.85rem);font-weight:850;line-height:1.05;transition:transform .14s,filter .14s;display:inline-flex;box-shadow:0 14px 24px #9a4e892e}.action-button:active,.quick-button:active,.ghost-button:active,.drawer-link:active{transform:translateY(1px)}.action-primary{background:linear-gradient(180deg, var(--pink) 0%, var(--pink-strong) 100%)}.action-secondary{background:linear-gradient(180deg, var(--violet) 0%, var(--violet-dark) 100%)}.action-full{width:100%}.action-icon{color:#1410186b;place-items:center;width:30px;font-size:1.25em;font-weight:900;display:inline-grid}.section-heading{justify-content:space-between;align-items:center;gap:14px;display:flex}.subheading{color:var(--violet-dark);font-size:1rem;font-weight:850}.session-form{margin-top:18px}.route-form{border-top:1px solid #f0d8e8;margin-top:22px;padding-top:18px}.compact-list{margin-top:16px}.session-total{background:var(--soft);border:1px solid #f0d8e8;border-radius:18px;justify-content:space-between;align-items:center;gap:14px;min-height:64px;margin-top:18px;padding:14px 16px;display:flex}.session-total span{color:var(--muted);font-weight:780}.session-total strong{font-size:clamp(1.35rem,5.7vw,2rem);line-height:1}.session-total-input input{text-align:right;width:min(46%,180px);min-height:52px;padding:10px 12px;font-size:clamp(1.2rem,5vw,1.55rem);font-weight:850}.session-total-unit{color:var(--violet-dark);margin-left:-6px;font-weight:850}.button-stack{gap:10px;margin-top:14px;display:grid}.inline-stat{color:var(--muted);margin-top:10px;font-size:.95rem;font-weight:780}.status-badge{color:#fff;background:var(--mint);text-align:center;white-space:nowrap;border-radius:17px;min-width:96px;padding:10px 13px;font-size:clamp(.94rem,3.8vw,1.1rem);font-weight:850}.status-badge.is-over{background:var(--yellow);color:#21150a}button:disabled{cursor:not-allowed;filter:grayscale(.35);opacity:.62}.progress-track{background:#f1dce9;border-radius:999px;height:16px;margin-top:22px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--mint), var(--pink));border-radius:inherit;width:0%;height:100%;transition:width .22s}.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:22px 0 0;display:grid}.metric-section-title{margin-top:24px}.metric-section-title+.metric-grid{margin-top:12px}.metric-grid div{background:var(--soft);border:1px solid #f0d8e8;border-radius:18px;min-width:0;padding:14px}.metric-grid dt{color:var(--muted);font-size:.9rem;font-weight:780}.metric-grid dd{overflow-wrap:anywhere;margin:5px 0 0;font-size:clamp(1.35rem,5.7vw,2.05rem);font-weight:850;line-height:1}.chart-heading{align-items:flex-start}.range-tabs{background:#f2ddea;border-radius:16px;grid-template-columns:repeat(3,minmax(44px,1fr));gap:4px;padding:4px;display:inline-grid}.range-tab{min-height:38px;color:var(--muted);background:0 0;border-radius:12px;padding:0 10px;font-size:.95rem;font-weight:850}.range-tab.is-active{color:#fff;background:var(--violet)}.chart-wrap{aspect-ratio:2;width:100%;min-height:230px;margin-top:20px;position:relative}canvas{width:100%;height:100%;display:block}.legend{color:var(--muted);flex-wrap:wrap;gap:10px 16px;margin-top:12px;font-size:.9rem;font-weight:760;display:flex}.legend span{align-items:center;gap:7px;display:inline-flex}.legend-line,.legend-dot{border-radius:999px;width:18px;height:5px;display:inline-block}.legend-line.balance{background:var(--violet-dark)}.legend-line.target{background:var(--violet)}.legend-dot{width:10px;height:10px}.legend-dot.eaten{background:var(--pink)}.legend-dot.burned{background:var(--mint)}.entry-list{gap:10px;margin:20px 0 0;padding:0;list-style:none;display:grid}.entry-item{background:var(--soft);border:1px solid #efd9e8;border-radius:18px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;min-height:66px;padding:12px;display:grid}.entry-item.is-selected,.entry-item.is-editing{border-color:var(--violet);box-shadow:0 0 0 4px #6d5d9b1f}.entry-preview-button{min-width:0;color:inherit;text-align:left;background:0 0;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;padding:0;display:grid}.entry-preview-button:focus-visible{outline-offset:4px;border-radius:12px;outline:3px solid #cf5aa547}.entry-main{min-width:0}.entry-name{text-overflow:ellipsis;white-space:nowrap;font-size:1.03rem;font-weight:850;display:block;overflow:hidden}.entry-meta,.entry-time{color:var(--muted);margin-top:3px;font-size:.82rem;font-weight:680;display:block}.entry-amount{white-space:nowrap;font-weight:880}.entry-amount.food{color:var(--pink-strong)}.entry-amount.exercise{color:var(--mint)}.delete-entry{color:#776b78;background:#fff;border:1px solid #ebd6e5;border-radius:14px;width:42px;height:42px;font-size:1.45rem;line-height:1}.entry-actions{justify-content:flex-end;gap:6px;display:flex}.mini-action{min-height:42px;color:var(--violet-dark);background:#fff;border:1px solid #ebd6e5;border-radius:14px;justify-content:center;align-items:center;gap:6px;padding:0 9px;font-size:.82rem;font-weight:850;display:inline-flex}.entry-preview-panel{margin-top:16px}.readonly-form{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:18px;display:grid}.readonly-form .field-wide{grid-column:1/-1}.readonly-form input,.readonly-form textarea{color:var(--muted);background:#fff9fd}.readonly-form.is-editing input,.readonly-form.is-editing textarea,.readonly-form.is-editing select{color:#120d16;background:#fff}.readonly-form.is-editing input.locked-preview-field,.readonly-form.is-editing textarea.locked-preview-field,.readonly-form.is-editing select.locked-preview-field{color:var(--muted);border-color:var(--line);background:#fff9fd;box-shadow:inset 0 0 0 1px #dbadcc47}.preview-routes{margin-top:18px}.route-preview-item{background:var(--soft);border:1px solid #efd9e8;border-radius:18px;grid-template-columns:minmax(0,1fr) auto;gap:5px 12px;padding:12px;display:grid}.route-preview-item strong,.route-preview-item span{min-width:0}.route-preview-item span{color:var(--muted);font-size:.88rem;font-weight:700}.route-preview-item output{grid-area:1/2/span 2;align-self:center;font-weight:880}.panel-action{margin-top:18px}.empty-state{color:var(--muted);background:var(--soft);border:1px dashed #e7c6da;border-radius:18px;padding:16px;font-size:1rem;font-weight:700}.install-state{min-height:24px;color:var(--muted);text-align:center;margin-top:14px;font-size:.85rem}@media (width>=720px){.app-shell,.topbar.is-docked{padding-inline:28px}.field-grid{grid-template-columns:1fr 1fr}.field-wide{grid-column:1/-1}.metric-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.panel{border-radius:24px}}@media (width<=420px){.topbar.is-docked{grid-template-columns:48px minmax(0,1fr);gap:6px 8px}.topbar.is-docked .topbar-title{grid-area:1/2}.topbar.is-docked .topbar-actions{grid-area:1;display:none}.topbar.is-docked .topbar-day-controls{grid-area:2/1/auto/-1;justify-content:space-between;width:100%;min-width:0}.topbar-day-controls span{text-overflow:clip;white-space:normal;flex:auto;min-width:0;line-height:1.15;overflow:visible}.section-heading{flex-direction:column;align-items:flex-start}.range-tabs{width:100%}}@media (width<=360px){.quick-grid{grid-template-columns:1fr}.entry-item{grid-template-columns:1fr auto}.delete-entry,.entry-actions{grid-column:1/-1}.entry-actions{justify-content:stretch}.entry-actions>*{flex:auto}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
