﻿/*----------------------------------------------------------
dark blue:       #002640
trial blue:      #232f3d
orange:          #FFA622
trial orange:    #ff9900
green (in logo): #00B050
blue (in logo):  #0079D3
menu highlight : #47779d;
----------------------------------------------------------*/

*
{
    font-family: "Roboto";
}

body
{
    font-size: 13pt;
    margin: 0;
    padding: 0;
    color: #ddd;
}

select
{
    height: 32px;
    font-size: 16px;
    max-width: calc(100% - 1px);
    background-color: lightgray;
}
    select option
    {
        max-width: calc(100% - 1px);
        background-color: #fff;
    }

table
{
    border-spacing: 0;
    border-collapse: collapse;
}

.centerMiddle /* horizontal and vertical */
{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

#footer
{
    font-size: 9pt;
    white-space: nowrap;
    color: #ccc;
    position: absolute;
    left: 50%;
    transform: translate(-50%, -50%);
    bottom: 6px;
    z-index: -1;
}

.tagline
{
    color: #002640;
    font-size: 11pt;
    text-align: right;
}

/*----------------------------------------------------------*/
/* BACKGROUND                                               */
/*----------------------------------------------------------*/

.background
{
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-position: center;
    background-size: cover;
    /*opacity: 1;*/
    z-index: -2;
    transition: all 3s;
    -webkit-transition: all 3s;
    -moz-transition: all 3s;
}
    .background:not(.zoomout)
    {
        /*opacity: 1;*/
        transform: scale(1.05);
        -webkit-transform: scale(1.05);
        -moz-transform: scale(1.05);
        -ms-transform: scale(1.05);
    }

/*----------------------------------------------------------*/
/* FADE                                                     */
/*----------------------------------------------------------*/

.fade-in
{
    animation: fadeIn ease 1s;
    -webkit-animation: fadeIn ease 1s;
    -moz-animation: fadeIn ease 1s;
    -o-animation: fadeIn ease 1s;
}

@keyframes fadeIn
{
    0%
    {
        opacity: 0;
    }

    100%
    {
        opacity: 1;
    }
}

@-moz-keyframes fadeIn
{
    0%
    {
        opacity: 0;
    }

    100%
    {
        opacity: 1;
    }
}

@-webkit-keyframes fadeIn
{
    0%
    {
        opacity: 0;
    }

    100%
    {
        opacity: 1;
    }
}

@-o-keyframes fadeIn
{
    0%
    {
        opacity: 0;
    }

    100%
    {
        opacity: 1;
    }
}

/*----------------------------------------------------------*/
/* MESSAGES                                                 */
/*----------------------------------------------------------*/

.titleMessage
{
    font-size: 14pt;
    font-weight: normal;
    text-align: center;
    color: #EEE;
    margin-top: 0;
    margin-bottom: 8px;
}
    .titleMessage.small
    {
        font-size: 16px;
        margin-bottom: 0;
    }

.errorMessage
{
    font-size: 14pt;
    font-weight: normal;
    text-align: center;
    color: #fff900;
    margin-top: 8px;
    margin-bottom: 8px;
}
.errorMessage > span
{
    white-space: pre-line;
}

.statusMessage
{
    font-size: 12pt;
    font-weight: normal;
    color: #FFA622;
    margin-bottom: 12px;
    margin-top: 8px;
}

.infoMessage
{
    font-size: 14px;
    font-weight: normal;
    color: #FFA622;
    padding: 0 21px 0 21px;
}
    .infoMessage.large
    {
        font-size: 20px;
    }

.verifyMessage
{
    font-size: 22px;
    color: #EEE;
    margin-bottom: 12px;
    margin-top: 8px;
    display: block;
}
    .verifyMessage.small
    {
        font-size: 16px;
    }
    .verifyMessage li
    {
        font-size: 12pt;
        padding-bottom: 12px;
    }

.statusFailures
{
    position: absolute;
    bottom: 6px;
    right: 8px;
    font-size: 8pt;
    font-weight: normal;
    color: #6e747b;
}

/*----------------------------------------------------------*/
/* BUTTONS - navButton                                      */
/*----------------------------------------------------------*/

.navButton
{
    border: 1px solid;
    border-color: transparent;
    font-weight: normal;
    font-size: 18pt;
    width: calc(100% - 2px);
    height: 47px;
    margin-top: 12px;
    margin-bottom: 12px;
    cursor: pointer;
    background-color: #43a047;
    color: #f2f2f2;
}

    .navButton:hover
    {
        border-color: #FFA622;
    }
    .navButton.split
    {
        width: calc(50% - 12px);
    }
    .navButton.sendSMS
    {
        width: 215px;
    }
    .navButton.split.left
    {
        float: left;
    }
    .navButton.split.right
    {
        float: right;
        margin-top: 0;
        margin-right: 2px;
    }
    .navButton.secondary
    {
        background-color: #039be5;
        color: #f2f2f2;
    }
    .navButton:disabled
    {
        background-color: #b9b9b9;
        color: #6c6c6c;
        cursor: auto;
    }

/*----------------------------------------------------------*/
/* BUTTONS - navButtonLink                                  */
/*----------------------------------------------------------*/

.navButtonLink
{
    border: 1px solid;
    border-color: transparent;
    background-color: transparent;
    font-weight: normal;
    font-size: 13pt;
    color: #70bbfe;
    cursor: pointer;
    margin-bottom: 8px;
}

    .navButtonLink:hover
    {
        border-color: #FFA622;
    }
    .navButtonLink.tight
    {
        margin-top: 0;
        margin-bottom: 0;
    }
    .navButtonLink:disabled
    {
        color: #6c6c6c;
        cursor: auto;
    }
    .navButtonLink.split
    {
    }
        .navButtonLink.split.left
        {
            float: left;
        }
        .navButtonLink.split.right
        {
            float: right;
        }

/*----------------------------------------------------------*/
/* INPUT                                                    */
/*----------------------------------------------------------*/

.navInput
{
    height: 41px;
    font-size: 14pt;
    margin-bottom: 12px;
    padding: 0 0 0 10px;
    width: calc(100% - 15px);
    border: 1px solid;
    border-color: transparent;
}
    .navInput:hover
    {
        border-color: #FFA622;
    }
    /*.navInput:disabled
    {
        height: 41px;
        font-size: 14pt;
        margin-bottom: 12px;
        padding: 0 0 0 10px;
        width: calc(100% - 15px);
        border: 1px solid;
        border-color: transparent;
    }*/
    /*.navInput.pin
    {
        width: 109px;
        text-align: center;
        padding-left: 0;
        font-size: 22pt;
    }*/
    .navInput.tel
    {
        height: 47px;
        width: 405px; /*227px;*/
        font-size: 18pt;
    }
        .navInput.tel::placeholder
        {
            color: #d7d7d7;
            opacity: 1; /* Firefox */
        }

/*----------------------------------------------------------*/
/* PASSWORD			                                        */
/*----------------------------------------------------------*/

.togglePW
{
    width: 40px;
    text-align: center;
    position: absolute;
    padding: 2px 0;
    right: 2px;
    top: -21px;
    border: 1px solid;
    border-color: transparent;
    font-size: 12px;
    color: #f2f2f2;
    cursor: pointer;
}

    .togglePW:hover
    {
        border-color: #FFA622;
    }

/*----------------------------------------------------------*/
/* CODE INPUT                                               */
/*----------------------------------------------------------*/

.codeInput
{
    text-align: center;
    margin-top: 26px;
}

.codeDigit
{
    width: 40px;
    height: 40px;
    font-size: 35px;
    /*font-weight: bold;*/
    text-align: center;
    margin: 10px 10px 5px 0;
}

/* remove spinners on input elements */
/* Chrome, Safari, Edge, Opera */
input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button
{
    -webkit-appearance: none;
    margin: 0;
}
/* Firefox */
input[type=number]
{
    -moz-appearance: textfield;
}

/*----------------------------------------------------------*/
/* RESPONSIVE PANEL   
/*----------------------------------------------------------*/

.flex-form
{
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
}

.flex-panel
{
    position: relative;
    margin: auto;
    padding: 24px;
    width: 100%;
    max-width: 408px;
    min-width: 270px;
    background-color: #002640;
    border-radius: 7px;
    -webkit-box-shadow: 0px 0px 26px 1px rgba(0,0,0,0.75);
    -moz-box-shadow: 0px 0px 26px 1px rgba(0,0,0,0.75);
    box-shadow: 0px 0px 26px 1px rgba(0,0,0,0.75);
}

.flex-container
{
    z-index: 3;
    display: flex;
    flex-flow: column nowrap;
    justify-content: center;
    align-items: center;
}

.flex-item
{
    width: 100%;
}
    .flex-item.title
    {
        border-bottom: solid 2px #FFA622;
        margin-bottom: 12px;
    }
    .flex-item.relative
    {
        position: relative;
    }
    .flex-item.label
    {
        margin-bottom: 2px;
    }
    .flex-item.split
    {
        width: calc(49%);
    }
        .flex-item.split.left
        {
            float: left;
        }
        .flex-item.split.right
        {
            float: right;
            text-align: right;
        }

/*----------------------------------------------------------*/
/* WAITER/LOADER
/*----------------------------------------------------------*/

.waiter > .wait
{
    display: none;
    z-index: 3;
}

.waiter.wait > .wait
{
    display: inherit;
}

.waiter > .wait > .cover, .waiter > .wait > .overlay
{
    position: absolute;
    top: 0px;
    left: 0px;
    right: 0px;
    bottom: 0px;
}

.waiter > .wait > .cover
{
    background: #666666 url(Images/ui-bg_diagonals-thick_20_666666_40x40.png) 50% 50% repeat;
    opacity: .45;
    filter: Alpha(Opacity=45);
}

.waiter.wait > .wait > .cover
{
    z-index: 4;
}

.waiter.wait > .wait > .overlay
{
    z-index: 5;
}

    /* waiter spinner */
    .waiter.wait > .wait > .overlay > .loader
    {
        position: absolute;
        top: 50%;
        left: 50%;
        margin-top: -24px;
        margin-left: -24px;
        z-index: 4;
        width: 48px;
        height: 48px;
        background: #002640;
        border: 2px solid #FFA622;
        border-radius: 50%;
        display: inline-block;
        position: relative;
        box-sizing: border-box;
        animation: rotation 1s linear infinite;
    }

        .waiter.wait > .wait > .overlay > .loader::after
        {
            content: '';
            box-sizing: border-box;
            position: absolute;
            left: 50%;
            top: 0;
            background: #FFA622;
            width: 3px;
            height: 24px;
            transform: translateX(-50%);
        }

@keyframes rotation
{
    0%
    {
        transform: rotate(0deg);
    }

    100%
    {
        transform: rotate(360deg);
    }
}

/*----------------------------------------------------------*/
/* TWEAKS
/*----------------------------------------------------------*/

.center
{
    text-align: center;
}
.tight
{
    margin-top: 0px;
}
.bump
{
    padding-top: 16px;
}

/*----------------------------------------------------------*/
/* NOTICE
/*----------------------------------------------------------*/

.noticeRow
{
	padding-bottom: 4px;
    color: #000;
}
.noticeRow .noticeArea
{
	border-style: solid;
	border-color: #ff9900;
	background-color: ghostwhite;
	padding: 2px;
}
.noticeRow .noticeHeading
{
	text-align: center;
	font-weight: bold;
	font-size: 12pt;
	padding-bottom: 2px;
    color: #002640;
}
.noticeRow .noticeContent
{
	text-align: center;
	font-size: 10.5pt;
}

/*---------------------------------------------------------------------------------------------------------------*/
/* INTERNATIONAL INPUT OVERRIDE https://github.com/jackocnr/intl-tel-input/blob/master/README.md#demo-and-examples
/*---------------------------------------------------------------------------------------------------------------*/

/* use larger flags */
.iti
{
    --iti-path-flags-1x: url('/Scripts/intl-tel-input-25.3.0/img/flags@2x.png');
    --iti-path-flags-2x: url('/Scripts/intl-tel-input-25.3.0/img/flags@2x.png');
    --iti-flag-height: 24px;
    --iti-flag-width: 32px;
    --iti-flag-sprite-width: 7808px;
    --iti-flag-sprite-height: 24px;
}
.iti__flag
{
    background-image: var(--iti-path-flags-2x);
}
.iti__us
{
    --iti-flag-offset: -7232px;
}
.iti__selected-country
{
    margin: 0 4px 0 0;
}