@charset "utf-8";
/* CSS Document */

.e-con-full {
	padding-block-end:0!important
}
h4 {
	font-size: 32px!important;
}
.elementor-14867 .elementor-element.elementor-element-a1933fe .elementor-heading-title {
    font-family: 'Beausite','Noto Serif JP', sans-serif!important;
	font-size: 32px!important;
}
div.pict {
	max-width: 1400px;
	display: flex;
	flex-wrap: wrap;
	gap: 0px 24px;
	margin: 0 auto;
	padding: 32px 0;
}
div.pict > div {
	width: 32%;
}
div.pict > div > img {
	width: 100%;
	height: auto;
}
.swiper-wrapper {
	gap: 5%;
}
.swiper-button-next,
.swiper-button-prev {
	display: none;
}
	@media only screen and (max-width: 767px) {
		h4 {
			font-size: 4.5vw!important;
			font-weight: 700!important;
			line-height: 140%!important;
		}
		.elementor-14867 .elementor-element.elementor-element-a1933fe .elementor-heading-title {
		    font-size: 4.5vw!important;
		}
		.elementor-kit-7 p {
			text-align: left!important;
			padding-bottom: 30px;
		}
		div.pict {
			width: 100%;
			overflow: hidden;
			position: relative;
		}
		div.pict > div {
			width: 100%!important;
		}
		.swiper-wrapper {
			gap: 0%;
		}
			.swiper-button-next,
		.swiper-button-prev {
			display: inline;
			color: #fff!important;
		}
		.swiper-button-next:after,
		.swiper-button-prev:after {
			font-size: 30px;
		}
		.swiper-button-next {
			right: 0;
		}
		.swiper-button-prev {
			left: 10px;
		}
		.swiper-pagination.swiper-pagination-clickable.swiper-pagination-bullets.swiper-pagination-horizontal {
			bottom: 40px;
		}
		.swiper-pagination-bullet {
			background: #fff;
			opacity: .6;
		}
		.swiper-pagination-bullet-active {
			background: #fff;
			opacity: 1;
		}
	}



div.plan-details {
	background-color: #002e52;
	padding: 72px 24px 24px 24px;
}
div.plan-details > div {
	max-width: 1400px;
	display: flex;
	flex-direction: row;
	container-widget-width: initial;
	container-widget-height: 100%;
	container-widget-flex-grow: 1;
	container-widget-align-self: stretch;
	flex-wrap-mobile: wrap;
	gap: 24px 24px;
	row-gap: 24px;
	column-gap: 24px;
	overflow: hidden;
	margin: 0 auto;
}
div.plan-details > div > div {
	width: 50%;
	color: #fff;
	box-sizing: border-box;
}
div.plan-details > div > div:nth-child(2) {
	padding: 0 0 0 48px;
}
div.plan-details > div > div img {
	width: 100%;
}
div.plan-details > div > div h3 {
	font-family: 'Noto Serif JP', sans-serif;
	font-size: 24px;
	margin-bottom: 24px;
}
div.plan-details > div > div dl {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	font-family: 'Noto Serif JP', sans-serif;
}
div.plan-details > div > div dl dt {
	width: 15%;
	line-height: 160%;
	margin-bottom: 16px;
}
div.plan-details > div > div dl dd {
	width: 85%;
	line-height: 160%;
	margin-bottom: 16px;
}
div.plan-details > div > div dl.en {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	font-family: 'Noto Serif JP', sans-serif;
}
div.plan-details > div > div dl.en dt {
	width: 100%;
	line-height: 160%;
	margin-bottom: 10px;
}
div.plan-details > div > div dl.en dd {
	width: 100%;
	line-height: 160%;
	margin-bottom: 16px;
	padding-left: 20px;
}

ul.list li {
	list-style-type: none;
	line-height: 140%;
	text-indent:-1em;
	padding-left:1em;
	padding-bottom: 8px;
}
.ls {
	letter-spacing: .25em;
}
.acd-check {
    display: none;
}
.acd-label {
	display: block;
	font-family: 'Noto Serif JP', sans-serif;
	font-size:16px;
    color: #fff;
	line-height:1.4;
    position: relative;
}
.acd-label::before {
    content: "";
    display: inline-block;
    background-image: url(./img/icon_down.png);
    background-repeat: no-repeat;
    width: 14px;
    height: 8px;
    background-size: contain;
    vertical-align: middle;
    margin: 0 8px 5px 0;
}
.acd-check:checked + .acd-label:before {
	content: "";
	display: inline-block;
	background-image: url(./img/icon_up.png);
	background-repeat: no-repeat;
	width: 14px;
	height: 8px;
	background-size: contain;
	vertical-align: middle;
	margin: 0 8px 5px 0;
}

.acd-content {
	font-size:16px;
    height: 0;
    opacity: 0;
    padding: 0 1px;
    transition: .5s;
    visibility: hidden;
}
.acd-check:checked + .acd-label + .acd-content{
    height: auto;
    opacity: 1;
    padding: 1px;
    visibility: visible;
}
.acd-content table {
	width: 100%;
}
.acd-content table td,
.acd-content table th {
	font-family: 'Noto Serif JP', sans-serif;
	font-size: 15px;
	font-weight: 400;
	padding: 5px;
}
.acd-content table th {
	white-space: nowrap;
}
.acd-content table td:nth-child(1) {
	white-space: nowrap;
}
div.btn {
	display: block;
	margin: 24px 0;
}
a.booknow {
	display: inline-block;
	font-family: 'BeausiteLight';
	color: #fff;
	background-color: #d7463c;
	padding: 16px 24px;
}
	@media only screen and (max-width: 767px) {
		div.plan-details {
			padding: 36px 24px 24px 24px;
		}
		div.plan-details > div {
			width: 100%;
			max-width: 100%;
			display: block;
		}
		div.plan-details > div > div {
			width: 100%;
		}
		div.plan-details > div > div h3 {
			font-size: 5vw;
			line-height: 120%;
			margin: 24px 0;
		}
		div.plan-details > div > div:nth-child(2) {
			padding: 0;
		}
		div.plan-details > div > div dl {
			width: 100%;
			display: block;
		}
		div.plan-details > div > div dl dt {
			width: 100%;
		}
		div.plan-details > div > div dl dd {
			width: 100%;
			padding-left: 1em;
		}
	}

div.column2 {
	max-width: 1200px;
	display: flex;
	flex-wrap: wrap;
	margin: 0 auto;
	padding: 32px 0;
}
div.column2 > div {
	width: 50%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center; /*横*/
	align-items: center;
}
div.column2 > div.txt {
	color: #333;
	line-height: 160%;
	padding: 20px;
}
div.column2 > div.txt h6 {
	width: 100%;
	color: #333;
	font-size: 20px;
	margin-bottom: 20px;
}
div.column2 > div.txt ul.notes li {
    font-family: auto;
	color: #333;
}
	@media only screen and (max-width: 767px) {
		div.column2 {
			width: 100%;
			max-width: 100%;
			display: block;
		}
		div.column2 > div {
			width: 100%;
			display: block;
		}
}
div.list-block {
	max-width: 1400px;
	display: flex;
	flex-wrap: wrap;
	background-color: rgba(6, 56, 55, 0.2);
	margin: 0 auto;
	
}
div.list-block > div {
	padding: 24px 36px;
	box-sizing: border-box;
}
div.list-block > div:nth-child(odd){
	width: 70%;
	line-height: 160%;
}
div.list-block > div:nth-child(odd) > span {
	display: block;
	font-weight: 700;
	margin-bottom: 16px;
}
div.list-block > div:nth-child(even){
	width: 30%;
	text-align: center;
}
div.list-block > div:nth-child(even) > img {
	max-height: 200px;
}
	@media only screen and (max-width: 767px) {
		div.list-block {
			width: 100%;
			max-width: 100%;
			display: block;
		}
		div.list-block > div:nth-child(odd),
		div.list-block > div:nth-child(even) {
			width: 100%;
		}
	}

ul.notes.en {
    margin:0 0 30px;
}