/*#region abstracts */
.abstract .abstract-image {
    height: 96.8px;
    width: 96.8px;
    border: 3px solid #FFFFFF; /* --neutrals-white */
    border-radius: 50%;
    background-size: cover;
    background-position-x: 50%;
    background-position-y: 50%;
}
/*#endregion*/

/*#region Hero section */
#hero-container {
    margin-bottom: 24px;
}
.ab-mobile #hero-container {
    background-color: #233F62; /* --primary-blue */
}

    .ab-mobile #hero-container .slide {
        background-image: none !important;
    }


.ab-desktop #hero-container .slide {
    background-position: 60%;
    min-height: 700px;
}

.ab-desktop.ab-tablet #hero-container .slide {
    background-position: 70%;
}

.ab-mobile #hero-container .slide .slide-caption {
    padding: 1rem;
}

.ab-desktop #hero-container .slide .slide-caption {
    transform: translateY(200px) translateX(185px);
    width: 450px;
}

.ab-desktop.ab-tablet #hero-container .slide .slide-caption {
    transform: translateY(2rem) translateX(3rem);
    width: 450px;
}

.ab-mobile #hero-container .slide .slide-description,
.ab-mobile #hero-container .slide .slide-action-bar {
    display: none;
}

.ab-desktop #hero-container .slide .slide-description {
    font-size: 2rem;
    line-height: 2.5rem;
}

.ab-mobile #hero-container .slide-text-white,
.ab-mobile #hero-container .slide-text-charcoal {
    color: #FFFFFF; /* --neutrals-white */
}

.ab-desktop #hero-container .slide-text-white {
    color: #FFFFFF; /* --neutrals-white */
}

.ab-desktop #hero-container .slide-text-charcoal {
    color: #231F20; /* --neutrals-charcoal */
}
/*#endregion */




/*#region index */
.ab-desktop .short-control {
    width: 150px;
}

.ab-desktop .medium-control {
    margin-right: 125px;
}

.ab-desktop .long-control {
    margin-right: 125px;
}

/*#endregion*/

/*#region rate selection */
.collapse-container .col .collapse-toggle {
    margin-bottom: 0;
}
/*#endregion*/


/*#region identity, soleproprietor */

#socialsecuritynumber-form-group .optional,
#governmentid-form-group .optional,
#governmentidstate-form-group .optional,
#hasexperianpin-form-group .optional {
    display: none;
}
#experianpin-form-group .row > [class*="col-"]:last-child {
    padding-left: 15px;
    padding-right: 15px;
}
/*#endregion*/

/*#region programs*/
.greenergy-leaf {
    font-size: 2.25rem;
    color: #74A433; /** --secondary-green */
}
/*#endregion*/

/*#region review */
#loading-container {
    text-align: center;
}
p.fade-in {
    margin-top: 15px;
}
.suitcase-container {
    width: 80px;
    height: 50px;
    text-align: center;
    padding-top: 5px;
    display: inline-block;
}
.suitcase {
    -moz-animation: 3s ease 0s normal none infinite swing;
    -moz-transform-origin: center top;
    -webkit-animation: swing 3s infinite ease-in-out;
    -webkit-transform-origin: top;
    animation: swing 3s infinite ease-in-out;
    transform-origin: top;
    color: #f15c22;
}

@-moz-keyframes swing{
    0%{-moz-transform:rotate(30deg);}
    25%{-moz-transform:rotate(-30deg);}
    50%{-moz-transform:rotate(30deg);}
    75%{-moz-transform:rotate(-30deg);}
    100%{-moz-transform:rotate(30deg);}
}
@-webkit-keyframes swing{
    0%{-webkit-transform:rotate(30deg);}
    25%{-webkit-transform:rotate(-30deg);}
    50%{-webkit-transform:rotate(30deg);}
    75%{-webkit-transform:rotate(-30deg);}
    100%{-webkit-transform:rotate(30deg);}
}
@keyframes swing {
    0%{transform:rotate(30deg);}
    25%{transform:rotate(-30deg);}
    50%{transform:rotate(30deg);}
    75%{transform:rotate(-30deg);}
    100%{transform:rotate(30deg);}
}
.fade-in {
    -moz-animation:fade-in 10s;
    -moz-animation-iteration-count: 1;
    -webkit-animation:fade-in 10s;
    -webkit-animation-iteration-count: 1;
    animation:fade-in 10s;
    animation-iteration-count: 1;
    opacity: 1;
}
@-moz-keyframes fade-in {
    0% { opacity: 0; }
    60% { opacity: 0; }
    70% { opacity: 1; }
}
@-webkit-keyframes fade-in {
    0% { opacity: 0; }
    60% { opacity: 0; }
    70% { opacity: 1; }
}
@keyframes fade-in {
    0% { opacity: 0; }
    60% { opacity: 0; }
    70% { opacity: 1; }
}
.ellipsis {
    display: inline-block;
    text-align: left;
    width: 20px;
}
.ellipsis:after {
    overflow: hidden;
    display: inline-block;
    vertical-align: bottom;
    -moz-animation: ellipsis steps(4,end) 1500ms infinite;
    -webkit-animation: ellipsis steps(4,end) 1500ms infinite;
    animation: ellipsis steps(4,end) 1500ms infinite;
    content: "\2026"; /* ascii code for the ellipsis character */
    width: 0px;
}

@-moz-keyframes ellipsis {
    to {
        width: 1.25em;    
    }
}

@-webkit-keyframes ellipsis {
    to {
        width: 1.25em;    
    }
}

@keyframes ellipsis {
    to {
        width: 1.25em;    
    }
}
/*#endregion*/

/*#region confirmation */
.alert-content > h2 {
    margin-top: 0;
}

.alert-success hr {
    border-top-color: #ccc;
}
article ol {
    padding-left: 15px;
}
article ol li {
    margin-bottom: 15px;
}

.icon-list p {
    margin-bottom: 20px;
}

.icon-list .fa {
    margin-right: 8px;
    font-size: 21px;
    width: 25px;
    text-align: center;
    vertical-align: middle;
    color: #a6978a;
}
.icon-list .fa.fa-lightbulb-o,
.icon-list .fa.fa-home {
    font-size: 28px;
}
.icon-list .fa-stack {
    vertical-align: middle;
    margin-top: -6px;
}
.icon-list .fa-stack .fa-mobile {
    font-size: 36px;
    margin-top: -4px;
}
.icon-list .fa-stack .fa-info {
    font-size: 14px;
    margin-top: 1px;
}

.print-link {
    display: none;
}
@media print {
    h1 {
        margin-top: 0;
    }
    .bottom-shadow {
        border-bottom: 0;
        box-shadow: none;
    }
    .print-link {
        display: block;
    }
    #utility-nav,
    .step-progress-bar,
    .btn.btn-primary,
    .card.padded hr,
    footer {
        display: none;
    }
    article.container.card,
    .card.padded,
    .gutter {
        padding: 0 !important;
    }
    .card {
        border: 0;
    }
    html, body {
        height: auto;
        padding: 0;
        margin: 0;
    }
    .for-print .col-md-6 {
        float: left;
        width: 50%;
    }
}
/*#endregion*/
