:root{
  --main-color: #1c75bc;
  --main-bg-color: #FFF;
  --main-container-bg-color: #e1d4dc;
  --main-text-color: #333;
  --main-input-text-color: #717171;
  --main-grey-color: #D1D1D1;
  --main-deep-grey-color: #AAAAAA;
  --lg-red-color: #a50034;
  --header-height: 12rem;
  --main-min-width: 375px;

}

@font-face {
    font-family: MElleHK-Xbold;
    font-weight: bold;
    src: url("/fonts/MELLE-HK-XBOLD.TTF") format("truetype");
}

@font-face {
    font-family: msjhbd;
    font-weight: bold;
    src: url("/fonts/msjhbd.ttf") format("truetype");
}

@font-face {
    font-family: msjhfull;
    src: url("/fonts/msjhfull.ttf") format("truetype");
}

h1,h2,h3,h4,h5,h6 {
  font-size: inherit;
  margin-top: initial;
  margin-bottom: initial;
  font-family: inherit;
  font-weight: inherit;
  line-height: inherit;
  color: inherit;
}

body {
  /*padding-top: 5rem;*/
  /*font-family: "NeueHaasGroteskText-Regular", Airal;*/
  /*font-family: "MElleHK-Xbold", "微軟正黑體", "msjhbd", Airal;*/
  font-family: "msjhfull", "msjhbd", Airal;
  font-size: 1.5rem;
  /*font-weight: bold;*/
  background: rgb(255,255,255);
  background: linear-gradient(180deg, rgba(255,255,255,1) 10%, rgba(193,223,255,1) 100%);
  background-attachment: fixed;
  margin: 0 auto;
  padding: 0;
  color: var(--main-text-color);
  min-width: var(--main-min-width);
  /*overflow-x: hidden;*/
  /*overflow-y: scroll;*/
  height: 100vh;
  /*min-width: 1024px;*/
  max-width: 1920px;
}
body.sc {
  font-family: "微軟正黑體", "msjhbd", Airal;
  font-weight: bold;
}

button, input, optgroup, select, textarea {
  /*font-family: "NeueHaasGroteskText-Regular", Airal;*/
}

a, a:link, a:visited, a:hover, a:active{
  color: var(--main-text-color);
  text-decoration: none;
  pointer-events:auto;
}

.text_align_center {
  text-align: center;
}
.margin_left_10 {
  margin-left: 10px;
}
.color_red{
  color: red;
}


.main_container {
  width: 100%;
  /*max-width: 800px;*/
  margin: 0 auto;
  min-width: var(--main-min-width);
  position: relative;
  /*margin-bottom: 30px;*/
  /*font-size: 1rem;*/
}
.main_container img{
  width: 100%;
  max-width: 100%;
}

.content_container .mobile_menu {
  position: absolute;
  right: 20px;
  top: 15px;
  cursor: pointer;
  display: none;
}


.bottom_logo_container{
  position: absolute;
  bottom: 10px;
  left: 10px;
}
.content_container .logo_container{
  padding: 20px;
  float: left;
}
.content_container .logo_container img{
  margin-right: 20px;
  width: auto;
}
.content_container .logo_container a{

}
.content_container .logo_container .logo_small{
  max-width: 20%;
}

.content_container .lang_container{
  float: right;
  padding: 30px 20px 20px;
  /*height: 65px;*/
  font-weight: bold;
}
.content_container .lang_container .lang_btn{
  display: inline-block;
  margin-right: 10px;
  padding: 5px 10px;
  line-height: 32px;
}
.content_container .lang_container .lang_btn:nth-child(3){
  font-family: "微軟正黑體", "msjhbd", Airal;
  font-weight: bold;
}
.content_container .lang_container .lang_btn.active{
  border-radius: 100px;
  background-color: var(--main-color);
  color: #FFF;
}
.content_container .lang_container .lang_btn.active a{
  color: #FFF;
}
.content_container .lang_container .text_btn{
  display: inline-block;
  padding: 5px;
}

.content_container .main_navbar{
  clear: both;
  background-color: var(--main-color);
  color: #FFF;
  text-align: center;
  font-weight: bold;
}
.content_container .main_navbar .nav_btn{
  display: inline-block;
  padding: 10px 12px;
  line-height: 36px;
}
.content_container .main_navbar .nav_btn.active{
  background-color: #145283;
}
.content_container .main_navbar .nav_btn > a{
  display: inline-block;
  color: #FFF;
}

.content_container h2.form_title {
  text-align: center;
  margin: 20px auto;
  font-weight: bold;
}
.default_hidden {
  display: none;
}


*, *:after, *:before {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  /*font-family: "Open Sans";*/
}
/* Form Progress */
.form_progress {
  max-width: 1000px;
  margin: 20px auto;
  text-align: center;
}
.form_progress .circle,
.form_progress .bar {
  display: inline-block;
  background: #fff;
  width: 40px; height: 40px;
  border-radius: 40px;
  border: 1px solid #d5d5da;
}
.form_progress .circle{
  border: 1px solid transparent;

}
.form_progress .bar {
  position: relative;
  width: 80px;
  height: 1px;
  top: -38px;
  margin-left: -5px;
  margin-right: -5px;
  border-left: none;
  border-right: none;
  border-radius: 0;
}
.form_progress .circle .label {
  display: block;
  width: 40px;
  height: 40px;
  line-height: 37px;
  border-radius: 40px;
  margin-top: 0px;
  /* color: #b5b5ba; */
  color: #000;
  font-size: 17px;
  font-weight: bold;
}
.form_progress .circle .title {
  /*color: #b5b5ba;*/
  color: #000;
  font-size: 13px;
  line-height: 30px;
  margin-left: 0;
  white-space: nowrap;
  display: flex;
  justify-content: center;
}

.form_progress .circle.active {
  background-color: unset;
}

/* Done / Active */
.form_progress .bar.done,
.form_progress .circle.done {
  /*background: #eee;*/
}
.form_progress .bar.active {
  background: linear-gradient(to right, #EEE 40%, #FFF 60%);
}
.form_progress .circle.done .label {
  color: #000;
  /*color: #FFF;*/
  /*background: #8bc435;*/
  /*box-shadow: inset 0 0 2px rgba(0,0,0,.2);*/
}
.form_progress .circle.done .title {
  color: #444;
}
.form_progress .circle.active .label {
  color: #FFF;
  background: var(--main-color);
  /*box-shadow: inset 0 0 2px rgba(0,0,0,.2);*/
}
.form_progress .circle.active .title {
  /*color: #0c95be;*/
  color: #000;
  font-weight: bold;
}


.form_part  {
  margin: 0 auto;
  padding: 5px;
  max-width: 500px;
  padding-bottom: 20px;
}
.form_part.part1 {
  max-width:800px;
}
.form_part.part4 .confirm_title {
  font-size: 1.2rem;
  margin:10px;
}
.form_part .field_container {
  
}
.form_part .field_container > .title{
  color: #1c75bc;
  font-size: 70%;
  margin: 20px 0 5px;
}
.form_part .field_container .field{
  color: #414042;
  position: relative;
  cursor: pointer;
  border-bottom: 2px solid #1c75bc;
  font-size: 80%;
}
.form_part .field_container .two_col_field{
  display: grid;
  grid-template-columns:120px 1fr;
  font-size: 80%;
}
.form_part .field_container .three_col_field{
  display: grid;
  grid-template-columns:120px 1fr 1fr;
  font-size: 80%;
  grid-gap: 0 10px;
}

.form_part .field_container input{
  background-color: transparent;
  border: none;
  width: 100%;
  height: 100%;
  max-height: 48px;
}
.form_part .field_container input[name=vertify]{
  text-transform: uppercase;
}
.form_part .field_container input.line{
  border-bottom: 2px solid #1c75bc;

}
.form_part .field_container .field > .title{
  display: inline-block;
  padding-bottom: 10px;
  padding-right: 15px;
}
.form_part .field_container .field .arrow {
  position: absolute;
  right: 5px;
  top: 15px;
  width: 0; 
  height: 0; 
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  
  border-top: 5px solid #414042;
}
.form_part .field_container .options{
  /*margin-top: 10px;*/
  display: none;
}
.form_part .field_container .options .item{
  border-top: 2px solid #d1d3d4;
  margin-left: 10px;
  padding: 10px;

}
.form_part .field_container .field.verify_field{
  display: grid;
  grid-template-columns: 150px 30px 30px auto;
  grid-column-gap:5px;
}
.form_part .field_container .firstname_field{
  display: grid;
  grid-template-columns: 1fr 100px;
}

.form_part .next_btn {
  padding: 10px 30px;
  color: #FFF;
  background-color: #1c75bc;
  border-radius: 40px;
  width: 200px;
  margin: 0 auto;
  text-align: center;
  margin-top: 40px;
  cursor: pointer;
  display: block;
  border: none;
  font-weight: bold;
}
.form_part.part2 .next_btn {
  margin-top: 20px;
}
.form_part .next_btn.disabled {
  background-color: #bcbec0;
  cursor: not-allowed;
}

.form_part .tnc_container {
  /*height: 470px;
  background-color: #FFF;
  padding: 15px 40px;
  overflow-y: scroll;*/
  padding: 10px 40px;
  font-size: 1.2rem;
  text-align: justify;
}
.form_part .tnc_container > .title{
  font-size: 1.5rem;
  font-weight: bold;
  /*margin-left: -20px;*/
  margin-bottom: 10px;
  text-align: center;
}
.form_part .tnc_container > ol{

}
.form_part .tnc_container > ol li{
  margin-bottom: 10px;
}
.form_part .tnc_checkbox{
  margin: 10px 20px;
  display: inline-block;
  font-size: 80%;
  color: #1c75bc;
  font-weight: bold;
}

.form_part .refresh_code_btn,
.form_part .read_code_btn{
  border: none;
  background: unset;
}

.form_part.part5{
  background-color: #FFF;
  padding: 20px;
}

.info_text {
  font-size: 60%;
  margin: 20px auto;
  padding: 5px 20px;
  max-width: 500px;
  line-height: 100%;
}


.popup_blocker{
  position: fixed;
  inset: 0;
  background-color: rgba(0,0,0,0.3);
  z-index: 100;
}
.popup{
  background-color: #FFF;
  box-shadow: 0 0 20px 20px #00000033;
  z-index: 105;
  width: max(340px, 80vw);
  height: 340px;
  block-size: fit-content;
  position: fixed;
  inset: 0;
  margin: auto;
  padding: 30px;
  font-size: 1.3rem;
  line-height: 110%;
}
html[lang=en] .popup{
  /*height: 370px;*/
}
.popup h3{
  font-size: 140%;
  color: red;
  text-align: center;
  margin-bottom: 20px;
  line-height: 120%;
}
html[lang=en] .popup h3{
  /*height: 370px;*/
  font-size: 120%;
}

.popup >div {
  width: 75%;
  font-size: 80%;
  margin: 0 auto 20px;
  text-align: justify;
}
.popup > .form_submit {
    padding: 10px 30px;
  color: #FFF;
  background-color: #1c75bc;
  border-radius: 40px;
  width: 200px;
  margin: 0 auto;
  text-align: center;
  margin-top: 40px;
  cursor: pointer;
  display: block;
  border: none;
  font-weight: bold;
  padding: 0.2rem 1rem;
  background-color: red;
  color: #FFF;
}

.regdone_info {
  position: relative;
  background-color: #FFF;
  width: min(620px,95%);
  padding: 20px;
  font-size: inherit;
  margin: auto;
}
.regdone_info h3{
  color: red;
  margin-bottom: 20px;
  text-align: justify;
}
.regdone_info >div {
  font-size: 80%;
  margin: 0 auto 20px;
  text-align: justify;
}

.result_container {
  position: relative;
  border-bottom: 2px solid var(--main-color);
  margin-bottom: 20px;
  padding: 10px;
  font-size: 80%;
}
.result_container .edit_btn {
  position: absolute;
  right: 10px;
  bottom: 10px;
  cursor: pointer;
}
.result_container .edit_btn > img {
  width: auto;
  max-width: 100%;
}
.result_container .title {
  color: var(--main-color);
  margin-bottom: 5px;
}
.result_container .data_container {
  /*display: grid;
  grid-template-columns: 120px 1fr;*/
  padding-right: 30px;
}
.result_container .data_container.small_font {
  /*font-size: 80%;*/
}
.result_container .data_container .fulldate_row {
  display: inline-block;
  padding-left: 10px;
}


.content_container .content {
  background-image: url(/images/bg_desktop.png);
  background-position: bottom;
  background-repeat: no-repeat;
  /*background-size: cover;*/
  /*background-size: contain;*/
  background-size: 100%;
  /*min-height: 3109px;*/
  padding-top: 40px;
  /*padding-bottom: 7%;*/
}
/*body.en .content_container .content {
  background-image: url(/images/bg_desktop.png);
}*/
.content_container .content .banner{
  width: 76%;
  margin: 0 auto 20px;
}
.content_container .content .title{
  text-align: center;
  font-size: 4rem;
  font-weight: bold;
  font-family: 'MElleHK-Xbold', Airal;
  color: #0071bc;
  margin-bottom: 60px;
  display: none;
}
.content_container .content .openday{
  width: 77%;
  margin: 0% auto 0%;
  position: relative;
}

body.en .content_container .content .openday{
  width: 76%;
  margin: 0% auto 0%;
}
.content_container .content .openday > img.desktop{
  display: block;
}
.content_container .content .openday > img.mobile{
  display: none;
}
.content_container .content .openday > .text{
  display: none;
  position: absolute;
  top: 28%;
  left: 6%;
  width: 77%;
  height: 40%;
  text-align: justify;
  letter-spacing: 0.1rem;
  line-height: 2.2rem;
  font-size: 1.4rem;
  overflow: auto;
}
body.en .content_container .content .openday > .text{
  top: 27%;
  height: 57%;
  line-height: unset;
  font-size: 1.1rem;
}
.content_container .content .openday .video {
  margin-bottom: 2rem;
}
.content_container .content .openday .video iframe{
  margin: 0 auto;
  width: 60%;
  aspect-ratio: 560 / 315;
  display: block;
}

.content_container .content .live_title{
  width: 95%;
  margin: 20px auto;
}
.content_container .content .live_details{
  width: 75%;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 10% 1fr;
  grid-row-gap: 8rem;
  font-size: 2rem;
  font-family: msjhbd, Airal;
}
.content_container .content .live_details > div:nth-child(1),
.content_container .content .live_details > div:nth-child(3){
  display: flex;
  align-items: end;
}
.content_container .content .live_details > div:nth-child(2),
.content_container .content .live_details > div:nth-child(4){
  display: flex;
  align-items: end;
  font-size: 3rem;
  color: #2e3192;

}
.content_container .content .live_details a{
  text-decoration: underline;
  color: #0071bc;
}


.event_button {
  position: relative;
  width: 90%;
  text-align: center;
  margin: 0% auto 15%;
  padding-bottom: 0.5%;
}
.event_button .v360_btn,
.event_button .video_button,
.event_button .game_button{
  position: relative;
  display: inline-block;
  width: 337px;
}
.event_button .v360_btn {
  margin-right: 70px;
}
.event_button .v360_btn .text,
.event_button .video_button .text,
.event_button .game_button .text{
  position: absolute;
  font-size: 4rem;
  color: #FFF;
  top: 20%;
  left: 16%;
  text-align: center;
  letter-spacing: 0rem;
  line-height: 6rem;
  width: 46%;
  height: 57%;
  font-size: 2.2vw;
  line-height: 2.5vw;
  display: flex;
  align-items: center;
  justify-content: center;
  display: none;
}
body.en .event_button .v360_btn .text,
body.en .event_button .video_button .text,
body.en .event_button .game_button .text{
  top: 25%;
  height: 50%;
  font-size: calc(100vw *0.025 *0.5);
  line-height: calc(100vw * 0.07 * 0.15 *1.1);
}
.event_button .video_button .text,
.event_button .game_button .text{
  line-height: calc(100vw * 0.07);
  /* line-height: 180px; */
}
body.en .event_button .video_button .text,
body.en .event_button .game_button .text{
  line-height: calc(100vw * 0.07 * 0.8);
}

.games_button {
  position: relative;
  width: 95%;
  text-align: center;
  margin: 0% auto;
  padding-bottom: 23%;
}
.games_button .game_item{
  position: relative;
  display: inline-block;
  width: 33%;

}

.content_container .content.tour_intro .openday {
  width: 77%;
  padding-left: 4%;
}
.content_container .content.tour_intro .openday img.mobile{
  display: none;
}
.content_container .content.tour_intro .openday > .text{
  top: 28%;
  left: 8%;
  width: 78%;
  height: 53%;
}

.tour_button_container {
  position: relative;
  width: 70%;
  text-align: center;
  margin: 5% auto 0;
  padding-bottom: 4%;
}
.tour_button_container .tour_btn{
  position: relative;
  display: inline-block;
  max-width: 494px;
  width: 26vw;
  margin: 5px 0 0 0;
}

.tour_button_container .tour_btn .text{
  position: absolute;
  font-size: 4rem;
  color: #FFF;
  top: 5%;
  left: 5%;
  text-align: center;
  letter-spacing: 0rem;
  line-height: 6rem;
  width: 85%;
  height: 80%;
  font-size: 2.4vw;
  line-height: 2.5vw;
  display: flex;
  align-items: center;
  justify-content: center;
  text-shadow: 0px 0px 15px #474747;
  display: none;
}





.main_container .grid_container{
  display: grid;
  /*grid-template-columns: 1.2fr 2.3fr;*/
  grid-template-columns: 1fr;
  align-items: center;
  align-content: center;
  /*height: 100px;*/
  margin: 0 2rem;
}
.main_container .grid_container .logo{
  padding: 2.2rem;
}
.main_container .grid_container .header{
  font-size: 1.4rem;
}
.main_container .grid_container .header .zh{
  font-size: 1.8rem;
}
.main_container .form_helper{
  text-align: left;
  margin-top: 2rem;
}
.main_container .form_info{
  text-align: right;
  font-size: 80%;
}
.main_container .register_table {
  width: 100%;
  margin-top: 1rem;
}
.main_container .register_table tr{
  display: grid;
  grid-template-columns: 1.2fr 2.3fr;
  align-items: start;
  align-content: center;
  margin-bottom: 0.5rem;
}
.main_container .register_table .field_title{
  text-align: left;
  padding-left: 1rem;
  padding-top: 0.3rem;
}
.main_container .register_table .field_title.more{
  padding-top: 1rem;
}
.main_container .register_table .month_title{
  text-align: center;
  font-size: 1rem;
  position: relative;
}
.main_container .register_table .bg_block {
  color: var(--main-bg-color);
  background-color: var(--main-text-color);
  padding: 1rem;
  font-size: 1rem;
  user-select: none;
  position: relative;
}
.main_container .register_table .loading {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  display: none;
  opacity: 0.6;
  background-color: #FFF;
  cursor: not-allowed;
}
.main_container .register_table input[name=datetime] {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  top: 30px;
}
.main_container .register_table .month_container {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  align-items: center;
  align-content: center;
}
.main_container .register_table .month_container > div{
  border: 1px solid #e0dfdf;
  border-collapse: collapse;
  height: 40px;
  line-height: 40px;
  cursor: pointer;
}
.main_container .register_table .month_container > div:hover{
  background-color: var(--main-grey-color);
  color: var(--main-text-color);
}
.main_container .register_table .month_container > div.active{
  background-color: var(--main-deep-grey-color);
  color: var(--main-text-color);
}
.main_container .register_table .month_container > div.disabled{
  background-color: var(--main-bg-color);
  color: var(--main-text-color);
  cursor: not-allowed;
}
.main_container .register_table .month_container > div.no_border{
  border: none;
}
.main_container .register_table .time_container {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  align-items: center;
  align-content: center;
}
.main_container .register_table .time_container > div{
  border: 1px solid #e0dfdf;
  border-collapse: collapse;
  height: 35px;
  line-height: 35px;
  cursor: pointer;
  margin: 0.2rem;
}
.main_container .register_table .time_container > div:hover{
  background-color: var(--main-grey-color);
  color: var(--main-text-color);
}
.main_container .register_table .time_container > div.active{
  background-color: var(--main-deep-grey-color);
  color: var(--main-text-color);
}
.main_container .register_table .time_container > div.disabled{
  background-color: var(--main-bg-color);
  color: var(--main-text-color);
  cursor: not-allowed;
}

.main_container .sc_info {
  font-size:  0.8rem;
  text-align: left;
}
.main_container .sc_info img{
  max-width: 250px;
}

.main_container .info_block {
  font-size:  1rem;
  text-align: left;
}
.main_container .register_table .checkbox_block label{
  font-size: 1rem;
}
.main_container .submit_block {
  text-align: left;
}
.main_container .submit_btn {
  padding: 0.2rem 1rem;
    font-size: 1rem;
  background-color: var(--main-bg-color);
  color: var(--main-text-color);
  border: 1px solid var(--main-text-color);
}
.main_container .licences_block {
  font-size:  0.8rem;
  text-align: right;
}


/* Customize the label (the container) */
.container {
  width: 100%;
  display: block;
  position: relative;
  padding-left: 35px;
  margin-bottom: 12px;
  cursor: pointer;
  font-size: 22px;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

/* Hide the browser's default checkbox */
.checkbox_block .container input {
  position: absolute;
  opacity: 0;
  cursor: pointer;
  height: 1px;
  width: 1px;
  bottom: 0;
  left: 0;
}

/* Create a custom checkbox */
.checkbox_block .checkmark {
  position: absolute;
  top: 0;
  left: 0;
  height: 25px;
  width: 25px;
  /*background-color: ;*/
  border: 2px solid var(--main-text-color);
}
.checkbox_block a {
  text-decoration: underline;
}

/* On mouse-over, add a grey background color */
.checkbox_block .container:hover input ~ .checkmark {
  background-color: #ccc;
}

/* When the checkbox is checked, add a blue background */
.checkbox_block .container input:checked ~ .checkmark {
  /*background-color: #2196F3;*/
}

/* Create the checkmark/indicator (hidden when not checked) */
.checkmark:after {
  content: "";
  position: absolute;
  display: none;
}

/* Show the checkmark when checked */
.checkbox_block .container input:checked ~ .checkmark:after {
  display: block;
}

/* Style the checkmark/indicator */
.checkbox_block .container .checkmark:after {
  left: 7px;
  top: 1px;
  width: 8px;
  height: 17px;
  border: solid #000;
  border-width: 0 3px 3px 0;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}

.main_container .completed {

}
.main_container .completed .logo {
  width: 180px;
  margin: 1rem auto;
}
.main_container .completed .title {
  font-size: 2.0rem;
}
.main_container .completed .subtitle {
  font-size: 1.3rem;
  
}
.main_container .submit_detail {
  background-color: var(--main-text-color);
  color: var(--main-bg-color);
  border-top:1rem solid var(--lg-red-color);
  border-bottom:1rem solid var(--lg-red-color);
  margin: 2rem 1rem;
  padding: 2rem 1.5rem;
  text-align: left;
  font-size: 1.2rem;
}
.main_container .submit_detail .location > span{
  font-size: 1rem;
}
.main_container .submit_detail >div{
  margin-bottom: 0.5rem;
}
.main_container .submit_detail .tag_title {
  display: inline-block;
  background-color: var(--lg-red-color);
  color: var(--main-text-color);
  margin: 2rem 1rem 1rem 0;
  padding: 0.1rem 0.5rem;
  font-size: 1.3rem;
}
.main_container .submit_info {
  color: var(--main-text-color);
  margin: 0 auto;
  padding: 0 1rem;
    font-size: 0.9rem;
    text-align: justify;
    display: inline-block;
}


.main_container .input_text{
  width: 100%;
  background-color: var(--main-bg-color);
  color: var(--main-text-color);
  border:1px solid var(--main-text-color);
  padding: 0.4rem 1rem;
  display: inline-block;
  font-size: 0.8rem;
  margin-bottom: 0.2rem;
  outline: none;
}
.main_container .input_text::placeholder {
  color: var(--main-input-text-color);
  opacity: 1; /* Firefox */
}

.main_container .input_text:-ms-input-placeholder { /* Internet Explorer 10-11 */
 color: var(--main-input-text-color);
}

.main_container .input_text::-ms-input-placeholder { /* Microsoft Edge */
 color: var(--main-input-text-color);
}
.main_container .hkid_block {
  width: 100%;
  text-align: left;
  font-size: 0.8rem;
}
.main_container .input_text.hkid{
  width:  50px;
  padding-left: 0.9rem;
  padding-right: 0.3rem;
}
.main_container .hkid_block .title{

}
.main_container .hkid_block .content{

}
.main_container .register_table label{
  display: inline-block;
  font-size: 1rem;
  text-align: left;
  position: relative;
  /*word-break: break-all;*/
}
.main_container .upload_btn{
  width: 100px;
  background-color: var(--main-bg-color);
  color: var(--main-text-color);
  border:2px solid var(--main-text-color);
  padding: 0.2rem 1rem;
  font-size: 1rem;
  display: inline-block;
  text-align: center;
}
.main_container .upload_photo{
  position: absolute;
  height: 1px;
  width: 1px;
  opacity: 0;
}




.login_btn,
.header .logout_btn{
  box-shadow:inset 0px 1px 0px 0px #ffffff;
  background:linear-gradient(to bottom, #f9f9f9 5%, #e9e9e9 100%);
  background-color:#f9f9f9;
  border-radius:6px;
  border:1px solid #dcdcdc;
  cursor:pointer;
  color:#666666;
  padding:6px 24px;
  text-decoration:none;
  text-shadow:0px 1px 0px #ffffff;
  font-family: inherit;
}
.header .logout_btn{
  position: absolute;
  right: 30px;
  bottom: -30px;
  /*background: #FFF;*/
  border: 0;
  /*box-shadow: 2px 2px 5px 0px black;*/
  pointer-events:auto;
}

.bg_track {
  background-image: url(/images/road.png?v05112321);
  background-repeat: no-repeat;
  background-size: contain;
  width: 2430px;
  height: 630px;
  top: -150px;
  right: -1600px;
  position: absolute;
  z-index: -100;
  opacity: 0.3;
  /*margin-left: 50vw;*/
}

.content_container {
  width: 100%;
  /*max-width: 1200px;*/
  margin: 0 auto;
  padding: 0;
  /*padding-top: var(--header-height);*/
}

.content_container.tnc_container{
  width: 100%;
  /*max-width: 1200px;*/
  margin: 0 auto;
  padding: 0.5rem;
  font-size: 1rem;
  text-align: left;
  /*padding-top: var(--header-height);*/
  word-break: break-all;
}
.content_container.tnc_container ol{
  margin: 0.5rem 0 1rem -1rem;
}
.content_container.tnc_container .title{
  margin: 0 0 0 1.5rem;
  font-weight: bold;
}


.content_container.login_container{
  text-align: center;
  /*background-color: var(--main-container-bg-color);*/
}
.content_container.login_container > .title{
  margin-bottom: 3rem;
}
.content_container.login_container > .title span{
  /*display: block;*/
  font-size: 2.5rem;
  /*font-weight: bold;*/
}
.content_container.login_container > .title .main{
  color: var(--main-pupple-color);
  /*padding-left: 16px;*/
  /*margin-bottom: -25px;*/
}
.content_container.login_container > .title .sub{
  color: var(--main-green-color);
}
.login_container .login_form{
  display: grid;
  width: 70vw;
  margin: 0 auto;
  max-width: 600px;
}
.login_container .field_group{
  display: grid;
  grid-template-columns: auto 40%;
  margin-bottom: 0.5rem;
}
.login_container .login_form .title{
  text-align: right;
  padding-right: 2rem;
  font-size: 1.3rem;
  line-height: 1.7rem;
}
.login_container .login_form .field{
  text-align: left;
}
.login_container .login_form .field .form_err_msg{
  font-size: 0.8rem;
  color: #F00;
}
.login_container .login_form .field input,
.login_container .login_form .field select{
  width: 100%;
  height: 2rem;
}
/* Chrome, Safari, Edge, Opera */
.login_container .login_form .field input::-webkit-outer-spin-button,
.login_container .login_form .field input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* Firefox */
.login_container .login_form .field input[type=number] {
  -moz-appearance: textfield;
}
.login_container .login_form .form_btn{
  flex: 0 0 100%;
  text-align: right;
  padding-right: 42px;
  margin-top: 1rem;
}
.login_container .login_form .error_msg{
  color: #FF0000;
  /*font-size: 70%;*/
  flex: 0 0 100%;
}


.content_container.video_list_container{
  text-align: center;
}
.content_container.video_list_container > .title{
  margin-top: 0rem;
  margin-bottom: 1rem;
}
.content_container.video_list_container > .title span{
  /*display: block;*/
  font-size: 3rem;
  /*line-height: 5rem;*/
  /*font-weight: bold;*/
}
.content_container.video_list_container > .title .main{
  color: var(--main-pupple-color);
  /*padding-left: 16px;*/
  /*margin-bottom: -25px;*/
}
.content_container.video_list_container > .title .sub{
  color: var(--main-green-color);
}
.video_list_container .video_container{
  padding: 0.5rem;
  padding-top: 2rem;
}
.video_list_container .video_item{
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  width: 100%;
  max-width: 650px;
  margin: 0 auto;
  text-align: left;
  margin-bottom: 0.5rem;
  position: relative;
}
.video_list_container .video_item .left{
  flex: 1;
}
.video_list_container .video_item .right{
  flex: 3;
  padding-left: 1rem;
}
.video_list_container .video_item .image img{
  width: 100%;
  min-width: 200px;
  box-shadow: 1px 1px 4px 0px black;
}

.video_list_container .video_container .viewcount{
  font-size: 80%;
  color: #828282;
  display: none;
}

.content_container.video_player_container{
  /*text-align: center;*/
  /*padding-top: 0;*/
  margin-top: 2rem;
}
.content_container.video_player_container > .title{
  margin-bottom: 4rem;
  /*margin-left: 9rem;*/
  text-align: center;
}
.content_container.video_player_container > .title span{
  display: block;
  font-size: 4rem;
  /*font-weight: bold;*/
}
.content_container.video_player_container > .title .main{
  color: var(--main-pupple-color);
  padding-left: 36px;
  margin-bottom: -25px;
  /*padding-top: 30px;*/
}
.content_container.video_player_container > .title .main a{
  color: var(--main-pupple-color);
  display: block;
}
.content_container.video_player_container > .title .sub{
  color: var(--main-green-color);
  display: inline-block;
}
.video_player_container .video_item{
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  width: 100%;
  /*max-width: 650px;*/
  margin: 0 auto;
  text-align: left;
  margin-bottom: 0.5rem;
  position: relative;
}
.video_player_container .video_item .left{
  flex: 3 250px;
  /*padding: 0.5rem;*/
}
.video_player_container .video_item .left iframe{
  width: 100%;
  min-width: var(--main-min-width);
  height: calc(100vw / 2);
  max-height: 402px;
  min-height: calc(375px /2);
}
.video_player_container .video_item .left .title{
  margin-bottom: 0.4rem;
  padding: 0 0.5rem;
}
.video_player_container .video_item .left .desc{
  padding: 0 0.5rem;
}
.video_player_container .video_item .left .desc a{
  color: #0275d8;
}

.video_player_container .video_item .right{
  flex: 1;
  padding: 1rem;
  margin: 0 1rem;
  background-color: #FFF;
  min-width: 350px;
  max-width: 40vw;
}
.video_player_container .video_item .image img{
  width: 100%;
  min-width: 200px;
}

.video_player_container .player_container .viewcount{
  font-size: 80%;
  color: #828282;
  display: none;
}
.video_player_container .player_container .playlist .item{
  clear: both;
}
.video_player_container .player_container .playlist .item .image{
  width: 100%;
  max-width: 150px;
  float: left;
  margin: 0 1rem 1rem 0;
}
.video_player_container .player_container .playlist .item .image img{
  width: 100%;
  min-width: initial;
}

.tos {
  max-width: 630px;
  text-align: justify;
  margin: 0 auto;
}
.tos p {
  padding: 0 0.5rem;
}

.queue_status {
  font-size: 1.1rem;
  padding: 0 1.5rem;
  padding-bottom: 2rem;
}
.queue_status .counter_text{
  font-size: 2rem;
}

.footer {
  text-align: center;
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  min-width: var(--main-min-width);
  background-color: var(--main-bg-color);
}

.jconfirm .jconfirm-box{
  background-color: var(--main-bg-color);
  color: var(--main-text-color);
  text-align: left;
  /*word-break: break-all;*/
}

.error_msg, .photo_error_msg {
  color: #F00;
  font-size: 1rem;
}

#upload_info{
  color: #FFF;
  background-color: #4db6ac;
  padding: 1rem;
}


.meter {
  height: 40px;  /* Can be anything */
  position: relative;
  margin: 10px auto 50px;
  max-width: 600px;
  background: #555;
  -moz-border-radius: 25px;
  -webkit-border-radius: 25px;
  border-radius: 25px;
  padding: 10px;
  -webkit-box-shadow: inset 0 -1px 1px rgba(255,255,255,0.3);
  -moz-box-shadow   : inset 0 -1px 1px rgba(255,255,255,0.3);
  box-shadow        : inset 0 -1px 1px rgba(255,255,255,0.3);
}
.meter > span {
  display: block;
  height: 20px;
     -webkit-border-top-right-radius: 8px;
  -webkit-border-bottom-right-radius: 8px;
         -moz-border-radius-topright: 8px;
      -moz-border-radius-bottomright: 8px;
             border-top-right-radius: 8px;
          border-bottom-right-radius: 8px;
      -webkit-border-top-left-radius: 20px;
   -webkit-border-bottom-left-radius: 20px;
          -moz-border-radius-topleft: 20px;
       -moz-border-radius-bottomleft: 20px;
              border-top-left-radius: 20px;
           border-bottom-left-radius: 20px;
  background-color: rgb(43,194,83);
  background-image: -webkit-gradient(
    linear,
    left bottom,
    left top,
    color-stop(0, rgb(43,194,83)),
    color-stop(1, rgb(84,240,84))
   );
  background-image: -moz-linear-gradient(
    center bottom,
    rgb(43,194,83) 37%,
    rgb(84,240,84) 69%
   );
  -webkit-box-shadow:
    inset 0 2px 9px  rgba(255,255,255,0.3),
    inset 0 -2px 6px rgba(0,0,0,0.4);
  -moz-box-shadow:
    inset 0 2px 9px  rgba(255,255,255,0.3),
    inset 0 -2px 6px rgba(0,0,0,0.4);
  box-shadow:
    inset 0 2px 9px  rgba(255,255,255,0.3),
    inset 0 -2px 6px rgba(0,0,0,0.4);
  position: relative;
  overflow: hidden;
}
.meter > span:after, .animate > span > span {
  content: "";
  position: absolute;
  top: 0; left: 0; bottom: 0; right: 0;
  background-image:
     -webkit-gradient(linear, 0 0, 100% 100%,
        color-stop(.25, rgba(255, 255, 255, .2)),
        color-stop(.25, transparent), color-stop(.5, transparent),
        color-stop(.5, rgba(255, 255, 255, .2)),
        color-stop(.75, rgba(255, 255, 255, .2)),
        color-stop(.75, transparent), to(transparent)
     );
  background-image:
    -moz-linear-gradient(
      -45deg,
        rgba(255, 255, 255, .2) 25%,
        transparent 25%,
        transparent 50%,
        rgba(255, 255, 255, .2) 50%,
        rgba(255, 255, 255, .2) 75%,
        transparent 75%,
        transparent
     );
  z-index: 1;
  -webkit-background-size: 50px 50px;
  -moz-background-size: 50px 50px;
  background-size: 50px 50px;
  -webkit-animation: move 2s linear infinite;
  -moz-animation: move 2s linear infinite;
     -webkit-border-top-right-radius: 8px;
  -webkit-border-bottom-right-radius: 8px;
         -moz-border-radius-topright: 8px;
      -moz-border-radius-bottomright: 8px;
             border-top-right-radius: 8px;
          border-bottom-right-radius: 8px;
      -webkit-border-top-left-radius: 20px;
   -webkit-border-bottom-left-radius: 20px;
          -moz-border-radius-topleft: 20px;
       -moz-border-radius-bottomleft: 20px;
              border-top-left-radius: 20px;
           border-bottom-left-radius: 20px;
  overflow: hidden;
}

.animate > span:after {
  display: none;
}

@-webkit-keyframes move {
    0% {
       background-position: 0 0;
    }
    100% {
       background-position: 50px 50px;
    }
}

@-moz-keyframes move {
    0% {
       background-position: 0 0;
    }
    100% {
       background-position: 50px 50px;
    }
}


.orange > span {
  background-color: #f1a165;
  background-image: -moz-linear-gradient(top, #f1a165, #f36d0a);
  background-image: -webkit-gradient(linear,left top,left bottom,color-stop(0, #f1a165),color-stop(1, #f36d0a));
  background-image: -webkit-linear-gradient(#f1a165, #f36d0a);
}

.red > span {
  background-color: #f0a3a3;
  background-image: -moz-linear-gradient(top, #f0a3a3, #f42323);
  background-image: -webkit-gradient(linear,left top,left bottom,color-stop(0, #f0a3a3),color-stop(1, #f42323));
  background-image: -webkit-linear-gradient(#f0a3a3, #f42323);
}

.nostripes > span > span, .nostripes > span:after {
  -webkit-animation: none;
  -moz-animation: none;
  background-image: none;
}







@media (min-width: 1921px) {
  .event_button .v360_btn .text, .event_button .video_button .text, .event_button .game_button .text{
    font-size: 1.8rem;
    line-height: 2.7rem;
  }
  .event_button .video_button .text, .event_button .game_button .text{
    line-height: 8.8rem;
  }
  body.en .event_button .v360_btn .text,
  body.en .event_button .video_button .text,
  body.en .event_button .game_button .text{
    font-size: 2.1rem;
    line-height: 2.1rem;
  }
  body.en .event_button .video_button .text, .event_button .game_button .text{
    line-height: 8.8rem;
  }
}
@media (max-width: 1919px) {
  .event_button .v360_btn, .event_button .video_button, .event_button .game_button{
    width:  29%;
  }
}
@media (max-width: 1024px) {
  .event_button .v360_btn .text, .event_button .video_button .text, .event_button .game_button .text{
    /*font-size: 1.5rem;*/
    /*line-height: 4.3rem;*/
  }
  .event_button .video_button .text, .event_button .game_button .text{
    /*line-height: 4.5rem;*/
  }
  body.en .event_button .v360_btn .text,
  body.en .event_button .video_button .text,
  body.en .event_button .game_button .text{
    font-size: 1.1rem;
    line-height: 1.1rem;
  }
  body.en .event_button .video_button .text, .event_button .game_button .text{
    line-height: 4.5rem;
  }
}

@media (max-width: 700px) {
  .main_container .grid_container .logo {
    
    padding: 1rem;
  }
  .main_container .grid_container .header {
    font-size: 1.2rem;
  }
  .main_container .grid_container .header .zh {
    font-size: 1.4rem;
  }
  .queue_status {
    font-size: 1rem;
    padding: 0 1rem;
  }
  .main_container .register_table .bg_block {
      padding: 0.6rem;
  }
  .main_container .register_table tr {
      grid-template-columns: 1.1fr 2.3fr;
  }
  .main_container .register_table .time_container > div {
      font-size: 0.8rem;;
  }
  .main_container .register_table .time_container {
    grid-template-columns: repeat(2, 1fr);
  }

}

@media (max-width: 900px) {
  /* mobile */
  .content_container .content {
    /*background-size: cover;*/
    background-image: url(/images/bg_index_mobile.png);
    padding-top: 30px;
    /*min-height: calc(100vh - 0px);*/
    /*min-height: 584px;*/
  }
  .content_container .logo_container {
    float: none;
  }
  .content_container .logo_container img {
    width: 25%;
  }
  .content_container .logo_container .logo_small{
    max-width: 16%;
  }
  .content_container .mobile_menu{
    display: block;
  }
  .content_container .lang_container,
  .content_container .main_navbar{
    display: none;
  }

  .content_container .lang_container{
    float: none;
    padding: 0 20px;
    height: 43px;
    text-align: center;
    font-size: 1rem;
  }
  .content_container .main_navbar{
    font-size: 1rem;
  }
  .content_container .main_navbar .nav_btn {
    display: block;
  }
  .content_container .main_navbar > span {
    display: none;
  }

  .content_container .content .banner{
    width: 100%;
  }
  .content_container .content .openday,
  body.en .content_container .content .openday{
    width: 90%;
    margin-top: 3%;
  }
  .content_container .content .openday > .text {
    font-size: 0.58rem;
    line-height: 0.7rem;
    letter-spacing: 0rem;
    top: 40%;
    left: 4%;
    width: 74%;
    height: 45%;
    text-align: justify;
  }

  body.en .content_container .content .openday > .text {
    top: 32%;
    left: 4%;
    width: 75%;
    height: 55%;
    text-align: justify;
    font-size: 1rem;
    /* line-height: 1.1rem; */
  }
  body.en .content_container .content.tour_intro .openday > .text {
    left: 4%;
    top: 26%;
    height: 65%;
  }

  .event_button .v360_btn, .event_button .video_button, .event_button .game_button{
    width: 50%;
    margin-right: 0;
  }

  .event_button .v360_btn .text,
  .event_button .video_button .text,
  .event_button .game_button .text{
    font-size: 40%;
    line-height: 100%;
    font-size: calc(100vw *0.025 *1.2);
    line-height: calc(100vw * 0.07 * 0.45);
  }

  body.en .event_button .v360_btn .text,
  body.en .event_button .video_button .text,
  body.en .event_button .game_button .text {
    font-size: calc(100vw *0.025 *1.1);
    line-height: calc(100vw * 0.07 * 0.45);
  }
  .event_button {
    padding-top: 10%;
    padding-bottom: 42%;
  }
  body.en .event_button {
    padding-top: 5%;
  }
  .event_button .v360_btn {
    /*margin-right: 10px;*/
    margin-bottom: 9%;
  }

  .games_button .game_item {
    width: 75%;
  }

  .content_container .content.tour_intro {
    /*background-size: cover;*/
    background-image: url(/images/bg_mobile.png);
    padding-top: 0;
  }

  .content_container .content.tour_intro .openday{
    width: 90%;
    padding: 0;
  }
  .content_container .content.tour_intro .openday > .text{
    top: 26%;
    left: 4%;
    width: 76%;
    height: 62%;
    font-size: 0.6rem;
    line-height: 0.7rem;
    /*font-size: calc(12px + 1.2vw);*/
    /*line-height: calc(12px + 1.6vw);*/
  }
  .content_container .content.tour_intro .openday img.desktop{
    display: none;
  }
  .content_container .content.tour_intro .openday img.mobile{
    display: block;
  }
  .content_container .content .openday img.desktop{
    display: none;
  }
  .content_container .content .openday img.mobile{
    display: block;
  }
  .content_container .content .openday .video {
    margin-bottom: 0;
  }
  .content_container .content .openday .video iframe{
    width: 80%;
  }

  .tour_button_container {
    padding-bottom: 37%;
  }
  .tour_button_container .tour_btn {
    display: block;
    width: 44vw;
    min-width: 165px;
    margin: 0 auto 3%;
  }
  .tour_button_container .tour_btn .text {
    font-size: 3.6vw;
    line-height: 4vw;
  }

  .popup{
    padding: 15px;
  }
  .popup >div {
    width: 85%;
  }


}

@media (max-width: 430px) {
  .content_container .content {
    /*background-size: cover;*/
  }


}

@media (max-width: 430px) {
  body{
    font-size: 1.3rem;
  }


}



