@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Tinos:ital@0;1&display=swap');

.post, .page { margin: 0; }

body, p { font-family: 'Montserrat', sans-serif; font-weight: normal; color: #000000; }
p { line-height: 1.8; }
h1, h2, h3, h4, h5, h6 { font-family: 'Montserrat', sans-serif; font-weight: 600; text-transform: uppercase; color: #000000; }

main { padding-bottom: 0px; }

/* Site Logo */
header .navbar {
  padding: 25px 0;
}
header .navbar > .container-fluid {
  justify-content: end;
}
.navbar-brand { 
  margin: 0;
  padding: 0;
  position: absolute;
  width: 130px;
  top: 10px;
  left: 10px;
}
.navbar-brand img { width: 100px; }

/* Header Nav Menu */
.header-nav-container .menu-menu-1-container { padding: 15px 0; }
.header-nav {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-left: 0;
  margin: 0;
  list-style: none;
  gap: 30px;
}
.header-nav li.page_item {
  text-align: center;
}
.header-nav li {
  text-align: center;
  position: relative;
}
.header-nav li a {
  display: inline-block;
  text-decoration: none;
  text-transform: uppercase;
  color: #C12029;
  font-weight: 500;
}
.header-nav li a:hover {
  text-decoration: underline;
}
.menu-item.menu-arrow a {
  padding-right: 20px;
  display: block;
  position: relative;
}
.menu-item.menu-arrow > a:after {
  content: '';
  display: block;
  position: absolute;
  right: 20px;
  top: 3px;
  z-index: 999;
  width: 10px;
  height: 10px;
  background: none;
  border-bottom: 1px solid #C12029;
  border-left: 1px solid #C12029;
  transform: rotate(-45deg);
}
.menu-item ul.sub-menu {
  list-style: none;
  /* background: rgba(255, 255, 255, 1); */
  background: #ffffff;
  margin-left: 0;
  padding-left: 0;
  margin-top: 10px;
}
.menu-item ul.sub-menu li a {
  text-transform: capitalize;
  padding: 5px;
  color: #000000;
}
.menu-item ul.sub-menu li a:hover {
  /* color: #020168; */
  font-weight: 600;
}

/* Menu Toggle Button */
.menu-icon-container {
  display: inline-block;
  cursor: pointer;
  margin-right: 15px;
}
.bar1, .bar2, .bar3 {
  width: 20px;
  height: 2px;
  background-color: #C12029;
  margin: 6px 0;
  transition: 0.4s;
}
.change .bar1 {
  transform: translate(0, 5px) rotate(-45deg);
}
.change .bar2 {opacity: 0;}
.change .bar3 {
  transform: translate(0, -11px) rotate(45deg);
}

/* Footer */
footer {
  /* background: url('../assets/imgs/footer-bg.jpg') no-repeat center; */
  background-size: cover;
  background-color: #C12029;
  color: #ffffff;
  /* padding: 50px 20px; */
}
.footer-menu-heading {
  font-size: 18px;
  text-transform: uppercase;
  color: #ffffff;
  margin-bottom: 25px;
}
.footer-menu-content p {
  font-size: 14px;
  font-weight: 600;
  color: #ffffff;
}
.footer-menu-content .footer-menu-details, .footer-menu-content .footer-menu-details a {
  font-weight: normal;
  color: #F1DD6C;
}
.footer-menu-content .footer-menu-title { text-transform: uppercase; }
/* .footer-menu-content .store-loc-details { color: #ffffff; } */
.footer-social-links { margin-top: 30px; }
.footer-social-links a {
  display: inline-block;
  text-decoration: none;
  margin-right: 20px;
}
.footer-container {
  padding-top: 50px;
  padding-bottom: 25px;
}
.footer-container > div.row > div {
  margin-bottom: 25px;
}
.footer-copyright {
  background-color: #AA010A;
  padding-top: 15px;
  padding-bottom: 15px;
}
.footer-menu-text { font-size: 14px; line-height: 2; color: #ffffff; }

.wa-msg {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 9999;
}
.wa-msg img {
  width: 50px;
  height: 50px;
}

.email-marketing form input {
  color: #fff !important;
  background-color: transparent;
  border: 1px solid #fff;
  margin: 0 !important;
}
.email-marketing form input::-ms-input-placeholder { /* Edge 12-18 */
  color: #fff;
  text-transform: uppercase;
}

.email-marketing form input::placeholder {
  color: #fff;
  text-transform: uppercase;
}

/* .email-marketing form fieldset { position: relative; }
.email-marketing form .button {
  position: absolute;
  bottom: 0;
  right: 0;
  margin: 0;
  height: 100%;
  width: 50px;
}
.email-marketing form button {
  position: relative;
  font-size: 0;
  height: 100%;
  width: 100%;
  background: #fff;
} */
.email-marketing form button {
  position: relative;
  padding-right: 35px;
  border-radius: 10px;
  font-weight: 600;
  color: #000;
}
.email-marketing form button[disabled] {
  background: #f1f1f1;
  color: #555;
}
.email-marketing form button:before {
  content: '';
  display: block;
  /* width: 15px;
  height: 15px;
  background: #000; */
  position: absolute;
  right: 15px;
  top: 50%;
  transform: translate(0, -50%);
  border-top: 6px solid transparent;
  border-right: 0px solid transparent;
  border-bottom: 6px solid transparent;
  border-left: 10px solid #020168;
}
.email-marketing form button[disabled]:before {
  border-left: 10px solid #555555;
}

/* CTA */
.primary-cta, .primary-sub-cta a, form .wpcf7-submit {
  display: inline-block;
  text-decoration: none;
  text-transform: uppercase;
  background-color: #C12029;
  color: #ffffff !important;
  border-radius: 10px;
  padding: 8px 15px !important;
  font-weight: 600;
}

.primary-cta:hover, .primary-sub-cta a:hover {
  text-decoration: none !important;
}

.secondary-cta, .secondary-cta a {
  display: block;
  text-decoration: underline;
  text-transform: uppercase;
  background-color: #fff;
  color: #C12029 !important;
  border-radius: 10px;
  padding: 0px !important;
  margin-left: 0px;
  font-weight: 600;
}

.secondary-cta:hover, .secondary-cta a:hover {
  text-decoration: none !important;
}

form .wpcf7-submit {
  padding: 15px 20px !important;
}

/* Hero Section */
.hero-banner { text-align: center; padding: 30px 0; }
.hero-section-container picture { display: block; }
.hero-section-container picture img, .hero-section-container img { width: 100%; object-fit: cover; }
.hero-heading { margin-bottom: 0; color: #FFF0E1; }
.hero-banner {
  display: flex;
  flex-flow: column nowrap;
  justify-content: center;
  background: #C12029;
  color: #FFF0E1;
}
.hero-banner.content-flipped { flex-flow: column-reverse nowrap; }
.hero-banner.content-flipped .hero-heading { margin-top: 30px; }
.hero-text { margin-top: 15px; }
.hero-tagline {
  display: block;
  text-align: center;
  color: #020168;
  font-size: 14px;
  font-weight: 600;
  padding: 10px 15px;
  letter-spacing: 6px;
  line-height: 1.8;
}
.hero-dwnld-section {
  padding: 30px 0;
}
.hero-dwnld-section h2 {
  font-size: 16px;
  font-weight: 600;
}
.hero-dwnld-btns {
  display: flex;
  justify-content: center;
  margin-top: 15px;
  gap: 30px;
}

/* CTA 2 Col */
.module-full-bleed-title {
  margin-bottom: 15px;
  text-align: center;
}
.module-full-bleed {
  padding: 60px 0;
}
.cta-2-col-wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-flow: row wrap;
}
.cta-2-col-flipped {
  flex-flow: row-reverse wrap;
}
.cta-2-col-head { padding-bottom: 15px; }

.cta-2-col-image, .img-2-col-image {
  flex: 0 1 auto;
  max-width: 100%;
  overflow: hidden;
  padding: 0 15px;
}

.img-2-col-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-flow: row wrap;
}
.img-2-col-image {
  padding: 15px;
}
.img-2-col-section {
  padding: 15px 0;
}

@supports (object-fit: cover) {
  .cta-2-col-image img {
    height: 100%;
    object-fit: cover;
  }
}

.cta-2-col-text {
  flex: 1 1 0px;
  padding: 30px;
  text-align: center;
  align-self: center;
}

.cta-2-col-text strong, .cta-2-col-text b {
  font-weight: 500;
}

.cta-2-col-text h2, .cta-2-col-text p {
  color: #0000000;
}

.cta-2-col-text.text-start .module-cta {
  justify-content: start;
}

.cta-2-col-wrap .module-heading { font-size: 24px; margin-bottom: 15px; }

.cta-2-col-promo {
  /* background: #99D9D8; */
  padding: 0;
}
.cta-2-col-promo {
  background: #FFF0E1;
}
.cta-2-col-promo .cta-2-col-image, .cta-2-col-promo .cta-2-col-section {
  padding: 0 !important;
}
.cta-2-col-promo .cta-2-col-head {
  padding-top: 45px;
}

.cta-2-col-bg-section {
  background-color: #FFF0E1;
}

.module-cta {
  display: flex;
  gap: 20px;
  align-items: center;
  justify-content: center;
  flex-flow: column nowrap;
}

/* CTA 2 Col Silder */
ul.cta-2-col-slider-dots {
  list-style: none;
  padding-left: 0;
  margin: 10px 0;
  text-align: center;
}
ul.cta-2-col-slider-dots li {
  display: inline-block;
  margin: 0 5px;
}
ul.cta-2-col-slider-dots li button {
  font-size: 0;
  line-height: 0;
  display: block;
  width: 15px;
  height: 15px;
  cursor: pointer;
  border-radius: 100%;
  background: #D9D9D9;
  border: none;
}
ul.cta-2-col-slider-dots li.slick-active button {
  background: #C12029;
}

/* Featured Menus */
.feat-menu-section-title h2 {
  font-weight: 600;
  font-size: 24px;
  margin-bottom: 50px;
}
.feat-menus-list {
  display: flex;
  flex-flow: row wrap;
  gap: 40px 0;
}
.feat-menu-item { text-align: center; }
.feat-menu-item a {
  display: block;
  text-decoration: none;
  color: #000000;
}
.feat-menu-item a:hover {
  text-decoration: none;
  color: #000000;
}
.feat-menu-item-name {
  display: inline-block;
  line-height: 1.4;
  font-weight: 500;
  font-size: 16px;
  color: #AA010A;
  margin-top: 20px;
  margin-bottom: 0;
  text-transform: uppercase;
  text-decoration: underline;
}

/* Rewards Page */
.reward-benefits-list {
  display: flex;
  flex-flow: row wrap;
}
.reward-benefits-list .reward-benefit-item:not(:last-child) {
  margin-bottom: 15px;
}
.reward-benefit-item {
  text-align: center;
}
.reward-benefit-item img {
  margin-bottom: 20px;
}
.reward-benefit-name {
  font-size: 18px;
  font-weight: 600;
  color: #020168;
  margin-bottom: 15px;
}
.reward-benefit-text, .reward-benefit-text p {
  font-size: 16px;
  color: #020168;
}
.reward-points-levels-list {
  margin-bottom: 15px;
}
.reward-points-level-item {
  display: flex;
  flex-flow: row nowrap;
  font-size: 24px;
  justify-content: center;
}
.reward-points-level-item > div {
  padding: 10px 5px;
  color: #020168;
  background-color: #ffffff;
  align-content: center;
  font-size: 16px;
  margin: 3px;
}
.rewards-points { text-align: center; font-weight: 600; }
.reward-points-level-item .rewards-points-text {
  text-align: left;
  padding: 5px 10px;
}
.cta-2-col-rewards .module-heading { font-size: 21px; text-transform: capitalize; }
.cta-2-col-rewards .cta-2-col-text {
  padding: 0;
}
.cta-2-col-rewards .cta-2-col-wrap {
  gap: 60px;
}
.reward-points-level-one > div { background-color: #B7F3F2; }
.reward-points-level-two > div { background-color: #D0FFFE; }
.reward-points-level-three > div { background-color: #DEFFFE; }
.reward-points-level-four > div { background-color: #F5FFFF; }
.reward-points-level-five > div { background-color: #FFFFFF; }

/* Contact */
.contact-content .contact-social-section a img {
  filter: brightness(1) invert(1);
}
.contact-content p { font-size: 16px; margin-bottom: 10px; }
.contact-content .contact-heading-loc { font-weight: 600; }
.contact-heading { font-weight: 700; }
.contact-details a {
  color: #000000;
}
.contact-content iframe, .contact-content .contact-number { margin-bottom: 25px; }

/* Contact Form */
form input[type="text"], form input[type="email"], form input[type="tel"], form textarea {
  width: 100%;
  margin-top: 5px;
  padding: 10px;
  border-radius: 0;
}

/* Menu Pages */
.template-menu-wrapper {
  background-color: #FFFCF7;
}
.hero-banner-cafe-menu .cafe-menu-icon { margin-bottom: 15px; }
.hero-banner-cafe-menu .hero-text { font-style: italic; font-weight: 500; }
.menu-block-heading { text-align: center; padding-bottom: 30px; }
.menu-block-heading h2 {
  font-size: 32px;
  font-weight: 700;
  color: #C12129;
  margin-top: 0;
  margin-bottom: 10px;
}
.menu-block-heading p {
  font-family: 'Times New Roman', Times, serif;
  font-size: 28px;
  font-style: italic;
  color: #000000;
  line-height: 1.2;
  margin-bottom: 20px;
}
.menu-block-heading img {
  height: 80px;
  width: 100%;
  object-fit: cover;
  object-position: center;
}
.menu-block .menu-block-item:not(:last-child) { padding-bottom: 30px; }
.cafe-menu-item { margin-bottom: 20px; }
.cafe-menu-item .menu-name { color: #000000;}
.cafe-menu-item p {
  font-family: "Tinos", serif;
  font-weight: 400;
  font-style: italic;
  font-size: 20px;
  line-height: 1.4;
  color: #555555;
  margin-bottom: 10px;
}
.menu-desc { color: #555555; }
.menu-item-price {
  font-size: 24px;
  font-weight: 600;
  color: #000000;
}
.menu-item-servings {
  display: inline-block;
  font-weight: 600;
  font-size: 13px;
  color: #B59B7F;
}
.menu-item-info { text-align: right; }

/* Gallery Page */
.gallery-page-grid {
  display: -ms-flexbox; /* IE10 */
  display: flex;
  -ms-flex-wrap: wrap; /* IE10 */
  flex-wrap: wrap;
  justify-content: space-between;
}
.gallery-grid-col {
  -ms-flex: 100%; /* IE10 */
  flex: 100%;
  max-width: 100%;
}
.gallery-grid-item {
  margin-bottom: 30px;
}
.gallery-grid-item img {
  width: 100%;
}
.gallery-grid-item p {
  padding-top: 5px;
  font-weight: 600;
}

.wpcf7 form label { font-size: 16px; }

.social-section-title h2 {
  text-align: center;
  font-size: 24px;
  font-weight: 600;
  margin-bottom: 0;
}
.social-section-title { padding-bottom: 30px; }

.sbi_inner_wrap p, .sbi_inner_wrap span {
  color: #ffffff !important;
}

@media screen and (max-width: 767px) {
  .hero-tagline span { display: block; }
  .cta-2-col-text {
    padding-bottom: 0;
  }
  .cta-2-col-promo .cta-2-col-section {
    padding: 0;
    padding-bottom: 30px !important;
  }
  .feat-menu-item { padding: 0 20px; width: 50%; }
  .cta-2-col-rewards .cta-2-col-promo .cta-2-col-section { padding-bottom: 0 !important; }
  .cta-2-col-rewards .cta-2-col-wrap, .cta-2-col-rewards .cta-2-col-flipped { flex-flow: column-reverse nowrap; }
  .reward-points-level-item > div { line-height: 1.3; }
  .cta-2-col-rewards .module-cta { flex-flow: row wrap; }
  .contact-content { padding-bottom: 45px; }
  .menu-item-servings { font-size: 12px; }
}

@media screen and (min-width: 768px) {
  .navbar-brand img { width: 165px; }
  .cta-2-col-image {
    padding: 0;
    width: 50%;
    align-self: center;
    padding-left: 30px;
  }
  .cta-2-col-flipped .cta-2-col-image {
    padding: 0;
    padding-right: 30px;
  }
  /* .cta-2-col-wrap .module-heading { font-size: 22px; } */
  .module-cta { flex-flow: row wrap; }
  /* .cta-2-col-promo { padding: 30px 0; } */
  .feat-menus-list { flex-flow: row nowrap; gap: 40px; }
  .feat-menu-item { flex: 1; }
  .contact-content { padding-right: 15px; }
  .contact-section div.wpcf7 { padding-left: 15px; }
  .cta-2-col-rewards .cta-2-col-image { width: 35%; }
  .menu-item-price { font-size: 24px; }
  .secondary-cta, .secondary-cta a {
    display: inline-block;
    margin-left: 30px;
  }
  .menu-block-heading { padding: 0 30px 30px 30px; }
  .menu-block-heading img { height: 140px; }
  .gallery-grid-col {
    -ms-flex: 30%; /* IE10 */
    flex: 30%;
    max-width: 30%;
  }
  .gallery-grid-item p { font-size: 18px; }
  .reward-benefit-name { font-size: 24px; }
  .cta-2-col-rewards .module-heading { font-size: 24px; }
  .wpcf7 form label { font-size: 18px; }
  .contact-content p { font-size: 18px; }
}

/* Portrait and Landscape */
@media only screen 
  and (min-device-width: 768px) 
  and (max-device-width: 1024px)
  and (orientation: portrait)
  and (-webkit-min-device-pixel-ratio: 1) {
  .cta-2-col-rewards .cta-2-col-image { width: 40%; }
  .reward-points-level-item > div, .cta-2-col-rewards .module-heading { font-size: 16px; }
  .cta-2-col-rewards .cta-2-col-wrap { gap: 30px; }
}
@media only screen 
  and (min-device-width: 768px) 
  and (max-device-width: 1024px)
  and (orientation: landscape)
  and (-webkit-min-device-pixel-ratio: 1) {
  .cta-2-col-rewards .cta-2-col-image { width: 35%; }
  .reward-points-level-item > div, .cta-2-col-rewards .module-heading { font-size: 18px; }
}

@media (min-width: 992px) {
  .header-nav-container .menu-menu-1-container { padding: 0; }
  .navbar-expand-lg .header-nav {
      flex-direction: row;
  }
  .menu-icon-container { display: none; }
  .menu-item ul.sub-menu {
    display: none;
    position: absolute;
    top: 100%;
    left: -15px;
    margin: 0;
    width: max-content;
    padding: 10px 0;
  }
  .menu-item ul.sub-menu li {
    text-align: left;
  }
  .menu-item ul.sub-menu li a {
    padding: 10px 15px;
  }
  .menu-item.menu-item-has-children:hover > ul.sub-menu  {
    display: block;
  }
  .menu-item.menu-arrow > a:after { right: 0; }
  .hero-tagline {
    font-size: 16px;
    letter-spacing: 8px;
  }
  .cta-2-col-text {
    padding: 30px 60px;
  }
  .reward-benefits-section .reward-benefits-list .reward-benefit-item { margin-bottom: 0; }
  .cafe-menu-list .cafe-menu-item { padding-right: 45px; padding-left: 45px; }
}

@media screen and (min-width: 1200px) {
  .cta-2-col-text {
    padding: 30px 75px;
  }
  .reward-points-level-item > div {
    font-size: 24px;
  }
}