/* Playfair Display
Regular 400
Medium 500
SemiBold 600
Bold 700
ExtraBold 800
Black 900
*/

/* Source Sans Pro
ExtraLight 200
Light 300
Regular 400
SemiBold 600
Bold 700
Black 900
*/

/************************************************ Elements ************************************************/
body {
    background-color: #0d131e;
}

h1, h2, h3, h4, h5, h6, p, a {
    font-family: 'Playfair Display', serif;
    font-weight: 600;
    font-feature-settings: "lnum";
    color: #ffffff;
}

h1 {
    font-size: 96px;
}

h2 {
    font-size: 75px;
}

h3 {
    font-size: 48px;
}

h4 {
    font-size: 32px;
}

h5 {
    font-size: 24px;
    font-weight: 400;
}

h6 {
    font-size: 20px;
    font-weight: 400;
}

a {
    font-weight: 400;
    font-size: 14px;
    text-decoration: none;
}

p, label, ::placeholder, input, textarea {
    font-family: 'Source Sans Pro', sans-serif;
    font-weight: 300;
    font-size: 16px;
    line-height: 1.75;
}

input {
    color: #ffffff;
}

input[type=submit] {
    font-family: 'Playfair Display', serif;
    font-weight: 400;
    font-size: 14px;
}

caption {
    font-size: 12px;   
}

hr {
    color: #a1a8b2;
}

img {
    width: 100%;
}

/************************************************ IDs ************************************************/
#masthead, #sub-masthead {
    margin-bottom: 30px;
}

/************************************************ Classes ************************************************/
.fineline-top-logo {
    width: 160px;
}

.container-fluid {
    padding: 0;
}

.main-container {
    padding: 2% 10%;
}

.masthead-container {
    padding: 0 10% 2%;
}

.navbar-brand {
    padding-top: 0;
}

.navbar-dark .navbar-nav .nav-link {
    color: #ffffff;
}

.navbar-dark:hover .navbar-nav:hover .nav-link:hover {
    color: #ffffff;
}

.navbar-dark:hover .navbar-nav:hover .nav-item:last-child .nav-link:hover {
    background-color: #ffffff;
    color: #ce8d4c;
}

.navbar-nav, .nav-link {
    transition: none;
    text-align: center;
    letter-spacing: 2px;
}

.nav-item {
    margin-left: 40px;
}

.active {
    border-bottom: solid 1px #ce8d4c;
    padding-bottom: 5px;
}

.primary-btn-line:hover {
    border-bottom: solid 1px #ce8d4c;
    padding-bottom: 5px;
}

.primary-btn {
    border: none;
    background-color: #ce8d4c;
    padding: 7px 40px;
    letter-spacing: 2px;
}

.primary-btn:hover {
    background-color: #ffffff;
    color: #ce8d4c;
    padding: 7px 40px;
}

.secondary-btn {
    border: none;
    padding: 7px 0px;
    letter-spacing: 2px;
}

.secondary-btn:hover {
    color: #ffffff;
    border-bottom: solid 1px #ce8d4c;
}

.primary-btn-container {
    margin-top: 30px;
}

.secondary-btn-container {
    margin-bottom: 30px;
}

.body-bg {
    width: 100%;
    min-height: 1000px;
    position: relative;
}

.bg-img {
    width: 100%;
    height: 829px;
    background-image:url('../img/water-splash.png');
    background-color: #0d131e;
    background-position: center;
    background-repeat: no-repeat;
    background-size: 1700px 705px;
    position: absolute;
    z-index: -9999999999;
    top: 200px;
}

.main-masthead-img {
    width: 100%;
    padding: 23% 0;
    background-image:url('../img/masthead-banner.jpg');
    background-color: #0d131e;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}

.main-header h1 {
    text-align: center;
    text-shadow: 2px 2px 50px #0d131e;
}

.content-container {
    padding: 3% 20%;
}

.about-us-shortcut {
    margin-bottom: 30px;
}

.content-desc {
    margin-top: 20px;
}

.left-image-box {
    text-align: left;
}

.right-image-box {
    text-align: right;
}

.content-img {
    width: 95%;
}

.menu-img {
    margin: 25px 0;
}

.menu-shortcut {
    margin-top: 70px;
}

.shortcut-desc {
    margin-top: 120px;
}

.mailing-list-container {
    margin-top: 30px;
    padding: 7% 20%;
    background-color: #141d2d;
    text-align: center;
}

.form-floating {
    margin-top: 30px;
}

.form-field {
    width: 100%;
    border-radius: 0;
    background: none;
    border: none;
    border-bottom: solid 1px #a1a8b2;
    padding: 5px 10px;
    color: #ffffff;
}

.form-field:focus {
    outline: none;
}

.form-floating > label {
    padding: 0 20px;
    color: #a1a8b2;
}

textarea.form-field {
    resize: none;
}

input.form-field:focus ~ label, input.form-field:valid ~ label,
textarea.form-field:focus ~ label, textarea.form-field:valid ~ label {
    transform: translateY(-20px);
    font-size: 14px;
    color: #ffffff;
}

.fineline-bottom-logo {
    width: 200px;
}

.footer-links {
    padding: 100px 0 20px 0;
    text-align: center;
}

.footer-links p {
    font-family: 'Playfair Display', serif;
    font-weight: 400;
}

.copyright p {
    margin: 0;
    font-size: 12px;
}

.social-media a {
    margin: 30px 50px;
}

.footer-logo {
    padding-bottom: 30px;
}

.footer-contacts {
    padding: 0% 26%;
    line-height: 2;
}

.footer-contacts p {
    margin-bottom: 0;
}

a.hp-link, a.mail-link {
    padding: 0px;
}

a.hp-link:hover, a.mail-link:hover {
    color: #ffffff;
    border-bottom: solid 1px #ce8d4c;
}

div.social-media {
    padding: 30px 0;
}

.fa-brands:hover {
    color: #ce8d4c;
}

.navbar-dark .navbar-toggler-icon {
    background-image: url(../img/hamburger-menu.svg);
}

.contact-us-container {
    padding: 5% 10%;
    width: 80%;
    background-color: #141d2d;
}

.contact-us {
    margin-top: 50px;
}

.vertical-line {
    margin-right: 20px;
    height: 450px;
    border-right: solid 1px #a1a8b2;
}

.fa-light-blue {
    color: #a1a8b2;
}

.sub-bg-img {
    width: 100%;
}

.menu-sub-masthead-img {
    background-image:url('../img/menu-sub-masthead.jpg');
}

.about-sub-masthead-img {
    background-image:url('../img/about-sub-masthead.jpg');
}

.contact-sub-masthead-img {
    background-image:url('../img/contact-sub-masthead.jpg');
}

.sub-masthead-img {
    width: 100%;
    padding: 8% 0;
    background-color: #0d131e;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}

.sub-masthead-img h2 {
    text-align: center;
}

.body-subheader h3 {
    margin: 50px 0;
    text-align: center;
}

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

.food-row {
    margin-top: 20px;
}

.food-row p {
    color: #a1a8b2;
    font-style: italic;
}

p.menu-subheader {
    font-family: 'Playfair Display', serif;
    text-align: center;
    letter-spacing: 5px;
}

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

.position-container {
    margin-top: 50px;
}

.position-roles {
    padding: 50% 0;
}

.position-roles p {
    font-family: 'Playfair Display', serif;
    font-weight: 600;
    padding: 5%;
}

span.roles {
    font-style: italic;
    font-weight: 400;
}

/************************************************ Media Query ************************************************/
@media (max-width: 1200px) {
    /******************** Classes ********************/
    .shortcut-desc {
        margin-top: 0px;
    }
    
    .position-roles {
        padding: 40% 0;
    }
    
    .position-roles p {
        padding: 2%;
    }
}

@media (max-width: 992px) {
    /******************** Classes ********************/
    .md-sm-center {
        text-align: center;
    }

    .nav-item {
        margin: 5px 0px;
    }

    .cocktail-img {
        width: 100%;
    }

    .bg-dark {
        --bs-bg-opacity: 1;  
    }

    .menu-shortcut {
        margin-top: 40px;
    }

    .footer-contacts {
        padding: 0% 15%;
    }

    .vertical-line {
        margin-right: 0px;
        width: 100%;
        height: 0px;
        margin: 30px 0;
        border-right: none;
        border-bottom: solid 1px #a1a8b2;
    }  
    
    .content-img {
        width: 100%;
    }

    .image-center {
        margin: 0 auto;
    }

    .bg-img {
        top: 100px;
    }

    .shortcut-desc {
        margin-top: 20px;
    }

    .position-container {
        margin-top: 0px;
    }

    .position-roles {
        padding: 5% 0;
    }
    
    .mailing-list-container {
        padding: 10% 20%;
    }
}

@media (max-width: 768px) {
    /******************** Elements ********************/
    h1 {
        font-size: 68px;
    }

    h2 {
        font-size: 58px;
    }

    h3 {
        font-size: 40px;
    }
    
    /******************** Classes ********************/
    .nav-gradient {
        height: 90px;
    }    

    .footer-contacts {
        padding: 0%;
    }
    
    .bg-img {
        top: 0;
    }

}

@media (max-width: 576px) {
    /******************** Elements ********************/
    h1 {
        font-size: 56px;
    }

    h2 {
        font-size: 40px;
    }

    h3 {
        font-size: 32px;
    }
    
    /******************** Classes ********************/
    .social-media a {
        margin: 30px 40px;
    }

}