body {
    background-size: cover;
    background: url('../assets/images/bg.jpg') no-repeat fixed;
    margin: 0;
    font-family: Lato,sans-serif;
}

input[type=email],
input[type=text] {
    background: none repeat scroll 0 0 #ecf0f1;
    border: 1px solid #cbd3d5;
    border-radius: 10px;
    color: #282828;
    font-size: 18px;
    font-weight: 400;
    padding: 20px;
    width: 420px;
}

@media (max-width: 460px) {
    input[type=email],
    input[type=text] {
        width: 100%;
    }
}

.modal-overlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 50;
    background: rgba(0, 0, 0, 0.6);
}

.modal {
    display: block;
    width: 550px;
    max-width: 100%;
    max-height: 100%;
    position: fixed;
    z-index: 100;
    left: 50%;
    top: 50%;

    transform: translate(-50%, -50%);

    background: white;
    box-shadow: 0 0 60px 10px rgba(0, 0, 0, 0.9);
    border: 2px solid #09146d;
    border-radius: 8px;
    text-align: center;
}
.modal-text{
	line-height: 32px;
}

@media only screen and (max-width: 768px) {
    .modal{
        width:93%;
    }
}

.header_section {
    width: 100%;
    height: 38px;
    margin: 15px auto;
    background: url('../assets/images/logo.png') 50% no-repeat;
    background-size: contain;
}

.footer_intro_section {
    margin: 4em auto 0;
    max-width: 760px;
    padding: 0 20px;
    font-size: 10pt;
    color: #000;
}

.footer_intro_section a {
    color: #000000;
}

.footer_section {
    display: none;
    margin: 4em auto 20px;
    max-width: 760px;
    padding: 0 20px;
    font-size: 10pt;
    color: #000;
    text-align: center;
}

.footer_section a {
    color: #000000;
    margin: 0 5px;
}

.content_section {
    max-width: 760px;
    margin: 0 auto;
    padding: 35px;
    border-radius: 20px;
    background-color: #fff;
    color: #253a57;
    -webkit-box-shadow: 0 4px 20px -3px rgba(0,0,0,.46);
    box-shadow: 0 4px 20px -3px rgba(0,0,0,.46);
}

#STEP_INTRO .intro_header {
    text-align: center;
}

#STEP_INTRO h1 {
    font-size: 24px;
    text-align: center;
}

#STEP_INTRO h2 {
    font-size: 20px;
    text-align: center;
    margin: 20px 0;
}

#STEP_INTRO .intro_cards {
    max-width: 300px;
    width: 100%;
    height: 200px;
    margin: 15px auto;
    background: url('../assets/images/cards.png') 50% no-repeat;
    background-size: contain;
}
#STEP_INTRO .intro_cards:hover {
    cursor: pointer;
}

#STEP_INTRO .intro_button {
    margin: 30px auto 0;
    max-width: 300px;
    padding: 10px;
    text-align: center;
    border-radius: 5px;
    background-color: #ffc600;
    -webkit-box-shadow: 0 0 10px 2px rgba(0,0,0,.35);
    box-shadow: 0 0 10px 2px rgba(0,0,0,.35);
    color: #fff;
    font-size: 1em;
}
#STEP_INTRO .intro_button:hover {
    cursor: pointer;
}

#STEP_INTRO .intro_sophia {
    display: flex;
    margin-top: 30px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

#STEP_INTRO .intro_sophia .intro_photo {
    width: 154px;
    height: 232px;
    background: url('../assets/images/sophia_five_stars.jpg') 50% no-repeat;
    background-size: contain;
    margin-bottom: 50px;
}
#STEP_INTRO .intro_sophia span {
    text-align: center;
    line-height: 24px;
}

.progress,
#STEP_QUESTIONS,
#STEP_CARDS,
#STEP_TEXT,
#STEP_NAME_FORM,
#STEP_EMAIL_FORM {
    display: none;
}

.progress {
    width: 100%;
    height: 8px;
    background-color: #ededed;
}

.progress_value {
    height: 100%;
    background-color: #fad120;
    -webkit-transition: width .5s 1s;
    transition: width .5s;
}

#STEP_QUESTIONS [class^='question_'] {
    display: none;
}

#STEP_QUESTIONS .question-variants {
    width: 90%;
    margin: 0 auto 25px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

#STEP_QUESTIONS .question-variants [class^='question-variants_col'] {
    width: 50%;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    flex-direction: column;
    -webkit-flex-direction: column;
}

@media (max-width: 768px) {
    #STEP_QUESTIONS .question-variants {
        flex-direction: column;
    }

    #STEP_QUESTIONS .question-variants [class^='question-variants_col'] {
        width: 100%;
    }
}

#STEP_QUESTIONS .question-variants .question-variant {
    width: 95%;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    min-height: 40px;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    margin: 3px 5px;
    padding: 5px 20px;
    background-color: #f2f2f2;
    border-radius: 5px;
    font-size: 15px;
}

@media (min-width: 479px) {
    #STEP_QUESTIONS .question-variants .question-variant:hover {
        cursor: pointer;
        background-color: #1c4d90;
        color: #fff;
    }
}

#STEP_CARDS [class^='card_text_'] {
    display: none;
    font-size: 18px;
}

#STEP_CARDS .card_container {
    min-height: 250px;
}

#STEP_CARDS .card_container .card_deck {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    margin-bottom: 15px;
    margin-left: 25px;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
}

#STEP_CARDS .card_container .card_deck .card_deck_card {
    height: 204px;
    max-height: 204px;
    margin-left: -30px;
    -webkit-transition: all 300ms ease;
    transition: all 300ms ease;
    cursor: pointer;
}

#STEP_CARDS .card_container .card_deck .card_deck_card:nth-child(2n+1) {
    margin-top: 15px;
}

#STEP_CARDS .card_container .card_deck .card_deck_card img {
    max-width: 100%;
    vertical-align: middle;
    display: inline-block;
    width: 100%;
    height: 100%;
}

#STEP_CARDS .card_container .card_deck .card_deck_card:hover {
    margin-top: -10px;
}

#STEP_CARDS .card_container .card_deck .card_deck_card.selected {

}

@media (max-width: 479px) {
    #STEP_CARDS .card_container {
        min-height: 0;
    }

    #STEP_CARDS .card_container .card_deck {
        margin-right: auto;
        margin-left: auto;
        padding-left: 25px;
        float: none;
        -webkit-box-pack: center;
        -webkit-justify-content: center;
        -ms-flex-pack: center;
        justify-content: center;
        -webkit-box-align: stretch;
        -webkit-align-items: stretch;
        -ms-flex-align: stretch;
        align-items: stretch;
        text-align: center;
    }

    #STEP_CARDS .card_container .card_deck .card_deck_card {
        display: block;
        -webkit-box-flex: 0;
        -webkit-flex: 0 auto;
        -ms-flex: 0 auto;
        flex: 0 auto;
        width: 90px;
        height: auto;
        margin-bottom: 15px;
        margin-left: -30px;
    }
    #STEP_CARDS .card_container .card_deck .card_deck_card:nth-child(2n+1),
    #STEP_CARDS .card_container .card_deck .card_deck_card:hover {
        margin-top: 0;
    }
}


#STEP_CARDS .card_hint {
    text-align: center;
    font-size: 14px;
}






.card_content_section {
    position: relative;
}

.card_deck_card {
    z-index: 10;
    perspective: 1000px;
}

.card_deck_card.animate {
    /*position: absolute;*/
    /*transform: translate(-50%);*/
}

.card_deck_card.animate .flipper {
    transform: rotateY(180deg);
}

.card_deck_card.animate,
.card_deck_card.animate img {
    width: auto;
}

.flipper {
    transition: 0.8s;
    transform-style: preserve-3d;

    position: relative;
}

.front {
    opacity: 0;
}

.back {
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.back {
    z-index: 2;
    transform: rotateY(0deg);
}

.front {
    transform: rotateY(180deg);
}

.grow_card {
    background-color: #d3d3d3;
    width: auto;
    height: auto;
    position: fixed;
    top:0;
    left:0;
    margin:0;
    transition: transform 1s linear;
    z-index: 500;
    padding: 5px 0;
}
.grow_card.animate {
    transform: translate(-50%, -50%) scale(2);
}

.grow_card .card_title {
    font-size: 12px;
    white-space: pre-wrap;
    text-align: center;
}

.navigation_container {
    width: 100%;
    padding: 30px 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.navigation_container .button {
    min-width: 120px;
    border-radius: 5px;
    -webkit-box-shadow: 0 0 10px 2px rgba(0,0,0,.35);
    box-shadow: 0 0 10px 2px rgba(0,0,0,.35);
    color: #fff;
    font-size: 18px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 10px;
    background-color: #00b700;
}

.navigation_container .button:hover {
    cursor: pointer;
}

.navigation_container .button.disabled {
    background-color: #d6d6d6;
}

.comments {
    width: 618px;
    margin: 0 auto 20px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

@media (max-width: 768px) {
    .comments {
        width: 100%;
    }
}

.comments_title {
    margin: 0 auto 15px;
    text-align: center;
}

.fb_comments {
    width: 100%;
    max-width: 533px;
    max-height: 725px;
}

.comments_sophia {
    margin: 0 auto;
    border: 2px solid #ccc;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 618px;
    height: 282px;
    font-family: Open Sans,sans-serif;
    font-weight: 400;
    font-style: normal
}

.comments_sophia .sophia_about {
    width: 35%;
    padding-left: 15px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.comments_sophia .sophia_agenda {
    width: 65%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.sophia_about_photo {
    width: 107px;
    height: 134px;
    margin-top: 12px;
    background: url('../assets/images/sophiasmall.png') 50% no-repeat;
    background-size: contain;
}

.sophia_about_name {
    width: 125px;
    height: 25px;
    margin-top: 9px;
    background: url('../assets/images/sophia_loren.png') 50% no-repeat;
    background-size: contain;
}

.sophia_about_skill {
    font-size: 14px;
    text-align: center;
}

.sophia_about_stars {
    width: 102px;
    height: 32px;
    margin-top: 5px;
    background: url('../assets/images/stars.png') 50% no-repeat;
    background-size: contain;
}

.sophia_agenda_title {
    font-size: 19px;
    color: #000;
    margin-top: 12px;
}

.sophia_agenda_points {
    margin: 25px 0 25px -50px;
}

.sophia_agenda_point {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    font-size: 14px;
    line-height: 25px;
    height: 26px;
    color: #000;
}

.sophia_agenda_point:before {
    display: inline-block;
    content: "";
    width: 25px;
    height: 25px;
    background: url('../assets/images/triangle_bullet.png') 50% no-repeat;
    background-size: contain;
}

.sophia_agenda_tip {
    color: #8d0707;
    background-color: #fff73a;
    font-style: italic;
    font-size: 14px;
}

@media (max-width: 768px) {
    .comments_sophia {
        width: 100%;
        height: auto;
        -webkit-box-orient: vertical;
        -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
        flex-direction: column-reverse;
    }

    .comments_sophia .sophia_about,
    .comments_sophia .sophia_agenda {
        width: 100%;
    }

    .sophia_agenda_title {
        text-align: center;
        padding: 0 40px;
    }

    .sophia_agenda_points {
        margin-left: -10px;
    }
}

.wrong-email,
.exists-email {
    display: none;
}

.email_policyMessage {
    color: #6b6b6b;
    font-size: 13px;
}

.email_policyMessage p {
    width: 420px;
}

@media (max-width: 460px) {
    .email_policyMessage p {
        width: 100%;
    }
}

.email_policyMessage p a {
    color: #6b6b6b;
}

.email_policyMessage .email_lock {
    padding-left: 20px;
    background: url('../assets/images/lock.png') no-repeat;
}

.comments_rapid-ssl {
    height: 139px;
    background: url('../assets/images/rapidssl_cert.png') 50% no-repeat;
    background-size: contain;
}

.w-form-done,
.w-form-fail {
    display: none;
}
