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

CSS Name: style css
Author: [ bran-new-days.com ]
Description: 2023/11/9

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

/* /////////////////////////////////////////////////////////////////////////////

 全体 style

///////////////////////////////////////////////////////////////////////////// */

/* font-family: 'Questrial', sans-serif; */
@import url('https://fonts.googleapis.com/css2?family=Questrial&display=swap');

main, article, aside, header, canvas, details, figcaption, figure, footer, nav, section, summary {
	display: block;
}

html {
	font-size: 16px;
}

body {
	position: relative;
	left: 0;
	overflow: hidden;
	word-wrap: break-word;
	color: #333;
	font-size: 1rem;
	font-family: 'Hiragino Kaku Gothic Pro','ヒラギノ角ゴ Pro W3','メイリオ',Meiryo,'ＭＳ Ｐゴシック','MS PGothic',sans-serif;
	line-height: 1.6;
	background: #f1ece2;
	background-attachment: fixed;
}

a {
	color: #3d217f;
	color: #309cc5;
	text-decoration: underline;
}

a:hover {
	color: #5c429b;
	color: rgb(87, 126, 176);
	text-decoration: none;
}

a:hover img {
	opacity: 0.7;
	filter: alpha(opacity=70);
}

.font_gothic {
	font-family: 'Hiragino Kaku Gothic Pro','ヒラギノ角ゴ Pro W3','メイリオ',Meiryo,'ＭＳ Ｐゴシック','MS PGothic',sans-serif;
}
.font_mincho {
	font-family: '游明朝', YuMincho, 'Hiragino Mincho ProN W3', 'ヒラギノ明朝 ProN W3', 'Hiragino Mincho ProN', 'HG明朝E', 'ＭＳ Ｐ明朝', 'ＭＳ 明朝', serif;
}

video, object {
	display: block;
	max-width: 100%;
	height: auto;
	border: none;
	vertical-align: bottom;
}

img {
	max-width: 100%;
	height: auto;
	border: none;
	vertical-align: bottom;
}

.vibtn {
	position: absolute;
	visibility: hidden;
}


/* /////////////////////////////////////////////////////////////////////////////

 layout

///////////////////////////////////////////////////////////////////////////// */

.contents_wrapper {
	position: relative;
	margin: 0 auto;
}

.main_contents {
	margin: 0 auto;
}


/* 背景横突き抜け：ブロック
------------------------------------------------------------- */

.contents {
	position: relative;
	clear: both;
	zoom: 100%;
}
.contents.wh {
	background: #FFF;
}
.contents.pk {
	background: rgb(219,138,154);
	background: linear-gradient(135deg, rgba(219,138,154,1) 0%, rgba(215,169,188,1) 100%);
	color: #FFF;
}
.contents.pk::before {
	position: absolute;
	display: block;
	content: '';
	width: 100%;
	height: 100%;
	background-image: radial-gradient(rgba(0,0,0,.15) 30%, transparent 30%);
	background-size: 6px 6px;
}
.contents.arrow::after {
	position: absolute;
	display: block;
	content: '';
	left: 50%;
	bottom: -24px;
	margin-left: -20px;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 25px 20px 0 20px;
	border-color: #f1ece2 transparent transparent transparent;
	z-index: 1;
}

.contents_inner {
	position: relative;
	max-width: 1000px;
	margin: 0 auto;
	padding: 60px 15px;
	z-index: 1;
}


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

 header

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

.header_wrapper {
	height: 94px;
}

.header {
	position: fixed;
	z-index: 999999;
	top: 0;
	left: 0;
	width: 100%;
	background: #FFF;
	transition:all 300ms 0ms ease;
}

.header_inner {
	max-width: 1200px;
	margin: 0 auto;
	padding: 10px 10px;
	transition:all 300ms 0ms ease;
}
.header_main {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

/* logo */
.header_inner .logo {
	width: 45%;
	margin-top: 6px;
	line-height: 1.6;
	transition:all 300ms 0ms ease;
}
.header_inner .logo a {
	display: block;
	text-decoration: none;
}
.header_inner .logo img {
	width: 100%;
}

/* tel */
.header_inner .tel_block {
	width: 50%;
	margin-left: 5%;
	margin-bottom: 6px;
}
.header_inner .tel_block .tel_box .time {
	font-size: .75rem;
}
.header_inner .tel_block .tel_box .number {
	padding-left: .1em;
	font-size: min(6vw , 1.5rem);
}



/* gnavi
------------------------------------------------------------- */

.gnavi_block {
	width: 100%;
}
.gnavi {
	display: -webkit-flex;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	transition:all 300ms 0ms ease;
}
.gnavi li {
	margin-left: 4px;
}
.gnavi a {
	transition:all 300ms 0ms ease;
}

.gnavi .tel_box {
	margin-bottom: -2px;
}

/* header/footer 共通 */
.tel_box {
	text-align: center;
	line-height: 1;
}
.tel_box .time {
	display: block;
	margin-bottom: 4px;
	font-size: 1.125rem;
}
.tel_box .number {
	display: block;
	padding-left: .1em;
	color: #3d217f;
	font-size: 1.875rem;
	font-family: 'Questrial', sans-serif;
	font-weight: normal;
	letter-spacing: .1em;
}


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

 .footer

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

.footer {
	background: #FFF;
}

.footer_inner {
	max-width: 1100px;
	margin: 0 auto;
	padding: 40px 15px;
}


/* fnavi
------------------------------------------------------------- */

.fnavi {
	margin-bottom: 20px;
	text-align: center;
}
.fnavi li {
	display: inline-block;
	margin-bottom: 15px;
	vertical-align: middle;
}

.fnavi .tel_box {
	margin-bottom: -2px;
}
.fnavi .tel_box .time {
	display: inline-block;
	margin-left: 1em;
}
.fnavi .tel_box .number {
	display: inline-block;
	margin-left: 1em;
}

/* copy
-----------------------------------------------------------*/

.copy_area {
	font-size: .8125rem;
}
.copy_area .copy {
	text-align: center;
}


/* page top
-----------------------------------------------------------*/

.page_top_fx {
	position: fixed;
	overflow: hidden;
	bottom: 10px;
	right: 10px;
	z-index: 99999;
}

.page_top_fx a {
	position: relative;
	display: block;
	cursor: pointer;
	width: 60px;
	height: 60px;
	border-radius: 50vw;
	background: rgba(89, 64, 147, .5);
	background-size: 40% auto;
	text-indent: 100%;
	white-space: nowrap;
}
.page_top_fx a::before {
	position: absolute;
	display: block;
	content: '';
	top: 24px;
	left: 19px;
	width: 20px;
	height: 20px;
	border-top: 2px solid #FFF;
	border-left: 2px solid #FFF;
	transform: rotate(45deg);
}


/* /////////////////////////////////////////////////////////////////////////////

 メインコンテンツ

///////////////////////////////////////////////////////////////////////////// */

/* パンくず
-----------------------------------------------------------*/

.breadcrumb {
	clear: both;
	max-width: 1040px;
	margin: 20px auto 20px;
	padding: 0 20px;
	color: #666;
	font-size: .875rem;
}

.breadcrumb li {
	display: inline-block;
	padding: 0 8px 0 0;
}

/* ボタンボックス
-----------------------------------------------------------*/

.btn_box {
	margin: 0;
	text-align: center;
}
.btn_box a ,
.btn_box input[type="submit"] ,
.btn_box button {
	cursor: pointer;
	display: inline-block;
	width: 360px;
	max-width: 100%;
	padding: 2px 10px;
	border-radius: 50vh;
	border: none;
	background: #8597ce;
	color: #FFF;
	text-decoration: none;
	letter-spacing: .2em;
}
.btn_box a:hover ,
.btn_box input:hover ,
.btn_box button:hover {
	opacity: .65;
}
.btn_box a span {
	display: inline-block;
	padding-left: .2em;
}

/* p */
p.btn_box {
	padding: 20px 0 30px;
}
p.btn_box + p.btn_box {
	padding-top: 0;
}

.btn_box.btn_textL a {
	width: 520px;
	max-width: 100%;
	padding: 12px 10px;
	font-size: 1.125rem;
	font-weight: bold;
	letter-spacing: 0;
}

/* btn header/footer */
.gnavi .btn_box a {
	width: 11em;
	max-width: 100%;
}
.fnavi .btn_box {
	margin-bottom: 0
}
.fnavi .btn_box a {
	width: 16em;
	max-width: 100%;
}

/* contact */
.btn_box.btn_contact a ,
.btn_box.btn_contact input[type="submit"] ,
.btn_box.btn_contact button {
	background: rgb(47,179,131);
	background: linear-gradient(135deg, rgba(47, 179, 131, 1) 15%, rgba(48, 156, 197, 1) 85%);
}

/* request */
.btn_box.btn_request a ,
.btn_box.btn_request input[type="submit"] ,
.btn_box.btn_request button {
	background: rgb(203,86,145);
	background: linear-gradient(135deg, rgba(47,179,131,1) 15%, rgba(48,156,197,1) 85%);
}

/* disabled */
.btn_box.btn_contact button:disabled ,
.btn_box.btn_contact input:disabled ,
.btn_box.btn_request button:disabled ,
.btn_box.btn_request input:disabled {
	opacity: .5;
}

/* text link */
.link_box a {
	display: inline-block;
}


/* animation parts
------------------------------------------------------------- */

/* fadein */
.fadein {
	opacity : 0;
	transform : translate(0, 50px);
	transition : all 800ms;
}
.fadein.scrollin {
	opacity : 1;
	transform : translate(0, 0);
}

.fadein.fast {
	opacity : 0;
	transform : translate(0, 50px);
	transition : all 250ms;
}
.fadein.fast.scrollin {
	opacity : 1;
	transform : translate(0, 0);
}

.fadein.left {
	opacity : 0;
	transform : translate(-100px, 0);
	transition : all 250ms;
}
.fadein.left.scrollin {
	opacity : 1;
	transform : translate(0, 0);
}


/* ページタイトル
-----------------------------------------------------------*/

/* title */
.title_block {
	margin-bottom: 20px;
	text-align: center;
}
.title_block.single {
	margin-bottom: 0px !important;
}
.title_block h1 {
	font-size: 1.25rem;
}
.title_block h1 b ,
.title_block h1 span {
	display: inline-block;
	vertical-align: middle;
}
.title_block h1 .medium {
	margin-top: -10px;
	font-size: 1.5rem;
}
.title_block h1 .large {
	font-size: 1.75rem;
}
.title_block .dpk {
	color: #ab4e7d;
}
.title_block .pk {
	color: #c93d84;
}
.title_block .yw {
	color: #fff8a5;
}
.title_block .bk {
	color: #333333;
}
.title_block .pp {
	color: #482b7c;
}

.title_block .lsp2 {
	padding-right: .1em;
	letter-spacing: .1em;
}
.title_block h1 + p, .title_block h2 + p, .title_block h3 + p, .title_block p + p {
	margin-top: 20px;
}
.title_block p.catch {
	font-size: 1.125rem;
	font-weight: bold;
}

.title_min {
	font-size: 2.25rem;
}


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

 lp

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

.cover {
	position: relative;
	padding: 5% 15px 0;
	background: linear-gradient(135deg, rgba(255,252,246,1) 0%, rgba(245,245,245,1) 100%);
}
.cover_area ,
.request_area {
	position: relative;
	max-width: 1200px;
	margin: 0 auto;
	z-index: 1;
}
.cover_catch {
	padding-bottom: 20px;
}

/* cover_catch */
.cover_catch .catchs {
	color: #333333;
	line-height: 1.4;
}
.cover_catch .catchs img {
	display: block;
	width: 100%;
}
.cover_catch .catch02 {
	display: block;
	width: 100%;
	margin-bottom: 20px;
	padding: 8px .5em;
	color: #ffffff;
	background: #333333;
	font-size: 4.6vw;
	font-weight: bold;
	text-align: center;
}
.cover_catch .catch03 {
	margin-bottom: 15px;
	padding: 0 max(0.475em, 10px) 0.5em 10px;
	font-size: 1.25rem;
	border-bottom: 2px dashed;
}
.cover_catch .catch01 {
	font-size: 10.4vw;
	letter-spacing: -.025em;
	white-space: nowrap;
	margin-bottom: 15px;
}
.cover_catch .catch01 span {
	padding: 0 10px;
	margin: 0 -10px;
	background: linear-gradient(transparent 50%, #fff8a5 50%, #fff8a5 90%, transparent 90%);
}
.cover_linkbox {
	overflow: hidden;
	background: #fff;
}
.anim-box.poyopoyo {
	animation: poyopoyo 2s ease-out infinite;
	opacity: 1;
}
@keyframes poyopoyo {
	0%, 40%, 60%, 80% {
   		transform: scale(1.0);
	}
	50%, 70% {
		transform: scale(0.95);
	}
}
.cover_btn {
	font-weight: 900;
	font-size: 1.125rem;
}
.cover_btn > a {
	display: block;
	color: #fff;
	text-align: center;
	text-decoration: none;
	line-height: 2.5;
	border: 1px solid #fff;
	background: linear-gradient(135deg, rgba(47,179,131,1) 15%, rgba(48,156,197,1) 85%);
}
.cover_btn > a:hover {
	opacity: .65;
}
.cover_image {
	display: flex;
}


/* request
------------------------------------------------------------- */

.request_area .title_block h1 {
	font-size: 4.75vw;
	text-align: center;
}
.request_text {
	text-align: left;
}
.request_text .title_block {
	text-align: left;
}

.for_area {
	margin-bottom: 20px;
	padding: 15px 20px 10px;
	background: #f6f3ec;
	color: #333;
}
.for_area h2 {
	color: #e97228;
	font-size: min(5vw , 1.75rem);
	text-align: center;
}

/* check_list */
.check_list {
	font-size: 1.125rem;
	font-weight: bold;
	line-height: 1.5;
	letter-spacing: .125em;
}
.check_list li {
	position: relative;
	padding-top: .5em;
	padding-bottom: .5em;
	padding-left: 1.75em;
	background: url(../image/line_dash01.svg) repeat-x 0% 100%;
	background-size: auto 2px;
}
.check_list li:last-child {
	background: none;
}
.check_list > li::before {
	position: absolute;
	display: block;
	content: '';
	top: .7em;
	left: .25em;
	height: 1.125rem;
	width: auto;
	aspect-ratio: 5 / 4;
	background: url(../image/icon_check04.svg) no-repeat;
}
.check_list > li > span.pk {
	color: #c93d84;
}


/* request_form
------------------------------------------------------------- */

.cover_area .request_form ,
.request_area .request_form {
	margin-left: -15px;
	margin-right: -15px;
	padding: 20px 10px;
	background: #f1ece2;
	box-shadow: 0 0 35px rgba(10,4,7,.15);
	color: #333;
}

.request_form h2 {
	margin-bottom: 20px;
	text-align: center;
	line-height: 1;
}
.request_form h2 b {
	display: inline-block;
	width: 8em;
	color: #c93d84;
	font-size: 1.75rem;
	vertical-align: middle;
}
.request_form h2 span {
	display: inline-block;
	margin-left: 1em;
	padding: 6px 8px;
	background: #c93d84;
	color: #FFF;
	font-weight: normal;
	vertical-align: middle;
}
.request_form .text {
	margin-bottom: 30px;
	font-size: .75rem;
	text-align: center;
}
.cover_area .form_box ,
.request_form .form_box {
	max-width: 520px;
	margin: 0 auto;
}
.request_form .form_box {
	margin-bottom: 10px;
	font-size: .875rem;
}
.request_form .privacy_check {
	font-size: .75rem;
}
.request_form .btn_box.btn_request button {
	letter-spacing: 0;
}


/* slide layout
------------------------------------------------------------- */

/* 上部 */

.cover_slide {
	margin-top: -90px;
}

/* 下部 */

.bottom_slide {
	position: relative;
	z-index: 1;
}
.bottom_slide.pc_hide {
	margin-bottom: -80px;
}
.bottom_slide.sp_hide {
	margin-top: 80px;
	margin-bottom: -200px;
}


/* infinite slide
------------------------------------------------------------- */

.infinite_slide {
	position: relative;
}
.infinite_slide_inner {
	display: flex;
}
.infinite_slide_list {
	display: flex;
	align-items: center;
}
.infinite_slide_list.left {
	animation :infinity-scroll-left 30s infinite linear .4s both;
}
.infinite_slide_list.right {
	animation :infinity-scroll-right 30s infinite linear .4s both;
}
.infinite_slide_list li {
	flex: 0;
	margin: 0 10px;
}
.infinite_slide_list img {
	max-width: 180px;
	max-height: 180px;
	box-shadow: 0 0 10px rgba(0,0,0,.2);
}
@media only screen and (min-width: 769px) {
	.infinite_slide_list img {
		max-width: 300px;
		max-height: 300px;
	}
}
@keyframes infinity-scroll-left {
	from { transform: translateX(0); }
	to { transform: translateX(-100%); }
}
@keyframes infinity-scroll-right {
	from { transform: translateX(-100%); }
	to { transform: translateX(0%); }
}


/* kadai
------------------------------------------------------------- */

.kadai_list {
	padding: 5px 10px;
	background: #ffffff;
	font-size: 1.125rem;
	font-weight: bold;
	line-height: 1.5;
	letter-spacing: .125em;
}
.kadai_list li {
	position: relative;
	padding-top: .5em;
	padding-bottom: .5em;
	padding-left: 1.75em;
	background: url(../image/line_dash01.svg) repeat-x 0% 100%;
	background-size: auto 2px;
}
.kadai_list > li::before {
	position: absolute;
	display: block;
	content: '';
	top: .7em;
	left: .25em;
	height: 1.125rem;
	width: auto;
	aspect-ratio: 5 / 4;
	background: url(../image/icon_check04.svg) no-repeat;
}
.kadai_list li:last-child {
	background: none;
}
.kadai_list > li > span.pk {
	color: #e97228;
}
.kadai_area .fig {
	width: 50%;
	margin: 20px auto;
}


/* message
------------------------------------------------------------- */

.message_area {
	font-size: .9375rem;
}


/* service
------------------------------------------------------------- */

.contents_service .fadein + .fadein {
	margin-top: 60px;
}
.service_list {
	max-width: 840px;
	margin: 0 auto;
}
.service_list h2 {
	margin-bottom: 10px;
	text-align: center;
}
.service_list h2 em {
	display: block;
	width: 75%;
	margin: 0 auto 10px;
	padding: 4px;
	border-radius: 50vh;
	background: #c93d84;
	color: #FFF;
}
.service_list h2 span {
	display: inline-block;
	color: #c93d84;
	font-size: 1.25rem;
}

.service_list .inner .fig {
	width: auto;
	max-width: 65%;
	height: 185px;
	aspect-ratio: 250 / 235;
	margin: 0 auto;
}
.service_list .inner .fig > img {
	object-fit: contain;
	object-position: 50% 50%;
	width: 100%;
	height: 100%;
}
.service_list .inner .text {
	font-weight: bold;
}
.service_list .inner .text > p + p {
	margin-top: 1em;
}


/* tokucho
------------------------------------------------------------- */
.contents_tokucho .contents_inner .title_block .fig {
	margin: 0 auto 10px;
	width: 6em;
	font-size: 1.75rem;
}
.tokucho_list {
	margin: 0 auto;
}
.tokucho_list li + li {
	margin-top: 20px;
}
.tokucho_list .fig {
	padding: 20px 40px;
	text-align: center;
}
.tokucho_list .fig img {
	width: 75%;
}
.tokucho_list .text {
	padding: 12px 12px 10px;
	border-radius: 5px 5px 0 0;
	background: #c93d84;
	color: #FFF;
}
.tokucho_list .text h2 {
	font-size: 1.125rem;
	line-height: 1.6;
}
.count-number_white-box {
	margin-right: 0.25em;
	font-style: italic;
	font-size: 1.125em;
}
.tokucho_list .subtext {
	margin-top: 1px;
	padding: 10px;
	border-radius: 0 0 5px 5px;
	border: 1px solid #c93d84;
}


/* download
------------------------------------------------------------- */

.download_area {
	padding: 40px 20px;
	border-radius: 20px;
	background: #FFF;
	box-shadow: 0 20px 35px rgba(0,0,0,.25);
}


/* cv
------------------------------------------------------------- */

.contents_cv {
	padding-bottom: 90px;
}
.contents_download + .contents_jirei > .contents_inner {
	padding-top: 10px;
}

.contents_jirei > .contents_inner .title_block:nth-child(n+2) {
	margin-top: 60px;
}
.cv_list {
	max-width: 960px;
	margin: 0 auto;
}
.cv_list li {
	margin-bottom: 20px;
	padding: 20px 20px;
	border-radius: 15px;
	background: #FFF;
	color: #333;
}
.cv_list li:last-child {
	margin-bottom: 0;
}
.cv_list .logo_block {
	width: 50%;
	margin: 0 auto 20px;
}
.cv_list .logo_block .logo {
	background: #f1ece2;
	border-radius: 50%;
}
.cv_list .text_block {
	font-size: 1rem;
}
.cv_list .text_block .name {
	display: block;
	text-align: center;
}
.cv_list .text_block .name span {
	display: inline-block;
	padding: 4px 1em;
	border-radius: 50vh;
	background: #c93d84;
	color: #FFF;
}
.cv_list .text_block h2 {
	margin-top: 10px;
	margin-bottom: 10px;
	font-size: 1.25rem;
}


/* jirei
------------------------------------------------------------- */

dl.jirei_list + dl.jirei_list {
	margin-top: 1.5em;
}
dl.jirei_list > dt {
	padding-left: 10px;
	font-size: 1.25rem;
	font-weight: bold;
	border-left: 5px solid;
	color: #c93d84;
}
dl.jirei_list > dd {
	padding: 0.3em 0 0 15px;
	font-size: 1.125rem;
}
.sup-message {
	display: block;
	width: 100%;
	padding-left: 1.125em;
	font-size: 0.8rem;
	font-weight: normal;
	position: relative;
}
.sup-message::before {
	display: inline-block;
	content: "※";
	position: absolute;
	left: 0;
}


/* qa
------------------------------------------------------------- */

.qa-1 {
	padding: 1em;
	border: 1px solid #d6dde3;
	border-radius: 5px;
}
.qa-1 + .qa-1 {
	margin-top: 0.5rem;
}
.qa-1 summary {
	display: flex;
	justify-content: space-between;
	align-items: center;
	position: relative;
	padding: 0 calc( 1.3em * 1.25 );
	font-weight: 600;
	cursor: pointer;
}
.qa-1 summary::before,.qa-1 p::before {
	position: absolute;
	left: 0;
	font-weight: 600;
	font-size: 1.3em;
	line-height: 0;
}
.qa-1 summary::before {
	color: #75bbff;
	content: "Q";
	top: 12.795px;
}
.qa-1 summary::after {
	transform: translateY(-25%) rotate(45deg);
	width: 7px;
	height: 7px;
	margin-left: 10px;
	border-bottom: 3px solid #333333b3;
	border-right: 3px solid #333333b3;
	content: '';
	transition: transform .5s;
	position: absolute;
	right: 0;
}
.qa-1[open] summary::after {
	transform: rotate(225deg);
}
.qa-1 p {
	position: relative;
	transform: translateY(-10px);
	opacity: 0;
	margin-top: 1em;
	padding: 1em 0 0 calc( 1.3em * 1.25 );
	border-top: 1px dashed #d6dde3;
	transition: transform .5s, opacity .5s;
}
.qa-1[open] p {
	transform: none;
	opacity: 1;
}
.qa-1 p::before {
	color: #ff8d8d;
	content: "A";
	top: 29.295px;
}

/* nissen
------------------------------------------------------------- */

.nissen_area .text_block {
	margin-bottom: 15px;
}


/* flow
------------------------------------------------------------- */

.contents_flow > .contents_inner > .title_block .highlight {
	padding-left: 0.4em;
}
.flow_leaveit {
	margin: 20px 0 0 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 10px;
}
.flow_leaveit > .fig {
	max-height: 165.5px;
	aspect-ratio: 1164 / 850;
}
.flow_area {
	margin-top: 40px;
}
.flow_list li {
	position: relative;
	margin-bottom: 40px;
	border-radius: 15px;
	background: #FFF;
	box-shadow: 0 0 25px rgba(0,0,0,.15);
}
.flow_list li:last-child {
	margin-bottom: 0;
}
.flow_list li::after {
	position: absolute;
	display: block;
	content: '';
	left: 50%;
	bottom: -30px;
	margin-left: -18px;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 30px 18px 0 18px;
	border-color: #FFF transparent transparent transparent;
	z-index: 1;
}
.flow_list li:last-child::after {
	content: none;
}
.flow_list li .caption {
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 10px 10px;
	border-radius: 15px 15px 0 0;
	background: #c93d84;
	color: #FFF;
}
.flow_list li .caption h2 {
	padding-left: .2em;
	font-size: 1.25rem;
	letter-spacing: .2em;
}
.flow_list li .text {
	flex: 1;
	display: flex;
	justify-content: flex-start;
	align-items: center;
	padding: 15px 20px;
}
.flow_list li .text p {
	font-weight: bold;
}


/* contact form
------------------------------------------------------------- */

.form_info {
	max-width: 800px;
	margin: 0 auto 20px;
}
.form_info > p {
	margin-bottom: 20px;
}


/* step
------------------------------------------------------------- */

.form_step {
	overflow: hidden;
	display: flex;
	justify-content: center;
	max-width: 520px;
	margin: 0 auto 20px;
	padding: 10px 0;
	font-size: 1.125rem;
	font-weight: bold;
}
.form_step li {
	position: relative;
	padding: 0 20px;
	text-align: center;
}
.form_step li::after {
	position: absolute;
	display: block;
	content: '';
	top: 50%;
	right: -5px;
	width: 9px;
	height: 16px;
	margin-top: -8px;
	background-image: url(../image/icon_arrow_no.svg);
	background-repeat: no-repeat;
	background-size: 100% auto;
	opacity: .5;
}
.form_step li:last-child::after {
	content: none;
}
.form_step .active {
	color: #c93d84;
	font-weight: bold;
}


/* form
------------------------------------------------------------- */

.form_area {
	max-width: 720px;
	margin: 0 auto 20px;
}

/* ul */
ul.form_box {
	margin: 0 -5px 35px;
}
.form_box li {
	display: flex;
	margin-bottom: 18px;
}

/* items */
.form_box .form-item {
	display: block;
	flex: 1;
	padding: 0 5px;
}
.form-item.select {
	position: relative;
}
.form-item.select .label {
	position: absolute;
	display: block;
	display: none;
	top: 2px;
	left: 9px;
	padding-right: 4em;
	height: calc(2em - 2px);
	background: #FFF;
	color: #999;
	font-size: .75rem;
	line-height: 2;
}

.form_box input[type="text"] ,
.form_box input[type="email"] ,
.form_box input[type="tel"] ,
.form_box select ,
.form_box textarea {
	width: 100%;
	height: 3em;
	padding: 0 8px;
	border: 1px solid #CCC;
	background: #FFF;
	border-radius: 4px;
}

::placeholder{
	color: #999;
	font-size: .75rem;
}

.privacy_check {
	margin-bottom: 20px;
	text-align: center;
	font-size: .875rem;
}
.privacy_check .form-item {
	display: block;
	margin-bottom: 10px;
}

/* btns */
.form_btn_list {
	text-align: center;
}
.form_btn_list li {
	margin-bottom: 10px;
}
.form_btn_list li button ,
.form_btn_list li a {
	width: 14em;
}


/* /////////////////////////////////////////////////////////////////////////////

 汎用CSS

///////////////////////////////////////////////////////////////////////////// */

/* テキスト関係 --------------------- */

.attention { /* 注意色(基本赤) */
	color: #CC0000;
}

.attentionB { /* 注意色(基本赤) */
	color: #CC0000;
	font-weight: bold;
}

.bold {
	font-weight: bold;
}

.text_SS {
	font-size: 75%;
}

.text_S {
	font-size: 86%;
}

.text_L {
	font-size: 120%;
}

.text_LL {
	font-size: 150%;
}

.text_LLL {
	font-size: 180%;
}

.highlight {
	font-size: 120%;
	font-weight: bolder;
	background: linear-gradient(transparent 50%, #fff8a5 50%);
}


/* テキスト位置設定 ---------------- */

.entry_content p.center ,
.center {
	margin: auto;
	text-align: center;
}

.left {
	text-align: left;
}

.right {
	text-align: right;
}


/* マージン関係 ------------------- */

.m0 {
	margin: 0;
}

.m10 {
	margin: 10px;
}

.mT10 {
	margin-top: 10px;
}

.mT20 {
	margin-top: 20px;
}

.mB5 {
	margin-bottom: 5px;
}

.mB10 {
	margin-bottom: 10px;
}

.mB20 {
	margin-bottom: 20px;
}

.mR5 {
	margin-right: 5px;
}

.mR10 {
	margin-right: 10px;
}

.mR20 {
	margin-right: 20px;
}

.mL5 {
	margin-left: 5px;
}

.mL10 {
	margin-left: 10px;
}

.mL20 {
	margin-left: 20px;
}

.mRL10 {
	margin: auto 10px;
}

/*　パディング関係 ------------------ */
.p0 {
	padding: 0;
}

.p10 {
	padding: 10px;
}

.pT5 {
	padding-top: 5px;
}

.pT10 {
	padding-top: 10px;
}

.pB10 {
	padding-bottom: 10px;
}

.pR10 {
	padding-right: 10px;
}

.pL10 {
	padding-left: 10px;
}

.pB20 {
	padding-bottom: 20px;
}

.pRL10 {
	padding: auto 10px;
}

/* フロート関係 ------------------- */

.floatLeft {
	float: left;
}

.floatRight {
	float: right;
}

.clear,
.clearBoth {
	clear: both;
}

.clearfix {
	/zoom : 1; /* IE6-7 */
}

.clearfix::after { /* modern */
	content : '';
	display : block;
	clear : both;
	height: 0;
}


/* 画像関係
-----------------------------------------------------------*/

.figOne {
	margin-bottom: 40px;
}

.figLeft,
.figRight {
	display: block;
	margin: 0 auto 15px;
	text-align: center;
}

.fig_list {
	margin: 0 -10px 20px;
	display: -webkit-flex;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}

.fig_list li {
	flex-grow: 0;
	width: 33.33333%;
}

.fig_list li div {
	padding: 0 10px 20px;
}



/* /////////////////////////////////////////////////////////////////////////////

 デバイス別

///////////////////////////////////////////////////////////////////////////// */

/*media Queries スマホ / PC
-----------------------------------------------------------*/

@media only screen and (max-width: 820px) {
	.sp_hide {
		display: none !important;
	}
	sup {
		font-size: 0.8rem;
	}

	/* main ////////////////////////// sp */
	/* index ------------------------- sp */
	.request_area .bottom_slide.pc_hide + .request_form {
		padding-top: 120px;
	}
	.contents_request .contents_inner {
		padding-bottom: 0;
	}
	.cover_catch .catch01 {
		text-align: center;
	}
	.cover_catch .catch02 {
		width: calc(100% + 30px);
		margin: 0 -15px 20px;
		padding: 8px 15px;
	}
	.cover_image {
		width: calc(100% + 30px);
		margin: 0 -15px;
	}
	.service_area {
		margin-top: 2em;
		padding: 0 10px;
		background: #ffffffcc;
	}
	.service_list {
		position: relative;
		top: -1em;
	}
	.service_list .inner .fig {
		margin-bottom: 10px;
	}
	.tokucho_list .text h2 {
		display: flex;
		flex-wrap: nowrap;
		align-items: baseline;
	}
	.count-number_white-box::after {
		content: ".";
	}
}

@media only screen and (min-width: 640px) {
	.header_wrapper {
		height: 65px;
	}
	.header_main {
		justify-content: space-between;
		flex-wrap: nowrap;
		align-items: center;
	}
	.header_inner .logo {
		width: 20%;
	}
	.header_inner .tel_block {
		width: 25%;
		margin-left: 2%;
	}
	.gnavi_block {
		width: 50%;
	}
}

@media only screen and (min-width: 821px) {
	.pc_hide {
		display: none !important;
	}
	.highlight {
		color: #c93d84;
		font-size: 150%;
	}
	.cover_slide {
		margin-top: -150px;
	}
	.contents.arrow::after {
		bottom: -40px;
		margin-left: -40px;
		border-width: 50px 40px 0 40px;
	}
	.contents_inner {
		padding: 80px 15px;
	}
	.header_wrapper {
		height: 100px;
	}
	.header_inner {
		padding: 25px 20px;
	}
	.header_main {
		justify-content: space-between;
		flex-wrap: nowrap;
		align-items: center;
	}
	.header_main .logo {
		width: 290px;
		max-width: 23%;
		margin-bottom: 0;
	}
	.header_inner .tel_block {
		width: 30%;
		margin-left: 2%;
	}
	.header_inner .tel_block .tel_box .number {
		font-size: min(6vw , 1.875rem);
	}
	.gnavi_block {
		width: 460px;
		max-width: 40%;
	}
	.gnavi {
		justify-content: flex-end;
	}
	.gnavi li {
		flex-grow: 1;
		margin-left: 20px;
	}
	.header_slim {
		box-shadow: 0 0 4px rgba(0,0,0,.2);
	}
	.header_slim .header_inner {
		padding: 12px 20px;
	}
	.header_slim .header_inner .logo {
		width: 20%;
	}
	.header_slim .btn_box a {
		padding: 5px 20px;
	}
	.footer_inner {
		padding: 50px 20px;
	}
	.fnavi {
		margin-bottom: 40px;
	}
	.copy_area {
		display: flex;
		justify-content: space-between;
		font-size: .8125rem;
	}
	.copy_area .text ,
	.copy_area .copy {
		white-space: nowrap;
	}

	/* main ////////////////////////// pc */
	.btn_box a ,
	.btn_box input[type="submit"] ,
	.btn_box button {
		padding: 10px 10px;
		font-size: 1.125rem;
	}
	.btn_box.btn_textL a {
		font-size: 1.75rem;
	}
	.link_box a {
		font-size: 1.25rem;
	}

	.title_block {
		margin-bottom: 20px;
	}
	.title_block h1 {
		font-size: 2rem;
	}
	.title_block h1 .medium {
		margin-top: -10px;
		font-size: 2.5rem;
	}
	.title_block h1 .large {
		font-size: 3.125rem;
	}
	.title_block .lsp2 {
		padding-right: .2em;
		letter-spacing: .2em;
	}
	.title_block p.catch {
		font-size: 1.625rem;
	}

	/* LP ---------------------------- pc */
	.cover {
		padding-top: 15px;
		padding-bottom: 15px;
	}
	.cover_area ,
	.request_area {
		padding: 50px 10px;
		display: flex;
	}
	.cover_area {
		align-items: stretch;
	}
	.cover_catch {
		padding: 10px 0;
		display: flex;
		flex-direction: column;
		flex-wrap: nowrap;
		justify-content: center;
		align-items: center;
	}
	.cover_catch .catch01 {
		margin-bottom: 45px;
		padding: 0 10px;
		font-size: 5.8vw;
	}
	.cover_catch .catch02 {
		margin-bottom: 30px;
		padding: 15px 1em;
		font-size: 2.4vw;
		text-align: justify;
	}
	.cover_catch .catch03 {
		margin-bottom: 25px;
		font-size: 1.375rem;
	}	
	.cover_btn {
		font-size: 1.5rem;
	}
	.cover_image {
		margin-left: 2.5%;
		flex-grow: 1;
		flex-direction: column;
		justify-content: space-between;
		row-gap: 10px;
	}
	.cover_image > .MV {
		width: 100%;
		max-height: 278.865px;
		flex-grow: 2;
	}
	.cover_image > .MV > img {
		object-fit: cover;
		object-position: 50% 0%;
		width: 100%;
		height: 100%;
                border-radius: 20px;
	}

	.request_area {
		align-items: center;
	}
	.request_area .title_block h1 {
		margin-right: 20px;
		font-size: min(3vw , 2.25rem);
		text-align: left;
		display: flex;
		justify-content: center;
	}
	.request_text {
		flex: 1;
	}

	/* request */
	.contents_request .contents_inner {
		max-width: 1200px;
	}
	.for_area {
		margin-bottom: 0;
		margin-right: 20px;
		padding: 25px 15px 15px;
	}
	.for_area h2 {
		font-size: 1.875rem;
	}
	.check_list {
		font-size: 1.5rem;
	}
	.check_list > li::before {
		height: 1.5rem;
	}

	/* request_form */
	.cover_area .request_form ,
	.request_area .request_form {
		max-width: 430px;
		margin-left: auto;
		margin-right: auto;
		padding: 50px 30px 60px;
		border-radius: 15px;
	}
	.request_form .privacy_check {
		margin-bottom: 25px;
	}

	/* kadai */
	.kadai_area {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		align-items: flex-end;
	}
	.kadai_list {
		padding: 5px 1em;
		font-size: 1.5rem;
	}
	.kadai_list > li::before {
		height: 1.5rem;
	}
	.kadai_area .fig {
		width: 30%;
		margin: 20px 0 0 0;
		overflow: visible;
	}
	.kadai_area .fig > img {
		max-width: calc( 100% + 24px);
		margin: 0 -12px;
	}

	/* message */
	.message_area {
		font-size: 1.625rem;
		text-align: center;
	}

	/* service */
	.service_area {
		margin-top: 40px;
	}
	.contents_service .fadein + .fadein {
		margin-top: 80px;
	}

	.contents_service .title_block > h1 > b {
		padding-left: 0.4em;
		background: linear-gradient(transparent 50%, #fff8a5 50%);
	}
	.service_list h2 {
		margin-bottom: 20px;
		display: flex;
		flex-wrap: nowrap;
		align-items: center;
		justify-content: center;
	}
	.service_list h2 em {
		display: inline-block;
		min-width: 10em;
		width: auto;
		margin: 0 1em 0 0;
		padding: 8px 1.5em;
		font-size: 1.5rem;
	}
	.service_list h2 span {
		font-size: 2.5rem;
	}
	.service_list .inner {
		display: flex;
		align-items: center;
	}
	.service_list .inner .fig {
		width: 250px;
		max-width: 40%;
		height: auto;
		margin-right: 20px;
	}
	.service_list .inner .text {
		flex: 1;
		font-size: 1.2rem;
	}

	/* tokucho */
	.contents_tokucho .contents_inner .title_block .fig {
		font-size: 3.125rem;
	}
	.tokucho_area {
		margin-top: 40px;
	}
	.tokucho_list li + li {
		margin-top: 30px;
	}
	.tokucho_list .text,.tokucho_list .subtext {
		padding: 20px;
	}
	.tokucho_list .subtext {
		margin-top: 2px;
		border: 2px solid #c93d84;
		text-align: center;
		font-size: 1.2rem;
	}
	.tokucho_list .text h2 {
		font-size: 1.625rem;
		text-align: center;
	}
	.tokucho_list .text h2.one_line {
		line-height: 3.2;
	}
	.tokucho_list .text p {
		min-height: 4.6em;
	}
	.tokucho_list .subtext p img {
		width: 75%;
	}
	.count-number_white-box {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		margin-right: 0.45em;
		padding-top: 0.125em;
		height: calc(1.25em + 0.125em);
		aspect-ratio: 1 / 1;
		text-align: center;
       		background-color: #ffffff;
	        color: #c93d84;
        	border-radius: 5px;
	}

	/* cv */
	.contents_cv {
		padding-bottom: 150px;
	}
	.cv_area {
		margin-top: 40px;
	}
	.cv_list li {
		margin-bottom: 30px;
		padding: 30px 40px;
	}
	.cv_list li > div {
		display: flex;
		align-items: center;
	}
	.cv_list .logo_block {
		width: 250px;
		max-width: 35%;
		margin: 0 40px 0 0;
	}
	.cv_list .text_block {
		flex: 1;
		font-size: 1.125rem;
	}
	.cv_list .text_block .name {
		text-align: left;
	}
	.cv_list .text_block h2 {
		margin-top: 15px;
		margin-bottom: 15px;
		font-size: 1.875rem;
	}

	/* jirei */
	.jirei_area {
		display: flex;
		flex-direction: column;
		flex-wrap: wrap;
		align-content: center;
		align-items: stretch;
	}
	dl.jirei_list {
		display: flex;
		align-items: center;
	}
	dl.jirei_list + dl.jirei_list {
		margin-top: 1em;
	}
	dl.jirei_list > dt {
		width: 6em;
		aspect-ratio: 1 / 1;
		font-size: 1.5rem;
		text-align: center;
		color: #fff8a5;
		background: #c93d84;
		border: none;
		border-radius: 100%;
		display: flex;
		justify-content: center;
		align-items: center;
	}
	dl.jirei_list > dd {
		padding: 0 0 0 0.75em;
		font-size: 1.375rem;
		font-weight: bold;
	}
	dl.jirei_list > dd sup {
		font-size: 1rem;
	}
	.sup-message {
		font-size: 1rem;
	}

	/* qa */
	.qa-1 {
		font-size: 24px;
	}
	.qa-1 summary::before {
		top: 18px;
	}
	.qa-1 p::before {
		top: 43.5px;
	}

	/* nissen */
	.nissen_area {
		display: flex;
		align-items: center;
	}
	.nissen_area .text_block {
		flex: 1;
		margin-bottom: 0px;
		font-size: 1.125rem;
	}
	.nissen_area .title_block {
		text-align: left;
	}
	.nissen_area .fig_block {
		width: 480px;
		max-width: 43%;
		padding-left: 30px;
	}

	/* flow */
	.flow_leaveit {
		margin: 20px 2% 0 2%;
		flex-direction: row;
		justify-content: center;
		gap: 1%;
	}
	.flow_leaveit > p {
		white-space: nowrap;
	}
	.flow_leaveit > .fig {
		min-height: 150px;
		max-height: 200px;
	}
	.flow_list li {
		display: flex;
		margin-bottom: 60px;
	}
	.flow_list li .caption {
		width: 280px;
		padding: 20px 10px;
		border-radius: 15px 0 0 15px;
	}
	.flow_list li .caption h2 {
		padding-left: .2em;
		font-size: 1.875rem;
		letter-spacing: .2em;
	}
	.flow_list li .text {
		padding: 30px 40px;
	}
	.flow_list li .text p {
		font-size: 1.125rem;
	}


	/* form ------------------------- pc */
	.form_box dt {
		padding: 20px 40px 10px;
	}
	.form_box dd {
		padding: 0 40px 20px;
	}
	.form_btn_list {
		display: flex;
		justify-content: center;
		flex-direction: row-reverse;
	}
	.form_btn_list li {
		margin-bottom: 0;
		padding: 0 10px;
	}

	/* common //////////////////////// pc */
	.figLeft {
		float: left;
		margin-right: 30px;
		margin-bottom: 10px;
	}
	.figRight {
		float: right;
		margin-left: 20px;
		margin-bottom: 10px;
	}
}

@media only screen and (min-width: 1100px) {
	.cover_catch .catch02 {
		font-size: 1.75rem;
	}
	.cover_catch .catch03 {
		font-size: 1.75rem;
	}
	.cover_catch .catch01 {
		font-size: 4.25rem;
	}
}
