/*1792px*/
:root {
	--px4:0.223214vw;
	--px5:0.279018vw;
	--px5:0.279018vw;
	--px6:0.334821vw;
	--px7:0.390625vw;
	--px8:0.446429vw;
	--px9:0.502232vw;
	--px10:0.558036vw;
	--px11:0.613839vw;
	--px12:0.669643vw;
	--px13:0.725446vw;
	--px14:0.781250vw;
	--px15:0.837054vw;
	--px16:0.892857vw;
	--px17:0.948661vw;
	--px18:1.004464vw;
	--px19:1.060268vw;
	--px20:1.116071vw;
	--px21:1.171875vw;
	--px22:1.227679vw;
	--px23:1.283482vw;
	--px24:1.339286vw;
	--px25:1.395089vw;
	--px26:1.450893vw;
	--px27:1.506696vw;
	--px28:1.562500vw;
	--px29:1.618304vw;
	--px30:1.674107vw;
	--px31:1.729911vw;
	--px32:1.785714vw;
	--px33:1.841518vw;
	--px34:1.897321vw;
	--px35:1.953125vw;
	--px36:2.008929vw;
	--px37:2.064732vw;
	--px38:2.120536vw;
	--px39:2.176339vw;
	--px40:2.232143vw;
	--px41:2.287946vw;
	--px42:2.343750vw;
	--px43:2.399554vw;
	--px44:2.455357vw;
	--px45:2.511161vw;
	--px46:2.566964vw;
	--px47:2.622768vw;
	--px48:2.678571vw;
	--px49:2.734375vw;
	--px50:2.790179vw;
	--px51:2.845982vw;
	--px52:2.901786vw;
	--px53:2.957589vw;
	--px54:3.013393vw;
	--px55:3.069196vw;
	--px56:3.125000vw;
	--px57:3.180804vw;
	--px58:3.236607vw;
	--px59:3.292411vw;
	--px60:3.348214vw;
	--px61:3.404018vw;
	--px62:3.459821vw;
	--px63:3.515625vw;
	--px64:3.571429vw;
	--px65:3.627232vw;
	--px66:3.683036vw;
	--px67:3.738839vw;
	--px68:3.794643vw;
	--px69:3.850446vw;
	--px70:3.906250vw;
	--px71:3.962054vw;
	--px72:4.017857vw;
	--px73:4.073661vw;
	--px74:4.129464vw;
	--px75:4.185268vw;
	--px76:4.241071vw;
	--px77:4.296875vw;
	--px78:4.352679vw;
	--px79:4.408482vw;
	--px80:4.464286vw;

	--px100: 5.580357vw;
	--px250: 13.950892vw;
}
.rwd:after{
	content: 'ALL';
	display: none;
	position: fixed;
	z-index: 99;
	top: 0;
	left: 0;
}
body {
    font-family: 'Noto Sans TC', sans-serif;
    background-image: url(../img/bg.jpg);
}
section{
	padding: var(--px80) 0px;
}
hr{
	background-color: #555;
	opacity: .7;
}
img{
	vertical-align: middle;
	width: 100%;
}
.pic{
	position: relative;
}
.img_txt{
	position: absolute;
	right: 10px;
	bottom: 10px;
	z-index: 99;
	color: #fff;
	font-size: 12px;
	text-shadow: 1px 1px 2px #333;
}
/*============slick-slide============*/
/* the slides */
.slick-slide {
    /*margin: 0 5px;*/
}
/* the parent */
.slick-list {
    /*margin: 0 -5px;*/
}
.slick-dotted.slick-slider {
    margin-bottom: 0px;
}
.slick-dots {
	bottom: 20px;
}
.slick-dots li button:before{
	font-size: 14px;
	color: #fff;
	opacity: 1;
}
.slick-dots li.slick-active button:before{
	color: #e65a24;
	opacity: 1;
}
.slick-one .img{
	position: relative;
}
/*============文字============*/
h1{
	position: absolute;
	width: 1px;
	height: 1px;
	overflow: hidden;
}
h2{
    font-size: var(--px28);
    font-weight: 600;
    line-height: 1.5;
    color: #e75024;
}
h3{
    font-size: var(--px22);
    font-weight: 500;
    line-height: 1.5;
    color: #fff;
}
p{
    font-size: var(--px16);
    font-weight: 400;
    line-height: 1.8;
    text-align: justify;
    text-justify: inter-ideograph;
}
.en{
	font-size: var(--px26);
    font-weight: 400;
    line-height: 1.5;
    -webkit-writing-mode: vertical-lr;
	writing-mode: vertical-lr;
	position: absolute;
	right: var(--px10);
	top: var(--px80);
	letter-spacing: var(--px10);
	text-transform: uppercase;
}
/*=====手機下方選單=====*/
.menu_mobile{
	justify-content: space-between;
    position: sticky;
    bottom: -2px;
    z-index: 999;
    width: 100%;
    text-align: center;
	background-color: #000;
    z-index: 99999;
    border-top:0px solid #fff; 
}
.menu_mobile a{
    text-decoration: none;
    color: #B5B5B6;
    font-size: 12px;
    font-weight: 500 !important;
	display: block;
	width: 100%;
	padding: 10px 0;
}
.menu_mobile a + a{
	border-left: 1px solid #595757;
}
.menu_mobile i{
	display: block;
	margin-bottom: 10px;
	font-size: 16px;
}
.menu_mobile{
	display: none;
}
/*============單元============*/
.hint{
	width: var(--px60);
	height: var(--px60);
	font-size: var(--px16);
	position: fixed;
	top: 0;
	right: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	z-index: 10;
	opacity: 0;
	transition: all .3s;
}
.hint.active{
	opacity: 1;
}
.m_menu{
	display: none;
}
.topbar{
	position: fixed;
	z-index: 9;
	top: 0;
	left: 0;
	width: 100%;
	height: var(--px60);
	/*background-color: rgba(255, 255, 255, 1);*/
	background-color: #e1a865;
	display: flex;
	align-items: center;
	transition: all .3s;
}
.topbar.active{
	/*background-color: rgba(255, 255, 255, 1);*/
	background-color: #e1a865;
}
.topbar .nav{
	width: 85%;
	max-width: 1440px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.topbar .nav .logo{
	width: 10%;
	opacity: 1;
	transition: all .3s;
}
.topbar.active .nav .logo{
	opacity: 1;
}
.topbar .nav .menu{
	display: flex;
	align-items: center;
}
.topbar .nav .menu .item{
	text-decoration: none;
	color: #183e54;
	letter-spacing: 1px;
	font-size: var(--px16);
	font-weight: 400;
	white-space: nowrap;
	transition: all .3s;
}
.topbar.active .nav .menu .item{
	color: #183e54;
}
.topbar .nav .menu .item.active,
.topbar .nav .menu .item:hover{
	font-weight: 600;
	color: #183e54;
}
.topbar.active .nav .menu .item.active,
.topbar.active .nav .menu .item:hover{
	font-weight: 600;
	color: #183e54;
}
.topbar .nav .menu .item + .item{
	margin-left: var(--px25);
}
/**/
.line_btn{
	position: fixed;
	z-index: 9;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 80px;
}
.line_btn img{
	width: 100%;
}
/**/
.kv{
	width: 100%;
	height: 100vh;
	/*background-image: url(../img/kv-bg1.png);
	background-position: top left;
	background-repeat: no-repeat;
	background-size: 40%;*/
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	background-image: url(../img/kv-bg.jpg?v=1);
	background-size: cover;
	background-position: center center;
}
.kv .box{
	width: 30%;
	margin-top: 60px;
}
.kv .box .t1{
	width: 60%;
	margin: 0 auto;
}
.kv .box .main{
	background-image: url(../img/kv-main.png);
	background-size: 100%;
	width: 100%;
	padding-bottom: 100%;
}
.kv .box .t2{
	width: 70%;
	margin: 0 auto;
	display: none;
}
.kv .box .g{
	width: 10%;
	margin: 0 auto;
}
.kv .box .pic + .pic{
	margin-top: var(--px40);
}
/*.kv .bg2{
	position: absolute;
	z-index: 2;
	width: 43%;
	right: 0;
	bottom: 0;
	transform: translateY(10%);
}
.kv .box{
	width: 25%;
	position: relative;
	z-index: 3;
}
.kv .box .pic{
	position: absolute;
	width: 100%;
	top: 0;
	left: 0;
}
.kv .box .pic.t1{
	position: static;
}*/
/**/
.s1{
	position: relative;
}
.s1 .en{
	color: #e75024;
}
.s1 .box{
	width: 90%;
	max-width: 1440px;
	margin: 0 auto;
	display: flex;
	gap: 5%;
}
.s1 .box .image{
	width: 60%;
}
.s1 .box .text{
	width: 40%;
	padding: var(--px50) 0;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}
/**/
.s2{
	position: relative;
}
.s2 .en{
	color: #39aa4a;
}
.s2 .bg{
	position: absolute;
	left: 0;
	bottom: 10%;
	width: 20%;
}
.s2 .box{
	width: 90%;
	max-width: 1440px;
	margin: 0 auto;
	display: flex;
	gap: 5%;
	flex-direction: row-reverse;
	position: relative;
	z-index: 2;
}
.s2 .box .image{
	width: 60%;
}
.s2 .box .image .pic img{
	border-radius: var(--px20);
}
.s2 .box .text{
	width: 40%;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}
.s2 .box .text h2{
	color: #39aa4a;
}
/**/
.s3{
	position: relative;
}
.s3 .en{
	color: #1862a9;
}
.s3 .box{
	width: 90%;
	max-width: 1440px;
	margin: 0 auto;
	display: flex;
	gap: 5%;
}
.s3 .box .image{
	width: 60%;
}
.s3 .box .image .pic img{
	border-radius: var(--px20);
}
.s3 .box .text{
	width: 40%;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}
.s3 .box .text h2{
	color: #1862a9;
}
/**/
.s4{
	position: relative;
}
.s4 .en{
	color: #333333;
}
.s4 .box{
	width: 90%;
	max-width: 1440px;
	margin: 0 auto;
	display: flex;
}
.s4 .box .t1{
	background-image: url(../img/s4-1.jpg);
}
.s4 .box .t2{
	background-image: url(../img/s4-2.jpg);
}
.s4 .box .t3{
	background-image: url(../img/s4-3.jpg);
}
.s4 .box .t4{
	background-image: url(../img/s4-4.jpg);
}
.s4 .box .pic{
	width: 25%;
	padding-bottom: 55.68%;
	background-size: 100%;
	cursor: pointer;
	transform: scale(1.0);
	transition: all .3s;
}
.s4 .box .pic:hover{
	transform: scale(1.02);
	z-index: 3;
}
.s4 .overlayer{
	position: fixed;
	top: 0;
	left: 0;
	z-index: 98;
	width: 100%;
	height: 100vh;
	background-color: rgba(0, 0, 0, .7);
	display: none;
}
.s4 .overlayer.active{
	display: flex;
}
.s4 .t_con{
	position: fixed;
	top: 50%;
	left: 0;
	z-index: 98;
	width: 70%;
	display: flex;
	gap: 2%;
	background-color: rgba(0, 0, 0, .8);
	padding: var(--px30) var(--px30) var(--px30) var(--px80);
	transform: translateX(-100%) translateY(-50%);
	transition: all .5s;
}
.s4 .t_con.active{
	transform: translateX(0) translateY(-50%);
}
.s4 .t_con .close{
	position: absolute;
	width: var(--px30);
	top: var(--px30);
	left: var(--px30);
	cursor: pointer;
}
.s4 .t_con .image{
	width: 50%;
}
.s4 .t_con .text{
	width: 50%;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}
.s4 .t_con .text .txt{
	display: flex;
	flex-direction: column;
	align-items: center;
}
.s4 .t_con .text h2{
	font-size: var(--px26);
}
.s4 .t_con .text p{
	color: #fff;
	margin-top: var(--px20);
}
/**/
.s5{
	position: relative;
}
.s5 .en{
	color: #fff;
}
.s5{
	background-color: #e75024;
	position: relative;
}
.s5 .bg{
	position: absolute;
	z-index: 2;
	left: 0;
	bottom: -20%;
	width: 30%;
}
.s5 .box{
	width: 90%;
	max-width: 1440px;
	margin: 0 auto;
	display: flex;
	gap: 5%;
	flex-direction: row-reverse;
	position: relative;
	z-index: 2;
}
.s5 .box .image{
	width: 60%;
}
.s5 .box .image .pic img{
	border-radius: var(--px20);
}
.s5 .box .text{
	width: 40%;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}
.s5 .box .text h2,
.s5 .box .text p{
	color: #fff;
}
/**/
.s6{
	background-color: #e75024;
	position: relative;
}
.s6 .en{
	color: #fff;
	z-index: 5;
}
.s6 .bg{
	position: absolute;
	z-index: 2;
	right: 0;
	top: 10%;
	width: 18%;
}
.s6 .box{
	width: 90%;
	max-width: 1440px;
	margin: 0 auto;
	display: flex;
	gap: 5%;
	position: relative;
	z-index: 2;
}
.s6 .box .image{
	width: 60%;
}
.s6 .box .image .pic img{
	border-radius: var(--px20);
}
.s6 .box .text{
	width: 40%;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}
.s6 .box .text h2,
.s6 .box .text p{
	color: #fff;
}
.s6 .box .text p + p{
	margin-top: var(--px10);
}
.s6 .box .text p b{
	display: block;
	font-weight: 500;
	font-size: var(--px18);
}
/**/
.s7{
	position: relative;
}
.s7 .bg1{
	position: absolute;
	top: 0;
	right: 0;
	width: 30%;
}
.s7 .bg2{
	position: absolute;
	z-index: 3;
	bottom: 0;
	left: 0;
	width: 30%;
	transform: translateY(50%);
}
.s7 .box{
	width: 90%;
	height: 80vh;
	max-width: 1440px;
	margin: 0 auto;
	display: flex;
	justify-content: center;
	align-items: center;
}
.s7 .box .pic{
	width: 45%;
}
/**/
.s8{
	position: relative;
}
.s8 .en{
	color: #013567;
}
.s8 .box{
	width: 90%;
	max-width: 1440px;
	margin: 0 auto;
	display: flex;
	gap: 5%;
	flex-direction: row-reverse;
	position: relative;
	z-index: 2;
}
.s8 .box .image{
	width: 60%;
}
.s8 .box .image .pic img{
	border-radius: var(--px20);
}
.s8 .box .text{
	width: 40%;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}
.s8 .box .text h2{
	color: #013567;
}
/**/
input,
select{
	background-color: #fff;
	border-radius: 3px; 
	color: #000 !important;
	border: 0px solid #333 !important;
	font-size: 16px;
}
input[name="name"],
input[name="phone"],
select{
	height: 45px;
	width: 100%;
	margin-bottom: var(--px10);
}
input[name="note"]{
	width: 100%;
	height: 45px;
}
input[type="checkbox"]{
	transform: scale(2);
	transform-origin: left center;
	margin-right: var(--px5);
}
textarea{
	width: 100%;
	color: #000;
	font-size: 16px;
	margin-bottom: 15px;
}
::placeholder { /* Chrome, Firefox, Opera, Safari 10.1+ */
  font-size: 16px;
  color: rgba(0, 0, 0, .5) !important;
}
:-ms-input-placeholder { /* Internet Explorer 10-11 */
  font-size: 16px;
  color: rgba(0, 0, 0, .5) !important;
}
::-ms-input-placeholder { /* Microsoft Edge */
  font-size: 16px;
  color: rgba(0, 0, 0, .5) !important;
}
.reservation .box{
	width: 90%;
	max-width: 1200px;
	margin: 0 auto;
	position: relative;
	z-index: 5;
}
/*.reservation .gmap{
	position: relative;
}
.reservation .gmap:before{
	content: '';
	width: 100%;
	height: 100%;
	background-color: rgba(255, 255, 255, .2);
	position: absolute;
	top: 0;
	left: 0;
	z-index: 4;
	pointer-events: none;
}
.reservation .gmap iframe{
	-webkit-filter: grayscale(1);
}
.reservation .gmap .logo{
	position: absolute;
	z-index: 5;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	width: 20%;
}*/
.reservation form{
	display: flex;
	flex-wrap: wrap;
	align-items: flex-end;
	gap: 2%;
	margin-top: var(--px30);
	display: none;
}
.reservation form h2{
	-webkit-writing-mode: vertical-lr;
	writing-mode: vertical-lr;
	letter-spacing: var(--px4);
}
.reservation form .privacy p{
	margin-bottom: var(--px10);
}
.reservation .form_check_txt{
	color: #333;
	margin-left: 10px;
	line-height: 1.8;
}
.reservation .form_check_txt a{
	text-decoration: none;
	color: #29a0d7;
	margin-left: var(--px5);
}
.reservation .form_check_txt a:hover{
	text-decoration: underline;
	color: #29a0d7;
}
.reservation .send_btn,
.reservation .send_btn:hover{
	background-color: #e75024;
	color: #fff;
}
.reservation #send_btn{
	width: 100%;
    height: 55px;
    font-size: 26px;
    font-weight: 400;
    border: 1px solid #fff;
    margin-top: 20px;
}
.reservation .reg_btn_disabled {
    background-color: #e75024;
    cursor: no-drop;
    opacity: 0.6;
    color: #fff;
}
.reservation .reg_btn {
    background-color: #e75024;
    opacity: 1;
    color: #fff;
}
.reservation .reg_btn:hover {
    background-color: #062247;
    color: #fff;
    opacity: 1;
}
.reservation #msgerror{
	color: #333;
	font-size: 14px;
	text-align: center;
	margin-top: 10px;
}
.reservation .reg_line{
	text-align: center;
	margin-top: var(--px30);
}
.reservation .reg_line img{
	width: 80%;
	margin: 0 auto;
	margin-top: var(--px30);
}
/**/
.modal.fade h3{
	color: #333;
}
.modal-body h5{
	margin-bottom: 10px;
	color: #333;
}
.modal-body li{
	line-height: 2;
}
/**/

footer{
	background-color: #333;
}
footer p{
	background-color: #333;
	font-size: 12px;
	color: #fff;
	letter-spacing: 1px;
	text-align: center;
    text-justify: auto;
    padding: 15px 0px;
}
