@font-face {
        font-family: "Fraunces";
        src: url("Resources/Fonts/fraunces_120pt-light.woff2") format("woff2");
        font-weight: 100;
    }
@font-face {
        font-family: "Avenir";
        src: url("Resources/Fonts/avenir-lt-w01_35-light1475496.woff2") format("woff2");
        font-weight: 100;
    }
    
a{
    text-decoration: none;
    color: inherit;
}

body {
    margin: 0;
    background-color: white;
    color: grey;
    font-family: "Avenir", serif;
    }

header {
    align-items: center;

    position: fixed;
    top: 0px;
    width: 100%;
    height: min(40px, 100%);
    
    padding: 5vh 0vw 5vh 0vw;
    margin: 0 auto;
   
    z-index: 100;
    
    transition: opacity 0.2s linear;
    }
            
    #bio {
        display: flex;
        align-items: flex-start;
        justify-content: flex-start;
        }
         
        

        .other-site-title {
                font-family: "Fraunces", serif;
                font-weight: 100;
                font-size: 3vw;
                color: gray;
                position: fixed;
                margin: 0vh 25vw 20vh 25vw;
            }   
            .other-site-title:hover {
                color: black;
                }  
                a, .other-site-title {
                    transition: color 0.3s ease;
                }

    .other-nav{
        color: gray;
        position: fixed;
        margin: 0vh 0vw 0vh 35vw;
        display: grid;
        gap: 5vh;
    }
    
                a, .other-nav{ 
                        transition: opacity 0.4s ease;  
                    }


    .left-side {
        position: fixed;
        top: 0;
        flex: 0 0 40vw;
            transition: opacity 0.2s linear;
        }

    #bio-title {
        font-family: "Fraunces", serif;
        font-optical-sizing: auto;
        font-weight: 100;
        font-style: normal;
        font-size: 5vw;
        color: black;
                    
            position: fixed;
            bottom: 35vh;
            margin-left: 12vw;
            z-index: 2;
            }

    #other-pic { 
        width: 100%;
        height: 100vh;
        max-width: 33vw;
        object-fit: cover;
        margin-top: 0%;
        margin-bottom: 0%;
        }


    #bio-text {
        font-family: "Avenir", serif;
        font-optical-sizing: auto;
        font-weight: 100;
        font-style: normal;
        font-size: 0.75vw;
        line-height: 3vh;
        word-spacing: 0.2vw;
        text-align: justify;
        padding: 20vh 0vw 0vh 0vw;
        }   

    .right-side {
        position: relative;
        transition: opacity 0.2s linear;
        margin-left: 45vw;
        margin-right: 15vw;
        max-width: 80%;        
        }
#projects {
    gap: 10px 10px 10px 10px;
    padding: 15vh 0vw 0vh 0vw;
    margin: 0vh 50vw 0vh 0vw;
    columns: 300px 2;
}

.p-project-name {
  font-family: "Avenir", serif;
        font-weight: 70;
        font-style: normal;
        font-size: 1vw;
        overflow-wrap: break-word;
        color: white;
        position: absolute;
        opacity: 0;
        top: 150px;
        left: 50%;
        transform: translate(-50%, -50%);
        filter: brightness(2);
    }

    .album-art:hover .p-project-name {
        opacity: 1;
        filter:brightness(2);
        transition: opacity 2s ease;
    }

    .l-project-name {
  font-family: "Avenir", serif;
        font-weight: 70;
        font-style: normal;
        font-size: 1vw;
        overflow-wrap: break-word;
        color: white;
        position: absolute;
        opacity: 0;
        top: 100px;
        left: 50%;
        transform: translate(-50%, -50%);
        filter: brightness(2);
    }

    .album-art:hover .l-project-name {
        opacity: 1;
        filter:brightness(2);
        transition: opacity 2s ease;
    }


    .album-grid {
        padding: 15vh 0vw 0vh 0vw;
        display: grid;
        grid: auto / auto auto;
        justify-content:left;
        gap: 5vh 5vw;

}

    .album-art {
        position: relative;
        max-inline-size: 300px 300px;
        height: auto;
        width: auto;
        filter: brightness(1);
        }
        .album-art:hover {  
            filter: brightness(0.5);
            transition: filter 1s ease;
        }
         
        
    .album-title {
        font-family: "Avenir", serif;
        font-weight: 100;
        font-style: normal;
        font-size: 1vw;
        text-align: center;
        color: white;
        position: absolute;
        top: 40%;
        left: 50%;
        transform: translate(-50%, -50%);
        opacity: 0;
        z-index: 2;
    }

    .album-credits {
        font-family: "Avenir", serif;
        font-weight: 70;
        font-style: normal;
        font-size: 0.5vw;
        text-align: center;
        color: white;
        position: absolute;
        top: 60%;
        left: 50%;
        transform: translate(-50%, -50%);
        opacity: 0;
        z-index: 2;
    }

    .album-art:hover .album-title,
    .album-art:hover .album-credits {
        opacity: 1;
        filter:brightness(2);
        transition: opacity 2s ease;
    }
            .album-art::after .album-title,
            .album-art::after .album-credits {
                filter:brightness(2);
            }
            
                
    .bandcamp-embed{
        align-content: center;
        padding: 5vh 0vw 0vh 5vw;

    }

        .upcoming-title {
            text-align: right;
            font-family: "Fraunces", serif;
            font-size: 1.5vw;
            }

        .upcoming-dates {
            text-align: right;
            font-family: "Avenir", serif;
            font-size: 0.7vw;
            word-spacing: 0.3vw;
            color: inherit;
            }

            .upcoming-dates:hover {
                color: #940025;
                transition: 0.3s ease;
                cursor: pointer;
            }


        .previous-title {
            text-align: left;
            font-family: "Fraunces", serif;
            font-size: 1.5vw;
            padding: 3vh 0vw 0vh 0vw;
            }

        .year {
            text-align: center;
            font-family: "Fraunces", serif;
            font-size: 1vw;
            font-style: bold;
            color: #940025;
            }

        .previous-dates {
            text-align: left;
            font-family: "Avenir", serif;
            font-size: 0.75vw;
            word-spacing: 0.3vw;
            }


            #white-title {
        font-family: "Fraunces", serif;
        font-optical-sizing: auto;
        font-weight: 100;
        font-style: normal;
        font-size: 5vw;
        color: White;
        text-align: center;
            position: fixed;
                padding: 35vh 5vw;
                z-index: 2;
            }
.social {
    margin: 0 1vw;
    padding: 0px;
    font-size: 18px;
    transition: color 0.3s ease;
    color: #940025;
    
    
}
.social:hover {
    color: black;
}
a, .social {
    transition: color 0.3s ease;
}

.contact-footer {
    top: 35vh
}

.selected-page {
    color: #940025;
    }
        .button {
            position: relative;
                font-family: "Avenir", serif;
                font-optical-sizing: auto;
                font-weight: 100;
                font-style: normal;
                font-size: 10px; 
                text-align: inherit;   
            transition: color 0.3s ease;
            margin: 0vh 0vw;
            width: fit-content;
            height: 100%;
            }
            
                .button::after {              
                    content: "";
                    position: absolute;
                    left: 0;
                    bottom: -5px;
                    right: 0;
                    width: 0%;
                    background: black;
                    transition: width 0.5s ease;
                }
                    
                        a, button {
                            transition: color 0.3s ease;
                        }
                        .button:hover::after {
                            width: 100%;
                            height: 1px;
                            
                        }                    
            .initials {
                    font-family: "Fraunces", serif;
                    font-optical-sizing: auto;
                    font-weight: 100;
                    font-style: normal;
                    font-size: 1.2vw;
                    margin-top: 30px;
                    color: #940025;
                    text-align: center;
                    }
            .links {
                color: #940025;
                opacity: 0.7;
                padding: 0vh 0vw 0vh 0vw; 
            }

            
      
footer {
    height: auto;
    list-style: none;
    text-align: center;
    padding: 5vh 0vw 5vh 0vw;
    text-decoration: none; 
    list-style: none;
}
.created-by {
    font-family: "Fraunces", serif;
                    font-optical-sizing: auto;
                    font-weight: 100;
                    font-style: normal;
                    font-size: 0.5vw;
                    margin-top: 30px;
                    color: #940025;
                    text-align: center;
                    margin: 2px;
}

        /* Scroll reveal states: hidden by default, animate once visible */
        .fade-in-fast,
        .fade-in-slow,
        .fade-in-slowest {
            opacity: 1;
            transform: translateY(0px);
        }
        .fade-in-fast.is-visible {
            animation: fadeIn 1.5s ease forwards;
        }
        .fade-in-slow.is-visible {
            animation: fadeIn 3.5s ease forwards;
        }
        .fade-in-slowest.is-visible {
            animation: fadeIn 5.5s ease forwards;
        } 
       
            @keyframes fadeIn {
                from {
                    opacity: 0;
                    transform: translateY(10px);}
                to {
                    opacity: 1;
                    transform: translateY(0);}
                }

section {
    width: 100%;
    }
