This project contains the front-end code for the landing page of a fictional Bakery. It uses only HTML and CSS & SCSS. The design was shared in Figma by a web design student Olga. I had a chance to transform her vision into code.
Stack:
Type:
data:image/s3,"s3://crabby-images/d6dba/d6dbafe7bc07d3681b3a6aa79cbdab71aaaa5af9" alt="fictional bakery shop landing page"
Project purpose and goal
This project was intended to practice the skills acquired in the Advanced CSS and SASS course. The goal was to code from scratch a layout in HTML and CSS based on the design provided by a professional designer. I also made it fully responsive so it looks good on any device.
Overview
I coded the landing page using SCSS as this was the most convenient way to code a complex layout. I used separate template parts for each section and imported them into one final main.scss
file. The structure of the SCSS code can be viewed on GitHub here.
I used NPM packages to convert SCSS code into plain CSS, prefix the code for multi-browser support, and finally concatenate the CSS code.
The landing page contains several sections: Navigation Menu, Hero Banner, Pricing table, About section with feature boxes, Gallery, Testimonials, Call to Action, Contacts, and footer.
data:image/s3,"s3://crabby-images/af996/af9963e469432c5ba73f9086e0ce42258c2c6100" alt=""
data:image/s3,"s3://crabby-images/b9ed8/b9ed882b7230eaec1d42105e273264fd2753b963" alt=""
data:image/s3,"s3://crabby-images/d0ad8/d0ad81ef9717f5a2dc544bbc265fff2bf65f8987" alt=""
I used primarily grid layout, and some elements utilize flexbox. The design highlights animated buttons and gallery items that display captions on hover.
data:image/s3,"s3://crabby-images/4cf25/4cf255a24f841c155077c3a2c01798c6e766b1ab" alt=""
data:image/s3,"s3://crabby-images/60dcb/60dcb2468aa32fff834e3741ed440613100fe00a" alt=""
The landing page is fully responsive and contains breakpoints to adjust to tablet and mobile devices.
data:image/s3,"s3://crabby-images/d2d87/d2d87486bb87aba4523feb2d025ddd3b1752fba7" alt=""
data:image/s3,"s3://crabby-images/941a2/941a2c87c8630dcc3c5f720ce0cedd6f721bcbc3" alt=""
data:image/s3,"s3://crabby-images/fce3a/fce3a5c76afcfd56ee365ad0a41daa63dd818344" alt=""
data:image/s3,"s3://crabby-images/659ec/659ecd600e90aced7b52a2276091656306573e60" alt=""
data:image/s3,"s3://crabby-images/458d7/458d7dc82e4b2b604b35628d1c3d30593cc53647" alt=""
Problems and thought process
The layout contains a few floating images. It was a bit challenging to position these images for each device type, so I had to use a few breakpoints to maintain the accuracy of the design while keeping the elements displayed regardless of the device.
Olga – the designer – reviewed the design throughout the development process and noticed a few layout issues I oversaw (mainly related to alignment). Thanks to her input I was able to see the code from the designer’s perspective and make adjustments that improved the look of the page.
This was a fruitful collaboration where I learned the problems that might come up while coding a complex design, and I was able to experience the process of working with a professional designer and ways to address their requests and concerns.