@charset "UTF-8";

/*fontsize variable*/
:root {
	--font-xl:  clamp(44px, 3.5vw, 64px);
	--font-l:   clamp(32px, 2.2vw, 40px);
	--font-lm:  clamp(24px, 1.8vw, 28px);
	--font-m:   clamp(19px,1.45vw, 21px);
	--font-r:   18px;
	--font-s:   14px;
	--font-xs:   12.8px;

	/*accent-color: hsl(358, 95%, 40%);*/

	--gray-1: hsl(100, 0%, 97%);
	--gray-2: hsl(100, 0%, 83%);
	--gray-3: hsl(100, 0%, 66%);
	--gray-4: hsl(20, 5%, 44%);
	--gray-5: hsl(100, 0%, 33%);

	--red-1: hsl(358, 95%, 95%);
	--red-2: hsl(358, 91%, 47%);
	--red-3: hsl(358, 95%, 35%);

	--blue-1: hsl(228, 95%, 95%);
	--blue-2: hsl(228, 91%, 47%);
	--blue-3: hsl(228, 95%, 35%);

	--margin-l: 17.5vh;
	--margin-m: 7.5vh;
	--margin-s: 5vh;
}

:focus-visible { 
	outline-color: var(accent-color);
}

* {
	text-decoration: none;
	list-style: none;
	margin: 0;
	padding: 0;
	padding-block: 0;
	padding-inline: 0;
	box-sizing: border-box;
	font-family: 'Noto Serif JP',"ヒラギノ明朝 ProN W6", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	font-feature-settings: "palt";
	line-height: 1.8;
}

/*html {
	scroll-behavior: smooth;
	scroll-padding-top: 35vh;
}*/

.wrapper {
	width: 100%;
	margin: 0 auto;
}

header {
	width: 100%;
	height: 1vh;
	background-color: var(--red-2);
	/*padding: 16px;
	border-bottom: 1px solid var(--gray-2);*/
}

/*header > .a {
	display: inline-block;
}*/

/*header .headerLogo {
	display: block;
	width: 88px;
}*/

main {
	width: 80%;
	margin: 0 auto 100px;
}

.top {
	font-family: ten-mincho-antique, sans-serif;
	font-weight: 400;
	font-style: normal;
	text-align: center;
	margin-top: var(--margin-m);
}

.titleCnt__top {

}

.titleCnt__top > img {
	display: inline-block;
	width:  150px;
}

.titleCnt__top .text {
	font-size: var(--font-r);
	line-height: 1;
	color: var(--gray-4);
}

.titleCnt__middle {

}

.titleCnt__middle .text {
	font-size: var(--font-l);
	font-family: ten-mincho-antique, sans-serif;
	font-weight: 400;
	font-style: normal;
	letter-spacing: 0.1em;
	margin-top: 0.5em;
}

.titleCnt__middle--2 {
	margin-top: 0.5em;
}

.titleCnt__middle--2 .text {
	font-size: var(--font-m);
}

.titleCnt__middle--2 .text span {
	font-size: 1.35em;
	margin: 0 0.5em;
}

.titleCnt__bottom {
	margin-top: 0.75em;
}

.titleCnt__bottom .title {
	display: inline-block;
	font-size: var(--font-xl);
	font-family: ten-mincho-antique, sans-serif;
	font-weight: 400;
	font-style: normal;
	line-height: 1.2;
	letter-spacing: 0.1em;
	padding-bottom: 0.2em;
	border-bottom: 4px solid var(--gray-2);
}

.titleCnt__bottom .subTitle {
	display: block;
	font-size: var(--font-l);
	font-family: ten-mincho-antique, sans-serif;
	font-weight: 400;
	font-style: normal;
	line-height: 1.35;
	letter-spacing: 0.1em;
	margin-top: 0.7em;
}

.imgCnt {
	margin-top: 7.5%;
}

.imgCnt > .imgCnt__img {
	display: block;
	margin: auto;
}

.imgCnt > .imgCnt__img--t {
	width: max(480px, 35vw);
}

.imgCnt > .imgCnt__img--y {
	width: max(880px, 60vw);
}


.leadCnt {

}

.leadCnt__text {
	display: inline-block;
	font-size: var(--font-m);
	text-align: left;
	line-height: 2;
	margin: 3em auto 0;
}

.sampleImgBox{
	margin-top: var(--margin-l);
    /*margin-left: 5vw;
    margin-right: 5vw;*/
}

.sampleImgBox .one_Line{
	display: flex;
}

.sampleImgBox .one_Line .one_LineBlock{
	margin-bottom: 60px; 
}

.sampleImgBox .one_Line .one_LineBlock p {
	text-align: center;
	font-size: var(--font-m);
	color: var(--gray-5);
}

.sampleImgBox .one_Line .one_LineBlock span.sampleImg_caution{
	color: red;
	font-size: var(--font-s);	
}

.sampleImgBox .one_Line .one_LineBlock a {
	width: 50%;
}

.sampleImgBox .one_Line .one_LineBlock a:hover {
	opacity: 0.7;
	transition: 1s;
}

.sampleImgBox .one_Line .one_LineBlock .unkerBtn {
	text-align: center;
	margin-top: 20px;
}

.sampleImgBox .one_Line .one_LineBlock .unkerBtn a{
	color: white;
    background-color: var(--red-3);
    border-radius: 8px;
    padding: 20px;
}

.sampleImgBox .one_Line a img{
	width: 100%;
}


.sampleImgBox .one_Line .one_LineBlock {
	width: 50%;
}

.sampleImgBox .one_Line .one_LineBlock img{
	width: 100%;
}

.info {
	margin-top: var(--margin-l);
    /*margin-left: 5vw;
    margin-right: 5vw;*/
}

.infoItem {

}

.infoItem ~ .infoItem {
	padding-top: var(--margin-m);
	border-top: 1px dashed var(--gray-2);
	margin-top: var(--margin-m);
}

.infoItem__title {
	position: relative;
	font-size: var(--font-m);
	letter-spacing: 0.1em;
	color: #000;
	padding-left: 1em;
}

.infoItem__title:before {
	content: "";
	position: absolute;
	bottom: 0.425em;
	left: 0;
	display: inline-block;
	width: 4px;
	height: 1em;
	background-color: var(--gray-4);
}

.infoItem .textBox {
	font-size: var(--font-r);
	margin-top: 1.5em;
	padding-left: 1.5em;
}

.infoItem .textBox__text {
	display: block;
	margin-top: 1em;
	color: var(--gray-5);
}


.textBox__text--border {
	display: block;
}

.infoItem .textBox__text a {
	display: inline-block;
	color: var(--blue-2);
	border-bottom: 1px solid var(--blue-2);
}

.infoItem .textBox__text a:visited {
	color: var(--blue-2);
}

.textBox__text--border span {
	font-size: 0.85em;
}

.infoItem .textBox .textBox__text .oneCast{
	margin-bottom: 30px;
}

.infoItem .textBox .textBox__text .oneCast dt{
	font-weight: bold;
}

.infoItem .textBox .textBox__text .oneCast dd{
	padding-left: 20px;
}

/*
* form
*/
.form_sec {
	color: var(--gray-5);
	margin: 15vh auto 0;
}

.descCnt__text {
	margin-top: 1em;
	font-size: var(--font-r);
}

.form_sec h2,
.thanksTitle {
	font-size: var(--font-m);
	letter-spacing: 0.1em;
	color: var(--gray-5);
	padding-bottom: 0.2em;
	border-bottom: 1px solid var(--gray-3);
}

.formBox,
.infoMail {
	margin-top: var(--margin-s);
}

.formBox .flexBox {
	display: flex;
	flex-wrap: nowrap;
	justify-content: space-between;
	align-items: center;
	gap: 5%;
	width: 100%;
}

.formBox label{
	font-size: var(--font-m);
	font-weight: bold;
}

.formBox div.inputBox p {
	font-size: var(--font-r);
}

.leftItem,
.rightItem {
	width: 50%;
}

.flex--2 .flexBox {
	gap: 1.25%;
}

.radioBtn_box .flexBox {
	justify-content: flex-start;
	margin-top: 0.25em;
}

.radioBtn_box .flexBox .radioBtn {
	display: flex;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: center;
	gap: 20%;
}

.infoMail .flexBox {
	display: flex;
	flex-wrap: nowrap;
	gap: 5%;
}

.infoMail .flexBox .radioBtn {
	gap: 15%;
}

.inputBox .red {
	font-size: 0.85em;
	margin-top: 0.25em;
}

.inputBox span {
	word-break: keep-all;
	font-size: var(--font-r);
}

.inputBox input,
.inputBox select,
.inputBox textarea {
	width: 100%;
	font-size: var(--font-r);
	padding: 1.25em;
	background-color: var(--gray-1);
	outline: 2px solid var(--red-3);
	border: none;
	border-radius: 4px;
	margin-top: 0.5em;
}

.inputBox input:focus,
.inputBox select:focus,
.inputBox textarea:focus {
	outline: 2px solid var(--red-3);
} 

.inputBox select {
	cursor: pointer;
}

.selectWrapper {
	position: relative;
}

.inputBox select {
	appearance: none;
	color: black !important;
}

.inputBox #adSelect td{
	border-bottom: 0.5px solid #000000;
	border-right: dotted 1px #ccc;
	padding: 0 10px; 
}

.inputBox #adSelect td select{
    margin-bottom: 0.5em;
    text-align: center;
    outline: none;
}

#totalFee{
	padding: 30px 10px;
	font-weight: bold;
	text-align: right;
	border-bottom: 1px solid #000000;
}

#totalFee .fee{
	color: var(--red-3);
	font-size: var(--font-l);
}

/*input[type="radio"] {
	position: absolute;
	white-space: nowrap;
	width: 1px;
	height: 1px;
	overflow: hidden;
	border: 0;
	padding: 0;
	clip: rect(0 0 0 0);
	clip-path: inset(50%); 
	margin: -1px;
}*/

input[type="radio"],
input[type="checkbox"] {
	appearance: none;
	position: relative;	
	width: 1em;
	height: 1em;
	background: #fff;
	border: 1px solid var(--gray-3);
	border-radius: 50%;
	margin: 0;
	padding: 0.8em;
	transition: all 0.15s;
}

input[type="radio"]:checked,
input[type="checkbox"]:checked {
	background: var(--red-3);
	border: 1px solid var(--red-3);
}

input[type="radio"]::before,
input[type="checkbox"]::before {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	display: block;
	width: 40%;
	height: 40%;
	background: white;
	border-radius: 50%;
	transform: translate(-50%, -50%);
	opacity: 0;
}

input[type="radio"]:checked::before,
input[type="checkbox"]:checked::before {
	opacity: 1;
}

.selectWrapper:after {
	content: "";
	position: absolute;
	top: 45%;
	right: 0.75em;
	z-index: 1;
	display: inline-block;
	width: 1.5em;
	height: 1em;
	background-image: url(../img/select-arrow.svg);
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center;
}

#pref {
	color: black;
}

#pref.is-empty {
	color: var(--gray-3) !important;
}

::placeholder {
	color: var(--gray-3);
}

.require {
	display: inline-block;
	font-size: 0.6em;
	color: white;
	background-color: var(--red-3);
	padding: 0.15em 0.5em;
	border-radius: 4px;
	margin-left: 0.5em;
	transform: translateY(-0.2em);
}

.caution {
	width: 100%;
	padding: 2em;
	background-color: var(--red-1);
	border: none;
	border-radius: 4px;
	margin-top: var(--margin-s);
}

.caution__title {
	font-size: var(--font-r);
	font-weight: 600;
}

.caution__title--2 {
	margin-top: 2em;
	border-bottom: 1px dashed var(--gray-4);
}

.caution__list {
	margin-top: 0.5em;
}

.caution__title--2 + .caution__list {
	padding-left: 1.5em;
	margin-top: 1em;
}

.caution__title--2 + .caution__list li {
	list-style: circle;
}

.caution__list li ~ li {
	margin-top: 0.25em;
}

.btnCnt {
	display: flex;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
	gap: 5%;
}

.submitBox > input,
.submitBox > a,
.returnBox > input {
	padding-block: 0;
	padding-inline: 0;
	border-width: 0;
	border-style: none;
	display: inline-block;
	font-size: var(--font-m);
	color: white;
	letter-spacing: 0.1em;
	background-color: var(--red-3);
	padding: 0.5em 1.5em;
	border-radius: 8px;
	margin-top: 2em;
	cursor: pointer;
	opacity: 1;
	transition: opacity 0.6s;
}

.returnBox > input {
	background-color: var(--blue-3);
}

@media (hover: hover) {
	.submitBox > input:hover,
	.returnBox > input:hover {
		opacity: 0.7;
	}
}

#formBody input[type="text"].errorInput {
	background-color: var(--red-1) !important;
}

.error {
	font-size: 1.1em;
	font-weight: 600;	
	color: #ffffff;
	padding: 0.25em 0.5em;
	background-color: var(--red-3);
	border-radius: 4px;
	margin: 1em 0;
}


/*
* form check
*/
.check {
	padding-bottom: var(--margin-l);
}

p.formCheck {
	margin-top: 1em;
}

.check #formWraper {

}

.check #formWraper .formBox {
	font-size: var(--font-m);
	color: var(--gray-5);	
}

.check #formWraper .formBox ~ .formBox {
	padding-top: var(--margin-s);
	border-top: 1px solid var(--gray-2);
}

.check #formWraper .formBox label {
	display: block;
	font-size: var(--font-r);
	color: var(--gray-4);
}


/*
* thanks
*/
.thanksBox {
	margin-top: var(--margin-m);
}

.thanksTitle {
	
}

.thanksText {
	margin-top: 1em;
}

.thanksText span {
	font-size: var(--font-m);
	padding-right: 0.5em;
}

/*
 * aside
*/
.relationCnt {
	display: block;
	width: 90%;
	max-width: 50vw;
	margin: var(--margin-l) auto 0;
}

.relationCnt__title {
	font-size: var(--font-r);
	border-bottom: 1px solid var(--gray-2);	
}

.swiper {
	margin-top: 1.25%;
}

.relationCnt a {
	display: flex;
	flex-direction: column;
	opacity: 1;
	transition: opacity 0.6s;
}

@media (hover: hover) {
	.relationCnt a:hover {
		opacity: 0.7;
	}
}

.relationCnt .imgBox {
	width: 100%;
	height: 160px;
	overflow: hidden;
}

.relationCnt .textBox {
	display: block;
	width: 100%;
	font-size: var(--font-s);
	color: var(--gray-5);
	line-height: 1.3;
	margin-top: 1em;
}


/*
* swiper
*/

.swiper-container {
	position: relative;
}

.swiper-button-prev {
	width: 32px !important;
	height: 32px !important;
	left: -40px !important;
}

.swiper-button-next {
	width: 32px !important;
	height: 32px !important;
	right: -40px !important;
}

.swiper-button-prev:after,
.swiper-button-next:after {
	content: "" !important;
	width: 100%;
	height: 100%;
	border: 0;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	margin: auto;
	background-image: url(../img/arrow-button.svg);
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center;
}

.swiper-button-next:after {
	transform: rotate(180deg);
}

.relationCnt .swiper-slide.hidden {
	display: none !important;
}

.relationCnt .swiper-slide .imgBox {
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center;
}

.relationCnt .swiper-slide:nth-of-type(1) .imgBox {
	background-image: url(../../img/01.webp);
}

.relationCnt .swiper-slide:nth-of-type(2) .imgBox {
	background-image: url(../../img/02.webp);
}

.relationCnt .swiper-slide:nth-of-type(3) .imgBox {
	background-image: url(../../img/03.webp);
}

.relationCnt .swiper-slide:nth-of-type(4) .imgBox {
	background-image: url(../../img/04.webp);
}

.relationCnt .swiper-slide:nth-of-type(5) .imgBox {
	background-image: url(../../img/05.webp);
}

.relationCnt .swiper-slide:nth-of-type(6) .imgBox {
	background-image: url(../../img/06.webp);
}

.relationCnt .swiper-slide:nth-of-type(7) .imgBox {
	background-image: url(../../img/07.webp);
}


/*
* footer
*/
footer {
	text-align: center;
	margin-top: var(--margin-l);
	margin-bottom: var(--margin-s);
}

footer .innerCnt {
	display: block;
}

footer a {
	display: inline-block;
}

footer img {
	display: block;
	width: 160px;
}

footer small {
	display: block;
	font-size: var(--font-xs);
	line-height: 1.3;
}

footer small:first-of-type {
	margin-top: 1em;
}

.parallax_content{
	background-attachment: fixed;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
}

.fadeInDown {
	-webkit-animation-fill-mode:both;
	-ms-animation-fill-mode:both;
	animation-fill-mode:both;
	-webkit-animation-duration:1s;
	-ms-animation-duration:1s;
	animation-duration:1s;
	-webkit-animation-name: fadeInDown;
	animation-name: fadeInDown;
	visibility: visible !important;
}
@-webkit-keyframes fadeInDown {
	0% { opacity: 0; -webkit-transform: translateY(0px); }
	100% { opacity: 1; -webkit-transform: translateY(0); }
}
@keyframes fadeInDown {
	0% { opacity: 0; -webkit-transform: translateY(0px); -ms-transform: translateY(0px); transform: translateY(0px); }
	100% { opacity: 1; -webkit-transform: translateY(0); -ms-transform: translateY(0); transform: translateY(0); }
}