/*
Theme Name: Ryno Theme Three
Theme URI: http://rynoss.com
Author: RYNO Strategic Solutions
Author URI: http://rynoss.com
Description: The third theme.
Version: 2.0.0
Text Domain: ryno_theme_three
*/

.alignnone {
    margin: 5px 20px 20px 0;
}

.aligncenter,
div.aligncenter {
    display: block;
    margin: 5px auto 5px auto;
}

.alignright {
    float: right;
    margin: 5px 0 20px 20px;
}

.alignleft {
    float: left;
    margin: 5px 20px 20px 0;
}

a img.alignright {
    float: right;
    margin: 5px 0 20px 20px;
}

a img.alignnone {
    margin: 5px 20px 20px 0;
}

a img.alignleft {
    float: left;
    margin: 5px 20px 20px 0;
}

a img.aligncenter {
    display: block;
    margin-left: auto;
    margin-right: auto
}

.wp-caption {
    background: #fff;
    border: 1px solid #f0f0f0;
    max-width: 96%;
    /* Image does not overflow the content area */
    padding: 5px 3px 10px;
    text-align: center;
}

.wp-caption.alignnone {
    margin: 5px 20px 20px 0;
}

.wp-caption.alignleft {
    margin: 5px 20px 20px 0;
}

.wp-caption.alignright {
    margin: 5px 0 20px 20px;
}

.wp-caption img {
    border: 0 none;
    height: auto;
    margin: 0;
    max-width: 98.5%;
    padding: 0;
    width: auto;
}

.wp-caption p.wp-caption-text {
    font-size: 11px;
    line-height: 17px;
    margin: 0;
    padding: 0 4px 5px;
}

/* Text meant only for screen readers. */

.screen-reader-text {
    clip: rect(1px, 1px, 1px, 1px);
    position: absolute !important;
    height: 1px;
    width: 1px;
    overflow: hidden;
}

.screen-reader-text:focus {
    background-color: #f1f1f1;
    border-radius: 3px;
    box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
    clip: auto !important;
    color: #21759b;
    display: block;
    font-size: 14px;
    font-size: 0.875rem;
    font-weight: bold;
    height: auto;
    left: 5px;
    line-height: normal;
    padding: 15px 23px 14px;
    text-decoration: none;
    top: 5px;
    width: auto;
    z-index: 100000;
    /* Above WP toolbar. */
}

/* Products */

.product-table tr>td:first-child {
    width: 25%;
}


/*Contact Page Form*/

.main-contact-form .cf-text,
.main-contact-form .cf-textarea {
    background-color: #eaeaea;
    border: 0.0625rem solid #b8b8b8;
    border-radius: 0.25rem;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1) inset;
    box-sizing: border-box;
    color: rgba(0, 0, 0, 0.75);
    display: block;
    margin: 0 0 1rem;
    padding: 0.5rem;
    transition: all 0.3s ease;
    width: 100%;
}

.main-contact-form .cf-textarea {
    height: 4.6875rem;
}

.main-contact-form div>label,
.main-contact-form legend {
    font-size: 14px;
    font-size: 0.875rem;
    font-weight: bold;
    text-transform: uppercase;
}

.main-contact-form fieldset br {
    display: none;
}

.main-contact-form fieldset p {
    margin: 0;
}

.main-contact-form .wpcf7-list-item {
    clear: both;
    display: block;
}

.main-contact-form .wpcf7-list-item input[type="checkbox"] {
    margin-bottom: 0;
}

.main-contact-form .wpcf7-list-item-label {
    font-weight: bold;
}

.main-contact-form input[type="submit"] {
    background: none;
    border: 2px solid;
    cursor: pointer;
    display: block;
    font-size: 20px;
    font-size: 1.25rem;
    font-weight: bold;
    margin-top: 0.625rem;
    padding: 10px 0px;
    padding: 0.62522rem 0rem;
    text-align: center;
    text-transform: uppercase;
    transition: all 0.3s ease;
    width: 100%;
}

.main-contact-form input[type="submit"]:hover {
    color: #fff;
}


/* General Styles */

body {
    font-size: 14px;
    font-family: "Lato", sans-serif !important;
}

.content-area p,
.content-area div,
.content-area ul {
    font-size: 1.1rem;
    line-height: 1.595rem;
}

.clear {
    clear: both;
}

/* Sink */

.hvr-sink {
    position: relative;
    margin-top: 0;
    transition: all 0.3s ease;
}

.hvr-sink:hover,
.hvr-sink:focus,
.hvr-sink:active {
    margin-top: 8px !important;
    transition: all 0.3s ease;
}

ul,
ol,
dl {
    font-size: .8rem;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: "Montserrat", sans-serif;
    font-weight: bold;
    margin-top: 0;
    text-transform: uppercase;
}

h1 {
    font-size: 20px;
    font-weight: bold;
    letter-spacing: 0.125rem;
    line-height: 1;
    margin: 0 auto;
    padding: 0 10px 10px;
    text-align: center;
}

h1.home-title {
    border: 0 none;
    color: #000;
    font-size: 1.55rem;
    letter-spacing: 0;
    line-height: 1.95rem;
    margin: 0;
    padding: 0 0 20px 0;
    text-align: left;
    width: auto;
}

h1.page-title {
    margin-bottom: 1.563rem;
}

h2 {
    font-size: 1.675rem;
    margin-bottom: 10px;
}

h3 {
    font-size: 18px;
    font-weight: normal;
}

h4 {
    font-size: 18px;
    font-weight: bold;
    line-height: 1.25em;
}

h5 {
    font-size: 16px;
    font-weight: bold;
    line-height: 1.25em;
}

h6 {
    font-size: 14px;
    font-weight: bold;
    line-height: 1.25em;
}

p {
    font-size: 16px;
    line-height: 1.195rem;
}

a,
a:link,
a:visited,
a:active {
    font-weight: bold;
    text-decoration: none;
    transition: all 0.3s ease;
}

a.btn,
button,
.button {
    border-radius: 3px;
    display: block;
    font-family: "Montserrat", sans-serif;
    font-size: 12px;
    font-weight: bold;
    margin-bottom: 15px;
    padding: 10px 0;
    text-align: center;
    text-transform: uppercase;
    transition: all 0.3s ease;
    width: 100%;
}

form input.cf-text,
form .cf-textarea,
form select {
    border: 1px solid #ccc;
    box-shadow: none;
}

form select {
    background-color: #fff !important;
}

form textarea {
    resize: none;
}

/* Header */

.header-wrapper {
    position: relative;
    z-index: 3;
}

.header {
    padding: 22px 0;
    position: relative;
    z-index: 2;
}

.header-region {
    padding-bottom: 10px;
}

.header-social {
    -webkit-transform-style: preserve-3d;
    -moz-transform-style: preserve-3d;
    transform-style: preserve-3d;
}

.social-icons {
    list-style: none;
    margin: 0.9375rem 0rem;
    padding: 0;
}

.social-icons li {
    display: inline-block;
    margin: 0 0.1rem;
}

.social-icons a {
    border: 1px solid;
    border-radius: 50%;
    display: inline-block;
    height: 1.75rem;
    line-height: 1.75rem;
    text-decoration: none;
    text-align: center;
    width: 1.75rem;
}

.social-icons a:hover {
    box-shadow: 0 0 5px 0 #fff;
    color: #fff;
}

@media only screen and (min-width: 641px) {
    .header-region {
        display: flex;
        align-items: center;
    }
}

.header-phone {
    text-align: center;
    -webkit-transform-style: preserve-3d;
    -moz-transform-style: preserve-3d;
    transform-style: preserve-3d;
}

.header-phone,
.header-phone a {
    font-size: 17.5px;
    font-weight: normal;
    margin-bottom: 0;
    text-transform: none;
}


/*Weather*/

#wpc-weather .today {
    display: none;
}


/* Navigation */

.top-bar {
    background: none;
    height: 4rem;
    line-height: 4rem;
}

.top-bar.expanded {
    overflow: visible !important;
}

.top-bar.expanded .title-area {
    background: none;
}

.top-bar-section li.active:not(.has-form) a:not(.button),
.top-bar-section li:not(.has-form) a:not(.button) {
    background: none !important;
    line-height: 4rem;
}

.top-bar-section ul li,
.top-bar-section li:not(.has-form) a:not(.button) {
    background: none;
}

.top-bar-section ul li>a {
    font-family: "Montserrat", sans-serif;
    font-size: 14px;
    font-weight: normal !important;
}

.top-bar-section .has-dropdown>a::after {
    display: none;
}

.top-bar-section li:not(.has-form) a:not(.button),
.top-bar-section .has-dropdown>a {
    padding: 0 !important;
    text-align: center;
}

.top-bar-section ul li.has-dropdown .dropdown {
    display: block;
    opacity: 0;
    transition: all 0.3s ease;
    visibility: hidden;
}

.top-bar-section ul li.has-dropdown:hover>.dropdown {
    opacity: 1;
    text-decoration: none;
    transition: all 0.3s ease;
    visibility: visible;
}

.top-bar-section .dropdown li:not(.has-form):not(.active)>a:not(.button),
.top-bar-section .dropdown li.active:not(.has-form) a:not(.button),
.top-bar-section .dropdown li:not(.has-form) a:not(.button) {
    font-size: 0.875rem;
    height: 2.375rem;
    line-height: 2.375rem;
    padding: 0 10px !important;
    text-align: left;
}

.main-navigation li.active>a,
.main-navigation a:hover,
.top-bar-section ul li:hover:not(.has-form)>a {
    background: none !important;
    text-decoration: none;
}

/* SLIDER & PAGE HEADER */

#slider {
    -webkit-backface-visibility: hidden;
    -moz-backface-visibility: hidden;
    -webkit-transform: translate3d(0, 0, 0);
    -moz-transform: translate3d(0, 0, 0);
    height: auto;
    overflow: hidden;
    position: relative;
    width: 100%;
    z-index: 1;
}

#slider,
.page-header img {
    margin-bottom: 0;
    top: 0;
}

.page-header {
    padding: 60px 0;
}

.page-header h1 {
    border: 0 none;
    color: #fff;
    font-size: 45px;
    font-weight: 500;
    margin: 0;
    padding: 0;
    text-align: left !important;
    text-shadow: 2px 2px 2px rgba(0, 0, 0, 0.6);
}

.cycle-slideshow,
.slide {
    position: relative;
    width: 100% !important;
}

/* Arrows */

.cycle-prev,
.cycle-next {
    background: none;
    border: none;
    cursor: pointer;
    color: #fff;
    display: block;
    font-size: 1.875rem;
    height: 2.813rem;
    line-height: 0;
    opacity: 0;
    outline: none;
    padding: 0;
    position: absolute;
    top: 50%;
    transition: all 0.3s ease;
    width: 2.813rem;
    z-index: 101;
}

.cycle-slideshow:hover .cycle-prev,
.cycle-slideshow:hover .cycle-next {
    opacity: .75 !important;
    transition: all 0.3s ease;
}

.cycle-prev {
    left: 20px;
}

.cycle-next {
    right: 20px;
}

.cycle-pager {
    overflow: hidden;
    position: absolute;
    text-align: center;
    bottom: 10px;
    width: 100%;
    z-index: 500;
}

.cycle-pager span {
    color: rgba(255, 255, 255, 0.8);
    cursor: pointer;
    display: inline-block;
    font-size: 32px;
    height: 16px;
    width: 16px;
}

.cycle-pager span.cycle-pager-active {
    color: rgba(255, 255, 255, 1);
}

.cycle-pager-active {
    color: rgba(255, 255, 255, 1);
    line-height: 1em;
}

.slide img {
    height: auto;
    width: 100%;
}

.slider-shadow {
    text-align: center;
}

/* CTA Bar */

.cta-bar {
    margin-bottom: 60px;
    padding: 39px;
    -webkit-transform-style: preserve-3d;
    -moz-transform-style: preserve-3d;
    transform-style: preserve-3d;
}

@media only screen and (min-width: 641px) {
    .cta-bar .row {
        display: flex;
        align-items: center;
    }
}

.cta-bar h2,
.cta-bar .button {
    margin-bottom: 0;
    width: auto;
}

.cta-bar h2 {
    font-size: 1.539375rem;
    letter-spacing: 0.1em;
}

.cta-bar .button {
    font-family: "Montserrat", sans-serif;
    font-size: 12px;
    padding: 10px;
    text-transform: uppercase;
    margin-top: 2px;
}

.home-prefix-box {
    margin-top: 20px;
    position: relative;
}

.home-prefix-box a {
    display: block;
    font-family: "Montserrat", sans-serif;
    font-size: 16px;
    font-weight: normal;
    margin: -70px 0 0 0;
    padding: 23px 0;
    position: relative;
    text-transform: uppercase;
    transition: all 0.3s ease;
}

/*Home Prefix Boxes*/

.home-prefix-box {
    overflow: hidden;
    height: 284px;
}

.home-prefix-box a:hover,
.home-prefix-box:hover a {
    margin: -17.79rem 0rem 0rem 0rem;
    padding: 8.3rem 1rem;
    text-decoration: none;
}

.home-prefix h2 {
    font-size: 1.975rem;
}

.home-prefix p {
    font-size: 1.1rem;
    line-height: 1.495rem;
}

.home-prefix-desc {
    -webkit-transition: all 0.6s ease;
    -moz-transition: all 0.6s ease;
    -o-transition: all 0.6s ease;
    transition: all 0.6s ease;
    font-size: 10px;
    display: none;
    font-size: 0.75rem;
    margin: 20px 0;
}

.home-prefix-box:hover a .home-prefix-desc {
    display: block;
}

.home-prefix-price {
    -webkit-transition: all 0.6s ease;
    -moz-transition: all 0.6s ease;
    -o-transition: all 0.6s ease;
    transition: all 0.6s ease;
    display: none;
    text-transform: uppercase;
    font-weight: bold;
    color: #fff;
    font-size: 14px;
}

.home-prefix-title {
    font-weight: 700;
}

.home-prefix-box:hover a .home-prefix-price {
    display: block;
}

/* Home Prefix Two */

.home-prefix-two h2 {
    font-size: 14.5px;
    font-weight: normal;
    text-transform: uppercase;
}

.home-prefix-two p {
    font-size: 12px;
    line-height: 21px;
}

.home-prefix-two a {
    text-transform: uppercase;
}

/* Contact Bar */

.contact-bar {
    background: none;
    padding: 0.3125rem 0;
}

.contact-bar-inner {
    color: #fff;
    padding: 3.438rem 0.9375rem;
}

.contact-bar h2 {
    color: #000;
    font-size: 1.188rem;
    font-weight: bold;
    letter-spacing: 0.125rem;
    margin: 0;
    margin-bottom: 1rem;
    text-align: center;
    text-transform: uppercase;
}

.contact-bar-inner p {
    color: #848789;
    font-family: "Lato", sans-serif;
    margin: 0 auto 1.75rem;
    text-align: center;
    width: 60%;
}

.contact-bar-inner .button {
    background: #479fb8;
    display: block;
    font-family: "Montserrat", sans-serif;
    font-size: 0.75rem;
    font-weight: bold;
    letter-spacing: 0.0625rem;
    margin: 0 auto;
    padding: 0.9375rem 0;
    text-transform: uppercase;
    width: 25%;
}

/* Home Page Form*/

.contact-bar-inner form {
    width: 100%;
}

span.prefix,
label.prefix {
    background: #c3c3c3;
}

span.prefix .fa {
    color: #838383;
    font-size: 13px;
}

/* Main Content */

.content-wrapper {
    margin-bottom: 60px;
    margin-top: 60px;
}

/* Postscript */

#postscript {
    background: none;
    background-size: cover;
    position: relative;
}

#postscript img {
    width: 100%;
}

#postscript h2 {
    bottom: 0;
    color: #fff;
    font-size: 3.75rem;
    font-weight: 900;
    height: 3.75rem;
    left: 0;
    line-height: 3.75rem;
    margin: auto;
    position: absolute;
    right: 0;
    text-align: center;
    text-shadow: 0 0 5px rgba(0, 0, 0, 0.65);
    top: 0;
}

/* Coupons */

.coupon {
    background: #f5f5f5;
    background: -moz-linear-gradient(top, #f5f5f5 0%, #cfcfcf 100%);
    background: -webkit-linear-gradient(top, #f5f5f5 0%, #cfcfcf 100%);
    background: linear-gradient(to bottom, #f5f5f5 0%, #cfcfcf 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#f5f5f5', endColorstr='#cfcfcf', GradientType=0);
    -moz-background-clip: padding;
    /* Firefox 3.6 */
    -webkit-background-clip: padding;
    /* Safari 4? Chrome 6? */
    background-clip: padding-box;
    border: 3px dashed;
    margin-bottom: 30px;
    text-align: center;
}

.coupon-inner {
    background-position: center center;
    background-repeat: no-repeat;
    background-size: contain;
}

.coupon-text h3 {
    font-size: 24px;
    text-transform: uppercase;
}

.coupon-text {
    box-sizing: border-box;
    padding: 30px;
}

p.coupon-details {
    font-size: 16px;
    margin: 0 auto 20px;
    width: 75%;
}

p.coupon-disclaimer {
    font-size: 11px;
}

.coupon-text button {
    display: inline-block;
    margin: 0 auto;
    width: 33.34%
}

/* Specials Page Specific Coupons */
.page-template-page-specials .coupon-inner {
    height: 100%;
}

.page-template-page-specials .coupon-text {
    display: flex;
    flex-direction: column;
    height: 100%;
    justify-content: space-between;
}

.page-template-page-specials .coupon-schedule {
    align-self: center;
    margin-top: 20px;
    margin-bottom: 0;
    padding: 9px 20px !important;
}

/* Areas We Serve */

.postscript-cities {
    background-position: center top;
    background-repeat: no-repeat;
    background-size: cover;
    padding: 50px 0;
}

.postscript-cities h3 {
    font-size: 1.975rem;
    font-weight: normal;
    margin: 0 0 30 0;
    text-align: center;
}

.ryno-cities .ryno-column {
    font-size: 16px;
    margin-bottom: 12px;
}

.ryno-cities .ryno-column li>a {
    font-weight: bold;
    text-decoration: underline;
}

/* Postscript Form */

.postscript-contact {
    padding: 60px 0;
}

.postscript-contact h2 {
    font-size: 1.975rem;
}

.postscript-contact p {
    font-size: 1.1rem;
    line-height: 1.495rem;
}

.postscript-contact .cf-textarea {
    height: 90px;
}

.postscript-contact .wpcf7-form select,
.postscript-contact .wpcf7-form select option:first-of-type {
    opacity: 1;
}

.postscript-contact .wpcf7-form select option {
    color: #000;
    opacity: 1;
}


/*Hide postscript form section on Contact Us Page*/

body.contact-us .postscript-contact {
    display: none;
}


/*Change margin on left sidebar*/

.left-sidebar aside {
    margin-right: 8.33333% !important;
    margin-left: 0 !important;
}

/* Footer */

.footer-main {
    padding: 3.75rem 0;
}

.footer-main h2 {
    font-size: 1.425rem;
    font-weight: bold;
}

.footer-main p,
.footer-main ul {
    font-size: 13px;
}

.footer-main ul {
    margin-left: 0;
}

.footer-main ul li {
    float: left;
    width: 50%;
}

.footer-main a {
    font-weight: bold;
}

.footer-main a:hover {
    text-decoration: none;
}

.copyright {
    font-family: "Montserrat", sans-serif;
    font-size: 0.5625rem;
    letter-spacing: 0.0625rem;
    margin-bottom: 0;
    padding: 20px 0;
    text-align: center;
    text-transform: uppercase;
}

.copyright a {
    font-weight: bold;
    text-decoration: none;
}

.copyright a:hover {
    text-decoration: underline;
}

/* Blog styling */

.content-area .post-listing {
    border-bottom: 1px solid #ccc;
    padding: 30px 0;
}

.content-area .post-listing:last-child {
    border-bottom: none;
}

article.post .date {
    margin-bottom: 15px;
}

article.post {
    text-align: center;
}

.single article.post {
    text-align: left;
}

.single-post-h2 {
    margin-bottom: 25px;
}

.view-article {
    display: none;
}


/*Products Table Rebuilt with Foundations grid*/

.ryno-products-table {
    border: 1px solid #ddd;
}

.ryno-products-table .row {
    margin: 0 !important;
}

.ryno-products-table .ryno-dark-row {
    background-color: #F9F9F9;
}

.ryno-products-table .row {
    padding-top: 13px;
}

.ryno-flex-center {
    min-height: 185px;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
    text-align: center;
}

.ryno-cities .ryno-column {
    padding-left: 65px;
    font-size: 1.07rem;
}

/* 404 Error Page */

.error404 .page-header:not(.header-404) {
    display: none;
}

.error404 h3 {
    margin: 18px 0;
}

.error404 input[type="search"],
.search-no-results input[type="search"] {
    border: 3px solid #b1b1b1;
}

.error404 ul.primary-pages,
.search-no-results ul.primary-pages {
    list-style-type: none;
    margin-left: 0;
}

.error404 ul.primary-pages li,
.search-no-results ul.primary-pages li {
    margin-bottom: 10px;
}

.error404 input[type="search"],
.search-no-results input[type="search"] {
    border: 3px solid #b1b1b1;
    display: inline-block;
    width: 90%;
}

.error404 .search-wrap input[type="submit"] {
    background: none;
    height: 36px;
}

.error404 .search-wrap input[type="submit"]:hover {
    background: #ccc;
    color: #fff;
    cursor: pointer;
}

ul.right-column {
    float: left;
    width: 45%;
}

ul.left-column {
    float: left;
    width: 45%;
}

.home-prefix-two {
    display: none;
}


/* Media Queries */

/* 1024px */

@media screen and (max-width: 64em) {
    .ryno-cities .ryno-column {
        padding-left: 10px;
    }
    .sidebar iframe {
        max-width: 100%;
        display: block;
        margin: auto;
    }
    .ryno-button {
        margin: 0 auto 25px;
    }
    .home-prefix-body {
        max-width: 500px;
        margin: auto;
    }
}

@media screen and (min-width: 40em) and (max-width: 64em) {
    .postscript-cities {
        padding-left: 20px;
        padding-right: 20px;
    }
    .top-bar-section li:not(.has-form) a:not(.button),
    .top-bar-section .has-dropdown>a {
        padding: 0 9px !important;
        font-size: 12px;
    }
    aside.sidebar.medium-3.medium-offset-1.columns {
        margin-left: 0 !important;
        width: 33%;
    }
}

/* 767px */

@media screen and (max-width: 48em) {
    .ryno-button {
        width: 180px;
    }
}

/* 640px */

@media screen and (min-width: 40em) {
    .top-bar-section ul {
        display: flex;
        height: auto !important;
        justify-content: space-between;
        width: 100%;
    }
}

/* 640px */

@media screen and (max-width: 40em) {
    .header-logo {
        margin-bottom: 20px;
    }
    .header-right {
        transform: none;
    }
    .ryno-hide-mobile {
        display: none !important;
    }
    a.header-phone-link {
        color: #fff;
    }
    .top-bar-section .dropdown>.menu-item>a {
        -webkit-box-shadow: inset 0 9px 14px -9px rgba(0, 0, 0, 1);
        -moz-box-shadow: inset 0 9px 14px -9px rgba(0, 0, 0, 1);
        box-shadow: inset 0 9px 14px -9px rgba(0, 0, 0, 1);
    }
    .top-bar-section .dropdown>.menu-item~.menu-item>a {
        box-shadow: none;
    }
    .ryno-cities .ryno-column {
        margin: -5px 0 0;
    }
    .home-prefix-body {
        max-width: 250px;
    }
    .cta-bar .button {
        margin-top: 15px;
    }
    .footer-main {
        padding: 70px 0 30px;
    }
    .footer-main .medium-4.columns {
        margin-bottom: 20px;
    }
}
