@charset "UTF-8";

/* form */

.formTable{
	margin: 8vw auto 3vw;
	letter-spacing: 0.05em;
	border-bottom: 1px solid var(--base);
}
.formTable th,
.formTable td{
	box-sizing: border-box;
	vertical-align: top;
}
.formTable th{
	width: 33%;
	color: var(--base);
	font-size: 1.6vw;
	font-weight: 800;
	padding-top: 0.7vw;
}
.formTable td{
	padding: 0 0 2vw;
}
.formTable tr:last-of-type td{
	padding-bottom: 4vw;
}
.formTable th span{
	font-size: 0.6em;
	background-color: var(--vermillion);
	color: #fff;
	line-height: 1;
	margin-left: 1.5vw;
	padding: 0.02vw 1vw 0.2vw;
	letter-spacing: 0;
	position: relative;
	top: -0.2vw;
}
.formTable th small{
	font-size: 1.25vw;
	display: inline-block;
}
.formTable label{
	display: none;
}
.formGroupInline{
	display: flex;
	gap: 1vw;
}
.formSubmit{
	text-align: center;
}
.formSubmit p{
	color: var(--base);
	font-weight: 700;
	font-size: 1.4vw;
	line-height: 2;
}
.formSubmit p span{
	display: inline-block;
}
.formSubmit a{
	color: var(--vermillion);
	text-decoration: underline;
}
.formSubmit .formPrivacyPolicy{
	color: var(--base);
	display: flex;
	margin: 1.5vw auto 4vw;
	gap: 1.5vw;
	align-items: center;
	justify-content: center;
}
.formSubmit label{
	font-size: 1.75vw;
	font-weight: 800;
	letter-spacing: 0.06em;
	margin-top: -0.2vw;
}
.contactMsg{
	font-weight: 700;
	font-size: 1.4vw;
	line-height: 2;
	text-align: center;
	white-space: pre-wrap;
	padding-top: 4vw;
}
.contactMsg.success{
	color: var(--base);
}
.contactMsg.error{
	color: var(--vermillion);
}
@media screen and (min-width: 1051px){
	.formTable{
		margin: 5.25rem auto 1.97rem;
		border-bottom: 0.66px solid var(--base);
	}
	.formTable th{
		font-size: 1.05rem;
		padding-top: 0.46rem;
	}
	.formTable td{
		padding: 0 0 1.31rem;
	}
	.formTable tr:last-of-type td{
		padding-bottom: 2.63rem;
	}
	.formTable th span{
		margin-left: 0.99rem;
		padding: 0.02rem 0.66rem 0.13rem;
		top: -0.13rem;
	}
	.formTable th small{
		font-size: 0.82rem;
	}
	.formGroupInline{
		gap: 0.66rem;
	}
	.formSubmit p{
		font-size: 0.92rem;
	}
	.formSubmit .formPrivacyPolicy{
		margin: 0.99rem auto 2.63rem;
		gap: 0.99rem;
	}
	.formSubmit label{
		font-size: 1.16rem;
		margin-top: -0.13rem;
	}
	.contactMsg{
		padding-top: 2.63rem;
	}
}
@media screen and (max-width: 768px){
	.formTable{
		margin: 10vw auto 0;
	}
	.formTable th,
	.formTable td{
		display: block;
		width: 100%;
	}
	.formTable th{
		font-size: 3.5vw;
		padding: 0 0 1.5vw;
	}
	.formTable td{
		padding: 0 0 5vw;
	}
	.formTable tr:last-of-type td{
		padding-bottom: 7vw;
	}
	.formTable th span{
		margin-left: 2.75vw;
		padding: 0.05vw 1.8vw 0.25vw;
		top: -0.3vw;
	}
	.formTable th small{
		font-size: 3vw;
		margin-left: 2vw;
	}
	.formGroupInline{
		gap: 2vw;
	}
	.formSubmit p{
		padding-top: 5vw;
		font-size: 3vw;
	}
	.formSubmit .formPrivacyPolicy{
		margin: 5vw auto 8vw;
		gap: 2.5vw;
	}
	.formSubmit label{
		font-size: 3.75vw;
		margin-top: -0.25vw;
	}
	.contactMsg{
		padding-top: 8vw;
	}
}

input,
textarea{
	font-family: "Noto Sans JP", "Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
	display: block;
	box-sizing: border-box;
	width: 100%;
	font-size: 1.6vw;
	padding: 0.75vw 1.5vw;
	border-radius: 5px;
	background: #f1f1f1;
	border: solid 1px #f1f1f1;
}
input:focus,
textarea:focus{
	border: solid 1px var(--base);
	background: var(--ink2);
}
textarea{
	height: 20vw;
	line-height: 1.4;
	width: 100%;
}
.formSelectWrap{
	position: relative;
}
.formSelectWrap::before{
	content: '';
	position: absolute;
	top: calc( 50% - 5px );
	right: 8px;
	width: 6px;
	height: 6px;
	border-top: 1px solid #242323;
	border-left: 1px solid #242323;
	transform: rotate(-135deg);
	pointer-events: none;
}
input::placeholder{
	opacity: 0.35;
}
input:focus::-webkit-input-placeholder{	color: transparent; }
input:focus::-moz-placeholder{ color: transparent; }
input:focus::-ms-input-placeholder{ color: transparent; }
input:focus::placeholder{ color: transparent; }
input[type="text"],
input[type="tel"],
input[type="email"]{
	width: 100%;
}
input[type="checkbox"]{
	position: relative;
	padding: 0.89vw;
	width: 2.22vw;
	height: 2.22vw;
	border: 0.11vw solid #999;
	background: #f8f8f8;
	border-radius: 0.45vw;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}
input[type="checkbox"]:checked{
	background: var(--vermillion);
	border: 0.11vw solid var(--vermillion);
}
input[type="checkbox"]:checked:before{
	content: '';
	position: absolute;
	top: 0.34vw;
	left: 0.67vw;
	transform: rotate(50deg);
	width: 0.45vw;
	height: 0.89vw;
	border-right: 0.22vw solid var(--ink2);
	border-bottom: 0.22vw solid var(--ink2);
}
button{
	font-family: "Noto Sans JP", "Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
	display: block;
	width: 35vw;
	margin: 0 auto;
	padding: 2vw 0;
	border: none;
	border-radius: 0;
	background: var(--vermillion);
	color: var(--ink2);
	font-size: 2vw;
	font-weight: 700;
	letter-spacing: 0.16em;
	line-height: 1;
	text-align: center;
	cursor: pointer;
	appearance: none;
	-webkit-appearance: none;
	box-shadow: none;
	transition: opacity .3s ease;
}
button:disabled{
	opacity: 0.6;
	cursor: not-allowed;
}
@media screen and (min-width: 1051px){
	input,
	textarea{
		font-size: 1.05rem;
		padding: 0.49rem 0.99rem;
	}
	textarea{
		height: 13.13rem;
	}
	input[type="checkbox"]{
		padding: 0.59rem;
		width: 1.45rem;
		height: 1.45rem;
		border: 0.07rem solid #999;
		border-radius: 0.30rem;
	}
	input[type="checkbox"]:checked{
		border: 0.07rem solid var(--vermillion);
	}
	input[type="checkbox"]:checked:before{
		top: 0.23rem;
		left: 0.44rem;
		width: 0.30rem;
		height: 0.59rem;
		border-right: 0.15rem solid var(--ink2);
		border-bottom: 0.15rem solid var(--ink2);
	}
	button{
		width: 23.17rem;
		padding: 1.31rem 0;
		font-size: 1.31rem;
	}
}
@media screen and (max-width: 768px){
	input,
	textarea{
		font-size: clamp(16px, 3.5vw, 25px);
		padding: 2vw 3.26vw;
		border-radius: 0.93vw;
	}
	textarea{
		height: 60vw;
	}
	input[type="checkbox"]{
		padding: 1.78vw;
		width: 4.44vw;
		height: 4.44vw;
		border: 0.22vw solid #999;
		border-radius: 0.89vw;
	}
	input[type="checkbox"]:checked{
		border: 0.22vw solid var(--vermillion);
	}
	input[type="checkbox"]:checked:before{
		top: 0.67vw;
		left: 1.33vw;
		width: 0.89vw;
		height: 1.78vw;
		border-right: 0.44vw solid var(--ink2);
		border-bottom: 0.44vw solid var(--ink2);
	}
	button{
		width: 100%;
		padding: 4.8vw 0;
		font-size: 4.85vw;
	}
}


/* dlModal */

.dlModal{
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: flex;
	align-items: center;
	justify-content: center;
}
.dlModal[aria-hidden="true"]{
	display: none;
}
.dlModalOverlay{
	position: absolute;
	inset: 0;
	background: rgba(0,0,0,0.55);
}
.dlModalBox{
	position: relative;
	background: var(--ink2);
	width: 60%;
	max-width: 460px;
	border-radius: 6px;
	padding: 2.5rem 2.5rem 0;
	box-shadow: var(--shadow2);
}
.dlModalClose{
	position: absolute;
	top: 1.2rem;
	right: 1.2rem;
	width: auto;
	background: none;
	border: none;
	font-size: 1.4rem;
	color: var(--muted2);
	cursor: pointer;
	padding: 0;
	margin: 0;
	line-height: 1;
	letter-spacing: 0;
	border-radius: 0;
	font-weight: 400;
}
.dlModalClose:hover{
	color: var(--ink);
	opacity: 1;
}
.dlModalForm .formTable{
	margin: 0;
	border: none;
	padding: 1.5rem 0;
}
.dlModalForm .formTable th,
.dlModalForm .formTable td{
	display: block;
	width: 100%;
}
.dlModalForm .formTable th{
	font-size: 1rem;
	padding-bottom: 0.4rem;
}
.dlModalForm .formTable td{
	padding-bottom: 0.5rem;
}
.dlModalForm .formTable tr:last-of-type td{
	padding-bottom: 0.5rem;
}
.dlModalForm input,
.dlModalForm textarea{
	font-size: 1rem;
	padding: 0.5rem 1rem;
}
.dlModalForm input[type="checkbox"]{
	padding: 0.52rem;
	width: 1.29rem;
	height: 1.29rem;
	border: 0.06rem solid #999;
	border-radius: 0.26rem;
}
.dlModalForm input[type="checkbox"]:checked{
	border: 0.06rem solid var(--vermillion);
}
.dlModalForm input[type="checkbox"]:checked:before{
	top: 0.20rem;
	left: 0.39rem;
	width: 0.26rem;
	height: 0.52rem;
	border-right: 0.13rem solid var(--ink2);
	border-bottom: 0.13rem solid var(--ink2);
}
.dlModalForm .formPrivacyPolicy{
	margin: 1rem auto 1.75rem;
}
.dlModalForm .formPrivacyPolicy label{
	font-size: 0.8rem;
}
.dlModalForm button{
	font-size: 1rem;
	width: 90%;
}
.dlModalMsg{
	margin: 1rem 0;
	font-size: 0.82rem;
	color: var(--vermillion);
	text-align: center;
	min-height: 1.2em;
	white-space: pre-wrap;
}
@media screen and (max-width: 768px){
	.dlModalBox{
		width: 93%;
		padding: 10.5vw 8vw 5vw;
	}
	.dlModalForm .formTable{
		padding: 5vw 0 0;
		margin: 0;
	}
	.dlModalForm .formTable th{
		font-size: 3.4vw;
		padding-bottom: 2vw;
	}
	.dlModalForm .formTable td{
		padding-bottom: 4vw;
	}
	.dlModalForm .formTable tr:last-of-type td{
		padding-bottom: 1.2vw;
	}
	.dlModalForm input,
	.dlModalForm textarea{
		font-size: clamp(16px, 3.5vw, 25px);
		padding: 2vw 3.26vw;
		border-radius: 0.93vw;
	}
	.dlModalForm .formPrivacyPolicy{
		margin: 7vw auto 8vw;
	}
	.dlModalForm .formPrivacyPolicy label{
		font-size: 3vw;
	}
	.dlModalForm .formSubmit{
		margin-bottom: 0;
	}
	.dlModalForm button{
		font-size: 3.75vw;
		width: 100%;
	}
	.dlModalMsg{
		margin:  0.5vw 0 1vw;
		font-size: 2.8vw;
	}
}