*{margin:0;padding:0;box-sizing:border-box}body{font-family:system-ui,-apple-system,sans-serif;line-height:1.5;color:#2c2c2a;background-color:#fdf6e3}a{color:inherit;text-decoration:none}.checkbox-grid label{font-size:.85rem;text-transform:capitalize;cursor:pointer}.checkbox-grid input{margin-right:.25rem}.page-header{font-size:1.5rem;font-weight:600;color:#2c2c2a;margin:0 0 1.5rem;padding-bottom:.75rem;border-bottom:2px solid #84994F}.app-layout{display:flex;padding:16px;gap:16px;height:calc(100vh - 5.5rem);overflow:hidden}.pantry-pane{flex:1;height:100%;border-radius:16px;border:1.5px solid #d4ddb8;padding:1rem;overflow-y:auto;background:#eaf3de}.content-pane{flex:3;height:100%;border-radius:16px;border:1.5px solid #d4ddb8;padding:1rem;overflow-y:auto;background:#f6fdf0}@media(max-width:960px){.app-layout{flex-direction:column;height:auto;min-height:calc(100vh - 5.5rem);overflow:visible;padding:12px;gap:12px}.pantry-pane{flex:none;height:auto;max-height:40vh}.content-pane{flex:none;height:auto;min-height:50vh}}.navbar{display:flex;justify-content:space-between;align-items:center;height:5rem;min-height:unset;padding:.75rem 2rem;font-size:1em;background-color:#3b6d11;gap:1rem;overflow:visible;position:relative}.navbar-brand{display:flex;align-items:center}.navbar a{text-decoration:none;color:#fdf6e3;transition:color .2s}.navbar-brand a{font-weight:700;white-space:nowrap;color:#fff;font-size:1.3em;text-decoration:none}.navbar-links{display:flex;align-items:center;gap:1.5rem;margin-left:auto;flex-shrink:0;font-size:1.1em}.navbar-links a:hover{color:#f4a7bb}.navbar-links a.active{color:#fff;font-weight:600}.brand-link{display:flex;align-items:center;gap:1rem;text-decoration:none;color:#fff}.navbar-logo{width:80px;height:80px;padding-top:12px;object-fit:contain}.brand-link span{font-weight:700;font-size:1.2em}.hamburger-btn{display:none;background:none;border:none;color:#fdf6e3;font-size:1.8rem;cursor:pointer;padding:.25rem .5rem;line-height:1}.hamburger-btn:hover{color:#f4a7bb}.navbar-menu{position:relative}.navbar-menu-trigger{background:none;border:none;font:inherit;color:#fdf6e3;cursor:pointer;padding:0}.navbar-menu-trigger:hover{color:#f4a7bb}.navbar-menu-dropdown{position:absolute;top:calc(100% + .5rem);right:0;min-width:10rem;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 4px 12px #00000014;display:flex;flex-direction:column;overflow:hidden;z-index:100}.navbar-menu-dropdown a,.navbar-menu-dropdown button{background:none;border:none;font:inherit;text-align:left;padding:.75rem 1rem;cursor:pointer;color:#2c2c2a;text-decoration:none}.navbar-menu-dropdown a:hover,.navbar-menu-dropdown button:hover{background:#eaf3de;color:#3b6d11}@media(max-width:960px){.navbar{padding:.75rem 1rem;height:auto;min-height:4rem}.navbar-logo{width:50px;height:50px;padding-top:4px}.brand-link span{font-size:1em}.hamburger-btn{display:block}.navbar-links{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background-color:#3b6d11;padding:.5rem 0;border-top:1px solid rgba(255,255,255,.1);margin-left:0;z-index:99}.navbar-links.navbar-links-open{display:flex}.navbar-links a,.navbar-menu-trigger{padding:1rem 1.5rem;font-size:1.05em;width:100%;text-align:left}.navbar-links a:hover,.navbar-menu-trigger:hover{background-color:#ffffff1a}.navbar-menu{width:100%}.navbar-menu-dropdown{position:static;width:100%;background:#00000026;border:none;border-radius:0;box-shadow:none}.navbar-menu-dropdown a,.navbar-menu-dropdown button{color:#fdf6e3;padding:.75rem 2.5rem}.navbar-menu-dropdown a:hover,.navbar-menu-dropdown button:hover{background:#ffffff1a;color:#fff}}.ingredient-input{width:100%;padding:8px 12px;box-sizing:border-box;border:1.5px solid #d4ddb8;border-radius:8px;font-size:.95rem;background:#fff;color:#2c2c2a}.ingredient-input:focus{outline:none;border-color:#84994f;box-shadow:0 0 0 3px #84994f26}.suggestions-list{display:flex;flex-direction:column;gap:2px;margin:4px 0}.suggestions-list button{text-align:left;padding:6px 10px;background:#fff;border:1px solid #d4ddb8;cursor:pointer;font-size:14px;color:#2c2c2a}.suggestions-list button:hover{background:#eaf3de;color:#3b6d11}.chip-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}.chip{display:inline-flex;align-items:center;gap:6px;font-size:14px;line-height:1;padding:8px 12px;min-height:32px;border:1.5px solid #84994F;border-radius:999px;background:#eaf3de;color:#3b6d11;cursor:pointer}.chip:hover{background:#84994f;border-color:#f4a7bb;color:#2c2c2a}.chip:active{transform:translateY(1px)}.chip:focus-visible{outline:2px solid #84994F;outline-offset:2px}.pantry-error{color:#d32f2f;font-size:13px;margin:4px 0}.pantry-hint{font-size:.85rem;color:#84994f;margin-bottom:8px}.pantry-header{margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid #84994F;text-align:center}.recipe-card{border-radius:16px;display:flex;flex-direction:column;cursor:pointer;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:transform .15s,box-shadow .15s;background:#fff}.recipe-card:hover{transform:translateY(-4px);box-shadow:0 6px 16px #00000026}.recipe-img{width:100%;height:200px;object-fit:cover}.recipe-title{font-size:.85rem;text-align:center;padding:8px;line-height:1.3}.recipe-filters{display:flex;gap:8px;margin-bottom:16px}.recipe-filters button,.recipe-search button{padding:8px 16px;border:1.5px solid #d4ddb8;border-radius:8px;background:#fff;cursor:pointer;font-size:.9rem;color:#2c2c2a;transition:background .15s}.recipe-filters button:hover:not(:disabled){background:#eaf3de;border-color:#84994f;color:#3b6d11}.recipe-filters .search-button{background:#84994f;color:#fff;border-color:#84994f}.recipe-filters .search-button:hover:not(:disabled){background:#3b6d11;border-color:#3b6d11;color:#fff}.search-button:disabled{opacity:.5;cursor:not-allowed}.recipe-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px}@media(max-width:960px){.recipe-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}}.recipes-error{color:#d32f2f;font-size:13px}.filter-panel{border:1.5px solid #d4ddb8;border-radius:12px;padding:16px;margin-bottom:16px;background:#fff}.filter-group{margin-bottom:12px}.filter-group p{font-weight:600;margin-bottom:6px;text-transform:capitalize;color:#3b6d11}.filter-actions{display:flex;justify-content:flex-end;gap:12px;padding-top:20px;margin-top:20px;border-top:1px solid #d4ddb8;width:100%}.clear-filters-btn{background:#fff;color:#2c2c2a;border:1.5px solid #d4ddb8;padding:8px 16px;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s}.clear-filters-btn:hover{background:#eaf3de;border-color:#84994f}.apply-filters-btn{background:#84994f;color:#fff;border:none;padding:8px 20px;border-radius:8px;cursor:pointer;font-weight:600;transition:background .2s}.apply-filters-btn:hover{background:#3b6d11;color:#fff}.recipe-search{display:flex;gap:8px;margin-bottom:12px;max-width:700px}@media(max-width:480px){.recipe-search{flex-direction:column}.recipe-search .search-button{width:100%}}.recipe-search-input{flex:1;padding:8px 12px;border:1px solid #d4ddb8;border-radius:8px;font-size:.95rem;transition:border-color .2s}.recipe-search-input:focus{outline:none;border-color:#84994f;box-shadow:0 0 0 3px #84994f26}.recipe-search-input:disabled{background:#f5f5f5}.recipe-search .search-button{background:#84994f;color:#fff;border-color:#84994f}.recipe-search .search-button:hover:not(:disabled){background:#3b6d11;border-color:#3b6d11;color:#fff}.checkbox-grid{display:flex;flex-wrap:wrap;gap:4px 16px}.checkbox-grid label{font-size:.85rem;text-transform:capitalize;cursor:pointer;color:#2c2c2a}.checkbox-grid input{margin-right:.25rem;accent-color:#84994F}.back-button{padding:8px 16px;border:1px solid #ccc;border-radius:8px;background:#fff;cursor:pointer;font-size:.9rem;margin-bottom:16px;transition:background .15s}.back-button:hover{background:#f0f0f0}.recipe-details-img{width:100%;max-height:400px;object-fit:cover;border-radius:12px}.recipe-details-title{font-size:1.6rem;margin:16px 0 8px}.recipe-footer{margin-top:40px;padding:20px 0 60px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:15px}.footer-divider{width:100%;border:0;border-top:1px solid #ddd;margin-bottom:20px}.favorite-btn-bottom{background-color:#a3b18a;color:#fff;border:none;padding:14px 30px;border-radius:30px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 10px #a3b18a4d}.favorite-btn-bottom.active{background-color:#588157;box-shadow:none}.favorite-btn-bottom:hover{transform:translateY(-2px);filter:brightness(1.05)}.recipe-meta{display:flex;flex-wrap:wrap;gap:16px;padding:12px 0;border-top:1px solid #eee;border-bottom:1px solid #eee;margin-bottom:24px}.ingredients-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:6px 24px;margin-bottom:32px}.step-text{font-size:.95rem;border-bottom:1px solid #eee}.recipe-meta-item{font-size:.9rem;color:#555}.recipe-meta-item strong{color:#213547}.ingredients-section h3,.steps-section h3{font-size:1.2rem;margin-bottom:12px}.ingredients-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:6px 24px;margin-bottom:12px}.ingredient-item{font-size:.9rem;padding:4px 0;border-bottom:1px solid #f0f0f0}.add-list-button{background:#2d6a4f!important;color:#fff!important;border-color:#2d6a4f!important;padding:8px 16px;border:1px solid;border-radius:8px;margin:12px 2px 24px;cursor:pointer;transition:background .15s;font-size:.9rem}.add-list-button:hover:not(disabled){background:#1b4332!important}.add-list-button:disabled{opacity:.5;cursor:not-allowed}.missing-tag{color:red;font-weight:700}.steps-section{margin-bottom:24px}.steps-section-name{font-weight:600;margin-bottom:8px;color:#555}.step-item{display:flex;gap:12px;margin-bottom:12px;line-height:1.5}.step-number{font-weight:700;color:#2d6a4f;min-width:24px}.step-text{font-size:.95rem}@media(max-width:960px){.recipe-details-img{max-height:250px}.recipe-details-title{font-size:1.4rem}.recipe-meta{flex-direction:column;gap:6px}.add-list-button{width:100%;padding:12px 16px;font-size:1rem}.favorite-btn-bottom{width:100%;max-width:300px}}.auth-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:#fdf6e3;padding:1rem}.card{background-color:#fff;width:90%;max-width:420px;margin:2rem auto;border-radius:16px;border:1.5px solid #d4ddb8;box-shadow:0 4px 20px #0000000f}.card-header{background-color:#84994f;text-align:center;padding:1.5rem;border-radius:14px 14px 0 0}.card-header h2{color:#fff;margin:0;font-size:1.4rem}.card-header p{color:#eaf3de;margin:6px 0 0;font-size:.9rem}.card-body{padding:2rem}.card-body label{font-size:.9rem;font-weight:600;color:#3b6d11}.card-body input{width:100%;padding:10px 12px;border:1.5px solid #d4ddb8;border-radius:8px;font-size:.95rem;background:#fff;box-sizing:border-box;margin-top:4px;transition:border-color .2s}.card-body input:focus{outline:none;border-color:#84994f;box-shadow:0 0 0 3px #84994f26}.card-body button{width:100%;padding:11px;background-color:#84994f;border:1.5px solid #84994F;border-radius:8px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;margin-top:.75rem;transition:background .2s}.card-body button:hover{background-color:#3b6d11;border-color:#3b6d11}.card-body p{font-size:.9rem;color:#5a3e00;margin-top:1rem;white-space:nowrap}.card-body a{color:#84994f;font-weight:600}.card-body a:hover{color:#3b6d11}.auth-logo-link{display:flex;justify-content:center;margin-bottom:.5rem}.auth-logo{width:100px;height:100px;object-fit:contain;cursor:pointer}@media(max-width:480px){.card{width:95%;margin:1rem auto}.card-body{padding:1.5rem}.card-body p{white-space:normal}}.account-page{max-width:800px}.account-msg{padding:2rem;color:#666}.account-section{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid #eee}.account-section:last-child{border-bottom:none}.account-section h3{font-size:1.1rem;margin-bottom:.5rem}.account-email{color:#555;font-size:.95rem}.account-section-hint{font-size:.85rem;color:#666;margin-bottom:1rem;font-style:italic}.preferences-group{margin-bottom:1.5rem}.preferences-group-label{font-weight:600;margin-bottom:.5rem;text-transform:capitalize}.save-preferences-btn{background:#84994f;color:#fff;border:1px solid #84994F;border-radius:8px;padding:10px 20px;font-size:.95rem;cursor:pointer;margin-top:1rem;transition:background .15s}.save-preferences-btn:hover:not(:disabled){background:#6b7c3f}.save-preferences-btn:disabled{opacity:.6;cursor:not-allowed}.logout-btn-page{background:none;color:#b45253;border:1px solid #b45253;border-radius:8px;padding:10px 20px;font-size:.95rem;cursor:pointer;transition:background .15s}.logout-btn-page:hover{background:#b45253;color:#fff}.favorites-container{max-width:1200px;margin:0 auto}.fav-msg{padding:2rem;text-align:center;color:#666}.empty-msg{text-align:center;margin-top:40px;color:#666;font-style:italic}.shopping-list-container{max-width:800px;margin-left:auto;margin-right:auto;font-family:Inter,system-ui,sans-serif}.list-grid{display:flex;flex-direction:column;gap:12px}.list-item{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:15px;border-radius:12px;transition:transform .2s,opacity .2s;border:1px solid #d4ddb8}.list-item:hover{transform:translateY(-2px)}.item-info{display:flex;align-items:center;gap:15px}.item-info input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#84994f}.item-name{margin:0;font-weight:500;font-size:1.1rem;color:#2c2c2a}.recipe-tag{display:block;font-size:.8rem;color:#84994f;margin-top:2px}.list-item.checked{opacity:.6;background:#f5f5f0}.list-item.checked .item-name{text-decoration:line-through;color:#888}.delete-btn{background:#ffeded;color:#ff4d4d;border:none;width:32px;height:32px;border-radius:50%;font-size:1.2rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}.delete-btn:hover{background:#ff4d4d;color:#fff}.list-msg,.empty-msg{text-align:center;margin-top:50px;color:#7f8c8d;font-style:italic}
