:root{--primary: #2563eb;--primary-dark: #1e40af;--success: #059669;--error: #dc2626;--bg: #f9fafb;--surface: #ffffff;--text: #111827;--text-light: #6b7280;--border: #e5e7eb;--shadow: 0 1px 3px 0 rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.6}.container{max-width:800px;margin:0 auto;padding:2rem 1rem}header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}h1{font-size:2rem;font-weight:700;color:var(--text)}.settings-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:.5rem;border-radius:.5rem;transition:background .2s}.settings-btn:hover{background:var(--border)}form{margin-bottom:2rem}.tab-switcher{display:flex;gap:.5rem;margin-bottom:1.5rem;background:var(--surface);padding:.5rem;border-radius:.5rem;box-shadow:var(--shadow)}.tab-btn{flex:1;padding:.75rem 1.5rem;background:transparent;color:var(--text-light);border:none;border-radius:.375rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.tab-btn:hover{background:var(--bg);color:var(--text)}.tab-btn.active{background:var(--primary);color:#fff}.tab-btn.active:hover{background:var(--primary-dark)}.servings-control{display:flex;align-items:center;gap:.75rem;background:var(--surface);padding:1rem;border-radius:.5rem;box-shadow:var(--shadow);margin-bottom:1.5rem}.servings-control label{font-size:.875rem;font-weight:500;color:var(--text)}.servings-control input[type=number]{width:80px;padding:.5rem;border:1px solid var(--border);border-radius:.375rem;font-size:1rem;text-align:center}.input-group{display:flex;gap:.5rem;background:var(--surface);padding:.5rem;border-radius:.5rem;box-shadow:var(--shadow)}input[type=url],input[type=text]{flex:1;padding:.75rem;border:1px solid var(--border);border-radius:.375rem;font-size:1rem}input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.servings-input{display:flex;align-items:center;gap:.5rem;white-space:nowrap}.servings-input label{font-size:.875rem;color:var(--text-light)}.servings-input input[type=number]{width:60px;padding:.75rem .5rem;border:1px solid var(--border);border-radius:.375rem;font-size:1rem;text-align:center}button{padding:.75rem 1.5rem;background:var(--primary);color:#fff;border:none;border-radius:.375rem;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s}button:hover:not(:disabled){background:var(--primary-dark)}button:disabled{opacity:.5;cursor:not-allowed}.error{background:#fef2f2;border:1px solid #fecaca;color:var(--error);padding:1rem;border-radius:.5rem;margin-bottom:1rem}.warning{background:#fffbeb;border:1px solid #fcd34d;color:#92400e;padding:.75rem 1rem;border-radius:.5rem;margin-bottom:1rem;font-size:.875rem}.results{background:var(--surface);padding:2rem;border-radius:.5rem;box-shadow:var(--shadow-lg)}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.results-header h2{font-size:1.5rem;font-weight:600}.copy-btn{background:var(--success);padding:.5rem 1rem;font-size:.875rem}.copy-btn:hover:not(:disabled){background:#047857}.recipe-link{display:inline-block;color:var(--primary);text-decoration:none;margin-bottom:1.5rem}.recipe-link:hover{text-decoration:underline}.preview{background:var(--bg);padding:1rem;border-radius:.375rem;border:1px solid var(--border)}.preview h4{font-size:.875rem;font-weight:600;color:var(--text-light);margin-bottom:.5rem}.preview pre{font-size:.875rem;white-space:pre-wrap;word-wrap:break-word;color:var(--text);font-family:Courier New,monospace}.settings{background:var(--surface);padding:1.5rem;border-radius:.5rem;box-shadow:var(--shadow-lg);margin-bottom:2rem}.settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.settings-header h3{font-size:1.25rem;font-weight:600}.close-btn{background:none;color:var(--text-light);font-size:2rem;padding:0;width:2rem;height:2rem;line-height:1}.settings-description{color:var(--text-light);margin-bottom:1rem;font-size:.875rem}.preferences-list{margin-bottom:1rem}.preference-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:var(--bg);border-radius:.375rem;margin-bottom:.5rem}.preference-item button{background:var(--error);padding:.25rem .75rem;font-size:.875rem}.add-preference{display:flex;gap:.5rem;margin-bottom:1rem}.add-preference select{padding:.75rem;border:1px solid var(--border);border-radius:.375rem;font-size:1rem;background:#fff}.settings-actions{display:flex;justify-content:flex-end}.save-btn{background:var(--success)}.save-btn:hover{background:#047857}.footer{margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--border);text-align:center;color:var(--text-light);font-size:.875rem}.photo-upload{width:100%}.photo-upload-content{display:flex;flex-direction:column;gap:1rem}.upload-area{border:2px dashed #cbd5e0;border-radius:8px;padding:2rem;text-align:center;background-color:#f7fafc;transition:border-color .3s ease}.upload-area:hover{border-color:#4a90e2}.upload-instructions{margin-bottom:1.5rem}.upload-title{font-size:1.25rem;font-weight:600;color:#2d3748;margin-bottom:.5rem}.upload-description{color:#4a5568;margin-bottom:.5rem}.upload-formats{font-size:.875rem;color:#718096}.upload-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.upload-btn,.camera-btn{padding:.75rem 1.5rem;font-size:1rem;border:none;border-radius:6px;cursor:pointer;transition:all .3s ease;font-weight:500}.upload-btn{background-color:#4a90e2;color:#fff}.upload-btn:hover:not(:disabled){background-color:#357abd}.camera-btn{background-color:#48bb78;color:#fff}.camera-btn:hover:not(:disabled){background-color:#38a169}.upload-btn:disabled,.camera-btn:disabled{opacity:.5;cursor:not-allowed}.preview-area{display:flex;flex-direction:column;gap:1rem;align-items:center}.image-preview{max-width:100%;max-height:400px;overflow:hidden;border-radius:8px;border:1px solid #e2e8f0}.image-preview img{max-width:100%;max-height:400px;object-fit:contain;display:block}.preview-info{text-align:center}.file-name{font-weight:500;color:#2d3748;margin-bottom:.25rem}.file-size{font-size:.875rem;color:#718096}.scale-option{display:flex;align-items:center;gap:.75rem;justify-content:center;flex-wrap:wrap}.scale-label{display:flex;align-items:center;gap:.4rem;font-size:.9rem;color:#4a5568;cursor:pointer;-webkit-user-select:none;user-select:none}.scale-label input[type=checkbox]{width:16px;height:16px;cursor:pointer}.scale-servings-input{width:64px;padding:.3rem .5rem;border:1px solid #cbd5e0;border-radius:4px;font-size:.9rem;text-align:center;color:#2d3748}.scale-servings-input:focus{outline:none;border-color:#4a90e2}.scale-servings-input--disabled{opacity:.4;cursor:not-allowed}.preview-actions{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.process-btn,.clear-btn{padding:.75rem 1.5rem;font-size:1rem;border:none;border-radius:6px;cursor:pointer;transition:all .3s ease;font-weight:500}.process-btn{background-color:#48bb78;color:#fff}.process-btn:hover:not(:disabled){background-color:#38a169}.process-btn:disabled{opacity:.6;cursor:not-allowed}.clear-btn{background-color:#e53e3e;color:#fff}.clear-btn:hover:not(:disabled){background-color:#c53030}.clear-btn:disabled{opacity:.6;cursor:not-allowed}.progress-container{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background-color:#bee3f8;border-radius:6px}.progress-message{text-align:center;color:#2c5282;font-weight:500;font-size:.9rem}.progress-bar{width:100%;height:8px;background-color:#e0f2fe;border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;background-color:#2563eb;transition:width .3s ease;border-radius:4px}.cancel-btn{align-self:center;padding:.5rem 1rem;background-color:#ef4444;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .3s ease}.cancel-btn:hover{background-color:#dc2626}.error-message{text-align:center;padding:1rem;background-color:#fed7d7;border-radius:6px;color:#c53030;font-weight:500}@media(max-width:640px){.upload-area{padding:1.5rem 1rem}.upload-buttons,.preview-actions{flex-direction:column;width:100%}.upload-btn,.camera-btn,.process-btn,.clear-btn{width:100%}.image-preview{max-height:300px}}
