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

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

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

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

 全体 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: #313131;
	font-size: 1rem;
	font-family: 'Hiragino Kaku Gothic Pro','ヒラギノ角ゴ Pro W3','メイリオ',Meiryo,'ＭＳ Ｐゴシック','MS PGothic',sans-serif;
	line-height: 1.6;
	background: #FFF;
	background-attachment: fixed;
}

a {
	color: #002e73;
	text-decoration: underline;
}

a:hover {
	color: #1c51a0;
	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

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

.main_contents {
	margin: 0 auto;
}
body.child .main_contents {
	margin-top: 100px;
}


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

.contents {
	position: relative;
	clear: both;
	zoom: 100%;
}
.contents.wh {
	background-color: #FFF;
}
.contents.bgy {
	background: rgb(132,179,201);
	background: radial-gradient(circle, rgba(132,179,201,1) 0%, rgba(75,122,144,1) 100%);
}
.contents.lbu {
	background-color: #ddf7ff;
}
.contents.pbu {
	background-color: #e2edf1;
}
.contents.grade {
	background: rgb(137,247,254);
	background: linear-gradient(90deg, rgba(137,247,254,1) 0%, rgba(107,177,255,1) 100%);
}
.contents.grade::before ,
.contents.grade::after {
	position: absolute;
	display: block;
	content: '';
	width: 400px;
	max-width: 100%;
	height: 400px;
	max-height: 100%;
	background-repeat: no-repeat;
	background-size: 120%;
}
.contents.grade::before {
	top: 0;
	left: 0;
	background-image: url(../image/bg_square01.png);
	background-position: right bottom;
}
.contents.grade::after {
	bottom: 0;
	right: 0;
	background-image: url(../image/bg_square02.png);
	background-position: left top;
}
.contents.contents_nayami + .contents::before {
	position: absolute;
	display: block;
	content: '';
	top: -1px;
	left: calc(50% - 20px);
	width: 40px;
	height: 35px;
	background-color: #5a899f;
	clip-path: polygon(0 0, 100% 0, 50% 100%);
}

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

@media only screen and (min-width: 821px) {
	.contents.contents_nayami + .contents::before {
		left: calc(50% - 30px);
		width: 60px;
		height: 50px;
		background-color: #6c9cb1;
	}	
	.contents_inner {
		padding: 60px 15px;
	}
}


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

 header

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

.header_wrapper {
	height: 0;
}
.header {
	position: fixed;
	z-index: 999999;
	top: 0;
	left: 0;
	width: 100%;
	transition: 300ms;
}
body.child .header {
	background: rgb(137,247,254);
	background: linear-gradient(90deg, rgba(137,247,254,1) 0%, rgba(107,177,255,1) 100%);
}
.header_inner {
	position: relative;
	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 {
	text-align: center;
	line-height: 1;
}
.header_inner .tel_block .tel_box .time {
	display: block;
	margin-bottom: 4px;
	font-size: .75rem;
}
.header_inner .tel_block .tel_box .number {
	padding-left: 0;
	color: #FFF;
	font-size: min(1.5rem,5.35vw);
	text-shadow: 0px 0px 10px rgba(4, 4, 4, .65);
	white-space: nowrap;
}
.header_inner .tel_block .tel_box .number a {
	color: #FFF;
}

/* header/footer 共通 */
.tel_box .number {
	display: block;
	padding-left: .1em;
	font-size: 1.875rem;
	font-family: 'Questrial', sans-serif;
	font-weight: bold;
	letter-spacing: .1em;
}
.tel_box a ,
.tel_box a:link ,
.tel_box a:visited ,
.tel_box a:hover {
	pointer-events: none;
	text-decoration: none!important;
}
.tel_box a::before ,
.tel_box a::after {
	content: none!important;
	animation: none;
	transform: none;
	transition: unset;
}

.header_slim {
	background: rgb(137,247,254);
	background: linear-gradient(90deg, rgba(137,247,254,1) 0%, rgba(107,177,255,1) 100%);
}

@media only screen and (min-width: 640px) {
	.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%;
	}
}
@media only screen and (min-width: 821px) {
	.header_wrapper {
		height: 0;
	}
	.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);
	}
	.header_slim .header_inner {
		padding: 12px 20px;
	}
	.header_slim .header_inner .logo {
		width: 20%;
	}
	.header_slim .btn_box a {
		padding: 5px 20px;
	}
}

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

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

@media only screen and (min-width: 640px) {
	/*.gnavi_block {
		width: 50%;
	}*/
}
@media only screen and (min-width: 821px) {
	.gnavi_block {
		width: 460px;
		max-width: 40%;
		margin: auto;
	}
	.gnavi {
		justify-content: flex-end;
	}
	.gnavi li {
		flex-grow: 1;
		margin-left: 20px;
		margin-right: auto;
	}
}


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

 .footer

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

.footer {
	background: #efeded;
}

.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;
	text-align: center;
	line-height: 1;
}
.fnavi .tel_box .time {
	display: inline-block;
	margin-left: 1em;
}
.fnavi .tel_box .number {
	display: inline-block;
	letter-spacing: .2em;
}
.fnavi .tel_box .number a {
	background: rgb(32,156,255);
	background: linear-gradient(90deg, rgba(32,156,255,1) 0%, rgba(104,224,207,1) 100%);
	-moz-background-clip: text;
	-webkit-background-clip: text;
	background-clip: text;
	-moz-text-fill-color: transparent;
	-webkit-text-fill-color: transparent;
	color: #209cff!important;
}


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

.copy_area {
	font-size: min(.8125rem,3vw);
}
.copy_area .text {
	margin-bottom: 10px;
}
.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(32, 110, 218, .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);
}

@media only screen and (min-width: 821px) {
	.footer_inner {
		padding: 50px 20px;
	}
	.fnavi {
		margin-bottom: 40px;
	}
	.fnavi .btn_box {
		margin-bottom: 0
	}
	.fnavi .tel_box .number {
		margin-left: .7em;
	}	
	.copy_area {
		text-align: center;
	}
	.copy_area .text {
		margin-bottom: 15px;
	}
	.copy_area .text ,
	.copy_area .copy {
		white-space: nowrap;
	}
	.figLeft {
		float: left;
		margin-right: 30px;
		margin-bottom: 10px;
	}
	.figRight {
		float: right;
		margin-left: 20px;
		margin-bottom: 10px;
	}
}


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

 メインコンテンツ

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

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

.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: 240px;
	max-width: 100%;
	padding: 4px 10px;
	border-radius: 50vh;
	border: none;
	background: rgb(30,60,114);
	background: linear-gradient(90deg, rgba(30,60,114,1) 0%, rgba(42,82,152,1) 100%);
	color: #FFF;
	font-size: min(1rem,4vw);
	font-weight: 600;
	text-align: center;
	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;
}
p.btn_box + p.btn_box {
	padding-top: 0;
}

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

.btn_box.btn_large a {
	width: 480px;
	max-width: 100%;
	padding: 12px 10px;
	font-size: min(1.125rem,4vw);
}

/* dark blue */
.btn_box.btn_dbgrade a ,
.btn_box.btn_dbgrade input[type="submit"] ,
.btn_box.btn_dbgrade button {
	border:  2px solid rgb(80, 108, 165);
	border-right-color:  rgb(18, 44, 92);
	border-bottom-color: rgb(18, 44, 92);
	background: rgb(30,60,114);
	background: linear-gradient(90deg, rgba(30,60,114,1) 0%, rgba(42,82,152,1) 100%);
	box-shadow: 0 2px 8px rgba(0, 0, 0, .3);
	color: #FFF;
}

/* orange */
.btn_box.btn_orgrade a ,
.btn_box.btn_orgrade input[type="submit"] ,
.btn_box.btn_orgrade button {
	border:  2px solid rgb(249, 215, 89);
	border-right-color:  rgb(224, 84, 46);
	border-bottom-color: rgb(242, 164, 61);
	background: rgb(250,204,34);
	background: linear-gradient(90deg, rgba(250,204,34,1) 0%, rgba(248,54,0,1) 100%);
	box-shadow: 0 2px 8px rgba(0, 0, 0, .3);
	color: #FFF;
	text-shadow: 0px 0px 10px rgba(4, 4, 4, .65);
}

/* disabled */
.btn_box.btn_dbgrade button:disabled ,
.btn_box.btn_dbgrade input:disabled ,
.btn_box.btn_orgrade button:disabled ,
.btn_box.btn_orgrade input:disabled {
	opacity: .75;
}

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

@media only screen and (max-width: 820px) {
	.btn_box.btn_large a {
		letter-spacing: -.01em;
	}	
}



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

@media only screen and (min-width: 821px) {
	.btn_box a ,
	.btn_box input[type="submit"] ,
	.btn_box button {
		padding: 12px 10px;
		font-size: 1.125rem;
	}
	.link_box a {
		font-size: 1.25rem;
	}
}


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

/* fadein */
.fadein {
	opacity : 0;
	transform : translate(0, 50px);
	transition : all 400ms;
}
.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 h1 {
	color: #002e73;
	line-height: 1.6;
}
.title_block h1 .ja_L {
	display: inline-block;
	padding-left: .15em;
	letter-spacing: .15em;
	font-size: min(2.25rem,6.5vw);
}
.title_block h1 .ja {
	display: inline-block;
	padding-left: .15em;
	letter-spacing: .15em;
	font-size: min(2rem,6vw);
}
.title_block h1 .ja_M {
	display: inline-block;
	font-size: min(1.75rem,5.5vw);
}
.title_block h1 .ja_S {
	display: inline-block;
	font-size: min(1.5rem,4.5vw);
}
.title_block h1 .long {
	padding-left: 0;
	letter-spacing: 0;
}
.title_block h1 .large {
	font-size: 120%;
}
.title_block h1 small {
	font-size: 80%;
}
.title_block .fuki {
	position: relative;
	display: inline-block;
	width: 8em;
	margin-bottom: .5em;
	padding-top: 10px;
	padding-bottom: 10px;
	border-radius: 24px;
	background-color: #FFF;
	box-shadow: 0px 5px 40px rgba(0, 0, 0, .2);
}
.title_block .fuki::after {
	position: absolute;
	display: block;
	content: '';
	left: calc(50% - 10px);
	bottom: -28px;
	width: 40px;
	height: 30px;
	background-color: #FFF;
	clip-path: polygon(0 0, 70% 0, 100% 100%);
}
.title_block .dots {
	padding-top: .4em;
	background-image: radial-gradient(circle at center, #f3b31b 20%, transparent 20%);
	background-position: 95% top;
	background-repeat: repeat-x;
	background-size: 1.15em 0.3em;
}
.title_block .catch {
	margin-top: 1em;
	font-size: min(1.25rem,4.5vw);
}

@media only screen and (min-width: 821px) {
	.title_block {
		margin-bottom: 40px;
	}
}

/* テキスト
-----------------------------------------------------------*/

.text_block p {
	margin-bottom: 1.8em;
}
.text_block p:last-child {
	margin-bottom: .4em;
}

.marker__txt {
	display: inline;
	padding: 0 .15em .25em;
}
.marker__txt.yw {
	background: #fffab4;
}
.marker__txt.lbu {
	background: linear-gradient(transparent 50%, #cdf1f8 0%);
}
.marker__txt.bgyh {
	background: linear-gradient(transparent 50%, #4b8098 0%);
}
.marker__txt.ywh {
	background: linear-gradient(transparent 50%, #fff799 0%);
}
.marker__txt.pkh {
	background: linear-gradient(transparent 50%, #f9deef 0%);
}
.marker__txt.orh {
	background: linear-gradient(transparent 50%, #facd89 0%);
}

.text_shadow {
	text-shadow: 0px 0px 9px rgba(0, 0, 0, .7);
}

.color__sky {
	color: #48a9e5;
}
.color__lbu {
	color: #438ab6;
}
.color__yw {
	color: #fff799;
}
.color__dyw {
	color: #f3b31b;
}
.color__or {
	color: #f19149;
}
.color__dbu {
	color: #0c293b;
}

.inline__underline {
	display: inline-block;
	margin-bottom: .25em;
	border-bottom: 2px solid #f19149;
	line-height: 1.4;
}

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

 lp

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

.cover {
	position: relative;
	background-color: #d3ebfb;
}

.cover .cover_inner {
	max-width: 1100px;
	margin: 0 auto;
}
.cover .cover_inner::before,
.cover::after {
	position: absolute;
	display: block;
	content: '';
	left: 0;
	width: 100%;
	height: 35vw;
	background: rgb(137,247,254);
	background: linear-gradient(90deg, rgba(137,247,254,1) 0%, rgba(107,177,255,1) 100%);
}
.cover .cover_inner::before {
	top: 0;
	clip-path: polygon(0 0, 100% 0, 100% 100%, 0 70%);
	z-index: 1;
}
.cover::after {
	bottom: 0;
	clip-path: polygon(0 0, 100% 70%, 100% 100%, 0 100%);
	z-index: 3;
}

.cover .cover_image {
	position: relative;
	padding: 0 10%;
	text-align: center;
	z-index: 2;
}
.cover .cover_image .catch01 {
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	padding: 20px;
}
.cover .cover_form {
	padding: 0 20px;
	z-index: 4;
}

@media only screen and (max-width: 820px) {
	.cover .cover_inner {
		position: relative;
		padding: 120px 0 40px;
		z-index: 4;
	}
}
@media only screen and (min-width: 821px) {
	.cover {
		padding: 80px 20px 0;
	}
	.cover .cover_inner::before,
	.cover::after {
		height: 13vw;
	}
	.cover .cover_inner::before {
		clip-path: polygon(0 0, 100% 0, 100% 100%, 0 50%);
	}
	.cover::after {
		clip-path: polygon(0 0, 100% 50%, 100% 100%, 0 100%);
	}
	.cover .cover_inner {
		display: flex;
		align-items: center;
	}
	.cover_catch {
		position: absolute;
		left: 0;
		bottom: 50px;
		width: 100%;
		z-index: 5;
	}
	.cover_catch .catch01 {
		position: relative;
		max-width: 1100px;
		margin: 0 auto;
	}
	.cover_catch .catch01 img {
		position: absolute;
		left: 20px;
		bottom: 0;
		max-width: 55%;
	}
	.cover_ver02 .cover_catch .catch01 img {
		bottom: -80px;
	}
	.cover .cover_form {
		width: 380px;
		padding: 0;
	}
	.cover .cover_image {
		flex: 1;
		padding: 0;
	}
}
@media only screen and (min-width: 821px) and (max-width: 980px) {
	.cover_catch .catch01 img {
		max-width: 52%;
	}
}

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

.request_area {
	max-width: 960px;
	margin: 0 auto;
}
.request_text {
	text-align: left;
}
.request_text .title_block {
	margin-bottom: 20px;
}
.for_block {
	margin-bottom: 20px;
}
.for_block {
	margin-bottom: 20px;
}
.for_block .fig_box {
	margin-bottom: 20px;
}
.for_block .fig_box img {
	width: 200px;
	max-width: 60%;
}
.for_block h2 {
	margin-bottom: 20px;
	padding: 4px 0;
	border-radius: 50vh;
	background-color: #FFF;
	font-size: min(1.125rem, 4.5vw);
	text-align: center;
}

/* check_list */
.check_list {
	margin-right: -10px;
	font-size: min(.9375rem, 4vw);
	font-weight: bold;
	line-height: 1.5;
}
.check_list li {
	position: relative;
	padding-top: .5em;
	padding-bottom: .5em;
	padding-left: 2em;
	background-size: auto 2px;
}
.check_list li:last-child {
	background: none;
}
.check_list > li::before {
	position: absolute;
	display: block;
	content: '';
	top: .5em;
	left: .25em;
	width: 30px;
	height: 24px;
	background: url(../image/icon_check01sq.svg) no-repeat;
}


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

.cover .request_form ,
.request_area .request_form {
	padding: 20px 10px;
	background: #FFF;
	box-shadow: 0px 0px 30px rgba(0, 0, 0, .2);
	border-radius: 15px;
}

.request_form h2 {
	margin-bottom: 20px;
	text-align: center;
	line-height: 1;
}
.request_form h2 b {
	display: inline-block;
	color: #002e73;
	font-size: min(1.25rem,5vw);
	letter-spacing: .15em;
	vertical-align: middle;
}
.request_form h2 span {
	display: inline-block;
	margin-left: 1em;
	padding: 3px 8px;
	background: #bdf5b3;
	color: #303131;
	font-weight: normal;
	vertical-align: middle;
}
.request_form .text {
	margin-bottom: 30px;
	font-size: .75rem;
	text-align: center;
}
.request_form .form_box {
	max-width: 520px;
	margin: 0 auto 10px;
	font-size: .875rem;
}
.request_form .privacy_check {
	font-size: .75rem;
}
.request_form .btn_box.btn_orgrade button {
	letter-spacing: 0;
}
.request_form .btn_box button {
	width: 100%;
}

@media only screen and (min-width: 821px) {
	.request_area {
		display: flex;
		justify-content: space-between;
		align-items: center;
	}
	.request_text {
		flex: 1;
	}
	.for_block {
		position: relative;
		margin-bottom: 0;
		margin-right: 40px;
	}
	.check_list {
		padding-left: 1.5em;
	}

	/* request_form */
	.cover .request_form ,
	.request_area .request_form {
		max-width: 410px;
		margin-left: auto;
		margin-right: auto;
		padding: 30px 30px;
	}
	.request_form h2 {
		margin-bottom: 20px;
	}
	.request_form .text {
		margin-bottom: 20px;
	}
	.request_form .form_box {
		margin-bottom: 20px;
	}
	.request_form .privacy_check {
		margin-bottom: 25px;
	}
}


/* voice
------------------------------------------------------------- */

.voice_list li {
	margin-bottom: 20px;
}
.voice_block {
	padding: 20px;
	background-color: #FFF;
	box-shadow: 0px 0px 30px rgba(0, 0, 0, .2);
	border-radius: 24px;
}
.voice_block .logo_box {
	margin-bottom: 15px;
	text-align: center;
}
.voice_block .logo_box img {
	width: 60%;
}
.voice_block .text_box {
	color: #002e73;
	font-size: .9375rem;
}
.voice_block .text_box h2 {
	margin-bottom: 1em;
	padding-bottom: .75em;
	border-bottom: 2px solid #002e73;
	font-size: 1.0625rem;
}
.voice_block .text_box p {
	margin-right: -.75em;
}

@media only screen and (min-width: 821px) {
	.voice_list {
		display: flex;
		margin: 0 -15px;
	}
	.voice_list li {
		width: 33.33333%;
		padding: 0 15px;
	}
	.voice_block {
		padding: 30px;
		height: 100%;
	}
	.voice_block .logo_box img {
		width: auto;
	}
}

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

.download_area .title_block {
	margin-bottom: 15px;
}
.download_area .btn_box {
	padding-top: 0;
}
.download_fig_block {
	position: absolute;
	right: 0;
	bottom: 0;
}
.download_fig_block img {
	max-width: 35vw;
	margin-right: -5vw;
}
@media only screen and (min-width: 821px) {
	.download_area .title_block {
		margin-bottom: 35px;
	}
}


/* nayami
------------------------------------------------------------- */

.contents_nayami .title_block h1 {
	color: #FFF;
}
.nayami_list {
	display: flex;
}
.nayami_list li:nth-child(1) {
	width: 32%;
	margin-top: 22%;
}
.nayami_list li:nth-child(2) {
	width: 40%;
	margin-top: 5%;
	margin-left: -15%;
}
.nayami_list li:nth-child(3) {
	width: 30%;
	margin-left: -2%;
	margin-right: -17%;
}
.nayami_list li:nth-child(4) {
	width: 36%;
	margin-top: 18%;
	margin-right: -5%;
}
.nayami_list li > div {
	position: relative;
}
.nayami_list .text_box {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
}
.nayami_list .text_box p {
	font-size: min(1.5rem,3.25vw);
	font-weight: 600;
}

.nayami_area .fig_box {
	margin-top: -50px;
	text-align: center;
}
.nayami_area .fig_box img {
	max-width: 60%;
}

@media only screen and (min-width: 821px) {
	.nayami_list li:nth-child(1) {
		width: 24.5%;
		width: 27%;
		margin-top: 10%;
	}
	.nayami_list li:nth-child(2) {
		width: 34%;
		margin-top: -2%;
		margin-left: -7%;
	}
	.nayami_list li:nth-child(3) {
		width: 25%;
		margin-right: -5%;
		margin-left: -1%;
	}
	.nayami_list li:nth-child(4) {
		width: 31%;
		margin-top: 10%;
	}
	.nayami_area .fig_box {
		margin-top: -100px;
	}
}


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

.contents_message .title_block {
	margin-bottom: 0;
}


/* feature
------------------------------------------------------------- */

.feature_block:not(:last-child) {
	margin-bottom: 30px;
}
.feature_block .fig_box {
	position: relative;
	margin-bottom: -20px;
	text-align: center;
	z-index: 2;
}
.feature_block .fig_box img {
	width: 80%;
	border-radius: 24px;
	box-shadow: 0px 0px 30px rgba(0, 0, 0, .2);
}
.feature_block .text_box {
	position: relative;
	padding: 35px 20px 20px;
}
.feature_block .text_box::before {
	position: absolute;
	display: block;
	content: '';
	top: 0;
	width: 100%;
	height: 100%;
	border-radius: 24px;
	background: rgba(137,247,254,.4);
	background: linear-gradient(90deg, rgba(137,247,254,.45) 0%, rgba(107,177,255,.45) 100%);
}
.feature_block .text_box .inner {
	position: relative;
}
.feature_block .text_box h2 {
	position: relative;
	margin-bottom: .5em;
	padding-bottom: .5em;
	font-size: min(1.75rem,6vw);
}
.feature_block .text_box h2::after {
	position: absolute;
	display: block;
	content: '';
	bottom: 0;
	width: 100%;
	height: 0;
	border-bottom: 2px solid #FFF;
}
.feature_block:nth-child(2n-1) .text_box::before ,
.feature_block:nth-child(2n-1) .text_box h2::after {
	left: 0;
}
.feature_block:nth-child(2n) .text_box h2::after ,
.feature_block:nth-child(2n) .text_box::before {
	right: 0;
}
.feature_block .text_box h2 .pont {
	display: block;
	margin-bottom: 10px;
	font-size: min(2.5rem,8vw);
	line-height: 1;
}
.feature_block .text_box h2 .pont img {
	height: 1em;
}
.feature_block .text_box h2 .caption {
	display: inline-block;
	background: rgb(51,95,160);
	background: linear-gradient(90deg, rgba(51,95,160,1) 0%, rgba(29,213,230,1) 100%);
	-moz-background-clip: text;
	-webkit-background-clip: text;
	background-clip: text;
	-moz-text-fill-color: transparent;
	-webkit-text-fill-color: transparent;
	color: #1dd5e6!important;
	font-style: italic;
}
.feature_block .text_box p {
	color: #002e73;
	font-size: min(1.375rem,4.25vw);
}

@media only screen and (min-width: 821px) {
	.feature_area {
		margin-bottom: 40px;
		padding-top: 40px;
	}
	.feature_block {
		display: flex;
		justify-content: center;
	}
	.feature_block:not(:last-child) {
		margin-bottom: 80px;
	}
	.feature_block:nth-child(2n-1) {
		flex-direction: row-reverse;
	}
	.feature_block .fig_box {
		width: 450px;
		max-width: 45%;
		margin-bottom: 60px;
	}
	.feature_block .fig_box img {
		width: auto;
	}
	.feature_block .text_box {
		flex: 1;
		margin-top: 70px;
		padding: 40px;
	}
	.feature_block:nth-child(2n-1) .text_box::before {
		width: calc(140%);
	}
	.feature_block:nth-child(2n-1) .text_box h2::after {
		width: calc(140%);		
	}
	.feature_block:nth-child(2n) .text_box::before {
		width: calc(140%);
	}
	.feature_block:nth-child(2n) .text_box h2::after {
		width: calc(140%);		
	}
	.feature_block .text_box h2 {
		position: relative;
		display: flex;
		align-items: center;
		min-height: 4em;
		margin-bottom: 1em;
	}
	.feature_block:nth-child(2n) .text_box h2 {
		justify-content: end;
	}
	.feature_block:nth-child(2n) .text_box {
		text-align: right;
	}
}


/* efficacy
------------------------------------------------------------- */

.efficacy_block {
	padding: 20px;
	border-radius: 18px;
	background-color: #FFF;
	box-shadow: 0px 0px 30px 0px rgba(0, 0, 0, .2);
}
.efficacy_block .fig_box {
	margin: 20px 0;
	text-align: center;
}
.efficacy_block .fig_box img {
	width: 60%;
}
.efficacy_block .text_box {
	font-size: min(1.125rem,4vw);
	font-weight: 600;	
}
.efficacy_block .text_box ul li {
	padding-left: 1em;
	text-indent: -1em;
}
.efficacy_block h2 {
	margin-bottom: 15px;
	font-size: min(1.875rem,6vw);
}
.efficacy_block h2 {
	display: inline-block;
	background: rgb(250,204,34);
	background: linear-gradient(90deg, rgba(250,204,34,1) 0%, rgba(248,54,0,1) 100%);
	-moz-background-clip: text;
	-webkit-background-clip: text;
	background-clip: text;
	-moz-text-fill-color: transparent;
	-webkit-text-fill-color: transparent;
	color: #f0613a!important;
}
.efficacy_block .btn_box {
	padding-bottom: 0;
}
@media only screen and (min-width: 821px) {
	.efficacy_block {
		display: flex;
		padding: 50px;
	}
	.efficacy_block .fig_box {
		width: 240px;
		max-width: 25%;
		margin: 0;
		margin-right: 40px;
	}
	.efficacy_block .fig_box img {
		width: auto;
	}
	.efficacy_block .text_box {
		flex: 1;
	}
	
}


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

.flow_area {
	max-width: 780px;
	margin: 0 auto;
}
.flow_list li {
	position: relative;
	margin-bottom: 40px;
}
.flow_list li:last-child {
	margin-bottom: 0;
}
.flow_list li::after {
	position: absolute;
	display: block;
	content: '';
	left: 50%;
	bottom: -30px;
	margin-left: -12px;
	width: 24px;
	height: 16px;
	background: url('data:image/svg+xml,%3Csvg%20height%3D%2224.5%22%20width%3D%2233.5%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22m26.814%207.5-11.314%2011.314-11.314-11.314%22%20fill%3D%22none%22%20stroke%3D%22%23002e73%22%20stroke-linecap%3D%22round%22%20stroke-width%3D%222%22%2F%3E%3C%2Fsvg%3E') no-repeat;
	background-size: 100% auto;
}
.flow_list li:last-child::after {
	content: none;
}
.flow_list li .caption {
	position: relative;
}
.flow_list li .caption h2 {
	margin-bottom: 15px;
	padding: 6px 0 6px .15em;
	border-radius: 50vh;
	background: rgb(32,156,255);
	background: linear-gradient(90deg, rgba(32,156,255,1) 0%, rgba(104,224,207,1) 100%);
	color: #FFF;
	font-size: min(1.375rem,5vw);
	text-align: center;
	letter-spacing: .15em;
}
.flow_list li .text {
	flex: 1;
	font-weight: 600;
	text-align: center;
}
@media only screen and (min-width: 821px) {
	.flow_list li {
		display: flex;
		align-items: center;
		margin-bottom: 44px;
	}
	.flow_list li::after {
		left: 135px;
		margin-left: 0;
	}
	.flow_list li .caption {
		width: 280px;
		margin-right: 60px;
	}
	.flow_list li .caption h2 {
		margin-bottom: 0;
	}
	.flow_list li .text {
		font-size: 1.125rem;
		text-align: left;
	}
}


/* faq
----------------------------------------------------------- */

.faq_area {
	max-width: 720px;
	margin: 0 auto;
	padding: 10px;
}

.faq_block {
	position: relative;
	margin-bottom: 15px;
	padding: 15px;
	background-color: #FFF;
	color: #002e73;
}
.faq_block label {
	position: relative;
	cursor: pointer;
	display: block;
	padding-left: 40px;
	padding-right: 30px;
	font-size: min(1.375rem,4.5vw);
	font-weight: 600;
}
.faq_block label span {
	display: block;
}

.faq_block label::before ,
.faq_block .txt::before {
	position: absolute;
	left: .2em;
	font-size: min(1.75rem,6.5vw);
	font-weight: 600;
}
.faq_block label::before {
	content: 'Q';
	top: -.15em;
	color: #448aca;
}
.faq_block .txt::before {
	content: 'A';
	top: 0;
	color: #f19149;
	transition: 0.4s;
}
.faq_block .vibtn:checked ~ .txt::before {
	top: .25em;
}

/* アコーディオン */
.faq_block .txt {
	position: relative;
	opacity: 0;
	height: 0;
	margin: 0;
	padding-left: 40px;
	transition: 0.4s;
}
.faq_block .vibtn:checked ~ .txt {
	height: auto;
	opacity: 1;
	margin-top: 10px;
	padding-top: 10px;
	border-top: 1px solid #002e73;
}

/* vibtn */
.faq_block .vibtn {
	position: absolute;
	visibility: hidden;
}

/* icon */
.faq_block .icon::before ,
.faq_block .icon::after {
	position: absolute;
	visibility: visible;
	content: '';
	top: 28px;
	right: 20px;
	width: 20px;
	height: 0;
	border-top: 2px solid #002e73;
}
.faq_block .icon::before {
	transform: rotate(90deg);
	transition: 0.4s;
}
.faq_block .vibtn:checked + .icon::before {
	transform: rotate(0);
}

@media only screen and (min-width: 821px) {
	.faq_block {
		margin-bottom: 20px;
		padding: 20px;
	}
	.faq_block .vibtn:checked ~ .txt {
		margin-top: 15px;
		padding-top: 15px;
	}
	.faq_block .icon::before ,
	.faq_block .icon::after {
		top: 36px;
		width: 24px;
		border-top: 3px solid #002e73;
	}
	.faq_block .txt {
		font-size: 1.125rem;
	}
	.faq_block label::before {
		top: -.25em;
	}
}


/* 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: #66a6ff;
	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: 10px;
}

/* 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;
}

.form_area .btn_box a ,
.form_area .btn_box button {
	width: 16em;
}
.document_block .btn_box a {
	width: 460px;
}

@media only screen and (min-width: 821px) {
	.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;
	}
}


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

 汎用CSS

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

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

.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%;
}

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

.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 {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	margin: 0 -5px 20px;
}
.fig_list li {
	flex-grow: 0;
	width: 50%;
	padding: 0 5px 10px;
}
.fig_list.sepa01 li {
	width: 100%;
}

@media only screen and (min-width: 769px) {
	.figLeft {
		float: left;
		margin-right: 30px;
		margin-bottom: 10px;
	}
	.figRight {
		float: right;
		margin-left: 20px;
		margin-bottom: 10px;
	}
	.fig_list {
		margin: 0 -10px;
	}
	.fig_list li {
		padding: 0 10px 20px;
	}
	.fig_list.sepa01 li {
		width: 70%;
	}
	.fig_list.sepa02 li {
		width: 50%;
	}
	.fig_list.sepa03 li {
		width: 33.33333%;
	}
	.fig_list.sepa04 li {
		width: 25%;
	}
}


@media only screen and (max-width: 820px) {
	.sp_hide {
		display: none;
	}
}

@media only screen and (min-width: 821px) {
	.pc_hide {
		display: none;
	}
}