body {
    font-family: 'Gin-Regular';
    font-size: 14px;
}

.header {
    overflow-x: hidden;
    position: relative;
}

.header .header-top {
    background-image: url(../images/header-bg.jpg);
    background-repeat: no-repeat;
    background-position: center bottom;
    background-size: cover;

    text-align: center;
    margin-top: 0;
    position: relative;
    padding: 2rem;
    min-height: 100vh;
    width: 100vw;
    max-width: 100%;
}

.hero-title a {
    color: #fff;
    display: block;
    /* vertical-align: middle; */
    margin: auto;
    /* text-align: center; */
    width: 260px;
}

.hero-title a:hover {
    margin-top: 2px;
}

p.hero-title a > i {
    font-size: 36px;
    /* line-height: 45px; */
    float: left;
}

p.hero-title a > span {
    display: block;
    /* line-height: 45px; */
    float: left;
    padding: 0 15px;
    font-size: 26px;
}

.header .logo {
    /*position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: 20px;*/
}
.header .logo img {
    max-height: 30vh;
}

.header-top {
    color: #ffffff;
}

.header-top h1 {
    font-size: 56px;
    /*padding-top: 32vh;*/
    margin-top: 30px;
}

.header-top h2 {
    font-size: 32px;
}
.header-content {
    height: 40vh;
    vertical-align: middle;
    margin-top: 10vh;
}

.hero-separator {
    height: 50px;
    margin-bottom: 10px;
}

.hero-cta {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 70px;
    background: rgba(0,0,0,0.7);
}

.hero-cta .hero-title {
    font-size: 30px;
    margin-bottom: 0;
    padding-top: 15px;
}

@media (min-width: 1200px) {
    .container {
        max-width: 990px;
    }
}
@media (max-width: 990px) {
    .header .header-top {
        padding-top: 10vh;
    }
}

.header .social-icons {
    position: absolute;
    top: 30px;
    right: 30px;
    z-index: 999;
    background: #fff;
    padding: 5px 10px;
    border-radius: 5px;
}

.social-icons > a {
    width: 40px;
    height: 40px;
    background-image: url(../images/head-social-media-icons.png);
    display: inline-block;
    background-position: 0 0;
    background-repeat: no-repeat;
    text-decoration: none !important;
}
.social-icons > a.instagram-icon {
    background-position: -44px 0;
}
.social-icons > a.email-icon {
    background-position: -88px 0;
}

/** Sections **/
.section {
    text-align: center;
    padding: 40px;
}
.section h2 {
    font-size: 46px;
    margin-bottom: 0;
}
.section p {
    font-family: 'Roboto', sans-serif;
    text-align: center;
}

.heading-separator {
    margin-bottom: 30px;
}


.section.contact-us {
    background: #000000;
    color: #ffffff;
    font-size: 26px;
}

.section.contact-us a {
    color: #ffffff !important;
}

.section.contact-us h2 {
    font-size: 40px;
    padding-top: 20px;
    padding-bottom: 20px;
}

.phone-number,
.facebook-page,
.contact-us-form {
    display: inline-block;
    padding-bottom: 20px;
}

.contact-us-form {
    padding-bottom: 20px;
    margin-top: 30px;
}

.phone-number a:before,
.facebook-page a:before,
.contact-us-form a:before {
    height: 30px;
    width: 30px;
    display: block;
    float: left;

    background-position: 0 0;
    background-repeat: no-repeat;

    text-decoration: none !important;
    content: ' ';
    background-color: transparent;
    margin-right: 10px;
}

.phone-number a:before {
    background-image: url(../images/phone-icon.png);
}
.facebook-page a:before {
    background-image: url(../images/icon-facebook.png);
}
.contact-us-form a:before {
    background-image: url(../images/icon-email.png);
    margin-top: 4px;
}

.contact-links a {
    display: inline-block;
    line-height: 30px;
    margin-right: 20px;
}

.section.section-map {
    padding: 0;
}

.mapSection {
    position: relative;
}

.bannerImg {
    height: 500px;
    width: 100%;
}

.section.section-cta {
    position: relative;
    padding: 0;
    padding-bottom: 40px;
    background-image: url(../images/background-cta-section.jpg);
    background-repeat: no-repeat;
    background-size: cover;
}

.section.section-cta > img {
    /* position: absolute; */
    margin-top: -55px;
    margin-bottom: 30px;
}

.section.section-cta h2 {
    color: #ffffff;
    font-size: 54px;
}

.section-bar-menu {
    padding: 40px 40px 100px;
}

.section-bar-menu h4:before,
.section-bar-menu h4:after {
    display: inline-block;
    content: ' ';
    background-image: url(../images/heading-icon.png);
    background-repeat: no-repeat;
    width: 30px;
    height: 20px;
    margin: 0 10px;
}
.section-bar-menu h4:after {
    transform: rotate(180deg);
}

.section-bar-menu h3 {
    font-size: 40px;
    margin-bottom: 0;
}
.section-bar-menu h4 {
    font-size: 26px;
    margin-bottom: 25px;
}

.section-bar-menu p {
    text-align: left;
    font-size: 14px;
    line-height: 1.2;
    font-family: 'Gin-Regular';
    /*text-align: justify;*/
}

.section-bar-menu .first-column:after {
    content: ' ';
    display: block;
    width: 3px;
    background: red;
    position: absolute;
    top: -35px;
    right: 0;
    bottom: -35px;
    z-index: 0;
}

.bar-menu-container .media-body h5 {
    font-size: 26px;
    margin-bottom: 5px;
}

.bar-menu-container .media-body h6 {
    font-size: 19px;
    padding-bottom: 5px;
    border-bottom: 3px solid #ff0000;
}

.bar-menu-container .pizza .media-body h6 {
    font-size: 26px;
    margin-bottom: 5px;
    padding-bottom: 5px;
}

.footer {
    padding: 130px 30px 20px;
    background: #000000;
    text-align: center;
    color: #ffffff;
}

.footer-image {
    /* margin-top: -140px; */
    width: 300px;
    overflow: hidden;
    display: block;
    margin: -115px auto 20px;
}
.footer-image > img {
    z-index: 2;
    position: relative;
}

.footer-social .social-icons {
    position: static;
    top: 0;
    right: 0;
    margin-bottom: 15px;
}

.footer-social .social-icons > a {
    background-image: url(../images/head-social-media-icons-white.png);
}

.footer p {
    font-family: Roboto;
}

.form-validation {
    font-family: Roboto;
    font-size: 14px;
    width: 100%;
    margin: 15px 15px;
}

.form-control {
    font-family: 'Roboto';
}

.contact-form {
    display: none;
}

section.section.text-center.section-beer-logos {
    padding: 20px 40px;
    /* border-bottom: 1px solid #e8e8e8; */
    background: #fafafa;
}

.section-beer-logos img {
    width: 160px;
    margin-right: 2em;
    /*border-right: 1px solid #e8e8e8;*/
    padding-right: 2em;

}
.section-beer-logos img:last-child {
    border-right: none;
}

.header-top h2, .header-top h3 {
    width: auto;
    margin: auto;
    display: inline-block;
    padding: 5px 15px;
}

.header h3 {
    font-family: Roboto;
    font-size: 24px;
}

@media screen and (orientation: landscape) {
    .header .header-top {
        padding: 1rem;
        padding-top: 1rem;
    }

    .header-content {
        margin-top: 2vh;

    }

    .header-top h1 {
        font-size: 50px;
    }

    .hero-separator {
        display: none;
    }
}
@media (max-height: 800px) {
    .header-top h2, .header-top h3 {
        background: rgba(0,0,0,0.5);
    }
}


.section.contact-us h2.opening-day {
    display: block !important;
    text-align: center;
    width: auto;
    margin: 0 auto;
    color: #e20714;
    font-size: 44px;
    margin-bottom: 30px;
    padding-top: 0;
    padding-bottom: 0;
}

section.section.section-cta.section-cta-menu {
    background: #dcb48b;

    padding: 30px;
    margin-bottom: 20px;
}

section.section.section-cta.section-cta-menu h3 {
    font-size: 2em;
    display: none;
}

section.section.section-cta.section-cta-menu .menu-link {
    font-size: 26px;
    color: black;
    text-decoration: underline;
    /* border-bottom: 1px solid; */
    display: block;
}

section.section.section-cta.section-cta-menu .menu-link:before,
section.section.section-cta.section-cta-menu .menu-link:after {
    display: inline-block;
    content: ' ';
    background-image: url(../images/heading-icon.png);
    background-repeat: no-repeat;
    width: 30px;
    height: 20px;
    margin: 0 10px;
}
section.section.section-cta.section-cta-menu .menu-link:after {
    transform: rotate(180deg);
}

section.section-iframe-menu {
    padding: 0;
    margin: 0;
    width: 100%;
    height: 650px;
    overflow: hidden;
}

section.section-iframe-menu iframe {
    width: 100%;
    height: 850px;
    border: 0;
    padding: 0;
    margin: 0;
    display: flex;
    margin-top: -200px;
}

section.section.section-cta.section-cta-menu {
    margin-bottom: 0;
}