@charset "UTF-8";

/* VARS
 * =================================
 */
/* MIXINS
* =================================
*/
/* GENERAL
* =================================
*/
:root {
  --primary-color: #2d9bf3;
  --secondary-color: #29abe2;
}

* {
  position: relative;
  box-sizing: border-box;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  font-family: 'Roboto', helvetica, arial, sans-serif;
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
  font-smoothing: antialiased;
}

.noscroll {
  overflow: hidden;
}

html {
  height: 100vh;
}

.hide {
  position: absolute;
}

.hidden {
  display: none !important;
}

.sms-error-msg {
  margin-top: -35px !important;
  margin-left: 30px !important;
  font-size: 12px;
  color: red;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  /* font-family: 'Montserrat', helvetica, sans-serif;  */
  font-family: 'Quicksand', sans-serif;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;

}

h1 span,
h2 span,
h3 span,
h4 span,
h5 span,
h6 span {
  font: inherit;
}

h1 {
  color: white;
}

h1.dark {
  color: black;
}

h2 {
  font-weight: 500;
  font-size: 21px;
}

h3 {
  color: var(--primary-color);
  font-size: 17px;
}

h4 {
  font-weight: 500;
}

h6 {
  color: var(--primary-color);
}

a {
  text-decoration: none;
  color: #0098ff;
  cursor: pointer;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-tap-highlight-color: transparent;
}

p,
li {
  font-weight: 100;
  font-size: 14px;
  line-height: 1.6em;
}

p.sm,
li.sm {
  font-size: 14px;
  line-height: 1.3em;
}

p.description,
li.description {
  font-size: 14px;
  color: slategrey;
}

input,
textarea {
  font-weight: 100;
  font-size: 16px;
  line-height: 1.6em;
  resize: none;
}

input[type="image"],
textarea[type="image"] {
  width: auto;
  margin: 0 auto;
}

::-webkit-calendar-picker-indicator,
::-webkit-inner-spin-button {
  -webkit-appearance: none;
  display: none;
}

ul {
  list-style: none;
  padding: 0;
  margin: 10px 0 30px;
}

button {
  cursor: pointer;
  background: rgba(45, 155, 243, 1);
  color: white;
  line-height: 1;
  padding: 0 30px;
  height: 30px;
  border-radius: 25px;
  font-size: 14px;
  font-weight: 400;
  font-family: 'Montserrat', helvetica, sans-serif;
  border: none;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-tap-highlight-color: transparent;
  background: linear-gradient(
      90deg,
      rgba(1, 153, 252, 1) 0%,
      rgba(0, 195, 253, 1) 100%
    )
}

button.load-button, button.load-treatment {
  background: transparent;
  box-shadow: inset 0 0 0 1px #46a4fb;
  z-index: 0;
  -webkit-transition: all 3s cubic-bezier(0.49, 0.01, 0.22, 1);
  -moz-transition: all 3s cubic-bezier(0.49, 0.01, 0.22, 1);
  -o-transition: all 3s cubic-bezier(0.49, 0.01, 0.22, 1);
  -ms-transition: all 3s cubic-bezier(0.49, 0.01, 0.22, 1);
  transition: all 3s cubic-bezier(0.49, 0.01, 0.22, 1);
  color: #46a4fb;
  -webkit-user-select: none !important;
  -moz-user-select: none !important;
  -ms-user-select: none !important;
  user-select: none !important;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-tap-highlight-color: transparent;
}

button.load-button:before, button.load-treatment:before {
  content: attr(data);
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  background: #46a4fb;
  background: -moz-linear-gradient(to right, #6DC8FC 0%, #0098FF 100%);
  background: -webkit-linear-gradient(to right, #6DC8FC 0%, #0098FF 100%);
  background: linear-gradient(to right, #6DC8FC 0%, #0098FF 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='$color1', endColorstr='$color2', GradientType=1);
  -webkit-transition: inherit;
  -moz-transition: inherit;
  -o-transition: inherit;
  -ms-transition: inherit;
  transition: inherit;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  border-radius: 25px;
  -webkit-clip-path: polygon(0 0, 0 0, 0 100%, 0 100%);
  -moz-clip-path: polygon(0 0, 0 0, 0 100%, 0 100%);
  -ms-clip-path: polygon(0 0, 0 0, 0 100%, 0 100%);
  clip-path: polygon(0 0, 0 0, 0 100%, 0 100%);
  color: white;
}

button.load-button.loading:before,
button.load-button.loaded:before,
button.load-treatment.loading:before,
button.load-treatment.loaded:before {
  -webkit-clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
  -moz-clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
  -ms-clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
}

button img {
  margin-left: 10px;
  height: 16px;
}

button a {
  font: inherit;
  color: inherit;
}

button:focus {
  outline: none;
}

form {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}

form.basic {
  margin-top: 30px;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
}

form.basic>span,
form.basic>div>span {
  width: auto;
  margin-bottom: 20px;
  margin-right: 20px;
}

form.basic div.half-row {
  width: 48%;
}

form.basic label:not(.label-bug) {
  -webkit-transform: none;
  -moz-transform: none;
  -ms-transform: none;
  transform: none;
  left: unset;
  position: relative;
  font-size: 14px;
  font-weight: 400;
  color: #0098ff;
  margin-bottom: 6px;
}

form.basic label.focused:not(.label-bug) {
  font-size: 14px;
  color: #0098FF;
}

form.basic input {
  border: none;
  border-radius: 0;
  border-bottom: 1px solid lightgrey;
  padding: 5px 0;
  margin: 0;
  line-height: 1.4em;
}

form.basic input:focus {
  outline: none;
  border-color: #0098FF;
}

form.basic button {
  margin: 10px auto;
}

form.basic button i {
  margin-right: 7px;
}

form>span,
form>div>span {
  display: block;
  width: 100%;
}

form>span.half-col,
form>div>span.half-col {
  width: 46%;
}

form p.error-message {
  color: red;
  margin: -15px 0 15px;
  font-weight: normal;
  font-size: 12px;
}

form label:not(.label-bug):not(.edit-loc-label):not(.package label):not(.info label):not(#setup-club-info-popup label):not(#marketplace-filters-popup label):not(#add-treatment-popup label):not(#add-checkin-popup label):not(#claim-reward-popup label) {
  /* position: absolute; */
  left: 8px;
  -webkit-transform: translateY(32px);
  -moz-transform: translateY(32px);
  -ms-transform: translateY(32px);
  transform: translateY(32px);
  -webkit-transition: all 0.2s ease-in-out;
  -moz-transition: all 0.2s ease-in-out;
  -o-transition: all 0.2s ease-in-out;
  -ms-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
  font-weight: lighter;
  color: grey;
  white-space: nowrap;
}

form label.focused:not(.label-bug):not(.node-label):not(.edit-loc-label):not(.info label):not(#setup-club-info-popup label):not(#marketplace-filters-popup label) {
  -webkit-transform: none !important;
  -moz-transform: none !important;
  -ms-transform: none !important;
  transform: none !important;
  left: 0 !important;
  font-size: 12px;
  font-weight: 400;
}

form label.stay-focused {
  -webkit-transform: none;
  -moz-transform: none;
  -ms-transform: none;
  transform: none;
  left: 0;
  font-size: 12px;
  font-weight: 400;
}

form input {
  width: 100%;
  margin: 20px 0;
  padding: 8px;
  border: 1px solid lightgrey;
  background: none;
  border-radius: 3px;
}

form input:required {
  box-shadow: none;
}

form span.switcher {
  width: 55px;
  height: 30px;
  border-radius: 15px;
  border: 1px solid lightgrey;
  cursor: pointer;
}

form span.switcher input {
  margin: 0;
  width: 100%;
  height: 100%;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
  opacity: 0;
  border-radius: 15px;
  border: none;
  outline: none;
  -webkit-transition: all 0.3s cubic-bezier(0.49, 0.01, 0.22, 1);
  -moz-transition: all 0.3s cubic-bezier(0.49, 0.01, 0.22, 1);
  -o-transition: all 0.3s cubic-bezier(0.49, 0.01, 0.22, 1);
  -ms-transition: all 0.3s cubic-bezier(0.49, 0.01, 0.22, 1);
  transition: all 0.3s cubic-bezier(0.49, 0.01, 0.22, 1);
}

form span.switcher input:checked+label {
  background: #cee9ff;
  box-shadow: none;
}

form span.switcher input:checked+label:before {
  -webkit-transform: translateX(25px);
  -moz-transform: translateX(25px);
  -ms-transform: translateX(25px);
  transform: translateX(25px);
  background: #2d9bf3;
}

form span.switcher label {
  width: 100%;
  height: 100%;
  border-radius: 15px;
  position: absolute;
  top: 0;
  left: 0;
  -webkit-transition: all 0.3s cubic-bezier(0.49, 0.01, 0.22, 1);
  -moz-transition: all 0.3s cubic-bezier(0.49, 0.01, 0.22, 1);
  -o-transition: all 0.3s cubic-bezier(0.49, 0.01, 0.22, 1);
  -ms-transition: all 0.3s cubic-bezier(0.49, 0.01, 0.22, 1);
  transition: all 0.3s cubic-bezier(0.49, 0.01, 0.22, 1);
  background: #fcfcfc;
  box-shadow: inset 0 0 20px rgba(0, 0, 0, 0.05);
}

form span.switcher label:before {
  content: '';
  display: inline-block;
  height: 26px;
  width: 26px;
  position: absolute;
  left: 1px !important;
  top: 1px;
  border-radius: 50%;
  background: grey;
  -webkit-transition: inherit;
  -moz-transition: inherit;
  -o-transition: inherit;
  -ms-transition: inherit;
  transition: inherit;
}

form textarea:required {
  box-shadow: none;
}

form button {
  margin: 10px auto;
}

form span.dob-wrapper {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 5px 0;
}

form span.dob-wrapper label {
  top: -3px;
  font-size: 12px;
  font-weight: 400;
  left: 0;
  -webkit-transform: none;
  -moz-transform: none;
  -ms-transform: none;
  transform: none;
}

form span.dob-wrapper select {
  width: 30%;
}

form span.form-buttons {
  display: none;
  margin-top: 25px;
}

form span.form-buttons button {
  width: 50%;
  margin: 0;
  -webkit-justify-content: center;
  justify-content: center;
}

form span.form-buttons button.cancel-button {
  margin-right: 30px;
  background: slategrey !important;
}

form span.form-buttons button.cancel-button:before {
  display: none;
}

form span.form-buttons button.save-button {
  background: #46a4fb !important;
}

form span.form-buttons button.save-button:before {
  display: none;
}

select {
  margin: 16px 0;
  /* width: 100%; */
  height: 40px;
  font-size: 16px;
  font-weight: 100;
  border: 1px solid lightgrey;
  border-radius: 0;
  background: white;
}

table {
  width: 100%;
}

body {
  margin: 0;
}

body.noscroll-promo {
  position: fixed;
  width: 100%;
  height: 100%;
}

body .app-container {
  position: relative;
  z-index: 1;
  margin: 0 auto;
  max-width: 500px;
  min-height: 100vh;
  background-color: #f9f9f9;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
}

body .app-container:before {
  content: '';
  position: fixed;
  top: 50%;
  left: 50%;
  width: 120vw;
  height: 120vh;
  -webkit-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  -webkit-filter: blur(5px);
  -moz-filter: blur(5px);
  -o-filter: blur(5px);
  filter: blur(5px);
  background: inherit;
  background-color: #ddd;
  background-blend-mode: overlay;
  z-index: -2;
}

body .app-container:after {
  content: '';
  position: fixed;
  top: 0;
  left: 50%;
  width: 100%;
  max-width: 500px;
  height: 100vh;
  -webkit-transform: translateX(-50%);
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%);
  background: inherit;
  background-color: #333;
  background-blend-mode: overlay;
  z-index: -1;
}

body .mobile-menu-container {
  z-index: 97;
  position: fixed;
  bottom: 0;
  max-width: 500px;
  width: 100%;
  height: 65px;
  border: 1px solid #e4e4e4;
  border-top: none;
  background-color: white;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%);
  box-shadow: 0 -10px 10px -5px rgba(15, 15, 15, 0.15);
  display: -webkit-flex;
  display: flex;
  -webkit-transition: all 0.3s cubic-bezier(0.49, 0.01, 0.22, 1);
  -moz-transition: all 0.3s cubic-bezier(0.49, 0.01, 0.22, 1);
  -o-transition: all 0.3s cubic-bezier(0.49, 0.01, 0.22, 1);
  -ms-transition: all 0.3s cubic-bezier(0.49, 0.01, 0.22, 1);
  transition: all 0.3s cubic-bezier(0.49, 0.01, 0.22, 1);
}

body .mobile-menu-container.hide {
  -webkit-transform: translate(-50%, 100%);
  -moz-transform: translate(-50%, 100%);
  -ms-transform: translate(-50%, 100%);
  transform: translate(-50%, 100%);
}

body .mobile-menu-container a.menu-link {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  -webkit-justify-content: center;
  justify-content: center;
  width: 25%;
  height: 100%;
}

body .mobile-menu-container a.menu-link:not(:last-child) {
  border-right: 1px solid #e4e4e4;
}

body .mobile-menu-container a.menu-link.active:after {
  content: '';
  position: absolute;
  z-index: -1;
  opacity: .1;
  left: 0;
  top: 0;
  height: 70%;
  width: 100%;
  background: var(--primary-color);
  background: -moz-linear-gradient(top, var(--primary-color) 0%, #eaeaea 100%, var(--primary-color) 100%, #00e9ff 100%);
  background: -webkit-linear-gradient(top, var(--primary-color) 0%, #eaeaea 100%, var(--primary-color) 100%, #00e9ff 100%);
  background: linear-gradient(to bottom, var(--primary-color) 0%, #eaeaea 100%, var(--primary-color) 100%, #00e9ff 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='var(--primary-color)', endColorstr='#00e9ff', GradientType=0);
}

body .mobile-menu-container a.menu-link.active:before {
  content: '';
  position: absolute;
  top: 0;
  width: 100%;
  height: 4px;
  background-color: var(--primary-color);
}

body .mobile-menu-container a.menu-link.active .icon-wrapper img,
body .mobile-menu-container a.menu-link.active .icon-wrapper svg,
body .mobile-menu-container a.menu-link.active .icon-wrapper span {
  opacity: 1;
}

body .mobile-menu-container a.menu-link .icon-wrapper {
  text-align: center;
}

body .mobile-menu-container a.menu-link .icon-wrapper img,
body .mobile-menu-container a.menu-link .icon-wrapper svg,
body .mobile-menu-container a.menu-link .icon-wrapper span {
  opacity: .4;
}

body .mobile-menu-container a.menu-link .icon-wrapper img,
body .mobile-menu-container a.menu-link .icon-wrapper svg {
  height: 22px;
  margin: 5px 0 0;
}

body .mobile-menu-container a.menu-link .icon-wrapper span {
  font-weight: 100;
  font-size: 14px;
  font-weight: 500;
  color: black;
  display: block;
}

body .mobile-menu-container a.menu-link .icon-wrapper span#treasure-notification {
  opacity: 1;
  position: absolute;
  background-color: red;
  height: 8px;
  width: 8px;
  right: 12px;
  top: 2px;
  border-radius: 50%;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
}

body .mobile-menu-container a.menu-link .icon-wrapper span#treasure-notification:before {
  white-space: nowrap;
  text-align: center;
  background: rgba(0, 0, 0, 0.7);
  color: white;
  padding: 5px 10px;
  line-height: 1;
  border-radius: 5px;
  top: -25px;
  position: absolute;
  font-size: 12px;
  z-index: 10;
}

body .card {
  padding: 16px;
  background-color: white;
  border-radius: 20px;
  margin: 0 16px 30px;
}

body .card.hide {
  display: none !important;
}

body .card h2 {
  margin: 10px 0 20px;
}

body .card .half-row {
  width: 48%;
}

body .card-container {
  background-color: #f9f9f9;
  border-radius: 10px;
  padding: 16px;
  padding-bottom: 32px;
  margin-bottom: 20px;
  min-height: calc(100vh - 200px);
  border: none;
}

body .card-container.offset {
  border-radius: 0;
  border-top: 10px solid #dfb255;
  margin-top: 140px;
  min-height: calc(100vh - 255px);
}

body .card-container.offset .card.upshift {
  margin-top: -100px;
}

body .card-container:last-child {
  margin-bottom: 0;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}

body .card-container .card {
  margin-left: 0;
  margin-right: 0;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
}

body .card-container .card:last-child {
  margin-bottom: 0;
}

body p.offline-message {
  position: absolute;
  width: 100%;
  color: white;
  text-align: center;
  font-size: 13px;
  font-weight: 600;
  margin: 0;
  top: -60px;
  background: rgba(255, 0, 0, 0.8);
  padding: 5px;
  /* border-radius: 5px;  */
}

body p.offline-message i {
  margin-right: 5px;
  font-size: 16px;
}


@media all and (min-width: 500px) {
  body p.offline-message br {
    /* display: none;  */
  }
}

body .page-intro {
  text-align: center;
  font-size: 25px;
}

body .page-intro h1 {
  margin-bottom: 10px;
}

body .page-intro h4 {
  color: white;
}

@keyframes shine {
  0% {
    background-size: 200% auto;
  }

  66%,
  100% {
    background-position: 200% center;
  }
}

body #referral-container {
  z-index: 98;
  position: fixed;
  bottom: 0;
  width: 100%;
  height: 100vh;
  max-width: 500px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%);
  -webkit-transition: all 0.6s cubic-bezier(0.49, 0.01, 0.22, 1);
  -moz-transition: all 0.6s cubic-bezier(0.49, 0.01, 0.22, 1);
  -o-transition: all 0.6s cubic-bezier(0.49, 0.01, 0.22, 1);
  -ms-transition: all 0.6s cubic-bezier(0.49, 0.01, 0.22, 1);
  transition: all 0.6s cubic-bezier(0.49, 0.01, 0.22, 1);
  pointer-events: none;
  overflow: hidden;
}

body #referral-container * {
  -webkit-transition: inherit;
  -moz-transition: inherit;
  -o-transition: inherit;
  -ms-transition: inherit;
  transition: inherit;
}

body #referral-container.expand {
  z-index: 100;
  background: rgba(0, 0, 0, 0.5);
  pointer-events: auto;
}

body #referral-container.expand #referral-wrapper {
  opacity: 1;
  -webkit-transform: scale(1);
  -moz-transform: scale(1);
  -ms-transform: scale(1);
  transform: scale(1);
}

body #referral-container #referral-icon {
  position: fixed;
  width: 0;
  height: 0;
  border-radius: 50%;
  left: 50%;
  top: 50%;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  cursor: pointer;
  pointer-events: auto;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

body #referral-container #referral-icon:before {
  content: '';
  position: absolute;
  height: 0;
  width: 0;
  opacity: 1;
  background: rgba(96, 125, 139, 0.5);
  border-radius: 50%;
}

body #referral-container #referral-icon.reveal {
  -webkit-transform: none;
  -moz-transform: none;
  -ms-transform: none;
  transform: none;
}

body #referral-container #referral-icon i {
  color: transparent;
  font-size: 21px;
}

body #referral-container #referral-wrapper {
  position: absolute;
  opacity: 0;
  -webkit-transform: scale(0);
  -moz-transform: scale(0);
  -ms-transform: scale(0);
  transform: scale(0);
  width: 300px;
  padding: 20px;
  background: white;
  border-radius: 5px;
  box-shadow: rgba(255, 255, 255, 0.1) 2px 2px 5px 1px, rgba(0, 0, 0, 0.1) 2px 2px 10px 1px;
  text-align: center;
}

body #referral-container #referral-wrapper h6 {
  margin-bottom: 10px;
}

body #referral-container #referral-wrapper #socials-wrapper {
  margin: 20px 0;
}

body #referral-container #referral-wrapper #socials-wrapper span#referral-url-wrapper {
  display: block;
  margin-bottom: 20px;
  overflow: hidden;
}

body #referral-container #referral-wrapper #socials-wrapper span#referral-url-wrapper.active:before {
  -webkit-transform: none;
  -moz-transform: none;
  -ms-transform: none;
  transform: none;
}

body #referral-container #referral-wrapper #socials-wrapper span#referral-url-wrapper:before {
  content: 'Copied!';
  z-index: 1;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  position: absolute;
  border-radius: 5px;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  -webkit-justify-content: center;
  justify-content: center;
  color: white;
  background: #29abe2;
  -webkit-transition: all 0.4s cubic-bezier(0.49, 0.01, 0.22, 1);
  -moz-transition: all 0.4s cubic-bezier(0.49, 0.01, 0.22, 1);
  -o-transition: all 0.4s cubic-bezier(0.49, 0.01, 0.22, 1);
  -ms-transition: all 0.4s cubic-bezier(0.49, 0.01, 0.22, 1);
  transition: all 0.4s cubic-bezier(0.49, 0.01, 0.22, 1);
  -webkit-transform: translateY(-100%);
  -moz-transform: translateY(-100%);
  -ms-transform: translateY(-100%);
  transform: translateY(-100%);
}

body #referral-container #referral-wrapper #socials-wrapper span#referral-url-wrapper:after {
  content: '\f0c5';
  font-family: 'font awesome\ 5 free';
  position: absolute;
  right: 10px;
  top: 15px;
  color: #2d9bf3;
  pointer-events: none;
}

body #referral-container #referral-wrapper #socials-wrapper span#referral-url-wrapper input {
  width: 100%;
  padding: 10px;
  border: 1px solid lightgrey;
  border-radius: 5px;
  cursor: pointer;
}

body #referral-container #referral-wrapper #socials-wrapper span#referral-url-wrapper input::selection {
  background: #f9f9f9;
}

body #referral-container #referral-wrapper #socials-wrapper a {
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -moz-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  height: 45px;
  width: 45px;
  background: #2d9bf3;
  border-radius: 50%;
  margin: 0 6px;
}

body #referral-container #referral-wrapper #socials-wrapper a i {
  color: white;
  font-size: 21px;
}

body #referral-container #referral-wrapper p {
  font-weight: normal;
  color: grey;
  line-height: 1.6;
}

body #referral-container #referral-wrapper span.close-icon {
  position: absolute;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  height: 20px;
  width: 20px;
  top: 10px;
  right: 10px;
  color: #666;
  border-radius: 50%;
  font-size: 14px;
  cursor: pointer;
  -webkit-transition: none;
  -moz-transition: none;
  -o-transition: none;
  -ms-transition: none;
  transition: none;
}

body #referral-container #referral-wrapper span.close-icon:hover {
  color: #333;
}

body #referral-container #referral-wrapper span.close-icon:before {
  content: '\f00d';
  font-family: 'Font Awesome\ 5 Free';
  font-weight: 900;
}

body #milestone-tracker h2 {
  text-align: center;
}

body #milestone-tracker h4,
body #milestone-tracker p {
  /* color: black; */
  width: 100%;
  text-align: center;
  font-size: 30px;
}

body #milestone-tracker p {
  font-weight: normal;
}

body #milestone-tracker #milestone-header {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}

body #milestone-tracker #milestone-header p {
  margin: 0;
  text-align: right;
  line-height: 1.2;
  font-weight: normal;
  font-size: 13px;
}

body #milestone-tracker #milestone-header p span {
  display: block;
}

body #milestone-tracker #milestone-header p span#next-milestone {
  font-weight: bold;
}

body #milestone-tracker #progress-wrapper {
  /* margin: 20px 0;  */
  margin-bottom: 20px;
  margin-top: 10px;
}

body #milestone-tracker #progress-wrapper #progress-bar-wrapper {
  width: 75%;
  height: 12px;
  border-radius: 6px;
  background: lightgray;
  box-shadow: 0 9px 22px rgba(0, 0, 0, 0.01), 0 6px 10px rgba(0, 0, 0, 0.1);
}

body #milestone-tracker #progress-wrapper #progress-bar-wrapper span#progress-bar {
  display: block;
  width: 0;
  height: 100%;
  background: #29abe2;
  background: -moz-linear-gradient(top, #29abe2 45%, #177da8 75%);
  background: -webkit-linear-gradient(top, #29abe2 45%, #177da8 75%);
  background: linear-gradient(to bottom, #29abe2 45%, #177da8 75%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='$color1', endColorstr='$color2', GradientType=0);
  border-top-left-radius: inherit;
  border-bottom-left-radius: inherit;
  border-radius: inherit;
  -webkit-transition: width 1.2s cubic-bezier(0.49, 0.01, 0.22, 1);
  -moz-transition: width 1.2s cubic-bezier(0.49, 0.01, 0.22, 1);
  -o-transition: width 1.2s cubic-bezier(0.49, 0.01, 0.22, 1);
  -ms-transition: width 1.2s cubic-bezier(0.49, 0.01, 0.22, 1);
  transition: width 1.2s cubic-bezier(0.49, 0.01, 0.22, 1);
}

body #milestone-tracker #progress-wrapper #progress-bar-wrapper span#progress-bar:after {
  position: absolute;
  right: 0;
  height: 200%;
  border-right: 2px solid white;
  top: -50%;
}

body #milestone-tracker #progress-wrapper #progress-bar-wrapper span#progress-bar p {
  white-space: nowrap;
  position: absolute;
  top: 5px;
  right: 0;
  -webkit-transform: translateX(50%);
  -moz-transform: translateX(50%);
  -ms-transform: translateX(50%);
  transform: translateX(50%);
}

body #milestone-tracker #progress-wrapper #progress-bar-wrapper span#progress-bar p span#current-visit-count {
  display: none;
}

body #milestone-tracker #progress-wrapper #progress-bar-wrapper span#progress-bar p span#current-visit-count.hide {
  display: none;
}

body #milestone-tracker #progress-wrapper #progress-visits-wrapper {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}

body #milestone-tracker #progress-wrapper #progress-visits-wrapper p {
  display: none;
  margin: 0;
  margin-top: 5px;
}

body .restaurant-header {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-align-items: flex-start;
  -moz-align-items: flex-start;
  -ms-align-items: flex-start;
  align-items: flex-start;
  width: 100%;
  padding: 16px;
}

body .restaurant-header img {
  height: 100px;
  max-width: 80%;
}

body .restaurant-header a.login-link {
  padding: 10px 24px;
  background: white;
  color: grey;
  border-radius: 5px;
  font-weight: 400;
  font-size: 13px;
  box-shadow: 0 0 10px rgba(100, 100, 100, 0.5);
  font-family: 'Montserrat', helvetica, arial, sans-serif;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-tap-highlight-color: transparent;
}

body .restaurant-header a.login-link:hover {
  background: #f9f9f9;
}

body .restaurant-intro {
  text-align: center;
}

body .restaurant-intro h1 {
  color: white;
  font-size: 40px;
  margin: 0 50px 5px;
  font-weight: 100;
}

body .restaurant-intro a.powered-by {
  color: darkgrey;
  text-decoration: none;
  margin: 0;
  font-weight: 500;
  cursor: default;
  -webkit-touch-callout: none;
  /* iOS Safari */
  -webkit-user-select: none;
  /* Safari */
  -khtml-user-select: none;
  /* Konqueror HTML */
  -moz-user-select: none;
  /* Old versions of Firefox */
  -ms-user-select: none;
  /* Internet Explorer/Edge */
  user-select: none;
}

/* body .restaurant-intro a.powered-by:hover {
        text-decoration: underline; } */
body .popup {
  position: fixed;
  width: 300px;
  background-color: white;
  /* padding: 16px; */
  top: 0;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -60%);
  -moz-transform: translate(-50%, -60%);
  -ms-transform: translate(-50%, -60%);
  transform: translate(-50%, -60%);
  border-radius: 10px;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: all 0.4s cubic-bezier(0.49, 0.01, 0.22, 1);
  -moz-transition: all 0.4s cubic-bezier(0.49, 0.01, 0.22, 1);
  -o-transition: all 0.4s cubic-bezier(0.49, 0.01, 0.22, 1);
  -ms-transition: all 0.4s cubic-bezier(0.49, 0.01, 0.22, 1);
  transition: all 0.4s cubic-bezier(0.49, 0.01, 0.22, 1);
  text-align: center;
  z-index: 100;
  pointer-events: none;
}

body .popup#reward-popup svg {
  width: 60px;
  margin-top: 20px;
  fill: #dfb255;
  /* -webkit-filter: drop-shadow(0 0 5px yellow);
      filter: drop-shadow(0 0 5px yellow);  */
}

body .popup#forgot-password-popup input:focus {
  outline: none;
}

body .popup#forgot-password-popup p.error-message {
  width: 100%;
  margin: 0;
  margin-top: 10px;
}

body .popup#forgot-password-popup p.error-message i {
  margin-left: 3px;
  font-family: 'Font Awesome\ 5 Free';
  font-weight: 900;
}

body .popup#forgot-password-popup button.send-button {
  opacity: .2;
}

body .popup#forgot-password-popup button.send-button.valid {
  opacity: 1;
}

body .popup#referral-popup #referral-wrapper {
  display: block;
  margin: 20px 0 0;
}

body .popup#referral-popup #referral-wrapper input {
  font-size: 13px;
  padding: 6px 10px;
  width: 100%;
  border: none;
}

body .popup#referral-popup #referral-wrapper a {
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -moz-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  height: 25px;
  background: #2d9bf3;
  margin: 15px 5px 5px;
  border-radius: 3px;
  color: white;
  font-family: sans-serif;
  font-weight: normal;
  font-size: 13px;
  white-space: nowrap;
  padding: 0 6px;
  overflow: hidden;
}

body .popup#referral-popup #referral-wrapper a#copy-share-button {
  background: #0098ff;
  color: transparent;
}

body .popup#referral-popup #referral-wrapper a#copy-share-button i {
  color: white;
}

body .popup#referral-popup #referral-wrapper a#copy-share-button.reveal:before {
  -webkit-transform: translateY(-180%);
  -moz-transform: translateY(-180%);
  -ms-transform: translateY(-180%);
  transform: translateY(-180%);
}

body .popup#referral-popup #referral-wrapper a#copy-share-button.reveal:after {
  -webkit-transform: none;
  -moz-transform: none;
  -ms-transform: none;
  transform: none;
}

body .popup#referral-popup #referral-wrapper a#copy-share-button:before,
body .popup#referral-popup #referral-wrapper a#copy-share-button:after {
  position: absolute;
  color: white;
  margin-left: 9px;
  -webkit-transition: all 0.4s cubic-bezier(0.49, 0.01, 0.22, 1);
  -moz-transition: all 0.4s cubic-bezier(0.49, 0.01, 0.22, 1);
  -o-transition: all 0.4s cubic-bezier(0.49, 0.01, 0.22, 1);
  -ms-transition: all 0.4s cubic-bezier(0.49, 0.01, 0.22, 1);
  transition: all 0.4s cubic-bezier(0.49, 0.01, 0.22, 1);
}

body .popup#referral-popup #referral-wrapper a#copy-share-button:before {
  content: 'Copy Link';
}

body .popup#referral-popup #referral-wrapper a#copy-share-button:after {
  content: 'Copied!';
  -webkit-transform: translateY(180%);
  -moz-transform: translateY(180%);
  -ms-transform: translateY(180%);
  transform: translateY(180%);
}

body .popup#referral-popup #referral-wrapper a:hover {
  background: #29abe2;
}

body .popup#referral-popup #referral-wrapper a i {
  margin-right: 5px;
}

body .popup.reveal {
  -webkit-transform: translate(-50%, -70%);
  -moz-transform: translate(-50%, -70%);
  -ms-transform: translate(-50%, -70%);
  transform: translate(-50%, -70%);
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

body .popup.reveal:before {
  content: '';
  position: absolute;
  height: 200vh;
  width: 200vw;
  max-width: 500px;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  /* background: rgba(0, 0, 0, 0.5);  */
}

body .popup:first-child {
  margin-top: 0;
}

body .popup h2 {
  color: black;
}

body .popup h6 {
  margin-bottom: 10px;
}

body .popup p {
  color: lightgrey;
  line-height: 1.4;
  font-weight: normal;
}

body .popup p * {
  color: white;
}

body .popup p span.color {
  font-weight: bold;
}

body .popup p span.date {
  font-weight: bold;
}

body .popup button {
  margin: 0 auto 10px;
}

body .popup span.close-icon {
  position: absolute;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  height: 20px;
  width: 20px;
  top: 10px;
  right: 10px;
  color: lightgrey;
  border: 1px solid lightgrey;
  border-radius: 50%;
  font-size: 10px;
  cursor: pointer;
}

body .popup span.close-icon:hover {
  color: black;
  background: lightgrey;
}

body .popup span.close-icon:before {
  content: '\f00d';
  font-family: 'Font Awesome\ 5 Free';
  font-weight: 900;
}

body .popup span.popup-buttons {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  margin: 30px 0 0;
}

body .popup span.popup-buttons button {
  width: 48%;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  white-space: nowrap;
}

body .popup span.popup-buttons button.cancel-button,
body .popup span.popup-buttons button.close-button {
  background-color: slategrey;
}

body .popup span.popup-buttons button.confirm-button {
  background-color: #46a4fb;
}

body .popup span.popup-buttons button#confirm-cancellation-button {
  color: #ed4a63;
  box-shadow: inset 0 0 0 2px #ed4a63;
  font-weight: 600;
}

body .popup span.popup-buttons button#confirm-cancellation-button:before {
  background: #ed4a63 !important;
  color: white !important;
}

body #tooltips-overlay {
  position: fixed;
  height: 100vh;
  width: 100%;
  max-width: 500px;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%);
  background-color: rgba(0, 0, 0, 0.8);
  z-index: 100;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

body #tooltips-overlay.hide {
  display: none;
}

body #tooltips-overlay.first-timer {
  display: -webkit-flex;
  display: flex;
}

body #tooltips-overlay h1 {
  color: white;
  margin-bottom: 15px;
  line-height: 1.4;
}

body #tooltips-overlay p {
  /* color: white;  */
}

body #tooltips-overlay img {
  width: 100px;
}

body #tooltips-overlay img.rest-logo {
  margin-bottom: 15px;
  max-width: 120px;
}

body #tooltips-overlay img.coin {
  max-width: 100px;
}

body #tooltips-overlay img.screen {
  width: 70%;
}

body #tooltips-overlay svg#treasure-icon {
  max-width: 90px;
  fill: #dfb255;
}

body #tooltips-overlay p#instruction img {
  width: 15px;
  margin: 0 3px;
}

body #tooltips-overlay p#instruction #add-to-homescreen {
  font-weight: bold;
  font-size: 17px;
  display: block;
  margin-top: 5px;
}

@-webkit-keyframes lol {
  0% {
    width: 10px;
    height: 10px;
    opacity: 0;
  }

  25% {
    opacity: 1;
  }

  50%,
  100% {
    height: 60px;
    width: 60px;
    opacity: 0;
  }
}

@-moz-keyframes lol {
  0% {
    width: 10px;
    height: 10px;
    opacity: 0;
  }

  25% {
    opacity: 1;
  }

  50%,
  100% {
    height: 60px;
    width: 60px;
    opacity: 0;
  }
}

@keyframes lol {
  0% {
    width: 10px;
    height: 10px;
    opacity: 0;
  }

  25% {
    opacity: 1;
  }

  50%,
  100% {
    height: 60px;
    width: 60px;
    opacity: 0;
  }
}

body #tooltips-overlay p#instruction span#share-icon:before {
  content: '';
  position: absolute;
  top: 30%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  height: 60px;
  width: 60px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.2);
  -webkit-animation-delay: false;
  -webkit-animation-duration: 2s;
  -webkit-animation-name: lol;
  -webkit-animation-direction: false;
  -webkit-animation-timing-function: cubic-bezier(0.49, 0.01, 0.22, 1);
  -webkit-animation-iteration-count: infinite;
  -moz-animation-delay: false;
  -moz-animation-duration: 2s;
  -moz-animation-name: lol;
  -moz-animation-direction: false;
  -moz-animation-timing-function: cubic-bezier(0.49, 0.01, 0.22, 1);
  -moz-animation-iteration-count: infinite;
  animation-delay: false;
  animation-duration: 2s;
  animation-name: lol;
  animation-direction: false;
  animation-timing-function: cubic-bezier(0.49, 0.01, 0.22, 1);
  animation-iteration-count: infinite;
}

body #tooltips-overlay p#tooltips-close {
  position: fixed;
  /* bottom: 20px; */
  /* bottom: 310px; */
  text-align: center;
  line-height: 1;
  cursor: pointer;
  color: #a0a0a0;
  z-index: 99;
  letter-spacing: 2px;
}

body #tooltips-overlay .slide-controls {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  width: 320px;
  max-width: 320px;
  z-index: 99;
}

body #tooltips-overlay .slide-controls i {
  color: lightgray;
  cursor: pointer;
  font-size: 28px;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  -webkit-justify-content: center;
  justify-content: center;
  margin-left: -10px;
  margin-right: -10px;
}

body #tooltips-overlay .slide-controls i.hide {
  position: relative;
  visibility: hidden;
  pointer-events: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

body #tooltips-overlay .slide-controls i:after {
  content: '';
  height: 25px;
  width: 25px;
  border-radius: 50%;
  /* border: 2px solid white; */
  position: absolute;
  opacity: 0;
  -webkit-transition: all 0.2s cubic-bezier(0.49, 0.01, 0.22, 1);
  -moz-transition: all 0.2s cubic-bezier(0.49, 0.01, 0.22, 1);
  -o-transition: all 0.2s cubic-bezier(0.49, 0.01, 0.22, 1);
  -ms-transition: all 0.2s cubic-bezier(0.49, 0.01, 0.22, 1);
  transition: all 0.2s cubic-bezier(0.49, 0.01, 0.22, 1);
}

body #tooltips-overlay .slide-controls i:hover:after {
  height: 40px;
  width: 40px;
  opacity: 1;
}

body #tooltips-overlay section.tooltips-slide {
  position: absolute;
  text-align: center;
  /* max-width: 250px; */
  max-width: 320px;
  height: 310px;
  visibility: hidden;
  opacity: 0;
  -webkit-transition: all 0.2s ease-in-out;
  -moz-transition: all 0.2s ease-in-out;
  -o-transition: all 0.2s ease-in-out;
  -ms-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
}

body #tooltips-overlay section.tooltips-slide.active {
  visibility: visible;
  opacity: 1;
  background-color: white;
  padding: 40px;
  border-radius: 20px;
}

body #tooltips-overlay section.tooltips-slide.active span#animated-treasure-bar #animated-bar {
  width: 50%;
}

body #tooltips-overlay section.tooltips-slide.flippity.coin-flip-slide #tooltip-redeem-screen {
  max-height: 300px;
}

body #tooltips-overlay section.tooltips-slide.flippity.coin-flip-slide #tooltip-redeem-screen img#redeem-screen {
  opacity: 1;
}

body #tooltips-overlay section.tooltips-slide.flippity.coin-flip-slide #tooltip-redeem-screen #redeem-upper-text,
body #tooltips-overlay section.tooltips-slide.flippity.coin-flip-slide #tooltip-redeem-screen #redeem-lower-text {
  opacity: 1;
  visibility: visible;
}

body #tooltips-overlay section.tooltips-slide.flippity.coin-flip-slide #tooltip-redeem-screen #redeem-lower-text {
  -webkit-transform: translateY(10px);
  -moz-transform: translateY(10px);
  -ms-transform: translateY(10px);
  transform: translateY(10px);
}

body #tooltips-overlay section.tooltips-slide.flippity.coin-flip-slide #tooltip-coin-wrapper {
  -webkit-transform: translateY(-45px) rotateY(180deg);
  -moz-transform: translateY(-45px) rotateY(180deg);
  -ms-transform: translateY(-45px) rotateY(180deg);
  transform: translateY(-45px) rotateY(180deg);
}

body #tooltips-overlay section.tooltips-slide.flippity.coin-flip-slide>h1,
body #tooltips-overlay section.tooltips-slide.flippity.coin-flip-slide>p {
  opacity: 0;
  visibility: hidden;
}

body #tooltips-overlay section.tooltips-slide button {
  /* margin: 0 auto; */
}

body #tooltips-overlay section.tooltips-slide button i {
  margin-left: 8px;
  font-size: 16px;
}

body #tooltips-overlay .coin-flip-slide #tooltip-redeem-screen {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  max-height: 120px;
  -webkit-transition: all 0.5s ease-in-out;
  -moz-transition: all 0.5s ease-in-out;
  -o-transition: all 0.5s ease-in-out;
  -ms-transition: all 0.5s ease-in-out;
  transition: all 0.5s ease-in-out;
}

body #tooltips-overlay .coin-flip-slide #tooltip-redeem-screen img#redeem-screen {
  opacity: 0;
  -webkit-transition: all 0.2s ease-in-out;
  -moz-transition: all 0.2s ease-in-out;
  -o-transition: all 0.2s ease-in-out;
  -ms-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
}

body #tooltips-overlay .coin-flip-slide #tooltip-redeem-screen h1,
body #tooltips-overlay .coin-flip-slide #tooltip-redeem-screen p {
  width: 100%;
}

body #tooltips-overlay .coin-flip-slide #tooltip-redeem-screen #redeem-upper-text,
body #tooltips-overlay .coin-flip-slide #tooltip-redeem-screen #redeem-lower-text {
  position: absolute;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: all 0.5s ease-in-out;
  -moz-transition: all 0.5s ease-in-out;
  -o-transition: all 0.5s ease-in-out;
  -ms-transition: all 0.5s ease-in-out;
  transition: all 0.5s ease-in-out;
}

body #tooltips-overlay .coin-flip-slide #tooltip-redeem-screen #redeem-upper-text {
  bottom: 100%;
}

body #tooltips-overlay .coin-flip-slide #tooltip-redeem-screen #redeem-lower-text {
  top: 100%;
}

body #tooltips-overlay .coin-flip-slide #tooltip-coin-wrapper {
  position: absolute;
  display: inline-block;
  -webkit-transition: all 0.8s cubic-bezier(0.49, 0.01, 0.22, 1);
  -moz-transition: all 0.8s cubic-bezier(0.49, 0.01, 0.22, 1);
  -o-transition: all 0.8s cubic-bezier(0.49, 0.01, 0.22, 1);
  -ms-transition: all 0.8s cubic-bezier(0.49, 0.01, 0.22, 1);
  transition: all 0.8s cubic-bezier(0.49, 0.01, 0.22, 1);
  perspective: 800px;
  -webkit-perspective: 800px;
  transform-style: preserve-3d;
  -webkit-transform-style: preserve-3d;
}

body #tooltips-overlay .coin-flip-slide img.coin {
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  cursor: pointer;
}

body #tooltips-overlay .coin-flip-slide span#coin-backside-wrapper {
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  position: absolute;
  top: 0;
  left: 0;
  -webkit-transform: rotateY(180deg);
  -moz-transform: rotateY(180deg);
  -ms-transform: rotateY(180deg);
  transform: rotateY(180deg);
  height: 100px;
  width: 100px;
}

body #tooltips-overlay .coin-flip-slide span#coin-backside-wrapper img#coin-backside-logo {
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  height: 50px;
  width: auto;
}

body #tooltips-overlay .coin-flip-slide>h1,
body #tooltips-overlay .coin-flip-slide>p {
  -webkit-transition: all 0.2s ease-in-out;
  -moz-transition: all 0.2s ease-in-out;
  -o-transition: all 0.2s ease-in-out;
  -ms-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
}

body #tooltips-overlay span#animated-treasure-bar {
  display: block;
  height: 10px;
  width: 210px;
  margin: 20px 0;
  border-radius: 5px;
  border: 1px solid #6f6f6f;
  overflow: hidden;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%);
}

body #tooltips-overlay span#animated-treasure-bar #animated-bar {
  position: absolute;
  left: 0;
  top: 0;
  width: 0;
  height: 100%;
  background: #29abe2;
  background: -moz-linear-gradient(top, #29abe2 45%, #177da8 75%);
  background: -webkit-linear-gradient(top, #29abe2 45%, #177da8 75%);
  background: linear-gradient(to bottom, #29abe2 45%, #177da8 75%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='$color1', endColorstr='$color2', GradientType=0);
  border-radius: inherit;
  -webkit-transition: all 1s cubic-bezier(0.49, 0.01, 0.22, 1) 0.5s;
  -moz-transition: all 1s cubic-bezier(0.49, 0.01, 0.22, 1) 0.5s;
  -o-transition: all 1s cubic-bezier(0.49, 0.01, 0.22, 1) 0.5s;
  -ms-transition: all 1s cubic-bezier(0.49, 0.01, 0.22, 1) 0.5s;
  transition: all 1s cubic-bezier(0.49, 0.01, 0.22, 1) 0.5s;
}

body #drink-preferences-overlay {
  position: fixed;
  height: 100vh;
  width: 100%;
  max-width: 500px;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%);
  background-color: white;
  z-index: 100;
  text-align: center;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}

body #drink-preferences-overlay.hide {
  display: none;
}

body #drink-preferences-overlay.hide.first-timer {
  display: -webkit-flex;
  display: flex;
}

body #drink-preferences-overlay span.scrollable-wrapper {
  overflow: auto;
  padding: 40px 20px 35px;
}

body #drink-preferences-overlay form {
  width: 100%;
}

body #drink-preferences-overlay #setup-preferences-later {
  display: block;
  font-size: 15px;
  margin-top: 15px;
}

body .token-loader-wrapper {
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  z-index: 200;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  background: rgba(0, 0, 0, 0.5);
}

body .token-loader-wrapper .token-loader {
  position: absolute;
  width: 80px;
  height: 80px;
  -webkit-transition: all 1.4s cubic-bezier(0.5, 0, 0.5, 1), opacity 0s linear;
  -moz-transition: all 1.4s cubic-bezier(0.5, 0, 0.5, 1), opacity 0s linear;
  -o-transition: all 1.4s cubic-bezier(0.5, 0, 0.5, 1), opacity 0s linear;
  -ms-transition: all 1.4s cubic-bezier(0.5, 0, 0.5, 1), opacity 0s linear;
  transition: all 1.4s cubic-bezier(0.5, 0, 0.5, 1), opacity 0s linear;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  pointer-events: none;
  perspective: 800px;
  -webkit-perspective: 800px;
  transform-style: preserve-3d;
  -webkit-transform-style: preserve-3d;
}

body .token-loader-wrapper .token-loader.hide {
  opacity: 0;
}

body .token-loader-wrapper .token-loader.flip {
  -webkit-transform: rotateY(1080deg);
  -moz-transform: rotateY(1080deg);
  -ms-transform: rotateY(1080deg);
  transform: rotateY(1080deg);
}

body .token-loader-wrapper .token-loader img {
  width: 100%;
  height: 100%;
}

body .token-loader-wrapper .token-loader img.tails {
  position: absolute;
  top: 0;
  left: 0;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

body form.drink-options-form.editable .preferences-label-wrapper {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

body form.drink-options-form.editable p#drink-summary {
  display: none;
}

body form.drink-options-form .preferences-label-wrapper {
  display: none;
  margin-bottom: 30px;
  margin-top: -10px;
}

body form.drink-options-form h4 {
  width: 100%;
}

body form.drink-options-form p#drink-summary {
  width: 100%;
  margin: 0;
}

body form.drink-options-form p#drink-summary:empty:before {
  content: 'None';
  color: grey;
}

body form.drink-options-form p#drink-summary span {
  text-transform: capitalize;
  display: inline-block;
}

body form.drink-options-form p#drink-summary span:not(:first-child):before {
  content: '•';
  margin: 0 5px;
}

body form.drink-options-form label.checkbox-label {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  position: relative;
  left: unset;
  color: unset;
  width: 47%;
  height: 60px;
  margin-bottom: 20px;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-transition: none;
  -moz-transition: none;
  -o-transition: none;
  -ms-transition: none;
  transition: none;
  border-radius: 5px;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
}

body form.drink-options-form label.checkbox-label.yes {
  border: 2px solid #2d9bf3;
}

body form.drink-options-form label.checkbox-label input {
  display: none;
  width: unset;
  margin-right: 7px !important;
}

body#signup .app-container,
body#login .app-container {
  margin-bottom: 0;
}

body#signup .disable,
body#login .disable {
  opacity: .4;
  pointer-events: none;
}

body#signup .signup-options,
body#signup .signin-options,
body#signup #login-signup-fork,
body#login .signup-options,
body#login .signin-options,
body#login #login-signup-fork {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: center;
  justify-content: center;
  padding: 16px 0;
}

body#signup .signup-options>a,
body#signup .signin-options>a,
body#signup #login-signup-fork>a,
body#login .signup-options>a,
body#login .signin-options>a,
body#login #login-signup-fork>a {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  width: 80%;
  text-align: center;
  background-color: #2d9bf3;
  color: white;
  padding: 13px;
  border-radius: 40px;
  margin: 0 auto;
  cursor: pointer;
  height: 46px;
  font-weight: 400;
  width: 100%;
  max-width: 300px;
  min-width: 275px;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-tap-highlight-color: transparent;
}

body#signup .signup-options>a:not(:last-child),
body#signup .signin-options>a:not(:last-child),
body#signup #login-signup-fork>a:not(:last-child),
body#login .signup-options>a:not(:last-child),
body#login .signin-options>a:not(:last-child),
body#login #login-signup-fork>a:not(:last-child) {
  margin-bottom: 20px;
}

body#signup .signup-options>a.fb-login-button:empty:before,
body#signup .signin-options>a.fb-login-button:empty:before,
body#signup #login-signup-fork>a.fb-login-button:empty:before,
body#login .signup-options>a.fb-login-button:empty:before,
body#login .signin-options>a.fb-login-button:empty:before,
body#login #login-signup-fork>a.fb-login-button:empty:before {
  content: url("../assets/fb-icon.svg");
  margin-right: 20px;
  height: 25px;
  width: 25px;
}

body#signup .signup-options>a.email-option,
body#signup .signin-options>a.email-option,
body#signup #login-signup-fork>a.email-option,
body#login .signup-options>a.email-option,
body#login .signin-options>a.email-option,
body#login #login-signup-fork>a.email-option {
  background-color: var(--primary-color);
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-tap-highlight-color: transparent;
}

body#signup .signup-options>a i,
body#signup .signin-options>a i,
body#signup #login-signup-fork>a i,
body#login .signup-options>a i,
body#login .signin-options>a i,
body#login #login-signup-fork>a i {
  margin-right: 20px;
  margin-left: -20px;
  font-size: 28px;
}

body#signup .signup-options>a svg,
body#signup .signin-options>a svg,
body#signup #login-signup-fork>a svg,
body#login .signup-options>a svg,
body#login .signin-options>a svg,
body#login #login-signup-fork>a svg {
  display: inline-block;
  height: 28px;
  background: white;
  border-radius: 50%;
  padding: 3px;
  margin-right: 20px;
  margin-left: -20px;
}

body#signup .signup-options p.other-method,
body#signup .signin-options p.other-method,
body#signup #login-signup-fork p.other-method,
body#login .signup-options p.other-method,
body#login .signin-options p.other-method,
body#login #login-signup-fork p.other-method {
  font-weight: normal;
  font-size: 16px;
  margin: 0;
  padding-top: 10px;
  width: 100%;
  text-align: center;
  color: grey;
}

body#signup .signup-options p.other-method a,
body#signup .signin-options p.other-method a,
body#signup #login-signup-fork p.other-method a,
body#login .signup-options p.other-method a,
body#login .signin-options p.other-method a,
body#login #login-signup-fork p.other-method a {
  font-weight: normal;
}

body#signup span#accept-terms-of-service,
body#login span#accept-terms-of-service {
  display: block;
  text-align: center;
}

body#signup span#accept-terms-of-service input[type="checkbox"],
body#login span#accept-terms-of-service input[type="checkbox"] {
  width: unset;
  margin-right: 5px;
}

body#signup .vip-insiders-info,
body#login .vip-insiders-info {
  display: block;
  text-align: center;
  max-width: 400px;
  margin: 0 auto;
}

body#signup .vip-insiders-info:nth-child(2),
body#login .vip-insiders-info:nth-child(2) {
  /* border-top: 1px solid #e4e4e4; */
  margin-top: 16px;
}

body#signup .vip-insiders-info:nth-child(2) h1,
body#login .vip-insiders-info:nth-child(2) h1 {
  margin-top: 30px;
}

body#signup .vip-insiders-info:nth-last-child(2),
body#login .vip-insiders-info:nth-last-child(2) {
  /* border-bottom: 1px solid #e4e4e4; */
  margin-bottom: 16px;
  padding-bottom: 16px;
}

body#signup .vip-insiders-info #custom-sign-up-verbiage,
body#login .vip-insiders-info #custom-sign-up-verbiage {
  margin-top: 30px;
  margin-bottom: 30px;
}

body#signup .vip-insiders-info #custom-sign-up-verbiage>div,
body#signup .vip-insiders-info #custom-sign-up-verbiage>span,
body#login .vip-insiders-info #custom-sign-up-verbiage>div,
body#login .vip-insiders-info #custom-sign-up-verbiage>span {
  font-size: 14px;
  font-weight: 200;
  line-height: 1.6;
}

body#signup .vip-insiders-info #custom-sign-up-verbiage b,
body#login .vip-insiders-info #custom-sign-up-verbiage b {
  font-weight: 400;
}

body#signup .vip-insiders-info h1,
body#login .vip-insiders-info h1 {
  font-family: 'Roboto', helvetica, arial, sans-serif;
  font-size: 24px;
  color: black;
  margin-top: 30px;
  letter-spacing: -.5px;
  font-weight: 400;
  margin-bottom: 5px
}

body#signup .vip-insiders-info img,
body#login .vip-insiders-info img {
  width: 65px;
  margin-bottom: 10px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%);
}

body#signup .vip-insiders-info ul,
body#login .vip-insiders-info ul {
  list-style: unset;
  padding-left: 20px;
}

body#signup .vip-insiders-info h2,
body#login .vip-insiders-info h2 {
  margin: 0;
  font-family: 'Roboto', helvetica, arial, sans-serif;
  font-weight: bold;
}

body#signup .vip-insiders-info h2:before,
body#login .vip-insiders-info h2:before {
  display: inline-block;
  height: 15px;
  width: 15px;
  margin-right: 7px;
  border-radius: 50%;
  background-color: red;
}

body#signup .vip-insiders-info h2 span.best-deal,
body#login .vip-insiders-info h2 span.best-deal {
  display: block;
  font-size: 14px;
  margin-top: 5px;
}

body#signup .vip-insiders-info p,
body#login .vip-insiders-info p {
  font-size: 14px;
}

body#signup .vip-insiders-info p.join,
body#login .vip-insiders-info p.join {
  font-weight: bold;
}

body#signup .vip-insiders-info p span.disclaimer,
body#login .vip-insiders-info p span.disclaimer {
  display: block;
  font-style: italic;
  font-size: 13px;
  margin-top: 5px;
}

body#signup a.go-back,
body#login a.go-back {
  width: 100%;
  text-align: center;
  margin: 10px 0;
}

body#signup #register-container h2,
body#login #register-container h2 {
  text-align: center;
  width: 100%;
}

body#signup #register-container p.login-prompt,
body#login #register-container p.login-prompt {
  width: 100%;
  text-align: center;
}

body#signup #register-container p.login-prompt span,
body#login #register-container p.login-prompt span {
  font-weight: bold;
  color: var(--secondary-color);
  cursor: pointer;
}

body#signup #register-container #register-tabs,
body#login #register-container #register-tabs {
  display: -webkit-flex;
  display: flex;
  margin-bottom: 20px;
}

body#signup #register-container #register-tabs span,
body#login #register-container #register-tabs span {
  width: 50%;
  text-align: center;
  cursor: pointer;
  padding: 10px 0;
  font-size: 21px;
  font-weight: bold;
}

body#signup #register-container #register-tabs span.active,
body#login #register-container #register-tabs span.active {
  border-bottom: 4px solid var(--primary-color);
}

body#signup #register-container .register-form,
body#login #register-container .register-form {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

body#signup #register-container .register-form.active,
body#login #register-container .register-form.active {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

body#signup form#signup-form p#illegal-age,
body#login form#signup-form p#illegal-age {
  margin: 0;
  margin-top: -10px;
}

body#signup form#signin-form>span>a,
body#login form#signin-form>span>a {
  position: absolute;
  right: 0;
  top: 0;
  font-size: 12px;
  color: grey;
}

body#signup form#signin-form>span>a:hover,
body#login form#signin-form>span>a:hover {
  color: lightgrey;
}

body#signup .popup form input:not(.bug-form-input),
body#login .popup form input:not(.bug-form-input) {
  color: white;
  margin: 0;
  text-align: center;
  border: none;
  border-bottom: 1px solid white;
}

body#redirect .app-container {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  background-image: url("../assets/vipbg.jpg");
}

body#redirect #loading-prompt {
  text-align: center;
}

body#redirect #loading-prompt * {
  display: block;
  color: white;
}

body#redirect #loading-prompt i.loading-icon {
  font-size: 40px;
  margin-top: 20px;
}

body#signup-info button#go-back {
  display: block;
  width: 100%;
  text-align: center;
  margin-top: -20px;
  margin-bottom: 30px;
  color: white;
  background: none;
  font-family: 'Roboto', helvetica, arial, sans-serif;
  font-size: 16px;
  height: auto;
}

body#signup-info a.go-back {
  display: block;
  width: 100%;
  text-align: center;
  margin-top: -20px;
  margin-bottom: 30px;
  color: white;
}

body#signup-info span#employee-referral-wrapper,
body#signup-info span#other-referral-wrapper {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  margin: 10px 0 30px;
}

body#signup-info span#employee-referral-wrapper label,
body#signup-info span#other-referral-wrapper label {
  position: relative;
  font-size: 13px;
  margin-right: 8px;
  -webkit-transform: none;
  -moz-transform: none;
  -ms-transform: none;
  transform: none;
  left: 0;
  white-space: unset;
  font-weight: normal;
  line-height: 1.4;
}

body#signup-info span#employee-referral-wrapper input,
body#signup-info span#other-referral-wrapper input {
  width: 100%;
  height: 40px;
  border: 1px solid lightgrey;
  padding: 10px;
  margin: 0;
}

body#signup-info button.continue {
  margin: 10px auto;
}

body#home #milestone-tracker {
  background: transparent;
  margin-top: -10%;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  padding-top: 80px;
  padding-bottom: 5px;
  margin-bottom: 0px;
  min-height: 0;
}

body#home #promotion-container {
  padding-top: 30px;
  padding-bottom: 40px;
}

body#home #promotion-container p#current-date,
body#home #promotion-container p#current-date-es {
  margin-top: 13px;
  text-align: center;
  margin: -10px 0 16px;
  color: grey;
}

body#home #promotion-container p#current-date span,
body#home #promotion-container p#current-date-es span {
  font-size: 14px;
  margin: 0 3px;
}

body#home #promotion-container .promo {
  padding: 0;
  cursor: pointer;
  height: 308px;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-tap-highlight-color: transparent;
}

body#home #promotion-container .promo * {
  -webkit-transition: all 0.4s cubic-bezier(0.49, 0.01, 0.22, 1);
  -moz-transition: all 0.4s cubic-bezier(0.49, 0.01, 0.22, 1);
  -o-transition: all 0.4s cubic-bezier(0.49, 0.01, 0.22, 1);
  -ms-transition: all 0.4s cubic-bezier(0.49, 0.01, 0.22, 1);
  transition: all 0.4s cubic-bezier(0.49, 0.01, 0.22, 1);
}

body#home #promotion-container .promo.reveal {
  cursor: auto;
  z-index: 999;
}

body#home #promotion-container .promo.reveal .promo-wrapper {
  border-radius: 0;
  height: 100vh;
  width: calc(100% - -33px);
  left: -16px;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-tap-highlight-color: transparent;
}

body#home #promotion-container .promo.reveal .promo-header span.close-promo {
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -moz-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  top: 13px;
}

body#home #promotion-container .promo.reveal .promo-image {
  height: 273px;
}

body#home #promotion-container .promo .promo-wrapper {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 20px;
  overflow: hidden;
  background-color: white;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-tap-highlight-color: transparent;
}

body#home #promotion-container .promo .promo-header {
  position: absolute;
  z-index: 2;
  width: 100%;
  height: 108px;
  /* padding: 40px; */
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}

body#home #promotion-container .promo .promo-header:before {
  content: '';
  position: absolute;
  height: 100px;
  width: 100%;
  top: 0;
  left: 0;
  opacity: .7;
  /* background: -moz-linear-gradient(top, black 0%, rgba(0, 0, 0, 0) 100%);
          background: -webkit-linear-gradient(top, black 0%, rgba(0, 0, 0, 0) 100%);
          background: linear-gradient(to bottom, black 0%, rgba(0, 0, 0, 0) 100%);
          filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#000000', endColorstr='#00000000',GradientType=0 );  */
}

body#home #promotion-container .promo .promo-header h2 {
  margin: 0;
  color: white;
  /* text-shadow: 0 0 10px rgba(0, 0, 0, 0.5); */
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -moz-box-flex: 1;
  -moz-flex: 1;
  -ms-flex: 1;
  flex: 1;
}

body#home #promotion-container .promo .promo-header span.close-promo-wrapper {
  height: 35px;
  width: 90%;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-tap-highlight-color: transparent;
  text-align: right;
}

body#home #promotion-container .promo .promo-header span.close-promo {
  display: none;
  width: 35px;
  height: 35px;
  border-radius: 50%;
  background-color: white;
  color: #000;
  cursor: pointer;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.5);
  position: fixed;
  z-index: 99;
}

body#home #promotion-container .promo .promo-header span.close-promo:before {
  content: '\f00d';
  font-family: 'Font Awesome\ 5 Free';
  font-weight: 900;
}

body#home #promotion-container .promo .promo-image {
  width: 100%;
  height: 200px;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-color: lightgrey;
  border-top-left-radius: 20px;
  border-top-right-radius: 20px;
}

div.promo-image>img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

body#home #promotion-container .promo .promo-info {
  padding: 16px;
  transition: all 0s 0s;
}

body#home #promotion-container .promo .promo-info:after {
  content: '';
  position: relative;
  display: block;
  height: 120px;
}

body#home #promotion-container .promo .promo-info span.promo-details {
  display: block;
  margin-bottom: 25px;
  margin-top: 30px;
}

body#home #promotion-container .promo .promo-info span.promo-details p.promo-detail {
  padding-left: 25px;
  margin: 7px 0;
}

body#home #promotion-container .promo .promo-info span.promo-details p.promo-detail:before {
  font-family: 'Font Awesome\ 5 Free';
  position: absolute;
  left: 0;
  text-align: center;
  width: 20px;
  color: lightgray;
}

body#home #promotion-container .promo .promo-info span.promo-details p.promo-detail.promo-location:before {
  content: '\f3c5';
  font-weight: 900;
}

body#home #promotion-container .promo .promo-info span.promo-details p.promo-detail.promo-date:before {
  content: '\f073';
}

body#home #promotion-container .promo .promo-info span.promo-details p.promo-detail.promo-exp-date:before {
  content: '\f273';
}

body#home #promotion-container .promo .promo-info span.promo-details p.promo-detail.promo-time:before {
  content: '\f017';
}

body#home #promotion-container .promo .promo-info span.promo-details p.promo-detail.promo-phone:before {
  content: '\f3cd';
  font-weight: 900;
}

body#home #promotion-container .promo .promo-info span.promo-details p.promo-detail.promo-email:before {
  content: '\f0e0';
}

body#home #promotion-container .promo .promo-info span.promo-details p.promo-detail.promo-link:before {
  content: '\f0c1';
  font-weight: 900;
}

body#home #promotion-container .promo .promo-info span.promo-details p.promo-detail a {
  color: #0098ff;
}

body#home #promotion-container .promo .promo-info span.promo-description {
  display: block;
  margin-bottom: 30px;
  font-weight: 100;
}

body#rewards .page-intro {
  margin-bottom: 30px;
}

body#rewards #milestone-tracker {
  background: rgba(0, 0, 0, 0.65);
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  padding-top: 32px;
  padding-bottom: 52px;
  margin-bottom: 0;
  min-height: 0;
  top: 20px;
}

body#rewards #rewards-container {
  margin-bottom: 0;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  padding-bottom: 95px;
}

body#rewards #rewards-container h2 {
  margin-bottom: 20px;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
}

body#rewards #rewards-container h2 svg {
  height: 20px;
  fill: #dfb255;
  margin-left: 10px;
}

body#rewards #rewards-container .rewards-wrapper {
  padding: 0;
}

body#rewards #rewards-container .rewards-wrapper:last-child {
  margin-bottom: 100px;
}

body#rewards #rewards-container .rewards-wrapper#upcoming-rewards item * {
  -webkit-filter: blur(4px);
  -moz-filter: blur(4px);
  -o-filter: blur(4px);
  filter: blur(4px);
  pointer-events: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

body#rewards #rewards-container .rewards-wrapper#upcoming-rewards item.available * {
  -webkit-filter: none;
  -moz-filter: none;
  -o-filter: none;
  filter: none;
  pointer-events: auto;
  /* -webkit-user-select: auto;
        -moz-user-select: auto;
        -ms-user-select: auto;
        user-select: auto; */
}

body#rewards #rewards-container .rewards-wrapper item {
  padding: 10px 16px;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  border-bottom: 1px solid #e4e4e4;
  /* height: 60px;  */
}

body#rewards #rewards-container .rewards-wrapper item:last-child {
  border: none;
}

body#rewards #rewards-container .rewards-wrapper h4.required-visits {
  color: var(--primary-color);
  font-size: 14px;
  display: none;
}

body#rewards #rewards-container .rewards-wrapper h4.required-visits:after {
  content: ' visits';
}

body#rewards #rewards-container .rewards-wrapper p.reward-item {
  margin: 0;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

body#rewards #rewards-container .rewards-wrapper p.already-claimed {
  margin: 0;
  font-weight: bold;
  color: #22b573;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

body#rewards .popup svg {
  margin-bottom: 25px;
}

body#rewards .popup#reward-popup p {
  display: none;
}

body#rewards .popup#just-claimed-popup h2 {
  color: #dfb255;
}

body#rewards .popup#just-claimed-popup button {
  margin-top: 20px;
}

body#rewards .popup#just-claimed-popup p.show-server-message {
  /* font-weight: normal;
    color: white;
    max-width: 300px;
    margin: 20px auto 20px;
    line-height: 1.2;
    background: white;
    background: -moz-linear-gradient(left, white 0%, #bdc9cc 100%);
    background: -webkit-linear-gradient(left, white 0%, #bdc9cc 100%);
    background: linear-gradient(to right, white 0%, #bdc9cc 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='$color1', endColorstr='$color2',GradientType=1 );
    background-size: 200% auto;
    background-clip: text;
    text-fill-color: transparent;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    -webkit-animation-delay: false;
    -webkit-animation-duration: 3s;
    -webkit-animation-name: shine;
    -webkit-animation-direction: false;
    -webkit-animation-timing-function: ease-in-out;
    -webkit-animation-iteration-count: infinite;
    -moz-animation-delay: false;
    -moz-animation-duration: 3s;
    -moz-animation-name: shine;
    -moz-animation-direction: false;
    -moz-animation-timing-function: ease-in-out;
    -moz-animation-iteration-count: infinite;
    animation-delay: false;
    animation-duration: 3s;
    animation-name: shine;
    animation-direction: false;
    animation-timing-function: ease-in-out;
    animation-iteration-count: infinite;  */
}

@keyframes shine {
  0% {
    background-size: 200% auto;
  }

  66%,
  100% {
    background-position: 200% center;
  }
}

body#benefits .page-intro {
  margin-bottom: 60px;
}

body#settings #settings-container {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  padding: 16px;
  padding-bottom: 80px;
  -webkit-transition: all 1s cubic-bezier(0.49, 0.01, 0.22, 1);
  -moz-transition: all 1s cubic-bezier(0.49, 0.01, 0.22, 1);
  -o-transition: all 1s cubic-bezier(0.49, 0.01, 0.22, 1);
  -ms-transition: all 1s cubic-bezier(0.49, 0.01, 0.22, 1);
  transition: all 1s cubic-bezier(0.49, 0.01, 0.22, 1);
  margin-bottom: 60px;
}

body#settings #settings-container .setting {
  width: 48%;
  border-radius: 5px;
  background-color: white;
  margin-bottom: 16px;
  cursor: pointer;
  padding: 16px;
  text-align: center;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.8);
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-tap-highlight-color: transparent;
}

body#settings #settings-container .setting span.setting-icon-wrapper {
  margin: 0 auto;
  height: 60px;
  width: 60px;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  padding: 18px;
  background-color: var(--primary-color);
  border-radius: 50%;
}

body#settings #settings-container .setting span.setting-icon-wrapper img,
body#settings #settings-container .setting span.setting-icon-wrapper svg {
  height: 100%;
  width: auto;
  fill: white;
}

body#settings #settings-container .setting span.setting-icon-wrapper img.xl,
body#settings #settings-container .setting span.setting-icon-wrapper svg.xl {
  height: 130%;
}

body#settings #settings-container .setting h4 {
  margin: 14px 0;
}

body#settings #settings-container .setting p {
  margin: 0;
  color: grey;
  font-size: 12px;
  line-height: 1.3;
}

body#settings #settings-container .setting form {
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
  opacity: 0;
}

body#settings #settings-container .setting form button {
  margin: 0;
  padding: 0;
  height: 100%;
  width: 100%;
  border-radius: 0;
}

body.setting-page .app-container {
  padding: 0;
  margin: 0 auto;
}

body.setting-page .setting-container {
  min-height: 100vh;
  height: 100%;
  width: 100%;
  padding-bottom: 80px;
  /* background-color: #f9f9f9;  */
  background-color: #ffffff;
  font-family: 'Roboto';
}

body.setting-page .setting-container .page-header {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  width: 100%;
  height: 60px;
  background-color: white;
  border-bottom: #e4e4e4;
  box-shadow: 0 0 10px rgba(15, 15, 15, 0.15);
}

body.setting-page .setting-container .page-header a.back-link {
  position: absolute;
  left: 16px;
  font-size: 18px;
}

body.setting-page .setting-container .page-header a.back-link i {
  margin-right: 5px;
}

body.setting-page .setting-container .page-forms {
  /* margin-top: 40px;  */
}

body.setting-page .setting-container .page-forms h2 {
  padding: 15px;
  margin-top: 7px;
  font-weight: 500;
  font-size: 25px;
  font-weight: 700;
  font-family: 'Montserrat';
}

body.setting-page .setting-container .page-forms>p {
  padding: 0 16px;
  margin-top: 0;
}

body.setting-page .setting-container .page-forms form {
  background-color: white;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  padding: 10px 16px;
  border-top: 1px solid #ececec;
}

body.setting-page .setting-container .page-forms form:last-child {
  /* border-bottom: 1px solid #e4e4e4;  */
}

body.setting-page .setting-container .page-forms form.editable span.form-info {
  padding: 0;
}

body.setting-page .setting-container .page-forms form.editable span.form-info input:focus {
  outline: none;
  border-bottom: 1px solid black;
}

body.setting-page .setting-container .page-forms form.editable img.edit-icon {
  display: none;
}

body.setting-page .setting-container .page-forms form.editable span.edit-buttons {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}

body.setting-page .setting-container .page-forms form span.form-info {
  width: unset;
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -moz-box-flex: 1;
  -moz-flex: 1;
  -ms-flex: 1;
  flex: 1;
  padding-right: 16px;
}

body.setting-page .setting-container .page-forms form span.form-info h4 {
  margin-bottom: 5px;
  text-transform: uppercase;
  font-family: "Montserrat", helvetica, arial, sans-serif;
  font-weight: 600;
  font-size: 11px;
  letter-spacing: .5px;
  color: #b1b1b1;
}

body.setting-page .setting-container .page-forms form span.form-info input {
  margin: 0;
  border: none;
  padding: 0;
  font-family: 'Montserrat' !important;
}

body.setting-page .setting-container .page-forms form img.edit-icon {
  height: 20px;
  cursor: pointer;
}

body.setting-page .setting-container .page-forms form span.edit-buttons {
  display: none;
  margin-top: 10px;
}

body.setting-page .setting-container .page-forms form span.edit-buttons button {
  width: 45%;
  -webkit-justify-content: center;
  justify-content: center;
}

body.setting-page .setting-container .page-forms form span.edit-buttons button.cancel-button {
  background: slategrey;
}

body.setting-page .setting-container .page-forms form span.edit-buttons button.save-button {
  background: #46a4fb;
}

body.setting-page .setting-container .page-forms form p#emailAlreadyExists {
  margin: 0;
}

body.setting-page .setting-container .page-forms a {
  background: white;
  display: block;
  padding: 20px 16px;
  border-top: 1px solid #e4e4e4;
}

body.setting-page .setting-container .page-forms a:last-child {
  border-bottom: 1px solid #e4e4e4;
}

body.setting-page .setting-container .page-forms a#delete-account-link {
  color: red;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}

body.setting-page .setting-container .history-container {
  background-color: white;
  margin-bottom: 40px;
}

body.setting-page .setting-container .history-container item {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: flex-end;
  -moz-align-items: flex-end;
  -ms-align-items: flex-end;
  align-items: flex-end;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  padding: 10px 16px;
  border-bottom: 1px solid #e4e4e4;
}

body.setting-page .setting-container .history-container item:first-child {
  border-top: 1px solid #e4e4e4;
}

body.setting-page .setting-container .history-container item h6.location-name {
  margin-top: 5px;
  color: #444 !important;
  font-weight: 500;
  font-size: 13px;
  font-family: 'Montserrat', helvetica, sans-serif;
}

body.setting-page .setting-container .history-container item p {
  margin: 0;
  font-size: 12px;
  line-height: 1.3em;
  font-family: 'Montserrat', helvetica, sans-serif;
  color: #444
}

body.setting-page .setting-container .history-container item p.location-address {
  margin-top: 5px;
  color: #5a5a5a;
  font-size: 12px;
  font-family: 'Montserrat', helvetica, sans-serif;
}

body.setting-page .setting-container .history-container item span#reward-name {
  width: 100%;
}

body.setting-page .setting-container .history-container item span#reward-name h3 {
  color: #000;
  margin-bottom: 5px;
  font-weight: 400;
}

body.setting-page .setting-container .history-container item span.where {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -moz-box-flex: 1;
  -moz-flex: 1;
  -ms-flex: 1;
  flex: 1;
  padding-right: 20px;
}

body.setting-page .setting-container .history-container item span.when {
  text-align: right;
}

body.setting-page .popup span.popup-buttons button.close-button {
  margin: 0;
  margin-bottom: 10px;
}

body.setting-page .popup span.popup-buttons form {
  width: 48%;
}

body.setting-page .popup span.popup-buttons form button {
  width: 100%;
}

body#home footer .referral-button,
body#rewards footer .referral-button,
body#benefits footer .referral-button,
body#settings footer .referral-button {
  display: block;
}

body#home footer .referral-button>a,
body#rewards footer .referral-button>a,
body#benefits footer .referral-button>a,
body#settings footer .referral-button>a,
.cloned-share.referral-button>a {
  background: #2d9bf3;
  color: white;
  width: 100%;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  padding: 12px 10px;
  top: -40px;
  border-radius: 5px;
  font-weight: 400;
  background: linear-gradient(
      90deg,
      rgba(1, 153, 252, 1) 0%,
      rgba(0, 195, 253, 1) 100%
    )
}

.cloned-share.referral-button>a {
  margin-bottom: 30px;
  top: 0;
  font-size: 13px;
  text-align: center;
}

.referral-button a span{
  font-size: 16px;
}

body#home footer .referral-button>a i,
body#rewards footer .referral-button>a i,
body#benefits footer .referral-button>a i,
body#settings footer .referral-button>a i {
  font-size: 22px;
  margin-right: 10px;
}

body#terms-of-service,
body#privacy-policy {
  background: #f6f6f6;
}

body#terms-of-service .full-page-container,
body#privacy-policy .full-page-container {
  max-width: 1000px;
  background: white;
  min-height: 100vh;
  margin: 0 auto;
  padding: 40px;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.05);
}

body#terms-of-service .full-page-container .page-section,
body#privacy-policy .full-page-container .page-section {
  margin: 40px 0;
}

body#terms-of-service .full-page-container .page-section:first-child,
body#privacy-policy .full-page-container .page-section:first-child {
  margin-top: 0;
}

body#terms-of-service .full-page-container h1,
body#privacy-policy .full-page-container h1 {
  color: #333;
}

body#terms-of-service .full-page-container ul,
body#privacy-policy .full-page-container ul {
  list-style: unset;
  padding-left: 30px;
}

body#terms-of-service .full-page-container a,
body#privacy-policy .full-page-container a {
  word-wrap: break-word;
}

@keyframes scaleUp {

  0%,
  70% {
    -webkit-transform: scale(0);
    -moz-transform: scale(0);
    -ms-transform: scale(0);
    transform: scale(0);
  }

  100% {
    -webkit-transform: none;
    -moz-transform: none;
    -ms-transform: none;
    transform: none;
  }
}

body#admin h1,
body#admin h2,
body#admin h3,
body#admin h4,
body#admin h5,
body#admin h6,
body#admin-edit h1,
body#admin-edit h2,
body#admin-edit h3,
body#admin-edit h4,
body#admin-edit h5,
body#admin-edit h6 {
  font-family: 'Roboto', helvetica, arial, sans-serif;
}

body#admin h2.with-download,
body#admin-edit h2.with-download {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-align-items: flex-end;
  -moz-align-items: flex-end;
  -ms-align-items: flex-end;
  align-items: flex-end;
}

body#admin h2.with-download a,
body#admin-edit h2.with-download a {
  margin-top: 10px;
  font-size: 12px;
  border: 1px solid #46a4fb;
  padding: 5px 10px;
  border-radius: 5px;
}

body#admin h2.with-download a:hover,
body#admin-edit h2.with-download a:hover {
  background: #f4faff;
}

body#admin p,
body#admin-edit p {
  margin: 0;
}

body#admin button,
body#admin-edit button[type='submit'] {
  /* background: #5c7fe3;
      background: -moz-linear-gradient(left, #5c7fe3 0%, #6dc8fc 100%);
      background: -webkit-linear-gradient(left, #5c7fe3 0%, #6dc8fc 100%);
      background: linear-gradient(to right, #5c7fe3 0%, #6dc8fc 100%); */
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='$color1', endColorstr='$color2', GradientType=1);
  overflow: hidden;
  z-index: 1;
  -webkit-transition: all 0.2s ease-in-out;
  -moz-transition: all 0.2s ease-in-out;
  -o-transition: all 0.2s ease-in-out;
  -ms-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
  font-size: 12px;
  padding: 0 20px;
  height: 35px;
  background: #0098ff;
}

body#admin button:before,
body#admin-edit button:before {
  content: '';
  position: absolute;
  height: 100%;
  width: 100%;
  opacity: 0;
  top: 0;
  left: 0;
  z-index: -1;
  background: #6dc8fc;
  background: -moz-linear-gradient(to right, #6DC8FC 0%, #0098FF 100%);
  background: -webkit-linear-gradient(to right, #6DC8FC 0%, #0098FF 100%);
  background: linear-gradient(to right, #6DC8FC 0%, #0098FF 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='$color1', endColorstr='$color2', GradientType=1);
  -webkit-transition: inherit;
  -moz-transition: inherit;
  -o-transition: inherit;
  -ms-transition: inherit;
  transition: inherit;
}

body#admin button:hover,
body#admin-edit button:hover {
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.15);
}

body#admin button:hover:before,
body#admin-edit button:hover:before {
  opacity: 1;
}

body#admin button i,
body#admin-edit button i {
  margin-right: 8px;
}

body#admin table:not(.ui-datepicker-calendar),
body#admin-edit table:not(.ui-datepicker-calendar) {
  margin-top: 20px;
}

#customersTable {
  margin-top: 10px;
}

span#table-explanation {
  background-color: #f0f0f0;
  padding: 10px 20px 10px 35px;
  border-radius: 5px;
  max-width: 80%;
  font-size: 14px;
  margin-right: 25px;
  display: none;
}

.display-inline {
  display: inline-block !important;
}

span#table-explanation::before {
  content: '';
  height: 18px;
  width: 18px;
  background-image: url(/assets/info-icon.svg);
  font-family: 'Font Awesome\ 5 Free';
  font-weight: 900;
  font-size: 16px;
  position: absolute;
  left: 12px;
  top: 9px;
  color: #9b9b9b;
}

div#user-table-loader {
  position: relative;
  right: 0;
  left: 0;
  margin-top: 0;
}

#zero-users-notice {
  text-align: center;
  margin: 20px auto;
  display: block;
  color: grey;
}

body#admin table:not(.ui-datepicker-calendar) tr,
body#admin-edit table:not(.ui-datepicker-calendar) tr {
  text-align: left;
}

body#admin table:not(.ui-datepicker-calendar) tr:hover td.has-delete i,
body#admin-edit table:not(.ui-datepicker-calendar) tr:hover td.has-delete i {
  display: inline-block;
}

body#admin table:not(.ui-datepicker-calendar) tr th,
body#admin table:not(.ui-datepicker-calendar) tr td,
body#admin-edit table:not(.ui-datepicker-calendar) tr th,
body#admin-edit table:not(.ui-datepicker-calendar) tr td {
  font-size: 14px;
  white-space: nowrap;
}

body#admin table:not(.ui-datepicker-calendar) tr.table-header-row.unsortable th:before,
body#admin table:not(.ui-datepicker-calendar) tr.table-header-row.unsortable th:after,
body#admin-edit table:not(.ui-datepicker-calendar) tr.table-header-row.unsortable th:before,
body#admin-edit table:not(.ui-datepicker-calendar) tr.table-header-row.unsortable th:after {
  display: none;
}

body#admin table:not(.ui-datepicker-calendar) tr.table-header-row th,
body#admin-edit table:not(.ui-datepicker-calendar) tr.table-header-row th {
  padding: 20px;
  font-weight: 400;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

body#admin table:not(.ui-datepicker-calendar) tr.table-header-row th.nosort,
body#admin-edit table:not(.ui-datepicker-calendar) tr.table-header-row th.nosort {
  cursor: auto;
}

body#admin table:not(.ui-datepicker-calendar) tr.table-header-row th.nosort:before,
body#admin table:not(.ui-datepicker-calendar) tr.table-header-row th.nosort:after,
body#admin-edit table:not(.ui-datepicker-calendar) tr.table-header-row th.nosort:before,
body#admin-edit table:not(.ui-datepicker-calendar) tr.table-header-row th.nosort:after {
  display: none !important;
}

body#admin table:not(.ui-datepicker-calendar) tr.table-header-row th:before,
body#admin table:not(.ui-datepicker-calendar) tr.table-header-row th:after,
body#admin-edit table:not(.ui-datepicker-calendar) tr.table-header-row th:before,
body#admin-edit table:not(.ui-datepicker-calendar) tr.table-header-row th:after {
  font-family: 'Font Awesome\ 5 Free';
  font-weight: 900;
  font-size: 12px;
  position: absolute;
  color: grey;
}

body#admin table:not(.ui-datepicker-calendar) tr.table-header-row th:before,
body#admin-edit table:not(.ui-datepicker-calendar) tr.table-header-row th:before {
  content: '\f0de';
  right: 0;
}

body#admin table:not(.ui-datepicker-calendar) tr.table-header-row th:after,
body#admin-edit table:not(.ui-datepicker-calendar) tr.table-header-row th:after {
  content: '\f0dd';
  right: 0;
  margin-top: 2px;
}

body#admin table:not(.ui-datepicker-calendar) tr.table-header-row th.ascn,
body#admin-edit table:not(.ui-datepicker-calendar) tr.table-header-row th.ascn {
  color: #0098ff;
}

body#admin table:not(.ui-datepicker-calendar) tr.table-header-row th.ascn:before,
body#admin-edit table:not(.ui-datepicker-calendar) tr.table-header-row th.ascn:before {
  color: inherit;
}

body#admin table:not(.ui-datepicker-calendar) tr.table-header-row th.ascn:after,
body#admin-edit table:not(.ui-datepicker-calendar) tr.table-header-row th.ascn:after {
  color: lightgrey;
}

body#admin table:not(.ui-datepicker-calendar) tr.table-header-row th.desc,
body#admin-edit table:not(.ui-datepicker-calendar) tr.table-header-row th.desc {
  color: #0098ff;
}

body#admin table:not(.ui-datepicker-calendar) tr.table-header-row th.desc:before,
body#admin-edit table:not(.ui-datepicker-calendar) tr.table-header-row th.desc:before {
  color: lightgrey;
}

body#admin table:not(.ui-datepicker-calendar) tr.table-header-row th.desc:after,
body#admin-edit table:not(.ui-datepicker-calendar) tr.table-header-row th.desc:after {
  color: inherit;
}

body#admin table:not(.ui-datepicker-calendar) tr:nth-child(2n),
body#admin-edit table:not(.ui-datepicker-calendar) tr:nth-child(2n) {
  background-color: #f9fafc;
}

body#admin table:not(.table-condensed) tr td,
body#admin-edit table:not(.table-condensed) tr td {
  padding: 13px;
  color: grey;
}

body#admin table:not(.ui-datepicker-calendar) tr td.has-delete,
body#admin-edit table:not(.ui-datepicker-calendar) tr td.has-delete {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
}

body#admin table:not(.ui-datepicker-calendar) tr td.has-delete i,
body#admin-edit table:not(.ui-datepicker-calendar) tr td.has-delete i {
  display: none;
  color: #0098ff;
  cursor: pointer;
}

body#admin table:not(.ui-datepicker-calendar) tr.subtotal-row,
body#admin-edit table:not(.ui-datepicker-calendar) tr.subtotal-row {
  background: lightslategrey;
}

body#admin table:not(.ui-datepicker-calendar) tr.subtotal-row td,
body#admin-edit table:not(.ui-datepicker-calendar) tr.subtotal-row td {
  font-weight: 900;
  color: white;
}

body#admin .ui-datepicker,
body#admin-edit .ui-datepicker {
  display: none;
  background: white;
  padding: 12px;
  border: 1px solid lightgrey;
  text-align: center;
  font-weight: normal;
  font-size: 15px;
  width: 455px;
}

body#admin .ui-datepicker .ui-datepicker-calendar,
body#admin-edit .ui-datepicker .ui-datepicker-calendar {
  padding-top: 10px;
  border-top: 1px solid lightgrey;
}

body#admin .ui-datepicker .ui-datepicker-header,
body#admin-edit .ui-datepicker .ui-datepicker-header {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  margin: 10px 0 20px;
}

body#admin .ui-datepicker .ui-datepicker-header a.ui-datepicker-next,
body#admin-edit .ui-datepicker .ui-datepicker-header a.ui-datepicker-next {
  -webkit-box-ordinal-group: 10;
  -moz-box-ordinal-group: 10;
  -ms-flex-order: 10;
  -webkit-order: 10;
  order: 10;
}

body#admin .ui-datepicker thead th,
body#admin-edit .ui-datepicker thead th {
  font-weight: normal;
}

body#admin .ui-datepicker td,
body#admin-edit .ui-datepicker td {
  padding: 7px;
  border-radius: 50%;
  cursor: pointer;
}

body#admin .ui-datepicker td:hover,
body#admin-edit .ui-datepicker td:hover {
  background: #f9f9f9;
}

body#admin .popup:before,
body#admin-edit .popup:before {
  display: none;
}

body#admin .popup h2,
body#admin-edit .popup h2 {
  font-size: 17px;
  line-height: 1.4;
}

body#admin .popup #location-to-be-deleted,
body#admin-edit .popup #location-to-be-deleted {
  font-weight: bold;
}

body#admin .popup .delete-button,
body#admin-edit .popup .delete-button {
  background: red;
}

body#admin .popup .delete-button:before,
body#admin-edit .popup .delete-button:before {
  display: none;
}

body#admin .popup .delete-button:hover,
body#admin-edit .popup .delete-button:hover {
  background: darkred;
}

body#admin.has-sidebar #admin-dashboard,
body#admin-edit.has-sidebar #admin-dashboard {
  width: calc(100% - 250px);
}

body#admin.has-sidebar #admin-dashboard #sidebar-logo,
body#admin-edit.has-sidebar #admin-dashboard #sidebar-logo {
  height: 35px;
}

body#admin.has-sidebar #admin-dashboard #admin-loader,
body#admin-edit.has-sidebar #admin-dashboard #admin-loader {
  position: fixed;
  top: 0;
  right: 0;
  height: 100vh;
  width: calc(100% - 250px);
  background-color: rgba(255, 255, 255, 0.8);
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
}

body#admin.has-sidebar #admin-dashboard #admin-loader i,
body#admin-edit.has-sidebar #admin-dashboard #admin-loader i {
  font-family: 'Font Awesome\ 5 Free';
  font-weight: 900;
  font-size: 30px;
  color: lightblue;
}

body#admin #admin-dashboard,
body#admin-edit #admin-dashboard {
  max-width: 1140px;
  margin: 0 auto;
  width: 100%;
}

body#admin #admin-dashboard .update-confirmation,
body#admin-edit #admin-dashboard .update-confirmation {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  visibility: hidden;
  opacity: 0;
  z-index: 101;
  -webkit-transform: scale(0.85);
  -moz-transform: scale(0.85);
  -ms-transform: scale(0.85);
  transform: scale(0.85);
  -webkit-transition: all 0.4s cubic-bezier(0.49, 0.01, 0.22, 1);
  -moz-transition: all 0.4s cubic-bezier(0.49, 0.01, 0.22, 1);
  -o-transition: all 0.4s cubic-bezier(0.49, 0.01, 0.22, 1);
  -ms-transition: all 0.4s cubic-bezier(0.49, 0.01, 0.22, 1);
  transition: all 0.4s cubic-bezier(0.49, 0.01, 0.22, 1);
}

body#admin #admin-dashboard .update-confirmation.reveal,
body#admin-edit #admin-dashboard .update-confirmation.reveal {
  opacity: 1;
  visibility: visible;
  -webkit-transform: none;
  -moz-transform: none;
  -ms-transform: none;
  transform: none;
}

body#admin #admin-dashboard .update-confirmation.reveal .confirmation-wrapper i,
body#admin-edit #admin-dashboard .update-confirmation.reveal .confirmation-wrapper i {
  -webkit-transform: none;
  -moz-transform: none;
  -ms-transform: none;
  transform: none;
}

body#admin #admin-dashboard .update-confirmation .confirmation-wrapper,
body#admin-edit #admin-dashboard .update-confirmation .confirmation-wrapper {
  max-width: 200px;
  width: 100%;
  padding: 20px;
  background: white;
  border-radius: 5px;
  border: 1px solid #e4e4e4;
  box-shadow: 0 0 20px rgba(100, 100, 100, 0.3);
  text-align: center;
}

body#admin #admin-dashboard .update-confirmation .confirmation-wrapper h5,
body#admin-edit #admin-dashboard .update-confirmation .confirmation-wrapper h5 {
  font-size: 18px;
  margin-bottom: 15px;
}

body#admin #admin-dashboard .update-confirmation .confirmation-wrapper i,
body#admin-edit #admin-dashboard .update-confirmation .confirmation-wrapper i {
  font-size: 50px;
  -webkit-transform: scale(0);
  -moz-transform: scale(0);
  -ms-transform: scale(0);
  transform: scale(0);
  -webkit-transition: all 0.2s cubic-bezier(0.5, 0, 0.5, 1) 0.3s;
  -moz-transition: all 0.2s cubic-bezier(0.5, 0, 0.5, 1) 0.3s;
  -o-transition: all 0.2s cubic-bezier(0.5, 0, 0.5, 1) 0.3s;
  -ms-transition: all 0.2s cubic-bezier(0.5, 0, 0.5, 1) 0.3s;
  transition: all 0.2s cubic-bezier(0.5, 0, 0.5, 1) 0.3s;
}

body#admin #admin-dashboard .update-confirmation#update-success .confirmation-wrapper i,
body#admin-edit #admin-dashboard .update-confirmation#update-success .confirmation-wrapper i {
  color: #82e65c;
}

body#admin #admin-header,
body#admin-edit #admin-header {
  z-index: 10;
  width: 100%;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  padding-bottom: 30px;
  border-bottom: 1px solid lightgrey;
}

body#admin #admin-header h1#restaurant-title,
body#admin-edit #admin-header h1#restaurant-title {
  font-weight: 100;
  font-size: 40px;
  color: black;
}

body#admin #admin-header span#admin-header-buttons,
body#admin-edit #admin-header span#admin-header-buttons {
  display: -webkit-flex;
  display: flex;
}

body#admin #admin-header span#admin-header-buttons button#customer-button,
body#admin-edit #admin-header span#admin-header-buttons button#customer-button {
  margin-right: 20px;
}

body#admin #admin-header i,
body#admin-edit #admin-header i {
  margin-right: 10px;
}

body#admin nav#admin-menu,
body#admin-edit nav#admin-menu {
  z-index: 10;
  width: 100%;
  display: -webkit-flex;
  display: flex;
  margin-bottom: 40px;
  overflow: auto;
  background: #f3f3f3;
}

body#admin nav#admin-menu span.tab,
body#admin-edit nav#admin-menu span.tab {
  width: 16.66%;
  /* min-width: 120px; */
  height: 45px;
  padding: 0 10px;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  -webkit-justify-content: center;
  justify-content: center;
  color: grey;
  cursor: pointer;
  -webkit-transition: all 0.1s ease-in-out;
  -moz-transition: all 0.1s ease-in-out;
  -o-transition: all 0.1s ease-in-out;
  -ms-transition: all 0.1s ease-in-out;
  transition: all 0.1s ease-in-out;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

body#admin nav#admin-menu span.tab:hover,
body#admin-edit nav#admin-menu span.tab:hover {
  background-color: #e4e4e4;
}

body#admin nav#admin-menu span.tab.active,
body#admin-edit nav#admin-menu span.tab.active {
  color: #0098ff;
  background-color: white;
  border: 1px solid lightgrey;
  border-top: none;
  border-bottom: 3px solid #0098ff;
}

body#admin nav#admin-menu span.tab h6,
body#admin-edit nav#admin-menu span.tab h6 {
  font-size: 14px;
  font-weight: 400;
  color: inherit;
  text-align: center;
}

body#admin section.admin-section,
body#admin-edit section.admin-section {
  display: none;
}

body#admin section.admin-section.active,
body#admin-edit section.admin-section.active {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}

body#admin section.admin-section .card,
body#admin-edit section.admin-section .card {
  margin: 0;
  margin-bottom: 50px;
  padding: 20px;
  overflow: visible;
}

body#admin section.admin-section .card.full-row,
body#admin-edit section.admin-section .card.full-row {
  width: 100%;
}

body#admin section.admin-section .card.half-row,
body#admin-edit section.admin-section .card.half-row {
  width: 48%;
}

body#admin section.admin-section .card h2,
body#admin-edit section.admin-section .card h2 {
  margin: 0;
}

body#admin section.admin-section .card h2 i,
body#admin-edit section.admin-section .card h2 i {
  margin-right: 6px;
  color: #0098FF;
}

body#admin section.admin-section .card h2 span.sm,
body#admin-edit section.admin-section .card h2 span.sm {
  font-size: 12px;
  margin-left: 5px;
  color: grey;
}

body#admin section.admin-section span.card-header-wrapper,
body#admin-edit section.admin-section span.card-header-wrapper {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-align-items: flex-end;
  -moz-align-items: flex-end;
  -ms-align-items: flex-end;
  align-items: flex-end;
}

body#admin section.admin-section .date-range-wrapper,
body#admin-edit section.admin-section .date-range-wrapper {
  width: 100%;
}

body#admin section.admin-section .date-range-wrapper select,
body#admin-edit section.admin-section .date-range-wrapper select {
  margin-right: 20px;
}

body#admin section.admin-section .date-range-wrapper input,
body#admin-edit section.admin-section .date-range-wrapper input {
  height: 40px;
  border-radius: 3px;
  border: 1px solid lightgrey;
}

body#admin section.admin-section#locations-section #nm-chart,
body#admin-edit section.admin-section#locations-section #nm-chart {
  height: 100%;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-align-items: flex-end;
  -moz-align-items: flex-end;
  -ms-align-items: flex-end;
  align-items: flex-end;
  padding: 50px 0;
}

body#admin section.admin-section#locations-section #nm-chart:after,
body#admin-edit section.admin-section#locations-section #nm-chart:after {
  content: '';
  position: absolute;
  width: 100%;
  bottom: 50px;
  border-bottom: 1px solid #e4e4e4;
}

body#admin section.admin-section#locations-section #nm-chart span.nm-bar,
body#admin-edit section.admin-section#locations-section #nm-chart span.nm-bar {
  margin-right: 16px;
  height: 0;
  width: calc(100%/7);
  max-width: 45px;
  background: #0098ff;
  background: -moz-linear-gradient(left, #0098ff 0%, #6dc8fc 100%);
  background: -webkit-linear-gradient(left, #0098ff 0%, #6dc8fc 100%);
  background: linear-gradient(to right, #0098ff 0%, #6dc8fc 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='$color1', endColorstr='$color2', GradientType=1);
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-transition: all 0.8s cubic-bezier(0.49, 0.01, 0.22, 1);
  -moz-transition: all 0.8s cubic-bezier(0.49, 0.01, 0.22, 1);
  -o-transition: all 0.8s cubic-bezier(0.49, 0.01, 0.22, 1);
  -ms-transition: all 0.8s cubic-bezier(0.49, 0.01, 0.22, 1);
  transition: all 0.8s cubic-bezier(0.49, 0.01, 0.22, 1);
}

body#admin section.admin-section#locations-section #nm-chart span.nm-bar:last-child,
body#admin-edit section.admin-section#locations-section #nm-chart span.nm-bar:last-child {
  margin-right: 0;
}

body#admin section.admin-section#locations-section #nm-chart span.nm-bar:before,
body#admin-edit section.admin-section#locations-section #nm-chart span.nm-bar:before {
  content: attr(members);
  position: absolute;
  bottom: 100%;
  font-size: 12px;
  color: #0098ff;
  text-align: center;
  -webkit-transform: translateY(-5px);
  -moz-transform: translateY(-5px);
  -ms-transform: translateY(-5px);
  transform: translateY(-5px);
}

body#admin section.admin-section#locations-section #nm-chart span.nm-bar:after,
body#admin-edit section.admin-section#locations-section #nm-chart span.nm-bar:after {
  content: attr(date);
  position: absolute;
  top: 100%;
  font-size: 12px;
  color: grey;
  text-align: center;
  -webkit-transform: translateY(15px);
  -moz-transform: translateY(15px);
  -ms-transform: translateY(15px);
  transform: translateY(15px);
}

body#admin section.admin-section#locations-section #new-members-card canvas#newMemberChart,
body#admin-edit section.admin-section#locations-section #new-members-card canvas#newMemberChart {
  position: absolute;
  bottom: 20px;
}

body#admin section.admin-section#users-section span#search-user,
body#admin-edit section.admin-section#users-section span#search-user {
  width: 50%;
}

body#admin section.admin-section#users-section span#search-user:before,
body#admin-edit section.admin-section#users-section span#search-user:before {
  content: '\f002';
  font-family: 'Font Awesome\ 5 Free';
  font-weight: 900;
  font-size: 14px;
  position: absolute;
  top: 13px;
}

body#admin section.admin-section#users-section span#search-user.active:before,
body#admin-edit section.admin-section#users-section span#search-user.active:before {
  color: #0098ff;
}

body#admin section.admin-section#users-section span#search-user input,
body#admin-edit section.admin-section#users-section span#search-user input {
  background: none;
  border: none;
  border-bottom: 1px solid lightgrey;
  margin-bottom: 40px;
  line-height: 1;
  width: 100%;
  padding: 5px 10px;
  padding-left: 20px;
  font-size: 24px;
  -webkit-transition: all 0.3s ease-in-out;
  -moz-transition: all 0.3s ease-in-out;
  -o-transition: all 0.3s ease-in-out;
  -ms-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}

body#admin section.admin-section#users-section span#search-user input::placeholder,
body#admin-edit section.admin-section#users-section span#search-user input::placeholder {
  color: lightgrey;
}

body#admin section.admin-section#users-section span#search-user input:focus,
body#admin-edit section.admin-section#users-section span#search-user input:focus {
  outline: none;
  border-bottom: 1px solid #0098ff;
}

body#admin section.admin-section#users-section span#search-user {
  width: auto;
  color: #9b9b9b;
}

body#admin section.admin-section#users-section span#search-user::before {
  top: 7px;
}

body#admin section.admin-section#users-section span#search-user input {
  margin: 0;
  padding: 5px 10px 5px 25px;
  font-size: 16px;
}

body#admin section.admin-section#users-section div#user-pagination,
body#admin-edit section.admin-section#users-section div#user-pagination {
  width: auto;
  float: right;
  white-space: nowrap;
  margin-left: auto;
}

body#admin section.admin-section#users-section div#user-pagination p,
body#admin section.admin-section#users-section div#user-pagination a,
body#admin-edit section.admin-section#users-section div#user-pagination p,
body#admin-edit section.admin-section#users-section div#user-pagination a {
  color: grey;
  font-weight: lighter;
  line-height: 1;
}

body#admin section.admin-section#users-section div#user-pagination #paginate-summary,
body#admin section.admin-section#users-section div#user-pagination #user-pages,
body#admin-edit section.admin-section#users-section div#user-pagination #paginate-summary,
body#admin-edit section.admin-section#users-section div#user-pagination #user-pages {
  white-space: nowrap;
  margin-bottom: 6px;
}

#user-pages {
  display: inline-block;
}

body#admin section.admin-section#users-section div#user-pagination span#page-indices,
body#admin-edit section.admin-section#users-section div#user-pagination span#page-indices {
  margin: 0 5px;
}

body#admin section.admin-section#users-section div#user-pagination span#page-indices a,
body#admin-edit section.admin-section#users-section div#user-pagination span#page-indices a {
  margin: 0 3px;
}

body#admin section.admin-section#users-section div#user-pagination span#page-indices a:hover,
body#admin-edit section.admin-section#users-section div#user-pagination span#page-indices a:hover {
  color: #46a4fb;
}

body#admin section.admin-section#users-section div#user-pagination .active-page,
body#admin-edit section.admin-section#users-section div#user-pagination .active-page {
  color: #46a4fb;
  text-decoration: underline;
}

body#admin section.admin-section#users-section div#user-pagination #prev-page,
body#admin section.admin-section#users-section div#user-pagination #next-page,
body#admin-edit section.admin-section#users-section div#user-pagination #prev-page,
body#admin-edit section.admin-section#users-section div#user-pagination #next-page {
  font-size: 12px;
}

body#admin section.admin-section#users-section div#user-pagination #prev-page:hover,
body#admin section.admin-section#users-section div#user-pagination #next-page:hover,
body#admin-edit section.admin-section#users-section div#user-pagination #prev-page:hover,
body#admin-edit section.admin-section#users-section div#user-pagination #next-page:hover {
  color: #46a4fb;
}

div#user-pagination>span {
  color: grey;
}

body#admin section.admin-section#promotions-section #promo-control-panel,
body#admin-edit section.admin-section#promotions-section #promo-control-panel {
  width: 100%;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  margin-bottom: 40px;
}

body#admin section.admin-section#promotions-section #promo-control-panel>span,
body#admin-edit section.admin-section#promotions-section #promo-control-panel>span {
  display: -webkit-flex;
  display: flex;
  margin-left: auto;
}

body#admin section.admin-section#promotions-section #promo-control-panel button,
body#admin-edit section.admin-section#promotions-section #promo-control-panel button {
  background: #0098ff;
  margin-left: 20px;
}

body#admin section.admin-section#promotions-section #promo-control-panel button.add-new-promo,
body#admin-edit section.admin-section#promotions-section #promo-control-panel button.add-new-promo {
  z-index: 99;
  position: absolute;
  padding: 0;
  /* border-radius: 50%; */
  border-radius: 25px;
  width: 140px;
  height: 35px;
  margin-left: 0;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
}

body#admin section.admin-section#promotions-section #promo-control-panel button.add-new-promo i,
body#admin-edit section.admin-section#promotions-section #promo-control-panel button.add-new-promo i {
  margin-right: 0;
}

body#admin section.admin-section#promotions-section #promo-control-panel button.add-new-promo.fixed,
body#admin-edit section.admin-section#promotions-section #promo-control-panel button.add-new-promo.fixed {
  position: fixed;
  top: 40px;
}

body#admin section.admin-section#promotions-section #push-notification-container,
body#admin-edit section.admin-section#promotions-section #push-notification-container {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: 100;
  background: rgba(255, 255, 255, 0.8);
  padding: 20px;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  visibility: hidden;
  opacity: 0;
  -webkit-transition: all 0.2s cubic-bezier(0.49, 0.01, 0.22, 1);
  -moz-transition: all 0.2s cubic-bezier(0.49, 0.01, 0.22, 1);
  -o-transition: all 0.2s cubic-bezier(0.49, 0.01, 0.22, 1);
  -ms-transition: all 0.2s cubic-bezier(0.49, 0.01, 0.22, 1);
  transition: all 0.2s cubic-bezier(0.49, 0.01, 0.22, 1);
}

body#admin section.admin-section#promotions-section #push-notification-container.show,
body#admin-edit section.admin-section#promotions-section #push-notification-container.show {
  visibility: visible;
  opacity: 1;
}

body#admin section.admin-section#promotions-section #push-notification-container form,
body#admin-edit section.admin-section#promotions-section #push-notification-container form {
  padding: 20px;
  border-radius: 5px;
  max-width: 400px;
  background: white;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.15);
}

body#admin section.admin-section#promotions-section #push-notification-container h2,
body#admin-edit section.admin-section#promotions-section #push-notification-container h2 {
  text-align: center;
  width: 100%;
  margin-bottom: 10px;
}

body#admin section.admin-section#promotions-section #push-notification-container input,
body#admin section.admin-section#promotions-section #push-notification-container textarea,
body#admin section.admin-section#promotions-section #push-notification-container select,
body#admin-edit section.admin-section#promotions-section #push-notification-container input,
body#admin-edit section.admin-section#promotions-section #push-notification-container textarea,
body#admin-edit section.admin-section#promotions-section #push-notification-container select {
  font-size: 14px;
}

body#admin section.admin-section#promotions-section #push-notification-container select,
body#admin-edit section.admin-section#promotions-section #push-notification-container select {
  margin-bottom: 0;
}

body#admin section.admin-section#promotions-section #push-notification-container textarea,
body#admin-edit section.admin-section#promotions-section #push-notification-container textarea {
  border: 1px solid lightgrey;
  border-radius: 3px;
  width: 100%;
  padding: 8px;
}

body#admin section.admin-section#promotions-section #push-notification-container span.form-buttons-2,
body#admin-edit section.admin-section#promotions-section #push-notification-container span.form-buttons-2 {
  display: -webkit-flex;
  display: flex;
  margin-top: 20px;
}

body#admin section.admin-section#promotions-section #push-notification-container span.form-buttons-2 button,
body#admin-edit section.admin-section#promotions-section #push-notification-container span.form-buttons-2 button {
  -webkit-justify-content: center;
  justify-content: center;
  width: 50%;
  margin: 0 10px;
}

body#admin section.admin-section#promotions-section #push-notification-container span.form-buttons-2 button.reset-button,
body#admin-edit section.admin-section#promotions-section #push-notification-container span.form-buttons-2 button.reset-button {
  background: slategrey;
}

body#admin section.admin-section#promotions-section #push-notification-container span.form-buttons-2 button.send-button,
body#admin-edit section.admin-section#promotions-section #push-notification-container span.form-buttons-2 button.send-button {
  background: #46a4fb;
}

body#admin section.admin-section#promotions-section .promo-container,
body#admin-edit section.admin-section#promotions-section .promo-container {
  width: 100%;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-align-items: flex-start;
  -moz-align-items: flex-start;
  -ms-align-items: flex-start;
  align-items: flex-start;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}

body#admin section.admin-section#promotions-section .promo-container span#reorder-promo-wrapper,
body#admin-edit section.admin-section#promotions-section .promo-container span#reorder-promo-wrapper {
  width: 100%;
  margin-bottom: 40px;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-tap-highlight-color: transparent;
}

body#admin section.admin-section#promotions-section .promo-container span#reorder-promo-wrapper button,
body#admin-edit section.admin-section#promotions-section .promo-container span#reorder-promo-wrapper button {
  float: right;
}

body#admin section.admin-section#promotions-section .promo-container .card,
body#admin-edit section.admin-section#promotions-section .promo-container .card {
  display: block;
  min-height: 50px;
  width: 48%;
  box-shadow: 0 0 10px rgba(200, 200, 200, 0.2);
}

body#admin section.admin-section#promotions-section .promo-container .card.new-promo,
body#admin-edit section.admin-section#promotions-section .promo-container .card.new-promo {
  border: 1px solid #0098ff;
}

body#admin section.admin-section#promotions-section .promo-container .card.new-promo span.promo-menu-button,
body#admin-edit section.admin-section#promotions-section .promo-container .card.new-promo span.promo-menu-button {
  display: none !important;
}

body#admin section.admin-section#promotions-section .promo-container .card .wys-container .panel-buttons,
body#admin-edit section.admin-section#promotions-section .promo-container .card .wys-container .panel-buttons {
  display: none;
}

body#admin section.admin-section#promotions-section .promo-container .card.editable span.event-image input,
body#admin-edit section.admin-section#promotions-section .promo-container .card.editable span.event-image input {
  display: -webkit-flex;
  display: flex;
}

body#admin section.admin-section#promotions-section .promo-container .card.editable span.form-buttons,
body#admin-edit section.admin-section#promotions-section .promo-container .card.editable span.form-buttons {
  display: -webkit-flex;
  display: flex;
}

body#admin section.admin-section#promotions-section .promo-container .card.editable input:not(.img-upload),
body#admin section.admin-section#promotions-section .promo-container .card.editable textarea,
body#admin-edit section.admin-section#promotions-section .promo-container .card.editable input:not(.img-upload),
body#admin-edit section.admin-section#promotions-section .promo-container .card.editable textarea {
  border: 1px solid #e4e4e4 !important;
  padding: 10px;
}

body#admin section.admin-section#promotions-section .promo-container .card.editable input:not(.img-upload):focus,
body#admin section.admin-section#promotions-section .promo-container .card.editable textarea:focus,
body#admin-edit section.admin-section#promotions-section .promo-container .card.editable input:not(.img-upload):focus,
body#admin-edit section.admin-section#promotions-section .promo-container .card.editable textarea:focus {
  outline: none;
  border: 1px solid #0098ff !important;
}

body#admin section.admin-section#promotions-section .promo-container .card.editable span.event-details p.event-detail span,
body#admin-edit section.admin-section#promotions-section .promo-container .card.editable span.event-details p.event-detail span {
  display: inline-block;
}

body#admin section.admin-section#promotions-section .promo-container .card.editable .wys-container .panel-buttons,
body#admin-edit section.admin-section#promotions-section .promo-container .card.editable .wys-container .panel-buttons {
  display: -webkit-flex;
  display: flex;
}

body#admin section.admin-section#promotions-section .promo-container .card#add-promo,
body#admin-edit section.admin-section#promotions-section .promo-container .card#add-promo {
  background-color: transparent;
  border: 1px dashed #0098ff;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  -webkit-justify-content: center;
  justify-content: center;
  width: 100%;
}

body#admin section.admin-section#promotions-section .promo-container .card#add-promo button.add-new-promo,
body#admin-edit section.admin-section#promotions-section .promo-container .card#add-promo button.add-new-promo {
  margin: 0 auto;
}

body#admin section.admin-section#promotions-section .promo-container .card#add-promo button.add-new-promo i,
body#admin-edit section.admin-section#promotions-section .promo-container .card#add-promo button.add-new-promo i {
  margin-right: 8px;
}

body#admin section.admin-section#promotions-section .promo-container .card input,
body#admin section.admin-section#promotions-section .promo-container .card textarea,
body#admin-edit section.admin-section#promotions-section .promo-container .card input,
body#admin-edit section.admin-section#promotions-section .promo-container .card textarea {
  border: none !important;
  margin: 0;
  padding: 0;
  outline: none;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-header,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-header {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-align-items: flex-start;
  -moz-align-items: flex-start;
  -ms-align-items: flex-start;
  align-items: flex-start;
  z-index: 10;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-header input,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-header input {
  font-weight: 500;
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -moz-box-flex: 1;
  -moz-flex: 1;
  -ms-flex: 1;
  flex: 1;
  padding-right: 15px;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-header span.promo-menu-button,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-header span.promo-menu-button {
  height: 20px;
  width: 20px;
  background-color: rgba(255, 255, 255, 0.8);
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  -webkit-justify-content: flex-end;
  justify-content: flex-end;
  cursor: pointer;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-header span.promo-menu-button:before,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-header span.promo-menu-button:before {
  content: '\f142';
  font-family: 'Font Awesome 5 Free';
  font-weight: 900;
  color: #0098ff;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-header span.promo-menu-button:hover .promo-menu,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-header span.promo-menu-button:hover .promo-menu {
  opacity: 1;
  visibility: visible;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-header span.promo-menu-button .promo-menu,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-header span.promo-menu-button .promo-menu {
  top: 0;
  visibility: hidden;
  opacity: 0;
  overflow: hidden;
  position: absolute;
  box-shadow: 0 0 10px rgba(100, 100, 100, 0.5);
  border-radius: 3px;
  background-color: rgba(255, 255, 255, 0.95);
  right: 100%;
  -webkit-transition: all 0.2s ease-in-out;
  -moz-transition: all 0.2s ease-in-out;
  -o-transition: all 0.2s ease-in-out;
  -ms-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-header span.promo-menu-button .promo-menu p,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-header span.promo-menu-button .promo-menu p {
  padding: 5px 20px;
  font-size: 12px;
  font-weight: 500;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-header span.promo-menu-button .promo-menu p:not(:last-child),
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-header span.promo-menu-button .promo-menu p:not(:last-child) {
  border-bottom: 1px solid #e4e4e4;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-header span.promo-menu-button .promo-menu p:hover,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-header span.promo-menu-button .promo-menu p:hover {
  background-color: #0098ff;
  color: white;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-header span.promo-menu-button .promo-menu p.copy-promo:before,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-header span.promo-menu-button .promo-menu p.copy-promo:before {
  content: '\f24d';
  margin-right: 7px;
  font-family: 'Font Awesome\ 5 Free';
  font-weight: 900;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-header span.promo-menu-button .promo-menu p.edit-promo:before,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-header span.promo-menu-button .promo-menu p.edit-promo:before {
  content: '\f303';
  margin-right: 7px;
  font-family: 'Font Awesome\ 5 Free';
  font-weight: 900;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-header span.promo-menu-button .promo-menu p.delete-promo,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-header span.promo-menu-button .promo-menu p.delete-promo {
  color: red;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-header span.promo-menu-button .promo-menu p.delete-promo:hover,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-header span.promo-menu-button .promo-menu p.delete-promo:hover {
  background-color: red;
  color: white;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-header span.promo-menu-button .promo-menu p.delete-promo:before,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-header span.promo-menu-button .promo-menu p.delete-promo:before {
  content: '\f2ed';
  margin-right: 7px;
  font-family: 'Font Awesome\ 5 Free';
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-image,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-image {
  display: block;
  margin: 15px 0 25px;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-image img,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-image img {
  width: 100%;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-image input,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-image input {
  display: none;
  margin-top: 10px;
  font-size: 14px;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-details ::-webkit-input-placeholder,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-details ::-webkit-input-placeholder {
  font-style: italic;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-details :-moz-placeholder,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-details :-moz-placeholder {
  font-style: italic;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-details ::-moz-placeholder,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-details ::-moz-placeholder {
  font-style: italic;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-details :-ms-input-placeholder,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-details :-ms-input-placeholder {
  font-style: italic;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-details p.event-detail,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-details p.event-detail {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  color: grey;
  padding-left: 25px;
  line-height: 1.3;
  margin-bottom: 15px;
  font-weight: 400;
  font-size: 13px;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-details p.event-detail:before,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-details p.event-detail:before {
  font-family: 'Font Awesome\ 5 Free';
  position: absolute;
  left: 0;
  text-align: center;
  width: 20px;
  color: #0098ff;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-details p.event-detail.event-location:before,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-details p.event-detail.event-location:before {
  content: '\f3c5';
  font-weight: 900;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-details p.event-detail.event-date:before,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-details p.event-detail.event-date:before {
  content: '\f274';
  font-weight: 900;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-details p.event-detail.event-schedule-date:before,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-details p.event-detail.event-schedule-date:before {
  content: '\f073';
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-details p.event-detail.event-time:before,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-details p.event-detail.event-time:before {
  content: '\f017';
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-details p.event-detail.event-phone:before,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-details p.event-detail.event-phone:before {
  content: '\f3cd';
  font-weight: 900;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-details p.event-detail.event-email:before,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-details p.event-detail.event-email:before {
  content: '\f0e0';
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-details p.event-detail.event-link:before,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-details p.event-detail.event-link:before {
  content: '\f0c1';
  font-weight: 900;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-details p.event-detail.event-exp-date:before,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-details p.event-detail.event-exp-date:before {
  content: '\f273';
  font-weight: 900;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-details p.event-detail.event-sms:before,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-details p.event-detail.event-sms:before {
  content: '\f075';
  font-weight: 900;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-details p.event-detail input,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-details p.event-detail input {
  font: inherit;
  color: black;
  border-bottom: 1px solid transparent;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-details p.event-detail span:not(.input-with-icon),
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-details p.event-detail span:not(.input-with-icon) {
  margin-left: 10px;
  white-space: nowrap;
  display: none;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-details p.event-detail span input[type="checkbox"],
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-details p.event-detail span input[type="checkbox"] {
  width: auto;
  margin-right: 5px;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-details p.event-selection,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-details p.event-selection {
  font-weight: normal;
  font-size: 13px;
  margin-top: 20px !important;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-details p.event-selection select,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-details p.event-selection select {
  margin: 0;
  margin-top: 5px;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-details p.event-description,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-details p.event-description {
  margin-top: 20px;
}

body#admin section.admin-section#promotions-section .promo-container .card span.event-details p.event-description textarea,
body#admin-edit section.admin-section#promotions-section .promo-container .card span.event-details p.event-description textarea {
  min-height: 100px;
  height: 200px;
  font: inherit;
  resize: none;
  border: none;
  width: 100%;
  font-size: 13px;
  line-height: 1.8;
}

body#admin section.admin-section#promotions-section .promo-container .insert-bar,
body#admin-edit section.admin-section#promotions-section .promo-container .insert-bar {
  display: block;
  width: 100%;
  max-width: 600px;
  height: 2px;
  background: #46a4fb;
  margin: 0 auto;
}

body#admin section.admin-section#promotions-section .reorder-promo,
body#admin-edit section.admin-section#promotions-section .reorder-promo {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  width: 100%;
  margin: 30px 0;
}

body#admin section.admin-section#redemptions-section .card,
body#admin-edit section.admin-section#redemptions-section .card {
  text-align: center;
}

body#admin section.admin-section#redemptions-section #avg-coin-redemption-container,
body#admin-edit section.admin-section#redemptions-section #avg-coin-redemption-container {
  margin: 30px 0;
}

body#admin section.admin-section#redemptions-section #avg-coin-redemption-container h3#avg-coin-redeemed-message,
body#admin-edit section.admin-section#redemptions-section #avg-coin-redemption-container h3#avg-coin-redeemed-message {
  color: #0098ff;
  font-size: 48px;
  font-weight: 100;
}

body#admin section.admin-section#redemptions-section #avg-coin-redemption-container h3#avg-coin-redeemed-message:before,
body#admin section.admin-section#redemptions-section #avg-coin-redemption-container h3#avg-coin-redeemed-message:after,
body#admin-edit section.admin-section#redemptions-section #avg-coin-redemption-container h3#avg-coin-redeemed-message:before,
body#admin-edit section.admin-section#redemptions-section #avg-coin-redemption-container h3#avg-coin-redeemed-message:after {
  display: block;
  font-size: 14px;
  font-weight: 100;
}

body#admin section.admin-section#redemptions-section #avg-coin-redemption-container h3#avg-coin-redeemed-message:before,
body#admin-edit section.admin-section#redemptions-section #avg-coin-redemption-container h3#avg-coin-redeemed-message:before {
  content: 'An average of';
}

body#admin section.admin-section#redemptions-section #avg-coin-redemption-container h3#avg-coin-redeemed-message:after,
body#admin-edit section.admin-section#redemptions-section #avg-coin-redemption-container h3#avg-coin-redeemed-message:after {
  content: 'have been redeemed';
}

body#admin section.admin-section#redemptions-section #roi-calc-container,
body#admin-edit section.admin-section#redemptions-section #roi-calc-container {
  margin-top: 50px;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

body#admin section.admin-section#redemptions-section #roi-calc-container span.roi-field,
body#admin-edit section.admin-section#redemptions-section #roi-calc-container span.roi-field {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
  width: 45%;
  padding: 0 10px;
}

body#admin section.admin-section#redemptions-section #roi-calc-container span.roi-field label,
body#admin-edit section.admin-section#redemptions-section #roi-calc-container span.roi-field label {
  position: absolute;
  bottom: 125%;
  font-size: 11px;
  padding: 0 10px;
}

body#admin section.admin-section#redemptions-section #roi-calc-container span.roi-field input,
body#admin-edit section.admin-section#redemptions-section #roi-calc-container span.roi-field input {
  border: none;
  border-bottom: 1px solid lightgrey;
  background: transparent;
  width: 100%;
  outline: none;
  text-align: center;
}

body#admin section.admin-section#redemptions-section #roi-calc-container h3#calculated-roi,
body#admin-edit section.admin-section#redemptions-section #roi-calc-container h3#calculated-roi {
  color: #0098ff;
  font-size: 48px;
  font-weight: 100;
  margin-top: 20px;
}

body#admin section.admin-section#redemptions-section #roi-calc-container h3#calculated-roi:before,
body#admin-edit section.admin-section#redemptions-section #roi-calc-container h3#calculated-roi:before {
  content: "";
  white-space: nowrap;
  display: block;
  font-size: 12px;
}

body#admin section.admin-section#redemptions-section #roi-calc-container h3#calculated-roi:after,
body#admin-edit section.admin-section#redemptions-section #roi-calc-container h3#calculated-roi:after {
  content: '$';
  position: absolute;
  right: 102%;
  font-size: 32px;
  margin-top: 5px;
}

body#admin section.admin-section#summary-section .date-selection-wrapper,
body#admin-edit section.admin-section#summary-section .date-selection-wrapper {
  width: 100%;
}

body#admin section.admin-section#summary-section .date-selection-wrapper select,
body#admin-edit section.admin-section#summary-section .date-selection-wrapper select {
  width: 140px;
}

body#admin section.admin-section#summary-section .date-selection-wrapper select:not(:last-child),
body#admin-edit section.admin-section#summary-section .date-selection-wrapper select:not(:last-child) {
  margin-right: 10px;
}

body#admin .wys-container,
body#admin-edit .wys-container {
  margin: 30px 0;
  width: 100%;
  max-width: 800px;
}

body#admin .wys-container .panel-buttons,
body#admin-edit .wys-container .panel-buttons {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  width: 100%;
}

body#admin .wys-container .panel-buttons .button-group,
body#admin-edit .wys-container .panel-buttons .button-group {
  display: -webkit-flex;
  display: flex;
}

body#admin .wys-container .panel-buttons .button-group:last-child,
body#admin-edit .wys-container .panel-buttons .button-group:last-child {
  border: 1px solid #333;
  border-top: none;
  border-left: none;
}

body#admin .wys-container .panel-buttons button,
body#admin-edit .wys-container .panel-buttons button {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -moz-box-flex: 1;
  -moz-flex: 1;
  -ms-flex: 1;
  flex: 1;
  -webkit-justify-content: center;
  justify-content: center;
  padding: 12px;
  border-radius: 0;
  background: #333 !important;
  box-shadow: inset 0 0 1px 0 rgba(0, 0, 0, 0.3);
  margin: 0;
}

body#admin .wys-container .panel-buttons button i,
body#admin-edit .wys-container .panel-buttons button i {
  margin-right: 0;
  pointer-events: none;
}

body#admin .wys-container .panel-buttons select,
body#admin-edit .wys-container .panel-buttons select {
  margin: 0;
  height: 100%;
  font-size: 13px;
  border: none;
  cursor: pointer;
  background: transparent;
}

body#admin .wys-container a.clear-wys-styling,
body#admin-edit .wys-container a.clear-wys-styling {
  display: inline-block;
  margin-top: 10px;
  font-size: 12px;
  border-radius: 5px;
  border: 1px solid lightgrey;
  color: grey;
  padding: 7px 10px;
  -webkit-transition: all 0.2s ease-in-out;
  -moz-transition: all 0.2s ease-in-out;
  -o-transition: all 0.2s ease-in-out;
  -ms-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
}

body#admin .wys-container a.clear-wys-styling:hover,
body#admin-edit .wys-container a.clear-wys-styling:hover {
  background: #333;
  border-color: #333;
  color: white;
}

body#admin .wys-container .wys-editor,
body#admin-edit .wys-container .wys-editor {
  min-height: 160px;
  border: 1px solid grey;
  padding: 10px;
  background: white;
  font-family: 'Roboto', helvetica, arial, sans-serif;
  font-size: 14px;
  font-weight: 300;
  line-height: 1.4;
  outline: none;
}

body#admin .wys-container .wys-editor:empty:before,
body#admin-edit .wys-container .wys-editor:empty:before {
  content: 'Enter text here...';
  color: lightgrey;
}

body#admin .wys-container .wys-editor[contentEditable="false"],
body#admin-edit .wys-container .wys-editor[contentEditable="false"] {
  border: none;
}

body#admin .wys-container .htmlview,
body#admin-edit .wys-container .htmlview {
  display: none;
}

body#admin .wys-container ul,
body#admin-edit .wys-container ul {
  list-style: unset;
  padding-left: 30px;
}

body#admin-edit #admin-header {
  border-bottom: none;
}

body#admin-edit textarea#iframe-code {
  width: 100%;
  margin-top: 30px;
  border: 1px solid lightgrey;
  border-radius: 3px;
  font-size: 12px;
}

body#admin-edit #edit-restaurant-card {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}

body#admin-edit #edit-restaurant-card h2 {
  display: block;
  width: 100%;
}

body#admin-edit #edit-restaurant-card form.basic {
  -webkit-align-items: flex-start;
  -moz-align-items: flex-start;
  -ms-align-items: flex-start;
  align-items: flex-start;
  box-shadow: 0 0 10px rgba(200, 200, 200, 0.5);
  border-radius: 5px;
  padding: 20px;
}

body#admin-edit #edit-restaurant-card form.basic input {
  font-size: 14px;
}

body#admin-edit #edit-restaurant-card form.basic>span {
  margin-right: 0;
  width: 100%;
}

body#admin-edit #edit-restaurant-card form.basic button {
  margin: 0;
  margin-top: 20px;
}

body#admin-edit #edit-restaurant-card form.basic>div>span {
  margin-bottom: 35px;
  margin-right: 0;
}

body#admin-edit #edit-restaurant-card form.basic h3 {
  color: black;
  margin-bottom: 10px;
  font-weight: 400;
}

body#admin-edit #edit-restaurant-card form.basic p.sm {
  color: #222;
  line-height: 1.6;
  font-size: 13px;
  margin-bottom: 10px;
}

body#admin-edit #edit-restaurant-card form.basic span#rest-name input {
  font-size: 24px;
}

body#admin-edit #edit-restaurant-card form.basic span#rest-brand-colors>span,
body#admin-edit #edit-restaurant-card form.basic span#rest-campaign-colors>span {
  display: block;
  margin-top: 20px;
}

body#admin-edit #edit-restaurant-card form.basic span#rest-brand-colors>span input,
body#admin-edit #edit-restaurant-card form.basic span#rest-campaign-colors>span input {
  padding-left: 10px;
}

body#admin-edit #edit-restaurant-card form.basic span#rest-brand-colors>span label,
body#admin-edit #edit-restaurant-card form.basic span#rest-campaign-colors>span label{
  color: black !important;
  display: block;
}

.sp-original-input-container {
  width: 100%;
}
.sp-colorize-container {
  width: 32px !important;
  border: 1px solid lightgray;
  margin-right: 5px !important;
}

body#admin-edit #edit-restaurant-card form.basic span#rest-brand-colors>span span.swatch {
  position: absolute;
  height: 25px;
  width: 25px;
  display: inline-block;
  bottom: 7px;
  left: 0;
  border: 1px solid #e4e4e4;
}

body#admin-edit #edit-restaurant-card form.basic span.image-upload-wrapper input.image-upload {
  border-bottom: none;
}

body#admin-edit #edit-restaurant-card form.basic span.image-upload-wrapper img {
  margin: 10px 0;
  width: 100%;
  background-color: #e4e4e4;
}

body#admin-edit #edit-restaurant-card form.basic span.image-upload-wrapper img#rest-logo-upload {
  max-height: 500px;
  width: auto;
  max-width: 100%;
}

body#admin-edit #edit-restaurant-card form.basic span.image-upload-wrapper img#rest-favicon-upload {
  max-height: 200px;
  width: auto;
  max-width: 100%;
}

body#admin-edit #edit-restaurant-card form.basic span.form-buttons {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  width: 100%;
  margin: 0;
}

body#admin-edit #edit-restaurant-card form.basic span.form-buttons button {
  margin: 20px;
}

body#admin-edit #edit-restaurant-card form.basic span.form-buttons button.undo-button {
  background: slategrey;
}

body#admin-edit #edit-restaurant-card form.basic span.form-buttons button.undo-button:before {
  display: none;
}

body#admin-edit #admin-edit-restaurant section.admin-section {
  display: block;
}

body#admin-edit #add-locations-card form {
  -webkit-justify-content: space-between;
  justify-content: space-between;
}

body#admin-edit #add-locations-card form>span {
  width: 30%;
  margin: 0;
  margin-bottom: 20px;
}

body#admin-edit #add-locations-card form button {
  width: 30%;
  margin: 10px 0;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
}

body#admin-edit #edit-locations-card .loc-delete:hover, body#admin-edit #edit-locations-card .loc-edit:hover {
  color: #0098ff;
}

body#admin-edit #edit-locations-card .loc-delete, body#admin-edit #edit-locations-card .loc-edit {
  cursor: pointer;
}

#ranking-criteria form {
  justify-content: space-between;
}

#ranking-criteria form span {
  width: 30%;
  margin: 0;
  margin-bottom: 20px;
}

#ranking-criteria form span select {
  display: block;
}

#ranking-criteria form button[type=submit],
#quarantine-criteria form button[type=submit] {
  width: 30%;
  margin: 10px 0;
  display: flex;
  justify-content: center;
}

#quarantine-criteria h4 {
  color: grey;
  padding-top: 20px;
  font-style: italic;
  font-weight: 200;
  font-size: 16px;
  display: inline-block;
}

#quarantine-criteria input {
  width: 50px;
  height: 40px;
  text-align: center;
}

#quarantine-criteria label {
  padding: 0 10px;
  font-size: 16px;
  color: #0098ff;
}

#quarantine-criteria>form>span {
  margin-bottom: 0;
}

#quarantine-criteria>form {
  margin-top: 10px;
}

#quarantine-criteria select {
  margin: 0;
}

#quarantine-criteria button {
  float: right;
  margin: 25px 0;
}

body nav#admin-sidebar {
  height: 100%;
  width: 250px;
  z-index: 100;
}

body nav#admin-sidebar #menu-button {
  height: 40px;
  width: 40px;
  background: #0098ff;
  background: -moz-linear-gradient(left, #0098ff 0%, #6dc8fc 100%);
  background: -webkit-linear-gradient(left, #0098ff 0%, #6dc8fc 100%);
  background: linear-gradient(to right, #0098ff 0%, #6dc8fc 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='$color1', endColorstr='$color2', GradientType=1);
  position: absolute;
  right: 100%;
  top: 50px;
  cursor: pointer;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
}

body nav#admin-sidebar #menu-button i {
  color: white;
}

body nav#admin-sidebar #sidebar-wrapper {
  height: inherit;
  width: inherit;
  left: 0;
  top: 0;
  position: fixed;
  padding: 25px;
  background-color: white;
  box-shadow: 0 0 10px rgba(200, 200, 200, 0.5);
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}

body nav#admin-sidebar #chain-wrapper {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -moz-box-flex: 1;
  -moz-flex: 1;
  -ms-flex: 1;
  flex: 1;
  overflow: auto;
}

body nav#admin-sidebar #add-chain-wrapper {
  margin-bottom: 20px;
  box-shadow: 0 10px 10px -10px rgba(0, 0, 0, 0.1);
}

body nav#admin-sidebar #add-chain-wrapper button#add-chain {
  margin: 0;
  margin-bottom: 30px;
  width: 100%;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
}

body nav#admin-sidebar #chain-name-list {
  overflow: auto;
}

body nav#admin-sidebar #chain-name-list .chain-name {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-align-items: center;
  -moz-align-items: center;
  -ms-align-items: center;
  align-items: center;
}

body nav#admin-sidebar #chain-name-list .chain-name:hover span.deleteLoc {
  display: inline-block;
}

body nav#admin-sidebar #chain-name-list a {
  display: block;
  margin: 10px 0;
  font-size: 14px;
  font-weight: lighter;
  color: #333;
}

body nav#admin-sidebar #chain-name-list a.active {
  color: #0098ff;
}

body nav#admin-sidebar #chain-name-list a:hover {
  color: #0098ff;
}

body nav#admin-sidebar #chain-name-list span.deleteLoc {
  display: none;
  height: 16px;
  color: grey;
  top: -2px;
  cursor: pointer;
}

body nav#admin-sidebar #chain-name-list span.deleteLoc:hover {
  color: darkred;
}

body nav#admin-sidebar #sidebar-footer {
  margin-top: 40px;
}

body nav#admin-sidebar #sidebar-footer a#documentation {
  color: darkgrey;
  font-size: 11px;
  font-weight: bold;
}

body nav#admin-sidebar #sidebar-footer a#documentation:hover {
  color: lightgrey;
}

body nav#admin-sidebar #sidebar-footer p {
  color: darkgrey;
  font-size: 11px;
  margin-top: 10px;
  line-height: 1.4;
}

body div#admin-dashboard {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -moz-box-flex: 1;
  -moz-flex: 1;
  -ms-flex: 1;
  flex: 1;
}

body div#admin-dashboard p.restaurant-name-footer,
body div#admin-dashboard p.restaurant-name-footer-es {
  text-align: center;
  color: grey;
  font-size: 13px;
}

footer {
  text-align: center;
  padding: 30px 0;
  margin-top: 45px;
}

footer .referral-button {
  display: none;
}

footer span {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  margin-bottom: 30px;
}

footer span a {
  display: inline-block;
  font-size: 14px;
  color: #46a4fb;
  margin-right: 13px;
}

footer p {
  font-size: 14px;
  color: #a5a5a5;
  line-height: 1.2;
}

footer p a {
  font: inherit;
  color: inherit;
}

@media all and (max-width: 1139px) {

  body#admin #admin-header h1#restaurant-title,
  body#admin-edit #admin-header h1#restaurant-title {
    font-size: 32px;
  }

  body#admin nav#admin-menu span.tab,
  body#admin-edit nav#admin-menu span.tab {
    height: 35px;
  }

  body#admin nav#admin-menu span.tab h6,
  body#admin-edit nav#admin-menu span.tab h6 {
    font-size: 12px;
  }

  body#admin.has-sidebar #admin-dashboard,
  body#admin-edit.has-sidebar #admin-dashboard {
    width: calc(100% - 220px);
  }

  body#admin.has-sidebar #admin-dashboard #admin-loader,
  body#admin-edit.has-sidebar #admin-dashboard #admin-loader {
    width: calc(100% - 220px);
  }

  body#admin section.admin-section .card.half-row {
    width: 100%;
  }

  body#admin section.admin-section canvas {
    width: 100% !important;
  }

  body#admin section.admin-section#locations-section #new-members-card canvas#newMemberChart {
    position: relative;
    bottom: unset;
  }

  body#admin section.admin-section#users-section span#search-user input {
    font-size: 18px;
  }

  body nav#admin-sidebar {
    width: 220px;
  }
}

@media all and (max-width: 1023px) {

  body#admin.has-sidebar #admin-header,
  body#admin-edit.has-sidebar #admin-header {
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }

  body#admin.has-sidebar #admin-header h1#restaurant-title,
  body#admin-edit.has-sidebar #admin-header h1#restaurant-title {
    width: 100%;
    margin-bottom: 20px;
  }

  body#admin section.admin-section#promotions-section .promo-container .card {
    width: 100%;
  }
}

@media all and (max-width: 900px) {
  body#admin-edit .half-row {
    width: 100%;
  }

  body#admin section.admin-section#users-section span#search-user {
    width: 100%;
  }

  body#admin section.admin-section#users-section div#user-pagination {
    width: 100%;
    text-align: left;
    margin-bottom: 20px;
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-align-items: center;
    -moz-align-items: center;
    -ms-align-items: center;
    align-items: center;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
}

@media all and (max-width: 767px) {

  body#admin,
  body#admin-edit {
    padding: 50px 30px;
  }

  body#admin #admin-header,
  body#admin-edit #admin-header {
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }

  body#admin #admin-header h1#restaurant-title,
  body#admin-edit #admin-header h1#restaurant-title {
    width: 100%;
    margin-bottom: 20px;
  }

  body#admin table:not(.ui-datepicker-calendar) tr.table-header-row th,
  body#admin-edit table:not(.ui-datepicker-calendar) tr.table-header-row th {
    padding: 10px 20px;
  }

  body#admin table:not(.ui-datepicker-calendar) tr td,
  body#admin-edit table:not(.ui-datepicker-calendar) tr td {
    padding: 10px 20px;
  }

  body#admin section.admin-section#users-section span#search-user {
    text-align: center;
  }

  body#admin section.admin-section#users-section span#search-user input {
    width: 85%;
  }

  body#admin-edit #add-locations-card form>span {
    width: 47%;
  }

  body nav#admin-sidebar {
    /* position: absolute; */
    left: 100%;
    -webkit-box-ordinal-group: 2;
    -moz-box-ordinal-group: 2;
    -ms-flex-order: 2;
    -webkit-order: 2;
    order: 2;
  }

  body nav#admin-sidebar * {
    -webkit-transition: all 0.2s ease-in-out;
    -moz-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    -ms-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
  }

  body nav#admin-sidebar.open #sidebar-wrapper {
    -webkit-transform: none;
    -moz-transform: none;
    -ms-transform: none;
    transform: none;
  }

  body nav#admin-sidebar #sidebar-wrapper {
    left: unset;
    right: 0;
    -webkit-transform: translateX(220px);
    -moz-transform: translateX(220px);
    -ms-transform: translateX(220px);
    transform: translateX(220px);
  }

  body#admin.has-sidebar #admin-dashboard {
    width: 100%;
    -webkit-transition: all 0.2s ease-in-out;
    -moz-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    -ms-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
  }

  body#admin.has-sidebar #admin-dashboard.open {
    -webkit-transform: translate(-220px);
    -moz-transform: translate(-220px);
    -ms-transform: translate(-220px);
    transform: translate(-220px);
  }
}

@media all and (max-width: 500px) {

  body#admin,
  body#admin-edit {
    padding: 50px 20px;
  }

  body#admin section.admin-section#promotions-section #promo-control-panel,
  body#admin-edit section.admin-section#promotions-section #promo-control-panel {
    -webkit-align-items: baseline;
    -moz-align-items: baseline;
    -ms-align-items: baseline;
    align-items: baseline;
    margin-bottom: 10px;
  }

  body#admin section.admin-section#promotions-section #promo-control-panel>span,
  body#admin-edit section.admin-section#promotions-section #promo-control-panel>span {
    max-width: 210px;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-justify-content: flex-end;
    justify-content: flex-end;
  }

  body#admin section.admin-section#promotions-section #promo-control-panel button,
  body#admin-edit section.admin-section#promotions-section #promo-control-panel button {
    margin: 0;
    margin-bottom: 10px;
    -webkit-justify-content: center;
    justify-content: center;
  }

  body#privacy-policy .full-page-container,
  body#terms-of-service .full-page-container {
    padding: 40px 20px;
  }

  body#admin-edit #add-locations-card form>span {
    width: 100%;
  }
}

@media all and (max-width: 400px) {
  footer .referral-button>a {
    font-size: 13px;
  }

  footer .referral-button>a i {
    font-size: 16px !important;
  }
}

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