@charset "utf-8";
/*default setting start*/
body,
html{
	margin: 0px;
	padding: 0px;
}
img {
	max-width: 100%;
	border: none;
}
img.full{
	width:100%;
}
body{
	font-family: "Apple LiGothic Medium","Microsoft JhengHei","微軟正黑體",arial,"新細明體",sans-serif;
	font-size: 16px;
	color:#000;
	background-color: #fff;
}
body.noscroll,
body.noscrollcert {
    overflow: hidden;
}
p{
	font-size: 16px;
	line-height: 24px;
}
.transition-effect{
	transition: all 0.4s ease;
	-webkit-transition: all 0.4s ease;
	-moz-transition: all 0.4s ease;
	-o-transition: all 0.4s ease;
}
ul{
	margin:0;
	padding: 0;
}
img{
	user-drag: none; 
	user-select: none;
	-moz-user-select: none;
	-webkit-user-drag: none;
	-webkit-user-select: none;
	-ms-user-select: none;
}
select{
    border-radius: 0;
    appearance: none;
    -moz-appearance:none; /* Firefox */
    -webkit-appearance:none; /* Safari and Chrome */
}
in
select::-ms-expand {
    display: none;
}
a,
a:hover,
a:active,
a:focus{
	color:#4e4e4e;
	outline: 0;
}
a:focus{
	text-decoration:none;
}
button{
	outline:none;
}
.container-fluid{
	padding:0; 
	background-color: transparent;
}
.container{
	padding-right: 15px;
	padding-left: 15px;
}
/*default setting end*/
.error{
	display:inline-block;
	color:#e60012;
	font-size:14px;
	margin-top:4px;
}
.error-focus{
	background-color:#fce8eb;
	padding:10px;
	margin: 0 -10px;
}
.img-title{
	line-height: 0
}
.blur {
    filter: blur(5px);
}
/*---Header---*/
.header{
	width: 100%;
	min-width:1500px;
	min-height: 70px;	
	background-color:#fff;
	position:fixed;
	top:0;
	z-index:9999;
}
.header .container{
	height: 100%;
	position: relative;
	max-width: 1200px;
}
.logo{
	position:absolute;
	left:100px;
	top:18px;
	z-index:1;
}
.menu{
	position:relative;
}
.social{
	list-style:none;
	float: right;
}
.social li{
	float: left;
}
.menu-list{
	float: left;
	font-size:24px;
	line-height:24px;
	margin: 20px 0 0 70px;
	list-style:none;
}
.menu-list li{
	float:left;
	padding:0 45px;
}
.menu-list li:not(:last-child) {
    border-right: 1px solid #4d4d4d;
}
.menu-list li a:hover{
	text-decoration:none;
}
#mobile-menu-btn{
	width: 10.287%;
    height: 44px;
    position: fixed;
    left: 45px;
    top: 28px;
	-webkit-transform: rotate(0deg);
	-moz-transform: rotate(0deg);
	-o-transform: rotate(0deg);
	transform: rotate(0deg);
	-webkit-transition: .5s ease-in-out;
	-moz-transition: .5s ease-in-out;
	-o-transition: .5s ease-in-out;
	transition: .5s ease-in-out;
	display:none;
	cursor: pointer;
	z-index: 99999;
}
#mobile-menu-btn span{
	display: block;
	position: absolute;
	height: 4px;
	width: 100%;
	background: #7d7d7d;
	border-radius: 9px;
	opacity: 1;
	left: 0;
	-webkit-transform: rotate(0deg);
	-moz-transform: rotate(0deg);
	-o-transform: rotate(0deg);
	transform: rotate(0deg);
	-webkit-transition: .25s ease-in-out;
	-moz-transition: .25s ease-in-out;
	-o-transition: .25s ease-in-out;
	transition: .25s ease-in-out;
	-webkit-box-shadow: 0px 2px 4px 0px rgba(0,0,0,0.2);
    -moz-box-shadow:  0px 2px 4px 0px rgba(0,0,0,0.2);
    box-shadow: 0px 2px 4px 0px rgba(0,0,0,0.2);
}
#mobile-menu-btn span:nth-child(1) {
	top: 0px;
}
#mobile-menu-btn span:nth-child(2),
#mobile-menu-btn span:nth-child(3){
	top: 20px;
}
#mobile-menu-btn span:nth-child(2){
	-webkit-box-shadow:none;
    -moz-box-shadow:none;
	box-shadow: none;
}
#mobile-menu-btn span:nth-child(4) {
	top: 40px;
}
#mobile-menu-btn.open span:nth-child(1){
	top: 9px;
	width: 0%;
	left: 50%;
}
#mobile-menu-btn.open span:nth-child(2){
	background: #fff;
	-webkit-transform: rotate(45deg);
	-moz-transform: rotate(45deg);
	-o-transform: rotate(45deg);
	transform: rotate(45deg);
}
#mobile-menu-btn.open span:nth-child(3){
	background: #fff;
	-webkit-transform: rotate(-45deg);
	-moz-transform: rotate(-45deg);
	-o-transform: rotate(-45deg);
	transform: rotate(-45deg);
}
#mobile-menu-btn.open span:nth-child(4){
	top: 9px;
	width: 0%;
	left: 50%;
}
/*---Footer---*/
.footer{
	text-align:center;
}
.carousel-fade .carousel-inner > .item {
  transition-property: opacity;
}
.carousel-fade .carousel-inner .item img{
	width:100%;
}
.carousel-fade .carousel-inner > .item,
.carousel-fade .carousel-inner > .active.left,
.carousel-fade .carousel-inner > .active.right {
  opacity: 0;
}
.carousel-fade .carousel-inner .active,
.carousel-fade .carousel-inner .next.left,
.carousel-fade .carousel-inner .prev.right {
  opacity: 1;
}
.carousel-fade .carousel-inner .next,
.carousel-fade .carousel-inner .prev,
.carousel-fade .carousel-inner .active.left,
.carousel-fade .carousel-inner .active.right {
  left: 0;
  -webkit-transform: translate3d(0, 0, 0);
          transform: translate3d(0, 0, 0);
}

/*---block one---*/
.inner{
	width: 1200px;
	margin: 0 auto;
    position: relative;
}
.block-one{
	background: url(../images/haku_kv_pc.jpg) center center no-repeat;
    background-position-y: -80px;
    /*background-size: cover;*/
    width: 100%;
    overflow: hidden;
}
.block-one .inner{
    height: 965px;
}
.block-one .inner .prod{
    display: none;
    left: 4.5%;
    top: 4.6%;
    position: absolute;
}
.block-one .inner .word {
    display: none;
    left: 7.1%;
    top: 65.5%;
    position: absolute;
}
/*---block two---*/
.block-two{
    /*background-size: cover;*/
    width: 100%;
    overflow: hidden;
}
.block-two .inner {
	width: 1260px;
	background: url(../images/haku_block2_bg.png) left top no-repeat;
    height: 867px;
}
.block-two .inner .word{
    cursor: pointer;
    z-index: 1;
    position: absolute;
    top: 39%;
    right: 0;
}
.block-two .inner .yt_1{
    cursor: pointer;
    z-index: 1;
    position: absolute;
    top: 39%;
    left: 29%;
    /*width: 228px;*/
}
.block-two .inner .yt_2{
    cursor: pointer;
    z-index: 0;
    position: absolute;
    top: 4.5%;
    left: 2.5%;
    /*width: 330px;*/
}
.block-two .yt_popup {
    cursor: pointer;
    display: none;
    z-index: 9999;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background-color: rgba(0, 0, 0, 0.85);
}
.block-two .yt_popup .video {
    position: relative;
    width: 80vw;
    height: 45vw;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
/*---block three---*/
.block-three{
    background: url(../images/haku_block3_bg.jpg) center center no-repeat;
    overflow: hidden;
    margin-top: 100px;
}
.block-three .inner {
    height: 1210px;
    padding-top: 130px;
}
.block-three .inner .subtitle{
    text-align: center;
    margin: 70px 0 10px 0;	
}
.block-three #CardContainer{
	position: relative;
}
.block-three #CardContainer #CharH {
    top: 292px;
    left: 105px;
    animation-delay: 0s;
}
.block-three #CardContainer #CharA {
    top: 422px;
    left: 367px;
    animation-delay: 0.7s;
}
.block-three #CardContainer #CharK {
    top: 292px;
    left: 628px;
    animation-delay: 1.4s;
}
.block-three #CardContainer #CharU {
    top: 422px;
    left: 890px;
    animation-delay: 2.1s;
}
.block-three #CardContainer .char {
    position: absolute;
    width: 241px;
    height: 444px;
    animation-iteration-count: infinite;
    animation-duration: 3s;
    animation-fill-mode: both;
    cursor: pointer;
}
.block-three #CardContainer .char > * {
    position: absolute;
}
.block-three #CardContainer .char .bgImg {
    width: 100%;
    height: 100%;
    z-index: 1;
    top: 0;
    left: 0;
}
.block-three #CardContainer #CharH .bgImg {
	background: url(../images/haku_block3_cardH.png) 0 0 no-repeat;
}
.block-three #CardContainer #CharA .bgImg {
	background: url(../images/haku_block3_cardA.png) 0 0 no-repeat;
}
.block-three #CardContainer #CharK .bgImg {
	background: url(../images/haku_block3_cardK.png) 0 0 no-repeat;
}
.block-three #CardContainer #CharU .bgImg {
	background: url(../images/haku_block3_cardU.png) 0 0 no-repeat;
}
.block-three #CardResult{
	position: relative;
}
.block-three #CardResult:after{
	position: absolute;
	display: block;
	content: '';
	width: 100%;
	height: 1px;
	background: url(../images/haku_block3_bar.png) right bottom no-repeat;
    bottom: -90px;
	left: 0;
}
.block-three #CardResult.charH {
    background: url(../images/haku_block3_cardH_open_text.png) 0 0 no-repeat;
}
.block-three #CardGame #CardResult #card.charH {
    background: url(../images/haku_block3_cardH_open_card.png) 0 0 no-repeat;
}
.block-three #CardResult.charA {
    background: url(../images/haku_block3_cardA_open_text.png) 0 0 no-repeat;
}
.block-three #CardGame #CardResult #card.charA {
    background: url(../images/haku_block3_cardA_open_card.png) 0 0 no-repeat;
}
.block-three #CardResult.charK {
    background: url(../images/haku_block3_cardK_open_text.png) 0 0 no-repeat;
}
.block-three #CardGame #CardResult #card.charK {
    background: url(../images/haku_block3_cardK_open_card.png) 0 0 no-repeat;
}
.block-three #CardResult.charU {
    background: url(../images/haku_block3_cardU_open_text.png) 0 0 no-repeat;
}
.block-three #CardGame #CardResult #card.charU {
    background: url(../images/haku_block3_cardU_open_card.png) 0 0 no-repeat;
}
.block-three #CardGame #CardResult {
    display: none;
    position: relative;
    height: 750px;
}
.block-three #CardGame #CardResult #card {
    position: absolute;
    width: 20.5%;
    height: 80%;
    top: 31%;
    right: 10%;
}
/*---block four---*/
.block-four .inner{
    height: 815px;
    margin-top: 42px;
}
.block-four .inner .title{
	text-align: center;
}
.block-four .inner .blog_1, 
.block-four .inner .blog_2, 
.block-four .inner .blog_3 {
    position: absolute;
    width: 31.5%;
    max-width: 380px;
    top: 30%;
    opacity: 0;
    overflow: hidden;
    cursor: pointer;
    height: 520px;
}

.block-four .inner .active.blog_1,
.block-four .inner .active.blog_2, 
.block-four .inner .active.blog_3 {
    top: 23.8%;
    opacity: 1;
}
.block-four .inner .blog_1 {
    left: 0%;
    transition: all 1s 0s ease-out;
}
.block-four .inner .blog_2 {
    left: 33.6%;
    transition: all 1s 0.2s ease-out;
}
.block-four .inner .blog_3 {
    left: 67.22%;
    transition: all 1s 0.4s ease-out;
}
.block-four .inner .blog_1 img,
.block-four .inner .blog_2 img, 
.block-four .inner .blog_3 img {
	width:100%;
	max-width:none;
    position: relative;
    transition: all 0.5s ease-out;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
.block-four .inner .blog_1:hover img, 
.block-four .inner .blog_2:hover img, 
.block-four .inner .blog_3:hover img {
    width: 102%;
    position: relative;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
.block-four .inner .shadow {
    box-shadow: 15px 15px 0 rgba(0, 0, 0, 0.09);
}
/*---block mapform---*/
.block-five{
	margin-top: 30px;
}
.block-five .title{
	text-align: center;
	margin-bottom: 55px;
}
.block-mapform{
	position:relative;
	height:auto;
}
.form-container{
	max-width: 1065px;
	padding: 0;
}
.counter_choose{
	position:relative;
}
#map_loading{
	position:absolute;
	width:28%;
	height:35%;
	z-index:2;
	background-color:rgba(255,255,255,0.7);
	left:11%;
	top:-4%;
}
.counter_select{
	width:1010px;
	list-style:none;
	margin:0 auto 60px;
}
.counter_select li{
	float:left;
	height:57px;
	color: #4d4d4d;
	border:1px solid #707070;
	line-height:57px;
	text-align:center;
	margin:0 15px;
	font-weight:bold;
	font-size:27px;
}
li.counter{
	border:0;
}
.find_counter{
	width:275px;
	cursor:pointer;
	background-color:#fff;
}
.find_counter img{
	margin-right:15px;
	margin-top: -4px;
}
.select{
	width:275px;
	background-color:#fff;
}
.counter_select select{
	width:100%;
	cursor: pointer;
    padding: 0 15px;
	border: 0;
    outline: none;
    appearance: none;
    -ms-appearance: none;
    -moz-appearance: none;
    -webkit-appearance: none;
    background: url(../images/haku_mapform_sel.png) right 15px center no-repeat;
}
.counter_select select::-ms-expand{ display:none; }

.tips{
	text-align: center;
	margin:0 auto 350px;
}
#map_choose_container{
	display:none;
}
.map{
	margin:0 auto;
	margin-bottom:60px;
}
.map > div{
	float:left;
	border: 3px solid #b6b6b6;
	border-radius: 0 3px 3px 0;
}
.map > div.google_map{
	border-right: 0;
	border-radius: 0;
}
.google_map{
	width:720px;
	height:860px;
	background:#ccc;
}
.counter_list{
	width:345px;
	height:860px;
	background-color:#fff;
}
.list_title{
	font-size:30px;
	background-color:#b6b6b6;
	text-align:center;
	padding:10px 15px;
	color:#fff;
	position:relative;
}
.counter_ul{
    height: 792px;
	overflow-y: auto;
    margin-right: 10px;
}
.counter_ul::-webkit-scrollbar {
    width: 5px;
    border-left: 5px solid #b6b6b6;
}
.counter_ul::-webkit-scrollbar-track {
    background-color: #fff;
}

.counter_ul::-webkit-scrollbar-thumb {
    background-color: #fff;
    border-left: 5px solid #b6b6b6;
}
.counter_ul li{    
	padding: 0 15px 0 15px;
}
.counter_ul label{
	position:relative;
	display:block;    
	padding: 25px 0 25px 65px;
	border-bottom:1px solid #b6b6b6;
	cursor:pointer;
}
.counter_ul input[type=radio]{
	display:none;
}
.counter_ul label span{
	position:absolute;
	width:42px;
	height:42px;
	border: 4px solid #b6b6b6;
    left: 8px;
    top: 30px;
}
.counter_ul input[type=radio]:checked+label span {
    background: url(../images/haku_mapform_check.png) center center no-repeat;
}
.c_name{
    font-size: 22px;
	color: #4d4d4d;
	margin-bottom:10px;
}
.c_phone,
.c_address{
	position:relative;
	font-size:14px;
	color:#4d4d4d;
	padding-left:20px;
	margin-bottom:3px;
}
.s_tel,
.s_addr{
	position:relative;
	font-size:22px;
	color:#4d4d4d;
	padding-left:30px;
	margin-bottom:3px;
}

.s_tel{
	margin-right:20px;
}

.c_phone:before,
.c_address:before{
	content:'';
	width:13px;
	height:18px;
	position: absolute;
	left:0;
	top:3px;
	background-repeat:no-repeat;
}
.s_tel:before,
.s_addr:before{
	content:'';
	width:21px;
	height:28px;
	position: absolute;
	left:0;
	top:3px;
	background-repeat:no-repeat;
}
.c_phone:before{
	background-image:url(../images/haku_mapform_phone.png);
}
.c_address:before{
	background-image:url(../images/haku_mapform_map.png);
}
.s_tel:before{
	background-image:url(../images/haku_mapform_phone_2.png);
}
.s_addr:before{
	background-image:url(../images/haku_mapform_map_2.png);
}
.counter_ok{
	text-align: center;
	margin:0 auto 95px;
	cursor:pointer;
}
.counter_ok.disabled{
	opacity:0.7;
	cursor: not-allowed;
	-webkit-filter: grayscale(100%);
    -moz-filter: grayscale(100%);
    -ms-filter: grayscale(100%);
    -o-filter: grayscale(100%);
    filter: grayscale(100%);
    -webkit-filter: gray;
    filter: gray;
}
.form_page{
	position:relative;
	display:none;
	margin: 0 0 30px;
}
.form_header,
.form_inner,
.success-page{
	max-width:630px;    
	margin-left: 340px;
}
.form_header{
	margin-top: 30px;
}
.form_inner{
	margin-bottom: 40px;
}
.form_content{
	margin-bottom: 100px;
}
.s_title{
	font-size:30px;
	color:#4d4d4d;
	font-weight:bold;
	margin-bottom:4px;
}
.input_row{
	position:relative;
	padding-left:138px;
	margin-bottom:20px;
}
.input_row span{
	position:absolute;
	left:0;
	color:#4d4d4d;
	font-weight:bold;
	font-size:30px;
	line-height:38px;
}
.form_body,
.success-page{
	padding-top:30px;
}
.form-input{
	width:100%;
	display: block;
	border: 1px solid #b6b6b6;
	padding: 8.5px 15px;
	font-size: 18px;
	color:#1e1e1e;
	background-color: #fff!important;
	outline:none;
}
.form-checkbox-input{
	margin:0px 0 20px;
}

.form-checkbox-input label {
	padding-left:55px;
    position: relative;
    font-weight:normal;
    cursor:pointer;
    margin:0 20px 0 0;
    color:#707070;
    font-size:27px;
}
.form-checkbox-input label.checkbox-label.notice{
	color: #0068b7;
	position: relative;
}
.checkbox-label a{
	color:#707070;
	text-decoration:underline;
}

.checkbox-label:before{
	content: '';
	width:42px;
	height:42px;
	display: block;
    position: absolute;
    left: 0px;
    top: -2px;
    background: #fff;
    border:2px solid #b6b6b6;
}
.form-checkbox-input input:checked + .checkbox-label:after {
	content: '';
	display: block;
    position: absolute;
    left: 6px;
    top: 2px;
    color: #d8b658;
    width: 42px;
    height: 42px;
    background-image: url(../images/haku_mapform_check.png);
    background-repeat:no-repeat;
}
.form-checkbox-input input:checked + .checkbox-label.notice:after{
	background-image: url(../images/haku_mapform_check_2.png);
}
.form-checkbox-input .radio-label:before {
	content: '';
	display: block;
    position: absolute;
    left: 6px;
    top: 2px;
    color: #d8b658;
    width: 32px;
    height: 30px;
    background-image: url(../images/haku_mapform_star.png);
    background-repeat:no-repeat;
}
.notice{
    font-size: 27px;
    color: #0068b7;
}
.send-btn,
.back-btn{
	width:450px;
	cursor:pointer;
    border: none;
    padding: 0;
	background-color: transparent;
}
.form-btn-box{
	margin: 50px auto 20px;
}
.back-btn{
	margin-right:100px;
}
.is-end{
	color:#000;
	text-align:center;
    font-size: 14px;
    padding:10px 15px;
}
.d_info{
	min-height:35px;
	font-size: 18px;
    line-height: 35px;
}
.resend-btn {
	width:42.083%;
    padding-top: 5.834%;
	background-repeat:no-repeat;
    cursor: pointer;
    border: none;
    background:url(../images/haku_mapform_resend_pc2.png);
    background-size:100%;
    background-repeat: no-repeat;
    outline: none;
    position: absolute;
    top: 44.9%;
    left: 51.8%;
}
.resend-btn:hover,
.resend-btn:focus{
	color: #fff;
	outline: none;
}

.go_top{
	position:absolute;
	bottom:50px;
	right:50px;
	cursor:pointer;
}
.pop-up{
	position:fixed;
	top:0;
	left:0;
	width:100%;
	height:100%;
	z-index:9999;
	display:none;
	overflow: auto;
	text-align: center;
	background: rgba(0,0,0,0.8);
}
.pop-up:before{
	content: "";
    display: inline-block;
    height: 100%;
    vertical-align: middle;
    margin-right: -5px;
}
.pop-window{
	width:75%;
	max-width:1200px;
	position:relative;
	margin:50px 0 50px;
    display:inline-block;
	vertical-align: middle;
}
.pop-container{
    padding-top: 61%;
	text-align:center;
	background: url(../images/haku_mapform_pop_pc2.jpg) no-repeat ;
	background-size:100%;
	position: relative;
}
.pop-container p{
	min-height:72px;
	margin-bottom:34px;
}
.pop-sel{
    width: 41%;
    height: 13.5%;
    position: absolute;
    top: 84.4%;
    left: 20.5%;
}
.pop-check-btn{
    width: 28.916666%;
    padding-top: 3.667%;
    position: absolute;
	top: 84%;
    left: 61.6%;
    background: url(../images/haku_mapform_pop_check_pc2.png) no-repeat;
    background-size: 100%;
}
.pop-sel select{
    width: 32%;
    margin-right: 1%;
    height: 49%;
    font-size: 24px;
    float: left;
    color: #707070;
    border: 1px solid #b6b6b6;
    border-radius: 3px;
    padding: 0 10% 0 3%;
    background: url(../images/haku_mapform_sel_2.jpg) 98% center no-repeat;
    background-size: 26%;
    -webkit-box-shadow: 1px 1px 1px 1px #d6d3d5 inset;
    -moz-box-shadow: 1px 1px 1px 1px #d6d3d5 inset;
    box-shadow: 1px 1px 1px 1px #d6d3d5 inset;
}
.pop-up .pop-overlay{
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    background: rgba(0,0,0,0.8);
    position: fixed;
}
.pop-close{
    width: 4.08%;
    height: 6.7%;
    position: absolute;
    right: 2%;
    top: 3%;
	cursor:pointer;
}
/*.pop-close:before,*/
.pop-close:after{
	content:'';
	display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    background: url(../images/haku_mapform_close.png) center center no-repeat;
    background-size: 100%;
}
/*.pop-close:after {
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    -o-transform: rotate(-45deg);
    transform: rotate(-45deg);
}*/
.pop-success{
	font-size:28px;
	margin:40px 0 25px;
}
.info-title{
	margin-bottom:20px;	
}
.info-title-fail{
	text-align:center;
	margin:126px 0 120px;
}
.msg{
	font-size:28px;
}
.success-page{
    color:#000;
    margin-bottom: 10%;
}
.success-page .info{
	margin-bottom:8px;
	font-size:18px;
}
#city-info{
	margin-right:15px;
}
.form-page{
	position:relative;
	height:100%;
}
.form-page.submitting:after{
	content:'';
	position:absolute;
	width:100%;
	height:100%;
	top:0;
	left:0;
}
.form-select{
	-webkit-appearance: none;
	-moz-appearance: none;
	-ms-appearance: none;
	-o-appearance: none;
	appearance: none;
}
.form-select option{
	color:#000;
}
.form-select::-ms-expand{ display:none; }

.dp_p2{
	width: 26%;
    position: absolute;
    top: -4%;
    left: 8%;
}

/*#menu-five-target{
	position:absolute;
}*/

.act_notice{
	font-size:50px;
	color:#707070;
	padding-bottom: 8px;
	margin-bottom:20px;
	position: relative;
}
.act_notice:after{
	position: absolute;
	content: '';
	width: 200px;
	left: 50%;
	bottom: 0;
	border-bottom:1px solid #707070;
	margin-left: -100px;
}
.policy_notice{
	font-size: 24px;
	color:#707070;
	line-height:50px;
}
@media(max-width: 1001px){
	.pop-sel select{
		font-size: 18px;
	}
}
@media (min-width:769px){
	body, html {
	    min-width:1200px;
	}
	body{
		padding-top:70px;
	}
	.container-fluid{
		min-width:1200px;
	}
	.menu-list li a:hover:after{
		opacity: 1;
		transition: all 0.4s ease;
		-webkit-transition: all 0.4s ease;
		-moz-transition: all 0.4s ease;
		-o-transition: all 0.4s ease;
	}
	.menu-list li.fb-link a:hover:after{
		opacity: 0;
		display: none;
	}
	.m-show{
		display:none!important;
	}
	
}
@media(max-width: 1800px)
{
	.block-three{
		margin-top: 0;
	}
	.block-two .inner {
		width: 1100px;
		height: 695px;
		background-size: 50%;
	}
	.block-two .inner .word{
	    cursor: pointer;
	    z-index: 1;
	    position: absolute;
	    top: 27%;
    	right: 10%;
	}
	.block-two .inner .yt_1 {
	    cursor: pointer;
	    z-index: 1;
	    position: absolute;
	    top: 32%;
	    left: 22%;
	    width: 25%;
	}
	.block-two .inner .yt_2 {
	    cursor: pointer;
	    z-index: 0;
	    position: absolute;
	    top: 4.5%;
	    left: 2.5%;
	    width: 36%;
	}
}
@media(max-width: 1259px)
{
	.block-two .inner{
		width: 1200px;
	}
}
@media (max-width:768px){
	.pc-show{
		display:none!important;
	}
	.two-col{
		width:100%;
	}
	.container-half{
		float:none!important;
		margin-left: auto;
		margin-right: auto;
	}
	/*---Header---*/
	.header{
		z-index:1000;
		min-height:0;
		position: absolute;
    	top: 0;
    	width: 100%;
	}

	.mobile-header{
		position: relative;
		z-index:1001;
		height: 60px;
	}
	.logo{
		left:15px;
		top: 15px;
	}

	.menu{
		width:100%;
		height:110%;
		position:fixed;
		top:0;
		left:0;
		opacity:0;
		visibility: hidden;
		background-color: rgba(0,0,0,0.7);
		overflow:hidden;
	}
	.menu-container{
		width:100%;
		position: absolute;
		top: 50%;
		margin-top:-220px;
		overflow-y: auto;
	}
	#menu-one .m-show{
		width: 37.76%;
	}
	#menu-two .m-show{
		width: 58.33%;
	}
	#menu-three .m-show{
		width: 37.76%;
	}
	#menu-four .m-show{
		width: 37.76%;
	}
	#mobile-menu-btn{
		display:block;
		z-index:1002;
	}
	#mobile-menu-btn.open + .menu{
		visibility: visible;
		opacity:1;
		transition: opacity 0.4s ease,visibility 0.4s ease;
		-webkit-transition: opacity 0.4s ease,visibility 0.4s ease;
		-moz-transition: opacity 0.4s ease,visibility 0.4s ease;
		-o-transition: opacity 0.4s ease,visibility 0.4s ease;
	}
	
	/*---Footer---*/
	
	/*---block one---*/
	.block-one .inner{
		width: 100%;
	}
	.block-one{
		background: url(../images/haku_kv_m.jpg) center center no-repeat;
	    background-position-y: 0;
	    background-size: cover;
	    height: 155.16667vw;
	    width: 100%;
	    overflow: hidden;
	}
	/*---block two---*/
	.block-two .inner{
		width: 100%;
		height: 152.22222vw;
		background: none;
		margin-top: 45px;
	}
	.block-two .inner .word{
	    cursor: pointer;
	    z-index: 1;
	    position: relative;
	    top: 0;
	    left: 0;
	}
	.block-two .inner .yt_1{
		width: 52.475%;
	    cursor: pointer;
	    z-index: 1;
	    position: absolute;
	    top: 31.5%;
	    right: 0;
	    left: inherit;
	}
	.block-two .inner .yt_2{
    	width:71.095%;
	    cursor: pointer;
	    z-index: 0;
	    position: absolute;
	    top: 40.8%;
    	left: 0;
	}
	
	/*---block three---*/
	.block-three{
	    background: url(../images/haku_block3_bg_m.png) top center no-repeat;
	    overflow: hidden;
	    margin-top: 0;
	}
	.block-three .inner {
		width: 100%;
	    height: 245.75926vw;
    	position: relative;
	    padding-top: 120px;
	    margin-bottom: 20px;
	}
	.block-three .inner .subtitle{
	    position: absolute;
	    z-index: 1;
	    width: 51.66667vw;
	    top: 103.88889vw;
	    right: 4.62963vw;
	}
	.block-three #CardContainer{
		position: relative;
	}
	.block-three #CardContainer #CharH {
	    top: 34.81481vw;
	    left: 15.92593vw;
	    animation-delay: 0s;;
	}
	.block-three #CardContainer #CharA {
	    top: 47.96296vw;
	    left: 52.87037vw;
	    animation-delay: 0.7s;
	}
	.block-three  #CardContainer #CharA:after {
		content: '';
	    position: absolute;
	    width: 17.96296vw;
	    height: 23.24074vw;
	    background: url(../images/haku_block3_cardA_m_after.png) 0 0 no-repeat;
	    background-size: cover;
	    z-index: 3;
	    top: -19.24074vw;
    	right: -5vw;
	}
	.block-three #CardContainer #CharK {
	    top: 131.75926vw;
	    left: 15.92593vw;
	    animation-delay: 1.4s;
	}
	.block-three #CardContainer #CharK:after {
		content: '';
	    position: absolute;
	    width: 19.72222vw;
	    height: 32.22222vw;
	    background: url(../images/haku_block3_cardK_m_after.png) 0 0 no-repeat;
	    background-size: cover;
	    z-index: 3;
	    top: -26.5vw;
    	left: 6vw;
	}
	.block-three #CardContainer #CharU {
	    top: 122.87037vw;
	    left: 52.96296vw;
	    animation-delay: 2.1s;
	}
	.block-three #CardContainer .char {
	    position: absolute;
	    width: 31.75926vw;
	    height: 59.72222vw;
	    animation-iteration-count: infinite;
	    animation-duration: 3s;
	    animation-fill-mode: both;
	}
	.block-three #CardContainer .char > * {
	    position: absolute;
	}
	.block-three #CardContainer .char .bgImg {
	    width: 100%;
	    height: 100%;
	    z-index: 1;
	    top: 0;
	    left: 0;
	}
	.block-three #CardContainer #CharH .bgImg {
		background: url(../images/haku_block3_cardH_m.png) 0 0 no-repeat;
		background-size: cover;
	}
	.block-three #CardContainer #CharA .bgImg {
		background: url(../images/haku_block3_cardA_m.png) 0 0 no-repeat;
		background-size: cover;
	}
	.block-three #CardContainer #CharK .bgImg {
		background: url(../images/haku_block3_cardK_m.png) 0 0 no-repeat;
		background-size: cover;
	}
	.block-three #CardContainer #CharU .bgImg {
		background: url(../images/haku_block3_cardU_m.png) 0 0 no-repeat;
		background-size: cover;
	}
	.block-three #CardResult.charH {
	    background: url(../images/haku_block3_cardH_open_text_m.png) 0 0 no-repeat;
	    background-size: cover;
	}
	.block-three #CardGame #CardResult #card.charH {
	    background: url(../images/haku_block3_cardH_open_card_m.png) 0 0 no-repeat;
	    background-size: cover;
	}
	.block-three #CardResult.charA {
	    background: url(../images/haku_block3_cardA_open_text_m.png) 0 0 no-repeat;
	    background-size: cover;
	}
	.block-three #CardGame #CardResult #card.charA {
	    background: url(../images/haku_block3_cardA_open_card_m.png) 0 0 no-repeat;
	    background-size: cover;
	}
	.block-three #CardResult.charK {
	    background: url(../images/haku_block3_cardK_open_text_m.png) 0 0 no-repeat;
	    background-size: cover;
	}
	.block-three #CardGame #CardResult #card.charK {
	    background: url(../images/haku_block3_cardK_open_card_m.png) 0 0 no-repeat;
	    background-size: cover;
	}
	.block-three #CardResult.charU {
	    background: url(../images/haku_block3_cardU_open_text_m.png) 0 0 no-repeat;
	    background-size: cover;
	}
	.block-three #CardGame #CardResult #card.charU {
	    background: url(../images/haku_block3_cardU_open_card_m.png) 0 0 no-repeat;
	    background-size: cover;
	}
	.block-three #CardGame #CardResult {
	    display: none;
	    position: relative;
	    width: 100vw;
	    height: 140.18519vw;
	    margin-top: 90px;
	}
	.block-three #CardGame #CardResult #card {
	    position: absolute;
	    width: 35.83333vw;
	    height: 65.37037vw;
	    top: 16.66667vw;
	    left: 41.66667vw;
	}
	/*---block four---*/
	.block-four .inner{
		width: 100%;
	    height: 105.09259vw;
	    margin-top: 42px;
	    background: url(../images/haku_block4_bg_m.png) left center no-repeat;
	}
	.block-four .inner .title{
		text-align: left;
		margin-bottom: 20px;
	}
	.block-four .inner .blog_1, 
	.block-four .inner .blog_2, 
	.block-four .inner .blog_3 {
	    position: absolute;
	    width: 31.5%;
	    max-width: 380px;
	    top: 30%;
	    opacity: 0;
	    overflow: hidden;
	    cursor: pointer;
	    height: 520px;
	}

	.block-four .inner .active.blog_1,
	.block-four .inner .active.blog_2, 
	.block-four .inner .active.blog_3 {
	    top: 23.8%;
	    opacity: 1;
	}
	.block-four .inner .item{
		position: relative;
    	height: 84.62963vw;
	}
	.block-four .inner .active.blog_1 {
	    width: 41.48148vw;
	    height: 57.1vw;
	    left: 7.12963vw;
	    top: inherit;
	    bottom: 0;
	    position: absolute;
	    overflow: visible;
	}
	.block-four .inner .active.blog_1:after{
		content: '';
	    position: absolute;
	    width: 19.72222vw;
	    height: 32.22222vw;
	    background: url(../images/haku_block4_img1_m_after.png) 0 0 no-repeat;
	     background-size: contain; 
	    z-index: 3;
	    top: -26.222vw;
	    left: 0;
	}
	.block-four .inner .active.blog_2 {
	    width: 38.14815vw;
	    height: 39.5vw;
	    top: 0;
	    right: 8.7963vw;
	    left: inherit;
	    position: absolute;
	}
	.block-four .inner .active.blog_3 {
	    width: 38.14815vw;
	    height: 39.5vw;
	    top: inherit;
	    bottom: 0;
	    left: inherit;
	    right: 8.7963vw;
	    position: absolute;
	}
	.block-four .inner .blog_1 img,
	.block-four .inner .blog_2 img, 
	.block-four .inner .blog_3 img {
	    position: relative;
	    transition: all 0.5s ease-out;
	    top: 50%;
	    left: 50%;
	    transform: translate(-50%, -50%);
	}
	.block-four .inner .blog_1:hover img, 
	.block-four .inner .blog_2:hover img, 
	.block-four .inner .blog_3:hover img {
	    width: 102%;
	    position: relative;
	    top: 50%;
	    left: 50%;
	    transform: translate(-50%, -50%);
	    max-width: 102%;
	}
	.block-four .inner .shadow {
	    box-shadow: 1.38889vw 1.38889vw 0px rgba(0, 0, 0, 0.09);
	}
	/*---block mapform---*/
	.block-five .inner{
		width: 100%;
	}
	.block-mapform {

	}
	.form_header{
		border: none;
	    padding-bottom: 17%;
	    margin: 0 0 0 40%;
	}
	.form_inner, .success-page {
	    max-width: 100%;
	    margin-left: 0;
	}
	.form-container {
    	padding-top: 110%;
    	padding:0 4% 0;
	}
	#map_loading{
		width:100%;
		height:24%;
		left:0%;
		top:-3%;
	}
	.counter_select{
		width:100%;
		margin-bottom:20px;
	}
	.counter_select li{
		width:100%;
		margin: 0 0 20px;
	}
	.counter{
		display:none;
	}
	.map{
		width:100%;
		margin-bottom:30px;
	}
	.google_map{
		width:100%;
		height:350px;
	}
	.counter_ul{
		height: auto;
	    max-height: 390px;
	    min-height: 150px;
	    padding-bottom: 15px;
	}
	.counter_list{
		width:100%;
		height:auto;
	}
	.counter_ul li{
		padding:0 20px;
	}
	.list_title{
		width:100%;
	}
	.form_page{
		margin: 0;
    	height: auto;
	}
	.form_content{
		width:100%;
		max-width: 100%;
		margin:0;
		padding: 0 0 30px;
	}
	.form_header{
		border:none;
		padding-bottom:26%;
	}
	.form-input{
		padding: 1.5%;
	}
	.s_title{
		max-width: 100%;
		margin-bottom:10px;
	}
	.s_tel{
		display:block;
		margin-bottom:5px;
	}
	.s_addr{
		display:block;
	}
	.form_body, .success-page{
		padding:0;
	}
	.input_row{
		width:100%;
		padding-left: 90px;
	}
	.input_row span{
		font-size: 20px;
	}
	.d_info{
		min-height:20px;
	}
	.form-checkbox-input label{
	    font-size: 24px;
	    line-height: 26px;
	    margin:0 20px 30px 0;
	}
	.form-checkbox-input label.any_y{
	    margin-left: 55px;
	}
	.notice{
		display:block;
		font-size: 24px;
		padding-left: 55px;
		margin-top:10px;
	}
	.form-checkbox-input{
		margin:20px 0 30px;
	}
	.form-checkbox-input .radio-label{
		display: block;
		margin:0 0 30px 0;
	}
	.tips{
		width: 100%;
		margin:0 auto 30px;
	}
	.form-btn-box{
		width:100%;
	}
	.dp_p2{
		top: 0;
	}
	.counter_ok{
		width:100%;
	}
	/*---block form---*/
	.back-btn{
		width:100%;
		margin-right:0;
		margin-bottom: 20px;
	}
	.send-btn{
		width:100%;
	}
	.resend-btn{
		width:100%;
		font-size: 3vw;
	}
	.is-end{
		width: 100%;
    	top: 45%;
    	left: 0;
    	font-size: 14px;
    	font-size: 4vw;
	}
	.success-page .info{
		font-size:4vw;
	}
	.msg{
		font-size:5vw;
	}
	.copyright{
		background: #fff3cd;
		text-align:center;
		padding:10px 20px 1%;
	}
	
	#menu-three-target{
		top:12%;
	}
	.menu-list{
		width: 100%;
    	margin: 60px auto 10px;
		text-align:center;
	}
	.menu-list li,
	.menu-list a{
		width:100%;
		display:block;
	}
	.menu-list li{
		padding:0;
	}
	.menu-list a{
		color:#fff;
		padding:30px;
	}
	.menu-list li:not(:last-child){
		border:0;
	}
	.map > div.google_map {
	    border-right:3px solid #b6b6b6;
	    border-radius: 0;
	}
	.act_notice{
		font-size: 36px;
	}
	.act_notice:after{
		width: 150px;
		margin-left: -75px;
	}
	/*pop*/
	.pop-container{
	    height: auto;
		padding-top: 170%;
		background: url(../images/haku_mapform_pop.png) no-repeat;
		background-size: 100%;
	}
	.resend-btn {
		height: auto;
    	padding-top: 12%;
	    background: url(../images/haku_mapform_resend.jpg) no-repeat;
	    background-size: 100%;
	    top: 54.3%;
	    left:0;
	}
	.pop-sel-wrap{
		width: 59.7%;
		position: absolute;
		top: 84%;
	    left: 27.4%;
	    padding-top:7%;
	}
	.pop-sel {
	    width: 100%;
	    height:100%;
	    left:0;
	    top:0;
	    position: absolute;
	}
	.pop-sel select {
	    float: left;
	    width: 32.717%;
	   	height: 100%;
	    font-size: 18px;
	    padding: 0 10% 0 5px;
	    margin-right: 0.9245%;
	    background-size: 30%;
	}
	.pop-sel select:last-child{
		margin-right: 0;
	}
	.pop-check-btn {
	    width: 57%;
	    height: auto;
	    padding-top: 7%;
	    position: absolute;
	    top: 89.2%;
	    left: 29%;
	    background: url(../images/haku_mapform_pop_check.png) no-repeat;
	    background-size: 100%;
	}
	.pop-close{
		width: 7.11%;
    	height: auto;
    	padding-top: 12%;
		position:absolute;
		right: 3%;
		top:0px;
		cursor:pointer;
	}
	.pop-close:after{
		background-size: 100%;
	}
	.block-five {
	    margin-top: 70px;
	}
	.pop-window{
		width:100%;
		max-width:425px;
	}
	.pop-up:before{
		content: normal;
	}
}

@media(max-width: 500px){
    .block-two .inner .yt_1{
	    top: 40.5%;
	}
	.block-two .inner .yt_2{
	    top: 51.8%;
	}
	.counter_ul input[type=radio]:checked+label span{
		background-size: 100%;
	}
	.counter_ul label span,
	.checkbox-label:before{
		width: 32px;
		height: 32px;
	}
	.form-checkbox-input input:checked + .checkbox-label:after
	{
	    left: 4px;
	    top: 0;
	    width: 32px;
	    height: 32px;
	    background-size: 82%;
	}
	.form_header {
	    padding-bottom: 14%;
	}
	.form-checkbox-input label,
	.notice{
		font-size: 18px;
	}
	.pop-sel select {
	    font-size: 14px;
	}
	.s_title {
	    font-size: 24px;
	}
	.s_tel, .s_addr {
	    font-size: 20px;
	    padding-left: 10%;
	}
	.counter_select li,
	.list_title{
		font-size: 24px;
	}
	.s_tel:before, .s_addr:before {
	    width: 8.2%;
	    height: 5.6vw;
	    left: 0;
	    top: 13%;
	    background-size: 90%;
	}
	.act_notice{
		font-size: 24px;
	}
	.act_notice:after {
	    position: absolute;
	    content: '';
	    width: 120px;
	    left: 50%;
	    bottom: 0;
	    margin-left: -60px;
	}
	.policy_notice{
		font-size: 16px;
		line-height:36px;
	}
}
@media (max-width:768px) and (min-height:500px){
	.menu-container{
		height:auto!important;
	}
}
@media (max-width:768px) and (max-height:500px){
	.menu-container{
		top: 0;
    	height: 100%;
		-webkit-transform:none;
		-ms-transform:none;
		margin-top:0;
		padding-bottom:30px;
	}
}

#confirm-btn.btn[disabled]{
	opacity:1;
}
#confirm-btn.submitting .fa,
#confirm-btn .sp{
	display:none;
}
#confirm-btn.submitting .sp{
	display:inline-block;
}

@-webkit-keyframes spScaleAlpha {
  0% {
    opacity: 1;
  }
  33% {
    opacity: 0.25;
  }
  66% {
    opacity: 0.25;
  }
  100% {
    opacity: 1;
  }
}
@keyframes spScaleAlpha {
  0% {
    opacity: 1;
  }
  33% {
    opacity: 0.25;
  }
  66% {
    opacity: 0.25;
  }
  100% {
    opacity: 1;
  }
}
@-webkit-keyframes spScaleAlphaBefore {
  0% {
    opacity: 0.25;
  }
  33% {
    opacity: 1;
  }
  66% {
    opacity: 0.25;
  }
}
@keyframes spScaleAlphaBefore {
  0% {
    opacity: 0.25;
  }
  33% {
    opacity: 1;
  }
  66% {
    opacity: 0.25;
  }
}
@-webkit-keyframes spScaleAlphaAfter {
  33% {
    opacity: 0.25;
  }
  66% {
    opacity: 1;
  }
  100% {
    opacity: 0.25;
  }
}
@keyframes spScaleAlphaAfter {
  33% {
    opacity: 0.25;
  }
  66% {
    opacity: 1;
  }
  100% {
    opacity: 0.25;
  }
}
@-webkit-keyframes scaleBtn {
  0% {
  	-webkit-transform: scale(1);
  	transform: scale(1);
  }
  50% {
  	-webkit-transform: scale(1.2);
  	transform: scale(1.2);
  }
  100% { 
  	-webkit-transform: scale(1);
  	transform: scale(1);
  }
}
@keyframes scaleBtn {
  0% {
  	-webkit-transform: scale(1);
  	transform: scale(1);
  }
  50% {
  	-webkit-transform: scale(1.2);
  	transform: scale(1.2);
  }
  100% { 
  	-webkit-transform: scale(1);
  	transform: scale(1);
  }
}

.sp-3balls, .sp-3balls:before, .sp-3balls:after {
  border-radius: 50%;
  background-color: #000;
  width: 7px;
  height: 7px;
  transform-origin: center center;
  display: inline-block;
}
.sp-3balls {
  position:absolute;
  left: 50%;
  margin-left:-3.5px;
  top: 45%;
  opacity: 1;
  -webkit-animation: spScaleAlpha 1s infinite linear;
  animation: spScaleAlpha 1s infinite linear;
}
.sp-3balls:before, .sp-3balls:after {
  content: '';
  position: absolute;
  opacity: 0.25;
}
.sp-3balls:before {
  left: 11px;
  top: 0px;
  -webkit-animation: spScaleAlphaBefore 1s infinite linear;
  animation: spScaleAlphaBefore 1s infinite linear;
}
.sp-3balls:after {
  left: -11px;
  top: 0px;
  -webkit-animation: spScaleAlphaAfter 1s infinite linear;
  animation: spScaleAlphaAfter 1s infinite linear;
}
@media (max-width: 560px)
{
	.block-three .inner .subtitle {
	    top: 98.88889vw;
	}
}
@media(max-width: 490px)
{
	.menu-list a{
		padding: 30px;
	}
}
@media(max-width: 390px)
{
	.block-three .inner .subtitle {
	    top: 91.88889vw;
	}
	#mobile-menu-btn{
		left: 20px;
    	top: 28px;
    	height: 44px;
    }
    #mobile-menu-btn span:nth-child(2),
	#mobile-menu-btn span:nth-child(3){
		top: 15px;
	}
	#mobile-menu-btn span:nth-child(4) {
		top: 30px;
	}
	.menu-list{
		margin-top: 0;
	}
}
@media(max-width: 360px)
{
	.block-three .inner .subtitle {
	    top: 90.88889vw;
	}
}
@keyframes bb {
  6%, 17%, 26%, from, to {
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    transform: translate3d(0, 0, 0);
  }
  13%, 14% {
    animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    transform: translate3d(0, -30px, 0);
  }
  23% {
    animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    transform: translate3d(0, -15px, 0);
  }
  30% {
    transform: translate3d(0, -4px, 0);
  }
  33% {
    transform: translate3d(0, 0, 0);
  }
}

.bb {
  animation-name: bb;
  transform-origin: center bottom;
}

@keyframes card_bb {
  6%, 17%, 26%, from, to {
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    transform: translate3d(0, 0, 0);
  }
  13%, 14% {
    animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    transform: translate3d(0, -30px, 0);
  }
  23% {
    animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    transform: translate3d(0, -15px, 0);
  }
  30% {
    transform: translate3d(0, -4px, 0);
  }
  33% {
    transform: translate3d(0, 0, 0);
  }
}

.card_bb {
  animation-name: card_bb;
  transform-origin: center bottom;
  animation-duration: 3s;
  animation-iteration-count: infinite;
}