*{box-sizing:border-box;margin:0;padding:0}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;--bg: #0f172a;--surface: #1e293b;--surface2: #334155;--border: #334155;--text: #f1f5f9;--text-muted: #94a3b8;--primary: #6366f1;--primary-hover: #4f46e5;--danger: #ef4444}body{background:var(--bg);color:var(--text);min-height:100dvh;margin:0;max-width:100vw;overflow-x:hidden}#root{min-height:100dvh;display:flex;flex-direction:column}.app{max-width:480px;width:100%;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column;position:relative;padding-bottom:calc(88px + env(safe-area-inset-bottom,0px));overflow-x:hidden}.app-header{padding:10px 16px 8px;border-bottom:1px solid var(--border);background:var(--surface);position:sticky;top:0;z-index:10;padding-top:calc(10px + env(safe-area-inset-top,0px))}.app-title{font-size:1.25rem;font-weight:700;letter-spacing:-.3px}.app-main{flex:1;padding:0 0 20px}.tab-bar{display:flex;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:48px;z-index:9}.tab-btn{flex:1;padding:10px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.dashboard{padding:14px 16px}.dashboard-date{font-size:.85rem;color:var(--text-muted);margin-bottom:14px;text-align:center}.calories-ring{text-align:center;background:var(--surface);border-radius:16px;padding:16px;margin-bottom:14px}.calories-number{font-size:2.5rem;font-weight:800;letter-spacing:-2px;line-height:1}.calories-label{font-size:.85rem;color:var(--text-muted);margin-top:4px}.calories-goal{font-size:.8rem;color:var(--text-muted);margin-top:8px}.macro-bars{display:flex;flex-direction:column;gap:10px}.macro-bar{background:var(--surface);border-radius:12px;padding:10px 14px}.macro-bar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.macro-label{font-weight:600;font-size:.9rem}.macro-values{font-size:.85rem;color:var(--text-muted)}.macro-values.over-goal{color:var(--danger)}.progress-track{height:8px;background:var(--surface2);border-radius:4px;overflow:hidden}.progress-fill{height:100%;border-radius:4px;transition:width .3s ease}.macro-remaining{font-size:.75rem;color:var(--text-muted);margin-top:6px;text-align:right}.food-log{padding:0 16px}.log-title{font-size:1rem;font-weight:600;color:var(--text-muted);margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px;font-size:.75rem}.log-list{display:flex;flex-direction:column;gap:8px}.log-item{display:flex;align-items:center;gap:12px;background:var(--surface);border-radius:12px;padding:12px}.log-thumbnail{width:48px;height:48px;object-fit:cover;border-radius:8px;flex-shrink:0}.log-info{flex:1;min-width:0}.log-name{font-weight:600;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.log-macros{display:flex;gap:8px;margin-top:4px;font-size:.78rem;color:var(--text-muted);flex-wrap:wrap}.log-cal{color:var(--text);font-weight:600}.delete-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px 8px;border-radius:6px;font-size:.85rem;flex-shrink:0;transition:color .15s}.delete-btn:hover{color:var(--danger)}.food-log-empty{text-align:center;padding:48px 20px;color:var(--text-muted)}.empty-icon{font-size:3rem;margin-bottom:12px}.empty-hint{font-size:.85rem;margin-top:6px;opacity:.7}.fab-container{position:fixed;bottom:calc(24px + env(safe-area-inset-bottom,0px));right:50%;transform:translate(212px);z-index:20}@media(max-width:480px){.fab-container{right:20px;transform:none}}.fab{width:56px;height:56px;border-radius:50%;background:var(--primary);color:#fff;border:none;font-size:1.7rem;line-height:1;cursor:pointer;box-shadow:0 4px 20px #6366f166;transition:transform .15s,background .15s;display:flex;align-items:center;justify-content:center}.fab:hover{background:var(--primary-hover);transform:scale(1.05)}.btn{padding:12px 20px;border-radius:10px;border:none;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;justify-content:center;gap:6px}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-secondary{background:var(--surface2);color:var(--text)}.btn-secondary:hover{background:#475569}.btn-ghost{background:none;color:var(--text-muted);border:1px solid var(--border)}.btn-ghost:hover{background:var(--surface2);color:var(--text)}.photo-capture{padding:16px}.photo-capture h2{font-size:1.2rem;font-weight:700;margin-bottom:6px}.capture-hint{color:var(--text-muted);font-size:.85rem;margin-bottom:16px}.drop-zone{border:2px dashed var(--border);border-radius:16px;padding:28px 16px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s;margin-bottom:14px}.drop-zone:hover{border-color:var(--primary);background:#6366f10d}.drop-icon{font-size:2rem;margin-bottom:8px}.drop-text{font-weight:600;margin-bottom:4px}.drop-subtext{font-size:.8rem;color:var(--text-muted)}.capture-actions{display:flex;gap:12px;margin-bottom:16px}.capture-actions .btn{flex:1}.preview-image{width:100%;max-height:220px;object-fit:contain;border-radius:12px;margin-bottom:14px;background:var(--surface)}.cancel-btn{width:100%;margin-top:8px}.mode-toggle{display:flex;background:var(--surface);border-radius:10px;padding:3px;margin-bottom:14px;gap:3px}.mode-btn{flex:1;padding:7px 8px;border-radius:7px;border:none;background:none;color:var(--text-muted);font-size:.82rem;font-weight:600;cursor:pointer;transition:all .15s}.mode-btn.active{background:var(--surface2);color:var(--text)}.food-textarea{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:14px;color:var(--text);font-size:1rem;font-family:inherit;resize:vertical;line-height:1.5;margin-bottom:6px;transition:border-color .15s}.food-textarea:focus{outline:none;border-color:var(--primary)}.food-textarea::placeholder{color:var(--text-muted)}.textarea-hint{font-size:.75rem;color:var(--text-muted);margin-bottom:12px}.text-description-badge{background:var(--surface);border-radius:10px;padding:12px 16px;font-size:.9rem;color:var(--text-muted);margin-bottom:16px;font-style:italic}.macro-result{padding:16px}.macro-result h2{font-size:1.2rem;font-weight:700;margin-bottom:12px}.result-image{width:100%;max-height:220px;object-fit:contain;border-radius:12px;background:var(--surface);margin-bottom:16px}.analyzing{text-align:center;padding:32px 0}.spinner{width:40px;height:40px;border:3px solid var(--surface2);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}@keyframes spin{to{transform:rotate(360deg)}}.analysis-progress{font-size:.75rem;color:var(--text-muted);background:var(--surface);border-radius:8px;padding:12px;margin-top:12px;white-space:pre-wrap;word-break:break-all;overflow-wrap:anywhere;max-height:120px;max-width:100%;overflow:hidden auto;text-align:left}.confidence-badge{display:inline-block;font-size:.8rem;font-weight:600;margin-bottom:12px;text-transform:capitalize}.result-notes{font-size:.85rem;color:var(--text-muted);background:var(--surface);padding:10px 14px;border-radius:8px;margin-bottom:16px}.result-form{background:var(--surface);border-radius:16px;padding:16px;margin-bottom:20px}.macro-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px}.form-input{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:10px 12px;color:var(--text);font-size:.95rem;font-family:inherit;width:100%;transition:border-color .15s}.form-input:focus{outline:none;border-color:var(--primary)}.result-actions{display:flex;flex-direction:column;gap:10px}.result-actions .btn{width:100%}.error-state{text-align:center;padding:24px 0}.error-text{color:var(--danger);margin-bottom:16px}.past-foods-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px;max-height:55dvh;overflow-y:auto}.past-food-item{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px;width:100%;text-align:left;cursor:pointer;color:var(--text);transition:background .15s,border-color .15s}.past-food-item:hover{background:var(--surface2);border-color:var(--primary)}.goals-settings{padding:16px}.goals-settings h2{font-size:1.2rem;font-weight:700;margin-bottom:14px}.presets{margin-bottom:24px}.presets-label{font-size:.85rem;color:var(--text-muted);margin-bottom:10px}.preset-buttons{display:flex;flex-wrap:wrap;gap:8px}.preset-btn{font-size:.82rem;padding:8px 14px}.goals-form{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.unit-hint{color:var(--text-muted);font-weight:400}.save-btn{width:100%}
