@charset "UTF-8";
/* CSS Document */

body {
	max-width: 2000px;
	margin: 0 auto;
}

/*セクション間余白----------------------------------------------------------- */
section {
	padding: 75px 0;
}

/*色関連----------------------------------------------------------- */
.bg_cl1 {background-color: #eeeef5;}
.bg_cl2 {background-color: #f3f2f2;}
.cl_base {color: #ff00cc;}
.cl_main {color: #ef3300;}
.cl_accent {color: #4265a1;}
.cl_white {color: #fff;}

/*リンク色----------------------------------------------------------- */
a:link,a:visited {
	color: #333;
	text-decoration: none;
}

/*Page Top----------------------------------------------------------- */
.pagetop a {
	background-color: #e59753;
	filter: drop-shadow(3px 3px 4px rgba(0, 0, 0, 0.3));
}

/*header----------------------------------------------------------- */
.header {
	width: 100%;
	/* height: 80px; */
	position: sticky;
	top: 0;
	left: 0;
	z-index: 999999;
	background: #fff;
}
.header a {
	display: block;
}
.header_inner {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	min-height: 60px;
}
.logo img {
	width: 240px;
}
/* 画像を入れる場合は削除 */
.header_img p {
	width: fit-content;
}
.header_drawer {
	position: absolute;
	right: 15px;
	top: 50%;
	transform: translateY(-50%);
	width: 28px;
	height: 28px;
	cursor: pointer;
}
.header_drawer span {
	position: absolute;
	width: 100%;
	height: 2px;
	background-color: #000;
}
.header_drawer span:nth-child(1) {
	top: 0;
}
.header_drawer span:nth-child(2) {
	top: 13px;
}
.header_drawer span:nth-child(3) {
	top: 26px;
}
.header_drawer.is-open span {
	transition: all .3s ease 0s;
}
.header_drawer.is-open span:nth-child(1) {
	top: 50%;
	transform: rotate(-45deg);
}
.header_drawer.is-open span:nth-child(2) {
	display: none;
}
.header_drawer.is-open span:nth-child(3) {
	top: 50%;
	transform: rotate(45deg);
}
.header_menus {
	display: flex;
	align-items: center;
	gap: 15px;
}
.header_menu {
	display: flex;
	align-items: center;
	gap: 15px;
}
/* .header_menus.is-open {
	display: flex;
} */
.header_link {
	position: relative;
}
.header_link a {
	padding: 10px 5px;
}
.header_acc-wrap {
	position: absolute;
	top: 80px;
    left: 50%;
    transform: translateX(-50%);
	display: none;
	background: #FFF; /* 背景を明示 */
	z-index: 10;
}
.header_acc-link {
	width: max-content;
	display: block;
}
.header_btn a {
	padding: 5px 30px;
	background-color: orange;
	color: #fff;
}
@media screen and (max-width: 767px) {
	.header_acc-wrap.is-active {

	}
	.header_menus {
		display: none;
		position: absolute;
		top: 60px;
		left: 0;
		width: 100%;
		height: 100vh;
		background-color: #fff;
		color: #000;
		padding: 60px 0 120px;
		overflow: auto;
	}
	.header_menu {
		flex-wrap: wrap;
	}
	.header_link {
		width: 100%;
	}
	.header_link a {
		text-align: center;
		width: inherit;
		color: #000;
		font-size: 1.4rem;
	}
}

/*MV----------------------------------------------------------- */
.mv {
	background: url(../img/pc_fv_bg.png) no-repeat center center/ cover;
}
.fv_wrap {
	position: relative;
}
.fv_btn {
	width: 50%;
	position: absolute;
	left: 3.2%;
	bottom: 1%;
}

/*CTA----------------------------------------------------------- */
.cta {
	background: url(../img/pc_cta_bg.png) no-repeat center center/cover;
	position: relative;
	z-index: 2;
	padding: 150px 0 170px;
}
.cta .white_box {
	border-radius: 15px;
}
.cta .fx-col-40-s {
	-ms-flex-preferred-size: 43%;
	flex-basis: 43%;
	max-width: 43%;
}
.cta .fx-col-60-s {
	-ms-flex-preferred-size: 57%;
	flex-basis: 57%;
	max-width: 57%;
}

/*sec01----------------------------------------------------------- */
.sec01 {
	background: url(../img/pc_sec01_bg.png) no-repeat center top/ cover;
	padding: 75px 0 90px;
}
@media (min-width: 768px) and (max-width: 1229px) {
	.sec01 {
		padding: 7.5% 0 10%;
	}
}

/*sec02----------------------------------------------------------- */
.sec02 {
	margin-top: -30px;
	overflow: hidden;
}
.sec02 .pic_r img {
	min-width: 1000px;
}
.yt-wrapper {
	position: relative;
	width: 80%;
	margin: 0 auto;
}
.yt-wrapper:before {
	content:"";
	display: block;
	padding-top: 56.25%;
}
.yt-wrapper iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
@media (min-width: 768px) and (max-width: 1229px) {
	.sec02 .pic_r img {
		min-width: 80vw;
	}
}

/*sec03----------------------------------------------------------- */
.sec03 {
	background: url(../img/pc_sec03_bg.png) no-repeat center center/cover;
}
.sec03 .fx-row {
	margin-top: -30px;
}
.sec03 [class*="fx-col"] {
	margin-top: 30px;
}

/*sec04----------------------------------------------------------- */
.sec04 .white_box {
	background: #faf4ed;
	height: 100%;
	border-radius: 10px 0 0 10px;
}
.sec04 .fx-row {
	margin-left: 0;
	margin-right: 0;
}
.sec04 [class*="fx-col"] {
	padding-right: 0;
	padding-left: 0;
}
.sec04 h3 {
	font-size: min(2.4vw,32px);
	letter-spacing: 0.08em;
}
.sec04 h3 .font_cg {
	color: #e59753;
	font-size: min(1.8vw,24px);
}
.sec04 h3 .font_cg span {
	font-size: min(2.4vw,32px);
}
.sec04 h3 .jp {
	font-weight: bold;
}
.sec04 h3 .jp span {
	background: #e59753;
	color: #fff;
	padding: 5px;
}
.sec04 .jp .font_s {
	font-size: min(1.8vw,24px);
}

/*sec05----------------------------------------------------------- */
.sec05 {
	background: url(../img/pc_sec05_bg.png) bottom center/cover;
	margin-top: -60px;
	position: relative;
	/* z-index: 0; */
}
.sec05 .white_box {
	border-radius: 15px;
}
.sec05 h3 {
	letter-spacing: 0.08em;
}
.sec05 h3 .font_cg {
	padding-right: 10px;
}
.sec05 h3 .font_l {
	font-size: min(2.2vw,30px);
}
.sec05 .fx {
	display: flex;
	justify-content: center;
	gap: 5px;
}

/*sec06----------------------------------------------------------- */
.sec06 p {
	margin-top: -150px;
}

/*sec07----------------------------------------------------------- */
.sec07 {
	background: #f7f0df;
}
.sec07 .white_box,
.sec07 .white_box_s {
	border-radius: 15px;
}
.sec07 .white_box {
	position: relative;
}
.sec07 .white_box:before {
	position: absolute;
	content: "";
	height: calc(100% - 180px);
	width: 0;
	border-left: 4px dotted #999;
	left: 92px;
}
.sec07 .fx {
	display: flex;
	gap: 15px;
	position: relative;
	z-index: 2;
}
.sec07 .fx:not(:first-child) {
	padding-top: 30px;
}
.sec07 .fx-l {
	width: 11.5%;
}
.sec07 .fx-l p {
	padding: 10px 0;
	background: #fff;
}
.sec07 .fx-r {
	width: 89.5%;
}
.sec07 h3 {
	font-size: min(2.2vw,30px);
	font-weight: bold;
	padding-bottom: 10px;
	letter-spacing: 0.08em;
}
.sec07 .application a {
	color: #e59753;
	text-decoration: underline;
}
.sec07 .white_box_s {
	background: #f7f2eb;
}

/*sec08----------------------------------------------------------- */
.sec08 {
	background: url(../img/pc_sec08_bg.png) no-repeat bottom center/cover;
}
.sec08 .fx-row {
	margin-top: -20px;
}

/*sec09----------------------------------------------------------- */
.sec09 h3 {
	font-size: min(1.8vw,24px);
	font-weight: bold;
	padding: 10px 25px;
	margin-bottom: 30px;
	border-left: 5px solid #e59753;
}
.sec09 h3:not(:first-child) {
	margin-top: 30px;
}
.more_v1_01 {
	display: block;
	margin: 0 auto;
	width: 100%;
	line-height: 1;
	padding: 30px 90px 30px 75px;
	background: #e59753;
	color: #fff;
	font-weight: bold;
	cursor:pointer;
	position: relative;
	border-radius: 10px;
	transition: all .8s;
	font-size: min(1.8vw,24px);
	line-height: 1.2;
	margin-top: 15px;
}
.more_v1_01:before {
	position: absolute;
	transition: all .3s;
	top: 50%;
	left: 30px;
	transform: translateY(-50%);
	font-family: "Font Awesome 5 Free";
	content: "Q";
}
.more_v1_01 .plus {
	position: absolute;
	top: 50%;
	right: 30px;
	transform: translateY(-50%);
	display: block;
	width: 30px;
	height: 30px;
	background: #fff;
	border-radius: 15px;
	transition: all .3s;
}
.more_v1_01 .plus:before,
.more_v1_01 .plus:after {
	position: absolute;
	content: "";
	background: #e59753;
	transition: all .3s;
}
.more_v1_01 .plus:before {
	height: 2px;
	width: 16px;
	top: calc(50% - 1px);
	left: calc(50% - 8px);
}
.more_v1_01 .plus:after {
	height: 16px;
	width: 2px;
	top: calc(50% - 8px);
	left: calc(50% - 1px);
}
.more_v1_01.open .plus:after {
	transform: rotate(90deg);
}
.more_v1_01.open {
	border-radius: 10px 10px 0 0;
}
.more_v1_01.open:after {
}
.more_v1_01_close {
	display: none;
	border: 3px solid #e59753;
	padding: 15px 15px 15px 75px;
	border-radius: 0 0 10px 10px;
}
.sec09 a {
	color: #e59753;
	font-weight: bold;
}

/*sec10----------------------------------------------------------- */
.sec10 {
	background: #f7f0df;
	margin-top: -90px;
}
.sec10 .white_box {
	border-radius: 10px;
}
.sec10 .fx-row > div:first-child {
	border-right: 4px dotted #ccc;
}
.form_wrap {
	padding-left: 30px;
}
.sec10 h3 {
	font-size: 24px;
	font-weight: bold;
	position: relative;
	margin-bottom: 15px;
}
.sec10 h3:before {
	position: absolute;
	content: "1";
	background: #17a1aa;
	color: #fff;
	border-radius: 15px;
	width: 25px;
	height: 25px;
	display: flex;
	align-items: center;
	justify-content: center;
	left: -30px;
	top: 50%;
	transform: translateY(-50%);
	font-size: 18px;
}
.sec10 .fx_row {
	margin-left: -30px;
	margin-right: -30px;
}
.sec10 [class*="fx-col"] {
	padding-left: 30px;
	padding-right: 30px;
}
.sec10 .fx-col-33-s h3:before {
	content: "2"
}
.sec10 form a {
	text-decoration: underline;
}
.sec10 .input_adjust {
	width: 100%;
	padding: 20px;
	border-radius: 15px;
	border: none;
	background: #f5f5f5;
}
.sec10 button {
	border: 0;
	border: none;
	background: none;
	transition: all .3s;
}
.sec10 button:hover {
	opacity: 0.7;
}

/*Footer----------------------------------------------------------- */

.thanks {
	background: #f7f0df;
}