.nutrition-container{max-width:1200px;margin:0 auto;padding:1rem;padding-top:120px;padding-bottom:120px}.upload-container{position:relative;width:100%;max-width:500px;margin:0 auto 15px;border-radius:12px;overflow:hidden;background-color:var(--surface-color);box-shadow:0 2px 8px #0000001a;padding:2rem;text-align:center}.upload-instructions{display:flex;flex-direction:column;align-items:center;margin-bottom:2rem}.upload-instructions i{color:var(--accent-color);margin-bottom:1rem}.upload-instructions h3{margin:.5rem 0}.upload-instructions p{margin:.5rem 0;color:var(--text-secondary-color)}.capture-btn{width:60px;height:60px;border-radius:50%;background-color:var(--accent-color);border:4px solid #ffffff;display:flex;justify-content:center;align-items:center;box-shadow:0 2px 6px #0003;cursor:pointer;transition:transform .2s ease}.capture-btn:active{transform:scale(.95)}.camera-alt-options{display:flex;justify-content:center;margin-top:1rem;gap:1rem}.camera-alt-btn{padding:.5rem 1rem;border-radius:8px;background-color:var(--surface-color);color:var(--text-color);border:1px solid var(--border-color);cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:background-color .2s ease}.camera-alt-btn:hover{background-color:var(--surface-hover-color)}.food-analysis{margin-top:1rem;background-color:var(--surface-color);border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a;max-width:500px;margin-left:auto;margin-right:auto}.food-analysis-header{padding:1rem;background-color:var(--surface-alt-color);display:flex;justify-content:space-between;align-items:center}.food-analysis-body{padding:1rem}.food-items-list{list-style:none;padding:0;margin:0}.food-item{padding:1rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:1rem}.food-item:last-child{border-bottom:none}.food-item-icon{width:40px;height:40px;display:flex;justify-content:center;align-items:center;background-color:var(--accent-light-color);border-radius:8px;color:var(--accent-color)}.food-item-details{flex:1}.food-item-name{font-weight:500;margin:0}.food-item-portion{font-size:.85rem;color:var(--text-secondary-color);margin:.25rem 0 0}.food-item-quantity{margin:.8rem 0 1.5rem;display:flex;align-items:center;gap:.75rem}.food-item-quantity label{font-size:.85rem;font-weight:500;color:var(--text-secondary-color);margin:0;flex-shrink:0}.quantity-controls{display:flex;align-items:center;gap:.5rem}.quantity-btn{width:32px;height:32px;border:1px solid var(--border-color);background-color:var(--surface-color);color:var(--text-color);border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;font-size:.75rem}.quantity-btn:hover{background-color:var(--surface-hover-color);border-color:var(--accent-color)}.quantity-btn:active{transform:scale(.95)}.quantity-input{width:60px;height:32px;border:1px solid var(--border-color);border-radius:6px;text-align:center;font-size:.85rem;font-weight:500;background-color:var(--surface-color);color:var(--text-color);transition:border-color .2s ease}.quantity-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px #4caf501a}.food-item-macros{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1.15rem}.macro-pill.editable{position:relative;cursor:pointer;transition:all .2s ease}.macro-pill.editable:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.macro-pill.editing{background-color:#4caf501a;border:2px solid var(--accent-color)}.macro-pill-input{background:none;border:none;color:inherit;font-weight:inherit;font-size:inherit;width:60px;text-align:center;outline:none;font-family:inherit}.macro-pill-input:focus{background-color:#fff3;border-radius:4px}.edit-hint{position:absolute;bottom:-20px;left:50%;transform:translate(-50%);font-size:.7rem;color:var(--text-secondary-color);white-space:nowrap;opacity:0;transition:opacity .2s ease}.macro-pill.editable:hover .edit-hint{opacity:1}[data-theme=dark] .macro-pill.editing{background-color:#4caf5033;border-color:var(--accent-color)}[data-theme=dark] .macro-pill-input:focus{background-color:#0003}[data-theme=dark] .edit-hint{color:#fff9}.macro-pill{padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:500;display:flex;align-items:center;gap:.25rem;position:relative}.macro-pill:before{position:absolute;top:-.65rem;left:50%;transform:translate(-50%);font-size:.55rem;line-height:1;font-weight:600;text-transform:uppercase;color:var(--text-secondary-color);pointer-events:none}.macro-pill--calories:before{content:"Cal"}.macro-pill--protein:before{content:"Protein"}.macro-pill--carbs:before{content:"Carbs"}.macro-pill--fat:before{content:"Fat"}.macro-pill--calories{background-color:#ff98001a;color:#ff9800}.macro-pill--protein{background-color:#4caf501a;color:#4caf50}.macro-pill--carbs{background-color:#0d94881a;color:#0d9488}.macro-pill--fat{background-color:#e91e631a;color:#e91e63}.food-analysis-total{margin-top:1rem;padding:1rem;background-color:var(--surface-alt-color);border-radius:8px}.food-analysis-total h4{margin:0 0 .5rem}.macro-total-bar{height:24px;border-radius:12px;background-color:var(--surface-color);display:flex;overflow:hidden;margin-top:.5rem}.macro-total-bar-segment{height:100%;transition:width .3s ease}.macro-total-bar-segment--protein{background-color:#4caf50}.macro-total-bar-segment--carbs{background-color:#0d9488}.macro-total-bar-segment--fat{background-color:#e91e63}.macro-legend{display:flex;flex-wrap:wrap;gap:1rem;margin-top:.5rem;font-size:.85rem}.macro-legend-item{display:flex;align-items:center;gap:.25rem}.macro-legend-color{width:12px;height:12px;border-radius:3px}.macro-legend-color--protein{background-color:#4caf50}.macro-legend-color--carbs{background-color:#0d9488}.macro-legend-color--fat{background-color:#e91e63}.nutrition-dashboard{margin-top:2rem}.nutrition-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:1rem}@media (min-width: 768px){.nutrition-stats{grid-template-columns:repeat(4,1fr)}}.nutrition-stat-card{background-color:var(--surface-color);border-radius:12px;padding:1rem;display:flex;flex-direction:column;align-items:center;text-align:center;box-shadow:0 2px 8px #0000001a}.nutrition-stat-icon{width:48px;height:48px;display:flex;justify-content:center;align-items:center;border-radius:50%;margin-bottom:.5rem;font-size:1.5rem}.nutrition-stat-icon--calories{background-color:#ff98001a;color:#ff9800}.nutrition-stat-icon--protein{background-color:#4caf501a;color:#4caf50}.nutrition-stat-icon--carbs{background-color:#0d94881a;color:#0d9488}.nutrition-stat-icon--fat{background-color:#e91e631a;color:#e91e63}.nutrition-stat-value{font-size:1.5rem;font-weight:700;margin:.25rem 0}.nutrition-stat-label{font-size:.85rem;color:var(--text-secondary-color);margin:0}.nutrition-chart-container{background-color:var(--surface-color);border-radius:12px;padding:1rem;margin-top:1rem;box-shadow:0 2px 8px #0000001a}.nutrition-chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.nutrition-chart-title{font-size:1.1rem;font-weight:500;margin:0}.nutrition-time-filters{display:flex;gap:.5rem}.nutrition-time-filter{padding:.25rem .75rem;border-radius:16px;background-color:var(--surface-alt-color);border:1px solid var(--border-color);font-size:.85rem;cursor:pointer;transition:all .2s ease}.nutrition-time-filter.active{background-color:var(--primary-color);color:#fff;border-color:var(--primary-color)}.chart-container{width:100%;height:250px}.food-history-day{width:100%;background-color:var(--surface-color);border-radius:16px;overflow:hidden;box-shadow:0 4px 12px #00000014;border:1px solid var(--border-color);transition:transform .2s ease,box-shadow .2s ease}.food-history-day:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000001f}.food-history-day-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;background:linear-gradient(135deg,var(--primary-color),#43A047);color:#fff;margin:0}.food-history-day-date{font-weight:600;font-size:1.1rem;margin:0;color:#fff}.food-history-day-total{font-size:.9rem;font-weight:500;background-color:#fff3;padding:.4rem .8rem;border-radius:20px;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.food-history-entry{width:100%;margin:0;background-color:transparent;border-radius:0;box-shadow:none;border-bottom:1px solid var(--border-color);transition:background-color .2s ease}.food-history-entry:last-child{border-bottom:none}.food-history-entry:hover{background-color:var(--surface-hover-color, rgba(0, 0, 0, .02))}.food-history-entry-header{padding:1rem 1.5rem .5rem;background-color:transparent;display:flex;justify-content:space-between;align-items:center;border-bottom:none}.food-history-entry-time{font-size:.9rem;font-weight:600;margin:0;color:var(--text-color);display:flex;align-items:center;gap:.5rem}.food-history-entry-time:before{content:"🕐";font-size:1rem}.food-history-entry-type{font-size:.8rem;font-weight:600;padding:.4rem .8rem;border-radius:20px;background:linear-gradient(135deg,var(--primary-color),#43A047);color:#fff;text-transform:capitalize;box-shadow:0 2px 6px #4ade804d;border:none}.food-history-entry-body{display:flex;padding:.5rem 1.5rem 1.5rem;gap:1rem;align-items:flex-start}.food-history-entry-image{width:90px;height:90px;object-fit:cover;border-radius:12px;flex-shrink:0;box-shadow:0 4px 12px #00000026;border:2px solid var(--border-color)}.food-history-entry-info{flex:1;padding:0}.food-history-entry-items{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.food-history-entry-item{display:flex;justify-content:space-between;align-items:center;font-size:.95rem;padding:.5rem 0;border-bottom:1px solid rgba(0,0,0,.05)}.food-history-entry-item:last-child{border-bottom:none;margin-bottom:1rem}.food-history-entry-item-name{font-weight:500;color:var(--text-color);flex:1}.food-history-entry-item-calories{font-weight:600;color:var(--primary-color);font-size:.9rem}.food-history-entry-macros{display:flex;justify-content:center;gap:.75rem;margin-top:.5rem;padding-top:1rem;border-top:1px solid var(--border-color);flex-wrap:wrap}.food-history-macro-pill{padding:.3rem .6rem;border-radius:16px;font-size:.75rem;font-weight:600;display:flex;align-items:center;gap:.25rem;border:1px solid}.food-history-macro-pill--calories{background-color:#ff98001a;color:#ff9800;border-color:#ff98004d}.food-history-macro-pill--protein{background-color:#4caf501a;color:#4caf50;border-color:#4caf504d}.food-history-macro-pill--carbs{background-color:#0d94881a;color:#0d9488;border-color:#0d94884d}.food-history-macro-pill--fat{background-color:#e91e631a;color:#e91e63;border-color:#e91e634d}.calorie-balance{margin-top:2rem;background-color:var(--surface-color);border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a;padding:1rem}.calorie-balance-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.calorie-balance-header h3{margin:0;color:var(--text-color)}.calorie-comparison{display:flex;flex-direction:row;gap:.5rem}.calorie-box{flex:1;padding:1rem;border-radius:8px;text-align:center}.calorie-box--in{background-color:#0d94881a;color:#0d9488}.calorie-box--out{background-color:#e91e631a;color:#e91e63}.calorie-box--net{background-color:#4caf501a;color:#4caf50}.calorie-box-value{font-size:1.75rem;font-weight:700;margin:.5rem 0}.calorie-box-label{font-size:.85rem;font-weight:500}.calorie-progress{margin-top:1.5rem}.calorie-progress-bar{height:8px;background-color:var(--surface-alt-color);border-radius:4px;overflow:hidden;margin-top:.5rem}.calorie-progress-fill{height:100%;background-color:var(--accent-color);width:0%;transition:width .3s ease}.calorie-progress-stats{display:flex;justify-content:space-between;font-size:.85rem;margin-top:.5rem}.loading-spinner{display:flex;justify-content:center;align-items:center;padding:1.5rem}.spinner{width:40px;height:40px;border:4px solid rgba(var(--accent-color-rgb),.2);border-radius:50%;border-top-color:var(--accent-color);animation:spin 1s infinite linear}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.fade-in{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}:root{--accent-color-rgb: 103, 58, 183;--accent-light-color: rgba(103, 58, 183, .1)}.dark-theme .macro-pill--calories{background-color:#ff980033}.dark-theme .macro-pill--protein{background-color:#4caf5033}.dark-theme .macro-pill--carbs{background-color:#5eead433}.dark-theme .macro-pill--fat{background-color:#e91e6333}.dark-theme .calorie-box--in{background-color:#5eead433}.dark-theme .calorie-box--out{background-color:#e91e6333}.dark-theme .calorie-box--net{background-color:#4caf5033}.nutrition-tabs{display:flex;background-color:var(--surface-color);border-radius:8px;overflow-x:auto;margin-bottom:1.5rem;box-shadow:0 2px 4px #0000001a;-webkit-overflow-scrolling:touch;scrollbar-width:none;position:relative}.nutrition-tabs::-webkit-scrollbar{display:none}.nutrition-tab{flex:1;padding:1rem .5rem;text-align:center;border-bottom:3px solid transparent;transition:all .2s ease;cursor:pointer;white-space:nowrap;min-width:70px}.nutrition-tab.active{border-bottom-color:var(--accent-color);background-color:var(--surface-alt-color);color:var(--accent-color)}.nutrition-tab i{margin-right:.25rem;font-size:1rem}.nutrition-tab-content{display:none}.nutrition-tab-content.active{display:block}.api-key-section{background-color:#f8f9fa;border-radius:8px;padding:15px;border:1px solid #e9ecef;transition:all .3s ease;max-width:500px;margin:15px auto}.api-key-section.key-saved{background-color:#e8f5e9;border-color:#a5d6a7}.api-key-section p{margin-bottom:15px;font-weight:500}.api-key-section small{display:block;margin-top:10px;color:#6c757d;font-size:.8rem}.api-key-input-container{display:flex;gap:10px}.api-key-input-container input{flex:1;padding:8px 12px;border:1px solid #ced4da;border-radius:4px;font-family:monospace}.btn-small{padding:.25rem .5rem;font-size:.8rem}.btn-large{padding:1rem 1.5rem;font-size:1.1rem}.camera-controls{display:flex;justify-content:center;gap:15px;margin:0 0 20px;flex-wrap:wrap}.manual-entry-container{background-color:var(--surface-color);border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a;max-width:500px;margin:1rem auto;border:1px solid var(--border-color)}.manual-entry-header{padding:1rem;background-color:var(--surface-alt-color);display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-color)}.manual-entry-header h3{margin:0;color:var(--accent-color)}.manual-entry-body{padding:1.5rem}.manual-entry-input{margin-bottom:1.5rem}.manual-entry-input label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-color)}.custom-input{width:100%;padding:.8rem 1rem;font-size:1rem;border:2px solid rgba(76,175,80,.3);border-radius:8px;background-color:var(--surface-color);color:var(--text-color);transition:all .2s ease;font-family:inherit}.custom-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px #4caf5033}.custom-input::placeholder{color:var(--text-secondary-color)}.manual-entry-input small{display:block;margin-top:.5rem;color:var(--text-secondary-color);font-size:.85rem;font-style:italic}.manual-entry-actions{display:flex;justify-content:center}[data-theme=dark] .manual-entry-container{background-color:#2d2d2d;border-color:#444;box-shadow:0 4px 12px #0000004d}[data-theme=dark] .manual-entry-header{background-color:#1e1e1e;border-bottom-color:#444}[data-theme=dark] .manual-entry-header h3{color:#fffffff2}[data-theme=dark] .manual-entry-input label{color:#ffffffe6}[data-theme=dark] .custom-input{background-color:#2d2d2d;color:#ffffffe6;border-color:#4caf5066}[data-theme=dark] .custom-input::placeholder{color:#ffffff80}[data-theme=dark] .manual-entry-input small{color:#ffffffb3}.btn{padding:8px 12px;border-radius:4px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;font-weight:500;transition:all .2s ease;border:none;white-space:nowrap}.btn-primary{background-color:#4caf50;color:#fff;box-shadow:0 2px 4px #0000001a}.btn-primary:hover{background-color:#43a047;box-shadow:0 2px 6px #0003}.btn-secondary{background-color:#f5f5f5;color:#333;border:1px solid #e0e0e0;box-shadow:0 1px 3px #0000001a}.btn-secondary:hover{background-color:#e0e0e0;box-shadow:0 1px 4px #00000026}.analysis-error{text-align:center;padding:20px;background-color:#fff5f5;border-radius:8px;border:1px solid #ffcccc;margin:15px auto;max-width:500px}.analysis-error i{font-size:2rem;color:#ff6b6b;margin-bottom:15px}.analysis-error p{margin-bottom:5px;font-weight:500}.analysis-error .error-details{font-family:monospace;padding:10px;background-color:#f8f9fa;border-radius:4px;margin-top:10px;font-size:.9rem;color:#dc3545;word-break:break-word}.analysis-error small{display:block;margin-top:15px;color:#6c757d;font-style:italic}@media (max-width: 600px){.nutrition-container{padding:1rem .75rem;padding-top:100px;padding-bottom:100px}.camera-controls{gap:8px;flex-direction:column;align-items:stretch}.btn{padding:.6rem .8rem;font-size:.9rem}.btn-large{padding:1rem 1.5rem;font-size:1rem}.manual-entry-container{max-width:100%;margin:1rem 0}.manual-entry-header{padding:.75rem}.manual-entry-body{padding:1rem}.custom-input{font-size:.9rem;padding:.7rem .8rem}.manual-entry-input small{font-size:.8rem}.food-analysis-header,.food-analysis-body{padding:.75rem}.nutrition-tab{padding:.75rem .5rem;font-size:.9rem}.nutrition-tab i{margin-right:.2rem;font-size:.9rem}.food-history-day-header{padding:1rem;flex-direction:column;gap:.5rem;text-align:center}.food-history-day-date{font-size:1rem}.food-history-day-total{font-size:.85rem}.food-history-entry-header{padding:.75rem 1rem .25rem;flex-direction:column;gap:.5rem;align-items:flex-start}.food-history-entry-time{font-size:.85rem}.food-history-entry-body{flex-direction:column;padding:.5rem 1rem 1rem;gap:.75rem;align-items:flex-start}.food-history-entry-image{width:100%;height:120px;align-self:center;max-width:200px;border-radius:12px}.food-history-entry-info{width:100%;padding:0}.food-history-entry-item{font-size:.9rem;padding:.4rem 0}.food-history-entry-macros{gap:.5rem;margin-top:.75rem;padding-top:.75rem}.food-history-macro-pill{font-size:.7rem;padding:.25rem .5rem}.food-item-macros{flex-wrap:wrap;gap:.5rem}.food-item-quantity{margin:.5rem 0}.quantity-controls{gap:.25rem}.quantity-btn{width:28px;height:28px;font-size:.7rem}.quantity-input{width:50px;height:28px;font-size:.8rem}.food-analysis{max-width:100%}}@media (max-width: 400px){.camera-controls{flex-direction:column;align-items:stretch;gap:.5rem}.btn-primary,.btn-secondary{width:100%;justify-content:center}.nutrition-tab span{display:none}.nutrition-tab i{margin-right:0;font-size:1.1rem}.nutrition-tab{min-width:50px;padding:.75rem .4rem}}#debug-btn{display:none}@media (min-width: 768px){body.is-dev #debug-btn{display:block}}[data-theme=dark] .nutrition-tab{color:#ffffffb3}[data-theme=dark] .nutrition-tab.active{color:var(--primary-color)}[data-theme=dark] .nutrition-stat-label,[data-theme=dark] .food-history-day-date,[data-theme=dark] .food-history-entry-time,[data-theme=dark] .food-history-entry-item,[data-theme=dark] .food-history-day-total,[data-theme=dark] .calorie-box-label,[data-theme=dark] .calorie-progress-stats,[data-theme=dark] .nutrition-chart-title,[data-theme=dark] .macro-legend,[data-theme=dark] label{color:#ffffffe6!important}[data-theme=dark] .nutrition-stat-value,[data-theme=dark] .calorie-box-value,[data-theme=dark] .food-history-entry-item span,[data-theme=dark] h2,[data-theme=dark] h3,[data-theme=dark] h4{color:var(--primary-color)}[data-theme=dark] .food-history-entry-type{background-color:var(--primary-color);color:#121212;font-weight:600;box-shadow:0 0 4px #4ade8066;border:none}[data-theme=dark] select.form-control option{background-color:#2d2d2d;color:#ffffffe6}.camera-controls{position:relative;bottom:auto;left:auto;right:auto;background:none;padding:1rem 0}#camera-tab{padding-bottom:60px}.btn-primary,.btn-secondary{min-width:120px;text-align:center;justify-content:center}@media (max-width: 400px){.camera-controls{flex-direction:column;align-items:center;gap:10px}.btn-primary,.btn-secondary{width:200px}}[data-theme=dark] .nutrition-time-filter{background-color:#2d2d2d;color:#fffc;border-color:#444}[data-theme=dark] .nutrition-time-filter.active{background-color:var(--primary-color);color:#121212;border-color:var(--primary-color);font-weight:600;box-shadow:0 0 4px #4ade8066}[data-theme=dark] .chart-js-render canvas{filter:brightness(.9)}[data-theme=dark] .chart-container{border:1px solid #333;border-radius:8px;background-color:#1e1e1e}.meal-details-section{margin-top:1.5rem;background-color:var(--surface-alt-color);border-radius:8px;padding:1rem}.meal-details-section h4{margin:0 0 1rem;font-size:1.1rem;color:var(--accent-color)}.meal-type-container,.meal-notes-container{margin-bottom:1rem}.meal-type-container label,.meal-notes-container label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-color)}.custom-select-wrapper{position:relative;display:block}.custom-select{width:100%;padding:.8rem 1rem;font-size:1rem;border:2px solid rgba(76,175,80,.3);border-radius:8px;background-color:var(--surface-color);-moz-appearance:none;appearance:none;-webkit-appearance:none;cursor:pointer;color:var(--text-color);transition:all .2s ease}.custom-select:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px #4caf5033}.select-icon{position:absolute;right:12px;top:50%;transform:translateY(-50%);pointer-events:none;color:var(--accent-color)}.custom-textarea{width:100%;padding:.8rem 1rem;font-size:1rem;min-height:100px;border:2px solid rgba(76,175,80,.3);border-radius:8px;background-color:var(--surface-color);resize:vertical;color:var(--text-color);transition:all .2s ease;font-family:inherit}.custom-textarea:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px #4caf5033}[data-theme=dark] .custom-select,[data-theme=dark] .custom-textarea{background-color:#2d2d2d;color:#ffffffe6;border-color:#4caf5066}[data-theme=dark] .custom-select option{background-color:#2d2d2d;color:#ffffffe6}.entry-preview{display:flex;flex-direction:column;gap:1rem}.entry-preview-image{width:100%;max-height:250px;object-fit:cover;border-radius:8px;margin-bottom:.5rem}.entry-preview-header{display:flex;justify-content:space-between;align-items:center}.entry-preview-header h4{margin:0;color:var(--accent-color)}.entry-preview-totals{background-color:var(--surface-alt-color);border-radius:8px;padding:1rem 1rem 1.25rem}.entry-preview-totals h5{margin:0 0 .75rem;font-size:1rem;color:var(--accent-color)}.entry-preview-foods{margin-top:2rem}.entry-preview-foods h5{margin:0 0 .75rem;font-size:1rem;color:var(--accent-color)}.entry-preview-foods .food-item+.food-item{margin-top:1.5rem}.modal-actions{display:flex;justify-content:space-between;margin-top:2rem;padding:0;width:100%}@media (max-width: 400px){.modal-actions{flex-direction:column;gap:1rem}.modal-actions .btn{width:100%}}#previewModal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:1000;align-items:center!important;justify-content:center!important}#previewModal.active,#previewModal[style*="display: flex"]{display:flex!important;align-items:center!important;justify-content:center!important}@media (max-width: 600px){#previewModal .modal-content{width:95%;max-height:85vh}#previewModal .modal-body{padding:1.5rem 1.5rem 2rem;overflow-y:auto;max-height:calc(80vh - 60px)}.modal-actions{padding:1rem .5rem .5rem;flex-direction:row;justify-content:space-between;gap:12px}}.modal-actions .btn{padding:1rem;width:48%;font-size:1rem;border-radius:8px;font-weight:600;text-align:center;display:flex;justify-content:center;align-items:center;box-shadow:0 2px 4px #0000001a;transition:all .2s ease;border:none;cursor:pointer}.modal-actions .btn-primary{background-color:#4caf50;color:#fff}.modal-actions .btn-primary:hover{background-color:#43a047;box-shadow:0 3px 6px #0003}.modal-actions .btn-danger{background-color:#e53935;color:#fff}.modal-actions .btn-danger:hover{background-color:#d32f2f;box-shadow:0 3px 6px #0003}@media (max-width: 400px){.modal-actions{flex-direction:column;gap:16px}.modal-actions .btn{width:100%}}[data-theme=dark] .entry-preview-totals,[data-theme=dark] .meal-details-section{background-color:#2d2d2d}[data-theme=dark] select.form-control{background-color:#2d2d2d;color:#ffffffe6;border-color:#444}[data-theme=dark] .modal-actions .btn-primary{background-color:#4caf50;color:#fff}[data-theme=dark] .modal-actions .btn-danger{background-color:#e53935;color:#fff}[data-theme=dark] .upload-container{background-color:#2d2d2d;border:1px solid #444;box-shadow:0 4px 12px #0000004d}[data-theme=dark] .upload-instructions h3{color:#fffffff2}[data-theme=dark] .upload-instructions p{color:#fffc}[data-theme=dark] .api-key-section{background-color:#2d2d2d;border:1px solid #444;box-shadow:0 2px 8px #0003}[data-theme=dark] .api-key-section h4{color:var(--primary-color)!important}[data-theme=dark] .api-key-section p{color:#ffffffd9!important}[data-theme=dark] .api-key-section small{color:#ffffffb3!important}[data-theme=dark] .api-key-input-container input{background-color:#1e1e1e;border:2px solid #444;color:#ffffffe6}[data-theme=dark] .api-key-input-container input:focus{border-color:var(--primary-color);box-shadow:0 0 0 2px #4ade8033}[data-theme=dark] .api-key-input-container input::placeholder{color:#ffffff80}[data-theme=dark] .food-analysis{background-color:#2d2d2d;border:1px solid #444;box-shadow:0 4px 12px #0000004d}[data-theme=dark] .food-analysis-header{background-color:#1e1e1e;border-bottom:1px solid #444}[data-theme=dark] .food-analysis-header h3{color:#fffffff2}[data-theme=dark] .food-item{border-bottom:1px solid #444}[data-theme=dark] .food-item-name{color:#fffffff2}[data-theme=dark] .food-item-portion,[data-theme=dark] .food-item-quantity label{color:#ffffffb3}[data-theme=dark] .quantity-btn{border-color:#444;background-color:#2d2d2d;color:#ffffffe6}[data-theme=dark] .quantity-btn:hover{background-color:#3d3d3d;border-color:var(--accent-color)}[data-theme=dark] .quantity-input{border-color:#444;background-color:#2d2d2d;color:#ffffffe6}[data-theme=dark] .quantity-input:focus{border-color:var(--accent-color);box-shadow:0 0 0 2px #4caf5033}[data-theme=dark] .food-item-icon{background-color:#4ade8026;border:1px solid rgba(74,222,128,.3)}[data-theme=dark] .macro-pill--calories{background-color:#ff980033;color:#ffb74d;border:1px solid rgba(255,152,0,.3)}[data-theme=dark] .macro-pill--protein{background-color:#4caf5033;color:#81c784;border:1px solid rgba(76,175,80,.3)}[data-theme=dark] .macro-pill--carbs{background-color:#5eead433;color:#5eead4;border:1px solid rgba(94,234,212,.3)}[data-theme=dark] .macro-pill--fat{background-color:#e91e6333;color:#f48fb1;border:1px solid rgba(233,30,99,.3)}[data-theme=dark] .food-analysis-total{background-color:#1e1e1e;border:1px solid #444;border-radius:8px;padding:1rem;margin-top:1rem}[data-theme=dark] .food-analysis-total h4{color:#fffffff2}[data-theme=dark] .macro-legend-item span{color:#ffffffe6}[data-theme=dark] .loading-spinner{color:#fffc}[data-theme=dark] .spinner{border-color:#ffffff1a;border-top-color:var(--primary-color)}[data-theme=dark] .analysis-error{background-color:#f443361a;border:1px solid rgba(244,67,54,.3);color:#ffffffe6}[data-theme=dark] .analysis-error i{color:#ef5350}[data-theme=dark] .analysis-error p{color:#ffffffe6}[data-theme=dark] .analysis-error .error-details{background-color:#0003;border:1px solid rgba(255,255,255,.1);color:#fffc}[data-theme=dark] .analysis-error small{color:#ffffffb3}[data-theme=dark] .nutrition-stat-card{background-color:#2d2d2d;border:1px solid #444;box-shadow:0 2px 8px #0003}[data-theme=dark] .nutrition-stat-icon{background-color:#4ade8026;border:1px solid rgba(74,222,128,.3)}[data-theme=dark] .nutrition-chart-container{background-color:#2d2d2d;border:1px solid #444;box-shadow:0 2px 8px #0003}[data-theme=dark] .chart-container{border:1px solid #444;border-radius:8px;background-color:#1e1e1e}[data-theme=dark] .food-history{background-color:transparent}[data-theme=dark] .food-history h3{color:#fffffff2}[data-theme=dark] .food-history-day{background-color:#2d2d2d;border:1px solid #444;box-shadow:0 4px 12px #0000004d}[data-theme=dark] .food-history-day:hover{box-shadow:0 6px 20px #0006}[data-theme=dark] .food-history-day-header{background:linear-gradient(135deg,var(--primary-color),#43A047);color:#fff}[data-theme=dark] .food-history-day-date{color:#fff}[data-theme=dark] .food-history-day-total{background-color:#fff3;color:#fff}[data-theme=dark] .food-history-entry{background-color:transparent;border-bottom:1px solid #444}[data-theme=dark] .food-history-entry:hover{background-color:#ffffff0d}[data-theme=dark] .food-history-entry-header{background-color:transparent}[data-theme=dark] .food-history-entry-time{color:#ffffffe6}[data-theme=dark] .food-history-entry-type{background:linear-gradient(135deg,var(--primary-color),#43A047);color:#fff;box-shadow:0 2px 6px #4ade8066}[data-theme=dark] .food-history-entry-image{border:2px solid #444;box-shadow:0 4px 12px #0000004d}[data-theme=dark] .food-history-entry-item{border-bottom:1px solid rgba(255,255,255,.1)}[data-theme=dark] .food-history-entry-item-name{color:#ffffffe6}[data-theme=dark] .food-history-entry-item-calories{color:var(--primary-color)}[data-theme=dark] .food-history-entry-macros{border-top:1px solid #444}[data-theme=dark] .food-history-macro-pill--calories{background-color:#ff980033;color:#ffb74d;border-color:#ff980066}[data-theme=dark] .food-history-macro-pill--protein{background-color:#4caf5033;color:#81c784;border-color:#4caf5066}[data-theme=dark] .food-history-macro-pill--carbs{background-color:#5eead433;color:#5eead4;border-color:#5eead466}[data-theme=dark] .food-history-macro-pill--fat{background-color:#e91e6333;color:#f48fb1;border-color:#e91e6366}[data-theme=dark] .calorie-balance{background-color:#2d2d2d;border-radius:12px;padding:1rem}[data-theme=dark] .calorie-balance-header h3{color:#fffffff2}[data-theme=dark] .calorie-box{background-color:#1e1e1e;border:1px solid #444;box-shadow:0 2px 8px #0003}[data-theme=dark] .calorie-progress{background-color:#1e1e1e;border:1px solid #444;border-radius:8px;padding:1rem}[data-theme=dark] .calorie-progress-bar{background-color:#ffffff1a;border:1px solid #444}[data-theme=dark] .calorie-progress-stats{color:#ffffffe6}[data-theme=dark] .meal-details-section{background-color:#2d2d2d;border:1px solid #444}[data-theme=dark] .meal-details-section h4{color:#fffffff2}[data-theme=dark] .meal-type-container label,[data-theme=dark] .meal-notes-container label{color:#ffffffe6}[data-theme=dark] .modal-content{background-color:#2d2d2d;border:1px solid #444;box-shadow:0 8px 32px #0006}[data-theme=dark] .modal-header{background-color:#1e1e1e;border-bottom:1px solid #444}[data-theme=dark] .modal-header h3{color:#fffffff2}[data-theme=dark] .close-modal{color:#fffc;background-color:transparent;border:1px solid #444}[data-theme=dark] .close-modal:hover{color:#fff;background-color:#ffffff1a}[data-theme=dark] .btn{border:1px solid rgba(74,222,128,.3)}[data-theme=dark] .btn-primary{background-color:var(--primary-color);color:#121212;font-weight:600;box-shadow:0 2px 8px #4ade804d}[data-theme=dark] .btn-primary:hover{background-color:#43a047;box-shadow:0 4px 12px #4ade8066}[data-theme=dark] .btn-secondary{background-color:#2d2d2d;color:#ffffffe6;border:1px solid #444}[data-theme=dark] .btn-secondary:hover{background-color:#3d3d3d;color:#fff}[data-theme=dark] .time-range-button{background-color:transparent;border:none;box-shadow:none}[data-theme=dark] .time-range-toggle{background-color:#1e1e1ee6;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#ffffffe6;border:1px solid rgba(74,222,128,.3);box-shadow:0 2px 8px #0003}[data-theme=dark] .time-range-toggle:hover{background-color:#1e1e1ef2;border-color:#4ade8080;box-shadow:0 4px 12px #0000004d}[data-theme=dark] .time-range-dropdown{background-color:#1e1e1ef2;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(74,222,128,.3);box-shadow:0 4px 12px #0006}[data-theme=dark] .time-range-option{color:#ffffffe6}[data-theme=dark] .time-range-option:hover{background-color:#4ade801a;color:var(--primary-color)}[data-theme=dark] .time-range-option.selected{background-color:#4ade8033;color:var(--primary-color)}[data-theme=dark] .no-data-state,[data-theme=dark] .loading-state{color:#fffc}[data-theme=dark] .no-data-state i,[data-theme=dark] .loading-state i{color:#fff9}[data-theme=dark] .nutrition-container p,[data-theme=dark] .nutrition-container span:not(.macro-pill span):not(.material-symbols-outlined){color:#ffffffd9}[data-theme=dark] .nutrition-tab:focus,[data-theme=dark] .nutrition-tab:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.food-history{margin-top:2rem;width:100%;max-width:100%;overflow-x:hidden}.food-history-list{width:100%;padding:0;display:flex;flex-direction:column;gap:1.5rem}.load-more-container{display:flex;justify-content:center;margin-top:2rem;margin-bottom:1rem}.load-more-btn{padding:.75rem 2rem;border-radius:24px;background-color:var(--surface-alt-color);border:1px solid var(--border-color);color:var(--text-color);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.load-more-btn:hover{background-color:var(--surface-hover-color);transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.load-more-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.load-more-btn:disabled:hover{background-color:var(--surface-alt-color);transform:none;box-shadow:none}.load-more-btn i{transition:transform .2s ease}.load-more-btn:hover i{transform:translateY(2px)}[data-theme=dark] .load-more-btn{background-color:var(--surface-color);border-color:var(--border-color);color:var(--text-color)}[data-theme=dark] .load-more-btn:hover{background-color:var(--surface-hover-color);border-color:var(--primary-color)}.food-analysis-total .food-item-macros{margin-top:1.25rem!important}.notification{position:fixed!important;top:20px!important;right:20px!important;background:var(--surface-color)!important;border:1px solid var(--border-color)!important;border-radius:8px!important;padding:1rem!important;box-shadow:0 4px 12px var(--shadow-color)!important;z-index:10000!important;transform:translate(100%)!important;opacity:0!important;transition:all .3s ease!important;max-width:400px!important;color:var(--text-color)!important}.notification.show{transform:translate(0)!important;opacity:1!important}.notification--success{border-left:4px solid var(--success-color)!important}.notification--error{border-left:4px solid var(--error-color)!important}.notification--info{border-left:4px solid var(--info-color)!important}.notification-content{display:flex!important;align-items:center!important;gap:.75rem!important;color:inherit!important}.notification-content i{font-size:1.25rem!important}.notification--success .notification-content i{color:var(--success-color)!important}.notification--error .notification-content i{color:var(--error-color)!important}.notification--info .notification-content i{color:var(--info-color)!important}[data-theme=dark] .notification{background:#2a2a2a!important;border-color:#4a4a4a!important;color:var(--text-color)!important;box-shadow:0 4px 12px #00000080!important}[data-theme=dark] .notification-content,[data-theme=dark] .notification-content span{color:#e0e0e0!important}
