html {
  overflow: hidden;
  overflow-y: auto;
  overflow-x: hidden;
  position: relative;
}
@media (max-width: 1023px) {
  html.show-modal {
    overflow: hidden;
  }
}

.button {
  padding: 10px 30px;
  border-radius: 20px;
  display: inline-block;
  background: #62b622;
  color: #ffffff;
  font-weight: 600;
  border: 1px solid rgba(0, 0, 0, 0.1803921569);
  box-shadow: 2px 2px 2px 0px rgba(0, 0, 0, 0.1607843137);
}
.button.red {
  background-color: #aa1616;
  color: #fff;
}
.button.dark {
  background-color: #232323;
  color: #fff;
}
.button.bordered {
  border: 3px solid #62b622;
  font-weight: 500;
  background-color: transparent;
  color: #62b622;
  text-transform: uppercase;
  font-size: 16px;
}

html, body {
  padding: 0;
  margin: 0;
  display: block;
  flex-direction: column;
  font-size: 16px;
  font-weight: 300;
  line-height: 1.5;
  min-height: 100%;
  color: #333333;
  flex: 1;
  min-width: 100vw;
  max-width: 100vw;
  width: 100vw;
  width: -webkit-fill-available;
  opacity: 1 !important;
  transition: opacity 0ms ease 0ms;
}
@media (max-width: 1023px) {
  html, body {
    font-size: 13px;
  }
}
@media (min-width: 1024px) {
  html, body {
    font-size: 14px;
  }
}
html.chat-mode, body.chat-mode {
  height: 100%;
}

html body {
  position: fixed;
  position: relative;
  min-width: 100vw;
  max-width: 100vw;
}

.app-wrap {
  max-width: 100%;
  width: 100%;
  flex: 1;
  position: relative;
  min-height: 100%;
  overflow: visible;
  display: flex;
  flex-direction: column;
}
@media (max-width: 1023px) {
  .app-wrap main {
    flex: 3;
  }
}

html, body, input, select, textarea {
  font-family: "Outfit", Verdana;
}

a {
  text-decoration: none;
  color: inherit;
}
h1, h2, h3, h4, h5, h6 {
  padding: 0;
  margin: 0;
  width: 100%;
  text-align: left;
  line-height: normal;
  font-size: inherit;
  font-weight: inherit;
}

html, body {
  background-color: #2d6105;
  color: #ffffff;
}

main {
  color: #ffffff;
}
main .frame-main {
  background-color: #2d6105;
}
.user-unverified .hide-user-not-verified {
  display: none !important;
}

.user-verified .hide-user-verified {
  display: none !important;
}
.user-verified .hide-user-not-verified.flex {
  display: flex;
}

.lock-top {
  transform: translate3d(0, 0, 0);
  position: -webkit-sticky;
  position: sticky;
  z-index: 7;
  top: -1px;
  transition: transform 250ms ease-out, top 250ms ease-out;
}
@media (max-width: 1023px) {
  .lock-top {
    top: 105px;
  }
}
@media (max-width: 1023px) and (max-width: 1023px) {
  .lock-top {
    top: 105px;
    background-color: #e7e7e7;
  }
}
@media (min-width: 1024px) {
  .lock-top {
    top: 130px;
  }
}
.lock-top-observer {
  position: relative;
  height: 1px;
  pointer-events: none;
  opacity: 0;
  width: 100%;
  margin-top: -1px;
}
@media (max-width: 1023px) {
  .lock-top-observer {
    transform: translateY(-105px);
  }
}
@media (max-width: 1023px) and (max-width: 1023px) {
  .lock-top-observer {
    transform: translateY(0px);
  }
}
@media (min-width: 1024px) {
  .lock-top-observer {
    transform: translateY(-130px);
  }
}
.endless {
  transform: translate3d(0, 0, 0);
  user-drag: none;
  user-select: none;
  -webkit-user-drag: none;
  -webkit-user-select: none;
}
.endless img {
  pointer-events: none;
}
.endless a {
  user-drag: none;
  user-select: none;
  -webkit-user-drag: none;
  -webkit-user-select: none;
  -webkit-touch-callout: none;
}
.endless:hover > .controls .previous, .endless:hover > .controls .next {
  opacity: 1;
}
.endless:hover > .controls .previous:hover, .endless:hover > .controls .next:hover {
  opacity: 0.8;
}
.endless > .controls {
  position: absolute;
  bottom: 30px;
  right: 30px;
  font-size: 30px;
  color: #eee;
  z-index: 5;
  display: flex;
}
@media (max-width: 1023px) {
  .endless > .controls {
    display: none;
  }
}
.endless > .controls .previous, .endless > .controls .next {
  padding: 0 0px;
  line-height: 0;
  border-bottom: 1px solid #eee;
  border-right: 1px solid #eee;
  cursor: pointer;
  transition: all 150ms ease;
  opacity: 0;
}
@media (max-width: 1023px) {
  .endless > .controls .previous, .endless > .controls .next {
    height: 20px;
    width: 20px;
  }
}
@media (min-width: 1024px) {
  .endless > .controls .previous, .endless > .controls .next {
    height: 20px;
    width: 20px;
  }
}
.endless > .controls .previous:hover, .endless > .controls .next:hover {
  opacity: 0.8;
}
.endless > .controls .previous i, .endless > .controls .next i {
  display: none;
}
.endless > .controls .next {
  margin-left: 5px;
  transform: rotate(-45deg);
}
.endless > .controls .previous {
  transform: rotate(-225deg);
}
.endless > ul {
  width: 100%;
  list-style-type: none;
  margin: 0;
  padding: 0;
  display: flex;
  position: relative;
  z-index: 1;
  overflow: auto;
}
.endless > ul li {
  cursor: grab;
  margin: 0;
  padding: 0;
}
.endless [endless-disable-desktop=true] li {
  cursor: default;
}

.remove-me {
  pointer-events: none !important;
}

strong {
  font-weight: 600;
}

* {
  box-sizing: border-box;
  outline: none;
  text-rendering: auto;
  outline: 0;
  scrollbar-width: none;
  -ms-overflow-style: none;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-overflow-scrolling: touch;
}
@media (max-width: 1024px) {
  * {
    -webkit-user-select: none;
  }
}

*::-webkit-scrollbar {
  display: none;
}

input, textarea {
  -webkit-user-select: text;
  resize: none;
}

input::placeholder, textarea::placeholder {
  font-style: normal;
  color: #222;
  font-weight: 300;
}

img {
  width: 100%;
  color: transparent;
  user-drag: none;
  user-select: none;
  -webkit-user-drag: none;
  -webkit-user-select: none;
  -webkit-touch-callout: none;
}

.container {
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  width: 100%;
  opacity: 1;
  transform: translateY(0px);
  transition: transform 200ms ease, opacity 300ms ease;
}
.loading .container {
  transform: translateY(10px);
  transition: none;
  opacity: 0;
}

.edit-mode .ui-sortable-helper.section-space {
  padding: 25px;
  border-top: 0;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 9999;
  padding: 25px;
  border-top: 0;
  background-color: #fff;
  width: 100%;
  overflow: hidden;
}
.section-border .edit-mode .ui-sortable-helper.section-space {
  border: 15px solid rgba(0, 0, 0, 0.0666666667);
  border-top: 0;
}
.section-border .edit-mode .ui-sortable-helper.section-space:first-child, .section-border .edit-mode .ui-sortable-helper.section-space.first {
  border: 15px solid rgba(0, 0, 0, 0.0666666667);
}
.edit-mode .ui-sortable-helper.section-space h2.section-title {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  padding-bottom: 20px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.0666666667);
  width: 100%;
  text-transform: capitalize;
  letter-spacing: 0.5px;
  position: relative;
  font-weight: 800;
  font-size: 150%;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}
.edit-mode .ui-sortable-helper.section-space h2.section-title .view-all {
  white-space: nowrap;
  font-weight: 300;
  font-size: 14px;
  text-decoration: underline;
}
.edit-mode .ui-sortable-helper.section-space h2.section-title:before {
  content: "";
  position: absolute;
  bottom: 0px;
  height: 2px;
  width: 250px;
  left: 0;
  background-color: #62b622;
}
.edit-mode .ui-sortable-helper.section-space.wrapper {
  flex-direction: column;
}

.app-wrap .contained .section-space .banner-image {
  display: flex;
}
.app-wrap .contained .section-space h2.section-title {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}
.app-wrap .contained .section-space h2.section-title .view-all {
  white-space: nowrap;
  font-weight: 300;
  font-size: 14px;
  text-decoration: underline;
}
.app-wrap .contained .section-space h2.section-title .view-all:hover {
  text-decoration: none;
}
@media (min-width: 1024px) {
  .app-wrap .contained {
    background-color: #fff;
  }
  .app-wrap .contained .section-space {
    padding: 25px;
    border-top: 0;
  }
  .section-border .app-wrap .contained .section-space {
    border: 15px solid rgba(0, 0, 0, 0.0666666667);
    border-top: 0;
  }
  .section-border .app-wrap .contained .section-space:first-child, .section-border .app-wrap .contained .section-space.first {
    border: 15px solid rgba(0, 0, 0, 0.0666666667);
  }
  .app-wrap .contained .section-space h2.section-title {
    padding-bottom: 20px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.0666666667);
    width: 100%;
    text-transform: capitalize;
    letter-spacing: 0.5px;
    position: relative;
    font-weight: 800;
    font-size: 150%;
  }
  .app-wrap .contained .section-space h2.section-title:before {
    content: "";
    position: absolute;
    bottom: 0px;
    height: 2px;
    width: 250px;
    left: 0;
    background-color: #62b622;
  }
  .app-wrap .contained .section-space.wrapper {
    flex-direction: column;
  }
  .app-wrap .contained .section-banner {
    padding: 0;
  }
}
@media (max-width: 1023px) {
  .app-wrap .stacked-frame .xlock-top.always-stacked, .app-wrap .overlay-frame .xlock-top.always-stacked {
    display: none;
  }
  .app-wrap .xlock-top.always-stacked section .highlight .items ul {
    background-color: transparent;
  }
  .app-wrap .xlock-top.always-stacked section .highlight .items ul li a {
    padding: 12.5px 0px 12.5px 15px;
    border: none;
  }
  .vibe-grid .app-wrap .xlock-top.always-stacked section .highlight .items ul li a {
    padding: 10px 10px 10px 10px;
  }
  .app-wrap .contained .section-shade {
    border-bottom: 5px solid #ececec;
  }
  .app-wrap .contained .section-categories {
    margin: 0;
  }
  .app-wrap .contained .section-categories ul {
    margin: 0;
    display: flex;
    padding: 0;
    list-style-type: none;
    flex-wrap: wrap;
    gap: 5px;
  }
  .app-wrap .contained .section-categories ul li {
    min-width: calc(33.4% - 5px);
    max-width: calc(33.6% - 5px);
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 90px;
    background-color: #eeeeee;
    flex-direction: column;
    font-weight: 600;
  }
  .app-wrap .contained .section-categories ul li .icon {
    position: relative;
    width: 40px;
    height: 40px;
    background-color: #62b622;
  }
  .app-wrap .contained .section-space h2.section-title {
    font-weight: 800;
    font-size: 125%;
    padding: 20px;
    position: relative;
  }
  .app-wrap .contained .always-stacked {
    gap: 15px;
  }
  .vibe-grid .app-wrap .contained .always-stacked {
    gap: 5px;
  }
  .app-wrap .contained .always-stacked .product-collections, .app-wrap .contained .always-stacked .product-collections.option-main {
    gap: 15px;
    padding: 15px;
    padding-bottom: 0;
    padding-top: 0;
    flex-direction: row;
    font-size: 18px;
  }
  .vibe-grid .app-wrap .contained .always-stacked .product-collections, .vibe-grid .app-wrap .contained .always-stacked .product-collections.option-main {
    padding: 0;
    gap: 5px;
  }
  .app-wrap .contained .always-stacked .product-collections .product-collection, .app-wrap .contained .always-stacked .product-collections.option-main .product-collection {
    min-width: calc(50% - 15px / 2);
    flex: 1;
    padding-top: 50%;
    position: relative;
    right: auto;
    left: auto;
  }
  .app-wrap .contained .always-stacked .product-collections .product-collection.home-redemptions-container, .app-wrap .contained .always-stacked .product-collections.option-main .product-collection.home-redemptions-container {
    min-width: 100%;
    width: 100%;
    order: 3;
    padding: 0;
  }
  .app-wrap .contained .always-stacked .product-collections .product-collection.home-redemptions-container > div, .app-wrap .contained .always-stacked .product-collections.option-main .product-collection.home-redemptions-container > div {
    height: 100%;
    width: 100%;
  }
}
@media (max-width: 1023px) and (max-width: 1023px) {
  .app-wrap .contained .always-stacked .product-collections .product-collection.home-redemptions-container, .app-wrap .contained .always-stacked .product-collections.option-main .product-collection.home-redemptions-container {
    order: 1;
  }
}
@media (max-width: 1023px) {
  .vibe-rounded .app-wrap .contained .always-stacked .product-collections .product-collection, .vibe-rounded .app-wrap .contained .always-stacked .product-collections.option-main .product-collection {
    border-radius: 10px;
  }
  .app-wrap .contained .always-stacked .product-collections .product-collection a, .app-wrap .contained .always-stacked .product-collections.option-main .product-collection a {
    padding: 15px 15px 15px 15px;
    font-size: inherit;
  }
  .app-wrap .contained .always-stacked .product-collections .product-collection:first-child, .app-wrap .contained .always-stacked .product-collections.option-main .product-collection:first-child {
    min-width: 100%;
  }
  .app-wrap .contained .always-stacked .product-collections .product-collection.mobile-height-100, .app-wrap .contained .always-stacked .product-collections.option-main .product-collection.mobile-height-100 {
    padding-top: 100%;
    min-width: 100%;
  }
  .app-wrap .contained .always-stacked .product-collections .product-collection.mobile-height-75, .app-wrap .contained .always-stacked .product-collections.option-main .product-collection.mobile-height-75 {
    padding-top: 75%;
    min-width: 100%;
  }
  .app-wrap .contained .always-stacked .product-collections .product-collection.mobile-height-60, .app-wrap .contained .always-stacked .product-collections.option-main .product-collection.mobile-height-60 {
    padding-top: 60%;
    min-width: 100%;
  }
  .app-wrap .contained .section-banner {
    padding: 0;
  }
}

.app-wrap .container.app-form {
  flex: 1;
  background-color: #ededed;
}
.app-wrap .container.app-form .contained {
  flex: 1;
  justify-content: flex-start;
  height: 100%;
  background-color: transparent;
}
.app-wrap .container.app-form .contained form {
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.app-wrap .container.app-form .contained form .icon-options {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  padding: 20px;
}
.app-wrap .container.app-form .contained form .icon-options label {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  width: auto;
  background-color: inherit;
  min-height: 0;
  line-height: normal;
  opacity: 0.3;
}
.app-wrap .container.app-form .contained form .icon-options label.active {
  opacity: 1;
}
.app-wrap .container.app-form .contained form .icon-options label.active .icon {
  background-color: #lightBackground;
  color: #lightColor;
}
.app-wrap .container.app-form .contained form .icon-options label .icon {
  font-size: 40px;
  border-radius: 100%;
  background-color: #777;
  color: #fff;
  width: 60px;
  height: 60px;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  overflow: hidden;
}
.app-wrap .container.app-form .contained form .group {
  border-bottom: 4px solid #ededed;
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.app-wrap .container.app-form .contained form label {
  display: flex;
  background-color: #fff;
  width: 100%;
  align-items: center;
  min-height: 40px;
  font-weight: 600;
}
.app-wrap .container.app-form .contained form label > div:first-child {
  min-width: 150px;
  padding: 0px 15px;
  opacity: 0.7;
  color: #555;
}
.app-wrap .container.app-form .contained form label > div:last-child {
  flex: 1;
}
.app-wrap .container.app-form .contained form label > div:last-child input[type=text], .app-wrap .container.app-form .contained form label > div:last-child input[type=tel], .app-wrap .container.app-form .contained form label > div:last-child input[type=email], .app-wrap .container.app-form .contained form label > div:last-child input[type=number], .app-wrap .container.app-form .contained form label > div:last-child select, .app-wrap .container.app-form .contained form label > div:last-child textarea {
  width: 100%;
  border: 0;
  padding: 15px 0px;
  margin: 0;
  height: 100%;
  font-weight: inherit;
}

.contained {
  width: 100%;
  text-align: left;
  position: relative;
  align-self: center;
}

@keyframes expand-bounce2 {
  0% {
    transform: scale(1);
  }
  20% {
    transform: scale(1.15);
  }
  100% {
    transform: scale(1);
  }
}
@keyframes expand-bounce {
  0% {
    transform: scale(0);
    height: 0;
    overflow: hidden;
  }
  70% {
    transform: scale(1.02);
    height: auto;
  }
  100% {
    transform: scale(1);
  }
}
.expand-bounce {
  animation: expand-bounce 700ms;
}

@keyframes fade-up {
  0% {
    transform: translateY(-100%);
    @media (min-width: 1024px) {
      transform: translateY(70px);
    }
  }
  100% {
    transform: translateY(-70px);
    opacity: 0;
    @media (min-width: 1024px) {
      transform: translateY(120px);
    }
  }
}
.expand-bounce2:before {
  content: "Cart Updated";
  animation: fade-up 2000ms forwards;
  position: absolute;
  transform: translateY(-20px);
  font-size: 12px;
  width: 30%;
  right: 0%;
  text-align: center;
  background-color: #dcf4ca;
  color: #2c5111;
  border-radius: 0px;
  padding: 7.5px 0;
  top: 0;
  right: 0px;
  pointer-events: none;
  transition: transform 300ms ease;
  z-index: 99;
}

@keyframes fade-in {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.fade-in {
  animation: fade-in 200ms forwards;
}

@keyframes fade-out {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
.fade-out {
  animation: fade-out 400ms forwards;
}

@keyframes spinner {
  to {
    transform: rotate(360deg);
  }
}
.loading {
  /*&:after {
      content: "";
      //background-color: #111;
      position: absolute;
      height: 100%;
      width: 100%;
      top: 0;
      opacity: 1;
      left: 0;	
      display: flex;
      justify-content: center;
      align-items: center;
      z-index: 2;
      opacity: 1;
  }*/
}
.loading.section-main > div, .loading .hide-loading > div {
  opacity: 0;
}
.loading:after {
  content: "";
  z-index: 3;
  box-sizing: border-box;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 40px;
  height: 40px;
  margin-left: -20px;
  border-radius: 50%;
  border-top: 2px solid #62b622;
  border-right: 2px solid transparent;
  animation: spinner 0.6s linear infinite;
}
.loading:after.inline {
  position: relative;
  width: 75px;
  height: 75px;
  display: inline-block;
  top: auto;
}

.dot-elastic {
  position: relative;
  display: inline-block;
  margin-left: 15px;
  width: 7.5px;
  height: 7.5px;
  border-radius: 5px;
  background-color: currentColor;
  animation: dot-elastic 1s infinite linear;
}

.dot-elastic::before, .dot-elastic::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 0;
}

.dot-elastic::before {
  left: -10px;
  width: 7.5px;
  height: 7.5px;
  border-radius: 5px;
  background-color: currentColor;
  animation: dot-elastic-before 1s infinite linear;
}

.dot-elastic::after {
  left: 10px;
  width: 7.5px;
  height: 7.5px;
  border-radius: 5px;
  background-color: currentColor;
  animation: dot-elastic-after 1s infinite linear;
}

@keyframes dot-elastic-before {
  0% {
    transform: scale(1, 1);
  }
  25% {
    transform: scale(1, 1.5);
  }
  50% {
    transform: scale(1, 0.67);
  }
  75% {
    transform: scale(1, 1);
  }
  100% {
    transform: scale(1, 1);
  }
}
@keyframes dot-elastic {
  0% {
    transform: scale(1, 1);
  }
  25% {
    transform: scale(1, 1);
  }
  50% {
    transform: scale(1, 1.5);
  }
  75% {
    transform: scale(1, 1);
  }
  100% {
    transform: scale(1, 1);
  }
}
@keyframes dot-elastic-after {
  0% {
    transform: scale(1, 1);
  }
  25% {
    transform: scale(1, 1);
  }
  50% {
    transform: scale(1, 0.67);
  }
  75% {
    transform: scale(1, 1.5);
  }
  100% {
    transform: scale(1, 1);
  }
}
.hide {
  display: none !important;
}

.hide-fade {
  opacity: 0 !important;
  pointer-events: none !important;
}

@media (max-width: 1023px) {
  .hide-mobile {
    display: none !important;
  }
}
@media (min-width: 1024px) {
  .hide-desktop {
    display: none !important;
  }
}
@media (max-width: 1023px) {
  .hide-portrait {
    display: none !important;
  }
}
@media (min-width: 1024px) {
  .hide-landscape {
    display: none !important;
  }
}
.glowColor {
  color: #2c5111;
}

.glowBackground {
  background-color: #dcf4ca;
}

.headerColor {
  color: #ffffff;
}

.headerBackground {
  background-color: #2d6105;
}

.glowColorAsBackground {
  background-color: #2c5111;
}

.glowBackgroundAsColor {
  color: #dcf4ca;
}

.highlightColor {
  color: #ffffff;
}

.highlightBackground {
  background-color: #62b622;
}

.highlightColorAsBackground {
  background-color: #ffffff;
}

.highlightBackgroundAsColor {
  color: #62b622;
}

.lightColor {
  color: #lightColor;
}

.lightBackground {
  background-color: #lightBackground;
}

.mainColor {
  color: #333333;
}

.mainBackground {
  background-color: #ffffff;
}

.lightColorAsBackground {
  background-color: #lightColor;
}

.lightBackgroundAsColor {
  color: #lightBackground;
}

/* Toggle variables so you can tweak size/colors quickly */
.switch__input {
  --w: 45px;
  /* overall width */
  --h: 25px;
  /* overall height */
  --pad: 0px;
  /* inner padding around the knob */
  --off: #2f2f2f;
  /* track color when OFF */
  --on: #f6b21a;
  /* track color when ON */
  --knob: #fff;
  /* knob color */
  --ring: 0 0 0 2px rgba(246, 178, 26, .35);
  /* focus ring */
  appearance: none;
  -webkit-appearance: none;
  width: var(--w);
  height: var(--h);
  border-radius: 999px;
  background: var(--off);
  border: 1px solid #111;
  border: 0;
  display: inline-block;
  position: relative;
  outline: none;
  cursor: pointer;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05), inset 0 -1px 0 rgba(0, 0, 0, 0.35);
  box-shadow: none;
  transition: background-color 0.18s linear, box-shadow 0.18s linear;
}

/* knob */
.switch__input::after {
  content: "";
  position: absolute;
  top: var(--pad);
  left: var(--pad);
  width: calc(var(--h) - var(--pad) * 2);
  height: calc(var(--h) - var(--pad) * 2);
  background: var(--knob);
  border-radius: 50%;
  transition: transform 0.22s cubic-bezier(0.22, 0.61, 0.36, 1);
  will-change: transform;
}

/* ON state */
.switch__input:checked {
  background: var(--on);
}

.switch__input:checked::after {
  transform: translateX(calc(var(--w) - var(--h)));
}

/* Focus + keyboard */
.switch__input:focus-visible {
  box-shadow: var(--ring);
}

/* Disabled */
.switch__input:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.cart-button-mobile {
  left: 0;
  margin: 0;
  border: 0;
  border-radius: 0;
  width: 100%;
  height: 40px;
  bottom: 40px;
  font-size: 22px;
  line-height: normal;
  transition: all 300ms ease;
  background-color: #dcf4ca;
  color: #2c5111;
  z-index: 26;
  position: fixed;
  display: flex;
  flex-direction: row;
  padding: 5px 15px 5px 15px;
  gap: 3px;
  align-items: center;
  justify-content: space-between;
  font-size: 15px;
  font-weight: 400;
  background-color: rgba(0, 0, 0, 0.6);
  color: #fff;
  opacity: 0;
  pointer-events: none;
  backdrop-filter: blur(20px);
  left: 20px;
  height: 70px;
  width: 70px;
  border-radius: 100%;
  display: flex;
  flex-direction: column;
  padding: 12px;
  font-size: 12px;
  transform: translateY(20px);
  transition: transform 100ms ease 10ms;
}
.cart-button-mobile .cart-message {
  flex: 1;
  display: none;
}
.cart-button-mobile .cart-total {
  /*color: $glowColor;
  background-color: $glowBackground;
  //color: #000;
  //background-color: #fff;
  padding: 5px 10px;
  border-radius: 5px;
  border: 1px solid #00000033;
  */
}
.cart-button-mobile .chevron {
  max-width: 20px;
  margin-left: 10px;
  display: none;
}
.active-cart .cart-button-mobile {
  bottom: 100px;
  box-shadow: 0px 0px 0px 1px rgba(0, 0, 0, 0.0705882353);
  opacity: 1;
  pointer-events: all;
}
.app-mode .cart-button-mobile {
  transform: translateY(0px);
}
.active-cart .app-mode .cart-button-mobile {
  bottom: 80px;
}
.scrolled-down-percise .cart-button-mobile {
  transform: translateY(0px);
}
@media (min-width: 1024px) {
  .cart-button-mobile {
    display: none;
  }
}

.cart-item-count {
  position: absolute;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  background-color: #dcf4ca;
  top: 11px;
  right: 10px;
  color: #2c5111;
  border-radius: 100%;
  transition: all 300ms ease;
  font-size: 12px;
  font-weight: 500;
  border: 1px solid #2c5111;
}

.points-button-mobile {
  display: flex;
  display: none;
  flex-direction: column;
  gap: 3px;
  align-items: center;
  justify-content: center;
  bottom: 10px;
  right: 15px;
  width: 75px;
  height: 65px;
  border: 0;
  border-radius: 10px;
  z-index: 4;
  position: fixed;
  background-color: #313131;
  color: #ccc;
  border: 3px solid #darkBackground;
  font-size: 22px;
  line-height: normal;
  transition: all 300ms ease;
  background-color: #62b622;
  color: #ffffff;
  border: 3px solid #darkBackground;
  /*&:before {
      content: "";
      background-color: #000;
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      border-radius: 100%;
      opacity: 0;
      z-index: -1;
      pointer-events: none;
      transition: all 300ms ease;
  }*/
}
.points-button-mobile .points-total {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  line-height: 16px;
  gap: 2px;
  font-size: 14px;
}
.points-button-mobile .points-total .user-points {
  font-size: 16px;
  font-weight: 600;
}
.points-button-mobile .points-label {
  font-size: 14px;
  font-weight: 400;
}
.points-button-mobile .points-total {
  font-size: 12px;
  font-weight: 500;
}
@media (min-width: 1024px) {
  .points-button-mobile {
    display: none;
  }
}
.points-button-mobile .points-item-count {
  position: absolute;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  background-color: #62b622;
  top: 11px;
  right: 10px;
  color: #ffffff;
  border-radius: 100%;
  transition: all 300ms ease;
  font-size: 12px;
  font-weight: 500;
  border: 1px solid #ffffff;
}
.show-modal .points-button-mobile {
  /*@media(max-width: 1023px) {
      transition: all 300ms ease, bottom 300ms ease 300ms, right 300ms ease 300ms, border 300ms ease 300ms, background-color 300ms ease 300ms, color 300ms ease 300ms;
      bottom: 5px;
      right: 5px;
      //border-color: transparent;
      border-width: 1px;
      //background-color:#00000022;
      background-color:$glowBackground;
      color: $glowColor;
      &:before {
          opacity: .5;
      }
  }*/
}

header.container {
  position: fixed;
  display: flex;
  z-index: 4;
  background: #2d6105;
  color: #ffffff;
  transition: transform 250ms ease-out, top 250ms ease-out;
  left: 0;
  top: 0;
  overscroll-behavior: none;
}
header.container a {
  height: 100%;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 15px 10px;
}
@media (min-width: 1024px) {
  header.container a {
    padding: 7.5px 0px;
  }
}
header.container a img {
  height: 100%;
  object-fit: contain;
}
@media (min-width: 1024px) {
  header.container a img {
    object-position: left;
  }
}
@media (max-width: 1023px) and (max-width: 1023px) {
  header.container {
    display: none;
  }
}
@media (max-width: 1023px) {
  header.container {
    height: 0px;
    width: 100%;
  }
}
@media (min-width: 1024px) {
  header.container {
    height: 80px;
    width: 100px;
    padding: 7.5px 10px 7.5px 30px;
    display: none;
  }
}
header.container h1 {
  text-align: center;
  font-weight: 600;
}

.microphone-enabled .enable-microphone {
  display: none;
}

.disable-microphone {
  display: none;
  color: #ff0000;
}
.microphone-enabled .disable-microphone {
  display: flex;
}

.header-lbl {
  font-size: 11px;
  text-transform: uppercase;
  color: #dcf4ca;
}
.header-lbl.active {
  color: #dcf4ca;
  font-weight: 600;
}
.header-lbl.inactive {
  color: inherit;
}

.sub-header {
  position: fixed;
  display: flex;
  z-index: 3;
  background: #dcf4ca;
  color: #2c5111;
  transition: transform 250ms ease-out, top 250ms ease-out, background-color 250ms ease-out;
  left: 0;
  width: 100%;
  overscroll-behavior: none;
  background-color: transparent;
  backdrop-filter: blur(20px);
}
@media (min-width: 1024px) {
  .sub-header {
    color: #111;
    background-color: #fff;
    background: transparent;
    background-color: rgba(255, 255, 255, 0.8666666667);
    backdrop-filter: blur(10px);
    position: absolute;
  }
  .sub-header:before {
    content: "";
    z-index: 0;
    top: 0;
    left: 0;
    position: absolute;
    width: 100%;
    height: 100%;
    pointer-events: none;
  }
}
.sub-header .opening-column {
  display: none;
  min-width: 85px;
  max-width: 85px;
  height: 100%;
  align-items: center;
  justify-content: flex-end;
  padding-right: 10px;
  position: relative;
  z-index: 3;
}
@media (max-width: 1023px) {
  .sub-header .opening-column {
    justify-content: center;
    min-width: 115px;
    max-width: 115px;
  }
}
.no-nav .sub-header .opening-column {
  justify-content: flex-start;
  max-width: 50px;
  min-width: 50px;
  padding-left: 5px;
}
.sub-header .opening-column a {
  display: flex;
}
.sub-header .opening-column a img {
  object-fit: contain;
  max-width: 100px;
  height: 35px;
}
@media (max-width: 1023px) {
  .floating-header .sub-header {
    background-color: transparent;
    transition: all 250ms ease;
  }
  .floating-header.not-top .sub-header {
    background-color: #dcf4cacc;
    backdrop-filter: blur(10px);
  }
  .sub-header .opening-column {
    display: flex;
    justify-content: flex-start;
    max-width: 50px;
    min-width: 50px;
    padding-left: 5px;
    margin-left: 35px;
  }
  .no-nav .sub-header .opening-column {
    margin-left: 0;
  }
  .sub-header .rewards-points {
    width: calc(100% - 140px);
  }
  .sub-header .header-part {
    min-width: 60px;
    max-width: 60px;
  }
}
.sub-header .header-part {
  border-left: 1px solid #2c511111;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px 20px;
  margin-left: 10px;
  z-index: 5;
}
@media (max-width: 1023px) {
  .sub-header .header-part {
    border-left: 0px solid #000;
    border-radius: 10px;
  }
}
@media (min-width: 1024px) {
  .sub-header .header-part {
    padding: 0px 10px;
  }
  .sub-header .header-part .header-links {
    height: 100%;
    width: 100%;
    display: flex;
    white-space: nowrap;
    gap: 2px;
  }
  .sub-header .header-part a {
    transition: all 300ms ease;
    height: 100%;
    align-items: center;
    justify-content: center;
    display: flex;
    padding: 5px 10px;
    align-self: center;
    height: auto;
    border-radius: 0px;
    margin: 0px 2px 0 0;
    border-radius: 20px;
  }
  .sub-header .header-part a img {
    display: none;
  }
  .vibe-rounded .sub-header .header-part a {
    border-radius: 20px;
  }
  .sub-header .header-part a i {
    margin-right: 5px;
    font-size: 16px;
  }
  .sub-header .header-part a.bolder {
    font-weight: 600;
    flex: 0;
  }
  .sub-header .header-part a.active {
    background-color: #lightBackground;
    color: #lightColor;
    box-shadow: 2px 2px 2px 0px rgba(0, 0, 0, 0.1607843137);
  }
  .sub-header .header-part .sep {
    border-right: 1px solid rgba(0, 0, 0, 0.3333333333);
    padding-right: 15px;
    margin-right: 15px;
    align-self: center;
    height: 20px;
    display: none;
  }
}
.sub-header .rewards-points {
  display: none;
}
@media (min-width: 1024px) {
  .sub-header .rewards-points {
    font-weight: 900;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0px 20px;
    white-space: nowrap;
    display: flex;
    gap: 5px;
    z-index: 2;
  }
  .sub-header .rewards-points i {
    color: #lightBackground;
  }
}
.sub-header .search {
  position: relative;
  width: 100%;
}
@media (min-width: 1024px) {
  .sub-header .search {
    border: 1px solid rgba(0, 0, 0, 0.0705882353);
    border-bottom: 0;
    border-top: 0;
  }
}
.sub-header .search .icon {
  position: absolute;
  left: 0;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 60px;
  height: 100%;
  pointer-events: none;
  color: #ffffff;
  font-size: 110%;
  padding: 0 0%;
  opacity: 1;
}
.sub-header .search .icon.submit {
  pointer-events: all;
}
@media (max-width: 1023px) {
  .sub-header .search .icon {
    right: 3.5px;
    left: auto;
    background-color: #62b622;
    color: #ffffff;
    border-radius: 10px;
    width: 30px;
    height: 30px;
    top: 8.5px;
    font-size: 14px;
  }
}
@media (min-width: 1024px) {
  .sub-header .search .icon {
    color: inherit;
    color: #62b622;
  }
}
.sub-header .search .clear {
  position: absolute;
  right: 35px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 100%;
  cursor: pointer;
  opacity: 0;
  transition: all 300ms ease;
}
.sub-header input {
  padding: 10px;
  margin: 0;
  border: 0;
  position: relative;
  z-index: 1;
  height: 100%;
  padding-left: 55px;
  width: 100%;
  font-weight: 600;
  font-size: 100%;
  background-color: transparent;
  color: #2c5111;
}
.sub-header input::placeholder {
  color: #2c5111;
  font-weight: 400;
}
@media (max-width: 1023px) {
  .sub-header input {
    padding: 10px;
  }
}
@media (min-width: 1024px) {
  .sub-header input {
    color: inherit;
  }
  .sub-header input::placeholder {
    color: inherit;
  }
}
@media (max-width: 1023px) {
  .sub-header {
    top: 0px;
    height: 65px;
    width: 100%;
    padding: 10px;
  }
}
@media (max-width: 1023px) and (max-width: 1023px) and (max-width: 1023px) {
  .sub-header {
    top: 0px;
  }
}
@media (max-width: 1023px) {
  .sub-header .search {
    position: absolute;
    width: 100%;
    bottom: -40px;
    left: 0;
    height: 40px;
  }
  .sub-header .search input {
    width: 100%;
    border-radius: 0;
    border: 0;
    padding: 10px 15px 10px 40px;
    margin: 0;
    height: 40px;
    border-bottom: 1px solid #e4e4e4;
  }
  .sub-header .search .icon {
    position: absolute;
    left: 0;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 70px;
    height: 100%;
    pointer-events: none;
    color: #ffffff;
    font-size: 110%;
    padding: 0 0%;
    opacity: 1;
    background-color: transparent;
  }
}
@media (max-width: 1023px) and (max-width: 1023px) {
  .sub-header .search .icon {
    left: 3.5px;
    color: #111;
    border-radius: 10px;
    width: 30px;
    height: 30px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 14px;
  }
}
@media (max-width: 1023px) {
  .sub-header .search .clear {
    position: absolute;
    right: 35px;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 100%;
    cursor: pointer;
    opacity: 0;
    transition: all 300ms ease;
  }
}
@media (min-width: 1024px) {
  .sub-header {
    top: 80px;
    height: 50px;
  }
}
.xlock-top {
  width: 100%;
  position: sticky;
  top: 65px;
  position: relative;
  top: auto;
  z-index: 55;
  transition: transform 250ms ease-out, top 250ms ease-out;
  backdrop-filter: blur(20px);
  margin-bottom: 0;
}
.vibe-rounded .xlock-top {
  box-shadow: 0px 0px 12px -3px rgba(0, 0, 0, 0.3333333333);
}
@media (min-width: 1024px) {
  .xlock-top {
    margin: 0;
    top: 130px;
    transition: transform 300ms ease;
    display: none;
  }
  .has-announcement .xlock-top {
    top: 145px;
  }
  .scrolled-down.has-announcement .xlock-top {
    top: 40px;
  }
  .scrolled-down .xlock-top {
    top: 130px;
    transform: translateY(-80px);
  }
}

.sub-header .profile-button {
  width: auto;
  right: 10px;
  z-index: 3;
}
.sub-header .profile-button .button {
  background-color: #dcf4ca;
  color: #2c5111;
}
.sub-header .location-button {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 600;
  z-index: 1;
}
@media (max-width: 1023px) {
  .sub-header .location-button {
    width: 100%;
    text-align: center;
    position: absolute;
    height: 65px;
    padding: 0;
    margin: 0;
    left: 0;
    top: 0;
    width: auto;
    text-align: left;
    position: relative;
    height: auto;
    padding: 0;
    margin: 0;
  }
  .no-nav .sub-header .location-button {
    width: auto;
    text-align: left;
    position: relative;
    height: auto;
    padding: 0;
    margin: 0;
  }
}
.change-location {
  font-weight: 300;
  font-size: 90%;
  text-decoration: underline;
}

.my-profile-stamps {
  display: flex;
  flex-direction: column-reverse;
  gap: 1px;
  min-width: 10px;
  max-width: 10px;
  width: 10px;
  align-items: center;
  justify-content: center;
  margin-left: 0px;
  margin-right: 5px;
}
.my-profile-stamps .my-profile-stamp {
  height: 2px;
  width: 100%;
  border-radius: 2px;
  background-color: #aaa;
  min-width: 10px;
  max-width: 10px;
  width: 10px;
}

.my-profile-button, .my-stamps-button {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 10px 10px;
  border-radius: 10px;
  height: 45px;
  flex-direction: column;
  font-size: 12px;
  font-weight: 600;
}
.my-profile-button .lbl, .my-stamps-button .lbl {
  font-weight: 600;
  font-size: 11px;
  text-transform: uppercase;
  color: #bbb;
  color: #dcf4ca;
  white-space: nowrap;
}

.mobile-search {
  width: 25px;
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  transition: all 0ms ease, opacity 0ms ease;
  opacity: 0;
  overflow: hidden;
  z-index: 5;
}
.mobile-search .icon, .mobile-search .clear {
  display: none;
  position: absolute;
  font-size: 16px;
}
.mobile-search input {
  color: #000;
  padding: 10px 20px 10px 40px;
  position: relative;
  z-index: 2;
  font-size: 16px;
}
.mobile-search input::placeholder {
  color: #999;
}
.mobile-search-active .mobile-search {
  transition: opacity 300ms ease;
  position: fixed;
  width: 100%;
  height: 65px;
  background-color: #fff;
  color: #000;
  opacity: 1;
}
.mobile-search-active .mobile-search .icon {
  width: 40px;
}
.mobile-search-active .mobile-search .icon, .mobile-search-active .mobile-search .clear {
  height: 100%;
  top: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 3;
}
.mobile-search-active .mobile-search .clear {
  right: 20px;
  z-index: 10;
  width: 30px;
}
.mobile-search-active .mobile-search .icon, .mobile-search-active .mobile-search .clear {
  display: flex;
}

.announcement {
  position: fixed;
  display: flex;
  z-index: 2;
  background: #000000;
  color: #ffffff;
  transition: transform 250ms ease-out, top 250ms ease-out;
  left: 0;
  width: 100%;
  font-size: 100%;
  line-height: normal;
  font-weight: 300;
  overscroll-behavior: none;
  overflow: hidden;
  flex-direction: column;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: center;
  display: none;
}
.has-announcement .announcement {
  display: flex;
}
.announcement:before {
  content: "";
  pointer-events: none;
  opacity: 0.8;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  position: absolute;
  background-color: #000;
  z-index: -1;
  display: none;
}
@media (min-width: 1024px) {
  .announcement {
    border-bottom: 0;
  }
}
.announcement .announcement-location {
  padding: 0 15px;
  flex: 1;
}
.announcement .search {
  position: relative;
  width: 100%;
}
.announcement .search input {
  width: 100%;
  border-radius: 0;
  border: 0;
  padding: 10px 15px 10px 40px;
  margin: 0;
  height: 40px;
}
.announcement .search .icon {
  position: absolute;
  left: 0;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 70px;
  height: 100%;
  pointer-events: none;
  color: #ffffff;
  font-size: 110%;
  padding: 0 0%;
  opacity: 1;
}
@media (max-width: 1023px) {
  .announcement .search .icon {
    left: 3.5px;
    color: #111;
    border-radius: 10px;
    width: 30px;
    height: 30px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 14px;
  }
}
.announcement .search .clear {
  position: absolute;
  right: 35px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 100%;
  cursor: pointer;
  opacity: 0;
  transition: all 300ms ease;
}
.announcement .rewards-header-section {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  flex: 1;
  padding: 0 15px;
}
.announcement .rewards-header-section .rewards-link {
  display: flex;
  gap: 5px;
  padding: 7px 0;
  height: 100%;
  align-items: center;
  width: 50%;
  font-weight: 700;
  font-size: 120%;
  white-space: nowrap;
}
.announcement .rewards-header-section .rewards-link a {
  align-items: center;
}
.announcement .rewards-header-section .rewards-link .selector {
  display: flex;
}
.announcement .rewards-header-section .punch-card-status {
  height: 100%;
  align-items: center;
  width: 50%;
}
.announcement .rewards-header-section .punch-card-status > div {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  height: 100%;
}
.announcement .rewards-header-section .punch-card-status .punch-card-header .punch-card-items {
  display: flex;
  gap: 3px;
  width: 100%;
  position: relative;
  justify-content: space-between;
}
.announcement .rewards-header-section .punch-card-status .punch-card-header .punch-card-items .punch {
  height: 10px;
  max-width: 10px;
  min-width: 10px;
  display: flex;
  background-color: #ddd;
  border-radius: 3px;
  position: relative;
}
.announcement .rewards-header-section .punch-card-status .punch-card-header .punch-card-items .punch.active {
  background-color: #dcf4ca;
}
.announcement .icon {
  color: #62b622;
  padding: 0px;
  font-size: 14px;
  display: flex;
  position: relative;
  align-items: flex-end;
  justify-content: center;
}
.announcement .announcement-title {
  padding: 0 5px;
  white-space: nowrap;
  display: flex;
  gap: 5px;
  flex: 1;
  line-height: normal;
  font-size: 14px;
}
.announcement .announcement-title .points-lbl {
  font-size: 16px;
  font-weight: 600;
}
.announcement .announcement-location {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}
.announcement .announcement-location .selector {
  padding-left: 10px;
}
.announcement .announcement-location .location-selector {
  display: flex;
  width: 50%;
  height: 100%;
  display: flex;
  align-items: center;
}
.announcement .announcement-location .location-hours {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  width: 50%;
  height: 100%;
  display: flex;
  align-items: center;
}
@media (max-width: 1023px) {
  .announcement {
    top: 105px;
    height: 40px;
    width: 100%;
  }
  .scrolled-down .announcement {
    transform: translateY(-100%);
  }
}
@media (min-width: 1024px) {
  .announcement {
    top: 130px;
    height: 40px;
  }
  .scrolled-down .announcement {
    transform: translateY(-100%);
  }
}
nav {
  width: 100%;
  display: flex;
  z-index: 26;
  transition: transform 250ms ease-out, top 250ms ease-out;
  line-height: normal;
}
nav .search-top {
  align-self: center;
  position: relative;
  width: 100%;
}
nav .search-top:before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 0;
  background-color: #fff;
  border-radius: 20px;
}
.vibe-rounded nav .search-top:before {
  border-radius: 60px;
}
nav .search-top .icon {
  position: absolute;
  top: 50%;
  right: 7px;
  color: #fff;
  transform: translateY(-50%);
  height: 35px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 35px;
  background-color: #62b622;
  color: #ffffff;
  border-radius: 20px;
  font-size: 18px;
  z-index: 2;
  cursor: pointer;
}
nav .search-top input {
  height: auto;
  padding: 10px 20px;
  flex: none;
  height: 50px;
  align-self: center;
  width: 100%;
  border-radius: 0px;
  border: 0;
  transition: all 100ms ease;
  position: relative;
  background-color: transparent;
  border-radius: 20px;
}
.vibe-rounded nav .search-top input {
  border-radius: 60px;
}
nav .search-top input:hover {
  background-color: #dcf4ca22;
}
nav .search-top input:focus {
  box-shadow: 0px 0px 0px 3px #lightBackground;
  background-color: #fff;
}
nav .location-top {
  max-width: none;
  padding-right: 20px;
}
nav .location-top .location-wrapper {
  white-space: nowrap;
  text-align: right;
  line-height: 135%;
  background-color: rgba(0, 0, 0, 0.2);
  align-self: center;
  height: 50px;
  position: relative;
  border-radius: 20px;
}
.vibe-rounded nav .location-top .location-wrapper {
  border-radius: 50px;
}
nav .location-top .location-wrapper .location-link {
  padding: 0px 60px 0px 60px;
  display: flex;
  flex-direction: column;
  height: 100%;
}
nav .location-top .location-wrapper .location-link .chevron {
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
}
nav .location-top .location-wrapper .location-link .dot {
  background-color: #62b622;
  color: #ffffff;
  align-items: center;
  justify-content: center;
  height: 35px;
  width: 35px;
  font-size: 18px;
  display: flex;
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  border-radius: 20px;
}
@media (max-width: 1023px) {
  nav {
    background: #2d6105;
    color: #ffffff;
    align-items: center;
    justify-content: center;
    padding: 0px 10px;
  }
}
@media (min-width: 1024px) {
  nav {
    position: fixed;
    height: auto;
    top: 0;
    bottom: auto;
    right: 0px;
    left: auto;
    width: 100%;
    height: 80px;
    z-index: 25;
    transform: translateY(0%);
  }
  .not-top.scrolled-down nav {
    transform: translateY(-150px);
  }
  .edit-mode.not-top.scrolled-down nav {
    transform: translateY(0px);
  }
  nav:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    z-index: -1;
  }
}
nav .nav-container {
  background: #2d6105;
  color: #ffffff;
  height: 100%;
  flex: 1;
  transition: transform 250ms ease-out, top 250ms ease-out;
  list-style-type: none;
  padding: 0;
  margin: 0;
  display: flex;
  width: 100%;
}
@media (max-width: 1023px) {
  nav .nav-container {
    flex: 1;
    padding: 0 0px;
    justify-content: space-around;
  }
}
@media (min-width: 1024px) {
  nav .nav-container {
    background: linear-gradient(0deg, #2d6105 0%, #2d6105dd 100%);
    color: #ffffff;
    background: linear-gradient(0deg, #2d6105bb 0%, #2d6105bb 100%);
    backdrop-filter: blur(10px);
  }
}
nav .nav-container li {
  padding: 0;
  margin: 0;
  display: flex;
  position: relative;
  white-space: nowrap;
}
@media (max-width: 1023px) {
  nav .nav-container li {
    flex: 1;
  }
}
@media (max-width: 1023px) and (max-width: 1023px) {
  nav .nav-container li.popout-item {
    box-shadow: inset 0px 0px 10px -5px #000;
    top: -40%;
    width: 70px;
    height: 70px;
    border-radius: 100%;
    border: 3px solid #2d6105;
  }
  nav .nav-container li.popout-item a {
    opacity: 1;
  }
}
nav .nav-container li.logo-nav {
  padding-left: 10px;
  padding-right: 5px;
  display: none;
}
nav .nav-container li.logo-nav img {
  max-height: 35px;
  max-width: 150px;
}
@media (min-width: 1024px) {
  nav .nav-container li.logo-nav {
    display: flex;
    padding-left: 25px;
  }
}
nav .nav-container li.spread {
  width: 100%;
  flex: 3;
}
@media (max-width: 1023px) {
  nav .nav-container li {
    align-items: flex-start;
    padding: 0px 0px;
  }
  nav .nav-container li a {
    opacity: 0.7;
    height: 80px;
  }
  nav .nav-container li a i {
    transition: all 300ms ease;
    transform-origin: bottom;
  }
  nav .nav-container li a:before {
    content: "";
    width: 0%;
    top: 12.5px;
    left: 0;
    position: absolute;
    height: 5px;
    border-radius: 20px;
    transition: opacity 500ms ease;
    opacity: 0;
    z-index: 0;
  }
  nav .nav-container li.active a {
    opacity: 1;
    color: #dcf4ca;
  }
  nav .nav-container li.active a i {
    color: #dcf4ca;
  }
  nav .nav-container li.active a:before {
    content: "";
    width: 100%;
    top: 3px;
    background-color: #62b622;
    opacity: 0;
  }
  nav .nav-container li:last-child {
    border-right: 0;
    max-width: 60px;
  }
}
@media (min-width: 1024px) {
  nav .nav-container li {
    padding: 10px 20px;
    font-size: 100%;
    min-width: 50px;
    font-weight: 400;
  }
  nav .nav-container li.spread {
    min-width: 10px;
    padding: 0;
  }
  nav .nav-container li.final-item {
    border-right: 0;
    min-width: 80px;
    border-left: 1px solid rgba(0, 0, 0, 0.0666666667);
    font-size: 20px;
    padding: 0;
    position: relative;
  }
  nav .nav-container li.final-item i {
    border-radius: 5px;
    min-height: 50px;
    min-width: 50px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
}
nav .nav-container li a {
  display: flex;
  width: 100%;
  position: relative;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  transition: all 300ms ease;
}
@media (max-width: 1023px) {
  nav .nav-container li a {
    padding: 0px 0px 20px 0px;
    text-align: center;
    font-weight: 600;
    font-size: 10px;
    margin: 0 0px;
  }
  nav .nav-container li a i {
    font-size: 24px;
  }
  nav .nav-container li a span {
    text-transform: none;
    font-size: 10px;
    position: relative;
    z-index: 3;
    padding: 0 0px;
    text-transform: uppercase;
  }
}
@media (min-width: 1024px) {
  nav .nav-container li a {
    padding: 13% 0px;
  }
  nav .nav-container li a:before {
    width: 100%;
    height: 5px;
    opacity: 0;
    position: absolute;
    bottom: 5px;
    border-radius: 2px;
    content: "";
    transition: all 300ms ease 100ms;
  }
  nav .nav-container li a:after {
    width: 100%;
    height: 3px;
    background-color: #dcf4ca;
    opacity: 0;
    position: absolute;
    bottom: 10px;
    content: "";
    transition: all 300ms ease 100ms;
    transform: rotate(0deg);
  }
  nav .nav-container li a.active:before, nav .nav-container li a.active:after {
    opacity: 1;
    transition: all 300ms ease 0ms;
  }
}
nav .nav-container li a i {
  margin-bottom: 5px;
}
@media (max-width: 1023px) {
  nav {
    bottom: 0;
    position: fixed;
    transition: transform 100ms ease 10ms;
    top: auto;
    height: calc(60px + env(safe-area-inset-bottom));
  }
  .app-mode nav {
    transform: translateY(0px);
  }
  .scrolled-down-percise nav {
    transform: translateY(0px);
  }
}
@keyframes blink {
  0% {
    transform: scale(0.5);
    opacity: 1;
  }
  25% {
    opacity: 0.7;
  }
  50% {
    transform: scale(1.1);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes rise-fade {
  0% {
    transform: translateY(-100%) translateX(-50%);
    opacity: 1;
  }
  100% {
    opacity: 0;
    transform: translateY(-300%) translateX(-50%);
  }
}
.blink {
  animation: blink 500ms;
}
.blink:before {
  animation: rise-fade 1000ms ease forwards;
}

.cart-opener {
  position: fixed;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  line-height: normal;
  font-size: 70%;
  z-index: 11;
  border-radius: 100%;
  background-color: #62b622;
  color: #ffffff;
  font-weight: 600;
  box-shadow: 0px 0px 0px 0px #62b622;
  transition: all 200ms ease;
  opacity: 0;
  pointer-events: none;
}
.cart-opener:before {
  content: "Added!";
  position: absolute;
  top: 0;
  left: 50%;
  padding: 5px 15px;
  transform: translateY(-100%) translateX(-50%);
  background-color: #dcf4ca;
  color: #2c5111;
  opacity: 0;
}
.active-cart .cart-opener {
  opacity: 1;
  pointer-events: all;
}
.active-cart .cart-opener.active {
  opacity: 0;
  pointer-events: all;
}
@media (max-width: 1023px) {
  .cart-opener {
    width: 75px;
    height: 75px;
    bottom: 90px;
    left: 20px;
  }
}
@media (min-width: 1024px) {
  .cart-opener {
    width: 80px;
    height: 80px;
    bottom: 140px;
    right: 50px;
  }
}
.cart-opener i {
  font-size: 250%;
  margin-bottom: 5px;
  position: relatve;
  z-index: 1;
}
.nav-opener-header, .my-account-opener-header {
  position: fixed;
  left: 0;
  top: 0;
  z-index: 26;
  height: 50px;
  width: 50px;
  align-items: center;
  justify-content: center;
  opacity: 1;
  transition: all 250ms ease-out;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: center;
  transition: all 300ms ease;
}
.no-nav .nav-opener-header, .no-nav .my-account-opener-header {
  opacity: 0;
  pointer-events: none;
}
.no-nav .nav-opener-header.show-nav, .no-nav .nav-opener-header.overlay-visible, .no-nav .my-account-opener-header.show-nav, .no-nav .my-account-opener-header.overlay-visible {
  opacity: 1;
  pointer-events: all;
}
@media (max-width: 1023px) {
  .nav-opener-header, .my-account-opener-header {
    height: 65px;
    width: 55px;
  }
  .overlay-visible .nav-opener-header, .overlay-visible .my-account-opener-header {
    transition: all 500ms ease 200ms;
    background-color: rgba(0, 0, 0, 0.062745098);
  }
}
.nav-opener-header:before, .my-account-opener-header:before {
  content: "";
  transition: all 300ms ease;
  position: absolute;
  top: 0;
  left: 0;
  background-color: #62b622;
  width: 100%;
  height: 100%;
  z-index: -1;
  opacity: 0;
}
.nav-opener-header:after, .my-account-opener-header:after {
  content: "";
  transition: all 300ms ease;
  position: absolute;
  top: 0;
  left: 0;
  background-color: #2d610588;
  width: 100%;
  height: 100%;
  z-index: 1;
  opacity: 0;
}
.nav-opener-header i, .my-account-opener-header i {
  position: relative;
  z-index: 2;
}
.nav-opener-header span, .my-account-opener-header span {
  position: relative;
  z-index: 2;
  text-transform: uppercase;
}
.show-nav .nav-opener-header, .overlay-visible .nav-opener-header, .show-nav .my-account-opener-header, .overlay-visible .my-account-opener-header {
  pointer-events: all;
  opacity: 1;
  transform: translateY(0);
}
@media (min-width: 1024px) {
  .nav-opener-header, .my-account-opener-header {
    display: none;
  }
}

.my-account-opener-header {
  right: 15px;
  top: 15px;
  left: auto;
  color: #ffffff;
  height: 40px;
  width: 40px;
  font-size: 18px;
  border-radius: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #62b622;
  display: none;
}
@media (max-width: 1023px) {
  .my-account-opener-header {
    display: none;
  }
}

.nav-opener {
  position: fixed;
  right: 0;
  bottom: 0;
  z-index: 16;
  height: 60px;
  width: 60px;
  align-items: center;
  justify-content: center;
  opacity: 1;
  pointer-events: none;
  transition: all 250ms ease-out;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 10px 0;
  box-shadow: -1px -1px 0px 0px #25480d;
  background-color: #2d6105;
  transform: translateY(105%);
}
.nav-opener .hamburger span {
  transition: transform 0.25s ease-in-out 500ms;
}
.nav-opener:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  background-color: #62b622;
  color: #ffffff;
  width: 100%;
  height: 100%;
  z-index: -1;
}
.nav-opener:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  background-color: #2d610588;
  width: 100%;
  height: 100%;
  z-index: 1;
}
.nav-opener i {
  position: relative;
  z-index: 2;
}
.nav-opener span {
  position: relative;
  z-index: 2;
  text-transform: uppercase;
}
.show-nav .nav-opener {
  transition: all 150ms ease-out 300ms;
  pointer-events: all;
  opacity: 1;
  transform: translateY(0);
}
@media (max-width: 1023px) {
  .nav-opener {
    display: flex;
  }
}
@media (min-width: 1024px) {
  .nav-opener {
    display: none;
  }
}

.hamburger-wrapper {
  border-radius: 100%;
  height: 65%;
  width: 100%;
  left: 15px;
  display: flex;
  align-items: center;
  position: relative;
}

.hamburger {
  width: 25px;
  height: 20px;
  position: relative;
  transform: rotate(0deg);
  transition: 0.5s ease-in-out;
  cursor: pointer;
  z-index: 3;
}
.hamburger span {
  display: block;
  position: absolute;
  height: 2px;
  width: 100%;
  background: #fff;
  border-radius: 3px;
  opacity: 1;
  right: 0;
  transform: rotate(0deg);
  transition: all 0.25s ease-in-out;
}
.hamburger span:nth-child(1) {
  top: 0px;
}
.hamburger span:nth-child(2), .hamburger span:nth-child(3) {
  top: 8px;
}
.hamburger span:nth-child(4) {
  top: 16px;
  width: 100%;
}
.hamburger span:nth-child(3) {
  width: 100%;
}
.hamburger span:nth-child(2) {
  width: 100%;
  opacity: 0;
}
.overlay-visible .hamburger span:nth-child(1) {
  top: 4px;
  transform: rotate(-35deg);
}
.overlay-visible .hamburger span:nth-child(1), .overlay-visible .hamburger span:nth-child(2), .overlay-visible .hamburger span:nth-child(3), .overlay-visible .hamburger span:nth-child(4) {
  left: 0;
  height: 4px;
  width: 20px;
}
.overlay-visible .hamburger span:nth-child(2) {
  opacity: 0;
}
.overlay-visible .hamburger span:nth-child(3) {
  opacity: 0;
}
.overlay-visible .hamburger span:nth-child(4) {
  transform: rotate(35deg);
  top: 14px;
}
.show-nav .hamburger span {
  transition: transform 0.25s ease-in-out;
}
.show-nav .hamburger span:nth-child(1) {
  top: 50%;
  width: 0%;
  left: 50%;
}
.show-nav .hamburger span:nth-child(2), .show-nav .hamburger span:nth-child(3), .show-nav .hamburger span:nth-child(4) {
  opacity: 1;
  width: 100%;
  left: 0;
}
.show-nav .hamburger span:nth-child(2) {
  transform: rotate(45deg);
}
.show-nav .hamburger span:nth-child(3) {
  transform: rotate(-45deg);
}
.show-nav .hamburger span:nth-child(4) {
  top: 50%;
  width: 0%;
  left: 50%;
}

.modal-back {
  padding: 15px;
  display: flex;
  align-items: center;
  line-height: normal;
  text-transform: capitalize;
}
.modal-back i {
  margin-right: 5px;
}
@media (max-width: 1023px) {
  .modal-back {
    display: none;
  }
}

.user-login-container {
  padding: 0px;
  width: 100vw;
  position: fixed;
  top: 0px;
  width: 100%;
  left: 0;
  z-index: 25;
}
@media (max-width: 1023px) {
  .user-login-container {
    height: 100%;
  }
}
@media (min-width: 1024px) {
  .user-login-container {
    left: auto;
    right: 0;
    width: 400px;
    z-index: 30;
    height: calc(100% - 130px);
    top: auto;
    bottom: 0;
  }
}
.user-login-container .register-form {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.user-login-container .register-form .show-invalid {
  display: none;
}
.user-login-container .register-form .invalid {
  color: red;
  box-shadow: inset 0px 0px 0px 3px red;
  background-color: #ffb8b8;
}
.user-login-container .register-form.invalid .hide-invalid {
  display: none !important;
}
.user-login-container .register-form.invalid .show-invalid {
  display: flex;
  flex-direction: column;
}
.user-login-container .rewards-signin-container {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 15px;
  background-color: #62b622;
  color: #ffffff;
  border-radius: 0px;
  font-weight: 800;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 50px;
  font-size: 20px;
  transition: transform 250ms ease-out, top 250ms ease-out;
  opacity: 1;
  pointer-events: all;
  transform: translateX(100%);
}
.rewards-signin-show .user-login-container .rewards-signin-container {
  transform: translateX(0%);
}
.user-login-container .rewards-signin-container h3 {
  width: 100%;
  font-weight: 600;
}
.user-login-container .rewards-signin-container .signin-form {
  display: flex;
  width: 100%;
}
.user-login-container .rewards-signin-container .signin-form input[type=text], .user-login-container .rewards-signin-container .signin-form input[type=number], .user-login-container .rewards-signin-container .signin-form input[type=tel] {
  padding: 0;
  margin: 0;
  padding: 5px 10px;
  font-size: 16px;
  border-radius: 10px;
  border: 0;
  width: 100%;
  height: 100%;
  height: 40px;
}
.user-login-container .rewards-signin-container .signin-form a {
  background-color: #darkBackground;
  color: #darkColor;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px;
  height: 40px;
  white-space: nowrap;
  border-radius: 10px;
  font-weight: 600;
}

.modal .redemption-popup {
  display: flex;
  flex-direction: column;
  width: 100%;
  left: 0;
  position: relative;
  height: 100%;
}
.modal .redemption-popup .breadcrumbs {
  min-height: 65px;
  font-size: 18px;
  font-weight: 600;
  padding: 0 15px;
}
.modal .redemption-popup .image {
  background-color: #fff;
  display: flex;
}
.modal .redemption-popup .image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  max-height: 300px;
}
.modal .redemption-popup .meta {
  padding: 15px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.modal .redemption-popup .meta > div {
  width: 100%;
}
.modal .redemption-popup .meta .button {
  font-size: 18px;
}

.modal {
  pointer-events: none;
  opacity: 0;
  z-index: 20;
  position: fixed;
  transition: opacity 100ms ease 400ms;
  width: 100vw;
  height: 100vh;
  width: -webkit-fill-available;
  height: -webkit-fill-available;
  height: 100%;
  left: 0;
  top: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (min-width: 1024px) {
  .modal {
    z-index: 36;
  }
}
.modal .frame {
  height: 100%;
}
.modal .frame .container {
  height: 100%;
  align-items: flex-start;
  justify-content: flex-start;
}
.modal .frame .container .section-header {
  height: 50px;
  min-height: 50px;
  max-height: 50px;
  background-color: #2d6105;
  color: #ffffff;
  width: 100%;
  display: flex;
  align-items: center;
  padding: 5px 15px;
  font-weight: 600;
  position: sticky;
  z-index: 5;
  top: 0;
}
.modal .frame .container .contained {
  display: flex;
  flex-direction: column;
  flex: 1;
  overflow-y: auto;
  flex-wrap: nowrap;
}
.modal .frame .container .actions {
  order: 3;
  width: 100%;
  display: flex;
  flex-direction: column;
  position: relative;
  transition: all 300ms ease;
  position: relative;
  left: 0;
  bottom: 0;
  z-index: 3;
}
@media (min-width: 1024px) {
  .modal .frame .container .actions {
    margin-top: 25px;
  }
}
.modal .frame .container .actions.disabled {
  transform: translateY(100px);
  height: 0px;
  overflow: hidden;
}
.modal .frame .container .actions .row {
  gap: 0px;
  background-color: #f1f1f1;
  display: flex;
  width: 100%;
}
.modal .frame .container .actions .button {
  border-radius: 0;
  flex: 1;
  padding: 32px 25px;
  transition: all 300ms ease;
}
.modal .frame .container .actions .button.disabled {
  background-color: #999;
  color: #333;
}
.modal .frame .radios {
  display: flex;
  width: 100%;
  background-color: #darkBackground;
  color: #darkColor;
  align-items: center;
  justify-content: center;
  position: relative;
  padding: 5px 0;
}
.modal .frame .radios label {
  flex: 1;
  position: relative;
  height: 100%;
  align-items: center;
  justify-content: center;
  display: flex;
  cursor: pointer;
}
.modal .frame .radios label.active {
  color: #2c5111;
}
.modal .frame .radios label.radio-title {
  flex: none;
  padding: 10px 15px;
  font-weight: 600;
  font-size: 14px;
  cursor: default;
}
.modal .frame .radios label input {
  cursor: pointer;
  appearance: none;
  height: 100%;
  width: 100%;
  position: absolute;
  left: 0;
  top: 0;
  padding: 0;
  margin: 0;
  z-index: 0;
  border-radius: 10px;
}
.modal .frame .radios label input:checked {
  background-color: #dcf4ca;
  cursor: default;
}
.modal .frame .radios label span {
  position: relative;
  z-index: 2;
}
.modal .secondary-filter {
  top: 0px;
}
.modal .lock-top {
  display: none;
}
.modal .modal-back {
  display: none !important;
}
.show-modal .modal {
  opacity: 1;
  pointer-events: all;
  transform: translateX(0%);
}
.show-modal .modal .modal-closer {
  transition: opacity 500ms ease;
  opacity: 1;
}
.show-modal .modal .modal-content {
  transform: translateY(0vh);
  transition: all 250ms ease-in-out 100ms;
  opacity: 1;
}
@media (max-width: 1023px) {
  .show-modal .modal {
    transition: opacity 500ms ease 200ms, transform 150ms ease 250ms;
    transform: translateY(0%);
  }
}
.modal .hide-modal {
  display: none !important;
}
.modal .modal-content {
  height: 100%;
  width: 100%;
  transform: translateY(0vh);
  opacity: 0;
  transition: all 250ms ease-in-out 200ms;
  overflow: auto;
}
[modal-config=dark] .modal .modal-content {
  width: auto;
  height: auto;
  border: 0;
  background-color: transparent;
  box-shadow: none;
  background-color: rgba(0, 0, 0, 0.6);
  color: #fff;
  border: 1px solid #000;
  backdrop-filter: blur(10px);
  padding: 25px;
}
[modal-config=dark] .modal .modal-content ul {
  display: flex;
  flex-direction: column;
  list-style-type: none;
  margin: 0;
  padding: 0;
}
[modal-config=dark] .modal .modal-content ul li {
  padding: 0;
  margin: 0;
  flex: 1;
}
@media (min-width: 1024px) {
  .vibe-rounded .modal .modal-content {
    border-radius: 30px;
  }
}
@media (max-width: 1023px) {
  .modal {
    backdrop-filter: blur(10px);
  }
  .modal .modal-content {
    background-color: #ffffff77;
    color: #333333;
  }
  .modal .modal-content .overlay-page-color {
    background-color: #ffffff;
    color: #333333;
  }
}
@media (min-width: 1024px) {
  .modal {
    transform: translateY(0%);
    font-size: 18px;
  }
  .modal .modal-content {
    background-color: #fff;
    border-radius: 20px;
  }
  .sideview-view .modal {
    width: 450px;
    right: 0px;
    left: auto;
    transition: transform 400ms ease;
    top: auto;
    bottom: 0px;
    height: calc(100% - 200px);
    overflow: hidden;
    height: calc(100% - 205px);
    height: 100%;
    border-radius: 0;
    padding: 60px;
    backdrop-filter: blur(10px);
    background-color: transparent;
    width: 100%;
    opacity: 0;
    transition: transform 300ms ease, opacity 300ms ease;
  }
  .sideview-view .modal .modal-content {
    transition: none;
    transform: translateY(10%);
    transition: transform 300ms ease, opacity 300ms ease;
  }
  .sideview-view[modal-config=dark] .modal {
    backdrop-filter: none;
    background-color: rgba(0, 0, 0, 0.1333333333);
  }
  .sideview-view.show-modal .modal {
    opacity: 1;
    transition: transform 300ms ease, opacity 300ms ease;
  }
  .sideview-view.show-modal .modal .modal-content {
    transition: transform 300ms ease, opacity 300ms ease;
    transform: translateY(0%);
  }
  .sideview-view .modal {
    box-shadow: -10px 0px 20px 0px rgba(0, 0, 0, 0.1333333333);
  }
  .sideview-view .modal .modal-content {
    box-shadow: 0px 0px 0px 1px #2d61054a;
  }
  .sideview-view .modal .modal-closer {
    width: 50px;
    height: 50px;
    background-color: #dcf4ca;
    border-radius: 20px;
  }
  .sideview-view .modal .modal-closer:before, .sideview-view .modal .modal-closer:after {
    background-color: #2c5111;
  }
}
.modal .modal-closer {
  width: 50px;
  height: 50px;
  background-color: #2d6105;
  align-items: center;
  justify-content: center;
  line-height: 1px;
  font-size: 1px;
  display: flex;
  position: absolute;
  right: 35px;
  top: 35px;
  z-index: 7;
  cursor: pointer;
  transition: all 300ms ease;
  box-shadow: 0px 0px 100px 0px rgba(0, 0, 0, 0.4196078431);
  opacity: 0;
}
.vibe-rounded .modal .modal-closer {
  border-radius: 100%;
}
@media (min-width: 1024px) {
  .modal .modal-closer {
    width: 75px;
    height: 75px;
  }
}
.modal .modal-closer:before, .modal .modal-closer:after {
  content: "";
  height: 80%;
  width: 2px;
  background-color: #ffffff;
  position: absolute;
}
.modal .modal-closer:before {
  transform: rotate(-135deg) scale(0.55);
}
.modal .modal-closer:after {
  transform: rotate(-225deg) scale(0.55);
}
@media (max-width: 1023px) {
  .modal {
    /*z-index: 20;
    height: calc(100% - 60px);
    top: auto;
    bottom: 0;
    */
    z-index: 28;
    height: 100%;
    top: auto;
    bottom: 0px;
    width: 100%;
    /* padding: 0px 2.5%; */
    border-radius: 0px;
    left: 0%;
    overflow: hidden;
    border: 0px solid #000;
    transform: translateY(100px);
    transition: opacity 500ms ease 0ms, transform 3000ms ease 0ms;
  }
  .modal .contained {
    width: 100%;
    background-color: #fff;
  }
}
@media (max-width: 1023px) and (min-width: 1024px) {
  .modal .contained {
    border: 1px solid #111;
    border-bottom: 0;
  }
}
@media (max-width: 1023px) {
  .modal .contained .section-header {
    min-height: 50px;
  }
  .modal .contained .section-body {
    padding: 15px;
    height: 100%;
    overflow: auto;
  }
}
@media (max-width: 1023px) and (max-width: 1023px) {
  .modal .modal-closer {
    right: 0px;
    top: 0px;
    height: 65px;
    width: 65px;
    border-radius: 0%;
    background-color: rgba(17, 17, 17, 0.3333333333);
    color: #fff;
  }
}

@media (max-width: 1023px) {
  .search .icon {
    opacity: 0;
  }
}
@media (max-width: 1023px) {
  .search input {
    opacity: 1;
    border-radius: 10px;
    margin: 5px 0;
    background-color: #fff;
    color: #000;
    height: 37px;
    font-size: 12px;
    font-weight: 400;
  }
  .search input::placeholder {
    color: #555;
  }
}

.live-chat-container {
  pointer-events: none;
  height: 80vh;
  z-index: 5;
  max-width: 350px;
  width: 100%;
  position: fixed;
  right: 0;
  top: 0;
  transition: opacity 300ms ease;
}
@media (min-width: 1024px) {
  .live-chat-container {
    top: auto;
    bottom: 0;
  }
  .live-chat-container.top-right {
    top: 0;
    bottom: auto;
    right: 0;
    left: auto;
    z-index: 30;
  }
  .live-chat-container.top-right .live-chat {
    border-radius: 0;
    top: 85px;
    right: 10px;
    left: auto;
    bottom: auto;
    width: 65px;
    height: 40px;
    border-radius: 0;
    box-shadow: 2px 2px 2px 0px rgba(0, 0, 0, 0.1607843137);
    background: #dcf4ca;
    color: #2c5111;
    border-radius: 5px;
    opacity: 0;
    pointer-events: none;
  }
  .live-chat-view .live-chat-container.top-right .live-chat {
    width: 100%;
    height: 100%;
    border-radius: 10px;
    top: 55px;
    right: 10px;
    box-shadow: 0px 0px 0px 3px #62b622;
    opacity: 1;
    pointer-events: all;
  }
  .live-chat-container.top-right .live-chat .live-chat-opener {
    background: #dcf4ca;
    color: #2c5111;
    border-radius: 0;
    border: 0;
  }
  .live-chat-container.top-right .live-chat .live-chat-opener img {
    padding: 17px 10px 0 10px;
  }
  .live-chat-container.top-right .live-chat .live-chat-opener:before {
    position: absolute;
    top: 10px;
    left: 0;
    width: 100%;
    text-align: center;
    font-size: 10px;
    color: #000;
  }
}
.live-chat-container.search-bind {
  opacity: 2;
  left: 0;
  right: auto;
  bottom: auto;
  top: 60px;
  height: 50px;
  max-width: 600px;
  transition: none;
  pointer-events: none;
}
@media (max-width: 1023px) {
  .live-chat-container.search-bind {
    top: 9px;
    width: 35px;
    right: 20px;
    left: auto;
  }
}
.live-chat-container.search-bind .live-chat {
  bottom: auto;
  right: auto;
  width: 100%;
  height: 100%;
  border-radius: 0;
  background-color: transparent;
  box-shadow: none;
  overflow: hidden;
  pointer-events: none;
}
.live-chat-view .live-chat-container.search-bind .live-chat {
  overflow: visible;
}
.live-chat-container.search-bind .live-chat .is-typing-container {
  color: rgba(0, 0, 0, 0.7333333333);
}
.live-chat-container.search-bind .live-chat .live-chat-opener {
  opacity: 0;
  display: none;
}
.live-chat-container.search-bind .live-chat .live-chat-opener img {
  padding: 10px 10px 0 10px;
}
.live-chat-container.search-bind .live-chat .live-chat-closer {
  bottom: auto;
  top: 0;
  right: auto;
  left: 0px;
}
.live-chat-container.search-bind .live-chat .live-chat-closer .portrait-closer {
  display: none;
}
@media (max-width: 1023px) {
  .live-chat-container.search-bind .live-chat .live-chat-closer .portrait-closer {
    display: flex;
  }
  .live-chat-container.search-bind .live-chat .live-chat-closer .landscape-closer {
    display: none;
  }
}
.live-chat-container.search-bind .live-chat .live-chat-content {
  height: 100%;
  opacity: 1;
  overflow: visible;
}
.live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray {
  background-color: transparent;
  overflow: visible;
  height: 100%;
}
.live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger {
  background-color: transparent;
  height: 100%;
  overflow: visible;
  box-shadow: none;
}
.live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger .chatting-with {
  pointer-events: all;
  display: flex;
  background-color: #dcf4ca;
  color: #ffffff;
  width: 100%;
}
@media (max-width: 1023px) {
  .live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger .chatting-with {
    order: 1;
  }
}
.live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger .chatting-with .chatter {
  display: flex;
  width: 100%;
  padding: 10px 10px;
  align-items: center;
}
.live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger .chatting-with .chatter .chatter-avatar {
  max-width: 25px;
  display: flex;
}
.live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger .chatting-with .chatter .chatter-name {
  flex: 1;
  padding: 0 20px;
  font-weight: 700;
  font-size: 18px;
}
.live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger .chatting-with .chatter .new-chat {
  cursor: pointer;
  padding: 5px 10px;
  background-color: rgba(0, 0, 0, 0.2);
  border-radius: 10px;
}
.live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger .messages {
  height: 0%;
  overflow: visible;
  flex: 1;
}
@media (max-width: 1023px) {
  .live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger .messages {
    overflow: hidden;
  }
}
.live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger .messages .messages-list {
  background-color: #dcf4ca;
  padding: 20px 20px 0 20px;
  transform-origin: top;
  transition: transform 1000ms ease;
}
@media (max-width: 1023px) {
  .live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger .messages .messages-list {
    padding: 10px 10px 10px 10px;
  }
}
.live-chat-view .live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger .messages .messages-list {
  box-shadow: 0px 0px 40px 0px #000000;
  border-bottom-right-radius: 10px;
  overflow: hidden;
}
.live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger .messages .list {
  border-radius: 10px;
  pointer-events: all;
  overflow: auto;
  height: 100%;
  max-height: 100%;
  flex-direction: column;
  background-color: #fff;
  min-height: 50px;
  align-self: flex-start;
  box-shadow: 0px 0px 0px 1px rgba(0, 0, 0, 0.2);
}
.live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger .messages .list:after {
  display: none;
}
@media (max-width: 1023px) {
  .live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger .messages .list {
    border-radius: 0;
    order: 2;
  }
}
.live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger .messages .list .message .message-section.no-bottom .groove {
  display: none;
}
.live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger .messages .list .message .message-section.no-bottom:after {
  opacity: 0;
}
.live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger .messages .list .message .message-section.no-bottom:before {
  opacity: 0;
}
.live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger .messages .list .message .message-options a {
  box-shadow: none;
}
.live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger .messages .list .message .message-options.grid a {
  margin-bottom: 15px;
}
.live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger .chat-controls {
  position: absolute;
  top: 0;
  width: calc(100% - 55px);
  pointer-events: none;
}
.live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger .chat-controls .chatter .chatter-name {
  font-style: italic;
  white-space: nowrap;
}
.live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger .chat-controls .chatter .new-chat {
  opacity: 0;
  transition: opacity 0ms ease 0ms;
}
.live-chat-view .live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger .chat-controls .chatter .new-chat {
  transition: all 300ms ease 700ms;
  opacity: 1;
}
.live-chat-view .live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger .chat-controls {
  position: relative;
  pointer-events: all;
  display: none;
}
.live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger form {
  background-color: transparent;
  border: 0;
}
@media (max-width: 1023px) {
  .live-chat-view .live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger form {
    background-color: #dcf4ca;
  }
}
.live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger form .message-row {
  background: #dcf4ca;
  opacity: 0;
}
.live-chat-view .live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger form .message-row {
  opacity: 1;
}
.live-chat-view .live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger form .message-row {
  color: #000;
  background-color: rgba(255, 255, 255, 0.6392156863);
  height: 50px;
}
.live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger form .message-row .message-box .chat-actions {
  display: none;
}
.live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger form .message-row .message-box textarea {
  background-color: transparent;
  padding: 12px 20px;
  height: 50px;
  padding-left: 60px;
  color: inherit;
  font-size: 20px;
  font-weight: 600;
  display: flex;
  transition: all 300ms ease;
}
.live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger form .message-row .message-box textarea::placeholder {
  transition: all 100ms ease;
  color: transparent;
  font-size: 16px;
  font-weight: 600;
  line-height: 25px;
}
@media (max-width: 1023px) {
  .live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger form .message-row .message-box textarea::placeholder {
    font-size: 14px;
  }
}
.live-chat-view .live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger form .message-row .message-box textarea::placeholder {
  color: inherit;
  opacity: 0.7;
}
.live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger form .message-row button {
  opacity: 0;
  margin: 7.5px 15px;
  padding: 0 10px;
  border-radius: 10px;
  height: 35px;
  transition: opacity 500ms ease 0ms;
}
.live-chat-view .live-chat-container.search-bind .live-chat .live-chat-content .frame-chat.gray .messenger form .message-row button {
  opacity: 1;
}
.live-chat-container.search-bind .live-chat .live-chat-opener {
  border-radius: 0;
}
.live-chat-view .live-chat-container.search-bind .live-chat {
  bottom: auto;
  right: auto;
  border-radius: 0;
}
.live-chat-view .live-chat-container.search-bind {
  height: 80%;
}
@media (max-width: 1023px) {
  .live-chat-view .live-chat-container.search-bind {
    top: 65px;
    height: calc(100% - 87px);
    left: 0;
    width: 100%;
  }
}
@media (max-width: 1023px) {
  .live-chat-container {
    height: 100vh;
    height: -webkit-fill-available;
    max-width: 100vw;
    z-index: 27;
  }
}
.live-chat-view .live-chat-container {
  opacity: 1;
}

.live-chat {
  position: absolute;
  top: auto;
  bottom: 0;
  z-index: 99;
  transition: all 200ms ease 100ms, transform 250ms ease-out, width 200ms ease 300ms, border-radius 500ms ease 400ms, right 300ms ease 200ms, bottom 300ms ease 100ms;
  opacity: 1;
  pointer-events: all;
  height: 150px;
  width: 250px;
  right: 0;
  background-color: #62b622;
  overflow: hidden;
  border-radius: 100%;
  width: 80px;
  height: 80px;
  bottom: 50px;
  right: 50px;
  box-shadow: 0px 0px 0px 1px #2d6105;
  display: flex;
}
@media (max-width: 1023px) {
  .live-chat {
    background: linear-gradient(180deg, #62b622aa 0%, #62b622dd 100%);
    backdrop-filter: blur(10px);
    border-radius: 20px;
    /*bottom: 25px;
    right: 15px;
    width: 70px;
    height: 70px;
    border: 0;
    */
    bottom: 90px;
    top: auto;
    right: -60px;
    width: 60px;
    height: 60px;
    border: 0;
    border-radius: 10px;
    box-shadow: 0px 0px 0px 0px rgba(0, 0, 0, 0.7333333333);
  }
  .active-cart .live-chat {
    bottom: 130px;
  }
}
.live-chat-view .live-chat {
  pointer-events: all;
  opacity: 1;
  height: 100%;
  width: 100%;
  transition: all 300ms ease 300ms, box-shadow 50ms ease, width 200ms ease 100ms, border-radius 200ms ease 0ms, right 300ms ease, bottom 300ms ease;
  box-shadow: 0px 0px 0px 3px #62b622;
}
@media (max-width: 1023px) {
  .live-chat-view .live-chat {
    border-radius: 0px;
    right: 0;
    bottom: 0;
    height: 100%;
  }
}
@media (min-width: 1024px) {
  .live-chat-view .live-chat {
    border-radius: 10px;
    bottom: 10px;
    right: 10px;
  }
}
.live-chat-view .live-chat .live-chat-closer {
  transition: all 500ms ease;
  opacity: 1;
  pointer-events: all;
  background-color: #62b622;
  color: #ffffff;
}
.live-chat-view .live-chat .live-chat-opener {
  opacity: 0;
  pointer-events: none;
  transition: all 300ms ease;
}
.live-chat-view .live-chat .live-chat-opener img {
  padding: 10px 10px 0 10px;
}
.live-chat-view .live-chat .live-chat-content {
  opacity: 1;
}
.live-chat .live-chat-closer, .live-chat .live-chat-opener {
  width: 60px;
  height: 60px;
  background-color: #62b622;
  align-items: center;
  justify-content: center;
  line-height: 1px;
  font-size: 18px;
  display: flex;
  position: absolute;
  top: 0px;
  right: 0px;
  color: #ffffff;
  z-index: 7;
  cursor: pointer;
  transition: all 300ms ease;
  opacity: 0;
  pointer-events: none;
}
.live-chat .live-chat-closer .portrait-closer, .live-chat .live-chat-opener .portrait-closer {
  display: flex;
}
.live-chat .live-chat-closer .landscape-closer, .live-chat .live-chat-opener .landscape-closer {
  display: none;
}
@media (min-width: 1024px) {
  .search-bind .live-chat .live-chat-closer, .search-bind .live-chat .live-chat-opener {
    width: 40px;
    height: 40px;
    margin: 10px 5px 0 5px;
    border-radius: 10px;
    border-bottom-right-radius: 0;
    border-bottom-left-radius: 0;
  }
}
.live-chat .live-chat-closer img, .live-chat .live-chat-opener img {
  padding: 10px 10px 0 10px;
}
.live-chat .live-chat-opener {
  opacity: 1;
  pointer-events: all;
  width: 100%;
  height: 100%;
  right: 0px;
  bottom: 0px;
  font-size: 25px;
  transition: all 300ms ease 300ms;
}
@media (max-width: 1023px) {
  .live-chat .live-chat-opener {
    background: transparent;
    color: #ffffff;
    font-size: 30px;
    pointer-events: all;
  }
  .live-chat .live-chat-opener img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: left;
  }
}
@media (min-width: 1024px) {
  .live-chat .live-chat-opener {
    pointer-events: none;
  }
  .live-chat .live-chat-opener img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    background: linear-gradient(180deg, #ffffff 0%, #ffca45 100%);
    border-radius: 0;
  }
}
.live-chat .live-chat-content {
  box-shadow: -1px 0px 0px 0px #2d61054a;
  transition: all 0ms ease 500ms, opacity 300ms ease 200ms;
  flex: 1;
  display: flex;
  width: 100%;
  position: relative;
  opacity: 0;
  overflow: hidden;
}

.loading-panel {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: 100;
  background-color: #2d6105;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20%;
  pointer-events: none;
  opacity: 0;
  transition: all 500ms ease;
  display: none;
}
@media (max-width: 1023px) {
  .show-loading-panel .loading-panel {
    opacity: 1;
  }
}
.sub-header, main, .announcement {
  transition: transform 250ms ease-out, top 250ms ease-out;
}

@media (max-width: 1023px) {
  .xendless {
    overflow: auto;
  }
  .xendless ul li:last-child {
    padding-right: 20px !important;
  }
  .overlay-visible {
    overflow: hidden;
    touch-action: none;
  }
  .overlay-visible body {
    touch-action: none;
  }
  .overlay-visible .sub-header, .overlay-visible main, .overlay-visible .announcement {
    transform: translateX(-40px);
  }
  .overlay-visible.overlay-dragging-close .sub-header, .overlay-visible.overlay-dragging-close main, .overlay-visible.overlay-dragging-close .announcement {
    transform: none;
  }
  .overlay-visible.overlay-dragging-close .nav-opener-header {
    opacity: 0;
  }
  .overlay-visible.scrolled-down .announcement {
    transform: translateX(-40px) translateY(-100%);
  }
}
.overlay {
  z-index: 25;
  pointer-events: none;
  display: flex;
  height: 100%;
  width: 100%;
  position: fixed;
  left: 0;
  top: 0;
}
.overlay .overlays {
  display: flex;
  height: 100%;
  width: 100%;
  position: relative;
  left: 0;
  top: 0;
}
.overlay .overlays.loading .overlay-frame:last-child {
  transform: translateX(100%);
}
.overlay .overlays .overlay-frame {
  display: flex;
  height: 100%;
  width: 100%;
  position: fixed;
  left: 0;
  top: 0;
  pointer-events: all;
  flex-direction: column;
  overflow: auto;
  transition: transform 250ms ease-out, top 250ms ease-out, opacity 250ms ease-out;
  background-color: #2d6105;
}
@media (max-width: 1023px) {
  .overlay .overlays .overlay-frame {
    padding-bottom: 80px;
  }
  .active-cart .overlay .overlays .overlay-frame {
    padding-bottom: 120px;
  }
}
.overlay .overlays .overlay-frame.remove-me {
  transform: translateX(100%);
  opacity: 1;
}
.overlay .overlays .overlay-frame .overlay-header {
  height: 65px;
  min-height: 65px;
  max-height: 65px;
  position: sticky;
  top: 0px;
  left: 0px;
  width: 100%;
  z-index: 2;
}
.overlay .overlays .overlay-frame .overlay-header .right-button {
  position: absolute;
  height: 100%;
  right: 0;
  z-index: 2;
  align-items: center;
  justify-content: center;
  padding: 10px;
  display: flex;
}
.overlay .overlays .overlay-frame .overlay-header .right-button .button {
  border-radius: 5px;
  font-size: 14px;
  font-weight: 300;
  border-radius: 5px;
  padding: 5px 10px;
  background-color: rgba(0, 0, 0, 0.2);
}
.overlay .overlays .overlay-frame .overlay-header .right-button .button.icon-only {
  font-size: 18px;
}
.overlay .overlays .overlay-frame .overlay-header:after {
  content: "";
  background-color: #dcf4ca;
  color: #2c5111;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.overlay .overlays .overlay-frame .overlay-header .overlay-header-title {
  flex: 1;
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  font-size: 18px;
  height: 100%;
  text-align: center;
  color: #2c5111;
}
.overlay .overlays .overlay-frame .overlay-header .overlay-closer {
  min-width: 65px;
  max-width: 65px;
  height: 65px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  z-index: 2;
  font-size: 24px;
  opacity: 0;
}
.overlay .overlays .overlay-frame .container {
  z-index: 1;
  background-color: #ffffff;
  flex: 1;
  align-items: flex-start;
  justify-content: flex-start;
}

@media (max-width: 1023px) {
  .app-wrap:before {
    content: "";
    background-color: #2d6105;
    width: 100%;
    position: relative;
    height: 65px;
    position: absolute;
    z-index: 2;
  }
}

main {
  position: relative;
  display: flex;
  z-index: 1;
  transform: translate3d(0, 0, 0);
  align-items: flex-start;
}
main.loading {
  transition: none;
  background-color: #ffffff;
  color: #333333;
}
main .overlay-header {
  display: none;
}
main .stacked-header {
  display: none;
}
.stack-visible main {
  z-index: 99;
}
main .slide-wrap-inner {
  max-width: none !important;
  font-size: 16px !important;
}
.sideview-view main {
  transition: all 500ms ease;
}
main section {
  transform: translate3d(0, 0, 0);
  width: 100%;
}
main.loading {
  transition: none;
}
main.loading:after {
  top: 300px;
}
main .frame-main {
  width: 100%;
  display: flex;
  flex-direction: column;
}
@media (max-width: 1023px) {
  main {
    padding-top: 65px;
    padding-bottom: 0px;
  }
  .floating-header main {
    padding-top: 0;
  }
  .show-search main {
    padding-top: 105px;
  }
  .has-announcement main {
    padding-top: 145px;
  }
  main .frame-main {
    min-height: calc(100vh - 145px);
    min-width: 100vw;
  }
  main .frame-main.stacked-frame {
    position: fixed;
    left: 0;
    top: 0;
    z-index: 60;
    padding-top: 65px;
    height: 100vh;
    width: 100vw;
    overflow: auto;
  }
  main .frame-main.stacked-frame .stacked-header {
    display: flex;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 65px;
    background: #dcf4ca;
    color: #2c5111;
    transition: transform 250ms ease-out, top 250ms ease-out, background-color 250ms ease-out;
    display: flex;
  }
  main .frame-main.stacked-frame .stacked-header .stacked-header-title {
    flex: 1;
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 18px;
  }
  main .frame-main.stacked-frame .stacked-header .stacked-closer {
    min-width: 65px;
    max-width: 65px;
    height: 65px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    z-index: 2;
  }
}
@media (max-width: 1023px) and (max-width: 1023px) {
  main {
    padding-top: 65px;
    padding-bottom: 80px;
  }
  .show-search main {
    padding-top: 105px;
  }
  .user-verified main {
    padding-bottom: 80px;
  }
  .active-cart .user-verified main {
    padding-bottom: 120px;
  }
  .mobile-fixed-footer main {
    padding-bottom: 0;
  }
  .active-cart main {
    padding-bottom: 120px;
  }
  .active-cart.mobile-fixed-footer main, .mobile-fixed-footer.active-cart main .user-verified, .mobile-fixed-footert main .user-verified {
    padding-bottom: 0;
  }
}
@media (max-width: 1023px) {
  .landing-mode main {
    padding-top: 0;
    padding-bottom: 0;
  }
  .chat-mode main {
    height: 100%;
    padding-top: 0;
    padding-bottom: 0;
  }
}
@media (max-width: 1023px) and (min-width: 1024px) {
  main .contained {
    padding: 15px;
    padding-top: 0;
  }
  main .contained section {
    margin-top: 15px;
  }
  main .contained .lock-top {
    border-top: 15px solid #fff;
  }
  main .contained .lock-top section {
    margin-top: 0;
  }
}
main:before {
  transition: opacity 500ms ease;
  background-color: rgba(0, 0, 0, 0.6);
  pointer-events: none;
  opacity: 0;
  z-index: 16;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: "";
}
@media (max-width: 1023px) {
  main:before {
    transition: opacity 500ms ease 300ms;
  }
}
@media (min-width: 1024px) {
  main:before {
    display: none;
  }
}
.show-modal.sideview-view main {
  transition: opacity 300ms ease;
}
.show-modal.sideview-view main:before {
  pointer-events: all;
  z-index: 16;
  opacity: 0;
}
@media (max-width: 1023px) {
  .show-modal.sideview-view main:before {
    transition: opacity 500ms ease;
  }
}
@media (min-width: 1024px) {
  main {
    margin-top: 130px;
    padding-bottom: 0px;
  }
  .has-announcement main {
    padding-top: 170px;
  }
  .landing-mode main {
    padding-top: 0;
    padding-bottom: 0;
  }
  .chat-mode main {
    height: 100%;
    padding-top: 0;
    padding-bottom: 0;
  }
  main .contained {
    padding-top: 0;
  }
}
@media (min-width: 1024px) and (min-width: 1024px) {
  main .contained {
    padding: 0px;
    padding-top: 0;
  }
}
@media (min-width: 1024px) {
  main .contained section {
    overflow: hidden;
  }
}
@media (min-width: 1024px) {
  main .contained .lock-top {
    border-top: 15px solid #fff;
  }
  main .contained .lock-top section {
    margin-top: 0;
  }
}
.section-tier-breakdown {
  gap: 20px;
  display: flex;
  flex-direction: column;
  padding-bottom: 25px;
}
.section-tier-breakdown .tier-breakdown {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 0 20px;
  width: 100%;
  line-height: normal;
}
.section-tier-breakdown .tier-breakdown .tier-visual {
  width: 40px;
  min-width: 40px;
  max-width: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 15px;
}
.section-tier-breakdown .tier-breakdown .tier-visual .tier-circle {
  height: 35px;
  width: 35px;
  border-radius: 100%;
  background-color: currentColor;
}
.section-tier-breakdown .tier-breakdown .tier-visual .tier-line {
  height: 100%;
  width: 5px;
  border-radius: 3px;
  background-color: currentColor;
}
.section-tier-breakdown .tier-breakdown .tier-meta {
  display: flex;
  flex: 1;
}
.section-tier-breakdown .tier-breakdown .tier-meta .tier-section {
  flex: 1;
}
.section-tier-breakdown .tier-breakdown .tier-meta .tier-section .tier-number {
  font-size: 12px;
  text-transform: uppercase;
  font-weight: 500;
  line-height: normal;
  opacity: 0.7;
}
.section-tier-breakdown .tier-breakdown .tier-meta .tier-section .tier-title {
  display: flex;
  justify-content: space-between;
}
.section-tier-breakdown .tier-breakdown .tier-meta .tier-section .tier-title .tier-name {
  text-transform: uppercase;
  font-size: 24px;
  font-weight: 600;
}
.section-tier-breakdown .tier-breakdown .tier-meta .tier-section .tier-title .tier-points {
  font-size: 13px;
}
.section-tier-breakdown .tier-breakdown .tier-detail {
  display: flex;
  flex: 1;
}
.section-tier-breakdown .tier-breakdown .tier-detail .tier-info {
  flex: 1;
  font-size: 14px;
  margin: 20px 0;
}
.section-tier-breakdown .tier-breakdown .tier-detail .tier-info ul {
  padding: 0;
  margin: 0;
  list-style-type: none;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.section-tier-breakdown .tier-breakdown .tier-detail .tier-info ul li {
  margin: 0;
  padding: 0 0 10px 0;
  border-bottom: 1px solid #ddd;
}
.section-tier-breakdown .tier-breakdown .tier-detail .tier-info ul li:last-child {
  border-bottom: 0;
}

@media (max-width: 1023px) {
  html {
    --web-grid-spacingMobile: 25pxMobile;
    --web-section-spacingMobile: 25pxMobile;
    --web-grid-roundingMobile: 20pxMobile;
    --web-button-roundingMobile: 20pxMobile;
  }
}
@media (min-width: 1024px) {
  html {
    --web-grid-spacing: 25px;
    --web-section-spacing: 25px;
    --web-grid-rounding: 20px;
    --web-button-rounding: 20px;
  }
}

.collection-tools, .collection-container-tools, .section-tools {
  display: none;
  pointer-events: none;
  opacity: 0;
}

.ui-edit-toolbar {
  position: fixed;
  z-index: 50;
  background-color: rgba(0, 0, 0, 0.6901960784);
  backdrop-filter: blur(10px);
  bottom: 25px;
  left: 50px;
  width: calc(100% - 100px);
  border-radius: 20px;
  transform: translateY(calc(100% + 50px));
  transition: all 300ms ease;
  color: #fff;
  padding: 0px;
  font-size: 18px;
  background-color: rgba(0, 0, 0, 0.6);
  color: #fff;
  backdrop-filter: blur(10px);
  border-radius: calc(20px * 2);
  align-items: center;
  justify-content: space-between;
  gap: 5px;
  pointer-events: all;
  opacity: 1;
  flex-direction: row;
  display: flex;
  border: 1px solid rgba(0, 0, 0, 0.2509803922);
}
.ui-edit-toolbar ul {
  list-style-type: none;
  display: flex;
  padding: 0;
  margin: 0;
  gap: 5px;
  flex: 1;
  padding: 10px;
}
.ui-edit-toolbar ul:first-child {
  border-right: 1px solid rgba(0, 0, 0, 0.2509803922);
}
.ui-edit-toolbar ul li {
  padding: 10px 10px;
  margin: 0;
  cursor: pointer;
  display: flex;
  gap: 5px;
}
.ui-edit-toolbar ul li.btn {
  border-radius: 20px;
  background-color: rgba(0, 0, 0, 0.2);
  transition: all 200ms ease;
}
.ui-edit-toolbar ul li.btn:hover {
  background-color: #lightBackground;
  color: #lightColor;
}
.ui-edit-toolbar ul li span {
  font-size: 12px;
}
.ui-edit-toolbar ul li.collection-remove {
  background-color: rgba(221, 0, 0, 0.6);
}
.edit-mode .ui-edit-toolbar {
  transform: translateY(0);
}
.edit-mode.dragging .ui-edit-toolbar {
  transform: translateY(calc(100% + 50px));
}

.handle-edit-mode {
  display: none !important;
  padding: 10px 0 !important;
}
.handle-edit-mode .a {
  line-height: normal;
  flex-direction: column;
  gap: 0px;
  align-items: center;
  justify-content: center;
  position: relative;
  padding: 0px 0px 0px 0px;
  margin-right: 15px;
  padding: 0 10px;
  background-color: #62b622;
  color: #ffffff;
  border-radius: 20px;
  transition: all 300ms ease;
  cursor: pointer;
  display: flex;
}
.admin-mode .handle-edit-mode {
  display: none !important;
}
@media (min-width: 1024px) {
  .admin-mode .handle-edit-mode {
    display: flex !important;
  }
}
.edit-mode .handle-edit-mode .a {
  background-color: #lightBackground;
  color: #lightColor;
}

[web-type=component] .hie:empty {
  display: none;
}
.edit-mode [web-type=component] .hie:empty {
  display: block;
}
@media (max-width: 1023px) {
  [web-type=component] {
    margin-bottom: var(--web-section-spacingMobile);
  }
  [web-type=component] [web-type=column] {
    margin-bottom: var(--web-section-spacingMobile);
  }
  [web-type=component]:first-child, [web-type=component]:last-child {
    margin-bottom: 0;
  }
  [web-type=component]:first-child [web-type=column], [web-type=component]:last-child [web-type=column] {
    margin-bottom: 0;
  }
}
@media (min-width: 1024px) {
  [web-type=component] {
    margin-bottom: var(--web-section-spacing);
  }
  [web-type=component]:last-child {
    margin-bottom: 0;
  }
}
[web-type=component] .section-title {
  display: flex;
  width: 100%;
  justify-content: space-between;
  align-items: center;
  font-weight: 600;
  font-size: 18px;
  padding: calc(15px - var(--web-grid-spacingMobile));
}
@media (min-width: 1024px) {
  [web-type=component] .section-title {
    padding: 0 0px 15px 0px;
  }
}
[web-type=component] .section-title a {
  font-weight: 300;
  font-size: 16px;
}
[web-type=component] [web-list=true] {
  border-radius: 0;
}
[web-type=component] [web-type=column] {
  display: flex;
}
@media (max-width: 1023px) {
  [web-type=component] [web-type=column] {
    gap: var(--web-grid-spacingMobile);
    padding: var(--web-grid-spacingMobile);
  }
  [web-type=component] [web-type=column].mobile-main-collection {
    padding: 0;
  }
  [web-type=component] [web-type=column].mobile-main-collection [web-type=collection] {
    border-radius: 0;
  }
}
@media (min-width: 1024px) {
  [web-type=component] [web-type=column] {
    margin-bottom: 0;
    gap: var(--web-grid-spacing);
  }
}
@media (min-width: 1024px) {
  [web-type=component] [web-type=column][web-layout=only-child] [web-onerow=true] .section-title {
    padding: var(--global-grid-spacing);
  }
}
[web-type=component] [web-type=column][web-layout=only-child] [web-onerow=true] .products .control.back {
  margin-left: calc(var(--global-grid-spacing) + 10px);
}
[web-type=component] [web-type=column][web-layout=only-child] [web-onerow=true] .products .control.forwards {
  margin-right: calc(var(--global-grid-spacing) + 10px);
}
[web-type=component] [web-type=column][web-layout=only-child] [web-onerow=true] .products ul li:first-child {
  margin-left: 10px;
}
[web-type=component] [web-type=column][web-layout=only-child] [web-onerow=true] .products ul li:last-child {
  margin-right: 10px;
}
@media (min-width: 1024px) {
  [web-type=component] [web-type=column][web-layout=only-child] [web-onerow=true] .products ul li:first-child {
    margin-left: var(--global-grid-spacing);
  }
  [web-type=component] [web-type=column][web-layout=only-child] [web-onerow=true] .products ul li:last-child {
    margin-right: var(--global-grid-spacing);
  }
}
@media (max-width: 1023px) {
  [web-type=component] [web-onerow=true] .products {
    padding-bottom: 30px;
  }
}
[web-type=component] [web-onerow=true] .products.nomargin {
  padding-bottom: 0;
}
[web-type=component] [web-onerow=true] .products .control {
  position: absolute;
  z-index: 3;
  display: flex;
  height: 100%;
  align-items: center;
  justify-content: center;
  top: 0;
  opacity: 0;
  pointer-events: none;
  transition: opacity 300ms ease;
  margin: 10px;
}
@media (max-width: 1023px) {
  [web-type=component] [web-onerow=true] .products .control {
    display: none;
  }
}
[web-type=component] [web-onerow=true] .products .control > div {
  border: 1px solid #lightColor;
  border-radius: 100%;
  width: 50px;
  height: 50px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #lightBackground;
  color: #lightColor;
  cursor: pointer;
  transition: all 300ms ease;
}
[web-type=component] [web-onerow=true] .products .control > div:hover {
  scale: 1.1;
}
[web-type=component] [web-onerow=true] .products .control.back {
  left: 0;
}
[web-type=component] [web-onerow=true] .products .control.forwards {
  right: 0;
}
[web-type=component] [web-onerow=true] .products .control.show-control {
  opacity: 1;
}
[web-type=component] [web-onerow=true] .products .control.show-control > div {
  pointer-events: all;
}
[web-type=component] [web-onerow=true] .products ul {
  flex-wrap: nowrap;
  flex-direction: row;
  overflow: auto;
  gap: 7px;
  padding: 0;
}
@media (min-width: 1024px) {
  [web-type=component] [web-onerow=true] .products ul {
    gap: 15px;
  }
}
@media (max-width: 1023px) {
  [web-type=component] [web-onerow=true] .products ul {
    padding: 0 7px;
  }
  .row-20-each [web-type=component] [web-onerow=true] .products ul {
    flex-wrap: wrap;
  }
}
@media (min-width: 1024px) {
  .vibe-rounded [web-type=component] [web-onerow=true] .products ul li {
    border-radius: 10px;
  }
}
[web-type=component] [web-onerow=true] .products ul li a span.image {
  background-color: transparent;
}
[web-type=component] [web-onerow=true] .products ul li a span.image img {
  background-color: transparent;
  border-radius: 20px;
  overflow: hidden;
}
@media (max-width: 1023px) {
  [web-type=component] [web-onerow=true] .products ul li {
    width: 60%;
    min-width: 60%;
    max-width: 100%;
  }
}
[web-type=component] [web-onerow=true] .products ul li:first-child {
  margin-left: 10px;
}
[web-type=component] [web-onerow=true] .products ul li:last-child {
  margin-right: 10px;
}
@media (min-width: 1024px) {
  [web-type=component] [web-onerow=true] .products ul li {
    min-width: calc(33.3% - 10px);
    max-width: 35%;
  }
  [web-type=component] [web-onerow=true] .products ul li:first-child {
    margin-left: 0;
  }
  [web-type=component] [web-onerow=true] .products ul li:last-child {
    margin-right: 0;
  }
}
@media (min-width: 1024px) {
  [web-type=component] [web-onerow=true][web-display-items="1"] .products ul li {
    min-width: calc(100% - 0px);
    max-width: 100%;
  }
}
@media (min-width: 1024px) {
  [web-type=component] [web-onerow=true][web-display-items="2"] .products ul li {
    min-width: calc(50% - 8px);
    max-width: none;
  }
}
@media (min-width: 1024px) {
  [web-type=component] [web-onerow=true][web-display-items="3"] .products ul li {
    min-width: calc(33.3% - 10px);
    max-width: none;
  }
}
@media (min-width: 1024px) {
  [web-type=component] [web-onerow=true][web-display-items="4"] .products ul li {
    min-width: calc(24% - 10px);
    max-width: none;
  }
}
@media (min-width: 1024px) {
  [web-type=component] [web-onerow=true][web-display-items="5"] .products ul li {
    min-width: calc(19% - 10px);
    max-width: none;
  }
}
@media (min-width: 1024px) {
  [web-type=component] [web-onerow=true][web-display-items="6"] .products ul li {
    min-width: calc(14.3% - 10px);
  }
}
[web-type=component][web-grid=false] .product-collections .product-collection {
  border-radius: 0 !important;
}
[web-type=component][web-grid=false] .product-collections .product-collection:after {
  border-radius: 0 !important;
}
[web-type=component][web-grid=true] {
  display: flex;
  flex-direction: column;
}
@media (min-width: 1024px) {
  [web-type=component][web-grid=true] {
    flex-direction: row;
    gap: 0;
  }
}
[web-type=component][web-grid=true] [web-type=column] {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  order: 2;
}
.edit-mode [web-type=component][web-grid=true] [web-type=column] {
  background-color: rgba(0, 0, 0, 0.0666666667);
}
@media (max-width: 1023px) {
  [web-type=component][web-grid=true] [web-type=column] {
    display: flex;
    width: 100%;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  }
  [web-type=component][web-grid=true] [web-type=column] [web-type=collection] {
    padding: 0;
    position: relative;
    right: auto;
    top: auto;
    left: auto;
    bottom: auto;
    flex: 1 1 30%;
    min-height: 200px;
    width: 100%;
  }
  [web-type=component][web-grid=true] [web-type=column] [web-type=collection]:nth-child(1) {
    grid-row: 1;
    grid-column: 1;
  }
  [web-type=component][web-grid=true] [web-type=column] [web-type=collection]:nth-child(2) {
    grid-row: 2;
    grid-column: 1;
  }
  [web-type=component][web-grid=true] [web-type=column] [web-type=collection]:nth-child(3) {
    grid-row: 2/span 2;
    grid-column: 2;
  }
  [web-type=component][web-grid=true] [web-type=column] [web-type=collection]:nth-child(4) {
    grid-row: 3;
    grid-column: 1;
  }
  [web-type=component][web-grid=true] [web-type=column] [web-type=collection]:nth-child(5) {
    grid-row: 4;
    grid-column: 1/span 2;
  }
  [web-type=component][web-grid=true] [web-type=column] [web-type=collection].products-list-container, [web-type=component][web-grid=true] [web-type=column] [web-type=collection].full-span-container {
    min-width: 100% !important;
    grid-column: 1/span 2 !important;
    grid-row: auto !important;
    order: auto !important;
    min-height: 50px;
    overflow: visible !important;
  }
  [web-type=component][web-grid=true] [web-type=column]:has(> [web-type=collection]:nth-child(2)) [web-type=collection]:nth-child(1) {
    grid-row: 1;
    grid-column: 1;
  }
  [web-type=component][web-grid=true] [web-type=column]:has(> [web-type=collection]:nth-child(2)) [web-type=collection]:nth-child(2) {
    grid-row: 2;
    grid-column: 1;
  }
  [web-type=component][web-grid=true] [web-type=column]:has(> [web-type=collection]:nth-child(3)) [web-type=collection]:nth-child(1) {
    grid-row: 1;
    grid-column: 1;
  }
  [web-type=component][web-grid=true] [web-type=column]:has(> [web-type=collection]:nth-child(3)) [web-type=collection]:nth-child(2) {
    grid-row: 1/span 2;
    grid-column: 2;
  }
  [web-type=component][web-grid=true] [web-type=column]:has(> [web-type=collection]:nth-child(3)) [web-type=collection]:nth-child(3) {
    grid-row: 2;
    grid-column: 1;
  }
}
@media (min-width: 1024px) {
  [web-type=component][web-grid=true] [web-type=column][web-layout=main] {
    width: calc(50% - 0px);
    flex: 1 1 50%;
  }
  [web-type=component][web-grid=true] [web-type=column][web-layout=full] {
    width: calc(100% - 0px);
    flex: 1 1 100%;
  }
  [web-type=component][web-grid=true] [web-type=column][web-layout="75"] {
    width: calc(75% - 0px);
    flex: 1 1 75%;
  }
  [web-type=component][web-grid=true] [web-type=column][web-layout="50"] {
    width: calc(50% - 0px);
    flex: 1 1 50%;
  }
  [web-type=component][web-grid=true] [web-type=column][web-layout="25"] {
    width: calc(25% - 0px);
    flex: 1 1 25%;
    flex-direction: column;
  }
  [web-type=component][web-grid=true] [web-type=column][web-layout="25"] .products-list-container {
    flex: none;
  }
}
@media (min-width: 1024px) {
  [web-type=component][web-grid=true] [web-type=column][web-layout=main] [web-type=collection]:nth-child(1) {
    padding-top: 60%;
  }
}
[web-type=component][web-grid=true] [web-type=column][web-layout=main] [web-type=collection]:nth-child(1) .collection-cta-header {
  display: block;
}
[web-type=component][web-grid=true] [web-type=column][web-layout=main] [web-type=collection]:nth-child(1) .collection-title {
  font-size: 40px;
  font-weight: 500;
}
[web-type=component][web-grid=true] [web-type=column][web-layout=main] [web-type=collection]:nth-child(1) .collection-cta-button {
  margin-top: 15px;
  border-radius: 30px;
  border: 1px solid #000;
  color: #darkColor;
  background-color: #fff;
  padding: 7.5px 15px;
  text-decoration: none;
  font-weight: 500;
  font-size: 16px;
  color: #000;
  border: 1px solid rgba(0, 0, 0, 0.1019607843);
  box-shadow: 2px 2px 2px 0px rgba(0, 0, 0, 0.1607843137);
  text-shadow: none;
}
[web-type=component][web-grid=true] [web-type=column][web-layout=main] [web-type=collection]:nth-child(2), [web-type=component][web-grid=true] [web-type=column][web-layout=main] [web-type=collection]:nth-child(3) {
  width: calc(50% - 12.5px);
  width: auto;
  flex: 1;
}
@media (min-width: 1024px) {
  [web-type=component][web-grid=true] [web-type=column][web-layout=main] [web-type=collection]:nth-child(2), [web-type=component][web-grid=true] [web-type=column][web-layout=main] [web-type=collection]:nth-child(3) {
    padding-top: 50%;
  }
}
@media (max-width: 1023px) {
  [web-type=component][web-grid=true]:nth-child(2) [web-type=column]:nth-child(1 of [web-type=column][web-layout=main]) {
    order: 1;
    padding-top: 0;
  }
  [web-type=component][web-grid=true]:nth-child(2) [web-type=column]:nth-child(1 of [web-type=column][web-layout=main]) [web-type=collection]:first-child {
    display: none;
  }
  [web-type=component][web-grid=true]:nth-child(2) [web-type=column]:nth-child(1 of [web-type=column][web-layout=main]) [web-type=collection]:nth-child(2) {
    grid-row: 2;
    grid-column: 1;
  }
  [web-type=component][web-grid=true]:nth-child(2) [web-type=column]:nth-child(1 of [web-type=column][web-layout=main]) [web-type=collection]:nth-child(3) {
    grid-row: 2;
    grid-column: 2;
  }
  [web-type=component][web-grid=true]:nth-child(2) [web-type=column]:nth-child(1 of [web-type=column][web-layout=main]) [web-type=collection]:nth-child(4) {
    grid-row: 3;
    grid-column: 1;
  }
  [web-type=component][web-grid=true]:nth-child(2) [web-type=column]:nth-child(1 of [web-type=column][web-layout=main]) [web-type=collection]:nth-child(5) {
    grid-row: 4;
    grid-column: 1;
  }
  [web-type=component][web-grid=true]:nth-child(2) [web-type=column]:nth-child(1 of [web-type=column][web-layout=main]) [web-type=collection]:nth-child(6) {
    grid-row: 5;
    grid-column: 1/span 2;
  }
  [web-type=component][web-grid=true]:nth-child(2) [web-type=column]:nth-child(1 of [web-type=column][web-layout=main]) [web-type=collection].full-span-container {
    min-width: 100%;
    grid-column: 1/span 2;
    grid-row: 1;
  }
  [web-type=component][web-grid=true]:nth-child(2) [web-type=column]:nth-child(1 of [web-type=column][web-layout=main]):has(> [web-type=collection]:nth-child(5)) [web-type=collection]:nth-child(3) {
    grid-row: 2/span 2;
    grid-column: 2;
  }
}
@media (min-width: 1024px) {
  [web-type=component][web-grid=true] {
    display: flex;
    width: 100%;
    gap: 25px;
    padding: 25px;
    gap: var(--web-grid-spacing);
    padding: var(--web-grid-spacing);
  }
}
[web-type=component] [web-type=collection] {
  min-height: 100px;
}
[web-type=component] [web-type=collection] .vanta-canvas {
  width: 100% !important;
  height: 100% !important;
}
[web-type=component] [web-type=collection][web-ai=flex-start] .product-collection-inner {
  align-items: flex-start;
  text-align: left;
}
[web-type=component] [web-type=collection][web-ai=center] .product-collection-inner {
  align-items: center;
  text-align: center;
}
[web-type=component] [web-type=collection][web-ai=flex-end] .product-collection-inner {
  align-items: flex-end;
  text-align: right;
}
[web-type=component] [web-type=collection][web-jc=flex-start] .product-collection-inner {
  justify-content: flex-start;
}
[web-type=component] [web-type=collection][web-jc=center] .product-collection-inner {
  justify-content: center;
}
[web-type=component] [web-type=collection][web-jc=flex-end] .product-collection-inner {
  justify-content: flex-end;
}
[web-type=component] [web-type=collection].full-span-container .product-collection-inner {
  padding: 0px;
}
[web-type=component] [web-type=collection].full-span-container .product-collection-inner .section-title {
  padding: 15px 15px 15px 0;
  padding: 15px 20px 10px 0;
}
[web-type=component] [web-type=collection].full-span-container .collection-title {
  pointer-events: all;
  padding: 7.5px 20px;
  background-color: var(--web-light-background);
  color: #fff;
  border-radius: 0px 10px 10px 0px;
}
@media (max-width: 1023px) {
  [web-type=component] [web-type=collection].full-span-container .collection-title {
    transform: translate(calc(var(--web-grid-spacingMobile) * -1), 0px);
  }
}
[web-type=component] [web-type=collection] .rewards-grid {
  padding: 15px;
  display: flex;
  overflow: auto;
  gap: 25px;
  justify-content: space-evenly;
}
@media (min-width: 1024px) {
  [web-type=component] [web-type=collection] .rewards-grid {
    overflow: hidden;
  }
  [web-type=component] [web-type=collection] .rewards-grid > div:nth-child(n+5) {
    display: none;
  }
}
[web-type=component] [web-type=collection] [web-type=collection-title], [web-type=component] [web-type=collection] [web-type=collection-ctaHeader], [web-type=component] [web-type=collection] [web-type=collection-ctaTitle] {
  min-height: 20px;
  min-width: 25px;
}
.edit-mode [web-type=component] [web-type=collection] [web-type=collection-title], .edit-mode [web-type=component] [web-type=collection] [web-type=collection-ctaHeader], .edit-mode [web-type=component] [web-type=collection] [web-type=collection-ctaTitle] {
  transition: all 300ms ease;
  cursor: text;
  transform-origin: left;
}
.edit-mode [web-type=component] [web-type=collection] [web-type=collection-title]:hover, .edit-mode [web-type=component] [web-type=collection] [web-type=collection-ctaHeader]:hover, .edit-mode [web-type=component] [web-type=collection] [web-type=collection-ctaTitle]:hover {
  background-color: rgba(0, 0, 0, 0.0666666667);
  box-shadow: 0px 0px 0px 5px rgba(0, 0, 0, 0.0666666667);
}
.edit-mode [web-type=component] [web-type=collection] [web-type=collection-title]:focus, .edit-mode [web-type=component] [web-type=collection] [web-type=collection-title]:active, .edit-mode [web-type=component] [web-type=collection] [web-type=collection-ctaHeader]:focus, .edit-mode [web-type=component] [web-type=collection] [web-type=collection-ctaHeader]:active, .edit-mode [web-type=component] [web-type=collection] [web-type=collection-ctaTitle]:focus, .edit-mode [web-type=component] [web-type=collection] [web-type=collection-ctaTitle]:active {
  background-color: #ffffff;
  box-shadow: 0px 0px 0px 2px #ffffff;
  color: #000;
  scale: 1.2;
  z-index: 3;
}
[web-type=component] [web-type=collection][web-color-mode=dark] {
  color: #000;
}
[web-type=component] [web-type=collection][web-color-mode=dark] a {
  color: #000;
}
[web-type=component] [web-type=collection][web-color-mode=light] {
  color: #fff;
}
[web-type=component] [web-type=collection][web-color-mode=light] a {
  color: #fff;
}

.status-ring {
  display: flex;
  position: relative;
}
.status-ring .ring-div {
  display: inline-flex;
  position: relative;
}
.status-ring .ring-div img {
  z-index: 0;
  position: absolute;
  /* opacity: 0; */
  height: 100%;
  width: 100%;
  object-fit: contain;
  padding: 17px;
}

.xstatus-ring {
  /* tweakables */
  --size: 100px; /* diameter */
  --thickness: 10px; /* ring width */
  --segments: 6; /* number of notches */
  --active: 0; /* blue notches (0..segments) */
  --gap: 10deg; /* angular gap between notches */
  --blue: #2f80ed;
  --grey: #c7c7c7;
  position: relative;
  width: var(--size);
  height: var(--size);
  transition: all 300ms ease;
}

/* Build the notched ring */
.xstatus-ring::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  transition: all 300ms ease;
  /* Paint: first N segments blue, rest gray */
  background: conic-gradient(var(--blue) 0 calc(1turn * var(--active) / var(--segments)), var(--grey) 0);
  /* MASK 1: carve inner hole to get a ring of desired thickness */
  /* MASK 2: cut the ring into notches with small angular gaps */
  -webkit-mask: radial-gradient(farthest-side, transparent calc(100% - var(--thickness)), #000 0), repeating-conic-gradient(#000 0 calc(1turn / var(--segments) - var(--gap)), transparent 0 calc(1turn / var(--segments)));
  /* Intersect mask layers (apply 2nd mask to the 1st) */
  -webkit-mask-composite: source-over, destination-in;
  mask: radial-gradient(farthest-side, transparent calc(100% - var(--thickness)), #000 0), repeating-conic-gradient(#000 0 calc(1turn / var(--segments) - var(--gap)), transparent 0 calc(1turn / var(--segments)));
  mask-composite: intersect; /* standards version where supported */
}

.edit-mode .app-wrap .contained section {
  background: linear-gradient(135deg, #eee 25%, #eee 25%, #eee 50%, #eee 50%, #eee 75%, #eee 75%, #eee 100%);
  background-color: #fff;
  background-size: 15px 15px;
  background-image: repeating-linear-gradient(to right, #eee 0, #eee 1px, transparent 1px, transparent 15px), repeating-linear-gradient(to bottom, #eee 0, #eee 1px, transparent 1px, transparent 15px);
}
.edit-mode .app-wrap .contained section {
  overflow: visible;
}
.edit-mode .app-wrap .contained section [web-type=column] {
  min-height: 150px;
}
.edit-mode .app-wrap .contained section [web-type=column] [web-type=collection] {
  background-color: #fff;
}
.edit-mode .app-wrap .contained section:after {
  content: "";
  pointer-events: none;
  width: calc(100% - 2px);
  height: calc(100% - 2px);
  left: 0;
  top: 0;
  position: absolute;
  border: 1px dashed #lightBackground;
  z-index: 4;
}
.edit-mode section.ui-sortable-placeholder {
  height: 100px !important;
  opacity: 1;
  visibility: visible !important;
}
.edit-mode section.ui-sortable-placeholder:before {
  content: "";
  position: absolute;
  background-color: #ddd;
  z-index: 5;
  left: 20px;
  top: 0;
  width: calc(100% - 20px);
  height: 100%;
}
.edit-mode .product-collection .collection-tools, .edit-mode .product-collections .collection-container-tools, .edit-mode section .section-tools {
  display: flex;
  position: absolute;
  bottom: 5px;
  left: 5px;
  width: calc(100% - 10px);
  background-color: rgba(0, 0, 0, 0.6);
  color: #fff;
  backdrop-filter: blur(10px);
  padding: 5px 5px;
  border-radius: 20px;
  animation: slide-up 200ms ease 100ms both;
  align-items: center;
  justify-content: space-between;
  gap: 5px;
  pointer-events: all;
  opacity: 1;
  z-index: 5;
  flex-direction: column;
}
.edit-mode .product-collection .collection-tools .positioner, .edit-mode .product-collections .collection-container-tools .positioner, .edit-mode section .section-tools .positioner {
  position: absolute;
  top: -60px;
  background-color: rgba(0, 0, 0, 0.2);
  width: 40px;
  height: 40px;
  right: 15px;
  display: flex;
  gap: 1px;
  flex-wrap: wrap;
  font-size: 8px;
  border-radius: 5px;
  overflow: hidden;
}
.edit-mode .product-collection .collection-tools .positioner div, .edit-mode .product-collections .collection-container-tools .positioner div, .edit-mode section .section-tools .positioner div {
  flex: 1;
  min-width: 30%;
  background-color: rgba(0, 0, 0, 0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 300ms ease;
}
.edit-mode .product-collection .collection-tools .positioner div.active, .edit-mode .product-collections .collection-container-tools .positioner div.active, .edit-mode section .section-tools .positioner div.active {
  background-color: #000;
}
.edit-mode .product-collection .collection-tools .positioner:hover div, .edit-mode .product-collections .collection-container-tools .positioner:hover div, .edit-mode section .section-tools .positioner:hover div {
  background-color: rgba(0, 0, 0, 0.7333333333);
}
.edit-mode .product-collection .collection-tools .positioner:hover div.active, .edit-mode .product-collections .collection-container-tools .positioner:hover div.active, .edit-mode section .section-tools .positioner:hover div.active {
  background-color: #000;
}
.edit-mode .product-collection .collection-tools .positioner:hover div:hover, .edit-mode .product-collections .collection-container-tools .positioner:hover div:hover, .edit-mode section .section-tools .positioner:hover div:hover {
  background-color: #62b622;
  color: #ffffff;
}
.edit-mode .product-collection .collection-tools ul, .edit-mode .product-collections .collection-container-tools ul, .edit-mode section .section-tools ul {
  list-style-type: none;
  display: flex;
  padding: 0;
  margin: 0;
  gap: 5px;
  flex-wrap: wrap;
}
.edit-mode .product-collection .collection-tools ul li, .edit-mode .product-collections .collection-container-tools ul li, .edit-mode section .section-tools ul li {
  margin: 0;
  background-color: rgba(0, 0, 0, 0.2);
  transition: all 200ms ease;
}
.edit-mode .product-collection .collection-tools ul li.full, .edit-mode .product-collections .collection-container-tools ul li.full, .edit-mode section .section-tools ul li.full {
  min-width: 100%;
  flex: 1;
  font-size: 12px;
  padding: 5px 10px;
  border-radius: 5px;
}
.edit-mode .product-collection .collection-tools ul li.full > div, .edit-mode .product-collections .collection-container-tools ul li.full > div, .edit-mode section .section-tools ul li.full > div {
  display: flex;
  gap: 5px;
  align-items: center;
  justify-content: center;
}
.edit-mode .product-collection .collection-tools ul li.has-input, .edit-mode .product-collections .collection-container-tools ul li.has-input, .edit-mode section .section-tools ul li.has-input {
  font-size: 12px;
  padding: 5px 10px;
  border-radius: 5px;
}
.edit-mode .product-collection .collection-tools ul li.has-input > div, .edit-mode .product-collections .collection-container-tools ul li.has-input > div, .edit-mode section .section-tools ul li.has-input > div {
  display: flex;
  gap: 5px;
  align-items: center;
  justify-content: center;
}
.edit-mode .product-collection .collection-tools ul li input, .edit-mode .product-collections .collection-container-tools ul li input, .edit-mode section .section-tools ul li input {
  width: 100%;
  flex: 1;
}
.edit-mode .product-collection .collection-tools ul li.tool-btn, .edit-mode .product-collections .collection-container-tools ul li.tool-btn, .edit-mode section .section-tools ul li.tool-btn {
  padding: 5px 7.5px !important;
  font-size: 11px !important;
  cursor: pointer;
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.edit-mode .product-collection .collection-tools ul li.tool-btn i, .edit-mode .product-collections .collection-container-tools ul li.tool-btn i, .edit-mode section .section-tools ul li.tool-btn i {
  pointer-events: none;
}
.edit-mode .product-collection .collection-tools ul li.tool-btn:hover, .edit-mode .product-collections .collection-container-tools ul li.tool-btn:hover, .edit-mode section .section-tools ul li.tool-btn:hover {
  background-color: #lightBackground;
  color: #lightColor;
}
.edit-mode .product-collection .collection-tools ul li.red, .edit-mode .product-collections .collection-container-tools ul li.red, .edit-mode section .section-tools ul li.red {
  background-color: rgba(221, 0, 0, 0.6);
}
.edit-mode .product-collection .collection-tools ul li.green, .edit-mode .product-collections .collection-container-tools ul li.green, .edit-mode section .section-tools ul li.green {
  background-color: rgba(0, 221, 0, 0.6);
}
.edit-mode .collection-tools .collection-display-items, .edit-mode .collection-tools .collection-limit, .edit-mode .collection-tools .show-list {
  display: none;
}
.edit-mode [web-list=true] .collection-display-items, .edit-mode [web-list=true] .collection-limit, .edit-mode [web-list=true] .show-list {
  display: flex;
}
.edit-mode [web-list=true] .hide-list {
  display: none !important;
}
.edit-mode .product-collections {
  border-radius: 20px;
  transition: all 300ms ease;
}
.edit-mode .product-collections .collection-container-tools {
  bottom: auto;
  top: -10px;
  left: -15px;
  width: calc(100% + 30px);
  min-height: 30px;
  min-width: 30px;
  height: 30px;
  width: 30px;
  z-index: 15;
  animation: slide-down 300ms ease 50ms both;
  transition: all 0ms ease 500ms;
  opacity: 1;
  flex-wrap: wrap;
  align-items: flex-start;
  flex-direction: column;
  justify-content: flex-start;
  overflow: hidden;
}
.edit-mode .product-collections .collection-container-tools ul {
  transition: all 0ms ease 500ms;
  display: flex;
  position: relative;
  opacity: 0;
  flex-wrap: wrap;
  width: 100%;
  padding: 5px;
}
.edit-mode .product-collections .collection-container-tools ul li {
  flex: 1;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}
.edit-mode .product-collections .collection-container-tools:hover {
  z-index: 15;
  opacity: 1;
  max-width: none;
  max-height: none;
  height: 150px;
  width: calc(100% + 30px);
  transition: height 300ms ease, background-color 300ms ease;
}
.edit-mode .product-collections .collection-container-tools:hover ul {
  transition: none;
  opacity: 1;
  position: relative;
  pointer-events: all;
}
.edit-mode section .section-tools {
  bottom: auto;
  top: 5px;
  right: 5px;
  left: auto;
  width: 100%;
  min-height: 30px;
  min-width: 30px;
  height: 30px;
  width: 30px;
  z-index: 18;
  animation: none;
  transition: opacity 0ms ease 500ms;
  transition: none;
  opacity: 1;
  flex-wrap: wrap;
  align-items: flex-start;
  flex-direction: column;
  justify-content: flex-start;
  overflow: hidden;
  border-radius: 5px;
}
.edit-mode section .section-tools ul {
  transition: all 0ms ease 500ms;
  transition: none;
  display: flex;
  position: relative;
  opacity: 0;
  flex-wrap: wrap;
  width: 100%;
  padding: 5px;
}
.edit-mode section .section-tools ul li {
  flex: 1;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}
.edit-mode section .section-tools:hover {
  opacity: 1;
  max-width: none;
  max-height: none;
  height: auto;
  top: 5px;
  right: 5px;
  width: 200px;
  transition: background-color 300ms ease;
  border-radius: 15px;
}
.edit-mode section .section-tools:hover ul {
  transition: none;
  opacity: 1;
  position: relative;
  pointer-events: all;
}
.edit-mode [web-grid=false] .product-collections .collection-container-tools {
  left: 5px;
}
.edit-mode [web-grid=false] .product-collections .collection-container-tools .collection-container-add {
  display: none;
}
.edit-mode [web-grid=false] .product-collections .collection-container-tools .collection-container-flex {
  display: none;
}
.edit-mode [web-grid=false] .product-collections .collection-container-tools:hover {
  left: 0;
  top: 0;
  height: calc(100% + 0px);
  width: calc(100% + 0px);
}

footer {
  z-index: 5;
  display: flex;
  font-size: 14px;
  background: #335f12;
  color: #eeeeee;
  justify-content: center;
  align-items: center;
  font-weight: 300;
}
@media (min-width: 1024px) {
  footer {
    z-index: 2;
    padding: 75px 50px;
  }
  .edit-mode footer {
    padding-bottom: 150px;
  }
}
footer .footer-content {
  position: relative;
  display: flex;
  transition: all 300ms ease;
  max-width: 1100px;
}
@media (max-width: 1023px) {
  footer .footer-content {
    padding-bottom: 80px;
  }
  .active-cart footer .footer-content {
    padding-bottom: 120px;
  }
}
@media (min-width: 1024px) {
  footer .footer-content ul {
    padding: 0px 0px 0px 0;
  }
  footer .footer-content ul.legal {
    padding: 0px 0px;
    margin-top: 25px;
  }
}
@media (max-width: 1023px) {
  footer {
    position: fixed;
    top: 0;
    left: 0;
    transform: translateX(-100vw);
    width: 100vw;
    height: 100%;
    max-width: 500px;
    transition: transform 250ms ease-out, top 250ms ease-out;
    pointer-events: none;
    overflow: auto;
  }
  footer .footer-content {
    width: 100vw;
    height: 100%;
    flex-direction: column;
    overflow-x: hidden;
  }
}
@media (max-width: 1023px) and (max-width: 1024px) {
  .mobile-fixed-footer footer {
    top: auto;
    left: auto;
    transform: none;
    height: auto;
    pointer-events: all;
    overflow: visible;
    position: relative;
  }
  .mobile-fixed-footer footer .hide-fixed-footer {
    display: none !important;
  }
}
@media (min-width: 1024px) {
  footer {
    position: relative;
    width: 100%;
  }
  footer .footer-content {
    width: 100%;
    flex-direction: row;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 10px 10px;
  }
}
.show-nav footer {
  transform: translateX(0);
  pointer-events: all;
  opacity: 1;
  z-index: 22;
}
.show-nav footer .footer-content {
  box-shadow: 15px 0px 50px 0px #000;
}
footer ul {
  list-style-type: none;
  display: flex;
  margin: 0;
  padding: 0;
  flex-direction: column;
  padding: 0px;
  flex: 1;
  order: 2;
  background: #335f12;
  width: 100%;
  position: relative;
  z-index: 2;
}
footer ul.resources li a {
  text-transform: capitalize;
}
@media (min-width: 1024px) {
  footer ul {
    gap: 10px;
  }
}
footer ul.pin {
  position: sticky;
  top: 0;
  z-index: 3;
  background: #335f12;
  min-width: 100%;
  display: none;
  padding: 15px 15px;
}
@media (max-width: 1023px) {
  footer ul.pin {
    display: flex;
  }
}
footer ul.pin:before {
  background-color: #000;
  opacity: 0.1;
  content: "";
  height: 100%;
  width: 100%;
  left: 0;
  top: 0;
  position: absolute;
  z-index: 0;
  pointer-events: none;
}
footer ul.bio {
  min-width: 100%;
  flex: 40;
}
@media (max-width: 1023px) {
  footer ul.bio {
    order: 3;
  }
}
@media (min-width: 1024px) {
  footer ul.bio {
    order: 1;
  }
}
footer ul.legal {
  min-width: 100%;
  background: #335f12;
  order: 4;
  align-items: center;
  justify-content: center;
}
@media (max-width: 1023px) {
  footer ul.legal {
    padding-bottom: 50px;
    padding: 0 20px 25px 20px;
  }
}
footer ul.legal li {
  align-items: center;
}
footer ul.legal:before {
  opacity: 0.2;
  content: "";
  height: 100%;
  width: 100%;
  left: 0;
  top: 0;
  position: absolute;
  z-index: 0;
  pointer-events: none;
}
footer ul li {
  display: flex;
  margin: 0;
  padding: 5px 0;
  width: 100%;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1333333333);
}
footer ul li:last-child {
  border-bottom: 0;
}
footer ul li a {
  display: inline-flex;
  justify-content: flex-start;
  align-items: center;
  line-height: normal;
  padding: 15px 15px;
  width: 100%;
}
footer ul li a.button {
  border-radius: 0;
  opacity: 1;
  width: auto;
  padding: 15px 25px;
  text-transform: uppercase;
  font-size: 18px;
  white-space: nowrap;
  font-weight: 300;
}
@media (max-width: 1023px) {
  footer ul li a.button {
    margin-left: 20px;
  }
}
footer ul li a.button.login-button {
  background-color: #333;
  color: #fff;
}
footer ul li a.button.book-a-chat-button {
  background-color: #dcf4ca;
  color: #2c5111;
}
@media (max-width: 1023px) {
  footer ul li a {
    text-align: left;
    justify-content: flex-start;
    padding: 7.5px 20px;
  }
}
footer ul li i {
  width: 25px;
  font-size: 160%;
  margin-right: 7.5px;
}
footer ul li.basic {
  padding: 0;
}
@media (max-width: 1023px) {
  footer ul li.basic {
    padding: 15px 20px;
  }
}
footer ul li.top {
  display: flex;
  align-items: center;
  padding: 15px 15px;
  font-size: 18px;
  font-weight: 600;
  text-transform: uppercase;
  color: #fff;
  margin-bottom: 10px;
  font-family: "dosis";
}
@media (min-width: 1024px) {
  footer ul li.top {
    margin-top: 10px;
  }
  footer ul li.top:first-child {
    margin-top: 0;
  }
}
@media (max-width: 1023px) {
  footer ul li.top {
    background-color: rgba(0, 0, 0, 0.1019607843);
    padding: 10px 20px;
    margin: 0;
  }
}
@media (min-width: 1024px) {
  footer ul li {
    padding: 0;
    border: 0;
  }
  footer ul li a {
    padding: 0px 0;
    border: 0;
  }
  footer ul li.top {
    padding: 0;
    margin-bottom: 5px;
  }
}

.frame-passcode {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
}
.frame-passcode form {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 50px;
}
.frame-passcode form .message {
  font-size: 40px;
  font-weight: 900;
  margin-bottom: 10px;
  font-style: italic;
}
.frame-passcode form .sub-message {
  margin-bottom: 20px;
}
.frame-passcode form input[type=number] {
  font-size: 30px;
  width: 200px;
  font-weight: 600;
  padding: 10px 20px;
}
.frame-passcode form input[type=number]::placeholder {
  font-style: italic;
  color: #aaa;
}
.frame-passcode form button {
  font-size: 30px;
  padding: 10px 20px;
  margin: 0;
  border: 0px solid #000;
  font-weight: 600;
  text-transform: uppercase;
  background-color: rgba(0, 0, 0, 0.6);
  color: #fff;
  margin-top: 10px;
  width: 200px;
}

.frame-passcode .show-status, .passcode-area .show-status {
  display: none;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}
.frame-passcode [data-status=pending] .show-pending, .passcode-area [data-status=pending] .show-pending {
  display: flex;
}
.frame-passcode [data-status=message-sent] .show-message-sent, .passcode-area [data-status=message-sent] .show-message-sent {
  display: flex;
}
.frame-passcode [data-status=invalid-account] .show-invalid-account, .passcode-area [data-status=invalid-account] .show-invalid-account {
  display: flex;
}
.frame-passcode [data-status=invalid-passcode] .show-invalid-passcode, .passcode-area [data-status=invalid-passcode] .show-invalid-passcode {
  display: flex;
}
.frame-passcode [data-status=redirect] .show-redirect, .passcode-area [data-status=redirect] .show-redirect {
  display: flex;
}

.tab-table {
  display: flex;
  flex-direction: column;
}
.tab-table .tab-headers {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  position: relative;
  padding-top: 5px;
}
.tab-table .tab-headers.sticky {
  position: sticky;
}
.tab-table .tab-headers.sticky.top65 {
  top: 65px;
}
.tab-table .tab-headers.sticky.top105 {
  top: 65px;
}
.show-search .tab-table .tab-headers.sticky.top105 {
  top: 105px;
}
.tab-table .tab-headers .tab-header {
  padding: 10px 20px 15px 20px;
  position: relative;
  font-weight: 600;
}
.tab-table .tab-headers .tab-header:before {
  content: "";
  border-radius: 5px;
  height: 5px;
  background-color: currentColor;
  width: 100%;
  bottom: -2px;
  opacity: 0;
  transition: all 300ms ease;
  left: 0;
  position: absolute;
}
.tab-table .tab-headers .tab-header.active:before {
  opacity: 1;
}
.tab-table .tabs {
  transform: translateY(-2.5px);
  width: 100%;
  position: relative;
  z-index: 1;
}
.tab-table .tabs .tab {
  display: none;
  background-color: #ddd;
  padding: 20px;
  position: relative;
  flex-direction: column;
  width: 100%;
}
.tab-table .tabs .tab.active {
  display: flex;
}

.dial {
  /* optional text styling (kept minimal) */
}
.dial .dial-score {
  fill: currentColor;
  font-size: 27px;
  font-weight: 800;
  text-anchor: middle;
  dominant-baseline: middle;
}
.dial .dial-sub {
  fill: currentColor;
  opacity: 1;
  font-size: 13px;
  font-weight: 500;
  text-anchor: middle;
  dominant-baseline: middle;
  transform: translateY(-3px);
}
.dial svg {
  display: block;
}
.dial .labels {
  position: absolute;
  top: 50%;
  transform: translateY(-50%) translateX(-50%);
  left: 50%;
  width: 100%;
  height: 170px;
  font-size: 16px;
  font-weight: 500;
  text-transform: uppercase;
}
.dial .labels .label {
  position: absolute;
  white-space: nowrap;
  font-size: 13px;
  text-align: center !important;
  padding: 3px;
  border-radius: 5px;
  opacity: 1;
  line-height: normal;
}
.dial .labels .label .ext {
  position: absolute;
  bottom: -18px;
  left: 0;
  width: 100%;
  text-align: center;
  font-size: 12px;
  opacity: 1;
  font-weight: 400;
}
.dial .labels .label.active {
  opacity: 1;
  box-shadow: 0px 0px 0px 2px #dcf4ca;
}
.dial .labels .label:first-child {
  bottom: 0px;
  left: 0%;
  text-align: right;
  width: 85px;
  color: #e6de8b;
  width: calc(25% + 20px);
}
.dial .labels .label:last-child {
  bottom: 0px;
  right: 0%;
  text-align: left;
  width: 85px;
  color: #8c8e8f;
  width: calc(25% + 20px);
}
.dial .labels.items-5 .label:nth-child(4) {
  right: 0%;
  text-align: left;
  width: 65px;
  color: #57595a;
}
.dial .labels.items-5 .label:nth-child(3) {
  top: -35px;
  left: 50%;
  transform: translateX(-50%);
  color: #ba603d;
}
.dial .labels.items-5 .label:nth-child(2) {
  left: 0%;
  text-align: right;
  width: 65px;
  color: #c7a55a;
}
.dial .labels.items-4 .label:nth-child(3) {
  right: 0%;
  text-align: left;
  width: 85px;
  color: #57595a;
  width: calc(25% + 20px);
}
.dial .labels.items-4 .label:nth-child(2) {
  left: 0%;
  text-align: right;
  width: 85px;
  color: #c7a55a;
  width: calc(25% + 20px);
}
.dial .labels.items-3 .label:nth-child(2) {
  top: -35px;
  left: 50%;
  transform: translateX(-50%);
  color: #ba603d;
}

.frame-home .collection-header {
  width: 100%;
  overflow: hidden;
  height: 200px;
  background-position: center;
  background-size: cover;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 30px;
  font-weight: 600;
  padding: 20px;
  font-family: "Fredoka";
  line-height: normal;
  text-align: center;
  background-color: #333;
  color: #fff;
  position: relative;
}
.frame-home .collection-header video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 0;
}
.frame-home .collection-header .collection-title {
  position: relative;
  z-index: 2;
}
.overlay .frame-home .collection-header .collection-title {
  display: none;
}
@media (min-width: 1024px) {
  .frame-home .collection-header {
    justify-content: flex-start;
    line-height: normal;
    padding: 50px;
    font-size: 40px;
    height: 175px;
    text-align: left;
  }
}

@media (min-width: 1024px) {
  main .frame-main .frame-home .contained {
    display: flex;
    flex-wrap: wrap;
    transition: transform 300ms ease;
  }
  main .frame-main .frame-home .contained .filter.side-filter, main .frame-main .frame-home .contained .products-container {
    transition: transform 300ms ease;
  }
  main .frame-main .frame-home .contained .highlight {
    width: 100%;
  }
  main .frame-main .frame-home .contained .highlight.d-cat {
    background-color: transparent;
  }
  main .frame-main .frame-home .contained .products-container {
    width: calc(100% - 345px);
    border-radius: 0px;
    border-left: 0;
    margin-top: 25px;
    margin-bottom: 25px;
  }
}
.passcode-area .show-status {
  display: none;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  width: 100%;
}
.passcode-area .show-status > div {
  width: 100%;
}
.passcode-area [data-status=pending] .show-pending {
  display: flex;
}
.passcode-area [data-status=message-sent] .show-message-sent {
  display: flex;
}
.passcode-area [data-status=invalid-account] .show-invalid-account {
  display: flex;
}
.passcode-area [data-status=invalid-passcode] .show-invalid-passcode {
  display: flex;
}
.passcode-area [data-status=ask-for-passcode] .show-ask-for-passcode {
  display: flex;
}
.passcode-area [data-status=redirect] .show-redirect {
  display: flex;
}

.show-user-verified {
  display: none;
  width: 100%;
}

.user-verified .show-user-verified {
  display: block;
}
.user-verified .show-user-verified.flex {
  display: flex;
}
.user-verified .show-user-verified.inline-flex {
  width: auto;
  display: inline-flex;
}
.user-verified .hide-user-verified {
  display: none !important;
}

.home-signin {
  padding: 25px 25px;
  display: flex;
  flex-direction: column;
  gap: 15px;
  color: #ffffff;
  background-color: #2d6105;
  line-height: normal;
  margin-top: 5px;
}
.home-signin .signin-title {
  font-weight: 600;
  font-size: 18px;
  text-align: center;
}
.home-signin .signin-form {
  display: flex;
  gap: 15px;
  align-items: center;
  position: relative;
}
.home-signin .signin-form .input {
  flex: 1;
  height: 100%;
  position: relative;
}
.home-signin .signin-form .input input {
  position: relative;
  height: 100%;
  width: 100%;
  border: 0;
  padding: 10px;
  font-size: 16px;
  height: 40px;
  border-radius: 10px;
}
.home-signin .signin-form .submit {
  position: relative;
  height: 100%;
}
.home-signin .signin-form .submit a {
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  white-space: nowrap;
  font-size: 14px;
  font-weight: 600;
  background-color: #62b622;
  padding: 5px 15px;
  border-radius: 10px;
}

.dialpad {
  margin-top: 10px;
  display: inline-flex;
  flex-wrap: wrap;
  position: relative;
  border-bottom: 0;
  border-right: 0;
  gap: 5px;
  align-items: center;
  justify-content: center;
  font-size: 65%;
  user-select: none;
  width: 100%;
}
.dialpad > div {
  width: calc(33.333333% - 4px);
  padding: 16px 2px;
  background-color: rgba(0, 0, 0, 0.2);
  transition: all 300ms ease;
  cursor: pointer;
  text-align: center;
}
.dialpad > div:hover {
  opacity: 0.8;
}
.dialpad > div.disabled {
  opacity: 0.5;
}

.contact-info {
  margin-bottom: 20px;
}
.contact-info .points-title {
  font-size: 3.5vw;
}

.frame-home .redemptions-section {
  position: relative;
  color: #2c5111;
  background-color: #000;
  z-index: 1;
  display: none;
}
.frame-home .redemptions-section > div {
  position: relative;
  z-index: 2;
}
.frame-home .redemptions-section:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #000;
  pointer-events: none;
  z-index: 0;
  background-color: #dcf4caff;
}
.frame-home .home-redemptions-container {
  min-width: 100%;
  width: 100%;
  padding: 0;
}
.frame-home .home-redemptions-container > .hide-user-verified, .frame-home .home-redemptions-container > .show-user-verified {
  height: 100%;
  width: 100%;
}
@media (max-width: 1023px) {
  .frame-home .home-redemptions-container {
    order: 1;
  }
}
.frame-home .home-redemptions {
  min-width: 100%;
  display: flex;
  width: 100%;
  gap: 5px;
  flex-direction: column;
  height: 100%;
  background: linear-gradient(to bottom, #dcf4ca99, #dcf4ca);
  background: radial-gradient(circle at 20% 30%, rgba(255, 255, 255, 0.1), transparent 70%), linear-gradient(120deg, #62b62255, #62b62266, #62b62277, #62b62233);
  border-radius: var(--web-grid-roundingMobile);
}
@media (min-width: 1024px) {
  .frame-home .home-redemptions {
    border-radius: var(--web-grid-rounding);
  }
}
.frame-home .home-redemptions .rewards-signin-container {
  padding: 15px 15px 0 15px;
}
.frame-home .home-redemptions .rewards-signin-container .signin-title {
  font-size: 105%;
  font-weight: 600;
}
.frame-home .home-redemptions .rewards-signin-container .passcode-form {
  display: flex;
  flex-direction: row;
  gap: 15px;
  white-space: nowrap;
  align-items: center;
}
.frame-home .home-redemptions .rewards-signin-container .passcode-form .enable-face-id {
  display: none;
}
.frame-home .home-redemptions .rewards-signin-container input[type=tel] {
  width: 100%;
  padding: 10px 20px;
  border-radius: 5px;
  border: 1px solid rgba(0, 0, 0, 0.3333333333);
  font-size: 20px;
  font-weight: 600;
}
.frame-home .home-redemptions .redemptions-section-title {
  width: 100%;
  min-width: 100%;
  padding: 15px 15px 10px 15px;
  line-height: normal;
  font-weight: 600;
  font-size: 18px;
}
.frame-home .home-redemptions ul {
  min-width: 100%;
  display: flex;
  overflow: auto;
  width: 100%;
  gap: 15px;
  list-style-type: none;
  margin: 0;
  padding: 5px 10px 5px 10px;
  align-items: center;
  justify-content: space-around;
}
@media (min-width: 1024px) {
  .frame-home .home-redemptions ul {
    flex-wrap: wrap;
  }
}
.frame-home .home-redemptions ul li {
  width: 100px;
  min-width: 100px;
  max-width: 100px;
  flex: 1;
  line-height: normal;
  overflow: hidden;
  padding: 10px 10px 10px 10px;
}
.frame-home .home-redemptions ul li a {
  display: flex;
  flex-direction: column;
  width: 100%;
  line-height: normal;
  padding: 0 !important;
  position: relative;
}
.frame-home .home-redemptions ul li a .button {
  display: none;
  padding: 5px 5px;
  width: 100%;
  font-size: 12px;
  text-align: center;
  font-weight: 400;
  line-height: normal;
}
.user-verified .frame-home .home-redemptions ul li a .button {
  display: block;
}
.frame-home .home-redemptions ul li a.disabled .button {
  opacity: 0.5;
}
.frame-home .home-redemptions ul li .image {
  display: flex;
  background-image: url(https://blackleaf.io/wp-content/uploads/2025/08/rewards-splash.png);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  height: 80px;
  padding: 0px;
  width: 80px;
}
.frame-home .home-redemptions ul li .image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 1;
}
.frame-home .home-redemptions ul li .pricing,
.frame-home .home-redemptions ul li .meta {
  white-space: nowrap;
  flex: 1;
  text-transform: uppercase;
  font-size: 11px;
  text-align: center;
  padding: 3px 5px;
  overflow: hidden;
  text-overflow: ellipsis;
}
.frame-home .home-redemptions ul li .meta {
  font-weight: 300;
  padding-bottom: 0px;
}
.frame-home .home-redemptions ul li .pricing {
  font-weight: 600;
  padding-top: 0px;
  position: absolute;
  background-color: #dcf4ca;
  color: #2c5111;
  padding: 3px 5px;
  border-radius: 5px;
}
.frame-home .xhome-redemptions ul li[redemption-popup="1"] a {
  margin-left: 10px;
}
.frame-home .xhome-redemptions ul li {
  position: relative;
}
.frame-home .xhome-redemptions ul li a {
  padding: 5px 4px;
  display: inline-block;
  width: 90px;
  position: relative;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.frame-home .xhome-redemptions ul li a .redemption-points {
  position: relative;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1;
  background-color: rgba(0, 0, 0, 0.0666666667);
  font-size: 11px;
  padding: 2px;
  font-weight: 500;
  border-top-right-radius: 5px;
  border-top-left-radius: 5px;
}
.frame-home .xhome-redemptions ul li a .redemption-image {
  position: relative;
  width: 100%;
  display: flex;
  background-color: #fff;
  padding: 5px;
}
.frame-home .xhome-redemptions ul li a .redemption-image img {
  object-fit: contain;
  width: 100%;
  height: 60px;
}
.frame-home .xhome-redemptions ul li a .redemption-title {
  position: relative;
  bottom: 0;
  left: 0;
  width: 100%;
  z-index: 1;
  background-color: rgba(0, 0, 0, 0.0666666667);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  padding: 2px 5px;
  font-size: 11px;
  font-weight: 500;
  text-transform: uppercase;
  border-bottom-right-radius: 5px;
  border-bottom-left-radius: 5px;
}
.frame-home .xhome-redemptions ul li .redemption-action {
  display: none;
}

.texture-background-1:before {
  background-image: url("https://www.transparenttextures.com/patterns/bedge-grunge.png");
}

.texture-background-2:before {
  background-image: url("https://www.transparenttextures.com/patterns/black-felt.png");
}

.texture-background-3:before {
  background-image: url("https://www.transparenttextures.com/patterns/black-paper.png");
}

.texture-background-4:before {
  background-image: url("https://www.transparenttextures.com/patterns/brick-wall-dark.png");
}

.texture-background-5:before {
  background-image: url("https://www.transparenttextures.com/patterns/bright-squares.png");
}

.texture-background-6:before {
  background-image: url("https://www.transparenttextures.com/patterns/brushed-alum.png");
}

.texture-background-7:before {
  background-image: url("https://www.transparenttextures.com/patterns/buried.png");
}

.product-collections {
  /*
  &:nth-child(even) {
      .product-collection {
          &:first-child {
              background-color: #62b622;
              color: $highlightColor;

          }
          &:nth-child(even) {
              background-color: #62b622;
              color: $highlightColor;

          }

      }

  }
  */
}
.product-collections .product-collection {
  background: linear-gradient(135deg, #eeeeeeee 25%, #eeeeee 25%, #eeeeee 50%, #eeeeeeee 50%, #eeeeeeee 75%, #eeeeee 75%, #eeeeee 100%);
  background-size: 5px 5px;
  background-color: #62b622;
  /*
  &:nth-child(even) {
      background-color: #62b622;
      color: $highlightColor;
  }
  &:nth-child(1),&:nth-child(5) {
      background-color: #lightBackground;
      color: $lightColor;

  }
  */
}
.product-collections .product-collection.products-list-container {
  background: none;
  width: 100%;
}

.product-collection {
  padding: 0px;
  position: relative;
  overflow: hidden;
  transition: all 300ms ease;
}
@media (min-width: 1024px) {
  .edit-mode .product-collection.ui-draggable:after {
    content: "";
    pointer-events: none;
    width: calc(100% - 2px);
    height: calc(100% - 2px);
    left: 0;
    top: 0;
    position: absolute;
    border: 1px dashed #lightBackground;
    z-index: 4;
    border-radius: var(--web-grid-rounding);
  }
}
.vibe-rounded .product-collection {
  box-shadow: 2px 3px 7px -2px rgba(0, 0, 0, 0.3215686275);
}
.product-collection a, .product-collection .product-collection-inner {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
}
@media (min-width: 1024px) {
  .product-collection a:before, .product-collection .product-collection-inner:before {
    opacity: 1;
    content: "";
    position: absolute;
    width: 100%;
    left: 0;
    height: 100%;
    top: 0;
    pointer-events: none;
    opacity: 0;
    transition: all 300ms ease;
    z-index: 3;
  }
  .vibe-rounded .product-collection a:before, .vibe-rounded .product-collection .product-collection-inner:before {
    border-radius: 10px;
  }
}
.product-collection:before {
  content: "";
  pointer-events: none;
  opacity: 0.5;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  position: absolute;
  z-index: 0;
}
@media (max-width: 1023px) {
  section.highlight .product-collections.option-main .product-collection:first-child {
    display: none;
  }
}
.show-off-header {
  position: relative;
}
.show-off-header:before, .show-off-header:after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  z-index: 0;
  height: 100%;
  width: 100%;
}
.show-off-header:before {
  background-color: #dcf4ca;
  transform: rotate(-2deg);
  z-index: 2;
}
.show-off-header:after {
  background-color: #62b622;
  transform: rotate(-4deg);
  z-index: 1;
}
.show-off-header span {
  z-index: 3;
  position: relative;
  display: flex;
  background-color: #lightBackground;
  color: #lightColor;
  padding: 3px 5px;
}

.dragging.edit-mode .product-collections:empty {
  align-self: initial;
}

.edit-mode .pc-dragging {
  opacity: 1;
}
.edit-mode .product-collections:empty {
  align-self: flex-start;
  /*&:before {
      content: "Add a Collection";
      width: 100%;
      align-self: flex-start;
      background-color: #eee;
      color: #111;
      padding: 15px;
      border: 2px solid #00000033;            
      border-radius: $buttonRounding;
      text-align: center;
      cursor: pointer;
      transition: all 200ms ease;
  }*/
}
.edit-mode .product-collections:empty:hover:before {
  background-color: #lightBackground;
  color: #lightColor;
}
.edit-mode .product-collection.clone {
  rotate: 5deg;
}
.edit-mode .pc-ghost {
  rotate: 3deg;
  opacity: 1;
  overflow: hidden;
  box-shadow: 0px 0px 5px 0px #lightBackground;
  pointer-events: none;
  height: auto !important;
  animation: bounce-in 300ms ease 0ms both;
}
.edit-mode.dragging .product-collection {
  opacity: 0.5;
}
.edit-mode.dragging .product-collection.pc-ghost {
  opacity: 1;
}
.edit-mode.dragging .product-collection.clone {
  opacity: 0.8;
  scale: 0.5;
  transform-origin: center;
}
.edit-mode .product-collection {
  transition: box-shadow 300ms ease;
}
.edit-mode .product-collection a {
  pointer-events: none;
  transition: none;
}

@keyframes slide-up {
  from {
    transform: translateY(100%);
  }
  to {
    transform: translateY(0);
  }
}
@keyframes slide-down {
  from {
    top: 0px;
    scale: 0.1;
  }
  to {
    top: -20px;
    scale: 1;
  }
}
@keyframes pop-in {
  from {
    scale: 0.2;
  }
  to {
    scale: 1;
  }
}
.pop-in {
  animation: pop-in 300ms ease 0ms both;
}

@keyframes bounce-in {
  0% {
    scale: 1;
  }
  75% {
    scale: 1.1;
  }
  110% {
    scale: 1.05;
  }
  100% {
    scale: 1;
  }
}
.bounce-in {
  animation: bounce-in 300ms ease 0ms both;
}

.product-collection {
  position: relative;
  width: calc(50% - 2.5px);
  line-height: normal;
  font-family: "Fredoka";
  order: 2;
}
.product-collection.hide {
  display: none !important;
}
@media (max-width: 1023px) {
  .product-collection {
    min-width: calc(50% - 2.5px);
    border-radius: var(--web-grid-roundingMobile);
  }
}
.product-collection .collection-cta-header {
  display: none;
  font-weight: 500;
  z-index: 2;
}
.product-collection .collection-cta-button {
  font-size: 75%;
  margin-top: 15px;
  text-decoration: underline;
  z-index: 1;
  font-weight: 300;
}
@media (max-width: 1023px) {
  .product-collection .collection-cta-button {
    background-color: #62b622;
    padding: 5px 10px;
    text-decoration: none;
    font-weight: 500;
    color: #ffffff;
    border: 1px solid rgba(0, 0, 0, 0.1803921569);
    font-size: 12px;
    box-shadow: 2px 2px 2px 0px rgba(0, 0, 0, 0.1607843137);
    border-radius: var(--web-button-roundingMobile);
  }
}
@media (min-width: 1024px) {
  .product-collection .collection-cta-button {
    background-color: rgba(0, 0, 0, 0.3098039216);
    padding: 5px 10px;
    text-decoration: none;
    font-weight: 500;
    color: #ffffff;
    border: 1px solid rgba(0, 0, 0, 0.1803921569);
    font-size: 12px;
    text-shadow: 0.5px 0.5px #000000;
    box-shadow: 2px 2px 2px 0px rgba(0, 0, 0, 0.1607843137);
    border-radius: var(--web-button-rounding);
  }
}
.product-collection .collection-title {
  font-weight: 600;
  font-size: 18px;
  z-index: 4;
}
.product-collection .collection-ctaTitle {
  z-index: 4;
}
.product-collection .collection-ctaHeader {
  z-index: 4;
}
@media (min-width: 1024px) {
  .product-collection {
    width: 100%;
    border-radius: var(--web-grid-rounding);
  }
  .product-collection .collection-title {
    line-height: normal;
  }
}
.product-collection.full {
  width: 100%;
}
.product-collection .product-collection-inner {
  display: flex;
  width: 100%;
  height: 100%;
  position: relative;
  padding: 15px;
  flex-direction: column;
  text-align: left;
  position: absolute;
  top: 0;
  left: 0;
  font-size: 18px;
  font-family: "Fredoka";
  align-items: flex-start;
}
.product-collection .product-collection-inner.pos-relative {
  position: relative;
  height: auto;
  padding-bottom: 0;
}

.product-collections {
  display: flex;
  flex-wrap: wrap;
  position: relative;
  flex-direction: column;
  order: 2;
  position: relative;
}
.product-collections video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 2;
  pointer-events: none;
}
.product-collections .featured-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}
.product-collections canvas {
  z-index: 0;
}
@media (min-width: 1024px) {
  .product-collections {
    margin-bottom: 0;
  }
  .product-collections .product-collection {
    flex: 1 1 auto;
  }
  .product-collections.no-rounding .product-collection {
    border-radius: 0;
  }
  .product-collections.option-main {
    flex-direction: row;
  }
  .product-collections.option-main .product-collection {
    flex: none;
  }
}
.product-collections.option-main .product-collection:nth-child(2), .product-collections.option-1 .product-collection:nth-child(2), .product-collections.option-2 .product-collection:nth-child(2) {
  position: absolute;
  right: 0px;
  top: 0px;
}
@media (min-width: 1024px) {
  .product-collections.option-main .product-collection:nth-child(2), .product-collections.option-1 .product-collection:nth-child(2), .product-collections.option-2 .product-collection:nth-child(2) {
    position: relative;
    top: auto;
    left: auto;
  }
}
.product-collections.product-of-the-day .product-collection {
  background-color: #dcf4ca;
  color: #2c5111;
  /*
  &:nth-child(odd) {
      background-color: $glowBackground;
      color: $glowColor;
      .collection-cta-header {
          color: $lightColor;
          background-color: $lightBackground;
      }
  }
  &:nth-child(even) {
      background-color: $lightBackground;
      color: $lightColor;
      .collection-cta-header {
          color: $glowColor;
          background-color: $glowBackground;
      }
  }
      */
}
.product-collections.product-of-the-day .product-collection:nth-child(odd) {
  background-color: #dcf4ca;
  color: #2c5111;
}
.product-collections.product-of-the-day .product-collection:nth-child(even) {
  background-color: #62b622;
  color: #ffffff;
}
.product-collections.product-of-the-day .product-collection .collection-cta-header {
  display: flex;
  align-self: flex-start;
  margin-bottom: 15px;
  font-size: 80%;
  font-weight: 400;
}
.product-collections.product-of-the-day .product-collection .collection-cta-header span {
  padding: 5px 10px;
}
.product-collections.option-main .product-collection:nth-child(1) a {
  align-items: flex-start;
}
@media (max-width: 1023px) {
  .floating-header .product-collections.option-main .product-collection:nth-child(1) a {
    padding-top: 100px;
  }
}
.product-collections.option-main .product-collection:nth-child(1) .collection-title {
  display: flex;
  position: relative;
  margin: 10px 0;
}
@media (max-width: 1023px) {
  .product-collections.option-2 {
    margin-bottom: 15px;
  }
  .product-collections.option-main {
    order: 1;
  }
  .product-collections.option-main.first-child {
    margin-top: 0;
  }
  .product-collections.option-main .product-collection:nth-child(1) {
    padding-top: 66%;
    width: 100%;
  }
  .floating-header .product-collections.option-main .product-collection:nth-child(1) {
    padding-top: 100%;
  }
  .product-collections.option-main .product-collection:nth-child(1) .collection-cta-header {
    display: block;
  }
  .product-collections.option-main .product-collection:nth-child(1) .collection-title {
    font-size: 30px;
    line-height: 100%;
  }
  .product-collections.option-main .product-collection:nth-child(1) .collection-cta-button {
    margin-top: 15px;
    border-radius: 20px;
    border: 1px solid #62b622;
    color: #ffffff;
    background-color: #62b622;
    padding: 7.5px 15px;
    text-decoration: none;
    font-weight: 600;
    font-size: 13px;
    background-color: #fff;
    color: #111;
    border: none;
  }
  .product-collections.option-main .product-collection:nth-child(2) {
    padding-top: 33%;
    position: relative;
  }
  .product-collections.option-main .product-collection:nth-child(3) {
    padding-top: calc(52% - 15px);
  }
  .product-collections.option-main .product-collection:nth-child(4) {
    padding-top: 82.4%;
    position: absolute;
    right: 0px;
  }
  .product-collections.option-main .product-collection:nth-child(5) {
    padding-top: 40%;
    width: 100%;
  }
  .product-collections.product-of-the-day .product-collection {
    padding-top: 35%;
    width: 100%;
  }
  .product-collections.product-of-the-day .product-collection a {
    background-position-x: 95% !important;
    background-position-y: center !important;
    background-size: 25% !important;
  }
  .product-collections.banner .product-collection {
    padding-top: 35%;
    width: 100%;
  }
}
@media (min-width: 1024px) {
  .product-collections {
    min-width: calc(25% - 7.5px);
    flex: 1 1 25%;
    min-width: 20%;
  }
  .product-collections.option-main {
    width: calc(50% - 0px);
    flex: 1 1 50%;
  }
  .product-collections.option-main .product-collection:nth-child(1).floating {
    padding-top: 60%;
  }
  .product-collections.option-main .product-collection:nth-child(1) .collection-cta-header {
    display: block;
  }
  .product-collections.option-main .product-collection:nth-child(1) .collection-title {
    font-size: 40px;
    font-weight: 500;
  }
  .product-collections.option-main .product-collection:nth-child(1) .collection-cta-button {
    margin-top: 15px;
    border-radius: 30px;
    border: 1px solid #000;
    color: #darkColor;
    background-color: #fff;
    padding: 7.5px 15px;
    text-decoration: none;
    font-weight: 500;
    font-size: 16px;
    color: #000;
    border: 1px solid rgba(0, 0, 0, 0.1019607843);
    box-shadow: 2px 2px 2px 0px rgba(0, 0, 0, 0.1607843137);
    text-shadow: none;
  }
  .product-collections.option-main .product-collection.floating:nth-child(2), .product-collections.option-main .product-collection.floating:nth-child(3) {
    padding-top: 50%;
    width: calc(50% - 12.5px);
    width: auto;
    flex: 1;
  }
  .product-collections.option-full {
    width: calc(100% - 0px);
    flex: 1 1 100%;
  }
  .product-collections.option-75 {
    width: calc(75% - 0px);
    flex: 1 1 75%;
  }
  .product-collections.option-50 {
    width: calc(50% - 0px);
    flex: 1 1 50%;
  }
  .product-collections.option-25 {
    width: calc(25% - 0px);
    flex: 1 1 25%;
  }
  .product-collections.product-of-the-day {
    flex-wrap: nowrap;
    width: calc(100% + 50px);
    transform: translateX(-25px);
  }
  .product-collections.product-of-the-day .product-collection {
    padding-top: 30%;
  }
  .product-collections.product-of-the-day .product-collection a {
    background-position-y: 95% !important;
    background-position-x: center !important;
    background-size: 70% !important;
  }
  .product-collections.banner {
    display: none;
  }
  .product-collections.banner .product-collection {
    padding-top: 35%;
    width: 100%;
  }
}

.punch-card {
  padding: 15px;
  border-radius: 10px;
  border: 2px dashed #111;
  background-color: #fff;
}
.punch-card .punch-card-title {
  margin-bottom: 10px;
  font-weight: 600;
}
.punch-card .punch-card-description {
  margin-top: 10px;
  font-size: 12px;
}
.punch-card .punch-card-label {
  font-size: 12px;
  text-transform: uppercase;
  margin-bottom: 5px;
  font-weight: 500;
}
.punch-card .punch-card-items {
  display: flex;
  gap: 5px;
  width: 100%;
  position: relative;
  justify-content: space-between;
}
.punch-card.mission-card .punch-card-items {
  align-items: center;
  gap: 10px;
}
.punch-card .progress-container {
  position: relative;
  width: 100%;
  border-radius: 10px;
  height: 15px;
  background-color: #ddd;
}
.punch-card .progress-container .progress {
  position: absolute;
  left: 0px;
  top: 0px;
  height: calc(100% - 0px);
  background-color: #62b622;
  border-radius: 10px;
}
.punch-card .valid {
  font-size: 12px;
  margin-top: 10px;
  opacity: 0.7;
}
.punch-card .progress-of {
  white-space: nowrap;
  font-size: 12px;
}

.punch {
  height: 25px;
  max-width: 25px;
  min-width: 25px;
  display: flex;
  background-color: #ddd;
  border-radius: 5px;
  position: relative;
}
.punch.active {
  background-color: #62b622;
}

.redemptions-list {
  padding: 10px 0;
}
.redemptions-list ul {
  width: 100%;
  list-style-type: none;
  margin: 0;
  padding: 0;
  display: flex;
  position: relative;
  z-index: 1;
}
.redemptions-list ul li {
  flex: 1;
}
.redemptions-list .my-redemptions .redemption {
  flex: none;
}
.redemptions-list .my-redemptions .redemption a {
  max-width: 100px;
}
.redemptions-list .redemption a .redemption-points, .redemptions-list .redemption a .redemption-title {
  background-color: #62b622;
  color: #ffffff;
}
.redemptions-list .redemption a {
  margin-left: 15px;
  display: flex;
  min-width: 80px;
  flex-direction: column;
  overflow: hidden;
  border-radius: 10px;
  font-size: 12px;
  font-weight: 600;
}
.redemptions-list .redemption a .redemption-points {
  text-align: center;
  padding: 1px;
}
.redemptions-list .redemption a .redemption-image {
  padding: 5px;
  background-color: #fff;
}
.redemptions-list .redemption a .redemption-image img {
  height: 50px;
  width: 100%;
  object-fit: contain;
  object-position: center;
}
.redemptions-list .redemption a .redemption-title {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  width: 100%;
  text-align: center;
  padding: 1px;
}
.redemptions-list .redemption .redemption-action {
  display: none;
}
.redemptions-list .redemption.disabled a .redemption-points, .redemptions-list .redemption.disabled a .redemption-title {
  background-color: #999;
  color: #ccc;
  font-style: italic;
  font-weight: 300;
}
.redemptions-list .redemption.disabled a .redemption-image {
  opacity: 0.7;
}

.redemptions-container .redemptions, .redemptions-container .my-redemptions {
  list-style-type: none;
  display: flex;
  border: 0;
  margin: 0;
  padding: 0;
  gap: 15px;
  flex-wrap: wrap;
  font-size: 16px;
  width: 100%;
  list-style-type: none;
  margin: 0;
  padding: 0;
  display: flex;
  position: relative;
  z-index: 1;
}
.redemptions-container .redemptions li, .redemptions-container .my-redemptions li {
  width: calc(33.33% - 10px);
  padding: 0;
  margin: 0;
  background-color: #2d6105;
  color: #ffffff;
  padding: 0px;
  display: flex;
  align-items: center;
  text-transform: uppercase;
  padding: 5px;
  flex-direction: column;
  gap: 5px;
}
.redemptions-container .redemptions li .redemption-image, .redemptions-container .my-redemptions li .redemption-image {
  height: 75px;
  width: 100%;
  display: flex;
  min-width: 100%;
  max-height: 75px;
  min-height: 75px;
  max-width: 100%;
}
.redemptions-container .redemptions li .redemption-image img, .redemptions-container .my-redemptions li .redemption-image img {
  object-fit: cover;
  object-position: center;
  width: 100%;
  height: 100%;
}
.redemptions-container .redemptions li .redemption-title, .redemptions-container .my-redemptions li .redemption-title {
  width: 100%;
  text-align: left;
  padding: 5px 0;
}
.redemptions-container .redemptions li .redemption-points, .redemptions-container .my-redemptions li .redemption-points {
  padding: 10px 10px 5px 10px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  line-height: 85%;
  background-color: rgba(0, 0, 0, 0.6);
  width: 100%;
  order: -1;
}
.redemptions-container .redemptions li .redemption-points .points-label, .redemptions-container .my-redemptions li .redemption-points .points-label {
  font-size: 50%;
}
.redemptions-container .redemptions li .redemption-action, .redemptions-container .my-redemptions li .redemption-action {
  width: 100%;
  display: flex;
}
.redemptions-container .redemptions li .redemption-action a, .redemptions-container .my-redemptions li .redemption-action a {
  padding: 10px 20px;
  height: 100%;
  width: 100%;
  position: relative;
  background-color: rgba(0, 0, 0, 0.6);
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #ffffff;
  background-color: rgba(0, 0, 0, 0.2);
  border-radius: 10px;
  font-size: 90%;
}
.redemptions-container .redemptions li.disabled .redemption-action a, .redemptions-container .my-redemptions li.disabled .redemption-action a {
  opacity: 0.5;
}

.redemption-collection {
  /*padding: 15px;
  background-color: #62b622c4;
  color: $highlightColor;
  border-radius: 10px;
  background-size: cover;
  background-position: center;*/
}

.redemption-collections {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
  position: relative;
}
.redemption-collections .redemption-collection {
  width: calc(33.33% - 10px);
  padding: 0;
  margin: 0;
  background-color: #915f1b;
  color: #ffffff;
  padding: 0px;
  display: flex;
  align-items: center;
  text-transform: uppercase;
  padding: 5px;
  flex-direction: column;
  gap: 5px;
}

.landing-page h1 {
  font-size: 250%;
  font-weight: 900;
  margin-bottom: 15px;
  line-height: normal;
  color: #62b622;
}
.landing-page h2 {
  font-size: 125%;
  font-weight: 600;
  margin-bottom: 15px;
  line-height: normal;
  color: #62b622;
}
.landing-page h3 {
  font-size: 120%;
  font-weight: 400;
  line-height: normal;
  margin-bottom: 15px;
}
.landing-page .button {
  padding: 10px 30px;
  border-radius: 25px;
  display: inline-block;
  background: #62b622;
  color: #ffffff;
  font-weight: 600;
  font-size: 90%;
}
.landing-page .logo-portrait {
  background-color: #2d6105;
  color: #ffffff;
  padding: 30px;
  max-width: none;
  text-align: center;
  width: 100%;
  font-weight: 600;
  align-items: center;
  justify-content: center;
  display: flex;
}
.landing-page .logo-portrait img {
  width: 150px;
}
.landing-page .logo {
  background-color: #2d6105;
  color: #ffffff;
  font-weight: 600;
}
@media (max-width: 1023px) {
  .landing-page .logo {
    padding: 20px 60px 0 60px;
    margin-bottom: 30px;
  }
}
@media (min-width: 1024px) {
  .landing-page .logo {
    margin-bottom: 20px;
  }
}
.landing-page .logo img {
  width: 200px;
}
.landing-page .landing-page-header {
  display: flex;
  background-color: #2d6105;
  color: #ffffff;
}
.landing-page .landing-page-header .logo-portrait {
  align-self: center;
}
@media (max-width: 1023px) {
  .landing-page .landing-page-header {
    padding: 0;
    flex-direction: column;
  }
}
@media (min-width: 1024px) {
  .landing-page .landing-page-header {
    padding: 50px;
    flex-direction: row;
  }
}
.landing-page .landing-page-header .info {
  flex: 1;
}
.landing-page .landing-page-header .info h1 {
  color: #ffffff;
}
.landing-page .landing-page-header .info .button {
  background-color: transparent;
  border: 2px solid #ffffff;
}
@media (max-width: 1023px) {
  .landing-page .landing-page-header .info {
    width: 100%;
    order: 2;
    padding: 0 30px 30px 30px;
    text-align: center;
  }
  .landing-page .landing-page-header .info h1, .landing-page .landing-page-header .info h3 {
    text-align: center;
  }
  .landing-page .landing-page-header .info h1 {
    margin: 0 0 20px 0;
  }
  .landing-page .landing-page-header .info h3 {
    margin: 0;
  }
  .landing-page .landing-page-header .info .button {
    margin-bottom: 20px;
    width: 90%;
  }
}
@media (min-width: 1024px) {
  .landing-page .landing-page-header .info {
    width: 50%;
    order: 1;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }
  .landing-page .landing-page-header .info h1 {
    order: 1;
  }
  .landing-page .landing-page-header .info h3 {
    margin-bottom: 30px;
    order: 2;
  }
  .landing-page .landing-page-header .info .button {
    order: 4;
  }
}
.landing-page .landing-page-header .featured-image {
  flex: 1;
  display: flex;
  position: relative;
}
@media (max-width: 1023px) {
  .landing-page .landing-page-header .featured-image {
    width: 100%;
    order: 1;
    margin-bottom: 20px;
    padding: 0px 0px;
  }
}
@media (min-width: 1024px) {
  .landing-page .landing-page-header .featured-image {
    width: 50%;
    order: 2;
    padding-left: 50px;
  }
}
.landing-page .landing-page-header .featured-image img {
  object-fit: contain;
  height: 100%;
  width: 100%;
  min-height: 100%;
  object-fit: cover;
}
.landing-page .landing-page-footer {
  background-color: #335f12;
  color: #eeeeee;
  padding: 30px;
  text-align: center;
  align-items: center;
  justify-content: center;
}
.landing-page .landing-page-footer ul {
  list-style-type: none;
  padding: 0;
  margin: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 1023px) {
  .landing-page .landing-page-footer ul {
    flex-direction: column;
  }
}
@media (min-width: 1024px) {
  .landing-page .landing-page-footer ul {
    flex-direction: row;
  }
}
@media (max-width: 1023px) {
  .landing-page .landing-page-footer ul li {
    padding-bottom: 15px;
  }
}
@media (min-width: 1024px) {
  .landing-page .landing-page-footer ul li {
    padding-right: 15px;
    margin-right: 15px;
    border-right: 1px solid #eeeeee;
  }
}
.landing-page .landing-page-footer ul li:last-child {
  border-right: 0;
  margin-right: 0;
  padding-right: 0;
  border-bottom: 0;
  margin-bottom: 0;
  padding-bottom: 0;
}
.landing-page .ctas {
  display: flex;
  background-color: #ffffff;
  color: #333333;
}
@media (max-width: 1023px) {
  .landing-page .ctas {
    flex-direction: column;
    padding: 30px;
  }
}
@media (min-width: 1024px) {
  .landing-page .ctas {
    flex-direction: row;
    padding: 50px 75px;
  }
}
.landing-page .ctas .cta {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  flex: 1;
  padding: 45px;
  background-color: #62b62211;
}
.landing-page .ctas .cta h1, .landing-page .ctas .cta h2, .landing-page .ctas .cta h3 {
  text-align: center;
  padding-bottom: 15px;
}
@media (max-width: 1023px) {
  .landing-page .ctas .cta {
    margin-bottom: 15px;
  }
  .landing-page .ctas .cta:last-child {
    margin-bottom: 0;
  }
}
@media (min-width: 1024px) {
  .landing-page .ctas .cta {
    margin-right: 45px;
  }
  .landing-page .ctas .cta:last-child {
    margin-right: 0;
  }
}
.landing-page .ctas .cta i {
  font-size: 400%;
  margin-bottom: 30px;
}

.side-filter.filter {
  width: 320px;
  font-weight: 300;
  text-transform: capitalize;
  border-top: none;
  position: relative;
  min-width: 320px;
  padding: 50px 20px 50px 50px;
}
.side-filter.filter.showing-all ul {
  flex-direction: column;
}
.side-filter.filter.showing-all ul li .labels {
  padding: 0 15px 15px 15px;
}
.side-filter.filter.showing-all ul li:first-child .labels {
  padding: 15px;
}
.side-filter.filter .filter-list {
  overflow: auto;
  position: relative;
  width: 100%;
}
.side-filter.filter strong {
  font-weight: 600;
  text-transform: uppercase;
}
.side-filter.filter ul {
  width: 100%;
  margin: 0;
  padding: 0;
  list-style-type: none;
}
.side-filter.filter ul li {
  display: flex;
}
.side-filter.filter ul li.total-products {
  text-transform: capitalize;
  border-bottom: 1px solid #eaeaea;
  margin-right: 40px;
  line-height: normal;
  padding-bottom: 20px;
  font-size: 16px;
}
.side-filter.filter ul li .labels {
  padding: 20px 20px 10px 20px;
  padding-left: 0;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  flex-direction: column;
  width: 80%;
}
.side-filter.filter ul li .labels label input {
  opacity: 0;
}
.side-filter.filter ul li .labels label:hover input {
  opacity: 1;
}
.side-filter.filter ul li .labels input {
  appearance: none;
  background-color: #333;
  font: inherit;
  color: currentColor;
  width: 12.5px;
  height: 12.5px;
  min-width: 12.5px;
  min-height: 12.5px;
  border-radius: 100%;
  transition: all 200ms ease 0ms;
}
.side-filter.filter ul li .labels input:before {
  content: "";
  width: 0.65em;
  height: 0.65em;
  transform: scale(0);
  transition: 120ms transform ease-in-out;
  box-shadow: inset 1em 1em var(--form-control-color);
}
.side-filter.filter ul li .labels input:checked {
  opacity: 1;
  background-color: #62b622;
}
.side-filter.filter ul li .labels input:checked:before {
  transform: scale(1);
}
.side-filter.filter ul li .labels input:checked:hover:active {
  background-color: #62b622;
}
.side-filter.filter ul li .labels input:checked:active {
  background-color: #62b622;
}
.side-filter.filter ul li .labels input:checked:hover {
  background-color: red;
}
.side-filter.filter ul li .labels label {
  display: flex;
  align-items: flex-start;
  margin-top: 7.5px;
  width: 100%;
  align-items: center;
  gap: 5px;
  cursor: pointer;
}
.side-filter.filter ul li .labels label .filter-item {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  width: 100%;
}
.side-filter.filter ul li .labels label .filter-item .filter-name {
  flex: 2;
  padding-right: 10px;
}
.side-filter.filter ul li .labels label .filter-item .total-items {
  opacity: 0.5;
  font-size: 100%;
}
@media (max-width: 1023px) {
  .side-filter.filter {
    display: none;
  }
}

.top-section {
  z-index: 3;
  position: sticky;
  top: 0;
}
@media (max-width: 1023px) {
  .top-section {
    background-color: #62b622;
    top: -210px;
  }
}

.floating-top .floating-cover {
  background-color: #62b623;
  height: 70px;
  position: sticky;
  top: 0;
  z-index: 1;
  margin-top: -70px;
}

.products-container {
  position: relative;
  display: flex;
  width: 100%;
}
@media (max-width: 1023px) {
  .products-container {
    min-height: 100vh;
    background-color: #ffffff;
    color: #333333;
  }
  .floating-top .products-container {
    margin-top: -60px;
    padding-top: 60px;
    top: auto;
  }
}
.products-container .products {
  transition: opacity 300ms ease;
  opacity: 1;
}
@media (min-width: 1024px) {
  .products-container .products {
    border-radius: 0px;
    overflow: hidden;
  }
}
.products-container.loading .products {
  transition: opacity 0ms ease;
  opacity: 0;
}

.breadcrumbs {
  text-transform: capitalize;
  display: flex;
  gap: 5px;
  line-height: normal;
  align-items: flex-end;
  order: -4;
  min-width: 100%;
  padding: 20px;
}
@media (max-width: 1023px) {
  .breadcrumbs {
    background-color: #2d6105;
    color: #ffffff;
    align-items: center;
    min-height: 65px;
  }
}
.breadcrumbs a {
  display: inline-block;
  width: auto;
  font-size: 13px;
}
.breadcrumbs .slash {
  font-size: 16px;
}

@media (min-width: 1024px) {
  .product.active .pricing .price {
    color: inherit;
  }
}
.product a, .product .product-item {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative;
  width: 100%;
}
@media (max-width: 1023px) {
  .product a, .product .product-item {
    flex-wrap: wrap;
  }
  .product-list-view .product a, .product-list-view .product .product-item {
    flex-wrap: nowrap;
  }
}
@media (min-width: 1024px) {
  .product-list-view .product a, .product-list-view .product .product-item {
    flex-direction: row;
  }
}
.product .row {
  width: 100%;
  display: flex;
}
.product .row .title-slot {
  text-align: center;
  border-radius: 10px;
  color: #fff;
  display: none;
  position: relative;
  font-weight: 700;
}
.product .row .title-slot .row-note {
  font-size: 10px;
  opacity: 0.7;
  display: flex;
  align-items: center;
  text-align: center;
  width: 100%;
}
.product .row .title-slot.hybrid {
  color: #99c455;
  display: block;
}
.product .row .title-slot.sativa {
  color: #ec5530;
  display: block;
}
.product .row .title-slot.indica {
  color: #7052a3;
  display: block;
}
.product .brand-area {
  width: 100%;
  color: #2c5111;
  background: #dcf4ca;
  padding: 3px;
  text-align: center;
  text-transform: uppercase;
  font-weight: 600;
}
.product .promo-tags {
  position: absolute;
  top: 1px;
  left: 1px;
  z-index: 5;
}
.product .promo-tags > span {
  padding: 5px 8px;
  border-radius: 3px;
  background-color: #444;
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  position: relative;
  overflow: hidden;
}
.product .promo-tags > span:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  background-color: #fff;
}
.product .promo-tags > span.bogo {
  background-color: #ef1e1e;
  color: #ffffff;
}
.product .promo-tags > span.bogo:after {
  content: "";
}
.product .image {
  position: relative;
  padding: 0px;
  overflow: hidden;
  width: 100%;
  max-width: 100%;
  overflow: hidden;
  display: inline-flex;
  margin: 10px 0 0 0;
}
@media (max-width: 1023px) {
  .product .image {
    padding-top: 60%;
  }
}
@media (min-width: 1024px) {
  .product .image {
    padding-top: 60%;
    min-width: 160px;
  }
  .product-list-view .product .image {
    padding-top: 0;
    width: 100px;
    height: 100px;
    padding: 10px 0;
    margin-right: 20px;
  }
}
.product .image img {
  height: 100%;
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  object-fit: contain;
}
.product-list-view .product .image img {
  position: relative;
}
.product.single-product {
  display: flex;
  flex-direction: column;
  /*
  @media(min-width: 1024px) {
      //font-size: 3vw;
      flex-direction: row;
      padding: 25px;
      .image {
          width: auto;
          order: 4;
          min-width: 35%;
          max-width: 35%;
          height: auto;
      }
      .meta {
          order: 1;
      }
      .pricing {
          order: 5;
          width: 100%;
          align-items: flex-start;
          flex-direction: row;
      }
  }*/
}
@media (min-width: 1024px) {
  .product.single-product {
    flex-wrap: wrap;
    padding: 25px 75px;
    flex-direction: row;
  }
  .sideview-view .product.single-product {
    padding: 0;
  }
}
.product.single-product .image {
  margin: 50px 0 0 0;
  width: 100%;
  min-width: 100%;
  max-width: 100%;
  order: -3;
  height: 100%;
  padding: 5% 5%;
  background-color: #fff;
  border: 1px solid #ededed;
  box-shadow: inset 0px 0px 100px 0px rgba(0, 0, 0, 0.0901960784);
}
@media (max-width: 1023px) {
  .product.single-product .image {
    margin: 0;
    border-bottom: 5px solid #ededed;
    max-height: 250px;
    height: 250px;
    padding: 15px;
  }
}
.product.single-product .image img {
  position: relative;
  top: 0;
  object-fit: contain;
  height: 100%;
  width: 100%;
}
@media (min-width: 1024px) {
  .product.single-product .image {
    width: 40%;
    min-width: 40%;
    max-width: 40%;
    margin: 0;
    margin-right: 100px;
    border-radius: 30px;
  }
}
.product.single-product .testings {
  font-size: inherit;
}
@media (min-width: 1024px) {
  .product.single-product .testings {
    justify-content: flex-start;
  }
}
.product.single-product .pricing {
  margin: 0;
  width: auto;
  flex-direction: column;
}
.product.single-product .description {
  min-width: 100%;
  border-top: 5px solid #62b622;
  margin-top: 50px;
  padding-top: 50px;
  padding: 50px;
  line-height: 165%;
}
@media (max-width: 1023px) {
  .product.single-product .description {
    margin-top: 25px;
    padding: 25px;
    padding-top: 25px;
  }
}
.sideview-view .product.single-product .description {
  padding: 25px;
  padding-bottom: 65px;
}
.product.single-product h2 {
  font-weight: 600;
}
.product.single-product .product-banner {
  order: -3;
  height: 50px;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding-left: 15px;
  font-weight: 600;
  font-size: 90%;
  padding-right: 50px;
  background-color: #62b622;
  color: #ffffff;
}
.product.single-product .title-info {
  order: -2;
  min-width: 100%;
  padding: 15px;
}
.product.single-product .title-info .row {
  min-width: 100%;
  display: block;
}
.product.single-product .title-info a {
  align-items: flex-start;
  display: inline;
}
.product.single-product .meta {
  height: auto;
  min-width: 30%;
  display: flex;
  flex-direction: column;
  align-self: flex-start;
  text-align: center;
  justify-content: center;
  align-items: center;
  text-align: center;
  justify-content: center;
  align-items: center;
}
@media (max-width: 1023px) {
  .product.single-product .meta {
    padding: 15px 0;
    z-index: 3;
  }
}
.product.single-product .meta .social {
  display: flex;
}
.product.single-product .meta .social a {
  padding: 5px;
  margin-right: 10px;
  color: #62b622;
  font-size: 120%;
}
.product.single-product .meta .social a:last-child {
  margin-right: 0;
}
.product.single-product .meta .price {
  display: inline-flex;
  flex-direction: column;
  text-align: center;
  justify-content: center;
  align-items: center;
  line-height: normal;
  white-space: nowrap;
  border: 1px solid #ffffff59;
  padding: 15px 25px;
  border-radius: 3px;
}
.product.single-product .meta .price .title {
  flex: 1;
  width: 100%;
  display: inline-flex;
  flex-direction: column;
  text-align: center;
  justify-content: center;
  align-items: center;
  margin-bottom: 2px;
  font-weight: 500;
  font-size: 90%;
}
.product.single-product .meta .price:last-child {
  margin-right: 0;
}
.product.single-product .meta .price .size-grams {
  padding-bottom: 5px;
}
.product.single-product .meta .price .size-price {
  padding-bottom: 0px;
}
.product.single-product .meta .price .size-add {
  color: #ffffff;
  background: #62b622;
  padding: 5px 15px;
  font-size: 70%;
  text-transform: uppercase;
}
.has-submitted-cart .product.single-product .meta .price .size-add {
  display: none;
}
@media (min-width: 1024px) {
  .product.single-product .meta {
    padding-right: 50px;
    /*padding-right: 25px;
    text-align: left;
    justify-content: flex-start;
    align-items: flex-start;
    .sideview-view & {
        padding-right: 0;
    }
      */
  }
}
.product.single-product .meta h2 {
  text-align: center;
  /*
  @media(min-width: 1024px) {
      justify-content: flex-start;
      align-items: flex-start;
      text-align: left;
      a {
          display: inline-flex;
          text-align:left;
          justify-content: flex-start;
          align-items: flex-start;

      }

  }*/
}
.product.single-product .meta .row {
  margin-bottom: 15px;
  padding: 0 15px;
}
@media (max-width: 1023px) {
  .product.single-product .meta .row {
    margin-bottom: 10px;
  }
}
.product.single-product .meta .row:last-child {
  margin-bottom: 0;
}
.product.single-product .meta .row.spread {
  align-items: center;
  justify-content: center;
}
.product.single-product .meta .row.spread .button {
  background-color: #62b622;
  color: #ffffff;
  border-radius: 30px;
  padding: 15px;
  width: 100%;
  text-align: center;
  font-weight: 500;
}
.product.single-product .meta .row.spread.lbl {
  padding: 0 0px;
  text-align: left;
  justify-content: flex-start;
  align-items: center;
  font-weight: 400;
  margin-bottom: 15px;
}
@media (max-width: 1023px) {
  .product.single-product .meta .row.spread.lbl {
    padding: 0 15px;
  }
}
.product.single-product .meta .row.spread.lbl.big-gap {
  margin-bottom: 30px;
}
.product.single-product .meta .row.spread.lbl .val {
  margin-left: 5px;
  font-weight: 600;
}
@media (min-width: 1024px) {
  .product.single-product .meta .row.spread {
    justify-content: flex-start;
    align-items: flex-start;
  }
}
.product.single-product .meta .row.spread.prices {
  gap: 10px;
  align-items: flex-start;
  justify-content: flex-start;
  flex-wrap: nowrap;
  overflow: auto;
  width: 100%;
}
.product.single-product .meta .row.spread.siblings-row {
  padding: 0;
}
.product.single-product .meta .row.spread.siblings-row .siblings {
  display: flex;
  gap: 15px;
  font-size: 12px;
  align-items: flex-start;
  width: 100%;
  overflow: auto;
  padding: 3px 15px;
}
@media (min-width: 1024px) {
  .product.single-product .meta .row.spread.siblings-row .siblings {
    flex-wrap: wrap;
    overflow: visible;
    padding: 0;
  }
}
.product.single-product .meta .row.spread.siblings-row .siblings a {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0px 0px 0px 1px #ededed;
  flex: 0 0 calc(33.6% - 11.2px);
}
@media (max-width: 1023px) {
  .product.single-product .meta .row.spread.siblings-row .siblings a {
    flex: 0 0 calc(30.6% - 11.2px);
  }
}
.product.single-product .meta .row.spread.siblings-row .siblings a .sibling-title {
  padding: 3px 5px;
  border-bottom: 1px solid #ededed;
  width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
}
.product.single-product .meta .row.spread.siblings-row .siblings a .sibling-image {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
}
.product.single-product .meta .row.spread.siblings-row .siblings a.active {
  box-shadow: 0px 0px 0px 2px #lightBackground;
}
.product.single-product .meta .row.spread.siblings-row .siblings a.active .sibling-title {
  background-color: #lightBackground22;
}
.product.single-product .meta .row.title-row {
  font-family: times;
  line-height: normal;
  font-size: 30px;
  justify-content: center;
}
@media (min-width: 1024px) {
  .product.single-product .meta .row.title-row {
    font-size: 60px;
    justify-content: flex-start;
  }
}
.sideview-view .product.single-product .meta .row.title-row {
  padding-top: 10px;
  font-size: 30px;
}
.product.single-product .meta h2 {
  text-align: center;
}
.product.single-product .meta h2 a {
  text-align: center;
  align-items: center;
  justify-content: center;
}
.product.single-product .meta .row.spread {
  align-items: flex-start;
  justify-content: flex-start;
}
.product.single-product .meta .row.spread.prices {
  gap: 10px;
  align-items: flex-start;
  justify-content: flex-start;
  flex-wrap: nowrap;
  overflow: auto;
  width: 100%;
  flex-wrap: wrap;
}
.product.single-product .meta .row.spread.prices.cart-enabled {
  flex-wrap: nowrap;
}
.product.single-product .meta .row.spread.prices.cart-enabled .price {
  cursor: pointer;
}
.product.single-product .meta .row.spread.prices.cart-enabled .price.active {
  background-color: #darkBackground;
  color: #darkColor;
  border-color: #darkBackground;
}
.product.single-product .meta .row.title-row {
  justify-content: center;
  align-items: center;
  text-align: center;
}
.sideview-view .product.single-product {
  flex-wrap: wrap;
  flex-direction: row;
  padding-top: 0;
}
@media (max-width: 1023px) {
  .sideview-view .product.single-product {
    padding: 0;
  }
}
@media (min-width: 1024px) {
  .sideview-view .product.single-product {
    padding: 0;
    height: 100%;
    padding-bottom: 20px;
  }
  .sideview-view .product.single-product .image {
    width: 40%;
    min-width: 40%;
    max-width: 40%;
    margin: 0px 100px 0px 20px;
    height: auto;
    align-self: flex-start;
    min-height: 50%;
    align-items: center;
  }
}
.sideview-view .product.single-product .testings {
  justify-content: center;
  align-items: center;
}
.product .hide-no-cart-items {
  display: none;
}
.product .hide-has-cart-items, .product .options-button {
  padding: 5px 10px;
}
.product .meta {
  display: flex;
  flex-direction: column;
  gap: 5px;
  height: 100%;
  flex: 1;
  flex-wrap: wrap;
  width: 100%;
}
.product-list-view .product .meta .row-buttons {
  order: 3;
}
.product .meta .row-buttons .row-button {
  color: #000;
  display: inline-flex;
  gap: 1px;
  font-size: 14px;
  border-radius: 20px;
  font-weight: 600;
  align-items: center;
  color: #ffffff;
  background-color: #62b622;
  color: #000;
  background-color: #fff;
  border: 1px solid #000;
  height: 33px;
  width: 67px;
  transition: width 300ms ease;
  box-shadow: 2px 2px 2px 0px rgba(0, 0, 0, 0.1607843137);
}
.product .meta .row-buttons .row-button > span {
  height: 100%;
}
.product .meta .row-buttons .row-button .icon {
  padding: 6.5px 15px;
}
.product .meta .row-buttons .row-button .add-item-to-cart, .product .meta .row-buttons .row-button .remove-item-from-cart {
  cursor: pointer;
  border-radius: 50px;
  transition: all 200ms ease;
  height: 100%;
  align-items: center;
  justify-content: center;
  display: flex;
}
.product .meta .row-buttons .row-button .add-item-to-cart {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
}
.product .meta .row-buttons .row-button i {
  font-size: 16px;
}
.product .meta .row {
  display: flex;
  flex-wrap: wrap;
  min-width: 100%;
  line-height: normal;
}
.product .meta .row.rewards-earn {
  font-size: 13px;
  align-self: flex-start;
  min-width: 0;
  width: auto;
  flex: none;
}
.product .meta .row.favorite {
  position: absolute;
  top: 0px;
  right: 0px;
  z-index: 2;
  min-width: 0px;
  width: auto;
  font-size: 20px;
  color: #000;
  height: 30px;
  width: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.product .meta .row.favorite:hover span {
  color: #62b622;
}
.product .meta .row.favorite span {
  transition: all 300ms ease;
  display: flex;
}
.product .meta .row.favorite span::before {
  font-family: "Font Awesome 6 Pro";
  font-weight: 300;
  content: "\f004";
  display: inline-block;
}
.product .meta .row.fresh-drop span {
  background-color: #lightBackground;
  color: #lightColor;
  font-size: 12px;
  align-self: flex-start;
  min-width: 0;
  width: auto;
  flex: none;
  justify-self: flex-start;
  padding: 3px 5px;
  font-weight: 400;
  display: flex;
}
.product .meta .row.spread {
  justify-content: space-between;
}
.product .meta .row.title-row {
  flex: 1;
  min-width: 100%;
  justify-content: space-between;
  flex-wrap: nowrap;
}
.product .meta .row.title-row .title {
  text-transform: capitalize;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  display: -webkit-box;
  overflow: hidden;
  font-size: 16px;
  margin-top: 10px;
}
@media (max-width: 1023px) {
  .product .meta .row.title-row .title {
    margin-right: 0;
  }
}
.product .meta .row .brand {
  opacity: 0.6;
}
.product .meta .row.pricing-row {
  align-items: flex-end;
}
.product .meta .brand, .product .meta .category {
  text-transform: capitalize;
}
.product .meta .category a {
  flex-direction: row;
  flex-wrap: nowrap;
  font-weight: 600;
  font-size: 90%;
}
.product .meta .category a img {
  width: 30px;
}
.product.is-favorite .meta .row.favorite span::before {
  font-weight: 900;
  color: #lightBackground;
}
.product .pricing {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  flex-wrap: wrap;
}
@media (max-width: 1023px) {
  .product .pricing {
    flex-direction: column;
    width: 100%;
  }
}
@media (min-width: 1024px) {
  .product .pricing {
    width: 100%;
    align-items: center;
  }
}
.product .pricing .grams {
  text-align: right;
}
.product .pricing .price {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  font-size: 135%;
}
.product .pricing .price .onSalePrice {
  color: red;
}
.product .pricing .price .oldPrice {
  font-size: 80%;
  color: #676767;
  font-weight: 300;
}
.product .price-display {
  display: flex;
  align-items: flex-end;
  justify-content: flex-start;
  gap: 5px;
  flex-wrap: wrap;
  width: 100%;
  line-height: normal;
}
.product .price-display .grams {
  font-size: 12px;
  font-weight: 300;
}
.product .todayOnly {
  font-weight: 300;
  font-size: 12px;
}
.product .lastPurchased {
  position: absolute;
  top: 5px;
  left: 5px;
  background-color: #333;
  color: #fff;
  border-radius: 3px;
  padding: 2px 5px;
  font-size: 11px;
  font-weight: 400;
}
.product .testings {
  line-height: normal;
  width: 100%;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}
.product .testings .test {
  margin-right: 8%;
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  white-space: nowrap;
  margin: 2.5px 0;
  margin-right: 8%;
}
.product .testings .test:last-child {
  margin-right: 0;
}
.product .testings .test:before {
  content: "";
  min-width: 10px;
  padding-top: 10px;
  width: 10px;
  margin-right: 5px;
  position: relative;
}
.product .testings .test.thc:before {
  transform: rotate(45deg);
  background-color: #73c435;
}
.product .testings .test.cbd:before {
  border-radius: 100%;
  background-color: #adab22;
}

.single-product .has-cart-items .hide-no-cart-items {
  display: flex;
  width: 100%;
  justify-content: space-between;
  align-items: center;
  height: 100%;
}
.single-product .has-cart-items .hide-no-cart-items span {
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.single-product .has-cart-items .hide-has-cart-items {
  display: none !important;
}

.products {
  width: 100%;
  display: flex;
  background-color: #ffffff;
  color: #333333;
  align-self: flex-start;
}
.products ul {
  display: flex;
  list-style-type: none;
  margin: 0;
  padding: 0;
  flex-wrap: wrap;
  width: 100%;
  flex: 1;
  position: relative;
  border-bottom: 0;
  gap: 10px;
  padding: 10px;
}
@media (min-width: 1024px) {
  .products ul {
    padding: 10px 0;
  }
}
.products ul li, .products ul li.product {
  position: relative;
  padding: 10px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: space-between;
  box-shadow: inset 0px 71px 510px 0px rgba(0, 0, 0, 0.0196078431);
  width: 50%;
  min-width: 50%;
  min-height: 100px;
  min-width: 150px;
  overflow: hidden;
  flex: 1;
  transition: all 300ms ease;
  border: 1px solid #ededed;
  border-radius: 20px;
}
.products ul li.squeezed, .products ul li.product.squeezed {
  padding: 0;
  min-height: 0px;
  min-width: 85px;
  background-color: #fff;
  border-radius: 20px;
  overflow: hidden;
  border: 0;
}
.vibe-rounded .products ul li.squeezed, .vibe-rounded .products ul li.product.squeezed {
  border-radius: 5px;
}
.products ul li.squeezed .image, .products ul li.product.squeezed .image {
  height: 50px;
  z-index: 1;
  margin: 30px 0;
}
.products ul li.squeezed .meta, .products ul li.product.squeezed .meta {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  z-index: 2;
  justify-content: space-between;
}
.products ul li.squeezed .meta .row, .products ul li.product.squeezed .meta .row {
  min-height: 20px;
  max-height: 20px;
}
.products ul li.squeezed .meta .row, .products ul li.squeezed .meta .pricing, .products ul li.product.squeezed .meta .row, .products ul li.product.squeezed .meta .pricing {
  text-align: center;
  background-color: #lightBackground;
  color: #lightColor;
}
.products ul li.squeezed .meta .pricing, .products ul li.product.squeezed .meta .pricing {
  gap: 5px;
  font-size: 13px;
  text-align: center;
  justify-content: center;
  min-height: 20px;
  max-height: 20px;
}
.products ul li.squeezed .meta .pricing .price-display, .products ul li.product.squeezed .meta .pricing .price-display {
  width: 100%;
}
.products ul li.squeezed .meta .pricing .price-display .price, .products ul li.product.squeezed .meta .pricing .price-display .price {
  width: 100%;
  font-size: 13px;
  gap: 5px;
}
.products ul li.squeezed .meta .row.title-row, .products ul li.product.squeezed .meta .row.title-row {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 7.5px;
}
.products ul li.squeezed .meta .row.title-row .title, .products ul li.product.squeezed .meta .row.title-row .title {
  margin: 0;
  width: 100%;
  font-size: 12px;
  font-weight: 300;
  align-items: center;
  justify-content: center;
  display: block;
  line-height: normal;
  text-transform: uppercase;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.products ul li.has-cart-items, .products ul li.product.has-cart-items {
  box-shadow: inset 0px 71px 510px 0px #lightBackground0f;
}
.products ul li.has-cart-items .hide-no-cart-items, .products ul li.product.has-cart-items .hide-no-cart-items {
  display: flex;
  width: 100%;
  justify-content: space-between;
  align-items: center;
}
.products ul li.has-cart-items .hide-no-cart-items .qty, .products ul li.product.has-cart-items .hide-no-cart-items .qty {
  flex: 1;
  text-align: center;
  font-size: 14px;
}
.products ul li.has-cart-items .hide-has-cart-items, .products ul li.product.has-cart-items .hide-has-cart-items {
  display: none !important;
}
.products ul li.has-cart-items .meta .row-buttons .row-button, .products ul li.product.has-cart-items .meta .row-buttons .row-button {
  width: 100%;
  /*background-color: $glowBackground;
  color: $glowColor;
  background-color: $lightBackground;
  color: $lightColor;*/
}
.vibe-rounded .products ul li, .vibe-rounded .products ul li.product {
  border-radius: 10px;
}
.products ul li .remove-cart-item, .products ul li.product .remove-cart-item {
  background-color: #d42929;
  color: #ffffff;
  font-size: 150%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 5px;
  height: 35px;
  min-height: 35px;
  max-height: 35px;
  width: 35px;
  align-self: flex-end;
  position: absolute;
  top: 0px;
  right: 0px;
}
.has-submitted-cart .products ul li .remove-cart-item, .has-submitted-cart .products ul li.product .remove-cart-item {
  display: none;
}
@media (max-width: 1023px) {
  .products ul li, .products ul li.product {
    width: 50%;
    min-width: 40%;
    max-width: 60%;
    flex-direction: row;
    flex: 0 1 calc(50% - 5px);
    /*&.active {
        width: 100%;
        min-width: 100%;
        max-width: 100%;
        //height: 240px;
        background-color: $darkBackground;
        color: $darkColor;
        padding: 50px;
        font-size: 200%;
        .image {
            width: 50vw;
            height: 50vw;
            max-height: 50vw;
            max-width: 50vw;
            box-shadow: 0px 0px 0px 1px #darkColor33;
            margin-bottom: 20px;

        }
        img {

        }
    }*/
  }
  .product-list-view .products ul li, .product-list-view .products ul li.product {
    min-width: 100%;
    max-width: 100%;
    width: 100%;
  }
  .products ul li a, .products ul li .product-item, .products ul li.product a, .products ul li.product .product-item {
    flex-direction: row;
  }
  .products ul li .image, .products ul li.product .image {
    width: 100%;
    padding-top: 0;
    height: 180px;
    margin-bottom: 5px;
  }
  .product-list-view .products ul li .image, .product-list-view .products ul li.product .image {
    height: auto;
    margin: 0;
    width: 75px;
    padding: 10px 10px 10px 0;
    margin-right: 10px;
  }
  .products ul li.callout, .products ul li.product.callout {
    width: 100%;
    max-width: 100%;
    min-width: 100%;
    box-shadow: 0;
    border: 0;
  }
  .products ul li.callout .image img, .products ul li.product.callout .image img {
    height: auto;
  }
}
@media (min-width: 700px) {
  .products ul li, .products ul li.product {
    max-width: 300px;
    min-width: 160px;
    flex: 1;
  }
  .product-list-view .products ul li, .product-list-view .products ul li.product {
    min-width: 100%;
    max-width: 100%;
    width: 100%;
  }
  .products ul li.callout, .products ul li.product.callout {
    min-width: 50%;
    width: 50%;
    box-shadow: none;
    border: 0;
  }
  .products ul li.callout .image img, .products ul li.product.callout .image img {
    height: auto;
  }
}
@media (max-width: 1023px) {
  .products.onerow {
    padding-bottom: 30px;
  }
}
.products.onerow.nomargin {
  padding-bottom: 0;
}
.products.onerow .control {
  position: absolute;
  z-index: 3;
  display: flex;
  height: 100%;
  align-items: center;
  justify-content: center;
  top: 0;
  opacity: 0;
  pointer-events: none;
  transition: opacity 300ms ease;
}
@media (max-width: 1023px) {
  .products.onerow .control {
    display: none;
  }
}
.products.onerow .control > div {
  border: 1px solid #lightColor;
  border-radius: 100%;
  width: 50px;
  height: 50px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #lightBackground;
  color: #lightColor;
  cursor: pointer;
  transition: all 300ms ease;
}
.products.onerow .control > div:hover {
  scale: 1.1;
}
.products.onerow .control.back {
  left: 0;
  margin-left: 35px;
}
.products.onerow .control.forwards {
  right: 0;
  margin-right: 35px;
}
.products.onerow .control.show-control {
  opacity: 1;
}
.products.onerow .control.show-control > div {
  pointer-events: all;
}
.products.onerow ul {
  flex-wrap: nowrap;
  flex-direction: row;
  overflow: auto;
  gap: 7px;
}
@media (min-width: 1024px) {
  .products.onerow ul {
    gap: 15px;
  }
}
@media (max-width: 1023px) {
  .products.onerow ul {
    padding: 0 7px;
  }
  .row-20-each .products.onerow ul {
    flex-wrap: wrap;
  }
}
@media (min-width: 1024px) {
  .vibe-rounded .products.onerow ul li {
    border-radius: 10px;
  }
  .products.onerow ul li:first-child {
    margin-left: 25px;
  }
  .products.onerow ul li:last-child {
    margin-right: 25px;
  }
}
.products.onerow ul li a span.image {
  background-color: transparent;
}
.products.onerow ul li a span.image img {
  background-color: transparent;
  border-radius: 20px;
  overflow: hidden;
}
@media (max-width: 1023px) {
  .products.onerow ul li {
    width: 43%;
    min-width: 43%;
    max-width: 100%;
  }
}
@media (min-width: 1024px) {
  .products.onerow ul li {
    width: 16%;
    min-width: 180px;
    max-width: calc(33% - 8px);
  }
}
.products.noIndent.onerow .control {
  margin: 10px;
}
@media (min-width: 1024px) {
  .products.noIndent.onerow ul li {
    min-width: calc(33% - 9px);
    max-width: 35%;
  }
  .products.noIndent.onerow ul li:first-child {
    margin-left: 0;
  }
  .products.noIndent.onerow ul li:last-child {
    margin-right: 0;
  }
}

@keyframes slide-fade-in {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes slide-drop-in {
  0% {
    transform: translateY(-20%);
    opacity: 0;
  }
  100% {
    transform: translateY(0%);
    opacity: 1;
  }
}
.elm, .slide-elm {
  z-index: 4;
}
.elm.vignette, .slide-elm.vignette {
  overflow: hidden;
}
.elm.vignette:before, .slide-elm.vignette:before {
  z-index: 3;
  position: absolute;
  bottom: 0;
  height: 0px;
  background-color: rgba(0, 0, 0, 0.6);
  box-shadow: 0px 0px 200px 100px rgba(0, 0, 0, 0.6);
  width: 100%;
  content: "";
}

.slide {
  transition: opacity 700ms ease;
  pointer-events: none;
  line-height: normal;
}
.slide img {
  object-fit: contain;
  height: 100%;
}
.slide .fixed-item {
  position: absolute;
}
.slide .slide-header {
  font-weight: 900;
  font-size: 125%;
}
.slide .slide-button {
  text-align: center;
  font-weight: 600;
  font-size: 150%;
  display: inline-block;
  border-radius: 5px;
  padding: 7.5px 15px;
  text-transform: uppercase;
  letter-spacing: 2px;
  font-size: 75%;
  font-weight: 500;
  justify-content: center;
  align-items: center;
}
.slide .slide-left-half {
  left: 0 !important;
  right: auto !important;
  height: 100% !important;
  width: 50% !important;
  top: 0 !important;
}
.slide .slide-right-half {
  right: 0 !important;
  left: auto !important;
  height: 100% !important;
  width: 50% !important;
  top: 0 !important;
}
.slide .elm, .slide .slide-elm {
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  position: absolute;
  display: flex;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
.slide .elm.slide-fade-in, .slide .slide-elm.slide-fade-in {
  opacity: 0;
}
.slide .elm.slide-drop-in, .slide .slide-elm.slide-drop-in {
  opacity: 0;
  transform: translateY(-20%);
}
.slide.show, .endless-active .slide {
  opacity: 1;
  pointer-events: all;
}
.slide.show .elm.slide-fade-in, .slide.show .slide-elm.slide-fade-in, .endless-active .slide .elm.slide-fade-in, .endless-active .slide .slide-elm.slide-fade-in {
  animation: slide-fade-in 0ms ease forwards;
}
.slide.show .elm.slide-drop-in, .slide.show .slide-elm.slide-drop-in, .endless-active .slide .elm.slide-drop-in, .endless-active .slide .slide-elm.slide-drop-in {
  animation: slide-drop-in 0ms ease forwards;
}
.slide.show .elm.delay-2000ms, .slide.show .slide-elm.delay-2000ms, .endless-active .slide .elm.delay-2000ms, .endless-active .slide .slide-elm.delay-2000ms {
  animation-delay: 2000ms;
}
.slide.show .elm.speed-2000ms, .slide.show .slide-elm.speed-2000ms, .endless-active .slide .elm.speed-2000ms, .endless-active .slide .slide-elm.speed-2000ms {
  animation-duration: 2000ms;
}
.slide.show .elm.delay-1500ms, .slide.show .slide-elm.delay-1500ms, .endless-active .slide .elm.delay-1500ms, .endless-active .slide .slide-elm.delay-1500ms {
  animation-delay: 1500ms;
}
.slide.show .elm.speed-1500ms, .slide.show .slide-elm.speed-1500ms, .endless-active .slide .elm.speed-1500ms, .endless-active .slide .slide-elm.speed-1500ms {
  animation-duration: 1500ms;
}
.slide.show .elm.delay-1000ms, .slide.show .slide-elm.delay-1000ms, .endless-active .slide .elm.delay-1000ms, .endless-active .slide .slide-elm.delay-1000ms {
  animation-delay: 1000ms;
}
.slide.show .elm.speed-1000ms, .slide.show .slide-elm.speed-1000ms, .endless-active .slide .elm.speed-1000ms, .endless-active .slide .slide-elm.speed-1000ms {
  animation-duration: 1000ms;
}
.slide.show .elm.delay-750ms, .slide.show .slide-elm.delay-750ms, .endless-active .slide .elm.delay-750ms, .endless-active .slide .slide-elm.delay-750ms {
  animation-delay: 750ms;
}
.slide.show .elm.speed-750ms, .slide.show .slide-elm.speed-750ms, .endless-active .slide .elm.speed-750ms, .endless-active .slide .slide-elm.speed-750ms {
  animation-duration: 750ms;
}
.slide.show .elm.delay-500ms, .slide.show .slide-elm.delay-500ms, .endless-active .slide .elm.delay-500ms, .endless-active .slide .slide-elm.delay-500ms {
  animation-delay: 500ms;
}
.slide.show .elm.speed-500ms, .slide.show .slide-elm.speed-500ms, .endless-active .slide .elm.speed-500ms, .endless-active .slide .slide-elm.speed-500ms {
  animation-duration: 500ms;
}
.slide.show .elm.delay-300ms, .slide.show .slide-elm.delay-300ms, .endless-active .slide .elm.delay-300ms, .endless-active .slide .slide-elm.delay-300ms {
  animation-delay: 300ms;
}
.slide.show .elm.speed-300ms, .slide.show .slide-elm.speed-300ms, .endless-active .slide .elm.speed-300ms, .endless-active .slide .slide-elm.speed-300ms {
  animation-duration: 300ms;
}
.slide.show .elm.delay-200ms, .slide.show .slide-elm.delay-200ms, .endless-active .slide .elm.delay-200ms, .endless-active .slide .slide-elm.delay-200ms {
  animation-delay: 200ms;
}
.slide.show .elm.speed-200ms, .slide.show .slide-elm.speed-200ms, .endless-active .slide .elm.speed-200ms, .endless-active .slide .slide-elm.speed-200ms {
  animation-duration: 200ms;
}
.slide.show .elm.delay-150ms, .slide.show .slide-elm.delay-150ms, .endless-active .slide .elm.delay-150ms, .endless-active .slide .slide-elm.delay-150ms {
  animation-delay: 150ms;
}
.slide.show .elm.speed-150ms, .slide.show .slide-elm.speed-150ms, .endless-active .slide .elm.speed-150ms, .endless-active .slide .slide-elm.speed-150ms {
  animation-duration: 150ms;
}
.slide.show .elm.delay-100ms, .slide.show .slide-elm.delay-100ms, .endless-active .slide .elm.delay-100ms, .endless-active .slide .slide-elm.delay-100ms {
  animation-delay: 100ms;
}
.slide.show .elm.speed-100ms, .slide.show .slide-elm.speed-100ms, .endless-active .slide .elm.speed-100ms, .endless-active .slide .slide-elm.speed-100ms {
  animation-duration: 100ms;
}

.carousel {
  width: 100%;
}
.carousel ul {
  list-style-type: none;
  padding: 0;
  margin: 0;
  position: relative;
  display: flex;
  overflow-x: visible;
  width: 100%;
}
.carousel ul li {
  padding: 0;
  margin: 0;
  min-width: 100%;
  padding-top: 66%;
  background-color: #222;
  position: relative;
  overflow: hidden;
  line-height: normal;
  display: flex;
}
@media (max-width: 1023px) {
  .carousel ul li {
    background-color: transparent;
    overflow: hidden;
  }
  .carousel ul li .slide-wrap {
    display: flex;
    height: 100%;
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
  }
  .carousel ul li .slide-wrap:after {
    content: "";
  }
  .carousel ul li .slide-wrap:before {
    content: "";
  }
  .carousel ul li .slide-wrap .slide-wrap-inner {
    display: flex;
    height: 100%;
    width: 100%;
    overflow: hidden;
  }
}
.carousel ul li .slide {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
}
.carousel ul li .slide .slide-elm {
  background-size: contain;
  background-repeat: no-repeat;
}
.carousel ul li .slide img {
  height: 100%;
  width: 100%;
  position: relative;
  object-fit: cover;
}

@media (max-width: 1023px) {
  .overlay-frame .secondary-filter {
    top: 65px;
  }
  .scrolled-down .overlay-frame .secondary-filter {
    top: 65px;
  }
}

.secondary-filter {
  display: none;
}
@media (max-width: 1023px) {
  .secondary-filter {
    display: block;
    top: 110px;
    position: sticky;
    overflow: hidden;
    z-index: 11;
    transition: transform 250ms ease-out, top 250ms ease-out;
  }
  .secondary-filter.maximized {
    z-index: 12;
    margin: 0;
    padding: 0;
    width: 100%;
    padding-top: 0px;
    color: #080808;
    overflow: visible;
    height: auto;
    left: 0%;
  }
  .secondary-filter.maximized section .highlight .items .filter {
    border: 0;
    color: inherit;
  }
  .secondary-filter.maximized section .highlight .items .main-filter-wrapper {
    box-shadow: none;
    margin: 0;
    color: #111;
  }
  .secondary-filter.maximized section .highlight .items .main-filter-wrapper form {
    margin-top: 50px;
  }
  .secondary-filter.maximized section .highlight .items .main-filter-wrapper form .filter-list {
    padding: 15px;
  }
  .secondary-filter.maximized section .highlight .items .main-filter-wrapper form .filter-list ul {
    flex-direction: column;
    height: auto;
    color: inherit;
    background-color: inherit;
  }
}
@media (max-width: 1023px) and (max-width: 1023px) {
  .secondary-filter.maximized section .highlight .items .main-filter-wrapper form .filter-list ul {
    margin-left: 0px;
  }
}
@media (max-width: 1023px) {
  .secondary-filter.maximized section .highlight .items .main-filter-wrapper form .filter-list ul.sort {
    display: flex;
  }
  .secondary-filter.maximized section .highlight .items .main-filter-wrapper form .filter-list ul li {
    color: inherit;
    background-color: inherit;
  }
  .secondary-filter.maximized section .highlight .items .main-filter-wrapper form .filter-list ul li:last-child {
    padding: 0;
  }
  .secondary-filter.maximized section .highlight .items .main-filter-wrapper form .filter-list ul li .labels {
    color: inherit;
    background-color: inherit;
    flex-wrap: wrap;
    width: 100%;
    padding: 0 10px;
    margin-bottom: 20px;
  }
  .secondary-filter.maximized section .highlight .items .main-filter-wrapper form .filter-list ul li .labels strong {
    min-width: 100%;
    font-size: 14px;
    display: block;
    font-weight: 700;
    color: inherit;
    background-color: inherit;
  }
  .secondary-filter.maximized section .highlight .items .main-filter-wrapper form .filter-list ul li .labels label {
    flex: 1;
    font-size: 13px;
    font-weight: 400;
    padding: 7.5px 10px;
    min-width: calc(50% - 10px);
    max-width: calc(50% - 10px);
    margin: 5px;
    text-align: center;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    text-overflow: ellipsis;
    color: #ffffff;
    display: none;
    color: inherit;
    background-color: inherit;
  }
  .secondary-filter.maximized section .highlight .items .main-filter-wrapper form .filter-list ul li .labels label:nth-child(-n+8) {
    display: block;
  }
  .secondary-filter.maximized section .highlight .items .main-filter-wrapper form .filter-list ul li .labels label span {
    text-overflow: ellipsis;
    overflow: hidden;
    width: 100%;
  }
  .secondary-filter.maximized section .highlight .items .main-filter-wrapper form .filter-list ul li .labels label input[type=checkbox] {
    background: rgba(0, 0, 0, 0.2509803922);
  }
  .secondary-filter.maximized section .highlight .items .main-filter-wrapper form .filter-list ul li .labels label input[type=checkbox]:after {
    margin: 2px;
    width: calc(100% - 4px);
    height: calc(100% - 4px);
  }
  .secondary-filter.maximized section .highlight .items .main-filter-wrapper form .filter-list ul li .labels label input[type=checkbox]:checked {
    color: #000;
    background: #62b62266;
  }
}

main .contained section.sub-section {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: transparent;
}
main .contained section.sub-section .section-body {
  width: 100%;
  max-width: 1100px;
}
main .contained section.sub-section.brand-highlight {
  justify-content: center;
  background-color: #62b622;
  color: #ffffff;
  padding: 30px;
  gap: 30px;
}
main .contained section.sub-section.join-rewards {
  background-color: #lightBackground;
  color: #lightColor;
}
main .contained section.sub-section h1 {
  font-weight: 700;
  font-size: 20px;
  text-align: center;
}
@media (max-width: 1023px) {
  main .contained section.sub-section.brand-highlight {
    overflow-x: auto;
    justify-content: flex-start;
  }
}
@media (min-width: 1024px) {
  main .contained section.sub-section {
    padding: 0 50px;
  }
}
main .contained section.sub-section img {
  width: auto;
  height: 30px;
  object-fit: contain;
}

.highlight.m-cat {
  display: none;
}
@media (max-width: 1023px) {
  .highlight.m-cat {
    height: 70px;
    position: sticky;
    top: 0px;
    z-index: 2;
    margin-top: 0px;
  }
}

.highlight.d-cat .categories {
  display: none;
}
@media (min-width: 1024px) {
  .highlight.d-cat .categories {
    display: flex;
  }
}

.highlight.d-cat {
  margin-top: 15px;
}
@media (max-width: 1023px) {
  .vibe-grid .highlight.d-cat {
    margin-top: 5px;
  }
}
@media (min-width: 1024px) {
  .highlight.d-cat {
    padding: 0px;
    margin: 0px 0 0px 0;
    gap: var(--web-grid-spacing);
  }
}
.highlight.d-cat .carousel {
  overflow: hidden;
  flex: 1;
}
.highlight.d-cat .carousel .endless {
  border-radius: 10px;
}
.highlight {
  position: relative;
  display: flex;
}
@media (max-width: 1023px) {
  .highlight.main-highlight ul {
    background-color: #eee;
  }
}
@media (min-width: 1024px) {
  .highlight {
    overflow: hidden;
  }
}
.highlight .categories {
  display: flex;
  flex: 1;
  flex-direction: column;
  width: 100%;
}
@media (min-width: 1024px) {
  .highlight .categories {
    border-radius: 30px;
  }
}
.highlight .categories ul {
  position: relative;
  list-style-type: none;
  padding: 0;
  margin: 0;
  display: flex;
  width: 100%;
  flex: 1;
}
.highlight .categories ul li {
  padding: 0;
  margin: 0;
  position: relative;
}
@media (max-width: 1023px) {
  .highlight .categories ul li {
    padding: 0;
    margin: 0;
    position: relative;
    flex: 1;
    align-items: center;
    justify-content: center;
    display: flex;
    background-color: #000;
    font-weight: 600;
  }
  .highlight .categories ul li:last-child {
    border-right: 0;
  }
  .highlight .categories ul li:first-child {
    display: none;
  }
  .highlight .categories ul li a {
    display: flex;
    flex: 1;
    width: 100%;
    text-align: center;
    padding: 15px 5px;
    font-size: 12px;
    background-color: #62b622c4;
    color: #fff;
    text-transform: uppercase;
    height: 100%;
    align-items: center;
    justify-content: center;
  }
}
.highlight .items {
  background-color: #f5f5f5;
  flex: 1;
}
@media (max-width: 1023px) {
  .highlight .items {
    background-color: #e7e7e7;
    color: #111;
    background-color: #393939;
    color: #fff;
    background-color: #fff;
    color: #111;
    background-color: transparent;
  }
  .maximized .highlight .items {
    background: transparent;
    box-shadow: none;
  }
}
.highlight .items.show ul li a span {
  font-weight: 400;
}
.highlight .items > ul {
  transition: max-height 300ms ease, min-height 300ms ease, background 300ms ease;
  justify-content: space-between;
  /*
  .is-sticky & {
      height: 45px;
      max-height: 45px;
      min-height: 45px;
      background-color: #00000007;
      @media(max-width: 1023px) {
          height: 120px;
          max-height: 120px;
          min-height: 120px;
      }

  }*/
}
@media (min-width: 1024px) {
  .highlight .items > ul {
    justify-content: flex-start;
  }
}
.highlight .items > ul li {
  padding: 0px;
  border-bottom: 1px solid transparent;
}
@media (max-width: 1023px) {
  .highlight .items > ul li {
    border-bottom: 0px solid transparent;
    align-items: center;
    display: flex;
  }
}
@media (min-width: 1024px) {
  .highlight .items > ul li {
    border-bottom: 1px solid transparent;
  }
  .highlight .items > ul li.active a {
    background: #fff;
    box-shadow: inset 0px 0px 0px 2px #62b622;
    color: #000;
  }
}
.highlight .items > ul li a {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 10px 10px;
  overflow: hidden;
  padding-bottom: 30px;
  width: 100%;
  border-radius: 0px;
  border-right: 5px solid #fff;
}
.highlight .items > ul li a .link-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
@media (min-width: 1024px) {
  .highlight .items > ul li a {
    padding: 7.5px 15px;
    margin: 7px 0;
  }
}
@media (max-width: 1023px) {
  .highlight .items > ul li a {
    margin: 0 0px;
    padding: 5px 15px;
  }
  .highlight .items > ul li a img {
    width: 55px;
    height: 55px;
    margin-bottom: 0px;
    border-radius: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    object-position: center;
    background-color: #eee;
    padding: 0px;
    box-shadow: inset 0px 0px 15px 0px #ccc;
    box-shadow: none;
    background-color: transparent;
    border-radius: 0;
  }
}
.highlight .items > ul li a .icon {
  position: relative;
  width: 30px;
  height: 30px;
  background-color: #62b622;
}
.highlight .items > ul li a > span {
  text-transform: capitalize;
  z-index: 1;
  position: absolute;
  white-space: nowrap;
}
@media (max-width: 1023px) {
  .highlight .items > ul li a > span {
    height: auto;
    bottom: auto;
    text-transform: capitalize;
    font-weight: 400;
    font-size: 13px;
  }
  .highlight .items > ul li a > span > span {
    padding: 2px 5px;
    border-radius: 5px;
  }
}
@media (min-width: 1024px) {
  .highlight .items > ul li a > span {
    font-size: 100%;
  }
}
.highlight .items > ul li img {
  object-fit: contain;
  width: 25px;
  height: 27px;
  padding: 5px 0;
  margin-right: 1px;
  transition: opacity 300ms linear, transform 300ms linear;
  transform: scale(1);
  /*
  .is-sticky & {
      @media(min-width: 1024px) {
          transform:scale(0);
          opacity: 0;
      }
  }*/
}
@media (min-width: 1024px) {
  .highlight .items > ul li img {
    display: none;
    height: 40px;
    width: 40px;
    padding: 10px 0;
    margin: 0;
  }
}
.highlight .items > ul li img.photo {
  display: none;
}
.highlight .items {
  display: flex;
  flex: 1;
  flex-direction: column;
}
@media (min-width: 1024px) {
  .highlight .items {
    border-radius: 0px;
    padding: 0 7px;
  }
}
@media (max-width: 1023px) {
  .highlight .items {
    background-color: transparent;
  }
}
@media (max-width: 1023px) {
  .highlight .items .main-filter-wrapper {
    box-shadow: 0px 0px 0px 10px #fff;
    border-bottom-right-radius: 0;
    border-bottom-left-radius: 0;
    background-color: #fff;
  }
  .maximized .highlight .items .main-filter-wrapper {
    background: transparent;
    box-shadow: none;
  }
}
.highlight .items .filter {
  z-index: 3;
  color: #dcf4ca;
  font-size: 11px;
  font-weight: 400;
  text-transform: uppercase;
  border-top: none;
  position: relative;
  background: #dcf4ca;
}
@media (max-width: 1023px) {
  .highlight .items .filter {
    background: #5c5c5c;
    border-bottom: 1px solid #111;
    overflow: hidden;
  }
  .maximized .highlight .items .filter {
    background: transparent;
  }
}
.highlight .items .filter.showing-all ul {
  flex-direction: column;
  padding: 15px 0;
}
.highlight .items .filter.showing-all ul li .labels {
  padding: 0px 0px 5px 0px;
}
.highlight .items .filter.showing-all ul li .labels strong {
  min-width: 115px;
}
.highlight .items .filter .filter-list {
  overflow: auto;
  position: relative;
  width: 100%;
}
.highlight .items .filter .show-all {
  position: absolute;
  top: 0px;
  left: 0px;
  height: calc(100% - 0px);
  width: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 4;
  font-size: 165%;
  color: #555;
  overflow: hidden;
  background-color: #5c5c5c;
  padding: 7px;
}
.highlight .items .filter .show-all span {
  border-radius: 5px;
  position: relative;
  z-index: 3;
  flex: 1;
  height: 100%;
  background-color: #cecece;
  display: flex;
  align-items: center;
  justify-content: center;
}
.highlight .items .filter .show-all:before {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  z-index: 1;
  pointer-events: none;
  content: "";
}
.highlight .items .filter .show-all:after {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  z-index: 2;
  pointer-events: none;
  content: "";
}
@media (min-width: 1024px) {
  .highlight .items .filter {
    font-size: 80%;
    display: none;
  }
}
.highlight .items .filter strong {
  font-weight: 600;
  text-transform: uppercase;
  color: #ffffff;
}
@media (max-width: 1023px) {
  .highlight .items .filter strong {
    color: #fff;
  }
}
.highlight .items .filter ul {
  width: 100%;
  height: 40px;
}
@media (max-width: 1023px) {
  .highlight .items .filter ul {
    margin-left: 5px;
  }
}
.highlight .items .filter ul li {
  display: flex;
}
@media (max-width: 1023px) {
  .highlight .items .filter ul li:last-child {
    padding-right: 60px;
  }
}
.highlight .items .filter ul li .labels {
  padding: 15px;
  padding-left: 0;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  flex-direction: row;
  width: 80%;
}
@media (max-width: 1023px) {
  .highlight .items .filter ul li .labels {
    align-items: center;
    width: 100%;
    padding: 15px 0;
  }
}
.highlight .items .filter ul li .labels strong {
  margin-left: 15px;
  padding: 2px 0;
}
@media (max-width: 1023px) {
  .highlight .items .filter ul li .labels strong {
    width: 0px;
    padding: 0;
    overflow: hidden;
    position: relative;
    margin: 0;
  }
}
.highlight .items .filter ul li .labels input {
  margin: 0px 5px 0 0;
  appearance: none;
  background-color: #fff;
  font: inherit;
  color: currentColor;
  width: 15px;
  height: 15px;
  min-width: 15px;
  min-height: 15px;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 100%;
  transition: all 200ms ease 0ms;
}
.highlight .items .filter ul li .labels input:before {
  content: "";
  width: 0.65em;
  height: 0.65em;
  transform: scale(0);
  transition: 120ms transform ease-in-out;
  box-shadow: inset 1em 1em var(--form-control-color);
}
@media (max-width: 1023px) {
  .highlight .items .filter ul li .labels input[type=checkbox] {
    border: 0px solid transparent;
    background-color: transparent;
    appearance: none;
    width: 100px;
    opacity: 1;
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    width: 100%;
    z-index: -2;
    border-radius: 3px;
  }
  .maximized .highlight .items .filter ul li .labels input[type=checkbox] {
    background-color: rgba(255, 255, 255, 0.1333333333);
  }
  .highlight .items .filter ul li .labels input[type=checkbox]:after {
    content: "";
    width: calc(100% - 2px);
    position: absolute;
    z-index: 0;
    height: calc(100% - 2px);
    top: 0;
    left: 0;
    border-radius: 3px;
    margin: 1px;
  }
}
.highlight .items .filter ul li .labels input:checked:before {
  transform: scale(1);
}
@media (max-width: 1023px) {
  .highlight .items .filter ul li .labels input:checked {
    background-color: rgba(255, 255, 255, 0.1333333333);
    border-radius: 5px;
    overflow: hidden;
  }
  .maximized .highlight .items .filter ul li .labels input:checked {
    background-color: #62b622;
    color: #ffffff;
  }
}
.highlight .items .filter ul li .labels input:checked:hover:active {
  background-color: #62b622;
}
.highlight .items .filter ul li .labels input:checked:active {
  background-color: #62b622;
}
@media (min-width: 1024px) {
  .highlight .items .filter ul li .labels input:checked:hover {
    background-color: red;
  }
}
.highlight .items .filter ul li .labels label {
  display: flex;
  align-items: center;
  margin-left: 0px;
  width: 100%;
  cursor: pointer;
  white-space: nowrap;
  padding: 2px 5px;
  position: relative;
  z-index: 1;
  color: #dfdfdf;
}
@media (max-width: 1023px) {
  .highlight .items .filter ul li .labels label {
    padding: 5px 10px;
    margin-right: 3px;
    display: none;
  }
  .highlight .items .filter ul li .labels label:nth-child(-n+6) {
    display: block;
  }
}
.highlight .items .filter ul li .labels label .filter-item {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  width: 100%;
}
.highlight .items .filter ul li .labels label .filter-item .filter-name {
  flex: 2;
  padding-right: 10px;
}
.highlight .items .filter ul li .labels label .filter-item .total-items {
  opacity: 0.8;
  font-size: 90%;
}
.highlight .items ul {
  position: relative;
  list-style-type: none;
  padding: 0;
  margin: 0;
  display: flex;
  width: 100%;
  flex: 1;
}
.highlight .items ul.sort {
  display: none;
}
.highlight .items ul li {
  padding: 0;
  margin: 0;
  position: relative;
}
@media (max-width: 1023px) {
  .secondary-filter .highlight .items ul li {
    padding: 0;
  }
}
@media (max-width: 1023px) {
  .highlight {
    flex-direction: column;
    gap: 5px;
  }
  .highlight .carousel {
    width: 100%;
  }
  .highlight .categories {
    width: 100%;
    flex: 1;
    overflow: hidden;
  }
  .highlight .categories img {
    display: none;
  }
}
@media (min-width: 1024px) {
  .highlight {
    flex-direction: row;
  }
  .highlight .carousel {
    width: calc(50% - 7.5px);
  }
  .highlight .categories {
    width: calc(50% - 7.5px);
    margin-left: 7.5px;
  }
  .highlight .categories ul {
    flex-wrap: wrap;
  }
  .highlight .categories ul li {
    min-width: calc(50% - 7.5px);
    max-width: calc(50% - 7.5px);
    display: none;
    position: relative;
  }
  .highlight .categories ul li:nth-child(1) {
    margin-right: 7.5px;
    margin-bottom: 7.5px;
  }
  .highlight .categories ul li:nth-child(2) {
    margin-left: 7.5px;
    margin-bottom: 7.5px;
  }
  .highlight .categories ul li:nth-child(3) {
    margin-right: 7.5px;
    margin-top: 7.5px;
  }
  .highlight .categories ul li:nth-child(4) {
    margin-left: 7.5px;
    margin-top: 7.5px;
  }
  .highlight .categories ul li a {
    display: flex;
    height: 100%;
    width: 100%;
    align-items: center;
    justify-content: center;
    background-color: #000;
    font-size: 125%;
    color: #fff;
    font-weight: 700;
    text-align: center;
  }
}
@media (min-width: 1024px) and (min-width: 1024px) {
  .highlight .categories ul li a {
    font-size: 150%;
  }
}
@media (min-width: 1024px) {
  .highlight .categories ul li a img {
    position: absolute;
    height: 100%;
    width: 100%;
    left: 0;
    top: 0;
    z-index: 1;
    opacity: 0.5;
    object-fit: cover;
    transition: all 1000ms ease;
  }
  .highlight .categories ul li a img.icon {
    display: none;
  }
  .highlight .categories ul li a span {
    position: relative;
    z-index: 2;
    text-shadow: 2px 2px #000;
  }
  .highlight .categories ul li a:hover img {
    opacity: 0.8;
  }
  .highlight .categories ul li:nth-child(1), .highlight .categories ul li:nth-child(2), .highlight .categories ul li:nth-child(3), .highlight .categories ul li:nth-child(4) {
    display: flex;
  }
}

section .filler-text {
  padding: 15px;
}

.elm-slider {
  margin-bottom: 20px;
  /* This line can be removed it was just for display on CodePen: */
  /* Functional styling;
   * These styles are required for noUiSlider to function.
   * You don't need to change these rules to apply your design.
   */
  /* Painting and performance;
   * Browsers can paint handles in their own layer.
   */
  /* Slider size and handle placement;
   */
  /* Styling;
   */
  /* Handles and cursors;
   */
  /* Disabled state;
   */
}
.elm-slider .container {
  padding-top: 10px;
  padding-right: 50px;
  padding-left: 10px;
}
.elm-slider .container .row {
  width: 100%;
  display: flex;
  flex: 1;
}
.elm-slider .container .row > div {
  flex: 1;
}
.elm-slider .slider-labels {
  margin-top: 10px;
}
.elm-slider .noUi-target, .elm-slider .noUi-target * {
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -ms-touch-action: none;
  touch-action: none;
  -ms-user-select: none;
  -moz-user-select: none;
  user-select: none;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
.elm-slider .noUi-target {
  position: relative;
  direction: ltr;
}
.elm-slider .noUi-base {
  width: 100%;
  height: 100%;
  position: relative;
  z-index: 1;
  /* Fix 401 */
}
.elm-slider .noUi-origin {
  position: absolute;
  right: 0;
  top: 0;
  left: 0;
  bottom: 0;
}
.elm-slider .noUi-handle {
  position: relative;
  z-index: 1;
}
.elm-slider .noUi-stacking .noUi-handle {
  /* This class is applied to the lower origin when
     its values is > 50%. */
  z-index: 10;
}
.elm-slider .noUi-state-tap .noUi-origin {
  -webkit-transition: left 0.3s, top 0.3s;
  transition: left 0.3s, top 0.3s;
}
.elm-slider .noUi-state-drag * {
  cursor: inherit !important;
}
.elm-slider .noUi-base, .elm-slider .noUi-handle {
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}
.elm-slider .noUi-horizontal {
  height: 4px;
}
.elm-slider .noUi-horizontal .noUi-handle {
  width: 18px !important;
  height: 18px !important;
  border-radius: 50%;
  left: -7px;
  top: -7px;
  background-color: #62b622;
}
.elm-slider .noUi-background {
  background: #D6D7D9;
}
.elm-slider .noUi-connect {
  background: #62b622;
  -webkit-transition: background 450ms;
  transition: background 450ms;
}
.elm-slider .noUi-origin {
  border-radius: 2px;
}
.elm-slider .noUi-target {
  border-radius: 2px;
}
.elm-slider .noUi-draggable {
  cursor: w-resize;
}
.elm-slider .noUi-vertical .noUi-draggable {
  cursor: n-resize;
}
.elm-slider .noUi-handle {
  cursor: default;
  -webkit-box-sizing: content-box !important;
  -moz-box-sizing: content-box !important;
  box-sizing: content-box !important;
}
.elm-slider .noUi-handle:active {
  border: 8px solid #62b622;
  border: 8px solid rgba(53, 93, 187, 0.38);
  -webkit-background-clip: padding-box;
  background-clip: padding-box;
  left: -14px;
  top: -14px;
}
.elm-slider [disabled].noUi-connect, .elm-slider [disabled] .noUi-connect {
  background: #B8B8B8;
}
.elm-slider [disabled].noUi-origin, .elm-slider [disabled] .noUi-handle {
  cursor: not-allowed;
}

.frame-locations .contained {
  font-size: 14px;
}
.frame-locations .contained h2 {
  font-weight: 600;
  margin-bottom: 10px;
}
.frame-locations .contained .search-input {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 15px;
}
.frame-locations .contained .search-input .input {
  flex: 1;
  position: relative;
}
.frame-locations .contained .search-input .input .fa-search {
  position: absolute;
  height: 100%;
  width: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  left: 0;
  top: 0;
  z-index: 2;
  font-size: 18px;
  margin-left: 10px;
}
.frame-locations .contained .search-input .input input {
  width: 100%;
  border: 1px solid #bbb;
  background-color: transparent;
  border-radius: 20px;
  font-size: 16px;
  padding: 10px 50px;
  margin: 0;
  position: relative;
  z-index: 1;
}
.frame-locations .contained .search-input .input-ext {
  padding: 10px;
}
.frame-locations .contained .location-search {
  display: flex;
  flex-direction: column;
  width: 100%;
  margin-bottom: 15px;
}
.frame-locations .contained .location-search .geolocate-location {
  display: flex;
  align-items: center;
  padding: 0 5px;
  cursor: pointer;
}
.frame-locations .contained .location-search .geolocate-location i {
  margin-right: 10px;
  font-size: 22px;
}
.frame-locations .contained .location-search .geolocate-location span {
  text-decoration: underline;
}
.frame-locations .contained .locations {
  display: flex;
  flex-direction: column;
}
.frame-locations .contained .locations .location {
  width: 100%;
  padding: 20px 10px;
  border-top: 1px solid #ddd;
  cursor: pointer;
  transition: all 300ms ease;
}
.frame-locations .contained .locations .location:hover {
  background-color: #dcf4ca22;
}
.frame-locations .contained .locations .location .location-title {
  font-weight: 600;
  font-size: 16px;
}

.cart-submitted .cart-bg {
  background-color: #1e3e84;
}
.cart-working .cart-bg {
  background-color: #5d82d2;
}
.cart-pending .cart-bg {
  background-color: #84841e;
}
.cart-working .cart-bg {
  background-color: #5d82d2;
}
.cart-transport .cart-bg {
  background-color: #ff9800;
}
.cart-ready .cart-bg {
  background-color: #6d4f83;
}
.cart-complete .cart-bg {
  background-color: #5d82d2;
}

.frame-cart {
  display: none;
}
.active-cart .frame-cart {
  display: flex;
}
.frame-cart.inactive-cart {
  display: flex;
}
.active-cart .frame-cart.inactive-cart {
  display: none;
}
.frame-cart textarea {
  width: 100%;
  height: 100px;
  padding: 10px;
  border-radius: 15px;
  border: 1px solid #d9d9d9;
}
.frame-cart .products-container .products {
  border-radius: 0;
  padding: 10px;
}
.frame-cart .list-items {
  border-top: 1px solid rgba(8, 8, 8, 0.0823529412);
  border-bottom: 1px solid rgba(8, 8, 8, 0.0823529412);
  border-radius: 0;
}
.frame-cart .cart-summary {
  padding: 15px;
}
.frame-cart .cart-summary h1 {
  font-size: 200%;
  font-weight: 600;
}
.frame-cart .cart-summary .cart-status {
  display: none;
  padding: 10px;
  color: #fff;
  width: 100%;
}
.cart-submitted .frame-cart .cart-summary .cart-status.submitted {
  display: inline-flex;
}
.cart-working .frame-cart .cart-summary .cart-status.working {
  display: inline-flex;
}
.cart-pending .frame-cart .cart-summary .cart-status.pending {
  display: inline-flex;
}
.cart-working .frame-cart .cart-summary .cart-status.working {
  display: inline-flex;
}
.cart-transport .frame-cart .cart-summary .cart-status.transport {
  display: inline-flex;
}
.cart-ready .frame-cart .cart-summary .cart-status.ready {
  display: inline-flex;
}
.cart-complete .frame-cart .cart-summary .cart-status.complete {
  display: inline-flex;
}
.frame-cart .products .product .meta .title-row {
  padding-right: 50px;
}
.active-cart .frame-cart .place-order {
  display: block;
}
.has-submitted-cart.active-cart .frame-cart .place-order {
  display: none;
}
.frame-cart .contained {
  display: flex;
}
.frame-cart .contained textarea {
  width: 100%;
  height: 80px;
  display: none;
  border: 0px solid transparent;
  box-shadow: inset 0px 0px 0px 1px rgba(0, 0, 0, 0.5333333333);
  padding: 5px;
}
.active-cart .frame-cart .contained textarea {
  display: flex;
}
.frame-cart .contained .cart-summary.filter.side-filter ul li {
  padding-bottom: 10px;
  justify-content: space-between;
  align-items: center;
}
.frame-cart .contained .cart-summary.filter.side-filter ul li:last-child {
  margin-bottom: 0;
}
.has-submitted-cart .frame-cart .contained .cart-summary.filter.side-filter ul li:last-child {
  display: none;
}
.frame-cart .contained .cart-summary.filter.side-filter ul li.keep-shopping {
  margin-bottom: 20px;
  letter-spacing: 1px;
}
.frame-cart .contained .cart-summary.filter.side-filter ul li.total {
  font-weight: 600;
}
.frame-cart .contained .cart-summary.filter.side-filter ul li .lbl {
  margin-right: 10px;
}
@media (max-width: 1023px) {
  .frame-cart .contained {
    flex-direction: column;
  }
  .frame-cart .contained .cart-summary.filter.side-filter {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-bottom: 0;
    margin-bottom: 0;
  }
  .frame-cart .contained .cart-summary.filter.side-filter ul {
    text-align: center;
    justify-content: center;
    align-items: center;
  }
  .frame-cart .contained .cart-summary.filter.side-filter h1 {
    text-align: center;
  }
}
@media (min-width: 1024px) {
  .frame-cart .contained {
    flex-direction: row;
  }
  main .frame-cart .contained .cart-summary {
    position: sticky;
    top: 125px;
    height: 100%;
    padding-right: 30px;
  }
}
.modal .frame-cart .contained {
  flex-direction: column;
}
.modal .frame-cart .contained .keep-shopping {
  display: none;
}
.modal .frame-cart .contained .cart-summary {
  width: 100%;
}
.vibe-rounded .modal .frame-cart .contained .products ul li {
  max-width: calc(50% - 5px);
}

.frame-brands .contained {
  padding: 25px;
  font-size: 14px;
}
.frame-brands .contained h2 {
  font-weight: 600;
  margin-bottom: 10px;
}

.frame-rewards {
  /* credit-card aspect */
  /* fan them with a consistent pattern using CSS vars */
  /* translate then rotate; tweak the step values to taste */
}
.frame-rewards .main-points-card {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  position: relative;
}
.frame-rewards .rewards-cards {
  position: absolute;
  right: -60px; /* push stack off the edge like the screenshot */
  top: 0px;
  width: 260px;
  height: 160px;
  overflow: visible; /* don't clip the fan */
  pointer-events: none; /* purely decorative */
}
.frame-rewards .rewards-card {
  position: absolute;
  width: 180px;
  aspect-ratio: 85.6/53.98;
  border: 3px solid #000;
  border-radius: 8px;
  background: #555;
  box-shadow: -5px 0px 10px 0px rgba(0, 0, 0, 0.05);
  right: 0;
  bottom: 0;
  /* pivot around bottom-right, so rotations look like the mock */
  transform-origin: 100% 0%;
  transition: all 300ms ease;
  right: -50px;
  transform: rotate(calc(12deg - var() * 6deg));
  --i: 0;
}
.frame-rewards .rewards-card:nth-child(1) {
  z-index: 1;
}
.frame-rewards .rewards-card:nth-child(2) {
  z-index: 2;
}
.frame-rewards .rewards-card:nth-child(3) {
  z-index: 3;
}
.frame-rewards .rewards-card:nth-child(4) {
  z-index: 4;
}
.frame-rewards .rewards-card:nth-child(5) {
  z-index: 5;
}
.frame-rewards.page-loaded .rewards-card:nth-child(1) {
  --i:0;
  z-index: 1;
  right: -50px;
}
.frame-rewards.page-loaded .rewards-card:nth-child(2) {
  --i:1;
  z-index: 2;
  right: -40px;
}
.frame-rewards.page-loaded .rewards-card:nth-child(3) {
  --i:2;
  z-index: 3;
  right: -30px;
}
.frame-rewards.page-loaded .rewards-card:nth-child(4) {
  --i:3;
  z-index: 4;
  right: -20px;
}
.frame-rewards.page-loaded .rewards-card:nth-child(5) {
  --i:4;
  z-index: 5;
  right: -10px;
}
.frame-rewards .rewards-card {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px;
  transform: rotate(calc(12deg - var(--i) * 6deg));
}
.frame-rewards .rewards-card .dots {
  border-radius: 8px;
  border: 3px solid currentColor;
  position: absolute;
  left: 5px;
  top: 5px;
  width: calc(100% - 10px);
  height: calc(100% - 10px);
  opacity: 0.2;
  display: none;
}
.frame-rewards .rewards-card .dots .dot {
  top: -7.5px;
  left: -7.5px;
  position: absolute;
  border-radius: 100%;
  width: 15px;
  height: 15px;
  background-color: currentColor;
  border: 3px solid currentColor;
  overflow: hidden;
  opacity: 0;
}
.frame-rewards .rewards-card .dots .dot:nth-child(2) {
  left: auto;
  right: -7.5px;
}
.frame-rewards .rewards-card .dots .dot:nth-child(3) {
  top: auto;
  bottom: -7.5px;
}
.frame-rewards .rewards-card .dots .dot:nth-child(4) {
  left: auto;
  right: -7.5px;
  top: auto;
  bottom: -7.5px;
}
.user-unverified .frame-rewards .items-to-redeem {
  order: 3;
}
.frame-rewards .contained .tab {
  background-color: transparent;
}
.frame-rewards .contained .tab-headers {
  background-color: #ddd;
}
.frame-rewards .contained .intro {
  text-align: center;
  padding: 15px 15px 15px 15px;
}
.frame-rewards .contained .rewards-levels-vertical {
  position: relative;
}
.frame-rewards .contained .rewards-levels-vertical .earned-points {
  padding: 15px 10px 25px 10px;
  background-color: #fff;
  color: #111;
  text-align: center;
  border-radius: 20px 20px 0 0;
  transform: translateY(10px);
  border: 1px dotted #111;
}
.frame-rewards .contained .rewards-levels-vertical .rewards-levels {
  position: relative;
  display: flex;
  flex-direction: column-reverse;
  font-size: 14px;
  gap: 0px;
}
.frame-rewards .contained .rewards-levels-vertical .rewards-levels .progress-container {
  position: absolute;
  right: 15px;
  width: 30px;
  border-radius: 20px;
  height: calc(100% - 40px);
  top: 20px;
  background-color: #cfcfcf;
  border: 1px solid #111;
  z-index: 3;
}
.frame-rewards .contained .rewards-levels-vertical .rewards-levels .progress-container .progress {
  position: absolute;
  bottom: 5px;
  left: 5px;
  width: calc(100% - 10px);
  height: 20%;
  background-color: #bbb;
  border-radius: 10px;
  transition: height 500ms ease;
}
.frame-rewards .contained .rewards-levels-vertical .rewards-levels .progress-container .progress:before {
  content: "";
  position: absolute;
  top: 4px;
  left: 3px;
  background-color: #60f159;
  width: 12px;
  height: 12px;
  border-radius: 100%;
}
.frame-rewards .contained .rewards-levels-vertical .rewards-levels .progress-container .progress:after {
  content: "";
  position: absolute;
  bottom: 4px;
  left: 3px;
  background-color: rgba(255, 255, 255, 0.4666666667);
  width: 12px;
  height: 12px;
  border-radius: 100%;
}
.frame-rewards .contained .rewards-levels-vertical .rewards-levels .rewards-level {
  width: 100%;
  padding: 0px;
  padding-right: 70px;
  opacity: 1;
  color: #2c5111;
  position: relative;
  display: flex;
  z-index: 1;
  border: 1px solid #111;
  border-bottom: 0;
}
.frame-rewards .contained .rewards-levels-vertical .rewards-levels .rewards-level .xpoints {
  position: absolute;
  width: 100%;
  left: 0;
  bottom: 0px;
  font-size: 11px;
  color: #fff;
  text-align: right;
  opacity: 0.7;
  padding-right: 45px;
}
.frame-rewards .contained .rewards-levels-vertical .rewards-levels .rewards-level .icon {
  font-size: 25px;
  min-width: 60px;
  max-width: 60px;
  padding: 10px 15px 10px 25px;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
}
.frame-rewards .contained .rewards-levels-vertical .rewards-levels .rewards-level .meta {
  display: flex;
  padding: 15px 0px;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  position: relative;
  flex: 1;
  gap: 2px;
  opacity: 0.5;
}
.frame-rewards .contained .rewards-levels-vertical .rewards-levels .rewards-level .meta .title, .frame-rewards .contained .rewards-levels-vertical .rewards-levels .rewards-level .meta .xdesc, .frame-rewards .contained .rewards-levels-vertical .rewards-levels .rewards-level .meta .xpoints {
  /*padding: 2px 7.5px;
  border-radius: 5px;
  display: inline;
  background-color: #00000033;*/
}
.frame-rewards .contained .rewards-levels-vertical .rewards-levels .rewards-level .meta .next-level {
  display: none;
  background-color: rgba(0, 0, 0, 0.4196078431);
  padding: 10px 10px;
  border-radius: 10px;
}
.frame-rewards .contained .rewards-levels-vertical .rewards-levels .rewards-level .title {
  font-weight: 600;
  text-transform: uppercase;
  font-size: 14px;
}
.frame-rewards .contained .rewards-levels-vertical .rewards-levels .rewards-level.active {
  box-shadow: 0px 0px 3px 0px #000;
  z-index: 2;
  border-radius: 15px;
  transform: scale(1.05);
  opacity: 1;
}
.frame-rewards .contained .rewards-levels-vertical .rewards-levels .rewards-level.active .next-level {
  display: flex;
}
.frame-rewards .contained .rewards-levels-vertical .rewards-levels .rewards-level.active:before {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: -20px;
}
.frame-rewards .contained .rewards-levels-vertical .rewards-levels .rewards-level.active .meta {
  opacity: 1;
}
.frame-rewards .contained .rewards-levels-vertical .rewards-levels .rewards-level.first {
  border-bottom-right-radius: 15px;
  border-bottom-left-radius: 15px;
  border: 1px solid #111;
}
.frame-rewards .contained .rewards-levels-vertical .rewards-levels .rewards-level.last {
  border-top-right-radius: 15px;
  border-top-left-radius: 15px;
}
.frame-rewards .contained .rewards-levels-container {
  padding: 50px 15px 15px 15px;
  position: relative;
}
.frame-rewards .contained .rewards-levels-container .rewards-levels {
  display: flex;
  position: relative;
  gap: 0px;
  width: 100%;
  color: #111;
  margin-bottom: 20px;
  font-size: 11px;
}
.frame-rewards .contained .rewards-levels-container .rewards-levels .rewards-level {
  position: relative;
  flex: 1;
  text-align: center;
  display: flex;
  flex-direction: column;
}
.frame-rewards .contained .rewards-levels-container .rewards-levels .rewards-level.gap {
  height: 100%;
  max-width: 10px;
  border: 0;
}
.frame-rewards .contained .rewards-levels-container .rewards-levels .rewards-level.gap .status-level {
  background-color: #777;
  height: 100%;
}
.frame-rewards .contained .rewards-levels-container .rewards-levels .rewards-level.gap .status-level:before {
  display: none;
}
.frame-rewards .contained .rewards-levels-container .rewards-levels .rewards-level.active .status-level .progress {
  min-width: 25px;
}
.frame-rewards .contained .rewards-levels-container .rewards-levels .rewards-level.active .status-level .progress .ind {
  opacity: 1;
}
.frame-rewards .contained .rewards-levels-container .rewards-levels .rewards-level .meta-info {
  text-align: left;
  position: relative;
  padding-top: 10px;
  font-size: 10px;
}
.frame-rewards .contained .rewards-levels-container .rewards-levels .rewards-level .meta-info > div {
  position: relative;
  display: inline-block;
  text-align: left;
}
.frame-rewards .contained .rewards-levels-container .rewards-levels .rewards-level .status-level {
  background-color: #bbb;
  border-left: 0;
  font-size: 11px;
  padding: 5px 5px;
  position: relative;
  z-index: 2;
  min-height: 20px;
}
.frame-rewards .contained .rewards-levels-container .rewards-levels .rewards-level .status-level:before {
  content: "";
  width: 1px;
  background-color: #999;
  top: 0;
  left: 0;
  height: calc(100% + 8px);
  position: absolute;
  z-index: 2;
}
.frame-rewards .contained .rewards-levels-container .rewards-levels .rewards-level .status-level .lbl {
  z-index: 2;
  position: relative;
  line-height: normal;
  padding: 3px 0;
}
.frame-rewards .contained .rewards-levels-container .rewards-levels .rewards-level .status-level .progress {
  z-index: 1;
  position: absolute;
  top: 5px;
  left: 0px;
  height: calc(100% - 10px);
  width: 0%;
}
.frame-rewards .contained .rewards-levels-container .rewards-levels .rewards-level .status-level .progress .ind {
  position: absolute;
  top: -25px;
  width: 10px;
  height: 10px;
  right: 0;
  opacity: 0;
  color: #000;
}
.frame-rewards .contained .rewards-levels-container .rewards-levels .rewards-level .status-level .progress .ind div {
  position: absolute;
  top: -13px;
  transform: translateX(-50%);
  white-space: nowrap;
}
.frame-rewards .contained .rewards-levels-container .rewards-levels .rewards-level:first-child .meta-info {
  text-align: left;
}
.frame-rewards .contained .rewards-levels-container .rewards-levels .rewards-level:first-child .meta-info > div {
  transform: translateX(0%);
  text-align: left;
}
.frame-rewards .contained .rewards-levels-container .rewards-levels .rewards-level:first-child .status-level {
  padding: 5px 0;
  border-top-left-radius: 10px;
  border-bottom-left-radius: 10px;
}
.frame-rewards .contained .rewards-levels-container .rewards-levels .rewards-level:first-child .progress {
  left: 5px;
}
.frame-rewards .contained .rewards-levels-container .rewards-levels .rewards-level:last-child .status-level {
  padding: 5px 0;
  border-top-right-radius: 10px;
  border-bottom-right-radius: 10px;
}
.frame-rewards .contained .member-panel {
  padding: 0px 0px 15px 0px;
  width: 100%;
  justify-content: space-between;
  gap: 10px;
  margin-top: 15px;
}
.frame-rewards .contained .member-panel .points-section {
  align-items: center;
  justify-content: center;
  background-size: cover;
  display: flex;
  gap: 5px;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  flex-direction: row;
  padding: 0 15px 0px 15px;
  font-size: 14px;
  /*
  .lifetime-points {
      .lbl {
          font-size: 30px;
          color: #111;
          background-color: transparent;
      }
  }*/
}
.frame-rewards .contained .member-panel .points-section .info-title {
  text-align: center;
  font-size: 12px;
  text-transform: uppercase;
  color: #111;
}
.frame-rewards .contained .member-panel .points-section .lbl {
  text-align: center;
  border-top: 1px solid #111;
  padding-top: 5px;
  margin-top: 5px;
  width: 100%;
  font-size: 18px;
  font-weight: 600;
}
.frame-rewards .contained .member-panel .points-section .current-points, .frame-rewards .contained .member-panel .points-section .lifetime-points, .frame-rewards .contained .member-panel .points-section .status, .frame-rewards .contained .member-panel .points-section .multiplier {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  padding: 10px;
}
.frame-rewards .contained .member-panel .points-section .current-points .lbl, .frame-rewards .contained .member-panel .points-section .lifetime-points .lbl, .frame-rewards .contained .member-panel .points-section .status .lbl, .frame-rewards .contained .member-panel .points-section .multiplier .lbl {
  /*padding:5px 20px;border-radius:15px;
  background-color:$highlightBackground;
  color:$highlightColor;
  font-size:40px;font-weight:600;display:flex;line-height:normal;
  */
}
.frame-rewards .contained .member-panel .level-section {
  display: flex;
}
.frame-rewards .contained .member-levels {
  display: flex;
  font-size: 11px;
  width: 100%;
  color: #222;
}
.frame-rewards .contained .member-levels .member-level {
  display: flex;
  flex: 1;
  align-items: center;
  justify-content: center;
  background-color: #ccc;
  padding: 5px 10px;
  flex-direction: column;
  white-space: nowrap;
  z-index: 1;
}
.frame-rewards .contained .member-levels .member-level div {
  color: #111;
}
.frame-rewards .contained .member-levels .member-level:last-child {
  border-top-right-radius: 5px;
  border-bottom-right-radius: 5px;
}
.frame-rewards .contained .member-levels .member-level:first-child {
  border-top-left-radius: 5px;
  border-bottom-left-radius: 5px;
}
.frame-rewards .contained .member-levels .member-level.active {
  box-shadow: 0px 0px 0px 5px currentColor;
  z-index: 3;
  font-size: 115%;
  font-weight: 900;
  border-radius: 5px;
  position: relative;
}
.frame-rewards .contained .member-levels .member-level.active:before {
  content: "";
  box-shadow: 0px 0px 0px 5px rgba(0, 0, 0, 0.3333333333);
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  position: absolute;
  border-radius: 5px;
}
.frame-rewards .contained .member-levels .member-level.intro {
  font-weight: 600;
  flex: 0;
  text-align: right;
  align-items: flex-end;
  padding: 5px 15px;
}
.frame-rewards .contained .redemptions .redemption {
  border-radius: 10px;
}
.frame-rewards .contained .mission-card {
  padding: 25px;
  background-color: #fff;
  display: flex;
  border-bottom: 1px solid #ccc;
}
.frame-rewards .contained .mission-card .mission-card-meta {
  display: flex;
  flex-direction: column;
  width: 100%;
  flex: 1;
  gap: 5px;
  line-height: normal;
}
.frame-rewards .contained .mission-card .mission-card-meta .mission-card-title {
  font-weight: 600;
}
.frame-rewards .contained .mission-card .mission-card-meta .mission-card-description {
  font-size: 12px;
}
.frame-rewards .contained .mission-card .mission-card-meta .mission-card-items {
  display: flex;
  gap: 5px;
  width: 100%;
  position: relative;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}
.frame-rewards .contained .mission-card .mission-card-meta .mission-card-points > div {
  color: #1e6619;
  background-color: #e1e4c0;
  border-radius: 10px;
  padding: 3px 10px;
  font-size: 12px;
  display: inline-block;
  margin: 5px 0;
  border: 1px solid #1e6619;
}
.frame-rewards .contained .mission-card .mission-card-label {
  font-size: 50px;
  text-transform: uppercase;
  margin-bottom: 5px;
  font-weight: 500;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  min-width: 75px;
  max-width: 75px;
}
.frame-rewards .contained .mission-card .progress-container {
  position: relative;
  width: 100%;
  border-radius: 10px;
  height: 15px;
  background-color: #ddd;
}
.frame-rewards .contained .mission-card .progress-container .progress {
  position: absolute;
  left: 0px;
  top: 0px;
  height: calc(100% - 0px);
  background-color: #15d206;
  border-radius: 10px;
}
.frame-rewards .contained .mission-card .valid {
  font-size: 12px;
  opacity: 0.7;
}
.frame-rewards .contained .mission-card .progress-of {
  white-space: nowrap;
  font-size: 12px;
}

.frame-feed .feedPosts {
  gap: 5px;
  width: 100%;
  align-items: center;
}
.frame-feed .feedPosts .feedPost {
  width: 100%;
  display: flex;
  background-color: #f7f7f7;
  color: #111;
  max-width: 500px;
}
.frame-feed .feedPosts .feedPost .show-liked {
  display: none;
}
.frame-feed .feedPosts .feedPost .post-content {
  border: 0;
  padding: 0 0 0 0;
  text-align: left;
  width: 100%;
}
.frame-feed .feedPosts .feedPost .post-content img {
  max-height: 100vw;
  object-fit: contain;
  object-position: center;
}
.frame-feed .feedPosts .feedPost .post-content .like-circle {
  font-size: 10px;
  display: inline-flex;
  width: 17px;
  height: 17px;
  align-items: center;
  justify-content: center;
  background-color: #62b622;
  color: #ffffff;
  border-radius: 100%;
}
.frame-feed .feedPosts .feedPost .post-content .feed-post-actions {
  border-top: 1px solid rgba(0, 0, 0, 0.0666666667);
  align-items: center;
  font-weight: 600;
  text-align: center;
}
.frame-feed .feedPosts .feedPost .post-content .feed-post-actions .feed-post-action {
  flex: 1;
  display: flex;
  align-items: center;
  font-size: 14px;
  justify-content: center;
  gap: 5px;
  padding: 10px;
  color: #333;
}
.frame-feed .feedPosts .feedPost .post-content .feed-post-actions .feed-post-action.like-feed-post .d {
  display: none;
}
.frame-feed .feedPosts .feedPost.liked .hide-liked {
  display: none !important;
}
.frame-feed .feedPosts .feedPost.liked .show-liked {
  display: block;
  width: 100%;
}
.frame-feed .feedPosts .feedPost.liked .post-content .feed-post-actions .feed-post-action.like-feed-post {
  color: #62b622;
}
.frame-feed .feedPosts .feedPost.liked .post-content .feed-post-actions .feed-post-action.like-feed-post .d {
  display: inline;
}

.frame-history .historyPost {
  width: 100%;
  display: flex;
  flex-direction: column;
  padding: 15px;
  border-bottom: 5px solid #fff;
  font-size: 14px;
  gap: 3px;
}
.frame-history .historyPost .rate i {
  color: #aaa;
  padding: 1.5px;
}
.frame-history .historyPost .rate i.active {
  color: #62b622;
}
.frame-history .historyPost h2 {
  margin: 5px 0px 5px 0px;
  font-weight: 600;
}
.frame-history .historyPost .summary {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  font-weight: 600;
  font-size: 18px;
}
.frame-history .historyPost .summary .rate-order {
  display: flex;
}
.frame-history .historyPost .type {
  text-transform: capitalize;
}
.frame-history .historyPost .cashier .name {
  text-transform: capitalize;
}
.frame-history .historyPost .discounts, .frame-history .historyPost .items {
  width: 100%;
  font-size: 12px;
  display: flex;
  flex-direction: column;
}
.frame-history .historyPost .discounts .item, .frame-history .historyPost .items .item {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 5px;
}
.frame-history .historyPost .discounts .item .image, .frame-history .historyPost .items .item .image {
  width: 50px;
  max-width: 50px;
  height: 50px;
  background-color: #fff;
  border-radius: 5px;
  overflow: hidden;
}
.frame-history .historyPost .discounts .item .image img, .frame-history .historyPost .items .item .image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}
.frame-history .historyPost .discounts .item .discount-name, .frame-history .historyPost .items .item .discount-name {
  max-width: 150px;
}
.frame-history .historyPost .discounts .item .savings, .frame-history .historyPost .items .item .savings {
  background-color: rgba(0, 0, 0, 0.0666666667);
  padding: 5px 10px;
  border-radius: 5px;
}
.frame-history .historyPost .discounts .item .quantity, .frame-history .historyPost .items .item .quantity {
  max-width: 20px;
  min-width: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
}
.frame-history .historyPost .discounts .item .product-name, .frame-history .historyPost .items .item .product-name {
  flex: 1;
}
.frame-history .historyPost .discounts .item .product-name .brand, .frame-history .historyPost .items .item .product-name .brand {
  color: rgba(0, 0, 0, 0.6);
}
.frame-history .historyPost .discounts .item .rate-item, .frame-history .historyPost .items .item .rate-item {
  display: flex;
  font-size: 15px;
}
.frame-history .historyPost .items {
  gap: 5px;
}
.frame-history .historyPost .items .item {
  background-color: rgba(0, 0, 0, 0.062745098);
  padding: 5px 10px;
  border-radius: 5px;
}
.frame-history .historyPost .discounts {
  gap: 10px;
  flex-wrap: wrap;
  flex-direction: row;
}
.frame-history .historyPost .discounts .item {
  background-color: #62b622;
  color: #ffffff;
  border-radius: 5px;
  padding: 5px 10px;
  width: auto;
}
.frame-history .historyPost.transaction {
  background-color: #ebebeb;
  color: #000000;
}
.frame-history .historyPost.transaction .status {
  display: none;
}
.frame-history .historyPost.redemption {
  background-color: #dcf4ca;
  color: #2c5111;
}
.frame-history .historyPost.redemption .rate {
  display: none;
}
.frame-history .historyPost.mission {
  background-color: #dcf4ca;
  color: #2c5111;
}
.frame-history .historyPost.mission .rate {
  display: none;
}
.frame-history .historyPost.points {
  background-color: #62b622;
  color: #ffffff;
}
.frame-history .historyPost.points .rate {
  display: none;
}

.frame-referral .contained h2 {
  font-weight: 600;
  margin-bottom: 10px;
}
.frame-referral .contained .section-panel .panel-header {
  padding: 0px 0px 0 0px;
  width: 100%;
  justify-content: space-between;
  gap: 10px;
  padding: 20px;
  background-color: #62b622;
  color: #ffffff;
}
.frame-referral .contained .section-panel .panel-header form {
  display: flex;
  flex-direction: column;
  width: 100%;
  gap: 10px;
}
.frame-referral .contained .section-panel .panel-header form label {
  width: 100%;
}
.frame-referral .contained .section-panel .panel-header form label .lbl {
  width: 100%;
  font-weight: 600;
}
.frame-referral .contained .section-panel .panel-header form label .val {
  width: 100%;
}
.frame-referral .contained .section-panel .panel-header form label .val input, .frame-referral .contained .section-panel .panel-header form label .val textarea {
  width: 100%;
  border-radius: 10px;
  border: 0;
  padding: 5px 10px;
}
.frame-referral .contained .section-panel .panel-header form label .val textarea {
  height: 100px;
}
.frame-referral .contained .section-panel .panel-header form .button {
  width: 100%;
  text-align: center;
  background-color: #777;
  color: #aaa;
  transition: all 300ms ease;
}
.frame-referral .contained .section-panel .panel-header form .button.enabled {
  background-color: #dcf4ca;
  color: #2c5111;
}
.frame-referral .contained .section-panel .section-items {
  padding: 15px;
}

.frame-services {
  /* credit-card aspect */
  /* fan them with a consistent pattern using CSS vars */
  /* translate then rotate; tweak the step values to taste */
}
.frame-services .contained {
  padding: 0;
}
.frame-services .main-points-card {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  position: relative;
}
.frame-services .rewards-cards {
  position: absolute;
  right: -60px; /* push stack off the edge like the screenshot */
  top: 0px;
  width: 260px;
  height: 160px;
  overflow: visible; /* don't clip the fan */
  pointer-events: none; /* purely decorative */
}
.frame-services .rewards-card {
  position: absolute;
  width: 180px;
  aspect-ratio: 85.6/53.98;
  border: 3px solid #000;
  border-radius: 8px;
  background: #555;
  box-shadow: -5px 0px 10px 0px rgba(0, 0, 0, 0.05);
  right: 0;
  bottom: 0;
  /* pivot around bottom-right, so rotations look like the mock */
  transform-origin: 100% 0%;
  transition: all 300ms ease;
  right: -50px;
  transform: rotate(calc(12deg - var() * 6deg));
  --i: 0;
}
.frame-services .rewards-card:nth-child(1) {
  z-index: 1;
}
.frame-services .rewards-card:nth-child(2) {
  z-index: 2;
}
.frame-services .rewards-card:nth-child(3) {
  z-index: 3;
}
.frame-services .rewards-card:nth-child(4) {
  z-index: 4;
}
.frame-services .rewards-card:nth-child(5) {
  z-index: 5;
}
.frame-services.page-loaded .rewards-card:nth-child(1) {
  --i:0;
  z-index: 1;
  right: -50px;
}
.frame-services.page-loaded .rewards-card:nth-child(2) {
  --i:1;
  z-index: 2;
  right: -40px;
}
.frame-services.page-loaded .rewards-card:nth-child(3) {
  --i:2;
  z-index: 3;
  right: -30px;
}
.frame-services.page-loaded .rewards-card:nth-child(4) {
  --i:3;
  z-index: 4;
  right: -20px;
}
.frame-services.page-loaded .rewards-card:nth-child(5) {
  --i:4;
  z-index: 5;
  right: -10px;
}
.frame-services .rewards-card {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px;
}
.frame-services .rewards-card {
  transform: rotate(calc(12deg - var(--i) * 6deg));
}

html.chat-mode {
  background-color: #62b622;
}
html.chat-mode body {
  background-color: transparent;
}
html.chat-mode body main {
  background-color: transparent;
}
html.chat-mode body main .frame-chat.gray {
  background-color: transparent;
  background-color: #62b622;
}
.frame-chat {
  align-self: stretch;
  justify-self: stretch;
  flex: 5;
  align-items: flex-start;
  justify-content: flex-start;
  text-align: left;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  font-size: 14px;
}
.frame-chat img {
  transform: translate3d(0, 0, 0);
}
.frame-chat .avatar {
  display: flex;
  position: absolute;
  z-index: 3;
  left: 0;
  padding: 0 10px 0 5px;
  width: 55px;
}
.frame-chat .avatar img {
  width: 100%;
  opacity: 0;
  background-color: #2d6105;
  padding: 5px;
  border-radius: 5px;
}
.frame-chat .show-admin {
  display: none;
}
.frame-chat.admin-mode .show-admin {
  display: flex;
}
.frame-chat .is-typing-container {
  font-size: 12px;
  opacity: 0;
  transition: all 300ms ease;
  padding: 20px 30px 0px 30px;
  text-align: left;
  width: 100%;
  position: absolute;
  font-size: 15px;
  left: 0;
  margin-bottom: 0;
}
.search-bind .frame-chat .is-typing-container {
  position: relative;
}
.frame-chat .is-typing-container .avatar {
  padding: 3px 10px;
}
.frame-chat.is-typing .is-typing-container {
  opacity: 1;
  animation: fade-in 400ms;
}
.frame-chat.admin-mode .messenger .messages .message.inbound .message-options.basic {
  display: none;
}
.frame-chat .chat-opener {
  display: flex;
  pointer-events: none;
  width: 100%;
  height: 100%;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: 35px;
  background-color: #62b622;
  color: #ffffff;
  position: fixed;
  bottom: 0;
  right: 0;
  opacity: 0;
  z-index: 25;
  pointer-events: none;
  transition: opacity 0ms ease 0ms;
}
.frame-chat .chat-opener i {
  opacity: 0;
  transition: all 100ms ease;
  height: 75px;
  width: 75px;
  align-items: center;
  justify-content: center;
  position: fixed;
  top: 0;
  right: 0;
  display: flex;
}
@media (max-height: 100px) {
  .frame-chat .chat-opener {
    display: flex;
    opacity: 1;
    transition: opacity 0ms ease 0ms;
  }
}
@media (max-width: 90px) {
  .frame-chat .chat-opener i {
    opacity: 1;
  }
}
@keyframes chat-opener-new-message {
  50% {
    box-shadow: inset 0px 0px 25px 10px blue;
  }
}
.frame-chat .show-new-chat-message {
  display: none !important;
}
.frame-chat.new-chat-message .show-new-chat-message {
  display: flex !important;
}
.frame-chat.new-chat-message .hide-new-chat-message {
  display: none !important;
}
.frame-chat.new-chat-message .chat-opener {
  animation: chat-opener-new-message 3000ms linear infinite;
}
.frame-chat .messenger {
  display: flex;
  flex-direction: column;
  width: 100%;
  position: relative;
  top: 0;
  right: 0;
  flex: 1;
}
.frame-chat .messenger .chat-controls {
  background-color: #62b622;
  color: #ffffff;
  padding: 10px 20px;
  height: 60px;
  min-height: 60px;
  padding-right: 60px;
}
.search-bind .frame-chat .messenger .chat-controls {
  background: #dcf4ca;
  color: #2c5111;
}
.search-bind .frame-chat .messenger .chat-controls {
  order: 3;
}
.frame-chat .messenger .chat-controls .chatter {
  display: flex;
  align-items: center;
  height: 100%;
}
.frame-chat .messenger .chat-controls .chatter .chatter-avatar {
  margin-right: 15px;
  display: none;
}
.show-chat-avatar .frame-chat .messenger .chat-controls .chatter .chatter-avatar {
  display: flex;
}
.frame-chat .messenger .chat-controls .chatter .chatter-avatar img {
  width: 35px;
  height: 30px;
  object-fit: contain;
}
.frame-chat .messenger .chat-controls .chatter .chatter-name {
  font-weight: 600;
  font-size: 16px;
  flex: 1;
}
.frame-chat .messenger .chat-controls .chatter .new-chat {
  padding: 8px 15px;
  font-size: 12px;
  cursor: pointer;
  margin-right: 10px;
  background-color: rgba(0, 0, 0, 0.2);
  border-radius: 30px;
}
.frame-chat .messenger form {
  display: flex;
  flex-wrap: wrap;
  position: relative;
  z-index: 3;
  pointer-events: all;
}
.search-bind .frame-chat .messenger form {
  order: 1;
}
@media (max-width: 1023px) {
  .search-bind .frame-chat .messenger form {
    order: 1;
  }
}
.frame-chat .messenger form input[type=text] {
  border: 0;
  margin: 0;
  padding: 10px 15px;
  border-radius: 30px;
}
.frame-chat .messenger form .message-row {
  display: flex;
  width: 100%;
}
.frame-chat .messenger form .message-row .message-box {
  flex: 1;
  position: relative;
}
.frame-chat .messenger form .message-row .message-box .icon {
  position: absolute;
  height: 100%;
  width: 55px;
  left: 0;
  top: 0;
  z-index: 3;
  pointer-events: none;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  opacity: 0;
}
.frame-chat .messenger form .message-row .message-box textarea {
  width: 100%;
  height: 100%;
  padding-right: 60px;
}
.frame-chat .messenger form .message-row .message-box .chat-actions {
  position: absolute;
  right: 0;
  z-index: 3;
  height: 100%;
  display: flex;
  padding: 0 10px;
  gap: 10px;
}
.frame-chat .messenger form .message-row .message-box .chat-action {
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.frame-chat .messenger form .message-row .message-box .chat-action i {
  font-size: 20px;
}
.frame-chat .messenger form .tools {
  min-width: 100%;
  flex: 1;
  padding: 10px 10px;
  white-space: nowrap;
  align-items: center;
}
.frame-chat .messenger form .tools input[type=text] {
  width: 150px;
  margin-right: 10px;
}
.frame-chat .messenger form .tools .avatars {
  width: 100%;
  display: flex;
  margin-left: 10px;
}
.frame-chat .messenger form .tools .avatars ul {
  display: flex;
  overflow: auto;
  padding: 0;
  gap: 15px;
  list-style-type: none;
  margin: 0;
  display: flex;
  padding-right: 20px;
}
.frame-chat .messenger form .tools .avatars ul li {
  margin: 0;
  padding: 0px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  transition: all 300ms ease;
  padding: 2px;
}
.frame-chat .messenger form .tools .avatars ul li img {
  height: 30px;
  width: 30px;
  object-fit: contain;
  object-position: center;
}
.frame-chat .messenger form .tools .avatars ul li:hover {
  box-shadow: inset 0px 0px 0px 2px rgba(255, 255, 0, 0.6);
}
.frame-chat .messenger form .tools .avatars ul li.active {
  box-shadow: inset 0px 0px 0px 2px yellow;
}
.frame-chat .messenger form textarea {
  flex: 1;
  padding: 20px;
  border: 0;
  border-radius: 0;
}
.frame-chat .messenger form button {
  padding: 10px 20px;
  flex: 1;
  max-width: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  border: 0;
  border-radius: 0;
  color: #ffffff;
  background-color: #62b622;
  cursor: pointer;
}
.frame-chat .messenger .messages {
  overflow: auto;
  display: flex;
  width: 100%;
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.search-bind .frame-chat .messenger .messages {
  order: 2;
}
@media (max-width: 1023px) {
  .search-bind .frame-chat .messenger .messages {
    justify-content: flex-end;
  }
}
.frame-chat .messenger .messages .messages-list {
  display: flex;
  flex-direction: column;
  width: 100%;
  max-height: 100%;
}
.frame-chat .messenger .messages .list {
  width: 100%;
  position: relative;
  max-height: 500px;
  min-height: 60px;
}
.frame-chat .messenger .messages .list:after {
  content: "";
  height: 60px;
  display: flex;
  width: 100%;
}
.frame-chat .messenger .messages .list > div {
  display: flex;
  flex-direction: column;
}
.frame-chat .messenger .messages .list > div:last-child:after {
  content: "";
}
.frame-chat .messenger .messages .list .message-row {
  padding: 0px 0;
}
.frame-chat .messenger .messages .list .message-row .message:first-child {
  padding-top: 10px;
}
.frame-chat .messenger .messages .list .message-row .message:last-child {
  padding-bottom: 10px;
}
.frame-chat .messenger .messages .list .message-row.inbound {
  min-height: 65px;
}
.frame-chat .messenger .messages .list .message {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  position: relative;
}
.frame-chat .messenger .messages .list .message .message-section {
  width: 100%;
  position: relative;
  display: flex;
}
.frame-chat .messenger .messages .list .message .message-section.no-bottom:before {
  content: "";
  width: 10px;
  height: 10px;
  position: absolute;
  left: calc(65% + 50px);
  bottom: 0;
  border-bottom-left-radius: 10px;
  z-index: 6;
}
.frame-chat .messenger .messages .list .message .message-section.no-bottom:after {
  content: "";
  width: 10px;
  height: 10px;
  position: absolute;
  left: calc(65% + 50px);
  bottom: 0;
  z-index: 5;
}
.frame-chat .messenger .messages .list .message .message-section.no-bottom .message-body {
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  align-items: flex-end;
  display: flex;
}
.frame-chat .messenger .messages .list .message .message-section.no-bottom .groove {
  position: absolute;
  bottom: 0;
  left: 0;
}
.frame-chat .messenger .messages .list .message .message-section.no-bottom .groove:before {
  content: "";
  width: 10px;
  height: 10px;
  position: absolute;
  left: 30px;
  bottom: 0;
  border-bottom-right-radius: 10px;
  z-index: 6;
  background-color: #eeeeee;
  border-left: 10px solid #eeeeee;
}
.frame-chat .messenger .messages .list .message .message-section.no-bottom .groove:after {
  content: "";
  width: 10px;
  height: 10px;
  position: absolute;
  left: 30px;
  bottom: 0;
  z-index: 5;
  border-left: 10px solid #d7d7d7;
  background-color: #d7d7d7;
}
.frame-chat .messenger .messages .list .message .message-body {
  word-break: break-word;
  padding: 5px 15px;
  border-radius: 10px;
  position: relative;
  line-height: 155%;
  transform: translate3d(0, 0, 0);
  width: 100%;
}
.frame-chat .messenger .messages .list .message .message-body img {
  min-width: 150px;
  max-width: 250px;
  opacity: 0;
  padding: 0px;
  background-color: #fff;
  border-radius: 10px;
  margin-top: 5px;
  max-height: 160px;
  object-fit: contain;
}
.frame-chat .messenger .messages .list .message .message-body img.product-image {
  padding: 10px;
}
.frame-chat .messenger .messages .list .message .message-body ul {
  margin: 0;
  padding: 0;
  list-style-type: none;
}
.frame-chat .messenger .messages .list .message .message-body ul li {
  margin: 0;
  align-items: center;
  display: flex;
}
.frame-chat .messenger .messages .list .message .message-body ul li:before {
  content: "";
  height: 5px;
  width: 5px;
  background-color: currentColor;
  margin-right: 10px;
  border-radius: 100%;
}
.frame-chat .messenger .messages .list .message .avatar {
  display: none;
}
.frame-chat .messenger .messages .list .message .avatar .fade-out {
  display: none !important;
}
.frame-chat .messenger .messages .list .message.inbound .avatar {
  display: none;
}
.show-chat-avatar .frame-chat .messenger .messages .list .message.inbound .avatar {
  display: block;
}
.frame-chat .messenger .messages .list .message.inbound .message-body {
  margin-left: 20px;
  margin-top: 0px;
  position: relative;
  z-index: 2;
}
.show-chat-avatar .frame-chat .messenger .messages .list .message.inbound .message-body {
  margin-left: 50px;
  border-top-left-radius: 5px;
}
.frame-chat .messenger .messages .list .message.inbound .message-body:first-letter {
  text-transform: capitalize;
}
.frame-chat .messenger .messages .list .message.inbound .message-options {
  margin-left: 50px;
}
.frame-chat .messenger .messages .list .message.outbound {
  align-items: flex-end;
  padding: 10px 20px 10px 20px !important;
}
.frame-chat .messenger .messages .list .message.outbound .message-body:before {
  content: "Guest:";
  color: #2c5111;
  font-weight: 800;
  margin-right: 7.5px;
  font-size: 12px;
  text-transform: uppercase;
}
.frame-chat .messenger .messages .list .message .message-options {
  display: flex;
  flex-wrap: wrap;
  max-width: 270px;
  width: 60%;
  margin: 0 15px;
  animation: fade-in 400ms forwards;
  opacity: 0;
  animation-delay: 200ms;
  gap: 7.5px;
}
.frame-chat .messenger .messages .list .message .message-options a {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  text-transform: capitalize;
  padding: 5px 10px;
  border-radius: 15px;
  text-align: center;
  width: 100%;
  background-color: inherit;
  color: inherit;
  border-color: #111;
  border-width: 2px;
}
.frame-chat .messenger .messages .list .message .message-options a.active {
  animation: expand-bounce2 400ms;
}
.frame-chat .messenger .messages .list .message .message-options a .total {
  padding: 3px 5px;
  height: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 30px;
  background-color: rgba(130, 130, 130, 0.3803921569);
  border-radius: 50px;
  font-size: 10px;
  font-weight: 600;
  color: #000;
  position: absolute;
  right: 5px;
  order: 1;
}
.frame-chat .messenger .messages .list .message .message-options.collapse-links {
  max-width: 90%;
  width: 90%;
  margin-left: 5px;
  padding: 10px 15px;
  margin-bottom: 20px;
}
.show-chat-avatar .frame-chat .messenger .messages .list .message .message-options.collapse-links {
  margin-left: 35px;
}
.frame-chat .messenger .messages .list .message .message-options.collapse-links a {
  width: auto;
}
.frame-chat .messenger .messages .list .message .message-options.collapse-links a .total {
  position: relative;
  right: -5px;
  left: auto;
  margin-left: 10px;
}
.frame-chat .messenger .messages .list .message .message-options.grid {
  margin: 0 0px;
  border: 0;
  flex-wrap: nowrap;
  overflow: auto;
  width: 100%;
  min-width: 100%;
  max-width: 100%;
  padding: 0 15px 0 15px;
  padding-left: 30px;
  border-bottom-left-radius: 10px;
  gap: 0px;
}
.frame-chat .messenger .messages .list .message .message-options.grid a {
  width: 35%;
  min-width: 200px;
  margin: 0;
  border-radius: 0;
  border: 0;
  border-radius: 0;
  position: relative;
  margin-bottom: 0px;
  display: flex;
  flex-direction: column;
  padding: 0;
  border-left: 0;
  overflow: hidden;
  padding-right: 1px;
  margin-bottom: 10px;
}
.frame-chat .messenger .messages .list .message .message-options.grid a:first-child {
  border-top-left-radius: 10px;
  border-bottom-left-radius: 10px;
}
.frame-chat .messenger .messages .list .message .message-options.grid a:first-child img {
  border-top-left-radius: 10px;
}
.frame-chat .messenger .messages .list .message .message-options.grid a:first-child .meta {
  border-bottom-left-radius: 10px;
}
.frame-chat .messenger .messages .list .message .message-options.grid a:last-child {
  border-top-right-radius: 10px;
  border-bottom-right-radius: 10px;
}
.frame-chat .messenger .messages .list .message .message-options.grid a:last-child img {
  border-top-right-radius: 10px;
}
.frame-chat .messenger .messages .list .message .message-options.grid a:last-child .meta {
  border-bottom-right-radius: 10px;
}
.frame-chat .messenger .messages .list .message .message-options.grid a .meta {
  position: relative;
  left: 0;
  order: 2;
  width: 100%;
  z-index: 2;
  padding: 2px 5px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 1;
  flex-direction: column;
  line-height: normal;
}
.frame-chat .messenger .messages .list .message .message-options.grid a .meta .title {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}
.frame-chat .messenger .messages .list .message .message-options.grid a img {
  order: 1;
  width: 100%;
  height: 150px;
  position: relative;
  top: 0;
  left: 0;
  object-fit: contain;
  object-position: center;
  padding: 15px;
  z-index: 1;
  opacity: 0;
}
.live-chat-fixed .live-chat-closer {
  display: none !important;
}
.live-chat-fixed .frame-chat .messenger .chat-controls {
  padding-right: 0;
}

.frame-chat.gray {
  background-color: #333;
}
.frame-chat.gray .is-typing-container {
  color: #777;
}
.frame-chat.gray .messenger {
  color: #292929;
  background-color: #eee;
  box-shadow: 0px 0px 0px 1px #000;
}
.frame-chat.gray .messenger form {
  border-top: 1px solid #ccc;
  background-color: #ddd;
}
.frame-chat.gray .messenger .messages .list .is-typing-container {
  color: #222;
}
.frame-chat.gray .messenger .messages .list .spacer {
  background-color: #2d610555;
}
.frame-chat.gray .messenger .messages .list .message-row.inbound {
  color: #222;
}
.frame-chat.gray .messenger .messages .list .message-row.outbound .message-body {
  color: #fff;
  background-color: #3855b7;
}
.frame-chat.gray .messenger .messages .list .message {
  /*&.inbound {
      color:$inboundMessageBodyColor;
      background-color: $inboundMessageBodyBackgroundColor;
      .message-body {
      };
  }
  &.outbound {
      color:$outboundMessageBodyColor;
      background-color: $outboundMessageBodyBackgroundColor;
      .message-body {
      };
  }*/
}
.frame-chat.gray .messenger .messages .list .message .message-section.no-bottom:before {
  background-color: #eee;
  border-left: 10px solid #eee;
}
.frame-chat.gray .messenger .messages .list .message .message-section.no-bottom:after {
  border-left: 10px solid #272727;
  background-color: #eee;
}
.frame-chat.gray .messenger .messages .list .message .message-options a {
  border: 1.5px solid rgba(0, 0, 0, 0.3);
  padding: 2px 10px;
  font-weight: 500;
}
.frame-chat.gray .messenger .messages .list .message .message-options a.active {
  background-color: rgba(3, 117, 190, 0.6509803922);
  border-color: rgba(83, 162, 213, 0.3803921569);
}
.frame-chat.gray .messenger .messages .list .message .message-options.grid a {
  border: 7.5px solid #2d610555;
  background-color: #272727;
  border-left-width: 0px;
  border-color: transparent;
  padding: 0px;
}
.frame-chat.gray .messenger .messages .list .message .message-options.grid a:first-child {
  border-left: 7.5px solid #2d610555;
  border-color: transparent;
}
.frame-chat.gray .messenger .messages .list .message .message-options.grid a:last-child {
  border-right: 7.5px solid #2d610555;
  border-color: transparent;
}
.frame-chat.gray .messenger .messages .list .message .message-options.grid a .meta {
  background-color: #fff;
  border-bottom-right-radius: 10px;
  border-bottom-left-radius: 10px;
}
.frame-chat.gray .messenger .messages .list .message .message-options.grid a .meta .title {
  color: #5b5b5b;
}
.frame-chat.gray .messenger .messages .list .message .message-options.grid a img {
  background-color: #fff;
  border-top-right-radius: 10px;
  border-top-left-radius: 10px;
}

@keyframes fade-in {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.fade-in {
  animation: fade-in 200ms forwards;
}

.frame-chat .messenger {
  height: 100%;
  overflow: hidden;
  font-family: "montserrat";
  font-weight: 400;
}
.frame-chat .messenger input, .frame-chat .messenger textarea, .frame-chat .messenger select {
  font-family: "montserrat";
  font-weight: 400;
}
.frame-chat .messenger .messages {
  overflow: hidden;
}
.frame-chat .messenger .messages .messages-list {
  height: 100%;
  overflow: hidden;
  align-items: flex-end;
  justify-content: flex-end;
}
.frame-chat .messenger .messages .messages-list .list {
  max-height: 100%;
  align-items: flex-end;
  flex-direction: column;
  overflow: auto;
}
.frame-chat .messenger .messages .messages-list .list > div {
  display: inline-flex;
  width: 100%;
}
.frame-chat .messenger .messages .messages-list .list > div.spacer {
  display: none;
}
.frame-chat .messenger .messages .messages-list .list .is-typing-container {
  position: relative;
}
.frame-chat .messenger .messages .messages-list .list .message-row {
  gap: 5px;
}
.frame-chat .messenger .messages .messages-list .list .message .message-body {
  max-width: 65%;
  user-select: text;
  width: auto;
  background-color: #272727;
  color: #fff;
}
.frame-chat .messenger .messages .messages-list .list .message.outbound {
  align-items: flex-end;
  justify-content: flex-end;
  width: 100%;
}
.frame-chat .messenger .messages .messages-list .list .message.outbound .message-section {
  justify-content: flex-end;
}
.frame-chat .messenger .messages .messages-list .list .message.outbound .message-section .message-body:before {
  content: "";
  display: none;
}
.frame-chat .messenger .messages .messages-list .list .message:last-child {
  padding-bottom: 0px;
}
.frame-chat .messenger .messages .messages-list .list:after {
  height: 20px;
}
.frame-chat .messenger .messages .messages-list .chatting-with {
  display: none;
}

/*# sourceMappingURL=client.css.map */
