@-ms-viewport{
    width: device-width;
}

:root {
    --color_a: #4EBBC2;
    --color_b: #000;
    --color_c: #FFFFFF;
    --color_d: #CD3B64;
    --color_e: #B4DB5A;
    --color_f: #92C341;
    --color_g: #B3DCD6;
    --color_h: #FC2A3B;
    --color_i: #979897;
    --color_red: #D60057;
    --color_sh: rgba(0,0,0,0.05);
    --color_sh_w: rgba(255,255,255,0.1);
    --color_gradient_w: linear-gradient(180deg, rgba(255,255,255,0.6) 0%, rgba(255,255,255,0) 100%);
}

body, html, *  {
    padding: 0; margin: 0; box-sizing: border-box;
    font-family: 'Barlow Condensed', sans-serif; 
}

body, html {
    width: 100%; height: 100%; overflow-x: hidden; background: var(--color_c);
}

.inner_content { padding: 2vw 0; text-align: center; }
.inner_content  * {
    color: var(--color_a);
    font-size: 6vw;
}

.hidden {
    display: none!important;
}

.error {
    color: var(--color_d)!important;
}

.bg_img_header {
    transform: translateX(-3vw) translateY(-6vw);
    animation: bounce 2s infinite;

}

.animation_bar_header {
    display: flex;
    flex-direction: column;
    gap: 5;
    position: absolute; left: 0; top: 0; right: 0;
    height: 100%; 
}
.animation_bar_header img {
    width: 100%; display: block; margin: 0 auto;
    position: absolute; left: 0; bottom: 0; right: 0;
    object-fit: contain; height: 40%;
}

.container {
    display: grid; 
    grid-template-rows: repeat(13, minmax(0, 1fr));
    background: var(--color_a); background: var(--color_c);
    flex-direction: column; height: 100vh;
}

.page_ended .container {
    grid-template-rows: repeat(12, minmax(0, 1fr));
}
.main_app {
    grid-row-start: 4;
    grid-row-end: 13;
    transition: transform 0.5s;
    transform: translateX(100%);
}
.page_ended .main_app {
    grid-row-start: 4;
    grid-row-end: 12;
}


.main_app.smaller {
    grid-row-start: 1;
}

.card_bar.active {
    display: none;
}
.main_app.enter {
    transform: translateX(0%);
}
.pole_holder { 
    height: 100%; display: flex; position: relative; 
}
.header_scores em {
    font-style: normal; 
    text-transform: uppercase;
    font-size: 8vw; color: var(--color_b);
}
.header_scores {
    padding-top: 2vw;
}

.header_scores svg {
    width: 5vw; height: auto; fill: var(--color_d);
}
.header_scores span:nth-child(1) svg:nth-child(2), 
.header_scores span:nth-child(3) svg:nth-child(1) {
 fill: var(--color_g);
}

header {
    grid-row-start: 1; transition: 2s transform;
    grid-row-end: 4; overflow: hidden;  position: relative;
    transform: scale(0) translateY(-10vh);
}

.page_ended  header {
    grid-row-start: 1;
    grid-row-end: 4;
}
header.show {
    transform: scale(1) translateY(0);
}
header svg {
    width: 100%; height: 100%; position: absolute; left: 0;
    top: 0;
}

.background_graphics {
    width: 100%; height: 100%;
    background: url(/assets/scans.png);
}

.animation_header_text {
    position: absolute; left: 0; top: 0.5vh; bottom: 0.5vh; right: 0;
    padding-top: 1vh;
    display: grid; 
    align-content: center;
    align-items: center;
    flex-wrap: wrap;
    flex-direction: row;
    justify-content: center;
    padding-top: 0;
    
}
.animation_header_text img {
    display: block; margin: 0 auto;
}

.splash_text {
    text-transform: uppercase;
    text-align: center; font-size: 12vw; color: var(--color_a);
    font-weight: 800; display: block;
}


.sub_title {
    padding-top: 1vh;
    display: flex; flex-direction: column; 
    line-height: 10rem;
}
.sub_title .splash_text {
    font-size: 15vw;
}
.page_ended .sub_title .splash_text {
    position: relative; top: -1vh;
}
.title_1 {
    font-size: 15vw;
    animation: up_down 2s infinite;

}
.title_2 {
    font-size: 15vw;
    animation: up_down 2s infinite;
    animation-delay: 1s;
}


.title_3 {
    font-size: 13vw; transform: rotate(5deg);
    animation: bounce_left 2s infinite;
}
.title_4 {
    font-size: 8vw; transform: rotate(-5deg);
    animation: bounce_right 2s infinite;
    animation-delay: 1s;
}
.title_5 {
    font-size: 12vw; transform: rotate(5deg);
    animation: bounce_left 2s infinite;
}


.base { 
    width: 100%; background: var(--color_f);  display: flex; justify-content: space-between;  grid-row-start: 13;
    grid-row-end: 14; padding: 5vw; align-items: center;
}

.page_ended .base { 
    grid-row-start: 12;
    grid-row-end: 13;
}


.btn_full_screen {
    background: var(--color_a); opacity: 0.2; padding: 4vw;
    height: 5vh; border-radius: 2vw; text-indent: -9999em; width: 20vw; margin: 0;
}

.base a {
    display: flex; width: 10vw; opacity: 0.2;
}
.base a:hover {
    opacity: 1;
}
.base svg {
    width: 100%; height: auto;
}
.score_board {
    padding: 2vw 1vw; display: flex; gap: 1vh;
    list-style-type: none; flex-direction: column;
    transition: transform 0.5s; transform: translateX(100%);
}
.score_board.show {
    transform: translateX(0);
}
.score_board li {
    background: var(--color_f); padding: 2vw;
    display: grid; grid-template-columns: repeat(8, minmax(0, 1fr));
    text-align: left; color: var(--color_b);
}

.score_board li span:nth-child(1) {
    color: var(--color_b);
    grid-column: span 6 / span 6;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.score_board li span:nth-child(2) {
    color: var(--color_b);
}



.inner_content p:nth-child(1) {
    padding: 0 0 1vw 0;
}
.score_board li span:nth-child(2) {
    font-weight: 500;
}

.score_message {
    padding: 18vw 2vw 6vw 2vw; text-align: center; font-weight: 500;
    font-size: 7vw; max-width: 70vw; margin: 0 auto;
}

.count_down_message {
    position: absolute;
    left: 0; right: 0;
    top: 0; bottom: 0;
    z-index: 10; display: flex; align-items: center; 
    justify-content: center;
    transform: scale(0); transition: transform 1s;
    
}

.count_down_message.show {
    transform: scale(1);
    animation: pop_animation infinite 2s;
}

.count_down_message svg {
    position: absolute; left: 0; right: 0;
    top: 50%; transform: translatey(-50%); display: block; width: 100%; height: auto;
}
.count_down_message span {
    color: var(--color_b);
    font-size: 20vw; position: relative;
}
.count_down_message span.large {
    font-size: 40vw;
}

.input {
    display: flex; align-items: center; flex-direction: column; padding-top: 8vw;
}
.input p {
    padding: 2vw 0; display: flex;
}
.input p input, .input button { padding: 2vw; font-weight: 500; margin: 0;  }
.input input { color: var(--color_b); width: 60vw; }
.input input:focus { box-shadow: 0 0 5vw rgba(255,255,255,0.5)}
.input button { background: var(--color_f); color: var(--color_b); }

.holder_star_qr {
    padding: 8vw 4vw; display: flex; align-items: center;
    justify-content: center; min-width: 50vw; position: relative;
}

.star_qr {
    background: url(/assets/stargreen.svg) no-repeat center center;
    width: 100%; height: 100%; position: absolute; left: 0; top: 0; top: 0; bottom: 0;
    background-size: contain; animation: star_rotation 20s infinite linear;
}
.holder_star_qr img {
    width: 30%; height: auto; position: relative;
}

.bar { 
    height: 100%; width: 100%; bottom: 0; position: absolute; left: 50%; transform: translateX(-50%); display: flex; justify-content: center;
}
.bell { 
    border-radius: 100%; background: var(--color_c); height: 20%; width: 45%; z-index: 10; left: 50%; top: 0; position: absolute; transform: translateX(-50%); box-shadow: -20px 10px 0 inset var(--color_sh); display: flex; align-items: center; justify-content: center;
}
.bell.shake {
    animation: horizontal-shaking 0.5s;
}
.bell:before {
    content: ''; display: block; width: 15%; height: 15%; background: var(--color_i);
    border-radius: 100%;
}
.indicator_bar {
    height: 85%; width: 45%;  top: 15%;
    position: relative; 
}
.indicator {
    height: 100%; position: absolute; bottom: 0; width: 100%;
    left: 50%; transform: translateX(-50%); 
}
.indicators {
    display: flex; flex-direction: column; gap: 25%; width: 100%;
    position: absolute; left: 0; bottom: 0; 
    height: 80%;
}
.indicators:before {
    content: ''; position: absolute; bottom: 0; left: 50%;
    transform: translateX(-50%); box-shadow: -5px 0 0 inset var(--color_sh); background: var(--color_f); width: 40%; height: 100%;
}


.card_bar {
    position: absolute; top: 0; left: 0; width: 100%; height: 20%;
    display: flex; padding: 2vw; align-items: center; justify-content: center;
}
.card_bar .card {
    width: 30vw; height: 70%; background: var(--color_sh_w); border-radius: 4vw;
    display: flex; align-items: center; justify-content: center;
}
.card_bar .card img { width: 70%; height: auto; }

.card_bar svg {
    fill: var(--color_d); margin: 0 1vw;
    transition: opacity 0.5s; opacity: 0;
}
.card_bar svg.star_2, .card_bar svg.star_3 {
    transform: translateY(-2vh) scale(0.8); 
    transition-delay: 250ms;
}
.card_bar.active svg  {
    opacity: 1;
}
.card_bar.active .card {
    background: rgba(205, 59, 100, 0.7);
}


.indicator_line {
    display: grid; grid-template-columns: repeat(4, minmax(0, 1fr));
    padding: 0 2vw; justify-content: center; align-content: flex-start;
    position: relative;
}


.indicators span {
    font-size: 6vw; color: var(--color_b); text-align: center; line-height: 1.5rem;
}
.indicators span.stripe {
    grid-column: span 2 / span 2;
    border-top: solid 1vh var(--color_i);
}

.ind_1 span.stripe {
    border-color: var(--color_i);
}
.score {
    background: var(--color_f);
    padding: 2vh 0; width: 100%; 
    color: var(--color_b);
}
.score p.total_score {
    color: var(--color_b); font-size: 5vh;
}
.score.show {
    transform: scale(1);
}
.stars {
    display: none;
}
.stars.show {
    display: block; position: fixed; left: 0; top: 0;
    bottom: 0; right: 0;
}
.results .stars svg {
    transform: scale(0);
    transform-origin: center center;
    transition: transform 0.5s;
    transition-delay: 0.2s;
}
.results .stars svg.show {
    transform: scale(1);
}

.results p {
    padding: 2vh 0;
}
.score p {
    font-size: 15vw;
    font-weight: 800;
}
.star svg { position: absolute; }
.star .star_1, .star .star_4 {
    fill: var(--color_g);
    left: 80%; top: -10%;
}
.star .star_2 {
    fill: var(--color_d);
    left: 40%; top: -8%; transform: scale(1.3);
}
.star .star_3 {
    fill: var(--color_f);
    left: 10%; top: -15%; transform: scale(0.8);
}
.star .star_4 {
    left: 10%; top: 60%;
}
.star .star_5 {
    fill: var(--color_a);
    left: 50%; top: 70%; transform: scale(1.3);
}

.perc_indicator {
    left: 0; width: 100%; background: var(--color_a); bottom: 0%; height: 3vh;
    transition: bottom 1.0s; transform-origin: bottom center;  position: absolute; transform: translateY(100%);
}
.indicators.right { left: auto; right: -5px; }

.dot {
    background: var(--color_a); width: 100%; padding-bottom:  calc(100% - 1vw);
    border-radius: 100%; flex-shrink: 0; border: solid 0.5vw var(--color_d); box-shadow: 0 5px 0 var(--color_sh); transition: background-color 0.5s, box-shadow 0.5s, border 0.5s;
}
.dot.active { background: var(--color_h); box-shadow: 0 0 10px var(--color_h); border: solid 0.5vw var(--color_h);  }


@keyframes horizontal-shaking {
    0% { transform: translateX(-50%) translateY(0%) rotate(0) }
    25% { transform: translateX(calc(-50% + 2px)) translateY(-2px)  rotate(5deg) }
    50% { transform: translateX(calc(-50% - 2px)) translateY(2px) rotate(-5deg) }
    75% { transform: translateX(calc(-50% + 2px)) translateY(-2px) rotate(5deg) }
    100% { transform: translateX(-50%) rotate(0) }
}
.loader_icon {
    display: flex; align-items: center; justify-content: center;
    padding: 2vw;
}

.lds-dual-ring {
    display: inline-block;
    width: 80px;
    height: 80px;
}
.lds-dual-ring:after {
    content: " ";
    display: block;
    width: 64px;
    height: 64px;
    margin: 8px;
    border-radius: 50%;
    border: 6px solid #fff;
    border-color: #fff transparent #fff transparent;
    animation: lds-dual-ring 1.2s linear infinite;
}
@keyframes lds-dual-ring {
    0% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(360deg);
    }
}


@keyframes bounce_left {
    0% {
        transform: scale(0.8) rotate(-5deg);
    }
    50% {
        transform: scale(1) rotate(-5deg);
    }
    100% {
        transform: scale(0.8) rotate(-5deg);
    }
}

@keyframes bounce_right {
    0% {
        transform: scale(0.8) rotate(5deg);
    }
    50% {
        transform: scale(1) rotate(5deg);
    }
    100% {
        transform: scale(0.8) rotate(5deg);
    }
}


@keyframes bounce{
    0% {
        transform: scale(0.8) translateX(-3vw) translateY(-6vw);
    }
    50% {
        transform: scale(1) translateX(-3vw) translateY(-6vw);
    }
    100% {
        transform: scale(0.8) translateX(-3vw) translateY(-6vw);
    }
}

@keyframes star_rotation {
    0% {
        transform: rotate(0deg);
    }
    50% {
        transform: rotate(360deg);
    }
    100% {
        transform: rotate(0deg);
    }
}

@keyframes pop_animation {
    0% {
        transform: scale(0.8);
    }
    50% {
        transform: scale(1.1);
    }
    100% {
        transform: rotate(0.8);
    }
}

@keyframes up_down {
    0% {
        transform: translateY(-5%);
    }
    50% {
        transform: translateY(0);
    }
    100% {
        transform: translateY(-5%);
    }
}

