@charset "UTF-8";
@font-face {
	font-family: "Zen Kaku Gothic New";
	src: url("../fonts/ZenKakuGothicNew-Light.woff") format("woff"), url("../fonts/ZenKakuGothicNew-Light.ttf") format("ttf");
	font-weight: 300;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: "Zen Kaku Gothic New";
	src: url("../fonts/ZenKakuGothicNew-Regular.woff") format("woff"), url("../fonts/ZenKakuGothicNew-Regular.ttf") format("ttf");
	font-weight: 400;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: "Zen Kaku Gothic New";
	src: url("../fonts/ZenKakuGothicNew-Medium.woff") format("woff"), url("../fonts/ZenKakuGothicNew-Medium.ttf") format("ttf");
	font-weight: 500;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: "Zen Kaku Gothic New";
	src: url("../fonts/ZenKakuGothicNew-Bold.woff") format("woff"), url("../fonts/ZenKakuGothicNew-Bold.ttf") format("ttf");
	font-weight: 700;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: "Zen Kaku Gothic New";
	src: url("../fonts/ZenKakuGothicNew-Black.woff") format("woff"), url("../fonts/ZenKakuGothicNew-Black.ttf") format("ttf");
	font-weight: 900;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: "Anton";
	src: url("../fonts/Anton-Regular.woff") format("woff"), url("../fonts/Anton-Regular.ttf") format("ttf");
	font-weight: 400;
	font-style: normal;
	font-display: swap;
}
html {
	font-size: 62.5%;
}

body {
	font-family: "Zen Kaku Gothic New", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "MS Pゴシック", "MS PGothic", sans-serif;
	font-size: 4.8vw;
	font-weight: 500;
	line-height: 1.5;
	color: #222;
}
body.open {
	height: 100%;
	overflow: hidden;
}

img {
	width: 100%;
	height: auto;
}

.sp {
	display: block;
}

.pc {
	display: none;
}

#wrap {
	width: 100%;
	overflow: hidden;
}

.section {
	padding: 10.6666666667vw 0 17.0666666667vw;
}

.inner_section {
	width: 87.4666666667vw;
	margin: 0 auto;
}

/* header
------------------------------------------------------------------------- */
#header {
	width: 100%;
	background: #fff;
	-webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
	box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
	position: fixed;
	top: 0;
	left: 0;
	z-index: 1000;
}

.wrap_header {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	height: 17.0666666667vw;
	padding-left: 2.1333333333vw;
}

/* ロゴ */
.header_logo {
	width: 56.5333333333vw;
}

/* ハンバーガーメニュー ここから*/
#nav_toggle {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	width: 17.0666666667vw;
	height: 17.0666666667vw;
	background: #2929B2;
}

#nav_toggle div {
	width: 12.8vw;
	height: 10.4vw;
	margin: 0 auto;
	position: relative;
}

#nav_toggle span {
	display: block;
	width: 10.6666666667vw;
	height: 1px;
	border-radius: 5px;
	background: #fff;
	position: absolute;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	-webkit-transition: top 0.2s ease, -webkit-transform 0.2s ease-in-out;
	transition: top 0.2s ease, -webkit-transform 0.2s ease-in-out;
	transition: transform 0.2s ease-in-out, top 0.2s ease;
	transition: transform 0.2s ease-in-out, top 0.2s ease, -webkit-transform 0.2s ease-in-out;
}

#nav_toggle span:nth-child(1) {
	top: 0;
}

#nav_toggle span:nth-child(2) {
	top: 2.1333333333vw;
}

#nav_toggle span:nth-child(3) {
	top: 4.2666666667vw;
}

#nav_toggle p:nth-child(4) {
	font-size: 3.2vw;
	font-weight: 500;
	width: 100%;
	color: #fff;
	text-align: center;
	position: absolute;
	bottom: 0;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
}

.open #nav_toggle span:nth-child(1) {
	-webkit-transform: translate(-50%, -50%) rotate(30deg);
	transform: translate(-50%, -50%) rotate(30deg);
	top: 2.1333333333vw;
}

.open #nav_toggle span:nth-child(2) {
	width: 0;
}

.open #nav_toggle span:nth-child(3) {
	-webkit-transform: translate(-50%, -50%) rotate(-30deg);
	transform: translate(-50%, -50%) rotate(-30deg);
	top: 2.1333333333vw;
}

/*========== グローバルナビゲーション ==========*/
#g_nav {
	width: 100%;
	height: calc(100vh - 17.0666666667vw);
	background: -webkit-gradient(linear, left top, left bottom, from(#1571DA), to(#2929B2));
	background: linear-gradient(to bottom, #1571DA 0%, #2929B2 100%);
	padding-top: 10.6666666667vw;
	position: fixed;
	top: 17.0666666667vw;
	left: 0;
	z-index: 1000;
	opacity: 0;
	visibility: hidden;
	-webkit-transition: 0.2s;
	transition: 0.2s;
}

.open #g_nav {
	opacity: 1;
	visibility: visible;
}

.ul_nav {
	width: 78.9333333333vw;
	margin: 0 auto 12.8vw;
}
.ul_nav li a {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	font-weight: bold;
	font-size: 4.2666666667vw;
	padding: 4.2666666667vw 0;
	color: #fff;
	border-bottom: 1px dashed #fff;
}
.ul_nav li a::before {
	content: "";
	display: block;
	width: 2.1333333333vw;
	height: 3.4666666667vw;
	background: url(../images/arrow_white.svg) no-repeat;
	background-size: contain;
	margin-right: 4.2666666667vw;
}
.ul_nav li:first-child a {
	padding-top: 0;
}

/* ボタン */
.wrap_header_btn {
	width: 87.4666666667vw;
	margin: 0 auto;
}
.wrap_header_btn .btn {
	margin-bottom: 4.2666666667vw;
}

.btn {
	width: 100%;
	position: relative;
	z-index: 1;
	border-radius: 10.6666666667vw;
	overflow: hidden;
}
.btn:last-child {
	margin-bottom: 0;
}
.btn::before {
	content: "";
	width: 50%;
	height: 100%;
	background: -webkit-gradient(linear, left top, right top, from(rgba(255, 255, 255, 0)), to(rgba(255, 255, 255, 0.3)));
	background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.3) 100%);
	position: absolute;
	top: 0;
	left: -75%;
	-webkit-transform: skewX(-25deg);
	transform: skewX(-25deg);
	z-index: 10;
	pointer-events: none;
}
.btn a {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	height: 21.3333333333vw;
	padding: 2.1333333333vw;
	border: 4px solid #fff;
	border-radius: 10.6666666667vw;
	color: #fff;
	font-weight: 900;
	font-size: 6.4vw;
	letter-spacing: 0.05em;
	-webkit-box-shadow: 10px 12px 10px rgba(0, 0, 0, 0.16);
	box-shadow: 10px 12px 10px rgba(0, 0, 0, 0.16);
	position: relative;
	z-index: 1;
}
.btn a::before {
	content: "";
	display: block;
	width: 17.0666666667vw;
	height: 17.0666666667vw;
	background-repeat: no-repeat;
	background-size: contain;
	margin-right: 6.4vw;
}
.btn a::after {
	content: "";
	display: block;
	width: calc(100% - 2.1333333333vw);
	height: 17.0666666667vw;
	border-radius: 10.6666666667vw;
	-webkit-box-shadow: 8px 8px 8px rgba(0, 0, 0, 0.16);
	box-shadow: 8px 8px 8px rgba(0, 0, 0, 0.16);
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	z-index: -1;
}
.btn.btn_tel a {
	background: #1571DA;
}
.btn.btn_tel a::before {
	background-image: url(../images/icon_tel_big.svg);
}
.btn.btn_mail a {
	background: #FF6B09;
}
.btn.btn_mail a::before {
	background-image: url(../images/icon_mail_big.svg);
}

.btn:hover::before {
	-webkit-animation: shine 0.7s;
	animation: shine 0.7s;
}

@-webkit-keyframes shine {
	100% {
		left: 125%;
	}
}

@keyframes shine {
	100% {
		left: 125%;
	}
}
/* main
------------------------------------------------------------------------- */
/*========== FV ==========*/
.fv {
	background: url(../images/fv_bg_img01_sp.jpg) no-repeat;
	background-size: cover;
	margin-top: 17.0666666667vw;
	padding: calc(8 / 375 * 100vw) 0 7.2vw;
	position: relative;
	z-index: 1;
}
.fv::after {
	content: "";
	display: block;
	width: 32vw;
	height: 40vw;
	background: url(../images/fv_human_sp.png) no-repeat;
	background-size: contain;
	position: absolute;
	bottom: 0;
	right: 0;
	z-index: -1;
}

.inner_fv {
	width: 87.4666666667vw;
	margin: 0 auto;
}

.fv_txt {
	margin-bottom: calc(8 / 375 * 100vw);
}

.fv_h1 {
	margin-bottom: 6.4vw;
}

.fv_price {
	width: 64vw;
	margin-top: 4.2666666667vw;
}

/*========== Solution ==========*/
.solution {
	background: linear-gradient(to bottom, #fff 0px, #fff 32vw, #CFE6FF 32vw);
	position: relative;
	z-index: 1;
}
.solution::before, .solution::after {
	content: "";
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	position: absolute;
	z-index: -1;
}
.solution::before {
	border-color: #fff transparent transparent transparent;
	border-width: 17.0666666667vw 36.8vw 0px 0px;
	top: 32vw;
	left: 0;
}
.solution::after {
	border-color: transparent transparent #fff transparent;
	border-width: 0px 0px 17.0666666667vw 36.8vw;
	bottom: 0;
	right: 0;
}
.solution .inner_section::before, .solution .inner_section::after {
	content: "";
	display: block;
	background-repeat: no-repeat;
	background-size: contain;
	position: absolute;
	z-index: 1;
}
.solution .inner_section::before {
	background-image: url(../images/solution_icon10.svg);
	width: 27.4666666667vw;
	height: 15.7333333333vw;
	top: 0;
	left: 2.1333333333vw;
}
.solution .inner_section::after {
	background-image: url(../images/solution_icon11.svg);
	width: 24.5333333333vw;
	height: 25.6vw;
	bottom: 0;
	right: 2.1333333333vw;
}

.ttl_en {
	width: 42.6666666667vw;
	margin: 0 auto 4.2666666667vw;
}

.ttl_h2 {
	font-weight: 900;
	font-size: 6.4vw;
	letter-spacing: 0.05em;
	margin-bottom: 4.2666666667vw;
	text-align: center;
}

.c_orange {
	color: #FF6B09;
}

.lead_text {
	font-weight: bold;
	font-size: 5.3333333333vw;
	margin-bottom: 8.5333333333vw;
}
.lead_text .c_orange {
	text-decoration: underline;
}

.solution .lead_text {
	margin-bottom: 17.0666666667vw;
}

.solution_contents {
	height: 59.4666666667vw;
	background: url(../images/solution_contents_bg.svg) no-repeat;
	background-size: contain;
	padding-top: 10.6666666667vw;
	margin-bottom: 10.6666666667vw;
	position: relative;
	z-index: 1;
}
.solution_contents:last-child {
	margin-bottom: 0;
}
.solution_contents::before {
	content: "";
	display: block;
	width: 17.0666666667vw;
	height: 17.0666666667vw;
	background-repeat: no-repeat;
	background-size: contain;
	position: absolute;
	top: 0;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
}
.solution_contents:nth-child(1)::before {
	background-image: url(../images/solution_icon01.svg);
}
.solution_contents:nth-child(2)::before {
	background-image: url(../images/solution_icon02.svg);
}
.solution_contents:nth-child(3)::before {
	background-image: url(../images/solution_icon03.svg);
}
.solution_contents:nth-child(4)::before {
	background-image: url(../images/solution_icon04.svg);
}
.solution_contents:nth-child(5)::before {
	background-image: url(../images/solution_icon05.svg);
}
.solution_contents:nth-child(6)::before {
	background-image: url(../images/solution_icon06.svg);
}
.solution_contents:nth-child(7)::before {
	background-image: url(../images/solution_icon07.svg);
}
.solution_contents:nth-child(8)::before {
	background-image: url(../images/solution_icon08.svg);
}
.solution_contents:nth-child(9)::before {
	background-image: url(../images/solution_icon09.svg);
}

.ttl_h3_solution {
	text-align: center;
	font-weight: 900;
	font-size: 6.4vw;
	color: #1571DA;
	margin-bottom: 2.1333333333vw;
}

.marker_yellow {
	background: linear-gradient(to bottom, transparent calc(100% - 12px), #FFFF00 calc(100% - 12px), #FFFF00 calc(100% - 4px), transparent calc(100% - 4px));
}

.solution_txt {
	width: 78.9333333333vw;
	margin: 0 auto;
}

/*========== Features ==========*/
.features_contents {
	background: #3797FF;
	padding-bottom: 17.0666666667vw;
	margin-bottom: 6.4vw;
	position: relative;
	z-index: 1;
}
.features_contents:last-child {
	margin-bottom: 0;
}
.features_contents::before, .features_contents::after {
	content: "";
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	position: absolute;
	z-index: -1;
}
.features_contents::before {
	border-color: #fff transparent transparent transparent;
	border-width: 17.0666666667vw 51.2vw 0px 0px;
	top: 0;
	left: 0;
}
.features_contents::after {
	border-color: transparent transparent #fff transparent;
	border-width: 0px 0px 17.0666666667vw 51.2vw;
	bottom: 0;
	right: 0;
}
.features_contents:nth-child(even)::before {
	border-color: transparent #fff transparent transparent;
	border-width: 0 51.2vw 17.0666666667vw 0px;
	left: auto;
	right: 0;
}
.features_contents:nth-child(even)::after {
	border-color: transparent transparent transparent #fff;
	border-width: 17.0666666667vw 0 0px 51.2vw;
	right: auto;
	left: 0;
}
.features_contents:nth-child(even) .features_point {
	margin-left: auto;
}
.features_contents:nth-child(2) {
	background: #1571DA;
}
.features_contents:nth-child(3) {
	background: #2929B2;
}

.features_point {
	width: 26.4vw;
}

.img_point {
	width: 78.9333333333vw;
	margin: 0 auto 6.4vw;
}

.wrap_features_txt {
	width: 78.9333333333vw;
	margin: 0 auto;
	color: #fff;
	letter-spacing: 0.05em;
}

.ttl_h3_features {
	font-weight: 900;
	font-size: 6.4vw;
	margin-bottom: 4.2666666667vw;
	text-align: center;
}

/*========== CTA ==========*/
.cta {
	padding: 17.0666666667vw 0;
	background: url(../images/cta_bg_img_sp.jpg) no-repeat center;
	background-size: cover;
}

.ttl_cta {
	width: 90.1333333333vw;
	margin: 0 auto;
}

.cta_txt {
	margin: 4.2666666667vw 0 6.4vw;
	font-weight: bold;
	color: #fff;
	text-shadow: 2px 2px 0 #005E32;
	text-align: center;
}

.wrap_cta_btn {
	width: 87.4666666667vw;
	margin: 0 auto;
}
.wrap_cta_btn .btn {
	margin-bottom: 4.2666666667vw;
}
.wrap_cta_btn .btn:last-child {
	margin-bottom: 0;
}

/*========== Service ==========*/
.service {
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0, #fff), color-stop(32vw, #fff), color-stop(32vw, #D9F4E8), to(#CFE6FF));
	background: linear-gradient(to bottom, #fff 0, #fff 32vw, #D9F4E8 32vw, #CFE6FF 100%);
	position: relative;
	z-index: 1;
}
.service::before, .service::after {
	content: "";
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	position: absolute;
	top: 32vw;
}
.service::before {
	border-color: #ffffff transparent transparent transparent;
	border-width: 21.3333333333vw 21.3333333333vw 0px 0px;
	left: 0;
}
.service::after {
	border-color: transparent #ffffff transparent transparent;
	border-width: 0px 21.3333333333vw 21.3333333333vw 0px;
	right: 0;
}

.service_contents {
	background: #fff;
	padding-top: 12.8vw;
	margin-bottom: 2.1333333333vw;
	position: relative;
	z-index: 1;
}
.service_contents:last-child {
	margin-bottom: 0;
}
.service_contents::before, .service_contents::after {
	content: "";
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	position: absolute;
	z-index: -1;
}
.service_contents::before {
	border-color: transparent #3797FF transparent transparent;
	border-width: 0 19.4666666667vw 12.8vw 0px;
	top: 0;
	right: 0;
}
.service_contents::after {
	border-color: transparent transparent transparent #3797FF;
	border-width: 63.4666666667vw 0 0px 87.4666666667vw;
	bottom: 0;
	left: 0;
}

.wrap_service_txt::after {
	content: "";
	display: block;
	width: 100%;
	height: 69.8666666667vw;
	margin-top: 4.2666666667vw;
	background-repeat: no-repeat;
	background-size: contain;
}

.service_contents:nth-child(1) .wrap_service_txt::after {
	background-image: url(../images/service_icon01.svg);
}
.service_contents:nth-child(2)::before {
	border-color: transparent #1571DA transparent transparent;
}
.service_contents:nth-child(2)::after {
	border-color: transparent transparent transparent #1571DA;
}
.service_contents:nth-child(2) .wrap_service_txt::after {
	background-image: url(../images/service_icon02.svg);
}
.service_contents:nth-child(3)::before {
	border-color: transparent #2929B2 transparent transparent;
}
.service_contents:nth-child(3)::after {
	border-color: transparent transparent transparent #2929B2;
}
.service_contents:nth-child(3) .wrap_service_txt::after {
	background-image: url(../images/service_icon03.svg);
}
.service_contents:nth-child(4)::before {
	border-color: transparent #15BFDA transparent transparent;
}
.service_contents:nth-child(4)::after {
	border-color: transparent transparent transparent #15BFDA;
}
.service_contents:nth-child(4) .wrap_service_txt::after {
	background-image: url(../images/service_icon04.svg);
}
.service_contents:nth-child(5)::before {
	border-color: transparent #17BA6E transparent transparent;
}
.service_contents:nth-child(5)::after {
	border-color: transparent transparent transparent #17BA6E;
}
.service_contents:nth-child(5) .wrap_service_txt::after {
	background-image: url(../images/service_icon05.svg);
}
.service_contents:nth-child(6)::before {
	border-color: transparent #005E32 transparent transparent;
}
.service_contents:nth-child(6)::after {
	border-color: transparent transparent transparent #005E32;
}
.service_contents:nth-child(6) .wrap_service_txt::after {
	background-image: url(../images/service_icon06.svg);
}
.service_contents:nth-child(7)::before {
	border-color: transparent #95BF07 transparent transparent;
}
.service_contents:nth-child(7)::after {
	border-color: transparent transparent transparent #95BF07;
}
.service_contents:nth-child(7) .wrap_service_txt::after {
	background-image: url(../images/service_icon07.svg);
}

.ttl_h3_service {
	width: 78.9333333333vw;
	font-weight: 900;
	font-size: 6.4vw;
	color: #1571DA;
	padding-bottom: 4.2666666667vw;
	margin: 0 auto 4.2666666667vw;
	border-bottom: 1px solid #1571DA;
}

.wrap_service_txt p {
	width: 78.9333333333vw;
	margin: 0 auto;
}
.wrap_service_txt p .marker_yellow {
	font-weight: bold;
}

/*========== Flow ==========*/
.flow {
	position: relative;
	z-index: 1;
}
.flow::before, .flow::after {
	content: "";
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	position: absolute;
	z-index: -1;
}
.flow::before {
	border-color: #CFE6FF transparent transparent transparent;
	border-width: 64vw 100vw 0px 0px;
	top: 0;
	left: 0;
}
.flow::after {
	border-color: transparent transparent #CFE6FF transparent;
	border-width: 0px 0px 64vw 100vw;
	bottom: 0;
	right: 0;
}

.wrap_flow_contents {
	position: relative;
	z-index: 1;
}
.wrap_flow_contents::after {
	content: "";
	display: block;
	width: 4.2666666667vw;
	height: 100%;
	background: #3797FF;
	position: absolute;
	top: 0;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	z-index: -1;
}

.flow_contents {
	height: 91.4666666667vw;
	background: url(../images/flow_bg_contents_sp.png) no-repeat;
	background-size: contain;
	padding: 6.4vw 4.2666666667vw;
	margin-bottom: 4.2666666667vw;
}
.flow_contents:last-child {
	margin-bottom: 0;
}

.flow_step {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	font-size: 10.6666666667vw;
	font-weight: 400;
	font-family: "Anton";
	letter-spacing: 0.1em;
	color: #1571DA;
	margin-bottom: 3.4666666667vw;
}
.flow_step::before {
	content: "";
	display: block;
	width: 21.3333333333vw;
	height: 21.3333333333vw;
	background-repeat: no-repeat;
	background-size: contain;
	margin-right: 6.4vw;
}

.flow_contents:nth-child(1) .flow_step::before {
	background-image: url(../images/flow_icon01.svg);
}
.flow_contents:nth-child(2) .flow_step::before {
	background-image: url(../images/flow_icon02.svg);
}
.flow_contents:nth-child(3) .flow_step::before {
	background-image: url(../images/flow_icon03.svg);
}
.flow_contents:nth-child(4) .flow_step::before {
	background-image: url(../images/flow_icon04.svg);
}

.ttl_h3_flow {
	font-weight: 900;
	font-size: 8.5333333333vw;
	letter-spacing: 0.05em;
	color: #1571DA;
	margin-bottom: 2.1333333333vw;
}

.wrap_flow_txt p a {
	color: #FF6B09;
	text-decoration: underline;
}
.wrap_flow_txt p span {
	font-size: 4.2666666667vw;
}

/*========== FAQ ==========*/
.dl_faq dt, .dl_faq dd {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	font-size: 4.2666666667vw;
	position: relative;
	z-index: 1;
}
.dl_faq dt::before, .dl_faq dd::before {
	content: "";
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	position: absolute;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	z-index: -1;
}
.dl_faq dt {
	padding: 2.1333333333vw 2.1333333333vw 2.1333333333vw 4.2666666667vw;
	background: #1571DA;
	font-weight: 900;
	color: #fff;
}
.dl_faq dt::before {
	border-color: transparent transparent transparent #ffffff;
	border-width: 2.1333333333vw 0px 2.1333333333vw 2.1333333333vw;
	left: 0;
}
.dl_faq dd {
	padding: 2.1333333333vw 2.1333333333vw 1.0666666667vw 4.2666666667vw;
	margin-bottom: 6.4vw;
	background: #CFE6FF;
}
.dl_faq dd:last-of-type {
	margin-bottom: 0;
}
.dl_faq dd::before {
	border-color: transparent #ffffff transparent transparent;
	border-width: 2.1333333333vw 2.1333333333vw 2.1333333333vw 0px;
	right: 0;
}
.dl_faq dd .faq_icon {
	color: #1571DA;
}
.dl_faq dd .c_orange {
	text-decoration: underline;
}
.dl_faq .faq_icon {
	font-family: "Anton";
	font-size: 6.4vw;
	margin-right: 2.1333333333vw;
}

/*========== Contact ==========*/
.contact {
	position: relative;
	z-index: 1;
}
.contact::before {
	content: "";
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-color: #CFE6FF transparent transparent transparent;
	border-width: 53.3333333333vw 100vw 0px 0px;
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
}
.contact .inner_section {
	width: 95.7333333333vw;
}
.contact .lead_text {
	width: 87.4666666667vw;
	margin: 0 auto 10.6666666667vw;
}

/* 電話でのお問い合わせ */
.wrap_contact_tel {
	width: 87.4666666667vw;
	margin: 0 auto;
	padding: 8.5333333333vw 0;
	border-top: 1px solid #3797FF;
	border-bottom: 1px solid #3797FF;
}

.ttl_h3_contact {
	font-weight: 900;
	font-size: 6.4vw;
	color: #1571DA;
	text-align: center;
	margin-bottom: 6.4vw;
}

.accept_time {
	text-align: center;
	margin-top: 4.2666666667vw;
}

/* フォームでのお問い合わせ */
.wrap_contact_form {
	margin-top: 12.8vw;
}

.contact_form {
	background: #CFE6FF;
	padding: 17.0666666667vw 0;
	position: relative;
	z-index: 1;
}
.contact_form::before, .contact_form::after {
	content: "";
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	position: absolute;
	z-index: -1;
}
.contact_form::before {
	border-color: #ffffff transparent transparent transparent;
	border-width: 12.8vw 19.2vw 0px 0px;
	top: 0;
	left: 0;
}
.contact_form::after {
	border-color: transparent transparent #ffffff transparent;
	border-width: 0px 0px 12.8vw 19.2vw;
	bottom: 0;
	right: 0;
}

.dl_contact {
	width: 87.4666666667vw;
	margin: 0 auto;
}
.dl_contact dt {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	font-weight: bold;
	margin-bottom: 2.1333333333vw;
}
.dl_contact dd {
	margin-bottom: 6.4vw;
}
.dl_contact dd:last-of-type {
	margin-bottom: 0;
}
.dl_contact .required {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	width: 10.6666666667vw;
	height: 6.9333333333vw;
	font-weight: 900;
	font-size: 3.7333333333vw;
	background: #2929B2;
	color: #fff;
	margin-right: 4.2666666667vw;
}

input[type=text],
input[type=tel],
input[type=email],
textarea {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	width: 100%;
	border: 1px solid #222;
	border-radius: 1.3333333333vw;
	padding: 3.0666666667vw 2.1333333333vw;
}

::-webkit-input-placeholder {
	font-family: "Zen Kaku Gothic New", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "MS Pゴシック", "MS PGothic", sans-serif;
	font-size: 4.8vw;
	font-weight: 500;
	color: rgba(34, 34, 34, 0.4);
}

::-moz-placeholder {
	font-family: "Zen Kaku Gothic New", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "MS Pゴシック", "MS PGothic", sans-serif;
	font-size: 4.8vw;
	font-weight: 500;
	color: rgba(34, 34, 34, 0.4);
}

:-ms-input-placeholder {
	font-family: "Zen Kaku Gothic New", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "MS Pゴシック", "MS PGothic", sans-serif;
	font-size: 4.8vw;
	font-weight: 500;
	color: rgba(34, 34, 34, 0.4);
}

::-ms-input-placeholder {
	font-family: "Zen Kaku Gothic New", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "MS Pゴシック", "MS PGothic", sans-serif;
	font-size: 4.8vw;
	font-weight: 500;
	color: rgba(34, 34, 34, 0.4);
}

::placeholder {
	font-family: "Zen Kaku Gothic New", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "MS Pゴシック", "MS PGothic", sans-serif;
	font-size: 4.8vw;
	font-weight: 500;
	color: rgba(34, 34, 34, 0.4);
}

/* チェックボックス */
.dd_checkbox {
	position: relative;
	padding: 0 0 0 9.3333333333vw;
}

.dd_checkbox a {
	color: #222;
	font-weight: 500;
	font-weight: bold;
}

.dd_checkbox .wpcf7-form-control-wrap {
	position: static;
}

.dd_checkbox .wpcf7-list-item {
	margin: 0;
}

input[type=checkbox] {
	display: none;
}

.dd_checkbox input + span {
	cursor: pointer;
	display: inline-block;
	width: auto;
}

.dd_checkbox input + span::before {
	background: #fff;
	border: 1px solid #222;
	content: "";
	display: block;
	position: absolute;
	top: 50%;
	left: 1.3333333333vw;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	width: 5.3333333333vw;
	height: 5.3333333333vw;
}

.dd_checkbox input + span::after {
	content: "";
	display: block;
	background: url(../images/icon_contact_check.svg) no-repeat;
	background-size: contain;
	width: 4vw;
	height: 5.6vw;
	opacity: 0;
	position: absolute;
	top: 50%;
	left: 2.1333333333vw;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}

input[type=checkbox]:checked + span::before {
	background: #fff;
}

input[type=checkbox]:checked + span::after {
	opacity: 1;
}

/* チェックボックスが複数の場合 */
.dd_checkbox.dd_checkbox2 {
	padding: 0;
}
.dd_checkbox.dd_checkbox2 .wpcf7-form-control {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	gap: 4.2666666667vw 6.4vw;
}

.dd_checkbox2 .wpcf7-list-item {
	position: relative;
	padding-left: 9.3333333333vw;
	display: block;
}

/* プライバシーポリシー */
.wrap_privacy_policy {
	height: 77.3333333333vw;
	background: #fff;
	padding: 4.2666666667vw;
	margin-bottom: 4.2666666667vw;
	overflow-y: auto;
	font-size: 4.2666666667vw;
	border: 1px solid #222;
	border-radius: 0.8vw;
}

.ttl_policy {
	font-weight: bold;
	font-size: 4.8vw;
	margin-bottom: 2.1333333333vw;
}

.dl_policy {
	margin-top: 2.1333333333vw;
}
.dl_policy dt {
	font-weight: bold;
	margin-bottom: 2.1333333333vw;
}
.dl_policy dd {
	margin-bottom: 6.4vw;
}
.dl_policy dd:last-of-type {
	margin-bottom: 0;
}
.dl_policy dd a {
	color: #FF6B09;
	text-decoration: underline;
}

/* 送信ボタン */
.wrap_btn_submit {
	width: 87.4666666667vw;
	margin: 14.4vw auto 0;
	position: relative;
	z-index: 1;
}
.wrap_btn_submit::before {
	content: "";
	display: block;
	width: 4.2666666667vw;
	height: 4.2666666667vw;
	background: url(../images/arrow_btn_submit.svg) no-repeat;
	background-size: contain;
	position: absolute;
	top: 50%;
	right: 29.0666666667vw;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	pointer-events: none;
}
.wrap_btn_submit::after {
	content: "";
	display: block;
	width: calc(100% - 4.2666666667vw);
	height: 12.8vw;
	border-radius: 10.6666666667vw;
	-webkit-box-shadow: 8px 8px 8px rgba(0, 0, 0, 0.16);
	box-shadow: 8px 8px 8px rgba(0, 0, 0, 0.16);
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	pointer-events: none;
}
.wrap_btn_submit input {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	font-family: "Zen Kaku Gothic New", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "MS Pゴシック", "MS PGothic", sans-serif;
	font-weight: bold;
	font-size: 4.8vw;
	letter-spacing: 0.1em;
	width: 100%;
	height: 17.0666666667vw;
	padding: 2.1333333333vw;
	border: 4px solid #fff;
	border-radius: 10.6666666667vw;
	color: #fff;
	-webkit-box-shadow: 10px 12px 10px rgba(0, 0, 0, 0.16);
	box-shadow: 10px 12px 10px rgba(0, 0, 0, 0.16);
	background: #FF6B09;
	padding-right: 8.5333333333vw;
}

.btn_submit {
	border-radius: 10.6666666667vw;
	overflow: hidden;
	position: relative;
}
.btn_submit:last-child {
	margin-bottom: 0;
}
.btn_submit::before {
	content: "";
	width: 50%;
	height: 100%;
	background: -webkit-gradient(linear, left top, right top, from(rgba(255, 255, 255, 0)), to(rgba(255, 255, 255, 0.3)));
	background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.3) 100%);
	position: absolute;
	top: 0;
	left: -75%;
	-webkit-transform: skewX(-25deg);
	transform: skewX(-25deg);
	z-index: 10;
	pointer-events: none;
}
.btn_submit:hover::before {
	-webkit-animation: shine 0.7s;
	animation: shine 0.7s;
}
.wpcf7-spinner {
	display: none;
}

/*========== Company ==========*/
.company {
	position: relative;
	z-index: 1;
}
.company::before, .company::after {
	content: "";
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	position: absolute;
	z-index: -1;
}
.company::before {
	border-color: transparent #CFE6FF transparent transparent;
	border-width: 0px 100vw 53.3333333333vw 0px;
	top: 0;
	right: 0;
}
.company::after {
	border-color: transparent transparent transparent #CFE6FF;
	border-width: 17.0666666667vw 0px 0px 100vw;
	bottom: 0;
	left: 0;
}
.company .inner_section {
	width: 79.2vw;
}

.dl_company {
	margin-top: 8.5333333333vw;
}
.dl_company div {
	border-bottom: 1px solid #D5D5D5;
	padding: 6.4vw 0;
}
.dl_company div:first-child {
	padding-top: 0;
}
.dl_company dt {
	font-weight: bold;
	margin-bottom: 2.1333333333vw;
}

.google_map {
	margin-top: 8.5333333333vw;
	position: relative;
	z-index: 1;
}
.google_map::before {
	content: "";
	display: block;
	width: 100%;
	padding-top: 100%;
}
.google_map iframe {
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
}

.address {
	margin: 2.1333333333vw 0;
}
.address .ttl_address {
	font-weight: bold;
}

/*========== フローティング ==========*/
.wrap_floating_btn {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	gap: 5.3333333333vw;
	width: 100%;
	background: rgba(255, 255, 255, 0.4);
	position: fixed;
	bottom: 0;
	left: 0;
	z-index: 100;
}

.btn_floating {
	width: 45.6vw;
	border-radius: 2.1333333333vw;
	position: relative;
	z-index: 1;
	overflow: hidden;
}
.btn_floating::before {
	content: "";
	width: 50%;
	height: 100%;
	background: -webkit-gradient(linear, left top, right top, from(rgba(255, 255, 255, 0)), to(rgba(255, 255, 255, 0.3)));
	background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.3) 100%);
	position: absolute;
	top: 0;
	left: -75%;
	-webkit-transform: skewX(-25deg);
	transform: skewX(-25deg);
	z-index: 10;
	pointer-events: none;
}
.btn_floating::after {
	content: "";
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-color: transparent transparent transparent #fff;
	border-width: 1.3333333333vw 0px 1.3333333333vw 2.1333333333vw;
	position: absolute;
	top: 50%;
	right: 2.1333333333vw;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	z-index: 1;
	pointer-events: none;
}
.btn_floating a {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	height: 17.0666666667vw;
	padding-right: 2.1333333333vw;
	color: #fff;
	font-size: 5.3333333333vw;
	letter-spacing: 0.05em;
	font-weight: bold;
	border-radius: 2.1333333333vw;
	position: relative;
	z-index: 1;
}
.btn_floating a::before {
	content: "";
	display: block;
	width: 8.5333333333vw;
	height: 8.5333333333vw;
	background-repeat: no-repeat;
	background-size: contain;
	margin-right: 2.4vw;
}
.btn_floating a::after {
	content: "";
	display: block;
	width: calc(100% - 2.1333333333vw);
	height: 14.9333333333vw;
	border-radius: 2.1333333333vw;
	-webkit-box-shadow: 8px 8px 8px rgba(0, 0, 0, 0.16);
	box-shadow: 8px 8px 8px rgba(0, 0, 0, 0.16);
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	z-index: -1;
}
.btn_floating.btn_floating_tel a {
	background: #1571DA;
}
.btn_floating.btn_floating_tel a::before {
	background-image: url(../images/icon_tel_small.svg);
}
.btn_floating.btn_floating_tel a::after {
	background: #3797FF;
}
.btn_floating.btn_floating_mail a {
	background: #FE4E13;
}
.btn_floating.btn_floating_mail a::before {
	background-image: url(../images/icon_mail_small.svg);
}
.btn_floating.btn_floating_mail a::after {
	background: #FF6B09;
}

/* footer
------------------------------------------------------------------------- */
#footer {
	padding-bottom: calc(64 / 375 * 100vw);
	background: #2929B2;
}

#footer.thanks_footer {
	padding-bottom: 0;
}

.copyright {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	height: 10.6666666667vw;
	font-size: 4.2666666667vw;
	color: #fff;
}

/* 送信完了
------------------------------------------------------------------------- */
.fv_thanks {
	display: flex;
	justify-content: center;
	align-items: center;
	height: calc(180 / 375 * 100vw);
	margin-top: 17.0666666667vw;
	background: #2929B2;
}

.ttl_h1_thanks {
	color: #fff;
	font-weight: 900;
	font-size: calc(24 / 375 * 100vw);
	letter-spacing: 0.05em;
}

.wrap_thanks_text p {
	margin-bottom: calc(24 / 375 * 100vw);
}

.wrap_thanks_text p:last-child {
	margin-bottom: 0;
}

.btn_top a {
	background: #FE4E13;
}

.btn_top a::after {
	background: #FF6B09;
}

@media (min-width: 769px) {
	body {
		font-size: min(1.3235294118vw, 18px);
	}
	.sp {
		display: none;
	}
	.pc {
		display: block;
	}
	.section {
		padding: min(2.9411764706vw, 40px) 0 min(5.8823529412vw, 80px);
	}
	.inner_section {
		width: min(85.2941176471vw, 1160px);
	}
	/* header
	------------------------------------------------------------------------- */
	.wrap_header {
		width: min(96.4705882353vw, 1312px);
		height: min(4.7058823529vw, 64px);
		margin: 0 auto;
		padding-left: 0;
	}
	/* ロゴ */
	.header_logo {
		width: min(15.5882352941vw, 212px);
	}
	/* ハンバーガーメニュー ここから*/
	#nav_toggle {
		display: none;
	}
	/*========== グローバルナビゲーション ==========*/
	#g_nav {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
		width: min(69.1176470588vw, 940px);
		height: 100%;
		background: none;
		padding-top: 0;
		position: static;
		opacity: 1;
		visibility: visible;
		-webkit-transition: 0;
		transition: 0;
	}
	.ul_nav {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
		width: min(46.7647058824vw, 636px);
		margin: 0;
	}
	.ul_nav li a {
		font-size: min(1.3235294118vw, 18px);
		padding: 0;
		color: #210D04;
		border-bottom: none;
		-webkit-transition: 0.2s;
		transition: 0.2s;
	}
	.ul_nav li a:hover {
		color: #FF6B09;
	}
	.ul_nav li a::before {
		content: none;
	}
	/* ボタン */
	.wrap_header_btn {
		width: min(20.5882352941vw, 280px);
		margin: 0;
	}
	.wrap_header_btn .btn {
		margin-bottom: 0;
	}
	.wrap_header_btn .btn.btn_tel {
		display: none;
	}
	.btn {
		border-radius: min(2.9411764706vw, 40px);
	}
	.btn a {
		height: min(4.1176470588vw, 56px);
		padding: 0 min(0.2941176471vw, 4px);
		border-radius: min(2.9411764706vw, 40px);
		font-size: min(1.4705882353vw, 20px);
		-webkit-box-shadow: 4px 4px 4px rgba(0, 0, 0, 0.16);
		box-shadow: 4px 4px 4px rgba(0, 0, 0, 0.16);
	}
	.btn a::before {
		width: min(2.9411764706vw, 40px);
		height: min(2.9411764706vw, 40px);
		margin-right: min(1.7647058824vw, 24px);
	}
	.btn a::after {
		width: calc(100% - min(0.5882352941vw, 8px));
		height: min(2.9411764706vw, 40px);
		border-radius: min(2.9411764706vw, 40px);
	}
	/* main
	------------------------------------------------------------------------- */
	/*========== FV ==========*/
	.fv {
		background-image: url(../images/fv_bg_img01_pc.jpg);
		margin-top: min(4.7058823529vw, 64px);
		padding: calc(8 / 1360 * 100vw) 0 calc(10 / 1360 * 100vw);
	}
	.fv::after {
		width: 17.9411764706vw;
		height: 22.3529411765vw;
		background-image: url(../images/fv_human_pc.png);
		right: 1.7647058824vw;
	}
	.fv .btn {
		width: 26.4705882353vw;
		margin: 0 auto;
	}
	.fv .btn a {
		height: 5.8823529412vw;
		font-size: 1.7647058824vw;
		border-radius: 2.9411764706vw;
	}
	.fv .btn a::before {
		width: 4.7058823529vw;
		height: 4.7058823529vw;
		margin-right: 2.9411764706vw;
	}
	.fv .btn a::after {
		height: 4.7058823529vw;
	}
	.inner_fv {
		width: 83.2352941176vw;
	}
	.fv_txt {
		width: calc(621 / 1360 * 100vw);
		margin: 0 auto calc(16 / 1360 * 100vw);
	}
	.fv_h1 {
		margin-bottom: calc(10 / 1360 * 100vw);
	}
	.fv_price {
		width: 52.6470588235vw;
		margin: calc(10 / 1360 * 100vw) auto 0;
	}
	/*========== Solution ==========*/
	.solution {
		background: linear-gradient(to bottom, #fff 0px, #fff min(8.8235294118vw, 120px), #CFE6FF min(8.8235294118vw, 120px));
	}
	.solution::before {
		border-width: 8.8235294118vw 19.1176470588vw 0px 0px;
		top: min(8.8235294118vw, 120px);
	}
	.solution::after {
		border-width: 0px 0px 8.8235294118vw 19.1176470588vw;
	}
	.solution .inner_section {
		width: min(96.4705882353vw, 1312px);
		position: relative;
		z-index: 1;
	}
	.solution .inner_section::before {
		width: min(20.5882352941vw, 280px);
		height: min(11.7647058824vw, 160px);
		top: min(3.5294117647vw, 48px);
		left: 0;
	}
	.solution .inner_section::after {
		width: min(9.4117647059vw, 128px);
		height: min(10vw, 136px);
		bottom: max(-5.8823529412vw, -80px);
		right: 0;
	}
	.ttl_en {
		width: min(11.7647058824vw, 160px);
		margin: 0 auto min(2.3529411765vw, 32px);
	}
	.ttl_h2 {
		font-size: min(2.9411764706vw, 40px);
		margin-bottom: min(1.7647058824vw, 24px);
	}
	.lead_text {
		font-size: min(1.4705882353vw, 20px);
		margin-bottom: min(3.5294117647vw, 48px);
		text-align: center;
	}
	.solution .lead_text {
		margin-bottom: min(5.8823529412vw, 80px);
	}
	.wrap_solution_contents {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
		gap: min(4.1176470588vw, 56px) min(2.9411764706vw, 40px);
		width: min(85.2941176471vw, 1160px);
		margin: 0 auto;
	}
	.solution_contents {
		width: min(26.4705882353vw, 360px);
		height: min(18.6029411765vw, 253px);
		padding-top: min(3.5294117647vw, 48px);
		margin-bottom: 0;
	}
	.solution_contents::before {
		width: min(4.7058823529vw, 64px);
		height: min(4.7058823529vw, 64px);
	}
	.ttl_h3_solution {
		font-size: min(1.7647058824vw, 24px);
		margin-bottom: min(1.1764705882vw, 16px);
	}
	.solution_txt {
		width: min(22.9411764706vw, 312px);
	}
	/*========== Features ==========*/
	.features_contents {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
		padding: min(2.9411764706vw, 40px) min(7.3529411765vw, 100px) min(2.9411764706vw, 40px) min(14.7058823529vw, 200px);
		margin-bottom: min(2.9411764706vw, 40px);
	}
	.features_contents::before {
		border-width: min(5.8823529412vw, 80px) min(17.6470588235vw, 240px) 0px 0px;
	}
	.features_contents::after {
		border-width: 0px 0px min(5.8823529412vw, 80px) min(17.6470588235vw, 240px);
	}
	.features_contents:nth-child(even) {
		-webkit-box-orient: horizontal;
		-webkit-box-direction: reverse;
		-ms-flex-direction: row-reverse;
		flex-direction: row-reverse;
		padding: min(2.9411764706vw, 40px) min(14.7058823529vw, 200px) min(2.9411764706vw, 40px) min(7.3529411765vw, 100px);
	}
	.features_contents:nth-child(even)::before {
		border-width: 0 min(17.6470588235vw, 240px) min(5.8823529412vw, 80px) 0px;
	}
	.features_contents:nth-child(even)::after {
		border-width: min(5.8823529412vw, 80px) 0 0px min(17.6470588235vw, 240px);
	}
	.features_contents:nth-child(even) .features_point {
		left: auto;
		right: min(2.9411764706vw, 40px);
	}
	.features_point {
		width: min(7.0588235294vw, 96px);
		position: absolute;
		top: 0;
		left: min(2.9411764706vw, 40px);
	}
	.img_point {
		width: min(26.4705882353vw, 360px);
		margin: 0;
	}
	.wrap_features_txt {
		width: min(33.8235294118vw, 460px);
		margin: 0;
	}
	.ttl_h3_features {
		font-size: min(2.3529411765vw, 32px);
		margin-bottom: min(1.7647058824vw, 24px);
	}
	/*========== CTA ==========*/
	.cta {
		padding: min(5.5147058824vw, 75px) 0 min(5.8823529412vw, 80px);
		background-image: url(../images/cta_bg_img_pc.jpg);
	}
	.ttl_cta {
		width: min(55.8823529412vw, 760px);
	}
	.cta_txt {
		margin: min(0.8823529412vw, 12px) 0 min(2.9411764706vw, 40px);
		font-size: min(1.7647058824vw, 24px);
		letter-spacing: 0.05em;
	}
	.wrap_cta_btn {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		justify-content: center;
		width: min(55.8823529412vw, 760px);
	}
	.wrap_cta_btn .btn {
		margin-bottom: 0;
	}
	.btn2 {
		width: min(26.4705882353vw, 360px);
		margin: 0;
	}
	.btn2 a {
		height: min(5.8823529412vw, 80px);
		font-size: min(1.7647058824vw, 24px);
		border-radius: min(2.9411764706vw, 40px);
	}
	.btn2 a::before {
		width: min(4.7058823529vw, 64px);
		height: min(4.7058823529vw, 64px);
		margin-right: min(2.9411764706vw, 40px);
	}
	.btn2 a::after {
		height: min(4.7058823529vw, 64px);
	}
	.btn2.btn_tel a {
		pointer-events: none;
	}
	.btn2.btn_tel a span {
		font-family: "Anton";
		font-weight: 400;
		font-size: min(2.3529411765vw, 32px);
		letter-spacing: 0.05em;
	}
	/*========== Service ==========*/
	.service {
		background: linear-gradient(to bottom, #fff 0, #fff min(8.8235294118vw, 120px), #D9F4E8 min(8.8235294118vw, 120px), #CFE6FF 100%);
	}
	.service::before, .service::after {
		top: min(8.8235294118vw, 120px);
	}
	.service::before {
		border-width: min(17.6470588235vw, 240px) min(17.6470588235vw, 240px) 0px 0px;
	}
	.service::after {
		border-width: 0px min(17.6470588235vw, 240px) min(17.6470588235vw, 240px) 0px;
	}
	.service_contents {
		padding: min(2.9411764706vw, 40px) min(7.3529411765vw, 100px) min(2.9411764706vw, 40px) 0;
		margin-bottom: min(4.7058823529vw, 64px);
	}
	.service_contents::before {
		border-width: 0 min(11.7647058824vw, 160px) min(7.6470588235vw, 104px) 0px;
	}
	.service_contents::after {
		border-width: min(17.5vw, 238px) 0 0px min(26.4705882353vw, 360px);
	}
	.wrap_service_txt {
		width: min(48.5294117647vw, 660px);
		margin-left: auto;
	}
	.wrap_service_txt::after {
		width: min(26.4705882353vw, 360px);
		height: min(19.2647058824vw, 262px);
		margin-top: 0;
		position: absolute;
		bottom: 0;
		left: 0;
	}
	.ttl_h3_service {
		width: 100%;
		font-size: min(2.3529411765vw, 32px);
		padding-bottom: min(1.1764705882vw, 16px);
		margin: 0 auto min(1.1764705882vw, 16px);
	}
	.wrap_service_txt p {
		width: 100%;
		margin: 0;
	}
	/*========== Flow ==========*/
	.flow::before {
		border-width: min(17.6470588235vw, 240px) 100vw 0px 0px;
	}
	.flow::after {
		border-width: 0px 0px min(17.6470588235vw, 240px) 100vw;
	}
	.wrap_flow_contents::after {
		width: min(1.1764705882vw, 16px);
	}
	.flow_contents {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
		height: min(13.75vw, 187px);
		background-image: url(../images/flow_bg_contents_pc.png);
		padding: 0 min(7.3529411765vw, 100px);
		margin-bottom: min(2.9411764706vw, 40px);
	}
	.flow_contents:last-child {
		margin-bottom: 0;
	}
	.flow_step {
		width: min(19.1176470588vw, 260px);
		font-size: min(2.9411764706vw, 40px);
		margin-bottom: 0;
	}
	.flow_step::before {
		width: min(5.8823529412vw, 80px);
		height: min(5.8823529412vw, 80px);
		margin-right: min(1.7647058824vw, 24px);
	}
	.wrap_flow_txt {
		width: min(48.5294117647vw, 660px);
	}
	.ttl_h3_flow {
		font-size: min(2.3529411765vw, 32px);
		margin-bottom: min(0.5882352941vw, 8px);
	}
	.wrap_flow_txt p span {
		font-size: min(1.1764705882vw, 16px);
	}
	/*========== FAQ ==========*/
	.faq .inner_section {
		width: min(70.5882352941vw, 960px);
	}
	.dl_faq dt, .dl_faq dd {
		font-size: min(1.3235294118vw, 18px);
	}
	.dl_faq dt {
		font-size: min(1.4705882353vw, 20px);
		padding: min(0.7352941176vw, 10px) min(2.9411764706vw, 40px) min(0.5882352941vw, 8px);
	}
	.dl_faq dt::before {
		border-width: min(1.1764705882vw, 16px) 0px min(1.1764705882vw, 16px) min(1.1764705882vw, 16px);
	}
	.dl_faq dd {
		padding: min(1.6176470588vw, 22px) min(2.9411764706vw, 40px) min(1.4705882353vw, 20px);
		margin-bottom: min(1.7647058824vw, 24px);
	}
	.dl_faq dd::before {
		border-width: min(1.1764705882vw, 16px) min(1.1764705882vw, 16px) min(1.1764705882vw, 16px) 0px;
	}
	.dl_faq .faq_icon {
		font-size: min(2.9411764706vw, 40px);
		margin-right: min(2.9411764706vw, 40px);
	}
	/*========== Contact ==========*/
	.contact::before {
		border-width: min(14.7058823529vw, 200px) 100vw 0px 0px;
	}
	.contact .inner_section {
		width: min(70.5882352941vw, 960px);
	}
	.contact .lead_text {
		width: auto;
		margin: 0 auto min(4.7058823529vw, 64px);
	}
	/* 電話でのお問い合わせ */
	.wrap_contact_tel {
		width: min(70.5882352941vw, 960px);
		padding: min(2.9411764706vw, 40px) 0;
	}
	.wrap_contact_tel .btn {
		margin: 0 auto;
	}
	.ttl_h3_contact {
		font-size: min(2.3529411765vw, 32px);
		margin-bottom: min(1.7647058824vw, 24px);
	}
	.accept_time {
		margin-top: min(1.1764705882vw, 16px);
	}
	/* フォームでのお問い合わせ */
	.wrap_contact_form {
		margin-top: min(4.7058823529vw, 64px);
	}
	.contact_form {
		padding: min(5.8823529412vw, 80px) 0;
	}
	.contact_form::before {
		border-width: min(5.8823529412vw, 80px) min(8.8235294118vw, 120px) 0px 0px;
	}
	.contact_form::after {
		border-width: 0px 0px min(5.8823529412vw, 80px) min(8.8235294118vw, 120px);
	}
	.dl_contact {
		width: min(56.0294117647vw, 762px);
	}
	.dl_contact dt {
		margin-bottom: min(1.1764705882vw, 16px);
	}
	.dl_contact dd {
		margin-bottom: min(1.7647058824vw, 24px);
	}
	.dl_contact .required {
		width: min(2.9411764706vw, 40px);
		height: min(1.9117647059vw, 26px);
		font-size: min(1.0294117647vw, 14px);
		margin-right: min(1.1764705882vw, 16px);
	}
	input[type=text],
	input[type=tel],
	input[type=email],
	textarea {
		border-radius: min(0.3676470588vw, 5px);
		padding: min(0.8823529412vw, 11.5px) min(0.5882352941vw, 8px);
	}
	::-webkit-input-placeholder {
		font-size: min(1.3235294118vw, 18px);
	}
	::-moz-placeholder {
		font-size: min(1.3235294118vw, 18px);
	}
	:-ms-input-placeholder {
		font-size: min(1.3235294118vw, 18px);
	}
	::-ms-input-placeholder {
		font-size: min(1.3235294118vw, 18px);
	}
	::placeholder {
		font-size: min(1.3235294118vw, 18px);
	}
	/* チェックボックス */
	.dd_checkbox {
		padding: 0 0 0 min(2.5735294118vw, 35px);
	}
	.dd_checkbox input + span::before {
		left: 0;
		width: min(1.7647058824vw, 24px);
		height: min(1.7647058824vw, 24px);
	}
	.dd_checkbox input + span::after {
		width: min(1.1029411765vw, 15px);
		height: min(1.5441176471vw, 21px);
		left: min(0.3676470588vw, 5px);
	}
	/* チェックボックスが複数の場合 */
	.dd_checkbox.dd_checkbox2 {
		padding: 0;
	}
	.dd_checkbox.dd_checkbox2 .wpcf7-form-control {
		gap: min(1.1764705882vw, 16px) min(2.9411764706vw, 40px);
	}
	.dd_checkbox2 .wpcf7-list-item {
		padding-left: min(2.5735294118vw, 35px);
	}
	/* プライバシーポリシー */
	.wrap_privacy_policy {
		height: min(15.4411764706vw, 210px);
		padding: min(1.1764705882vw, 16px);
		margin-bottom: min(1.1764705882vw, 16px);
		font-size: min(1.1764705882vw, 16px);
		border-radius: min(0.2205882353vw, 3px);
	}
	.ttl_policy {
		font-size: min(1.3235294118vw, 18px);
		margin-bottom: min(1.1764705882vw, 16px);
		text-align: center;
	}
	.dl_policy {
		margin-top: min(1.1764705882vw, 16px);
	}
	.dl_policy dt {
		margin-bottom: min(0.5882352941vw, 8px);
	}
	.dl_policy dd {
		margin-bottom: min(1.7647058824vw, 24px);
	}
	/* 送信ボタン */
	.wrap_btn_submit {
		width: min(41.1764705882vw, 560px);
		margin: min(3.5294117647vw, 48px) auto 0;
	}
	.wrap_btn_submit::before {
		width: min(1.1764705882vw, 16px);
		height: min(1.1764705882vw, 16px);
		right: min(15.9558823529vw, 217px);
	}
	.wrap_btn_submit::after {
		width: calc(100% - min(1.1764705882vw, 16px));
		height: min(3.5294117647vw, 48px);
		border-radius: min(2.9411764706vw, 40px);
	}
	.wrap_btn_submit input {
		font-size: min(1.3235294118vw, 18px);
		height: min(4.7058823529vw, 64px);
		padding: min(0.5882352941vw, 8px);
		border-radius: min(2.9411764706vw, 40px);
		cursor: pointer;
	}
	.btn_submit {
		border-radius: min(2.9411764706vw, 40px);
	}
	/*========== Company ==========*/
	.company::before {
		border-width: 0px 100vw min(14.7058823529vw, 200px) 0px;
	}
	.company::after {
		border-width: min(4.7058823529vw, 64px) 0px 0px 100vw;
	}
	.company .inner_section {
		width: min(85.2941176471vw, 1160px);
	}
	.dl_company {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
		gap: 0 min(2.9411764706vw, 40px);
		margin-top: min(3.5294117647vw, 48px);
	}
	.dl_company div {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		width: min(41.1764705882vw, 560px);
		padding: min(1.7647058824vw, 24px) 0 min(1.7647058824vw, 24px) min(2.9411764706vw, 40px);
	}
	.dl_company div:nth-child(1) {
		-webkit-box-ordinal-group: 2;
		-ms-flex-order: 1;
		order: 1;
	}
	.dl_company div:nth-child(2) {
		-webkit-box-ordinal-group: 4;
		-ms-flex-order: 3;
		order: 3;
	}
	.dl_company div:nth-child(3) {
		-webkit-box-ordinal-group: 3;
		-ms-flex-order: 2;
		order: 2;
		padding-top: 0;
	}
	.dl_company div:nth-child(4) {
		-webkit-box-ordinal-group: 5;
		-ms-flex-order: 4;
		order: 4;
	}
	.dl_company div:nth-child(5) {
		-webkit-box-ordinal-group: 6;
		-ms-flex-order: 5;
		order: 5;
	}
	.dl_company div:last-child {
		width: 100%;
	}
	.dl_company dt {
		margin: 0 min(7.7941176471vw, 106px) 0 0;
	}
	.wrap_access {
		width: min(70.5882352941vw, 960px);
		margin: 0 auto;
	}
	.google_map {
		margin-top: min(2.9411764706vw, 40px);
	}
	.google_map::before {
		content: none;
	}
	.google_map iframe {
		height: min(24.1176470588vw, 328px);
		position: static;
	}
	.address {
		margin: 0;
	}
	.address .ttl_address {
		display: inline-block;
		margin-right: min(0.8823529412vw, 12px);
	}
	.address .post_code {
		margin-right: 1em;
	}
	/*========== フローティング ==========*/
	.wrap_floating_btn {
		padding: min(0.5882352941vw, 8px) 0;
		-webkit-box-pack: center;
		-ms-flex-pack: center;
		justify-content: center;
		gap: min(2.9411764706vw, 40px);
	}
	.btn_floating {
		width: min(26.4705882353vw, 360px);
	}
	.btn_floating::before {
		border-radius: min(2.9411764706vw, 40px);
	}
	.btn_floating::after {
		content: none;
	}
	.btn_floating a {
		-webkit-box-pack: start;
		-ms-flex-pack: start;
		justify-content: flex-start;
		height: min(5.8823529412vw, 80px);
		padding: 0 min(0.2941176471vw, 4px);
		font-size: min(1.7647058824vw, 24px);
		border-radius: min(2.9411764706vw, 40px);
		border: 4px solid #fff;
	}
	.btn_floating a::before {
		width: min(4.7058823529vw, 64px);
		height: min(4.7058823529vw, 64px);
		margin-right: min(2.9411764706vw, 40px);
	}
	.btn_floating a::after {
		width: min(25.2941176471vw, 344px);
		height: min(4.7058823529vw, 64px);
		border-radius: min(2.9411764706vw, 40px);
	}
	.btn_floating.btn_floating_tel a {
		font-size: min(2.3529411765vw, 32px);
		font-family: "Anton";
		pointer-events: none;
	}
	.btn_floating.btn_floating_tel a::before {
		background-image: url(../images/icon_tel_big.svg);
	}
	.btn_floating.btn_floating_tel a::after {
		background: #1571DA;
	}
	.btn_floating.btn_floating_mail a::before {
		background-image: url(../images/icon_mail_big.svg);
	}
	.btn_floating:hover::before {
		-webkit-animation: shine 0.7s;
		animation: shine 0.7s;
	}
	/* footer
	------------------------------------------------------------------------- */
	#footer {
		padding-bottom: min(calc(96 / 1360 * 100vw), 96px);
	}

	.copyright {
		height: min(2.9411764706vw, 40px);
		font-size: min(1.1764705882vw, 16px);
	}

	/* 送信完了
	------------------------------------------------------------------------- */
	.fv_thanks {
		height: min(calc(240 / 1360 * 100vw), 240px);
		margin-top: min(4.7058823529vw, 64px);
	}

	.ttl_h1_thanks {
		font-size: min(calc(48 / 1360 * 100vw), 48px);
	}

	.thanks {
		padding: min(calc(80 / 1360 * 100vw), 80px);
	}

	.thanks .inner_section  {
		width: min(calc(960 / 1360 * 100vw), 960px);
	}

	.wrap_thanks_text {
		margin-top: min(calc(64 / 1360 * 100vw), 64px);
	}

	.wrap_thanks_text p {
		margin-bottom: min(calc(48 / 1360 * 100vw), 48px);
	}

	.btn_top {
		width: min(calc(360 / 1360 * 100vw), 360px);
		margin: 0 auto;
	}

	.btn_top a {
		justify-content: center;
	}

	.btn_top a::before {
		content: none;
	}
}