h1 {

    font-family: "BigShouldersDisplay-Bold", sans-serif;

    font-size: 5rem;

}

.hero-section {

    position: relative;

    overflow-y: hidden;

}

.hero-section:before {

    content: "";

    width: 100%;

    height: 100%;

    display: block;

    position: absolute;

    top: 0;

    left: 0;    

}

.hero-section * {

    color: #FFFFFF;

}

.hero-section .container-fluid {

    position: absolute;

}

.hero-section img {

    object-fit: cover;

    width: 100%;

}

.main-section {

    margin-top: 40px;

}

h3 {

    color: #CC0000;

    font-family: "BigShouldersDisplay-Bold", sans-serif;

    text-transform: uppercase;

    font-size: 3.125rem;

    max-width: 576px;

}

div#parallax-el {

    transition: all 0.2s ease;

}

.service-container {

    position: relative;

    margin-bottom: 48px;

    overflow: hidden;

}

.service-container img {

    transition: all 0.2s ease;

    min-width: 100%;

}

.service-container:hover img {

    transform: scale(1.1);

}

.service-container:before {

    content: "";

    background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.5) 100%);

    width: 100%;

    height: 100%;

    position: absolute;

    top: 0;

    left: 0;

    z-index: 9;

}

.service-heading {

    position: absolute;

    left: 0;

    right: 0;

    text-align: center;

    color: #FFFFFF;

    font-family: "BigShouldersDisplay-Bold", sans-serif;

    text-transform: uppercase;

    font-size: 24px;

    height: 100%;

    width: 100%;

    display: flex;

    top: 0;

    justify-content: center;

    align-items: flex-end;

    padding-bottom: 15px;

    z-index: 9;

}

.service-heading:hover, .service-heading:focus {

    color: #FFFFFF;

}

#recall-modal {

    overflow-y: hidden !important;

}

#recall-modal .modal-content {

    background-color: #000000;

    border-top: 3.95px solid #CC0000;    

}

#recall-modal .modal-content *:not(.close-container) {

    color: #FFFFFF;

    text-align: center;

}

#recall-modal .modal-heading {

    font-family: "Rubik-Light", sans-serif;

    font-size: 2rem;

    text-transform: uppercase;

}

#recall-modal .modal-description {

    font-size: 1rem;

}

#recall-modal .modal-content .cta {

    font-size: 1.2rem;

    color: #000000;

    background-color: #FFFFFF;

    padding: 5px 28px;

    text-transform: uppercase;

    border-radius: 6px;
    margin-top: 20px;
    margin-bottom: 20px;

}

#recall-modal .modal-description, #recall-modal .cta {

    font-family: "Rubik-Regular", sans-serif;

}

.close-container {

    text-align: right;

}

#recall-modal .close {

    float: none;

}

#recall-modal .cta:hover, #recall-modal .cta:focus {

    opacity: 0.9;

}

.related {

    margin-top: 64px;

}

.recall-detail span {

    font-family: "Rubik-Bold", sans-serif;

    color: #CC0000;

    font-size: 18px;

}

.recall-detail {

    font-family: "Rubik-Regular", sans-serif;

    color: #000000;

    font-size: 18px;    

}

.recall-detail:not(.warning) {

    margin-bottom: 45px;

}

.red-section, .red-section *, .red-section a:hover, .red-section a:focus {

    color: #CC0000;

    font-family: "Rubik-Regular", sans-serif;

    font-size: 18px;

}

form {

    max-width: 948px;

    margin: 0 auto 32px auto;

    background: #CC0000;

    border-radius: 15px;

    text-align: center;

}

.form-heading {

    font-family: "BigShouldersDisplay-Bold", sans-serif;

    color: #FFFFFF;

    font-size: 36px;

    text-transform: uppercase;

    margin: 0;

}

.form-subheading {

    font-family: "Rubik-Regular", sans-serif;

    color: #FFFFFF;

    font-size: 18px;

    margin-bottom: 24px;

}

form input.form-control, form select.form-control option {

    text-transform: uppercase;

    border-radius: 5px;

    font-family: "Rubik-Regular", sans-serif;

}

.submit-btn {

    background-color: #FFFFFF;

    text-transform: uppercase;

    color: #E60020;

    font-family: "Rubik-Regular", sans-serif;

    font-size: 24px;

    border-radius: 4px;

}

.submit-btn:hover {

    background-color: #000000;

    color: #FFFFFF;

}

.submit-btn:hover .default, .submit-btn:not(:hover) .hover {

    display: none;

}

form > div {

    max-width: 676px;

    margin: 0 auto;

    padding: 24px 16px;

}

.explanation {

    font-family: "Rubik-Light", sans-serif;

    font-size: 18px;

    color: #FFFFFF;

}

#form-modal .modal-content {

    background-color: #CC0000;

    border-radius: 10px;

}

#form-modal .modal-content p {

    text-transform: uppercase;

    font-family: "BigShouldersDisplay-SemiBold";

    color: #FFFFFF;

    font-size: 40px;

    text-align: center;

}

#form-modal .close-container {

    text-align: right;

    position: absolute;

    right: 0;

    top: 0;

}

.d-flex > div:first-child {

    width: 100%;

    position: relative;

}

.d-flex > div:first-child .form-group {

    position: relative;

}

.d-flex > div:first-child .form-group:last-child input {

    width: calc(100% - 38px);

    border-top-right-radius: 0;

    border-bottom-right-radius: 0;

}

.d-flex .img-container {

    position: absolute;

    right: 0;

    top: 0;

    background: #000000;

    height: 100%;

    border-top-right-radius: 5px;

    border-bottom-right-radius: 5px;

    display: flex;

    align-items: center;

    padding: 0 4px;

    cursor: pointer;

}

#validation-modal .modal-heading {

    text-transform: uppercase;

    font-family: "BigShouldersDisplay-Bold", sans-serif;

    color: #CC0000;

    font-size: 80px;

    text-align: center;

    margin-bottom: 0;

}

#validation-modal .modal-description {

    font-family: "Rubik-Regular", sans-serif;

    font-size: 24px;

    color: #CC0000;

    text-align: center;

}

#validation-modal .close-container {

    max-width: 24px;

    margin-right: 0;

    margin-left: auto;

}

.close-container img {

    max-width: 70%;
}
#search-result-modal .icon-container {
    margin-bottom: 10px;
}
#search-result-modal, #search-result-modal .icon-container {
    text-align: center;
}
#search-result-modal .modal-body {
    border: 4px solid;
    border-color: #CC0001;
    box-shadow: 0 0 0;
    border-top-left-radius: 6px;
    border-bottom-right-radius: 6px;
}
#search-result-modal .modal-heading, #search-result-modal .modal-title, #search-result-modal .extra-info {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 100%;
}
#search-result-modal .letter-container {
    position: relative;
    display: flex;
    align-items: center;
    background-color: #E7E4E5;
    padding: 8px;
    border-radius: 4px;
    text-align: left;
    margin-bottom: 1rem;
}
#search-result-modal .letter-container:after {
    content:"";
    display: block;
    height: 24px;
    width: 24px;
    background-image: url("../../img/recall/download-icon.png");
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    position: absolute;
    right: 8px;
    flex-shrink: 0;
}
#search-result-modal .letter-container a {
    display: inline-block;
    width: 88%;
    z-index: 99;
    color: #3D3D3D;
    font-family: "Rubik-Regular", sans-serif;
    word-wrap: break-word;
}
#search-result-modal .letter-container a:focus, #search-result-modal .letter-container a:hover {
    color: #3D3D3D;
}
#search-result-modal * {
    color: #3D3D3D !important;
}
.top-corner {
    border-radius: 6px;
    position: absolute;
    width: 40px;
    height: 40px;
    background-color: #fff;
    top: 0%;
    right: 0%;
    z-index: 999;
}
.bottom-corner {
    border-radius: 6px;
    position: absolute;
    width: 40px;
    height: 40px;
    background-color: #fff;
    bottom: 0%;
    left: 0%;
    z-index: 999;
}
#search-result-modal .modal-content {
    padding: 15px;
}
#search-result-modal .modal-heading {
    text-transform: uppercase;
    font-family: "Rubik-Bold", sans-serif;
    font-size: 32px;
}
#search-result-modal .modal-title {
    font-size: 24px;
}
#search-result-modal .modal-title, #search-result-modal .modal-description span.vin, #search-result-modal .extra-info p span  {
    font-family: "Rubik-Regular", sans-serif;
}
#search-result-modal .modal-description span:not(.vin), #search-result-modal .extra-info p {
    font-family: "Rubik-Light", sans-serif;
}
@media only screen and (min-width: 576px) {

    .modal-dialog {

        max-width: 760px;

    }

}

@media only screen and (min-width: 1024px) {

    .hero-section:before {

        background: linear-gradient(0deg, rgba(0, 0, 0, 0.25), rgba(0, 0, 0, 0.25)), linear-gradient(90deg, rgba(0, 0, 0, 0) 38.5%, rgba(0, 0, 0, 0.21) 49.55%, rgba(0, 0, 0, 0.6) 80%);

    }

    .hero-section img {

        max-height: 742px;

        object-fit: cover;

        width: 100%;

    }

    

    .col-md-4:not(:last-of-type) {

        padding-right: 0;

    }

}

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

    #validation-modal .modal-heading  {

        font-size: 36px;

    }

    #form-modal .close-container {

        width: 24px;

    }

    #form-modal .modal-content p {

        font-size: 32px;

    }

    .form-heading {

        font-size: 24px;

    }

    .form-subheading, form input.form-control, form .submit-btn, .recall-detail span, #validation-modal .modal-description, form select.form-control option {

        font-size: 16px;

    }

    .recall-detail, .red-section, .red-section * {

        font-size: 13px;

    }

    .hero-section #parallax-el:before {

        background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.6) 100%);

        content: "";

        width: 100%;

        height: 100%;

        display: block;

        position: absolute;

        top: 0;

        left: 0;

        z-index: 1;

    }

    .hero-text-container {

        z-index: 2;

    } 

    .hero-section h1 {

        font-size: 45px;

        line-height: 53.93px;

    }

    #recall-modal .modal-heading {

        font-size: 24px;

    }

    #recall-modal .modal-description {

        font-size: 16px;

    }

    #recall-modal .modal-content .cta {

        font-size: 22px;

    }

    .hero-section img {

        min-height: 681px;

    }

    .hero-section .container-fluid {

        text-align: center;

        bottom: 15px;

        left: 0;

        right: 0;

        margin: 0 auto;

    }

    .container-fluid {

       margin-top: 24px; 

    }

    

    .service-container {

        max-height: 261px;

    }

    .service-container {

        margin-bottom: 20px;

    }

    h3 {

        font-size: 24px;

    }

    .related {

        margin-top: 40px;

    }

    .related h3 {

        text-align: center;

    }

} 