:root{
  --main-bg-color: #FFF;
  --header-color: #231F20;
  --main-text-color: #231F20;
  --main-input-text-color: #231F20;
  --main-btn-text-color: #FFF;
  --main-field-bg-color: #f4f4f4;
  --main-container-bg-color: transparent;
  --main-btn-color: #007bff;
  --main-btn-highlight-color: #0062CD;
  --main-grey-color: #D1D1D1;
  --main-deep-grey-color: #AAAAAA;
  --lg-red-color: #a50034;
  --header-height: 12rem;
  --main-min-width: 375px;
  --main-font-normal : "NotoSansTC", sans-serif, Airal;

}

@font-face {
    font-family: NotoSansTC;
    /*font-weight: bold;*/
    src: url("/fonts/NotoSansTC-Regular.otf") format("opentype");
}

@font-face {
    font-family: NotoSansTC;
    font-weight: bold;
    src: url("/fonts/NotoSansTC-Bold.otf") format("opentype");
}

*{
  min-width: 0;
}

body {
  /*padding-top: 5rem;*/
  /*font-family: "NeueHaasGroteskText-Regular", Airal;*/
  font-family: var(--main-font-normal);
  background-color: var(--main-bg-color);
  /*background: linear-gradient(to top, #5e5e5e, #F5F5F5);*/
  margin: 0;
  padding: 0;
  color: var(--main-text-color);
  min-width: var(--main-min-width);
  overflow-x: hidden;
  font-size: 1rem;
/*  background-image: url(/images/20240508_yfd-background-1.png);*/
  background-size: 100% auto;
  background-position: top center;
  background-repeat: repeat-y;
  min-height: 100dvh;
}

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: underline;
  pointer-events:auto;
}

ul > li {
   margin-bottom: 12px;
}

h2 {
  font-size: 1.5rem;
}
section {
  padding-left: 8px;
}

html {
  background-color: var(--main-bg-color);
}
body {
  background-color: var(--main-bg-color);
}

.people_btn_container{
  display: grid;
  grid-template-columns: 30px 50px 30px;
}
.people_btn_container > input {
  width: 100%;
  height: 100%;
  border: 1px solid #000;
}
.people_btn_container > input:nth-child(1) {
  border-radius: 5px 0 0 5px;
}
.people_btn_container > input:nth-child(3) {
  border-radius: 0 5px 5px 0;
}

.qrcode_container {
  margin: 0.5rem;
  font-size: 1.5rem;
}

.client_info {
  margin: 0.5rem;
  display: none;
  font-size: 1.5rem;
}

.client_info > div{
  display: grid;
  grid-template-columns: 200px 1fr;
  margin-bottom: 0.5rem;
  border-bottom: 1px dashed #DDD;
}

.ui-widget{
  font-family: var(--main-font-normal);

}
.ui-state-active{
  border: 1px solid #003eff;
  background: var(--main-pupple-color);
}

.finish_text{
  margin-top: 110px;
  font-size: 1.6rem;
}
.finish_text a{
  color: var(--main-link-color);
  text-decoration: none;
  pointer-events:auto;
}
.finish_text span{
  display: inline-block;
}

.logout_btn {
  position: absolute;
  right: 20px;
  top: 20px;
  width: 55px;
}
.logout_btn img{
  width: 100%;
  object-fit: contain;
}

.form_notices {
  font-size: 0.8rem;
  margin-top: 0;
  font-weight: normal;
}


.main_container {
  width: 100%;
  max-width: 800px;
  margin: 0 auto;
  min-width: var(--main-min-width);
  position: relative;
  margin-bottom: 30px;
}
.main_container img{
  width: 100%;
}
.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 0 2rem;
}
.main_container .grid_container .logo{
  padding: 2.2rem;
}
.main_container .grid_container .logo_container{
  padding-top: 1rem;
}
.main_container .grid_container .logo_left{
  float: left;
  width: 300px;
  max-width: 49vw;
}
.main_container .grid_container .logo_right{
  float: right;
  width: 150px;
  max-width: 21vw;
}
.main_container .grid_container .logo_left img,
.main_container .grid_container .logo_right img{
  width: 100%;
  object-fit: contain;
}

}
.main_container .grid_container .header{
  font-size: 2rem;
}
.main_container .grid_container .header .zh{
  font-size: 1.8rem;
}
.main_container .grid_container .intro{
  text-align: center;
}
.main_container .grid_container .intro .intro_list{
  list-style-type: '- ';
  padding-left: 15px;
}
.main_container .grid_container .intro .intro_list > li{
  margin-bottom: 0;
}
.main_container .form_helper{
  text-align: left;
  margin-top: 2rem;
  font-size:  0.8rem;
}
.main_container .form_info{
  text-align: left;
  font-size: 100%;
}
.main_container .form_info h4{
  text-decoration: underline;
  font-weight: bold;
}
.main_container .register_table_people {
  width: 100%;
  border: 2px solid #b5b5b5;
  border-radius: 15px;
  border-collapse: separate;
  margin-top: 10px;
  padding: 10px 20px;
  position: relative;
  box-sizing: border-box;
}
.main_container .register_table_people .collapsible_container{
  display: grid;
  grid-template-columns: 35% 65%;
}
.main_container .register_table {
  width: 100%;
  margin-top: 1rem;
  text-align: left;
  display: block;
}
.main_container .register_table tbody{
  display: block;
  display: grid;
  grid-template-columns: 1fr 1fr;
}
.main_container .register_table td{
  display: block;
  padding-right: 10px;
  padding-left: 10px;
}
.main_container .register_table h2 {
  margin-top: 1rem;
}
.main_container .register_table .checkbox_padding{
  padding-left: 26px;
}
.main_container .register_table .form_group,
.main_container .register_table tr{
  display: grid;
  grid-template-columns: 1fr;
  align-items: start;
  align-content: center;
  margin-bottom: 0.5rem;
}
.main_container .register_table .form_group.oneline{
  grid-template-columns: 1fr;
}

.main_container .register_table .form_group > label,
.main_container .register_table .field_title{
  text-align: left;
  padding-left: 0.5rem;
  padding-right: 0.5rem;
  display: flex;
  align-items: center;
  height: 100%;
}
.main_container .register_table .form_group.oneline > label{
  text-align: left;
}
.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 select,
.main_container .register_table input,
.main_container .register_table textarea {
  padding: 10px;
  font-size: 16px;
  border: 1px solid #ccc;
  border-radius: 4px;
  width: 100%;
  box-sizing:border-box;
  background-color: var(--main-field-bg-color);
}
.main_container .register_table input[type="radio"]{
  width: 25px;
}
.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: center;*/
}
.main_container .preview_btn,
.main_container .submit_btn {
  padding: 0.2rem 1rem;
  font-size: 1.3rem;
  /*background-color: var(--main-bg-color);*/
  /*color: var(--main-text-color);*/
  border: 1px solid var(--main-text-color);
  background-color: var(--main-btn-color);
  color: var(--main-btn-text-color);
  cursor: pointer;
/*  width: 60%;*/
}
.main_container .preview_btn:hover,
.main_container .submit_btn:hover {
  background-color: var(--main-btn-highlight-color);
}
.main_container .submit_btn[disabled] {
  background-color: #C2C2C2;
  color: #8d8d8d;
  cursor: not-allowed;
}
.main_container .cancel_btn {
  padding: 0.2rem 1rem;
  font-size: 1.3rem;
  /*background-color: var(--main-bg-color);*/
  /*color: var(--main-text-color);*/
  border: 1px solid var(--main-text-color);
  background-color: #7ead38;
  color: var(--main-btn-text-color);
  cursor: pointer;
/*  width: 60%;*/
}

.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: #FFF;
  border: 2px solid var(--main-text-color);
}
.checkbox_block.size-small .checkmark {
  top: 3px;
  height: 18px;
  width: 18px;
}
.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);
}
.checkbox_block.size-small .container .checkmark:after {
  left: 4px;
  top: 0px;
  width: 7px;
  height: 12px;
}

.fake_checkmark {
  height: 25px;
  width: 25px;
  display: inline-block;
  /*background-color: ;*/
  border: 2px solid var(--main-text-color);
}

.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 .textarea_text,
.main_container .input_text{
  width: 100%;
  background-color: var(--main-field-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;
  /*text-align: center;*/
  resize: none;
}
.main_container .textarea_text{
  /*height: 65px;*/
  /*overflow: hidden;*/
  /*padding-top: 18px;*/
}
.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: 230px;
  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;
  cursor: pointer;
}
.main_container .upload_photo{
  position: absolute;
  height: 1px;
  width: 1px;
  opacity: 0;
}


.popup_tnc_blocker {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background-color: rgba(0, 0, 0, 0.6);
  z-index: 10;
  display: none;
}

.tnc_flat {
  text-align: left;
  font-size: 100%;
}
.tnc_flat h3{
  text-align: center;
  margin-top: 30px;
  font-size: 120%;
}
.tnc_flat a{
  text-decoration: underline;
}

.tnc_btn {
  text-decoration: underline;
}
.popup_tnc{
  position: fixed;
  width: 90%;
  height: 90%;
  /*max-width: 500px;*/
  /*max-width: 90vw;*/
  /*max-height: 90vw;*/
  left: calc(50% - (90% / 2));
  top: calc(50% - (90% / 2));
  border: 10px solid #FFF;
  background-color: #FFF;
  border-radius: 18px;
  z-index: 15;
  text-align: left;
  padding: 10px;
  display: none;
  -webkit-box-shadow: 12px 9px 49px 0px rgba(0,0,0,0.6); 
  box-shadow: 12px 9px 49px 0px rgba(0,0,0,0.6);
  overflow: auto;
}
.popup_tnc h3{
  text-align: center;
}
.popup_tnc .btn_container{
  text-align: center;
}
.popup_tnc .close_btn,
.popup_tnc .accept_btn,
.popup_tnc .reject_btn{
  width: 140px;
  text-align: center;
  padding: 5px 10px;
  margin: 20px;
  border: 1px solid #000;
  border-radius: 4px;
  display: inline-block;
  cursor: pointer;
}


.popup_upload_blocker {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background-color: rgba(0, 0, 0, 0.6);
  z-index: 10;
  display: none;
}

.popup_upload{
  position: fixed;
  width: 90%;
  height: 90%;
  /*max-width: 500px;*/
  /*max-width: 90vw;*/
  /*max-height: 90vw;*/
  left: calc(50% - (90% / 2));
  top: calc(50% - (90% / 2));
  border: 10px solid #FFF;
  background-color: #FFF;
  border-radius: 18px;
  z-index: 15;
  text-align: left;
  /*padding: 10px;*/
  display: none;
  -webkit-box-shadow: 12px 9px 49px 0px rgba(0,0,0,0.6); 
  box-shadow: 12px 9px 49px 0px rgba(0,0,0,0.6);
  overflow: auto;
}

.popup_upload .upload_file {
  display: none;
}
.popup_upload progress {
  display: none;
}
.popup_upload progress.done{
  display: none !important;
}
.popup_upload > img {
  max-width: 100%;
  width: auto;
}
.popup_upload .upload_container {
  background-color: #FFF;
  border-radius: 40px;
  color: #9fa0a0;
  font-size: 2rem;
  line-height: 3rem;
  margin: 20px 30px;
}
.popup_upload .upload_container label{
  width: 100%;
  display: inline-block;
  padding: 10px;
  line-height: 140%;
}
.popup_upload .upload_container .img{
  display: none;
}
.popup_upload .upload_container .img > img{
  width: 180px;
  height: 180px;
  object-fit: contain;
}
.popup_upload .upload_container .btn_item{
  width: 100px;
  display: block;
  color: #000;
  border-radius: 40px;
  border: 1px solid #000;
  text-align: center;
  margin: 10px auto;
}




.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);
/*  padding-top: 1rem;*/
}
.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);
}

.footer_logo {
  display: flex;
  align-items: center;
  justify-content: center;
}

.footer_logo div {
  margin: 0 10px;
}

.footer_logo .line {
  height: 90px;
  background-color: #000;
  width: 1px;
}

.footer_logo img {
  width: auto;
  height: 110px;
  padding: 15px 10px;
}


.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;
  grid-column: 1 / -1;
  min-width: 340px;
}
.parsley-errors-list{
  color: #9d0000;

}

#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;
}



.main_container .form_preview{
  position: fixed;
  inset: 0;
  background-color: #FFF;
  padding: 1rem;
  /*max-height: 100vh;*/
  overflow: auto;
  display: none;
}
.main_container .form_preview .logo_container{
  padding-top: 1rem;
}
.main_container .form_preview .logo_left{
  float: left;
  width: 45%;
  max-width: 300px;
}
.main_container .form_preview .logo_right{
  float: right;
  width: 35%;
  max-width: 150px;

}
.main_container .form_preview .logo_left img,
.main_container .form_preview .logo_right img{
  width: 100%;

}
.main_container .form_preview .header{
  clear: both;
  font-size: 1.4rem;
}
.main_container .form_preview h3{
  text-align: left;
  font-size: 1.3rem;
}
.main_container .form_preview h2{
  font-size: 1.2rem;
}
.main_container .form_preview table{
  width: 100%;
}
.main_container .form_preview table td{
  padding-bottom: 5px;
}
.main_container .form_preview table td:nth-child(1){
  text-align: right;
  vertical-align: top;
  padding-right: 5px;
  width: 130px;
}
.main_container .form_preview table td:nth-child(1)[colspan="2"]{
  text-align: left;
}
.main_container .form_preview table td:nth-child(1)[colspan="2"].submit_block{
  text-align: center;
}
.main_container .form_preview table td:nth-child(1)[colspan="2"].submit_block button{
  margin: 5px;
}
.main_container .form_preview table td:nth-child(2){
  text-align: left;
}


.main_container .header{
  font-size: 1.5rem;
  font-weight: bold;
  color: var(--header-color);
}







@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 .textarea_text, .main_container .input_text{
    padding: 0.4rem 0.5rem;
  }
  .main_container .register_table .time_container > div {
      font-size: 0.8rem;;
  }
  .main_container .register_table .time_container {
    grid-template-columns: repeat(2, 1fr);
  }
  .popup_upload{
    width: 95%;
    height: 95%;
    left: calc(50% - (95% / 2));
    top: calc(50% - (95% / 2));
  }

}

@media (max-width: 425px) {
  .main_container .register_table select,
  .main_container .register_table input,
  .main_container .register_table textarea {
    /*width: 95%;*/
  }

  .header h2{
    font-size: 1.2rem;
  }




}



