Inspired by: https://www.youtube.com/c/Hyperplexed
A recreation of the Zen shapes on https://karinasirqueira.com.
A Pen by Hyperplexed on CodePen.
Inspired by: https://www.youtube.com/c/Hyperplexed
A recreation of the Zen shapes on https://karinasirqueira.com.
A Pen by Hyperplexed on CodePen.
<div id="wrapper" data-configuration="1" data-roundness="1"> | |
<div class="shape"></div> | |
<div class="shape"></div> | |
<div class="shape"></div> | |
<div class="shape"></div> | |
<div class="shape"></div> | |
<div class="shape"></div> | |
<div class="shape"></div> | |
</div> | |
<a id="source-link" class="meta-link" href="https://karinasirqueira.com" target="_blank"> | |
<i class="fa-solid fa-link"></i> | |
<span>Source</span> | |
</a> | |
<a id="yt-link" class="meta-link" href="https://youtu.be/dhfQnmGXSwU" target="_blank"> | |
<i class="fa-brands fa-youtube"></i> | |
<span>3 min tutorial</span> | |
</a> |
const wrapper = document.getElementById("wrapper"); | |
const rand = (min, max) => Math.floor(Math.random() * (max - min + 1) + min); | |
const uniqueRand = (min, max, prev) => { | |
let next = prev; | |
while(prev === next) next = rand(min, max); | |
return next; | |
} | |
const combinations = [ | |
{ configuration: 1, roundness: 1 }, | |
{ configuration: 1, roundness: 2 }, | |
{ configuration: 1, roundness: 4 }, | |
{ configuration: 2, roundness: 2 }, | |
{ configuration: 2, roundness: 3 }, | |
{ configuration: 3, roundness: 3 } | |
]; | |
let prev = 0; | |
setInterval(() => { | |
const index = uniqueRand(0, combinations.length - 1, prev), | |
combination = combinations[index]; | |
wrapper.dataset.configuration = combination.configuration; | |
wrapper.dataset.roundness = combination.roundness; | |
prev = index; | |
}, 3000); |
body { | |
height: 100vh; | |
width: 100vw; | |
display: grid; | |
place-items: center; | |
background-color: black; | |
margin: 0px; | |
overflow: hidden; | |
} | |
#wrapper { | |
aspect-ratio: 1.618; | |
width: 90vmin; | |
position: relative; | |
} | |
#wrapper > .shape { | |
height: 30%; | |
width: 30%; | |
background-color: rgba(255 255 255 / 5%); | |
position: absolute; | |
transition: left, top, height, width, border-radius; | |
transition-duration: 750ms; | |
transition-timing-function: ease-in-out; | |
} | |
#wrapper > .shape:nth-child(1) { | |
background-color: rgb(176, 190, 197); | |
z-index: 2; | |
} | |
#wrapper > .shape:nth-child(2) { | |
background-color: rgb(245, 245, 245); | |
z-index: 2; | |
} | |
#wrapper > .shape:nth-child(3) { | |
background-color: rgb(155, 93, 229); | |
z-index: 1; | |
} | |
#wrapper > .shape:nth-child(4) { | |
background-color: rgb(241, 91, 181); | |
z-index: 2; | |
} | |
#wrapper > .shape:nth-child(5) { | |
background-color: rgb(254, 228, 64); | |
z-index: 2; | |
} | |
#wrapper > .shape:nth-child(6) { | |
background-color: rgb(0, 187, 249); | |
z-index: 2; | |
} | |
#wrapper > .shape:nth-child(7) { | |
background-color: rgb(0, 245, 212); | |
z-index: 2; | |
} | |
#wrapper[data-configuration="1"] > .shape:nth-child(1) { | |
left: 0%; | |
top: 0%; | |
height: 50%; | |
width: 20%; | |
} | |
#wrapper[data-configuration="1"] > .shape:nth-child(2) { | |
left: 20%; | |
top: 0%; | |
height: 50%; | |
width: 30%; | |
} | |
#wrapper[data-configuration="1"] > .shape:nth-child(3) { | |
left: 50%; | |
top: 0%; | |
height: 100%; | |
width: 50%; | |
} | |
#wrapper[data-configuration="1"] > .shape:nth-child(4) { | |
left: 0%; | |
top: 50%; | |
height: 50%; | |
width: 30%; | |
} | |
#wrapper[data-configuration="1"] > .shape:nth-child(5) { | |
left: 30%; | |
top: 50%; | |
height: 50%; | |
width: 20%; | |
} | |
#wrapper[data-configuration="1"] > .shape:nth-child(6) { | |
left: 70%; | |
top: 50%; | |
height: 50%; | |
width: 30%; | |
} | |
#wrapper[data-configuration="1"] > .shape:nth-child(7) { | |
left: 85%; | |
top: 75%; | |
height: 25%; | |
width: 15%; | |
} | |
#wrapper[data-configuration="2"] > .shape:nth-child(1) { | |
left: 25%; | |
top: 20%; | |
height: 80%; | |
width: 15%; | |
} | |
#wrapper[data-configuration="2"] > .shape:nth-child(2) { | |
left: 40%; | |
top: 20%; | |
height: 50%; | |
width: 10%; | |
} | |
#wrapper[data-configuration="2"] > .shape:nth-child(3) { | |
left: 50%; | |
top: 0%; | |
height: 100%; | |
width: 25%; | |
} | |
#wrapper[data-configuration="2"] > .shape:nth-child(4) { | |
left: 0%; | |
top: 0%; | |
height: 50%; | |
width: 10%; | |
} | |
#wrapper[data-configuration="2"] > .shape:nth-child(5) { | |
left: 10%; | |
top: 0%; | |
height: 70%; | |
width: 15%; | |
} | |
#wrapper[data-configuration="2"] > .shape:nth-child(6) { | |
left: 75%; | |
top: 10%; | |
height: 80%; | |
width: 15%; | |
} | |
#wrapper[data-configuration="2"] > .shape:nth-child(7) { | |
left: 90%; | |
top: 40%; | |
height: 60%; | |
width: 10%; | |
} | |
#wrapper[data-configuration="3"] > .shape:nth-child(1) { | |
left: 0%; | |
top: 16.5%; | |
height: 32%; | |
width: 20%; | |
} | |
#wrapper[data-configuration="3"] > .shape:nth-child(2) { | |
left: 20%; | |
top: 2.7%; | |
height: 55%; | |
width: 34%; | |
} | |
#wrapper[data-configuration="3"] > .shape:nth-child(3) { | |
left: 38%; | |
top: 0%; | |
height: 100%; | |
width: 62%; | |
} | |
#wrapper[data-configuration="3"] > .shape:nth-child(4) { | |
left: 0%; | |
top: 47.3%; | |
height: 55%; | |
width: 34%; | |
} | |
#wrapper[data-configuration="3"] > .shape:nth-child(5) { | |
left: 34%; | |
top: 56.4%; | |
height: 32%; | |
width: 20%; | |
} | |
#wrapper[data-configuration="3"] > .shape:nth-child(6) { | |
left: 66%; | |
top: 45%; | |
height: 55%; | |
width: 34%; | |
} | |
#wrapper[data-configuration="3"] > .shape:nth-child(7) { | |
left: 80%; | |
top: 68%; | |
height: 32%; | |
width: 20%; | |
} | |
#wrapper[data-roundness="1"] > .shape { | |
border-radius: 6rem; | |
} | |
#wrapper[data-roundness="2"] > .shape { | |
border-radius: 0rem; | |
} | |
#wrapper[data-roundness="3"] > .shape { | |
border-radius: 30rem; | |
} | |
#wrapper[data-roundness="4"] > .shape:nth-child(1) { | |
border-bottom-left-radius: 10rem; | |
} | |
#wrapper[data-roundness="4"] > .shape:nth-child(2) { | |
border-radius: 20rem; | |
} | |
#wrapper[data-roundness="4"] > .shape:nth-child(3) { | |
border-top-right-radius: 12rem; | |
} | |
#wrapper[data-roundness="4"] > .shape:nth-child(4) { | |
border-top-right-radius: 10rem; | |
border-bottom-right-radius: 10rem; | |
} | |
#wrapper[data-roundness="4"] > .shape:nth-child(5) { | |
border-bottom-left-radius: 10rem; | |
} | |
#wrapper[data-roundness="4"] > .shape:nth-child(6) { | |
border-top-left-radius: 16rem; | |
} | |
#wrapper[data-roundness="4"] > .shape:nth-child(7) { | |
border-top-left-radius: 10rem; | |
} | |
/* -- YouTube Link Styles -- */ | |
body.menu-toggled > .meta-link > span { | |
color: rgb(30, 30, 30); | |
} | |
#source-link { | |
bottom: 60px; | |
} | |
#source-link > i { | |
color: rgb(94, 106, 210); | |
} | |
#yt-link > i { | |
color: rgb(239, 83, 80); | |
} | |
.meta-link { | |
align-items: center; | |
backdrop-filter: blur(3px); | |
background-color: rgba(255, 255, 255, 0.05); | |
border: 1px solid rgba(255, 255, 255, 0.1); | |
border-radius: 6px; | |
bottom: 10px; | |
box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.1); | |
cursor: pointer; | |
display: inline-flex; | |
gap: 5px; | |
left: 10px; | |
padding: 10px 20px; | |
position: fixed; | |
text-decoration: none; | |
transition: background-color 400ms, border-color 400ms; | |
z-index: 10000; | |
} | |
.meta-link:hover { | |
background-color: rgba(255, 255, 255, 0.1); | |
border: 1px solid rgba(255, 255, 255, 0.2); | |
} | |
.meta-link > i, .meta-link > span { | |
height: 20px; | |
line-height: 20px; | |
} | |
.meta-link > span { | |
color: white; | |
font-family: "Rubik", sans-serif; | |
font-weight: 500; | |
} |