*,:before,:after{box-sizing:border-box}body{background:#f9fafb;margin:0}.navbar{z-index:10;background:#fff;border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;height:56px;padding:0 24px;display:flex;position:sticky;top:0}.navbar-brand{color:#6366f1;letter-spacing:.05em;font-size:1.2rem;font-weight:700}.navbar-links{gap:8px;display:flex}.nav-link{color:#6b7280;border-radius:8px;padding:8px 16px;font-size:.95rem;font-weight:500;text-decoration:none;transition:background .2s,color .2s}.nav-link:hover{color:#1a1a1a;background:#f3f4f6}.nav-link.active{color:#6366f1;background:#eef2ff}.logout-button{color:#6b7280;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:8px 16px;font-size:.9rem;font-weight:500;transition:all .2s}.logout-button:hover{color:#ef4444;border-color:#ef4444}.grocery-container{max-width:500px;margin:40px auto;padding:0 20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.grocery-title{color:#1a1a1a;margin-bottom:24px;font-size:2rem;font-weight:700}.add-form{gap:8px;margin-bottom:24px;display:flex}.add-input{border:2px solid #e5e7eb;border-radius:10px;outline:none;flex:1;padding:12px 16px;font-size:1rem;transition:border-color .2s}.add-input:focus{border-color:#6366f1}.add-button{color:#fff;cursor:pointer;background:#6366f1;border:none;border-radius:10px;padding:12px 20px;font-size:1rem;font-weight:600;transition:background .2s}.add-button:hover{background:#4f46e5}.item-list{margin:0;padding:0;list-style:none}.item{border-bottom:1px solid #f3f4f6;align-items:center;gap:12px;padding:12px 0;display:flex}.checkbox{cursor:pointer;background:#fff;border:2px solid #d1d5db;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:.75rem;transition:background .2s,border-color .2s;display:flex}.checkbox.checked{color:#fff;background:#6366f1;border-color:#6366f1}.item-name{color:#1a1a1a;flex:1;font-size:1rem}.item.checked .item-name{color:#9ca3af;text-decoration:line-through}.delete-button{color:#d1d5db;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 6px;font-size:.9rem;transition:color .2s}.delete-button:hover{color:#ef4444}.got-label{text-transform:uppercase;letter-spacing:.08em;color:#9ca3af;margin:20px 0 4px;font-size:.8rem;font-weight:600}.recipe-container{max-width:600px;margin:40px auto;padding:0 20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.recipe-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.recipe-title{color:#1a1a1a;margin:0;font-size:2rem;font-weight:700}.add-recipe-button{color:#fff;cursor:pointer;background:#6366f1;border:none;border-radius:10px;padding:10px 18px;font-size:.95rem;font-weight:600;transition:background .2s}.add-recipe-button:hover{background:#4f46e5}.recipe-form{background:#fff;border:1px solid #e5e7eb;border-radius:12px;flex-direction:column;gap:12px;margin-bottom:24px;padding:20px;display:flex}.form-input{resize:vertical;border:2px solid #e5e7eb;border-radius:8px;outline:none;padding:10px 14px;font-family:inherit;font-size:1rem;transition:border-color .2s}.form-input:focus{border-color:#6366f1}.submit-button{color:#fff;cursor:pointer;background:#6366f1;border:none;border-radius:10px;padding:12px;font-size:1rem;font-weight:600;transition:background .2s}.submit-button:hover{background:#4f46e5}.category-tabs{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.category-tab{color:#6b7280;cursor:pointer;background:#fff;border:2px solid #e5e7eb;border-radius:20px;padding:6px 14px;font-size:.85rem;font-weight:500;transition:all .2s}.category-tab:hover{color:#6366f1;border-color:#6366f1}.category-tab.active{color:#fff;background:#6366f1;border-color:#6366f1}.recipe-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.recipe-item{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden}.recipe-row{cursor:pointer;justify-content:space-between;align-items:center;padding:16px;transition:background .2s;display:flex}.recipe-row:hover{background:#f9fafb}.recipe-name{color:#1a1a1a;margin-right:10px;font-size:1rem;font-weight:600}.recipe-category{text-transform:uppercase;letter-spacing:.06em;color:#9ca3af;font-size:.75rem;font-weight:600}.recipe-chevron{color:#9ca3af;font-size:.75rem}.recipe-detail{border-top:1px solid #f3f4f6;flex-direction:column;gap:12px;padding:0 16px 16px;display:flex}.recipe-link{color:#6366f1;margin-top:12px;font-weight:500;text-decoration:none;display:inline-block}.recipe-link:hover{text-decoration:underline}.detail-section{flex-direction:column;gap:4px;display:flex}.detail-label{text-transform:uppercase;letter-spacing:.08em;color:#9ca3af;margin:0;font-size:.75rem;font-weight:700}.detail-text{color:#374151;white-space:pre-wrap;margin:0;font-family:inherit;font-size:.95rem}.grocery-button{color:#fff;cursor:pointer;background:#10b981;border:none;border-radius:8px;align-self:flex-start;padding:8px 16px;font-size:.9rem;font-weight:600;transition:background .2s}.grocery-button:hover{background:#059669}.grocery-button:disabled{opacity:.6;cursor:not-allowed}.delete-recipe-button{color:#ef4444;cursor:pointer;background:0 0;border:1px solid #fca5a5;border-radius:8px;align-self:flex-start;padding:6px 12px;font-size:.85rem;transition:all .2s}.delete-recipe-button:hover{background:#fef2f2}.empty-message{color:#9ca3af;text-align:center;padding:40px 0}.ingredient-list{flex-direction:column;gap:4px;margin:0 0 12px;padding:0;list-style:none;display:flex}.ingredient-item{cursor:pointer;border-radius:6px;align-items:center;gap:10px;padding:8px 4px;transition:background .15s;display:flex}.ingredient-item:hover{background:#f3f4f6}.ingredient-checkbox{background:#fff;border:2px solid #d1d5db;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:.75rem;transition:background .15s,border-color .15s;display:flex}.ingredient-checkbox.checked{color:#fff;background:#6366f1;border-color:#6366f1}.ingredient-name{color:#1a1a1a;font-size:.95rem;transition:color .15s}.ingredient-name.deselected{color:#9ca3af;text-decoration:line-through}.login-container{background:#f9fafb;justify-content:center;align-items:center;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;display:flex}.login-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;width:100%;max-width:380px;padding:40px}.login-title{color:#6366f1;text-align:center;letter-spacing:.05em;margin:0 0 4px;font-size:2rem;font-weight:700}.login-subtitle{color:#9ca3af;text-align:center;margin:0 0 28px;font-size:.95rem}.login-form{flex-direction:column;gap:12px;display:flex}.login-input{border:2px solid #e5e7eb;border-radius:10px;outline:none;padding:12px 16px;font-size:1rem;transition:border-color .2s}.login-input:focus{border-color:#6366f1}.login-button{color:#fff;cursor:pointer;background:#6366f1;border:none;border-radius:10px;margin-top:4px;padding:12px;font-size:1rem;font-weight:600;transition:background .2s}.login-button:hover{background:#4f46e5}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-error{color:#ef4444;text-align:center;margin:0;font-size:.9rem}
