section h2{
	text-align: center;
}

section h2 span.en{
	font-size: 8pt;
	color: #fff;
}

/* plan-common */
/* --- PC ---------- */
@media print, screen and (min-width: 741px) {
	.plan-common .main-title{
		background: url("../images/plan/plan-bk.jpg") center top no-repeat;
		background-size: cover;
	}
	
	.contents{
		max-width: 1200px;
		width: 90%;
		margin: 50px auto;
		text-align: center;
		font-size: 90%;
	}
	
	.plan-body{
		background-color: var(--bk-col02);
		background-image: url(../images/top/img-bk02.png);
		padding: 80px 0;
		margin: 70px 0 0;
		position: relative;
	}
	
	.plan-body::after {
		position: absolute;
		content: "";
		width: 1px;
		height: 80px;
		background: var(--main-color01);
		left: 50%;
		top: -40px;
	}
	
	.plan-body .w-common{
		display: -webkit-flex;
		display: flex;
		-webkit-flex-wrap: nowrap;
		flex-wrap: nowrap;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: center;
	}
}

/* --- SP ---------- */
@media print, screen and (max-width: 740px) {
	.plan-common .main-title{
		background: url("../images/plan/plan-bk.jpg") 81% top no-repeat;
		background-size: cover;
	}
	
	.contents {
		width: 90%;
		margin: 30px auto;
		text-align: center;
		font-size: 90%;
	}
	
	.plan-body{
		background: var(--bk-col02);
		padding: 50px 0 20px;
		margin: 50px 0 0;
		position: relative;
	}
	
	.plan-body::after {
		position: absolute;
		content: "";
		width: 1px;
		height: 60px;
		background: var(--main-color01);
		left: 50%;
		top: -30px;
	}
}


/* plan.html */
/* --- SP ---------- */
@media print, screen and (max-width: 740px) {
	.plan h2{
		font-size: 1.17em;
		line-height: 1.5em;
	}
	
	.plan .plan-wrap{
		margin: 0 auto 4em;
		max-width: 520px;
	}
	
	.plan .plan-wrap:last-child{
		margin-bottom: 0;
	}
	
	.plan .plan-wrap a{
		display: block;
		width: 100%;
		position: relative;
		text-align: center;
	}

	.plan .plan-wrap a img{
		position: relative;
		line-height: 0;
		display: block;
		opacity: 0.74;
		transition-duration: 0.3s;
	}

	.plan .plan-wrap a:hover img{
		opacity: 1;
		transition-duration: 0.3s;
	}

	.plan .plan-wrap .bk-filter{
		background: #000;
	}

	.plan .plan-wrap a:hover img.bk{
		filter: alpha(opacity=10);
		-moz-opacity: 0.10;
		opacity: 0.10;
	}
	
	.plan .plan-wrap a div.title{
		position: absolute;
		width: 100%;
		height: 100px;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		border: 0;
		margin: auto;
		padding: 0;
	}

	.plan .plan-wrap a h2{
		margin: 0;
		padding: 0;
		border: 0;
		color: #fff;
	}

	.plan .plan-wrap a h2 span.en{
		font-size: 24pt;
		font-style: italic;
		line-height: 130%;
		font-family: 'Noto Serif JP', serif;
	}	
	
	.plan .plan-wrap p{
		font-size: 80%;
		margin-top: 10px;
		line-height: 1.75em;
		letter-spacing: 0;
	}
}

@media print, screen and (max-width: 480px) {
	.plan .plan-wrap{
		width: 100%;
		margin-top: 10px;
	}
	
	.plan .plan-wrap:first-child{
		margin-top: 0;
	}

	.plan .plan-wrap a div.title{
		height: 80px;
	}
}

/* --- PC ---------- */
@media print, screen and (min-width: 741px) {	
	.plan h2{
		font-size: 1.17em;
	}

	.plan .plan-wrap{
		width: 42%;
		padding: 0 2%;
	}

	.plan .plan-wrap a{
		display: block;
		width: 100%;
		position: relative;
		text-align: center;
	}

	.plan .plan-wrap a img{
		position: relative;
		line-height: 0;
		display: block;
		opacity: 0.74;
		transition-duration: 0.3s;
	}

	.plan .plan-wrap a:hover img{
		opacity: 1;
		transition-duration: 0.3s;
	}

	.plan .plan-wrap .bk-filter{
		background: #000;
	}

	.plan .plan-wrap a:hover img.bk{
		filter: alpha(opacity=10);
		-moz-opacity: 0.10;
		opacity: 0.10;
	}
	
	.plan .plan-wrap a div.title{
		position: absolute;
		width: 100%;
		height: 100px;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		border: 0;
		margin: auto;
		padding: 0;
	}

	.plan .plan-wrap a h2{
		margin: 0;
		padding: 0;
		border: 0;
		color: #fff;
	}

	.plan .plan-wrap a h2 span.en{
		font-size: 40pt;
		font-style: italic;
		line-height: 130%;
		font-family: 'Noto Serif JP', serif;
	}	
	
	.plan .plan-wrap p{
		font-size: 80%;
		text-align: center;
		margin-top: 10px;
		line-height: 1.75em;
		letter-spacing: 0;
	}
}

@media print, screen and (min-width: 741px) and (max-width: 1300px) {
	main{
		font-size: 90%;
	}
}

@media print, screen and (min-width: 1101px) and (max-width: 1300px){
	.plan .plan-wrap a h2 span.en{
		font-size: 32pt;
	}

	.plan .plan-wrap p{
		font-size: 85%;
	}
}

@media print, screen and (min-width: 881px) and (max-width: 1100px){
	main{
		font-size: 85%;
	}
}

@media print, screen and (min-width: 741px) and (max-width: 880px) {
	main{
		font-size: 80%;
	}

	.plan .plan-wrap a h2 span.en{
		font-size: 24pt;
	}

	.plan .plan-wrap p{
		font-size: 80%;
	}
}




/*　特典アコーディオン　共通　*/

.plan-lists{
	width: 100%;
}

.plan-check{
    display: none;
}

.plan-label{
    background: #fff;
    color: #333;
    display: block;
    padding: 15px 10px 16px 110px;
    position: relative;
    cursor: pointer;
    counter-increment: num;
    font-size: 21px;
    font-weight: bold;
	letter-spacing: 1px;
}

.plan-label span{
	font-size: 140%;
}

.plan-label::after{
    content: '';
	width: 60px;
	height: 100%;
	background: url(../images/plan/ico-open.png) no-repeat center center;
    position: absolute;
    right: 0;
    top: 0px;
}

.plan-label::before{
	content: "特典."counter(num)"";
	text-align: center;
    position: absolute;
    left: 0;
    top: 0;
	background: var(--accent-col02);
	color: #fff;
	font-size: 80%;
	width: 90px;
	padding: 17px 0;
	font-family: 'Noto serif JP', sans-serif;
	letter-spacing: 0;
}

.plan-content{
	background-color: #f8f8f8;
    display: flex;
	flex-wrap: nowrap;
	align-items: center;
	justify-content: space-between;
    height: 0;
    opacity: 0;
    padding: 0 10px;
    visibility: hidden;
	margin: 0 0 20px;
}

.plan-content p{
	margin: 0;
	letter-spacing: 0;
}

.plan-content .plan-img{
	margin-left: 3.2%;
}

.plan-content p .small{
	font-size: 80%;
	color: #888;
}

.plan-check:checked + .plan-label::after{
    content: '';
	background: url(../images/plan/ico-close.png) no-repeat center center;
}

.plan-check:checked + .plan-label + .plan-content{
    height: auto;
    opacity: 1;
    padding: 3%;
    visibility: visible;	
}

.plan-type .notice{
	width: 100%;
	padding: 15px 0;
	background: repeating-linear-gradient(-45deg, #acf4e1, #acf4e1 10px, #c2f7ea 0, #c2f7ea 20px);
}

.plan-type .notice-inner{
	background-color: rgba( 255, 255, 255, 0.75 );
	width: 100%;
	margin: auto;
	padding: 2% 0;
}

.plan-type .notice-inner p{
	text-align: center;
	font-size: 150%;
	color: var(--main-color01);
	font-weight: bold;
}


/* plan-buy.html plan-rental.html*/
/* --- SP ---------- */
@media print, screen and (max-width: 740px) {
	
	.plan-label{
		padding: 30px 5px 5px 5px;
		position: relative;
		cursor: pointer;
		font-size: 12px;
		text-align: left;
	}
	
	.plan-label::before{
		content: "特典."counter(num)"";
		text-align: center;
		position: absolute;
		font-size: 100%;
		width: 100%;
		padding: 0;
		letter-spacing: 0;
	}
	
	.plan-label::after{
		width: 15px;
		height: 15px;
		right: 10px;
		top: 35px;
	}
	
	.plan-content{
		flex-wrap: wrap;
		align-items: center;
	}
	
	.plan-content p{
		width: 100%;
		font-size: 80%;
		line-height: 1.75em;
		order: 2;
	}
	
	.plan-content .plan-img{
		margin: 0 auto 10px;
		width: 80%;
		max-width: 260px;
	}
	
	.plan-check:checked + .plan-label + .plan-content{
		padding: 20px;
	}
	
	.plan-type .notice-inner p{
		font-size: 90%;
		letter-spacing: 0;
	}	
}

/* --- PC ---------- */
@media print, screen and (min-width: 741px) {
	.plan-type h2{
		color: var(--main-color01);
		font-size: 210%;
		text-align: center;
		padding: 0 0 100px;
		margin: 0;
		background: url(../images/top/h2-deco02.png) center 60px no-repeat;
		font-family: 'Noto serif JP', sans-serif;
		font-style: italic;
	}
}



/*  特典ページ 2025  */

.plan-new ul {
	margin: 0;
	padding: 0;
	list-style-type: none;
}

.plan-new{
	word-break: break-all;
	box-sizing: border-box;
}

.flow-list-wrap ul li .circle{
	position: relative;
}

.flow-list-wrap ul li .flow-btn{
	background-color: #FFF;
	border-radius: 15px;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 15px 0;
	text-decoration: none;
	font-weight: bold;
}

.plan-new.buy .flow-list-wrap ul li .flow-btn{
	border: 1px solid #E6326E;
	color: #E6326E;
}

.plan-new.buy .flow-list-wrap ul li .flow-btn:hover{
	box-shadow: 3px 3px 0px #E6326E5C;
}

.flow-list-wrap ul li .circle::after {
	content: '';
	display: inline-block;
	position: absolute;
}

.flow-list-wrap ul li:last-child .circle::after {
	display: none;
}

.flow-list-wrap ul li .circle span {
	width: 1em;
	height: 1em;
	border-radius: 50%;
	display: block;
	margin: 0 auto 60px;
	position: relative;
}

.plan-new.buy .flow-list-wrap ul li .circle span,
.plan-new.buy .flow-list-wrap ul li .circle::after,
.plan-new.buy .flow-list-wrap ul li .circle span::after {
	background-color: #E6326E;
}

.flow-list-wrap ul li .circle span::after {
	content: '';
	display: inline-block;
	position: absolute;
}

.plan-new .plan-body{
	background-image: url(../images/plan/nagane-bg.png);
	padding: 0;
	margin: 100px 0 0;
	position: unset;
}

.plan-new.buy .plan-body{
	background-color: #FEF2F4;
}

.plan-new .plan-body .w-common{
	display: block;
}

.plan-new .plan-body .plan-lists{
	padding: 50px 0 150px;
}

.plan-new .plan-box{
	display: flex;
	padding-top: 100px;
}

.plan-new .plan-box .plan-box-left{
	position: relative;
	margin-right: 40px;
}

.plan-new .plan-box .plan-box-left::after{
	content: '';
	display: inline-block;
	width: 3px;
	height: calc(100% + 100px);
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
}

.plan-new .plan-box:last-child .plan-box-left::after{
	display: none;
}

.plan-new .plan-box .plan-box-left .ttl-circle{
	width: 30px;
	height: 30px;
	border-radius: 50%;
}

.plan-new.buy .plan-box .plan-box-left::after,
.plan-new.buy .plan-box .plan-box-left .ttl-circle {
	background-color: #E6326E;
}

.plan-new .plan-box h2.plan-ttl{
	font-size: 26px;
	text-align: left;
	color: #000;
	padding: 0;
	margin: 0;
	background: none;
	font-family: 'Noto Sans JP',sans-serif;
	font-style: normal;
}

.plan-new .plan-box .plan-detail{
	border-radius: 15px;
	margin: 40px 0 0;
	padding: 45px;
	box-sizing: border-box;
}

.plan-new.buy .plan-box .plan-detail{
	background-color: #FFE3E6;
}

.plan-new .plan-box .plan-pickup-box:nth-of-type(n+2){
	margin-top: 45px;
}

.plan-new .plan-box .plan-pickup-box h3.pickup-ttl{
	font-size: 18px;
	margin: 0 0 1em;
}

.plan-new .plan-box .plan-pickup-box .pickup-txt{
	margin: 0;
}

.plan-new .plan-box .plan-other .other-ttl{
	font-size: 20px;
	font-weight: bold;
	padding-bottom: 0.5em;
	margin: 0 0 1em;
	border-bottom: 1px solid;
}

.plan-new.buy .plan-box .plan-other .other-ttl{
	border-bottom-color: #E6326E;
	color: #E6326E;
}

.plan-new .plan-box .plan-other ul li{
	padding-left: 1.5em;
	font-weight: bold;
	margin: 0 0 10px;
	font-size: 18px;
	position: relative;
}

.plan-new .plan-box .plan-other ul li::before{
	content: '';
	display: inline-block;
	width: 0.8em;
	height: 0.8em;
	border-radius: 50%;
	background-color: #fff;
	position: absolute;
	top: 0.3em;
	left: 0;
}

.plan-new .plan-box .plan-pickup-box.early .pickup-img{
	position: relative;
	display: flex;
	align-items: flex-start;
	justify-content: flex-start;
}

.plan-new .plan-box .plan-other ul li.early span{
	padding-right: 2.6em;
	display: inline-block;
	position: relative;
}

.plan-new .plan-box .plan-pickup-box.early .pickup-img::after,
.plan-new .plan-box .plan-other ul li.early span::after {
	content: '早得';
	display: inline-block;
	font-size: 16px;
	font-weight: normal;
	color: #fff;
	padding: 0 3px;
	border-radius: 5px;
}

.plan-new .plan-box .plan-pickup-box.early .pickup-img::after{
	position: absolute;
	top: -5px;
	right: -5px;
}

.plan-new .plan-box .plan-other ul li.early span::after {
	position: absolute;
	top: 0;
	right: 0;
}

.plan-new.buy .plan-box .plan-pickup-box.early .pickup-img::after,
.plan-new.buy .plan-box .plan-other ul li.early span::after {
	background-color: #E6326E;
}

/* --- PC ---------- */
@media print,
screen and (min-width: 741px) {
	.flow-list-wrap ul {
		display: flex;
	}

	.flow-list-wrap ul li {
		width: 15%;
		margin-right: 2%;
	}

	.flow-list-wrap ul li .circle::after {
		width: 110%;
		height: 1px;
		left: 50%;
		top: 50%;
		transform: translateY(-50%);
		-webkit-transform: translateY(-50%);
	}

	.flow-list-wrap ul li .circle span::after {
		width: 1px;
		height: 60px;
		bottom: -60px;
		left: 50%;
		transform: translateX(-50%);
		-webkit-transform: translateX(-50%);
	}

	.plan-new .plan-box .plan-pickup-box {
		display: flex;
	}

	.plan-new .plan-box .plan-pickup-box .pickup-desc {
		width: 55%;
		margin-right: 5%;
	}

	.plan-new .plan-box .plan-pickup-box .pickup-img {
		width: 40%;
	}
}

@media print,
screen and (min-width: 1000px) {
	.tab {
		display: none;
	}
}

@media print,
screen and (min-width: 1100px) {
	.plan-new .plan-box .plan-detail .plan-detail-inner .plan-pickup {
		min-width: 510px;
		width: 100%;
	}

	.plan-new .plan-box .plan-detail.half .plan-detail-inner .plan-pickup {
		max-width: 510px;
	}

	.plan-new .plan-box .plan-detail-inner.flex {
		display: flex;
	}

	.plan-new .plan-box .plan-detail-inner.flex .detail-box {
		width: 47.5%;
	}

	.plan-new .plan-box .plan-detail-inner.flex .detail-box:first-child {
		margin-right: 5%;
	}
}

@media print,
screen and (max-width: 1099px) {
	.plan-new .plan-box .plan-pickup-box .pickup-img {
		max-width: 200px;
		width: 100%;
	}

	.plan-new .plan-box .plan-detail-inner.flex .detail-box:nth-of-type(n+2) {
		margin-top: 30px;
	}
}

/* --- SP ---------- */
@media print, screen and (max-width: 740px) {
	.tab {
		display: none;
	}

	.flow-list-wrap ul li{
		display: flex;
		align-items: center;
		margin-bottom: 10px;
	}

	.flow-list-wrap ul li .circle{
		margin-right: 2em;
	}

	.flow-list-wrap ul li .circle::after{
		width: 1px;
		height: 5em;
		top: 0;
		left: 50%;
		transform: translateX(-50%);
		-webkit-transform: translateX(-50%);
	}

	.flow-list-wrap ul li .circle span{
		margin: 0;
	}

	.flow-list-wrap ul li .circle span::after{
		width: 2em;
		height: 1px;
		left: 1em;
		top: 50%;
		transform: translateY(-50%);
		-webkit-transform: translateY(-50%);
	}

	.flow-list-wrap ul li .flow-btn{
		width: 100%;
	}

	.plan-new .plan-body{
		margin-top: 50px;
	}

	.plan-new .plan-body .plan-lists{
		padding-bottom: 50px;
	}

	.plan-new .plan-box{
		padding-top: 50px;
	}

	.plan-new .plan-box .plan-box-left{
		margin-right: 10px;
	}

	.plan-new .plan-box .plan-box-left::after{
		height: calc(100% + 50px);
	}

	.plan-new .plan-box .plan-box-left .ttl-circle{
		width: 25px;
		height: 25px;
	}

	.plan-new .plan-box h2.plan-ttl{
		font-size: 22px;
	}

	.plan-new .plan-box .plan-detail{
		margin-top: 20px;
		padding: 15px;
	}

	.plan-new .plan-box .plan-pickup-box:nth-of-type(n+2){
		margin-top: 30px;
	}

	.plan-new .plan-box .plan-pickup-box h3.pickup-ttl{
		margin-bottom: 7px;
	}

	.plan-new .plan-box .plan-other .other-ttl{
		font-size: 18px;
	}

	.plan-new .plan-box .plan-other ul li{
		font-size: 16px;
		margin-bottom: 5px;
	}

	.plan-new .plan-box .plan-pickup-box .pickup-img{
		margin-top: 10px;
	}
}