:root{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--radius:12px;--background:#fff;--foreground:#1f2937;--card:#fff;--card-foreground:#1f2937;--primary:#00be3c;--primary-hover:#00d343;--primary-foreground:#fff;--secondary:#f3f4f6;--secondary-hover:#e5e7eb;--secondary-foreground:#111827;--muted-foreground:#6b7280;--border:#e5e7eb;font-family:system-ui,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box;scroll-behavior:smooth}body{background-color:var(--background);color:var(--foreground);margin:0;font-family:inherit}.btn{text-align:center;border-radius:9999px;padding:.75rem 2rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:background-color .15s,color .15s,border-color .15s;display:inline-block}.btn-primary{background-color:var(--primary);color:var(--primary-foreground);border:none}.btn-primary:hover{background-color:var(--primary-hover)}.btn-secondary{background-color:var(--secondary);color:var(--secondary-foreground);border:1px solid var(--border)}.btn-secondary:hover{background-color:var(--secondary-hover)}.soft-shadow{box-shadow:0 0 24px #0000000d,0 1px 3px #0000001a}.auth-page{background:linear-gradient(to bottom right, var(--background), #f0fff4);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{background:var(--card);width:100%;max-width:420px;color:var(--card-foreground);border:1px solid var(--border);border-radius:var(--radius);padding:32px 28px}.auth-card h1{text-align:center;color:var(--primary);margin:0 0 8px;font-size:1.8rem}.auth-subtitle{text-align:center;color:var(--muted-foreground);margin-bottom:24px;font-size:.95rem}.auth-card form{flex-direction:column;gap:14px;display:flex}.auth-card input{border-radius:var(--radius);border:1px solid var(--border);background:var(--background);outline:none;width:100%;padding:12px 14px;font-size:.95rem;transition:all .15s}.auth-card input:focus{border-color:var(--primary);box-shadow:0 0 0 2px #00be3c26}.auth-card input::placeholder{color:var(--muted-foreground)}.auth-card button{background:var(--primary);width:100%;color:var(--primary-foreground);cursor:pointer;border:none;border-radius:9999px;margin-top:6px;padding:.75rem 2rem;font-weight:500;transition:background-color .15s;display:inline-block}.auth-card button:hover:not(:disabled){background:var(--primary-hover)}.auth-card button:disabled{opacity:.5;cursor:not-allowed}.auth-success{text-align:center;font-size:.9rem}.auth-back{color:var(--primary);margin-bottom:12px;font-size:.9rem;font-weight:500;text-decoration:none;transition:opacity .15s;display:inline-block}.auth-back:hover{opacity:.7}.auth-error{color:red;font-size:.9rem}.auth-footer{text-align:center;color:var(--muted-foreground);margin-top:20px;font-size:.9rem}.auth-footer a{color:var(--primary);font-weight:500;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.header{z-index:100;background-color:var(--background);border-bottom:1px solid var(--border);width:100%;transition:max-width .3s,transform .3s,border-radius .3s,box-shadow .3s,border .3s,padding .3s}.header-container{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:.75rem 1.5rem;transition:padding .3s;display:flex}.header-left{align-items:center;gap:.75rem;display:flex}.header-logo{object-fit:cover;border-radius:8px;width:36px;height:36px}.header-title{font-size:1.1rem;font-weight:600}.header-nav{gap:2rem;display:flex}.header-link{color:var(--foreground);font-size:.9rem;font-weight:500;text-decoration:none;transition:color .15s}.header-link:hover{color:var(--primary)}.header-actions{align-items:center;gap:1rem;display:flex}@media (width<=768px){.header-nav{display:none}.header{position:sticky;top:0}.btn{border-radius:9999px;padding:.5rem 1.5rem;font-size:.8rem}}@media (width>=768px){.header.is-pill{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fff;border:1px solid #d3d3d3;border-radius:9999px;max-width:900px;margin-left:auto;margin-right:auto;padding:.5rem 1rem;position:sticky;top:0;transform:translateY(.75rem);box-shadow:0 10px 30px #0000001a}}.landing-banner{background:radial-gradient(circle at top,#ffffffe6,#0000 38%),linear-gradient(#fdf1de 0%,#f6e7cb 100%);justify-content:center;align-items:center;width:100%;min-height:calc(100svh - 74px);padding:2rem 1.5rem 0;display:flex;position:relative;overflow:hidden}.landing-banner-inner{flex-direction:column;justify-content:center;align-items:center;width:100%;max-width:1240px;display:flex}.utensils-title-wrapper{justify-content:center;align-items:center;margin-top:5rem;display:flex;position:relative}.title-group{z-index:1;flex-direction:column;align-items:center;margin-bottom:-85px;display:flex}.title-group>a{margin-top:15px}.bowl-title{color:#333;z-index:1;margin:0;font-size:4rem;font-weight:800}.bowl-subtitle{color:#666;z-index:1;margin:0;font-size:1.2rem}.recipe-counter-row{z-index:1;align-items:center;gap:1.5rem;display:flex}.recipe-counter-divider{background-color:#00000026;width:1px;height:36px}.recipe-counter{flex-direction:column;align-items:center;gap:.25rem;display:flex}.recipe-counter-num{color:var(--primary,#2563eb);font-variant-numeric:tabular-nums;font-size:2.5rem;font-weight:800;line-height:1}.recipe-counter-label{color:#666;text-transform:uppercase;letter-spacing:.08em;font-size:.95rem}.utensil{z-index:2;width:auto;height:500px;position:absolute;left:50%}.bowl-scene{flex-shrink:0;width:740px;height:690px;margin-bottom:-280px;position:relative}.bowl-img{z-index:1;width:90%;height:auto;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.bowl-front-img{z-index:3;pointer-events:none;width:90%;height:auto;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.food-item{z-index:2;filter:drop-shadow(0 2px 4px #00000026);width:260px;height:auto;position:absolute}.food-chicken{width:660px;top:15%;left:50%}.food-chilli{width:240px;top:32%;left:1%}.food-longbeans{width:250px;top:34%;left:10%}.food-mushroom{width:220px;top:37%;left:20%}.food-potato{width:240px;top:35%;right:15%}.food-mushroom-2{width:200px;top:40%;right:7%}.food-mushroom-3{width:185px;top:42%;left:42%}.food-chilli-2{width:220px;top:40%;right:20%}@media (width<=767px){.landing-banner{min-height:calc(100svh - 64px);padding-top:1rem}.utensils-title-wrapper{width:100%;margin-top:2.5rem}.title-group{margin-bottom:-30px}.bowl-title{text-align:center;font-size:clamp(2.5rem,10vw,4rem)}.bowl-subtitle{text-align:center;max-width:30ch}.recipe-counter-row{gap:1rem}.utensil{display:none}.bowl-scene{width:min(100vw,520px);height:470px;margin-bottom:-170px}.food-item{width:176px}.food-chicken{width:390px}.food-chilli,.food-longbeans,.food-potato,.food-chilli-2{width:164px}.food-mushroom,.food-mushroom-2,.food-mushroom-3{width:142px}}.landing{background-image:url(/landing/background.jpg);background-repeat:repeat;background-size:auto;background-attachment:scroll}.features-section{z-index:10;background:linear-gradient(#fffaf0,#fff);border-top-left-radius:32px;border-top-right-radius:32px;margin-top:-2rem;padding:8rem 1.5rem 6rem;position:relative;box-shadow:0 -24px 60px #6e563414}.features-scroll-section{min-height:520vh;padding-bottom:0}.features-scroll-sticky{justify-content:center;align-items:center;min-height:100vh;padding:1rem 1.5rem 4rem;display:flex;position:sticky;top:0;overflow:visible}.section-header{max-width:70vw;color:var(--primary);text-align:center;margin:0 auto 4rem;font-size:3rem}.section-subtitle{color:var(--muted-foreground);margin-top:1.5rem;font-size:1.125rem}.features-scroll-header{z-index:2;pointer-events:none;max-width:min(70vw,60rem);margin:0 auto;position:relative}.features-scroll-stage{justify-content:center;align-items:center;padding:2.5rem 1.5rem 4rem;display:flex;position:absolute;inset:0}.feature-scroll-frame{width:min(100%,1080px);position:absolute}.features-grid{gap:1.5rem;max-width:1080px;margin:0 auto;display:grid}.feature-card{border-radius:20px;grid-template-columns:minmax(0,1.1fr) minmax(240px,.9fr);align-items:center;min-height:28rem;padding:2rem;transition:transform .15s,box-shadow .15s;display:grid;overflow:hidden}.feature-card:hover{transform:translateY(-4px)}.feature-copy{text-align:left}.feature-icon{width:3rem;height:3rem;color:var(--primary);background-color:#2563eb1a;border-radius:14px;justify-content:center;align-items:center;margin-bottom:1rem;display:flex}.feature-title{color:var(--foreground);margin:0;font-size:1.25rem;font-weight:600}.feature-description{color:var(--muted-foreground);max-width:34ch;margin-top:1rem;line-height:1.7}.feature-image-shell{background:radial-gradient(circle at top,#ffffffb3,#0000 60%),linear-gradient(135deg,#ffd6aab3,#fff5e4f2);border-radius:18px;justify-content:center;align-items:center;min-height:220px;padding:1.5rem;display:flex}.feature-image{object-fit:contain;filter:drop-shadow(0 18px 24px #22180c2e);width:min(100%,220px);height:auto}.search-demo{background:#ffffffd1;border:1px solid #2563eb29;border-radius:999px;justify-content:flex-start;align-items:center;height:4.75rem;padding:0 1.25rem;display:flex;overflow:hidden;box-shadow:0 18px 30px #2563eb1f}.search-demo-icon{width:2rem;height:2rem;color:var(--primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.search-demo-text{white-space:nowrap;color:var(--foreground);margin-left:1rem;font-size:1rem;font-weight:600}.dietary-demo{place-items:center;width:min(100%,21rem);min-height:16rem;display:grid;position:relative}.dietary-demo-item{background:#ffffffc7;border-radius:2rem;justify-content:center;align-items:center;width:8.75rem;height:8.75rem;display:flex;position:absolute;box-shadow:0 18px 28px #6e56341f}.dietary-demo-egg{top:1rem;left:1.25rem}.dietary-demo-walnut{bottom:1.75rem;right:1.25rem}.dietary-demo-image{object-fit:contain;width:5.5rem;height:5.5rem}.dietary-demo-strike{pointer-events:none;width:88%;height:.42rem;position:absolute;top:48%;left:6%;transform:rotate(38deg)}.dietary-demo-strike-line{transform-origin:0;background:#dc2626;border-radius:999px;width:100%;height:100%;display:block;box-shadow:0 0 0 .18rem #fff9}.quickmeal-demo{place-items:center;width:min(100%,20rem);min-height:18rem;display:grid;position:relative}.quickmeal-clock{place-items:center;width:10rem;height:10rem;display:grid;position:relative}.quickmeal-clock-face{place-items:center;width:100%;height:100%;display:grid;position:relative}.quickmeal-clock-ring{background:#fff;border:.42rem solid #000;border-radius:50%;position:absolute;inset:0}.quickmeal-hand{background:var(--primary);transform-origin:bottom;border-radius:999px;position:absolute;bottom:50%;left:50%}.quickmeal-hour{width:.34rem;height:2.4rem;margin-left:-.17rem}.quickmeal-minute{background:#0f172a;width:.26rem;height:3.65rem;margin-left:-.13rem}.quickmeal-center-dot{background:var(--primary);border-radius:50%;width:.9rem;height:.9rem;position:absolute;box-shadow:0 0 0 .24rem #ffffffb3}@media (width<=767px){.section-header{max-width:min(90vw,34rem)}.features-section{border-top-left-radius:24px;border-top-right-radius:24px;margin-top:-1rem;padding-top:2rem}.features-scroll-section{min-height:460vh}.features-scroll-sticky{align-items:center;padding-top:1.5rem}.features-scroll-stage{align-items:flex-start;padding-top:5rem}.features-scroll-header{max-width:min(90vw,34rem)}.feature-card{grid-template-columns:1fr;min-height:32rem;padding:1.5rem}.feature-description{max-width:none}.feature-image-shell{min-height:180px}.quickmeal-demo{min-height:15rem}.quickmeal-clock{width:10rem;height:10rem}}.landing-footer{border-top:1px solid var(--border);background-color:var(--card);padding:2rem 1.5rem}.landing-footer-inner{justify-content:space-between;align-items:center;gap:1rem;max-width:1200px;margin:0 auto;display:flex}.landing-footer-link{color:var(--muted-foreground);align-items:center;gap:.5rem;text-decoration:none;transition:color .15s;display:inline-flex}.landing-footer-link:hover{color:var(--foreground)}.landing-footer-copy{color:var(--muted-foreground);font-size:.875rem}.card{background-color:#fff;border-radius:16px;flex-direction:column;display:flex;overflow:hidden;box-shadow:0 2px 8px #00000014}.card-image{object-fit:cover;width:100%;height:180px}.card-body{flex-direction:column;flex:1;gap:8px;padding:14px;display:flex}.card-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:15px;font-weight:600;line-height:1.3;display:-webkit-box;overflow:hidden}.card-meta{color:#666;flex-wrap:wrap;gap:10px;font-size:13px;display:flex}.card-save-btn{color:#fff;cursor:pointer;background-color:#22c55e;border:none;border-radius:8px;width:100%;margin-top:auto;padding:8px;font-size:13px}.save-btn{color:#fff;cursor:pointer;background-color:#22c55e;border:none;border-radius:24px;width:100%;margin-top:16px;padding:12px 32px;font-size:15px;font-weight:600}.save-btn.saved{color:#166534;background-color:#86efac}.similar-card{cursor:pointer;background:#fff;border-radius:12px;padding:16px;transition:transform .15s;box-shadow:0 2px 8px #0000000f}.similar-card:hover{transform:translateY(-2px)}.similar-title{margin-bottom:8px;font-size:14px;font-weight:600;line-height:1.3}.home-container{background:#f5f0e8;min-height:100vh;padding:32px 20px 48px}.welcome-section{text-align:center;margin:12px 0 32px}.welcome-title{color:#1f2a44;letter-spacing:-.02em;margin-bottom:8px;font-size:2.4rem;font-weight:800}.welcome-subtitle{color:#6b7280;margin:0;font-size:1rem}.search-bar{justify-content:center;gap:10px;margin-top:24px;margin-bottom:28px;display:flex}.search-input{background:#fffdf9;border:1px solid #ddd8cf;border-radius:999px;outline:none;width:400px;padding:12px 18px;font-size:15px;transition:border-color .15s,box-shadow .15s}.search-input:focus{border-color:#b7cbb5;box-shadow:0 0 0 4px #22c55e14}.search-button{color:#fff;cursor:pointer;background-color:#22c55e;border:none;border-radius:999px;padding:12px 22px;font-size:15px;font-weight:600;transition:transform .15s,box-shadow .15s;box-shadow:0 6px 14px #22c55e2e}.search-button:hover{transform:translateY(-1px);box-shadow:0 10px 18px #22c55e38}.suggested-section{-ms-border-radius:20px;-o-border-radius:20px;background:#f8f5ef;border:1px solid #e8e1d8;border-radius:20px;max-width:1000px;margin:24px auto 0;padding:16px 18px;box-shadow:0 10px 26px #0000000a}.home-title{text-align:left;color:#1f2a44;margin:12px;font-size:1.6rem;font-weight:750}.message{justify-content:center;margin-bottom:12px;display:flex}.search-message{color:#6b7280;font-size:.95rem}.recipe-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;display:grid}.recipe-grid .card{background:#fffdfa;border:1px solid #ece6dd;border-radius:24px;transition:transform .18s,box-shadow .18s;overflow:hidden;box-shadow:0 6px 18px #0000000b}.recipe-grid .card:hover{transform:translateY(-3px);box-shadow:0 12px 24px #00000013}.recipe-grid .card-image{object-fit:cover;height:180px}.recipe-grid .card-body{padding:.75rem .85rem}.recipe-grid .card-title{color:#1f2937;margin-bottom:.5rem;font-size:.95rem;font-weight:700;line-height:1.35}.recipe-grid .card-meta{color:#6b7280;margin-bottom:.6rem;font-size:.82rem}.recipe-grid .card-save-btn{border-radius:14px;width:100%;padding:.65rem;font-size:.85rem;font-weight:600}.pagination{justify-content:center;align-items:center;gap:14px;margin:28px 0 8px;display:flex}.pagination button{cursor:pointer;background:#fff;border:1px solid #ddd8cf;border-radius:999px;justify-content:center;align-items:center;width:42px;height:42px;font-size:17px;transition:transform .15s,border-color .15s;display:flex;box-shadow:0 4px 10px #0000000a}.pagination button:hover:not(:disabled){border-color:#cfc7bc;transform:translateY(-1px)}.pagination button:disabled{opacity:.35;cursor:not-allowed}.pagination span{color:#666;font-size:14px;font-weight:500}.saved-section{text-align:center;background:#f2f7f3;flex-direction:column;align-items:center;margin:10px auto 28px;display:flex}.saved-section h2{color:#1f2a44;margin-bottom:10px}.saved-section p{color:#666;max-width:420px}.carousel{align-items:center;gap:12px;display:flex}.carousel-track{gap:16px;display:flex;overflow:hidden}.saved-card-wrap{flex:0 0 calc(33.3333% - 10.6667px);min-width:0}.carousel-btn{cursor:pointer;background:#fff;border:1px solid #d8d2c8;border-radius:999px;flex-shrink:0;width:36px;height:36px;font-size:18px;box-shadow:0 3px 8px #0000000a}@media (width<=1000px){.recipe-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=700px){.home-container{padding:20px 14px 32px}.welcome-title{font-size:2rem}.search-bar{flex-direction:column;align-items:center}.search-input{width:100%;max-width:420px}.suggested-section{border-radius:22px;padding:18px}.recipe-grid{grid-template-columns:1fr}.recipe-grid .card-image{height:185px}}.navbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#ffffffb3;border-radius:50px;justify-content:space-between;align-items:center;margin:16px 40px;padding:12px 24px;display:flex;box-shadow:0 2px 12px #00000014}.navbar-logo{font-size:18px;font-weight:700}.navbar-links{align-items:center;gap:24px;display:flex}.navbar-links a{color:#333;font-size:15px;text-decoration:none}.navbar-links button{color:#fff;cursor:pointer;background-color:#22c55e;border:none;border-radius:50px;padding:10px 24px;font-size:15px;font-weight:600}.search-wrapper{max-width:600px;margin:0 auto 32px;position:relative}.search-input-row{gap:10px;display:flex}.search-input{border:.5px solid #ddd;border-radius:24px;outline:none;flex:1;padding:12px 20px;font-size:15px}.search-input:focus{border-color:#22c55e}.search-button{color:#fff;cursor:pointer;background:#22c55e;border:none;border-radius:24px;padding:12px 24px;font-size:15px}.filter-panel{background:#fff;border:.5px solid #eee;border-radius:16px;margin-top:8px;padding:20px}.filter-section{margin-bottom:20px}.filter-section:last-child{margin-bottom:0}.filter-label{color:#999;letter-spacing:.05em;margin-bottom:10px;font-size:12px;font-weight:500}.filter-chips{flex-wrap:wrap;gap:8px;display:flex}.chip{cursor:pointer;background:#f5f5f5;border:1px solid #ddd;border-radius:20px;padding:7px 16px;font-size:13px}.chip.active{color:#fff;background:#22c55e;border-color:#22c55e}.saved-section{background:#f8f5ef;border-radius:20px;margin:1.25rem 0 2rem;padding:1rem 1.1rem 1.2rem;box-shadow:0 4px 14px #0000000d}.saved-header{align-items:center;gap:10px;margin-bottom:.8rem;display:flex}.saved-header h2{color:#1f2a44;margin:0;font-size:1.4rem;font-weight:700}.saved-count{color:#6b7280;background:#fff;border-radius:999px;padding:.3rem .65rem;font-size:.8rem;font-weight:600}.saved-carousel-shell{align-items:center;gap:.65rem;display:flex}.carousel-track{flex:1;gap:.8rem;display:flex;overflow:hidden}.saved-card-wrap{flex:0 0 300px}.saved-card-wrap .card{background:#fff;border-radius:18px;overflow:hidden;box-shadow:0 5px 14px #0000000f}.saved-card-wrap .card-image{object-fit:cover;height:130px}.saved-card-wrap .card-body{padding:.75rem .8rem .8rem}.saved-card-wrap .card-title{margin-bottom:.45rem;font-size:1rem;line-height:1.25}.saved-card-wrap .card-meta{color:#6b7280;margin-bottom:.65rem;font-size:.85rem}.saved-card-wrap .card-save-btn{cursor:pointer;border:none;border-radius:10px;width:100%;padding:.65rem .8rem;font-size:.9rem;font-weight:600}.carousel-btn{cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:999px;width:38px;height:38px;font-size:1.1rem;box-shadow:0 3px 10px #0000000f}.carousel-btn:disabled{opacity:.4;cursor:not-allowed}.onboarding-page{background:linear-gradient(#eef7f1 0%,#f8fbf9 100%);justify-content:center;align-items:center;min-height:100vh;padding:40px 20px;display:flex}.onboarding-card{background:#fff;border:1px solid #e6ece8;border-radius:24px;width:100%;max-width:820px;padding:40px;box-shadow:0 16px 50px #00000014}.onboarding-header{text-align:center;margin-bottom:32px}.onboarding-step{color:#16a34a;text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px;font-size:.85rem;font-weight:600}.onboarding-title{color:#111827;margin:0 0 12px;font-size:2rem;font-weight:700}.onboarding-subtitle{color:#4b5563;max-width:560px;margin:0 auto;font-size:1rem;line-height:1.6}.onboarding-form{flex-direction:column;gap:24px;display:flex}.onboarding-section{background:#f9fbfa;border:1px solid #e7eeea;border-radius:18px;padding:24px}.onboarding-section h2{color:#111827;margin:0 0 8px;font-size:1.15rem}.onboarding-section p{color:#6b7280;margin:0 0 16px;font-size:.95rem;line-height:1.5}.option-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.option-card{cursor:pointer;color:#1f2937;background:#fff;border:1px solid #dfe8e2;border-radius:14px;align-items:center;gap:12px;padding:14px 16px;font-weight:500;transition:all .18s;display:flex}.option-card:hover{border-color:#22c55e;transform:translateY(-1px);box-shadow:0 6px 16px #22c55e14}.option-card input{accent-color:#22c55e;flex-shrink:0;width:16px;height:16px;margin:0}.onboarding-section input[type=text]{box-sizing:border-box;background:#fff;border:1px solid #d7e1da;border-radius:12px;outline:none;width:100%;padding:14px 16px;font-size:.98rem;transition:border-color .18s,box-shadow .18s}.onboarding-section input[type=text]:focus{border-color:#22c55e;box-shadow:0 0 0 4px #22c55e1f}.success-message{color:#15803d;margin:-4px 0 0;font-weight:500}.onboarding-actions{justify-content:flex-end;gap:12px;margin-top:8px;display:flex}.secondary-btn,.primary-btn{cursor:pointer;border:none;border-radius:999px;padding:12px 20px;font-size:.95rem;font-weight:600;transition:transform .18s,box-shadow .18s,opacity .18s}.secondary-btn{color:#374151;background:#eef2f0}.primary-btn{color:#fff;background:#22c55e}.secondary-btn:hover,.primary-btn:hover{transform:translateY(-1px);box-shadow:0 8px 18px #00000014}@media (width<=700px){.onboarding-card{padding:24px}.option-grid{grid-template-columns:1fr}.onboarding-actions{flex-direction:column}.secondary-btn,.primary-btn{width:100%}.onboarding-title{font-size:1.6rem}}.ingredient-search-row{align-items:center;gap:12px;display:flex}.ingredient-search-row input{flex:1}.add-chip-btn{color:#fff;cursor:pointer;background:#22c55e;border:none;border-radius:12px;padding:14px 18px;font-weight:600;transition:transform .18s,box-shadow .18s}.add-chip-btn:hover{transform:translateY(-1px);box-shadow:0 8px 18px #22c55e26}.ingredient-chip-list{flex-wrap:wrap;gap:12px;margin-top:18px;display:flex}.ingredient-chip{background:#fff;border:1px solid #dfe8e2;border-radius:999px;align-items:center;gap:10px;padding:8px 10px 8px 8px;display:flex;box-shadow:0 4px 10px #0000000a}.ingredient-chip-image{object-fit:cover;background:#f3f4f6;border-radius:50%;width:34px;height:34px}.ingredient-chip-label{color:#1f2937;text-transform:capitalize;font-size:.95rem;font-weight:500}.ingredient-chip-remove{color:#6b7280;cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:1.1rem;line-height:1}.ingredient-chip-remove:hover{color:#111827}@media (width<=700px){.ingredient-search-row{flex-direction:column;align-items:stretch}.add-chip-btn{width:100%}}.quick-pick-section{margin-top:20px}.quick-pick-section h3{color:#111827;margin-bottom:12px;font-size:1rem;font-weight:600}.allergen-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;display:grid}.allergen-card{cursor:pointer;text-align:center;color:#1f2937;background:#fff;border:1px solid #dfe8e2;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:14px 10px;font-weight:500;transition:all .18s;display:flex}.allergen-card:hover{border-color:#22c55e;transform:translateY(-2px);box-shadow:0 8px 18px #22c55e1a}.allergen-card-image{object-fit:cover;background:#f3f4f6;border-radius:50%;width:52px;height:52px}.allergen-card span{color:#1f2937;font-size:.9rem;font-weight:500}.allergen-card.selected{background:#ecfdf5;border-color:#22c55e;box-shadow:0 6px 16px #22c55e1f}@media (width<=900px){.allergen-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width<=600px){.allergen-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.progress-bar{background:#e5e7eb;border-radius:999px;width:100%;max-width:420px;height:10px;margin:18px auto 0;overflow:hidden}.progress-bar-fill{background:#22c55e;border-radius:999px;height:100%;transition:width .25s}.onboarding-actions-left,.onboarding-actions-right{gap:12px;display:flex}.onboarding-actions{justify-content:space-between;align-items:center;gap:12px;margin-top:8px;display:flex}@media (width<=700px){.onboarding-actions{flex-direction:column;align-items:stretch}.onboarding-actions-left,.onboarding-actions-right{flex-direction:column;width:100%}}.detail-page{background:#f5f3ef;min-height:100vh;padding:32px 20px 56px}.detail-container{max-width:980px;margin:0 auto}.back-btn{cursor:pointer;color:#16a34a;background:0 0;border:none;margin-bottom:20px;padding:0;font-size:15px;font-weight:600;transition:opacity .15s}.back-btn:hover{opacity:.8}.detail-hero{background:#fcfbf8;border:1px solid #e9e3da;border-radius:24px;gap:28px;margin-bottom:28px;padding:22px;display:flex;box-shadow:0 10px 24px #0000000a}.detail-image{object-fit:cover;border:1px solid #eee7dd;border-radius:18px;flex-shrink:0;width:380px;height:270px}.detail-hero-info{flex-direction:column;flex:1;justify-content:center;display:flex}.detail-title{color:#1f2937;margin-bottom:16px;font-size:30px;font-weight:750;line-height:1.2}.detail-meta{flex-wrap:wrap;gap:10px;margin-bottom:16px;display:flex}.detail-meta span{color:#5f6b76;background:#f4f6f5;border:1px solid #e5e7eb;border-radius:999px;padding:7px 12px;font-size:14px}.detail-diets{flex-wrap:wrap;gap:8px;margin-bottom:18px;display:flex}.diet-tag{color:#15803d;background-color:#dcfce7;border:1px solid #bbf7d0;border-radius:999px;padding:6px 12px;font-size:13px;font-weight:600}.save-btn{color:#fff;cursor:pointer;background:#22c55e;border:none;border-radius:14px;align-self:flex-start;padding:12px 18px;font-size:14px;font-weight:700;transition:transform .15s,box-shadow .15s,opacity .15s;box-shadow:0 6px 16px #22c55e33}.save-btn:hover{transform:translateY(-1px);box-shadow:0 10px 20px #22c55e3d}.save-btn.saved{background:#16a34a}.detail-section{background:#fcfbf8;border:1px solid #e9e3da;border-radius:22px;margin-bottom:24px;padding:22px 24px;box-shadow:0 8px 20px #00000008}.detail-section h2{color:#1f2937;border-bottom:1px solid #ece7df;margin-bottom:16px;padding-bottom:10px;font-size:21px;font-weight:700}.ingredients-list{color:#374151;padding-left:22px;line-height:1.9;list-style:outside}.steps-list{color:#374151;padding-left:22px;line-height:1.85}.steps-list li{margin-bottom:14px}.similar-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;display:grid}.similar-card{cursor:pointer;background:#f8faf8;border:1px solid #e5e7eb;border-radius:18px;padding:16px;transition:transform .15s,box-shadow .15s,border-color .15s}.similar-card:hover{border-color:#cfe9d6;transform:translateY(-2px);box-shadow:0 10px 20px #0000000d}.similar-title{color:#1f2937;margin-bottom:8px;font-weight:700;line-height:1.35}.similar-card span{color:#6b7280;font-size:14px}.loading{text-align:center;color:#666;padding:48px;font-size:16px}@media (width<=800px){.detail-page{padding:20px 14px 36px}.detail-hero{flex-direction:column;gap:18px;padding:16px}.detail-image{width:100%;height:220px}.detail-title{font-size:24px}.detail-section{padding:18px}}.saved-page{background:#f5f3ef;min-height:100vh;padding:1rem 1.5rem 2rem}.saved-page-inner{max-width:1100px;margin:0 auto}.saved-hero{justify-content:space-between;align-items:center;margin:1.5rem 0 1rem;display:flex}.saved-page-title{color:#1f2a44;margin:0;font-size:2rem;font-weight:700}.saved-page-subtitle{color:#6b7280;margin:.25rem 0 0;font-size:.9rem}.saved-count-pill{background:#fff;border:1px solid #e5e7eb;border-radius:999px;padding:.4rem .7rem;font-size:.8rem;font-weight:600}.saved-content-card{background:#f8f6f2;border:1px solid #ece7df;border-radius:20px;padding:1rem}.saved-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;display:grid}.saved-grid .card{background:#fff;border:1px solid #ece7df;border-radius:18px;overflow:hidden;box-shadow:0 4px 12px #0000000d}.saved-grid .card-image{object-fit:cover;height:160px}.saved-grid .card-body{padding:.75rem .8rem}.saved-grid .card-title{margin-bottom:.4rem;font-size:1rem;font-weight:600}.saved-grid .card-meta{color:#6b7280;margin-bottom:.7rem;font-size:.85rem}.saved-grid .card-save-btn{border-radius:10px;padding:.65rem;font-size:.85rem}.saved-empty-state{text-align:center;color:#6b7280;padding:2rem 1rem}.saved-empty-state h2{margin-bottom:.4rem;font-size:1.2rem}
