@charset "UTF-8";
#site-logo {
    filter: invert(1);
    max-width: 235px;
}
#header.is-fixed #site-logo { filter: initial;}
@media screen and (max-width: 767px) {
	#site-logo { filter: initial!important;}
}
.headline01 {
    align-items: flex-start;
    min-height: auto;
    padding-left: 0;
    padding-right: 0;
    margin-bottom:50px;
}
.headline01 .inner {
    margin: 0;
    max-width: initial;
    width: auto;
}
.headline01 h2 { padding-left: 0;}
.bg-side {
	position: absolute;
	width: 300px;
	background: url(../imgs/amenities/bg_side.jpg) no-repeat top center / cover;
	top: 0;
	height: 100%;
	z-index: -1;
}
sup { line-height: 1;}
.line-h {
	height: 1px;
	position: absolute;
	top: 0;
	left: 0;
	width: 0;
	background: rgba(64, 61, 60, 0.3);
	transition: all 1s linear;
}
.on .line-h,
.line-h.on { width: 100%;}

@media screen and (min-width: 768px) and (max-width: 1000px) {
	.bg-side { width: 220px;}
}
@media screen and (max-width: 767px) {
	.bg-side { display: none;}
}
.sec-cmarea {
	display: grid;
	grid-template-columns: 250px auto;
	gap: 65px;
	padding: 160px 50px;
	position: relative;
	z-index: 0;
	min-height: 70vh;
}
.type-list .item {
	cursor: pointer;
	font-size: clamp(2rem, 1.547619047619047619vw, 2rem);
	line-height: 1;
	letter-spacing: 0.05em;
	position: relative;
	padding-left: 20px;
    color: #BEBEBE;
	transition: all 0.3s ease;
}
.type-list .item:hover { opacity: 0.7;}
.type-list .item + .item { margin-top: 20px;}
.type-list .item:before {
	background: #fff;
	border-radius: 50%;
	content: "";
	width: 6px;
	height: 6px;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	position: absolute;
	opacity: 0;
	visibility: hidden;
	transition: all 0.3s ease;
}
.type-list .item.is-active {
	opacity: 1;
	pointer-events: none;
    color: #fff;
}
.type-list .item.is-active:before {
	opacity: 1;
	visibility: visible;
}
.cmarea-anchor {
	position: relative;
	z-index: 0;
	color: #fff;
}
.cmarea-anchor.is-fixed .cmarea-select {
	position: fixed;
	top: 136px;
}
.cmarea-anchor .ttl {
	font-size: clamp(1.6rem, 1.1904761904761904762vw, 2rem);
	font-weight: 300;
	margin: 0 0 40px;
}
.cmarea-anchor.is-bottom .cmarea-select {
	position: absolute;
	top: auto;
	bottom: 0;
	left: 0 !important;
}
@media screen and (min-width: 768px) and (max-width: 1200px) {
	.sec-cmarea {
		gap: 40px;
		padding: 160px 40px;
	}
}
@media screen and (min-width: 1000px) and (max-width: 1200px) {
	.sec-cmarea { grid-template-columns: 260px auto;}
}
@media screen and (min-width: 768px) and (max-width: 1000px) {
	.sec-cmarea { grid-template-columns: 180px auto;}
}
@media screen and (max-width: 767px) {
	.sec-cmarea {
		padding: 110px 15px 80px;
		grid-template-columns: auto;
		gap: 80px;
		min-height: unset;
	}
	.cmarea-anchor {
        display: none;
        position: unset;
        z-index: unset;
    }
	.cmarea-anchor.is-bottom .cmarea-select {
		position: unset;
		top: auto;
		bottom: auto;
	}
	.cmarea-anchor.is-fixed .cmarea-select {
		top: 0;
		z-index: 1;
		background: rgba(255, 255, 255, 0.5);
		backdrop-filter: blur(20px);
		left: 0;
		padding: 15px 15px 0;
		width: 100% !important;
		position: fixed !important;
		z-index: 100;
		bottom: unset;
	}
	.cmarea-anchor .ttl { margin: 0 0 8px;}
	.is-bot .cmarea-anchor .cmarea-select {
		position: absolute !important;
		top: auto !important;
		bottom: 0 !important;
		left: 0 !important;
	}
	.type-list {
		display: flex;
		flex-wrap: wrap;
		margin: 0 -10px;
	}
	.type-list .item {
		font-size: 1.8rem;
		text-align: center;
		padding: 0 3px 5px !important;
		margin: 7px 7px 0 !important;
	}
	.type-list .item + .item { margin-top: 0;}
	.line-sp {
		width: calc(100% + 30px);
		margin-left: -15px;
		position: relative;
		height: 1px;
	}
	.type-list .item::before {
		width: 100%;
		height: 1px;
		left: 0;
		top: auto;
		bottom: -1px;
		transform: translateY(0);
		margin: auto;
		background: #000;
	}
}

.cmarea-list {
    display: grid;
    grid-template-columns: auto;
    gap: 0;
    padding-right: 45px;
}
.cmarea-item {
/*    display: flex;*/
    flex-wrap: nowrap;
    align-items: center;
    gap: 6%;
    padding-bottom: clamp(60px, 8.9285714285714285714vw, 150px);
}
.cmarea-item .image {
/*    width: 53.5%;*/
    order: 3;
}
.cmarea-item .cont {
    flex: 1;
    order: 2;
}
.sec-cmarea .ttl {
    font-size: clamp(2rem, 4.7619047619047619048vw, 8rem);
    line-height: 1;
    letter-spacing: 0;
    margin: 0 0 20px;
    color: #A78775;
}
.sec-cmarea .sub {
    font-size: 2rem;
    line-height: 1.5;
    letter-spacing: 0;
    margin: 0 0 50px;
}
.sec-cmarea .txt {
    font-size: clamp(1.4rem, 2.0119047619047619048vw, 2.3rem);
    line-height: 2;
    letter-spacing: 0;
	margin-bottom: 25px;
}
.sec-cmarea h4 {font-size: 3rem;line-height: 4rem;margin: 50px 0 20px;border-bottom: solid 1px black;
}
.acbox{margin: 45px 0 0;}
.acbox h4{
	font-size: 2.5rem;
		line-height: 2.5rem;
		margin-bottom: 10px;
}

.acbox > div{margin-bottom: 50px;}
.acbox p{position: absolute; left: 50%;  top: 50%; transform: translate(-50%,-50%);width: 100%; padding: 5px; color: #fff; background-color:rgba(0,0,0,0.4); font-size: 3rem; line-height: 4rem;text-align: center;}
span.acmini{font-size:.7em;}
span.minred{color: #C91558; font-size: 1.2em;}
.acbox p sup{font-size:.5em;}
	.airport{font-size: 2em; border-bottom: 1px solid #000; margin-bottom: 10px; justify-content: space-between;align-items: flex-end;}
.shuttle{border: 1px solid #000; padding: 15px; text-align: center; margin: 50px 0;}
.shuttlemain{font-size: 2rem; line-height: 3rem; }
.shuttlemain span{border-bottom: 1px solid #000000; display: inline-block; margin-bottom: 30px; font-size: .86em;}
.shuttlebody{ line-height: 3rem;margin-bottom: 15px;}
.shuttlebody a:link,.shuttlebody a:visited{color: #727272; }
.shuttlebody a:hover{text-decoration: underline;}
.t86{font-size: .86em; color: #727272;}
.busbox{font-size: 1.8rem; line-height: 2em;}
.bus01{margin-bottom: 75px;}
.bus01 .buslist{width: 44%;}
.brt_txt{margin: 25px auto; }
.brt_txt a:hover{text-decoration: underline;}
.bustime{border-bottom: 1px solid #000; font-size: .86em;}
.bustime2{margin-left: 1em;}
.sta{font-size: 1.3em;}
@media screen and (min-width: 767px){
.shuttle{display: inline-block; display: flex; justify-content: space-around; padding: 15px;}
.shuttlemain{font-size: 4rem; line-height: 5rem; }
.busbox{margin: 50px;font-size: 2.5rem;}
.bus01{display: flex;justify-content: space-between; align-items: flex-end;}
.bus01 .busmap{width: 55%;}
.bus01 .buslist{width: 44%;}
.carbox{display: flex; flex-direction: row-reverse;}
.cartxt{width: 65%; margin-left: 20px;}
}
@media screen and (max-width: 767px){
.shuttlemain span{font-size: 1.2em;}
.shuttlebody{ font-size: .86em; text-align: left;}
.shuttlesub{font-size: .86em;}
}
@media screen and (min-width: 767px){
	.acbox{display: flex; flex-wrap: wrap; justify-content: space-between;}
	.acbox > div{width: 31%;}
	.acbox > div.pe{width: 48%;}
	.acbox::after {
display: block;
content:"";
width: 31%;
}
}
.busTable {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 15px;
}
.busTable th,
.busTable td {
  padding: 10px;
  border: 1px solid #888;
  background: #fff;
}
.busTable th {
  font-weight: normal;
  text-align: center;
  background: #D1C4AF;
}
.busTable .small {
  font-size: 0.8em;
}
@media only screen and (max-width: 768px) {
  .busTable {
    display: block;
    overflow-x: scroll;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
	  width: 380px;
  }
}


.cmarea-item.block-revert .image { order: 1; }
.cmarea-item:not(.block-revert) .cont{  padding-left: 8%;}
@media screen and (max-width: 1200px) {
    .cmarea-list { padding-right: 0;}
    .cmarea-item:not(.block-revert) .cont{ padding-left: 0;}
}
@media screen and (min-width:768px) and (max-width: 1200px){
    .sec-cmarea .ttl {
        font-size: 6rem;
        margin: 0 0 30px;
    }
    .cmarea-item {
        flex-wrap: wrap;
        gap: 30px;
        padding-bottom: 60px;
    }
    .cmarea-item .image { width: 100%;}
    .cmarea-item.block-revert .image {  order: 2;}
    .cmarea-item.block-revert .cont { order: 1;}
}
@media screen and (max-width: 767px) {
    .sec-cmarea .ttl {
        font-size: 4.8rem;
        margin: 0 0 20px;
    }
    .sec-cmarea .sub {
        font-size: 1.8rem;
        margin: 0 0 20px;
    }
    .sec-cmarea .txt {
        max-width: 100%;
    }
.sec-cmarea h4 {font-size: 1.8rem;}
    .cmarea-item {
        gap: 20px;
        padding-bottom: 80px;
        flex-wrap: wrap;
    }
    .cmarea-item .image {
        width: 100%;
        order: 1;
    }
    .cmarea-item .cont {
        width: 100%;
        flex: unset;
    }
    .cmarea-item .image .img {
        width: 100%;
        margin: 0 !important;
    } 
}