.search-box-container{width:100%;max-width:600px;margin:0 auto}.search-input-wrapper{position:relative;width:100%}.search-input{width:100%;padding:.875rem 1.25rem;font-size:1rem;border:1px solid var(--border-color);border-radius:24px;outline:none;transition:all .3s ease;background:#fff;box-shadow:0 1px 6px #2021241a}.search-input:hover{box-shadow:0 1px 6px #20212433}.search-input:focus{border-color:var(--primary-pink);box-shadow:0 2px 8px #ffc0cb4d}.search-input:disabled{opacity:.6;cursor:not-allowed}.autocomplete-dropdown{position:absolute;top:calc(100% + .5rem);left:0;right:0;background:#fff;border-radius:12px;box-shadow:0 4px 16px #00000026;overflow:hidden;z-index:1000;animation:dropdown-appear .2s ease}@keyframes dropdown-appear{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{padding:.875rem 1.25rem;cursor:pointer;transition:background-color .15s ease;border-bottom:1px solid var(--light-pink)}.dropdown-item:last-child{border-bottom:none}.dropdown-item:hover,.dropdown-item.selected{background-color:var(--light-pink)}.dropdown-item:active{background-color:var(--primary-pink);color:#fff}.lucky-button{padding:.875rem 2rem;font-size:1rem;font-weight:500;color:var(--text-color);background:#fff;border:1px solid var(--border-color);border-radius:24px;cursor:pointer;transition:all .3s ease;box-shadow:0 1px 6px #2021241a;margin-top:1.5rem}.lucky-button:hover:not(:disabled){box-shadow:0 2px 8px #ffc0cb4d;border-color:var(--primary-pink);background:var(--light-pink)}.lucky-button:active:not(:disabled){transform:translateY(1px);box-shadow:0 1px 4px #20212433}.lucky-button:disabled{opacity:.6;cursor:not-allowed}.meal-display{max-width:800px;margin:0 auto;padding:2rem;animation:fadeIn .5s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.meal-display.empty{display:flex;align-items:center;justify-content:center;min-height:400px}.empty-state{text-align:center;color:var(--text-light)}.empty-state h2{color:var(--primary-pink);font-size:2rem;margin-bottom:1rem}.empty-state p{font-size:1.1rem}.meal-header{text-align:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid var(--light-pink)}.meal-name{font-size:2.5rem;color:var(--primary-pink);margin-bottom:1rem;font-weight:700}.meal-meta{display:flex;justify-content:center;gap:2rem;font-size:1rem;color:var(--text-light)}.meal-image-container{margin:2rem 0;border-radius:16px;overflow:hidden;box-shadow:0 4px 16px #0000001a;position:relative}.meal-image{width:100%;height:auto;display:block}.download-image-btn{position:absolute;bottom:1rem;right:1rem;padding:.75rem 1.5rem;background:#ffb6c1f2;color:#fff;border:none;border-radius:24px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #0003;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.download-image-btn:hover{background:pink;transform:translateY(-2px);box-shadow:0 6px 16px #0000004d}.download-image-btn:active{transform:translateY(0);box-shadow:0 2px 8px #0003}.image-placeholder{margin:2rem 0;padding:3rem;background:linear-gradient(135deg,var(--light-pink) 0%,#fff 100%);border-radius:16px;border:2px dashed var(--primary-pink)}.placeholder-content{text-align:center;color:var(--text-light)}.placeholder-content span{font-size:3rem;display:block;margin-bottom:1rem}.placeholder-content p{font-size:1.1rem;margin-bottom:.5rem}.placeholder-content small{font-size:.9rem;color:var(--text-light)}.placeholder-content small.error-text{color:#c00;font-weight:500}.image-spinner{width:40px;height:40px;border:4px solid var(--light-pink);border-top:4px solid var(--primary-pink);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.image-loading-text{display:flex;align-items:center;justify-content:center;gap:.5rem}.meal-section{margin:2rem 0}.meal-section h2{font-size:1.75rem;color:var(--primary-pink);margin-bottom:1rem;font-weight:600}.ingredients-list{list-style:none;padding:0}.ingredients-list li{padding:.75rem 1rem;margin-bottom:.5rem;background:var(--bg-color);border-radius:8px;border-left:3px solid var(--primary-pink);transition:transform .2s ease}.ingredients-list li:hover{transform:translate(5px)}.ingredients-list li.wine-ingredient{background:linear-gradient(135deg,#ffd1dc,#fff);border-left-color:#c41e3a;font-weight:500}.preparation-steps{padding-left:1.5rem}.preparation-steps li{padding:1rem 0;line-height:1.6;border-bottom:1px solid var(--light-pink)}.preparation-steps li:last-child{border-bottom:none}.valentine-footer{text-align:center;margin-top:3rem;padding-top:2rem;border-top:2px solid var(--light-pink);color:var(--primary-pink);font-size:1.1rem;font-weight:500}@media(max-width:768px){.meal-display{padding:1rem}.meal-name{font-size:1.75rem}.meal-meta{flex-direction:column;gap:.5rem}}.drawer-toggle{position:fixed;left:0;top:60%;transform:translateY(-50%);background:var(--primary-pink);color:#fff;border:none;border-radius:0 8px 8px 0;padding:1rem .5rem;cursor:pointer;font-size:1.25rem;z-index:1001;transition:all .3s ease;box-shadow:2px 2px 8px #0003}@media(max-width:768px){.drawer-toggle{top:65%}}.drawer-toggle:hover{background:var(--secondary-pink);padding-right:.75rem}.drawer-toggle.open{left:300px}.meal-history{position:fixed;left:0;top:0;bottom:0;width:300px;background:#fff;border-right:1px solid var(--border-color);box-shadow:2px 0 8px #0000001a;transition:transform .3s ease;z-index:1000;display:flex;flex-direction:column}.meal-history.closed{transform:translate(-100%)}.history-header{padding:1.5rem;border-bottom:2px solid var(--light-pink);background:linear-gradient(135deg,var(--light-pink) 0%,white 100%)}.history-header h2{margin:0 0 .5rem;color:var(--primary-pink);font-size:1.5rem}.meal-count{font-size:.875rem;color:var(--text-light)}.history-list{flex:1;overflow-y:auto;padding:.5rem}.empty-history{padding:2rem 1rem;text-align:center;color:var(--text-light)}.empty-history p{margin-bottom:.5rem;font-weight:500}.empty-history small{font-size:.875rem}.history-item{padding:1rem;margin-bottom:.5rem;background:var(--bg-color);border-radius:8px;cursor:pointer;transition:all .2s ease;border-left:3px solid transparent}.history-item:hover{background:var(--light-pink);transform:translate(5px);border-left-color:var(--primary-pink)}.history-item.active{background:var(--light-pink);border-left-color:var(--primary-pink);box-shadow:0 2px 8px #ffc0cb4d}.history-date{font-size:.75rem;color:var(--text-light);margin-bottom:.25rem;text-transform:uppercase;letter-spacing:.5px}.history-ingredient{font-weight:600;color:var(--primary-pink);margin-bottom:.25rem;font-size:.95rem}.history-meal-name{font-size:.85rem;color:var(--text-color);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-list::-webkit-scrollbar{width:6px}.history-list::-webkit-scrollbar-track{background:var(--bg-color)}.history-list::-webkit-scrollbar-thumb{background:var(--primary-pink);border-radius:3px}.history-list::-webkit-scrollbar-thumb:hover{background:var(--secondary-pink)}@media(max-width:768px){.meal-history{width:250px}.drawer-toggle.open{left:250px}}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem}.spinner{width:50px;height:50px;border:4px solid var(--light-pink);border-top:4px solid var(--primary-pink);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-message{margin-top:1.5rem;color:var(--primary-pink);font-size:1rem;font-weight:500}:root{--primary-pink: #FFB6C1;--secondary-pink: #FFC0CB;--light-pink: #FFD1DC;--soft-pink: #FFE4E9;--bg-color: #FFF5F7;--bg-white: #FFFFFF;--text-color: #333333;--text-light: #666666;--border-color: #FADADD;--shadow-sm: 0 1px 3px rgba(255, 182, 193, .2);--shadow-md: 0 4px 6px rgba(255, 182, 193, .25);--shadow-lg: 0 10px 20px rgba(255, 182, 193, .3)}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-color);color:var(--text-color)}body:before{content:"💕";position:fixed;top:20px;right:20px;font-size:2rem;opacity:.3;z-index:-1;animation:float 3s ease-in-out infinite}body:after{content:"❤️";position:fixed;bottom:20px;left:20px;font-size:2rem;opacity:.3;z-index:-1;animation:float 4s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-color)}::-webkit-scrollbar-thumb{background:var(--primary-pink);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--secondary-pink)}#root{min-height:100vh;display:flex}.app{flex:1;display:flex;transition:margin-left .3s ease}.app.drawer-open{margin-left:300px}.main-content{flex:1;display:flex;flex-direction:column;min-height:100vh}.app-header{background:linear-gradient(135deg,var(--primary-pink) 0%,var(--secondary-pink) 100%);padding:2rem;text-align:center;box-shadow:var(--shadow-md)}.app-logo{height:200px;width:auto;max-width:100%;object-fit:contain;filter:drop-shadow(2px 2px 4px rgba(0,0,0,.3))}.app-title{margin:0;font-size:3rem;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.2);font-weight:700;letter-spacing:-1px}.app-subtitle{margin:1rem 0 0;font-size:2rem;color:#fff;opacity:.95;font-weight:500}.search-section{padding:3rem 2rem;text-align:center;background:#fff;box-shadow:var(--shadow-sm)}.search-wrapper{max-width:600px;margin:0 auto}.content-section{flex:1;padding:2rem;overflow-y:auto}.error-message{max-width:600px;margin:2rem auto;padding:1rem 1.5rem;background:#fee;border:1px solid #fcc;border-radius:8px;color:#c00;text-align:center}.error-message strong{display:block;margin-bottom:.5rem}.api-key-warning{max-width:600px;margin:2rem auto;padding:1.5rem;background:linear-gradient(135deg,var(--light-pink) 0%,white 100%);border:2px solid var(--primary-pink);border-radius:12px;text-align:center}.api-key-warning h3{margin:0 0 1rem;color:var(--primary-pink)}.api-key-warning ol{text-align:left;margin:1rem 0}.api-key-warning code{background:#fff;padding:.25rem .5rem;border-radius:4px;font-family:Courier New,monospace;color:var(--primary-pink)}@media(max-width:768px){.app.drawer-open{margin-left:0}.app-logo{height:140px}.app-title{font-size:2rem}.app-subtitle{font-size:1.5rem}.search-section{padding:2rem 1rem}.content-section{padding:1rem}}
