diff --git a/README.md b/README.md index de05024..266f35d 100644 --- a/README.md +++ b/README.md @@ -1 +1,52 @@ +[![Review Assignment Due Date](https://classroom.github.com/assets/deadline-readme-button-24ddc0f5d75046c5622901739e7c5dd533143b0c8e959d652212380cedb1ea36.svg)](https://classroom.github.com/a/E1TYCvbT) [![Open in Visual Studio Code](https://classroom.github.com/assets/open-in-vscode-718a45dd9cf7e7f842a935f5ebbe5719a5e09af4491e668f4dbf3b35d5cca122.svg)](https://classroom.github.com/online_ide?assignment_repo_id=10922263&assignment_repo_type=AssignmentRepo) + + + +What the project does. + +This project is an animated, scrollable website about sustainable goal 14. UN's sustainable goal 14 is about conserving and use the oceans sustainably. Sea and marine resources are an important key element for a future within sustainable development, and should therefore be utalized. +In the project we are using advanced CSS features such as CSS architecture, Sass, BEM, SVG, keyframe animations, transitions and transformations to achieve a unique and fun scrolling experience that hopefully will be educating. + +This site features a scrolling narration, implemented use of Intersection Observer, and includes accessibility features such as "prefer-color-scheme" to ensure an optimal user experience. +The primary objective of the project is to educate users about Sustainable Development Goal 14, which focuses on ocean conservation and sustainable use of marine resources. This is achieved through a combination of storytelling, animations, layout, and typography, which are designed to engage and inform users about the importance of protecting our oceans. + + +Why the project is useful + +This project aims to raise awareness about United Nations Sustainable Development Goal 14: Life Below Water. Through an engaging scrollytelling experience, it educates individuals about the importance of protecting and sustainably managing our oceans, seas, and marine resources. By showcasing the challenges faced by marine ecosystems and offering actionable solutions, the project encourages people to become advocates for Goal 14 and contribute to a healthier and more sustainable future for our planet. + + +How users can get started with the project + +1. To get started with the project you can Visit the GitHub Pages link where the project is published + +2. Explore the visually captivating animations and educational resources on the website to support Sustainable Development Goal 14, which aims to conserve and sustainably use the oceans, seas, and marine resources. + +3. For developers interested in contributing to the project,begin by forking the repository and cloning it to your local machine. + +4. Next, create a new branch for the feature you'd like to work on and start making changes to the code. + +5. Once you've completed your changes, push the branch to your forked repository and create a pull request to merge your changes into the original repository. Join the effort to protect our oceans and promote sustainable use of marine resources by contributing to this important project! + + + +Where users can get help with your project + +Please consult the README file located in the project's GitHub repository for guidance. +If you encounter any bugs or issues, please utilize the "Issues" section within the GitHub repository to report them. +For assistance or inquiries regarding the project, feel free to contact the team members listed as contributors in the GitHub repository. + + +Which technology is used + +To promote sustainability goal 14, the project employs a variety of technologies to create an animated and scrollable website. These technologies include advanced CSS features, CSS architecture, Sass, BEM, SVG, keyframe animations, transitions, transformations,implementation of accessibility, prefers-reduced-motion, prefers-color-scheme, orientation and Scrollytelling using Intersection Observer and Javascript. we have used the color-scheme to change the sun to moon and a background gradient from lighter to darker shades creates a distinct transition that gives off a night-time vibe. +The sun, the bottle, and the waves are reduced motion elements that represent the need to reduce our impact on the environment. By incorporating the prefers-reduced-motion feature, the website ensures that users who prefer reduced motion can access the content without any discomfort. +By utilizing these technologies, the project is visually appealing, informative, and accessible to a diverse range of users. + + +Who maintains and contributes to the project + +Since this project is a work on github, anyone who's a member of the community are allowed and able to contribute if they want to. +The project is maintained and contributed by the team members which is listed in the github repository, +Elina, Johan, Jørgen and Solveig. diff --git a/images/bottle-trash-1.png b/images/bottle-trash-1.png new file mode 100644 index 0000000..1525a21 Binary files /dev/null and b/images/bottle-trash-1.png differ diff --git a/images/bottle-trash-2.png b/images/bottle-trash-2.png new file mode 100644 index 0000000..ae3aadc Binary files /dev/null and b/images/bottle-trash-2.png differ diff --git a/images/bottle-trash.png b/images/bottle-trash.png new file mode 100644 index 0000000..d53768b Binary files /dev/null and b/images/bottle-trash.png differ diff --git a/images/bottle.jpeg b/images/bottle.jpeg new file mode 100644 index 0000000..8f3efe7 Binary files /dev/null and b/images/bottle.jpeg differ diff --git a/images/bottle.png b/images/bottle.png new file mode 100644 index 0000000..eebed39 Binary files /dev/null and b/images/bottle.png differ diff --git a/images/carpet.avif b/images/carpet.avif new file mode 100644 index 0000000..623ad57 Binary files /dev/null and b/images/carpet.avif differ diff --git a/images/cloud.png b/images/cloud.png new file mode 100644 index 0000000..16d8991 Binary files /dev/null and b/images/cloud.png differ diff --git a/images/coral-purple.png b/images/coral-purple.png new file mode 100644 index 0000000..2866705 Binary files /dev/null and b/images/coral-purple.png differ diff --git a/images/dead-coral-left.png b/images/dead-coral-left.png new file mode 100644 index 0000000..edd8549 Binary files /dev/null and b/images/dead-coral-left.png differ diff --git a/images/dead-coral-right.png b/images/dead-coral-right.png new file mode 100644 index 0000000..aef8e91 Binary files /dev/null and b/images/dead-coral-right.png differ diff --git a/images/dead-earth.png b/images/dead-earth.png new file mode 100644 index 0000000..96b65bc Binary files /dev/null and b/images/dead-earth.png differ diff --git a/images/fish3D.png b/images/fish3D.png new file mode 100644 index 0000000..053f01e Binary files /dev/null and b/images/fish3D.png differ diff --git a/images/fishBlack.png b/images/fishBlack.png new file mode 100644 index 0000000..828e419 Binary files /dev/null and b/images/fishBlack.png differ diff --git a/images/fishBlack4.png b/images/fishBlack4.png new file mode 100644 index 0000000..0b2377a Binary files /dev/null and b/images/fishBlack4.png differ diff --git a/images/fishBlue.png b/images/fishBlue.png new file mode 100644 index 0000000..a3cb7b5 Binary files /dev/null and b/images/fishBlue.png differ diff --git a/images/fishBlue2.png b/images/fishBlue2.png new file mode 100644 index 0000000..112e521 Binary files /dev/null and b/images/fishBlue2.png differ diff --git a/images/fishDead.png b/images/fishDead.png new file mode 100644 index 0000000..4ccbfee Binary files /dev/null and b/images/fishDead.png differ diff --git a/images/fishGreen.png b/images/fishGreen.png new file mode 100644 index 0000000..2a9d017 Binary files /dev/null and b/images/fishGreen.png differ diff --git a/images/fishGreen2.png b/images/fishGreen2.png new file mode 100644 index 0000000..b676944 Binary files /dev/null and b/images/fishGreen2.png differ diff --git a/images/fishGrey.png b/images/fishGrey.png new file mode 100644 index 0000000..e080bce Binary files /dev/null and b/images/fishGrey.png differ diff --git a/images/fishGrey2.png b/images/fishGrey2.png new file mode 100644 index 0000000..ac6c21b Binary files /dev/null and b/images/fishGrey2.png differ diff --git a/images/fishOrange.png b/images/fishOrange.png new file mode 100644 index 0000000..f0113f7 Binary files /dev/null and b/images/fishOrange.png differ diff --git a/images/fishOrange2.png b/images/fishOrange2.png new file mode 100644 index 0000000..6ca64ab Binary files /dev/null and b/images/fishOrange2.png differ diff --git a/images/fishPink.png b/images/fishPink.png new file mode 100644 index 0000000..8f78340 Binary files /dev/null and b/images/fishPink.png differ diff --git a/images/fishStrange.png b/images/fishStrange.png new file mode 100644 index 0000000..75f3e15 Binary files /dev/null and b/images/fishStrange.png differ diff --git a/images/fishStrange2.png b/images/fishStrange2.png new file mode 100644 index 0000000..bd5978c Binary files /dev/null and b/images/fishStrange2.png differ diff --git a/images/fishStrange3.gif b/images/fishStrange3.gif new file mode 100644 index 0000000..11078e4 Binary files /dev/null and b/images/fishStrange3.gif differ diff --git a/images/fishStrange4.png b/images/fishStrange4.png new file mode 100644 index 0000000..ede7cad Binary files /dev/null and b/images/fishStrange4.png differ diff --git a/images/fishblack2.png b/images/fishblack2.png new file mode 100644 index 0000000..02e5c76 Binary files /dev/null and b/images/fishblack2.png differ diff --git a/images/fishblack3.png b/images/fishblack3.png new file mode 100644 index 0000000..b93fd32 Binary files /dev/null and b/images/fishblack3.png differ diff --git a/images/fishgrey3.png b/images/fishgrey3.png new file mode 100644 index 0000000..3411357 Binary files /dev/null and b/images/fishgrey3.png differ diff --git a/images/fishing_dock.png b/images/fishing_dock.png new file mode 100644 index 0000000..7811c3e Binary files /dev/null and b/images/fishing_dock.png differ diff --git a/images/green-sea-grass-left.png b/images/green-sea-grass-left.png new file mode 100644 index 0000000..3b64ab8 Binary files /dev/null and b/images/green-sea-grass-left.png differ diff --git a/images/green-sea-grass-right.png b/images/green-sea-grass-right.png new file mode 100644 index 0000000..b66fb50 Binary files /dev/null and b/images/green-sea-grass-right.png differ diff --git a/images/healthy-earth.png b/images/healthy-earth.png new file mode 100644 index 0000000..5276dd5 Binary files /dev/null and b/images/healthy-earth.png differ diff --git a/images/landscape.png b/images/landscape.png new file mode 100644 index 0000000..d64a6a4 Binary files /dev/null and b/images/landscape.png differ diff --git a/images/man.png b/images/man.png new file mode 100644 index 0000000..217f5a0 Binary files /dev/null and b/images/man.png differ diff --git a/images/moon.png b/images/moon.png new file mode 100644 index 0000000..cf0d9e5 Binary files /dev/null and b/images/moon.png differ diff --git a/images/nice-bottle.png b/images/nice-bottle.png new file mode 100644 index 0000000..d9ded93 Binary files /dev/null and b/images/nice-bottle.png differ diff --git a/images/ocean-wave-small-tattoo-7793.png b/images/ocean-wave-small-tattoo-7793.png new file mode 100644 index 0000000..91933c1 Binary files /dev/null and b/images/ocean-wave-small-tattoo-7793.png differ diff --git a/images/pink-coral.png b/images/pink-coral.png new file mode 100644 index 0000000..fc4e66f Binary files /dev/null and b/images/pink-coral.png differ diff --git a/images/recycled-bottle.png b/images/recycled-bottle.png new file mode 100644 index 0000000..a3ff8fe Binary files /dev/null and b/images/recycled-bottle.png differ diff --git a/images/sleepingba.png b/images/sleepingba.png new file mode 100644 index 0000000..cd369f3 Binary files /dev/null and b/images/sleepingba.png differ diff --git a/images/sun .png b/images/sun .png new file mode 100644 index 0000000..2be6de6 Binary files /dev/null and b/images/sun .png differ diff --git a/images/sun.png b/images/sun.png new file mode 100644 index 0000000..e759ce8 Binary files /dev/null and b/images/sun.png differ diff --git a/images/tracksuit.svg b/images/tracksuit.svg new file mode 100644 index 0000000..65b08e8 --- /dev/null +++ b/images/tracksuit.svg @@ -0,0 +1,21 @@ + + + + + + + + + \ No newline at end of file diff --git a/images/trash-bin.png b/images/trash-bin.png new file mode 100644 index 0000000..7e4571a Binary files /dev/null and b/images/trash-bin.png differ diff --git a/images/tshirt.webp b/images/tshirt.webp new file mode 100644 index 0000000..6f987ef Binary files /dev/null and b/images/tshirt.webp differ diff --git a/images/upholstery.png b/images/upholstery.png new file mode 100644 index 0000000..b9ade01 Binary files /dev/null and b/images/upholstery.png differ diff --git a/images/water-bottle-3927420_1280.png b/images/water-bottle-3927420_1280.png new file mode 100644 index 0000000..26e7d0a Binary files /dev/null and b/images/water-bottle-3927420_1280.png differ diff --git a/images/wave.png b/images/wave.png new file mode 100644 index 0000000..438acd6 Binary files /dev/null and b/images/wave.png differ diff --git a/images/waves-noncolor.png b/images/waves-noncolor.png new file mode 100644 index 0000000..1e46c25 Binary files /dev/null and b/images/waves-noncolor.png differ diff --git a/images/waves.png b/images/waves.png new file mode 100644 index 0000000..f639406 Binary files /dev/null and b/images/waves.png differ diff --git a/index.html b/index.html index 0c90011..ace32cc 100644 --- a/index.html +++ b/index.html @@ -1 +1,187 @@ -

hei

+ + + + + + Group 1 Assignment 3 + + + + +
+
+ + +
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ + + +
+
+
+
+
+
+
+
+ + + +
+
+ + +
+
+

+ A man on a trip, by the ocean struggling to dispose of his water bottle. Unable to find a trash bin, he finally throws it in the ocean. The bottle's journey begins as it drifts away alone in the vast ocean. +

+
+
+ +
+ +
+ +
+
+ + + + +
+
+

+ The water bottle floated on the surface, enjoying the colorful world around it, until it started to sink. + Fishes started swarming the bottle, and it had to fight to stay afloat. +

+
+
+ + +
+
+ +
+
+ + +
+
+ +
+
+

+ After a long journey, the bottle finally hits the ocean floor and ends up in a trash can. + This short story emphasizes the negative impact of human contamination on water and the environment. +

+
+
+ +
+
+ +
+
+ + + +
+
+

+ It shows the struggles of survival and battling the environment. + In the end, the bottle's fate becomes a silent reminder to protect the environment and preserve order. +

+
+
+
+ +
+
+ +
+
+ + +
+

IS THIS THE EARTH YOU WANT TO LIVE ON ?

+
+ + +
+ + +
+ + +
+

WHAT IT COULD BE INSTEAD

+
+ + + + + +
+ +
+
+ + + +
+ + + + + + + + + + + + + + + + + + + + + READ MORE HERE + + + + t-shirt +
+
+ + diff --git a/script.js b/script.js new file mode 100644 index 0000000..77e17fd --- /dev/null +++ b/script.js @@ -0,0 +1,71 @@ +// Observer for .scene-text-container +const textObserver = new IntersectionObserver(function(entries, observer) { + entries.forEach(entry => { + if (entry.isIntersecting && !entry.target.classList.contains('showTextAnimation')) { + entry.target.classList.add('showTextAnimation'); + } + }); +}, { threshold: 0.3 }); + +// Observer for .background-plants-right +const plantObserverRight = new IntersectionObserver(function(entries, observer) { + entries.forEach(entry => { + if (entry.isIntersecting && !entry.target.classList.contains('showPlantRightAnimation')) { + entry.target.classList.add('showPlantRightAnimation'); + } + }); +}); + +// Observer for .background-plants-left +const plantObserverLeft = new IntersectionObserver(function(entries, observer) { + entries.forEach(entry => { + if (entry.isIntersecting && !entry.target.classList.contains('showPlantLeftAnimation')) { + entry.target.classList.add('showPlantLeftAnimation'); + } + }); +}); + +// Observer for .removeBottleTrigger +const removeBottleTriggerObserver = new IntersectionObserver(function(entries, observer) { + entries.forEach(entry => { + const bottleElement = document.querySelector('.scene1__content-bottle'); + const trashbinElement = document.querySelector('.scene9__trash-bin'); + const trashExample1Element = document.querySelector('.scene9__img-container-trashExample1'); + const trashExample2Element = document.querySelector('.scene9__img-container-trashExample2'); + const trashExample3Element = document.querySelector('.scene9__img-container-trashExample3'); + const trashExample4Element = document.querySelector('.scene9__img-container-trashExample4'); + const trashExample5Element = document.querySelector('.scene9__img-container-trashExample5'); + if (entry.isIntersecting && bottleElement && !bottleElement.classList.contains('removeBottle')) { + bottleElement.classList.remove('throwBottleAnimation'); + trashbinElement.classList.add('trashBinFixed'); + trashExample1Element.classList.add('showTrashExample1'); + trashExample2Element.classList.add('showTrashExample2'); + trashExample3Element.classList.add('showTrashExample3'); + trashExample4Element.classList.add('showTrashExample4'); + trashExample5Element.classList.add('showTrashExample5'); + } + }); +}); + +// Observer for Link reveal +const linkcontainerObserver = new IntersectionObserver(function(entries, observer) { + entries.forEach(entry => { + if (entry.isIntersecting && !entry.target.classList.contains('revealanimation')) { + entry.target.classList.add('revealanimation'); + } + }); +}); + +// Elements to observe +const textElements = document.querySelectorAll('.text-container'); +const plantElementsRight = document.querySelectorAll('.plant-container__background-plants-right'); +const plantElementsleft = document.querySelectorAll('.plant-container__background-plants-left'); +const bottleRemove = document.querySelectorAll('.scene9__remove-bottle-trigger'); +const linkrevealelement = document.querySelectorAll('h4 a span'); + +// Add observers to elements +textElements.forEach(el => textObserver.observe(el)); +plantElementsRight.forEach(el => plantObserverRight.observe(el)); +plantElementsleft.forEach(el => plantObserverLeft.observe(el)); +bottleRemove.forEach(el => removeBottleTriggerObserver.observe(el)); +linkrevealelement.forEach(el => linkcontainerObserver.observe(el)); diff --git a/style.css b/style.css deleted file mode 100644 index 8b13789..0000000 --- a/style.css +++ /dev/null @@ -1 +0,0 @@ - diff --git a/style/_animations.scss b/style/_animations.scss new file mode 100644 index 0000000..039ea84 --- /dev/null +++ b/style/_animations.scss @@ -0,0 +1,547 @@ +@keyframes textboxInn { + 0% { + transform: translateY(0); + opacity: 0; + } + 100% { + transform: translateY(-40px); + opacity: 1; + } +} + +@keyframes plantLeftInn { + 0% { + opacity: 1; + transform: rotate(13deg) translateX(-90px); + } + 40% { + opacity: 1; + transform: rotate(38deg) translateX(0px); + } + 60% { + opacity: 1; + transform: rotate(38deg) translateX(0px); + } + 80% { + opacity: 1; + transform: rotate(38deg) translateX(0px); + } + 100% { + opacity: 1; + transform: rotate(38deg) translateX(0px); + } +} + +@keyframes plantRightInn { + 0% { + opacity: 1; + transform: rotate(-13deg) translateX(90px); + } + 40% { + opacity: 1; + transform: rotate(-30deg) translateX(0px); + } + 60% { + opacity: 1; + transform: rotate(-30deg) translateX(0px); + } + 80% { + opacity: 1; + transform: rotate(-30deg) translateX(0px); + } + 100% { + opacity: 1; + transform: rotate(-30deg) translateX(0px); + } +} + +@keyframes bottleThrow { + 0% { + transform: translateY(4vw); + } + 60% { + transform: translateX(20vw) translateY(-20vw) rotate(-200deg); + } + + 100% { + transform: translateX(17vw) translateY(10vw) rotate(-400deg); + position: fixed; + } +} + +@keyframes trashbinFixedAnimation { + 0% { + } + 100% { + position: sticky; + top: 23vw; + left: 40vw; + } +} + +.trashBinFixed { + animation-name: trashbinFixedAnimation; + animation-fill-mode: forwards; +} + +.showTrashExample1 { + animation-name: textboxInn; + transition: 0.8s; + animation-duration: 1s; + animation-delay: 0.3s; + animation-fill-mode: forwards; +} + +.showTrashExample2 { + animation-name: textboxInn; + transition: 0.8s; + animation-duration: 1s; + animation-delay: 0.6s; + animation-fill-mode: forwards; +} + +.showTrashExample3 { + animation-name: textboxInn; + transition: 0.8s; + animation-duration: 1s; + animation-delay: 0.9s; + animation-fill-mode: forwards; +} + +.showTrashExample4 { + animation-name: textboxInn; + transition: 0.8s; + animation-duration: 1s; + animation-delay: 1.2s; + animation-fill-mode: forwards; +} + +.showTrashExample5 { + animation-name: textboxInn; + transition: 0.8s; + animation-duration: 1s; + animation-delay: 1.5s; + animation-fill-mode: forwards; +} + +.showTextAnimation { + animation-name: textboxInn; + transition: 0.8s; + animation-duration: 1s; + animation-delay: 0.7s; + animation-fill-mode: forwards; +} + +.showPlantLeftAnimation { + animation-name: plantLeftInn; + transition: 0.8s; + animation-duration: 3s; + animation-delay: 0.9s; + animation-fill-mode: forwards; +} + +.showPlantRightAnimation { + animation-name: plantRightInn; + animation-duration: 1s; + animation-delay: 0.9s; + animation-fill-mode: forwards; +} + +.throwBottleAnimation { + animation-name: bottleThrow; + transition: 2s; + animation-duration: 3s; + animation-delay: 2s; + animation-fill-mode: forwards; +} +.sun { + animation-name: sunMove; + animation-duration: 2s; + animation-iteration-count: infinite; + animation-direction: alternate; +} + +@keyframes sunMove { + 0% { + transform: scale(0.7); + } + 100% { + transform: scale(0.8); + } +} + +/* Man animations */ +.scene1__content-man { + animation: walking 0.6s infinite, man-walking 5s forwards; +} +@keyframes walking { + 0% { + transform: translateY(0); + } + 50% { + transform: translateY(-20px); + } + 100% { + transform: translateY(0); + } +} +@keyframes man-walking { + 0% { + left: -50%; + } + 50% { + left: 25%; + } + 100% { + left: -50%; + } +} +/*clouds*/ +.clouds__1, .clouds__2{ + animation: cloudMove 10s linear infinite; +} +@keyframes cloudMove { + 0% { + transform: translateX(-50%); + } + 100% { + transform: translateX(100%); + } +} + +/*Waves animation*/ +.waves__1 { + animation: animate__wave-1 10s linear; + animation-iteration-count: 1000; +} +@keyframes animate__wave-1 { + 0% { + background-position-x: 0vw; + } + 100% { + background-position-x: -80vw; + } +} + +.waves__2 { + animation: animate__wave-2 20s linear infinite; + animation-delay: 0s; +} +@keyframes animate__wave-2 { + 0% { + background-position-x: 0vw; + } + 100% { + background-position-x: 80vw; + } +} + +.waves__3 { + animation: animate__wave-3 10s linear infinite; + animation-delay: 5s; +} +@keyframes animate__wave-3 { + 0% { + background-position-x: 10vw; + } + 100% { + background-position-x: -100vw; + } +} + +.waves__4 { + animation: animate__wave-4 30s linear; + z-index: 1000; + animation-iteration-count: 1000; +} +@keyframes animate__wave-4 { + 0% { + background-position-x: 0vw; + } + 100% { + background-position-x: 80vw; + } +} + +/* MEDIA CODE */ +/* reduce motion*/ +@media (prefers-reduced-motion) { + /*Sun animation*/ + .sun { + animation-name: sunMove 2s infinite alternate; + } + @keyframes sunMove { + 0% { + transform: scale(0.8); + } + 100% { + transform: scale(0.8); + } + } + /*Waves animation*/ + .waves__1 { + animation: animate__wave-1 50s linear; + animation-iteration-count: 1000; + } + @keyframes animate__wave-1 { + 0% { + background-position-x: 0vw; + } + 100% { + background-position-x: -80vw; + } + } + + .waves__2 { + animation: animate__wave-2 30s linear infinite; + animation-delay: 0s; + } + @keyframes animate__wave-2 { + 0% { + background-position-x: 0vw; + } + 100% { + background-position-x: 80vw; + } + } + + .waves__3 { + animation: animate__wave-3 20s linear infinite; + animation-delay: 5s; + } + @keyframes animate__wave-3 { + 0% { + background-position-x: 10vw; + } + 100% { + background-position-x: -100vw; + } + } + + .waves__4 { + animation: animate__wave-4 40s linear infinite; + } + @keyframes animate__wave-4 { + 0% { + background-position-x: 0vw; + } + 100% { + background-position-x: 80vw; + } + } + + @keyframes bottleThrow { + 0% { + transform: translateY(4vw); + } + 60% { + transform: translateX(20vw) translateY(-5vw); + } + + 100% { + transform: translateX(20vw) translateY(10vw); + position: fixed; + } + } +} + +/* Fish animations */ + +@keyframes fishSwimAnimation1 { + 0% { + transform: translateY(0); + left: 0; + } + 25% { + transform: translateY(30px); + } + 49% { + transform: translateY(0px); + left: 90vw; + } + 50%{ + transform: scalex(-1); + } + 75% { + transform: translateY(50px) scalex(-1); + } + 100% { + transform: translateY(0px)scalex(-1); + left: 0; + } +} + +@keyframes fishSwimAnimation2 { + 0% { + transform: translateY(0); + left: 0; + } + 25% { + transform: translateY(30px); + } + 49% { + transform: translateY(0px); + left: 90vw; + } + 50%{ + transform: scalex(-1); + } + 75% { + transform: translateY(50px) scalex(-1); + } + 100% { + transform: translateY(0px)scalex(-1); + left: 0; + } +} + +@keyframes fishSwimAnimation3 { + 0% { + transform: translateY(0); + left: 0; + } + 25% { + transform: translateY(30px); + } + 49% { + transform: translateY(0px); + left: 40vw; + } + 50%{ + transform: scalex(-1); + } + 75% { + transform: translateY(50px) scalex(-1); + } + 100% { + transform: translateY(0px)scalex(-1); + left: 0; + } +} + +@keyframes fishSwimAnimation4 { + 0% { + transform: translateY(0); + left: 0; + } + 25% { + transform: translateY(30px); + } + 49% { + transform: translateY(0px); + left: 3vw; + } + 50%{ + transform: scalex(-1); + } + 75% { + transform: translateY(50px) scalex(-1); + } + 100% { + transform: translateY(0px)scalex(-1); + left: 0; + } +} + +@keyframes fishSwimAnimation5 { + 0% { + transform: translateY(0); + left: 80vw; + } + 25% { + transform: translateY(30px); + } + 49% { + transform: translateY(0px); + left: 70vw; + } + 50%{ + transform: scalex(-1); + } + 75% { + transform: translateY(50px) scalex(-1); + } + 100% { + transform: translateY(0px)scalex(-1); + left: 80vw; + } +} + +.plant-container__scene2Fish1 { + position: absolute; + animation-name: fishSwimAnimation1; + animation-duration: 35s; + animation-iteration-count: infinite; +} + +.scene2__scene2Fish2 { + position: absolute; + animation-name: fishSwimAnimation3; + animation-duration: 35s; + animation-iteration-count: infinite; +} + +.plant-container-fish1 { + position: absolute; + animation-name: fishSwimAnimation2; + animation-duration: 20s; + animation-iteration-count: infinite; +} + +.scene3__scene3Fish2 { + position: absolute; + animation-name: fishSwimAnimation3; + animation-delay: 2s; + animation-duration: 25s; + animation-iteration-count: infinite; +} + +.scene4__scene4Fish1 { + position: absolute; + animation-name: fishSwimAnimation4; + animation-delay: 2s; + animation-duration: 15s; + animation-iteration-count: infinite; +} + +.scene5Fish1 { + position: absolute; + animation-name: fishSwimAnimation5; + animation-delay: 2s; + animation-duration: 15s; + animation-iteration-count: infinite; +} + +/* read more reveal */ +.revealanimation { + display: block; + animation-name: reveal; + animation-duration: 1.5s; + transition: cubic-bezier(0.77, 0, 0.175, 1); +} + +@keyframes reveal { + 0% { + transform: translate(0,100%); + } + 100% { + transform: translate(0,0); + } +} + + +/*SVG animations*/ + +.head { + animation: head-animation linear 5s infinite; +} +@keyframes head-animation { + 50% { + transform: translateY(175px) translateX(-50px); + } + 100% { + transform: translateY(170px) translateX(-50px); + + } +} + diff --git a/style/_color.scss b/style/_color.scss new file mode 100644 index 0000000..efa2c49 --- /dev/null +++ b/style/_color.scss @@ -0,0 +1,120 @@ +/* Variables */ +$scene1GradientDarkMode: linear-gradient( + 180deg, + rgb(4, 36, 48) 67%, + rgb(9, 129, 155) 67% +); +$scene1GradientLightMode: linear-gradient( + 180deg, + rgba(157, 221, 247, 1) 67%, + rgb(83, 154, 184) 67% +); +$scene2GradientDarkMode: linear-gradient( + 180deg, + rgba(9, 129, 155) 22%, + rgba(63, 106, 124, 1) 66% +); +$scene2Gradient: linear-gradient( + 180deg, + rgba(83, 154, 184, 1) 22%, + rgba(63, 106, 124, 1) 66% +); +$scene3Gradient: linear-gradient( + 180deg, + rgba(63, 106, 124, 1) 22%, + rgba(15, 48, 62, 1) 73% +); +$scene4Gradient: linear-gradient( + 180deg, + rgba(15, 48, 62, 1) 22%, + rgba(0, 0, 0, 1) 73% +); +$scene5Gradient: black; +$darkSceneFontColor: white; +$trashcanBackground: lightblue; +$urlWave: url(../images/wave.png); + +/*Applying colors*/ +/*dark mode */ +@media (prefers-color-scheme: dark) { + .scene1 { + background: $scene1GradientDarkMode; + } + .sun { + background: url(../images/moon.png); + } + .scene2 { + background: $scene2GradientDarkMode; + } +} + +/*light mode */ +@media (prefers-color-scheme: light) { + .scene1 { + background: $scene1GradientLightMode; + } + .sun { + background: url(../images/sun.png); + } + + .scene2 { + background: $scene2Gradient; + } +} + +body { + background-color: $scene5Gradient; + color: $darkSceneFontColor; +} + +a{ + color: $darkSceneFontColor; +} + +/*Wave url*/ +.waves__1 { + background: $urlWave; +} +.waves__2 { + background: $urlWave; +} +.waves__3 { + background: $urlWave; +} +.waves__4 { + background: $urlWave; +} +.scene3 { + background: $scene3Gradient; +} +.scene4 { + background: $scene4Gradient; +} +.scene5 { + background: $scene5Gradient; +} +.scene6 { + background: $scene5Gradient; +} +.scene7 { + background-color: $scene5Gradient; +} + +.scene8 { + background-color: $scene5Gradient; +} + +.scene9{ + background-color: $trashcanBackground; +} + +.scene10{ + background-color: $trashcanBackground; +} +.clouds__1>*, .clouds__2>*{ + background-color: white; +} + +main { + background-color: $scene5Gradient; +} diff --git a/style/_font.scss b/style/_font.scss new file mode 100644 index 0000000..684ae52 --- /dev/null +++ b/style/_font.scss @@ -0,0 +1,17 @@ +body { + font-family: sans-serif; +} + +.text-container, +p { + font-size: 1.7rem; +} + +h3 { + font-size: 5rem; + text-align: center; +} + +h4{ + font-size: 8vw; +} diff --git a/style/_layout.scss b/style/_layout.scss new file mode 100644 index 0000000..19f56e4 --- /dev/null +++ b/style/_layout.scss @@ -0,0 +1,346 @@ +body { + margin: 0; +} +a{ +text-decoration: none; +} + +/* Gives the first 5 scenes a grid layout */ +main { + & > div:nth-of-type(-n + 5) { + display: grid; + grid-template-columns: 1fr 1fr; + grid-template-rows: 1fr 1fr; + position: relative; + } +} + +/* styles the size of the textboxes */ +.text-container { + width: 30vw; + margin: 0 auto; + opacity: 0; + position: sticky; + top: 25px; +} + +/* general layout for side plant images*/ +.plant-container__background-plants-right { + width: 9vw; + float: right; + opacity: 0; +} + +.plant-container { + overflow: hidden; +} + +.plant-container__background-plants-left { + width: 9vw; + opacity: 0; +} + +/* Style for scene 1 and the elenent in it */ +.scene1__content-bottle { + position: absolute; + width: 5vw; + left: 32vw; + transform: translateY(4vw); + z-index: 2; +} +.clouds{ + display: grid; + grid-template-columns: 1fr 1fr; + margin-top: 10%; + margin-left: 10%; +} +.clouds__1, .clouds__2{ + display: grid; + grid-template-columns: 1fr 1fr 1fr; + width: 100px; + height: 10px; +} +.clouds__1>*, .clouds__2>*{ + border-radius: 0; + border-top-left-radius: 50% 100%; + border-top-right-radius: 50% 100%; +} +.clouds__1{ + margin-top: 30%; +} +.clouds__1--1, .clouds__2--1{ + width:40px; + height:20px; +} +.clouds__1--2, .clouds__2--2{ + margin-left: -8px; + margin-top: 5px; + height: 15px; + width: 50px; +} +.clouds__1--3, .clouds__2--3{ + margin-left: 20px; + margin-top: 10px; + height: 10px; +width: 35px; +} + +.scene1__content-dock { + position: relative; + width: 50vw; + z-index: 2; +} +.sun { + background-size: contain; + background-repeat: no-repeat; + width: 30%; +} + +.scene1__content-man { + width: 10%; + position: absolute; + margin-top: -3%; + left: -50%; + z-index: 3; +} + +.waves { + position: absolute; + width: 100vw; + top: 58%; + transform: translateY(-50%); + z-index: 0; +} + +.waves__1 { + position: absolute; + top: 0vh; + left: 0vw; + width: 100vw; + height: 100px; + background-repeat: repeat-x; + background-size: 1000px 100px; + opacity: 0.7; +} + +.waves__2 { + position: absolute; + bottom: 20vh; + left: 0vw; + top: 0vh; + width: 100vw; + height: 100px; + background-repeat: repeat-x; + background-size: 1000px 100px; + opacity: 0.6; +} + +.waves__3 { + position: absolute; + bottom: 20vh; + left: 0vw; + top: 0vh; + width: 100vw; + height: 100px; + background-repeat: repeat-x; + background-size: 1000px 100px; + opacity: 1; +} + +.waves__4 { + position: absolute; + top: 0vh; + left: -10vw; + width: 100vw; + height: 100px; + background-repeat: repeat-x; + background-size: 1000px 100px; + opacity: 0.5; +} + +/* Style for scene 6 */ +.scene6 { + height: 100vh; + h3 { + position: sticky; + top: 50vh; + margin: 7vw 0; + z-index: 3; + } +} + +/* Styling scene 7 and 8 */ +.scene7 { + height: 100vh; + background-image: url("../images/healthy-earth.png"); + background-repeat: no-repeat; + background-position: center; + background-attachment: fixed; + + div { + height: 100vh; + } +} + +.scene8 { + height: 100vh; + background-image: url("../images/dead-earth.png"); + background-repeat: no-repeat; + background-position: center; + background-attachment: fixed; +} + +/* Style for scene 9 */ +.scene9 { + height: 120vh; + + .scene9__img-container { + display: grid; + grid-template-columns: 1fr 1fr 1fr 1fr 1fr; + margin: 3vw 0; + position: sticky; + top: 5vw; + left: 40vw; + + img { + opacity: 0; + width: 10vw; + margin: 0 auto; + } + } + + .scene9__trash-bin { + position: relative; + width: 20vw; + min-width: 200px; + z-index: 2; + left: 40vw; + } + + h3 { + margin: 0; + padding-top: 5vw; + } +} +.scene10 { + display: grid; + place-items: center; + height: 100vh; + text-align: center; + max-width: 100%; +} + + +/*SVG*/ + +.head { + transform: translateY(170px) translateX(-50px); +} + +.hair { + transform: scale(0.2) translateY(1100px) translateX(300px) rotate(-15deg); +} + +.left-eye__pupil { + transform: translateX(0.4vw) translateY(-0.4vh); +} + +.left-eye { + transform: translateY(120px) translateX(-20px); +} +.right-eye__pupil { + transform: translateX(5px) translateY(-4px); +} + +.right-eye { + transform: translateY(120px) translateX(18px); +} +.mouth { + transform: translateY(350px) translateX(120px) scale(0.15); +} +@media (orientation: landscape) { + .speech-bubble { + transform: translateX(120px) translateY(45px) rotate(9deg) scale(1.1); + } + .head-speech { + transform: translateY(-20vh) translateX(-17vw); + } + .tshirt { + transform: scale(0.4) translateY(-1080px) translateX(-80vw); + } + + +.pop-up{ + display: none; +} +} + +@media (orientation: portrait) { + .speech-bubble { + transform: translateX(120px) translateY(45px) rotate(9deg) scale(1.1); + } + .head-speech { + transform: translateY(4vh) translateX(-13vw); + } + .tshirt { + transform: scale(0.4) translateY(-1200px) translateX(-105vw); + } + + main{ + display: none; + } + .pop-up{ + display: grid; + place-items: center; + font-size: 50px; + margin-top: 25vh; + img{ + width: 50vw; + filter: invert(100); + margin: 0 auto; + } + } +} + +/* Style fishes */ +.plant-container__scene2Fish1{ + width: 10vw; + z-index: 0; + opacity: 20%; +} + +.scene2__scene2Fish2{ + width: 10vw; + z-index: 0; + opacity: 30%; +} + +.plant-container__fish1{ + width: 7vw; + z-index: 0; + opacity: 90%; +} + +.plant-container-fish1{ + width: 7vw; + z-index: 0; + opacity: 10%; +} + +.scene3__scene3Fish2{ + width: 7vw; + z-index: 0; + opacity: 45%; +} + +.scene4__scene4Fish1{ + width: 15vw; + z-index: 0; + opacity: 65%; +} + +.scene5__scene5Fish1{ + width: 15vw; + z-index: 0; + opacity: 65%; +} diff --git a/style/index.css b/style/index.css new file mode 100644 index 0000000..020de5c --- /dev/null +++ b/style/index.css @@ -0,0 +1,873 @@ +/* Variables */ +/*Applying colors*/ +/*dark mode */ +@media (prefers-color-scheme: dark) { + .scene1 { + background: linear-gradient(180deg, rgb(4, 36, 48) 67%, rgb(9, 129, 155) 67%); + } + .sun { + background: url(../images/moon.png); + } + .scene2 { + background: linear-gradient(180deg, rgb(9, 129, 155) 22%, rgb(63, 106, 124) 66%); + } +} +/*light mode */ +@media (prefers-color-scheme: light) { + .scene1 { + background: linear-gradient(180deg, rgb(157, 221, 247) 67%, rgb(83, 154, 184) 67%); + } + .sun { + background: url(../images/sun.png); + } + .scene2 { + background: linear-gradient(180deg, rgb(83, 154, 184) 22%, rgb(63, 106, 124) 66%); + } +} +body { + background-color: black; + color: white; +} + +h4 { + border-bottom: solid white 5px; +} + +a { + color: white; +} + +/*Wave url*/ +.waves-1 { + background: url(../images/wave.png); +} + +.waves-2 { + background: url(../images/wave.png); +} + +.waves-3 { + background: url(../images/wave.png); +} + +.waves-4 { + background: url(../images/wave.png); +} + +.scene3 { + background: linear-gradient(180deg, rgb(63, 106, 124) 22%, rgb(15, 48, 62) 73%); +} + +.scene4 { + background: linear-gradient(180deg, rgb(15, 48, 62) 22%, rgb(0, 0, 0) 73%); +} + +.scene5 { + background: black; +} + +.scene6 { + background: black; +} + +.scene7 { + background-color: black; +} + +.scene8 { + background-color: black; +} + +.scene9 { + background-color: lightblue; +} + +.scene10 { + background-color: lightblue; +} + +.man__head { + background-color: black; +} + +.man__body { + background-color: black; +} + +.man__leg > * { + background-color: black; +} + +main { + background-color: black; +} + +body { + margin: 0; +} + +a { + text-decoration: none; +} + +/* Gives the first 5 scenes a grid layout */ +main > div:nth-of-type(-n + 5) { + display: grid; + grid-template-columns: 1fr 1fr; + grid-template-rows: 1fr 1fr; + position: relative; +} + +/* styles the size of the textboxes */ +.scene-text-conteiner { + width: 30vw; + margin: 0 auto; + opacity: 0; + position: sticky; + top: 25px; +} + +/* general layout for side plant images*/ +.background-plants-right { + width: 9vw; + float: right; + opacity: 0; +} + +.plantContainer { + overflow: hidden; +} + +.background-plants-left { + width: 9vw; + opacity: 0; +} + +/* Style for scene 1 and the elenent in it */ +.bottle { + position: absolute; + width: 5vw; + left: 32vw; + transform: translateY(4vw); + z-index: 2; +} + +.cloud { + width: 50%; +} + +.dock { + position: relative; + width: 50vw; + z-index: 2; +} + +.sun { + background-size: contain; + background-repeat: no-repeat; + width: 30%; +} + +.man { + width: 10%; + position: absolute; + margin-top: -3%; + left: -50%; + z-index: 3; +} + +.waves { + position: absolute; + width: 100vw; + top: 58%; + transform: translateY(-50%); + z-index: 0; +} + +.waves-1 { + position: absolute; + top: 0vh; + left: 0vw; + width: 100vw; + height: 100px; + background-repeat: repeat-x; + background-size: 1000px 100px; + opacity: 0.7; +} + +.waves-2 { + position: absolute; + bottom: 20vh; + left: 0vw; + top: 0vh; + width: 100vw; + height: 100px; + background-repeat: repeat-x; + background-size: 1000px 100px; + opacity: 0.6; +} + +.waves-3 { + position: absolute; + bottom: 20vh; + left: 0vw; + top: 0vh; + width: 100vw; + height: 100px; + background-repeat: repeat-x; + background-size: 1000px 100px; + opacity: 1; +} + +.waves-4 { + position: absolute; + top: 0vh; + left: -55vw; + width: 100vw; + height: 100px; + background-repeat: repeat-x; + background-size: 1000px 100px; + opacity: 0.5; +} + +/* Style for scene 6 */ +.scene6 { + height: 100vh; +} +.scene6 h3 { + position: sticky; + top: 50vh; + margin: 7vw 0; + z-index: 3; +} + +/* Styling scene 7 and 8 */ +.scene7 { + height: 100vh; + background-image: url("../images/healthy-earth.png"); + background-repeat: no-repeat; + background-position: center; + background-attachment: fixed; +} +.scene7 div { + height: 100vh; +} + +.scene8 { + height: 100vh; + background-image: url("../images/dead-earth.png"); + background-repeat: no-repeat; + background-position: center; + background-attachment: fixed; +} + +/* Style for scene 9 */ +.scene9 { + height: 120vh; +} +.scene9 .img-container { + display: grid; + grid-template-columns: 1fr 1fr 1fr 1fr 1fr; + margin: 3vw 0; + position: sticky; + top: 5vw; + left: 40vw; +} +.scene9 .img-container img { + opacity: 0; + width: 10vw; + margin: 0 auto; +} +.scene9 .trash-bin { + position: relative; + width: 20vw; + min-width: 200px; + z-index: 2; + left: 40vw; +} +.scene9 h3 { + margin: 0; + padding-top: 5vw; +} + +.scene10 { + display: grid; + place-items: center; + height: 100vh; + text-align: center; +} +.scene10 .linkContainer { + padding: 100px 20px 0; + margin: 0 auto; +} +.scene10 h4 { + margin: 0; + text-align: center; + overflow: hidden; + line-height: 1; +} +.scene10 h4:hover { + transition: 0.2s; + cursor: pointer; + transform: skewX(-5deg); +} + +/* Style fishes */ +.scene2Fish1 { + width: 10vw; + z-index: 0; + opacity: 20%; +} + +.scene2Fish2 { + width: 10vw; + z-index: 0; + opacity: 30%; +} + +.scene3Fish1 { + width: 7vw; + z-index: 0; + opacity: 90%; +} + +.scene3Fish2 { + width: 7vw; + z-index: 0; + opacity: 10%; +} + +.scene3Fish2 { + width: 7vw; + z-index: 0; + opacity: 45%; +} + +.scene4Fish1 { + width: 15vw; + z-index: 0; + opacity: 65%; +} + +.scene5Fish1 { + width: 15vw; + z-index: 0; + opacity: 65%; +} + +body { + font-family: sans-serif; +} + +.scene-text-conteiner, +p { + font-size: 2.7ch; +} + +h3 { + font-size: 5rem; + text-align: center; +} + +h4 { + font-size: 8vw; +} + +@keyframes textboxInn { + 0% { + transform: translateY(0); + opacity: 0; + } + 100% { + transform: translateY(-40px); + opacity: 1; + } +} +@keyframes plantLeftInn { + 0% { + opacity: 1; + transform: rotate(13deg) translateX(-90px); + } + 40% { + opacity: 1; + transform: rotate(38deg) translateX(0px); + } + 60% { + opacity: 1; + transform: rotate(38deg) translateX(0px); + } + 80% { + opacity: 1; + transform: rotate(38deg) translateX(0px); + } + 100% { + opacity: 1; + transform: rotate(38deg) translateX(0px); + } +} +@keyframes plantRightInn { + 0% { + opacity: 1; + transform: rotate(-13deg) translateX(90px); + } + 40% { + opacity: 1; + transform: rotate(-30deg) translateX(0px); + } + 60% { + opacity: 1; + transform: rotate(-30deg) translateX(0px); + } + 80% { + opacity: 1; + transform: rotate(-30deg) translateX(0px); + } + 100% { + opacity: 1; + transform: rotate(-30deg) translateX(0px); + } +} +@keyframes bottleThrow { + 0% { + transform: translateY(4vw); + } + 60% { + transform: translateX(20vw) translateY(-20vw) rotate(-200deg); + } + 100% { + transform: translateX(17vw) translateY(10vw) rotate(-400deg); + position: fixed; + } +} +@keyframes trashbinFixedAnimation { + 100% { + position: sticky; + top: 23vw; + left: 40vw; + } +} +.trashBinFixed { + animation-name: trashbinFixedAnimation; + animation-fill-mode: forwards; +} + +.showTrashExample1 { + animation-name: textboxInn; + transition: 0.8s; + animation-duration: 1s; + animation-delay: 0.3s; + animation-fill-mode: forwards; +} + +.showTrashExample2 { + animation-name: textboxInn; + transition: 0.8s; + animation-duration: 1s; + animation-delay: 0.6s; + animation-fill-mode: forwards; +} + +.showTrashExample3 { + animation-name: textboxInn; + transition: 0.8s; + animation-duration: 1s; + animation-delay: 0.9s; + animation-fill-mode: forwards; +} + +.showTrashExample4 { + animation-name: textboxInn; + transition: 0.8s; + animation-duration: 1s; + animation-delay: 1.2s; + animation-fill-mode: forwards; +} + +.showTrashExample5 { + animation-name: textboxInn; + transition: 0.8s; + animation-duration: 1s; + animation-delay: 1.5s; + animation-fill-mode: forwards; +} + +.showTextAnimation { + animation-name: textboxInn; + transition: 0.8s; + animation-duration: 1s; + animation-delay: 0.7s; + animation-fill-mode: forwards; +} + +.showPlantLeftAnimation { + animation-name: plantLeftInn; + transition: 0.8s; + animation-duration: 3s; + animation-delay: 0.9s; + animation-fill-mode: forwards; +} + +.showPlantRightAnimation { + animation-name: plantRightInn; + animation-duration: 1s; + animation-delay: 0.9s; + animation-fill-mode: forwards; +} + +.throwBottleAnimation { + animation-name: bottleThrow; + transition: 2s; + animation-duration: 3s; + animation-delay: 2s; + animation-fill-mode: forwards; +} + +.sun { + animation-name: sunMove; + animation-duration: 2s; + animation-iteration-count: infinite; + animation-direction: alternate; +} + +@keyframes sunMove { + 0% { + transform: scale(0.7); + } + 100% { + transform: scale(0.8); + } +} +/* Man animations */ +.man { + animation: walking 0.6s infinite, man-walking 5s forwards; +} + +@keyframes walking { + 0% { + transform: translateY(0); + } + 50% { + transform: translateY(-20px); + } + 100% { + transform: translateY(0); + } +} +@keyframes man-walking { + 0% { + left: -50%; + } + 50% { + left: 25%; + } + 100% { + left: -50%; + } +} +/*Waves animation*/ +.waves-1 { + animation: animate__wave-1 10s linear; + animation-iteration-count: 1000; +} + +@keyframes animate__wave-1 { + 0% { + background-position-x: 0vw; + } + 100% { + background-position-x: -80vw; + } +} +.waves-2 { + animation: animate__wave-2 20s linear infinite; + animation-delay: 0s; +} + +@keyframes animate__wave-2 { + 0% { + background-position-x: 0vw; + } + 100% { + background-position-x: 80vw; + } +} +.waves-3 { + animation: animate__wave-3 10s linear infinite; + animation-delay: 5s; +} + +@keyframes animate__wave-3 { + 0% { + background-position-x: 10vw; + } + 100% { + background-position-x: -100vw; + } +} +.waves-4 { + animation: animate__wave-4 30s linear; + z-index: 1000; + animation-iteration-count: 1000; +} + +@keyframes animate__wave-4 { + 0% { + background-position-x: 0vw; + } + 100% { + background-position-x: 80vw; + } +} +/* MEDIA CODE */ +/* reduce motion*/ +@media (prefers-reduced-motion) { + /*Sun animation*/ + .sun { + animation-name: sunMove 2s infinite alternate; + } + @keyframes sunMove { + 0% { + transform: scale(0.8); + } + 100% { + transform: scale(0.8); + } + } + /*Waves animation*/ + .waves-1 { + animation: animate__wave-1 50s linear; + animation-iteration-count: 1000; + } + @keyframes animate__wave-1 { + 0% { + background-position-x: 0vw; + } + 100% { + background-position-x: -80vw; + } + } + .waves-2 { + animation: animate__wave-2 30s linear infinite; + animation-delay: 0s; + } + @keyframes animate__wave-2 { + 0% { + background-position-x: 0vw; + } + 100% { + background-position-x: 80vw; + } + } + .waves-3 { + animation: animate__wave-3 20s linear infinite; + animation-delay: 5s; + } + @keyframes animate__wave-3 { + 0% { + background-position-x: 10vw; + } + 100% { + background-position-x: -100vw; + } + } + .waves-4 { + animation: animate__wave-4 40s linear infinite; + } + @keyframes animate__wave-4 { + 0% { + background-position-x: 0vw; + } + 100% { + background-position-x: 80vw; + } + } + @keyframes bottleThrow { + 0% { + transform: translateY(4vw); + } + 60% { + transform: translateX(20vw) translateY(-5vw); + } + 100% { + transform: translateX(20vw) translateY(10vw); + position: fixed; + } + } +} +/* Fish animations */ +@keyframes fishSwimAnimation1 { + 0% { + transform: translateY(0); + left: 0; + } + 25% { + transform: translateY(30px); + } + 49% { + transform: translateY(0px); + left: 90vw; + } + 50% { + transform: scalex(-1); + } + 75% { + transform: translateY(50px) scalex(-1); + } + 100% { + transform: translateY(0px) scalex(-1); + left: 0; + } +} +@keyframes fishSwimAnimation2 { + 0% { + transform: translateY(0); + left: 0; + } + 25% { + transform: translateY(30px); + } + 49% { + transform: translateY(0px); + left: 90vw; + } + 50% { + transform: scalex(-1); + } + 75% { + transform: translateY(50px) scalex(-1); + } + 100% { + transform: translateY(0px) scalex(-1); + left: 0; + } +} +@keyframes fishSwimAnimation3 { + 0% { + transform: translateY(0); + left: 0; + } + 25% { + transform: translateY(30px); + } + 49% { + transform: translateY(0px); + left: 40vw; + } + 50% { + transform: scalex(-1); + } + 75% { + transform: translateY(50px) scalex(-1); + } + 100% { + transform: translateY(0px) scalex(-1); + left: 0; + } +} +@keyframes fishSwimAnimation4 { + 0% { + transform: translateY(0); + left: 0; + } + 25% { + transform: translateY(30px); + } + 49% { + transform: translateY(0px); + left: 3vw; + } + 50% { + transform: scalex(-1); + } + 75% { + transform: translateY(50px) scalex(-1); + } + 100% { + transform: translateY(0px) scalex(-1); + left: 0; + } +} +@keyframes fishSwimAnimation5 { + 0% { + transform: translateY(0); + left: 80vw; + } + 25% { + transform: translateY(30px); + } + 49% { + transform: translateY(0px); + left: 70vw; + } + 50% { + transform: scalex(-1); + } + 75% { + transform: translateY(50px) scalex(-1); + } + 100% { + transform: translateY(0px) scalex(-1); + left: 80vw; + } +} +.scene2Fish1 { + position: absolute; + animation-name: fishSwimAnimation1; + animation-duration: 35s; + animation-iteration-count: infinite; +} + +.scene2Fish2 { + position: absolute; + animation-name: fishSwimAnimation3; + animation-duration: 35s; + animation-iteration-count: infinite; +} + +.scene3Fish1 { + position: absolute; + animation-name: fishSwimAnimation2; + animation-duration: 20s; + animation-iteration-count: infinite; +} + +.scene3Fish2 { + position: absolute; + animation-name: fishSwimAnimation3; + animation-delay: 2s; + animation-duration: 25s; + animation-iteration-count: infinite; +} + +.scene4Fish1 { + position: absolute; + animation-name: fishSwimAnimation4; + animation-delay: 2s; + animation-duration: 15s; + animation-iteration-count: infinite; +} + +.scene5Fish1 { + position: absolute; + animation-name: fishSwimAnimation5; + animation-delay: 2s; + animation-duration: 15s; + animation-iteration-count: infinite; +} + +/* read more reveal */ +.revealanimation { + display: block; + animation-name: reveal; + animation-duration: 1.5s; + transition: cubic-bezier(0.77, 0, 0.175, 1); +} + +@keyframes reveal { + 0% { + transform: translate(0, 100%); + } + 100% { + transform: translate(0, 0); + } +}/*# sourceMappingURL=index.css.map */ diff --git a/style/index.css.map b/style/index.css.map new file mode 100644 index 0000000..54e5a3f --- /dev/null +++ b/style/index.css.map @@ -0,0 +1 @@ +{"version":3,"sources":["_color.scss","index.css","_layout.scss","_font.scss","_animations.scss"],"names":[],"mappings":"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","file":"index.css"} diff --git a/style/index.scss b/style/index.scss new file mode 100644 index 0000000..f0e533b --- /dev/null +++ b/style/index.scss @@ -0,0 +1,4 @@ +@import "./_color.scss"; +@import "./_layout.scss"; +@import "./_font.scss"; +@import "./_animations";