@import url("https://fonts.googleapis.com/css2?family=Kanit:wght@200;400;500&display=swap");
:root {
  --bg-color: #f6f9f9;
  --primary-color: #00abea;
  --light-color: #00abea;
  --dark-color: #004e69;
  --gray-color: #e7e7e7;
  --secondary-color: #ffdd17;
  --black-color: #000;
  --stroke-color: #bcbcbc;
  --text-color: #00abea;
  --clr: #222327;
}

/*:root {
  --bg-color: #f6f9f9;
  --primary-color: #009acc;
  --light-color: #00ace6;
  --dark-color: #007ba2;
  --gray-color: #e7e7e7;
  --secondary-color: #ffdd17;
  --black-color: #000;
  --stroke-color: #bcbcbc;
  --text-color: #000;
  --clr: #222327;
}*/
/*
@font-face {
  font-family: 'Noto Sans Thai';
  src: url('../fonts/NotoSansThai-SemiBold.woff2') format('woff2'),
  url('../fonts/NotoSansThai-SemiBold.woff') format('woff'),
  url('../fonts/NotoSansThai-SemiBold.ttf') format('truetype');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Noto Sans Thai';
  src: url('../fonts/NotoSansThai-Bold.woff2') format('woff2'),
  url('../fonts/NotoSansThai-Bold.woff') format('woff'),
  url('../fonts/NotoSansThai-Bold.ttf') format('truetype');
  font-weight: bold;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Myriad Pro';
  src: url('../fonts/MyriadPro-Regular.woff2') format('woff2'),
  url('../fonts/MyriadPro-Regular.woff') format('woff'),
  url('../fonts/MyriadPro-Regular.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}


@font-face {
  font-family: 'Noto Sans Thai';
  src: url('../fonts/NotoSansThai-Regular.woff2') format('woff2'),
  url('../fonts/NotoSansThai-Regular.woff') format('woff'),
  url('../fonts/NotoSansThai-Regular.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
*/
* {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  touch-action: manipulation;
  max-height: 1000000px;
  -webkit-text-size-adjust: none;
  text-size-adjust: none;
}

a {
  text-decoration: none;
}
a:hover {
  text-decoration: none;
}

html {
  -webkit-text-size-adjust: none;
  -moz-text-size-adjust: none;
  -ms-text-size-adjust: none;
  text-size-adjust: none;
}

body {
  -webkit-text-size-adjust: none;
  -moz-text-size-adjust: none;
  -ms-text-size-adjust: none;
  text-size-adjust: none;
  font-size: 16px;
  font-family: "Kanit", sans-serif;
  font-weight: normal;
  position: relative;
  background: #ffffff;
  padding: 0;
  margin: 0;
}

.gd {
  background: var(--light-color);
  background: -moz-linear-gradient(top, var(--light-color) 0%, var(--dark-color) 100%);
  background: -webkit-linear-gradient(top, var(--light-color) 0%, var(--dark-color) 100%);
  background: linear-gradient(to bottom, var(--light-color) 0%, var(--dark-color) 100%);
}

#top-overlay {
  position: fixed;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  height: 10px;
  z-index: 11;
  background: -moz-linear-gradient(top, rgb(233, 217, 205) 0%, rgba(255, 255, 255, 0) 100%);
  background: -webkit-linear-gradient(top, rgb(233, 217, 205) 0%, rgba(255, 255, 255, 0) 100%);
  background: linear-gradient(to bottom, rgb(233, 217, 205) 0%, rgba(255, 255, 255, 0) 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#e9d9cd", endColorstr="#00ffffff", GradientType=0);
  max-width: 768px;
}

#app {
  padding: 0;
  min-height: 100vh;
  position: relative;
  max-width: 768px;
  margin: 0 auto;
  background: var(--bg-color);
  overflow: hidden;
  -webkit-box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.5);
  box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.5);
  /*

  &::before {
    opacity: 1;
    content: '';
    display: block;
    width: 200px;
    height: 200px;
    background: url('../images/bg-1.svg') top center no-repeat;
    background-size: cover;
    position: absolute;
    z-index: 0;
    top: 250px;
    left: -100px;
  }

  &::after {
    opacity: 1;
    content: '';
    display: block;
    width: 200px;
    height: 160px;
    background: url('../images/bg-2.svg') top center no-repeat;
    background-size: cover;
    position: absolute;
    z-index: 0;
    top: 300px;
    right: -120px;
  }
  */
}
#app.no-bg::before, #app.no-bg::after {
  display: none;
}

.container-custom {
  padding-top: 10px;
  max-width: 720px;
  margin: 0 auto;
  min-width: 320px;
  height: calc(100vh - 80px);
  overflow-x: hidden;
  overflow-y: auto;
  padding-bottom: 30px;
  z-index: 8;
}
.container-custom.full-h {
  height: 100vh;
}
.container-custom.page {
  height: calc(100vh - 70px);
}

.lds-roller {
  display: inline-block;
  position: absolute;
  width: 80px;
  height: 80px;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
}

.lds-roller div {
  animation: lds-roller 1.2s cubic-bezier(0.5, 0, 0.5, 1) infinite;
  transform-origin: 40px 40px;
}

.lds-roller div:after {
  content: " ";
  display: block;
  position: absolute;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #ffffff;
  margin: -4px 0 0 -4px;
}

.lds-roller div:nth-child(1) {
  animation-delay: -0.036s;
}

.lds-roller div:nth-child(1):after {
  top: 63px;
  left: 63px;
}

.lds-roller div:nth-child(2) {
  animation-delay: -0.072s;
}

.lds-roller div:nth-child(2):after {
  top: 68px;
  left: 56px;
}

.lds-roller div:nth-child(3) {
  animation-delay: -0.108s;
}

.lds-roller div:nth-child(3):after {
  top: 71px;
  left: 48px;
}

.lds-roller div:nth-child(4) {
  animation-delay: -0.144s;
}

.lds-roller div:nth-child(4):after {
  top: 72px;
  left: 40px;
}

.lds-roller div:nth-child(5) {
  animation-delay: -0.18s;
}

.lds-roller div:nth-child(5):after {
  top: 71px;
  left: 32px;
}

.lds-roller div:nth-child(6) {
  animation-delay: -0.216s;
}

.lds-roller div:nth-child(6):after {
  top: 68px;
  left: 24px;
}

.lds-roller div:nth-child(7) {
  animation-delay: -0.252s;
}

.lds-roller div:nth-child(7):after {
  top: 63px;
  left: 17px;
}

.lds-roller div:nth-child(8) {
  animation-delay: -0.288s;
}

.lds-roller div:nth-child(8):after {
  top: 56px;
  left: 12px;
}

@keyframes lds-roller {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
#loading {
  position: fixed;
  top: 50%;
  left: 50%;
  width: 100px;
  height: 100px;
  z-index: 2;
  background: rgba(0, 0, 0, 0.5);
  border-radius: 12px;
  transform: translateX(-50%) translateY(-50%);
}

.custom-date {
  border-radius: 30px;
  background: var(--gray-color);
  height: 40px;
}

.custom-button {
  padding-left: 30px;
  padding-right: 30px;
  text-align: center;
  height: 40px;
  line-height: 40px;
  border: none;
  cursor: pointer;
  background: var(--light-color);
  background: -moz-linear-gradient(top, var(--light-color) 0%, var(--dark-color) 100%);
  background: -webkit-linear-gradient(top, var(--light-color) 0%, var(--dark-color) 100%);
  background: linear-gradient(to bottom, var(--light-color) 0%, var(--dark-color) 100%);
  color: #ffffff;
  border-radius: 20px;
  font-weight: normal;
  font-family: "Kanit", sans-serif;
  font-size: 16px;
  margin-left: auto;
  margin-right: auto;
  display: block;
  text-transform: uppercase;
}
.custom-button.end {
  max-width: 120px;
}
.custom-button:disabled {
  cursor: not-allowed;
  filter: grayscale(1);
  opacity: 0.7;
}
.custom-button.outline {
  background: #ffffff;
  color: var(--text-color);
  border: 1px solid var(--text-color);
  height: 38px;
  line-height: 36px;
}

#language {
  width: 70px;
  height: 30px;
  -webkit-box-shadow: inset 0 0 5px 5px rgba(0, 0, 0, 0.1);
  box-shadow: inset 0 0 5px 5px rgba(0, 0, 0, 0.1);
  border-radius: 20px;
  background: #ffffff;
  cursor: pointer;
  overflow: hidden;
  margin-left: auto;
  margin-right: 10px;
}
#language.left {
  margin-left: 10px;
}
#language div {
  text-align: center;
  display: flex;
  justify-content: space-between;
  align-items: center;
  justify-items: center;
  height: 30px;
  margin: 0 12px;
}
#language div img {
  width: 20px;
  height: 20px;
  display: block;
}
#language div span {
  font-weight: 500;
  display: block;
  font-size: 16px;
  align-self: center;
  padding-top: 2px;
}

#slider {
  position: relative;
  z-index: 5;
}
#slider .slick-list {
  border-radius: 14px;
  background: #ffffff;
  overflow: hidden;
}
#slider img {
  width: 100%;
  max-width: 100%;
  height: auto;
}
#slider .slick-dots {
  display: flex;
  height: 5px;
  background: #eeeeee;
  border-radius: 3px;
  width: 140px;
  margin: 25px auto;
  justify-content: space-between;
  padding: 0;
  overflow: hidden;
}
#slider .slick-dots li {
  display: block;
  height: 5px;
  width: 100%;
  border: 0;
  font-size: 0;
  line-height: 0;
  padding: 0;
  background: #eeeeee;
  margin-left: -1px;
}
#slider .slick-dots li::after {
  content: "";
  display: block;
  background-image: linear-gradient(var(--primary-color), var(--primary-color));
  background-position: 0 100%;
  background-size: 0% 5px;
  background-repeat: no-repeat;
  width: 100%;
  height: 5px;
  transition: background-size 0.3s, background-position 0s 0.3s;
}
#slider .slick-dots li.slick-active::after {
  background-position: 100% 100%;
  background-size: 100% 5px;
}
#slider .slick-dots li button {
  display: none;
}

.navigation {
  max-width: 768px;
  width: 100%;
  height: 70px;
  background: #fff;
  position: fixed;
  display: flex;
  justify-content: center;
  align-items: center;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: 10;
}

.navigation ul {
  display: flex;
  justify-content: space-between;
  margin: 0;
  padding: 0 15px;
  width: 100%;
}

.navigation ul li {
  position: relative;
  list-style: none;
  width: 70px;
  height: 70px;
  z-index: 1;
}

.navigation ul li a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  width: 100%;
  text-align: center;
  font-weight: 500;
}

.navigation ul li a .icon {
  position: relative;
  display: block;
  line-height: 75px;
  font-size: 1.5em;
  text-align: center;
  transition: 0.5s;
}
.navigation ul li a .icon img {
  width: auto;
  height: 25px;
}
.navigation ul li a .icon.icon-coupon img {
  width: auto;
  height: 20px;
}

.navigation ul li.active a .icon {
  transform: translateY(-38px);
}
.navigation ul li.active a .icon img {
  height: 30px;
}
.navigation ul li.active a .icon.icon-coupon img {
  width: auto;
  height: 20px;
}

.navigation ul li a .text {
  position: absolute;
  color: var(--text-color);
  font-size: 12px;
  transition: 0.5s;
  line-height: 1;
  opacity: 0;
  transform: translateY(20px);
}

.navigation ul li.active a .text {
  opacity: 1;
  transform: translateY(15px);
  font-size: 16px;
  text-transform: uppercase;
  font-weight: 500;
}

.indicator {
  position: absolute;
  top: -50%;
  width: 70px;
  height: 70px;
  background: var(--primary-color);
  border-radius: 50%;
  border: 6px solid var(--bg-color);
  transition: 0.5s;
  left: 15px;
}

input[type=search], select {
  -webkit-appearance: none;
}

/* ===== Scrollbar CSS ===== */
/* Firefox */
* {
  scrollbar-width: thin;
  scrollbar-color: #b0b0b0 #ffffff;
}

/* Chrome, Edge, and Safari */
*::-webkit-scrollbar {
  width: 0px;
}

*::-webkit-scrollbar-track {
  background: #ffffff;
}

*::-webkit-scrollbar-thumb {
  background-color: #b0b0b0;
  border-radius: 10px;
  border: 0px solid #ffffff;
}

.indicator::before {
  content: "";
  position: absolute;
  top: 50%;
  left: -18px;
  width: 15px;
  height: 17px;
  background: transparent;
  border-top-right-radius: 20px;
  box-shadow: 1px -10px 0 0 var(--bg-color);
}

.indicator::after {
  content: "";
  position: absolute;
  top: 50%;
  right: -18px;
  width: 15px;
  height: 17px;
  background: transparent;
  border-top-left-radius: 20px;
  box-shadow: -1px -10px 0 0 var(--bg-color);
}

#home-button {
  position: relative;
  z-index: 2;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  justify-items: center;
}
#home-button a {
  text-decoration: none;
}
#home-button .home-button {
  width: 33.333%;
  text-align: center;
  margin-bottom: 20px;
}
#home-button .home-button .button-warp {
  text-align: center;
}
#home-button .home-button .button-circle {
  margin: 0 auto;
  background: #ffffff;
  border-radius: 50%;
  width: 60px;
  height: 60px;
  line-height: 60px;
  box-shadow: 3px 3px 5px #aca198, -3px -3px 5px var(--bg-color);
}
#home-button .home-button .button-circle img {
  width: 50%;
  height: auto;
}
#home-button .home-button .button-title {
  color: var(--text-color);
  line-height: 1.2;
  font-size: 12px;
  margin-top: 8px;
  font-weight: 500;
}
#home-button .home-button .button-sub {
  color: var(--text-color);
  line-height: 1.2;
  font-size: 10px;
}

#register-btn .button-circle {
  border: 2px solid var(--primary-color);
  width: 60px !important;
  height: 60px !important;
}
#register-btn .button-circle img {
  margin-top: -6px;
  margin-left: 6px;
}

@media all and (min-width: 321px) and (max-width: 375px) {
  #home-button .home-button .button-circle {
    width: 70px;
    height: 70px;
    line-height: 70px;
  }
  #register-btn .button-circle {
    border: 2px solid var(--primary-color);
    width: 70px !important;
    height: 70px !important;
  }
  #register-btn .button-circle img {
    margin-top: -6px;
    margin-left: 6px;
  }
}
@media all and (min-width: 376px) {
  #register-btn .button-circle {
    border: 2px solid var(--primary-color);
    width: 80px !important;
    height: 80px !important;
  }
  #register-btn .button-circle img {
    margin-top: -6px;
    margin-left: 6px;
  }
  #home-button .home-button .button-circle {
    width: 80px;
    height: 80px;
    line-height: 80px;
  }
  #home-button .home-button .button-title {
    color: var(--text-color);
    line-height: 1.2;
    font-size: 16px;
    margin-top: 8px;
    font-weight: 500;
  }
  #home-button .home-button .button-sub {
    color: var(--text-color);
    line-height: 1.2;
    font-size: 12px;
  }
}
label {
  font-size: 18px;
  display: block;
  padding-left: 10px;
}
label.text-red {
  color: var(--primary-color);
  font-weight: 500;
  font-size: 18px !important;
}

#page-section {
  border-radius: 16px;
  margin: 10px;
  position: relative;
  z-index: 2;
  padding: 10px;
  margin-top: 0;
  text-transform: uppercase;
}
#page-section #close {
  width: 40px;
  height: 40px;
  position: absolute;
  top: -20px;
  right: 10px;
  z-index: 3;
}
#page-section.no-pd {
  padding-left: 0;
  padding-right: 0;
  margin-left: 5px;
  margin-right: 5px;
}

#register-section {
  background: #ffffff;
  border-radius: 16px;
  margin: 10px;
  position: relative;
  z-index: 2;
  padding: 20px;
  text-transform: uppercase;
}
#register-section #close {
  width: 40px;
  height: 40px;
  position: absolute;
  top: -20px;
  right: 10px;
}
#register-section.no-pd {
  padding: 20px 10px;
}
#register-section .head-logo-first {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 30px;
}
#register-section .head-logo-first img {
  width: 150px;
  text-align: center;
  margin: 0 auto;
  display: block;
}
#register-section .head-logo-first div {
  text-align: right;
  font-size: 30px;
  color: var(--primary-color);
  display: block;
  font-weight: 500;
}
#register-section .head-logo {
  text-align: center;
  margin-bottom: 20px;
}
#register-section .head-logo img {
  width: 250px;
}
#register-section .head-text {
  text-align: center;
  font-size: 20px;
  margin: 0;
  font-weight: 500;
  line-height: 1.2;
}
#register-section .head-sub {
  text-align: center;
  font-size: 20px;
  color: var(--primary-color);
  margin: 0;
  font-weight: 500;
  line-height: 1.2;
}
#register-section .head-sub.text-left {
  padding-left: 10px;
  font-size: 18px;
}
#register-section .form-group {
  margin-bottom: 15px;
}
#register-section .form-custom {
  border-radius: 40px;
  background: #ffffff;
  display: block;
  width: 100%;
  height: 40px;
  font-size: 18px;
  padding-left: 20px;
  padding-right: 20px;
  border: 1px solid var(--gray-color);
  font-family: "Kanit", sans-serif;
}
#register-section .form-custom.light {
  background: #ffffff;
  line-height: 38px;
}
#register-section .form-custom::placeholder {
  color: #c1c1c1;
  font-family: "Kanit", sans-serif;
}
#register-section .form-custom:focus {
  border: 1px solid var(--primary-color);
  outline: none;
}
#register-section .form-custom:disabled {
  background: #eeeeee;
}
#register-section .form-custom:disabled::placeholder {
  color: #dddddd;
}

.modal-header {
  background: var(--light-color);
  background: -moz-linear-gradient(top, var(--light-color) 0%, var(--dark-color) 100%);
  background: -webkit-linear-gradient(top, var(--light-color) 0%, var(--dark-color) 100%);
  background: linear-gradient(to bottom, var(--light-color) 0%, var(--dark-color) 100%);
  color: white;
  padding: 14px;
  border-radius: 12px 12px 0 0;
  overflow: hidden;
}

.modal-content {
  border-radius: 12px;
  background: transparent;
}

.modal-body {
  background: #ffffff;
  border-radius: 0 0 12px 12px;
}

.close {
  color: white;
}

.custom-checkbox input {
  opacity: 0;
  position: absolute;
}
.custom-checkbox input ~ label {
  color: var(--text-color);
  font-size: 16px;
  font-weight: 500;
  cursor: pointer;
  margin-bottom: 0;
}
.custom-checkbox input ~ label::before {
  content: "";
  display: block;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 1px solid #cccccc;
  float: left;
  margin-right: 8px;
  margin-top: 3px;
}
.custom-checkbox input:disabled ~ label::before {
  background: #bcbcbc;
}
.custom-checkbox input:checked ~ label::before {
  background: var(--light-color);
  background: -moz-linear-gradient(top, var(--light-color) 0%, var(--dark-color) 100%);
  background: -webkit-linear-gradient(top, var(--light-color) 0%, var(--dark-color) 100%);
  background: linear-gradient(to bottom, var(--light-color) 0%, var(--dark-color) 100%);
}

.col-6.custom-px-5 {
  padding-left: 5px;
  padding-right: 5px;
}

.custom-option input {
  opacity: 0;
  position: absolute;
}
.custom-option input ~ label {
  color: var(--text-color);
  font-weight: 400;
  cursor: pointer;
  line-height: 1;
  background: var(--gray-color);
  color: var(--text-color);
  text-align: center;
  font-size: 18px;
  border-radius: 50px;
  margin-bottom: 15px;
  padding: 5px 20px;
  min-height: 40px;
  display: flex;
  justify-content: center;
  justify-items: center;
  align-items: center;
  line-height: 1.3;
}
.custom-option input:checked ~ label {
  background: var(--secondary-color);
}
.custom-option input:disabled ~ label {
  background: #eeeeee;
  color: #c4c4c4;
}

#term-content {
  margin-top: 20px;
  padding: 20px;
  font-size: 12px;
  line-height: 1.2;
  background: var(--gray-color);
  border-radius: 12px;
  overflow-x: hidden;
}
#term-content ul {
  margin-left: 0;
  padding-left: 0;
  list-style: none;
}

.active-code {
  font-size: 24px;
  font-weight: 500;
  max-width: 70%;
}

#footer-register {
  line-height: 1.2;
  text-align: center;
  font-size: 20px;
  margin-top: 20px;
}
#footer-register small {
  display: block;
  color: var(--primary-color);
  font-size: 16px;
}

#qrcode {
  width: 70%;
  margin-top: 25px;
  margin-left: auto;
  margin-right: auto;
}
#qrcode img {
  max-width: 100%;
  width: 100%;
  height: auto;
  display: block;
}

#error-page {
  position: relative;
  z-index: 3;
  background: #ffffff;
  padding: 20px;
  border-radius: 12px;
  margin: 10px;
  min-height: calc(100vh - 250px);
  display: flex;
}
#error-page img {
  width: 70%;
  display: block;
  margin: 0 auto;
  height: auto;
}

.b-form-btn-label-control.form-control > .dropdown-menu {
  position: fixed !important;
  will-change: transform;
  top: 50% !important;
  left: 50% !important;
  transform: translateX(-50%) translateY(-50%) !important;
}

.select2-container--default .select2-selection--single {
  background: none !important;
  border: 0 !important;
  height: 40px !important;
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
  top: 6px !important;
}

.select2-hidden-accessible {
  width: 100% !important;
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
  line-height: 37px !important;
}

.activity-card {
  background: var(--text-color);
  border-radius: 12px;
  margin-bottom: 25px;
  overflow: hidden;
  padding: 5px;
}
.activity-card img {
  width: 100%;
  border-radius: 12px;
  display: block;
}
.activity-card .activity-title {
  font-size: 20px;
  margin-top: 5px;
  font-weight: 500;
  color: #fff;
  padding: 0 10px;
}
.activity-card .custom-button {
  margin-top: 10px;
  color: #ffffff;
  width: 160px;
  margin-bottom: 10px;
}

#back {
  width: 75px;
  height: 30px;
  display: block;
  position: absolute;
  left: 0;
  top: -30px;
}
#back img {
  width: 100%;
  height: auto;
}

.page-content {
  background: #ffffff;
  padding: 15px;
  border-radius: 12px;
}
.page-content img {
  width: 100%;
  border-radius: 12px;
  display: block;
}
.page-content p {
  padding: 0;
  margin: 0;
}

.page-card {
  border-radius: 12px;
  font-size: 12px;
}
.page-card.disabed {
  filter: grayscale(1);
}
.page-card h5 {
  font-size: 16px;
  font-weight: 500;
}
.page-card img {
  width: 100%;
  border-radius: 12px;
  display: block;
  position: relative;
  z-index: 2;
}
.page-card p {
  padding: 0;
  margin: 0;
}
.page-card ol, .page-card ul {
  padding-left: 10px;
}
.page-card .page-card-content {
  transform: translateY(-20px);
  z-index: 1;
  position: relative;
  padding: 30px 15px 15px 15px;
  border-radius: 0 0 12px 12px;
  background: var(--text-color);
  color: #ffffff;
  text-transform: none;
}
.page-card .page-card-content .date {
  color: #fff;
}
.page-card .page-card-content .custom-button {
  margin-top: 20px;
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  justify-items: center;
}
.page-card .page-card-content .custom-button img {
  width: 25px;
  height: 15px;
  border-radius: 0;
  margin-left: 5px;
}

#countdown {
  text-align: center;
}
#countdown strong {
  font-size: 16px;
  font-weight: 500;
}
#countdown a {
  text-align: center;
  width: 150px;
  color: #ffffff;
  display: block;
}

#filter-activity {
  margin: 0 auto;
  display: flex;
  justify-content: center;
  border-radius: 30px;
  overflow: hidden;
  position: relative;
  background: var(--gray-color);
  line-height: 1.2;
}
#filter-activity::after {
  position: absolute;
  content: "";
  display: block;
  left: 0;
  top: 0;
  width: 33.333%;
  height: 40px;
  background: var(--light-color);
  background: -moz-linear-gradient(left, var(--light-color) 0%, var(--dark-color) 100%);
  background: -webkit-linear-gradient(left, var(--light-color) 0%, var(--dark-color) 100%);
  background: linear-gradient(to right, var(--light-color) 0%, var(--dark-color) 100%);
  z-index: 1;
  transition: 0.3s;
}
#filter-activity.active-1::after {
  left: 33.333%;
}
#filter-activity.active-2::after {
  left: 67%;
}
#filter-activity button {
  position: relative;
  z-index: 2;
  height: 40px;
  background: transparent;
  border: none;
  display: block;
  width: 100%;
  cursor: pointer;
  font-weight: 500;
  color: var(--text-color);
  transition: 0.3s;
  font-size: 11px;
  /*   &:first-child{
       border-radius: 30px 0 0 30px;
     }
     &:last-child{
       border-radius: 0 30px 30px 0;
     }
     &.active{
       color: #ffffff;
       background: var(--light-color);
       background: -moz-linear-gradient(left, var(--light-color) 0%, var(--dark-color) 100%);
       background: -webkit-linear-gradient(left, var(--light-color) 0%, var(--dark-color) 100%);
       background: linear-gradient(to right, var(--light-color) 0%, var(--dark-color) 100%);
     }*/
}
#filter-activity button.activity, #filter-activity button.special, #filter-activity button.agenda {
  color: #ffffff;
}

#activity-lists {
  margin-top: 20px;
}
#activity-lists .activity {
  border: 1px solid #cccccc;
  background: #ffffff;
  border-radius: 12px;
  overflow: hidden;
  display: flex;
  align-items: center;
  padding: 10px;
  margin-bottom: 20px;
  position: relative;
}
#activity-lists .activity::before, #activity-lists .activity::after {
  content: "";
  width: 20px;
  height: 20px;
  background: var(--bg-color);
  border-radius: 50%;
  position: absolute;
  top: 20%;
}
#activity-lists .activity::before {
  left: -10px;
}
#activity-lists .activity::after {
  right: -10px;
}
#activity-lists .activity .thumb {
  width: 60px;
  height: 60px;
  border: 1px solid #eeeeee;
  margin: 10px;
  overflow: hidden;
}
#activity-lists .activity .thumb img {
  width: 100%;
  height: auto;
}
#activity-lists .activity .line {
  height: 10px;
  display: block;
  background: var(--light-color);
  position: absolute;
  width: 100%;
  left: 0;
  bottom: 0;
}
#activity-lists .activity .description {
  width: 100%;
  padding-bottom: 5px;
  padding-top: 5px;
}
#activity-lists .activity .description .title {
  color: #000000;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.3;
}
#activity-lists .activity .description .detail {
  font-size: 9px;
  color: #000000;
  line-height: 1.2;
  margin-top: 4px;
}
#activity-lists .activity .description .date {
  font-size: 16px;
  color: #dc3545;
  line-height: 1.2;
  margin-top: 4px;
  font-weight: 500;
}
#activity-lists .activity .description .date.last {
  margin-top: 0;
}
#activity-lists .activity .dot {
  width: 1.3px;
  height: 100%;
  position: absolute;
  top: 0;
  right: 95px;
  background: url("../images/line.svg") top center repeat-y;
}
#activity-lists .activity .link {
  float: right;
  margin-top: 5px;
}
#activity-lists .activity .link span {
  color: #ffffff;
  font-size: 10px;
  font-weight: 500;
  display: block;
  margin-bottom: 2px;
  margin-top: -1px;
}
#activity-lists .activity .link button {
  display: block;
  background: var(--light-color) !important;
  background: -moz-linear-gradient(top, var(--light-color) 0%, var(--dark-color) 100%) !important;
  background: -webkit-linear-gradient(top, var(--light-color) 0%, var(--dark-color) 100%) !important;
  background: linear-gradient(to bottom, var(--light-color) 0%, var(--dark-color) 100%) !important;
  height: 30px;
  color: #fff;
  text-align: center;
  border-radius: 15px;
  width: 100px;
  line-height: 25px;
  font-size: 11px;
  font-weight: 500;
  border: none;
}
#activity-lists .activity .link button.full {
  cursor: not-allowed;
  background: #222327 !important;
}
#activity-lists .activity .link button:disabled {
  cursor: not-allowed;
  background: #969696 !important;
}
#activity-lists .activity-photo {
  background: #ffffff;
  border-radius: 12px;
  overflow: hidden;
  margin-bottom: 10px;
  padding: 5px;
}
#activity-lists .activity-photo img {
  width: 100%;
  display: block;
  border-radius: 12px;
  overflow: hidden;
}

#agenda-tab {
  display: flex;
  justify-items: center;
  justify-content: space-between;
  align-items: center;
  margin-top: 10px;
  margin-bottom: -10px;
  border-radius: 20px;
  overflow: hidden;
  position: relative;
  background: #eeeeee;
  height: 30px;
  width: 100%;
}
#agenda-tab::after {
  position: absolute;
  content: "";
  display: block;
  left: 0;
  top: 0;
  width: 33.333%;
  height: 30px;
  background: var(--light-color);
  background: -moz-linear-gradient(left, var(--light-color) 0%, var(--dark-color) 100%);
  background: -webkit-linear-gradient(left, var(--light-color) 0%, var(--dark-color) 100%);
  background: linear-gradient(to right, var(--light-color) 0%, var(--dark-color) 100%);
  z-index: 1;
  transition: 0.3s;
}
#agenda-tab.active-2::after {
  left: 33.333%;
}
#agenda-tab.active-3::after {
  left: 67%;
}
#agenda-tab div {
  cursor: pointer;
  width: 50%;
  text-align: center;
  color: var(--text-color);
  height: 30px;
  line-height: 30px;
  font-size: 16px;
  font-weight: 500;
  position: relative;
  z-index: 2;
  transition: 0.3s;
}
#agenda-tab div.active {
  color: #ffffff;
}

@media all and (max-width: 640px) {
  .b-rsm {
    display: block;
  }
  .b-sm {
    display: block;
    max-width: 100%;
  }
}
.v-drumroll-picker__input {
  background: transparent;
  border: none;
  box-shadow: none !important;
  padding: 6px !important;
}

.v-drumroll-picker .v-drumroll-picker__button {
  background: var(--light-color) !important;
  background: -moz-linear-gradient(top, var(--light-color) 0%, var(--dark-color) 100%) !important;
  background: -webkit-linear-gradient(top, var(--light-color) 0%, var(--dark-color) 100%) !important;
  background: linear-gradient(to bottom, var(--light-color) 0%, var(--dark-color) 100%) !important;
  border-radius: 30px !important;
}

.v-drumroll-picker .-selected {
  color: var(--primary-color) !important;
}

.v-drumroll-picker__container .vue-scroll-picker-item {
  font-size: 25px;
}

.v-drumroll-picker__divider {
  font-size: 25px;
  padding: 5px 1px 2px !important;
}

.disabled {
  filter: grayscale(1);
  cursor: not-allowed;
}

.layout-enter-active,
.page-enter-active,
.layout-leave-active,
.page-leave-active {
  transition: opacity 400ms, transform 400ms;
}

.layout-enter,
.page-enter {
  opacity: 0;
  transform: translate3d(0, 20px, 0);
}

.layout-enter-to,
.page-enter-to {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

.layout-leave,
.page-leave {
  opacity: 1;
}

.layout-leave-to,
.page-leave-to {
  opacity: 0;
}

#search-box {
  display: flex;
  justify-content: space-between;
  justify-items: center;
  align-items: center;
}
#search-box .custom-button {
  color: #ffffff;
  padding-left: 5px;
  padding-right: 5px;
  width: 155px;
}
#search-box .custom-button img {
  display: inline-block;
  width: auto;
  height: 20px;
  margin-left: 5px;
}

#search-group {
  width: calc(100% - 65px);
  padding-right: 10px;
  position: relative;
}
#search-group input {
  border-radius: 40px;
  background: var(--gray-color);
  display: block;
  width: 100%;
  height: 40px;
  font-size: 16px;
  padding-left: 20px;
  border: 1px solid var(--gray-color);
  padding-right: 50px;
  color: var(--text-color);
}
#search-group input:focus, #search-group input:active {
  outline: none;
}
#search-group button {
  position: absolute;
  right: 15px;
  top: 0;
  width: 40px;
  height: 40px;
  background: none;
  cursor: pointer;
  border: none;
  line-height: 35px;
}
#search-group button img {
  width: auto;
  height: 15px;
}

#zone-box {
  margin-top: 20px;
}
#zone-box h4 {
  font-weight: normal;
  color: var(--text-color);
  font-size: 16px;
  padding-left: 20px;
}
#zone-box ul {
  list-style: none;
  padding-left: 0;
  margin-bottom: 5px;
}
#zone-box ul li {
  display: inline-block;
  color: #ffffff;
  background: #e7b559;
  cursor: pointer;
  border-radius: 15px;
  font-size: 16px;
  font-weight: normal;
  padding: 2px 15px;
  margin-bottom: 5px;
  margin-right: 5px;
}
#zone-box ul li.active {
  background: var(--light-color) !important;
  background: -moz-linear-gradient(top, var(--light-color) 0%, var(--dark-color) 100%) !important;
  background: -webkit-linear-gradient(top, var(--light-color) 0%, var(--dark-color) 100%) !important;
  background: linear-gradient(to bottom, var(--light-color) 0%, var(--dark-color) 100%) !important;
}

#big-zone {
  display: flex;
  justify-content: space-between;
  justify-items: center;
}
#big-zone .big-zone {
  padding: 5px;
  cursor: pointer;
  filter: grayscale(1);
}
#big-zone .big-zone .icon-zone {
  text-align: center;
}
#big-zone .big-zone .icon-zone img {
  width: 100%;
  max-width: 70px;
}
#big-zone .big-zone .title-zone {
  margin-top: 7px;
  text-align: center;
  color: var(--text-color);
  font-size: 12px;
  line-height: 1.2;
}
#big-zone .big-zone.active {
  filter: grayscale(0);
}

#booth-box {
  display: flex;
  justify-content: space-between;
  justify-items: center;
  flex-wrap: wrap;
  margin-top: 20px;
}
#booth-box .booth-item {
  width: 50%;
  padding: 5px;
}
#booth-box .booth-item a {
  display: block;
  background: #ffffff;
  border-radius: 10px;
  padding: 5px;
  color: #ffffff;
}
#booth-box .booth-item a img {
  width: 100%;
  height: auto;
  border-radius: 10px;
  object-fit: cover;
}
#booth-box .booth-item a .booth-thumb {
  overflow: hidden;
}
#booth-box .booth-item a .booth-title {
  color: var(--primary-color);
  line-height: 1;
  font-size: 16px;
  font-weight: 500;
  margin-top: 5px;
}
#booth-box .booth-item a .booth-zone {
  font-size: 10px;
  line-height: 1;
  color: #969696;
  margin-top: 5px;
}
#booth-box .booth-item a .booth-detail {
  color: var(--text-color);
  font-size: 10px;
  margin-top: 5px;
  line-height: 1.2;
}
#booth-box .booth-item a .booth-badge {
  margin-top: 5px;
}
#booth-box .booth-item a .booth-badge div {
  display: inline-block;
  margin-right: 2px;
  background: var(--primary-color);
  color: #ffffff;
  font-size: 10px;
  border-radius: 20px;
  padding: 2px 10px;
}

.booth-info {
  background: var(--text-color);
  color: #ffffff;
  padding: 20px;
}
.booth-info .booth-title {
  font-weight: 500;
  font-size: 16px;
  line-height: 1.2;
}
.booth-info .booth-detail {
  margin-top: 10px;
  font-size: 16px;
  line-height: 1.2;
  margin-bottom: 10px;
}
.booth-info .booth-data {
  font-size: 16px;
  display: flex;
}
.booth-info .booth-data span {
  font-weight: 500;
}
.booth-info .booth-data label {
  width: 100px;
  padding: 0;
  font-weight: normal;
}

#booth-map-button {
  margin-top: 20px;
}
#booth-map-button .custom-button {
  color: #ffffff;
  padding-left: 5px;
  padding-right: 5px;
  width: 200px;
}
#booth-map-button .custom-button img {
  display: inline-block;
  width: auto;
  height: 20px;
  margin-left: 5px;
}

#vote-panel, #vote-success {
  background: #ffffff;
  border-radius: 12px;
}
#vote-panel a, #vote-success a {
  color: #ffffff;
}
#vote-panel img, #vote-success img {
  width: 60px;
  display: block;
  margin: 0 auto;
}
#vote-panel h3, #vote-success h3 {
  font-size: 16px;
  text-align: center;
  margin-bottom: 0;
  margin-top: 0;
  color: var(--text-color);
  line-height: 1.1;
}
#vote-panel h2, #vote-success h2 {
  font-size: 18px;
  text-align: center;
  margin-top: 0;
  margin-bottom: 0;
  color: var(--primary-color);
  line-height: 1.1;
}
#vote-panel h4, #vote-success h4 {
  font-size: 16px;
  text-align: center;
  color: var(--primary-color);
  margin-top: 10px;
  line-height: 1.1;
}

#mascot-lists {
  display: flex;
  flex-wrap: wrap;
  justify-items: center;
  align-items: center;
  justify-content: space-between;
  margin-top: 20px;
}
#mascot-lists .mascot-item {
  width: 50%;
  padding: 5px;
}
#mascot-lists .mascot-item input {
  opacity: 0;
  position: absolute;
}
#mascot-lists .mascot-item input:checked ~ label {
  background: var(--primary-color);
  color: #ffffff;
}
#mascot-lists .mascot-item input:disabled ~ label {
  opacity: 0.5;
  cursor: auto;
}
#mascot-lists .mascot-item label {
  display: flex;
  background: var(--gray-color);
  width: 100%;
  height: 47px;
  text-align: center;
  border-radius: 40px;
  cursor: pointer;
  flex-wrap: wrap;
  justify-items: center;
  align-items: center;
  padding: 10px 0;
  text-transform: uppercase;
}
#mascot-lists .mascot-item label strong {
  display: block;
  width: 100%;
  padding: 0;
  margin: 0;
  line-height: 1;
  font-weight: 500;
}
#mascot-lists .mascot-item label small {
  display: block;
  width: 100%;
  padding: 0;
  margin: 2px 0 0 0;
  line-height: 1;
}

#mascot-score {
  margin-top: 30px;
}
#mascot-score .item-score {
  position: relative;
  height: 30px;
  display: flex;
  justify-content: center;
  justify-items: center;
  align-items: center;
  margin-bottom: 10px;
}
#mascot-score .item-score:before {
  background: var(--gray-color);
  content: "";
  display: block;
  position: absolute;
  width: calc(100% - 15px);
  left: 15px;
  height: 30px;
  z-index: 1;
  border-radius: 20px;
}
#mascot-score .item-score .no {
  position: relative;
  z-index: 2;
  width: 26px;
  height: 26px;
  color: #ffffff;
  text-align: center;
  line-height: 26px;
  font-size: 12px;
  font-weight: 500;
  background: var(--light-color);
  background: -moz-linear-gradient(top, var(--light-color) 0%, var(--dark-color) 100%);
  background: -webkit-linear-gradient(top, var(--light-color) 0%, var(--dark-color) 100%);
  background: linear-gradient(to bottom, var(--light-color) 0%, var(--dark-color) 100%);
  border-radius: 50%;
}
#mascot-score .item-score .name {
  position: relative;
  z-index: 2;
  font-size: 12px;
  padding-left: 10px;
  width: calc(100% - 110px);
}
#mascot-score .item-score .name strong {
  font-weight: 500;
}
#mascot-score .item-score .score {
  position: relative;
  z-index: 2;
  font-size: 16px;
  height: 30px;
  color: #ffffff;
  text-align: center;
  line-height: 30px;
  background: var(--light-color);
  background: -moz-linear-gradient(top, var(--light-color) 0%, var(--dark-color) 100%);
  background: -webkit-linear-gradient(top, var(--light-color) 0%, var(--dark-color) 100%);
  background: linear-gradient(to bottom, var(--light-color) 0%, var(--dark-color) 100%);
  border-radius: 20px;
  width: 80px;
}
#mascot-score a {
  color: #ffffff;
}

.flex {
  display: flex;
}

#line-login {
  width: 300px;
  margin: 0 auto;
}
#line-login h3 {
  font-size: 15px;
}
#line-login img {
  width: 250px;
  margin: 20px;
}
#line-login #login-pc {
  border: 1px solid green;
  border-radius: 6px;
  padding: 5px;
  color: #ffffff;
  background: green;
}
#line-login #login-pc a {
  color: #ffffff;
}
#line-login #login-mobile {
  border: 1px solid green;
  border-radius: 6px;
  padding: 5px;
  color: #ffffff;
  background: green;
}
#line-login #login-mobile a {
  color: #ffffff;
}

@media screen and (min-width: 768px) {
  .show-mobile {
    display: none;
  }
  .show-pc {
    display: block;
  }
}
@media screen and (max-width: 767px) {
  .show-mobile {
    display: block;
  }
  .show-pc {
    display: none;
  }
}
.card-subtitle {
  font-size: 18px;
}

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

.v-drumroll-picker--dialog .v-drumroll-picker__container {
  position: fixed !important;
  top: 50% !important;
  left: 50% !important;
  transform: translateX(-50%) translateY(-50%) !important;
  border-radius: 10px !important;
  width: 300px !important;
}

.mt-0 {
  margin-top: 0;
}

.mt-1 {
  margin-top: 10px;
}

.mt-2 {
  margin-top: 20px;
}

.mt-3 {
  margin-top: 30px;
}

.mt-4 {
  margin-top: 40px;
}

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

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