@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--radius-lg:.5rem;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components,utilities;*{box-sizing:border-box;margin:0;padding:0}:root{--primary:#4f46e5;--primary-hover:#4338ca;--secondary:#6b7280;--secondary-hover:#4b5563;--danger:#ef4444;--danger-hover:#dc2626;--success:#22c55e;--warning:#f59e0b;--background:#f9fafb;--surface:#fff;--text:#111827;--text-secondary:#6b7280;--border:#e5e7eb;--border-focus:#4f46e5;--shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--radius:8px;--radius-lg:12px}body{background-color:var(--background);color:var(--text);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5}#root{min-height:100vh}.app{flex-direction:column;min-height:100vh;display:flex}.nav{background:var(--surface);border-bottom:1px solid var(--border);z-index:100;justify-content:space-between;align-items:center;height:56px;padding:0 1rem;display:flex;position:sticky;top:0}.nav-brand a{color:var(--primary);font-size:1.25rem;font-weight:700;text-decoration:none}.nav-links{gap:.5rem;display:none}@media(min-width:768px){.nav-links{display:flex}}.nav-link{border-radius:var(--radius);color:var(--text-secondary);align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.nav-link:hover{color:var(--text);background:var(--background)}.nav-link.active{color:var(--primary);background:#4f46e51a}.main-content{flex:1;width:100%;max-width:800px;margin:0 auto;padding:1.5rem 1.5rem 5rem}@media(min-width:768px){.main-content{padding-bottom:1.5rem}}.page{flex-direction:column;gap:1.5rem;display:flex}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.page-header h1{color:var(--text);font-size:1.5rem;font-weight:700}.date-display{color:var(--text-secondary);font-size:.875rem}.btn{border-radius:var(--radius);cursor:pointer;border:none;justify-content:center;align-items:center;padding:.625rem 1rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-secondary{background:var(--background);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--border)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:var(--danger-hover)}.btn-link{color:var(--primary);cursor:pointer;background:0 0;border:none;padding:0;font-weight:500}.btn-link:hover{text-decoration:underline}.btn-sm{padding:.375rem .75rem;font-size:.75rem}.btn-lg{padding:.875rem 1.5rem;font-size:1rem}.btn-full{width:100%}.btn-icon{min-width:2rem;height:2rem;padding:.5rem}.btn-add-food{border:1px dashed var(--border);color:var(--text-secondary);border-radius:var(--radius);cursor:pointer;background:0 0;width:100%;padding:.75rem;transition:all .15s}.btn-add-food:hover{border-color:var(--primary);color:var(--primary)}.form-group{flex-direction:column;gap:.375rem;display:flex}.form-group label{color:var(--text);font-size:.875rem;font-weight:500}.form-group input,.form-group select{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);padding:.625rem .875rem;font-size:.875rem;transition:border-color .15s}.form-group input:focus,.form-group select:focus{border-color:var(--border-focus);outline:none;box-shadow:0 0 0 3px #4f46e51a}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.input-with-select{gap:0;display:flex}.input-with-select input{border-right:none;border-top-right-radius:0;border-bottom-right-radius:0;flex:1}.input-with-select select{background-color:var(--bg-secondary);border-top-left-radius:0;border-bottom-left-radius:0;width:auto;min-width:70px}.form-actions{gap:.75rem;margin-top:.5rem;display:flex}.dashboard-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:1.5rem}.dashboard-card h2{color:var(--text-secondary);margin-bottom:1rem;font-size:1rem;font-weight:600}.calories-display{align-items:baseline;gap:.25rem;margin-bottom:1rem;display:flex}.calories-current{color:var(--text);font-size:2.5rem;font-weight:700}.calories-divider,.calories-goal{color:var(--text-secondary);font-size:1.5rem}.calories-remaining{color:var(--text-secondary);margin-top:.75rem;font-size:.875rem}.progress-bar-container{margin-bottom:1rem}.progress-bar-header{justify-content:space-between;margin-bottom:.375rem;display:flex}.progress-bar-label{color:var(--text);font-size:.875rem;font-weight:500}.progress-bar-values{color:var(--text-secondary);font-size:.875rem}.progress-bar-values.over-goal{color:var(--danger)}.progress-bar-track{background:var(--background);border-radius:4px;height:8px;overflow:hidden}.progress-bar-fill{border-radius:4px;height:100%;transition:width .3s}.macros-grid{flex-direction:column;gap:.5rem;display:flex}.dashboard-actions{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.login-page{justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.login-container{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:400px;padding:2rem}.login-container h1{text-align:center;margin-bottom:.5rem;font-size:1.5rem;font-weight:700}.login-subtitle{text-align:center;color:var(--text-secondary);margin-bottom:1.5rem}.login-form{flex-direction:column;gap:1rem;display:flex}.login-switch{text-align:center;color:var(--text-secondary);margin-top:1.5rem;font-size:.875rem}.error-message{color:var(--danger);border-radius:var(--radius);background:#ef44441a;padding:.75rem;font-size:.875rem}.field-error{color:var(--danger);margin-top:.25rem;font-size:.75rem}.field-hint{color:var(--text-secondary);margin-top:.25rem;font-size:.75rem}.input-readonly{background-color:var(--bg-secondary);cursor:not-allowed;opacity:.8}.success-message{color:var(--success);margin-top:.5rem;font-size:.875rem}.search-container{margin-bottom:1rem}.search-input{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);width:100%;padding:.75rem 1rem;font-size:.875rem}.search-input:focus{border-color:var(--border-focus);outline:none}.foods-list{flex-direction:column;gap:.75rem;display:flex}.food-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);flex-wrap:wrap;align-items:center;gap:1rem;padding:1rem;display:flex}.food-info{flex:1;min-width:150px}.food-info h3{margin-bottom:.25rem;font-size:1rem;font-weight:600}.serving-size{color:var(--text-secondary);font-size:.75rem}.food-macros{flex-wrap:wrap;gap:.75rem;display:flex}.macro{background:var(--background);color:var(--text-secondary);border-radius:4px;padding:.25rem .5rem;font-size:.75rem}.macro.calories{color:var(--primary);background:#4f46e51a;font-weight:500}.food-actions{gap:.5rem;display:flex}.foods-form-container{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:1.5rem}.foods-form-container h2{margin-bottom:1.25rem;font-size:1.125rem;font-weight:600}.food-form{flex-direction:column;gap:1rem;display:flex}.date-navigator{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 1rem;display:flex}.date-navigator .date-display{flex-direction:column;align-items:center;gap:.25rem;display:flex}.current-date{color:var(--text);font-weight:600}.date-picker-container{justify-content:center;display:flex}.date-picker{border:1px solid var(--border);border-radius:var(--radius);padding:.5rem;font-size:.875rem}.daily-summary{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);flex-wrap:wrap;align-items:center;gap:1rem;padding:1rem;display:flex}.summary-label{color:var(--text-secondary);font-weight:500}.summary-calories{color:var(--primary);font-size:1.25rem;font-weight:700}.summary-macros{color:var(--text-secondary);font-size:.875rem}.meals-container{flex-direction:column;gap:1rem;display:flex}.meal-section{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}.meal-header{background:var(--background);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1rem;display:flex}.meal-header h3{font-size:1rem;font-weight:600}.meal-calories{color:var(--primary);font-weight:600}.meal-entries{flex-direction:column;gap:.5rem;padding:.75rem;display:flex}.diary-entry{background:var(--background);border-radius:var(--radius);align-items:center;gap:1rem;padding:.75rem;display:flex}.diary-entry-missing{opacity:.5}.entry-info{flex:1;min-width:0}.entry-name{text-overflow:ellipsis;white-space:nowrap;font-weight:500;display:block;overflow:hidden}.entry-serving{color:var(--text-secondary);font-size:.75rem}.entry-macros{flex-wrap:wrap;gap:.5rem;display:flex}.macro-item{color:var(--text-secondary);font-size:.75rem}.no-entries{color:var(--text-secondary);text-align:center;padding:1rem;font-size:.875rem}.add-entry-form{background:var(--background);border-radius:var(--radius);flex-direction:column;gap:.75rem;padding:.75rem;display:flex}.add-entry-form select,.add-entry-form input{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:.5rem .75rem;font-size:.875rem}.settings-section{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:1.5rem}.settings-section h2{border-bottom:1px solid var(--border);margin-bottom:1rem;padding-bottom:.75rem;font-size:1.125rem;font-weight:600}.profile-info{flex-direction:column;gap:.5rem;display:flex}.profile-info p{font-size:.875rem}.goals-hint{color:var(--text-secondary);margin-bottom:1rem;font-size:.875rem}.goals-form{flex-direction:column;gap:1rem;display:flex}.section-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;display:flex}.section-header h2{border-bottom:none;margin-bottom:0;padding-bottom:0}.btn-icon{border-radius:var(--radius);width:2rem;height:2rem;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;transition:all .15s;display:flex}.btn-icon:hover{background:var(--background);color:var(--primary)}.goals-details{flex-direction:column;gap:.75rem;display:flex}.detail-row{background:var(--background);border-radius:var(--radius);justify-content:space-between;align-items:center;padding:.75rem;display:flex}.detail-label{color:var(--text-secondary);font-size:.875rem}.detail-value{color:var(--text);font-size:.875rem;font-weight:600}.loading-container{flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:3rem;display:flex}.loading-spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;color:var(--text-secondary);padding:3rem 1.5rem}.empty-state p{margin-bottom:.5rem}.empty-state .btn{margin-top:1rem}.mobile-tab-bar{z-index:100;background:var(--surface);border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom,0);position:fixed;bottom:0;left:0;right:0}@media(min-width:768px){.mobile-tab-bar{display:none}}.mobile-tab-list{justify-content:space-around;align-items:center;margin:0;padding:0;list-style:none;display:flex}.mobile-tab-item{flex:1}.mobile-tab-link{color:var(--text-secondary);flex-direction:column;align-items:center;gap:.25rem;padding:.75rem .5rem;text-decoration:none;transition:color .15s;display:flex}.mobile-tab-link:hover,.mobile-tab-link.active{color:var(--primary)}.mobile-tab-icon{width:1.25rem;height:1.25rem}.mobile-tab-label{font-size:.75rem;font-weight:500}.toast-viewport{z-index:1000;flex-direction:column;gap:.5rem;width:calc(100% - 2rem);max-width:400px;display:flex;position:fixed;top:1rem;right:1rem}@media(min-width:640px){.toast-viewport{top:1.5rem;right:1.5rem}}.toast-root{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-lg);border-left:4px solid;align-items:flex-start;gap:.75rem;padding:.875rem 1rem;animation:.2s ease-out toast-slide-in;display:flex}.toast-root[data-ending-style]{animation:.2s ease-in toast-slide-out}@keyframes toast-slide-in{0%{opacity:0;transform:translateY(-100%)translate(0)}to{opacity:1;transform:translateY(0)translate(0)}}@keyframes toast-slide-out{0%{opacity:1;transform:translateY(0)translate(0)}to{opacity:0;transform:translate(100%)}}.toast-success{border-left-color:var(--success)}.toast-success .toast-icon{color:var(--success)}.toast-error{border-left-color:var(--danger)}.toast-error .toast-icon{color:var(--danger)}.toast-warning{border-left-color:var(--warning)}.toast-warning .toast-icon{color:var(--warning)}.toast-info{border-left-color:var(--primary)}.toast-info .toast-icon{color:var(--primary)}.toast-icon{flex-shrink:0;margin-top:.125rem}.toast-content{flex:1;min-width:0}.toast-title{color:var(--text);margin-bottom:.25rem;font-size:.875rem;font-weight:600}.toast-description{color:var(--text-secondary);font-size:.875rem;line-height:1.4}.toast-close{width:1.5rem;height:1.5rem;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:all .15s;display:flex}.toast-close:hover{background:var(--background);color:var(--text)}@media(max-width:640px){.nav{padding:0 .75rem}.main-content{padding:1rem 1rem 5rem}.form-row,.dashboard-actions{grid-template-columns:1fr}.food-card{flex-direction:column;align-items:flex-start}.food-actions{width:100%}.food-actions .btn{flex:1}}
