:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:#1e1e24;background-color:#ebf2fa;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#edb458;text-decoration:inherit}body{margin:0}h1{font-size:3.2em;line-height:1.1}button,[role=button]{border-radius:8px;border:1px solid transparent;border-bottom:3px solid #d49d42;padding:.8em 1.5em;font-size:1em;font-weight:500;font-family:inherit;background-color:#edb458;color:#fff;cursor:pointer;transition:all .15s ease-out}button:hover,[role=button]:hover{background-color:#f4c06b}button:active,[role=button]:active{transform:translateY(2px);border-bottom-width:1px}.button-outline{background-color:transparent;color:#555;border:1px solid #ccc;border-bottom:3px solid #aaa}.button-outline:hover{background-color:#f0f0f0;border-color:#bbb;border-bottom-color:#999}.button-outline:active{transform:translateY(2px);border-bottom-width:1px}button:focus,[role=button]:focus,button:focus-visible,[role=button]:focus-visible{outline:4px auto -webkit-focus-ring-color}.main-content{padding-top:60px}.navbar{background-color:#fff;box-shadow:0 2px 4px #0000001a;position:fixed;top:0;left:0;right:0;z-index:100}.navbar-container{max-width:1280px;margin:0 auto;padding:0 2rem;display:flex;justify-content:center;gap:1rem}.nav-link{display:flex;flex-direction:column;align-items:center;padding:.8rem 1rem;color:#555;text-decoration:none;transition:color .2s}.logout-btn{background:none;border:none;cursor:pointer;font-family:inherit;font-size:inherit}.nav-guest-message{padding:1rem;font-size:1.2rem;font-weight:600}.nav-link.active{color:#edb458;border-bottom:3px solid #edb458}.nav-link span{font-size:.8rem;margin-top:.2rem}main{max-width:1280px;margin:0 auto;padding:2rem}.recipe-list-container h1{text-align:center;margin-bottom:2rem;font-size:2.5em}.recipe-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:2rem;list-style:none;padding:0}.recipe-card{background-color:#fdfdff;border-radius:12px;box-shadow:0 4px 12px #00000014;overflow:hidden;position:relative;transition:transform .2s ease-in-out,box-shadow .2s ease-in-out}.recipe-card.selectable{cursor:pointer}.recipe-card.selectable.selected{transform:scale(.95);box-shadow:0 0 0 3px #edb458;opacity:.9}.recipe-card:hover{transform:translateY(-5px);box-shadow:0 8px 20px #0000001f}.recipe-card a{display:flex;flex-direction:column;height:100%}.recipe-header{position:relative}.recipe-detail{max-width:800px;margin:2rem auto;padding:0;background-color:#fdfdff;border-radius:12px;box-shadow:0 4px 12px #00000014}.recipe-card-image{width:100%;height:180px;object-fit:cover}.recipe-card-title{padding:1rem 1.2rem;font-weight:600;font-size:1.1rem;text-align:center}.recipe-image{width:100%;height:300px;object-fit:cover;border-top-left-radius:12px;border-top-right-radius:12px;display:block}.recipe-detail h1{position:absolute;inset:0;display:flex;justify-content:center;align-items:center;margin:0;padding:1em;color:#fff;background-color:#1e1e2499;border-top-left-radius:12px;border-top-right-radius:12px;text-align:center}.recipe-detail h2{font-size:1.8em;margin-top:.5rem;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #eee}.recipe-detail ul{list-style:none;padding-left:0}.recipe-detail ul li{padding:.4rem 0;color:#555}.recipe-content{padding:1rem 2.5rem}.back-button{position:absolute;top:1rem;left:1rem;z-index:10}.page-actions{text-align:center;margin-top:3rem;display:flex;justify-content:center;gap:1rem}.settings-page{max-width:800px;margin:2rem auto;padding:2rem 3rem;background-color:#fdfdff;border-radius:12px;box-shadow:0 4px 12px #00000014}.settings-page h1{text-align:center;margin-bottom:1rem}.settings-section{margin-top:3rem;border-top:1px solid #eee;padding-top:2rem}.settings-page p{text-align:center;color:#777;margin-bottom:2rem}.passkey-list{list-style:none;padding:0;margin-bottom:1rem}.passkey-list li{background-color:#fff;padding:.8rem 1rem;border:1px solid #eee;border-radius:4px;margin-bottom:.5rem}.category-list{list-style:none;padding:0}.category-list li{color:inherit;padding:.8rem 1rem;margin-bottom:.5rem;background-color:#fff;border:1px solid #eee;border-radius:4px;display:flex;align-items:center;touch-action:none}.drag-area{display:flex;align-items:center;flex-grow:1;cursor:grab}.category-name{padding:0 .5rem}.drag-handle{margin-right:1rem;color:#ccc}.delete-category-btn{background-color:#cc5a5a;color:#fff;border:1px solid transparent;cursor:pointer;padding:.5rem;border-radius:50%;width:32px;height:32px;display:flex;justify-content:center;align-items:center;transition:background-color .2s;flex-shrink:0}.delete-category-btn:hover{background-color:#a73c46}.add-category-form{display:flex;gap:.5rem;margin-bottom:2rem}.add-category-form input{flex-grow:1;padding:.8em;border:1px solid #ccc;border-radius:4px}.add-category-form button{padding:.8em 1em;flex-shrink:0}.button svg{margin-right:.5em}.add-ingredient-form{display:flex;flex-wrap:wrap;gap:1rem;padding:1.5rem;margin-bottom:2rem;background-color:#fafcff;border:1px solid #e8eef5;border-radius:8px}.add-ingredient-form>input,.add-ingredient-form>.select-container{flex:1 1 200px}.add-ingredient-form>button{flex-grow:0;white-space:nowrap}.ingredient-management-list{list-style:none;padding:0}.ingredient-item{display:flex;align-items:center;justify-content:space-between;padding:.8rem 1rem;margin-bottom:.5rem;background-color:#fff;border:1px solid #eee;border-radius:4px}.ingredient-item.editing{flex-wrap:wrap;gap:.5rem}.ingredient-item-info{display:flex;flex-direction:column}.ingredient-name{font-weight:600}.ingredient-details{font-size:.9rem;color:#777}.ingredient-item-actions{display:flex;gap:.5rem}.action-btn{background:none;border:none;cursor:pointer;padding:.5rem;border-radius:50%;width:32px;height:32px;display:flex;justify-content:center;align-items:center;transition:color .2s,background-color .2s}.action-btn.edit-btn{color:#555}.action-btn.edit-btn:hover{background-color:#e0e0e0}.action-btn.delete-btn,.action-btn.cancel-btn{background-color:#cc5a5a;color:#fff}.action-btn.delete-btn:hover,.action-btn.cancel-btn:hover{background-color:#a73c46}.action-btn.save-btn{color:#28a745}.action-btn.save-btn:hover{background-color:#d4edda}.edit-ingredient-name{flex-basis:40%;padding:.5em}.edit-ingredient-unit{flex-basis:20%;padding:.5em}.edit-ingredient-category{flex-grow:1;min-width:150px}.shopping-list-page h1{text-align:center;margin-bottom:2rem}.shopping-list{list-style:none;padding:0}.shopping-list-category{margin-bottom:2rem}.shopping-list-category h2{font-size:1.5em;margin-bottom:0;color:#333}.shopping-list-category ul{margin-top:0;list-style:none;padding:0}.shopping-list-item{display:flex;align-items:center;padding:.8rem .5rem;border-bottom:1px solid #f0f0f0;cursor:pointer;transition:background-color .2s}.shopping-list-item:hover{background-color:#f9f9f9}.shopping-list-item input[type=checkbox]{width:20px;height:20px;margin-right:1rem;accent-color:#edb458;cursor:pointer}.shopping-list-item .item-details{display:flex;align-items:baseline;gap:.5rem}.shopping-list-item .item-amount{font-weight:600;min-width:80px}.shopping-list-item.checked .item-details{text-decoration:line-through;color:#999}.recipe-form{max-width:800px;margin:2rem auto;padding:2rem 3rem;background-color:#fdfdff;border-radius:12px;box-shadow:0 4px 12px #00000014}.recipe-form label{display:block;font-weight:600;margin-top:1.5rem;margin-bottom:.5rem}.recipe-form input[type=text],.recipe-form input[type=file],.recipe-form input[type=number],.recipe-form textarea,.recipe-form select{width:100%;padding:.8em;border:1px solid #ccc;border-radius:4px;box-sizing:border-box}.ingredient-adder{display:flex;gap:1rem;align-items:center}.ingredient-list{list-style:none;padding:0;margin-top:1rem}.ingredient-list li{display:flex;justify-content:space-between;align-items:center;padding:.5rem;border-bottom:1px solid #eee}.remove-btn{background-color:#cc5a5a;color:#fff;border:1px solid transparent;border-radius:4px;padding:.3em .6em;cursor:pointer;transition:background-color .2s}.remove-btn:hover{background-color:#a73c46}.error-message{color:#cc5a5a;margin-top:1rem}.empty-list-info{color:#777;font-style:italic}.ingredient-adder{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.modal-overlay{position:fixed;inset:0;background-color:#1e1e24cc;display:flex;justify-content:center;align-items:center;z-index:1000}.modal{background-color:#fdfdff;padding:2rem 3rem;border-radius:12px;box-shadow:0 10px 30px #0003;width:100%;max-width:500px}.ingredient-modal{max-width:700px;height:80vh;display:flex;flex-direction:column}.modal-search-bar{margin-bottom:1rem}.modal-search-bar input{width:100%;padding:.8em;border:1px solid #ccc;border-radius:4px;box-sizing:border-box}.create-new-prompt{color:#007bff;font-weight:600;text-align:center;padding:1rem!important}.modal-ingredient-list{list-style:none;padding:0;overflow-y:auto;flex-grow:1;border:1px solid #eee;border-radius:4px}.modal-ingredient-list li{display:flex;align-items:center;padding:.8rem 1rem;cursor:pointer;transition:background-color .2s;border-bottom:1px solid #eee}.modal-ingredient-list li:hover{background-color:#f4f4f4}.modal-ingredient-list li.selected{background-color:#edb45820;font-weight:600}.selection-indicator{width:20px;margin-right:1rem;color:#edb458}.amount-input{margin-left:auto;width:80px}.modal-actions{margin-top:2rem;display:flex;justify-content:flex-end;gap:1rem}.back-button svg{margin-right:.5em}.recipe-counter-badge{position:absolute;top:10px;right:10px;background-color:#edb458;color:#fff;border-radius:50%;width:28px;height:28px;display:flex;justify-content:center;align-items:center;font-weight:700;font-size:1rem;box-shadow:0 2px 4px #0003;z-index:2}.remove-recipe-btn{position:absolute;bottom:10px;right:10px;background-color:#cc5a5a;color:#fff;border:1px solid transparent;border-radius:50%;width:32px;height:32px;font-size:1rem;font-weight:700;line-height:1;padding:0;display:flex;justify-content:center;align-items:center;cursor:pointer;z-index:2;transition:background-color .2s}.remove-recipe-btn:hover{background-color:#a73c46}.page-actions .button-outline,.modal-actions .button-outline{background-color:#cc5a5a;color:#fff;border-color:transparent;border-bottom-color:#a73c46}.page-actions .button-outline:hover,.modal-actions .button-outline:hover{background-color:#a73c46;border-bottom-color:#8b2f38}.auth-page{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 60px - 4rem)}.auth-container{max-width:calc(650px - 4rem);width:100%;padding:1.5rem 2rem;background-color:#fdfdff;border-radius:12px;box-shadow:0 4px 12px #00000014;text-align:center;display:flex}.passkey-auth{border-right:1px solid #efefef;padding-right:2rem;display:flex;justify-content:center;align-items:center}.classic-auth{margin-left:2rem}.classic-auth input{width:100%;margin-bottom:1rem;padding:.8em;border:1px solid #ccc;border-radius:4px;box-sizing:border-box}.classic-auth button{width:100%}.setup-page{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:2rem;box-sizing:border-box}.setup-container{max-width:600px;width:100%;padding:2rem 3rem;background-color:#fdfdff;border-radius:12px;box-shadow:0 4px 12px #00000014}.setup-container h1{text-align:center;font-size:2em;margin-bottom:1rem}.setup-container p{text-align:center;color:#555;margin-bottom:2rem}.setup-container form{text-align:left}.setup-container fieldset{border:1px solid #ddd;border-radius:8px;padding:1.5rem;margin-bottom:2rem}.setup-container legend{font-weight:600;padding:0 .5em;margin-left:1rem;color:#333}.setup-container label{display:block;margin-bottom:1rem;font-weight:500;color:#444}.setup-container input{width:100%;padding:.8em;border:1px solid #ccc;border-radius:4px;box-sizing:border-box;margin-top:.25rem}.setup-container fieldset button{width:100%;margin-top:.5rem}.setup-container button[type=submit]{width:100%;margin-top:1rem}.setup-container .message{padding:1rem;border-radius:8px;margin-bottom:1.5rem;text-align:center;font-weight:500}.setup-container .message.success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.setup-container .message.error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.setup-container .message.info{background-color:#d1ecf1;color:#0c5460;border:1px solid #bee5eb}.floating-message-box{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);padding:1rem 1.5rem;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:1100;font-weight:500;animation:fade-in .3s ease-out}.floating-message-box.success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.floating-message-box.error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}@keyframes fade-in{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}
