@charset "UTF-8";

/*  ---------  PLAN TOP --------- */
#plan .inner--head{
	margin-bottom: clamp(30px, 6vw, 60px);
	display: flex;
	flex-direction: column;
	font-size: clamp(30px, 5.6vw, 56px);
	color: #93845e;
	line-height: 1;
}
#plan .lead{
	margin-top: 16px;
	font-size: clamp(13px, 3.2vw, 15px);
	line-height: 1.5;
}
#plan .copy-section .inner{
	padding: clamp(60px, 10vw, 100px) 0;
}
#plan .copy-section .inner--head{
	margin-bottom: 1.5em;
	display: block;
	font-size: clamp(18px, 2.5vw, 25px);
	line-height: 1.5;
	color: #333;
}
#plan .copy-section .note{
	margin-bottom: 0;
	font-size: clamp(13px, 3.25vw, 15px);
	line-height: 2.1;
	letter-spacing: -.01rem;
}
.pc-none{
	display: none;
}
.sp-none{
	display: block;
}
.is-gold{
	color: #93845e;
}
@media screen and (max-width: 767px){
	#plan .copy-section .inner--head{
		margin-bottom: 1em;
	}
	#plan .copy-section .note{
		line-height: 1.8;
	}
	.pc-none{
		display: block;
	}
	.sp-none{
		display: none;
	}
}
.superior-section{
	background: url(../img/plan/bg-superior.webp) no-repeat top center/ cover;
}
#plan .superior-section .inner--head{
	color: #333;
}
.premium-section{
	background-color: #003349;
}
.superior-section .plan-cards{
	box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
}
.superior-section .plan-cards-content{
	max-width: 100%;
	width: 100%;
	height: auto;
	flex-direction: row;
	align-items: center;
}
.superior-section .plan-ldk{
	margin-bottom: 0;
}
.plan-cards-wrap{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
	gap: 20px;
}
.plan-cards{
	width: calc(50% - 10px);
	background: #ffffff;
	background: linear-gradient(120deg,rgba(255, 255, 255, 1) 0%, rgba(204, 204, 204, 1) 100%);
}
.plan-cards:hover{
	opacity: 1;
}
.plan-cards-flex{
	width: 100%;
	flex-wrap: nowrap;
	align-items: center;
}
.plan-cards-img{
	width: calc(50% + 30px);
}
.plan-cards-img .copy{
	position: absolute;
	inset: 0;
	display: grid;
	place-items: center;
	font-size: clamp(16px, 2.2vw, 22px);
}
.plan-cards-img img{
	height: 324px;
    object-fit: cover;
}
.plan-cards-img::before{
	content: '';
	width: 100%;
	height: 100%;
	position: absolute;
	inset: 0;
	background: #000000;
	background: linear-gradient(135deg, rgba(0, 0, 0, 0.51) 0%, rgba(0, 0, 0, 0.29) 100%);
	transform: translate3d(0,0,0);
	opacity: .4;
	mix-blend-mode: multiply;
}
.plan-cards-content{
	padding: 30px 35px;
	width: calc(50% - 30px);
	max-height: 260px;
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}
.plan-name{
	margin-bottom: 10px;
	padding: 0 4px 4px;
	border-bottom: .5px solid #707070;
	font-weight: 300;
}
.helvetica-font{
	font-family: "Helvetica Neue" , Helvetica , Arial , Verdana , Roboto , "游ゴシック" , "Yu Gothic" , "游ゴシック体" , "YuGothic" , "ヒラギノ角ゴ Pro W3" , "Hiragino Kaku Gothic Pro" , "Meiryo UI" , "メイリオ" , Meiryo , "ＭＳ Ｐゴシック" , "MS PGothic" , sans-serif;
}
.plan-name .large-text{
	margin-right: 1px;
	font-size: 130%;
	font-weight: 300;
}
.plan-ldk,
.plan-wide{
	padding: 0 4px;
}
.plan-ldk{
	margin-bottom: clamp(20px, 3vw, 30px);
	font-size: clamp(14px, 2vw, 20px);
	line-height: 1.3;
}
.plan-ldk .large-text{
	font-size: 170%;
}
.plan-wide{
	font-size: clamp(20px, 2.6vw, 26px);
	line-height: 1;
}
.plan-wide .small-text{
	font-size: 12px;
}
.plan-wide-num{
	font-size: clamp(36px, 5.2vw, 52px);
}
.viewmore{
	padding: 8px;
	background-color: #fff;
	font-size: 14px;
	letter-spacing: -.06rem;
	overflow: hidden;
	position: relative;
	z-index: 1;
	transition: color .3s ease-in;
}
.viewmore::before{
	content: '';
	background-color: #000;
	border-radius: 50%;
	width: 10px;
	height: 10px;
	transform: translate(-50%,-50%) scale(0);
	position: absolute;
	top: 50%;
	left: 50%;
	transition: all .4s ease-out;
	z-index: -1;
}
.plan-cards:hover .viewmore{
	color: #fff;
}
.plan-cards:hover .viewmore::before{
	transform: translate(-50%,-50%) scale(100);
}
@media screen and (max-width: 1010px){
	.plan-cards-wrap{
		display: block
	}
	.plan-cards-wrap .slick-list{
    	overflow: visible;
	}
	.plan-cards{
		margin-inline: 12px;
	}
	.plan-cards-img{
		width: 50%
	}
	.plan-cards-img img{
		min-height: 223px;
		height: 100%;
	}
	.plan-cards-content{
		padding: 20px 10px;
		width: calc(50% - 10px);
		max-height: 100%;
	}
	.superior-section .plan-cards-flex{
		justify-content: center;
	}
	.superior-section .plan-cards-content{
		max-width: 320px;
		gap: 20px;
	}
}
@media screen and (max-width: 767px){
	.premium-section .inner,
	.only-section .inner{
		padding: 100px 0;
	}
	.plan-name{
		padding-bottom: 0;
	}
	.plan-ldk{
		letter-spacing: -.03rem;
	}
	.superior-section .plan-cards-content{
        padding: 16px 10px;
        max-width: 100%;
	}
}
.only-section{
	background: url(../img/plan/only-bg.webp) no-repeat center center / cover;
}
.only-section .note{
	font-size: 14px;
	font-feature-settings: "palt";
	letter-spacing: -.01rem;
	line-height: 1.8;
}
.only-flex{
	margin-bottom: clamp(46px, 6.4vw, 64px);
	align-items: center;
}
.only-content{
	padding-left: 3vw;
	width: calc(50% - 3vw);
}
.only-flex:nth-child(odd) .only-content{
	padding-left: 0;
	padding-right: 3vw;
}
.only-img{
	width: 50%;
}
.only-title{
	margin-bottom: clamp(26px, 3vw, 30px);
	font-size: 18px;
	font-weight: 400;
	line-height: 1.8;
}
.servive-heading{
	margin-bottom: 24px;
	font-weight: 300;
}
.point-box{
	margin: 20px 0 30px;
}
.point-heading{
	margin-bottom: 20px;
	padding: 4px 0;
	background-color: #93845e;
	font-size: 18px;
	font-weight: 400;
	line-height: 1.6;
	color: #fff;
}
.point-grid{
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 14px;
}
.plan-point-item{
	padding: 4px 8px;
	background-color: #fff;
	border: 1px solid #93845e;
	font-size: 16px;
	letter-spacing: -.01rem;
}
.point-box .caption{
	margin-top: 10px;
	font-size: 11px;
	letter-spacing: -.03rem;
}
.point-box .small-text,
.point-box sub{
	margin-left: 4px;
	vertical-align: baseline;
	font-size: 10px;
}
.point-grid2 .plan-point-item{
	padding: 4px 0;
	display: flex;
	align-items: center;
}
.point-l,
.point-r{
	padding: 12px 10px;
	letter-spacing: -.1rem;
	line-height: 1;
}
.point-l{
	max-width: 180px;
	width: 100%;
	position: relative;
}
.point-l::before{
	content: '';
	width: 1px;
	height: 60%;
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
	background-color: #93845e;
}
.point-r{
	text-align: left;
}
@media screen and (max-width: 1010px){
	.point-grid{
		grid-template-columns: auto;
	}
	.point-grid2 .plan-point-item{
		flex-wrap: wrap;
	}
	.point-box{
		margin-bottom: 70px;
	}
	.point-l,
	.point-r{
		padding: 12px 10px;
		letter-spacing: -.03rem;
	}
	.point-r{
		width: 100%;
        display: flex;
        justify-content: center;
        align-items: baseline;
		text-align: center;
	}
	.point-r sub{
		order: 3;
	}
	.point-l{
		max-width: 100%;
	}
	.point-l::before{
		width: 80%;
		height: .5px;
		top: auto;
		right: auto;
		bottom: 0;
		left: 50%;
		transform: translate(-50%,0);
	}
	.point-grid2 .plan-point-item{
		padding: 0;
	}
}
@media screen and (max-width: 767px){
	.only-flex{
		gap: 24px;
	}
	.only-img,
	.only-content{
		width: 100%
	}
	.only-content{
		padding-left: 0;
	}
	.only-flex:nth-child(odd) .only-content{
		padding-right: 0;
	}
	.only-point-num{
		margin-bottom: 6px;
		font-size: 15px;
	}
	.only-section .note{
		font-size: 14px;
	}
	.point-box .caption{
		margin-top: 20px;
	}
	.pc-none{
		display: block;
	}
	.servive-heading{
		margin-bottom: 30px;
	}
	.point-heading{
		font-size: 17px;
	}
	.plan-point-item{
		padding: 8px;
		font-size: 15px;
	}
}
.designer-box{
	padding: clamp(16px, 2.8vw, 28px) clamp(24px, 4.4vw, 44px) 20px;
	background-color: #fff;
	border: 1px solid #93845e;
}
.designer-box-flex{
	justify-content: space-between;
	align-items: center;
	gap: 4vw;
}
.text-area{
	max-width: calc(100% - calc(160px + 4vw));
	width: 100%;
}
.text-area .note{
	margin-bottom: 0;
}
.text-area-heading{
	padding-bottom: 12px;
	position: relative;
	font-size: 18px;
	font-weight: 400;
}
.text-area-heading::before{
	content: '';
	width: 100%;
	height: 1px;
	position: absolute;
	bottom: 0;
	left: 0;
	background-color: #807B4C;
}
.img-area{
	max-width: clamp(120px, 20vw, 150px);
	width: 100%;
}
.img-area .caption{
	font-size: 13px;
}
.category{
	font-size: 16px;
}
.category .seasons-font-regular{
	letter-spacing: .3rem;
}
.category-ja{
	font-size: 14px;
	letter-spacing: -.01rem;
}
@media screen and (max-width: 767px){
	.designer-box-flex{
		padding-top: 35px;
		position: relative;
	}
	.text-area{
		max-width: 100%;
	}
	.text-area-heading{
		padding-bottom: clamp(56px, 10vw, 80px);
	}
	.img-area{
		position: absolute;
		top: 0;
		right: 0;
	}
	.img-area figure{
		position: relative;
	}
	.img-area .caption{
        position: absolute;
        bottom: -32px;
        right: 0;
        white-space: nowrap;
        font-size: 13px;
        letter-spacing: 0;
	}
	.category{
		font-size: 15px;
	}
	.category-ja{
		font-size: 12px;
	}
	.category .seasons-font-regular{
		letter-spacing: .1rem;
	}
	.text-area-heading{
		font-size: 17.5px;
		line-height: 1.7;
		letter-spacing: -.03rem;
	}
	.text-area .note{
		line-height: 1.6;
	}
}

/*  ---------  PLAN DETAIL --------- */
header.inner-main::before{
	content: '';
    width: 100%;
    height: 230px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(0, 0, 0, .6) 100%);
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 1;
}
.detail-section{
	background-color: rgba(147, 132, 94, .26);
	position: relative;
}
.detail-section.superior{
	background: url(../img/plan/bg-detail-superior.webp) no-repeat center center / cover;
}
.superior .plan-detail-heading::before{
	background-color: #777777;
}
.superior .plan-detail-heading .seasons-font-regular{
	color: #777777;
}
.detail-section .inner{
	padding: 60px 0 70px;
}
.plan-detail-wrap{
	margin-inline: auto;
	max-width: 540px;
	width: 100%;
}
.plan-detail-heading {
	margin-bottom: 20px;
	padding-bottom: 4px;
	display: flex;
	flex-direction: column;
	align-items: center;
	font-size: clamp(25px, 3.6vw, 36px);
	position: relative;
}
.plan-detail-heading::before {
	content: '';
	width: 100%;
	height: 1px;
	position: absolute;
	bottom: 0;
	left: 0;
	background-color: #b2a685;
}
.plan-detail-heading .helvetica-font{
	font-size: 14px;
	font-weight: 400;
}
.plan-detail-heading .helvetica-font .large-text{
	margin-right: 3px;
	font-size: clamp(16px, 2vw, 20px);
}
.plan-detail-ldk{
	font-size: 20px;
	vertical-align: baseline;
	line-height: 1;
}
.plan-detail-ldk .large-text{
	margin-right: 4px;
	font-size: clamp(56px, 6vw, 60px);
	letter-spacing: -.06rem;
}
.plan-detail-ldk .middle-text{
	font-size: clamp(25px, 2.8vw, 28px);
}
.plan-detail-wide{
	justify-content: center;
	align-items: center;
	gap: 0 clamp(4px, 1vw, 8px);
	line-height: 1;
}
.wide-text{
	margin-top: 10px;
	font-size: 15px;
	letter-spacing: -.03rem;
}
.plan-wide-num-wrap{
	font-size: 32px;
}
.plan-wide-num-wrap sub{
	vertical-align: baseline;
	font-size: 15px;
	letter-spacing: -.02rem;
}
.wide-num{
	font-size: 48px;
	letter-spacing: -.1rem;
}
.wide-num .large-text{
	font-size: clamp(74px, 8vw, 80px);
}
.plan-detail-note{
	margin-top: clamp(8px, 2vw, 20px);
	font-size: 14px;
	line-height: 1.8;
	letter-spacing: -.01rem;
}
.plan-detail-note span{
	margin-left: 4px;
}
.floor-img{
	max-width: 190px;
	width: 100%;
	position: absolute;
	top: 50%;
	right: 4.5%;
	transform: translateY(-50%);
}
.plan-contents-section .inner{
	padding: 60px 0;
}
.img-wrap{
	margin: clamp(50px, 8vw, 80px) auto 0;
	max-width: 920px;
	width: 100%;
}
.plan-type-img{
	margin: clamp(30px, 7.2vw, 72px) auto clamp(52px, 6vw, 60px);
	max-width: 680px;
	width: 100%;
}
.plan-type-img.plan-type-img-big{
	max-width: 1000px;
}
.plan-point-list{
	margin-bottom: clamp(30px, 5vw, 50px);
	display: flex;
	flex-wrap: wrap;
	gap: 12px 20px;
}
.plan-point-list.dummy{
	position: relative;
}
.plan-point-list.dummy::before{
	content: 'ダミー';
	width: 100%;
	position: absolute;
	inset: 0;
	background-color: rgba(0, 0, 0, .4);
	display: grid;
	place-items: center;
	font-size: 2rem;
	color: #fff;
	z-index: 3;
}
.plan-point-list-item{
	padding: 12px clamp(14px, 2vw, 20px);
	width: calc(50% - 50px);
	align-content: center;
	background-color: #efeee9;
	font-size: 17px;
	letter-spacing: -.03rem;
}
.col-1{
	width: 100%;
}
.plan-content-section .general-btn{
	background-color: #9e9477;
	mix-blend-mode: multiply;
}
.plan-content-section .general-btn{
	margin: 16px 18px;
	display: inline-grid;
	place-items: center;
	background-color: #9e9477;
	mix-blend-mode: multiply;
	transform: translate3d(0,0,0);
	font-size: 15px;
	line-height: 1.5;
}
.plan-hanrei-wrap{
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: center;
	gap: 8px;
}
.plan-hanrei{
	max-width: 240px;
	width: 100%;
	display: flex;
}
.plan-description{
	font-size: 10px;
	letter-spacing: -.03rem;
}
.description-section .inner{
	width: 100%;
}
@media screen and (max-width: 1023px){
	.floor-img{
		margin: 30px auto 0;
		max-width: 174px;
		position: static;
		top: auto;
		right: auto;
		transform: translateY(0);
	}
}
@media screen and (max-width: 767px){
	.plan-content-section .general-btn{
		margin: 8px 4px;
		width: calc(50% - 11px);
		padding: 0;
	}
	.wide-text{
		font-size: 14px;
	}
	.plan-detail-note{
		font-size: 13px;
		letter-spacing: -.01rem;
	}
	.detail-section .inner{
		padding: clamp(30px, 4vw, 40px) 0;
	}
	.plan-wide-num-wrap sub{
		font-size: 13px;
	}
	.plan-point-list{
		gap: 8px;
	}
	.plan-point-list-item{
		width: 100%;
		font-size: 13px;
	}
	.description-section .inner{
		padding: 30px 0;
	}
	.plan-hanrei-wrap{
		flex-wrap: wrap;
	}
}
@media screen and (max-width: 370px){
	.plan-wide-num{
		font-size: 32px;
	}
	.wide-text{
		font-size: 13px;
	}
	.wide-num .large-text{
		font-size: 70px;
	}
}