html, body {
    touch-action: none;
    width: 100%;
    height: 100%;
    text-size-adjust: none;
    -webkit-text-size-adjust: none;
    overscroll-behavior-y: contain;
    overscroll-behavior-x: contain;
}

html {
    font-size: 17px;
    /*prevent user scaling*/
}

body {
    font-family: 'Roboto Condensed', sans-serif;
    margin: 0;
    padding: 0;
    background-image: url('/img/background_portrait.jpg');
    background-size: cover;
    /* background-color: #00EE21; */
}

.rotated {
    transform: rotate(90deg);
    -ms-transform: rotate(90deg);
    /* IE 9 */
    -moz-transform: rotate(90deg);
    /* Firefox */
    -webkit-transform: rotate(90deg);
    /* Safari and Chrome */
    -o-transform: rotate(90deg);
    /* Opera */
}

.startupOverlay {
    /* background: rgba(168, 168, 168, .7); */
    z-index: 50000;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 150%;
    /* border: 3px solid red; */
}

#scanTypeCamera {
    height: 100%;
    display: none;
    /* background-image: url('img/background_portrait.svg');
    background-size: cover; */
}

h1 {
    margin: 10px 0;
    font-size: 40px;
}

#version {
    font-size: 1rem;
    position: absolute;
    top: 1vh;
    margin-left: 4vw;
}

#qr-canvas {
    visibility: hidden;
}

#output {
    /* margin-top: 20px; */
    /* background: #eee; */
    /* padding: 10px; */
    padding-bottom: 0;
}

#output div {
    padding-top: 40px;
    padding-bottom: 10px;
    word-wrap: break-word;
}

#overlay {
    background-color: white;
    position: absolute;
}

.intro-curved-arrow {
    position: fixed;
    bottom: 22%;
    width: 13rem;
}

.startpage-button-wrapper {
    position: fixed;
    width: 100%;
    text-align: center;
    height: auto;
    bottom: 10%;
}

/* .intro-button {
    display: inline-block;
    width: 7rem;
    height: 1.9rem;
    background-color: #04A317;
    color: #ffffff;
    font-weight: 700;
    font-size: 1.2rem;
    padding: .5rem;
    padding-top: .75rem;
    padding-bottom: .25rem;
    cursor: pointer;
    margin: 0 auto;
    margin-right: 5px;
    border: 3px solid #08BF19;
} */
.intro-btns {
    height: 4.9rem;
}

.intro-done-button {
    width: 12rem;
    height: 3.5rem;
    background-color: #04A317;
    color: #ffffff;
    font-weight: 700;
    font-size: 1.55rem;
    padding: .5rem;
    padding-top: 1.85rem;
    padding-bottom: .25rem;
    cursor: pointer;
    border: 3px solid #08BF19;
    margin: 0 auto;
    margin-top: 2%;
    text-align: center;
}

.start-button {
    display: inline-block;
    color: #ffffff;
    width: 7rem;
    height: 1.9rem;
    background-color: #04A317;
    color: #ffffff;
    font-weight: 700;
    font-size: 1.2rem;
    padding: .5rem;
    padding-top: .75rem;
    padding-bottom: .25rem;
    cursor: pointer;
    margin: 0 auto;
    margin-left: 5px;
    border: 3px solid #08BF19;
}

.start-page-info {
    color: #000000;
    top: 55%;
    text-align: center;
    font-size: .9rem;
    font-weight: 700;
}

.intro-start-button {
    bottom: 10rem;
    position: relative;
    width: 18rem;
    border: none;
}

@media only screen and (max-width: 310px) and (orientation: portrait) {
    .main-logo {
        width: 60%;
        margin-top: 50%;
    }

    .start-page-info {
        position: fixed;
        width: 100%;
        text-align: center;
        font-size: .9rem;
    }

    .intro-start-button {
        bottom: 10rem;
        position: relative;
        width: 18rem;
        border: none;
        z-index: 100000
    }

    .intro-btns {
        height: 4rem;
    }

    .intro-done-button {
        width: 12rem;
        height: 3.5rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: 1.55rem;
        padding: .5rem;
        padding-top: 1.85rem;
        padding-bottom: .25rem;
        cursor: pointer;
        border: 3px solid #08BF19;
        margin: 0 auto;
        margin-top: 2%;
        text-align: center;
    }

    .start-button {
        display: inline-block;
        color: #ffffff;
        width: 7rem;
        height: 1.9rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: 1.2rem;
        padding: .5rem;
        padding-top: .75rem;
        padding-bottom: .25rem;
        cursor: pointer;
        margin: 0 auto;
        margin-left: 5px;
        border: 3px solid #08BF19;
    }

    .lock-icon {
        position: absolute;
        top: 5px;
        right: 5px;
        margin: 0 auto;
        cursor: pointer
    }

    .instructions {
        /* background-image: url('/img/background.svg'); */
        /* background-size: cover; */
        position: absolute;
        top: 0;
        left: 0px;
        height: 100%;
        width: 100%;
        min-width: 100%;
    }

    .instructions-logo {
        width: 7rem;
        margin-top: 1rem;
    }

    .instructions-table {
        font-size: .7rem;
        color: #ffffff;
        /* margin: 0px 10%; */
    }

    .instructions-table-text-cells {
        padding-left: .5rem;
        padding-right: .5rem;
    }

    .instruction-icons {
        height: 2.5rem;
        margin-top: 1.2rem;
        /* margin-bottom: 1rem; */
    }

    .progression-dots {
        width: .6rem;
        display: inline-block;
        height: 100%;
        margin-right: 10px;
    }

    .progression-arrow,
    .progression-arrow-left,
    .progression-arrow-right {
        width: 50px;
        vertical-align: baseline;
        cursor: pointer;
    }

    .progression-arrow-right {}

    .progression-arrow-left {}

    .instructions-tagline {
        font-size: 1rem;
        font-weight: 700;
        vertical-align: 45%
    }

    #installation-popup-1 {
        position: absolute;
        bottom: 0%;
        width: 10%;
        text-align: center;
        margin: 0 auto;
        left: 0;
        right: 0;
        display: block;
        border: none;
        z-index: 20000;
    }

    #installation-popup-1-close {
        width: 9%;
        position: absolute;
        top: 8px;
        right: 3%;
    }

    .intro-curved-arrow {
        position: fixed;
        bottom: 22%;
        width: 13rem;
    }
}

/* END: @media only screen and (max-width: 320px) and (orientation: portrait)*/
@media only screen and (min-width: 310.1px) and (max-width: 350px) and (orientation: portrait) {
    .main-logo {
        width: 60%;
        margin-top: 50%;
    }

    .start-page-info {
        position: fixed;
        width: 100%;
        text-align: center;
        font-size: 1.1rem;
    }

    .intro-start-button {
        bottom: 10rem;
        position: relative;
        width: 18rem;
        border: none;
        z-index: 100000
    }

    .intro-btns {
        height: 4rem;
    }

    .intro-button-initial {
        position: fixed;
        bottom: 10%;
        width: 7rem;
        height: 1.9rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: 1rem;
        padding: .5rem;
        padding-top: .75rem;
        padding-bottom: .25rem;
        cursor: pointer;
        float: left;
        margin-left: 6%;
        border: 3px solid #08BF19;
        text-align: center;
    }

    .intro-done-button {
        width: 12rem;
        height: 2.5rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: 1.55rem;
        padding: .5rem;
        padding-top: .95rem;
        padding-bottom: .25rem;
        cursor: pointer;
        border: 3px solid #08BF19;
        margin: 0 auto;
        margin-top: 2%;
        text-align: center;
    }

    .start-button {
        display: inline-block;
        color: #ffffff;
        width: 7rem;
        height: 1.9rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: 1rem;
        padding: .5rem;
        padding-top: .75rem;
        padding-bottom: .25rem;
        cursor: pointer;
        margin: 0 auto;
        margin-left: 5px;
        border: 3px solid #08BF19;
    }

    .lock-icon {
        position: absolute;
        top: 5px;
        right: 5px;
        margin: 0 auto;
        cursor: pointer
    }

    .instructions {
        /* background-image: url('/img/background.svg');
        background-size: cover; */
        position: absolute;
        top: 0;
        left: 0px;
        height: 100%;
        width: 100%;
        min-width: 100%;
    }

    .instructions-logo {
        width: 7rem;
        margin-top: 1rem;
    }

    .instructions-table {
        font-size: .7rem;
        color: #ffffff;
        /* margin: 0px 10%; */
    }

    .instructions-table-text-cells {
        padding-left: .5rem;
        padding-right: .5rem;
    }

    .instruction-icons {
        height: 2.5rem;
        margin-top: 1.2rem;
        /* margin-bottom: 1rem; */
    }

    .progression-dots {
        width: .6rem;
        display: inline-block;
        height: 100%;
        margin-right: 10px;
    }

    .progression-arrow,
    .progression-arrow-left,
    .progression-arrow-right {
        width: 50px;
        vertical-align: baseline;
        cursor: pointer;
    }

    .progression-arrow-right {}

    .progression-arrow-left {}

    .instructions-tagline {
        font-size: 1rem;
        font-weight: 700;
        vertical-align: 45%
    }

    #installation-popup-1 {
        position: absolute;
        bottom: 0%;
        width: 10%;
        text-align: center;
        margin: 0 auto;
        left: 0;
        right: 0;
        display: block;
        border: none;
        z-index: 20000;
    }

    #installation-popup-1-close {
        width: 9%;
        position: absolute;
        top: 8px;
        right: 3%;
    }

    .intro-curved-arrow {
        position: fixed;
        bottom: 25%;
        width: 13rem;
    }
}

/* END: @media only screen and (min-width: 320.1px) and (max-width: 350px) and (orientation: portrait) */
@media only screen and (min-width: 350.1px) and (max-width: 380px) and (max-height: 670px) and (orientation: portrait) {
    .main-logo {
        width: 60%;
        margin-top: 50%;
    }

    .intro-start-button {
        bottom: 10rem;
        position: relative;
        width: 18rem;
        border: none;
        z-index: 100000;
        margin-top: -80px;
    }

    .start-page-info {
        position: fixed;
        width: 100%;
        top: 58%;
        text-align: center;
        font-size: 1.1rem;
    }

    .intro-btn {
        width: 120%;
        bottom: 0rem;
        position: relative;
    }

    .start-btn {
        width: 120%;
        bottom: 0rem;
        position: relative;
    }

    .intro-button-initial {
        position: fixed;
        bottom: 10%;
        text-align: center;
        width: 8rem;
        height: 1.9rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: 1.2rem;
        padding: .5rem;
        padding-top: .75rem;
        padding-bottom: .25rem;
        cursor: pointer;
        float: left;
        margin-left: 6%;
        border: 3px solid #08BF19;
    }

    .intro-done-button {
        width: 12rem;
        height: 3.5rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: 1.55rem;
        padding: .5rem;
        padding-top: 1.85rem;
        padding-bottom: .25rem;
        cursor: pointer;
        border: 3px solid #08BF19;
        margin: 0 auto;
        margin-top: 2%;
        text-align: center;
    }

    .start-button {
        display: inline-block;
        color: #ffffff;
        width: 8rem;
        height: 1.9rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: 1.2rem;
        padding: .5rem;
        padding-top: .75rem;
        padding-bottom: .25rem;
        cursor: pointer;
        margin: 0 auto;
        margin-left: 5px;
        border: 3px solid #08BF19;
    }

    .lock-icon {
        position: absolute;
        top: 5px;
        right: 5px;
        margin: 0 auto;
        cursor: pointer
    }

    .instructions {
        /* background-image: url('/img/background.svg');
        background-size: cover; */
        position: absolute;
        top: 0;
        left: 0px;
        height: 100%;
        width: 100%;
        min-width: 100%;
    }

    .instructions-logo {
        width: 7rem;
        margin-top: 1rem;
    }

    .instructions-table {
        font-size: .7rem;
        color: #ffffff;
        /* margin: 0px 10%; */
    }

    .instructions-table-text-cells {
        padding-left: .5rem;
        padding-right: .5rem;
    }

    .instruction-icons {
        height: 2.5rem;
        margin-top: 1.2rem;
        /* margin-bottom: 1rem; */
    }

    .progression-dots {
        width: .6rem;
        display: inline-block;
        height: 100%;
        margin-right: 10px;
    }

    .progression-arrow,
    .progression-arrow-left,
    .progression-arrow-right {
        width: 50px;
        vertical-align: baseline;
        cursor: pointer;
    }

    .progression-arrow-right {}

    .progression-arrow-left {}

    .instructions-tagline {
        font-size: 1rem;
        font-weight: 700;
        vertical-align: 45%
    }

    #installation-popup-1 {
        position: absolute;
        bottom: 0%;
        width: 10%;
        text-align: center;
        margin: 0 auto;
        left: 0;
        right: 0;
        display: block;
        border: none;
        z-index: 20000;
    }

    #installation-popup-1-close {
        width: 9%;
        position: absolute;
        top: 8px;
        right: 3%;
    }

    .intro-curved-arrow {
        position: fixed;
        bottom: 22%;
        width: 13rem;
    }
}

@media only screen and (min-width: 350.1px) and (max-width: 380px) and (min-height: 670px) and (orientation: portrait) {
    .main-logo {
        width: 60%;
        margin-top: 50%;
    }

    .intro-start-button {
        bottom: 0rem;
        position: relative;
        width: 18rem;
        border: none;
        z-index: 100000;
        margin-top: -80px;
    }

    .start-page-info {
        position: fixed;
        width: 100%;
        top: 52%;
        text-align: center;
        font-size: 1.1rem;
    }

    .intro-btn {
        width: 120%;
        bottom: 0rem;
        position: relative;
    }

    .start-btn {
        width: 120%;
        bottom: 0rem;
        position: relative;
    }

    .intro-button-initial {
        position: fixed;
        bottom: 10%;
        text-align: center;
        width: 8rem;
        height: 1.9rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: 1.2rem;
        padding: .5rem;
        padding-top: .75rem;
        padding-bottom: .25rem;
        cursor: pointer;
        float: left;
        margin-left: 6%;
        border: 3px solid #08BF19;
    }

    .intro-done-button {
        width: 12rem;
        height: 3.5rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: 1.55rem;
        padding: .5rem;
        padding-top: 1.85rem;
        padding-bottom: .25rem;
        cursor: pointer;
        border: 3px solid #08BF19;
        margin: 0 auto;
        margin-top: 2%;
        text-align: center;
    }

    .start-button {
        display: inline-block;
        color: #ffffff;
        width: 8rem;
        height: 1.9rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: 1.2rem;
        padding: .5rem;
        padding-top: .75rem;
        padding-bottom: .25rem;
        cursor: pointer;
        margin: 0 auto;
        margin-left: 5px;
        border: 3px solid #08BF19;
    }

    .lock-icon {
        position: absolute;
        top: 5px;
        right: 5px;
        margin: 0 auto;
        cursor: pointer
    }

    .instructions {
        /* background-image: url('/img/background.svg');
        background-size: cover; */
        position: absolute;
        top: 0;
        left: 0px;
        height: 100%;
        width: 100%;
        min-width: 100%;
    }

    .instructions-logo {
        width: 7rem;
        margin-top: 1rem;
    }

    .instructions-table {
        font-size: .7rem;
        color: #ffffff;
        /* margin: 0px 10%; */
    }

    .instructions-table-text-cells {
        padding-left: .5rem;
        padding-right: .5rem;
    }

    .instruction-icons {
        height: 2.5rem;
        margin-top: 1.2rem;
        /* margin-bottom: 1rem; */
    }

    .progression-dots {
        width: .6rem;
        display: inline-block;
        height: 100%;
        margin-right: 10px;
    }

    .progression-arrow,
    .progression-arrow-left,
    .progression-arrow-right {
        width: 50px;
        vertical-align: baseline;
        cursor: pointer;
    }

    .progression-arrow-right {}

    .progression-arrow-left {}

    .instructions-tagline {
        font-size: 1rem;
        font-weight: 700;
        vertical-align: 45%
    }

    #installation-popup-1 {
        position: absolute;
        bottom: 0%;
        width: 10%;
        text-align: center;
        margin: 0 auto;
        left: 0;
        right: 0;
        display: block;
        border: none;
        z-index: 20000;
    }

    #installation-popup-1-close {
        width: 9%;
        position: absolute;
        top: 8px;
        right: 3%;
    }

    .intro-curved-arrow {
        position: fixed;
        bottom: 22%;
        width: 13rem;
    }
}

/* END: @media only screen and (min-width: 350.1px) and (max-width: 380px) and (orientation: portrait) */
@media only screen and (min-width: 380.1px) and (max-width: 479px) and (orientation: portrait) {
    .main-logo {
        width: 60%;
        margin-top: 50%;
    }

    .start-page-info {
        position: fixed;
        width: 100%;
        text-align: center;
        font-size: 1.3rem;
    }

    .intro-start-button {
        bottom: 10rem;
        position: relative;
        width: 18rem;
        border: none;
        z-index: 100000
    }

    .intro-btn {
        width: 120%;
        bottom: 0rem;
        position: relative;
    }

    .start-btn {
        width: 120%;
        bottom: 0rem;
        position: relative;
    }

    .intro-button {
        display: inline-block;
        width: 7rem;
        height: 1.9rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: 1rem;
        padding: .5rem;
        padding-top: .75rem;
        padding-bottom: .25rem;
        cursor: pointer;
        margin: 0 auto;
        margin-right: 5px;
        border: 3px solid #08BF19;
    }

    .intro-button-initial {
        position: fixed;
        bottom: 10%;
        width: 7rem;
        height: 1.9rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: 1rem;
        padding: .5rem;
        padding-top: .75rem;
        padding-bottom: .25rem;
        cursor: pointer;
        float: left;
        margin-left: 14%;
        text-align: center;
        border: 3px solid #08BF19;
    }

    .intro-done-button {
        width: 12rem;
        height: 3.5rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: 1.55rem;
        padding: .5rem;
        padding-top: 1.85rem;
        padding-bottom: .25rem;
        cursor: pointer;
        border: 3px solid #08BF19;
        margin: 0 auto;
        margin-top: 2%;
        text-align: center;
    }

    .start-button {
        display: inline-block;
        color: #ffffff;
        width: 7rem;
        height: 1.9rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: 1rem;
        padding: .5rem;
        padding-top: .75rem;
        padding-bottom: .25rem;
        cursor: pointer;
        margin: 0 auto;
        margin-left: 5px;
        border: 3px solid #08BF19;
    }

    .lock-icon {
        position: absolute;
        top: 5px;
        right: 5px;
        margin: 0 auto;
        cursor: pointer
    }

    .instructions {
        /* background-image: url('/img/background.svg');
        background-size: cover; */
        position: absolute;
        top: 0;
        left: 0px;
        height: 100%;
        width: 100%;
        min-width: 100%;
    }

    .instructions-logo {
        width: 7rem;
        margin-top: 1rem;
    }

    .instructions-table {
        font-size: .7rem;
        color: #ffffff;
        /* margin: 0px 10%; */
    }

    .instructions-table-text-cells {
        padding-left: .5rem;
        padding-right: .5rem;
    }

    .instruction-icons {
        height: 2.5rem;
        margin-top: 1.2rem;
        /* margin-bottom: 1rem; */
    }

    .progression-dots {
        width: .6rem;
        display: inline-block;
        height: 100%;
        margin-right: 10px;
    }

    .progression-arrow,
    .progression-arrow-left,
    .progression-arrow-right {
        width: 50px;
        vertical-align: baseline;
        cursor: pointer;
    }

    .progression-arrow-right {}

    .progression-arrow-left {}

    .instructions-tagline {
        font-size: 1rem;
        font-weight: 700;
        vertical-align: 45%
    }

    #installation-popup-1 {
        position: absolute;
        bottom: 0%;
        width: 10%;
        text-align: center;
        margin: 0 auto;
        left: 0;
        right: 0;
        display: block;
        border: none;
        z-index: 20000;
    }

    #installation-popup-1-close {
        width: 8%;
        position: absolute;
        top: 8px;
        right: 3%;
    }

    .intro-curved-arrow {
        position: fixed;
        bottom: 22%;
        width: 13rem;
    }
}

/* END: @media only screen and (min-width: 380.1px) and (max-width: 479px) and (orientation: portrait) */
/* Mobile Landscape Size to Tablet Portrait (devices and browsers) */
@media only screen and (min-width: 479.1px) and (max-width: 767px) and (orientation: portrait) {
    .main-logo {
        width: 60%;
        margin-top: 50%;
    }

    .start-page-info {
        position: fixed;
        width: 100%;
        text-align: center;
        font-size: 1.5rem;
    }

    .intro-button {
        display: inline-block;
        width: 8.1rem;
        height: 2.4rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: 1.2rem;
        padding: .5rem;
        padding-top: .75rem;
        padding-bottom: 0;
        cursor: pointer;
        margin: 0 auto;
        margin-right: 5px;
        border: 3px solid #08BF19;
    }

    .intro-button-initial {
        position: fixed;
        bottom: 10%;
        text-align: center;
        width: 8.1rem;
        height: 2.4rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: 1.2rem;
        padding: .5rem;
        padding-top: .75rem;
        padding-bottom: 0rem;
        cursor: pointer;
        margin-left: 15%;
        border: 3px solid #08BF19;
        bottom: 10%;
    }

    .intro-done-button {
        width: 12rem;
        height: 3.5rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: 1.55rem;
        padding: .5rem;
        padding-top: 1.85rem;
        padding-bottom: .25rem;
        cursor: pointer;
        border: 3px solid #08BF19;
        margin: 0 auto;
        margin-top: 5%;
        text-align: center;
    }

    .start-button {
        display: inline-block;
        width: 8.1rem;
        height: 2.4rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: 1.2rem;
        padding: .5rem;
        padding-top: .75rem;
        padding-bottom: 0;
        cursor: pointer;
        margin: 0 auto;
        margin-left: 5px;
        border: 3px solid #08BF19;
    }

    .lock-icon {
        position: absolute;
        top: 5px;
        right: 5px;
        margin: 0 auto;
        cursor: pointer
    }

    .instructions {
        /* background-image: url('/img/background.svg');
        background-size: cover; */
        position: absolute;
        top: 0;
        left: 0px;
        height: 100%;
        width: 100%;
        min-width: 100%;
    }

    .instructions-logo {
        width: 7rem;
        margin-top: 1rem;
    }

    .instructions-table {
        font-size: .7rem;
        color: #ffffff;
        /* margin: 0px 10%; */
    }

    .instructions-table-text-cells {
        padding-left: .5rem;
        padding-right: .5rem;
    }

    .instruction-icons {
        height: 2.5rem;
        margin-top: 1.2rem;
        /* margin-bottom: 1rem; */
    }

    .progression-dots {
        width: .6rem;
        display: inline-block;
        height: 100%;
        margin-right: 10px;
    }

    .progression-arrow,
    .progression-arrow-left,
    .progression-arrow-right {
        width: 50px;
        vertical-align: baseline;
        cursor: pointer;
    }

    .progression-arrow-right {}

    .progression-arrow-left {}

    .instructions-tagline {
        font-size: 1rem;
        font-weight: 700;
        vertical-align: 45%
    }

    #installation-popup-1 {
        position: absolute;
        bottom: 0%;
        width: 10%;
        text-align: center;
        margin: 0 auto;
        left: 0;
        right: 0;
        display: block;
        border: none;
        z-index: 20000;
    }

    #installation-popup-1-close {
        width: 9%;
        position: absolute;
        top: 8px;
        right: 3%;
    }

    .intro-curved-arrow {
        position: fixed;
        bottom: 20%;
        width: 13rem;
    }
}

/* END: @media only screen and (min-width: 480px) and (max-width: 767px) and (orientation: portrait) */
/* Tablet Portrait size to standard 960 (devices and browsers) */
@media only screen and (min-width: 768px) and (max-width: 989px) {
    .main-logo {
        width: 60%;
        margin-top: 50%;
    }

    .start-page-info {
        top: 65%;
        position: fixed;
        width: 100%;
        text-align: center;
        font-size: 120%;
    }

    .intro-button {
        display: inline-block;
        width: 6rem;
        height: 1.9rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: .9rem;
        padding: .5rem;
        padding-top: .75rem;
        padding-bottom: 0;
        cursor: pointer;
        margin: 0 auto;
        margin-right: 5px;
        border: 3px solid #08BF19;
    }

    .intro-button-initial {
        position: fixed;
        bottom: 10%;
        width: 7rem;
        height: 1.9rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: 1.2rem;
        padding: .5rem;
        padding-top: .75rem;
        padding-bottom: .25rem;
        cursor: pointer;
        float: left;
        margin-left: 12%;
        border: 3px solid #08BF19;
        text-align: center;
    }

    .intro-done-button {
        width: 12rem;
        height: 3.5rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: 1.55rem;
        padding: .5rem;
        padding-top: 1.85rem;
        padding-bottom: .25rem;
        cursor: pointer;
        border: 3px solid #08BF19;
        margin: 0 auto;
        margin-top: 2%;
        text-align: center;
    }

    .start-button {
        display: inline-block;
        color: #ffffff;
        width: 6rem;
        height: 1.9rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: .9rem;
        padding: .5rem;
        padding-top: .75rem;
        padding-bottom: 0;
        cursor: pointer;
        margin: 0 auto;
        margin-left: 5px;
        border: 3px solid #08BF19;
    }

    .lock-icon {
        position: absolute;
        top: 5px;
        right: 5px;
        margin: 0 auto;
        cursor: pointer
    }

    .instructions {
        /* background-image: url('/img/background.svg');
        background-size: cover; */
        position: absolute;
        top: 0;
        left: 0px;
        height: 100%;
        width: 100%;
        min-width: 100%;
    }

    .instructions-logo {
        width: 25%;
        margin-top: 3%;
    }

    .instructions-table {
        font-size: .9rem;
        color: #ffffff;
        /* margin: 0px 10%; */
    }

    .instructions-table-text-cells {
        padding-left: .5rem;
        padding-right: .5rem;
    }

    .instruction-icons {
        height: 40%;
        margin-top: 15%;
        /* margin-bottom: 1rem; */
    }

    .progression-dots {
        width: .6rem;
        display: inline-block;
        height: 100%;
        margin-right: 10px;
    }

    .progression-arrow,
    .progression-arrow-left,
    .progression-arrow-right {
        width: 50px;
        vertical-align: baseline;
        cursor: pointer;
    }

    .progression-arrow-right {}

    .progression-arrow-left {}

    .instructions-tagline {
        font-size: 1rem;
        font-weight: 700;
        vertical-align: 45%
    }

    #installation-popup-1 {
        position: absolute;
        bottom: 0%;
        width: 10%;
        text-align: center;
        margin: 0 auto;
        left: 0;
        right: 0;
        display: block;
        border: none;
        z-index: 20000;
    }

    #installation-popup-1-close {
        width: 9%;
        position: absolute;
        top: 8px;
        right: 3%;
    }

    .intro-curved-arrow {
        position: fixed;
        bottom: 22%;
        width: 13rem;
    }
}

/* END: @media only screen and (min-width: 768px) and (max-width: 989px)  */
/* Laptops and large tablets in landscape mode */
@media only screen and (min-width: 990px) and (max-width: 1600px) {
    .main-logo {
        width: 60%;
        margin-top: 50%;
    }

    .start-page-info {
        top: 60%;
        position: fixed;
        width: 100%;
        text-align: center;
        font-size: 300%;
    }

    .intro-btn {
        width: 120%;
        bottom: 10rem;
        position: relative;
    }

    .start-btn {
        width: 120%;
        bottom: 10rem;
        position: relative;
    }

    #install-app-icon {
        margin-left: auto;
        margin-right: auto;
        height: 35rem;
    }

    #install-app-txt {
        height: 22rem;
    }

    #install-app-close-icon {
        right: .5rem;
        top: -6.5rem;
        position: absolute;
        height: 4rem;
    }

    #install-app-donotshow {
        height: 16rem;
    }

    .intro-start-button {
        width: 92%;
        bottom: 6rem;
        position: relative;
    }

    .intro-button-initial {
        position: fixed;
        bottom: 10%;
        width: 7rem;
        height: 1.9rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: 1.2rem;
        padding: .5rem;
        padding-top: .75rem;
        padding-bottom: .25rem;
        cursor: pointer;
        float: left;
        margin-left: 12%;
        border: 3px solid #08BF19;
        text-align: center;
    }

    .start-button {
        display: inline-block;
        color: #ffffff;
        width: 6rem;
        height: 1.9rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: .9rem;
        padding: .5rem;
        padding-top: .75rem;
        padding-bottom: 0;
        cursor: pointer;
        margin: 0 auto;
        margin-left: 5px;
        border: 3px solid #08BF19;
    }

    .lock-icon {
        position: absolute;
        top: 5px;
        right: 5px;
        margin: 0 auto;
        cursor: pointer
    }

    .instructions {
        /* background-image: url('/img/background.svg');
        background-size: cover; */
        position: absolute;
        top: 0;
        left: 0px;
        height: 100%;
        width: 100%;
        min-width: 100%;
    }

    .instructions-logo {
        width: 25%;
        margin-top: 3%;
    }

    .instructions-table {
        font-size: .9rem;
        color: #ffffff;
        /* margin: 0px 10%; */
    }

    .instructions-table-text-cells {
        padding-left: .5rem;
        padding-right: .5rem;
    }

    .instruction-icons {
        height: 40%;
        margin-top: 15%;
        /* margin-bottom: 1rem; */
    }

    .progression-dots {
        width: .6rem;
        display: inline-block;
        height: 100%;
        margin-right: 10px;
    }

    .progression-arrow,
    .progression-arrow-left,
    .progression-arrow-right {
        width: 50px;
        vertical-align: baseline;
        cursor: pointer;
    }

    .progression-arrow-right {}

    .progression-arrow-left {}

    .instructions-tagline {
        font-size: 1rem;
        font-weight: 700;
        vertical-align: 45%
    }

    #installation-popup-1 {
        position: absolute;
        bottom: 0%;
        width: 10%;
        text-align: center;
        margin: 0 auto;
        left: 0;
        right: 0;
        display: block;
        border: none;
        z-index: 20000;
    }

    #installation-popup-1-close {
        width: 9%;
        position: absolute;
        top: 8px;
        right: 3%;
    }

    .intro-curved-arrow {
        position: fixed;
        bottom: 22%;
        width: 13rem;
    }
}

/* END @media only screen and (min-width: 990px) and (max-width: 1600px) */
/* LANDSCAPE breakpoints */
/* Mobile Landscape Size to Tablet Portrait (devices and browsers) */
@media only screen and (min-width: 250px) and (max-width: 479px) and (orientation: landscape) {
    .main-logo {
        width: 60%;
        margin-top: 45%;
    }

    .start-page-info {
        position: fixed;
        width: 100%;
        text-align: center;
        font-size: 100%;
    }

    .intro-btns {
        height: 4rem;
    }

    .intro-done-button {
        width: 12rem;
        height: 3.5rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: 1.55rem;
        padding: .5rem;
        padding-top: 1.85rem;
        padding-bottom: .25rem;
        cursor: pointer;
        border: 3px solid #08BF19;
        margin: 0 auto;
        margin-top: 2%;
        text-align: center;
    }

    .start-button {
        display: inline-block;
        color: #ffffff;
        width: 6rem;
        height: 1.9rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: .9rem;
        padding: .5rem;
        padding-top: .75rem;
        padding-bottom: 0;
        cursor: pointer;
        margin: 0 auto;
        margin-left: 5px;
        border: 3px solid #08BF19;
    }

    .lock-icon {
        position: absolute;
        top: 5px;
        right: 5px;
        margin: 0 auto;
        cursor: pointer
    }

    .instructions {
        /* background-image: url('/img/background.svg');
        background-size: cover; */
        position: absolute;
        top: 0;
        left: 0px;
        height: 100%;
        width: 100%;
        min-width: 100%;
    }

    .instructions-logo {
        width: 7rem;
        margin-top: 1rem;
    }

    .instructions-table {
        font-size: .7rem;
        color: #ffffff;
        /* margin: 0px 10%; */
    }

    .instructions-table-text-cells {
        padding-left: .5rem;
        padding-right: .5rem;
    }

    .instruction-icons {
        height: 2.5rem;
        margin-top: 1.2rem;
        /* margin-bottom: 1rem; */
    }

    .progression-dots {
        width: .6rem;
        display: inline-block;
        height: 100%;
        margin-right: 10px;
    }

    .progression-arrow,
    .progression-arrow-left,
    .progression-arrow-right {
        width: 50px;
        vertical-align: baseline;
        cursor: pointer;
    }

    .progression-arrow-right {}

    .progression-arrow-left {}

    .instructions-tagline {
        font-size: 1rem;
        font-weight: 700;
        vertical-align: 45%
    }

    #installation-popup-1 {
        position: absolute;
        bottom: 0%;
        width: 10%;
        text-align: center;
        margin: 0 auto;
        left: 0;
        right: 0;
        display: block;
        border: none;
        z-index: 20000;
    }

    #installation-popup-1-close {
        width: 9%;
        position: absolute;
        top: 8px;
        right: 3%;
    }

    .intro-curved-arrow {
        position: fixed;
        bottom: 22%;
        width: 10rem;
    }
}

/* Mobile Landscape Size to Tablet Portrait (devices and browsers) */
@media only screen and (min-width: 480px) and (max-width: 670px) and (orientation: landscape) {
    .main-logo {
        width: 60%;
        margin-top: 45%;
    }

    .start-page-info {
        position: fixed;
        width: 100%;
        text-align: center;
        font-size: 100%;
    }

    .intro-btns {
        height: 4rem;
    }

    .intro-done-button {
        width: 12rem;
        height: 3.5rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: 1.55rem;
        padding: .5rem;
        padding-top: 1.85rem;
        padding-bottom: .25rem;
        cursor: pointer;
        border: 3px solid #08BF19;
        margin: 0 auto;
        margin-top: 2%;
        text-align: center;
    }

    .start-button {
        display: inline-block;
        color: #ffffff;
        width: 6rem;
        height: 1.9rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: .9rem;
        padding: .5rem;
        padding-top: .75rem;
        padding-bottom: 0;
        cursor: pointer;
        margin: 0 auto;
        margin-left: 5px;
        border: 3px solid #08BF19;
    }

    .lock-icon {
        position: absolute;
        top: 5px;
        right: 5px;
        margin: 0 auto;
        cursor: pointer
    }

    .instructions {
        /* background-image: url('/img/background.svg');
        background-size: cover; */
        position: absolute;
        top: 0;
        left: 0px;
        height: 100%;
        width: 100%;
        min-width: 100%;
    }

    .instructions-logo {
        width: 7rem;
        margin-top: 1rem;
    }

    .instructions-table {
        font-size: .7rem;
        color: #ffffff;
        /* margin: 0px 10%; */
    }

    .instructions-table-text-cells {
        padding-left: .5rem;
        padding-right: .5rem;
    }

    .instruction-icons {
        height: 2.5rem;
        margin-top: 1.2rem;
        /* margin-bottom: 1rem; */
    }

    .progression-dots {
        width: .6rem;
        display: inline-block;
        height: 100%;
        margin-right: 10px;
    }

    .progression-arrow,
    .progression-arrow-left,
    .progression-arrow-right {
        width: 50px;
        vertical-align: baseline;
        cursor: pointer;
    }

    .progression-arrow-right {}

    .progression-arrow-left {}

    .instructions-tagline {
        font-size: 1rem;
        font-weight: 700;
        vertical-align: 45%
    }

    #installation-popup-1 {
        position: absolute;
        bottom: 0%;
        width: 10%;
        text-align: center;
        margin: 0 auto;
        left: 0;
        right: 0;
        display: block;
        border: none;
        z-index: 20000;
    }

    #installation-popup-1-close {
        width: 9%;
        position: absolute;
        top: 8px;
        right: 3%;
    }

    .intro-curved-arrow {
        position: fixed;
        bottom: 22%;
        width: 10rem;
    }
}

/* END @media only screen and (min-width: 480px) and (max-width: 670px) and (orientation: landscape) */
@media only screen and (min-width: 671px) and (max-width: 860px) and (orientation: landscape) {
    .main-logo {
        width: 60%;
        margin-top: 30%;
    }

    .start-page-info {
        position: fixed;
        width: 100%;
        text-align: center;
        font-size: 100%;
    }

    .intro-button {
        display: inline-block;
        width: 6rem;
        height: 1.9rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: .9rem;
        padding: .5rem;
        padding-top: .75rem;
        padding-bottom: 0;
        cursor: pointer;
        margin: 0 auto;
        margin-right: 5px;
        border: 3px solid #08BF19;
    }

    .intro-button-initial {
        position: fixed;
        bottom: 10%;
        width: 8rem;
        height: 1.9rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: 1.2rem;
        padding: .5rem;
        padding-top: .75rem;
        padding-bottom: .25rem;
        cursor: pointer;
        float: left;
        margin-left: 7%;
        border: 3px solid #08BF19;
        text-align: center;
    }

    .intro-done-button {
        width: 12rem;
        height: 3.5rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: 1.55rem;
        padding: .5rem;
        padding-top: 1.85rem;
        padding-bottom: .25rem;
        cursor: pointer;
        border: 3px solid #08BF19;
        margin: 0 auto;
        margin-top: 2%;
        text-align: center;
    }

    .start-button {
        display: inline-block;
        color: #ffffff;
        width: 6rem;
        height: 1.9rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: .9rem;
        padding: .5rem;
        padding-top: .75rem;
        padding-bottom: 0;
        cursor: pointer;
        margin: 0 auto;
        margin-left: 5px;
        border: 3px solid #08BF19;
    }

    .lock-icon {
        position: absolute;
        top: 5px;
        right: 5px;
        margin: 0 auto;
        cursor: pointer
    }

    .instructions {
        /* background-image: url('/img/background.svg');
        background-size: cover; */
        position: absolute;
        top: 0;
        left: 0px;
        height: 100%;
        width: 100%;
        min-width: 100%;
    }

    .instructions-logo {
        width: 7rem;
        margin-top: 1rem;
    }

    .instructions-table {
        font-size: .7rem;
        color: #ffffff;
        /* margin: 0px 10%; */
    }

    .instructions-table-text-cells {
        padding-left: .5rem;
        padding-right: .5rem;
    }

    .instruction-icons {
        height: 2.5rem;
        margin-top: 1.2rem;
        /* margin-bottom: 1rem; */
    }

    .progression-dots {
        width: .6rem;
        display: inline-block;
        height: 100%;
        margin-right: 10px;
    }

    .progression-arrow,
    .progression-arrow-left,
    .progression-arrow-right {
        width: 50px;
        vertical-align: baseline;
        cursor: pointer;
    }

    .progression-arrow-right {}

    .progression-arrow-left {}

    .instructions-tagline {
        font-size: 1rem;
        font-weight: 700;
        vertical-align: 45%
    }

    #installation-popup-1 {
        position: absolute;
        bottom: 0%;
        width: 10%;
        text-align: center;
        margin: 0 auto;
        left: 0;
        right: 0;
        display: block;
        border: none;
        z-index: 20000;
    }

    #installation-popup-1-close {
        width: 9%;
        position: absolute;
        top: 8px;
        right: 3%;
    }

    .intro-curved-arrow {
        position: fixed;
        bottom: 22%;
        width: 10rem;
    }
}

/* END: @media only screen and (min-width:671px) and (max-width: 860px) and (orientation: landscape) */
@media only screen and (min-width: 861px) and (max-width: 1200px) and (orientation: landscape) {
    .main-logo {
        width: 60%;
        margin-top: 30%;
    }

    .start-page-info {
        position: fixed;
        width: 100%;
        text-align: center;
        font-size: 100%;
    }

    .intro-button {
        display: inline-block;
        width: 6rem;
        height: 1.9rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: .9rem;
        padding: .5rem;
        padding-top: .75rem;
        padding-bottom: 0;
        cursor: pointer;
        margin: 0 auto;
        margin-right: 5px;
        border: 3px solid #08BF19;
    }

    .intro-button-initial {
        position: fixed;
        bottom: 10%;
        width: 8rem;
        height: 1.9rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: 1.2rem;
        padding: .5rem;
        padding-top: .75rem;
        padding-bottom: .25rem;
        cursor: pointer;
        float: left;
        margin-left: 7%;
        border: 3px solid #08BF19;
        text-align: center;
    }

    .intro-done-button {
        width: 12rem;
        height: 3.5rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: 1.55rem;
        padding: .5rem;
        padding-top: 1.85rem;
        padding-bottom: .25rem;
        cursor: pointer;
        border: 3px solid #08BF19;
        margin: 0 auto;
        margin-top: 2%;
        text-align: center;
    }

    .start-button {
        display: inline-block;
        color: #ffffff;
        width: 6rem;
        height: 1.9rem;
        background-color: #04A317;
        color: #ffffff;
        font-weight: 700;
        font-size: .9rem;
        padding: .5rem;
        padding-top: .75rem;
        padding-bottom: 0;
        cursor: pointer;
        margin: 0 auto;
        margin-left: 5px;
        border: 3px solid #08BF19;
    }

    .lock-icon {
        position: absolute;
        top: 5px;
        right: 5px;
        margin: 0 auto;
        cursor: pointer
    }

    .instructions {
        /* background-image: url('/img/background.svg');
        background-size: cover; */
        position: absolute;
        top: 0;
        left: 0px;
        height: 100%;
        width: 100%;
        min-width: 100%;
    }

    .instructions-logo {
        width: 7rem;
        margin-top: 1rem;
    }

    .instructions-table {
        font-size: .7rem;
        color: #ffffff;
        /* margin: 0px 10%; */
    }

    .instructions-table-text-cells {
        padding-left: .5rem;
        padding-right: .5rem;
    }

    .instruction-icons {
        height: 2.5rem;
        margin-top: 1.2rem;
        /* margin-bottom: 1rem; */
    }

    .progression-dots {
        width: .6rem;
        display: inline-block;
        height: 100%;
        margin-right: 10px;
    }

    .progression-arrow,
    .progression-arrow-left,
    .progression-arrow-right {
        width: 50px;
        vertical-align: baseline;
        cursor: pointer;
    }

    .progression-arrow-right {}

    .progression-arrow-left {}

    .instructions-tagline {
        font-size: 1rem;
        font-weight: 700;
        vertical-align: 45%
    }

    #installation-popup-1 {
        position: absolute;
        bottom: 0%;
        width: 10%;
        text-align: center;
        margin: 0 auto;
        left: 0;
        right: 0;
        display: block;
        border: none;
        z-index: 20000;
    }

    #installation-popup-1-close {
        width: 9%;
        position: absolute;
        top: 8px;
        right: 3%;
    }

    .intro-curved-arrow {
        position: fixed;
        bottom: 22%;
        width: 10rem;
    }
}

/* END: @media only screen and (min-width: 861px) and (max-width: 1200px) and (orientation: landscape) */
@media screen and (min-width: 240px) and (max-width:1200px) and (orientation: landscape) {
    html {
        transform: rotate(-90deg);
        transform-origin: left top;
        width: 100vh;
        height: 100vw;
        overflow: scroll;
        position: absolute;
        top: 100%;
        left: 0;
    }
}
