@charset "utf-8";
/* CSS Document */
.pc-only {
	display: none !important;
}
html {
	font-size: 62.5%;
}
body {
	font-size: 1.3rem;
	font-family: YakuHanJP, 'Noto Sans JP', "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "MS Pゴシック", sans-serif;
	color: #4F434B;
	line-height: 1.8;
	font-weight: 300;
}
p {
	line-height: 1.8;
	font-feature-settings: "palt";
}
h1, h2, h3, h4, h5 {
	font-weight: 400;
}
.inner {
	width: 1200px;
	margin: auto;
}
img {
	max-width: 100%;
}
:root {
	--gray: #4F434B;
	--pink: #F0C2D1;
	--blue: #C9E4FB;
	--white: #fff;
	--short: .3s;
	--hover: .7;
}
section {
	overflow: hidden;
}

.footer {
	margin-top: 6rem;
	margin-bottom: 14rem;
	text-align: center;
}
.footer_link {
	transition: var(--short);
}
.footer_link:hover {
	opacity: var(--hover);
}
.footer_link img {
	max-width: 487px;
}
.footer_copy {
	margin-top: 2rem;
	display: block;
	font-size: 2rem;
}

/*----------------------------------------------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------------------------------------------*/
/*----------------------------------------------タブレット-PC／ブレイクポイント-------------------------------------------*/
/*----------------------------------------------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------------------------------------------*/
@media screen and (min-width:768px) {
	.sp-only {
		display: none !important;
	}
	.pc-only {
		display: block !important;
	}
	a[href^="tel:"] {
		pointer-events: none;
	}
	.inner {
		padding: 0 4rem;
		width: 100%;
	}
}

/*----------------------------------------------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------------------------------------------*/
/*-------------------------------------------SP／ブレイクポイント-------------------------------------------*/
/*----------------------------------------------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------------------------------------------*/
@media screen and (max-width: 767px) {
	body {
		font-size: 1.8rem;
	}
	.inner {
		width: auto;
		margin: 0 auto;
		padding: 0;
	}
	
	.footer-cta {
		flex-direction: column;
	}
	.footer-cta-button {
		margin: .5rem 0;
	}
	.footer_link img {
		max-width: 204px;
	}
	.footer_copy {
		font-size: 1.1rem;
	}
}

/*----------------------------------------------------------------------------------------------------------------*/

.body-header {
	padding: 16px 0 16px 30px;
}
.body-header .logo {
	@media screen and (max-width:767px) {
		max-width: 50%;
		display: inline-block;
	}
}

.main {
	text-align: center;
	section {
		max-width: 1300px;
		padding:0 3.5%;
		margin: 0 auto;
	}

	picture{
		display: block;
	}
	.link-button {
		position: relative;
		display: inline-block;
	}

	.link-button img{
		background-color: #d27700;
		padding: 2.4rem 2.4rem 2.4rem 4.8rem;
		border-radius: 9999px;
		border: #1b1e24 2px solid;
		position: relative;
		transform:translateY(0);
		transition: transform .1s ease-in-out;
	}
	.link-button:hover img {
		transform:translateY(8px);
	}
	.link-button::before {
		content: "";
		width: 100%;
		height: 100%;
		background: #1b1e24;
		border-radius: 9999px;
		position: absolute;
		top: 8px;
		left: 0;
		z-index: -1;
	}

	.hero {
		overflow: visible;
	}

	.hero-box {
		position: relative;
	}

	.hero-link_wrapper {
		text-align: right;
		padding-right: 3%;
		@media screen and (max-width:767px) {
			padding: 0 2%;
		}
	}
	.hero-link {
		@media screen and (max-width:767px) {
			margin-top: 2.4rem;
		}
		@media screen and (min-width:768px) {
			transform:translateY(-50%);
			max-width: 35%;
		}
	}

	.hero-link picture {
		display: inline-block;
	}

	.present {
		@media screen and (max-width:767px) {
			margin: 7.2rem 0 3.6rem;
		}
	}

	.present picture {
		margin-bottom: 3.6rem;
	}

	.feature {
		margin-bottom: 9.4rem;
	}

	.flow {
		margin-bottom: 12rem;
		@media screen and (max-width:767px) {
			margin-bottom: 7.2rem;
		}
	}

	.flow-link_wrapper{
		padding-bottom: 2.4rem;
	}

	.flow-link {
		margin-top: 9.6rem;
		display: inline-block;
		@media screen and (max-width:767px) {
			margin-top: 6rem;
		}
	}

	.style picture{
		margin-bottom: 7.2rem;
	}

	.style .style-interior {
		text-align: left;
	}

	.reserve {
		background: #d0dfea;
		border-radius: 6rem;
		padding-top: 12rem;
		padding-bottom: 12rem;
		max-width: 100%;
		@media screen and (max-width:767px) {
			border-radius: 2rem;
			padding-top: 6rem;
			padding-bottom: 0;
		}
	}

	.reserve-title img{
		@media screen and (max-width:767px) {
			max-width: 80%;
		}
	}

	.form {
		text-align: left;
		max-width: 1024px;
		margin: 4rem auto;
		font-size: 2.6rem;
		@media screen and (max-width:767px) {
			font-size: 1.6rem;
		}
	}
	input,textarea,select{
		border-radius: .75rem;
		padding:2.4rem;
		background-color: #FFF;
		font-size: 3rem;
		width: 100%;
		display: inline-block;
		cursor: pointer;
		-webkit-appearance: none;
    appearance: none;
		line-height: 1.4;
		@media screen and (max-width:767px) {
			font-size: 1.8rem;
			padding: 1.4rem;
		}
	}
	select,select option {
		color:#4F434B;
	}

	input[type="checkbox"],input[type="radio"]{
		width: auto;
		display: none;
	}
	input[type="checkbox"]:checked + .form-input_label:after,
	input[type="radio"]:checked + .form-input_label:after {
		content: "";
		width: .75rem;
		height: 1.75rem;
		position: absolute;
		left: 1.25rem;
		top: .75rem;
		border-style: solid;
		border-width:.5rem ;
		border-color:transparent #a01e2f #a01e2f transparent;
		transform: rotate(45deg);
		@media screen and (max-width:767px) {
			border-width:.25rem ;
			width: calc(.75rem / 2 );
			height: calc(1.75rem / 2 );
			left: .8rem;
			top: .3rem;
		}
	}
	.form-unit_radio {
		margin-right: 2.4rem;
		margin-bottom: 2.4rem;
		display: inline-block;
		@media screen and (max-width:767px) {
			margin-right: 1.2rem;
			margin-bottom: 1.2rem;
		}
	}

	.form-unit {
		margin-bottom: 4.8rem;
		@media screen and (max-width:767px) {
			margin-bottom: 3.6rem;
		}
	}

	.form-unit_label {
		margin-bottom: 2.4rem;
		display: block;
		font-weight: 500;
		line-height: 1.4;
		@media screen and (max-width:767px) {
			margin-bottom: .75rem;
		}
	}
	.form-unit_label b {
		font-size: 3.125rem;
		font-weight: 500;
		@media screen and (max-width:767px) {
			font-size: 2rem;
		}
	}
	.form-unit_step {
		font-size: 2rem;
		padding: 1rem;
		margin-right: 1.2rem;
		background: #155e97;
		vertical-align:baseline;
		color: #fff;
		border-radius: 3px;
		display: inline-block;
		vertical-align: baseline;
		@media screen and (max-width:767px) {
			font-size: 1.4rem;
			margin-bottom: .25rem;
		}
	}
	.form-unit_label_name {
		margin-right: 1.2rem;
		line-height: 1.4;
		@media screen and (max-width:767px) {
			padding: 6px 0;
			margin: 0 .5rem 0 0;
			line-height: 1.4;
			display: inline-block;
		}
	}
	.form-unit_label_required {
		font-size: 1.8rem;
		padding: 1rem;
		background: #dd656b;
		vertical-align:baseline;
		color: #fff;
		border-radius: 3px;
		display: inline-block;
		vertical-align: baseline;
		@media screen and (max-width:767px) {
			font-size: 1.3rem;
			padding: .75rem;
		}
	}
	
	.form-input_label {
		padding-left: 4.75rem;
		position: relative;
		font-weight: 500;
		font-size: 3.125rem;
		cursor: pointer;
		display: inline-block;
		line-height: 1.4;
		@media screen and (max-width:767px) {
			font-size: 1.6rem;
			padding-left: 3rem;
		}
	}
	.form-input_label:before {
		content: "";
		width: 3rem;
		height: 3rem;
		position: absolute;
		left: .5rem;
		top: 1rem;
		background:#fff;
		border-radius: .72rem;
		@media screen and (max-width:767px) {
			width: 1.5rem;
			height: 1.5rem;
			border-radius: .24rem;
			top: .5rem;
		}
	}

	.form-unit_select{
		position: relative;
	}
	.step2 select {
		color: #b3b3b4;
	}
	.step2 .selected_option {
		color: #4F434B;
	}

	.form-unit_select::before,
	.form-unit_select::after{
		content: "";
		width: 20px;
		height: 2px;
		background: #b4b4b5;
		position: absolute;
		top: 0;
		bottom: 0;
		margin: auto;
		@media screen and (max-width:767px) {
			width:12px;
		}
	}
	.form-unit_select::before {
		right: 24px;
		transform:rotate(45deg) translateY(2px);
		border-radius: 4px 0 0 4px;
		@media screen and (max-width:767px) {
			right:12px;
		}
	}
	.form-unit_select::after {
		right: 13px;
		transform:rotate(-45deg) translateY(2px);
		border-radius: 0 4px 4px 0;
		@media screen and (max-width:767px) {
			right:8px;
		}
	}
	.form-unit_select select {
		padding-right: 64px;
		@media screen and (max-width:767px) {
			padding-right: 36px;
		}
	}
	.form-unit_selectdate{
		display: inline-flex;
	}
	.form-unit_selectdate select {
		width: auto;
		padding-right: 80px;
	}
	.form-unit_with_suffix .form-unit_select {
		display: inline-block;
	}
	.form-unit_suffix {
		font-weight: 500;
		margin:0 2.4rem 0 .25rem;
	}

	@media screen and (max-width:767px) {
		.form-unit_suffix {
			margin-right: 0;
		}
		.form-unit_selectdate{
			display: flex;
			flex-wrap: wrap;
			gap: 0;
		}
		.form-unit_yyyy {
			margin-bottom: 1.2rem;
			width: 100%;
		}
		.form-unit_mm, .form-unit_dd {
			width: 50%;
		}
		.form-unit_yyyy .form-unit_select,
		.form-unit_mm .form-unit_select,
		.form-unit_dd .form-unit_select {
			width: calc(100% - 4rem);
		}
		.form-unit_yyyy .form-unit_select select,
		.form-unit_mm .form-unit_select select,
		.form-unit_dd .form-unit_select select{
			width: 100%;
		}
	}

	.step13 {
		margin-bottom: 2.4rem;
		@media screen and (min-width:768px) {
			margin-bottom: 9.6rem;
		}
	}
	.step13 .form-unit_inwrap {
		text-align: center;
		display: block;
	}
	.step14 {
		margin: 0 auto;
		max-width: 900px;
	}
	.step13 .form-unit_inwrap,
	.step14 .form-unit_inwrap{
		@media screen and (max-width:767px) {
			text-align: left;
		}
	}
	.step14 .form-unit_desc {
		padding-left: 4.75rem;
		padding-top: 1.2rem;
		font-size: 1.8rem;
		line-height: 1.5;
		@media screen and (max-width:767px) {
			padding-right: 1.2rem;
			padding-left: 3rem;
			font-size: 1.3rem;
		}
	}
	.form-unit_submit {
		margin-top: 4.8rem;
		text-align: center;
	}
	.form-input_submit {
		max-width: 75%;
		background: #a01e2f;
		color: #fff;
		transition: background .3s ease;
	}
	.form-input_submit:disabled {
		background: #999;
		cursor: auto;
	opacity: 1 !important;
	}
	input[type="submit"].submit-btn {
		@media screen and (max-width:767px) {
			border-radius: .25rem;
		}
	}

	.form-terms {
		max-height: 40vh;
		overflow-y: scroll;
		padding: 1.4rem;
		margin-bottom: 4.8rem;
		background: #fff;
		border-radius: .75rem;
		border: 1rem solid #fff;
		font-size: 2.2rem;
		line-height: 1.6;
		@media screen and (max-width:767px) {
			font-size: 1.3rem;
		}
	}
	.form-terms_title {
		color: #155e97;
		font-size: 2.4rem;
		margin-bottom: 1.2rem;
		font-weight: 400;
		@media screen and (max-width:767px) {
			font-size: 1.6rem;
		}
	}
	.form-terms-list{
		padding-bottom: 4.8rem;
		@media screen and (max-width:767px) {
			padding-bottom: 2.4rem;
		}
	}
	.form-terms-list_item {
		line-height: 1.6;
		padding-bottom: .75rem;
		text-indent: 1.5rem;
		position: relative;
		font-weight: 400;
	}
	.form-terms-list_item:before {
		content: "";
		width: .5rem;
		height: .5rem;
		border-radius: 9999px;
		background: #000;
		position: absolute;
		left: .25rem;
		top: 1.6rem;
		@media screen and (max-width:767px) {
			top:.75rem
		}
	}
}