@charset "UTF-8";
* { box-sizing: border-box; }
html, body { margin: 0 auto; padding: 0; }
body {
    font-family: 'Montserrat', sans-serif;
    font-size: 16px; line-height: 1.5em;
    -webkit-font-smoothing: subpixel-antialiased;
    -webkit-tap-highlight-color: transparent;
    -webkit-text-size-adjust: 100%;
    background: #fff; color: #000;
    position: relative;
}
input[type=submit],
button { -webkit-appearance: none; }

a { color: #000; }
strong { font-weight: 600; }
img { max-width: 100%; height: auto; }

#main {
    color: #fff;
}
body.auth_patient #main,
body.auth_medical #main {
    background: #fff url('../img/bg_home.jpg') 50% 0 no-repeat;
    /*background-size: 100% auto;*/
    color: #fff;
}
body.auth_medical #main,
body.account_medical2step #main,
body.account_medical3step #main,
body.account_medical4step #main,
body.account_default.medical #main {
    background: #fff url('../img/bg_auth_medical.jpg') 50% 0 no-repeat;
}
body.auth_patient #main,
body.account_patient2step #main,
body.account_default.patient #main {
    background: #fff url('../img/bg_auth_patient.jpg?cccnew') 50% 0 no-repeat;
}
body.auth_default #main,
body.account_default #main {
    background: #fff url('../img/bg_auth_default.jpg') 50% 0 no-repeat;
}
body.account_default #main header,
body.auth_patient #main header,
body.account_patient2step #main header,
body.auth_medical #main header,
body.account_medical2step #main header,
body.account_medical3step #main header,
body.account_medical4step #main header,
body.auth_default #main header {
    background: transparent;
}
body.account_default #main .mirror,
body.account_patient2step #main .mirror,
body.account_medical2step #main .mirror,
body.account_medical3step #main .mirror,
body.account_medical4step #main .mirror,
body.auth_default #main .mirror {
    font-weight: 600;
}
.mirror {
    margin: 0 auto;
    max-width: 788px;
}

header {
    background: #00a9d5;
}
header .container {
    position: relative;
}
header #logo {
    padding: 25px 0 20px 10px; display: inline-block;
}
#userMenu {
    /*position: absolute; top: 0; right: 0; z-index: 9999999999;*/
    padding: 5px 15px;
    background: #00a9d5;
}
#userMenu a {
    color: #fff;
}

.valign:before {
    content: '';
    height: 100%;
    margin-right: -0.25em;
    vertical-align: middle;
    display: inline-block;
}

footer {
    padding-bottom: 40px;
    text-align: center; color: #000; font-size: 14px;
}
footer a { color: #000; }
footer .bg_img_footer { margin-top: 80px; }


.icon_icci { width: 115px; height: 115px; }
.icon_icci.white path { fill: #fff; }
.icon_icci.blue path { fill: #00a9d5; }
.icon_icci.green path { fill: #496a65; }

.program-contains {
    background: #00a9d5; color: #fff;
}
.program-contains .title { padding: 40px 0; color: #fff; }
.program-contains ul li { font-size: 18px; line-height: 22px; font-weight: 600; margin-bottom: 1em }

.what-you-get {
    background: #00a9d5; color: #fff;
    text-align: center;
}
.what-you-get .box { margin-bottom: 40px; }
.what-you-get .title { padding: 40px 0; color: #fff; }
.what-you-get .box .text {
    padding: 0 10px;
    font-size: 14px; line-height: 20px; font-weight: 600;
}

.bgBlue { background: #00a9d5; color: #fff; }
.bgBlue a,
.bgBlue h2,
.bgBlue h3 { color: #fff; }
.bgBlue .form legend { color: #fff; text-align: center; margin-left: auto; margin-right: auto }
.bgBlue .form label { color: #fff; }
.bgBlue .form input,
.bgBlue .form textarea,
.bgBlue .form select { border-color: #fff; }
.bgBlue .form .button { border-color: #fff; }
/*.bgBlue .form fieldset:last-of-type { text-align: center; }*/
/*.bgBlue .form fieldset:last-of-type div { width: calc(100% + 15px); padding-top: 20px; padding-bottom: 20px;  }*/

.bgBlue .form label .consent-info-icon {
    color: #00a9d5;
    background: #fff;
}

.bgBlue .form label .consent-info-text {
    background: #fff;
    color: #000;
}


.bg_blue_footer { display: inline-block; }
.nowrap { white-space: nowrap; }

#steps {
    margin: 150px 0 0 0;
    padding: 0 0 50px; position: relative; text-align: center;
}
#steps .item {
    border-right: 2px solid #fff;
    /*padding-top: 20px;*/
    margin-bottom: 20px;
}
#steps .item:last-child {
    border-right: 0;
}
#steps .step {
    margin-top: -10px;
    text-align: center;
    text-decoration: none;
}
#steps .step .wrapper {
    margin-bottom: 0px;
    padding: 12px;
    display: inline-block;
}
#steps span.text {
    padding: 5px 10px;
    display: block; color: #fff; font-size: 15px; line-height: 18px;
}
#steps span.num {
    font-size: 16px; line-height: 20px;
}
#steps .step a { color: #fff; }
#steps .step b {
    height: 40px; font-size: 28px; vertical-align: middle; font-weight:700;
    display: inline-block;
    color: #fff; text-align: center;
}
#steps .step b sup { margin-left: 1px; font-size: 12px; line-height: 12px; display: inline-block; font-weight: normal }
#steps.active1 .step.n1 span,
#steps.active2 .step.n2 span,
#steps.active4 .step.n4 span,
#steps.active3 .step.n3 span { color: #00a9d5; }
#steps.active1 .step.n1 b,
#steps.active2 .step.n2 b,
#steps.active4 .step.n4 b,
#steps.active3 .step.n3 b { color: #00a9d5; /*background-color: #00a9d5; border-color: #00a9d5;*/ }
#steps.active1 .step.n1 .wrapper,
#steps.active2 .step.n2 .wrapper,
#steps.active4 .step.n4 .wrapper,
#steps.active3 .step.n3 .wrapper { border-color: #00a9d5; }
#steps.active1 .step.n1 span.num,
#steps.active2 .step.n2 span.num,
#steps.active4 .step.n4 span.num,
#steps.active3 .step.n3 span.num { font-weight: 700 }
#steps .stepindicator {
    width: 600px; height: 12px; line-height: 35px; position: absolute; left: 20px; top: 20px;
    z-index: 9;
    /*background: transparent url('./images/steps_indicator.png') 0 0 no-repeat;*/
    border-top: 1px dashed #ccc;
}
body.auth_medical #steps {
    margin-top: 100px;
}
body.auth_patient #steps .step a,
body.auth_patient #steps .step b,
body.auth_patient #steps span.text,
body.auth_medical #steps .step a,
body.auth_medical #steps .step b,
body.auth_medical #steps span.text {
    opacity: .5;
}

#objectimage { position: relative; }
#objectimage img.bg { width: 100%; height: auto; display: block; }

.rotate {
    display: inline-block;
    -webkit-transform:rotate(-90deg);
    -o-transform:rotate(-90deg);
    -ms-transform:rotate(-90deg);
}

#page {
    padding: 20px 0 0px;
    color: #000;
}
body.auth_default #page,
body.account_patient2step #page,
body.account_medical2step #page,
body.account_medical3step #page,
body.account_medical4step #page,
body.account_default #page {
    padding-top: 240px;
}
body.auth_default #page {
    color: #fff;
}
body.auth_default #page p.blackText {
    color: #000; font-weight: 400;
}
#page .container {  }
h1 {
    margin: 0; padding: 20px 0 40px;
    font-size: 32px; line-height: 1.2; font-weight: 700;
    text-transform: uppercase;
    color: #00a9d5;
}
h2 {
    margin: 0; padding: 40px 0;
    font-size: 28px; line-height: 1.2; font-weight: 700;
    text-transform: uppercase;
    color: #00a9d5;
}
.form legend,
h3 {
    margin: 0; padding: 40px 0 30px;
    font-size: 24px; line-height: 1.2; font-weight: 700;
    text-transform: uppercase;
    color: #00a9d5;
}
ul, ol {
    margin: 0 0 0 1.5em; padding: 0;
}
ul li, ol li {
    margin: 0 0 .5em; padding: 0;
}
ul.fakeList {
    list-style-type: none;
}

blockquote {
    margin: 30px 0 30px 0; padding: 15px 15px 15px 20px;
    border-left: solid 3px #00a9d5;
    background: #efefef;
}
blockquote p {
    margin: 0 0 1em;
    font-size: 18px;
    font-style: italic;
}
blockquote footer {
    margin: 0; padding: 0 0 0 25px;
    text-align: left;
    position: relative;
}
blockquote footer:before {
    content: '—';
    position: absolute; left: 0;
}

#who .text a {
    padding-top: 30px; display: inline-block;
    font-weight: 400; text-transform: uppercase; font-size: 24px; line-height: 26px; text-decoration: none;
}
#who a .icon_icci {
    width: 82px; height: 100px;
}
#who .patient {
    border-right: 2px solid #496a65;
}

.form input.button,
.form input[type=submit],
.button {
    background-color: #00a9d5; color: #fff; border: 2px solid #00a9d5; text-transform: uppercase;
    font-size: 20px; line-height: 1em; font-weight: 400; font-family: 'Montserrat', sans-serif;
    display: inline-block; padding: 20px 50px; text-decoration: none;
    cursor: pointer;
}
.button.light { background: transparent; border-color: #00a9d5; color: #00a9d5; }
.button.light.white { background: transparent; border-color: #fff; color: #fff; }
.button.small { padding: 5px 10px; font-size: 14px; }
.button.big { padding: 30px 60px; font-size: 48px; }

#msg,
.msg,
.flash,
.form-error {
    max-width: 75%; font-size: 18px;
    margin: 10px auto 20px; padding: 10px 20px;
    background: #fff; color: #E03C3C; border: 4px solid #E03C3C; font-weight: 600;
}
.form-error .button {
    margin-left: 5px;
}
.form-error,
.flash {
    margin: 10px auto 40px;
    text-align: center; background: #E03C3C; color: #fff;
}
.flash.info {
    background: green; border-color: green;
}

.form-error-message {
    margin: 0 0 20px; padding: 1px; font-size: 18px;
}
.form-error-message,
#fillFakeDataButton {
    background: #cc0000; color: #fff;
}

#frm-loginForm,
#frm-recoverPasswordForm,
#frm-newPasswordForm,
#frm-changePasswordForm {
    max-width: 480px;
    margin: 0 auto;
}

.fluidMedia {
    position: relative;
    padding-bottom: 56.25%;
    padding-top: 30px;
    height: 0;
    overflow: hidden;
}
.fluidMedia iframe {
    position: absolute; top: 0; left: 0;
    width: 100%; height: 100%
}

table.table {
    width: 100%;
    margin: 20px auto;
    border-spacing: 5px;
    border-collapse: separate;
}
table.table.promocode {
    width: auto;
}
table.table tr td {
    padding: 10px 15px; background: #EFEFEF;
}
table.table tr td.nopadding {
    padding: 0;
}
table.table.files tr td {
    border-bottom: 10px solid #fff;
}
table.table.promocode tr td {
    width: 240px;
}
table.table tr td img.fileicon {
    /*width: 32px; height: auto;*/
    vertical-align: middle; margin-right: 5px;
}

#overlay {
    position: fixed; top: 0; right: 0; bottom: 0; left: 0; z-index: 99999999999; display: none;
    /*background: rgba(0,0,0, .9); color: #fff; display: none;*/
    background: rgba(0,169,213, 1); color: #fff;
}
#overlay .info { position: relative; top: 40%; color: #fff; font-size: 18px; text-align: center; text-transform: uppercase; }
#overlay .info p { margin: 0; padding: 0; }
#overlay .info p span { display: inline-block; max-width: 240px }
#overlay .info i { font-size: 64px; margin-bottom: 30px }


#registration-notice {
    display: none;
}
.registration-notice-box {
    margin-top: 2em
}
.registration-notice-box p:last-child {
    margin-bottom: 0
}

#popup {
    display: none;
    position: fixed; top: 0; right: 0; bottom: 0; left: 0; z-index: 99999999999;
    background: rgba(0,169,213, .9); color: #fff;
}
#popup .popup-box {
    max-width: 640px; margin: 0 auto; padding: 25px 25px 15px;
    position: relative; top: 40%; color: #000; font-size: 18px; text-align: center; background: #fff
}
#popup .popup-box .button {
    margin: 0 15px;
}
#popup .popup-box #popup-close {
    position: absolute; top: 5px; right: 5px;
    text-decoration: none; font-size: 36px;
}

@media only screen and (max-width: 1200px) {

}
@media only screen and (max-width: 980px) {

}
@media only screen and (max-width: 768px) {
    body.auth_default #page {
        padding-top: 180px;
    }
    #steps {
        margin-top: 60px;
    }
    body.auth_medical #steps {
        margin-top: 40px;
        padding-bottom: 0;
    }
    #who .text a {
        display: block;
        text-align: center;
    }
}
@media only screen and (max-width: 640px) {
    body.auth_default #page {
        padding-top: 140px;
    }
}
@media only screen and (max-width: 480px) {

    body.auth_patient #page {

    }
    body.auth_default #page {
        padding-top: 80px;
    }
    body.account_default #page {
        padding-top: 140px;
    }
    #steps {
        margin-top: 20px;
    }
    #steps .item {
        border-right: none;
    }
    #who .text a {
        padding-top: 20px;
        font-size: 18px; line-height: 20px; text-decoration: none;
    }
    #who .text {
        text-align: center;
    }
    table.table.files {
        margin-top: 0;
        margin-bottom: 0;
        border-spacing: 0;
    }
    table.table.files,
    table.table.files thead,
    table.table.files tbody,
    table.table.files tfoot,
    table.table.files tr,
    table.table.files tr th,
    table.table.files tr td {
        display: inline-block;
    }
    table.table.files tr {
        margin-bottom: 1em;
        background: #EFEFEF;
    }
    table.table.files tr th {
        display: none;
    }
    table.table.files tr td {
        border-bottom: 0;
        text-align: left!important;
    }
    table.table.files .language_cell {
        display: none;
    }
}
@media only screen and (max-width: 420px) {
    body.auth_default #page {
        padding-top: 40px;
    }
}
@media only screen and (max-width: 375px) {
    body.auth_default #page {
        padding-top: 0px;
        font-size: 14px;
    }
    #steps {
        margin-top: 0px;
    }
    #steps .item {
        margin-top: 10px;
        margin-bottom: 10px;
    }
    #steps .item span {
        padding-left: 0px;
        padding-right: 0px;
    }
    #who .text a {
        padding-top: 0px;
        font-size: 18px; line-height: 20px; text-decoration: none;
    }
    #who .patient {
        border-right: none;
        padding-bottom: 20px;
    }
}
@media only screen and (max-width: 320px) {}