*,:before,:after{box-sizing:border-box}:root{--bg:#0c1017;--bg-elevated:#131a24;--surface:#1a2332;--surface-hover:#222d3f;--border:#ffffff12;--border-strong:#ffffff1f;--text:#e8edf4;--text-muted:#8fa3bc;--text-subtle:#5c7089;--accent:#34d399;--accent-bright:#6ee7b7;--accent-dim:#34d3991f;--accent-glow:#34d39940;--danger:#f87171;--danger-dim:#f871711f;--radius-sm:.5rem;--radius-md:.75rem;--radius-lg:1rem;--radius-xl:1.25rem;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 24px #00000059;--shadow-glow:0 0 40px var(--accent-glow);--font-body:"DM Sans", system-ui, sans-serif;--font-display:"Outfit", system-ui, sans-serif;--sidebar-width:240px;--mobile-nav-height:64px;--content-max:1280px}body{font-family:var(--font-body);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;margin:0;font-size:15px;line-height:1.5}#root{min-height:100vh}h1,h2,h3{font-family:var(--font-display);letter-spacing:-.02em;color:var(--text);font-weight:600}h1{margin:0;font-size:1.5rem}h2{margin:0 0 .75rem;font-size:1.1rem}h3{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:0 0 .65rem;font-size:.85rem}p{margin:0}button{font-family:inherit}input:focus-visible,button:focus-visible,a:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.app-shell{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-elevated);border-inline-end:1px solid var(--border);z-index:10;flex-direction:column;padding:1.5rem 1rem;display:flex;position:fixed;inset-block:0;inset-inline-start:0}.brand{align-items:center;gap:.65rem;padding:.25rem .5rem 1.75rem;display:flex}.brand-mark{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--accent) 0%, #14b8a6 100%);color:#0c1017;width:2.25rem;height:2.25rem;font-family:var(--font-display);box-shadow:var(--shadow-glow);place-items:center;font-size:1rem;font-weight:700;display:grid}.brand-name{font-family:var(--font-display);letter-spacing:-.03em;font-size:1.15rem;font-weight:700}.sidebar-nav{flex-direction:column;gap:.25rem;display:flex}.nav-link{border-radius:var(--radius-md);color:var(--text-muted);align-items:center;gap:.6rem;padding:.6rem .75rem;font-size:.9rem;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex}.nav-link:hover{background:var(--surface);color:var(--text)}.nav-link.active{background:var(--accent-dim);color:var(--accent-bright)}.nav-icon{opacity:.85;font-size:1.05rem;line-height:1}.main-area{width:calc(100% - var(--sidebar-width));flex-direction:column;flex:1;min-width:0;min-height:100vh;margin-inline-start:var(--sidebar-width);padding:clamp(1.25rem,2.5vw,2.5rem) clamp(1rem,4vw,3rem);display:flex}.main-content{width:100%;max-width:var(--content-max);flex-direction:column;flex:1;margin-inline:auto;display:flex}.page-container{flex:1;width:100%;min-width:0}.page-header{width:100%;margin-bottom:1.75rem}.page-header h1{margin-bottom:.35rem;font-size:1.75rem}.page-header p{color:var(--text-muted);max-width:60ch;font-size:.95rem}.app-footer{border-top:1px solid var(--border);width:100%;margin-top:2.5rem;padding-top:1.5rem}.footer-inner{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1.5rem;margin-bottom:1.25rem;display:flex}.footer-brand{align-items:flex-start;gap:.75rem;display:flex}.footer-mark{border-radius:var(--radius-sm);background:var(--accent-dim);width:2rem;height:2rem;color:var(--accent-bright);font-family:var(--font-display);flex-shrink:0;place-items:center;font-size:.9rem;font-weight:700;display:grid}.footer-name{font-family:var(--font-display);margin:0 0 .2rem;font-size:.95rem;font-weight:600}.footer-tagline{color:var(--text-muted);max-width:28ch;margin:0;font-size:.82rem}.footer-nav{flex-wrap:wrap;gap:.5rem 1rem;display:flex}.footer-nav a{color:var(--text-muted);font-size:.85rem;font-weight:500;text-decoration:none;transition:color .15s}.footer-nav a:hover{color:var(--accent-bright)}.footer-bottom{border-top:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding-top:1rem;display:flex}.footer-copy,.footer-credit{color:var(--text-subtle);margin:0;font-size:.78rem}.footer-credit a{color:var(--text-muted);text-decoration:none}.footer-credit a:hover{color:var(--accent-bright);text-decoration:underline}.mobile-nav{height:var(--mobile-nav-height);background:var(--bg-elevated);border-block-start:1px solid var(--border);z-index:10;display:none;position:fixed;inset-block-end:0;inset-inline:0}.mobile-nav .nav-link{text-align:center;border-radius:0;flex-direction:column;flex:1;justify-content:center;gap:.2rem;padding:.5rem;font-size:.7rem}.mobile-nav .nav-icon{font-size:1.25rem}.mobile-nav-inner{height:100%;display:flex}.stack{flex-direction:column;gap:1rem;display:flex}.stack-lg{gap:1.25rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:1.25rem}.card-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.card-header h2{margin:0}.card-badge{background:var(--accent-dim);color:var(--accent-bright);border-radius:999px;padding:.2rem .55rem;font-size:.75rem;font-weight:600}.stats-hero{background:linear-gradient(135deg, #1a2e28 0%, var(--surface) 60%);border-color:#34d39933;position:relative;overflow:hidden}.stats-hero:before{content:"";background:radial-gradient(circle, var(--accent-glow) 0%, transparent 70%);pointer-events:none;border-radius:50%;width:200px;height:200px;position:absolute;inset-block-start:-40%;inset-inline-end:-20%}.stats-hero-inner{justify-content:space-between;align-items:flex-end;gap:1rem;display:flex;position:relative}.stats-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:.35rem;font-size:.8rem;font-weight:600}.stat{font-family:var(--font-display);letter-spacing:-.04em;color:var(--accent-bright);margin:0;font-size:2.75rem;font-weight:700;line-height:1}.stat-unit{color:var(--text-muted);margin-inline-start:.15rem;font-size:1.1rem;font-weight:600}.stat-meta{color:var(--text-subtle);margin-top:.5rem;font-size:.85rem}.entry-form{flex-direction:column;gap:1rem;display:flex}.field{flex-direction:column;gap:.4rem;display:flex}.field span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.8rem;font-weight:600}.field-row{grid-template-columns:1fr 1fr;gap:.85rem;display:grid}input{font:inherit;color:var(--text);background:var(--bg);border:1px solid var(--border-strong);border-radius:var(--radius-md);padding:.65rem .85rem;font-size:.95rem;transition:border-color .15s,box-shadow .15s}input::placeholder{color:var(--text-subtle)}input:hover{border-color:#ffffff2e}input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim);outline:none}.input-readonly{color:var(--accent-bright);background:var(--accent-dim);cursor:default;border-color:#34d39933}.entry-mode-row{border-radius:var(--radius-md);background:var(--bg);border:1px solid var(--border);justify-content:space-between;align-items:center;gap:1rem;padding:.75rem .85rem;display:flex}.entry-mode-label{flex-direction:column;gap:.15rem;min-width:0;display:flex}.entry-mode-title{color:var(--text);font-size:.88rem;font-weight:600}.entry-mode-hint{color:var(--text-subtle);font-size:.78rem}.toggle-switch{cursor:pointer;flex-shrink:0;display:inline-flex;position:relative}.toggle-switch input{opacity:0;width:0;height:0;position:absolute}.toggle-track{background:var(--surface-hover);border:1px solid var(--border-strong);border-radius:999px;width:2.75rem;height:1.5rem;transition:background .2s,border-color .2s;display:block}.toggle-thumb{background:var(--text-muted);border-radius:999px;width:1.1rem;height:1.1rem;margin:.15rem;transition:transform .2s,background .2s;display:block}.toggle-switch input:checked+.toggle-track{background:var(--accent-dim);border-color:#34d39959}.toggle-switch input:checked+.toggle-track .toggle-thumb{background:var(--accent-bright);transform:translate(1.25rem)}.toggle-switch input:focus-visible+.toggle-track{outline:2px solid var(--accent);outline-offset:2px}.search-field{position:relative}.search-hint,.search-selected{margin:.35rem 0 0;font-size:.82rem}.search-hint{color:var(--text-subtle)}.search-selected{color:var(--accent-bright)}.search-dropdown{inset-inline:0;z-index:20;background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius-md);max-height:240px;box-shadow:var(--shadow-md);position:absolute;top:calc(100% - .25rem);overflow-y:auto}.search-option{border:none;border-bottom:1px solid var(--border);width:100%;color:var(--text);text-align:left;cursor:pointer;background:0 0;flex-direction:column;align-items:flex-start;gap:.15rem;padding:.65rem .85rem;display:flex}.search-option:last-child{border-bottom:none}.search-option:hover{background:var(--surface-hover)}.search-option-name{font-size:.9rem;font-weight:600}.search-option-meta{color:var(--text-muted);font-size:.78rem}.search-status{color:var(--text-muted);margin:0;padding:.75rem .85rem;font-size:.85rem}.search-status-error{color:var(--danger)}.btn-primary:disabled{opacity:.45;cursor:not-allowed;transform:none}.btn-primary{border-radius:var(--radius-md);font:inherit;color:#0c1017;background:linear-gradient(135deg, var(--accent) 0%, #14b8a6 100%);cursor:pointer;box-shadow:0 2px 12px var(--accent-glow);border:none;justify-content:center;align-items:center;gap:.4rem;padding:.7rem 1.1rem;font-size:.9rem;font-weight:600;transition:opacity .15s,transform .1s;display:inline-flex}.btn-primary:hover{opacity:.92}.btn-primary:active{transform:scale(.98)}.btn-ghost{border:1px solid var(--border-strong);border-radius:var(--radius-sm);font:inherit;color:var(--text-muted);cursor:pointer;background:0 0;padding:.35rem .65rem;font-size:.8rem;font-weight:500;transition:background .15s,color .15s,border-color .15s}.btn-ghost:hover{background:var(--surface-hover);border-color:var(--border-strong);color:var(--text)}.btn-ghost.btn-danger:hover{background:var(--danger-dim);color:var(--danger);border-color:#f871714d}.btn-primary.btn-sm{padding:.45rem .85rem;font-size:.82rem}.error-text{border-radius:var(--radius-sm);background:var(--danger-dim);color:var(--danger);margin:0;padding:.55rem .75rem;font-size:.85rem}.entry-list{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.entry-item{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);justify-content:space-between;align-items:center;gap:1rem;padding:.85rem 1rem;transition:border-color .15s,background .15s;display:flex}.entry-item:hover{border-color:var(--border-strong);background:var(--surface-hover)}.entry-name{margin:0;font-size:.95rem;font-weight:600}.entry-meta{align-items:center;gap:.5rem;margin-top:.35rem;display:flex}.meta-pill{color:var(--text-muted);background:var(--surface);border:1px solid var(--border);border-radius:999px;align-items:center;gap:.25rem;padding:.15rem .5rem;font-size:.78rem;font-weight:500;display:inline-flex}.meta-pill.calories{color:var(--accent-bright);background:var(--accent-dim);border-color:#34d39933}.entry-actions{flex-shrink:0;align-items:center;gap:.35rem;display:flex}.entry-item-editing{flex-direction:column;align-items:stretch;padding:1rem}.entry-editor{flex-direction:column;gap:.85rem;width:100%;display:flex}.entry-editor-actions{justify-content:flex-end;gap:.5rem;display:flex}.btn-add-entry{border:1px dashed var(--border-strong);border-radius:var(--radius-md);width:100%;color:var(--text-muted);font:inherit;cursor:pointer;background:0 0;margin-top:.65rem;padding:.55rem;font-size:.82rem;font-weight:500;transition:border-color .15s,color .15s,background .15s;display:block}.btn-add-entry:hover{border-color:var(--accent);color:var(--accent-bright);background:var(--accent-dim)}.btn-add-entry-primary{background:var(--surface);border-style:solid}.history-log-card{flex-direction:column;gap:.85rem;display:flex}.empty-state{text-align:center;flex-direction:column;align-items:center;gap:.5rem;padding:2rem 1rem;display:flex}.empty-icon{opacity:.5;margin-bottom:.25rem;font-size:2rem}.empty-state p{color:var(--text-muted);max-width:260px;font-size:.9rem}.history-day{border-block-end:1px solid var(--border);padding-block-end:1.25rem}.history-day:last-child{border-block-end:none;padding-block-end:0}.history-day-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.date-pill{font-family:var(--font-display);color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:999px;align-items:center;gap:.4rem;padding:.3rem .7rem;font-size:.85rem;font-weight:600;display:inline-flex}.day-total{color:var(--accent-bright);font-size:.8rem;font-weight:600}.muted{color:var(--text-muted);font-size:.9rem}.chart-wrap{width:100%;min-height:280px;margin-top:.5rem}.chart-wrap .recharts-responsive-container{min-height:280px}.today-grid{grid-template-columns:1fr;align-items:start;gap:1.25rem;display:grid}.login-page{justify-content:center;width:100%;display:flex}.login-card{width:100%;max-width:440px}.login-icon{border-radius:var(--radius-lg);background:var(--accent-dim);place-items:center;width:3rem;height:3rem;margin-bottom:1rem;font-size:1.4rem;display:grid}.coming-soon-tag{text-transform:uppercase;letter-spacing:.06em;color:var(--text-subtle);border:1px dashed var(--border-strong);border-radius:999px;margin-top:1rem;padding:.25rem .6rem;font-size:.75rem;font-weight:600;display:inline-block}.auth-form{margin-top:1rem}.btn-link{color:var(--accent-bright);font:inherit;cursor:pointer;text-underline-offset:3px;background:0 0;border:none;margin-top:1rem;padding:0;font-size:.88rem;text-decoration:underline}.sidebar-user{border-top:1px solid var(--border);margin-top:auto;padding:.75rem .5rem 0}.user-email{color:var(--text-muted);word-break:break-all;margin:0 0 .5rem;font-size:.78rem}.btn-sm-logout{justify-content:center;width:100%}.welcome{flex-direction:column;gap:1.25rem;display:flex}.welcome-hero{background:linear-gradient(135deg, #1a2e28 0%, var(--surface) 55%);border-color:#34d39933;padding:clamp(1.25rem,3vw,2rem)}.welcome-tag{text-transform:uppercase;letter-spacing:.08em;color:var(--accent-bright);margin:0 0 .75rem;font-size:.78rem;font-weight:600}.welcome-title{font-family:var(--font-display);letter-spacing:-.03em;margin:0 0 1rem;font-size:clamp(1.55rem,3vw,2.35rem);line-height:1.15}.welcome-accent{color:var(--accent-bright)}.welcome-lead{max-width:65ch;color:var(--text-muted);margin:0 0 1.5rem;font-size:clamp(.95rem,1.5vw,1.05rem);line-height:1.6}.welcome-actions{flex-wrap:wrap;gap:.65rem;display:flex}.welcome-actions .btn-primary,.welcome-actions .btn-ghost-lg{text-decoration:none}.btn-ghost-lg{align-items:center;padding:.7rem 1.1rem;font-size:.9rem;display:inline-flex}.welcome-features{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}.welcome-feature h3{text-transform:none;letter-spacing:normal;color:var(--text);margin:.5rem 0 .35rem;font-size:1rem}.welcome-feature-icon{font-size:1.5rem}.welcome-steps h3{text-transform:none;letter-spacing:normal;margin:0 0 1rem;font-size:1rem}.welcome-step-list{flex-direction:column;gap:.65rem;margin:0;padding:0;list-style:none;display:flex}.welcome-step-list li{color:var(--text-muted);align-items:center;gap:.75rem;font-size:.95rem;display:flex}.step-number{background:var(--accent-dim);width:1.75rem;height:1.75rem;color:var(--accent-bright);border-radius:999px;flex-shrink:0;place-items:center;font-size:.82rem;font-weight:700;display:grid}@media (width>=900px){.today-grid{grid-template-columns:minmax(280px,1fr) minmax(320px,1.2fr)}}@media (width>=1100px){.welcome-features{grid-template-columns:repeat(4,1fr)}.chart-wrap,.chart-wrap .recharts-responsive-container{min-height:360px}}@media (width<=768px){.sidebar{display:none}.main-area{width:100%;padding:1.25rem 1rem calc(var(--mobile-nav-height) + 1.25rem);margin-inline-start:0}.page-header h1{font-size:1.4rem}.stat{font-size:2.25rem}.mobile-nav{display:block}.field-row{grid-template-columns:1fr}.entry-item{flex-direction:column;align-items:stretch}.entry-actions{justify-content:flex-end;margin-top:.5rem}.welcome-features{grid-template-columns:1fr}.welcome-title{font-size:1.55rem}.footer-inner{flex-direction:column}.footer-bottom{flex-direction:column;align-items:flex-start}}
