:root{--bg:#f8f3ea;--bg-warm:#f4ece0;--surface:#fff;--card:#fff;--card-hover:#fefdfb;--border:#dfd3c1;--border-subtle:#eae1d3;--primary:#b85a32;--primary-hover:#9e4c28;--primary-dim:#b85a3214;--primary-glow:#b85a3233;--olive:#6b7f52;--olive-dim:#6b7f5214;--gold:#96804a;--gold-dim:#96804a0f;--text:#2c2114;--text-muted:#6d5f4e;--text-dim:#b0a08a;--success:#527a42;--success-bg:#527a4212;--danger:#b84a3a;--danger-bg:#b84a3a12;--info:#4a7a8f;--info-bg:#4a7a8f0f;--radius:8px;--radius-lg:14px;--transition:.2s ease;--shadow:0 4px 24px #2c211412;--shadow-sm:0 2px 10px #2c21140a;--shadow-lg:0 12px 48px #2c21141a}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}::selection{color:var(--text);background:#b85a3224}body{background:linear-gradient(180deg, #faf6ee 0%, var(--bg-warm) 100%);color:var(--text);-webkit-font-smoothing:antialiased;background-attachment:fixed;min-height:100vh;font-family:Karla,system-ui,sans-serif;font-weight:400;line-height:1.65}body:after{content:"";pointer-events:none;z-index:9999;background:radial-gradient(at 50% 0,#0000 55%,#b49b780b 100%);position:fixed;inset:0}::-webkit-scrollbar{width:7px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}h1,h2,h3{letter-spacing:-.01em;color:var(--text);font-family:Cormorant Garamond,Georgia,serif;line-height:1.2}h1{font-size:2.75rem;font-weight:600}h2{font-size:2.2rem;font-weight:600}h3{font-size:1.5rem;font-weight:600}a{color:var(--primary);transition:color var(--transition);text-decoration:none}a:hover{color:var(--primary-hover)}.app{flex-direction:column;min-height:100vh;display:flex}.container{flex:1;max-width:860px;margin:0 auto;padding:2.5rem 1.5rem}.navbar{z-index:100;-webkit-backdrop-filter:blur(18px);border-bottom:1px solid var(--border);background:#faf6eee0;justify-content:space-between;align-items:center;height:64px;padding:0 2rem;display:flex;position:sticky;top:0}.nav-brand{color:var(--text);letter-spacing:.04em;transition:opacity var(--transition);font-family:Cormorant Garamond,serif;font-size:1.35rem;font-weight:700;text-decoration:none}.nav-brand:hover{opacity:.75;color:var(--text)}.nav-brand em{color:var(--primary);font-style:italic}.nav-links{align-items:center;gap:1.75rem;display:flex}.nav-links a{color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;transition:color var(--transition);font-size:.775rem;font-weight:600;position:relative}.nav-links a:after{content:"";background:var(--primary);transform-origin:100%;height:1.5px;transition:transform .25s;position:absolute;bottom:-4px;left:0;right:0;transform:scaleX(0)}.nav-links a:hover{color:var(--text)}.nav-links a:hover:after{transform-origin:0;transform:scaleX(1)}.btn-link{color:var(--text-dim);cursor:pointer;letter-spacing:.1em;text-transform:uppercase;transition:color var(--transition);background:0 0;border:none;padding:0;font-family:Karla,sans-serif;font-size:.775rem;font-weight:600}.btn-link:hover{color:var(--danger)}.nav-toggle{cursor:pointer;background:0 0;border:none;flex-direction:column;justify-content:center;gap:4px;width:40px;height:40px;padding:.5rem;display:none}.nav-toggle span{background:var(--text);border-radius:1px;width:22px;height:2px;transition:transform .25s,opacity .2s;display:block}.nav-toggle.open span:first-child{transform:translateY(6px)rotate(45deg)}.nav-toggle.open span:nth-child(2){opacity:0}.nav-toggle.open span:nth-child(3){transform:translateY(-6px)rotate(-45deg)}.page{animation:.4s both fadeUp}.page-header{border-bottom:none;margin-bottom:2.5rem;padding-bottom:2rem;position:relative}.page-header:after{content:"";background:linear-gradient(90deg, var(--primary), var(--gold));border-radius:2px;width:60px;height:3px;position:absolute;bottom:0;left:0}.page-header h2{margin-bottom:.4rem}.page-header .subtitle,.subtitle{color:var(--text-muted);margin-bottom:0;font-size:.95rem}.page>h2{margin-bottom:.3rem}.page>.subtitle{margin-bottom:2rem}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.form-section{border-bottom:1px solid var(--border-subtle);margin-bottom:2.25rem;padding-bottom:2.25rem}.form-section:last-of-type{border-bottom:none;margin-bottom:0}.section-label{letter-spacing:.18em;text-transform:uppercase;color:var(--text-dim);margin-bottom:1.1rem;font-size:.68rem;font-weight:700}.form-group{margin-bottom:1.2rem}.form-group>label{letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.5rem;font-size:.72rem;font-weight:700;display:block}.form-group input[type=text],.form-group input[type=password],.form-group input[type=number],.form-group select{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);transition:border-color var(--transition), box-shadow var(--transition);appearance:none;padding:.75rem 1rem;font-family:Karla,sans-serif;font-size:.95rem}.form-group input:focus,.form-group select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-dim);outline:none}.form-group input::placeholder{color:var(--text-dim)}.form-group select{cursor:pointer;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 d='M1 1l5 5 5-5' stroke='%236d5f4e' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right 1rem center;background-repeat:no-repeat;padding-right:2.5rem}.form-group select option{background:var(--surface);color:var(--text)}.form-row{gap:1rem;display:flex}.form-row .form-group{flex:1}.btn{border-radius:var(--radius);letter-spacing:.04em;cursor:pointer;transition:all var(--transition);white-space:nowrap;border:none;justify-content:center;align-items:center;gap:.45rem;padding:.7rem 1.4rem;font-family:Karla,sans-serif;font-size:.85rem;font-weight:700;display:inline-flex}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover);box-shadow:0 4px 16px var(--primary-glow);transform:translateY(-1px)}.btn-primary:active:not(:disabled){box-shadow:none;transform:translateY(0)}.btn-secondary{background:var(--surface);color:var(--text-muted);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg);color:var(--text);border-color:var(--text-dim)}.btn-danger{color:var(--danger);background:0 0;border:1px solid #b84a3a4d}.btn-danger:hover:not(:disabled){background:var(--danger-bg);border-color:var(--danger)}.btn-large{letter-spacing:.1em;text-transform:uppercase;padding:.9rem 2.75rem;font-size:.9rem}.auth-page{max-width:420px;margin:4rem auto;animation:.45s both fadeUp}.auth-brand{text-align:center;margin-bottom:2.5rem}.auth-brand h1{color:var(--text);letter-spacing:.03em;margin-bottom:.35rem;font-size:2.4rem}.auth-brand h1 em{color:var(--primary);font-style:italic}.auth-brand p{color:var(--text-dim);letter-spacing:.22em;text-transform:uppercase;font-size:.72rem}.auth-divider{align-items:center;gap:1rem;margin-bottom:2rem;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);flex:1;height:1px}.auth-divider span{color:var(--primary);letter-spacing:.4em;font-size:.8rem}.auth-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:2.5rem 2.75rem}.auth-card h2{color:var(--text);margin-bottom:1.75rem;font-size:1.6rem}.auth-link{text-align:center;color:var(--text-dim);margin-top:1.5rem;font-size:.875rem}.auth-link a{color:var(--primary);font-weight:600}.auth-link a:hover{color:var(--primary-hover)}.tags{flex-wrap:wrap;gap:.45rem;margin-top:.65rem;display:flex}.tag{background:var(--bg);border:1px solid var(--border);color:var(--text-muted);border-radius:20px;align-items:center;gap:.35rem;padding:.3rem .8rem;font-size:.8rem;display:inline-flex}.tag button{cursor:pointer;color:var(--text-dim);transition:color var(--transition);background:0 0;border:none;align-items:center;padding:0;font-size:1rem;line-height:1;display:flex}.tag button:hover{color:var(--danger)}.tag-ingredient{color:var(--olive);background:#6b7f5214;border-color:#6b7f5238;padding:0;transition:background-color .18s,border-color .18s}.tag-ingredient .tag-trigger{cursor:pointer;color:inherit;font:inherit;transition:background-color var(--transition);background:0 0;border:none;border-radius:20px;padding:.45rem .95rem}.tag-ingredient .tag-trigger:hover{color:inherit;background:#6b7f5224}.modal-overlay{z-index:1000;background:#2c21148c;justify-content:center;align-items:center;padding:1.25rem;animation:.18s both fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:420px;box-shadow:var(--shadow-lg);padding:2rem 2rem 1.5rem;animation:.22s cubic-bezier(.2,.85,.4,1) both modalIn}@keyframes modalIn{0%{opacity:0;transform:translateY(20px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-title{margin-bottom:.65rem;font-size:1.45rem}.modal-body{color:var(--text-muted);margin-bottom:1.75rem;font-size:.95rem;line-height:1.55}.modal-body strong{color:var(--text);font-weight:700}.modal-actions{justify-content:flex-end;gap:.75rem;display:flex}.modal-actions .btn{min-width:110px}@media (width<=480px){.modal{padding:1.5rem 1.4rem 1.25rem}.modal-title{font-size:1.25rem}.modal-actions{flex-direction:column-reverse;gap:.6rem}.modal-actions .btn{width:100%}}.tag-ingredient.tag-removable{gap:.45rem;padding:.3rem .55rem .3rem .85rem}.tag-ingredient.tag-removable .tag-label{font-size:.82rem}.tag-ingredient.tag-removable>button{cursor:pointer;color:var(--text-dim);transition:color var(--transition), background-color var(--transition);background:0 0;border:none;border-radius:50%;padding:.15rem .35rem;font-size:1.1rem;line-height:1}.tag-ingredient.tag-removable>button:hover{color:var(--danger);background:var(--danger-bg)}.section-hint{color:var(--text-muted);margin-top:-.5rem;margin-bottom:1rem;font-size:.85rem;line-height:1.5}.chip-input-row{align-items:stretch;gap:.5rem;display:flex}.chip-input-row input{flex:1;min-width:0}.chip-add-btn{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:44px;color:var(--primary);cursor:pointer;transition:background-color var(--transition), border-color var(--transition), color var(--transition);flex-shrink:0;font-family:Karla,sans-serif;font-size:1.45rem;font-weight:600;line-height:1}.chip-add-btn:hover{background:var(--primary-dim);border-color:var(--primary);color:var(--primary-hover)}.chip-add-btn:active{transform:translateY(1px)}.ingredient-group{margin-bottom:1.75rem}.ingredient-group:last-of-type{margin-bottom:0}.ingredient-group-label{letter-spacing:.16em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.65rem;font-family:Karla,sans-serif;font-size:.7rem;font-weight:700}.ingredient-group .tags{margin-top:0}.ingredient-form{gap:.75rem;margin-bottom:2rem;display:flex}.ingredient-form input{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);transition:border-color var(--transition), box-shadow var(--transition);flex:1;padding:.75rem 1rem;font-family:Karla,sans-serif;font-size:.95rem}.ingredient-form input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-dim);outline:none}.ingredient-form input::placeholder{color:var(--text-dim)}.ingredient-input-wrapper{flex:1;position:relative}.ingredient-input-wrapper input{width:100%}.ingredient-suggestions{z-index:10;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);max-height:320px;margin:0;padding:.25rem 0;list-style:none;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto}.ingredient-suggestions li{margin:0}.ingredient-suggestions button{text-align:left;width:100%;color:var(--text);cursor:pointer;transition:background-color var(--transition);background:0 0;border:none;padding:.55rem 1rem;font-family:Karla,sans-serif;font-size:.95rem}.ingredient-suggestions button:hover,.ingredient-suggestions button:focus{background:var(--olive-dim);outline:none}.count{color:var(--text-dim);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.75rem;font-size:.72rem}.empty{color:var(--text-dim);text-align:center;padding:3rem 0;font-size:.95rem;font-style:italic}.radio-group,.checkbox-group{flex-wrap:wrap;gap:.5rem;display:flex}.radio-btn,.checkbox-btn{background:var(--surface);border:1px solid var(--border);cursor:pointer;color:var(--text-muted);transition:all var(--transition);-webkit-user-select:none;user-select:none;border-radius:20px;align-items:center;padding:.45rem 1.05rem;font-size:.82rem;font-weight:500;display:inline-flex}.radio-btn input,.checkbox-btn input{display:none}.radio-btn:hover,.checkbox-btn:hover{border-color:var(--primary);color:var(--text)}.radio-btn.active,.checkbox-btn.active{background:var(--primary-dim);border-color:var(--primary);color:var(--primary);font-weight:700}.qty-control{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:0;display:inline-flex;overflow:hidden}.qty-control button{color:var(--text-muted);cursor:pointer;width:42px;height:40px;transition:all var(--transition);background:0 0;border:none;justify-content:center;align-items:center;font-family:Karla,sans-serif;font-size:1.2rem;display:flex}.qty-control button:hover{background:var(--bg);color:var(--primary)}.qty-control span{color:var(--text);text-align:center;border-left:1px solid var(--border);border-right:1px solid var(--border);min-width:48px;padding:0 1.25rem;font-size:1.05rem;font-weight:700;line-height:40px}.generate-cta{border-top:1px solid var(--border-subtle);align-items:center;gap:1.5rem;margin-top:2.5rem;padding-top:2rem;display:flex}.recipe-list{flex-direction:column;gap:2rem;margin:2rem 0;display:flex}.recipe-list .recipe-card:nth-child(2){animation-delay:80ms}.recipe-list .recipe-card:nth-child(3){animation-delay:.16s}.recipe-list .recipe-card:nth-child(4){animation-delay:.24s}.recipe-list .recipe-card:nth-child(5){animation-delay:.32s}.recipe-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);animation:.4s both fadeUp;overflow:hidden}.recipe-card:hover{box-shadow:var(--shadow-lg);border-color:#b85a3226;transform:translateY(-3px)}.recipe-card-accent{background:linear-gradient(90deg, var(--primary) 0%, var(--gold) 50%, var(--olive) 100%);height:3px}.recipe-card-body{padding:2rem}.recipe-header{margin-bottom:1.25rem}.recipe-header h3{color:var(--text);margin-bottom:.65rem;font-size:1.65rem;line-height:1.25}.recipe-badges{flex-wrap:wrap;gap:.4rem;display:flex}.badge{background:var(--bg);border:1px solid var(--border);letter-spacing:.07em;text-transform:uppercase;color:var(--text-muted);border-radius:12px;padding:.2rem .7rem;font-size:.7rem;font-weight:700;display:inline-block}.recipe-meta{color:var(--text-dim);border-bottom:1px solid var(--border-subtle);flex-wrap:wrap;gap:1.5rem;margin-bottom:1.5rem;padding-bottom:1.5rem;font-size:.83rem;display:flex}.recipe-section{margin-bottom:1.5rem}.recipe-section h4{letter-spacing:.18em;text-transform:uppercase;color:var(--primary);margin-bottom:.8rem;font-family:Karla,sans-serif;font-size:.68rem;font-weight:800}.recipe-section ul,.recipe-section ol{color:var(--text-muted);padding-left:1.3rem}.recipe-section li{margin-bottom:.4rem;font-size:.92rem;line-height:1.65}.recipe-section li::marker{color:var(--primary)}.recipe-nutrition{background:var(--bg);border:1px solid var(--border-subtle);border-radius:var(--radius);margin-bottom:1.5rem;padding:1.1rem 1.25rem}.recipe-nutrition h4{letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:.8rem;font-family:Karla,sans-serif;font-size:.68rem;font-weight:800}.nutrition-grid{color:var(--text-muted);grid-template-columns:1fr 1fr;gap:.35rem 1.5rem;font-size:.85rem;display:grid}.recipe-actions{border-top:1px solid var(--border-subtle);flex-wrap:wrap;gap:.5rem;padding-top:1.25rem;display:flex}.filter-bar{border-bottom:1px solid var(--border-subtle);gap:.5rem;margin-bottom:2rem;padding-bottom:1.75rem;display:flex}.error{color:var(--danger);margin:.5rem 0;font-size:.875rem}.success{color:var(--success);margin:.5rem 0;font-size:.875rem}.info-banner{background:var(--info-bg);border:1px solid #4a7a8f26;border-left:3px solid var(--info);color:#3a6a7a;border-radius:var(--radius);margin-bottom:1.75rem;padding:.9rem 1.1rem;font-size:.9rem;line-height:1.6}.tour-banner{padding:1.1rem 1.25rem}.tour-banner-meta{letter-spacing:.18em;text-transform:uppercase;color:var(--info);margin-bottom:.5rem;font-size:.65rem;font-weight:700}.tour-banner-body{color:var(--text);margin-bottom:1rem;font-size:.95rem}.tour-banner-actions{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.tour-banner-actions .btn{padding:.55rem 1.1rem;font-size:.82rem}.tour-skip{color:var(--text-dim);letter-spacing:.08em;font-size:.78rem}.tour-skip:hover{color:var(--text-muted)}@media (width<=480px){.tour-banner-actions{gap:.75rem}.tour-banner-actions .btn{width:100%}}.loading-state{color:var(--text-dim);letter-spacing:.12em;text-transform:uppercase;justify-content:center;align-items:center;padding:5rem 2rem;font-size:.85rem;display:flex}@media (width<=900px){h1{font-size:2.4rem}h2{font-size:1.95rem}h3{font-size:1.35rem}.container{padding:2rem 1.4rem}.recipe-card-body{padding:1.75rem}}@media (width<=640px){h1{font-size:2rem}h2{font-size:1.65rem}h3{font-size:1.25rem}.navbar{flex-wrap:wrap;height:56px;padding:0 1.1rem}.nav-brand{font-size:1.2rem}.nav-toggle{display:flex}.nav-links{background:var(--bg);border-bottom:1px solid var(--border);z-index:99;flex-direction:column;align-items:stretch;gap:0;max-height:0;padding:.5rem 0;transition:max-height .28s,padding .2s;position:absolute;top:56px;left:0;right:0;overflow:hidden;box-shadow:0 8px 24px #2c21141f}.nav-links.open{max-height:360px;padding:.75rem 0}.nav-links a,.nav-links .btn-link{text-align:left;padding:.85rem 1.5rem;font-size:.85rem}.nav-links a:after{display:none}.container{padding:1.5rem 1rem}.page-header{margin-bottom:1.75rem;padding-bottom:1.5rem}.page>.subtitle{margin-bottom:1.5rem}.form-row{flex-direction:column;gap:0}.form-section{margin-bottom:1.75rem;padding-bottom:1.75rem}.auth-page{margin:2rem auto;padding:0 1rem}.auth-card{padding:1.75rem 1.4rem}.auth-brand h1{font-size:2rem}.auth-brand{margin-bottom:1.75rem}.ingredient-form{flex-direction:column;gap:.6rem}.ingredient-form .btn{width:100%}.ingredient-suggestions{max-height:260px}.nutrition-grid{grid-template-columns:1fr}.recipe-card-body{padding:1.35rem}.recipe-header h3{font-size:1.4rem}.recipe-meta{gap:.85rem 1rem;font-size:.78rem}.filter-bar{flex-wrap:wrap;margin-bottom:1.5rem;padding-bottom:1.25rem}.filter-bar .btn{flex:auto;min-width:0}.generate-cta{flex-direction:column;align-items:stretch;gap:1rem}.generate-cta .btn{width:100%}.recipe-actions .btn{flex:auto}.qty-control{justify-content:space-between;width:100%}.qty-control button{width:56px}.radio-group,.checkbox-group{gap:.4rem}.radio-btn,.checkbox-btn{padding:.4rem .85rem;font-size:.78rem}.form-group input,.form-group select,.ingredient-form input{font-size:16px}}@media (width<=400px){h1{font-size:1.85rem}h2{font-size:1.5rem}.container{padding:1.25rem .85rem}.auth-card{padding:1.5rem 1.1rem}.recipe-card-body{padding:1.1rem}.nav-brand{font-size:1.1rem}}
