body {
    background: white;
    min-height: 100vh;
    font-family: 'Inter';
    min-width: 400px;
}

#top_section {
    background-image: url(/static/images/eclass_piano_bg.png);
    background-size: cover;
    padding-bottom: 3rem;
}

#video_buttons_wrapper {
    margin: 0 3rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-between;
    height: 100%;
}

#video_buttons_wrapper .buttons {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

@media  screen and (max-width: 990px) {
    #video_buttons_wrapper {
        width: 80%;
        margin: auto;
    }

    #video_buttons_wrapper .buttons {
        display: none;
    }
}

@media screen and (max-width: 1200px) {
    #video_buttons_wrapper .buttons {
        margin-top: 2rem;
    }
}

#video {
    position: relative;
    padding-top: 56.25%;
}

#video #player {
    position: absolute;
    width: 100%;
    top: 0;
    height: 100%;
    border-radius: 20px;
}

/* */
.ec-title {
    font-family: "Linux Libertine O Regular";
    font-size: clamp(1.75rem, 3.2vw, 3rem);
    line-height: 1.2;
    color: rgba(120, 153, 168, 0.7);
    margin-bottom: .25rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 900;
}

.ec-title .new-badge {
    color: white;
    font-weight: 700;
    font-size: 1.5rem;
    margin-right: 0.5rem;
    text-transform: uppercase;
    font-family: "Inter";
    background: #D52819;
    padding: 0.5rem 0.7rem;
}


.ec-subtitle {
    font-weight: 700;
    font-size: clamp(1.1rem, 2.2vw, 1.75rem);
    color: #D52819;
    margin-bottom: 1rem;
}
.store-badge {
    height: 60px; /* provided image height */
    width: auto;
    transition: transform .15s ease, filter .15s ease;
    image-rendering: -webkit-optimize-contrast;
}
.store-badge:hover, .store-badge:focus {
    transform: translateY(-2px);
    filter: drop-shadow(0 0.25rem 0.5rem rgba(0,0,0,.15));
}
/* spacing between badges on small screens */
.badge-col { margin: .25rem .5rem; }
/* */

#album_section {
    background-color: #F5F3EC;
    padding: 4rem 0;
}

#camerata_album_img {
    width: 100%;
    box-shadow: 7px 7px 15px 0px rgba(0, 0, 0, 0.37);
}

#camerata_album_artist {
    font-weight: bold;
    margin-top: 2rem;
}

#camerata_album_artist a {
    color: black !important;
}

#camerata_album_title {
    font-size: 1.2rem;
    font-weight: 600;
}

#camerata_album_desc {
    font-style: italic;
}

/* track list */
.album-track-list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
.track-row {
    align-items: center;
    gap: 1rem;
    padding: 0.5rem 2rem;
    border-radius: 6px;
}

.track-row.active {
    background-color: #E6DCCC;
}

.small_playbtn_img {
	width: 2.5rem;
	height: 2.5rem;
	background-size: contain;
	display: inline-block;
	vertical-align: middle;
	background-repeat: no-repeat;
	margin-top:3px;
	border-radius: 10px;
	margin-bottom: 5px;
	cursor: pointer;
}

.track-row .track-title {
    font-weight: bold;
}

.track_playbtn .button-icon {
    font-size: 2rem;
    color: #7899A8;
}

.track-title-artists {
    flex: 1;
}

/* */

#uservids_section {
    background: white;
}

#popular_videos_header {
    color: #7899A8;
    font-style: normal;
    font-weight: 500;
    font-size: 2rem;
    text-align: center;
    margin: 1rem 0;
    margin-top: 3rem;
    margin-bottom: 3rem;
}

.ec-video-list .user-vid-image {
    object-fit: cover;
    max-width: 100%;
    border-radius: 8px;
}

.ec-video-list .user-vid-title {
    font-weight: bold;
}

.ec-video-list .user-vid-author {
    font-weight: 500;
}

.ec-video-list .user-vid-country {
    color: #666666;
    font-size: 0.8rem;
}

.user-vid-item-wrapper.active {
    background: #CADDE0;
}

.ec-video-list .user-vid-item-wrapper {
    margin: 0;
    padding: 0.5rem;
    cursor: pointer;
    border-radius: 12px;
}

.ec-video-list .user-vid-item-info {
    line-height: 1rem;
    margin-top: 0.5rem;
    align-items: flex-start;
}

.ec-video-list  .fanvid-author-img {
    width: 30px !important;
    height: 30px;
    object-fit: cover;
    border-radius: 50%;
}

#site_logo_wrapper {
    margin-right:2rem;
    display: flex;
    align-items: center;
    height: 100%;
    max-width: 250px;
}

#site_logo {
    width: 100%;
}

#view_cont {
    display: flex;
    margin-bottom: 1rem;
    color: white;
    align-items: baseline;
    text-transform: uppercase;
}

#view_number {
    font-size: 2.5rem;
    margin-right:1rem;
}

#pleasehelp_cont {
    color: white;
}

#pleasehelp_header {
   text-transform: uppercase;
}

#pleasehelp_socials {
    display: flex;
    justify-content: center;
    margin-top: 1rem;
    margin-bottom: 2rem;
    gap: 1rem;
}

@media screen and (max-width: 990px) {
    #pleasehelp_socials {
        margin-top: 3rem;
    }
}

#pleasehelp_socials .social-button-cont {
    flex-direction: column;
}

#pleasehelp_socials .social-button-cont .share-count {
    color:white;
}

#pleasehelp_socials .social-button-cont img {
    padding: 0;
}


#row4-social-buttons-wrapper {
    display: flex;
    justify-content: flex-end;
    margin: 1rem;
    gap: 1rem;
}

#sharevoice_section {
    background-image: url("/static/images/sharevoice_bg.png");
    background-size: cover;
    padding-bottom: 5rem;
    min-height: 95vh;
}

@media screen and (max-width: 990px) {
    #sharevoice_section {
        padding-bottom: 3rem;
        min-height: auto;
    }
}

#sharevoice_header {
    color: black;
    font-style: normal;
    font-weight: 500;
    font-size: 3rem;
    text-align: center;
    font-family: "Linux Libertine O Regular";
    margin-top: 2rem;
    margin-bottom: 1rem;
}

#sharevoice_desc {
    margin-top: 1rem;
    text-align: center;
}

#sharevoice_instructions {
    margin-top: 1rem;
    text-align: center;
}

#sharevoice_instructions ul {
    list-style-position: inside;
}

#slogan {
    font-size:2.5rem;
    color: rgba(120, 153, 168, 0.7);
    text-align: center;
    font-family: "Linux Libertine O Regular";
}

@media screen and (max-width: 990px) {
    #slogan {
        font-size:2rem;
    }
}

#sharevoice_button_wrapper {
    display: flex;
    align-items: center;
    justify-content: end;
    gap: 1rem;
    flex-direction: column;
}

#sharevoice_button_wrapper .mobile-buttons {
    display: none;
}

@media screen and (max-width: 990px) {
    #sharevoice_button_wrapper {
        justify-content: center;
    }

    #sharevoice_button_wrapper .mobile-buttons {
        display: contents;
    }
}

#sharevoice_button, #sharevoice_button:hover {
    text-decoration: none;
    color: white;
    background: #D52819 !important;
    width: 220px;
    text-align: center;
    font-size: 12px;
}

@media screen and (min-width: 990px) and (max-width: 1200px) {
    #sharevoice_button {
        width: 220px;
    }
}

.eclass_videos_button, .eclass_videos_button:hover,
.camerata_concert_button, .camerata_concert_button:hover {
    text-decoration: none;
    color: white;
    background: #7899A8 !important;
    width: 220px;
    text-align: center;
    font-size: 12px;
}

#pdf_download_button, #pdf_download_button:hover {
    text-decoration: none;
    color: white;
    background: #7899A8 !important;
    width: 220px;
    text-align: center;
    font-size: 12px;
}


.round-button .button-icon {
    vertical-align: middle;
    font-size: 1.5em;
}

#sharevoice_caption {
    color:white;
}

.updown_button {
    padding: 0.8rem 4rem;
    font-size: 0.8rem;
    border-radius:100px;
    color: white;
    display: inline-block;
    margin: 1rem;
    cursor: pointer;
    white-space: nowrap;
    background-color: #D52819;
}

.updown_button .button-text {
    font-weight: 500;
}

.updown_button .button-icon {
    vertical-align: middle;
    font-weight: 500;
}

#footer_section {
    background: #334552;
}

#footer_cont {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
}

.youtube-button-wrapper {
    display: flex;
    cursor: pointer;
}

.yt-btn-img {
    margin-right: 1rem;
}

.yt-btn-text {
    color: white;
    font-weight: 500;
    font-size: 0.8rem;
    line-height: 1rem;
}

.share-count {
    color: white;
    font-weight: 500;
}

#footer_cont .sponsor-img {
    width: 36px;
    height: 36px;
    margin: 0.5rem;
    border-radius: 50%;
}

.social-button-cont {
    display: flex;
    align-items: center;
    margin: 0 0.5rem;
    cursor: pointer;
}

.social-button-cont img {
    height: 2rem;
    width: 2rem;
    border-radius: 50%;
    margin-right: 0.3rem;
}

@media screen and (max-width: 990px) {
    .social-button-cont img {
        width: 3rem;
        height: 3rem;
    }
}

.social-button-cont .share-count {
    color: #666666;
    font-size: 0.8rem;
}

.ca3-scroll-down-arrow {
    background-image: url("/static/images/down_arrow.svg");
    background-size: contain;
    background-repeat: no-repeat;
    -webkit-filter: drop-shadow( 0px 0px 5px white );
    filter: drop-shadow( 0px 0px 5px white );
}

.ca3-scroll-down-link {
    pointer-events: none;
    height: 60px;
    width: 80px;
    margin: 0px 0 0 -40px;
    line-height: 60px;
    position: fixed;
    left: 50%;
    bottom: 0px;
    color: #FFF;
    text-align: center;
    font-size: 70px;
    z-index: 100;
    text-decoration: none;
    text-shadow: 0px 0px 3px rgba(0, 0, 0, 0.4);
    
    -webkit-animation: ca3_fade_move_down 2s ease-in-out infinite;
    -moz-animation:    ca3_fade_move_down 2s ease-in-out infinite;
    animation:         ca3_fade_move_down 2s ease-in-out infinite;
}


/*animated scroll arrow animation*/
@-webkit-keyframes ca3_fade_move_down {
    0%   { -webkit-transform:translate(0,-20px); opacity: 0;  }
    50%  { opacity: 1;  }
    100% { -webkit-transform:translate(0,20px); opacity: 0; }
}
@-moz-keyframes ca3_fade_move_down {
    0%   { -moz-transform:translate(0,-20px); opacity: 0;  }
    50%  { opacity: 1;  }
    100% { -moz-transform:translate(0,20px); opacity: 0; }
}
@keyframes ca3_fade_move_down {
    0%   { transform:translate(0,-20px); opacity: 0;  }
    50%  { opacity: 1;  }
    100% { transform:translate(0,20px); opacity: 0; }
}
/* */


/* Big Player section */
#bottom_player_cont {
  position: sticky;
  bottom: 0;
  z-index: 1000;
  background: white;
}

.bigplayer-row {
    --bs-gutter-x: 2.5rem;
}

.bigplayer-row .col-12 {
    padding: 0.5rem 1.875rem;
    align-items: center;
    display: flex;
}

#playing_track_cover {
    width: 3.125rem;
    height: 3.125rem;
    object-fit: contain;
}

.playing-track-cont {
    display: flex;
    width:30%;
	gap: 1.25rem;
}

@media screen and (max-width: 990px) {
    .playing-track-cont {
        width:90%;
        justify-content: center;
        text-align: center;
    }
}

#playing_track_title {
	font-family: Inter;
	font-style: normal;
	font-weight: 700;
}

#playing_track_artists {
	font-family: Montserrat;
	font-style: normal;
}

#bigplayer_controls_wrapper {
    width: 40%;
    gap: 0;
}

@media screen and (max-width: 1200px) {
    #bigplayer_controls_wrapper {
        width: 50%;
    }
}

@media screen and (max-width: 990px) {
    #bigplayer_controls_wrapper {
        width: 90%;
        text-align: center;
    }
}

#bigplayer_controls {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 1.875rem;
}

#bigplayer_controls img {
    cursor: pointer;
}

#bigplayer_controls_bigbuttons {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 1rem;
}

#bigplayer_playpause {
	width: 3.5rem;
}

#bigplayer_prev, #bigplayer_next {
	width: 2rem;
}

.bigplayer-row > .col-12 {
    justify-content: space-between;
	gap: 1rem;
}

@media screen and (max-width: 990px) {
    .bigplayer-row > .col-12 {
        flex-direction: column;
    }
}

#bigplayer_additional_buttons {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 1.875rem;
    width:30%;
}

@media screen and (max-width: 990px) {
    #bigplayer_additional_buttons {
        width:90%;
    }
}


#bigplayer_additional_buttons .dummy-btn {
    width: 1.5rem;
    height: 1.5rem;
}

/***/

#bigplayer_duration_cont {
    display: flex;
    gap: 1rem;
    align-items: center;
    justify-content: center;
    width: 100%;
}

#bigplayer_current_time, #bigplayer_duration {
    font-family: Inter;
    color: #7899A8;
}

/***/

:root {
    --track-background: #CADDE0;
    --thumb-fill: #7899A8;
    --thumb-shadow-dark: #678491;
    --thumb-shadow-light: #8ab0c2;
    --thumb-border-transparent: rgba(255, 30, 0, 0);
    --shadow-black: #000000;
    --seekbar-thickness: 2px;
}

#bigplayer_seekbar_wrapper {
    position: relative;
    flex: 1;
}

#bigplayer_seekbar {
    -webkit-appearance: none;
    margin: 0px;
    background-color: transparent;
    width: 100%;
    border-radius: 10px;
    vertical-align: middle;
}

#bigplayer_seekbar::before {
    content: '';
    position: absolute;
    width: 100%;
    height: 16px;
    top:50%;
    transform: translatey(-50%);
    cursor: pointer;
}

#bigplayer_seekbar:focus {
    outline: none;
}

#bigplayer_seekbar::-webkit-slider-runnable-track {
    width: 100%;
    height: var(--seekbar-thickness);
    cursor: pointer;
    box-shadow: 0px 0px 0px var(--shadow-black), 0px 0px 0px var(--track-background);
    background: var(--track-background);
    border-radius: 10px;
    border: 0.1px solid transparent;
}

#bigplayer_seekbar::-webkit-slider-thumb {
    box-shadow: 0px 0px 0px var(--thumb-shadow-dark), 0px 0px 0px var(--thumb-shadow-light);
    border: 0px solid var(--thumb-border-transparent);
    height: var(--seekbar-thickness);
    width: var(--seekbar-thickness);
    border-radius: 50%;
    background: var(--thumb-fill);
    cursor: pointer;
    -webkit-appearance: none;
    margin-top: -0.1px;
}

#bigplayer_seekbar:focus::-webkit-slider-runnable-track {
    background: var(--track-background);
}

@media screen and (-webkit-min-device-pixel-ratio:0) {
    #bigplayer_seekbar {
        overflow: hidden;
    }

    #bigplayer_seekbar::-webkit-slider-thumb {
        box-shadow: -500px 0 0 500px var(--thumb-fill) !important;
    }
}

#bigplayer_seekbar::-moz-range-progress {
    background-color: var(--thumb-fill);
    height: var(--seekbar-thickness);
}

#bigplayer_seekbar::-moz-range-track {
    width: 100%;
    height: var(--seekbar-thickness);
    cursor: pointer;
    box-shadow: 0px 0px 0px var(--shadow-black), 0px 0px 0px var(--track-background);
    background: var(--track-background);
    border-radius: 10px;
    border: 0.1px solid transparent;
}

#bigplayer_seekbar::-moz-range-thumb {
    box-shadow: 0px 0px 0px var(--thumb-shadow-dark), 0px 0px 0px var(--thumb-shadow-light);
    border: 0px solid var(--thumb-border-transparent);
    height: var(--seekbar-thickness);
    width: var(--seekbar-thickness);
    border-radius: 50%;
    background: var(--thumb-fill);
    cursor: pointer;
}

#bigplayer_seekbar::-ms-track {
    width: 100%;
    height: var(--seekbar-thickness);
    cursor: pointer;
    background: transparent;
    border-color: transparent;
    color: transparent;
}

#bigplayer_seekbar::-ms-fill-lower {
    background: var(--thumb-fill);
    border: 0.1px solid transparent;
    border-radius: 10px;
    box-shadow: 0px 0px 0px var(--shadow-black), 0px 0px 0px var(--track-background);
}

#bigplayer_seekbar::-ms-fill-upper {
    background: var(--track-background);
    border: 0.1px solid transparent;
    border-radius: 10px;
    box-shadow: 0px 0px 0px var(--shadow-black), 0px 0px 0px var(--track-background);
}

#bigplayer_seekbar::-ms-thumb {
    box-shadow: 0px 0px 0px var(--thumb-shadow-dark), 0px 0px 0px var(--thumb-shadow-light);
    border: 0px solid var(--thumb-border-transparent);
    background: var(--thumb-fill);
    cursor: pointer;
    height: var(--seekbar-thickness);
    width: var(--seekbar-thickness);
    border-radius: 50%;
}

#bigplayer_seekbar:focus::-ms-fill-lower {
    background: var(--track-background);
}

#bigplayer_seekbar:focus::-ms-fill-upper {
    background: var(--track-background);
}

/* ******* */

#fan_videos_list_desktop {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 2rem 1rem;
}

#fan_videos_list_carousel {
    display: none;
}

#fan_videos_list_desktop .user-vid-item-wrapper {
    width: calc(20% - 1rem);
    margin: 0;

}

@media screen and (max-width: 1200px) {
    #fan_videos_list_desktop {
        display: none;
    }

    #fan_videos_list_carousel {
        display: block;
    }
    
}


#player_wrapper {
    overflow: hidden;
    position: relative;
    width:100%;
    margin-bottom: 10px;
}

#player_wrapper iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.round-button {
    color: white;
    padding: 0.8rem 1.5rem;
    border-radius: 100px;
    margin: 0.3rem 1rem 0.3rem 0;
    cursor: pointer;
    white-space: nowrap;
}


@media only screen and (max-width: 1200px) {
    
    #main-row4-socials {
        flex-wrap: wrap;
        justify-content: space-around;
    }
}

@media only screen and (max-width: 990px) {
    html {
        font-size:12px;
    }

    #footer_cont {
        justify-content: space-around;
    } 
}

/* **** /