:root{font-family:Poppins,Inter,Segoe UI,sans-serif;line-height:1.6;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#101828;background-color:transparent}a{color:inherit;text-decoration:none}body{margin:0;min-height:100vh}button{font:inherit}:root{--color-primary: #f97316;--color-secondary: #ef4444;--color-accent: #8b5cf6;--color-surface: rgba(255, 255, 255, .88);--color-text: #101828;--shadow-elevated: 0 32px 60px rgba(15, 23, 42, .12);--radius-xl: 32px}*{box-sizing:border-box}body{margin:0;font-family:Poppins,Inter,Segoe UI,Arial,sans-serif;background-image:radial-gradient(circle at 15% 20%,rgba(249,115,22,.18),transparent 42%),radial-gradient(circle at 85% 15%,rgba(139,92,246,.18),transparent 50%),radial-gradient(circle at 40% 80%,rgba(236,72,153,.12),transparent 55%),linear-gradient(180deg,#fff8f2,#f8fbff 55%,#f3f4ff);background-attachment:fixed;color:var(--color-text);min-height:100vh}a{color:inherit}.app-container{min-height:100vh;display:flex;flex-direction:column;position:relative}.main-content{flex:1;width:min(1160px,94%);margin:32px auto 64px}@media (max-width: 768px){.main-content{margin:20px auto 48px;width:min(720px,92%)}}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:clamp(40px,6vw,96px) 16px;position:relative}.auth-container:before,.auth-container:after{content:"";position:absolute;border-radius:999px;filter:blur(60px);opacity:.6;z-index:-1}.auth-container:before{width:320px;height:320px;background:#f9731659;top:8%;left:12%}.auth-container:after{width:360px;height:360px;background:#8b5cf659;bottom:8%;right:10%}.auth-card{width:min(1080px,100%);display:grid;grid-template-columns:1fr;border-radius:var(--radius-xl);background:#ffffffe6;box-shadow:var(--shadow-elevated);overflow:hidden;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.65)}.auth-showcase{position:relative;min-height:320px;display:flex;align-items:flex-end;justify-content:center;padding:clamp(28px,6vw,48px);background:linear-gradient(135deg,#f97316d9,#ec4899d9);overflow:hidden}.auth-showcase-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 20%,rgba(255,255,255,.55),transparent 60%);mix-blend-mode:screen}.auth-image{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;opacity:.45;transform:scale(1.05);filter:saturate(1.2)}.auth-branding{position:relative;display:flex;align-items:center;gap:16px;padding:18px 22px;border-radius:18px;background:#ffffff2e;border:1px solid rgba(255,255,255,.35);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);color:#fff}.auth-logo{width:56px;height:56px;border-radius:18px;box-shadow:0 12px 30px #0f172a3d}.auth-branding-text{display:flex;flex-direction:column;gap:4px}.auth-branding-name{font-size:1.35rem;font-weight:700;letter-spacing:.01em}.auth-branding-tagline{margin:0;font-size:.95rem;opacity:.9}.auth-highlights{position:absolute;bottom:clamp(28px,6vw,42px);left:clamp(28px,6vw,42px);display:flex;flex-wrap:wrap;gap:12px;max-width:360px}.auth-highlight-chip{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;background:#ffffff2e;border:1px solid rgba(255,255,255,.28);color:#fff;font-size:.9rem;letter-spacing:.01em}.auth-content{padding:clamp(32px,6vw,56px);display:flex;flex-direction:column;gap:24px;background:#fffffff2}.auth-header{display:flex;flex-direction:column;gap:12px}.auth-pill{align-self:flex-start;display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:999px;background:linear-gradient(135deg,#f9731629,#ec489933);color:var(--color-secondary);font-weight:600;letter-spacing:.04em;text-transform:uppercase;font-size:.78rem}.auth-header h1{margin:0;font-size:clamp(1.8rem,2.8vw,2.6rem);line-height:1.2;color:#1f2937}.auth-desc{margin:0;font-size:1rem;line-height:1.7;color:#475467}.auth-form{display:flex;flex-direction:column;gap:18px}.auth-input{padding:14px 18px;border-radius:14px;border:1px solid rgba(148,163,184,.35);background:#f8fafcbf;font-size:1rem;color:#1f2937;transition:border-color .2s,box-shadow .2s,transform .2s}.auth-input:focus{border-color:#ec489999;box-shadow:0 0 0 4px #ec489926;outline:none;transform:translateY(-1px)}.auth-btn{width:100%;padding:15px 18px;border-radius:16px;border:none;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background-position .2s}.auth-btn:disabled{opacity:.7;cursor:not-allowed}.primary-btn{background-image:linear-gradient(135deg,#f97316,#ef4444,#8b5cf6);color:#fff;box-shadow:0 18px 32px #ef444440;background-size:200% 200%}.primary-btn:hover{transform:translateY(-2px);background-position:100% 0;box-shadow:0 24px 40px #8b5cf640}.secondary-btn{background:#f9731614;color:#f97316;border:1px solid rgba(249,115,22,.22)}.secondary-btn:hover{background:#f9731624;transform:translateY(-2px)}.auth-divider{position:relative;display:flex;align-items:center;gap:12px;color:#98a2b3;font-size:.9rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,#f9731600,#f9731673,#f9731600)}.auth-socials{display:flex;gap:12px;flex-wrap:wrap}.social-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:14px 16px;background:#f8fafcd9;border:1px solid rgba(148,163,184,.25);color:#344054;border-radius:14px;transition:transform .2s ease,box-shadow .2s ease}.social-btn:hover{transform:translateY(-2px);box-shadow:0 16px 30px #0f172a1f}.auth-error{color:#ef4444;font-size:.9rem;text-align:center}@media (min-width: 960px){.auth-card{grid-template-columns:1.1fr 1fr}.auth-showcase{min-height:100%}.auth-content{padding:clamp(40px,5vw,64px)}}@media (max-width: 640px){.auth-card{border-radius:24px}.auth-branding{flex-direction:column;text-align:center}.auth-highlights{position:relative;bottom:auto;left:auto;margin-top:24px}.auth-highlight-chip{font-size:.85rem}.auth-socials{flex-direction:column}.social-btn{width:100%}}.flm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0f172a66;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:200;padding:24px}.flm-modal{position:relative;width:min(440px,100%);border-radius:28px;background:#fffffff2;border:1px solid rgba(255,255,255,.75);padding:clamp(28px,6vw,40px);box-shadow:0 28px 60px #0f172a33;overflow:hidden}.flm-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at top right,rgba(236,72,153,.28),transparent 55%);opacity:.9}.flm-header{position:relative;display:flex;gap:18px;align-items:center;margin-bottom:18px}.flm-logo{width:64px;height:64px;border-radius:20px;box-shadow:0 18px 38px #ef444438}.flm-header h2{margin:0;font-size:1.6rem;color:#0f172a}.flm-description{margin:8px 0 0;color:#475467;line-height:1.6}.flm-hint{position:relative;margin:0 0 24px;padding:14px 16px;border-radius:16px;background:#f9731614;color:#f97316;font-weight:600;border:1px solid rgba(249,115,22,.22)}.flm-actions{position:relative;display:flex;gap:12px;flex-wrap:wrap}.flm-primary,.flm-secondary{flex:1 1 160px;text-align:center;padding:14px 18px;border-radius:16px;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.flm-primary{background:linear-gradient(135deg,#f97316,#ef4444,#8b5cf6);color:#fff;text-decoration:none;box-shadow:0 18px 34px #ef444440}.flm-primary:hover{transform:translateY(-2px)}.flm-secondary{border:none;background:#f8fafce6;border:1px solid rgba(148,163,184,.25);color:#475467}.flm-secondary:hover{transform:translateY(-2px);box-shadow:0 14px 24px #0f172a1f}@media (max-width: 480px){.flm-modal{border-radius:22px}.flm-header{flex-direction:column;text-align:center}.flm-hint{text-align:center}}.home-wrapper{display:flex;flex-direction:column;gap:clamp(32px,5vw,48px);margin:0 auto}.home-hero{position:relative;overflow:hidden;border-radius:var(--radius-xl);padding:clamp(36px,7vw,72px);background:linear-gradient(135deg,#f973162e,#ec489929);border:1px solid rgba(255,255,255,.6);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow-elevated)}.home-hero-ornament{position:absolute;top:-20%;right:40%;bottom:40%;left:-10%;background:linear-gradient(135deg,#f9731673,#ec48996b,#8b5cf666);filter:blur(80px);opacity:.65}.home-hero-content{position:relative;display:flex;flex-direction:column;gap:clamp(18px,4vw,28px);max-width:640px;color:#1f2937}.home-hero-badge{align-self:flex-start;padding:8px 18px;border-radius:999px;background:#fffc;border:1px solid rgba(249,115,22,.3);font-weight:600;letter-spacing:.08em;text-transform:uppercase;font-size:.78rem;color:#f97316}.home-hero-title{margin:0;font-size:clamp(2.2rem,4vw,3.2rem);line-height:1.2;color:#0f172a}.home-hero-subtitle{margin:0;font-size:1.05rem;line-height:1.7;color:#475467}.home-hero-actions{display:flex;flex-wrap:wrap;gap:16px}.home-hero-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 22px;border-radius:16px;font-weight:600;text-decoration:none;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.home-hero-btn.primary{background:linear-gradient(135deg,#f97316,#ef4444,#8b5cf6);color:#fff;box-shadow:0 24px 40px #8b5cf633;background-size:200% 200%}.home-hero-btn.primary:hover{transform:translateY(-2px);background-position:100% 0}.home-hero-btn.ghost{background:#ffffffd9;border:1px solid rgba(148,163,184,.4);color:#475467}.home-hero-btn.ghost:hover{transform:translateY(-2px);background:#fffffff2;box-shadow:0 12px 24px #0f172a1f}.home-stats{display:flex;flex-wrap:wrap;gap:24px}.home-stat{display:flex;flex-direction:column;gap:4px;padding:12px 0;min-width:140px}.home-stat-value{font-size:1.8rem;font-weight:700;color:#ef4444}.home-stat-label{color:#475467;font-size:.95rem}.home-recipes{display:flex;flex-direction:column;gap:28px;padding:clamp(28px,5vw,36px);border-radius:28px;background:#ffffffeb;border:1px solid rgba(255,255,255,.75);box-shadow:0 16px 40px #0f172a1a}.home-recipes-header h2{margin:0;font-size:clamp(1.6rem,3vw,2.2rem);color:#0f172a}.home-recipes-header p{margin:8px 0 0;color:#64748b;font-size:1rem}.recipes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px}.recipe-card{position:relative;overflow:hidden;border-radius:22px;background:#f8fafcf2;border:1px solid rgba(226,232,240,.8);padding:24px;min-height:220px;display:flex}.recipe-card-gradient{position:absolute;inset:-40% -20% auto;height:180px;background:radial-gradient(circle at top left,rgba(249,115,22,.35),transparent 60%)}.recipe-card-content{position:relative;display:flex;flex-direction:column;gap:16px;z-index:1}.recipe-card-content h3{margin:0;font-size:1.2rem;color:#0f172a}.recipe-card-content p{margin:0;color:#475467;line-height:1.6;white-space:pre-line}.recipe-card-footer{margin-top:auto;display:inline-flex;align-items:center;gap:8px;color:#ef4444;font-weight:600;letter-spacing:.02em}.home-empty-state{display:flex;flex-direction:column;align-items:center;gap:16px;padding:48px 24px;border-radius:24px;background:#f8fafce6;border:1px dashed rgba(236,72,153,.35);color:#475467;text-align:center}.home-empty-state span{font-size:2rem}@media (max-width: 768px){.home-stats{gap:16px}.home-stat{min-width:120px}.home-recipes{border-radius:22px}}@media (max-width: 560px){.home-hero{border-radius:24px}.home-hero-actions{flex-direction:column}.home-hero-btn{width:100%}}.profile-container{width:100%;padding:24px;background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000000d}.profile-header{display:flex;align-items:center;margin-bottom:32px;padding-bottom:16px;border-bottom:1px solid #eee;flex-wrap:wrap}.profile-header h1{flex:1;font-size:28px;color:#333;margin:0}.profile-avatar{width:80px;height:80px;border-radius:50%;object-fit:cover;margin-right:16px}.profile-user-info{flex:1;min-width:200px}.profile-user-info h2{margin:0 0 8px;font-size:20px;color:#333}.profile-user-info p{margin:0;color:#666}.profile-loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:18px;color:#666}.profile-error{background-color:#fee2e2;color:#ef4444;padding:12px;border-radius:8px;margin-bottom:16px}.profile-success{background-color:#dcfce7;color:#16a34a;padding:12px;border-radius:8px;margin-bottom:16px}.profile-form{display:flex;flex-direction:column;gap:24px}.form-section{margin-bottom:8px}.form-section h3{font-size:18px;margin:0 0 12px;color:#333}.checkbox-group{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:16px;color:#444}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:#f87171}.profile-input{width:100%;max-width:300px;padding:12px 16px;border-radius:10px;border:1px solid #e2e8f0;font-size:16px;color:#1f2937;background-color:#fff;transition:border-color .2s ease,box-shadow .2s ease,background-color .2s ease}.profile-input:focus{outline:none;border-color:#f87171;box-shadow:0 0 0 3px #f871711f}.profile-select{width:100%;max-width:320px;padding:12px 48px 12px 16px;border-radius:12px;border:1px solid #e2e8f0;font-size:16px;color:#1f2937;background-color:#f8fafc;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='none' stroke='%23f87171' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' d='M1 1l5 5 5-5'/%3E%3C/svg%3E"),linear-gradient(180deg,#fff,#f8fafc);background-repeat:no-repeat;background-position:right 16px center,0 0;background-size:16px 16px,100% 100%;box-shadow:0 1px 3px #0f172a14;transition:border-color .2s ease,box-shadow .2s ease,background-color .2s ease,transform .2s ease;cursor:pointer;appearance:none;-webkit-appearance:none;-moz-appearance:none}.profile-select:hover{background-color:#fff;box-shadow:0 4px 12px #0f172a1f;transform:translateY(-1px)}.profile-select:focus{outline:none;border-color:#f87171;box-shadow:0 0 0 3px #f871712e}.profile-select:disabled{cursor:not-allowed;background-color:#f1f5f9;color:#94a3b8;box-shadow:none}.profile-actions{display:flex;gap:16px;margin-top:16px;flex-wrap:wrap}.profile-save-btn,.profile-logout-btn{padding:14px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;border:none}.profile-save-btn{background-color:#f87171;color:#fff}.profile-save-btn:hover{background-color:#ef4444}.profile-save-btn:disabled{background-color:#fca5a5;cursor:not-allowed}.profile-logout-btn{background-color:#fff;color:#f87171;border:1px solid #f87171}.profile-logout-btn:hover{background-color:#fef2f2}@media (max-width: 640px){.profile-container{padding:16px;border-radius:0;box-shadow:none}.profile-header{flex-direction:column;align-items:flex-start;text-align:center}.profile-avatar{margin:0 auto 16px}.profile-user-info{width:100%;text-align:center}.checkbox-group{grid-template-columns:1fr}.profile-actions{flex-direction:column}.profile-save-btn,.profile-logout-btn{width:100%}.profile-select,.profile-input{max-width:100%}}.ingredient-text-input{max-width:800px;margin:0 auto;padding:20px;background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a}.ingredient-text-input h2{color:#ef4444;margin-bottom:10px;font-size:1.8rem}.ingredient-text-input-description{color:#666;margin-bottom:20px;font-size:1rem}.ingredient-text-area-container{margin-bottom:15px}.ingredient-text-area{width:100%;padding:12px;border:1px solid #ddd;border-radius:6px;font-size:1rem;resize:vertical;font-family:inherit}.ingredient-text-area:focus{outline:none;border-color:#f87171;box-shadow:0 0 0 2px #f8717133}.ingredient-text-actions{display:flex;gap:10px;margin-bottom:20px}.ingredient-extract-btn,.ingredient-reset-btn,.ingredient-add-btn,.ingredient-delete-btn{padding:10px 15px;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:background-color .2s,transform .1s}.ingredient-extract-btn{background-color:#ef4444;color:#fff;flex:1}.ingredient-extract-btn:hover{background-color:#dc2626}.ingredient-extract-btn:disabled{background-color:#fca5a5;cursor:not-allowed}.ingredient-reset-btn{background-color:#e5e7eb;color:#4b5563}.ingredient-reset-btn:hover{background-color:#d1d5db}.ingredient-reset-btn:disabled{background-color:#f3f4f6;color:#9ca3af;cursor:not-allowed}.ingredient-error{color:#ef4444;margin:10px 0;font-size:.9rem}.ingredient-results{margin-top:30px}.ingredient-results h3{color:#4b5563;margin-bottom:15px;font-size:1.4rem;border-bottom:1px solid #e5e7eb;padding-bottom:8px}.ingredient-delete-btn{background-color:#fee2e2;color:#ef4444;padding:6px 10px;font-size:.85rem}.ingredient-add-btn{background-color:#f3f4f6;color:#4b5563;display:block;margin:15px 0}.ingredient-add-btn:hover{background-color:#e5e7eb}@media (max-width: 768px){.ingredient-text-input{padding:15px}.ingredient-table{display:block;overflow-x:auto}.ingredient-text-actions{flex-direction:column}.ingredient-extract-btn,.ingredient-reset-btn{width:100%}}.voice-recipe-generator-integrated{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.75rem;padding:1.5rem;margin:1rem 0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.voice-header{text-align:center;margin-bottom:1.5rem}.voice-header h2{color:#1f2937;margin-bottom:.5rem;font-size:1.5rem}.voice-header p{color:#6b7280;font-size:1rem;margin:0}.progress-container{margin-bottom:1.5rem}.progress-bar{width:100%;height:6px;background:#e5e7eb;border-radius:3px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#10b981);transition:width .5s ease;border-radius:3px}.progress-text{text-align:center;color:#374151;font-weight:500;margin:0;font-size:.875rem}.voice-controls{display:flex;justify-content:center;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap}.record-btn,.reset-btn{padding:.75rem 1.5rem;border:none;border-radius:2rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;min-width:150px}.start-recording{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;box-shadow:0 2px 10px #3b82f64d}.start-recording:hover{transform:translateY(-1px);box-shadow:0 4px 15px #3b82f666}.stop-recording{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 2px 10px #ef44444d;animation:pulse 2s infinite}.stop-recording:hover{transform:translateY(-1px);box-shadow:0 4px 15px #ef444466}.processing{background:#9ca3af;color:#fff;cursor:not-allowed}.reset-btn{background:#6b7280;color:#fff}.reset-btn:hover{background:#4b5563}@keyframes pulse{0%{box-shadow:0 2px 10px #ef44444d}50%{box-shadow:0 2px 15px #ef444499}to{box-shadow:0 2px 10px #ef44444d}}.audio-playback{background:#f1f5f9;padding:1rem;border-radius:.5rem;margin-bottom:1rem;text-align:center}.audio-playback h4{margin-top:0;margin-bottom:.75rem;color:#374151;font-size:.875rem}.transcript-display{background:#eff6ff;border:1px solid #bfdbfe;padding:1rem;border-radius:.5rem;margin-bottom:1rem}.transcript-display h4{margin-top:0;margin-bottom:.75rem;color:#1e40af;font-size:.875rem}.transcript-text{background:#fff;padding:.75rem;border-radius:.375rem;border:1px solid #bfdbfe;font-style:italic;color:#374151;font-size:.875rem}.error-display{background:#fef2f2;border:1px solid #fecaca;padding:1rem;border-radius:.5rem;margin-bottom:1rem;text-align:center}.error-display p{color:#dc2626;margin-bottom:.75rem;font-weight:500;font-size:.875rem}.retry-btn{background:#ef4444;color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;cursor:pointer;font-weight:500;font-size:.875rem}.retry-btn:hover{background:#dc2626}.voice-tips{background:#fffbeb;border:1px solid #fed7aa;padding:1rem;border-radius:.5rem;margin-top:1rem}.voice-tips h4{margin-top:0;margin-bottom:.75rem;color:#92400e;font-size:.875rem}.voice-tips ul{margin:0;padding-left:1.25rem;color:#78350f}.voice-tips li{margin-bottom:.25rem;font-size:.875rem}.extracted-ingredients{background:#f0f9ff;border:1px solid #bae6fd;padding:1rem;border-radius:.5rem;margin-bottom:1rem}.extracted-ingredients h4{margin-top:0;margin-bottom:.75rem;color:#4b5563;font-size:1.4rem;border-bottom:1px solid #e5e7eb;padding-bottom:8px}.ingredient-table{width:100%;border-collapse:collapse;margin-bottom:20px}.ingredient-table th{text-align:left;padding:10px;background-color:#f9fafb;border-bottom:1px solid #e5e7eb;color:#4b5563;font-weight:600}.ingredient-table td{padding:8px 10px;border-bottom:1px solid #e5e7eb}.ingredient-table input{width:100%;padding:8px;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.ingredient-table input:focus{outline:none;border-color:#f87171;box-shadow:0 0 0 2px #f871711a}.ingredient-delete-btn{background-color:#fee2e2;color:#ef4444;padding:6px 10px;font-size:.85rem;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.ingredient-delete-btn:hover{background-color:#fecaca}.ingredient-add-btn{background:#10b981;color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:background-color .2s;margin-bottom:.75rem}.ingredient-add-btn:hover{background:#059669}.ingredients-note{color:#374151;font-size:.875rem;font-style:italic;margin:0;background:#fffbeb;padding:.5rem;border-radius:.25rem;border:1px solid #fed7aa}@media (max-width: 768px){.voice-recipe-generator-integrated{padding:1rem}.voice-controls{flex-direction:column;align-items:center}.record-btn,.reset-btn{min-width:140px;padding:.625rem 1.25rem}}@media (max-width: 768px){.ingredient-table{font-size:.8rem}.ingredient-table th,.ingredient-table td,.ingredient-table input{padding:5px}.ingredient-delete-btn{padding:4px 8px;font-size:.7rem}}.photo-ingredient-input{margin-top:1em}.hidden-file-input{display:none}.photo-actions{display:flex;flex-wrap:wrap;gap:.75em;margin:.75em 0}.upload-btn{display:inline-flex;align-items:center;justify-content:center;padding:.5em 1em;border:1px solid #d1d5db;border-radius:8px;background-color:#f9fafb;color:#111827;cursor:pointer;font-weight:600;transition:background-color .2s ease,border-color .2s ease}.upload-btn:hover{background-color:#f3f4f6;border-color:#9ca3af}.camera-btn,.capture-btn,.detect-btn{padding:.5em 1em;border-radius:8px;border:none;font-weight:600;cursor:pointer;background-color:#2563eb;color:#fff;transition:background-color .2s ease}.camera-btn:hover,.capture-btn:hover,.detect-btn:hover{background-color:#1d4ed8}.camera-btn:disabled,.capture-btn:disabled,.detect-btn:disabled{background-color:#9ca3af;cursor:not-allowed}.camera-preview{display:flex;flex-direction:column;align-items:flex-start;gap:.75em;margin-bottom:1em}.camera-preview video{width:100%;max-width:320px;border-radius:12px;background:#000}.photo-preview-container{margin:1em 0;display:flex;flex-wrap:wrap;gap:.75em}.photo-preview{max-width:150px;border-radius:12px;box-shadow:0 4px 12px #0000001a}.detect-btn{margin-top:.5em}.photo-error{color:#b91c1c;margin-top:.5em}.photo-ingredients-list{margin-top:1em;list-style:disc inside}.ingredients-page{width:100%;padding:20px}.ingredients-header{text-align:center;margin-bottom:30px}.ingredients-header h1{color:#ef4444;font-size:2.2rem;margin-bottom:10px}.ingredients-header p{color:#6b7280;font-size:1.1rem}.input-method-selector{display:flex;justify-content:center;gap:15px;margin-bottom:30px}.method-btn{padding:10px 20px;border:2px solid #e5e7eb;border-radius:8px;background-color:#fff;color:#4b5563;font-weight:500;cursor:pointer;transition:all .2s}.method-btn:hover:not(:disabled){border-color:#f87171;color:#ef4444}.method-btn.active{border-color:#ef4444;color:#ef4444;background-color:#fee2e2}.method-btn:disabled{opacity:.5;cursor:not-allowed}.ingredients-input-container{margin-bottom:30px}.placeholder-container{text-align:center;padding:40px;background-color:#f9fafb;border-radius:8px;border:1px dashed #d1d5db}.placeholder-container p{color:#6b7280;font-size:1.1rem}.generate-recipe-container{text-align:center;margin-top:30px;padding-top:20px;border-top:1px solid #e5e7eb}.generate-recipe-btn{padding:12px 24px;background-color:#ef4444;color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.generate-recipe-btn:hover{background-color:#dc2626}.recipe-actions{display:flex;gap:1rem;margin-top:1rem;flex-wrap:wrap}.save-recipe-btn{background-color:#28a745;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .3s ease}.save-recipe-btn:hover:not(:disabled){background-color:#218838;transform:translateY(-2px)}.save-recipe-btn:disabled{background-color:#6c757d;cursor:not-allowed;transform:none}.generate-another-recipe-btn{background-color:#007bff;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .3s ease}.generate-another-recipe-btn:hover:not(:disabled){background-color:#0056b3;transform:translateY(-2px)}.generate-another-recipe-btn:disabled{background-color:#6c757d;cursor:not-allowed;transform:none}.success-message{color:#28a745;font-weight:500;margin-top:.5rem;padding:.5rem;background-color:#d4edda;border:1px solid #c3e6cb;border-radius:4px}.error-message{color:#dc3545;font-weight:500;margin-top:.5rem;padding:.5rem;background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px}.saved-recipes-container{margin-top:2rem;padding:1.5rem;background-color:#f8f9fa;border-radius:12px;border:1px solid #e9ecef}.saved-recipes-container h2{color:#495057;margin-bottom:1rem;font-size:1.5rem}.saved-recipes-container ul{list-style:none;padding:0;margin:0}.saved-recipes-container li{padding:.75rem;margin-bottom:.5rem;background-color:#fff;border-radius:8px;border:1px solid #dee2e6;font-weight:500;color:#495057;transition:all .2s ease}.saved-recipes-container li:hover{background-color:#e9ecef;transform:translate(5px)}.generation-options{margin-bottom:15px;padding:10px;background-color:#f9fafb;border-radius:6px;border:1px solid #e5e7eb}.image-option{display:flex;align-items:center;gap:8px;font-size:.9rem;color:#4b5563;cursor:pointer}.image-option input[type=checkbox]{width:16px;height:16px;accent-color:#ef4444}.meal-type-selector,.recipe-type-selector{margin-bottom:18px;font-size:.95rem;color:#1f2937;display:flex;justify-content:center}.meal-type-selector label,.recipe-type-selector label{display:flex;flex-direction:column;gap:6px;font-weight:600;color:#1f2937;align-items:center;text-align:center}.meal-type-selector select,.recipe-type-selector select{width:100%;max-width:260px;padding:10px 44px 10px 16px;border-radius:12px;border:1px solid #e2e8f0;background-color:#f8fafc;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='none' stroke='%23f87171' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' d='M1 1l5 5 5-5'/%3E%3C/svg%3E"),linear-gradient(180deg,#fff,#f8fafc);background-repeat:no-repeat;background-position:right 14px center,0 0;background-size:16px 16px,100% 100%;box-shadow:0 1px 3px #0f172a14;font-weight:500;color:#1f2937;transition:border-color .2s ease,box-shadow .2s ease,background-color .2s ease,transform .2s ease;cursor:pointer;appearance:none;-webkit-appearance:none;-moz-appearance:none;margin:0 auto}.meal-type-selector select:hover,.recipe-type-selector select:hover{background-color:#fff;box-shadow:0 4px 12px #0f172a1f;transform:translateY(-1px)}.meal-type-selector select:focus,.recipe-type-selector select:focus{outline:none;border-color:#f87171;box-shadow:0 0 0 3px #f871712e}.meal-type-selector select:disabled,.recipe-type-selector select:disabled{cursor:not-allowed;background-color:#f1f5f9;color:#94a3b8;box-shadow:none}.recipe-image-container{text-align:center;margin-bottom:20px}.recipe-image{max-width:400px;width:100%;height:auto;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a;border:1px solid #e5e7eb}.recipe-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px}.generate-image-btn{padding:10px 16px;background-color:#8b5cf6;color:#fff;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:background-color .2s}.generate-image-btn:hover:not(:disabled){background-color:#7c3aed}.generate-image-btn:disabled{background-color:#d1d5db;cursor:not-allowed}.success-message{color:#059669;background-color:#ecfdf5;padding:8px 12px;border-radius:6px;border:1px solid #a7f3d0;margin-top:10px}.error-message{color:#dc2626;background-color:#fef2f2;padding:8px 12px;border-radius:6px;border:1px solid #fca5a5;margin-top:10px}.recipe-history{margin-top:1.5rem;padding:1rem;background-color:#f8f9fa;border-radius:8px;border:1px solid #e5e7eb}.recipe-history h3{margin:0;color:#374151;font-size:1.1rem}.recipe-history-buttons{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.recipe-history-btn{padding:.5rem 1rem;border-radius:999px;border:1px solid #d1d5db;background-color:#fff;color:#374151;cursor:pointer;transition:all .2s ease-in-out}.recipe-history-btn:hover{border-color:#ef4444;color:#ef4444}.recipe-history-btn.active{background-color:#fee2e2;border-color:#ef4444;color:#ef4444;font-weight:600}@media (max-width: 768px){.ingredients-page{padding:15px}.ingredients-header h1{font-size:1.8rem}.input-method-selector{flex-direction:column;gap:10px}.method-btn{width:100%}.meal-type-selector select,.recipe-type-selector select{max-width:100%}}.navbar{width:min(1160px,94%);margin:24px auto 0;padding:16px clamp(20px,4vw,32px);border-radius:24px;background:linear-gradient(135deg,#ffffffeb,#ffffffd1);border:1px solid rgba(255,255,255,.7);box-shadow:0 24px 50px #0f172a1a;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;justify-content:space-between;align-items:center;position:sticky;top:20px;z-index:100}.navbar:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;pointer-events:none;border:1px solid rgba(249,115,22,.12)}.navbar-brand{display:flex;align-items:center;gap:14px}.brand-link{display:inline-flex;align-items:center;gap:16px;text-decoration:none;color:var(--color-text)}.brand-logo-wrap{display:inline-flex;width:52px;height:52px;border-radius:18px;padding:4px;background:linear-gradient(135deg,#f9731626,#ec489938);box-shadow:0 16px 30px #ef444440}.brand-logo{width:100%;height:100%;border-radius:14px}.brand-copy{display:flex;flex-direction:column;gap:4px}.brand-name{font-size:1.4rem;font-weight:700;letter-spacing:.01em;color:#1f2937}.brand-tagline{font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;color:#f97316;font-weight:600}.navbar-links{display:flex;align-items:center;gap:clamp(16px,3vw,28px)}.navbar-link{position:relative;color:#475467;text-decoration:none;font-weight:600;font-size:.98rem;padding:10px 14px;border-radius:12px;transition:color .2s ease}.navbar-link:after{content:"";position:absolute;inset:auto 14px -10px;height:3px;border-radius:999px;background:linear-gradient(90deg,#f97316,#ef4444,#8b5cf6);transform:scaleX(0);transform-origin:left;transition:transform .2s ease}.navbar-link:hover{color:#ef4444}.navbar-link:hover:after,.navbar-link.active:after{transform:scaleX(1)}.navbar-link.active{color:#ef4444;background:#ef444414}.logout-btn{padding:10px 18px;border-radius:16px;border:none;background:linear-gradient(135deg,#ef44441f,#8b5cf61f);color:#ef4444;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.logout-btn:hover{transform:translateY(-2px);box-shadow:0 18px 32px #ef44442e}.language-switcher{display:inline-flex;align-items:center;gap:10px;padding:6px;border-radius:999px;background:#f8fafcd9;border:1px solid rgba(148,163,184,.25);box-shadow:inset 0 0 0 1px #ffffff4d}.lang-btn{border:none;background:transparent;padding:6px 12px;border-radius:999px;font-weight:600;color:#475467;cursor:pointer;transition:background .2s ease,color .2s ease}.lang-btn:hover{background:#ef44441f;color:#ef4444}@media (max-width: 900px){.navbar{flex-direction:column;align-items:flex-start;gap:16px}.navbar-links{flex-wrap:wrap;gap:12px;width:100%}.language-switcher{margin-left:auto}}@media (max-width: 640px){.navbar{position:static;top:auto;width:100%;margin:12px 0 0;padding:14px 16px;border-radius:18px}.brand-logo-wrap{width:46px;height:46px}.brand-name{font-size:1.2rem}.brand-tagline{font-size:.72rem}.navbar-links{flex-direction:column;align-items:stretch}.navbar-link{width:100%}.language-switcher{width:100%;justify-content:center}}
