.camera-capture{border:2px dashed var(--accent-color,#0070f3);cursor:pointer;background-color:var(--bg-secondary,#0070f30d);border-radius:16px;justify-content:center;align-items:center;width:100%;max-width:500px;min-height:250px;margin:0 auto;transition:all .3s cubic-bezier(.25,.8,.25,1);display:flex;position:relative;overflow:hidden}.camera-capture:hover{background-color:var(--bg-hover,#0070f31a);transform:translateY(-2px);box-shadow:0 8px 24px #0070f326}.camera-capture.drag-active{border-color:var(--success-color,#10b981);background-color:#10b9811a;transform:scale(1.02)}.camera-capture.loading{opacity:.7;pointer-events:none;border-style:solid;animation:2s ease-in-out infinite pulse-border}.camera-capture input[type=file]{display:none}.capture-content{text-align:center;pointer-events:none;padding:2rem}.capture-content .icon{margin-bottom:1rem;font-size:3rem;transition:transform .3s;display:inline-block}.camera-capture:hover .icon{transform:scale(1.1)rotate(-5deg)}.capture-content p{color:var(--text-primary,#111827);margin:0;font-size:1.1rem;font-weight:600}.capture-content .sub-text{color:var(--text-secondary,#6b7280);margin-top:.5rem;font-size:.9rem;display:block}@keyframes pulse-border{0%{border-color:#0070f366}50%{border-color:#0070f3}to{border-color:#0070f366}}.camera-capture-wrapper{flex-direction:column;gap:1.5rem;width:100%;display:flex}.thumbnails-container{flex-direction:column;align-items:center;gap:1.5rem;width:100%;display:flex}.thumbnails-grid{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.thumbnail-wrapper{border-radius:12px;width:80px;height:80px;position:relative;overflow:hidden;box-shadow:0 4px 12px #0000001a}.thumbnail-img{object-fit:cover;width:100%;height:100%;display:block}.remove-btn{color:#fff;cursor:pointer;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:12px;transition:background .2s;display:flex;position:absolute;top:4px;right:4px}.remove-btn:hover{background:#ef4444e6}.analyze-batch-btn{background-color:var(--accent-color,#0070f3);color:#fff;cursor:pointer;border:none;border-radius:30px;padding:.8rem 2rem;font-size:1.1rem;font-weight:600;transition:all .2s;box-shadow:0 4px 14px #0070f34d}.analyze-batch-btn:hover{background-color:var(--accent-hover,#0051a8);transform:translateY(-2px);box-shadow:0 6px 20px #0070f366}.thumbnail-wrapper.processing{animation:1.2s ease-in-out infinite both thumbnail-pulse}@keyframes thumbnail-pulse{0%{opacity:1;border-radius:12px;transform:scale(1)}50%{opacity:.6;border-radius:18px;transform:scale(.85)}to{opacity:1;border-radius:12px;transform:scale(1)}}
.preference-form{background:var(--bg-surface,#fff);border-radius:24px;width:100%;max-width:500px;margin:2rem auto;padding:2rem;transition:transform .3s;box-shadow:0 10px 40px #00000014}.form-group{margin-bottom:2rem}.form-group label{color:var(--text-primary,#111827);margin-bottom:1rem;font-size:1.1rem;font-weight:700;display:block}.cuisine-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem;display:grid}.cuisine-btn{background:var(--bg-secondary,#f3f4f6);cursor:pointer;border:2px solid #0000;border-radius:16px;flex-direction:column;align-items:center;gap:.5rem;padding:1rem .5rem;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.cuisine-btn:hover:not(:disabled){background:var(--bg-hover,#e5e7eb);transform:translateY(-2px)}.cuisine-btn.active{border-color:var(--accent-color,#0070f3);background:#0070f31a;box-shadow:0 4px 12px #0070f326}.cuisine-btn .emoji{font-size:1.8rem;transition:transform .3s cubic-bezier(.175,.885,.32,1.275)}.cuisine-btn.active .emoji{transform:scale(1.2)}.cuisine-btn .label{color:var(--text-secondary,#4b5563);font-size:.9rem;font-weight:600}.cuisine-btn.active .label{color:var(--accent-color,#0070f3)}.counter-control{background:var(--bg-secondary,#f3f4f6);border-radius:100px;justify-content:center;align-items:center;gap:1.5rem;width:fit-content;margin:0 auto;padding:.5rem;display:flex}.counter-btn{width:40px;height:40px;color:var(--accent-color,#0070f3);cursor:pointer;background:#fff;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.5rem;font-weight:700;transition:all .2s;display:flex;box-shadow:0 2px 8px #0000001a}.counter-btn:hover:not(:disabled){background:var(--accent-color,#0070f3);color:#fff;transform:scale(1.1)}.counter-btn:disabled{opacity:.5;cursor:not-allowed;color:#9ca3af}.count-display{text-align:center;min-width:2ch;color:var(--text-primary,#111827);font-size:1.5rem;font-weight:800}.submit-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#0070f3 0%,#0050cd 100%);border:none;border-radius:100px;width:100%;margin-top:1rem;padding:1.2rem;font-size:1.2rem;font-weight:700;transition:all .3s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 8px 24px #0070f34d}.submit-btn:hover:not(:disabled){transform:translateY(-3px)scale(1.02);box-shadow:0 12px 32px #0070f366}.submit-btn:active:not(:disabled){transform:translateY(1px)}.submit-btn.loading{box-shadow:none;cursor:wait;background:#9ca3af;animation:2s ease-in-out infinite pulse}@keyframes pulse{0%{opacity:.8}50%{opacity:1}to{opacity:.8}}
.results-container{width:100%;max-width:800px;margin:0 auto;padding:2rem 0}h2{color:var(--text-primary,#111827);letter-spacing:-.02em;margin-bottom:1.5rem;font-size:1.8rem;font-weight:800}.recipes-list{flex-direction:column;gap:2rem;display:flex}.recipe-card{background:var(--bg-surface,#fff);border-top:4px solid var(--accent-color,#0070f3);border-radius:24px;flex-direction:column;display:flex;overflow:hidden;box-shadow:0 10px 40px #00000014}.recipe-image-wrapper{background:var(--bg-secondary,#f3f4f6);border-bottom:1px solid #0000000d;width:100%;height:250px;position:relative;overflow:hidden}.recipe-image{object-fit:cover;width:100%;height:100%;transition:transform .5s}.recipe-image.clickable{cursor:pointer}.recipe-card:hover .recipe-image{transform:scale(1.05)}.recipe-card h3{color:var(--text-primary,#111827);margin:2rem 2rem .5rem;font-size:1.6rem;font-weight:800}.recipe-desc{color:var(--text-secondary,#6b7280);margin:0 2rem 2rem;font-size:1.05rem;line-height:1.6}.recipe-details{grid-template-columns:1fr;gap:2rem;padding:0 2rem 2rem;display:grid}@media (min-width:768px){.recipe-details{grid-template-columns:1fr 2fr}}.detail-block h4{color:var(--text-primary,#111827);text-transform:uppercase;letter-spacing:.05em;margin:0 0 1rem;font-size:.85rem;font-weight:700}.detail-block ul,.detail-block ol{color:var(--text-secondary,#4b5563);margin:0;padding-left:1.2rem;line-height:1.7}.detail-block li{margin-bottom:.5rem}.detail-block li::marker{color:var(--accent-color,#0070f3);font-weight:700}.action-buttons{flex-direction:column;gap:1rem;max-width:400px;margin:3rem auto 0;display:flex}@media (min-width:600px){.action-buttons{flex-direction:row;justify-content:center}}.reset-btn,.secondary-btn{cursor:pointer;border-radius:100px;flex:1;justify-content:center;align-items:center;padding:.8rem 2rem;font-size:1rem;font-weight:600;transition:all .2s;display:flex}.reset-btn{border:2px solid var(--text-secondary,#6b7280);color:var(--text-secondary,#6b7280);background:0 0}.reset-btn:hover{background:var(--text-secondary,#6b7280);color:#fff}.secondary-btn{border:2px solid var(--accent-color,#0070f3);color:var(--accent-color,#0070f3);background:0 0}.secondary-btn:hover{background:var(--accent-color,#0070f3);color:#fff}.animate-fade-in{animation:.6s ease-out forwards fadeIn}.animate-slide-up{opacity:0;animation:.6s cubic-bezier(.16,1,.3,1) forwards slideUp;transform:translateY(20px)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{to{opacity:1;transform:translateY(0)}}.image-modal-overlay{z-index:9999;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-sizing:border-box;background-color:#000000d9;justify-content:center;align-items:center;width:100vw;height:100vh;padding:0;animation:.3s ease-out forwards fadeIn;display:flex;position:fixed;top:0;left:0;overflow:auto}.image-modal-content{object-fit:contain;cursor:zoom-out;width:100%;height:100%;transition:transform .2s ease-out}.image-modal-controls{z-index:1001;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;border-radius:30px;align-items:center;gap:15px;padding:8px 16px;display:flex;position:absolute;top:20px;right:30px}.zoom-btn{color:#fff;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;font-size:1.5rem;font-weight:700;transition:background .2s;display:flex}.zoom-btn:hover{background:#fff3}.zoom-level{color:#fff;text-align:center;min-width:45px;font-size:.9rem;font-weight:500}.image-modal-close{color:#fff;cursor:pointer;background:0 0;border:none;border-left:1px solid #fff3;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;margin-left:10px;padding-left:25px;font-size:1.5rem;font-weight:300;transition:transform .2s;display:flex;position:absolute;top:20px;right:30px}.image-modal-close:hover{transform:scale(1.1)}
.page-module___8aEwW__main{min-height:100vh;font-family:var(--font-geist-sans),system-ui,sans-serif;background-color:var(--bg-default,#f9fafb);padding:2rem 1rem}.page-module___8aEwW__header{text-align:center;margin-bottom:3rem;padding-top:1rem}.page-module___8aEwW__header h1{letter-spacing:-.05em;background:linear-gradient(135deg,#0070f3 0%,#10b981 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0;font-size:3rem;font-weight:900}.page-module___8aEwW__header p{color:var(--text-secondary,#6b7280);margin-top:.5rem;font-size:1.1rem}.page-module___8aEwW__container{max-width:1000px;margin:0 auto;position:relative}.page-module___8aEwW__stepContainer{animation:.5s cubic-bezier(.16,1,.3,1) forwards page-module___8aEwW__slideIn}.page-module___8aEwW__detectedPreview{text-align:center;margin-bottom:2rem}.page-module___8aEwW__detectedPreview h3{color:var(--success-color,#10b981);margin:0 0 .5rem;font-size:1.5rem}.page-module___8aEwW__detectedPreview p{color:var(--text-secondary,#6b7280);margin:0}.page-module___8aEwW__ingredientsSection{background:var(--bg-surface,#fff);text-align:left;border-radius:24px;width:100%;max-width:500px;margin:3rem auto 0;padding:2rem;box-shadow:0 4px 20px #0000000d}.page-module___8aEwW__ingredientsSection h2{color:var(--text-primary,#111827);letter-spacing:-.02em;margin-bottom:1.5rem;font-size:1.5rem;font-weight:800}.page-module___8aEwW__ingredientsBadges{flex-wrap:wrap;gap:.8rem;display:flex}.page-module___8aEwW__ingredientBadge{background:var(--bg-secondary,#f3f4f6);color:var(--text-secondary,#4b5563);border:1px solid #0000000d;border-radius:100px;align-items:center;gap:.4rem;padding:.6rem 1.2rem;font-size:.95rem;display:flex}.page-module___8aEwW__ingredientBadge strong{color:var(--text-primary,#111827)}.page-module___8aEwW__errorBanner{color:#991b1b;background:#fee2e2;border-left:4px solid #ef4444;border-radius:8px;justify-content:space-between;align-items:center;max-width:500px;margin:0 auto 2rem;padding:1rem 1.5rem;animation:.3s ease-out forwards page-module___8aEwW__slideDown;display:flex}.page-module___8aEwW__errorBanner button{color:#991b1b;cursor:pointer;background:0 0;border:none;padding:0 .5rem;font-size:1.2rem}@keyframes page-module___8aEwW__slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes page-module___8aEwW__slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.page-module___8aEwW__headerContent{flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;width:100%;display:flex}.page-module___8aEwW__langToggle{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:20px;align-items:center;gap:.5rem;padding:.5rem 1rem;display:flex}.page-module___8aEwW__langToggle button{color:var(--text-secondary,#6b7280);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.2rem .5rem;font-size:.9rem;transition:all .2s}.page-module___8aEwW__langToggle button:hover{color:var(--text-primary,#111827)}.page-module___8aEwW__langToggle .page-module___8aEwW__activeLang{color:var(--primary-color,#0070f3);background:#ffffff4d;font-weight:600}.page-module___8aEwW__langDivider{color:var(--text-secondary,#6b7280);font-size:.8rem}
