

* {
    box-sizing: border-box;
}



body {
    font-family: 'Outfit', sans-serif;
    /*font-family: Optima, Verdana, Arial;*/
    background-color: lightgray;
    margin: 0px;
}




.top-main {
    height: 20vw;
    min-height: 150px;
    background-image: linear-gradient(to bottom, rgb(43, 201, 245), rgb(0, 33, 222));
    border-width: 6px;
    border-bottom-width: 0px;
    border-color: rgb(174, 236, 255);
    border-style: solid;
    /*background-color: rgb(119, 216, 18);
    transition: background-color 12s;*/
}

.top-secondary {
    height: 10vw;
    min-height: 75px;
    background-image: linear-gradient(to bottom, rgb(0, 102, 255), rgb(0, 33, 222));
    border-width: 6px;
    border-bottom-width: 0px;
    border-color: rgb(174, 236, 255);
    border-style: solid;
    /*background-color: rgb(119, 216, 18);
    transition: background-color 12s;*/
}



.top-main img {
    height: 100%;
    display: block;
    margin: auto;
}

.top-secondary img {
    height: 60%;
    display: block;
    margin: 2vw auto;
}


.navbar {
    background-color: rgb(33, 56, 189);
    display: flex;
    border-top-width: 6px;
    border-right-width: 0px;
    border-left-width: 6px;
    border-bottom-width: 0px;
    border-color: rgb(174, 236, 255);
    border-style:solid;
    height: 5vw;
    min-height: 60px;
}

.navlink {
    flex: 25%;
    color: rgb(174, 236, 255);
    padding-top: 1vw;
    font-size: 2vw;
    text-decoration: none;
    text-align: center;
    border-width: 0px;
    border-right-width: 6px;
    border-color: rgb(174, 236, 255);
    border-style:solid;
    transition-duration: 200ms;
}

.navlink:hover {
    font-weight: 800;
    color: rgb(0, 47, 255);
    background-color:rgb(0, 187, 255);
}




/*.main-music {
    display: flex;
    flex-wrap: nowrap;
    height: fit-content;
}*/












.welcome {
    padding: 0px 24px;
    margin: 0vh 10vw 5vh 10vw;
    font-family: Optima;
}

.pageheader{
    font-size: 48px;
    font-family: Optima;
}

.welcome p {
    font-size: 28px;
}

/*.date {
    text-align: left;
    margin-left: 2vw;
    font-style: italic;
}*/

.main-home {
    /*min-height: 75vh;*/
    min-height: 80vh;
    background-color: rgb(0, 174, 255);
    background-image: url("images/bubbles.svg");
    background-size: 100vw, auto;
    background-position-y: 0px;
    padding: 20px 0px;
    border-width: 6px;
    border-bottom-width: 0px;
    border-style: solid;
    border-color: rgb(174, 236, 255);
    text-align: center;
    /*font-family: verdana, Geneva;*/

    animation-name: bubble_scroll;
    animation-duration: 25s;
    animation-iteration-count: infinite;
    animation-timing-function: linear;
}

@keyframes bubble_scroll {
    from {background-position-y: 0px;}
    to {background-position-y: -93.2vw;}
}

@keyframes bubble_scroll-minimum {
    from {background-position-y: 0px;}
    to {background-position-y: -699px}
}

@keyframes watercolors {
    0% {
        background-color:rgb(0, 174, 255);
    }

    33% {
        background-color:rgb(2, 78, 255);
    }

    67% {
        
        background-color:rgb(2, 213, 255);
    }

    100% {
        background-color:rgb(0, 174, 255);
    }
}





/* new stuff */

.pagetitle {
    text-align: center;
    color:rgb(236, 62, 227);
    font-size: 5vw;
    border-color: rgb(236, 8, 8);
    border-width: 0px;
    border-style: solid;
    background-color:rgb(174, 236, 255)
}

.main-panel {
    padding: 20px 40px;
    margin: 40px 8vw 20px 8vw;
    background-color:rgb(33, 56, 189);
    border-width: 6px;
    border-color: rgb(174, 236, 255);
    border-style: solid;
    border-radius: 5vw;
    font-size: 24px;
    color:rgb(174, 236, 255);
    text-align: center;
}

.main-panel h1 {
    font-size: 4vw;
    margin-top: 0vw;
    margin-bottom: 0vw;
}

.main-panel h3 {
    font-size: 5vw;
    margin-bottom: 1vw;
}

.articlePhoto {
    width: 60%;
}

.main-panel p {
    font-size: 2vw;
}

/*.welcome-panel h1 {
    font-size: 48pt;
    font-weight: 900;
    background: -webkit-linear-gradient(rgb(255, 204, 0), rgb(249, 81, 255));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    margin: 18px auto;
}*/

.logo-text {
    margin: 24px auto;
    height: auto;
    width: 60vw;
}

.subtitle {
    font-size: 4vw;
    margin: 10px auto;
    font-style: italic;
    color: rgb(174, 236, 255);
}






/* music page specific stuff */

.main-music {
    height: auto;
    background-color: rgb(0, 174, 255);
    background-image: url("images/bubbles.svg");
    background-size: 100vw, auto;
    background-position-y: 0px;
    padding: 0px 0px;
    /*border-top-width: 0px;
    border-left-width: 6px;
    border-right-width: 0px;*/
    border-width: 6px;
    border-bottom-width: 0px;
    border-style: solid;
    border-color: rgb(174, 236, 255);

    animation-name: bubble_scroll;
    animation-duration: 25s;
    animation-iteration-count: infinite;
    animation-timing-function: linear;

    
}


.musiclist {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    /*height: 120vw;*/
    height: fit-content;
}


.musicpanelbox {
    flex: 33%;
    /*border-style: solid;
    border-top-width: 6px;
    border-bottom-width: 0px;
    border-right-width: 6px;
    border-left-width: 0px;
    border-color:rgb(174, 236, 255);*/
    padding: 4vw 0;
}


.musicpanel {
    margin: auto;
    background-color: rgb(154, 231, 255);
    /*rgb(33, 56, 189)*/
    height: 34vw;
    width: 25vw;
    padding-top: 5%;
    font-family:'Gill Sans', 'Gill Sans MT', Calibri, 'Trebuchet MS', sans-serif;
    text-align: center;
    border-width: 6px;
    border-color:rgb(226, 248, 255);
    border-style:solid;
    border-radius: 4%;
}

.musicpanel a {
    margin: auto;
    font-size: 2vw;
    text-decoration: none;
    color:rgb(0, 69, 106);
    /*color:rgb(174, 236, 255);*/
    font-weight: 600;
}
.musicpanel img {
    height: 70%;
    background-color: none;
    max-width: 23vw;
}




.main-musicselection {
    min-height: 80vh;
    background-color:rgb(0, 45, 62);
    background-size: 100vw, auto;
    background-position-y: 0px;
    padding: 20px 0px;
    border-width: 6px;
    border-bottom-width: 0px;
    border-style: solid;
    border-color: rgb(174, 236, 255);
    text-align: center;
    color:rgb(174, 236, 255);
}

.main-musicselection h1 {
    font-size: 4vw;
}

.main-musicselection h2 {
    font-size: 22pt;
    font-style: none;
    font-weight: 600;
    margin: 20px 10px;
}
.main-musicselection h3 {
    font-size: 16pt;
    font-style: italic;
    font-weight: normal;
    margin: 16px 10px;
}

.main-musicselection p {
    font-size: 14pt;
    font-weight: normal;
    margin: 0px 10px;
}

.main-musicselection em {
    font-weight: bold;
    font-style: italic;
}

.separator {
    font-weight: bold;
    font-size: 20pt;
}

.main-musicselection ul {
    padding-left: 0;
    align-items: center;
    list-style: none;
    font-size: 14pt;
    font-weight: normal;
    margin: 0px 10px;
}

.musicselection-content {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items:normal;
    height: fit-content;
}

.contentbox {
    width: 50vw;
    /*border-width: 3px;
    border-style:solid;*/

}

.contentbox img{
    width: 90%;
    /*background-color: greenyellow;*/
}

/* end of new stuff */


.bottom {
    color: rgb(174, 236, 255);
    background-color: rgb(33, 56, 189);
    border-color: rgb(174, 236, 255);
    border-width: 6px;
    border-style: solid;
    padding: 1.6vw;
    font-size: 2vw;
    font-style: italic;
    height: 7vw;
    min-height: 50px;

}



.article-home {
    padding: 20px 40px;
    margin: 0vh 8vw 3vh 8vw;
    background-color: rgb(0, 33, 222);
    border-width: 4px;
    border-color: rgb(174, 236, 255);
    border-style: solid;
    border-radius: 8vw;
    font-size: 24px;
}

.headerline {
    border-width: 2px;
    border-style: solid;
    width: 75%;
}

/*.groovy:hover {
    animation: spin 500ms;
    animation-iteration-count: infinite;
    animation-timing-function: linear;
}

.slowgroove:hover {
    animation: spin 1000ms;
    animation-iteration-count: infinite;
    animation-timing-function: linear;
}

@keyframes spin {
    0% {transform: translate(0px, 0px) rotate(0deg);}
    25% {transform: translate(20px, 10px) rotate(10deg);}
    50% {transform: translate(0px, 0px) rotate(0deg);}
    75% {transform: translate(-20px, 10px) rotate(-10deg);}
}*/


.sliderbox {
    margin: auto;
    width: 90%;
}


.slider {
    -webkit-appearance: none;
    appearance: none;
    width: 100%;
    height: 2vw;
    background: rgb(30, 67, 171);
    outline: none;
    opacity: 0.8;
    -webkit-transition: 400ms;
    transition: 400ms;
    border-radius: 1vw;
    /*display: none;
    border-width: 3px;
    border-color: rgb(255, 0, 200);
    
    border-style: solid;*/
    animation-name: none;
    animation-duration:250ms;
    animation-fill-mode: forwards;
}

@keyframes toGradient {
    0%  {background-image: linear-gradient(to right, #1e41a9, #1e41a9);}
    16% {background-image: linear-gradient(to right, #5446bf, #673ca9);}
    33% {background-image: linear-gradient(to right, #8346d2, #ba2896);}
    49% {background-image: linear-gradient(to right, #b142e1, #ee2a72);}
    66% {background-image: linear-gradient(to right, #c83de6, #ff5846);}
    83% {background-image: linear-gradient(to right, #df36ea, #ff742d);}
    100% {background-image: linear-gradient(to right, rgb(245, 43, 238), rgb(255, 142, 3));}
}
@keyframes fromGradient {
    
    0% {background-image: linear-gradient(to right, rgb(245, 43, 238), rgb(255, 142, 3));}
    16% {background-image: linear-gradient(to right, #df36ea, #ff742d);}
    33% {background-image: linear-gradient(to right, #c83de6, #ff5846);}
    49% {background-image: linear-gradient(to right, #b142e1, #ee2a72);}
    66% {background-image: linear-gradient(to right, #8346d2, #ba2896);}
    83% {background-image: linear-gradient(to right, #5446bf, #673ca9);}
    100%  {background-image: linear-gradient(to right, #1e41a9, #1e41a9);}
}


.slider:hover {
    height: 2vw;
    opacity: 1;
}


.slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 2.5vw;
    height: 2.5vw;
    background: rgb(174, 236, 255);
    background-image: linear-gradient(to bottom right, rgb(255, 255, 255), rgb(30, 187, 255));
    cursor: pointer;
    border-radius: 50%;
    transition: 400ms;
}
  
.slider::-moz-range-thumb {
    width: 2.5vw;
    height: 2.5vw;
    background: rgb(174, 236, 255);
    cursor: pointer;
    border-radius: 50%;
}



.runtimetext {
   font-size: 2vw;
   font-weight: 800;
   margin: 0.4vw;
}


.musiccontrols {
    display: flex;
    margin: auto;
    background-color: rgb(30, 67, 171);
    width: 90%;
    height: fit-content;
    border-radius: 3vw;;
    opacity: 0.8;
    transition: 400ms;
    animation-name: none;
    animation-duration: 250ms;
    animation-fill-mode: forwards;
}

.musiccontrols:hover {
    opacity: 1;
}

.controlbutton {
    flex: 25%;
    background-color: rgb(72, 95, 117);
    color: rgb(174, 236, 255);
    
    padding: 3%;
    margin: 3% 6%;
    border-width: 3px;
    border-radius: 2vw;
    border-style: solid;
    border-color: rgb(136, 180, 193);
    transition-duration: 200ms;
}

.controlbutton:hover {
    background-color: rgb(82, 196, 230);
    /*background-image: linear-gradient(to bottom right, rgb(245, 43, 238), rgb(255, 142, 3));*/
    color: rgb(0, 102, 255);
    border-color: rgb(183, 223, 255);
}






@media screen and (max-width: 100vh){
    /*.main-music {
        flex-direction: column-reverse;
        height: fit-content;
    }

    .pageheader {
        font-size: 32px;
    }

    .welcome p {
        font-size: 16px;
    }

    .article-home {
        font-size: 16px;
        margin: 0vh 2vw 3vh 2vw;
        padding: 20px 8px;
    }*/

    
}

@media screen and (max-width: 1200px){
    .main-musicselection h1 {
        font-size: 36pt;
    }
    .runtimetext {
        font-size: 18pt;
    }
    .slider {
        height: 24px;
    }

    .slider::-webkit-slider-thumb {
        width: 30px;
        height: 30px;
    }
      
    .slider::-moz-range-thumb {
        width: 30px;
        height: 30px;
        background: rgb(174, 236, 255);
        cursor: pointer;
        border-radius: 50%;
    }

    .articlePhoto {
        width: 70%;
    }
}


@media screen and (max-width: 750px){
    .navlink {
        padding-top: 8px;
        font-size: 12pt;
    }

    .bottom {
        display: flex;
        flex-direction: column;
        padding: 12px;
        font-size: 15px;
    }

    .main-home {
        background-size: 750px auto;
        animation-name: bubble_scroll-minimum;
    }

    .main-panel h1 {
        font-size: 22pt;
    }
    
    .main-panel h3 {
        font-size: 28pt;
        margin-bottom: 1vw;
    }
    
    .articlePhoto {
        width: 80%;
    }
    
    .main-panel p {
        font-size: 12pt;;
    }

    
    .logo-text {
        margin: 24px auto;
        height: auto;
        width: 60vw;
    }
    
    .subtitle {
        font-size: 4vw;
        margin: 10px auto;
        font-style: italic;
    }



    .main-music {
        background-size: 750px auto;
        animation-name: bubble_scroll-minimum;
    }

    .musicpanelbox {
        flex: 100%;
    }

    .musiclist {
        height: fit-content;
    }

    .musicpanel {
        height: 85vw;
        width: 62.5vw;
        padding-top: 5%;
    }
    
    .musicpanel a {
        font-size: 5vw;
    }

    .musicpanel img {
        height: 70%;
        max-width: 57.5vw;
    }



    .musicselection-content {
        flex-direction: column;
    }

    .contentbox {
        width: 96vw;
        /*border-color:red;
        border-style: solid;
        border-width: 5px;*/
    
    }

    
}

/*@media screen and (max-height: 1000px){
    .top {
        background-color: black;
        height: 150px;
    }
}*/

/*@media screen and (max-height: 740px){
    .main-music {
        flex-direction: column-reverse;
        height: fit-content;
    }
    .lakeimg {
        height: 592px;
    }

    .pageheader {
        font-size: 32px;
    }

    .welcome p {
        font-size: 16px;
    }

    .article-home {
        font-size: 16px;
        margin: 0vh 2vw 3vh 2vw;
        padding: 20px 8px;
    }
}*/



/*.side {
    flex: 30%;
    background-color:rgb(0, 33, 222);
    padding: 20px;
    border-width: 7px;
    border-bottom-width: 0px;
    border-style: solid;
    border-color:rgb(174, 236, 255);
    text-align: center;
    overflow-y: auto;
    color:rgb(174, 236, 255);
}

.musictitle {
    font-size: 20pt;
}

.titleline {
    border-width: 1.5px;
    border-style: solid;
    border-color: white;
}

*/


/*
.composertext {
    display: none;
}




.lake {
    flex: 70%;
    overflow: scroll;
    white-space: nowrap;
    padding: 0px;
    position: relative;
}


.lakeimg {
    height: 80vh;
    width: auto;
    position: static;
}



.musicbutton {
    font-family: verdana, Geneva;
    font-size: 2vh;
    font-style: italic;
    background-color: rgb(64, 112, 216);
    color: white;
    position: absolute;
    padding: 3vh 4vh;
    border-width: 3px;
    border-color: black;
    border-style: solid;
    border-radius: 15px;
    transition-duration: 200ms;
    transform: translate(-50%, -50%);
}


.musicbutton:hover {
    background-color:rgb(64, 179, 255);
}*/

