@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";.date-navbar{padding:var(--space-3) 0;margin-bottom:var(--space-4)}.date-navbar-scroll{display:flex;gap:var(--space-2);overflow-x:auto;padding:0 var(--space-4);scrollbar-width:none;-ms-overflow-style:none}.date-navbar-scroll::-webkit-scrollbar{display:none}.date-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);min-width:56px;background:var(--bg-glass);border:1px solid var(--border-glass);transition:all var(--transition-base);position:relative}.date-item:hover{background:var(--bg-glass-hover);border-color:var(--border-glass-hover);transform:translateY(-2px)}.date-item.active{background:var(--accent-gradient);border-color:transparent;box-shadow:var(--shadow-glow)}.date-item.active .date-day-name,.date-item.active .date-month{color:#ffffffd9}.date-item.active .date-day-num{color:#fff}.date-item.today:not(.active){border-color:var(--accent-primary)}.date-day-name{font-size:var(--font-xs);font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.date-day-num{font-size:var(--font-lg);font-weight:700;color:var(--text-primary);line-height:1}.date-month{font-size:var(--font-xs);color:var(--text-tertiary);font-weight:500}.date-dot{width:5px;height:5px;border-radius:50%;margin-top:2px}.date-dot.under{background:var(--color-success);box-shadow:0 0 4px #22c55e80}.date-dot.over{background:var(--color-danger);box-shadow:0 0 4px #ef444480}.quick-buttons-section{padding:0 var(--space-4);margin-bottom:var(--space-6)}.section-header{display:flex;align-items:baseline;gap:var(--space-3);margin-bottom:var(--space-4)}.section-title{font-size:var(--font-lg);font-weight:700;color:var(--text-primary)}.section-subtitle{font-size:var(--font-sm);color:var(--text-tertiary)}.quick-buttons-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3)}.quick-button{display:flex;flex-direction:column;align-items:center;padding:var(--space-4) var(--space-2);gap:var(--space-1);position:relative;animation:fadeIn .3s ease forwards;opacity:0}.quick-button.has-quantity{border-color:var(--accent-primary);background:#6366f10f}.quick-btn-edit{position:absolute;top:6px;right:6px;font-size:12px;width:24px;height:24px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-fast)}.quick-button:hover .quick-btn-edit{opacity:.6}.quick-btn-edit:hover{opacity:1!important;background:var(--bg-glass-hover)}.quick-btn-emoji{font-size:1.8rem;line-height:1}.quick-btn-name{font-size:var(--font-sm);font-weight:600;color:var(--text-primary);text-align:center;line-height:1.2}.quick-btn-info{font-size:var(--font-xs);color:var(--text-tertiary)}.quick-btn-controls{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-2)}.qty-btn{width:30px;height:30px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:var(--font-md);font-weight:700;transition:all var(--transition-fast)}.qty-btn.minus{background:var(--bg-glass-hover);color:var(--text-secondary)}.qty-btn.minus:hover:not(:disabled){background:var(--color-danger-bg);color:var(--color-danger)}.qty-btn.minus:disabled{opacity:.3;cursor:not-allowed}.qty-btn.plus{background:#6366f126;color:var(--accent-secondary)}.qty-btn.plus:hover{background:#6366f140;color:var(--accent-primary);transform:scale(1.1)}.qty-display{font-size:var(--font-md);font-weight:700;min-width:24px;text-align:center;color:var(--text-primary)}.quick-btn-total{font-size:var(--font-xs);color:var(--accent-secondary);font-weight:600;margin-top:var(--space-1)}.add-button{justify-content:center;gap:var(--space-2);border-style:dashed;opacity:.6;cursor:pointer;min-height:140px}.add-button:hover{opacity:1;border-color:var(--accent-primary)}.add-btn-icon{font-size:var(--font-2xl);color:var(--accent-secondary);line-height:1}.add-btn-text{font-size:var(--font-sm);color:var(--text-secondary);font-weight:500}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;padding:var(--space-4);animation:fadeIn .2s ease}.modal{width:100%;max-width:380px;padding:var(--space-6);background:var(--bg-secondary)!important;border:1px solid var(--border-glass-hover)!important;animation:fadeInScale .25s ease}.modal-title{font-size:var(--font-lg);font-weight:700;margin-bottom:var(--space-5);color:var(--text-primary)}.modal-field{margin-bottom:var(--space-4)}.modal-field label{display:block;font-size:var(--font-sm);color:var(--text-secondary);margin-bottom:var(--space-1);font-weight:500}.modal-input{width:100%;padding:var(--space-3) var(--space-4);background:var(--bg-glass);border:1px solid var(--border-glass);border-radius:var(--radius-md);font-size:var(--font-base);color:var(--text-primary);transition:border-color var(--transition-fast)}.modal-input:focus{border-color:var(--accent-primary)}.modal-input.emoji-input{width:60px;text-align:center;font-size:var(--font-xl)}.modal-actions{display:flex;gap:var(--space-3);margin-top:var(--space-6);justify-content:flex-end}.modal-btn{padding:var(--space-2) var(--space-5);border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:600;transition:all var(--transition-fast)}.modal-btn.cancel{color:var(--text-secondary)}.modal-btn.cancel:hover{background:var(--bg-glass-hover)}.modal-btn.confirm{background:var(--accent-gradient);color:#fff}.modal-btn.confirm:hover{box-shadow:var(--shadow-glow);transform:translateY(-1px)}.modal-btn.danger{color:var(--color-danger)}.modal-btn.danger:hover{background:var(--color-danger-bg)}.modal-macro-section{margin-bottom:var(--space-4)}.modal-macro-title{display:block;font-size:var(--font-sm);color:var(--text-secondary);margin-bottom:var(--space-2);font-weight:500}.modal-macro-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2)}.modal-macro-field label{display:block;font-size:var(--font-xs);margin-bottom:2px;font-weight:600}.modal-macro-field .modal-input{padding:var(--space-2) var(--space-3);font-size:var(--font-sm)}.food-input-section{padding:0 var(--space-4);margin-bottom:var(--space-6)}.food-input-container{padding:var(--space-4)}.food-textarea{width:100%;resize:none;background:transparent;font-size:var(--font-base);color:var(--text-primary);line-height:1.5;padding:var(--space-2) 0;border-bottom:1px solid var(--border-glass);margin-bottom:var(--space-3)}.food-textarea::placeholder{color:var(--text-tertiary)}.food-textarea:focus{border-bottom-color:var(--accent-primary)}.food-input-actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);flex-wrap:wrap}.image-file-input{display:none}.upload-image-btn{background:var(--bg-glass);color:var(--text-secondary);padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);font-size:var(--font-sm);font-weight:500;border:1px solid var(--border-glass);transition:all var(--transition-fast);cursor:pointer;white-space:nowrap}.upload-image-btn:hover:not(:disabled){background:#6366f11a;border-color:var(--accent-primary);color:var(--accent-primary);transform:translateY(-1px)}.upload-image-btn:disabled{opacity:.5;cursor:not-allowed}.image-preview-container{position:relative;display:inline-block;margin-bottom:var(--space-3);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-glass);max-width:100%}.image-preview{display:block;max-width:100%;max-height:200px;object-fit:cover;border-radius:var(--radius-md)}.image-remove-btn{position:absolute;top:6px;right:6px;width:28px;height:28px;border-radius:50%;background:#000000a6;color:#fff;font-size:14px;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;transition:all var(--transition-fast);line-height:1;padding:0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.image-remove-btn:hover{background:var(--color-danger);transform:scale(1.1)}.api-key-hint{font-size:var(--font-sm);color:var(--color-warning);background:var(--color-warning-bg);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);transition:all var(--transition-fast)}.api-key-hint:hover{transform:translateY(-1px)}.submit-btn{background:var(--accent-gradient);color:#fff;padding:var(--space-2) var(--space-5);border-radius:var(--radius-full);font-size:var(--font-sm);font-weight:600;transition:all var(--transition-base)}.submit-btn:hover:not(:disabled){box-shadow:var(--shadow-glow);transform:translateY(-2px)}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.loading-dots{display:flex;gap:4px}.loading-dots span{animation:pulse 1s ease-in-out infinite;font-size:10px}.loading-dots span:nth-child(2){animation-delay:.15s}.loading-dots span:nth-child(3){animation-delay:.3s}.food-error{margin-top:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-danger-bg);border-radius:var(--radius-md);color:var(--color-danger);font-size:var(--font-sm);display:flex;align-items:center;gap:var(--space-2)}.food-result{margin-top:var(--space-4);padding:var(--space-5);border-color:var(--accent-primary)!important;background:#6366f10a!important}.result-header{text-align:center;margin-bottom:var(--space-4)}.result-total{display:flex;align-items:baseline;gap:var(--space-2);justify-content:center}.result-cal-num{font-size:var(--font-3xl);font-weight:800;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}.result-cal-unit{font-size:var(--font-md);color:var(--text-secondary);font-weight:600}.result-label{font-size:var(--font-sm);color:var(--text-tertiary);margin-top:var(--space-1)}.result-items{border-top:1px solid var(--border-glass);padding-top:var(--space-3);margin-bottom:var(--space-3);overflow-x:auto}.result-items-header{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) 0;border-bottom:1px solid var(--border-glass);font-size:var(--font-xs);color:var(--text-tertiary);text-transform:uppercase;font-weight:600;letter-spacing:.5px}.result-items-header .ri-name{flex:1;min-width:0}.result-items-header .ri-cal,.result-items-header .ri-macro{width:40px;text-align:right;flex-shrink:0}.result-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) 0;font-size:var(--font-sm)}.result-item-name{flex:1;min-width:0;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.result-item-cal{width:40px;text-align:right;color:var(--text-primary);font-weight:600;flex-shrink:0}.result-item-macro{width:40px;text-align:right;color:var(--text-secondary);font-size:var(--font-xs);flex-shrink:0}.result-macros-summary{display:flex;gap:var(--space-2);justify-content:center;margin-bottom:var(--space-4);flex-wrap:wrap}.macro-pill{display:flex;flex-direction:column;align-items:center;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);min-width:60px}.macro-pill.protein{background:#ef44441a;border:1px solid rgba(239,68,68,.2)}.macro-pill.carbs{background:#f59e0b1a;border:1px solid rgba(245,158,11,.2)}.macro-pill.fats{background:#6366f11a;border:1px solid rgba(99,102,241,.2)}.macro-pill.fiber{background:#22c55e1a;border:1px solid rgba(34,197,94,.2)}.macro-pill-value{font-size:var(--font-md);font-weight:700;color:var(--text-primary);line-height:1.2}.macro-pill-label{font-size:var(--font-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.3px}.result-explanation{font-size:var(--font-sm);color:var(--text-tertiary);font-style:italic;padding:var(--space-3);background:var(--bg-glass);border-radius:var(--radius-sm);margin-bottom:var(--space-4);line-height:1.5}.result-actions{display:flex;gap:var(--space-3);justify-content:flex-end}.exercise-result{border:1px solid rgba(34,197,94,.3);background:linear-gradient(135deg,#22c55e0f,#10b9810a)}.exercise-cal{background:linear-gradient(135deg,#22c55e,#10b981);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.macro-table-section{padding:0 var(--space-4);margin-bottom:var(--space-6)}.macro-totals{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);margin-bottom:var(--space-3);gap:var(--space-2)}.macro-total-item{display:flex;flex-direction:column;align-items:center;flex:1}.macro-total-divider{width:1px;height:32px;background:var(--border-glass);flex-shrink:0}.mt-value{font-size:var(--font-md);font-weight:700;line-height:1.2}.mt-value.calories{background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.mt-value.protein{color:#ef4444}.mt-value.carbs{color:#f59e0b}.mt-value.fats{color:#818cf8}.mt-value.fiber{color:#22c55e}.mt-label{font-size:var(--font-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.3px;margin-top:2px}.macro-bar-container{padding:var(--space-3) var(--space-4);margin-bottom:var(--space-3)}.macro-bar{display:flex;height:10px;border-radius:var(--radius-full);overflow:hidden;gap:2px}.macro-bar-segment{border-radius:var(--radius-full);transition:flex var(--transition-base)}.macro-bar-segment.protein{background:#ef4444}.macro-bar-segment.carbs{background:#f59e0b}.macro-bar-segment.fats{background:#818cf8}.macro-bar-legend{display:flex;justify-content:center;gap:var(--space-4);margin-top:var(--space-2);flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:4px;font-size:var(--font-xs);color:var(--text-secondary)}.legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.legend-dot.protein{background:#ef4444}.legend-dot.carbs{background:#f59e0b}.legend-dot.fats{background:#818cf8}.macro-table-container{padding:var(--space-3);overflow-x:auto}.macro-table{width:100%;min-width:340px}.macro-table-head{display:flex;align-items:center;padding:var(--space-2) 0;border-bottom:1px solid var(--border-glass);font-size:var(--font-xs);color:var(--text-tertiary);text-transform:uppercase;font-weight:600;letter-spacing:.5px}.macro-table-row{display:flex;align-items:center;padding:var(--space-2) 0;border-bottom:1px solid rgba(255,255,255,.03);transition:background var(--transition-fast)}.macro-table-row:hover{background:var(--bg-glass-hover)}.macro-table-row.meal-row{font-size:var(--font-sm)}.macro-table-row.sub-row{font-size:var(--font-xs);opacity:.7}.macro-table-row.total-row{border-top:2px solid var(--border-glass-hover);border-bottom:none;margin-top:var(--space-1);padding-top:var(--space-3);font-size:var(--font-sm)}.mt-cell{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mt-cell.name{flex:1;min-width:0;padding-right:var(--space-2);color:var(--text-secondary)}.mt-cell.name.sub{padding-left:var(--space-4);color:var(--text-tertiary)}.mt-cell.num{width:42px;text-align:right;flex-shrink:0;color:var(--text-secondary)}.mt-cell.num.sub{color:var(--text-tertiary)}.mt-cell.num.bold{font-weight:700;color:var(--text-primary)}.protein-text{color:#ef4444!important}.carbs-text{color:#f59e0b!important}.fats-text{color:#818cf8!important}.fiber-text{color:#22c55e!important}.macro-table-group+.macro-table-group{border-top:1px solid var(--border-glass)}.macro-table-group+.macro-table-group .macro-table-row:first-child{padding-top:var(--space-2)}.calorie-dashboard{margin-bottom:var(--space-6)}.dashboard-ring-container{margin:0 var(--space-4);padding:var(--space-6) var(--space-4);display:flex;flex-direction:column;align-items:center;gap:var(--space-5)}.ring-wrapper{position:relative;width:160px;height:160px}.progress-ring{width:100%;height:100%}.ring-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.ring-consumed{font-size:var(--font-2xl);font-weight:800;color:var(--text-primary);line-height:1}.ring-divider{font-size:var(--font-sm);color:var(--text-tertiary);margin-top:2px}.ring-unit{font-size:var(--font-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:1px;font-weight:600}.dashboard-stats{display:flex;align-items:center;gap:var(--space-6);width:100%;justify-content:center}.stat-item{display:flex;flex-direction:column;align-items:center;gap:2px}.stat-label{font-size:var(--font-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;font-weight:500}.stat-value{font-size:var(--font-lg);font-weight:700;color:var(--text-primary)}.stat-value.over{color:var(--color-danger)}.stat-value.status{font-size:var(--font-sm);font-weight:600}.stat-divider{width:1px;height:32px;background:var(--border-glass)}.logged-items{margin-top:var(--space-4)}.logged-title{font-size:var(--font-base);font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-3)}.logged-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);margin-bottom:var(--space-2)}.logged-item-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.logged-item-name{font-size:var(--font-sm);color:var(--text-primary);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logged-item-type{font-size:var(--font-xs);color:var(--text-tertiary)}.logged-item-right{display:flex;align-items:center;gap:var(--space-3)}.logged-item-cal{font-size:var(--font-sm);font-weight:700;color:var(--accent-secondary);white-space:nowrap}.logged-item-remove{width:24px;height:24px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--text-tertiary);transition:all var(--transition-fast)}.logged-item-remove:hover{background:var(--color-danger-bg);color:var(--color-danger)}.logged-exercise{border:1px solid rgba(34,197,94,.2);background:linear-gradient(135deg,#22c55e0f,#10b98108)}.exercise-burned{color:#22c55e!important}.weekly-summary{padding-bottom:var(--space-10)}.weekly-header{margin-bottom:var(--space-4)}.weekly-totals{padding:var(--space-5);text-align:center}.weekly-total-main{display:flex;align-items:baseline;justify-content:center;gap:var(--space-2)}.weekly-total-num{font-size:var(--font-3xl);font-weight:800;line-height:1}.weekly-total-num.deficit{color:var(--color-success)}.weekly-total-num.surplus{color:var(--color-danger)}.weekly-total-unit{font-size:var(--font-md);color:var(--text-secondary);font-weight:600}.weekly-total-label{font-size:var(--font-sm);color:var(--text-tertiary);margin-top:var(--space-2)}.weekly-chart{padding:var(--space-5)}.chart-bars{display:flex;align-items:flex-end;gap:var(--space-2);height:180px;margin-bottom:var(--space-4)}.chart-bar-group{flex:1;display:flex;flex-direction:column;align-items:center;gap:var(--space-1);height:100%;background:none;border:none;padding:0;transition:transform var(--transition-fast)}.chart-bar-group:hover{transform:scaleY(1.02)}.chart-bar-group.today .chart-label{color:var(--accent-secondary);font-weight:700}.chart-bar-wrapper{flex:1;width:100%;position:relative;display:flex;align-items:flex-end}.maintenance-line{position:absolute;left:-2px;right:-2px;height:2px;background:var(--text-tertiary);opacity:.3;border-radius:1px}.chart-bar{width:100%;border-radius:var(--radius-sm) var(--radius-sm) 0 0;min-height:2px;transition:height .5s ease}.chart-bar.deficit{background:linear-gradient(to top,#22c55e4d,#22c55e99)}.chart-bar.surplus{background:linear-gradient(to top,#ef44444d,#ef444499)}.chart-bar.empty{background:var(--bg-glass);min-height:4px}.chart-label{font-size:var(--font-xs);color:var(--text-secondary);font-weight:500}.chart-date{font-size:var(--font-xs);color:var(--text-tertiary)}.chart-cal{font-size:9px;font-weight:600;position:absolute;top:-16px;width:100%;text-align:center}.chart-cal.deficit{color:var(--color-success)}.chart-cal.surplus{color:var(--color-danger)}.chart-legend{display:flex;justify-content:center;gap:var(--space-5);padding-top:var(--space-3);border-top:1px solid var(--border-glass)}.legend-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-xs);color:var(--text-tertiary)}.legend-dot{width:8px;height:8px;border-radius:50%}.legend-dot.deficit{background:var(--color-success)}.legend-dot.surplus{background:var(--color-danger)}.legend-line{width:16px;height:2px;background:var(--text-tertiary);opacity:.5}.breakdown-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);margin-bottom:var(--space-2);width:100%;text-align:left}.breakdown-date{display:flex;align-items:center;gap:var(--space-2)}.breakdown-day{font-size:var(--font-sm);font-weight:600;color:var(--text-primary)}.breakdown-num{font-size:var(--font-sm);color:var(--text-tertiary)}.breakdown-today{font-size:var(--font-xs);background:var(--accent-gradient);color:#fff;padding:1px 6px;border-radius:var(--radius-full);font-weight:600}.breakdown-right{display:flex;align-items:center;gap:var(--space-3)}.breakdown-cal{font-size:var(--font-sm);color:var(--text-primary);font-weight:600}.breakdown-empty{font-size:var(--font-sm);color:var(--text-tertiary)}.breakdown-diff{font-size:var(--font-xs);font-weight:700;padding:2px 8px;border-radius:var(--radius-full)}.breakdown-diff.deficit{background:var(--color-success-bg);color:var(--color-success)}.breakdown-diff.surplus{background:var(--color-danger-bg);color:var(--color-danger)}.settings-page{padding-bottom:var(--space-10)}.settings-group{padding:var(--space-5)}.settings-group-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.settings-group-title{font-size:var(--font-base);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-3)}.settings-group-header .settings-group-title{margin-bottom:0}.settings-field{margin-bottom:var(--space-3)}.settings-field label{display:block;font-size:var(--font-sm);color:var(--text-secondary);margin-bottom:var(--space-1);font-weight:500}.settings-hint{font-size:var(--font-sm);color:var(--text-tertiary);line-height:1.5}.settings-link{color:var(--accent-secondary);text-decoration:none;font-weight:600}.settings-link:hover{text-decoration:underline}.cal-input-wrapper{display:flex;align-items:center;gap:var(--space-2)}.cal-input{width:120px;text-align:center;font-size:var(--font-lg)!important;font-weight:700}.cal-input-unit{font-size:var(--font-sm);color:var(--text-tertiary);font-weight:600}.key-input-wrapper{display:flex;align-items:center;gap:var(--space-2)}.key-input{flex:1;font-family:monospace;font-size:var(--font-sm)!important}.key-toggle{width:36px;height:36px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:16px;transition:background var(--transition-fast)}.key-toggle:hover{background:var(--bg-glass-hover)}.add-btn-small{font-size:var(--font-sm);color:var(--accent-secondary);font-weight:600;padding:var(--space-1) var(--space-3);border-radius:var(--radius-md);transition:all var(--transition-fast)}.add-btn-small:hover{background:#6366f11a}.button-list{display:flex;flex-direction:column;gap:var(--space-2)}.button-config-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3);background:var(--bg-glass);border-radius:var(--radius-md)}.button-config-info{display:flex;align-items:center;gap:var(--space-3)}.button-config-emoji{font-size:1.3rem}.button-config-name{font-size:var(--font-sm);font-weight:600;color:var(--text-primary)}.button-config-cal{font-size:var(--font-xs);color:var(--text-tertiary)}.button-config-actions{display:flex;gap:var(--space-1)}.icon-btn{width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:14px;transition:background var(--transition-fast)}.icon-btn:hover{background:var(--bg-glass-hover)}.icon-btn.danger:hover{background:var(--color-danger-bg)}.button-edit-form,.button-add-form{width:100%;display:flex;flex-direction:column;gap:var(--space-3)}.button-add-form{margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--border-glass)}.edit-row{display:flex;gap:var(--space-2)}.emoji-input-sm{width:48px!important;text-align:center;font-size:1.2rem!important;flex-shrink:0}.edit-actions{display:flex;gap:var(--space-2);justify-content:flex-end}.danger-zone{border-color:#ef444426!important}.clear-btn{margin-top:var(--space-3);padding:var(--space-2) var(--space-5);background:var(--color-danger-bg);color:var(--color-danger);border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:600;transition:all var(--transition-fast)}.clear-btn:hover{background:#ef444433;transform:translateY(-1px)}.macro-fields-label{font-size:var(--font-xs);color:var(--text-secondary);font-weight:500;margin-bottom:var(--space-1)}.edit-row.macro-row{gap:var(--space-2)}.macro-field-group{display:flex;flex-direction:column;flex:1;min-width:0}.macro-field-label{font-size:var(--font-xs);font-weight:600;margin-bottom:2px;text-align:center}.macro-input{padding:var(--space-2) var(--space-2)!important;font-size:var(--font-sm)!important;text-align:center}.protein-label{color:#ef4444}.carbs-label{color:#f59e0b}.fats-label{color:#818cf8}.fiber-label{color:#22c55e}.button-config-macros{display:flex;gap:var(--space-2);margin-top:2px;flex-wrap:wrap}.config-macro{font-size:var(--font-xs);font-weight:600}.app{min-height:100vh;display:flex;flex-direction:column;max-width:480px;margin:0 auto;position:relative}.app-header{display:flex;align-items:center;justify-content:center;padding:var(--space-4) var(--space-4) var(--space-2);position:sticky;top:0;z-index:50;background:#0a0e1ad9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.app-logo{display:flex;align-items:center;gap:var(--space-2)}.logo-icon{font-size:1.5rem}.logo-text{font-size:var(--font-xl);font-weight:800;color:var(--text-primary);letter-spacing:-.5px}.logo-accent{background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-main{flex:1;padding-bottom:80px}.app-bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;display:flex;align-items:center;justify-content:space-around;padding:var(--space-2) var(--space-4) calc(var(--space-3) + env(safe-area-inset-bottom,0px));background:#0a0e1ae6;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid var(--border-glass);z-index:50}.nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);transition:all var(--transition-fast);min-width:64px}.nav-item:hover{background:var(--bg-glass-hover)}.nav-item.active{background:#6366f11a}.nav-icon{font-size:1.3rem;line-height:1}.nav-label{font-size:var(--font-xs);font-weight:600;color:var(--text-tertiary);transition:color var(--transition-fast)}.nav-item.active .nav-label{color:var(--accent-secondary)}.view-home,.view-weekly,.view-settings{padding-top:var(--space-2)}:root{--bg-primary: #0a0e1a;--bg-secondary: #111827;--bg-card: rgba(17, 24, 39, .8);--bg-glass: rgba(255, 255, 255, .04);--bg-glass-hover: rgba(255, 255, 255, .08);--border-glass: rgba(255, 255, 255, .08);--border-glass-hover: rgba(255, 255, 255, .15);--accent-primary: #6366f1;--accent-secondary: #818cf8;--accent-glow: rgba(99, 102, 241, .3);--accent-gradient: linear-gradient(135deg, #6366f1, #8b5cf6, #a78bfa);--accent-gradient-hover: linear-gradient(135deg, #818cf8, #a78bfa, #c4b5fd);--color-success: #22c55e;--color-success-bg: rgba(34, 197, 94, .1);--color-warning: #f59e0b;--color-warning-bg: rgba(245, 158, 11, .1);--color-danger: #ef4444;--color-danger-bg: rgba(239, 68, 68, .1);--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-tertiary: #64748b;--text-inverse: #0a0e1a;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-xs: .7rem;--font-sm: .8rem;--font-base: .9rem;--font-md: 1rem;--font-lg: 1.2rem;--font-xl: 1.5rem;--font-2xl: 2rem;--font-3xl: 2.5rem;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px var(--accent-glow);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;overflow-x:hidden;line-height:1.6}body:before{content:"";position:fixed;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 20%,rgba(99,102,241,.05) 0%,transparent 50%),radial-gradient(circle at 70% 80%,rgba(139,92,246,.04) 0%,transparent 50%);pointer-events:none;z-index:0}#root{position:relative;z-index:1;min-height:100vh}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text-tertiary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}button{font-family:var(--font-family);cursor:pointer;border:none;outline:none;background:none;color:inherit}input,textarea{font-family:var(--font-family);border:none;outline:none;background:none;color:inherit}.glass-card{background:var(--bg-glass);border:1px solid var(--border-glass);border-radius:var(--radius-lg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transition:all var(--transition-base)}.glass-card:hover{background:var(--bg-glass-hover);border-color:var(--border-glass-hover)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-fade-in{animation:fadeIn .4s ease forwards}.animate-slide-up{animation:slideUp .5s ease forwards}
