*,*:before,*:after{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Noto Sans KR,Apple SD Gothic Neo,Malgun Gothic,Segoe UI,Tahoma,sans-serif;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%}button{font-family:inherit;cursor:pointer}input{font-family:inherit}:root{--orange: #ff6b35;--orange-lt: #ffb347;--orange-bg: #fff4ee;--orange-border: #ffd5b8;--white: #ffffff;--text: #2c2c2c;--text-muted: #888888;--green-bg: #f0fff4;--green-border: #c6f6d5;--green-text: #276749;--yellow-bg: #fffbeb;--yellow-border: #fde68a;--yellow-text: #92400e;--radius: 18px;--radius-sm: 10px;--shadow: 0 2px 16px rgba(255, 107, 53, .12)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Noto Sans KR,Apple SD Gothic Neo,Malgun Gothic,Segoe UI,sans-serif;background:var(--orange-bg);color:var(--text);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}.app{max-width:600px;margin:0 auto;min-height:100vh}.app-header{background:linear-gradient(135deg,var(--orange) 0%,var(--orange-lt) 100%);color:var(--white);position:sticky;top:0;z-index:100;box-shadow:0 4px 24px #ff6b3566}.header-inner{display:flex;justify-content:space-between;align-items:center;padding:.875rem 1.25rem}.logo{display:flex;align-items:center;gap:.625rem}.logo-icon{font-size:2.2rem;filter:drop-shadow(0 2px 6px rgba(0,0,0,.25))}.logo h1{font-size:1.2rem;font-weight:800;letter-spacing:-.5px;line-height:1.2}.logo p{font-size:.68rem;opacity:.88}.fav-header-btn{background:#ffffff38;border:1.5px solid rgba(255,255,255,.5);color:var(--white);border-radius:24px;padding:.4rem .875rem;font-size:.9rem;cursor:pointer;font-weight:700;display:flex;align-items:center;gap:.3rem;transition:background .2s}.fav-header-btn:hover{background:#ffffff59}.fav-count{background:var(--white);color:var(--orange);border-radius:50%;width:20px;height:20px;font-size:.65rem;display:flex;align-items:center;justify-content:center;font-weight:800}.app-main{padding:1rem 1rem 2.5rem;display:flex;flex-direction:column;gap:1rem}.api-warning{background:#fff3cd;border:1px solid #ffc107;border-radius:var(--radius-sm);padding:.75rem 1rem;font-size:.82rem;color:#664d03;line-height:1.5}.api-warning code{background:#00000014;border-radius:4px;padding:0 4px;font-family:monospace}.panel{background:var(--white);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow)}.panel h2{font-size:1.05rem;font-weight:800;margin-bottom:.2rem}.panel-subtitle{font-size:.78rem;color:var(--text-muted);margin-bottom:1rem}.quick-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.45rem;margin-bottom:1rem}@media(max-width:380px){.quick-grid{grid-template-columns:repeat(4,1fr)}}.quick-btn{display:flex;flex-direction:column;align-items:center;gap:.15rem;padding:.5rem .2rem;border:1.5px solid var(--orange-border);border-radius:var(--radius-sm);background:var(--orange-bg);cursor:pointer;transition:all .15s;color:var(--text);line-height:1.2}.quick-emoji{font-size:1.35rem}.quick-name{font-size:.63rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.quick-btn.selected{background:var(--orange);border-color:var(--orange);color:var(--white);transform:scale(1.06);box-shadow:0 2px 8px #ff6b3566}.quick-btn:hover:not(.selected){border-color:var(--orange);background:#ffe8d6}.ingredient-input-row{display:flex;gap:.5rem}.ingredient-input-row input{flex:1;border:1.5px solid var(--orange-border);border-radius:var(--radius-sm);padding:.6rem .875rem;font-size:.88rem;outline:none;transition:border-color .2s;background:var(--orange-bg);color:var(--text)}.ingredient-input-row input:focus{border-color:var(--orange);background:var(--white)}.ingredient-input-row input::placeholder{color:#bbb;font-size:.82rem}.ingredient-input-row button{background:var(--orange);color:var(--white);border:none;border-radius:var(--radius-sm);padding:.6rem 1.1rem;font-size:.88rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:background .2s}.ingredient-input-row button:hover:not(:disabled){background:#e55d28}.ingredient-input-row button:disabled{opacity:.45;cursor:not-allowed}.chips-section{border-top:1px solid var(--orange-border);padding-top:.75rem;margin-top:.5rem}.chips-label{font-size:.73rem;color:var(--text-muted);font-weight:600;margin-bottom:.5rem}.chips{display:flex;flex-wrap:wrap;gap:.4rem}.chip{display:flex;align-items:center;gap:.25rem;background:#fff0e6;border:1.5px solid var(--orange);color:var(--orange);border-radius:20px;padding:.2rem .6rem;font-size:.8rem;font-weight:600}.chip button{background:none;border:none;cursor:pointer;color:var(--orange);font-size:1.05rem;line-height:1;padding:0;opacity:.65;transition:opacity .15s;display:flex;align-items:center}.chip button:hover{opacity:1}.constraints-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.6rem}.constraint-btn{display:flex;flex-direction:column;align-items:center;gap:.15rem;padding:.875rem .5rem;border:1.5px solid var(--orange-border);border-radius:var(--radius-sm);background:var(--orange-bg);cursor:pointer;transition:all .15s;text-align:center}.c-emoji{font-size:1.7rem}.c-label{font-size:.8rem;font-weight:700;color:var(--text)}.c-desc{font-size:.65rem;color:var(--text-muted)}.constraint-btn.active{background:var(--orange);border-color:var(--orange);box-shadow:0 2px 10px #ff6b3559}.constraint-btn.active .c-label,.constraint-btn.active .c-desc{color:var(--white)}.constraint-btn:hover:not(.active){border-color:var(--orange);background:#ffe8d6}.error-msg{background:#ffe5e5;border:1px solid #ff9999;border-radius:var(--radius-sm);padding:.75rem 1rem;font-size:.85rem;color:#c00;text-align:center}.generate-btn{background:linear-gradient(135deg,var(--orange) 0%,var(--orange-lt) 100%);color:var(--white);border:none;border-radius:50px;padding:1.05rem;font-size:1.15rem;font-weight:800;cursor:pointer;width:100%;letter-spacing:-.3px;box-shadow:0 6px 22px #ff6b3580;transition:transform .2s,box-shadow .2s}.generate-btn:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 10px 28px #ff6b3599}.generate-btn:active:not(:disabled){transform:translateY(0)}.generate-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.loading-card{background:var(--white);border-radius:var(--radius);padding:3rem 2rem;text-align:center;box-shadow:var(--shadow);display:flex;flex-direction:column;align-items:center;gap:.5rem}.loading-pan{font-size:3.5rem;animation:pan-tilt 1.2s ease-in-out infinite;display:inline-block}@keyframes pan-tilt{0%,to{transform:rotate(-12deg)}50%{transform:rotate(12deg)}}.loading-msg{font-size:1rem;font-weight:700;color:var(--text);margin-top:.75rem;min-height:1.5em}.loading-sub{font-size:.82rem;color:var(--text-muted);margin-bottom:.75rem}.dots{display:flex;gap:.4rem}.dots span{width:8px;height:8px;background:var(--orange);border-radius:50%;animation:dot-bounce 1.4s ease-in-out infinite}.dots span:nth-child(2){animation-delay:.2s}.dots span:nth-child(3){animation-delay:.4s}@keyframes dot-bounce{0%,80%,to{transform:scale(.6);opacity:.5}40%{transform:scale(1);opacity:1}}.recipe-card{display:flex;flex-direction:column;gap:1rem;animation:slide-up .35s ease-out}@keyframes slide-up{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.back-btn{background:var(--white);border:1.5px solid var(--orange-border);border-radius:20px;padding:.4rem 1rem;font-size:.82rem;color:var(--text-muted);cursor:pointer;align-self:flex-start;transition:all .2s;font-weight:600}.back-btn:hover{border-color:var(--orange);color:var(--orange)}.recipe-header-card{background:linear-gradient(135deg,var(--orange) 0%,var(--orange-lt) 100%);border-radius:var(--radius);padding:1.75rem 1.25rem 1.25rem;text-align:center;color:var(--white);box-shadow:0 6px 24px #ff6b3566}.recipe-emoji-big{font-size:4rem;filter:drop-shadow(0 4px 10px rgba(0,0,0,.25));line-height:1;margin-bottom:.5rem}.recipe-title{font-size:1.5rem;font-weight:800;letter-spacing:-.5px;margin-bottom:.75rem}.recipe-badges{display:flex;justify-content:center;gap:.5rem;margin-bottom:.875rem;flex-wrap:wrap}.badge-pill{background:#ffffff40;border-radius:20px;padding:.25rem .75rem;font-size:.78rem;font-weight:600}.used-ingredients{display:flex;flex-wrap:wrap;justify-content:center;gap:.3rem}.ing-tag{background:#fff3;border:1px solid rgba(255,255,255,.4);border-radius:12px;padding:.15rem .5rem;font-size:.72rem}.recipe-section{background:var(--white);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow)}.recipe-section h3{font-size:.95rem;font-weight:700;margin-bottom:.875rem;color:var(--text)}.steps-list{list-style:none;display:flex;flex-direction:column;gap:.875rem}.step-item{display:flex;gap:.75rem;align-items:flex-start}.step-num{background:var(--orange);color:var(--white);border-radius:50%;min-width:26px;height:26px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:800;margin-top:.1rem;box-shadow:0 2px 6px #ff6b3566}.step-item p{font-size:.9rem;line-height:1.65;color:var(--text);flex:1}.ingr-section{background:#f0f4ff;border:1px solid #c7d4ff}.ingr-section h3{color:#2d45a8}.ingr-list{list-style:none;display:flex;flex-direction:column;gap:.5rem}.ingr-item{display:flex;align-items:center;gap:.6rem;font-size:.9rem;color:var(--text);line-height:1.5}.ingr-dot{min-width:7px;height:7px;border-radius:50%;background:#4a6cf7}.dish-section{background:var(--green-bg);border:1px solid var(--green-border)}.dish-section h3{color:var(--green-text)}.dish-chips{display:flex;flex-wrap:wrap;gap:.4rem}.dish-chip{background:var(--green-border);color:var(--green-text);border-radius:20px;padding:.25rem .75rem;font-size:.8rem;font-weight:600}.tips-section{background:var(--yellow-bg);border:1px solid var(--yellow-border)}.tips-section h3{color:var(--yellow-text)}.tips-text{font-size:.9rem;color:#78350f;line-height:1.7}.fav-toggle-btn{border:2px solid var(--orange);border-radius:50px;padding:.9rem;font-size:1rem;font-weight:800;cursor:pointer;width:100%;background:var(--white);color:var(--orange);transition:all .2s;box-shadow:0 2px 12px #ff6b3526}.fav-toggle-btn.saved{background:var(--orange);color:var(--white);box-shadow:0 4px 16px #ff6b3573}.fav-toggle-btn:hover{transform:translateY(-2px)}.favorites-drawer{display:flex;flex-direction:column;gap:1rem;animation:slide-up .3s ease-out}.fav-header{display:flex;justify-content:space-between;align-items:center;background:var(--white);border-radius:var(--radius);padding:1rem 1.25rem;box-shadow:var(--shadow)}.fav-header h2{font-size:1.05rem;font-weight:800}.close-btn{background:none;border:none;font-size:1.2rem;cursor:pointer;color:var(--text-muted);padding:.2rem;line-height:1;transition:color .15s}.close-btn:hover{color:var(--text)}.fav-empty{background:var(--white);border-radius:var(--radius);padding:3rem 1.25rem;text-align:center;box-shadow:var(--shadow)}.fav-empty-emoji{font-size:2.5rem;margin-bottom:.5rem}.fav-empty-title{font-size:1rem;font-weight:700;margin-bottom:.3rem}.fav-empty-sub{font-size:.82rem;color:var(--text-muted)}.fav-list{display:flex;flex-direction:column;gap:.6rem}.fav-item{background:var(--white);border-radius:var(--radius-sm);padding:.875rem 1rem;box-shadow:var(--shadow);display:flex;align-items:center;gap:.5rem;transition:transform .15s}.fav-item:hover{transform:translate(3px)}.fav-item-main{flex:1;display:flex;align-items:center;gap:.75rem;background:none;border:none;cursor:pointer;text-align:left}.fav-item-emoji{font-size:2rem}.fav-item-info{flex:1}.fav-item-name{font-size:.95rem;font-weight:700;color:var(--text);margin-bottom:.2rem}.fav-item-meta{font-size:.75rem;color:var(--text-muted)}.fav-delete-btn{background:none;border:none;cursor:pointer;font-size:1.1rem;padding:.25rem;opacity:.5;transition:opacity .15s}.fav-delete-btn:hover{opacity:1}.main-nav{display:flex;gap:.5rem;align-items:center}.nav-btn{background:transparent;border:none;color:#ffffffb3;font-size:.9rem;font-weight:700;cursor:pointer;padding:.4rem .6rem;transition:color .2s,background .2s;border-radius:20px}.nav-btn:hover{color:var(--white);background:#ffffff1a}.nav-btn.active{color:var(--white);background:#ffffff38}.fav-header-btn.active{background:var(--white);color:var(--orange)}.fav-header-btn.active .fav-count{background:var(--orange);color:var(--white)}.app-footer{margin-top:auto;padding:1.5rem 1rem;text-align:center;border-top:1px solid var(--orange-border);background:var(--orange-bg)}.footer-inner{display:flex;flex-direction:column;gap:.4rem;align-items:center}.app-footer p{font-size:.75rem;color:var(--text-muted)}.footer-link{background:none;border:none;color:var(--orange);font-size:.75rem;text-decoration:underline;cursor:pointer;opacity:.8;transition:opacity .2s}.footer-link:hover{opacity:1}.cooking-tips-container{background:var(--white);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow);animation:slide-up .3s ease-out}.cooking-tips-container h2{font-size:1.2rem;font-weight:800;margin-bottom:.5rem;color:var(--orange);text-align:center}.tips-intro{font-size:.9rem;color:var(--text-muted);text-align:center;margin-bottom:1.5rem;line-height:1.5}.tips-grid{display:flex;flex-direction:column;gap:1.25rem}.tip-card{background:var(--orange-bg);border:1px solid var(--orange-border);border-radius:var(--radius-sm);padding:1.25rem}.tip-card h3{font-size:1rem;font-weight:700;margin-bottom:.75rem;color:var(--text);display:flex;align-items:center;gap:.4rem}.tip-card ul{list-style:none;display:flex;flex-direction:column;gap:.5rem}.tip-card li{font-size:.88rem;color:var(--text);line-height:1.6;position:relative;padding-left:1rem}.tip-card li:before{content:"•";color:var(--orange);position:absolute;left:0;top:-1px;font-weight:700}.policy-container{background:var(--white);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow);animation:slide-up .3s ease-out}.policy-container h2{font-size:1.15rem;font-weight:800;margin-bottom:.5rem;color:var(--text);text-align:center}.policy-intro{font-size:.85rem;color:var(--text-muted);text-align:center;margin-bottom:1.5rem}.policy-section{margin-bottom:1.25rem}.policy-section h3{font-size:.95rem;font-weight:700;margin-bottom:.4rem;color:var(--text)}.policy-section p{font-size:.85rem;color:#555;line-height:1.6;background:#f9f9f9;padding:.875rem;border-radius:var(--radius-sm)}.contact-container{background:var(--white);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow);animation:slide-up .3s ease-out}.contact-header{text-align:center;margin-bottom:1.5rem}.contact-header h2{font-size:1.2rem;font-weight:800;color:var(--orange);margin-bottom:.5rem}.contact-header p{font-size:.85rem;color:var(--text-muted);line-height:1.5}.contact-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{font-size:.85rem;font-weight:700;color:var(--text)}.form-group input,.form-group textarea{border:1.5px solid var(--orange-border);border-radius:var(--radius-sm);padding:.75rem;font-size:.9rem;font-family:inherit;outline:none;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus{border-color:var(--orange)}.submit-btn{background:var(--orange);color:var(--white);border:none;border-radius:var(--radius-sm);padding:.875rem;font-size:1rem;font-weight:800;cursor:pointer;transition:background .2s,transform .1s}.submit-btn:hover:not(:disabled){background:#e55d28}.submit-btn:active:not(:disabled){transform:scale(.98)}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.contact-success{text-align:center;padding:2rem 0}.success-icon{font-size:3rem;margin-bottom:1rem}.contact-success h3{font-size:1.15rem;font-weight:800;margin-bottom:.5rem}.contact-success p{font-size:.9rem;color:var(--text-muted);margin-bottom:1.5rem}.back-home-btn{background:var(--orange-bg);color:var(--orange);border:1.5px solid var(--orange-border);padding:.6rem 1.2rem;border-radius:20px;font-weight:700;cursor:pointer}.form-error{color:#d32f2f;font-size:.85rem;text-align:center;margin:0}.choice-container{display:flex;flex-direction:column;gap:1.5rem;padding:.5rem 0}.animate-fade-in{animation:fadeIn .4s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.choice-back-btn{align-self:flex-start;background:#fff9;border:1px solid var(--orange-border);padding:.5rem 1rem;border-radius:20px;font-size:.85rem;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.4rem}.choice-back-btn:hover{background:var(--white);color:var(--orange);border-color:var(--orange);transform:translate(-2px)}.choice-header{text-align:center;margin-bottom:.5rem}.choice-subtitle{font-size:.85rem;color:var(--orange);font-weight:700;margin-bottom:.3rem;letter-spacing:.5px}.choice-title{font-size:1.5rem;font-weight:800;color:var(--text);letter-spacing:-.5px}.choice-cards-wrapper{position:relative;display:flex;flex-direction:column;gap:1.5rem}.vs-badge{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--text);color:var(--white);width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1rem;z-index:10;box-shadow:0 4px 12px #00000026;border:4px solid var(--orange-bg)}.modern-choice-card{position:relative;background:var(--white);border-radius:24px;padding:1.5rem;cursor:pointer;overflow:hidden;box-shadow:0 4px 16px #0000000f;transition:all .3s cubic-bezier(.175,.885,.32,1.275);border:2px solid transparent}.modern-choice-card:hover{transform:translateY(-5px) scale(1.02);box-shadow:0 12px 32px #ff6b3526;border-color:#ff6b354d}.card-bg-glow{position:absolute;top:-50%;right:-20%;width:150px;height:150px;border-radius:50%;filter:blur(40px);opacity:.15;z-index:0;transition:opacity .3s}.modern-choice-card:hover .card-bg-glow{opacity:.3}.variant-1 .card-bg-glow{background:#ff6b35}.variant-2 .card-bg-glow{background:#4caf50}.card-content{position:relative;z-index:1;display:flex;flex-direction:column;gap:1rem}.card-top{display:flex;justify-content:space-between;align-items:flex-start}.emoji-container{width:64px;height:64px;background:#00000008;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:2.5rem;box-shadow:inset 0 2px 4px #00000005}.meta-badges{display:flex;flex-direction:column;gap:.4rem;align-items:flex-end}.meta-badge{font-size:.75rem;font-weight:700;padding:.3rem .6rem;border-radius:12px}.meta-badge.time{background:#fff3e0;color:#e65100}.meta-badge.ingr{background:#e8f5e9;color:#2e7d32}.card-text{display:flex;flex-direction:column;gap:.4rem}.recipe-name{font-size:1.25rem;font-weight:800;color:var(--text);line-height:1.3}.recipe-desc{font-size:.85rem;color:var(--text-muted);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.ingredients-preview{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.2rem}.ing-chip{background:#f5f5f5;color:#555;font-size:.75rem;padding:.25rem .6rem;border-radius:8px;font-weight:600}.ing-chip.more{background:#00000014}.select-btn{margin-top:.5rem;background:var(--orange-bg);color:var(--orange);border:1.5px solid var(--orange-border);padding:.85rem;border-radius:14px;font-size:.95rem;font-weight:800;cursor:pointer;transition:all .2s}.modern-choice-card:hover .select-btn{background:var(--orange);color:var(--white);border-color:var(--orange)}@media(min-width:480px){.choice-cards-wrapper{flex-direction:row;align-items:stretch}.modern-choice-card{flex:1;display:flex;flex-direction:column}.card-content{flex:1}.select-btn{margin-top:auto}}
