:root {
    --primary-bg: #18800C;
    --text-color-white: #fff;
    --text-color-black: #000;
    --green-main: #22B712;
    --green-tertiary: #093317;
    --secondary-yellow: #F1C500;
    --page-max-width: 1196px;
    --primary-font: "Montserrat", sans-serif;
    --secondary-font: "Jost", sans-serif;
    --body-text-size: 14px;
    --body-text-weight: 400;
    --text-small: 12px;
    --h1-text-size: 44px;
    --h2-text-size: 36px;
    --h3-text-size: 24px;
    --h1-text-size-xs: 2em;
    --h2-text-size-xs: 1.8em;
    --h3-text-size-xs: 1.6em;
    --cta-radius: 12px;
    --cta-transparent: transparent;
    --navbar-text-color: #32484D;
    --navbar-text-color-hover: var(--primary-bg);
    --form-h2-text-size: 36px;
    --form-h2-text-color: #000;
    --form-input-bg: #F2F2F2;
    --form-input-text-size-md: 18px;
}

body {
    font-family: var(--primary-font);
    font-size: var(--body-text-size);
    font-weight: var(--body-text-weight);
}
h1, h2 {
    font-weight: 700;
}
h1 {
    font-size: var(--h1-text-size);
    letter-spacing: 0;
}
h2 {
    font-size: var(--h2-text-size);
    color: var(--secondary-yellow);
}

.top-bar {
    background-color: var(--primary-bg);
    color: var(--text-color-white);
    min-height: 40px;
    letter-spacing: .5px;
    padding-top: 12px;
    padding-bottom: 12px;
}

.top-bar h3 {
    color: var(--text-color-white);
    font-family: var(--secondary-font);
    font-size: var(--text-small);
    font-weight: 400;
    margin: 0px;
}
.top-bar h3 b {
    font-family: var(--primary-font);
    font-size: var(--body-text-size);
    font-weight: 700;
}
.top-location {
    font-weight: 700;
    display: flex;
    justify-content: flex-end;
}
.top-location .btn-marker, .top-location .btn-marker:hover, .top-location .btn-marker:visited {
    display: flex;
    margin-right: 60px;
    color: var(--text-color-white);
    text-decoration: none;
    line-height: 2;
    padding-top: 6px;
}

.top-location .btn-cta, .top-location .btn-cta:hover, .top-location .btn-cta:visited {
    padding: 6px;
    height: 30px;
    color: var(--green-tertiary);
}

.wl-icons {
    background-image: url(../img/icons.png);
    background-repeat: no-repeat;
    display: inline-block;
}
.wl-icon-map {
    width: 30px;
    height: 30px;
    background-position: -41px 0;
    margin-right: 12px;
}
.wl-icon-phone {
    width: 30px;
    height: 30px;
    background-position: -73px 0;
    margin-right: 12px;
}
.wl-icon-success {
    width: 40px;
    height: 40px;
    background-position: 0 0;
    margin-right: 20px;
}

.page-with-bg {
    background-image: 
        linear-gradient(rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.5)), 
        url('/wonderland/html/assets/img/home-bg.jpg');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    color: var(--text-color-white);
}

.page-wrapper {
    margin: auto;
    max-width: var(--page-max-width);
}

.btn-cta, .btn-cta:hover, .btn-cta:visited {
    display: inline-block;
    line-height: 1;
    border-radius: var(--cta-radius);
    text-decoration: none;
    padding: 22px 24px;
}

.btn-cta-yellow, .btn-cta-yellow:hover, .btn-cta-yellow:visited {
    background-color: var(--secondary-yellow);
    padding: 6px;
    min-height: 42px;
    display: flex;
    line-height: 2;
}
.btn-cta-green, .btn-cta-white {
    line-height: 1;
    font-weight: 700;
    margin-right: 20px;
}
.btn-cta-green, .btn-cta-green:hover, .btn-cta-green:visited {
    background-color: var(--green-main);
    color: var(--text-color-white);
}
.btn-cta-white, .btn-cta-white:hover, .btn-cta-white:visited {
    background-color: var( --text-color-white );
    color: var(--green-tertiary);
}
.btn-cta-back, .btn-cta-back:hover, .btn-cta-back:visited {
    background-color: var( --cta-transparent);
    color: var(--green-tertiary);
    padding-left: 0 !important;
    font-weight: 700;
}

.wl-main-menu {
    list-style: none;
    margin: 0px;
    padding: 0px;
    display: inline-block;
    text-align: right;
}
.wl-main-menu li {
    display: inline-block;
    margin: 0 18px;
}

.wl-main-menu a, .wl-main-menu a:hover, .wl-main-menu a:visited {
    color: var(--navbar-text-color);
    text-decoration: none;
    font-weight: 700;
    display: inline-block;
    padding: 5px 0 3px 0;
    line-height: 1;
}
.wl-main-menu a:hover {
    color: var(--navbar-text-color-hover);
    border-bottom: solid 1px var(--navbar-text-color-hover);
}
.navbar-wrapper .btn-cta-green {
    margin-right: 0px;
}

.navbar-wrapper {
    min-height: 115px;
    letter-spacing: .5px;
}
.navbar {
    justify-content: end;
}
.navbar .btn-cta-green {
    margin-left: 20px;
}
.navbar-bars, #menu-close {
    display: none;
}
.navbar-bars .btn-open, .navbar-bars .btn-open:hover, .navbar-bars .btn-open:visited {
    font-size: 2em;
    color: var(--green-tertiary);
    padding: 3px 5px;
    display: inline-block;
    border: solid 2px var(--green-tertiary);
    line-height: 1;
    border-radius: var(--cta-radius);
    cursor: pointer;
}

.navbar-mobile-wrapper {
    max-width: 30vw;
    margin: auto;
    text-align: left;
}

.navbar-mobile {
    position: absolute;
    left: 0;
    right: 0;
    background-color: var(--green-tertiary);
    padding: 20px;
    display: none;
}
.navbar-mobile .wl-main-menu {
    position: relative;
    width: 100%;
    text-align: left;
}
.navbar-mobile .wl-main-menu li {
    display: block;
    margin-bottom: 20px;
    margin-right: 0;
}
.navbar-mobile .wl-main-menu li a, .navbar-mobile .wl-main-menu li a:hover, .navbar-mobile .wl-main-menu li a:visited {
    color: var(--text-color-white);
    width: 100%;
}

.page-hero {
    min-height: 75vh;
}
.page-hero .content {
    max-width: 690px;
}

.footerWrapper {
    height: 40px;
}

.page-hero .widget-yelp {
    margin-top: 40px;
}

.wl-form {
    max-width: 720px;
    border-radius: 24px;
}
.wl-form .modal-content {
    border-radius: 24px;
}
.wl-form .modal-header,
.wl-form .modal-footer {
    border: none;
}
.wl-form .modal-body {
    padding: 60px 40px;
}
.wl-form h2 {
    font-size: var(--form-h2-text-size);
    color: var(--form-h2-text-size);
    margin-bottom: 15px;
}
.wl-form p {
    margin-bottom: 40px;
}
.wl-form input[type="text"],
.wl-form input[type="email"],
.wl-form input[type="tel"] {
    background-color: var(--form-input-bg);
    border-radius: 6px;
    display: block;
    width: 90%;
    margin: 15px 0;
    border: none;
    outline-offset: 0;
    font-family: var(--secondary-font);
    font-size: 12px;
    padding: 15px 12px;
    line-height: 1;
    letter-spacing: .5px;
}
.wl-form .progress-wrapper {
    width: 90%;
}
.wl-form .progress {
    height: 2px;
    background-color: var(--form-input-bg);
    width: 100%;
    position: relative;
    top: -8px;
    z-index: 10;
}
.wl-form .progress-markers {
    display: flex;
    justify-content:space-between;
    width: 100%;
}
.wl-form .progress-marker, .wl-form .progress-marker-on {
    width: 16px;
    height: 16px;
    border-radius: 8px;
    position: relative;
    z-index: 11;
    display: inline-block;
}
.wl-form .progress-marker {
    background-color: var(--form-input-bg);
}
.wl-form .progress-marker-on {
    background-color: var(--secondary-yellow);
}
.wl-form-thanks {
    display: inline-flex;
}
.wl-form-thanks h3 {
    font-size: var(--h3-text-size);
    font-weight: 600;
    display: block;
}
.wl-form .step {
    display: none;
}

/* media queries */
@media screen and (max-height: 700px) {
  .page-hero {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}

@media screen and (max-width: 992px) {
    .wl-main-menu li {
        margin: 0 5px;
    }
}

@media screen and (max-width: 870px) {
    .navbar-wrapper { min-height: auto; padding: 10px 0; }
    .logo-wrapper img { width: 25vw;}
    .navbar { display: none; }
    .top-location .btn-marker { margin-right: 30px;}
    .page-hero h1 { font-size: var(--h1-text-size-xs); }
    .page-hero h2 { font-size: var(--h2-text-size-xs); }
    .page-hero h3 { font-size: var(--h3-text-size-xs); }
    .navbar-bars { display: block; }
}
@media screen and (max-width: 765px) {
    .top-deal {text-align: center; }
    .top-location { justify-content: center; margin-top: 10px; }
    .top-bar { padding-top: 9px; padding-bottom: 9px; }
}
@media screen and (max-width: 640px) { 
    .btn-cta, .btn-cta:hover, .btn-cta:visited {
        padding: 12px 14px;
    }
    .wl-form h2 { font-size: var(--h2-text-size-xs); }
    .wl-form input[type="text"],
    .wl-form input[type="email"],
    .wl-form input[type="tel"] {
        font-size: var(--form-input-text-size-md);
        width: 100%;
    }
    .wl-form .progress-wrapper, .wl-form .progress, .wl-form .progress-markers { width: 100%; }

}
@media screen and (max-width: 576px) { 
    .navbar-mobile-wrapper { max-width: 70vw; }
}
@media screen and (max-width: 480px) { 
    .logo-wrapper img { width: 95%;}
    .navbar-mobile-wrapper { max-width: 90vw; text-align: left; }
    .navbar-mobile .wl-main-menu { text-align: left; }
    .navbar-mobile-wrapper .btn-cta-green { margin-right: 0;}
}