@charset "UTF-8";
/* CSS Document */

/* Table of contents
––––––––––––––––––––
- Base Styles
- Typography
- links
- Buttons
- Modals
- Forms
- Tables
- Navigation
- Utilities
- Media Queries
------------------*/

/* --------------
-- Base Styles --
---------------*/

* {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

img {
    display: block;
    margin: auto;
}

.img-responsive {
    width: 100%;
}

.img-framed {
    border: 5px solid #fff;
    -webkit-box-shadow: 2px 2px 4px #000;
    box-shadow: 1px 1px 4px #000;
}

@media (min-width: 550px) {
    .img-framed {
        border: 8px solid #fff;
    }
}

html {
    height: 100%;
}

body {
    font-family: "goudy-old-style", serif;
}

header {
    background-color: #cf1c44;
    border-bottom: 5px solid #fff;
    display: block;
    padding: 20px 0;
}

main {
    border-top: 5px solid #0b9446;
    -o-box-shadow: inset 0 0 10px #000000;
    -webkit-box-shadow: inset 0 0 10px #000000;
    box-shadow: inset 0 0 10px #000000;
    color: #fff;
    display: block;
    width: 100%;
}

#landing {
    background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, .6)), to(rgba(0, 0, 0, 0))), url('../img/ingredients-hero.jpg');
    background: linear-gradient(to bottom, rgba(0, 0, 0, .6), rgba(0, 0, 0, 0)), url('../img/ingredients-hero.jpg');
    background-size: cover;
    background-position: top;
}

#catering {
    background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, .6)), to(rgba(0, 0, 0, 0))), url('../img/catering-hero.jpg');
    background: linear-gradient(to bottom, rgba(0, 0, 0, .6), rgba(0, 0, 0, 0)), url('../img/catering-hero.jpg');
    background-size: cover;
    background-position: top;
}

#menus {
    background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, .6)), to(rgba(0, 0, 0, 0))), url('../img/menus-hero.jpg');
    background: linear-gradient(to bottom, rgba(0, 0, 0, .6), rgba(0, 0, 0, 0)), url('../img/menus-hero.jpg');
    background-size: cover;
    background-position: top;
}

#contact {
    background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, .6)), to(rgba(0, 0, 0, 0))), url('../img/contact-hero.jpg');
    background: linear-gradient(to bottom, rgba(0, 0, 0, .6), rgba(0, 0, 0, 0)), url('../img/contact-hero.jpg');
    background-size: cover;
    background-position: top;
}

#events {
    background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, .6)), to(rgba(0, 0, 0, 0))), url('../img/events-hero.jpg');
    background: linear-gradient(to bottom, rgba(0, 0, 0, .6), rgba(0, 0, 0, 0)), url('../img/events-hero.jpg');
    background-size: cover;
    background-position: top;
}

#page-error {
    background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, .6)), to(rgba(0, 0, 0, 0))), url('../img/ingredients-hero.jpg');
    background: linear-gradient(to bottom, rgba(0, 0, 0, .6), rgba(0, 0, 0, 0)), url('../img/ingredients-hero.jpg');
    background-size: cover;
    background-position: top;
    position: absolute;
    height: 100vh;
    color: #fff;
    display: block;
    width: 100%;
    height: 100vh;
    text-align: center;
}

footer {
    background-color: #d7c5b7;
    color: #5e1211;
    display: block;
    width: 100%;
}

.footer-brand {
    height: 19px;
    margin-top: 4px;
    margin-bottom: 25px;
}

@media (min-width: 550px) {
    header {
        padding: 20px 20px;
    }
    .footer-brand {
        height: 39px;
        margin-top: 0;
        margin-bottom: 29px;
    }
}

@media (min-width: 750px) {
    body {
        overflow: hidden;
    }
    header {
        padding: ;
    }
    main {
        position: absolute;
        height: calc(100vh - 75px);
    }
    .scrollable {
        overflow: scroll;
        height: calc(100vh - 75px);
    }
    footer {
        position: absolute;
        top: 100%;
    }
}

/* -------------
-- Typography --
--------------*/

h1,
h2,
h3,
h4 {
    font-family: 'Slabo 13px', serif;
    font-weight: 800;
    letter-spacing: .15rem;
}

h5 {
    font-family: 'Slabo 13px', serif;
    font-weight: 800;
    letter-spacing: .0125rem;
}

.menu h6 {
    font-size: 2rem;
    font-style: italic;
    font-weight: 800;
    border-bottom: 1px solid #5e1211;
}

h6.special,
.price {
    display: block;
    font-family: 'Slabo 13px', serif;
    font-weight: 800;
    letter-spacing: .0125rem;
    text-align: center;
}

p {
    line-height: 1.25;
}

.italic-txt {
    font-style: italic;
}

.underline-txt {
    text-decoration: underline;
}

.left-txt {
    text-align: left;
}

.center-txt {
    text-align: center;
}

.right-txt {
    text-align: right;
}

.justify-txt {
    text-align: justify;
}

.block-txt {
    display: block;
}

.landing-message {
    text-shadow: 1px 1px 2px #000;
}

.landing-message h1 {
    font-size: 3.5rem;
}

.shadow {
    -webkit-box-shadow: 1px 1px 2px #000;
    box-shadow: 1px 1px 2px #000;
}

.text-shadow {
    text-shadow: 1px 1px 2px #000;
}

p.lead {
    font-size: 1.5rem;
    letter-spacing: .1rem;
}

@media (min-width: 750px) {
    .landing-message h1 {
        font-size: 5rem;
    }
    p.lead {
        font-size: 2.25rem;
    }
}

.page-header {
    border-bottom: 3px solid #fff;
    margin-bottom: 90px;
    padding-bottom: 15px;
}

address {
    font-size: 1em;
    line-height: 1.265;
    font-weight: 400;
    font-style: normal;
    padding: 0;
    margin-top: 0;
    margin-bottom: 15px;
    ;
}

.phone-number,
.store-hours {
    display: block;
    margin-top: .765em;
}

/* --------
-- Links --
---------*/

a {
    font-family: 'Slabo 13px', serif;
    font-weight: 800;
    color: #fff;
    text-decoration: none;
}

footer a {
    color: #5e1211;
}

footer a:hover,
footer a:focus {
    color: #cf1c44;
}

a:hover,
a:focus {
    color: #cf1c44;
}

a.scroll-link {
    display: none;
    visibility: hidden;
}

@media (min-width: 750px) {
    a.scroll-link {
        display: inline-block;
        visibility: visible;
        margin-right: 0;
        position: absolute;
        bottom: 15px;
        right: 30px;
    }
}

/* ----------
-- Buttons --
-----------*/

.button.button-primary,
button.button-primary,
input[type="submit"].button-primary,
input[type="reset"].button-primary,
input[type="button"].button-primary {
    background-color: #5e1211;
    border-color: transparent;
    color: #fff;
    -webkit-transition: .25s ease-in-out;
    transition: .25s ease-in-out;
    font-family: "goudy-old-style", serif;
    font-family: 'Slabo 13px', serif;
}

.button.button-primary:hover,
button.button-primary:hover,
input[type="submit"].button-primary:hover,
input[type="reset"].button-primary:hover,
input[type="button"].button-primary:hover,
.button.button-primary:focus,
button.button-primary:focus,
input[type="submit"].button-primary:focus,
input[type="reset"].button-primary:focus,
input[type="button"].button-primary:focus {
    background-color: #cf1c44;
    border-color: transparent;
}

.button.button-primary.button-lg,
button.button-primary.button-lg,
input[type="submit"].button-primary.button-lg,
input[type="reset"].button-primary.button-lg,
input[type="button"].button-primary.button-lg {
    /*    background-color: #0b9446;*/
    border-radius: 6px;
    display: inline-block;
    font-size: 1.25rem;
    height: auto;
    margin-bottom: 15px;
    padding: 5px 30px;
    width: 100%;
}

@media (min-width: 750px) {
    .button.button-primary.button-lg,
    button.button-primary.button-lg,
    input[type="submit"].button-primary.button-lg,
    input[type="reset"].button-primary.button-lg,
    input[type="button"].button-primary.button-lg {
        border-radius: 12px;
        display: inline-block;
        font-size: 1.5rem;
        height: auto;
        padding: 15px 30px;
    }
}

/* ---------
-- Modals --
----------*/

.modal {
    background-color: #d7c5b7;
    border-radius: 0;
    color: #5e1211;
    padding: 30px;
    max-width: 550px;
    -webkit-box-shadow: none;
    box-shadow: none;
    outline: 0;
}

.modal img {
    max-width: 550px;
}

@media (min-width: 750px) {
    .modal {
        max-width: 750px;
    }
}

.modal a {
    color: #5e1211;
    float: right;
}

.modal a:hover,
.modal a:focus {
    color: #cf1c44;
}

.modal a.close-modal[class*="icon-"] {
    background: #5e1211;
    color: #d7c5b7;
}

.modal-icon-cover {
    position: absolute;
    background-color: #d7c5b7;
    width: 30px;
    height: 30px;
    top: 0;
    right: 0;
    z-index: 1000;

}

.modal i {
    display: inline-block;
    float: left;
}

.modal-note {
    display: inline-block;
    width: calc(100% - 95px);
    margin-left: 30px;
    line-height: 2.1rem;
    float: left;
}

#twitter .modal-note {
    width: calc(100% - 105px);
}

/* --------
-- Forms --
---------*/

form {
    margin-bottom: 0;
}

input[type="email"],
input[type="number"],
input[type="search"],
input[type="text"],
input[type="tel"],
input[type="url"],
input[type="password"],
textarea,
select {
    font-family: "goudy-old-style", serif;
    outline-color: #cf1c44;
}

label > .label-body {
    display: inline-block;
    margin-left: .5rem;
    margin-bottom: 1rem;
    font-weight: normal;
}

#newsletter-form {
    margin-bottom: 40px;
}

@media (min-width: 550px) {
    #newsletter-form {
        margin-bottom: 0;
    }
}

/* ---------
-- Menus --
----------*/

.menu {
    display: block;
}

.menu .row {
    display: block;
    margin-bottom: 30px;
}

.menu .item {
    display: block;
    font-family: 'Slabo 13px', serif;
    font-weight: 800;
    letter-spacing: .0125rem;
    margin-bottom: 10px;
}

.menu .description {
    display: block;
    padding-bottom: 10px;
}

.menu .addition {
    display: block;
    font-size: 1.25rem;
    font-style: italic;
    padding: 10px 0;
    line-height: 1;
}

.menu .price {
    display: block;
    text-align: right;
}

@media (min-width: 550px) {
    .menu .item,
    .menu .description,
    .menu .addition {
        display: inline-block;
        text-align: left;
        float: left;
    }
    .menu .addition {
        margin-right: 30px;
    }
    .menu .addition {
        margin-right: 30px;
    }
    .menu .item {
        clear: left;
    }
    .menu .price {
        display: inline-block;
        text-align: right;
        float: right;
        margin-left: 30px;

    }
}

/* --------
-- Lists --
---------*/

ul.social-icons {
    display: block;
    list-style: none;
    margin: 0;
    padding: 0;
}

ul.social-icons li {
    display: inline-block;
    margin-right: 15px;
    margin-bottom: 55px
}

@media (min-width: 550px) {
    ul.social-icons li {
        margin-bottom: 0;
    }
}

ul.social-icons li a i {
    display: block;
    font-size: 3.276rem;
}

/* -------------
-- Navigation --
--------------*/

.brand {
    display: block;
    float: left;
    width: auto;
    height: 20px;
}

#pasta-amore-horiz-logo {
    height: 20px;
    padding-bottom: 3px;
}

.sitemap-link {
    float: right;
}

.nav-toggler {
    float: right;
    height: 20px;
}

.sitemap-link a:hover,
.sitemap-link a:focus {
    color: #0b9446;
}

.sitemap-link i {
    display: block;
    font-size: 14px;
    height: 20px;
    line-height: 20px;
    margin-left: 20px;
    vertical-align: middle;
}

@media screen and (min-width: 550px) {
    .sitemap-link i {
        font-size: 21px;
        padding-top: 6px;
    }
}

.nav-toggler i {
    color: #fff;
    display: block;
    font-size: 17px;
    height: 20px;
    line-height: 20px;
    vertical-align: middle;
    -webkit-transition: .25s ease-in-out;
    transition: .25s ease-in-out;
}

#target-nav {
    display: block;
    border-top: 1px solid #fff;
    display: none;
    margin-top: 20px;
    float: left;
    width: 100%;
}

.nav {
    display: block;
    margin: 0;
    padding-left: 0;
    width: 100%;
}

.nav li {
    display: block;
    list-style: none;
    margin: 0;
}

.nav li:first-child {
    margin-left: 0;
}

.nav li a {
    color: #fff;
    display: block;
    font-size: 16px;
    font-weight: 800;
    letter-spacing: 1px;
    line-height: 1;
    margin-top: 20px;
    text-decoration: none;
}

.dropdown-menu {
    display: block;
    visibility: hidden;
    max-height: 0;
    overflow: hidden;
    -webkit-transition: .25s ease-in-out;
    transition: .25s ease-in-out;
}

li.dropdown:hover > .dropdown-menu,
li.dropdown:focus > .dropdown-menu {
    visibility: visible;
    max-height: 300px;
}

.divider {
    visibility: hidden;
}

.dropdown-menu a {
    display: block;
    padding-left: 20px;
}

.nav-toggler i.fas.fa-bars:hover,
.nav-toggler i.fas.fa-bars:focus {
    color: #0b9446;
}

.nav li a:hover,
.nav li a:focus {
    color: #0b9446;
}

@media screen and (min-width: 550px) {
    .brand {
        height: 30px;
    }

    #pasta-amore-horiz-logo {
        height: 30px;
    }

    .nav-toggler {
        height: 26px;
        padding-top: 5px;
    }

    .nav-toggler i {
        font-size: 26px;
    }
}

@media screen and (min-width: 750px) {
    .sitemap-link {
        position: fixed;
        right: 30px;
    }
    .nav-toggler {
        display: none;
        visibility: hidden;
    }

    #target-nav {
        display: block !important;
        border-top: none;
        float: right;
        margin-top: 8px;
        width: auto;
    }

    .nav {
        margin-top: 0;
        width: auto;
    }
    .nav li {
        display: block;
        margin-left: 30px;
        float: left;
    }
    .nav li a {
        margin-top: 0;
    }

    .dropdown {
        text-align: center;
        width: auto;
    }

    .dropdown:hover,
    .dropdown:focus {
        -webkit-transition: .25s ease-in-out;
        transition: .25s ease-in-out;
    }

    .dropdown-menu {
        position: absolute;
        width: 0;
    }

    li.dropdown:hover > .dropdown-menu,
    li.dropdown:focus > .dropdown-menu {
        position: relative;
        width: auto;
    }

    li.dropdown:hover > .dropdown-menu > .dropdown-link,
    li.dropdown:focus > .dropdown-menu > .dropdown-link {
        position: relative;
        display: block;
        height: 20px;
    }

    .divider {
        visibility: visible;
        border-bottom: 1px solid #fff;
        width: 25px;
        margin: 5px auto 0 auto;
    }

    .dropdown > .dropdown-menu > a {
        margin-top: 20px;
        padding-left: 0;
        text-align: center;
    }
}

/* ------------
-- Utilities --
-------------*/

/* padding */

.p-xy {
    padding: 30px;
}

.p-xy-extra {
    padding: 60px;
}

.p-x {
    padding-left: 30px;
    padding-right: 30px;
}

.p-x-extra {
    padding-left: 60px;
    padding-right: 60px;
}

.p-y {
    padding-top: 30px;
    padding-bottom: 30px;
}

.p-y-extra {
    padding-top: 60px;
    padding-bottom: 60px;
}

.p-t {
    padding-top: 30px;
}

.p-t-extra {
    padding-top: 60px;
}

.p-b {
    padding-bottom: 30px;
}

.p-b-extra {
    padding-bottom: 60px;
}

/* margin */

.m-xy {
    margin: 30px;
}

.m-xy-extra {
    margin: 60px;
}

.m-x {
    margin-left: 30px;
    margin-right: 30px;
}

.m-x-extra {
    margin-left: 60px;
    margin-right: 60px;
}

.m-y {
    margin-top: 30px;
    margin-bottom: 30px;
}

.m-y-extra {
    margin-top: 60px;
    margin-bottom: 60px;
}

.m-t {
    margin-top: 30px;
}

.m-t-extra {
    margin-top: 60px;
}

.m-b {
    margin-bottom: 30px;
}

.m-b-extra {
    margin-bottom: 60px;
}

/* clearfix */

.clearfix {
    overflow: auto;
}

.clearfix::after {
    content: "";
    clear: both;
    display: table;
}

/* -------------
-- Animations --
--------------*/

/* Flash class and keyframe animation */

.flashit {
    color: #f2f;
    -webkit-animation: flash linear 1s infinite;
    animation: flash linear 1s infinite;
}

@-webkit-keyframes flash {
    0% {
        opacity: 1;
    }
    50% {
        opacity: .1;
    }
    100% {
        opacity: 1;
    }
}

@keyframes flash {
    0% {
        opacity: 1;
    }
    50% {
        opacity: .1;
    }
    100% {
        opacity: 1;
    }
}

/* ----------------
-- Media Queries --
-----------------*/

/* Larger than mobile */

@media (min-width: 400px) {}

/* Larger than phablet (also point when grid becomes active) */

@media (min-width: 550px) {}

/* Larger than tablet */

@media (min-width: 750px) {}

/* Larger than desktop */

@media (min-width: 1000px) {}

/* Larger than Desktop HD */

@media (min-width: 1200px) {}
