@import url('https://fonts.googleapis.com/css2?family=Architects+Daughter&display=swap');

*{
    padding: 0;
    margin: 0;
}

:root{    
    --padding: 1rem;
    --size: 12rem;
    --gap: 0.65rem;
}

body{
    font-family: 'Architects Daughter', cursive;
    min-height: 100svh;
    width: 100%;
    overflow-x: hidden;
}

header{
    margin: 1rem 0rem;
}

div.grid-gallery{
    width: calc(100% - var(--padding) * 2);
    padding: var(--padding);
    min-height: 100%;
    display: grid;
    place-items: center;
}

ul{
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(var(--size), 100%), 1fr));    
    grid-auto-rows: minmax(min(var(--size), 100%), 1fr);
    grid-auto-flow: dense;
    grid-gap: var(--gap);
    width: 100%;
    list-style: none;
}

@keyframes start {
    0%{
        transform: scale(0.5) rotate(-27.5deg) translateX(-100%); 
        opacity: 0;
    }
    100%{
        transform: scale(1) rotate(0deg) translateX(0%);
        opacity: 1;
    }
}

ul>li{
    transform: scale(0.5) rotate(-67.5deg) translateX(-100%); 
    opacity: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    animation: start 0.7s ease-in-out forwards;
}

ul>li.grid-item-2x1{
    grid-column: span 2;
    grid-row: span 1;
}
ul>li.grid-item-3x2{
    grid-column: span 3;
    grid-row: span 2;
}
ul>li.grid-item-1x3{
    grid-column: span 1;
    grid-row: span 3;
}
ul>li.grid-item-1x2{
    grid-column: span 1;
    grid-row: span 2;
}
ul>li.grid-item-2x2{
    grid-column: span 2;
    grid-row: span 2;
}

ul>li>div.info{
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 100%;
    opacity: 0;
    transition: opacity 0.3s ease-in-out;
    overflow: hidden;
}

ul>li:hover>div.info{
    overflow: hidden;
    opacity: 1;
}

ul>li>div.info::before{
    content: '';
    width: 100%;
    height: 100%;
    position: absolute;
    background-color: greenyellow;
    scale: 0;
    border-radius: 500%;
    transition: all 0.3s ease-in-out;
    z-index: -1;
}

ul>li:nth-of-type(5n)>div.info::before{
    background-color: powderblue;
}
ul>li:nth-of-type(5n - 1)>div.info::before{
    background-color: purple;
}
ul>li:nth-of-type(5n - 2)>div.info::before{
    background-color: orange;
}
ul>li:nth-of-type(5n - 3)>div.info::before{
    background-color: red;
}

ul>li:hover>div.info::before{
    scale: 1;
    border-radius: 0%;
}

ul>li>div.info>*{
    font-size: 1rem;
    font-weight: 500;
}

ul>li>div.info>h2{
    font-size: 1.5rem;
    font-weight: 800;
}