/********** Utilities **********/
.block {
    display: block;
}

.margin-t {
    margin-top: 1rem;
}

.margin-b {
    margin-bottom: 1rem;
}

.clearfix {
    overflow: auto;
}

.clearfix::after {
    content: "";
    clear: both;
    display: table;
}

h1 {
    font-family: 'Cinzel', serif;
    font-size: 40px;
    text-align: center;
    padding: 0;
    font-weight: normal;
    width: auto;
    margin: 0 auto 20px auto;
    padding-bottom: 5px;
}

h3 {
    display: block;
}

.pad-sm {
    padding: 2rem;
}

.pad-l-sm {
    padding-left: 2rem;
}

.pad-r-sm {
    padding-right: 2rem;
}

/********** Fonts/Typography **********/

span.page-title {
    width: 100%;
    margin: 0 auto;
    display: block;
    text-align: center;
}

span.page-title h1,
span.page-title h2,
span.page-title h3 {
    border-top: 2px solid black;
    border-bottom: 2px solid black;
    padding: .3em;
    display: inline-block;
    left: 0;
    transform: none;
    margin-bottom: 2rem;
}

span.page-subtitle {
    width: 100%;
    margin: 0 auto;
    display: block;
    text-align: center;
}

span.page-subtitle h1,
span.page-subtitle h2,
span.page-subtitle h3 {
    border-top: none;
    border-bottom: 2px solid black;
    padding: .3em;
    display: inline-block;
    left: 0;
    transform: none;
    margin-bottom: 2rem;
}

span.page-title h1 { font-size: 40px; }

a {
    color: #BD202D;
    font-weight: 600;
}

a:hover {
    color: #ef2839;
}

/********** Main Options Page **********/
div.options__container {
    width: calc(33% - 2rem);
    margin: 1rem;
    display: inline-block;
    float: left;
    min-height: 400px;
}
div.options__container img { max-width: 100%; height: auto;}
div.options__container div {
    display: flex;
    flex-direction: column;
    height: 250px;
}
div.options__container div h2 { font-weight: 400; text-align: center;}
div.options__container div p {
    flex: 1;
    text-align: center;
}

div.options__container div a { align-self: center; }

/********** Options Pages **********/

div.option__description {
    width: 75%;
    margin: 0 auto;
    text-align: center;
}

div.option.option__feature,
div.option{
    display: flex;
    flex-direction: row;
    align-items: center;
    margin: 5em auto;
}

div.option.option__feature--rtl {
    flex-direction: row-reverse;
}

h3.option__feature-title {
    margin-bottom: 0px;
}

div.option__feature-image,
div.option__feature-text,
div.option__feature-container{
    flex-grow: 1;
    flex-basis: 50%;
}

div.option__feature-container ul {
    padding: 0;
    list-style: none;
}

div.option__feature-container h3 {
    margin-bottom: 0px;
}

div.option__feature-text {
    padding: 1em;
    order: 1;
}

div.option__feature-image {
    order: 0;
}

div.option__feature-image img{
    width: 100%;
    height: auto;
}

div.option__price {
    text-align: center;
}

div.option__actions {
    text-align: center;
}

div.option__price h2{
    border-bottom: none;
    left: 0;
    transform: none;
    font-size: 40px;
    color: black;
}

div#innerContentBox {
    padding: 2rem 20px;
}

div#insulation-reduces {
    border-right: 2px solid #bd202d;
}

span.option__feature-price {
    font-family: Cinzel, serif;
    text-align: center;
    display: block;
    font-size: 110%;
    color: black;
}

a.button{
    font-family: 'Helvetica Neue', sans-serif;
    padding: 15px 25px;
    background-color: #cccccc;
    color: #222;
    text-decoration: none;
    border-radius: 5px;
    font-weight: 600;
    position: relative;
    text-align: center;
    /* text-transform: uppercase; */
    letter-spacing: 1px;
    -webkit-transition: all 400ms;
    transition: all 400ms;
    /* float: right; */
    display: inline-block;
    max-width: 350px;
    vertical-align: middle;
    border:0;
}

a.button.light{
    background-color: #f3bf27;
    color: #222;
}

a.button.light:hover{
    background-color: #ffdc18;
    color: #111;
}

/********** Decorative Elements Page **********/

.decorative-element {
    display: flex;
    flex-direction: column;
    justify-content: center;
    float: left;
    min-height: 280px;
    margin-bottom: 8rem;
}

.decorative-element .decorative-element__image-wrapper {
    height: 200px;
    width: 100%;
    display: flex;
    align-items: center;
}

.decorative-element.col-3 {
    width: 21%;
    max-width: 21%;
    margin:4rem 2%;
}

.decorative-element.col-4 {
    width: 29%;
    max-width: 29%;
    margin: 4rem 2%;
}

/********** Contact Page **********/
.location-hours__wrapper {
    display: flex;
    flex-direction: row;
    width: 100%;
}

.location-hours__wrapper .location__wrapper,
.location-hours__wrapper .hours__wrapper {
    width: 50%;
    padding: 1rem;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

.location-hours__wrapper .location__wrapper {
    order: 0;
}

.location-hours__wrapper .hours__wrapper {
    order: 1;
    text-align: center;
}

.location-hours__wrapper .hours__wrapper .hours .hours-listing {
    display: block;
    line-height: 2;
}

div.alert {
    display: block;
    width: 80%;
    min-width: 400px;
    margin: 1rem auto;
    box-sizing: border-box;
    padding: 1em;
    font-weight: 600;
    background: #fff;
    border: 2px solid #000;
    border-radius: 10px;
}

div.alert p {
    margin: 0;
}

div.alert.alert-warning {
    border-color: #ef2839;
    background: #ffaaaa;
    color: #bd202d;
}


@media screen and (max-width: 799px) {
    div.options__container {
        width: calc(50% - 2rem);
        margin: 1rem;
    }

    div.options-divider {
        display: none;
    }

    div.alert {
        min-width: unset;
        width: 100%;
    }
}

@media screen and (max-width: 650px) {
    div.option.option__feature--ltr,
    div.option.option__feature--rtl{
        display: flex;
        flex-direction: column;
        align-items: center;
    }

    .sm-no-pad {
        padding: 0;
    }

    div#insulation-reduces {
        border-right: none;
    }

    .decorative-element.col-3 {
        width: 100%;
        max-width: 100%;
        margin: 0;
    }

    .decorative-element.col-4 {
        width: 100%;
        max-width: 100%;
        margin: 0;
    }

    .location-hours__wrapper {
        flex-direction: column;
        width: 100%;
    }

    .location-hours__wrapper .location__wrapper,
    .location-hours__wrapper .hours__wrapper {
        width: 100%;
    }

    .location-hours__wrapper .location__wrapper {
        order: 1;
    }

    .location-hours__wrapper .hours__wrapper {
        order: 0;
    }
}

@media screen and (max-width: 500px) {
    div.options__container {
        width: 100%;
        margin: 2rem 1rem;
        min-height: auto;
    }

    div.options__container div {
        height: auto;
    }
}

