@charset "utf-8";
/* CSS Document */

@import url(notosanstc.css);
html{
    scroll-behavior: smooth;
    height: 100%;
}
html, body {
    height: 100%;
    font-size: 62.5%;
}
body{
    font-family: 'Noto Sans TC', "Microsoft JhengHei UI", "微軟正黑體", "Microsoft JhengHei UI", sans-serif;
	color: #000;
    min-height: 100%;
}
*{
    box-sizing: border-box;
}
p{
    font-size: 1.5rem;
    color: #333;
    line-height: 1.5;
    font-weight: 300;
    letter-spacing: 0.25rem;
}
a{
    font-size: 1.5rem;
    font-weight: 400;
    color: #6f8c31;
    outline: none;
    -webkit-transition: all 0.4s;
    -o-transition: all 0.4s;
    transition: all 0.4s;
    text-underline-offset: 5px;
}
a:hover{
    color: #ff7a39;
}
.btn{
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 20px;
}
.btn a{
    font-size: 1.5rem;
    color: #fff;
    padding: 10px 20px;
    background-color: #ff7a39;
    border-radius: 8px;
    text-decoration: none;
    outline: none;
}
.btn a:hover{
    background-color: #ddd;
    color: #333;
}
.wrap {
    min-height: 100%;
}
header{
    position: fixed;
    top: 0px;
    left: 0px;
    width: 100%;
    height: 60px;
    border-bottom: 1px solid #ccc;
    background-color: #fff;
    box-shadow: 0px 6px 12px 0px rgba(0,0,0,0.12);
    z-index: 9998;
}
.header-wrap{
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 98%;
    height: 60px;
    padding: 0 15px;
    margin: 0 auto;
}
.logo{
    display: flex;
    justify-content: flex-start;
    align-items: center;
    float: left;
    height: auto;
    width: auto;
}
.logo a{
    display: block;
    height: 38px;
    width: auto;
    margin-right: 20px;
}
.logo a img{
    width: 100%;
    height: 100%;
    object-fit: contain;
}
.slogan{
    font-size: 1.5rem;
    color: #7faf27;
}
.guide{
    float: right;
}
.guide a{
    display: flex;
    align-items: center;
    white-space:nowrap;
    height: 100%;
    font-size: 1.5rem;
    text-decoration: none;
}
.guide a i{
    display: flex;
    justify-content: center;
    align-items: center;
    width: 26px;
    height: 26px;
    font-size: 1.5rem;
    margin-right: 5px;
    color: #fff;
    border-radius: 50%;
    background-color:#ff7a39;
}

.main { 
    /*overflow:auto; */
    padding-bottom: 50px; 
    padding-top: 60px;
}
.container{
    width: 50%;
    padding: 20px;
    border: 1px solid #dddddd;
    background-color: #fff;
    box-shadow: 0px 6px 12px rgba(0,0,0,0.12);
    border-radius: 12px;
    margin: 50px auto;
}
.events-container{
    display: flex;
    justify-content: center;
    /*width: 60%;*/
    width: 1140px;
    margin: 20px auto;
}
.result-container{
    width: 30%;
    padding: 20px;
    border: 1px solid #dddddd;
    background-color: #fff;
    box-shadow: 0px 6px 12px rgba(0,0,0,0.12);
    border-radius: 12px;
    margin: 50px auto;
}
.events-container ul{
    display: flex;
    justify-content: flex-start;
    align-items: stretch;
    flex-wrap: wrap;
    width: fit-content;
}
.events-container ul li{
    display: block;
    /*width: calc(33% - 20px);*/
    width: 360px;
    margin: 10px;
    background-color: #fff;
    border: 2px solid #6f8c31;
    border-radius: 15px;
    padding: 20px;
    box-shadow: 0px 6px 12px 0px rgba(0,0,0,0.24);
    /* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#eeeeee+0,ffffff+100 */
background: linear-gradient(to bottom,  rgba(238,238,238,1) 0%,rgba(255,255,255,1) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */

}
.title01{
    min-height: 60px;
    font-size: 2.4rem;
    text-align: center;
    font-weight: 600;
    margin-bottom: 10px;
    line-height: 1.2;
}
.rate{
    font-size: 3.6rem;
    color: #ff4e4e;
    font-weight: 800;
    text-align: center;
    margin-bottom: 10px;
}
.events-content{
    font-size: 1.5rem;
    color: #333;
    font-weight: 300;
    line-height: 1.7;
}
footer {
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    margin-top: -50px; /* negative value of footer height */
    height: 50px;
    clear:both;
    background-color: #6F8C31;
}
footer .copyright{
    font-size: 15px;
    font-weight: 200;
    color: #fff;
}
.control-wrap{
    position: fixed;
    right: 0px;
    bottom: 60px;
    width: 60px;
    z-index: 9999;
}
.control-wrap a{
    display: block;
    color: #fff;
    font-size: 1.4rem;
    padding: 7px;
    text-decoration: none;
    text-align: center;
}
.guide-flow{
    display: none;
    width: 60px;
    background-color:#6f8c31;
    border: 1px solid #fff;
    box-shadow: 0px 6px 6px 0px rgba(0,0,0,0.24);
    -webkit-border-top-left-radius: 5px;
    -webkit-border-bottom-left-radius: 5px;
    -moz-border-radius-topleft: 5px;
    -moz-border-radius-bottomleft: 5px;
    border-top-left-radius: 5px;
    border-bottom-left-radius: 5px;
    margin-bottom: 3px;
}
.customer{
    width: 60px;
    background-color:#6f8c31;
    border: 1px solid #fff;
    box-shadow: 0px 6px 6px 0px rgba(0,0,0,0.24);
    -webkit-border-top-left-radius: 5px;
    -webkit-border-bottom-left-radius: 5px;
    -moz-border-radius-topleft: 5px;
    -moz-border-radius-bottomleft: 5px;
    border-top-left-radius: 5px;
    border-bottom-left-radius: 5px;
    margin-bottom: 3px;
}
.customer a{
    padding: 10px;
}
.gotop{
    width: 60px;
    background-color:#6f8c31;
    border: 1px solid #fff;
    box-shadow: 0px 6px 6px 0px rgba(0,0,0,0.24);
    -webkit-border-top-left-radius: 5px;
    -webkit-border-bottom-left-radius: 5px;
    -moz-border-radius-topleft: 5px;
    -moz-border-radius-bottomleft: 5px;
    border-top-left-radius: 5px;
    border-bottom-left-radius: 5px;
}
.gotop a{
    display: flex;
    justify-content: center;
    align-items: center;
}
.form-caption p{
    margin-bottom: 20px;
    text-align: center;
}
.title02{
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 3rem;
    color: #6f8c31;
    font-weight: 600;
    text-align: center;
    margin-bottom: 20px;
}
.title02 i{
    font-size:3.6rem;
    margin-right: 5px;
}
.title03{
    font-size: 1.6rem;
    font-weight: 300;
    min-width: 160px;
    width: 100%;
}
.title03 span{
    font-size: 1.4rem;
}
.form-wrap2 .title03{
    width: 100%;
    margin-right: 10px;
}
.form-wrap2 ul li{
    display: flex;
    justify-content: flex-start;
    align-items: center;
    margin-bottom: 15px;
    flex-wrap: wrap;
}
.select-box{
    margin:0 15px;
}
/*Radio button setting*/
.select-box .radio {
  display: block;
  position: relative;
  padding-left: 20px;
  /*margin-bottom: 12px;*/
  cursor: pointer;
  font-size: 1.6rem;
  font-weight: 300;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

/* Hide the browser's default radio button */
.select-box .radio input {
  display: none;
  position: absolute;
  opacity: 0;
  cursor: pointer;
}
/* Create a custom radio button */
.select-box .checkmark {
  position: absolute;
  top: 3px;
  left: 0;
  height: 18px;
  width: 18px;
  border: 1px solid #888888;
  background-color: #fff;
  border-radius: 50%;
}

/* On mouse-over, add a grey background color */
.select-box .radio:hover input ~ .checkmark {
  /*background-color: #ccc;*/
}

/* When the radio button is checked, add a blue background */
.select-box .radio input:checked ~ .checkmark {
  /*background-color: #2196F3;*/
}

/* Create the indicator (the dot/circle - hidden when not checked) */
.select-box .checkmark:after {
  content: "";
  position: absolute;
  display: none;
}

/* Show the indicator (dot/circle) when checked */
.select-box .radio input:checked ~ .checkmark:after {
  display: block;
}

/* Style the indicator (dot/circle) */
.select-box .radio .checkmark:after {
 	top: 3px;
	left: 3px;
	width: 10px;
	height: 10px;
	border-radius: 50%;
	/*background: white;*/
    background: #da9055;
}
.select-box-wrap{
    display: flex;
    justify-content: flex-start;
    align-items: center;
}
.form-items{
    display: flex;
    justify-content: flex-start;
    align-items: center;
    flex-wrap: wrap;
    font-size: 1.6rem;
}
.form-items input{
    border: 1px solid #b2b2b2;
    padding: 10px 5px;
    border-radius: 6px;
    outline: none;
    font-size: 1.6rem;
}
.form-items input.long-size{
    width: 600px;
}
.form-wrap{}
.form-wrap ul{}
.form-wrap ul li{
    display: flex;
    justify-content: flex-start;
    align-items: center;
    margin-bottom: 15px;
    flex-wrap: wrap;
}
label.form-check-label{
    display: flex;
    align-items: center;
    width: fit-content;
    font-size: 1.6rem;
    position: relative;
    padding-left: 20px;
    padding-top: 0px;
    margin-bottom: 0em;
    cursor: pointer;
    margin-right: 10px;
    white-space: nowrap;
    color: #555;
    /*display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;*/
}
.agree-wrap label.form-check-label{
    margin-right: 0px;
}
input[type="checkbox"].form-check-input {
    display: none;
}
label.form-check-label::before {
    content: '';
    display: block;
    position: absolute;
    width: 18px;
    height: 18px;
    background: #FFF;
    border: 1px solid #888888;
    margin-top: 0px;
    left: 0;
    top: 4px;
    box-sizing: border-box;
	/*-webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    border-radius: 3px;*/
}
input[type="checkbox"]:checked + label.form-check-label::after {
    /*background: #a46952;*/
	background-image: url(../images/checked.png);
	background-repeat: no-repeat;
	background-position: center;
    /*box-shadow: 1px 1px 5px white;*/
}
label.form-check-label::after {
    content: '';
    position: absolute;
    width: 12px;
    height: 9px;
    /*border-radius: 15px;*/
    margin-top: -3px;
    left: 3px;
    top: 12px;
    overflow: hidden;
    transition: all 0.2s;
}
label.form-check-label.main-select{
    font-size: 1.5rem;
    margin-bottom: 5px;
}
.other{
    display: flex;
    justify-content: flex-start;
    align-items: center;
    width: 100%;
    margin-top:5px;
}
.agree-wrap{
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 20px;
    font-size: 1.6rem;
}
.agree-wrap p{
    font-size: 1.6rem;
}
.agree-wrap ul{
    display: flex;
    flex-direction: column;
    justify-content: center;
    flex-wrap: wrap;
}
.agree-wrap ul li{
    display: flex;
    justify-content: flex-start;
    /* width: 240px; */
    margin-bottom: 5px;
    font-size: 1.6rem;
}
.agree-wrap ul li a{
    /*padding-left: 15px;*/
}
.form-wrap2{
    margin-bottom: 20px;
    padding-bottom: 20px;
    border-bottom: 1px solid #ddd;
}
.bg_close {
    position: absolute;
    height: 100%;
    width: 100%;
    left: 0px;
    top: 0px;
}
.w3-btn, .w3-button{
    padding: 0px;
    text-decoration: underline;
    overflow: unset;
}
.lightbox-wrap{
    width: 980px;
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
    align-content: center;
    background-color: #fff;
    border: 1px solid #d7d7d7;
    padding: 20px 50px;
    margin-top: 50px;
    -webkit-border-radius: 16px;
    -moz-border-radius: 16px;
    border-radius: 16px;
    box-shadow: 0px 6px 16px 0px rgb(0 0 0 / 12%);
    z-index: 9999;
}
.lightbox-wrap .w3-btn, span.w3-close.w3-button {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 36px;
    height: 36px;
    font-size: 1.9rem;
    color: #000;
    line-height: 0.9;
    font-weight: 600;
    text-align: center;
    -webkit-border-radius: 18px;
    -moz-border-radius: 18px;
    border-radius: 18px;
    padding: 7px;
    transition: all 0.4s;
    -o-transition: all 0.4s;
    -moz-transition: all 0.4s;
    -webkit-transition: all 0.4s;
    background-color: #eee;
    text-decoration: none;
}
.modal-header h2{
    font-size: 3rem;
    color: #000;
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 30px;
}
.modal-body{
    font-size: 1.5rem;
    color: #333;
    font-weight: 400;
    line-height: 1.7;
}
.contract-wrap{
    margin-bottom: 20px;
}
.contract-wrap i{
    margin-right: 5px;
    font-size: 1.4rem;
}
.contract-title{
    font-size: 1.6rem;
    font-weight: 600;
}
.information-box{
    font-size: 1.5rem;
    color: #333;
    font-weight: 400;
    line-height: 1.7;
    text-align: center;
    margin-bottom: 20px;
}
.text-tiny{
    font-size: 1.2rem !important;
}
.text-small{
    font-size: 1.5rem !important;
}
.text-big{
    font-size: 1.6rem !important;
}
.text-huge{
    font-size: 1.8rem !important;
}
@media screen and (max-width: 1366px) {
.events-container{
    /*width: 85%;*/
}
.container{
    width: 85%;
}
.result-container{
    width: 45%;
}
}
@media screen and (max-width: 1180px) {
.events-container{
    width: 980px;
}
.events-container ul li{
    width: 300px;
}
}
@media screen and (max-width: 1024px) {
.events-container{
    /*width: 90%;*/}
.container{
    width: 90%;}
.result-container {
    width: 50%;
}
}
@media screen and (max-width: 820px) {
.events-container{
    width: 640px;
}
/*.events-container ul li{
    display: block;
    width: calc(50% - 20px);}*/
.form-items{
    flex-wrap: wrap;
}
.select-box-wrap{
    margin-bottom: 10px;
}
.result-container {
    width: 60%;
}
}
@media screen and (max-width: 768px) {
table th, table td{
    border-right: 0px solid #ddd;
}
}
@media screen and (max-width: 600px) {
.events-container{
    width: 100%;
}
.events-container ul{
    justify-content: center;
}
.events-container ul li{
    display: block;
    width: 90%;
    /*width: calc(100% - 20px);*/}
header{
    height: 90px;
}
.main{
    padding-top: 90px;
}
.header-wrap{
    height: 90px;
    justify-content: center;
    align-items: center;
}
.logo{
    flex-direction: column;
}
.logo a{
    margin-right: 0px;
    margin-bottom: 5px;
}
footer{
    height: 60px;
}
footer .copyright{
    text-align: center;
}
.guide{
    display: none;
}
.main { 
    padding-bottom: 60px;}
.guide-flow{
    display: block;
}
.select-box-wrap{
    flex-wrap: wrap;
}
.select-box{
    width: 100%;
}
.form-items input.long-size{
    width: 100%;
}
.form-items{
    width: 100%;
}
.agree-wrap{
    justify-content: flex-start;
}
.lightbox-wrap{
    width: 96%;
    padding: 20px;
}
.agree-wrap ul li{
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    width: 100%;
}
label.form-check-label{
    padding-left: 20px;
}
.agree-wrap ul li a{
    padding-left: 0px;
    font-size: 1.5rem;
    width: calc(100% - 25px);
    white-space: unset;
}
.container{
    margin: 30px auto;
}
.result-container{
    margin: 30px auto;
}
.result-container {
    width: 98%;
}
}